



# Modeling Analog and Continuous Behaviors with SystemC-AMS

Created by Michele Lora

Nicola Dall'Ora  
Franco Fummi

# Cyber-Physical Systems

- **Embedded Systems (ES)**: information processing embedded into a large product [Marwedel, 03]
- **Cyber-Physical Systems (CPS)**: integration of computation with physical processes [Lee, 06]

$$CPS = ES + \text{physical environment}$$



# What a Cyber-Physical System is



# SystemC-AMS

- Extension of the SystemC language standard
  - System-level modeling for **Analog Mixed-Signal Systems**
  - Introduction of new execution semantics
  - Standardized by Accellera
    - Current standard version: 2.0
  - Standardized by IEEE in 2016: **IEEE 1666.1-2016**
- Methodologies for Mixed-Signal Systems:
  - Executable specifications
  - Virtual prototyping
  - Architecture exploration
  - Integration validation



# Use Cases

- Executable specification
  - Verify correctness of system requirement using simulation
- Virtual prototyping
  - High-level (untimed/timed) model of HW architecture
- Architecture exploration
  - Evaluate mapping between behavior and system architecture
- Integration validation
  - Verify the correctness of integrated components

# Discrete-time vs. Continuous-time Descriptions

- Discrete-time descriptions:
  - Signals and physical quantities defined at discrete time points
    - Assumed constant between time points
  - Behavior as procedural assignments involving sampled signals  $\Rightarrow$  E.g. digital systems
  - Well suited for describing signal-processing dominated behaviors
    - Signals are naturally (over)sampled
  - Used also for describing (approximation of) continuous-time behaviors
- Continuous-time descriptions:
  - Signal and physical quantities described as real-valued functions of time
    - Time considered as a continuous value
  - Behavior as Differential algebraic equations (DAE) or Ordinary differential equations (ODE)
    - Solved by linear or non-linear solver (complex algorithms)
  - Well suited for describing physical behaviors of dynamic systems

# Non-conservative vs. Conservative Descriptions

- Non-conservative descriptions:
  - Behavior expressed as directed flows of continuous time signals or variables
    - Processing functions (e.g., filtering or integration) are applied
  - Non-linear dynamic can be described
  - Mutual effects and interaction between AMS components not supported
    - E.g., impedances or loads
- Conservative descriptions: → model electrical circuits
  - Based on satisfaction of Kirchhoff's laws
  - Huge sets of equations to solve are inferred
    - Computational hard

# Modeling Formalisms

- Timed Data Flow (Discrete Event Models)
  - Discrete time, non-conservative modeling
  - Static scheduler (based on dataflow)
- Linear Signal Flow (LSF)
  - Continuous, non-conservative modeling
  - DAE and ODE based
    - Represented by connection of primitives for real-valued time-domain signals
  - Symbolic and numeric solvers
- Electrical Linear Network (ELN)
  - Continuous, conservative modeling
  - Modeling of electrical networks
    - Linear network primitives (e.g., resistors, capacitor etc...)
    - Continuous relations between voltage and currents



# SystemC-AMS: Modeling Formalisms



# Language Architecture



Discrete-time Non-conservative MoC:  
**Time Data Flow** discrete version of SystemC-AMS

# Fundamentals

- Based on Synchronous Data Flow (SDF)
  - SDF untimed, Discrete Event Models discrete-time
- Each Discrete Event Models module contains a C++ method
  - Computes a mathematical function
    - Depending on its direct inputs
    - Can depend also on its internal states
  - Composition of modules in appropriate order

## Composition: Example

- Overall behavior given by:  $f_C(f_B(f_A))$



# Function Execution

- A given function is executed iff there are enough samples available at the input port
  - Fixed number of consumed and produced samples
- Every sample has a time stamp
  - Fixed interval called time step

# Discrete Event Models Module and Port Attributes

- Time step (module)



- Time step (port)



- Rate (port)



- Delay (port)



- Time offset (port)

– Specialized port

# Scheduling

- Discrete Event Models Cluster: set of connected Discrete Event Models modules which belong the same static schedule
  - Parameters must be compatible
  - Defines a sequence in which Discrete Event Models modules are executed
- Overcome SystemC event-based scheduler
  - Increase in efficiency
  - Interaction with pure SystemC through specific converter ports

# Scheduling Feasibility

- Loops are sources for problems:
  - Every loop must present at least one delay port
  - No leftover samples allowed
- Delay ports can lead to inconsistency:
  - Initial value should be specified



# Scheduling Loops

write:  $1 \times 2$  samples



read/write:  $2 \times 1$  sample



read/write:  $2 \times 1$  sample



read/write:  $2 \times 1$  sample



Infinite (broken) schedule: {A→B→C→D→B→C→D}

A R:2

B

C

D:1

Possible schedule: {A→B→B→C→D}

# Connection to Discrete-event Models

- Converter input/output port are given
  - With a fixed time offset



# Closed Loop and Discrete Domain

- Special converter ports introduce implicit delay
  - Data readed by A, reach C in the same Delta cycle
  - Data produced by C are read by A after 1 cycle



# Multiple Clusters

- A Discrete Event Models model can present more clusters
  - Every cluster is scheduled independently
  - Every cluster can be connected to the others
- Communication between Discrete Event Models cluster evolves accordingly to the SystemC discrete-event scheduler!

# Language Constructs

- Discrete Event Models **Modules**
- Discrete Event Models **Ports**
- Discrete Event Models **Signals**

# Discrete Event Models Modules

```
SCA_TDF_MODULE(my_tdf_module) ①
{
    // port declarations
    sca_tdf::sca_in<double> in; ②
    sca_tdf::sca_out<double> out;

    SCA_CTOR(my_tdf_module) {} ③

    void set_attributes() ④
    {
        // module and port attributes
    }

    void initialize() ⑤
    {
        // initial values of ports with a delay
    }

    void processing() ⑥
    {
        // time-domain signal processing behavior or algorithm
    }

    void ac_processing() ⑦
    {
        // small-signal frequency-domain behavior
    }
};
```

1. Primitive module declaration
  - Macro or extending `sca_tdf::sca_module`
2. Input and output ports declarations
3. Constructor
  - Macro or by creating a new class
    - Derived from `sca_tdf::sca_module`
    - Always with parameter `sc_core::sc_module_name`
  - Only function that can be called by the user
4. Function to define module and ports attributes
5. Function to initialize data members
  - Representing module state and samples
6. Implementation of functionality
  - Processing function in time-domain
7. Implementation of functionality and noise
  - Small-frequency domain can be used to model noise

# Discrete Event Models Modules: Constraints on Usage

- Hierarchy is not supported
  - Composition of Discrete Event Models modules is possible using regular SystemC classes
- Function to describe discrete-event behavior are not allowed
  - SystemC forbidden constructs:
    - SC\_HAS\_PROCESS, SC\_METHOD, SC\_THREAD
    - wait, next\_trigger, sensitive
  - Incompatibility in execution semantics
- Local time of a Discrete Event Models module is calculate independently
  - get\_time instead of sc\_core::sc\_time\_stamp
- Specialized converter port to use SystemC signals

# Discrete Event Models Ports

- in and out port but no inout
  - Incopatible with the adopted model of computation
- «intra-cluster» ports:
  - `sca_tdf::sca_in<T>`
  - `sca_tdf::sca_out<T>`
- «extra-cluster» ports:
  - `sca_tdf::sca_de::sca_in<T>`
  - `sca_tdf::sca_de::sca_out<T>`

## Discrete Event Models Ports (Cont.d)

- Getter and Setter methods are given for ports attributes
  - Available attributes: simestep, rate, delay, timeoffset
  - `set_[attribute]( value )` and `get_[attribute]()` functions defined
  - Setters called by `set_attribute()`, Getters by `initialize()` and `process()`
- A port with non-zero delay must be always initialized
  - Member function `initialize()` of the module
- Multirate port permit to read/write on a specific sample
  - E.g., `input_port.read(0)` or `output_port.write(val, 1)`

# Discrete Event Models Signals

- Used to connect Discrete Event Models ports of different modules
  - They carry the sample, ports determine direction
  - `sca_tdf::sca_signal<T>`
- Little differences with SystemC signals
  - `read()` and `write()` functions are not provided
  - Naming for signal as in SystemC on constructor

# Discrete Event Models and Continuous-time Modeling

- Discrete Event Models is based on production of (discrete) samples
- It is possible to embed linear dynamic equations
  - Linear transfer function (Laplace)
    - Numerator-denominator form (`sca_tdf::sca_ltf_nd`)
    - Zero-pole form (`sca_tdf::sca_ltf_zp`)
    - Coefficients as objects of `sca_util::sca_vector`
    - Complex domain through `sca_util::sca_complex`
  - State-space equations
    - Matrix based representation (`sca_tdf::sca_ss`)

# Discrete Event Models Execution Semantics



Continuous-time Non-conservative MoC

## Linear Signal Flow

# Fundamentals

- Behavior defined as relations between variables of a set of Linear DAE
  - Continuous-time modeling using directed real-value signals
    - Non conservative description
    - Only one real-valued is used to represent each signal
- Signal flow models represented by block diagram notation
  - Elementary parts represented by blocks
  - Signal used to interconnect these blocks
- An LSF model is composed by a set of connected LSF modules (LSF equation system or cluster)

# Block Diagrams

- Elementary parts or functions
  - LSF Blocks
    - Every block introduces a well-defined function
    - Define within a Standard API
    - Extension of API: “forbidden”!
- Interconnection between basic blocks
  - LSF Signals
    - Specialization of SystemC signals
    - Fixed (Real) data-type
- Interfaces for discrete models
  - Timed Data Flow
  - SystemC-RTL

# Setup of LSF Equations



- Equations system composed by the constructor
  - Compose mathematical equations
    - Blocks
    - Interconnections
  - Set to default values the non-specified parameters

# LSF Modules

| <b>LSF module name</b>                                                             | <b>Description</b>                                                                     |
|------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| <code>sca_lsf::sca_add</code>                                                      | Weighted addition of two LSF signals.                                                  |
| <code>sca_lsf::sca_sub</code>                                                      | Weighted subtraction of two LSF signals.                                               |
| <code>sca_lsf::sca_gain</code>                                                     | Multiplication of an LSF signal by a constant gain.                                    |
| <code>sca_lsf::sca_dot</code>                                                      | Scaled first-order time derivative of an LSF signal.                                   |
| <code>sca_lsf::sca_integ</code>                                                    | Scaled time-domain integration of an LSF signal.                                       |
| <code>sca_lsf::sca_delay</code>                                                    | Scaled time-delayed version of an LSF signal.                                          |
| <code>sca_lsf::sca_source</code>                                                   | LSF source.                                                                            |
| <code>sca_lsf::sca_ltf_nd</code>                                                   | Scaled Laplace transfer function in the time-domain in the numerator-denominator form. |
| <code>sca_lsf::sca_ltf_zp</code>                                                   | Scaled Laplace transfer function in the time-domain in the zero-pole form.             |
| <code>sca_lsf::sca_ss</code>                                                       | Single-input single-output state-space equation.                                       |
| <code>sca_lsf::sca_tdf::sca_gain,</code><br><code>sca_lsf::sca_tdf_gain</code>     | Scaled multiplication of a TDF input signal with an LSF input signal.                  |
| <code>sca_lsf::sca_tdf::sca_source,</code><br><code>sca_lsf::sca_tdf_source</code> | Scaled conversion of a TDF input signal to an LSF output signal.                       |
| <code>sca_lsf::sca_tdf::sca_sink,</code><br><code>sca_lsf::sca_tdf_sink</code>     | Scaled conversion from an LSF input signal to a TDF output signal.                     |
| <code>sca_lsf::sca_tdf::sca_mux,</code><br><code>sca_lsf::sca_tdf_mux</code>       | Selection of one of two LSF input signals by a TDF control signal (multiplexer).       |

## LSF Modules (Cont.d)

| LSF module name                                                                  | Description                                                                                                                   |
|----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| <code>sca_lsf::sca_tdf::sca_demux,</code><br><code>sca_lsf::sca_tdf_demux</code> | Routing of an LSF input signal to either one of two LSF output signals controlled by a TDF signal (demultiplexer).            |
| <code>sca_lsf::sca_de::sca_gain,</code><br><code>sca_lsf::sca_de_gain</code>     | Scaled multiplication of a discrete-event input signal by an LSF input signal.                                                |
| <code>sca_lsf::sca_de::sca_source,</code><br><code>sca_lsf::sca_de_source</code> | Scaled conversion of a discrete-event input signal to an LSF output signal.                                                   |
| <code>sca_lsf::sca_de::sca_sink,</code><br><code>sca_lsf::sca_de_sink</code>     | Scaled conversion from an LSF input signal to a discrete-event output signal.                                                 |
| <code>sca_lsf::sca_de::sca_mux,</code><br><code>sca_lsf::sca_de_mux</code>       | Selection of one of two LSF input signals by a discrete-event control signal (multiplexer).                                   |
| <code>sca_lsf::sca_de::sca_demux,</code><br><code>sca_lsf::sca_de_demux</code>   | Routing of an LSF input signal to either one of two LSF output signals controlled by a discrete-event signal (demultiplexer). |

# Time Step Assignment and Propagation

- The time step
  - Simulation step for a LSF cluster
  - Disconnected by the numerical integration algorithm
    - Integration step can be smaller (never larger)
    - In PoC implementation (1.0): time step = integration step
- Can be explicitly assigned for every block or every cluster
  - At least one block: time step explicitly set
- Can be inferred by a propagation mechanism
  - Inferred by time step assignments within blocks
  - Connection of LSF and Discrete Event Models
    - Discrete Event Models Dynamic Time Step introduced in 2.0 standard
- Must preserves consistency

# LSF Port and Signals

- Two classes of Ports
  - `sca_lsf::sca_in`
  - `sca_lsf::sca_out`
  - Fixed data-type (called *signal flow nature*)
    - Implicitly a double
    - Conversions are forbidden!
  - Special ports to connect the discrete world!
- Signals
  - Used to bind LSF ports and components
  - Determine the direction of the signals
  - Not a templatic class
    - They can't be customized!

# Modeling Continuous-time Behavior

```
SC_MODULE(my_structural_lsf_model)
{
    sca_lsf::sca_in x; ①
    sca_lsf::sca_out y;

    sca_lsf::sca_gain gain1, gain2; ②
    sca_lsf::sca_dot dot1;
    sca_lsf::sca_add add1;

    my_structural_lsf_model( sc_core::sc_module_name, double k1, double k2 )
    : x("x"), y("y"), gain1("gain1", k1), gain2("gain2", k2), dot1("dot1"), add1("add1"),
      sig1("sig1"), sig2("sig2"), sig3("sig3")
    {
        gain1.x(x); ④
        gain1.y(sig1);
        gain1.set_timestep(1, sc_core::SC_MS); ⑤

        add1.x1(sig1);
        add1.x2(sig3);
        add1.y(sig2);

        dot1.x(sig2);
        dot1.y(y);

        gain2.x(y);
        gain2.y(sig3);
    }

    private:
        sca_lsf::sca_signal sig1, sig2, sig3; ⑥
    };
}
```



# Interaction with Discrete World



# Interaction with Discrete Event Models



# Using Discrete-events



# LSF Model Encapsulation



# Execution Semantics



Continuous-time conservative MoC

# **Electrical Linear Network**

# Fundamentals

- Composition of electrical primitives and interconnections
  - Every primitive is conservative
  - Interconnections must preserve conservation of energy
- Resolution of systems of equations
  - Every primitive introduce a set of equation
  - “Cluster” of connected components: system of equations
    - Consistency checking at run-time
- Implicit introduction of Kirchhoff's Laws
  - Kirchhoff's Current Law:  $\sum_{\sigma} i_k(t) = 0$  thus,  $\sum I_{in} = \sum I_{out}$   
*“total current or charge entering a junction or node is exactly equal to the charge leaving the node as it has no other place to go except to leave, as no charge is lost within the node”*
  - Kirchhoff's Voltage Law:  $\sum V_i(t) = 0$

# Equation System (Example)

- Consider the basic components:



Circuit symbol for a capacitor (C) with terminals p and n.

$$i_{p,n}(t) = C \cdot \frac{d(v_{p,n}(t) + \frac{q_0}{C})}{dt}$$

Circuit symbol for an inductor (L) with terminals p and n.

$$v_{p,n}(t) = L \cdot \frac{d(i_{p,n}(t) + \frac{phi_0}{L})}{dt}$$

- ... and the following composition:



- $$\left\{ \begin{array}{l} -i_1 + \frac{v_a}{R1} + C * \frac{d(v_{a,b} + \frac{q_0}{C})}{dt} = 0 \\ \frac{v_b}{R2} + C * \frac{d(v_{a,b} + \frac{q_0}{C})}{dt} = 0 \end{array} \right.$$

*Kirchhoff Laws*

# ELN Basic Blocks

- ELN Modules
  - Predefined electrical primitive
    - Used to build electrical network
  - Interface composed by *terminal*
  - Parameters for time-domain simulation
    - *time step, delays, offsets etc..*
    - Module specific: check the LRM!
- ELN Terminals: ***sca\_eln::sca\_terminal***
  - Basic component of ELN interfaces
    - Components are connected using terminals
    - Can be seen as ports
    - No direction!
  - “Bind” to nodes
- ELN Nodes: ***sca\_eln::sca\_node***
  - Primitive to connect modules
    - Binded to terminals, can be seen as signals
  - Special kind of node: Ground (***sca\_eln::sca\_node\_ref***)
    - Implements the ground of a electrical circuit

## ELN Basic Blocks (Cont.d)

| ELN module name                                            | Description                                         |
|------------------------------------------------------------|-----------------------------------------------------|
| sca_eln::sca_r                                             | Resistor                                            |
| sca_eln::sca_c                                             | Capacitor                                           |
| sca_eln::sca_l                                             | Inductor                                            |
| sca_eln::sca_vcv                                           | Voltage controlled voltage source                   |
| sca_eln::sca_vccs                                          | Voltage controlled current source                   |
| sca_eln::sca_ccvs                                          | Current controlled voltage source                   |
| >sca_eln::sca_cccs                                         | Current controlled current source                   |
| sca_eln::sca_nullor                                        | Nullor (nullator - norator pair), ideal op-amp      |
| sca_eln::sca_gyrator                                       | Gyrator                                             |
| sca_eln::sca_ideal_transformer                             | Ideal transformer                                   |
| sca_eln::sca_transmission_line                             | Transmission line                                   |
| sca_eln::sca_vsource                                       | Independent voltage source                          |
| sca_eln::sca_isource                                       | Independent current source                          |
| sca_eln::sca_tdf::sca_r,<br>sca_eln::sca_tdf_r             | Variable resistor controlled by a TDF input signal  |
| sca_eln::sca_tdf::sca_c,<br>sca_eln::sca_tdf_c             | Variable capacitor controlled by a TDF input signal |
| sca_eln::sca_tdf::sca_l,<br>sca_eln::sca_tdf_l             | Variable inductor controlled by a TDF input signal  |
| sca_eln::sca_tdf::sca_rswitch,<br>sca_eln::sca_tdf_rswitch | Switch controlled by a TDF input signal             |

## ELN Basic Blocks (Cont.d)

| ELN module name                                                                      | Description                                                    |
|--------------------------------------------------------------------------------------|----------------------------------------------------------------|
| <code>sca_elm::sca_tdf::sca_vsource,</code><br><code>sca_elm::sca_tdf_vsource</code> | Voltage source driven by a TDF input signal                    |
| <code>sca_elm::sca_tdf::sca_isource,</code><br><code>sca_elm::sca_tdf_isource</code> | Current source driven by a TDF input signal                    |
| <code>sca_elm::sca_tdf::sca_vsink,</code><br><code>sca_elm::sca_tdf_vsink</code>     | Converts voltage to a TDF output signal                        |
| <code>sca_elm::sca_tdf::sca_isink,</code><br><code>sca_elm::sca_tdf_isink</code>     | Converts current to a TDF output signal                        |
| <code>sca_elm::sca_de::sca_r,</code><br><code>sca_elm::sca_de_r</code>               | Variable resistor controlled by a discrete-event input signal  |
| <code>sca_elm::sca_de::sca_c,</code><br><code>sca_elm::sca_de_c</code>               | Variable capacitor controlled by a discrete-event input signal |
| <code>sca_elm::sca_de::sca_l,</code><br><code>sca_elm::sca_de_l</code>               | Variable inductor controlled by a discrete-event input signal  |
| <code>sca_elm::sca_de::sca_rswitch,</code><br><code>sca_elm::sca_de_rswitch</code>   | Switch controlled by a discrete-event input signal             |
| <code>sca_elm::sca_de::sca_vsource,</code><br><code>sca_elm::sca_de_vsource</code>   | Voltage source driven by a discrete-event input signal         |
| <code>sca_elm::sca_de::sca_isource,</code><br><code>sca_elm::sca_de_isource</code>   | Current source driven by a discrete-event input signal         |
| <code>sca_elm::sca_de::sca_vsink,</code><br><code>sca_elm::sca_de_vsink</code>       | Converts voltage to a discrete-event output signal             |
| <code>sca_elm::sca_de::sca_isink,</code><br><code>sca_elm::sca_de_isink</code>       | Converts current to a discrete-event output signal             |

# Structural Composition

```
SC_MODULE(my_structural_eln_model)
{
    sca_eln::sca_terminal a; ①
    sca_eln::sca_terminal b;

    sca_eln::sca_r r1, r2; ②
    sca_eln::sca_c c1;

    SC_CTOR(my_structural_eln_model)
    : a("a"), b("b"), r1("r1", 10e3), r2("r2", 100.0), c1("c1", 100e-6), net1("net1"), gnd("gnd") ③
    {
        r1.p(a); ④
        r1.n(b);

        r2.p(a);
        r2.n(net1);

        c1.p(net1);
        c1.n(gnd);
    }

    private:
        sca_eln::sca_node net1; ⑤
        sca_eln::sca_node_ref gnd;
};
```

Port-to-port binding  
ELN terminal  
Instance of class  
sca\_eln::sca\_terminal  
Port-to-port binding

ELN node  
Instance of class  
sca\_eln::sca\_node

ELN reference node  
Instance of class  
sca\_eln::sca\_node\_ref

SystemC parent module  
Object of class  
sc\_core::sc\_module

## Structural Composition (Cont.d)

1. The ELN terminals declared inside this module of class `sc_core::sc_module` become part of the structural composition.
2. The ELN primitive modules are declared within the parent module as child modules.
3. The initialization-list in the parent module's constructor propagates the necessary configuration parameters to the ELN terminals, ELN nodes, and child modules.
4. Port (terminal) binding is done inside the constructor of the parent module.
5. Internal ELN nodes are used to connect the ELN terminals and child modules. These nodes are declared in the private space, as they should not be accessible from outside the module.

# Interaction with Discrete Event Models

- Reading from Discrete Event Models

- Voltage and Current sources controlled by a discrete signal
- `sca_eln::sca_tdf::sca_vsource`
  - `sca_eln::sca_tdf_sca_vsource`
- `sca_eln::sca_tdf::sca_isource`
  - `sca_eln::sca_tdf_sca_isource`



- Writing to Discrete Event Models

- Voltage and Current sinks writing into a discrete signal
- `sca_eln::sca_tdf::sca_vsink`
  - `sca_eln::sca_tdf_sca_vsink`
- `sca_eln::sca_tdf::sca_isink`
  - `sca_eln::sca_tdf_sca_isink`



# Interaction with Discrete Event Models

## • Reading from Discrete Event Models

- Voltage and Current sources controlled by a discrete signal
- `sca_eln::sca_tdf::sca_vsource`
  - `sca_eln::sca_tdf_sca_vsource`
- `sca_eln::sca_tdf::sca_isource`
  - `sca_eln::sca_tdf_sca_isource`

## • Writing to Discrete Event Models

- Voltage and Current sinks writing into a discrete signal
- `sca_eln::sca_tdf::sca_vsink`
  - `sca_eln::sca_tdf_sca_vsink`
- `sca_eln::sca_tdf::sca_isink`
  - `sca_eln::sca_tdf_sca_isink`



# Execution Semantics



Analyzing the simulation

## Tracing

# Simulation Control

- Time-domain simulation
  - Classic discrete-event SystemC simulation with AMS modules
    - *sc\_start* function standard
  - Time no longer dependent on events: **natural concept of time**
    - Implicit events: sampling of continuous values
    - Resolution has to be set:  
*sc\_core::sc\_set\_time\_resolution(1.0, sc\_core::SC\_FS)*
      - Femtosecond: extremely high resolution, good for Analog descriptions
- Small-signal frequency-domain simulation
  - Small-signal (AC) simulation
    - *sc\_ac\_analysis::sca\_ac\_start* to start the simulation
  - Frequency-domain noise simulation
    - *sc\_ac\_analysis::sca\_ac\_noise\_start* to start the simulation
  - Requires at least one time-domain simulation first
    - If not explicitly called, it is called by the kernel (transparent to the user)

# Tracing Alternatives

- Tracing to a VCD file
  - Special case of VCD tracing functions
    - `sca_util::sca_create_vcd_file("filename.vcd");`
  - Standard VCD tracing can be used to trace AMS signals
    - Attention: AMS signals translated in DE signals using TDF output ports
    - TDF/DE rules for synchronization are implicitly applied
- Tracing to a tabular file
  - Data represented as a table
    - Every line corresponds to an instant of the simulation
    - Every column to a traced signal
      - Time stamp in the first column
  - Adhoc functions
    - `sca_util::sca_create_tabular_trace_file(filename.dat);`
    - Possibility to specify `std::cout` as file -> output to the out stream to avoid huge files

# Trace File Control

- Methods in the `sca_util::sca_trace_file` class to control the tracing
  - `enable`: start tracing when it is called (after the start)
  - `disable`: stop the tracing when it is called (before the end of simulation)
  - `reopen`: continue tracing in a new trace file
  - `set_mode`: change the mode of the trace when it is called
    - `sca_util::sca_sampling`: set the sampling time
    - `sca_util::sca_multirate`: defines which signals value should be written to the trace if no actual value is available.
      - `sca_util::SCA_INTERPOLATE`
      - `sca_util::SCA_HOLD_SAMPLE`
      - `sca_util::SCA_DONT_INTERPOLATE` to not write the value!
    - `sca_util::sca_ac_format`: format of the signals to write:
      - `sca_util::SCA_AC_REAL_IMAG`: amplitude and phase
      - `sca_util::SCA_MAG_RAD`: magnitude and radiant
      - `sca_util::SCA_AC_DB_DEG`: dB/degrees
    - `sca_noise_format`: how to write the noise contribution
      - `sca_util::SCA_NOISE_ALL`: noise divided in contributions
      - `sca_util::SCA_NOISE_SUM`: noise expressed as sum of all the contributions

# Using GTKWave for Analog Signals

- Open the vcd file and load the analog waves
- Right click on the wave
  - Data format
  - Analog -> Interpolated
  - Insert analog height extension



# Suggested Readings

- Alain Vachoux, Christoph Grimm, and Karsten Einwich, "*SystemC-AMS requirements, design objectives and rationale*" *Proceedings of IEEE/ACM DATE 2003*.
- Alain Vachoux, Christoph Grimm, and Karsten Einwich, "*Analog and mixed signal modelling with SystemC-AMS*" *Proceedings of IEEE ISCAS 2003*
- Grimm, C., Barnasconi, M., Vachoux, A., & Einwich, K., "*An introduction to modeling embedded analog/mixed-signal systems using SystemC AMS extensions*" *Proceedings of IEEE/ACM DAC 2008*
- Franco Fummi, Michele Lora, Francesco Stefanni, Sara Vinco, "*Code generation alternatives to reduce heterogeneous embedded systems to homogeneity*", *Proceedings of IEEE/ECSI FDL 2013*
- François Pêcheux, Christophe Lallement, and Alain Vachoux. "*VHDL-AMS and Verilog-AMS as alternative hardware description languages for efficient modeling of multidiscipline systems.*" *IEEE transactions on Computer-Aided design of integrated Circuits and Systems* 24.2 (2005): 204-225.

# User Guide Examples

- Example made assembling components described in the user guide
  - Using all the computational models
    - ELN, LSF and TDF
  - Purely didactic example



Thanks to Enrico Fraccaroli for providing this example.

# Language Resources

- Accellera website
  - Very reactive support forum
  - Standard Definition
  - Official User Guide
    - Most of the material of this lesson is taken from there!
- The fundamental material is reported in the e-learning site
- Implementation:
  - <http://www.coseda-tech.com/systemc-ams-proof-of-concept> COSEDA technologies website:
    - 2.1-beta-PoC is the suggested implementation to use