Menu

[r540]: / trunk / htdocs / examples / csd_demo.py  Maximize  Restore  History

Download this file

35 lines (27 with data), 754 Bytes

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#!/usr/bin/env python
"""
Compute the cross spectral density of two signals
"""
from __future__ import division
import sys
from matplotlib.matlab import *
dt = 0.01
t = arange(0, 30, dt)
nse1 = randn(len(t)) # white noise 1
nse2 = randn(len(t)) # white noise 2
r = exp(divide(-t,0.05))
cnse1 = convolve(nse1, r, mode=2)*dt # colored noise 1
cnse1 = cnse1[:len(t)]
cnse2 = convolve(nse2, r, mode=2)*dt # colored noise 2
cnse2 = cnse2[:len(t)]
# two signals with a coherent part and a random part
s1 = 0.01*sin(2*pi*10*t) + cnse1
s2 = 0.01*sin(2*pi*10*t) + cnse2
subplot(211)
plot(t, s1, 'b-', t, s2, 'g-')
xlim(0,5)
xlabel('time')
ylabel('s1 and s2')
subplot(212)
cxy, f = csd(s1, s2, 256, 1/dt)
show()
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.