summaryrefslogtreecommitdiff
path: root/src/calibration.h
blob: 4876c176a6bf25b6f30c8249acd93dc286d413e5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#pragma once

#include <array>

#include <QSharedPointer>

#include "constants.h"
#include "pixels.h"

using CalibrationColumn = std::array<float, calibrationTableHeight>;
// map [0; discretesInRage] (discretes) to [0; zRangeMm] (mm)
using CalibrationTable = std::array<CalibrationColumn, img_width>;
using CalibrationTablePtr = QSharedPointer<CalibrationTable>;

constexpr auto calibrationColumnHeight = std::tuple_size<CalibrationColumn>();

bool openCalibrationTable(const QString &filename, const CalibrationTablePtr table);

// void dumpCalibrationPixels(std::vector<Pixels> &&calibrationPixels);
enum class DumpFormat { Json, Binary };
void dumpCalibrationPixels(const std::vector<std::shared_ptr<Pixels> > &calibrationPixels,
                           const DumpFormat format = DumpFormat::Json);
bool dump(const CalibrationTablePtr &table, const QString &filename);

// TODO: implement median filter
QList<Pixels> filter(const QList<Pixels> &rawProfiles);

bool calibrateX(const QList<Pixels> &rawProfiles, CalibrationTablePtr table);
bool calibrateZ(const QList<Pixels> &rawProfiles,
                const uint32_t &stepsPerMm,
                CalibrationTablePtr table);

QImage calibrationTableToImage(const CalibrationTablePtr &calibrationTable);

void interpolate(const CalibrationTablePtr table);
void interpolate(CalibrationColumn &column);

// TODO: remove from this file
namespace {
// static CalibrationTablePtr calibrationTableZ;
// static CalibrationTablePtr calibrationTableX;
} // namespace