Single Carrier¶

Single carrier waveforms modulate only a single discrete carrier frequency. They are typically applying a shaping filter around the modulated frequency, of which the following are currently available:
- class FilteredSingleCarrierWaveform(symbol_rate=1000000.0, num_preamble_symbols=16, num_data_symbols=256, num_postamble_symbols=0, pilot_rate=0, guard_interval=0.0, oversampling_factor=4, pilot_symbol_sequence=None, repeat_pilot_symbol_sequence=True, **kwargs)[source]¶
Bases:
ConfigurablePilotWaveform
This method provides a class for a generic PSK/QAM modem.
The modem has the following characteristics: - root-raised cosine filter with arbitrary roll-off factor - arbitrary constellation, as defined in modem.tools.psk_qam_mapping:PskQamMapping
This implementation has currently the following limitations: - hard output only (no LLR) - no reference signal - ideal channel estimation - equalization of ISI with FMCW in AWGN channel only - no equalization (only amplitude and phase of first propagation path is compensated)
- Parameters:
symbol_rate (
float
) – Rate at which symbols are being generated in Hz.num_preamble_symbols (
int
) – Number of preamble symbols within a single communication frame.num_data_symbols (
int
) – Number of data symbols within a single communication frame.num_postamble_symbols (
int
) – Number of postamble symbols within a single communication frame.guard_interval (
float
) – Guard interval between communication frames in seconds. Zero by default.oversampling_factor (
int
) – The oversampling factor of the waform.pilot_rate (
int
) – Pilot symbol rate. Zero by default, i.e. no pilot symbols.pilot_symbol_sequence (
PilotSymbolSequence
|None
) – The configured pilot symbol sequence. Uniform by default.repeat_pilot_symbol_sequence (
bool
) – Allow the repetition of pilot symbol sequences. Enabled by default.**kwargs (
Any
) – Waveform generator base class initialization parameters.
- classmethod Deserialize(process)[source]¶
Deserialize an object’s state.
Objects cannot be deserialized directly, instead a
Factory
must be instructed to carry out the deserialization process.- Parameters:
process (
DeserializationProcess
) – The current stage of the deserialization process. This object is generated by theFactory
and provides an interface to deserialization methods supporting multiple backends.- Return type:
- Returns:
The deserialized object.
- map(bits)[source]¶
Map a stream of bits to data symbols.
- Parameters:
data_bits – Vector containing a sequence of L hard data bits to be mapped onto data symbols.
- Return type:
Returns: Mapped data symbols.
- modulate(symbols)[source]¶
Modulate a stream of data symbols to a base-band signal containing a single data frame.
- Parameters:
data_symbols – Singular stream of data symbols to be modulated by this waveform.
- Return type:
Returns: Samples of the modulated base-band signal.
- pick(symbols)[source]¶
Pick the mapped symbols from the communicaton frame.
Additionally removes interleaved pilot symbols.
- Parameters:
placed_symbols – The placed symbols.
- Return type:
Returns: The symbols with the mapped symbols picked from the frame.
- place(data_symbols)[source]¶
Place the mapped symbols within the communicaton frame.
Additionally interleaves pilot symbols.
- Parameters:
symbols – The mapped symbols.
- Return type:
Returns: The symbols with the mapped symbols placed within the frame.
- plot_filter()[source]¶
Plot the transmit filter shape.
Returns: Handle to the generated matplotlib figure.
- Return type:
- plot_filter_correlation()[source]¶
Plot the convolution between transmit and receive filter shapes.
Returns: Handle to the generated matplotlib figure.
- Return type:
- serialize(process)[source]¶
Serialize this object’s state.
Objects cannot be serialized directly, instead a
Factory
must be instructed to carry out the serialization process.- Parameters:
process (
SerializationProcess
) – The current stage of the serialization process. This object is generated by theFactory
and provides an interface to serialization methods supporting multiple backends.- Return type:
- property bit_energy: float¶
Returns the theoretical average (discrete-time) bit energy of the modulated baseband_signal.
Energy of baseband_signal \(x[k]\) is defined as \(\sum{|x[k]}^2\) Only data bits are considered, i.e., reference, guard intervals are ignored.
- property guard_interval: float¶
Frame guard interval.
- Raises:
ValueError – If interval is smaller than zero.
- property modulation_order: int¶
Access the modulation order.
- Returns:
The modulation order.
- Return type:
- property num_data_symbols: int¶
Number of data symbols per frame.
- Raises:
ValueError – If num is smaller than zero.
- property num_postamble_symbols: int¶
Number of postamble symbols.
Transmitted at the end of communication frames.
- Raises:
ValueError – If the number of symbols is smaller than zero.
- property num_preamble_symbols: int¶
Number of preamble symbols.
Transmitted at the beginning of communication frames.
- Raises:
ValueError – If the number of symbols is smaller than zero.
- property pilot_rate: int¶
Repetition rate of pilot symbols within the frame.
A pilot rate of zero indicates no pilot symbols within the data frame.
- Raises:
ValueError – If the pilot rate is smaller than zero.
- property pilot_signal: Signal¶
Model of the pilot sequence within this communication waveform.
Returns: The pilot sequence.
- property power: float¶
Returns the theoretical average symbol (unitless) power,
Power of baseband_signal \(x[k]\) is defined as \(\sum_{k=1}^N{|x[k]|}^2 / N\) Power is the average power of the data part of the transmitted frame, i.e., bit energy x raw bit rate
- property sampling_rate: float¶
Rate at which the waveform generator signal is internally sampled.
Returns: Sampling rate in Hz.
- property symbol_energy: float¶
The theoretical average symbol (discrete-time) energy of the modulated baseband_signal.
Energy of baseband_signal \(x[k]\) is defined as \(\sum{|x[k]}^2\) Only data bits are considered, i.e., reference, guard intervals are ignored.
- Returns:
The average symbol energy in UNIT.
- property symbol_rate: float¶
Repetition rate of symbols.
Returns: Symbol rate in Hz.
- Raises:
ValueError – For rates smaller or equal to zero.
- class RolledOffSingleCarrierWaveform(relative_bandwidth=1.0, roll_off=0.0, filter_length=16, *args, **kwargs)[source]¶
Bases:
FilteredSingleCarrierWaveform
Base class for single carrier waveforms applying linear filters longer than a single symbol duration.
- Parameters:
relative_bandwidth (
float
) – Bandwidth relative to the configured symbol rate. One by default, meaning the pulse bandwidth is equal to the symbol rate in Hz, assuming zero roll_off.roll_off (
float
) – Filter pulse shape roll off factor between zero and one. Zero by default, meaning no inter-symbol interference at the sampling instances.filter_length (
int
) – Filter length in modulation symbols. 16 by default.
- serialize(process)[source]¶
Serialize this object’s state.
Objects cannot be serialized directly, instead a
Factory
must be instructed to carry out the serialization process.- Parameters:
process (
SerializationProcess
) – The current stage of the serialization process. This object is generated by theFactory
and provides an interface to serialization methods supporting multiple backends.- Return type:
- property bandwidth: float¶
Bandwidth of the frame generated by this generator.
Used to estimate the minimal sampling frequency required to adequately simulate the scenario.
Returns: Bandwidth in Hz.
- property filter_length: int¶
Filter length in modulation symbols.
Configures how far the shaping filter stretches in terms of the number of modulation symbols it overlaps with.
- Raises:
ValueError – For filter lengths smaller than one.
- property relative_bandwidth: float¶
Bandwidth relative to the configured symbol rate.
- Raises:
ValueError – On values smaller or equal to zero.
- property roll_off: float¶
Filter pulse shape roll off factor.
- Raises:
ValueError – On values smaller than zero or larger than one.