verilog 浮点数转定点数_一段verilog的浮点转定点的程序,谁能帮我转成VHDL的啊,万分感谢~~~~~~...

这是一个Verilog代码实现的浮点数到定点数转换模块,参数包括输入大小、输出大小、小数位数、指数位数等。代码中处理了正负数、不同指数情况下的转换,并将结果存储在输出变量`fixnum`中。
摘要由CSDN通过智能技术生成

modulefloat_fixnumber(floatnum,fixnum);parameterinsize=15;parameteroutsize=18;parameterdotnum=7;parameterexpbitn=5;parameterweishubit=9;parameterfixzhengshubit=10;input[i...

module float_fixnumber(floatnum,fixnum);

parameter insize=15;

parameter outsize=18;

parameter dotnum=7;

parameter expbitn=5;

parameter weishubit=9;

parameter fixzhengshubit=10;

input [insize-1:0] floatnum;

output[outsize-1:0] fixnum;

reg [outsize-1:0] fixnum;

reg [outsize+1:0] zhengexp,shiftzhengexp;

reg [expbitn-1:0] expbit;

reg [weishubit:0] fenshubit,fenshu;

reg signbit;

integer i,k,j,shiftno;

initial

begin

i=0;

k=0;

j=0;

shiftno=0;

end

always

begin

signbit<=floatnum[insize-1];

expbit<=floatnum[insize-2:insize-expbitn-1];

fenshubit<={1'b1,floatnum[weishubit-1:0]};

if(signbit==1)

if(expbit[expbitn-1]==1)

begin

shiftno<=expbit[expbitn-2:0];

fenshu<=(fenshubit>>shiftno);

fixnum<={signbit,10'b0,fenshu[weishubit-1:weishubit-7]};

end

else

begin

shiftno<=expbit[expbitn-2:0];

zhengexp[weishubit:0]<=fenshubit;

shiftzhengexp<=zhengexp<

fixnum[17]<=signbit;

fixnum[16:0]<=shiftzhengexp[outsize:outsize-16];

end

else

begin

if(expbit[expbitn-1]==1)

begin

shiftno<=expbit[expbitn-2:0];

fenshu<=(fenshubit>>shiftno);

fixnum<={signbit,10'b0,fenshu[weishubit-1:weishubit-7]};

end

else

begin

shiftno<=expbit[expbitn-2:0];

zhengexp[weishubit:0]<=fenshubit;

shiftzhengexp<=zhengexp<

fixnum[17]<=signbit;

fixnum[16:0]<=shiftzhengexp[outsize:outsize-16];

end

end

signbit<=floatnum[insize-1];

expbit<=floatnum[insize-2:insize-expbitn-1];

fenshubit<={1'b1,floatnum[weishubit-1:0]};

end

endmodule

展开

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值