81 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			81 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| /* MOD2CONVERT-TEST. C - Program to test mod2convert module. */
 | |
| 
 | |
| /* Copyright (c) 1995-2012 by Radford M. Neal.
 | |
|  *
 | |
|  * Permission is granted for anyone to copy, use, modify, and distribute
 | |
|  * these programs and accompanying documents for any purpose, provided
 | |
|  * this copyright notice is retained and prominently displayed, and note
 | |
|  * is made of any changes made to these programs.  These programs and
 | |
|  * documents are distributed without any warranty, express or implied.
 | |
|  * As the programs were written for research purposes only, they have not
 | |
|  * been tested to the degree that would be advisable in any important
 | |
|  * application.  All use of these programs is entirely at the user's own
 | |
|  * risk.
 | |
|  */
 | |
| 
 | |
| 
 | |
| /* Correct output for this program is saved in the file mod2convert-test-out */
 | |
| 
 | |
| 
 | |
| #include <stdlib.h>
 | |
| #include <stdio.h>
 | |
| #include <math.h>
 | |
| 
 | |
| #include "mod2dense.h"
 | |
| #include "mod2sparse.h"
 | |
| #include "mod2convert.h"
 | |
| #include "rand.h"
 | |
| 
 | |
| #define Rows 40		/* Dimensions of matrix to use in test */
 | |
| #define Cols 13
 | |
| 
 | |
| #define N 100		/* Number of bits to set in test matrix (some may be
 | |
|                            duplicates, leading to fewer 1's in matrix */
 | |
| 
 | |
| main(void)
 | |
| {
 | |
|   mod2sparse *sm1, *sm2;
 | |
|   mod2dense *dm1, *dm2;
 | |
|   int i;
 | |
| 
 | |
|   sm1 = mod2sparse_allocate(Rows,Cols);
 | |
|   sm2 = mod2sparse_allocate(Rows,Cols);
 | |
| 
 | |
|   dm1 = mod2dense_allocate(Rows,Cols);
 | |
|   dm2 = mod2dense_allocate(Rows,Cols);
 | |
| 
 | |
|   printf("\nCreating sparse matrix.\n"); 
 | |
|   fflush(stdout);
 | |
| 
 | |
|   for (i = 0; i<N; i++)
 | |
|   { mod2sparse_insert(sm1,rand_int(Rows),rand_int(Cols));
 | |
|   }
 | |
| 
 | |
|   printf("Converting from sparse to dense.\n");
 | |
|   fflush(stdout);
 | |
| 
 | |
|   mod2sparse_to_dense(sm1,dm1);
 | |
| 
 | |
|   printf("Converting back to dense again.\n");
 | |
|   fflush(stdout);
 | |
| 
 | |
|   mod2dense_to_sparse(dm1,sm2);
 | |
| 
 | |
|   printf("Testing for equality of two sparse matrices: %s.\n",
 | |
|     mod2sparse_equal(sm1,sm2) ? "OK" : "NOT OK");
 | |
|   fflush(stdout);
 | |
| 
 | |
|   printf("Converting to dense once again.\n");
 | |
|   fflush(stdout);
 | |
|  
 | |
|   mod2sparse_to_dense(sm2,dm2);
 | |
| 
 | |
|   printf("Testing for equality of two dense matrices: %s.\n",
 | |
|     mod2dense_equal(dm1,dm2) ? "OK" : "NOT OK");
 | |
|   fflush(stdout);
 | |
| 
 | |
|   printf("\nDONE WITH TESTS.\n");
 | |
| 
 | |
|   exit(0);
 | |
| }
 | 
