⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rx_fine_time_sync.m

📁 符号定时
💻 M
字号:


function fine_time_est = rx_fine_time_sync(input_signal, sim_options)
%符号定时算法
global sim_consts;

[n_tx_antennas, n_rx_antennas] = get_n_antennas(sim_options);%获取分集天线数量

if sim_options.FineTimeSync
   %timing search window size,定时搜索窗口长度
   start_search=130;
   end_search=200;
   
   % get time domain long training symbols,获得时域长训练符号
   long_tr_symbols = tx_freqd_to_timed(sim_consts.LongTrainingSymbols);%以sim_consts.LongTrainingSymbols为输入参数调用函数tx_freqd_to_timed
   % 'LongTrainingSymbols', [1 1 -1 -1 1 1 -1 1 -1 1 1 1 1 1 1 -1 -1 1 1 -1 1 -1 1 1 1 1 ...
    %  1 -1 -1 1 1 -1 1 -1 1 -1 -1 -1 -1 -1 1 1 -1 -1 1 -1 1 -1 1 1 1 1], ...
  
   if sim_options.UseTxDiv   %是否使用发射分集,若使用,则执行
      long_trs = [long_tr_symbols(49:64) long_tr_symbols(1:48)];%???????
   else                      %没使用,则执行
      long_trs = [long_tr_symbols(33:64) long_tr_symbols(1:32)];%?????
   end
   
   time_corr_long = zeros(n_rx_antennas,end_search-start_search+1);%zeros(接收天线数量,200-130+1)
   
   for k=1:n_rx_antennas   
      % calculate cross correlation ,计算互相关     
      for idx=start_search:end_search  %130:200
         time_corr_long(k,idx-start_search+1) = sum((input_signal(k,idx:idx+63).*conj(long_trs)));%从信号的第130列开始计算p39的式子,到第200列结束计算,每次循环计算的窗口长度L为64,搜索长度为71.
      end
   end
   
   % combine, if we had two antennas
   time_corr_long = sum(abs(time_corr_long),1);%取绝对值后,按列相加,得行向量
   %figure(3);
   %plot(time_corr_long)
   %grid on
   [max_peak_long,long_search_idx] = max(abs(time_corr_long));%将行向量中的最大值赋予max_peak_long,其索引赋予long_search_idx
   
   if sim_options.UseTxDiv
      fine_time_est = start_search-1 + long_search_idx+16;%定时时间计算,加上开始搜索的时间
   else
      fine_time_est = start_search-1 + long_search_idx+32;
   end
   
else    %如果没有选中定时同步选项,则设置默认值
   % Magic numbers
   if ~sim_options.UseTxDiv
      fine_time_est = 194;
   else
      fine_time_est = 194-16;
   end
end


⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -