short numpy name
This commit is contained in:
parent
e5c2382f73
commit
74b35f5612
|
@ -202,7 +202,7 @@ subroutine CPFEM_general(mode, ffn, ffn1, temperature_inp, dt, elFE, ip, cauchyS
|
||||||
call random_number(rnd)
|
call random_number(rnd)
|
||||||
if (rnd < 0.5_pReal) rnd = rnd - 1.0_pReal
|
if (rnd < 0.5_pReal) rnd = rnd - 1.0_pReal
|
||||||
CPFEM_cs(1:6,ip,elCP) = ODD_STRESS * rnd
|
CPFEM_cs(1:6,ip,elCP) = ODD_STRESS * rnd
|
||||||
CPFEM_dcsde(1:6,1:6,ip,elCP) = ODD_JACOBIAN * math_identity2nd(6)
|
CPFEM_dcsde(1:6,1:6,ip,elCP) = ODD_JACOBIAN * math_eye(6)
|
||||||
|
|
||||||
else validCalculation
|
else validCalculation
|
||||||
updateJaco = mod(cycleCounter,num%iJacoStiffness) == 0
|
updateJaco = mod(cycleCounter,num%iJacoStiffness) == 0
|
||||||
|
@ -217,7 +217,7 @@ subroutine CPFEM_general(mode, ffn, ffn1, temperature_inp, dt, elFE, ip, cauchyS
|
||||||
call random_number(rnd)
|
call random_number(rnd)
|
||||||
if (rnd < 0.5_pReal) rnd = rnd - 1.0_pReal
|
if (rnd < 0.5_pReal) rnd = rnd - 1.0_pReal
|
||||||
CPFEM_cs(1:6,ip,elCP) = ODD_STRESS * rnd
|
CPFEM_cs(1:6,ip,elCP) = ODD_STRESS * rnd
|
||||||
CPFEM_dcsde(1:6,1:6,ip,elCP) = ODD_JACOBIAN * math_identity2nd(6)
|
CPFEM_dcsde(1:6,1:6,ip,elCP) = ODD_JACOBIAN * math_eye(6)
|
||||||
|
|
||||||
else terminalIllness
|
else terminalIllness
|
||||||
|
|
||||||
|
|
|
@ -576,7 +576,7 @@ subroutine crystallite_stressTangent
|
||||||
lhs_3333 = crystallite_subdt(c,i,e)*math_mul3333xx3333(dSdFe,temp_3333) &
|
lhs_3333 = crystallite_subdt(c,i,e)*math_mul3333xx3333(dSdFe,temp_3333) &
|
||||||
+ math_mul3333xx3333(dSdFi,dFidS)
|
+ math_mul3333xx3333(dSdFi,dFidS)
|
||||||
|
|
||||||
call math_invert(temp_99,error,math_identity2nd(9)+math_3333to99(lhs_3333))
|
call math_invert(temp_99,error,math_eye(9)+math_3333to99(lhs_3333))
|
||||||
if (error) then
|
if (error) then
|
||||||
call IO_warning(warning_ID=600,el=e,ip=i,g=c, &
|
call IO_warning(warning_ID=600,el=e,ip=i,g=c, &
|
||||||
ext_msg='inversion error in analytic tangent calculation')
|
ext_msg='inversion error in analytic tangent calculation')
|
||||||
|
@ -947,7 +947,7 @@ function integrateStress(ipc,ip,el,timeFraction) result(broken)
|
||||||
do o=1,3; do p=1,3
|
do o=1,3; do p=1,3
|
||||||
dFe_dLp(o,1:3,p,1:3) = - dt * A(o,p)*transpose(invFi_new) ! dFe_dLp(i,j,k,l) = -dt * A(i,k) invFi(l,j)
|
dFe_dLp(o,1:3,p,1:3) = - dt * A(o,p)*transpose(invFi_new) ! dFe_dLp(i,j,k,l) = -dt * A(i,k) invFi(l,j)
|
||||||
enddo; enddo
|
enddo; enddo
|
||||||
dRLp_dLp = math_identity2nd(9) &
|
dRLp_dLp = math_eye(9) &
|
||||||
- math_3333to99(math_mul3333xx3333(math_mul3333xx3333(dLp_dS,dS_dFe),dFe_dLp))
|
- math_3333to99(math_mul3333xx3333(math_mul3333xx3333(dLp_dS,dS_dFe),dFe_dLp))
|
||||||
temp_9 = math_33to9(residuumLp)
|
temp_9 = math_33to9(residuumLp)
|
||||||
call dgesv(9,1,dRLp_dLp,9,devNull_9,temp_9,9,ierr) ! solve dRLp/dLp * delta Lp = -res for delta Lp
|
call dgesv(9,1,dRLp_dLp,9,devNull_9,temp_9,9,ierr) ! solve dRLp/dLp * delta Lp = -res for delta Lp
|
||||||
|
@ -992,7 +992,7 @@ function integrateStress(ipc,ip,el,timeFraction) result(broken)
|
||||||
do o=1,3; do p=1,3
|
do o=1,3; do p=1,3
|
||||||
dFi_dLi(1:3,1:3,o,p) = matmul(matmul(Fi_new,dFi_dLi(1:3,1:3,o,p)),Fi_new)
|
dFi_dLi(1:3,1:3,o,p) = matmul(matmul(Fi_new,dFi_dLi(1:3,1:3,o,p)),Fi_new)
|
||||||
enddo; enddo
|
enddo; enddo
|
||||||
dRLi_dLi = math_identity2nd(9) &
|
dRLi_dLi = math_eye(9) &
|
||||||
- math_3333to99(math_mul3333xx3333(dLi_dS, math_mul3333xx3333(dS_dFe, dFe_dLi) &
|
- math_3333to99(math_mul3333xx3333(dLi_dS, math_mul3333xx3333(dS_dFe, dFe_dLi) &
|
||||||
+ math_mul3333xx3333(dS_dFi, dFi_dLi))) &
|
+ math_mul3333xx3333(dS_dFi, dFi_dLi))) &
|
||||||
- math_3333to99(math_mul3333xx3333(dLi_dFi, dFi_dLi))
|
- math_3333to99(math_mul3333xx3333(dLi_dFi, dFi_dLi))
|
||||||
|
|
|
@ -731,7 +731,7 @@ function utilities_maskedCompliance(rot_BC,mask_stress,C)
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
! check if inversion was successful
|
! check if inversion was successful
|
||||||
sTimesC = matmul(c_reduced,s_reduced)
|
sTimesC = matmul(c_reduced,s_reduced)
|
||||||
errmatinv = errmatinv .or. any(dNeq(sTimesC,math_identity2nd(size_reduced),1.0e-12_pReal))
|
errmatinv = errmatinv .or. any(dNeq(sTimesC,math_eye(size_reduced),1.0e-12_pReal))
|
||||||
if (debugGeneral .or. errmatinv) then
|
if (debugGeneral .or. errmatinv) then
|
||||||
write(formatString, '(i2)') size_reduced
|
write(formatString, '(i2)') size_reduced
|
||||||
formatString = '(/,a,/,'//trim(formatString)//'('//trim(formatString)//'(2x,es9.2,1x)/))'
|
formatString = '(/,a,/,'//trim(formatString)//'('//trim(formatString)//'(2x,es9.2,1x)/))'
|
||||||
|
|
30
src/math.f90
30
src/math.f90
|
@ -72,10 +72,6 @@ module math
|
||||||
3,3 &
|
3,3 &
|
||||||
],shape(MAPPLAIN)) !< arrangement in Plain notation
|
],shape(MAPPLAIN)) !< arrangement in Plain notation
|
||||||
|
|
||||||
interface math_eye
|
|
||||||
module procedure math_identity2nd
|
|
||||||
end interface math_eye
|
|
||||||
|
|
||||||
!---------------------------------------------------------------------------------------------------
|
!---------------------------------------------------------------------------------------------------
|
||||||
private :: &
|
private :: &
|
||||||
selfTest
|
selfTest
|
||||||
|
@ -239,18 +235,18 @@ end function math_range
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
!> @brief second rank identity tensor of specified dimension
|
!> @brief second rank identity tensor of specified dimension
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
pure function math_identity2nd(d)
|
pure function math_eye(d)
|
||||||
|
|
||||||
integer, intent(in) :: d !< tensor dimension
|
integer, intent(in) :: d !< tensor dimension
|
||||||
integer :: i
|
integer :: i
|
||||||
real(pReal), dimension(d,d) :: math_identity2nd
|
real(pReal), dimension(d,d) :: math_eye
|
||||||
|
|
||||||
math_identity2nd = 0.0_pReal
|
math_eye = 0.0_pReal
|
||||||
do i=1,d
|
do i=1,d
|
||||||
math_identity2nd(i,i) = 1.0_pReal
|
math_eye(i,i) = 1.0_pReal
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
end function math_identity2nd
|
end function math_eye
|
||||||
|
|
||||||
|
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
|
@ -264,7 +260,7 @@ pure function math_identity4th(d)
|
||||||
real(pReal), dimension(d,d,d,d) :: math_identity4th
|
real(pReal), dimension(d,d,d,d) :: math_identity4th
|
||||||
real(pReal), dimension(d,d) :: identity2nd
|
real(pReal), dimension(d,d) :: identity2nd
|
||||||
|
|
||||||
identity2nd = math_identity2nd(d)
|
identity2nd = math_eye(d)
|
||||||
do i=1,d; do j=1,d; do k=1,d; do l=1,d
|
do i=1,d; do j=1,d; do k=1,d; do l=1,d
|
||||||
math_identity4th(i,j,k,l) = 0.5_pReal &
|
math_identity4th(i,j,k,l) = 0.5_pReal &
|
||||||
*(identity2nd(i,k)*identity2nd(j,l)+identity2nd(i,l)*identity2nd(j,k))
|
*(identity2nd(i,k)*identity2nd(j,l)+identity2nd(i,l)*identity2nd(j,k))
|
||||||
|
@ -1240,23 +1236,23 @@ subroutine selfTest
|
||||||
if(dNeq(math_det33(math_symmetric33(t33)),math_detSym33(math_symmetric33(t33)),tol=1.0e-12_pReal)) &
|
if(dNeq(math_det33(math_symmetric33(t33)),math_detSym33(math_symmetric33(t33)),tol=1.0e-12_pReal)) &
|
||||||
call IO_error(0,ext_msg='math_det33/math_detSym33')
|
call IO_error(0,ext_msg='math_det33/math_detSym33')
|
||||||
|
|
||||||
if(any(dNeq0(math_identity2nd(3),math_inv33(math_I3)))) &
|
if(any(dNeq0(math_eye(3),math_inv33(math_I3)))) &
|
||||||
call IO_error(0,ext_msg='math_inv33(math_I3)')
|
call IO_error(0,ext_msg='math_inv33(math_I3)')
|
||||||
|
|
||||||
do while(abs(math_det33(t33))<1.0e-9_pReal)
|
do while(abs(math_det33(t33))<1.0e-9_pReal)
|
||||||
call random_number(t33)
|
call random_number(t33)
|
||||||
enddo
|
enddo
|
||||||
if(any(dNeq0(matmul(t33,math_inv33(t33)) - math_identity2nd(3),tol=1.0e-9_pReal))) &
|
if(any(dNeq0(matmul(t33,math_inv33(t33)) - math_eye(3),tol=1.0e-9_pReal))) &
|
||||||
call IO_error(0,ext_msg='math_inv33')
|
call IO_error(0,ext_msg='math_inv33')
|
||||||
|
|
||||||
call math_invert33(t33_2,det,e,t33)
|
call math_invert33(t33_2,det,e,t33)
|
||||||
if(any(dNeq0(matmul(t33,t33_2) - math_identity2nd(3),tol=1.0e-9_pReal)) .or. e) &
|
if(any(dNeq0(matmul(t33,t33_2) - math_eye(3),tol=1.0e-9_pReal)) .or. e) &
|
||||||
call IO_error(0,ext_msg='math_invert33: T:T^-1 != I')
|
call IO_error(0,ext_msg='math_invert33: T:T^-1 != I')
|
||||||
if(dNeq(det,math_det33(t33),tol=1.0e-12_pReal)) &
|
if(dNeq(det,math_det33(t33),tol=1.0e-12_pReal)) &
|
||||||
call IO_error(0,ext_msg='math_invert33 (determinant)')
|
call IO_error(0,ext_msg='math_invert33 (determinant)')
|
||||||
|
|
||||||
call math_invert(t33_2,e,t33)
|
call math_invert(t33_2,e,t33)
|
||||||
if(any(dNeq0(matmul(t33,t33_2) - math_identity2nd(3),tol=1.0e-9_pReal)) .or. e) &
|
if(any(dNeq0(matmul(t33,t33_2) - math_eye(3),tol=1.0e-9_pReal)) .or. e) &
|
||||||
call IO_error(0,ext_msg='math_invert t33')
|
call IO_error(0,ext_msg='math_invert t33')
|
||||||
|
|
||||||
do while(math_det33(t33)<1.0e-2_pReal) ! O(det(F)) = 1
|
do while(math_det33(t33)<1.0e-2_pReal) ! O(det(F)) = 1
|
||||||
|
@ -1269,14 +1265,14 @@ subroutine selfTest
|
||||||
|
|
||||||
call random_number(r)
|
call random_number(r)
|
||||||
d = int(r*5.0_pReal) + 1
|
d = int(r*5.0_pReal) + 1
|
||||||
txx = math_identity2nd(d)
|
txx = math_eye(d)
|
||||||
allocate(txx_2(d,d))
|
allocate(txx_2(d,d))
|
||||||
call math_invert(txx_2,e,txx)
|
call math_invert(txx_2,e,txx)
|
||||||
if(any(dNeq0(txx_2,txx) .or. e)) &
|
if(any(dNeq0(txx_2,txx) .or. e)) &
|
||||||
call IO_error(0,ext_msg='math_invert(txx)/math_identity2nd')
|
call IO_error(0,ext_msg='math_invert(txx)/math_eye')
|
||||||
|
|
||||||
call math_invert(t99_2,e,t99) ! not sure how likely it is that we get a singular matrix
|
call math_invert(t99_2,e,t99) ! not sure how likely it is that we get a singular matrix
|
||||||
if(any(dNeq0(matmul(t99_2,t99)-math_identity2nd(9),tol=1.0e-9_pReal)) .or. e) &
|
if(any(dNeq0(matmul(t99_2,t99)-math_eye(9),tol=1.0e-9_pReal)) .or. e) &
|
||||||
call IO_error(0,ext_msg='math_invert(t99)')
|
call IO_error(0,ext_msg='math_invert(t99)')
|
||||||
|
|
||||||
if(any(dNeq(math_clip([4.0_pReal,9.0_pReal],5.0_pReal,6.5_pReal),[5.0_pReal,6.5_pReal]))) &
|
if(any(dNeq(math_clip([4.0_pReal,9.0_pReal],5.0_pReal,6.5_pReal),[5.0_pReal,6.5_pReal]))) &
|
||||||
|
|
|
@ -96,7 +96,7 @@ program DAMASK_mesh
|
||||||
|
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
! reading basic information from load case file and allocate data structure containing load cases
|
! reading basic information from load case file and allocate data structure containing load cases
|
||||||
fileContent = IO_readline(trim(interface_loadFile))
|
fileContent = IO_readlines(trim(interface_loadFile))
|
||||||
do l = 1, size(fileContent)
|
do l = 1, size(fileContent)
|
||||||
line = fileContent(l)
|
line = fileContent(l)
|
||||||
if (IO_isBlank(line)) cycle ! skip empty lines
|
if (IO_isBlank(line)) cycle ! skip empty lines
|
||||||
|
|
Loading…
Reference in New Issue