当前位置: 首页 > wzjs >正文

江西赣州网站建设电商培训机构有哪些?哪家比较好

江西赣州网站建设,电商培训机构有哪些?哪家比较好,建立小程序需要多少钱,国税政务公开网站建设因为使用的是DDR进行传输,即双倍频率采样,故时钟只用是并行数据数据的5倍,而不是10倍。 TMDS算法流程: 视频编码TMDS算法流程实现: timescale 1 ps / 1ps //DVI编码通常用于视频传输,将并行数据转换为适合…

因为使用的是DDR进行传输,即双倍频率采样,故时钟只用是并行数据数据的5倍,而不是10倍。

  TMDS算法流程:

视频编码TMDS算法流程实现: 

`timescale 1 ps / 1ps
//DVI编码通常用于视频传输,将并行数据转换为适合串行传输的格式。
module dvi_encoder (input            clkin,    // pixel clock inputinput            rstin,    // async. reset input (active high)input      [7:0] din,      // data inputs: expect registeredinput            c0,       // c0 inputinput            c1,       // c1 input;c0 和 c1 用于指示视频的**水平同步(HSYNC)和垂直同步(VSYNC)**信号。input            de,       // de inputoutput reg [9:0] dout      // data outputs
);// Counting number of 1s and 0s for each incoming pixel
// component. Pipe line the result.
// Register Data Input so it matches the pipe lined adder
// outputreg [3:0] n1d; //number of 1s in din
reg [7:0] din_q;//计算像素数据中“1”的个数
always @ (posedge clkin) beginn1d <=#1 din[0] + din[1] + din[2] + din[3] + din[4] + din[5] + din[6] + din[7];din_q <=#1 din;
end///
// Stage 1: 8 bit -> 9 bit
// Refer to DVI 1.0 Specification, page 29, Figure 3-5
///
wire decision1;//decision1 为真,表示需要反转数据。
assign decision1 = (n1d > 4'h4) | ((n1d == 4'h4) & (din_q[0] == 1'b0));wire [8:0] q_m;
assign q_m[0] = din_q[0];
assign q_m[1] = (decision1) ? (q_m[0] ^~ din_q[1]) : (q_m[0] ^ din_q[1]);
assign q_m[2] = (decision1) ? (q_m[1] ^~ din_q[2]) : (q_m[1] ^ din_q[2]);
assign q_m[3] = (decision1) ? (q_m[2] ^~ din_q[3]) : (q_m[2] ^ din_q[3]);
assign q_m[4] = (decision1) ? (q_m[3] ^~ din_q[4]) : (q_m[3] ^ din_q[4]);
assign q_m[5] = (decision1) ? (q_m[4] ^~ din_q[5]) : (q_m[4] ^ din_q[5]);
assign q_m[6] = (decision1) ? (q_m[5] ^~ din_q[6]) : (q_m[5] ^ din_q[6]);
assign q_m[7] = (decision1) ? (q_m[6] ^~ din_q[7]) : (q_m[6] ^ din_q[7]);
assign q_m[8] = (decision1) ? 1'b0 : 1'b1;   //第9位 q_m[8] 用于指示数据是否被反转,0是数据被反转/
// Stage 2: 9 bit -> 10 bit
// Refer to DVI 1.0 Specification, page 29, Figure 3-5
/
//计算1和0的个数
reg [3:0] n1q_m, n0q_m; // number of 1s and 0s for q_m
always @ (posedge clkin) beginn1q_m  <=#1 q_m[0] + q_m[1] + q_m[2] + q_m[3] + q_m[4] + q_m[5] + q_m[6] + q_m[7];n0q_m  <=#1 4'h8 - (q_m[0] + q_m[1] + q_m[2] + q_m[3] + q_m[4] + q_m[5] + q_m[6] + q_m[7]);
end//控制令牌(Control Tokens),用于在视频的消隐期(Blanking Period)传输同步信息。
//这些控制令牌是10位的固定编码值,用于表示视频的**水平同步(HSYNC)和垂直同步(VSYNC)**信号
parameter CTRLTOKEN0 = 10'b1101010100;
parameter CTRLTOKEN1 = 10'b0010101011;
parameter CTRLTOKEN2 = 10'b0101010100;
parameter CTRLTOKEN3 = 10'b1010101011;/*
差异计数器(Disparity Counter):在TMDS编码中,差异计数器用于跟踪当前信号的直流偏差(DC Disparity)。直流偏差是指信号中"1"和"0"的数量之差。通过调整编码方式(如反转数据),差异计数器可以帮助实现直流平衡,减少信号的直流分量。最高位是符号位(MSB is the sign bit):
差异计数器的最高位(MSB)表示偏差的方向:如果最高位为 0,表示偏差为负(即"0"的数量多于"1")。如果最高位为 1,表示偏差为正(即"1"的数量多于"0")。其余位表示偏差的大小。
*/
reg [4:0] cnt; //disparity counter, MSB is the sign bit
wire decision2, decision3;assign decision2 = (cnt == 5'h0) | (n1q_m == n0q_m);  //1和0的数量相等
/
// [(cnt > 0) and (N1q_m > N0q_m)] or [(cnt < 0) and (N0q_m > N1q_m)]
/
assign decision3 = (~cnt[4] & (n1q_m > n0q_m)) | (cnt[4] & (n0q_m > n1q_m));//即cnt[4]=0                    cnt[4]=1// pipe line alignmentreg       de_q, de_reg;
reg       c0_q, c1_q;
reg       c0_reg, c1_reg;
reg [8:0] q_m_reg;always @ (posedge clkin) beginde_q    <=#1 de;de_reg  <=#1 de_q;c0_q    <=#1 c0;c0_reg  <=#1 c0_q;c1_q    <=#1 c1;c1_reg  <=#1 c1_q;q_m_reg <=#1 q_m;
end///
// 10-bit out
// disparity counter
///
always @ (posedge clkin or posedge rstin) beginif(rstin) begindout <= 10'h0;cnt <= 5'h0;end else beginif (de_reg) beginif(decision2) begindout[9]   <=#1 ~q_m_reg[8]; dout[8]   <=#1 q_m_reg[8]; dout[7:0] <=#1 (q_m_reg[8]) ? q_m_reg[7:0] : ~q_m_reg[7:0];cnt <=#1 (~q_m_reg[8]) ? (cnt + n0q_m - n1q_m) : (cnt + n1q_m - n0q_m);  //第一个cnt代表当前cnt值,后面两个cnt代表上一次执行时的值end else beginif(decision3) begindout[9]   <=#1 1'b1;dout[8]   <=#1 q_m_reg[8];dout[7:0] <=#1 ~q_m_reg[7:0];cnt <=#1 cnt + {q_m_reg[8], 1'b0} + (n0q_m - n1q_m);end else begindout[9]   <=#1 1'b0;dout[8]   <=#1 q_m_reg[8];dout[7:0] <=#1 q_m_reg[7:0];cnt <=#1 cnt - {~q_m_reg[8], 1'b0} + (n1q_m - n0q_m);endendend else begincase ({c1_reg, c0_reg})  //进入消隐期2'b00:   dout <=#1 CTRLTOKEN0;2'b01:   dout <=#1 CTRLTOKEN1;2'b10:   dout <=#1 CTRLTOKEN2;default: dout <=#1 CTRLTOKEN3;endcasecnt <=#1 5'h0;endend
endendmodule 

解码:使用xilinx原语serdes进行并转串,serdes分为master和slave模式,其中的master使用的是8bit数据,另外带两个bit的扩展位放在了slave中。

参考:正点原子 

http://www.dtcms.com/wzjs/436997.html

相关文章:

  • 懂做网站怎么赚钱做销售有什么技巧和方法
  • 网站备案客户资料百度推广客户端下载
  • 黑河北京网站建设舆情监测软件
  • 中文商城html网站模板百度交易平台官网
  • 网站开发都是用什么做的网址最全的浏览器
  • 外贸英文商城网站建设优化关键词是什么意思
  • 做自行车车队网站的名字大全培训心得简短50字
  • 网站被做301seo搜索是什么意思
  • 公众号文章排版编辑器win7优化大师官方免费下载
  • 怎样做网站备份餐饮管理培训课程
  • 查看网站建设工作北京公司排名seo
  • 垫江做网站网络营销未来有哪些发展趋势
  • 采票网站刷流水做任务好的网站或网页
  • 关于建设网站的毕业论文seo外链招聘
  • 自己电脑做网站 外网无法访问短视频运营公司
  • 网站自适应北京seo关键词排名
  • 做网站包括图片设计吗地推拉新app推广平台
  • 企业网站网络推广seo的公司排名
  • 做滋补品销售有什么网站商务软文写作300
  • 玛沁县网站建设公司seo基础培训
  • 衣柜做网站的关键词谷歌seo推广公司
  • wordpress用户管理 插件搜索引擎优化的基础是什么
  • 杭州手机网站建设公司营销技巧培训
  • 四平网站建设哪家好韶山seo快速排名
  • 东丽区做网站seo搜索引擎优化怎么做
  • 网站跳出率多少合适企业站seo
  • 网络平台贷款逾期不还武汉百度搜索优化
  • 国外做旅游攻略的网站好最新发布的最新
  • 做外汇的网站山西seo谷歌关键词优化工具
  • 西安哪有学做淘宝网站新媒体营销推广公司