JOVIAL

From HandWiki
Revision as of 18:08, 6 February 2024 by OrgMain (talk | contribs) (correction)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Short description: Programming language
JOVIAL
ParadigmsProcedural, imperative, structured
FamilyALGOL
Designed bySystem Development Corporation
DeveloperSoftware Engineering Associates[1]
First appeared1960; 64 years ago (1960)
Typing disciplinestatic, strong, safe, structural
ScopeLexical
Major implementations
MVS, OpenVMS, macOS, Windows, Linux, SPARC, PowerPC, MIL-STD-1750A, other legacy systems
Dialects
J3, J3B-2, J73
Influenced by
ALGOL, SAGE
Influenced
CMS-2, Coral 66, SYMPL

JOVIAL is a high-level programming language based on ALGOL 58, specialized for developing embedded systems (specialized computer systems designed to perform one or a few dedicated functions, usually embedded as part of a larger, more complete device, including mechanical parts). It was a major system programming language through the 1960s and 1970s.[2]

History

File:Computer Programming Manual for the Jovial (J73) Language.djvu JOVIAL was developed as a new "high-order"[3]:1 programming language starting in 1959 by a team at System Development Corporation (SDC) headed by Jules Schwartz to compose software for the electronics of military aircraft.[4]

The name JOVIAL is an acronym for Jules' Own Version[5] of the International Algebraic Language; International Algorithmic Language (IAL) was a name proposed originally for ALGOL 58.[6] According to Schwartz, the language was originally called OVIAL, but this was opposed for various reasons. JOVIAL was then suggested, with no meaning attached to the J. Somewhat jokingly it was suggested that the language be named after Schwartz, since he was the meeting chairperson, and this unofficial name stuck.[7]

During the 1960s, JOVIAL was a part of the US Military L-project series, particularly the ITT 465L Strategic Air Command Control System (the Strategic Automated Command and Control System (SACCS) project), due to a lack of real-time computing programming languages available. Some 95 percent of the SACCS project, managed by International Telephone & Telegraph (ITT) with software mainly written by SDC, was written in JOVIAL. The software project took two years and fewer than 1,400 programmer years, less than half of the equivalent time in the SAGE L-project.[8]

Pin button showing JOVIAL as one of the languages that Advanced Computer Techniques made cross-compilers for

During the late 1970s and early 1980s, the United States Air Force adopted a standardized central processing unit (CPU), the MIL-STD-1750A, and subsequent JOVIAL programs were built for that processor. Several commercial vendors provided compilers and related programming tools to build JOVIAL for processors such as the MIL-STD-1750A, including Advanced Computer Techniques (ACT), TLD Systems, Proprietary Software Systems (PSS), and others.[9][10]

JOVIAL was standardized during 1973 with MIL-STD-1589 and was revised during 1984 with MIL-STD-1589C. It is still used to update and maintain software on older military vehicles and aircraft. There are three dialects in common use: J3, J3B-2, and J73.

(As of 2010), JOVIAL is no longer maintained and distributed by the USAF JOVIAL Program Office (JPO). Software formerly distributed by the JPO is still available through commercial resources at Software Engineering Associates, Inc., (SEA) as are other combinations of host/target processors including Windows, Linux, Mac OS X on PowerPC, SPARC, VAX, 1750A, PowerPC, TI-9989, Zilog Z800x, Motorola 680x0, and IBM System 360, System 370, and System z. Further, DDC-I, which acquired parts of Advanced Computer Techniques, also lists JOVIAL compilers and related tools (As of April 2020).[2]

Most software implemented in JOVIAL is mission critical, and maintenance is growing more difficult. In December 2014, it was reported that software derived from JOVIAL code produced in the 1960s was involved in a major failure of the United Kingdom 's air traffic control infrastructure, and that the agency that uses it, NATS Holdings, was having to train its IT staff in JOVIAL so they could maintain this software, which was not scheduled for replacement until 2016.[11]

Influence

Languages influenced by JOVIAL include CORAL, SYMPL, Space Programming Language (SPL), and to some extent CMS-2.[12] An interactive subset of JOVIAL called TINT, similar to JOSS was developed in the 1960s.[7]

Features

JOVIAL includes features not found in standard ALGOL, such as items (now called structures), arrays of items, status variables (now called enumerations) and inline assembly language.[13]

It also included provisions for "packed" data within tables. Table packing refers to the allocation of items within an entry to words of storage (bits in a unit of data). This was important with respect to the limited memory and storage of the computing systems of the JOVIAL era.

The Communication Pool (COMPOOL) in Jovial is similar to libraries of header files for languages such as PL/I and C.

Applications

Notable systems using embedded JOVIAL software include:

  • Milstar communications satellite
  • Advanced Cruise Missile
  • B-52, B-1B,[14] B-2 bombers
  • C-130, C-141, C-17 transport aircraft
  • F-111, F-15, F-16 (prior to Block 50), F-117 fighter aircraft
  • LANTIRN
  • U-2 aircraft
  • Boeing E-3 Sentry AWACS aircraft (Prior to Block 40/45)
  • Navy Aegis cruisers
  • Army Multiple Launch Rocket System (MLRS)
  • Army Sikorsky UH-60 Black Hawk helicopters
  • F100, F117, F119 jet engines
  • NORAD air defense & control system (Hughes HME-5118ME system)
  • NATO Air Defence Ground Environment (NADGE) system
  • RL10 rocket engines
  • Civil NAS (National Airspace System) Air Traffic Control
  • APG-70, APG-71, and APG-73 airborne radar systems[15]

Example

The following example is taken from Computer Programming Manual for the JOVIAL (J73) Language.[3]:12

PROC RETRIEVE(CODE:VALUE);
   BEGIN
   ITEM CODE U;
   ITEM VALUE F;
   VALUE = -99999.;
   FOR I:0 BY 1 WHILE I<1000;
      IF CODE = TABCODE(I);
         BEGIN
         VALUE = TABVALUE(I);
         EXIT;
      END
   END

This example defines a procedure named RETRIEVE which takes an unsigned integer input argument CODE and a floating-point output argument VALUE. It searches the 1000-element array TABCODE for an entry that matches CODE, and then sets the floating-point variable VALUE to the element of array TABVALUE having the same matching array index. If no matching element is found, VALUE is set to −99999.0.

References

  1. "Software Engineering Associates, Inc. (SEA)". http://www.seadeo.com/. 
  2. 2.0 2.1 "Mature Development Systems, Field Proven on Hundreds of Applications". Phoenix, Arizona. 2020. https://www.ddci.com/products_legacy/. 
  3. 3.0 3.1 Softech, Inc. (June 1981). Computer Programming Manual for the JOVIAL (J73) Language. Rome, New York: Rome Air Development Center. p. 1. http://apps.dtic.mil/dtic/tr/fulltext/u2/a101061.pdf. Retrieved May 16, 2018. 
  4. Schwartz, Jules I. (7 April 1989). Oral History interview with Jules I. Schwartz. University of Minnesota. http://purl.umn.edu/107628.  Schwartz worked for the RAND Corporation on various defense related projects: especially Semi-Automatic Ground Environment (SAGE) and JOHNNIAC. When RAND organized the System Development Corporation, Schwartz went to the new company. For most of the interview, Schwartz describes his association with SAGE, his part in the computer laboratory work on time-sharing for the AN/FSQ-32 computer, computer networks, control system projects (such as TDMS), and his interactions with J. C. R. Licklider, Lawrence G. Roberts, and Robert Saxton Taylor. He discusses his later position at Computer Sciences Corporation.
  5. "Ed and Kay, JOVIAL Pioneers". https://jovial.com/JOVIAL/index.html. 
  6. Shaw, Christopher J. (1963-12-01). "A specification of JOVIAL". Communications of the ACM 6 (12): 721–736. doi:10.1145/763973.763978. ISSN 0001-0782. https://doi.org/10.1145/763973.763978. 
  7. 7.0 7.1 Schwartz, Jules I. (August 8, 1978). "The Development of Jovial". ACM SIGPLAN Notices 13 (8): 203. doi:10.1145/960118.808385. http://jovial.com/documents/p203-schwartz-jovial.pdf. Retrieved January 28, 2015. 
  8. Campbell-Kelly, Martin (2003). From airline reservations to Sonic the Hedgehog: a history of the software industry. Cambridge, Massachusetts: MIT Press. pp. 46-7. ISBN 0-262-03303-8. https://archive.org/details/fromairlinereser00camp_410. 
  9. Schachter, Oscar (7 May 2004). Oral history interview with Oscar Schachter. University of Minnesota. p. 17. http://purl.umn.edu/107622. 
  10. "JOVIAL (J73) and MIL-STD-1750A ISA Software Support Tools". Ada–JOVIAL Newsletter (High Order Language Control Facility, Wright-Patterson AFB, U.S. Air Force): pp. 21–24. September 1993. 
  11. Rayner, Gordon (December 12, 2014). "UK flights chaos: Air traffic control computers using software from the 1960s". Daily Telegraph. https://www.telegraph.co.uk/news/aviation/11291495/UK-flights-chaos-Air-traffic-control-computers-using-software-from-the-1960s.html. 
  12. Digital Computer Basics Rate Training Manual, NAVEDTRA 10088-B, United States Navy, 1978 
  13. Halang, Wolfgang A.; Stoyenko, Alexander D. (1991). Constructing Predictable Real Time Systems. Springer Verlag. p. 31. ISBN 978-1-4615-4032-8. https://www.springer.com/computer/communication+networks/book/978-0-7923-9202-6?token=gbgen&wt_mc=Google-_-Book%20Search-_-Springer-_-EN. 
  14. "Jovial to smooth U.S. Air Force shift to Ada". Defense Electronics. March 1, 1984. http://business.highbeam.com/438317/article-1G1-3161147/jovial-smooth-us-air-force-shift-ada. Retrieved January 28, 2015. 
  15. "AN/APG-73, Warfighter's Encyclopedia". https://wrc.navair-rdte.navy.mil/warfighter_enc/weapons/SensElec/RADAR/anapg73.htm. 

External links

  • The Development of Jovial
  • "MIL-STD-1589C, Military Standard: JOVIAL (J73)". United States Department of Defense. 6 Jul 1984. http://everyspec.com/MIL-STD/MIL-STD-1500-1599/download.php?spec=MIL-STD-1589C.014577.pdf. 
  • April 2006 archive of the JOVIAL Program Office
  • Page on Jules Schwartz, including film of a humorous talk on the development of JOVIAL[|permanent dead link|dead link}}]
  • DODSSP U.S. Department of Defense Single Stock Point for Military Specifications, Standards and Related Publications
  • Software Engineering Associates
  • DDC-I, Inc.: DDC-I JOVIAL Compiler System (DJCS)
  • Archived at Ghostarchive and the Wayback Machine: Schwartz, Jules. Jules Schwartz lecture on JOVIAL (video). YouTube. Retrieved 2020-04-22.
  • Hogan, Michael Olin. "The History of JOVIAL". https://scholarworks.calstate.edu/downloads/6969z3909.