aboutsummaryrefslogtreecommitdiffstats
path: root/Transceiver52M/signalVector.cpp
diff options
context:
space:
mode:
authorThomas Tsou <tom@tsou.cc>2013-11-09 14:30:41 -0500
committerThomas Tsou <tom@tsou.cc>2013-11-15 23:35:07 -0500
commit20eb6d64fdf6ca5b547cb1f16f67c7c9f2c45ef0 (patch)
tree424b2e4dc3cf4bb6c98b9025f7a6fb7509b918d7 /Transceiver52M/signalVector.cpp
parente0fa2bfd937406cbaf992f8d16d0a262dd6ddd87 (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.cpp81
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;
+}