实验18:秒表计数器

发布时间:2023-10-12  
  • (1)熟悉和掌握开发流程和软件使用方法;
  • (2)通过实验理解和掌握计数器原理;
  • (3)掌握用数据流和行为级描述寄存器单元的方法。

设计简单秒表(60进制),并要求带启动、复位、暂停功能。

本文引用地址:

如下所示,秒表(60进制)即显示从00到59循环跳转计数。并且通过开关设置,达到复位至00,任意时刻暂停和启动的功能。我们通过将开发板的12M晶振分频(参考分频程序)出1Hz的计时频率,实现秒钟的效果。将clk_1s的上升沿作为触发信号计时。通过开发板上的按键开关置零,实现复位功能。通过拨码开关置1或0,实现暂停和启动的功能。


程序清单counter60.v

 module counter60 
(input wire clk,rst,           //时钟和复位输入
input wire key,				  //启动暂停按键
output wire [8:0] segment_led_1,segment_led_2    	  //数码管输出
); 
wire	clk1h;			//1秒时钟
reg	[7:0] cnt;			//计时计数器
reg		flag;			//启动暂停标志 
divide #				//例化分频器产生1秒时钟信号
(
.WIDTH(24),
.N(12_000_000)
) u1
(
.clk(clk),
.rst_n(rst),
.clkout(clk1h)
);
always @(posedge clk)		//产生标志信号
	if(!rst)
		flag = 1'b0;
	else if(!key)
		flag = ~flag;
	else
		flag = flag;always @(posedge clk1h )        //产生60进制计数器
	begin	//数码管显示要按照十进制的方式显示
		if(!rst)
			cnt <= 8'h00;		//复位初值显示00
		else if(flag)
			begin
				if(cnt[3:0] == 4'd9)	//个位满九?
					begin
						cnt[3:0] <= 4'd0;	//个位清零
						if(cnt[7:4] == 4'd5 )	//十位满五?
							cnt[7:4] <= 4'd0;	//个位清零
						else
							cnt[7:4] <= cnt[7:4] + 1'b1;	//十位加一
					end
				else cnt[3:0] <= cnt[3:0] + 1'b1;	//个位加一
			end
		else
			cnt <= cnt;
	end
	segment u2
	(
	.seg_data_1		(cnt[7:4]),  //seg_data input
	.seg_data_2		(cnt[3:0]),  //seg_data input
	.segment_led_1	(segment_led_1),  //MSB~LSB = SEG,DP,G,F,E,D,C,B,A
	.segment_led_2	(segment_led_2)   //MSB~LSB = SEG,DP,G,F,E,D,C,B,A
	);
	endmodule

其中例化的模块还包括分频模块程序divide.v和数码管segment.v

  1. 打开,建立工程。
  2. 新建设计文件,并键入设计代码。
  3. 根据逻辑综合并分配管脚,在本实验中引脚分配如下:clkin —C1,rstnin—L14,key1—M13,[8:0] segmentled1 — A10~C9,[8:0] segmentled2 —C12~A12
  4. 构建并输出编程文件,烧写至的Flash之中。
  5. 观察输出结果。

开发板上的两个显示数码管从00至59循环累加。当按键开关L14按下时,计数器复位。在计数过程中,按一次M13计数暂停,再按一次M13正常计数。我们可以通过暂停清零启动的过程达到秒表计数功能。


文章来源于:电子产品世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

相关文章

    AT89S51单片机对6位LED数码管实现显示时计方式的设计;这是我们设计的单片机电子钟/计时器学习板,它采用6位LED数码管显示时、分、秒,以24小时计时方式。可以通过按键实现时分调整、秒表/时钟......
    实验18:秒表计数器;实验目的 (1)熟悉和掌握开发流程和软件使用方法; (2)通过实验理解和掌握计数器原理; (3)掌握用数据流和行为级描述寄存器单元的方法。 实验任务 设计简单秒表(60......
    下表示设置分钟,设置完分钟再按下设置键退出闹钟设置模式。闹钟时间到了会通过蜂鸣器播放闹钟铃声。期间如果想停止闹铃可以按下停止闹铃按键。 通过按下闹钟按键进入闹钟显示模式,秒表指示灯亮。开始按键启动秒表计时,暂停按键暂停当前秒表计时并显示计时......
    /计数器(T/C) 设计电子秒表,用51单片机STC89C52设计控制电路,用4位数码管显示,能从00.00秒计时到99.99秒。 秒表计数器元器件选型秒表计......
    计时精度为0.01秒,能正确地进行计时,同时能记录一次时间,并在下一次计时后对上一次计时时间进行查询。当按键Key1按下时,秒表开始运行,再按下时,秒表停止;每按下一次,状态翻转一次;当按键Key2......
    按启动按钮之前) 按了启动按钮之后,秒表将会自动开始计时,由于无法演示动态过程,只能在中间按下暂停键给大家看看效果: 按下复位键后: 由于我用的是一个比较完整的51开发板,所以里面有很多部分,大家......
    Linux定时器的使用;使用定时器的目的无非是为了周期性的执行某一任务,或者是到了一个指定时间去执行某一个任务。要达到这一目的,一般有两个常见的比较有效的方法。一个是用linux内部的三个定时器......
    常见的测量工具有哪些?测量工具读数方法;测量工具读数方法   常见的测量工具有哪些? 【千分尺】        【游标卡尺】      【带表卡尺】     【千分尺】    千分尺读数方法......
    计数 总结 使用过S7-200的电气工程师都知道Timer紧缺,所以利用时基计数的方式解决了定时器紧张的问题,再加上CPU运行速度越来越快,时基计数方式的精确度也得以提升 国内触摸屏HMI厂家......
    关于定时器、波特率、TH和TL值的计算;假设晶振位6MHZ,定时10ms   单片机系统晶振频率为6mhz,系统时钟频率 (也是计时脉冲频率)为500KHZ,一个脉冲周期2us ,10ms是5000......

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>