⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 gr_constellation_decoder_cb.cc

📁 这是用python语言写的一个数字广播的信号处理工具包。利用它
💻 CC
字号:
/* -*- c++ -*- *//* * Copyright 2006 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 <gr_constellation_decoder_cb.h>#include <gr_io_signature.h>#include <stdexcept>#include <iostream>using std::cout;using std::endl;static const bool compute_EVM = false;gr_constellation_decoder_cb_sptrgr_make_constellation_decoder_cb (const std::vector<gr_complex> &sym_position, 				  const std::vector<unsigned char> &sym_value_out){  return gr_constellation_decoder_cb_sptr 		(new gr_constellation_decoder_cb(sym_position, sym_value_out));}gr_constellation_decoder_cb::gr_constellation_decoder_cb (const std::vector<gr_complex> &sym_position, 			     const std::vector<unsigned char> &sym_value_out)  : gr_sync_block ("constellation_decoder_cb",		   gr_make_io_signature (1, 1, sizeof (gr_complex)),		   gr_make_io_signature (1, 1, sizeof (unsigned char)))	{  if (!set_constellation(sym_position,sym_value_out))    throw std::invalid_argument("constellation_decoder_cb");}gr_constellation_decoder_cb::~gr_constellation_decoder_cb(){}boolgr_constellation_decoder_cb::set_constellation(const std::vector<gr_complex> &sym_position, 			                       const std::vector<unsigned char> &sym_value_out){  if (sym_position.size() != sym_value_out.size())    return false;  if (sym_position.size()<1)    return false;  d_sym_position  = sym_position;  d_sym_value_out = sym_value_out;	  return true;}intgr_constellation_decoder_cb::work(int noutput_items,				  gr_vector_const_void_star &input_items,				  gr_vector_void_star &output_items){  gr_complex const *in = (const gr_complex *) input_items[0];  unsigned char *out = (unsigned char *) output_items[0];  unsigned int table_size = d_sym_value_out.size();  unsigned int min_index = 0;  float min_euclid_dist = 0;  float euclid_dist = 0;  double total_error = 0;      for(int i = 0; i < noutput_items; i++){    min_euclid_dist = norm(in[i] - d_sym_position[0]);     min_index = 0;     for (unsigned int j = 1; j < table_size; j++){      euclid_dist = norm(in[i] - d_sym_position[j]);      if (euclid_dist < min_euclid_dist){	min_euclid_dist = euclid_dist;	min_index = j;      }    }    out[i] = d_sym_value_out[min_index];    if (compute_EVM)      total_error += sqrtf(min_euclid_dist);  }  if (compute_EVM){    double mean = total_error / noutput_items;    double rms = sqrt(mean * mean);    fprintf(stderr, "EVM = %8.4f\n", rms);  }  return noutput_items;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -