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

📄 scaledmf.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 - 2002 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

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

#include "OFELI.h"
#include "Electromagnetics.h"

#ifndef LARGE
#define LARGE 1.e20
#endif

using namespace OFELI;

void ScaledMF(Mesh &ms, SkMatrix<std::complex<double> > &a, Vect<std::complex<double> > &b, 
              std::complex<double> &current, double omega, int flag)
//------------------------------------------------------------------------------
//              Calculate scaled magnetic field
//------------------------------------------------------------------------------
{
   Element *el;
   Node *nd;
   for (ms.TopElement(); (el=ms.GetElement());) {
      EC2D1T3 equa(el);
      equa.Magnetic(omega,1.);
      equa.Electric();
      a.Assembly(el,equa.A());
   }

   for (ms.TopNode(); (nd=ms.GetNode());) {
      int m = nd->DOF(1);
      if (nd->Code(1)==1) {
        a.Set(m,m,a(m,m)*LARGE);
        b[m-1] = a(m,m)*current;
      }
      if (nd->Code(1)==2) {
        a.Set(m,m,a(m,m)*LARGE);
        b[m-1] = 0;
      }
   }

   a.Factor();
   a.Solve(b);
}

⌨️ 快捷键说明

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