[Pw_forum] question on q2r.f90

Guoying Gao gaoguoying at gmail.com
Wed Dec 5 08:05:32 CET 2007


Dear everyone,
      When I read the routine q2r.f90 given in the pwtools directory,
I find the following lines:
  %%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
        lq = .true.
        do ipol=1,3
           xq = 0.0
           do icar=1,3
              xq = xq + at(icar,ipol) * q(icar,nq) * nr(ipol)
           end do
           lq = lq .and. (abs(nint(xq) - xq) .lt. eps)
           iq = nint(xq)
           !
           m(ipol)= mod(iq,nr(ipol)) + 1
           if (m(ipol) .lt. 1) m(ipol) = m(ipol) + nr(ipol)
        end do
        if (.not.lq) call errore('init','q not allowed',1)
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
I know the parameters at(icar, ipol) means the components of the
crystal vectors, q(icar, np) is the coordinates of the qpoints and
nr(ipol) are the dimensions
of the FFT grid formed by the q-point grid. What I don't understand is
why the three parameters multiply and sum for x, y and z
components:that is,
          do icar=1,3
              xq = xq + at(icar,ipol) * q(icar,nq) * nr(ipol)
           end do
and then there is another line: lq = lq .and. (abs(nint(xq) - xq) .lt. eps
what makes (abs(nint(xq) - xq) should be less than eps.
Is there anyone familiar with this part? Any small suggestions may be
a great help for me.
Thanks for your help!
Best wishes,
Guoying


More information about the Pw_forum mailing list