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

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

?? mainpeg.cpp

?? ldpc碼的peg構造
?? CPP
字號:
/************************************************************************/
/*                                                                      */
/*        Free software: Progressive edge-growth (PEG) algorithm        */
/*        Created by Xiaoyu Hu                                          */
/*                   Evangelos Eletheriou                               */
/*                   Dieter Arnold                                      */
/*        IBM Research, Zurich Research Lab., Switzerland               */
/*        Changed by XiaoYu Chongqing University                        */
/*                                                                      */
/*        The C++ sources files have been compiled using xlC compiler   */
/*        at IBM RS/6000 running AIX. For other compilers and platforms,*/
/*        minor changes might be needed.                                */
/*                                                                      */
/*        Bug reporting to: xhu@zurich.ibm.com                          */
/**********************************************************************/

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <iostream.h>
#include <iomanip.h>
#include <fstream.h>
#include <math.h>
#include "BigGirth.h"
#include "Random.h"
#include "CyclesOfGraph.h"

#define EPS  1e-6

int N=1008,M=504;

int main(int argc, char * argv[]){
  int i, j, m;
  
  int sglConcent=1;  // default to non-strictly concentrated parity-check distribution
  int targetGirth=100000; // default to greedy PEG version 
  //char codeName[100], degFileName[100];
  char codeName[100]="PEG2.dat ";
  char degFileName[100]="DenEvl_15.deg";
  int *degSeq, *deg;
  double *degFrac;
  BigGirth *bigGirth;
  CyclesOfGraph *cog;

  int numArgs=(argc-1)/2;
  if (argc<9) {
  USE:
    cout<<"*******************************************************************************************"<<endl;
    cout<<" Usage Reminder: MainPEG -numM M -numN N -codeName CodeName -degFileName DegFileName " <<endl;
    cout<<"         option:         -sglConcent SglConcent                                     " <<endl; 
    cout<<"                         sglConcent==0 ----- strictly concentrated parity-check      " <<endl;
    cout<<"                                       degree distribution (including regular graphs)" <<endl;
    cout<<"                         sglConcent==1 ----- Best-effort concentrated (DEFAULT)      " <<endl;
    cout<<"         option:         -tgtGirth TgtGirth                                          " <<endl; 
    cout<<"                  TgtGirth==4, 6 ...; if very large, then greedy PEG (DEFAULT)       " <<endl;
    cout<<"                  IF sglConcent==0, TgtGirth is recommended to be set relatively small" <<endl;
    cout<<"                                                                                       " <<endl;
    cout<<" Remarks: File CodeName stores the generated PEG Tanner graph. The first line contains"<<endl;
    cout<<"          the block length, N. The second line defines the number of parity-checks, M."<<endl;
    cout<<"          The third line defines the number of columns of the compressed parity-check "<<endl;
    cout<<"          matrix. The following M lines are then the compressed parity-check matrix.  "<<endl;
    cout<<"          Each of the M rows contains the indices (1 ... N) of 1's in the compressed  "<<endl;
    cout<<"          row of parity-check matrix. If not all column entries are used, the column  "<<endl;
    cout<<"          is filled up with 0's.                                                      "<<endl;
    cout<<"                                                                                      "<<endl;
    cout<<"          File DegFileName is the input file to specify the degree distribution (node "<<endl;
    cout<<"          perspective). The first line contains the number of various degrees. The second"<<endl;
    cout<<"          defines the row vector of degree sequence in the increasing order. The vector"<<endl;
    cout<<"          of fractions of the corresponding degree is defined in the last line.         "<<endl;
    cout<<"                                                                                       "<<endl;
    cout<<"          A log file called 'leftHandGirth.dat' will also be generated and stored in the"<<endl;
    cout<<"          current directory, which gives the girth of the left-hand subgraph of j, where"<<endl;
    cout<<"          1<=j<=N. The left-hand subgraph of j is defined as all the edges emanating from"<<endl;
    cout<<"          bit nodes {1 ... j} and their associated nodes.                                "<<endl; 
    cout<<"                                                                                         "<<endl;
    cout<<"          The last point is, when strictly concentrated parity-check degree distribution"<<endl;
    cout<<"          is invoked, i.e. sglConcent==0, the girth might be weaken to some extent as    "<<endl;
    cout<<"          compared to the generic PEG algorithm.                                         "<<endl;
    cout<<"**********************************************************************************************"<<endl;
    exit(-1);
  }else {
    for(i=0;i<numArgs;i++){
      if (strcmp(argv[2*i+1], "-numM")==0) {
	M=atoi(argv[2*i+2]);
      } else if(strcmp(argv[2*i+1], "-numN")==0) {
	N=atoi(argv[2*i+2]);
      } else if(strcmp(argv[2*i+1], "-codeName")==0) {
	strcpy(codeName, argv[2*i+2]); 
      } else if(strcmp(argv[2*i+1], "-degFileName")==0) {
	strcpy(degFileName, argv[2*i+2]); 
      } else if(strcmp(argv[2*i+1], "-sglConcent")==0) {
	sglConcent=atoi(argv[2*i+2]);
      } else if(strcmp(argv[2*i+1], "-tgtGirth")==0) {
	targetGirth=atoi(argv[2*i+2]);
      } else{
   // goto USE;
      }
    }
    if(M>N) {
      cout<<"Warning: M must be samller than N"<<endl;
      exit(-1);
    }
  }

  degSeq=new int[N];

  ifstream infn(degFileName);
  if (!infn) {cout << "\nCannot open file " << degFileName << endl; exit(-1); } 
  infn >>m;
  deg=new int[m];
  degFrac=new double[m];
  for(i=0;i<m;i++) infn>>deg[i];
  for(i=0;i<m;i++) infn>>degFrac[i];
  infn.close();  
  double dtmp=0.0;
  for(i=0;i<m;i++) dtmp+=degFrac[i];
  cout.setf(ios::fixed, ios::floatfield);
  if(fabs(dtmp-1.0)>EPS) 
  {
    cout.setf(ios::fixed, ios::floatfield);
    cout <<"\n Invalid degree distribution (node perspective): sum != 1.0 but "<<setprecision(10)<<dtmp<<endl; exit(-1); 
  } 
  for(i=1;i<m;i++) degFrac[i]+=degFrac[i-1];
  for(i=0;i<N;i++) 
  {
    dtmp=(double)i/N;
    for(j=m-1;j>=0;j--) 
	{
      if(dtmp>degFrac[j]) break;
    }
    if(dtmp<degFrac[0]) degSeq[i]=deg[0];
    else degSeq[i]=deg[j+1];
  }

  bigGirth=new BigGirth(M, N, degSeq, codeName, sglConcent, targetGirth);

  //(*bigGirth).writeToFile_Hcompressed();
  //(*bigGirth).writeToFile_Hmatrix()        //  different output format
  //(*bigGirth).writeToFile();               //  different output format: including generator matrix (compressed)
  
  //computing local girth distribution  
  /*if(N<10000) {
    cout<<" Now computing the local girth on the global Tanner graph setting. "<<endl;
    cout<<"     might take a bit long time. Please wait ...                   "<<endl;
    (*bigGirth).loadH();
    cog=new CyclesOfGraph(M, N, (*bigGirth).H);
    (*cog).getCyclesTable();
    (*cog).printCyclesTable();
    delete cog;
    cog=NULL;
  }*/

  delete [] degSeq;  degSeq=NULL;
  delete [] deg; deg=NULL;
  delete [] degFrac; degFrac=NULL;
  delete bigGirth;
}




?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品性做久久久久久| 不卡视频免费播放| 国产又黄又大久久| 美国三级日本三级久久99| 天天影视色香欲综合网老头| 一区二区三区四区在线播放| 亚洲日本电影在线| 亚洲欧美自拍偷拍色图| 亚洲国产精品v| 国产精品久久久久天堂| 国产精品嫩草影院av蜜臀| 国产免费观看久久| 亚洲欧美一区二区三区孕妇| 亚洲日本青草视频在线怡红院| 亚洲欧美福利一区二区| 亚洲精选免费视频| 一区二区三区成人| 亚洲国产精品久久久久婷婷884 | 欧美精品第1页| 91精品国产综合久久久蜜臀粉嫩 | 国产精品不卡一区二区三区| 亚洲欧美日韩一区二区三区在线观看| 亚洲男人电影天堂| 午夜激情综合网| 激情综合网av| 国产成人免费9x9x人网站视频| 成人精品高清在线| 在线观看视频一区二区欧美日韩| 欧美三级中文字| 日韩情涩欧美日韩视频| 国产日韩欧美在线一区| 国产精品国产三级国产普通话蜜臀| 亚洲欧美日本韩国| 免费观看一级特黄欧美大片| 国产乱一区二区| 色综合久久中文字幕| 欧美一区二区成人6969| 久久精品网站免费观看| 亚洲精品成a人| 九色综合狠狠综合久久| 99久久精品国产网站| 欧美一区二区三区性视频| 久久精品欧美日韩精品| 亚洲欧美激情插| 久久97超碰国产精品超碰| 99免费精品视频| 欧美一区二区三区视频免费| 久久九九全国免费| 亚洲综合久久久| 国产一区二区在线观看视频| 一本色道久久综合亚洲aⅴ蜜桃| 7777精品伊人久久久大香线蕉经典版下载| 亚洲精品一线二线三线无人区| 亚洲色图都市小说| 久久超级碰视频| 色综合欧美在线视频区| www久久精品| 亚洲国产一区在线观看| 国产成人自拍在线| 884aa四虎影成人精品一区| 国产精品久久久久久久蜜臀| 日韩精品亚洲专区| 91丨九色丨黑人外教| 欧美成人猛片aaaaaaa| 亚洲视频综合在线| 国模冰冰炮一区二区| 欧美亚洲一区二区在线观看| 国产亚洲一二三区| 人人超碰91尤物精品国产| 色悠久久久久综合欧美99| 久久网站最新地址| 日韩专区在线视频| 在线精品国精品国产尤物884a| 国产欧美精品一区二区色综合朱莉 | 国产精品嫩草99a| 蜜臀av一区二区在线观看| 欧美在线观看你懂的| 国产精品护士白丝一区av| 国产精品中文字幕日韩精品| 日韩免费观看2025年上映的电影 | 色综合色综合色综合色综合色综合| 久久亚区不卡日本| 日本v片在线高清不卡在线观看| 色欲综合视频天天天| 国产精品视频第一区| 久88久久88久久久| 日韩一区二区三区在线| 亚洲成人一区在线| 欧美影院一区二区三区| 亚洲黄色av一区| 91在线精品秘密一区二区| 国产精品女同互慰在线看| 粉嫩高潮美女一区二区三区| 久久久午夜精品理论片中文字幕| 精品在线免费视频| 日韩精品一区二区三区在线观看| 热久久免费视频| 91精品国产色综合久久久蜜香臀| 亚洲va欧美va人人爽午夜| 欧美色图在线观看| 亚洲香肠在线观看| 欧美老肥妇做.爰bbww| 亚洲成人资源网| 777亚洲妇女| 麻豆精品一区二区av白丝在线| 欧美裸体一区二区三区| 五月天丁香久久| 日韩一区二区三区电影| 久久精品国产亚洲高清剧情介绍| 日韩一区二区在线免费观看| 蜜臀av在线播放一区二区三区| 欧美一区二区三区在线视频| 麻豆免费看一区二区三区| 精品免费视频.| 国产毛片精品一区| 国产亚洲精品aa午夜观看| 国产成人av电影免费在线观看| 亚洲国产高清在线观看视频| 不卡影院免费观看| 亚洲另类一区二区| 欧美影院一区二区三区| 日本视频免费一区| 久久综合九色综合欧美就去吻 | 久久久久久久电影| 不卡的av网站| 一二三区精品视频| 欧美一区在线视频| 激情六月婷婷久久| 国产网红主播福利一区二区| 91在线观看一区二区| 一区二区日韩av| 91精品黄色片免费大全| 国产在线一区二区| 国产精品欧美久久久久一区二区| 一本色道久久综合亚洲aⅴ蜜桃 | 日韩成人伦理电影在线观看| 日韩精品一区二区三区视频| 国产成人在线观看| 亚洲欧美一区二区不卡| 欧美电影在哪看比较好| 国产精品一级黄| 一区二区三区不卡视频在线观看| 91精品国产入口| 高清在线观看日韩| 亚洲国产一区二区三区| 精品国产自在久精品国产| 成人h动漫精品一区二区| 日日摸夜夜添夜夜添国产精品 | 日韩av在线免费观看不卡| 久久久久久日产精品| 99精品视频一区| 美女网站色91| 亚洲品质自拍视频| 欧美精品一区二| 欧美性大战久久久| 国产麻豆精品95视频| 亚洲综合激情另类小说区| 久久综合九色综合欧美就去吻| 在线亚洲人成电影网站色www| 麻豆成人免费电影| 亚洲黄色免费电影| 久久久久久久久久久久电影| 欧美中文字幕一区| 夫妻av一区二区| 视频一区在线播放| 亚洲女同ⅹxx女同tv| 精品国产一区二区三区av性色 | 欧美不卡在线视频| 色哟哟一区二区三区| 国产美女视频一区| 日本三级亚洲精品| 有码一区二区三区| 亚洲国产成人一区二区三区| 日韩欧美国产麻豆| 欧美日韩一区在线| av电影在线观看一区| 国产一区二区三区精品视频| 一级精品视频在线观看宜春院 | 亚洲成人动漫精品| 自拍偷拍欧美激情| 国产性色一区二区| 日韩欧美123| 欧美色视频一区| 91免费版在线| 国产91精品精华液一区二区三区| 免费高清在线一区| 日韩精品成人一区二区在线| 一区二区在线观看免费视频播放| 国产欧美中文在线| 亚洲精品一区二区三区福利| 91麻豆精品国产自产在线| 在线观看91精品国产入口| 99久久精品免费精品国产| 国产91丝袜在线观看| 国产在线精品免费| 美国三级日本三级久久99| 日韩专区在线视频| 水野朝阳av一区二区三区| 亚洲成人av电影在线| 亚洲一二三区不卡|