wudi123baobei 发表于 2014-11-12 20:04:47

DDS任意信号发生器


/*信号定义
inclock:时钟
control:控制产生波形的种类,为00,01,10,11时,分别产生正弦波、方波、三角波和锯齿波;
i:控制读取时间间隔,调整频率
q_out:输出数据*/
module signal_gene(inclock,q_out,control,i);

input inclock;
output q_out;
input control;//控制产生波形的种类
input i;
reg address;
wire q_out;
reg m,k;
reg state;
rom rom_component(.address(address),
                        .clock(inclock),
                                                                  .q(q_out)
                                                                  );
                                                                  
always @(posedge inclock)
begin
case(state)
0:begin    //产生正弦波形
   if(control==1) address<=9'd128;
   if(control==2) address<=9'd256;
          if(control==3) address<=9'd384;
   if(i==0||i==1) begin
            address<=address+1'b1;
               if(address>=9'd127) address<=9'd0;
               end
               else begin
                     k<=127/i;m<=i*k;
                        address<=address+i;
                        if(address>=m) address<=9'd0;
                        end
                end
      1:begin   //产生锯齿波形
          if(control==0)address<=9'd0;
          if(control==2)address<=9'd256;
          if(control==3)address<=9'd384;
          if(address<128) address<=9'd128;
         else begin
            if(i==0||i==1)begin
                  address<=address+1'b1;
                         if(address==9'd255) address<=9'd128;
                         end
                  else begin
                     k<=127/i;m<=i*k;
                        address<=address+i;
                        if(address>=m+9'd128) address<=9'd128;
                        end
                  end
         end
      2:begin//产生方波形
                if(control==0)address<=9'd0;
      if(control==1) address<=9'd128;
                if(control==3)address<=9'd384;
                if(address<9'd256) address<=9'd256;
                  else begin
            if(i==0||i==1)begin
                  address<=address+1'b1;
                         if(address==9'd383) address<=9'd256;
                         end
                  else begin
                     k<=127/i;m<=i*k;
                        address<=address+i;
                        if(address>=m+256) address<=9'd256;
                        end
                  end
               end
                3:begin    //产生三角波形
   if(control==1) address<=9'd128;
   if(control==2) address<=9'd256;
          if(control==3) address<=9'd384;
          if(address<384) address<=9'd384;
          else begin
       if(i==0||i==1) begin
            address<=address+1'b1;
               if(address==9'd511) address<=9'd384;
               end
               else begin
                     k<=127/i;m<=i*k;
                        address<=address+i;
                        if(address>=m+384) address<=9'd384;
                        end
                  end
                  
               end
                endcase
      end
endmodule
测试文件:
`timescale 1 ps/ 1 ps
module signal_gene_vlg_tst();

reg control;
reg i;
reg inclock;
// wires                                             
wire q_out;

// assign statements (if any)                        
signal_gene i1 (
// port map - connection between master ports and signals/registers   
      .control(control),
      .i(i),
      .inclock(inclock),
      .q_out(q_out)
   );
initial                                                
begin   
                                             
inclock=0;
i=4'b0000;
control=2'b00;
#100 control=2'b11;
#100 control=2'b10;
#100000 $finish;                     
end                                                   
always#10 inclock=~inclock;
endmodule
页: [1]
查看完整版本: DDS任意信号发生器