设为首页收藏本站|繁體中文 快速切换版块

 找回密码
 立即加入
搜索
查看: 19289|回复: 90

由一个实例说明PSCAD与C语言接口方法

   火... [复制链接]
  • TA的每日心情
    无聊
    2020-11-4 11:03
  • 签到天数: 3 天

    连续签到: 1 天

    [LV.2]偶尔看看I

    累计签到:3 天
    连续签到:1 天
    发表于 2011-6-1 20:19:02 | 显示全部楼层 |阅读模式

    马上加入,结交更多好友,共享更多资料,让你轻松玩转电力研学社区!

    您需要 登录 才可以下载或查看,没有账号?立即加入

    ×
    本帖最后由 yuanzhch 于 2011-6-1 20:23 编辑 ! C' h/ U2 N- l! ]1 s  N9 S
    0 }! J8 C3 Q* `# U
    pscad中要实现新的算法,首先要建立一个自定义元件。自定义元件分为两种,一种是电气元件,一种是信号处理元件。本帖实现的内容是一个非线性电感,其电感值随着电流大小而变化,属于电气元件。写控制算法的同学可能主要用到后者,将输入信号经过一系列的处理计算得到一个输出信号。   
    3 q. M8 c+ C; o7 ^- F4 |- Q8 _7 L问题1:将程序写在哪里?) A: O: Q8 O$ n* ^$ L
        首先要将算法程序分成两个部分:$ J: X" \) G+ M' E9 B
        一部分是PSCAD可以实现的,如处理仿真参数、读入仿真数据、输出仿真结果以及积分、微分等简单函数。这部分内容写在自定义元件definition的Script中。可以写在Fortran中也可以写在DSDYN中,两者略有不同但不会影响简单应用,具体内容请参阅帮助文件。( m; z- \/ E* C4 w, }  p
        另一部分是我们自己的C语言算法,要将C算法总结成y=f(x,p)的输入输出形式的形式写在一个*.c文件中。并添加到PSCAD的File Reference中。 C函数的命名形式一定是 void XX_XXX__()的形式,注意名字中的下划线,本人的试验结果是必须有这三个下划线,哪位同学有其他发现可以一起探讨一下。  w2 W9 e, w) p1 g9 ?3 i1 V
    问题2:如何传数据?
    & d0 h4 p$ e) E3 _+ m/ A* w1 v, `    由于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程序中的变量,后面参数前面加“$”是引用参数的意思,具体内容请参阅帮助文件。
    , m$ q! e; R! j6 w* S* O4 ?问题3:如何保存前一时刻的变量并在本时刻调用?
      A$ u- ^9 Y5 \* T+ d' n4 g$ n$ m    在时域仿真的时候我们不可避免的要用到上一时刻的某些计算结果。而PSCAD中的Fortran程序和C程序每一时刻都重新执行一次,变量都要清零,所以就要单独存放需要的数据。PSCAD提供了一个STORF数组,这里直接给出例子:+ p& A0 `4 }6 t; ]! B
    #STORAGE REAL:4
    $ `) P2 u" _7 E% s  ~: w      MY_NSTORF=NSTORF
    9 E" Q7 {3 e( o      NSTORF=NSTORF+4
    ' D: o8 ~- J' y$ Q% f! Q/ |; h# W- x* H     BT=STORF(MY_NSTORF)& \8 E; t3 f2 k1 B) }4 e. P3 p
          HT=STORF(MY_NSTORF+1)
    $ i3 n3 s  I$ F2 G+ u2 {      MT=STORF(MY_NSTORF+2)  K" @6 a! M# O, U8 c& X* K
          H=STORF(MY_NSTORF+3)*$N/$L9 t& h' O" [% @
    这是读上一时刻值。
    * N1 r  _& H$ V2 P; e6 v9 I      STORF(MY_NSTORF)=B
    1 e2 [+ B2 p, v/ h      STORF(MY_NSTORF+2)=M
    ( ?9 q- Z2 g5 P0 @3 q5 v$ u( Q  u/ @这是保存存本时刻值。
    " u: X$ E2 ^& G, N0 }4 t解决了上面3个问题就可以完成信号处理元件的建模。) ]- z. P' z5 g" K) d- ]
    问题4:如何建立电气元件?
    1 v; ~4 ?7 g2 W! m9 T% ?/ c    我们对一个电气元件建模就是要描述其伏安特性。如一个双端口元件,测它两个结点电压,然后计算出支路电流就可以了。PSCAD提供了一个基于结点的电气接口函数,说白了就是一个受控电流源叫GGIN和CCIN。帮助里可以搜到,下面给出例子:7 c! o5 |1 |+ Q8 i, |+ Y: S. P+ r' H
          CCIN($NA,$SS)=CCIN($NA,$SS)-STORF(MY_NSTORF+3)/1000.0
    7 D% {3 k3 D  n5 ~1 y      CCIN($NB,$SS)=CCIN($NB,$SS)+STORF(MY_NSTORF+3)/1000.0
    + [: p$ O  ?& ^7 C8 G+ y1 e' _      GGIN($NA,$SS)=GGIN($NA,$SS)+G$ V- [2 E7 C5 w6 Q# p" u2 {6 q' U2 U
          GGIN($NB,$SS)=GGIN($NB,$SS)+G
    1 Z* @: S( a& d我觉得解决以上4个问题就能满足一般应用了。这里只是给大家提供一个思路,还有一些细节没有说到还需要看帮助文件,希望能帮到大家!附件中是个非线性电感,J-A模型是个微分方程在C函数中用龙格库塔法解之。
      A! @! {9 v4 f, V+ q! }/ x 基于JA理论的非线性电感.rar (1.03 KB, 下载次数: 238)

    评分

    参与人数 4威望 +11 学分 +12 收起 理由
    pursue2000 + 5 + 5 很给力!
    hyxzl123 + 1 好贴!
    XIAOJIUWEI + 2 对我很有帮助!
    mingyu + 5 + 5 很有用!

    查看全部评分

    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    楼主热帖
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】
  • TA的每日心情
    奋斗
    2019-5-24 09:31
  • 签到天数: 5 天

    连续签到: 1 天

    [LV.2]偶尔看看I

    累计签到:5 天
    连续签到:1 天
    发表于 2019-5-5 16:32:36 | 显示全部楼层
    刚刚接触这一块,一脸懵逼状态,专家分不够,云里雾里的,这个pscad的help里面好像没有特别多的介绍,楼主用的是哪个版本的呀,是不是我看帮助的方式不对,呜呜呜
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】
    回复 推荐 踩下

    使用道具 举报

  • TA的每日心情
    奋斗
    2019-5-24 09:31
  • 签到天数: 5 天

    连续签到: 1 天

    [LV.2]偶尔看看I

    累计签到:5 天
    连续签到:1 天
    发表于 2019-5-7 09:28:10 | 显示全部楼层
    这个里面的三种引脚类型:数据输入、数据输出以及电气引脚有什么区别呀
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】
    回复 推荐 踩下

    使用道具 举报

  • TA的每日心情
    慵懒
    2018-11-12 16:24
  • 签到天数: 36 天

    连续签到: 2 天

    [LV.5]常住居民I

    累计签到:36 天
    连续签到:2 天
    发表于 2018-1-15 16:07:13 | 显示全部楼层
    求大神发一下我的邮箱,专家分不够啊1762771794@qq.com
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】
    回复 推荐 踩下

    使用道具 举报

  • TA的每日心情
    愤怒
    2020-12-8 11:59
  • 签到天数: 105 天

    连续签到: 1 天

    [LV.6]常住居民II

    累计签到:220 天
    连续签到:1 天
    发表于 2011-6-1 20:28:05 | 显示全部楼层
    虽然不太懂fortran,但是觉得你的思路很好!
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】
  • TA的每日心情
    无聊
    2020-11-4 11:03
  • 签到天数: 3 天

    连续签到: 1 天

    [LV.2]偶尔看看I

    累计签到:3 天
    连续签到:1 天
     楼主| 发表于 2011-6-1 20:28:43 | 显示全部楼层
    回复 2# mingyu # q8 W5 c7 g7 z; Y% ~3 i# N

    : k$ W/ _9 s0 g% l1 {( H! m$ x+ [5 h4 a* x
        怎么转成普通贴?; Z: m+ ^' p) p& d
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】
  • TA的每日心情
    愤怒
    2020-12-8 11:59
  • 签到天数: 105 天

    连续签到: 1 天

    [LV.6]常住居民II

    累计签到:220 天
    连续签到:1 天
    发表于 2011-6-1 21:29:23 | 显示全部楼层
    回复 3# yuanzhch
    2 e/ P8 y- p! h# F
    ; M+ T+ t! M9 c$ n4 V( m9 S
    4 r  V" j& H' E4 `% W! [3 ~    自己可以结贴,返还部分学分。
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】
  • TA的每日心情
    开心
    2020-10-7 17:12
  • 签到天数: 9 天

    连续签到: 1 天

    [LV.3]偶尔看看II

    累计签到:9 天
    连续签到:1 天
    发表于 2011-6-1 21:40:02 | 显示全部楼层
    楼主强人啊,谢谢分享!!!
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】
  • TA的每日心情
    开心
    2017-8-30 23:34
  • 签到天数: 3 天

    连续签到: 1 天

    [LV.2]偶尔看看I

    累计签到:3 天
    连续签到:1 天
    发表于 2011-6-2 01:41:43 | 显示全部楼层
    我也在做PSCAD和C的接口,发现一些细节:% {4 s( F5 ?1 c3 A
    1.fortran 接口子函数的文件名必须是xxx_df90.f ,C程序文件名必须是xxx_msc.c。当大家编译通过但连接出现问题的时候,可以试试修改调用的这两个文件的文件名。) u# k; ^) z9 V$ _6 Z  A/ n
    2.PSCAD3.0以前的版本连接外部文件采用的是File reference;4.0以后的版本发生了一些变化,在以前的基础上,在project setting的fortran标签页里,也要添加接口子程序(.f)文件的文件路径。, c  Y2 D6 P. w6 j$ k' Q
    3.楼主提到了PSCAD存放数据的数组,其实有4个,数组指针名分别是STORF(实数量) STORI(整数量) STORL(逻辑量) STORC(复数量),对应类型的量应该存到对应的数组里。
    - ]  i# B# Q! p& c4 V% G/ B% J1 H) I( W8 t+ w6 X: x* f
    楼主说的C函数命名时要加下划线的奇怪规则我也发现了。但想不明白原因。' }: J8 s0 O: n0 c8 _

    : w% W# y9 n7 k  ^! \2 ^0 J以上是做毕设过程中总结的一些小经验,不一定正确,但如果你想我一样2天无法连接文件实现接口的时候,不妨来这里看看。用这里的方法试试
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】

    该用户从未签到

    尚未签到

    发表于 2011-6-2 11:13:50 | 显示全部楼层
    回复 1# yuanzhch & T# o& x3 G. n9 t

    3 @( W* Z6 `+ [7 {& J: M1 c2 ^1 O* S+ i, _) o- w- K
       我也尝试过调用C,但是遇到了问题,PSCAD每一步长CALL一下C程序。想给C的变量赋一个初值,由于循环调用,每CALL一下,变量又都成初值了,请问楼主怎么解决啊?
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】
  • TA的每日心情
    无聊
    2020-11-4 11:03
  • 签到天数: 3 天

    连续签到: 1 天

    [LV.2]偶尔看看I

    累计签到:3 天
    连续签到:1 天
     楼主| 发表于 2011-6-2 12:41:22 | 显示全部楼层
    回复 7# caunow 6 S6 _5 m2 Q9 S, \

    ' Q- g% l% K6 y: |/ t2 M  L# m6 \
    2 F( }" z) V* K2 Z    这就是我说的问题4,用STORF,STORC等数组。
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】
  • TA的每日心情
    慵懒
    2018-10-31 22:06
  • 签到天数: 12 天

    连续签到: 1 天

    [LV.3]偶尔看看II

    累计签到:12 天
    连续签到:1 天
    发表于 2011-6-2 13:35:25 | 显示全部楼层
    楼主,思路很好很强大
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】

    该用户从未签到

    尚未签到

    发表于 2011-6-2 20:12:35 | 显示全部楼层
    楼主强人啊,谢谢分享!!!
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】
    您需要登录后才可以回帖 登录 | 立即加入

    本版积分规则

    招聘斑竹

    小黑屋|手机版|APP下载(beta)|Archiver|电力研学网 ( 赣ICP备12000811号-1|赣公网安备36040302000210号 )|网站地图

    GMT+8, 2024-4-24 02:49

    Powered by Discuz! X3.5 Licensed

    © 2001-2024 Discuz! Team.

    快速回复 返回顶部 返回列表