- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
角度传感器程序总结
角度传感器程序总结
——电信101 吴超琼
角度传感器AS5045这种绝对角度测量方式可即时指出磁铁的角度位置,其分辨率达到0.0879°=每圈360°共4096个位置,能够以串行比特流及PWM信号输出的形式给出数字化数据。
2种数字式12位绝对值输出:
-串行接口输出
-脉冲调制(PWM)输出
该程序采用了串行接口输出12位绝对值输出。
角度传感器程序流程图如下:
AS5045采集得的数据是角度位置数据,要得到物体真正转过的角度就要进行计算,一圈360°,共4096个位置(5045芯片就是这样分配的),每个位置就有0.00879°,用读取AS5045得到的数据a乘以0.00879就得到我们所要求的角度。为了精确我们小数点后要有相应的有效数字,若有n位有效数字,就需要再乘以10n。例如:jiaodu=a*0.00879*10。
程序如下:
/*********通过AD转换和数字信号处理(DSP)算法**********/
/*********AS5045可提供精确的高分辨率*******************/
/*********绝对角度位置信息*****************************/
/*********AS5045能够检测磁场的方向并计算出12位的二进制编码********
*********此编码通过同步串行接口(SSI)进行访问*****/
/**********屏蔽掉的程序是另一种算法差不多************************/
#includereg52.h
#includestdlib.h
#include intrins.h
#define uchar unsigned char
#define uint unsigned int
/******液晶引脚定义******/
sbit RST=P0^0;
sbit PSB=P0^1;
sbit E=P0^5;
sbit RW=P0^6;
sbit RS=P0^7;
//用了并行PSB=1,数据口用P2
/*****AS5045引脚定义**************/
sbit D0=P3^2; //同步串行接口的数据输出
sbit CLK=P3^3; //同步串行接口的时钟输入
sbit CSn=P3^4; //片选,低电平有效,施密特触发器输入,内部上拉电阻
uint dd; //算得的最终角度
//float cc;
uint out,bb; //out为获取得的角度信息(绝对角度位置数据)D[11:0] 串行字包括18位数据,前12位是角度信息
uint dis0[7]; //用来存放角度数据
uchar code tab[]={角度传感器实验};
uchar code dis1[]={当前角度: };
uchar code dis2[]={.};
void delay(uint z)
{
uint x,y;
for(y=110;y0;y--)
for(x=z;x0;x--);
}
/*******读取忙状态****/
bit lcd_busy()
{
bit result;
RS=0;
RW=1;
E=1;
delay(5);
result=(bit)(P20X80);
E=0;
return(result);
}
/******写指令*******/
void write_com(uchar com)
{
while(lcd_busy());
RS=0;
RW=0;
P2=com;
delay(5);
E=1;
delay(5);
E=0;
delay(5); }
/******写数据*******/
void write_data(uchar dat)
{
while(lcd_busy());
RS = 1;
RW = 0;
E = 0;
P2 = dat;
delay(5);
E = 1;
delay(5);
E = 0;
}
//****液晶初始化******//
void lcd_init()
{
PSB = 1; //并行口
RST = 0; //复位
delay(5);
RST = 1;
delay(5);
write_com(0x30); //基本指令操作
delay(5);
文档评论(0)