view extra/secs2d/inst/Utilities/Udriftdiffusion2.m @ 9886:2112c90c2445 octave-forge

secs2d: update license to GPLv3+
author carandraug
date Mon, 26 Mar 2012 19:46:13 +0000
parents c25715bc0bc2
children
line wrap: on
line source

## Copyright (C) 2004-2008  Carlo de Falco
##
## SECS2D - A 2-D Drift--Diffusion Semiconductor Device Simulator
##
## SECS2D 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; either version 3 of the License, or
## (at your option) any later version.
##
## SECS2D 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 SECS2D; If not, see <http://www.gnu.org/licenses/>.
##
## AUTHOR: Carlo de Falco <cdf _AT_ users.sourceforge.net>

## -*- texinfo -*-
##
## @deftypefn {Function File}{@var{n}} = @
## Udriftdiffusion2(@var{mesh},@var{Dsides},@var{guess},@var{M},@var{U},@var{V},@var{Vth},@var{u})
##
## Solve the drift diffusion equation
## 
## -div ( @var{u} ( \nabla (@var{n} @var{Vth}) - @var{n} \nabla @var{V})) + @var{M} = @var{U}
##
## @end deftypefn

function c = Udriftdiffusion2(mesh,Dsides,guess,M,U,V,Vth,u)

  global DDG_RHS DDG_MASS

  Nnodes    = max(size(mesh.p));
  Nelements = max(size(mesh.t));


  ## Set list of nodes with Dirichelet BCs
  Dnodes = Unodesonside(mesh,Dsides);

  ## Set values of Dirichelet BCs
  Bc = guess(Dnodes);

  ## Set list of nodes without Dirichelet BCs
  Varnodes = setdiff([1:Nnodes],Dnodes);

  ## Build LHS matrix and RHS
  A = Uscharfettergummel2(mesh,V,u,Vth);
  if (isempty(DDG_MASS))
    DDG_MASS = Ucompmass2(mesh,ones(Nnodes,1),ones(Nelements,1));
  endif
  A = A + DDG_MASS.*spdiag(M,0);

  if (isempty(DDG_RHS))
    DDG_RHS = Ucompconst(mesh,ones(Nnodes,1),ones(Nelements,1));
  endif
  b = DDG_RHS.*U;

  ## Apply boundary conditions
  A(Dnodes,:) = 0;
  b(Dnodes)   = 0;
  b           = b - A (:,Dnodes) * Bc;

  A(Dnodes,:) = [];
  A(:,Dnodes) = [];

  b(Dnodes)   = [];


  c           = guess;
  c(Varnodes) = A \ b;

endfunction