view extra/secs2d/inst/Utilities/Updesurf.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} {} Updesurf(@var{mesh}, @
## @var{u} [ @var{property}, @var{value} ...])
## 
## Plots the scalar field @var{u}
## defined on the triangulation @var{mesh} using opendx.
##
## options (default value):
## @itemize @minus
## @item data_dep ("positions") defines wether data depends on
## positions or connections
## @item plot_field ("scalar") defines wether to plot the scalar field
## itself or its gradient
## @end itemize
##
## @end deftypefn

function Updesurf(varargin); 

  if nargin == 1

    Udrawedge(varargin{1}); 

  elseif nargin == 2

    mesh = varargin{1};
    u = varargin{2};

    dataname = mktemp("/tmp",".dx");
    scriptname = mktemp("/tmp",".net");

    UDXoutput2Ddata(dataname,mesh.p,mesh.t,u,'u',0,1,1);

    showmesh = file_in_path(path,"Ucoloredrubbersheet.net");
    system (["cp " showmesh " " scriptname]);
    system (["sed -i \'s|__FILE__DX__|" dataname "|g\' " scriptname]);

    command = ["dx -program " scriptname " -execute -image >& /dev/null &"];
    system(command);

  else

    fprintf(1,"wrong number of parameters\n\n")

  endif

endfunction 

function filename = mktemp (direct,ext);

  if (~exist(direct,"dir"))
    error("trying to save temporary file to non existing directory")
  endif

  done=false;

  while ~done
    filename = [direct,"/SECS2D.",num2str(floor(rand*1e7)),ext];
    if ~exist(filename,"file")
      done =true;
    endif
  endwhile
endfunction