diff options
author | Thomas Tsou <tom@tsou.cc> | 2013-11-09 14:30:41 -0500 |
---|---|---|
committer | Thomas Tsou <tom@tsou.cc> | 2013-11-15 23:35:07 -0500 |
commit | 20eb6d64fdf6ca5b547cb1f16f67c7c9f2c45ef0 (patch) | |
tree | 424b2e4dc3cf4bb6c98b9025f7a6fb7509b918d7 /Transceiver52M/signalVector.cpp | |
parent | e0fa2bfd937406cbaf992f8d16d0a262dd6ddd87 (diff) |
Transceiver52M: Separate signalVector into it's own file
Break out the signalVector object and clean up the interface in the
process.
Signed-off-by: Thomas Tsou <tom@tsou.cc>
Diffstat (limited to 'Transceiver52M/signalVector.cpp')
-rw-r--r-- | Transceiver52M/signalVector.cpp | 81 |
1 files changed, 81 insertions, 0 deletions
diff --git a/Transceiver52M/signalVector.cpp b/Transceiver52M/signalVector.cpp new file mode 100644 index 0000000..4b4099e --- /dev/null +++ b/Transceiver52M/signalVector.cpp @@ -0,0 +1,81 @@ +#include "signalVector.h" + +signalVector::signalVector(size_t size) + : Vector<complex>(size), + real(false), aligned(false), symmetry(NONE) +{ +} + +signalVector::signalVector(size_t size, size_t start) + : Vector<complex>(size + start), + real(false), aligned(false), symmetry(NONE) +{ + mStart = mData + start; +} + +signalVector::signalVector(complex *data, size_t start, size_t span) + : Vector<complex>(NULL, data + start, data + start + span), + real(false), aligned(false), symmetry(NONE) +{ +} + +signalVector::signalVector(const signalVector &vector) + : Vector<complex>(vector.size() + vector.getStart()), aligned(false) +{ + mStart = mData + vector.getStart(); + vector.copyTo(*this); + symmetry = vector.getSymmetry(); + real = vector.isReal(); +}; + +signalVector::signalVector(const signalVector &vector, + size_t start, size_t tail) + : Vector<complex>(start + vector.size() + tail), aligned(false) +{ + mStart = mData + start; + vector.copyTo(*this); + symmetry = vector.getSymmetry(); + real = vector.isReal(); +}; + +void signalVector::operator=(const signalVector& vector) +{ + resize(vector.size() + vector.getStart()); + memcpy(mData, vector.mData, bytes()); + mStart = mData + vector.getStart(); +} + +size_t signalVector::getStart() const +{ + return mStart - mData; +} + +Symmetry signalVector::getSymmetry() const +{ + return symmetry; +} + +void signalVector::setSymmetry(Symmetry symmetry) +{ + this->symmetry = symmetry; +} + +bool signalVector::isReal() const +{ + return real; +} + +void signalVector::isReal(bool wOnly) +{ + real = wOnly; +} + +bool signalVector::isAligned() const +{ + return aligned; +} + +void signalVector::setAligned(bool aligned) +{ + this->aligned = aligned; +} |