SampleRate
Overview
Measures the sample rate of the input signal
Discussion
Sample rate measurement module. The module is designed measure the sample rate of the signal on single channel. Seperate modules are required to measure the sample rate on different channels. The module compares the measured sample rate with the allowable sample rates and estimates the nearest value. The measured sample rate will be displayed on the inspector.
The module can also compute the sample rate averaged over multiple blocks. .numBlocksToAverage specifies how many blocks to use for the averaging.
The module also optionally outputs the measured sample rate on an output pin. This option is selected by setting the argument SROUTPIN to true. The sample rate value is output an an integer.
Type Definition
typedef struct _ModuleSampleRate
{
ModuleInstanceDescriptor instance; // Common Audio Weaver module instance structure
FLOAT32 procSpeed; // Processor clock speed in MHz
INT32 numBlocksToAverage; // Number of blocks to process before the sample rate is retured
INT32 lastCount; // Holds the last call cycle count
INT32 averageDeltaCount; // Holds the average delta count of numBlocksToAverage calls
INT32 SRArrayLength; // Number of sample rates that can be estimated
INT32 initialized; // Specifies whether the last cycle counter has been initialized
INT32 dataValid; // Indicates whether the sample rate measurement is valid
FLOAT32 measuredSR; // Readback variable. Displays the measured sample rate on the inspector
FLOAT32 prevMeasuredSR; // Last measured sample rate
FLOAT32 prevPrevMeasuredSR; // Previous to last measured sample rate
INT32 SROutPin; // Boolean specifies whether module will have output pin
INT32 blockCounter; // Counts up to numBlocksToAverage
FLOAT32* allowableSR; // Array of possible sample rates
} ModuleSampleRateClass;
Variables
Properties
Name | Type | Usage | isHidden | Default value | Range | Units |
procSpeed | float | parameter | 0 | 10 | Unrestricted | |
numBlocksToAverage | int | parameter | 0 | 100 | 1:16384 | |
lastCount | int | state | 0 | 0 | Unrestricted | |
averageDeltaCount | int | state | 0 | 0 | Unrestricted | |
SRArrayLength | int | const | 0 | 3 | Unrestricted | |
initialized | int | state | 0 | 0 | Unrestricted | |
dataValid | int | state | 0 | 0 | 0:1 | |
measuredSR | float | state | 0 | 48000 | Unrestricted | |
prevMeasuredSR | float | state | 0 | 0 | Unrestricted | |
prevPrevMeasuredSR | float | state | 0 | 0 | Unrestricted | |
SROutPin | int | const | 0 | 1 | Unrestricted | |
blockCounter | int | state | 0 | 0 | Unrestricted | |
allowableSR | float* | parameter | 0 | [3 x 1] | Unrestricted |
Pins
Input Pins
Name: in
Description: Input data pin
Data type: {int, float, fract32}
Channel range: Unrestricted
Block size range: Unrestricted
Sample rate range: Unrestricted
Complex support: Real
Output Pins
Name: out
Description: Measured sample rate
Data type: int
MATLAB Usage
File Name: measure_sample_rate_module.m
M=measure_sample_rate_module(NAME, SRARRAYLEN, SROUTPIN)
Creates a sample rate measure module for use with the Audio
Weaver. Arguments:
NAME - name of the module.
SRARRAYLEN - Array length of the allowable sample rates
SROUTPIN - Boolean which specifies whether module outputs detected
sample rate that can be used as the input to sample rate
switch module