TA的每日心情 | 无聊 2020-11-4 11:03 |
|---|
签到天数: 3 天 连续签到: 1 天 [LV.2]偶尔看看I 累计签到:3 天 连续签到:1 天
|
马上加入,结交更多好友,共享更多资料,让你轻松玩转电力研学社区!
您需要 登录 才可以下载或查看,没有账号?立即加入
×
本帖最后由 yuanzhch 于 2011-6-1 20:23 编辑
# A, f9 a0 R* d; F' v) y; _% u
3 e% K- E6 o( t% P" Q0 l在pscad中要实现新的算法,首先要建立一个自定义元件。自定义元件分为两种,一种是电气元件,一种是信号处理元件。本帖实现的内容是一个非线性电感,其电感值随着电流大小而变化,属于电气元件。写控制算法的同学可能主要用到后者,将输入信号经过一系列的处理计算得到一个输出信号。 9 \, _0 l& L, a% @4 O J s( K
问题1:将程序写在哪里?
) O% T( y! V' h9 ]! n" J# F 首先要将算法程序分成两个部分:
1 x; [+ K2 b" ` G7 j 一部分是PSCAD可以实现的,如处理仿真参数、读入仿真数据、输出仿真结果以及积分、微分等简单函数。这部分内容写在自定义元件definition的Script中。可以写在Fortran中也可以写在DSDYN中,两者略有不同但不会影响简单应用,具体内容请参阅帮助文件。
* w5 k, \7 Y. c- ~! f 另一部分是我们自己的C语言算法,要将C算法总结成y=f(x,p)的输入输出形式的形式写在一个*.c文件中。并添加到PSCAD的File Reference中。 C函数的命名形式一定是 void XX_XXX__()的形式,注意名字中的下划线,本人的试验结果是必须有这三个下划线,哪位同学有其他发现可以一起探讨一下。8 J7 K5 F; M5 A6 R( |5 w3 U
问题2:如何传数据?
6 u6 X+ Z. @. O, T0 E0 D 由于PSCAD和C函数是互相传递指针,因此就需要将C函数写成f(y,x,p)的形式,例如:void ja_model__(real *h,real *ht,real *mt,real *ms,real *a,real *alpha,real *c,real *k,real *b,real *m)。其中h是输出,ht,mt是输入,后面的都是参数。在PSCAD中用call语句调用,例如:CALL JA_MODEL(H,HT,MT,$MS,$A,$ALPHA,$C,$K,B,M) 。注意函数名中的下划线,这里只有一个!其中H,HT,MT都是Fortran程序中的变量,后面参数前面加“$”是引用参数的意思,具体内容请参阅帮助文件。2 j) W% e7 m+ G% L# e: W
问题3:如何保存前一时刻的变量并在本时刻调用?% X8 w+ ?8 p. i+ n2 t( v% G! D
在时域仿真的时候我们不可避免的要用到上一时刻的某些计算结果。而PSCAD中的Fortran程序和C程序每一时刻都重新执行一次,变量都要清零,所以就要单独存放需要的数据。PSCAD提供了一个STORF数组,这里直接给出例子: b# A2 X3 v2 [7 d& M' {4 I
#STORAGE REAL:4% M; y. V0 f" Z9 O
MY_NSTORF=NSTORF
, ?' N( k. ^6 i& x0 J" | NSTORF=NSTORF+4
9 L% U! F9 [% R. A7 f* U- e) v8 H BT=STORF(MY_NSTORF)
! ^0 g, i: z8 w) C5 [+ n HT=STORF(MY_NSTORF+1)
' V: K8 ~6 \0 F$ }$ X MT=STORF(MY_NSTORF+2)( @, h( I/ h* U# S- k- b* X
H=STORF(MY_NSTORF+3)*$N/$L
0 V4 v# A0 Z/ o2 W这是读上一时刻值。, Q. O, X4 J3 T% X0 \
STORF(MY_NSTORF)=B: q- [7 O" X% l# h& L. ^
STORF(MY_NSTORF+2)=M
0 r }% t) a, y+ d. v) j这是保存存本时刻值。; X* h/ Q" u9 {
解决了上面3个问题就可以完成信号处理元件的建模。
: x* Z6 c3 ~9 I8 o问题4:如何建立电气元件?
* O$ ~5 b. R. j5 Q' I6 J+ p' O 我们对一个电气元件建模就是要描述其伏安特性。如一个双端口元件,测它两个结点电压,然后计算出支路电流就可以了。PSCAD提供了一个基于结点的电气接口函数,说白了就是一个受控电流源叫GGIN和CCIN。帮助里可以搜到,下面给出例子:
3 J$ Q( n3 ]# E, D2 b CCIN($NA,$SS)=CCIN($NA,$SS)-STORF(MY_NSTORF+3)/1000.0& [9 o1 Q U9 `) g0 u
CCIN($NB,$SS)=CCIN($NB,$SS)+STORF(MY_NSTORF+3)/1000.0
/ x* i8 h& L8 e. k x& \' L% d) H GGIN($NA,$SS)=GGIN($NA,$SS)+G
( |4 H. H$ X4 i( F1 g GGIN($NB,$SS)=GGIN($NB,$SS)+G
' j9 m( h7 s5 |# J' T$ {; q' a我觉得解决以上4个问题就能满足一般应用了。这里只是给大家提供一个思路,还有一些细节没有说到还需要看帮助文件,希望能帮到大家!附件中是个非线性电感,J-A模型是个微分方程在C函数中用龙格库塔法解之。" @- g! _) U2 q4 G' B: q% H
基于JA理论的非线性电感.rar
(1.03 KB, 下载次数: 241)
|
评分
-
查看全部评分
|