例如,數(shù)據(jù)類型 REAL 在程序中以 6 位小數(shù)的精度進行指定和計算。在計算浮點數(shù)(REAL和 LREAL)時,請注意此精度通常應用于每個計算步驟。
在加減浮點數(shù)時,將會調整指數(shù)。因此在加減過程中,基數(shù)和指數(shù)將保持不變,僅增加尾數(shù)。
在以下編程示例中,將對兩個 REAL 數(shù)量類型的操作數(shù)進行相加,然后再減去一個數(shù)。在計算的下一步中,用常量 1 除以前面的結果。為執(zhí)行此操作,創(chuàng)建一個全局數(shù)據(jù)塊,在其中聲明用于進行計算編程的操作數(shù)和函數(shù)。
計算公式;
y = a + b - c
Z = 1/y
創(chuàng)建數(shù)據(jù)塊“DB_GlobalData”:
1. 雙擊“添加新塊”(Add new block) 命令。
這樣會打開“添加新塊”(Add new block) 對話框。
2. 單擊“數(shù)據(jù)塊 (DB)”(Data block (DB)) 按鈕。
3. 指定名稱“DB_GlobalData”。
4. 選擇“Global DB”作為數(shù)據(jù)塊的類型。
5. 單擊“確定”(OK)。
6. 在數(shù)據(jù)塊中創(chuàng)建以下變量,然后輸入相應的起始值:
這兩個變量的起始值都是 100000000.0,并根據(jù)數(shù)據(jù)類型 REAL 轉換為 1.0E+8。
創(chuàng)建一個 SCL 函數(shù)并將其命名為“FC_Calculate”。
1. 按如下方式聲明塊接口:
2. 將以下公式寫入程序代碼并建立在線連接以查看結果:
SCL
#y := "DB_GlobalData".a + "DB_GlobalData".b - "DB_GlobalData".c;
#z := 1/#y;
您可以看到,操作數(shù)的運算結果為 #y = 0,即使實際期望數(shù)字 1 作為結果也是如此。
不正確的結果產(chǎn)生過程如下:
1. 在第一個計算步驟中,將操作數(shù) a 和 b 相加。在指數(shù)調整后,兩個操作數(shù)(a = 1.000000*108和 b = 1.000000*100)的 REAL 值如下所示:
a = 1.000000*108 且 b = 0.00000001*108。 第二個數(shù)字(操作數(shù) b)的最后兩位數(shù)將被截斷,因為 6 位小數(shù)的精度無法再表示這個數(shù)。 因此,該操作數(shù)將會加 0,而不是加 1。
2. 在第二個計算步驟中,將用前面的計算步驟結果減去操作數(shù) C(中間結果 = 1.000000*108 - c = 1.000000*108 為 0.000000e0)。
3. 如果現(xiàn)在計算下一個計算步驟中的操作數(shù) z,則嘗試除以 0。
1. 可能的解決方案
要解決此類問題,可以簡單地調整計算公式。將公式改為如下所示:
計算公式
y = a - c + b
Z = 1/y
由于在第一個計算步驟(操作數(shù) a - c)后將會得到結果 0.000000e0
在第二個計算步驟中加上 REAL 值(中間結果 + b)就會得到正確的結果 (y = 0.000000*100+ 1.000000*100= 1.000000*100)。
2. 可能的解決方案
要計算上述公式,請使用 LREAL 數(shù)據(jù)類型來代替 REAL 數(shù)據(jù)類型。由于此數(shù)據(jù)類型是以 15位小數(shù)的精度進行處理,因此不會產(chǎn)生上述問題。
在全局數(shù)據(jù)塊“DB_GlobalData”中,使用相同的值創(chuàng)建三個全為 LREAL 數(shù)據(jù)類型的新變量。
在 FC“FC_Calculate”的塊接口中,另外聲明兩個 LREAL 數(shù)據(jù)類型的新變量。
在程序代碼中對公式使用新的 LREAL 變量并建立在線連接以查看結果:
SCL
#y_LREAL := "DB_GlobalData".a_LREAL +"DB_GlobalData".b_LREAL - "DB_GlobalData".c_LREAL;
#z_LREAL := 1/#y_LREAL;
責任編輯:lq6
-
浮點數(shù)
+關注
關注
0文章
61瀏覽量
16125 -
Real
+關注
關注
0文章
18瀏覽量
14022 -
SCL
+關注
關注
1文章
243瀏覽量
17549
原文標題:在 SCL 中使用浮點數(shù)(REAL 和 LREAL)進行計算
文章出處:【微信號:gh_a8b121171b08,微信公眾號:機器人及PLC自動化應用】歡迎添加關注!文章轉載請注明出處。
發(fā)布評論請先 登錄
PRINTF函數(shù)無法打印出浮點數(shù)內(nèi)容是為什么?
labview數(shù)據(jù)類型與PLC 數(shù)據(jù)類型之間的轉換(來自于寫入浮點數(shù)到匯川 PLC中的數(shù)據(jù)轉換關鍵的修改)
西門子TIA Portal如何比較兩個浮點數(shù)相等

ADS1282采集到的數(shù)據(jù)傳到PC上應該怎么轉為浮點數(shù)?
TLV320AIC3106音頻芯片怎么發(fā)送、接收浮點數(shù)呢?
labview中浮點數(shù)與十六進制字符串相互轉化
TMS320C6745浮點數(shù)字信號處理器技術簡介

分享在arduino 單片機中浮點數(shù)轉換位數(shù)不夠,精度丟失的解決辦法
請問AURIX TC3xx tricore架構下浮點運算和將浮點數(shù)小數(shù)點去掉變成整數(shù)來計算哪種方式更加節(jié)省算力?
TMS320C6671定點和浮點數(shù)字信號處理器數(shù)據(jù)表

TMS320C6713B浮點數(shù)字信號處理器數(shù)據(jù)表

TMS320C6712D浮點數(shù)字信號處理器數(shù)據(jù)表

TMS320C6711D浮點數(shù)字信號處理器數(shù)據(jù)表

SM320C6727B浮點數(shù)字信號處理器數(shù)據(jù)表

評論