Medial Code Documentation
Loading...
Searching...
No Matches
AssignmentFunctors.h
1// This file is part of Eigen, a lightweight C++ template library
2// for linear algebra.
3//
4// Copyright (C) 2008-2010 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#ifndef EIGEN_ASSIGNMENT_FUNCTORS_H
11#define EIGEN_ASSIGNMENT_FUNCTORS_H
12
13namespace Eigen {
14
15namespace internal {
16
21template<typename DstScalar,typename SrcScalar> struct assign_op {
22
23 EIGEN_EMPTY_STRUCT_CTOR(assign_op)
24 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE void assignCoeff(DstScalar& a, const SrcScalar& b) const { a = b; }
25
26 template<int Alignment, typename Packet>
27 EIGEN_STRONG_INLINE void assignPacket(DstScalar* a, const Packet& b) const
28 { internal::pstoret<DstScalar,Packet,Alignment>(a,b); }
29};
30
31// Empty overload for void type (used by PermutationMatrix)
32template<typename DstScalar> struct assign_op<DstScalar,void> {};
33
34template<typename DstScalar,typename SrcScalar>
41
46template<typename DstScalar,typename SrcScalar> struct add_assign_op {
47
48 EIGEN_EMPTY_STRUCT_CTOR(add_assign_op)
49 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE void assignCoeff(DstScalar& a, const SrcScalar& b) const { a += b; }
50
51 template<int Alignment, typename Packet>
52 EIGEN_STRONG_INLINE void assignPacket(DstScalar* a, const Packet& b) const
53 { internal::pstoret<DstScalar,Packet,Alignment>(a,internal::padd(internal::ploadt<Packet,Alignment>(a),b)); }
54};
55template<typename DstScalar,typename SrcScalar>
62
67template<typename DstScalar,typename SrcScalar> struct sub_assign_op {
68
69 EIGEN_EMPTY_STRUCT_CTOR(sub_assign_op)
70 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE void assignCoeff(DstScalar& a, const SrcScalar& b) const { a -= b; }
71
72 template<int Alignment, typename Packet>
73 EIGEN_STRONG_INLINE void assignPacket(DstScalar* a, const Packet& b) const
74 { internal::pstoret<DstScalar,Packet,Alignment>(a,internal::psub(internal::ploadt<Packet,Alignment>(a),b)); }
75};
76template<typename DstScalar,typename SrcScalar>
83
88template<typename DstScalar, typename SrcScalar=DstScalar>
90
91 EIGEN_EMPTY_STRUCT_CTOR(mul_assign_op)
92 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE void assignCoeff(DstScalar& a, const SrcScalar& b) const { a *= b; }
93
94 template<int Alignment, typename Packet>
95 EIGEN_STRONG_INLINE void assignPacket(DstScalar* a, const Packet& b) const
96 { internal::pstoret<DstScalar,Packet,Alignment>(a,internal::pmul(internal::ploadt<Packet,Alignment>(a),b)); }
97};
98template<typename DstScalar, typename SrcScalar>
105
110template<typename DstScalar, typename SrcScalar=DstScalar> struct div_assign_op {
111
112 EIGEN_EMPTY_STRUCT_CTOR(div_assign_op)
113 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE void assignCoeff(DstScalar& a, const SrcScalar& b) const { a /= b; }
114
115 template<int Alignment, typename Packet>
116 EIGEN_STRONG_INLINE void assignPacket(DstScalar* a, const Packet& b) const
117 { internal::pstoret<DstScalar,Packet,Alignment>(a,internal::pdiv(internal::ploadt<Packet,Alignment>(a),b)); }
118};
119template<typename DstScalar, typename SrcScalar>
126
142template<typename Scalar> struct swap_assign_op {
143
144 EIGEN_EMPTY_STRUCT_CTOR(swap_assign_op)
145 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE void assignCoeff(Scalar& a, const Scalar& b) const
146 {
147#ifdef EIGEN_GPUCC
148 // FIXME is there some kind of cuda::swap?
149 Scalar t=b; const_cast<Scalar&>(b)=a; a=t;
150#else
151 using std::swap;
152 swap(a,const_cast<Scalar&>(b));
153#endif
154 }
155};
156template<typename Scalar>
158 enum {
160 PacketAccess =
161 #if defined(EIGEN_VECTORIZE_AVX) && EIGEN_COMP_CLANG && (EIGEN_COMP_CLANG<800 || defined(__apple_build_version__))
162 // This is a partial workaround for a bug in clang generating bad code
163 // when mixing 256/512 bits loads and 128 bits moves.
164 // See http://eigen.tuxfamily.org/bz/show_bug.cgi?id=1684
165 // https://bugs.llvm.org/show_bug.cgi?id=40815
166 0
167 #else
169 #endif
170 };
171};
172
173} // namespace internal
174
175} // namespace Eigen
176
177#endif // EIGEN_ASSIGNMENT_FUNCTORS_H
Base class for all dense matrices, vectors, and expressions.
Definition MatrixBase.h:50
Namespace containing all symbols from the Eigen library.
Definition LDLT.h:16
NLOHMANN_BASIC_JSON_TPL_DECLARATION void swap(nlohmann::NLOHMANN_BASIC_JSON_TPL &j1, nlohmann::NLOHMANN_BASIC_JSON_TPL &j2) noexcept(//NOLINT(readability-inconsistent-declaration-parameter-name, cert-dcl58-cpp) is_nothrow_move_constructible< nlohmann::NLOHMANN_BASIC_JSON_TPL >::value &&//NOLINT(misc-redundant-expression) is_nothrow_move_assignable< nlohmann::NLOHMANN_BASIC_JSON_TPL >::value)
exchanges the values of two JSON objects
Definition json.hpp:24418
Holds information about the various numeric (i.e.
Definition NumTraits.h:236
Definition AssignmentFunctors.h:46
Definition AssignmentFunctors.h:21
Definition AssignmentFunctors.h:110
Definition XprHelper.h:176
Definition Meta.h:151
Definition AssignmentFunctors.h:89
Definition GenericPacketMath.h:107
Definition AssignmentFunctors.h:67
Definition AssignmentFunctors.h:142
Definition PacketMath.h:47