• Main Page
  • Related Pages
  • Namespaces
  • Classes
  • Files
  • File List
  • File Members

DruckerPragerModel.hpp

Go to the documentation of this file.
00001 //*****************************************************************//
00002 //    Albany 2.0:  Copyright 2012 Sandia Corporation               //
00003 //    This Software is released under the BSD license detailed     //
00004 //    in the file "license.txt" in the top-level Albany directory  //
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

Generated on Wed Mar 26 2014 18:36:38 for Albany: a Trilinos-based PDE code by  doxygen 1.7.1