Hi,

In order to look for correct usage of *gr::io_signature::makev*, I checked this example https://github.com/gnuradio/gnuradio/blob/master/gr-digital/lib/fll_band_edge_cc_impl.cc

and found

*static int ios[] = {sizeof(gr_complex), sizeof(***gr_complex*), sizeof(***gr_complex*), sizeof(float)}; *

*static std::vector<int> iosig(ios, ios+sizeof(ios)/sizeof(int));*

and then use as *io_signature::makev(1, 4, iosig))*

Basically I have to use it in sync_short.cc from gr-ieee 80211 in order to create more inputs.

But if I use the above two lines inside the class i.e. sync_short_impl, I get lots of error. I have attached the file for reference. Could you please suggest me correct usage. I can give more information if needed.

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

/home/john/myprefix/src/gr-ieee-80211/lib/sync_short.cc:31:84: error: in-class initialization of static data member ‘int sync_short_impl::ios []’ of incomplete type  tic int ios[] = {sizeof(gr_complex), sizeof(float), sizeof(float), sizeof(float)};
^
/home/john/myprefix/src/gr-ieee-80211/lib/sync_short.cc:32:31: error: ‘ios’ is not a type
 static std::vector<int> iosig(ios, ios+sizeof(ios)/sizeof(int));
                               ^
/home/john/myprefix/src/gr-ieee-80211/lib/sync_short.cc:32:36: error: ‘ios’ is not a type
 static std::vector<int> iosig(ios, ios+sizeof(ios)/sizeof(int));
                                    ^
/home/john/myprefix/src/gr-ieee-80211/lib/sync_short.cc:32:39: error: expected ‘,’ or ‘...’ before ‘+’ token
 static std::vector<int> iosig(ios, ios+sizeof(ios)/sizeof(int));
                                       ^
/home/john/myprefix/src/gr-ieee-80211/lib/sync_short.cc: In constructor ‘sync_short_impl::sync_short_impl(double, unsigned int, bool, bool)’: /home/john/myprefix/src/gr-ieee-80211/lib/sync_short.cc:35:39: error: no matching function for call to ‘gr::io_signature::makev(int, int, std::vector<int> (&)(int, int))’
    gr::io_signature::makev(4, 4, iosig),
                                       ^
In file included from /home/john/myprefix/include/gnuradio/basic_block.h:30:0,
                 from /home/john/myprefix/include/gnuradio/block.h:27,
                 from /home/john/myprefix/src/gr-ieee-80211/include/ieee802-11/sync_short.h:21,                  from /home/john/myprefix/src/gr-ieee-80211/lib/sync_short.cc:17: /home/john/myprefix/include/gnuradio/io_signature.h:100:17: note: candidate: static gr::io_signature::sptr gr::io_signature::makev(int, int, const std::vector<int>&)
     static sptr makev(int min_streams, int max_streams,
                 ^
/home/john/myprefix/include/gnuradio/io_signature.h:100:17: note:   no known conversion for argument 3 from ‘std::vector<int>(int, int)’ to ‘const std::vector<int>&’ lib/CMakeFiles/gnuradio-ieee802_11.dir/build.make:584: recipe for target 'lib/CMakeFiles/gnuradio-ieee802_11.dir/sync_short.cc.o' failed make[2]: *** [lib/CMakeFiles/gnuradio-ieee802_11.dir/sync_short.cc.o] Error 1 CMakeFiles/Makefile2:200: recipe for target 'lib/CMakeFiles/gnuradio-ieee802_11.dir/all' failed
make[1]: *** [lib/CMakeFiles/gnuradio-ieee802_11.dir/all] Error 2
Makefile:138: recipe for target 'all' failed
make: *** [all] Error 2

/*
 * Copyright (C) 2013, 2016 Bastian Bloessl <bloe...@ccs-labs.org>
 *
 * This program 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.
 *
 * This program 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 this program.  If not, see <http://www.gnu.org/licenses/>.
 */
#include <ieee802-11/sync_short.h>
#include <gnuradio/io_signature.h>
#include "utils.h"

#include <iostream>

using namespace gr::ieee802_11;

static const int MIN_GAP = 480;
static const int MAX_SAMPLES = 540 * 80;

class sync_short_impl : public sync_short {

public:
static int ios[] = {sizeof(gr_complex), sizeof(gr_complex), sizeof(gr_complex), sizeof(float)};
static std::vector<int> iosig(ios, ios+sizeof(ios)/sizeof(int));
sync_short_impl(double threshold, unsigned int min_plateau, bool log, bool debug) :
		block("sync_short",
			gr::io_signature::makev(4, 4, iosig),
			gr::io_signature::make2(2, 2, sizeof(gr_complex), sizeof(gr_complex))),
		d_log(log),
		d_debug(debug),
		d_state(SEARCH),
		d_plateau(0),
		d_freq_offset(0),
		d_copied(0),
		MIN_PLATEAU(min_plateau),
		d_threshold(threshold) {

	set_tag_propagation_policy(block::TPP_DONT);
}

int general_work (int noutput_items, gr_vector_int& ninput_items,
		gr_vector_const_void_star& input_items,
		gr_vector_void_star& output_items) {

	const gr_complex *in = (const gr_complex*)input_items[0];
	const gr_complex *in_1 = (const gr_complex*)input_items[1];
	const gr_complex *in_abs = (const gr_complex*)input_items[2];
	const float *in_cor = (const float*)input_items[3];
	gr_complex *out = (gr_complex*)output_items[0];
	gr_complex *out_1 = (gr_complex*)output_items[1];

	int noutput = noutput_items;
int ninput = std::min(std::min(ninput_items[2] ,std::min(ninput_items[0], ninput_items[1])), ninput_items[3]);

	// dout << "SHORT noutput : " << noutput << " ninput: " << ninput_items[0] << std::endl;

	switch(d_state) {

	case SEARCH: {
		int i;

		for(i = 0; i < ninput; i++) {
			if(in_cor[i] > d_threshold) {
				if(d_plateau < MIN_PLATEAU) {
					d_plateau++;

				} else {
					d_state = COPY;
					d_copied = 0;
					d_freq_offset = arg(in_abs[i]) / 16;
					d_plateau = 0;
					insert_tag(nitems_written(0), d_freq_offset, nitems_read(0) + i);
					dout << "SHORT Frame!" << std::endl;
					break;
				}
			} else {
				d_plateau = 0;
			}
		}

		consume_each(i);
		return 0;
	}

	case COPY: {

		int o = 0;
		while( o < ninput && o < noutput && d_copied < MAX_SAMPLES) {
			if(in_cor[o] > d_threshold) {
				if(d_plateau < MIN_PLATEAU) {
					d_plateau++;

				// there's another frame
				} else if(d_copied > MIN_GAP) {
					d_copied = 0;
					d_plateau = 0;
					d_freq_offset = arg(in_abs[o]) / 16;
					insert_tag(nitems_written(0) + o, d_freq_offset, nitems_read(0) + o);
					dout << "SHORT Frame!" << std::endl;
					break;
				}

			} else {
				d_plateau = 0;
			}

			out[o] = in[o] * exp(gr_complex(0, -d_freq_offset * d_copied));
			out_1[o] = in[o] * exp(gr_complex(0, -d_freq_offset * d_copied));
			o++;
			d_copied++;
		}

		if(d_copied == MAX_SAMPLES) {
			d_state = SEARCH;
		}

		dout << "SHORT copied " << o << std::endl;

		consume_each(o);
		return o;
	}
	}

	throw std::runtime_error("sync short: unknown state");
	return 0;
}

void insert_tag(uint64_t item, double freq_offset, uint64_t input_item) {
	mylog(boost::format("frame start at in: %2% out: %1%") % item % input_item);

	const pmt::pmt_t key = pmt::string_to_symbol("wifi_start");
	const pmt::pmt_t value = pmt::from_double(freq_offset);
	const pmt::pmt_t srcid = pmt::string_to_symbol(name());
	add_item_tag(0, item, key, value, srcid);
}

private:
	enum {SEARCH, COPY} d_state;
	int d_copied;
	int d_plateau;
	float d_freq_offset;
	const double d_threshold;
	const bool d_log;
	const bool d_debug;
	const unsigned int MIN_PLATEAU;
};

sync_short::sptr
sync_short::make(double threshold, unsigned int min_plateau, bool log, bool debug) {
	return gnuradio::get_initial_sptr(new sync_short_impl(threshold, min_plateau, log, debug));
}
_______________________________________________
Discuss-gnuradio mailing list
Discuss-gnuradio@gnu.org
https://lists.gnu.org/mailman/listinfo/discuss-gnuradio

Reply via email to