Down-Sampling 降采样(Verilog)

这篇具有很好参考价值的文章主要介绍了Down-Sampling 降采样(Verilog)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

简介

         在图像处理领域中,降采样是一个非常常用的图像处理方法,目的是为了在大体上不改变图片的情况下,缩小图像,降低分辨率,减少数据的计算量,生成对应图像的降采样图。本质就是抽取图像数据来降低特征的维度进而保留有效的信息。

原理

         对一个需要处理的图片的像素值序列间隔几个像素值取样一次,也就是抽取像素值,得到的新的像素值序列就是原像素值序列的降采样,也称为下采样。 

         降采样分为整数倍降采样和分数倍降采样,在这篇文章中,介绍的是比较常用的 2 倍降采样,也可以说是奇数降采样或偶数降采样。

模块端口图

降采样,fpga开发

         这里把 RGB 数据的三个通道都列了出来,当然也可以用其他的图像数据格式,如:YUV 。

设计文件代码

         以下为降采样的设计代码,留下的是偶数列的图像数据。代码中控制计数器的为 MCNT,也就是计数最大值,这个视情况而定,也可用数据有效信号(Data_valid)来控制计数器。 

   module Down_Sampling(
          Data_in_r,
          Data_in_g, 
          Data_in_b,

          clk,
          rst_n,
 
          Data_out_r,
          Data_out_g,
          Data_out_b,

);


       input [7:0] Data_in_r;
       input [7:0] Data_in_g;
       input [7:0] Data_in_b;

       input clk;
       input rst_n;

       output [7:0] Data_out_r;
       output [7:0] Data_out_g;
       output [7:0] Data_out_b;


       parameter MCNT = 根据情况定 也可用数据有效信号控制;

          reg [10:0] Data_cnt;
   always@(posedge clk or negedge rst_n)
         if(!rst_n)
              Data_cnt <= 0;
         else if(Data_cnt == MCNT) 
              Data_cnt <= 0;
         else 
              Data_cnt <= Data_cnt + 1;

   always@(posedge clk or negedge rst_n)
         if(!rst_n)begin
              Data_out_r <= 0;
              Data_out_g <= 0;
              Data_out_b <= 0;
         end
         else if(!Data_cnt[0])begin
              Data_out_r <= Data_in_r;
              Data_out_g <= Data_in_g;
              Data_out_b <= Data_in_b;
            end  
            else begin
              Data_out_r <= Data_out_r;
              Data_out_g <= Data_out_g;
              Data_out_b <= Data_out_b;
            end

      
endmodule

         以下为留下奇数列的图像数据。文章来源地址https://www.toymoban.com/news/detail-633171.html

   module Down_Sampling(
          Data_in_r,
          Data_in_g, 
          Data_in_b,

          clk,
          rst_n,
 
          Data_out_r,
          Data_out_g,
          Data_out_b,

);


       input [7:0] Data_in_r;
       input [7:0] Data_in_g;
       input [7:0] Data_in_b;

       input clk;
       input rst_n;

       output [7:0] Data_out_r;
       output [7:0] Data_out_g;
       output [7:0] Data_out_b;


       parameter MCNT = 根据情况定 也可用数据有效信号控制;

          reg [10:0] Data_cnt;
   always@(posedge clk or negedge rst_n)
         if(!rst_n)
              Data_cnt <= 0;
         else if(Data_cnt == MCNT) 
              Data_cnt <= 0;
         else 
              Data_cnt <= Data_cnt + 1;

   always@(posedge clk or negedge rst_n)
         if(!rst_n)begin
              Data_out_r <= 0;
              Data_out_g <= 0;
              Data_out_b <= 0;
         end
         else if(Data_cnt[0])begin
              Data_out_r <= Data_in_r;
              Data_out_g <= Data_in_g;
              Data_out_b <= Data_in_b;
            end  
            else begin
              Data_out_r <= Data_out_r;
              Data_out_g <= Data_out_g;
              Data_out_b <= Data_out_b;
            end

      
endmodule

到了这里,关于Down-Sampling 降采样(Verilog)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 基于Verilog 语言开发的FPGA密码锁工程

    基于Verilog 语言开发的FPGA密码锁工程。 通过矩阵键盘输入按键值。 输入12修改密码,13清除密码,可以修改原来默认的密码,修改时首先要输入当前密码进行验证,正确后才能更新当前密码,否则修改不成功。 修改结束后按键15,确认修改成功。 也直接使用默认密码作为最终

    2024年02月10日
    浏览(59)
  • 基于FPGA的FSK调制解调系统verilog开发

    目录 1.算法仿真效果 2.verilog核心程序 3.算法涉及理论知识概要 4.完整verilog VIVADO2019.2仿真结果如下:       频移键控是利用载波的频率变化来传递数字信息。数字频率调制是数据通信中使用较 早的一种通信方式,由于这种调制解调方式容易实现,抗噪声和抗衰减性能较强,

    2024年02月05日
    浏览(77)
  • FPGA开发] 使用Verilog实现一个简单的计数器

    计数器是数字电路中常见的元件之一,它能够按照一定的规律进行计数。在FPGA开发中,我们可以使用硬件描述语言Verilog来实现一个简单的计数器。本文将为您详细介绍如何使用Verilog编写一个基于FPGA的计数器,并提供相应的源代码。 首先,我们需要定义计数器的功能和规格

    2024年02月03日
    浏览(61)
  • 基于vivado+Verilog FPGA开发 — GT收发器

    代码规范:Verilog 代码规范_verilog代码编写规范-CSDN博客 开发流程:FPGA基础知识----第二章 FPGA 开发流程_fpga 一个项目的整个流程-CSDN博客   源码下载:GitHub - Redamancy785/FPGA-Learning-Record: 项目博客:https://blog.csdn.net/weixin_51460407 零、低速通信接口的缺陷 1、同步通信要求传输数据

    2024年04月17日
    浏览(64)
  • fpga开发基于verilog HDL的四人抢答器

    鱼弦:CSDN内容合伙人、CSDN新星导师、全栈领域创作新星创作者 、51CTO(Top红人+专家博主) 、github开源爱好者(go-zero源码二次开发、游戏后端架构 https://github.com/Peakchen) 智能电子抢答器可容纳4组参赛者抢答,每组设一个抢答钮。 ③ 电路具有第一抢答信号的鉴别和锁存功能。

    2024年02月04日
    浏览(49)
  • 密码锁设计Verilog代码Quartus 睿智FPGA开发板

    名称:密码锁设计Verilog代码Quartus  睿智FPGA开发板(文末获取) 软件:Quartus 语言:Verilog 代码功能: 1、设计一个密码锁的控制电路,当输入正确代码时,输岀开锁信号用红灯亮、绿灯 熄灭表示关锁,用绿灯亮、红灯熄灭表示开锁 2、在锁的控制电路中储存一个可以修改的4位代

    2024年01月18日
    浏览(51)
  • 基于FPGA的7x7矩阵求逆verilog开发

    up目录 一、理论基础 二、核心程序 三、测试结果       要通过Verilog实现矩阵求逆,需要进行复杂的硬件设计,这是一个相当复杂的任务,特别是对于大型矩阵。矩阵求逆涉及到大量的浮点运算和存储操作,因此需要高度的硬件设计和优化。以下是一般步骤,可以帮助您开始

    2024年02月15日
    浏览(62)
  • 【Verilog实现8个输入1个输出的选择器】--FPGA开发

    【Verilog实现8个输入1个输出的选择器】–FPGA开发 在FPGA开发中,选择器是一种重要的电路,它可以将多个输入端口上的数据选择一个输出端口进行传输。通过Verilog语言实现选择器,我们可以灵活地根据实际需求来配置输入和输出端口,提高FPGA的功能和性能。 下面,我们将讨

    2024年02月07日
    浏览(44)
  • Quartus数字秒表verilog代码青创QC-FPGA开发板

    名称:Quartus数字秒表verilog代码青创QC-FPGA开发板(文末获取) 软件:Quartus 语言:Verilog 代码功能: 数字秒表设计 1、支持复位、启动、暂停 2、具有量程切换功能,可以切换显示小时、分钟或者秒、毫秒 3、数码管显示时间,精确到10毫秒 FPGA代码Verilog/VHDL代码资源下载:www.hd

    2024年02月03日
    浏览(41)
  • 基于FPGA的4x4矩阵键盘控制器verilog开发实现

    欢迎订阅《FPGA学习入门100例教程》、《MATLAB学习入门100例教程》 目录 一、理论基础 二、核心程序 三、测试结果        基于FPGA的4x4矩阵键盘控制器是一种使用FPGA(现场可编程门阵列)来实现对4x4矩阵键盘进行控制的设备。该控制器能够有效地降低硬件资源的使用,提高系

    2024年02月11日
    浏览(51)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包