gtsam
3rdparty
Eigen
lapack
3rdparty/Eigen/lapack/cholesky.cpp
Go to the documentation of this file.
1
// This file is part of Eigen, a lightweight C++ template library
2
// for linear algebra.
3
//
4
// Copyright (C) 2010-2011 Gael Guennebaud <gael.guennebaud@inria.fr>
5
//
6
// This Source Code Form is subject to the terms of the Mozilla
7
// Public License v. 2.0. If a copy of the MPL was not distributed
8
// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
9
10
#include "
lapack_common.h
"
11
#include <Eigen/Cholesky>
12
13
// POTRF computes the Cholesky factorization of a real symmetric positive definite matrix A.
14
EIGEN_LAPACK_FUNC
(potrf,(
char
* uplo,
int
*
n
,
RealScalar
*pa,
int
*
lda
,
int
*
info
))
15
{
16
*
info
= 0;
17
if
(
UPLO
(*uplo)==
INVALID
) *
info
= -1;
18
else
if
(*
n
<0) *
info
= -2;
19
else
if
(*
lda
<
std::max
(1,*
n
)) *
info
= -4;
20
if
(*
info
!=0)
21
{
22
int
e
= -*
info
;
23
return
xerbla_
(
SCALAR_SUFFIX_UP
"POTRF"
, &
e
, 6);
24
}
25
26
Scalar
*
a
=
reinterpret_cast<
Scalar
*
>
(pa);
27
MatrixType
A
(
a
,*
n
,*
n
,*
lda
);
28
int
ret
;
29
if
(
UPLO
(*uplo)==
UP
)
ret
=
int
(internal::llt_inplace<Scalar, Upper>::blocked(
A
));
30
else
ret
=
int
(internal::llt_inplace<Scalar, Lower>::blocked(
A
));
31
32
if
(
ret
>=0)
33
*
info
=
ret
+1;
34
35
return
0;
36
}
37
38
// POTRS solves a system of linear equations A*X = B with a symmetric
39
// positive definite matrix A using the Cholesky factorization
40
// A = U**T*U or A = L*L**T computed by DPOTRF.
41
EIGEN_LAPACK_FUNC
(potrs,(
char
* uplo,
int
*
n
,
int
*nrhs,
RealScalar
*pa,
int
*
lda
,
RealScalar
*pb,
int
*ldb,
int
*
info
))
42
{
43
*
info
= 0;
44
if
(
UPLO
(*uplo)==
INVALID
) *
info
= -1;
45
else
if
(*
n
<0) *
info
= -2;
46
else
if
(*nrhs<0) *
info
= -3;
47
else
if
(*
lda
<
std::max
(1,*
n
)) *
info
= -5;
48
else
if
(*ldb<
std::max
(1,*
n
)) *
info
= -7;
49
if
(*
info
!=0)
50
{
51
int
e
= -*
info
;
52
return
xerbla_
(
SCALAR_SUFFIX_UP
"POTRS"
, &
e
, 6);
53
}
54
55
Scalar
*
a
=
reinterpret_cast<
Scalar
*
>
(pa);
56
Scalar
*
b
=
reinterpret_cast<
Scalar
*
>
(pb);
57
MatrixType
A
(
a
,*
n
,*
n
,*
lda
);
58
MatrixType
B
(
b
,*
n
,*nrhs,*ldb);
59
60
if
(
UPLO
(*uplo)==
UP
)
61
{
62
A
.triangularView<
Upper
>().
adjoint
().solveInPlace(
B
);
63
A
.triangularView<
Upper
>().solveInPlace(
B
);
64
}
65
else
66
{
67
A
.triangularView<
Lower
>().solveInPlace(
B
);
68
A
.triangularView<
Lower
>().
adjoint
().solveInPlace(
B
);
69
}
70
71
return
0;
72
}
gtsam.examples.DogLegOptimizerExample.int
int
Definition:
DogLegOptimizerExample.py:111
UPLO
#define UPLO(X)
Definition:
gtsam/3rdparty/Eigen/blas/common.h:56
e
Array< double, 1, 3 > e(1./3., 0.5, 2.)
ret
int ret
Definition:
3rdparty/Eigen/lapack/cholesky.cpp:28
MatrixType
MatrixXf MatrixType
Definition:
benchmark-blocking-sizes.cpp:52
B
MatrixType B(b, *n, *nrhs, *ldb)
EIGEN_LAPACK_FUNC
#define EIGEN_LAPACK_FUNC(FUNC, ARGLIST)
Definition:
lapack_common.h:16
Eigen::Upper
@ Upper
Definition:
Constants.h:211
a
Scalar * a
Definition:
3rdparty/Eigen/lapack/cholesky.cpp:26
b
Scalar * b
Definition:
3rdparty/Eigen/lapack/cholesky.cpp:56
n
int n
Definition:
BiCGSTAB_simple.cpp:1
A
MatrixType A(a, *n, *n, *lda)
info
else if n * info
Definition:
3rdparty/Eigen/lapack/cholesky.cpp:18
SCALAR_SUFFIX_UP
#define SCALAR_SUFFIX_UP
Definition:
blas/complex_double.cpp:12
lapack_common.h
Eigen::Lower
@ Lower
Definition:
Constants.h:209
RealScalar
NumTraits< Scalar >::Real RealScalar
Definition:
bench_gemm.cpp:47
xerbla_
EIGEN_WEAK_LINKING int xerbla_(const char *msg, int *info, int)
Definition:
xerbla.cpp:15
lda
else if * lda(1, *n)) *info=-4;if(*info!=0
Definition:
3rdparty/Eigen/lapack/cholesky.cpp:19
max
#define max(a, b)
Definition:
datatypes.h:20
INVALID
#define INVALID
Definition:
gtsam/3rdparty/Eigen/blas/common.h:45
adjoint
void adjoint(const MatrixType &m)
Definition:
adjoint.cpp:67
UP
#define UP
Definition:
gtsam/3rdparty/Eigen/blas/common.h:39
Scalar
SCALAR Scalar
Definition:
bench_gemm.cpp:46
gtsam
Author(s):
autogenerated on Tue Jan 7 2025 04:01:56