mirror of
https://github.com/f4exb/sdrangel.git
synced 2024-12-25 04:03:30 -05:00
203 lines
6.4 KiB
C++
203 lines
6.4 KiB
C++
///////////////////////////////////////////////////////////////////////////////////
|
|
// Copyright (C) 2020 Edouard Griffiths, F4EXB <f4exb06@gmail.com> //
|
|
// //
|
|
// 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 as 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 V3 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 INCLUDE_SIGMFFILEDATA_H
|
|
#define INCLUDE_SIGMFFILEDATA_H
|
|
|
|
#include <QString>
|
|
|
|
struct SigMFFileDataType
|
|
{
|
|
bool m_complex;
|
|
bool m_floatingPoint;
|
|
bool m_signed;
|
|
bool m_bigEndian;
|
|
bool m_swapIQ;
|
|
int m_sampleBits;
|
|
|
|
SigMFFileDataType() :
|
|
m_complex(true),
|
|
m_floatingPoint(false),
|
|
m_signed(true),
|
|
m_bigEndian(false),
|
|
m_swapIQ(false),
|
|
m_sampleBits(32)
|
|
{}
|
|
|
|
SigMFFileDataType(const SigMFFileDataType& other) :
|
|
m_complex(other.m_complex),
|
|
m_floatingPoint(other.m_floatingPoint),
|
|
m_signed(other.m_signed),
|
|
m_bigEndian(other.m_bigEndian),
|
|
m_swapIQ(other.m_swapIQ),
|
|
m_sampleBits(other.m_sampleBits)
|
|
{}
|
|
|
|
SigMFFileDataType& operator=(const SigMFFileDataType& t)
|
|
{
|
|
// Check for self assignment
|
|
if (this != &t)
|
|
{
|
|
m_complex = t.m_complex;
|
|
m_floatingPoint = t.m_floatingPoint;
|
|
m_signed = t.m_signed;
|
|
m_bigEndian = t.m_bigEndian;
|
|
m_swapIQ = t.m_swapIQ;
|
|
m_sampleBits = t.m_sampleBits;
|
|
}
|
|
|
|
return *this;
|
|
}
|
|
};
|
|
|
|
class SigMFFileMetaInfo
|
|
{
|
|
public:
|
|
// core
|
|
QString m_dataTypeStr;
|
|
SigMFFileDataType m_dataType;
|
|
uint64_t m_totalSamples;
|
|
uint64_t m_totalTimeMs;
|
|
double m_coreSampleRate;
|
|
QString m_sigMFVersion;
|
|
QString m_sha512;
|
|
unsigned int m_offset;
|
|
QString m_description;
|
|
QString m_author;
|
|
QString m_metaDOI;
|
|
QString m_dataDOI;
|
|
QString m_recorder;
|
|
QString m_license;
|
|
QString m_hw;
|
|
// sdrangel
|
|
QString m_sdrAngelVersion;
|
|
QString m_qtVersion;
|
|
int m_rxBits;
|
|
QString m_arch;
|
|
QString m_os;
|
|
// lists
|
|
unsigned int m_nbCaptures;
|
|
unsigned int m_nbAnnotations;
|
|
|
|
SigMFFileMetaInfo()
|
|
{}
|
|
|
|
SigMFFileMetaInfo(const SigMFFileMetaInfo& other) :
|
|
m_dataTypeStr(other.m_dataTypeStr),
|
|
m_dataType(other.m_dataType),
|
|
m_totalSamples(other.m_totalSamples),
|
|
m_totalTimeMs(other.m_totalTimeMs),
|
|
m_coreSampleRate(other.m_coreSampleRate),
|
|
m_sigMFVersion(other.m_sigMFVersion),
|
|
m_sha512(other.m_sha512),
|
|
m_offset(other.m_offset),
|
|
m_description(other.m_description),
|
|
m_author(other.m_author),
|
|
m_metaDOI(other.m_metaDOI),
|
|
m_dataDOI(other.m_dataDOI),
|
|
m_recorder(other.m_recorder),
|
|
m_license(other.m_license),
|
|
m_hw(other.m_hw),
|
|
m_sdrAngelVersion(other.m_sdrAngelVersion),
|
|
m_qtVersion(other.m_qtVersion),
|
|
m_rxBits(other.m_rxBits),
|
|
m_arch(other.m_arch),
|
|
m_os(other.m_os),
|
|
m_nbCaptures(other.m_nbCaptures),
|
|
m_nbAnnotations(other.m_nbAnnotations)
|
|
{}
|
|
|
|
SigMFFileMetaInfo& operator=(const SigMFFileMetaInfo& t)
|
|
{
|
|
// Check for self assignment
|
|
if (this != &t)
|
|
{
|
|
m_dataTypeStr = t.m_dataTypeStr;
|
|
m_dataType = t.m_dataType;
|
|
m_totalSamples = t.m_totalSamples;
|
|
m_totalTimeMs = t.m_totalTimeMs;
|
|
m_coreSampleRate = t.m_coreSampleRate;
|
|
m_sigMFVersion = t.m_sigMFVersion;
|
|
m_sha512 = t.m_sha512;
|
|
m_offset = t.m_offset;
|
|
m_description = t.m_description;
|
|
m_author = t.m_author;
|
|
m_metaDOI = t.m_metaDOI;
|
|
m_dataDOI = t.m_dataDOI;
|
|
m_recorder = t.m_recorder;
|
|
m_license = t.m_license;
|
|
m_hw = t.m_hw;
|
|
m_sdrAngelVersion = t.m_sdrAngelVersion;
|
|
m_qtVersion = t.m_qtVersion;
|
|
m_rxBits = t.m_rxBits;
|
|
m_arch = t.m_arch;
|
|
m_os = t.m_os;
|
|
m_nbCaptures = t.m_nbCaptures;
|
|
m_nbAnnotations = t.m_nbAnnotations;
|
|
}
|
|
|
|
return *this;
|
|
}
|
|
};
|
|
|
|
class SigMFFileCapture
|
|
{
|
|
public:
|
|
uint64_t m_tsms; //!< Unix timestamp in milliseconds
|
|
uint64_t m_centerFrequency; //!< Center frequency in Hz
|
|
uint64_t m_sampleStart; //!< Sample index at which capture start
|
|
uint64_t m_length; //!< Length of capture in samples
|
|
uint64_t m_cumulativeTime; //!< Time since beginning of record (millisecond timestamp) at start
|
|
unsigned int m_sampleRate; //!< sdrangel extension - sample rate for this capture
|
|
|
|
SigMFFileCapture() :
|
|
m_tsms(0),
|
|
m_centerFrequency(0),
|
|
m_sampleStart(0),
|
|
m_length(0),
|
|
m_cumulativeTime(0),
|
|
m_sampleRate(1)
|
|
{}
|
|
|
|
SigMFFileCapture(const SigMFFileCapture& other) :
|
|
m_tsms(other.m_tsms),
|
|
m_centerFrequency(other.m_centerFrequency),
|
|
m_sampleStart(other.m_sampleStart),
|
|
m_length(other.m_length),
|
|
m_cumulativeTime(other.m_cumulativeTime),
|
|
m_sampleRate(other.m_sampleRate)
|
|
{}
|
|
|
|
SigMFFileCapture& operator=(const SigMFFileCapture& t)
|
|
{
|
|
// Check for self assignment
|
|
if (this != &t)
|
|
{
|
|
m_tsms = t.m_tsms;
|
|
m_centerFrequency = t.m_centerFrequency;
|
|
m_sampleStart = t.m_sampleStart;
|
|
m_length = t.m_length;
|
|
m_cumulativeTime = t.m_cumulativeTime;
|
|
m_sampleRate = t.m_sampleRate;
|
|
}
|
|
|
|
return *this;
|
|
}
|
|
};
|
|
|
|
#endif // INCLUDE_SIGMFFILEDATA_H
|