]> Creatis software - CreaPhase.git/blobdiff - octave_packages/ocs-0.1.3/sbn/Mpmosfet.m
Add a useful package (from Source forge) for octave
[CreaPhase.git] / octave_packages / ocs-0.1.3 / sbn / Mpmosfet.m
diff --git a/octave_packages/ocs-0.1.3/sbn/Mpmosfet.m b/octave_packages/ocs-0.1.3/sbn/Mpmosfet.m
new file mode 100644 (file)
index 0000000..c4fbae3
--- /dev/null
@@ -0,0 +1,153 @@
+## 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
+##
+## See the @cite{IFF file format specifications} for details about 
+## the output structures.
+##
+## @seealso{prs_iff,asm_initialize_system,asm_build_system}
+## @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 = prs_iff(mtdpmos);
+      
+
+      tmpstruct.NLC.pvmatrix    = [k Vth rd];
+      tmpstruct.LCR(1).pvmatrix = [Rs; Rd];
+      tmpstruct.LCR(2).pvmatrix = [Cs; Cd; Cb];
+      
+      [A0,B,C]     = asm_initialize_system(tmpstruct,[extvar;intvar]);
+      [A1,Jac,res] = asm_build_system(tmpstruct,[extvar;intvar],t);
+      
+      a = A0+A1;
+      b = B+Jac;
+      c = res + B*[extvar;intvar] + C;
+
+      break;
+
+    otherwise
+      error(["unknown option:" string]);
+  endswitch
+
+endfunction