File: vq_test.py

package info (click to toggle)
python-scipy 0.3.2-6
  • links: PTS
  • area: main
  • in suites: sarge
  • size: 13,572 kB
  • ctags: 20,326
  • sloc: ansic: 87,138; fortran: 51,876; python: 47,747; cpp: 2,134; objc: 384; makefile: 175; sh: 83
file content (47 lines) | stat: -rwxr-xr-x 1,337 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
47
from Numeric import *
from scipy_base.scipy_base.fastumath 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()