Nothing
##
## f d e r i v . R Numerical Differentiation
##
fderiv <- function(f, x, n = 1, h = 0,
method = c("central", "forward", "backward"), ...) {
if (length(x) == 0) return(c())
if (!is.numeric(x))
stop("Argument 'x' must be a number or a numeric vector.")
n <- floor(n)
if (n < 0)
stop("The order of the derivative, 'n', can only be between 0 and 8.")
if (n > 8)
warning("Numerical derivatives of order 'n > 8' will be very inexact.")
method <- match.arg(method)
fun <- match.fun(f)
f <- function(x) fun(x, ...)
fx <- f(x)
if (length(fx) != length(x))
stop("Function 'f' must first be vectorized: Vectorize(f).")
if (n == 0) return(f(x))
if (h == 0) {
h <- .Machine$double.eps^(1/(n+2))
}
if (method == "central") {
if (n == 1) {
.df <- (f(x+h) - f(x-h)) / (2*h)
} else if (n == 2) {
.df <- (f(x+h) - 2*f(x) + f(x-h)) / h^2
} else if (n == 3) {
.df <- (f(x+2*h) - 2*f(x+h) + 2*f(x-h) - f(x-2*h)) / (2*h^3)
} else if (n == 4) {
.df <- (f(x+2*h) - 4*f(x+h) + 6*f(x) - 4*f(x-h) + f(x-2*h)) / h^4
} else {
.df <- sum((-1)^(0:n) * choose(n, 0:n) * f(((n/2):(-n/2))*h))/h^n
}
} else if (method == "forward") {
if (n == 1) {
.df <- (-f(x+2*h) + 4*f(x+h) - 3*f(x)) / (2*h)
} else if (n == 2) {
.df <- (-f(x+3*h) + 4*f(x+2*h) - 5*f(x+h) + 2*f(x)) / h^2
} else if (n == 3) {
.df <- (-3*f(x+4*h) + 14*f(x+3*h) - 24*f(x+2*h) + 18*f(x+h) - 5*f(x)) / (2*h^3)
} else if (n == 4) {
.df <- (-2*f(x+5*h) + 11*f(x+4*h) - 24*f(x+3*h) + 26*f(x+2*h) - 14*f(x+h) + 3*f(x)) / h^4
} else {
.df <- sum((-1)^(0:n) * choose(n, 0:n) * f((n:0)*h))/h^n
}
} else if (method == "backward") {
if (n == 1) {
.df <- (3*f(x) - 4*f(x-h) + f(x-2*h)) / (2*h)
} else if (n == 2) {
.df <- (2*f(x) - 5*f(x-h) + 4*f(x-2*h) - f(x-3*h)) / h^2
} else if (n == 3) {
.df <- (5*f(x) - 18*f(x-h) + 24*f(x-2*h) - 14*f(x-3*h) + 3*f(x-4*h)) / (2*h^3)
} else if (n == 4) {
.df <- (3*f(x) - 14*f(x-h) + 26*f(x-2*h) - 24*f(x-3*h) + 11*f(x-4*h) - 2*f(x-5*h)) / h^4
} else {
.df <- sum((-1)^(0:n) * choose(n, 0:n) * f((0:-n)*h))/h^n
}
} else
stop("Unknown 'method'; use 'central', 'forward' or 'backward' instead.")
return(.df)
}
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.