Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

Version 1 Current »

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

  • No labels