summaryrefslogtreecommitdiff
path: root/gr-gcell/src/gcell_fft_vcc.cc
diff options
context:
space:
mode:
Diffstat (limited to 'gr-gcell/src/gcell_fft_vcc.cc')
-rw-r--r--gr-gcell/src/gcell_fft_vcc.cc160
1 files changed, 0 insertions, 160 deletions
diff --git a/gr-gcell/src/gcell_fft_vcc.cc b/gr-gcell/src/gcell_fft_vcc.cc
deleted file mode 100644
index ae40b6fad..000000000
--- a/gr-gcell/src/gcell_fft_vcc.cc
+++ /dev/null
@@ -1,160 +0,0 @@
-/* -*- c++ -*- */
-/*
- * Copyright 2004,2007,2008,2010 Free Software Foundation, Inc.
- *
- * This file is part of GNU Radio
- *
- * GNU Radio 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, or (at your option)
- * any later version.
- *
- * GNU Radio 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 GNU Radio; see the file COPYING. If not, write to
- * the Free Software Foundation, Inc., 51 Franklin Street,
- * Boston, MA 02110-1301, USA.
- */
-
-#ifdef HAVE_CONFIG_H
-#include "config.h"
-#endif
-
-#include <gcell_fft_vcc.h>
-#include <gr_io_signature.h>
-#include <gcell/gc_job_manager.h>
-#include <gcell/gc_aligned_alloc.h>
-#include <gcell/gcp_fft_1d_r2.h>
-#include <math.h>
-#include <assert.h>
-#include <stdexcept>
-#include <string.h>
-
-
-#define MIN_FFT_SIZE 32
-#define MAX_FFT_SIZE 4096
-
-inline static bool
-is_power_of_2(int x)
-{
- return x != 0 && (x & (x-1)) == 0;
-}
-
-static int
-int_log2(int x) // x is an exact power of 2
-{
- for (int i = 0; i < 32; i++)
- if (x == (1 << i))
- return i;
-
- assert(0);
-}
-
-#if 0
-gr_fft_vcc_sptr
-gcell_make_fft_vcc(int fft_size, bool forward, const std::vector<float> &window, bool shift)
-{
- // If it doesn't meet our constraints, use standard implemenation
- if (fft_size < MIN_FFT_SIZE || fft_size > MAX_FFT_SIZE
- || !is_power_of_2(fft_size)
- || (window.size() != 0 && fft_size > MAX_FFT_SIZE/2))
- return gr_make_fft_vcc(fft_size, forward, window, shift);
- else
- return gr_fft_vcc_sptr (new gcell_fft_vcc(fft_size, forward, window, shift));
-}
-#else
-
-gcell_fft_vcc_sptr
-gcell_make_fft_vcc(int fft_size, bool forward, const std::vector<float> &window, bool shift)
-{
- return gnuradio::get_initial_sptr(new gcell_fft_vcc(fft_size, forward, window, shift));
-}
-
-#endif
-
-gcell_fft_vcc::gcell_fft_vcc (int fft_size, bool forward,
- const std::vector<float> &window, bool shift)
- : gr_fft_vcc("gcell_fft_vcc", fft_size, forward, window, shift)
-{
- if (fft_size < MIN_FFT_SIZE || fft_size > MAX_FFT_SIZE || !is_power_of_2(fft_size)){
- throw std::invalid_argument("fft_size");
- }
-
- if (window.size() != 0 && fft_size > MAX_FFT_SIZE/2){
- throw std::invalid_argument("fft_size too big to use window");
- }
-
- d_log2_fft_size = int_log2(fft_size);
- d_mgr = gc_job_manager::singleton(); // grab the singleton job manager
- d_twiddle_boost = gc_aligned_alloc_sptr(sizeof(std::complex<float>) * fft_size/4, 128);
- d_twiddle = (std::complex<float>*) d_twiddle_boost.get();
- gcp_fft_1d_r2_twiddle(d_log2_fft_size, d_twiddle);
-}
-
-gcell_fft_vcc::~gcell_fft_vcc ()
-{
-}
-
-int
-gcell_fft_vcc::work(int noutput_items,
- gr_vector_const_void_star &input_items,
- gr_vector_void_star &output_items)
-{
- const gr_complex *in = (const gr_complex *) input_items[0];
- gr_complex *out = (gr_complex *) output_items[0];
-
- // unsigned int input_data_size = input_signature()->sizeof_stream_item(0);
- // unsigned int output_data_size = output_signature()->sizeof_stream_item(0);
-
- float window_buf[MAX_FFT_SIZE/2] __attribute__((aligned (16)));
- float *window = 0;
-
- // If we've got a window, ensure it's 16-byte aligned
- // FIXME move this to set_window
- if (d_window.size()){
- if ((((intptr_t)&d_window[0]) & 0xf) == 0)
- window = &d_window[0]; // OK as is
- else {
- window = window_buf; // copy to aligned buffer
- memcpy(window, &d_window[0], sizeof(float) * d_window.size());
- }
- }
-
- std::vector<gc_job_desc_sptr> jd_sptr(noutput_items);
- gc_job_desc *jd[noutput_items];
- bool done[noutput_items];
-
- // submit noutput_items jobs in parallel
-
- for (int i = 0; i < noutput_items; i++){
- jd_sptr[i] = gcp_fft_1d_r2_submit(d_mgr, d_log2_fft_size,
- d_forward, d_shift,
- &out[i * d_fft_size],
- &in[i * d_fft_size],
- d_twiddle,
- window);
- jd[i] = jd_sptr[i].get();
- }
-
- int n = d_mgr->wait_jobs(noutput_items, jd, done, GC_WAIT_ALL);
- if (n != noutput_items){
- fprintf(stderr, "gcell_fft_vcc: wait_jobs returned %d, expected %d\n",
- n, noutput_items);
- return -1;
- }
-
- for (int i = 0; i < noutput_items; i++){
- if (jd[i]->status != JS_OK){
- fprintf(stderr, "gcell_fft_vcc jd[%d]->status = %s\n",
- i, gc_job_status_string(jd[i]->status).c_str());
- return -1;
- }
- }
-
- return noutput_items;
-}
-