R/taylor.R

Defines functions taylor

Documented in taylor

##
##  t a y l o r . R  Taylor Series Approximation
##


taylor <- function(f, x0, n = 4, ...) {
    if (!is.numeric(x0))
        stop("Argument 'x0' must be a numeric value or vector.")
    if (!is.numeric(n) || floor(n) != ceil(n) || length(n) != 1)
        stop("Order 'n' must be an scalar integer between 1 and 8.")

    fun <- match.fun(f)
    f <- function(x) fun(x, ...)

    if (n > 8) {
        # n <- 8
        warning("Order 'n' is too high; should not be greater than 'n=8'.")
    } else if (n <= 0) {
        n <- 4
        warning("Order 'n' is too low; will be reset to the default 'n=4'.")
    }

    T <- f(x0)
    for (i in 1:n) {
        T <- polyadd(T, fderiv(f, x0, i)/fact(i) * polypow(c(1, -x0), i))
    }
    return(T)
}

Try the pracma package in your browser

Any scripts or data that you put into this service are public.

pracma documentation built on March 19, 2024, 3:05 a.m.