Denotative vs Procedural
Posted: Sun Jul 30, 2017 2:12 pm
In Thursday's Webinar I banged on a bit about Denotative vs Procedural thinking. It was not my intention to imply that one paradigm is superior to the other and I certainly didn't mean to "dis" procedural programming. There's megabucks to be made with the representation and manipulation of state, as shareholders in Oracle Corp will attest.
The point I was trying to make is that at the deepest level, and while each has its place, the two mindsets are profoundly different. I was first introduced to programming in the procedural (first do this, then do that, ...) mood and it feels very natural to me for many tasks. For such jobs, I would probably tend to use traditional APL (tradfns) with their control structures and multiple re-assignments. On the other hand, some tasks seem to lend themselves to expression as a set of definitions. For these I would choose dfns and try to avoid re-specifying names.
Procedural thinking: Mutate variables towards the required result.
Denotative (inc "Functional") thinking: Develop definitions for the required result.
The merge operation, traditionally supplied by indexed assignment, is the final area of Dyalog in which I was forced to change my mode of thinking while in the denotative mood. Now we have @, I can stay within that mindset while I'm constructing my definitions.
Terminology: I have started using the term "denotative" for a number reasons:
[a] Stephen Taylor, drawing on his degree in philosophy, remarked after a presentation where I was trying to vocalise ← as "is", that "denotes" would be more accurate.
[b] Peter Landin, who must have some claim to be one of the fathers of functional programming said: "The word "denotative" seems more appropriate than nonprocedural, declarative or functional. The antithesis of denotative is "imperative".
[c] "Denotative" has a slightly broader connotation than "functional". In the following definitions:
avg1←{sum←+⌿⍵ ⋄ num←≢⍵ ⋄ sum÷num}
avg2←{sum←+⌿ ⋄ num←≢ ⋄ (sum÷num)⍵}
both are denotative; the second is (arguably) "more functional".
</IMHO>
John
The point I was trying to make is that at the deepest level, and while each has its place, the two mindsets are profoundly different. I was first introduced to programming in the procedural (first do this, then do that, ...) mood and it feels very natural to me for many tasks. For such jobs, I would probably tend to use traditional APL (tradfns) with their control structures and multiple re-assignments. On the other hand, some tasks seem to lend themselves to expression as a set of definitions. For these I would choose dfns and try to avoid re-specifying names.
Procedural thinking: Mutate variables towards the required result.
Denotative (inc "Functional") thinking: Develop definitions for the required result.
The merge operation, traditionally supplied by indexed assignment, is the final area of Dyalog in which I was forced to change my mode of thinking while in the denotative mood. Now we have @, I can stay within that mindset while I'm constructing my definitions.
Terminology: I have started using the term "denotative" for a number reasons:
[a] Stephen Taylor, drawing on his degree in philosophy, remarked after a presentation where I was trying to vocalise ← as "is", that "denotes" would be more accurate.
[b] Peter Landin, who must have some claim to be one of the fathers of functional programming said: "The word "denotative" seems more appropriate than nonprocedural, declarative or functional. The antithesis of denotative is "imperative".
[c] "Denotative" has a slightly broader connotation than "functional". In the following definitions:
avg1←{sum←+⌿⍵ ⋄ num←≢⍵ ⋄ sum÷num}
avg2←{sum←+⌿ ⋄ num←≢ ⋄ (sum÷num)⍵}
both are denotative; the second is (arguably) "more functional".
</IMHO>
John