BT.656 NTSC制式彩条生成模块(verilog)

1.知识储备

隔行扫描是将一副图像分成两场扫描,第一场扫描第1,2,5,7...等奇数行,第二场扫描2,4,6,8...等偶数行,并把扫奇数行的场称为奇数场,扫偶数行的场称为偶数场,一幅图像经过两次扫描即可。由左到右的扫描称为行扫描,由上到下的扫描称为场扫描。

对于标准的8bit BT656(YUV4:2:2)标清制式来说,一帧图像的格式定义如下:

一行是由4个部分组成:行 = 结束码(EAV) + 水平消隐(Horizontal Vertical Blanking) + 起始码(SAV) + 有效数据(Active Video)

注意:实际的工程中彩条每一行像素点的排列并不是这样的,而是(SAV Code ->Active video->EAV Code->Blanking video)

2.代码分析

TPG端口说明:

reset_in:由SDI播出工程内部信号提供。

pclk_in:与播出时钟tx_usrclk对接。

data_out:输出图像数据。

tx_sd_ce:门控时钟(SD-SDI,5/6/5/6)

并且初识化像素位置pixels=1,行位置lines=1,即图像扫描的初始位置。

彩条中各种色彩值设定(忽略十进制的数字,部分有误),同时定义了用来存储当前颜色的寄存器cur_color

定义常数,总共有多少行,多少列(1716 ,525)

彩条颜色分配函数,通过像素点的位置来分配当前位置的颜色。

有效像素点的排列如下图所示:

pixels初始值为1,则

01:Cb

10:Y

11:Cr

00:Y

01:Cb

通过pixels[0],pixels[1:0]来分割cur_color,得到colorValue.

以下always块里面是行扫描和场扫描控制,当一行扫描完成后,pixels回到初始位置,line加1.

根据行来控制F,V的值:

每一行的像素排列,一定要注意顺序SAV(FF,00,00,XY),接下来的是Active video,然后是EAV(FF,00,00,XY),最后是Blanking video,用80,10填充。

视频数据的输出:

颜色数据是8位的,SDI工程接收的是10bit的数据,如果要对接,就需要进行低位填充,当数据是ff时,低2位填充11,当数据不是ff时,低2位填充00.

module tpg(
reset_in,
pclk_in,
pclk_out,
data_out,
pixels_out,
tx_sd_ce
); input reset_in;
input pclk_in;
input tx_sd_ce;
output pclk_out;
output [:]data_out;
output [:]pixels_out; reg [:] pixels = ;
reg [:] lines = ;
reg [:] data;
reg F, V; wire [:] pixels_w; `define V_TOTAL_SIZE
`define V_ACTIVE_SIZE //* 240 line
`define V_BLANK_SIZE //* 22 line `define H_TOTAL_SIZE
`define H_ACTIVE_SIZE //* 1444 pixel (4(SAV) + 720*2(Y+Cr/Cb))
`define H_BLANK_SIZE //* 272 pixel (4(EAV) + 268) `define H_COUNT_ADD_ONE 'b1
`define V_COUNT_ADD_ONE 'b1 //* Y, Cb, Cr values for test pattern colours
//* 75% amplitude, 100% saturated
//* Values from "Video De-mystified" book, chapter 3
reg [:] white = {'heb, 8'h80, 'h80};//{8'd235, 'd128, 8'd128};
reg [:] black = {'h10, 8'h80, 'h80};//{8'd16, 'd128, 8'd128};
reg [:] blue = {'h29, 8'hf0, 'h6e};//{8'd35, 'd212, 8'd114};
reg [:] green = {'h91, 8'h36, 'h22};//{8'd112, 'd72, 8'd58};
reg [:] red = {'h51, 8'h5a, 'hf0};//{8'd65, 'd100, 8'd212};
reg [:] cyan = {'haa, 8'ha6, 'h10};//{8'd131, 'd156, 8'd44};
reg [:] yellow = {'hd2, 8'h10, 'h92};//{8'd162, 'd44, 8'd142};
reg [:] magenta = {'h6a, 8'hca, 'hde};//{8'd84, 'd184, 8'd198};
reg [:] cur_color; //产生图像数据,数据8个8个出
function [:] colorValue;
input [:] pixels;
begin
if( > pixels)
cur_color = white;
else if( > pixels)
cur_color = black;
else if( > pixels)
cur_color = blue;
else if( > pixels)
cur_color = green;
else if( > pixels)
cur_color = red;
else if( > pixels)
cur_color = cyan;
else if( > pixels)
cur_color = yellow;
else
cur_color = magenta; //* Y
if(pixels[] == 'h0)
colorValue = cur_color[:];
//* Cr and Cb
else if(pixels[:] == 'h1)
colorValue = cur_color[:]; //* Cb
else
colorValue = cur_color[:]; //* Cr
end
endfunction //复位,pixels和lines都归1,像素值逐渐增加,当一行的像素填充完后
//继续扫描下一行,即lines加1
always @ (posedge pclk_in)
if(reset_in)
begin
pixels <= ;
lines <= ;
end
else if(tx_sd_ce)
begin
if(pixels < `H_TOTAL_SIZE)
pixels <= pixels + `H_COUNT_ADD_ONE;
else
begin
pixels <= ;
if(lines < `V_TOTAL_SIZE)
lines <= lines + `V_COUNT_ADD_ONE;
else
lines <= ;
end
end //通过bt656标准,行结构的分布来确定F,V
always @ (posedge pclk_in)
if(reset_in)
data <= 'h00;
else if(tx_sd_ce)
begin
//* even field is 1
if(lines< || lines>)
F <= ;
else
F <= ; //* vertical blank is 1
if(lines< || (lines> && lines<))
V <= ;
else
V <= ; /*
if(pixels <=1440)
begin
if( V== 1)
data <= (pixels[0] == 1) ? 8'h80 : 8'h10;
else
data <= colorValue(pixels);
end
else if(pixels == 1441)
data <= 8'hFF;
else if(pixels == 1442)
data <= 8'h00;
else if(pixels == 1443)
data <= 8'h00;
else if(pixels == 1444)
begin
//* EAV is 1
//H <= 1;
//data <= { 1'b1, F, V, H, (V ^ H), (F ^ H), (F ^V ), (F ^ V ^ H) };
data <= { 1'b1, F, V, 1'b1, (V ^ 1'b1), (F ^ 1'b1), (F ^ V ), (F ^ V ^ 1'b1) };
end
else if(pixels <= 1712)
data <= (pixels[0] == 1) ? 8'h80 : 8'h10;
else if(pixels == 1713)
data <= 8'hFF;
else if(pixels == 1714)
data <= 8'h00;
else if(pixels == 1715)
data <= 8'h00;
else if(pixels == 1716)
begin
//* SAV is 0
//H <= 0;
//data <= { 1'b1, F, V, H, (V ^ H), (F ^ H), (F ^V ), (F ^ V ^ H) };
data <= { 1'b1, F, V, 1'b0, (V ^ 1'b1), (F ^ 1'b1), (F ^ V ), (F ^ V ^ 1'b1) };
end
end
*/
if(pixels == )
data <= 'hFF;
else if(pixels == )
data <= 'h00;
else if(pixels == )
data <= 'h00;
else if(pixels == )
begin
//* EAV is 1 //换成sav
//H <= 1;
//data <= { 1'b1, F, V, H, (V ^ H), (F ^ H), (F ^V ), (F ^ V ^ H) };
data <= { 'b1, F, V, 1'b0, (V ^ 'b1), (F ^ 1'b1), (F ^ V ), (F ^ V ^ 'b1) };
end
else if(pixels <= ) //* horizontal blanking pixel
begin
if( V== )
data <= (pixels[] == ) ? 'h80 : 8'h10;
else
data <= colorValue(pixels);
end
else if(pixels == )
data <= 'hFF;
else if(pixels == )
data <= 'h00;
else if(pixels == )
data <= 'h00;
else if(pixels == )
begin
//* SAV is 0 //换成eav
//H <= 0;
//data <= { 1'b1, F, V, H, (V ^ H), (F ^ H), (F ^V ), (F ^ V ^ H) };
data <= { 'b1, F, V, 1'b1, (V ^ 'b0), (F ^ 1'b0), (F ^ V ), (F ^ V ^ 'b0) };
end
else //* horizontal active pixel
//* if vertical blank, fill with 0x80, 0x10
data <= (pixels[] == ) ? 'h80 : 8'h10;
end assign pclk_out = pclk_in;
assign data_out = (data == 'hff) ? {data, 2'b11} : {data, 'b00};
assign pixels_out = pixels; assign pixels_w = pixels;
endmodule

BT.656 NTSC制式彩条生成模块(verilog)的更多相关文章

  1. 标准BT.656并行数据结构

    转自网络,感谢原作者和转载者. 还有参考:百科http://baike.baidu.com/link?url=bqBT3S7pz_mRJoQE7zkE0K-R1RgQ6FmHNOZ0EjhlSAN_o ...

  2. ITU-R BT.656 协议

    ITU-R BT.601和ITU-R BT.656国际电信联盟(International Telecommunication Union)无线通信部门(ITU-R)制定的标准.严格来说,ITU-R ...

  3. BT.656视频信号解码

    BT.656视频信号解码   BT.656协议标准 ITU-R BT.601和ITU-R BT.656是ITU-R(国际电信联盟)制定的标准.严格来说ITU-R BT.656是ITU-R BT.601 ...

  4. BT.656

    转自http://www.cnblogs.com/s_agapo/archive/2012/04/08/2437775.html 凡是做模拟信号采集的,很少不涉及BT.656标准的,因为常见的模拟视频 ...

  5. Yii1使用Gii生成模块实现CURD

    Yii里Gii的强大就不用说了,可以快速生成模块的Model.Controller来开发.要使用Gii,首先你需要创建好操作的数据表. 第一步:创建数据表 CREATE TABLE `t_knowle ...

  6. 信号滤波模块verilog代码---UNLOCK,LOCK状态机方式

    信号滤波模块verilog代码 `timescale 1ns / 1ps /////////////////////////////////////////////////////////////// ...

  7. thinkphp3.2自动生成模块BIND_MODULE

    thinphp3.2中提供了自定义生成模块与控制器的常量,分别是BIND_MODULE,BUILD_CONTROLLER_LIST 在 index.php 文件中定义 BIND_MODULE,BUIL ...

  8. TP自动生成模块目录

    TP自动生成模块目录 例如我想在项目中增加一个AdminI模块 只需要在入口文件index.php中添加: define('BIND_MODULE','Admin'); 再访问127.0.0.1项目就 ...

  9. 微信小程序条码、二维码生成模块

    代码地址如下:http://www.demodashi.com/demo/13994.html 一.前期准备工作 软件环境:微信开发者工具 官方下载地址:https://mp.weixin.qq.co ...

随机推荐

  1. 1--Python 入门--Python基础数据类型

    一.Python基础语法 初次使用Python,首先要明确三点: Python的标识符(例如变量名.函数名等),可用字母.数字和下划线构成,不能以数字开头,且区分大小写. Python对于缩进敏感.在 ...

  2. SSL/TLS Server supports TLSv1.0

    远程登录服务器后打开注册表编辑器,点开HKEY-LOCAL-MACHINE,SYSTEM,CURRENTCONTROLSET下的Control 找到SecurityProviders下的SCHANNE ...

  3. 微信小程序--地图上添加图片

    如何在微信小程序地图添加上,添加图片? 在微信小程序中,地图的层级最高,所以我们没有办法,通过定位,在地图上添加图片等信息; 处理办法: 添加控件:controls; 其中有个属性position,进 ...

  4. Android Native Hook技术(二)

    Hook技术应用 已经介绍了安卓 Native hook 原理,这里介绍 hook 技术的应用,及 Cyida Substrate 框架. 分析某APP,发现其POST请求数据经过加密,我们希望还原其 ...

  5. Java 构造器Constructor 继承

    Java默认构造方法 构造方法作用:初始化所定义的类的对象和属性. 构造方法没有返回类型. 2 继承中的构造器 子类是不继承父类的构造器(构造方法或者构造函数)的,它只是调用(隐式或显式). 如果父类 ...

  6. [LeetCode&Python] Problem 506. Relative Ranks

    Given scores of N athletes, find their relative ranks and the people with the top three highest scor ...

  7. openssl:AES CBC PKCS5 加解密 (C/GOLANG)

    #include <openssl/aes.h> /* AES_CBC_PKCS5_Encrypt * 入参: * src:明文 * srcLen:明文长度 * key:密钥 长度只能是1 ...

  8. innerHTML与innerText功能的强大

    例: <div id="study"> <span style="color:red">学习</span>study < ...

  9. 启动tomcat报错:Failed to start component [StandardEngine[Catalina].StandardHost[localhost]

    1.右键点击需要启动的tomcat,选择Clean和Clean Tomcat Work Directory,清除即可!

  10. 2018.4.23 《深入理解Java虚拟机:JVM高级特性与最佳实践》笔记

    一.Java内存区域与内存溢出 1.程序计数器是一块较小的内存空间,它可看作是当前线程所执行的字节码的行号指示器.字节码解释器工作时就是通过改变这个计数器的值来选取下一条需要执行的字节码指令.各条线程 ...