Mercurial > hg > jslab
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 |