Misplaced Pages

PC-LISP

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
This article has multiple issues. Please help improve it or discuss these issues on the talk page. (Learn how and when to remove these messages)
This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed.
Find sources: "PC-LISP" – news · newspapers · books · scholar · JSTOR (November 2024) (Learn how and when to remove this message)
The topic of this article may not meet Misplaced Pages's general notability guideline. Please help to demonstrate the notability of the topic by citing reliable secondary sources that are independent of the topic and provide significant coverage of it beyond a mere trivial mention. If notability cannot be shown, the article is likely to be merged, redirected, or deleted.
Find sources: "PC-LISP" – news · newspapers · books · scholar · JSTOR (September 2023) (Learn how and when to remove this message)
(Learn how and when to remove this message)
PC-LISP
DeveloperPeter Ashwood-Smith
Platformi386, x86-64
OSLinux, macOS, Microsoft Windows, NetBSD
License
Influenced by
Franz Lisp

PC-LISP is an implementation of the Franz Lisp dialect by Peter Ashwood-Smith.

Version 2.07 was released on 1 February 1986, and version 3.00 was released on 1 February 1990. A current version is available through GitHub.

Currently, PC-LISP has been ported to 32 & 64 bit versions of Linux, Mac, Windows and NetBSD. For NetBSD there also exists ports for AArch64, ARMv5/6/7, PowerPC, Motorola 68000, SPARC/SPARC64, Alpha and VAX.

Note that the Franz LISP dialect was the immediate, portable successor to the ITS version of Maclisp and is perhaps the closest thing to the LISP in the Steven Levy book Hackers as is practical to operate.

PC-LISP is written primarily in the C programming language, with some parts now also written in Common Lisp. PC-LISP runs well in DOS emulators and on modern Windows versions. Because PC-LISP implements Franz LISP, it is a dynamically scoped predecessor to modern Common Lisp. This is therefore an historically important implementation.

Example

The session is running the following code which demonstrates dynamic scoping in Franz LISP. Note that PC-LISP does not implement the let special form that Emacs Lisp provides for local variables. Instead, all variables are what an ALGOL-based language would call "global". The first dialect of Lisp to incorporate ALGOL scoping rules (called lexical scoping) was Scheme although the Common Lisp language also added this feature.

;; Demonstration of dynamic scoping
;; This is a "global" variable
(setq myglobal "this is my global variable")
;; Another global variable
(setq yourglobal "this is my global variable")
;; a function which prints the symbols
(defun dosomething (mine yours)
  (princ " * Mine is  - ")
  (princ mine)
  (princ "\n")
  (princ " * Yours is - ")
  (princ yours)
  (princ "\n"))
;; override the symbols
(defun nolocals ()
  (setq mine "I have set mine to a new value")
  (setq yours "I have set yours to a new value")
  (dosomething mine yours))
(defun main ()
  ;; define two symbols
  (setq mine myglobal)
  (setq yours yourglobal)
  ;; print them
  (princ "calling dosomething\n")
  (dosomething mine yours)
  (princ "calling nolocals\n")
  (nolocals)
  (princ "calling dosomething again\n")
  (dosomething mine yours))

Another example showing the use of backquote and the power of LISP. This is a differentiation example.

; D(e,X) -
;          Will compute the symbolic derivative of expression e with respect
; to variable X. We take the expression in standard lisp prefix form and will
; use the following rules of differentiation.
;
;         D(x)    = 1
;         D(a)    = 0
;         D(ln u) = D(u)/u 
;         D(u+v)  = D(u)+D(v)
;         D(u-v)  = D(u)-D(v)
;         D(u*v)  = D(u)*v + u*D(v)
;         D(u/v)  = D(u)*v + (u*D(v))/v^2
;         D(v^u)  = (v^u)*(u*D(v)/v + D(u)*ln(v))
;
(defun  D(e X &aux u v)
 (cond ((equal e X) 1) 
       ((atom e) 0)           
       (t (setq u (cadr e) v (caddr e))
	  (caseq (car e)
		 (ln `(/ ,(D u X) ,u)) 
		 (+  `(+ ,(D u X) ,(D v X)))
		 (-  `(- ,(D u X) ,(D v X)))
		 (*  `(+  (* ,(D u X) ,v) (* ,(D v X) ,u)))
		 (/  `(-  (/ ,(D u X) ,v)
			  (/ (* ,u ,(D v X)) (^ ,v 2))))
		 (^  `(* ,e  (+ (/ (* ,v ,(D u X)) ,u)
				   (* ,(D v X) (ln ,u)))))
		 (t (princ "ERROR") (exit)]

References

  1. ^ Ashwood-Smith, Peter (1 February 1990). "PC-LISP V3.00 (C) February 1st 1990 Peter Ashwood-Smith". Carnegie Mellon University - School of Computer Science. Retrieved 14 November 2024.
  2. ^ "blakemcbride/PC-LISP". 4 August 2020. Retrieved 14 November 2024 – via GitHub.
  3. Ashwood-Smith, Peter (May 1987). Van Deusen, Mary S. (ed.). "PC-LISP". LISP Pointers. Vol. 1, no. 1. pp. 51–52. Retrieved 14 November 2024.
  4. Ashwood-Smith, Peter (20 February 1986). "A GUIDE TO THE PC-LISP INTERPRETER (V2.07)". The Unix Heritage Society. Retrieved 14 November 2024.
  5. ^ "lang/pc-lisp - The NetBSD Packages Collection". NetBSD. Retrieved 14 November 2024.
  6. Foderaro, John K.; Sklower, Keith L.; Layer, Kevin (June 1983). "FRANZ LISP". The FRANZ LISP Manual (PDF). p. 5 – via GitHub.

External links

Categories: