File: vq_test.py

package info (click to toggle)
python-scipy 0.5.2-0.1
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 33,888 kB
  • ctags: 44,231
  • sloc: ansic: 156,256; cpp: 90,347; python: 89,604; fortran: 73,083; sh: 1,318; objc: 424; makefile: 342
file content (46 lines) | stat: -rwxr-xr-x 1,248 bytes parent folder | download
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
from numpy import *
import vq_c as vq

def python_vq(all_data,code_book):
    import time
    t1 = time.time()
    codes1,dist1 = vq.vq(all_data,code_book)
    t2 = time.time()
    print 'fast (double):', t2 - t1
    print '  first codes:', codes1[:5]
    print '  first dist:', dist1[:5]
    print '  last codes:', codes1[-5:]
    print '  last dist:', dist1[-5:]
    float_obs = all_data.astype(Float32)
    float_code = code_book.astype(Float32)
    t1 = time.time()
    codes1,dist1 = vq.vq(float_obs,float_code)
    t2 = time.time()
    print 'fast (float):', t2 - t1
    print '  first codes:', codes1[:5]
    print '  first dist:', dist1[:5]
    print '  last codes:', codes1[-5:]
    print '  last dist:', dist1[-5:]

    return codes1,dist1

def read_data(name):
    f = open(name,'r')
    data = []
    for line in f.readlines():
        data.append(map(float,string.split(line)))
    f.close()
    return array(data)

def main():
    import scipy.stats
    scipy.stats.seed(1000,1000)
    Ncodes = 40
    Nfeatures = 16
    Nobs = 4000
    code_book = RandomArray.normal(0,1,(Ncodes,Nfeatures))
    features = RandomArray.normal(0,1,(Nobs,Nfeatures))
    codes,dist = python_vq(features,code_book)

if __name__ == '__main__':
    main()