/** * @file tests/qss/graph_manager.cpp * @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 TESTS_QSS_GRAPH_MANAGER_HPP #define TESTS_QSS_GRAPH_MANAGER_HPP #include #include #include #include #include #include namespace artis { namespace tests { namespace qss { class ConstantGraphManager : public artis::qss::GraphManager { public: ConstantGraphManager(common::Coordinator* coordinator, const artis::qss::QSSParameters& parameters, const artis::common::NoParameters& graph_parameters) : artis::qss::GraphManager(coordinator, parameters, graph_parameters) { } ~ConstantGraphManager() override = default; }; class OnlyOneGraphManager : public artis::qss::GraphManager { public: enum submodels { A }; OnlyOneGraphManager(common::Coordinator* coordinator, const artis::qss::QSSParameters& parameters, const artis::common::NoParameters& graph_parameters) : artis::qss::GraphManager(coordinator, parameters, graph_parameters), S("a", parameters, graph_parameters) { add_child(A, &S); } ~OnlyOneGraphManager() override = default; private: artis::pdevs::Coordinator> S; }; class ParabolaGraphManager : public artis::qss::GraphManager { public: ParabolaGraphManager(common::Coordinator* coordinator, const artis::qss::QSSParameters& parameters, const artis::common::NoParameters& graph_parameters) : artis::qss::GraphManager( coordinator, parameters, graph_parameters) { } ~ParabolaGraphManager() override = default; }; class OnlyOneParabolaGraphManager : public artis::pdevs::GraphManager> { public: enum submodels { A }; OnlyOneParabolaGraphManager(common::Coordinator* coordinator, const artis::qss::QSSParameters& parameters, const artis::common::NoParameters& graph_parameters) : artis::pdevs::GraphManager>( coordinator, parameters, graph_parameters), S("a", parameters, graph_parameters) { add_child(A, &S); } ~OnlyOneParabolaGraphManager() override = default; private: artis::pdevs::Coordinator> S; }; class PredatorGraphManager : public artis::qss::GraphManager { public: enum inputs { IN_X = artis::qss::GraphManager::RESET + 1 }; PredatorGraphManager(common::Coordinator* coordinator, const artis::qss::QSSParameters& parameters, const artis::common::NoParameters& graph_parameters) : artis::qss::GraphManager( coordinator, parameters, graph_parameters) { coordinator->input_port({IN_X, "in_x"}); in({coordinator, IN_X}) >> in({derivative(), derivative()->dynamics().IN_X}); } ~PredatorGraphManager() override = default; }; class PreyGraphManager : public artis::qss::GraphManager { public: enum inputs { IN_Y = artis::qss::GraphManager::RESET + 1 }; PreyGraphManager(common::Coordinator* coordinator, const artis::qss::QSSParameters& parameters, const artis::common::NoParameters& graph_parameters) : artis::qss::GraphManager( coordinator, parameters, graph_parameters) { coordinator->input_port({IN_Y, "in_y"}); in({coordinator, IN_Y}) >> in({derivative(), derivative()->dynamics().IN_Y}); } ~PreyGraphManager() override = default; }; struct PreyPredatorGraphManagerParameters { artis::qss::QSSParameters _predator; artis::qss::QSSParameters _prey; }; class PreyPredatorGraphManager : public artis::pdevs::GraphManager { public: enum submodels { PREDATOR, PREY }; enum inputs { RESET_X, RESET_Y }; enum outputs { OUT_X, OUT_Y }; PreyPredatorGraphManager(common::Coordinator* coordinator, const PreyPredatorGraphManagerParameters& parameters, const artis::common::NoParameters& graph_parameters) : artis::pdevs::GraphManager( coordinator, parameters, graph_parameters), _predator("predator", parameters._predator, graph_parameters), _prey("prey", parameters._prey, graph_parameters) { add_child(PREDATOR, &_predator); add_child(PREY, &_prey); coordinator->input_ports({{RESET_X, "reset_x"}, {RESET_Y, "reset_y"}}); coordinator->output_ports({{OUT_X, "out_x"}, {OUT_Y, "out_y"}}); in({coordinator, RESET_X}) >> in({&_prey, PreyGraphManager::RESET}); in({coordinator, RESET_Y}) >> in({&_prey, PreyGraphManager::IN_Y}); in({coordinator, RESET_X}) >> in({&_predator, PredatorGraphManager::IN_X}); in({coordinator, RESET_Y}) >> in({&_predator, PredatorGraphManager::RESET}); out({&_prey, PreyGraphManager::OUT}) >> out({coordinator, OUT_X}); out({&_predator, PredatorGraphManager::OUT}) >> out({coordinator, OUT_Y}); out({&_predator, PredatorGraphManager::OUT}) >> in({&_prey, PreyGraphManager::IN_Y}); out({&_prey, PreyGraphManager::OUT}) >> in({&_predator, PredatorGraphManager::IN_X}); } ~PreyPredatorGraphManager() override = default; private: artis::pdevs::Coordinator> _predator; artis::pdevs::Coordinator> _prey; }; struct PreyPredatorSmartGardenerGraphManagerParameters { PreyPredatorGraphManagerParameters _prey_predator; SmartGardenerParameters _smart_gardener; }; class PreyPredatorSmartGardenerGraphManager : public artis::pdevs::GraphManager { public: enum submodels { PREY_PREDATOR, SMART_GARDENER }; PreyPredatorSmartGardenerGraphManager( common::Coordinator* coordinator, const PreyPredatorSmartGardenerGraphManagerParameters& parameters, const artis::common::NoParameters& graph_parameters) : artis::pdevs::GraphManager( coordinator, parameters, graph_parameters), _prey_predator("prey_predator", parameters._prey_predator, graph_parameters), _smart_gardener("smart_gardener", parameters._smart_gardener) { add_child(PREY_PREDATOR, &_prey_predator); add_child(SMART_GARDENER, &_smart_gardener); out({&_prey_predator, PreyPredatorGraphManager::OUT_X}) >> in({&_smart_gardener, SmartGardener::IN_X}); out({&_prey_predator, PreyPredatorGraphManager::OUT_Y}) >> in({&_smart_gardener, SmartGardener::IN_Y}); out({&_smart_gardener, SmartGardener::OUT_X}) >> in({&_prey_predator, PreyPredatorGraphManager::RESET_X}); out({&_smart_gardener, SmartGardener::OUT_Y}) >> in({&_prey_predator, PreyPredatorGraphManager::RESET_Y}); } ~PreyPredatorSmartGardenerGraphManager() override = default; private: artis::pdevs::Coordinator _prey_predator; artis::pdevs::Simulator _smart_gardener; }; class DiscretePredatorGraphManager : public artis::dtss::GraphManager { public: enum submodels { PREDATOR }; enum inputs { RESET, IN_X }; enum outputs { OUT }; DiscretePredatorGraphManager( artis::common::Coordinator* coordinator, const DiscretePreyPredatorParameters& parameters, const artis::common::NoParameters& graph_parameters) : artis::dtss::GraphManager( coordinator, parameters, graph_parameters ), _predator("predator", parameters) { add_child(PREDATOR, &_predator); coordinator->input_ports({{RESET, "reset"}, {IN_X, "in_x"}}); coordinator->output_port({OUT, "out"}); out({&_predator, DiscretePredator::OUT}) >> out({coordinator, OUT}); in({coordinator, RESET}) >> in({&_predator, DiscretePredator::RESET}); in({coordinator, IN_X}) >> in({&_predator, DiscretePredator::IN_X}); } ~DiscretePredatorGraphManager() override = default; private: artis::dtss::Simulator _predator; }; struct MixedPreyPredatorGraphManagerParameters { DiscretePreyPredatorParameters _predator; artis::qss::QSSParameters _prey; }; class MixedPreyPredatorGraphManager : public artis::pdevs::GraphManager { public: enum submodels { PREDATOR, PREY }; enum inputs { RESET_X, RESET_Y }; enum outputs { OUT_X, OUT_Y }; MixedPreyPredatorGraphManager( artis::common::Coordinator* coordinator, const MixedPreyPredatorGraphManagerParameters& parameters, const artis::common::NoParameters& graph_parameters) : artis::pdevs::GraphManager( coordinator, parameters, graph_parameters), _predator("predator", parameters._predator, graph_parameters), _prey("prey", parameters._prey, graph_parameters) { add_child(PREDATOR, &_predator); add_child(PREY, &_prey); coordinator->input_ports({{RESET_X, "reset_x"}, {RESET_Y, "reset_y"}}); coordinator->output_ports({{OUT_X, "out_x"}, {OUT_Y, "out_y"}}); in({coordinator, RESET_X}) >> in({&_prey, PreyGraphManager::RESET}); in({coordinator, RESET_Y}) >> in({&_predator, PredatorGraphManager::RESET}); out({&_prey, PreyGraphManager::OUT}) >> out({coordinator, OUT_X}); out({&_predator, PredatorGraphManager::OUT}) >> out({coordinator, OUT_Y}); out({&_predator, PredatorGraphManager::OUT}) >> in({&_prey, PreyGraphManager::IN_Y}); out({&_prey, PreyGraphManager::OUT}) >> in({&_predator, PredatorGraphManager::IN_X}); } ~MixedPreyPredatorGraphManager() override = default; private: artis::dtss::Coordinator _predator; artis::pdevs::Coordinator> _prey; }; } } } // namespace artis tests qss #endif