-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathCopulaFunctions.R
60 lines (41 loc) · 1.65 KB
/
CopulaFunctions.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
#-----------------------------------------------------------------------------------------------------------------------
# THIS CODE CONTAINS STATISTICS FOR LOOKING AT TAIL DEPENDENCE (using non-parametric statistics)
#-----------------------------------------------------------------------------------------------------------------------
source("CopulaFunctions_flexible.R")
#--------------------------- correlation based Stat ---------------------------------------------------------
CorlCoru<-function(vi,vj){
Corl<-Corbds(vi,vj,0,0.5)
Coru<-Corbds(vi,vj,0.5,1)
return(c(Corl,Coru))
}
#----------------- Stat based on counting points for a given distance from the diagonal in lower and upper triangle -------------
PlPu<-function(vi,vj){
ind_ll<-which(vi+vj<1)
ind_ur<-which(vi+vj>1)
if(length(ind_ll)!=0 & length(ind_ur)!=0){
res_l<-Pbds(vi,vj,0,0.5)
Pl<-res_l$abs_res
dist_Sl_P<-res_l$dist_S
Sl_P<-res_l$S
dist_Si_P<-res_l$dist_Si
Si_P<-res_l$Si
res_u<-Pbds(vi,vj,0.5,1)
Pu<-res_u$abs_res
dist_Su_P<-res_u$dist_S
Su_P<-res_u$S
Sl_Su_Si_P<-list(dist_Sl_P=dist_Sl_P,Sl_P=Sl_P,dist_Su_P=dist_Su_P,Su_P=Su_P,dist_Si_P=dist_Si_P,Si_P=Si_P)
}else{
Sl_Su_Si_P<-list(dist_Sl_P=NA,Sl_P=NA,dist_Su_P=NA,Su_P=NA,dist_Si_P=NA,Si_P=NA)
Pl<-NA
Pu<-NA
}
return(list(Sl_Su_Si_P,Pl,Pu))
}
#-------------------------------- stat based on distance from the diagonal ---------------------------------------
D2lD2u<-function(vi,vj)
{
D2l<-D2bds(vi,vj,0,0.5)
D2u<-D2bds(vi,vj,0.5,1)
return(c(D2l,D2u))
}
#----------------------------------------------------------------------