47 const pastix_complex64_t *A,
52 size_t lrwork = 2 * minMN;
53 size_t lzwork = M * N;
54 pastix_complex64_t *W;
57 W = malloc( lzwork *
sizeof(pastix_complex64_t) + lrwork *
sizeof(
double) );
58 s = (
double*)(W + M*N);
61 ret = LAPACKE_zlacpy_work( LAPACK_COL_MAJOR,
'A', M, N, A, lda, W, M );
63 ret = LAPACKE_zgesvd(LAPACK_COL_MAJOR,
'N',
'N', M, N, W, M, s, NULL, 1, NULL, 1, superb );
66 for(i=0; i<minMN; i++) {
67 fprintf( stderr,
"%e ", s[i] );
69 fprintf(stderr,
"\n");
103 const pastix_complex64_t *A,
106 pastix_complex64_t *Id;
112 double eps = LAPACKE_dlamch_work(
'e');
118 Id = malloc( minMN * minMN *
sizeof(pastix_complex64_t) );
119 ret = LAPACKE_zlaset_work( LAPACK_COL_MAJOR,
'A', minMN, minMN,
125 cblas_zherk(CblasColMajor, CblasUpper, CblasConjTrans, N, M, alpha, A, lda, beta, Id, minMN);
129 cblas_zherk(CblasColMajor, CblasUpper, CblasNoTrans, M, N, alpha, A, lda, beta, Id, minMN);
132 normQ = LAPACKE_zlanhe_work( LAPACK_COL_MAJOR,
'M',
'U', minMN, Id, minMN, NULL );
133 res = normQ / (maxMN * eps);
135 if ( isnan(res) || isinf(res) || (res > 60.0) ) {
136 fprintf(stderr,
"Check Orthogonality: || I - Q*Q' || = %e, ||Id-Q'*Q||_oo / (N*eps) = %e : \n",
189 const pastix_complex64_t *A,
191 const pastix_complex64_t *B,
194 pastix_complex64_t *Zero;
197 double eps = LAPACKE_dlamch_work(
'e');
198 pastix_complex64_t zone = 1.0;
199 pastix_complex64_t zzero = 0.0;
202 Zero = malloc( NA * NB *
sizeof(pastix_complex64_t) );
203 ret = LAPACKE_zlaset_work( LAPACK_COL_MAJOR,
'A', NA, NB,
207 cblas_zgemm(CblasColMajor, CblasConjTrans, CblasNoTrans,
209 CBLAS_SADDR(zone), A, lda,
211 CBLAS_SADDR(zzero), Zero, NA);
213 norm = LAPACKE_zlange_work( LAPACK_COL_MAJOR,
'M', NA, NB, Zero, NA, NULL );
214 res = norm / (M * eps);
216 if ( isnan(res) || isinf(res) || (res > 60.0) ) {
217 fprintf(stderr,
"Check Orthogonality: || A' B || = %e, || A' B ||_oo / (M*eps) = %e : \n",
BEGIN_C_DECLS typedef int pastix_int_t
int core_zlrdbg_check_orthogonality_AB(pastix_int_t M, pastix_int_t NA, pastix_int_t NB, const pastix_complex64_t *A, pastix_int_t lda, const pastix_complex64_t *B, pastix_int_t ldb)
Check the orthogonality of the matrix A relatively to the matrix B.
void core_zlrdbg_printsvd(pastix_int_t M, pastix_int_t N, const pastix_complex64_t *A, pastix_int_t lda)
Print the svd values of the given matrix.
int core_zlrdbg_check_orthogonality(pastix_int_t M, pastix_int_t N, const pastix_complex64_t *A, pastix_int_t lda)
Check the orthogonality of the matrix A.
Manage nancheck for lowrank kernels. This header describes all the LAPACKE functions used for low-ran...