Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007 #if !defined(LCM_ElasticDamageModel_hpp)
00008 #define LCM_ElasticDamageModel_hpp
00009
00010 #include "Phalanx_ConfigDefs.hpp"
00011 #include "Phalanx_Evaluator_WithBaseImpl.hpp"
00012 #include "Phalanx_Evaluator_Derived.hpp"
00013 #include "Phalanx_MDField.hpp"
00014 #include "Albany_Layouts.hpp"
00015 #include "LCM/models/ConstitutiveModel.hpp"
00016
00017 namespace LCM
00018 {
00019
00021 template<typename EvalT, typename Traits>
00022 class ElasticDamageModel: public LCM::ConstitutiveModel<EvalT, Traits>
00023 {
00024 public:
00025
00026 typedef typename EvalT::ScalarT ScalarT;
00027 typedef typename EvalT::MeshScalarT MeshScalarT;
00028
00029 using ConstitutiveModel<EvalT, Traits>::num_dims_;
00030 using ConstitutiveModel<EvalT, Traits>::num_pts_;
00031 using ConstitutiveModel<EvalT, Traits>::field_name_map_;
00032
00036 ElasticDamageModel(Teuchos::ParameterList* p,
00037 const Teuchos::RCP<Albany::Layouts>& dl);
00038
00042 virtual
00043 ~ElasticDamageModel()
00044 {};
00045
00049 virtual
00050 void
00051 computeState(typename Traits::EvalData workset,
00052 std::map<std::string, Teuchos::RCP<PHX::MDField<ScalarT> > > dep_fields,
00053 std::map<std::string, Teuchos::RCP<PHX::MDField<ScalarT> > > eval_fields);
00054
00055 private:
00056
00060 ElasticDamageModel(const ElasticDamageModel&);
00061
00065 ElasticDamageModel& operator=(const ElasticDamageModel&);
00066
00070 RealType max_damage_, saturation_;
00071
00072 };
00073 }
00074
00075 #endif