mirror of
				https://github.com/gnss-sdr/gnss-sdr
				synced 2025-10-22 11:07:41 +00:00 
			
		
		
		
	Correlator class now takes profit of the GNU Radio memory alignment, used by Volk SIMD functions
git-svn-id: https://svn.code.sf.net/p/gnss-sdr/code/trunk@218 64b25241-fba3-4117-9849-534c7e92360d
This commit is contained in:
		| @@ -17,7 +17,7 @@ ControlThread.wait_for_flowgraph=false | |||||||
| SignalSource.implementation=File_Signal_Source | SignalSource.implementation=File_Signal_Source | ||||||
|  |  | ||||||
| ;#filename: path to file with the captured GNSS signal samples to be processed | ;#filename: path to file with the captured GNSS signal samples to be processed | ||||||
| ;SignalSource.filename=../data/my_capture.dat | SignalSource.filename=/media/DATALOGGER_/signals/Agilent GPS Generator/cap2/agilent_cap2.dat | ||||||
|  |  | ||||||
| ;#item_type: Type and resolution for each of the signal samples. Use only gr_complex in this version. | ;#item_type: Type and resolution for each of the signal samples. Use only gr_complex in this version. | ||||||
| SignalSource.item_type=gr_complex | SignalSource.item_type=gr_complex | ||||||
| @@ -292,7 +292,7 @@ Acquisition.sampled_ms=1 | |||||||
| ;#implementation: Acquisition algorithm selection for this channel: [GPS_L1_CA_PCPS_Acquisition] | ;#implementation: Acquisition algorithm selection for this channel: [GPS_L1_CA_PCPS_Acquisition] | ||||||
| Acquisition0.implementation=GPS_L1_CA_PCPS_Acquisition | Acquisition0.implementation=GPS_L1_CA_PCPS_Acquisition | ||||||
| ;#threshold: Acquisition threshold | ;#threshold: Acquisition threshold | ||||||
| Acquisition0.threshold=50 | Acquisition0.threshold=70 | ||||||
| ;#doppler_max: Maximum expected Doppler shift [Hz] | ;#doppler_max: Maximum expected Doppler shift [Hz] | ||||||
| Acquisition0.doppler_max=10000 | Acquisition0.doppler_max=10000 | ||||||
| ;#doppler_max: Doppler step in the grid search [Hz] | ;#doppler_max: Doppler step in the grid search [Hz] | ||||||
| @@ -302,28 +302,28 @@ Acquisition0.doppler_step=250 | |||||||
|  |  | ||||||
| ;######### ACQUISITION CH 1 CONFIG ############ | ;######### ACQUISITION CH 1 CONFIG ############ | ||||||
| Acquisition1.implementation=GPS_L1_CA_PCPS_Acquisition | Acquisition1.implementation=GPS_L1_CA_PCPS_Acquisition | ||||||
| Acquisition1.threshold=50 | Acquisition1.threshold=70 | ||||||
| Acquisition1.doppler_max=10000 | Acquisition1.doppler_max=10000 | ||||||
| Acquisition1.doppler_step=250 | Acquisition1.doppler_step=250 | ||||||
|  |  | ||||||
|  |  | ||||||
| ;######### ACQUISITION CH 2 CONFIG ############ | ;######### ACQUISITION CH 2 CONFIG ############ | ||||||
| Acquisition2.implementation=GPS_L1_CA_PCPS_Acquisition | Acquisition2.implementation=GPS_L1_CA_PCPS_Acquisition | ||||||
| Acquisition2.threshold=50 | Acquisition2.threshold=70 | ||||||
| Acquisition2.doppler_max=10000 | Acquisition2.doppler_max=10000 | ||||||
| Acquisition2.doppler_step=250 | Acquisition2.doppler_step=250 | ||||||
|  |  | ||||||
|  |  | ||||||
| ;######### ACQUISITION CH 3 CONFIG ############ | ;######### ACQUISITION CH 3 CONFIG ############ | ||||||
| Acquisition3.implementation=GPS_L1_CA_PCPS_Acquisition | Acquisition3.implementation=GPS_L1_CA_PCPS_Acquisition | ||||||
| Acquisition3.threshold=50 | Acquisition3.threshold=70 | ||||||
| Acquisition3.doppler_max=10000 | Acquisition3.doppler_max=10000 | ||||||
| Acquisition3.doppler_step=250 | Acquisition3.doppler_step=250 | ||||||
|  |  | ||||||
|  |  | ||||||
| ;######### ACQUISITION CH 4 CONFIG ############ | ;######### ACQUISITION CH 4 CONFIG ############ | ||||||
| Acquisition4.implementation=GPS_L1_CA_PCPS_Acquisition | Acquisition4.implementation=GPS_L1_CA_PCPS_Acquisition | ||||||
| Acquisition4.threshold=50 | Acquisition4.threshold=70 | ||||||
| Acquisition4.doppler_max=10000 | Acquisition4.doppler_max=10000 | ||||||
| Acquisition4.doppler_step=250 | Acquisition4.doppler_step=250 | ||||||
|  |  | ||||||
| @@ -409,7 +409,7 @@ Observables.dump_filename=./observables.dat | |||||||
| PVT.implementation=GPS_L1_CA_PVT | PVT.implementation=GPS_L1_CA_PVT | ||||||
|  |  | ||||||
| ;#averaging_depth: Number of PVT observations in the moving average algorithm | ;#averaging_depth: Number of PVT observations in the moving average algorithm | ||||||
| PVT.averaging_depth=100 | PVT.averaging_depth=10 | ||||||
|  |  | ||||||
| ;#flag_average: Enables the PVT averaging between output intervals (arithmetic mean) [true] or [false]  | ;#flag_average: Enables the PVT averaging between output intervals (arithmetic mean) [true] or [false]  | ||||||
| PVT.flag_averaging=true | PVT.flag_averaging=true | ||||||
|   | |||||||
| @@ -389,8 +389,8 @@ int Gps_L1_Ca_Dll_Fll_Pll_Tracking_cc::general_work (int noutput_items, gr_vecto | |||||||
|                     d_late_code, |                     d_late_code, | ||||||
|                     d_Early, |                     d_Early, | ||||||
|                     d_Prompt, |                     d_Prompt, | ||||||
|                     d_Late); |                     d_Late, | ||||||
|  |                     is_unaligned()); | ||||||
|             // check for samples consistency (this should be done before in the receiver / here only if the source is a file) |             // check for samples consistency (this should be done before in the receiver / here only if the source is a file) | ||||||
|             if (std::isnan((*d_Prompt).real()) == true or std::isnan((*d_Prompt).imag()) == true )// or std::isinf(in[i].real())==true or std::isinf(in[i].imag())==true) |             if (std::isnan((*d_Prompt).real()) == true or std::isnan((*d_Prompt).imag()) == true )// or std::isinf(in[i].real())==true or std::isinf(in[i].imag())==true) | ||||||
| 			{ | 			{ | ||||||
|   | |||||||
| @@ -386,7 +386,8 @@ int Gps_L1_Ca_Dll_Pll_Tracking_cc::general_work (int noutput_items, gr_vector_in | |||||||
|                     d_late_code, |                     d_late_code, | ||||||
|                     d_Early, |                     d_Early, | ||||||
|                     d_Prompt, |                     d_Prompt, | ||||||
|                     d_Late); |                     d_Late, | ||||||
|  |                     is_unaligned()); | ||||||
|  |  | ||||||
|             // check for samples consistency (this should be done before in the receiver / here only if the source is a file) |             // check for samples consistency (this should be done before in the receiver / here only if the source is a file) | ||||||
|             if (std::isnan((*d_Prompt).real()) == true or std::isnan((*d_Prompt).imag()) == true )// or std::isinf(in[i].real())==true or std::isinf(in[i].imag())==true) |             if (std::isnan((*d_Prompt).real()) == true or std::isnan((*d_Prompt).imag()) == true )// or std::isinf(in[i].real())==true or std::isinf(in[i].imag())==true) | ||||||
|   | |||||||
| @@ -424,7 +424,8 @@ int Gps_L1_Ca_Tcp_Connector_Tracking_cc::general_work (int noutput_items, gr_vec | |||||||
|                     d_late_code, |                     d_late_code, | ||||||
|                     d_Early, |                     d_Early, | ||||||
|                     d_Prompt, |                     d_Prompt, | ||||||
|                     d_Late); |                     d_Late, | ||||||
|  |                     is_unaligned()); | ||||||
|  |  | ||||||
|             // check for samples consistency (this should be done before in the receiver / here only if the source is a file) |             // check for samples consistency (this should be done before in the receiver / here only if the source is a file) | ||||||
|             if (std::isnan((*d_Prompt).real()) == true or std::isnan((*d_Prompt).imag()) == true )// or std::isinf(in[i].real())==true or std::isinf(in[i].imag())==true) |             if (std::isnan((*d_Prompt).real()) == true or std::isnan((*d_Prompt).imag()) == true )// or std::isinf(in[i].real())==true or std::isinf(in[i].imag())==true) | ||||||
|   | |||||||
| @@ -73,23 +73,19 @@ void Correlator::Carrier_wipeoff_and_EPL_generic(int signal_length_samples,const | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void Correlator::Carrier_wipeoff_and_EPL_volk(int signal_length_samples,const gr_complex* input, gr_complex* carrier,gr_complex* E_code, gr_complex* P_code, gr_complex* L_code,gr_complex* E_out, gr_complex* P_out, gr_complex* L_out) | void Correlator::Carrier_wipeoff_and_EPL_volk(int signal_length_samples,const gr_complex* input, gr_complex* carrier,gr_complex* E_code, gr_complex* P_code, gr_complex* L_code,gr_complex* E_out, gr_complex* P_out, gr_complex* L_out, bool input_vector_aligned) | ||||||
| { | { | ||||||
|     gr_complex* bb_signal; |     gr_complex* bb_signal; | ||||||
|     gr_complex* input_aligned; |     gr_complex* input_aligned; | ||||||
|     //gr_complex* carrier_aligned; |  | ||||||
|  |  | ||||||
|     // signal_length_samples=next_power_2(signal_length_samples); |  | ||||||
|     //std::cout<<"length="<<signal_length_samples<<std::endl; |  | ||||||
|  |  | ||||||
|     //long int new_length=next_power_2(signal_length_samples); |  | ||||||
|     //todo: do something if posix_memalign fails |     //todo: do something if posix_memalign fails | ||||||
|     if (posix_memalign((void**)&bb_signal, 16, signal_length_samples * sizeof(gr_complex)) == 0) {}; |     if (posix_memalign((void**)&bb_signal, 16, signal_length_samples * sizeof(gr_complex)) == 0) {}; | ||||||
|     if (posix_memalign((void**)&input_aligned, 16, signal_length_samples * sizeof(gr_complex)) == 0){}; |  | ||||||
|     //posix_memalign((void**)&carrier_aligned, 16, new_length*sizeof(gr_complex)); |  | ||||||
|  |  | ||||||
|  |     if (input_vector_aligned==false) | ||||||
|  |     { | ||||||
|  |         //todo: do something if posix_memalign fails | ||||||
|  |     	if (posix_memalign((void**)&input_aligned, 16, signal_length_samples * sizeof(gr_complex)) == 0){}; | ||||||
|         memcpy(input_aligned,input,signal_length_samples * sizeof(gr_complex)); |         memcpy(input_aligned,input,signal_length_samples * sizeof(gr_complex)); | ||||||
|     //memcpy(carrier_aligned,carrier,signal_length_samples*sizeof(gr_complex)); |  | ||||||
|  |  | ||||||
|         //volk_32fc_x2_multiply_32fc_a_manual(bb_signal, input_aligned, carrier, signal_length_samples,  volk_32fc_x2_multiply_32fc_a_best_arch.c_str()); |         //volk_32fc_x2_multiply_32fc_a_manual(bb_signal, input_aligned, carrier, signal_length_samples,  volk_32fc_x2_multiply_32fc_a_best_arch.c_str()); | ||||||
|         //volk_32fc_x2_dot_prod_32fc_a_manual(E_out, bb_signal, E_code, signal_length_samples * sizeof(gr_complex),  volk_32fc_x2_dot_prod_32fc_a_best_arch.c_str()); |         //volk_32fc_x2_dot_prod_32fc_a_manual(E_out, bb_signal, E_code, signal_length_samples * sizeof(gr_complex),  volk_32fc_x2_dot_prod_32fc_a_best_arch.c_str()); | ||||||
| @@ -97,13 +93,20 @@ void Correlator::Carrier_wipeoff_and_EPL_volk(int signal_length_samples,const gr | |||||||
|         //volk_32fc_x2_dot_prod_32fc_a_manual(L_out, bb_signal, L_code, signal_length_samples * sizeof(gr_complex),  volk_32fc_x2_dot_prod_32fc_a_best_arch.c_str()); |         //volk_32fc_x2_dot_prod_32fc_a_manual(L_out, bb_signal, L_code, signal_length_samples * sizeof(gr_complex),  volk_32fc_x2_dot_prod_32fc_a_best_arch.c_str()); | ||||||
|  |  | ||||||
|         volk_32fc_x2_multiply_32fc_a(bb_signal, input_aligned, carrier, signal_length_samples); |         volk_32fc_x2_multiply_32fc_a(bb_signal, input_aligned, carrier, signal_length_samples); | ||||||
|  |     }else{ | ||||||
|  |     	//use directly the input vector | ||||||
|  |         volk_32fc_x2_multiply_32fc_a(bb_signal, input, carrier, signal_length_samples); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     volk_32fc_x2_dot_prod_32fc_a(E_out, bb_signal, E_code, signal_length_samples * sizeof(gr_complex)); |     volk_32fc_x2_dot_prod_32fc_a(E_out, bb_signal, E_code, signal_length_samples * sizeof(gr_complex)); | ||||||
|     volk_32fc_x2_dot_prod_32fc_a(P_out, bb_signal, P_code, signal_length_samples * sizeof(gr_complex)); |     volk_32fc_x2_dot_prod_32fc_a(P_out, bb_signal, P_code, signal_length_samples * sizeof(gr_complex)); | ||||||
|     volk_32fc_x2_dot_prod_32fc_a(L_out, bb_signal, L_code, signal_length_samples * sizeof(gr_complex)); |     volk_32fc_x2_dot_prod_32fc_a(L_out, bb_signal, L_code, signal_length_samples * sizeof(gr_complex)); | ||||||
|  |  | ||||||
|     free(bb_signal); |     free(bb_signal); | ||||||
|  |     if (input_vector_aligned==false) | ||||||
|  |     { | ||||||
|     	free(input_aligned); |     	free(input_aligned); | ||||||
|     //free(carrier_aligned); |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| void Correlator::cpu_arch_test_volk_32fc_x2_dot_prod_32fc_a() | void Correlator::cpu_arch_test_volk_32fc_x2_dot_prod_32fc_a() | ||||||
|   | |||||||
| @@ -50,7 +50,7 @@ class Correlator | |||||||
| { | { | ||||||
| public: | public: | ||||||
|     void Carrier_wipeoff_and_EPL_generic(int signal_length_samples,const gr_complex* input, gr_complex* carrier,gr_complex* E_code, gr_complex* P_code, gr_complex* L_code,gr_complex* E_out, gr_complex* P_out, gr_complex* L_out); |     void Carrier_wipeoff_and_EPL_generic(int signal_length_samples,const gr_complex* input, gr_complex* carrier,gr_complex* E_code, gr_complex* P_code, gr_complex* L_code,gr_complex* E_out, gr_complex* P_out, gr_complex* L_out); | ||||||
|     void Carrier_wipeoff_and_EPL_volk(int signal_length_samples,const gr_complex* input, gr_complex* carrier,gr_complex* E_code, gr_complex* P_code, gr_complex* L_code,gr_complex* E_out, gr_complex* P_out, gr_complex* L_out); |     void Carrier_wipeoff_and_EPL_volk(int signal_length_samples,const gr_complex* input, gr_complex* carrier,gr_complex* E_code, gr_complex* P_code, gr_complex* L_code,gr_complex* E_out, gr_complex* P_out, gr_complex* L_out,bool input_vector_aligned); | ||||||
|     Correlator(); |     Correlator(); | ||||||
|     ~Correlator(); |     ~Correlator(); | ||||||
| private: | private: | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Javier Arribas
					Javier Arribas