h30631
級別: 略有小成
![]() |
請問各位大師們,為什麼用GX 模擬PLC 去跑程式時,DADDP 指令時,數(shù)字會亂跳,如圖片 但是實(shí)際上監(jiān)控實(shí)體PLC 就不會有這個問題,請問是哪裡出錯了?? ![]() [ 此帖被h30631在2013-01-03 17:03重新編輯 ] |
---|---|
|
sjm213
有小知識,無大學(xué)問。
級別: 論壇版主
![]() ![]() ![]() ![]() |
1,根本原因在于你用了DADDP,這是個32位的指令。實(shí)際計算過程是把[D351 D350]與[T1 T0]相加后放入了[D351 D350]; 2,仿真與實(shí)機(jī)的區(qū)別在于,仿真默認(rèn)掃描周期是100ms的,而實(shí)機(jī)的掃描周期會原低于這個數(shù)。這就造成仿真在T0計時到后,其輸出觸點(diǎn)驅(qū)動了T1計時,T1的數(shù)值馬上變成了1,所以掃描到達(dá)T0的上升沿,執(zhí)行加法處理時,就是00000000+00010014--》00010014(都用16進(jìn)制表示)的計算過程,這個十六進(jìn)制的數(shù)換成十進(jìn)制就是65556;執(zhí)行到第八遍的時候,這個數(shù)就是65556*8=524448。而因?qū)崣C(jī)的掃描周期遠(yuǎn)低于100ms,則在實(shí)機(jī)上執(zhí)行該程序,T0計時到達(dá),掃描到T1時,該數(shù)值還沒有累積到0.1S,所以T1的數(shù)值還是0沒有變成1,繼續(xù)執(zhí)行加法處理時,就是00000000+00000014--》00000014的計算過程,這個十六進(jìn)制的數(shù)換成10進(jìn)制就是20,得到了想要的結(jié)果; 3,將DADDP指令換成16位的ADDP指令可以避免這種情況; 4,將T0上升沿后做加法運(yùn)算這一句緊放在T0輸出線圈這一句后面可以避免這種情況;T0輸出線圈這一句放在RST T0這段后面更好。 |
---|---|
|
sjm213
有小知識,無大學(xué)問。
級別: 論壇版主
![]() ![]() ![]() ![]() |
今天在實(shí)機(jī)上調(diào)試了這個程序,現(xiàn)象與樓主所講一樣。 再仔細(xì)想了一下,在三樓講的第二條有問題。 PLC中無論掃描周期如何修改,執(zhí)行的結(jié)果都是樓主期望的那樣,T1對ADD之后的D350不會產(chǎn)生影響,因?yàn)門0狀態(tài)ON的這個掃描周期,T1才剛開始計時,PLC工作的原理是下一次掃描到T1輸出觸點(diǎn)時才會更新當(dāng)前值,所以T1現(xiàn)在的值是0,不會影響到T0和D350值的相加。 仿真中,無論掃描周期如何修改,T1在T0為ON開始計時的這個周期都是已經(jīng)有了一個數(shù)值“1”,這就對D350的數(shù)值產(chǎn)生了附圖中顯示的影響。 說明仿真和PLC實(shí)機(jī)運(yùn)行是不一樣的。 |
---|---|
|
sjm213
有小知識,無大學(xué)問。
級別: 論壇版主
![]() ![]() ![]() ![]() |
但是32位指令執(zhí)行時是 D1 D0 + T1 T0這是確確實(shí)實(shí)的。 |
---|---|
|