@@ -277,7 +301,7 @@
Logical Structure of the Specification
The source files are grouped in planes and components
according to the following table.
- A notation file covering the whole specification is provided.
+ Notation files covering the whole specification are provided.
The notation for the relations or functions introduced in each file
is shown in parentheses (? are placeholders).
@@ -300,33 +324,9 @@
dynamic typing |
- "big tree" parallel computation |
- yprs ( ? ⢠â¦?,?⦠â¥[g] â¦?,?⦠) |
- yprs_yprs |
- ygt ( ? ⢠�,?⦠>[g] �,?⦠) |
- ygt_ygt |
-
-
-
-
- |
- "big tree" parallel reduction |
- ypr ( ? ⢠â¦?,?⦠â½[g] â¦?,?⦠) |
- ysc ( ? ⢠â¦?,?⦠â»[g] â¦?,?⦠) |
-
-
- |
-
-
- |
-
-
-
-
- |
local env. ref. for stratified native validity |
- lsubsv ( ? ⢠? ¡â[?] ? ) |
- lsubsv_ldrop lsubsv_lsuba lsubsv_ssta lsubsv_dxprs lsubsv_cpcs lsubsv_snv |
+ lsubsv ( ? ⢠? ¡â[?,?] ? ) |
+ lsubsv_ldrop lsubsv_lsubd lsubsv_lsuba lsubsv_lsstas lsubsv_cpds lsubsv_cpcs lsubsv_snv |
|
@@ -339,8 +339,8 @@
stratified native validity |
- snv ( �,?⦠⢠? ¡[?] ) |
- snv_lift snv_ltpss_dx snv_ltpss_sn snv_aaa snv_ssta snv_sstas snv_ssta_ltpr snv_ltpr snv_cpcs |
+ snv ( �,?⦠⢠? ¡[?,?] ) |
+ snv_lift snv_da_lpr snv_aaa snv_lsstas snv_lsstas_lpr snv_lpr snv_cpcs |
|
@@ -350,9 +350,9 @@
equivalence |
- local env. ref. for stratified static type assignment |
- lsubss ( ? â¢â[?] ? ) |
- lsubss_ldrop lsubss_ssta lsubss_cpcs |
+ decomposed extended equivalence |
+ cpes ( â¦?,?⦠⢠? â¢*â¬*[?,?] ? ) |
+ cpes_cpds |
|
@@ -365,8 +365,8 @@
context-sensitive equivalence |
- cpcs ( ? ⢠? â¬* ? ) |
- cpcs_lpss cpcs_aaa cpcs_cprs cpcs_cpcs |
+ cpcs ( â¦?,?⦠⢠? â¬* ? ) |
+ cpcs_aaa cpcs_cprs cpcs_cpcs |
|
@@ -377,7 +377,7 @@
conversion |
context-sensitive conversion |
- cpc ( ? ⢠? ⬠? ) |
+ cpc ( �,?⦠⢠? ⬠? ) |
cpc_cpc |
@@ -388,9 +388,83 @@
|
computation |
- decomposed extended computation |
- dxprs ( â¦?,?⦠⢠? â¢*â¡*[?] ? ) |
- dxprs_lift dxprs_lpss dxprs_aaa dxprs_dxprs |
+ evaluation for context-sensitive extended reduction |
+ cpxe ( â¦?,?⦠⢠â¡*[?,?] ðâ¦?⦠) |
+
+
+ |
+
+
+ |
+
+
+ |
+
+
+
+
+ |
+ evaluation for context-sensitive reduction |
+ cpre ( â¦?,?⦠⢠â¡* ðâ¦?⦠) |
+ cpre_cpre |
+
+
+ |
+
+
+ |
+
+
+
+
+ |
+ strongly normalizing "big tree" computation |
+ fsb ( �,?⦠⢠⦥[?,?] ? ) |
+ fsb_alt ( �,?⦠⢠⦥⦥[?,?] ? ) |
+ fsb_aaa fsb_csx |
+
+
+ |
+
+
+
+
+ |
+ strongly normalizing extended computation |
+ lcosx ( ? ⢠⧤â¬*[?,?,?] ? ) |
+ lcosx_cpxs |
+
+
+ |
+
+
+ |
+
+
+
+
+ |
+
+
+ |
+ lsx ( ? ⢠ââ¬*[?,?,?,?] ? ) |
+ lsx_ldrop lsx_cpxs lsx_csx |
+
+
+ |
+
+
+ |
+
+
+
+
+ |
+
+
+ |
+ csx_vector ( â¦?,?⦠⢠â¬*[?,?] ? ) |
+ csx_tstc_vector csx_aaa |
|
@@ -402,9 +476,23 @@
|
- weakly normalizing computation |
- cpe ( ? ⢠â¡* ðâ¦?⦠) |
- cpe_cpe |
+
+
+ |
+ csx ( â¦?,?⦠⢠â¬*[?,?] ? ) |
+ csx_alt ( â¦?,?⦠⢠â¬â¬*[?,?] ? ) |
+ csx_lift csx_lpx csx_lpxs csx_fpbs |
+
+
+ |
+
+
+
+
+ |
+ "big tree" parallel computation |
+ fpbg ( â¦?,?,?⦠>â[?,?] â¦?,?,?⦠) |
+ fpbg_lift fpbg_fpns fpbg_fpbg |
|
@@ -416,9 +504,11 @@
|
- strongly normalizing computation |
- csn_vector ( ? ⢠â¬* ? ) |
- csn_tstc_vector csn_aaa |
+
+
+ |
+ fpbc ( â¦?,?,?⦠â»â[?,?] â¦?,?,?⦠) |
+ fpbc_fpns fpbc_fpbs |
|
@@ -433,9 +523,81 @@
|
- csn ( ? ⢠â¬* ? ) |
- csn_alt ( ? ⢠â¬â¬* ? ) |
- csn_lift csn_lpr |
+ fpbu ( â¦?,?,?⦠â»[?,?] â¦?,?,?⦠) |
+ fpbu_lift fpbu_fpns |
+
+
+ |
+
+
+ |
+
+
+
+
+ |
+
+
+ |
+ fpbs ( â¦?,?,?⦠â¥[?,?] â¦?,?,?⦠) |
+ fpbs_alt ( â¦?,?,?⦠â¥â¥[?,?] â¦?,?,?⦠) |
+ fpbs_lift fpbs_aaa fpbs_fpns fpbs_fpbs fpbs_ext |
+
+
+ |
+
+
+
+
+ |
+ parallel computation for "big tree" normal forms |
+ fpns ( â¦?,?,?⦠⢠ââ¡*[?,?] â¦?,?,?⦠) |
+ fpns_fpns |
+
+
+ |
+
+
+ |
+
+
+
+
+ |
+ decomposed extended computation |
+ cpds ( â¦?,?⦠⢠? â¢*â¡*[?,?] ? ) |
+ cpds_lift cpds_aaa cpds_cpds |
+
+
+ |
+
+
+ |
+
+
+
+
+ |
+ context-sensitive extended computation |
+ lpxs ( â¦?,?⦠⢠â¡*[?,?] ? ) |
+ lpxs_alt ( â¦?,?⦠⢠â¡â¡*[?,?] ? ) |
+ lpxs_ldrop lpxs_lleq lpxs_aaa lpxs_cpxs lpxs_lpxs |
+
+
+ |
+
+
+
+
+ |
+
+
+ |
+ cpxs ( â¦?,?⦠⢠? â¡*[?,?] ? ) |
+ cpxs_tstc cpxs_tstc_vector cpxs_lift cpxs_cpys cpxs_lleq cpxs_aaa cpxs_cpxs |
+
+
+ |
|
@@ -445,9 +607,9 @@
context-sensitive computation |
- lprs ( ? ⢠â¡* ? ) |
- lprs_alt ( ? ⢠â¡â¡* ? ) |
- lprs_ldrop lprs_lpss lprs_aaa lprs_cprs lprs_lprs |
+ lprs ( â¦?,?⦠⢠â¡* ? ) |
+ lprs_alt ( â¦?,?⦠⢠â¡â¡* ? ) |
+ lprs_ldrop lprs_cprs lprs_lprs |
|
@@ -459,8 +621,8 @@
|
- cprs ( ? ⢠? â¡* ?) |
- cprs_tstc cprs_tstc_vector cprs_lift cprs_lpss cprs_aaa cprs_cprs |
+ cprs ( â¦?,?⦠⢠? â¡* ?) |
+ cprs_lift cprs_cprs |
|
@@ -473,7 +635,7 @@
local env. ref. for abstract candidates of reducibility |
- lsubc ( ? â[?] ? ) |
+ lsubc ( ? ⢠? â[?] ? ) |
lsubc_ldrop lsubc_ldrops lsubc_lsuba |
@@ -488,7 +650,7 @@
|
support for abstract computation properties |
acp |
- acp_cr ( â¦?,?⦠ϵ[?] ã?ã ) |
+ acp_cr ( â¦?,?,?⦠ϵ[?] ã?ã ) |
acp_aaa |
@@ -496,9 +658,9 @@
|
reduction |
- context-sensitive normal forms |
- cnf ( ? ⢠ðâ¦?⦠) |
- cnf_liftt cnf_crf cnf_cif |
+ "big tree" parallel reduction |
+ fpb ( â¦?,?,?⦠â½[?,?] â¦?,?,?⦠) |
+ fpb_lift fpb_aaa |
|
@@ -510,9 +672,23 @@
|
- context-sensitive reduction |
- lpr ( ? ⢠⡠? ) |
- lpr_ldrop lpr_lpss lpr_aaa lpr_lpr |
+ normal forms for context-sensitive extended reduction |
+ cnx ( â¦?,?⦠⢠â¡[?,?] ðâ¦?⦠) |
+ cnx_lift cnx_crx cnx_cix |
+
+
+ |
+
+
+ |
+
+
+
+
+ |
+ context-sensitive extended reduction |
+ lpx ( â¦?,?⦠⢠â¡[?,?] ? ) |
+ lpx_ldrop lpx_cpys lpx_lleq lpx_aaa |
|
@@ -527,8 +703,8 @@
|
- cpr ( ? ⢠? ⡠? ) |
- cpr_lift cpr_cif |
+ cpx ( â¦?,?⦠⢠? â¡[?,?] ? ) |
+ cpx_lift cpx_cpys cpx_lleq cpx_cix |
|
@@ -540,46 +716,106 @@
|
- context-sensitive reducible forms |
- crf ( ? ⢠ðâ¦?⦠) |
- crf_append |
- cif ( ? ⢠ðâ¦?⦠) |
- cif_append |
+ irreducible forms for context-sensitive extended reduction |
+ cix ( â¦?,?⦠⢠â¡[?,?] ðâ¦?⦠) |
+ cix_lift |
+
+
+ |
+
+
+ |
- unfold |
- restricted parallel computation |
- lpqs ( ? ⢠â¤* ? ) |
- lpqs_ldrop lpqs_cpqs lpqs_lpqs |
-
+ |
|
-
+ | reducible forms for context-sensitive extended reduction |
+ crx ( â¦?,?⦠⢠â¡[?,?] ðâ¦?⦠) |
+ crx_lift |
+
+
+ |
+
|
-
+ |
|
-
+ | normal forms for context-sensitive reduction |
+ cnr ( â¦?,?⦠⢠⡠ðâ¦?⦠) |
+ cnr_lift cnr_crr cnr_cir |
+
|
- cpqs ( ? ⢠? â¤* ? ) |
- cpqs_lift |
-
+ |
|
-
+ |
+
+
+
+ |
+ context-sensitive reduction |
+ lpr ( �,?⦠⢠⡠? ) |
+ lpr_ldrop lpr_lpr |
+
+
+ |
+
|
-
+ |
|
+
+
+ |
+ cpr ( �,?⦠⢠? ⡠? ) |
+ cpr_lift cpr_cir |
+
+
+ |
+
+
+ |
+
+
+
+
+ |
+ irreducible forms for context-sensitive reduction |
+ cir ( â¦?,?⦠⢠⡠ðâ¦?⦠) |
+ cir_lift |
+
+
+ |
+
+
+ |
+
+
+
+
+ |
+ reducible forms for context-sensitive reduction |
+ crr ( â¦?,?⦠⢠⡠ðâ¦?⦠) |
+ crr_lift |
+
+
+ |
+
+
+ |
+
+
+ unfold |
unfold |
- unfold ( ? ⢠? ⧫* ? ) |
+ unfold ( �,?⦠⢠? ⧫* ? ) |
|
@@ -594,21 +830,19 @@
|
- iterated stratified static type assignment |
- sstas ( â¦?,?⦠⢠? â¢*[?] ? ) |
- sstas_lift sstas_lpss sstas_aaa sstas_sstas |
-
-
- |
+ iterated static type assignment |
+ lsstas ( â¦?,?⦠⢠? â¢*[?,?,?] ? ) |
+ lsstas_alt ( â¦?,?⦠⢠? â¢â¢*[?,?,?] ? ) |
+ lsstas_lift lsstas_aaa lsstas_lsstas |
|
static typing |
- stratified static type assignment |
- ssta ( â¦?,?⦠⢠? â¢[?,?] ? ) |
- ssta_lift ssta_lpss ssta_aaa ssta_ssta |
+ local env. ref. for atomic arity assignment |
+ lsuba ( ? ⢠? ââ ? ) |
+ lsuba_ldrop lsuba_aaa lsuba_lsuba |
|
@@ -620,9 +854,9 @@
|
- local env. ref. for atomic arity assignment |
- lsuba ( ? ââ ? ) |
- lsuba_ldrop lsuba_aaa lsuba_lsuba |
+ atomic arity assignment |
+ aaa ( â¦?,?⦠⢠? â ? ) |
+ aaa_lift aaa_lifts aaa_fqus aaa_da aaa_ssta aaa_aaa |
|
@@ -634,9 +868,9 @@
|
- atomic arity assignment |
- aaa ( ? ⢠? â ? ) |
- aaa_lift aaa_lifts aaa_lpss aaa_aaa |
+ stratified static type assignment |
+ ssta ( â¦?,?⦠⢠? â¢[?,?] ? ) |
+ ssta_lift ssta_ssta |
|
@@ -648,9 +882,9 @@
|
- parameters |
- sh |
- sd |
+ local env. ref. for degree assignment |
+ lsubd ( ? ⢠? âªâ ? ) |
+ lsubd_da lsubd_lsubd |
|
@@ -659,29 +893,39 @@
- substitution |
- parallel substitution |
- lpss ( ? ⢠â¶* ? ) |
- lpss_ldrop lpss_cpss lpss_lpss |
-
+ |
|
-
+ | degree assignment |
+ da ( â¦?,?⦠⢠? âª[?,?] ? ) |
+ da_lift da_da |
+
+
+ |
+
|
-
+ |
|
-
+ | parameters |
+ sh |
+ sd |
+
|
- cpss ( ? ⢠? â¶* ? ) |
- cpss_lift |
-
+ |
|
+
+
+ substitution |
+ lazy equivalence for local environments |
+ lleq ( ? â[?,?] ? ) |
+ lleq_alt ( ? ââ[?,?] ? ) |
+ lleq_ldrop lleq_fqus lleq_lleq lleq_ext |
|
@@ -690,12 +934,10 @@
|
- local env. ref. for substitution |
- lsubr ( ? â ? ) |
- lsubr_lsubr |
-
-
- |
+ contxt-sensitive extended multiple substitution |
+ cpys ( â¦?,?⦠⢠? â¶*[?,?] ? ) |
+ cpys_alt ( â¦?,?⦠⢠? â¶â¶*[?,?] ? ) |
+ cpys_lift cpys_cpys |
|
@@ -705,8 +947,8 @@
iterated structural successor for closures |
- fsups ( â¦?,?⦠â* â¦?,?⦠) |
- fsups_fsups |
+ fqus ( â¦?,?,?⦠â* â¦?,?,?⦠) |
+ fqus_alt fqus_fqus |
|
@@ -721,8 +963,8 @@
|
- fsupp ( â¦?,?⦠â+ â¦?,?⦠) |
- fsupp_fsupp |
+ fqup ( â¦?,?,?⦠â+ â¦?,?,?⦠) |
+ fqup_fqup |
|
@@ -734,8 +976,8 @@
|
- generic local env. slicing |
- ldrops ( â©*[?] ? â¡ ? ) |
+ iterated local env. slicing |
+ ldrops ( â©*[?,?] ? â¡ ? ) |
ldrops_ldrop ldrops_ldrops |
@@ -786,8 +1028,66 @@
|
relocation |
+ contxt-sensitive extended ordinary substitution |
+ cpy ( â¦?,?⦠⢠? â¶[?,?] ? ) |
+ cpy_lift cpy_cpy |
+
+
+ |
+
+
+ |
+
+
+
+
+ |
+ restricted local env. ref. |
+ lsubr ( ? â ? ) |
+ lsubr_lsubr |
+
+
+ |
+
+
+ |
+
+
+
+
+ |
+ local env. ref. for extended substitution |
+ lsuby ( ? âÃ[?,?] ? ) |
+ lsuby_lsuby |
+
+
+ |
+
+
+ |
+
+
+
+
+ |
structural successor for closures |
- fsup ( â¦?,?⦠â â¦?,?⦠) |
+ fquq ( â¦?,?,?⦠â⸮ â¦?,?,?⦠) |
+ fquq_alt ( â¦?,?,?⦠ââ⸮ â¦?,?,?⦠) |
+
+
+ |
+
+
+ |
+
+
+
+
+ |
+
+
+ |
+ fqu ( â¦?,?,?⦠â â¦?,?,?⦠) |
|
@@ -817,8 +1117,8 @@
basic local env. slicing |
- ldrop ( â©[?,?] ? â¡ ? ) |
- ldrop_append ldrop_lpx_sn ldrop_ldrop |
+ ldrop ( â©[?,?,?] ? â¡ ? ) |
+ ldrop_lpx_sn ldrop_leq ldrop_ldrop |
|
@@ -858,6 +1158,20 @@
grammar |
+ equivalence for local environments |
+ leq ( ? â[?,?] ? ) |
+ leq_leq |
+
+
+ |
+
+
+ |
+
+
+
+
+ |
pointwise extension of a relation |
lpx_sn |
lpx_sn_tc lpx_sn_lpx_sn |
@@ -887,8 +1201,8 @@
closures |
- cl_shift ( ? @@ ? ) |
- cl_weight ( â¯{?,?} ) |
+ cl_weight ( â¯{?,?,?} ) |
+ cl_restricted_weight ( â¯{?,?} ) |
|
@@ -1004,6 +1318,6 @@
- Last update: Fri, 10 May 2013 18:19:21 +0200
+ Last update: Mon, 24 Feb 2014 19:58:07 +0100