Parsing command line args
This commit is contained in:
parent
f8729011e8
commit
6e5ddb3c80
@ -6,6 +6,6 @@ cmake_minimum_required (VERSION 3.8)
|
|||||||
project ("ParallelSearch")
|
project ("ParallelSearch")
|
||||||
|
|
||||||
# Fügen Sie der ausführbaren Datei dieses Projekts eine Quelle hinzu.
|
# Fügen Sie der ausführbaren Datei dieses Projekts eine Quelle hinzu.
|
||||||
add_executable (ParallelSearch "main.cpp" "TestRunner.hpp" "ParallelSearch.hpp")
|
add_executable (ParallelSearch "main.cpp" "TestRunner.hpp" "ParallelSearch.hpp" "Parameters.hpp")
|
||||||
|
|
||||||
# TODO: Fügen Sie bei Bedarf Tests hinzu, und installieren Sie Ziele.
|
# TODO: Fügen Sie bei Bedarf Tests hinzu, und installieren Sie Ziele.
|
||||||
|
|||||||
68
Parameters.hpp
Normal file
68
Parameters.hpp
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
#ifndef PARAMETERS_HPP
|
||||||
|
#define PARAMETERS_HPP
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
#include <iostream>
|
||||||
|
#include <thread>
|
||||||
|
|
||||||
|
class Parameters
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
Parameters():
|
||||||
|
workerCount_(std::thread::hardware_concurrency()),
|
||||||
|
testDataLength_(4),
|
||||||
|
searchPattern_("ABC")
|
||||||
|
{};
|
||||||
|
|
||||||
|
~Parameters() {};
|
||||||
|
|
||||||
|
bool parseCmdLine(int argc, char** argv)
|
||||||
|
{
|
||||||
|
for (int i = 1; i < argc; i++)
|
||||||
|
{
|
||||||
|
std::string arg = argv[i];
|
||||||
|
if (0 == arg.compare(0, 2, "-w"))
|
||||||
|
{
|
||||||
|
workerCount_ = std::stoi(arg.substr(2));
|
||||||
|
}
|
||||||
|
else if (0 == arg.compare(0, 2, "-l"))
|
||||||
|
{
|
||||||
|
testDataLength_ = std::stoi(arg.substr(2));
|
||||||
|
}
|
||||||
|
else if (0 == arg.compare(0, 1, "-"))
|
||||||
|
{
|
||||||
|
// invalid option
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// no leading dash ... must be pattern
|
||||||
|
searchPattern_ = arg;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void show_usage(const char* cmd)
|
||||||
|
{
|
||||||
|
std::cerr << "Invalid command line args" << std::endl;
|
||||||
|
std::cerr
|
||||||
|
<< "Usage: " << cmd << " [options] [search_pattern]" << std::endl
|
||||||
|
<< "Options" << std::endl
|
||||||
|
<< " -wX Number of parallel workers" << std::endl
|
||||||
|
<< " -lY Length of test-data string" << std::endl
|
||||||
|
<< std::endl;
|
||||||
|
};
|
||||||
|
|
||||||
|
unsigned WorkerCount() const { return workerCount_; };
|
||||||
|
unsigned TestDataLength() const { return testDataLength_; };
|
||||||
|
std::string SearchPattern() const { return searchPattern_; };
|
||||||
|
|
||||||
|
private:
|
||||||
|
unsigned workerCount_;
|
||||||
|
unsigned testDataLength_;
|
||||||
|
std::string searchPattern_;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
26
main.cpp
26
main.cpp
@ -3,10 +3,11 @@
|
|||||||
#include <vector>
|
#include <vector>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <random>
|
#include <random>
|
||||||
#include <thread>
|
|
||||||
|
|
||||||
#include "ParallelSearch.hpp"
|
#include "ParallelSearch.hpp"
|
||||||
#include "TestRunner.hpp"
|
#include "TestRunner.hpp"
|
||||||
|
#include "Parameters.hpp"
|
||||||
|
|
||||||
// Type of our hay stack: a list of strings
|
// Type of our hay stack: a list of strings
|
||||||
typedef std::vector<std::string> WordList;
|
typedef std::vector<std::string> WordList;
|
||||||
@ -39,31 +40,42 @@ void run_wordsearch(ParallelWordSearch& search)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int main()
|
int main(int argc, char** argv)
|
||||||
{
|
{
|
||||||
|
Parameters parameters;
|
||||||
double time_span;
|
double time_span;
|
||||||
std::string pattern = "ABC";
|
|
||||||
unsigned workerCount = std::thread::hardware_concurrency();
|
|
||||||
WordList test_data;
|
WordList test_data;
|
||||||
|
|
||||||
|
std::cout << "ParallelSearch Demo" << std::endl << std::endl;
|
||||||
|
|
||||||
|
if (false == parameters.parseCmdLine(argc, argv))
|
||||||
|
{
|
||||||
|
parameters.show_usage(argv[0]);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::cout << "Workercount: " << parameters.WorkerCount() << std::endl;
|
||||||
|
std::cout << "Testdata length: " << parameters.TestDataLength() << std::endl;
|
||||||
|
std::cout << "Search pattern: " << parameters.SearchPattern() << std::endl;
|
||||||
|
std::cout << std::endl;
|
||||||
|
|
||||||
time_span = TestRunner(create_testdata, test_data);
|
time_span = TestRunner(create_testdata, test_data);
|
||||||
std::cout << "created test_data (" << test_data.size() << " words) " << time_span << " seconds" << std::endl;
|
std::cout << "created test_data (" << test_data.size() << " words) " << time_span << " seconds" << std::endl;
|
||||||
|
|
||||||
time_span = TestRunner(shuffle_testdata, test_data);
|
time_span = TestRunner(shuffle_testdata, test_data);
|
||||||
std::cout << "shuffled test_data " << time_span << " seconds" << std::endl;
|
std::cout << "shuffled test_data " << time_span << " seconds" << std::endl;
|
||||||
|
|
||||||
ParallelWordSearch wordSearch(1, test_data.begin(), test_data.end(), pattern);
|
ParallelWordSearch wordSearch(1, test_data.begin(), test_data.end(), parameters.SearchPattern());
|
||||||
|
|
||||||
time_span = TestRunner(run_wordsearch, wordSearch);
|
time_span = TestRunner(run_wordsearch, wordSearch);
|
||||||
std::cout << "linear search found " << wordSearch.get_result().size() << " matches: " << time_span << " seconds" << std::endl;
|
std::cout << "linear search found " << wordSearch.get_result().size() << " matches: " << time_span << " seconds" << std::endl;
|
||||||
|
|
||||||
ParallelWordSearch parallelWordSearch(workerCount, test_data.begin(), test_data.end(), pattern);
|
ParallelWordSearch parallelWordSearch(parameters.WorkerCount(), test_data.begin(), test_data.end(), parameters.SearchPattern());
|
||||||
time_span = TestRunner(run_wordsearch, parallelWordSearch);
|
time_span = TestRunner(run_wordsearch, parallelWordSearch);
|
||||||
std::cout << "parallel search found " << parallelWordSearch.get_result().size() << " matches: " << time_span << " seconds" << std::endl;
|
std::cout << "parallel search found " << parallelWordSearch.get_result().size() << " matches: " << time_span << " seconds" << std::endl;
|
||||||
|
|
||||||
// TODO add validation of results
|
// TODO add validation of results
|
||||||
// TODO brush up output
|
// TODO brush up output
|
||||||
// TODO command line args for workerCount, test-pattern generation, search pattern ?
|
|
||||||
|
|
||||||
std::cout << std::endl;
|
std::cout << std::endl;
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user