㈠ 單片機浮點數運算問題。程序如下
.採用定點方法如一個脈沖代表0.003米,將其擴大1000倍為整數3,然後顯示結果
unsigneg long int depth=pulse*3 最後顯示時把小數點定在倒數第4位後面即可
2.
用C語言編程時,可用float型,後將結果轉化成字元串,然後用字元串顯示函數
如 sprintf(s,"%6.4f",a);, a是浮點數變數S[]是保存字元串轉換結果的數組 長度根據需要自己定中間引號里是輸出格式控制符,類似於print
方法1我一直採用,第2種方法是我最近才學會的
㈡ 單片機浮點乘法和浮點除法一樣嗎
不一樣。單片機浮點乘法和浮點除法是不一樣的,一般盡量用乘法或其它方法代替除法。浮點(floating-point)是一種數的表示方法。一個數被表示為尾數部分和指數部分,其值為尾數乘以基數的指數次冪,基數(通常為2)隱含在表示格式中。
㈢ 單片機 浮點運算
用keil C51,加入
#include<math.h>
就行了。
但你要注意了!要進行浮點運算,你的程序存儲器一定要大,因為一個乘除法需要三、四百個位元組,開方需要七百多位元組呢,而且好像算得不太准。慎用!
㈣ 單片機能做浮點運算嗎
可以啊,但不同品牌、不同型號單片機的運算能力不同,同樣的運算代碼,會出現不同的運算速度。
㈤ 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;
....... //然後就開始顯示了
}
㈥ 單片機做乘除法運算與浮點運算相比耗時嗎
是的,對於沒有浮點運算單元FPU的單片機,一般就是採用這種方式來計算。
例如原本要計算的數據是個電壓值,在0~3.3V之間,通過12位采樣之後得到0~4095的采樣值AD_value。按照AD_value*2/5計算之後得到的就是0~1638內的結果,再反向換算為電壓0~1.32V。
㈦ 51單片機能不能計算浮點數,支不支持浮點運算有人說能,有人說不能。
不能直接硬體計算浮點(就是所謂的FPU),只能通過程序庫(調用函數)模擬完成,非常耗時!
㈧ 單片機三位元組浮點數演算法
唉,給你出這個題目的人的腦子一定是壞掉了!
既然是用C語言,還用自己編程實現來浮點數演算法嗎?
㈨ 在玩單片機 的時候總是會說什麼定點運算和浮點運算,始終不明白,這個浮點運算是什麼,
定點運算實際就是整數(定點小數,可以視為整數)運算,浮點運算實際就是實數運算。
假如處理器是32位的,也就是說32位都用來表示整數的話,那麼對於無符號整數就是 0~2^32-1,對於有符號整數就是 -2^31~2^31-1。如果是實數的話,機器有兩種辦法來表示,一種是定點,即小數點位置是固定的;另一種就是浮點,即小數點位置不固定,計算方法也比較麻煩,通常會比整數運算代價大很多。
因為計算機只能存儲整數,所以實數都是「約等於」出來的,浮點運算是很慢的而且會存在精度問題(也即誤差)。
基本所有處理器都支持定點運算,但不是所有的都支持浮點運算。
㈩ 51單片機怎麼實現浮點運算
要先按裝浮點庫C51FPS.LIB,按裝路徑為:將 C51FPS.LIB 文件復制到 C:\Keil\C51\LIB\ 文件夾下面。
而後在程序中用浮點型變數float或double進行運算即可。