コード例 #1
0
 def test_statistical_different_windows(self):
     n_trials = 1000
     n_points = 200
     window1 = sp.ones(n_points, dtype=float)
     window1 += sp.sin(sp.arange(n_points) / 10.0)
     window2 = 2 * sp.ones(n_points, dtype=float)
     window2 += 2 * sp.sin(sp.arange(n_points) / 22.0)
     window2[window2 < 0.5] = 0
     window1[window1 < 0.5] = 0
     power = sp.zeros(n_points // 2)
     for ii in range(n_trials):
         wave = self.amp1 * random.randn(n_points)
         p = npow.windowed_power(wave * window1, window1, wave * window2,
                                 window2)
         power += npow.prune_power(p).real
     power /= n_trials
     self.assertTrue(
         sp.allclose(power / self.amp1**2,
                     1.0,
                     atol=6.0 * (2.0 / sp.sqrt(n_trials))))
     # Expect this to fail ~1/100 times.
     self.assertFalse(
         sp.allclose(power / self.amp1**2,
                     1.0,
                     atol=0.01 * (2.0 / sp.sqrt(n_trials))))
コード例 #2
0
 def test_window_with_zeros(self) :
     window = sp.ones_like(self.wave1)
     window += sp.sin(sp.arange(self.n)/50.0)
     self.wave1 *= window
     power = np.windowed_power(self.wave1, window)
     self.assertAlmostEqual(power[self.mode1]/self.amp1**2/self.n*4, 1.0, 3)
     self.assertTrue(sp.allclose(power[:self.mode1], 0, 
                                 atol=self.amp1**2*self.n/1e3))
     self.assertTrue(sp.allclose(power[self.mode1+1:], 0, 
                                 atol=self.amp1**2*self.n/1e3))
コード例 #3
0
 def test_non_zero_window(self) :
     window = sp.ones_like(self.wave1)
     window += 0.5*sp.sin(sp.arange(self.n)/15.0)
     self.wave1 *= window
     power = npow.windowed_power(self.wave1, window)
     power = npow.prune_power(power)
     self.assertAlmostEqual(power[self.mode1]/self.amp1**2/self.n*4, 1.0, 3)
     self.assertTrue(sp.allclose(power[:self.mode1], 0, 
                                 atol=self.amp1**2*self.n/1e3))
     self.assertTrue(sp.allclose(power[self.mode1+1:], 0, 
                                 atol=self.amp1**2*self.n/1e3))
コード例 #4
0
 def test_no_window(self) :
     window = sp.ones_like(self.wave1)
     power = np.windowed_power(self.wave1, window)
     self.assertAlmostEqual(power[self.mode1]/self.amp1**2/self.n*4, 1)
     self.assertTrue(sp.allclose(power[:self.mode1], 0, 
                                 atol=self.amp1**2*self.n/1e15))
     self.assertTrue(sp.allclose(power[self.mode1+1:], 0, 
                                 atol=self.amp1**2*self.n/1e15))
     # With no window, we have a quick way to the answer
     quick_power = (abs(fft.fft(self.wave1))**2)[:self.n//2]/self.n
     self.assertTrue(sp.allclose(power, quick_power))
コード例 #5
0
 def test_no_window(self) :
     window = sp.ones_like(self.wave1)
     power = npow.windowed_power(self.wave1, window)
     power = npow.prune_power(power)
     self.assertAlmostEqual(power[self.mode1]/self.amp1**2/self.n*4, 1)
     self.assertTrue(sp.allclose(power[:self.mode1], 0, 
                                 atol=self.amp1**2*self.n/1e15))
     self.assertTrue(sp.allclose(power[self.mode1+1:], 0, 
                                 atol=self.amp1**2*self.n/1e15))
     # With no window, we have a quick way to the answer
     quick_power = npow.calculate_power(self.wave1)
     self.assertTrue(sp.allclose(power, quick_power[:self.n//2]))
コード例 #6
0
 def test_statistical_no_window(self) :
     n_trials = 1000
     n_points = 200
     window = sp.ones(n_points, dtype=float)
     power = sp.zeros(n_points//2)
     for ii in range(n_trials) :
         wave = self.amp1*random.randn(n_points)
         power += np.windowed_power(wave, window)
     power /= n_trials
     self.assertTrue(sp.allclose(power/self.amp1**2, 1.0,
                                 atol=4.0*(2.0/sp.sqrt(n_trials))))
     # Expect this to fail ~1/100 times.
     self.assertFalse(sp.allclose(power/self.amp1**2, 1.0,
                                 atol=0.01*(2.0/sp.sqrt(n_trials))))
コード例 #7
0
 def test_different_windows(self) :
     window1 = sp.ones_like(self.wave1)
     window1 += sp.sin(sp.arange(self.n)/40.0)
     window2 = 2*sp.ones_like(self.wave1)
     window2 += 2*sp.sin(sp.arange(self.n)/62.0)
     window2[window2<0.5] = 0
     wave1 = self.wave1*window1
     wave2 = self.wave1*window2
     power = np.windowed_power(wave1, window1, wave2, window2)
     self.assertAlmostEqual(power[self.mode1]/self.amp1**2/self.n*4, 1.0, 3)
     self.assertTrue(sp.allclose(power[:self.mode1], 0, 
                                 atol=self.amp1**2*self.n/1e3))
     self.assertTrue(sp.allclose(power[self.mode1+1:], 0, 
                                 atol=self.amp1**2*self.n/1e3))
コード例 #8
0
 def test_window_with_zeros(self):
     window = sp.ones_like(self.wave1)
     window += sp.sin(sp.arange(self.n) / 50.0)
     self.wave1 *= window
     power = npow.windowed_power(self.wave1, window)
     power = npow.prune_power(power)
     self.assertAlmostEqual(power[self.mode1] / self.amp1**2 / self.n * 4,
                            1.0, 3)
     self.assertTrue(
         sp.allclose(power[:self.mode1],
                     0,
                     atol=self.amp1**2 * self.n / 1e3))
     self.assertTrue(
         sp.allclose(power[self.mode1 + 1:],
                     0,
                     atol=self.amp1**2 * self.n / 1e3))
コード例 #9
0
 def test_no_window(self):
     window = sp.ones_like(self.wave1)
     power = npow.windowed_power(self.wave1, window)
     power = npow.prune_power(power)
     self.assertAlmostEqual(power[self.mode1] / self.amp1**2 / self.n * 4,
                            1)
     self.assertTrue(
         sp.allclose(power[:self.mode1],
                     0,
                     atol=self.amp1**2 * self.n / 1e15))
     self.assertTrue(
         sp.allclose(power[self.mode1 + 1:],
                     0,
                     atol=self.amp1**2 * self.n / 1e15))
     # With no window, we have a quick way to the answer
     quick_power = npow.calculate_power(self.wave1)
     self.assertTrue(sp.allclose(power, quick_power[:self.n // 2]))
コード例 #10
0
 def test_statistical_no_window(self):
     n_trials = 1000
     n_points = 200
     window = sp.ones(n_points, dtype=float)
     power = sp.zeros(n_points // 2)
     for ii in range(n_trials):
         wave = self.amp1 * random.randn(n_points)
         p = npow.windowed_power(wave, window)
         power += npow.prune_power(p).real
     power /= n_trials
     self.assertTrue(
         sp.allclose(power / self.amp1**2,
                     1.0,
                     atol=4.0 * (2.0 / sp.sqrt(n_trials))))
     # Expect this to fail ~1/100 times.
     self.assertFalse(
         sp.allclose(power / self.amp1**2,
                     1.0,
                     atol=0.01 * (2.0 / sp.sqrt(n_trials))))
コード例 #11
0
 def test_different_windows(self):
     window1 = sp.ones_like(self.wave1)
     window1 += sp.sin(sp.arange(self.n) / 40.0)
     window2 = 2 * sp.ones_like(self.wave1)
     window2 += 2 * sp.sin(sp.arange(self.n) / 62.0)
     window2[window2 < 0.5] = 0
     wave1 = self.wave1 * window1
     wave2 = self.wave1 * window2
     power = npow.windowed_power(wave1, window1, wave2, window2)
     power = npow.prune_power(power)
     self.assertAlmostEqual(power[self.mode1] / self.amp1**2 / self.n * 4,
                            1.0, 3)
     self.assertTrue(
         sp.allclose(power[:self.mode1],
                     0,
                     atol=self.amp1**2 * self.n / 1e3))
     self.assertTrue(
         sp.allclose(power[self.mode1 + 1:],
                     0,
                     atol=self.amp1**2 * self.n / 1e3))
コード例 #12
0
 def test_statistical_different_windows(self) :
     n_trials = 1000
     n_points = 200
     window1 = sp.ones(n_points, dtype=float)
     window1 += sp.sin(sp.arange(n_points)/10.0)
     window2 = 2*sp.ones(n_points, dtype=float)
     window2 += 2*sp.sin(sp.arange(n_points)/22.0)
     window2[window2<0.5] = 0
     window1[window1<0.5] = 0
     power = sp.zeros(n_points//2)
     for ii in range(n_trials) :
         wave = self.amp1*random.randn(n_points)
         power += np.windowed_power(wave*window1, window1, wave*window2,
                                    window2)
     power /= n_trials
     self.assertTrue(sp.allclose(power/self.amp1**2, 1.0,
                                 atol=6.0*(2.0/sp.sqrt(n_trials))))
     # Expect this to fail ~1/100 times.
     self.assertFalse(sp.allclose(power/self.amp1**2, 1.0,
                                 atol=0.01*(2.0/sp.sqrt(n_trials))))