added missing pInts
This commit is contained in:
parent
a26456f9c0
commit
195491aaaa
|
@ -92,6 +92,7 @@ CONTAINS
|
|||
!*******************************************
|
||||
subroutine numerics_init()
|
||||
|
||||
use, intrinsic :: iso_fortran_env
|
||||
!*** variables and functions from other modules ***!
|
||||
use prec, only: pInt, &
|
||||
pReal
|
||||
|
@ -145,110 +146,110 @@ subroutine numerics_init()
|
|||
read(fileunit,'(a1024)',END=100) line
|
||||
if (IO_isBlank(line)) cycle ! skip empty lines
|
||||
positions = IO_stringPos(line,maxNchunks)
|
||||
tag = IO_lc(IO_stringValue(line,positions,1)) ! extract key
|
||||
tag = IO_lc(IO_stringValue(line,positions,1_pInt)) ! extract key
|
||||
select case(tag)
|
||||
case ('relevantstrain')
|
||||
relevantStrain = IO_floatValue(line,positions,2)
|
||||
relevantStrain = IO_floatValue(line,positions,2_pInt)
|
||||
case ('defgradtolerance')
|
||||
defgradTolerance = IO_floatValue(line,positions,2)
|
||||
defgradTolerance = IO_floatValue(line,positions,2_pInt)
|
||||
case ('ijacostiffness')
|
||||
iJacoStiffness = IO_intValue(line,positions,2)
|
||||
iJacoStiffness = IO_intValue(line,positions,2_pInt)
|
||||
case ('ijacolpresiduum')
|
||||
iJacoLpresiduum = IO_intValue(line,positions,2)
|
||||
iJacoLpresiduum = IO_intValue(line,positions,2_pInt)
|
||||
case ('pert_fg')
|
||||
pert_Fg = IO_floatValue(line,positions,2)
|
||||
pert_Fg = IO_floatValue(line,positions,2_pInt)
|
||||
case ('pert_method')
|
||||
pert_method = IO_intValue(line,positions,2)
|
||||
pert_method = IO_intValue(line,positions,2_pInt)
|
||||
case ('nhomog')
|
||||
nHomog = IO_intValue(line,positions,2)
|
||||
nHomog = IO_intValue(line,positions,2_pInt)
|
||||
case ('nmpstate')
|
||||
nMPstate = IO_intValue(line,positions,2)
|
||||
nMPstate = IO_intValue(line,positions,2_pInt)
|
||||
case ('ncryst')
|
||||
nCryst = IO_intValue(line,positions,2)
|
||||
nCryst = IO_intValue(line,positions,2_pInt)
|
||||
case ('nstate')
|
||||
nState = IO_intValue(line,positions,2)
|
||||
nState = IO_intValue(line,positions,2_pInt)
|
||||
case ('nstress')
|
||||
nStress = IO_intValue(line,positions,2)
|
||||
nStress = IO_intValue(line,positions,2_pInt)
|
||||
case ('substepmincryst')
|
||||
subStepMinCryst = IO_floatValue(line,positions,2)
|
||||
subStepMinCryst = IO_floatValue(line,positions,2_pInt)
|
||||
case ('substepsizecryst')
|
||||
subStepSizeCryst = IO_floatValue(line,positions,2)
|
||||
subStepSizeCryst = IO_floatValue(line,positions,2_pInt)
|
||||
case ('stepincreasecryst')
|
||||
stepIncreaseCryst = IO_floatValue(line,positions,2)
|
||||
stepIncreaseCryst = IO_floatValue(line,positions,2_pInt)
|
||||
case ('substepminhomog')
|
||||
subStepMinHomog = IO_floatValue(line,positions,2)
|
||||
subStepMinHomog = IO_floatValue(line,positions,2_pInt)
|
||||
case ('substepsizehomog')
|
||||
subStepSizeHomog = IO_floatValue(line,positions,2)
|
||||
subStepSizeHomog = IO_floatValue(line,positions,2_pInt)
|
||||
case ('stepincreasehomog')
|
||||
stepIncreaseHomog = IO_floatValue(line,positions,2)
|
||||
stepIncreaseHomog = IO_floatValue(line,positions,2_pInt)
|
||||
case ('rtol_crystallitestate')
|
||||
rTol_crystalliteState = IO_floatValue(line,positions,2)
|
||||
rTol_crystalliteState = IO_floatValue(line,positions,2_pInt)
|
||||
case ('rtol_crystallitetemperature')
|
||||
rTol_crystalliteTemperature = IO_floatValue(line,positions,2)
|
||||
rTol_crystalliteTemperature = IO_floatValue(line,positions,2_pInt)
|
||||
case ('rtol_crystallitestress')
|
||||
rTol_crystalliteStress = IO_floatValue(line,positions,2)
|
||||
rTol_crystalliteStress = IO_floatValue(line,positions,2_pInt)
|
||||
case ('atol_crystallitestress')
|
||||
aTol_crystalliteStress = IO_floatValue(line,positions,2)
|
||||
aTol_crystalliteStress = IO_floatValue(line,positions,2_pInt)
|
||||
case ('integrator')
|
||||
numerics_integrator(1) = IO_intValue(line,positions,2)
|
||||
numerics_integrator(1) = IO_intValue(line,positions,2_pInt)
|
||||
case ('integratorstiffness')
|
||||
numerics_integrator(2) = IO_intValue(line,positions,2)
|
||||
numerics_integrator(2) = IO_intValue(line,positions,2_pInt)
|
||||
|
||||
!* RGC parameters:
|
||||
case ('atol_rgc')
|
||||
absTol_RGC = IO_floatValue(line,positions,2)
|
||||
absTol_RGC = IO_floatValue(line,positions,2_pInt)
|
||||
case ('rtol_rgc')
|
||||
relTol_RGC = IO_floatValue(line,positions,2)
|
||||
relTol_RGC = IO_floatValue(line,positions,2_pInt)
|
||||
case ('amax_rgc')
|
||||
absMax_RGC = IO_floatValue(line,positions,2)
|
||||
absMax_RGC = IO_floatValue(line,positions,2_pInt)
|
||||
case ('rmax_rgc')
|
||||
relMax_RGC = IO_floatValue(line,positions,2)
|
||||
relMax_RGC = IO_floatValue(line,positions,2_pInt)
|
||||
case ('perturbpenalty_rgc')
|
||||
pPert_RGC = IO_floatValue(line,positions,2)
|
||||
pPert_RGC = IO_floatValue(line,positions,2_pInt)
|
||||
case ('relevantmismatch_rgc')
|
||||
xSmoo_RGC = IO_floatValue(line,positions,2)
|
||||
xSmoo_RGC = IO_floatValue(line,positions,2_pInt)
|
||||
case ('viscositypower_rgc')
|
||||
viscPower_RGC = IO_floatValue(line,positions,2)
|
||||
viscPower_RGC = IO_floatValue(line,positions,2_pInt)
|
||||
case ('viscositymodulus_rgc')
|
||||
viscModus_RGC = IO_floatValue(line,positions,2)
|
||||
viscModus_RGC = IO_floatValue(line,positions,2_pInt)
|
||||
case ('refrelaxationrate_rgc')
|
||||
refRelaxRate_RGC = IO_floatValue(line,positions,2)
|
||||
refRelaxRate_RGC = IO_floatValue(line,positions,2_pInt)
|
||||
case ('maxrelaxation_rgc')
|
||||
maxdRelax_RGC = IO_floatValue(line,positions,2)
|
||||
maxdRelax_RGC = IO_floatValue(line,positions,2_pInt)
|
||||
case ('maxvoldiscrepancy_rgc')
|
||||
maxVolDiscr_RGC = IO_floatValue(line,positions,2)
|
||||
maxVolDiscr_RGC = IO_floatValue(line,positions,2_pInt)
|
||||
case ('voldiscrepancymod_rgc')
|
||||
volDiscrMod_RGC = IO_floatValue(line,positions,2)
|
||||
volDiscrMod_RGC = IO_floatValue(line,positions,2_pInt)
|
||||
case ('discrepancypower_rgc')
|
||||
volDiscrPow_RGC = IO_floatValue(line,positions,2)
|
||||
volDiscrPow_RGC = IO_floatValue(line,positions,2_pInt)
|
||||
|
||||
!* spectral parameters
|
||||
case ('err_div_tol')
|
||||
err_div_tol = IO_floatValue(line,positions,2)
|
||||
err_div_tol = IO_floatValue(line,positions,2_pInt)
|
||||
case ('err_stress_tolrel')
|
||||
err_stress_tolrel = IO_floatValue(line,positions,2)
|
||||
err_stress_tolrel = IO_floatValue(line,positions,2_pInt)
|
||||
case ('itmax')
|
||||
itmax = IO_intValue(line,positions,2)
|
||||
itmax = IO_intValue(line,positions,2_pInt)
|
||||
case ('memory_efficient')
|
||||
memory_efficient = IO_intValue(line,positions,2) > 0_pInt
|
||||
memory_efficient = IO_intValue(line,positions,2_pInt) > 0_pInt
|
||||
case ('fftw_timelimit')
|
||||
fftw_timelimit = IO_floatValue(line,positions,2)
|
||||
fftw_timelimit = IO_floatValue(line,positions,2_pInt)
|
||||
case ('fftw_planner_string')
|
||||
fftw_planner_string = IO_stringValue(line,positions,2)
|
||||
fftw_planner_string = IO_stringValue(line,positions,2_pInt)
|
||||
case ('rotation_tol')
|
||||
rotation_tol = IO_floatValue(line,positions,2)
|
||||
rotation_tol = IO_floatValue(line,positions,2_pInt)
|
||||
case ('divergence_correction')
|
||||
divergence_correction = IO_intValue(line,positions,2) > 0_pInt
|
||||
divergence_correction = IO_intValue(line,positions,2_pInt) > 0_pInt
|
||||
case ('update_gamma')
|
||||
update_gamma = IO_intValue(line,positions,2) > 0_pInt
|
||||
update_gamma = IO_intValue(line,positions,2_pInt) > 0_pInt
|
||||
case ('simplified_algorithm')
|
||||
simplified_algorithm = IO_intValue(line,positions,2) > 0_pInt
|
||||
simplified_algorithm = IO_intValue(line,positions,2_pInt) > 0_pInt
|
||||
case ('cut_off_value')
|
||||
cut_off_value = IO_floatValue(line,positions,2)
|
||||
cut_off_value = IO_floatValue(line,positions,2_pInt)
|
||||
|
||||
!* Random seeding parameters
|
||||
case ('fixed_seed')
|
||||
fixedSeed = IO_intValue(line,positions,2)
|
||||
fixedSeed = IO_intValue(line,positions,2_pInt)
|
||||
endselect
|
||||
enddo
|
||||
100 close(fileunit)
|
||||
|
@ -341,50 +342,50 @@ subroutine numerics_init()
|
|||
!$ write(6,'(a24,1x,i8,/)') ' number of threads: ',DAMASK_NumThreadsInt
|
||||
|
||||
! sanity check
|
||||
if (relevantStrain <= 0.0_pReal) call IO_error(260)
|
||||
if (defgradTolerance <= 0.0_pReal) call IO_error(294)
|
||||
if (iJacoStiffness < 1_pInt) call IO_error(261)
|
||||
if (iJacoLpresiduum < 1_pInt) call IO_error(262)
|
||||
if (pert_Fg <= 0.0_pReal) call IO_error(263)
|
||||
if (relevantStrain <= 0.0_pReal) call IO_error(260_pInt)
|
||||
if (defgradTolerance <= 0.0_pReal) call IO_error(294_pInt)
|
||||
if (iJacoStiffness < 1_pInt) call IO_error(261_pInt)
|
||||
if (iJacoLpresiduum < 1_pInt) call IO_error(262_pInt)
|
||||
if (pert_Fg <= 0.0_pReal) call IO_error(263_pInt)
|
||||
if (pert_method <= 0_pInt .or. pert_method >= 4_pInt) &
|
||||
call IO_error(299)
|
||||
if (nHomog < 1_pInt) call IO_error(264)
|
||||
if (nMPstate < 1_pInt) call IO_error(279) !! missing in IO !!
|
||||
if (nCryst < 1_pInt) call IO_error(265)
|
||||
if (nState < 1_pInt) call IO_error(266)
|
||||
if (nStress < 1_pInt) call IO_error(267)
|
||||
if (subStepMinCryst <= 0.0_pReal) call IO_error(268)
|
||||
if (subStepSizeCryst <= 0.0_pReal) call IO_error(268)
|
||||
if (stepIncreaseCryst <= 0.0_pReal) call IO_error(268)
|
||||
if (subStepMinHomog <= 0.0_pReal) call IO_error(268)
|
||||
if (subStepSizeHomog <= 0.0_pReal) call IO_error(268)
|
||||
if (stepIncreaseHomog <= 0.0_pReal) call IO_error(268)
|
||||
if (rTol_crystalliteState <= 0.0_pReal) call IO_error(269)
|
||||
if (rTol_crystalliteTemperature <= 0.0_pReal) call IO_error(276) !! oops !!
|
||||
if (rTol_crystalliteStress <= 0.0_pReal) call IO_error(270)
|
||||
if (aTol_crystalliteStress <= 0.0_pReal) call IO_error(271)
|
||||
call IO_error(299_pInt)
|
||||
if (nHomog < 1_pInt) call IO_error(264_pInt)
|
||||
if (nMPstate < 1_pInt) call IO_error(279_pInt) !! missing in IO !!
|
||||
if (nCryst < 1_pInt) call IO_error(265_pInt)
|
||||
if (nState < 1_pInt) call IO_error(266_pInt)
|
||||
if (nStress < 1_pInt) call IO_error(267_pInt)
|
||||
if (subStepMinCryst <= 0.0_pReal) call IO_error(268_pInt)
|
||||
if (subStepSizeCryst <= 0.0_pReal) call IO_error(268_pInt)
|
||||
if (stepIncreaseCryst <= 0.0_pReal) call IO_error(268_pInt)
|
||||
if (subStepMinHomog <= 0.0_pReal) call IO_error(268_pInt)
|
||||
if (subStepSizeHomog <= 0.0_pReal) call IO_error(268_pInt)
|
||||
if (stepIncreaseHomog <= 0.0_pReal) call IO_error(268_pInt)
|
||||
if (rTol_crystalliteState <= 0.0_pReal) call IO_error(269_pInt)
|
||||
if (rTol_crystalliteTemperature <= 0.0_pReal) call IO_error(276_pInt) !! oops !!
|
||||
if (rTol_crystalliteStress <= 0.0_pReal) call IO_error(270_pInt)
|
||||
if (aTol_crystalliteStress <= 0.0_pReal) call IO_error(271_pInt)
|
||||
if (any(numerics_integrator <= 0_pInt) .or. any(numerics_integrator >= 6_pInt)) &
|
||||
call IO_error(298)
|
||||
call IO_error(298_pInt)
|
||||
|
||||
!* RGC parameters: added <<<updated 17.11.2009>>>
|
||||
if (absTol_RGC <= 0.0_pReal) call IO_error(272)
|
||||
if (relTol_RGC <= 0.0_pReal) call IO_error(273)
|
||||
if (absMax_RGC <= 0.0_pReal) call IO_error(274)
|
||||
if (relMax_RGC <= 0.0_pReal) call IO_error(275)
|
||||
if (pPert_RGC <= 0.0_pReal) call IO_error(276) !! oops !!
|
||||
if (xSmoo_RGC <= 0.0_pReal) call IO_error(277)
|
||||
if (viscPower_RGC < 0.0_pReal) call IO_error(278)
|
||||
if (viscModus_RGC < 0.0_pReal) call IO_error(278)
|
||||
if (refRelaxRate_RGC <= 0.0_pReal) call IO_error(278)
|
||||
if (maxdRelax_RGC <= 0.0_pReal) call IO_error(288)
|
||||
if (maxVolDiscr_RGC <= 0.0_pReal) call IO_error(289)
|
||||
if (volDiscrMod_RGC < 0.0_pReal) call IO_error(289)
|
||||
if (volDiscrPow_RGC <= 0.0_pReal) call IO_error(289)
|
||||
|
||||
if (absTol_RGC <= 0.0_pReal) call IO_error(272_pInt)
|
||||
if (relTol_RGC <= 0.0_pReal) call IO_error(273_pInt)
|
||||
if (absMax_RGC <= 0.0_pReal) call IO_error(274_pInt)
|
||||
if (relMax_RGC <= 0.0_pReal) call IO_error(275_pInt)
|
||||
if (pPert_RGC <= 0.0_pReal) call IO_error(276_pInt) !! oops !!
|
||||
if (xSmoo_RGC <= 0.0_pReal) call IO_error(277_pInt)
|
||||
if (viscPower_RGC < 0.0_pReal) call IO_error(278_pInt)
|
||||
if (viscModus_RGC < 0.0_pReal) call IO_error(278_pInt)
|
||||
if (refRelaxRate_RGC <= 0.0_pReal) call IO_error(278_pInt)
|
||||
if (maxdRelax_RGC <= 0.0_pReal) call IO_error(288_pInt)
|
||||
if (maxVolDiscr_RGC <= 0.0_pReal) call IO_error(289_pInt)
|
||||
if (volDiscrMod_RGC < 0.0_pReal) call IO_error(289_pInt)
|
||||
if (volDiscrPow_RGC <= 0.0_pReal) call IO_error(289_pInt)
|
||||
|
||||
!* spectral parameters
|
||||
if (err_div_tol <= 0.0_pReal) call IO_error(49)
|
||||
if (err_stress_tolrel <= 0.0_pReal) call IO_error(49)
|
||||
if (itmax <= 1.0_pInt) call IO_error(49)
|
||||
if (err_div_tol <= 0.0_pReal) call IO_error(49_pInt)
|
||||
if (err_stress_tolrel <= 0.0_pReal) call IO_error(49_pInt)
|
||||
if (itmax <= 1.0_pInt) call IO_error(49_pInt)
|
||||
|
||||
if (fixedSeed <= 0_pInt) then
|
||||
!$OMP CRITICAL (write2out)
|
||||
|
|
Loading…
Reference in New Issue