예제 #1
0
void cauchy_improve_coding_matrix(int k, int m, int w, int *matrix)
{
    int index, i, j, x;
    int tmp;
    int bno, tno, bno_index;

    for (j = 0; j < k; j++)
    {
        if (matrix[j] != 1)
        {
            tmp = galois_single_divide(1, matrix[j], w);
            index = j;
            for (i = 0; i < m; i++)
            {
                matrix[index] = galois_single_multiply(matrix[index], tmp, w);
                index += k;
            }
        }
    }
    for (i = 1; i < m; i++)
    {
        bno = 0;
        index = i*k;
        for (j = 0; j < k; j++) bno += cauchy_n_ones(matrix[index+j], w);
        bno_index = -1;
        for (j = 0; j < k; j++)
        {
            if (matrix[index+j] != 1)
            {
                tmp = galois_single_divide(1, matrix[index+j], w);
                tno = 0;
                for (x = 0; x < k; x++)
                {
                    tno += cauchy_n_ones(galois_single_multiply(matrix[index+x], tmp, w), w);
                }
                if (tno < bno)
                {
                    bno = tno;
                    bno_index = j;
                }
            }
        }
        if (bno_index != -1)
        {
            tmp = galois_single_divide(1, matrix[index+bno_index], w);
            for (j = 0; j < k; j++)
            {
                matrix[index+j] = galois_single_multiply(matrix[index+j], tmp, w);
            }
        }
    }
}
예제 #2
0
파일: cauchy_01.c 프로젝트: AleksMx/qfs
int main(int argc, char **argv)
{
  int n;
  int i, no, w;
  int *bitmatrix;
  
  if (argc != 3) usage(NULL);
  if (sscanf(argv[1], "0x%x", &n) == 0) {
    if (sscanf(argv[1], "%d", &n) == 0) usage("Bad n");
  }
  if (sscanf(argv[2], "%d", &w) == 0 || w <= 0 || w > 32) usage("Bad w");
  if (w == 31) {
    if (n & 0x80000000L) usage("Bad n/w combination (n not between 0 and 2^w-1)\n");
  } else if (w < 31) {
    if (n >= (1 << w)) usage("Bad n/w combination (n not between 0 and 2^w-1)\n");
  }

  bitmatrix = jerasure_matrix_to_bitmatrix(1, 1, w, &n);
  printf("<HTML><title>cauchy_01 %u %d</title>\n", w, n);
  printf("<HTML><h3>cauchy_01 %u %d</h3>\n", w, n);
  printf("<pre>\n");
  if (w == 32) {
    printf("Converted the value 0x%x to the following bitmatrix:\n\n", n);
  } else {
    printf("Converted the value %d (0x%x) to the following bitmatrix:\n\n", n, n);
  }
  jerasure_print_bitmatrix(bitmatrix, w, w, w);
  printf("\n");

  no = 0;
  for (i = 0; i < w*w; i++) no += bitmatrix[i];
  if (no != cauchy_n_ones(n, w)) { 
    fprintf(stderr, "Jerasure error: # ones in the bitmatrix (%d) doesn't match cauchy_n_ones() (%d).\n",
       no, cauchy_n_ones(n, w));
    exit(1);
  }

  printf("# Ones: %d\n", cauchy_n_ones(n, w));

  return 0;
}
예제 #3
0
int main(int argc, char **argv)
{
  int n, i, no, w;
  int *bitmatrix;
  
  if (argc != 3) usage(NULL);
  if (sscanf(argv[1], "%d", &n) == 0 || n <= 0) usage("Bad n");
  if (sscanf(argv[2], "%d", &w) == 0 || w <= 0 || w > 32) usage("Bad w");
  if (w < 30 && n >= (1 << w)) usage("n is too big");

  bitmatrix = jerasure_matrix_to_bitmatrix(1, 1, w, &n);
  no = 0;
  for (i = 0; i < w*w; i++) no += bitmatrix[i];

  printf("# Ones: %d\n", cauchy_n_ones(n, w));
  printf("\n");
  printf("Bitmatrix has %d ones\n", no);
  printf("\n");
  jerasure_print_bitmatrix(bitmatrix, w, w, w);

  return 0;
}
예제 #4
0
/*
* Class:     eu_vandertil_jerasure_jni_Cauchy
* Method:    cauchy_n_ones
* Signature: (II)I
*/
JNIEXPORT jint JNICALL Java_eu_vandertil_jerasure_jni_Cauchy_cauchy_1n_1ones
	(JNIEnv *env, jclass clazz, jint jn, jint jw)
{
	return cauchy_n_ones(jn, jw);
}