Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007 #if !defined(LCM_DruckerPragerModel_hpp)
00008 #define LCM_DruckerPragerModel_hpp
00009
00010 #include <Intrepid_MiniTensor.h>
00011 #include "Phalanx_ConfigDefs.hpp"
00012 #include "Phalanx_Evaluator_WithBaseImpl.hpp"
00013 #include "Phalanx_Evaluator_Derived.hpp"
00014 #include "Phalanx_MDField.hpp"
00015 #include "Albany_Layouts.hpp"
00016 #include "LCM/models/ConstitutiveModel.hpp"
00017
00018 #include "Sacado.hpp"
00019
00020 namespace LCM
00021 {
00022
00027
00028 template<typename EvalT, typename Traits>
00029 class DruckerPragerModel: public LCM::ConstitutiveModel<EvalT, Traits>
00030 {
00031
00032 public:
00033
00034 typedef typename EvalT::ScalarT ScalarT;
00035 typedef typename EvalT::MeshScalarT MeshScalarT;
00036 typedef typename Sacado::mpl::apply<FadType,ScalarT>::type DFadType;
00037
00038 using ConstitutiveModel<EvalT, Traits>::num_dims_;
00039 using ConstitutiveModel<EvalT, Traits>::num_pts_;
00040 using ConstitutiveModel<EvalT, Traits>::field_name_map_;
00041
00045 DruckerPragerModel(Teuchos::ParameterList* p,
00046 const Teuchos::RCP<Albany::Layouts>& dl);
00047
00051 virtual
00052 ~DruckerPragerModel()
00053 {};
00054
00058 virtual
00059 void
00060 computeState(typename Traits::EvalData workset,
00061 std::map<std::string, Teuchos::RCP<PHX::MDField<ScalarT> > > dep_fields,
00062 std::map<std::string, Teuchos::RCP<PHX::MDField<ScalarT> > > eval_fields);
00063
00064 private:
00065
00069 DruckerPragerModel(const DruckerPragerModel&);
00070
00074 DruckerPragerModel& operator=(const DruckerPragerModel&);
00075
00079 RealType a0_, a1_, a2_, a3_, b0_;
00080
00084 RealType Cf_, Cg_;
00085
00089 void
00090 ResidualJacobian(std::vector<ScalarT> & X,
00091 std::vector<ScalarT> & R, std::vector<ScalarT> & dRdX,
00092 const ScalarT ptr, const ScalarT qtr, const ScalarT eqN,
00093 const ScalarT mu, const ScalarT kappa);
00094
00095 };
00096 }
00097
00098 #endif