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

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

?? mainpeg.c

?? PROGRASSIVE EDGE GROWTH 累加邊增加LDPC算法
?? C
字號:
/************************************************************************//*                                                                      *//*        Free software: Progressive edge-growth (PEG) algorithm        *//*        Created by Xiaoyu Hu                                          *//*                   Evangelos Eletheriou                               *//*                   Dieter Arnold                                      *//*        IBM Research, Zurich Research Lab., Switzerland               *//*                                                                      *//*        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-6int main(int argc, char * argv[]){  int i, j, m, N, 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];  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精品久久只有精品| 欧美日韩高清一区| 亚洲mv在线观看| 国产精品三级av| 欧美一区二区三区电影| 成人黄色av网站在线| 麻豆精品精品国产自在97香蕉| 中文字幕一区二区在线播放| 欧美一区二区私人影院日本| 一本到一区二区三区| 国产99久久久精品| 麻豆精品新av中文字幕| 亚洲国产三级在线| 国产精品福利电影一区二区三区四区| 欧美大胆人体bbbb| 欧美日本在线看| 欧美性生活久久| 91影院在线观看| 成人免费av资源| 国产99久久久精品| 另类成人小视频在线| 日韩黄色小视频| 亚洲国产精品久久久久秋霞影院 | 精品国产乱码久久| 欧美特级限制片免费在线观看| 成人开心网精品视频| 精品一区二区三区在线观看 | 91麻豆精品国产91久久久| 色婷婷综合久久久久中文 | 亚洲国产精品久久一线不卡| 亚洲人成伊人成综合网小说| 日本一区二区三区久久久久久久久不| 日韩视频一区在线观看| 91精品国产乱码| 欧美欧美午夜aⅴ在线观看| 欧美三级日韩三级国产三级| 色老头久久综合| 欧美主播一区二区三区| 91香蕉视频mp4| 91麻豆精品视频| 色婷婷精品久久二区二区蜜臀av| 91免费看`日韩一区二区| 99久久婷婷国产综合精品| 成人av免费在线观看| 99精品欧美一区二区三区小说| 9久草视频在线视频精品| av成人老司机| 在线亚洲免费视频| 欧美日韩一区高清| 91超碰这里只有精品国产| 4438x成人网最大色成网站| 欧美一区在线视频| 精品人伦一区二区色婷婷| 久久久亚洲精品石原莉奈| 国产精品美女久久久久aⅴ| 国产精品电影一区二区三区| 亚洲黄色免费电影| 首页亚洲欧美制服丝腿| 麻豆精品视频在线观看视频| 国产精品一级在线| 91影院在线观看| 91麻豆精品国产91久久久更新时间| 欧美大片免费久久精品三p| 国产欧美日本一区视频| 一区二区三区资源| 另类中文字幕网| 成人av电影在线| 4438x成人网最大色成网站| 久久综合丝袜日本网| 亚洲视频在线一区观看| 天天色天天操综合| 国产精品一色哟哟哟| 99在线热播精品免费| 欧美日韩另类一区| 国产欧美日韩视频一区二区 | 亚洲aⅴ怡春院| 久久99国内精品| 99久久婷婷国产综合精品 | 久久久久久久性| 亚洲精品中文在线| 九色|91porny| 欧美性大战久久久久久久蜜臀| 日韩欧美高清在线| 日韩一区在线播放| 蜜臀av在线播放一区二区三区| 99久久精品久久久久久清纯| 91精品国产综合久久福利软件 | www.日韩精品| 91麻豆精品国产91久久久资源速度 | 欧美不卡在线视频| 亚洲柠檬福利资源导航| 国内欧美视频一区二区| 欧美性猛片aaaaaaa做受| 国产欧美日韩综合| 日韩av一区二| 色婷婷国产精品综合在线观看| 精品久久久久av影院| 亚洲小说欧美激情另类| 成人高清在线视频| 欧美xxxx在线观看| 亚洲一区二区精品视频| 国产a久久麻豆| 精品国内二区三区| 天天av天天翘天天综合网| 成人国产精品免费观看| 精品久久久久一区二区国产| 亚洲福利视频导航| 色综合天天综合色综合av | 亚洲 欧美综合在线网络| www.日本不卡| 久久欧美一区二区| 精品一二三四区| 欧美一级专区免费大片| 亚洲一二三四在线| 91色综合久久久久婷婷| 中文字幕av资源一区| 国产精品影音先锋| 精品国产第一区二区三区观看体验| 性感美女久久精品| 欧美体内she精高潮| 亚洲视频你懂的| www.欧美亚洲| 中文字幕高清不卡| 成人午夜电影久久影院| 久久这里只有精品6| 精品一区二区在线播放| 日韩写真欧美这视频| 人人精品人人爱| 91精品国产综合久久久蜜臀粉嫩 | 欧美日韩一区二区三区四区| 一区二区三区四区亚洲| 91理论电影在线观看| 亚洲婷婷综合色高清在线| 99久久精品国产一区二区三区 | 日韩电影在线一区二区| 91精品国产综合久久小美女| 日精品一区二区| 欧美一区二视频| 老色鬼精品视频在线观看播放| 精品剧情v国产在线观看在线| 国内不卡的二区三区中文字幕| 欧美成人aa大片| 国产一区二区三区| 欧美极品xxx| 99久久精品一区| 亚洲最大的成人av| 欧美日本国产视频| 蜜桃精品在线观看| 久久久久久久综合日本| 波多野结衣一区二区三区| 亚洲精品中文在线影院| 欧美日韩精品欧美日韩精品| 日本不卡一区二区| 精品国产第一区二区三区观看体验| 国产一区二区免费在线| 亚洲欧美在线另类| 欧美日韩视频在线观看一区二区三区 | 欧美日精品一区视频| 美腿丝袜亚洲色图| 国产精品无码永久免费888| 91网址在线看| 日韩 欧美一区二区三区| 2019国产精品| 在线视频你懂得一区| 青青草97国产精品免费观看| 国产亚洲成年网址在线观看| 91蝌蚪porny九色| 香蕉影视欧美成人| 国产三级精品三级在线专区| 色久优优欧美色久优优| 六月婷婷色综合| 亚洲图片激情小说| 日韩免费看的电影| 不卡电影一区二区三区| 日韩黄色免费电影| 中文字幕 久热精品 视频在线| 在线观看欧美黄色| 国产在线精品国自产拍免费| 亚洲精选在线视频| 久久久久青草大香线综合精品| 色悠悠久久综合| 国产又粗又猛又爽又黄91精品| 一区二区三区丝袜| 久久久久久影视| 欧美视频一区在线观看| 粉嫩在线一区二区三区视频| 亚洲国产aⅴ成人精品无吗| 国产欧美日韩另类视频免费观看| 欧美日韩亚洲综合一区| 国产v综合v亚洲欧| 美脚の诱脚舐め脚责91| 亚洲日本中文字幕区| 精品国产青草久久久久福利| 日本电影亚洲天堂一区| 粉嫩av一区二区三区粉嫩| 日韩福利视频网| 亚洲制服丝袜av| 国产精品久久久久久亚洲毛片 | 日韩视频在线永久播放| 欧美这里有精品|