avoid code (loop) duplication
This commit is contained in:
parent
535ccf1378
commit
1fdc5443b2
|
@ -75,7 +75,6 @@ subroutine grid_damage_spectral_init(num_grid)
|
||||||
type(tDict), pointer, intent(in) :: num_grid
|
type(tDict), pointer, intent(in) :: num_grid
|
||||||
|
|
||||||
integer(MPI_INTEGER_KIND), dimension(0:worldsize-1) :: cells3_global
|
integer(MPI_INTEGER_KIND), dimension(0:worldsize-1) :: cells3_global
|
||||||
integer :: i, j, k, ce
|
|
||||||
DM :: DM_damage
|
DM :: DM_damage
|
||||||
real(pREAL), dimension(:,:,:), pointer :: phi ! 0-indexed
|
real(pREAL), dimension(:,:,:), pointer :: phi ! 0-indexed
|
||||||
Vec :: uBound, lBound
|
Vec :: uBound, lBound
|
||||||
|
@ -193,11 +192,7 @@ subroutine grid_damage_spectral_init(num_grid)
|
||||||
phi_stagInc = phi_lastInc
|
phi_stagInc = phi_lastInc
|
||||||
end if restartRead
|
end if restartRead
|
||||||
|
|
||||||
ce = 0
|
call homogenization_set_phi(reshape(phi,[product(cells(1:2))*cells3]))
|
||||||
do k = 0, cells3-1; do j = 0, cells(2)-1; do i = 0, cells(1)-1
|
|
||||||
ce = ce + 1
|
|
||||||
call homogenization_set_phi(phi(i,j,k),ce)
|
|
||||||
end do; end do; end do
|
|
||||||
|
|
||||||
call DMDAVecRestoreArrayF90(DM_damage,phi_PETSc,phi,err_PETSc)
|
call DMDAVecRestoreArrayF90(DM_damage,phi_PETSc,phi,err_PETSc)
|
||||||
CHKERRQ(err_PETSc)
|
CHKERRQ(err_PETSc)
|
||||||
|
@ -215,7 +210,6 @@ function grid_damage_spectral_solution(Delta_t) result(solution)
|
||||||
real(pREAL), intent(in) :: &
|
real(pREAL), intent(in) :: &
|
||||||
Delta_t !< increment in time for current solution
|
Delta_t !< increment in time for current solution
|
||||||
|
|
||||||
integer :: i, j, k, ce
|
|
||||||
type(tSolutionState) :: solution
|
type(tSolutionState) :: solution
|
||||||
PetscInt :: devNull
|
PetscInt :: devNull
|
||||||
PetscReal :: phi_min, phi_max, stagNorm
|
PetscReal :: phi_min, phi_max, stagNorm
|
||||||
|
@ -253,13 +247,7 @@ function grid_damage_spectral_solution(Delta_t) result(solution)
|
||||||
if (err_MPI /= 0_MPI_INTEGER_KIND) error stop 'MPI error'
|
if (err_MPI /= 0_MPI_INTEGER_KIND) error stop 'MPI error'
|
||||||
phi_stagInc = phi
|
phi_stagInc = phi
|
||||||
|
|
||||||
!--------------------------------------------------------------------------------------------------
|
call homogenization_set_phi(reshape(phi,[product(cells(1:2))*cells3]))
|
||||||
! updating damage state
|
|
||||||
ce = 0
|
|
||||||
do k = 0, cells3-1; do j = 0, cells(2)-1; do i = 0,cells(1)-1
|
|
||||||
ce = ce + 1
|
|
||||||
call homogenization_set_phi(phi(i,j,k),ce)
|
|
||||||
end do; end do; end do
|
|
||||||
|
|
||||||
call DMDAVecRestoreArrayF90(DM_damage,phi_PETSc,phi,err_PETSc)
|
call DMDAVecRestoreArrayF90(DM_damage,phi_PETSc,phi,err_PETSc)
|
||||||
CHKERRQ(err_PETSc)
|
CHKERRQ(err_PETSc)
|
||||||
|
@ -280,7 +268,6 @@ subroutine grid_damage_spectral_forward(cutBack)
|
||||||
|
|
||||||
logical, intent(in) :: cutBack
|
logical, intent(in) :: cutBack
|
||||||
|
|
||||||
integer :: i, j, k, ce
|
|
||||||
DM :: DM_damage
|
DM :: DM_damage
|
||||||
real(pREAL), dimension(:,:,:), pointer :: phi ! 0-indexed
|
real(pREAL), dimension(:,:,:), pointer :: phi ! 0-indexed
|
||||||
PetscErrorCode :: err_PETSc
|
PetscErrorCode :: err_PETSc
|
||||||
|
@ -292,11 +279,7 @@ subroutine grid_damage_spectral_forward(cutBack)
|
||||||
CHKERRQ(err_PETSc)
|
CHKERRQ(err_PETSc)
|
||||||
|
|
||||||
if (cutBack) then
|
if (cutBack) then
|
||||||
ce = 0
|
call homogenization_set_phi(reshape(phi_lastInc,[product(cells(1:2))*cells3]))
|
||||||
do k = 1, cells3; do j = 1, cells(2); do i = 1,cells(1)
|
|
||||||
ce = ce + 1
|
|
||||||
call homogenization_set_phi(phi_lastInc(i,j,k),ce)
|
|
||||||
end do; end do; end do
|
|
||||||
phi = phi_lastInc
|
phi = phi_lastInc
|
||||||
phi_stagInc = phi_lastInc
|
phi_stagInc = phi_lastInc
|
||||||
else
|
else
|
||||||
|
|
|
@ -74,7 +74,7 @@ subroutine grid_thermal_spectral_init(num_grid)
|
||||||
type(tDict), pointer, intent(in) :: num_grid
|
type(tDict), pointer, intent(in) :: num_grid
|
||||||
|
|
||||||
integer(MPI_INTEGER_KIND), dimension(0:worldsize-1) :: cells3_global
|
integer(MPI_INTEGER_KIND), dimension(0:worldsize-1) :: cells3_global
|
||||||
integer :: i, j, k, ce
|
integer :: ce
|
||||||
DM :: DM_thermal
|
DM :: DM_thermal
|
||||||
real(pREAL), dimension(:,:,:), pointer :: T ! 0-indexed
|
real(pREAL), dimension(:,:,:), pointer :: T ! 0-indexed
|
||||||
integer(MPI_INTEGER_KIND) :: err_MPI
|
integer(MPI_INTEGER_KIND) :: err_MPI
|
||||||
|
@ -170,11 +170,8 @@ subroutine grid_thermal_spectral_init(num_grid)
|
||||||
dotT_lastInc = 0.0_pREAL * T_lastInc
|
dotT_lastInc = 0.0_pREAL * T_lastInc
|
||||||
end if restartRead
|
end if restartRead
|
||||||
|
|
||||||
ce = 0
|
call homogenization_thermal_setField(reshape(T,[product(cells(1:2))*cells3]), &
|
||||||
do k = 0, cells3-1; do j = 0, cells(2)-1; do i = 0, cells(1)-1
|
[(0.0_pReal, ce = 1,product(cells(1:2))*cells3)])
|
||||||
ce = ce + 1
|
|
||||||
call homogenization_thermal_setField(T(i,j,k),0.0_pREAL,ce)
|
|
||||||
end do; end do; end do
|
|
||||||
|
|
||||||
call DMDAVecRestoreArrayF90(DM_thermal,T_PETSc,T,err_PETSc)
|
call DMDAVecRestoreArrayF90(DM_thermal,T_PETSc,T,err_PETSc)
|
||||||
CHKERRQ(err_PETSc)
|
CHKERRQ(err_PETSc)
|
||||||
|
@ -230,13 +227,8 @@ function grid_thermal_spectral_solution(Delta_t) result(solution)
|
||||||
if (err_MPI /= 0_MPI_INTEGER_KIND) error stop 'MPI error'
|
if (err_MPI /= 0_MPI_INTEGER_KIND) error stop 'MPI error'
|
||||||
T_stagInc = T
|
T_stagInc = T
|
||||||
|
|
||||||
!--------------------------------------------------------------------------------------------------
|
call homogenization_thermal_setField(reshape(T,[product(cells(1:2))*cells3]), &
|
||||||
! updating thermal state
|
reshape(T-T_lastInc,[product(cells(1:2))*cells3])/params%Delta_t)
|
||||||
ce = 0
|
|
||||||
do k = 0, cells3-1; do j = 0, cells(2)-1; do i = 0, cells(1)-1
|
|
||||||
ce = ce + 1
|
|
||||||
call homogenization_thermal_setField(T(i,j,k),(T(i,j,k)-T_lastInc(i+1,j+1,k+1))/params%Delta_t,ce)
|
|
||||||
end do; end do; end do
|
|
||||||
|
|
||||||
call DMDAVecRestoreArrayF90(DM_thermal,T_PETSc,T,err_PETSc)
|
call DMDAVecRestoreArrayF90(DM_thermal,T_PETSc,T,err_PETSc)
|
||||||
CHKERRQ(err_PETSc)
|
CHKERRQ(err_PETSc)
|
||||||
|
@ -257,7 +249,6 @@ subroutine grid_thermal_spectral_forward(cutBack)
|
||||||
|
|
||||||
logical, intent(in) :: cutBack
|
logical, intent(in) :: cutBack
|
||||||
|
|
||||||
integer :: i, j, k, ce
|
|
||||||
DM :: DM_thermal
|
DM :: DM_thermal
|
||||||
real(pREAL), dimension(:,:,:), pointer :: T ! 0-indexed
|
real(pREAL), dimension(:,:,:), pointer :: T ! 0-indexed
|
||||||
PetscErrorCode :: err_PETSc
|
PetscErrorCode :: err_PETSc
|
||||||
|
@ -269,11 +260,8 @@ subroutine grid_thermal_spectral_forward(cutBack)
|
||||||
CHKERRQ(err_PETSc)
|
CHKERRQ(err_PETSc)
|
||||||
|
|
||||||
if (cutBack) then
|
if (cutBack) then
|
||||||
ce = 0
|
call homogenization_thermal_setField(reshape(T_lastInc,[product(cells(1:2))*cells3]), &
|
||||||
do k = 1, cells3; do j = 1, cells(2); do i = 1,cells(1)
|
reshape(dotT_lastInc,[product(cells(1:2))*cells3]))
|
||||||
ce = ce + 1
|
|
||||||
call homogenization_thermal_setField(T_lastInc(i,j,k),dotT_lastInc(i,j,k),ce)
|
|
||||||
end do; end do; end do
|
|
||||||
T = T_lastInc
|
T = T_lastInc
|
||||||
T_stagInc = T_lastInc
|
T_stagInc = T_lastInc
|
||||||
else
|
else
|
||||||
|
|
|
@ -145,9 +145,8 @@ module homogenization
|
||||||
real(pREAL) :: f
|
real(pREAL) :: f
|
||||||
end function homogenization_f_T
|
end function homogenization_f_T
|
||||||
|
|
||||||
module subroutine homogenization_thermal_setField(T,dot_T, ce)
|
module subroutine homogenization_thermal_setField(T,dot_T)
|
||||||
integer, intent(in) :: ce
|
real(pREAL), dimension(:), intent(in) :: T, dot_T
|
||||||
real(pREAL), intent(in) :: T, dot_T
|
|
||||||
end subroutine homogenization_thermal_setField
|
end subroutine homogenization_thermal_setField
|
||||||
|
|
||||||
module function homogenization_damage_active() result(active)
|
module function homogenization_damage_active() result(active)
|
||||||
|
@ -170,10 +169,8 @@ module homogenization
|
||||||
real(pREAL) :: f
|
real(pREAL) :: f
|
||||||
end function homogenization_f_phi
|
end function homogenization_f_phi
|
||||||
|
|
||||||
module subroutine homogenization_set_phi(phi,ce)
|
module subroutine homogenization_set_phi(phi)
|
||||||
integer, intent(in) :: ce
|
real(pREAL), dimension(:), intent(in) :: phi
|
||||||
real(pREAL), intent(in) :: &
|
|
||||||
phi
|
|
||||||
end subroutine homogenization_set_phi
|
end subroutine homogenization_set_phi
|
||||||
|
|
||||||
end interface
|
end interface
|
||||||
|
|
|
@ -151,20 +151,19 @@ end function homogenization_f_phi
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
!> @brief Set damage field.
|
!> @brief Set damage field.
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
module subroutine homogenization_set_phi(phi,ce)
|
module subroutine homogenization_set_phi(phi)
|
||||||
|
|
||||||
integer, intent(in) :: ce
|
real(pREAL), dimension(:), intent(in) :: phi
|
||||||
real(pREAL), intent(in) :: phi
|
|
||||||
|
|
||||||
integer :: &
|
integer :: ho, en, ce
|
||||||
ho, &
|
|
||||||
en
|
|
||||||
|
|
||||||
|
|
||||||
|
do ce=1, ubound(phi,1)
|
||||||
ho = material_ID_homogenization(ce)
|
ho = material_ID_homogenization(ce)
|
||||||
en = material_entry_homogenization(ce)
|
en = material_entry_homogenization(ce)
|
||||||
damagestate_h(ho)%state(1,en) = phi
|
damagestate_h(ho)%state(1,en) = phi(ce)
|
||||||
current(ho)%phi(en) = phi
|
current(ho)%phi(en) = phi(ce)
|
||||||
|
end do
|
||||||
|
|
||||||
end subroutine homogenization_set_phi
|
end subroutine homogenization_set_phi
|
||||||
|
|
||||||
|
|
|
@ -173,15 +173,18 @@ end function homogenization_f_T
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
!> @brief Set thermal field and its rate (T and dot_T).
|
!> @brief Set thermal field and its rate (T and dot_T).
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
module subroutine homogenization_thermal_setField(T,dot_T, ce)
|
module subroutine homogenization_thermal_setField(T,dot_T)
|
||||||
|
|
||||||
integer, intent(in) :: ce
|
real(pREAL), dimension(:), intent(in) :: T, dot_T
|
||||||
real(pREAL), intent(in) :: T, dot_T
|
|
||||||
|
integer :: ce
|
||||||
|
|
||||||
|
|
||||||
current(material_ID_homogenization(ce))%T(material_entry_homogenization(ce)) = T
|
do ce=1, min(ubound(T,1),ubound(dot_T,1))
|
||||||
current(material_ID_homogenization(ce))%dot_T(material_entry_homogenization(ce)) = dot_T
|
current(material_ID_homogenization(ce))%T(material_entry_homogenization(ce)) = T(ce)
|
||||||
|
current(material_ID_homogenization(ce))%dot_T(material_entry_homogenization(ce)) = dot_T(ce)
|
||||||
call thermal_partition(ce)
|
call thermal_partition(ce)
|
||||||
|
end do
|
||||||
|
|
||||||
end subroutine homogenization_thermal_setField
|
end subroutine homogenization_thermal_setField
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue