91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

深度剖析PLC編程中的浮點數(shù)

科技觀察員 ? 來源:allaboutcircuits ? 作者:大衛(wèi) ·彼得森 ? 2022-04-29 16:20 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

PLC 必須處理三種主要類型的值:布爾值、整數(shù)和浮點數(shù)。這些最后的浮點值會給程序員和技術(shù)人員帶來最大的困惑。

任何包含處理器的數(shù)字控制系統(tǒng)都旨在接收輸入值,使用這些值計算解決方案,然后使用這些計算向其他設(shè)備提供輸出。必須仔細選擇此過程中每個步驟使用的數(shù)字——不僅要足夠精確以提供正確的輸出值,而且要足夠小,以免占用太多有限的可用內(nèi)存空間。

數(shù)字的主要類別

數(shù)字?jǐn)?shù)字適合三個主要類別的值:

一位“布爾”數(shù)字

多位整數(shù)

“浮點小數(shù)”數(shù)字

一位布爾數(shù)字只能保存 0 或 1 的值。這些布爾值非常適合傳感器和開關(guān)輸入以及線圈輸出。

多位整數(shù)通常是 8、16 或 32 個連續(xù)位,并且只能保存整數(shù)值。可以使用這些數(shù)字存儲或計算的最大值受位數(shù)限制。較大的數(shù)字需要更多的位,但也會消耗更多的內(nèi)存。

最后一個類別經(jīng)常出現(xiàn)在表示實際值時,例如溫度、速度或壓力。這些類型的值不限于整數(shù),因為以某種精度知道值通常至關(guān)重要。

例如,測量壓力時,了解 15.1 psi 和 15.8 psi 之間的變化可能很重要。如果我們將值限制為整數(shù),它們都將顯示為 15 psi,失去該精度。

這種數(shù)據(jù)類型的名稱是“浮點十進制”數(shù)字,在編程軟件中通常稱為“浮點”或“實數(shù)”數(shù)據(jù)類型。

浮點數(shù)的結(jié)構(gòu)

通常沒有必要理解在實際值和二進制浮點等效值之間進行轉(zhuǎn)換所涉及的每個數(shù)學(xué)運算。與許多數(shù)字轉(zhuǎn)換一樣,這是一個復(fù)雜的過程,可以根據(jù)需要進行研究。但這并不意味著應(yīng)該忽略整個概念。

在本文中,這些數(shù)字將被稱為浮點數(shù)。但是,如果您是 RSLogix 用戶或該術(shù)語的任何其他適當(dāng)頭銜,則可以在心理上將其轉(zhuǎn)換為真實的。

浮點數(shù)由 PLC 中的 32 位組成。在許多現(xiàn)代計算機處理器中,可能使用 64 位,但對于幾乎所有 PLC,32 位是標(biāo)準(zhǔn)。這意味著就內(nèi)存容量而言,浮點數(shù)不會比 32 位整數(shù)(例如 double 或 DINT)消耗更多空間。有時,兩個 32 位數(shù)字可以組合成一個 64 位浮點值。

浮標(biāo)的一部分

浮點數(shù)由三個部分組成,每個部分使用 32 位的一部分。第一位是符號位,用于標(biāo)識它是正值還是負值。如果將真空表示為儀表值,則溫度很容易為負數(shù),壓力也可以為負數(shù)。速度可能是正的/負的,也可能是使用 CW/CCW 或類似的術(shù)語來區(qū)分的。第一位標(biāo)識正面或負面。

下表顯示了 32 位浮點數(shù)的示例分解。此示例顯示可能的最小正值,指數(shù)為 1,尾數(shù)為 0。

pYYBAGJrn7OAIrqcAAAbz0CxMK4169.png

poYBAGJrn5-AWZS7AAD5WrNe86U957.png

浮點數(shù)的限制

與整數(shù)值相比,浮點數(shù)的主要注意事項可能是計算解的額外時間。在一個具體示例中,根據(jù)羅克韋爾自動化針對 ControlLogix 處理器的文檔,使用 REAL 數(shù)據(jù)類型的 ADD 計算的執(zhí)行時間比 DINT 的相同 ADD 長約 6.5 倍。

pYYBAGJrn9yAeqcrAABHhnQgaS4382.jpg

圖 2.數(shù)據(jù)表摘錄比較使用 32 位 DINT 和 32 位 REAL 數(shù)據(jù)類型的 ADD 指令時間。

有時,浮點數(shù)是必要的,但處理指令的額外時間應(yīng)該是一個堅定的提醒,在合理的情況下考慮使用整數(shù)。

某些情況下的另一個潛在問題是無法真正處理絕對精確的值。對于整數(shù),比如數(shù)數(shù),你可以數(shù) 100 個項目,但你永遠不會數(shù)到 100.5 個項目。因此,它可以很容易地顯示為 100,沒有理由顯示 100.0000000 個項目。

但是,對于需要非常大精度的值(這意味著尾數(shù)非常大),該值可能會被四舍五入。對于許多系統(tǒng)來說這可能不是問題,但是當(dāng)系統(tǒng)必須定期測量大的模擬值時,舍入誤差可能會導(dǎo)致問題。

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

    關(guān)注

    5051

    文章

    14595

    瀏覽量

    486980
  • 浮點數(shù)
    +關(guān)注

    關(guān)注

    0

    文章

    62

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    TMS320C6711D浮點數(shù)字信號處理器:高性能與靈活性的完美結(jié)合

    TMS320C6711D浮點數(shù)字信號處理器:高性能與靈活性的完美結(jié)合 在數(shù)字信號處理(DSP)領(lǐng)域,TI的TMS320C6711D浮點數(shù)字信號處理器以其卓越的性能和豐富的功能脫穎而出。今天,我們就來
    的頭像 發(fā)表于 03-06 16:55 ?894次閱讀

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

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

    點數(shù)表示實數(shù)的方法以及定點數(shù)在硬件上的運算驗證

    ’b110_0000_0000_0000_0000_0000時,表示為十進制小數(shù)0.75( 2^(-1)+2^(-2) )。E是指數(shù),為了能夠表示負指數(shù)、IEEE754標(biāo)準(zhǔn)規(guī)定浮點數(shù)的實際指數(shù)為E-127。從32位浮點數(shù)編碼結(jié)
    發(fā)表于 10-28 08:13

    E203添加浮點數(shù)方法:譯碼和派遣模塊設(shè)計

    的數(shù)據(jù)來自于整數(shù)寄存器還是浮點數(shù)寄存器。 派遣模塊與其他模塊的連接方式如下圖: 左圖只選取了有代表性的信號展示出來,即只展示了源操作數(shù)和寫寄存器的地址是如何在這些模塊傳遞的。右圖是 dispatch
    發(fā)表于 10-24 13:54

    浮點指令(三)

    Convert to Single from Double). R-type, RV32D and RV64D. 把寄存器 f[rs1]的雙精度浮點數(shù)轉(zhuǎn)化為單精度浮點數(shù),再寫入 f[rd]
    發(fā)表于 10-24 13:38

    E203添加浮點數(shù)方法:FPU控制邏輯

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

    蜂鳥E203擴展浮點指令設(shè)計(2)

    fmv.w.x rd, rs1 ? fmv.x.w 指令將通用浮點寄存器 rs1的單精度浮點數(shù)讀出,然后寫回通用整數(shù)寄存rd。 ? fmv.w.x 指令將通用整數(shù)寄存器 rs1
    發(fā)表于 10-24 11:56

    浮點指令(一:單精度)

    , Single-Precision). R-type, RV32F and RV64F. 把寄存器 f[rs1]和 f[rs2]的單精度浮點數(shù)相加,并將舍入后的和寫入 f[rd]。 fsub.s
    發(fā)表于 10-24 11:42

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

    )相加所得。 ? flw 指令從存儲器讀回一個單精度浮點數(shù),寫回寄存器 rd 。 ? fsw 指令將操作數(shù)寄存器 rs2 的單精度浮點數(shù)
    發(fā)表于 10-24 10:00

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

    1位。 ###### 浮點數(shù)的平方根運算步驟為:浮點數(shù)的平方根運算步驟為: 1.從指數(shù)減去偏置分量,求絕對差。 2.將結(jié)果右移一位,然后計算最后的指數(shù)。 3.找到尾數(shù)的平方根,考慮隱藏的部分
    發(fā)表于 10-24 08:42

    浮點數(shù)指令添加——長指令寫回仲裁

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

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

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

    大彩講堂:VisualHMI-LUA教程-獲取設(shè)置單精度浮點數(shù)函數(shù)的應(yīng)用

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

    想在bsp工程打印浮點數(shù),結(jié)果找不到rt_vsnprintf_full軟件包,怎么解決?

    想在bsp工程打印浮點數(shù),結(jié)果找不到rt_vsnprintf_full軟件包 問題復(fù)現(xiàn) 使用env-windows-v2.0.0 執(zhí)行pkgs --upgrade 打開menuconfig找不到rt_vsnprintf_full軟件包 使用/搜索找到軟件包但顯示紅色,不能操作,有沒有大佬知道是什么原因,怎么解決
    發(fā)表于 06-13 07:48

    PRINTF函數(shù)無法打印出浮點數(shù)內(nèi)容是為什么?

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