kopia lustrzana https://github.com/f4exb/sdrangel
				
				
				
			
		
			
				
	
	
		
			102 wiersze
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
			
		
		
	
	
			102 wiersze
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
/*---------------------------------------------------------------------------*\
 | 
						|
 | 
						|
  FILE........: codec2_ofdm.h
 | 
						|
  AUTHORS.....: David Rowe & Steve Sampson
 | 
						|
  DATE CREATED: June 2017
 | 
						|
 | 
						|
  External user references to the modem library.
 | 
						|
 | 
						|
\*---------------------------------------------------------------------------*/
 | 
						|
 | 
						|
/*
 | 
						|
  Copyright (C) 2017 David Rowe
 | 
						|
 | 
						|
  All rights reserved.
 | 
						|
 | 
						|
  This program is free software; you can redistribute it and/or modify
 | 
						|
  it under the terms of the GNU Lesser General Public License version 2.1, as
 | 
						|
  published by the Free Software Foundation.  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 Lesser General Public License
 | 
						|
  along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
						|
*/
 | 
						|
 | 
						|
#ifndef CODEC2_OFDM_H
 | 
						|
#define CODEC2_OFDM_H
 | 
						|
 | 
						|
/* Includes */
 | 
						|
 | 
						|
#include <complex.h>
 | 
						|
#include <stdbool.h>
 | 
						|
#include <stdint.h>
 | 
						|
 | 
						|
#include "codec2/comp.h"
 | 
						|
#include "modem_stats.h"
 | 
						|
 | 
						|
/* Defines */
 | 
						|
 | 
						|
#define OFDM_AMP_SCALE (2E5*1.1491/1.06)   /* use to scale to 16 bit short */
 | 
						|
#define OFDM_CLIP (32767*0.35)             /* experimentally derived constant to reduce PAPR to about 8dB */
 | 
						|
 | 
						|
namespace FreeDV
 | 
						|
{
 | 
						|
 | 
						|
struct OFDM_CONFIG;
 | 
						|
struct OFDM;
 | 
						|
 | 
						|
typedef enum {
 | 
						|
    search,
 | 
						|
    trial,
 | 
						|
    synced
 | 
						|
} State;
 | 
						|
 | 
						|
typedef enum {
 | 
						|
    unsync,             /* force sync state machine to lose sync, and search for new sync */
 | 
						|
    autosync,           /* falls out of sync automatically */
 | 
						|
    manualsync          /* fall out of sync only under operator control */
 | 
						|
} Sync;
 | 
						|
 | 
						|
/* create and destroy modem states */
 | 
						|
 | 
						|
struct OFDM *ofdm_create(const struct OFDM_CONFIG * config);
 | 
						|
void ofdm_destroy(struct OFDM *);
 | 
						|
 | 
						|
/* signal processing */
 | 
						|
 | 
						|
void ofdm_mod(struct OFDM *, COMP *, const int *);
 | 
						|
void ofdm_demod(struct OFDM *, int *, COMP *);
 | 
						|
void ofdm_demod_shorts(struct OFDM *, int *, short *, float);
 | 
						|
int  ofdm_sync_search(struct OFDM *, COMP *);
 | 
						|
int  ofdm_sync_search_shorts(struct OFDM *, short *, float);
 | 
						|
void ofdm_sync_state_machine(struct OFDM *, uint8_t *);
 | 
						|
 | 
						|
/* getters */
 | 
						|
 | 
						|
struct OFDM_CONFIG *ofdm_get_config_param(void);
 | 
						|
int ofdm_get_nin(struct OFDM *);
 | 
						|
int ofdm_get_samples_per_frame(void);
 | 
						|
int ofdm_get_max_samples_per_frame(void);
 | 
						|
int ofdm_get_bits_per_frame(void);
 | 
						|
void ofdm_get_demod_stats(struct OFDM *ofdm, struct MODEM_STATS *stats);
 | 
						|
 | 
						|
/* option setters */
 | 
						|
 | 
						|
void ofdm_set_verbose(struct OFDM *, int);
 | 
						|
void ofdm_set_timing_enable(struct OFDM *, bool);
 | 
						|
void ofdm_set_foff_est_enable(struct OFDM *, bool);
 | 
						|
void ofdm_set_phase_est_enable(struct OFDM *, bool);
 | 
						|
void ofdm_set_off_est_hz(struct OFDM *, float);
 | 
						|
void ofdm_set_sync(struct OFDM *, Sync);
 | 
						|
void ofdm_set_tx_bpf(struct OFDM *, bool);
 | 
						|
 | 
						|
void ofdm_print_info(struct OFDM *);
 | 
						|
 | 
						|
} // FreeDV
 | 
						|
 | 
						|
#endif
 | 
						|
 |