Lemma is an Electromagnetics API
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

LemmaObject.h 5.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. /* This file is part of Lemma, a geophysical modelling and inversion API */
  2. /* This Source Code Form is subject to the terms of the Mozilla Public
  3. * License, v. 2.0. If a copy of the MPL was not distributed with this
  4. * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
  5. /**
  6. @file
  7. @author Trevor Irons
  8. @date 06-13-2016
  9. **/
  10. #ifndef __LEMMAOBJECT_H
  11. #define __LEMMAOBJECT_H
  12. #include "helper.h"
  13. #include "lemma.h"
  14. #ifdef HAVE_YAMLCPP
  15. #include "yaml-cpp/yaml.h"
  16. #endif
  17. #include <memory>
  18. namespace Lemma {
  19. /** \brief Abstract class providing common interface for Lemma Objects.
  20. * \details Lemma objects can be members of other Lemma, and may be members
  21. * of multiple objects. Since updates should be atomic, and objects
  22. * can be large, it becomes useful to count the number of
  23. * Classes an object is a member of.
  24. * Before C++-11, this was done internally in Lemma, with the inclusion of
  25. * more sophisticated smart pointers, this logic has been offloaded to the
  26. * standard. All Lemma objects should be created as C++-11 Smart pointers, using
  27. * the supplied New method. Calls to Delete are no longer necessary or available.
  28. */
  29. class LemmaObject {
  30. /** Recursively prints information about this object
  31. */
  32. friend std::ostream &operator<<(std::ostream &stream, const LemmaObject &ob);
  33. #ifdef HAVE_YAMLCPP
  34. friend YAML::Emitter& operator << (YAML::Emitter& out, const LemmaObject &ob) ;
  35. #endif
  36. friend class LemmaObjectDeleter;
  37. public:
  38. // ==================== LIFECYCLE ==============================
  39. //virtual std::shared_ptr<LemmaObject> NewSP() const = 0;
  40. // Needed because many derived classes have Eigen vectors as members,
  41. // causing alignment issues when vectorisation is enabled.
  42. EIGEN_MAKE_ALIGNED_OPERATOR_NEW
  43. // ==================== OPERATORS ==============================
  44. // ==================== OPERATIONS ==============================
  45. // ==================== ACCESS ==============================
  46. // ==================== INQUIRY ==============================
  47. /** Returns the name of the class, similiar to Python's type */
  48. std::string GetName() const;
  49. #ifdef HAVE_YAMLCPP
  50. /**
  51. * Uses YAML to serialize this object.
  52. * @return a YAML::Node
  53. * FOR NOT LemmaObject does not write out any YAML info,
  54. * in the future the reference count could be logged? But the utility
  55. * of that is minimal.
  56. * @note Not every Lemma class needs to be Serializable, for instance HankelTransform
  57. * classes will never need to be Serialized. There may be a need to differentiate these
  58. * two families in to a LemmaInternalClass without serializing and perhaps this class for
  59. * all external classes that might need to be serialized.
  60. */
  61. virtual YAML::Node Serialize() const {
  62. return YAML::Node();
  63. };
  64. #endif
  65. protected:
  66. // ==================== LIFECYCLE ==============================
  67. /** Protected default constructor. This is an abstract class and
  68. * cannot be instantiated.
  69. */
  70. LemmaObject (const std::string &name);
  71. #ifdef HAVE_YAMLCPP
  72. /** Protected DeDerializing constructor, use factory DeSerialize method*/
  73. LemmaObject (const YAML::Node& node);
  74. #endif
  75. /** Protected default destructor. This is an abstract class and
  76. * cannot be instantiated.
  77. */
  78. virtual ~LemmaObject();
  79. private:
  80. // ==================== DATA MEMBERS ==============================
  81. /** Stores an ASCII string representation of the class name */
  82. std::string Name;
  83. }; // ----- end of class LemmaObject -----
  84. class LemmaObjectDeleter
  85. {
  86. public:
  87. void operator()(LemmaObject* p) { delete p; }
  88. };
  89. /////////////////////////////////////////////////////////////////
  90. // BOILERPLATE MACROS
  91. #define DESERIALIZECHECK( node, Object ) { \
  92. if (node.Tag() != Object->GetName()) { \
  93. throw DeSerializeTypeMismatch(Object, node.Tag()) ; \
  94. } } \
  95. /////////////////////////////////////////////////////////////////
  96. // Error Classes
  97. /** Error called when DeSerializing breaks. If the node type is not the expected one
  98. * this error is thown.
  99. */
  100. class DeSerializeTypeMismatch : public std::runtime_error {
  101. public:
  102. DeSerializeTypeMismatch(LemmaObject *ptr, const std::string& got);
  103. };
  104. /** If an assignment is made that is out of bounts, throw this.
  105. */
  106. class AssignmentOutOfBounds : public std::runtime_error {
  107. public:
  108. /** Throw when an assignment is out of bounds.
  109. * @param[in] ptr is a pointer to the class throwing the exception.
  110. */
  111. AssignmentOutOfBounds(LemmaObject *ptr);
  112. };
  113. /** If a pointer to a class is requested, but it is NULL valued, throw this
  114. */
  115. class RequestToReturnNullPointer : public std::runtime_error {
  116. public:
  117. /** Thrown when the pointer is NULL
  118. * @param[in] ptr is a pointer to the class throwing the exception.
  119. */
  120. RequestToReturnNullPointer(LemmaObject *ptr);
  121. };
  122. /** If an error in opening a .mat file is encountered, throw this.
  123. */
  124. class MatFileCannotBeOpened : public std::runtime_error {
  125. /** thown when a mat file fails to be opened.
  126. */
  127. public: MatFileCannotBeOpened();
  128. };
  129. /** Generic file I/O error. */
  130. class GenericFileIOError : public std::runtime_error {
  131. public: GenericFileIOError(LemmaObject *ptr, const std::string &filename);
  132. };
  133. }
  134. #endif // __LEMMAOBJECT_H