added missing pInts

This commit is contained in:
Martin Diehl 2012-02-09 12:35:55 +00:00
parent a26456f9c0
commit 195491aaaa
1 changed files with 89 additions and 88 deletions

View File

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