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

📄 main.cpp

📁 OFELI is an object oriented library of C++ classes for development of finite element codes. Its main
💻 CPP
字号:
/*==============================================================================

                                    O  F  E  L  I

                            Object  Finite  Element  Library

  ==============================================================================

   Copyright (C) 1998 - 2004 Rachid Touzani

   This program is free software; you can redistribute it and/or modify it under
   the terms of the GNU General Public License as published by the Free 
   Software Foundation; Version 2 of the License.

   This program is distributed in the hope that it will be useful, but WITHOUT
   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
   FOR A PARTICULAR PURPOSE. See the GNU General Public License for more 
   details.

   You should have received a copy of the GNU General Public License 
   along with this program; if not, write to the :

   Free Software Foundation
   Inc., 59 Temple Place - Suite 330
   Boston, MA  02111-1307, USA

  ==============================================================================

             An example of a Finite Element Code using OFELI

            Solution of a 2-D Transient Heat Equation using :
                  - P1 Finite elements for space discretization
                  - Implicit Euler scheme for time discretization

  ==============================================================================*/


#include "OFELI.h"
#include "Therm.h"
#include "User.h"
using namespace OFELI;

int main(int argc, char *argv[])
{
   Element *el;
   Side    *sd;

// Read and output mesh data
   if (argc <= 1) {
      cout << " Usage : ex4 <parameter_file>" << endl;
      exit(1);
   }
   IPF data(argv[1]);
   double max_time = data.MaxTime();
   double deltat = data.TimeStep();
   Mesh ms(data.MeshFile(1));
   User ud(ms);

// Declare problem data (matrix, rhs, boundary conditions, body forces)
   SkSMatrix<double> a(ms);
   Vect<double> b(ms.NbDOF()), u(ms.NbDOF()), bc(ms.NbDOF());

// Read in initial solution
   ud.SetInitialData(u);

   int nb_step = int(max_time/deltat);
   double time = 0;

// Loop over time steps
// --------------------

   for (int step=1; step<=nb_step; step++) {
      time += deltat;
      b = 0;

//    Read in boundary conditions
      ud.Time(time);
      ud.SetDBC(bc);

      for (ms.TopElement(); (el=ms.GetElement());) {

//       Declare an instance of class DC2DT3
         DC2DT3 eq(el,u,time);

//       Capacity contribution to matrix and to RHS
         eq.LCapacityToLHS(1./deltat);
         eq.LCapacityToRHS(1./deltat);

//       Diffusion contribution to matrix
         eq.Diffusion();

//       Assemble element matrix and RHS
         if (step==1)
           a.Assembly(el,eq.A());
         b.Assembly(el,eq.b());
      }

//    Loop over edges
      for (ms.TopSide(); (sd=ms.GetSide());) {
         DC2DT3 eq(sd,u,time);
         eq.BoundaryRHS(ud);
         b.Assembly(sd,eq.b());
      }

//    Impose boundary conditions on matrix and RHS
      a.Prescribe(ms,b,bc,step-1);

//    Solve the linear system of equations
      if (step == 1) 
        a.Factor();
      a.Solve(b);
      u = b;

//    Output solution
      cout << "\nSolution for time : " << time << endl << u;
   }

#ifdef WITH_PAUSE
   system("PAUSE");
#endif
   return 0;
}

⌨️ 快捷键说明

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