[Pw_forum] Normalization of the Wave Functions

Giovanni La Penna glapenna at iccom.cnr.it
Fri Dec 23 17:18:58 CET 2011


I used the Kohn-Sham states output of PP analysis program
and they are normalized to one with ultrasoft pseudopotentials.
See below for gamma-point only (psi are real,
see also comments in the PP code).
Unfortunately, this implies to store all the states,
as cube-files in the example below.

PP input:

&inputpp
  prefix='relax',
  outdir='./',
  filplot='state.out',
  plot_num=7,
  lsign = .true.,
  kpoint = 1,
  kband = 1,
/

&plot
  nfile=1,
  filepp(1)='state.out',
  iflag=3,
  fileout='state_1.cube',
  output_format=6,
/


Piece of analysis C code (single precision):

/* ... */

#define _REAL float
#define l_sqrt sqrtf
#define l_copysign copysignf
#define Nabs(dumx) ((dumx) >= 0 ? (dumx) : -(dumx))

/* ... */
/* dx,dy,dz are the grid sides in a.u. (bohr)
  nr1x,nr2x,nr3x are the number of grid points in x,y,z
  input[js] is the unit of state js output from PP
(state_1.cube above) */

   dvol=dx*dy*dz;

   sum=0.;
   for(i1=1;i1<=nr1x;i1++)
   {
    for(j1=1;j1<=nr2x;j1++)
    {
     for(k1=1;k1<=nr3x;k1++)
     {
      fscanf(input[js],"%e ",&val);
/* for ADF and CPMD this is enough. For QE... */
      um=val;
      ut=l_sqrt(Nabs(um));
      val=l_copysign(ut,um);

      sum+=val*val;
      fwrite(&val,sizeof(_REAL),1,output[is]);
     }
    }
   }

   printf ("Integral of modulus of state %d = %e\n",js,sum*dvol);
/* ... */

Hoping this be useful (even though slow), my best wishes,
               Giovanni

============================================================
Giovanni La Penna - National research council (Cnr)
Institute for chemistry of organo-metallic compounds (Iccom)
via Madonna del Piano 10,
I-50019 Sesto Fiorentino, Firenze, Italy
tel.: +39 055 522-5264, fax: +39 055 522-5203
e-mail: glapenna at iccom.cnr.it - http://www.iccom.cnr.it/lapenna
skype: giovannilapenna
============================================================



More information about the Pw_forum mailing list