/** * @file kernel/pdevs/qss/Quantifier.hpp * @author The ARTIS Development Team * See the AUTHORS or Authors.txt file */ /* * ARTIS - the multimodeling and simulation environment * This file is a part of the ARTIS environment * * Copyright (C) 2013-2019 ULCO http://www.univ-littoral.fr * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #ifndef QSS_QUANTIFIER #define QSS_QUANTIFIER #include #include #include namespace artis { namespace pdevs { namespace qss { struct QuantifierParameters { bool allow_offsets; bool zero_init_offset; double quantum; unsigned int archive_length; }; template class Quantifier : public artis::pdevs::Dynamics, QuantifierParameters> { public: enum inputs { IN = 1 }; enum outputs { OUT = 1 }; Quantifier(const std::string& name, const Context, QuantifierParameters>& context) : artis::pdevs::Dynamics, QuantifierParameters>(name, context) { this->input_port({IN, "in"}); this->output_port({OUT, "out"}); this->observables({{UP, "up"}, {DOWN, "down"}, {VALUE, "value"}}); _adaptive = context.parameters().allow_offsets; _adaptive_state = _adaptive ? POSSIBLE : IMPOSSIBLE; _zero_init_offset = context.parameters().zero_init_offset; _step_size = context.parameters().quantum; assert(_step_size > 0); _past_length = context.parameters().archive_length; assert(_past_length > 2); } virtual ~Quantifier() { } virtual void dconf(typename Time::type t, typename Time::type e, const common::Bag