Model Transfer Functions by Applying the Laplace Transform in LTspice


Transfer functions are used in the design of electronic systems such as filters, power supplies, and other control systems. Frequency domain analysis of a transfer function involves the Laplace transform. This article explores the implementation of a transfer function in LTspice®, compares the ideal response to a modeled implementation, and provides several useful examples along the way. Files are available to aid in the understanding and implementation of this topic.


Transfer functions are used when we want to analyze how the output of a system changes depending on the input. The system could be the output voltage of a resistor divider or the speed of a car when you step on the gas. To analyze a system, we want to know how its output amplitude and phase compare with the input over frequency. To do this we use the Laplace transform.


There are many resources available that discuss both the mathematics and intuition of the Laplace transform. For our purposes, we can think of it as a mathematical tool that allows us to work with the gain, frequency, phase, and exponential response of a system.

The basic idea of a transfer function diagram is shown in Figure 1.

Figure 1. Transfer function.

Figure 2. Both the resistor divider and RC circuit reduce the amplitude by half with f = 1 kHz. The RC circuit also introduces a delay.

Figure 2 shows two different transfer functions. The resistor divider is simply described as:


But the RC circuit is described by the slightly more complex Equation 2:


Writing the transfer function in this form allows us to talk in terms of poles and zeros. Here we have a single pole at ωp = 1/RC. While the 1 kHz output of the RC circuit (red trace) is the same amplitude as the resistor divider, the phase delay is notable. The Laplace transform allows us to describe how the RC circuit changes both gain and phase over frequency. The example file is Simple_RC_vs_R_Divider.asc.1

Laplace Transform Syntax in LTspice

To implement the Laplace transform in LTspice, first place a voltage dependent voltage source in your schematic. The dialog box for this is shown in Figure 3.

Figure 3. Placing a voltage dependent voltage source.

Right click the voltage source element to open its Component Attribute Editor. In the Value field, enter “Laplace = ” followed by your equation, which should contain the complex variable “s.”

Figure 4. Enter the equation in the Value field.

In Figure 4, {C} and {R} are placed in curly brackets so that we can use the .step spice command to cycle through some values.

The Figure 5 simulation shows the step response of an RC impedance divider, and the equivalent transfer function written using the Laplace transform. Running the simulation,2 we see that the two outputs match.

Figure 5. A simple RC circuit and its equivalent Laplace transform.

As the transfer functions become larger, I have found it useful to use a code editor, which automatically highlights matching parenthesis. Type the equation in the text editor, and then copy it into the LTspice dialog box. See Figure 6.

Figure 6. Taking advantage of a text editor’s syntax highlighting.

A Refresher on Poles and Zeros

An example transfer function is given in Equation 3.


Dissecting Equation 3, we first see the term ωp0/s. This is referred to as an origin pole. An origin pole is synonymous with an integrator and is used to provide extremely high gain at low frequencies, which eliminates steady state error in a control system. Origin poles result in a constant phase delay of 90° and a gain response of –20 dB per decade. The ωp0 term refers to the frequency at which the gain, due to the origin pole, has rolled off to 0 dB.

Finding the roots of the numerator and denominator gives us the zero and pole frequencies, respectively. Note that the pole/zero frequencies are given by the magnitude (that is, absolute value) of these roots. A zero results in a phase boost of 90° and an increase of gain around its frequency. A pole results in a phase delay of 90° and a decrease in gain around its frequency.

If instead the example transfer function were written as:


The leading “s” term is now referred to as a zero at the origin. A zero at the origin is representative of a pure differentiator. It has a constant phase boost of 90° and its gain increases with frequency, reaching 0 dB gain at frequency ωz0.

Figure 7 shows an example with these various poles and zeros implemented separately. Each has a frequency of 1 kHz. The resulting gain and phase of each is shown in Figure 8. The example file is PoleZeroExamples.asc.3

Figure 7. Implementation of poles and zeros.

Figure 8. Frequency and phase response of poles and zeros, all at 1 kHz.

Comparing the Ideal to Modeled Implementation

By using LTspice to model a transfer function, you can take advantage of the vast library of modeled components. As a first example, let’s look at an inverting op amp providing proportional gain. Ideally H(s) = –Rp/Ri. This should result in a simple scaling of the input voltage and a phase shift of 180°. But as illustrated in Figure 9, at about 320 kHz the gain has rolled off from the ideal by 3 dB and the phase has shifted significantly. This follows from the gain bandwidth of the LT6015 being 3.2 MHz, and the circuit in Figure 9 having a gain of —10 V/V.

Figure 9. Proportional gain.

In LTspice, it is possible to enter your own equations into the waveform viewer. If we want to see the gain and phase difference between our ideal equation and the op amp-based circuit, then we add a new waveform. This is done by right clicking on the waveform viewer and selecting Add Traces. The expression can then be added to plot one node divided by the other (that is, V(vout_pro)/V(vout_laplace)). See Figure 10.

Figure 10. Adding a calculated waveform.

The gain and phase comparison are shown in Figure 11, which makes it easy to see that, at low frequencies, we have 0 dB in gain difference and no discrepancy in phase. The example file is ProportionalGain.asc.4

Figure 11. Comparing gain and phase of two waveforms.

Second-Order RLC System

The general form of a second-order system is given by the Simon Bramble article, “Electronic Control Theory of Second-Order Systems: A Practical Analysis for Engineers.”5


When implemented as an LRC, we have


The LTspice implementation is shown in Figure 12. The example allows you to specify R, L, and C, or alternatively you can specify the damping factor ζ and resonant frequency ωn.

Figure 12. A second-order RLC system.

The frequency response of this second-order system is shown in Figure 13. The peaking shown is often undesirable, requiring damping when designing something like an input EMI filter for a buck regulator. The example file is LRC_AC_Analysis.asc.6

Figure 13. RLC frequency response.

Differentiator and the Safety Pole

A differentiator is shown in Figure 14.

Figure 14. Differentiator.

As expected, the origin zero results in a 20 dB/decade increase in gain over frequency. Differentiators are used to increase response to high frequency signals. In practice, pure differentiators are not used and instead are implemented with the addition of a safety pole. A safety pole is placed so that a system is not overly sensitive to high frequency noise. Also, notice the resonant peak shown in the op amp implementation. This peak may prove problematic when attempting to control a system.

The Figure 14 implementation has the zero (where gain crosses 0 dB) at


In our example, a safety pole is implemented at five times this value. Figure 15 shows a differentiator plus safety pole implementation. The pole frequency we desire is at 5 × 159 Hz = 796 Hz. To achieve this, we place a feedback capacitor with 1⁄5 the value of the input capacitor. The full transfer function is given by


where ωz = 1/RpCd and ωp = 1/RpCi . The simulation (see Figure 11) shows us that this safety pole reduces both the gain and phase as the pole frequency is approached. The peaking due to the op amp is also reduced.

First-Order Plus Delay (FOPD)

When modeling the behavior of a system, the FOPD model is a useful tool. For a more complete explanation, read Dr. John D. Hedengren’s “Dynamic Process Modeling” lecture.7 In short, a process can be described by a fixed delay, a full-scale response, and a time constant. To implement a fixed delay, we take advantage of the following Laplace transform:


As a reminder, a time constant is defined by 1 –1/e = 63.2%. The FOPD model comes out as:



kp = full-scale output

𝜏F = time constant

𝛳F = time delay

Figure 16 shows the implementation of a system having a full scale of 100, a time constant of 10 s, and a delay of 1 s. Because the input step is applied at t = 1 s, it follows in Figure 17 that at t = 12 s the output is at 63.2 V. The simulation file is FOPD.asc.8

Figure 16. First-order plus delay model.

Figure 17. First-order plus delay response to an input step.

Compensator Design in LTspice

Control system design is a rich field that spans many disciplines. A key component to a closed-loop control system is the compensator. Once the transfer function of system to be controlled is known, the compensator is designed to address the gain and phase adjustment needed for closed-loop stability and performance.

The PI (Type 2a) Compensator

Many systems can be compensated with a Type 2a compensator, which consists of a pole at the origin (integrator) plus a zero. Negative feedback provides 180° of phase delay, while the pole at the origin results in another fixed 90° of delay. By placing a zero, that additional 90° phase shift is removed at higher frequencies. With this approach we can decide how much phase shift we want at a specific frequency and place the zero accordingly.

Figure 18. Type 2a op amp-based compensator.

An op amp-based Type 2a controller is shown in Figure 18. The Type 2a transfer function is written as


The origin pole frequency is given by ωp = 1/R2Ci and the zero frequency is ωz = 1/R2Ci.

The effect of the op amp here is again apparent with both gain and phase rolling off from the ideal at higher frequencies. The example file is Type2a.asc.9

Type 2 Compensator

The Type 2 compensator consists of an origin pole plus a pole/zero pair and takes the form shown in Figure 19.

Figure 19. Type 2 compensator.

The transfer function is given by:


With pole/zero locations of:


At this point, the designer faces a dilemma. The choice of Rs and Cs affects both the pole and zero. Also, the question of where to place the pole and zero needs to be addressed. The book Designing Control Loops for Linear and Switching Power Supplies derives and gives an example of how to step through the design process. To aid the reader, this method is applied and given in the LTspice example file, Type2_autoCalcs.asc.10 The output of this example is show in Figure 20. The goal of 10 dB attenuation with a 30° phase boost at 10 kHz is achieved. Once again, the nonideal properties of the op amp show up at higher frequencies.

Figure 20. Type 2 phase and frequency response.

Type 3 Compensator

A Type 3 compensator takes the form shown in Figure 21.

Figure 21. Type 3 compensator.

The motivation for this more complex transfer function is that we can get access to a larger phase boost. Negative feedback gives us the initial 180° of delay. But now we have access to two zeros that have the potential of boosting phase by 180°. Two poles are placed to roll off the high frequency gain and phase. The transfer function is given by:


With pole/zero locations of:


As with the Type 2a compensator, the process of choosing pole/zero locations and then calculating the Rs and Cs is involved. The book Designing Control Loops for Linear and Switching Power Supplies derives and gives an example of how to step through the design process. To aid the reader, this method is applied and given in the LTspice example file Type3_autoCalcs.asc..11 The output of this example is show in Figure 22. The goal of 10 dB attenuation with a 145° phase boost at 5 kHz is achieved. Once again, the nonideal properties of the op amp show up at higher frequencies.

Figure 22. Type 3 compensator response.

Origin Pole in the Time Domain

Up to this point we’ve shown how LTspice can implement a transfer function by using circuit elements and the Laplace transform. Examples shown have been in the frequency domain. It may naturally follow to analyze these transfer functions in the time domain (that is, a step response).

To do this, we need to address the issue of the origin pole and how to implement it. A transfer function with an origin pole (that is, pure integrator) is H(s) = 1/s. This transfer function works fine in the frequency domain (Figure 23), but in the time domain we get an error (Figure 24).

Figure 23. AC analysis of an origin pole works.

Figure 24. Transient analysis of an origin pole fails.

To get past this issue, we can instead use the behavioral voltage source and the idt() function. This approach is shown in Figure 25. Figure 25 also gives the beginnings of a feedback system, which compares a setback to a static feedback voltage. The example file is OriginPole_TransientAnalysis_idt.asc.12

Figure 25. Integration that works in the time domain.

Filter Design

The Linear Circuit Design Handbook13 is just part of the vast library of educational materials provided by Analog Devices. Chapter 8 discusses analog filters. The Laplace representation of the filters discussed in this chapter are given as an example file, Laplace_Filters_LinearSystemsBook.asc.14 Please refer to the filter design section of the Precision Toolbox, which aids in the design of active filters.15


Numerous examples have been given of how to implement a transfer function by comparing the lumped element representation to a Laplace transform-based equation. These examples are educational, in the sense of connecting classroom theory to circuit implementation, and they aid in the practical design of various compensators. It is important to note that, for switch-mode power supplies, LTpowerCAD is a powerful (and preferred) resource for compensation design.16 While LTspice may be used to work with and understand some compensators, in the case of power supply design, LTPowerCAD is the right tool for the job.


1 Simple_RC_vs_R_Divider.asc. Analog Devices, Inc.

2 Laplace_Simple_RC.asc. Analog Devices, Inc.

3 PoleZeroExamples.asc. Analog Devices, Inc.

4 ProportionalGain.asc. Analog Devices, Inc.

5 Simon Bramble. “Electronic Control Theory of Second-Order Systems: A Practical Analysis for Engineers.” Analog Dialogue, Vol. 54, No. 3, September 2020.

6 LRC_AC_Analysis.asc. Analog Devices, Inc.

7 John D. Hedengren. “Dynamic Process Modeling.”

8 FOPD.asc. Analog Devices, Inc.

9 Type2a.asc. Analog Devices, Inc.

10 Type2_autoCalcs.asc. Analog Devices, Inc.

11 Type3_autoCalcs.asc. Analog Devices, Inc.

12 OriginPole_TransientAnalysis_idt.asc. Analog Devices, Inc.

13 Linear Circuit Design Handbook. Analog Devices, Inc., 2008.

14 Laplace_Filters_LinearSystemsBook.asc. Analog Devices, Inc.

15 ADI Precision Studio. Analog Devices, Inc.

16 Henry Zhang. “Application Note 149: Modeling and Loop Compensation Design ofSwitching Mode Power Supplies.” Linear Technology, January 2015.

Basso, Christophe. Designing Control Loops for Linear and Switching PowerSupplies. Artech House, October 2012.

Differentiator_SafetyPole.asc. Analog Devices, Inc.

Type3_autoCalcs_steps.asc. Analog Devices, Inc.


Simulations were conducted in LTspice. Thank you to Dr. Shalom D. Ruben, University of Colorado Boulder, for his guidance on this article.


Joseph Spencer

Joseph Spencer

Joseph Spencer has been a field applications engineer with Linear Technology (now part of Analog Devices) since 2013. Joseph supports customers in Utah and Idaho, focusing on high performance analog and RF solutions. Prior to being an FAE, Joseph worked at L3 Communications, where he designed and managed the design of hardware for software-defined radios. Joseph started his career at Maxim Integrated where he worked in both applications and test engineering roles. Joseph holds both a bachelor’s and master’s degree in electrical engineering from the University of Utah.