mirror of
https://github.com/LCPQ/DEHam
synced 2025-01-05 02:48:46 +01:00
printing energies and s2 together
This commit is contained in:
parent
260daba4b2
commit
86b4621ea9
61
src/ex1.c
61
src/ex1.c
@ -165,41 +165,6 @@ int main(int argc,char **argv)
|
|||||||
ierr = EPSGetConverged(eps,&nconv);CHKERRQ(ierr);
|
ierr = EPSGetConverged(eps,&nconv);CHKERRQ(ierr);
|
||||||
//ierr = EPSPrintSolution(eps,NULL);CHKERRQ(ierr);
|
//ierr = EPSPrintSolution(eps,NULL);CHKERRQ(ierr);
|
||||||
|
|
||||||
if (nconv>0) {
|
|
||||||
/*
|
|
||||||
Display eigenvalues && relative errors
|
|
||||||
*/
|
|
||||||
ierr = PetscPrintf(PETSC_COMM_WORLD,
|
|
||||||
" k ||Ax-kx||/||kx||\n"
|
|
||||||
" ----------------- ------------------\n");CHKERRQ(ierr);
|
|
||||||
|
|
||||||
for (i=0;i<nev;i++) {
|
|
||||||
/*
|
|
||||||
Get converged eigenpairs: i-th eigenvalue is stored in kr (real part) and
|
|
||||||
ki (imaginary part)
|
|
||||||
*/
|
|
||||||
ierr = EPSGetEigenpair(eps,i,&kr,&ki,xr,xi);CHKERRQ(ierr);
|
|
||||||
/*
|
|
||||||
Compute the relative error associated to each eigenpair
|
|
||||||
*/
|
|
||||||
ierr = EPSComputeError(eps,i,EPS_ERROR_RELATIVE,&error);CHKERRQ(ierr);
|
|
||||||
|
|
||||||
#if defined(PETSC_USE_COMPLEX)
|
|
||||||
re = PetscRealPart(kr);
|
|
||||||
im = PetscImaginaryPart(kr);
|
|
||||||
#else
|
|
||||||
re = kr;
|
|
||||||
im = ki;
|
|
||||||
#endif
|
|
||||||
if (im!=0.0) {
|
|
||||||
ierr = PetscPrintf(PETSC_COMM_WORLD," %14f%+14fi %12g\n",(double)re,(double)im,(double)error);CHKERRQ(ierr);
|
|
||||||
} else {
|
|
||||||
ierr = PetscPrintf(PETSC_COMM_WORLD," %18f %12g\n",(double)re,(double)error);CHKERRQ(ierr);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
ierr = PetscPrintf(PETSC_COMM_WORLD,"\n");CHKERRQ(ierr);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Save eigenvectors, if == ested
|
Save eigenvectors, if == ested
|
||||||
*/
|
*/
|
||||||
@ -226,6 +191,10 @@ int main(int argc,char **argv)
|
|||||||
|
|
||||||
if (nconv>0) {
|
if (nconv>0) {
|
||||||
|
|
||||||
|
ierr = PetscPrintf(PETSC_COMM_WORLD,
|
||||||
|
" k ||Ax-kx||/||kx|| <S^2>\n"
|
||||||
|
" ----------------- ----------------- ------------------\n");CHKERRQ(ierr);
|
||||||
|
|
||||||
for(i=0;i<nev;i++){
|
for(i=0;i<nev;i++){
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -374,11 +343,31 @@ int main(int argc,char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
//printf("\n mpiid = %d # root = %d norm = %18f xymat = %18f S^2 = %18f \n", mpiid, i, norm, xymat, XS);
|
//printf("\n mpiid = %d # root = %d norm = %18f xymat = %18f S^2 = %18f \n", mpiid, i, norm, xymat, XS);
|
||||||
PetscPrintf(PETSC_COMM_WORLD,"\n norm = %18f xymat = %18f S^2 = %18f \n", normfin, xymatfin, XS);
|
//PetscPrintf(PETSC_COMM_WORLD,"\n norm = %18f xymat = %18f S^2 = %18f \n", normfin, xymatfin, XS);
|
||||||
xymatfin = 0.0;
|
xymatfin = 0.0;
|
||||||
normfin = 0.0;
|
normfin = 0.0;
|
||||||
|
|
||||||
|
/*
|
||||||
|
Compute the relative error associated to each eigenpair
|
||||||
|
*/
|
||||||
|
ierr = EPSComputeError(eps,i,EPS_ERROR_RELATIVE,&error);CHKERRQ(ierr);
|
||||||
|
|
||||||
|
#if defined(PETSC_USE_COMPLEX)
|
||||||
|
re = PetscRealPart(kr);
|
||||||
|
im = PetscImaginaryPart(kr);
|
||||||
|
#else
|
||||||
|
re = kr;
|
||||||
|
im = ki;
|
||||||
|
#endif
|
||||||
|
if (im!=0.0) {
|
||||||
|
ierr = PetscPrintf(PETSC_COMM_WORLD," %14f%+14fi %12g\n",(double)re,(double)im,(double)error);CHKERRQ(ierr);
|
||||||
|
} else {
|
||||||
|
ierr = PetscPrintf(PETSC_COMM_WORLD," %18f %12g %18f\n",(double)re,(double)error,(double)XS);CHKERRQ(ierr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
ierr = PetscPrintf(PETSC_COMM_WORLD,"\n");CHKERRQ(ierr);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
ierr = EPSDestroy(&eps);CHKERRQ(ierr);
|
ierr = EPSDestroy(&eps);CHKERRQ(ierr);
|
||||||
ierr = MatDestroy(&A);CHKERRQ(ierr);
|
ierr = MatDestroy(&A);CHKERRQ(ierr);
|
||||||
|
Loading…
Reference in New Issue
Block a user