u16 c语言在那个头文件下,关于官方编码器库函数问题U16_MAX,U32_MAX,s16
修改的程序....
/******************** (C) COPYRIGHT 2007 STMicroelectronics ********************
* File Name : stm32f10x_encoder.c
* Author : IMS Systems Lab
* Date First Issued : 21/11/07
* Description : This file contains the software implementation for the
* encoder unit
********************************************************************************
* History:
* 21/11/07 v1.0
********************************************************************************
* THE PRESENT SOFTWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME.
* AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT,
* INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE
* CONTENT OF SUCH SOFTWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING
* INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
*******************************************************************************/
/* Includes ------------------------------------------------------------------*/
#include "stm32f10x_encoder.h"
#include "stm32f10x.h"
/* Private typedef -----------------------------------------------------------*/
/* Private define ------------------------------------------------------------*/
#define ENCODER_TIMER TIM3 // Encoder unit connected to TIM3
#define ENCODER_PPR (u16)(400) // number of pulses per revolution
#define SPEED_BUFFER_SIZE 8
#define COUNTER_RESET (u16)0
#define ICx_FILTER (u8) 6 // 6 670nsec
#define TIMx_PRE_EMPTION_PRIORITY 1
#define TIMx_SUB_PRIORITY 0
#define SPEED_SAMPLING_FREQ (u16)(2000/(SPEED_SAMPLING_TIME+1))
#define U16_MAX ((u16)65535u)
#define U32_MAX ((u32)4294967295uL)
/* Private functions ---------------------------------------------------------*/
s16 ENC_Calc_Rot_Speed(void);
/* Private variables ---------------------------------------------------------*/
//static s16 hPrevious_angle/*, hSpeed_Buffer[SPEED_BUFFER_SIZE],hRot_Speed*/;
//static u8 bSpeed_Buffer_Index = 0;
//static bool bIs_First_Measurement = TRUE;
static volatile u16 hEncoder_Timer_Overflow;
/*******************************************************************************
* Function Name : ENC_Init
* Description : General Purpose Timer x set-up for encoder speed/position
* sensors
* Input : None
* Output : None
* Return : None
*******************************************************************************/
void ENC_Init(void)
{
TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
TIM_ICInitTypeDef TIM_ICInitStructure;
/* Encoder unit connected to TIM3, 4X mode */
GPIO_InitTypeDef GPIO_InitStructure;
NVIC_InitTypeDef NVIC_InitStructure;
/* TIM3 clock source enable */
RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3, ENABLE);
/* Enable GPIOA, clock */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);
GPIO_StructInit(&GPIO_InitStructure);
/* Configure PA.06,07 as encoder input */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6 | GPIO_Pin_7;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIOA, &GPIO_InitStructure);
/* Enable the TIM3 Update Interrupt */
NVIC_InitStructure.NVIC_IRQChannel = TIM3_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = TIMx_PRE_EMPTION_PRIORITY;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = TIMx_SUB_PRIORITY;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
/* Timer configuration in Encoder mode */
TIM_DeInit(ENCODER_TIMER);
TIM_TimeBaseStructInit(&TIM_TimeBaseStructure);
TIM_TimeBaseStructure.TIM_Prescaler = 0x0; // No prescaling
TIM_TimeBaseStructure.TIM_Period = (4*ENCODER_PPR)-1;
TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
TIM_TimeBaseInit(ENCODER_TIMER, &TIM_TimeBaseStructure);
TIM_EncoderInterfaceConfig(ENCODER_TIMER, TIM_EncoderMode_TI12,
TIM_ICPolarity_Rising, TIM_ICPolarity_Rising);
TIM_ICStructInit(&TIM_ICInitStructure);
TIM_ICInitStructure.TIM_ICFilter = ICx_FILTER;
TIM_ICInit(ENCODER_TIMER, &TIM_ICInitStructure);
// Clear all pending interrupts
TIM_ClearFlag(ENCODER_TIMER, TIM_FLAG_Update);
TIM_ITConfig(ENCODER_TIMER, TIM_IT_Update, ENABLE);
//Reset counter
TIM2->CNT = COUNTER_RESET;
ENC_Clear_Speed_Buffer();
TIM_Cmd(ENCODER_TIMER, ENABLE);
}
/*******************************************************************************
* Function Name : ENC_Get_Electrical_Angle
* Description : Returns the absolute electrical Rotor angle
* Input : None
* Output : None
* Return : Rotor electrical angle: 0 -> 0 degrees,
* S16_MAX-> 180 degrees,
* S16_MIN-> -180 degrees
*******************************************************************************/
s16 ENC_Get_Electrical_Angle(void)
{
s32 temp;
temp = (s32)(TIM_GetCounter(ENCODER_TIMER)) * (s32)(U32_MAX / (4*ENCODER_PPR));
return((s16)(temp/65536)); // s16 result
}
/*******************************************************************************
* Function Name : ENC_Clear_Speed_Buffer
* Description : Clear speed buffer used for average speed calculation
* Input : None
* Output : None
* Return : None
*******************************************************************************/
//void ENC_Clear_Speed_Buffer(void)
//{
// u32 i;
// for (i=0;i
// {
// hSpeed_Buffer[i] = 0;
// }
// bIs_First_Measurement = TRUE;
//}
/*******************************************************************************
* Function Name : ENC_Calc_Rot_Speed
* Description : Compute return latest speed measurement
* Input : None
* Output : s16
* Return : Return the speed in 0.1 Hz resolution.
*******************************************************************************/
//s16 ENC_Calc_Rot_Speed(void)
//{
// s32 wDelta_angle;
// u16 hEnc_Timer_Overflow_sample_one, hEnc_Timer_Overflow_sample_two;
// u16 hCurrent_angle_sample_one, hCurrent_angle_sample_two;
// signed long long temp;
// s16 haux;
//
// if (!bIs_First_Measurement)
// {
// // 1st reading of overflow counter
// hEnc_Timer_Overflow_sample_one = hEncoder_Timer_Overflow;
// // 1st reading of encoder timer counter
// hCurrent_angle_sample_one = ENCODER_TIMER->CNT;
// // 2nd reading of overflow counter
// hEnc_Timer_Overflow_sample_two = hEncoder_Timer_Overflow;
// // 2nd reading of encoder timer counter
// hCurrent_angle_sample_two = ENCODER_TIMER->CNT;
// // Reset hEncoder_Timer_Overflow and read the counter value for the next
// // measurement
// hEncoder_Timer_Overflow = 0;
// haux = ENCODER_TIMER->CNT;
//
// if (hEncoder_Timer_Overflow != 0)
// {
// haux = ENCODER_TIMER->CNT;
// hEncoder_Timer_Overflow = 0;
// }
//
// if (hEnc_Timer_Overflow_sample_one != hEnc_Timer_Overflow_sample_two)
// { //Compare sample 1 & 2 and check if an overflow has been generated right
// //after the reading of encoder timer. If yes, copy sample 2 result in
// //sample 1 for next process
// hCurrent_angle_sample_one = hCurrent_angle_sample_two;
// hEnc_Timer_Overflow_sample_one = hEnc_Timer_Overflow_sample_two;
// }
//
// if ( (ENCODER_TIMER->CR1 & TIM_CounterMode_Down) == TIM_CounterMode_Down)
// {// encoder timer down-counting
// wDelta_angle = (s32)(hCurrent_angle_sample_one - hPrevious_angle -
// (hEnc_Timer_Overflow_sample_one) * (4*ENCODER_PPR));
// }
// else
// {//encoder timer up-counting
// wDelta_angle = (s32)(hCurrent_angle_sample_one - hPrevious_angle +
// (hEnc_Timer_Overflow_sample_one) * (4*ENCODER_PPR));
// }
//
// // speed computation as delta angle * 1/(speed sempling time)
// temp = (signed long long)(wDelta_angle * SPEED_SAMPLING_FREQ);
// temp *= 10; // 0.1 Hz resolution
// temp /= (4*ENCODER_PPR);
//
// } //is first measurement, discard it
// else
// {
// bIs_First_Measurement = FALSE;
// temp = 0;
// hEncoder_Timer_Overflow = 0;
// haux = ENCODER_TIMER->CNT;
// // Check if Encoder_Timer_Overflow is still zero. In case an overflow IT
// // occured it resets overflow counter and wPWM_Counter_Angular_Velocity
// if (hEncoder_Timer_Overflow != 0)
// {
// haux = ENCODER_TIMER->CNT;
// hEncoder_Timer_Overflow = 0;
// }
// }
//
// hPrevious_angle = haux;
//
// return((s16) temp);
//}
/*******************************************************************************
* Function Name : TIM2_IRQHandler
* Description : This function handles TIMx Update interrupt request.
Encoder unit connected to TIM2
* Input : None
* Output : None
* Return : None
*******************************************************************************/
void TIM3_IRQHandler(void)
{
/* Clear the interrupt pending flag */
TIM_ClearFlag(ENCODER_TIMER, TIM_FLAG_Update);
if (hEncoder_Timer_Overflow != U16_MAX)
{
hEncoder_Timer_Overflow++;
}
}
/******************* (C) COPYRIGHT 2007 STMicroelectronics *****END OF FILE****/
u16 c语言在那个头文件下,关于官方编码器库函数问题U16_MAX,U32_MAX,s16相关推荐
- C语言两个同名头文件,C lang: C语言中两个头文件引入相同的头文件(Header.h)
C lang: C语言中两个头文件引入相同的头文件(Header.h) C lang: C语言中两个头文件引入相同的头文件(Header.h) [var1] For example: Header.h ...
- c语言exit头文件,exit函数在那个头文件
c语言 exit的头文件是什么? C语言exit函数的头文件是stdlib.h. exit的声明为 void exit(int value); exit的作用是,退出程序,并将参数value的值返回给 ...
- Linux下C语言的系统头文件
Linux菜鸟初看Linux下编程的糗事. 前段时间琢磨着接触一下Linux下的C语言编程,就找了本书看.看到很多文件操作的程序要包含"sys/stat.h". 写程序前,我想先找 ...
- linux下各个头文件及作用总结
#include <linux/***.h> 是在linux-2.6.29/include/linux下面寻找源文件. #include <asm/***.h> 是在linux ...
- c语言设置输出字符大小_C语言中常用的几个头文件及库函数
点击上方"C语言中文社区",选择"设为星标★" 技术干货第一时间送达! 来源:https://www.jb51.net/article/124594.htm 这 ...
- Linux(Ubuntu)下,生成C语言可执行文件和汇编文件
Linux(Ubuntu)下,生成C语言可执行文件和汇编文件 前言 一.一些Linux操作 二.编写C语言文件 三.生成可执行文件 1. 正常过程 2. 可能错误 四.直接生成汇编文件 五.反汇编 1 ...
- c语言所有库函数及其头文件,c语言中常用的几个头文件及库函数
不完全统计,C语言标准库中的头文件有15个之多,所以我主要介绍常用的这四个头文件stdio.h,string.h,math.h,stdlib.h,以后用到其他的再做补充.下面上干货: 1.:定义了输入 ...
- 用c语言批量删除指定文件夹,C语言删除文件夹下所有代码的注释for Mac
#include #include #include char b[1000000]; void delete(char a[]) { int i,j=0; for(i=0;a[i];i++) { i ...
- c语言windows.h头文件详解
如果c语言库里没有某个头文件 只需要将下好的头文件放入下面的路径即可 windows.h头文件包含的函数及其用法 1.GetAsyncKeyState()()//通过函数来判断按键按下的状态 主要用法 ...
最新文章
- yum源及yum仓库服务搭建讲解
- 驭下术:如何让下属老实听话?用这3招,让你不怒自威
- 常见宽带路由器配置及口令清除技巧
- 【多线程】ThreadPoolExecutor类万字源码解析(注解超级详细)
- 树莓派3B用Ubuntu MATE安装ros
- java小程序设计一个国旗点击国旗唱国歌,看这篇足矣了!
- linux使用flock解决crontab任务冲突
- sendmail 常见报错总结
- JMeter 连接 sql server
- MATLAB神经网络应用之Elman神经网络
- 机器学习 第一节 第一课
- php中文数组,php数组的定义
- linux开发板2048游戏界面图,linux c 实现2048游戏
- 测试用例方法--错误推测法
- 使用java实现输出图形(三角形、菱形等四个图形)
- 【问题记录】js 更改数组中某字段名
- qq批量登录软件_把微信PC版越甩越远:QQ电脑版这些新功能太良心
- 微信公众号开发之接收与发送消息
- 零基础制作【武林外传】辅助工具(二)
- Python之基本扩展模块
热门文章
- 医学图像标注终极指南
- 解除Android封锁app,解除微信对app支付的封锁
- java png转gif_【ImageMagick】png序列转gif(适合处理带透明度的图片)
- IS-IS P2P网络下LSDB同步过程
- DataMining学习2_数据挖掘十大经典算法
- 视频剪辑app软件开发需要实现哪些功能
- 【paper reading】Uncalibrated Photometric Stereo under Natural Illumination
- HTML5里video标签支持哪些格式的视频文件
- 王富强散文诗集《天降斯人》自序
- 计算机网络实训报告,计算机网络技术实训报告范文