[Pw_forum] Bug in QE 5.0 with ibrav=0 and using a instead of
Y. L. Li
ylli at theory.issp.ac.cn
Sat Aug 25 23:57:26 CEST 2012
Hi,
I agree with you. I also found this bug as you said.
Yanling
----On Wed, 22 Aug 2012 15:06:20 +0200 wrote: ----
> Date: Wed, 22 Aug 2012 15:06:12 +0200
> From: Giovanni Pizzi
> Subject: [Pw_forum] Bug in QE 5.0 with ibrav=0 and using a instead of
> celldm
> To: pw_forum at pwscf.org
> Message-ID:
> Content-Type: text/plain; charset=ISO-8859-1; format=flowed
>
> Dear all,
> I believe there is a bug in QE 5.0 (pw.x) that occurs when using ibrav=0
> and defining 'a' instead of 'celldm(1)'.
> In this case, celldm is not set and remains equal to zero. (This
> behavior was different in 4.3.2, where instead the celldm(1) value was
> set from the 'a' value.)
>
> This doesn't seem to create problems in the pw.x calculation.
> However, in the matdyn files generated by ph.x, the celldm(1) is set to
> zero.
> When the matdyn files are then given to q2r.x, the code crashes,
> complaining of a wrong celldm value.
>
> In particular this is what happens in q2r.x:
> 1. the first q point is read (matdyn1) using the routine
> read_dyn_from_file; celldm(1) is set to 0
> 2. the code calls the routine latgen: this routine sets celldm(1) to the
> a value different from zero (moreover this value may be wrong if 'a' in
> the input file was not set to the length of the first lattice vector)
> 3. the code reads the second q point (matdyn2) and compares the celldm
> value read from file (which is zero) with the old value (which was set
> to a value different from zero at step 2): being different, the code stops.
>
> I think that to correct it, one should replace the following lines
> (cell_base.f90, lines 152 and following)
> IF( celldm( 1 ) /= 0.0_DP ) THEN
> alat = celldm( 1 )
> ELSE IF ( a /= 0.0_dp ) THEN
> alat = a / bohr_radius_angs
> ELSE
> alat = SQRT ( at(1,1)**2+at(2,1)**2+at(3,1)**2 )
> END IF
> at(:,:) = at(:,:) / alat
>
> with
> IF( celldm( 1 ) /= 0.0_DP ) THEN
> alat = celldm( 1 )
> ELSE IF ( a /= 0.0_dp ) THEN
> alat = a / bohr_radius_angs
> celldm( 1 ) = alat
> ELSE
> alat = SQRT ( at(1,1)**2+at(2,1)**2+at(3,1)**2 )
> celldm( 1 ) = alat
> END IF
> at(:,:) = at(:,:) / alat
>
> Let me know what you think.
>
> Best,
> Giovanni Pizzi
>
>
>
> --
> Giovanni Pizzi
> Post-doctoral Research Scientist
> EPFL STI IMX THEOS
> MXC 319 (B?timent MXC)
> Station 12
> CH-1015 Lausanne (Switzerland)
> Phone: +41 21 69 31159
>
>
>
> ------------------------------
>
> _______________________________________________
> Pw_forum mailing list
> Pw_forum at pwscf.org
> http://www.democritos.it/mailman/listinfo/pw_forum
>
>
> End of Pw_forum Digest, Vol 62, Issue 37
> ****************************************
>
------
ISSP
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://www.democritos.it/pipermail/pw_forum/attachments/20120826/13dee290/attachment.htm
More information about the Pw_forum
mailing list