-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathtest5.py
74 lines (55 loc) · 1.45 KB
/
test5.py
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
import math
import numpy as np
import sys
matrix = np.array([
[0, 1, 1, 2, 3],
[0, 0, 2, 3, 3],
[0, 1, 2, 2, 3],
[1, 2, 3, 2, 2],
[2, 2, 3, 3, 2]], dtype=np.float32)
P = np.array([
[2.5, 2.0, 0.75, 0],
[2.0, 1.0, 2.25, 0.5],
[0.75, 2.25, 7, 5.25],
[0, 0.5, 5.25, 4]], dtype=np.float32)
#print matkok[3, 3]
EN = 0
Px = 0
Py = 0
MeanX = 0
MeanY = 0
StdevX = 0
StdevY = 0
for j in range(4):
Px += P[0, j]
for i in range(4):
Py += P[i, 0]
for i in range(4):
for j in range(4):
MeanX += i * P[i, j]
for j in range(4):
for i in range(4):
MeanY += j * P[i, j]
Mean = np.average(P)
for i in range(4):
for j in range(4):
StdevX += math.pow((i - (i * P[i, j])), 2)
for j in range(4):
StdevX += P[0, j]
for i in range(4):
for j in range(4):
StdevY += math.pow((j - (j * P[i, j])), 2)
for i in range(4):
StdevY += P[i, 0]
StdevX = math.sqrt(StdevX)
StdevY = math.sqrt(StdevY)
# Contras: (((i * j) * P[i, j]) - (MeanX * MeanY)) / (StdevX * StdevY)
# IDM: (1 / (1 + math.pow((i - j), 2))) * P[i, j]
# ENT: P[i, j] * math.log(P[i, j] + sys.float_info.epsilon, 2)
for i in range(4):
for j in range(4):
temp = math.pow((i - Mean), 2) * P[i, j]
EN += temp
#print EN
print "Px: {0} | Py: {1} | MeanX: {2} | MeanY: {3} | EN: {4}".format(Px, Py, MeanX, MeanY, EN)
print "StedvX: {0} | StedvY: {1}".format(StdevX, StdevY)