源码拾贝三则

简介: 文章分享了三则源码示例,包括:1) 枚举类型的新型使用方式;2) Eigen库中LDLT分解的实现;3) 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);
}
相关文章
|
开发框架 小程序 前端开发
带你了解小程序的框架之谜
带你了解小程序的框架之谜
|
6月前
|
存储 Web App开发 运维
发布、部署,傻傻分不清楚?从概念到实际场景,再到工具应用,一篇文章让你彻底搞清楚
部署和发布是软件工程中经常互换使用的两个术语,甚至感觉是等价的。然而,它们是不同的! • 部署是将软件从一个受控环境转移到另一个受控环境,它的目的是将软件从开发状态转化为生产状态,使得软件可以为用户提供服务。 • 发布是将软件推向用户的过程,应用程序需要多次更新、安全补丁和代码更改,跨平台和环境部署需要对版本进行适当的管理,有一定的计划性和管控因素。
1526 1
|
6月前
|
消息中间件 NoSQL Java
九大核心专题,630页内容,熬夜23天吃透,我收割了3个大厂offer
今年受疫情影响非常大,春招和金三银四都要比往年来得更迟一些。春招结束之后,我特意把自己的面试经历顺了顺,总结出了不少的经验。对了,这次一共收割了3个大厂offer,分别是蚂蚁金服、美团和网易,特意分享这次对我帮助非常大的宝典资料,一共涉及九大核心专题,分别是计算机网络、操作系统、MySQL、Linux、JAVA、JVM、Redis、消息队列与分布式、网站优化相关,这些内容我熬夜整整23天才读完,希望它也能帮助到你们。
值得一看!阿里又杀疯了开源内部“M9”级别全彩版分布式实战笔记
系统架构大致经历了单体应用架构→垂直应用架构→分布式架构→SOA架构→微服务架构的演变
|
缓存 Java 程序员
肝到头秃!百度强推并发编程笔记我爱了,原来这才叫并发
随着Java程序员的大幅增长,人们对Java程序员的要求也是越来越严苛。从现在Java岗的招聘需求来看,并发编程已经是我们Java程序员避不开的坎了! 编写正确的程序并不容易,而编写正确的并发程序就更难了。与顺序执行的程序相比,并发程序中显然更容易出现错误。而且并发性错误通常并不会以某种确定的方式显现出来。
|
Windows
谈一谈|下载软件的门道你懂吗?
谈一谈|下载软件的门道你懂吗?
134 0
|
机器学习/深度学习 存储 人工智能
程序员饭碗不保了?GPT-3 最强应用发布,动动手指就自动写代码的神器来了!...
程序员饭碗不保了?GPT-3 最强应用发布,动动手指就自动写代码的神器来了!...
1879 0
程序员饭碗不保了?GPT-3 最强应用发布,动动手指就自动写代码的神器来了!...
|
XML 测试技术 程序员
人月神话札记:整体部分
人月神话札记:整体部分
120 0
人月神话札记:整体部分
|
程序员
程序员十大常规内卷操作,你学废了吗?
现阶段内卷已经成为互联网行业的专有名词,在很多公司,内卷的程度则代表着员工的努力程度,本文尝试教授十招程序员内卷操作,学完过后,帮助你干啥啥不行,内卷第一名。
|
JSON Java Android开发
Android性能优化来龙去脉总结
更多Android高级架构进阶视频免费学习:Android高级架构进阶视频免费分享学习网址以下是本人在工作中对经历过的性能优化的一些总结,依据故事的发展路线,将其分为了5个部分,分别是:常见的性能问题;产生性能问题的一些可能原因;解决性能问题的套路;代码建议及潜在性能问题排查项。
下一篇
无影云桌面