6#ifndef DERIVATION_THEORETICA_H
7#define DERIVATION_THEORETICA_H
9#include "../core/function.h"
10#include "../polynomial/polynomial.h"
20 template<
typename Field = real>
32 for (
unsigned int i = 1; i <
p.size(); ++i)
50 for (
unsigned int i = 0; i + 1 <
p.size(); ++i) {
52 const unsigned int pos =
p.size() - i - 1;
72 return (f(x +
h) - f(x -
h)) / (2.0 *
h);
88 return (f(x +
h) - f(x)) /
h;
104 return (f(x) - f(x -
h)) /
h;
146 for (
unsigned int i = 0; i < degree; ++i) {
148 for (
unsigned int n = 0;
n <= i; ++
n) {
150 unsigned int m = i -
n;
156 A[
n][
m] = (coeff * A[
n - 1][
m + 1] - A[
n - 1][
m]) / (coeff - 1);
162 return A[degree - 1][0];
194 return (f(x +
h) - (2 * f(x)) + f(x -
h)) / (
h *
h);
A polynomial of arbitrary order with coefficients of a specified type.
Definition polynomial.h:28
void resize(size_t sz)
Change the number of coefficients of the polynomial.
Definition polynomial.h:168
#define TH_MATH_ERROR(F_NAME, VALUE, EXCEPTION)
TH_MATH_ERROR is a macro which throws exceptions or modifies errno (depending on which compilation op...
Definition error.h:219
Main namespace of the library which contains all functions and objects.
Definition algebra.h:27
double real
A real number, defined as a floating point type.
Definition constants.h:207
real deriv_forward(RealFunction f, real x, real h=CALCULUS_DERIV_STEP)
Approximate the first derivative of a real function using the forward method.
Definition deriv.h:87
Vector make_error()
Create a vector representing an error state, with all NaN values.
Definition algebra.h:103
constexpr real CALCULUS_DERIV_STEP
Default variation for derivative approximation.
Definition constants.h:327
TH_CONSTEXPR real nan()
Return a quiet NaN number in floating point representation.
Definition error.h:74
real deriv_ridders(RealFunction f, real x, real h=0.01, unsigned int degree=3)
Approximate the first derivative of a real function using Ridder's method of arbitrary degree.
Definition deriv.h:136
real deriv_ridders2(RealFunction f, real x, real h=CALCULUS_DERIV_STEP)
Approximate the first derivative of a real function using Ridder's method of second degree.
Definition deriv.h:119
@ InvalidArgument
Invalid argument.
real deriv_central(RealFunction f, real x, real h=CALCULUS_DERIV_STEP)
Approximate the first derivative of a real function using the central method.
Definition deriv.h:71
real deriv2(RealFunction f, real x, real h=CALCULUS_DERIV_STEP)
Approximate the second derivative of a real function using the best available algorithm.
Definition deriv.h:193
real deriv_backward(RealFunction f, real x, real h=CALCULUS_DERIV_STEP)
Approximate the first derivative of a real function using the backward method.
Definition deriv.h:103
polynomial< Field > deriv(const polynomial< Field > &p)
Compute the exact derivative of a polynomial function.
Definition deriv.h:21
dual2 square(dual2 x)
Return the square of a second order dual number.
Definition dual2_functions.h:23