-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcleansixunif.R
163 lines (115 loc) · 5.56 KB
/
cleansixunif.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
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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
cleansixunif = function(input){
# Bifurcated approach for 95.4% Confidence interval of Start posterior phase distribution is split into two parts
rng3 <- input[3]
rng4 <- input[4]
rng5 <- input[5]
rng6 <- input[6]
# Cleaning of the output begins
rngsplit3<-unlist(strsplit(rng3, "\" ", fixed = TRUE))
rngsplit4<-unlist(strsplit(rng4, "\" ", fixed = TRUE))
rngsplit5<-unlist(strsplit(rng5, "\" ", fixed = TRUE))
rngsplit6<-unlist(strsplit(rng6, "\" ", fixed = TRUE))
keeps <- c(".")
rngrange3 <- gsub(paste0(".*?($|'|", paste(paste0("\\",
keeps), collapse = "|"), "|[^[:punct:]]).*?"), "\\1", rngsplit3[2])
rngrange4 <- gsub(paste0(".*?($|'|", paste(paste0("\\",
keeps), collapse = "|"), "|[^[:punct:]]).*?"), "\\1", rngsplit4[2])
rngrange5 <- gsub(paste0(".*?($|'|", paste(paste0("\\",
keeps), collapse = "|"), "|[^[:punct:]]).*?"), "\\1", rngsplit5[2])
rngrange6 <- gsub(paste0(".*?($|'|", paste(paste0("\\",
keeps), collapse = "|"), "|[^[:punct:]]).*?"), "\\1", rngsplit6[2])
rngrangesplit3 <- gsub('BP','',rngrange3)
rngrangesplit4 <- gsub('BP','',rngrange4)
rngrangesplit5 <- gsub('BP','',rngrange5)
rngrangesplit6 <- gsub('BP','',rngrange6)
rngrangesplit32 <- strsplit(gsub(paste0("([[:alnum:]]{", # Apply strsplit function
6,
"})"),
"\\1 ",
rngrangesplit3),
" ")[[1]]
rngrangesplit42 <- strsplit(gsub(paste0("([[:alnum:]]{", # Apply strsplit function
6,
"})"),
"\\1 ",
rngrangesplit4),
" ")[[1]]
rngrangesplit52 <- strsplit(gsub(paste0("([[:alnum:]]{", # Apply strsplit function
6,
"})"),
"\\1 ",
rngrangesplit5),
" ")[[1]]
rngrangesplit62 <- strsplit(gsub(paste0("([[:alnum:]]{", # Apply strsplit function
6,
"})"),
"\\1 ",
rngrangesplit6),
" ")[[1]]
rngrangesplit32_num <- as.numeric(rngrangesplit32)
rngrangesplit32_num_noNA<-rngrangesplit32_num[!is.na(rngrangesplit32_num)]
rngrangesplit42_num <- as.numeric(rngrangesplit42)
rngrangesplit42_num_noNA<-rngrangesplit42_num[!is.na(rngrangesplit42_num)]
rngrangesplit52_num <- as.numeric(rngrangesplit52)
rngrangesplit52_num_noNA<-rngrangesplit52_num[!is.na(rngrangesplit52_num)]
rngrangesplit62_num <- as.numeric(rngrangesplit62)
rngrangesplit62_num_noNA<-rngrangesplit62_num[!is.na(rngrangesplit62_num)]
# Cleaned entires
# Filtering accurate results
time.s32 <- rngrangesplit32_num_noNA[1]
time.e32 <- rngrangesplit32_num_noNA[3]
accuracy <- 0
# Define value
x1 <- 5000
# Define lower bound
left1 <- time.e32
# Define upper bound
right1 <- time.s32
# Apply between function
range32 <- between(x1, left1, right1)
time.s42 <- rngrangesplit42_num_noNA[1]
time.e42 <- rngrangesplit42_num_noNA[3]
# Define value
x2 <- 5000
# Define lower bound
left2 <- time.e42
# Define upper bound
right2 <- time.s42
# Apply between function
range42 <- between(x2, left2, right2)
time.s52 <- rngrangesplit52_num_noNA[1]
time.e52 <- rngrangesplit52_num_noNA[3]
# Define value
x3 <- 5000
# Define lower bound
left3 <- time.e52
# Define upper bound
right3 <- time.s52
# Apply between function
range52 <- between(x2, left3, right3)
time.s62 <- rngrangesplit62_num_noNA[1]
time.e62 <- rngrangesplit62_num_noNA[3]
# Define value
x4 <- 5000
# Define lower bound
left4 <- time.e62
# Define upper bound
right4 <- time.s62
# Apply between function
range62 <- between(x4, left4, right4)
if (range32 == "TRUE" || range42 == "TRUE"|| range52 == "TRUE" || range62 == "TRUE")
{
accuracy <- accuracy + 1
}
margin32 <- time.s32 - time.e32
margin42 <- time.s42 - time.e42
margin52 <- time.s52 - time.e52
margin62 <- time.s62 - time.e62
margin <- + margin62 + margin52 + margin42 + margin32
distancefromstart <- 0
if (accuracy == 0){
distancefromstart <- min(c(abs(5000-rngrangesplit32_num_noNA[1]),abs(5000-rngrangesplit32_num_noNA[3]),abs(5000-rngrangesplit42_num_noNA[1]),abs(5000-rngrangesplit42_num_noNA[3]),abs(5000-rngrangesplit52_num_noNA[1]),abs(5000-rngrangesplit52_num_noNA[3]),abs(5000-rngrangesplit62_num_noNA[1]),abs(5000-rngrangesplit62_num_noNA[3])))
}
new_row <- c(margin, accuracy, distancefromstart)
unif_df[nrow(unif_df) + 1, ] <<- new_row
}