X-Git-Url: https://bilbo.iut-bm.univ-fcomte.fr/and/gitweb/blast.git/blobdiff_plain/abbc64cf04a35ab3549d5c516f44c7c5921baa63..3fb762e7042d9b4a1cf78556ad9ed7f117cc53ba:/Graph.h?ds=inline diff --git a/Graph.h b/Graph.h index 7f34682..d5b15a9 100644 --- a/Graph.h +++ b/Graph.h @@ -10,7 +10,8 @@ class GroupBlock; class ReferenceBlock; class FunctionalBlock; class AbstractInterface; - +#include "Exception.h" +class Exception; using namespace std; using namespace Qt; @@ -21,14 +22,55 @@ public: Graph(); ~Graph(); - QList getOutsideInterfaces(); + // getters inline GroupBlock* getTopGroup() { return topGroup; } + inline QList getAllGroups() { return groups; } + inline double getClock(int id) { return clocks.at(id); } + inline QList& getClocks() { return clocks; } + + //setters + inline void resetClocks() { clocks.clear(); } + + // methods for group blocks + GroupBlock* createChildGroupBlock(GroupBlock* parent, bool createGroupIface = true); + void removeGroupBlock(GroupBlock *group); + GroupBlock* getGroupBlockByName(QString name); + + // methods for functional blocks + FunctionalBlock* createFunctionalBlock(GroupBlock *group, ReferenceBlock *ref, bool createIfaces = true); + FunctionalBlock* duplicateFunctionalBlock(FunctionalBlock *block); + bool removeFunctionalBlock(FunctionalBlock* block); + FunctionalBlock* getFunctionalBlockByName(QString name, GroupBlock* parent = NULL); //! if parent = NULL, search in the whole graph + + // methods for stimulis blocks + FunctionalBlock* createStimuliBlock(ReferenceBlock *ref, bool createIfaces = true); + FunctionalBlock* duplicateStimuliBlock(FunctionalBlock *block); + FunctionalBlock* getStimuliBlockByName(QString name); + bool removeStimuliBlock(FunctionalBlock* block); + + // others + void createTopGroup(bool createTopGroupIfaces = true); + inline void addClock(double freq) { clocks.append(freq); } + QList getOutsideInterfaces(); + QList getExternalResources(); // returns the list of all external files needed for VHDL generation - GroupBlock* createChildBlock(GroupBlock* parent); - FunctionalBlock* addFunctionalBlock(GroupBlock *group, ReferenceBlock *ref); + /*! + * \brief createPatterns + * createPatterns() crosses the graph and for each functional block, it computes + * the consumptionPattern, the productionPattern, the production counter and delta + * using the parameters fo the block. + */ + void createPatterns() throw(Exception); + void resetPatternComputed(); + void computeOutputPatterns(int nbExec) throw(Exception); + + void generateVHDL(const QString& path) throw(Exception); private: GroupBlock* topGroup; + QList groups; //! usefull to avoid recursive methods to find a particular group. + QList stimulis; //! source for the top group + QList clocks; // clocks[0] is the main clock. };