国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內不再提示

深度剖析PLC編程中的浮點數

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

掃碼添加小助手

加入工程師交流群

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

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

數字的主要類別

數字數字適合三個主要類別的值:

一位“布爾”數字

多位整數

“浮點小數”數字

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

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

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

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

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

浮點數的結構

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

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

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

浮標的一部分

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

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

pYYBAGJrn7OAIrqcAAAbz0CxMK4169.png

poYBAGJrn5-AWZS7AAD5WrNe86U957.png

浮點數的限制

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

pYYBAGJrn9yAeqcrAABHhnQgaS4382.jpg

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

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

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

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

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

    關注

    5051

    文章

    14594

    瀏覽量

    486915
  • 浮點數
    +關注

    關注

    0

    文章

    62

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    TMS320C6711D浮點數字信號處理器:高性能與靈活性的完美結合

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

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

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

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

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

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

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

    浮點指令(三)

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

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

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

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

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

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

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

    浮點數是如何實現開平方運算的

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

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

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

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

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

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

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

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

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

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

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

    設計了一個基于浮點數運算的協處理器,使用C語言編程時沒法輸入float型數據,請問有哪些部分需要修改?

    我設計了一個基于浮點數運算的協處理器,使用C語言編程時沒法輸入float型數據,請問有哪些部分需要修改?SDK,EXU_decoder浮點寄存器都需要修改嗎,謝謝
    發表于 03-07 16:03