Skip to content
Snippets Groups Projects
Commit b4735570 authored by Jan Trávníček's avatar Jan Trávníček
Browse files

access for nonlinear tree pattern automaton algo

parent 11cf64b4
No related branches found
No related tags found
No related merge requests found
......@@ -27,6 +27,7 @@
#include <arbology/exact/ExactPatternMatchingAutomaton.h>
#include <arbology/exact/ExactSubtreeAutomaton.h>
#include <arbology/exact/ExactTreePatternAutomaton.h>
#include <arbology/exact/ExactNonlinearTreePatternAutomaton.h>
#include <arbology/exact/ExactSubtreeRepeatsNaive.h>
#include <arbology/transform/BeginToEndIndex.h>
 
......@@ -48,6 +49,7 @@ int main ( int argc, char * argv[] ) {
allowed.push_back ( "exactPatternMatchingAutomaton" );
allowed.push_back ( "exactSubtreeAutomaton" );
allowed.push_back ( "exactTreePatternAutomaton" );
allowed.push_back ( "exactNonlinearTreePatternAutomaton" );
allowed.push_back ( "exactSubtreeRepeatsNaive" );
TCLAP::ValuesConstraint < std::string > allowedVals ( allowed );
 
......@@ -223,6 +225,20 @@ int main ( int argc, char * argv[] ) {
measurements::end ( );
measurements::start ( "Output write", measurements::Type::AUXILIARY );
 
alib::XmlDataFactory::toStdout ( res );
} else if ( algorithm.getValue ( ) == "exactNonlinearTreePatternAutomaton" ) {
tree::Tree subject = alib::XmlDataFactory::fromTokens < tree::Tree > ( std::move ( sax::FromXMLParserHelper::parseInput(true, subjectInput).front ( ) ) );
alphabet::Symbol subtreeWildcard = alib::XmlDataFactory::fromTokens < alphabet::Symbol > ( sax::FromXMLParserHelper::parseInput(subtreeWildcardInput) );
std::set < alphabet::Symbol > nonlinearVariables = alib::XmlDataFactory::fromTokens < std::set < alphabet::Symbol > > ( sax::FromXMLParserHelper::parseInput(nonlinearVariablesInput) );
measurements::end ( );
measurements::start ( "Algorithm", measurements::Type::MAIN );
automaton::Automaton res = arbology::exact::ExactNonlinearTreePatternAutomaton::construct ( subject, subtreeWildcard, nonlinearVariables );
measurements::end ( );
measurements::start ( "Output write", measurements::Type::AUXILIARY );
alib::XmlDataFactory::toStdout ( res );
} else if ( algorithm.getValue ( ) == "exactSubtreeRepeatsNaive" ) {
tree::Tree subject = alib::XmlDataFactory::fromTokens < tree::Tree > ( std::move ( sax::FromXMLParserHelper::parseInput(true, subjectInput).front ( ) ) );
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment