58class signal_generator_c :
public gr::block
61 ~signal_generator_c() =
default;
64 int general_work(
int noutput_items,
65 gr_vector_int &ninput_items,
66 gr_vector_const_void_star &input_items,
67 gr_vector_void_star &output_items);
71 const std::vector<std::string> &signal1,
72 const std::vector<std::string> &system,
73 const std::vector<unsigned int> &PRN,
74 const std::vector<float> &CN0_dB,
75 const std::vector<float> &doppler_Hz,
76 const std::vector<unsigned int> &delay_chips,
77 const std::vector<unsigned int> &delay_sec,
81 unsigned int vector_length,
85 std::vector<std::string> signal1,
86 std::vector<std::string> system,
87 const std::vector<unsigned int> &PRN,
88 std::vector<float> CN0_dB,
89 std::vector<float> doppler_Hz,
90 std::vector<unsigned int> delay_chips,
91 std::vector<unsigned int> delay_sec,
95 unsigned int vector_length,
100 void generate_codes();
102 std::random_device r;
103 std::uniform_int_distribution<int> uniform_dist;
104 std::normal_distribution<float> normal_dist;
105 std::vector<std::string> signal_;
106 std::vector<std::string> system_;
107 std::vector<std::vector<gr_complex>> sampled_code_data_;
108 std::vector<std::vector<gr_complex>> sampled_code_pilot_;
109 std::vector<gr_complex> current_data_bits_;
110 std::vector<gr_complex> complex_phase_;
111 std::vector<float> CN0_dB_;
112 std::vector<float> doppler_Hz_;
113 std::vector<float> start_phase_rad_;
114 std::vector<unsigned int> PRN_;
115 std::vector<unsigned int> delay_chips_;
116 std::vector<unsigned int> delay_sec_;
117 std::vector<unsigned int> samples_per_code_;
118 std::vector<unsigned int> num_of_codes_per_vector_;
119 std::vector<unsigned int> data_bit_duration_ms_;
120 std::vector<unsigned int> ms_counter_;
121 std::vector<signed int> current_data_bit_int_;
122 std::vector<signed int> data_modulation_;
123 std::vector<signed int> pilot_modulation_;
125 unsigned int work_counter_{};
127 unsigned int num_sats_;
128 unsigned int vector_length_;
friend signal_generator_c_sptr signal_make_generator_c(const std::vector< std::string > &signal1, const std::vector< std::string > &system, const std::vector< unsigned int > &PRN, const std::vector< float > &CN0_dB, const std::vector< float > &doppler_Hz, const std::vector< unsigned int > &delay_chips, const std::vector< unsigned int > &delay_sec, bool data_flag, bool noise_flag, unsigned int fs_in, unsigned int vector_length, float BW_BB)
Return a shared_ptr to a new instance of gen_source.
signal_generator_c_sptr signal_make_generator_c(const std::vector< std::string > &signal1, const std::vector< std::string > &system, const std::vector< unsigned int > &PRN, const std::vector< float > &CN0_dB, const std::vector< float > &doppler_Hz, const std::vector< unsigned int > &delay_chips, const std::vector< unsigned int > &delay_sec, bool data_flag, bool noise_flag, unsigned int fs_in, unsigned int vector_length, float BW_BB)
Return a shared_ptr to a new instance of gen_source.