⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dual.cpp

📁 Dolfin provide a high-performance linear algebra library
💻 CPP
字号:
// Copyright (C) 2003-2005 Anders Logg.// Licensed under the GNU LGPL Version 2.1.//// First added:  2003-11-28// Last changed: 2005#include <dolfin/dolfin_log.h>#include <dolfin/dolfin_math.h>#include <dolfin/Dual.h>using namespace dolfin;// FIXME: BROKEN/*//-----------------------------------------------------------------------------Dual::Dual(ODE& primal, Function& u) : ODE(primal.size()), rhs(primal, u){  // Set sparsity to transpose of sparsity for the primal  sparsity.transp(primal.sparsity);  // Set end time  T = primal.endtime();}//-----------------------------------------------------------------------------Dual::~Dual(){  // Do nothing}//-----------------------------------------------------------------------------real Dual::u0(unsigned int i){  return 1.0 / sqrt(static_cast<real>(N));}//-----------------------------------------------------------------------------real Dual::f(const Vector& phi, real t, unsigned int i){  // FIXME: Here we can do some optimization. Since we compute the sum  // FIXME: over all dual dependencies of i we will do the update of  // FIXME: buffer values many times. Since there is probably some overlap  // FIXME: we could precompute a new sparsity pattern taking all these  // FIXME: dependencies into account and then updating the buffer values  // FIXME: outside the sum.  real sum = 0.0;      if ( sparsity.sparse() )  {    const Array<unsigned int>& row(sparsity.row(i));    for (unsigned int pos = 0; pos < row.size(); pos++)      sum += rhs.dfdu(row[pos], i, T - t) * phi(row[pos]);  }  else  {    for (unsigned int j = 0; j < N; j++)      sum += rhs.dfdu(j, i, T - t) * phi(j);  }  return sum;}//-----------------------------------------------------------------------------*/

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -