实现两个sym转一个sym
CVO输出如果是一个像素并行输出,选择内嵌人插入同步码。如果两个像素并行输出是不能选择内嵌的,只能选择分离的方式。如果把输出的并行数据给VIP并且要求是内嵌,那只能在内部转或者外部转。
这里是实现外部转换的方式。
程序是比较简单的,只是防止以后找不到程序反复得写而已。
实现过程是:
1、先把两个像素转换成一个像素
module sym2_2_sym1(
input clk_i,
input [:] h_sync_i,
input [:] v_sync_i,
input [:] de_i,
input [:] vin, input clk_o,
output h_sync_o,
output v_sync_o,
output [:] vout
);
reg de_i_r = 'b0;
reg cnt = 'b0;
reg [:] din_r = 'd0;
reg [:] h_sync_i_r = 'b00;
reg [:] v_sync_i_r = 'b00;
reg h_sync_r =;
reg v_sync_r = ;
reg [:] vout_r =;
/*********************************************************
检测de信号上升沿,用于指示每行第一个有效数据
**********************************************************/
always @( posedge clk_o )
begin
de_i_r <= de_i[]; end
wire pos_de = ({de_i_r,de_i[] } == 'b01 );
always @( posedge clk_o )
begin
cnt <= pos_de ? : ~cnt; end
/*********************************************************
由于de上升沿延时一个时钟周期,所以对数据也延时一个时钟周期
**********************************************************/
always @( posedge clk_o )
begin
din_r <= vin;
h_sync_i_r <= h_sync_i;
v_sync_i_r <= v_sync_i;
end
/*********************************************************
2转1
**********************************************************/ always @( posedge clk_o )
begin
vout_r <= cnt ? din_r[:] : din_r[:];
h_sync_r <= cnt ? h_sync_i_r[]: h_sync_i_r[];
v_sync_r <= cnt ? v_sync_i_r[] : v_sync_i_r[];
end assign h_sync_o = h_sync_r;
assign v_sync_o = v_sync_r;
assign vout = vout_r; endmodule
2、在像素中插入同步码
module seperate_2_embeded(
input clk,
input h_sync,//低电平有效
input v_sync,//低电平为有效区间
input f_sync,
input [:] h_black_len,
input [:] vin,
output [:] vout ); reg [:] h_r = ;
reg [:] v_r = ;
reg [:] vin_r1 = ;
reg [:] vin_r2 = ;
reg [:] vout_r = ;
(*keep*)reg [:] cnt = ;
wire [:] xyz ;
wire black_len_m4;
reg black_len_m4_dly = 'b0;
/************************************************************************
把行消隐区间的长度去掉4个
************************************************************************/
always @( posedge clk )
begin
h_r <= {h_r[:],h_sync};
v_r <= {v_r[:],v_sync};
end
assign black_len_m4 = h_r[] & h_sync;
/************************************************************************
找到上升沿与下降沿,即SAV与EAV的位置
************************************************************************/
always @( posedge clk )
begin
black_len_m4_dly <= black_len_m4;
end assign pos_black_len_m4 = {black_len_m4_dly,black_len_m4} == 'b01;
assign neg_black_len_m4 = {black_len_m4_dly,black_len_m4} == 'b10;
/************************************************************************
在SAV 和EAV位置计数
************************************************************************/
always @( posedge clk )
begin
if( pos_black_len_m4 | neg_black_len_m4 )
cnt <= ;
else if( cnt == )
cnt <= cnt;
else
cnt <= cnt + 'b1;
end always @( posedge clk )
begin
case( cnt )
'h0 :
vout_r <= 'hffff;
'h1 :
vout_r <= 'h0000;
'h2 :
vout_r <= 'h0000;
'h3 :
vout_r <= {{xyz[:]}};
default:vout_r <= data[];
endcase end reg[:] data[:];
reg [:] i;
generate
// genvar i;
always @( posedge clk )
begin
for(i = ;i <= ;i= i + )
data[i+] <= data[i];
end endgenerate always @( posedge clk )
begin
data[] <= vin;
end assign xyz = calc_xyz({'b0,v_r[0],h_r[0]});
assign vout = vout_r;
function [:] calc_xyz;
input [:] FVH;
case (FVH)
'b000 : calc_xyz = 10'h200;
'b001 : calc_xyz = 10'h274;
'b010 : calc_xyz = 10'h2ac;
'b011 : calc_xyz = 10'h2d8;
'b100 : calc_xyz = 10'h31c;
'b101 : calc_xyz = 10'h368;
'b110 : calc_xyz = 10'h3b0;
'b111 : calc_xyz = 10'h3c4;
endcase
endfunction endmodule
实现两个sym转一个sym的更多相关文章
- zeromq中两个dealer 通过一个router进行通信
发现有童鞋不是很清楚ZMQ中的“请求-回复”模式中的ROUTER怎么用,所以简单介绍一下“请求-回复”模式的使用(最后付代码). 一.讲一讲 1.要使用zmq 通过一个router进行通信,你首先需要 ...
- C# 图片的裁剪,两个图片合成一个图片
图片的裁剪,两个图片合成一个图片(这是从网上摘的) /// <summary> /// 图片裁剪,生成新图,保存在同一目录下,名字加_new,格式1.png 新图1_ne ...
- c# 写着玩的,两个Task并发,一个写队列一个读队列的异常情况
class Program { class TestEnqueue { static Queue<string> str = new Queue<string>(); publ ...
- 两个dropDownList和一个GridView的选择与显示
很久没有写ASP.NET了,今天有看到论坛上一个问题:"两个dropDownList和一个GridView,已经进行了数据绑定,现在想让第一个下拉菜单的数据改变时,第二个下拉菜单自动变到相应 ...
- java cache过期策略两种实现,一个基于list轮询一个基于timer定时
最近项目要引入缓存机制,但是不想引入分布式的缓存框架,所以自己就写了一个轻量级的缓存实现,有两个版本,一个是通过timer实现其超时过期处理,另外一个是通过list轮询. 首先要了解下ja ...
- 客户端一个http连接包含两个方向,一个是这个http连接的输入,另一个是这个http连接的输出。
1.客户端一个http连接包含两个方向,一个是这个http连接的输入,另一个是这个http连接的输出. 利用httpclient进行ip地址和端口号连接后,http的输出端作为http请求参数设置.h ...
- 《剑指Offer》附加题_用两个队列实现一个栈_C++版
在<剑指Offer>中,在栈和队列习题中,作者留下来一道题目供读者自己实现,即"用两个队列实现一个栈". 在计算机数据结构中,栈的特点是后进先出,即最后被压入(push ...
- 已知有两个水杯,一个11L一个7L,水可以任意使用,求怎么得到2L 的详细解法
问题:有两个水杯,一个是11L一个是7L,水可以随便用,怎么得到2L 1.了解问题的本质 问题中给出了两个杯子,只有这两个杯子有量度,所以只能让杯中的水满进满出才能确定杯子中最后有多少水. 现在问题要 ...
- Python两个栈实现一个队列
牛客网原题: 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 实现这个算法的方式有很多种,这里就写一种比较简单易懂的:虽然可能算法和效率上不太出色,当大多数人 ...
随机推荐
- Java03-Java语法基础(二)运算符
Java语法基础(二)运算符 一.运算符 1.算数运算符:+.-.*./.% 1)双目运算符:二元运算符,参加运算的对象有两个(+.-.*./.%) 2)单目运算符:一元运算符,参加运算的对象只有一个 ...
- position的absolute与fixed,absolute与relative共同点与不同点
absolute与fixed 共同点: (1) 改变行内元素的呈现方式,display被置为block: (2) 让元素脱离普通流,不占据空间: (3) 默认会覆盖到非定位元素上 不同点: absol ...
- ios NSUserDefaults存储数据(偏好设置)
ios NSUserDefaults存储数据(偏好设置) 1.NSUserDefaults用于存储数据量小的数据,主要是用户配置,但也可以支持存储一些小数据包括:NSString, NSNumber, ...
- Django之ModalForm
ModelForm 自己定义的form--->Form--->BaseForm 自己定义的ModelForm--->ModelForm--->BaseModelForm---& ...
- TF30063:没有访问xxx的权限 vs2017
凭据什么的都删掉了,还是无法连接上,最后同事用一种方法o(╥﹏╥)o,先登录vs2015的tfs账号,然后再vs2017上面登录tfs账号即可解决.PS:网上很多文章都是抄的,这个Bug真TM恶心.
- PAT 1056 组合数的和(15)(代码)
1056 组合数的和(15 分) 给定 N 个非 0 的个位数字,用其中任意 2 个数字都可以组合成 1 个 2 位的数字.要求所有可能组合出来的 2 位数字的和.例如给定 2.5.8,则可以组合出: ...
- PAT 1018 锤子剪刀布(20)
1018 锤子剪刀布 (20)(20 分) 大家应该都会玩"锤子剪刀布"的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方 ...
- 转录组分析---Hisat2+StringTie+Ballgown使用
转录组分析---Hisat2+StringTie+Ballgown使用 (2016-10-10 08:14:45) 转载▼ 标签: 生物信息学 转录组 1.Hisat2建立基因组索引: First ...
- Python generator 的yield (enumerate)
生成杨辉三角 1 1 1 1 2 1 1 3 3 1 1 4 6 4 1 1 5 10 10 5 1 def triangles(max): L = [1,] while len(L) - 1 < ...
- 设计师们做UI设计和交互设计、界面设计等一般会去什么网站呢?
明明可靠颜值吃饭,却偏偏要靠才华立身,UI设计师就是这样一群神奇的物种.面对“大的同时小一点”.“五彩斑斓黑”.“下班之前给我”……这些甲方大大刁钻的需求,设计师每天都在咬牙微笑讨生活.你可以批评我的 ...