1 | !include once #1018630 // Spectro Edit |
2 | |
3 | static Clip frequencyImageToAudio(BWImage img, IF1<Double> uncolorizer default lambda1 id) ctex {
|
4 | int w = img.getWidth(), h = img.getHeight(); |
5 | // clip.getFrameFreqSamples()? |
6 | int h2 = min(h, audio_frequencyImageHeight()); |
7 | BWImage img = new(w, h2); |
8 | |
9 | Rectangle region = new(0, 0, w, h); |
10 | //toClipCoords(region, clip); |
11 | region.y = clip.getFrameFreqSamples() - (region.y + region.height); |
12 | //print(+region); |
13 | |
14 | int endCol = region.x + region.width; |
15 | int endRow = min(region.y + region.height, h2); |
16 | |
17 | for (int col = region.x; col < endCol; col++) {
|
18 | net.bluecow.spectro.Frame f = clip.getFrame(col); |
19 | for (int row = region.y; row < endRow; row++) |
20 | img.setPixel(col, h2-1-row, toFloat(colorizer.get(f.getReal(row)))); |
21 | } |
22 | |
23 | double[] timeData = new double[data.length]; |
24 | System.arraycopy(data, 0, timeData, 0, data.length); |
25 | DoubleDCT_1D dct = getDctInstance(data.length); |
26 | dct.inverse(timeData, true); |
27 | windowFunc.applyWindow(timeData); |
28 | ret timeData; |
29 | |
30 | ret img; |
31 | } |
Began life as a copy of #1018632
download show line numbers debug dex old transpilations
Travelled to 4 computer(s): bhatertpkbcr, mowyntqkapby, mqqgnosmbjvj, pyentgdyhuwx
No comments. add comment
| Snippet ID: | #1032434 |
| Snippet name: | frequencyImageToAudio [dev.] |
| Eternal ID of this version: | #1032434/1 |
| Text MD5: | aba8af11caaed4525e40a626cc60d06c |
| Author: | stefan |
| Category: | javax / audio analysis + synthesis |
| Type: | JavaX fragment (include) |
| Public (visible to everyone): | Yes |
| Archived (hidden from active list): | No |
| Created/modified: | 2021-09-05 04:35:13 |
| Source code size: | 1087 bytes / 31 lines |
| Pitched / IR pitched: | No / No |
| Views / Downloads: | 427 / 442 |
| Referenced in: | [show references] |