Program algebra for random access machine programs by Middelburg, C. A.
ar
X
iv
:2
00
7.
09
94
6v
1 
 [c
s.P
L]
  2
0 J
ul 
20
20
Program Algebra for
Random Access Machine Programs
C.A. Middelburg
Informatics Institute, Faculty of Science, University of Amsterdam,
Science Park 904, 1098 XH Amsterdam, the Netherlands
C.A.Middelburg@uva.nl
Abstract. This paper presents an algebraic theory of instruction se-
quences with instructions for a random access machine (RAM) as basic
instructions, the behaviours produced by the instruction sequences con-
cerned under execution, and the interaction between such behaviours
and RAM memories. This theory provides a setting for the development
of theory in areas such as computational complexity and analysis of al-
gorithm that distinguishes itself by offering the possibility of equational
reasoning to establish whether an instruction sequence computes a given
function and being more general than the setting provided by any known
version of the RAMmodel of computation. In this setting, a semi-realistic
version of the RAM model of computation and a bit-oriented time com-
plexity measure for this version are introduced.
Keywords: program algebra, thread algebra, random access machine,
semi-realistic RAM program, bit-oriented time complexity.
1998 ACM Computing Classification: D.1.4, E.3, F.1.1, F.1.3.
1 Introduction
This paper introduces an algebraic theory which provides a setting for the de-
velopment of theory in areas such as computational complexity and analysis of
algorithms that elaborates on a version of the random access machine (RAM)
model of computation. The setting in question distinguishes itself by offering the
possibility of equational reasoning to establish whether an instruction sequence
computes a given function and being more general than the setting provided
by any known version of the RAM model of computation. Many known and
unknown versions of this model of computation can be dealt with by imposing
apposite restrictions. We expect that the generality is conducive to the investi-
gation of novel issues in areas such as computational complexity and analysis
of algorithms. This expectation is based on our experience with a comparable
algebraic theory of instruction sequences, where instructions operate on Boolean
registers, in previous work (see [7,8,9,10,11,14]).
This paper belongs to a line of research that started with [3], and of which
an enumeration is available at [25]. The first objective of this line of research is
to understand the concept of a program. The notion of an instruction sequence
appears in the work in question as a mathematical abstraction for which the ra-
tionale is based on this objective. The structure of the mathematical abstraction
at issue has been determined in advance with the hope of applying it in diverse
circumstances where in each case the fit may be less than perfect. Until now, the
work in question has yielded contributions to various computer science subjects
and new insights into diverse issues.
The basis of all the work in question (see [25]) is the combination of an alge-
braic theory of single-pass instruction sequences, called program algebra, and an
algebraic theory of mathematical objects that represent the behaviours produced
by instruction sequences under execution, called basic thread algebra, extended
to deal with the interaction between such behaviours and components of an exe-
cution environment for instruction sequences. This combination is parameterized
by a set of basic instructions and a set of objects that represent the behaviours
exhibited by the components of an execution environment.
The current paper contains a simplified presentation of the instantiation of
this combination in which RAM memories are taken as the components of an
execution environment, instructions for a RAM are taken as basic instructions,
and an execution environment consists of only one component. Because we opt
for the most general instantiation, all instructions that do not read out or alter
more than one register from the RAM memory are taken as basic instructions.
Both known and unknown versions of the RAM model of computation can be
dealt with by restriction on the set of basic instructions. We expect that by
this set-up the presented instantiation can be useful to rigorous investigations
of novel issues relating to computational complexity and analysis of algorithms.
Program algebra and basic thread algebra were first presented in [3].1 The
extension of basic thread algebra referred to above, an extension to deal with the
interaction between the behaviours produced by instruction sequences under ex-
ecution and components of an execution environment, was first presented in [5].
The presentation of the extension is rather involved because it is parameterized
and owing to this covers a generic set of basic instructions and a generic set of
execution environment components. In the current paper, a much less involved
presentation is obtained by considering only the case where execution environ-
ment components are RAM memories, basic instructions are instructions for a
RAM, and an execution environment consists of only one component.
After the presentation in question, we make precise in the setting of the
presented theory what it means that a given instruction sequence computes a
given partial function on bit strings, show that a relatively unknown, but more
or less realistic, version of the RAM model can be dealt with in this setting by
imposing apposite restrictions, and introduce for this model an alternative to
the usual time measures for versions of the RAM model. Under the alternative
time measure, RAMs from the more or less realistic version of the RAM model
of computation can be simulated by multi-tape Turing machines with quadratic
time overhead. Moreover, under a usual space measure for versions of the RAM
1 In that paper and the first subsequent papers, basic thread algebra was introduced
under the name basic polarized process algebra.
2
model, RAMs from the more or less realistic version of the RAM model can be
simulated by multi-tape Turing machines with constant-factor space overhead.
This paper is organized as follows. First, a survey is given of program al-
gebra, basic thread algebra, and an extension of their combination that makes
precise which behaviours are produced by instruction sequences under execution
(Sections 2, 3, and 4). Next, the surveyed theory is instantiated and extended to
handle interaction between instruction sequences, with instructions for a RAM,
under execution and the memory of a RAM (Sections 5 and 6). Then, in the
setting of the resulting theory, it is made precise what it means that a given
instruction sequence computes a given partial function (Section 7) and a version
of the RAM model of computation is described that is a more or less realistic
idealization of a real computer (Sections 8, 9, and 10). After that, a new time
measure and a known space measure for this model of computation are intro-
duced (Sections 11 and 12) and the former measure is discussed (Section 13).
Finally, some concluding remarks are made (Section 14).
In this paper, some familiarity with algebraic specification, computability,
and computational complexity is assumed. The relevant notions are explained
in many handbook chapters and textbooks, e.g. [20,29,31] for the relevant no-
tions concerning algebraic specification and [1,26,28] for the relevant notions
concerning computability and computational complexity.
Sections 2–4, i.e. the preliminary sections of this paper, are largely shortened
versions of Sections 2–4 of [12], which, in turn, draw from the preliminary sections
of several earlier papers.
2 Program Algebra
This section presents a survey of program algebra (PGA). A program is perceived
in PGA as a single-pass instruction sequence, i.e. a possibly infinite sequence
of instructions of which each instruction is executed at most once and can be
dropped after it has been executed or jumped over.
It is assumed that a fixed but arbitrary set A of basic instructions has been
given. A is the basis for the set of instructions that may occur in instruction
sequences. The intuition is that the execution of a basic instruction may modify a
state and must produce the value 0 or 1 as reply at its completion. The produced
reply may be state-dependent. In applications of PGA, the instructions taken as
basic instructions vary from instructions relating to Boolean registers to machine
language instructions of actual computers.
The set of instructions of which the instruction sequences are composed is
the set that consists of the following elements:
– for each a ∈ A, a plain basic instruction a;
– for each a ∈ A, a positive test instruction +a;
– for each a ∈ A, a negative test instruction −a;
– for each l ∈ N, a forward jump instruction #l;
– a termination instruction !.
3
We write I for this set. The elements from this set are called primitive instruc-
tions.
On execution of an instruction sequence, the primitive instructions of which
it is composed have the following effects:
– the effect of a positive test instruction +a is that basic instruction a is
executed and execution proceeds with the next primitive instruction if the
produced reply is 1 and otherwise the next primitive instruction is skipped
and execution proceeds with the primitive instruction following the skipped
one — inaction occurs if there is no primitive instruction to proceed with;
– the effect of a negative test instruction −a is the same as the effect of +a,
but with the role of the produced reply reversed;
– the effect of a plain basic instruction a is the same as the effect of +a, but
execution always proceeds as if the produced reply is 1;
– the effect of a forward jump instruction #l is that execution proceeds with
the lth next primitive instruction — inaction occurs if l equals 0 or there is
no primitive instruction to proceed with;
– the effect of the termination instruction ! is that execution terminates.
The phrase “inaction occurs” indicates that no more basic instructions are exe-
cuted, but execution does not terminate.
PGA has one sort: the sort IS of instruction sequences. To build terms of
sort IS, PGA has the following constants and operators:
– for each u ∈ I, the instruction constant u :→ IS ;
– the binary concatenation operator ; : IS× IS→ IS ;
– the unary repetition operator ω : IS→ IS .
Terms of sort IS are built as usual in the one-sorted case. We assume that there
are infinitely many variables of sort IS, including X,Y, Z. We use infix notation
for concatenation and postfix notation for repetition.
A PGA term in which the repetition operator does not occur is called a
repetition-free PGA term.
One way of thinking about closed PGA terms is that they represent non-
empty, possibly infinite sequences of primitive instructions with finitely many
distinct suffixes. Let t and t′ be closed PGA terms representing instruction se-
quences s and s′. Then the operators of PGA can be explained as follows:
– t ; t′ represents the concatenation of s and s′;
– tω represents s concatenated infinitely many times with itself.
The axioms of PGA are given in Table 1. In this table, u, u1, . . . , uk and
v1, . . . , vk′+1 stand for arbitrary primitive instructions from I, k, k
′, and l stand
for arbitrary natural numbers from N, and n stands for an arbitrary natural
number from N1.
2 For each n ∈ N1, the term t
n, where t is a PGA term, is
defined by induction on n as follows: t1 = t, and tn+1 = t ; tn.
2 We write N1 for the set {n ∈ N | n ≥ 1} of positive natural numbers.
4
Table 1. Axioms of PGA
(X ; Y ) ; Z = X ; (Y ; Z) PGA1
(Xn)ω = Xω PGA2
Xω ; Y = Xω PGA3
(X ; Y )ω = X ; (Y ;X)ω PGA4
#k+1 ; u1 ; . . . ; uk ; #0 = #0 ; u1 ; . . . ; uk ; #0 PGA5
#k+1 ; u1 ; . . . ; uk ; #l = #l+k+1 ; u1 ; . . . ; uk ; #l PGA6
(#l+k+1 ; u1 ; . . . ; uk)
ω = (#l ; u1 ; . . . ; uk)
ω PGA7
#l+k+k′+2 ; u1 ; . . . ; uk ; (v1 ; . . . ; vk′+1)
ω =
#l+k+1 ; u1 ; . . . ; uk ; (v1 ; . . . ; vk′+1)
ω PGA8
Let t and t′ be closed PGA terms. Then t = t′ is derivable from the axioms
of PGA iff t and t′ represent the same instruction sequence after changing all
chained jumps into single jumps and making all jumps as short as possible.
Moreover, t = t′ is derivable from PGA1–PGA4 iff t and t′ represent the same
instruction sequence.
The informal explanation of closed PGA terms as sequences of primitive in-
structions given above can be looked upon as a sketch of the intended model
of axioms PGA1–PGA4. This model, which is described in detail in, for exam-
ple, [6], is an initial model of axioms PGA1–PGA4. Henceforth, the instruction
sequences of the kind considered in PGA are called PGA instruction sequences.
3 Basic Thread Algebra for Finite and Infinite Threads
In this section, we introduce basic thread algebra (BTA) and an extension of BTA
that reflects the idea that infinite threads are identical if their approximations
up to any finite depth are identical.
BTA is concerned with mathematical objects that model in a direct way
the behaviours produced by PGA instruction sequences under execution. The
objects in question are called threads. A thread models a behaviour that consists
of performing basic actions in a sequential fashion. Upon performing a basic
action, a reply from an execution environment determines how the behaviour
proceeds subsequently. The possible replies are the values 0 and 1.
The basic instructions from A are taken as basic actions. Besides, tau is taken
as a special basic action. It is assumed that tau /∈ A. We write Atau for A∪{tau}.
BTA has one sort: the sort T of threads. To build terms of sort T, BTA has
the following constants and operators:
– the inaction constant D :→T;
– the termination constant S :→T;
5
Table 2. Axiom of BTA
x E tauD y = tau ◦ x T1
– for each α ∈ Atau, the binary postconditional composition operator EαD :
T×T→ T.
Terms of sort T are built as usual in the one-sorted case. We assume that there
are infinitely many variables of sort T, including x, y, z. We use infix notation
for postconditional composition. We introduce basic action prefixing as an ab-
breviation: α ◦ t, where α ∈ Atau and t is a BTA term, abbreviates tEαD t. We
treat an expression of the form α ◦ t and the BTA term that it abbreviates as
syntactically the same.
Closed BTA terms are considered to represent threads. The constants of PGA
can be explained as follows:
– D represented the thread that models inactive behaviour, i.e. the behaviour
that performs no more basic actions and does not terminate either;
– S represents the thread that models the behaviour that does nothing else
but terminate.
Let t and t′ be closed BTA terms representing threads r and r′. Then the oper-
ators of PGA can be explained as follows:
– tEαD t′ represents the thread that models the behaviour that first performs
α and then proceeds as the behaviour modeled by r if the reply from the
execution environment is 1 and otherwise proceeds as the behaviour modeled
by r′.
BTA has only one axiom. This axiom is given in Table 2. It tells us that
performing tau, which is considered performing an internal action, always leads
to the reply 1.
Each closed BTA term represents a finite thread, i.e. a thread with a finite
upper bound to the number of basic actions that it can perform. Infinite threads,
i.e. threads without a finite upper bound to the number of basic actions that
it can perform, can be defined by means of a set of recursion equations (see
e.g. [5]). A regular thread is a finite or infinite thread that can be defined by
means of a finite set of recursion equations. The behaviours produced by PGA
instruction sequences under execution are exactly the behaviours modeled by
regular threads.
Two infinite threads are considered identical if their approximations up to
any finite depth are identical. The approximation up to depth n of a thread mod-
els the behaviour that differs from the behaviour modeled by the thread in that
it will become inactive after it has performed n actions unless it would termi-
nate at this point. The approximation induction principle (AIP) is a conditional
equation that formalizes the above-mentioned view on infinite threads. In AIP,
6
Table 3. Axioms for the projection operators and AIP
π0(x) = D PR1
πn+1(D) = D PR2
πn+1(S) = S PR3
πn+1(xEαD y) = πn(x)EαD πn(y) PR4
∧
n≥0
πn(x) = πn(y) ⇒ x = y AIP
the approximation up to depth n is phrased in terms of the unary projection
operator πn :T→ T.
The axioms for the projection operators and AIP are given in Table 3. In
this table, α stands for an arbitrary basic action from Atau and n stands for an
arbitrary natural number from N. We write BTA∞ for BTA extended with the
projection operators, the axioms for the projection operators, and AIP.
Because we have to deal with conditional equational formulas with a count-
ably infinite number of premises in BTA∞, it is understood that infinitary con-
ditional equational logic is used in deriving equations from the axioms of BTA∞.
A complete inference system for infinitary conditional equational logic can be
found in [22].
The depth of a finite thread is the maximum number of basic actions that
it can perform before it terminates or becomes inactive. We define the function
depth that assigns to each closed BTA term the depth of the finite thread that
it represents recursively as follows:
depth(S) = 0 ,
depth(D) = 0 ,
depth(tEαD t′) = max{depth(t), depth(t′)}+ 1 .
4 Thread Extraction from Instruction Sequences
In this section, we make precise in the setting of BTA∞ which behaviours are
produced by PGA instruction sequences under execution.
To make precise which behaviours are produced by PGA instruction se-
quences under execution, we introduce an operator | |. For each closed PGA
term t, |t| represents the thread that models the behaviour produced by the
instruction sequence represented by t under execution.
Formally, we combine PGA with BTA∞ and extend the combination with
the thread extraction operator | | : IS → T and the axioms given in Table 4.
In this table, a stands for an arbitrary basic instruction from A, u stands for
an arbitrary primitive instruction from I, and l stands for an arbitrary natural
number from N. We write PGA/BTA∞ for the combination of PGA and BTA∞
7
Table 4. Axioms for the thread extraction operator
|a| = a ◦ D TE1
|a ;X| = a ◦ |X| TE2
|+a| = a ◦ D TE3
|+a ;X| = |X| EaD |#2 ;X| TE4
|−a| = a ◦ D TE5
|−a ;X| = |#2 ;X|EaD |X| TE6
|#l| = D TE7
|#0 ;X| = D TE8
|#1 ;X| = |X| TE9
|#l + 2 ; u| = D TE10
|#l + 2 ; u ;X| = |#l + 1 ;X| TE11
|!| = S TE12
|! ;X| = S TE13
extended with the thread extraction operator and the axioms for the thread
extraction operator.
If a closed PGA term t represents an instruction sequence that starts with
an infinite chain of forward jumps, then TE9 and TE11 can be applied to |t|
infinitely often without ever showing that a basic action is performed. In this
case, we have to do with inaction and, being consistent with that, |t| = D is
derivable from the axioms of PGA and TE1–TE13. By contrast, |t| = D is not
derivable from PGA1–PGA4 and TE1–TE13. However, if closed PGA terms t
and t′ represent instruction sequences in which no infinite chains of forward
jumps occur, then t = t′ is derivable from the axioms of PGA only if |t| = |t′| is
derivable from PGA1–PGA4 and TE1–TE13.
If a closed PGA term t represents an infinite instruction sequence, then we
can extract the approximations of the thread modeling the behaviour produced
by that instruction sequence under execution up to every finite depth: for each
n ∈ N, there exists a closed BTA term t′′ such that πn(|t|) = t
′′ is derivable from
the axioms of PGA, TE1–TE13, the axioms of BTA, and PR1–PR4. If closed
PGA terms t and t′ represent infinite instruction sequences that produce the
same behaviour under execution, then this can be proved using the following
instance of AIP:
∧
n≥0 πn(|t|) = πn(|t
′|) ⇒ |t| = |t′|.
The following proposition, proved in [6], puts the expressiveness of PGA in
terms of producible behaviours.
Proposition 1. Let M be a model of PGA/BTA∞. Then, for each element r
from the domain associated with the sort T in M, there exists a closed PGA
term t such that the interpretation of |t| in M is r iff r can be defined by means
of a finite set of recursion equations.
PGA instruction sequences are behaviourally equivalent if they produce the
same behaviour under execution. Behavioural equivalence is not a congruence.
Instruction sequences are behaviourally congruent if they produce the same be-
haviour irrespective of the way they are entered and the way they are left.
8
5 Basic Instructions for Random Access Machines
PGA instruction sequences under execution may interact with components of
their execution environment. The execution environment components vary from
one applications of PGA to another. In this section, we consider basic instruc-
tion for the case where the execution environment components are memories of
RAMs.
The memory of a RAM consists of a countably infinite number of registers
which are numbered by natural numbers. Each register is capable of containing
a bit string of arbitrary length. The contents of the registers constitute the state
of the memory.
A RAM memory state is a function σ :N→ {0, 1}∗ that satisfies the condition
that there exists a i ∈ N such that, for all j ∈ N, σ(i + j) = ǫ.3 We write Σrm
for the set of all RAM memory states, and we write σǫ for the unique σ ∈ Σrm
such that σ(i) = ǫ for all i ∈ N.
Let σ be a RAM memory state. Then, for all i ∈ N, σ(i) is the content of
the register with number i in memory state σ. The condition expresses that the
part of the memory that is actually in use remains finite.
Henceforth, we will use the notation (σ : i1 7→ w1, . . . , in 7→ wn). For each
σ :N→ {0, 1}∗, i1, . . . , in ∈ N, and w1, . . . , wn ∈ {0, 1}
∗, (σ :i1 7→w1, . . . , in 7→wn)
is the function σ′ :N→ {0, 1}∗ defined as follows: σ′(i1) = w1, . . . , σ
′(in) = wn,
and, for all j ∈ N with j /∈ {i1, . . . , in}, σ
′(j) = σ(j).
The execution of an instruction by a RAM may change the memory state of
the RAM and must produce the value 0 or 1 as reply.
The set of basic instructions used in this case consists of a basic RAM in-
struction p/q for each p : Σrm → {0, 1} and q : Σrm → Σrm that satisfy the
following conditions for all σ ∈ Σrm:
(a) there exists at most one i ∈ N for which there exists a w ∈ {0, 1}∗ such that
σ(i) 6= w and p(σ) 6= p((σ : i 7→ w)),
(b) there exists at most one i ∈ N for which σ(i) 6= q(σ)(i),
(c) if there exists an i ∈ N for which there exists a w ∈ {0, 1}∗ such that σ(i) 6= w
and p(σ) 6= p((σ : i 7→w)) and there exists an i ∈ N for which σ(i) 6= q(σ)(i),
then there exists an i ∈ N for which there exists a w ∈ {0, 1}∗ such that
σ(i) 6= w and p(σ) 6= p((σ : i 7→ w)) and σ(i) 6= q(σ)(i).
We write Aram for this set.
Each basic RAM instruction leads to carrying out an operation on a RAM
memory when the instruction is executed. The intuition is basically that carrying
out the operation modifies the content of a single register of the RAM memory
and produces the value 0 or 1 as reply depending on the content of this register.
More precisely, the execution of a basic RAM instruction p/q has the following
effects:
– if the RAM memory state is σ when the execution of p/q starts, then the
reply produced on termination of the execution of p/q is p(σ);
3 We write ǫ for the empty bit string.
9
– if the RAM memory state is σ when the execution of p/q starts, then the
RAM memory state is q(σ) when the execution of p/q terminates.
Condition (a) expresses that a basic RAM instruction does not produce a reply
that depends on the content of more than one register. Condition (b) expresses
that a basic RAM instruction does not modify the content of more than one
register. Condition (c) expresses that a basic RAM instruction produces a reply
that depends on the content of a register and modifies the content of a register
only if the former register is the same as the latter register.
A function from Σrm to {0, 1} for which condition (a) trivially holds is the
function 1 defined by 1(σ) = 1. A function from Σrm to Σrm for which condi-
tion (b) trivially holds is the function i defined by i(σ) = σ. From Section 9,
only basic RAM instruction of the forms 1/q and p/ i are considered.
We write [PGA/BTA∞](Aram) for PGA/BTA
∞ withA instantiated byAram.
6 Interaction of Threads with RAM Memories
If instructions from Aram are taken as basic instructions, a PGA instruction
sequence under execution may interact with the memory of a RAM. In line
with this kind of interaction, a thread may perform a basic action basically for
the purpose of changing the memory state of a RAM or receiving a reply that
depends on the memory state of a RAM. In this section, we introduce related
constants and operators.
We extend PGA/BTA∞(Aram) with the sort RM of RAM memories, the
following operators:
– for each σ ∈ Σrm ∪ {∗}, the RAM memory constant rm(σ) :→RM;
– the binary use operator / :T×RM→ T;
– the binary apply operator • :T×RM→ RM;
and the axioms given in Tables 5.4 In these tables, p stands for an arbitrary
function from Σrm to {0, 1}, q stands for an arbitrary function from Σrm to
Σrm, σ stands for an arbitrary RAM memory state from Σrm, n stands for
an arbitrary natural number from N, and t and t′ stand for arbitrary terms
of sort RM. Moreover, u is assumed to be a variable of sort RM. We use
infix notation for the use and apply operators. We write PGA/BTA∞/RAM for
[PGA/BTA∞](Aram) extended with the sort RM, the RAM memory constants,
the use operator, the apply operator, and the axioms for these operators.
Axioms U1–U6 and A1–A6 formalize the informal explanation of the use
operator and the apply operator given below and in addition stipulate what is
the result of use and apply if an inoperative RAM memory is involved (U6 and
A6). Axioms U7 and A7 allow of reasoning about infinite threads, and therefore
about the behaviour produced by infinite instruction sequences under execution,
in the context of use and apply, respectively.
4 We write t[t′/x] for the result of substituting term t′ for variable x in term t.
10
Table 5. Axioms for the use and apply operator
S / u = S U1
D / u = D U2
(tau ◦ x) / u = tau ◦ (x / u) U3
(xE p/qD y) / rm(σ) = tau ◦ (x / rm(q(σ))) if p(σ) = 1 U4
(xE p/qD y) / rm(σ) = tau ◦ (y / rm(q(σ))) if p(σ) = 0 U5
(xE p/qD y) / rm(∗) = tau ◦ D U6
πn(x / u) = πn(x) / u U7
S • u = u A1
D • u = rm(∗) A2
(tau ◦ x) • u = tau ◦ (x • u) A3
(xE p/qD y) • rm(σ) = x • rm(q(σ)) if p(σ) = 1 A4
(xE p/qD y) • rm(σ) = y • rm(q(σ)) if p(σ) = 0 A5
(xE p/qD y) • rm(∗) = rm(∗) A6
∧
k≥n
t[πk(x)/z] = t
′[πk(y)/z] ⇒ t[x/z] = t
′[y/z] A7
The RAM memory denoted by a closed term of the form rm(σ), where
σ ∈ Σrm, is an operative RAM memory whose state is σ. The RAM mem-
ory denoted by a closed term of the form rm(∗) is an inoperative RAM memory.
An inoperative RAM memory can be viewed as a RAM memory whose state
is unavailable. Carrying out an operation on an inoperative RAM memory is
impossible.
On interaction between a thread and a RAM memory, the thread affects
the RAM memory and the RAM memory affects the thread. The use operator
concerns the effects of a RAM memory on a thread and the apply operator
concerns the effects of a thread on a RAM memory. The thread denoted by a
closed term of the form t / t′ and the RAM memory denoted by a closed term of
the form t • t′ are the thread and RAM memory, respectively, that result from
carrying out the operations that go with the basic actions performed by the
thread denoted by t on the RAM memory denoted by t′. When the operation
that goes with a basic action performed by a thread is carried out on a RAM
memory, the state of the RAM memory is changed according to the operation
concerned and the thread is affected as follows: the basic action turns into the
internal action tau and the two ways to proceed reduce to one on the basis of the
reply produced according to the operation concerned. Thus, the internal action
tau is left as a trace of each basic action that has led to carrying out an operation
on the RAM memory.
11
The following two elimination results for closed PGA/BTA∞/RAM terms
are proved similarly to Theorems 1 and 2 from [13].
Proposition 2. For all closed PGA/BTA∞/RAM terms t of sort T in
which all subterms of sort IS are repetition-free, there exists a closed
[PGA/BTA∞](Aram) term t
′ of sort T such that t = t′ is derivable from the
axioms of PGA/BTA∞/RAM.
Proposition 3. For all closed PGA/BTA∞/RAM terms t of sort RM
in which all subterms of sort IS are repetition-free, there exists a closed
[PGA/BTA∞](Aram) term t
′ of sort RM such that t = t′ is derivable from
the axioms of PGA/BTA∞/RAM.
7 Computing Partial Functions from ({0, 1}∗)n to {0, 1}∗
In this section, we make precise in the setting of the algebraic theory
PGA/BTA∞/RAM what it means that a given instruction sequence computes
a given partial function from ({0, 1}∗)
n
to {0, 1}∗ (n ∈ N).
We use the notation f : A 7→ B to indicate that f is a partial function from
A to B. We write ℓ(w), where w ∈ {0, 1}∗, for the length of w.
Let t be a closed PGA/BTA∞/RAM term of sort IS, let n ∈ N, let F :
({0, 1}∗)n 7→ {0, 1}∗, and let T :N→ N. Then t computes F in time T under the
uniform time measure if:
– for all w1, . . . , wn ∈ {0, 1}
∗ such that F (w1, . . . , wn) is defined, there exist a
σ ∈ Σrm such that:
|t| • rm((σǫ : 1 7→ w1, . . . , n 7→ wn)) = rm((σ : 0 7→ F (w1, . . . , wn))) ,
depth(|t| / rm((σǫ : 1 7→ w1, . . . , n 7→ wn))) ≤ T (ℓ(w1) + . . .+ ℓ(wn)) ;
– for all w1, . . . , wn ∈ {0, 1}
∗ such that F (w1, . . . , wn) is undefined:
|t| • rm((σǫ : 1 7→ w1, . . . , n 7→ wn)) = rm(∗) .
We say that t computes F if there exists a T :N→ N such that t computes F in
time T under the uniform time measure.
With the above definition, we can establish whether an instruction sequence
of the kind considered in PGA/BTA∞/RAM computes a given partial function
from ({0, 1}∗)n to {0, 1}∗ (n ∈ N) by equational reasoning using the axioms of
PGA/BTA∞/RAM.
The setting provided by PGA/BTA∞/RAM is more general than the set-
ting provided by any known version of the RAM model of computation.
PGA/BTA∞/RAM is not suitable as a model of computation itself, but vir-
tually all known versions of the RAM model of computation can be dealt with
by imposing restrictions on the set of basic RAM instructions (Aram). Inves-
tigations of issues in areas such as computational complexity and analysis of
12
algorithms require restriction to instructions that are found to be sufficiently
primitive. Without any restriction on Aram, we even have that, for each com-
putable F : ({0, 1}∗)
n
7→ {0, 1}∗, there exists a closed PGA/BTA∞/RAM term
t of sort IS such that t computes F in one step.
Restriction of the set of basic RAM instructions to instructions, with both
direct and indirect addressing of registers, to carry out addition by one on natural
numbers, to carry out comparisons of natural numbers on equal to and greater
than, and to copy natural numbers (identifying bit strings with the natural
numbers that they represent) gives rise to the version of the RAM model of
computation known as the successor RAM model. The basic instructions of
a successor RAM are clearly very primitive, but as a consequence of that a
successor RAM is not a very realistic idealization of a real computer. In Section 8,
we present a set of basic RAM instructions that yields a much more realistic
idealization of a real computer.
Whatever version of the RAM model of computation is obtained by restric-
tion of the set of basic RAM instructions considered in PGA/BTA∞/RAM, it
is an idealization of a real computer in the sense that its memory offers an un-
bounded number of registers that can contain a bit string of arbitrary length
instead of a bounded number of registers that can only contain a bit string of a
fixed length.
8 Basic Instructions for More or Less Realistic RAMs
In this section, we introduce a set of basic RAM instructions that give rise to a
version of the RAM model of computation that is a fairly realistic idealization
of a real computer.
In general, the execution of an instruction by a real computer changes the
memory state of the computer by carrying out a certain operation on the contents
of certain registers and changing the content of a certain register into the result
of this. We use a special notation reflecting this for the restricted set of basic
RAM instructions with which a fairly realistic idealization of a real computer
is obtained. This restricted set of basic RAM instructions consists of all basic
RAM instructions that have one of the following forms in the special notation:
binop:s1:s2:d or unop:s1:d or cmpop:s1:s2 ,
where
binop ∈ {add, sub,mul, div, and, or, xor} ,
unop ∈ {not, shl, shr, rol, ror,mov} ,
cmpop ∈ {eq, gt} .
and
13
s1 has one of the following forms: #i or i or @i, where i ∈ N,
s2 has one of the following forms: #i or i or @i, where i ∈ N,
d has one of the following forms: i or @i, where i ∈ N,
We write Asrram for this set of basic RAM instructions. Moreover, we write Src
for the set {#i | i ∈ N} ∪N ∪ {@i | i ∈ N}, Dst for the set N∪ {@i | i ∈ N}, and
Csrram for the set {cmpop:s1:s2 | cmpop ∈ {eq, gt} ∧ s1, s2 ∈ Src}.
The following is a preliminary explanation of basic RAM instructions of the
different forms:
– on execution of an instruction of the form binop:s1:s2:d , the binary operation
named binop is carried out on the values given by s1 and s2 and the content
of the register given by d is changed into the result of this;
– on execution of an instruction of the form unop:s1:d , the unary operation
named unop is carried out on the value given by s1 and the content of the
register given by d is changed into the result of this;
– on execution of an instruction of the form cmpop:s1:s2, the comparison op-
eration named cmpop is carried out on the values given by s1 and s2 and the
result of this is produced as reply.
For each of the basic RAM instructions from Asrram, each operand of the
operation to be carried out on its execution is given in one the following three
ways:
– immediate: it is the shortest bit string representing the natural number i if
s is of the form #i;
– direct addressing: it is the content of the register with number i if s is of the
form i;
– indirect addressing: it is the content of the register whose number is repre-
sented by the content of the register with number i if s is of the form @i.
Except for the comparison instructions, the result of the operation concerned
becomes the content of a register in one the following two ways:
– direct addressing: it becomes the content of the register with number i if d
is of the form i;
– indirect addressing: it becomes the content of the register whose number
is represented by the content of the register with number i if d is of the
form @i.
As mentioned above, in the case of comparison instructions, the result of the
operation concerned becomes the reply produced.
The following kinds of instructions are included in Asrram:
– arithmetic instructions (add, sub,mul, div) for carrying out operations that
model arithmetic operations on natural numbers with respect to their binary
representation by bit strings;
14
– logical instructions (and, or, xor, not) for carrying out bitwise logical opera-
tions on bit strings;
– shift/rotate instructions (shl, shr, rol, ror) for carrying out bit shift and rotate
operations on bit strings;
– data transfer instructions (mov) for copying bit strings;
– comparison instructions (eq, gt) for carrying out comparison operations on
bit strings.
Data transfer instructions can be interpreted as instructions for carrying out the
identity operation on bit strings.
Virtually all common general-purpose instructions of real computers are
essentially variants of the basic RAM instructions from Asrram. Therefore, we
believe that Asrram yields a version of the RAM model of computation that is a
fairly realistic idealization of a real computer.
Above, a special notation is used for the basic RAM instructions from the set
Asrram. In order to use the version of the RAM model of computation with this
set of basic RAM instructions in the setting of PGA/BTA∞/RAM, the special
notation must be related to the notation used in that setting.
9 Realistic RAM Instructions and PGA/BTA∞/RAM
In this section, we relate the special notation for basic RAM instructions used
in Section 8 to the notation used in the setting of PGA/BTA∞/RAM.
We start with defining auxiliary functions for conversion between natural
numbers and bit strings and evaluation of the elements of Src and Dst .
We write ·− for proper subtraction of natural numbers. We write ÷ for zero-
totalized Euclidean division of natural numbers, i.e. Euclidean division made to-
tal by imposing that division by zero yields zero (like in meadows, see e.g. [15,4]).
We use juxtaposition for concatenation of bit strings.
The natural to bit string function b : N → {0, 1}∗ is recursively defined as
follows:
b(b) = b and b(n) = (n mod 2)b(n÷ 2) if n > 1
and the bit string to natural function n : {0, 1}∗ → N is recursively defined as
follows:
n(ǫ) = 0 and n(bw) = 2 · n(w) + b.
These definitions tell us that, when viewed as the binary representation of a
natural number, the first bit of a bit string is considered the least significant
bit. Results of applying b have no leading zeros, but the operand of n may have
leading zeros. Thus, we have that n(b(n)) = n and b(n(w)) = w′, where w′ is w
without leading zeros.
For each σ ∈ Σrm, the src-valuation in σ function vσ :Src → {0, 1}
∗ is defined
as follows:
vσ(#i) = b(i), vσ(i) = σ(i), and vσ(@i) = σ(n(σ(i)))
15
and, for each σ ∈ Σrm, the dst-valuation in σ function rσ :Dst → N is defined as
follows:
rσ(i) = i and rσ(@i) = n(σ(i)).
We define the operations on bit strings that the operation names add, sub,
mul, and div refer to as follows:
+ : {0, 1}∗ × {0, 1}∗ → {0, 1}∗: w1 + w2 = b(n(w1) + n(w2));
·− : {0, 1}∗ × {0, 1}∗ → {0, 1}∗: w1 ·− w2 = b(n(w1) ·− n(w2));
· : {0, 1}∗ × {0, 1}∗ → {0, 1}∗: w1 · w2 = b(n(w1) · n(w2));
÷ : {0, 1}∗ × {0, 1}∗ → {0, 1}∗: w1 ÷ w2 = b(n(w1)÷ n(w2)).
These definitions tell us that, although the operands of the operations +, ·−,
·, and ÷ may have leading zeros, results of applying these operations have no
leading zeros.
We define the operations on bit strings that the operation names and, or, xor,
and not refer to recursively as follows:
∧ : {0, 1}∗ × {0, 1}∗ → {0, 1}∗: ǫ ∧ ǫ = ǫ, ǫ ∧ (bw) = 0(ǫ ∧ w),
(bw) ∧ ǫ = 0(w ∧ ǫ), (b1w1) ∧ (b2w2) = (b1 ∧ b2)(w1 ∧ w2);
∨ : {0, 1}∗ × {0, 1}∗ → {0, 1}∗: ǫ ∨ ǫ = ǫ, ǫ ∨ (bw) = b(ǫ ∨ w),
(bw) ∨ ǫ = b(w ∨ ǫ), (b1w1) ∨ (b2w2) = (b1 ∨ b2)(w1 ∨ w2);
⊕ : {0, 1}∗ × {0, 1}∗ → {0, 1}∗: ǫ⊕ ǫ = ǫ, ǫ⊕ (bw) = b(ǫ ⊕ w),
(bw)⊕ ǫ = b(w ⊕ ǫ), (b1w1)⊕ (b2w2) = (b1 ⊕ b2)(w1 ⊕ w2);
¬ : {0, 1}∗ → {0, 1}∗: ¬ǫ = ǫ, ¬(bw) = (¬b)(¬w).
These definitions tell us that, if the operands of the operations ∧, ∨, and ⊕ do
not have the same length, sufficient leading zeros are assumed to exist. Moreover,
results of applying these operations and results of applying ¬ can have leading
zeros.
We define the operations on bit strings that the operation names shl, shr, rol,
and ror refer to as follows:
≪ : {0, 1}∗ → {0, 1}∗: ≪ǫ = ǫ, ≪(bw) = 0bw;
≫ : {0, 1}∗ → {0, 1}∗: ≫ǫ = ǫ, ≫(bw) = w;
<◦ : {0, 1}∗ → {0, 1}∗: <◦ǫ = ǫ, <◦(wb) = bw;
◦> : {0, 1}∗ → {0, 1}∗: ◦>ǫ = ǫ, ◦>(bw) = wb.
These definitions tell us that results of applying the operations ≪ , ≫ , <◦ , and
◦> can have leading zeros. We have that n(≪w) = n(w)·2 and n(≫w) = n(w)÷2.
16
Now, we are ready to relate the special notation for basic RAM instructions
used in Section 8 to the notation used in the setting of PGA/BTA∞/RAM:
add:s1:s2:d stands for 1/q where q(σ) = (σ : rσ(d) 7→ vσ(s1) + vσ(s2));
sub:s1:s2:d stands for 1/q where q(σ) = (σ : rσ(d) 7→ vσ(s1) ·− vσ(s2));
mul:s1:s2:d stands for 1/q where q(σ) = (σ : rσ(d) 7→ vσ(s1) · vσ(s2));
div:s1:s2:d stands for 1/q where q(σ) = (σ : rσ(d) 7→ vσ(s1)÷ vσ(s2));
and:s1:s2:d stands for 1/q where q(σ) = (σ : rσ(d) 7→ vσ(s1) ∧ vσ(s2));
or:s1:s2:d stands for 1/q where q(σ) = (σ : rσ(d) 7→ vσ(s1) ∨ vσ(s2));
xor:s1:s2:d stands for 1/q where q(σ) = (σ : rσ(d) 7→ vσ(s1)⊕ vσ(s2));
not:s1:d stands for 1/q where q(σ) = (σ : rσ(d) 7→ ¬vσ(s1));
shl:s1:d stands for 1/q where q(σ) = (σ : rσ(d) 7→≪vσ(s1));
shr:s1:d stands for 1/q where q(σ) = (σ : rσ(d) 7→≫vσ(s1));
rol:s1:d stands for 1/q where q(σ) = (σ : rσ(d) 7→<◦vσ(s1));
ror:s1:d stands for 1/q where q(σ) = (σ : rσ(d) 7→ ◦>vσ(s1));
mov:s1:d stands for 1/q where q(σ) = (σ : rσ(d) 7→ vσ(s1));
eq:s1:s2 stands for p/ i where p(σ) = 1 iff n(vσ(s1)) = n(vσ(s2));
gt:s1:s2 stands for p/ i where p(σ) = 1 iff n(vσ(s1)) > n(vσ(s2)).
10 Semi-Realistic RAM Programs
In this section, we introduce a version of the RAM model of computation that
is intended to be a more or less realistic idealization of a real computer. This
version is obtained by restriction of the set of basic RAM instructions considered
in PGA/BTA∞/RAM.
A semi-realistic RAM program, called an SRRAM program for short, is a
closed PGA/BTA∞/RAM term of sort IS that is of the form (t1 ; . . . ; tn)
ω,
where each ti has one of the following forms:
a where a ∈ Asrram \ C
sr
ram;
+a ; #l where a ∈ Csrram and l ∈ N;
#l where l ∈ N;
!.
In the SRRAM model of computation, machines, called SRRAMs, consist of an
SRRAM program together with a RAM memory on which it operates during
execution.
17
A standard RAM program is an SRRAM program in which only addition in-
structions, subtraction instructions, data transfer instructions, and comparison
instructions occur (cf. [18]). A successor RAM program is an SRRAM program
in which only addition instructions of the form add:s1:#1:d, data transfer in-
structions, and comparison instructions occur (cf. [30]).
The following theorem is a result concerning the computational power of
SRRAM programs.
Theorem 1. For each F :({0, 1}∗)
n
7→ {0, 1}∗, there exists an SRRAM program
P such that P computes F iff F is Turing-computable.
Proof. The SRRAM model of computation is essentially the same as the
MBRAM model of computation from [21] extended with shift/rotate instruc-
tions. It follows directly from simulation results mentioned in [21] (part (5) of
Theorem 2.4, part (1) of Theorem 2.5, and part (3) of Theorem 2.6) that each
MBRAM can be simulated by a Turing machine and vice versa. Because each
Turing machine can be simulated by a MBRAM, we immediate have that each
Turing machine can be simulated by an SRRAM. It is easy to see that the
shift/rotate instructions can be simulated by a Turing machine. From this and
the fact that each MBRAM can be simulated by a Turing machine, it follows
that each SRRAM can be simulated by a Turing machine as well. Hence, each
SRRAM is Turing equivalent to a Turing machine. From this, the theorem fol-
lows immediately. ⊓⊔
Henceforth, we write POLY for {T | T :N→ N∧T is a polynomial function}.
The following theorem is a result relating the complexity class PSPACE
to the functions from {0, 1}∗ to {0, 1} that can be computed by an SRRAM
program in polynomial time.
Theorem 2. For each F : {0, 1}∗ → {0, 1}, there exist an SRRAM program P
and a T ∈ POLY such that P computes F in time T under the uniform time
measure if F ∈ PSPACE.
Proof. The SRRAM model of computation is essentially the same as the MRAM
model of computation from [24] extended with division and shift/rotate instruc-
tions. We know from Theorem 2 in that paper that, for each F :{0, 1}∗ → {0, 1},
there even exists an SRRAM program P in which division and shift/rotate in-
structions do not occur and a T ∈ POLY such that P computes F in time T
under the uniform time measure if F ∈ PSPACE. ⊓⊔
Theorem 2 tell us that all decision problems that belong to PSPACE can be
solved by means of a SRRAM program in polynomial time. This means that it is
highly questionable whether the SRRAM model of computation is a reasonable
model of computation. However, it can be made a reasonable model by switching
from the uniform time measure to another time measure. Such a time measure
is introduced in Section 11.
The proof of Theorem 2 reveals that the theorem still holds if division and
shift/rotate instructions are excluded from the SRRAM programs. It turns out
that we get another result if multiplication instructions are excluded as well.
18
Theorem 3. For each F : {0, 1}∗ → {0, 1}, there exist an SRRAM program P
in which multiplication, division, and shift/rotate instructions do not occur and
a T ∈ POLY such that P computes F in time T under the uniform time measure
iff F ∈ P.
Proof. The model of computation obtained by excluding multiplication, divi-
sion, and shift/rotate instructions from the SRRAM programs is the standard
RAM model of computation extended with logical instructions. From Theorem 2
in [18], we know that time complexity on standard RAMs under the uniform time
measure and time complexity on multi-tape Turing machines are polynomially
related. It is easy to see that the logical instructions can be simulated by a
multi-tape Turing machine in linear time. Hence, the time complexities remain
polynomially related if the standard RAM model is extended with logical in-
structions. From this, the theorem follows immediately. ⊓⊔
11 A Bit-Oriented Time Measure for SRRAM Programs
In this section, we introduce a time measure for the SRRAM model of com-
putation that has it origin in the idea that the time that it takes to execute
an instruction on an SRRAM should be based on the number of steps that
a multi-tape Turing machine with input alphabet {0, 1} needs to simulate the
instruction. The choice have been made to use well-known polynomial upper
bounds, but lesser upper bounds that are not polynomial could have been used
instead.
We write CT for the set of all closed PGA/BTA
∞/RAM terms of sort T.
We define a family c of partial non-uniform cost functions cσ : CT 7→ N, one
for each σ ∈ Σrm, recursively as follows:
cσ(S) = 0 ,
cσ(tEp/qD t
′) = cσ(p/q) + cq(σ)(t) if p(σ) = 1 ,
cσ(tEp/qD t
′) = cσ(p/q) + cq(σ)(t
′) if p(σ) = 0 ,
where the family of partial functions cσ :Aram 7→ N (defined for all basic RAM
instructions from Asrram), one for each σ ∈ Σrm, is defined as follows:
cσ(binop:s1:s2:d) = max{cσ(s1), cσ(s2)} if binop /∈ {mul, div} ,
cσ(binop:s1:s2:d) = cσ(s1) · cσ(s2) if binop ∈ {mul, div} ,
cσ(unop:s1:d) = cσ(s1) ,
cσ(cmpop:s1:s2) = max{cσ(s1), cσ(s2)} ,
where the family of total functions cσ :Src → N, one for each σ ∈ Σrm, is defined
as follows:
19
cσ(#i) = ℓ(b(i)) ,
cσ(i) = ℓ(b(i)) + ℓ(vσ(i)) ,
cσ(@i) = ℓ(b(i)) + ℓ(vσ(i)) + ℓ(vσ(n(vσ(i)))) .
Let t be a closed PGA/BTA∞/RAM term of sort IS, let n ∈ N, let F :
({0, 1}∗)n 7→ {0, 1}∗, and let T :N→ N. Then t computes F in time T under the
bit-oriented time measure if:
– for all w1, . . . , wn ∈ {0, 1}
∗ such that F (w1, . . . , wn) is defined, there exist a
σ ∈ Σrm such that:
|t| • rm((σǫ : 1 7→ w1, . . . , n 7→ wn)) = rm((σ : 0 7→ F (w1, . . . , wn))) ,
c(σǫ:17→w1,...,n7→wn)(|t|) ≤ T (ℓ(w1) + . . .+ ℓ(wn)) ;
– for all w1, . . . , wn ∈ {0, 1}
∗ such that F (w1, . . . , wn) is undefined:
|t| • rm((σǫ : 1 7→ w1, . . . , n 7→ wn)) = rm(∗) .
Fine-tuning this definition boils down to adapting the definition of the family of
partial functions cσ :Aram 7→ N.
The parts of Theorem 2 from [18] that concern standard RAMs under the
logarithmic time measure hold also for SRRAMs under the bit-oriented time
measure.
Theorem 4. For each F : ({0, 1}∗)n 7→ {0, 1}∗, there exist an SRRAM program
P and a T :N→ N such that P computes F in time T under the bit-oriented time
measure iff there exists a multi-tape Turing machine M such that M computes
F in time O(T 2).
Proof. The proof of this theorem relies heavily on the proof of Theorem 2
from [18]. That theorem is stated for all total functions from {0, 1}∗ to {0, 1} in-
stead of all partial functions from ({0, 1}∗)
n
to {0, 1}∗. However, the proof does
not depend on this restriction. Therefore, we talk below about that theorem as
if it is stated for all partial functions from ({0, 1}∗)
n
to {0, 1}∗.
Part (i) of part (a) of Theorem 2 from [18] essentially states that the theorem
holds in the “only if” direction under the logarithmic time measure if P is a
standard RAM program. It is easy to see that the proof of this part goes through
under the bit-oriented time measure if P is an SRRAM program.
Part (b) of Theorem 2 from [18] essentially states that a stronger version of
the theorem holds in the “if” direction under the logarithmic time measure if
P is a standard RAM program. Because the logarithmic time measure coincides
with the bit-oriented time measure for standard RAM programs, the theorem
also holds under the bit-oriented time measure if P is a standard RAM program.
Because a standard RAM program is also a SRRAM program, we are done. ⊓⊔
The following corollary of Theorem 4 is a counterpart of Theorem 3.
Corollary 1. For each F : ({0, 1}∗)
n
→ {0, 1}, there exist an SRRAM program
P and a T ∈ POLY such that P computes F in time T under the bit-oriented
time measure iff F ∈ P.
20
12 A Bit-Oriented Space Measure for SRRAM Programs
In this section, we introduce for completeness sake a bit-oriented space measure
for the SRRAM model of computation. This space measure originates from [21].
Let t be a closed PGA/BTA∞/RAM term of sort IS, let n ∈ N, let F :
({0, 1}∗)n 7→ {0, 1}∗, and let S : N → N. Then t computes F in space S if t
computes F and, for all w1, . . . , wn ∈ {0, 1}
∗ such that F (w1, . . . , wn) is defined,
for some m ∈ N1, there exist closed PGA/BTA
∞/RAM terms t1, . . . , tm of sort
T and RAM memory states σ1, . . . , σm such that:
– t1 = |t|;
– tm = S;
– σ1(i) = ǫ for all i ∈ N with i /∈ {1, . . . , n};
– σj(i) = wi for all i ∈ {1, . . . , n} and j ∈ {1, . . . ,m};
– σm(0) = F (w1, . . . , wn);
– for all j ∈ {1, . . . ,m}, tj • rm(σj) = tj+1 • rm(σj+1) is a closed substitution
instance of an instance of axiom schema A4 or A5;
– max{
∑
i∈N\{1,...,n}(ℓ(i)+ℓ(σj(i))) | j ∈ {1, . . . ,m}} ≤ S(ℓ(w1)+. . .+ℓ(wn)).
The pairs (tj , σj), for j ∈ {1, . . . ,m}, can be looked upon as SRRAM configu-
rations and the sequence (t1, σ1) . . . (tm, σm) can be looked upon as a SRRAM
computation. Instead of introducing off-line SRRAMs, we require that during
computations the contents of the input registers are never changed.
In the above definition space is essentially measured following the third
method mentioned in [21], using the function sizeb from that paper as size func-
tion. By this space measure, it is guaranteed that space complexity on SRRAMs
and space complexity on multi-tape Turing machines are related by a constant
factor.
13 Discussion on the Bit-Oriented Time Measure
In the field of computational complexity, a model of computation is consid-
ered a reasonable model of computation if time complexity on its machines and
time complexity on multi-tape Turing machines are polynomially related and
space complexity on its machines and space complexity on multi-tape Turing
machines are related by a constant factor.5 This makes the complexity classes
that represent the fundamental concepts of computational complexity machine-
independent insofar as reasonable models of computation are concerned.
The logarithmic time measure has been introduced in all but the simplest
known versions of the RAM model of computation to obtain a reasonable model.
However, it is questionable whether the logarithmic time measure is the most
natural time measure. It takes the lengths of the bit strings involved in the
execution of an instruction into account, but not the operation involved. The
5 In either direction, the polynomial overhead in time complexity and the constant-
factor overhead in space complexity should be simultaneously achievable.
21
logarithmic time measure works in the case of the known versions of the RAM
model of computation only because the operations involved can always be sim-
ulated by a multi-tape Turing machine in polynomial time.
The bit-oriented time measure introduced in this paper takes both the opera-
tion and the lengths of the bit strings involved in the execution of an instruction
into account. Thereby, the bit-oriented time measure actually takes the total
number of operations on bits involved in the execution of an instruction into ac-
count. This property is arguably the best justification of a time measure intended
to make the time measures of different models of computation comparable.
With {0, 1} as input alphabet, a version of the Turing machine model of
computation supports operations on bits more directly than most other well-
known models of computation. This has been an important reason to consider
in this paper the times that it takes to carry out the operations on bits in the
setting of a version of the Turing machine model. Another important reason
has been that the complexity classes that represent the fundamental concepts of
computational complexity were initially introduced and studied in the setting of
the multi-tape Turing machine model.
The extended logarithmic time measure introduced in [19] also takes the
total number of operations on bits involved in the execution of an instruction
into account, but, there, the choice is made to consider the times that it takes
to carry out the operations on bits in the setting of the successor RAM model.
This is the most primitive version of the RAM model and supports operations on
bits equally directly as multi-tape Turing machine model. The approach of [19]
may be advantageous if one is interested in relating complexity results based on
other versions of the RAM model to complexity results based on the successor
RAM model, but is disadvantageous if one is interested in relating complexity
results based on versions of the RAM model to complexity results based on the
multi-tape Turing machine model.
The idea behind the bit-oriented time measure from this paper is that the
time that it takes to execute an instruction on an SRRAM should be based on
the number of steps that a multi-tape Turing machine with input alphabet {0, 1}
needs to simulate the instruction. Moreover, the choice has been made to use
upper bounds. By producing the bit-oriented measure in this way for programs
of RAMs of a kind obtained by restricting the set of basic RAM instructions of
PGA/BTA∞/RAM in another way than for SRRAM programs, it is guaranteed
that Theorem 4 holds for these programs as well. Examination of the proof of
that theorem learns us that it depends only on the choice to use upper bounds
for the number of steps that a multi-tape Turing machine with input alphabet
{0, 1} needs to simulate the instructions that may occur in the programs.
14 Concluding Remarks
We have presented an instantiation of a parameterized algebraic theory of single-
pass instruction sequences, the behaviours produced by such instruction se-
quences under execution, and the interaction between such behaviours and com-
22
ponents of an execution environment for instruction sequences. In the instanti-
ation concerned, RAM memories are taken as the components of an execution
environment, instructions for a RAM are taken as basic instructions, and an
execution environment consists of only one component. Because we have opted
for the most general instantiation, all instructions that do not read out or alter
more than one register from the RAM memory are taken as basic instructions.
The presentation of the instantiation has been set up in such a way that
the introduction of services, the generic kind of execution-environment compo-
nents from the parameterized theory, is circumvented. In [12], the presentation
of another instantiation of the same parameterized theory has been set up in the
same way. The distinguishing feature of this way of presenting an instantiation
of the parameterized theory is that it yields a less involved presentation than
the way adopted in earlier work based on an instantiation of this parameterized
theory.
We have provided evidence for the claim that the presented algebraic theory
provides a setting for the development of theory in areas such as computational
complexity and analysis of algorithms that is more general than the setting
provided by some known version of the RAM model of computation. We have
among other things shown that a relatively unknown, but realistic, version of
the RAM model can be dealt with in the setting concerned by imposing apposite
restrictions. For this model, an alternative to the usual time measures for versions
of the RAM model, called the bit-oriented time measure has been introduced.
Related to the introduction of the bit-oriented time measure is the choice for
registers that contain bit strings instead of natural numbers. Whereas it is usual
in versions of the RAM model of computation that bit strings are represented by
natural numbers, here natural numbers are represented by bit strings. Moreover,
the choice has been made to represent the natural number 0 by the bit string 0
and to adopt the empty bit string as the register content that indicates that a
register is (as yet) unused. Therefore, we have, as in most other versions of the
RAM model, ℓ(0) = 1 and ℓ(i + 1) = ⌊log2(i + 1)⌋ + 1 if ℓ on natural numbers
is simply defined by ℓ(i) = ℓ(b(i)).
The closed terms of the presented algebraic theory that are used as RAM
programs can be considered to constitute a programming language of which
the syntax and semantics is defined following an algebraic approach. However,
this approach is more operational than the usual algebraic approach, which is
among other things followed in [16,17,23]. The more operational approach is
advantageous in the case of a language that is used to investigate issues in the
areas of computational complexity and analysis of algorithms.
The work presented in this paper is among other things concerned with for-
malization in areas such as computational complexity and analysis of algorithms.
To the best of our knowledge, very little work has been done in this area. Three
notable exceptions are [27,32,2]. However, those papers are concerned with for-
malization in a theorem prover (HOL4, Isabelle/HOL, Matita) and focussed on
some version of the Turing machine model of computation. This makes it imprac-
ticable to compare the work presented in those papers with the work presented
23
in this paper. The above-mentioned contributions of this paper to work on mod-
els of computation rely heavily on [18,24]. A variant of the bit-oriented time
measure has been proposed in [19].
References
1. Aho, A.V., Hopcroft, J.E., Ullman, J.D.: The Design and Analysis of Computer
Algorithms. Addison-Wesley, Reading, MA (1974)
2. Asperti, A., Ricciotti, W.: A formalization of multi-tape Turing machines. Theo-
retical Computer Science 603, 23–42 (2015)
3. Bergstra, J.A., Loots, M.E.: Program algebra for sequential code. Journal of Logic
and Algebraic Programming 51(2), 125–156 (2002)
4. Bergstra, J.A., Middelburg, C.A.: Inversive meadows and divisive meadows. Jour-
nal of Applied Logic 9(3), 203–220 (2011)
5. Bergstra, J.A., Middelburg, C.A.: Instruction sequence processing operators. Acta
Informatica 49(3), 139–172 (2012)
6. Bergstra, J.A., Middelburg, C.A.: Instruction Sequences for Computer Science,
Atlantis Studies in Computing, vol. 2. Atlantis Press, Amsterdam (2012)
7. Bergstra, J.A., Middelburg, C.A.: Instruction sequence expressions for the secure
hash algorithm SHA-256. arXiv:1308.0219v7 [cs.PL] (August 2013)
8. Bergstra, J.A., Middelburg, C.A.: Instruction sequence based non-uniform com-
plexity classes. Scientific Annals of Computer Science 24(1), 47–89 (2014)
9. Bergstra, J.A., Middelburg, C.A.: On algorithmic equivalence of instruction se-
quences for computing bit string functions. Fundamenta Informaticae 138(4), 411–
434 (2015)
10. Bergstra, J.A., Middelburg, C.A.: Instruction sequence size complexity of parity.
Fundamenta Informaticae 149(3), 297–309 (2016)
11. Bergstra, J.A., Middelburg, C.A.: Instruction sequences expressing multiplication
algorithms. Scientific Annals of Computer Science 28(1), 39–66 (2018)
12. Bergstra, J.A., Middelburg, C.A.: A short introduction to program algebra with
instructions for Boolean registers. Computer Science Journal of Moldova 26(3),
199–232 (2018)
13. Bergstra, J.A., Middelburg, C.A.: Program algebra for Turing-machine programs.
Scientific Annals of Computer Science 29(2), 113–139 (2019)
14. Bergstra, J.A., Middelburg, C.A.: On the complexity of the correctness problem for
non-zeroness test instruction sequences. Theoretical Computer Science 802, 1–18
(2020)
15. Bergstra, J.A., Tucker, J.V.: The rational numbers as an abstract data type. Jour-
nal of the ACM 54(2), Article 7 (2007)
16. Broy, M., Dosch, W., Mo¨ller, B., Wirsing, M.: GOTOs – a study in the algebraic
specification of programming languages (extended abstract). In: Brauwer, W. (ed.)
GI — 11. Jahrestagung. Informatik-Fachberichte, vol. 50, pp. 109–121. Springer-
Verlag (1981)
17. Broy, M., Wirsing, M., Pepper, P.: On the algebraic definition of programming
languages. ACM Transactions on Programming Languages and Systems 9(1), 54–
99 (1987)
18. Cook, S.A., Reckhow, R.A.: Time bounded random access machine. Journal of
Computer and System Sciences 7(4), 354–375 (1973)
24
19. Diem, C.: On the notion of bit complexity. Bulletin of the EATCS 103, 36–52
(2011)
20. Ehrig, H., Mahr, B.: Fundamentals of Algebraic Specification I: Equations and
Initial Semantics, EATCS Monographs, vol. 6. Springer-Verlag, Berlin (1985)
21. van Emde Boas, P.: Machine models and simulations. In: van Leeuwen, J. (ed.)
Handbook of Theoretical Computer Science, vol. A, pp. 2–66. Elsevier, Amsterdam
(1990)
22. van Glabbeek, R.J., Vaandrager, F.W.: Modular specification of process algebras.
Theoretical Computer Science 113(2), 293–348 (1993)
23. Goguen, J.A., Malcolm, G.: Algebraic Semantics of Imperative Programs. Foun-
dations of Computing, MIT Press, Cambridge, MA (1996)
24. Hartmanis, J., Simon, J.: On the power of multiplication in random access ma-
chines. In: SWAT ’74. pp. 13–23. IEEE (1974)
25. Middelburg, C.A.: Instruction sequences as a theme in computer science.
https://instructionsequence.wordpress.com/ (2015)
26. Moret, B.M.: The Theory of Computation. Addison-Wesley, Reading, MA (1998)
27. Norrish, M.: Mechanised computability theory. In: van Eekelen, M., Geuvers, H.,
Schmaltz, J., Wiedijk, F. (eds.) ITP 2011. Lecture Notes in Computer Science, vol.
6898, pp. 297–311. Springer-Verlag (2011)
28. Papadimitriou, C.H.: Computational Complexity. Addison-Wesley, Reading, MA
(1994)
29. Sannella, D., Tarlecki, A.: Foundations of Algebraic Specification and Formal Soft-
ware Development. Monographs in Theoretical Computer Science, An EATCS Se-
ries, Springer-Verlag, Berlin (2012)
30. Scho¨nhage, A.: On the power of random access machines. In: Maurer, H.A. (ed.)
ICALP’79. Lecture Notes in Computer Science, vol. 71, pp. 520–529. Springer-
Verlag (1979)
31. Wirsing, M.: Algebraic specification. In: van Leeuwen, J. (ed.) Handbook of The-
oretical Computer Science, vol. B, pp. 675–788. Elsevier, Amsterdam (1990)
32. Xu, J., Zhang, X., Urban, C.: Mechanising Turing machines and computability
theory in Isabelle/HOL. In: Blazy, S., Paulin-Mohring, C., Pichardie, D. (eds.)
ITP 2013. Lecture Notes in Computer Science, vol. 7998, pp. 147–162. Springer-
Verlag (2013)
25
