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_dgbrfsx( int matrix_order, char trans, char equed,
00038                             lapack_int n, lapack_int kl, lapack_int ku,
00039                             lapack_int nrhs, const double* ab, lapack_int ldab,
00040                             const double* afb, lapack_int ldafb,
00041                             const lapack_int* ipiv, const double* r,
00042                             const double* c, const double* b, lapack_int ldb,
00043                             double* x, lapack_int ldx, double* rcond,
00044                             double* berr, lapack_int n_err_bnds,
00045                             double* err_bnds_norm, double* err_bnds_comp,
00046                             lapack_int nparams, double* params )
00047 {
00048     lapack_int info = 0;
00049     lapack_int* iwork = NULL;
00050     double* work = NULL;
00051     if( matrix_order != LAPACK_COL_MAJOR && matrix_order != LAPACK_ROW_MAJOR ) {
00052         LAPACKE_xerbla( "LAPACKE_dgbrfsx", -1 );
00053         return -1;
00054     }
00055 #ifndef LAPACK_DISABLE_NAN_CHECK
00056     
00057     if( LAPACKE_dgb_nancheck( matrix_order, n, n, kl, ku, ab, ldab ) ) {
00058         return -8;
00059     }
00060     if( LAPACKE_dgb_nancheck( matrix_order, n, n, kl, kl+ku, afb, ldafb ) ) {
00061         return -10;
00062     }
00063     if( LAPACKE_dge_nancheck( matrix_order, n, nrhs, b, ldb ) ) {
00064         return -15;
00065     }
00066     if( LAPACKE_lsame( equed, 'b' ) || LAPACKE_lsame( equed, 'c' ) ) {
00067         if( LAPACKE_d_nancheck( n, c, 1 ) ) {
00068             return -14;
00069         }
00070     }
00071     if( nparams>0 ) {
00072         if( LAPACKE_d_nancheck( nparams, params, 1 ) ) {
00073             return -25;
00074         }
00075     }
00076     if( LAPACKE_lsame( equed, 'b' ) || LAPACKE_lsame( equed, 'r' ) ) {
00077         if( LAPACKE_d_nancheck( n, r, 1 ) ) {
00078             return -13;
00079         }
00080     }
00081     if( LAPACKE_dge_nancheck( matrix_order, n, nrhs, x, ldx ) ) {
00082         return -17;
00083     }
00084 #endif
00085     
00086     iwork = (lapack_int*)LAPACKE_malloc( sizeof(lapack_int) * MAX(1,n) );
00087     if( iwork == NULL ) {
00088         info = LAPACK_WORK_MEMORY_ERROR;
00089         goto exit_level_0;
00090     }
00091     work = (double*)LAPACKE_malloc( sizeof(double) * MAX(1,4*n) );
00092     if( work == NULL ) {
00093         info = LAPACK_WORK_MEMORY_ERROR;
00094         goto exit_level_1;
00095     }
00096     
00097     info = LAPACKE_dgbrfsx_work( matrix_order, trans, equed, n, kl, ku, nrhs,
00098                                  ab, ldab, afb, ldafb, ipiv, r, c, b, ldb, x,
00099                                  ldx, rcond, berr, n_err_bnds, err_bnds_norm,
00100                                  err_bnds_comp, nparams, params, work, iwork );
00101     
00102     LAPACKE_free( work );
00103 exit_level_1:
00104     LAPACKE_free( iwork );
00105 exit_level_0:
00106     if( info == LAPACK_WORK_MEMORY_ERROR ) {
00107         LAPACKE_xerbla( "LAPACKE_dgbrfsx", info );
00108     }
00109     return info;
00110 }