[dout]=func_conv_channels(Hmmatrix,din,Num,Powers,Delays,fd,Samples,count) %归一化各径延时 Dshift = floor(Delays/Samples); [Sr,Sc] = size(din); dout = zeros(size(din)); %信道采样点数 Sample_point = Sr*Sc; %初始化频率选择性信道 Multi_ray = zeros(Num,Sample_point); %各径功率线性化 Powchan = 10.^(Powers/10); %rayleigh信道 for k=1:Num Multi_ray(k,:)= sqrt(Powchan(k))*func_rayleighnew(Sample_point,Samples,fd,k*count)/sqrt(sum(Powchan)); end delay_sig=zeros(Num,Sample_point); %以下for循环为各径的输入信号做延迟处理 for f=1:Num if Dshift(f)~=0 delay_sig(f,1:Dshift(f)) = zeros(1,Dshift(f)); end delay_sig(f,(Dshift(f)+1):Sample_point) = din(1:(Sample_point-Dshift(f))); end output_sig_serial=zeros(1,Sample_point); %各径叠加 [R,C] = size(Hmmatrix); for f=1:Num for i = 1:R for j = 1:C output_sig_serial= output_sig_serial+abs(Hmmatrix(i,j))*Multi_ray(f,:).*delay_sig(f,:)*exp(sqrt(-1)*angle(Hmmatrix(i,j))); end end end dout = reshape(output_sig_serial,Sr,Sc); end function ray_chann=func_rayleighnew(Samples,tstp,fd,CNT) Nums=25; if fd ~= 0.0 Ad1 = sqrt(1.0 ./ (2.0.*(Nums + 1))); Ad2 = sqrt(1.0 ./ (2.0.*Nums)); pai = 3.14159265; wm = 1000*2.0.*pai.*fd; n = 4.*Nums + 2; ts = tstp; wmts = wm.*ts; paino = pai./Nums; xc=zeros(1,Samples); xs=zeros(1,Samples); ic=[1:Samples]+CNT; for nn = 1: Nums cwn = cos( cos(2.0.*pai.*nn./n).*ic.*wmts ); xc = xc + cos(paino.*nn).*cwn; xs = xs + sin(paino.*nn).*cwn; end cwmt = sqrt(2.0).*cos(ic.*wmts); xc = (2.0.*xc + cwmt).*Ad1; xs = 2.0.*xs.*Ad2; ray_chann=xc+j*xs; else ray_chann=ones(1,Samples); end end
时间: 2024-03-27 12:42:06 浏览: 61
这是一段MATLAB代码,实现了一个信道模型的计算。具体来说,该代码实现了归一化各径延时信道模型,包括以下几个步骤:
1. 根据输入的各径功率、延时、多径数等参数,生成一个多径信道模型的矩阵Hmmatrix和各径功率线性化后的Multi_ray矩阵。
2. 对输入信号进行延时处理,将各径延时后的信号存储在delay_sig矩阵中。
3. 进行各径的叠加,将每个路径的信号与对应的信道系数相乘,同时考虑各径之间的相位差异,最终得到输出信号output_sig_serial。
4. 将输出信号reshape成原始信号din的大小,最终输出dout。
代码中还包含了一个名为func_rayleighnew的函数,用于生成Rayleigh信道的模拟结果。该函数输入了一些参数,如信道采样点数、采样时间间隔、多普勒频率等,最终输出一个名为ray_chann的Rayleigh信道模拟结果。
相关问题
//dout_time输出 always @(posedge clk or negedge rst_n) begin if (!rst_n) begin dout_time<=20'b0; end else begin case (state_c) IDEL:dout_time<=idel_dout; SET_TIME:dout_time<=set_time_dout; default :dout_time<=IDEL; endcase end end assign beep_r=dout_time[13:3]==14'b0000000000&&state_c!=SET_TIME; endmodule //counter
这段代码实现了时钟计时器的输出和蜂鸣器控制。其中:
- always @(posedge clk or negedge rst_n) 表示在时钟的上升沿或复位信号的下降沿触发输出操作;
- if (!rst_n) begin ... end else begin ... end 表示当复位信号为低电平时,dout_time 被置为 0;否则根据当前的状态选择输出的值;
- case (state_c) 表示根据当前的状态选择不同的输出值;
- IDEL:dout_time<=idel_dout; 表示当状态为 IDLE 时,输出时钟计时器的值;
- SET_TIME:dout_time<=set_time_dout; 表示当状态为 SET_TIME 时,输出设置时间的值;
- default :dout_time<=IDEL; 表示当状态为其它值时,输出 IDLE 状态的值;
- assign beep_r=dout_time[13:3]==14'b0000000000&&state_c!=SET_TIME; 表示当时钟计时器的值为 00:00:00 且状态不为 SET_TIME 时,蜂鸣器控制信号 beep_r 被置为高电平,用来触发蜂鸣器发声。
综上所述,这段代码实现了时钟计时器的输出和蜂鸣器控制,用来输出当前的时间和触发蜂鸣器发声。
解释这些代码 assign DOUT = data_r; always @ ( posedge clk , posedge clr , posedge load) begin if ( clr = = 1) data_r < = 0; else if ( load = = 1) data_r < = DIN; else begin if ( up_down ==1) begin // 异步清零 // 异步预置数 //加计数 if ( data_r = = 4'b1001) begin data_r<= 4'b0000; c = 1; end else begin data_r<= data_r +1; c = 0 ; end else begin end //减计数 if ( data_r = = 4'b0000) begin data_r < = 4'b1001; c = 1; end else begin data_r < = data_r -1; c = 0 ; end end end end endmodule
这段代码是一个 Verilog HDL 的模块,用于实现一个可加载和计数的寄存器。其中,assign DOUT = data_r; 是把当前寄存器中的值赋给了一个输出端口 DOUT。always @ (posedge clk, posedge clr, posedge load) 这一行表示这个模块会在时钟上升沿、清零信号上升沿、加载信号上升沿的时候执行下面的代码。接下来的 if-else 语句检测了清零信号 clr 和加载信号 load 的状态,如果 clr 为 1,表示需要清空寄存器,则 data_r 的值被置为0。如果 load 为 1,表示需要将 DIN 的值加载到寄存器中。当 up_down 的值为1时,表示需要做加法,否则做减法。如果当前寄存器的值已经是 4'b1001 了,那么将其置为 4'b0000,并设置一个计数器 c 为 1。如果寄存器的值不是 4'b1001,则将其加 1,并将计数器 c 设为 0。同理,当需要做减法时,如果当前寄存器值已经是 4'b0000,那么将其置为 4'b1001,并设置 c 为 1。如果寄存器的值不是 4'b0000,则将其减 1,并将 c 设为 0。
阅读全文