Program Listing for File op_registry.hpp

Return to documentation for file (SeQuant/domain/mbpt/op_registry.hpp)

//
// Created by Ajay Melekamburath on 12/14/25.
//

#ifndef SEQUANT_DOMAIN_MBPT_OP_REGISTRY_HPP
#define SEQUANT_DOMAIN_MBPT_OP_REGISTRY_HPP

#include <SeQuant/core/container.hpp>
#include <SeQuant/core/expressions/tensor.hpp>
#include <SeQuant/core/reserved.hpp>
#include <SeQuant/core/utility/macros.hpp>

#include <range/v3/view/map.hpp>

#include <memory>

namespace sequant::mbpt {

enum class OpClass { ex, deex, gen };

inline Hermiticity default_hermiticity(OpClass cls) {
  return cls == OpClass::gen ? Hermiticity::Hermitian
                             : Hermiticity::NonHermitian;
}

class OpRegistry {
 public:
  OpRegistry()
      : ops_(std::make_shared<container::map<std::wstring, OpClass>>()),
        herm_overrides_(
            std::make_shared<container::map<std::wstring, Hermiticity>>()) {}

  OpRegistry(std::shared_ptr<container::map<std::wstring, OpClass>> ops)
      : ops_(std::move(ops)),
        herm_overrides_(
            std::make_shared<container::map<std::wstring, Hermiticity>>()) {}

  OpRegistry(const OpRegistry& other)
      : ops_(other.ops_), herm_overrides_(other.herm_overrides_) {}

  OpRegistry(OpRegistry&& other) noexcept
      : ops_(std::move(other.ops_)),
        herm_overrides_(std::move(other.herm_overrides_)) {}

  OpRegistry& operator=(const OpRegistry& other);

  OpRegistry& operator=(OpRegistry&& other) noexcept;

  [[nodiscard]] decltype(auto) begin() const { return ops_->cbegin(); }

  [[nodiscard]] decltype(auto) end() const { return ops_->cend(); }

  OpRegistry clone() const;

  OpRegistry& add(const std::wstring& op, OpClass action);

  OpRegistry& add(const std::wstring& op, OpClass action,
                  Hermiticity hermiticity);

  OpRegistry& set_hermiticity(const std::wstring& op, Hermiticity hermiticity);

  OpRegistry& remove(const std::wstring& op);

  bool contains(const std::wstring& op) const;

  [[nodiscard]] OpClass to_class(const std::wstring& op) const;

  [[nodiscard]] Hermiticity hermiticity(const std::wstring& op) const;

  [[nodiscard]] auto ops() const { return ranges::views::keys(*ops_); }

  void purge() {
    ops_->clear();
    herm_overrides_->clear();
  }

 private:
  std::shared_ptr<container::map<std::wstring, OpClass>> ops_;
  std::shared_ptr<container::map<std::wstring, Hermiticity>> herm_overrides_;

  void validate_op(const std::wstring& op) const;

  friend bool operator==(const OpRegistry& reg1, const OpRegistry& reg2) {
    return *reg1.ops_ == *reg2.ops_ &&
           *reg1.herm_overrides_ == *reg2.herm_overrides_;
  }
};  // class OpRegistry
}  // namespace sequant::mbpt

#endif  // SEQUANT_DOMAIN_MBPT_OP_REGISTRY_HPP