|
|
马上加入,结交更多好友,共享更多资料,让你轻松玩转电力研学社区!
您需要 登录 才可以下载或查看,没有账号?立即加入
×
终于把MPPT调成功了,还是C语言编程能力不足啊,找了几天才找出问题,不过现在也不是很确定是完全正确还是碰巧波形能够跟需要结果相似。在这里呢就还是先介绍一下,然后劳请各位大侠们指正。首先随便搭了一个Boost电路的测试模型,用的是前面介绍过的PSIM9.0自带的光伏板模型,以下就是模型电路图
' N$ D! W5 }2 `& e0 U
MPPT测试模型
& e4 J! i/ v v5 {& ?$ Z( R5 T) U5 S: Y( j# W$ \' g# n
其中MPPT是一个DLL模块,进行MPPT计算并产生PWM波的,最下面一个DLL模块就拿来测试一下效率,是输出功率与最大功率的比。" v( L7 ^8 B& d
对于DLL模块的使用,非常简单,首先打开VC++6.0,然后新建一个Win32 Dynamic-Link Library工程,再新建一个C文件,就可以编程了。编好之后在组建里面选择全部重建,完了之后就可以在你所建的工程文件夹Debug里面找到相应的dll文件了,最后在DLL模块里面选择用该dll文件就可以了。! H' L8 ]9 o2 Z- W. S( M/ D9 \& P) f K
对于编程来讲,首先在c文件里面包含如下语句:
" }8 C4 N; B9 J1 }$ g6 z* p#include <stdio.h>$ s$ P: D( }8 g. Z3 Z
#include <math.h>
* F6 K4 H% L3 {+ n7 ?__declspec(dllexport) void simuser (double t, double delt, double *in, double *out)* x I1 l; g& I! [
{/ I- @4 n4 @6 Q: F; i3 e7 T
}
; L$ i- `$ z' h* P& ^那么在括号内就可以根据自己的需要编写程序了,t是指时间,delt是仿真步长,这两个都在你的仿真电路的时钟控制里面设置,编程不用管。# p9 G) l9 r i2 d) a& U2 l$ \0 z* |
in和out分别对应输入输出,用的时候直接用用数组形式赋值,比如a=in[0],out[0]=b;就行了,DLL模块有小圆圈的一头从上往下依次是in[0],[1],[2]……out[0],[1],[2]……' E+ j, t( Z! @; M0 `' Q6 j, y
那么我编写的MPPT程序如下:
. r3 P. Y. t5 m3 m6 w8 N* l' k
/ h6 O! d5 P4 X% n9 F Vi=in[0];- D; p6 B& S$ [7 {* K$ Q) L
3 T1 y1 J: Y. F' ^9 tIi=in[1];: L, d) _$ Z/ ~* {+ E. J
0 |, E* Y& M* w1 I y
Pi=Vi*Ii;9 p$ n/ T( q" A- i u
/ z3 _+ a1 o5 L% \dv=Vi-Vl; //采样电压电流,获得电压,功率增量
6 X+ @! J9 h- d4 L: o
) X$ j: v- X9 u9 Rdp=Pi-Pl;
" z3 A- S p: ?) Y4 d5 o5 d% s9 [- s( r+ f. F7 c
if (dp==0)' a, F2 k8 v0 T) Y$ m6 c
7 |! p7 c2 r# U- D. b
{
4 a6 i; R% c2 Y' e4 n
2 Y5 @ U g0 {% Verr=0;
/ O" t0 c7 K" `0 u' v0 Q2 O4 Q2 x+ _0 a* G
}+ \# u( G, m. w. l y; \) k( k
4 ~! O8 X0 |: Y' T$ e7 [else
a. V. b# b- T; M: E0 V- v% [8 y \, s% W0 _
{ B- p+ Y& P- e# J
, Y, O: W$ v2 o4 mif (dp>0). g& z! i: K) T# ~# Y+ u. s
- M5 q* _' w U/ O" F: N
{
% N4 L2 U% V0 ]1 S$ L1 P) ~7 R3 C% C2 E5 Z# l- f- I
if (dv>0)
5 x" k G Q- c) D
5 U; b/ d6 z4 N! s! D{err=0.1;}
d3 @( c# Q/ B7 i* O4 P+ W1 L) D j8 s& {" m; o, v0 j6 m
else //MPPT1 x' {# }: H6 F; p) \1 j( M, o' b8 z/ v
5 D/ P* B' j& [( P7 s
{err=-0.1;}6 o1 t t, k$ C$ | X$ h
- u6 S9 M! `" G3 s+ B* n0 ^' F! T1 c, Y, ~
}) S3 ^6 `* L! k: v3 [
9 \5 U- h" `% r4 [( R6 J/ Z6 b6 ?else( |( h/ S$ m; L5 x; [
! {7 b# _5 ?8 K) I/ W/ v
{( H o" L% F; h( z( q
' M, f; k9 y3 t3 F9 t) s; Aif (dv>0)! p+ H* l+ ~' I3 ]
& Q6 U$ N' l& k ~6 ~) ]
{err=-0.1;}% p5 @8 W0 S' j8 p% }4 R) K1 u
* ^( n7 n+ a5 L) q/ C) `else6 W, [0 Y2 }: \7 }; C
, o' x, B, Q2 v9 F% E
{err=0.1;}
0 o- d9 _6 ^+ E% V+ Q
1 ^9 I+ O5 k9 _7 |+ v; y( g}
$ ?& F5 }5 \5 _6 V4 E( _: z& J0 j
- p5 k2 M. C; X0 x+ d) J}: ~6 k$ |& m; J. w; w9 r4 c! f
+ c. B8 N. c! }0 z8 E5 g' n
我用的是最简单的PO法,然后设每次Vref=Vin+0.1或者-0.1,所以上面err就是一次计算完了之后的误差值,送入下面的增量型PI控制
2 Q: o% {8 Q, P5 e7 \' T. n h dVout=20*(err-errf)+err;
0 v$ u$ X/ ] H# n+ j( _
- I- }& |8 g5 G' j: ^' U3 V% vif (fabs(dVout)>4.1)
+ P) @* T0 W/ m3 \- _2 v |& S' r1 H
5 \6 ]( j2 Q" T; Q{% D2 S2 G4 \2 F' p$ G
0 R& z: o0 c$ I% z2 G: p
if ((dVout)>0)
6 f2 \$ {$ Y( f% t8 h( a, p6 _( v
- A: U7 z3 ~6 f3 |# V: g3 l. a{dVout=4.1;}
9 F0 L: _# C4 t3 G. c' n6 q1 P- O$ p7 g, r5 g3 u
else
: r( L$ e w. I; |; N& Z! @6 N
0 C- J$ X' _: Z{dVout=-4.1;}
) } b: D5 F N( j. u# ?% n- @+ Z z0 l7 U) U3 Y% K
}/ U9 J1 Q" i, i, O) I
7 K3 d! i, @& [# G3 f0 |Vtemp=Vout+dVout; //PI
" y2 D& N; N. @' _ P) e# ~0 Z' o4 j2 {& O4 B; H
$ n w9 ~. l8 ^% T$ C
0 R1 v# [% s3 ?% j$ K
if (Vtemp>10) p0 q4 _. B5 U6 {4 a
) K! z& T1 R/ i' O9 H& ]8 p{Vtemp=10;}
6 J- a0 d- V! ^
$ c3 N# c( P6 ielse6 u" S: W; h+ o* a% _
+ o% s# X- H) N- ~1 @
{2 i# ?6 T- y# v( r+ r2 I' \
2 N. A! w8 c7 \' U% S; ^if (Vtemp<0)
. b. A" s# L: ^0 K/ l3 \5 B# u, E: k. R8 e1 L$ T F& a" |! |$ |9 y2 r
{Vtemp=0;}9 i, o% |0 c( J2 j
& g% L+ ^+ g4 ]- z% F. L- j" |/ m
else
! S+ d( I( m& B( b
+ b, K/ F# o# C: R3 d/ ?{Vtemp=Vtemp;}! c- { y4 D/ I" t2 ]
6 _9 ?4 ]# p" ?8 [ G! W. l3 G}
- X2 I0 d, a6 H1 Q9 d' b& Q* ~+ }8 z' N* E8 i
Vout=Vtemp;: o# h8 Q, C$ N R2 C6 x) u# J
# M* }0 H j& F% j1 B0 \. q/ a
errf=err;* n9 E! Y/ x* Q, E) J
p ^& D1 x" Y! Z& ^: ]! t用来得到比较值的变化,最后跟锯齿波比较之后输出占空比。 k9 |3 O% F: m! ~- U
以上程序跑完之后的仿真结果如下所示:4 m F7 [, I7 S# E4 l% @
: q: W; j7 ]+ T6 G. b2 s; g; S, c4 X# f: F$ S Z
感觉还是蛮精确的,效率算下来大概在99.87%,但是我总觉得哪儿有问题,不是太对,上面误差输出的值就只有0.1,-0.1,0三个值
5 c+ i9 ]# n0 k: y4 I5 b不过不知道问题到底原因是什么,仿真效果还蛮好嘛,呵呵9 w5 S S% [* O8 v# ]) v: B! x6 U* Q
大家给我指导一下呗,多谢!~
, p" P$ i, g6 E |
|