LibreVNA/Software/PC_Application/Calibration/calkit.h

67 lines
1.8 KiB
C
Raw Normal View History

#ifndef CALKIT_H
#define CALKIT_H
#include "touchstone.h"
2020-11-08 21:30:19 +08:00
#include "Util/qpointervariant.h"
#include "calstandard.h"
2021-10-21 19:00:34 +08:00
#include <string>
#include <complex>
2020-11-08 21:30:19 +08:00
#include <QDir>
class Calkit
{
friend class CalkitDialog;
public:
Calkit();
2022-03-17 19:53:13 +08:00
Calkit(const Calkit&) = default;
2020-11-08 21:30:19 +08:00
Calkit& operator=(const Calkit& other)
{
this->manufacturer = other.manufacturer;
this->serialnumber = other.serialnumber;
this->description = other.description;
this->standards = other.standards;
2020-11-08 21:30:19 +08:00
return *this;
}
class SOLT {
public:
std::complex<double> Open;
std::complex<double> Short;
std::complex<double> Load;
std::complex<double> ThroughS11, ThroughS12, ThroughS21, ThroughS22;
};
class TRL {
public:
bool reflectionIsNegative;
std::complex<double> ThroughS11, ThroughS12, ThroughS21, ThroughS22;
};
void toFile(QString filename);
static Calkit fromFile(QString filename);
void edit(std::function<void(void)> updateCal = nullptr);
bool hasSeparateMaleFemaleStandards();
SOLT toSOLT(double frequency, bool male_standards = true);
TRL toTRL(double frequency);
double minFreqTRL();
double maxFreqTRL();
double minFreqSOLT(bool male_standards = true);
double maxFreqSOLT(bool male_standards = true);
bool checkIfValid(double min_freq, double max_freq, bool isTRL, bool include_male, bool include_female);
bool isTRLReflectionShort() const;
private:
2022-08-27 01:25:24 +08:00
void clearStandards();
QString manufacturer, serialnumber, description;
std::vector<CalStandard::Virtual*> standards;
2022-01-16 00:00:57 +08:00
const std::vector<Savable::SettingDescription> descr = {{
{&manufacturer, "Manufacturer", ""},
{&serialnumber, "Serialnumber", ""},
{&description, "Description", ""},
2020-11-08 21:30:19 +08:00
}};
};
#endif // CALKIT_H