Found an issue with the book? Report it on Github.
Let us return now to an engineering context. For readers who are more familiar with electrical systems, consider the following circuit:
Suppose we want to solve for: , , and . To solve for each of the currents , and , we can use the equations associated with inductors, resistors and capacitors, respectively:
where is the battery voltage.
Since we have only 3 equations, but 4 variables, we need one additional equation. That additional equation is going to be Kirchoff’s current law:
Now that we have determined the equations and variables for this problem, we will create a basic model (including physical types) by translating the equations directly into Modelica. But in a later section on Electrical Components we will return to this same circuit and demonstrate how to create models by dragging, dropping and connecting models that really look like the circuit components in our Low-Pass RLC Filter.
But for now, we will build a model composed simply of variables and equations. Such a model could be written as follows:
model RLC1 "A resistor-inductor-capacitor circuit model"
type Voltage=Real(unit="V");
type Current=Real(unit="A");
type Resistance=Real(unit="Ohm");
type Capacitance=Real(unit="F");
type Inductance=Real(unit="H");
parameter Voltage Vb=24 "Battery voltage";
parameter Inductance L = 1;
parameter Resistance R = 100;
parameter Capacitance C = 1e-3;
Voltage V;
Current i_L;
Current i_R;
Current i_C;
equation
V = i_R*R;
C*der(V) = i_C;
L*der(i_L) = (Vb-V);
i_L=i_R+i_C;
end RLC1;
Let’s go through this example bit by bit and reinforce the meaning of the various statements. Let’s start at the top:
model RLC1 "A resistor-inductor-capacitor circuit model"
Here we see that the name of the model is RLC1
. Furthermore, a
description of this model has been included, namely "A
resistor-inductor-capacitor circuit model"
. Next, we introduce a
few physical types that we will need:
type Voltage=Real(unit="V");
type Current=Real(unit="A");
type Resistance=Real(unit="Ohm");
type Capacitance=Real(unit="F");
type Inductance=Real(unit="H");
Each of these lines introduces a physical type that specializes the
built-in Real
type by associating it with a particular physical
unit. Then, we declare all of the parameter
variables in our
problem:
parameter Voltage Vb=24 "Battery voltage";
parameter Inductance L = 1;
parameter Resistance R = 100;
parameter Capacitance C = 1e-3;
These parameter
variables represent various physical
characteristics (in this case, voltage, inductance, resistance and
capacitance, respectively). The last variables we need to define are
the ones we wish to solve for, i.e.,
Voltage V;
Current i_L;
Current i_R;
Current i_C;
Now that all the variables have been declared, we add an equation
section to the model that specifies the equations to use when
generating solutions for this model:
equation
V = i_R*R;
C*der(V) = i_C;
L*der(i_L) = (Vb-V);
i_L=i_R+i_C;
Finally, we close the model by creating an end
statement that
includes the model
name (i.e., RLC1
in this case):
end RLC1;
One thing that distinguishes this example from the previous examples
is the fact that it contains more equations. As with the
NewtonCooling
example, we have some equations with expressions on
both the left and right hand sides. We also have a mix of
differential equation (ones that include the derivative of a variable)
and others that are simply algebraic equations.
This further emphasizes the point that in Modelica it is not necessary to put the system of equations into the so-called “explicit state-space form” required in some modeling environments. We could, of course, rearrange the equations into a more explicit form like this:
der(V) = i_C/C;
der(i_L) = (Vb-V)/L;
i_R = i_L-i_C;
V = i_R*R;
But the important point is that with Modelica, we do not need to perform such manipulations. Instead, we are free to write the equations in whatever form we chose.
Ultimately, these equations will probably need to be manipulated into a form like explicit state-space form. But if such manipulations are necessary, it will be the responsibility of the Modelica compiler, not the model developer, to perform these manipulations. This eliminates the need for the model developer to deal with this tedious, time consuming and error prone task.
The ability to keep equations in their “textbook form” is important because, as we will show in later sections, we eventually want to get to the point where these equations are “captured” in individual components models. In those cases, we won’t know (when we create the component model) exactly what variable each equation will be used to solve for. Making such manipulations the responsibility of the Modelica compiler not only makes the model development faster and easier, but it dramatically improves the reusability of the models.
The following figure shows the dynamic response of the RLC1
model: