/*----------------------------------------------------------------------------- | Copyright (c) 2013-2017, Nucleic Development Team. | | Distributed under the terms of the Modified BSD License. | | The full license is in the file LICENSE, distributed with this software. |----------------------------------------------------------------------------*/ #pragma once #include #include "term.h" namespace kiwi { class Expression { public: Expression(double constant = 0.0) : m_constant(constant) {} Expression(const Term &term, double constant = 0.0) : m_terms(1, term), m_constant(constant) {} Expression(const std::vector &terms, double constant = 0.0) : m_terms(terms), m_constant(constant) {} ~Expression() {} const std::vector &terms() const { return m_terms; } double constant() const { return m_constant; } double value() const { typedef std::vector::const_iterator iter_t; double result = m_constant; iter_t end = m_terms.end(); for (iter_t it = m_terms.begin(); it != end; ++it) result += it->value(); return result; } private: std::vector m_terms; double m_constant; }; } // namespace kiwi