Engee 文档
Notebook

差分配对放大器

本例将演示差分配对放大器的仿真。

模型图:

differential_pair_amplifier--1742910732573.png

定义加载和运行模型的函数:

In [ ]:
function start_model_engee()
    try
        engee.close("differential_pair_amplifier", force=true) # 关闭模型
        catch err # 如果没有模型关闭和engee。close()不执行,它将在catch之后加载。
            m = engee.load("$(@__DIR__)/differential_pair_amplifier.engee") # 加载模型
        end;

    try
        engee.run(m, verbose=true) # 启动模型
        catch err # 如果模型没有加载和engee。run()不执行,catch后最下面的两行将被执行。
            m = engee.load("$(@__DIR__)/differential_pair_amplifier.engee") # 加载模型
            engee.run(m, verbose=true) # 启动模型
        end
end
Out[0]:
start_model_engee (generic function with 1 method)

运行模拟

In [ ]:
start_model_engee();
Building...
Progress 0%
Progress 8%
Progress 39%
Progress 93%
Progress 100%
Progress 100%

将仿真数据写入变量:

In [ ]:
t = simout["differential_pair_amplifier/Signal Generator.1"].time[:]
vb1 = simout["differential_pair_amplifier/Signal Generator.1"].value[:]
vb2 = simout["differential_pair_amplifier/Mode Differential.y"].value[:]
vc1 = simout["differential_pair_amplifier/Vd/Voltage Sensor p.1"].value[:]
vc2 = simout["differential_pair_amplifier/Vd/Voltage Sensor n.1"].value[:]
vc2_minus_vc1 = simout["differential_pair_amplifier/Vd/Voltage Sensor d.1"].value[:]
vb2_minus_vb1 = vb2 .- vb1;

数据可视化

In [ ]:
using Plots

Npn1和NPN2晶体管集电极上电压的可视化:

In [ ]:
plot(t, vb1, linewidth=2, label="vb1")
plot!(t, vb2, linewidth=2, label="vb2")
plot!(t, vb2_minus_vb1, linewidth=2, label="vb2-vb1", title="输入电压")
Out[0]:
In [ ]:
plot(t, vc1, linewidth=2, label="vc1")
plot!(t, vc2, linewidth=2, label="vc2")
plot!(t, vc2_minus_vc1, linewidth=2, label="vc2-vc1", title="输出电压")
Out[0]:

结论:

在这个例子中,我们考虑了差分配对放大器的模型。 这些图表显示了放大器的输出和输入特性,它们相差40倍以上。