summaryrefslogtreecommitdiffstats
path: root/src/GuardIntervalInserter.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/GuardIntervalInserter.cpp')
-rw-r--r--src/GuardIntervalInserter.cpp107
1 files changed, 107 insertions, 0 deletions
diff --git a/src/GuardIntervalInserter.cpp b/src/GuardIntervalInserter.cpp
new file mode 100644
index 0000000..2fb4668
--- /dev/null
+++ b/src/GuardIntervalInserter.cpp
@@ -0,0 +1,107 @@
+/*
+ Copyright (C) 2005, 2206, 2007, 2008, 2009, 2010, 2011 Her Majesty
+ the Queen in Right of Canada (Communications Research Center Canada)
+ */
+/*
+ This file is part of CRC-DADMOD.
+
+ CRC-DADMOD 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, either version 3 of the
+ License, or (at your option) any later version.
+
+ CRC-DADMOD 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 for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with CRC-DADMOD. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "GuardIntervalInserter.h"
+#include "PcDebug.h"
+
+
+#include <sys/types.h>
+#include <string.h>
+#include <stdexcept>
+#include <complex>
+
+typedef std::complex<float> complexf;
+
+
+GuardIntervalInserter::GuardIntervalInserter(size_t nbSymbols,
+ size_t spacing,
+ size_t nullSize,
+ size_t symSize) :
+ ModCodec(ModFormat(d_nbSymbols * d_spacing * sizeof(complexf)),
+ ModFormat((d_nullSize + (d_nbSymbols * d_symSize))
+ * sizeof(complexf))),
+ d_nbSymbols(nbSymbols),
+ d_spacing(spacing),
+ d_nullSize(nullSize),
+ d_symSize(symSize)
+{
+ PDEBUG("GuardIntervalInserter::GuardIntervalInserter(%zu, %zu, %zu, %zu)"
+ " @ %p\n", nbSymbols, spacing, nullSize, symSize, this);
+
+ if (d_nullSize) {
+ myHasNull = true;
+ myInputFormat.size((d_nbSymbols + 1) * d_spacing * sizeof(complexf));
+ } else {
+ myHasNull = false;
+ }
+}
+
+
+GuardIntervalInserter::~GuardIntervalInserter()
+{
+ PDEBUG("GuardIntervalInserter::~GuardIntervalInserter() @ %p\n", this);
+
+}
+
+
+int GuardIntervalInserter::process(Buffer* const dataIn, Buffer* dataOut)
+{
+ PDEBUG("GuardIntervalInserter::process(dataIn: %p, dataOut: %p)\n",
+ dataIn, dataOut);
+
+ dataOut->setLength((d_nullSize + (d_nbSymbols * d_symSize))
+ * sizeof(complexf));
+
+ const complexf* in = reinterpret_cast<const complexf*>(dataIn->getData());
+ complexf* out = reinterpret_cast<complexf*>(dataOut->getData());
+ size_t sizeIn = dataIn->getLength() / sizeof(complexf);
+
+ if (sizeIn != (d_nbSymbols + (myHasNull ? 1 : 0)) * d_spacing) {
+ PDEBUG("Nb symbols: %zu\n", d_nbSymbols);
+ PDEBUG("Spacing: %zu\n", d_spacing);
+ PDEBUG("Null size: %zu\n", d_nullSize);
+ PDEBUG("Sym size: %zu\n", d_symSize);
+ PDEBUG("\n%zu != %zu\n", sizeIn, (d_nbSymbols + 1) * d_spacing);
+ throw std::runtime_error(
+ "GuardIntervalInserter::process input size not valid!");
+ }
+
+ // Null symbol
+ if (myHasNull) {
+ // end - (nullSize - spacing) = 2 * spacing - nullSize
+ memcpy(out, &in[2 * d_spacing - d_nullSize],
+ (d_nullSize - d_spacing) * sizeof(complexf));
+ memcpy(&out[d_nullSize - d_spacing], in, d_spacing * sizeof(complexf));
+ in += d_spacing;
+ out += d_nullSize;
+ }
+ // Data symbols
+ for (size_t i = 0; i < d_nbSymbols; ++i) {
+ // end - (nullSize - spacing) = 2 * spacing - nullSize
+ memcpy(out, &in[2 * d_spacing - d_symSize],
+ (d_symSize - d_spacing) * sizeof(complexf));
+ memcpy(&out[d_symSize - d_spacing], in, d_spacing * sizeof(complexf));
+ in += d_spacing;
+ out += d_symSize;
+ }
+
+ return sizeIn;
+}