# include <stdlib.h> # include <stdio.h> # include <math.h> # include <time.h> # include <string.h> # include "hb_io.h" int main ( ); void test01 ( char *input_file ); void test02 ( ); void test03 ( char *input_file ); void test04 ( ); void test05 ( char *input_file ); void test06 ( ); void test07 ( char *input_file ); void test08 ( ); void test09 ( char *input_file ); void test10 ( ); void test11 ( ); void test12 ( ); /******************************************************************************/ int main ( ) /******************************************************************************/ /* Purpose: hb_io_test() tests hb_io(). Licensing: This code is distributed under the MIT license. Modified: 22 January 2014 Author: John Burkardt */ { timestamp ( ); printf ( "\n" ); printf ( "hn_io_test():\n" ); printf ( " C version\n" ); printf ( " Test hb_io().\n" ); test01 ( "rua_32.txt" ); test01 ( "rse_5.txt" ); test02 ( ); test03 ( "rua_32.txt" ); test03 ( "rse_5.txt" ); test04 ( ); test05 ( "rua_32.txt" ); test05 ( "rse_5.txt" ); test06 ( ); test07 ( "rua_32.txt" ); test08 ( ); test09 ( "rua_32.txt" ); test10 ( ); test11 ( ); test12 ( ); /* Terminate. */ printf ( "\n" ); printf ( "hb_io_test():\n" ); printf ( " Normal end of execution.\n" ); printf ( "\n" ); timestamp ( ); return 0; } /******************************************************************************/ void test01 ( char *input_file ) /******************************************************************************/ /* Purpose: TEST01 tests HB_HEADER_READ; Licensing: This code is distributed under the MIT license. Modified: 01 March 2007 Author: John Burkardt */ { int indcrd; char *indfmt = NULL; FILE *input; char *key = NULL; char *mxtype = NULL; int ncol; int neltvl; int nnzero; int nrhs; int nrhsix; int nrow; int ptrcrd; char *ptrfmt = NULL; int rhscrd; char *rhsfmt = NULL; char *rhstyp = NULL; char *title = NULL; int totcrd; int valcrd; char *valfmt = NULL; printf ( " \n" ); printf ( "TEST01\n" ); printf ( " HB_HEADER_READ reads the header of an HB file.\n" ); printf ( "\n" ); printf ( " Reading the file '%s'.\n", input_file ); input = fopen ( input_file, "rt" ); if ( !input ) { printf ( "\n" ); printf ( "TEST01 - Warning!\n" ); printf ( " Error opening the file.\n" ); return; } hb_header_read ( input, &title, &key, &totcrd, &ptrcrd, &indcrd, &valcrd, &rhscrd, &mxtype, &nrow, &ncol, &nnzero, &neltvl, &ptrfmt, &indfmt, &valfmt, &rhsfmt, &rhstyp, &nrhs, &nrhsix ); fclose ( input ); /* Print out the header information. */ hb_header_print ( title, key, totcrd, ptrcrd, indcrd, valcrd, rhscrd, mxtype, nrow, ncol, nnzero, neltvl, ptrfmt, indfmt, valfmt, rhsfmt, rhstyp, nrhs, nrhsix ); return; } /******************************************************************************/ void test02 ( ) /******************************************************************************/ /* Purpose: TEST02 tests HB_HEADER_WRITE; Licensing: This code is distributed under the MIT license. Modified: 21 January 2014 Author: John Burkardt */ { int indcrd = 8; char indfmt[17] = "(16I5)"; char key[9] = "RUA_32"; char mxtype[4] = "RUA"; int ncol = 32; int neltvl = 0; int nnzero = 126; int nrhs = 0; int nrhsix = 0; int nrow = 32; FILE *output; char output_file[] = "rua_32_header.txt"; int ptrcrd = 3; char ptrfmt[17] = "(16I5)"; int rhscrd = 0; char rhsfmt[21] = " "; char rhstyp[4] = " "; char title[] = "1Real unsymmetric assembled matrix based on IBM32"; int totcrd = 11; int valcrd = 0; char valfmt[21] = " "; printf ( "\n" ); printf ( "TEST02\n" ); printf ( " HB_HEADER_WRITE writes the header of an HB file.\n" ); printf ( "\n" ); printf ( " Writing the file '%s'.\n", output_file ); output = fopen ( output_file, "wt" ); if ( !output ) { printf ( "\n" ); printf ( "TEST02 - Warning!\n" ); printf ( " Error opening the file.\n" ); return; } hb_header_write ( output, title, key, totcrd, ptrcrd, indcrd, valcrd, rhscrd, mxtype, nrow, ncol, nnzero, neltvl, ptrfmt, indfmt, valfmt, rhsfmt, rhstyp, nrhs, nrhsix ); fclose ( output ); return; } /******************************************************************************/ void test03 ( char *input_file ) /******************************************************************************/ /* Purpose: TEST03 tests HB_STRUCTURE_READ; Licensing: This code is distributed under the MIT license. Modified: 22 January 2014 Author: John Burkardt */ { int *colptr = NULL; int indcrd; char *indfmt = NULL; FILE *input; char *key = NULL; char *mxtype = NULL; int ncol; int neltvl; int nnzero; int nrhs; int nrhsix; int nrow; int ptrcrd; char *ptrfmt = NULL; int rhscrd; char *rhsfmt = NULL; char *rhstyp = NULL; int *rowind; char *title = NULL; int totcrd; int valcrd; char *valfmt = NULL; printf ( "\n" ); printf ( "TEST03\n" ); printf ( " HB_STRUCTURE_READ reads the structure of an HB file.\n" ); printf ( "\n" ); printf ( " Reading the file '%s'.\n", input_file ); input = fopen ( input_file, "rt" ); if ( !input ) { printf ( "\n" ); printf ( "TEST03 - Warning!\n" ); printf ( " Error opening the file.\n" ); return; } printf ( " Reading the header.\n" ); hb_header_read ( input, &title, &key, &totcrd, &ptrcrd, &indcrd, &valcrd, &rhscrd, &mxtype, &nrow, &ncol, &nnzero, &neltvl, &ptrfmt, &indfmt, &valfmt, &rhsfmt, &rhstyp, &nrhs, &nrhsix ); colptr = ( int * ) malloc ( ( ncol + 1 ) * sizeof ( int ) ); if ( mxtype[2] == 'A' ) { rowind = ( int * ) malloc ( nnzero * sizeof ( int ) ); } else if ( mxtype[2] == 'E' ) { rowind = ( int * ) malloc ( neltvl * sizeof ( int ) ); } else { printf ( "\n" ); printf ( "TEST03 - Warning!\n" ); printf ( " Illegal value of MXTYPE character 3 = '%c'\n", mxtype[2] ); return; } printf ( " Reading the structure.\n" ); hb_structure_read ( input, ncol, mxtype, nnzero, neltvl, ptrcrd, ptrfmt, indcrd, indfmt, colptr, rowind ); fclose ( input ); printf ( "\n" ); printf ( " '%s'\n", title ); printf ( " KEY = '%s'.\n", key ); printf ( "\n" ); printf ( " NROW = %d\n", nrow ); printf ( " NCOL = %d\n", ncol ); printf ( " NNZERO = %d\n", nnzero ); printf ( " NELTVL = %d\n", neltvl ); hb_structure_print ( ncol, mxtype, nnzero, neltvl, colptr, rowind ); free ( colptr ); free ( rowind ); return; } /******************************************************************************/ void test04 ( ) /******************************************************************************/ /* Purpose: TEST04 tests HB_STRUCTURE_WRITE; Licensing: This code is distributed under the MIT license. Modified: 22 January 2014 Author: John Burkardt */ { # define NCOL 32 # define NELTVL 0 # define NNZERO 126 int colptr[NCOL+1] = { 1, 7, 12, 18, 22, 26, 29, 34, 39, 46, 53, 58, 61, 63, 65, 68, 71, 74, 79, 82, 85, 88, 90, 94, 97, 102, 106, 110, 112, 117, 121, 124, 127 }; char indfmt[17] = "(16I5)"; char mxtype[4] = "RUA"; FILE *output; char output_file[] = "rua_32_structure.txt"; char ptrfmt[17] = "(16I5)"; int rowind[NNZERO] = { 1, 2, 3, 4, 7, 26, 1, 2, 9, 21, 28, 2, 3, 6, 8, 9, 29, 3, 4, 5, 12, 3, 5, 23, 27, 1, 6, 16, 3, 7, 14, 21, 31, 1, 8, 12, 17, 27, 7, 9, 10, 13, 19, 23, 27, 1, 10, 11, 21, 23, 25, 27, 2, 11, 15, 18, 29, 6, 12, 24, 11, 13, 3, 14, 2, 15, 20, 4, 16, 22, 4, 16, 17, 6, 10, 18, 20, 30, 1, 19, 26, 8, 16, 20, 3, 21, 32, 11, 22, 2, 17, 21, 23, 12, 24, 26, 6, 15, 18, 24, 25, 13, 18, 22, 26, 5, 24, 26, 27, 9, 28, 3, 5, 27, 29, 32, 12, 17, 23, 30, 13, 14, 31, 24, 28, 32 }; printf ( "\n" ); printf ( "TEST04\n" ); printf ( " HB_STRUCTURE_WRITE writes the structure of an HB file.\n" ); printf ( "\n" ); printf ( " Writing the file '%s'\n", output_file ); output = fopen ( output_file, "wt" ); if ( !output ) { printf ( "\n" ); printf ( "TEST04 - Warning!\n" ); printf ( " Error opening the file.\n" ); return; } hb_structure_write ( output, NCOL, mxtype, NNZERO, NELTVL, ptrfmt, indfmt, colptr, rowind ); fclose ( output ); return; # undef NNZERO # undef NELTVL # undef NCOL } /******************************************************************************/ void test05 ( char *input_file ) /******************************************************************************/ /* Purpose: TEST05 tests HB_VALUES_READ; Licensing: This code is distributed under the MIT license. Modified: 22 January 2014 Author: John Burkardt */ { int *colptr = NULL; int indcrd; char *indfmt = NULL; FILE *input; char *key = NULL; int khi; int klo; char *mxtype = NULL; int ncol; int neltvl; int nnzero; int nrhs; int nrhsix; int nrow; int ptrcrd; char *ptrfmt = NULL; int rhscrd; char *rhsfmt = NULL; char *rhstyp = NULL; int *rowind = NULL; char *title = NULL; int totcrd; int valcrd; char *valfmt = NULL; double *values = NULL; printf ( "\n" ); printf ( "TEST05\n" ); printf ( " HB_VALUES_READ reads the values of an HB file.\n" ); printf ( "\n" ); printf ( " Reading the file '%s'\n", input_file ); input = fopen ( input_file, "rt" ); if ( !input ) { printf ( "\n" ); printf ( "TEST05 - Warning!\n" ); printf ( " Error opening the file.\n" ); return; } printf ( " Reading the header.\n" ); hb_header_read ( input, &title, &key, &totcrd, &ptrcrd, &indcrd, &valcrd, &rhscrd, &mxtype, &nrow, &ncol, &nnzero, &neltvl, &ptrfmt, &indfmt, &valfmt, &rhsfmt, &rhstyp, &nrhs, &nrhsix ); colptr = ( int * ) malloc ( ( ncol + 1 ) * sizeof ( int ) ); if ( mxtype[2] == 'A' ) { rowind = ( int * ) malloc ( nnzero * sizeof ( int ) ); } else if ( mxtype[2] == 'E' ) { rowind = ( int * ) malloc ( neltvl * sizeof ( int ) ); } else { printf ( "\n" ); printf ( "TEST05 - Warning!\n" ); printf ( " Illegal value of MXTYPE character 3.\n" ); return; } printf ( " Reading the structure.\n" ); hb_structure_read ( input, ncol, mxtype, nnzero, neltvl, ptrcrd, ptrfmt, indcrd, indfmt, colptr, rowind ); if ( mxtype[2] == 'A' ) { values = ( double * ) malloc ( nnzero * sizeof ( double ) ); } else if ( mxtype[2] == 'E' ) { values = ( double * ) malloc ( neltvl * sizeof ( double ) ); } else { printf ( "\n" ); printf ( "TEST05 - Warning!\n" ); printf ( " Illegal value of MXTYPE character 3 = '%c'\n", mxtype[2] ); return; } printf ( " Reading the values.\n" ); hb_values_read ( input, valcrd, mxtype, nnzero, neltvl, valfmt, values ); fclose ( input ); printf ( "\n" ); printf ( " '%s'\n", title ); printf ( " KEY = '%s'\n", key ); printf ( "\n" ); printf ( " NROW = %d\n", nrow ); printf ( " NCOL = %d\n", ncol ); printf ( " NNZERO = %d\n", nnzero ); printf ( " NELTVL = %d\n", neltvl ); hb_values_print ( ncol, colptr, mxtype, nnzero, neltvl, values ); free ( colptr ); free ( rowind ); free ( values ); return; } /******************************************************************************/ void test06 ( ) /******************************************************************************/ /* Purpose: TEST06 tests HB_VALUES_WRITE; Licensing: This code is distributed under the MIT license. Modified: 22 January 2014 Author: John Burkardt */ { # define NELTVL 0 # define NNZERO 126 char mxtype[4] = "RUA"; FILE *output; char output_file[] = "rua_32_values.txt"; int valcrd = 13; char valfmt[21] = "(10F7.1)"; double values[NNZERO] = { 101.0, 102.0, 103.0, 104.0, 107.0, 126.0, 201.0, 202.0, 209.0, 221.0, 228.0, 302.0, 303.0, 306.0, 308.0, 309.0, 329.0, 403.0, 404.0, 405.0, 412.0, 503.0, 505.0, 523.0, 527.0, 601.0, 606.0, 616.0, 703.0, 707.0, 714.0, 721.0, 731.0, 801.0, 808.0, 812.0, 817.0, 827.0, 907.0, 909.0, 910.0, 913.0, 919.0, 923.0, 927.0, 1001.0, 1010.0, 1011.0, 1021.0, 1023.0, 1025.0, 1027.0, 1102.0, 1111.0, 1115.0, 1118.0, 1129.0, 1206.0, 1212.0, 1224.0, 1311.0, 1313.0, 1403.0, 1414.0, 1502.0, 1515.0, 1520.0, 1604.0, 1616.0, 1622.0, 1704.0, 1716.0, 1717.0, 1806.0, 1810.0, 1818.0, 1820.0, 1830.0, 1901.0, 1919.0, 1926.0, 2008.0, 2016.0, 2020.0, 2103.0, 2121.0, 2132.0, 2211.0, 2222.0, 2302.0, 2317.0, 2321.0, 2323.0, 2412.0, 2424.0, 2426.0, 2506.0, 2515.0, 2518.0, 2524.0, 2525.0, 2613.0, 2618.0, 2622.0, 2626.0, 2705.0, 2724.0, 2726.0, 2727.0, 2809.0, 2828.0, 2903.0, 2905.0, 2927.0, 2929.0, 2932.0, 3012.0, 3017.0, 3023.0, 3030.0, 3113.0, 3114.0, 3131.0, 3224.0, 3228.0, 3232.0 }; printf ( "\n" ); printf ( "TEST06\n" ); printf ( " HB_VALUES_WRITE writes the values of an HB file.\n" ); printf ( "\n" ); printf ( " Writing the file '%s'\n", output_file ); output = fopen ( output_file, "wt" ); if ( !output ) { printf ( "\n" ); printf ( "TEST06 - Warning!\n" ); printf ( " Error opening the file.\n" ); return; } hb_values_write ( output, valcrd, mxtype, NNZERO, NELTVL, valfmt, values ); fclose ( output ); return; # undef NELTVL # undef NNZERO } /******************************************************************************/ void test07 ( char *input_file ) /******************************************************************************/ /* Purpose: TEST07 tests HB_RHS_READ, HB_GUESS_READ, HB_EXACT_READ; Licensing: This code is distributed under the MIT license. Modified: 22 January 2014 Author: John Burkardt */ { int *colptr = NULL; double *exact = NULL; double *guess = NULL; int i; int indcrd; char *indfmt = NULL; FILE *input; int j; char *key = NULL; int khi; int klo; char *mxtype = NULL; int ncol; int neltvl; int nnzero; int nrhs; int nrhsix; int nrow; int ptrcrd; char *ptrfmt = NULL; int rhscrd; char *rhsfmt = NULL; int *rhsind = NULL; int *rhsptr = NULL; char *rhstyp = NULL; double *rhsval = NULL; double *rhsvec = NULL; int *rowind = NULL; char *title = NULL; int totcrd; int valcrd; char *valfmt = NULL; double *values = NULL; printf ( "\n" ); printf ( "TEST07\n" ); printf ( " HB_RHS_READ reads right hand sides from an HB file.\n" ); printf ( " HB_GUESS_READ reads starting guesses from an HB file.\n" ); printf ( " HB_EXACT_READ reads exact solutions from an HB file.\n" ); printf ( "\n" ); printf ( " Reading the file '%s'\n", input_file ); input = fopen ( input_file, "rt" ); if ( !input ) { printf ( "\n" ); printf ( "TEST07 - Warning!\n" ); printf ( " Error opening the file.\n" ); return; } printf ( " Reading the header.\n" ); hb_header_read ( input, &title, &key, &totcrd, &ptrcrd, &indcrd, &valcrd, &rhscrd, &mxtype, &nrow, &ncol, &nnzero, &neltvl, &ptrfmt, &indfmt, &valfmt, &rhsfmt, &rhstyp, &nrhs, &nrhsix ); colptr = ( int * ) malloc ( ( ncol + 1 ) * sizeof ( int ) ); if ( mxtype[2] == 'A' ) { rowind = ( int * ) malloc ( nnzero * sizeof ( int ) ); } else if ( mxtype[2] == 'E' ) { rowind = ( int * ) malloc ( neltvl * sizeof ( int ) ); } else { printf ( "\n" ); printf ( "TEST07 - Warning!\n" ); printf ( " Illegal value of MXTYPE character 3 = '%c'\n", mxtype[2] ); exit ( 1 ); } printf ( " Reading the structure.\n" ); hb_structure_read ( input, ncol, mxtype, nnzero, neltvl, ptrcrd, ptrfmt, indcrd, indfmt, colptr, rowind ); if ( mxtype[2] == 'A' ) { values = ( double * ) malloc ( nnzero * sizeof ( double ) ); } else if ( mxtype[2] == 'E' ) { values = ( double * ) malloc ( neltvl * sizeof ( double ) ); } else { printf ( "\n" ); printf ( "TEST07 - Warning!\n" ); printf ( " Illegal value of MXTYPE character 3 = '%c'\n", mxtype[2] ); return; } printf ( " Reading the values.\n" ); hb_values_read ( input, valcrd, mxtype, nnzero, neltvl, valfmt, values ); /* Read the right hand sides. */ if ( 0 < rhscrd ) { printf ( " Reading the right hand side.\n" ); if ( rhstyp[0] == 'F' ) { rhsval = ( double * ) malloc ( nrow * nrhs * sizeof ( double ) ); } else if ( rhstyp[0] == 'M' ) { if ( mxtype[2] == 'A' ) { rhsptr = ( int * ) malloc ( ( nrhs + 1 ) * sizeof ( int ) ); rhsind = ( int * ) malloc ( nrhsix * sizeof ( int ) ); rhsvec = ( double * ) malloc ( nrhsix * sizeof ( double ) ); } else if ( mxtype[2] == 'E' ) { rhsval = ( double * ) malloc ( nnzero * nrhs * sizeof ( double ) ); } } hb_rhs_read ( input, nrow, nnzero, nrhs, nrhsix, rhscrd, ptrfmt, indfmt, rhsfmt, mxtype, rhstyp, rhsval, rhsind, rhsptr, rhsvec ); printf ( " Done reading the right hand side.\n" ); if ( rhstyp[0] == 'F' ) { r8mat_print_some ( nrow, nrhs, rhsval, 1, 1, 5, 5, " Part of RHS" ); } else if ( rhstyp[0] == 'M' && mxtype[2] == 'A' ) { i4vec_print_part ( nrhs+1, rhsptr, 10, " Part of RHSPTR" ); i4vec_print_part ( nrhsix, rhsind, 10, " Part of RHSIND" ); r8vec_print_part ( nrhsix, rhsvec, 10, " Part of RHSVEC" ); } else if ( rhstyp[0] == 'M' && mxtype[2] == 'E' ) { r8mat_print_some ( nnzero, nrhs, rhsval, 1, 1, 5, 5, " Part of RHS" ); } /* Read the starting guesses. */ if ( rhstyp[1] == 'G' ) { printf ( " Reading the starting guesses.\n" ); guess = ( double * ) malloc ( nrow * nrhs * sizeof ( double ) ); hb_guess_read ( input, nrow, nrhs, rhscrd, rhsfmt, rhstyp, guess ); r8mat_print_some ( nrow, nrhs, guess, 1, 1, 5, 5, " Part of GUESS" ); } /* Read the exact solutions. */ if ( rhstyp[2] == 'X' ) { printf ( " Reading the exact solutions.\n" ); exact = ( double * ) malloc ( nrow * nrhs * sizeof ( double ) ); hb_exact_read ( input, nrow, nrhs, rhscrd, rhsfmt, rhstyp, exact ); r8mat_print_some ( nrow, nrhs, exact, 1, 1, 5, 5, " Part of EXACT" ); } } fclose ( input ); if ( colptr ) { free ( colptr ); } if ( exact ) { free ( exact ); } if ( guess ) { free ( guess ); } if ( rhsind ) { free ( rhsind ); } if ( rhsptr ) { free ( rhsptr ); } if ( rhsval ) { free ( rhsval ); } if ( rhsvec ) { free ( rhsvec ); } if ( rowind ) { free ( rowind ); } if ( values ) { free ( values ); } return; } /******************************************************************************/ void test08 ( ) /******************************************************************************/ /* Purpose: TEST08 tests HB_RHS_WRITE, HB_GUESS_WRITE, HB_EXACT_WRITE; Licensing: This code is distributed under the MIT license. Modified: 22 January 2014 Author: John Burkardt */ { # define NELTVL 0 # define NNZERO 126 # define NRHS 1 # define NRHSIX 0 # define NROW 32 double exact[NROW*NRHS] = { 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0, 10.0, 11.0, 12.0, 13.0, 14.0, 15.0, 16.0, 17.0, 18.0, 19.0, 20.0, 21.0, 22.0, 23.0, 24.0, 25.0, 26.0, 27.0, 28.0, 29.0, 30.0, 31.0, 32.0 }; double guess[NROW*NRHS] = { 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0 }; char indfmt[17] = "(16I5)"; char mxtype[4] = "RUA"; FILE *output; char output_file[] = "rua_32_rhs.txt"; char ptrfmt[17] = "(16I5)"; int rhscrd = 12; char rhsfmt[21] = "(10F7.1)"; int *rhsind = NULL; int *rhsptr = NULL; double rhsval[NROW*NRHS] = { 101.0, 102.0, 103.0, 104.0, 107.0, 126.0, 201.0, 202.0, 209.0, 221.0, 228.0, 302.0, 303.0, 306.0, 308.0, 309.0, 329.0, 403.0, 404.0, 405.0, 412.0, 503.0, 505.0, 523.0, 527.0, 601.0, 606.0, 616.0, 703.0, 707.0, 714.0, 721.0 }; double *rhsvec = NULL; char rhstyp[4] = "FGX"; printf ( "\n" ); printf ( "TEST08\n" ); printf ( " HB_RHS_WRITE writes the right hand sides to an HB file.\n" ); printf ( " HB_GUESS_WRITE writes starting guesses to an HB file.\n" ); printf ( " HB_EXACT_WRITE writes exact solutions to an HB file.\n" ); printf ( "\n" ); printf ( " Writing the file '%s'\n", output_file ); output = fopen ( output_file, "wt" ); if ( !output ) { printf ( "\n" ); printf ( "TEST08 - Warning!\n" ); printf ( " Error opening the file.\n" ); return; } /* Write the right hand sides. */ hb_rhs_write ( output, NROW, NNZERO, NRHS, NRHSIX, rhscrd, ptrfmt, indfmt, rhsfmt, mxtype, rhstyp, rhsval, rhsind, rhsptr, rhsvec ); /* Write the right hand sides. */ hb_guess_write ( output, NROW, NRHS, rhscrd, rhsfmt, rhstyp, guess ); /* Write the right hand sides. */ hb_exact_write ( output, NROW, NRHS, rhscrd, rhsfmt, rhstyp, exact ); fclose ( output ); return; # undef NELTVL # undef NNZERO # undef NRHS # undef NRHSIX # undef NROW } /******************************************************************************/ void test09 ( char *input_file ) /******************************************************************************/ /* Purpose: TEST09 tests HB_FILE_READ; Licensing: This code is distributed under the MIT license. Modified: 22 January 2014 Author: John Burkardt */ { int *colptr = NULL; double *exact = NULL; double *guess = NULL; int i; int indcrd; char *indfmt = NULL; FILE *input; int j; char *key = NULL; int khi; int klo; char *mxtype = NULL; int ncol; int neltvl; int nnzero; int nrhs; int nrhsix; int nrow; int ptrcrd; char *ptrfmt = NULL; int rhscrd; char *rhsfmt = NULL; int *rhsind = NULL; int *rhsptr = NULL; char *rhstyp = NULL; double *rhsval = NULL; double *rhsvec = NULL; int *rowind = NULL; char *title = NULL; int totcrd; int valcrd; char *valfmt = NULL; double *values = NULL; printf ( "\n" ); printf ( "TEST09\n" ); printf ( " HB_FILE_READ reads all the data in an HB file.\n" ); printf ( " HB_FILE_MODULE is the module that stores the data.\n" ); printf ( "\n" ); printf ( " Reading the file '%s'\n", input_file ); input = fopen ( input_file, "rt" ); if ( !input ) { printf ( "\n" ); printf ( "TEST09 - Warning!\n" ); printf ( " Error opening the file.\n" ); return; } hb_file_read ( input, &title, &key, &totcrd, &ptrcrd, &indcrd, &valcrd, &rhscrd, &mxtype, &nrow, &ncol, &nnzero, &neltvl, &ptrfmt, &indfmt, &valfmt, &rhsfmt, &rhstyp, &nrhs, &nrhsix, &colptr, &rowind, &values, &rhsval, &rhsptr, &rhsind, &rhsvec, &guess, &exact ); /* Print out the header information. */ hb_header_print ( title, key, totcrd, ptrcrd, indcrd, valcrd, rhscrd, mxtype, nrow, ncol, nnzero, neltvl, ptrfmt, indfmt, valfmt, rhsfmt, rhstyp, nrhs, nrhsix ); /* Print the structure information. */ hb_structure_print ( ncol, mxtype, nnzero, neltvl, colptr, rowind ); /* Print the values. */ hb_values_print ( ncol, colptr, mxtype, nnzero, neltvl, values ); if ( 0 < rhscrd ) { /* Print a bit of the right hand sides. */ if ( rhstyp[0] == 'F' ) { r8mat_print_some ( nrow, nrhs, rhsval, 1, 1, 5, 5, " Part of RHS" ); } else if ( rhstyp[0] == 'M' && mxtype[2] == 'A' ) { i4vec_print_part ( nrhs+1, rhsptr, 10, " Part of RHSPTR" ); i4vec_print_part ( nrhsix, rhsind, 10, " Part of RHSIND" ); r8vec_print_part ( nrhsix, rhsvec, 10, " Part of RHSVEC" ); } else if ( rhstyp[0] == 'M' && mxtype[2] == 'E' ) { r8mat_print_some ( nnzero, nrhs, rhsval, 1, 1, 5, 5, " Part of RHS" ); } /* Print a bit of the starting guesses. */ if ( rhstyp[1] == 'G' ) { r8mat_print_some ( nrow, nrhs, guess, 1, 1, 5, 5, " Part of GUESS" ); } /* Print a bit of the exact solutions. */ if ( rhstyp[2] == 'X' ) { r8mat_print_some ( nrow, nrhs, exact, 1, 1, 5, 5, " Part of EXACT" ); } } fclose ( input ); if ( colptr ) { free ( colptr ); } if ( exact ) { free ( exact ); } if ( guess ) { free ( guess ); } if ( rhsind ) { free ( rhsind ); } if ( rhsptr ) { free ( rhsptr ); } if ( rhsval ) { free ( rhsval ); } if ( rhsvec ) { free ( rhsvec ); } if ( rowind ) { free ( rowind ); } if ( values ) { free ( values ); } return; } /******************************************************************************/ void test10 ( ) /******************************************************************************/ /* Purpose: TEST10 tests HB_FILE_WRITE; Licensing: This code is distributed under the MIT license. Modified: 22 January 2014 Author: John Burkardt */ { # define NCOL 32 # define NELTVL 0 # define NNZERO 126 # define NRHS 1 # define NRHSIX 0 # define NROW 32 int colptr[NCOL+1] = { 1, 7, 12, 18, 22, 26, 29, 34, 39, 46, 53, 58, 61, 63, 65, 68, 71, 74, 79, 82, 85, 88, 90, 94, 97, 102, 106, 110, 112, 117, 121, 124, 127 }; double exact[NROW*NRHS] = { 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0, 10.0, 11.0, 12.0, 13.0, 14.0, 15.0, 16.0, 17.0, 18.0, 19.0, 20.0, 21.0, 22.0, 23.0, 24.0, 25.0, 26.0, 27.0, 28.0, 29.0, 30.0, 31.0, 32.0 }; double guess[NROW*NRHS] = { 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0 }; int indcrd = 8; char indfmt[17] = "(16I5)"; char key[9] = "RUA_32"; char mxtype[4] = "RUA"; char output_file[] = "rua_32_file.txt"; FILE *output; int ptrcrd = 3; char ptrfmt[17] = "(16I5)"; int rhscrd = 12; char rhsfmt[21] = "(10F7.1)"; int *rhsind = NULL; int *rhsptr = NULL; double rhsval[NROW*NRHS] = { 101.0, 102.0, 103.0, 104.0, 107.0, 126.0, 201.0, 202.0, 209.0, 221.0, 228.0, 302.0, 303.0, 306.0, 308.0, 309.0, 329.0, 403.0, 404.0, 405.0, 412.0, 503.0, 505.0, 523.0, 527.0, 601.0, 606.0, 616.0, 703.0, 707.0, 714.0, 721.0 }; char rhstyp[4] = "FGX"; double *rhsvec = NULL; int rowind[NNZERO] = { 1, 2, 3, 4, 7, 26, 1, 2, 9, 21, 28, 2, 3, 6, 8, 9, 29, 3, 4, 5, 12, 3, 5, 23, 27, 1, 6, 16, 3, 7, 14, 21, 31, 1, 8, 12, 17, 27, 7, 9, 10, 13, 19, 23, 27, 1, 10, 11, 21, 23, 25, 27, 2, 11, 15, 18, 29, 6, 12, 24, 11, 13, 3, 14, 2, 15, 20, 4, 16, 22, 4, 16, 17, 6, 10, 18, 20, 30, 1, 19, 26, 8, 16, 20, 3, 21, 32, 11, 22, 2, 17, 21, 23, 12, 24, 26, 6, 15, 18, 24, 25, 13, 18, 22, 26, 5, 24, 26, 27, 9, 28, 3, 5, 27, 29, 32, 12, 17, 23, 30, 13, 14, 31, 24, 28, 32 }; char title[73] = "1Real unsymmetric assembled matrix based on IBM32"; int totcrd = 36; int valcrd = 13; char valfmt[21] = "(10F7.1)"; double values[NNZERO] = { 101.0, 102.0, 103.0, 104.0, 107.0, 126.0, 201.0, 202.0, 209.0, 221.0, 228.0, 302.0, 303.0, 306.0, 308.0, 309.0, 329.0, 403.0, 404.0, 405.0, 412.0, 503.0, 505.0, 523.0, 527.0, 601.0, 606.0, 616.0, 703.0, 707.0, 714.0, 721.0, 731.0, 801.0, 808.0, 812.0, 817.0, 827.0, 907.0, 909.0, 910.0, 913.0, 919.0, 923.0, 927.0, 1001.0, 1010.0, 1011.0, 1021.0, 1023.0, 1025.0, 1027.0, 1102.0, 1111.0, 1115.0, 1118.0, 1129.0, 1206.0, 1212.0, 1224.0, 1311.0, 1313.0, 1403.0, 1414.0, 1502.0, 1515.0, 1520.0, 1604.0, 1616.0, 1622.0, 1704.0, 1716.0, 1717.0, 1806.0, 1810.0, 1818.0, 1820.0, 1830.0, 1901.0, 1919.0, 1926.0, 2008.0, 2016.0, 2020.0, 2103.0, 2121.0, 2132.0, 2211.0, 2222.0, 2302.0, 2317.0, 2321.0, 2323.0, 2412.0, 2424.0, 2426.0, 2506.0, 2515.0, 2518.0, 2524.0, 2525.0, 2613.0, 2618.0, 2622.0, 2626.0, 2705.0, 2724.0, 2726.0, 2727.0, 2809.0, 2828.0, 2903.0, 2905.0, 2927.0, 2929.0, 2932.0, 3012.0, 3017.0, 3023.0, 3030.0, 3113.0, 3114.0, 3131.0, 3224.0, 3228.0, 3232.0 }; printf ( "\n" ); printf ( "TEST10\n" ); printf ( " HB_FILE_WRITE writes an HB file.\n" ); printf ( "\n" ); printf ( " Writing the file '%s'\n", output_file ); output = fopen ( output_file, "wt" ); if ( !output ) { printf ( "\n" ); printf ( "TEST10 - Warning!\n" ); printf ( " Error opening the file.\n" ); return; } hb_file_write ( output, title, key, totcrd, ptrcrd, indcrd, valcrd, rhscrd, mxtype, NROW, NCOL, NNZERO, NELTVL, ptrfmt, indfmt, valfmt, rhsfmt, rhstyp, NRHS, NRHSIX, colptr, rowind, values, rhsval, rhsptr, rhsind, rhsvec, guess, exact ); fclose ( output ); return; # undef NCOL # undef NELTVL # undef NNZERO # undef NRHS # undef NRHSIX # undef NROW } /******************************************************************************/ void test11 ( ) /******************************************************************************/ /* Purpose: TEST11 tests HB_FILE_WRITE; Licensing: This code is distributed under the MIT license. Modified: 22 January 2014 Author: John Burkardt */ { # define NCOL 32 # define NELTVL 0 # define NNZERO 126 # define NRHS 2 # define NRHSIX 0 # define NROW 32 int colptr[NCOL+1] = { 1, 7, 12, 18, 22, 26, 29, 34, 39, 46, 53, 58, 61, 63, 65, 68, 71, 74, 79, 82, 85, 88, 90, 94, 97, 102, 106, 110, 112, 117, 121, 124, 127 }; double exact[NROW*NRHS] = { 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0 }; double guess[NROW*NRHS] = { 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0 }; int indcrd = 8; char indfmt[17] = "(16I5)"; char key[9] = "RUA_32"; char mxtype[4] = "RUA"; char output_file[] = "rua_32_ax.txt"; FILE *output; int ptrcrd = 3; char ptrfmt[17] = "(16I5)"; int rhscrd = 12; char rhsfmt[21] = "(10F7.1)"; int *rhsind = NULL; int *rhsptr = NULL; double *rhsval; char rhstyp[4] = "FGX"; double *rhsvec = NULL; int rowind[NNZERO] = { 1, 2, 3, 4, 7, 26, 1, 2, 9, 21, 28, 2, 3, 6, 8, 9, 29, 3, 4, 5, 12, 3, 5, 23, 27, 1, 6, 16, 3, 7, 14, 21, 31, 1, 8, 12, 17, 27, 7, 9, 10, 13, 19, 23, 27, 1, 10, 11, 21, 23, 25, 27, 2, 11, 15, 18, 29, 6, 12, 24, 11, 13, 3, 14, 2, 15, 20, 4, 16, 22, 4, 16, 17, 6, 10, 18, 20, 30, 1, 19, 26, 8, 16, 20, 3, 21, 32, 11, 22, 2, 17, 21, 23, 12, 24, 26, 6, 15, 18, 24, 25, 13, 18, 22, 26, 5, 24, 26, 27, 9, 28, 3, 5, 27, 29, 32, 12, 17, 23, 30, 13, 14, 31, 24, 28, 32 }; char title[73] = "1Real unsymmetric assembled matrix based on IBM32"; int totcrd = 36; int valcrd = 13; char valfmt[21] = "(10F7.1)"; double values[NNZERO] = { 101.0, 102.0, 103.0, 104.0, 107.0, 126.0, 201.0, 202.0, 209.0, 221.0, 228.0, 302.0, 303.0, 306.0, 308.0, 309.0, 329.0, 403.0, 404.0, 405.0, 412.0, 503.0, 505.0, 523.0, 527.0, 601.0, 606.0, 616.0, 703.0, 707.0, 714.0, 721.0, 731.0, 801.0, 808.0, 812.0, 817.0, 827.0, 907.0, 909.0, 910.0, 913.0, 919.0, 923.0, 927.0, 1001.0, 1010.0, 1011.0, 1021.0, 1023.0, 1025.0, 1027.0, 1102.0, 1111.0, 1115.0, 1118.0, 1129.0, 1206.0, 1212.0, 1224.0, 1311.0, 1313.0, 1403.0, 1414.0, 1502.0, 1515.0, 1520.0, 1604.0, 1616.0, 1622.0, 1704.0, 1716.0, 1717.0, 1806.0, 1810.0, 1818.0, 1820.0, 1830.0, 1901.0, 1919.0, 1926.0, 2008.0, 2016.0, 2020.0, 2103.0, 2121.0, 2132.0, 2211.0, 2222.0, 2302.0, 2317.0, 2321.0, 2323.0, 2412.0, 2424.0, 2426.0, 2506.0, 2515.0, 2518.0, 2524.0, 2525.0, 2613.0, 2618.0, 2622.0, 2626.0, 2705.0, 2724.0, 2726.0, 2727.0, 2809.0, 2828.0, 2903.0, 2905.0, 2927.0, 2929.0, 2932.0, 3012.0, 3017.0, 3023.0, 3030.0, 3113.0, 3114.0, 3131.0, 3224.0, 3228.0, 3232.0 }; printf ( "\n" ); printf ( "TEST11\n" ); printf ( " HB_MATVEC_A_MEM multiplies a matrix times a vector.\n" ); printf ( "\n" ); printf ( " This particular version assumes:\n" ); printf ( " * the matrix is in ""A"" format (assembled),\n" ); printf ( " * the matrix and vectors can fit in memory,\n" ); printf ( " * the matrix and multiplicand have been read into\n" ); printf ( " memory before the routine is called.\n" ); printf ( "\n" ); printf ( " For this example, the first vector X is zero except\n" ); printf ( " for a 1 in row 10. This means A*X should return\n" ); printf ( " column 10 of A.\n" ); printf ( "\n" ); printf ( " The second vector X is all 1's. A*X should be\n" ); printf ( " the sum of the entries of each row.\n" ); rhsval = hb_matvec_a_mem ( NROW, NCOL, NNZERO, NRHS, colptr, rowind, values, exact ); r8mat_print ( NROW, NRHS, rhsval, " The product vectors A*X" ); printf ( "\n" ); printf ( " Writing the file '%s'\n", output_file ); output = fopen ( output_file, "wt" ); if ( !output ) { printf ( "\n" ); printf ( "TEST11 - Warning!\n" ); printf ( " Error opening the file.\n" ); return; } hb_file_write ( output, title, key, totcrd, ptrcrd, indcrd, valcrd, rhscrd, mxtype, NROW, NCOL, NNZERO, NELTVL, ptrfmt, indfmt, valfmt, rhsfmt, rhstyp, NRHS, NRHSIX, colptr, rowind, values, rhsval, rhsptr, rhsind, rhsvec, guess, exact ); fclose ( output ); free ( rhsval ); return; # undef NCOL # undef NELTVL # undef NNZERO # undef NRHS # undef NRHSIX # undef NROW } /******************************************************************************/ void test12 ( ) /******************************************************************************/ /* Purpose: TEST12 tests HB_FILE_WRITE; Licensing: This code is distributed under the MIT license. Modified: 22 January 2014 Author: John Burkardt */ { # define NCOL 32 # define NELTVL 0 # define NNZERO 126 # define NRHS 2 # define NRHSIX 0 # define NROW 32 int colptr[NCOL+1] = { 1, 7, 12, 18, 22, 26, 29, 34, 39, 46, 53, 58, 61, 63, 65, 68, 71, 74, 79, 82, 85, 88, 90, 94, 97, 102, 106, 110, 112, 117, 121, 124, 127 }; double exact[NROW*NRHS] = { 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0 }; double guess[NROW*NRHS] = { 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0 }; int indcrd = 8; char indfmt[17] = "(16I5)"; char key[9] = "RUA_32"; char mxtype[4] = "RUA"; char output_file[] = "rua_32_xa.txt"; FILE *output; int ptrcrd = 3; char ptrfmt[17] = "(16I5)"; int rhscrd = 12; char rhsfmt[21] = "(10F7.1)"; int *rhsind = NULL; int *rhsptr = NULL; double *rhsval; char rhstyp[4] = "FGX"; double *rhsvec = NULL; int rowind[NNZERO] = { 1, 2, 3, 4, 7, 26, 1, 2, 9, 21, 28, 2, 3, 6, 8, 9, 29, 3, 4, 5, 12, 3, 5, 23, 27, 1, 6, 16, 3, 7, 14, 21, 31, 1, 8, 12, 17, 27, 7, 9, 10, 13, 19, 23, 27, 1, 10, 11, 21, 23, 25, 27, 2, 11, 15, 18, 29, 6, 12, 24, 11, 13, 3, 14, 2, 15, 20, 4, 16, 22, 4, 16, 17, 6, 10, 18, 20, 30, 1, 19, 26, 8, 16, 20, 3, 21, 32, 11, 22, 2, 17, 21, 23, 12, 24, 26, 6, 15, 18, 24, 25, 13, 18, 22, 26, 5, 24, 26, 27, 9, 28, 3, 5, 27, 29, 32, 12, 17, 23, 30, 13, 14, 31, 24, 28, 32 }; char title[73] = "1Real unsymmetric assembled matrix based on IBM32"; int totcrd = 36; int valcrd = 13; char valfmt[21] = "(10F7.1)"; double values[NNZERO] = { 101.0, 102.0, 103.0, 104.0, 107.0, 126.0, 201.0, 202.0, 209.0, 221.0, 228.0, 302.0, 303.0, 306.0, 308.0, 309.0, 329.0, 403.0, 404.0, 405.0, 412.0, 503.0, 505.0, 523.0, 527.0, 601.0, 606.0, 616.0, 703.0, 707.0, 714.0, 721.0, 731.0, 801.0, 808.0, 812.0, 817.0, 827.0, 907.0, 909.0, 910.0, 913.0, 919.0, 923.0, 927.0, 1001.0, 1010.0, 1011.0, 1021.0, 1023.0, 1025.0, 1027.0, 1102.0, 1111.0, 1115.0, 1118.0, 1129.0, 1206.0, 1212.0, 1224.0, 1311.0, 1313.0, 1403.0, 1414.0, 1502.0, 1515.0, 1520.0, 1604.0, 1616.0, 1622.0, 1704.0, 1716.0, 1717.0, 1806.0, 1810.0, 1818.0, 1820.0, 1830.0, 1901.0, 1919.0, 1926.0, 2008.0, 2016.0, 2020.0, 2103.0, 2121.0, 2132.0, 2211.0, 2222.0, 2302.0, 2317.0, 2321.0, 2323.0, 2412.0, 2424.0, 2426.0, 2506.0, 2515.0, 2518.0, 2524.0, 2525.0, 2613.0, 2618.0, 2622.0, 2626.0, 2705.0, 2724.0, 2726.0, 2727.0, 2809.0, 2828.0, 2903.0, 2905.0, 2927.0, 2929.0, 2932.0, 3012.0, 3017.0, 3023.0, 3030.0, 3113.0, 3114.0, 3131.0, 3224.0, 3228.0, 3232.0 }; printf ( "\n" ); printf ( "TEST12\n" ); printf ( " HB_VECMAT_A_MEM multiplies a vector times a matrix.\n" ); printf ( "\n" ); printf ( " This particular version assumes:\n" ); printf ( " * the matrix is in ""A"" format (assembled),\n" ); printf ( " * the matrix and vectors can fit in memory,\n" ); printf ( " * the matrix and multiplicand have been read into\n" ); printf ( " memory before the routine is called.\n" ); printf ( "\n" ); printf ( " For this example, the first vector X is zero except\n" ); printf ( " for a 1 in row 10. This means A'*X should return\n" ); printf ( " row 10 of A.\n" ); printf ( "\n" ); printf ( " The second vector X is all 1's. A'*X should be\n" ); printf ( " the sum of the entries of each column.\n" ); rhsval = hb_vecmat_a_mem ( NROW, NCOL, NNZERO, NRHS, colptr, rowind, values, exact ); r8mat_print ( NCOL, NRHS, rhsval, " The product vectors A'*X" ); printf ( "\n" ); printf ( " Writing the file '%s'\n", output_file ); output = fopen ( output_file, "wt" ); if ( !output ) { printf ( "\n" ); printf ( "TEST12 - Warning!\n" ); printf ( " Error opening the file.\n" ); return; } hb_file_write ( output, title, key, totcrd, ptrcrd, indcrd, valcrd, rhscrd, mxtype, NROW, NCOL, NNZERO, NELTVL, ptrfmt, indfmt, valfmt, rhsfmt, rhstyp, NRHS, NRHSIX, colptr, rowind, values, rhsval, rhsptr, rhsind, rhsvec, guess, exact ); fclose ( output ); free ( rhsval ); return; # undef NCOL # undef NELTVL # undef NNZERO # undef NRHS # undef NRHSIX # undef NROW }