A uniform treatment of order of evaluation and aggregate update (Q685390): Difference between revisions

From MaRDI portal
Import240304020342 (talk | contribs)
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

    Identifiers