導航:首頁 > 操作系統 > 單片機的浮點運算

單片機的浮點運算

發布時間:2024-03-28 18:16:09

㈠ 51單片機能不能計算浮點數,支不支持浮點運算有人說能,有人說不能。

不能直接硬體計算浮點(就是所謂的FPU),只能通過程序庫(調用函數)模擬完成,非常耗時!

㈡ 單片機中float的具體用法用法

float是單精度陪跡哪浮點數,在內存中佔4個位元組州中,可以定義變蘆碼量類型為 浮點數如
int a,b;
float c;
a=3;
b=4;
c=a/b; 則c=0.75;
如果c也是int型則
c=a/b 結果是0

㈢ 單片機能做浮點運算嗎

可以啊,但不同品牌、不同型號單片機的運算能力不同,同樣的運算代碼,會出現不同的運算速度。

㈣ C51單片機浮點數運算

因為沒有電路,所以程序我就沒法給你寫,給你個思路.
第一,不知道你的a和b是什麼類型的,如果是定義成浮點型,那麼,可以這樣寫:
float f_Div = a/b;
如果兩個有一個是整形的,那麼,把整型強制轉換成浮點型:
float f_Div = (float)a/(float)b;
注意,那個f_Div變數必須是float型,才能有小數產生

第二,你要進行顯示,肯定要把各個位都取出來,這裡面肯定有一個取模運算,就是"%",
對於浮點型,不運行取模運算的,所以,你必須把浮點型轉換成整型,但是,不能強制轉換,
比如: unsigned int I_Div = (unsigned int)f_Div;這是不可以的,你的小數部分就沒有了.
所以,你必須要放大一定的倍數,根據你的要求,你是要保留三位,那麼,這里還有個問題,你的
小數點之前有幾位,決定了你小數點後面保留幾位.
比如,你得到的結果是 1.2345,那麼,你就保留1.23
如果你得到的結果是 12.345,那麼,就保留12.3
如果你得到的結果是 123.45,你就只能保留123了
如果得到的結果是 0.123,你就只能保留 0.12

所以可以看出,你的浮點型結果整數部分有多少位,決定了你的小數能保留多少位,所以還要進行如下運算:

unsigned int i_Div = unsigned int)f_Div;;
unsigned char Dot_Bit = 0; //---這個變數用來表示在第幾位上顯示小數點,因為
//---通過下面的操作,已經把小數變成整數了
if(I_Div >= 100) //---表示前面有3個整數部分位
{
; //---那就沒什麼可操作的,unsigned int i_Div = unsigned int)f_Div;;就符合要求
}
else if (I_DIV >= 10) //---表示整數部分有2位
{
I_DIV = f_Div *10;
Dot_Bit = 1; //---在右數第2個地方顯示小數點,也就是十位後顯示小數點
}
else
{
I_DIV = f_Div *10;
Dot_Bit = 2; //---在右數第2個地方顯示小數點,也就是最前面那位後面顯示
}
void Display(void)
{

unsigned char Hundred = I_Div/100;
unsigned char TenBit = (I_Div/%00)/10;
unsigned char TenBit = I_Div%10;
....... //然後就開始顯示了

}

㈤ 在玩單片機 的時候總是會說什麼定點運算和浮點運算,始終不明白,這個浮點運算是什麼,

定點運算實際就是整數(定點小數,可以視為整數)運算,浮點運算實際就是實數運算。

假如處理器是32位的,也就是說32位都用來表示整數的話,那麼對於無符號整數就是 0~2^32-1,對於有符號整數就是 -2^31~2^31-1。如果是實數的話,機器有兩種辦法來表示,一種是定點,即小數點位置是固定的;另一種就是浮點,即小數點位置不固定,計算方法也比較麻煩,通常會比整數運算代價大很多。

因為計算機只能存儲整數,所以實數都是「約等於」出來的,浮點運算是很慢的而且會存在精度問題(也即誤差)。

基本所有處理器都支持定點運算,但不是所有的都支持浮點運算。

㈥ 單片機中C語言如何實現浮點除法運算

直接除就可以了
比如定義一個整形變數int x;
另一個整形變數int y;
浮點型變數float z;

浮點數除法:
z = (float)x / (float)y

㈦ 單片機 程序中能輸入小數嗎

這樣程序處理的也簡單、2,比如輸入1、5就可以、4.0245,還是逐位輸入的好、0不用用小數表示,否則處理小數的程序都會讓你吃不消,就逐位輸入1

㈧ 51單片機怎麼實現浮點運算

要先按裝浮點庫C51FPS.LIB,按裝路徑為:將 C51FPS.LIB 文件復制到 C:\Keil\C51\LIB\ 文件夾下面。
而後在程序中用浮點型變數float或double進行運算即可。

閱讀全文

與單片機的浮點運算相關的資料

熱點內容
看比賽用哪個app 瀏覽:974
如何評價如故app 瀏覽:149
建立表結構的命令 瀏覽:579
安卓文件為什麼蘋果手機打不開 瀏覽:82
東奧輕4可以在哪個app做題 瀏覽:163
金融科技加密卡 瀏覽:835
程序員那麼開一共有多少集 瀏覽:980
面試程序員被問數學問題怎麼辦 瀏覽:91
背大學英語的app哪個最好 瀏覽:719
哪個app買的衣服好 瀏覽:467
天刀以前玩過的伺服器忘了怎麼辦 瀏覽:211
單片機基礎代碼解讀 瀏覽:233
廣東青少年編程學習 瀏覽:509
買男士香水去哪個app 瀏覽:548
androidsleep函數 瀏覽:151
android內核代碼下載 瀏覽:665
伺服器如何添加墨跡 瀏覽:747
diglinux安裝 瀏覽:279
虛擬機執行命令 瀏覽:446
cctv16奧林匹克頻道加密播出 瀏覽:901