0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線(xiàn)課程
  • 觀(guān)看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創(chuàng)作中心

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

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

單片機(jī)浮點(diǎn)數(shù)運(yùn)算的源碼設(shè)計(jì)

GReq_mcu168 ? 來(lái)源:未知 ? 作者:鄧佳佳 ? 2018-03-07 15:19 ? 次閱讀

單片機(jī)的一個(gè)浮點(diǎn)數(shù)一般在KeilC51中是以4字節(jié)形式存儲(chǔ)的,格式嚴(yán)格遵循IEEE-754標(biāo)準(zhǔn)。在單片機(jī)二進(jìn)制數(shù)據(jù)中,浮點(diǎn)數(shù)用兩個(gè)部分來(lái)表示,基C為2,E為階碼,M為尾數(shù),E的保存形式是一個(gè)0~255的8位值,指數(shù)的實(shí)際表示值是保存值減去127,范圍在-127~+128的數(shù),尾數(shù)是一個(gè)24位值,換算7個(gè)十進(jìn)制數(shù),最高位通常是1,符號(hào)位表示浮點(diǎn)數(shù)的正負(fù)。

現(xiàn)在看怎樣顯示一個(gè)浮點(diǎn)數(shù),由于浮點(diǎn)數(shù)的尾數(shù)是24位,最高可以表達(dá)的整數(shù)值為16777215,用科學(xué)計(jì)數(shù)法表示時(shí)整數(shù)部分占據(jù)1位,小數(shù)部分就可以有6位,我們將浮點(diǎn)數(shù)的尾數(shù)放在長(zhǎng)整形數(shù)據(jù)longint中保存,階碼可以在int型數(shù)據(jù)中保存。此處我們用C程序來(lái)實(shí)現(xiàn)顯示一個(gè)浮點(diǎn)數(shù)的功能。

(1)浮點(diǎn)數(shù)顯示子函數(shù)。

}}

(2)顯示十進(jìn)制尾數(shù)和階的子函數(shù)。

在大多數(shù)的單片機(jī)應(yīng)用系統(tǒng)中都不能離開(kāi)數(shù)值計(jì)算,最基本的數(shù)值運(yùn)算為四則運(yùn)算,單片機(jī)中的數(shù)都是以二進(jìn)制形式表示的,二進(jìn)制的算法有很多,其中最基本的是定點(diǎn)制和浮點(diǎn)制,以上介紹了浮點(diǎn)數(shù)在單片機(jī)中的表示方式和匯編子程序,浮點(diǎn)數(shù)比定點(diǎn)數(shù)加減法要困難,但是克服了定點(diǎn)數(shù)表示范圍小的問(wèn)題,總之定點(diǎn)數(shù)和浮點(diǎn)數(shù)各有各得的特點(diǎn),讀者可以在實(shí)際運(yùn)用中加以?xún)?yōu)化運(yùn)用。

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

    關(guān)注

    6061

    文章

    44838

    瀏覽量

    645309

原文標(biāo)題:51單片機(jī)執(zhí)行指令的過(guò)程

文章出處:【微信號(hào):mcu168,微信公眾號(hào):硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 0人收藏

    評(píng)論

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

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

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

    設(shè)計(jì)了一個(gè)基于浮點(diǎn)數(shù)運(yùn)算的協(xié)處理器,使用C語(yǔ)言編程時(shí)沒(méi)法輸入float型數(shù)據(jù),請(qǐng)問(wèn)有哪些部分需要修改?

    我設(shè)計(jì)了一個(gè)基于浮點(diǎn)數(shù)運(yùn)算的協(xié)處理器,使用C語(yǔ)言編程時(shí)沒(méi)法輸入float型數(shù)據(jù),請(qǐng)問(wèn)有哪些部分需要修改?SDK,EXU_decoder浮點(diǎn)寄存器都需要修改嗎,謝謝
    發(fā)表于 03-07 16:03

    labview寫(xiě)入浮點(diǎn)數(shù)到匯川 PLC中的數(shù)據(jù)轉(zhuǎn)換關(guān)鍵

    本帖最后由 ironflag 于 2025-3-26 13:35 編輯 Labview通過(guò)Modbus庫(kù)函數(shù),寫(xiě)入浮點(diǎn)數(shù)到匯川PLC,正常操作如下: 1、將labview浮點(diǎn)數(shù),強(qiáng)制轉(zhuǎn)換
    發(fā)表于 02-24 19:01

    西門(mén)子TIA Portal如何比較兩個(gè)浮點(diǎn)數(shù)相等

    概述: 由于浮點(diǎn)數(shù)的定義規(guī)則,導(dǎo)致浮點(diǎn)數(shù)不能通過(guò)二進(jìn)制精確表示,所以在浮點(diǎn)數(shù)計(jì)算過(guò)程中,會(huì)出現(xiàn)兩個(gè)值一樣的浮點(diǎn)數(shù)進(jìn)行比較相等計(jì)算時(shí)結(jié)果并不相等的情況。下面先設(shè)計(jì)一個(gè)實(shí)例說(shuō)明該問(wèn)題,并給
    的頭像 發(fā)表于 01-06 10:07 ?544次閱讀
    西門(mén)子TIA Portal如何比較兩個(gè)<b class='flag-5'>浮點(diǎn)數(shù)</b>相等

    ADS1282采集到的數(shù)據(jù)傳到PC上應(yīng)該怎么轉(zhuǎn)為浮點(diǎn)數(shù)

    我最近在用ADS1282,采集到的數(shù)據(jù)傳到PC上應(yīng)該怎么轉(zhuǎn)為浮點(diǎn)數(shù)?比如說(shuō)通過(guò)串口調(diào)試助手收到一個(gè)采樣點(diǎn)的數(shù)據(jù)為 FF FF 9D 17,它的真實(shí)浮點(diǎn)數(shù)是多少呢?我知道ADC是以補(bǔ)碼形式存的,是要將數(shù)據(jù)倒轉(zhuǎn)為17 9D FF FF,再與上0xFF,再float()嗎?還
    發(fā)表于 12-13 06:23

    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 ?1064次閱讀

    請(qǐng)問(wèn)AURIX TC3xx tricore架構(gòu)下浮點(diǎn)運(yùn)算和將浮點(diǎn)數(shù)小數(shù)點(diǎn)去掉變成整數(shù)來(lái)計(jì)算哪種方式更加節(jié)省算力?

    AURIX TC3xx tricore架構(gòu)下浮點(diǎn)運(yùn)算和將浮點(diǎn)數(shù)小數(shù)點(diǎn)去掉變成整數(shù)來(lái)計(jì)算哪種方式更加節(jié)省算力? 比如一個(gè)浮點(diǎn)數(shù)12.89V,如果將其寫(xiě)成12890mV,再參與計(jì)算,哪種方
    發(fā)表于 08-26 06:54

    TMS320C6711D浮點(diǎn)數(shù)字信號(hào)處理器數(shù)據(jù)表

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

    官方例程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ù)?

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

    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

    電子發(fā)燒友

    中國(guó)電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會(huì)員交流學(xué)習(xí)
    • 獲取您個(gè)性化的科技前沿技術(shù)信息
    • 參加活動(dòng)獲取豐厚的禮品