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

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

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

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

科技觀察員 ? 來(lái)源:allaboutcircuits ? 作者:大衛(wèi) ·彼得森 ? 2022-04-29 16:20 ? 次閱讀

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

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

數(shù)字的主要類(lèi)別

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

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

多位整數(shù)

“浮點(diǎn)小數(shù)”數(shù)字

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

多位整數(shù)通常是 8、16 或 32 個(gè)連續(xù)位,并且只能保存整數(shù)值??梢允褂眠@些數(shù)字存儲(chǔ)或計(jì)算的最大值受位數(shù)限制。較大的數(shù)字需要更多的位,但也會(huì)消耗更多的內(nèi)存。

最后一個(gè)類(lèi)別經(jīng)常出現(xiàn)在表示實(shí)際值時(shí),例如溫度、速度或壓力。這些類(lèi)型的值不限于整數(shù),因?yàn)橐阅撤N精度知道值通常至關(guān)重要。

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

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

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

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

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

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

浮標(biāo)的一部分

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

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

pYYBAGJrn7OAIrqcAAAbz0CxMK4169.png

poYBAGJrn5-AWZS7AAD5WrNe86U957.png

浮點(diǎn)數(shù)的限制

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

pYYBAGJrn9yAeqcrAABHhnQgaS4382.jpg

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

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

某些情況下的另一個(gè)潛在問(wèn)題是無(wú)法真正處理絕對(duì)精確的值。對(duì)于整數(shù),比如數(shù)數(shù),你可以數(shù) 100 個(gè)項(xiàng)目,但你永遠(yuǎn)不會(huì)數(shù)到 100.5 個(gè)項(xiàng)目。因此,它可以很容易地顯示為 100,沒(méi)有理由顯示 100.0000000 個(gè)項(xiàng)目。

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

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

    關(guān)注

    5006

    文章

    13107

    瀏覽量

    461450
  • 浮點(diǎn)數(shù)
    +關(guān)注

    關(guān)注

    0

    文章

    59

    瀏覽量

    15856
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    TLV320AIC3106音頻芯片怎么發(fā)送、接收浮點(diǎn)數(shù)呢?

    TLV320AIC3106 音頻芯片怎么發(fā)送、接收浮點(diǎn)數(shù)呢?是把浮點(diǎn)數(shù)轉(zhuǎn)成整數(shù)嗎?如果是該怎么轉(zhuǎn)呢? 經(jīng)AD采樣后得到的是整數(shù),又該怎么轉(zhuǎn)換成原始的浮點(diǎn)數(shù)呢?
    發(fā)表于 11-05 07:13

    labview浮點(diǎn)數(shù)與十六進(jìn)制字符串相互轉(zhuǎn)化

    與下位機(jī)數(shù)據(jù)交流及通訊時(shí),經(jīng)常有浮點(diǎn)數(shù)與十六進(jìn)制字符串相互轉(zhuǎn)化的需求,經(jīng)過(guò)兩天總結(jié),找到了最簡(jiǎn)潔的相互轉(zhuǎn)化的方法,萌新歡迎大佬指正,文件也附上。*附件:HEX字符串與浮點(diǎn)數(shù)轉(zhuǎn)換.rar
    發(fā)表于 10-21 19:51

    TMS320C6745浮點(diǎn)數(shù)字信號(hào)處理器技術(shù)簡(jiǎn)介

    電子發(fā)燒友網(wǎng)站提供《TMS320C6745浮點(diǎn)數(shù)字信號(hào)處理器技術(shù)簡(jiǎn)介.pdf》資料免費(fèi)下載
    發(fā)表于 10-09 09:34 ?0次下載
    TMS320C6745<b class='flag-5'>浮點(diǎn)數(shù)</b>字信號(hào)處理器技術(shù)簡(jiǎn)介

    分享在arduino 單片機(jī)浮點(diǎn)數(shù)轉(zhuǎn)換位數(shù)不夠,精度丟失的解決辦法

    arduino由于硬件限制,浮點(diǎn)數(shù)只有2位小數(shù)。但經(jīng)過(guò)這個(gè)函數(shù)處理可以達(dá)到7位
    的頭像 發(fā)表于 08-27 14:34 ?525次閱讀

    官方例程modbus slave rtu,浮點(diǎn)數(shù)精度不對(duì)是怎么回事?

    官方例程 modbus slave rtu, 浮點(diǎn)數(shù)精度不對(duì),對(duì)保持寄存器設(shè)置一個(gè)浮點(diǎn)數(shù),讀取到的浮點(diǎn)數(shù)結(jié)果精度只能到小數(shù)點(diǎn)后兩位,根本無(wú)法使用,用的是idf 5.1.2版本,開(kāi)發(fā)環(huán)境是vscode。
    發(fā)表于 07-19 08:10

    請(qǐng)問(wèn)如何打印浮點(diǎn)數(shù)或雙精度變量?

    如何打印浮點(diǎn)數(shù)或雙精度變量?
    發(fā)表于 07-12 08:24

    ESP8266_RTOS_SDK如何打印浮點(diǎn)數(shù)?

    不適用于浮點(diǎn)數(shù); 我的假設(shè)是編譯器沒(méi)有啟用浮點(diǎn)? 如果是這種情況,我不確定要啟用什么標(biāo)志? 編譯器版本: xtensa-lx106-elf-gcc --版本
    發(fā)表于 07-09 06:56

    如何關(guān)閉ESP32-S3的FPU浮點(diǎn)數(shù)計(jì)算單元?

    如何關(guān)閉ESP32-S3的FPU浮點(diǎn)數(shù)計(jì)算單元。如題,之前的項(xiàng)目在esp32s2 上面運(yùn)行良好,但是移植到esp32s3上后由于fpu造成浮點(diǎn)數(shù)計(jì)算無(wú)法在中斷中使用,并且也不能跨cpu去使用,對(duì)固件性能和穩(wěn)定性造成了很大的影響
    發(fā)表于 06-27 07:32

    STM32CubeIDE printf浮點(diǎn)數(shù),浮點(diǎn)數(shù)丟失數(shù)值的原因?

    1、芯片:STM32F103C8T62、環(huán)境:STM32CubeIDE3、問(wèn)題:printf浮點(diǎn)數(shù),浮點(diǎn)數(shù)數(shù)值丟失如 float A=25.6666;float B=24.7777;實(shí)際打印
    發(fā)表于 06-03 07:07

    一文帶你秒懂IEEE 754浮點(diǎn)數(shù)

    一、簡(jiǎn)介1、常見(jiàn)的浮點(diǎn)數(shù)表示方式是IEEE754標(biāo)準(zhǔn),它規(guī)定了浮點(diǎn)數(shù)的存儲(chǔ)格式和運(yùn)算規(guī)則,這個(gè)標(biāo)準(zhǔn)定義了兩種浮點(diǎn)數(shù)表示:?jiǎn)尉群碗p精度。2、任何一個(gè)浮點(diǎn)數(shù)的二進(jìn)制數(shù)可以寫(xiě)為:NUM=(
    的頭像 發(fā)表于 03-18 08:09 ?7903次閱讀
    一文帶你秒懂IEEE 754<b class='flag-5'>浮點(diǎn)數(shù)</b>

    modbus浮點(diǎn)數(shù)怎么讀取

    Modbus是一種通信協(xié)議,常用于工業(yè)自動(dòng)化系統(tǒng)的設(shè)備之間的通信。它支持多種數(shù)據(jù)類(lèi)型,包括整數(shù)、浮點(diǎn)數(shù)、字符串等。浮點(diǎn)數(shù)在工業(yè)領(lǐng)域中廣泛應(yīng)用,因此了解如何讀取和處理Modbus浮點(diǎn)數(shù)
    的頭像 發(fā)表于 12-28 14:38 ?5674次閱讀

    單精度和雙精度浮點(diǎn)數(shù)的區(qū)別

    單精度和雙精度是計(jì)算機(jī)中表示浮點(diǎn)數(shù)的兩種不同的精度。在計(jì)算機(jī),浮點(diǎn)數(shù)用來(lái)表示帶有小數(shù)部分的實(shí)數(shù),而單精度和雙精度用來(lái)表示浮點(diǎn)數(shù)的精確程度不同。在以下文章
    的頭像 發(fā)表于 12-15 10:25 ?5131次閱讀

    單精度和雙精度浮點(diǎn)數(shù)的區(qū)別

    在計(jì)算機(jī)科學(xué)和數(shù)值計(jì)算,浮點(diǎn)數(shù)是一種用于表示實(shí)數(shù)的數(shù)據(jù)類(lèi)型。浮點(diǎn)數(shù)有兩種精度級(jí)別:?jiǎn)尉群碗p精度。這兩種精度級(jí)別在表示范圍、精度和存儲(chǔ)空間等方面都有所不同。本文將詳細(xì)介紹單精度和雙精度浮點(diǎn)數(shù)
    的頭像 發(fā)表于 12-13 10:55 ?9911次閱讀

    縫縫補(bǔ)補(bǔ)的浮點(diǎn)數(shù)進(jìn)制轉(zhuǎn)換器

    [浮點(diǎn)數(shù)]()在計(jì)算機(jī)科學(xué)是一種重要的數(shù)據(jù)類(lèi)型,用于表示實(shí)數(shù)。其中,F(xiàn)P32和FP16是兩種常見(jiàn)的浮點(diǎn)數(shù)格式,分別占用32位和16位。
    的頭像 發(fā)表于 12-04 14:00 ?1391次閱讀
    縫縫補(bǔ)補(bǔ)的<b class='flag-5'>浮點(diǎn)數(shù)</b>進(jìn)制轉(zhuǎn)換器

    請(qǐng)問(wèn)ADSP-21469的匯編指令集ISA/VISA中有沒(méi)有專(zhuān)門(mén)用來(lái)進(jìn)行浮點(diǎn)數(shù)和定點(diǎn)數(shù)轉(zhuǎn)換的指令?

    得到的ADC數(shù)據(jù)需要進(jìn)行定點(diǎn)數(shù)浮點(diǎn)數(shù)的轉(zhuǎn)換,為了節(jié)省開(kāi)銷(xiāo),想使用匯編程序進(jìn)行定點(diǎn)和浮點(diǎn)之間的轉(zhuǎn)換。請(qǐng)問(wèn)ADSP-21469的匯編指令集ISA/VISA中有沒(méi)有專(zhuān)門(mén)用來(lái)進(jìn)行
    發(fā)表于 11-29 08:03