V10/cmd/matlab/install.n

.ds xl MATLAB Installation
.hy 0
.de pp
.sp 
.ti +5
..
.de hd
'sp 2
.if \\n%-1 'tl '\*(xl, page %'
.if !\\n%-1 'tl '\n(mo/\n(dy/\n(yr'
'sp 3
'ns
..
.de fo
'bp
..
.wh 0 hd
.wh -7 fo
\	
.sp 3
.ce 2
MATLAB Installation Guide
November, 1983
.sp 2
.ce 3
Cleve Moler
Department of Computer Science
University of New Mexico
.sp 2
.pp
The MATLAB tape is usually in one of two formats -- a UNIX "tar" tape,
or a "generic" tape with the following parameters:
   
          9 track
          1600 bits per inch
          no label
          80 characters per record
          1600 characters per block
          18 files in ASCII, followed by 18 files in EBCDIC
.pp
There are 36 files on the generic tape.  The names of the first 18, and their
approximate sizes, are:

          1.  INSTALL       1100 lines
          2.  MAT           3900 lines
          3.  LIB           3339 lines
          4.  HELPER.66       75 lines
          5.  HELPER.77      120 lines
          6.  HELP           750 lines
          7.  SYS.UNIX       900 lines
          8.  SYS.VMS        260 lines
          9.  SYS.TSO        200 lines
         10.  SYS.CMS        350 lines
         11.  SYS.DEC10      250 lines
         12.  SYS.CDC        200 lines
         13.  SYS.PRIME      350 lines
         14.  DOC           3960 lines
         15.  DEMO            21 lines
         16.  DOC.NROFF     3250 lines
         17.  MAT.SNGL      3850 lines
         18.  LIB.SNGL      3339 lines

where a line is one 80 character record.  
.pp
The first 18 files are in the ASCII character set.  
The remaining 18 files are copies of the first 18 in EBCDIC.
.pp
INSTALL is this document.  You can skip over it if you have this hard copy.
.pp
MAT, LIB, one of the versions of HELPER and one of the versions of SYS
together constitute the complete source code for the
double precision version of MATLAB.
.pp
The subroutines in MAT make up the parser and interpreter.
They include a COMMON statement which can be
changed to change the amount of memory allocated to variables.
.pp
The subroutines in LIB include modified versions of
the necessary routines from LINPACK, EISPACK and the BLAS.
These do not contain any COMMON statements and do not have to be
changed if the size of the stack is changed.
.pp
There are two versions of HELPER, the subroutine 
which manages the help facility.
The version in HELPER.66 is written in Fortran 66 and
uses sequential i/o. 
The version in HELPER.77 is written in Fortran 77 and uses
character variables and direct access i/o.  
If your system supports
both versions, you will probably want to choose the direct access one --
it should be much faster.  
If you choose the direct access version, you will have to run 
a preprocessor named HELPSET, which is also in file HELPER.77.
.pp
HELP is the source text for the help facility.  It is read by the
sequential version of HELPER, or preprocessed by HELPSET into two files which
are then read by the direct access version of HELPER.  HELP is also included as
an appendix in the User's Guide.
.pp
The subroutines in one of the versions of SYS
may have to be modified for your particular
operating system.  They involve file access and floating point word format.
I have included versions that should work on several different
operating systems.  Pick the version that is closest to your own
system and make any changes you need.
There are no machine dependent constants.
.pp
DOC is a report entitled "MATLAB Users' Guide".
It should be printed on a nice printer with upper and lower case;
there are 66 lines per page.
Make as many copies as you need, or order copies from us at New Mexico.
.pp
DEMO contains a demonstration exec file which can be accessed
by the exec command in MATLAB.  
On most systems, all that is required is
EXEC('DEMO') or EXEC('DEMO',7).
On some systems, like TSO and NOS, it will be necessary
to attach file DEMO to unit 2 and then EXEC(2) or EXEC(2,7).
.pp
DOC.NROFF is the input to the UNIX text processing system
that was used to produce DOC.  This may be useful if you want
to print the users' guide in a different format.
.pp
MAT.SNGL and LIB.SNGL are the single precision versions of MAT and LIB.
It is suggested that these be used only on systems with long words
(48 bit floating point fraction) or small memories.
.pp
The first thing to worry about is the character set.  
The use of an upper-lower case character set is highly desirable,
but not essential.
Read the tape
and look at the first 50 or so lines of MAT.  
This is the subroutine MATLAB, a listing
of which is included in this document.  
Check the comments near the beginning to see if the special characters
are ok.  The ones we have had trouble with include:
        SEMI ;   BSLASH \\   COLON :   LESS <   GREAT >
.br
Any characters which are not ok should be changed in the comment and
in the data statement which follows.  
The alternate character set includes the lower case letters as well
as substitutes for some of the special characters, such as \\ and :,
which are not on some terminals.  
Do not worry too much about the alternate character set now.
These data statements in subroutine MATLAB are the only place in the
source code where the special characters occur.
(If you want to get fancy, there is a data statement involving BEL
in subroutine ERROR near the end of file MAT.
Change 1H-blank to 1H-control G to get your terminal to ring its
bell for any error.)
.pp
The files DOC and HELP are full of special characters, including 
          <   >   [   ]   :   ;   \\   |  
.br
If they are not ok, I hope it is not too difficult to fix them up.
.pp
I have used several FORTRAN constructions which are only semi-standard,
and which may have to be changed for some systems:
  Single quote (') in FORMATS instead of a tribute to Hollerith.
  Entire arrays initialized in DATA statements.
  Use of END= in READ statements.
.br
I have not asked PFORT to tell me what else is non-standard.
.pp
Some interactive FORTRAN systems use column 1 for carriage control and
others don't.  If your system does not, edit file MAT and delete
all "1X," .  There are 131 occurrences.
.pp
The main program in file SYS simply calls MATLAB.  
It may have to be modified to control the printing of
underflow and overflow messages.
The ground rules are:  Underflows are possible, but are harmless if
they are quietly set to zero.  
Overflows are error conditions.  It would be nice to print a message
and continue.
.pp
A listing of a typical version of SYS,
using some Fortran 77 for clarity, is included in this document.
I hope it is fairly easy to see what the various subroutines
do and how they have to be revised for your system. 
Please send me copies of versions appropriate for your system.
.pp
The amount of memory required can be altered by a global text edit on MAT
which changes the matrix element stack length from
5005 to something else.  Be sure to get the statement
          VSIZE = 5005
.br
in the subroutine MATLAB.
With this setting of the stack length, MATLAB requires about a 300K byte
region on an IBM system. 
The length has to be reduced somewhat to get MATLAB to fit
into a 64K word region on a CDC system.
Since each matrix element occupies two double or single precision words,
an increase of 1000 in the stack length requires an additional
16K bytes or 2000 words.
.pp
It is possible to get by with less memory if you use overlays.
The simplest way to do this is the following.  
  
.ne 5
                   ROOT
                     |
      -------------------------------
      |     |     |     |     |     | 
     S0    S1    S2    S3    S4    S5
   
Only ROOT plus one of the segments S0 through S5 need be in
memory at any one time.  The segments do not call each other,
but return to the root.  All the relevant calls are near the end
of subroutine MATLAB in the root.  
There are five labeled COMMON blocks which are shared by the
root and all the segments.
The various segments consist of:
  
.ne 7
      ROOT:
        MAIN        MATLAB      STACK1
        PRINT       PRNTID      FUNS
        STACKP      ERROR       FILES
        HELPER      PYTHAG      FORMZ
        FLOP        PROMPT
        Plus everything in file LIB not mentioned below.
  
.ne 6
      S0:
        PARSE       COMAND      CLAUSE
        EXPR        TERM        FACTOR      
        STACKG      STACK2      GETSYM
        GETLIN      GETCH       GETVAL
        EDIT        XCHAR

.ne 4
      S1:
        MATFN1      WGECO       WGEFA
        WGESL       WGEDI       WPOFA
        RREF        HILBER
  
.ne 3
      S2:
        MATFN2      CORTH       COMQR3
        HTRIDI      HTRIBK      IMTQL2
  
.ne 2
      S3:
        MATFN3      WSVDC
  
.ne 2
      S4:
        MATFN4      WQRDC       WQRSL
  
.ne 4
      S5:
        MATFN5      MATFN6      MAGIC
        SAVLOD      RAT         USER
        PLOT
   
If you have enough room, combine ROOT and S0.
With more room, combine ROOT, S0 and S5.
If you use some overlay structure, please send me a description of
how it is done on your system.
.pp
In case anybody needs to know, here are the changes necessary
to convert from double to single precision.  They can all be
safely accomplished by simple global text changes in MAT, LIB
and an appropriate version of SYS.
  
      DOUBLE PRECISION   REAL
      DOUBLE-            REAL-
      DSQRT              SQRT
      DLOG               ALOG
      DEXP               EXP
      DSIN               SIN
      DCOS               COS
      DATAN              ATAN
      DABS               ABS
      DMAX1              AMAX1
      DMIN1              AMIN1
      IDINT              IFIX
      DSIGN              SIGN
      DMOD               AMOD
      D0                 E0
      D1                 E1
      D2                 E2
      D9                 E9
   
.pp
Here are some additional comments that apply to individual systems.
.sp 2
VAX UNIX.
.pp
If you have read the "tar" format tape, see file README and
the makefile.  Ignore the rest of this section.
.pp
It is essential to change the single backslash \\ in the data
statement near the beginning of file MAT to a double backslash \\\\.
If this is not done, the F77 compiler produces an obscure error message
about "dataalpha" being too long.  
.pp
Increase the size of the stack to take advantage of the virtual memory.  
Eliminate all the "1X," in formats.  
Change the statement
CASE = 0 in MATLAB to CASE = 1 to get lower case file names.
All these changes can be accomplished
by applying the following ed or vi commands to file MAT.
  
        1,$s/\\/\\\\/g  
        1,$s/5005/50005/g  
        1,$s/1X,/0X,/g
        1,$s/CASE = 0/CASE = 1/
        1,$s/BEL\/1H /BEL\/1H^G/
        1,$s/LCT(2) = 25/LCT(2) = 25000/
.pp
The compilation should suppress warnings about initializing non-character
variables with Hollerith and should use the Berkeley version of the
i/o support routines.  This can be accomplished with:

      % f77 -w66 mat.f lib.f helper.f sys.f -lI77uc
.pp
Gary Klimowicz and Lee Ward of UNM have developed a overflow fault handler 
for use with VAX UNIX.  A copy of their C program in included in SYS.UNIX
and on the "tar" tape.
.sp 3
VAX VMS
.pp
SYS.VMS contains an extra subroutine for proper handling of floating
point overflow.  The main program includes a call to the system
which initializes this handling.
.pp
Integer overflow is expected in the the print routine and in
random number generator.
The integer overflow messages can be turned off by
  
     FORTRAN/NOCHECK  MAT.FOR,LIB.FOR
.sp 3
IBM (TSO)
.br
(Thanks to Jack Dongarra at Argonne.)
.pp
The main program in SYS.TSO includes the appropriate calls
to the IBM system utility ERRSET that turns off verbose
underflow and overflow messages.
.pp
Unfortunately, TSO does not have a mechanism for opening
files during execution.  It is necessary to use file numbers with SAVE,
LOAD and EXEC.  
.pp
We have to specify LRECL=80 for terminal input
on unit 5 to get blanks added to input lines.  It is a good
idea to set up a clist something like the following.
  
      FREE FILE(FT05F001 FT06F001 FT09F001 FT01F001 FT02F001)
      FREE ATTRLIST(AT80)
      ATTR  AT80 LRECL(80) BLKSIZE(80) RECFM(F)
      ALLOC FILE(FT05F001) DA(*) USING(AT80)
      ALLOC FILE(FT06F001) DA(*) 
      ALLOC FILE(FT09F001) DA('MATLAB.HELP.DATA')
      ALLOC FILE(FT01F001) DA(SAVLOD.DATA)
      ALLOC FILE(FT02F001) DA('MATLAB.DEMO.DATA')
      CALL 'MATLAB.LOAD(MATMOD)'
   
With this arrangement, the DEMO file can be executed by  exec(2).
.sp 3
IBM (CMS)
.br
(Thanks to Jack Dongarra at Argonne and David Gay at MIT.)
.pp
Entering a blank line in response to the MATLAB prompt generates
an end-of-file from terminal input (Fortran unit FT05F001). 
This results in a call from GETLIN to FILES with LUNIT = -5.
The terminal is "rewound" and control eventually returned to PARSE 
which prints another prompt.  I hope this works.
.pp
An assembly language routine used to attach files with names generated
by MATLAB to Fortran unit numbers is included in SYS.CMS.
.sp 3
DEC-10
.br
(Thanks to Stan Eisenstat and Craig Douglas at Yale.)
.pp
The hyperbolic trig functions SINH and COSH are not available
on the DEC system.  Fortran subroutines are included in the SYS.DEC10 file.
.sp 3
PRIME 400
.br
(Thanks to Richard Franke and Drexel University.)
.pp
The terminal is Fortran I/O unit number 1.
Subroutine MATLAB has to be changed so that 
      RTE = 5  becomes  RTE = 1
      WTE = 6  becomes  WTE = 1
.br
Subroutine MATFN5 has to be changed so that
      WIO = 1  becomes  WIO = 8
      LUNIT = 1  becomes  LUNIT = 8  (in two places).
.sp 3
CDC
.pp
CDC systems offer exciting challenges as far as portability is concerned.
The first question is: which character set should be used?
An easy approach is to convert everything to the venerable 6-bit character set.
Even so, you may have trouble
with the colon, which is a pretty important MATLAB character.
It is far more fun to try to use upper and lower case and all
the special symbols.
I have succeeded in doing this
with the 6/12-bit setup used on the NOS system at Sandia,
but have given up with the 6/18-bit coding on LTSS at Los Alamos.
.pp
In "ASCII" mode on NOS, lower case characters are represented by
12 bits -- the first 6 bits are octal 76 and the last 6 are the
corresponding upper case character.  They count as two characters.
So, the following changes are required in file MAT.  Several of
the mixed case strings in FORMAT statements extend beyond
column 72.  You might as well convert these to all upper case.
All the 80A1's in FORMATS should be changed to 132A1's and
all the DATA statements initializing LRECL should be changed from 80 to 132.
The DATA statement for ALPHB in subroutine MATLAB can be changed to
have all upper case alphabetic characters because subroutine XCHAR
will catch the prefix octal 76.
.pp
An important change involves our friend the colon, which becomes 
a 12-bit octal 7404.  In the DATA statement for ALPHA, make the
element just before 1H+ into a 1H(percent sign).
And, in the DATA statement for ALPHB, make the corresponding element
into a 2H(colon).
Then read the comments in subroutine XCHAR in file SYS.CDC and make
sure that the DATA statements there are correct.
.pp
The FTN5 compiler should take MATLAB pretty much is it is.
The older FTN compiler requires two familiar changes to the
entire source code.  First, the END= in the READ statements have
to be replaced by IF (EOF) GO TO ... .
Second, the single quotes in FORMATS have to be replaced with
asterisks.
.sp 3
Good luck.  Please let me know what difficulties you have, and what
I have left out of this guide.  You can call me at:
         505-268-8631  (home)
         505-277-3112  (office)

------------
.pp
The support of the National Science Foundation and the use of
facilities at Argonne National Laboratory, Los Alamos National Laboratory
and Stanford Linear Accelerator Center is gratefully acknowledged.
So is the assistance of the many people who have installed early
versions of MATLAB.
.bp
.ll 80
.nf
Contents of file MAT:
   
      SUBROUTINE MATLAB(INIT)
      SUBROUTINE PARSE
      SUBROUTINE COMAND(ID)
      SUBROUTINE CLAUSE
      SUBROUTINE EXPR
      SUBROUTINE TERM
      SUBROUTINE FACTOR
      SUBROUTINE FUNS(ID)
      SUBROUTINE STACKP(ID)
      SUBROUTINE STACKG(ID)
      SUBROUTINE STACK1(OP)
      SUBROUTINE STACK2(OP)
      SUBROUTINE PRINT(ID,K)
      SUBROUTINE PRNTID(ID,ARGCNT)
      SUBROUTINE GETSYM
      SUBROUTINE GETLIN
      SUBROUTINE GETCH
      SUBROUTINE GETVAL(S)
      SUBROUTINE MATFN1
      SUBROUTINE MATFN2
      SUBROUTINE MATFN3
      SUBROUTINE MATFN4
      SUBROUTINE MATFN5
      SUBROUTINE MATFN6
      SUBROUTINE ERROR(N)
      DOUBLE PRECISION FUNCTION PYTHAG(A,B)
      SUBROUTINE RAT(X,LEN,MAXD,D)

Contents of file HELPER.66:

      SUBROUTINE HELPER(H) -- Sequential version
  
Contents of file HELPER.77:

      PROGRAM HLPSET       -- Direct access setup
      SUBROUTINE HELPER(H) -- Direct access version
  
Contents of file SYS:
  
      PROGRAM MAIN
      SUBROUTINE FILES(LUNIT,NAME)
      SUBROUTINE SAVLOD(LUNIT,ID,M,N,IMG,JOB,XREAL,XIMAG)
      SUBROUTINE FORMZ(LUNIT,X,Y)
      DOUBLE PRECISION FUNCTION FLOP(X)
      SUBROUTINE XCHAR(BUF,K)
      SUBROUTINE USER(A,M,N,S,T)
      SUBROUTINE PROMPT(PAUSE)
      SUBROUTINE PLOT(LUNIT,X,Y,N,P,K,BUF)
      SUBROUTINE EDIT(BUF,N)
.bp
Contents of file LIB:
   
      SUBROUTINE WGECO(AR,AI,LDA,N,IPVT,RCOND,ZR,ZI)
      SUBROUTINE WGEFA(AR,AI,LDA,N,IPVT,INFO)
      SUBROUTINE WGESL(AR,AI,LDA,N,IPVT,BR,BI,JOB)
      SUBROUTINE WGEDI(AR,AI,LDA,N,IPVT,DETR,DETI,WORKR,WORKI,JOB)
      SUBROUTINE WPOFA(AR,AI,LDA,N,INFO)
      SUBROUTINE RREF(AR,AI,LDA,M,N,EPS)
      SUBROUTINE HILBER(A,LDA,N)
      SUBROUTINE HTRIDI(NM,N,AR,AI,D,E,E2,TAU)
      SUBROUTINE HTRIBK(NM,N,AR,AI,TAU,M,ZR,ZI)
      SUBROUTINE IMTQL2(NM,N,D,E,Z,IERR,JOB)
      SUBROUTINE CORTH(NM,N,LOW,IGH,AR,AI,ORTR,ORTI)
      SUBROUTINE COMQR3(NM,N,LOW,IGH,ORTR,ORTI,HR,HI,WR,WI,ZR,ZI,IERR
      SUBROUTINE WSVDC(XR,XI,LDX,N,P,SR,SI,ER,EI,UR,UI,LDU,VR,VI,LDV,
      SUBROUTINE WQRDC(XR,XI,LDX,N,P,QRAUXR,QRAUXI,JPVT,WORKR,WORKI,
      SUBROUTINE WQRSL(XR,XI,LDX,N,K,QRAUXR,QRAUXI,YR,YI,QYR,QYI,QTYR,
      SUBROUTINE MAGIC(A,LDA,N)
      SUBROUTINE BASE(X,B,EPS,S,N)
      DOUBLE PRECISION FUNCTION URAND(IY)
      SUBROUTINE WMUL(AR,AI,BR,BI,CR,CI)
      SUBROUTINE WDIV(AR,AI,BR,BI,CR,CI)
      SUBROUTINE WSIGN(XR,XI,YR,YI,ZR,ZI)
      SUBROUTINE WSQRT(XR,XI,YR,YI)
      SUBROUTINE WLOG(XR,XI,YR,YI)
      SUBROUTINE WATAN(XR,XI,YR,YI)
      DOUBLE PRECISION FUNCTION WNRM2(N,XR,XI,INCX)
      DOUBLE PRECISION FUNCTION WASUM(N,XR,XI,INCX)
      INTEGER FUNCTION IWAMAX(N,XR,XI,INCX)
      SUBROUTINE WRSCAL(N,S,XR,XI,INCX)
      SUBROUTINE WSCAL(N,SR,SI,XR,XI,INCX)
      SUBROUTINE WAXPY(N,SR,SI,XR,XI,INCX,YR,YI,INCY)
      DOUBLE PRECISION FUNCTION WDOTUR(N,XR,XI,INCX,YR,YI,INCY)
      DOUBLE PRECISION FUNCTION WDOTUI(N,XR,XI,INCX,YR,YI,INCY)
      DOUBLE PRECISION FUNCTION WDOTCR(N,XR,XI,INCX,YR,YI,INCY)
      DOUBLE PRECISION FUNCTION WDOTCI(N,XR,XI,INCX,YR,YI,INCY)
      SUBROUTINE WCOPY(N,XR,XI,INCX,YR,YI,INCY)
      SUBROUTINE WSET(N,XR,XI,YR,YI,INCY)
      SUBROUTINE WSWAP(N,XR,XI,INCX,YR,YI,INCY)
      SUBROUTINE RSET(N,DX,DY,INCY)
      SUBROUTINE RSWAP(N,X,INCX,Y,INCY)
      SUBROUTINE RROT(N,DX,INCX,DY,INCY,C,S)
      SUBROUTINE RROTG(DA,DB,C,S)
      LOGICAL FUNCTION EQID(X,Y)
      SUBROUTINE PUTID(X,Y)
      DOUBLE PRECISION FUNCTION ROUND(X)
.bp
First subroutine in file MAT:
  
      SUBROUTINE MATLAB(INIT)
C     INIT = 0 FOR ORDINARY FIRST ENTRY 
C          = POSITIVE FOR SUBSEQUENT ENTRIES
C          = NEGATIVE FOR SILENT INITIALIZATION (SEE MATZ)
C
      DOUBLE PRECISION STKR(5005),STKI(5005)
      INTEGER IDSTK(4,48),LSTK(48),MSTK(48),NSTK(48),VSIZE,LSIZE,BOT,TOP
      INTEGER ALFA(52),ALFB(52),ALFL,CASE
      INTEGER IDS(4,32),PSTK(32),RSTK(32),PSIZE,PT,PTZ
      INTEGER DDT,ERR,FMT,LCT(4),LIN(1024),LPT(6),RIO,WIO,RTE,WTE,HIO
      INTEGER SYM,SYN(4),BUF(256),CHAR,FLP(2),FIN,FUN,LHS,RHS,RAN(2)
      COMMON /VSTK/ STKR,STKI,IDSTK,LSTK,MSTK,NSTK,VSIZE,LSIZE,BOT,TOP
      COMMON /ALFS/ ALFA,ALFB,ALFL,CASE
      COMMON /RECU/ IDS,PSTK,RSTK,PSIZE,PT,PTZ
      COMMON /IOP/ DDT,ERR,FMT,LCT,LIN,LPT,RIO,WIO,RTE,WTE,HIO
      COMMON /COM/ SYM,SYN,BUF,CHAR,FLP,FIN,FUN,LHS,RHS,RAN
C
      DOUBLE PRECISION S,T
      INTEGER EPS(4),FLOPS(4),EYE(4),RAND(4)
C
C     CHARACTER SET
C            0       10       20       30       40       50
C
C     0      0        A        K        U   COLON  :  LESS   <
C     1      1        B        L        V   PLUS   +  GREAT  >
C     2      2        C        M        W   MINUS  -
C     3      3        D        N        X   STAR   *
C     4      4        E        O        Y   SLASH  /
C     5      5        F        P        Z   BSLASH \\
C     6      6        G        Q  BLANK     EQUAL  =
C     7      7        H        R  LPAREN (  DOT    .
C     8      8        I        S  RPAREN )  COMMA  ,
C     9      9        J        T  SEMI   ;  QUOTE  '
C
      INTEGER ALPHA(52),ALPHB(52)
      DATA ALPHA /1H0,1H1,1H2,1H3,1H4,1H5,1H6,1H7,1H8,1H9,
     $    1HA,1HB,1HC,1HD,1HE,1HF,1HG,1HH,1HI,1HJ,
     $    1HK,1HL,1HM,1HN,1HO,1HP,1HQ,1HR,1HS,1HT,
     $    1HU,1HV,1HW,1HX,1HY,1HZ,1H ,1H(,1H),1H;,
     $    1H:,1H+,1H-,1H*,1H/,1H\\,1H=,1H.,1H,,1H',
     $    1H<,1H>/
C
C     ALTERNATE CHARACTER SET
C
      DATA ALPHB /1H0,1H1,1H2,1H3,1H4,1H5,1H6,1H7,1H8,1H9,
     $    1Ha,1Hb,1Hc,1Hd,1He,1Hf,1Hg,1Hh,1Hi,1Hj,
     $    1Hk,1Hl,1Hm,1Hn,1Ho,1Hp,1Hq,1Hr,1Hs,1Ht,
     $    1Hu,1Hv,1Hw,1Hx,1Hy,1Hz,1H ,1H(,1H),1H;,
     $    1H|,1H+,1H-,1H*,1H/,1H$,1H=,1H.,1H,,1H",
     $    1H[,1H]/
C
      DATA EPS/14,25,28,36/,FLOPS/15,21,24,25/
      DATA EYE/14,34,14,36/,RAND/27,10,23,13/
C
      IF (INIT .GT. 0) GO TO 90
C
C     RTE = UNIT NUMBER FOR TERMINAL INPUT
C     WTE = UNIT NUMBER FOR TERMINAL OUTPUT
C     HIO = UNIT NUMBER FOR HELP FILE
      RTE = 5
      WTE = 6
      HIO = 9
C
      IF (INIT .GE. 0) WRITE(WTE,100)
  100 FORMAT(//1X,'     < M A T L A B >'
     $  /1X,'   Version of --/--/--')
C
C     ASK HELPER TO OPEN HELP FILE
      BUF(1) = 0
      CALL HELPER(BUF)
C
C     RANDOM NUMBER SEED
      RAN(1) = 0
C
C     INITIAL LINE LIMIT
      LCT(2) = 25
C
      ALFL = 52
      CASE = 1
C     CASE = 1 for file names in lower case
      DO 20 I = 1, ALFL
         ALFA(I) = ALPHA(I)
         ALFB(I) = ALPHB(I)
   20 CONTINUE
C
      VSIZE = 50005
      LSIZE = 48
      PSIZE = 32
      BOT = LSIZE-3
      CALL WSET(5,0.0D0,0.0D0,STKR(VSIZE-4),STKI(VSIZE-4),1)
      CALL PUTID(IDSTK(1,LSIZE-3),EPS)
      LSTK(LSIZE-3) = VSIZE-4
      MSTK(LSIZE-3) = 1
      NSTK(LSIZE-3) = 1
      S = 1.0D0
   30 S = S/2.0D0
      T = 1.0D0 + S
      IF (T .GT. 1.0D0) GO TO 30
      STKR(VSIZE-4) = 2.0D0*S
      CALL PUTID(IDSTK(1,LSIZE-2),FLOPS)
      LSTK(LSIZE-2) = VSIZE-3
      MSTK(LSIZE-2) = 1
      NSTK(LSIZE-2) = 2
      CALL PUTID(IDSTK(1,LSIZE-1), EYE)
      LSTK(LSIZE-1) = VSIZE-1
      MSTK(LSIZE-1) = -1
      NSTK(LSIZE-1) = -1
      STKR(VSIZE-1) = 1.0D0
      CALL PUTID(IDSTK(1,LSIZE), RAND)
      LSTK(LSIZE) = VSIZE
      MSTK(LSIZE) = 1
      NSTK(LSIZE) = 1
      FMT = 1
      FLP(1) = 0
      FLP(2) = 0
      DDT = 0
      RAN(2) = 0
      PTZ = 0
      PT = PTZ
      ERR = 0
      RIO = RTE
      WIO = 0
      IF (INIT .LT. 0) RETURN
C
   90 CALL PARSE
      IF (FUN .EQ. 1) CALL MATFN1
      IF (FUN .EQ. 2) CALL MATFN2
      IF (FUN .EQ. 3) CALL MATFN3
      IF (FUN .EQ. 4) CALL MATFN4
      IF (FUN .EQ. 5) CALL MATFN5
      IF (FUN .EQ. 6) CALL MATFN6
      IF (FUN .EQ. 21) CALL MATFN1
      IF (FUN .NE. 99) GO TO 90
      RETURN
      END
.bp
Typical file SYS (Nonstandard stuff in lower case):
   
C     PROGRAM MAIN
      call overflow-control
      CALL MATLAB(0)
      STOP
      END


      SUBROUTINE FILES(LUNIT,NAME)
      INTEGER LUNIT,NAME(32)
C
C     SYSTEM DEPENDENT ROUTINE TO ALLOCATE FILES
C     LUNIT = LOGICAL UNIT NUMBER
C     NAME = FILE NAME, 1 CHARACTER PER WORD
C
      character*32 nam
c
c     close exec, save, load and print files
      if (lunit .lt. 0) then
         close(unit=-lunit)
         return
      end if
c
c     Fortran 77 internal file conversion from 32a1 to character*32
      write(nam,'(32a1)') name
c     
c     formatted i/o for exec and print
      if (lunit .gt. 2) open(unit=lunit,file=nam)
c
c     unformatted i/o for save and load
      if (lunit .le. 2) open(unit=lunit,file=nam,form='unformatted')
c
c     rewind all except diary
      if (lunit .ne. 8) rewind lunit
c
      RETURN
      END


      SUBROUTINE SAVLOD(LUNIT,ID,M,N,IMG,JOB,XREAL,XIMAG)
      INTEGER LUNIT,ID(4),M,N,IMG,JOB
      DOUBLE PRECISION XREAL(1),XIMAG(1)
C
C     IMPLEMENT SAVE AND LOAD
C     LUNIT = LOGICAL UNIT NUMBER
C     ID = NAME, FORMAT 4A1
C     M, N = DIMENSIONS
C     IMG = NONZERO IF XIMAG IS NONZERO
C     JOB = 0     FOR SAVE
C         = SPACE AVAILABLE FOR LOAD
C     XREAL, XIMAG = REAL AND OPTIONAL IMAGINARY PARTS
C
C     THIS VERSION USES UNFORMATTED READ AND WRITE
C
      IF (JOB .GT. 0) GO TO 20
C
C     SAVE
   10 WRITE(LUNIT) ID,M,N,IMG
      DO 15 J = 1, N
         K = (J-1)*M+1
         L = J*M
         WRITE(LUNIT) (XREAL(I),I=K,L) 
         IF (IMG .NE. 0) WRITE(LUNIT) (XIMAG(I),I=K,L)
   15 CONTINUE
      RETURN
C
C     LOAD
   20 READ(LUNIT,END=30) ID,M,N,IMG
      IF (M*N .GT. JOB) GO TO 30
      DO 25 J = 1, N
         K = (J-1)*M+1
         L = J*M
         READ(LUNIT,END=30) (XREAL(I),I=K,L)
         IF (IMG .NE. 0) READ(LUNIT,END=30) (XIMAG(I),I=K,L)
   25 CONTINUE
      RETURN
C
C     END OF FILE
   30 M = 0
      N = 0
      RETURN
      END


      SUBROUTINE FORMZ(LUNIT,X,Y)
      DOUBLE PRECISION X,Y
C
C     SYSTEM DEPENDENT ROUTINE TO PRINT WITH Z FORMAT
C
      IF (Y .NE. 0.0D0) WRITE(LUNIT,10) X,Y
      IF (Y .EQ. 0.0D0) WRITE(LUNIT,10) X
   10 format(2z18)
      RETURN
      END


      DOUBLE PRECISION FUNCTION FLOP(X)
      DOUBLE PRECISION X
C     SYSTEM DEPENDENT FUNCTION
C     COUNT AND POSSIBLY CHOP EACH FLOATING POINT OPERATION
C     FLP(1) IS FLOP COUNTER
C     FLP(2) IS NUMBER OF PLACES TO BE CHOPPED
C
      INTEGER SYM,SYN(4),BUF(256),CHAR,FLP(2),FIN,FUN,LHS,RHS,RAN(2)
      COMMON /COM/ SYM,SYN,BUF,CHAR,FLP,FIN,FUN,LHS,RHS,RAN
C
      double precision mask(14),xx,mm
      real mas(2,14)
      logical lx(2),lm(2)
      equivalence (lx(1),xx),(lm(1),mm)
      equivalence (mask(1),mas(1))
      data mas/
     $ z'ffffffff',z'fff0ffff',
     $ z'ffffffff',z'ff00ffff',
     $ z'ffffffff',z'f000ffff',
     $ z'ffffffff',z'0000ffff',
     $ z'ffffffff',z'0000fff0',
     $ z'ffffffff',z'0000ff00',
     $ z'ffffffff',z'0000f000',
     $ z'ffffffff',z'00000000',
     $ z'fff0ffff',z'00000000',
     $ z'ff00ffff',z'00000000',
     $ z'f000ffff',z'00000000',
     $ z'0000ffff',z'00000000',
     $ z'0000fff0',z'00000000',
     $ z'0000ff80',z'00000000'/
C
      FLP(1) = FLP(1) + 1
      K = FLP(2)
      FLOP = X
      IF (K .LE. 0) RETURN
      FLOP = 0.0D0
      IF (K .GE. 15) RETURN
      XX = X
      MM = MASK(K)
      LX(1) = and(LX(1),LM(1))
      LX(2) = and(LX(2),LM(2))
      FLOP = XX
      RETURN
      END


      SUBROUTINE XCHAR(BUF,K)
      INTEGER BUF(1),K
C
C     SYSTEM DEPENDENT ROUTINE TO HANDLE SPECIAL CHARACTERS
C
      INTEGER DDT,ERR,FMT,LCT(4),LIN(1024),LPT(6),RIO,WIO,RTE,WTE
      COMMON /IOP/ DDT,ERR,FMT,LCT,LIN,LPT,RIO,WIO,RTE,WTE
      write(WTE,10) buf(1)
   10 format(A1,' is not a MATLAB character.')
      RETURN
      END


      SUBROUTINE USER(A,M,N,S,T)
      DOUBLE PRECISION A(M,N),S,T
C
      INTEGER A3(9)
      DATA A3 /-149,537,-27,-50,180,-9,-154,546,-25/
      IF (A(1,1) .NE. 3.0D0) RETURN
      DO 10 I = 1, 9
         A(I,1) = A3(I)
   10 CONTINUE
      M = 3
      N = 3
      RETURN
      END


      SUBROUTINE PROMPT(PAUSE)
      INTEGER PAUSE
C
C     ISSUE MATLAB PROMPT WITH OPTIONAL PAUSE
C
      INTEGER DDT,ERR,FMT,LCT(4),LIN(1024),LPT(6),RIO,WIO,RTE,WTE
      COMMON /IOP/ DDT,ERR,FMT,LCT,LIN,LPT,RIO,WIO,RTE,WTE
      WRITE(WTE,10)
      IF (WIO .NE. 0) WRITE(WIO,10)
   10 FORMAT(1X,/'<>')
      IF (PAUSE .EQ. 1) READ(RTE,20) DUMMY
   20 FORMAT(A1)
      RETURN
      END


      SUBROUTINE PLOT(LUNIT,X,Y,N,P,K,BUF)
      DOUBLE PRECISION X(N),Y(N),P(1)
      INTEGER BUF(79)
C
C     PLOT X VS. Y ON LUNIT
C     IF K IS NONZERO, THEN P(1),...,P(K) ARE EXTRA PARAMETERS
C     BUF IS WORK SPACE
C
      DOUBLE PRECISION XMIN,YMIN,XMAX,YMAX,DY,DX,Y1,Y0
      INTEGER AST,BLANK,H,W
      DATA AST/1H*/,BLANK/1H /,H/20/,W/79/
C
C     H = HEIGHT, W = WIDTH
C
      XMIN = X(1)
      XMAX = X(1)
      YMIN = Y(1)
      YMAX = Y(1)
      DO 10 I = 1, N
         XMIN = DMIN1(XMIN,X(I))
         XMAX = DMAX1(XMAX,X(I))
         YMIN = DMIN1(YMIN,Y(I))
         YMAX = DMAX1(YMAX,Y(I))
   10 CONTINUE
      DX = XMAX - XMIN
      IF (DX .EQ. 0.0D0) DX = 1.0D0
      DY = YMAX - YMIN
      WRITE(LUNIT,35)
      DO 40 L = 1, H
         DO 20 J = 1, W
            BUF(J) = BLANK
   20    CONTINUE
         Y1 = YMIN + (H-L+1)*DY/H
         Y0 = YMIN + (H-L)*DY/H
         JMAX = 1
         DO 30 I = 1, N
            IF (Y(I) .GT. Y1) GO TO 30
            IF (L.NE.H .AND. Y(I).LE.Y0) GO TO 30
            J = 1 + (W-1)*(X(I) - XMIN)/DX
            BUF(J) = AST
            JMAX = MAX0(JMAX,J)
   30    CONTINUE
         WRITE(LUNIT,35) (BUF(J),J=1,JMAX)
   35    FORMAT(1X,79A1)
   40 CONTINUE
      RETURN
      END


      SUBROUTINE EDIT(BUF,N)
      INTEGER BUF(N)
C
C     CALLED AFTER INPUT OF A SINGLE BACKSLASH
C     BUF CONTAINS PREVIOUS INPUT LINE, ONE CHAR PER WORD
C     ENTER LOCAL EDITOR IF POSSIBLE
C
      character*256 s
      open(7,file='----')
      write(7,10) (buf(i),i=1,n)
   10 format(256a1)
      close(7)
      call system('edit  ----')
      open(7,file='----')
      rewind 7
      read(7,'(a)') s
      close(7)
      call system('remove ----')
      n = 0
      do 20 i = 1, 256
         if (s(i:i) .ne. ' ') n = i
   20 continue
      read(s,10) (buf(i),i=1,n)
      RETURN
      END