00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 
00009 
00010 
00011 
00012 
00013 
00014 
00015 
00016 
00017 
00018 
00019 
00020 
00021 
00022 
00023 
00024 
00025 
00026 
00027 
00028 
00029 
00030 
00031 
00032 
00033 
00034 #include "lapacke.h"
00035 #include "lapacke_utils.h"
00036 
00037 lapack_int LAPACKE_zporfs( int matrix_order, char uplo, lapack_int n,
00038                            lapack_int nrhs, const lapack_complex_double* a,
00039                            lapack_int lda, const lapack_complex_double* af,
00040                            lapack_int ldaf, const lapack_complex_double* b,
00041                            lapack_int ldb, lapack_complex_double* x,
00042                            lapack_int ldx, double* ferr, double* berr )
00043 {
00044     lapack_int info = 0;
00045     double* rwork = NULL;
00046     lapack_complex_double* work = NULL;
00047     if( matrix_order != LAPACK_COL_MAJOR && matrix_order != LAPACK_ROW_MAJOR ) {
00048         LAPACKE_xerbla( "LAPACKE_zporfs", -1 );
00049         return -1;
00050     }
00051 #ifndef LAPACK_DISABLE_NAN_CHECK
00052     
00053     if( LAPACKE_zpo_nancheck( matrix_order, uplo, n, a, lda ) ) {
00054         return -5;
00055     }
00056     if( LAPACKE_zpo_nancheck( matrix_order, uplo, n, af, ldaf ) ) {
00057         return -7;
00058     }
00059     if( LAPACKE_zge_nancheck( matrix_order, n, nrhs, b, ldb ) ) {
00060         return -9;
00061     }
00062     if( LAPACKE_zge_nancheck( matrix_order, n, nrhs, x, ldx ) ) {
00063         return -11;
00064     }
00065 #endif
00066     
00067     rwork = (double*)LAPACKE_malloc( sizeof(double) * MAX(1,n) );
00068     if( rwork == NULL ) {
00069         info = LAPACK_WORK_MEMORY_ERROR;
00070         goto exit_level_0;
00071     }
00072     work = (lapack_complex_double*)
00073         LAPACKE_malloc( sizeof(lapack_complex_double) * MAX(1,2*n) );
00074     if( work == NULL ) {
00075         info = LAPACK_WORK_MEMORY_ERROR;
00076         goto exit_level_1;
00077     }
00078     
00079     info = LAPACKE_zporfs_work( matrix_order, uplo, n, nrhs, a, lda, af, ldaf,
00080                                 b, ldb, x, ldx, ferr, berr, work, rwork );
00081     
00082     LAPACKE_free( work );
00083 exit_level_1:
00084     LAPACKE_free( rwork );
00085 exit_level_0:
00086     if( info == LAPACK_WORK_MEMORY_ERROR ) {
00087         LAPACKE_xerbla( "LAPACKE_zporfs", info );
00088     }
00089     return info;
00090 }