Merge 487f00d8e4 into e643468de8
This commit is contained in:
commit
2380b1123f
3 changed files with 227 additions and 0 deletions
75
eo/src/eoFilterMonOp.h
Normal file
75
eo/src/eoFilterMonOp.h
Normal file
|
|
@ -0,0 +1,75 @@
|
||||||
|
/* Software License Agreement (GNU GPLv3)
|
||||||
|
*
|
||||||
|
* Copyright (C) 2013 Patrick Lehner <lehner.patrick@gmx.de>
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef EO_FILTERMONOP_H
|
||||||
|
#define EO_FILTERMONOP_H
|
||||||
|
|
||||||
|
// C++ library includes
|
||||||
|
#include <iostream>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
// EO library includes
|
||||||
|
#include <eo> // eo general include
|
||||||
|
#include <eoOp.h>
|
||||||
|
|
||||||
|
template< class EOT >
|
||||||
|
class eoFilterMonOp: public eoMonOp< EOT >
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
typedef bool(*FilterFuncPtr)(const EOT&);
|
||||||
|
|
||||||
|
eoFilterMonOp(eoMonOp<EOT>* actualOp_) :
|
||||||
|
eoMonOp< EOT >(), actualOp(actualOp_)
|
||||||
|
{}
|
||||||
|
|
||||||
|
virtual ~eoFilterMonOp() {}
|
||||||
|
|
||||||
|
bool operator()(EOT& _eo1) {
|
||||||
|
EOT eo2(_eo1);
|
||||||
|
|
||||||
|
if (!(*actualOp)(eo2))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
bool accepted = true;
|
||||||
|
for (FilterFuncPtr fp : filters)
|
||||||
|
if ( !(*fp)(eo2) ) {
|
||||||
|
accepted = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (accepted) {
|
||||||
|
_eo1 = eo2;
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool add(FilterFuncPtr fp) {
|
||||||
|
if (!fp)
|
||||||
|
return false;
|
||||||
|
filters.push_back(fp);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
eoMonOp<EOT>* actualOp;
|
||||||
|
std::vector<FilterFuncPtr> filters;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // SOPARS_EO_FILTERMONOP_HPP
|
||||||
77
eo/src/eoFilterQuadOp.h
Normal file
77
eo/src/eoFilterQuadOp.h
Normal file
|
|
@ -0,0 +1,77 @@
|
||||||
|
/* Software License Agreement (GNU GPLv3)
|
||||||
|
*
|
||||||
|
* Copyright (C) 2013 Patrick Lehner <lehner.patrick@gmx.de>
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef EO_FILTERQUADOP_H
|
||||||
|
#define EO_FILTERQUADOP_H
|
||||||
|
|
||||||
|
// C++ library includes
|
||||||
|
#include <iostream>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
// EO library includes
|
||||||
|
#include <eo> // eo general include
|
||||||
|
#include <eoOp.h>
|
||||||
|
|
||||||
|
template< class EOT >
|
||||||
|
class eoFilterQuadOp: public eoQuadOp< EOT >
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
typedef bool(*FilterFuncPtr)(const EOT&);
|
||||||
|
|
||||||
|
eoFilterQuadOp(eoQuadOp<EOT>* actualOp_) :
|
||||||
|
eoQuadOp< EOT >(), actualOp(actualOp_)
|
||||||
|
{}
|
||||||
|
|
||||||
|
virtual ~eoFilterQuadOp() {}
|
||||||
|
|
||||||
|
bool operator()(EOT& _eo1, EOT& _eo2) {
|
||||||
|
EOT cpeo1(_eo1);
|
||||||
|
EOT cpeo2(_eo2);
|
||||||
|
|
||||||
|
if (!(*actualOp)(cpeo1, cpeo2))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
bool accepted = true;
|
||||||
|
for (FilterFuncPtr fp : filters)
|
||||||
|
if ( !(*fp)(cpeo1) || !(*fp)(cpeo2) ) {
|
||||||
|
accepted = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (accepted) {
|
||||||
|
_eo1 = cpeo1;
|
||||||
|
_eo2 = cpeo2;
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool add(FilterFuncPtr fp) {
|
||||||
|
if (!fp)
|
||||||
|
return false;
|
||||||
|
filters.push_back(fp);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
eoQuadOp<EOT>* actualOp;
|
||||||
|
std::vector<FilterFuncPtr> filters;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // SOPARS_EO_FILTERQUADOP_HPP
|
||||||
75
eo/src/eoInitFilter.h
Normal file
75
eo/src/eoInitFilter.h
Normal file
|
|
@ -0,0 +1,75 @@
|
||||||
|
/* Software License Agreement (GNU GPLv3)
|
||||||
|
*
|
||||||
|
* Copyright (C) 2013 Patrick Lehner <lehner.patrick@gmx.de>
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef EO_INITFILTER_H
|
||||||
|
#define EO_INITFILTER_H
|
||||||
|
|
||||||
|
// C++ library includes
|
||||||
|
#include <iostream>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
// EO library includes
|
||||||
|
#include <eo> // eo general include
|
||||||
|
#include <eoInit.h>
|
||||||
|
|
||||||
|
template<class EOT>
|
||||||
|
class eoInitFilter : public eoInit<EOT> {
|
||||||
|
|
||||||
|
public:
|
||||||
|
typedef bool(*FilterFuncPtr)(const EOT&);
|
||||||
|
|
||||||
|
eoInitFilter(eoInit<EOT>* actualInit_) :
|
||||||
|
eoInit<EOT>(), actualInit(actualInit_)
|
||||||
|
{
|
||||||
|
if (!actualInit_)
|
||||||
|
std::cerr << "ERROR: No actual initializer given for eoInitFilter" << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// My class name
|
||||||
|
virtual std::string className() const { return "eoInteractiveInit"; };
|
||||||
|
|
||||||
|
void operator()(EOT& _eo)
|
||||||
|
{
|
||||||
|
bool accepted = false;
|
||||||
|
|
||||||
|
while (!accepted) {
|
||||||
|
(*actualInit)(_eo);
|
||||||
|
|
||||||
|
accepted = true;
|
||||||
|
for (FilterFuncPtr fp : filters)
|
||||||
|
if ( !(*fp)(_eo) ) {
|
||||||
|
accepted = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool add(FilterFuncPtr fp) {
|
||||||
|
if (!fp)
|
||||||
|
return false;
|
||||||
|
filters.push_back(fp);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
eoInit<EOT>* actualInit;
|
||||||
|
std::vector<FilterFuncPtr> filters;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // SOPARS_EO_INITFILTER_HPP
|
||||||
Loading…
Add table
Add a link
Reference in a new issue