mirror of
https://github.com/ggerganov/ggwave.git
synced 2026-05-09 18:37:48 +08:00
ggwave : compute Tx amplitudes always
This commit is contained in:
@@ -333,16 +333,6 @@ public:
|
|||||||
int bytesPerTx; // number of bytes in a chunk of data
|
int bytesPerTx; // number of bytes in a chunk of data
|
||||||
|
|
||||||
int nDataBitsPerTx() const { return 8*bytesPerTx; }
|
int nDataBitsPerTx() const { return 8*bytesPerTx; }
|
||||||
|
|
||||||
bool operator==(const TxProtocol & other) const {
|
|
||||||
return freqStart == other.freqStart &&
|
|
||||||
framesPerTx == other.framesPerTx &&
|
|
||||||
bytesPerTx == other.bytesPerTx;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool operator!=(const TxProtocol & other) const {
|
|
||||||
return !(*this == other);
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
using RxProtocol = TxProtocol;
|
using RxProtocol = TxProtocol;
|
||||||
|
|||||||
@@ -410,7 +410,6 @@ struct GGWave::Tx {
|
|||||||
|
|
||||||
TxRxData txData;
|
TxRxData txData;
|
||||||
TxProtocol txProtocol;
|
TxProtocol txProtocol;
|
||||||
TxProtocol txProtocolLast;
|
|
||||||
|
|
||||||
AmplitudeData outputBlock;
|
AmplitudeData outputBlock;
|
||||||
AmplitudeData outputBlockResampled;
|
AmplitudeData outputBlockResampled;
|
||||||
@@ -543,8 +542,6 @@ GGWave::GGWave(const Parameters & parameters) :
|
|||||||
if (m_isTxEnabled) {
|
if (m_isTxEnabled) {
|
||||||
m_tx = std::unique_ptr<Tx>(new Tx());
|
m_tx = std::unique_ptr<Tx>(new Tx());
|
||||||
|
|
||||||
m_tx->txProtocolLast = {};
|
|
||||||
|
|
||||||
{
|
{
|
||||||
const int maxDataBits = 2*16*maxBytesPerTx();
|
const int maxDataBits = 2*16*maxBytesPerTx();
|
||||||
|
|
||||||
@@ -703,7 +700,6 @@ bool GGWave::encode(const CBWaveformOut & cbWaveformOut) {
|
|||||||
m_resampler->reset();
|
m_resampler->reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_tx->txProtocol != m_tx->txProtocolLast) {
|
|
||||||
for (int k = 0; k < (int) m_tx->phaseOffsets.size(); ++k) {
|
for (int k = 0; k < (int) m_tx->phaseOffsets.size(); ++k) {
|
||||||
m_tx->phaseOffsets[k] = (M_PI*k)/(m_tx->txProtocol.nDataBitsPerTx());
|
m_tx->phaseOffsets[k] = (M_PI*k)/(m_tx->txProtocol.nDataBitsPerTx());
|
||||||
}
|
}
|
||||||
@@ -731,8 +727,6 @@ bool GGWave::encode(const CBWaveformOut & cbWaveformOut) {
|
|||||||
m_tx->bit0Amplitude[k][i] = std::sin((2.0*M_PI)*(curi*m_isamplesPerFrame)*((freq + m_hzPerSample*m_freqDelta_bin)*curIHzPerSample) + phaseOffset);
|
m_tx->bit0Amplitude[k][i] = std::sin((2.0*M_PI)*(curi*m_isamplesPerFrame)*((freq + m_hzPerSample*m_freqDelta_bin)*curIHzPerSample) + phaseOffset);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
m_tx->txProtocolLast = m_tx->txProtocol;
|
|
||||||
|
|
||||||
const int nECCBytesPerTx = getECCBytesForLength(m_tx->txDataLength);
|
const int nECCBytesPerTx = getECCBytesForLength(m_tx->txDataLength);
|
||||||
const int sendDataLength = m_tx->txDataLength + m_encodedDataOffset;
|
const int sendDataLength = m_tx->txDataLength + m_encodedDataOffset;
|
||||||
|
|||||||
Reference in New Issue
Block a user