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

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

?? mod2dense.c

?? ldpc的11個(gè)程序 encode decode extract make-gen make-ldpc make-pchk print-gen print-pchk rand-src transm
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
/* 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;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久午夜国产精品| 欧美日韩视频在线观看一区二区三区| 日韩一区国产二区欧美三区| 视频一区免费在线观看| 日韩三级.com| 国产在线观看免费一区| 国产精品免费网站在线观看| 99re8在线精品视频免费播放| 日韩伦理免费电影| 欧美日韩夫妻久久| 韩国精品在线观看| 国产精品成人午夜| 欧美日韩亚州综合| 精品一二三四在线| 亚洲欧美影音先锋| 欧美丰满少妇xxxxx高潮对白| 韩国中文字幕2020精品| 国产精品蜜臀av| 欧美日韩成人在线| 国产乱子伦视频一区二区三区 | 亚洲色图另类专区| 欧美日韩国产123区| 国产成人在线色| 亚洲图片欧美色图| 久久久国产午夜精品| 色综合久久中文综合久久97 | 极品美女销魂一区二区三区免费| 国产色综合久久| 欧美又粗又大又爽| 国产一区在线精品| 一区二区三区四区五区视频在线观看 | 欧美一区二区免费| 99久久亚洲一区二区三区青草 | 亚洲免费观看高清完整版在线观看| 欧美在线免费观看视频| 国产伦精品一区二区三区免费迷 | 日韩av二区在线播放| 国产欧美日韩在线看| 精品视频一区二区三区免费| 国产a视频精品免费观看| 亚洲成人免费在线观看| 中文字幕欧美三区| 欧美第一区第二区| 欧美日韩www| 91色九色蝌蚪| 国产在线播放一区三区四| 亚洲小说春色综合另类电影| 国产色一区二区| 91精品国产福利| 在线亚洲+欧美+日本专区| 成人午夜免费av| 久久国产尿小便嘘嘘尿| 婷婷开心激情综合| 亚洲激情一二三区| 亚洲私人黄色宅男| 欧美国产日韩精品免费观看| 日韩欧美亚洲另类制服综合在线| 欧美色网一区二区| 91视频免费看| www.成人网.com| 成人自拍视频在线观看| 久草这里只有精品视频| 青青草一区二区三区| 丝袜诱惑制服诱惑色一区在线观看| 亚洲男人电影天堂| 一区精品在线播放| 中文字幕一区二区不卡| 亚洲国产成人私人影院tom| 久久久精品日韩欧美| 欧美精品一区视频| www一区二区| 久久久久久久久免费| 久久精品一区二区三区不卡牛牛| 精品日本一线二线三线不卡| 精品剧情在线观看| 欧美videos大乳护士334| 日韩精品一区二区三区在线播放| 69久久99精品久久久久婷婷| 欧美日韩色综合| 91精品麻豆日日躁夜夜躁| 91麻豆精品国产91久久久更新时间| 欧美三级韩国三级日本一级| 欧美亚洲国产一区二区三区| 欧美日韩精品免费观看视频| 欧美性色黄大片| 欧美日韩国产精选| 欧美成人精品1314www| 欧美成人精品1314www| 欧美精品一区二区三| 国产亚洲制服色| 一区在线播放视频| 亚洲国产欧美在线| 日本不卡一二三| 国产一区二区不卡老阿姨| www.成人在线| 欧美三级在线播放| 精品免费国产一区二区三区四区| 久久久亚洲精品石原莉奈| 国产精品欧美精品| 亚洲激情五月婷婷| 免费看欧美女人艹b| 国产真实乱偷精品视频免| 91在线观看美女| 久久精品亚洲乱码伦伦中文| 欧美午夜不卡在线观看免费| 欧美一级高清片| 欧美国产97人人爽人人喊| 亚洲自拍偷拍网站| 久久不见久久见中文字幕免费| 国产一区二区影院| 91久久线看在观草草青青| 欧美精品一卡两卡| 国产午夜精品一区二区三区嫩草 | 亚洲一区二区精品3399| 免费观看30秒视频久久| 成年人午夜久久久| 在线不卡免费欧美| 国产精品水嫩水嫩| 奇米精品一区二区三区四区 | 色综合久久综合| 欧美变态凌虐bdsm| 亚洲男人的天堂网| 麻豆freexxxx性91精品| 99精品久久免费看蜜臀剧情介绍| 欧美日韩国产大片| 国产精品久久久99| 老司机午夜精品| 91在线无精精品入口| 2020国产精品自拍| 肉色丝袜一区二区| 色综合久久综合网欧美综合网 | 中文字幕色av一区二区三区| 偷拍日韩校园综合在线| www..com久久爱| www国产成人| 石原莉奈在线亚洲三区| 91蜜桃在线免费视频| 国产亚洲精品久| 婷婷中文字幕综合| 色婷婷亚洲综合| 国产精品夫妻自拍| 国产精品夜夜爽| 欧美成人精精品一区二区频| 天使萌一区二区三区免费观看| 91亚洲精品久久久蜜桃| 国产亚洲精品久| 国内成人免费视频| 日韩一区二区影院| 五月综合激情网| 精品视频全国免费看| 亚洲人123区| www.亚洲精品| 国产精品麻豆欧美日韩ww| 国产精品正在播放| 久久蜜桃av一区精品变态类天堂| 五月天激情综合网| 欧美巨大另类极品videosbest| 亚洲欧美日韩小说| va亚洲va日韩不卡在线观看| 久久九九久久九九| 粉嫩13p一区二区三区| 久久免费视频色| 国产精品99久| 国产情人综合久久777777| 国产精品91xxx| 国产精品视频yy9299一区| 国产高清在线观看免费不卡| 久久综合久久综合九色| 国产美女av一区二区三区| 亚洲精品一线二线三线无人区| 精品一区二区成人精品| 久久久影视传媒| 成人黄色网址在线观看| 日韩一区在线看| 色美美综合视频| 亚洲成年人网站在线观看| 在线不卡免费av| 国产在线精品国自产拍免费| 日韩精品久久理论片| 91精品免费在线观看| 九色porny丨国产精品| 久久精品水蜜桃av综合天堂| 成人高清av在线| 一区二区三区免费网站| 欧美日韩午夜影院| 玖玖九九国产精品| 国产亚洲欧美日韩日本| 99久久er热在这里只有精品66| 亚洲精品国产无天堂网2021| 欧美猛男男办公室激情| 欧美美女bb生活片| 狠狠色丁香婷婷综合久久片| 国产欧美一区二区精品婷婷| 色八戒一区二区三区| 美腿丝袜在线亚洲一区| 亚洲国产电影在线观看| 欧洲生活片亚洲生活在线观看| 琪琪久久久久日韩精品| 国产精品网站导航| 欧美理论在线播放|