Libraryless. Click here for Pure Java version (5980L/34K).
sclass AudioSampleOps { // implementation of gain modifier srecord noeq Gain(double factor, IAudioSample original) implements IAudioSample { public double sampleRate() { ret original.sampleRate(); } public int channels() { ret original.channels(); } public DoubleRange bounds() { ret original.bounds(); } public double sampleSum(int channel, double start, double end) { ret original.sampleSum(channel, start, end)*factor; } // coalesce consecutive gains public IAudioSample gain(double factor) { ret original.gain(this.factor*factor); } } // Implementation of the time-shift modifier. // moves the input <shift> samples to the left (cuts off beginning). // Shift can be fractional - we're in integral image (audio) wonderland after all // where a traditional pixel has no meaning. srecord noeq TimeShift(double shift, IAudioSample original) implements IAudioSample { public double sampleRate() { ret original.sampleRate(); } public int channels() { ret original.channels(); } public DoubleRange bounds() { ret shiftDoubleRange(original.bounds(), -shift); } public double sampleSum(int channel, double start, double end) { ret original.sampleSum(channel, start+shift, end+shift); } // coalesce consecutive time-shifts public IAudioSample timeShift(double shift) { ret original.timeShift(this.shift+shift); } } // Implementation of the speed-up modifier which transforms every frequency f to f*factor. // This is for convenience, you could also just call sampleSum() directly with larger intervals. sclass SpeedUp implements IAudioSample { double factor, invFactor; IAudioSample original; *(double *factor, IAudioSample *original) { if (factor < 1) fail("Can't slow down. " + factor); invFactor = 1/factor; } public double sampleRate() { ret original.sampleRate()*invFactor; } public int channels() { ret original.channels(); } public DoubleRange bounds() { ret scaleDoubleRange(original.bounds(), invFactor); } public double sampleSum(int channel, double start, double end) { ret original.sampleSum(channel, start*factor, end*factor)*invFactor; } // coalesce consecutive speed-ups public IAudioSample speedUp(double factor) { ret original.speedUp(this.factor*factor); } } }
download show line numbers debug dex old transpilations
Travelled to 4 computer(s): bhatertpkbcr, ekrmjmnbrukm, mowyntqkapby, mqqgnosmbjvj
No comments. add comment
Snippet ID: | #1032975 |
Snippet name: | AudioSampleOps |
Eternal ID of this version: | #1032975/2 |
Text MD5: | 155297c21bbe2d864eee8dcdb814f6cf |
Transpilation MD5: | 4ea72373e6f0221933796bd6d40f5ebf |
Author: | stefan |
Category: | javax / stefan's os |
Type: | JavaX fragment (include) |
Public (visible to everyone): | Yes |
Archived (hidden from active list): | No |
Created/modified: | 2021-10-11 07:30:56 |
Source code size: | 2456 bytes / 61 lines |
Pitched / IR pitched: | No / No |
Views / Downloads: | 180 / 355 |
Version history: | 1 change(s) |
Referenced in: | #1034167 - Standard Classes + Interfaces (LIVE, continuation of #1003674) |