WPILibC++
2023.4.3-108-ge5452e3
lbeta.hpp
Go to the documentation of this file.
1
/*################################################################################
2
##
3
## Copyright (C) 2016-2022 Keith O'Hara
4
##
5
## This file is part of the GCE-Math C++ library.
6
##
7
## Licensed under the Apache License, Version 2.0 (the "License");
8
## you may not use this file except in compliance with the License.
9
## You may obtain a copy of the License at
10
##
11
## http://www.apache.org/licenses/LICENSE-2.0
12
##
13
## Unless required by applicable law or agreed to in writing, software
14
## distributed under the License is distributed on an "AS IS" BASIS,
15
## WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
## See the License for the specific language governing permissions and
17
## limitations under the License.
18
##
19
################################################################################*/
20
21
#ifndef _gcem_lbeta_HPP
22
#define _gcem_lbeta_HPP
23
24
/**
25
* Compile-time log-beta function
26
*
27
* @param a a real-valued input.
28
* @param b a real-valued input.
29
* @return the log-beta function using \f[ \ln \text{B}(\alpha,\beta) := \ln \int_0^1 t^{\alpha - 1} (1-t)^{\beta - 1} dt = \ln \Gamma(\alpha) + \ln \Gamma(\beta) - \ln \Gamma(\alpha + \beta) \f]
30
* where \f$ \Gamma \f$ denotes the gamma function.
31
*/
32
33
template
<
typename
T1,
typename
T2>
34
constexpr
35
common_return_t<T1,T2>
36
lbeta
(
const
T1 a,
const
T2
b
)
37
noexcept
38
{
39
return
( (
lgamma
(a) +
lgamma
(
b
)) -
lgamma
(a+
b
) );
40
}
41
42
#endif
lgamma
EIGEN_DEVICE_FUNC const LgammaReturnType lgamma() const
\cpp11
Definition:
ArrayCwiseUnaryOps.h:620
lbeta
constexpr common_return_t< T1, T2 > lbeta(const T1 a, const T2 b) noexcept
Compile-time log-beta function.
Definition:
lbeta.hpp:36
units::b
b
Definition:
data.h:44
thirdparty
gcem
include
gcem_incl
lbeta.hpp
Generated on Mon Jul 10 2023 17:03:00 for WPILibC++ by
1.9.4