两极式三相光伏逆变并网仿真 ★前级为Boost变换器,采用mppt算法(扰动观察法)。 逆变器为三相两电平LCL型并网逆变器,采用SVPWM调制算法。 控制环路: ★除了直流电压环外,电流控制环采用双环PI调节,外环为并网电流环,内环采用电容电流反馈,也起到了有源阻尼的作用。 送一个简要的设计报告。
最近在搞一个光伏并网逆变器的仿真项目,前级用Boost加MPPT,后级走三相LCL逆变。这玩意儿调起来是真带劲,特别是双环PI和SVPWM配合的时候,几个关键点必须得说清楚。
先说Boost这头,扰动观察法核心就二十行代码的事。咱们直接在Simulink里搭了个逻辑判断模块:
function delta_V = mppt_perturb_obs(V, I, prev_P) persistent step_size last_dir; if isempty(last_dir) step_size = 0.5; % 电压扰动步长 last_dir = 1; end current_P = V * I; delta_P = current_P - prev_P; if delta_P > 0 delta_V = last_dir * step_size; else delta_V = (-last_dir) * step_size; last_dir = -last_dir; end end这里有个坑要注意——采样间隔得大于电网周期,我之前设了10ms结果功率曲线抖得像心电图。实际调试发现20ms采样时扰动方向判断最稳,避免了在最大功率点附近反复横跳。
后级逆变器的双环控制才是重头戏。外环并网电流环的输出直接作为内环的参考,这里PI参数整定特别关键。在调试时发现,先调内环能让系统更快收敛:
// 内环电容电流PI计算(DSP代码片段) float cap_current_control(float I_ref, float I_actual) { static float integral = 0; float Kp = 0.8, Ki = 120; float error = I_ref - I_actual; integral += Ki * error * Ts; // Ts为控制周期 return Kp * error + integral; }内环这个Ki值调起来很玄学,刚开始设80时响应太肉,调到200直接振荡上天。后来发现跟LCL滤波器的谐振频率有关,用扫频法测出谐振点后,把Ki压在谐振频率的1/5以下才稳定。
SVPWM生成部分有个实用技巧——用查表法代替实时计算。提前把60度分段的矢量作用时间存成数组:
sector_table = [ (0,1,2), (2,0,1), (1,2,0), (1,0,2), (2,1,0), (0,2,1) ] def svpwm_calc(alpha, beta): sector = determine_sector(alpha, beta) # 扇区判断函数 t1, t2 = calculate_duty(sector, alpha, beta) # 占空比计算 return sector_table[sector], t1, t2实测这种方法比实时计算节省30%的运算时间,特别在低端DSP上跑波形明显更干净。记得在换相点加0.5us的死区,有次没加死区直接炸了IGBT模型。
调完所有环节后,电网电流THD居然卡在4.8%下不去。最后发现是LCL滤波器的电容ESR设成了理想值,加上实际的0.1Ω等效电阻后THD直接降到2.3%。这告诉我们仿真时器件参数不能太理想,得留点余量。
整个系统跑起来后,动态响应测试结果挺有意思:光照突变时直流母线电压超调控制在8%以内,恢复到稳态只用0.2秒。这得归功于电压外环和电流内环的解耦设计,两个环的带宽差了差不多一个数量级。
最后丢几个关键参数供参考:
- Boost电感:2mH(按20kHz开关频率设计)
- LCL滤波:2mH+50uF+1mH
- 直流母线电容:2200uF
- 并网电流环带宽:200Hz
- SVPWM频率:10kHz
调这种系统就像玩跷跷板,动了PI参数就得注意调制环节,改了滤波参数又得回头调控制。建议新手一定要用实时波形录制功能,抓住波形突变的那个瞬间,往往就是问题所在。