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

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

?? mod2dense.c

?? ldpc的11個程序 encode decode extract make-gen make-ldpc make-pchk print-gen print-pchk rand-src transm
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* MOD2DENSE.C - Procedures for handling dense mod2 matrices. *//* Copyright (c) 1996, 2000, 2001 by Radford M. Neal  * * Permission is granted for anyone to copy, use, or modify this program  * for purposes of research or education, provided this copyright notice  * is retained, and note is made of any changes that have been made.  * * This program is distributed without any warranty, express or implied. * As this program was written for research purposes only, it has not been * tested to the degree that would be advisable in any important application. * All use of this program is entirely at the user's own risk. *//* NOTE:  See mod2dense.html for documentation on these procedures. */#include <stdlib.h>#include <stdio.h>#include <math.h>#include "alloc.h"#include "intio.h"#include "mod2dense.h"/* ALLOCATE SPACE FOR A DENSE MOD2 MATRIX. */mod2dense *mod2dense_allocate ( int n_rows, 		/* Number of rows in matrix */  int n_cols		/* Number of columns in matrix */){  mod2dense *m;  int j;  if (n_rows<=0 || n_cols<=0)  { fprintf(stderr,"mod2dense_allocate: Invalid number of rows or columns\n");    exit(1);  }  m = chk_alloc (1, sizeof *m);  m->n_rows = n_rows;  m->n_cols = n_cols;  m->n_words = (n_rows+mod2_wordsize-1) >> mod2_wordsize_shift;  m->col = chk_alloc (m->n_cols, sizeof *m->col);  m->bits = chk_alloc(m->n_words*m->n_cols, sizeof *m->bits);  for (j = 0; j<m->n_cols; j++)  { m->col[j] = m->bits + j*m->n_words;  }  return m;}/* FREE SPACE OCCUPIED BY A DENSE MOD2 MATRIX. */void mod2dense_free( mod2dense *m		/* Matrix to free */){ free(m->bits);  free(m->col);  free(m);}/* CLEAR A DENSE MOD2 MATRIX. */void mod2dense_clear( mod2dense *r){  int k, j;  for (j = 0; j<mod2dense_cols(r); j++)  { for (k = 0; k<r->n_words; k++)    { r->col[j][k] = 0;    }  }}/* COPY A DENSE MOD2 MATRIX. */void mod2dense_copy( mod2dense *m,		/* Matrix to copy */  mod2dense *r		/* Place to store copy of matrix */){   int k, j;  if (mod2dense_rows(m)>mod2dense_rows(r)    || mod2dense_cols(m)>mod2dense_cols(r))  { fprintf(stderr,"mod2dense_copy: Destination matrix is too small\n");    exit(1);  }  for (j = 0; j<mod2dense_cols(m); j++)  { for (k = 0; k<m->n_words; k++)    { r->col[j][k] = m->col[j][k];    }    for ( ; k<r->n_words; k++)    { r->col[j][k] = 0;    }  }  for ( ; j<mod2dense_cols(r); j++)  { for (k = 0; k<r->n_words; k++)    { r->col[j][k] = 0;    }  }}/* COPY ROWS OF A DENSE MOD2 MATRIX. */void mod2dense_copyrows( mod2dense *m,		/* Matrix to copy */  mod2dense *r,		/* Place to store copy of matrix */  int *rows		/* Indexes of rows to copy, from 0 */){   int i, j;  if (mod2dense_cols(m)>mod2dense_cols(r))  { fprintf(stderr,      "mod2dense_copyrows: Destination matrix has fewer columns than source\n");    exit(1);  }  mod2dense_clear(r);  for (i = 0; i<mod2dense_rows(r); i++)  { if (rows[i]<0 || rows[i]>=mod2dense_rows(m))    { fprintf(stderr,"mod2dense_copyrows: Row index out of range\n");      exit(1);    }    for (j = 0; j<mod2dense_cols(m); j++)    { mod2dense_set(r,i,j,mod2dense_get(m,rows[i],j));    }  }}/* COPY COLUMNS OF A DENSE MOD2 MATRIX. */void mod2dense_copycols( mod2dense *m,		/* Matrix to copy */  mod2dense *r,		/* Place to store copy of matrix */  int *cols		/* Indexes of columns to copy, from 0 */){   int k, j;  if (mod2dense_rows(m)>mod2dense_rows(r))  { fprintf(stderr,      "mod2dense_copycols: Destination matrix has fewer rows than source\n");    exit(1);  }  for (j = 0; j<mod2dense_cols(r); j++)  { if (cols[j]<0 || cols[j]>=mod2dense_cols(m))    { fprintf(stderr,"mod2dense_copycols: Column index out of range\n");      exit(1);    }    for (k = 0; k<m->n_words; k++)    { r->col[j][k] = m->col[cols[j]][k];    }    for ( ; k<r->n_words; k++)    { r->col[j][k] = 0;    }  }}/* PRINT A DENSE MOD2 MATRIX IN HUMAN-READABLE FORM. */void mod2dense_print     ( FILE *f,  mod2dense *m){   int i, j;  for (i = 0; i<mod2dense_rows(m); i++)  { for (j = 0; j<mod2dense_cols(m); j++)    { fprintf(f," %d",mod2dense_get(m,i,j));    }    fprintf(f,"\n");  }}/* WRITE A DENSE MOD2 MATRIX TO A FILE IN MACHINE-READABLE FORM.   Data is written using intio_write, so that it will be readable on a machine   with a different byte-ordering.  At present, this assumes that the words    used to pack bits into are no longer than 32 bits. */int mod2dense_write     ( FILE *f,   mod2dense *m){   int j, k;  intio_write(f,m->n_rows);  if (ferror(f)) return 0;  intio_write(f,m->n_cols);  if (ferror(f)) return 0;  for (j = 0; j<mod2dense_cols(m); j++)  {    for (k = 0; k<m->n_words; k++)    { intio_write(f,m->col[j][k]);      if (ferror(f)) return 0;    }  }  return 1;}/* READ A DENSE MOD2 MATRIX STORED IN MACHINE-READABLE FORM FROM A FILE. */mod2dense *mod2dense_read  ( FILE *f){   int n_rows, n_cols;  mod2dense *m;  int j, k;    n_rows = intio_read(f);  if (feof(f) || ferror(f) || n_rows<=0) return 0;  n_cols = intio_read(f);  if (feof(f) || ferror(f) || n_cols<=0) return 0;  m = mod2dense_allocate(n_rows,n_cols);  for (j = 0; j<mod2dense_cols(m); j++)  {    for (k = 0; k<m->n_words; k++)    { m->col[j][k] = intio_read(f);      if (feof(f) || ferror(f))       { mod2dense_free(m);        return 0;      }    }  }  return m;}/* GET AN ELEMENT FROM A DENSE MOD2 MATRIX. */int mod2dense_get  ( mod2dense *m, 	/* Matrix to get element from */  int row,		/* Row of element (starting with zero) */  int col		/* Column of element (starting with zero) */){  if (row<0 || row>=mod2dense_rows(m) || col<0 || col>=mod2dense_cols(m))  { fprintf(stderr,"mod2dense_get: row or column index out of bounds\n");    exit(1);  }  return mod2_getbit (m->col[col][row>>mod2_wordsize_shift],                       row&mod2_wordsize_mask);}/* SET AN ELEMENT IN A DENSE MOD2 MATRIX. */void mod2dense_set ( mod2dense *m, 	/* Matrix to modify element of */  int row,		/* Row of element (starting with zero) */  int col,		/* Column of element (starting with zero) */  int value		/* New value of element (0 or 1) */){   mod2word *w;  if (row<0 || row>=mod2dense_rows(m) || col<0 || col>=mod2dense_cols(m))  { fprintf(stderr,"mod2dense_set: row or column index out of bounds\n");    exit(1);  }  w = &m->col[col][row>>mod2_wordsize_shift];  *w = value ? mod2_setbit1(*w,row&mod2_wordsize_mask)              : mod2_setbit0(*w,row&mod2_wordsize_mask);}/* FLIP AN ELEMENT OF A DENSE MOD2 MATRIX. */int mod2dense_flip  ( mod2dense *m, 	/* Matrix to flip element in */  int row,		/* Row of element (starting with zero) */  int col		/* Column of element (starting with zero) */){  mod2word *w;  int b;  if (row<0 || row>=mod2dense_rows(m) || col<0 || col>=mod2dense_cols(m))  { fprintf(stderr,"mod2dense_flip: row or column index out of bounds\n");    exit(1);  }  b = 1 ^ mod2_getbit (m->col[col][row>>mod2_wordsize_shift],                        row&mod2_wordsize_mask);  w = &m->col[col][row>>mod2_wordsize_shift];  *w = b ? mod2_setbit1(*w,row&mod2_wordsize_mask)          : mod2_setbit0(*w,row&mod2_wordsize_mask);  return b;}/* COMPUTE THE TRANSPOSE OF A DENSE MOD2 MATRIX. */void mod2dense_transpose( mod2dense *m,		/* Matrix to compute transpose of (left unchanged) */  mod2dense *r		/* Result of transpose operation */){  mod2word w, v, *p;  int k1, j1, i2, j2;  if (mod2dense_rows(m)!=mod2dense_cols(r)    || mod2dense_cols(m)!=mod2dense_rows(r))  { fprintf(stderr,     "mod2dense_transpose: Matrices have incompatible dimensions\n");    exit(1);  }  if (r==m)  { fprintf(stderr,      "mod2dense_transpose: Result matrix is the same as the operand\n");    exit(1);  }  mod2dense_clear(r);  for (j1 = 0; j1<mod2dense_cols(m); j1++)  {     i2 = j1 >> mod2_wordsize_shift;    v = 1 << (j1 & mod2_wordsize_mask);    p = m->col[j1];    k1 = 0;    for (j2 = 0; j2<mod2dense_cols(r); j2++)    { if (k1==0)      { w = *p++;        k1 = mod2_wordsize;      }      if (w&1)      { r->col[j2][i2] |= v;      }      w >>= 1;           k1 -= 1;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
7777精品伊人久久久大香线蕉超级流畅| 欧美成人精品3d动漫h| 欧洲精品中文字幕| 精品国产免费久久| 一区二区三国产精华液| 国产一区二区在线电影| 欧美视频在线一区| 中文字幕在线观看不卡视频| 麻豆成人91精品二区三区| 91免费观看视频在线| 26uuuu精品一区二区| 图片区小说区区亚洲影院| av激情成人网| 欧美国产禁国产网站cc| 捆绑变态av一区二区三区 | 亚洲国产三级在线| 大白屁股一区二区视频| 欧美xxxxx牲另类人与| 午夜精品久久久久久久99水蜜桃| 91久久一区二区| 亚洲欧洲日韩综合一区二区| 国产精品亚洲专一区二区三区| 欧美日韩高清影院| 视频在线在亚洲| 欧美日韩国产另类不卡| 一区二区三区av电影| 91蜜桃传媒精品久久久一区二区 | 欧美一区二区高清| 爽好久久久欧美精品| 91精彩视频在线| 亚洲精品成人a在线观看| 99久久久国产精品免费蜜臀| 欧美激情自拍偷拍| 99久久精品费精品国产一区二区| 国产精品久久久久一区二区三区 | 久久疯狂做爰流白浆xx| 欧美一级在线免费| 六月丁香婷婷色狠狠久久| 日韩女优视频免费观看| 久久精品国产成人一区二区三区 | 国产一区亚洲一区| 国产午夜精品在线观看| 成人听书哪个软件好| 国产精品理论片| 色久优优欧美色久优优| 一个色妞综合视频在线观看| 欧美日韩中文字幕精品| 日本亚洲免费观看| 久久九九久精品国产免费直播| 国产精一品亚洲二区在线视频| 国产日韩在线不卡| 在线观看免费视频综合| 国产高清无密码一区二区三区| 中文欧美字幕免费| 色哟哟一区二区三区| 日韩黄色免费电影| 久久久久久夜精品精品免费| 91视频在线观看| 老司机精品视频导航| 亚洲欧洲性图库| 欧美一区二区三区四区视频| 丁香婷婷综合五月| 亚洲电影欧美电影有声小说| 精品国产免费一区二区三区四区| 成人精品亚洲人成在线| 亚洲一区二区四区蜜桃| 精品国产sm最大网站免费看| aaa欧美大片| 老司机午夜精品99久久| 国产精品久久久久久亚洲毛片| 欧美色图在线观看| 国产成人aaa| 日本少妇一区二区| 日韩码欧中文字| 日韩久久免费av| 91国产免费观看| 国产美女娇喘av呻吟久久| 一级做a爱片久久| 国产三级一区二区三区| 日韩无一区二区| 91免费版pro下载短视频| 国产精品一区在线观看乱码 | 国产精品视频免费| 51午夜精品国产| 97精品视频在线观看自产线路二| 久久爱另类一区二区小说| 成人午夜电影网站| 欧美96一区二区免费视频| 一区二区三区中文字幕| 中文av字幕一区| 久久精品一二三| 日韩免费高清av| 欧美亚洲丝袜传媒另类| 99re66热这里只有精品3直播 | 成人午夜电影久久影院| 久久精品国产久精国产| 亚洲va天堂va国产va久| 国产精品美女视频| 久久亚洲欧美国产精品乐播| 日韩一区二区三区高清免费看看| 91丨九色丨尤物| 成人黄色大片在线观看| 国产毛片精品国产一区二区三区| 看国产成人h片视频| 日韩精品一区第一页| 亚洲一区在线观看免费观看电影高清 | 精品国产第一区二区三区观看体验| 欧美性色aⅴ视频一区日韩精品| 成人av在线资源网站| 国产91丝袜在线播放九色| 国产在线视频精品一区| 精品无码三级在线观看视频| 久久99精品国产| 国产老妇另类xxxxx| 国内精品自线一区二区三区视频| 青青草国产成人99久久| 看片的网站亚洲| 国产精品2024| 成人美女视频在线看| heyzo一本久久综合| av不卡在线观看| 色噜噜狠狠色综合中国| 欧美专区日韩专区| 这里只有精品视频在线观看| 91精品在线麻豆| 精品日韩欧美一区二区| 国产亚洲va综合人人澡精品| 国产精品福利电影一区二区三区四区| 中文字幕国产一区| 一区二区欧美在线观看| 亚洲午夜电影网| 美女在线一区二区| 风间由美一区二区三区在线观看 | 久久网这里都是精品| 国产视频在线观看一区二区三区 | 欧美性做爰猛烈叫床潮| 欧美一级片在线看| 久久天天做天天爱综合色| 国产精品丝袜一区| 亚洲国产精品久久人人爱蜜臀| 奇米888四色在线精品| 福利一区二区在线| 91精品福利在线| 日韩免费视频一区| 成人欧美一区二区三区1314| 香蕉成人啪国产精品视频综合网| 麻豆成人91精品二区三区| 国v精品久久久网| 欧美色老头old∨ideo| 久久精品亚洲精品国产欧美kt∨| 国产精品色呦呦| 香蕉影视欧美成人| 国产成人av电影在线| 欧美日韩精品专区| 日本一区二区三区在线不卡| 亚洲激情av在线| 精品一区二区综合| 日本电影欧美片| 欧美激情一区二区三区蜜桃视频 | 欧美大片免费久久精品三p| 日韩一区在线免费观看| 日本不卡视频在线观看| 暴力调教一区二区三区| 欧美日韩和欧美的一区二区| 久久精品日产第一区二区三区高清版 | 色噜噜久久综合| 久久久777精品电影网影网 | 成人免费av网站| 久久综合色8888| 亚洲二区在线观看| 99精品国产热久久91蜜凸| 精品理论电影在线| 亚洲成精国产精品女| 成人涩涩免费视频| 337p粉嫩大胆噜噜噜噜噜91av | 亚洲午夜久久久久久久久电影院| 黄页视频在线91| 91精品国产一区二区三区香蕉| 国产精品欧美经典| 美日韩一区二区三区| 欧美日韩在线免费视频| 中文字幕字幕中文在线中不卡视频| 久久se精品一区精品二区| 7777精品久久久大香线蕉| 亚洲人成伊人成综合网小说| 国产福利91精品一区二区三区| 欧美一区二区三区在线观看视频 | 国产日本欧洲亚洲| 青青草视频一区| 日韩欧美在线不卡| 午夜伊人狠狠久久| 欧美日韩一区在线观看| 亚洲免费观看高清在线观看| 99久久久国产精品| 日韩伦理电影网| 国产精品综合视频| 国产午夜精品久久久久久免费视| 国产精品一二三四区| 中文在线免费一区三区高中清不卡| 国产乱码字幕精品高清av|