source: src/Potentials/PotentialFactory.hpp@ e83114

Candidate_v1.7.0 stable
Last change on this file since e83114 was e83114, checked in by Frederik Heber <frederik.heber@…>, 8 weeks ago

StreamFactory_EmpiricalPotential creates potential instances with params.

  • EmpiricalPotential expose getter and setter for parameters.
  • potential and stream factor for EmpiricalPotential have new createInstance that also takes a present parameter set.
  • this is used in StreamFactory_EmpiricalPotential::createInstance from istream to create the correct instance with parameters directly.
  • Property mode set to 100644
File size: 2.4 KB
Line 
1/*
2 * PotentialFactory.hpp
3 *
4 * Created on: 30.11.2012
5 * Author: heber
6 */
7
8#ifndef POTENTIALFACTORY_HPP_
9#define POTENTIALFACTORY_HPP_
10
11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
16#include <string>
17#include <iosfwd>
18
19#include "CodePatterns/Singleton.hpp"
20
21#include "Potentials/EmpiricalPotential.hpp"
22#include "Potentials/Specifics/PotentialTypes.hpp"
23#include "Potentials/StreamFactory_EmpiricalPotential.hpp"
24
25/** Class that creates instances of potentials.
26 *
27 * This is a factory pattern.
28 *
29 */
30class PotentialFactory :
31 public Singleton<PotentialFactory>,
32 public StreamFactory<EmpiricalPotential>
33{
34 //!> make Singleton template friend
35 friend class Singleton<PotentialFactory>;
36
37protected:
38
39 /** Returns a default potential to which only we have access.
40 *
41 */
42 EmpiricalPotential* getDefaultPotential(const std::string &_name) const;
43
44public:
45
46 /** Returns a default potential to which only we have access.
47 *
48 */
49 EmpiricalPotential const * const getDefaultPotential(const enum PotentialTypes &_type) const;
50
51
52 /** Creates an instance of the requested potential.
53 *
54 * \param potentialtype key of potential to create
55 * \param charges charges for which the potential is (to be) fitted
56 */
57 EmpiricalPotential *createInstance(
58 const std::string &potentialtype,
59 const SerializablePotential::ParticleTypes_t &charges) const;
60
61 /** Creates an instance of the requested potential.
62 *
63 * \param potentialtype key of potential to create
64 * \param charges charges for which the potential is (to be) fitted
65 */
66 EmpiricalPotential *createInstance(
67 const std::string &potentialtype,
68 const SerializablePotential::ParticleTypes_t &charges,
69 const FunctionModel::parameters_t &params) const;
70
71 //!> typedef for map to lookup type for a given name
72 typedef std::map< std::string, enum PotentialTypes > NameToType_t;
73
74 //!> map for looking up type to a given name
75 static NameToType_t NameToType;
76
77 //!> typedef for map to lookup name for a given type
78 typedef std::map< enum PotentialTypes,std::string > TypeToName_t;
79
80 //!> map for looking up type to a given name
81 static TypeToName_t TypeToName;
82
83 static enum PotentialTypes getTypeForName(const std::string &_name);
84
85 static const std::string & getNameForType(enum PotentialTypes _type);
86
87private:
88 PotentialFactory() {}
89 ~PotentialFactory() {}
90};
91
92#endif /* POTENTIALFACTORY_HPP_ */
Note: See TracBrowser for help on using the repository browser.