AK8975磁力计数据采集--模拟SPI读取

2023-10-08 17:20

本文主要是介绍AK8975磁力计数据采集--模拟SPI读取,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

AK8975磁力计数据采集–模拟SPI读取

1、ak8975磁力计特性

在这里插入图片描述

1.1 四种模式:

在这里插入图片描述

1.2 SPI读写时序

在这里插入图片描述
SPI工作在模式3
CSB拉低表示开启SPI数据读取模式, SK上升沿读取数据,下降沿数据进行变换

SPI写数据时序图
在这里插入图片描述
SPI读数据时序图
在这里插入图片描述

2、模拟SPI读取磁力计

AK8975寄存器地址

#define AK8975_WIA_REG          0X00 
#define AK8975_INFO_REG         0X01 
#define AK8975_ST1_REG          0X02 
#define AK8975_HXL_REG          0X03 
#define AK8975_HXH_REG          0X04
#define AK8975_HYL_REG          0X05
#define AK8975_HYH_REG          0X06
#define AK8975_HZL_REG          0X07
#define AK8975_HZH_REG          0X08
#define AK8975_ST2_REG          0X09 
#define AK8975_CNTL_REG         0X0A 
#define AK8975_RSV_REG          0X0B
#define AK8975_ASTC_REG         0X0C 
#define AK8975_TS1_REG          0X0D
#define AK8975_TS2_REG          0X0E
#define AK8975_I2CDIS_REG       0X0F 
#define AK8975_ASAX_REG         0X10 
#define AK8975_ASAY_REG         0X11
#define AK8975_ASAZ_REG         0X12

模拟SPI读写函数

/*******************************************************************************
** 名    称 : SPIReadWriteByte
** 功    能 : SPI 收发字节
** 入口参数 :txd:发送字节
** 出口参数 : rev:返回字节
*******************************************************************************/
unsigned char ak8975SPIReadWriteByte(unsigned char txd)
{    unsigned char i;  unsigned int rev = 0;AK8975_SK = 0;for(i=0; i<8; i++){       		if (txd&0x80){AK8975_SI = 1;delay_us(1);}else{AK8975_SI = 0;delay_us(1);}txd<<=1;AK8975_SK=1; //上升沿时读写数据, 下降沿时交换数据rev <<= 1;delay_us(1);if (AK8975_SO == 1) // 下降沿来临之前AK8975_SO还没有变{rev++;}AK8975_SK=0;    delay_us(1);}	return rev;
}

Ak8975数据读取函数

/*******************************************************************************
** 名    称 : AK8975_Read
** 功    能 : ak8975读取数据
** 入口参数 :reg: 寄存器地址  buf:存储读取到的字节数据  len:需要读取数据的长度
** 出口参数 : void
*******************************************************************************/
void AK8975_Read(u8 reg, u8 *ak8975_buf, u8 len)
{	AK8975_SK = 1;AK8975_CSB = 0;delay_us(1);ak8975SPIReadWriteByte(reg | 0x80); // 0写  1读    for(u8 i=0; i<len; i++){*ak8975_buf = ak8975SPIReadWriteByte(0xff); // 读ak8975_buf++;}AK8975_CSB = 1;delay_us(1);ak8975_Trig();
}/*******************************************************************************
** 名    称 : ak8975IdCheck
** 功    能 : ak8975读取ak8975的ID
** 入口参数 : void
** 出口参数 : 返回ID: 0x48
*******************************************************************************/
u8 ak8975IdCheck()
{u8 add;AK8975_SK = 1;AK8975_CSB = 0;ak8975SPIReadWriteByte(AK8975_WIA_REG|0x80); // 0写  1读    add = ak8975SPIReadWriteByte(0xff); // 读AK8975_SK = 1;AK8975_CSB = 1;delay_us(1);ak8975_Trig();return add;
}/*******************************************************************************
** 名    称 : ak8975_Trig
** 功    能 : ak8975状态切换: 每次读取完数据后,ak8975都会自动变为power-down模式,所以每次读完数据都需要重新设置成单次测量模式
** 入口参数 : void
** 出口参数 : void
*******************************************************************************/
void ak8975_Trig(void)
{AK8975_CSB = 0;ak8975SPIReadWriteByte(AK8975_CNTL_REG & 0x7f);ak8975SPIReadWriteByte(0x01);AK8975_CSB = 1;
}// 最终数据可以这样获取
Drv_AK8975_Read(AK8975_HXL_REG, ak8975_buf, 6);  // 连续读6个字节数据
// 磁数据 数字量
mag_x =  (((int16_t)ak8975_buf[1]) << 8) | ak8975_buf[0];
mag_y =  (((int16_t)ak8975_buf[3]) << 8) | ak8975_buf[2];
mag_z =  (((int16_t)ak8975_buf[5]) << 8) | ak8975_buf[4];**mag_x、mag_y 、mag_z  为采集的数字量,datasheet中提到分辨率为0.3uT/LSB
实际数据 = mag_x * 0.3  单位uT       1uT = 10mG(毫高斯)  
实际数据 = mag_x * 0.3 * 10   单位mG
注意:每次读取的间隔需要*20ms*左右(经验值), 具体可以通过读取DRDY位来判断数据是否就绪**

3、总结

由于个人水平有限,如有错误,欢迎指正。
需要源代码的可以下方留言,留下邮箱即可。

这篇关于AK8975磁力计数据采集--模拟SPI读取的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/166823

相关文章

Qt实现对Word网页的读取功能

《Qt实现对Word网页的读取功能》文章介绍了几种在Qt中实现Word文档(.docx/.doc)读写功能的方法,包括基于QAxObject的COM接口调用、DOCX模板替换及跨平台解决方案,重点讨论... 目录1. 核心实现方式2. 基于QAxObject的COM接口调用(Windows专用)2.1 环境

MySQL数据目录迁移的完整过程

《MySQL数据目录迁移的完整过程》文章详细介绍了将MySQL数据目录迁移到新硬盘的整个过程,包括新硬盘挂载、创建新的数据目录、迁移数据(推荐使用两遍rsync方案)、修改MySQL配置文件和重启验证... 目录1,新硬盘挂载(如果有的话)2,创建新的 mysql 数据目录3,迁移 MySQL 数据(推荐两

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

MySQL快速复制一张表的四种核心方法(包括表结构和数据)

《MySQL快速复制一张表的四种核心方法(包括表结构和数据)》本文详细介绍了四种复制MySQL表(结构+数据)的方法,并对每种方法进行了对比分析,适用于不同场景和数据量的复制需求,特别是针对超大表(1... 目录一、mysql 复制表(结构+数据)的 4 种核心方法(面试结构化回答)方法 1:CREATE

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

MySQL中的DELETE删除数据及注意事项

《MySQL中的DELETE删除数据及注意事项》MySQL的DELETE语句是数据库操作中不可或缺的一部分,通过合理使用索引、批量删除、避免全表删除、使用TRUNCATE、使用ORDERBY和LIMI... 目录1. 基本语法单表删除2. 高级用法使用子查询删除删除多表3. 性能优化策略使用索引批量删除避免

MySQL 数据库进阶之SQL 数据操作与子查询操作大全

《MySQL数据库进阶之SQL数据操作与子查询操作大全》本文详细介绍了SQL中的子查询、数据添加(INSERT)、数据修改(UPDATE)和数据删除(DELETE、TRUNCATE、DROP)操作... 目录一、子查询:嵌套在查询中的查询1.1 子查询的基本语法1.2 子查询的实战示例二、数据添加:INSE

在C#中读取文件的六种主流方法详解

《在C#中读取文件的六种主流方法详解》在C#中读取文件有多种方法,不同方式适用于不同场景(小型文件、大型文件、文本文件或二进制文件),本文给大家介绍了6种主流方法以及其适用场景,需要的朋友可以参考下... 目录方法1:File.ReadAllText(读取整个文本文件)方法2:File.ReadAllLin

Linux服务器数据盘移除并重新挂载的全过程

《Linux服务器数据盘移除并重新挂载的全过程》:本文主要介绍在Linux服务器上移除并重新挂载数据盘的整个过程,分为三大步:卸载文件系统、分离磁盘和重新挂载,每一步都有详细的步骤和注意事项,确保... 目录引言第一步:卸载文件系统第二步:分离磁盘第三步:重新挂载引言在 linux 服务器上移除并重新挂p

使用MyBatis TypeHandler实现数据加密与解密的具体方案

《使用MyBatisTypeHandler实现数据加密与解密的具体方案》在我们日常的开发工作中,经常会遇到一些敏感数据需要存储,比如用户的手机号、身份证号、银行卡号等,为了保障数据安全,我们通常会对... 目录1. 核心概念:什么是 TypeHandler?2. 实战场景3. 代码实现步骤步骤 1:定义 E