智能车学习(十一)——陀螺仪学习
一、学习说明
感觉就是配置I2C通信,然后直接移植51代码。。。
二、代码分享:
1、头文件:
#ifndef I2C_GYRO_H_
#define I2C_GYRO_H_ /***********函数声明***********/ extern void Gyro_Init(void);
extern void Read_GY(void); /*****************************/ /***********全局变量声明***********/ extern float Gyro_X ;
extern float Gyro_Y ;
extern float Gyro_Z ; /*********************************/ #endif
2、源文件:
#include "include.h"
#include "common.h"
#include "gpio.h"
#include "I2C_GYRO.h"
#include "lptmr.h" /***********管脚声明***********/ #define L3G_S_I2C_SDA (PTE21)//(PTB3)//(PTE0) //(PTE22)//(PTC1)//
#define L3G_S_I2C_SCL (PTE5)//(PTB2)//(PTE1)//(PTE20)//(PTC0)// /*****************************/ //IO方向设置
#define L3G_I2C_SDA_IN() DDRE21 = 0//输入模式
#define L3G_I2C_SDA_OUT() DDRE21 = 1//输出模式 //IO操作函数
#define L3G_I2C_SCL PTE5_OUT //SCL
#define L3G_I2C_SDA PTE21_OUT //SDA
#define L3G_I2C_READ_SDA PTE21_IN //输入SDA /***********全局变量声明***********/
float Gyro_X = 0;
float Gyro_Y = 0;
float Gyro_Z = 0;
/********************************/ //**********L3G4200D内部寄存器地址*********
#define L3G_WHO_AM_I 0x0F
#define L3G_CTRL_REG1 0x20
#define L3G_CTRL_REG2 0x21
#define L3G_CTRL_REG3 0x22
#define L3G_CTRL_REG4 0x23
#define L3G_CTRL_REG5 0x24
#define L3G_REFERENCE 0x25
#define L3G_OUT_TEMP 0x26
#define L3G_STATUS_REG 0x27
#define L3G_OUT_X_L 0x28
#define L3G_OUT_X_H 0x29
#define L3G_OUT_Y_L 0x2A
#define L3G_OUT_Y_H 0x2B
#define L3G_OUT_Z_L 0x2C
#define L3G_OUT_Z_H 0x2D
#define L3G_FIFO_CTRL_REG 0x2E
#define L3G_FIFO_SRC_REG 0x2F
#define L3G_INT1_CFG 0x30
#define L3G_INT1_SRC 0x31
#define L3G_INT1_TSH_XH 0x32
#define L3G_INT1_TSH_XL 0x33
#define L3G_INT1_TSH_YH 0x34
#define L3G_INT1_TSH_YL 0x35
#define L3G_INT1_TSH_ZH 0x36
#define L3G_INT1_TSH_ZL 0x37
#define L3G_INT1_DURATION 0x38
//****************************************
#define L3G_SlaveAddress 0xD2 //定义器件在IIC总线中的从地址,根据ALT ADDRESS地址引脚不同修改
#define L3G_SlaveAddfire 0x69 //定义器件在IIC总线中的从地址,根据ALT ADDRESS地址引脚不同修改 //============================================================================
//函数名称:void L3G_I2C_Config(void)
//函数返回:无
//参数说明:无
//功能概要:配置I2C管脚
//============================================================================
void L3G_I2C_Config(void)
{
//L3G_I2C_SDA_OUT();
gpio_init(L3G_S_I2C_SDA,GPO,0);
gpio_init(L3G_S_I2C_SCL,GPO,1); L3G_I2C_SCL=1;
L3G_I2C_SDA=1;
} //============================================================================
//函数名称:void L3G_I2C_Start(void)
//函数返回:无
//参数说明:无
//功能概要:I2C启动
//============================================================================
void L3G_I2C_Start(void)
{
L3G_I2C_SDA_OUT();
L3G_I2C_SDA=1;
L3G_I2C_SCL=1;
lptmr_delay_us(1);
L3G_I2C_SDA=0;
lptmr_delay_us(1);
L3G_I2C_SCL=0;
} //============================================================================
//函数名称:void L3G_I2C_Stop(void)
//函数返回:无
//参数说明:无
//功能概要:I2C停止
//============================================================================
void L3G_I2C_Stop(void)
{
L3G_I2C_SDA_OUT();
L3G_I2C_SDA=0;
L3G_I2C_SCL=1;
lptmr_delay_us(1);
L3G_I2C_SDA=1;
lptmr_delay_us(1);
L3G_I2C_SCL=0;
} //============================================================================
//函数名称:void L3G_I2C_Mack(void)
//函数返回:无
//参数说明:无
//功能概要:
//============================================================================
void L3G_I2C_Mack(void)
{
L3G_I2C_SDA_OUT();
L3G_I2C_SDA=0;
L3G_I2C_SCL=1;
lptmr_delay_us(1);
L3G_I2C_SCL=0;
L3G_I2C_SDA=1;
} //============================================================================
//函数名称:void L3G_I2C_Mnack(void)
//函数返回:无
//参数说明:无
//功能概要:读取完的完成停顿信号
//============================================================================
void L3G_I2C_Mnack(void)
{
L3G_I2C_SDA_OUT();
L3G_I2C_SDA=1;
lptmr_delay_us(1);
L3G_I2C_SCL=1;
lptmr_delay_us(1);
L3G_I2C_SCL=0;
lptmr_delay_us(1);
//L3G_I2C_SDA=0;
} //============================================================================
//函数名称:uint8_t L3G_I2C_Cack(void)
//函数返回:无
//参数说明:无
//功能概要:发送间隔函数
//============================================================================
uint8_t L3G_I2C_Cack(void)
{
L3G_I2C_SDA_IN();
L3G_I2C_SCL=0;
lptmr_delay_us(1);
L3G_I2C_SCL=1;
lptmr_delay_us(1);
if(L3G_I2C_READ_SDA)
{
//L3G_I2C_Stop();
//return 0xff;
}
L3G_I2C_SCL=0;
L3G_I2C_SDA_OUT();
return 0;
} //============================================================================
//函数名称:void L3G_I2C_WriteByte(unsigned char data)
//函数返回:无
//参数说明:无
//功能概要:I2C发送一个字节的数据
//============================================================================
void L3G_I2C_WriteByte(unsigned char data)
{
unsigned char i=8;
L3G_I2C_SDA_OUT();
while(i--)
{
lptmr_delay_us(1);
if(data & 0x80)
L3G_I2C_SDA=1;
else
L3G_I2C_SDA=0;
lptmr_delay_us(1);
L3G_I2C_SCL=1;
lptmr_delay_us(1);
L3G_I2C_SCL=0;
data<<=1;
}
} //============================================================================
//函数名称:uint8_t L3G_I2C_ReadByte(void)
//函数返回:无
//参数说明:无
//功能概要:I2C接收一个字节的数据
//============================================================================
uint8_t L3G_I2C_ReadByte(void)
{
unsigned char i;
unsigned char data=0;
char temp;
L3G_I2C_SDA_IN();
for(i=0;i<8;i++)
{
data<<=1;
lptmr_delay_us(1);
L3G_I2C_SCL=1;
temp=L3G_I2C_READ_SDA;
if(temp)
data++;
lptmr_delay_us(1);
L3G_I2C_SCL=0;
}
return data;
} //============================================================================
//函数名称:uint8_t L3G_I2C_WR_REG(uint8_t dev_addr, uint8_t reg_addr, uint8_t writeData)
//函数返回:无
//参数说明:无
//功能概要:I2C向一个地址写一个数据
//============================================================================
uint8_t L3G_I2C_WR_REG(uint8_t dev_addr, uint8_t reg_addr, uint8_t writeData)
{
L3G_I2C_Start();
L3G_I2C_WriteByte(dev_addr);
L3G_I2C_Cack();
L3G_I2C_WriteByte(reg_addr);
L3G_I2C_Cack();
L3G_I2C_WriteByte(writeData);
L3G_I2C_Cack();
L3G_I2C_Stop(); return 0;
} //============================================================================
//函数名称:uint8_t L3G_I2C_RD_REG(uint8_t dev_addr, uint8_t reg_addr)
//函数返回:无
//参数说明:无
//功能概要:I2C从一个地址读一个数据
//============================================================================
uint8_t L3G_I2C_RD_REG(uint8_t dev_addr, uint8_t reg_addr)
{
uint8_t read_reg = 0;
L3G_I2C_Start();
L3G_I2C_WriteByte(dev_addr);
L3G_I2C_Cack();
L3G_I2C_WriteByte(reg_addr);
L3G_I2C_Cack();
L3G_I2C_Start();
L3G_I2C_WriteByte(dev_addr + 1);
L3G_I2C_Cack();
read_reg = L3G_I2C_ReadByte();
L3G_I2C_Mnack();
L3G_I2C_Stop(); return read_reg;
} //============================================================================
//函数名称:uint8_t L3G_I2C_RD_Buffer(uint8_t dev_addr, uint8_t reg_addr, uint8_t data_num, uint8_t *readBuffer)
//函数返回:无
//参数说明:无
//功能概要:I2C向一个地址写一连串数据
//============================================================================
uint8_t L3G_I2C_RD_Buffer(uint8_t dev_addr, uint8_t reg_addr, uint8_t data_num, uint8_t *readBuffer)
{
uint8_t i = 0;
L3G_I2C_Start();
L3G_I2C_WriteByte(dev_addr);
L3G_I2C_Cack();
L3G_I2C_WriteByte(reg_addr);
L3G_I2C_Cack();
L3G_I2C_Start();
L3G_I2C_WriteByte(dev_addr + 1);
L3G_I2C_Cack(); for(i = 0; i < data_num; i++){
*(readBuffer+i) = L3G_I2C_ReadByte();
if(i == data_num - 1)
L3G_I2C_Mnack();
else
L3G_I2C_Mack();
}
L3G_I2C_Stop(); return 0;
} //============================================================================
//函数名称:void Gyro_Init( __RAMFUNC void)
//函数返回:无
//参数说明:无
//功能概要://初始化为指定模式
//============================================================================
void Gyro_Init(void)
{
L3G_I2C_Config();
L3G_I2C_WR_REG(L3G_SlaveAddress,L3G_CTRL_REG1,0xcf); //数据手册30 0xbf 400hz 20~110截止频率
L3G_I2C_WR_REG(L3G_SlaveAddress,L3G_CTRL_REG2,0x20);//前两位00,后两位高通滤波器模式选择,后四位截止频率 0x29
L3G_I2C_WR_REG(L3G_SlaveAddress,L3G_CTRL_REG3,0x00);
L3G_I2C_WR_REG(L3G_SlaveAddress,L3G_CTRL_REG4,0x30);
L3G_I2C_WR_REG(L3G_SlaveAddress,L3G_CTRL_REG5,0x00);
} //============================================================================
//函数名称:void Read_GY(void)
//函数返回:无
//参数说明:无
//功能概要:陀螺仪传感器测量值读取接口
//============================================================================ uint8_t tmpBuffer[6] = {0}; void Read_GY(void)
{
//int16_t x_h = 0,x_l = 0,y_l = 0,y_h = 0,z_h = 0,z_l = 0;//Gyro_X = 0,Gyro_Y = 0,Gyro_Z = 0;
//Gyro_Init();
L3G_I2C_RD_Buffer(L3G_SlaveAddress,0xA8,6,tmpBuffer); /*
Gyro_X = ((short)((tmpBuffer[1]<<8)|tmpBuffer[0]))>>2;// 14位精度 Gyro_Y = ((short)((tmpBuffer[3]<<8)|tmpBuffer[2]))>>2;// 14位精度 Gyro_Z = ((short)((tmpBuffer[5]<<8)|tmpBuffer[4]))>>2;// 14位精度
*/ int temp; temp = ((short)((tmpBuffer[1]<<8)|tmpBuffer[0]))>>4;//2;// 14位精度 1g数值为1024(原本为4096,但是右移了(无效位2位)(有效位14位)两位)
Gyro_X = (double)Gyro_X*0.5+(double)temp*0.5; temp = ((short)((tmpBuffer[3]<<8)|tmpBuffer[2]))>>4;//2;// 14位精度
Gyro_Y = (double)Gyro_Y*0.5+(double)temp*0.5; temp = ((short)((tmpBuffer[5]<<8)|tmpBuffer[4]))>>4;//2;// 14位精度
Gyro_Z = (double)Gyro_Z*0.5+(double)temp*0.5;
}
智能车学习(十一)——陀螺仪学习的更多相关文章
- 智能车学习(十五)——K60野火2013版例程
一.中断函数注册方法: 1.格式: 配置某个功能的中断 注册中断函数 开启中断 2.一个例子 pit_init_ms(PIT0,);//定时中断初始化 set_vector_handler(PIT0_ ...
- 201521123061 《Java程序设计》第十一周学习总结
201521123061 <Java程序设计>第十一周学习总结 1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容. 本周学习的是如何解决多线程访问中的互斥 ...
- 201521123072《java程序设计》第十一周学习总结
201521123072<java程序设计>第十一周学习总结 1. 本周学习总结 2. 书面作业 本次PTA作业题集多线程 互斥访问与同步访问 完成题集4-4(互斥访问)与4-5(同步访问 ...
- 201521123038 《Java程序设计》 第十一周学习总结
201521123038 <Java程序设计> 第十一周学习总结 1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容. 2. 书面作业 本次PTA作业题集多 ...
- 杨其菊/常惠琢《面向对象程序设计(java)》第十一周学习总结
<面向对象程序设计>第十一周学习总结 第一部分:理论知识 JAVA的集合框架 JAVA的集合框架实现对各种数据结构的封装,以降低对数据管理与处理的难度. 所谓框架就是一个类库的集合,框 ...
- 【转载】 强化学习(十一) Prioritized Replay DQN
原文地址: https://www.cnblogs.com/pinard/p/9797695.html ------------------------------------------------ ...
- “2017面向对象程序设计(Java)第十一周学习总结”存在问题的反馈及教学安排
“2017面向对象程序设计(Java)第十一周学习总结”存在问题的反馈及教学安排1.“提出表扬的同学:姜依萍,王雪玲,徐楠,相文君,赵晓未提交作业的同学:任红强,王瑞强,宗鹏新,扎西才让,布旦刀杰,范 ...
- 20172325 2017-2018-2 《Java程序设计》第十一周学习总结
20172325 2017-2018-2 <Java程序设计>第十一周学习总结 教材学习内容总结 Android简介 Android操作系统是一种多用户的Linux系统,每个应用程序作为单 ...
- 20172330 2017-2018-1 《Java程序设计》第十一周学习总结
20172330 2017-2018-1 <程序设计与数据结构>第十一周学习总结 教材学习内容总结 本周的学习内容为集合 Android简介 Android操作系统是一种多用户的Linux ...
- 孤荷凌寒自学python第八十一天学习爬取图片1
孤荷凌寒自学python第八十一天学习爬取图片1 (完整学习过程屏幕记录视频地址在文末) 通过前面十天的学习,我已经基本了解了通过requests模块来与网站服务器进行交互的方法,也知道了Beauti ...
随机推荐
- jQuery获取循环中的选中单选按钮radio的值
1.<input type="radio" name="testradio" value="jquery获取radio的值" /> ...
- 数组里的数据绑定到dataset中
string [] an = {"a","b","c"};DataTable dt = new DataTable(); dt.Column ...
- 【编程题目】查找最小的 k 个元素
5.查找最小的 k 个元素(数组)题目:输入 n 个整数,输出其中最小的 k 个.例如输入 1,2,3,4,5,6,7 和 8 这 8 个数字,则最小的 4 个数字为 1,2,3 和 4. 算法里面学 ...
- 【linux】英文显示乱码解决
在linux环境中中文显示正常,而英文却显示乱码 用 echo $LANG 显示编码为 zh_CN.GB18030 解决方法: 输入 export LC_ALL=POSIX 即可
- (2016弱校联盟十一专场10.2) E.Coins
题目链接 很久之前写的了,好像是对拍打表过的,推一下就行了. #include <bits/stdc++.h> using namespace std; typedef long long ...
- CodeForces 407B Long Path (DP)
题目链接 题意:一共n+1个房间,一个人从1走到n+1,如果第奇数次走到房间i,会退回到房间Pi,如果偶数次走到房间i,则走到房间i+1,问走到n+1需要多少步,结果对1e9+7取模. 题解:设dp[ ...
- vs win32 & MFC 指针默认位置
一开始win32指针所在的位置是与debug文件夹同级的.即打开打开改程序的第一个文件夹这一级. MFC指针是在第二个debug下头,就是打开第二个project名词的文件夹下头,e.g., &quo ...
- 备忘zookeeper(单机+伪集群+集群)
#下载: #单机模式 解压到合适目录. 进入zookeeper目录下的conf子目录, 复制zoo_sample.cfg-->zoo.cfg(如果没有data和logs就新建):tickTime ...
- 关于jQuery新的事件绑定机制on()的使用技巧
关于jQuery新的事件绑定机制on()的使用技巧 http://www.jb51.net/article/36064.htm 本篇文章介绍了,关于jQuery新的事件绑定机制on()的使用技巧.需要 ...
- No space left on device you must specify the filesystem type--Linux重启挂在失败
在Linux中拷贝了一个文件比较大5G,直接提示:No SPace Left On Device,很明显是磁盘空间不够了,我因为是在虚拟机上面建的,直接右击虚拟机==>编辑设置 如图片1所示, ...