MIMIC is a further development from MIDAS (Modified Integration Digital Analog Simulator), which represented analog computer design. Written completely in FORTRAN but one routine in COMPASS, and ran on Control Datasupercomputers, MIMIC is capable of solving much larger simulation models.
The MIMIC software package, written as FORTRAN overlay programs, executes input statements of the mathematical model in six consecutive passes. Simulation programs written in MIMIC are compiled rather than interpreted. The core of the simulation package is a variable step numerical integrator of fourth-order Runge-Kutta method. Many useful functions related to electrical circuit elements exist besides some mathematical functions found in most scientific programming languages. There is no need to sort the statements in order of dependencies of the variables, since MIMIC does it internally.
Parts of the software organized in overlays are:
MIMIN (input)– reads in user simulation program and data,
MIMCO (compiler) – compiles the user program and creates an in-core array of instructions,
MIMSO (sort)– sorts the instructions array after dependencies of variables,
MIMEX (execute)– executes the user program by integrating,
MIMOUT (output)– puts out the data as a list or diagram of data.
Example
Problem
Consider a predator-prey model from the field of marine biology to determine the dynamics of fish and shark populations. As a simple model, we choose the Lotka–Volterra equation and the constants given in a tutorial.[2]
If
f(t): Fish population over time (fish)
s(t): Shark population over time (sharks)
df / dt or : growth rate of fish population (fish/year)
ds / dt or : growth rate of shark population (sharks/year)
: growth rate of fish in the absence of sharks (1/year)
: death rate per encounter of fish with sharks (1/sharks and year).
: death rate of sharks in the absence of their prey, fish (1/year)
: efficiency of turning predated fish into sharks (sharks/fish)
then
with initial conditions
The problem's constants are given as:
= 600 fish
= 50 sharks
= 0.7 fish/year
= 0.007 fish/shark and year
= 0.5 shark/year
= 0.1 shark/fish
tmax = 50 year
Code sample
Card columns
0 1 2 3 4 5 6 7
12345678901234567890123456789012345678901234567890123456789012345678901
-----------------------------------------------------------------------
* A SIMPLE PREDATOR-PREY MODEL FROM MARINE BIOLOGY
/ (TUTORIAL 2: NUMERICAL SOLUTION OF ODE'S - 19/08/02)
/ ENVIRONMENTAL FLUID MECHANICS LAB
/ DEPT OF CIVIL AND ENVIRONMENTAL ENGINEERİNG
/ STANFORD UNIVERSITY
*
* LOTKA–VOLTERRA EQUATION
CON(F0,S0,TMAX)
CON(ALPHA,BETA,GAMMA,EPS)
1DF = ALPHA*F-BETA*F*S
F = INT(1DF,F0)
1DS = EPS*BETA*F*S-GAMMA*S
S = INT(1DS,S0)
HDR(TIME,FISH,SHARK)
OUT(T,F,S)
PLO(F,S)
FIN(T,TMAX)
END
<EOR>
600. 50. 50.
0.7 0.007 0.5 0.1
<EOF>
^"Tutorial 2: Numerical Solutions of ODE's"(PDF). Stanford University-Dept of Civil and Environmental Engineering, Environmental Fluid Mechanics Lab. 2002-08-19. Archived from the original(PDF) on 2010-07-20. Retrieved 2012-02-26.
Notes
Control Data MIMIC; A Digital Simulation Language, Reference Manual, Publication Number 4461n400, Control Data Corporation, Special Systems Publications, St. Paul, Minnesota (April 1968)
MIMIC, An Alternative Programming Language for Industrial Dynamics, N.D. Peterson, Socio-Econ Plan Sci. 6, Pergamon 1972