- nssNumber of slip systems
C++ Type:int
Description:Number of slip systems
- slip_sys_file_nameName of the file containing the slip system
C++ Type:FileName
Description:Name of the file containing the slip system
Finite Strain Crystal Plasticity
Crystal Plasticity base class: FCC system with power law flow rule implemented
Description
The FiniteStrainCrystalPlasticity
model is maintained but not actively developed. Use of the FiniteStrainUObasedCP crystal plasticity system is recommend instead.
Constitutive models are used to calculate the plastic slip rate. In this crystal plasticity material the slip rate is modeled as a power law: (1) where is a reference slip rate, is the applied shear stress on each slip system , is the slip system strength, or resistance to slip, and is the strain rate sensitivity exponent. The strength of each slip system is solved with an iterative process as a function of the slip increment (2) where is a hardening coefficient matrix that accounts for the different in self and latent hardening, Eq. (3), is an initial hardening term, is a constant saturated hardening value, and is the hardening exponent (Kalidindi et al., 1992). The self and latent hardening of the crystal is defined for an FCC system as (3) where is a constant value of latent hardening among non-coplanar slip systems. In Eq. (3) the slip systems which share the same slip plane normal (e.g. ) are coplanar and grouped together with a latent hardening rate of unity (Kalidindi et al., 1992). Each matrix entry in Eq. (3) represents the interaction among two different coplanar slip system groups, that is a total of six slip systems (Kalidindi et al., 1992).
In this class, the crystal strain and stress response with response to the residual calculated by the second Piola-Kirchoff stress increment. In contrast, in FiniteStrainCPSlipRateRes the convergence of the crystal plasticity strain and stress response is determined with respect to the slip rate on each slip system of the crystal plasticity model.
Units Assumed in the Crystal Plasticity Materials
The simulation domain for crystal plasticity models is resolved on the order of individual crystal grains, and, as such, the mesh size is small. Although MOOSE itself is dimension agnostic, the crystal plasticity models are implemented in the mm-MPa-s unit system. This dimension system choice impacts the input files in the following manner:
Mesh dimensions should be constructed in mm
Elastic constant values (e.g. Young's modulus and shear modulus) are entered in MPa
Initial slip system strength values are entered in MPa
Simulation times are given in s
Strain rates and displacement loading rates are given in 1/s and mm/s, respectively
In physically based models, which maybe based on this class, initial densities of crystal defects (e.g. dislocations, point defects) should be given in 1/mm or 1/mm
Input Parameters
- abs_tol1e-06Constitutive stress residue absolute tolerance
Default:1e-06
C++ Type:double
Description:Constitutive stress residue absolute tolerance
- base_nameOptional parameter that allows the user to define multiple mechanics material systems on the same block, i.e. for multiple phases
C++ Type:std::string
Description:Optional parameter that allows the user to define multiple mechanics material systems on the same block, i.e. for multiple phases
- blockThe list of block ids (SubdomainID) that this object will be applied
C++ Type:std::vector
Description:The list of block ids (SubdomainID) that this object will be applied
- boundaryThe list of boundary IDs from the mesh where this boundary condition applies
C++ Type:std::vector
Description:The list of boundary IDs from the mesh where this boundary condition applies
- computeTrueWhen false, MOOSE will not call compute methods on this material. The user must call computeProperties() after retrieving the MaterialBase via MaterialBasePropertyInterface::getMaterialBase(). Non-computed MaterialBases are not sorted for dependencies.
Default:True
C++ Type:bool
Description:When false, MOOSE will not call compute methods on this material. The user must call computeProperties() after retrieving the MaterialBase via MaterialBasePropertyInterface::getMaterialBase(). Non-computed MaterialBases are not sorted for dependencies.
- constant_onNONEWhen ELEMENT, MOOSE will only call computeQpProperties() for the 0th quadrature point, and then copy that value to the other qps.When SUBDOMAIN, MOOSE will only call computeSubdomainProperties() for the 0th quadrature point, and then copy that value to the other qps. Evaluations on element qps will be skipped
Default:NONE
C++ Type:MooseEnum
Description:When ELEMENT, MOOSE will only call computeQpProperties() for the 0th quadrature point, and then copy that value to the other qps.When SUBDOMAIN, MOOSE will only call computeSubdomainProperties() for the 0th quadrature point, and then copy that value to the other qps. Evaluations on element qps will be skipped
- flowpropsParameters used in slip rate equations
C++ Type:std::vector
Description:Parameters used in slip rate equations
- gen_random_stress_flagFalseFlag to generate random stress to perform time cutback on constitutive failure
Default:False
C++ Type:bool
Description:Flag to generate random stress to perform time cutback on constitutive failure
- gpropsInitial values of slip system resistances
C++ Type:std::vector
Description:Initial values of slip system resistances
- gtol100Constitutive slip system resistance residual tolerance
Default:100
C++ Type:double
Description:Constitutive slip system resistance residual tolerance
- hpropsHardening properties
C++ Type:std::vector
Description:Hardening properties
- input_random_scaling_varFalseFlag to input scaling variable: _Cijkl(0,0,0,0) when false
Default:False
C++ Type:bool
Description:Flag to input scaling variable: _Cijkl(0,0,0,0) when false
- intvar_read_typenoneRead from options for initial value of internal variables: Default from .i file
Default:none
C++ Type:MooseEnum
Description:Read from options for initial value of internal variables: Default from .i file
- line_search_maxiter20Line search bisection method maximum number of iteration
Default:20
C++ Type:unsigned int
Description:Line search bisection method maximum number of iteration
- line_search_methodCUT_HALFThe method used in line search
Default:CUT_HALF
C++ Type:MooseEnum
Description:The method used in line search
- line_search_tol0.5Line search bisection method tolerance
Default:0.5
C++ Type:double
Description:Line search bisection method tolerance
- maximum_substep_iteration1Maximum number of substep iteration
Default:1
C++ Type:unsigned int
Description:Maximum number of substep iteration
- maxiter100Maximum number of iterations for stress update
Default:100
C++ Type:unsigned int
Description:Maximum number of iterations for stress update
- maxitergss100Maximum number of iterations for slip system resistance update
Default:100
C++ Type:unsigned int
Description:Maximum number of iterations for slip system resistance update
- min_line_search_step_size0.01Minimum line search step size
Default:0.01
C++ Type:double
Description:Minimum line search step size
- num_slip_sys_flowrate_props2Number of flow rate properties for a slip system
Default:2
C++ Type:unsigned int
Description:Number of flow rate properties for a slip system
- num_slip_sys_props0Number of slip system specific properties provided in the file containing slip system normals and directions
Default:0
C++ Type:unsigned int
Description:Number of slip system specific properties provided in the file containing slip system normals and directions
- random_scaling_var1e+09Random scaling variable: Large value can cause non-positive definiteness
Default:1e+09
C++ Type:double
Description:Random scaling variable: Large value can cause non-positive definiteness
- random_seed2000Random integer used to generate random stress when constitutive failure occurs
Default:2000
C++ Type:unsigned int
Description:Random integer used to generate random stress when constitutive failure occurs
- read_prop_user_objectThe ElementReadPropertyFile GeneralUserObject to read element specific property values from file
C++ Type:UserObjectName
Description:The ElementReadPropertyFile GeneralUserObject to read element specific property values from file
- rtol1e-06Constitutive stress residue relative tolerance
Default:1e-06
C++ Type:double
Description:Constitutive stress residue relative tolerance
- slip_incr_tol0.02Maximum allowable slip in an increment
Default:0.02
C++ Type:double
Description:Maximum allowable slip in an increment
- slip_sys_flow_prop_file_nameName of the file containing the values of slip rate equation parameters
C++ Type:FileName
Description:Name of the file containing the values of slip rate equation parameters
- slip_sys_hard_prop_file_nameName of the file containing the values of hardness evolution parameters
C++ Type:FileName
Description:Name of the file containing the values of hardness evolution parameters
- slip_sys_res_prop_file_nameName of the file containing the initial values of slip system resistances
C++ Type:FileName
Description:Name of the file containing the initial values of slip system resistances
- tan_mod_typenoneType of tangent moduli for preconditioner: default elastic
Default:none
C++ Type:MooseEnum
Description:Type of tangent moduli for preconditioner: default elastic
- use_line_searchFalseUse line search in constitutive update
Default:False
C++ Type:bool
Description:Use line search in constitutive update
Optional Parameters
- control_tagsAdds user-defined labels for accessing object parameters via control logic.
C++ Type:std::vector
Description:Adds user-defined labels for accessing object parameters via control logic.
- enableTrueSet the enabled status of the MooseObject.
Default:True
C++ Type:bool
Description:Set the enabled status of the MooseObject.
- implicitTrueDetermines whether this object is calculated using an implicit or explicit form
Default:True
C++ Type:bool
Description:Determines whether this object is calculated using an implicit or explicit form
- seed0The seed for the master random number generator
Default:0
C++ Type:unsigned int
Description:The seed for the master random number generator
Advanced Parameters
- output_propertiesList of material properties, from this material, to output (outputs must also be defined to an output type)
C++ Type:std::vector
Description:List of material properties, from this material, to output (outputs must also be defined to an output type)
- outputsnone Vector of output names were you would like to restrict the output of variables(s) associated with this object
Default:none
C++ Type:std::vector
Description:Vector of output names were you would like to restrict the output of variables(s) associated with this object
Outputs Parameters
Input Files
- modules/tensor_mechanics/test/tests/crystal_plasticity/crysp_fileread.i
- modules/tensor_mechanics/test/tests/crystal_plasticity/crysp_user_object.i
- modules/tensor_mechanics/test/tests/crystal_plasticity/rot-eg1.i
- modules/tensor_mechanics/test/tests/crystal_plasticity/crysp_read_slip_prop.i
- modules/tensor_mechanics/test/tests/crystal_plasticity/crysp.i
- modules/tensor_mechanics/test/tests/crystal_plasticity/crysp_cutback.i
- modules/tensor_mechanics/test/tests/crystal_plasticity/orthotropic_rotation_Cijkl.i
- modules/tensor_mechanics/test/tests/crystal_plasticity/karthik-eg-1.i
- modules/tensor_mechanics/test/tests/crystal_plasticity/crysp_linesearch.i
- modules/tensor_mechanics/test/tests/crystal_plasticity/crysp_save_euler.i
- modules/tensor_mechanics/test/tests/crystal_plasticity/crysp_substep.i
Child Objects
References
- Surya R Kalidindi, Curt A Bronkhorst, and Lallit Anand.
Crystallographic texture evolution in bulk deformation processing of fcc metals.
Journal of the Mechanics and Physics of Solids, 40(3):537–569, 1992.[BibTeX]