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

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

?? biggirth.c

?? PROGRASSIVE EDGE GROWTH 累加邊增加LDPC算法
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
#include <stdio.h>#include <stdlib.h>#include <iostream.h>#include <fstream.h>#include "BigGirth.h"#include "Random.h"NodesInGraph::NodesInGraph(void) {;}void NodesInGraph::setNumOfConnectionSymbolBit(int deg) {  if(deg<=0) {cout<<"Wrong NodesInGraph::setNumOfConnectionSymbolBit()"<<endl;exit(-1);}  numOfConnectionSymbolBit=deg;  connectionSymbolBit=new int[deg];}void NodesInGraph::initConnectionParityBit(void) {  maxDegParity=10000;  numOfConnectionParityBit=0;  connectionParityBit=new int[1];//dummy memory, actually not used}void NodesInGraph::initConnectionParityBit(int deg) {  maxDegParity=deg;  numOfConnectionParityBit=0;  connectionParityBit=new int[1];//dummy memory, actually not used}NodesInGraph::~NodesInGraph(void) {  if(connectionParityBit!=NULL)    delete [] connectionParityBit;  if(connectionSymbolBit!=NULL)    delete [] connectionSymbolBit;}BigGirth::BigGirth(void) {;}BigGirth::BigGirth(int M, int N, int *symbolDegSequence, char *filename, int sglConcent, int tgtGirth){  int i, j, k, m, index, localDepth=100;  int *mid;  EXPAND_DEPTH=(tgtGirth-4)/2;   if(EXPAND_DEPTH<0) EXPAND_DEPTH=0;  //      corresponds to depth l in the PEG paper;    //      the target girth = 2*EXPAND_DEPTH+4  //      if set large, then GREEDY algorithm  myrandom=new Random();  //(12345678l, 987654321lu);  (*this).M=M;  (*this).N=N;  (*this).filename=filename;  mid=new int[M];  localGirth=new int[N];  nodesInGraph=new NodesInGraph [N];  for(i=0;i<N;i++)    nodesInGraph[i].setNumOfConnectionSymbolBit(symbolDegSequence[i]);  j=0;  for(k=0;k<N;k++) j+=symbolDegSequence[k];  k=j/M;  for(i=0;i<M;i++) mid[i]=k;  for(i=0;i<j-k*M;i++) mid[i]++;  k=0; for(i=0;i<M;i++) k+=mid[i];  if(k!=j) {cout<<"Wrong in computing maxDegParity!"<<endl;exit(-1);}  for(i=0;i<M;i++) {    if(sglConcent==0) nodesInGraph[i].initConnectionParityBit(mid[i]);    else  nodesInGraph[i].initConnectionParityBit();   }         for(k=0;k<N;k++){    m=1000000;index=-1;    for(i=0;i<M;i++){      if(nodesInGraph[i].numOfConnectionParityBit<m && nodesInGraph[i].numOfConnectionParityBit<nodesInGraph[i].maxDegParity) {	m=nodesInGraph[i].numOfConnectionParityBit;	index=i;      }    }    nodesInGraph[k].connectionSymbolBit[0]=index;//least connections of parity bit    int iter=0;   ITER:    localGirth[k]=100;    for(m=1;m<nodesInGraph[k].numOfConnectionSymbolBit;m++){      nodesInGraph[k].connectionSymbolBit[m]=selectParityConnect(k, m, localDepth);      localGirth[k]=(localGirth[k]>localDepth)?localDepth:localGirth[k];            if(k>0 && localGirth[k]<localGirth[k-1] && iter<20) {iter++; goto ITER;}      if(localGirth[k]==0 && iter<30) {iter++; goto ITER;}    }    //if((k+1)%100==0) {      cout<<"k="<<k<<"  ";      for(m=0;m<nodesInGraph[k].numOfConnectionSymbolBit;m++)	cout<<nodesInGraph[k].connectionSymbolBit[m]<<" ";      cout<<"LocalGirth="<<2*localGirth[k]+4;      cout<<endl;      //}    updateConnection(k);  }  cout<<"Showing the row weight distribution..."<<endl;  for(i=0;i<M;i++)    cout<<nodesInGraph[i].numOfConnectionParityBit<<" ";  cout<<endl;  delete [] mid;  ofstream cycleFile;  cycleFile.open("leftHandGirth.log", ios::out);  localDepth=100;  for(k=0;k<N;k++) {    if(localGirth[k]<localDepth) localDepth=localGirth[k];    if(localDepth==100) cycleFile<<"inf ";    else cycleFile<<2*localDepth+4<<" ";  }  cycleFile<<endl;  cycleFile.close();  cout<<"*************************************************************"<<endl;  cout<<"       The global girth of the PEG Tanner graph :="<< 2*localDepth+4<<endl;  cout<<"*************************************************************"<<endl;  loadH();}BigGirth::~BigGirth(void) {  if(H!=NULL) {    for(int i=0;i<M;i++)      delete [] H[i];    delete [] H;    H=NULL;  }    delete [] localGirth;  delete [] nodesInGraph;  nodesInGraph=NULL;  delete myrandom;}int BigGirth::selectParityConnect(int kthSymbol, int mthConnection, int & cycle) {  int i, j, k, index, mincycles, numCur, numNext, cpNumCur;  int *tmp, *med;  int *current;//take note of the covering parity bits  mincycles=0;  tmp=new int[M]; med=new int[M];  numCur=mthConnection;  current=new int[mthConnection];  for(i=0;i<mthConnection;i++) current[i]=nodesInGraph[kthSymbol].connectionSymbolBit[i];LOOP:  mincycles++;  for(i=0;i<M;i++) tmp[i]=0;  //maintain   for(i=0;i<mthConnection;i++) tmp[nodesInGraph[kthSymbol].connectionSymbolBit[i]]=1;  for(i=0;i<numCur;i++){    for(j=0;j<nodesInGraph[current[i]].numOfConnectionParityBit;j++){      for(k=0;k<nodesInGraph[nodesInGraph[current[i]].connectionParityBit[j]].numOfConnectionSymbolBit;k++){        tmp[nodesInGraph[nodesInGraph[current[i]].connectionParityBit[j]].connectionSymbolBit[k]]=1;      }    }  }  index=0; cpNumCur=0;  for(i=0;i<M;i++) {    if(tmp[i]==1) cpNumCur++;    if(tmp[i]==1 || nodesInGraph[i].numOfConnectionParityBit>=nodesInGraph[i].maxDegParity)       index++;     }  if(cpNumCur==numCur) {//can not expand any more    //additional handlement to select one having least connections    j=10000000; //dummy number    for(i=0;i<M;i++){      if(tmp[i]==0 && nodesInGraph[i].numOfConnectionParityBit<j && nodesInGraph[i].numOfConnectionParityBit<nodesInGraph[i].maxDegParity)	j=nodesInGraph[i].numOfConnectionParityBit;    }    for(i=0;i<M;i++){      if(tmp[i]==0){	if(nodesInGraph[i].numOfConnectionParityBit!=j || nodesInGraph[i].numOfConnectionParityBit>=nodesInGraph[i].maxDegParity){	  tmp[i]=1;	}      }    }    index=0;    for(i=0;i<M;i++) if(tmp[i]==1) index++;    //----------------------------------------------------------------    j=(*myrandom).uniform(0, M-index)+1; //randomly selected    index=0;    for(i=0;i<M;i++){      if(tmp[i]==0) index++;      if(index==j) break;    }    delete [] tmp; tmp=NULL;    delete [] current; current=NULL;    return(i);  }  else if(index==M || mincycles>EXPAND_DEPTH){//covering all parity nodes or meet the upper bound on cycles        cycle=mincycles-1;    for(i=0;i<M;i++) tmp[i]=0;    for(i=0;i<numCur;i++) tmp[current[i]]=1;    index=0;    for(i=0;i<M;i++) if(tmp[i]==1) index++;    if(index!=numCur) {cout<<"Error in the case of (index==M)"<<endl;exit(-1);}    //additional handlement to select one having least connections    j=10000000;     for(i=0;i<M;i++){      if(tmp[i]==0 && nodesInGraph[i].numOfConnectionParityBit<j && nodesInGraph[i].numOfConnectionParityBit<nodesInGraph[i].maxDegParity)	j=nodesInGraph[i].numOfConnectionParityBit;    }    for(i=0;i<M;i++){      if(tmp[i]==0){	if(nodesInGraph[i].numOfConnectionParityBit!=j || nodesInGraph[i].numOfConnectionParityBit>=nodesInGraph[i].maxDegParity){	  tmp[i]=1;	}      }    }          index=0;    for(i=0;i<M;i++) if(tmp[i]==1) index++;       j=(*myrandom).uniform(0, M-index)+1;    index=0;    for(i=0;i<M;i++){      if(tmp[i]==0) index++;      if(index==j) break;    }    delete [] tmp; tmp=NULL;    delete [] current; current=NULL;    return(i);  }  else if(cpNumCur>numCur && index!=M){    delete [] current;    current=NULL;    numCur=cpNumCur;    current=new int[numCur];    index=0;    for(i=0;i<M;i++) {      if(tmp[i]==1) {current[index]=i; index++;}    }    goto LOOP;  }  else {    cout<<"Should not come to this point..."<<endl;    cout<<"Error in BigGirth::selectParityConnect()"<<endl;    return(-1);  }}void BigGirth::updateConnection(int kthSymbol){  int i, j, m;  int *tmp;  for(i=0;i<nodesInGraph[kthSymbol].numOfConnectionSymbolBit;i++){    m=nodesInGraph[kthSymbol].connectionSymbolBit[i];//m [0, M) parity node    tmp=new int[nodesInGraph[m].numOfConnectionParityBit+1];    for(j=0;j<nodesInGraph[m].numOfConnectionParityBit;j++)      tmp[j]=nodesInGraph[m].connectionParityBit[j];    tmp[nodesInGraph[m].numOfConnectionParityBit]=kthSymbol;    delete [] nodesInGraph[m].connectionParityBit;    nodesInGraph[m].connectionParityBit=NULL;    nodesInGraph[m].numOfConnectionParityBit++; //increase by 1    nodesInGraph[m].connectionParityBit=new int[nodesInGraph[m].numOfConnectionParityBit];    for(j=0;j<nodesInGraph[m].numOfConnectionParityBit;j++)      nodesInGraph[m].connectionParityBit[j]=tmp[j];    delete [] tmp;    tmp=NULL;  }}void BigGirth::loadH(void){  int i, j;  if(H==NULL) {    H=new int*[M];    for(i=0;i<M;i++) H[i]=new int[N];  }

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美精品一级二级三级| 亚洲三级在线看| 欧美一卡二卡三卡四卡| 在线不卡一区二区| 91精品国产入口| 欧美一区二区三区人| 日韩欧美一二三| 精品处破学生在线二十三| 欧美精品一区二区三区在线| 精品国产免费久久| 久久久久久麻豆| 国产精品国产a级| 亚洲乱码中文字幕| 亚洲影视在线播放| 日本特黄久久久高潮| 美女视频黄频大全不卡视频在线播放| 亚洲大片免费看| 免费观看日韩电影| 国产精品99久久久| 不卡一区二区在线| 91久久线看在观草草青青| 欧美日韩免费视频| 日韩欧美高清一区| 国产人成一区二区三区影院| 国产精品成人免费在线| 亚洲一区二区三区在线看| 天天色天天操综合| 国产一区二区三区免费看| 懂色av中文字幕一区二区三区| 91香蕉视频污| 欧美高清hd18日本| 久久婷婷国产综合精品青草| 国产精品久久久久久亚洲伦| 亚洲国产美女搞黄色| 另类小说一区二区三区| youjizz国产精品| 欧美视频第二页| 久久伊人中文字幕| 一区二区三区中文在线观看| 日本欧美大码aⅴ在线播放| 国产成人av电影免费在线观看| 色综合久久综合| 欧美成人video| 中文字幕亚洲视频| 奇米精品一区二区三区四区| 成人国产精品免费观看动漫| 在线成人av影院| 国产精品久久久久国产精品日日| 一区二区三区美女| 国产美女主播视频一区| 欧美影片第一页| 国产亚洲精品资源在线26u| 亚洲午夜免费福利视频| 国产黄色成人av| 欧美日韩国产首页在线观看| 亚洲国产岛国毛片在线| 日本最新不卡在线| jlzzjlzz亚洲日本少妇| 日韩网站在线看片你懂的| 国产精品国产三级国产aⅴ原创| 欧美96一区二区免费视频| 成人网在线播放| 欧美成人三级在线| 亚洲一区二区黄色| 夫妻av一区二区| 日韩欧美在线影院| 亚洲一区二区偷拍精品| 成人免费黄色大片| 精品黑人一区二区三区久久 | 亚洲欧洲制服丝袜| 精品一区二区三区的国产在线播放 | 国产一区免费电影| 欧美精品1区2区3区| 亚洲精品美国一| 高清不卡一二三区| 久久久久久久网| 热久久免费视频| 欧美精品久久久久久久多人混战| 综合激情网...| 成人黄色777网| 国产喷白浆一区二区三区| 日本成人在线网站| 欧美日韩在线播放| 亚洲自拍另类综合| 一本大道久久精品懂色aⅴ| 国产精品免费人成网站| 国产精品资源站在线| 26uuu另类欧美| 日本va欧美va欧美va精品| 欧美人体做爰大胆视频| 亚洲国产美国国产综合一区二区| 色天天综合色天天久久| 亚洲视频一二三| 91浏览器打开| 亚洲日本在线天堂| 91香蕉视频mp4| 亚洲人精品午夜| 91香蕉视频污在线| 亚洲男人天堂一区| 91免费在线播放| 亚洲免费观看高清| 色拍拍在线精品视频8848| 亚洲你懂的在线视频| 色欧美片视频在线观看| 亚洲精品国产无天堂网2021| 在线免费亚洲电影| 亚洲一区二区在线免费看| 欧美日韩国产在线播放网站| 午夜精品影院在线观看| 欧美一级久久久| 久久精品国产第一区二区三区 | 亚洲超碰精品一区二区| 欧美精品久久久久久久多人混战 | 欧美精品一级二级三级| 日韩电影在线观看网站| 欧美成人三级在线| 国产精品77777| 1区2区3区欧美| 欧美在线|欧美| 日韩精品五月天| 精品免费日韩av| 国产福利一区二区三区视频在线| 欧美国产在线观看| 色婷婷av一区二区三区软件| 午夜精品视频一区| 欧美v国产在线一区二区三区| 国产一区不卡视频| 国产精品久久毛片| 欧美日韩你懂得| 精品一区二区久久| 国产精品成人免费在线| 欧美日韩精品欧美日韩精品一综合| 偷窥国产亚洲免费视频| 亚洲精品在线免费观看视频| 丁香网亚洲国际| 亚洲成人激情社区| 欧美精品一区二区蜜臀亚洲| 成人免费高清在线| 亚洲成av人片一区二区三区| 精品国产一区二区三区av性色| 成人国产精品免费网站| 性做久久久久久| 久久久国产一区二区三区四区小说 | 精品一二线国产| 日韩毛片视频在线看| 777久久久精品| 成人小视频免费在线观看| 亚洲成人av中文| 精品国产百合女同互慰| 97国产精品videossex| 蜜桃精品视频在线| 亚洲精品视频在线观看网站| 精品蜜桃在线看| 欧美在线999| 成人久久视频在线观看| 五月综合激情日本mⅴ| 国产精品成人免费精品自在线观看 | 久久免费午夜影院| 精品视频资源站| 国产91精品一区二区麻豆网站| 午夜免费欧美电影| 国产精品久久久久9999吃药| 日韩欧美国产系列| 欧美性大战久久久| 高清不卡在线观看av| 麻豆成人在线观看| 亚洲电影一区二区| 国产精品麻豆视频| 久久久久久久久久久久久女国产乱| 欧美亚洲一区三区| 99精品国产91久久久久久 | 日本久久一区二区三区| 免费成人在线网站| 亚洲国产精品久久人人爱| 欧美日韩一区中文字幕| 国产成人精品免费网站| 久久爱www久久做| 亚洲精品欧美专区| 久久久综合激的五月天| 国产精品一区二区久久精品爱涩| 日韩一区精品字幕| 亚洲精品久久久久久国产精华液| 精品久久久久久最新网址| 欧美理论在线播放| 91浏览器打开| 国产成人免费av在线| 爽好久久久欧美精品| 亚洲一区二区三区三| 中文字幕亚洲一区二区va在线| 精品久久久久久无| 日韩精品中文字幕在线不卡尤物| 色综合久久综合中文综合网| 国产成人日日夜夜| 日本aⅴ亚洲精品中文乱码| 一区二区三区四区蜜桃| 亚洲国产精品激情在线观看| 欧美tickling网站挠脚心| 欧美不卡视频一区| 色综合天天综合狠狠| 成人综合婷婷国产精品久久蜜臀|