EDA实验-----直流电机驱动设计(Quartus II )

news2025/1/24 11:45:51

目录

一、实验目的

二、实验仪器设备

三、实验的重点和难点

四、实验原理

五、实验步骤

六、实验报告

七、实验过程

1.分频器代码

2.方向选择器

3.直流电动机工作原理

4.电路连接图

5.文件烧录


一、实验目的

  1. 了解直流电机控制的工作原理和实现的方法。
  2. 掌握PWM波控制直流电机转速的方法。
  3. 学会用于Verilog语言设计直流电机控制电路。

二、实验仪器设备

  1. PC机一台
  2. FPGA实验开发系统一套。

三、实验的重点和难点

  1. 重点:掌握直流电机调速控制原理。
  2. 难点:应用Verilog语言实现直流电机控制电路设计。

四、实验原理

本次实验使用的电机驱动电路如下图所示:

                                                图1 直流电机H桥驱动电路 

                                                                  图2 锁存器

  1. 调方向

如图1所示,当PWM1为高电平时,PWM2为低电平时,Q2和Q4导通,Q3和Q5不导通。当PWM1为低电平时,PWM2为高电平时,Q2和Q4不导通,Q3和Q5导通。两种情况电机转动的方向不一样。

     2. 调速度

电机的速度是通过PWM调节,所谓PWM就是脉宽调制器,通过调制器给电机提供一个具有一定频率的脉冲宽度可调的脉冲电。脉冲宽度越大即占空比越大,提供给电机的平均电压越大,电机转速就高。反之脉冲宽度越小,则占空比越越小。提供给电机的平均电压越小,电机转速就低。

五、实验步骤

  1. 启动 Quartus II 建立一个空白工程,选择的器件为 Altera 公司的 Cyclone 系列的 EP2C8Q240C8 芯片,命名为 moto.qpf;
  2. 新建一个 Schematic File 文件,命名为 moto.bdf;
  3. 分别新建 3 个 Verilog HDL File 文件,分别命名为 divclk.v,pwm_logic.v, moto_test.v。输入程序代码并保存(对应源程序 11),然后进行综合编译。若在编译过程中发现错误,则找出错误并更正错误,直至编译成功为止。从设计文件创建模块(FileàCreat UpdateàCreat Symbol Files for Current File), divclk.v生成名为 divclk.bsf;pwm_logic.v 生成名为 pwm_logic.bsf;moto_test.v 生成 moto_test.bsf;
  4. 在 moto.bdf 文件中,在空白处双击鼠标左键,在 Symbol 对话框左上角的 libraries 中,分别将Project 下的 divclk、moto_test、pwm_logic 模块放在图形文件 moto.bdf 中,加入输入、输出引脚,双击每个引脚,进行引脚命名,并锁定管脚,将未使用的引脚设置为三态输入(一定要设置,否则可能会损坏芯片);

Clk1

209

K1

153

K2

95

K3

154

MOT_CS

171

Gpio[4]

164

Gpio[5]

159

完整的顶层模块原理图如图所示:

其中 K1 控制电机的正转与反转;K2 控制电动机启动、停止;K3 控制占空比;

        5. 将 moto.bdf 设置为顶层实体。对该工程文件进行全程编译处理,若在编译过程中出现错                误,则找出错误并更正,直至编译通过为止;

        6. 将 USB-Blaster 下载电缆的两端分别连接到 PC 机的 USB 接口和EDA 实验箱上的 JTAG                下载口上,打开电源,执行下载命令,把程序下载到 FPGA 器件中,此时,即可在 EDA 实         验箱上控制直流电机。

六、实验报告

  1. 总结Verilog设计直流电机驱动的步骤。
  2. 讨论自己在设计过程中遇到的问题、解决的过程以及收获体会。

七、实验过程

基本流程为创建项目、创建Verilog文件、写代码、进行波形仿真、画出电路图、设置管脚和三态、烧录文件。前面的项目创建等等基本操作我就不去做演示了,下面主要去讲原理和代码。

1.分频器代码

这个模块是对输入信号的频率去进行分频处理,分出的频率是满足电动机所需的频率即可。代码如下,很显然,这个是一个8分频的分频器,这里我们直接拿过来用就行了。

module divclk(inclk,outclk);
	input inclk;
	output outclk;
	reg outclk;
	reg [2:0] cnt;
	initial
		begin
			cnt<=0;
			outclk<=0;
		end
	always @(posedge inclk)
		begin
			cnt<=cnt+1;
			if (cnt<=0)
				outclk<=outclk+1;
		end
endmodule 

2.方向选择器

下面代码是用于设计直流电动机转向选择的代码,供大家参考一下。

module pwm_logic(clk,pwm_en,duty_cycle,pwm_out);
input clk;												
input [3:0] duty_cycle;					
input pwm_en;							
output pwm_out;							
reg pwm_out;							
reg [15:0] counter;						
always @(posedge clk)         
begin
	if(pwm_en)
		counter <= counter + 1'b1;
end
always @(posedge clk)      
begin
	if (pwm_en & (counter[15:12] <= duty_cycle))
		pwm_out <= 1'b1;
	else
		pwm_out <= 1'b0;
end

Endmodule

3.直流电动机工作原理

直流电动机可以通过不同的按键来去设置其转向、转速等等内容,这里我主要去讲如何去控制转速问题。

对于电动机转速的理解,我们可以理解成日常生活当中的骑电动车,我们骑电动车的时候并不是一直在加油的,而是加油一定时间之后就让电动车自己利益惯性滑行,然后慢下来再去加油。同样的,直流电动机也是通过这样的方式去调档,输入高电平表示通电(也就是加油),低电平就不通电(此时惯性滑行),如果在一个周期内,高电平占比为99.9%的话我们就表示为最高档,如果占比66.6%我们就表示第二档,占比33.3%就最低档,那剩下的时间就是惯性转动。

这部分就是核心代码了,其中输入包括分频输出的信号,以及按键的三个输入(包括转向控制,转速设置和启动开关)。

module moto_test(clk, pwm_in, k1, k2, k3, duty_cycle, pwm_en, motoa, motob, speed_led);  
input k1, k2, k3, clk, pwm_in;  
output reg pwm_en, motoa, motob;  
output reg [3:0] duty_cycle;  
reg moto_dir;  
reg [2:0] dout1, dout2, dout3, buff, key_edge;  

output reg speed_led; // 新增的输出端口  
  
//新增部分:速度计算和速度LED显示  
reg [15:0] speed_counter; // 用于计算速度的计数器,可以根据需要调整位宽  
reg speed_flag; // 当速度计数器达到设定值时,此标志位置1  
  
initial begin  
    duty_cycle = 4;  
    speed_counter = 0;  
    speed_flag = 0;  
end  
  
// 在每个时钟上升沿,如果电机正在运行(pwm_en为高),则增加速度计数器  
always @(posedge clk) begin  
    if (pwm_en) begin  
        if (k1 || k2 || k3) begin // 如果按键被按下,增加计数器的速度  
            speed_counter <= speed_counter + 1;  
        end else begin // 否则,计数器的速度降低  
            speed_counter <= speed_counter - 1;  
        end  
    end  
end  
  
// 当速度计数器达到设定值时(例如,对应于每秒的转速),将速度LED设置为高电平,否则为低电平  
always @(posedge clk) begin  
    if (speed_flag) begin  
        speed_led <= 2; // 如果速度标志已经设置,那么点亮LED灯  
    end else if (pwm_en) begin  
        speed_led <= 1'b0; // 如果速度标志没有设置,且电机正在运行,那么熄灭LED灯  
    end  
end  
  
// 当速度计数器达到设定值时,设置速度标志,并在下一个时钟周期将其清除  
always @(posedge clk) begin  
    if (speed_counter == 10000) begin // 例如,这里设定为每10000个时钟周期为1秒(可以根据需要调整)  
        speed_flag <= 1'b1;   
    end else begin  
        speed_flag <= 1'b0;   
    end  
end  
//按键消抖部分
always @(posedge clk)
begin
	begin
		dout1 <= {k1,k2,k3};
		dout2 <= dout1;
		dout3 <= dout2;
	end	
end  

//按键边沿检测部分 
always @(posedge clk)
begin
	buff <= dout1 | dout2 | dout3;
	key_edge = ~(dout1 | dout2 | dout3) & buff;
	if(key_edge[0])	//按键1;K3,控制占空比
		begin
			duty_cycle <= duty_cycle + 1'b1;
			if(duty_cycle==8)
				duty_cycle<=1;
		end
	if(key_edge[1])	//按键2;K2,控制电动机启动、停止
		pwm_en <= ~pwm_en;
	if(key_edge[2])	//按键3;K1,控制电机正转与反转
		moto_dir <= ~moto_dir;
	motoa = moto_dir ? pwm_in : 1'b0;
	motob = moto_dir ? 1'b0 : pwm_in;	
end
endmodule

4.电路连接图

写好了Verilog代码,就进行分析错误,分析无误后,我们就对这些代码生成子模块文件。然后就创建block文件开始连接电路图,电路图以及管脚配置如下:

5.文件烧录

弄好了之后就是最后一步操作了,把没用到的管脚设置三态,然后烧录文件。

点击Assignment, Device

然后点击这里,设置管脚状态。  

选择第一个就行了,就是把多余的管脚设置三态。

最后点击此处进行烧录。 

  这里我们会看到,下面有一个芯片,这个也就是我们写好了的sof文件,然后就是通过你的电脑接口去连接到开发板,如果你看到上面有一个No Hardware的时候,你点击旁边的按钮进行接口设置,设置为USB接口即可(USB线连接了你的开发板就会自动显示出来的)。最后点击start就可以进行烧录了。 

以上就是本期的全部内容了,我们下次见!

分享一张壁纸:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1330033.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

农学小作业(根据降雨量计算排灌水量)(旱地版)

//------------------------------------------------------------------------------------------------------------------- //农学小作业(根据降雨量计算排灌水量)(旱地版) //01.参考书目:ISBN-7-80734-087-8.ISBN-7-80124-644-6. //01.农作物生长发育阶段需要消耗水份. //0…

Deepin更换仿Mac主题

上一篇博客说了要写一篇deepin系统的美化教程 先看效果图&#xff1a; 准备工作&#xff1a; 1.你自己 嘻嘻嘻 2.能上网的deepin15.11电脑 首先去下载主题 本次需要系统美化3部分&#xff1a;1.图标 2.光标 3.壁纸 开始之前&#xff0c;请先把你的窗口特效打开&#xff0c;…

【MVT_1703230471】基于Python NLTK分词、词云、LDA主题分类及GPT情感分类

【Talk is cheap】 1 数据探索 case idcase outcome case title case text 0 Case1 cited Alpine Hardwood (Aust) Pty Ltd v Hardys Pty Lt... Ordinarily that discretion will be exercised s... 1 Case2 cited Black v Lipovac [1998] FCA 699 ; (1998) 217 AL... The gen…

Epson爱普生手臂机器人与PC通讯 C#

一、Epson手臂配置 1.安装Epson手臂控制软件 安装Epson手臂控制软体EPSON RC+ 7.0(根据实际需求下载应用),可以去官网下载安装。 2.硬件配置 准备一台PC,用网线连接PC和EPSON手臂控制器。 3.在PC上修改IP地址 EPSON手臂默认IP(192.168.0.1),PC IP改为手臂同一网段…

歌曲春节回家:荆涛歌声中的深情与诗人的心声

歌曲春节回家&#xff1a;荆涛歌声中的深情与诗人的心声 在寒冬的寂静中&#xff0c;荆涛的歌声如同春风拂面&#xff0c;温暖而深情。它唤起了我们对家的思念&#xff0c;让我们感受到家的温暖和亲情的珍贵。而在歌声中&#xff0c;我们仿佛听到了那些描绘春节的经典诗句&…

pycharm修改项目文件夹名称

目录 1 修改项目文件夹名称 2 修改代码中的项目名称 1 修改项目文件夹名称 选中项目文件夹&#xff0c;右键&#xff0c;选择refactor-rename。 选择rename project&#xff1a; 然后输入新的项目名称。 此时进入资源管理器&#xff0c;修改项目文件夹的名字&#xff0c;完成…

Linux 一键部署二进制Gitea

gitea 前言 Gitea 是一个轻量级的 DevOps 平台软件。从开发计划到产品成型的整个软件生命周期,他都能够高效而轻松的帮助团队和开发者。包括 Git 托管、代码审查、团队协作、软件包注册和 CI/CD。它与 GitHub、Bitbucket 和 GitLab 等比较类似。 Gitea 最初是从 Gogs 分支而来…

EarMaster Pro 7 简体中文破解版 v7.2.0.42 电脑版

软件介绍 EarMaster破解版一款功能强大的专业级别多媒体音乐教育学习软件&#xff0c;EarMaster破解版提供了大量音乐相关的学习内容&#xff0c;用户在这里可以学习基础的和弦、音阶、节奏&#xff0c;也可以提升自己的音感&#xff0c;如果基础已经很扎实了&#xff0c;还可…

vue3 + TypeScript使用国际化

vue3 TypeScript使用国际化 本文使用了 Vite 构建工具创建的vue3项目Vite 支持使用特殊的 import.meta.glob 函数从文件系统导入多个模块Vite 官方中文文档当然如果你的vue3项目未使用vite,你也可以为你的旧项目提提速&#xff0c;安装vite &#xff0c;安装方法在上一个博客…

ubuntu 18.04 共享屏幕

用于windows远程ubuntu 1. sudo apt install xrdp 2. 配置 sudo vim /etc/xrdp/startwm.sh 把最下面的test和exec两行注释掉&#xff0c;添加一行 gnome-session 3.安装dconf-editor : sudo apt-get install dconf-editor 关闭require encrytion org->gnome->desktop…

js中将数字转成中文

文章目录 一、实现二、最后 一、实现 如果要将数字10、100和1000转换成中文的"十"、“一百"和"一千”&#xff0c;可以使用以下 JavaScript 代码实现&#xff1a; function numberToChinese(num) {const chineseNums [零, 一, 二, 三, 四, 五, 六, 七, …

华为防火墙小企业简单应用命令行配置

实现&#xff1a; 1、内网访问外网 2、内网和外网访问dmz区ftp服务器 3、开启ftp的aspf功能 4、开启内网黑洞功能 防火墙配置&#xff1a; interface GigabitEthernet1/0/0 undo shutdown ip address 10.0.0.1 255.255.255.0 service-manage ping permit interface GigabitEth…

【Hadoop】 YARN 运行过程/YARN设计目标

YARN 运行过程剖析YARN设计目标 YARN 运行过程剖析 一个Job在YARN中的处理过程&#xff1a; 客户端向RM提交一个job&#xff0c;进入RM中的调度器队列以供调度RM中的AppManager与NM协商协商好一个容器&#xff0c;以启动一个App Master实例App Master启动之后向RM注册并根据Jo…

电脑完全重装教程——原版系统镜像安装

注意事项 本教程会清除所有个人文件 请谨慎操作 请谨慎操作 请谨慎操作 前言 本教程是以系统安装U盘为介质进行系统重装操作&#xff0c;照着流程操作会清除整个硬盘里的文件&#xff0c;请考虑清楚哦&#xff5e; 有些小伙伴可能随便在百度上找个WinPE作为启动盘就直接…

清风数学建模学习笔记--灰色关联分析

一&#xff1a;内容&#xff1a;灰色关联分析 介绍&#xff1a;可以分析多个因素之间&#xff0c;哪一个对y的影响大&#xff0c;哪一个对y的影响小。之前学过回归分析中的标准化回归也可以分析&#xff0c;岭回归&#xff0c;lasso回归等都可以分析&#xff0c;那为什么要使用…

Java基础01 基础语法

文章目录 01 Java概述1、JAVA安装2、HelloWorld3、JAVA概述3.1 JAVA的发展3.2JAVA可以做什么3.2.1 JAVA SE3.2.2 JAVA ME3.2.3 JAVA EE3.2.4 总结 4、JAVA跨平台的原理5、JDK与JRE5.1 JDK5.2 JRE5.3 Other 02 基础语法1、注释2、关键字3、字面量4、变量5、计算机中的数据存储5.…

Vue3+el-table实现甘特图

Vue3 el-table实现甘特图效果 代码gitee 整体实现效果如下 进度列&#xff0c;可以通过设置天或小时&#xff0c;切换不同列显示类型。 涉及到的问题 1、通过Worker解决js线程堵塞问题 在根据时间动态生成列时&#xff0c;由于开始时间与结束时间跨度过大时&#xff0c;计…

Python 运算符 算数运算符 关系运算符 赋值运算符 逻辑运算 (逻辑运算符的优先级) 位运算 成员运算符 身份运算符 运算符的优先级

1 运算符算数运算符关系运算符赋值运算符逻辑运算逻辑运算符的优先级 位运算布尔运算符移位运算符 成员运算符身份运算符运算符的优先级 运算符 算数运算符 四则运算 - * / a 8 b 9 print(ab)#与Java类似 也可以进行字符串的连接 注意:字符串数字字符串 不存在会抛出异常…

Vue项目如何打包

1. 确保你已经在项目根目录下安装了Vue CLI。如果没有安装&#xff0c;可以通过以下命令进行安装&#xff1a; npm install -g vue/cli 2. 在项目根目录下打开终端或命令行工具&#xff0c;运行以下命令来创建一个生产环境的打包文件&#xff1a; npm run build 这个命令会执…

异丙醇蒸汽干燥晶圆法

在半导体制程中&#xff0c;大多数的朋友对于晶圆干燥的印象还停留在旋转式甩干机&#xff08;SRD&#xff09;的阶段。晶圆旋转式甩干是目前最普遍的一种晶圆甩干方式&#xff0c;但是在很多工序中&#xff0c;并不太适合用旋转式甩干机&#xff0c;那么IPA&#xff08;异丙醇…