Nothing
get_ArAr_ratio <- function(tt,st=0,J,sJ=0,exterr=FALSE){
L <- lambda("K40")[1]
sL <- lambda("K40")[2]
R <- (exp(L*tt)-1)/J
if (exterr){
J1 <- (1-exp(L*tt))/J^2
J2 <- tt*exp(L*tt)/J
} else {
J1 <- J2 <- 0
}
J3 <- L*exp(L*tt)/J
E11 <- sJ^2
E22 <- sL^2
E33 <- st^2
vR <- errorprop1x3(J1,J2,J3,E11,E22,E33)
out <- cbind(R,sqrt(vR))
colnames(out) <- c('Ar40Ar39','s[Ar40Ar39]')
out
}
get_ArAr_age <- function(Ar40Ar39,sAr40Ar39=0,J,sJ=0,exterr=FALSE){
L <- lambda("K40")[1]
tt <- log(J*Ar40Ar39+1)/L
J1 <- J/(L*(J*Ar40Ar39+1))
if (exterr){
J2 <- Ar40Ar39/(L*(J*Ar40Ar39+1))
J3 <- -tt/L
} else {
J2 <- 0
J3 <- 0
}
E11 <- sAr40Ar39^2
E22 <- sJ^2
E33 <- lambda("K40")[2]^2
vt <- errorprop1x3(J1,J2,J3,E11,E22,E33)
out <- cbind(tt,sqrt(vt))
colnames(out) <- c('t','st')
out
}
# x an object of class \code{ArAr} returns a matrix
# of 40Ar/39Ar-ages and their uncertainties.
ArAr_age <- function(x,exterr=FALSE,i=NULL,i2i=FALSE,projerr=FALSE,omit4c=NULL){
ns <- length(x)
if (ns<2) i2i <- FALSE
out <- matrix(0,ns,2)
if (i2i){
y <- data2york(x,inverse=TRUE)
fit <- york(clear(y,omit4c))
b <- fit$b
DP <- 1/(y[,'X'] - y[,'Y']/b[1])
J1 <- -DP^2
J2 <- (DP^2)/b[1]
J3 <- -y[,'Y']*(DP/b[1])^2
E33 <- rep(b[2]^2,ns)
} else {
y <- data2york(x,inverse=FALSE)
a <- iratio("Ar40Ar36")
DP <- (y[,'Y']-a[1])/y[,'X']
J1 <- -DP/y[,'X']
J2 <- 1/y[,'X']
J3 <- -1/y[,'X']
E33 <- rep(a[2]^2,ns)
}
E11 <- y[,'sX']^2
E22 <- y[,'sY']^2
E12 <- y[,'rXY']*y[,'sX']*y[,'sY']
if (projerr) sDP <- sqrt(errorprop1x3(J1,J2,J3,E11,E22,E33,E12))
else sDP <- sqrt(errorprop1x2(J1,J2,E11,E22,E12))
out <- get_ArAr_age(DP,sDP,x$J[1],x$J[2],exterr=exterr)
if (!is.null(i)) out <- out[i,]
colnames(out) <- c('t','s[t]')
out
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.