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_ctgsyl( int matrix_order, char trans, lapack_int ijob,
00038                            lapack_int m, lapack_int n,
00039                            const lapack_complex_float* a, lapack_int lda,
00040                            const lapack_complex_float* b, lapack_int ldb,
00041                            lapack_complex_float* c, lapack_int ldc,
00042                            const lapack_complex_float* d, lapack_int ldd,
00043                            const lapack_complex_float* e, lapack_int lde,
00044                            lapack_complex_float* f, lapack_int ldf,
00045                            float* scale, float* dif )
00046 {
00047     lapack_int info = 0;
00048     lapack_int lwork = -1;
00049     lapack_int* iwork = NULL;
00050     lapack_complex_float* work = NULL;
00051     lapack_complex_float work_query;
00052     if( matrix_order != LAPACK_COL_MAJOR && matrix_order != LAPACK_ROW_MAJOR ) {
00053         LAPACKE_xerbla( "LAPACKE_ctgsyl", -1 );
00054         return -1;
00055     }
00056 #ifndef LAPACK_DISABLE_NAN_CHECK
00057     
00058     if( LAPACKE_cge_nancheck( matrix_order, m, m, a, lda ) ) {
00059         return -6;
00060     }
00061     if( LAPACKE_cge_nancheck( matrix_order, n, n, b, ldb ) ) {
00062         return -8;
00063     }
00064     if( LAPACKE_cge_nancheck( matrix_order, m, n, c, ldc ) ) {
00065         return -10;
00066     }
00067     if( LAPACKE_cge_nancheck( matrix_order, m, m, d, ldd ) ) {
00068         return -12;
00069     }
00070     if( LAPACKE_cge_nancheck( matrix_order, n, n, e, lde ) ) {
00071         return -14;
00072     }
00073     if( LAPACKE_cge_nancheck( matrix_order, m, n, f, ldf ) ) {
00074         return -16;
00075     }
00076 #endif
00077     
00078     iwork = (lapack_int*)LAPACKE_malloc( sizeof(lapack_int) * MAX(1,m+n+2) );
00079     if( iwork == NULL ) {
00080         info = LAPACK_WORK_MEMORY_ERROR;
00081         goto exit_level_0;
00082     }
00083     
00084     info = LAPACKE_ctgsyl_work( matrix_order, trans, ijob, m, n, a, lda, b, ldb,
00085                                 c, ldc, d, ldd, e, lde, f, ldf, scale, dif,
00086                                 &work_query, lwork, iwork );
00087     if( info != 0 ) {
00088         goto exit_level_1;
00089     }
00090     lwork = LAPACK_C2INT( work_query );
00091     
00092     work = (lapack_complex_float*)
00093         LAPACKE_malloc( sizeof(lapack_complex_float) * lwork );
00094     if( work == NULL ) {
00095         info = LAPACK_WORK_MEMORY_ERROR;
00096         goto exit_level_1;
00097     }
00098     
00099     info = LAPACKE_ctgsyl_work( matrix_order, trans, ijob, m, n, a, lda, b, ldb,
00100                                 c, ldc, d, ldd, e, lde, f, ldf, scale, dif,
00101                                 work, lwork, iwork );
00102     
00103     LAPACKE_free( work );
00104 exit_level_1:
00105     LAPACKE_free( iwork );
00106 exit_level_0:
00107     if( info == LAPACK_WORK_MEMORY_ERROR ) {
00108         LAPACKE_xerbla( "LAPACKE_ctgsyl", info );
00109     }
00110     return info;
00111 }