|This article needs additional citations for verification. (March 2009) (Learn how and when to remove this template message)|
|Paradigm||multi-paradigm: parallel, Prototype-based|
|Typing discipline||strong, dynamic|
|Modula-3, Self, Oberon|
Obliq is an interpreted, object-oriented programming language designed to make distributed, and locally multi-threaded, computation simple and easy for the programmer, while providing program safety and implicit type system. The interpreter is written in Modula-3, and provides Obliq with full access to Modula-3's network objects capabilities. A type inference algorithm for record concatenation, subtyping and recursive types has been developed for Obliq, more important it has been proved to be NP-complete  and its lowest complexity to be Ο(n3) or if under other modeling up to certain conditions down to Ο(n2)  and its best known implementation runs in Ο(n5). Obliq's syntax is very similar to Modula-3, the biggest difference being that Obliq has no need of explicit typed variables (i.e., a variable can hold any data type allowed by the type checker and if does not accepts one, i.e., a given expression execution error will be thrown) although explicit type declarations are allowed and ignored by the interpreter. The basic data types in the language include booleans, integers, reals, characters, strings, and arrays. Obliq supports the usual set of sequential control structures (conditional, iteration, and exception handling forms), as well as special control forms for concurrency (mutexes and guarded statements). Besides that Obliq's objects are able to be cloned and safely copied remotely by any machine in a distributed network object and it can be done in a transparent way.
Obliq's large standard library provides strong support for mathematical operations, I/O, persistence, thread control, graphics, and animation. Distributed computation is object-based: objects hold a state, which is local to a particular process. Scope of objects and other variables is purely lexical. Objects can call methods of other objects, even if those objects are on another machine on the network. Obliq objects are simply collections of named fields (similar to slots in Self and Smalltalk), and support inheritance by delegation (like Self).
The common uses of Obliq involve programming over networks, 3D animation, and distributed computation over Ethernet LAN as. Obliq is included free with the DEC Modula-3 distribution, but other free versions exist elsewhere including pre-compiled binaries for several operating systems.
Projects using Obliq
- The Collaborative Active Textbooks (CAT)  developed using Obliq applets and the Zeus algorithm animation System (written in Modula-3).
- Obliq applets (Oblets)  special web browser (written in Modula-3) Obliq web page embedded applications.
- Henglein, Fritz (1999). "Breaking through the n3 barrier: Faster object type inference". Theory and Practice of Object Systems. 5 (1): 57–72.
- Palsberg, Jens; Tian Zhao (2002). "Efficient Type Inference for Record Concatenation and Subtyping". Logic in Computer Science, Symposium on. Los Alamitos, CA, USA: IEEE Computer Society. p. 125. doi:10.1109/LICS.2002.1029822.
- Briais, Sebastien; Uwe Nestmann (2002). "Mobile Objects "must" Move Safely". IN FMOODS’02: 129–146. Retrieved 2010-05-15.
- Collaborative Active Textbooks: A Web-Based Algorithm Animation System for an Electronic Classroom Marc H. Brown and Marc A. Najork. DEC Systems Research Center (SRC) Research Report 142 (May 1996)
- Brown, Marc H.; Marc A. Najork (1997). "Distributed applets". CHI '97 extended abstracts on Human factors in computing systems: looking to the future. Atlanta, Georgia: ACM. pp. 204–205. ISBN 0-89791-926-2. doi:10.1145/1120212.1120344. Retrieved 2010-05-15.
- Zeus: A System for Algorithm Animation and Multi-view Editing Marc H. Brown. DEC Systems Research Center (SRC) Research Report 075 (February 1992)