源码拾贝三则

简介: 文章分享了三则源码示例,包括: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());                            
    }
AI 代码解读

二 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
AI 代码解读

三 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);
}
AI 代码解读
目录
打赏
0
0
0
0
48
分享
相关文章
为什么 Rust 备受开发者青睐?
在本篇文章中,作者介绍了 Rust 是什么,它的历史以及 Rust 是如何备受开发者和行业的青睐。希望本篇文章能帮助读者对 Rust 这门语言有一个大概的了解。
137836 43
《设计模式:可复用面向对象软件的基础(典藏版)》
本书是埃里克·伽玛著作,涵盖180个笔记,主要介绍面向对象设计模式,包括MVC、设计模式编目、组织编目、实现描述、复用机制、运行时与编译时结构关联、设计支持变化等方面。书中详细解释了23种设计模式,如Abstract Factory、Adapter、Bridge、Builder等,按创建型、结构型、行为型分类,旨在提高软件可复用性和灵活性。
681 0
《设计模式:可复用面向对象软件的基础(典藏版)》
微服务调用中TraceId是如何传递的?
由于网络原因,我暂时无法解析提供的网页链接。请检查链接是否有效,或稍后再试。如果您有其他问题或需要帮助,请随时告诉我。
微服务调用中TraceId是如何传递的?
使用 Python holidays 库获取中国节日
使用 Python holidays 库获取中国节日
608 2
情感分析的终极形态:全景式细粒度多模态对话情感分析基准PanoSent
【9月更文挑战第24天】PanoSent是一种全新的多模态对话情感分析框架,旨在全景式地提取和分析情感元素,包括情感六元组提取与情感翻转分析两大任务。此框架依托大规模、高质量的多模态数据集PanoSent,涵盖文本、图像、音频等多种模态及多种语言,适应不同应用场景。为解决这些任务,研究人员提出了Chain-of-Sentiment推理框架,结合多模态大语言模型Sentica,实现细粒度的情感分析。尽管PanoSent在情感分析任务上表现优异,但仍面临多模态数据处理和跨领域适用性的挑战。
270 2
【C】转义字符以及注释的介绍
转义字符顾名思义就是转变意思。就是把原来字符的意思转变了,让它拥有别的意思。
【Python实现坦克大战,带你找回童年的快乐】附源码
【Python实现坦克大战,带你找回童年的快乐】附源码
343 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问