-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMInfo.cpp
More file actions
100 lines (70 loc) · 1.72 KB
/
MInfo.cpp
File metadata and controls
100 lines (70 loc) · 1.72 KB
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
#include<iostream>
#include<vector>
#include<sstream>
#include<fstream>
#include<cmath>
#include"func.h"
using namespace std;
double MInfo(double* joint,int gridsize){
ifstream infile;
int i,l,j,k;
double Info=0;
//ifstream infile("/home/diana/workspace/Analysis/R_projects/pdf12_QL435_ALL.dat");
//double joint[gridsize][gridsize];
double margX[gridsize];
double margY[gridsize];
for(j=0;j<gridsize;j++){
margX[j]=0;
margY[j]=0;
}
for(j=0;j<gridsize;j++){
for(k=0;k<gridsize;k++){
//infile>>joint[j][k];
margX[j]+=joint[j*gridsize+k];
margY[k]+=joint[j*gridsize+k];
}
}
for(j=0;j<gridsize;j++){
for(k=0;k<gridsize;k++){
if(joint[j*gridsize+k]!=0) Info+=joint[j*gridsize+k]*log(joint[j*gridsize+k]/(margX[j]*margY[k]))/log(2.);
}
}
return Info;
}
double MInfo2(double* cond,double* input, int gridsize,int Nin){
int i,l,j,k;
double Info=0;
double marg[gridsize];
for(j=0;j<gridsize;j++){
marg[j]=0;
}
for(j=0;j<gridsize;j++){
for(k=0;k<Nin;k++){
if(cond[k*gridsize+j]>0) marg[j]+=input[k]*cond[k*gridsize+j];
}
}
for(j=0;j<gridsize;j++){
for(k=0;k<Nin;k++){
if(cond[k*gridsize+j]>0) Info+=input[k]*cond[k*gridsize+j]*log(cond[k*gridsize+j]/marg[j])/log(2.);
}
}
return Info;
}
void MInfo_vec(double* cond,double* input, int gridsize,int Nin,double* infovec){
int i,l,j,k;
double marg[gridsize];
for(j=0;j<gridsize;j++){
marg[j]=0;
}
for(i=0;i<Nin;i++) infovec[i]=0;
for(j=0;j<gridsize;j++){
for(k=0;k<Nin;k++){
if(cond[k*gridsize+j]>0) marg[j]+=input[k]*cond[k*gridsize+j];
}
}
for(j=0;j<gridsize;j++){
for(k=0;k<Nin;k++){
if(cond[k*gridsize+j]>0) infovec[k]+=/*input[k]**/cond[k*gridsize+j]*log(cond[k*gridsize+j]/marg[j])/log(2.);
}
}
}