#pragma once #include #include #include #include #include "MinigridGrammar.h" #include "PrismPrinter.h" #include "PrismModulesPrinter.h" #include "PrismFormulaPrinter.h" #include "ConfigYaml.h" class Grid { public: Grid(cells gridCells, cells background, const std::map &stateRewards = {}, const float probIntended = 1.0, const float faultyProbability = 0, prism::ModelType mType = prism::ModelType::MDP); cells getGridCells(); bool isBlocked(coordinates p); bool isWall(coordinates p); void printToPrism(std::ostream &os, std::vector& configuration); void applyOverwrites(std::string& str, std::vector& configuration); std::array getWalkableDirOf8Neighborhood(cell c); friend std::ostream& operator<<(std::ostream& os, const Grid &grid); private: cells allGridCells; cells background; coordinates maxBoundaries; prism::ModelType modelType; cell agent; cells adversaries; AgentNameAndPositionMap agentNameAndPositionMap; KeyNameAndPositionMap keyNameAndPositionMap; cells walls; cells floor; cells slipperyNorth; cells slipperyEast; cells slipperySouth; cells slipperyWest; cells lockedDoors; cells unlockedDoors; cells boxes; cells balls; cells lava; cells goals; cells keys; std::map backgroundTiles; std::map stateRewards; const float probIntended; const float faultyProbability; };