set_11a_para.m
上传用户:look542
上传日期:2009-06-04
资源大小:784k
文件大小:6k
源码类别:

传真(Fax)编程

开发平台:

Matlab

  1. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  2. % 设置B3G系统全局变量,参阅本实验室的B3G系统参数文档
  3. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  4. % 2.1 OFDMA收发机系统参数定义单元
  5. % 命名规律: N_xxx: xxx的数目,为非负整数
  6. %           T_xxx: xxx的持续时间,为非负实数
  7. %           Idx_xxx: xxx的编号,为整数向量
  8. %           一些约定俗成的表示, 如fc载频, Bw信道带宽等
  9. % 1) 当TurnOn.AdptMod = 0 时表示所有子载波用调制方式:(不使用信道编码时)
  10. % 1--BPSK调制, 2--QPSK调制,3--8PSK调制, 4--16QAM调制,6--64QAM调制
  11. % 2) 当TurnOn.AdptMod = 1 时表示自适应调制,平均每个子载波上调制的比特数
  12. % 此时最大只能设置为4, 否则调制器无法处理
  13. Modulation = 1;       
  14. N_sym = 10;                              %  每帧中OFDM符号数,不包括两个前缀OFDM符号
  15. N_frame = 100;                           %  仿真的帧个数
  16. % 仿真循环开始的Eb_No,定义为每比特的能量Eb
  17. % 和噪声的单边功率谱密度No的比值, dB值
  18. Eb_NoStart = 10;                                                          
  19. Eb_NoInterval = 5;      % 仿真Eb/No的间隔值(dB)
  20. Eb_NoEnd = 20;          % 仿真Eb/No的终止值(dB)                        
  21. fc = 5e9;                               %  载波频率(Hz)
  22. Bw = 20e6;                              %  基带系统带宽(Hz)
  23. fs = 20e6;                              %  基带抽样频率
  24. T_sample = 1/fs;                        %  基带时域样点间隔(s)
  25. % 802.11a的基本参数
  26. N_subc = 64;                          %  OFDM 子载波总数
  27. Idx_used = [-26:-1 1:26];             %  使用的子载波编号
  28. Idx_pilot = [-21:14:-7 7:14:21];    %  导频子载波编号
  29. N_used = length(Idx_used);              % 使用的子载波数
  30. N_pilot = length(Idx_pilot);            % 导频的子载波数
  31. N_data = N_used - N_pilot;              % 导频的子载波数
  32. Idx_data = zeros(1,N_data);
  33. N_tran_sym = 2;
  34. % 得到数据子载波的编号
  35. m = 1; n = 1;
  36. for k  = 1:length(Idx_used)
  37.     if Idx_used(k) ~= Idx_pilot(m);
  38.         Idx_data(n) = Idx_used(k);
  39.         n = n + 1;
  40.     else
  41.         if m ~= N_pilot
  42.             m = m + 1;
  43.         end
  44.     end
  45. end
  46. %  为编程使用方便,调整子载波编号为从1开始,到子载波总数
  47. Idx_used = Idx_used + N_subc/2 +1;       
  48. Idx_pilot = Idx_pilot + N_subc/2 +1;
  49. Idx_data = Idx_data + N_subc/2 +1; 
  50. % 导频位置值
  51. PilotValue = ones(N_pilot,1);
  52. % OFDM循环前缀占有效FFT时间的比例
  53. PrefixRatio = 1/4;                
  54. T_sym = T_sample*( (1 + PrefixRatio)*N_subc );
  55. Es = 1;                 % 在16QAM, 64QAM调制方式下,符号能量都被归一化 
  56. Eb = Es/Modulation;     % 每比特能量
  57. % 假设每个用户的RS码参数相同,均为(204,188,8)                                   
  58. UserRS_Coding = repmat([255,239,8]',1,N_user);                              
  59. TraceBackLen = 3;       % 卷积码译码参数
  60. % 假设每个用户的卷积码trellis 结构体相同
  61. UserTrellis = repmat( poly2trellis(3,[6 7]),1,N_user );
  62. N_ant_pair = N_Tx_ant * N_Rx_ant;   % 收发天线对的数目
  63. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  64. % 2.2 信道参数定义单元, 每个用户移动台参数不同
  65.     for u = 1:N_user
  66.         % 车辆运动速度, 单位:km/hr , 对应多普勒频移!!
  67.         speed = 0;
  68.         ch{u} = struct('Speed', speed);
  69.         % 多普勒频移, 单位: Hz
  70.         ch{u}.fd = ch{u}.Speed *(1e3/3.6e3)*fc/3e8;  
  71.         % 指数衰落的信道功率时延谱
  72. %         ch{u}.Power = 10.^([ 0 -6 -12 -18 -24 -30 ]'./10);  % 6径信道每条径的功率
  73. %         ch{u}.Delay = [ 0 1400 2800 4200 5600 7000 ]';      % 最大多径时延 7us 室外信道
  74.         %ch{u}.Delay = [ 0 1000 2000 3000 4000 5000 ]';     % 最大多径时延 5us 室外信道
  75.         %ch{u}.Delay = [ 0 100 200 300 400 500 ]';          % 最大多径时延 500ns 室内信道参数
  76.         
  77.         % 室内信道的功率时延谱
  78.         ch{u}.Power = [ 0.3240 0.4015 0.0929 0.0961 0.0291 0.0340 0.0060 0.0165]';
  79.         ch{u}.Delay = [ 50 100 150 200 250 300 350 400 ]';      
  80.         ch{u}.Power = ch{u}.Power/ sum(ch{u}.Power); % 功率归一化  
  81.         
  82.         % 每个用户每条径对应的样点数
  83.         ch{u}.Delay_sample = round(ch{u}.Delay  * 1e-9 * fs);                 
  84.         ch{u}.N_path = size(ch{u}.Power,1);          % 径数 
  85.         % 每个用户,各条径对应的莱斯衰落K因子
  86.         % ch{u}.Ricean_K = zeros(N_path,1) ;         
  87.     end
  88. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  89. % 2.3 OFDMA收发机算法选择和参数定义单元
  90. %自适应调制方法 ,当TurnOn.AdptMod == 1时, 
  91. % 1--自适应调制方法1, 给功率增加最小的子载波分配比特和功率, 子载波分配由AllocMethod确定
  92. % 2--自适应调制方法2, 给误比特性能降低最小的子载波分配比特和增加功率, 子载波分配由AllocMethod确定
  93. % 3--自适应调制方法3, 按照信道响应降序排列,子载波间争夺比特和功率, 子载波
  94. % 分配由AllocMethod确定
  95. % 当TurnOn.AdptMod == 0 时,此不起作用, 无自适应调制,使用固定子载波分配
  96. AdptMethod = 1;
  97. % 子载波分配方法, 1--相邻分配, 2--交织分配, 3---跳频分配 ,4--自适应子载波分配
  98. AllocMethod = 1;
  99. % 自适应调制算法中需要的目标误比特率
  100. TargetBer = 1e-3;
  101. % 空时编码方法, 1--空时分组码, 2--空时格码
  102. ST_Code = 1;   
  103. % 单天线信道估计方法
  104. % 1 - 基本LS算法; 2 - LS的DFT改进算法; 3 - 加判决反馈的LS-DFT
  105. % 4 - 基本MMSE算法; 5 - MMSE的DFT改进算法; 6 - 加判决反馈的MMSE-DFT
  106. % 7 - 使用SVD分解算法,8 - Robust算法
  107. CE_Method = 4 ;                      
  108. % 使用LS或MMSE的DFT改进算法时,所保留的子载波数                                    
  109. CE_SubcRemain = max(ch{u}.Delay_sample);        % 最大多径时延对应的样点数                 
  110. % 多天线信道估计方法
  111. CE_Method2 = 1;
  112. % 定时同步算法
  113. PreNoiseLen = 100;      % 为定时算法加的前噪样点数
  114. PostNoiseLen = 100;     % 后噪样点数
  115. delta_fc = 10e3;         % 载波频偏 (Hz)
  116. Repeat = 4;              % 第1个训练OFDM符号,时域信号重复部分的数目
  117. % 帧(粗)定时
  118. % 帧定时算法, 1--单窗口能量检测方法, 2--双窗口能量检测方法 , 3--延时相关方法帧定时
  119. FrameTiming = 1;         
  120. Window1 = 32;          % 帧定时算法的窗口宽度
  121. Threshold1 = 0.4;       % 帧定时算法门限
  122. Delay1 = 32;            % 帧定时延时相关算法的延时样点数
  123. % 载波频偏粗估计
  124. WinStart = 16;
  125. WinSize = 32;
  126. Delay2 = 16;
  127. % 符号定时算法
  128. Window2 = 32;           % 和已知序列求相关,序列的长度
  129. TimingAhead = 0;        % 定时提前的样点数
  130. % 载波频偏粗估计
  131. WinStart2 = 16; 
  132. WinSize2 = 32;
  133. Delay3 = 32;