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

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

?? testfunction.cpp

?? 這是一個MIMO的ITPP源代碼
?? CPP
字號:

#include "stdafx.h"
#include "TestFunction.h"


void Test_STBC(void)
{

  MIMO  mimo;
  QAM qpsk(16);
  CSTBC STCoding;     //Space-Time Coding
  MIMOChannel channel;
  const vec EbN0dB = "-5:1:20";        // SNR range
  int Number_of_bits;
  double Ec, Eb;
  vec  EbN0, N0, noise_variance, bit_error_rate; //vec is a vector containing double


  Ec = 1.0;                      //The transmitted energy per QPSK symbol is 1.
  Eb = Ec / 2.0;                 //The transmitted energy per bit is 0.5.
  //EbN0dB = linspace(0.0,9.0,10); //Simulate for 10 Eb/N0 values from 0 to 9 dB.
  EbN0 = inv_dB(EbN0dB);         //Calculate Eb/N0 in a linear scale instead of dB.
  N0 = Eb * pow(EbN0,-1.0);      //N0 is the variance of the (complex valued) noise.
  Number_of_bits = 1000000;       //One hundred thousand bits is transmitted for each Eb/N0 value

  Array<BERC> beruc(length(EbN0dB));  // counter for uncoded BER
  bit_error_rate.set_size(EbN0dB.length(),false);

  for (int nsnr=0; nsnr<length(EbN0dB); nsnr++)
  {
    bvec transmitted_bits,received_bits;
    cvec transmitted_signal,received_signal;
    cmat tr_STSignal, rec_STSignal;
    //general the transmitted bits 
    transmitted_bits = randb(Number_of_bits);
    
    //modulate the transmitted bits
    transmitted_signal = qpsk.modulate_bits(transmitted_bits);
    
    //ST encoder
    STCoding.Encoder(transmitted_signal,tr_STSignal);
    
    //through the channel
    channel.IniChannel(2,2);
    channel.set_noise(N0(nsnr));
    rec_STSignal = channel(tr_STSignal);
    //cmat rec_STSignal = tr_STSignal;
    
    //ST decoder
    STCoding.Decoder(rec_STSignal,channel.GetChannel(),received_signal);
    //STCoding.Decoder(tr_STSignal,channel.GetChannel(),received_signal);  
    
    //Demodulate the bits
    received_bits = qpsk.demodulate_bits(received_signal/sqrt(2.0)); 
	//Count the number of errors
    beruc(nsnr).count(transmitted_bits,received_bits);
    //bit_error_rate(nsnr) = beruc(nsnr).get_errorrate();

	cout<<endl<<"the SNR:"<<EbN0dB(nsnr)<<"has been simulated"<<endl;
	cout<<"bit_error_rate"<<beruc(nsnr).get_errorrate();
  }

  for (int nsnr=0; nsnr<length(EbN0dB); nsnr++)
  {
    bit_error_rate(nsnr) = beruc(nsnr).get_errorrate();

  }

  //////////////////////////////////////////////////
  //Save simulation result to File.
  //////////////////////////////////////////////////
  it_file ff("Test_STBC1.it");

  // Save channel coefficients to the output file
  //ff << Name("transmitted_bits") << transmitted_bits;
  //ff << Name("transmitted_signal") << transmitted_signal;

  //ff << Name("channel") << channel.GetChannel();
  //ff << Name("tr_STSignal") << tr_STSignal;
  //ff << Name("rec_STSignal") << rec_STSignal;


  //ff << Name("received_signal") << received_signal;
  //ff << Name("received_bits") << received_bits;
  ff << Name("bit_error_rate")<<bit_error_rate;
  // Close the output file
  ff.close();
}

void Test_AWGNChannel()
{
  //Initiate the AWGN_Channel class
  double noisevar = 0.001;
  AWGN_Channel awgn_channel(noisevar);
  
  //Initiate a QPSK-modulator, and generate the transmitted signal
  QAM qpsk(16);
  bvec transmitted_bits = randb(500);
  cvec transmitted_signal = qpsk.modulate_bits(transmitted_bits);
  
  //Usage of the member operator ()
  cvec received_signal = awgn_channel(transmitted_signal);
  
  //Demodulate the bits
  bvec received_bits = qpsk.demodulate_bits(received_signal);

  //////////////////////////////////////////////////
  //Save simulation result to File.
  //////////////////////////////////////////////////
  it_file ff("Test_AWGNChannel.it");

  // Save channel coefficients to the output file
  ff << Name("transmitted_bits") << transmitted_bits;
  ff << Name("transmitted_signal") << transmitted_signal;
  ff << Name("received_signal") << received_signal;
  ff << Name("received_bits") << received_bits;
  // Close the output file
  ff.close();

}


int Test_MIMO(int nC,int nRx,int nTx,int Tc)
{
  // -- modulation and channel parameters (taken from command line input) --
  //int nC;                    // type of constellation  (1=QPSK, 2=16-QAM, 3=64-QAM)
  //int nRx;                   // number of receive antennas
  //int nTx;                   // number of transmit antennas
  //int Tc;                    // coherence time (number of channel vectors with same H)

  ////add by ssw
  //nC = 2;
  //nRx = 2;
  //nTx = 2;
  //Tc = 1;
 ////add by ssw


 /* if (argc!=5) 
  {
    cout << "Usage: cm nTx nRx nC Tc" << endl << "Example: cm 2 2 1 100000 (2x2 QPSK MIMO on slow fading channel)" << endl;
    exit(1);
  } 
  else 
  {
    sscanf(argv[1],"%i",&nTx);
    sscanf(argv[2],"%i",&nRx);
    sscanf(argv[3],"%i",&nC);
    sscanf(argv[4],"%i",&Tc);
  }
*/
  cout << "Initializing.. " << nTx << " TX antennas, " << nRx << " RX antennas, "
       << (1<<nC) << "-PAM per dimension, coherence time " << Tc << endl;

  // -- simulation control parameters --
  const vec EbN0db = "-5:0.5:50";        // SNR range
  const int Nmethods = 2;                 // number of demodulators to try
  const int Nbitsmax = 50000000;  // maximum number of bits to ever simulate per SNR point
  const int Nu = 1000;                   // length of data packet (before applying channel coding)

  int Nbers, Nfers;              // target number of bit/frame errors per SNR point
  double BERmin, FERmin;         // BER/FER at which to terminate simulation
  if (Tc==1) 
  {           // Fast fading channel, BER is of primary interest
    BERmin = 0.001;      // stop simulating a given method if BER<this value
    FERmin = 1.0e-10;    // stop simulating a given method if FER<this value
    Nbers = 1000;        // move to next SNR point after counting 1000 bit errors
    Nfers = 200;         // do not stop on this condition
  } 
  else 
  {               // Slow fading channel, FER is of primary interest here
    BERmin = 1.0e-15;    // stop simulating a given method if BER<this value
    FERmin = 0.01;       // stop simulating a given method if FER<this value
    Nbers = -1;          // do not stop on this condition
    Nfers = 200;         // move to next SNR point after counting 200 frame errors
  }

  // -- Channel code parameters --
  Convolutional_Code code;
  ivec generator(3);
  generator(0)=0133;  // use rate 1/3 code
  generator(1)=0165;
  generator(2)=0171;
  double rate=1.0/3.0;
  code.set_generator_polynomials(generator, 7);
  bvec dummy;
  code.encode_tail(randb(Nu),dummy);
  const int Nc = length(dummy);      // find out how long the coded blocks are

  // ============= Initialize ====================================

  const int Nctx = (int) (2*nC*nTx*ceil(double(Nc)/double(2*nC*nTx)));   // Total number of bits to transmit
  const int Nvec = Nctx/(2*nC*nTx);          // Number of channel vectors to transmit
  const int Nbitspvec = 2*nC*nTx;            // Number of bits per channel vector

  // initialize MIMO channel with uniform QAM per complex dimension and Gray coding
  ND_UQAM chan;
  chan.set_M(nTx, 1<<(2*nC));
  cout << chan << endl;

  // initialize interleaver
  Sequence_Interleaver<bin> sequence_interleaver_b(Nctx);
  Sequence_Interleaver<int> sequence_interleaver_i(Nctx);
  sequence_interleaver_b.randomize_interleaver_sequence();
  sequence_interleaver_i.set_interleaver_sequence(sequence_interleaver_b.get_interleaver_sequence());

  //  RNG_randomize();

  Array<cvec> Y(Nvec);        // received data
  Array<cmat> H(Nvec/Tc+1);   // channel matrix (new matrix for each coherence interval)

  ivec Contflag = ones_i(Nmethods);   // flag to determine whether to run a given demodulator
  if (pow(2.0,nC*2.0*nTx)>256) 
  {      // ML decoder too complex..
    Contflag(1)=0;
  }
  if (nTx>nRx) 
  {
    Contflag(0)=0;                    // ZF not for underdetermined systems
  }
  cout << "Running methods: " << Contflag << endl;

  cout.setf(ios::fixed, ios::floatfield);
  cout.setf(ios::showpoint);
  cout.precision(5);

  // ================== Run simulation =======================
  for (int nsnr=0; nsnr<length(EbN0db); nsnr++) 
  {
    const double Eb=1.0; // transmitted energy per information bit
    const double N0 = inv_dB(-EbN0db(nsnr));
    const double sigma2=N0;   // Variance of each scalar complex noise sample
    const double Es=rate*2*nC*Eb; // Energy per complex scalar symbol
    // (Each transmitted scalar complex symbol contains rate*2*nC
    // information bits.)
    const double Ess=sqrt(Es);

    Array<BERC> berc(Nmethods);  // counter for coded BER
    Array<BERC> bercu(Nmethods); // counter for uncoded BER
    Array<BLERC> ferc(Nmethods); // counter for coded FER

    for (int i=0; i<Nmethods; i++) 
	{
      ferc(i).set_blocksize(Nu);
    }

    long int nbits=0;
    while (nbits<Nbitsmax) 
	{
      nbits += Nu;

      // generate and encode random data
      bvec inputbits = randb(Nu);
      bvec txbits;
      code.encode_tail(inputbits, txbits);
      // coded block length is not always a multiple of the number of
      // bits per channel vector
      txbits=concat(txbits,randb(Nctx-Nc));
      txbits = sequence_interleaver_b.interleave(txbits);

      // -- generate channel and data ----
      for (int k=0; k<Nvec; k++) 
	  {
        /* A complex valued channel matrix is used here. An
           alternative (with equivalent result) would be to use a
           real-valued (structured) channel matrix of twice the
           dimension.
        */
        if (k%Tc==0) 
		{       // generate a new channel realization every Tc intervals
          H(k/Tc) = Ess*randn_c(nRx,nTx);
        }

        // modulate and transmit bits
        bvec bitstmp = txbits(k*2*nTx*nC,(k+1)*2*nTx*nC-1);
        cvec x=chan.modulate_bits(bitstmp);
        cvec e=sqrt(sigma2)*randn_c(nRx);
        Y(k) = H(k/Tc)*x+e;
      }

      // -- demodulate --
      Array<QLLRvec> LLRin(Nmethods);
      for (int i=0; i<Nmethods; i++) 
	  {
        LLRin(i) = zeros_i(Nctx);
      }

      QLLRvec llr_apr =zeros_i(nC*2*nTx);  // no a priori input to demodulator
      QLLRvec llr_apost=zeros_i(nC*2*nTx);
      for (int k=0; k<Nvec; k++) 
	  {
        // zero forcing demodulation
        if (Contflag(0)) 
		{
          chan.demodulate_soft_bits(Y(k), H(k/Tc), sigma2, llr_apr, llr_apost,
                                    ND_UQAM::ZF_LOGMAP);
          LLRin(0).set_subvector(k*Nbitspvec,(k+1)*Nbitspvec-1,llr_apost);
        }

        // ML demodulation
        if (Contflag(1)) 
		{
          chan.demodulate_soft_bits(Y(k), H(k/Tc), sigma2, llr_apr, llr_apost);
          LLRin(1).set_subvector(k*Nbitspvec,(k+1)*Nbitspvec-1,llr_apost);
        }
      }

      // -- decode and count errors --
      for (int i=0; i<Nmethods; i++) 
	  {
        bvec decoded_bits;
        if (Contflag(i)) 
		{
          bercu(i).count(txbits(0,Nc-1),LLRin(i)(0,Nc-1)<0);  // uncoded BER
          LLRin(i) = sequence_interleaver_i.deinterleave(LLRin(i),0);
          // QLLR values must be converted to real numbers since the convolutional decoder wants this
          vec llr=chan.get_llrcalc().to_double(LLRin(i).left(Nc));
          //      llr=-llr; // UNCOMMENT THIS LINE IF COMPILING WITH 3.10.5 OR EARLIER (BEFORE HARMONIZING LLR CONVENTIONS)
          code.decode_tail(llr,decoded_bits);
          berc(i).count(inputbits(0,Nu-1),decoded_bits(0,Nu-1));  // coded BER
          ferc(i).count(inputbits(0,Nu-1),decoded_bits(0,Nu-1));  // coded FER
        }
      }

      /* Check whether it is time to terminate the simulation.
       Terminate when all demodulators that are still running have
       counted at least Nbers or Nfers bit/frame errors. */
      int minber=1000000;
      int minfer=1000000;
      for (int i=0; i<Nmethods; i++) 
	  {
        if (Contflag(i)) 
		{
          minber=min(minber,round_i(berc(i).get_errors()));
          minfer=min(minfer,round_i(ferc(i).get_errors()));
        }
      }
      if (Nbers>0 && minber>Nbers)  break;
      if (Nfers>0 && minfer>Nfers)  break;
    }

    cout << "-----------------------------------------------------" << endl;
    cout << "Eb/N0: " << EbN0db(nsnr) << " dB. Simulated " << nbits << " bits." << endl;
    cout << " Uncoded BER: " << bercu(0).get_errorrate() << " (ZF);     " << bercu(1).get_errorrate() << " (ML)" << endl;
    cout << " Coded BER:   " << berc(0).get_errorrate()  << " (ZF);     " << berc(1).get_errorrate()  << " (ML)" << endl;
    cout << " Coded FER:   " << ferc(0).get_errorrate()  << " (ZF);     " << ferc(1).get_errorrate()  << " (ML)" << endl;
    cout.flush();

    /* Check wheter it is time to terminate simulation. Stop when all
    methods have reached the min BER/FER of interest. */
    int contflag=0;
    for (int i=0; i<Nmethods; i++) 
	{
      if (Contflag(i)) 
	  {
        if (berc(i).get_errorrate()>BERmin)    contflag=1;   
		else { Contflag(i)= 0; }
        if (ferc(i).get_errorrate()>FERmin)    contflag=1;   
		else { Contflag(i)= 0; }
      }
    }
    if (contflag)  continue; 
	else break; 
  }

  return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品乱码久久久久久| 91蝌蚪porny| 成人a区在线观看| 欧美性感一区二区三区| 欧美成人精品3d动漫h| 国产日韩亚洲欧美综合| 亚洲综合色在线| 久久电影网站中文字幕| 99精品欧美一区二区三区小说| 欧美专区日韩专区| 久久久蜜桃精品| 亚洲综合久久久| 国产乱人伦偷精品视频免下载| 色综合天天视频在线观看| 日韩一级视频免费观看在线| 国产精品视频一二三区| 首页国产欧美日韩丝袜| 国产1区2区3区精品美女| 欧美日本一道本在线视频| 国产午夜精品一区二区三区四区 | 欧美亚洲禁片免费| 777xxx欧美| 亚洲欧美综合色| 韩国视频一区二区| 欧美性猛交一区二区三区精品 | 国产精品影视网| 在线免费观看不卡av| 久久久久久久久免费| 婷婷综合久久一区二区三区| 春色校园综合激情亚洲| 日韩一区二区三区免费看| 国产精品久久看| 国产又粗又猛又爽又黄91精品| 精品污污网站免费看| 国产精品久久午夜夜伦鲁鲁| 久草中文综合在线| 欧美精品v日韩精品v韩国精品v| 国产精品不卡视频| 国产成人综合网站| 911国产精品| 一区二区成人在线视频| 成人av免费观看| 国产婷婷色一区二区三区四区| 免费亚洲电影在线| 欧美人伦禁忌dvd放荡欲情| 17c精品麻豆一区二区免费| 国产精品自拍av| 日韩精品中文字幕一区二区三区 | 日韩色视频在线观看| 亚洲一区中文日韩| 91视视频在线直接观看在线看网页在线看| 精品精品国产高清一毛片一天堂| 亚洲成人先锋电影| 欧美少妇性性性| 一区二区三区日韩精品| 一本大道综合伊人精品热热| 国产精品国产三级国产| 国产福利视频一区二区三区| 精品国产网站在线观看| 免费成人在线观看| 欧美一级xxx| 奇米色777欧美一区二区| 欧美日韩不卡一区| 亚洲成a人v欧美综合天堂下载| 色香色香欲天天天影视综合网| 中文字幕日韩一区二区| av电影天堂一区二区在线| 中文字幕免费不卡在线| 国产69精品一区二区亚洲孕妇| 久久久777精品电影网影网 | 国产69精品久久久久毛片| 国产精品久久久久久久裸模| 国产精品色在线| 国产麻豆精品在线观看| 久久久噜噜噜久久中文字幕色伊伊 | 秋霞成人午夜伦在线观看| 欧美绝品在线观看成人午夜影视| 日日夜夜免费精品视频| 欧美三级午夜理伦三级中视频| 午夜私人影院久久久久| 欧美一区二区在线播放| 免费在线一区观看| 亚洲精品一区二区在线观看| 国产乱一区二区| 国产精品久久精品日日| 色综合天天在线| 亚洲午夜成aⅴ人片| 欧美一区二区三区视频在线观看| 免费一区二区视频| 国产视频一区在线播放| 成人免费视频视频| 亚洲欧美日韩一区| 欧美精品第1页| 欧美日本在线看| 日韩精品一二三| 久久夜色精品一区| 本田岬高潮一区二区三区| 一区二区三区在线播放| 91精品国产欧美一区二区成人| 国产伦理精品不卡| 国产精品乱人伦中文| 91国偷自产一区二区三区成为亚洲经典 | 黄网站免费久久| 国产精品久久久久国产精品日日| 欧美性欧美巨大黑白大战| 免费看黄色91| 国产精品美女一区二区| 欧美三日本三级三级在线播放| 青青草一区二区三区| 欧美激情一区二区三区蜜桃视频| 96av麻豆蜜桃一区二区| 五月开心婷婷久久| 久久久久久久久蜜桃| 日本丰满少妇一区二区三区| 蜜臀av在线播放一区二区三区| 国产精品嫩草久久久久| 欧美亚洲国产bt| 精品一区二区免费看| 亚洲欧美综合另类在线卡通| 91 com成人网| 成人国产精品免费观看视频| 日韩和欧美一区二区三区| 中文字幕成人av| 这里只有精品电影| 成人av第一页| 久久se精品一区二区| 亚洲女性喷水在线观看一区| 日韩精品专区在线影院观看| 色综合久久久久久久久| 精品伊人久久久久7777人| 亚洲精品五月天| 久久久久高清精品| 884aa四虎影成人精品一区| 99麻豆久久久国产精品免费优播| 日韩电影在线免费看| 亚洲欧美日韩在线| 久久久久久久久久久黄色| 欧美久久久久久久久中文字幕| 成人性色生活片免费看爆迷你毛片| 日韩国产欧美一区二区三区| 亚洲日穴在线视频| 久久人人爽爽爽人久久久| 欧美色爱综合网| 91麻豆精东视频| 国产一区二区免费视频| 视频一区中文字幕国产| 亚洲日本va在线观看| 久久久综合九色合综国产精品| 欧美日韩一二三| 在线亚洲免费视频| 波多野结衣在线一区| 国产一区 二区 三区一级| 日本视频免费一区| 亚洲精品第1页| 综合欧美亚洲日本| 国产精品视频一区二区三区不卡| 精品久久久久久亚洲综合网| 91精品国产免费| 欧美日韩性生活| 欧美性大战久久| 色综合色综合色综合| jlzzjlzz亚洲日本少妇| 国产精品资源在线| 久久成人免费网站| 久久精品国产久精国产| 天堂蜜桃91精品| 日韩综合在线视频| 午夜视频在线观看一区二区| 亚洲电影你懂得| 亚洲国产乱码最新视频| 亚洲国产视频一区| 一区二区日韩av| 夜夜精品视频一区二区| 一区二区三区中文字幕电影| 综合激情成人伊人| 亚洲视频你懂的| 自拍偷拍亚洲综合| √…a在线天堂一区| 欧美经典一区二区| 国产精品毛片a∨一区二区三区| 中文久久乱码一区二区| 亚洲国产精品成人综合| 国产视频一区二区在线| 久久精品人人爽人人爽| 国产欧美视频在线观看| 中文字幕不卡三区| 亚洲日本乱码在线观看| 一区二区高清在线| 婷婷国产在线综合| 日韩av一区二区三区| 另类欧美日韩国产在线| 国内精品国产成人国产三级粉色| 国产另类ts人妖一区二区| 丁香另类激情小说| 91在线观看美女| 91精品福利在线| 91精品国产一区二区三区蜜臀| 日韩一区二区三区免费看| 久久久久高清精品| 国产精品电影一区二区|