當(dāng)前位置:首頁 > 芯聞號(hào) > 充電吧
[導(dǎo)讀]之前使用的是ADXL362測(cè)量加速度,功耗特別低,使用的還可以,但是后來用于測(cè)量角度時(shí)誤差特別大,最終更換為MMA8452Q ,這個(gè)芯片較便宜,測(cè)量設(shè)備靜態(tài)的傾角,還是蠻好用的,我的使用中只需要測(cè)量Z

之前使用的是ADXL362測(cè)量加速度,功耗特別低,使用的還可以,但是后來用于測(cè)量角度時(shí)誤差特別大,最終更換為MMA8452Q ,這個(gè)芯片較便宜,測(cè)量設(shè)備靜態(tài)的傾角,還是蠻好用的,我的使用中只需要測(cè)量Z軸的傾角。

/*************************************************************************************************************
?*?文件名:			MMA8452Q.c
?*?功能:			MMA8452Q驅(qū)動(dòng)
?*?作者:			cp1300@139.com
?*?創(chuàng)建時(shí)間:		2018-04-09
?*?最后修改時(shí)間:	2018-04-09
?*?詳細(xì):			MMA8452Q三軸加速度傳感器
					依賴SoftwareIIC
*************************************************************************************************************/
#include?"system.h"
#include?"MMA8452Q.h"
#include?"math.h"
#include#include?"SoftwareIIC.h"

//調(diào)試宏開關(guān)
#define?MMA8452Q_DBUG	1
#if?MMA8452Q_DBUG
	#include?"system.h"
	#define?MMA8452Q_Debug(format,...)	uart_printf(format,##__VA_ARGS__)
#else
	#define?MMA8452Q_Debug(format,...)	/
/
#endif	//MMA8452Q_DBUG


#define?PI?3.1415926535898

u8?MMA8452Q_ReadOneReg(MMA8452Q_HANDLE?*pHandle,u8?RegAddr);								//MMA8452Q讀取一個(gè)寄存器
void?MMA8452Q_ReadMultReg(MMA8452Q_HANDLE?*pHandle,u8?RegAddr,?u8?RegNum,?u8?DataBuff[]);	//MMA8452Q讀取多個(gè)寄存器
void?MMA8452Q_WriteOneReg(MMA8452Q_HANDLE?*pHandle,u8?RegAddr,u8?data);						//MMA8452Q寫一個(gè)寄存器


/*************************************************************************************************************************
*函數(shù)????????	:	bool?MMA8452Q_Init(MMA8452Q_HANDLE?*pHandle,?u8?SlaveAddr)
*功能????????	:	MMA8452Q初始化
*參數(shù)????????	:	pHandle:句柄;SlaveAddr:芯片IIC地址
*返回????????	:	TRUE:初始化成功;FALSE:初始化失敗
*依賴			:?	底層宏定義
*作者???????	:	cp1300@139.com
*時(shí)間?????		:	2018-04-09
*最后修改時(shí)間	:	2018-04-09
*說明????????	:	
*************************************************************************************************************************/
bool?MMA8452Q_Init(MMA8452Q_HANDLE?*pHandle,?u8?SlaveAddr)
{
	u8?temp;
	
	if(pHandle?==?NULL)?return?FALSE;
	pHandle->SlaveAddr?=?SlaveAddr;
	
	
	MMA8452Q_WriteOneReg(pHandle,?0x2A,?0x01);
	MMA8452Q_WriteOneReg(pHandle,?0x2B,?0x02);
	temp?=?MMA8452Q_ReadOneReg(pHandle,?0x0D);	//讀取器件ID
	if(temp?!=?0x2A)	//ID不對(duì)
	{
		uart_printf("初始化失敗,ID錯(cuò)誤:0x%02Xrn",?temp);
		return?FALSE;
	}
	uart_printf("ID:0x%02Xrn",?temp);
	
	return?TRUE;
}


/*************************************************************************************************************************
*函數(shù)????????	:	u8?MMA8452Q_ReadOneReg(MMA8452Q_HANDLE?*pHandle,u8?RegAddr)
*功能????????	:	MMA8452Q讀取一個(gè)寄存器
*參數(shù)????????	:	pHandle:句柄;RegAddr:寄存器地址
*返回????????	:	讀取的寄存器值
*依賴			:?	底層宏定義
*作者???????	:	cp1300@139.com
*時(shí)間?????		:	2018-04-09
*最后修改時(shí)間	:	2018-04-09
*說明????????	:	
*************************************************************************************************************************/
u8?MMA8452Q_ReadOneReg(MMA8452Q_HANDLE?*pHandle,u8?RegAddr)
{
	u8?data;
	
	SIIC_Start(&pHandle->IIC_Handle);								//產(chǎn)生IIC起始信號(hào)
	if(SIIC_SendByte(&pHandle->IIC_Handle,?pHandle->SlaveAddr)?==?FALSE)	//發(fā)送設(shè)備地址+寫信號(hào)
	{
		DEBUG("沒有收到ACKrn");
	}
	SIIC_SendByte(&pHandle->IIC_Handle,?RegAddr);					//發(fā)送寄存器地址
	SIIC_Start(&pHandle->IIC_Handle);								//產(chǎn)生IIC起始信號(hào)
	SIIC_SendByte(&pHandle->IIC_Handle,?pHandle->SlaveAddr|BIT0);	//發(fā)送設(shè)備地址+讀信號(hào)
	data?=?SIIC_ReadByte(&pHandle->IIC_Handle,?TRUE);				//SIIC讀取一個(gè)字節(jié)
	SIIC_Stop(&pHandle->IIC_Handle);								//產(chǎn)生IIC停止信號(hào)
	
	return?data;
}


/*************************************************************************************************************************
*函數(shù)????????	:	void?MMA8452Q_ReadMultReg(MMA8452Q_HANDLE?*pHandle,u8?RegAddr,?u8?RegNum,?u8?DataBuff[])
*功能????????	:	MMA8452Q讀取多個(gè)寄存器
*參數(shù)????????	:	pHandle:句柄;RegAddr:寄存器地址;RegNum:寄存器數(shù)量;DataBuff:返回結(jié)果緩沖區(qū)
*返回????????	:	無
*依賴			:?	底層宏定義
*作者???????	:	cp1300@139.com
*時(shí)間?????		:	2018-04-09
*最后修改時(shí)間	:	2018-04-09
*說明????????	:	
*************************************************************************************************************************/
void?MMA8452Q_ReadMultReg(MMA8452Q_HANDLE?*pHandle,u8?RegAddr,?u8?RegNum,?u8?DataBuff[])
{
	u8?i;
	
	SIIC_Start(&pHandle->IIC_Handle);									//產(chǎn)生IIC起始信號(hào)
	SIIC_SendByte(&pHandle->IIC_Handle,?pHandle->SlaveAddr);			//發(fā)送設(shè)備地址+寫信號(hào)
	SIIC_SendByte(&pHandle->IIC_Handle,?RegAddr);						//發(fā)送寄存器地址
	SIIC_Start(&pHandle->IIC_Handle);									//產(chǎn)生IIC起始信號(hào)
	SIIC_SendByte(&pHandle->IIC_Handle,?pHandle->SlaveAddr|BIT0);		//發(fā)送設(shè)備地址+讀信號(hào)
	for(i?=?0;i?<?RegNum;i?++)
	{
		if(i?==?(RegNum-1))	//最后一字節(jié)不響應(yīng)ACK
		{
			DataBuff[i]?=?SIIC_ReadByte(&pHandle->IIC_Handle,?FALSE);	//SIIC讀取一個(gè)字節(jié)-NAK
		}
		else
		{
			DataBuff[i]?=?SIIC_ReadByte(&pHandle->IIC_Handle,?TRUE);	//SIIC讀取一個(gè)字節(jié)-ACK
		}	
	}
	SIIC_Stop(&pHandle->IIC_Handle);									//產(chǎn)生IIC停止信號(hào)
}


/*************************************************************************************************************************
*函數(shù)????????	:	void?MMA8452Q_WriteOneReg(MMA8452Q_HANDLE?*pHandle,u8?RegAddr,u8?data)
*功能????????	:	MMA8452Q寫一個(gè)寄存器
*參數(shù)????????	:	pHandle:句柄;RegAddr:寄存器地址;data:要寫入的值
*返回????????	:	無
*依賴			:?	底層宏定義
*作者???????	:	cp1300@139.com
*時(shí)間?????		:	2018-04-09
*最后修改時(shí)間	:	2018-04-09
*說明????????	:	
*************************************************************************************************************************/
void?MMA8452Q_WriteOneReg(MMA8452Q_HANDLE?*pHandle,u8?RegAddr,u8?data)
{
	SIIC_Start(&pHandle->IIC_Handle);								//產(chǎn)生IIC起始信號(hào)
	SIIC_SendByte(&pHandle->IIC_Handle,?pHandle->SlaveAddr);		//發(fā)送設(shè)備地址+寫信號(hào)
	SIIC_SendByte(&pHandle->IIC_Handle,?RegAddr);					//發(fā)送寄存器地址
	SIIC_SendByte(&pHandle->IIC_Handle,?data);						//發(fā)送要寫入的數(shù)據(jù)
	SIIC_Stop(&pHandle->IIC_Handle);								//產(chǎn)生IIC停止信號(hào)
}




/*************************************************************************************************************************
*函數(shù)????????	:	bool?MMA8452Q_ReadAcceleration(MMA8452Q_HANDLE?*pHandle,?s16?*pXa,s16?*pYa,?s16?*pZa)
*功能????????	:	MMA8452Q?讀取三軸加速度
*參數(shù)????????	:	pHandle:句柄;pXa:返回X軸加速度;pYa:返回Y軸加速度;pZa:返回Z軸加速度
*返回????????	:	TRUE:成功;FALSE:失敗
*依賴			:?	底層宏定義
*作者???????	:	cp1300@139.com
*時(shí)間?????		:	2018-04-09
*最后修改時(shí)間	:	2018-04-09
*說明????????	:	
*************************************************************************************************************************/
bool?MMA8452Q_ReadAcceleration(MMA8452Q_HANDLE?*pHandle,?s16?*pXa,s16?*pYa,?s16?*pZa)
{
	u8?buff[6];
	s16?temp;
	
	temp?=?MMA8452Q_ReadOneReg(pHandle,?0x0D);	//讀取器件ID
	if(temp?!=?0x2A)	//ID不對(duì)
	{
		return?FALSE;
	}
	MMA8452Q_ReadMultReg(pHandle,?1,?6,?buff);	//讀取數(shù)據(jù)
	temp?=?buff[0];
	temp<>4;
	if(buff[0]?&?BIT7)	//負(fù)數(shù)
	{
		temp?|=?0xF000;
	}
	*pXa?=?temp;	//X軸
	
	temp?=?buff[2];
	temp<>4;
	if(buff[2]?&?BIT7)	//負(fù)數(shù)
	{
		temp?|=?0xF000;
	}
	*pYa?=?temp;	//Y軸
	
	temp?=?buff[4];
	temp<>4;
	if(buff[4]?&?BIT7)	//負(fù)數(shù)
	{
		temp?|=?0xF000;
	}
	*pZa?=?temp;	//Z軸

	return?TRUE;
}



/*************************************************************************************************************************
*函數(shù)????????	:	void?ADXL362_CalAngle(s16?Xa,s16?Ya,?s16?Za,?float?*pAngleX,?float?*pAngleY,?float?*pAngleZ)
*功能????????	:	ADXL362?通過加速度計(jì)算角度信息
*參數(shù)????????	:	Xa:X軸加速度;Ya:Y軸加速度;Za:Z軸加速度,pAngleX:X方向傾角;pAngleY:Y方向傾角;pAngleZ:Z方向傾角
*返回????????	:	無
*依賴			:?	底層宏定義
*作者???????	:	cp1300@139.com
*時(shí)間?????		:	2016-04-06
*最后修改時(shí)間	:	2018-03-13
*說明????????	:	需要進(jìn)行浮點(diǎn),反正切運(yùn)算
*************************************************************************************************************************/
void?MMA8452Q_CalAngle(s16?Xa,s16?Ya,?s16?Za,?float?*pAngleX,?float?*pAngleY,?float?*pAngleZ)
{
	double?A;
	
	//X方向
	A?=?(double)Ya*Ya+(double)Za*Za;
	A?=?sqrt(A);
	A?=?(double)Xa/A;
	A?=?atan(A);?
	A?=?A*180/PI;
	if(Za<0)	//將坐標(biāo)轉(zhuǎn)換為±180度
	{
		if(A?<0)A=-90-(A+90);
		else?A=90+(90-A);
	}
	if(A?<0)	//將坐標(biāo)轉(zhuǎn)換為360度
	{
		A=fabs(A);
		A?=?180+180-A;
	}
	*pAngleX?=?A;	
	
	//Y方向
	A?=?(double)Xa*Xa+(double)Za*Za;
	A?=?sqrt(A);
	A?=?(double)Ya/A;
	A?=?atan(A);?
	A?=?A*180/PI;
	if(Za<0)//將坐標(biāo)轉(zhuǎn)換為±180度
	{
		if(A?<0)A=-90-(A+90);
		else?A=90+(90-A);
	}
	if(A?<0)	//將坐標(biāo)轉(zhuǎn)換為360度
	{
		A=fabs(A);
		A?=?180+180-A;
	}
	*pAngleY?=?A;
	
	//Z方向
	A?=?(double)Xa*Xa+(double)Ya*Ya;
	A?=?sqrt(A);
	A?=?(double)A/abs(Za);
	A?=?atan(A);?
	A?=?A*180/PI;
	uart_printf("XA:%dtYA:%dtZA:%dt",Xa,Ya,Za);
	/*if(Za<0)//將坐標(biāo)轉(zhuǎn)換為±180度
	{
		if(A?<0)A=-90-(A+90);
		else?A=90+(90-A);
	}
	if(A?<0)	//將坐標(biāo)轉(zhuǎn)換為360度
	{
		A=fabs(A);
		A?=?180+180-A;
	}*/
	*pAngleZ?=?A;
}


/*************************************************************************************************************************
*函數(shù)????????	:	bool?MMA8452Q_GetZAxisAngle(MMA8452Q_HANDLE?*pHandle,s16?AcceBuff[3],?float?*pAngleZ)
*功能????????	:	MMA8452Q?獲取Z軸傾角
*參數(shù)????????	:	pHandle:句柄;AcceBuff:3個(gè)軸的加速度;pAngleZ:Y方向傾角
*返回????????	:	TRUE:成功;FALSE:失敗
*依賴			:?	底層宏定義
*作者???????	:	cp1300@139.com
*時(shí)間?????		:	2018-04-09
*最后修改時(shí)間	:	2018-04-09
*說明????????	:	
*************************************************************************************************************************/

bool?MMA8452Q_GetZAxisAngle(MMA8452Q_HANDLE?*pHandle,s16?AcceBuff[3],?float?*pAngleZ)
{
	double?fx,fy,fz;
	double?A;
	s16?Xa,Ya,Za;
	
	
	
	
	
	if(MMA8452Q_ReadAcceleration(pHandle,?&Xa,?&Ya,?&Za)?==?FALSE)?return?FALSE;		//ADXL362?讀取加速度數(shù)據(jù)
	//uart_printf("Xa:%d?tYa:%d?tZa:%d?rn",Xa,Ya,Za);
	AcceBuff[0]?=?Xa;	//x軸加速度
	AcceBuff[1]?=?Ya;	//y軸加速度
	AcceBuff[2]?=?Za;	//z軸加速度
	
	fx?=?Xa;
	fx?*=?10.0/1024;
	fy?=?Ya;
	fy?*=?10.0/1024;
	fz?=?Za;
	fz?*=?10.0/1024;
	
	//uart_printf("fx:%.04ftfy:%.04ftfz:%.04ftrn",fx,fy,fz);
	
	//Z方向
	A?=?fx*fx+fy*fy;
	A?=?sqrt(A);
	A?=?(double)A/fz;
	A?=?atan(A);?
	A?=?A*180/PI;
	
	*pAngleZ?=?A;
	//uart_printf("=======角度:%.04frn",*pAngleZ);
	

	return?TRUE;
}
/*************************************************************************************************************
?*?文件名:			MMA8452Q.c
?*?功能:			MMA8452Q驅(qū)動(dòng)
?*?作者:			cp1300@139.com
?*?創(chuàng)建時(shí)間:		2018-04-09
?*?最后修改時(shí)間:	2018-04-09
?*?詳細(xì):			MMA8452Q三軸加速度傳感器
*************************************************************************************************************/
#ifndef?_MMA8452Q_H_
#define?_MMA8452Q_H_
#include?"system.h"
#include?"SoftwareIIC.h"

//MMA8452Q?句柄
typedef?struct
{
	SIIC_HANDLE?IIC_Handle;
	u8?SlaveAddr;
}MMA8452Q_HANDLE;


bool?MMA8452Q_Init(MMA8452Q_HANDLE?*pHandle,?u8?SlaveAddr);											//MMA8452Q初始化
bool?MMA8452Q_ReadAcceleration(MMA8452Q_HANDLE?*pHandle,?s16?*pXa,s16?*pYa,?s16?*pZa);				//MMA8452Q?讀取三軸加速度
bool?MMA8452Q_GetZAxisAngle(MMA8452Q_HANDLE?*pHandle,s16?AcceBuff[3],?float?*pAngleZ);				//MMA8452Q?獲取Z軸角度信息


#endif?/*_MMA8452Q_H_*/


//測(cè)試

g_SysFlag.ADXL362_Status?=?MMA8452Q_Init(&g_SysFlag.MMA8452Q_Handle,?0x1C<<1);
	if(g_SysFlag.ADXL362_Status?==?FALSE)
	{
		DEBUG("MMA8452Q初始化失??!rn");
	}
if(MMA8452Q_GetZAxisAngle(&g_SysFlag.MMA8452Q_Handle,?g_SysFlag.AcceBuff,?&AngleZ)?==?FALSE)			//ADXL362?獲取角度信息
			{
				//角度讀取失敗
				AngleZ?=?0;	//讀取失敗,固定為0
			}



本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉