SampleType » History » Version 28
Chris Cannam, 2014-02-10 02:59 PM
1 | 1 | Chris Cannam | h1. Output Sample Type and Sample Rate |
---|---|---|---|
2 | 1 | Chris Cannam | |
3 | 15 | Chris Cannam | {{>toc}} |
4 | 15 | Chris Cannam | |
5 | 12 | Chris Cannam | A Vamp plugin receives audio and produces a series of descriptive feature structures. |
6 | 1 | Chris Cannam | |
7 | 12 | Chris Cannam | The audio input is provided as a series of fixed-length sample blocks, equally spaced in time, provided to successive calls to the plugin's @process@ function. The plugin may return any number of features from each @process@ call, and may also return any number of features from @getRemainingFeatures@ after all the audio has been received. |
8 | 11 | Chris Cannam | |
9 | 11 | Chris Cannam | Features are each associated with a particular output of the plugin. The plugin declares that each output has certain properties, which constrain the sort of feature data the host can expect to see. (See diagram.) |
10 | 10 | Chris Cannam | |
11 | 7 | Chris Cannam | !/attachments/download/980/feature-structures-20pc.png! |
12 | 9 | Chris Cannam | |
13 | 22 | Chris Cannam | A feature may or may not have a timestamp (as well as, optionally, a duration). Whether a timestamp is needed -- and, if it is provided, what it means -- are determined by the @sampleType@ and @sampleRate@ properties of the output on which the feature is returned. |
14 | 7 | Chris Cannam | |
15 | 27 | Chris Cannam | An output's @sampleType@ property may be either @OneSamplePerStep@, @FixedSampleRate@, or @VariableSampleRate@. Here's what they mean. |
16 | 1 | Chris Cannam | |
17 | 27 | Chris Cannam | h2. OneSamplePerStep |
18 | 1 | Chris Cannam | |
19 | 23 | Chris Cannam | This is the simplest option. |
20 | 1 | Chris Cannam | |
21 | 23 | Chris Cannam | If an output is declared as having a @sampleType@ of @OneSamplePerStep@, then any features returned from a @process@ call are assumed to match up with the audio block provided to that @process@ call. |
22 | 23 | Chris Cannam | |
23 | 14 | Chris Cannam | The @sampleRate@ and @hasDuration@ output properties are ignored for outputs of this type. |
24 | 1 | Chris Cannam | |
25 | 14 | Chris Cannam | For any features returned through an output declared with @OneSamplePerStep@ type, |
26 | 14 | Chris Cannam | |
27 | 24 | Chris Cannam | * The plugin _should not_ set timestamps on these features and _should_ set their @hasTimestamp@ property to @false@; |
28 | 1 | Chris Cannam | * The plugin _should not_ set durations on these features and _should_ set their @hasDuration@ property to @false@; |
29 | 24 | Chris Cannam | * If the plugin does set either timestamps or durations, the host _must_ ignore them; |
30 | 24 | Chris Cannam | * The host _must_ treat all such features returned from a given @process@ call as if they had the same timestamp as it passed to that @process@ call; |
31 | 1 | Chris Cannam | * The host _must_ treat all such features returned from @getRemainingFeatures@ as if they were immediately following the final @process@ block (i.e. with the same time as the next equally-spaced @process@ block would have had if the input had not ended); |
32 | 22 | Chris Cannam | * The host _must_ treat all such features has having duration equal to the spacing between process blocks. |
33 | 1 | Chris Cannam | |
34 | 27 | Chris Cannam | h3. Examples |
35 | 14 | Chris Cannam | |
36 | 14 | Chris Cannam | @OneSamplePerStep@ is most often used for simple measurements and visualisations, in which some internal calculation is updated on each process call and a new result returned. For example: envelope trackers; power calculations; spectrograms. These outputs are typically visualised using line graphs or colour matrix plots. |
37 | 14 | Chris Cannam | |
38 | 1 | Chris Cannam | @OneSamplePerStep@ is often used for intermediate results calculated during processing of a more sophisticated feature. For example, a beat tracker might have an auxiliary output with @OneSamplePerStep@ type returning its internal onset detection function value. |
39 | 14 | Chris Cannam | |
40 | 27 | Chris Cannam | h2. VariableSampleRate |
41 | 20 | Chris Cannam | |
42 | 21 | Chris Cannam | If the @OneSamplePerStep@ output type essentially means that the plugin leaves all time calculations up to the host, @VariableSampleRate@ is the opposite. |
43 | 22 | Chris Cannam | |
44 | 1 | Chris Cannam | If an output is declared as having a @SampleType@ of @VariableSampleRate@, the features returned through it will have timestamps set by the plugin, and they won't necessarily have any relationship to the process block timestamps provided by the host. |
45 | 1 | Chris Cannam | |
46 | 27 | Chris Cannam | h3. Timestamps |
47 | 25 | Chris Cannam | |
48 | 1 | Chris Cannam | For any features returned through an output declared with @VariableSampleRate@ type, |
49 | 24 | Chris Cannam | |
50 | 24 | Chris Cannam | * The plugin _must_ set timestamps on these features and _must_ set their @hasTimestamp@ property to @true@; |
51 | 28 | Chris Cannam | * The host _must_ obtain the features' start times from their timestamps rather than calculating them itself. |
52 | 25 | Chris Cannam | |
53 | 27 | Chris Cannam | h3. Durations |
54 | 25 | Chris Cannam | |
55 | 1 | Chris Cannam | Features returned through @VariableSampleRate@ outputs may optionally have durations. |
56 | 25 | Chris Cannam | |
57 | 26 | Chris Cannam | If the output's @hasDuration@ property is @true@, then |
58 | 26 | Chris Cannam | |
59 | 28 | Chris Cannam | * The plugin _may_ set the @hasDuration@ property of such features to @true@ and, if it does so, _must_ also set their @duration@ property; |
60 | 28 | Chris Cannam | * If a feature's @hasDuration@ property is true, then the host _must_ use the feature's @duration@ property as the feature duration; otherwise the host _must_ treat the feature as having "minimal" duration (see "Sample Rate" below). |
61 | 1 | Chris Cannam | |
62 | 28 | Chris Cannam | If the output's @hasDuration@ property is @false@, then |
63 | 1 | Chris Cannam | |
64 | 28 | Chris Cannam | * The plugin _should not_ set the @duration@ property of that output's features; |
65 | 28 | Chris Cannam | * The host _must_ ignore the @hasDuration@ and @duration@ properties of the features and treat them as having "minimal" duration (see below). |
66 | 28 | Chris Cannam | |
67 | 28 | Chris Cannam | h3. Sample rate and "minimal" duration |
68 | 28 | Chris Cannam | |
69 | 28 | Chris Cannam | The plugin may optionally set a @sampleRate@ property for each @VariableSampleRate@ output. A @sampleRate@ of zero indicates no value. |
70 | 28 | Chris Cannam | |
71 | 28 | Chris Cannam | If a @sampleRate@ is set, |
72 | 28 | Chris Cannam | |
73 | 28 | Chris Cannam | * The host _may_ optionally use the 1/@sampleRate@ seconds as indicating the resolution of the output feature timestamps, and _may_ round each output feature timestamp to a multiple of that resolution; |
74 | 28 | Chris Cannam | * The host _must_ use 1/@sampleRate@ seconds as the "minimal" duration assigned to features that have no duration supplied. |
75 | 28 | Chris Cannam | |
76 | 28 | Chris Cannam | If no @sampleRate@ is set, |
77 | 28 | Chris Cannam | |
78 | 28 | Chris Cannam | * The host _must_ use the feature timestamps unmodified; |
79 | 28 | Chris Cannam | * The host must use zero as the "minimal" duration used for features with no duration supplied. |
80 | 22 | Chris Cannam | |
81 | 27 | Chris Cannam | h3. Examples |
82 | 1 | Chris Cannam | |
83 | 27 | Chris Cannam | h2. FixedSampleRate |
84 | 22 | Chris Cannam | |
85 | 22 | Chris Cannam | If an output is declared as having a @SampleType@ of @FixedSampleRate@ |
86 | 22 | Chris Cannam | |
87 | 27 | Chris Cannam | h3. Examples |