annotate src/samer/units/RescaledIFT.java @ 8:5e3cbbf173aa tip

Reorganise some more
author samer
date Fri, 05 Apr 2019 22:41:58 +0100
parents bf79fb79ee13
children
rev   line source
samer@0 1 /*
samer@0 2 * Copyright (c) 2000, Samer Abdallah, King's College London.
samer@0 3 * All rights reserved.
samer@0 4 *
samer@0 5 * This software is provided AS iS and WITHOUT ANY WARRANTY;
samer@0 6 * without even the implied warranty of MERCHANTABILITY or
samer@0 7 * FITNESS FOR A PARTICULAR PURPOSE.
samer@0 8 */
samer@0 9
samer@0 10 package samer.units;
samer@0 11
samer@0 12 import samer.core.*;
samer@0 13 import samer.maths.*;
samer@0 14 import samer.tools.*;
samer@0 15 import samer.functions.*;
samer@0 16
samer@0 17 /**
samer@0 18 Inverts a given FFT using an alternative magnitude spectrum
samer@0 19 */
samer@0 20
samer@0 21 public class RescaledIFT extends FFT implements Task
samer@0 22 {
samer@0 23 Vec mag;
samer@0 24 FFT ft;
samer@0 25 double k[];
samer@0 26 VVector out;
samer@0 27
samer@0 28 public RescaledIFT(FFT ft, Vec mag) throws Exception
samer@0 29 {
samer@0 30 super(ft.size());
samer@0 31 this.ft=ft;
samer@0 32 this.mag=mag;
samer@0 33 k=new double[N];
samer@0 34 invert();
samer@0 35 out=new VVector("ift.output", real);
samer@0 36 }
samer@0 37
samer@0 38 public VVector output() { return out; }
samer@0 39
samer@0 40 public void dispose() {}
samer@0 41 public void starting() {}
samer@0 42 public void stopping() {}
samer@0 43 public void run() {
samer@0 44 Vec.Iterator mit=mag.iterator();
samer@0 45 int i, j;
samer@0 46
samer@0 47 for (i=0, j=N-1; mit.more(); i++, j--)
samer@0 48 k[j]=k[i]=mit.next()/abs(ft.real[i],ft.imag[i]);
samer@0 49 for (; i<=N/2; i++, j--) k[i]=k[j]=0;
samer@0 50
samer@0 51 for (i=0; i<N; i++) {
samer@0 52 j=bitrev[i];
samer@0 53 real[j] = k[i]*ft.real[i];
samer@0 54 imag[j] = k[i]*ft.imag[i];
samer@0 55 }
samer@0 56 calculate();
samer@0 57 out.changed();
samer@0 58 }
samer@0 59
samer@0 60 private static double abs(double x,double y) { return Math.sqrt(x*x+y*y); }
samer@0 61 }
samer@0 62