//***************FileName:Capature.C***************//
//***************ICCAVR V6.30编译*****************//
#include <iom16v.h>
#include <macros.h>
#define uchar unsigned char
#define uint unsigned int
#define CON 1000 //频率常数定义
uchar Flag=0; //捕获次数定义
//数码管字型表,对应0,1,2,3,4,5,6,7,8,9,A,b,C,d,E,F//
uchar Table[20]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,0x39,0x5E,0x79,0x71};
uchar Data[4]={0,0,0,0}; //显示初始值:0 0 0 0
uint CNT1; //第一次捕获值
uint CNT2; //第二此捕获值
uint CNT=100; //捕获差值
void DelayMs(uint i) //Ms级延时,参数i为延时时间
{uint j;
for(;i!=0;i--)
{for(j=250;j!=0;j--) {;}}
}
void Pre_Display(void) //预显示函数,数码管显示检测
{uchar i;
for(i=0;i<16;i++)
{PORTC=0x00;
PORTA=Table[i];
DelayMs(100);
}
}
void Display(uchar *p) //动态显示函数,参数p为待显示的数组名
{uchar i,sel=0x08;
for(i=0;i<4;i++)
{PORTC=~sel; //选通最右边的数码管
PORTA=Table[p[i]]; //送字型码
DelayMs(2); //显示延时
sel=sel>>1; //移位以显示前一位
}
}
void HZ(uint i,uchar *p)
{uint TEM;
p[0]=CON/i;
TEM=CON%i;
TEM=TEM*10;
p[1]=TEM/i;
TEM=TEM%i;
TEM=TEM*10;
p[2]=TEM/i;
TEM=TEM%i;
TEM=TEM*10;
p[3]=TEM/i;
}
void Init_IO(void) //初始化I/O口
{DDRA=0xff; //设置A口为推挽1输出
PORTA=0xff;
DDRC=0xff; //设置C口为推挽1输出
PORTC=0xff;
DDRD=0x00; //设置D口为带上拉电阻输入
PORTD=0x00;
}
void Init_Timer1(void) //初始化T/C1的输入捕获中断
{TIMSK=TIMSK|0x20; //输入捕获使能
TCCR1B=0xC2; //输入捕获噪音使能,下降沿捕获,时钟8分频1uS计数一次。
TIFR=0x20; //清中断标志
SREG=SREG&0x7f; //全局中断关
}
void main(void)
{uchar i;
Init_IO(); //初始化I/O口
PORTA=0xff; //点亮以测试所有的数码管
PORTC=0xf0;
DelayMs(300);
PORTC=0xff; //熄灭所有的数码管
Pre_Display(); //预显示,数码管显示测试
PORTC=0xff;
Init_Timer1(); //T/C1初试化
while(1)
{
while(TIFR&0x20) //捕获检测
{TIFR|=0x20; //清除捕获标志
CNT=ICR1L; //CNT暂存
CNT2=(ICR1H<<8)+ICR1L; //CNT2存放当前捕获值
CNT=CNT2-CNT1; //CNT存放两次时间差
CNT1=CNT2; //CNT1存放上次捕获值
Flag++;} //检测到第一次捕获
if(Flag==2) //检测到第二此捕获
{Flag=0; //清除捕获检测标志
HZ(CNT,Data); //数据处理
for(i=0;i<100;i++) //频率显示
Display(Data);
CNT=0;CNT1=0;CNT2=0;}} //清除捕获值及捕获差值
}
CrMylive.
- 粉丝: 1w+
- 资源: 4万+
最新资源
- MMC SIMULINK模块化多电平变换器仿真模型:带电压控制与环流抑制功能,性能卓越无参考文献,可完美运行,MMC SIMULINK 模块化多电平变器仿真模型,带有电压控制和环流抑制,没有参考文献
- 基于模拟部分的ADC逆向数据解析与16bit流水线原理图学习分享,adc逆向数据,只含模拟部分:16bit pipleline原理图,仅供个人学习使用,适合有一定基础的小伙伴,只提供数据 ,核心关键词
- 基于Tent混沌映射的麻雀搜索算法优化:提高全局搜索能力与初始解质量,基于Tent混沌映射的麻雀搜索算法matlab代码: 针对麻雀搜索算法(SSA)在接近全局最优时,种群多样性减少,易陷入局部最优解
- ERP模块化编程框架:分散解耦、配置式开发,美观界面与强大数据库支持,支持VS2017至VS2022及SQLSERVER开发环境,ERP WPF框架源码 1,ERP 开发框架; 2,ERP 模块化编程
- 基于碳交易和P2G光热电站及碳捕集技术的多能微网低碳经济优化调度策略,考虑碳交易和P2G-光热电站-碳捕集的多能微网低碳经济调度 构建了含有光热电站-电转气系统以及碳捕集系统的综合能源
- Matlab下的A星算法改进:提升搜索效率、冗余拐角优化及路径平滑处理,Matlab算法代码 A星算法 路径规划A* Astar算法仿真 传统A*+改进后的A*算法 Matlab代码 改进: ①提升
- Matlab中ADMM算法在碳排放交易背景下电力系统的最优潮流应用:分布式优化与仿真求解,Matlab代码:ADMM算法在考虑碳排放交易的电力系统最优潮流中的应用 关键词:交替方向乘子法, ADMM
- 基于Matlab Simulink的光伏逆变器仿真建模:HERIC拓扑结构设计与DC-AC转换实现,Simulink仿真:基于Matlab Simulink的HERIC光伏逆变器仿真建模 关键词:光伏
- 基于目标级联分析法的多微网主动配电系统自治优化经济调度算法实践:初级拉格朗日算法应用,GAMS代码:基于目标级联分析法的多微网主动配电系统自治优化经济调度 该代码并非完全复现该文献,而是参照文献
- "COMSOL电磁传感器螺孔缺陷检测计算模型解析:缺陷位置的电磁分布研究",comsol 电磁传感器螺孔缺陷检测计算模型,可以得到缺陷处的电磁分布 ,核心关键词:comsol; 电磁传感器; 螺孔缺陷
- 基于卡尔曼滤波的锂蓄电池SOC在线估计:噪声环境下的动态分析与算法优化,MATLAB基于卡尔曼滤波的锂蓄电池SOC设计 用自适应卡尔曼滤波方法,基于锂离子动力电池等效电路模型,在未知干扰噪声环境下,在
- 基于电转气P2G与碳捕集设备的热电联供综合能源系统优化调度模型研究,考虑P2G和碳捕集设备的热电联供综合能源系统优化调度模型 摘要:代码主要做的是一个考虑电转气P2G和碳捕集设备的热电联供综合能源系统
- BMS电池管理系统中的SOC估计模型与卡尔曼滤波算法研究:基于Simulink的锂电池参数辨识与SOC估算,BMS电池管理系统SOC估计模型 电池管理系统simulink SOC电池参数辨识模型10个
- 西门子S7-1200机器人码垛机程序及立体库案例解析:清晰结构、详尽注释、涵盖变频器与视觉相机控制等高级应用,142-西门子S7-1200机器人码垛机程序和1200立体库及码垛机等三个程序案例,程序带
- 西门子S7-1200控制五轴伺服程序与维纶触摸屏画面案例:模块化设计,脉冲定位与速度/扭矩模式,多种功能及触摸屏编程软件应用,西门子S7-1200控制5轴伺服程序加维纶触摸屏画面案例 1.PTO
- 基于欧姆龙元器件的涂布机程序NJ501-1400高精度运动控制系统,涂布机程序欧姆龙NJ501-1400,无触摸屏 整机全部使用欧姆龙产品,欧姆龙R88D系列伺服,NX-ECC201耦合器通信远程总
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈