📄 rs_decode_file.c
字号:
/*Procedures and Programs for Galois-Field Arithmetic and Reed-Solomon Coding. Copyright (C) 2003 James S. PlankThis library is free software; you can redistribute it and/ormodify it under the terms of the GNU Lesser General PublicLicense as published by the Free Software Foundation; eitherversion 2.1 of the License, or (at your option) any later version.This library is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNULesser General Public License for more details.You should have received a copy of the GNU Lesser General PublicLicense along with this library; if not, write to the Free SoftwareFoundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA---------------------------------------------------------------------------Please see http://www.cs.utk.edu/~plank/plank/gflibfor instruction on how to use this library.Jim Plankplank@cs.utk.eduhttp://www.cs.utk.edu/~plankAssociate ProfessorDepartment of Computer ScienceUniversity of Tennessee203 Claxton Complex1122 Volunteer Blvd.Knoxville, TN 37996-3450 865-974-4397Fax: 865-974-4404$Revision: 1.2 $*/#include <stdio.h>#include "gflib.h"#include <sys/time.h>#include <sys/types.h>#include <sys/stat.h>/* This one is going to be in-core */main(int argc, char **argv){ int i, j, k, *vdm, *inv, *prod, cache_size; int rows, cols, blocksize, orig_size; int n, m, sz, *factors, tmp, factor, *exists, *map; char *stem, *filename; char **buffer, *buf_file, *block; struct stat buf; Condensed_Matrix *cm; int *mat, *id; FILE *f; if (argc != 2) { fprintf(stderr, "usage: rs_decode_file stem\n"); exit(1); } stem = argv[1]; buf_file = (char *) malloc(sizeof(char)*(strlen(stem)+30)); if (buf_file == NULL) { perror("malloc - buf_file"); exit(1); } sprintf(buf_file, "%s-info.txt", stem, i); f = fopen(buf_file, "r"); if (f == NULL) { perror(buf_file); exit(1); } if (fscanf(f, "%d\n", &orig_size) != 1) { fprintf(stderr, "Error reading info file 1\n"); exit(1); } if (fscanf(f, "%d\n", &sz) != 1) { fprintf(stderr, "Error reading info file 2\n"); exit(1); } if (fscanf(f, "%d\n", &blocksize) != 1) { fprintf(stderr, "Error reading info file 3\n"); exit(1); } if (fscanf(f, "%d\n", &n) != 1) { fprintf(stderr, "Error reading info file 4\n"); exit(1); } if (fscanf(f, "%d\n", &m) != 1) { fprintf(stderr, "Error reading info file 5\n"); exit(1); } vdm = gf_read_matrix(f, &rows, &cols); if (vdm == NULL) { fprintf(stderr, "Error reading info file matrix\n"); exit(1); } fclose(f); if (rows != n+m) { fprintf(stderr, "Error in %s - rows != n+m\n", buf_file); exit(1); } if (cols != n) { fprintf(stderr, "Error in %s - cols != n\n", buf_file); exit(1); } exists = (int *) malloc(sizeof(int) * rows); if (exists == NULL) { perror("malloc - exists"); exit(1); } factors = (int *) malloc(sizeof(int) * rows); if (factors == NULL) { perror("malloc - factors"); exit(1); } map = (int *) malloc(sizeof(int) * rows); if (map == NULL) { perror("malloc - map"); exit(1); } buffer = (char **) malloc(sizeof(char *)*n); for (i = 0; i < n; i++) { buffer[i] = (char *) malloc(blocksize); if (buffer[i] == NULL) { perror("Allocating buffer to store the whole file"); exit(1); } } j = 0; for (i = 0; i < rows && j < cols; i++) { sprintf(buf_file, "%s-%04d.rs", stem, i); if (stat(buf_file, &buf) != 0) { map[i] = -1; } else { if (buf.st_size != blocksize) { map[i] = -1; } else { map[i] = j++; f = fopen(buf_file, "r"); if (f == NULL) { perror(buf_file); exit(1); } k = fread(buffer[map[i]], 1, blocksize, f); if (k != blocksize) { fprintf(stderr, "%s -- stat says %d bytes, but only read %d\n", buf_file, buf.st_size, k); exit(1); } } } } if (j < cols) { fprintf(stderr, "Only %d fragments -- need %d. Sorry\n", j, cols); exit(1); } j = 0; for (i = 0; i < cols; i++) if (map[i] == -1) j++; fprintf(stderr, "Blocks to decode: %d\n", j); if (j == 0) { cache_size = orig_size; for (i = 0; i < cols; i++) { if (cache_size > 0) { fwrite(buffer[i], 1, (cache_size > blocksize) ? blocksize : cache_size, stdout); cache_size -= blocksize; } } exit(0); } block = (char *) malloc(sizeof(char)*blocksize); if (block == NULL) { perror("malloc - block"); exit(1); } for (i = 0; i < rows; i++) exists[i] = (map[i] != -1); cm = gf_condense_dispersal_matrix(vdm, exists, rows, cols); mat = cm->condensed_matrix; id = cm->row_identities; /* Fix it so that map[i] for i = 0 to cols-1 is defined correctly. map[i] is the index of buffer[] that holds the blocks for row i in the condensed matrix */ for (i = 0; i < cols; i++) { if (map[i] == -1) map[i] = map[id[i]]; } fprintf(stderr, "Inverting condensed dispersal matrix ... "); fflush(stderr); inv = gf_invert_matrix(mat, cols); if (inv == NULL) { fprintf(stderr, "\n\nError -- matrix unvertible\n"); exit(1); } fprintf(stderr, "Done\n"); fflush(stderr); fprintf(stderr, "\nCondensed matrix:\n\n"); gf_fprint_matrix(stderr, mat, cols, cols); fprintf(stderr, "\nInverted matrix:\n\n"); gf_fprint_matrix(stderr, inv, cols, cols); for(i = 0; i < rows; i++) factors[i] = 1; cache_size = orig_size; for (i = 0; i < cols && cache_size > 0; i++) { if (id[i] < cols) { fprintf(stderr, "Writing block %d from memory ... ", i); fflush(stderr); if (factors[i] != 1) { tmp = gf_single_divide(1, factors[i]);/* fprintf(stderr, "Factor = %3d. Tmp = %3d. Before[0] = %3d. ", factors[i], tmp, (unsigned char) buffer[map[i]][0]); */ factors[i] = 1; gf_mult_region(buffer[map[i]], blocksize, tmp);/* fprintf(stderr, "After[0] = %3d.\n", (unsigned char) buffer[map[i]][0]); */ } else {/* fprintf(stderr, "Factor = %3d. Buffer[0] = %3d.\b", factors[i], (unsigned char) buffer[map[i]][0]); */ } fwrite(buffer[map[i]], 1, (cache_size > blocksize) ? blocksize : cache_size, stdout); cache_size -= blocksize; fprintf(stderr, "Done\n"); fflush(stderr); } else { fprintf(stderr, "Decoding block %d ... ", i); fflush(stderr); memset(block, 0, blocksize); for (j = 0; j < cols; j++) { tmp = inv[i*cols+j]; factor = gf_single_divide(tmp, factors[j]);/* fprintf(stderr, "Factors[%d] = %3d. Tmp = %3d. Factor = %3d\n Before[j][0] = %3d. ", j, factors[j], tmp, factor, (unsigned char) buffer[map[j]][0]); */ factors[j] = tmp; gf_mult_region(buffer[map[j]], blocksize, factor);/* fprintf(stderr, "After[j][0] = %3d. ", (unsigned char) buffer[map[j]][0]); fprintf(stderr, "Before-block[0] = %3d. ", (unsigned char) block[0]); */ gf_add_parity(buffer[map[j]], block, blocksize);/* fprintf(stderr, "After-block[0] = %3d.\n", (unsigned char) block[0]); */ } fprintf(stderr, "writing ... "); fflush(stderr); fwrite(block, 1, (cache_size > blocksize) ? blocksize : cache_size, stdout); cache_size -= blocksize; fprintf(stderr, "Done\n"); fflush(stderr); } }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -