00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032 #ifndef PHX_EXAMPLE_VP_FE_INTERPOLATION_HPP
00033 #define PHX_EXAMPLE_VP_FE_INTERPOLATION_HPP
00034
00035 #include "Phalanx_ConfigDefs.hpp"
00036 #include "Phalanx_Evaluator_WithBaseImpl.hpp"
00037 #include "Phalanx_Evaluator_Derived.hpp"
00038 #include "Phalanx_MDField.hpp"
00039
00046 template<typename EvalT, typename Traits>
00047 class FEInterpolation : public PHX::EvaluatorWithBaseImpl<Traits>,
00048 public PHX::EvaluatorDerived<EvalT, Traits> {
00049
00050 public:
00051
00052 FEInterpolation(const Teuchos::ParameterList& p);
00053
00054 void postRegistrationSetup(PHX::FieldManager<Traits>& vm);
00055
00056 void evaluateFields(typename Traits::EvalData d);
00057
00058 private:
00059
00060 typedef typename EvalT::ScalarT ScalarT;
00061
00063 PHX::MDField<ScalarT,PHX::NaturalOrder,Cell,Node> val_node;
00064
00066 PHX::MDField<ScalarT,PHX::NaturalOrder,Cell,QuadPoint> val_qp;
00067
00069 PHX::MDField<ScalarT,PHX::NaturalOrder,Cell,QuadPoint,Dim> val_grad_qp;
00070
00071 std::size_t num_nodes;
00072 std::size_t num_qp;
00073 std::size_t num_dim;
00074
00075 };
00076
00077 #include "Evaluator_FEInterpolation_Def.hpp"
00078
00079 #endif