| [d76ce74] | 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> | 
|---|
| [b3b31e] | 17 | #include <iosfwd> | 
|---|
| [d76ce74] | 18 |  | 
|---|
|  | 19 | #include "CodePatterns/Singleton.hpp" | 
|---|
|  | 20 |  | 
|---|
| [fdd23a] | 21 | #include "Potentials/EmpiricalPotential.hpp" | 
|---|
| [931077] | 22 | #include "Potentials/Specifics/PotentialTypes.hpp" | 
|---|
| [f6abb1] | 23 | #include "Potentials/StreamFactory_EmpiricalPotential.hpp" | 
|---|
| [d76ce74] | 24 |  | 
|---|
|  | 25 | /** Class that creates instances of potentials. | 
|---|
|  | 26 | * | 
|---|
|  | 27 | * This is a factory pattern. | 
|---|
|  | 28 | * | 
|---|
|  | 29 | */ | 
|---|
| [f6abb1] | 30 | class PotentialFactory : | 
|---|
|  | 31 | public Singleton<PotentialFactory>, | 
|---|
|  | 32 | public StreamFactory<EmpiricalPotential> | 
|---|
| [d76ce74] | 33 | { | 
|---|
|  | 34 | //!> make Singleton template friend | 
|---|
|  | 35 | friend class Singleton<PotentialFactory>; | 
|---|
|  | 36 |  | 
|---|
| [f6abb1] | 37 | protected: | 
|---|
|  | 38 |  | 
|---|
|  | 39 | /** Returns a default potential to which only we have access. | 
|---|
| [d76ce74] | 40 | * | 
|---|
|  | 41 | */ | 
|---|
| [f6abb1] | 42 | EmpiricalPotential* getDefaultPotential(const std::string &_name) const; | 
|---|
|  | 43 |  | 
|---|
|  | 44 | public: | 
|---|
| [d76ce74] | 45 |  | 
|---|
| [55c494] | 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 |  | 
|---|
| [b3b31e] | 52 | /** Creates an instance of the requested potential. | 
|---|
|  | 53 | * | 
|---|
|  | 54 | * \param potentialtype key of potential to create | 
|---|
| [f6abb1] | 55 | * \param charges charges for which the potential is (to be) fitted | 
|---|
| [b3b31e] | 56 | */ | 
|---|
|  | 57 | EmpiricalPotential *createInstance( | 
|---|
|  | 58 | const std::string &potentialtype, | 
|---|
| [f6abb1] | 59 | const SerializablePotential::ParticleTypes_t &charges) const; | 
|---|
| [b3b31e] | 60 |  | 
|---|
| [e83114] | 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 ¶ms) const; | 
|---|
|  | 70 |  | 
|---|
| [a0d8aa] | 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 |  | 
|---|
| [d76ce74] | 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 |  | 
|---|
| [f6abb1] | 90 | static enum PotentialTypes getTypeForName(const std::string &_name); | 
|---|
|  | 91 |  | 
|---|
|  | 92 | static const std::string & getNameForType(enum PotentialTypes _type); | 
|---|
|  | 93 |  | 
|---|
| [d76ce74] | 94 | private: | 
|---|
|  | 95 | PotentialFactory() {} | 
|---|
|  | 96 | ~PotentialFactory() {} | 
|---|
|  | 97 | }; | 
|---|
|  | 98 |  | 
|---|
|  | 99 | #endif /* POTENTIALFACTORY_HPP_ */ | 
|---|