通过FPGA实现基于RS232串口的指令发送并控制显示器中目标位置

目录

1.算法理论概述

串口通信模块

指令解析模块

位置控制模块

显示器驱动模块

2.部分核心程序

3.算法运行软件版本

4.算法运行效果图预览

5.算法完整程序工程


1.算法理论概述

        通过FPGA实现基于RS232串口的指令发送并控制显示器中目标位置是一种常见的应用场景,用于实现对显示器中目标位置的控制。该系统利用FPGA芯片作为主控制器,通过RS232串口与计算机或其他设备进行通信,接收指令并解析,然后控制显示器中目标位置的移动。该系统的主要原理是利用FPGA芯片作为主控制器,通过RS232串口与计算机或其他设备进行通信。计算机通过串口发送指令到FPGA,FPGA接收并解析指令,然后根据指令控制显示器中目标位置的移动。系统主要包括串口通信模块、指令解析模块、位置控制模块和显示器驱动模块。

  • 串口通信模块

串口通信模块用于与计算机或其他设备进行数据交互。通过RS232串口协议,实现数据的发送和接收。具体实现步骤包括串口初始化、数据发送和数据接收。

  • 指令解析模块

指令解析模块用于解析接收到的指令,提取控制参数。指令可以是设定目标位置的命令,例如“MOVE X=100 Y=200”,其中X和Y为目标位置的横纵坐标。指令解析模块通过解析指令中的参数,提取目标位置的横纵坐标。

  • 位置控制模块

       位置控制模块根据解析得到的目标位置,通过控制信号控制显示器中目标位置的移动。具体实现步骤包括生成控制信号和发送控制信号。控制信号可以是电平信号或PWM信号,用于控制显示器中的驱动器。

这里,串口发射的数据格式如下: 

帧头

16个1

表示帧头

8bit

是否显示

文字

8bit+8bit

X坐标

8bit+8bit

Y坐标

8bit+8bit

X长度

8bit+8bit

Y坐标

8bit+8bit

校验

  • 显示器驱动模块

       显示器驱动模块接收位置控制模块发送的控制信号,将其转换为显示器可以识别的信号。显示器驱动模块根据控制信号,控制显示器中的电机或其他执行器,使目标位置实现移动。

       实现该系统的关键在于FPGA的编程和配置,以及串口通信的数据交互和指令解析的算法设计。此外,还需要根据具体的显示器和驱动器的接口要求进行信号转换和电平调整。

2.部分核心程序

..................................................................
wire RST;
assign RST = ~reset;wire clk50M;
wire clk25M;
CLK_dcm CLK_dcm_u(// Clock in ports.CLK_IN1 (clk50),      // IN// Clock out ports.CLK_OUT1(clk50M),     // OUT.CLK_OUT2(clk25M));    // OUT//根据输入使能信号产生行列计数器,用来进行定位
//根据输入使能信号产生行列计数器,用来进行定位
//根据输入使能信号产生行列计数器,用来进行定位
wire [4:0] wvga_r;
wire [5:0] wvga_g;
wire [4:0] wvga_b;
wire [10:0]x_cnt;
wire [9:0] y_cnt;	
wire       vga_hsync;
wire       vga_vsync;
//VGA显示控制部分
vga_disp	vga_disp_inst(.vga_clk                 (clk25M),.vga_rst                 (RST),	.ddr_data_vga            (64'd0),      //如果使用DDR送入视频,那么从这里输入即可,我这边测试则不考虑,这里空出来.vga_r                   (wvga_r),     //DDr转换为R,.vga_g                   (wvga_g),     //DDr转换为G, .vga_b                   (wvga_b),     //DDr转换为B,.vga_hsync               (vga_hsync),	.vga_vsync               (vga_vsync),.ddr_addr_rd_set         (),     //ddr_addr_rd_set.ddr_rden                (),     //ddr_rden.ddr_rd_cmd              (),     //ddr_rd_cmd.x_cnt                   (x_cnt),.y_cnt                   (y_cnt));//串口输入信号
//串口输入信号
//串口输入信号
//串口输入信号
wire[15:0]w_head;
wire[7 :0]w_text_view;
wire[15:0]w_x;
wire[15:0]w_y;
wire[15:0]w_w;
wire[15:0]w_h;
wire clk_data;
wire clk;
UART_signal instance_name (.clk50      (clk50M), .rx         (rx), .reset      (RST), .LED_test   (), .o_head     (w_head), .o_text_view(w_text_view), .o_x        (w_x), .o_y        (w_y), .o_w        (w_w), .o_h        (w_h), .clk_data   (clk_data),.clk        (clk));reg[15:0]r_head;
reg[7 :0]r_text_view;
reg[15:0]r_x;
reg[15:0]r_y;
reg[15:0]r_w;
reg[15:0]r_h;	 always @(posedge clk50M or posedge RST)   
beginif(RST)beginr_head      <= 16'd0;r_text_view <= 8'd0;r_x         <= 16'd0;r_y         <= 16'd0;r_w         <= 16'd0;r_h         <= 16'd0;	  end
else beginr_head      <= w_head;r_text_view <= w_text_view;r_x         <= w_x;r_y         <= w_y;r_w         <= w_w;r_h         <= w_h;	end
end//字体显示
/
wire w_FLAG1;
test_load test_load_u(.i_clk (clk25M), .i_rst (RST), .i_en  (r_text_view[7]|r_text_view[6]|r_text_view[5]|r_text_view[4]|r_text_view[3]|r_text_view[2]|r_text_view[1]|r_text_view[0]),.i_xcnt(x_cnt), //根据H和V的使能,得到视频区域的计数器.i_ycnt(y_cnt), //根据H和V的使能,得到视频区域的计数器.o_FLAG(w_FLAG1));/
wire w_FLAG2;	 
box_load box_load_u(.i_clk   (clk25M), .i_rst   (RST), .i_xcnt  (x_cnt), //根据H和V的使能,得到视频区域的计数器.i_ycnt  (y_cnt), //根据H和V的使能,得到视频区域的计数器.i_width (r_w), //16'd300.i_height(r_h), //16'd200.i_xc    (r_x), //16'd1000.i_yc    (r_y), //16'd300.o_flag  (w_FLAG2));		 wire[7:0]CCD_R;
wire[7:0]CCD_G;
wire[7:0]CCD_B;wire[7:0]CCD_R1;
wire[7:0]CCD_G1;
wire[7:0]CCD_B1;assign CCD_R1=(w_FLAG1==1'b1)?8'd255:{wvga_r,3'd0};
assign CCD_G1=(w_FLAG1==1'b1)?8'd255:{wvga_g,2'd0};
assign CCD_B1=(w_FLAG1==1'b1)?8'd255:{wvga_b,3'd0};assign CCD_R=(w_FLAG2==1'b1)?8'd255:{CCD_R1};
assign CCD_G=(w_FLAG2==1'b1)?8'd255:{CCD_G1};
assign CCD_B=(w_FLAG2==1'b1)?8'd255:{CCD_B1};assign vga_r=CCD_R[7:3];
assign vga_g=CCD_G[7:2];
assign vga_b=CCD_B[7:3];//在线信号检测,实际最后可以删除
//在线信号检测,实际最后可以删除
//在线信号检测,实际最后可以删除	
//在线信号检测,实际最后可以删除
wire[99:0]testdata;assign testdata[15:0]  = r_head;
assign testdata[23:16] = r_text_view; 
assign testdata[39:24] = r_x; 
assign testdata[55:40] = r_y; 
assign testdata[71:56] = r_w; 
assign testdata[87:72] = r_h; 
assign testdata[88]    = clk_data; 
assign testdata[89]    = clk; Chipscop Chipscop_u(.i_clk(clk), .trig(8'b0000_0000), .testdata(testdata));endmodule
13_014m

3.算法运行软件版本

MATLAB2022a

ISE14.7

芯片型号:

 使用的FPGA开发板型号如下:

黑金AX545开发板SPARTANT6 XC6S LX45

4.算法运行效果图预览

5.算法完整程序工程

OOOOO

OOO

O

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

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

相关文章

Prompt 技巧指南-让 ChatGPT 回答更准确

随着 ChatGPT 等大型语言模型 (LLM)的兴起&#xff0c;人们慢慢发现&#xff0c;怎么样向 LLM 提问、以什么技巧提问&#xff0c;是获得更加准确的回答的关键&#xff0c;也由此产生了提示工程这个全新的领域。 提示工程(prompt engineering)是一门相对较新的领域&#xff0c;用…

java学习003

Java数组 Java 语言中提供的数组是用来存储固定大小的同类型元素&#xff0c;这一点和PHP语言的可变数组长度不同。 声明变量数组 首先必须声明数组变量&#xff0c;才能在程序中使用数组。下面是声明数组变量的语法&#xff1a; dataType[] arrayRefVar; // 首选的方法 或 …

云计算——云计算与虚拟化的关系

作者简介&#xff1a;一名云计算网络运维人员、每天分享网络与运维的技术与干货。 座右铭&#xff1a;低头赶路&#xff0c;敬事如仪 个人主页&#xff1a;网络豆的主页​​​​​ 目录 前言 一.虚拟化 1.什么是虚拟化 2.虚拟化技术作用 二.云计算与虚拟化的关系 三.虚…

华为eNSP:ospf的配置

一、拓扑图 二、路由器的配置 1、路由器依据规划配置接口IP AR1: <Huawei>system-view [Huawei]int g0/0/0 [Huawei-GigabitEthernet0/0/0]ip add 10.10.10.1 24 [Huawei-GigabitEthernet0/0/0]qu AR2: <Huawei>system-view [Huawei]int g0/0/0 [Huawei-Gi…

RabbitMQ消息可靠性问题及解决

说明&#xff1a;在RabbitMQ消息传递过程中&#xff0c;有以下问题&#xff1a; 消息没发到交换机 消息没发到队列 MQ宕机&#xff0c;消息在队列中丢失 消息者接收到消息后&#xff0c;未能正常消费&#xff08;程序报错&#xff09;&#xff0c;此时消息已在队列中移除 …

STM32(HAL库)驱动AD8232心率传感器

目录 1、简介 2、CubeMX初始化配置 2.1 基础配置 2.1.1 SYS配置 2.1.2 RCC配置 2.2 ADC外设配置 2.3 串口外设配置 2.4 GPIO配置 2.5 项目生成 3、KEIL端程序整合 3.1 串口重映射 3.2 ADC数据采集 3.3 主函数代码整合 4 硬件连接 5 效果展示 1、简介 本文通过STM32…

Linux文件处理命令

目录&#xff1a; linux系统与shell环境准备linux常用命令之文件处理Linux系统登录与文件操作 1.linux系统与shell环境准备 Linux 系统简介&#xff1a; Linux 内核最初只是由芬兰人林纳斯托瓦兹&#xff08;Linus Torvalds&#xff09;在赫尔辛基大学上学时出于个人爱好而…

分布式光伏并网防孤岛保护装置AM5SE-IS

分布式光伏并网防孤岛保护装置AM5SE-IS 应用场景 防孤岛原理&#xff1a;防孤岛保护装置检测到并网点有逆功率、频率突变、 等异常数据时&#xff0c;即发生孤岛现象时&#xff0c;装置可配合断路器快速切除并网点&#xff0c;使本站与电网侧快速脱离&#xff0c;保证整个电站…

blender 纹理材质

添加材质纹理需要哪五个节点&#xff1f; 映射节点&#xff1a;调整纹理的位置、大小、缩放&#xff1b; 纹理坐标&#xff1a;怎么映射&#xff0c;以什么方式去映射这张图&#xff0c;换句话说就是如何将 2D 的图片映射到 3D 的图像上&#xff1b;纹理坐标就是以什么坐标方式…

Flutter系列(3):如何将Flutter项目打包成Android安装包

将Flutter项目打包成Android安装包&#xff0c;主要步骤如下&#xff1a; 一、生成key 进入jdk的bin目录下&#xff1a; keytool -genkey -v -keystore D:\key.jks -keyalg RSA -keysize 2048 -validity 10000 -alias key 大概会有密码等参数&#xff0c;根据自身需要&#x…

Mysql数据库

目录 1.数据库 2.数据库分类与常见的数据库 3.SQL 3.1.DDL 数据库操作 表操作 3.2.DML 3.3.DQL 3.4.DCL 管理用户 权限控制 4.Mysql常用的数据类型 1.数据库 数据库:是“按照数据结构来组织、存储和管理数据的仓库”。是一个长期存储在计算机内的、有组织的、可共…

Spring MVC异常处理【单个控制异常处理器、全局异常处理器、自定义异常处理器】

目录 一、单个控制器异常处理 1.1 控制器方法 1.2 编写出错页面 1.3 测试结果 二、全局异常处理 2.1 一个有异常的控制器类 2.2 全局异常处理器类 2.3 测试结果 三、自定义异常处理器 3.1 自定义异常处理器 3.2 测试结果 往期专栏&文章相关导读 1. Maven系列…

只需3步,使用Stable Diffusion无限生产AI数字人视频

效果演示 先看效果&#xff0c;感兴趣的可以继续读下去。 没有找到可以上传视频的地方&#xff0c;大家打开这个网盘链接观看&#xff1a;https://www.aliyundrive.com/s/CRBm5NL3xAE 基本方法 搞一张照片&#xff0c;搞一段语音&#xff0c;合成照片和语音&#xff0c;同…

SpringBoot+jasypt-spring-boot-starter实现配置文件明文加密

1.使用环境 springboot:2.1.4.RELEASE JDK:8 jasypt-spring-boot-starter:3.0.2 2.引入依赖 !-- 配置文件加密 --> <dependency><groupId>com.github.ulisesbocchio</groupId><artifactId>jasypt-spring-boot-starter</artifactId><ver…

uni-app:请求后端数据uni.request

完整代码&#xff1a; onLoad() {uni.request({url: getApp().globalData.position Produce/select_employee,data: {username: getApp().globalData.username,},method: POST,dataType: json,success: res > {this.employee_name res.data.info.employee_name;// consol…

sketch如何在线打开?有没有什么软件可以辅助

Sketch 在线打开的方法有哪些&#xff1f;这个问题和我之前回答过的「Sketch 可以在线编辑吗&#xff1f;」是一样的答案&#xff0c;没有。很遗憾&#xff0c;Sketch 没有在线打开的方法&#xff0c;Sketch 也做不到可以在线编辑。那么&#xff0c;那些广告里出现的设计软件工…

数学建模学习(4):TOPSIS 综合评价模型及编程实战

一、数据总览 需求&#xff1a;我们需要对各个银行进行评价&#xff0c;A-G为银行的各个指标&#xff0c;下面是银行的数据&#xff1a; 二、代码逐行实现 清空代码和变量的指令 clear;clc; 层次分析法 每一行代表一个对象的指标评分 p [8,7,6,8;7,8,8,7];%每一行代表一个…

Docker 基本管理

目录 一、Docker 概述 二、为什么容器越来越受欢迎&#xff1f; 三、Docker 与 虚拟机 的区别 四、 Linux Namespace的6大类型 五、Docker 核心概念 1.镜像 2.容器 3.仓库 六、安装 Docker 1.安装依赖包 2.设置阿里云镜像源&#xff0c;安装Docker 3.查看 docker 版…

PostgreSQL 的事务管理和并发控制机制解析

&#x1f337;&#x1f341; 博主 libin9iOak带您 Go to New World.✨&#x1f341; &#x1f984; 个人主页——libin9iOak的博客&#x1f390; &#x1f433; 《面试题大全》 文章图文并茂&#x1f995;生动形象&#x1f996;简单易学&#xff01;欢迎大家来踩踩~&#x1f33…

BEVPoolv2 A Cutting-edge Implementation of BEVDet Toward Deployment 论文学习

Github Repo: https://github.com/HuangJunJie2017/BEVDet/tree/dev2.0 Arxiv Paper: https://arxiv.org/abs/2211.17111 1. 解决了什么问题&#xff1f; 多相机 3D 目标检测是自动驾驶领域的基本任务&#xff0c;受到学术界和工业界的大量关注。Lift-Splat-Shoot view trans…