当前位置:首页 > 单片机 > 单片机
[导读] /**************************************************************************实验四(第二版):用 Atmega8 实现D触发锁存器的功能实现目的:1.管脚设定为输入时,了解如何可以编程设定上拉电阻。2.

/**************************************************************************
实验四(第二版):用 Atmega8 实现D触发锁存器的功能
实现目的:
1.管脚设定为输入时,了解如何可以编程设定上拉电阻。
2.如何使用软件控制取样频率及时间,达到一定的抗干扰目的
3.为了让程序运行更稳定,防止跑飞,如何使用看门狗?

By armok (2004-09-18) a13809260240@126.com
***************************************************************************/


#include //本实验使用Atmega8
#include

#define sapleing_way 2 //定义多少路采样。最大值为8。PB为输入,PD输出。
#define sampling_times 20 //定义取样的次数,连续次数的取样值相同,视为有效取样。
#define sampling_interval 50 //定义每次取样的时间间隔,单位 us.


typedef struct
{ unsigned int v_last; //上一次sampling_times个取样值的结果
unsigned int v_current; //当前sampling_times个取样值的结果
unsigned int v[sampling_times]; //存放连续sampling_times次的取样值
unsigned int v_temp; //存放比较的临时值,为1时有效,0时无效
} inputStruct;

void delay_nus(unsigned int n); //延时函数,单位 us.
void watchdog_init(void); //初始化watchdog函数
void port_init(void); //端口初始化函数
void main(void) //主函数
{
unsigned int i;
unsigned int j;
inputStruct pb_input[sapleing_way];

port_init(); //初始化端口
watchdog_init(); //初始化watchdog

while (1)
{
//以下的for循环,将连续sampling_times次的取样结果存放在相应的数组里
for (i=0;i{
delay_nus(sampling_interval); //每隔sampling_interval取样一次
for(j=0;j{
pb_input[j].v[i]=PINB&BIT(j);
}
}


//以下的for循环,判断连续sampling_times次的取样结果是否有效
for(j=0;j {
for (i=1;i {
if (pb_input[j].v[i-1]==pb_input[j].v[i]) //如果sampling_times次取样结果均相同,视为有效
pb_input[j].v_temp=1; //sampling_times次取样有效的标志
else //否则舍弃,不作处理。
{
pb_input[j].v_temp=0; //sampling_times次取样无效,不作处理
break;
}
}

//以下的if判断PB输入的电平,与上一次取样计算结果比较,判断是否翻转相应的PD
if (pb_input[j].v_temp==1) //sampling_times次取样有效,进行以下判断
{
if (pb_input[j].v[0]==0) //输入为低电平
pb_input[j].v_current=0;
else
pb_input[j].v_current=1; //输入为高电平
if (pb_input[j].v_last==1 && pb_input[j].v_current==0)//如果前十个取样是高电平,现在十个是低电平,视为有效的动作,执行输出
PORTD^=BIT(j);//将相应的PD位翻转
pb_input[j].v_last=pb_input[j].v_current; //将当前结果传给上一次结果,准备下一次处理
}
} //end for

WDR(); //看门狗计数清零
} //end while
} // end main()


void delay_nus(unsigned int n)//n微秒延时函数
{
unsigned int i;
for (i=0;i {
asm("nop");
}
}

void port_init(void)
{
DDRB=0x00;//设置PB0-7为输入
PORTB=0xFF; //与下一句同时起作用
SFIOR&=~BIT(2); //置SFIOR的PDU上拉电阻有效。与上一句一起生效。
DDRD=0xFF;//PD0-7为输出
}

void watchdog_init(void)
{
WDR(); //看门狗计数清零
WDTCR=0x0F; //使能watchdog,并且,采用2048K分频,典型溢出时间5V时2.1S
}


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

2025年08月29日,比利时泰森德洛·哈姆——全球微电子工程公司Melexis宣布,正式发布专为水平方向磁位置检测而设计,具备卓越的静电防护(ESD)能力以及高输出电流限制等特性的三线制霍尔效应锁存器MLX92211系...

关键字: 锁存器 电机 自动化

锁存器是一种电平触发的存储单元,用于存储单个比特的信息,其状态由输入信号的电平值决定。

关键字: 锁存器

在数字电路设计中,Latch(锁存器)与Register(寄存器)是两种常见的存储元件,它们在功能和实现上各有特点,对电路的性能和稳定性有着重要影响。本文将从行为描述、触发机制、资源消耗、时序分析以及实际应用等方面,深入...

关键字: Latch Register 数字电路 锁存器

在实际的数字系统中,通常把能够用来存储一组二进制代码的同步时序逻辑电路称为寄存器.由于触发器内有记忆功能,因此利用触发器可以方便地构成寄存器。

关键字: 锁存器 Latch

美国新罕布什尔州曼彻斯特 - 运动控制和节能系统传感技术和功率半导体解决方案的全球领导厂商Allegro MicroSystems(纳斯达克股票代码:ALGM)(以下简称Allegro)在 Electronica 202...

关键字: 功率磁性开关 锁存器 传感器

锁存允许端(LE)的作用。当LE为高电平时,输出端(Q0至Q7)随输入数据端(D0至D7)的变化而变化。当LE为低电平时,输出端被锁存在已建立的数据电平,即使输入数据端发生变化,输出端的电平也不会改变。

关键字: 74ls373 锁存器 触发器

在现代电子技术领域,集成电路(IC)扮演着至关重要的角色。其中,74LS373是一款常用的三态八位锁存器,广泛应用于数字电路系统中。本文将详细介绍74LS373的功能特点、使用方法以及在实际应用中的典型场景,帮助读者更好...

关键字: 集成电路 74LS373 锁存器

2023年10月9日,上海 —— 纳芯微宣布推出基于隧道磁阻 (TMR) 的超低功耗磁开关/锁存器NSM105x系列,为数字位置检测提供高精度的解决方案,可被广泛应用于工业与消费领域的位置检测。

关键字: 锁存器 TMR开关

首先应该明确锁存器和触发器也是由与非门之类的东西构成。尤其是锁存器,虽说数字电路定义含有锁存器或触发器的电路叫时序电路,但锁存器有很多组合电路的特性。

关键字: 锁存器 寄存器

当我们需要设计一个具有特定性能的DAC时,很可能没有任何一种架构是理想的。这种情况下,可以将两个或更多DAC组合成一个更高分辨率的DAC,以获得所需的性能。

关键字: DAC ADI 电流开关 锁存器
关闭