A uniform treatment of order of evaluation and aggregate update (Q685390): Difference between revisions
From MaRDI portal
Set profile property. |
Set OpenAlex properties. |
||
(One intermediate revision by one other user not shown) | |||
Property / cites work | |||
Property / cites work: Q3787437 / rank | |||
Normal rank | |||
Property / cites work | |||
Property / cites work: Strictness analysis for higher-order functions / rank | |||
Normal rank | |||
Property / cites work | |||
Property / cites work: Q4692880 / rank | |||
Normal rank | |||
Property / cites work | |||
Property / cites work: LCF considered as a programming language / rank | |||
Normal rank | |||
Property / cites work | |||
Property / cites work: Detecting global variables in denotational specifications / rank | |||
Normal rank | |||
Property / cites work | |||
Property / cites work: Detecting stack-based environments in denotational definitions / rank | |||
Normal rank | |||
Property / cites work | |||
Property / cites work: Q3969890 / rank | |||
Normal rank | |||
Property / full work available at URL | |||
Property / full work available at URL: https://doi.org/10.1016/0304-3975(93)90110-f / rank | |||
Normal rank | |||
Property / OpenAlex ID | |||
Property / OpenAlex ID: W2053513491 / rank | |||
Normal rank |
Latest revision as of 09:20, 30 July 2024
scientific article
Language | Label | Description | Also known as |
---|---|---|---|
English | A uniform treatment of order of evaluation and aggregate update |
scientific article |
Statements
A uniform treatment of order of evaluation and aggregate update (English)
0 references
28 October 1993
0 references
The article presents an algorithm for the destructive update optimization in first-order lazy functional languages. The main component of the method is a new static analysis of the order of evaluation of expressions which, compared to other published work, has a much lower complexity and is not restricted to pure lazy evaluation. The other component, which we call reduction to variables, is a method of detecting the variables which denote locations where the result of an expression might be stored. Starting with the operational semantics of the language, we introduce some markers for the values in the basic domain. By appropriately choosing the set of markers \(M\) and the method of propagating them during evaluation, we can extract some property of the evaluation in which an expression can participate in by looking at the marker of its value. We define then an equivalent denotational semantics and derive the above analyses, in an uniform way, by abstract interpretation over a subdomain of \(P(M_ \perp)\).
0 references
abstract interpretation
0 references
destructive update
0 references
functional languages
0 references
denotational semantics
0 references