2023-05-16 21:28:16 +02:00
|
|
|
function Node_FFT(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
|
|
|
name = "FFT";
|
|
|
|
previewable = false;
|
|
|
|
|
|
|
|
w = 96;
|
2023-05-22 20:31:55 +02:00
|
|
|
h = 72;
|
2023-05-16 21:28:16 +02:00
|
|
|
min_h = h;
|
|
|
|
|
|
|
|
inputs[| 0] = nodeValue("Data", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, [])
|
|
|
|
.setArrayDepth(1)
|
|
|
|
.setVisible(true, true);
|
|
|
|
|
|
|
|
outputs[| 0] = nodeValue("Array", self, JUNCTION_CONNECT.output, VALUE_TYPE.float, [])
|
|
|
|
.setArrayDepth(1);
|
|
|
|
|
|
|
|
static process_data = function(_outSurf, _data, _output_index, _array_index) {
|
|
|
|
var _dat = _data[0];
|
|
|
|
var _cmp = [];
|
|
|
|
|
|
|
|
for( var i = 0; i < array_length(_dat); i++ )
|
|
|
|
_cmp[i] = new Complex(_dat[i]);
|
|
|
|
|
|
|
|
var _res = FFT(_cmp);
|
|
|
|
var _r = [];
|
|
|
|
|
|
|
|
for( var i = 0; i < array_length(_res); i++ )
|
2023-05-22 20:31:55 +02:00
|
|
|
_r[i] = sqrt(sqr(_res[i].re) + sqr(_res[i].im));
|
2023-05-16 21:28:16 +02:00
|
|
|
|
|
|
|
return _r;
|
|
|
|
}
|
|
|
|
|
|
|
|
static onDrawNode = function(xx, yy, _mx, _my, _s, _hover, _focus) {
|
|
|
|
var bbox = drawGetBbox(xx, yy, _s);
|
2023-05-22 20:31:55 +02:00
|
|
|
draw_sprite_fit(s_node_FFT, 0, bbox.xc, bbox.yc, bbox.w, bbox.h);
|
2023-05-16 21:28:16 +02:00
|
|
|
}
|
|
|
|
}
|