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_cgesvxx( int matrix_order, char fact, char trans,
00038                             lapack_int n, lapack_int nrhs,
00039                             lapack_complex_float* a, lapack_int lda,
00040                             lapack_complex_float* af, lapack_int ldaf,
00041                             lapack_int* ipiv, char* equed, float* r, float* c,
00042                             lapack_complex_float* b, lapack_int ldb,
00043                             lapack_complex_float* x, lapack_int ldx,
00044                             float* rcond, float* rpvgrw, float* berr,
00045                             lapack_int n_err_bnds, float* err_bnds_norm,
00046                             float* err_bnds_comp, lapack_int nparams,
00047                             float* params )
00048 {
00049     lapack_int info = 0;
00050     float* rwork = NULL;
00051     lapack_complex_float* work = NULL;
00052     if( matrix_order != LAPACK_COL_MAJOR && matrix_order != LAPACK_ROW_MAJOR ) {
00053         LAPACKE_xerbla( "LAPACKE_cgesvxx", -1 );
00054         return -1;
00055     }
00056 #ifndef LAPACK_DISABLE_NAN_CHECK
00057     
00058     if( LAPACKE_cge_nancheck( matrix_order, n, n, a, lda ) ) {
00059         return -6;
00060     }
00061     if( LAPACKE_lsame( fact, 'f' ) ) {
00062         if( LAPACKE_cge_nancheck( matrix_order, n, n, af, ldaf ) ) {
00063             return -8;
00064         }
00065     }
00066     if( LAPACKE_cge_nancheck( matrix_order, n, nrhs, b, ldb ) ) {
00067         return -14;
00068     }
00069     if( LAPACKE_lsame( fact, 'f' ) && ( LAPACKE_lsame( *equed, 'b' ) ||
00070         LAPACKE_lsame( *equed, 'c' ) ) ) {
00071         if( LAPACKE_s_nancheck( n, c, 1 ) ) {
00072             return -13;
00073         }
00074     }
00075     if( nparams>0 ) {
00076         if( LAPACKE_s_nancheck( nparams, params, 1 ) ) {
00077             return -25;
00078         }
00079     }
00080     if( LAPACKE_lsame( fact, 'f' ) && ( LAPACKE_lsame( *equed, 'b' ) ||
00081         LAPACKE_lsame( *equed, 'r' ) ) ) {
00082         if( LAPACKE_s_nancheck( n, r, 1 ) ) {
00083             return -12;
00084         }
00085     }
00086 #endif
00087     
00088     rwork = (float*)LAPACKE_malloc( sizeof(float) * MAX(1,3*n) );
00089     if( rwork == NULL ) {
00090         info = LAPACK_WORK_MEMORY_ERROR;
00091         goto exit_level_0;
00092     }
00093     work = (lapack_complex_float*)
00094         LAPACKE_malloc( sizeof(lapack_complex_float) * MAX(1,2*n) );
00095     if( work == NULL ) {
00096         info = LAPACK_WORK_MEMORY_ERROR;
00097         goto exit_level_1;
00098     }
00099     
00100     info = LAPACKE_cgesvxx_work( matrix_order, fact, trans, n, nrhs, a, lda, af,
00101                                  ldaf, ipiv, equed, r, c, b, ldb, x, ldx, rcond,
00102                                  rpvgrw, berr, n_err_bnds, err_bnds_norm,
00103                                  err_bnds_comp, nparams, params, work, rwork );
00104     
00105     LAPACKE_free( work );
00106 exit_level_1:
00107     LAPACKE_free( rwork );
00108 exit_level_0:
00109     if( info == LAPACK_WORK_MEMORY_ERROR ) {
00110         LAPACKE_xerbla( "LAPACKE_cgesvxx", info );
00111     }
00112     return info;
00113 }