parent
25c9bb1cd7
commit
6b5b0fae22
|
@ -88,38 +88,52 @@ module quaternions
|
|||
|
||||
end type
|
||||
|
||||
interface assignment (=)
|
||||
interface assignment (=)
|
||||
module procedure assign_quat__
|
||||
module procedure assign_vec__
|
||||
end interface assignment (=)
|
||||
end interface assignment (=)
|
||||
|
||||
interface quaternion
|
||||
interface quaternion
|
||||
module procedure init__
|
||||
end interface quaternion
|
||||
end interface quaternion
|
||||
|
||||
interface abs
|
||||
interface abs
|
||||
procedure abs__
|
||||
end interface abs
|
||||
end interface abs
|
||||
|
||||
interface dot_product
|
||||
interface dot_product
|
||||
procedure dot_product__
|
||||
end interface dot_product
|
||||
end interface dot_product
|
||||
|
||||
interface conjg
|
||||
interface conjg
|
||||
module procedure conjg__
|
||||
end interface conjg
|
||||
end interface conjg
|
||||
|
||||
interface exp
|
||||
interface exp
|
||||
module procedure exp__
|
||||
end interface exp
|
||||
end interface exp
|
||||
|
||||
interface log
|
||||
interface log
|
||||
module procedure log__
|
||||
end interface log
|
||||
end interface log
|
||||
|
||||
private :: &
|
||||
unitTest
|
||||
|
||||
contains
|
||||
|
||||
|
||||
!--------------------------------------------------------------------------------------------------
|
||||
!> @brief doing self test
|
||||
!--------------------------------------------------------------------------------------------------
|
||||
subroutine quaternions_init()
|
||||
|
||||
write(6,'(/,a)') ' <<<+- quaternions init -+>>>'
|
||||
call unitTest
|
||||
|
||||
end subroutine quaternions_init
|
||||
|
||||
|
||||
!---------------------------------------------------------------------------------------------------
|
||||
!> constructor for a quaternion from a 4-vector
|
||||
!---------------------------------------------------------------------------------------------------
|
||||
|
@ -434,29 +448,58 @@ end function asArray
|
|||
|
||||
|
||||
!---------------------------------------------------------------------------------------------------
|
||||
!> quaternion as plain array
|
||||
!> real part of a quaternion
|
||||
!---------------------------------------------------------------------------------------------------
|
||||
pure function real__(self)
|
||||
|
||||
real(pReal), dimension(3) :: real__
|
||||
real(pReal) :: real__
|
||||
class(quaternion), intent(in) :: self
|
||||
|
||||
real__ = [self%x,self%y,self%z]
|
||||
real__ = self%w
|
||||
|
||||
end function real__
|
||||
|
||||
|
||||
!---------------------------------------------------------------------------------------------------
|
||||
!> quaternion as plain array
|
||||
!> imagninary part of a quaternion
|
||||
!---------------------------------------------------------------------------------------------------
|
||||
pure function aimag__(self)
|
||||
|
||||
real(pReal) :: aimag__
|
||||
real(pReal), dimension(3) :: aimag__
|
||||
class(quaternion), intent(in) :: self
|
||||
|
||||
aimag__ = self%w
|
||||
aimag__ = [self%x,self%y,self%z]
|
||||
|
||||
end function aimag__
|
||||
|
||||
|
||||
!--------------------------------------------------------------------------------------------------
|
||||
!> @brief check correctness of (some) quaternions functions
|
||||
!--------------------------------------------------------------------------------------------------
|
||||
subroutine unitTest
|
||||
|
||||
real(pReal), dimension(4) :: qu
|
||||
|
||||
type(quaternion) :: q, q_2
|
||||
|
||||
call random_number(qu)
|
||||
q = qu
|
||||
|
||||
write(6,*) q%asArray() == qu
|
||||
write(6,*) q%real() == qu(1)
|
||||
write(6,*) q%aimag() == qu(2:4)
|
||||
|
||||
|
||||
q_2 = q%homomorphed()
|
||||
write(6,*) q == q_2*(-1.0_pReal)
|
||||
write(6,*) q_2%real() == qu(1)*(-1.0_pReal)
|
||||
write(6,*) q_2%aimag() == qu(2:4)*(-1.0_pReal)
|
||||
|
||||
q_2 = conjg(q)
|
||||
write(6,*) q_2%real() == q%real()
|
||||
write(6,*) q_2%aimag() == q%aimag()*(-1.0_pReal)
|
||||
|
||||
end subroutine unitTest
|
||||
|
||||
|
||||
end module quaternions
|
||||
|
|
|
@ -88,10 +88,10 @@ contains
|
|||
!--------------------------------------------------------------------------------------------------
|
||||
!> @brief doing self test
|
||||
!--------------------------------------------------------------------------------------------------
|
||||
subroutine rotations_init()
|
||||
subroutine rotations_init
|
||||
|
||||
write(6,'(/,a)') ' <<<+- rotations init -+>>>'
|
||||
call unitTest()
|
||||
call unitTest
|
||||
|
||||
end subroutine rotations_init
|
||||
|
||||
|
@ -265,7 +265,7 @@ pure function rotVector(self,v,active) result(vRot)
|
|||
else
|
||||
q = conjg(self%q) * (quaternion([0.0_pReal, v_normed(1), v_normed(2), v_normed(3)]) * self%q )
|
||||
endif
|
||||
vRot = q%real()*norm2(v)
|
||||
vRot = q%aimag()*norm2(v)
|
||||
endif
|
||||
|
||||
end function rotVector
|
||||
|
@ -1233,8 +1233,6 @@ subroutine unitTest
|
|||
if(qu(1)<0.0_pReal) qu = qu * (-1.0_pReal)
|
||||
endif
|
||||
|
||||
|
||||
|
||||
if(dNeq0(norm2(om2qu(qu2om(qu))-qu),1.0e-12_pReal)) msg = trim(msg)//'om2qu/qu2om,'
|
||||
if(dNeq0(norm2(eu2qu(qu2eu(qu))-qu),1.0e-12_pReal)) msg = trim(msg)//'eu2qu/qu2eu,'
|
||||
if(dNeq0(norm2(ax2qu(qu2ax(qu))-qu),1.0e-12_pReal)) msg = trim(msg)//'ax2qu/qu2ax,'
|
||||
|
@ -1267,8 +1265,7 @@ subroutine unitTest
|
|||
ho = qu2ho(qu)
|
||||
if(dNeq0(norm2(ho2qu(cu2ho(ho2cu(ho)))-qu),1.0e-7_pReal)) msg = trim(msg)//'cu2ho/ho2cu,'
|
||||
|
||||
if(len_trim(msg) /= 0) &
|
||||
call IO_error(401,ext_msg=msg)
|
||||
if(len_trim(msg) /= 0) call IO_error(401,ext_msg=msg)
|
||||
|
||||
enddo
|
||||
|
||||
|
|
Loading…
Reference in New Issue