/
BlockMedian

BlockMedian

Overview

N-Channel Block median

Discussion

Computes the median ("middle value") for each block of data. The median computation is computed on a channel by channel basis. The module supports an arbitrary block size and number of channels. The output has a block size of 1 and the number of channels matches the number of channels of the input.

Internally, the module uses a scratch buffer and sorts each block of data. It then picks the "middle" value as the median. Let N represent the block size of the input pin. If N is odd, then the median is the sample at index [(N - 1) / 2] (assuming zero indexing). If N is even, then the median is at sample index [N/2 - 1].

Type Definition

typedef struct _ModuleBlockMedian { ModuleInstanceDescriptor instance; // Common Audio Weaver module instance structure } ModuleBlockMedianClass;

Pins

Input Pins

Name: in

Description: Input signal

Data type: float

Channel range: Unrestricted

Block size range: Unrestricted

Sample rate range: Unrestricted

Complex support: Real

Output Pins

Name: out

Description: Output signal

Data type: float

Scratch Pins

Channel count: 1

Block size: 32

Sample rate: 48000

MATLAB Usage

File Name: block_median_module.m

M = block_median_module(NAME) Computes the median value of a block of data. Can be configured for block mode or streaming mode. Arguments: NAME - name of the module.