1. 项目背景与核心问题
电力系统中同步电机与构网型变流器的交互问题已成为新能源并网领域的研究热点。传统同步发电机通过转子惯量自然提供频率支撑,而构网型变流器(Grid-Forming Converter)通过控制算法模拟同步机特性。当两类设备在电网中共存时,其动态特性差异可能导致频率振荡等稳定性问题。
我在参与某风电场并网项目时,曾遇到变流器与同步机并联运行时出现的2-5Hz低频振荡现象。现场实测波形显示,当风电渗透率达到35%时,系统阻尼明显恶化。这促使我深入研究其机理,并通过Simulink搭建仿真模型验证解决方案。
2. 系统建模关键步骤
2.1 同步电机模型构建
采用六阶实用模型(忽略定子暂态):
matlab复制% 同步电机参数设置(标幺值)
Xd = 1.8; Xq = 1.7; Xd' = 0.3; Xq' = 0.4;
Td0' = 8.0; Tq0' = 0.8; H = 3.5; D = 2.0;
转子运动方程是频率响应的核心:
code复制dδ/dt = ω - ω0
2H dω/dt = Pm - Pe - D(ω - ω0)
注意:需合理设置惯量常数H(3-6秒典型值)和阻尼系数D,过小的D会导致仿真中出现持续振荡。
2.2 构网型变流器控制策略
采用虚拟同步机(VSG)控制架构,关键环节包括:
- 有功-频率下垂控制:
matlab复制ω_ref = ω0 - kp*(P - Pset) - 虚拟惯量环节:
matlab复制J dω/dt = Pm - Pe - Dp(ω - ω0) - 电压控制环(Q-V下垂):
matlab复制
V_ref = V0 - kq*(Q - Qset)
实测中发现,当kp取值大于传统同步机的自然调差系数(典型值0.04-0.06)时,容易引发模态耦合。建议初始设置为0.03pu/MW进行试算。
3. 稳定性分析方法
3.1 小信号模型建立
通过线性化处理得到状态空间模型:
matlab复制dx/dt = Ax + Bu
y = Cx + Du
使用MATLAB的linmod函数从Simulink提取矩阵,再通过eig(A)计算特征值。重点关注实部为正的特征根对应模态。
3.2 参与因子分析
计算各状态变量对关键模态的参与程度:
matlab复制[V,D] = eig(A);
participation = abs(V) .* abs(inv(V))';
某次仿真结果显示,同步机转子角δ和VSG的虚拟角θv对0.8Hz模态的参与度均超过0.4,证实了两者动态耦合。
4. 典型问题与解决方案
4.1 低频振荡抑制
现象:渗透率40%时出现1.2Hz持续振荡,阻尼比仅0.03。
解决方案:
-
调整VSG虚拟惯量J:
- 过大(J>6)导致响应迟缓
- 过小(J<2)削弱阻尼
- 最优值通常为同步机H值的50-70%
-
附加阻尼控制器(PSS类似):
matlab复制ΔP = Kd * sTw / (1 + sTw) * Δω参数经验:Kd=5-15, Tw=1-3s
4.2 高比例新能源场景
当同步机容量占比<30%时:
- 需协调多VSG单元的下垂系数
- 建议采用一致性算法动态调整kp:
matlab复制
某项目实测显示,该方法可使频率偏差减少42%。kp_i = kp0 + γΣ(kp_j - kp_i)
5. 完整仿真流程示范
5.1 模型搭建要点
- 使用Simscape Electrical库搭建电网接口
- 同步机选择"Fundamental Synchronous Machine"
- VSG控制用S-Function实现核心算法
5.2 典型测试案例
matlab复制%% 负荷阶跃测试
t_step = 10; % 扰动时刻
ΔP = 0.15; % 负荷突增15%
sim('GFM_vs_SG.slx');
%% 结果分析
figure;
plot(t, ω_sg, t, ω_vsg);
legend('SyncGen','VSG');
xlabel('Time(s)'); ylabel('Freq(pu)');
关键指标:频率最大偏差应<0.5Hz,恢复时间<15s
6. 工程实践建议
-
参数整定顺序:
- 先调下垂系数kp保证稳态精度
- 再调虚拟惯量J改善动态
- 最后加阻尼补偿提高稳定性
-
实测与仿真差异处理:
- 现场遇到未仿真出的10Hz以上振荡时
- 检查PWM开关频率(通常2-5kHz)
- 增加输出滤波器阻尼比
-
代码优化技巧:
- 使用MATLAB Coder生成加速代码
- 对于变步长仿真,设置最大步长≤1/10最小振荡周期
- 并行计算推荐parsim函数
某沿海风电场应用本方法后,频率波动标准差从0.12Hz降至0.05Hz。特别需要注意的是,冬季低温会使得电缆参数变化,需重新校核模型,我们通过在线参数辨识解决了该问题。