色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

請問怎樣在SCL中去使用浮點數進行計算?

機器人及PLC自動化應用 ? 來源:機器人及PLC自動化應用 ? 作者:微笑應對 ? 2021-07-04 11:32 ? 次閱讀

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

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

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

計算公式;

y = a + b - c

Z = 1/y

創建數據塊“DB_GlobalData”:

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

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

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

3. 指定名稱“DB_GlobalData”。

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

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

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

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

創建一個 SCL 函數并將其命名為“FC_Calculate”。

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

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

SCL

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

#z := 1/#y;

您可以看到,操作數的運算結果為 #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. 如果現在計算下一個計算步驟中的操作數 z,則嘗試除以 0。

1. 可能的解決方案

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

計算公式

y = a - c + b

Z = 1/y

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

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

2. 可能的解決方案

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

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

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

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

SCL

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

#z_LREAL := 1/#y_LREAL;

責任編輯:lq6

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

    關注

    0

    文章

    60

    瀏覽量

    15872
  • Real
    +關注

    關注

    0

    文章

    17

    瀏覽量

    13855
  • SCL
    SCL
    +關注

    關注

    1

    文章

    239

    瀏覽量

    17099

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

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

收藏 人收藏

    評論

    相關推薦

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

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

    TLV320AIC3106音頻芯片怎么發送、接收浮點數呢?

    TLV320AIC3106 音頻芯片怎么發送、接收浮點數呢?是把浮點數轉成整數嗎?如果是該怎么轉呢? 經AD采樣后得到的是整數,又該怎么轉換成原始的浮點數呢?
    發表于 11-05 07:13

    labview中浮點數與十六進制字符串相互轉化

    與下位機數據交流及通訊時,經常有浮點數與十六進制字符串相互轉化的需求,經過兩天總結,找到了最簡潔的相互轉化的方法,萌新歡迎大佬指正,文件也附上。*附件:HEX字符串與浮點數轉換.rar
    發表于 10-21 19:51

    TMS320C6745浮點數字信號處理器技術簡介

    電子發燒友網站提供《TMS320C6745浮點數字信號處理器技術簡介.pdf》資料免費下載
    發表于 10-09 09:34 ?0次下載
    TMS320C6745<b class='flag-5'>浮點數</b>字信號處理器技術簡介

    分享arduino 單片機中浮點數轉換位數不夠,精度丟失的解決辦法

    arduino中由于硬件限制,浮點數只有2位小數。但經過這個函數處理可以達到7位
    的頭像 發表于 08-27 14:34 ?748次閱讀

    請問AURIX TC3xx tricore架構下浮點運算和將浮點數小數點去掉變成整數來計算哪種方式更加節省算力?

    ? tricore架構下CPU有專門的FPU來處理浮點數運算,是否意味著用12.89參與運算,調用FPU來計算的情況下,計算時間不會比12890參與
    發表于 08-26 06:54

    TMS320C6671定點和浮點數字信號處理器數據表

    電子發燒友網站提供《TMS320C6671定點和浮點數字信號處理器數據表.pdf》資料免費下載
    發表于 08-05 11:17 ?0次下載
    TMS320C6671定點和<b class='flag-5'>浮點數</b>字信號處理器數據表

    TMS320C6711D浮點數字信號處理器數據表

    電子發燒友網站提供《TMS320C6711D浮點數字信號處理器數據表.pdf》資料免費下載
    發表于 08-03 09:29 ?0次下載
    TMS320C6711D<b class='flag-5'>浮點數</b>字信號處理器數據表

    官方例程modbus slave rtu,浮點數精度不對是怎么回事?

    官方例程 modbus slave rtu, 浮點數精度不對,對保持寄存器設置一個浮點數,讀取到的浮點數結果精度只能到小數點后兩位,根本無法使用,用的是idf 5.1.2版本,開發環境是vscode。
    發表于 07-19 08:10

    請問如何打印浮點數或雙精度變量?

    如何打印浮點數或雙精度變量?
    發表于 07-12 08:24

    ESP8266_RTOS_SDK如何打印浮點數

    嘗試使用 printf 打印浮點數,例如, 浮點數 d = 1.0; printf("d = %f", d); 但它打印出來: d = 此外,sprintf
    發表于 07-09 06:56

    如何關閉ESP32-S3中的FPU浮點數計算單元?

    如何關閉ESP32-S3中的FPU浮點數計算單元。如題,之前的項目esp32s2 上面運行良好,但是移植到esp32s3上后由于fpu造成浮點數
    發表于 06-27 07:32

    STM32CubeIDE printf浮點數浮點數丟失數值的原因?

    1、芯片:STM32F103C8T62、環境:STM32CubeIDE3、問題:printf浮點數浮點數數值丟失如 float A=25.6666;float B=24.7777;實際打印
    發表于 06-03 07:07

    verilog語音實現浮點運算

    Verilog可以通過使用IEEE標準的浮點數表示來實現浮點運算。下面是一個基本的Verilog模塊示例,展示了如何進行加法、乘法和除法等常見的浮點運算操作: module
    發表于 03-25 21:49

    一文帶你秒懂IEEE 754浮點數

    一、簡介1、常見的浮點數表示方式是IEEE754標準,它規定了浮點數的存儲格式和運算規則,這個標準定義了兩種浮點數表示:單精度和雙精度。2、任何一個浮點數的二進制數可以寫為:NUM=(
    的頭像 發表于 03-18 08:09 ?8833次閱讀
    一文帶你秒懂IEEE 754<b class='flag-5'>浮點數</b>
    主站蜘蛛池模板: 亚洲国产成人99精品激情在线| 日日干夜夜爽| 日本二区三区欧美亚洲国| 伊人久久精品午夜| 国产色婷婷亚洲99精品| 色戒2小时38分在线观看| av网站视频在线观看| 巨胸美乳中文在线观看| 伊人久99久女女视频精品免| 娇妻让壮男弄的流白浆| 亚洲手机在线人成视频| 国产人妻午夜无码AV天堂| yellow在线观看免费观看大全 | 午夜日韩久久影院| 国产高潮国产高潮久久久久久| 日韩特黄特色大片免费视频| 成人在免费视频手机观看网站 | 恋夜秀场支持安卓版全部视频国产 | 超碰人热人人热人人看| 欧美丰满白嫩bbxx| 999久久国产精品免费人妻| 男人的天堂黄色片| www免费看.男人的天堂| 又粗又大又爽又黄的免费视频| 国产日韩高清一区二区三区| 被高跟鞋调教丨vk| 北原多香子qvod| free性中国hd护士高清| 插我一区二区在线观看| 光棍天堂在线a| 国产精品大全国产精品| 精品久久日日躁夜夜躁AV| 久久精品亚洲AV高清网站性色| 蜜桃TV成人网站免费打开| 国产精品亚洲欧美| 老女老肥熟国产在线视频| 97精品免费视频| 人妻熟女斩五十路0930| 国产精品久久久久久久久久久| 韩日午夜在线资源一区二区| 亚洲 欧美 中文 日韩 另类|