numerical-collection-cpp
0.10.0
A collection of algorithms in numerical analysis implemented in C++
Loading...
Searching...
No Matches
expm1_maclaurin.h
Go to the documentation of this file.
1
/*
2
* Copyright 2021 MusicScience37 (Kenta Kabashima)
3
*
4
* Licensed under the Apache License, Version 2.0 (the "License");
5
* you may not use this file except in compliance with the License.
6
* You may obtain a copy of the License at
7
*
8
* http://www.apache.org/licenses/LICENSE-2.0
9
*
10
* Unless required by applicable law or agreed to in writing, software
11
* distributed under the License is distributed on an "AS IS" BASIS,
12
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
* See the License for the specific language governing permissions and
14
* limitations under the License.
15
*/
20
#pragma once
21
22
#include "
num_collect/constants/one.h
"
// IWYU pragma: keep
23
#include "
num_collect/constants/zero.h
"
// IWYU pragma: keep
24
25
namespace
num_collect::constants::impl
{
26
41
template
<
typename
T>
42
constexpr
auto
expm1_maclaurin
(T x) -> T {
43
T sum =
zero<T>
;
44
T term =
one<T>
;
45
constexpr
int
max_loops = 1000;
46
for
(
int
i = 1; i <= max_loops; ++i) {
47
T prev_sum = sum;
48
term *= x;
49
term /=
static_cast<
T
>
(i);
50
sum += term;
51
if
(sum == prev_sum) {
52
break
;
53
}
54
}
55
return
sum;
56
}
57
58
}
// namespace num_collect::constants::impl
num_collect::constants::impl
Namespace of internal implementations.
Definition
exp_maclaurin.h:24
num_collect::constants::impl::expm1_maclaurin
constexpr auto expm1_maclaurin(T x) -> T
Calculate exponential function minus one with Maclaurin series.
Definition
expm1_maclaurin.h:42
num_collect::constants::zero
constexpr T zero
Value 0.
Definition
zero.h:30
num_collect::constants::one
constexpr T one
Value 1.
Definition
one.h:30
one.h
Definition of one.
zero.h
Definition of zero.
include
num_collect
constants
impl
expm1_maclaurin.h
Generated on Sat Jan 18 2025 03:47:32 for numerical-collection-cpp by
1.12.0