# Accelerating Analog Design with SystemC-AMS October 28, 2019 Américo Dias ## Motivation and Problem Statement #### Power requirement for IoT module ## Case study: How to reduce existing SDM power consumption? ## Design Strategy - Create a macromodel based modulator. - 2. Use the ideal model to set a reference point. - Study alternative implementations and use polynomial fitting to capture their behavior. - 4. Implement the curve fitting results in the macromodel simulation to study the degradation on the circuit performance (SNR, SNDR, etc). Predict circuit behaviour before spending time on the practical implementation! (i.e. Feasibility Study) ## Inverter based gm cell Third Order Surface Fit Tao, Sha & Chi, Jiazuo & Rusu, Ana. (2015). Design Considerations for Pipelined Continuous-Time Incremental Sigma-Delta ADCs. 10.1109/ISCAS.2015.7168808. $$I_{out}(v_{in}, v_{out}) = c_0 + c_1 v_{in} + c_2 v_{out} + c_3 v_{in}^3 + c_4 v_{out}^3 + c_5 (v_{in} - v_{out})^2 (v_{in} + v_{out})$$ # Spectre Macromodel Implementation - Basic spectre/spice components like capacitors, vccs, and bsource for modeling the third order fit. - VerilogA for the quantizer and dac, and part of the common mode feedback (not shown). ## SystemC-AMS Model Implementation - ELN (Electrical Linear Networks): Has most of the passive components and sources like spice, however doesn't have become and TDF to implement the third order fit. - TDF (Timed Data Flow): The TDF model of computation shall define the procedural behavior that processes samples, which are tagged in time. - Quantizer and DAC can be implemented in standard SystemC. ## GM Cell implementation in Spectre ## GM Cell implementation in SystemC-AMS ## GM Cell implementation in SystemC-AMS ## GM Cell implementation in SystemC-AMS ## Quantizer in VerilogA and SystemC-AMS #### VerilogA ``` @ (cross(V(vclk) - vtrans clk, 1)) begin vdiff = gain*(V(vinp)-V(vinn)); if(vdiff <= level[0]) begin</pre> vo = -2; end else if (vdiff > level[0] && vdiff <= level[1]) begin</pre> vo = 1; end else if (vdiff > level[1] && vdiff <= level[2]) begin</pre> vo = -0: end else if (vdiff > level[2] && vdiff <= level[3]) begin</pre> vo = 1; end else if (vdiff > level[3]) begin vo = 2; end end // assign the outputs V(vout) <+ transition( vo, tdel, trise, tfall );</pre> ``` #### SystemC-AMS ``` /** * Processing thread */ void sc_sdm_quantizer::sig_proc(void) { double vdiff = input_gain * (sc_in_vinp.read() - sc_in_vinn.read()); sc_out_sync.write(!sc_out_sync.read()); if (vdiff <= threshold[0]) sc_out_vout.write(-2); else if (vdiff > threshold[0] && vdiff <= threshold[1]) sc_out_vout.write(-1); else if (vdiff > threshold[1] && vdiff <= threshold[2]) sc_out_vout.write(0); else if (vdiff > threshold[2] && vdiff <= threshold[3]) sc_out_vout.write(1); else if (vdiff > threshold[3]) sc_out_vout.write(2); } ``` ## Design flow - **Specte** (or other spice simulator) is always required to measure the transistor distortion for specific operating point. This is done only once. - **Python** can be used to automatically run the rest of the flow, configuring and launching the SystemC-AMS executable. - **Python** can replace **Matlab** using the right libraries like numpy. - Python + SystemC-AMS solution is virtually free and run in all major operating systems. - Each **SystemC-AMS** simulation takes less than 1 second. **Spectre** model requires more than 2 minutes. ## Maximum SNR with ideal model ## Maximum SNR with ideal model (zoom) ## SNR with polynomial fit ## SNR with polynomial fit (zoom) # Dynamic range ## Conclusion #### Pros: - SystemC-AMS is a good tool for early phase studies. - Much faster than spice (120x in this example!) - By developing his own simulator, the designer gains a better understanding of the circuit. - The simulation can be customized and tuned for the designer needs. - The simulator runs on local machine (independently of the OS). - It is free and can be easily controlled by Python (or other script languages). #### Cons: - It's more difficult and time consuming to develop a systemc-ams model than spice (learning curve). - The designer need to ensure its correctness and accuracy (compare with spice for peace of mind). ### Other resources - IEEE 1666.1-2016 Standard: <a href="https://standards.ieee.org/findstds/standard/1666.1-2016.html">https://standards.ieee.org/findstds/standard/1666.1-2016.html</a> - Wikipedia Page: <a href="https://en.wikipedia.org/wiki/SystemC">https://en.wikipedia.org/wiki/SystemC</a> AMS - How to compile SystemC/SystemC-AMS libraries: - Windows: <a href="https://goo.gl/NjQBtD">https://goo.gl/NjQBtD</a> - Linux: https://goo.gl/rC9ZLv - Mac: https://goo.gl/69nfz8 - PLL design example (personal project): <a href="https://goo.gl/ZaFExo">https://goo.gl/ZaFExo</a> Thank you