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_cgbsvxx( int matrix_order, char fact, char trans,
00038                             lapack_int n, lapack_int kl, lapack_int ku,
00039                             lapack_int nrhs, lapack_complex_float* ab,
00040                             lapack_int ldab, lapack_complex_float* afb,
00041                             lapack_int ldafb, lapack_int* ipiv, char* equed,
00042                             float* r, float* c, lapack_complex_float* b,
00043                             lapack_int ldb, lapack_complex_float* x,
00044                             lapack_int ldx, float* rcond, float* rpvgrw,
00045                             float* berr, lapack_int n_err_bnds,
00046                             float* err_bnds_norm, float* err_bnds_comp,
00047                             lapack_int nparams, 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_cgbsvxx", -1 );
00054         return -1;
00055     }
00056 #ifndef LAPACK_DISABLE_NAN_CHECK
00057     
00058     if( LAPACKE_cgb_nancheck( matrix_order, n, n, kl, ku, ab, ldab ) ) {
00059         return -8;
00060     }
00061     if( LAPACKE_lsame( fact, 'f' ) ) {
00062         if( LAPACKE_cgb_nancheck( matrix_order, n, n, kl, kl+ku, afb,
00063             ldafb ) ) {
00064             return -10;
00065         }
00066     }
00067     if( LAPACKE_cge_nancheck( matrix_order, n, nrhs, b, ldb ) ) {
00068         return -16;
00069     }
00070     if( LAPACKE_lsame( fact, 'f' ) && ( LAPACKE_lsame( *equed, 'b' ) ||
00071         LAPACKE_lsame( *equed, 'c' ) ) ) {
00072         if( LAPACKE_s_nancheck( n, c, 1 ) ) {
00073             return -15;
00074         }
00075     }
00076     if( nparams>0 ) {
00077         if( LAPACKE_s_nancheck( nparams, params, 1 ) ) {
00078             return -27;
00079         }
00080     }
00081     if( LAPACKE_lsame( fact, 'f' ) && ( LAPACKE_lsame( *equed, 'b' ) ||
00082         LAPACKE_lsame( *equed, 'r' ) ) ) {
00083         if( LAPACKE_s_nancheck( n, r, 1 ) ) {
00084             return -14;
00085         }
00086     }
00087 #endif
00088     
00089     rwork = (float*)LAPACKE_malloc( sizeof(float) * MAX(1,3*n) );
00090     if( rwork == NULL ) {
00091         info = LAPACK_WORK_MEMORY_ERROR;
00092         goto exit_level_0;
00093     }
00094     work = (lapack_complex_float*)
00095         LAPACKE_malloc( sizeof(lapack_complex_float) * MAX(1,2*n) );
00096     if( work == NULL ) {
00097         info = LAPACK_WORK_MEMORY_ERROR;
00098         goto exit_level_1;
00099     }
00100     
00101     info = LAPACKE_cgbsvxx_work( matrix_order, fact, trans, n, kl, ku, nrhs, ab,
00102                                  ldab, afb, ldafb, ipiv, equed, r, c, b, ldb, x,
00103                                  ldx, rcond, rpvgrw, berr, n_err_bnds,
00104                                  err_bnds_norm, err_bnds_comp, nparams, params,
00105                                  work, rwork );
00106     
00107     LAPACKE_free( work );
00108 exit_level_1:
00109     LAPACKE_free( rwork );
00110 exit_level_0:
00111     if( info == LAPACK_WORK_MEMORY_ERROR ) {
00112         LAPACKE_xerbla( "LAPACKE_cgbsvxx", info );
00113     }
00114     return info;
00115 }