Plecs { Name "forward_peak_current_mode_transconductance_amplifier" Version "3.7" CircuitModel "ContStateSpace" StartTime "0.0" StopTime "simuation_total_time" Solver "radau" MaxStep "1e-3" InitStep "-1" FixedStep "1e-3" Refine "1" ZCStepSize "1e-9" RelTol "1e-3" AbsTol "-1" TurnOnThreshold "0" SyncFixedStepTasks "2" UseSingleCommonBaseRate "1" LossVariableLimitExceededMsg "3" NegativeSwitchLossMsg "3" DivisionByZeroMsg "2" StiffnessDetectionMsg "2" MaxConsecutiveZCs "1000" AssertionAction "1" InitializationCommands "fid = fopen(\"myfile.txt\");\n\nfor i = 1:100\n\tfli" "ne = fgetl(fid);\n\t\n\tif(fline == -1)\n\t\tbreak;\n\tend\n\n\tdisp(fline);" "\n\teval(fline);\n\t\t\n\t\nend\n\nfclose(fid)" InitialState "1" SystemState "" CodeGenTopologies "[]" CodeGenSwitchingAlgorithm "1" CodeGenMatrixCodingStyle "1" CodeGenParameterInlining "2" CodeGenInliningExceptions "AAAACwAAAAAA" CodeGenIntegerWordSize "32" CodeGenAbsTimeUsageMsg "3" CodeGenBaseName "" CodeGenOutputDir "" CodeGenExtraOpts "" ExtendedMatrixPrecision "1" MatrixSignificanceCheck "2" Schematic { Location [0, 34; 3840, 2049] ZoomFactor 1.87249 SliderPosition [0, 0] ShowBrowser off BrowserWidth 100 Component { Type From Name "From9" Show off Position [765, 675] Direction up Flipped off Parameter { Variable "Tag" Value "Ifb" Show off } Parameter { Variable "Visibility" Value "1" Show off } } Component { Type Reference SrcComponent "Components/Control/Logical/SR Flip-flop" Name "SR Flip-flop1" Show on Position [935, 540] Direction up Flipped off Frame [-20, -20; 20, 20] LabelPosition [0, 23] LabelAlign up Parameter { Variable "x_init" Value "0" Show off } Terminal { Type Input Position [-20, 10] Direction left } Terminal { Type Input Position [-20, -10] Direction left } Terminal { Type Output Position [24, -10] Direction right } Terminal { Type Output Position [24, 10] Direction right } } Component { Type PulseGenerator Name "Pulse\nGenerator1" Show on Position [840, 480] Direction right Flipped off Parameter { Variable "Hi" Value "1" Show off } Parameter { Variable "Lo" Value "0" Show off } Parameter { Variable "f" Value "fsw" Show off } Parameter { Variable "DutyCycle" Value "0.01" Show off } Parameter { Variable "Delay" Value "0" Show off } } Component { Type Comparator Name "Comparator1" Show on Position [835, 550] Direction right Flipped off } Component { Type Sum Name "Sum2" Show off Position [765, 625] Direction left Flipped off Parameter { Variable "IconShape" Value "2" Show off } Parameter { Variable "Inputs" Value "|++" Show off } } Component { Type TriangleGenerator Name "Artifical Ramp1" Show on Position [815, 625] Direction left Flipped off Parameter { Variable "Min" Value "0" Show off } Parameter { Variable "Max" Value "Va" Show off } Parameter { Variable "f" Value "fsw" Show off } Parameter { Variable "DutyCycle" Value "0.99" Show off } Parameter { Variable "Delay" Value "0" Show off } } Component { Type Resistor Name "Rupper" Show on Position [50, 495] Direction up Flipped off Parameter { Variable "R" Value "Rupper" Show off } } Component { Type Resistor Name "Rbottom" Show on Position [50, 585] Direction up Flipped off Parameter { Variable "R" Value "Rbottom" Show off } } Component { Type Ground Name "Ground3" Show off Position [50, 640] Direction up Flipped off } Component { Type Voltmeter Name "Viref" Show on Position [520, 555] Direction up Flipped off } Component { Type Saturation Name "Saturation" Show on Position [580, 555] Direction right Flipped off Parameter { Variable "UpperLimit" Value "Vref_IC" Show on } Parameter { Variable "LowerLimit" Value "0" Show on } } Component { Type Saturation Name "Saturation1" Show on Position [690, 555] Direction right Flipped off Parameter { Variable "UpperLimit" Value "VM_i*0.99" Show on } Parameter { Variable "LowerLimit" Value "VM_i*0.01" Show on } } Component { Type Goto Name "Goto7" Show off Position [995, 530] Direction right Flipped off Parameter { Variable "Tag" Value "PWM" Show off } Parameter { Variable "Visibility" Value "1" Show off } } Component { Type Resistor Name "Rz1" Show on Position [380, 580] Direction up Flipped off Parameter { Variable "R" Value "Rz_trans_cond" Show off } } Component { Type Capacitor Name "Cz1" Show on Position [380, 530] Direction up Flipped on Parameter { Variable "C" Value "Cz_trans_cond" Show off } Parameter { Variable "v_init" Value "0" Show off } } Component { Type Capacitor Name "Cp1" Show on Position [435, 560] Direction up Flipped on Parameter { Variable "C" Value "Cp_trans_cond" Show off } Parameter { Variable "v_init" Value "0" Show off } } Component { Type CurrentSource Name "I" Show on Position [325, 555] Direction down Flipped on Parameter { Variable "DiscretizationBehavior" Value "2" Show off } Parameter { Variable "StateSpaceInlining" Value "1" Show off } } Component { Type Ground Name "Ground7" Show off Position [405, 660] Direction up Flipped off } Component { Type Gain Name "gm" Show on Position [280, 555] Direction right Flipped off Parameter { Variable "K" Value "gm" Show off } Parameter { Variable "Multiplication" Value "1" Show off } } Component { Type Sum Name "Sum3" Show off Position [230, 555] Direction up Flipped off Parameter { Variable "IconShape" Value "1" Show off } Parameter { Variable "Inputs" Value "+-" Show off } } Component { Type Constant Name "Voltage \nController\nReference" Show on Position [160, 480] Direction right Flipped off Frame [-10, -10; 10, 10] LabelPosition [0, 13] LabelAlign up Parameter { Variable "Value" Value "Vc_v" Show off } } Component { Type Voltmeter Name "Vfb" Show on Position [120, 560] Direction up Flipped off } Component { Type Label Name "Label4" Show off Position [50, 430] Direction up Flipped off Parameter { Variable "Tag" Value "Vout" Show off } Parameter { Variable "Visibility" Value "1" Show off } } Component { Type DCVoltageSource Name "V_dc" Show off Position [210, 135] Direction down Flipped on Parameter { Variable "V" Value "Vinput" Show on } } Component { Type Inductor Name "L1" Show off Position [580, 105] Direction left Flipped off Parameter { Variable "L" Value "Lout" Show on } Parameter { Variable "i_init" Value "0" Show off } } Component { Type Resistor Name "R" Show off Position [815, 200] Direction down Flipped off Parameter { Variable "R" Value "Rload50" Show on } } Component { Type Capacitor Name "C1" Show off Position [735, 235] Direction down Flipped on Parameter { Variable "C" Value "Cout" Show on } Parameter { Variable "v_init" Value "Vout" Show on } } Component { Type PlecsProbe Name "Probe\nIL-Vo" Show on Position [70, 120] Direction right Flipped off } Component { Type SignalDemux Name "Demux1" Show off Position [115, 120] Direction right Flipped on Parameter { Variable "Width" Value "2" Show off } } Component { Type Voltmeter Name "Vout" Show on Position [925, 200] Direction up Flipped off } Component { Type Goto Name "Goto" Show off Position [970, 200] Direction right Flipped off Parameter { Variable "Tag" Value "Vo" Show off } Parameter { Variable "Visibility" Value "1" Show off } } Component { Type Resistor Name "R1" Show off Position [870, 320] Direction down Flipped off Parameter { Variable "R" Value "Rload50" Show on } } Component { Type Switch Name "S1" Show on Position [870, 365] Direction down Flipped off Parameter { Variable "s_init" Value "0" Show off } } Component { Type PulseGenerator Name "50% to 100%" Show on Position [815, 365] Direction right Flipped off Parameter { Variable "Hi" Value "1" Show off } Parameter { Variable "Lo" Value "0" Show off } Parameter { Variable "f" Value "fdisturbance" Show off } Parameter { Variable "DutyCycle" Value "0.5" Show off } Parameter { Variable "Delay" Value "0" Show off } } Component { Type Ground Name "Ground" Show off Position [870, 425] Direction up Flipped off } Component { Type Transformer Name "Tr2" Show on Position [455, 145] Direction right Flipped on Parameter { Variable "Windings" Value "[1 1]" Show off } Parameter { Variable "n" Value "[primary_turns_number secondary_turns_number]" Show off } Parameter { Variable "Polarity" Value "+" Show off } Parameter { Variable "Lm" Value "inf" Show off } Parameter { Variable "im0" Value "0" Show off } } Component { Type Mosfet Name "T2" Show off Position [370, 205] Direction down Flipped on Parameter { Variable "Ron" Value "0" Show off } Parameter { Variable "s_init" Value "0" Show off } Parameter { Variable "thermal" Value "" Show off } Parameter { Variable "T_init" Value "0" Show off } } Component { Type From Name "From10" Show off Position [415, 205] Direction left Flipped off Parameter { Variable "Tag" Value "PWM" Show off } Parameter { Variable "Visibility" Value "1" Show off } } Component { Type Mosfet Name "T3" Show off Position [370, 80] Direction down Flipped on Parameter { Variable "Ron" Value "0" Show off } Parameter { Variable "s_init" Value "0" Show off } Parameter { Variable "thermal" Value "" Show off } Parameter { Variable "T_init" Value "0" Show off } } Component { Type From Name "From12" Show off Position [415, 80] Direction left Flipped off Parameter { Variable "Tag" Value "PWM" Show off } Parameter { Variable "Visibility" Value "1" Show off } } Component { Type Diode Name "D1" Show on Position [330, 90] Direction down Flipped off Parameter { Variable "Vf" Value "0" Show off } Parameter { Variable "Ron" Value "0" Show off } Parameter { Variable "thermal" Value "" Show off } Parameter { Variable "T_init" Value "0" Show off } } Component { Type Diode Name "D2" Show on Position [290, 190] Direction down Flipped off Parameter { Variable "Vf" Value "0" Show off } Parameter { Variable "Ron" Value "0" Show off } Parameter { Variable "thermal" Value "" Show off } Parameter { Variable "T_init" Value "0" Show off } } Component { Type Ground Name "Ground1" Show off Position [465, 310] Direction up Flipped off } Component { Type Diode Name "D3" Show on Position [500, 105] Direction left Flipped off Parameter { Variable "Vf" Value "0" Show off } Parameter { Variable "Ron" Value "0" Show off } Parameter { Variable "thermal" Value "" Show off } Parameter { Variable "T_init" Value "0" Show off } } Component { Type Diode Name "D4" Show on Position [530, 200] Direction down Flipped off Parameter { Variable "Vf" Value "0" Show off } Parameter { Variable "Ron" Value "0" Show off } Parameter { Variable "thermal" Value "" Show off } Parameter { Variable "T_init" Value "0" Show off } } Component { Type Label Name "Label3" Show off Position [870, 85] Direction up Flipped off Parameter { Variable "Tag" Value "Vout" Show off } Parameter { Variable "Visibility" Value "1" Show off } } Component { Type Resistor Name "R2" Show off Position [735, 180] Direction down Flipped off Parameter { Variable "R" Value "Cout_ESR" Show on } } Component { Type Resistor Name "R3" Show off Position [655, 105] Direction left Flipped off Parameter { Variable "R" Value "Lout_ESR" Show on } } Component { Type Scope Name "Scope" Show on Position [155, 120] Direction up Flipped off Location [0, 0; 0, 0] State "" SavedViews "" HeaderState "" PlotPalettes "" Axes "2" TimeRange "0" ScrollingMode "1" SingleTimeAxis "1" Open "0" Ts "-1" SampleLimit "0" XAxisLabel "" Axis { Name "IL" AutoScale 1 MinValue 0 MaxValue 1 Signals {} SignalTypes [ ] Untangle 0 KeepBaseline off BaselineValue 0 } Axis { Name "Vout" AutoScale 1 MinValue 0 MaxValue 1 Signals {} SignalTypes [ ] Untangle 0 KeepBaseline off BaselineValue 0 } Fourier { SingleXAxis on AxisLabel "Frequency" Scaling 0 PhaseDisplay 0 Axis { Name "" AutoScale 1 MinValue 0 MaxValue 1 Signals {} Untangle 0 KeepBaseline off BaselineValue 0 } Axis { Name "" AutoScale 1 MinValue 0 MaxValue 1 Signals {} Untangle 0 KeepBaseline off BaselineValue 0 } } } Component { Type Resistor Name "R4" Show off Position [255, 245] Direction left Flipped off Parameter { Variable "R" Value "Rsense" Show on } } Component { Type Voltmeter Name "Vm1" Show on Position [255, 285] Direction right Flipped off } Component { Type Goto Name "Goto1" Show off Position [255, 320] Direction down Flipped off Parameter { Variable "Tag" Value "Ifb" Show off } Parameter { Variable "Visibility" Value "1" Show off } } Connection { Type Signal SrcComponent "Pulse\nGenerator1" SrcTerminal 1 Points [900, 480] DstComponent "SR Flip-flop1" DstTerminal 2 } Connection { Type Signal SrcComponent "Artifical Ramp1" SrcTerminal 1 DstComponent "Sum2" DstTerminal 3 } Connection { Type Signal SrcComponent "Comparator1" SrcTerminal 3 DstComponent "SR Flip-flop1" DstTerminal 1 } Connection { Type Signal SrcComponent "Sum2" SrcTerminal 1 Points [765, 545] DstComponent "Comparator1" DstTerminal 1 } Connection { Type Signal SrcComponent "Viref" SrcTerminal 3 DstComponent "Saturation" DstTerminal 1 } Connection { Type Signal SrcComponent "Saturation1" SrcTerminal 2 DstComponent "Comparator1" DstTerminal 2 } Connection { Type Signal SrcComponent "SR Flip-flop1" SrcTerminal 3 DstComponent "Goto7" DstTerminal 1 } Connection { Type Wire SrcComponent "Rz1" SrcTerminal 1 DstComponent "Cz1" DstTerminal 1 } Connection { Type Wire SrcComponent "Rz1" SrcTerminal 2 Points [380, 630] Branch { Points [405, 630] Branch { Points [435, 630] Branch { DstComponent "Cp1" DstTerminal 1 } Branch { Points [520, 630] DstComponent "Viref" DstTerminal 2 } } Branch { DstComponent "Ground7" DstTerminal 1 } } Branch { Points [325, 630] DstComponent "I" DstTerminal 1 } } Connection { Type Signal SrcComponent "gm" SrcTerminal 2 DstComponent "I" DstTerminal 3 } Connection { Type Signal SrcComponent "Sum3" SrcTerminal 1 DstComponent "gm" DstTerminal 1 } Connection { Type Signal SrcComponent "Voltage \nController\nReference" SrcTerminal 1 Points [190, 480; 190, 550] DstComponent "Sum3" DstTerminal 2 } Connection { Type Wire SrcComponent "Cz1" SrcTerminal 2 Points [380, 480] Branch { Points [435, 480] Branch { DstComponent "Cp1" DstTerminal 2 } Branch { Points [520, 480] DstComponent "Viref" DstTerminal 1 } } Branch { Points [325, 480] DstComponent "I" DstTerminal 2 } } Connection { Type Signal SrcComponent "Vfb" SrcTerminal 3 DstComponent "Sum3" DstTerminal 3 } Connection { Type Wire SrcComponent "Label4" SrcTerminal 1 DstComponent "Rupper" DstTerminal 1 } Connection { Type Wire SrcComponent "Rupper" SrcTerminal 2 Points [50, 530] Branch { DstComponent "Rbottom" DstTerminal 1 } Branch { Points [120, 530] DstComponent "Vfb" DstTerminal 1 } } Connection { Type Wire SrcComponent "Rbottom" SrcTerminal 2 Points [50, 615] Branch { DstComponent "Ground3" DstTerminal 1 } Branch { Points [120, 615] DstComponent "Vfb" DstTerminal 2 } } Connection { Type Signal SrcComponent "Saturation" SrcTerminal 2 DstComponent "Saturation1" DstTerminal 1 } Connection { Type Wire SrcComponent "R" SrcTerminal 2 Points [815, 105] Branch { Points [735, 105] Branch { DstComponent "R2" DstTerminal 2 } Branch { DstComponent "R3" DstTerminal 2 } } Branch { Points [870, 105] Branch { Points [925, 105] DstComponent "Vout" DstTerminal 1 } Branch { DstComponent "R1" DstTerminal 2 } Branch { DstComponent "Label3" DstTerminal 1 } } } Connection { Type Signal SrcComponent "Probe\nIL-Vo" SrcTerminal 1 DstComponent "Demux1" DstTerminal 1 } Connection { Type Signal SrcComponent "Vout" SrcTerminal 3 DstComponent "Goto" DstTerminal 1 } Connection { Type Wire SrcComponent "R" SrcTerminal 1 Points [815, 285] Branch { Points [735, 285] Branch { DstComponent "C1" DstTerminal 2 } Branch { Points [530, 285] Branch { Points [465, 285] Branch { DstComponent "Tr2" DstTerminal 4 } Branch { DstComponent "Ground1" DstTerminal 1 } } Branch { DstComponent "D4" DstTerminal 1 } } } Branch { Points [925, 285] DstComponent "Vout" DstTerminal 2 } } Connection { Type Wire SrcComponent "S1" SrcTerminal 2 DstComponent "R1" DstTerminal 1 } Connection { Type Signal SrcComponent "50% to 100%" SrcTerminal 1 DstComponent "S1" DstTerminal 3 } Connection { Type Wire SrcComponent "S1" SrcTerminal 1 DstComponent "Ground" DstTerminal 1 } Connection { Type Signal SrcComponent "From10" SrcTerminal 1 DstComponent "T2" DstTerminal 3 } Connection { Type Signal SrcComponent "From12" SrcTerminal 1 DstComponent "T3" DstTerminal 3 } Connection { Type Wire SrcComponent "T2" SrcTerminal 2 Points [370, 245; 290, 245] Branch { DstComponent "R4" DstTerminal 2 } Branch { DstComponent "D2" DstTerminal 1 } Branch { Points [290, 285] DstComponent "Vm1" DstTerminal 1 } } Connection { Type Wire SrcComponent "Tr2" SrcTerminal 1 Points [370, 125] Branch { DstComponent "T3" DstTerminal 2 } Branch { Points [290, 125] DstComponent "D2" DstTerminal 2 } } Connection { Type Wire SrcComponent "Tr2" SrcTerminal 2 Points [370, 155] Branch { DstComponent "T2" DstTerminal 1 } Branch { Points [330, 155] DstComponent "D1" DstTerminal 1 } } Connection { Type Wire SrcComponent "T3" SrcTerminal 1 Points [370, 35; 330, 35] Branch { Points [210, 35] DstComponent "V_dc" DstTerminal 1 } Branch { DstComponent "D1" DstTerminal 2 } } Connection { Type Wire SrcComponent "Tr2" SrcTerminal 3 Points [465, 105] DstComponent "D3" DstTerminal 1 } Connection { Type Wire SrcComponent "D3" SrcTerminal 2 Points [530, 105] Branch { DstComponent "L1" DstTerminal 1 } Branch { DstComponent "D4" DstTerminal 2 } } Connection { Type Wire SrcComponent "C1" SrcTerminal 1 DstComponent "R2" DstTerminal 1 } Connection { Type Wire SrcComponent "R3" SrcTerminal 1 DstComponent "L1" DstTerminal 2 } Connection { Type Signal SrcComponent "Demux1" SrcTerminal 2 DstComponent "Scope" DstTerminal 1 } Connection { Type Signal SrcComponent "Demux1" SrcTerminal 3 DstComponent "Scope" DstTerminal 2 } Connection { Type Wire SrcComponent "V_dc" SrcTerminal 2 Points [210, 245] Branch { DstComponent "R4" DstTerminal 1 } Branch { Points [210, 285] DstComponent "Vm1" DstTerminal 2 } } Connection { Type Signal SrcComponent "Vm1" SrcTerminal 3 DstComponent "Goto1" DstTerminal 1 } Connection { Type Signal SrcComponent "From9" SrcTerminal 1 DstComponent "Sum2" DstTerminal 2 } } ProbeBlock { Tag "forward_peak_current_mode_transconductance_amplifier/Probe" "\\nIL-Vo" Probe { Component "L1" Path "" Signals {"Inductor current"} } Probe { Component "C1" Path "" Signals {"Capacitor voltage"} } } } DemoSignature "Bap6DS4NTtxJPw9fC3z2AbJLrfwBdiffL87wB+C5SIw="