using texture class

This commit is contained in:
Martin Diehl 2019-09-19 19:14:37 -07:00
parent 5d0a67e5dc
commit a94c104c75
3 changed files with 28 additions and 24 deletions

@ -1 +1 @@
Subproject commit 33d1fc10bc23ccc97e65af023e2105249340805f Subproject commit b4bda32ab8ffa7511cf5fb4e176a5498375803ef

View File

@ -169,8 +169,9 @@ module material
microstructure_phase, & !< phase IDs of each microstructure microstructure_phase, & !< phase IDs of each microstructure
microstructure_texture !< texture IDs of each microstructure microstructure_texture !< texture IDs of each microstructure
type(Rotation), dimension(:), allocatable, private :: &
texture_Eulers !< Euler angles in material.config (possibly rotated for alignment)
real(pReal), dimension(:,:), allocatable, private :: & real(pReal), dimension(:,:), allocatable, private :: &
texture_Eulers, & !< Euler angles in material.config (possibly rotated for alignment)
microstructure_fraction !< vol fraction of each constituent in microstructure microstructure_fraction !< vol fraction of each constituent in microstructure
logical, dimension(:), allocatable, private :: & logical, dimension(:), allocatable, private :: &
@ -322,7 +323,7 @@ subroutine material_init
do c = 1, homogenization_Ngrains(discretization_homogenizationAt(e)) do c = 1, homogenization_Ngrains(discretization_homogenizationAt(e))
material_phaseAt(c,e) = microstructure_phase(c,myMicro) material_phaseAt(c,e) = microstructure_phase(c,myMicro)
material_texture(c,i,e) = microstructure_texture(c,myMicro) material_texture(c,i,e) = microstructure_texture(c,myMicro)
material_EulerAngles(1:3,c,i,e) = texture_Eulers(1:3,material_texture(c,i,e)) ! this is a copy of crystallite_orientation0 material_EulerAngles(1:3,c,i,e) = texture_Eulers(material_texture(c,i,e))%asEulerAngles() ! this is a copy of crystallite_orientation0
enddo enddo
enddo enddo
enddo enddo
@ -687,11 +688,11 @@ end subroutine material_parsePhase
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
subroutine material_parseTexture subroutine material_parseTexture
integer :: j, t, i integer :: j, t
character(len=65536), dimension(:), allocatable :: strings ! Values for given key in material config character(len=65536), dimension(:), allocatable :: strings ! Values for given key in material config
integer, dimension(:), allocatable :: chunkPos integer, dimension(:), allocatable :: chunkPos
real(pReal), dimension(3,3) :: texture_transformation ! maps texture to microstructure coordinate system real(pReal), dimension(3,3) :: texture_transformation ! maps texture to microstructure coordinate system
type(rotation) :: unajusted, adjusted real(pReal), dimension(3) :: Eulers ! Euler angles in degrees from file
do t=1, size(config_texture) do t=1, size(config_texture)
if (config_texture(t)%countKeys('(gauss)') /= 1) call IO_error(147,ext_msg='count((gauss)) != 1') if (config_texture(t)%countKeys('(gauss)') /= 1) call IO_error(147,ext_msg='count((gauss)) != 1')
@ -700,24 +701,23 @@ subroutine material_parseTexture
if (config_texture(t)%keyExists('(fiber)')) call IO_error(147,ext_msg='(fiber)') if (config_texture(t)%keyExists('(fiber)')) call IO_error(147,ext_msg='(fiber)')
enddo enddo
allocate(texture_Eulers (3,size(config_texture)), source=0.0_pReal) allocate(texture_Eulers(size(config_texture)))
do t=1, size(config_texture) do t=1, size(config_texture)
strings = config_texture(t)%getStrings('(gauss)',raw= .true.) strings = config_texture(t)%getStrings('(gauss)',raw= .true.)
do i = 1 , size(strings) chunkPos = IO_stringPos(strings(1))
chunkPos = IO_stringPos(strings(i))
do j = 1,9,2 do j = 1,9,2
select case (IO_stringValue(strings(i),chunkPos,j)) select case (IO_stringValue(strings(1),chunkPos,j))
case('phi1') case('phi1')
texture_Eulers(1,t) = IO_floatValue(strings(i),chunkPos,j+1)*inRad Eulers(1) = IO_floatValue(strings(1),chunkPos,j+1)
case('phi') case('phi')
texture_Eulers(2,t) = IO_floatValue(strings(i),chunkPos,j+1)*inRad Eulers(2) = IO_floatValue(strings(1),chunkPos,j+1)
case('phi2') case('phi2')
texture_Eulers(3,t) = IO_floatValue(strings(i),chunkPos,j+1)*inRad Eulers(3) = IO_floatValue(strings(1),chunkPos,j+1)
end select end select
enddo enddo
enddo call texture_Eulers(t)%fromEulerAngles(Eulers,degrees=.true.)
if (config_texture(t)%keyExists('axes')) then if (config_texture(t)%keyExists('axes')) then
strings = config_texture(t)%getStrings('axes') strings = config_texture(t)%getStrings('axes')
@ -740,9 +740,7 @@ subroutine material_parseTexture
end select end select
enddo enddo
if(dNeq(math_det33(texture_transformation),1.0_pReal)) call IO_error(157,t) if(dNeq(math_det33(texture_transformation),1.0_pReal)) call IO_error(157,t)
call unajusted%fromEulerAngles(texture_Eulers(:,t)) call texture_Eulers(t)%fromRotationMatrix(matmul(texture_Eulers(t)%asRotationMatrix(),texture_transformation))
call adjusted%fromRotationMatrix(matmul(unajusted%asRotationMatrix(),texture_transformation))
texture_Eulers(:,t) = adjusted%asEulerAngles()
endif endif
enddo enddo

View File

@ -145,12 +145,18 @@ subroutine fromRotationMatrix(self,om)
end subroutine end subroutine
!--------------------------------------------------------------------------------------------------- !---------------------------------------------------------------------------------------------------
subroutine fromEulerAngles(self,eu) subroutine fromEulerAngles(self,eu,degrees)
class(rotation), intent(out) :: self class(rotation), intent(out) :: self
real(pReal), dimension(3), intent(in) :: eu real(pReal), dimension(3), intent(in) :: eu
logical, intent(in), optional :: degrees
if (.not. present(degrees)) then
self%q = eu2qu(eu) self%q = eu2qu(eu)
else
self%q = eu2qu(merge(eu*INRAD,eu,degrees))
endif
end subroutine end subroutine
!--------------------------------------------------------------------------------------------------- !---------------------------------------------------------------------------------------------------