This is a collection of M scripts for learning purposes. The examples in this tutorial are run with GT.M. https://www.isharkfly.com/tag/mumps
Go to file
programarivm 6cd92a6313 cleanup 2019-09-26 15:18:37 +01:00
01-the-very-basics cleanup 2019-09-26 10:40:39 +01:00
02-user-defined-functions FactorialByValue.m is been shortened 2019-09-26 10:43:20 +01:00
03-routines M routines are added 2019-09-26 15:04:21 +01:00
04-databases cleanup 2019-09-26 15:18:37 +01:00
.editorconfig .editorconfig is added 2019-09-23 17:04:03 +01:00
README.md cleanup 2019-09-26 15:18:37 +01:00

README.md

MUMPS Examples

MUMPS ("Massachusetts General Hospital Utility Multi-Programming System"), or M, is a general-purpose computer programming language originally designed in 1966 for the healthcare industry. Its differentiating feature is its "built-in" database, enabling high-level access to disk storage using simple symbolic program variables and subscripted arrays; similar to the variables used by most languages to access main memory. Read more...

The implementations currently available are:

The examples in this tutorial are run with both GPL Mumps and GT.M.

Prerequisites

GPL Mumps

GT.M

Additional Documentation


Quick Setup

GPL Mumps

To install the open source distribution of the Mumps interpreter:

cd /usr/local/src
wget https://www.cs.uni.edu/~okane/source/MUMPS-MDH/mumps-18.02.src.tar.gz
tar -zxvf mumps-18.02.src.tar.gz
cd mumpsc
./ConfigureNative.script
./BuildMumpsWithGlobalsInSingleUserNative.script

The resulting interpreter is located in /usr/bin/mumps.

mumps

Mumps 17.30; Built: 16:05:53 Sep 23 2019
Float: double; DBMS: Native Stand Alone; Hardware math: yes; Int: int; Float digits: 6; Cache: 33; Block: 2048; FP Bits: N/A
http://threadsafebooks.com/
Enter HALT to exit

> write "Hello world"
Hello world
> halt
EOF - goodbye ...

To uninstall GPL Mumps:

cd /usr/local/src/mumpsc
make uninstall
rm -f /usr/bin/mumps*

GT.M

To install GT.M on Debian based OS:

apt-get install fis-gtm

Set up the environment variables:

source /usr/lib/x86_64-linux-gnu/fis-gtm/V6.3-003A_x86_64/gtmprofile

Open the GT.M prompt:

gtm

GTM>write "Hello world"
Hello world
GTM>halt

To uninstall GT.M:

apt-get purge fis-gtm

Run the Examples

GPL Mumps

Use the Open Mumps interpreter:

mumps HelloWorld.m

GT.M

Copy the examples into your ~/.fis-gtm/V6.3-003A_x86_64/r folder and run:

mumps -run ^HelloWorld

1. The Very Basics

HelloWorld.m

Hello world

HelloWorldInLoop.m

Hello world
Hello world
Hello world
Hello world
Hello world
Hello world
Hello world
Hello world
Hello world
Hello world

HelloWorldInAnotherLoop.m

Hello world
Hello world
Hello world
Hello world
Hello world
Hello world
Hello world
Hello world
Hello world
Hello world

HelloWorldInNestedLoop.m

1:1 Hello world
1:2 Hello world
1:3 Hello world
1:4 Hello world
1:5 Hello world
2:1 Hello world
2:2 Hello world
2:3 Hello world
2:4 Hello world
2:5 Hello world

ArithmeticOperations.m

There were 7 apples, 8 pears and 9 oranges,
a total of 24 fruits in a basket.
Then, something happened:
1 apple, 2 pears and 0 oranges were eaten!
Now there are 21 fruits in the basket,
the average fruit value is 7.

Arrays.m

Approaching the solar system:
Mercury
Venus
Earth
Mars
Jupiter
Saturn
Uranus
Neptune
Pluto

September 2019:
26 27 28 29 30 31 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 1 2 3 4 5 6

Genealogical tree:
Harry and Emily had Jack

Associative array:
Have you ever been to London?

ArraysShortened.m

The output obtained is the same as that in Arrays.m

2. User Defined Functions

FactorialByReference.m

Enter n: 5
5! = 120

FactorialByValue.m

Enter n: 5
5! = 120

Fibonacci.m

Enter n: 9
F(9) = 34

3. Routines

Main.m

Hello!
Enter n: 9

areaCircle(9) = 254.469
fibonacci(9) = 34
factorialByVal(9) = 362880
factorialByRef(9) = 362880

For further details also visit MyMath.m

4. Databases

GenealogicalTree.m

Genealogical tree:
^gtree(0,1,1) is Jessica
$data(^gtree(0,2)) is 0
$data(^gtree(0,1,1,1)) is 1
$data(^gtree(0,0,0,0,0)) is 10
$data(^gtree(0)) is 11

Removing tree...
$data(^gtree(0,2)) is 0
$data(^gtree(0,1,1,1)) is 0
$data(^gtree(0,0,0,0,0)) is 0
$data(^gtree(0)) is 0

Contributions

Would you help make this tutorial better? Contributions are welcome.

Many thanks.