Simscape™ User's Guide
Simscape™ User's Guide
User’s Guide
R2014a
How to Contact MathWorks
www.mathworks.com                 Web
comp.soft-sys.matlab              Newsgroup
www.mathworks.com/contact_TS.html Technical Support
508-647-7000 (Phone)
508-647-7001 (Fax)
Trademarks
MATLAB and Simulink are registered trademarks of The MathWorks, Inc. See
www.mathworks.com/trademarks for a list of additional trademarks. Other product or brand
names may be trademarks or registered trademarks of their respective holders.
Patents
MathWorks products are protected by one or more U.S. patents. Please see
www.mathworks.com/patents for more information.
Revision History
March 2007         Online   only   New for Version 1.0 (Release 2007a)
September 2007     Online   only   Revised for Version 2.0 (Release 2007b)
March 2008         Online   only   Revised for Version 2.1 (Release 2008a)
October 2008       Online   only   Revised for Version 3.0 (Release 2008b)
March 2009         Online   only   Revised for Version 3.1 (Release 2009a)
September 2009     Online   only   Revised for Version 3.2 (Release 2009b)
March 2010         Online   only   Revised for Version 3.3 (Release 2010a)
September 2010     Online   only   Revised for Version 3.4 (Release 2010b)
April 2011         Online   only   Revised for Version 3.5 (Release 2011a)
September 2011     Online   only   Revised for Version 3.6 (Release 2011b)
March 2012         Online   only   Revised for Version 3.7 (Release 2012a)
September 2012     Online   only   Revised for Version 3.8 (Release 2012b)
March 2013         Online   only   Revised for Version 3.9 (Release 2013a)
September 2013     Online   only   Revised for Version 3.10 (Release 2013b)
March 2014         Online   only   Revised for Version 3.11 (Release 2014a)
                                                                                                        Contents
                                                             Model Construction
1
    Basic Principles of Modeling Physical Networks . . . . .                                      1-2
      Overview of the Physical Network Approach to Modeling
        Physical Systems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .            1-2
      Variable Types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .      1-4
      Building the Mathematical Model . . . . . . . . . . . . . . . . . . . .                     1-5
      Direction of Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . .            1-6
      Connector Ports and Connection Lines . . . . . . . . . . . . . . . .                        1-8
      Connecting Simscape Diagrams to Simulink Sources and
        Scopes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .   1-10
                                                                                                                   v
                       Assumptions and Limitations . . . . . . . . . . . . . . . . . . . . . . .                  1-44
                       Fundamental Equations . . . . . . . . . . . . . . . . . . . . . . . . . . . .              1-45
                       Network Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .          1-46
                       Connection Constraints . . . . . . . . . . . . . . . . . . . . . . . . . . . .             1-47
                       References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .   1-47
vi   Contents
                                                                    Model Simulation
3
    How Simscape Models Represent Physical Systems . . .                                             3-2
      Representations of Physical Systems . . . . . . . . . . . . . . . . . .                        3-2
      Differential, Differential-Algebraic, and Algebraic
         Systems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .       3-2
      Stiffness . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .    3-3
      Events and Zero Crossings . . . . . . . . . . . . . . . . . . . . . . . . . .                  3-3
      Working with Simscape Representation . . . . . . . . . . . . . . .                             3-3
                                                                                                           vii
                      Real-Time Simulation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .             3-39
                        What Is Real-Time Simulation? . . . . . . . . . . . . . . . . . . . . . .                  3-39
                        Requirements for Real-Time Simulation . . . . . . . . . . . . . . .                        3-40
                        Simulating Physical Models in Real Time . . . . . . . . . . . . . .                        3-41
                        Preparing a Model for Real-Time Simulation . . . . . . . . . . .                           3-42
                        Troubleshooting Real-Time Simulation Problems . . . . . . .                                3-45
                      Limitations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .    3-71
                        Sample Time and Solver Restrictions . . . . . . . . . . . . . . . . .                      3-71
                        Algebraic Loops . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .      3-71
                        Restricted Simulink Tools . . . . . . . . . . . . . . . . . . . . . . . . . .              3-72
                        Unsupported Simulink Tools . . . . . . . . . . . . . . . . . . . . . . . .                 3-74
                        Simulink Tools Not Compatible with Simscape Blocks . . .                                   3-74
                        Code Generation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .        3-75
References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-77
viii   Contents
    Initialize Variables for a Mass-Spring-Damper
      System . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .    4-8
                                                                           Data Logging
5
    About Simulation Data Logging . . . . . . . . . . . . . . . . . . . . .                       5-2
      Suggested Workflows . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .             5-2
      Limitations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .     5-2
                                                                      Model Statistics
6
    Simscape Model Statistics . . . . . . . . . . . . . . . . . . . . . . . . . .                 6-2
                                                                                                        ix
                   View Model Statistics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .            6-13
                                                                                        Physical Units
               7
                   How to Work with Physical Units . . . . . . . . . . . . . . . . . . .                         7-2
x   Contents
Working with Restricted and Full Modes . . . . . . . . . . . .                   8-9
 Set the Model Loading Preference . . . . . . . . . . . . . . . . . . . .        8-9
 Save a Model in Restricted Mode . . . . . . . . . . . . . . . . . . . . .      8-10
 Work with a Model in Restricted Mode . . . . . . . . . . . . . . . .           8-13
 Switch from Restricted to Full Mode . . . . . . . . . . . . . . . . . .        8-23
                                                                                       xi
xii   Contents
                                                                  1
Model Construction
1-2
                                            Basic Principles of Modeling Physical Networks
real physical components. The Physical Network approach, with its Through
and Across variables and nondirectional physical connections, automatically
resolves all the traditional issues with variables, directionality, and so on.
The number of connection ports for each element is determined by the number
of energy flows it exchanges with other elements in the system, and depends
on the level of idealization. For example, a fixed-displacement hydraulic
pump in its simplest form can be represented as a two-port element, with one
energy flow associated with the inlet (suction) and the other with the outlet.
In this representation, the angular velocity of the driving shaft is assumed
constant, making it possible to neglect the energy exchange between the
pump and the shaft. To account for a variable driving torque, you need a third
port associated with the driving shaft.
The element is represented with three energy flows: two flows of hydraulic
energy through the inlet and outlet of the cylinder and a flow of mechanical
                                                                                      1-3
 1    Model Construction
                           energy associated with the rod motion. It therefore has the following three
                           connector ports:
                           See “Connector Ports and Connection Lines” on page 1-8 for more information
                           on connector port types.
                           Variable Types
                           Physical Network approach supports two types of variables:
                           The following table lists the Through and Across variables associated with
                           each type of physical domain in Simscape software:
1-4
                                           Basic Principles of Modeling Physical Networks
Note Generally, the product of each pair of Across and Through variables
associated with a domain is power (energy flow in watts). The exceptions are
pneumatic domain, where the product of pressure and mass flow rate is not
power, magnetic domain, where the product of mmf and flux is not power, but
energy, and the thermal liquid domain, where products of both variable pairs
are not power. These result in a pseudo-bond graph.
F3 = p1 A1 − p2 A2
q1 = A1 v3
                                                                                     1-5
 1    Model Construction
q2 = A2 v3
where
                           Direction of Variables
                           Each variable is characterized by its magnitude and sign. The sign is the
                           result of measurement orientation. The same variable can be positive or
                           negative, depending on the polarity of a measurement gauge.
                           Elements with only two ports are characterized with one pair of variables, a
                           Through variable and an Across variable. Since these variables are closely
                           related, their orientation is defined with one direction. For example, if an
                           element is oriented from port A to port B, it implies that the Through variable
                           (TV) is positive if it “flows” from A to B, and the Across variable is determined
1-6
                                             Basic Principles of Modeling Physical Networks
as AV = AVA – AVB, where AVA and AVB are the element node potentials or, in
other words, the values of this Across variable at ports A and B, respectively.
                                                                                       1-7
 1    Model Construction
                           The block positive direction is from port C to port R. This means that the force
                           is positive if it acts in the direction from C to R, and causes bodies connected
                           to port R to accelerate in the positive direction. The relative velocity is
                           determined as v = vC – vR, where vR, vC are the absolute velocities at ports R
                           and C, respectively, and it is negative if velocity at port R is greater than that
                           at port C. The power generated by the source is computed as the product of
                           force and velocity, and is negative if the source provides energy to the system.
                           All the elements in a network are divided into active and passive elements,
                           depending on whether they deliver energy to the system or dissipate (or store)
                           it. Active elements (force and velocity sources, flow rate and pressure sources,
                           etc.) must be oriented strictly in accordance with the line of action or function
                           that they are expected to perform in the system, while passive elements
                           (dampers, resistors, springs, pipelines, etc.) can be oriented either way.
1-8
                                           Basic Principles of Modeling Physical Networks
Each of these ports and connections between them are described in greater
detail below.
• You can connect Conserving ports only to other Conserving ports of the
  same type.
• The Physical connection lines that connect Conserving ports together are
  nondirectional lines that carry physical variables (Across and Through
  variables, as described above) rather than signals. You cannot connect
  Physical lines to Simulink ports or to Physical Signal ports.
• Two directly connected Conserving ports must have the same values for all
  their Across variables (such as pressure or angular velocity).
• You can branch Physical connection lines. When you do so, components
  directly connected with one another continue to share the same Across
  variables. Any Through variable (such as flow rate or torque) transferred
  along the Physical connection line is divided among the multiple
  components connected by the branches. How the Through variable is
  divided is determined by the system dynamics.
  For each Through variable, the sum of all its values flowing into a branch
  point equals the sum of all its values flowing out.
                                                                                     1-9
 1     Model Construction
1-10
                                                                         Simscape™ Block Libraries
           In addition, if you have installed any of the add-on products of the Physical
           Modeling family, you will see the corresponding libraries under the main
           Simscape library.
                                                                                            1-11
 1     Model Construction
                            Using the elements contained in these Foundation libraries, you can create
                            more complex components that span different physical domains. You can
                            then group this assembly of blocks into a subsystem and parameterize it to
                            reuse and share these components.
                            For examples of using these blocks in a Simscape model, see the tutorial
                            “Creating and Simulating a Simple Model” on page 1-18.
                            You can combine all these blocks in your Simscape diagrams to model physical
                            systems. You can also use the basic Simulink blocks in your diagrams, such as
                            sources or scopes. See “Connecting Simscape Diagrams to Simulink Sources
                            and Scopes” on page 1-10 for more information on how to do this.
1-12
                                                             Simscape™ Block Libraries
                                                                                1-13
 1     Model Construction
1-14
                                                              Essential Physical Modeling Techniques
                                                                                              1-15
 1     Model Construction
1-16
                                                      Essential Physical Modeling Techniques
  For each Through variable, the sum of all its values flowing into a branch
  point equals the sum of all its values flowing out.
• You can connect Physical Signal ports to other Physical Signal ports with
  regular connection lines, similar to Simulink signal connections. These
  connection lines carry physical signals between Simscape blocks.
• You can connect Physical Signal ports to Simulink ports through special
  converter blocks. Use the Simulink-PS Converter block to connect Simulink
  outports to Physical Signal inports. Use the PS-Simulink Converter block
  to connect Physical Signal outports to Simulink inports.
• Unlike Simulink signals, which are essentially unitless, Physical Signals
  can have units associated with them. Simscape block dialogs let you specify
  the units along with the parameter values, where appropriate. Use the
  converter blocks to associate units with an input signal and to specify the
  desired output signal units.
For examples of applying these rules when creating an actual physical model,
see the tutorial “Creating and Simulating a Simple Model” on page 1-18.
                                                                                      1-17
 1     Model Construction
1-18
                                                Creating and Simulating a Simple Model
2 Create a new model. To do this, from the top menu bar of the Library
  Browser, select File > New > Model. The software creates an empty
  model in memory and displays it in a new model editor window.
3 Open the Simscape > Foundation Library > Mechanical > Translational
  Elements library.
                                                                                1-19
 1     Model Construction
1-20
                                                  Creating and Simulating a Simple Model
7 To add the representation of the force acting on the mass, open the
  Simscape > Foundation Library > Mechanical > Mechanical Sources library
  and add the Ideal Force Source block to your diagram.
  To reflect the correct direction of the force shown in the original schematic,
  flip the block by selecting Diagram > Rotate & Flip > Flip Block >
  Up-Down from the top menu bar of the model window. Connect the block’s
  port C (for “case”) to the second Mechanical Translational Reference block,
  and its port R (for “rod”) to the Mass block, as shown below.
                                                                                   1-21
 1     Model Construction
                            8 Add the sensor to measure speed and position of the mass. Place the Ideal
                              Translational Motion Sensor block from the Mechanical Sensors library
                              into your diagram and connect it as shown below.
1-22
                                               Creating and Simulating a Simple Model
9 Now you need to add the sources and scopes. They are found in the regular
  Simulink libraries. Open the Simulink > Sources library and copy the
  Signal Builder block into the model. Then open the Simulink > Sinks
  library and copy two Scope blocks. Rename one of the Scope blocks to
  Velocity and the other to Position.
                                                                               1-23
 1     Model Construction
1-24
                                                  Creating and Simulating a Simple Model
                                                                                  1-25
 1     Model Construction
                             1 Select a Simulink solver. On the top menu bar of the model window, select
                               Simulation > Model Configuration Parameters. The Configuration
                               Parameters dialog box opens, showing the Solver node.
1-26
                                                   Creating and Simulating a Simple Model
1 The input signal for the force is provided by the Signal Builder block. The
  signal profile is shown in the illustration below. It starts with a value of 0,
                                                                                    1-27
 1     Model Construction
                              The Velocity scope outputs the mass velocity, and the Position scope
                              outputs the mass displacement as a function of time. Double-click both
                              scopes to open them.
1-28
                                                 Creating and Simulating a Simple Model
3 Once the simulation starts running, the Velocity and Position scope
  windows display the simulation results, as shown in the next illustration.
  In the beginning, the mass is at rest. Then at 4 seconds, as the input signal
  changes abruptly, the mass velocity spikes in the positive direction and
  gradually returns to zero. The mass position at the same time changes
  more gradually, on account of inertia and damping, and stays at the new
                                                                                  1-29
 1     Model Construction
                              value as long as the force is acting upon it. At 6 seconds, when the input
                              signal changes back to zero, the velocity gets a mirror spike, and the mass
                              gradually returns to its initial position.
                            You can now adjust various inputs and block parameters and see their effect
                            on the mass velocity and displacement.
                            2 Click the first vertical segment of the signal profile and drag it from 4 to 2
                              seconds, as shown below. Close the block dialog.
1-30
                                               Creating and Simulating a Simple Model
3 Run the simulation. The simulation results are shown in the following
  illustration.
                                                                               1-31
 1     Model Construction
1-32
                                                 Creating and Simulating a Simple Model
1 Double-click the Translational Spring block. Set its Spring rate to 2000
  N/m.
4 Run the simulation. Because of the increase in viscosity, the mass is slower
  both in reaching its maximum displacement and in returning to the initial
  position, as shown in the following illustration.
                                                                                 1-33
 1     Model Construction
1-34
Creating and Simulating a Simple Model
                                1-35
 1     Model Construction
                            Grounding Rules
                            This section contains guidelines for using domain-specific reference blocks
                            (such as Electrical Reference, Mechanical Translational Reference, and so
                            on) in Simscape diagrams, along with examples of correct and incorrect
                            configurations.
1-36
                                                                 Modeling Best Practices
                                                                                  1-37
 1     Model Construction
                            The following diagram, however, will not produce an error because the
                            resistor defines the output voltage relative to the ground reference.
1-38
                                                                  Modeling Best Practices
• Electrical conserving ports of all the blocks that are directly connected to
  ground must be connected to an Electrical Reference block.
• All translational ports that are rigidly clamped to the frame (ground) must
  be connected to a Mechanical Translational Reference block.
• All rotational ports that are rigidly clamped to the frame (ground) must be
  connected to a Mechanical Rotational Reference block.
• Hydraulic conserving ports of all the blocks that are referenced to
  atmosphere (for example, suction ports of hydraulic pumps, or return ports
  of valves, cylinders, pipelines, if they are considered directly connected to
  atmosphere) must be connected to a Hydraulic Reference block.
                                                                                   1-39
 1     Model Construction
                            In electrical circuits, common examples that can cause this behavior include
                            voltage sources connected in parallel with capacitors, inductors connected in
                            series with current sources, voltage sources connected in parallel, and current
                            sources connected in series. Often, the cause of the numerical difficulty is
                            immediately apparent. For example, two voltage sources in parallel must
                            have identical voltage values; otherwise, the ports connecting them would not
                            be physical conserving ports. In practical circuits, topologies such as parallel
                            voltage sources are possible, and small difference in their instantaneous
                            voltages is possible due to parasitic series resistance.
1-40
                                                                  Modeling Best Practices
There are two approaches to resolving these difficulties. The first is to change
the circuit to an equivalent simpler one. In the example of two parallel voltage
sources, one source can be simply deleted. The same applies to two series
current sources, the deleted one being replaced by a short circuit. For some
circuit topologies, however, it is not possible to find an equivalent simpler one
that resolves the problem, and the second approach is needed.
                                                                                    1-41
 1     Model Construction
                            Simulate the model, and you will see that the output is minus the derivative
                            of the input sinusoid.
                            Now open the capacitor C block dialog, and set the series resistance to zero.
                            The model now issues an initialization error.
                            The cause of the error is that the circuit effectively connects the voltage source
                            in parallel with the capacitor. This is because an ideal op-amp satisfies V+ =
1-42
                                                                Modeling Best Practices
                                                                                 1-43
 1     Model Construction
                            Intended Applications
                            The Foundation library contains basic pneumatic elements, such as orifices,
                            chambers, and pneumatic-mechanical converters, as well as pneumatic
                            sensors and sources. Use these blocks to model pneumatic systems, for
                            applications such as:
                            You can also use these blocks to model dry air and low-pressure flows, for
                            example, for HVAC applications.
1-44
                                                                   Modeling Pneumatic Systems
Fundamental Equations
The energy balance for a control volume [1] is
     dEcv                 ⎛ ⎛        v2       ⎞⎞      ⎛    ⎛     v2       ⎞⎞
          = Qcv − Wcv + ∑ ⎜ mi ⎜ hi + i + gzi ⎟ ⎟ − ∑ ⎜ mo ⎜ ho + o + gzo ⎟ ⎟
      dt                  ⎜ ⎜         2       ⎟⎟      ⎜    ⎜      2       ⎟⎟
                        i ⎝    ⎝              ⎠⎠ o ⎝       ⎝              ⎠⎠
where
The equation is an accounting balance for the energy of the control volume. It
states that the rate of energy increase or decrease within the control volume
equals the difference between the rates of energy transfer in and out across the
boundary. The mechanisms of energy transfer are heat and work, as for closed
systems, and the energy that accompanies the mass entering and exiting.
                                                                                        1-45
 1     Model Construction
p = ρRT
where
                             p          Absolute pressure
                             ρ          Gas density
                             R          Specific gas constant
                             T          Absolute gas temperature
                            Also, the specific enthalpies for an ideal gas at temperature T and constant
                            pressure and constant volume are given by:
h = c pT
h = cvT
                                 dρ 1
                                   = ( mi − mo )
                                 dt V
                            where ρ is the density of the gas within the component. For components with
                            no internal mass of gas, the equation simplifies to:
G = mi = mo
For specific equations used in each block, see the block reference pages.
                            Network Variables
                            The Across variables are pressure and temperature, and the Through
                            variables are mass flow rate and heat flow. Note that these choices result in
1-46
                                                           Modeling Pneumatic Systems
a pseudo-bond graph, because the product of pressure and mass flow rate
is not power.
Connection Constraints
Every node in a pneumatic network must have a defined temperature as
well as pressure. This rule places some constraints on how you connect
the pneumatic elements. In effect, every node should have a volume of
fluid associated with it. When the ideal gas law is applied, this volume
of fluid determines the relationship between temperature and pressure.
Some elements already have a volume of fluid associated with them, and
therefore having just one of these components connected to a node satisfies
this condition. Such blocks include Constant Volume Pneumatic Chamber,
Pneumatic Piston Chamber, Rotary Pneumatic Piston Chamber, and
Pneumatic Atmospheric Reference.
An exception to the above rule (that every node must have a volume of fluid
associated with it) occurs when two nodes are connected by a component for
which the heat equation says that the temperatures are equal. In this case,
just one of the nodes needs to be connected to a component with associated
volume of fluid. Such components include the pressure and flow rate sources.
References
[1] Moran M.J. and Shapiro H.N. Fundamentals of Engineering
Thermodynamics. Second edition. New York: John Wiley & Sons, 1992.
                                                                                1-47
 1     Model Construction
1-48
                                                            2
                              To decide whether Thermal Liquid blocks fit your modeling needs, consider
                              the fluid system you are trying to represent. Other Simscape blocks—e.g.
                              Hydraulic or Pneumatic—may better suit your application. Assess the
                              following:
                              • Number of phases
                                Is the fluid medium single phase or multiphase?
                              • Relevant phases
                                Is the fluid medium a gas, a liquid, or a multiphase mixture?
                              • Thermal effects
                                Does temperature change significantly in the time scale of the simulation?
                                Are thermal effects important for analysis? Are the temperature
                                dependences of the liquid properties important?
                              As a rule, use Thermal Liquid blocks for fluid systems in which a single-phase
                              liquid experiences significant temperature changes. For gaseous systems,
2-2
                                                         Modeling Thermal Liquid Systems
use Pneumatic blocks instead. For isothermal liquid systems, use Hydraulic
blocks.
Modeling Workflow
The suggested workflow for Thermal Liquid models includes four steps:
4 Run simulation — Configure the solver settings. Then, run the simulation.
  If necessary, refine the model until you achieve the desired fidelity level.
                                                                                    2-3
 2    Thermal Liquid Models
                              You also must determine the dimensions and properties of each component.
                              During modeling, you specify these parameters in the Simscape blocks
                              for the components. Obtain the physical properties of the liquid medium.
                              Manufacturer data sheets typically provide this data. You can also use
                              analytical expressions to define the physical property lookup tables.
                              If you are unsure whether an effect is relevant to your model, simulate the
                              model with and without that effect. Then, compare the two simulation
                              results. If the difference is substantial, leave that effect in place. The result is
                              greater model fidelity at small time scales, e.g., during transients associated
                              with flow reversal in a pipe.
                              Identify the appropriate blocks for representing the physical components and
                              their interactions. Components can be simple, requiring a single block, or
                              custom, requiring multiple blocks typically within a Subsystem block. Add
                              the blocks to the model canvas and connect them according to the Simscape
                              connection rules.
2-4
                                                        Modeling Thermal Liquid Systems
Once you have connected the blocks, specify the relevant parameters. These
include dimensions, physical states, empirical correlation coefficients, and
initial conditions. In Pipe (TL), Rotational Mechanical Converter (TL), and
Translational Mechanical Converter (TL) blocks, select the appropriate
setting for effects such as dynamic compressibility and flow inertia.
Note For accurate simulation results, always replace the default parameter
values with data appropriate for your model.
To configure a model for Simscape data logging, see “How to Log Simulation
Data” on page 5-3. For an example of how to plot logged data, see “Log and
Plot Simulation Data” on page 5-7.
Run Simulation
The final step in the modeling workflow is to simulate the model. Before
running simulation, check that the numerical solver is appropriate for your
model. To do this, use the Model Configuration Parameters dialog box.
                                                                                   2-5
 2    Thermal Liquid Models
                              Run the simulation. Plot simulation data from sensors and Simscape data
                              logging, or process it for further analysis. If necessary, refine the model. For
                              example, correct simulation issues or to improve model fidelity.
2-6
                                                                            Thermal Liquid Library
           The Thermal Liquid library provides a modeling tool that you can use to
           analyze the thermal behavior of thermal liquid systems. Three featured
           examples show some applications well-suited for Thermal Liquid modeling:
                                                                                              2-7
 2    Thermal Liquid Models
                              itself. Simple components are often industry independent and can be modeled
                              using a single Thermal Liquid block. For example, you can model a pipeline
                              segment using a single Pipe (TL) block.
2-8
                                                                 Thermal Liquid Library
The block accepts two-way lookup tables as input. These tables provide
the different thermodynamic property values at discrete pressures and
temperatures. You can populate these tables using empirical data from
product data sheets or values calculated from analytical expressions.
                                                                                   2-9
 2     Thermal Liquid Models
                               For instance, you can use the thermal conserving port of a Pipe (TL) block to
                               model conductive heat transfer through a pipe wall. Oil pipeline modeling is
                               one application. The example ssc_tl_oil_pipeline shows this approach.
                               The table lists the Thermal Liquid blocks that have thermal or mechanical
                               conserving ports. You can use these blocks to create a multidomain model
                               containing thermal liquid, thermal, and mechanical subsystems.
2-10
                                                               Thermal Liquid Modeling Framework
                                                                                            2-11
 2     Thermal Liquid Models
                               variables using Simscape data logging. For more information, see “About
                               Simulation Data Logging” on page 5-2.
                               Two physical principles govern the dynamic evolution of liquid pressure and
                               temperature at the internal node of a control volume: mass conservation and
                               energy conservation. Pressure and temperature computation is carried out for
                               the control volume surrounding the internal node. This control volume is the
                               total volume of the thermal liquid component the block represents.
                               Two physical principles govern the mass and heat flow rates through a
                               Thermal Liquid conserving port: momentum conservation and energy
2-12
                                                    Thermal Liquid Modeling Framework
conservation. The mass flow rate at a port is computed from the momentum
conservation principle. The heat flow rate at a port is computed from the
thermal energy conservation principle.
The flow rate computations are carried out for half the control volume of a
thermal liquid component. The half control volume is bounded on one end by
the interface the port represents, and on another end by a parallel surface
passing through the control volume centroid.
The figure shows the half control volume for flow rate computations at
interface A of a pipeline segment. Interface A corresponds to Thermal Liquid
conserving port A of a Pipe (TL) block. Node C corresponds to the internal
node of the block, which is coincident with the control volume centroid.
                                                                                2-13
 2     Thermal Liquid Models
2-14
                                                                 Heat Transfer in Insulated Oil Pipeline
            Oil Pipelines
            Temperature plays an important role in oil pipeline design. Below the
            so-called cloud point, paraffin waxes precipitate from crude oil and start
            to accumulate along the pipe wall interior. The waxy deposits restrict oil
            flow, increasing the power requirements of the pipeline. At still-lower
            temperatures—below the pour point of oil—these crystals become so
            numerous that, if allowed to quiesce, oil becomes semisolid.
            In cold climates, conductive heat losses through the pipe wall can be
            significant. To keep oil in its favorable temperature range, pipelines include
            some temperature control measures. Heating stations placed at intervals
            along the pipeline help to warm the oil. An insulant liner covering the pipe
            wall interior helps to retard the cooling rate of the oil.
                                                                                                  2-15
 2     Thermal Liquid Models
                               form of heat. The warming effect is small, but sufficient to at least partially
                               offset the conductive heat losses that occur through the insulant liner.
                               In this example, you simulate an insulated oil pipeline segment. You then run
                               an optimization script to determine the optimal insulation thickness. This
                               example is based on Simscape model ssc_tl_oil_pipeline.
                               Modeling Considerations
                               The physical system in this example is an oil pipeline segment. Insulation
                               lines the pipe wall interior, while soil covers the pipe wall exterior, retarding
                               conductive heat loss. The simplifying assumption is made that the physical
                               system is symmetric about the pipe center line.
                               Flow through the pipeline segment is assumed fully developed: the velocity
                               profile of the flowing oil remains constant along the pipeline length.
                               In addition, oil is assumed Newtonian and compressible: shear stress
                               is proportional to the shear strain, and mass density varies with both
                               temperature and pressure.
2-16
                                                     Heat Transfer in Insulated Oil Pipeline
Inside the pipeline segment, viscous dissipation heats the flowing oil, while
thermal conduction through the pipe wall cools it. The balance between the
two processes governs the temperature of oil exiting the pipeline segment.
The amount of heat gained through viscous dissipation depends partly on oil
viscosity and mass flow rate. The greater these quantities are, the greater the
viscous heat gain is—and the warmer the oil tends to get. The amount of heat
lost via thermal conduction depends partly on the thermal resistances of the
insulation, pipe wall, and soil layer. The smaller the thermal resistances are,
the greater the conductive heat loss is—and the cooler the oil tends to get.
Assuming the pipe wall is thin and its material a good thermal conductor,
you can safely ignore the thermal resistance of the pipe wall. The combined
thermal resistance is then simply the sum of the insulation and soil
contributions, Rins. and Rsoil.
                                                                                      2-17
 2     Thermal Liquid Models
                               The figure shows the relevant dimensions of the pipeline segment. Variable
                               names match those specified in the model. The inner insulation diameter, D1,
                               is also the hydraulic diameter of the pipeline segment.
                               Simscape Model
                               The Simscape model ssc_tl_oil_pipeline represents an insulated oil
                               pipeline segment buried underground. To open this model, at the MATLAB
                               command prompt, enter ssc_tl_oil_pipeline. The figure shows the model.
2-18
                                                     Heat Transfer in Insulated Oil Pipeline
The Pipe (TL) block represents the physical system in this example, i.e., the
oil pipeline segment. Port A represents its inlet and port B its outlet. Port W
represents thermal conduction through the pipe wall. The block accounts for
viscous heating.
The Mass Flow Rate Source (TL) block provides the flow rate through the
pipe. The From upstream segment block acts as a temperature source for the
pipe inlet, while the To downstream segment block acts as a temperature
sink at the pipe outlet.
                                                                                      2-19
 2     Thermal Liquid Models
                               The Thermal Liquid Settings (TL) block provides the physical properties of
                               the oil, expressed as two-sided lookup tables containing the temperature and
                               pressure dependence of the properties. The table summarizes these blocks.
                                Block                                  Description
                                Pipe (TL)                              Pipeline segment
                                Conduction through insulant            Insulant thermal conduction
                                Conduction through soil                Soil thermal conduction
                                Soil (Subsystem)                       Soil temperature
                                From upstream segment                  Pipe inlet temperature sink
                                To downstream segment                  Pipe outlet temperature sink
                                Mass Flow Rate Source (TL)             Oil mass flow rate
                                Thermal Liquid Settings (TL)           Oil thermodynamic properties
                               Run Simulation
                               To analyze the performance of the oil pipeline segment, simulate the model.
                               The Comparison scope plots the upstream and downstream oil temperatures.
                               Open this scope. The insulation thickness is near its optimal value, resulting
                               in only a small temperature change over a 1000 meter length. At a rate
                               of ~0.020 K/km, oil temperature changes approximately 2 K over a 100
                               kilometer length.
2-20
                                                      Heat Transfer in Insulated Oil Pipeline
  In the data tree, the kinematic viscosity nu appears under the node
  pipe_model, which itself appears under the node simlog.Pipe_TL.
  The logging object for the kinematic viscosity of oil in the pipe, then, is
  simlog.Pipe_TL.pipe_model.nu.
                                                                                       2-21
 2     Thermal Liquid Models
2-22
                                                   Heat Transfer in Insulated Oil Pipeline
Note For more information about Simscape logging, see “About Simulation
Data Logging” on page 5-2.
                                                                                    2-23
 2     Thermal Liquid Models
4 Enter 0.20.
                               By reducing the inner diameter of the insulation layer to 0.20, you increase
                               the insulation thickness, slowing down heat loss through the pipe wall via
                               thermal conduction. Run the simulation. Then, open the Comparison scope
                               and autoscale to view full plot.
                               The new plot shows an oil temperature at the pipe outlet (top curve) that
                               significantly exceeds that at the pipe inlet (bottom line). Viscous dissipation
                               now dominates the thermal energy balance in the pipeline segment. The new
                               insulation thickness poses a design problem: in a long pipeline, a 1.1 K/km
                               heating rate can raise the oil temperature substantially at the receiving end
                               of the pipeline.
                               Plotting the kinematic viscosity as a function of time shows that its variability
                               is now quite significant also. At the MATLAB command line, enter the logging
                               command: simscape.logging.plot({simlog.Pipe_TL.pipe_model.nu}).
2-24
                                                    Heat Transfer in Insulated Oil Pipeline
Try increasing the inner diameter of the insulation layer, D1, to 0.55. By
increasing this value, you decrease the insulation thickness, accelerating heat
loss through the pipe wall via thermal conduction. Then, run the simulation.
Open the Comparison scope and autoscale to view the full plot.
                                                                                     2-25
 2     Thermal Liquid Models
                               The resulting plot shows that the oil temperature at the pipe outlet is
                               now significantly lower than that at the pipe inlet. Thermal conduction
                               clearly dominates the thermal energy balance in the pipeline segment. This
                               insulation thickness also poses a design issue: at a rate of 0.25K/km, oil
                               flowing through a long pipeline will cool down substantially.
2-26
                                                    Heat Transfer in Insulated Oil Pipeline
                                                                                     2-27
 2     Thermal Liquid Models
                               2 In the plot that opens, visually determine the horizontal-axis value for the
                                 intersection point between the two curves.
4 Enter 0.37.
                               Now, run the simulation. Open the Comparison scope and autoscale to view
                               the full plot. The temperature difference between the inlet and the outlet
                               is negligible.
2-28
                                                         Heat Transfer in Insulated Oil Pipeline
                                                                                          2-29
 2     Thermal Liquid Models
2-30
                                                                  3
Model Simulation
                         • ODEs govern the rates of change of system variables and contain some or
                           all of the time derivatives of the system variables.
                         • Algebraic equations specify functional constraints among system variables,
                           but contain no time derivatives of system variables.
3-2
                                        How Simscape™ Models Represent Physical Systems
Stiffness
A mathematical problem is stiff if the solution you are seeking varies slowly,
but there are other solutions within the error tolerances that vary rapidly. A
stiff system has several intrinsic time scales of very different magnitude [1].
A stiff physical system has one or more components that behave “stiffly” in the
ordinary sense, such as a spring with a large spring constant. Mathematical
equivalents include quasi-incompressible fluids and low electrical inductance.
Such systems often exhibit high frequency oscillations in some of their
components or modes.
                                                                                   3-3
 3    Model Simulation
Your model can contain zero-crossing conditions arising from several sources:
                         • Simscape and normal Simulink blocks copied from their respective block
                           libraries
                         • Expressions programmed in the Simscape language
                         Tip If the exact times of zero crossings are important in your model,
                         then keep zero-crossing detection enabled. Disabling it can lead to major
                         simulation inaccuracies.
3-4
                                                                 How Simscape™ Simulation Works
          Simscape software gives you multiple ways to simulate and analyze physical
          systems in the Simulink environment. Running a physical model simulation
          is similar to simulating any Simulink model. It entails setting various
          simulation options, starting the simulation, and viewing the simulation
          results. This topic describes various aspects of simulation specific to Simscape
          models. For specifics of simulating and analyzing with individual Simscape
          add-on products, refer to the documentation for those individual add-on
          products.
                                                                                             3-5
 3    Model Simulation
3-6
                                                        How Simscape™ Simulation Works
Model Validation
The Simscape solver first validates the model configuration and checks your
data entries from the block dialog boxes.
Network Construction
After validating the model, the Simscape solver constructs the physical
network based on the following principles:
                                                                                   3-7
 3    Model Simulation
                         • Two directly connected Conserving ports have the same values for all their
                           Across variables (such as voltage or angular velocity).
                         • Any Through variable (such as current or torque) transferred along
                           the Physical connection line is divided among the multiple components
                           connected by the branches. For each Through variable, the sum of all its
                           values flowing into a branch point equals the sum of all its values flowing
                           out.
                         Equation Construction
                         Based on the network configuration, the parameter values in the block dialog
                         boxes, and the global parameters defined by the fluid properties, if applicable,
                         the Simscape solver constructs the system of equations for the model.
                         The solver then performs the analysis and eliminates variables that are
                         not needed to solve the system of equations. After variable elimination,
                         the remaining variables (algebraic, dynamic dependent, and dynamic
                         independent) get mapped to Simulink state vector of the model.
                         For information on how to view and analyze model variables, see “Model
                         Statistics”.
3-8
                                                         How Simscape™ Simulation Works
The solver computes the initial conditions by finding initial values for all the
system variables that exactly satisfy all the model equations. You can affect
the initial conditions computation by block-level variable initialization, that
is, by specifying the priority and target initial values on the Variables tab of
the block dialog boxes.
The values you specify during block-level variable initialization are not the
actual values of the respective variables, but rather their target values at the
beginning of simulation (t = 0). Depending on the results of the solve, some
of these targets may or may not be satisfied. The solver tries to satisfy the
high-priority targets first, then the low-priority ones:
• At first, the solver tries to find a solution where all the high-priority
  variable targets are met exactly, and the low-priority targets are
  approximated as closely as possible. If the solution is found during this
  stage, it satisfies all the high-priority targets. Some of the low-priority
  targets might also be met exactly, the others are approximated.
• If the solver cannot find a solution that exactly satisfies all the high-priority
  targets, it issues a warning and enters the second stage, where High
  priority is relaxed to Low. That is, the solver tries to find a solution by
  approximating both the high-priority and the low-priority targets as closely
  as possible.
After you initialize the block variables and prior to simulating the model,
you can open the Variable Viewer to see which of the variable targets have
been satisfied. For more information on block-level variable initialization,
see “Variable Initialization”.
                                                                                      3-9
 3     Model Simulation
                          system were held constant for a long enough time, starting from the initial
                          state obtained from the initial conditions computation just described. If the
                          steady-state solve succeeds, the state found is some steady state (within
                          tolerance), but not necessarily the state expected from the given initial
                          conditions. Steady state means that the system variables are no longer
                          changing with time. Simulation then starts from this steady state.
                          A model can have more than one steady state. In this case, the solver selects
                          the steady-state solution that is consistent with the variable targets specified
                          during block-level variable initialization. For more information, see “Variable
                          Initialization”.
                          Transient Initialization
                          After computing the initial conditions, or after a subsequent event (such
                          as a discontinuity resulting, for example, from a valve opening, or from a
                          hard stop), the Simscape solver performs transient initialization. Transient
                          initialization fixes all dynamic variables and solves for algebraic variables
                          and derivatives of dynamic variables. The goal of transient initialization is to
                          provide a consistent set of initial conditions for the next phase, transient solve.
                          Transient Solve
                          Finally, the Simscape solver performs transient solve of the system of
                          equations. In transient solve, continuous differential equations are integrated
                          in time to compute all the variables as a function of time.
                          The solver continues to perform the simulation according to the results of the
                          transient solve until the solver encounters an event, such as a zero crossing or
                          discontinuity. The event may be within the physical network or elsewhere in
                          the Simulink model. If the solver encounters an event, the solver returns to
                          the phase of transient initialization, and then back to transient solve. This
                          cycle continues until the end of simulation.
3-10
                                                                Setting Up Solvers for Physical Models
            When you first create a model, the default Simulink solver is ode45. To select
            a different solver, follow a procedure similar to the procedure in “Modifying
            Initial Settings” on page 1-26.
            • You can choose one from a suite of both variable-step and fixed-step solvers.
              A variable-step solver is the default.
                                                                                                3-11
 3     Model Simulation
                          • You can also select from among explicit and implicit solvers. An explicit
                            solver is the default. But for physical models, MathWorks recommends
                            implicit solvers, such as ode14x, ode23t, and ode15s. Implicit solvers
                            require fewer time steps than explicit solvers, such as ode45, ode113, and
                            ode1.
                            See “Switching from the Default Explicit Solver to Other Simulink Solvers”
                            on page 3-14.
                          • If all the Simulink and Simscape states in your model are discrete,
                            Simulink automatically switches to a discrete solver and issues a warning.
                            Otherwise, a continuous solver is the default.
                          • By default, Simulink variable-step solvers attempt to locate events in
                            time by zero-crossing detection. See “Enabling or Disabling Simulink
                            Zero-Crossing Detection” on page 3-17.
                          A physical network using a local solver appears to the global Simulink solver
                          as if it has discrete states. You can still use any continuous global solver.
                          Choosing Local Solvers and Sample Times. To use a local solver, choose
                          a solver type (Backward Euler or Trapezoidal Rule) and a sample time.
                          Backward Euler is the default.
                          Choosing Multirate Simulation. With the local solver option, you can
                          perform multirate simulations, with:
3-12
                                                  Setting Up Solvers for Physical Models
                                                                                  3-13
 3     Model Simulation
3-14
                                                     Setting Up Solvers for Physical Models
2 Click OK.
The filter time constant controls the filtering of the input signal. The filtered
input follows the true input but is smoothed, with a lag on the order of the
time constant that you choose. Set the time constant to a value no larger than
the smallest time interval in the system that interests you. If you choose
a very small time constant, the filtered input signal is closer to the true
input signal. However, this filtered input signal increases the stiffness of
the system and slows the simulation.
Instead of using input filtering, you can provide time derivatives for the input
signal directly, as additional physical signals.
                                                                                     3-15
 3     Model Simulation
                          You can control the way you provide time derivatives for each input signal by
                          configuring the Simulink-PS Converter block connected to that input signal:
3-16
                                                    Setting Up Solvers for Physical Models
  Input filtering order parameter, and set the appropriate Input filtering
  time constant parameter value for your model.
4 To avoid filtering the input signal, set the Filtering and derivatives
  parameter to Provide input derivative(s). Then set the Input
  derivatives parameter value:
  • Provide first derivative — If you select this option, an additional
    Simulink input port appears on the Simulink-PS Converter block, to let
    you connect the signal providing input derivatives.
  • Provide first and second derivatives — If you select this option,
    two additional Simulink input ports appear on the Simulink-PS
    Converter block, to let you connect the signals providing input
    derivatives.
You can choose between warning and error messages in the Simscape pane
of the Configuration Parameters dialog box.
                                                                                    3-17
 3     Model Simulation
2 Click OK.
3-18
                                                             Customizing Solvers for Physical Models
                                                                                              3-19
 3     Model Simulation
                          With a fixed-step solver, you specify the time step size to control the accuracy
                          and speed of your simulation. Fixed-step solvers do not adapt to improve
                          accuracy or to locate events. These limitations can lead to significant
                          simulation inaccuracies.
3-20
                                                   Customizing Solvers for Physical Models
• Fixed-step solvers detect events after “stepping over” them, but cannot
  adaptively locate events in time. This can lead to large inaccuracies or
  failure to converge on a solution.
• Variable-step solvers can both detect events and estimate the instants
  when they occur by adapting the timing and length of the time steps.
Tip To estimate the timing of events or rapid changes in your simulation, use
a variable-step solver.
                                                                                    3-21
 3     Model Simulation
                          step. Such iterations are variable and not generally limited in number; the
                          solver iterates as much as it needs to.
                          Fixing execution time implies fixed-cost simulation, which both fixes the time
                          step and limits the number of per-step iterations. Fixed-cost simulation
                          prevents execution overruns, when the execution time is longer than the
                          simulation sample time. A bounded execution time without a known fixed cost
                          might still cause some steps to overrun the sample time.
3-22
                                                   Customizing Solvers for Physical Models
• The ode15s solver is more stable, but tends to damp out oscillations.
• The ode23t solver captures oscillations better but is less stable.
With Simscape models, these solvers solve the differential and algebraic parts
of the physical model simultaneously, making the simulation more accurate
and efficient.
• The Backward Euler tends to damp out oscillations, but is more stable,
  especially if you increase the time step.
• The Trapezoidal Rule solver captures oscillations better but is less stable.
Regardless of which local solver you choose, the Backward Euler method is
always applied:
• If you switch a physical network to a local solver, the global solver treats
  that network as having discrete states.
                                                                                    3-23
 3     Model Simulation
                          • If other physical networks in your model are not using local solvers, or if
                            the non-Simscape parts of your model have continuous states, then you
                            must use a continuous global solver.
                          • If all physical networks in your model use local solvers, and any
                            non-Simscape parts of your model have only discrete states, then the
                            global solver effectively sees only discrete states. In that case, MathWorks
                            recommends a discrete, fixed-step global solver. If you are attempting
                            a fixed-cost simulation with discrete states, you must use a discrete,
                            fixed-step global solver.
                          In this solver, you must limit the number of global implicit iterations per
                          time step. Control these iterations with the Number Newton’s iterations
                          parameter in the Solver pane of the Configuration Parameters dialog box.
                          To limit the iterations, open the Solver Configuration block of each physical
                          network. Select Use fixed-cost runtime consistency iterations and set
                          limits for the number of nonlinear and mode iterations per time step.
3-24
                                                   Customizing Solvers for Physical Models
Any one or all of these steps increase accuracy, but make the simulation
run more slowly.
For Local Solvers. Models with friction or hard stops are particularly
difficult for local solvers, and may not work or may require a very small time
step.
With the Trapezoidal Rule solver, oscillatory “ringing” can become more of a
problem as the time step is increased. For a larger time step in a local solver,
consider switching to Backward Euler.
For ODE Systems. In certain cases, your model reduces to an ODE system,
with no dependent algebraic variables. (See “How Simscape Models Represent
Physical Systems” on page 3-2.) If so, you can use any global Simulink solver,
with no special physical modeling considerations. An explicit solver is often
the best choice in such situations.
For Large Systems. Depending on the number of system states, you can
simulate more efficiently if you switch the value of the Linear Algebra
setting in the Solver Configuration block.
                                                                                    3-25
 3     Model Simulation
                          For smaller systems, Full provides faster results. For larger systems, Sparse
                          is typically faster.
                          • Two networks (numbers 1 and 3) use local solvers, making these two
                            networks appear to the global solver as if they had discrete states.
                            Internally, these networks still have continuous states. These networks are
                            moderately and highly stiff, respectively.
                            One of these networks (number 1) uses the Backward Euler (BE) local
                            solver. The other (number 3) uses the Trapezoidal Rule (TR) local solver.
                          • The remaining network (number 2) uses the global Simulink solver. Its
                            states appear to the model as continuous. This network is not stiff and is
                            pure ODE. Use an explicit global solver.
                          • Because at least one network appears to the model as continuous, you
                            must use a continuous solver. However, if you remove network 2, and if
                            the model contains no continuous Simulink states, Simulink automatically
                            switches to a discrete global solver.
3-26
Customizing Solvers for Physical Models
                                 3-27
 3     Model Simulation
If a simulation failed:
3-28
                                                         Troubleshooting Simulation Errors
MathWorks recommends that you build, simulate, and test your model
incrementally. Start with an idealized, simplified model of your system,
simulate it, verify that it works the way you expected. Then incrementally
make your model more realistic, factoring in effects such as friction loss,
motor shaft compliance, hard stops, and the other things that describe
real-world phenomena. Simulate and test your model at every incremental
step. Use subsystems to capture the model hierarchy, and simulate and test
your subsystems separately before testing the whole model configuration.
This approach helps you keep your models well organized and makes it easier
to troubleshoot them.
                                                                                    3-29
 3     Model Simulation
                          hydraulic fluid block is attached to a loop, the hydraulic blocks in this loop
                          use the default fluid. However, more than one hydraulic fluid block in a loop
                          generates an error.
                          If you get an error message about too many domain-specific global parameter
                          blocks attached to the network, look for an extra Hydraulic Fluid block,
                          Custom Hydraulic Fluid block, or Gas Properties block and remove it.
                          If you get an error message about a missing reference block, or node, check
                          your system configuration and add the appropriate reference block based on
                          the rules described above. The missing reference node diagnostic messages
                          include information about the particular block and variable that needs a
                          reference node. This is especially helpful when multiple domains are involved
                          in the model. For more information and examples of best modeling practices,
                          see “Grounding Rules” on page 1-36.
3-30
                                                         Troubleshooting Simulation Errors
These configurations are impossible in the real world and illegal theoretically.
If your model contains such a configuration, upon simulation the solver issues
an error followed by a list of blocks, as shown in the following example.
Example. The model shown in the following illustration contains two Ideal
Translational Velocity Sources connected in parallel. This produces a loop of
independent velocity sources, and the solver cannot construct a consistent
system of equations for the circuit.
When you try to simulate the model, the solver issues an error message with
links to the Ideal Translational Velocity Source and Ideal Translational
Velocity Source1 blocks. To fix the circuit, you can either replace the two
velocity sources by a single Ideal Translational Velocity Source block, or add a
Translational Damper block between them.
                                                                                    3-31
 3     Model Simulation
                          Parameter Discontinuities
                          Nonlinear parameters, dependent on time or other variables, may also lead
                          to numerical simulation issues as a result of parameter discontinuity. These
                          issues usually manifest themselves at the transient initialization stage (see
                          “Transient Simulation Issues” on page 3-33).
3-32
                                                           Troubleshooting Simulation Errors
                                                                                      3-33
 3     Model Simulation
                          Review your model to find the possible sources of discontinuity. See also
                          “Troubleshooting Tips and Techniques” on page 3-28.
                          You can also try to decrease the Constraint Residual Tolerance parameter
                          value (that is, tighten the tolerance) in the Solver Configuration block.
3-34
                                                                                Code Generation
Code Generation
           In this section...
           “About Code Generation from Simscape Models” on page 3-35
           “Reasons for Generating Code” on page 3-35
           “Using Code-Related Products and Features” on page 3-36
           “How Simscape Code Generation Differs from Simulink” on page 3-36
          Note Code generated from Simscape models is intended for rapid prototyping
          and hardware-in-the-loop applications. It is not intended for use as production
          code in embedded controller applications.
                                                                                            3-35
 3     Model Simulation
                          • Compiled code versions of Simulink and Simscape models run faster than
                            the original block diagram models. The time savings can be dramatic.
                          • An equally important consideration for Simscape models is the stand-alone
                            implementation of generated and compiled code. Once you convert part
                            or all of your model to code, you can deploy the stand-alone executable
                            program on virtually any platform, independently of MATLAB.
                            Converting a model or subsystem to code also hides the original model or
                            subsystem.
3-36
                                                                     Code Generation
http://www.mathworks.com/support/compilers/current_release
For all other compilers, the static runtime libraries needed by code generated
from Simscape models are compiled once per model during the code generation
build process.
                                                                                 3-37
 3     Model Simulation
3-38
                                                                             Real-Time Simulation
Real-Time Simulation
            In this section...
            “What Is Real-Time Simulation?” on page 3-39
            “Requirements for Real-Time Simulation” on page 3-40
            “Simulating Physical Models in Real Time” on page 3-41
            “Preparing a Model for Real-Time Simulation” on page 3-42
            “Troubleshooting Real-Time Simulation Problems” on page 3-45
                                                                                           3-39
 3     Model Simulation
                          Example
                          Systems with a human in the simulation loop require real-time simulation.
                          For example, flight simulators that train pilots require real-time simulation
                          of the plane, its control system, the weather, and other environmental
                          conditions.
                          The simulation execution time per time step must be consistently short
                          enough to permit any other tasks that the simulation environment must
                          perform, such as reading sensor input or generating output actuator
                          signals. This requirement must be satisfied even if the simulation changes
                          its qualitative character: the system stiffness might change, and discrete
                          components can switch states. Such changes occasionally require more
                          computations to achieve an accurate result.
                          • Choose a fixed-step solver that can capture the system dynamics accurately
                            and minimize the amount of computation required per time step, without
                            changing the step size. If the system states are all discrete, the fixed-step
                            solver can be discrete as well.
                            If you choose a small enough step size, most fixed-step solvers produce
                            the same simulation results as a variable-step solver. However, different
                            fixed-step solvers (implicit/explicit, lower/higher order, and so on) require
                            different step sizes to produce accurate results. They also require different
                            amounts of computation per time step.
3-40
                                                                     Real-Time Simulation
• Choose a fixed step size large enough to permit stable real-time simulation.
  The step size must not be so large that the simulation results are
  inaccurate, but not so small that real-time simulation is impossible.
  You often need trial and error to find the right combination of settings that
  satisfy both criteria.
Real-time simulation requires not only bounding the execution time, but fixing
it to a stable value. This requires a fixed-cost simulation method. For more
information, see “Customizing Solvers for Physical Models” on page 3-19.
This figure plots the normalized computational cost of all fixed-step solvers
available for Simscape models, obtained for a nonlinear model example with
one physical network. For comparison, the step size was kept the same, with
similar settings for the total number of solver iterations.
                                                                                    3-41
 3     Model Simulation
                          • Solver choice
                          • Number of solver iterations
                          • Simulation time step size
                          • Model size and fidelity
2 “Check Variable Time Steps for Optimal Step Size” on page 3-43
3-42
                                                                       Real-Time Simulation
To ensure that the results obtained with the fixed-step solver are accurate, you
need a set of reference results. You can obtain these by simulating the system
with a variable-step solver. Ensure that the results converge by tightening
the error tolerances until the simulation results do not change significantly.
A variable-step solver varies the step size to keep the solution within error
tolerances and to react to zero crossing events. If the solver abruptly reduces
the step size to a small value (for example, 1e-15 s), the solver is trying
to accurately identify a zero crossing event. A fixed-step solver might have
trouble capturing these events at a step size large enough to permit real-time
simulation.
                                                                                      3-43
 3     Model Simulation
                          During each time step, the real-time simulation must calculate the result
                          for the next time step (simulation execution), and read inputs and write
                          outputs (I/O processing and other tasks). If these actions take less time than
                          the specified time step, the processor remains idle during the remainder of
                          the step. Choosing a computationally more intensive solver, increasing the
                          number of nonlinear iterations, or reducing the step size both increases the
                          simulation accuracy and reduces the amount of idle time, raising the risk
                          that the simulation cannot run in real time. Adjusting these settings in the
                          opposite way increases the amount of idle time but reduce accuracy.
3-44
                                                                                        Real-Time Simulation
                   Estimating the budget for the execution time helps ensure that you choose
                   a feasible combination of settings. If you know the amount of time spent
                   processing inputs and outputs and performing other actions, as well as the
                   percentage of idle time that you want, the amount of time available for
                   simulation execution can be calculated as follows:
                   Estimating Real-Time Execution Time. You can use the desktop simulation
                   speed to estimate the execution time on a real-time hardware target. Many
                   factors affect the real-time target execution time, so that comparing processor
                   speeds might not be sufficient.
                   If the simulation does not run in real time on the target hardware, the model
                   might not be real-time capable.
                                                                                                       3-45
 3     Model Simulation
                          model and the speed of the real-time platform might make it impossible to
                          find solver settings that permit it to run in real time. Consider the following
                          options to make it real-time capable.
                          Once you modify your model, return to the third, fourth, and fifth tasks of
                          “Preparing a Model for Real-Time Simulation” on page 3-42 to identify and
                          implement the appropriate settings to enable real-time simulation.
                          Alternatively, you can achieve the same goal by determining new model
                          settings that permit a larger step size or reduce the execution time (for
                          example, by reducing the number of nonlinear iterations).
3-46
                                                                    Real-Time Simulation
With scripts written in MATLAB, you can interrogate the model, identify
these components quickly, and narrow the search for the effects that you need
to modify. You can automate and extend these searches to other models with
tools like the Simulink Model Advisor. The troublesome components that
you need to locate include:
                                                                                  3-47
 3     Model Simulation
                          The most important and common type of operating point is a steady state,
                          where some or all of the system dynamic variables are constant.
                          Example
                          A pilot flying an aircraft wants to find, for a given environment, a state of the
                          aircraft engine and control surfaces that produces level, constant-velocity, and
                          constant-altitude flight relative to the ground. The requirements of "level,"
                          "constant velocity," "constant altitude," and "relative to the ground" constitute
3-48
                                                               Finding an Operating Point
Tip To find a steady state, the Simscape steady-state solver is the most direct
method. For a comprehensive suite of operating point and linearization tools,
MathWorks recommends Simulink Control Design™ software.
To analyze operating points, you work with the full state vector of your model,
which contains:
Whichever method that you choose to find an operating point, if you want to
use it for linearization, you must save the operating point information in the
form of an operating point object, a simulation time t0, or a state vector x0
and input vector u0.
                                                                                   3-49
 3     Model Simulation
                          1 In your Simscape model, set up sensor outputs for whatever block outputs
                            you want to observe.
                          2 In each block dialog box, select the Start simulation from steady state
                            check box.
                            If you also have input signals u in the model, you can capture those inputs
                            by connecting To Workspace blocks to the input Simulink signal lines.
                          The first vector of values x(t=0) that you capture during simulation reflects
                          the steady state x0 that the Simscape solver identified.
3-50
                                                             Finding an Operating Point
Note The techniques described in this section require the Simulink Control
Design product.
You must use the features of this product on the Simulink lines in your model,
not directly on Simscape physical network lines or blocks. Simulink Control
Design offers both command line and graphical interfaces for finding and
analyzing operating points.
Simulink Control Design methods are state-based, giving you full access to
state names and values, and allow you to impose operating specifications
or use simulation snapshots. MathWorks® does not recommend imposing
operating specifications state-by-state using the Simulink Control Design
dialogs (or findop function), but simulation snapshots work well.
You have several choices for operating specifications for the components of
the state vector.
                                                                                 3-51
 3     Model Simulation
                          Additional Simulink Control Design Methods. You can also use the
                          graphical user interface, through the model menu bar: Analysis > Control
                          Design > Linear Analysis. This interface gives you access to state, input,
                          and output names, structure, and initial values.
                          For more details on the use of operating point specification objects, related
                          functions, and the graphical interface, see the Simulink Control Design
                          documentation.
                          However, you cannot obtain an operating point for the original system
                          (without the source blocks) by saving the state values from the model and
                          then removing the source blocks. In general, the number, order, and identity
                          of state components change after adding and removing Simscape blocks in
                          a model.
3-52
                                                          Finding an Operating Point
                                                                              3-53
 3     Model Simulation
                          What Is Linearization?
                          Determining the response of a system to small perturbations at an operating
                          point is a critical step in system and controller design. Once you find an
                          operating point, you can linearize the model about that operating point to
                          explore the response and stability of the system. To find an operating point in
                          a Simscape model, see “Finding an Operating Point” on page 3-48.
                          If the system dynamics do not explicitly depend on time and the operating
                          point is a steady state, the system response to state and input perturbations
                          near the steady state is approximately governed by a linear time-invariant
                          (LTI) state space model:
y = C·x + D·u.
3-54
                                                           Linearizing at an Operating Point
If the operating point is not a steady state or the system dynamics depend
explicitly on time, the linearized dynamics near the operating point are more
complicated. The matrices A, B, C, D are not constant and depend on the
simulation time t0 , as well as the operating point x0 and u0 [3].
Tip While you can linearize a closed system with no inputs or outputs and
obtain a nonzero A matrix, obtaining a nontrivial linearized input-output
model requires at least one input component in u and one output component
in y.
Example
A pilot is flying, or simulating, an aircraft in level, constant-velocity, and
constant-altitude flight relative to the ground. A crucial question for the
aircraft pilot and designers is: will the aircraft return to the steady state if
perturbed from it by a disturbance, such as a wind gust — in other words,
is this steady state stable? If the operating point is unstable, the aircraft
trajectory can diverge from the steady state, requiring human or automatic
intervention to maintain steady flight.
                                                                                      3-55
 3     Model Simulation
                          For more information on Simscape dynamic and algebraic variables, see “How
                          Simscape Simulation Works” on page 3-5.
3-56
                                                       Linearizing at an Operating Point
Note The techniques described in this section require the Simulink Control
Design product.
You must use the features of this product on the Simulink lines in your model,
not directly on Simscape physical network lines or blocks.
This approach requires that you start with an operating point object saved
from trimming the model to an operating specification, as explained in “Using
Simulink® Control Design™ Techniques to Find Operating Points” on page
3-51.
                                                                                  3-57
 3     Model Simulation
                          Additional Simulink Control Design Methods. You can also use the
                          graphical user interface, through the model menu bar: Analysis > Control
                          Design > Linear Analysis. For more details on linearization, operating
                          points and state-space objects, related functions, and the graphical interface,
                          see the Simulink Control Design documentation.
                          Tip If your model has continuous states, use linmod. (Continuous states
                          are the Simscape default.) If your model has mixed continuous and discrete
                          states, or purely discrete states, use dlinmod.
                          Linearizing a model with the local solver enabled (in the Solver Configuration
                          block) is not supported.
                          Linearizing with Default State and Input. You can call linmod without
                          specifying state or input. Enter linmod('modelname') at the command line.
                          With this form of linmod, Simulink linearization solves for consistent initial
                          conditions in the same way it does on the first step of any simulation. Any
                          initial conditions, such as initial offset from equilibrium for a spring, are set
                          as if the simulation were starting from the initial time.
                          linmod allows you to change the time of externally specified signals (but not
                          the internal system dynamics) from the default. For this and more details, see
                          the linmod function reference page.
3-58
                                                           Linearizing at an Operating Point
2 Select the Start simulation from steady state check box for the physical
  networks that you want to linearize.
3 Close the Solver Configuration dialog boxes and save the modified model.
linmod linearizes at the first step of simulation. In this case, the initial state
is also an operating point, a steady state.
For more about setting up the steady-state solver, see the Solver Configuration
block reference page. For more details on its use, see “Using the Simscape
Initial Condition Solver” on page 3-50.
With this form of linmod, Simulink linearization does not solve for initial
conditions. Because not all states in the model have to be independent, it is
possible, though erroneous, to provide linmod with an inconsistent state to
linearize about.
If you specify a state that is not self-consistent (within solver tolerance), the
Simscape solver issues a warning at the command line when you attempt
linearization. The Simscape solver then attempts to make the specified x0
consistent by changing some of its components, possibly by large amounts.
Tip You most easily ensure a self-consistent state by taking the state from
some simulated time. For example, by selecting the States check box on the
Data Import/Export pane of the model Configuration Parameters dialog
box, you can capture a time series of state values in a simulation run.
                                                                                      3-59
 3     Model Simulation
                          For complete details about these blocks, see their respective block reference
                          pages.
3-60
                                                                          Linearize an Electronic Circuit
             Depending on the software you have available, use the appropriate sections of
             this example to explore various linearization and analysis techniques.
                                                                                                   3-61
 3     Model Simulation
                          frequency 1 kHz. The Scope block displays the resulting collector output
                          voltage after the DC is filtered out by the output decoupling capacitor.
                          R1 and R2 set the nominal operating point, and the small signal gain is
                          approximately set by the ratio R3/R4. The 1uF decoupling capacitors have
                          been chosen to present negligible impedance at 1 kHz.
                          The model is configured for linearization. You can quickly generate and
                          view the small-signal frequency response by double-clicking the Linearize
                          block. To view the MATLAB script that generates the frequency response,
                          double-click the Open script block. This documentation provides background
                          information and alternative ways of linearization based on the software you
                          have.
                          Open the Solver Configuration block and see that the Start simulation
                          from steady state check box is selected. Then open the Scope and run
                          the simulation to see the basic circuit behavior. The transistor junction
                          capacitance initial voltages are set to be consistent with the bias conditions
                          defined by the resistors. The output is a steady sinusoid with zero average, its
                          amplitude amplified by the transistor and bias circuit.
3-62
                                                         Linearize an Electronic Circuit
To see the circuit relax from a nonsteady initial state, in the Solver
Configuration block, clear the Start simulation from steady state check
box and click OK. With the Scope open, simulate again. In this case, the
output voltage starts at zero because the transistor junction capacitances
start with zero charge.
                                                                                  3-63
 3     Model Simulation
3-64
                                                             Linearize an Electronic Circuit
Open the Solver Configuration block, select the Start simulation from
steady state check box (as it was when you first opened the model), and click
OK. Change the simulation time back to .01 s and rerun the simulation.
Open the Solver Configuration block and make sure the Start simulation
from steady state check box is selected. When you simulate the model with
the Simscape steady-state solver enabled, the circuit is initialized at the state
defined by the transistor bias resistors. This steady-state solution is an
operating point suitable for linearization.
                                                                                      3-65
 3     Model Simulation
                          Note Also make sure that the Use local solver check box is cleared.
                          Linearizing a model with the local solver enabled is not supported.
To linearize the model, type the following in the MATLAB Command Window:
[a,b,c,d]=linmod('ssc_bipolar_nonlinear');
                          You can alternatively call the linmod function with a single output argument,
                          in which case it generates a structure with states, inputs, and outputs, as well
                          as the linear time-invariant (LTI) model.
                          • a is 16-by-16
                          • b is 16-by-1
                          • c is 1-by-16
                          • d is 1-by-1
                          To generate a Bode plot with negative feedback convention, type the following
                          in the MATLAB Command Window:
                          c = -c; d = -d;
                          npts = 100; f = logspace(-2,10,npts); G = zeros(1,npts);
                          for i=1:npts
                               G(i) = c*(2*pi*1i*f(i)*eye(size(a))-a)^-1*b +d;
                          end
                          subplot(211), semilogx(f,20*log10(abs(G)))
                          grid
                          ylabel('Magnitude (dB)')
                          subplot(212), semilogx(f,180/pi*unwrap(angle(G)))
                          ylabel('Phase (degrees)')
                          xlabel('Frequency (Hz)')
                          grid
3-66
                                                          Linearize an Electronic Circuit
Note To work through this section, you must have a Simulink Control
Design license.
Simulink Control Design software has tools that help you find operating
points and returns a state-space model object that defines state names. This
is the recommended way to linearize Simscape models.
1 In the top menu bar of the Nonlinear Bipolar Transistor model, select
  Analysis > Control Design > Linear Analysis .
2 In the Linear Analysis Tool, from the Plot Result list, select New Bode.
                                                                                   3-67
 3     Model Simulation
                          Note To work through this section, you must have a Control System Toolbox
                          license.
                          You can use the built-in analysis and plotting capabilities of Control System
                          Toolbox software to analyze and compare Bode plots of different steady states.
                          First, use the Simulink linmod function to obtain the linear time-invariant
                          (LTI) model.
[a,b,c,d]=linmod('ssc_bipolar_nonlinear');
3-68
                                                           Linearize an Electronic Circuit
Not all the states of the LTI model derived in this example are independent.
Confirm this by calculating the determinant of the a matrix, det(a). The
determinant vanishes, which implies one or more zero eigenvalues. To
analyze the LTI model, reduce the LTI matrices to a minimal realization.
Obtain a minimal realization using the minreal function.
[a0,b0,c0,d0] = minreal(a,b,c,d);
12 states removed.
                                                                                    3-69
 3     Model Simulation
                          Produce the LTI model at the second steady state, reduce it to a minimal
                          realization, and superpose the second Bode plot on the first one.
                          [a_R1,b_R1,c_R1,d_R1]=linmod('ssc_bipolar_nonlinear');
                          [a0_R1,b0_R1,c0_R1,d0_R1] = minreal(a_R1,b_R1,c_R1,d_R1); % 12 states removed.
                          hold on % Keeps first Bode plot open
                          bode(a0_R1,b0_R1,c0_R1,d0_R1) % Superposes second Bode plot on first
                          For more information on using Control System Toolbox software for Bode
                          analysis, see the Control System Toolbox documentation.
3-70
                                                                                             Limitations
Limitations
               In this section...
               “Sample Time and Solver Restrictions” on page 3-71
               “Algebraic Loops” on page 3-71
               “Restricted Simulink Tools” on page 3-72
               “Unsupported Simulink Tools” on page 3-74
               “Simulink Tools Not Compatible with Simscape Blocks” on page 3-74
               “Code Generation” on page 3-75
              If you switch to a local solver in the Solver Configuration block, the states of
              the associated physical network become discrete. If there are no continuous
              Simulink or Simscape states anywhere in a model, you are free to use a
              discrete solver to simulate the model.
              Algebraic Loops
              A Simscape physical network should not exist within a Simulink algebraic
              loop. This means that you should not directly connect an output of a
              PS-Simulink Converter block to an input of a Simulink-PS Converter block of
              the same physical network.
                                                                                                  3-71
 3     Model Simulation
                          • You can use the Simulink set_param and get_param commands to set or
                            get Simscape block parameters, if the parameters correspond to fields in
                            the block dialog box. MathWorks does not recommend that you use these
                            commands to find or change any other block parameters.
3-72
                                                                          Limitations
  If you make changes to block parameters at the command line, run your
  model first before saving it. Otherwise, you might save invalid block
  parameters. Any block parameter changes that you make with set_param
  are not validated unless you run the model.
• Simscape blocks accept Simulink.Parameter objects as parameter values
  in get_param and set_param, within the restrictions specified here.
• Enabled subsystems can contain Simscape blocks. Always set the States
  when enabling parameter in the Enable dialog to held for the subsystem’s
  Enable port.
  Setting States when enabling to reset is not supported and can lead
  to fatal simulation errors.
• You can place Simscape blocks within nonvirtual subsystems that support
  continuous states. Nonvirtual subsystems that support continuous states
  include Enabled subsystems and Atomic subsystems. However, physical
  connections and physical signals must not cross nonvirtual boundaries.
  When placing Simscape blocks in a nonvirtual subsystem, make sure
  to place all blocks belonging to a given Physical Network in the same
  nonvirtual subsystem.
• Simulink configurable subsystems work with Simscape blocks only if all of
  the block choices have consistent port signatures.
• For Iterator, Function-Call, Triggered, and While Iterator nonvirtual
  subsystems cannot contain Simscape blocks.
• An atomic subsystem with a user-specified (noninherited) sample time
  cannot contain Simscape blocks.
• When using SimState to save and restore simulations of models, you cannot
  make any changes to the Simscape blocks in the model between the time
  at which you save the SimState and the time at which you restore the
  simulation using the SimState.
  This is an extension of the Simulink limitation prohibiting structural
  changes to the model between these two points in time (see “Limitations of
  the SimState”). Changes to Simscape block parameters can cause equation
  changes and result in changes to the state representation. Therefore,
  modifying parameters of Simscape blocks between saving and restoring
  the SimState is not allowed.
                                                                               3-73
 3     Model Simulation
                          • The Simulink Profiler tool does not work with Simscape models.
                          • Exporting a model to a format used by an earlier version (File > Export
                            Model to > Previous Version) is not supported for models containing
                            Simscape blocks.
                          • Physical signals and physical connection lines between conserving ports are
                            different from Simulink signals. Therefore, the Signal and Scope Manager
                            tool and the signal label functionality are not supported.
3-74
                                                                              Limitations
Code Generation
Code generation is supported for Simscape physical modeling software and its
family of add-on products. However, there are restrictions on code generated
from Simscape models.
There are variations and exceptions as well in the code generation features
of the add-on products based on Simscape platform. For details, see
documentation for individual add-on products.
                                                                                   3-75
 3     Model Simulation
                          * For the RSim Target, Simscape software supports only the Simulink
                          solver module. In the model Configuration Parameters dialog box, see the
                          Code Generation: RSim Target: Solver selection menu. The default is
                          automatic selection, which might fail to choose the Simulink solver module.
3-76
                                                                                           References
References
             [1] Moler, C. B., Numerical Computing with MATLAB, Philadelphia, Society
             for Industrial and Applied Mathematics, 2004, chapter 7
             [2] Horowitz, P., and Hill, W., The Art of Electronics, 2nd Ed., Cambridge,
             Cambridge University Press, 1989, chapter 2
             [3] Brogan, W. L., Modern Control Theory, 2nd Ed., Englewood Cliffs, New
             Jersey, Prentice-Hall, 1985
                                                                                               3-77
 3     Model Simulation
3-78
                                                                         4
                               The values you specify during block-level variable initialization are not the
                               actual values of the respective variables, but rather their target values at the
                               beginning of simulation (t = 0). Depending on the results of the solve, some of
                               these targets may or may not be satisfied.
                               If the solver cannot find a solution that exactly satisfies all the high-priority
                               targets, it issues a warning and enters the second stage of the solve process,
                               where it tries to find a solution by approximating both the high-priority and
                               the low-priority targets as closely as possible.
                               If you have selected the Start simulation from steady state check box in
                               the Solver block dialog box, the solver attempts to find the steady state (when
4-2
                                                                About Variable Initialization
the system variables are no longer changing with time). If the steady-state
solve succeeds, the state found is some steady state (within tolerance), but
not necessarily the state expected from the given initial conditions. In other
words, if simulation starts from steady state, even the high-priority variable
targets might no longer be satisfied at the start of simulation. However, if the
model has more than one steady state, the variable targets you specify can
affect which steady-state solution is selected by the solver.
After you initialize the block variables and prior to simulating the model,
you can open the Variable Viewer to see which of the variable targets have
been satisfied. The Variable Viewer displays the actual initial values of the
variables obtained as a result of the solve, along with the variable target
values, priority, and other information about the variable. For details, see
“Variable Viewer” on page 4-22.
• High — If a variable has high priority, the solver tries to find a solution
  where the actual initial value of this variable exactly satisfies its target
  value.
• Low — If a variable has low priority, the solver tries to approximate the
  target value of this variable as closely as possible when finding a solution.
  Depending on the results of the solve for high-priority variables, some of
  the low-priority targets might be met exactly, the others are approximated.
• None — A variable has no initialization priority when its Specify check
  box is cleared, and the Priority, Value, and Unit fields display Unused.
  This does not mean that the variable itself is not used in the initialization
  process, only that its target is not used. The solver finds initial values for
  all system variables, but if a variable has priority of none, (i.e. Unused),
  the solver does not try to satisfy any specific initial value for this variable
  when solving the system.
When you specify too many high-priority targets for system variables, it is
possible to over-specify your model. In this case, the solver might not be able
to find a solution that exactly satisfies all the high-priority targets, or even
                                                                                        4-3
 4    Variable Initialization and State Viewer
                               fail to find a solution altogether. For an example of how you can deal with
                               over-specification by using the Variable Viewer and changing the variable
                               priority and targets, see “Initialize Variables for a Mass-Spring-Damper
                               System” on page 4-8.
                               Suggested Workflow
                               1 Using the Variables tab of the respective block dialog boxes, specify which
                                  variable targets should be used for initialization and set their priority,
                                  target values, and units.
                               2 Open the Variable Viewer to see which of the initial targets have been
                                  satisfied. Although the viewer does not simulate the model, it runs the
                                  simulation for 0 seconds to initialize it, and therefore the model must be in
                                  an executable state.
                               3 If initialization fails, or you are not satisfied with the results, iterate by
                                  changing the block variable target values and priority, then refreshing
                                  the viewer.
4 When satisfied with initialization, run the simulation to see the results.
      Related                  • “Set Priority and Initial Target for Block Variables” on page 4-5
      Examples                 • “Initialize Variables for a Mass-Spring-Damper System” on page 4-8
4-4
                                                        Set Priority and Initial Target for Block Variables
            For details on these variables and their usage in the block equations, click the
            Source code link in the block dialog box to view the underlying Simscape
            source file. The Source code link is available for all the Foundation library
            blocks that have a Variables tab.
            To specify the initial deformation of the spring, select the check box next to
            the Deformation variable. Once you select the check box next to a variable,
            its Priority changes to High, while Value and Unit assume the values
            specified in the variable declaration in the underlying component file.
                                                                                                      4-5
 4    Variable Initialization and State Viewer
                               Type a new number into the Value field and change the unit, if desired. The
                               Unit drop-down lists contains all the units defined in the unit registry that
                               are commensurate with the one specified in the variable declaration. You
                               can also change the priority from High to Low. In the following dialog box,
                               Deformation is specified as a high-priority variable with the initial target of
                               20 mm.
4-6
                                                        Set Priority and Initial Target for Block Variables
           If you clear the check box next to a variable name, its Priority, Value, and
           Unit fields switch to Unused. However, if you select it again, these fields will
           retain their last specified value for when they were in use.
                                                                                                      4-7
 4    Variable Initialization and State Viewer
                               2 Prepare the model for simulation. On the top menu bar of the model
                                  window, select Simulation > Model Configuration Parameters. Under
                                  Solver options, set Solver to ode23t (mod.stiff/Trapezoidal) and
                                  Max step size to 0.2. Also adjust the Simulation time to be between 0
                                  and 2 seconds, by setting Stop time to 2.0.
4-8
                                       Initialize Variables for a Mass-Spring-Damper System
  and Unit assume the values specified in the variable declaration in the
  underlying component file. Change the Value to 0.1. Leave the Unit
  unchanged as m.
4 Adjust the initial position of the sensor, to compensate for the spring
  deformation. Double-click the Ideal Translational Motion Sensor block and
  set its Initial position parameter value to 0.1 m as well. This way, when
  you simulate the model, mass oscillations center around 0.
                                                                                       4-9
 4     Variable Initialization and State Viewer
                                6 Open the Variable Viewer. In the top menu bar of the model window, select
                                   Analysis > Simscape > Variable Viewer.
4-10
                                        Initialize Variables for a Mass-Spring-Damper System
  The Translational Spring variable x, in the bottom row, has high priority
  and the target value of 0.1 m. This is the Deformation variable that you
  have just set up in the block dialog box. Its actual start value matches its
  target value, and therefore its Status column displays a green circle.
  The other high-priority variable in this model is the position, x, of the Ideal
  Translational Motion Sensor block, which is set inside the component file
  because it is necessary for the correct operation of the sensor. Its actual
  start value also matches its target value, and its Status column also
  displays a green circle.
  The rest of the variables in the model do not have initialization priority
  specified, therefore their Status column also displays green circles. The
  overall status at the bottom of the Variable Viewer window displays a green
  circle as well, and says that all the variable targets are satisfied.
You can now see how specifying different variable targets affects system
initialization and simulation results.
                                                                                      4-11
 4     Variable Initialization and State Viewer
                                1 Specify the initial velocity of the mass. Double-click the Mass block, go to
                                   the Variables tab, select the check box next to the Velocity variable, and
                                   enter a value of 10. Keep the priority High and the unit m/s.
4-12
                                       Initialize Variables for a Mass-Spring-Damper System
  You can see that the solver has found a different initial solution, which
  satisfies your variable targets for spring deformation and mass velocity.
  The Status column displays green circles, and the overall status at the
  bottom of the Variable Viewer window also displays a green circle and says
  that all the variable targets are satisfied.
3 Notice that when you refreshed the Variable Viewer, the scopes turned
  blank. This happens because solver runs the simulation for 0 seconds to
  find the initial solution and display it in the Variable Viewer.
  Rerun the simulation and examine the Velocity and Position scope
  windows, to see the effect of the new initial value for mass velocity on the
  simulation results.
                                                                                     4-13
 4     Variable Initialization and State Viewer
4-14
                                        Initialize Variables for a Mass-Spring-Damper System
  The overall status at the bottom of the Variable Viewer window now
  displays a red square and says that the solver is unable to satisfy all the
  high-priority variable targets. There are red squares in the Status column
  for the two high-priority variables with targets not satisfied, as well as for
  their parent blocks.
  Notice that the solver has been able to find a solution for model
  initialization. If you rerun the simulation, it runs without errors and you
  can see the new simulation results.
                                                                                      4-15
 4     Variable Initialization and State Viewer
                                   However, the Variable Viewer shows that the model initialization solution
                                   does not satisfy your target values for block variables. This happens
                                   because placing high-priority constraints on all three elements of the
                                   mass-spring-damper system results in a conflict. You can resolve the
                                   over-specification issue by relaxing the priority of some of the conflicting
                                   variable targets.
4-16
                                       Initialize Variables for a Mass-Spring-Damper System
  The overall status at the bottom of the Variable Viewer window now
  displays a yellow triangle and says that all the high-priority targets are
                                                                                     4-17
 4     Variable Initialization and State Viewer
                                   satisfied, but some of the low-priority targets are not satisfied. There are
                                   now two yellow triangles in the status column: one for the low-priority force
                                   variable f and one for its parent block, Translational Damper.
                                   Essentially, the solution found in this case is the same as when you
                                   previously specified high-priority target for the mass velocity, and the
                                   simulation results are the same.
4-18
                                       Initialize Variables for a Mass-Spring-Damper System
                                                                                     4-19
 4     Variable Initialization and State Viewer
                                   Again, the Variable Viewer status says that all the high-priority targets
                                   have been satisfied and that some of the low-priority targets are not
                                   satisfied. However, because you changed the variable priorities, the solver
                                   now tried to satisfy the initial force on the damper rather than the mass
                                   velocity, and the solution is different in this case, as are the simulation
                                   results.
4-20
                                                  Initialize Variables for a Mass-Spring-Damper System
Related    • “Set Priority and Initial Target for Block Variables” on page 4-5
Examples
                                                                                                4-21
 4     Variable Initialization and State Viewer
       Variable Viewer
                                 In this section...
                                 “About Variable Viewer” on page 4-22
                                 “Advanced Configuration” on page 4-25
                                 “Useful Filtering Techniques” on page 4-26
                                 “Interaction with Model Updates and Simulation” on page 4-27
                                To open the Variable Viewer, in the top menu bar of the model window, select
                                Analysis > Simscape > Variable Viewer.
                                The Variable Viewer is a table, its rows listing all the blocks in the model
                                and all the public variables under each block, and the columns providing
                                the initialization status, priority, target and actual start values, and other
                                information for each variable.
4-22
                                                                          Variable Viewer
By default, the Variable Viewer opens in basic configuration, which has the
following columns:
 Name            Description
 Status          Initialization status of each variable, can be one of:
                                                                                   4-23
 4     Variable Initialization and State Viewer
                                 Name             Description
                                 Start            The actual initial value of the variable computed by the
                                                  solver.
                                 Unit             The variable base unit, common for all the values
                                                  (Target, Prestart, and Start). Simscape unit manager
                                                  automatically converts all the values as needed. For
                                                  example, if you specified the target Value in the block
                                                  dialog box as 20 and the Unit as mm, the Variable Viewer
                                                  displays the Target as 0.2 and Unit as m.
Expands all nodes, showing all variables under each block name.
                                      Collapses all variables under each block name. You can then expand
                                      the block nodes individually to see the variables under this block.
                                      Recomputes the initial conditions for the model and refreshes the
                                      values displayed in the viewer. Use this button after adjusting the block
                                      parameter values, changing variable priorities and targets, or updating
                                      the block diagram. For more information, see “Interaction with Model
                                      Updates and Simulation” on page 4-27.
                                      Clears all the column filtering options and displays all the rows in the
                                      table. For more information, see “Useful Filtering Techniques” on page
                                      4-26.
                                      Shows the Variable Viewer in its default, basic, configuration, with only
                                      the following columns displayed: Status, Priority, Target, Start,
                                      and Unit.
                                      Shows the Variable Viewer in advanced configuration, with all the
                                      columns displayed. Use this view for troubleshooting your model, for
                                      example, if the model initialization failed.
4-24
                                                                           Variable Viewer
Advanced Configuration
In most cases, the default Variable Viewer configuration contains sufficient
data for viewing the variable targets and verifying the model initialization
results. However, if the solver is unable to satisfy all the high-priority variable
targets, or if the model initialization fails, the advanced Variable Viewer
configuration might provide additional data that can help you troubleshoot
your model.
 Name             Description
 Prestart         The value of the variable that the solver uses at the
                  beginning of the initial conditions solve process. For
                  variables with no initialization priority, the prestart values
                  come from the variable declaration in the underlying
                  component file. If the initialization process fails, these
                  values can help you determine the reason (for example, a
                  prestart value of 0 for a variable used as a denominator in a
                  model equation). If a variable has an undesirable prestart
                  value, specify a better value as a low-priority initialization
                                                                                      4-25
 4     Variable Initialization and State Viewer
Name Description
                                You can change the default order of columns by clicking a column heading
                                and dragging it, while holding down the mouse button, to the desired location.
                                You can also hide columns by right-clicking their headers and selecting Hide
                                This Column from the context menu, or clearing the check mark next to a
                                To filter the rows, click the arrow, and then select or clear the check boxes in
                                the drop-down list to indicate which rows you want to be displayed, based on
4-26
                                                                          Variable Viewer
their value. Selecting All clears all the filters for that column. To clear all
For example, filtering on the Priority column values (selecting only the check
boxes for HIGH and LOW) lets you view all the targets and actual values in a
compact format, which can be helpful for a large model.
You might also find the following filtering techniques useful in troubleshooting
your models:
• Filter the Differential column on TRUE, to display only the rows for
  differential variables. Time derivatives of these variables appear in
  equations. These variables add dynamics to the system and can produce
  independent states, therefore these variables are more likely to require
  high initialization priority.
• Filter the Determined column on TRUE, to verify that these variables
  have no initialization priority. The values of these variables are either
  predetermined by the equation analysis or depend on the system inputs,
  and therefore specifying initialization priority and targets for these
  variables has little or no effect on model initialization.
• The model must be in an executable state when you open or refresh the
  viewer, otherwise you get an error message.
• If the scopes are open, they turn blank every time you open or refresh the
  viewer. Rerun the simulation to see the new results.
• If you rerun the simulation while the Variable Viewer is open, the results in
  the viewer are automatically refreshed when the simulation starts running.
• If you change variable priorities and targets or adjust the block parameters
  while the Variable Viewer is open, the results in the viewer are not updated
  automatically. Refresh the viewer (by clicking      in the Variable Viewer
  toolbar) to compute the new actual values of the variables and update the
  status.
                                                                                   4-27
 4     Variable Initialization and State Viewer
                                • If you update block diagram (by selecting Simulation > Update Diagram
                                  in the top menu bar of the model window) while the Variable Viewer is
                                  open, the previously computed actual values become unavailable and the
                                  Status column displays gray rectangles. The overall status at the bottom
                                  of the Variable Viewer window is also not available. Refresh the viewer to
                                  compute the new actual values of the variables and update the status.
4-28
                                                 5
Data Logging
                     Suggested Workflows
                     You can log simulation data to the workspace for debugging and verification.
                     Data logging lets you analyze how internal block variables change with time
                     during simulation. For example, you may want to see that the pressure in a
                     hydraulic cylinder is above some minimum value, or compare it against the
                     pump pressure. If you log simulation data to the workspace, you can later
                     query, plot, and analyze it without rerunning the simulation.
                     Simulation data logging can also replace connecting sensors and scopes to
                     track simulation data. These blocks increase the model complexity and slow
                     down simulation. The “Log and Plot Simulation Data” on page 5-7 shows how
                     you can log and plot simulation data instead of adding sensors to your model.
                     It also shows how you can print the complete logging tree for a model, and
                     plot simulation results for a selected variable.
                     For additional information, see the reference pages for the classes
                     simscape.logging.Node, simscape.logging.Series, and their associated
                     methods.
                     Limitations
                     Simulation data logging is not supported for:
                     • Model reference
                     • Generated code
                     • Accelerator mode
                     • Rapid Accelerator mode
5-2
                                                                       How to Log Simulation Data
           1 In the model window, from the top menu bar, select Simulation > Model
             Configuration Parameters. The Configuration Parameters dialog box
             opens.
                                                                                             5-3
 5    Data Logging
                     4 Simulate the model. This creates a workspace variable named simlog (as
                       specified by the Workspace variable name parameter), which contains
                       the simulation data.
                     For information on how to access and use the data stored in this variable, see
                     “Log and Plot Simulation Data” on page 5-7.
5-4
                                                             How to Log Simulation Data
Saving data to the workspace can slow down the simulation and consume
memory. To avoid this, you can use either the Decimation parameter, or
Limit data points in conjunction with Data history (last N steps), or both
methods, to limit the number of data points saved. The two methods work
independently from each other and can be used separately or together. For
example, if you specify a decimation factor of 2 and keep the default value
of 5000 for the Data history (last N steps) parameter, your workspace
variable will contain downsampled data from the last 10000 time steps in the
simulation.
                                                                                   5-5
 5    Data Logging
5-6
                                                                        Log and Plot Simulation Data
           This model is very similar to the Permanent Magnet DC Motor example, but,
           unlike the example model, it does not include the Ideal Rotational Motion
           Sensor and the Current Sensor blocks, along with the respective PS-Simulink
           Converter blocks and scopes. For a detailed description of the Permanent
           Magnet DC Motor example, see “Evaluating Performance of a DC Motor”.
                                                                                                5-7
 5    Data Logging
                     3 Simulate the model. This creates a workspace variable named simlog (as
                       specified by the Workspace variable name parameter), which contains
                       the simulation data.
                     4 The simlog variable has the same hierarchy as the model. To see the whole
                       variable structure, at the command prompt, type:
simlog.print
                           dc_motor2
                           +-Electrical_Reference2
                           | +-V
                           | | +-v
                           | +-i
                           +-Friction_Mr
                           | +-C
                           | | +-w
5-8
                                           Log and Plot Simulation Data
| +-R
| | +-w
| +-t
| +-w
+-L
| +-i
| +-i_L
| +-n
| | +-v
| +-p
| | +-v
| +-v
+-Load_Torque
| +-C
| | +-w
| +-R
| | +-w
| +-S
| +-t
| +-w
+-Mechanical_Rotational_Reference
| +-W
| | +-w
| +-t
+-Mechanical_Rotational_Reference1
| +-W
| | +-w
| +-t
+-Motor_Inertia_J
| +-I
| | +-w
| +-t
+-Rotational_Electromechanical_Converter
| +-C
| | +-w
| +-R
| | +-w
| +-i
| +-n
| | +-v
                                                                   5-9
 5     Data Logging
                             | +-p
                             | | +-v
                             | +-t
                             | +-v
                             | +-w
                             +-Rotor_Resistance_R
                             | +-i
                             | +-n
                             | | +-v
                             | +-p
                             | | +-v
                             | +-v
                             +-Simulink_PS_Converter
                             +-x1_5V
                              +-i
                              +-n
                              | +-v
                              +-p
                              | +-v
                              +-v
s1 = simlog.Rotational_Electromechanical_Converter.R.w.series;
                        From here, you can access the values and time vectors for the series and
                        analyze them.
                      6 You do not have to isolate series data to plot its values against time,
                        or against another series. For example, to see how the motor speed (in
                        revolutions per minute) changes with time, type:
5-10
                                                              Log and Plot Simulation Data
7 Compare this figure to the RPM scope display in the Permanent Magnet
  DC Motor example. The results are exactly the same.
8 To plot the motor torque against its angular velocity, in rpm, and add
  descriptive axis names, type:
                                                                                    5-11
 5     Data Logging
                      Note Plotting simulation data for a high-level node and its children can
                      generate a large number of plots. By default, the plots are not docked
                      in the desktop, which results in a multitude of separate figure windows.
                      To avoid this inconvenience, you can issue a command to make figures
                      automatically dock in the desktop. For more information, see “Docking
                      Figures Automatically” in the MATLAB documentation.
5-12
                                                                             Log Simulation Statistics
            This model is the same as the one used in the “Log and Plot Simulation Data”
            on page 5-7 example.
                                                                                                5-13
 5     Data Logging
                      3 Simulate the model. This creates a workspace variable named simlog (as
                        specified by the Workspace variable name parameter), which contains
                        the simulation data. Because you selected the Log simulation statistics
                        checkbox, the workspace variable contains additional nodes that represent
                        zero-crossing data.
                      4 The simlog variable has the same hierarchy as the model. To see the whole
                        variable structure, at the command prompt, type:
simlog.print
                            dc_motor2
                            +-Electrical_Reference2
                            | +-V
                            | | +-v
                            | +-i
                            +-Friction_Mr
5-14
                                     Log Simulation Statistics
| +-C
| | +-w
| +-R
| | +-w
| +-SimulationStatistics
| | +-zc_0
| | | +-crossings
| | | +-values
| | +-zc_1
| | | +-crossings
| | | +-values
| | +-zc_2
| |     +-crossings
| |     +-values
| +-t
| +-w
+-L
| +-i
| +-i_L
| +-n
| | +-v
| +-p
| | +-v
| +-v
+-Load_Torque
| +-C
| | +-w
| +-R
| | +-w
| +-S
| +-t
| +-w
+-Mechanical_Rotational_Reference
| +-W
| | +-w
| +-t
+-Mechanical_Rotational_Reference1
| +-W
| | +-w
| +-t
                                                        5-15
 5     Data Logging
                            +-Motor_Inertia_J
                            | +-I
                            | | +-w
                            | +-t
                            +-Rotational_Electromechanical_Converter
                            | +-C
                            | | +-w
                            | +-R
                            | | +-w
                            | +-i
                            | +-n
                            | | +-v
                            | +-p
                            | | +-v
                            | +-t
                            | +-v
                            | +-w
                            +-Rotor_ResistanceR
                            | +-i
                            | +-n
                            | | +-v
                            | +-p
                            | | +-v
                            | +-v
                            +-x1_5V
                              +-i
                              +-n
                              | +-v
                              +-p
                              | +-v
                              +-v
                      5 If you compare this tree to the one used in the “Log and Plot Simulation
                        Data” on page 5-7 example, you can see that under the Friction_Mr node
                        there is now an additional node called SimulationStatistics. The rest of
                        the tree is unchanged. This means that Friction Mr is the only block in the
                        model that can generate zero-crossings during simulation.
5-16
                                                             Log Simulation Statistics
6 You can access and analyze this data similar to other data logged
  to workspace during simulation. For more information, see
  simscape.logging.Node and simscape.logging.Series reference pages.
                                                                                5-17
 5     Data Logging
5-18
                                                                    6
Model Statistics
                         Use model statistics as part of the iterative model building process. For
                         example, after you make a change to the model, you can view model statistics
                         to answer the following questions:
6-2
                                                                         Simscape™ Model Statistics
           • 1-D/3-D Interface — This node lists the connections between the two
             types of physical networks. It appears only for models that connect blocks
             from SimMechanics Second Generation library to Simscape blocks, or
             blocks from other add-on products.
           The Sources section of the Statistics Viewer window lists variable sources for
           the selected statistic:
                                                                                               6-3
 6    Model Statistics
6-4
                                                             1-D Physical System Statistics
                                                                                      6-5
 6    Model Statistics
                               their values only at specific events, such as sample time hits. These
                               variables are typically generated from blocks that are sampled and run
                               at specified sample times.
                           -   Number of real-valued variables — This statistic represents the
                               number of real-valued discrete variables associated with all 1-D physical
                               systems in the model. Real-valued discrete variables are system
                               variables that take on real values and can change their values only at
                               specific events.
                               If you select a local solver in the Solver Configuration block, then all
                               continuous variables associated with that system are discretized and
                               represented as real-valued discrete variables.
                         • Number of zero-crossing signals — This statistic represents the number
                           of scalar signals that are monitored by the Simulink zero-crossing detection
                           algorithm. Zero-crossing signals are scalar functions of states, inputs, and
                           time whose crossing zero indicates discontinuity in the system. These
                           signals are typically generated from operators and functions that contain
                           discontinuities, such as comparison operators, abs, sqrt functions, and
                           so on. Times when these signals cross zero are reported as zero-crossing
                           events. During simulation it is possible for none of these signals to produce
                           a zero-crossing event or for one or more of these signals to have multiple
                           zero-crossing events.
                         • Number of dynamic variable constraints — This statistic represents
                           the number of constraints involving only dynamic variables and inputs.
                           Such constraints result in high-index differential algebraic equations
                           (DAEs) and therefore can cause numerical difficulties or slow down your
                           simulation.
                         If you select a statistic with a nonzero value, the Sources section lists all the
                         variables that fall under this statistic. For each variable:
                         • The Source column contains the full path to the variable, starting from
                           the top-level model, with a link to the relevant block. If you click the
                           link in the Source column, the corresponding block is highlighted in the
                           block diagram.
                         • The Value column contains the name of the variable, as it would appear in
                           the Variables tab of the block dialog box.
6-6
                                                                     1-D Physical System Statistics
                                                                                              6-7
 6    Model Statistics
6-8
                                                          3-D Multibody System Statistics
                                                                                     6-9
 6     Model Statistics
                            equations that a cut joint contributes equals six minus the number of
                            degrees of freedom that joint provides.
                            For more information about kinematic graphs and trees, see the statistic
                            description for Number of joints (total).
                          • Number of position constraint equations (non-redundant) — This
                            statistic provides the number of unique position constraint equations
                            associated with a model. This number is smaller than or equal to the
                            total number of position constraint equations. The difference between the
                            two is the number of redundant position constraint equations, which are
                            satisfied whenever the unique position constraint equations are satisfied.
                            SimMechanics attempts to remove redundant equations to improve
                            simulation performance.
                          • Number of mechanism degrees of freedom (minimum) — This
                            statistic provides a lower bound on the number of degrees of freedom in a
                            mechanical system. It equals the difference between the number of tree
                            degrees of freedom and the number of non-redundant position constraint
                            equations. The actual number of degrees of freedom can exceed this lower
                            bound if SimMechanics fails to detect a position constraint equation.
                            Some position constraint equations become redundant only in certain
                            configurations. If an equation becomes redundant during simulation, the
                            actual number of degrees of freedom in a model can change. However,
                            that number must still equal or exceed the lower bound that this statistic
                            provides.
                          • State vector size — This statistic provides the number of scalar values in
                            the state vector of a mechanical system.
                          • Average kinematic loop length — This statistic provides the average
                            number of edges—or, equivalently, vertices—in the closed loops of a
                            kinematic graph. The average number is taken over all loops in the graph.
                            If the graph has no kinematic loops, this number equals zero.
                            For more information about kinematic graphs and trees, see the statistic
                            description for Number of joints (total).
6-10
                                                                           1-D/3-D Interface Statistics
            • The Source column contains the full path to the interface port, starting
              from the top-level model, with a link to the relevant block. If you click the
              link in the Source column, the corresponding block is highlighted in the
              block diagram.
            • The Value column specifies whether the port is the source or destination.
            If you expand a connection node, the Statistics Viewer provides the filtering
            information: whether a filter is used, and, if yes, the filter order and time
            constant.
                                                                                                 6-11
 6     Model Statistics
6-12
                                                                             View Model Statistics
            2 To view model statistics, in the top menu bar of the model window, select
              Analysis > Simscape > Statistics Viewer.
              The Simscape Statistics window opens, displaying the name of the model
              and an overview of the models statistics in a collapsed state.
                                                                                            6-13
 6     Model Statistics
6-14
                                                                    View Model Statistics
  You can see that, after variable elimination, the model contains seven
  continuous differential variables, no algebraic variables, no discrete
  variables, and no zero-crossing signals.
5 Select Analysis > Simscape > Statistics Viewer to refresh the model
  statistics.
                                                                                   6-15
 6     Model Statistics
6-16
                                                                             View Model Statistics
                                                                                            6-17
 6     Model Statistics
                          2 To view model statistics, in the top menu bar of the model window, select
                            Analysis > Simscape > Statistics Viewer.
                            The Simscape Statistics window opens, displaying the name of the model
                            and an overview of the models statistics in a collapsed state.
6-18
                                            Access Block Variables Using Statistics Viewer
 You can see that, after variable elimination, the model contains three
 continuous differential variables, and the Sources section of the Statistics
 Viewer lists these three variables. For each variable:
                                                                                    6-19
 6     Model Statistics
                            • The Source column contains the full path to the variable, starting from
                              the top-level model, with a link to the relevant block.
                            • The Value column contains the name of the variable, as it would appear
                              in the Variables tab of the block dialog box.
                          4 Click the first link in the Source column. The full path indicates that
                            the source variable i_L belongs to block L (Inductor) in the DC Motor
                            subsystem of the top-level example model, therefore the DC Motor
                            subsystem opens and the corresponding block is highlighted in the block
                            diagram, as shown in the following figure.
6-20
                                                        Access Block Variables Using Statistics Viewer
             According to the Value column in the Statistics Viewer, the name of the
             variable in the block dialog box is Inductor current. The dialog box shows
             that this variable has high initialization priority and a target value of 0
             A. You can modify the priority and value, if needed, and then open the
             Variable Viewer to see the model initialization results.
Related    • “Set Priority and Initial Target for Block Variables” on page 4-5
Examples
                                                                                                6-21
 6     Model Statistics
6-22
                                                              7
Physical Units
                       Simscape software comes with a library of standard units, and you can define
                       additional units as needed (see “Unit Definitions” on page 7-4). You can use
                       these units in your block diagrams:
7-2
                                                        How to Work with Physical Units
  of the input physical signal coming into the converter block and applies a
  gain equal to the conversion factor before outputting the Simulink signal.
  The default value is 1, which means that the unit is not specified. If you
  do not specify a unit, or if the unit matches the actual units of the input
  physical signal, no gain is applied.
For more information, see “How to Specify Units in Block Dialogs” on page
7-10.
Note Currently, the blocks in the Physical Signals library (such as PS Add,
PS Gain, and so on) ignore the physical unit of the input signal and just
perform calculations on the value. The output signals of the Physical Signals
library blocks are unitless.
                                                                                   7-3
 7    Physical Units
      Unit Definitions
                       Simscape unit names are defined in the pm_units.m file, which is shipped with
                       the product. You can open this file to see how the physical units are defined in
                       the product, and also as an example when adding your own units. This file is
                       located in the directory matlabroot\toolbox\physmod\common\units\mli\m.
                       Default registered units and their abbreviations are listed in the following
                       table. Use the pm_getunits command to get an up-to-date list of units
                       currently defined in your unit registry. Use the pm_adddimension and
                       pm_addunit commands to define additional units.
7-4
                                                                Unit Definitions
                                                                           7-5
 7    Physical Units
7-6
                                                              Unit Definitions
                                                                         7-7
 7    Physical Units
7-8
                                                                        Unit Definitions
Note This table lists the unit abbreviations defined in the product. For
information on how to use the abbreviations above, or mathematical
expressions with these abbreviations, to specify units for the parameter values
in the block dialogs, see “How to Specify Units in Block Dialogs” on page 7-10.
                                                                                   7-9
 7     Physical Units
                        You can either select a unit from the drop-down list, or type a commensurate
                        unit name (or a mathematical expression with unit names) directly into the
                        unit combo box of the block dialog. You can use the abbreviations for the
                        units defined in your registry, or any valid mathematical expressions with
                        these abbreviations. For example, you can specify torque in newton-meters
                        (N*m) or pound-feet (lbf*ft). To specify velocity, you can use one of the
                        defined unit abbreviations (mph, fpm, fps), or an expression based on any
                        combination of the defined units of length and time, such as meters/second
                        (m/s), millimeters/second (mm/s), inches/minute (in/min), and so on.
                        Note Affine units (such as Celsius or Fahrenheit) are not allowed in unit
                        expressions. For more information, see “About Affine Units” on page 7-12.
                         *        Multiplication
                         /        Division
                         ^        Power
                         +        Plus — for exponents only
                         -        Minus — for exponents only
                         ()       Brackets to specify evaluation order
                        Metric unit prefixes, such as kilo, milli, or micro, are not supported. For
                        example, if you want to use milliliter as a unit of volume, you have to add
                        it to the unit registry:
7-10
                                                      How to Specify Units in Block Dialogs
                                                                                     7-11
 7     Physical Units
Tnew = L * Told + O
TFahr = 9 / 5 * TCels + 32
                        The following are the default Simscape unit registry definitions for
                        temperature units:
7-12
                                                                 Thermal Unit Conversions
ΔTnew = L * ΔTold
In this case, adding the affine offset would yield incorrect conversion results.
ΔTkelvin = 5 / 9 * ΔTFahr
and you get 10 K, that is, the outdoor temperature changed by 10 kelvin.
If you apply affine conversion, you will get a temperature change of
approximately 265 kelvin, which is incorrect.
This is even better illustrated if you use degrees Celsius for the input units
because the linear term for conversion between Celsius and kelvin is 1:
For example, you model a house-heating system, and you need to input the
outdoor temperature. In the following diagram, the Constant source block
represents the average outdoor temperature, in degrees Celsius, and the
Sine source block adds the daily temperature variation. The average outdoor
temperature, in this case, is 12 degrees Celsius. Daily variation with an
amplitude of 8 makes the input outdoor temperature vary between 4 and 20
degrees Celsius.
                                                                                   7-13
 7     Physical Units
7-14
                                                             Thermal Unit Conversions
                                                                               7-15
 7     Physical Units
       Angular Units
                        Simscape implementation of angular units relies on the concept of angular
                        units, specifically radians, being a unit but dimensionless. The notion of
                        angular units being dimensionless is widely held in the metrology community.
                        The fundamental angular unit, radian, is defined in the Simscape unit
                        registry as:
pm_addunit('rad', 1, 'm/m');
                        which corresponds to the SI and NIST definition [1]. In other words, Simscape
                        unit manager does not introduce a separate dimension, 'angle', with a
                        fundamental unit of 'rad' (similar to dimensions for length or mass), but
                        rather defines the fundamental angular unit in terms of meter over meter or,
                        in effect, 1.
                        The additional angular units, degree and revolution, are defined respectively
                        as:
                        As a result, forward trigonometric functions, such as sin, cos, and tan, work
                        directly with arguments expressed in angular units. For example, cosinus of
                        90 degrees equals the cosinus of (pi/2) radians and equals the cosinus of (pi/2).
                        Expansion of forward trigonometric functions works in a similar manner.
                        References
                        [1] The NIST Reference on Constants, Units, and Uncertainty,
                        http://physics.nist.gov/cuu/Units/units.html
7-16
                                                              Units for Angular Velocity and Frequency
           Simscape software defines the unit hertz (Hz) as 1/s, in compliance with
           the SI unit system. This definition works well when frequency refers to a
           nonrotational periodic signal such as the frequency of a PWM source. For
           cyclical processes, however, the block equations have to contain the 2*pi
           conversion factor, to convert the numerical value specified in Hz, or s-1, to
           angular frequency.
           As a result, frequency units (based on Hz) and angular velocity units (based on
           rpm) are not directly convertible, and using one instead of the other may result
           in unexpected conversion factors applied to the numerical values by the block
           equations. For example, the AC Voltage Source block explicitly multiplies
           the value you specify for its Frequency parameter by 2*pi, to convert it to
           angular frequency before calculating the sine function.
           Drop-down lists of suggested units in block dialogs reflect this distinction. For
           example, if a block has a Frequency parameter with the default unit of Hz,
           the drop-down list for this parameter contains only units directly convertible
           to Hz (such as kHz, MHz, and GHz) and does not contain the angular velocity
           units. Conversely, if you define a custom block where the Frequency
           parameter has the default unit of rpm, its drop-down list of suggested units
           will include deg/s and rad/s, but will not contain Hz, kHz, MHz, or GHz.
           When you type a unit expression in the parameter units combo box (instead
           of selecting a value from the drop-down list), the Simscape unit manager
           considers the units of frequency and angular velocity to be commensurate. For
           example, when the default parameter unit is Hz, you are able to type not only
           1/s, but also expressions such as deg/s and rad/s. This behavior is consistent
           with the Simscape implementation of angular units (see “Angular Units” on
           page 7-16). It is your responsibility to verify that the unit expression you
           typed works correctly with the block equations and reflects your design intent.
                                                                                                7-17
 7     Physical Units
                        Note Prior to Release R2013a, the unit definition for Hz was rev/s. For
                        information on how to update legacy models and custom Simscape libraries
                        written in R2012b or earlier, see Compatibility Considerations under “Unit
                        definition of Hz now consistent with SI”, in the R2013a Release Notes.
7-18
                                                          8
                           Suggested Workflows
                           The Simscape Editing Mode functionality is implemented for customers
                           who perform physical modeling and simulation using Simscape platform
                           and its add-on products: SimDriveline, SimElectronics, SimHydraulics,
                           SimMechanics, and SimPowerSystems. It allows you to open, simulate, and
                           save models that contain blocks from add-on products in Restricted mode,
                           without checking out add-on product licenses, as long as the products are
                           installed on your machine. It is intended to provide an economical way to
                           distribute simulation models throughout a team or organization.
                           Note Unless your organization uses concurrent licenses, see the Simscape
                           product page on the MathWorks Web site for specific information on how to
                           install add-on products on your machine, to be able to work in Restricted mode.
                           Specifically, this feature allows a user, model developer, to build a model that
                           uses Simscape platform and one or more add-on products and share that
                           model with other users, model users. When building the model in Full mode,
                           the model developer must have a Simscape license and the add-on product
                           licenses for all the blocks in the model. For example, if a model combines
                           Simscape, SimHydraulics, and SimDriveline blocks, the model developer
                           needs to check out licenses for all three products to work with it in Full mode.
8-2
                                                      About the Simscape™ Editing Mode
Once the model is built, model users need only to check out a Simscape license
to simulate the model and fine-tune its parameters in Restricted mode. As
long as no structural changes are made to the model, model users can work in
Restricted mode and do not need to check out add-on product licenses.
Another workflow, available with concurrent licenses only, lets multiple users,
who all have Simscape licenses, share a small number of add-on product
licenses by working mostly in Restricted mode, and temporarily switching
models to Full mode only when they need to perform a specific design task
that requires being in Full mode.
Note MathWorks recommends that you save all the models in Full mode
before upgrading to a new version of Simulink or Simscape software.
If you have saved a model in Restricted mode and, upon upgrading to a new
product version, open the model and it does not run, switch it to Full mode
and save. You can then again switch to Restricted mode and work without
problem.
For other types of changes, listed in the following section, your model has to
be in Full mode. Some of these disallowed changes are impossible to make in
Restricted mode (for example, Restricted parameters are grayed out in block
                                                                                  8-3
 8    Add-On Product License Management
                           dialog boxes). Other changes, like changing the physical topology of a model,
                           are not explicitly disallowed, but if you make these changes in Restricted
                           mode, the software will issue an error message when you try to run, compile,
                           or save such a model.
                           • Add or delete Physical Modeling blocks (that is, Simscape blocks or blocks
                             from the add-on product libraries).
                           • Make or break Physical connections (between Conserving or Physical
                             Signal ports).
                           • Change the types of signals going into actuators or out of sensors (for
                             example, from velocity to torque).
                           • Change configuration parameters.
                           • Change block parameterization options and other restricted parameters.
                           • Change physical units of parameters.
                           • Protect a referenced model containing Physical Modeling blocks (for more
                             information, see “Protected Model”).
8-4
About the Simscape™ Editing Mode
                            8-5
 8    Add-On Product License Management
                           New models are always created in Full mode. You can then either save the
                           model in Full mode, or switch to Restricted mode and save the model in
                           Restricted mode.
                           When you load an existing model, the license manager checks whether it has
                           been saved in Full or Restricted mode.
                           • If the model has been saved in Restricted mode, it opens in Restricted mode.
                           • If the model has been saved in Full mode, the license manager checks
                             whether all the add-on product licenses for this model are available and, if
                             so, opens it in Full mode. If a add-on product license is not available, the
                             license manager issues an error message and opens the model in Restricted
                             mode. See also “Example with Multiple Add-On Products” on page 8-6.
                           Note You can set a Simulink preference to specify that the models are always
                           to open in Restricted mode, regardless of the way they have been saved.
                           When a model is open, you can transition it between Full and Restricted
                           modes at any time, in either direction:
                           • When you try to switch from Restricted to Full mode, the license manager
                             checks whether all the add-on product licenses for this model are available.
                             If a add-on product license is not available, the license manager issues an
                             error message and the model stays in Restricted mode. See also “Example
                             with Multiple Add-On Products” on page 8-6.
                           • No checks are performed when switching from Full to Restricted mode.
                           Note If a add-on product license has been checked out to open a model in Full
                           mode, it remains checked out for the remainder of the MATLAB session.
                           Switching to Restricted mode does not immediately return the license.
8-6
                                                      About the Simscape™ Editing Mode
For example, consider a model that uses blocks from SimHydraulics and
SimDriveline libraries, but the user who tries to open it has only the
SimDriveline license available. It may happen that the license manager
checks out a SimDriveline license first, and then tries to check out a
SimHydraulics license, which is not available. The license manager then
issues an error message and opens the model in Restricted mode, but the
SimDriveline license stays checked out until the end of the MATLAB session.
                                                                                   8-7
 8    Add-On Product License Management
                           • To add external physical ports to a library block, you need to work in Full
                             mode.
                              -   You can work in Restricted mode when loading a preexisting model that
                                  uses this library block.
                              -   However, to connect these additional ports, you need to work in Full
                                  mode because you are changing the model topology.
                           • To delete external physical ports from a library block, you need to work in
                             Full mode. If these ports were connected in a model saved in Restricted
                             mode, loading the model causes the topology to change, so you need to
                             switch to Full mode to save or compile the model.
                           If you want to customize certain blocks and use them in your models, you
                           must add these modified blocks to your own custom library, then copy the
                           block instances that you need to your model.
8-8
                                                             Working with Restricted and Full Modes
           2 In the left pane of the Preferences dialog box, select Simscape. The right
             pane displays the Editing Mode group box. By default, the Load models
             using option is set to Editing mode specified in models.
           3 Select Restricted mode always from the drop-down list, as shown, and
             click OK.
                                                                                               8-9
 8     Add-On Product License Management
                            Now, when you open a model, the license manager does not attempt to check
                            out add-on product licenses and always opens the model in Restricted mode.
                             1 From the top menu bar in the model window, select Simulation > Model
                               Configuration Parameters. The Configuration Parameters dialog box
                               opens.
3 Select Restricted from the drop-down list, as shown, and click OK.
8-10
                                                   Working with Restricted and Full Modes
Note The Simscape entry does not appear in the left pane of the
Configuration Parameters dialog box until you add at least one Physical
Modeling block to your model. If you create an additional configuration set for
a model, the Simscape entry does not appear in it until you either activate
it or perform a Physical Modeling operation, such as adding or deleting a
Physical Modeling block or connection, opening a Physical Modeling block
dialog box, and so on.
Once you have switched a model to Restricted mode, working with it follows
the rules described in “Work with a Model in Restricted Mode” on page 8-13.
Note, however, that the add-on product licenses for this model stay checked
out until you quit the MATLAB session.
                                                                                   8-11
 8     Add-On Product License Management
                            When you open a model that has been saved in Restricted mode, the license
                            manager opens it in Restricted mode and does not check out the add-on
                            product licenses.
                             2 From the top menu bar in the model window, select Simulation > Model
                               Configuration Parameters. The Configuration Parameters dialog box
                               opens.
8-12
                                                   Working with Restricted and Full Modes
When you open a block dialog box in Restricted mode, some of the block
parameters may be grayed out. These are the so-called restricted parameters
that can be modified only in Full mode. In general, you can change numerical
parameter values in Restricted mode, but you cannot change the block
parameterization options. See the block reference pages for specifics. Note
also that when a restricted parameter defines the block parameterization
schema, nonrestricted parameters available for fine-tuning in Restricted mode
depend on the value of this restricted parameter. For example, in a Constant
Volume Chamber block, the Chamber specification parameter is restricted.
If, at the time the model entered Restricted mode, this parameter was set
to By volume, then the nonrestricted parameters available for fine-tuning
would be Chamber volume, Specific heat ratio, and Initial pressure. If,
however, it was set to By length and diameter, you will have a different set
of parameters available in Restricted mode.
You cannot change physical units in Restricted mode. When you open a block
dialog box in Restricted mode, the drop-down lists of units next to a parameter
name and value are grayed out. When you open a PS-Simulink Converter or
Simulink-PS Converter block dialog box, the Unit parameter is grayed out.
                                                                                   8-13
 8     Add-On Product License Management
                             2 Open the Joint C Position scope and simulate the model. The models runs
                               and simulates in Restricted mode.
8-14
                                                 Working with Restricted and Full Modes
3 Double-click the Wheel and Axle block to open its dialog box. Notice that
  the Mechanism orientation parameter is grayed out, because you cannot
  modify the block driving direction in Restricted mode.
                                                                                 8-15
 8     Add-On Product License Management
                             5 Simulate the model again. Notice that the motion amplitude of node C
                               became smaller as a result of the wheel radius change.
6 Double-click the Mass block and change the Mass parameter value to 24.
                             7 Simulate the model. Notice that doubling the mass resulted in increased
                               vibrations.
8-16
                                                Working with Restricted and Full Modes
                                                                                8-17
 8     Add-On Product License Management
8-18
                                                Working with Restricted and Full Modes
3 Delete the Signal Builder block named Force Input. Replace it with a Sine
  Wave block from the Simulink Sources library, as shown below.
                                                                                8-19
 8     Add-On Product License Management
                             4 Simulate the model again. The model successfully compiles and simulates
                               in Restricted mode.
8-20
                                                Working with Restricted and Full Modes
                                                                                8-21
 8     Add-On Product License Management
                             3 Delete the connection line between port P of the Ideal Translational Motion
                               Sensor block and the PS-Simulink Converter block. Instead, connect port
                               V of the Ideal Translational Motion Sensor block to the input port of the
                               PS-Simulink Converter block, to measure the velocity on node C of the
                               lever.
8-22
                                                  Working with Restricted and Full Modes
4 Try to simulate the model. An error message appears saying that the
  model cannot be compiled because its topology has been changed while in
  Restricted mode. You can either undo the changes, or switch to Full mode,
  as described in “Switch from Restricted to Full Mode” on page 8-23.
1 From the top menu bar in the model window, select Simulation > Model
  Configuration Parameters. The Configuration Parameters dialog box
  opens.
                                                                                  8-23
 8     Add-On Product License Management
3 Select Full from the drop-down list, as shown, and click OK.
                               The license manager checks whether all the add-on product licenses for
                               this model are available. If yes, it checks out the add-on product licenses
                               and switches the model to Full mode. If a add-on product license is not
                               available, the license manager issues an error message and the model stays
                               in Restricted mode.
                            Note If the switch to Full mode fails but some of the add-on product licenses
                            have already been checked out, they stay checked out until you quit the
                            MATLAB session. For more information, see “Example with Multiple Add-On
                            Products” on page 8-6.
                            Once the model is switched to Full mode, you can perform the needed design
                            and simulation tasks, and then either save it in Full mode, or switch back to
                            Restricted mode and save it in Restricted mode.
8-24
                                                                             Editing Mode Information
           1 From the top menu bar in the model window, select Simulation > Model
             Configuration Parameters. The Configuration Parameters dialog box
             opens.
           3 At this point, you can either try switching the mode by selecting a different
             option from the drop-down list, or click Cancel to stay in the current mode.
license('inuse')
           This command returns a list of licenses checked out in the current MATLAB
           session. In the list, products are listed alphabetically by their license feature
           names.
8-25