RosettaCodeData/Task/Deconvolution-1D/PascalABC.NET/deconvolution-1d.pas

27 lines
670 B
ObjectPascal

##
function deconv(g, f: array of real): array of real;
begin
var h: array of real;
setlength(h, g.length - f.length + 1);
for var n := 0 to h.length - 1 do
begin
h[n] := g[n];
var lower: integer;
if n >= f.length then
lower := n - f.length + 1;
for var i := lower to n - 1 do
h[n] -= h[i] * f[n - i];
h[n] /= f[0];
end;
result := h;
end;
var h := |-8.0, -9, -3, -1, -6, 7|;
var f := |-3.0, -6, -1, 8, -6, 3, -1, -9, -9, 3, -2, 5, 2, -2, -7, -1|;
var g := |24.0, 75, 71, -34, 3, 22, -45, 23, 245, 25, 52, 25, -67, -96,
96, 31, 55, 36, 29, -43, -7|;
h.Println;
deconv(g, f).Println;
f.Println;
deconv(g, h).Println;