-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmcmFunctions.R
60 lines (42 loc) · 1.58 KB
/
mcmFunctions.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
require("matrixcalc")
mcmFit <- function(timeSeries, numBins, numStepAhead=1){
a <- min(timeSeries)
b <- max(timeSeries)
binWidth <- (b-a) / numBins
state <- floor((timeSeries - a) / binWidth) + 1
state[state > numBins] <- numBins # remove any state > numberOfStates
p <- matrix(0, numBins, numBins)
for (i in 2:length(timeSeries)){
p[state[i-1], state[i]] <- p[state[i-1], state[i]] + 1
}
#normalize p
pNormalized <- p / rowSums(p)
pNormalized[is.na(pNormalized)] <- 0.0
pStepped <- matrix.power(pNormalized, numStepAhead)
return(pStepped)
}
mcmForecast <- function(p, a, b, obs) {
stopifnot(a < b) # a should be less than b
stopifnot(diff(dim(p)) == 0) # p should be square matrix
stopifnot(obs >= a) # observation should be larger than the samllest value in the range.
numBins <- dim(p)[1]
binWidth <- (b-a) / numBins
binStartArray <- a + binWidth * (0:(numBins-1))
obsBin <- max(which(obs >= binStartArray))
returnList <- list(binStartingValues = binStartArray,
transitionProbs = p[obsBin,])
return(returnList)
}
mcmRnd <- function(binStartVals, transProbs, numSamples){
binWidth <- diff(binStartVals)[1]
numBins <- length(binStartVals)
empiricalCdf <- cumsum(transProbs)
randWithinBin <- runif(numSamples, min=0, max=binWidth)
randWithinECDF <- runif(numSamples, min=0, max=1.0)
rndValue <- rep(0, numSamples)
for (i in 1:numSamples){
binIndex <- min(which(randWithinECDF[i] <= empiricalCdf))
rndValue[i] <- binStartVals[binIndex] + randWithinBin[i]
}
return(rndValue)
}