summaryrefslogtreecommitdiffhomepage
path: root/ftnoir_filter_accela
diff options
context:
space:
mode:
authorStanislaw Halik <sthalik@misaki.pl>2015-07-01 14:51:12 +0200
committerStanislaw Halik <sthalik@misaki.pl>2015-07-01 14:51:12 +0200
commit307d9030edbc3e97a49fd1f2266b0e22fcfa552a (patch)
treee0670398fb712c28e1d7e116caddd469ab47f5de /ftnoir_filter_accela
parentaa3d3748fd7f8a9f6f0153eecf402e50c60c7ccf (diff)
parente94be88e28b41610bab983a1cbf8f31133a4ced8 (diff)
Merge branch 'unstable' of github.com:opentrack/opentrack into trackhat-ui
Diffstat (limited to 'ftnoir_filter_accela')
-rw-r--r--ftnoir_filter_accela/ftnoir_filter_accela.cpp67
-rw-r--r--ftnoir_filter_accela/ftnoir_filter_accela.h4
2 files changed, 37 insertions, 34 deletions
diff --git a/ftnoir_filter_accela/ftnoir_filter_accela.cpp b/ftnoir_filter_accela/ftnoir_filter_accela.cpp
index f0b0b468..5adaea23 100644
--- a/ftnoir_filter_accela/ftnoir_filter_accela.cpp
+++ b/ftnoir_filter_accela/ftnoir_filter_accela.cpp
@@ -12,20 +12,42 @@
#include "opentrack/plugin-api.hpp"
using namespace std;
-FTNoIR_Filter::FTNoIR_Filter() : first_run(true)
-{
-}
+static constexpr double rot_gains[][2] = {
+ { 7, 200 },
+ { 6, 100 },
+ { 5, 45 },
+ { 4, 15 },
+ { 3, 5 },
+ { 2, 1.4 },
+ { 1, .4 },
+ { 0, .2 },
+ { -1, 0 }
+};
+static constexpr double trans_gains[][2] = {
+ { 5, 180 },
+ { 4, 64 },
+ { 3, 20 },
+ { 2, 5 },
+ { 1, .7 },
+ { 0, .1 },
+ { -1, 0 }
+};
-double FTNoIR_Filter::f(double val, const double gains[][2])
+FTNoIR_Filter::FTNoIR_Filter() : first_run(true)
{
- for (int i = 0; gains[i][0] >= 0; i++)
+ rot.setMaxInput(rot_gains[0][0]);
+ trans.setMaxInput(trans_gains[0][0]);
+ rot.setMaxOutput(rot_gains[0][1]);
+ trans.setMaxOutput(trans_gains[0][1]);
+
+ for (int i = 0; rot_gains[i][0] >= 0; i++)
{
- if (val >= gains[i][0])
- {
- return gains[i][1] * val;
- }
+ rot.addPoint(QPointF(rot_gains[i][0], rot_gains[i][1]));
+ }
+ for (int i = 0; trans_gains[i][0] >= 0; i++)
+ {
+ trans.addPoint(QPointF(trans_gains[i][0], trans_gains[i][1]));
}
- return 0;
}
void FTNoIR_Filter::filter(const double* input, double *output)
@@ -43,25 +65,6 @@ void FTNoIR_Filter::filter(const double* input, double *output)
return;
}
- static const double rot_gains[][2] = {
- { 6, 15 },
- { 5, 8 },
- { 4, 4 },
- { 3, 1.6 },
- { 2, .7 },
- { 1, .4 },
- { 0, .2 },
- { -1, 0 }
- };
- static const double trans_gains[][2] = {
- { 4, 8 },
- { 3, 4 },
- { 2, 2 },
- { 1, .5 },
- { 0, .1 },
- { -1, 0 }
- };
-
const double rot_t = 10. * (1+s.rot_threshold) / 100.;
const double trans_t = 5. * (1+s.trans_threshold) / 100.;
@@ -75,6 +78,8 @@ void FTNoIR_Filter::filter(const double* input, double *output)
for (int i = 0; i < 6; i++)
{
+ Map& m = i >= 3 ? rot : trans;
+
smoothed_input[i] = smoothed_input[i] * (1.-alpha) + input[i] * alpha;
const double in = smoothed_input[i];
@@ -83,14 +88,12 @@ void FTNoIR_Filter::filter(const double* input, double *output)
const double dz = i >= 3 ? rot_dz : trans_dz;
const double vec_ = max(0., fabs(vec) - dz);
const double thres = i >= 3 ? rot_t : trans_t;
- const double val = f(vec_ / thres, i >= 3 ? rot_gains : trans_gains) * thres;
+ const double val = m.getValue(vec_ / thres) * thres;
const double result = last_output[i] + (vec < 0 ? -1 : 1) * dt * val;
const bool negp = vec < 0.;
const bool done = negp
? result <= in
: result >= in;
- if (i == 3 && val > 0.1 && done)
- qDebug() << "done";
const double ret = done ? in : result;
last_output[i] = output[i] = ret;
diff --git a/ftnoir_filter_accela/ftnoir_filter_accela.h b/ftnoir_filter_accela/ftnoir_filter_accela.h
index 17698922..e2b29ee4 100644
--- a/ftnoir_filter_accela/ftnoir_filter_accela.h
+++ b/ftnoir_filter_accela/ftnoir_filter_accela.h
@@ -1,5 +1,6 @@
#pragma once
#include "opentrack/plugin-api.hpp"
+#include "qfunctionconfigurator/functionconfig.h"
#include <atomic>
#include <QMutex>
#include <QTimer>
@@ -25,12 +26,11 @@ class FTNoIR_Filter : public IFilter
public:
FTNoIR_Filter();
void filter(const double* input, double *output);
+ Map rot, trans;
private:
settings_accela s;
bool first_run;
double last_output[6];
double smoothed_input[6];
Timer t;
-
- double f(double val, const double gains[][2]);
};