CHROMA
inline_propagator_s.h
Go to the documentation of this file.
1 // -*- C++ -*-
2 /*! \file
3  * \brief Inline construction of propagator
4  *
5  * Propagator calculations
6  */
7 
8 #ifndef __inline_propagator_s_h__
9 #define __inline_propagator_s_h__
10 
11 #include "chromabase.h"
13 #include "io/qprop_io.h"
14 
15 namespace Chroma
16 {
17  /*! \ingroup inlinehadron */
18  namespace InlineStaggeredPropagatorEnv
19  {
20  extern const std::string name;
21  bool registerAll();
22 
23  //! Parameter structure
24  /*! \ingroup inlinehadron */
25  struct Params
26  {
27  Params();
28  Params(XMLReader& xml_in, const std::string& path);
29  void writeXML(XMLWriter& xml_out, const std::string& path);
30 
31  unsigned long frequency;
32 
34 
36  {
41 
42  std::string xml_file; // Alternate XML file pattern
43  };
44 
45  //! Inline computation of propagators
46  /*! \ingroup inlinehadron */
48  {
49  public:
51  InlineMeas(const Params& p) : params(p) {}
53 
54  unsigned long getFrequency(void) const {return params.frequency;}
55 
56  //! Do the measurement
57  void operator()(const unsigned long update_no,
58  XMLWriter& xml_out);
59 
60  protected:
61  //! Do the measurement
62  void func(const unsigned long update_no,
63  XMLWriter& xml_out);
64 
65  private:
67  };
68 
69  }
70 
71 }
72 
73 #endif
Abstract inline measurements.
Primary include file for CHROMA library code.
unsigned long getFrequency(void) const
Tell me how often I should measure this beastie.
void operator()(const unsigned long update_no, XMLWriter &xml_out)
Do the measurement.
void func(const unsigned long update_no, XMLWriter &xml_out)
Do the measurement.
bool registerAll()
Register all the factories.
Asqtad Staggered-Dirac operator.
Definition: klein_gord.cc:10
::std::string string
Definition: gtest.h:1979
Routines associated with Chroma propagator IO.
Propagator parameters.
Definition: qprop_io.h:75
void writeXML(XMLWriter &xml_out, const std::string &path)
struct Chroma::InlineStaggeredPropagatorEnv::Params::NamedObject_t named_obj