基于Verilog实现的DDS任意波形发生器 下载本文

集成电路课程设计

reg cos_ena; reg sawtooth_ena; reg triangle_ena;

reg [8:0]data_out;

wire [8:0] sine_d; wire [8:0] cosine_d; wire [8:0] sawtooth_d; wire [8:0] triangle_d; wire [8:0] rom_ad;

assign rom_ad = ADD_B;

always@(posedge clk or negedge rst) begin

if(!rst) begin ADD_A <= 9'd0; end else case(we)

1'b1 : ADD_A <= data; 1'b0 : ADD_A <= 9'd0; default: ADD_A <= 9'd0; endcase end

always@(posedge clk or negedge rst)

- 21 -

集成电路课程设计

begin

if(!rst) begin

ADD_B <= 9'b0; sin_ena<=1'b0; cos_ena<=1'b0; sawtooth_ena <= 1'b0; triangle_ena <= 1'b0; end else begin

case(choose_wave) 2'b00:begin

sin_ena <= 1'b1; cos_ena <= 1'b0; sawtooth_ena <= 1'b0; triangle_ena <= 1'b0;

if(ADD_B > 256) ADD_B <= 0; else ADD_B <= ADD_A + ADD_B; end 2'b01:begin

cos_ena <= 1'b1; sin_ena <= 1'b0; sawtooth_ena <= 1'b0; triangle_ena <= 1'b0;

if(ADD_B > 256) ADD_B <= 0; else ADD_B <= ADD_A + ADD_B; end 2'b10:begin

sin_ena <= 1'b0;

- 22 -

集成电路课程设计

cos_ena <= 1'b0; sawtooth_ena <= 1'b1; triangle_ena <= 1'b0;

if(ADD_B > 256) ADD_B <= 0; else ADD_B <= ADD_A + ADD_B; end end end

always@(posedge clk)

2'b11:begin

sin_ena <= 1'b0; cos_ena <= 1'b0; sawtooth_ena <= 1'b0; triangle_ena <= 1'b1;

if(ADD_B > 256) ADD_B <= 0; else ADD_B <= ADD_A + ADD_B; end default:begin

ADD_B <= 9'b0; sin_ena <= 1'b0; cos_ena <= 1'b0; sawtooth_ena <= 1'b0; triangle_ena <= 1'b0; end endcase - 23 -

集成电路课程设计

begin

case(choose_wave) 2'b00:begin

data_out <= sine_d; end 2'b01:begin

data_out <= cosine_d; end 2'b10:begin

data_out <= sawtooth_d; end 2'b11:begin

data_out <= triangle_d; end default:begin

data_out <= 9'b0; end endcase end

rom_sin rom_sin1(

.address(rom_ad), .clock(clk), .ena(sin_ena), .wr_data(sine_d) );

- 24 -

集成电路课程设计

rom_cos rom_cos1(

.address(rom_ad), .clock(clk), .ena(cos_ena), .wr_data(cosine_d) ); rom_triangle rom_triangle1(

.address(rom_ad), .clock(clk), .ena(triangle_ena), .wr_data(triangle_d) );

rom_sawtooth rom_sawtooth1( .address(rom_ad), .clock(clk), .ena(sawtooth_ena), .wr_data(sawtooth_d) ); endmodule

附录2:sin函数查找表

module rom_sin(

address, clock, wr_data,

- 25 -