2017-04-03 12:52:03 -04:00
|
|
|
module complex_to_mag
|
|
|
|
#(
|
|
|
|
parameter DATA_WIDTH = 16
|
|
|
|
)
|
|
|
|
(
|
|
|
|
input clock,
|
|
|
|
input enable,
|
|
|
|
input reset,
|
|
|
|
|
|
|
|
input signed [DATA_WIDTH-1:0] i,
|
|
|
|
input signed [DATA_WIDTH-1:0] q,
|
|
|
|
input input_strobe,
|
|
|
|
|
|
|
|
output reg [DATA_WIDTH-1:0] mag,
|
2023-01-09 14:47:34 +01:00
|
|
|
output reg mag_stb
|
2017-04-03 12:52:03 -04:00
|
|
|
);
|
|
|
|
|
|
|
|
reg [DATA_WIDTH-1:0] abs_i;
|
|
|
|
reg [DATA_WIDTH-1:0] abs_q;
|
|
|
|
|
|
|
|
reg [DATA_WIDTH-1:0] max;
|
|
|
|
reg[ DATA_WIDTH-1:0] min;
|
|
|
|
|
2023-01-09 14:47:34 +01:00
|
|
|
reg input_strobe_reg0;
|
|
|
|
reg input_strobe_reg1;
|
2017-04-07 11:36:21 -04:00
|
|
|
|
2023-01-09 14:47:34 +01:00
|
|
|
// delayT #(.DATA_WIDTH(1), .DELAY(3)) stb_delay_inst (
|
|
|
|
// .clock(clock),
|
|
|
|
// .reset(reset),
|
|
|
|
|
|
|
|
// .data_in(input_strobe),
|
|
|
|
// .data_out(mag_stb)
|
|
|
|
// );
|
2017-04-07 11:36:21 -04:00
|
|
|
|
|
|
|
|
2017-04-03 12:52:03 -04:00
|
|
|
// http://dspguru.com/dsp/tricks/magnitude-estimator
|
|
|
|
// alpha = 1, beta = 1/4
|
|
|
|
// avg err 0.006
|
|
|
|
always @(posedge clock) begin
|
|
|
|
if (reset) begin
|
|
|
|
mag <= 0;
|
|
|
|
abs_i <= 0;
|
|
|
|
abs_q <= 0;
|
|
|
|
max <= 0;
|
|
|
|
min <= 0;
|
2023-01-09 14:47:34 +01:00
|
|
|
input_strobe_reg0 <= 0;
|
|
|
|
input_strobe_reg1 <= 0;
|
2017-04-03 12:52:03 -04:00
|
|
|
end else if (enable) begin
|
|
|
|
abs_i <= i[DATA_WIDTH-1]? (~i+1): i;
|
|
|
|
abs_q <= q[DATA_WIDTH-1]? (~q+1): q;
|
|
|
|
|
|
|
|
max <= abs_i > abs_q? abs_i: abs_q;
|
|
|
|
min <= abs_i > abs_q? abs_q: abs_i;
|
|
|
|
|
|
|
|
mag <= max + (min>>2);
|
2023-01-09 14:47:34 +01:00
|
|
|
|
|
|
|
input_strobe_reg0 <= input_strobe;
|
|
|
|
input_strobe_reg1 <= input_strobe_reg0;
|
|
|
|
mag_stb <= input_strobe_reg1;
|
2017-04-03 12:52:03 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
endmodule
|