World Library  
Flag as Inappropriate
Email this Article

Dartmouth BASIC

Article Id: WHEBN0000516845
Reproduction Date:

Title: Dartmouth BASIC  
Author: World Heritage Encyclopedia
Language: English
Subject: Dartmouth Time Sharing System, BASIC, GW-BASIC, Tiny BASIC, MECC
Collection: Basic Compilers, Dartmouth College History, Discontinued Basics, Programming Languages Created in 1964
Publisher: World Heritage Encyclopedia
Publication
Date:
 

Dartmouth BASIC

Dartmouth BASIC
Paradigm imperative
Designed by John Kemeny, Thomas Kurtz
First appeared 1964 (1964)
OS Dartmouth Time Sharing System
Influenced by
FORTRAN, ALGOL
Influenced
Cf. list of BASIC dialects

Dartmouth BASIC is the original version of the John Kemeny and Thomas Kurtz as part of the Dartmouth Time Sharing System (DTSS) and was one of the first programming languages intended to be used interactively.

Several versions were produced at Dartmouth over the years, all implemented as compile and go compilers, unlike many of the versions of the language implemented elsewhere, which were interpreters. The first compiler was produced before the time-sharing system was ready. Known as CardBASIC, it was intended for the standard card-reader based batch processing system. Like all the following versions, it was implemented by a team of undergraduate programmers working under the direction of Kemeny and Kurtz. The first interactive version was made available to general users in June 1964; the second in October, 1964; the third in 1966; the fourth in 1969; the fifth in 1970; the sixth in 1971; and the seventh in 1979.

Contents

  • Development history 1
  • User interface 2
    • List of commands 2.1
  • Keywords 3
    • List of BASIC statements 3.1
    • List of operators 3.2
    • List of functions 3.3
  • References 4
  • Bibliography 5
  • External links 6

Development history

Work on the compiler and the operating system was done concurrently, and so the first BASIC programs were run in batch mode as part of the development process during early 1964. However on May 1, 1964 at 4 a.m. ET, John Kemeny and John McGeachie ran the first BASIC programs to be executed successfully from terminals by the DTSS system.[1] It is not completely clear what the first programs were. However, the programs either consisted of the single line:

PRINT 2 + 2

or were implementations of the Sieve of Eratosthenes, according to a 1974 interview in which Kemeny and McGeachie took part.

The second version of BASIC only made minimal changes, adding the semicolon operator to the PRINT statement and zero subscripts to arrays.

For the third version, the INPUT statement was introduced along with the powerful MAT statements for matrix manipulation and the RESTORE statement for use with READ/DATA. Development continued with the introduction of text manipulation and variables, also known as string variables, for version 4 and true file handling in version 5; this is the version from which most later BASIC dialects descend.

Version 6 saw the introduction of separately compilable procedures with parameters. In 1976, Steve Garland added structured programming features to create Dartmouth SBASIC, a precompiler which produced version 6 output (and which formed the basis of ANSI BASIC). In 1979 Kemeny and Kurtz released an ANSI BASIC compiler as the seventh and final version of BASIC at Dartmouth before leaving the college to concentrate on the further development of ANSI BASIC in the form of True BASIC.

The early versions of BASIC were used and tested by other Dartmouth students working in the College Psychology labs in early 1964. The departments shared several IBM card punch machines that were used to run batch statistical analysis programs.

Students working on NSF grants in both departments lived in the same rural New Hampshire farmhouse during the summer of 1964. They often met to share ideas. A notable contribution of these late night sessions was the GOTO statement. The earliest printed versions of the users' manual were mimeographed (with the typical purple print of Ditto machines of the era) and had a pink cover.

Dr. Kemeny, an immigrant from Hungary and chairman of the Mathematics department at the time, eventually went on to serve with great distinction as president of the college. Mr. McGeachie, an undergraduate at the time, was called "Geach" by his friends and colleagues.

User interface

DTSS implemented an early integrated development environment (IDE): an interactive command line interface. There was no need to log out. If users did not respond, they were logged out after a short delay.

Any line typed in by the user, and beginning with a line number, was added to the program, replacing any previously stored line with the same number; anything else was assumed to be a DTSS command and immediately executed. Lines which consisted solely of a line number weren't stored but did remove any previously stored line with the same number. This method of editing was necessary due to use of teleprinters as the terminal units for the Dartmouth Timesharing system.

List of commands

  • HELLO — log into DTSS
  • BYE — log off from DTSS
  • BASIC — start BASIC mode
  • NEW — name and begin writing a program
  • OLD — retrieve a previously named program from permanent storage
  • LIST — display the current program
  • SAVE — save the current program in permanent storage
  • UNSAVE — clear the current program from permanent storage
  • CATALOG — display the names of programs in permanent storage
  • SCRATCH — erase the current program without clearing its name
  • RENAME — change the name of the current program without erasing it
  • RUN — execute the current programs
  • STOP — interrupt the currently running program
  • FRI — Friden mode for teletypes with mechanical linefeeds
  • NFR — exit Friden mode
  • EXP — explain (help) EXP EXP for list of commands that can be explained by the system
  • REPLACE — save the current program using a name already in use for another file

The commands were often believed to be part of the BASIC language by users, but, in fact, were part of the time sharing system and were also used when preparing ALGOL or FORTRAN programs via the DTSS terminals.

Keywords

The first interactive version implemented the following statement types, taking some of its operators and keywords from FORTRAN II and some from ALGOL 60.

List of BASIC statements

  • DEF — define single line functions
  • DIM — (short for dimension) define the size of arrays
  • END — define the end of the program
  • STOP — stop a program before the textual end
  • FOR / TO / STEP — define loops
  • NEXT — mark the end of loops
  • GOSUB — transfer control to simple subroutines
  • RETURN — return control from simple subroutines
  • GOTO — transfer control to another statement
  • IF / THEN — decision making
  • LET / = — assign formula results to a variable
  • PRINT — output results
  • DATA — store static data within the program
  • READ — input data stored in DATA statements
  • REM — comment

It also implemented floating-point numeric variables and arithmetic. Variable names were limited to A to Z, A0 to A9, B0 to B9, ..., Z0 to Z9, giving a maximum of 286 possible distinct variables. Array names were restricted to A to Z only. Arrays did not need to be defined, but in the absence of a DIM statement they defaulted to 10 elements, subscripted from 1 to 10.

List of operators

Arithmetic operators Relational/logical operators
- Negation (unary op.) = Equal To
+ Addition <> Not Equal To
- Subtraction (binary op.) < Less Than
* Multiplication <= Less Than or Equal To
/ Division > Greater Than
Exponentiation => Greater Than or Equal To
Grouping operator
( ) Grouping

List of functions

  • ABS -- Absolute value
  • ATN -- Arctangent value (result in radians)
  • COS -- Cosine value (argument in radians)
  • EXP -- Exponential value
  • INT -- Integer value
  • LOG -- Natural Logarithmic value
  • RND -- Random value
  • SIN -- Sine value (argument in radians)
  • SQR -- Square root value
  • TAN -- Tangent value (argument in radians)

References

  1. ^ Author unknown (2007-08-08). Dartmouth Time Sharing System (DTSS) timeline (archived 2007). "Portions reprinted without permission from the Dartmouth Alumni Magazine, March 1995." Retrieved from http://web.archive.org/web/20070808230138/http://www.dtss.org/timeline.php.

Bibliography

  • Kemeny, John G. & Kurtz, Thomas E. (1985). Back to BASIC: The History, Corruption and Future of the Language. Addison-Wesley Publishing Company, Inc. ISBN 0-201-13433-0.
  • BASIC version 2 manual. Dartmouth College Computation center, 1964. (PDF)
  • BASIC version 4 manual. Dartmouth College Computation center, 1968. (PDF)
  • Kurtz, Thomas E. 1978. BASIC

External links

  • Listing of the source code for version 2 of the Dartmouth BASIC compiler circa 1965 (archived 2007)
  • Scans of original documentation and software.
  • Dartmouth BASIC Interpreter, RetroWiki.es
This article was sourced from Creative Commons Attribution-ShareAlike License; additional terms may apply. World Heritage Encyclopedia content is assembled from numerous content providers, Open Access Publishing, and in compliance with The Fair Access to Science and Technology Research Act (FASTR), Wikimedia Foundation, Inc., Public Library of Science, The Encyclopedia of Life, Open Book Publishers (OBP), PubMed, U.S. National Library of Medicine, National Center for Biotechnology Information, U.S. National Library of Medicine, National Institutes of Health (NIH), U.S. Department of Health & Human Services, and USA.gov, which sources content from all federal, state, local, tribal, and territorial government publication portals (.gov, .mil, .edu). Funding for USA.gov and content contributors is made possible from the U.S. Congress, E-Government Act of 2002.
 
Crowd sourced content that is contributed to World Heritage Encyclopedia is peer reviewed and edited by our editorial staff to ensure quality scholarly research articles.
 
By using this site, you agree to the Terms of Use and Privacy Policy. World Heritage Encyclopedia™ is a registered trademark of the World Public Library Association, a non-profit organization.
 


Copyright © World Library Foundation. All rights reserved. eBooks from Project Gutenberg are sponsored by the World Library Foundation,
a 501c(4) Member's Support Non-Profit Organization, and is NOT affiliated with any governmental agency or department.