返回首页

51单片机浮点数乘法运算(51单片机可以计算浮点数吗)

来源:www.haichao.net  时间:2022-12-16 03:26   点击:287  编辑:admin   手机版

1. 51单片机可以计算浮点数吗

一般是浮点数乘以10的n次方变成整数进行计算等处理,在输出的时候再次处理小数点。

比如,输入的是1234.567,1234保存到2个unsigned char型变量里面,567保存到2个unsigned char型变量里面,如果是有符号浮点数,可以把符号单独保存到一个unsigned char里面,计算的时候所有的数都乘以1000,输出的时候单独输出整数部分和小数部分。

2. 51单片机浮点数运算

这三个正是嵌入式发展的三个分支。单片机内部包含程序存储器,RAM,处理器等,用于处理较弱的处理要求,成本较低。

DSP用于数字信号处理器,侧重于于浮点运算,如图像处理,滤波处理等算法。

嵌入式微处理器如ARM7等处理器,主频较高,需外部接程序存储器,用于手机、路由等高级IT设备的开发。

3. 计算机一个浮点数

plc中浮点是指浮点数以及浮点计算。浮点型简单讲就是实数的意思。浮点数在计算机中用以近似表示任意某个实数。浮点计算是指浮点数参与浮点计算的运算,这种运算通常伴随着因为无法精确表示而进行的近似或舍入。

有理数中某特定子集的数的数字表示,在计算机中用以近似表示任意某个实数。

具体的说,这个实数由一个整数或定点数(即尾数)乘以某个基数(计算机中通常是2)的整数次幂得到,这种表示方法类似于基数为10的科学记数法。

4. 51单片机浮点数转字符串

C#中将byte[]转化为字符串可以参考以下的代码:

//字符串转bytestring StringMessage = "How Are you?"

;Console.WriteLine("{0}", StringMessage)

;System.Text.ASCIIEncoding ASCII = new System.Text.ASCIIEncoding()

;Byte[] BytesMessage = ASCII.GetBytes(StringMessage)

;//byte转字符串Byte[] BytesMessage;System.Text.ASCIIEncoding ASCII = new System.Text.ASCIIEncoding()

;String StringMessage = ASCII.GetString( BytesMessage );扩展资料:字符串的转换可以用 (string) 标记或者strval()函数将一个值转换为字符串。当某表达式需要字符串时,字符串的转换会在表达式范围内自动完成。

例如当使用echo()或者print()函数时,或者将一个变量值与一个字符串进行比较的时候。阅读手册中有关类型和类型戏法中的部分有助于更清楚一些。

整数或浮点数数值在转换成字符串时,字符串由表示这些数值的数字字符组成(浮点数还包含有指数部分)。

数组将被转换成字符串 "Array",因此无法通过echo()或者print()函数来输出数组的内容。

5. 单片机浮点数怎么取整

意思:实数的意思,float是C语言中的一个数据类型的关键字,表示单精度浮点型(双精度浮点型为double)。定义格式为:float a // a表示一个浮点型的变量。

C语言规定浮点型在内存占用4个字节,精度为7位,取值范围为:3.4*10^-38 ~3.4*10^38。

C语言是一门通用计算机编程语言,应用广泛。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。

C语言之所以命名为C,是因为 C语言源自Ken Thompson发明的B语言,而 B语言则源自BCPL语言。2011年12月8日,ISO又正式发布了新的标准,称为ISO/IEC9899: 2011,简称为C11。

尽管C语言提供了许多低级处理的功能,但仍然保持着良好跨平台的特性,以一个标准规格写出的C语言程序可在许多电脑平台上进行编译,甚至包含一些嵌入式处理器(单片机或称MCU)以及超级电脑等作业平台

6. 51单片机串口发送浮点数

你说的数字带小数点的,叫浮点数。小数点的数据用十六进制表示用4个字节。如果小数部分都是0,则可以用整数表示。例如:用长整型表示。long dat; //用于保存接收到的十六进制数dat=12345;万位数:ww = dat/10000;千位数:qw = dat%10000/1000;百位数:bw = dat%10000%1000/100;十位数:sw = dat%10000%1000%100/10;个位数:gw = dat%10000%1000%100%10;依次类推。

7. 通用微机和单片机都能支持浮点运算

在单片机的开发应用中,已逐渐开始引入高级语言,

C语言就是其中的一种。对用惯了汇编的人来说,总觉得高级语言’可控性’不好,不如汇编那样随心所欲。

但是只要我们掌握了一定的C语言知识,有些东西还是容易做出来的,以下是笔者实际工作中遇到的几个问题,希望对初学C51者有所帮助。

一、C51热启动代码的编制

对于工业控制计算机,往往设有有看门狗电路,当看门狗动作,使计算机复位,这就是热启动。

热启动时,一般不允许从头开始,这将导致现有的已测量到或计算到的值复位,导致系统工作异常。

因而在程序必须判断是热启动还是冷启动,常用的方法是:确定某内存单位为标志位(如0x7f位和0x7e位),

启动时首先读该内存单元的内容,如果它等于一个特定的值(例如两个内存单元的都是0xaa),就认为是热启动,

否则就是冷启动,程序执行初始化部份,并将0xaa赋与这两个内存单元。

根据以上的设计思路,编程时,设置一个指针,让其指向特定的内存单元如0x7f,然后在程序中判断,程序如下:

void main()

{ char data *HotPoint=(char *)0x7f;

if((*HotPoint==0xaa)&&(*(--HotPoint)==0xaa))

{ /*热启动的处理 */

}

else

{ HotPoint=0x7e; /*冷启动的处进

*HotPoint=0xaa;

*(++HotPoint)=0xaa;

}

/*正常工作代码*/

}

然而实际调试中发现,无论是热启动还是冷启动,开机后所有内存单元的值都被复位为0,当然也实现不了热启动的要求。这是为什么呢?原来,用C语言编程时,开机时执行的代码并非是从main()函数的第一句语句开始的,在main()函数的第一句语句执行前要先执行一段’起始代码’。正是这段代码执行了清零的工作。C编译程序提供了这段起始代码的源程序,名为CSTARTUP.A51,打开这个文件,可以看到如下代码:

.

IDATALEN EQU 80H ; the length of IDATA memory in bytes.

.

STARTUP1:

IF IDATALEN <> 0

MOV R0,#IDATALEN - 1

CLR A

IDATALOOP: MOV @R0,A

DJNZ R0,IDATALOOP

ENDIF

.

可见,在执行到判断是否热启动的代码之前,起始代码已将所有内存单元清零。如何解决这个问题呢?好在启动代码是可以更改的,方法是:修改startup.a51源文件,然后用编译程序所附带的a51.exe程序对 startup.a51编译,得到startup.obj文件,然后用这段代码代替原来的起始代码。具体步骤是(设C源程序名为HOTSTART.C):

修改startup.a51源文件(这个文件在C51LIB目录下)。

 

 

执行如下命令:

 

A51 startup.a51 得到startup.obj文件。将此文件拷入HOTSTART.C所在目录。

将编好的C源程序用C51.EXE编译好,得到目标文件HOTS

TART.OBJ。

 

用 L51 HOTSTART, STARTUP.OBJ 命令连接,得到绝对目标文件HOTSTART。

 

用 OHS51 HOTSTART 得到HOTSTART.HEX文件,即可。

 

对于startup.a51的修改,根据自已的需要进行,如将IDATALEN EQU 80H中的80H改为70H,就可以使6F到7F的16字节内存不被清零。

二、直接调用EPROM中已固化的程序

笔者用的仿真机,由6位数码管显示,在内存DE00H处放显示子程序,只要将要显示的数放入显示缓冲区,然后调用这个子程序就可以使用了,汇编指令为:

LCALL 0DEOOH

在用C语言编程时,如何实现这一功能呢?C语言中有指向函数的指针这一概念,可以利用这种指针来实现用函数指针调用函数。指向函数的指针变量的定义格式为:

类型标识符 (*指针变量名)();

在定义好指针后就可以给指针变量赋值,使其指向某个函数的开始存地址,然后用

(*指针变量名)()即可调用这个函数。如下例:

void main(void)

{

void (*DispBuffer)(); /*定义指向函数指针*/

DispBuffer=0xde00; /*赋值*/

for(;;)

{ Key();

DispBuffer();

}

}

三、将浮点数转化为字符数组

笔者在编制应用程序时有这样的要求:将运算的结果(浮点数)存入EEPROM中。我们知道,浮点数在C语言中是以IEEE格式存储的,一个浮点数占用四个字节,例如浮点数34.526存为(160,26,10,66)这四个数。要将一个浮点数存入EEPROM,实际上就是要存这四个数。那么如何在程序中得到一个浮点数的组成数呢?

浮点数在存储时,是存储连续的字节中的,只要设法找到存储位置,就可以得到这些数了。可以定义一个void的指针,将此指针指向需要存储的浮点数,然后将此指针强制转化为char型,这样,利用指针就可以得到组成该浮点数的各个字节的值了。具体程序如下:

#define uchar unsigned char#define uint unsigned intvoid FtoC(void)

{ float a;

uchar i,*px

uchar x[4]; /*定义字符数组,准备存储浮点数的四个字节*、

void *pf;

px=x; /*px指针指向数组x*/

pf=&a; /*void 型指针指向浮点数首地址*/

a=34.526;

for(i=0;i<4;i++)

{ *(px+i)=*((char *)pf+i); /*强制void 型指针转成char型,因为*/

} /*void型指针不能运算*/

}

如果已将数存入EEPROM,要将其取出合并,方法也是一样,可参考下面的程序。

#define uchar unsigned char#define uint unsigned int

void CtoF(void)

{ float a;

uchar i,*px

uchar x[4]={56,180,150,73};

void *pf;

px=x;

pf=&a;

for(i=0;i<4;i++)

{ *((char *)pf+i)=*(px+i);

}

}

以上所用C语言为FRANKLIN C51 VER 3.2。

8. 51单片机浮点型

C语言中,变量一般有两种属性,分别是:存储类别、数据类型。

例如定义一个变量:static unsigned char var = 0; 上述语句中,static(静态的)为变量的存储类别,unsigned char(无符号字符型)为变量的数据类型,var为变量名,初始化值为0。

下面给你说明几点。

存储类别:即变量在代码运行期间的存储方式。c语言提供了4种,分别是:auto(自动的)、static(静态的)、extern(外部的)、register(寄存器的)。

默认情况下,如果不加存储类别,则该变量是auto类的,该关键字可以省略,其它三个不能省。static的用法是,定义一个局部变量,该变量只进行一次初始化,在程序运行期间一直占用着内存,每次调用完毕都保持本次调用完后得到的值(而auto调用完一次即释放内存,下次调用用从新进行初始化)。extern:

一个变量被定义成全局变量,加上该关键字,意思是提醒编译器,该变量是在别的C文件中(即你想再一个C文件中调用另外一个C文件的变量,需用该关键字进行引入)。register:定义一个变量为该存储类型,建议编译器将该变量存放在CUP内部寄存器中,以便该变量频繁调用而提高代码运行速度。注意,它是建议型的,一般用在循环次数多的地方,因为变量一般存放在内存中,每次CUP访问它都得跑到内存去提取,次数多了,影响运行速度。放在内部寄存器就快多了(当然放不放我们不知道,只是建议编译器这么做),这种变量也是用完就释放。

数据类型:C语言提供了三种基本数据类型:char型 int型 float型。

默认情况下,char/int/float是指有符号的,即前面都省略了signed关键字,如果需要定义成无符号型的,需在前面加上不可省略的unsigned关键字。char占一个字节,int占2个字节(在有的环境下是4个字节),float占4个。表示的数据范围也比较明确,char一个字节8位

,共256种状态,有符号的最高位表示符号,0为正,1为负,其余7位表示数字位,2的7次方。int型16位 的,一样。float型的数据必须要有小数点,一般float能表示6~7位有效数字。上述的数据类型中,如果范围还不够大,还可以定义成long型,即长整型,占4个字节,而浮点型可以定义成double型,可以表示16~17为小数,当然,它也只占四个字节。

其它还有指针型的变量,还有构造型的如结构体、共同体、枚举等等。学单片机的还有bit型的。C语言概念很多,但都很简单。重点是在用。世界上没有纯记忆的技术,只有一边用一边记忆的技术。

9. 单片机 浮点数

一、可以提高电脑水平。

  学习PLC编程,首先要学会各种PLC、触摸屏软件安装和卸载,打字当然也是必不可少的要求,软件中的菜单的应用相当于把电脑的基础知识好好的学习了一番,一些人用电脑只会用鼠标点击,久而久之,这其实还是电脑盲,而学好PLC编程,键盘鼠标都要配合使用。在电脑硬件方面,电脑配置要求,串口以及外置接口在学习中自然而然学好了。

二、自然而然也学好了英语。

  PLC软件里面的指令LD(load),OR,ANB(andblock)、SET、DMOV(doublemove)以及英文帮助文件和英文手册让你不得不把这些单词和专业英语记住记牢。

三、等于使你的计算机语言和单片机编程语言知识入了门。

  PLC的助记符(指令表).ST高级编程语言和触摸屏的宏指令、D脚本其实就是计算机C语言、单片机汇编语言的雏形,很多指令代码的作用和效果都是一样的,PLC编程里面用到的二进制、八进制、十进制、十六进制和位元件、字元件,数组、字节,16位二进制有符号整数,16位二进制无符号整数,32位浮点数等等这是计算机语言国际标准完全一样。

四、学会电工知识、电子技术。

  初学PLC编程的人员很大一部分都没有电工基础,不懂电子技术,但慢慢学习和应用之后,也学会了电路中的自锁、互锁,自保持,电子技术的与门,或门非门和PWM电路以及PLC输入电路中的源型漏型等等。

五、提高逻辑思维能力。

  编写一个完成、系统机械设备工程的电气程序,必须要做到对设备动作和工艺心中有数,为完成设备功能,先选择相关的电气材料及相关的元器件型号,画出电路图,接线安装,进行初步调试,程序编写、完善,设备的性能目的达到之后,要进行操作说明书编写,资料整理归档等等,同时在程序编写中应用到的各个变量之间的逻辑关系是否合理,有无矛盾,这都能提供编程学习者的逻辑思维能力。

六、触类旁通,机械、气动、液压、各种产品的生产工艺久而久之也会由陌生变熟悉,甚至精通。

  在和设备打交道中,少不了和这些接触,什么分割器,机械手,电缸,电磁阀、比例阀,变送器,液压传动等等以及设备的工艺流程、所保证的技术参数这些都必须要弄以明白,做到心中有数。

七、锻炼了自学能力。

  经常遇到学员或者想学习PLC编程的人员说,“我要学习欧姆龙PLC编程”,“我要学习台达PLC编程”,“我要学校松下PLC编程”、“我要学习伺服"等等,我一听就知道他们对编程还不明白或者是还没有深入到课程内容中去,以大多数成功学好编程人士为例,他们大多都是初学以三菱或者西门子、欧姆龙系列的一种plc开始,然后把一种类型的PLC原理弄明白了之后,其他类型的PLC也是基本上大同小异而异,这完全就等于学开车一样的,学会了一种汽车,其他汽车琢磨琢磨也会开

10. 51单片机支持浮点运算吗

普通的加减乘除,用一般的增强型51单片机或AVR单片机足矣 运算时间不到1 ms 如果进行三角函数运算,大约几ms 大量的浮点和三角函数运算建议用STM32单片机

顶一下
(0)
0%
踩一下
(0)
0%