From a7a06a7ccfe0af1e134357678b8fa6cf87dff3b0 Mon Sep 17 00:00:00 2001 From: Lorry Tar Creator Date: Sat, 7 Feb 2009 16:32:56 +0000 Subject: anthy-9100h --- test/test-matrix.c | 74 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 74 insertions(+) create mode 100644 test/test-matrix.c (limited to 'test/test-matrix.c') diff --git a/test/test-matrix.c b/test/test-matrix.c new file mode 100644 index 0000000..2552abe --- /dev/null +++ b/test/test-matrix.c @@ -0,0 +1,74 @@ +/* 疎行列のテスト用コード */ +#include +#include +#include +#include + +static void +change_endian(struct matrix_image *im) +{ + int i; + for (i = 0; i < im->size; i++) { + im->image[i] = anthy_dic_htonl(im->image[i]); + } +} + +static void +zero_matrix(void) +{ + struct sparse_matrix *m; + struct matrix_image *mi; + int *im, e; + m = anthy_sparse_matrix_new(); + anthy_sparse_matrix_make_matrix(m); + mi = anthy_matrix_image_new(m); + change_endian(mi); + im = mi->image; + e = anthy_matrix_image_peek(im, 0, 0); + printf("zero matrix: size=%d (0,0)=%d\n", mi->size, e); +} + +static void +dense_matrix(void) +{ + int i, j, fail; + struct sparse_matrix *m; + struct matrix_image *mi; + int *im, e; + m = anthy_sparse_matrix_new(); + for (i = 0; i < 100; i++) { + for (j = 0; j < 100; j++) { + anthy_sparse_matrix_set(m, i, j, i + j, NULL); + } + } + anthy_sparse_matrix_make_matrix(m); + mi = anthy_matrix_image_new(m); + change_endian(mi); + im = mi->image; + fail = 0; + for (i = 0; i < 100; i++) { + for (j = 0; j < 100; j++) { + e = anthy_matrix_image_peek(im, i, j); + if (e != i+j) { + printf("image(%d,%d) == %d != %d\n", i,j,e,i+j); + fail ++; + } + e = anthy_sparse_matrix_get_int(m, i, j); + if (e != i+j) { + printf("origin(%d,%d) == %d != %d\n", i,j,e,i+j); + fail ++; + } + } + } + printf("%d errors in desnse matrix\n", fail); +} + +int +main(int argc, char **argv) +{ + (void)argc; + (void)argv; + zero_matrix(); + dense_matrix(); + return 0; +} -- cgit v1.2.1