diff --git a/include/aidge/aidge.hpp b/include/aidge/aidge.hpp index c3f97f96e6b797afca7a28928f717691ae998185..e708c168421216fa249f26eee1f2b2eb80b588fd 100644 --- a/include/aidge/aidge.hpp +++ b/include/aidge/aidge.hpp @@ -38,6 +38,7 @@ #include "aidge/operator/MetaOperator.hpp" #include "aidge/operator/MetaOperatorDefs.hpp" #include "aidge/operator/Operator.hpp" +#include "aidge/operator/Pad.hpp" #include "aidge/operator/Producer.hpp" #include "aidge/operator/ReLU.hpp" #include "aidge/operator/Softmax.hpp" diff --git a/src/graphRegex/matchFsm/FsmGraph.cpp b/src/graphRegex/matchFsm/FsmGraph.cpp index 09bc25d636c1cc882439f50107bf728714fdfb20..5a9f00d728cd2cd9f58c2228361f8393de2a3d9d 100644 --- a/src/graphRegex/matchFsm/FsmGraph.cpp +++ b/src/graphRegex/matchFsm/FsmGraph.cpp @@ -1,6 +1,6 @@ #include "aidge/graphRegex/matchFsm/FsmGraph.hpp" -using namespace Aidge; +using namespace Aidge; @@ -14,7 +14,7 @@ FsmGraph::FsmGraph(/* args */){ if(startNodes.size() != startNodesFsm.size()){ throw std::runtime_error("bad number of Start nodes"); } - + std::vector<std::shared_ptr<FsmRunTimeContext>> walks; for(std::size_t i = 0; i < startNodes.size(); i++){ walks.push_back(std::make_shared<FsmRunTimeContext>(startNodesFsm[i],startNodes[i])); @@ -32,16 +32,16 @@ FsmGraph::FsmGraph(/* args */){ for(auto fsmContext : walks){ allContextSee.push_back(fsmContext); //if we are in a valid st we save it - //it's one solution of the posible solution of the matching + //it's one solution of the posible solution of the matching if(fsmContext->isOnValidState()){ - //not save 2 time the same end point + //not save 2 time the same end point if(!std::any_of(allValidContext.begin(), allValidContext.end(), [&](std::shared_ptr<Aidge::FsmRunTimeContext> oldValid) { return fsmContext->areEqual(oldValid); })){ allValidContext.push_back(fsmContext); } - + } //dont test 2 time a fsmContext @@ -60,15 +60,15 @@ FsmGraph::FsmGraph(/* args */){ walks.swap(nextWalks); nextWalks.clear(); } - - + + return std::make_shared<MatchResult>(allValidContext,getNbSubFsm()); } /////////////// -// FSM construction +// FSM construction /////////////// const std::set<std::shared_ptr<FsmEdge>>& FsmGraph::getEdge(void){ return mEdges; @@ -140,7 +140,7 @@ void FsmGraph::mergeOneStartOneValid(const std::shared_ptr<FsmGraph> fsmGraph){ } unionG(fsmGraph); - //for loop useless but for future merge it's coudl be used + //for loop useless but for future merge it's coudl be used for(auto valid : validNodes){ valid->unValid(); for(auto start : startNodes){ @@ -159,9 +159,11 @@ void FsmGraph::incOrigineAllNodeBy(std::size_t incr){ for(auto node :nodes){ node->incOrigine(incr); } + std::set<std::size_t> updatedOrigin; for(auto origin : mAllOrigine){ - origin += incr; + updatedOrigin.insert(origin + incr); } + mAllOrigine.swap(updatedOrigin); } void FsmGraph::_mergeNode(std::shared_ptr<FsmNode> source,std::shared_ptr<FsmNode> dest){ @@ -189,7 +191,7 @@ void FsmGraph::_mergeNode(std::shared_ptr<FsmNode> source,std::shared_ptr<FsmNod } } - //check is source is not in graph + //check is source is not in graph nodes = getNodes(); if(nodes.find(source) != nodes.end() ){ throw std::runtime_error("FsmGraph merge node not effective"); diff --git a/src/nodeTester/ConditionalInterpreter.cpp b/src/nodeTester/ConditionalInterpreter.cpp index 8cb20ac2f2348821b245dfc9f61be1072d76b9c9..e01bdd76a28576451a1a09202d5fd1e87a4856e5 100644 --- a/src/nodeTester/ConditionalInterpreter.cpp +++ b/src/nodeTester/ConditionalInterpreter.cpp @@ -1,7 +1,7 @@ #include "aidge/nodeTester/ConditionalInterpreter.hpp" -using namespace Aidge; +using namespace Aidge; /////////////////////////////// @@ -31,7 +31,7 @@ using namespace Aidge; mLambdaRegiter.insert("getType",+[](NodePtr NodeOp){return NodeOp->type();}); } - + bool ConditionalInterpreter::test( const NodePtr nodeOp) { @@ -39,9 +39,9 @@ using namespace Aidge; clearRes(); try{ std::vector<ConditionalData*> r = visit({mTree},nodeOp); - + if (mResolution.size() != 1){ - throw std::runtime_error("Multy output interpretation output"); + throw std::runtime_error("Multi-output interpretation output"); }else{ if (!mResolution[0]->isTypeEqualTo<bool>()){ throw std::runtime_error("TEST OUT MUST BE A BOOL "); @@ -53,7 +53,7 @@ using namespace Aidge; }catch(const std::exception& e){ std::ostringstream errorMessage; errorMessage << "Error in test " << "\n\t" << e.what() << "\n"; - throw std::runtime_error(errorMessage.str()); + throw std::runtime_error(errorMessage.str()); } } @@ -70,7 +70,7 @@ using namespace Aidge; switch (node->getType()){ /////////////////////////////////// //OPERATOR - /////////////////////////////////// + /////////////////////////////////// case ConditionalTokenTypes::NOT: { visit(node->getChilds(),nodeOp); @@ -105,10 +105,10 @@ using namespace Aidge; /////////////////////////////////// //VALUE - /////////////////////////////////// - + /////////////////////////////////// + case ConditionalTokenTypes::KEY: - + break; case ConditionalTokenTypes::INTEGER: { @@ -118,7 +118,7 @@ using namespace Aidge; case ConditionalTokenTypes::FLOAT: { fStrToFloat(node); - + } break; case ConditionalTokenTypes::STRING: @@ -126,7 +126,7 @@ using namespace Aidge; fStrToStr(node); } break; - + case ConditionalTokenTypes::NODE: //TODO { @@ -141,14 +141,14 @@ using namespace Aidge; { visit(node->getChilds(),nodeOp); fLambda(node); - + } break; case ConditionalTokenTypes::BOOL: //TODO { ConditionalData* data = new ConditionalData; - + if(node->getValue() == "true"){ data->setValue<bool>(true); }else{ @@ -170,7 +170,7 @@ using namespace Aidge; }catch(const std::exception& e){ std::ostringstream errorMessage; errorMessage << "Error in visiting AST for node"<< nodeOp->name() << "\n\t" << e.what() << "\n"; - throw std::runtime_error(errorMessage.str()); + throw std::runtime_error(errorMessage.str()); } } @@ -192,7 +192,7 @@ using namespace Aidge; void ConditionalInterpreter::fStrToFloat(const std::shared_ptr<AstNode<ConditionalTokenTypes>>& node) { - + ConditionalData* data = new ConditionalData; data->setValue<float>(std::stof(node->getValue())); mResolution.push_back(data); @@ -205,7 +205,7 @@ using namespace Aidge; mResolution.push_back(data); } - void ConditionalInterpreter::fLambda(const std::shared_ptr<AstNode<ConditionalTokenTypes>>& node) + void ConditionalInterpreter::fLambda(const std::shared_ptr<AstNode<ConditionalTokenTypes>>& node) { //if the lambda have input ConditionalData* data; @@ -214,7 +214,7 @@ using namespace Aidge; } catch (const std::exception& e) { std::ostringstream errorMessage; errorMessage << "Error in conditional interpretation when run the "<< node->getValue() <<" Lambda\n\t" << e.what() << "\n"; - throw std::runtime_error(errorMessage.str()); + throw std::runtime_error(errorMessage.str()); } clearRes(); @@ -224,7 +224,7 @@ using namespace Aidge; void ConditionalInterpreter::fEq(void) { if (mResolution.size() != 2){ - throw std::runtime_error("EQ need 2 arg and get :" + mResolution.size()); + throw std::runtime_error("EQ need 2 arg and get :" + std::to_string(mResolution.size())); } auto a = mResolution[0]; auto b = mResolution[1]; @@ -256,7 +256,7 @@ using namespace Aidge; void ConditionalInterpreter::fNeq(void) { if (mResolution.size() != 2){ - throw std::runtime_error("NEQ need 2 arg and get :" + mResolution.size()); + throw std::runtime_error("NEQ need 2 arg and get :" + std::to_string(mResolution.size())); } auto a = mResolution[0]; auto b = mResolution[1]; @@ -285,7 +285,7 @@ using namespace Aidge; void ConditionalInterpreter::fAnd(void) { if (mResolution.size() != 2){ - throw std::runtime_error("AND need 2 arg and get :" + mResolution.size()); + throw std::runtime_error("AND need 2 arg and get :" + std::to_string(mResolution.size())); } auto a = mResolution[0]; auto b = mResolution[1]; @@ -297,7 +297,7 @@ using namespace Aidge; ConditionalData* data = new ConditionalData; data->setValue<bool>( a->getValue<bool>() && b->getValue<bool>()); - + clearRes(); mResolution.push_back(data); @@ -306,7 +306,7 @@ using namespace Aidge; void ConditionalInterpreter::fOr(void) { if (mResolution.size() != 2){ - throw std::runtime_error("OR need 2 arg and get :" + mResolution.size()); + throw std::runtime_error("OR need 2 arg and get :" + std::to_string(mResolution.size())); } auto a = mResolution[0]; auto b = mResolution[1]; @@ -318,7 +318,7 @@ using namespace Aidge; ConditionalData* data = new ConditionalData; data->setValue<bool>( a->getValue<bool>() || b->getValue<bool>()); - + clearRes(); mResolution.push_back(data); @@ -327,7 +327,7 @@ using namespace Aidge; void ConditionalInterpreter::fNot() { if (mResolution.size() != 1){ - throw std::runtime_error("not need 1 arg and get :" + mResolution.size()); + throw std::runtime_error("NOT need 1 arg and get :" + std::to_string(mResolution.size())); } auto a = mResolution[0]; @@ -337,7 +337,7 @@ using namespace Aidge; ConditionalData* data = new ConditionalData; data->setValue<bool>( !a->getValue<bool>() ); - + clearRes(); mResolution.push_back(data);