1
0
mirror of https://github.com/gnss-sdr/gnss-sdr synced 2025-01-08 00:10:34 +00:00

Added support to select the frontend clock reference source in UHD

signal source (i.e. internal or external clock reference)
This commit is contained in:
Javier 2015-06-17 18:07:36 +02:00
parent df48bf7342
commit a31542cbf6
3 changed files with 20 additions and 21 deletions

View File

@ -7,7 +7,7 @@
;######### GLOBAL OPTIONS ################## ;######### GLOBAL OPTIONS ##################
;internal_fs_hz: Internal signal sampling frequency after the signal conditioning stage [Hz]. ;internal_fs_hz: Internal signal sampling frequency after the signal conditioning stage [Hz].
GNSS-SDR.internal_fs_hz=2000000 GNSS-SDR.internal_fs_hz=4000000
;######### CONTROL_THREAD CONFIG ############ ;######### CONTROL_THREAD CONFIG ############
ControlThread.wait_for_flowgraph=false ControlThread.wait_for_flowgraph=false
@ -28,8 +28,10 @@ GNSS-SDR.SUPL_CI=0x31b0
SignalSource.implementation=UHD_Signal_Source SignalSource.implementation=UHD_Signal_Source
SignalSource.device_address=192.168.50.2 SignalSource.device_address=192.168.50.2
SignalSource.item_type=cshort SignalSource.item_type=cshort
SignalSource.sampling_frequency=2000000 SignalSource.sampling_frequency=4000000
SignalSource.freq=1227600000 SignalSource.freq=1227600000
;### Options: internal, external, or MIMO
SignalSource.clock_source=internal
SignalSource.gain=35 SignalSource.gain=35
SignalSource.subdevice=A:0 SignalSource.subdevice=A:0
SignalSource.samples=0 SignalSource.samples=0
@ -71,7 +73,7 @@ InputFilter.band2_error=1.0
InputFilter.filter_type=bandpass InputFilter.filter_type=bandpass
InputFilter.grid_density=16 InputFilter.grid_density=16
InputFilter.sampling_frequency=2000000 InputFilter.sampling_frequency=4000000
InputFilter.IF=0 InputFilter.IF=0
;######### RESAMPLER CONFIG ############ ;######### RESAMPLER CONFIG ############
@ -79,13 +81,13 @@ Resampler.implementation=Pass_Through
Resampler.dump=false Resampler.dump=false
Resampler.dump_filename=../data/resampler.dat Resampler.dump_filename=../data/resampler.dat
Resampler.item_type=gr_complex Resampler.item_type=gr_complex
Resampler.sample_freq_in=2000000 Resampler.sample_freq_in=4000000
Resampler.sample_freq_out=2000000 Resampler.sample_freq_out=4000000
;######### CHANNELS GLOBAL CONFIG ############ ;######### CHANNELS GLOBAL CONFIG ############
;#count: Number of available GPS satellite channels. ;#count: Number of available GPS satellite channels.
Channels_2S.count=2 Channels_2S.count=1
;#in_acquisition: Number of channels simultaneously acquiring for the whole receiver ;#in_acquisition: Number of channels simultaneously acquiring for the whole receiver
Channels.in_acquisition=1 Channels.in_acquisition=1
@ -108,32 +110,28 @@ Channel7.signal=2S
;######### ACQUISITION GLOBAL CONFIG ############ ;######### ACQUISITION GLOBAL CONFIG ############
;# GPS L2C M
Acquisition_2S.dump=false Acquisition_2S.dump=false
Acquisition_2S.dump_filename=./acq_dump.dat Acquisition_2S.dump_filename=./acq_dump.dat
Acquisition_2S.item_type=gr_complex Acquisition_2S.item_type=gr_complex
Acquisition_2S.if=0 Acquisition_2S.if=0
Acquisition_2S.coherent_integration_time_ms=1
Acquisition_2S.implementation=GPS_L2_M_PCPS_Acquisition Acquisition_2S.implementation=GPS_L2_M_PCPS_Acquisition
Acquisition_2S.threshold=0.001 Acquisition_2S.threshold=0.0015
;Acquisition_2S.pfa=0.00001 ;Acquisition_2S.pfa=0.001
Acquisition_2S.doppler_max=5000 Acquisition_2S.doppler_max=5000
Acquisition_2S.doppler_step=30 Acquisition_2S.doppler_min=-5000
Acquisition_2S.bit_transition_flag=false Acquisition_2S.doppler_step=60
Acquisition_2S.max_dwells=1 Acquisition_2S.max_dwells=1
;######### TRACKING GLOBAL CONFIG ############
Tracking_2S.implementation=GPS_L2_M_DLL_PLL_Tracking Tracking_2S.implementation=GPS_L2_M_DLL_PLL_Tracking
Tracking_2S.item_type=gr_complex Tracking_2S.item_type=gr_complex
Tracking_2S.if=0 Tracking_2S.if=0
Tracking_2S.dump=true Tracking_2S.dump=true
Tracking_2S.dump_filename=./tracking_ch_ Tracking_2S.dump_filename=./tracking_ch_
Tracking_2S.pll_bw_hz=2.0; Tracking_2S.pll_bw_hz=2.0;
Tracking_2S.dll_bw_hz=0.3; Tracking_2S.dll_bw_hz=0.25;
Tracking_2S.fll_bw_hz=2.0; Tracking_2S.fll_bw_hz=0.0;
Tracking_2S.order=3; Tracking_2S.order=2;
Tracking_2S.early_late_space_chips=0.5; Tracking_2S.early_late_space_chips=0.5;
;######### TELEMETRY DECODER GPS CONFIG ############ ;######### TELEMETRY DECODER GPS CONFIG ############

View File

@ -64,6 +64,7 @@ UhdSignalSource::UhdSignalSource(ConfigurationInterface* configuration,
} }
subdevice_ = configuration->property(role + ".subdevice", empty); subdevice_ = configuration->property(role + ".subdevice", empty);
clock_source_ = configuration->property(role + ".clock_source", std::string("internal"));
RF_channels_ = configuration->property(role + ".RF_channels", 1); RF_channels_ = configuration->property(role + ".RF_channels", 1);
sample_rate_ = configuration->property(role + ".sampling_frequency", (double)4.0e6); sample_rate_ = configuration->property(role + ".sampling_frequency", (double)4.0e6);
item_type_ = configuration->property(role + ".item_type", default_item_type); item_type_ = configuration->property(role + ".item_type", default_item_type);
@ -152,8 +153,7 @@ UhdSignalSource::UhdSignalSource(ConfigurationInterface* configuration,
// 2.1 set sampling clock reference // 2.1 set sampling clock reference
// Set the clock source for the usrp device. // Set the clock source for the usrp device.
// Options: internal, external, or MIMO // Options: internal, external, or MIMO
std::string clk_reference = "internal"; uhd_source_->set_clock_source(clock_source_);
uhd_source_->set_clock_source(clk_reference);
// 2.2 set the sample rate for the usrp device // 2.2 set the sample rate for the usrp device
uhd_source_->set_samp_rate(sample_rate_); uhd_source_->set_samp_rate(sample_rate_);

View File

@ -94,6 +94,7 @@ private:
size_t item_size_; size_t item_size_;
std::string subdevice_; std::string subdevice_;
std::string clock_source_;
std::vector<double> freq_; std::vector<double> freq_;
std::vector<double> gain_; std::vector<double> gain_;