chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

在SCL中在計算浮點數REAL和LREAL

機器人及PLC自動化應用 ? 來源:機器人及PLC自動化應用 ? 作者:微笑應對 ? 2022-09-14 16:23 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

例如,數據類型 REAL 在程序中以 6 位小數的精度進行指定和計算。在計算浮點數(REAL和 LREAL)時,請注意此精度通常應用于每個計算步驟。

在加減浮點數時,將會調整指數。因此在加減過程中,基數和指數將保持不變,僅增加尾數。

在以下編程示例中,將對兩個 REAL 數量類型的操作數進行相加,然后再減去一個數。在計算的下一步中,用常量 1 除以前面的結果。為執(zhí)行此操作,創(chuàng)建一個全局數據塊,在其中聲明用于進行計算編程的操作數和函數。

計算公式;

y = a + b - c

Z = 1/y

創(chuàng)建數據塊“DB_GlobalData”:

1. 雙擊“添加新塊”(Add new block) 命令。

這樣會打開“添加新塊”(Add new block) 對話框。

2. 單擊“數據塊 (DB)”(Data block (DB)) 按鈕。

3. 指定名稱“DB_GlobalData”。

4. 選擇“Global DB”作為數據塊的類型。

5. 單擊“確定”(OK)。

6. 在數據塊中創(chuàng)建以下變量,然后輸入相應的起始值:

70a426ae-304c-11ed-ba43-dac502259ad0.png

這兩個變量的起始值都是 100000000.0,并根據數據類型 REAL 轉換為 1.0E+8。

創(chuàng)建一個 SCL 函數并將其命名為“FC_Calculate”。

1. 按如下方式聲明塊接口

70d07236-304c-11ed-ba43-dac502259ad0.png

2. 將以下公式寫入程序代碼并建立在線連接以查看結果:

SCL

#y := "DB_GlobalData".a + "DB_GlobalData".b - "DB_GlobalData".c;

#z := 1/#y;

70f295aa-304c-11ed-ba43-dac502259ad0.png

您可以看到,操作數的運算結果為 #y = 0,即使實際期望數字 1 作為結果也是如此。

不正確的結果產生過程如下:

1. 在第一個計算步驟中,將操作數 a 和 b 相加。在指數調整后,兩個操作數(a = 1.000000*108和 b = 1.000000*100)的 REAL 值如下所示:

a = 1.000000*108 且 b = 0.00000001*108。第二個數字(操作數 b)的最后兩位數將被截斷,因為 6 位小數的精度無法再表示這個數。因此,該操作數將會加 0,而不是加 1。

2. 在第二個計算步驟中,將用前面的計算步驟結果減去操作數 C(中間結果 = 1.000000*108 - c = 1.000000*108 為 0.000000e0)。

3. 如果現(xiàn)在計算下一個計算步驟中的操作數 z,則嘗試除以 0。

710ad4ee-304c-11ed-ba43-dac502259ad0.png

1. 可能的解決方案

要解決此類問題,可以簡單地調整計算公式。將公式改為如下所示:

計算公式

y = a - c + b

Z = 1/y

由于在第一個計算步驟(操作數 a - c)后將會得到結果 0.000000e0

,在第二個計算步驟中加上 REAL 值(中間結果 + b)就會得到正確的結果 (y = 0.000000*100+ 1.000000*100= 1.000000*100)。

7126566a-304c-11ed-ba43-dac502259ad0.png

2. 可能的解決方案

要計算上述公式,請使用 LREAL 數據類型來代替 REAL 數據類型。由于此數據類型是以 15位小數的精度進行處理,因此不會產生上述問題。

在全局數據塊“DB_GlobalData”中,使用相同的值創(chuàng)建三個全為 LREAL 數據類型的新變量。

7141024e-304c-11ed-ba43-dac502259ad0.png

在 FC“FC_Calculate”的塊接口中,另外聲明兩個 LREAL 數據類型的新變量。

71653394-304c-11ed-ba43-dac502259ad0.png

在程序代碼中對公式使用新的 LREAL 變量并建立在線連接以查看結果:

SCL

#y_LREAL := "DB_GlobalData".a_LREAL +"DB_GlobalData".b_LREAL - "DB_GlobalData".c_LREAL;

#z_LREAL := 1/#y_LREAL;

718789d0-304c-11ed-ba43-dac502259ad0.png




審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • SCL
    SCL
    +關注

    關注

    1

    文章

    244

    瀏覽量

    17936

原文標題:在 SCL 中使用浮點數(REAL 和 LREAL)進行計算

文章出處:【微信號:gh_a8b121171b08,微信公眾號:機器人及PLC自動化應用】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    如何使用 ARM FPU 加速浮點計算?

    一、浮點數的存儲浮點數按照 IEEE 754 標準存儲計算機中,ARM浮點環(huán)境是遵循 「IEEE 754-1985」 標準實現(xiàn)的。 IEE
    發(fā)表于 11-19 06:51

    使用VScode的PIO開發(fā)GD32VF103,但是串口無法打印浮點數怎么解決?

    我最近在使用VScode的PIO開發(fā)GD32V,使用的是longan的模板,但是我將串口輸出重定義到printf函數,發(fā)現(xiàn)無法使用%f輸出浮點數,想問問應該怎么配置,我看到的一種說法是
    發(fā)表于 11-06 06:49

    點數表示實數的方法以及定點數硬件上的運算驗證

    ,整數與浮點數做運算時,還需要將整數轉化為浮點數才能運算。此外,FPGA,并不能直接支持浮點數運算,需要自己設計相應的
    發(fā)表于 10-28 08:13

    E203添加浮點數方法:譯碼和派遣模塊設計

    存在浮點數時應該怎么判斷輸出數據的選擇(選擇整數還是浮點數),因此筆者從 dispatch 模塊開始講起。文件 "e203_exu_disp.v" 的代碼,出現(xiàn)
    發(fā)表于 10-24 13:54

    E203添加浮點數方法:FPU控制邏輯

    指令的全部運算都集中了 FPU 當中。對于指令周期的設計,筆者將除了除法、開方和浮點數存取指令以外的指令都設計為單周期指令(實際為2周期,原因在于 OITF 的原理),這也是為什么原 E203 代碼
    發(fā)表于 10-24 13:28

    蜂鳥E203擴展浮點指令設計(1)

    : ?c.flw 與32位的指令類似 ?c.fsw 與32位的指令類似 ?c.flwsp是一條 RV32FC 僅有指令,它將一個單精度浮點數值從存儲器讀入浮點寄存器 rd 。其有效地址的
    發(fā)表于 10-24 10:00

    浮點數是如何實現(xiàn)開平方運算的

    。 下圖展示了浮點數的平方根計算的基本方案。這里的架構十分通俗易懂。VRSH1塊是控制右移塊。平方根塊能夠計算小數的平方根。指數計算路徑
    發(fā)表于 10-24 08:42

    Vivado浮點數IP核的握手信號

    Vivado浮點數IP核的握手信號 我們的設計方案,F(xiàn)PU計算單元將收到的三條數據和使能信號同步發(fā)給20多個模塊,同時只有一個模塊被時鐘使能,進行計算,但結果都會保留,發(fā)給數選。
    發(fā)表于 10-24 07:01

    浮點數指令添加——長指令寫回仲裁

    浮點數指令添加——長指令寫回仲裁 增加浮點數指令時,我們會遇到一些需要寫回寄存器的指令,此時就需要對原先的寫回功能模塊做更改。 寫回功能主要集中在這兩個模塊
    發(fā)表于 10-24 06:07

    risc-v浮點運算單元的使用及其設計考慮

    的應用。 RISC-V,浮點運算單元分為單精度浮點數(32位)和雙精度浮點數(64位),通常包括以下幾種基本功能: 加法器/減法器:用于
    發(fā)表于 10-21 14:46

    大彩講堂:VisualHMI-LUA教程-獲取設置單精度浮點數函數的應用

    軟件開發(fā)各種協(xié)議對浮點數數據進行獲取和賦值處理。get_float(vtype,addr)讀取單精度浮點數(float)寄存器,返回有符號單精度浮點數·vtype:數
    的頭像 發(fā)表于 10-16 00:00 ?1248次閱讀
    大彩講堂:VisualHMI-LUA教程-獲取設置單精度<b class='flag-5'>浮點數</b>函數的應用

    PRINTF函數無法打印出浮點數內容是為什么?

    1、MCXN947低功耗adc,歷程中使用官方提供的PRINTF無法打印出浮點數內容。 2、同樣mcuxpresso ide 也不可以打印浮點數,這是為什么呢? 3、使用的歷程是lpadc歷程。
    發(fā)表于 03-20 08:06

    labview數據類型與PLC 數據類型之間的轉換(來自于寫入浮點數到匯川 PLC的數據轉換關鍵的修改)

    浮點數默認數據類型是64為雙精度浮點數,PLCreal浮點數數據類型,是單精度浮點數32位。
    發(fā)表于 02-24 19:01

    西門子TIA Portal如何比較兩個浮點數相等

    概述: 由于浮點數的定義規(guī)則,導致浮點數不能通過二進制精確表示,所以浮點數計算過程中,會出現(xiàn)兩個值一樣的
    的頭像 發(fā)表于 01-06 10:07 ?1184次閱讀
    西門子TIA Portal如何比較兩個<b class='flag-5'>浮點數</b>相等

    ADS1282采集到的數據傳到PC上應該怎么轉為浮點數?

    我最近在用ADS1282,采集到的數據傳到PC上應該怎么轉為浮點數?比如說通過串口調試助手收到一個采樣點的數據為 FF FF 9D 17,它的真實浮點數是多少呢?我知道ADC是以補碼形式存的,是要將數據倒轉為17 9D FF FF,再與上0xFF,再float()嗎?還
    發(fā)表于 12-13 06:23