亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? multi_rayleigh_vita_rsencoded_bis_all_wdiv2.m

?? 短波信道抗多音干擾的性能分析及其仿真
?? M
?? 第 1 頁 / 共 2 頁
字號:
%function pb=multi_rayleigh_vita_rsencoded(Eb_to_Nj_in_dB,Eb_to_No_in_dB,BPH,number_of_states,Q)
%VITERBI      This program simulates the Viterbi sequnce detection of the
%             differential frequency hopping system with (15,7) RS coding
%             and diversity of level 2
%
%             Eb_to_Nj_in_dB is the signal-to-jamming ratio given in dB
%
%             Eb_to_No_in_dB is the signal-to-noise ratio given in dB
%
%             BPH is the number of bits transmitted by one hop
%
%             number_of_states is the number of states in the DFH
%             trellis,corresponding to the right L stages of the DFH encoding 
%             shift register 
%
%             Q is the number of jamming tones in the DFH bandwidth
%
%             這個程序是正確的,帶(N,K,D)=(15,7,9)的 RS 糾錯碼,編碼后在后面只補上L個0,即符號流總長度是2N+L而不是2(N+L),
             

%********系統參數********%
% Eb_to_Nj_in_dB=11;
Eb_to_Nj_in_dB=[9,12,15];
Eb_to_No_in_dB=13.35;
BPH=2;
number_of_states=16;
Q=4; % 干擾音的個數
N=700; % 每次符號流長度
times=10; % 重復做500次

PB_all=zeros(length(Eb_to_Nj_in_dB),1);
PS_all=zeros(length(Eb_to_Nj_in_dB),1);

vita_symbol_err=zeros(length(Eb_to_Nj_in_dB),times);% 維特比譯碼后, RS 譯碼之前2^BPH=4進制符號錯誤個數計數器
num_of_err=zeros(length(Eb_to_Nj_in_dB),times);% 最終 RS 碼譯碼輸出的2^M=16進制符號錯誤個數計數器

M=4; % 伽羅華域GF(2^m)中m=4,即GF(16)域
% 4位二進制序列與GF(16)域中1個16進制GF符號對應轉換關系表
binary_table=[0 0 0 0;
              0 0 0 1;
              0 0 1 0;
              0 0 1 1;
              0 1 0 0;
              0 1 0 1;
              0 1 1 0;
              0 1 1 1;
              1 0 0 0;
              1 0 0 1;
              1 0 1 0;
              1 0 1 1;
              1 1 0 0;
              1 1 0 1;
              1 1 1 0;
              1 1 1 1];
% 2位四進制序列與GF(16)域中1個16進制GF符號對應轉換關系表
quarter_table=[0 0;
               0 1;
               0 2;
               0 3;
               1 0;
               1 1;
               1 2;
               1 3;
               2 0;
               2 1;
               2 2;
               2 3;
               3 0;
               3 1;
               3 2;
               3 3];
decimal_table=[0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15]';
GF16_table=gf(decimal_table,M);% GF(16)域中GF符號表


%************************%
WTbarpp=waitbar(0,'Outer SNRs Loop:Please wait...');
for pp=1:length(Eb_to_Nj_in_dB)


fanout=2^BPH; % DFH的扇出系數
Eb_to_Nj=10^(Eb_to_Nj_in_dB(pp)/10); % 比值形式的Eb/Nj
Eb_to_No=10^(Eb_to_No_in_dB/10); % 比值形式的Eb/No
L=floor(log(number_of_states)/log(fanout)); % 編碼移位寄存器的長度為L+1,最右邊L級是其狀態位,與網格圖中的狀態一一對應(注意并不是與跳頻頻點一一對應)

% pb=zeros(1,times);
WTbar=waitbar(0,'SNR inside loop:please wait...');
for rep=1:times

% source=[randint(1,N,fanout),zeros(1,L)]; % 信息源:(注意不是10進制的,而是fanout進制的)隨機符號流,最后補上L個0符號,使移位寄存器的狀態清零

%***************信源部分(信源是長度為N的16進制符號流)*********************%

source_sequence=randint(1,N,2^M);
source_matrix=reshape(source_sequence,7,N/7); % 特別注意reshape函數是從矩陣A中按列的順序取出元素,返回一個M*N的矩陣,但是注意是把元素按先填第1列,然后填第2列……的順序填到新矩陣中去的,不是按行填寫
source=source_matrix';               % reshape之后得到的是一個7行100列的矩陣,轉置后得到的是一個100行7列的矩陣source,矩陣source的第一行存放的是source_sequence
                                     % 序列的第1到7個符號,第二行存放的是source_sequence序列的第8到14個符號,依此類推    
%*************************************************************************%

% %***********************信源部分************************%
% 
% % 將信息符號流轉化成二進制信息比特流
% dsource=zeros(1,N*BPH); 
% if(BPH~=1)
%     for i=1:N
%         dsource((i-1)*BPH+1:i*BPH)=deci2change(source(i),BPH,2); %%%%%%%%%%%%其實這里是把 2^BPH 進制的符號source(i)轉換成BPH個二進制比特,前面產生的符號流source=randint(1,N,fanout)
%                                                                  %產生的符號流原來本身也就是fanout=2^BPH進制的,這正好相吻合,所以這里并不是把十進制的符號source(i)轉化為
%                                                                  %BPH位二進制比特,而是把2^BPH進制的符號source(i)(顯然source=randint(1,N,fanout)表明source(i)
%                                                                  %的取值范圍被限定在0到fanout-1之間)轉化為BPH位二進制比特,
%     end
% else
%     dsource=source(1:N);%*****
% end
% 
% %******************************************************%


% % *******************差錯控制編碼部分(8,4)碼**********************%
% % G=[1 0 0 0 1 0 1 1;
% %    0 1 0 0 1 1 1 0;
% %    0 0 1 0 1 1 0 1;
% %    0 0 0 1 0 1 1 1];
% G=[1 0 0 0 1 0 1 1;0 1 0 0 1 1 0 1;0 0 1 0 0 1 1 1;0 0 0 1 1 1 1 0]; % (8,4,4)擴展漢明碼的生成矩陣G
% % H=[1 1 1 1 1 1 1 1;1 1 0 1 1 0 0 0;0 1 1 1 0 1 0 0;1 0 1 1 0 0 1 0]; % (8,4,4)擴展漢明碼的一致校驗矩陣H
% % trt=syndtable(H); % (8,4,4)擴展漢明碼的伴隨式譯碼表
% dsource_coded=encode(dsource,8,4,'linear',G)';
% % source_coded0=zeros(1,2*N);
% % *****************************************************************%

%****************差錯控制編碼部分(N,K,Dmin)=(15,7,9)的 RS 碼*****************%

msg_GF=gf(source,M); %把信息符號轉化為GF域的符號
source_coded_GF=rsenc(msg_GF,15,7); % RS編碼后,source_coded_GF是一個100行15列的矩陣,矩陣每一行是一個 RS 碼的碼字

%****************************************************************************%
% % *********************交織部分(塊交織)(基于比特的交織)****************%
% % 僅適用于BPH=2且N=1000時
% interleave_outcome=zeros(1,2*BPH*N);
% A1=zeros(200,200);
% for i=1:2*BPH*N
%     A1(i)=dsource_coded(i);
% end
% A=A1.';
% for i=1:2*BPH*N
%     interleave_outcome(i)=A(i);
% end
% %************************************************%

% % *******************隨機交織************************%
% [interleave_outcome,alpha]=interleave(dsource_coded); % dsource_coded 長度為(n/k)*N*BPH=2*N*BPH
% 
% % ***************************************************%

%**************交織部分(基于16進制GF(16)域符號(即RS碼元)的交織)***************%
codedsequence=zeros(1,1500);
codedsequence_GF=gf(codedsequence,M);
for i=1:1500
    codedsequence_GF(i)=source_coded_GF(i); % 把RS編碼后的碼字矩陣轉化為一串碼字序列,按列讀出,相當于100*15的分組交織
end
% ************* End of the Interleaving Modular *********************%
% % % 編碼和交織后將二進制序列轉換成十進制序列,準備輸入到G函數進行映射
% % if (BPH~=1)
% %     for i=1:2*N
% %         register=interleave_outcome((i-1)*BPH+1:i*BPH);
% %         source_coded_ba0(i)=change2deci(register,2); % 其實是把BPH個二進制比特轉化為一個2^BPH進制的符號,這里BPH=2,就是把2個二進制比特轉化為1個四進制符號(是對的)
% %     end
% % else
% %     source_coded_ba0=interleave_outcome(1:2*N);% source_coded_ba0 是行矢量,source_coded_ba0是編碼輸出十進制符號序列,長度為2N個符號(補2L個0符號之前)
% % end
% 
% source_coded=[source_coded_ba0,zeros(1,L)];% G函數映射前補上L個0符號


% **************** Normal Domain Symbol to Galois Domain Symbol Change Modular ***************** % 
% 編碼和交織后將GF(16)域的16進制符號轉化為普通域的fanout=4進制的符號,準備輸入到G函數進行映射
codedsequence_quart=zeros(1,3000);
for i=1:1500
    for j=0:2^M-1
        if (codedsequence_GF(i)==j)
            codedsequence_quart(2*(i-1)+1:2*i)=quarter_table(j+1,:);
        end
    end
end   % 把1500個編碼后的16進制 RS 碼元都轉化為3000個4進制符號,準備輸入到G函數進行映射(通過測試,結果正確,可以轉化)
source_coded=[codedsequence_quart,zeros(1,L)]; % G函數映射前補上L=2個0符號,總共3002個4進制符號進行G函數映射
% ********************* End of the Domains Change Modular ********************* %


% ******************* G 函數實現部分 ************************ %

% 先定義三個關鍵矩陣"nextstates" "output" "input"
nextstate=zeros(number_of_states,fanout); % nextstate矩陣:行代表網格圖中的各狀態(一一對應),列與輸入移位寄存器的信息符號一一對應,
                                          % 矩陣中存儲的內容是與當前狀態和輸入符號對應的下一狀態號(即存儲網格圖的狀態轉移規則)  
output=zeros(number_of_states,fanout);    % output矩陣:行代表網格圖中的各狀態(一一對應),列與輸入移位寄存器的信息符號一一對應,
                                          % 矩陣中存儲的內容是與當前狀態和輸入符號對應的網格圖分支轉移輸出(分支轉移輸出是跳頻頻率號)
input=zeros(number_of_states,number_of_states);
number_of_out=number_of_states*fanout;% 跳頻頻點數Nt
for i=0:number_of_states-1
    for j=0:fanout-1
        [next_state,out_put]=G_func1(i,j,L,fanout);
        nextstate(i+1,j+1)=next_state;
        output(i+1,j+1)=out_put;
        input(i+1,next_state+1)=j;
    end
end 
% ********************************************************* %



depth_of_trellis=length(source_coded);%*******************
Eb=1;
% Es=Eb*BPH*(1/2);
Es=Eb*(14/15);% Es=Eb*BPH*(k/n)
diversi=2; % 2重分集
Ec=Es/diversi; % 分集后每個分集碼片的能量
% Ej0=(Eb*number_of_out*Q)/(Eb_to_Nj);% 每個多音干擾的能量Ej0
Ej0=(Es*number_of_out)/(BPH*Q*Eb_to_Nj); % 每跳時間內每個多音干擾的能量Ej0
sgma=sqrt(Eb/(2*Eb_to_No));% AWGN的均方根
demod_input=zeros(number_of_out,depth_of_trellis);
f=zeros(1,depth_of_trellis);
% rc=zeros(1,number_of_out);
% rs=zeros(1,number_of_out);
D=0; % D 記錄網格圖的當前狀態,這里初始狀態是0狀態

% % *******************信道和非相干解調部分:加多音干擾和噪聲,然后非相干解調****************** %
% for i=1:depth_of_trellis % i表示網格圖的時間走勢
%     f(i)=output(D+1,source_coded(i)+1); % f(i)是i時刻的分支轉移輸出,即i時刻的跳頻頻率號,頻率號范圍是[0,number_of_out-1]而不是[1,number_of_out]
%     thyta=2*pi*rand;% 干擾音與跳頻信號的相對相位
% %   J=randint(1,Q,number_of_out); % J 矩陣中存放Q個干擾音所在的頻率號,干擾音所在頻率號范圍也是[0,number_of_out-1]而不是[1,number_of_out]
%     J=gen_multijammer(Q,number_of_out);% J 矩陣中存放Q個干擾音所在的頻率號,干擾音所在頻率號范圍也是[0,number_of_out-1]而不是[1,number_of_out]
%     for j=0:number_of_out-1
%         if (j==f(i))
%             rc(j+1)=raylrnd(sqrt(Es))+sgma*randn;% 改了,原來是sqrt(Es)+sgma*randn,信號幅度服從瑞利分布,瑞利分布的參數是sqrt(Es)*222222222222222222222222*
%             rs(j+1)=sgma*randn;
%         else
%             rc(j+1)=sgma*randn;
%             rs(j+1)=sgma*randn;
%         end
%     end
%     jam_rayleigh=raylrnd(sqrt(Ej0));% 干擾音的幅度服從瑞利分布,瑞利分布的參數是sqrt(Ej0)*222222222222222222222222222222222222222222222222222222222222222*

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美电影在线免费观看| 蜜臀av一区二区| 91激情在线视频| 精品影院一区二区久久久| 国产调教视频一区| 久久久亚洲高清| 欧美大片在线观看| 久久久久久久综合日本| www国产精品av| 欧美一区二区精美| 久久一区二区视频| 日韩精品在线一区二区| 日韩三级av在线播放| 欧美videos大乳护士334| 日韩免费高清视频| 国产精品三级电影| 亚洲欧美视频一区| 亚洲在线观看免费视频| 日韩高清一区二区| 久久精品国产第一区二区三区| 亚洲欧洲av色图| 青青青伊人色综合久久| 日韩黄色在线观看| 国产91丝袜在线18| 色婷婷精品久久二区二区蜜臀av| 欧美在线影院一区二区| 精品国产一区二区国模嫣然| www激情久久| 欧美精品在欧美一区二区少妇| 91精品婷婷国产综合久久性色 | 三级一区在线视频先锋| 日韩av一二三| 黄一区二区三区| 成年人网站91| 欧美系列在线观看| 日韩精品一区二| 亚洲蜜臀av乱码久久精品蜜桃| 一区二区在线免费观看| 日本亚洲最大的色成网站www| 懂色av一区二区夜夜嗨| 91麻豆国产福利在线观看| 欧美猛男超大videosgay| 久久蜜臀中文字幕| 一区二区三区高清不卡| 国产乱码精品一区二区三| 91啪九色porn原创视频在线观看| 成人小视频免费观看| 91麻豆精品国产自产在线观看一区| 久久亚洲二区三区| 国产精品伦理一区二区| 午夜激情久久久| 盗摄精品av一区二区三区| 日韩一级大片在线| 亚洲天堂中文字幕| 精品一区二区三区的国产在线播放| 丁香一区二区三区| 91精品国产一区二区| 久久美女高清视频| 爽好多水快深点欧美视频| 日本一不卡视频| 色婷婷狠狠综合| 亚洲精品国久久99热| 国产精品1区二区.| 日韩欧美国产综合| 亚洲午夜日本在线观看| 色婷婷综合久久久| 国产精品丝袜久久久久久app| 日本欧美一区二区在线观看| 欧美日韩专区在线| 亚洲美女在线一区| 色94色欧美sute亚洲线路一ni| 国产亚洲欧美日韩在线一区| 日韩成人免费看| 日韩视频一区二区三区在线播放 | 精品乱人伦一区二区三区| 精品久久久久久最新网址| 日韩和欧美的一区| 欧美在线短视频| 亚洲成人激情av| 欧美亚洲一区三区| 三级一区在线视频先锋 | 自拍偷拍欧美激情| 成人精品视频一区二区三区尤物| 久久久国产一区二区三区四区小说| 香蕉影视欧美成人| 欧美一区二区三区视频在线| 亚洲高清在线精品| 91丝袜国产在线播放| 伊人婷婷欧美激情| 在线免费亚洲电影| 日韩av网站在线观看| 91精品免费在线| 亚洲成av人在线观看| 日韩免费电影一区| 国产一区激情在线| 亚洲三级免费电影| 91影院在线免费观看| 欧美极品aⅴ影院| 欧美亚洲日本一区| 婷婷成人激情在线网| 2欧美一区二区三区在线观看视频| 韩国成人精品a∨在线观看| 日韩欧美在线影院| 国产精品资源在线| 中文字幕一区二区三区不卡在线 | 亚洲视频一区在线| 欧美日韩亚洲丝袜制服| 成人免费小视频| 日韩视频在线你懂得| 毛片av中文字幕一区二区| 国产精品免费av| 在线免费观看日韩欧美| 精品一区二区三区在线播放视频| 久久久久久久久久久久电影 | 国产欧美精品一区二区三区四区 | 国产精品一区二区在线观看网站| 国产精品精品国产色婷婷| 91碰在线视频| 免费视频最近日韩| 国产清纯美女被跳蛋高潮一区二区久久w | 亚洲电影第三页| 欧美电影免费观看高清完整版在| 国产精品自在在线| 亚洲一区自拍偷拍| 日韩欧美在线影院| 99精品桃花视频在线观看| 亚洲成va人在线观看| 久久蜜桃av一区二区天堂| 欧美精品99久久久**| 成人精品小蝌蚪| 黑人巨大精品欧美一区| 亚洲永久免费视频| 久久久不卡影院| 精品国产免费一区二区三区香蕉 | 一区二区三区91| 精品处破学生在线二十三| 欧美猛男gaygay网站| 国产成人精品亚洲午夜麻豆| 亚洲成人激情av| 亚洲欧美日韩久久精品| 久久综合色婷婷| 欧美一区二区在线播放| 一本一道综合狠狠老| 国产成人午夜精品影院观看视频| 亚洲成av人综合在线观看| 一区二区三区在线免费| 欧美精品一区二区三| 欧美日韩二区三区| 欧美日韩一区久久| 91久久香蕉国产日韩欧美9色| www.亚洲精品| 成熟亚洲日本毛茸茸凸凹| 一区二区三区成人| 综合久久给合久久狠狠狠97色| 欧美精品一区二区三区蜜臀| 2020日本不卡一区二区视频| 884aa四虎影成人精品一区| 欧美日韩精品三区| 欧美色手机在线观看| caoporen国产精品视频| 粉嫩av一区二区三区在线播放| 久久精品999| 成人午夜av在线| 国产寡妇亲子伦一区二区| 成人av网站在线| av日韩在线网站| 国产最新精品免费| 99久久777色| 色妹子一区二区| 91国产视频在线观看| 91网站最新网址| 欧美自拍丝袜亚洲| 在线免费观看日本一区| 日本高清成人免费播放| 欧美亚洲一区三区| 99国产精品久久久久久久久久 | 国产盗摄一区二区三区| 国产剧情av麻豆香蕉精品| 国产一区二区在线看| 成人午夜精品一区二区三区| 国产精品羞羞答答xxdd| 91视频免费观看| 欧美精品1区2区| 欧美军同video69gay| 国产午夜精品一区二区三区四区| 日本一二三不卡| 日韩电影在线观看一区| 国产呦精品一区二区三区网站| 暴力调教一区二区三区| 欧美午夜精品久久久久久超碰| 在线视频观看一区| 欧美tk丨vk视频| 国产精品久久综合| 老色鬼精品视频在线观看播放| 国产1区2区3区精品美女| 欧美日韩中字一区| 久久精品视频网| 日韩精彩视频在线观看| 国产超碰在线一区| 日韩欧美二区三区|