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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ber_ofdm_64s_1e4_withclipping_snr20_differcr_1_2_3_nofilter.m

?? 限幅方法降低OFDM系統(tǒng)誤碼率
?? M
?? 第 1 頁 / 共 2 頁
字號:
BitsTx = floor(rand(1,NumLoop*NumSubc)*2);%用rand產(chǎn)生0:1的隨機(jī)數(shù),不會產(chǎn)生負(fù)值,如果用randn會產(chǎn)生負(fù)值;乘以2是為了使用floor函數(shù)

% --------------------------------------------- %
%                   QAM MODULATION              %
% --------------------------------------------- %
% Modulate (Generates QAM symbols)
% input: BitsTx(1,NumLoop*NumSubc); output:SymQAM(NumLoop,NumSubc/2)
SymQAMtmp = reshape(BitsTx,2,NumLoop*NumSubc/2).';
SymQAMtmptmp = bi2de(SymQAMtmp,2,'left-msb');%/?????(bi2de)
%--------------------------------------------------------------------------

QAMTable = [-1-i -1+i 1-i 1+i];
SymQAM = QAMTable(SymQAMtmptmp+1);

% --------------------------------------------- %
% IFFT   input: SymQAM(NumLoop,NumSubc/2); output: SymIFFT(NumSubc,NumLoop)
% --------------------------------------------- %

SymIFFT = zeros(NumSubc,NumLoop);
SymIFFTtmp = reshape(SymQAM,NumSubc/2,NumLoop);%(為什么載波數(shù)除以2)
SymIFFTtmptmp = zeros(NumSubc,NumLoop);
SymIFFTtmptmp(1,:) = real(SymIFFTtmp(1,:)); % 實(shí)數(shù)
SymIFFTtmptmp(NumSubc/2+1,:) = imag(SymIFFTtmp(1,:)); % 實(shí)數(shù)

SymIFFTtmptmp(2:NumSubc/2,:) = SymIFFTtmp(2:NumSubc/2,:);
SymIFFTtmptmp((NumSubc/2+2):NumSubc,:) = flipdim(conj(SymIFFTtmp(2:NumSubc/2,:)),1);

SymIFFT = ifft(SymIFFTtmp,NumSubc,1);%(后邊這個(gè)1是干什么的?)

% --------------------------------------------- %
%             Add cyclic prefix                 %
% --------------------------------------------- %
% input: SymIFFT(NumSubc,NumLoop); output: SymCP(NumSubc + NumCP,NumLoop)
NumAddPrefix = NumSubc + NumCP;
SymCP = zeros(NumAddPrefix,NumLoop);
RowPrefix = (NumSubc - NumCP + 1):NumSubc;
SymCP = [SymIFFT(RowPrefix,:);SymIFFT];%(把保護(hù)間隔放在符號的前面)

% --------------------------------------------- %
%                  限幅                         %
% --------------------------------------------- %
CR = 0.8;
SymCP_Clip_last =  zeros(NumAddPrefix,NumLoop);
SymCP_Clip_temp3 = zeros(NumAddPrefix,1);
%SymCP_Clip_temp2 = zeros()

for nSymbol = 1:NumLoop
    Signal_Power = abs(SymCP(:,nSymbol).^2);
    Peak_Power = max(Signal_Power); %Peak_Power = max(Signal_Power,[],2);
    Mean_Power = mean(Signal_Power);%Mean_Power = mean(Signal_Power,2);
    
    A = CR*sqrt(Mean_Power);
    SymCP_Clip_temp1 = SymCP(:,nSymbol)';%把第nSymbol列的值轉(zhuǎn)換成行向量并付給一個(gè)向量
    SymCP_Clip_temp2 = SymCP_Clip_temp1(Signal_Power>A);
    SymCP_Clip = A*SymCP_Clip_temp2./abs(SymCP_Clip_temp2);
    SymCP_Clip_temp1(Signal_Power>A) = SymCP_Clip;
    
    SymCP_Clip_temp3 = SymCP_Clip_temp1'
    SymCP_Clip_last(:,nSymbol) = SymCP_Clip_temp3;
end
    
    
% --------------------------------------------- %
%             Go through the channel            %
% --------------------------------------------- %
% input: SymCP(NumSubc + NumCP,NumLoop); output: SymCh(1,(NumSubc + NumCP)*NumLoop)
SymChtmp = zeros(1,(NumSubc + NumCP)*NumLoop);
SymChtmp = SymCP_Clip_last(:).';   % 進(jìn)行這個(gè)轉(zhuǎn)置操作之后就成了一個(gè)矢量;       并串變換
% 相當(dāng)于把矩陣的列向量依次排列 改變?yōu)橐粋€(gè)行向量

% % --------------------------------------------- %
% %濾波
% % --------------------------------------------- %
% Ch = [1 1/2 1/4];
% SymChtmptmp = filter(Ch,1,SymChtmp);%濾波
snrIndex3 = 0;
BerSnrTable_CR0P8 = zeros(7,2);%?????
for snr=0:2:13;  % = SNR + 10*log10(log2(2));
    snrIndex3=snrIndex3+1;
    BerSnrTable_CR0P8(snrIndex3,1) = snr;
    SymCh = awgn(SymChtmp,snr,'measured');

    % --------------------------------------------- %
    %            Remove Guard Intervals             %
    % --------------------------------------------- %
    % input: SymCh(1,(NumSubc + NumCP)*NumLoop); output: SymDeCP(NumSubc,NumLoop)
    SymDeCP = zeros(NumSubc,NumLoop);
    SymDeCPtmp = reshape(SymCh,NumSubc + NumCP,NumLoop);
    SymDeCP = SymDeCPtmp((NumCP+1+SyncDelay):NumAddPrefix+SyncDelay,:);

    % --------------------------------------------- %
    %                     FFT                       %
    % --------------------------------------------- %
    % input: SymDeCP(NumSubc,NumLoop); output: SymFFT(NumSubc,NumLoop)
    SymFFT = fft(SymDeCP,NumSubc,1);

    % --------------------------------------------- %
    %        Make Decision(Include DeQAM)           %
    % --------------------------------------------- %
    % SymFFT(NumSubc,NumLoop); output: SymDec(NumSubc,NumLoop)
    SymDec = zeros(NumSubc,NumLoop);
    SymEqtmp(1,:) = SymFFT(1,:)+i*SymFFT(NumSubc/2+1,:);
    SymEqtmp(2:NumSubc/2,:) = SymFFT(2:NumSubc/2,:);%???????????(SymEqtmp是哪里來的?)
    for m = 1:NumLoop
        for n = 1:NumSubc/2
            Real = real(SymEqtmp(n,m));
            Imag = imag(SymEqtmp(n,m));
            if( abs((Real -1)) < abs((Real +1)))%????????每個(gè)點(diǎn)到坐標(biāo)軸上1和-1的距離,哪個(gè)離1近就把1付給它,同理得-1
                SymDec(2*n-1,m) = 1;
            else
                SymDec(2*n-1,m) = 0;%把實(shí)部放在奇數(shù)行
            end

            if( abs((Imag -1)) < abs((Imag +1  )) )
                SymDec(2*n,m) = 1;

            else
                SymDec(2*n,m) = 0;%把虛部放在偶數(shù)行
            end
        end
    end
    %----------------------------------------------------------------------
    % Bit Error
    %----------------------------------------------------------------------
    BitsRx = zeros(1,NumSubc*NumLoop);
    BitsRx = SymDec(:).';
    [Num,Ber] = symerr(BitsTx,BitsRx)%(BitsTx是原始數(shù)據(jù)符號)
    %BerSnrTable(snr+1,2) = Num ;
    BerSnrTable_CR0P8(snrIndex3,2) = Ber ;%BerSnrTable(snr+1,3) = Ber ;
end

BerSnrTable_CP0P8_plot = zeros(7,1);
BerSnrTable_CP0P8_plot = BerSnrTable_CR0P8(:,2);
save('CR_0P8','BerSnrTable_CP0P8_plot');
    semilogy(BerSnrTable_CR0P8(:,1),BerSnrTable_CP0P8_plot,'*-g');
    legend('CR=2');
%     xlabel('SNR');
%     ylabel('BER');
    grid on;
    hold on;
    % ------------------------------------------------------------------------
    time_of_sim = toc
%end;
% 
% 
% 
% 
% 
%CR=0.6
% --------------------------------------------- %
%                   參數(shù)定義                     %
% --------------------------------------------- %
% Initialize the parameters
% NumLoop = 10000;
% NumSubc = 64;
% NumCP = 8;
% SyncDelay = 0;
%-----------------------------------------------

%-----------------------------------------------
% Generate the random binary stream for transmit test
%-----------------------------------------------
BitsTx = floor(rand(1,NumLoop*NumSubc)*2);%用rand產(chǎn)生0:1的隨機(jī)數(shù),不會產(chǎn)生負(fù)值,如果用randn會產(chǎn)生負(fù)值;乘以2是為了使用floor函數(shù)

% --------------------------------------------- %
%                   QAM MODULATION              %
% --------------------------------------------- %
% Modulate (Generates QAM symbols)
% input: BitsTx(1,NumLoop*NumSubc); output:SymQAM(NumLoop,NumSubc/2)
SymQAMtmp = reshape(BitsTx,2,NumLoop*NumSubc/2).';
SymQAMtmptmp = bi2de(SymQAMtmp,2,'left-msb');%/?????(bi2de)
%--------------------------------------------------------------------------

QAMTable = [-1-i -1+i 1-i 1+i];
SymQAM = QAMTable(SymQAMtmptmp+1);

% --------------------------------------------- %
% IFFT   input: SymQAM(NumLoop,NumSubc/2); output: SymIFFT(NumSubc,NumLoop)
% --------------------------------------------- %

SymIFFT = zeros(NumSubc,NumLoop);
SymIFFTtmp = reshape(SymQAM,NumSubc/2,NumLoop);%(為什么載波數(shù)除以2)
SymIFFTtmptmp = zeros(NumSubc,NumLoop);
SymIFFTtmptmp(1,:) = real(SymIFFTtmp(1,:)); % 實(shí)數(shù)
SymIFFTtmptmp(NumSubc/2+1,:) = imag(SymIFFTtmp(1,:)); % 實(shí)數(shù)

SymIFFTtmptmp(2:NumSubc/2,:) = SymIFFTtmp(2:NumSubc/2,:);
SymIFFTtmptmp((NumSubc/2+2):NumSubc,:) = flipdim(conj(SymIFFTtmp(2:NumSubc/2,:)),1);

SymIFFT = ifft(SymIFFTtmp,NumSubc,1);%(后邊這個(gè)1是干什么的?)

% --------------------------------------------- %
%             Add cyclic prefix                 %
% --------------------------------------------- %
% input: SymIFFT(NumSubc,NumLoop); output: SymCP(NumSubc + NumCP,NumLoop)
NumAddPrefix = NumSubc + NumCP;
SymCP = zeros(NumAddPrefix,NumLoop);
RowPrefix = (NumSubc - NumCP + 1):NumSubc;
SymCP = [SymIFFT(RowPrefix,:);SymIFFT];%(把保護(hù)間隔放在符號的前面)

% --------------------------------------------- %
%                  限幅                         %
% --------------------------------------------- %
CR = 0.6;
SymCP_Clip_last =  zeros(NumAddPrefix,NumLoop);
SymCP_Clip_temp3 = zeros(NumAddPrefix,1);
%SymCP_Clip_temp2 = zeros()

for nSymbol = 1:NumLoop
    Signal_Power = abs(SymCP(:,nSymbol).^2);
    Peak_Power = max(Signal_Power); %Peak_Power = max(Signal_Power,[],2);
    Mean_Power = mean(Signal_Power);%Mean_Power = mean(Signal_Power,2);
    
    A = CR*sqrt(Mean_Power);
    SymCP_Clip_temp1 = SymCP(:,nSymbol)';%把第nSymbol列的值轉(zhuǎn)換成行向量并付給一個(gè)向量
    SymCP_Clip_temp2 = SymCP_Clip_temp1(Signal_Power>A);
    SymCP_Clip = A*SymCP_Clip_temp2./abs(SymCP_Clip_temp2);
    SymCP_Clip_temp1(Signal_Power>A) = SymCP_Clip;
    
    SymCP_Clip_temp3 = SymCP_Clip_temp1'
    SymCP_Clip_last(:,nSymbol) = SymCP_Clip_temp3;
end
    
    
% --------------------------------------------- %
%             Go through the channel            %
% --------------------------------------------- %
% input: SymCP(NumSubc + NumCP,NumLoop); output: SymCh(1,(NumSubc + NumCP)*NumLoop)
SymChtmp = zeros(1,(NumSubc + NumCP)*NumLoop);
SymChtmp = SymCP_Clip_last(:).';   % 進(jìn)行這個(gè)轉(zhuǎn)置操作之后就成了一個(gè)矢量;       并串變換
% 相當(dāng)于把矩陣的列向量依次排列 改變?yōu)橐粋€(gè)行向量

% % --------------------------------------------- %
% %濾波
% % --------------------------------------------- %
% Ch = [1 1/2 1/4];
% SymChtmptmp = filter(Ch,1,SymChtmp);%濾波
snrIndex2 = 0;
BerSnrTable_CR0P6 = zeros(7,2);%?????
for snr=0:2:13;  % = SNR + 10*log10(log2(2));
    snrIndex2=snrIndex2+1;
    BerSnrTable_CR0P6(snrIndex2,1) = snr;
    SymCh = awgn(SymChtmp,snr,'measured');

    % --------------------------------------------- %
    %            Remove Guard Intervals             %
    % --------------------------------------------- %
    % input: SymCh(1,(NumSubc + NumCP)*NumLoop); output: SymDeCP(NumSubc,NumLoop)
    SymDeCP = zeros(NumSubc,NumLoop);
    SymDeCPtmp = reshape(SymCh,NumSubc + NumCP,NumLoop);
    SymDeCP = SymDeCPtmp((NumCP+1+SyncDelay):NumAddPrefix+SyncDelay,:);

    % --------------------------------------------- %
    %                     FFT                       %
    % --------------------------------------------- %
    % input: SymDeCP(NumSubc,NumLoop); output: SymFFT(NumSubc,NumLoop)
    SymFFT = fft(SymDeCP,NumSubc,1);

    % --------------------------------------------- %
    %        Make Decision(Include DeQAM)           %
    % --------------------------------------------- %
    % SymFFT(NumSubc,NumLoop); output: SymDec(NumSubc,NumLoop)
    SymDec = zeros(NumSubc,NumLoop);
    SymEqtmp(1,:) = SymFFT(1,:)+i*SymFFT(NumSubc/2+1,:);
    SymEqtmp(2:NumSubc/2,:) = SymFFT(2:NumSubc/2,:);%???????????(SymEqtmp是哪里來的?)
    for m = 1:NumLoop
        for n = 1:NumSubc/2
            Real = real(SymEqtmp(n,m));
            Imag = imag(SymEqtmp(n,m));
            if( abs((Real -1)) < abs((Real +1)))%????????每個(gè)點(diǎn)到坐標(biāo)軸上1和-1的距離,哪個(gè)離1近就把1付給它,同理得-1
                SymDec(2*n-1,m) = 1;
            else
                SymDec(2*n-1,m) = 0;%把實(shí)部放在奇數(shù)行
            end

            if( abs((Imag -1)) < abs((Imag +1  )) )
                SymDec(2*n,m) = 1;

            else
                SymDec(2*n,m) = 0;%把虛部放在偶數(shù)行
            end
        end
    end
    %----------------------------------------------------------------------
    % Bit Error
    %----------------------------------------------------------------------
    BitsRx = zeros(1,NumSubc*NumLoop);
    BitsRx = SymDec(:).';
    [Num,Ber] = symerr(BitsTx,BitsRx)%(BitsTx是原始數(shù)據(jù)符號)
    %BerSnrTable(snr+1,2) = Num ;
    BerSnrTable_CR0P6(snrIndex2,2) = Ber ;%BerSnrTable(snr+1,3) = Ber ;
end
BerSnrTable_CR0P6_plot = zeros(7,1);
BerSnrTable_CR0P6_plot = BerSnrTable_CR0P6(:,2);
save('CR_0P6','BerSnrTable_CR0P6_plot');
    semilogy(BerSnrTable_CR0P6(:,1),BerSnrTable_CR0P6(:,2),'+:m');
    legend('CR=1');
%     xlabel('SNR');
%     ylabel('BER');
    grid on;
    hold on;
    % ------------------------------------------------------------------------
    time_of_sim = toc
% end;
    

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久91精品国产一区二区精品| 国产精品久久久久久户外露出 | 国产一区日韩二区欧美三区| 欧美激情一区二区三区在线| 91精品国产91热久久久做人人| 风间由美一区二区三区在线观看 | 成人黄色在线看| 国产麻豆视频一区二区| 亚洲午夜精品网| 国产精品国产精品国产专区不蜜| 精品久久久久久久久久久久久久久久久| 97se亚洲国产综合自在线不卡| 国产一区二区视频在线播放| 日韩成人精品在线| 亚洲午夜在线视频| 亚洲欧美偷拍卡通变态| 国产日韩高清在线| 久久综合视频网| 日韩美女在线视频| 欧美精品第1页| 在线视频观看一区| 色综合久久久久网| 99精品欧美一区二区三区综合在线| 久久成人免费日本黄色| 日本不卡一区二区三区 | 国产一区二区三区| 日韩av一区二区三区四区| 亚洲第一成年网| 亚洲图片欧美综合| 一区二区三区欧美视频| 一区在线观看视频| 中文字幕精品—区二区四季| 久久精品夜色噜噜亚洲aⅴ| 日韩精品综合一本久道在线视频| 欧美老肥妇做.爰bbww视频| 欧美系列日韩一区| 欧美色大人视频| 欧美日韩国产影片| 欧美午夜精品久久久久久孕妇| 色综合天天天天做夜夜夜夜做| 91女神在线视频| 色香蕉久久蜜桃| 91成人国产精品| 欧美日韩的一区二区| 欧美日本一道本| 日韩美女天天操| 亚洲精品国产精华液| 亚洲女与黑人做爰| 亚洲一区二区欧美日韩 | 成人性生交大片免费看中文网站| 国产麻豆成人传媒免费观看| 国产盗摄视频一区二区三区| 高清成人免费视频| 一本色道久久综合亚洲91| 在线亚洲欧美专区二区| 欧美乱熟臀69xxxxxx| 日韩欧美你懂的| 国产日韩av一区| 中文字幕一区二区三区蜜月 | 奇米777欧美一区二区| 激情偷乱视频一区二区三区| 懂色一区二区三区免费观看| 99精品1区2区| 337p亚洲精品色噜噜狠狠| 欧美sm极限捆绑bd| 中文字幕佐山爱一区二区免费| 亚洲高清中文字幕| 国产伦精一区二区三区| 91小视频在线免费看| 欧美三级在线视频| 欧美成人女星排名| 亚洲欧美综合色| 性做久久久久久免费观看| 激情文学综合丁香| 91久久精品一区二区二区| 91精品国产aⅴ一区二区| 欧美激情在线看| 亚洲mv在线观看| 国产精品456露脸| 欧美视频在线不卡| 久久嫩草精品久久久精品一| 一区二区三区精品久久久| 久久激情五月婷婷| 99国产精品久久久久| 日韩一区二区三区免费看 | 自拍偷拍亚洲综合| 婷婷一区二区三区| 国产成人在线视频网址| 欧美日韩亚洲不卡| 国产精品国产成人国产三级| 免费看欧美女人艹b| 色综合色综合色综合| 欧美videofree性高清杂交| 亚洲男同1069视频| 国产麻豆91精品| 91精品国产综合久久久久久久久久| 欧美国产日韩一二三区| 日本午夜一本久久久综合| av一区二区不卡| 久久综合色天天久久综合图片| 亚洲第一电影网| 91啦中文在线观看| 久久久精品免费网站| 奇米在线7777在线精品| 91福利国产精品| 亚洲欧美自拍偷拍色图| 国内精品写真在线观看| 欧美精品一级二级| 亚洲蜜臀av乱码久久精品 | 欧美欧美午夜aⅴ在线观看| 国产精品久久久一本精品| 国产一区美女在线| 欧美成人一区二区| 日韩1区2区日韩1区2区| 欧洲激情一区二区| 亚洲人成网站影音先锋播放| 国产精品99精品久久免费| 日韩欧美国产电影| 日韩中文字幕不卡| 欧美日韩高清在线播放| 亚洲人成伊人成综合网小说| 成人福利电影精品一区二区在线观看 | 亚洲影视在线观看| 色综合久久88色综合天天6| 国产精品成人免费| 成人小视频免费观看| 国产欧美一区二区精品秋霞影院| 精品在线播放免费| 欧美变态tickling挠脚心| 捆绑紧缚一区二区三区视频| 欧美一区在线视频| 免费成人在线视频观看| 日韩一级二级三级| 男女激情视频一区| 精品久久久久久亚洲综合网| 麻豆精品一区二区| 日韩一区二区三| 国产综合色精品一区二区三区| 欧美α欧美αv大片| 国产一区高清在线| 久久精品人人做人人爽97| 国产成人综合在线| 国产精品污污网站在线观看 | 欧美一区在线视频| 久久国产福利国产秒拍| 精品粉嫩超白一线天av| 国内精品久久久久影院一蜜桃| 久久久精品黄色| 91在线免费播放| 亚洲成人你懂的| 欧美成人午夜电影| 成人国产一区二区三区精品| 青草国产精品久久久久久| 91精品国产色综合久久不卡电影| 美女被吸乳得到大胸91| 亚洲精品一区在线观看| 国产福利一区二区| 亚洲欧美激情视频在线观看一区二区三区 | 中文字幕中文字幕在线一区| 色欧美乱欧美15图片| 亚洲高清免费一级二级三级| 日韩精品综合一本久道在线视频| 国产精品一二三在| 亚洲免费视频中文字幕| 欧美一区二区日韩| 高清不卡一区二区| 一区二区在线观看免费视频播放| 欧美精品乱码久久久久久按摩| 国产在线观看一区二区| 亚洲精品少妇30p| 欧美一级生活片| jlzzjlzz亚洲女人18| 三级欧美在线一区| 亚洲国产高清在线观看视频| 欧美中文一区二区三区| 国产在线精品一区二区| 亚洲女人****多毛耸耸8| 欧美一级xxx| 91在线国产福利| 精一区二区三区| 亚洲伦理在线精品| 欧美电影免费观看高清完整版在| jiyouzz国产精品久久| 麻豆国产欧美日韩综合精品二区| 久久在线观看免费| 欧美日韩高清一区| 波多野结衣中文一区| 欧美96一区二区免费视频| 中文字幕制服丝袜一区二区三区| 欧美一级二级在线观看| 色综合久久久久综合99| 国产乱码精品一区二区三区av | 韩国精品一区二区| 亚洲一二三区在线观看| 国产色综合一区| 欧美一区二区日韩一区二区| 色哟哟一区二区| 丁香婷婷综合五月| 麻豆久久久久久久| 亚洲国产成人av|