 
 
 
 
 
 
   
Our specification language is linear temporal logic (LTL), 
with program point predicates  as atomic propositions
but omitting the type predicate
 as atomic propositions
but omitting the type predicate  . 
The choice of linear temporal logic as the specification language, 
instead of for instance the modal
. 
The choice of linear temporal logic as the specification language, 
instead of for instance the modal  -calculus for which 
the model checking problem for our encoding
into pushdown systems
is also efficiently decidable, was solely motivated by the existence
of the efficient model checker Moped [8] for LTL.
-calculus for which 
the model checking problem for our encoding
into pushdown systems
is also efficiently decidable, was solely motivated by the existence
of the efficient model checker Moped [8] for LTL.
The operators of the logic
are the standard ones. If  and
and  are formulas then so are
 are formulas then so are
 ,
, 
 ,
, 
 ,
,
 and
 and
 .
The meaning of formulas is defined with respect
to runs of infinite length
.
The meaning of formulas is defined with respect
to runs of infinite length 
 . We let
. We let  denote
the suffix of
 denote
the suffix of  starting in configuration
 starting in configuration  .
Then satisfaction
.
Then satisfaction 
 of a formula
of a formula  by a run
 by a run  is
defined as:
 is
defined as:
|  | iff | point  | 
|  | iff | not  | 
|  | iff |  and  | 
|  | iff |  or  | 
|  | iff |  | 
|  | iff | there is an  such that | 
|  and  | ||
| for all  | 
Henceforth
let 
 abbreviate
 abbreviate 
 for some atomic predicate
 for some atomic predicate  ,
,
 abbreviate
 abbreviate 
 ,
,
 abbreviate
 abbreviate 
 ,
and
,
and 
 abbreviate
 abbreviate 
 and
and 
 abbreviate
 abbreviate 
 .
Further define
.
Further define
 and
 and
 .
The weak until operator
.
The weak until operator 
 abbreviates
abbreviates 
 .
Finally let
.
Finally let 
 .
.
Given a PDS 
 let the notation
let the notation
 express the judgement that all
runs starting in the entry program point of
the method
express the judgement that all
runs starting in the entry program point of
the method  satisfy
 satisfy  .
More formally:
.
More formally:
 with the single control location
 with the single control location
 and a method
 and a method  , 
the judgement
, 
the judgement
 is valid
iff
for every run
is valid
iff
for every run  of the PDS
 of the PDS 
 from the initial configuration
from the initial configuration
 ,
,
 holds,
where
 holds,
where  is the entry program point of 
method
 is the entry program point of 
method  (i.e.
 (i.e. 
 entry
   entry  ), and
), and
 is the PDS
 is the PDS 
 extended with the fresh stack symbol
extended with the fresh stack symbol 
 and the single rewrite rule
and the single rewrite rule
 to achieve infinite runs.
to achieve infinite runs.
The definition of a judgement 
 is
motivated by the Moped tool which implements
an algorithm for checking an
initial configuration against an LTL formula.
 is
motivated by the Moped tool which implements
an algorithm for checking an
initial configuration against an LTL formula.
 
 
 
 
