source: src/Potentials/PotentialFactory.hpp@ a0d8aa

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

PotentialFactory exposes particle type numbers.

  • Also, potentials use getParticleTypeNumber() in asserts.
  • Property mode set to 100644
File size: 2.7 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 /** Returns the number of particle types for the given potential.
72 *
73 * \param _name name of the potential
74 * \return number of particle types needed by the potential, 0 if potential unknown
75 */
76 unsigned int getPotentialsParticleTypeNumber(const std::string &_name) const;
77
78 //!> typedef for map to lookup type for a given name
79 typedef std::map< std::string, enum PotentialTypes > NameToType_t;
80
81 //!> map for looking up type to a given name
82 static NameToType_t NameToType;
83
84 //!> typedef for map to lookup name for a given type
85 typedef std::map< enum PotentialTypes,std::string > TypeToName_t;
86
87 //!> map for looking up type to a given name
88 static TypeToName_t TypeToName;
89
90 static enum PotentialTypes getTypeForName(const std::string &_name);
91
92 static const std::string & getNameForType(enum PotentialTypes _type);
93
94private:
95 PotentialFactory() {}
96 ~PotentialFactory() {}
97};
98
99#endif /* POTENTIALFACTORY_HPP_ */
Note: See TracBrowser for help on using the repository browser.