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

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

?? mod2sparse.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):
/* MOD2SPARSE.C - Procedures for handling sparse mod2 matrices. *//* Copyright (c) 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 mod2sparse.html for documentation on these procedures. */#include <stdlib.h>#include <stdio.h>#include <math.h>#include "alloc.h"#include "intio.h"#include "mod2sparse.h"/* ALLOCATE AN ENTRY WITHIN A MATRIX.  This local procedure is used to   allocate a new entry, representing a non-zero element, within a given   matrix.  Entries in this matrix that were previously allocated and   then freed are re-used.  If there are no such entries, a new block   of entries is allocated. */static mod2entry *alloc_entry( mod2sparse *m){   mod2block *b;  mod2entry *e;  int k;  if (m->next_free==0)  {     b = chk_alloc (1, sizeof *b);    b->next = m->blocks;    m->blocks = b;    for (k = 0; k<Mod2sparse_block; k++)    { b->entry[k].left = m->next_free;      m->next_free = &b->entry[k];    }  }  e = m->next_free;  m->next_free = e->left;  e->pr = 0;  e->lr = 0;  return e;}/* ALLOCATE SPACE FOR A SPARSE MOD2 MATRIX.  */mod2sparse *mod2sparse_allocate( int n_rows, 		/* Number of rows in matrix */  int n_cols		/* Number of columns in matrix */){  mod2sparse *m;  mod2entry *e;  int i, j;  if (n_rows<=0 || n_cols<=0)  { fprintf(stderr,"mod2sparse_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->rows = chk_alloc (n_rows, sizeof *m->rows);  m->cols = chk_alloc (n_cols, sizeof *m->cols);  m->blocks = 0;  m->next_free = 0;  for (i = 0; i<n_rows; i++)  { e = &m->rows[i];    e->left = e->right = e->up = e->down = e;    e->row = e->col = -1;  }  for (j = 0; j<n_cols; j++)  { e = &m->cols[j];    e->left = e->right = e->up = e->down = e;    e->row = e->col = -1;  }  return m;}/* FREE SPACE OCCUPIED BY A SPARSE MOD2 MATRIX. */void mod2sparse_free( mod2sparse *m		/* Matrix to free */){   mod2block *b;  free(m->rows);  free(m->cols);  while (m->blocks!=0)  { b = m->blocks;    m->blocks = b->next;    free(b);  }}/* CLEAR A SPARSE MATRIX TO ALL ZEROS. */void mod2sparse_clear( mod2sparse *r){  mod2block *b;  mod2entry *e;  int i, j;  for (i = 0; i<mod2sparse_rows(r); i++)  { e = &r->rows[i];    e->left = e->right = e->up = e->down = e;  }  for (j = 0; j<mod2sparse_cols(r); j++)  { e = &r->cols[j];    e->left = e->right = e->up = e->down = e;  }  while (r->blocks!=0)  { b = r->blocks;    r->blocks = b->next;    free(b);  }}/* COPY A SPARSE MATRIX. */void mod2sparse_copy( mod2sparse *m,	/* Matrix to copy */  mod2sparse *r		/* Place to store copy of matrix */){  mod2entry *e, *f;  int i;  if (mod2sparse_rows(m)>mod2sparse_rows(r)    || mod2sparse_cols(m)>mod2sparse_cols(r))  { fprintf(stderr,"mod2sparse_copy: Destination matrix is too small\n");    exit(1);  }  mod2sparse_clear(r);  for (i = 0; i<mod2sparse_rows(m); i++)  {    e = mod2sparse_first_in_row(m,i);     while (!mod2sparse_at_end(e))    { f = mod2sparse_insert(r,e->row,e->col);      f->lr = e->lr;      f->pr = e->pr;      e = mod2sparse_next_in_row(e);    }  }}/* COPY ROWS OF A SPARSE MOD2 MATRIX. */void mod2sparse_copyrows( mod2sparse *m,	/* Matrix to copy */  mod2sparse *r,	/* Place to store copy of matrix */  int *rows		/* Indexes of rows to copy, from 0 */){   mod2entry *e;  int i;  if (mod2sparse_cols(m)>mod2sparse_cols(r))  { fprintf(stderr,     "mod2sparse_copyrows: Destination matrix has fewer columns than source\n");    exit(1);  }  mod2sparse_clear(r);  for (i = 0; i<mod2sparse_rows(r); i++)  { if (rows[i]<0 || rows[i]>=mod2sparse_rows(m))    { fprintf(stderr,"mod2sparse_copyrows: Row index out of range\n");      exit(1);    }    e = mod2sparse_first_in_row(m,rows[i]);    while (!mod2sparse_at_end(e))    { mod2sparse_insert(r,i,e->col);      e = mod2sparse_next_in_row(e);    }  }}/* COPY COLUMNS OF A SPARSE MOD2 MATRIX. */void mod2sparse_copycols( mod2sparse *m,	/* Matrix to copy */  mod2sparse *r,	/* Place to store copy of matrix */  int *cols		/* Indexes of columns to copy, from 0 */){   mod2entry *e;  int j;  if (mod2sparse_rows(m)>mod2sparse_rows(r))  { fprintf(stderr,      "mod2sparse_copycols: Destination matrix has fewer rows than source\n");    exit(1);  }  mod2sparse_clear(r);  for (j = 0; j<mod2sparse_cols(r); j++)  { if (cols[j]<0 || cols[j]>=mod2sparse_cols(m))    { fprintf(stderr,"mod2sparse_copycols: Column index out of range\n");      exit(1);    }    e = mod2sparse_first_in_col(m,cols[j]);    while (!mod2sparse_at_end(e))    { mod2sparse_insert(r,e->row,j);      e = mod2sparse_next_in_col(e);    }  }}/* PRINT A SPARSE MOD2 MATRIX IN HUMAN-READABLE FORM. */void mod2sparse_print( FILE *f,  mod2sparse *m){   int rdigits, cdigits;  mod2entry *e;  int i;  rdigits = mod2sparse_rows(m)<=10 ? 1           : mod2sparse_rows(m)<=100 ? 2          : mod2sparse_rows(m)<=1000 ? 3          : mod2sparse_rows(m)<=10000 ? 4          : mod2sparse_rows(m)<=100000 ? 5          : 6;  cdigits = mod2sparse_cols(m)<=10 ? 1           : mod2sparse_cols(m)<=100 ? 2          : mod2sparse_cols(m)<=1000 ? 3          : mod2sparse_cols(m)<=10000 ? 4          : mod2sparse_cols(m)<=100000 ? 5          : 6;  for (i = 0; i<mod2sparse_rows(m); i++)  {     fprintf(f,"%*d:",rdigits,i);    e = mod2sparse_first_in_row(m,i);    while (!mod2sparse_at_end(e))    { fprintf(f," %*d",cdigits,mod2sparse_col(e));      e = mod2sparse_next_in_row(e);    }    fprintf(f,"\n");  }}/* WRITE A SPARSE MOD2 MATRIX TO A FILE IN MACHINE-READABLE FORM. */int mod2sparse_write( FILE *f,  mod2sparse *m){  mod2entry *e;  int i;  intio_write(f,m->n_rows);  if (ferror(f)) return 0;  intio_write(f,m->n_cols);  if (ferror(f)) return 0;  for (i = 0; i<mod2sparse_rows(m); i++)  {     e = mod2sparse_first_in_row(m,i);    if (!mod2sparse_at_end(e))    {      intio_write (f, -(i+1));      if (ferror(f)) return 0;      while (!mod2sparse_at_end(e))      {         intio_write (f, mod2sparse_col(e)+1);        if (ferror(f)) return 0;        e = mod2sparse_next_in_row(e);      }    }  }  intio_write(f,0);  if (ferror(f)) return 0;  return 1;}/* READ A SPARSE MOD2 MATRIX STORED IN MACHINE-READABLE FORM FROM A FILE. */mod2sparse *mod2sparse_read( FILE *f){  int n_rows, n_cols;  mod2sparse *m;  int v, row, col;  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 = mod2sparse_allocate(n_rows,n_cols);  row = -1;  for (;;)  {    v = intio_read(f);    if (feof(f) || ferror(f)) break;    if (v==0)    { return m;    }    else if (v<0)     { row = -v-1;      if (row>=n_rows) break;    }    else     { col = v-1;      if (col>=n_cols) break;      if (row==-1) break;      mod2sparse_insert(m,row,col);    }  }  /* Error if we get here. */  mod2sparse_free(m);  return 0;   }/* LOOK FOR AN ENTRY WITH GIVEN ROW AND COLUMN. */mod2entry *mod2sparse_find( mod2sparse *m,  int row,  int col){   mod2entry *re, *ce;  if (row<0 || row>=mod2sparse_rows(m) || col<0 || col>=mod2sparse_cols(m))  { fprintf(stderr,"mod2sparse_find: row or column index out of bounds\n");    exit(1);  }  /* Check last entries in row and column. */  re = mod2sparse_last_in_row(m,row);  if (mod2sparse_at_end(re) || mod2sparse_col(re)<col)   { return 0;  }  if (mod2sparse_col(re)==col)   { return re;  }  ce = mod2sparse_last_in_col(m,col);  if (mod2sparse_at_end(ce) || mod2sparse_row(ce)<row)  { return 0;  }  if (mod2sparse_row(ce)==row)  { return ce;  }  /* Search row and column in parallel, from the front. */  re = mod2sparse_first_in_row(m,row);  ce = mod2sparse_first_in_col(m,col);  for (;;)  {     if (mod2sparse_at_end(re) || mod2sparse_col(re)>col)    { return 0;    }     if (mod2sparse_col(re)==col)     { return re;    }    if (mod2sparse_at_end(ce) || mod2sparse_row(ce)>row)    { return 0;    }     if (mod2sparse_row(ce)==row)    { return ce;    }    re = mod2sparse_next_in_row(re);    ce = mod2sparse_next_in_col(ce);  }}/* INSERT AN ENTRY WITH GIVEN ROW AND COLUMN. */mod2entry *mod2sparse_insert( mod2sparse *m,  int row,  int col){  mod2entry *re, *ce, *ne;  if (row<0 || row>=mod2sparse_rows(m) || col<0 || col>=mod2sparse_cols(m))  { fprintf(stderr,"mod2sparse_insert: row or column index out of bounds\n");    exit(1);  }  /* Find old entry and return it, or allocate new entry and insert into row. */  re = mod2sparse_last_in_row(m,row);  if (!mod2sparse_at_end(re) && mod2sparse_col(re)==col)   { return re;  }  if (mod2sparse_at_end(re) || mod2sparse_col(re)<col)   { re = re->right;  }  else  {    re = mod2sparse_first_in_row(m,row);    for (;;)    {       if (!mod2sparse_at_end(re) && mod2sparse_col(re)==col)       { return re;      }      if (mod2sparse_at_end(re) || mod2sparse_col(re)>col)      { break;      }       re = mod2sparse_next_in_row(re);    }  }  ne = alloc_entry(m);  ne->row = row;  ne->col = col;  ne->left = re->left;  ne->right = re;  ne->left->right = ne;  ne->right->left = ne;  /* Insert new entry into column.  If we find an existing entry here,     the matrix must be garbled, since we didn't find it in the row. */  ce = mod2sparse_last_in_col(m,col);  if (!mod2sparse_at_end(ce) && mod2sparse_row(ce)==row)   { fprintf(stderr,"mod2sparse_insert: Garbled matrix\n");    exit(1);  }  if (mod2sparse_at_end(ce) || mod2sparse_row(ce)<row)   { ce = ce->down;  }  else  {    ce = mod2sparse_first_in_col(m,col);    for (;;)    {       if (!mod2sparse_at_end(ce) && mod2sparse_row(ce)==row)       { fprintf(stderr,"mod2sparse_insert: Garbled matrix\n");        exit(1);      }      if (mod2sparse_at_end(ce) || mod2sparse_row(ce)>row)      { break;      }       ce = mod2sparse_next_in_col(ce);    }  }      ne->up = ce->up;  ne->down = ce;  ne->up->down = ne;  ne->down->up = ne;  /* Return the new entry. */  return ne;}/* DELETE AN ENTRY FROM A SPARSE MATRIX. */void mod2sparse_delete( mod2sparse *m,  mod2entry *e){   if (e==0)  { fprintf(stderr,"mod2sparse_delete: Trying to delete a null entry\n");    exit(1);  }  if (e->row<0 || e->col<0)  { fprintf(stderr,"mod2sparse_delete: Trying to delete a header entry\n");    exit(1);  }  e->left->right = e->right;  e->right->left = e->left;  e->up->down = e->down;  e->down->up = e->up;   e->left = m->next_free;  m->next_free = e;}/* TEST WHETHER TWO SPARSE MATRICES ARE EQUAL. */int mod2sparse_equal( mod2sparse *m1,  mod2sparse *m2){  mod2entry *e1, *e2;  int i;  if (mod2sparse_rows(m1)!=mod2sparse_rows(m2)    || mod2sparse_cols(m1)!=mod2sparse_cols(m2))  { fprintf(stderr,"mod2sparse_equal: Matrices have different dimensions\n");    exit(1);  }    for (i = 0; i<mod2sparse_rows(m1); i++)  {     e1 = mod2sparse_first_in_row(m1,i);    e2 = mod2sparse_first_in_row(m2,i);    while (!mod2sparse_at_end(e1) && !mod2sparse_at_end(e2))    {        if (mod2sparse_col(e1)!=mod2sparse_col(e2))      { return 0;      }      e1 = mod2sparse_next_in_row(e1);      e2 = mod2sparse_next_in_row(e2);    }    if (!mod2sparse_at_end(e1) || !mod2sparse_at_end(e2))     { return 0;    }  }  return 1;}/* COMPUTE THE TRANSPOSE OF A SPARSE MOD2 MATRIX. */void mod2sparse_transpose( mod2sparse *m,	/* Matrix to compute transpose of (left unchanged) */  mod2sparse *r		/* Result of transpose operation */){  mod2entry *e;  int i;  if (mod2sparse_rows(m)!=mod2sparse_cols(r)    || mod2sparse_cols(m)!=mod2sparse_rows(r))  { fprintf(stderr,     "mod2sparse_transpose: Matrices have incompatible dimensions\n");    exit(1);  }  if (r==m)  { fprintf(stderr,      "mod2sparse_transpose: Result matrix is the same as the operand\n");    exit(1);  }  mod2sparse_clear(r);  for (i = 0; i<mod2sparse_rows(m); i++)  {    e = mod2sparse_first_in_row(m,i);    while (!mod2sparse_at_end(e))    { mod2sparse_insert(r,mod2sparse_col(e),i);      e = mod2sparse_next_in_row(e);    }  }}/* ADD TWO SPARSE MOD2 MATRICES. */void mod2sparse_add( mod2sparse *m1,	/* Left operand of add */  mod2sparse *m2,	/* Right operand of add */  mod2sparse *r		/* Place to store result of add */){  mod2entry *e1, *e2;  int i;  if (mod2sparse_rows(m1)!=mod2sparse_rows(r)    || mod2sparse_cols(m1)!=mod2sparse_cols(r)    || mod2sparse_rows(m2)!=mod2sparse_rows(r)   || mod2sparse_cols(m2)!=mod2sparse_cols(r))   { fprintf(stderr,"mod2sparse_add: Matrices have different dimensions\n");    exit(1);  }  if (r==m1 || r==m2)  { fprintf(stderr,     "mod2sparse_add: Result matrix is the same as one of the operands\n");    exit(1);  }  mod2sparse_clear(r);  for (i = 0; i<mod2sparse_rows(r); i++)  {     e1 = mod2sparse_first_in_row(m1,i);    e2 = mod2sparse_first_in_row(m2,i);    while (!mod2sparse_at_end(e1) && !mod2sparse_at_end(e2))    {       if (mod2sparse_col(e1)==mod2sparse_col(e2))      { e1 = mod2sparse_next_in_row(e1);        e2 = mod2sparse_next_in_row(e2);       }

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
激情综合网最新| 国产乱码精品1区2区3区| 日韩亚洲欧美成人一区| 欧美三区在线观看| 91欧美激情一区二区三区成人| 91免费视频网址| 久久国产精品99久久人人澡| 免费一级片91| 中文字幕不卡三区| 91成人网在线| 欧美色图在线观看| 亚洲线精品一区二区三区八戒| 精品日产卡一卡二卡麻豆| 欧美日韩精品一区视频| 久久毛片高清国产| 亚洲你懂的在线视频| 久久99精品久久久久久动态图| 成人短视频下载| 精品视频免费看| 亚洲国产精品v| 偷拍日韩校园综合在线| 国产成人一区在线| 91免费看片在线观看| 欧美日本精品一区二区三区| 26uuu久久天堂性欧美| 尤物在线观看一区| 精东粉嫩av免费一区二区三区| eeuss国产一区二区三区| 欧美最猛性xxxxx直播| 这里是久久伊人| 亚洲男同1069视频| 久久国内精品视频| 99精品久久免费看蜜臀剧情介绍| 欧美一区二区黄| 一区二区三区久久| 成人综合在线网站| 久久精品一区四区| 九九在线精品视频| 91精品黄色片免费大全| 亚洲视频在线观看三级| 国产毛片一区二区| 日韩欧美亚洲国产精品字幕久久久| 国产精品污网站| 国产一区二区电影| 欧美少妇bbb| 亚洲线精品一区二区三区| 蜜臀国产一区二区三区在线播放| 亚洲美女视频在线观看| 一区二区三区国产豹纹内裤在线| 国产精品99久久久久久似苏梦涵 | 亚洲h动漫在线| 国产精品99久久久久久久女警 | 亚洲第一狼人社区| 丁香啪啪综合成人亚洲小说| 日韩电影一二三区| 在线观看日韩一区| 天天免费综合色| 欧美一区二区三区思思人| 日韩二区三区四区| 欧美一区二区在线免费播放 | 亚洲卡通欧美制服中文| 成人高清在线视频| 中文字幕日韩精品一区| 不卡一区二区三区四区| 亚洲最大色网站| 欧美三级电影一区| 日本强好片久久久久久aaa| 欧美videos中文字幕| 国产一区久久久| 国产精品久久久久久亚洲伦 | www.在线欧美| 国产精品不卡一区二区三区| 91在线观看美女| 亚洲韩国精品一区| 欧美变态凌虐bdsm| 色综合一个色综合| 国产精品久久久久久久久免费相片 | 久国产精品韩国三级视频| 欧美三级视频在线| 五月开心婷婷久久| 欧美久久久一区| 麻豆精品视频在线观看| 欧美成人性战久久| 国产精品一区二区久激情瑜伽| 日韩一区二区视频在线观看| 欧洲一区二区三区在线| 蜜臀a∨国产成人精品| 《视频一区视频二区| 欧美大片在线观看一区二区| 91丝袜国产在线播放| 久久综合综合久久综合| 亚洲精品美国一| 久久只精品国产| 欧美一区日韩一区| 欧美一a一片一级一片| 日本麻豆一区二区三区视频| 亚洲精品一二三区| 国产精品伦一区| 日韩免费高清视频| 91精品久久久久久蜜臀| 91黄色小视频| 91首页免费视频| 成人黄色综合网站| 韩国成人福利片在线播放| 亚洲国产精品久久久久秋霞影院| 国产精品乱人伦中文| 精品动漫一区二区三区在线观看| 欧美精品v国产精品v日韩精品 | 亚洲区小说区图片区qvod| 91久久精品国产91性色tv| 免费一级片91| 亚洲一区二区三区三| 亚洲欧美影音先锋| 九九久久精品视频| 欧美一卡二卡三卡| 国产欧美日韩另类视频免费观看| 国产精品99久| 亚洲综合成人在线视频| 日韩免费看网站| 99久久久无码国产精品| 日韩在线播放一区二区| 久久精品这里都是精品| 欧美日韩免费高清一区色橹橹 | 欧美tickling挠脚心丨vk| 日韩一区二区免费高清| 精品蜜桃在线看| 国产精品久久久久天堂| 国产精品久久久久久久久晋中| 亚洲一区二区美女| 亚洲福利一二三区| 国产精品自拍毛片| 色综合中文字幕| 欧美一区二区人人喊爽| 日韩视频在线你懂得| 欧美韩国日本一区| 亚洲精品国产精华液| 日本一区中文字幕| 国产真实乱偷精品视频免| 91麻豆国产在线观看| 欧美一级黄色大片| 国产精品国产成人国产三级| 亚洲一区二区三区影院| 国产在线精品免费| 欧洲精品在线观看| 国产精品久久久久久久浪潮网站 | proumb性欧美在线观看| 4438x成人网最大色成网站| 在线成人免费观看| 一区二区三区电影在线播| 国产麻豆视频一区| 亚洲国产高清不卡| 亚洲美女屁股眼交3| 亚洲一区二区美女| 日韩欧美一级片| 欧美午夜精品一区二区三区| 亚洲va韩国va欧美va| 欧美性生活一区| 91丝袜高跟美女视频| 国产成人h网站| 久久99久久99精品免视看婷婷| 亚洲国产综合在线| 一区二区三区在线观看国产| 国产日韩欧美亚洲| 久久一夜天堂av一区二区三区| 日韩欧美一级片| 91精品国产综合久久久久久久| 欧美调教femdomvk| 亚洲成人手机在线| 在线精品亚洲一区二区不卡| 久久综合丝袜日本网| 久草热8精品视频在线观看| 欧美丰满一区二区免费视频 | 欧美欧美欧美欧美| 中文字幕欧美激情| 久久99国产精品久久99果冻传媒| 欧美在线观看禁18| 亚洲成a人片综合在线| 精品久久人人做人人爽| 成人三级伦理片| 国产成人在线视频免费播放| 国产乱人伦偷精品视频不卡| 韩日欧美一区二区三区| 极品少妇xxxx精品少妇| 免费看黄色91| 国产精品自产自拍| 成人av免费在线播放| av中文一区二区三区| 欧美这里有精品| 成人免费高清视频在线观看| 丰满白嫩尤物一区二区| 成人免费毛片嘿嘿连载视频| 欧美国产日韩精品免费观看| 黑人巨大精品欧美一区| 91麻豆视频网站| 国产精品传媒视频| 欧美日韩成人在线| 日韩激情一二三区| 久久精品国产亚洲aⅴ| 99热精品一区二区| 91精品国产乱|