Turner, David A. (2004) Total Functional Programming. Journal of Universal Computer Science, 10 (7). pp. 751-768. ISSN 0948-695X. E-ISSN 0948-6968. (doi:10.3217/jucs-010-07-0751) (The full text of this publication is not currently available from this repository. You may be able to access a copy if URLs are provided) (KAR id:88938)
| The full text of this publication is not currently available from this repository. You may be able to access a copy if URLs are provided. | |
| Official URL: http://doi.org/ 10.3217/jucs-010-07-0751 |
|
| Additional URLs: |
|
Abstract
The driving idea of functional programming is to make programming more closely related to mathematics. A program in a functional language such as Haskell or Miranda consists of equations which are both computation rules and a basis for simple algebraic reasoning about the functions and data structures they define. The existing model of functional programming, although elegant and powerful, is compromised to a greater extent than is commonly recognised by the presence of partial functions. We consider a simple discipline of total functional programming designed to exclude the possibility of non-termination. Among other things this requires a type distinction between data, which is finite, and codata, which is potentially infinite.
| Item Type: | Article |
|---|---|
| DOI/Identification number: | 10.3217/jucs-010-07-0751 |
| Uncontrolled keywords: | functional programming |
| Subjects: | Q Science > QA Mathematics (inc Computing science) |
| Institutional Unit: | Schools > School of Computing |
| Former Institutional Unit: |
Divisions > Division of Computing, Engineering and Mathematical Sciences > School of Computing
|
| Depositing User: | David Turner |
| Date Deposited: | 30 Jun 2021 12:23 UTC |
| Last Modified: | 22 Jul 2025 09:06 UTC |
| Resource URI: | https://kar.kent.ac.uk/id/eprint/88938 (The current URI for this page, for reference purposes) |
- Export to:
- RefWorks
- EPrints3 XML
- BibTeX
- CSV
- Depositors only (login required):

Altmetric
Altmetric