Shape input signal using ideal rectangular pulses
Comm Filters
The Ideal Rectangular Pulse Filter block upsamples and shapes the input signal using rectangular pulses. The block replicates each input sample N times, where N is the Pulse length parameter. After replicating input samples, the block can also normalize the output signal and/or apply a linear amplitude gain.
If the Pulse delay parameter is nonzero, then the block outputs that number of zeros at the beginning of the simulation, before starting to replicate any of the input values.
This block accepts a scalar, column vector, or matrix input signal. For information about the data types each block port supports, see the Supported Data Type table on this page.
The vector size, the pulse length, and the pulse delay are mutually independent. They do not need to satisfy any conditions with respect to each other.
When you set the Rate options parameter
to Enforce singlerate processing
, the
input and output of the block have the same sample rate. To generate
the output while maintaining the input sample rate, the block resamples
the data in each column of the input such that the frame size of the
output (M_{o}) is L times
larger than that of the input (M_{o} = M_{i}*L),
where L is the Pulse length (number of
samples) parameter value.
When you set the Rate options parameter
to Allow multirate processing
, the input
and output of the block are the same size. However, the sample rate
of the output is L times faster than that of the
input (i.e. the output sample time is 1/N times the input sample time).
When the block is in multirate processing mode, you must also specify
a value for the Input processing parameter:
When you set the Input processing parameter
to Elements as channels (sample based)
,
the block treats an MbyN matrix
input as M*N independent channels,
and processes each channel over time. The output sample period (T_{so})
is L times shorter than the input sample period
(T_{so} = T_{si}/L),
while the input and output sizes remain identical.
When you set the Input processing parameter
to Columns as channels (frame based)
, the
block treats an M_{i}byN matrix
input as N independent channels. The block processes
each column of the input over time by keeping the frame size constant
(M_{i}=M_{o}),
while making the output frame period (T_{fo}) L times
shorter than the input frame period (T_{fo} = T_{fi}/L).
You determine the block's normalization behavior using the Normalize output signal and Linear amplitude gain parameters.
If you clear Normalize output signal, then the block multiplies the set of replicated values by the Linear amplitude gain parameter. This parameter must be a scalar.
If you select Normalize output signal, then the Normalization method parameter appears. The block scales the set of replicated values so that one of these conditions is true:
The sum of the samples in each pulse equals the original input value that the block replicated.
The energy in each pulse equals the energy of the original input value that the block replicated. That is, the sum of the squared samples in each pulse equals the square of the input value.
After the block applies the scaling specified in the Normalization method parameter, it multiplies the scaled signal by the constant scalar value specified in the Linear amplitude gain parameter.
The output is scaled by $$\sqrt{N}$$. If the output of this block feeds the input to the AWGN Channel block, specify the AWGN signal power parameter to be 1/N.
The number of samples in each output pulse; that is, the number of times the block replicates each input value when creating the output signal.
The number of zeros that appear in the output at the beginning of the simulation, before the block replicates any input values.
Specify how the block processes the input signal. You can set this parameter to one of the following options:
Columns as channels (frame based)
—
When you select this option, the block treats each column of the input
as a separate channel.
Elements as channels (sample based)
—
When you select this option, the block treats each element of the
input as a separate channel.
Specify the method by which the block should upsample and shape the input signal. You can select one of the following options:
Enforce singlerate processing
—
When you select this option, the block maintains the input sample
rate, and processes the signal by increasing the output frame size
by a factor of L. To select this option, you must
set the Input processing parameter to Columns
as channels (frame based)
.
Allow multirate processing
—
When you select this option, the block processes the signal such that
the output sample rate is L times faster than the
input sample rate.
If you select this, then the block scales the set of replicated values before applying the linear amplitude gain.
The quantity that the block considers when scaling the set of
replicated values. Choices are Sum of samples
and Energy
per pulse
. This field appears only if you select Normalize
method.
A positive scalar used to scale the output signal.
Use this parameter to specify the rounding method to be used
when the result of a fixedpoint calculation does not map exactly
to a number representable by the data type and scaling storing the
result. The filter coefficients do not obey this parameter; they always
round to Nearest
.
For more information, see Rounding Modes (DSP System Toolbox) or Rounding Mode: Simplest (FixedPoint Designer).
Select the overflow mode for fixedpoint operations. The filter coefficients do not obey this parameter; they are always saturated.
Choose how you specify the word length and the fraction length of the filter coefficients (numerator and/or denominator). See Filter Structure Diagrams (DSP System Toolbox) in DSP System Toolbox™ Reference Guide for illustrations depicting the use of the coefficient data types in this block:
When you select Same word length as input
,
the word length of the filter coefficients match that of the input
to the block. In this mode, the fraction length of the coefficients
is automatically set to the binarypoint only scaling that provides
you with the best precision possible given the value and word length
of the coefficients.
When you select Specify word length
,
you are able to enter the word length of the coefficients, in bits.
In this mode, the fraction length of the coefficients is automatically
set to the binarypoint only scaling that provides you with the best
precision possible given the value and word length of the coefficients.
When you select Binary point scaling
,
you are able to enter the word length and the fraction length of the
coefficients, in bits. If applicable, you are able to enter separate
fraction lengths for the numerator and denominator coefficients.
When you select Slope and bias scaling
,
you are able to enter the word length, in bits, and the slope of the
coefficients. If applicable, you are able to enter separate slopes
for the numerator and denominator coefficients. This block requires
poweroftwo slope and a bias of zero.
The filter coefficients do not obey the Rounding mode and the
Saturate on integer overflow parameters; they are always saturated and
rounded to Nearest
.
Use this parameter to specify how you would like to designate the product output word and fraction lengths. See Filter Structure Diagrams (DSP System Toolbox) and Multiplication Data Types (DSP System Toolbox) in DSP System Toolbox Reference Guide for illustrations depicting the use of the product output data type in this block:
When you select Same as input
,
these characteristics match those of the input to the block.
When you select Binary point scaling
,
you are able to enter the word length and the fraction length of the
product output, in bits.
When you select Slope and bias scaling
,
you are able to enter the word length, in bits, and the slope of the
product output. This block requires poweroftwo slope and a bias
of zero.
Use this parameter to specify how you would like to designate the accumulator word and fraction lengths. See Filter Structure Diagrams (DSP System Toolbox) and Multiplication Data Types (DSP System Toolbox) for illustrations depicting the use of the accumulator data type in this block:
When you select Same as input
,
these characteristics match those of the input to the block.
When you select Same as product output
,
these characteristics match those of the product output.
When you select Binary point scaling
,
you are able to enter the word length and the fraction length of the
accumulator, in bits.
When you select Slope and bias scaling
,
you are able to enter the word length, in bits, and the slope of the
accumulator. This block requires poweroftwo slope and a bias of
zero.
Choose how you specify the output word length and fraction length:
When you select Same as input
,
these characteristics match those of the input to the block.
When you select Same as accumulator
,
these characteristics match those of the accumulator.
When you select Binary point scaling
,
you are able to enter the word length and the fraction length of the
output, in bits.
When you select Slope and bias scaling
,
you are able to enter the word length, in bits, and the slope of the
output. This block requires poweroftwo slope and a bias of zero.
Select this check box to prevent any fixedpoint scaling you specify in the block mask from being overridden by the autoscaling tool in the FixedPoint Tool.
Port  Supported Data Types 

In 

Out 

If Pulse length is 4
and Pulse
delay is the scalar 3
, then the table
below shows how the block treats the beginning of a ramp (1
, 2
, 3
,...)
in several situations. (The values shown in the table do not reflect
vector sizes but merely indicate numerical values.)
Normalization Method, If Any  Linear Amplitude Gain  First Several Output Values 

None (Normalize output signal cleared)  1  0 , 0 , 0 , 1 , 1 , 1 , 1 , 2 , 2 , 2 , 2 , 3 , 3 , 3 , 3 ,... 
None (Normalize output signal cleared)  10  0 , 0 , 0 , 10 , 10 , 10 , 10 , 20 , 20 , 20 , 20 , 30 , 30 , 30 , 30 ,... 
Sum of samples  1  0 , 0 , 0 , 0.25 , 0.25 , 0.25 , 0.25 , 0.5 , 0.5 , 0.5 , 0.5 , 0.75 , 0.75 , 0.75 , 0.75 ,...,
where 0.25*4=1 
Sum of samples  10  0 , 0 , 0 , 2.5 , 2.5 , 2.5 , 2.5 , 5 , 5 , 5 , 5 , 7.5 , 7.5 , 7.5 , 7.5 ,
... 
Energy per pulse  1  0 , 0 , 0 , 0.5 , 0.5 , 0.5 , 0.5 , 1.0 , 1.0 , 1.0 , 1.0 , 1.5 , 1.5 , 1.5 , 1.5 ,...,
where (0.5)^2*4=1^2 
Energy per pulse  10  0 , 0 , 0 , 5 , 5 , 5 , 5 , 10 , 10 , 10 , 10 , 15 , 15 , 15 , 15 ,... 