1.软件版本

ISE14.7+ Modelsim SE-64 10.1c

2.本算法理论知识

【导纳分析】基于FPGA的导纳分析仪的verilog设计_微信

3.核心代码

`timescale 1ns / 1ps
//
// Company:
// Engineer:
//
// Create Date: 14:51:45 08/26/2020
// Design Name:
// Module Name: mysys
// Project Name:
// Target Devices:
// Tool versions:
// Description:
//
// Dependencies:
//
// Revision:
// Revision 0.01 - File Created
// Additional Comments:
//
//
module mysys(
input i_clk,
input i_rst,
input signed[11:0]i_Vin,//将外部的DAC输入接这里

output signed[11:0]o_sin1,
output signed[11:0]o_sin2,
output signed[11:0]o_sin3,
output signed[11:0]o_sin4,
output signed[11:0]o_Vout,//接到DA输出混叠正弦信号
//乘法输出
output signed[23:0]o_rsin1,
output signed[23:0]o_rcos1,
output signed[23:0]o_rsin2,
output signed[23:0]o_rcos2,
output signed[23:0]o_rsin3,
output signed[23:0]o_rcos3,
output signed[23:0]o_rsin4,
output signed[23:0]o_rcos4,

//积分输出
output signed[15:0]o_Rxs1,
output signed[15:0]o_Rxc1,
output signed[15:0]o_Rxs2,
output signed[15:0]o_Rxc2,
output signed[15:0]o_Rxs3,
output signed[15:0]o_Rxc3,
output signed[15:0]o_Rxs4,
output signed[15:0]o_Rxc4
);

//频率配置参数
parameter address1 = 32'd400000000;//400000000/2^32*100e6;
parameter address2 = 32'd200000000;//200000000/2^32*100e6;
parameter address3 = 32'd100000000;//100000000/2^32*100e6;
parameter address4 = 32'd50000000;//50000000/2^32*100e6;





//DA输出,接到你外部的网络中
sin_4out sin_4out_u(
.i_clk (i_clk),
.i_rst (i_rst),
.i_address1(address1),
.i_address2(address2),
.i_address3(address3),
.i_address4(address4),

.o_sin1 (o_sin1),
.o_sin2 (o_sin2),
.o_sin3 (o_sin3),
.o_sin4 (o_sin4),
.Vout (o_Vout)//接到DA输出混叠正弦信号
);


//然后是AD输入
//ADC输入采样Vin后,对信号进行检波处理,乘法器将Vin与8路参考数字信号(4个频率点的正弦及余弦,FPGA内部产生)相乘并积分(积分时间可调)得到其数值。
check_tops check_tops_u(
.i_clk (i_clk),
.i_rst (i_rst),
.i_address1(address1),
.i_address2(address2),
.i_address3(address3),
.i_address4(address4),

.i_Vin (i_Vin),

.o_rsin1 (o_rsin1),
.o_rcos1 (o_rcos1),
.o_rsin2 (o_rsin2),
.o_rcos2 (o_rcos2),
.o_rsin3 (o_rsin3),
.o_rcos3 (o_rcos3),
.o_rsin4 (o_rsin4),
.o_rcos4 (o_rcos4),
.o_Rxs1 (o_Rxs1),
.o_Rxc1 (o_Rxc1),
.o_Rxs2 (o_Rxs2),
.o_Rxc2 (o_Rxc2),
.o_Rxs3 (o_Rxs3),
.o_Rxc3 (o_Rxc3),
.o_Rxs4 (o_Rxs4),
.o_Rxc4 (o_Rxc4)
);

//8个数据进行串口设计


endmodule

4.操作步骤与仿真结论

【导纳分析】基于FPGA的导纳分析仪的verilog设计_参考文献_02

【导纳分析】基于FPGA的导纳分析仪的verilog设计_导纳分析仪_03

 5.参考文献

【导纳分析】基于FPGA的导纳分析仪的verilog设计_导纳分析仪_04

 A37-07