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

UnitGradient.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_Unit_Gradient_hpp)
00008 #define LCM_Unit_Gradient_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 
00015 #include "Albany_Layouts.hpp"
00016 
00017 namespace LCM {
00022   template<typename EvalT, typename Traits>
00023   class UnitGradient : public PHX::EvaluatorWithBaseImpl<Traits>,
00024                        public PHX::EvaluatorDerived<EvalT, Traits>  {
00025 
00026   public:
00027 
00031     UnitGradient(const Teuchos::ParameterList& p,
00032                  const Teuchos::RCP<Albany::Layouts>& dl);
00033 
00037     void postRegistrationSetup(typename Traits::SetupData d,
00038                                PHX::FieldManager<Traits>& vm);
00039 
00043     void evaluateFields(typename Traits::EvalData d);
00044 
00045   private:
00046 
00047     typedef typename EvalT::ScalarT ScalarT;
00048     typedef typename EvalT::MeshScalarT MeshScalarT;
00049 
00053     PHX::MDField<ScalarT,Cell,QuadPoint,Dim> scalar_grad_;
00054 
00058     PHX::MDField<ScalarT,Cell,QuadPoint,Dim> unit_grad_;
00059 
00063     std::size_t num_pts_;
00064 
00068     std::size_t num_dims_;
00069   };
00070 }
00071 
00072 #endif

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