Main Page
Related Pages
Modules
Namespaces
Namespace List
Namespace Members
All
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
Functions
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
z
Variables
a
b
c
d
e
f
g
h
i
l
m
n
o
p
q
r
s
t
u
x
y
Typedefs
a
b
c
d
f
h
i
n
o
p
q
r
s
t
u
Enumerations
a
c
d
e
f
i
m
n
p
q
r
s
t
u
Enumerator
a
b
c
d
e
f
g
h
i
l
m
n
o
p
r
s
t
u
v
w
x
z
Classes
Class List
Class Hierarchy
Class Members
All
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
~
Functions
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
~
Variables
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
Typedefs
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
Enumerations
a
b
c
d
e
f
g
i
l
m
n
p
r
s
t
u
w
Enumerator
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
r
s
t
u
v
w
x
y
Related Functions
c
e
h
i
m
o
p
q
s
t
v
Files
File List
File Members
All
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
Functions
a
b
c
d
e
f
g
h
i
l
m
n
o
p
q
r
s
t
u
v
x
z
Variables
a
b
c
e
g
i
l
m
n
p
r
s
t
v
x
y
Typedefs
a
b
c
d
e
f
h
i
l
m
n
p
q
r
s
t
u
Enumerator
Macros
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
Examples
src
extern
eigen3
blas
GeneralRank1Update.h
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) 2012 Chen-Pang He <jdh8@ms63.hinet.net>
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
#ifndef EIGEN_GENERAL_RANK1UPDATE_H
11
#define EIGEN_GENERAL_RANK1UPDATE_H
12
13
namespace
internal
{
14
15
/* Optimized matrix += alpha * uv' */
16
template
<
typename
Scalar,
typename
Index,
int
StorageOrder,
bool
ConjLhs,
bool
ConjRhs>
17
struct
general_rank1_update
;
18
19
template
<
typename
Scalar,
typename
Index,
bool
ConjLhs,
bool
ConjRhs>
20
struct
general_rank1_update
<
Scalar
,
Index
,
ColMajor
,ConjLhs,ConjRhs>
21
{
22
static
void
run
(
Index
rows,
Index
cols,
Scalar
*
mat
,
Index
stride,
const
Scalar
* u,
const
Scalar
* v,
Scalar
alpha
)
23
{
24
typedef
Map<const Matrix<Scalar,Dynamic,1> > OtherMap;
25
typedef
typename
conj_expr_if<ConjLhs,OtherMap>::type ConjRhsType;
26
conj_if<ConjRhs> cj;
27
28
for
(
Index
i=0; i<cols; ++i)
29
Map<Matrix<Scalar,Dynamic,1> >(
mat
+stride*i,rows) +=
alpha
* cj(v[i]) * ConjRhsType(OtherMap(u,rows));
30
}
31
};
32
33
template
<
typename
Scalar,
typename
Index,
bool
ConjLhs,
bool
ConjRhs>
34
struct
general_rank1_update
<
Scalar
,
Index
,
RowMajor
,ConjLhs,ConjRhs>
35
{
36
static
void
run
(
Index
rows,
Index
cols,
Scalar
*
mat
,
Index
stride,
const
Scalar
* u,
const
Scalar
* v,
Scalar
alpha
)
37
{
38
general_rank1_update<Scalar,Index,ColMajor,ConjRhs,ConjRhs>::run
(rows,cols,
mat
,stride,u,v,
alpha
);
39
}
40
};
41
42
}
// end namespace internal
43
44
#endif // EIGEN_GENERAL_RANK1UPDATE_H
internal::general_rank1_update< Scalar, Index, RowMajor, ConjLhs, ConjRhs >::run
static void run(Index rows, Index cols, Scalar *mat, Index stride, const Scalar *u, const Scalar *v, Scalar alpha)
Definition:
GeneralRank1Update.h:36
alpha
RealScalar alpha
Definition:
level1_cplx_impl.h:125
internal::general_rank1_update
Definition:
GeneralRank1Update.h:17
Scalar
SCALAR Scalar
Definition:
common.h:84
Eigen::RowMajor
@ RowMajor
Definition:
Constants.h:322
internal::general_rank1_update< Scalar, Index, ColMajor, ConjLhs, ConjRhs >::run
static void run(Index rows, Index cols, Scalar *mat, Index stride, const Scalar *u, const Scalar *v, Scalar alpha)
Definition:
GeneralRank1Update.h:22
Eigen::TensorSycl::run
void run(Expr &expr, Dev &dev)
Definition:
TensorSyclRun.h:47
internal
Definition:
BandTriangularSolver.h:13
Eigen::ColMajor
@ ColMajor
Definition:
Constants.h:320
mat
else mat
Definition:
eigenvalues.cpp:43
Eigen::Index
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition:
Meta.h:33
control_box_rst
Author(s): Christoph Rösmann
autogenerated on Wed Mar 2 2022 00:05:47