-
Notifications
You must be signed in to change notification settings - Fork 97
/
Copy pathpregraphKM.R
66 lines (64 loc) · 1.83 KB
/
pregraphKM.R
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
`pregraphKM` <-
function(matrice)
{
`row.col.number` <- function(mat,number){
nr<-nrow(mat)
nc<-ncol(mat)
mod<-number %% nr
div<-number/nr
##First column
if(mod!=0 & div>1){
nr.f<-mod
nc.f<-trunc(div)+1
}else{
if(div<=1){
nc.f<-1
nr.f<-number
}else{
if(mod==0){
nc.f<-div
nr.f<-nr
}
}
}
list(nr=nr.f,nc=nc.f)
}
## Beginning of the function
for(k in 1:(ncol(matrice)-1)){
i=1
j=1
tmp<-0
while(j <= max(matrice[,k])){
if(i==1){
mat<-table(matrice[,k],matrice[,k+1])
number<-which.max(mat)
tmp<-row.col.number(mat,number)
tmp0<-tmp
## Change les indices
if(tmp$nr!=tmp$nc){
find.nc<-which(matrice[,k+1]==tmp$nc)
find.nr<-which(matrice[,k+1]==tmp$nr)
matrice[find.nc,k+1]<-tmp$nr
matrice[find.nr,k+1]<-tmp$nc
}else{}
i=2
}else{
mat<-table(matrice[,k],matrice[,k+1])
mat[tmp0$nr,]<-0
mat[,tmp0$nr]<-0
number<-which.max(mat)
tmp<-row.col.number(mat,number)
## Change les indices
if(tmp$nr!=tmp$nc){
find.nc<-which(matrice[,k+1]==tmp$nc)
find.nr<-which(matrice[,k+1]==tmp$nr)
matrice[find.nc,k+1]<-tmp$nr
matrice[find.nr,k+1]<-tmp$nc
}else{}
tmp0$nr<-c(tmp0$nr,tmp$nr)
}
j=j+1
}
}
matrice
}