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

Counter module with optional wrap around

Discussion

This module counts up starting from 0 at a specified rate in milliseconds. The count value is output as an integer value on the output pin. The module has an input pin whose only purpose is to get the current sample rate and blockSize. This information is used to determine the time base for the processing. The sample rate of the output pin equals the sample rate of the input divided by the input block size.

The module determine time by counting input samples. The hidden variable .sampleCounterPeriod equals the number of samples which most closely approximates .incTime.

The module variable .wrap can be used to implement circular wrapping. If .wrap = 0, then no wrapping is performed. If .wrap = N, then the module counts up to N-1 and then wraps to 0.

The internal module counter is initialized to 0 and the module outputs the sequence 0, 1, 2, ..., N-1, 0, 1, 2, ..., N-1, 0, etc.

When muted the module outputs all zeros. When bypassed the module continues to run.

Type Definition

typedef struct _ModuleCounter
{
    ModuleInstanceDescriptor instance;            // Common Audio Weaver module instance structure
    FLOAT32 incTime;                              // Time in msec to wait between increments
    UINT32 wrap;                                  // Counting is performed modulo this value
    UINT32 count;                                 // Current counter value
    UINT32 sampleCounter;                         // Internal variable used to maintain time
    UINT32 sampleCounterPeriod;                   // Number of samples corresponding to incTime
} ModuleCounterClass;

Variables

Properties

Name

Type

Usage

isHidden

Default value

Range

Units

incTime

float

parameter

0

1000

0:10000

msec

wrap

uint

parameter

0

5

Unrestricted

count

uint

state

0

0

Unrestricted

sampleCounter

uint

state

1

0

Unrestricted

sampleCounterPeriod

uint

state

1

48000

Unrestricted

Pins

Input Pins

Name: in

Description: Ignored input

Data type: {float, int, fract32}

Channel range: Unrestricted

Block size range: Unrestricted

Sample rate range: Unrestricted

Complex support: Real

Output Pins

Name: count

Description: Count value

Data type: int

MATLAB Usage

File Name: counter_module.m

 M = counter_module(NAME)
 Audio Weaver module which counts up, and wraps around, at a specified
 rate.  The count value is output on a pin.  Arguments:
    NAME - name of the module

  • No labels