Logo Search packages:      
Sourcecode: octave-ocs version File versions  Download package

Mpmosfet.m

## Copyright (C) 2006,2007,2008  Carlo de Falco            
##
## This file is part of:
## OCS - A Circuit Simulator for Octave
##
## OCS 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.
##
## 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 (see the file LICENSE); if not,
## see <http://www.gnu.org/licenses/>.
##
## author: Carlo de Falco <cdf _AT_ users.sourceforge.net> 

## -*- texinfo -*-
##
## @deftypefn{Function File} @
## {[@var{a},@var{b},@var{c}]=}Mpmosfet@
## (@var{string}, @var{parameters}, @var{parameternames}, @
## @var{extvar},@var{intvar},@var{t})
##
## SBN file implementing standard models for p-mosfets.
##
## @var{string} is used to select among models. Parameters are listed
## as inner items. Possible models are:
##
## @enumerate
## @item @var{string} = "simple" (Standard model for MOSFET)
## @itemize @minus
## @item rd  -> parasitic resistance between drain and source
## @item k   -> k parameter for usual mosfet model
## @item Vth -> threshold voltage
## @end itemize
## @item @var{string} = "lincap" (Adds RC parasitics)
## @itemize @minus
## @item rd  -> parasitic resistance between drain and source
## @item k   -> k parameter for usual mosfet model
## @item Vth -> threshold voltage
## @item Rs  -> parasitic source resistance 
## @item Rd  -> parasitic drain resistance
## @item Cs  -> gate-source capacitance
## @item Cd  -> gate-drain capacitance
## @item Cb  -> gate-bulk capacitance
## @end itemize
## @end enumerate
##
## @seealso{ PRSiffparse, ASMinitsystem, ASMbuildsystem, the IFF file
## format  specifications }
## @end deftypefn

function [a,b,c]= Mpmosfet (string,parameters,parameternames,extvar,intvar,t) 
  
  switch string
    case "simple"
      
      rd = 1e6;
      
      for ii=1:length(parameternames)
      eval([parameternames{ii} "=",...
            num2str(parameters(ii)) " ;"]);
      endfor

      vg   = extvar(1);
      vs   = extvar(2);
      vd   = extvar(3);
      vb   = extvar(4);

      vgs  = vg-vs;
      vds  = vd-vs;
      
      if (vgs > Vth)

      gm = 0;
      gd = 1/rd;
      id = vds*gd;
      
      elseif ((vgs-Vth)<=(vds))&(vds<=0)
      
      id = k*((vgs-Vth)*vds-(vds^2)/2)+vds/rd;
      gm = k*vds;
      gd = k*(vgs-Vth-vds)+1/rd;
      
      elseif ((vgs-Vth)<=(vds))&(vds>0)
      
      gm = 0;
      gd = 1/rd;
      id = vds*gd;
      
      else

      id = k*(vgs-Vth)^2/2+vds/rd;
      gm = k*(vgs-Vth);
      gd = 1/rd;
      
      endif
      a = zeros(4);
      
      b = [0    0       0  0;
         -gm  (gm+gd) -gd  0; 
         gm -(gm+gd)  gd  0;
           0    0       0   0 ];
      
      c =[0 -id id 0]';
      break;

    case "lincap"
      
      ## Default parameter values
      if isempty(intvar)
      intvar = zeros(5,1);
      endif
      Rs = 1e2; Rd = 1e2; Cs = 1e-15; 
      Cd = 1e-15; Cb = 1e-12;
      rd = inf; k = -1e-3; Vth = -.1; 

      ## parameters given in input
      
      for ii=1:length(parameternames)
      eval([parameternames{ii} "=",...
            num2str(parameters(ii)) " ;"])      
      endfor
      
      
      mtdpmos   = file_in_path(path,"Mtdpmos.cir");
      mtdpmos(end-3:end)=[];
      tmpstruct = PRSIFFparse(mtdpmos);
      

      tmpstruct.NLC.pvmatrix    = [k Vth rd];
      tmpstruct.LCR(1).pvmatrix = [Rs; Rd];
      tmpstruct.LCR(2).pvmatrix = [Cs; Cd; Cb];
      
      [A0,B,C,tmpstruct]     = ASMinitsystem(tmpstruct,[extvar;intvar]);
      [A1,Jac,res] = ASMbuildsystem(tmpstruct,[extvar;intvar],t);
      
      a = A0+A1;
      b = B+Jac;
      c = res + B*[extvar;intvar] + C;

      break;

    otherwise
      error(["unknown option:" string]);
  endswitch

endfunction

Generated by  Doxygen 1.6.0   Back to index