当前位置: 首页 > news >正文

源码拾贝三则

目录

一  一种枚举类型的新型使用方式

二 Eigen库中的LDLT分解

三 Eigen中的访问者模式


一  一种枚举类型的新型使用方式

///D:\Program Files (x86)\Microsoft Visual Studio\2019\Community\VC\Tools\MSVC\14.29.30133\include\xiosbase							enum _Iostate { // constants for stream states							_Statmask = 0x17							};							static constexpr _Iostate goodbit = static_cast<_Iostate>(0x0);							static constexpr _Iostate eofbit  = static_cast<_Iostate>(0x1);							static constexpr _Iostate failbit = static_cast<_Iostate>(0x2);							static constexpr _Iostate badbit  = static_cast<_Iostate>(0x4);							_NODISCARD bool __CLR_OR_THIS_CALL good() const {							return rdstate() == ios_base::goodbit;							}							_NODISCARD bool __CLR_OR_THIS_CALL eof() const {							return rdstate() & ios_base::eofbit;							}							_NODISCARD bool __CLR_OR_THIS_CALL fail() const {							return rdstate() & (ios_base::badbit | ios_base::failbit);							}							_NODISCARD bool __CLR_OR_THIS_CALL bad() const {							return rdstate() & ios_base::badbit;							}							_NODISCARD iostate __CLR_OR_THIS_CALL exceptions() const {							return _Except;							}							void __CLR_OR_THIS_CALL exceptions(iostate _Newexcept) { // set exception mask to argument							_Except = _Newexcept & _Statmask;							clear(rdstate());							}							

二 Eigen库中的LDLT分解

													
Eigen-3.4.0\Eigen\src\Cholesky\LDLT.h													
template<typename _MatrixType,int _UpLo>													
template<bool Conjugate, typename RhsType, typename DstType>													
void LDLT<_MatrixType,_UpLo>::_solve_impl_transposed(const RhsType &rhs, DstType &dst) const													
{													// dst = P b													dst = m_transpositions * rhs;													// dst = L^-1 (P b)													// dst = L^-*T (P b)													matrixL().template conjugateIf<!Conjugate>().solveInPlace(dst);													// dst = D^-* (L^-1 P b)													// dst = D^-1 (L^-*T P b)													// more precisely, use pseudo-inverse of D (see bug 241)													using std::abs;													const typename Diagonal<const MatrixType>::RealReturnType vecD(vectorD());													// In some previous versions, tolerance was set to the max of 1/highest (or rather numeric_limits::min())													// and the maximal diagonal entry * epsilon as motivated by LAPACK's xGELSS:													// RealScalar tolerance = numext::maxi(vecD.array().abs().maxCoeff() * NumTraits<RealScalar>::epsilon(),RealScalar(1) / NumTraits<RealScalar>::highest());													// However, LDLT is not rank revealing, and so adjusting the tolerance wrt to the highest													// diagonal element is not well justified and leads to numerical issues in some cases.													// Moreover, Lapack's xSYTRS routines use 0 for the tolerance.													// Using numeric_limits::min() gives us more robustness to denormals.													RealScalar tolerance = (std::numeric_limits<RealScalar>::min)();													for (Index i = 0; i < vecD.size(); ++i)													{													if(abs(vecD(i)) > tolerance)													dst.row(i) /= vecD(i);													else													dst.row(i).setZero();													}													// dst = L^-* (D^-* L^-1 P b)													// dst = L^-T (D^-1 L^-*T P b)													matrixL().transpose().template conjugateIf<Conjugate>().solveInPlace(dst);													// dst = P^T (L^-* D^-* L^-1 P b) = A^-1 b													// dst = P^-T (L^-T D^-1 L^-*T P b) = A^-1 b													dst = m_transpositions.transpose() * dst;													
}													
#endif													

三 Eigen中的访问者模式

Eigen-3.4.0\Eigen\src\Core\Visitor.h
template<typename Derived>
template<typename Visitor>
EIGEN_DEVICE_FUNC
void DenseBase<Derived>::visit(Visitor& visitor) const
{if(size()==0)return;typedef typename internal::visitor_evaluator<Derived> ThisEvaluator;ThisEvaluator thisEval(derived());enum {unroll =  SizeAtCompileTime != Dynamic&& SizeAtCompileTime * int(ThisEvaluator::CoeffReadCost) + (SizeAtCompileTime-1) * int(internal::functor_traits<Visitor>::Cost) <= EIGEN_UNROLLING_LIMIT};return internal::visitor_impl<Visitor, ThisEvaluator, unroll ? int(SizeAtCompileTime) : Dynamic>::run(thisEval, visitor);
}

http://www.lryc.cn/news/346049.html

相关文章:

  • nginx配置文件和配置命令详解案例
  • 服务网关GateWay原理
  • 第12节 第二种shellcode编写实战(1)
  • 在Ubuntu上安装Anaconda并配置远程访问Jupyter
  • 格雷希尔GripSeal:E10系列低压信号电测试连接器,应用于新能源汽车的DCR测试和EOL测试
  • 飞跨电容型的三电平(FC-NPC)逆变器simulink仿真模型
  • 前端Sass使用详解,看这篇就够了
  • 用js操作dom节点的一些方法
  • electron 中拦截内嵌页面 beforeunload 的弹窗提示
  • hcip-datacom英文词汇积累简述3
  • 什么是新能源汽车热管理?
  • iOS plist文件增删改查
  • docker安装与重装
  • 武汉星起航引领跨境新浪潮,一站式解决方案助力卖家驰骋亚马逊
  • 在做题中学习(56):二维前缀和模板
  • 驾驭多云环境,加速AI创新丨Animbus Cloud 8.3.0 算力调度平台升级发布
  • JavaScript异步编程——02-Ajax入门和发送http请求
  • 湖仓一体 - Apache Arrow的那些事
  • 常用的启发式算法:探索问题解决的智慧之道
  • docker Harbor私有仓库部署管理
  • 序列化的不同格式:JSON、XML、TOML、CSON、YAML
  • Mapreduce | 案例
  • U盘文件剪切丢失怎么办?揭秘原因并给出恢复方法
  • 软件设计师考试---访问控制列表、堆,栈和堆栈、防火墙、数据流图、嵌入式操作、绑定方式、uml、模式、传输协议
  • vlock工具:锁定Linux终端的安全智能方法
  • 【Linux】Docker 安装部署 Nacos
  • 纯血鸿蒙APP实战开发——阅读翻页方式案例
  • 如何从Mac电脑恢复任何删除的视频
  • 【Halcon 内存泄漏记录 - C#】
  • MT8370_联发科MTK8370(Genio 510)芯片性能规格参数