1、答题记录

1、 答题记录

1.规约运算符

两两按位做运算,& | ^ 等。按位异或可以用来进行奇偶校验操作。
例如:

`timescale 1ns/1ns
//对输入的32位数据进行奇偶校验,根据sel输出校验结果(1 输出奇校验,0 输出偶校验)
module odd_sel
(
	input [31:0] bus,
	input sel,
	output check
);
//*************code***********//
	wire panduan;
	wire odd;
	assign panduan = ^bus;        //规约运算
	assign check = sel ? panduan : ~panduan ;
//*************code***********//
endmodule

波形示意图

2.generate for 语句

例如:

`timescale 1ns/1ns
module gen_for_module
( 
    input [7:0] data_in,
    output [7:0] data_out
);
	genvar i;
	generate 
	    for(i=0;i<=7;i=i+1)
	    begin : loop
	     assign    data_out[i]  = data_in[7-i];
	    end 
	endgenerate
endmodule

3.拼接赋值运算{{}}

例如:
给定五个1bit信号(a、b、c、d 和 e),生成两种25位的数据: 一种是将信号复制五次后连接起来aaaaabbbbb…,
一种是将信号连接起来复制五次成为abcdeabcde… 。比较两个25位信号,如果两个信号的同样位置的位相等,则输出1。
这道题主要是考察拼接符的灵活运用
{} 代表拼接 例如 {a,b,c,d,e} 代表将这几位拼接起来
{{ }} 代表复制 例如 {{5{a}} 代表将a 复制五次.

`timescale 1ns/1ns

module top_module
(
    input a, b, c, d, e,
	output [24:0] out
);
	wire [24:0] res1,res2;
	assign res1 = {{5{a}},{5{b}},{5{c}},{5{d}},{5{e}}};
	assign res2 = {5{a,b,c,d,e}};
	assign out = ~res1^res2;
endmodule

4.函数用法

例如
用函数实现一个4bit数据大小端转换的功能。实现对两个不同的输入分别转换并输出。

`timescale 1ns/1ns
module function_mod
(
	input [3:0]a,
	input [3:0]b,
	output [3:0]c,
	output [3:0]d
);
	assign c = mod(a);
	assign d = mod(b);
	integer i;
	function [3:0] mod;
		input [3:0] a;
		begin 
			for(i=0;i<=3;i=i+1)
			begin
				mod[i] = a[3-i];
			end
		end
	endfunction
endmodule

5.半加器、全加器

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值