当前位置: 首页>>代码示例>>C++>>正文


C++ Grid2D::GetNI方法代码示例

本文整理汇总了C++中Grid2D::GetNI方法的典型用法代码示例。如果您正苦于以下问题:C++ Grid2D::GetNI方法的具体用法?C++ Grid2D::GetNI怎么用?C++ Grid2D::GetNI使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Grid2D的用法示例。


在下文中一共展示了Grid2D::GetNI方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: K

void Kriging2D::krigSurface(Grid2D              & trend,
                            const KrigingData2D & krigingData,
                            const CovGrid2D     & cov,
                            bool                  getResiduals)
{
  //
  // This routine by default returns z(x) = m(x) + k(x)K^{-1}(d - m). If only
  // residuals are wanted a copy of the input trend
  //
  int md = krigingData.getNumberOfData();
  const std::vector<int> & indexi = krigingData.getIndexI();
  const std::vector<int> & indexj = krigingData.getIndexJ();
  std::vector<float>       data   = krigingData.getData();   // Take an editable copy

  int nx = static_cast<int>(trend.GetNI());
  int ny = static_cast<int>(trend.GetNJ());

  if (md > 0 && md < nx*ny) {

    NRLib::SymmetricMatrix K(md);
    NRLib::Vector residual(md);
    NRLib::Vector k(md);
    NRLib::Vector x(md);

    subtractTrend(residual, data, trend, indexi, indexj);

    fillKrigingMatrix(K, cov, indexi, indexj);

    NRLib::CholeskySolve(K, residual, x);

    for (int i = 0 ; i < nx ; i++) {
      for (int j = 0 ; j < ny ; j++) {

        fillKrigingVector(k, cov, indexi, indexj, i, j);

        if (getResiduals) {  // Only get the residuals
          trend(i,j) = k * x;
        }
        else {
          trend(i,j) += k * x;
        }
      }
    }
  }
}
开发者ID:alfbr,项目名称:crava,代码行数:45,代码来源:kriging2d.cpp


注:本文中的Grid2D::GetNI方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。