From 5a636c864112b9cb98a5e9e1c4233afa68ac9f93 Mon Sep 17 00:00:00 2001 From: rv-jenkins Date: Mon, 13 Nov 2023 16:01:15 +0000 Subject: [PATCH] gh-pages: Updated the website --- CNAME | 1 + ...irefly-Download-Icon-Inverted.32636383.png | Bin 0 -> 571 bytes assets/css/Firefly-Download-Icon.8094a4f0.png | Bin 0 -> 586 bytes assets/css/fontawesome-webfont.0caf0c90.ttf | Bin 0 -> 165548 bytes assets/css/fontawesome-webfont.3981e506.eot | Bin 0 -> 165742 bytes assets/css/fontawesome-webfont.58488e7e.woff2 | Bin 0 -> 77160 bytes assets/css/fontawesome-webfont.a9323ae9.svg | 1 + assets/css/fontawesome-webfont.ed962b83.woff | Bin 0 -> 98024 bytes assets/css/iconfont.960c72b2.eot | Bin 0 -> 2216 bytes assets/css/iconfont.a07d77e0.woff2 | Bin 0 -> 892 bytes assets/css/iconfont.b2a06094.woff | Bin 0 -> 1296 bytes assets/css/index.css | 1 + assets/css/owl.video.play.e7a23fb2.png | Bin 0 -> 2794 bytes assets/css/select-arrow.b8e89c0c.svg | 1 + assets/img/404.png | Bin 0 -> 33413 bytes assets/img/500.png | Bin 0 -> 45305 bytes assets/img/android-chrome-192x192.png | Bin 0 -> 8642 bytes assets/img/android-chrome-512x512.png | Bin 0 -> 17774 bytes assets/img/apple-touch-icon.png | Bin 0 -> 7679 bytes assets/img/favicon-16x16.png | Bin 0 -> 489 bytes assets/img/favicon-32x32.png | Bin 0 -> 972 bytes assets/img/favicon.ico | Bin 0 -> 15406 bytes assets/img/hero/kerc20-hero-image.png | Bin 0 -> 208144 bytes assets/img/hero/test-coverage-hero-image.png | Bin 0 -> 56813 bytes assets/img/hero/test-runner-hero-image.png | Bin 0 -> 208144 bytes assets/img/k-logo-dark.png | Bin 0 -> 32908 bytes assets/img/k-logo.png | Bin 0 -> 5022 bytes assets/img/lang.jpg | Bin 0 -> 1619 bytes assets/img/new.gif | Bin 0 -> 275 bytes assets/img/rv-logo-dark.png | Bin 0 -> 3624 bytes assets/img/rv-logo.png | Bin 0 -> 6988 bytes assets/img/try-it-online.jpg | Bin 0 -> 1562 bytes assets/js/index.js | 212 + assets/sass/icons/iconfont.css | 36 + assets/sass/icons/iconfont.eot | Bin 0 -> 2216 bytes assets/sass/icons/iconfont.svg | 30 + assets/sass/icons/iconfont.ttf | Bin 0 -> 2048 bytes assets/sass/icons/iconfont.woff | Bin 0 -> 1296 bytes assets/sass/icons/iconfont.woff2 | Bin 0 -> 888 bytes docs/cheat_sheet/index.html | 372 + docs/ktools/index.html | 726 + docs/user_manual/index.html | 3945 +++ editor_support/index.html | 455 + .../index.html | 401 + exports/K.epub | Bin 0 -> 952873 bytes exports/K.html | 23816 ++++++++++++++++ exports/K.mobi | Bin 0 -> 2362510 bytes exports/K.pdf | Bin 0 -> 1241273 bytes faq/index.html | 467 + index.html | 418 + install | 71 + k-distribution/INSTALL/index.html | 603 + .../kframework/builtin/domains/index.html | 3938 +++ .../include/kframework/builtin/ffi/index.html | 619 + .../kframework/builtin/json/index.html | 428 + .../kframework/builtin/kast/index.html | 966 + .../kframework/builtin/prelude/index.html | 399 + .../include/kframework/builtin/rat/index.html | 620 + .../builtin/substitution/index.html | 484 + k-distribution/include/kframework/index.html | 405 + .../1_basic/01_installing/index.html | 473 + .../k-tutorial/1_basic/02_basics/index.html | 612 + .../k-tutorial/1_basic/03_parsing/index.html | 780 + .../1_basic/04_disambiguation/index.html | 729 + .../k-tutorial/1_basic/05_modules/index.html | 670 + .../1_basic/06_ints_and_bools/index.html | 608 + .../1_basic/07_side_conditions/index.html | 621 + .../08_literate_programming/index.html | 571 + .../1_basic/09_unparsing/index.html | 718 + .../k-tutorial/1_basic/10_strings/index.html | 554 + .../k-tutorial/1_basic/11_casts/index.html | 592 + .../1_basic/12_syntactic_lists/index.html | 577 + .../1_basic/13_rewrite_rules/index.html | 696 + .../1_basic/14_evaluation_order/index.html | 707 + .../1_basic/15_configurations/index.html | 663 + .../1_basic/16_collections/index.html | 742 + .../1_basic/17_cell_multiplicity/index.html | 577 + .../18_equality_and_conditionals/index.html | 483 + .../1_basic/19_debugging/index.html | 912 + .../k-tutorial/1_basic/20_backends/index.html | 503 + .../1_basic/21_symbolic_execution/index.html | 583 + .../k-tutorial/1_basic/22_proofs/index.html | 819 + k-distribution/k-tutorial/1_basic/index.html | 401 + .../2_intermediate/01_macros/index.html | 567 + .../02_fresh_constants/index.html | 397 + .../2_intermediate/03_klabels/index.html | 397 + .../2_intermediate/04_overloading/index.html | 397 + .../05_matching_logic/index.html | 397 + .../06_function_context/index.html | 397 + .../07_record_productions/index.html | 397 + .../2_intermediate/08_fun_and_let/index.html | 397 + .../2_intermediate/09_as/index.html | 397 + .../10_matching_operator/index.html | 397 + .../11_evaluation_order/index.html | 397 + .../12_floats_and_machine_ints/index.html | 397 + .../2_intermediate/13_substitution/index.html | 397 + .../2_intermediate/14_io/index.html | 397 + .../15_string_buffers_and_bytes/index.html | 397 + .../2_intermediate/16_kore/index.html | 397 + .../17_debugging_proofs/index.html | 397 + .../k-tutorial/2_intermediate/index.html | 430 + .../3_advanced/1_parsing/1_layout/index.html | 387 + .../1_parsing/2_ambiguities/index.html | 387 + .../1_parsing/3_locations/index.html | 387 + .../3_advanced/2_libraries/1_json/index.html | 387 + .../3_advanced/2_libraries/2_rat/index.html | 387 + .../3_advanced/2_libraries/3_ffi/index.html | 387 + .../3_extending_k/1_custom_hooks/index.html | 387 + .../3_extending_k/2_scripting_k/index.html | 387 + .../k-tutorial/3_advanced/index.html | 387 + k-distribution/k-tutorial/index.html | 398 + .../pl-tutorial/1_k/1_lambda/index.html | 404 + .../1_k/1_lambda/lesson_1/NOTES/index.html | 379 + .../1_k/1_lambda/lesson_1/index.html | 471 + .../1_k/1_lambda/lesson_2.5/NOTES/index.html | 379 + .../1_k/1_lambda/lesson_2/NOTES/index.html | 385 + .../1_k/1_lambda/lesson_2/index.html | 453 + .../1_k/1_lambda/lesson_3/NOTES/index.html | 377 + .../1_k/1_lambda/lesson_3/index.html | 418 + .../1_k/1_lambda/lesson_4/NOTES/index.html | 376 + .../1_k/1_lambda/lesson_4/index.html | 412 + .../1_k/1_lambda/lesson_5/NOTES/index.html | 381 + .../1_k/1_lambda/lesson_5/index.html | 465 + .../1_k/1_lambda/lesson_6/index.html | 421 + .../1_k/1_lambda/lesson_7/NOTES/index.html | 379 + .../1_k/1_lambda/lesson_7/index.html | 459 + .../exercises/SK-combinators/index.html | 415 + .../lesson_8/exercises/mu-derived/index.html | 380 + .../1_k/1_lambda/lesson_8/index.html | 432 + .../1_k/1_lambda/lesson_9/index.html | 445 + .../1_k/1_lambda/lesson_9/lambda/index.html | 510 + .../pl-tutorial/1_k/2_imp/NOTES/index.html | 379 + .../pl-tutorial/1_k/2_imp/index.html | 403 + .../pl-tutorial/1_k/2_imp/lesson_1/index.html | 541 + .../pl-tutorial/1_k/2_imp/lesson_2/index.html | 453 + .../pl-tutorial/1_k/2_imp/lesson_3/index.html | 591 + .../exercises/purely-syntactic/index.html | 382 + .../uninitialized-variables/index.html | 381 + .../pl-tutorial/1_k/2_imp/lesson_4/index.html | 497 + .../1_k/2_imp/lesson_5/imp/index.html | 547 + .../pl-tutorial/1_k/2_imp/lesson_5/index.html | 400 + .../pl-tutorial/1_k/3_lambda++/index.html | 399 + .../lesson_1/exercises/NOTES/index.html | 378 + .../lesson_1/exercises/callCC/index.html | 378 + .../from-call-CC-to-callcc/index.html | 377 + .../from-callcc-to-call-CC/index.html | 381 + .../1_k/3_lambda++/lesson_1/index.html | 486 + .../1_k/3_lambda++/lesson_2/index.html | 535 + .../1_k/3_lambda++/lesson_3/NOTES/index.html | 393 + .../1_k/3_lambda++/lesson_3/index.html | 408 + .../1_k/3_lambda++/lesson_4/NOTES/index.html | 397 + .../1_k/3_lambda++/lesson_4/index.html | 469 + .../1_k/3_lambda++/lesson_5/index.html | 444 + .../lesson_6/exercises/NOTES/index.html | 378 + .../lesson_6/exercises/callCC/index.html | 379 + .../from-call-CC-to-callcc/index.html | 377 + .../from-callcc-to-call-CC/index.html | 378 + .../1_k/3_lambda++/lesson_6/index.html | 394 + .../1_k/3_lambda++/lesson_6/lambda/index.html | 542 + .../pl-tutorial/1_k/4_imp++/index.html | 408 + .../1_k/4_imp++/lesson_1/NOTES/index.html | 381 + .../1_k/4_imp++/lesson_1/index.html | 465 + .../1_k/4_imp++/lesson_2/NOTES/index.html | 376 + .../1_k/4_imp++/lesson_2/index.html | 447 + .../1_k/4_imp++/lesson_3/NOTES/index.html | 377 + .../1_k/4_imp++/lesson_3/index.html | 492 + .../1_k/4_imp++/lesson_4/NOTES/index.html | 382 + .../1_k/4_imp++/lesson_4/index.html | 484 + .../1_k/4_imp++/lesson_5/index.html | 434 + .../1_k/4_imp++/lesson_6/index.html | 569 + .../1_k/4_imp++/lesson_7/index.html | 465 + .../1_k/4_imp++/lesson_8/imp/index.html | 954 + .../1_k/4_imp++/lesson_8/index.html | 404 + .../pl-tutorial/1_k/5_types/index.html | 392 + .../1_k/5_types/lesson_1.9/NOTES/index.html | 383 + .../1_k/5_types/lesson_1/NOTES/index.html | 376 + .../1_k/5_types/lesson_1/index.html | 492 + .../1_k/5_types/lesson_2/NOTES/index.html | 377 + .../1_k/5_types/lesson_2/index.html | 447 + .../1_k/5_types/lesson_3/index.html | 434 + .../1_k/5_types/lesson_4/NOTES/index.html | 380 + .../1_k/5_types/lesson_4/index.html | 577 + .../1_k/5_types/lesson_5/index.html | 433 + .../1_k/5_types/lesson_6/NOTES/index.html | 377 + .../1_k/5_types/lesson_6/index.html | 487 + .../1_k/5_types/lesson_7/NOTES/index.html | 378 + .../1_k/5_types/lesson_7/index.html | 492 + .../1_k/5_types/lesson_8/NOTES/index.html | 377 + .../1_k/5_types/lesson_8/index.html | 425 + .../1_k/5_types/lesson_9.5/NOTES/index.html | 376 + .../1_k/5_types/lesson_9/index.html | 542 + k-distribution/pl-tutorial/1_k/index.html | 397 + .../1_simple/1_untyped/NOTES/index.html | 393 + .../1_untyped/simple-untyped/index.html | 1709 ++ .../2_typed/1_static/NOTES/index.html | 380 + .../functions-with-throws/tests/index.html | 379 + .../1_static/simple-typed-static/index.html | 1150 + .../2_dynamic/simple-typed-dynamic/index.html | 1142 + .../1_simple/2_typed/programs/index.html | 379 + .../2_kool/1_untyped/kool-untyped/index.html | 1522 + .../1_dynamic/kool-typed-dynamic/index.html | 1385 + .../2_kool/2_typed/2_static/NOTES/index.html | 380 + .../2_static/kool-typed-static/index.html | 1424 + .../1_environment/fun-untyped/index.html | 1225 + .../2_substitution/fun-untyped/index.html | 720 + .../4_logik/basic/logik/index.html | 710 + .../pl-tutorial/2_languages/index.html | 396 + k-distribution/pl-tutorial/NOTES/index.html | 455 + k-distribution/pl-tutorial/index.html | 578 + .../checks/markdownErrorLocation/index.html | 394 + .../regression-new/imp++-llvm/imp/index.html | 961 + .../set-balance-spec/index.html | 433 + .../kprove-markdown/set-balance/index.html | 1227 + .../markdownSelectors/a-spec/index.html | 381 + .../markdownSelectors/test/index.html | 407 + news/k-framework-demo/index.html | 354 + overview/index.html | 356 + projects/index.html | 447 + sitemap.xml | 711 + 219 files changed, 120422 insertions(+) create mode 100644 CNAME create mode 100644 assets/css/Firefly-Download-Icon-Inverted.32636383.png create mode 100644 assets/css/Firefly-Download-Icon.8094a4f0.png create mode 100644 assets/css/fontawesome-webfont.0caf0c90.ttf create mode 100644 assets/css/fontawesome-webfont.3981e506.eot create mode 100644 assets/css/fontawesome-webfont.58488e7e.woff2 create mode 100644 assets/css/fontawesome-webfont.a9323ae9.svg create mode 100644 assets/css/fontawesome-webfont.ed962b83.woff create mode 100644 assets/css/iconfont.960c72b2.eot create mode 100644 assets/css/iconfont.a07d77e0.woff2 create mode 100644 assets/css/iconfont.b2a06094.woff create mode 100644 assets/css/index.css create mode 100644 assets/css/owl.video.play.e7a23fb2.png create mode 100644 assets/css/select-arrow.b8e89c0c.svg create mode 100644 assets/img/404.png create mode 100644 assets/img/500.png create mode 100644 assets/img/android-chrome-192x192.png create mode 100644 assets/img/android-chrome-512x512.png create mode 100644 assets/img/apple-touch-icon.png create mode 100644 assets/img/favicon-16x16.png create mode 100644 assets/img/favicon-32x32.png create mode 100644 assets/img/favicon.ico create mode 100644 assets/img/hero/kerc20-hero-image.png create mode 100644 assets/img/hero/test-coverage-hero-image.png create mode 100644 assets/img/hero/test-runner-hero-image.png create mode 100644 assets/img/k-logo-dark.png create mode 100644 assets/img/k-logo.png create mode 100644 assets/img/lang.jpg create mode 100644 assets/img/new.gif create mode 100644 assets/img/rv-logo-dark.png create mode 100644 assets/img/rv-logo.png create mode 100644 assets/img/try-it-online.jpg create mode 100644 assets/js/index.js create mode 100644 assets/sass/icons/iconfont.css create mode 100644 assets/sass/icons/iconfont.eot create mode 100644 assets/sass/icons/iconfont.svg create mode 100644 assets/sass/icons/iconfont.ttf create mode 100644 assets/sass/icons/iconfont.woff create mode 100644 assets/sass/icons/iconfont.woff2 create mode 100644 docs/cheat_sheet/index.html create mode 100644 docs/ktools/index.html create mode 100644 docs/user_manual/index.html create mode 100644 editor_support/index.html create mode 100644 events/k-a-rewriting-based-language-definitional-framework/index.html create mode 100644 exports/K.epub create mode 100644 exports/K.html create mode 100644 exports/K.mobi create mode 100644 exports/K.pdf create mode 100644 faq/index.html create mode 100644 index.html create mode 100644 install create mode 100644 k-distribution/INSTALL/index.html create mode 100644 k-distribution/include/kframework/builtin/domains/index.html create mode 100644 k-distribution/include/kframework/builtin/ffi/index.html create mode 100644 k-distribution/include/kframework/builtin/json/index.html create mode 100644 k-distribution/include/kframework/builtin/kast/index.html create mode 100644 k-distribution/include/kframework/builtin/prelude/index.html create mode 100644 k-distribution/include/kframework/builtin/rat/index.html create mode 100644 k-distribution/include/kframework/builtin/substitution/index.html create mode 100644 k-distribution/include/kframework/index.html create mode 100644 k-distribution/k-tutorial/1_basic/01_installing/index.html create mode 100644 k-distribution/k-tutorial/1_basic/02_basics/index.html create mode 100644 k-distribution/k-tutorial/1_basic/03_parsing/index.html create mode 100644 k-distribution/k-tutorial/1_basic/04_disambiguation/index.html create mode 100644 k-distribution/k-tutorial/1_basic/05_modules/index.html create mode 100644 k-distribution/k-tutorial/1_basic/06_ints_and_bools/index.html create mode 100644 k-distribution/k-tutorial/1_basic/07_side_conditions/index.html create mode 100644 k-distribution/k-tutorial/1_basic/08_literate_programming/index.html create mode 100644 k-distribution/k-tutorial/1_basic/09_unparsing/index.html create mode 100644 k-distribution/k-tutorial/1_basic/10_strings/index.html create mode 100644 k-distribution/k-tutorial/1_basic/11_casts/index.html create mode 100644 k-distribution/k-tutorial/1_basic/12_syntactic_lists/index.html create mode 100644 k-distribution/k-tutorial/1_basic/13_rewrite_rules/index.html create mode 100644 k-distribution/k-tutorial/1_basic/14_evaluation_order/index.html create mode 100644 k-distribution/k-tutorial/1_basic/15_configurations/index.html create mode 100644 k-distribution/k-tutorial/1_basic/16_collections/index.html create mode 100644 k-distribution/k-tutorial/1_basic/17_cell_multiplicity/index.html create mode 100644 k-distribution/k-tutorial/1_basic/18_equality_and_conditionals/index.html create mode 100644 k-distribution/k-tutorial/1_basic/19_debugging/index.html create mode 100644 k-distribution/k-tutorial/1_basic/20_backends/index.html create mode 100644 k-distribution/k-tutorial/1_basic/21_symbolic_execution/index.html create mode 100644 k-distribution/k-tutorial/1_basic/22_proofs/index.html create mode 100644 k-distribution/k-tutorial/1_basic/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/01_macros/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/02_fresh_constants/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/03_klabels/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/04_overloading/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/05_matching_logic/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/06_function_context/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/07_record_productions/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/08_fun_and_let/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/09_as/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/10_matching_operator/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/11_evaluation_order/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/12_floats_and_machine_ints/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/13_substitution/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/14_io/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/15_string_buffers_and_bytes/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/16_kore/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/17_debugging_proofs/index.html create mode 100644 k-distribution/k-tutorial/2_intermediate/index.html create mode 100644 k-distribution/k-tutorial/3_advanced/1_parsing/1_layout/index.html create mode 100644 k-distribution/k-tutorial/3_advanced/1_parsing/2_ambiguities/index.html create mode 100644 k-distribution/k-tutorial/3_advanced/1_parsing/3_locations/index.html create mode 100644 k-distribution/k-tutorial/3_advanced/2_libraries/1_json/index.html create mode 100644 k-distribution/k-tutorial/3_advanced/2_libraries/2_rat/index.html create mode 100644 k-distribution/k-tutorial/3_advanced/2_libraries/3_ffi/index.html create mode 100644 k-distribution/k-tutorial/3_advanced/3_extending_k/1_custom_hooks/index.html create mode 100644 k-distribution/k-tutorial/3_advanced/3_extending_k/2_scripting_k/index.html create mode 100644 k-distribution/k-tutorial/3_advanced/index.html create mode 100644 k-distribution/k-tutorial/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_1/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_1/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_2.5/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_2/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_2/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_3/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_3/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_4/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_4/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_5/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_5/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_6/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_7/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_7/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_8/exercises/SK-combinators/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_8/exercises/mu-derived/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_8/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_9/index.html create mode 100644 k-distribution/pl-tutorial/1_k/1_lambda/lesson_9/lambda/index.html create mode 100644 k-distribution/pl-tutorial/1_k/2_imp/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/2_imp/index.html create mode 100644 k-distribution/pl-tutorial/1_k/2_imp/lesson_1/index.html create mode 100644 k-distribution/pl-tutorial/1_k/2_imp/lesson_2/index.html create mode 100644 k-distribution/pl-tutorial/1_k/2_imp/lesson_3/index.html create mode 100644 k-distribution/pl-tutorial/1_k/2_imp/lesson_4/exercises/purely-syntactic/index.html create mode 100644 k-distribution/pl-tutorial/1_k/2_imp/lesson_4/exercises/uninitialized-variables/index.html create mode 100644 k-distribution/pl-tutorial/1_k/2_imp/lesson_4/index.html create mode 100644 k-distribution/pl-tutorial/1_k/2_imp/lesson_5/imp/index.html create mode 100644 k-distribution/pl-tutorial/1_k/2_imp/lesson_5/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/callCC/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/from-call-CC-to-callcc/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/from-callcc-to-call-CC/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_2/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_3/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_3/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_4/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_4/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_5/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/callCC/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/from-call-CC-to-callcc/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/from-callcc-to-call-CC/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/index.html create mode 100644 k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/lambda/index.html create mode 100644 k-distribution/pl-tutorial/1_k/4_imp++/index.html create mode 100644 k-distribution/pl-tutorial/1_k/4_imp++/lesson_1/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/4_imp++/lesson_1/index.html create mode 100644 k-distribution/pl-tutorial/1_k/4_imp++/lesson_2/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/4_imp++/lesson_2/index.html create mode 100644 k-distribution/pl-tutorial/1_k/4_imp++/lesson_3/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/4_imp++/lesson_3/index.html create mode 100644 k-distribution/pl-tutorial/1_k/4_imp++/lesson_4/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/4_imp++/lesson_4/index.html create mode 100644 k-distribution/pl-tutorial/1_k/4_imp++/lesson_5/index.html create mode 100644 k-distribution/pl-tutorial/1_k/4_imp++/lesson_6/index.html create mode 100644 k-distribution/pl-tutorial/1_k/4_imp++/lesson_7/index.html create mode 100644 k-distribution/pl-tutorial/1_k/4_imp++/lesson_8/imp/index.html create mode 100644 k-distribution/pl-tutorial/1_k/4_imp++/lesson_8/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_1.9/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_1/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_1/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_2/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_2/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_3/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_4/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_4/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_5/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_6/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_6/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_7/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_7/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_8/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_8/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_9.5/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/1_k/5_types/lesson_9/index.html create mode 100644 k-distribution/pl-tutorial/1_k/index.html create mode 100644 k-distribution/pl-tutorial/2_languages/1_simple/1_untyped/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/2_languages/1_simple/1_untyped/simple-untyped/index.html create mode 100644 k-distribution/pl-tutorial/2_languages/1_simple/2_typed/1_static/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/2_languages/1_simple/2_typed/1_static/exercises/functions-with-throws/tests/index.html create mode 100644 k-distribution/pl-tutorial/2_languages/1_simple/2_typed/1_static/simple-typed-static/index.html create mode 100644 k-distribution/pl-tutorial/2_languages/1_simple/2_typed/2_dynamic/simple-typed-dynamic/index.html create mode 100644 k-distribution/pl-tutorial/2_languages/1_simple/2_typed/programs/index.html create mode 100644 k-distribution/pl-tutorial/2_languages/2_kool/1_untyped/kool-untyped/index.html create mode 100644 k-distribution/pl-tutorial/2_languages/2_kool/2_typed/1_dynamic/kool-typed-dynamic/index.html create mode 100644 k-distribution/pl-tutorial/2_languages/2_kool/2_typed/2_static/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/2_languages/2_kool/2_typed/2_static/kool-typed-static/index.html create mode 100644 k-distribution/pl-tutorial/2_languages/3_fun/1_untyped/1_environment/fun-untyped/index.html create mode 100644 k-distribution/pl-tutorial/2_languages/3_fun/1_untyped/2_substitution/fun-untyped/index.html create mode 100644 k-distribution/pl-tutorial/2_languages/4_logik/basic/logik/index.html create mode 100644 k-distribution/pl-tutorial/2_languages/index.html create mode 100644 k-distribution/pl-tutorial/NOTES/index.html create mode 100644 k-distribution/pl-tutorial/index.html create mode 100644 k-distribution/tests/regression-new/checks/markdownErrorLocation/index.html create mode 100644 k-distribution/tests/regression-new/imp++-llvm/imp/index.html create mode 100644 k-distribution/tests/regression-new/kprove-markdown/set-balance-spec/index.html create mode 100644 k-distribution/tests/regression-new/kprove-markdown/set-balance/index.html create mode 100644 k-distribution/tests/regression-new/markdownSelectors/a-spec/index.html create mode 100644 k-distribution/tests/regression-new/markdownSelectors/test/index.html create mode 100644 news/k-framework-demo/index.html create mode 100644 overview/index.html create mode 100644 projects/index.html create mode 100644 sitemap.xml diff --git a/CNAME b/CNAME new file mode 100644 index 00000000000..f5515ee7595 --- /dev/null +++ b/CNAME @@ -0,0 +1 @@ +kframework.org diff --git a/assets/css/Firefly-Download-Icon-Inverted.32636383.png b/assets/css/Firefly-Download-Icon-Inverted.32636383.png new file mode 100644 index 0000000000000000000000000000000000000000..c87605a3d70a8940e7b547a9b635d7b16e4a80f5 GIT binary patch literal 571 zcmeAS@N?(olHy`uVBq!ia0vp^1|ZDA3?vioaBc-soCO|{#S9F3${@^GvDCf{D9DoT z=V7Kx3{!3H#Rm@RFoGN7Zny3L`6l0hKBh0`FeYM zxr2b4yPKPfi?gGngM)*;y}g~St&NS1wY9aCiHWhXv5}FHp`oFHfq}lBo-T7@;bfr0 z7?Zr+T^Kr8Wj%mwZci7-kcwMxuO9C^WFXR-n0$z5FVEhVdo}M`zt`{a6j}H>p;)>;SGa5`8rZVeRFzh(Hb>4lifTn)N2h0bw9j*)SZ14;J#60Ks zTV8wSds}{||6r&PT6t~S=Z5XNqP`M#4u!!>ogA*MPV+IF@X<<`X;a99 z7ES8lQK@yUVw`9EPIJfU|FH}Q#D2G4>)v~pc?07F@wtUtt=>JUc3?QO#e7$U)Bjgb zHvc-k!rXL&L%1oQfzl<<{DO=X>)1Oc*fF@I)CzQL_-$aY<@Q8Q=I9BWjmno#f4s>0 zHT6&0>0Qi=Zk?ZfRf(NtI{W5>@d?c{S$R5|m1|xf{>Ojhi*tdk^e+)$7%_Od`njxg HN@xNAMg{L! literal 0 HcmV?d00001 diff --git a/assets/css/Firefly-Download-Icon.8094a4f0.png b/assets/css/Firefly-Download-Icon.8094a4f0.png new file mode 100644 index 0000000000000000000000000000000000000000..e0fdca7b4c45cfd913001c3a4e58442e40f5d6b2 GIT binary patch literal 586 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 z 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 d0mW2@EHO9NV8h3u2x_sp}KECIB>@9+Qn{FBV{ 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 G*yFsbY~cLNXLP73aA74Mq6M9f^&YV`isWW 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

5q!RY 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 literal 0 HcmV?d00001 diff --git a/assets/css/fontawesome-webfont.a9323ae9.svg b/assets/css/fontawesome-webfont.a9323ae9.svg new file mode 100644 index 00000000000..756bf0896c7 --- /dev/null +++ b/assets/css/fontawesome-webfont.a9323ae9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/assets/css/fontawesome-webfont.ed962b83.woff b/assets/css/fontawesome-webfont.ed962b83.woff new file mode 100644 index 0000000000000000000000000000000000000000..400014a4b06eee3d0c0d54402a47ab2601b2862b GIT binary patch literal 98024 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 SdSQM28?+M|D(2r_;{O0|uQ74} literal 0 HcmV?d00001 diff --git a/assets/css/iconfont.960c72b2.eot b/assets/css/iconfont.960c72b2.eot new file mode 100644 index 0000000000000000000000000000000000000000..63c3474526541909b8c7f080484239aaad77102f GIT binary patch literal 2216 zcmd^A&u<$=6n^91@w&BXaZ(jRSBisCX}xYjuvH~MBS=(~l&CFHFQMIT)^?)xu4S*I zq~cIfg|-5rsFzBK$f4rE0Ra-CDkE6vH{A_0$JpdOBE@7Ozfw# zWK)&e=AF9z+3R7|N+`HrYM}t>DmcgEX=bSM# z`s-;E`p3{`t-9G5+j{srM+5F|)mf=LH+^fGDEu?@uWPnB-}`|!hsi(DU#)=skY-tjC`_~I|DzXv^2Hbv6*D&u&-{B2fS3Z!8B$S9t1~Fc{bmq~;^yovxDsBIms$687V5A513)F9Dfz&Ue>#v2YfuCcg;fQAAn_FoI%F z*zd#|MWNlK+mJ7)v5J#R+uso8cC?wwTl4frM|5H`x`Qeo97E7J>b*LWiy3~K$I#)i zcu#srbO9{ya10|N2Om*35#~Fw$H+xTu!PRB@?#GJML8nDQT^XrN+#ffN&_;|;mmPX zdBo3%JHM_DZh$-AL>`F#^Bx9vzywD@#)zy1TeO1Z5nIg-Uu%q$jAFi z`S@4Y7u%buxkUc$#Q2dL+NQlPkw2X{)%_I^eTvU%7{7fDD{*MhM>Cn1KJ{1uQd0y2b?`J2Ek z43t(l0^Fx?6uuo%I0pWx!by6Wh7{J|(HwRVksdG^YA75+(YUH`82l#+M}RjKj-rfw zsc;PZj|wMITz*qnqZh@|1&FFul}DBxU>B2E|9zRy-VY6 zt4S14R~Au|e2nv?(`8zLY|#>m?GRWWMOa5~qR7^PCR9nbQHUL29r@TV1?e#zjbkMMOkJOvFWkGM3}D?BkWT376)z{76-^4k|Zaa+~9y7EQ1O^9K_dt zy6?DmB~pMaY}8ML>r_`F3P(zSkm-059>^yDJC}ce>5vcQ-B1xg*ZVn2o4zz1sL4&C z1AczS0L!@vPr@7zJeT`7Cg=jW=TR1B`IvOp8lqVsVK0UTj;St^2NEqf)s6()1P2t+ z|IKcQ<$!_$!2tI~i{iGqGXohp4es6wi4XBdP7;YRj7 z1V<#`(hJ)1Z{Lt^9w;^<*qYn+1fcyd-;NhRL+Sv5LJKq)xg4cTNBso}L_;Nr!o>N> zhTz+k%X~|!L@sr#q8XNh#Q(c6xe`Eu0uJ9oJaT~o4+u1PKw!WF0t+4xIDohjJb-FY z2e^h?fpCWWhM``EQWeCBp~M+Xk1^j&h(TgqYi^6ftVM|n(i&}LsanY^B8Ek43q`Eu zb%s<@6xoC+&CSU?>1V|(zh$m)dQKM(;*M%5yBz=ciFwJw0_iQ?#XJf?(Vm|EbjQq- zo{y8C9%X(34%oWHY+tG3*Q;=mt=pJ2dUG1L1DG8vbue(`!yoGf3-p`T03Hs*;Y#IZrg`$uFn=qV64x zMekqg@31v*`(Ddx{!dN30C*qMHPCs9K%l^8aG0sM_;s=%_A_;3zRU`H{wWI;h$1Kp zjJ2Nk6U%=l85A$nTwMxl05s4Rf|axroM4C$4XfLqG+2>9;tE79Qz9tU4hUMU1E7Ik z5v*qS1gF*`ANcw`IO^q8gDv^^Iw3#Y=R*s%UVTE0eT7OOVojx>Bs1gH?jU9)z z8LX3%I;h~fqj%;$WQ;pZ!6T?ie@IHRvAUX$ZSiYdhcFFipy^LblTeV2Q3+3@e-(AF>axc+KgG6Ks2(riALL#%x!5#)>Mse SKJpDgOw_r+M2(v}0000s%Y`uj literal 0 HcmV?d00001 diff --git a/assets/css/iconfont.b2a06094.woff b/assets/css/iconfont.b2a06094.woff new file mode 100644 index 0000000000000000000000000000000000000000..5c0b2e3a596643441bcd143b36b2a7bf3b5fb24e GIT binary patch literal 1296 zcmXT-cXMN4WB>wI0S0am&A|ZSgV?CRJvh_}C<#=+U=73}3f-zz{=xc2Krt5}-xi3& zY|eTnCg&y=0L5B>{6rwV&34z<8|gWfX+ZW1AeIB-4br}od^1uLQy3VSLFVZJv6)yC zcWeew5GZB=Ya$jMIzsY?LzfjkBQ#uCOyxrr4( zdzpclK^}+|7)2Qj@)C1XfnpPYc4{&(Fp15czK^RQzqo{ffn^U+O)wDW{obY5SurO$ zAtfQnws=ELsC`g3^9 z8)6a-P98YGp~SGXh;uE_0TpxJPCUqaK!Jx@mZLI6b}946SO4PG7L*;5=q+*ErXuQ=j zdvW(>R>A8R`i>eNVC2{VZ_L;9%;$r-o`97K9v0pya z7=72{780-SjquT5$F)iOUq<^9RmZfW6N{J@&)NR-?V6A4VoRU-@ry0mDY@g-mAMQ# zo8C#Lg;*+hcrM73{rykzy!HLQ`91L;Jm=hvm)x&iZ=-WGd9TjV6}R-*e<$jmO6A?a zHX+AF6ch*G_-A@BFj~M=#$dOBsTE`nLzDCkLk7n;tb)LR2LTg?42Cv_MGU(bZb0oxNDoL% zNMvACQ+USY#Mbsd!H$`M=Q*Pr&>g80Z1WB|h_oC}@L&pR64BJ$9Ll9MbN(b|2Y<)u zhh}Uw+_d*vmE)q*oJB1%ipx8Snq)MRKW8N9+SeQB-+On8f$c|YdsXF*+^oG(I~H0M z&ilcq*cX-!p+&L`0>`<-Eqq)`<|77PfdOZ|-_fhfAvj3WIChu>tt~j*4 zVEVuQ0)Fj3oZmmb;=O!AWTWPtAobrmThc54t=qCTD0qdZfn78(pGsTp4Scdy;i--8rMhUfE?d+)#GrsJ^=QiuN*H ztzTQiW+)u^p|v$(RmLR6smIz*n)a;`<+I84x^B4kN7T6|OLm^gx~HP7{qOy*?Tdvk z@^8pp=5@y4k#PKz=4X6A?QI3)Rse$)6qZR13=+M3Hza3D%#@6jh?Kl3aZ}P#f@M+=FnYz-o^W{pNoj+Yy>YV(^I+cfq K;Yxy790LF=Ir-iI literal 0 HcmV?d00001 diff --git a/assets/css/index.css b/assets/css/index.css new file mode 100644 index 00000000000..5fdaff40711 --- /dev/null +++ b/assets/css/index.css @@ -0,0 +1 @@ +:root{--blue:#007bff;--indigo:#6610f2;--purple:#6f42c1;--pink:#e83e8c;--red:#dc3545;--orange:#fd7e14;--yellow:#ffc107;--green:#28a745;--teal:#20c997;--cyan:#17a2b8;--white:#fff;--gray:#6c757d;--gray-dark:#343a40;--primary:#007bff;--secondary:#6c757d;--success:#28a745;--info:#17a2b8;--warning:#ffc107;--danger:#dc3545;--light:#f8f9fa;--dark:#343a40;--breakpoint-xs:0;--breakpoint-sm:576px;--breakpoint-md:768px;--breakpoint-lg:992px;--breakpoint-xl:1200px;--font-family-sans-serif:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans","Liberation Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-family-monospace:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}*,:after,:before{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;font-family:sans-serif;line-height:1.15}article,aside,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}body{color:#212529;text-align:left;background-color:#fff;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,Liberation Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-size:1rem;font-weight:400;line-height:1.5}[tabindex="-1"]:focus:not(:focus-visible){outline:0!important}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5rem}p{margin-top:0;margin-bottom:1rem}abbr[data-original-title],abbr[title]{cursor:help;-webkit-text-decoration-skip-ink:none;text-decoration-skip-ink:none;text-decoration:underline;border-bottom:0;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}address{font-style:normal;line-height:inherit;margin-bottom:1rem}dl,ol,ul{margin-top:0;margin-bottom:1rem}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}dt{font-weight:700}dd{margin-bottom:.5rem;margin-left:0}blockquote{margin:0 0 1rem}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}a{color:#007bff;background-color:#0000;text-decoration:none}a:hover{color:#0056b3;text-decoration:underline}a:not([href]):not([class]){color:inherit;text-decoration:none}a:not([href]):not([class]):hover{color:inherit;text-decoration:none}code,kbd,pre,samp{font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}pre{-ms-overflow-style:scrollbar;margin-top:0;margin-bottom:1rem;overflow:auto}figure{margin:0 0 1rem}img{vertical-align:middle;border-style:none}svg{vertical-align:middle;overflow:hidden}table{border-collapse:collapse}caption{color:#6c757d;text-align:left;caption-side:bottom;padding-top:.75rem;padding-bottom:.75rem}th{text-align:inherit;text-align:-webkit-match-parent}label{margin-bottom:.5rem;display:inline-block}button{border-radius:0}button:focus:not(:focus-visible){outline:0}button,input,optgroup,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit;margin:0}button,input{overflow:visible}button,select{text-transform:none}[role=button]{cursor:pointer}select{word-wrap:normal}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]:not(:disabled),[type=reset]:not(:disabled),[type=submit]:not(:disabled),button:not(:disabled){cursor:pointer}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}textarea{resize:vertical;overflow:auto}fieldset{min-width:0;border:0;margin:0;padding:0}legend{width:100%;max-width:100%;font-size:1.5rem;line-height:inherit;color:inherit;white-space:normal;margin-bottom:.5rem;padding:0;display:block}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{cursor:pointer;display:list-item}template{display:none}[hidden]{display:none!important}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{margin-bottom:.5rem;font-weight:500;line-height:1.2}.h1,h1{font-size:2.5rem}.h2,h2{font-size:2rem}.h3,h3{font-size:1.75rem}.h4,h4{font-size:1.5rem}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}.lead{font-size:1.25rem;font-weight:300}.display-1{font-size:6rem;font-weight:300;line-height:1.2}.display-2{font-size:5.5rem;font-weight:300;line-height:1.2}.display-3{font-size:4.5rem;font-weight:300;line-height:1.2}.display-4{font-size:3.5rem;font-weight:300;line-height:1.2}hr{border:0;border-top:1px solid #0000001a;margin-top:1rem;margin-bottom:1rem}.small,small{font-size:.875em;font-weight:400}.mark,mark{background-color:#fcf8e3;padding:.2em}.list-unstyled,.list-inline{padding-left:0;list-style:none}.list-inline-item{display:inline-block}.list-inline-item:not(:last-child){margin-right:.5rem}.initialism{text-transform:uppercase;font-size:90%}.blockquote{margin-bottom:1rem;font-size:1.25rem}.blockquote-footer{color:#6c757d;font-size:.875em;display:block}.blockquote-footer:before{content:"— "}.img-fluid{max-width:100%;height:auto}.img-thumbnail{max-width:100%;height:auto;background-color:#fff;border:1px solid #dee2e6;border-radius:.25rem;padding:.25rem}.figure{display:inline-block}.figure-img{margin-bottom:.5rem;line-height:1}.figure-caption{color:#6c757d;font-size:90%}code{color:#e83e8c;word-wrap:break-word;font-size:87.5%}a>code{color:inherit}kbd{color:#fff;background-color:#212529;border-radius:.2rem;padding:.2rem .4rem;font-size:87.5%}kbd kbd{padding:0;font-size:100%;font-weight:700}pre{color:#212529;font-size:87.5%;display:block}pre code{font-size:inherit;color:inherit;word-break:normal}.pre-scrollable{max-height:340px;overflow-y:scroll}.container,.container-fluid,.container-lg,.container-md,.container-sm,.container-xl{width:100%;margin-left:auto;margin-right:auto;padding-left:15px;padding-right:15px}@media (min-width:576px){.container,.container-sm{max-width:540px}}@media (min-width:768px){.container,.container-md,.container-sm{max-width:720px}}@media (min-width:992px){.container,.container-lg,.container-md,.container-sm{max-width:960px}}@media (min-width:1200px){.container,.container-lg,.container-md,.container-sm,.container-xl{max-width:1140px}}.row{-ms-flex-wrap:wrap;flex-wrap:wrap;margin-left:-15px;margin-right:-15px;display:-ms-flexbox;display:flex}.no-gutters{margin-left:0;margin-right:0}.no-gutters>.col,.no-gutters>[class*=col-]{padding-left:0;padding-right:0}.col,.col-1,.col-10,.col-11,.col-12,.col-2,.col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9,.col-auto,.col-lg,.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-lg-auto,.col-md,.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-md-auto,.col-sm,.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-sm-auto,.col-xl,.col-xl-1,.col-xl-10,.col-xl-11,.col-xl-12,.col-xl-2,.col-xl-3,.col-xl-4,.col-xl-5,.col-xl-6,.col-xl-7,.col-xl-8,.col-xl-9,.col-xl-auto{width:100%;padding-left:15px;padding-right:15px;position:relative}.col{max-width:100%;-ms-flex-positive:1;-ms-flex-preferred-size:0;flex-grow:1;flex-basis:0}.row-cols-1>*{max-width:100%;-ms-flex:0 0 100%;flex:0 0 100%}.row-cols-2>*{max-width:50%;-ms-flex:0 0 50%;flex:0 0 50%}.row-cols-3>*{max-width:33.3333%;-ms-flex:0 0 33.3333%;flex:0 0 33.3333%}.row-cols-4>*{max-width:25%;-ms-flex:0 0 25%;flex:0 0 25%}.row-cols-5>*{max-width:20%;-ms-flex:0 0 20%;flex:0 0 20%}.row-cols-6>*{max-width:16.6667%;-ms-flex:0 0 16.6667%;flex:0 0 16.6667%}.col-auto{width:auto;max-width:100%;-ms-flex:none;flex:none}.col-1{max-width:8.33333%;-ms-flex:0 0 8.33333%;flex:0 0 8.33333%}.col-2{max-width:16.6667%;-ms-flex:0 0 16.6667%;flex:0 0 16.6667%}.col-3{max-width:25%;-ms-flex:0 0 25%;flex:0 0 25%}.col-4{max-width:33.3333%;-ms-flex:0 0 33.3333%;flex:0 0 33.3333%}.col-5{max-width:41.6667%;-ms-flex:0 0 41.6667%;flex:0 0 41.6667%}.col-6{max-width:50%;-ms-flex:0 0 50%;flex:0 0 50%}.col-7{max-width:58.3333%;-ms-flex:0 0 58.3333%;flex:0 0 58.3333%}.col-8{max-width:66.6667%;-ms-flex:0 0 66.6667%;flex:0 0 66.6667%}.col-9{max-width:75%;-ms-flex:0 0 75%;flex:0 0 75%}.col-10{max-width:83.3333%;-ms-flex:0 0 83.3333%;flex:0 0 83.3333%}.col-11{max-width:91.6667%;-ms-flex:0 0 91.6667%;flex:0 0 91.6667%}.col-12{max-width:100%;-ms-flex:0 0 100%;flex:0 0 100%}.order-first{-ms-flex-order:-1;order:-1}.order-last{-ms-flex-order:13;order:13}.order-0{-ms-flex-order:0;order:0}.order-1{-ms-flex-order:1;order:1}.order-2{-ms-flex-order:2;order:2}.order-3{-ms-flex-order:3;order:3}.order-4{-ms-flex-order:4;order:4}.order-5{-ms-flex-order:5;order:5}.order-6{-ms-flex-order:6;order:6}.order-7{-ms-flex-order:7;order:7}.order-8{-ms-flex-order:8;order:8}.order-9{-ms-flex-order:9;order:9}.order-10{-ms-flex-order:10;order:10}.order-11{-ms-flex-order:11;order:11}.order-12{-ms-flex-order:12;order:12}.offset-1{margin-left:8.33333%}.offset-2{margin-left:16.6667%}.offset-3{margin-left:25%}.offset-4{margin-left:33.3333%}.offset-5{margin-left:41.6667%}.offset-6{margin-left:50%}.offset-7{margin-left:58.3333%}.offset-8{margin-left:66.6667%}.offset-9{margin-left:75%}.offset-10{margin-left:83.3333%}.offset-11{margin-left:91.6667%}@media (min-width:576px){.col-sm{max-width:100%;-ms-flex-positive:1;-ms-flex-preferred-size:0;flex-grow:1;flex-basis:0}.row-cols-sm-1>*{max-width:100%;-ms-flex:0 0 100%;flex:0 0 100%}.row-cols-sm-2>*{max-width:50%;-ms-flex:0 0 50%;flex:0 0 50%}.row-cols-sm-3>*{max-width:33.3333%;-ms-flex:0 0 33.3333%;flex:0 0 33.3333%}.row-cols-sm-4>*{max-width:25%;-ms-flex:0 0 25%;flex:0 0 25%}.row-cols-sm-5>*{max-width:20%;-ms-flex:0 0 20%;flex:0 0 20%}.row-cols-sm-6>*{max-width:16.6667%;-ms-flex:0 0 16.6667%;flex:0 0 16.6667%}.col-sm-auto{width:auto;max-width:100%;-ms-flex:none;flex:none}.col-sm-1{max-width:8.33333%;-ms-flex:0 0 8.33333%;flex:0 0 8.33333%}.col-sm-2{max-width:16.6667%;-ms-flex:0 0 16.6667%;flex:0 0 16.6667%}.col-sm-3{max-width:25%;-ms-flex:0 0 25%;flex:0 0 25%}.col-sm-4{max-width:33.3333%;-ms-flex:0 0 33.3333%;flex:0 0 33.3333%}.col-sm-5{max-width:41.6667%;-ms-flex:0 0 41.6667%;flex:0 0 41.6667%}.col-sm-6{max-width:50%;-ms-flex:0 0 50%;flex:0 0 50%}.col-sm-7{max-width:58.3333%;-ms-flex:0 0 58.3333%;flex:0 0 58.3333%}.col-sm-8{max-width:66.6667%;-ms-flex:0 0 66.6667%;flex:0 0 66.6667%}.col-sm-9{max-width:75%;-ms-flex:0 0 75%;flex:0 0 75%}.col-sm-10{max-width:83.3333%;-ms-flex:0 0 83.3333%;flex:0 0 83.3333%}.col-sm-11{max-width:91.6667%;-ms-flex:0 0 91.6667%;flex:0 0 91.6667%}.col-sm-12{max-width:100%;-ms-flex:0 0 100%;flex:0 0 100%}.order-sm-first{-ms-flex-order:-1;order:-1}.order-sm-last{-ms-flex-order:13;order:13}.order-sm-0{-ms-flex-order:0;order:0}.order-sm-1{-ms-flex-order:1;order:1}.order-sm-2{-ms-flex-order:2;order:2}.order-sm-3{-ms-flex-order:3;order:3}.order-sm-4{-ms-flex-order:4;order:4}.order-sm-5{-ms-flex-order:5;order:5}.order-sm-6{-ms-flex-order:6;order:6}.order-sm-7{-ms-flex-order:7;order:7}.order-sm-8{-ms-flex-order:8;order:8}.order-sm-9{-ms-flex-order:9;order:9}.order-sm-10{-ms-flex-order:10;order:10}.order-sm-11{-ms-flex-order:11;order:11}.order-sm-12{-ms-flex-order:12;order:12}.offset-sm-0{margin-left:0}.offset-sm-1{margin-left:8.33333%}.offset-sm-2{margin-left:16.6667%}.offset-sm-3{margin-left:25%}.offset-sm-4{margin-left:33.3333%}.offset-sm-5{margin-left:41.6667%}.offset-sm-6{margin-left:50%}.offset-sm-7{margin-left:58.3333%}.offset-sm-8{margin-left:66.6667%}.offset-sm-9{margin-left:75%}.offset-sm-10{margin-left:83.3333%}.offset-sm-11{margin-left:91.6667%}}@media (min-width:768px){.col-md{max-width:100%;-ms-flex-positive:1;-ms-flex-preferred-size:0;flex-grow:1;flex-basis:0}.row-cols-md-1>*{max-width:100%;-ms-flex:0 0 100%;flex:0 0 100%}.row-cols-md-2>*{max-width:50%;-ms-flex:0 0 50%;flex:0 0 50%}.row-cols-md-3>*{max-width:33.3333%;-ms-flex:0 0 33.3333%;flex:0 0 33.3333%}.row-cols-md-4>*{max-width:25%;-ms-flex:0 0 25%;flex:0 0 25%}.row-cols-md-5>*{max-width:20%;-ms-flex:0 0 20%;flex:0 0 20%}.row-cols-md-6>*{max-width:16.6667%;-ms-flex:0 0 16.6667%;flex:0 0 16.6667%}.col-md-auto{width:auto;max-width:100%;-ms-flex:none;flex:none}.col-md-1{max-width:8.33333%;-ms-flex:0 0 8.33333%;flex:0 0 8.33333%}.col-md-2{max-width:16.6667%;-ms-flex:0 0 16.6667%;flex:0 0 16.6667%}.col-md-3{max-width:25%;-ms-flex:0 0 25%;flex:0 0 25%}.col-md-4{max-width:33.3333%;-ms-flex:0 0 33.3333%;flex:0 0 33.3333%}.col-md-5{max-width:41.6667%;-ms-flex:0 0 41.6667%;flex:0 0 41.6667%}.col-md-6{max-width:50%;-ms-flex:0 0 50%;flex:0 0 50%}.col-md-7{max-width:58.3333%;-ms-flex:0 0 58.3333%;flex:0 0 58.3333%}.col-md-8{max-width:66.6667%;-ms-flex:0 0 66.6667%;flex:0 0 66.6667%}.col-md-9{max-width:75%;-ms-flex:0 0 75%;flex:0 0 75%}.col-md-10{max-width:83.3333%;-ms-flex:0 0 83.3333%;flex:0 0 83.3333%}.col-md-11{max-width:91.6667%;-ms-flex:0 0 91.6667%;flex:0 0 91.6667%}.col-md-12{max-width:100%;-ms-flex:0 0 100%;flex:0 0 100%}.order-md-first{-ms-flex-order:-1;order:-1}.order-md-last{-ms-flex-order:13;order:13}.order-md-0{-ms-flex-order:0;order:0}.order-md-1{-ms-flex-order:1;order:1}.order-md-2{-ms-flex-order:2;order:2}.order-md-3{-ms-flex-order:3;order:3}.order-md-4{-ms-flex-order:4;order:4}.order-md-5{-ms-flex-order:5;order:5}.order-md-6{-ms-flex-order:6;order:6}.order-md-7{-ms-flex-order:7;order:7}.order-md-8{-ms-flex-order:8;order:8}.order-md-9{-ms-flex-order:9;order:9}.order-md-10{-ms-flex-order:10;order:10}.order-md-11{-ms-flex-order:11;order:11}.order-md-12{-ms-flex-order:12;order:12}.offset-md-0{margin-left:0}.offset-md-1{margin-left:8.33333%}.offset-md-2{margin-left:16.6667%}.offset-md-3{margin-left:25%}.offset-md-4{margin-left:33.3333%}.offset-md-5{margin-left:41.6667%}.offset-md-6{margin-left:50%}.offset-md-7{margin-left:58.3333%}.offset-md-8{margin-left:66.6667%}.offset-md-9{margin-left:75%}.offset-md-10{margin-left:83.3333%}.offset-md-11{margin-left:91.6667%}}@media (min-width:992px){.col-lg{max-width:100%;-ms-flex-positive:1;-ms-flex-preferred-size:0;flex-grow:1;flex-basis:0}.row-cols-lg-1>*{max-width:100%;-ms-flex:0 0 100%;flex:0 0 100%}.row-cols-lg-2>*{max-width:50%;-ms-flex:0 0 50%;flex:0 0 50%}.row-cols-lg-3>*{max-width:33.3333%;-ms-flex:0 0 33.3333%;flex:0 0 33.3333%}.row-cols-lg-4>*{max-width:25%;-ms-flex:0 0 25%;flex:0 0 25%}.row-cols-lg-5>*{max-width:20%;-ms-flex:0 0 20%;flex:0 0 20%}.row-cols-lg-6>*{max-width:16.6667%;-ms-flex:0 0 16.6667%;flex:0 0 16.6667%}.col-lg-auto{width:auto;max-width:100%;-ms-flex:none;flex:none}.col-lg-1{max-width:8.33333%;-ms-flex:0 0 8.33333%;flex:0 0 8.33333%}.col-lg-2{max-width:16.6667%;-ms-flex:0 0 16.6667%;flex:0 0 16.6667%}.col-lg-3{max-width:25%;-ms-flex:0 0 25%;flex:0 0 25%}.col-lg-4{max-width:33.3333%;-ms-flex:0 0 33.3333%;flex:0 0 33.3333%}.col-lg-5{max-width:41.6667%;-ms-flex:0 0 41.6667%;flex:0 0 41.6667%}.col-lg-6{max-width:50%;-ms-flex:0 0 50%;flex:0 0 50%}.col-lg-7{max-width:58.3333%;-ms-flex:0 0 58.3333%;flex:0 0 58.3333%}.col-lg-8{max-width:66.6667%;-ms-flex:0 0 66.6667%;flex:0 0 66.6667%}.col-lg-9{max-width:75%;-ms-flex:0 0 75%;flex:0 0 75%}.col-lg-10{max-width:83.3333%;-ms-flex:0 0 83.3333%;flex:0 0 83.3333%}.col-lg-11{max-width:91.6667%;-ms-flex:0 0 91.6667%;flex:0 0 91.6667%}.col-lg-12{max-width:100%;-ms-flex:0 0 100%;flex:0 0 100%}.order-lg-first{-ms-flex-order:-1;order:-1}.order-lg-last{-ms-flex-order:13;order:13}.order-lg-0{-ms-flex-order:0;order:0}.order-lg-1{-ms-flex-order:1;order:1}.order-lg-2{-ms-flex-order:2;order:2}.order-lg-3{-ms-flex-order:3;order:3}.order-lg-4{-ms-flex-order:4;order:4}.order-lg-5{-ms-flex-order:5;order:5}.order-lg-6{-ms-flex-order:6;order:6}.order-lg-7{-ms-flex-order:7;order:7}.order-lg-8{-ms-flex-order:8;order:8}.order-lg-9{-ms-flex-order:9;order:9}.order-lg-10{-ms-flex-order:10;order:10}.order-lg-11{-ms-flex-order:11;order:11}.order-lg-12{-ms-flex-order:12;order:12}.offset-lg-0{margin-left:0}.offset-lg-1{margin-left:8.33333%}.offset-lg-2{margin-left:16.6667%}.offset-lg-3{margin-left:25%}.offset-lg-4{margin-left:33.3333%}.offset-lg-5{margin-left:41.6667%}.offset-lg-6{margin-left:50%}.offset-lg-7{margin-left:58.3333%}.offset-lg-8{margin-left:66.6667%}.offset-lg-9{margin-left:75%}.offset-lg-10{margin-left:83.3333%}.offset-lg-11{margin-left:91.6667%}}@media (min-width:1200px){.col-xl{max-width:100%;-ms-flex-positive:1;-ms-flex-preferred-size:0;flex-grow:1;flex-basis:0}.row-cols-xl-1>*{max-width:100%;-ms-flex:0 0 100%;flex:0 0 100%}.row-cols-xl-2>*{max-width:50%;-ms-flex:0 0 50%;flex:0 0 50%}.row-cols-xl-3>*{max-width:33.3333%;-ms-flex:0 0 33.3333%;flex:0 0 33.3333%}.row-cols-xl-4>*{max-width:25%;-ms-flex:0 0 25%;flex:0 0 25%}.row-cols-xl-5>*{max-width:20%;-ms-flex:0 0 20%;flex:0 0 20%}.row-cols-xl-6>*{max-width:16.6667%;-ms-flex:0 0 16.6667%;flex:0 0 16.6667%}.col-xl-auto{width:auto;max-width:100%;-ms-flex:none;flex:none}.col-xl-1{max-width:8.33333%;-ms-flex:0 0 8.33333%;flex:0 0 8.33333%}.col-xl-2{max-width:16.6667%;-ms-flex:0 0 16.6667%;flex:0 0 16.6667%}.col-xl-3{max-width:25%;-ms-flex:0 0 25%;flex:0 0 25%}.col-xl-4{max-width:33.3333%;-ms-flex:0 0 33.3333%;flex:0 0 33.3333%}.col-xl-5{max-width:41.6667%;-ms-flex:0 0 41.6667%;flex:0 0 41.6667%}.col-xl-6{max-width:50%;-ms-flex:0 0 50%;flex:0 0 50%}.col-xl-7{max-width:58.3333%;-ms-flex:0 0 58.3333%;flex:0 0 58.3333%}.col-xl-8{max-width:66.6667%;-ms-flex:0 0 66.6667%;flex:0 0 66.6667%}.col-xl-9{max-width:75%;-ms-flex:0 0 75%;flex:0 0 75%}.col-xl-10{max-width:83.3333%;-ms-flex:0 0 83.3333%;flex:0 0 83.3333%}.col-xl-11{max-width:91.6667%;-ms-flex:0 0 91.6667%;flex:0 0 91.6667%}.col-xl-12{max-width:100%;-ms-flex:0 0 100%;flex:0 0 100%}.order-xl-first{-ms-flex-order:-1;order:-1}.order-xl-last{-ms-flex-order:13;order:13}.order-xl-0{-ms-flex-order:0;order:0}.order-xl-1{-ms-flex-order:1;order:1}.order-xl-2{-ms-flex-order:2;order:2}.order-xl-3{-ms-flex-order:3;order:3}.order-xl-4{-ms-flex-order:4;order:4}.order-xl-5{-ms-flex-order:5;order:5}.order-xl-6{-ms-flex-order:6;order:6}.order-xl-7{-ms-flex-order:7;order:7}.order-xl-8{-ms-flex-order:8;order:8}.order-xl-9{-ms-flex-order:9;order:9}.order-xl-10{-ms-flex-order:10;order:10}.order-xl-11{-ms-flex-order:11;order:11}.order-xl-12{-ms-flex-order:12;order:12}.offset-xl-0{margin-left:0}.offset-xl-1{margin-left:8.33333%}.offset-xl-2{margin-left:16.6667%}.offset-xl-3{margin-left:25%}.offset-xl-4{margin-left:33.3333%}.offset-xl-5{margin-left:41.6667%}.offset-xl-6{margin-left:50%}.offset-xl-7{margin-left:58.3333%}.offset-xl-8{margin-left:66.6667%}.offset-xl-9{margin-left:75%}.offset-xl-10{margin-left:83.3333%}.offset-xl-11{margin-left:91.6667%}}.table{width:100%;color:#212529;margin-bottom:1rem}.table td,.table th{vertical-align:top;border-top:1px solid #dee2e6;padding:.75rem}.table thead th{vertical-align:bottom;border-bottom:2px solid #dee2e6}.table tbody+tbody{border-top:2px solid #dee2e6}.table-sm td,.table-sm th{padding:.3rem}.table-bordered,.table-bordered td,.table-bordered th{border:1px solid #dee2e6}.table-bordered thead td,.table-bordered thead th{border-bottom-width:2px}.table-borderless tbody+tbody,.table-borderless td,.table-borderless th,.table-borderless thead th{border:0}.table-striped tbody tr:nth-of-type(2n+1){background-color:#0000000d}.table-hover tbody tr:hover{color:#212529;background-color:#00000013}.table-primary,.table-primary>td,.table-primary>th{background-color:#b8daff}.table-primary tbody+tbody,.table-primary td,.table-primary th,.table-primary thead th{border-color:#7abaff}.table-hover .table-primary:hover{background-color:#9fcdff}.table-hover .table-primary:hover>td,.table-hover .table-primary:hover>th{background-color:#9fcdff}.table-secondary,.table-secondary>td,.table-secondary>th{background-color:#d6d8db}.table-secondary tbody+tbody,.table-secondary td,.table-secondary th,.table-secondary thead th{border-color:#b3b7bb}.table-hover .table-secondary:hover{background-color:#c8cbcf}.table-hover .table-secondary:hover>td,.table-hover .table-secondary:hover>th{background-color:#c8cbcf}.table-success,.table-success>td,.table-success>th{background-color:#c3e6cb}.table-success tbody+tbody,.table-success td,.table-success th,.table-success thead th{border-color:#8fd19e}.table-hover .table-success:hover{background-color:#b1dfbb}.table-hover .table-success:hover>td,.table-hover .table-success:hover>th{background-color:#b1dfbb}.table-info,.table-info>td,.table-info>th{background-color:#bee5eb}.table-info tbody+tbody,.table-info td,.table-info th,.table-info thead th{border-color:#86cfda}.table-hover .table-info:hover{background-color:#abdde5}.table-hover .table-info:hover>td,.table-hover .table-info:hover>th{background-color:#abdde5}.table-warning,.table-warning>td,.table-warning>th{background-color:#ffeeba}.table-warning tbody+tbody,.table-warning td,.table-warning th,.table-warning thead th{border-color:#ffdf7e}.table-hover .table-warning:hover{background-color:#ffe8a1}.table-hover .table-warning:hover>td,.table-hover .table-warning:hover>th{background-color:#ffe8a1}.table-danger,.table-danger>td,.table-danger>th{background-color:#f5c6cb}.table-danger tbody+tbody,.table-danger td,.table-danger th,.table-danger thead th{border-color:#ed969e}.table-hover .table-danger:hover{background-color:#f1b0b7}.table-hover .table-danger:hover>td,.table-hover .table-danger:hover>th{background-color:#f1b0b7}.table-light,.table-light>td,.table-light>th{background-color:#fdfdfe}.table-light tbody+tbody,.table-light td,.table-light th,.table-light thead th{border-color:#fbfcfc}.table-hover .table-light:hover{background-color:#ececf6}.table-hover .table-light:hover>td,.table-hover .table-light:hover>th{background-color:#ececf6}.table-dark,.table-dark>td,.table-dark>th{background-color:#c6c8ca}.table-dark tbody+tbody,.table-dark td,.table-dark th,.table-dark thead th{border-color:#95999c}.table-hover .table-dark:hover{background-color:#b9bbbe}.table-hover .table-dark:hover>td,.table-hover .table-dark:hover>th{background-color:#b9bbbe}.table-active,.table-active>td,.table-active>th{background-color:#00000013}.table-hover .table-active:hover{background-color:#00000013}.table-hover .table-active:hover>td,.table-hover .table-active:hover>th{background-color:#00000013}.table .thead-dark th{color:#fff;background-color:#343a40;border-color:#454d55}.table .thead-light th{color:#495057;background-color:#e9ecef;border-color:#dee2e6}.table-dark{color:#fff;background-color:#343a40}.table-dark td,.table-dark th,.table-dark thead th{border-color:#454d55}.table-dark.table-bordered{border:0}.table-dark.table-striped tbody tr:nth-of-type(2n+1){background-color:#ffffff0d}.table-dark.table-hover tbody tr:hover{color:#fff;background-color:#ffffff13}@media (max-width:575.98px){.table-responsive-sm{width:100%;-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.table-responsive-sm>.table-bordered{border:0}}@media (max-width:767.98px){.table-responsive-md{width:100%;-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.table-responsive-md>.table-bordered{border:0}}@media (max-width:991.98px){.table-responsive-lg{width:100%;-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.table-responsive-lg>.table-bordered{border:0}}@media (max-width:1199.98px){.table-responsive-xl{width:100%;-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.table-responsive-xl>.table-bordered{border:0}}.table-responsive{width:100%;-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.table-responsive>.table-bordered{border:0}.form-control{width:100%;height:calc(1.5em + .75rem + 2px);color:#495057;background-color:#fff;background-clip:padding-box;border:1px solid #ced4da;border-radius:.25rem;padding:.375rem .75rem;font-size:1rem;font-weight:400;line-height:1.5;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;display:block}@media (prefers-reduced-motion:reduce){.form-control{transition:none}}.form-control::-ms-expand{background-color:#0000;border:0}.form-control:focus{color:#495057;background-color:#fff;border-color:#80bdff;outline:0;box-shadow:0 0 0 .2rem #007bff40}.form-control::-webkit-input-placeholder{color:#6c757d;opacity:1}.form-control::-moz-placeholder{color:#6c757d;opacity:1}.form-control:-ms-input-placeholder{color:#6c757d;opacity:1}.form-control::-moz-placeholder{color:#6c757d;opacity:1}.form-control::placeholder{color:#6c757d;opacity:1}.form-control:disabled,.form-control[readonly]{opacity:1;background-color:#e9ecef}input[type=date].form-control,input[type=datetime-local].form-control,input[type=month].form-control,input[type=time].form-control{-webkit-appearance:none;-moz-appearance:none;appearance:none}select.form-control:-moz-focusring{color:#0000;text-shadow:0 0 #495057}select.form-control:focus::-ms-value{color:#495057;background-color:#fff}.form-control-file,.form-control-range{width:100%;display:block}.col-form-label{font-size:inherit;margin-bottom:0;padding-top:calc(.375rem + 1px);padding-bottom:calc(.375rem + 1px);line-height:1.5}.col-form-label-lg{padding-top:calc(.5rem + 1px);padding-bottom:calc(.5rem + 1px);font-size:1.25rem;line-height:1.5}.col-form-label-sm{padding-top:calc(.25rem + 1px);padding-bottom:calc(.25rem + 1px);font-size:.875rem;line-height:1.5}.form-control-plaintext{width:100%;color:#212529;background-color:#0000;border:1px solid #0000;border-width:1px 0;margin-bottom:0;padding:.375rem 0;font-size:1rem;line-height:1.5;display:block}.form-control-plaintext.form-control-lg,.form-control-plaintext.form-control-sm{padding-left:0;padding-right:0}.form-control-sm{height:calc(1.5em + .5rem + 2px);border-radius:.2rem;padding:.25rem .5rem;font-size:.875rem;line-height:1.5}.form-control-lg{height:calc(1.5em + 1rem + 2px);border-radius:.3rem;padding:.5rem 1rem;font-size:1.25rem;line-height:1.5}select.form-control[multiple],select.form-control[size]{height:auto}textarea.form-control{height:auto}.form-group{margin-bottom:1rem}.form-text{margin-top:.25rem;display:block}.form-row{-ms-flex-wrap:wrap;flex-wrap:wrap;margin-left:-5px;margin-right:-5px;display:-ms-flexbox;display:flex}.form-row>.col,.form-row>[class*=col-]{padding-left:5px;padding-right:5px}.form-check{padding-left:1.25rem;display:block;position:relative}.form-check-input{margin-top:.3rem;margin-left:-1.25rem;position:absolute}.form-check-input:disabled~.form-check-label,.form-check-input[disabled]~.form-check-label{color:#6c757d}.form-check-label{margin-bottom:0}.form-check-inline{align-items:center;margin-right:.75rem;padding-left:0;display:-ms-inline-flexbox;display:inline-flex}.form-check-inline .form-check-input{margin-top:0;margin-left:0;margin-right:.3125rem;position:static}.valid-feedback{width:100%;color:#28a745;margin-top:.25rem;font-size:.875em;display:none}.valid-tooltip{z-index:5;max-width:100%;color:#fff;background-color:#28a745e6;border-radius:.25rem;margin-top:.1rem;padding:.25rem .5rem;font-size:.875rem;line-height:1.5;display:none;position:absolute;top:100%;left:0}.form-row>.col>.valid-tooltip,.form-row>[class*=col-]>.valid-tooltip{left:5px}.is-valid~.valid-feedback,.is-valid~.valid-tooltip,.was-validated :valid~.valid-feedback,.was-validated :valid~.valid-tooltip{display:block}.form-control.is-valid,.was-validated .form-control:valid{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8'%3e%3cpath fill='%2328a745' d='M2.3 6.73L.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e");background-position:right calc(.375em + .1875rem) center;background-repeat:no-repeat;background-size:calc(.75em + .375rem) calc(.75em + .375rem);border-color:#28a745;padding-right:calc(1.5em + .75rem)!important}.form-control.is-valid:focus,.was-validated .form-control:valid:focus{border-color:#28a745;box-shadow:0 0 0 .2rem #28a74540}.was-validated select.form-control:valid,select.form-control.is-valid{background-position:right 1.5rem center;padding-right:3rem!important}.was-validated textarea.form-control:valid,textarea.form-control.is-valid{background-position:right calc(.375em + .1875rem) top calc(.375em + .1875rem);padding-right:calc(1.5em + .75rem)}.custom-select.is-valid,.was-validated .custom-select:valid{background:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='4' height='5' viewBox='0 0 4 5'%3e%3cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") right .75rem center/8px 10px no-repeat,#fff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8'%3e%3cpath fill='%2328a745' d='M2.3 6.73L.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e") right 1.75rem center/calc(.75em + .375rem) calc(.75em + .375rem) no-repeat;border-color:#28a745;padding-right:calc(.75em + 2.3125rem)!important}.custom-select.is-valid:focus,.was-validated .custom-select:valid:focus{border-color:#28a745;box-shadow:0 0 0 .2rem #28a74540}.form-check-input.is-valid~.form-check-label,.was-validated .form-check-input:valid~.form-check-label{color:#28a745}.form-check-input.is-valid~.valid-feedback,.form-check-input.is-valid~.valid-tooltip,.was-validated .form-check-input:valid~.valid-feedback,.was-validated .form-check-input:valid~.valid-tooltip{display:block}.custom-control-input.is-valid~.custom-control-label,.was-validated .custom-control-input:valid~.custom-control-label{color:#28a745}.custom-control-input.is-valid~.custom-control-label:before,.was-validated .custom-control-input:valid~.custom-control-label:before{border-color:#28a745}.custom-control-input.is-valid:checked~.custom-control-label:before,.was-validated .custom-control-input:valid:checked~.custom-control-label:before{background-color:#34ce57;border-color:#34ce57}.custom-control-input.is-valid:focus~.custom-control-label:before,.was-validated .custom-control-input:valid:focus~.custom-control-label:before{box-shadow:0 0 0 .2rem #28a74540}.custom-control-input.is-valid:focus:not(:checked)~.custom-control-label:before,.was-validated .custom-control-input:valid:focus:not(:checked)~.custom-control-label:before{border-color:#28a745}.custom-file-input.is-valid~.custom-file-label,.was-validated .custom-file-input:valid~.custom-file-label{border-color:#28a745}.custom-file-input.is-valid:focus~.custom-file-label,.was-validated .custom-file-input:valid:focus~.custom-file-label{border-color:#28a745;box-shadow:0 0 0 .2rem #28a74540}.invalid-feedback{width:100%;color:#dc3545;margin-top:.25rem;font-size:.875em;display:none}.invalid-tooltip{z-index:5;max-width:100%;color:#fff;background-color:#dc3545e6;border-radius:.25rem;margin-top:.1rem;padding:.25rem .5rem;font-size:.875rem;line-height:1.5;display:none;position:absolute;top:100%;left:0}.form-row>.col>.invalid-tooltip,.form-row>[class*=col-]>.invalid-tooltip{left:5px}.is-invalid~.invalid-feedback,.is-invalid~.invalid-tooltip,.was-validated :invalid~.invalid-feedback,.was-validated :invalid~.invalid-tooltip{display:block}.form-control.is-invalid,.was-validated .form-control:invalid{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23dc3545' viewBox='0 0 12 12'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");background-position:right calc(.375em + .1875rem) center;background-repeat:no-repeat;background-size:calc(.75em + .375rem) calc(.75em + .375rem);border-color:#dc3545;padding-right:calc(1.5em + .75rem)!important}.form-control.is-invalid:focus,.was-validated .form-control:invalid:focus{border-color:#dc3545;box-shadow:0 0 0 .2rem #dc354540}.was-validated select.form-control:invalid,select.form-control.is-invalid{background-position:right 1.5rem center;padding-right:3rem!important}.was-validated textarea.form-control:invalid,textarea.form-control.is-invalid{background-position:right calc(.375em + .1875rem) top calc(.375em + .1875rem);padding-right:calc(1.5em + .75rem)}.custom-select.is-invalid,.was-validated .custom-select:invalid{background:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='4' height='5' viewBox='0 0 4 5'%3e%3cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") right .75rem center/8px 10px no-repeat,#fff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23dc3545' viewBox='0 0 12 12'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e") right 1.75rem center/calc(.75em + .375rem) calc(.75em + .375rem) no-repeat;border-color:#dc3545;padding-right:calc(.75em + 2.3125rem)!important}.custom-select.is-invalid:focus,.was-validated .custom-select:invalid:focus{border-color:#dc3545;box-shadow:0 0 0 .2rem #dc354540}.form-check-input.is-invalid~.form-check-label,.was-validated .form-check-input:invalid~.form-check-label{color:#dc3545}.form-check-input.is-invalid~.invalid-feedback,.form-check-input.is-invalid~.invalid-tooltip,.was-validated .form-check-input:invalid~.invalid-feedback,.was-validated .form-check-input:invalid~.invalid-tooltip{display:block}.custom-control-input.is-invalid~.custom-control-label,.was-validated .custom-control-input:invalid~.custom-control-label{color:#dc3545}.custom-control-input.is-invalid~.custom-control-label:before,.was-validated .custom-control-input:invalid~.custom-control-label:before{border-color:#dc3545}.custom-control-input.is-invalid:checked~.custom-control-label:before,.was-validated .custom-control-input:invalid:checked~.custom-control-label:before{background-color:#e4606d;border-color:#e4606d}.custom-control-input.is-invalid:focus~.custom-control-label:before,.was-validated .custom-control-input:invalid:focus~.custom-control-label:before{box-shadow:0 0 0 .2rem #dc354540}.custom-control-input.is-invalid:focus:not(:checked)~.custom-control-label:before,.was-validated .custom-control-input:invalid:focus:not(:checked)~.custom-control-label:before{border-color:#dc3545}.custom-file-input.is-invalid~.custom-file-label,.was-validated .custom-file-input:invalid~.custom-file-label{border-color:#dc3545}.custom-file-input.is-invalid:focus~.custom-file-label,.was-validated .custom-file-input:invalid:focus~.custom-file-label{border-color:#dc3545;box-shadow:0 0 0 .2rem #dc354540}.form-inline{-ms-flex-flow:wrap;flex-flow:wrap;align-items:center;display:-ms-flexbox;display:flex}.form-inline .form-check{width:100%}@media (min-width:576px){.form-inline label{justify-content:center;align-items:center;margin-bottom:0;display:-ms-flexbox;display:flex}.form-inline .form-group{-ms-flex-flow:wrap;flex-flow:wrap;-ms-flex:none;flex:none;align-items:center;margin-bottom:0;display:-ms-flexbox;display:flex}.form-inline .form-control{width:auto;vertical-align:middle;display:inline-block}.form-inline .form-control-plaintext{display:inline-block}.form-inline .custom-select,.form-inline .input-group{width:auto}.form-inline .form-check{width:auto;justify-content:center;align-items:center;padding-left:0;display:-ms-flexbox;display:flex}.form-inline .form-check-input{-ms-flex-negative:0;flex-shrink:0;margin-top:0;margin-left:0;margin-right:.25rem;position:relative}.form-inline .custom-control{justify-content:center;align-items:center}.form-inline .custom-control-label{margin-bottom:0}}.btn{color:#212529;text-align:center;vertical-align:middle;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-color:#0000;border:1px solid #0000;border-radius:.25rem;padding:.375rem .75rem;font-size:1rem;font-weight:400;line-height:1.5;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;display:inline-block}@media (prefers-reduced-motion:reduce){.btn{transition:none}}.btn:hover{color:#212529;text-decoration:none}.btn.focus,.btn:focus{outline:0;box-shadow:0 0 0 .2rem #007bff40}.btn.disabled,.btn:disabled{opacity:.65}.btn:not(:disabled):not(.disabled){cursor:pointer}a.btn.disabled,fieldset:disabled a.btn{pointer-events:none}.btn-primary{color:#fff;background-color:#007bff;border-color:#007bff}.btn-primary:hover{color:#fff;background-color:#0069d9;border-color:#0062cc}.btn-primary.focus,.btn-primary:focus{color:#fff;background-color:#0069d9;border-color:#0062cc;box-shadow:0 0 0 .2rem #268fff80}.btn-primary.disabled,.btn-primary:disabled{color:#fff;background-color:#007bff;border-color:#007bff}.btn-primary:not(:disabled):not(.disabled).active,.btn-primary:not(:disabled):not(.disabled):active,.show>.btn-primary.dropdown-toggle{color:#fff;background-color:#0062cc;border-color:#005cbf}.btn-primary:not(:disabled):not(.disabled).active:focus,.btn-primary:not(:disabled):not(.disabled):active:focus,.show>.btn-primary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #268fff80}.btn-secondary{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-secondary:hover{color:#fff;background-color:#5a6268;border-color:#545b62}.btn-secondary.focus,.btn-secondary:focus{color:#fff;background-color:#5a6268;border-color:#545b62;box-shadow:0 0 0 .2rem #828a9180}.btn-secondary.disabled,.btn-secondary:disabled{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-secondary:not(:disabled):not(.disabled).active,.btn-secondary:not(:disabled):not(.disabled):active,.show>.btn-secondary.dropdown-toggle{color:#fff;background-color:#545b62;border-color:#4e555b}.btn-secondary:not(:disabled):not(.disabled).active:focus,.btn-secondary:not(:disabled):not(.disabled):active:focus,.show>.btn-secondary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #828a9180}.btn-success{color:#fff;background-color:#28a745;border-color:#28a745}.btn-success:hover{color:#fff;background-color:#218838;border-color:#1e7e34}.btn-success.focus,.btn-success:focus{color:#fff;background-color:#218838;border-color:#1e7e34;box-shadow:0 0 0 .2rem #48b46180}.btn-success.disabled,.btn-success:disabled{color:#fff;background-color:#28a745;border-color:#28a745}.btn-success:not(:disabled):not(.disabled).active,.btn-success:not(:disabled):not(.disabled):active,.show>.btn-success.dropdown-toggle{color:#fff;background-color:#1e7e34;border-color:#1c7430}.btn-success:not(:disabled):not(.disabled).active:focus,.btn-success:not(:disabled):not(.disabled):active:focus,.show>.btn-success.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #48b46180}.btn-info{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-info:hover{color:#fff;background-color:#138496;border-color:#117a8b}.btn-info.focus,.btn-info:focus{color:#fff;background-color:#138496;border-color:#117a8b;box-shadow:0 0 0 .2rem #3ab0c380}.btn-info.disabled,.btn-info:disabled{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-info:not(:disabled):not(.disabled).active,.btn-info:not(:disabled):not(.disabled):active,.show>.btn-info.dropdown-toggle{color:#fff;background-color:#117a8b;border-color:#10707f}.btn-info:not(:disabled):not(.disabled).active:focus,.btn-info:not(:disabled):not(.disabled):active:focus,.show>.btn-info.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #3ab0c380}.btn-warning{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-warning:hover{color:#212529;background-color:#e0a800;border-color:#d39e00}.btn-warning.focus,.btn-warning:focus{color:#212529;background-color:#e0a800;border-color:#d39e00;box-shadow:0 0 0 .2rem #deaa0c80}.btn-warning.disabled,.btn-warning:disabled{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-warning:not(:disabled):not(.disabled).active,.btn-warning:not(:disabled):not(.disabled):active,.show>.btn-warning.dropdown-toggle{color:#212529;background-color:#d39e00;border-color:#c69500}.btn-warning:not(:disabled):not(.disabled).active:focus,.btn-warning:not(:disabled):not(.disabled):active:focus,.show>.btn-warning.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #deaa0c80}.btn-danger{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-danger:hover{color:#fff;background-color:#c82333;border-color:#bd2130}.btn-danger.focus,.btn-danger:focus{color:#fff;background-color:#c82333;border-color:#bd2130;box-shadow:0 0 0 .2rem #e1536180}.btn-danger.disabled,.btn-danger:disabled{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-danger:not(:disabled):not(.disabled).active,.btn-danger:not(:disabled):not(.disabled):active,.show>.btn-danger.dropdown-toggle{color:#fff;background-color:#bd2130;border-color:#b21f2d}.btn-danger:not(:disabled):not(.disabled).active:focus,.btn-danger:not(:disabled):not(.disabled):active:focus,.show>.btn-danger.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #e1536180}.btn-light{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-light:hover{color:#212529;background-color:#e2e6ea;border-color:#dae0e5}.btn-light.focus,.btn-light:focus{color:#212529;background-color:#e2e6ea;border-color:#dae0e5;box-shadow:0 0 0 .2rem #d8d9db80}.btn-light.disabled,.btn-light:disabled{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-light:not(:disabled):not(.disabled).active,.btn-light:not(:disabled):not(.disabled):active,.show>.btn-light.dropdown-toggle{color:#212529;background-color:#dae0e5;border-color:#d3d9df}.btn-light:not(:disabled):not(.disabled).active:focus,.btn-light:not(:disabled):not(.disabled):active:focus,.show>.btn-light.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #d8d9db80}.btn-dark{color:#fff;background-color:#343a40;border-color:#343a40}.btn-dark:hover{color:#fff;background-color:#23272b;border-color:#1d2124}.btn-dark.focus,.btn-dark:focus{color:#fff;background-color:#23272b;border-color:#1d2124;box-shadow:0 0 0 .2rem #52585d80}.btn-dark.disabled,.btn-dark:disabled{color:#fff;background-color:#343a40;border-color:#343a40}.btn-dark:not(:disabled):not(.disabled).active,.btn-dark:not(:disabled):not(.disabled):active,.show>.btn-dark.dropdown-toggle{color:#fff;background-color:#1d2124;border-color:#171a1d}.btn-dark:not(:disabled):not(.disabled).active:focus,.btn-dark:not(:disabled):not(.disabled):active:focus,.show>.btn-dark.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #52585d80}.btn-outline-primary{color:#007bff;border-color:#007bff}.btn-outline-primary:hover{color:#fff;background-color:#007bff;border-color:#007bff}.btn-outline-primary.focus,.btn-outline-primary:focus{box-shadow:0 0 0 .2rem #007bff80}.btn-outline-primary.disabled,.btn-outline-primary:disabled{color:#007bff;background-color:#0000}.btn-outline-primary:not(:disabled):not(.disabled).active,.btn-outline-primary:not(:disabled):not(.disabled):active,.show>.btn-outline-primary.dropdown-toggle{color:#fff;background-color:#007bff;border-color:#007bff}.btn-outline-primary:not(:disabled):not(.disabled).active:focus,.btn-outline-primary:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-primary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #007bff80}.btn-outline-secondary{color:#6c757d;border-color:#6c757d}.btn-outline-secondary:hover{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-outline-secondary.focus,.btn-outline-secondary:focus{box-shadow:0 0 0 .2rem #6c757d80}.btn-outline-secondary.disabled,.btn-outline-secondary:disabled{color:#6c757d;background-color:#0000}.btn-outline-secondary:not(:disabled):not(.disabled).active,.btn-outline-secondary:not(:disabled):not(.disabled):active,.show>.btn-outline-secondary.dropdown-toggle{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-outline-secondary:not(:disabled):not(.disabled).active:focus,.btn-outline-secondary:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-secondary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #6c757d80}.btn-outline-success{color:#28a745;border-color:#28a745}.btn-outline-success:hover{color:#fff;background-color:#28a745;border-color:#28a745}.btn-outline-success.focus,.btn-outline-success:focus{box-shadow:0 0 0 .2rem #28a74580}.btn-outline-success.disabled,.btn-outline-success:disabled{color:#28a745;background-color:#0000}.btn-outline-success:not(:disabled):not(.disabled).active,.btn-outline-success:not(:disabled):not(.disabled):active,.show>.btn-outline-success.dropdown-toggle{color:#fff;background-color:#28a745;border-color:#28a745}.btn-outline-success:not(:disabled):not(.disabled).active:focus,.btn-outline-success:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-success.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #28a74580}.btn-outline-info{color:#17a2b8;border-color:#17a2b8}.btn-outline-info:hover{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-outline-info.focus,.btn-outline-info:focus{box-shadow:0 0 0 .2rem #17a2b880}.btn-outline-info.disabled,.btn-outline-info:disabled{color:#17a2b8;background-color:#0000}.btn-outline-info:not(:disabled):not(.disabled).active,.btn-outline-info:not(:disabled):not(.disabled):active,.show>.btn-outline-info.dropdown-toggle{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-outline-info:not(:disabled):not(.disabled).active:focus,.btn-outline-info:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-info.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #17a2b880}.btn-outline-warning{color:#ffc107;border-color:#ffc107}.btn-outline-warning:hover{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-outline-warning.focus,.btn-outline-warning:focus{box-shadow:0 0 0 .2rem #ffc10780}.btn-outline-warning.disabled,.btn-outline-warning:disabled{color:#ffc107;background-color:#0000}.btn-outline-warning:not(:disabled):not(.disabled).active,.btn-outline-warning:not(:disabled):not(.disabled):active,.show>.btn-outline-warning.dropdown-toggle{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-outline-warning:not(:disabled):not(.disabled).active:focus,.btn-outline-warning:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-warning.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #ffc10780}.btn-outline-danger{color:#dc3545;border-color:#dc3545}.btn-outline-danger:hover{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-outline-danger.focus,.btn-outline-danger:focus{box-shadow:0 0 0 .2rem #dc354580}.btn-outline-danger.disabled,.btn-outline-danger:disabled{color:#dc3545;background-color:#0000}.btn-outline-danger:not(:disabled):not(.disabled).active,.btn-outline-danger:not(:disabled):not(.disabled):active,.show>.btn-outline-danger.dropdown-toggle{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-outline-danger:not(:disabled):not(.disabled).active:focus,.btn-outline-danger:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-danger.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #dc354580}.btn-outline-light{color:#f8f9fa;border-color:#f8f9fa}.btn-outline-light:hover{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-outline-light.focus,.btn-outline-light:focus{box-shadow:0 0 0 .2rem #f8f9fa80}.btn-outline-light.disabled,.btn-outline-light:disabled{color:#f8f9fa;background-color:#0000}.btn-outline-light:not(:disabled):not(.disabled).active,.btn-outline-light:not(:disabled):not(.disabled):active,.show>.btn-outline-light.dropdown-toggle{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-outline-light:not(:disabled):not(.disabled).active:focus,.btn-outline-light:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-light.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #f8f9fa80}.btn-outline-dark{color:#343a40;border-color:#343a40}.btn-outline-dark:hover{color:#fff;background-color:#343a40;border-color:#343a40}.btn-outline-dark.focus,.btn-outline-dark:focus{box-shadow:0 0 0 .2rem #343a4080}.btn-outline-dark.disabled,.btn-outline-dark:disabled{color:#343a40;background-color:#0000}.btn-outline-dark:not(:disabled):not(.disabled).active,.btn-outline-dark:not(:disabled):not(.disabled):active,.show>.btn-outline-dark.dropdown-toggle{color:#fff;background-color:#343a40;border-color:#343a40}.btn-outline-dark:not(:disabled):not(.disabled).active:focus,.btn-outline-dark:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-dark.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #343a4080}.btn-link{color:#007bff;font-weight:400;text-decoration:none}.btn-link:hover{color:#0056b3;text-decoration:underline}.btn-link.focus,.btn-link:focus{text-decoration:underline}.btn-link.disabled,.btn-link:disabled{color:#6c757d;pointer-events:none}.btn-group-lg>.btn,.btn-lg{border-radius:.3rem;padding:.5rem 1rem;font-size:1.25rem;line-height:1.5}.btn-group-sm>.btn,.btn-sm{border-radius:.2rem;padding:.25rem .5rem;font-size:.875rem;line-height:1.5}.btn-block{width:100%;display:block}.btn-block+.btn-block{margin-top:.5rem}input[type=button].btn-block,input[type=reset].btn-block,input[type=submit].btn-block{width:100%}.fade{transition:opacity .15s linear}@media (prefers-reduced-motion:reduce){.fade{transition:none}}.fade:not(.show){opacity:0}.collapse:not(.show){display:none}.collapsing{height:0;transition:height .35s;position:relative;overflow:hidden}@media (prefers-reduced-motion:reduce){.collapsing{transition:none}}.collapsing.width{width:0;height:auto;transition:width .35s}@media (prefers-reduced-motion:reduce){.collapsing.width{transition:none}}.dropdown,.dropleft,.dropright,.dropup{position:relative}.dropdown-toggle{white-space:nowrap}.dropdown-toggle:after{vertical-align:.255em;content:"";border:.3em solid #0000;border-top-color:currentColor;border-bottom:0;margin-left:.255em;display:inline-block}.dropdown-toggle:empty:after{margin-left:0}.dropdown-menu{z-index:1000;float:left;min-width:10rem;color:#212529;text-align:left;background-color:#fff;background-clip:padding-box;border:1px solid #00000026;border-radius:.25rem;margin:.125rem 0 0;padding:.5rem 0;font-size:1rem;list-style:none;display:none;position:absolute;top:100%;left:0}.dropdown-menu-left{left:0;right:auto}.dropdown-menu-right{left:auto;right:0}@media (min-width:576px){.dropdown-menu-sm-left{left:0;right:auto}.dropdown-menu-sm-right{left:auto;right:0}}@media (min-width:768px){.dropdown-menu-md-left{left:0;right:auto}.dropdown-menu-md-right{left:auto;right:0}}@media (min-width:992px){.dropdown-menu-lg-left{left:0;right:auto}.dropdown-menu-lg-right{left:auto;right:0}}@media (min-width:1200px){.dropdown-menu-xl-left{left:0;right:auto}.dropdown-menu-xl-right{left:auto;right:0}}.dropup .dropdown-menu{margin-top:0;margin-bottom:.125rem;top:auto;bottom:100%}.dropup .dropdown-toggle:after{vertical-align:.255em;content:"";border:.3em solid #0000;border-top:0;border-bottom-color:currentColor;margin-left:.255em;display:inline-block}.dropup .dropdown-toggle:empty:after{margin-left:0}.dropright .dropdown-menu{margin-top:0;margin-left:.125rem;top:0;left:100%;right:auto}.dropright .dropdown-toggle:after{vertical-align:.255em;content:"";border:.3em solid #0000;border-left-color:currentColor;border-right:0;margin-left:.255em;display:inline-block}.dropright .dropdown-toggle:empty:after{margin-left:0}.dropright .dropdown-toggle:after{vertical-align:0}.dropleft .dropdown-menu{margin-top:0;margin-right:.125rem;top:0;left:auto;right:100%}.dropleft .dropdown-toggle:after{vertical-align:.255em;content:"";margin-left:.255em;display:inline-block}.dropleft .dropdown-toggle:after{display:none}.dropleft .dropdown-toggle:before{vertical-align:.255em;content:"";border-top:.3em solid #0000;border-bottom:.3em solid #0000;border-right:.3em solid;margin-right:.255em;display:inline-block}.dropleft .dropdown-toggle:empty:after{margin-left:0}.dropleft .dropdown-toggle:before{vertical-align:0}.dropdown-menu[x-placement^=bottom],.dropdown-menu[x-placement^=left],.dropdown-menu[x-placement^=right],.dropdown-menu[x-placement^=top]{bottom:auto;right:auto}.dropdown-divider{height:0;border-top:1px solid #e9ecef;margin:.5rem 0;overflow:hidden}.dropdown-item{width:100%;clear:both;color:#212529;text-align:inherit;white-space:nowrap;background-color:#0000;border:0;padding:.25rem 1.5rem;font-weight:400;display:block}.dropdown-item:focus,.dropdown-item:hover{color:#16181b;background-color:#e9ecef;text-decoration:none}.dropdown-item.active,.dropdown-item:active{color:#fff;background-color:#007bff;text-decoration:none}.dropdown-item.disabled,.dropdown-item:disabled{color:#adb5bd;pointer-events:none;background-color:#0000}.dropdown-menu.show{display:block}.dropdown-header{color:#6c757d;white-space:nowrap;margin-bottom:0;padding:.5rem 1.5rem;font-size:.875rem;display:block}.dropdown-item-text{color:#212529;padding:.25rem 1.5rem;display:block}.btn-group,.btn-group-vertical{vertical-align:middle;display:-ms-inline-flexbox;display:inline-flex;position:relative}.btn-group-vertical>.btn,.btn-group>.btn{-ms-flex:auto;flex:auto;position:relative}.btn-group-vertical>.btn:hover,.btn-group>.btn:hover{z-index:1}.btn-group-vertical>.btn.active,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn:focus,.btn-group>.btn.active,.btn-group>.btn:active,.btn-group>.btn:focus{z-index:1}.btn-toolbar{-ms-flex-wrap:wrap;flex-wrap:wrap;justify-content:flex-start;display:-ms-flexbox;display:flex}.btn-toolbar .input-group{width:auto}.btn-group>.btn-group:not(:first-child),.btn-group>.btn:not(:first-child){margin-left:-1px}.btn-group>.btn-group:not(:last-child)>.btn,.btn-group>.btn:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn-group:not(:first-child)>.btn,.btn-group>.btn:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.dropdown-toggle-split{padding-left:.5625rem;padding-right:.5625rem}.dropdown-toggle-split:after,.dropright .dropdown-toggle-split:after,.dropup .dropdown-toggle-split:after{margin-left:0}.dropleft .dropdown-toggle-split:before{margin-right:0}.btn-group-sm>.btn+.dropdown-toggle-split,.btn-sm+.dropdown-toggle-split{padding-left:.375rem;padding-right:.375rem}.btn-group-lg>.btn+.dropdown-toggle-split,.btn-lg+.dropdown-toggle-split{padding-left:.75rem;padding-right:.75rem}.btn-group-vertical{-ms-flex-direction:column;flex-direction:column;justify-content:center;align-items:flex-start}.btn-group-vertical>.btn,.btn-group-vertical>.btn-group{width:100%}.btn-group-vertical>.btn-group:not(:first-child),.btn-group-vertical>.btn:not(:first-child){margin-top:-1px}.btn-group-vertical>.btn-group:not(:last-child)>.btn,.btn-group-vertical>.btn:not(:last-child):not(.dropdown-toggle){border-bottom-left-radius:0;border-bottom-right-radius:0}.btn-group-vertical>.btn-group:not(:first-child)>.btn,.btn-group-vertical>.btn:not(:first-child){border-top-left-radius:0;border-top-right-radius:0}.btn-group-toggle>.btn,.btn-group-toggle>.btn-group>.btn{margin-bottom:0}.btn-group-toggle>.btn input[type=checkbox],.btn-group-toggle>.btn input[type=radio],.btn-group-toggle>.btn-group>.btn input[type=checkbox],.btn-group-toggle>.btn-group>.btn input[type=radio]{clip:rect(0,0,0,0);pointer-events:none;position:absolute}.input-group{width:100%;-ms-flex-wrap:wrap;flex-wrap:wrap;align-items:stretch;display:-ms-flexbox;display:flex;position:relative}.input-group>.custom-file,.input-group>.custom-select,.input-group>.form-control,.input-group>.form-control-plaintext{width:1%;min-width:0;-ms-flex:auto;flex:auto;margin-bottom:0;position:relative}.input-group>.custom-file+.custom-file,.input-group>.custom-file+.custom-select,.input-group>.custom-file+.form-control,.input-group>.custom-select+.custom-file,.input-group>.custom-select+.custom-select,.input-group>.custom-select+.form-control,.input-group>.form-control+.custom-file,.input-group>.form-control+.custom-select,.input-group>.form-control+.form-control,.input-group>.form-control-plaintext+.custom-file,.input-group>.form-control-plaintext+.custom-select,.input-group>.form-control-plaintext+.form-control{margin-left:-1px}.input-group>.custom-file .custom-file-input:focus~.custom-file-label,.input-group>.custom-select:focus,.input-group>.form-control:focus{z-index:3}.input-group>.custom-file .custom-file-input:focus{z-index:4}.input-group>.custom-select:not(:first-child),.input-group>.form-control:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.input-group>.custom-file{align-items:center;display:-ms-flexbox;display:flex}.input-group>.custom-file:not(:last-child) .custom-file-label,.input-group>.custom-file:not(:last-child) .custom-file-label:after{border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.custom-file:not(:first-child) .custom-file-label{border-top-left-radius:0;border-bottom-left-radius:0}.input-group:not(.has-validation)>.custom-file:not(:last-child) .custom-file-label,.input-group:not(.has-validation)>.custom-file:not(:last-child) .custom-file-label:after,.input-group:not(.has-validation)>.custom-select:not(:last-child),.input-group:not(.has-validation)>.form-control:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.input-group.has-validation>.custom-file:nth-last-child(n+3) .custom-file-label,.input-group.has-validation>.custom-file:nth-last-child(n+3) .custom-file-label:after,.input-group.has-validation>.custom-select:nth-last-child(n+3),.input-group.has-validation>.form-control:nth-last-child(n+3){border-top-right-radius:0;border-bottom-right-radius:0}.input-group-append,.input-group-prepend{display:-ms-flexbox;display:flex}.input-group-append .btn,.input-group-prepend .btn{z-index:2;position:relative}.input-group-append .btn:focus,.input-group-prepend .btn:focus{z-index:3}.input-group-append .btn+.btn,.input-group-append .btn+.input-group-text,.input-group-append .input-group-text+.btn,.input-group-append .input-group-text+.input-group-text,.input-group-prepend .btn+.btn,.input-group-prepend .btn+.input-group-text,.input-group-prepend .input-group-text+.btn,.input-group-prepend .input-group-text+.input-group-text{margin-left:-1px}.input-group-prepend{margin-right:-1px}.input-group-append{margin-left:-1px}.input-group-text{color:#495057;text-align:center;white-space:nowrap;background-color:#e9ecef;border:1px solid #ced4da;border-radius:.25rem;align-items:center;margin-bottom:0;padding:.375rem .75rem;font-size:1rem;font-weight:400;line-height:1.5;display:-ms-flexbox;display:flex}.input-group-text input[type=checkbox],.input-group-text input[type=radio]{margin-top:0}.input-group-lg>.custom-select,.input-group-lg>.form-control:not(textarea){height:calc(1.5em + 1rem + 2px)}.input-group-lg>.custom-select,.input-group-lg>.form-control,.input-group-lg>.input-group-append>.btn,.input-group-lg>.input-group-append>.input-group-text,.input-group-lg>.input-group-prepend>.btn,.input-group-lg>.input-group-prepend>.input-group-text{border-radius:.3rem;padding:.5rem 1rem;font-size:1.25rem;line-height:1.5}.input-group-sm>.custom-select,.input-group-sm>.form-control:not(textarea){height:calc(1.5em + .5rem + 2px)}.input-group-sm>.custom-select,.input-group-sm>.form-control,.input-group-sm>.input-group-append>.btn,.input-group-sm>.input-group-append>.input-group-text,.input-group-sm>.input-group-prepend>.btn,.input-group-sm>.input-group-prepend>.input-group-text{border-radius:.2rem;padding:.25rem .5rem;font-size:.875rem;line-height:1.5}.input-group-lg>.custom-select,.input-group-sm>.custom-select{padding-right:1.75rem}.input-group.has-validation>.input-group-append:nth-last-child(n+3)>.btn,.input-group.has-validation>.input-group-append:nth-last-child(n+3)>.input-group-text,.input-group:not(.has-validation)>.input-group-append:not(:last-child)>.btn,.input-group:not(.has-validation)>.input-group-append:not(:last-child)>.input-group-text,.input-group>.input-group-append:last-child>.btn:not(:last-child):not(.dropdown-toggle),.input-group>.input-group-append:last-child>.input-group-text:not(:last-child),.input-group>.input-group-prepend>.btn,.input-group>.input-group-prepend>.input-group-text{border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.input-group-append>.btn,.input-group>.input-group-append>.input-group-text,.input-group>.input-group-prepend:first-child>.btn:not(:first-child),.input-group>.input-group-prepend:first-child>.input-group-text:not(:first-child),.input-group>.input-group-prepend:not(:first-child)>.btn,.input-group>.input-group-prepend:not(:first-child)>.input-group-text{border-top-left-radius:0;border-bottom-left-radius:0}.custom-control{z-index:1;min-height:1.5rem;-webkit-print-color-adjust:exact;color-adjust:exact;print-color-adjust:exact;padding-left:1.5rem;display:block;position:relative}.custom-control-inline{margin-right:1rem;display:-ms-inline-flexbox;display:inline-flex}.custom-control-input{z-index:-1;width:1rem;height:1.25rem;opacity:0;position:absolute;left:0}.custom-control-input:checked~.custom-control-label:before{color:#fff;background-color:#007bff;border-color:#007bff}.custom-control-input:focus~.custom-control-label:before{box-shadow:0 0 0 .2rem #007bff40}.custom-control-input:focus:not(:checked)~.custom-control-label:before{border-color:#80bdff}.custom-control-input:not(:disabled):active~.custom-control-label:before{color:#fff;background-color:#b3d7ff;border-color:#b3d7ff}.custom-control-input:disabled~.custom-control-label,.custom-control-input[disabled]~.custom-control-label{color:#6c757d}.custom-control-input:disabled~.custom-control-label:before,.custom-control-input[disabled]~.custom-control-label:before{background-color:#e9ecef}.custom-control-label{vertical-align:top;margin-bottom:0;position:relative}.custom-control-label:before{width:1rem;height:1rem;pointer-events:none;content:"";background-color:#fff;border:1px solid #adb5bd;display:block;position:absolute;top:.25rem;left:-1.5rem}.custom-control-label:after{width:1rem;height:1rem;content:"";background:50%/50% 50% no-repeat;display:block;position:absolute;top:.25rem;left:-1.5rem}.custom-checkbox .custom-control-label:before{border-radius:.25rem}.custom-checkbox .custom-control-input:checked~.custom-control-label:after{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8'%3e%3cpath fill='%23fff' d='M6.564.75l-3.59 3.612-1.538-1.55L0 4.26l2.974 2.99L8 2.193z'/%3e%3c/svg%3e")}.custom-checkbox .custom-control-input:indeterminate~.custom-control-label:before{background-color:#007bff;border-color:#007bff}.custom-checkbox .custom-control-input:indeterminate~.custom-control-label:after{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4' viewBox='0 0 4 4'%3e%3cpath stroke='%23fff' d='M0 2h4'/%3e%3c/svg%3e")}.custom-checkbox .custom-control-input:disabled:checked~.custom-control-label:before{background-color:#007bff80}.custom-checkbox .custom-control-input:disabled:indeterminate~.custom-control-label:before{background-color:#007bff80}.custom-radio .custom-control-label:before{border-radius:50%}.custom-radio .custom-control-input:checked~.custom-control-label:after{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e")}.custom-radio .custom-control-input:disabled:checked~.custom-control-label:before{background-color:#007bff80}.custom-switch{padding-left:2.25rem}.custom-switch .custom-control-label:before{width:1.75rem;pointer-events:all;border-radius:.5rem;left:-2.25rem}.custom-switch .custom-control-label:after{width:calc(1rem - 4px);height:calc(1rem - 4px);background-color:#adb5bd;border-radius:.5rem;transition:transform .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out,-webkit-transform .15s ease-in-out;top:calc(.25rem + 2px);left:calc(2px - 2.25rem)}@media (prefers-reduced-motion:reduce){.custom-switch .custom-control-label:after{transition:none}}.custom-switch .custom-control-input:checked~.custom-control-label:after{background-color:#fff;-webkit-transform:translate(.75rem);transform:translate(.75rem)}.custom-switch .custom-control-input:disabled:checked~.custom-control-label:before{background-color:#007bff80}.custom-select{width:100%;height:calc(1.5em + .75rem + 2px);color:#495057;vertical-align:middle;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#fff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='4' height='5' viewBox='0 0 4 5'%3e%3cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") right .75rem center/8px 10px no-repeat;border:1px solid #ced4da;border-radius:.25rem;padding:.375rem 1.75rem .375rem .75rem;font-size:1rem;font-weight:400;line-height:1.5;display:inline-block}.custom-select:focus{border-color:#80bdff;outline:0;box-shadow:0 0 0 .2rem #007bff40}.custom-select:focus::-ms-value{color:#495057;background-color:#fff}.custom-select[multiple],.custom-select[size]:not([size="1"]){height:auto;background-image:none;padding-right:.75rem}.custom-select:disabled{color:#6c757d;background-color:#e9ecef}.custom-select::-ms-expand{display:none}.custom-select:-moz-focusring{color:#0000;text-shadow:0 0 #495057}.custom-select-sm{height:calc(1.5em + .5rem + 2px);padding-top:.25rem;padding-bottom:.25rem;padding-left:.5rem;font-size:.875rem}.custom-select-lg{height:calc(1.5em + 1rem + 2px);padding-top:.5rem;padding-bottom:.5rem;padding-left:1rem;font-size:1.25rem}.custom-file{width:100%;height:calc(1.5em + .75rem + 2px);margin-bottom:0;display:inline-block;position:relative}.custom-file-input{z-index:2;width:100%;height:calc(1.5em + .75rem + 2px);opacity:0;margin:0;position:relative;overflow:hidden}.custom-file-input:focus~.custom-file-label{border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40}.custom-file-input:disabled~.custom-file-label,.custom-file-input[disabled]~.custom-file-label{background-color:#e9ecef}.custom-file-input:lang(en)~.custom-file-label:after{content:"Browse"}.custom-file-input~.custom-file-label[data-browse]:after{content:attr(data-browse)}.custom-file-label{z-index:1;height:calc(1.5em + .75rem + 2px);color:#495057;background-color:#fff;border:1px solid #ced4da;border-radius:.25rem;padding:.375rem .75rem;font-weight:400;line-height:1.5;position:absolute;top:0;left:0;right:0;overflow:hidden}.custom-file-label:after{z-index:3;height:calc(1.5em + .75rem);color:#495057;content:"Browse";border-left:inherit;background-color:#e9ecef;border-radius:0 .25rem .25rem 0;padding:.375rem .75rem;line-height:1.5;display:block;position:absolute;top:0;bottom:0;right:0}.custom-range{width:100%;height:1.4rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#0000;padding:0}.custom-range:focus{outline:0}.custom-range:focus::-webkit-slider-thumb{box-shadow:0 0 0 1px #fff,0 0 0 .2rem #007bff40}.custom-range:focus::-moz-range-thumb{box-shadow:0 0 0 1px #fff,0 0 0 .2rem #007bff40}.custom-range:focus::-ms-thumb{box-shadow:0 0 0 1px #fff,0 0 0 .2rem #007bff40}.custom-range::-moz-focus-outer{border:0}.custom-range::-webkit-slider-thumb{width:1rem;height:1rem;-webkit-appearance:none;appearance:none;background-color:#007bff;border:0;border-radius:1rem;margin-top:-.25rem;-webkit-transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media (prefers-reduced-motion:reduce){.custom-range::-webkit-slider-thumb{-webkit-transition:none;transition:none}}.custom-range::-webkit-slider-thumb:active{background-color:#b3d7ff}.custom-range::-webkit-slider-runnable-track{width:100%;height:.5rem;color:#0000;cursor:pointer;background-color:#dee2e6;border-color:#0000;border-radius:1rem}.custom-range::-moz-range-thumb{width:1rem;height:1rem;-moz-appearance:none;appearance:none;background-color:#007bff;border:0;border-radius:1rem;-moz-transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media (prefers-reduced-motion:reduce){.custom-range::-moz-range-thumb{-moz-transition:none;transition:none}}.custom-range::-moz-range-thumb:active{background-color:#b3d7ff}.custom-range::-moz-range-track{width:100%;height:.5rem;color:#0000;cursor:pointer;background-color:#dee2e6;border-color:#0000;border-radius:1rem}.custom-range::-ms-thumb{width:1rem;height:1rem;appearance:none;background-color:#007bff;border:0;border-radius:1rem;margin-top:0;margin-left:.2rem;margin-right:.2rem;-ms-transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media (prefers-reduced-motion:reduce){.custom-range::-ms-thumb{-ms-transition:none;transition:none}}.custom-range::-ms-thumb:active{background-color:#b3d7ff}.custom-range::-ms-track{width:100%;height:.5rem;color:#0000;cursor:pointer;background-color:#0000;border-width:.5rem;border-color:#0000}.custom-range::-ms-fill-lower{background-color:#dee2e6;border-radius:1rem}.custom-range::-ms-fill-upper{background-color:#dee2e6;border-radius:1rem;margin-right:15px}.custom-range:disabled::-webkit-slider-thumb{background-color:#adb5bd}.custom-range:disabled::-webkit-slider-runnable-track{cursor:default}.custom-range:disabled::-moz-range-thumb{background-color:#adb5bd}.custom-range:disabled::-moz-range-track{cursor:default}.custom-range:disabled::-ms-thumb{background-color:#adb5bd}.custom-control-label:before,.custom-file-label,.custom-select{transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media (prefers-reduced-motion:reduce){.custom-control-label:before,.custom-file-label,.custom-select{transition:none}}.nav{-ms-flex-wrap:wrap;flex-wrap:wrap;margin-bottom:0;padding-left:0;list-style:none;display:-ms-flexbox;display:flex}.nav-link{padding:.5rem 1rem;display:block}.nav-link:focus,.nav-link:hover{text-decoration:none}.nav-link.disabled{color:#6c757d;pointer-events:none;cursor:default}.nav-tabs{border-bottom:1px solid #dee2e6}.nav-tabs .nav-link{background-color:#0000;border:1px solid #0000;border-top-left-radius:.25rem;border-top-right-radius:.25rem;margin-bottom:-1px}.nav-tabs .nav-link:focus,.nav-tabs .nav-link:hover{isolation:isolate;border-color:#e9ecef #e9ecef #dee2e6}.nav-tabs .nav-link.disabled{color:#6c757d;background-color:#0000;border-color:#0000}.nav-tabs .nav-item.show .nav-link,.nav-tabs .nav-link.active{color:#495057;background-color:#fff;border-color:#dee2e6 #dee2e6 #fff}.nav-tabs .dropdown-menu{border-top-left-radius:0;border-top-right-radius:0;margin-top:-1px}.nav-pills .nav-link{background:0 0;border:0;border-radius:.25rem}.nav-pills .nav-link.active,.nav-pills .show>.nav-link{color:#fff;background-color:#007bff}.nav-fill .nav-item,.nav-fill>.nav-link{text-align:center;-ms-flex:auto;flex:auto}.nav-justified .nav-item,.nav-justified>.nav-link{text-align:center;-ms-flex-positive:1;-ms-flex-preferred-size:0;flex-grow:1;flex-basis:0}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.navbar{-ms-flex-wrap:wrap;flex-wrap:wrap;justify-content:space-between;align-items:center;padding:.5rem 1rem;display:-ms-flexbox;display:flex;position:relative}.navbar .container,.navbar .container-fluid,.navbar .container-lg,.navbar .container-md,.navbar .container-sm,.navbar .container-xl{-ms-flex-wrap:wrap;flex-wrap:wrap;justify-content:space-between;align-items:center;display:-ms-flexbox;display:flex}.navbar-brand{font-size:1.25rem;line-height:inherit;white-space:nowrap;margin-right:1rem;padding-top:.3125rem;padding-bottom:.3125rem;display:inline-block}.navbar-brand:focus,.navbar-brand:hover{text-decoration:none}.navbar-nav{-ms-flex-direction:column;flex-direction:column;margin-bottom:0;padding-left:0;list-style:none;display:-ms-flexbox;display:flex}.navbar-nav .nav-link{padding-left:0;padding-right:0}.navbar-nav .dropdown-menu{float:none;position:static}.navbar-text{padding-top:.5rem;padding-bottom:.5rem;display:inline-block}.navbar-collapse{-ms-flex-positive:1;-ms-flex-preferred-size:100%;flex-grow:1;flex-basis:100%;align-items:center}.navbar-toggler{background-color:#0000;border:1px solid #0000;border-radius:.25rem;padding:.25rem .75rem;font-size:1.25rem;line-height:1}.navbar-toggler:focus,.navbar-toggler:hover{text-decoration:none}.navbar-toggler-icon{width:1.5em;height:1.5em;vertical-align:middle;content:"";background:50%/100% 100% no-repeat;display:inline-block}.navbar-nav-scroll{max-height:75vh;overflow-y:auto}@media (max-width:575.98px){.navbar-expand-sm>.container,.navbar-expand-sm>.container-fluid,.navbar-expand-sm>.container-lg,.navbar-expand-sm>.container-md,.navbar-expand-sm>.container-sm,.navbar-expand-sm>.container-xl{padding-left:0;padding-right:0}}@media (min-width:576px){.navbar-expand-sm{-ms-flex-flow:row;flex-flow:row;justify-content:flex-start}.navbar-expand-sm .navbar-nav{-ms-flex-direction:row;flex-direction:row}.navbar-expand-sm .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-sm .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand-sm>.container,.navbar-expand-sm>.container-fluid,.navbar-expand-sm>.container-lg,.navbar-expand-sm>.container-md,.navbar-expand-sm>.container-sm,.navbar-expand-sm>.container-xl{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-sm .navbar-nav-scroll{overflow:visible}.navbar-expand-sm .navbar-collapse{-ms-flex-preferred-size:auto;flex-basis:auto;display:-ms-flexbox!important;display:flex!important}.navbar-expand-sm .navbar-toggler{display:none}}@media (max-width:767.98px){.navbar-expand-md>.container,.navbar-expand-md>.container-fluid,.navbar-expand-md>.container-lg,.navbar-expand-md>.container-md,.navbar-expand-md>.container-sm,.navbar-expand-md>.container-xl{padding-left:0;padding-right:0}}@media (min-width:768px){.navbar-expand-md{-ms-flex-flow:row;flex-flow:row;justify-content:flex-start}.navbar-expand-md .navbar-nav{-ms-flex-direction:row;flex-direction:row}.navbar-expand-md .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-md .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand-md>.container,.navbar-expand-md>.container-fluid,.navbar-expand-md>.container-lg,.navbar-expand-md>.container-md,.navbar-expand-md>.container-sm,.navbar-expand-md>.container-xl{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-md .navbar-nav-scroll{overflow:visible}.navbar-expand-md .navbar-collapse{-ms-flex-preferred-size:auto;flex-basis:auto;display:-ms-flexbox!important;display:flex!important}.navbar-expand-md .navbar-toggler{display:none}}@media (max-width:991.98px){.navbar-expand-lg>.container,.navbar-expand-lg>.container-fluid,.navbar-expand-lg>.container-lg,.navbar-expand-lg>.container-md,.navbar-expand-lg>.container-sm,.navbar-expand-lg>.container-xl{padding-left:0;padding-right:0}}@media (min-width:992px){.navbar-expand-lg{-ms-flex-flow:row;flex-flow:row;justify-content:flex-start}.navbar-expand-lg .navbar-nav{-ms-flex-direction:row;flex-direction:row}.navbar-expand-lg .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-lg .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand-lg>.container,.navbar-expand-lg>.container-fluid,.navbar-expand-lg>.container-lg,.navbar-expand-lg>.container-md,.navbar-expand-lg>.container-sm,.navbar-expand-lg>.container-xl{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-lg .navbar-nav-scroll{overflow:visible}.navbar-expand-lg .navbar-collapse{-ms-flex-preferred-size:auto;flex-basis:auto;display:-ms-flexbox!important;display:flex!important}.navbar-expand-lg .navbar-toggler{display:none}}@media (max-width:1199.98px){.navbar-expand-xl>.container,.navbar-expand-xl>.container-fluid,.navbar-expand-xl>.container-lg,.navbar-expand-xl>.container-md,.navbar-expand-xl>.container-sm,.navbar-expand-xl>.container-xl{padding-left:0;padding-right:0}}@media (min-width:1200px){.navbar-expand-xl{-ms-flex-flow:row;flex-flow:row;justify-content:flex-start}.navbar-expand-xl .navbar-nav{-ms-flex-direction:row;flex-direction:row}.navbar-expand-xl .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-xl .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand-xl>.container,.navbar-expand-xl>.container-fluid,.navbar-expand-xl>.container-lg,.navbar-expand-xl>.container-md,.navbar-expand-xl>.container-sm,.navbar-expand-xl>.container-xl{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-xl .navbar-nav-scroll{overflow:visible}.navbar-expand-xl .navbar-collapse{-ms-flex-preferred-size:auto;flex-basis:auto;display:-ms-flexbox!important;display:flex!important}.navbar-expand-xl .navbar-toggler{display:none}}.navbar-expand{-ms-flex-flow:row;flex-flow:row;justify-content:flex-start}.navbar-expand>.container,.navbar-expand>.container-fluid,.navbar-expand>.container-lg,.navbar-expand>.container-md,.navbar-expand>.container-sm,.navbar-expand>.container-xl{padding-left:0;padding-right:0}.navbar-expand .navbar-nav{-ms-flex-direction:row;flex-direction:row}.navbar-expand .navbar-nav .dropdown-menu{position:absolute}.navbar-expand .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand>.container,.navbar-expand>.container-fluid,.navbar-expand>.container-lg,.navbar-expand>.container-md,.navbar-expand>.container-sm,.navbar-expand>.container-xl{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand .navbar-nav-scroll{overflow:visible}.navbar-expand .navbar-collapse{-ms-flex-preferred-size:auto;flex-basis:auto;display:-ms-flexbox!important;display:flex!important}.navbar-expand .navbar-toggler{display:none}.navbar-light .navbar-brand{color:#000000e6}.navbar-light .navbar-brand:focus,.navbar-light .navbar-brand:hover{color:#000000e6}.navbar-light .navbar-nav .nav-link{color:#00000080}.navbar-light .navbar-nav .nav-link:focus,.navbar-light .navbar-nav .nav-link:hover{color:#000000b3}.navbar-light .navbar-nav .nav-link.disabled{color:#0000004d}.navbar-light .navbar-nav .active>.nav-link,.navbar-light .navbar-nav .nav-link.active,.navbar-light .navbar-nav .nav-link.show,.navbar-light .navbar-nav .show>.nav-link{color:#000000e6}.navbar-light .navbar-toggler{color:#00000080;border-color:#0000001a}.navbar-light .navbar-toggler-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%280, 0, 0, 0.5%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}.navbar-light .navbar-text{color:#00000080}.navbar-light .navbar-text a{color:#000000e6}.navbar-light .navbar-text a:focus,.navbar-light .navbar-text a:hover{color:#000000e6}.navbar-dark .navbar-brand{color:#fff}.navbar-dark .navbar-brand:focus,.navbar-dark .navbar-brand:hover{color:#fff}.navbar-dark .navbar-nav .nav-link{color:#ffffff80}.navbar-dark .navbar-nav .nav-link:focus,.navbar-dark .navbar-nav .nav-link:hover{color:#ffffffbf}.navbar-dark .navbar-nav .nav-link.disabled{color:#ffffff40}.navbar-dark .navbar-nav .active>.nav-link,.navbar-dark .navbar-nav .nav-link.active,.navbar-dark .navbar-nav .nav-link.show,.navbar-dark .navbar-nav .show>.nav-link{color:#fff}.navbar-dark .navbar-toggler{color:#ffffff80;border-color:#ffffff1a}.navbar-dark .navbar-toggler-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.5%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}.navbar-dark .navbar-text{color:#ffffff80}.navbar-dark .navbar-text a{color:#fff}.navbar-dark .navbar-text a:focus,.navbar-dark .navbar-text a:hover{color:#fff}.card{min-width:0;word-wrap:break-word;background-color:#fff;background-clip:border-box;border:1px solid #00000020;border-radius:.25rem;-ms-flex-direction:column;flex-direction:column;display:-ms-flexbox;display:flex;position:relative}.card>hr{margin-left:0;margin-right:0}.card>.list-group{border-top:inherit;border-bottom:inherit}.card>.list-group:first-child{border-top-width:0;border-top-left-radius:calc(.25rem - 1px);border-top-right-radius:calc(.25rem - 1px)}.card>.list-group:last-child{border-bottom-width:0;border-bottom-left-radius:calc(.25rem - 1px);border-bottom-right-radius:calc(.25rem - 1px)}.card>.card-header+.list-group,.card>.list-group+.card-footer{border-top:0}.card-body{min-height:1px;-ms-flex:auto;flex:auto;padding:1.25rem}.card-title{margin-bottom:.75rem}.card-subtitle{margin-top:-.375rem;margin-bottom:0}.card-text:last-child{margin-bottom:0}.card-link:hover{text-decoration:none}.card-link+.card-link{margin-left:1.25rem}.card-header{background-color:#00000008;border-bottom:1px solid #00000020;margin-bottom:0;padding:.75rem 1.25rem}.card-header:first-child{border-radius:calc(.25rem - 1px) calc(.25rem - 1px) 0 0}.card-footer{background-color:#00000008;border-top:1px solid #00000020;padding:.75rem 1.25rem}.card-footer:last-child{border-radius:0 0 calc(.25rem - 1px) calc(.25rem - 1px)}.card-header-tabs{border-bottom:0;margin-bottom:-.75rem;margin-left:-.625rem;margin-right:-.625rem}.card-header-pills{margin-left:-.625rem;margin-right:-.625rem}.card-img-overlay{border-radius:calc(.25rem - 1px);padding:1.25rem;position:absolute;inset:0}.card-img,.card-img-bottom,.card-img-top{width:100%;-ms-flex-negative:0;flex-shrink:0}.card-img,.card-img-top{border-top-left-radius:calc(.25rem - 1px);border-top-right-radius:calc(.25rem - 1px)}.card-img,.card-img-bottom{border-bottom-left-radius:calc(.25rem - 1px);border-bottom-right-radius:calc(.25rem - 1px)}.card-deck .card{margin-bottom:15px}@media (min-width:576px){.card-deck{-ms-flex-flow:wrap;flex-flow:wrap;margin-left:-15px;margin-right:-15px;display:-ms-flexbox;display:flex}.card-deck .card{-ms-flex:1 0;flex:1 0;margin-bottom:0;margin-left:15px;margin-right:15px}}.card-group>.card{margin-bottom:15px}@media (min-width:576px){.card-group{-ms-flex-flow:wrap;flex-flow:wrap;display:-ms-flexbox;display:flex}.card-group>.card{-ms-flex:1 0;flex:1 0;margin-bottom:0}.card-group>.card+.card{border-left:0;margin-left:0}.card-group>.card:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.card-group>.card:not(:last-child) .card-header,.card-group>.card:not(:last-child) .card-img-top{border-top-right-radius:0}.card-group>.card:not(:last-child) .card-footer,.card-group>.card:not(:last-child) .card-img-bottom{border-bottom-right-radius:0}.card-group>.card:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.card-group>.card:not(:first-child) .card-header,.card-group>.card:not(:first-child) .card-img-top{border-top-left-radius:0}.card-group>.card:not(:first-child) .card-footer,.card-group>.card:not(:first-child) .card-img-bottom{border-bottom-left-radius:0}}.card-columns .card{margin-bottom:.75rem}@media (min-width:576px){.card-columns{-webkit-column-count:3;-moz-column-count:3;column-count:3;-webkit-column-gap:1.25rem;-moz-column-gap:1.25rem;orphans:1;widows:1;column-gap:1.25rem}.card-columns .card{width:100%;display:inline-block}}.accordion{overflow-anchor:none}.accordion>.card{overflow:hidden}.accordion>.card:not(:last-of-type){border-bottom:0;border-bottom-left-radius:0;border-bottom-right-radius:0}.accordion>.card:not(:first-of-type){border-top-left-radius:0;border-top-right-radius:0}.accordion>.card>.card-header{border-radius:0;margin-bottom:-1px}.breadcrumb{background-color:#e9ecef;border-radius:.25rem;-ms-flex-wrap:wrap;flex-wrap:wrap;margin-bottom:1rem;padding:.75rem 1rem;list-style:none;display:-ms-flexbox;display:flex}.breadcrumb-item+.breadcrumb-item{padding-left:.5rem}.breadcrumb-item+.breadcrumb-item:before{float:left;color:#6c757d;content:"/";padding-right:.5rem}.breadcrumb-item+.breadcrumb-item:hover:before{text-decoration:underline}.breadcrumb-item+.breadcrumb-item:hover:before{text-decoration:none}.breadcrumb-item.active{color:#6c757d}.pagination{border-radius:.25rem;padding-left:0;list-style:none;display:-ms-flexbox;display:flex}.page-link{color:#007bff;background-color:#fff;border:1px solid #dee2e6;margin-left:-1px;padding:.5rem .75rem;line-height:1.25;display:block;position:relative}.page-link:hover{z-index:2;color:#0056b3;background-color:#e9ecef;border-color:#dee2e6;text-decoration:none}.page-link:focus{z-index:3;outline:0;box-shadow:0 0 0 .2rem #007bff40}.page-item:first-child .page-link{border-top-left-radius:.25rem;border-bottom-left-radius:.25rem;margin-left:0}.page-item:last-child .page-link{border-top-right-radius:.25rem;border-bottom-right-radius:.25rem}.page-item.active .page-link{z-index:3;color:#fff;background-color:#007bff;border-color:#007bff}.page-item.disabled .page-link{color:#6c757d;pointer-events:none;cursor:auto;background-color:#fff;border-color:#dee2e6}.pagination-lg .page-link{padding:.75rem 1.5rem;font-size:1.25rem;line-height:1.5}.pagination-lg .page-item:first-child .page-link{border-top-left-radius:.3rem;border-bottom-left-radius:.3rem}.pagination-lg .page-item:last-child .page-link{border-top-right-radius:.3rem;border-bottom-right-radius:.3rem}.pagination-sm .page-link{padding:.25rem .5rem;font-size:.875rem;line-height:1.5}.pagination-sm .page-item:first-child .page-link{border-top-left-radius:.2rem;border-bottom-left-radius:.2rem}.pagination-sm .page-item:last-child .page-link{border-top-right-radius:.2rem;border-bottom-right-radius:.2rem}.badge{text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:.25rem;padding:.25em .4em;font-size:75%;font-weight:700;line-height:1;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;display:inline-block}@media (prefers-reduced-motion:reduce){.badge{transition:none}}a.badge:focus,a.badge:hover{text-decoration:none}.badge:empty{display:none}.btn .badge{position:relative;top:-1px}.badge-pill{border-radius:10rem;padding-left:.6em;padding-right:.6em}.badge-primary{color:#fff;background-color:#007bff}a.badge-primary:focus,a.badge-primary:hover{color:#fff;background-color:#0062cc}a.badge-primary.focus,a.badge-primary:focus{outline:0;box-shadow:0 0 0 .2rem #007bff80}.badge-secondary{color:#fff;background-color:#6c757d}a.badge-secondary:focus,a.badge-secondary:hover{color:#fff;background-color:#545b62}a.badge-secondary.focus,a.badge-secondary:focus{outline:0;box-shadow:0 0 0 .2rem #6c757d80}.badge-success{color:#fff;background-color:#28a745}a.badge-success:focus,a.badge-success:hover{color:#fff;background-color:#1e7e34}a.badge-success.focus,a.badge-success:focus{outline:0;box-shadow:0 0 0 .2rem #28a74580}.badge-info{color:#fff;background-color:#17a2b8}a.badge-info:focus,a.badge-info:hover{color:#fff;background-color:#117a8b}a.badge-info.focus,a.badge-info:focus{outline:0;box-shadow:0 0 0 .2rem #17a2b880}.badge-warning{color:#212529;background-color:#ffc107}a.badge-warning:focus,a.badge-warning:hover{color:#212529;background-color:#d39e00}a.badge-warning.focus,a.badge-warning:focus{outline:0;box-shadow:0 0 0 .2rem #ffc10780}.badge-danger{color:#fff;background-color:#dc3545}a.badge-danger:focus,a.badge-danger:hover{color:#fff;background-color:#bd2130}a.badge-danger.focus,a.badge-danger:focus{outline:0;box-shadow:0 0 0 .2rem #dc354580}.badge-light{color:#212529;background-color:#f8f9fa}a.badge-light:focus,a.badge-light:hover{color:#212529;background-color:#dae0e5}a.badge-light.focus,a.badge-light:focus{outline:0;box-shadow:0 0 0 .2rem #f8f9fa80}.badge-dark{color:#fff;background-color:#343a40}a.badge-dark:focus,a.badge-dark:hover{color:#fff;background-color:#1d2124}a.badge-dark.focus,a.badge-dark:focus{outline:0;box-shadow:0 0 0 .2rem #343a4080}.jumbotron{background-color:#e9ecef;border-radius:.3rem;margin-bottom:2rem;padding:2rem 1rem}@media (min-width:576px){.jumbotron{padding:4rem 2rem}}.jumbotron-fluid{border-radius:0;padding-left:0;padding-right:0}.alert{border:1px solid #0000;border-radius:.25rem;margin-bottom:1rem;padding:.75rem 1.25rem;position:relative}.alert-heading{color:inherit}.alert-link{font-weight:700}.alert-dismissible{padding-right:4rem}.alert-dismissible .close{z-index:2;color:inherit;padding:.75rem 1.25rem;position:absolute;top:0;right:0}.alert-primary{color:#004085;background-color:#cce5ff;border-color:#b8daff}.alert-primary hr{border-top-color:#9fcdff}.alert-primary .alert-link{color:#002752}.alert-secondary{color:#383d41;background-color:#e2e3e5;border-color:#d6d8db}.alert-secondary hr{border-top-color:#c8cbcf}.alert-secondary .alert-link{color:#202326}.alert-success{color:#155724;background-color:#d4edda;border-color:#c3e6cb}.alert-success hr{border-top-color:#b1dfbb}.alert-success .alert-link{color:#0b2e13}.alert-info{color:#0c5460;background-color:#d1ecf1;border-color:#bee5eb}.alert-info hr{border-top-color:#abdde5}.alert-info .alert-link{color:#062c33}.alert-warning{color:#856404;background-color:#fff3cd;border-color:#ffeeba}.alert-warning hr{border-top-color:#ffe8a1}.alert-warning .alert-link{color:#533f03}.alert-danger{color:#721c24;background-color:#f8d7da;border-color:#f5c6cb}.alert-danger hr{border-top-color:#f1b0b7}.alert-danger .alert-link{color:#491217}.alert-light{color:#818182;background-color:#fefefe;border-color:#fdfdfe}.alert-light hr{border-top-color:#ececf6}.alert-light .alert-link{color:#686868}.alert-dark{color:#1b1e21;background-color:#d6d8d9;border-color:#c6c8ca}.alert-dark hr{border-top-color:#b9bbbe}.alert-dark .alert-link{color:#040505}@-webkit-keyframes progress-bar-stripes{0%{background-position:1rem 0}to{background-position:0 0}}@keyframes progress-bar-stripes{0%{background-position:1rem 0}to{background-position:0 0}}.progress{height:1rem;background-color:#e9ecef;border-radius:.25rem;font-size:.75rem;line-height:0;display:-ms-flexbox;display:flex;overflow:hidden}.progress-bar{color:#fff;text-align:center;white-space:nowrap;background-color:#007bff;-ms-flex-direction:column;flex-direction:column;justify-content:center;transition:width .6s;display:-ms-flexbox;display:flex;overflow:hidden}@media (prefers-reduced-motion:reduce){.progress-bar{transition:none}}.progress-bar-striped{background-image:linear-gradient(45deg,#ffffff26 25%,#0000 25% 50%,#ffffff26 50% 75%,#0000 75%,#0000);background-size:1rem 1rem}.progress-bar-animated{-webkit-animation:progress-bar-stripes 1s linear infinite;animation:progress-bar-stripes 1s linear infinite}@media (prefers-reduced-motion:reduce){.progress-bar-animated{-webkit-animation:none;animation:none}}.media{align-items:flex-start;display:-ms-flexbox;display:flex}.media-body{-ms-flex:1;flex:1}.list-group{border-radius:.25rem;-ms-flex-direction:column;flex-direction:column;margin-bottom:0;padding-left:0;display:-ms-flexbox;display:flex}.list-group-item-action{width:100%;color:#495057;text-align:inherit}.list-group-item-action:focus,.list-group-item-action:hover{z-index:1;color:#495057;background-color:#f8f9fa;text-decoration:none}.list-group-item-action:active{color:#212529;background-color:#e9ecef}.list-group-item{background-color:#fff;border:1px solid #00000020;padding:.75rem 1.25rem;display:block;position:relative}.list-group-item:first-child{border-top-left-radius:inherit;border-top-right-radius:inherit}.list-group-item:last-child{border-bottom-right-radius:inherit;border-bottom-left-radius:inherit}.list-group-item.disabled,.list-group-item:disabled{color:#6c757d;pointer-events:none;background-color:#fff}.list-group-item.active{z-index:2;color:#fff;background-color:#007bff;border-color:#007bff}.list-group-item+.list-group-item{border-top-width:0}.list-group-item+.list-group-item.active{border-top-width:1px;margin-top:-1px}.list-group-horizontal{-ms-flex-direction:row;flex-direction:row}.list-group-horizontal>.list-group-item:first-child{border-top-right-radius:0;border-bottom-left-radius:.25rem}.list-group-horizontal>.list-group-item:last-child{border-top-right-radius:.25rem;border-bottom-left-radius:0}.list-group-horizontal>.list-group-item.active{margin-top:0}.list-group-horizontal>.list-group-item+.list-group-item{border-top-width:1px;border-left-width:0}.list-group-horizontal>.list-group-item+.list-group-item.active{border-left-width:1px;margin-left:-1px}@media (min-width:576px){.list-group-horizontal-sm{-ms-flex-direction:row;flex-direction:row}.list-group-horizontal-sm>.list-group-item:first-child{border-top-right-radius:0;border-bottom-left-radius:.25rem}.list-group-horizontal-sm>.list-group-item:last-child{border-top-right-radius:.25rem;border-bottom-left-radius:0}.list-group-horizontal-sm>.list-group-item.active{margin-top:0}.list-group-horizontal-sm>.list-group-item+.list-group-item{border-top-width:1px;border-left-width:0}.list-group-horizontal-sm>.list-group-item+.list-group-item.active{border-left-width:1px;margin-left:-1px}}@media (min-width:768px){.list-group-horizontal-md{-ms-flex-direction:row;flex-direction:row}.list-group-horizontal-md>.list-group-item:first-child{border-top-right-radius:0;border-bottom-left-radius:.25rem}.list-group-horizontal-md>.list-group-item:last-child{border-top-right-radius:.25rem;border-bottom-left-radius:0}.list-group-horizontal-md>.list-group-item.active{margin-top:0}.list-group-horizontal-md>.list-group-item+.list-group-item{border-top-width:1px;border-left-width:0}.list-group-horizontal-md>.list-group-item+.list-group-item.active{border-left-width:1px;margin-left:-1px}}@media (min-width:992px){.list-group-horizontal-lg{-ms-flex-direction:row;flex-direction:row}.list-group-horizontal-lg>.list-group-item:first-child{border-top-right-radius:0;border-bottom-left-radius:.25rem}.list-group-horizontal-lg>.list-group-item:last-child{border-top-right-radius:.25rem;border-bottom-left-radius:0}.list-group-horizontal-lg>.list-group-item.active{margin-top:0}.list-group-horizontal-lg>.list-group-item+.list-group-item{border-top-width:1px;border-left-width:0}.list-group-horizontal-lg>.list-group-item+.list-group-item.active{border-left-width:1px;margin-left:-1px}}@media (min-width:1200px){.list-group-horizontal-xl{-ms-flex-direction:row;flex-direction:row}.list-group-horizontal-xl>.list-group-item:first-child{border-top-right-radius:0;border-bottom-left-radius:.25rem}.list-group-horizontal-xl>.list-group-item:last-child{border-top-right-radius:.25rem;border-bottom-left-radius:0}.list-group-horizontal-xl>.list-group-item.active{margin-top:0}.list-group-horizontal-xl>.list-group-item+.list-group-item{border-top-width:1px;border-left-width:0}.list-group-horizontal-xl>.list-group-item+.list-group-item.active{border-left-width:1px;margin-left:-1px}}.list-group-flush{border-radius:0}.list-group-flush>.list-group-item{border-width:0 0 1px}.list-group-flush>.list-group-item:last-child{border-bottom-width:0}.list-group-item-primary{color:#004085;background-color:#b8daff}.list-group-item-primary.list-group-item-action:focus,.list-group-item-primary.list-group-item-action:hover{color:#004085;background-color:#9fcdff}.list-group-item-primary.list-group-item-action.active{color:#fff;background-color:#004085;border-color:#004085}.list-group-item-secondary{color:#383d41;background-color:#d6d8db}.list-group-item-secondary.list-group-item-action:focus,.list-group-item-secondary.list-group-item-action:hover{color:#383d41;background-color:#c8cbcf}.list-group-item-secondary.list-group-item-action.active{color:#fff;background-color:#383d41;border-color:#383d41}.list-group-item-success{color:#155724;background-color:#c3e6cb}.list-group-item-success.list-group-item-action:focus,.list-group-item-success.list-group-item-action:hover{color:#155724;background-color:#b1dfbb}.list-group-item-success.list-group-item-action.active{color:#fff;background-color:#155724;border-color:#155724}.list-group-item-info{color:#0c5460;background-color:#bee5eb}.list-group-item-info.list-group-item-action:focus,.list-group-item-info.list-group-item-action:hover{color:#0c5460;background-color:#abdde5}.list-group-item-info.list-group-item-action.active{color:#fff;background-color:#0c5460;border-color:#0c5460}.list-group-item-warning{color:#856404;background-color:#ffeeba}.list-group-item-warning.list-group-item-action:focus,.list-group-item-warning.list-group-item-action:hover{color:#856404;background-color:#ffe8a1}.list-group-item-warning.list-group-item-action.active{color:#fff;background-color:#856404;border-color:#856404}.list-group-item-danger{color:#721c24;background-color:#f5c6cb}.list-group-item-danger.list-group-item-action:focus,.list-group-item-danger.list-group-item-action:hover{color:#721c24;background-color:#f1b0b7}.list-group-item-danger.list-group-item-action.active{color:#fff;background-color:#721c24;border-color:#721c24}.list-group-item-light{color:#818182;background-color:#fdfdfe}.list-group-item-light.list-group-item-action:focus,.list-group-item-light.list-group-item-action:hover{color:#818182;background-color:#ececf6}.list-group-item-light.list-group-item-action.active{color:#fff;background-color:#818182;border-color:#818182}.list-group-item-dark{color:#1b1e21;background-color:#c6c8ca}.list-group-item-dark.list-group-item-action:focus,.list-group-item-dark.list-group-item-action:hover{color:#1b1e21;background-color:#b9bbbe}.list-group-item-dark.list-group-item-action.active{color:#fff;background-color:#1b1e21;border-color:#1b1e21}.close{float:right;color:#000;text-shadow:0 1px #fff;opacity:.5;font-size:1.5rem;font-weight:700;line-height:1}.close:hover{color:#000;text-decoration:none}.close:not(:disabled):not(.disabled):focus,.close:not(:disabled):not(.disabled):hover{opacity:.75}button.close{background-color:#0000;border:0;padding:0}a.close.disabled{pointer-events:none}.toast{max-width:350px;opacity:0;background-color:#ffffffd9;background-clip:padding-box;border:1px solid #0000001a;border-radius:.25rem;-ms-flex-preferred-size:350px;flex-basis:350px;font-size:.875rem;box-shadow:0 .25rem .75rem #0000001a}.toast:not(:last-child){margin-bottom:.75rem}.toast.showing{opacity:1}.toast.show{opacity:1;display:block}.toast.hide{display:none}.toast-header{color:#6c757d;background-color:#ffffffd9;background-clip:padding-box;border-bottom:1px solid #0000000d;border-top-left-radius:calc(.25rem - 1px);border-top-right-radius:calc(.25rem - 1px);align-items:center;padding:.25rem .75rem;display:-ms-flexbox;display:flex}.toast-body{padding:.75rem}.modal-open{overflow:hidden}.modal-open .modal{overflow:hidden auto}.modal{z-index:1050;width:100%;height:100%;outline:0;display:none;position:fixed;top:0;left:0;overflow:hidden}.modal-dialog{width:auto;pointer-events:none;margin:.5rem;position:relative}.modal.fade .modal-dialog{transition:transform .3s ease-out,-webkit-transform .3s ease-out;-webkit-transform:translateY(-50px);transform:translateY(-50px)}@media (prefers-reduced-motion:reduce){.modal.fade .modal-dialog{transition:none}}.modal.show .modal-dialog{-webkit-transform:none;transform:none}.modal.modal-static .modal-dialog{-webkit-transform:scale(1.02);transform:scale(1.02)}.modal-dialog-scrollable{max-height:calc(100% - 1rem);display:-ms-flexbox;display:flex}.modal-dialog-scrollable .modal-content{max-height:calc(100vh - 1rem);overflow:hidden}.modal-dialog-scrollable .modal-footer,.modal-dialog-scrollable .modal-header{-ms-flex-negative:0;flex-shrink:0}.modal-dialog-scrollable .modal-body{overflow-y:auto}.modal-dialog-centered{min-height:calc(100% - 1rem);align-items:center;display:-ms-flexbox;display:flex}.modal-dialog-centered:before{height:calc(100vh - 1rem);height:-webkit-min-content;height:-moz-min-content;height:min-content;content:"";display:block}.modal-dialog-centered.modal-dialog-scrollable{height:100%;-ms-flex-direction:column;flex-direction:column;justify-content:center}.modal-dialog-centered.modal-dialog-scrollable .modal-content{max-height:none}.modal-dialog-centered.modal-dialog-scrollable:before{content:none}.modal-content{width:100%;pointer-events:auto;background-color:#fff;background-clip:padding-box;border:1px solid #0003;border-radius:.3rem;outline:0;-ms-flex-direction:column;flex-direction:column;display:-ms-flexbox;display:flex;position:relative}.modal-backdrop{z-index:1040;width:100vw;height:100vh;background-color:#000;position:fixed;top:0;left:0}.modal-backdrop.fade{opacity:0}.modal-backdrop.show{opacity:.5}.modal-header{border-bottom:1px solid #dee2e6;border-top-left-radius:calc(.3rem - 1px);border-top-right-radius:calc(.3rem - 1px);justify-content:space-between;align-items:flex-start;padding:1rem;display:-ms-flexbox;display:flex}.modal-header .close{margin:-1rem -1rem -1rem auto;padding:1rem}.modal-title{margin-bottom:0;line-height:1.5}.modal-body{-ms-flex:auto;flex:auto;padding:1rem;position:relative}.modal-footer{border-top:1px solid #dee2e6;border-bottom-left-radius:calc(.3rem - 1px);border-bottom-right-radius:calc(.3rem - 1px);-ms-flex-wrap:wrap;flex-wrap:wrap;justify-content:flex-end;align-items:center;padding:.75rem;display:-ms-flexbox;display:flex}.modal-footer>*{margin:.25rem}.modal-scrollbar-measure{width:50px;height:50px;position:absolute;top:-9999px;overflow:scroll}@media (min-width:576px){.modal-dialog{max-width:500px;margin:1.75rem auto}.modal-dialog-scrollable{max-height:calc(100% - 3.5rem)}.modal-dialog-scrollable .modal-content{max-height:calc(100vh - 3.5rem)}.modal-dialog-centered{min-height:calc(100% - 3.5rem)}.modal-dialog-centered:before{height:calc(100vh - 3.5rem);height:-webkit-min-content;height:-moz-min-content;height:min-content}.modal-sm{max-width:300px}}@media (min-width:992px){.modal-lg,.modal-xl{max-width:800px}}@media (min-width:1200px){.modal-xl{max-width:1140px}}.tooltip{z-index:1070;text-align:left;text-align:start;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;white-space:normal;word-spacing:normal;line-break:auto;word-wrap:break-word;opacity:0;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,Liberation Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-size:.875rem;font-style:normal;font-weight:400;line-height:1.5;text-decoration:none;display:block;position:absolute}.tooltip.show{opacity:.9}.tooltip .arrow{width:.8rem;height:.4rem;display:block;position:absolute}.tooltip .arrow:before{content:"";border-style:solid;border-color:#0000;position:absolute}.bs-tooltip-auto[x-placement^=top],.bs-tooltip-top{padding:.4rem 0}.bs-tooltip-auto[x-placement^=top] .arrow,.bs-tooltip-top .arrow{bottom:0}.bs-tooltip-auto[x-placement^=top] .arrow:before,.bs-tooltip-top .arrow:before{border-width:.4rem .4rem 0;border-top-color:#000;top:0}.bs-tooltip-auto[x-placement^=right],.bs-tooltip-right{padding:0 .4rem}.bs-tooltip-auto[x-placement^=right] .arrow,.bs-tooltip-right .arrow{width:.4rem;height:.8rem;left:0}.bs-tooltip-auto[x-placement^=right] .arrow:before,.bs-tooltip-right .arrow:before{border-width:.4rem .4rem .4rem 0;border-right-color:#000;right:0}.bs-tooltip-auto[x-placement^=bottom],.bs-tooltip-bottom{padding:.4rem 0}.bs-tooltip-auto[x-placement^=bottom] .arrow,.bs-tooltip-bottom .arrow{top:0}.bs-tooltip-auto[x-placement^=bottom] .arrow:before,.bs-tooltip-bottom .arrow:before{border-width:0 .4rem .4rem;border-bottom-color:#000;bottom:0}.bs-tooltip-auto[x-placement^=left],.bs-tooltip-left{padding:0 .4rem}.bs-tooltip-auto[x-placement^=left] .arrow,.bs-tooltip-left .arrow{width:.4rem;height:.8rem;right:0}.bs-tooltip-auto[x-placement^=left] .arrow:before,.bs-tooltip-left .arrow:before{border-width:.4rem 0 .4rem .4rem;border-left-color:#000;left:0}.tooltip-inner{max-width:200px;color:#fff;text-align:center;background-color:#000;border-radius:.25rem;padding:.25rem .5rem}.popover{z-index:1060;max-width:276px;text-align:left;text-align:start;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;white-space:normal;word-spacing:normal;line-break:auto;word-wrap:break-word;background-color:#fff;background-clip:padding-box;border:1px solid #0003;border-radius:.3rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,Liberation Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-size:.875rem;font-style:normal;font-weight:400;line-height:1.5;text-decoration:none;display:block;position:absolute;top:0;left:0}.popover .arrow{width:1rem;height:.5rem;margin:0 .3rem;display:block;position:absolute}.popover .arrow:after,.popover .arrow:before{content:"";border-style:solid;border-color:#0000;display:block;position:absolute}.bs-popover-auto[x-placement^=top],.bs-popover-top{margin-bottom:.5rem}.bs-popover-auto[x-placement^=top]>.arrow,.bs-popover-top>.arrow{bottom:calc(-.5rem - 1px)}.bs-popover-auto[x-placement^=top]>.arrow:before,.bs-popover-top>.arrow:before{border-width:.5rem .5rem 0;border-top-color:#00000040;bottom:0}.bs-popover-auto[x-placement^=top]>.arrow:after,.bs-popover-top>.arrow:after{border-width:.5rem .5rem 0;border-top-color:#fff;bottom:1px}.bs-popover-auto[x-placement^=right],.bs-popover-right{margin-left:.5rem}.bs-popover-auto[x-placement^=right]>.arrow,.bs-popover-right>.arrow{width:.5rem;height:1rem;margin:.3rem 0;left:calc(-.5rem - 1px)}.bs-popover-auto[x-placement^=right]>.arrow:before,.bs-popover-right>.arrow:before{border-width:.5rem .5rem .5rem 0;border-right-color:#00000040;left:0}.bs-popover-auto[x-placement^=right]>.arrow:after,.bs-popover-right>.arrow:after{border-width:.5rem .5rem .5rem 0;border-right-color:#fff;left:1px}.bs-popover-auto[x-placement^=bottom],.bs-popover-bottom{margin-top:.5rem}.bs-popover-auto[x-placement^=bottom]>.arrow,.bs-popover-bottom>.arrow{top:calc(-.5rem - 1px)}.bs-popover-auto[x-placement^=bottom]>.arrow:before,.bs-popover-bottom>.arrow:before{border-width:0 .5rem .5rem;border-bottom-color:#00000040;top:0}.bs-popover-auto[x-placement^=bottom]>.arrow:after,.bs-popover-bottom>.arrow:after{border-width:0 .5rem .5rem;border-bottom-color:#fff;top:1px}.bs-popover-auto[x-placement^=bottom] .popover-header:before,.bs-popover-bottom .popover-header:before{width:1rem;content:"";border-bottom:1px solid #f7f7f7;margin-left:-.5rem;display:block;position:absolute;top:0;left:50%}.bs-popover-auto[x-placement^=left],.bs-popover-left{margin-right:.5rem}.bs-popover-auto[x-placement^=left]>.arrow,.bs-popover-left>.arrow{width:.5rem;height:1rem;margin:.3rem 0;right:calc(-.5rem - 1px)}.bs-popover-auto[x-placement^=left]>.arrow:before,.bs-popover-left>.arrow:before{border-width:.5rem 0 .5rem .5rem;border-left-color:#00000040;right:0}.bs-popover-auto[x-placement^=left]>.arrow:after,.bs-popover-left>.arrow:after{border-width:.5rem 0 .5rem .5rem;border-left-color:#fff;right:1px}.popover-header{background-color:#f7f7f7;border-bottom:1px solid #ebebeb;border-top-left-radius:calc(.3rem - 1px);border-top-right-radius:calc(.3rem - 1px);margin-bottom:0;padding:.5rem .75rem;font-size:1rem}.popover-header:empty{display:none}.popover-body{color:#212529;padding:.5rem .75rem}.carousel{position:relative}.carousel.pointer-event{-ms-touch-action:pan-y;touch-action:pan-y}.carousel-inner{width:100%;position:relative;overflow:hidden}.carousel-inner:after{clear:both;content:"";display:block}.carousel-item{float:left;width:100%;-webkit-backface-visibility:hidden;backface-visibility:hidden;margin-right:-100%;transition:transform .6s ease-in-out,-webkit-transform .6s ease-in-out;display:none;position:relative}@media (prefers-reduced-motion:reduce){.carousel-item{transition:none}}.carousel-item-next,.carousel-item-prev,.carousel-item.active{display:block}.active.carousel-item-right,.carousel-item-next:not(.carousel-item-left){-webkit-transform:translate(100%);transform:translate(100%)}.active.carousel-item-left,.carousel-item-prev:not(.carousel-item-right){-webkit-transform:translate(-100%);transform:translate(-100%)}.carousel-fade .carousel-item{opacity:0;transition-property:opacity;-webkit-transform:none;transform:none}.carousel-fade .carousel-item-next.carousel-item-left,.carousel-fade .carousel-item-prev.carousel-item-right,.carousel-fade .carousel-item.active{z-index:1;opacity:1}.carousel-fade .active.carousel-item-left,.carousel-fade .active.carousel-item-right{z-index:0;opacity:0;transition:opacity 0s .6s}@media (prefers-reduced-motion:reduce){.carousel-fade .active.carousel-item-left,.carousel-fade .active.carousel-item-right{transition:none}}.carousel-control-next,.carousel-control-prev{z-index:1;width:15%;color:#fff;text-align:center;opacity:.5;background:0 0;border:0;justify-content:center;align-items:center;padding:0;transition:opacity .15s;display:-ms-flexbox;display:flex;position:absolute;top:0;bottom:0}@media (prefers-reduced-motion:reduce){.carousel-control-next,.carousel-control-prev{transition:none}}.carousel-control-next:focus,.carousel-control-next:hover,.carousel-control-prev:focus,.carousel-control-prev:hover{color:#fff;opacity:.9;outline:0;text-decoration:none}.carousel-control-prev{left:0}.carousel-control-next{right:0}.carousel-control-next-icon,.carousel-control-prev-icon{width:20px;height:20px;background:50%/100% 100% no-repeat;display:inline-block}.carousel-control-prev-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' width='8' height='8' viewBox='0 0 8 8'%3e%3cpath d='M5.25 0l-4 4 4 4 1.5-1.5L4.25 4l2.5-2.5L5.25 0z'/%3e%3c/svg%3e")}.carousel-control-next-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' width='8' height='8' viewBox='0 0 8 8'%3e%3cpath d='M2.75 0l-1.5 1.5L3.75 4l-2.5 2.5L2.75 8l4-4-4-4z'/%3e%3c/svg%3e")}.carousel-indicators{z-index:15;justify-content:center;margin-left:15%;margin-right:15%;padding-left:0;list-style:none;display:-ms-flexbox;display:flex;position:absolute;bottom:0;left:0;right:0}.carousel-indicators li{box-sizing:content-box;width:30px;height:3px;text-indent:-999px;cursor:pointer;opacity:.5;background-color:#fff;background-clip:padding-box;border-top:10px solid #0000;border-bottom:10px solid #0000;-ms-flex:0 auto;flex:0 auto;margin-left:3px;margin-right:3px;transition:opacity .6s}@media (prefers-reduced-motion:reduce){.carousel-indicators li{transition:none}}.carousel-indicators .active{opacity:1}.carousel-caption{z-index:10;color:#fff;text-align:center;padding-top:20px;padding-bottom:20px;position:absolute;bottom:20px;left:15%;right:15%}@-webkit-keyframes spinner-border{to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes spinner-border{to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}.spinner-border{width:2rem;height:2rem;vertical-align:-.125em;border:.25em solid;border-right-color:#0000;border-radius:50%;-webkit-animation:spinner-border .75s linear infinite;animation:spinner-border .75s linear infinite;display:inline-block}.spinner-border-sm{width:1rem;height:1rem;border-width:.2em}@-webkit-keyframes spinner-grow{0%{-webkit-transform:scale(0);transform:scale(0)}50%{opacity:1;-webkit-transform:none;transform:none}}@keyframes spinner-grow{0%{-webkit-transform:scale(0);transform:scale(0)}50%{opacity:1;-webkit-transform:none;transform:none}}.spinner-grow{width:2rem;height:2rem;vertical-align:-.125em;opacity:0;background-color:currentColor;border-radius:50%;-webkit-animation:spinner-grow .75s linear infinite;animation:spinner-grow .75s linear infinite;display:inline-block}.spinner-grow-sm{width:1rem;height:1rem}@media (prefers-reduced-motion:reduce){.spinner-border,.spinner-grow{-webkit-animation-duration:1.5s;animation-duration:1.5s}}.align-baseline{vertical-align:baseline!important}.align-top{vertical-align:top!important}.align-middle{vertical-align:middle!important}.align-bottom{vertical-align:bottom!important}.align-text-bottom{vertical-align:text-bottom!important}.align-text-top{vertical-align:text-top!important}.bg-primary{background-color:#007bff!important}a.bg-primary:focus,a.bg-primary:hover,button.bg-primary:focus,button.bg-primary:hover{background-color:#0062cc!important}.bg-secondary{background-color:#6c757d!important}a.bg-secondary:focus,a.bg-secondary:hover,button.bg-secondary:focus,button.bg-secondary:hover{background-color:#545b62!important}.bg-success{background-color:#28a745!important}a.bg-success:focus,a.bg-success:hover,button.bg-success:focus,button.bg-success:hover{background-color:#1e7e34!important}.bg-info{background-color:#17a2b8!important}a.bg-info:focus,a.bg-info:hover,button.bg-info:focus,button.bg-info:hover{background-color:#117a8b!important}.bg-warning{background-color:#ffc107!important}a.bg-warning:focus,a.bg-warning:hover,button.bg-warning:focus,button.bg-warning:hover{background-color:#d39e00!important}.bg-danger{background-color:#dc3545!important}a.bg-danger:focus,a.bg-danger:hover,button.bg-danger:focus,button.bg-danger:hover{background-color:#bd2130!important}.bg-light{background-color:#f8f9fa!important}a.bg-light:focus,a.bg-light:hover,button.bg-light:focus,button.bg-light:hover{background-color:#dae0e5!important}.bg-dark{background-color:#343a40!important}a.bg-dark:focus,a.bg-dark:hover,button.bg-dark:focus,button.bg-dark:hover{background-color:#1d2124!important}.bg-white{background-color:#fff!important}.bg-transparent{background-color:#0000!important}.border{border:1px solid #dee2e6!important}.border-top{border-top:1px solid #dee2e6!important}.border-right{border-right:1px solid #dee2e6!important}.border-bottom{border-bottom:1px solid #dee2e6!important}.border-left{border-left:1px solid #dee2e6!important}.border-0{border:0!important}.border-top-0{border-top:0!important}.border-right-0{border-right:0!important}.border-bottom-0{border-bottom:0!important}.border-left-0{border-left:0!important}.border-primary{border-color:#007bff!important}.border-secondary{border-color:#6c757d!important}.border-success{border-color:#28a745!important}.border-info{border-color:#17a2b8!important}.border-warning{border-color:#ffc107!important}.border-danger{border-color:#dc3545!important}.border-light{border-color:#f8f9fa!important}.border-dark{border-color:#343a40!important}.border-white{border-color:#fff!important}.rounded-sm{border-radius:.2rem!important}.rounded{border-radius:.25rem!important}.rounded-top{border-top-left-radius:.25rem!important;border-top-right-radius:.25rem!important}.rounded-right{border-top-right-radius:.25rem!important;border-bottom-right-radius:.25rem!important}.rounded-bottom{border-bottom-left-radius:.25rem!important;border-bottom-right-radius:.25rem!important}.rounded-left{border-top-left-radius:.25rem!important;border-bottom-left-radius:.25rem!important}.rounded-lg{border-radius:.3rem!important}.rounded-circle{border-radius:50%!important}.rounded-pill{border-radius:50rem!important}.rounded-0{border-radius:0!important}.clearfix:after{clear:both;content:"";display:block}.d-none{display:none!important}.d-inline{display:inline!important}.d-inline-block{display:inline-block!important}.d-block{display:block!important}.d-table{display:table!important}.d-table-row{display:table-row!important}.d-table-cell{display:table-cell!important}.d-flex{display:-ms-flexbox!important;display:flex!important}.d-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}@media (min-width:576px){.d-sm-none{display:none!important}.d-sm-inline{display:inline!important}.d-sm-inline-block{display:inline-block!important}.d-sm-block{display:block!important}.d-sm-table{display:table!important}.d-sm-table-row{display:table-row!important}.d-sm-table-cell{display:table-cell!important}.d-sm-flex{display:-ms-flexbox!important;display:flex!important}.d-sm-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}}@media (min-width:768px){.d-md-none{display:none!important}.d-md-inline{display:inline!important}.d-md-inline-block{display:inline-block!important}.d-md-block{display:block!important}.d-md-table{display:table!important}.d-md-table-row{display:table-row!important}.d-md-table-cell{display:table-cell!important}.d-md-flex{display:-ms-flexbox!important;display:flex!important}.d-md-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}}@media (min-width:992px){.d-lg-none{display:none!important}.d-lg-inline{display:inline!important}.d-lg-inline-block{display:inline-block!important}.d-lg-block{display:block!important}.d-lg-table{display:table!important}.d-lg-table-row{display:table-row!important}.d-lg-table-cell{display:table-cell!important}.d-lg-flex{display:-ms-flexbox!important;display:flex!important}.d-lg-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}}@media (min-width:1200px){.d-xl-none{display:none!important}.d-xl-inline{display:inline!important}.d-xl-inline-block{display:inline-block!important}.d-xl-block{display:block!important}.d-xl-table{display:table!important}.d-xl-table-row{display:table-row!important}.d-xl-table-cell{display:table-cell!important}.d-xl-flex{display:-ms-flexbox!important;display:flex!important}.d-xl-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}}@media print{.d-print-none{display:none!important}.d-print-inline{display:inline!important}.d-print-inline-block{display:inline-block!important}.d-print-block{display:block!important}.d-print-table{display:table!important}.d-print-table-row{display:table-row!important}.d-print-table-cell{display:table-cell!important}.d-print-flex{display:-ms-flexbox!important;display:flex!important}.d-print-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}}.embed-responsive{width:100%;padding:0;display:block;position:relative;overflow:hidden}.embed-responsive:before{content:"";display:block}.embed-responsive .embed-responsive-item,.embed-responsive embed,.embed-responsive iframe,.embed-responsive object,.embed-responsive video{width:100%;height:100%;border:0;position:absolute;top:0;bottom:0;left:0}.embed-responsive-21by9:before{padding-top:42.8571%}.embed-responsive-16by9:before{padding-top:56.25%}.embed-responsive-4by3:before{padding-top:75%}.embed-responsive-1by1:before{padding-top:100%}.flex-row{-ms-flex-direction:row!important;flex-direction:row!important}.flex-column{-ms-flex-direction:column!important;flex-direction:column!important}.flex-row-reverse{-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-column-reverse{-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.flex-fill{-ms-flex:auto!important;flex:auto!important}.flex-grow-0{-ms-flex-positive:0!important;flex-grow:0!important}.flex-grow-1{-ms-flex-positive:1!important;flex-grow:1!important}.flex-shrink-0{-ms-flex-negative:0!important;flex-shrink:0!important}.flex-shrink-1{-ms-flex-negative:1!important;flex-shrink:1!important}.justify-content-start{justify-content:flex-start!important}.justify-content-end{justify-content:flex-end!important}.justify-content-center{justify-content:center!important}.justify-content-between{justify-content:space-between!important}.justify-content-around{justify-content:space-around!important}.align-items-start{align-items:flex-start!important}.align-items-end{align-items:flex-end!important}.align-items-center{align-items:center!important}.align-items-baseline{align-items:baseline!important}.align-items-stretch{align-items:stretch!important}.align-content-start{align-content:flex-start!important}.align-content-end{align-content:flex-end!important}.align-content-center{align-content:center!important}.align-content-between{align-content:space-between!important}.align-content-around{align-content:space-around!important}.align-content-stretch{align-content:stretch!important}.align-self-auto{align-self:auto!important}.align-self-start{align-self:flex-start!important}.align-self-end{align-self:flex-end!important}.align-self-center{align-self:center!important}.align-self-baseline{align-self:baseline!important}.align-self-stretch{align-self:stretch!important}@media (min-width:576px){.flex-sm-row{-ms-flex-direction:row!important;flex-direction:row!important}.flex-sm-column{-ms-flex-direction:column!important;flex-direction:column!important}.flex-sm-row-reverse{-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-sm-column-reverse{-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-sm-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-sm-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-sm-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.flex-sm-fill{-ms-flex:auto!important;flex:auto!important}.flex-sm-grow-0{-ms-flex-positive:0!important;flex-grow:0!important}.flex-sm-grow-1{-ms-flex-positive:1!important;flex-grow:1!important}.flex-sm-shrink-0{-ms-flex-negative:0!important;flex-shrink:0!important}.flex-sm-shrink-1{-ms-flex-negative:1!important;flex-shrink:1!important}.justify-content-sm-start{justify-content:flex-start!important}.justify-content-sm-end{justify-content:flex-end!important}.justify-content-sm-center{justify-content:center!important}.justify-content-sm-between{justify-content:space-between!important}.justify-content-sm-around{justify-content:space-around!important}.align-items-sm-start{align-items:flex-start!important}.align-items-sm-end{align-items:flex-end!important}.align-items-sm-center{align-items:center!important}.align-items-sm-baseline{align-items:baseline!important}.align-items-sm-stretch{align-items:stretch!important}.align-content-sm-start{align-content:flex-start!important}.align-content-sm-end{align-content:flex-end!important}.align-content-sm-center{align-content:center!important}.align-content-sm-between{align-content:space-between!important}.align-content-sm-around{align-content:space-around!important}.align-content-sm-stretch{align-content:stretch!important}.align-self-sm-auto{align-self:auto!important}.align-self-sm-start{align-self:flex-start!important}.align-self-sm-end{align-self:flex-end!important}.align-self-sm-center{align-self:center!important}.align-self-sm-baseline{align-self:baseline!important}.align-self-sm-stretch{align-self:stretch!important}}@media (min-width:768px){.flex-md-row{-ms-flex-direction:row!important;flex-direction:row!important}.flex-md-column{-ms-flex-direction:column!important;flex-direction:column!important}.flex-md-row-reverse{-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-md-column-reverse{-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-md-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-md-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-md-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.flex-md-fill{-ms-flex:auto!important;flex:auto!important}.flex-md-grow-0{-ms-flex-positive:0!important;flex-grow:0!important}.flex-md-grow-1{-ms-flex-positive:1!important;flex-grow:1!important}.flex-md-shrink-0{-ms-flex-negative:0!important;flex-shrink:0!important}.flex-md-shrink-1{-ms-flex-negative:1!important;flex-shrink:1!important}.justify-content-md-start{justify-content:flex-start!important}.justify-content-md-end{justify-content:flex-end!important}.justify-content-md-center{justify-content:center!important}.justify-content-md-between{justify-content:space-between!important}.justify-content-md-around{justify-content:space-around!important}.align-items-md-start{align-items:flex-start!important}.align-items-md-end{align-items:flex-end!important}.align-items-md-center{align-items:center!important}.align-items-md-baseline{align-items:baseline!important}.align-items-md-stretch{align-items:stretch!important}.align-content-md-start{align-content:flex-start!important}.align-content-md-end{align-content:flex-end!important}.align-content-md-center{align-content:center!important}.align-content-md-between{align-content:space-between!important}.align-content-md-around{align-content:space-around!important}.align-content-md-stretch{align-content:stretch!important}.align-self-md-auto{align-self:auto!important}.align-self-md-start{align-self:flex-start!important}.align-self-md-end{align-self:flex-end!important}.align-self-md-center{align-self:center!important}.align-self-md-baseline{align-self:baseline!important}.align-self-md-stretch{align-self:stretch!important}}@media (min-width:992px){.flex-lg-row{-ms-flex-direction:row!important;flex-direction:row!important}.flex-lg-column{-ms-flex-direction:column!important;flex-direction:column!important}.flex-lg-row-reverse{-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-lg-column-reverse{-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-lg-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-lg-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-lg-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.flex-lg-fill{-ms-flex:auto!important;flex:auto!important}.flex-lg-grow-0{-ms-flex-positive:0!important;flex-grow:0!important}.flex-lg-grow-1{-ms-flex-positive:1!important;flex-grow:1!important}.flex-lg-shrink-0{-ms-flex-negative:0!important;flex-shrink:0!important}.flex-lg-shrink-1{-ms-flex-negative:1!important;flex-shrink:1!important}.justify-content-lg-start{justify-content:flex-start!important}.justify-content-lg-end{justify-content:flex-end!important}.justify-content-lg-center{justify-content:center!important}.justify-content-lg-between{justify-content:space-between!important}.justify-content-lg-around{justify-content:space-around!important}.align-items-lg-start{align-items:flex-start!important}.align-items-lg-end{align-items:flex-end!important}.align-items-lg-center{align-items:center!important}.align-items-lg-baseline{align-items:baseline!important}.align-items-lg-stretch{align-items:stretch!important}.align-content-lg-start{align-content:flex-start!important}.align-content-lg-end{align-content:flex-end!important}.align-content-lg-center{align-content:center!important}.align-content-lg-between{align-content:space-between!important}.align-content-lg-around{align-content:space-around!important}.align-content-lg-stretch{align-content:stretch!important}.align-self-lg-auto{align-self:auto!important}.align-self-lg-start{align-self:flex-start!important}.align-self-lg-end{align-self:flex-end!important}.align-self-lg-center{align-self:center!important}.align-self-lg-baseline{align-self:baseline!important}.align-self-lg-stretch{align-self:stretch!important}}@media (min-width:1200px){.flex-xl-row{-ms-flex-direction:row!important;flex-direction:row!important}.flex-xl-column{-ms-flex-direction:column!important;flex-direction:column!important}.flex-xl-row-reverse{-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-xl-column-reverse{-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-xl-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-xl-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-xl-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.flex-xl-fill{-ms-flex:auto!important;flex:auto!important}.flex-xl-grow-0{-ms-flex-positive:0!important;flex-grow:0!important}.flex-xl-grow-1{-ms-flex-positive:1!important;flex-grow:1!important}.flex-xl-shrink-0{-ms-flex-negative:0!important;flex-shrink:0!important}.flex-xl-shrink-1{-ms-flex-negative:1!important;flex-shrink:1!important}.justify-content-xl-start{justify-content:flex-start!important}.justify-content-xl-end{justify-content:flex-end!important}.justify-content-xl-center{justify-content:center!important}.justify-content-xl-between{justify-content:space-between!important}.justify-content-xl-around{justify-content:space-around!important}.align-items-xl-start{align-items:flex-start!important}.align-items-xl-end{align-items:flex-end!important}.align-items-xl-center{align-items:center!important}.align-items-xl-baseline{align-items:baseline!important}.align-items-xl-stretch{align-items:stretch!important}.align-content-xl-start{align-content:flex-start!important}.align-content-xl-end{align-content:flex-end!important}.align-content-xl-center{align-content:center!important}.align-content-xl-between{align-content:space-between!important}.align-content-xl-around{align-content:space-around!important}.align-content-xl-stretch{align-content:stretch!important}.align-self-xl-auto{align-self:auto!important}.align-self-xl-start{align-self:flex-start!important}.align-self-xl-end{align-self:flex-end!important}.align-self-xl-center{align-self:center!important}.align-self-xl-baseline{align-self:baseline!important}.align-self-xl-stretch{align-self:stretch!important}}.float-left{float:left!important}.float-right{float:right!important}.float-none{float:none!important}@media (min-width:576px){.float-sm-left{float:left!important}.float-sm-right{float:right!important}.float-sm-none{float:none!important}}@media (min-width:768px){.float-md-left{float:left!important}.float-md-right{float:right!important}.float-md-none{float:none!important}}@media (min-width:992px){.float-lg-left{float:left!important}.float-lg-right{float:right!important}.float-lg-none{float:none!important}}@media (min-width:1200px){.float-xl-left{float:left!important}.float-xl-right{float:right!important}.float-xl-none{float:none!important}}.user-select-all{-webkit-user-select:all!important;-moz-user-select:all!important;user-select:all!important}.user-select-auto{-webkit-user-select:auto!important;-moz-user-select:auto!important;-ms-user-select:auto!important;user-select:auto!important}.user-select-none{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.overflow-auto{overflow:auto!important}.overflow-hidden{overflow:hidden!important}.position-static{position:static!important}.position-relative{position:relative!important}.position-absolute{position:absolute!important}.position-fixed{position:fixed!important}.position-sticky{position:-webkit-sticky!important;position:sticky!important}.fixed-top{z-index:1030;position:fixed;top:0;left:0;right:0}.fixed-bottom{z-index:1030;position:fixed;bottom:0;left:0;right:0}@supports ((position:-webkit-sticky) or (position:sticky)){.sticky-top{z-index:1020;position:-webkit-sticky;position:sticky;top:0}}.sr-only{width:1px;height:1px;clip:rect(0,0,0,0);white-space:nowrap;border:0;margin:-1px;padding:0;position:absolute;overflow:hidden}.sr-only-focusable:active,.sr-only-focusable:focus{width:auto;height:auto;clip:auto;white-space:normal;position:static;overflow:visible}.shadow-sm{box-shadow:0 .125rem .25rem #00000013!important}.shadow{box-shadow:0 .5rem 1rem #00000026!important}.shadow-lg{box-shadow:0 1rem 3rem #0000002d!important}.shadow-none{box-shadow:none!important}.w-25{width:25%!important}.w-50{width:50%!important}.w-75{width:75%!important}.w-100{width:100%!important}.w-auto{width:auto!important}.h-25{height:25%!important}.h-50{height:50%!important}.h-75{height:75%!important}.h-100{height:100%!important}.h-auto{height:auto!important}.mw-100{max-width:100%!important}.mh-100{max-height:100%!important}.min-vw-100{min-width:100vw!important}.min-vh-100{min-height:100vh!important}.vw-100{width:100vw!important}.vh-100{height:100vh!important}.m-0{margin:0!important}.mt-0,.my-0{margin-top:0!important}.mr-0,.mx-0{margin-right:0!important}.mb-0,.my-0{margin-bottom:0!important}.ml-0,.mx-0{margin-left:0!important}.m-1{margin:.25rem!important}.mt-1,.my-1{margin-top:.25rem!important}.mr-1,.mx-1{margin-right:.25rem!important}.mb-1,.my-1{margin-bottom:.25rem!important}.ml-1,.mx-1{margin-left:.25rem!important}.m-2{margin:.5rem!important}.mt-2,.my-2{margin-top:.5rem!important}.mr-2,.mx-2{margin-right:.5rem!important}.mb-2,.my-2{margin-bottom:.5rem!important}.ml-2,.mx-2{margin-left:.5rem!important}.m-3{margin:1rem!important}.mt-3,.my-3{margin-top:1rem!important}.mr-3,.mx-3{margin-right:1rem!important}.mb-3,.my-3{margin-bottom:1rem!important}.ml-3,.mx-3{margin-left:1rem!important}.m-4{margin:1.5rem!important}.mt-4,.my-4{margin-top:1.5rem!important}.mr-4,.mx-4{margin-right:1.5rem!important}.mb-4,.my-4{margin-bottom:1.5rem!important}.ml-4,.mx-4{margin-left:1.5rem!important}.m-5{margin:3rem!important}.mt-5,.my-5{margin-top:3rem!important}.mr-5,.mx-5{margin-right:3rem!important}.mb-5,.my-5{margin-bottom:3rem!important}.ml-5,.mx-5{margin-left:3rem!important}.p-0{padding:0!important}.pt-0,.py-0{padding-top:0!important}.pr-0,.px-0{padding-right:0!important}.pb-0,.py-0{padding-bottom:0!important}.pl-0,.px-0{padding-left:0!important}.p-1{padding:.25rem!important}.pt-1,.py-1{padding-top:.25rem!important}.pr-1,.px-1{padding-right:.25rem!important}.pb-1,.py-1{padding-bottom:.25rem!important}.pl-1,.px-1{padding-left:.25rem!important}.p-2{padding:.5rem!important}.pt-2,.py-2{padding-top:.5rem!important}.pr-2,.px-2{padding-right:.5rem!important}.pb-2,.py-2{padding-bottom:.5rem!important}.pl-2,.px-2{padding-left:.5rem!important}.p-3{padding:1rem!important}.pt-3,.py-3{padding-top:1rem!important}.pr-3,.px-3{padding-right:1rem!important}.pb-3,.py-3{padding-bottom:1rem!important}.pl-3,.px-3{padding-left:1rem!important}.p-4{padding:1.5rem!important}.pt-4,.py-4{padding-top:1.5rem!important}.pr-4,.px-4{padding-right:1.5rem!important}.pb-4,.py-4{padding-bottom:1.5rem!important}.pl-4,.px-4{padding-left:1.5rem!important}.p-5{padding:3rem!important}.pt-5,.py-5{padding-top:3rem!important}.pr-5,.px-5{padding-right:3rem!important}.pb-5,.py-5{padding-bottom:3rem!important}.pl-5,.px-5{padding-left:3rem!important}.m-n1{margin:-.25rem!important}.mt-n1,.my-n1{margin-top:-.25rem!important}.mr-n1,.mx-n1{margin-right:-.25rem!important}.mb-n1,.my-n1{margin-bottom:-.25rem!important}.ml-n1,.mx-n1{margin-left:-.25rem!important}.m-n2{margin:-.5rem!important}.mt-n2,.my-n2{margin-top:-.5rem!important}.mr-n2,.mx-n2{margin-right:-.5rem!important}.mb-n2,.my-n2{margin-bottom:-.5rem!important}.ml-n2,.mx-n2{margin-left:-.5rem!important}.m-n3{margin:-1rem!important}.mt-n3,.my-n3{margin-top:-1rem!important}.mr-n3,.mx-n3{margin-right:-1rem!important}.mb-n3,.my-n3{margin-bottom:-1rem!important}.ml-n3,.mx-n3{margin-left:-1rem!important}.m-n4{margin:-1.5rem!important}.mt-n4,.my-n4{margin-top:-1.5rem!important}.mr-n4,.mx-n4{margin-right:-1.5rem!important}.mb-n4,.my-n4{margin-bottom:-1.5rem!important}.ml-n4,.mx-n4{margin-left:-1.5rem!important}.m-n5{margin:-3rem!important}.mt-n5,.my-n5{margin-top:-3rem!important}.mr-n5,.mx-n5{margin-right:-3rem!important}.mb-n5,.my-n5{margin-bottom:-3rem!important}.ml-n5,.mx-n5{margin-left:-3rem!important}.m-auto{margin:auto!important}.mt-auto,.my-auto{margin-top:auto!important}.mr-auto,.mx-auto{margin-right:auto!important}.mb-auto,.my-auto{margin-bottom:auto!important}.ml-auto,.mx-auto{margin-left:auto!important}@media (min-width:576px){.m-sm-0{margin:0!important}.mt-sm-0,.my-sm-0{margin-top:0!important}.mr-sm-0,.mx-sm-0{margin-right:0!important}.mb-sm-0,.my-sm-0{margin-bottom:0!important}.ml-sm-0,.mx-sm-0{margin-left:0!important}.m-sm-1{margin:.25rem!important}.mt-sm-1,.my-sm-1{margin-top:.25rem!important}.mr-sm-1,.mx-sm-1{margin-right:.25rem!important}.mb-sm-1,.my-sm-1{margin-bottom:.25rem!important}.ml-sm-1,.mx-sm-1{margin-left:.25rem!important}.m-sm-2{margin:.5rem!important}.mt-sm-2,.my-sm-2{margin-top:.5rem!important}.mr-sm-2,.mx-sm-2{margin-right:.5rem!important}.mb-sm-2,.my-sm-2{margin-bottom:.5rem!important}.ml-sm-2,.mx-sm-2{margin-left:.5rem!important}.m-sm-3{margin:1rem!important}.mt-sm-3,.my-sm-3{margin-top:1rem!important}.mr-sm-3,.mx-sm-3{margin-right:1rem!important}.mb-sm-3,.my-sm-3{margin-bottom:1rem!important}.ml-sm-3,.mx-sm-3{margin-left:1rem!important}.m-sm-4{margin:1.5rem!important}.mt-sm-4,.my-sm-4{margin-top:1.5rem!important}.mr-sm-4,.mx-sm-4{margin-right:1.5rem!important}.mb-sm-4,.my-sm-4{margin-bottom:1.5rem!important}.ml-sm-4,.mx-sm-4{margin-left:1.5rem!important}.m-sm-5{margin:3rem!important}.mt-sm-5,.my-sm-5{margin-top:3rem!important}.mr-sm-5,.mx-sm-5{margin-right:3rem!important}.mb-sm-5,.my-sm-5{margin-bottom:3rem!important}.ml-sm-5,.mx-sm-5{margin-left:3rem!important}.p-sm-0{padding:0!important}.pt-sm-0,.py-sm-0{padding-top:0!important}.pr-sm-0,.px-sm-0{padding-right:0!important}.pb-sm-0,.py-sm-0{padding-bottom:0!important}.pl-sm-0,.px-sm-0{padding-left:0!important}.p-sm-1{padding:.25rem!important}.pt-sm-1,.py-sm-1{padding-top:.25rem!important}.pr-sm-1,.px-sm-1{padding-right:.25rem!important}.pb-sm-1,.py-sm-1{padding-bottom:.25rem!important}.pl-sm-1,.px-sm-1{padding-left:.25rem!important}.p-sm-2{padding:.5rem!important}.pt-sm-2,.py-sm-2{padding-top:.5rem!important}.pr-sm-2,.px-sm-2{padding-right:.5rem!important}.pb-sm-2,.py-sm-2{padding-bottom:.5rem!important}.pl-sm-2,.px-sm-2{padding-left:.5rem!important}.p-sm-3{padding:1rem!important}.pt-sm-3,.py-sm-3{padding-top:1rem!important}.pr-sm-3,.px-sm-3{padding-right:1rem!important}.pb-sm-3,.py-sm-3{padding-bottom:1rem!important}.pl-sm-3,.px-sm-3{padding-left:1rem!important}.p-sm-4{padding:1.5rem!important}.pt-sm-4,.py-sm-4{padding-top:1.5rem!important}.pr-sm-4,.px-sm-4{padding-right:1.5rem!important}.pb-sm-4,.py-sm-4{padding-bottom:1.5rem!important}.pl-sm-4,.px-sm-4{padding-left:1.5rem!important}.p-sm-5{padding:3rem!important}.pt-sm-5,.py-sm-5{padding-top:3rem!important}.pr-sm-5,.px-sm-5{padding-right:3rem!important}.pb-sm-5,.py-sm-5{padding-bottom:3rem!important}.pl-sm-5,.px-sm-5{padding-left:3rem!important}.m-sm-n1{margin:-.25rem!important}.mt-sm-n1,.my-sm-n1{margin-top:-.25rem!important}.mr-sm-n1,.mx-sm-n1{margin-right:-.25rem!important}.mb-sm-n1,.my-sm-n1{margin-bottom:-.25rem!important}.ml-sm-n1,.mx-sm-n1{margin-left:-.25rem!important}.m-sm-n2{margin:-.5rem!important}.mt-sm-n2,.my-sm-n2{margin-top:-.5rem!important}.mr-sm-n2,.mx-sm-n2{margin-right:-.5rem!important}.mb-sm-n2,.my-sm-n2{margin-bottom:-.5rem!important}.ml-sm-n2,.mx-sm-n2{margin-left:-.5rem!important}.m-sm-n3{margin:-1rem!important}.mt-sm-n3,.my-sm-n3{margin-top:-1rem!important}.mr-sm-n3,.mx-sm-n3{margin-right:-1rem!important}.mb-sm-n3,.my-sm-n3{margin-bottom:-1rem!important}.ml-sm-n3,.mx-sm-n3{margin-left:-1rem!important}.m-sm-n4{margin:-1.5rem!important}.mt-sm-n4,.my-sm-n4{margin-top:-1.5rem!important}.mr-sm-n4,.mx-sm-n4{margin-right:-1.5rem!important}.mb-sm-n4,.my-sm-n4{margin-bottom:-1.5rem!important}.ml-sm-n4,.mx-sm-n4{margin-left:-1.5rem!important}.m-sm-n5{margin:-3rem!important}.mt-sm-n5,.my-sm-n5{margin-top:-3rem!important}.mr-sm-n5,.mx-sm-n5{margin-right:-3rem!important}.mb-sm-n5,.my-sm-n5{margin-bottom:-3rem!important}.ml-sm-n5,.mx-sm-n5{margin-left:-3rem!important}.m-sm-auto{margin:auto!important}.mt-sm-auto,.my-sm-auto{margin-top:auto!important}.mr-sm-auto,.mx-sm-auto{margin-right:auto!important}.mb-sm-auto,.my-sm-auto{margin-bottom:auto!important}.ml-sm-auto,.mx-sm-auto{margin-left:auto!important}}@media (min-width:768px){.m-md-0{margin:0!important}.mt-md-0,.my-md-0{margin-top:0!important}.mr-md-0,.mx-md-0{margin-right:0!important}.mb-md-0,.my-md-0{margin-bottom:0!important}.ml-md-0,.mx-md-0{margin-left:0!important}.m-md-1{margin:.25rem!important}.mt-md-1,.my-md-1{margin-top:.25rem!important}.mr-md-1,.mx-md-1{margin-right:.25rem!important}.mb-md-1,.my-md-1{margin-bottom:.25rem!important}.ml-md-1,.mx-md-1{margin-left:.25rem!important}.m-md-2{margin:.5rem!important}.mt-md-2,.my-md-2{margin-top:.5rem!important}.mr-md-2,.mx-md-2{margin-right:.5rem!important}.mb-md-2,.my-md-2{margin-bottom:.5rem!important}.ml-md-2,.mx-md-2{margin-left:.5rem!important}.m-md-3{margin:1rem!important}.mt-md-3,.my-md-3{margin-top:1rem!important}.mr-md-3,.mx-md-3{margin-right:1rem!important}.mb-md-3,.my-md-3{margin-bottom:1rem!important}.ml-md-3,.mx-md-3{margin-left:1rem!important}.m-md-4{margin:1.5rem!important}.mt-md-4,.my-md-4{margin-top:1.5rem!important}.mr-md-4,.mx-md-4{margin-right:1.5rem!important}.mb-md-4,.my-md-4{margin-bottom:1.5rem!important}.ml-md-4,.mx-md-4{margin-left:1.5rem!important}.m-md-5{margin:3rem!important}.mt-md-5,.my-md-5{margin-top:3rem!important}.mr-md-5,.mx-md-5{margin-right:3rem!important}.mb-md-5,.my-md-5{margin-bottom:3rem!important}.ml-md-5,.mx-md-5{margin-left:3rem!important}.p-md-0{padding:0!important}.pt-md-0,.py-md-0{padding-top:0!important}.pr-md-0,.px-md-0{padding-right:0!important}.pb-md-0,.py-md-0{padding-bottom:0!important}.pl-md-0,.px-md-0{padding-left:0!important}.p-md-1{padding:.25rem!important}.pt-md-1,.py-md-1{padding-top:.25rem!important}.pr-md-1,.px-md-1{padding-right:.25rem!important}.pb-md-1,.py-md-1{padding-bottom:.25rem!important}.pl-md-1,.px-md-1{padding-left:.25rem!important}.p-md-2{padding:.5rem!important}.pt-md-2,.py-md-2{padding-top:.5rem!important}.pr-md-2,.px-md-2{padding-right:.5rem!important}.pb-md-2,.py-md-2{padding-bottom:.5rem!important}.pl-md-2,.px-md-2{padding-left:.5rem!important}.p-md-3{padding:1rem!important}.pt-md-3,.py-md-3{padding-top:1rem!important}.pr-md-3,.px-md-3{padding-right:1rem!important}.pb-md-3,.py-md-3{padding-bottom:1rem!important}.pl-md-3,.px-md-3{padding-left:1rem!important}.p-md-4{padding:1.5rem!important}.pt-md-4,.py-md-4{padding-top:1.5rem!important}.pr-md-4,.px-md-4{padding-right:1.5rem!important}.pb-md-4,.py-md-4{padding-bottom:1.5rem!important}.pl-md-4,.px-md-4{padding-left:1.5rem!important}.p-md-5{padding:3rem!important}.pt-md-5,.py-md-5{padding-top:3rem!important}.pr-md-5,.px-md-5{padding-right:3rem!important}.pb-md-5,.py-md-5{padding-bottom:3rem!important}.pl-md-5,.px-md-5{padding-left:3rem!important}.m-md-n1{margin:-.25rem!important}.mt-md-n1,.my-md-n1{margin-top:-.25rem!important}.mr-md-n1,.mx-md-n1{margin-right:-.25rem!important}.mb-md-n1,.my-md-n1{margin-bottom:-.25rem!important}.ml-md-n1,.mx-md-n1{margin-left:-.25rem!important}.m-md-n2{margin:-.5rem!important}.mt-md-n2,.my-md-n2{margin-top:-.5rem!important}.mr-md-n2,.mx-md-n2{margin-right:-.5rem!important}.mb-md-n2,.my-md-n2{margin-bottom:-.5rem!important}.ml-md-n2,.mx-md-n2{margin-left:-.5rem!important}.m-md-n3{margin:-1rem!important}.mt-md-n3,.my-md-n3{margin-top:-1rem!important}.mr-md-n3,.mx-md-n3{margin-right:-1rem!important}.mb-md-n3,.my-md-n3{margin-bottom:-1rem!important}.ml-md-n3,.mx-md-n3{margin-left:-1rem!important}.m-md-n4{margin:-1.5rem!important}.mt-md-n4,.my-md-n4{margin-top:-1.5rem!important}.mr-md-n4,.mx-md-n4{margin-right:-1.5rem!important}.mb-md-n4,.my-md-n4{margin-bottom:-1.5rem!important}.ml-md-n4,.mx-md-n4{margin-left:-1.5rem!important}.m-md-n5{margin:-3rem!important}.mt-md-n5,.my-md-n5{margin-top:-3rem!important}.mr-md-n5,.mx-md-n5{margin-right:-3rem!important}.mb-md-n5,.my-md-n5{margin-bottom:-3rem!important}.ml-md-n5,.mx-md-n5{margin-left:-3rem!important}.m-md-auto{margin:auto!important}.mt-md-auto,.my-md-auto{margin-top:auto!important}.mr-md-auto,.mx-md-auto{margin-right:auto!important}.mb-md-auto,.my-md-auto{margin-bottom:auto!important}.ml-md-auto,.mx-md-auto{margin-left:auto!important}}@media (min-width:992px){.m-lg-0{margin:0!important}.mt-lg-0,.my-lg-0{margin-top:0!important}.mr-lg-0,.mx-lg-0{margin-right:0!important}.mb-lg-0,.my-lg-0{margin-bottom:0!important}.ml-lg-0,.mx-lg-0{margin-left:0!important}.m-lg-1{margin:.25rem!important}.mt-lg-1,.my-lg-1{margin-top:.25rem!important}.mr-lg-1,.mx-lg-1{margin-right:.25rem!important}.mb-lg-1,.my-lg-1{margin-bottom:.25rem!important}.ml-lg-1,.mx-lg-1{margin-left:.25rem!important}.m-lg-2{margin:.5rem!important}.mt-lg-2,.my-lg-2{margin-top:.5rem!important}.mr-lg-2,.mx-lg-2{margin-right:.5rem!important}.mb-lg-2,.my-lg-2{margin-bottom:.5rem!important}.ml-lg-2,.mx-lg-2{margin-left:.5rem!important}.m-lg-3{margin:1rem!important}.mt-lg-3,.my-lg-3{margin-top:1rem!important}.mr-lg-3,.mx-lg-3{margin-right:1rem!important}.mb-lg-3,.my-lg-3{margin-bottom:1rem!important}.ml-lg-3,.mx-lg-3{margin-left:1rem!important}.m-lg-4{margin:1.5rem!important}.mt-lg-4,.my-lg-4{margin-top:1.5rem!important}.mr-lg-4,.mx-lg-4{margin-right:1.5rem!important}.mb-lg-4,.my-lg-4{margin-bottom:1.5rem!important}.ml-lg-4,.mx-lg-4{margin-left:1.5rem!important}.m-lg-5{margin:3rem!important}.mt-lg-5,.my-lg-5{margin-top:3rem!important}.mr-lg-5,.mx-lg-5{margin-right:3rem!important}.mb-lg-5,.my-lg-5{margin-bottom:3rem!important}.ml-lg-5,.mx-lg-5{margin-left:3rem!important}.p-lg-0{padding:0!important}.pt-lg-0,.py-lg-0{padding-top:0!important}.pr-lg-0,.px-lg-0{padding-right:0!important}.pb-lg-0,.py-lg-0{padding-bottom:0!important}.pl-lg-0,.px-lg-0{padding-left:0!important}.p-lg-1{padding:.25rem!important}.pt-lg-1,.py-lg-1{padding-top:.25rem!important}.pr-lg-1,.px-lg-1{padding-right:.25rem!important}.pb-lg-1,.py-lg-1{padding-bottom:.25rem!important}.pl-lg-1,.px-lg-1{padding-left:.25rem!important}.p-lg-2{padding:.5rem!important}.pt-lg-2,.py-lg-2{padding-top:.5rem!important}.pr-lg-2,.px-lg-2{padding-right:.5rem!important}.pb-lg-2,.py-lg-2{padding-bottom:.5rem!important}.pl-lg-2,.px-lg-2{padding-left:.5rem!important}.p-lg-3{padding:1rem!important}.pt-lg-3,.py-lg-3{padding-top:1rem!important}.pr-lg-3,.px-lg-3{padding-right:1rem!important}.pb-lg-3,.py-lg-3{padding-bottom:1rem!important}.pl-lg-3,.px-lg-3{padding-left:1rem!important}.p-lg-4{padding:1.5rem!important}.pt-lg-4,.py-lg-4{padding-top:1.5rem!important}.pr-lg-4,.px-lg-4{padding-right:1.5rem!important}.pb-lg-4,.py-lg-4{padding-bottom:1.5rem!important}.pl-lg-4,.px-lg-4{padding-left:1.5rem!important}.p-lg-5{padding:3rem!important}.pt-lg-5,.py-lg-5{padding-top:3rem!important}.pr-lg-5,.px-lg-5{padding-right:3rem!important}.pb-lg-5,.py-lg-5{padding-bottom:3rem!important}.pl-lg-5,.px-lg-5{padding-left:3rem!important}.m-lg-n1{margin:-.25rem!important}.mt-lg-n1,.my-lg-n1{margin-top:-.25rem!important}.mr-lg-n1,.mx-lg-n1{margin-right:-.25rem!important}.mb-lg-n1,.my-lg-n1{margin-bottom:-.25rem!important}.ml-lg-n1,.mx-lg-n1{margin-left:-.25rem!important}.m-lg-n2{margin:-.5rem!important}.mt-lg-n2,.my-lg-n2{margin-top:-.5rem!important}.mr-lg-n2,.mx-lg-n2{margin-right:-.5rem!important}.mb-lg-n2,.my-lg-n2{margin-bottom:-.5rem!important}.ml-lg-n2,.mx-lg-n2{margin-left:-.5rem!important}.m-lg-n3{margin:-1rem!important}.mt-lg-n3,.my-lg-n3{margin-top:-1rem!important}.mr-lg-n3,.mx-lg-n3{margin-right:-1rem!important}.mb-lg-n3,.my-lg-n3{margin-bottom:-1rem!important}.ml-lg-n3,.mx-lg-n3{margin-left:-1rem!important}.m-lg-n4{margin:-1.5rem!important}.mt-lg-n4,.my-lg-n4{margin-top:-1.5rem!important}.mr-lg-n4,.mx-lg-n4{margin-right:-1.5rem!important}.mb-lg-n4,.my-lg-n4{margin-bottom:-1.5rem!important}.ml-lg-n4,.mx-lg-n4{margin-left:-1.5rem!important}.m-lg-n5{margin:-3rem!important}.mt-lg-n5,.my-lg-n5{margin-top:-3rem!important}.mr-lg-n5,.mx-lg-n5{margin-right:-3rem!important}.mb-lg-n5,.my-lg-n5{margin-bottom:-3rem!important}.ml-lg-n5,.mx-lg-n5{margin-left:-3rem!important}.m-lg-auto{margin:auto!important}.mt-lg-auto,.my-lg-auto{margin-top:auto!important}.mr-lg-auto,.mx-lg-auto{margin-right:auto!important}.mb-lg-auto,.my-lg-auto{margin-bottom:auto!important}.ml-lg-auto,.mx-lg-auto{margin-left:auto!important}}@media (min-width:1200px){.m-xl-0{margin:0!important}.mt-xl-0,.my-xl-0{margin-top:0!important}.mr-xl-0,.mx-xl-0{margin-right:0!important}.mb-xl-0,.my-xl-0{margin-bottom:0!important}.ml-xl-0,.mx-xl-0{margin-left:0!important}.m-xl-1{margin:.25rem!important}.mt-xl-1,.my-xl-1{margin-top:.25rem!important}.mr-xl-1,.mx-xl-1{margin-right:.25rem!important}.mb-xl-1,.my-xl-1{margin-bottom:.25rem!important}.ml-xl-1,.mx-xl-1{margin-left:.25rem!important}.m-xl-2{margin:.5rem!important}.mt-xl-2,.my-xl-2{margin-top:.5rem!important}.mr-xl-2,.mx-xl-2{margin-right:.5rem!important}.mb-xl-2,.my-xl-2{margin-bottom:.5rem!important}.ml-xl-2,.mx-xl-2{margin-left:.5rem!important}.m-xl-3{margin:1rem!important}.mt-xl-3,.my-xl-3{margin-top:1rem!important}.mr-xl-3,.mx-xl-3{margin-right:1rem!important}.mb-xl-3,.my-xl-3{margin-bottom:1rem!important}.ml-xl-3,.mx-xl-3{margin-left:1rem!important}.m-xl-4{margin:1.5rem!important}.mt-xl-4,.my-xl-4{margin-top:1.5rem!important}.mr-xl-4,.mx-xl-4{margin-right:1.5rem!important}.mb-xl-4,.my-xl-4{margin-bottom:1.5rem!important}.ml-xl-4,.mx-xl-4{margin-left:1.5rem!important}.m-xl-5{margin:3rem!important}.mt-xl-5,.my-xl-5{margin-top:3rem!important}.mr-xl-5,.mx-xl-5{margin-right:3rem!important}.mb-xl-5,.my-xl-5{margin-bottom:3rem!important}.ml-xl-5,.mx-xl-5{margin-left:3rem!important}.p-xl-0{padding:0!important}.pt-xl-0,.py-xl-0{padding-top:0!important}.pr-xl-0,.px-xl-0{padding-right:0!important}.pb-xl-0,.py-xl-0{padding-bottom:0!important}.pl-xl-0,.px-xl-0{padding-left:0!important}.p-xl-1{padding:.25rem!important}.pt-xl-1,.py-xl-1{padding-top:.25rem!important}.pr-xl-1,.px-xl-1{padding-right:.25rem!important}.pb-xl-1,.py-xl-1{padding-bottom:.25rem!important}.pl-xl-1,.px-xl-1{padding-left:.25rem!important}.p-xl-2{padding:.5rem!important}.pt-xl-2,.py-xl-2{padding-top:.5rem!important}.pr-xl-2,.px-xl-2{padding-right:.5rem!important}.pb-xl-2,.py-xl-2{padding-bottom:.5rem!important}.pl-xl-2,.px-xl-2{padding-left:.5rem!important}.p-xl-3{padding:1rem!important}.pt-xl-3,.py-xl-3{padding-top:1rem!important}.pr-xl-3,.px-xl-3{padding-right:1rem!important}.pb-xl-3,.py-xl-3{padding-bottom:1rem!important}.pl-xl-3,.px-xl-3{padding-left:1rem!important}.p-xl-4{padding:1.5rem!important}.pt-xl-4,.py-xl-4{padding-top:1.5rem!important}.pr-xl-4,.px-xl-4{padding-right:1.5rem!important}.pb-xl-4,.py-xl-4{padding-bottom:1.5rem!important}.pl-xl-4,.px-xl-4{padding-left:1.5rem!important}.p-xl-5{padding:3rem!important}.pt-xl-5,.py-xl-5{padding-top:3rem!important}.pr-xl-5,.px-xl-5{padding-right:3rem!important}.pb-xl-5,.py-xl-5{padding-bottom:3rem!important}.pl-xl-5,.px-xl-5{padding-left:3rem!important}.m-xl-n1{margin:-.25rem!important}.mt-xl-n1,.my-xl-n1{margin-top:-.25rem!important}.mr-xl-n1,.mx-xl-n1{margin-right:-.25rem!important}.mb-xl-n1,.my-xl-n1{margin-bottom:-.25rem!important}.ml-xl-n1,.mx-xl-n1{margin-left:-.25rem!important}.m-xl-n2{margin:-.5rem!important}.mt-xl-n2,.my-xl-n2{margin-top:-.5rem!important}.mr-xl-n2,.mx-xl-n2{margin-right:-.5rem!important}.mb-xl-n2,.my-xl-n2{margin-bottom:-.5rem!important}.ml-xl-n2,.mx-xl-n2{margin-left:-.5rem!important}.m-xl-n3{margin:-1rem!important}.mt-xl-n3,.my-xl-n3{margin-top:-1rem!important}.mr-xl-n3,.mx-xl-n3{margin-right:-1rem!important}.mb-xl-n3,.my-xl-n3{margin-bottom:-1rem!important}.ml-xl-n3,.mx-xl-n3{margin-left:-1rem!important}.m-xl-n4{margin:-1.5rem!important}.mt-xl-n4,.my-xl-n4{margin-top:-1.5rem!important}.mr-xl-n4,.mx-xl-n4{margin-right:-1.5rem!important}.mb-xl-n4,.my-xl-n4{margin-bottom:-1.5rem!important}.ml-xl-n4,.mx-xl-n4{margin-left:-1.5rem!important}.m-xl-n5{margin:-3rem!important}.mt-xl-n5,.my-xl-n5{margin-top:-3rem!important}.mr-xl-n5,.mx-xl-n5{margin-right:-3rem!important}.mb-xl-n5,.my-xl-n5{margin-bottom:-3rem!important}.ml-xl-n5,.mx-xl-n5{margin-left:-3rem!important}.m-xl-auto{margin:auto!important}.mt-xl-auto,.my-xl-auto{margin-top:auto!important}.mr-xl-auto,.mx-xl-auto{margin-right:auto!important}.mb-xl-auto,.my-xl-auto{margin-bottom:auto!important}.ml-xl-auto,.mx-xl-auto{margin-left:auto!important}}.stretched-link:after{z-index:1;pointer-events:auto;content:"";background-color:#0000;position:absolute;inset:0}.text-monospace{font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace!important}.text-justify{text-align:justify!important}.text-wrap{white-space:normal!important}.text-nowrap{white-space:nowrap!important}.text-truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.text-left{text-align:left!important}.text-right{text-align:right!important}.text-center{text-align:center!important}@media (min-width:576px){.text-sm-left{text-align:left!important}.text-sm-right{text-align:right!important}.text-sm-center{text-align:center!important}}@media (min-width:768px){.text-md-left{text-align:left!important}.text-md-right{text-align:right!important}.text-md-center{text-align:center!important}}@media (min-width:992px){.text-lg-left{text-align:left!important}.text-lg-right{text-align:right!important}.text-lg-center{text-align:center!important}}@media (min-width:1200px){.text-xl-left{text-align:left!important}.text-xl-right{text-align:right!important}.text-xl-center{text-align:center!important}}.text-lowercase{text-transform:lowercase!important}.text-uppercase{text-transform:uppercase!important}.text-capitalize{text-transform:capitalize!important}.font-weight-light{font-weight:300!important}.font-weight-lighter{font-weight:lighter!important}.font-weight-normal{font-weight:400!important}.font-weight-bold{font-weight:700!important}.font-weight-bolder{font-weight:bolder!important}.font-italic{font-style:italic!important}.text-white{color:#fff!important}.text-primary{color:#007bff!important}a.text-primary:focus,a.text-primary:hover{color:#0056b3!important}.text-secondary{color:#6c757d!important}a.text-secondary:focus,a.text-secondary:hover{color:#494f54!important}.text-success{color:#28a745!important}a.text-success:focus,a.text-success:hover{color:#19692c!important}.text-info{color:#17a2b8!important}a.text-info:focus,a.text-info:hover{color:#0f6674!important}.text-warning{color:#ffc107!important}a.text-warning:focus,a.text-warning:hover{color:#ba8b00!important}.text-danger{color:#dc3545!important}a.text-danger:focus,a.text-danger:hover{color:#a71d2a!important}.text-light{color:#f8f9fa!important}a.text-light:focus,a.text-light:hover{color:#cbd3da!important}.text-dark{color:#343a40!important}a.text-dark:focus,a.text-dark:hover{color:#121416!important}.text-body{color:#212529!important}.text-muted{color:#6c757d!important}.text-black-50{color:#00000080!important}.text-white-50{color:#ffffff80!important}.text-hide{font:0/0 a;color:#0000;text-shadow:none;background-color:#0000;border:0}.text-decoration-none{text-decoration:none!important}.text-break{word-break:break-word!important;word-wrap:break-word!important}.text-reset{color:inherit!important}.visible{visibility:visible!important}.invisible{visibility:hidden!important}@media print{*,:after,:before{text-shadow:none!important;box-shadow:none!important}a:not(.btn){text-decoration:underline}abbr[title]:after{content:" (" attr(title)")"}pre{white-space:pre-wrap!important}blockquote,pre{page-break-inside:avoid;border:1px solid #adb5bd}img,tr{page-break-inside:avoid}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}@page{size:a3}body,.container{min-width:992px!important}.navbar{display:none}.badge{border:1px solid #000}.table{border-collapse:collapse!important}.table td,.table th{background-color:#fff!important}.table-bordered td,.table-bordered th{border:1px solid #dee2e6!important}.table-dark{color:inherit}.table-dark tbody+tbody,.table-dark td,.table-dark th,.table-dark thead th{border-color:#dee2e6}.table .thead-dark th{color:inherit;border-color:#dee2e6}}@-webkit-keyframes bs-notify-fadeOut{0%{opacity:.9}to{opacity:0}}@-o-keyframes bs-notify-fadeOut{0%{opacity:.9}to{opacity:0}}@keyframes bs-notify-fadeOut{0%{opacity:.9}to{opacity:0}}.bootstrap-select>select.bs-select-hidden,select.bs-select-hidden,select.selectpicker{display:none!important}.bootstrap-select{width:220px�;vertical-align:middle}.bootstrap-select>.dropdown-toggle{width:100%;text-align:right;white-space:nowrap;justify-content:space-between;align-items:center;display:-webkit-inline-box;display:-webkit-inline-flex;display:-ms-inline-flexbox;display:inline-flex;position:relative}.bootstrap-select>.dropdown-toggle:after{margin-top:-1px}.bootstrap-select>.dropdown-toggle.bs-placeholder,.bootstrap-select>.dropdown-toggle.bs-placeholder:active,.bootstrap-select>.dropdown-toggle.bs-placeholder:focus,.bootstrap-select>.dropdown-toggle.bs-placeholder:hover{color:#999}.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-danger,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-danger:active,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-danger:focus,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-danger:hover,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-dark,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-dark:active,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-dark:focus,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-dark:hover,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-info,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-info:active,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-info:focus,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-info:hover,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-primary,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-primary:active,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-primary:focus,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-primary:hover,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-secondary,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-secondary:active,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-secondary:focus,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-secondary:hover,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-success,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-success:active,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-success:focus,.bootstrap-select>.dropdown-toggle.bs-placeholder.btn-success:hover{color:#ffffff80}.bootstrap-select>select{border:none;bottom:0;left:50%;width:.5px!important;height:100%!important;opacity:0!important;z-index:0!important;padding:0!important;display:block!important;position:absolute!important}.bootstrap-select>select.mobile-device{top:0;left:0;width:100%!important;z-index:2!important;display:block!important}.bootstrap-select.is-invalid .dropdown-toggle,.error .bootstrap-select .dropdown-toggle,.has-error .bootstrap-select .dropdown-toggle,.was-validated .bootstrap-select select:invalid+.dropdown-toggle{border-color:#b94a48}.bootstrap-select.is-valid .dropdown-toggle,.was-validated .bootstrap-select select:valid+.dropdown-toggle{border-color:#28a745}.bootstrap-select.fit-width{width:auto!important}.bootstrap-select:not([class*=col-]):not([class*=form-control]):not(.input-group-btn){width:220px}.bootstrap-select .dropdown-toggle:focus,.bootstrap-select>select.mobile-device:focus+.dropdown-toggle{outline-offset:-2px;outline:thin dotted #333!important;outline:5px auto -webkit-focus-ring-color!important}.bootstrap-select.form-control{height:auto;border:none;margin-bottom:0;padding:0}:not(.input-group)>.bootstrap-select.form-control:not([class*=col-]){width:100%}.bootstrap-select.form-control.input-group-btn{float:none;z-index:auto}.form-inline .bootstrap-select,.form-inline .bootstrap-select.form-control:not([class*=col-]){width:auto}.bootstrap-select:not(.input-group-btn),.bootstrap-select[class*=col-]{float:none;margin-left:0;display:inline-block}.bootstrap-select.dropdown-menu-right,.bootstrap-select[class*=col-].dropdown-menu-right,.row .bootstrap-select[class*=col-].dropdown-menu-right{float:right}.form-group .bootstrap-select,.form-horizontal .bootstrap-select,.form-inline .bootstrap-select{margin-bottom:0}.form-group-lg .bootstrap-select.form-control,.form-group-sm .bootstrap-select.form-control{padding:0}.form-group-lg .bootstrap-select.form-control .dropdown-toggle,.form-group-sm .bootstrap-select.form-control .dropdown-toggle{height:100%;font-size:inherit;line-height:inherit;border-radius:inherit}.bootstrap-select.form-control-lg .dropdown-toggle,.bootstrap-select.form-control-sm .dropdown-toggle{font-size:inherit;line-height:inherit;border-radius:inherit}.bootstrap-select.form-control-sm .dropdown-toggle{padding:.25rem .5rem}.bootstrap-select.form-control-lg .dropdown-toggle{padding:.5rem 1rem}.form-inline .bootstrap-select .form-control{width:100%}.bootstrap-select.disabled,.bootstrap-select>.disabled{cursor:not-allowed}.bootstrap-select.disabled:focus,.bootstrap-select>.disabled:focus{outline:0!important}.bootstrap-select.bs-container{position:absolute;top:0;left:0;height:0!important;padding:0!important}.bootstrap-select.bs-container .dropdown-menu{z-index:1060}.bootstrap-select .dropdown-toggle .filter-option{float:left;height:100%;width:100%;text-align:left;-webkit-box-flex:0;-webkit-flex:0 auto;-ms-flex:0 auto;flex:0 auto;position:static;top:0;left:0;overflow:hidden}.bs3.bootstrap-select .dropdown-toggle .filter-option{padding-right:inherit}.input-group .bs3-has-addon.bootstrap-select .dropdown-toggle .filter-option{padding-top:inherit;padding-bottom:inherit;padding-left:inherit;float:none;position:absolute}.input-group .bs3-has-addon.bootstrap-select .dropdown-toggle .filter-option .filter-option-inner{padding-right:inherit}.bootstrap-select .dropdown-toggle .filter-option-inner-inner{overflow:hidden}.bootstrap-select .dropdown-toggle .filter-expand{float:left;overflow:hidden;width:0!important;opacity:0!important}.bootstrap-select .dropdown-toggle .caret{vertical-align:middle;margin-top:-2px;position:absolute;top:50%;right:12px}.input-group .bootstrap-select.form-control .dropdown-toggle{border-radius:inherit}.bootstrap-select[class*=col-] .dropdown-toggle{width:100%}.bootstrap-select .dropdown-menu{min-width:100%;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.bootstrap-select .dropdown-menu>.inner:focus{outline:0!important}.bootstrap-select .dropdown-menu.inner{float:none;-webkit-box-shadow:none;box-shadow:none;border:0;border-radius:0;margin:0;padding:0;position:static}.bootstrap-select .dropdown-menu li{position:relative}.bootstrap-select .dropdown-menu li.active small{color:#ffffff80!important}.bootstrap-select .dropdown-menu li.disabled a{cursor:not-allowed}.bootstrap-select .dropdown-menu li a{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.bootstrap-select .dropdown-menu li a.opt{padding-left:2.25em;position:relative}.bootstrap-select .dropdown-menu li a span.check-mark{display:none}.bootstrap-select .dropdown-menu li a span.text{display:inline-block}.bootstrap-select .dropdown-menu li small{padding-left:.5em}.bootstrap-select .dropdown-menu .notify{width:96%;min-height:26px;pointer-events:none;opacity:.9;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;background:#f5f5f5;border:1px solid #e3e3e3;margin:0 2%;padding:3px 5px;position:absolute;bottom:5px;-webkit-box-shadow:inset 0 1px 1px #0000000d;box-shadow:inset 0 1px 1px #0000000d}.bootstrap-select .dropdown-menu .notify.fadeOut{-webkit-animation:bs-notify-fadeOut .3s linear .75s forwards;-o-animation:bs-notify-fadeOut .3s linear .75s forwards;animation:bs-notify-fadeOut .3s linear .75s forwards}.bootstrap-select .no-results{white-space:nowrap;background:#f5f5f5;margin:0 5px;padding:3px}.bootstrap-select.fit-width .dropdown-toggle .filter-option{padding:0;display:inline;position:static}.bootstrap-select.fit-width .dropdown-toggle .filter-option-inner,.bootstrap-select.fit-width .dropdown-toggle .filter-option-inner-inner{display:inline}.bootstrap-select.fit-width .dropdown-toggle .bs-caret:before{content:" "}.bootstrap-select.fit-width .dropdown-toggle .caret{margin-top:-1px;position:static;top:auto}.bootstrap-select.show-tick .dropdown-menu .selected span.check-mark{display:inline-block;position:absolute;top:5px;right:15px}.bootstrap-select.show-tick .dropdown-menu li a span.text{margin-right:34px}.bootstrap-select .bs-ok-default:after{content:"";width:.5em;height:1em;-webkit-transform-style:preserve-3d;transform-style:preserve-3d;border-style:solid;border-width:0 .26em .26em 0;display:block;-webkit-transform:rotate(45deg);-ms-transform:rotate(45deg);-o-transform:rotate(45deg);transform:rotate(45deg)}.bootstrap-select.show-menu-arrow.open>.dropdown-toggle,.bootstrap-select.show-menu-arrow.show>.dropdown-toggle{z-index:1061}.bootstrap-select.show-menu-arrow .dropdown-toggle .filter-option:before{content:"";border-bottom:7px solid #ccc3;border-left:7px solid #0000;border-right:7px solid #0000;display:none;position:absolute;bottom:-4px;left:9px}.bootstrap-select.show-menu-arrow .dropdown-toggle .filter-option:after{content:"";border-bottom:6px solid #fff;border-left:6px solid #0000;border-right:6px solid #0000;display:none;position:absolute;bottom:-4px;left:10px}.bootstrap-select.show-menu-arrow.dropup .dropdown-toggle .filter-option:before{border-top:7px solid #ccc3;border-bottom:0;top:-4px;bottom:auto}.bootstrap-select.show-menu-arrow.dropup .dropdown-toggle .filter-option:after{border-top:6px solid #fff;border-bottom:0;top:-4px;bottom:auto}.bootstrap-select.show-menu-arrow.pull-right .dropdown-toggle .filter-option:before{left:auto;right:12px}.bootstrap-select.show-menu-arrow.pull-right .dropdown-toggle .filter-option:after{left:auto;right:13px}.bootstrap-select.show-menu-arrow.open>.dropdown-toggle .filter-option:after,.bootstrap-select.show-menu-arrow.open>.dropdown-toggle .filter-option:before,.bootstrap-select.show-menu-arrow.show>.dropdown-toggle .filter-option:after,.bootstrap-select.show-menu-arrow.show>.dropdown-toggle .filter-option:before{display:block}.bs-actionsbox,.bs-donebutton,.bs-searchbox{padding:4px 8px}.bs-actionsbox{width:100%;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.bs-actionsbox .btn-group button{width:50%}.bs-donebutton{float:left;width:100%;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.bs-donebutton .btn-group button{width:100%}.bs-searchbox+.bs-actionsbox{padding:0 8px 4px}.bs-searchbox .form-control{width:100%;float:none;margin-bottom:0}@font-face{font-family:FontAwesome;src:url(fontawesome-webfont.3981e506.eot);src:url(fontawesome-webfont.3981e506.eot#iefix&v=4.7.0)format("embedded-opentype"),url(fontawesome-webfont.58488e7e.woff2)format("woff2"),url(fontawesome-webfont.ed962b83.woff)format("woff"),url(fontawesome-webfont.0caf0c90.ttf)format("truetype"),url(fontawesome-webfont.a9323ae9.svg#fontawesomeregular)format("svg");font-weight:400;font-style:normal}.fa{font:14px/1 FontAwesome;font-size:inherit;text-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;display:inline-block}.fa-lg{vertical-align:-15%;font-size:1.33333em;line-height:.75em}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-fw{width:1.28571em;text-align:center}.fa-ul{margin-left:2.14286em;padding-left:0;list-style-type:none}.fa-ul>li{position:relative}.fa-li{width:2.14286em;text-align:center;position:absolute;top:.142857em;left:-2.14286em}.fa-li.fa-lg{left:-1.85714em}.fa-border{border:.08em solid #eee;border-radius:.1em;padding:.2em .25em .15em}.fa-pull-left{float:left}.fa-pull-right{float:right}.fa.fa-pull-left{margin-right:.3em}.fa.fa-pull-right{margin-left:.3em}.pull-right{float:right}.pull-left{float:left}.fa.pull-left{margin-right:.3em}.fa.pull-right{margin-left:.3em}.fa-spin{-webkit-animation:fa-spin 2s linear infinite;animation:fa-spin 2s linear infinite}.fa-pulse{-webkit-animation:fa-spin 1s steps(8,end) infinite;animation:fa-spin 1s steps(8,end) infinite}@-webkit-keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}@keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.fa-rotate-90{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=1)";-webkit-transform:rotate(90deg);-ms-transform:rotate(90deg);transform:rotate(90deg)}.fa-rotate-180{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=2)";-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg)}.fa-rotate-270{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=3)";-webkit-transform:rotate(270deg);-ms-transform:rotate(270deg);transform:rotate(270deg)}.fa-flip-horizontal{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1)";-webkit-transform:scaleX(-1);-ms-transform:scaleX(-1);transform:scaleX(-1)}.fa-flip-vertical{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1)";-webkit-transform:scaleY(-1);-ms-transform:scaleY(-1);transform:scaleY(-1)}:root .fa-rotate-90,:root .fa-rotate-180,:root .fa-rotate-270,:root .fa-flip-horizontal,:root .fa-flip-vertical{filter:none}.fa-stack{width:2em;height:2em;vertical-align:middle;line-height:2em;display:inline-block;position:relative}.fa-stack-1x,.fa-stack-2x{width:100%;text-align:center;position:absolute;left:0}.fa-stack-1x{line-height:inherit}.fa-stack-2x{font-size:2em}.fa-inverse{color:#fff}.fa-glass:before{content:""}.fa-music:before{content:""}.fa-search:before{content:""}.fa-envelope-o:before{content:""}.fa-heart:before{content:""}.fa-star:before{content:""}.fa-star-o:before{content:""}.fa-user:before{content:""}.fa-film:before{content:""}.fa-th-large:before{content:""}.fa-th:before{content:""}.fa-th-list:before{content:""}.fa-check:before{content:""}.fa-remove:before,.fa-close:before,.fa-times:before{content:""}.fa-search-plus:before{content:""}.fa-search-minus:before{content:""}.fa-power-off:before{content:""}.fa-signal:before{content:""}.fa-gear:before,.fa-cog:before{content:""}.fa-trash-o:before{content:""}.fa-home:before{content:""}.fa-file-o:before{content:""}.fa-clock-o:before{content:""}.fa-road:before{content:""}.fa-download:before{content:""}.fa-arrow-circle-o-down:before{content:""}.fa-arrow-circle-o-up:before{content:""}.fa-inbox:before{content:""}.fa-play-circle-o:before{content:""}.fa-rotate-right:before,.fa-repeat:before{content:""}.fa-refresh:before{content:""}.fa-list-alt:before{content:""}.fa-lock:before{content:""}.fa-flag:before{content:""}.fa-headphones:before{content:""}.fa-volume-off:before{content:""}.fa-volume-down:before{content:""}.fa-volume-up:before{content:""}.fa-qrcode:before{content:""}.fa-barcode:before{content:""}.fa-tag:before{content:""}.fa-tags:before{content:""}.fa-book:before{content:""}.fa-bookmark:before{content:""}.fa-print:before{content:""}.fa-camera:before{content:""}.fa-font:before{content:""}.fa-bold:before{content:""}.fa-italic:before{content:""}.fa-text-height:before{content:""}.fa-text-width:before{content:""}.fa-align-left:before{content:""}.fa-align-center:before{content:""}.fa-align-right:before{content:""}.fa-align-justify:before{content:""}.fa-list:before{content:""}.fa-dedent:before,.fa-outdent:before{content:""}.fa-indent:before{content:""}.fa-video-camera:before{content:""}.fa-photo:before,.fa-image:before,.fa-picture-o:before{content:""}.fa-pencil:before{content:""}.fa-map-marker:before{content:""}.fa-adjust:before{content:""}.fa-tint:before{content:""}.fa-edit:before,.fa-pencil-square-o:before{content:""}.fa-share-square-o:before{content:""}.fa-check-square-o:before{content:""}.fa-arrows:before{content:""}.fa-step-backward:before{content:""}.fa-fast-backward:before{content:""}.fa-backward:before{content:""}.fa-play:before{content:""}.fa-pause:before{content:""}.fa-stop:before{content:""}.fa-forward:before{content:""}.fa-fast-forward:before{content:""}.fa-step-forward:before{content:""}.fa-eject:before{content:""}.fa-chevron-left:before{content:""}.fa-chevron-right:before{content:""}.fa-plus-circle:before{content:""}.fa-minus-circle:before{content:""}.fa-times-circle:before{content:""}.fa-check-circle:before{content:""}.fa-question-circle:before{content:""}.fa-info-circle:before{content:""}.fa-crosshairs:before{content:""}.fa-times-circle-o:before{content:""}.fa-check-circle-o:before{content:""}.fa-ban:before{content:""}.fa-arrow-left:before{content:""}.fa-arrow-right:before{content:""}.fa-arrow-up:before{content:""}.fa-arrow-down:before{content:""}.fa-mail-forward:before,.fa-share:before{content:""}.fa-expand:before{content:""}.fa-compress:before{content:""}.fa-plus:before{content:""}.fa-minus:before{content:""}.fa-asterisk:before{content:""}.fa-exclamation-circle:before{content:""}.fa-gift:before{content:""}.fa-leaf:before{content:""}.fa-fire:before{content:""}.fa-eye:before{content:""}.fa-eye-slash:before{content:""}.fa-warning:before,.fa-exclamation-triangle:before{content:""}.fa-plane:before{content:""}.fa-calendar:before{content:""}.fa-random:before{content:""}.fa-comment:before{content:""}.fa-magnet:before{content:""}.fa-chevron-up:before{content:""}.fa-chevron-down:before{content:""}.fa-retweet:before{content:""}.fa-shopping-cart:before{content:""}.fa-folder:before{content:""}.fa-folder-open:before{content:""}.fa-arrows-v:before{content:""}.fa-arrows-h:before{content:""}.fa-bar-chart-o:before,.fa-bar-chart:before{content:""}.fa-twitter-square:before{content:""}.fa-facebook-square:before{content:""}.fa-camera-retro:before{content:""}.fa-key:before{content:""}.fa-gears:before,.fa-cogs:before{content:""}.fa-comments:before{content:""}.fa-thumbs-o-up:before{content:""}.fa-thumbs-o-down:before{content:""}.fa-star-half:before{content:""}.fa-heart-o:before{content:""}.fa-sign-out:before{content:""}.fa-linkedin-square:before{content:""}.fa-thumb-tack:before{content:""}.fa-external-link:before{content:""}.fa-sign-in:before{content:""}.fa-trophy:before{content:""}.fa-github-square:before{content:""}.fa-upload:before{content:""}.fa-lemon-o:before{content:""}.fa-phone:before{content:""}.fa-square-o:before{content:""}.fa-bookmark-o:before{content:""}.fa-phone-square:before{content:""}.fa-twitter:before{content:""}.fa-facebook-f:before,.fa-facebook:before{content:""}.fa-github:before{content:""}.fa-unlock:before{content:""}.fa-credit-card:before{content:""}.fa-feed:before,.fa-rss:before{content:""}.fa-hdd-o:before{content:""}.fa-bullhorn:before{content:""}.fa-bell:before{content:""}.fa-certificate:before{content:""}.fa-hand-o-right:before{content:""}.fa-hand-o-left:before{content:""}.fa-hand-o-up:before{content:""}.fa-hand-o-down:before{content:""}.fa-arrow-circle-left:before{content:""}.fa-arrow-circle-right:before{content:""}.fa-arrow-circle-up:before{content:""}.fa-arrow-circle-down:before{content:""}.fa-globe:before{content:""}.fa-wrench:before{content:""}.fa-tasks:before{content:""}.fa-filter:before{content:""}.fa-briefcase:before{content:""}.fa-arrows-alt:before{content:""}.fa-group:before,.fa-users:before{content:""}.fa-chain:before,.fa-link:before{content:""}.fa-cloud:before{content:""}.fa-flask:before{content:""}.fa-cut:before,.fa-scissors:before{content:""}.fa-copy:before,.fa-files-o:before{content:""}.fa-paperclip:before{content:""}.fa-save:before,.fa-floppy-o:before{content:""}.fa-square:before{content:""}.fa-navicon:before,.fa-reorder:before,.fa-bars:before{content:""}.fa-list-ul:before{content:""}.fa-list-ol:before{content:""}.fa-strikethrough:before{content:""}.fa-underline:before{content:""}.fa-table:before{content:""}.fa-magic:before{content:""}.fa-truck:before{content:""}.fa-pinterest:before{content:""}.fa-pinterest-square:before{content:""}.fa-google-plus-square:before{content:""}.fa-google-plus:before{content:""}.fa-money:before{content:""}.fa-caret-down:before{content:""}.fa-caret-up:before{content:""}.fa-caret-left:before{content:""}.fa-caret-right:before{content:""}.fa-columns:before{content:""}.fa-unsorted:before,.fa-sort:before{content:""}.fa-sort-down:before,.fa-sort-desc:before{content:""}.fa-sort-up:before,.fa-sort-asc:before{content:""}.fa-envelope:before{content:""}.fa-linkedin:before{content:""}.fa-rotate-left:before,.fa-undo:before{content:""}.fa-legal:before,.fa-gavel:before{content:""}.fa-dashboard:before,.fa-tachometer:before{content:""}.fa-comment-o:before{content:""}.fa-comments-o:before{content:""}.fa-flash:before,.fa-bolt:before{content:""}.fa-sitemap:before{content:""}.fa-umbrella:before{content:""}.fa-paste:before,.fa-clipboard:before{content:""}.fa-lightbulb-o:before{content:""}.fa-exchange:before{content:""}.fa-cloud-download:before{content:""}.fa-cloud-upload:before{content:""}.fa-user-md:before{content:""}.fa-stethoscope:before{content:""}.fa-suitcase:before{content:""}.fa-bell-o:before{content:""}.fa-coffee:before{content:""}.fa-cutlery:before{content:""}.fa-file-text-o:before{content:""}.fa-building-o:before{content:""}.fa-hospital-o:before{content:""}.fa-ambulance:before{content:""}.fa-medkit:before{content:""}.fa-fighter-jet:before{content:""}.fa-beer:before{content:""}.fa-h-square:before{content:""}.fa-plus-square:before{content:""}.fa-angle-double-left:before{content:""}.fa-angle-double-right:before{content:""}.fa-angle-double-up:before{content:""}.fa-angle-double-down:before{content:""}.fa-angle-left:before{content:""}.fa-angle-right:before{content:""}.fa-angle-up:before{content:""}.fa-angle-down:before{content:""}.fa-desktop:before{content:""}.fa-laptop:before{content:""}.fa-tablet:before{content:""}.fa-mobile-phone:before,.fa-mobile:before{content:""}.fa-circle-o:before{content:""}.fa-quote-left:before{content:""}.fa-quote-right:before{content:""}.fa-spinner:before{content:""}.fa-circle:before{content:""}.fa-mail-reply:before,.fa-reply:before{content:""}.fa-github-alt:before{content:""}.fa-folder-o:before{content:""}.fa-folder-open-o:before{content:""}.fa-smile-o:before{content:""}.fa-frown-o:before{content:""}.fa-meh-o:before{content:""}.fa-gamepad:before{content:""}.fa-keyboard-o:before{content:""}.fa-flag-o:before{content:""}.fa-flag-checkered:before{content:""}.fa-terminal:before{content:""}.fa-code:before{content:""}.fa-mail-reply-all:before,.fa-reply-all:before{content:""}.fa-star-half-empty:before,.fa-star-half-full:before,.fa-star-half-o:before{content:""}.fa-location-arrow:before{content:""}.fa-crop:before{content:""}.fa-code-fork:before{content:""}.fa-unlink:before,.fa-chain-broken:before{content:""}.fa-question:before{content:""}.fa-info:before{content:""}.fa-exclamation:before{content:""}.fa-superscript:before{content:""}.fa-subscript:before{content:""}.fa-eraser:before{content:""}.fa-puzzle-piece:before{content:""}.fa-microphone:before{content:""}.fa-microphone-slash:before{content:""}.fa-shield:before{content:""}.fa-calendar-o:before{content:""}.fa-fire-extinguisher:before{content:""}.fa-rocket:before{content:""}.fa-maxcdn:before{content:""}.fa-chevron-circle-left:before{content:""}.fa-chevron-circle-right:before{content:""}.fa-chevron-circle-up:before{content:""}.fa-chevron-circle-down:before{content:""}.fa-html5:before{content:""}.fa-css3:before{content:""}.fa-anchor:before{content:""}.fa-unlock-alt:before{content:""}.fa-bullseye:before{content:""}.fa-ellipsis-h:before{content:""}.fa-ellipsis-v:before{content:""}.fa-rss-square:before{content:""}.fa-play-circle:before{content:""}.fa-ticket:before{content:""}.fa-minus-square:before{content:""}.fa-minus-square-o:before{content:""}.fa-level-up:before{content:""}.fa-level-down:before{content:""}.fa-check-square:before{content:""}.fa-pencil-square:before{content:""}.fa-external-link-square:before{content:""}.fa-share-square:before{content:""}.fa-compass:before{content:""}.fa-toggle-down:before,.fa-caret-square-o-down:before{content:""}.fa-toggle-up:before,.fa-caret-square-o-up:before{content:""}.fa-toggle-right:before,.fa-caret-square-o-right:before{content:""}.fa-euro:before,.fa-eur:before{content:""}.fa-gbp:before{content:""}.fa-dollar:before,.fa-usd:before{content:""}.fa-rupee:before,.fa-inr:before{content:""}.fa-cny:before,.fa-rmb:before,.fa-yen:before,.fa-jpy:before{content:""}.fa-ruble:before,.fa-rouble:before,.fa-rub:before{content:""}.fa-won:before,.fa-krw:before{content:""}.fa-bitcoin:before,.fa-btc:before{content:""}.fa-file:before{content:""}.fa-file-text:before{content:""}.fa-sort-alpha-asc:before{content:""}.fa-sort-alpha-desc:before{content:""}.fa-sort-amount-asc:before{content:""}.fa-sort-amount-desc:before{content:""}.fa-sort-numeric-asc:before{content:""}.fa-sort-numeric-desc:before{content:""}.fa-thumbs-up:before{content:""}.fa-thumbs-down:before{content:""}.fa-youtube-square:before{content:""}.fa-youtube:before{content:""}.fa-xing:before{content:""}.fa-xing-square:before{content:""}.fa-youtube-play:before{content:""}.fa-dropbox:before{content:""}.fa-stack-overflow:before{content:""}.fa-instagram:before{content:""}.fa-flickr:before{content:""}.fa-adn:before{content:""}.fa-bitbucket:before{content:""}.fa-bitbucket-square:before{content:""}.fa-tumblr:before{content:""}.fa-tumblr-square:before{content:""}.fa-long-arrow-down:before{content:""}.fa-long-arrow-up:before{content:""}.fa-long-arrow-left:before{content:""}.fa-long-arrow-right:before{content:""}.fa-apple:before{content:""}.fa-windows:before{content:""}.fa-android:before{content:""}.fa-linux:before{content:""}.fa-dribbble:before{content:""}.fa-skype:before{content:""}.fa-foursquare:before{content:""}.fa-trello:before{content:""}.fa-female:before{content:""}.fa-male:before{content:""}.fa-gittip:before,.fa-gratipay:before{content:""}.fa-sun-o:before{content:""}.fa-moon-o:before{content:""}.fa-archive:before{content:""}.fa-bug:before{content:""}.fa-vk:before{content:""}.fa-weibo:before{content:""}.fa-renren:before{content:""}.fa-pagelines:before{content:""}.fa-stack-exchange:before{content:""}.fa-arrow-circle-o-right:before{content:""}.fa-arrow-circle-o-left:before{content:""}.fa-toggle-left:before,.fa-caret-square-o-left:before{content:""}.fa-dot-circle-o:before{content:""}.fa-wheelchair:before{content:""}.fa-vimeo-square:before{content:""}.fa-turkish-lira:before,.fa-try:before{content:""}.fa-plus-square-o:before{content:""}.fa-space-shuttle:before{content:""}.fa-slack:before{content:""}.fa-envelope-square:before{content:""}.fa-wordpress:before{content:""}.fa-openid:before{content:""}.fa-institution:before,.fa-bank:before,.fa-university:before{content:""}.fa-mortar-board:before,.fa-graduation-cap:before{content:""}.fa-yahoo:before{content:""}.fa-google:before{content:""}.fa-reddit:before{content:""}.fa-reddit-square:before{content:""}.fa-stumbleupon-circle:before{content:""}.fa-stumbleupon:before{content:""}.fa-delicious:before{content:""}.fa-digg:before{content:""}.fa-pied-piper-pp:before{content:""}.fa-pied-piper-alt:before{content:""}.fa-drupal:before{content:""}.fa-joomla:before{content:""}.fa-language:before{content:""}.fa-fax:before{content:""}.fa-building:before{content:""}.fa-child:before{content:""}.fa-paw:before{content:""}.fa-spoon:before{content:""}.fa-cube:before{content:""}.fa-cubes:before{content:""}.fa-behance:before{content:""}.fa-behance-square:before{content:""}.fa-steam:before{content:""}.fa-steam-square:before{content:""}.fa-recycle:before{content:""}.fa-automobile:before,.fa-car:before{content:""}.fa-cab:before,.fa-taxi:before{content:""}.fa-tree:before{content:""}.fa-spotify:before{content:""}.fa-deviantart:before{content:""}.fa-soundcloud:before{content:""}.fa-database:before{content:""}.fa-file-pdf-o:before{content:""}.fa-file-word-o:before{content:""}.fa-file-excel-o:before{content:""}.fa-file-powerpoint-o:before{content:""}.fa-file-photo-o:before,.fa-file-picture-o:before,.fa-file-image-o:before{content:""}.fa-file-zip-o:before,.fa-file-archive-o:before{content:""}.fa-file-sound-o:before,.fa-file-audio-o:before{content:""}.fa-file-movie-o:before,.fa-file-video-o:before{content:""}.fa-file-code-o:before{content:""}.fa-vine:before{content:""}.fa-codepen:before{content:""}.fa-jsfiddle:before{content:""}.fa-life-bouy:before,.fa-life-buoy:before,.fa-life-saver:before,.fa-support:before,.fa-life-ring:before{content:""}.fa-circle-o-notch:before{content:""}.fa-ra:before,.fa-resistance:before,.fa-rebel:before{content:""}.fa-ge:before,.fa-empire:before{content:""}.fa-git-square:before{content:""}.fa-git:before{content:""}.fa-y-combinator-square:before,.fa-yc-square:before,.fa-hacker-news:before{content:""}.fa-tencent-weibo:before{content:""}.fa-qq:before{content:""}.fa-wechat:before,.fa-weixin:before{content:""}.fa-send:before,.fa-paper-plane:before{content:""}.fa-send-o:before,.fa-paper-plane-o:before{content:""}.fa-history:before{content:""}.fa-circle-thin:before{content:""}.fa-header:before{content:""}.fa-paragraph:before{content:""}.fa-sliders:before{content:""}.fa-share-alt:before{content:""}.fa-share-alt-square:before{content:""}.fa-bomb:before{content:""}.fa-soccer-ball-o:before,.fa-futbol-o:before{content:""}.fa-tty:before{content:""}.fa-binoculars:before{content:""}.fa-plug:before{content:""}.fa-slideshare:before{content:""}.fa-twitch:before{content:""}.fa-yelp:before{content:""}.fa-newspaper-o:before{content:""}.fa-wifi:before{content:""}.fa-calculator:before{content:""}.fa-paypal:before{content:""}.fa-google-wallet:before{content:""}.fa-cc-visa:before{content:""}.fa-cc-mastercard:before{content:""}.fa-cc-discover:before{content:""}.fa-cc-amex:before{content:""}.fa-cc-paypal:before{content:""}.fa-cc-stripe:before{content:""}.fa-bell-slash:before{content:""}.fa-bell-slash-o:before{content:""}.fa-trash:before{content:""}.fa-copyright:before{content:""}.fa-at:before{content:""}.fa-eyedropper:before{content:""}.fa-paint-brush:before{content:""}.fa-birthday-cake:before{content:""}.fa-area-chart:before{content:""}.fa-pie-chart:before{content:""}.fa-line-chart:before{content:""}.fa-lastfm:before{content:""}.fa-lastfm-square:before{content:""}.fa-toggle-off:before{content:""}.fa-toggle-on:before{content:""}.fa-bicycle:before{content:""}.fa-bus:before{content:""}.fa-ioxhost:before{content:""}.fa-angellist:before{content:""}.fa-cc:before{content:""}.fa-shekel:before,.fa-sheqel:before,.fa-ils:before{content:""}.fa-meanpath:before{content:""}.fa-buysellads:before{content:""}.fa-connectdevelop:before{content:""}.fa-dashcube:before{content:""}.fa-forumbee:before{content:""}.fa-leanpub:before{content:""}.fa-sellsy:before{content:""}.fa-shirtsinbulk:before{content:""}.fa-simplybuilt:before{content:""}.fa-skyatlas:before{content:""}.fa-cart-plus:before{content:""}.fa-cart-arrow-down:before{content:""}.fa-diamond:before{content:""}.fa-ship:before{content:""}.fa-user-secret:before{content:""}.fa-motorcycle:before{content:""}.fa-street-view:before{content:""}.fa-heartbeat:before{content:""}.fa-venus:before{content:""}.fa-mars:before{content:""}.fa-mercury:before{content:""}.fa-intersex:before,.fa-transgender:before{content:""}.fa-transgender-alt:before{content:""}.fa-venus-double:before{content:""}.fa-mars-double:before{content:""}.fa-venus-mars:before{content:""}.fa-mars-stroke:before{content:""}.fa-mars-stroke-v:before{content:""}.fa-mars-stroke-h:before{content:""}.fa-neuter:before{content:""}.fa-genderless:before{content:""}.fa-facebook-official:before{content:""}.fa-pinterest-p:before{content:""}.fa-whatsapp:before{content:""}.fa-server:before{content:""}.fa-user-plus:before{content:""}.fa-user-times:before{content:""}.fa-hotel:before,.fa-bed:before{content:""}.fa-viacoin:before{content:""}.fa-train:before{content:""}.fa-subway:before{content:""}.fa-medium:before{content:""}.fa-yc:before,.fa-y-combinator:before{content:""}.fa-optin-monster:before{content:""}.fa-opencart:before{content:""}.fa-expeditedssl:before{content:""}.fa-battery-4:before,.fa-battery:before,.fa-battery-full:before{content:""}.fa-battery-3:before,.fa-battery-three-quarters:before{content:""}.fa-battery-2:before,.fa-battery-half:before{content:""}.fa-battery-1:before,.fa-battery-quarter:before{content:""}.fa-battery-0:before,.fa-battery-empty:before{content:""}.fa-mouse-pointer:before{content:""}.fa-i-cursor:before{content:""}.fa-object-group:before{content:""}.fa-object-ungroup:before{content:""}.fa-sticky-note:before{content:""}.fa-sticky-note-o:before{content:""}.fa-cc-jcb:before{content:""}.fa-cc-diners-club:before{content:""}.fa-clone:before{content:""}.fa-balance-scale:before{content:""}.fa-hourglass-o:before{content:""}.fa-hourglass-1:before,.fa-hourglass-start:before{content:""}.fa-hourglass-2:before,.fa-hourglass-half:before{content:""}.fa-hourglass-3:before,.fa-hourglass-end:before{content:""}.fa-hourglass:before{content:""}.fa-hand-grab-o:before,.fa-hand-rock-o:before{content:""}.fa-hand-stop-o:before,.fa-hand-paper-o:before{content:""}.fa-hand-scissors-o:before{content:""}.fa-hand-lizard-o:before{content:""}.fa-hand-spock-o:before{content:""}.fa-hand-pointer-o:before{content:""}.fa-hand-peace-o:before{content:""}.fa-trademark:before{content:""}.fa-registered:before{content:""}.fa-creative-commons:before{content:""}.fa-gg:before{content:""}.fa-gg-circle:before{content:""}.fa-tripadvisor:before{content:""}.fa-odnoklassniki:before{content:""}.fa-odnoklassniki-square:before{content:""}.fa-get-pocket:before{content:""}.fa-wikipedia-w:before{content:""}.fa-safari:before{content:""}.fa-chrome:before{content:""}.fa-firefox:before{content:""}.fa-opera:before{content:""}.fa-internet-explorer:before{content:""}.fa-tv:before,.fa-television:before{content:""}.fa-contao:before{content:""}.fa-500px:before{content:""}.fa-amazon:before{content:""}.fa-calendar-plus-o:before{content:""}.fa-calendar-minus-o:before{content:""}.fa-calendar-times-o:before{content:""}.fa-calendar-check-o:before{content:""}.fa-industry:before{content:""}.fa-map-pin:before{content:""}.fa-map-signs:before{content:""}.fa-map-o:before{content:""}.fa-map:before{content:""}.fa-commenting:before{content:""}.fa-commenting-o:before{content:""}.fa-houzz:before{content:""}.fa-vimeo:before{content:""}.fa-black-tie:before{content:""}.fa-fonticons:before{content:""}.fa-reddit-alien:before{content:""}.fa-edge:before{content:""}.fa-credit-card-alt:before{content:""}.fa-codiepie:before{content:""}.fa-modx:before{content:""}.fa-fort-awesome:before{content:""}.fa-usb:before{content:""}.fa-product-hunt:before{content:""}.fa-mixcloud:before{content:""}.fa-scribd:before{content:""}.fa-pause-circle:before{content:""}.fa-pause-circle-o:before{content:""}.fa-stop-circle:before{content:""}.fa-stop-circle-o:before{content:""}.fa-shopping-bag:before{content:""}.fa-shopping-basket:before{content:""}.fa-hashtag:before{content:""}.fa-bluetooth:before{content:""}.fa-bluetooth-b:before{content:""}.fa-percent:before{content:""}.fa-gitlab:before{content:""}.fa-wpbeginner:before{content:""}.fa-wpforms:before{content:""}.fa-envira:before{content:""}.fa-universal-access:before{content:""}.fa-wheelchair-alt:before{content:""}.fa-question-circle-o:before{content:""}.fa-blind:before{content:""}.fa-audio-description:before{content:""}.fa-volume-control-phone:before{content:""}.fa-braille:before{content:""}.fa-assistive-listening-systems:before{content:""}.fa-asl-interpreting:before,.fa-american-sign-language-interpreting:before{content:""}.fa-deafness:before,.fa-hard-of-hearing:before,.fa-deaf:before{content:""}.fa-glide:before{content:""}.fa-glide-g:before{content:""}.fa-signing:before,.fa-sign-language:before{content:""}.fa-low-vision:before{content:""}.fa-viadeo:before{content:""}.fa-viadeo-square:before{content:""}.fa-snapchat:before{content:""}.fa-snapchat-ghost:before{content:""}.fa-snapchat-square:before{content:""}.fa-pied-piper:before{content:""}.fa-first-order:before{content:""}.fa-yoast:before{content:""}.fa-themeisle:before{content:""}.fa-google-plus-circle:before,.fa-google-plus-official:before{content:""}.fa-fa:before,.fa-font-awesome:before{content:""}.fa-handshake-o:before{content:""}.fa-envelope-open:before{content:""}.fa-envelope-open-o:before{content:""}.fa-linode:before{content:""}.fa-address-book:before{content:""}.fa-address-book-o:before{content:""}.fa-vcard:before,.fa-address-card:before{content:""}.fa-vcard-o:before,.fa-address-card-o:before{content:""}.fa-user-circle:before{content:""}.fa-user-circle-o:before{content:""}.fa-user-o:before{content:""}.fa-id-badge:before{content:""}.fa-drivers-license:before,.fa-id-card:before{content:""}.fa-drivers-license-o:before,.fa-id-card-o:before{content:""}.fa-quora:before{content:""}.fa-free-code-camp:before{content:""}.fa-telegram:before{content:""}.fa-thermometer-4:before,.fa-thermometer:before,.fa-thermometer-full:before{content:""}.fa-thermometer-3:before,.fa-thermometer-three-quarters:before{content:""}.fa-thermometer-2:before,.fa-thermometer-half:before{content:""}.fa-thermometer-1:before,.fa-thermometer-quarter:before{content:""}.fa-thermometer-0:before,.fa-thermometer-empty:before{content:""}.fa-shower:before{content:""}.fa-bathtub:before,.fa-s15:before,.fa-bath:before{content:""}.fa-podcast:before{content:""}.fa-window-maximize:before{content:""}.fa-window-minimize:before{content:""}.fa-window-restore:before{content:""}.fa-times-rectangle:before,.fa-window-close:before{content:""}.fa-times-rectangle-o:before,.fa-window-close-o:before{content:""}.fa-bandcamp:before{content:""}.fa-grav:before{content:""}.fa-etsy:before{content:""}.fa-imdb:before{content:""}.fa-ravelry:before{content:""}.fa-eercast:before{content:""}.fa-microchip:before{content:""}.fa-snowflake-o:before{content:""}.fa-superpowers:before{content:""}.fa-wpexplorer:before{content:""}.fa-meetup:before{content:""}.sr-only{width:1px;height:1px;clip:rect(0,0,0,0);border:0;margin:-1px;padding:0;position:absolute;overflow:hidden}.sr-only-focusable:active,.sr-only-focusable:focus{width:auto;height:auto;clip:auto;margin:0;position:static;overflow:visible}.mfp-bg{width:100%;height:100%;z-index:1042;opacity:.8;background:#0b0b0b;position:fixed;top:0;left:0;overflow:hidden}.mfp-wrap{width:100%;height:100%;z-index:1043;-webkit-backface-visibility:hidden;position:fixed;top:0;left:0;outline:none!important}.mfp-container{text-align:center;width:100%;height:100%;box-sizing:border-box;padding:0 8px;position:absolute;top:0;left:0}.mfp-container:before{content:"";height:100%;vertical-align:middle;display:inline-block}.mfp-align-top .mfp-container:before{display:none}.mfp-content{vertical-align:middle;text-align:left;z-index:1045;margin:0 auto;display:inline-block;position:relative}.mfp-inline-holder .mfp-content,.mfp-ajax-holder .mfp-content{width:100%;cursor:auto}.mfp-ajax-cur{cursor:progress}.mfp-zoom-out-cur,.mfp-zoom-out-cur .mfp-image-holder .mfp-close{cursor:-moz-zoom-out;cursor:-webkit-zoom-out;cursor:zoom-out}.mfp-zoom{cursor:pointer;cursor:-webkit-zoom-in;cursor:-moz-zoom-in;cursor:zoom-in}.mfp-auto-cursor .mfp-content{cursor:auto}.mfp-close,.mfp-arrow,.mfp-preloader,.mfp-counter{-webkit-user-select:none;-moz-user-select:none;user-select:none}.mfp-loading.mfp-figure{display:none}.mfp-hide{display:none!important}.mfp-preloader{color:#ccc;width:auto;text-align:center;z-index:1044;margin-top:-.8em;position:absolute;top:50%;left:8px;right:8px}.mfp-preloader a{color:#ccc}.mfp-preloader a:hover{color:#fff}.mfp-s-ready .mfp-preloader,.mfp-s-error .mfp-content{display:none}button.mfp-close,button.mfp-arrow{cursor:pointer;-webkit-appearance:none;z-index:1046;box-shadow:none;touch-action:manipulation;background:0 0;border:0;outline:none;padding:0;display:block;overflow:visible}button::-moz-focus-inner{border:0;padding:0}.mfp-close{width:44px;height:44px;text-align:center;opacity:.65;color:#fff;padding:0 0 18px 10px;font-family:Arial,Baskerville,monospace;font-size:28px;font-style:normal;line-height:44px;text-decoration:none;position:absolute;top:0;right:0}.mfp-close:hover,.mfp-close:focus{opacity:1}.mfp-close:active{top:1px}.mfp-close-btn-in .mfp-close{color:#333}.mfp-image-holder .mfp-close,.mfp-iframe-holder .mfp-close{color:#fff;text-align:right;width:100%;padding-right:6px;right:-6px}.mfp-counter{color:#ccc;white-space:nowrap;font-size:12px;line-height:18px;position:absolute;top:0;right:0}.mfp-arrow{opacity:.65;width:90px;height:110px;-webkit-tap-highlight-color:transparent;margin:-55px 0 0;padding:0;position:absolute;top:50%}.mfp-arrow:active{margin-top:-54px}.mfp-arrow:hover,.mfp-arrow:focus{opacity:1}.mfp-arrow:before,.mfp-arrow:after{content:"";width:0;height:0;border:inset #0000;margin-top:35px;margin-left:35px;display:block;position:absolute;top:0;left:0}.mfp-arrow:after{border-top-width:13px;border-bottom-width:13px;top:8px}.mfp-arrow:before{opacity:.7;border-top-width:21px;border-bottom-width:21px}.mfp-arrow-left{left:0}.mfp-arrow-left:after{border-right:17px solid #fff;margin-left:31px}.mfp-arrow-left:before{border-right:27px solid #3f3f3f;margin-left:25px}.mfp-arrow-right{right:0}.mfp-arrow-right:after{border-left:17px solid #fff;margin-left:39px}.mfp-arrow-right:before{border-left:27px solid #3f3f3f}.mfp-iframe-holder{padding-top:40px;padding-bottom:40px}.mfp-iframe-holder .mfp-content{width:100%;max-width:900px;line-height:0}.mfp-iframe-holder .mfp-close{top:-40px}.mfp-iframe-scaler{width:100%;height:0;padding-top:56.25%;overflow:hidden}.mfp-iframe-scaler iframe{width:100%;height:100%;background:#000;display:block;position:absolute;top:0;left:0;box-shadow:0 0 8px #0009}img.mfp-img{width:auto;max-width:100%;height:auto;box-sizing:border-box;margin:0 auto;padding:40px 0;line-height:0;display:block}.mfp-figure{line-height:0}.mfp-figure:after{content:"";width:auto;height:auto;z-index:-1;background:#444;display:block;position:absolute;inset:40px 0;box-shadow:0 0 8px #0009}.mfp-figure small{color:#bdbdbd;font-size:12px;line-height:14px;display:block}.mfp-figure figure{margin:0}.mfp-bottom-bar{width:100%;cursor:auto;margin-top:-36px;position:absolute;top:100%;left:0}.mfp-title{text-align:left;color:#f3f3f3;word-wrap:break-word;padding-right:36px;line-height:18px}.mfp-image-holder .mfp-content{max-width:100%}.mfp-gallery .mfp-image-holder .mfp-figure{cursor:pointer}@media screen and (max-width:800px) and (orientation:landscape),screen and (max-height:300px){.mfp-img-mobile .mfp-image-holder{padding-left:0;padding-right:0}.mfp-img-mobile img.mfp-img{padding:0}.mfp-img-mobile .mfp-figure:after{top:0;bottom:0}.mfp-img-mobile .mfp-figure small{margin-left:5px;display:inline}.mfp-img-mobile .mfp-bottom-bar{box-sizing:border-box;background:#0009;margin:0;padding:3px 5px;position:fixed;top:auto;bottom:0}.mfp-img-mobile .mfp-bottom-bar:empty{padding:0}.mfp-img-mobile .mfp-counter{top:3px;right:5px}.mfp-img-mobile .mfp-close{width:35px;height:35px;text-align:center;background:#0009;padding:0;line-height:35px;position:fixed;top:0;right:0}}@media (max-width:900px){.mfp-arrow{-webkit-transform:scale(.75);transform:scale(.75)}.mfp-arrow-left{-webkit-transform-origin:0;transform-origin:0}.mfp-arrow-right{-webkit-transform-origin:100%;transform-origin:100%}.mfp-container{padding-left:6px;padding-right:6px}}.owl-carousel,.owl-carousel .owl-item{-webkit-tap-highlight-color:transparent;position:relative}.owl-carousel{width:100%;z-index:1;display:none}.owl-carousel .owl-stage{-ms-touch-action:pan-Y;touch-action:manipulation;-moz-backface-visibility:hidden;position:relative}.owl-carousel .owl-stage:after{content:".";clear:both;visibility:hidden;height:0;line-height:0;display:block}.owl-carousel .owl-stage-outer{position:relative;overflow:hidden;-webkit-transform:translate(0,0)}.owl-carousel .owl-item,.owl-carousel .owl-wrapper{-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;-ms-backface-visibility:hidden;-webkit-transform:translate(0,0);-moz-transform:translate(0,0);-ms-transform:translate(0,0)}.owl-carousel .owl-item{min-height:1px;float:left;-webkit-backface-visibility:hidden;-webkit-touch-callout:none}.owl-carousel .owl-item img{width:100%;display:block}.owl-carousel .owl-dots.disabled,.owl-carousel .owl-nav.disabled{display:none}.no-js .owl-carousel,.owl-carousel.owl-loaded{display:block}.owl-carousel .owl-dot,.owl-carousel .owl-nav .owl-next,.owl-carousel .owl-nav .owl-prev{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-khtml-user-select:none}.owl-carousel .owl-nav button.owl-next,.owl-carousel .owl-nav button.owl-prev,.owl-carousel button.owl-dot{color:inherit;font:inherit;background:0 0;border:none;padding:0!important}.owl-carousel.owl-loading{opacity:0;display:block}.owl-carousel.owl-hidden{opacity:0}.owl-carousel.owl-refresh .owl-item{visibility:hidden}.owl-carousel.owl-drag .owl-item{-ms-touch-action:pan-y;touch-action:pan-y;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.owl-carousel.owl-grab{cursor:move;cursor:grab}.owl-carousel.owl-rtl{direction:rtl}.owl-carousel.owl-rtl .owl-item{float:right}.owl-carousel .animated{animation-duration:1s;animation-fill-mode:both}.owl-carousel .owl-animated-in{z-index:0}.owl-carousel .owl-animated-out{z-index:1}.owl-carousel .fadeOut{animation-name:fadeOut}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.owl-height{transition:height .5s ease-in-out}.owl-carousel .owl-item .owl-lazy{opacity:0;transition:opacity .4s}.owl-carousel .owl-item .owl-lazy:not([src]),.owl-carousel .owl-item .owl-lazy[src^=""]{max-height:0}.owl-carousel .owl-item img.owl-lazy{transform-style:preserve-3d}.owl-carousel .owl-video-wrapper{height:100%;background:#000;position:relative}.owl-carousel .owl-video-play-icon{height:80px;width:80px;cursor:pointer;z-index:1;-webkit-backface-visibility:hidden;background:url(owl.video.play.e7a23fb2.png) no-repeat;margin-top:-40px;margin-left:-40px;transition:transform .1s;position:absolute;top:50%;left:50%}.owl-carousel .owl-video-play-icon:hover{-ms-transform:scale(1.3);transform:scale(1.3)}.owl-carousel .owl-video-playing .owl-video-play-icon,.owl-carousel .owl-video-playing .owl-video-tn{display:none}.owl-carousel .owl-video-tn{opacity:0;height:100%;background-position:50%;background-repeat:no-repeat;background-size:contain;transition:opacity .4s}.owl-carousel .owl-video-frame{z-index:1;height:100%;width:100%;position:relative}.owl-theme .owl-dots,.owl-theme .owl-nav{text-align:center;-webkit-tap-highlight-color:transparent}.owl-theme .owl-nav{margin-top:10px}.owl-theme .owl-nav [class*=owl-]{color:#fff;cursor:pointer;background:#d6d6d6;border-radius:3px;margin:5px;padding:4px 7px;font-size:14px;display:inline-block}.owl-theme .owl-nav [class*=owl-]:hover{color:#fff;background:#869791;text-decoration:none}.owl-theme .owl-nav .disabled{opacity:.5;cursor:default}.owl-theme .owl-nav.disabled+.owl-dots{margin-top:10px}.owl-theme .owl-dots .owl-dot{zoom:1;display:inline-block}.owl-theme .owl-dots .owl-dot span{width:10px;height:10px;-webkit-backface-visibility:visible;background:#d6d6d6;border-radius:30px;margin:5px 7px;transition:opacity .2s;display:block}.owl-theme .owl-dots .owl-dot.active span,.owl-theme .owl-dots .owl-dot:hover span{background:#869791}.toast-title{font-weight:700}.toast-message{-ms-word-wrap:break-word;word-wrap:break-word}.toast-message a,.toast-message label{color:#fff}.toast-message a:hover{color:#ccc;text-decoration:none}.toast-close-button{float:right;color:#fff;-webkit-text-shadow:0 1px 0 #fff;text-shadow:0 1px #fff;opacity:.8;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=80);filter:alpha(opacity=80);font-size:20px;font-weight:700;line-height:1;position:relative;top:-.3em;right:-.3em}.toast-close-button:focus,.toast-close-button:hover{color:#000;cursor:pointer;opacity:.4;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=40);filter:alpha(opacity=40);text-decoration:none}.rtl .toast-close-button{float:left;left:-.3em;right:.3em}button.toast-close-button{cursor:pointer;-webkit-appearance:none;background:0 0;border:0;padding:0}.toast-top-center{width:100%;top:0;right:0}.toast-bottom-center{width:100%;bottom:0;right:0}.toast-top-full-width{width:100%;top:0;right:0}.toast-bottom-full-width{width:100%;bottom:0;right:0}.toast-top-left{top:12px;left:12px}.toast-top-right{top:12px;right:12px}.toast-bottom-right{bottom:12px;right:12px}.toast-bottom-left{bottom:12px;left:12px}#toast-container{z-index:999999;pointer-events:none;position:fixed}#toast-container *{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}#toast-container>div{pointer-events:auto;width:300px;color:#fff;opacity:.8;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=80);filter:alpha(opacity=80);background-position:15px;background-repeat:no-repeat;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px;margin:0 0 6px;padding:15px 15px 15px 50px;position:relative;overflow:hidden;-webkit-box-shadow:0 0 12px #999;-moz-box-shadow:0 0 12px #999;box-shadow:0 0 12px #999}#toast-container>div.rtl{direction:rtl;background-position:right 15px center;padding:15px 50px 15px 15px}#toast-container>div:hover{opacity:1;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=100);filter:alpha(opacity=100);cursor:pointer;-webkit-box-shadow:0 0 12px #000;-moz-box-shadow:0 0 12px #000;box-shadow:0 0 12px #000}#toast-container>.toast-info{background-image:url()!important}#toast-container>.toast-error{background-image:url()!important}#toast-container>.toast-success{background-image:url()!important}#toast-container>.toast-warning{background-image:url()!important}#toast-container.toast-bottom-center>div,#toast-container.toast-top-center>div{width:300px;margin-left:auto;margin-right:auto}#toast-container.toast-bottom-full-width>div,#toast-container.toast-top-full-width>div{width:96%;margin-left:auto;margin-right:auto}.toast{background-color:#030303}.toast-success{background-color:#51a351}.toast-error{background-color:#bd362f}.toast-info{background-color:#2f96b4}.toast-warning{background-color:#f89406}.toast-progress{height:4px;opacity:.4;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=40);filter:alpha(opacity=40);background-color:#000;position:absolute;bottom:0;left:0}@media (max-width:240px){#toast-container>div{width:11em;padding:8px 8px 8px 50px}#toast-container>div.rtl{padding:8px 50px 8px 8px}#toast-container .toast-close-button{top:-.2em;right:-.2em}#toast-container .rtl .toast-close-button{left:-.2em;right:.2em}}@media (min-width:241px) and (max-width:480px){#toast-container>div{width:18em;padding:8px 8px 8px 50px}#toast-container>div.rtl{padding:8px 50px 8px 8px}#toast-container .toast-close-button{top:-.2em;right:-.2em}#toast-container .rtl .toast-close-button{left:-.2em;right:.2em}}@media (min-width:481px) and (max-width:768px){#toast-container>div{width:25em;padding:15px 15px 15px 50px}#toast-container>div.rtl{padding:15px 50px 15px 15px}}:root{--animate-duration:1s;--animate-delay:1s;--animate-repeat:1}.animate__animated{-webkit-animation-duration:1s;animation-duration:1s;-webkit-animation-duration:var(--animate-duration);animation-duration:var(--animate-duration);-webkit-animation-fill-mode:both;animation-fill-mode:both}.animate__animated.animate__infinite{-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite}.animate__animated.animate__repeat-1{-webkit-animation-iteration-count:1;animation-iteration-count:1;-webkit-animation-iteration-count:var(--animate-repeat);animation-iteration-count:var(--animate-repeat)}.animate__animated.animate__repeat-2{-webkit-animation-iteration-count:2;animation-iteration-count:2;-webkit-animation-iteration-count:calc(var(--animate-repeat)*2);animation-iteration-count:calc(var(--animate-repeat)*2)}.animate__animated.animate__repeat-3{-webkit-animation-iteration-count:3;animation-iteration-count:3;-webkit-animation-iteration-count:calc(var(--animate-repeat)*3);animation-iteration-count:calc(var(--animate-repeat)*3)}.animate__animated.animate__delay-1s{-webkit-animation-delay:1s;animation-delay:1s;-webkit-animation-delay:var(--animate-delay);animation-delay:var(--animate-delay)}.animate__animated.animate__delay-2s{-webkit-animation-delay:2s;animation-delay:2s;-webkit-animation-delay:calc(var(--animate-delay)*2);animation-delay:calc(var(--animate-delay)*2)}.animate__animated.animate__delay-3s{-webkit-animation-delay:3s;animation-delay:3s;-webkit-animation-delay:calc(var(--animate-delay)*3);animation-delay:calc(var(--animate-delay)*3)}.animate__animated.animate__delay-4s{-webkit-animation-delay:4s;animation-delay:4s;-webkit-animation-delay:calc(var(--animate-delay)*4);animation-delay:calc(var(--animate-delay)*4)}.animate__animated.animate__delay-5s{-webkit-animation-delay:5s;animation-delay:5s;-webkit-animation-delay:calc(var(--animate-delay)*5);animation-delay:calc(var(--animate-delay)*5)}.animate__animated.animate__faster{-webkit-animation-duration:.5s;animation-duration:.5s;-webkit-animation-duration:calc(var(--animate-duration)/2);animation-duration:calc(var(--animate-duration)/2)}.animate__animated.animate__fast{-webkit-animation-duration:.8s;animation-duration:.8s;-webkit-animation-duration:calc(var(--animate-duration)*.8);animation-duration:calc(var(--animate-duration)*.8)}.animate__animated.animate__slow{-webkit-animation-duration:2s;animation-duration:2s;-webkit-animation-duration:calc(var(--animate-duration)*2);animation-duration:calc(var(--animate-duration)*2)}.animate__animated.animate__slower{-webkit-animation-duration:3s;animation-duration:3s;-webkit-animation-duration:calc(var(--animate-duration)*3);animation-duration:calc(var(--animate-duration)*3)}@media (prefers-reduced-motion:reduce),print{.animate__animated{-webkit-transition-duration:1ms!important;transition-duration:1ms!important;-webkit-animation-duration:1ms!important;animation-duration:1ms!important;-webkit-animation-iteration-count:1!important;animation-iteration-count:1!important}.animate__animated[class*=Out]{opacity:0}}@-webkit-keyframes bounce{0%,20%,53%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1);animation-timing-function:cubic-bezier(.215,.61,.355,1);-webkit-transform:translateZ(0);transform:translateZ(0)}40%,43%{-webkit-animation-timing-function:cubic-bezier(.755,.05,.855,.06);animation-timing-function:cubic-bezier(.755,.05,.855,.06);-webkit-transform:matrix(1,0,0,1.1,0,-30);transform:matrix(1,0,0,1.1,0,-30)}70%{-webkit-animation-timing-function:cubic-bezier(.755,.05,.855,.06);animation-timing-function:cubic-bezier(.755,.05,.855,.06);-webkit-transform:matrix(1,0,0,1.05,0,-15);transform:matrix(1,0,0,1.05,0,-15)}80%{-webkit-transition-timing-function:cubic-bezier(.215,.61,.355,1);transition-timing-function:cubic-bezier(.215,.61,.355,1);-webkit-transform:scaleY(.95);transform:scaleY(.95)}90%{-webkit-transform:matrix(1,0,0,1.02,0,-4);transform:matrix(1,0,0,1.02,0,-4)}}@keyframes bounce{0%,20%,53%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1);animation-timing-function:cubic-bezier(.215,.61,.355,1);-webkit-transform:translateZ(0);transform:translateZ(0)}40%,43%{-webkit-animation-timing-function:cubic-bezier(.755,.05,.855,.06);animation-timing-function:cubic-bezier(.755,.05,.855,.06);-webkit-transform:matrix(1,0,0,1.1,0,-30);transform:matrix(1,0,0,1.1,0,-30)}70%{-webkit-animation-timing-function:cubic-bezier(.755,.05,.855,.06);animation-timing-function:cubic-bezier(.755,.05,.855,.06);-webkit-transform:matrix(1,0,0,1.05,0,-15);transform:matrix(1,0,0,1.05,0,-15)}80%{-webkit-transition-timing-function:cubic-bezier(.215,.61,.355,1);transition-timing-function:cubic-bezier(.215,.61,.355,1);-webkit-transform:scaleY(.95);transform:scaleY(.95)}90%{-webkit-transform:matrix(1,0,0,1.02,0,-4);transform:matrix(1,0,0,1.02,0,-4)}}.animate__bounce{-webkit-transform-origin:bottom;transform-origin:bottom;-webkit-animation-name:bounce;animation-name:bounce}@-webkit-keyframes flash{0%,50%,to{opacity:1}25%,75%{opacity:0}}@keyframes flash{0%,50%,to{opacity:1}25%,75%{opacity:0}}.animate__flash{-webkit-animation-name:flash;animation-name:flash}@-webkit-keyframes pulse{0%{-webkit-transform:scaleX(1);transform:scaleX(1)}50%{-webkit-transform:scale3d(1.05,1.05,1.05);transform:scale3d(1.05,1.05,1.05)}to{-webkit-transform:scaleX(1);transform:scaleX(1)}}@keyframes pulse{0%{-webkit-transform:scaleX(1);transform:scaleX(1)}50%{-webkit-transform:scale3d(1.05,1.05,1.05);transform:scale3d(1.05,1.05,1.05)}to{-webkit-transform:scaleX(1);transform:scaleX(1)}}.animate__pulse{-webkit-animation-name:pulse;animation-name:pulse;-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}@-webkit-keyframes rubberBand{0%{-webkit-transform:scaleX(1);transform:scaleX(1)}30%{-webkit-transform:scale(1.25,.75);transform:scale(1.25,.75)}40%{-webkit-transform:scale(.75,1.25);transform:scale(.75,1.25)}50%{-webkit-transform:scale(1.15,.85);transform:scale(1.15,.85)}65%{-webkit-transform:scale(.95,1.05);transform:scale(.95,1.05)}75%{-webkit-transform:scale(1.05,.95);transform:scale(1.05,.95)}to{-webkit-transform:scaleX(1);transform:scaleX(1)}}@keyframes rubberBand{0%{-webkit-transform:scaleX(1);transform:scaleX(1)}30%{-webkit-transform:scale(1.25,.75);transform:scale(1.25,.75)}40%{-webkit-transform:scale(.75,1.25);transform:scale(.75,1.25)}50%{-webkit-transform:scale(1.15,.85);transform:scale(1.15,.85)}65%{-webkit-transform:scale(.95,1.05);transform:scale(.95,1.05)}75%{-webkit-transform:scale(1.05,.95);transform:scale(1.05,.95)}to{-webkit-transform:scaleX(1);transform:scaleX(1)}}.animate__rubberBand{-webkit-animation-name:rubberBand;animation-name:rubberBand}@-webkit-keyframes shakeX{0%,to{-webkit-transform:translateZ(0);transform:translateZ(0)}10%,30%,50%,70%,90%{-webkit-transform:translate(-10px);transform:translate(-10px)}20%,40%,60%,80%{-webkit-transform:translate(10px);transform:translate(10px)}}@keyframes shakeX{0%,to{-webkit-transform:translateZ(0);transform:translateZ(0)}10%,30%,50%,70%,90%{-webkit-transform:translate(-10px);transform:translate(-10px)}20%,40%,60%,80%{-webkit-transform:translate(10px);transform:translate(10px)}}.animate__shakeX{-webkit-animation-name:shakeX;animation-name:shakeX}@-webkit-keyframes shakeY{0%,to{-webkit-transform:translateZ(0);transform:translateZ(0)}10%,30%,50%,70%,90%{-webkit-transform:translateY(-10px);transform:translateY(-10px)}20%,40%,60%,80%{-webkit-transform:translateY(10px);transform:translateY(10px)}}@keyframes shakeY{0%,to{-webkit-transform:translateZ(0);transform:translateZ(0)}10%,30%,50%,70%,90%{-webkit-transform:translateY(-10px);transform:translateY(-10px)}20%,40%,60%,80%{-webkit-transform:translateY(10px);transform:translateY(10px)}}.animate__shakeY{-webkit-animation-name:shakeY;animation-name:shakeY}@-webkit-keyframes headShake{0%{-webkit-transform:translate(0);transform:translate(0)}6.5%{-webkit-transform:translate(-6px)rotateY(-9deg);transform:translate(-6px)rotateY(-9deg)}18.5%{-webkit-transform:translate(5px)rotateY(7deg);transform:translate(5px)rotateY(7deg)}31.5%{-webkit-transform:translate(-3px)rotateY(-5deg);transform:translate(-3px)rotateY(-5deg)}43.5%{-webkit-transform:translate(2px)rotateY(3deg);transform:translate(2px)rotateY(3deg)}50%{-webkit-transform:translate(0);transform:translate(0)}}@keyframes headShake{0%{-webkit-transform:translate(0);transform:translate(0)}6.5%{-webkit-transform:translate(-6px)rotateY(-9deg);transform:translate(-6px)rotateY(-9deg)}18.5%{-webkit-transform:translate(5px)rotateY(7deg);transform:translate(5px)rotateY(7deg)}31.5%{-webkit-transform:translate(-3px)rotateY(-5deg);transform:translate(-3px)rotateY(-5deg)}43.5%{-webkit-transform:translate(2px)rotateY(3deg);transform:translate(2px)rotateY(3deg)}50%{-webkit-transform:translate(0);transform:translate(0)}}.animate__headShake{-webkit-animation-name:headShake;animation-name:headShake;-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}@-webkit-keyframes swing{20%{-webkit-transform:rotate(15deg);transform:rotate(15deg)}40%{-webkit-transform:rotate(-10deg);transform:rotate(-10deg)}60%{-webkit-transform:rotate(5deg);transform:rotate(5deg)}80%{-webkit-transform:rotate(-5deg);transform:rotate(-5deg)}to{-webkit-transform:rotate(0deg);transform:rotate(0deg)}}@keyframes swing{20%{-webkit-transform:rotate(15deg);transform:rotate(15deg)}40%{-webkit-transform:rotate(-10deg);transform:rotate(-10deg)}60%{-webkit-transform:rotate(5deg);transform:rotate(5deg)}80%{-webkit-transform:rotate(-5deg);transform:rotate(-5deg)}to{-webkit-transform:rotate(0deg);transform:rotate(0deg)}}.animate__swing{-webkit-transform-origin:top;transform-origin:top;-webkit-animation-name:swing;animation-name:swing}@-webkit-keyframes tada{0%{-webkit-transform:scaleX(1);transform:scaleX(1)}10%,20%{-webkit-transform:scale3d(.9,.9,.9)rotate(-3deg);transform:scale3d(.9,.9,.9)rotate(-3deg)}30%,50%,70%,90%{-webkit-transform:scale3d(1.1,1.1,1.1)rotate(3deg);transform:scale3d(1.1,1.1,1.1)rotate(3deg)}40%,60%,80%{-webkit-transform:scale3d(1.1,1.1,1.1)rotate(-3deg);transform:scale3d(1.1,1.1,1.1)rotate(-3deg)}to{-webkit-transform:scaleX(1);transform:scaleX(1)}}@keyframes tada{0%{-webkit-transform:scaleX(1);transform:scaleX(1)}10%,20%{-webkit-transform:scale3d(.9,.9,.9)rotate(-3deg);transform:scale3d(.9,.9,.9)rotate(-3deg)}30%,50%,70%,90%{-webkit-transform:scale3d(1.1,1.1,1.1)rotate(3deg);transform:scale3d(1.1,1.1,1.1)rotate(3deg)}40%,60%,80%{-webkit-transform:scale3d(1.1,1.1,1.1)rotate(-3deg);transform:scale3d(1.1,1.1,1.1)rotate(-3deg)}to{-webkit-transform:scaleX(1);transform:scaleX(1)}}.animate__tada{-webkit-animation-name:tada;animation-name:tada}@-webkit-keyframes wobble{0%{-webkit-transform:translateZ(0);transform:translateZ(0)}15%{-webkit-transform:translate(-25%)rotate(-5deg);transform:translate(-25%)rotate(-5deg)}30%{-webkit-transform:translate(20%)rotate(3deg);transform:translate(20%)rotate(3deg)}45%{-webkit-transform:translate(-15%)rotate(-3deg);transform:translate(-15%)rotate(-3deg)}60%{-webkit-transform:translate(10%)rotate(2deg);transform:translate(10%)rotate(2deg)}75%{-webkit-transform:translate(-5%)rotate(-1deg);transform:translate(-5%)rotate(-1deg)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes wobble{0%{-webkit-transform:translateZ(0);transform:translateZ(0)}15%{-webkit-transform:translate(-25%)rotate(-5deg);transform:translate(-25%)rotate(-5deg)}30%{-webkit-transform:translate(20%)rotate(3deg);transform:translate(20%)rotate(3deg)}45%{-webkit-transform:translate(-15%)rotate(-3deg);transform:translate(-15%)rotate(-3deg)}60%{-webkit-transform:translate(10%)rotate(2deg);transform:translate(10%)rotate(2deg)}75%{-webkit-transform:translate(-5%)rotate(-1deg);transform:translate(-5%)rotate(-1deg)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__wobble{-webkit-animation-name:wobble;animation-name:wobble}@-webkit-keyframes jello{0%,11.1%,to{-webkit-transform:translateZ(0);transform:translateZ(0)}22.2%{-webkit-transform:skew(-12.5deg)skewY(-12.5deg);transform:skew(-12.5deg)skewY(-12.5deg)}33.3%{-webkit-transform:skew(6.25deg)skewY(6.25deg);transform:skew(6.25deg)skewY(6.25deg)}44.4%{-webkit-transform:skew(-3.125deg)skewY(-3.125deg);transform:skew(-3.125deg)skewY(-3.125deg)}55.5%{-webkit-transform:skew(1.5625deg)skewY(1.5625deg);transform:skew(1.5625deg)skewY(1.5625deg)}66.6%{-webkit-transform:skew(-.78125deg)skewY(-.78125deg);transform:skew(-.78125deg)skewY(-.78125deg)}77.7%{-webkit-transform:skew(.390625deg)skewY(.390625deg);transform:skew(.390625deg)skewY(.390625deg)}88.8%{-webkit-transform:skew(-.195313deg)skewY(-.195313deg);transform:skew(-.195313deg)skewY(-.195313deg)}}@keyframes jello{0%,11.1%,to{-webkit-transform:translateZ(0);transform:translateZ(0)}22.2%{-webkit-transform:skew(-12.5deg)skewY(-12.5deg);transform:skew(-12.5deg)skewY(-12.5deg)}33.3%{-webkit-transform:skew(6.25deg)skewY(6.25deg);transform:skew(6.25deg)skewY(6.25deg)}44.4%{-webkit-transform:skew(-3.125deg)skewY(-3.125deg);transform:skew(-3.125deg)skewY(-3.125deg)}55.5%{-webkit-transform:skew(1.5625deg)skewY(1.5625deg);transform:skew(1.5625deg)skewY(1.5625deg)}66.6%{-webkit-transform:skew(-.78125deg)skewY(-.78125deg);transform:skew(-.78125deg)skewY(-.78125deg)}77.7%{-webkit-transform:skew(.390625deg)skewY(.390625deg);transform:skew(.390625deg)skewY(.390625deg)}88.8%{-webkit-transform:skew(-.195313deg)skewY(-.195313deg);transform:skew(-.195313deg)skewY(-.195313deg)}}.animate__jello{-webkit-transform-origin:50%;transform-origin:50%;-webkit-animation-name:jello;animation-name:jello}@-webkit-keyframes heartBeat{0%{-webkit-transform:scale(1);transform:scale(1)}14%{-webkit-transform:scale(1.3);transform:scale(1.3)}28%{-webkit-transform:scale(1);transform:scale(1)}42%{-webkit-transform:scale(1.3);transform:scale(1.3)}70%{-webkit-transform:scale(1);transform:scale(1)}}@keyframes heartBeat{0%{-webkit-transform:scale(1);transform:scale(1)}14%{-webkit-transform:scale(1.3);transform:scale(1.3)}28%{-webkit-transform:scale(1);transform:scale(1)}42%{-webkit-transform:scale(1.3);transform:scale(1.3)}70%{-webkit-transform:scale(1);transform:scale(1)}}.animate__heartBeat{-webkit-animation-name:heartBeat;animation-name:heartBeat;-webkit-animation-duration:1.3s;animation-duration:1.3s;-webkit-animation-duration:calc(var(--animate-duration)*1.3);animation-duration:calc(var(--animate-duration)*1.3);-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}@-webkit-keyframes backInDown{0%{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,0,-1200);transform:matrix(.7,0,0,.7,0,-1200)}80%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@keyframes backInDown{0%{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,0,-1200);transform:matrix(.7,0,0,.7,0,-1200)}80%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}.animate__backInDown{-webkit-animation-name:backInDown;animation-name:backInDown}@-webkit-keyframes backInLeft{0%{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,-2000,0);transform:matrix(.7,0,0,.7,-2000,0)}80%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@keyframes backInLeft{0%{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,-2000,0);transform:matrix(.7,0,0,.7,-2000,0)}80%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}.animate__backInLeft{-webkit-animation-name:backInLeft;animation-name:backInLeft}@-webkit-keyframes backInRight{0%{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,2000,0);transform:matrix(.7,0,0,.7,2000,0)}80%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@keyframes backInRight{0%{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,2000,0);transform:matrix(.7,0,0,.7,2000,0)}80%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}.animate__backInRight{-webkit-animation-name:backInRight;animation-name:backInRight}@-webkit-keyframes backInUp{0%{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,0,1200);transform:matrix(.7,0,0,.7,0,1200)}80%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@keyframes backInUp{0%{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,0,1200);transform:matrix(.7,0,0,.7,0,1200)}80%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}.animate__backInUp{-webkit-animation-name:backInUp;animation-name:backInUp}@-webkit-keyframes backOutDown{0%{opacity:1;-webkit-transform:scale(1);transform:scale(1)}20%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,0,700);transform:matrix(.7,0,0,.7,0,700)}}@keyframes backOutDown{0%{opacity:1;-webkit-transform:scale(1);transform:scale(1)}20%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,0,700);transform:matrix(.7,0,0,.7,0,700)}}.animate__backOutDown{-webkit-animation-name:backOutDown;animation-name:backOutDown}@-webkit-keyframes backOutLeft{0%{opacity:1;-webkit-transform:scale(1);transform:scale(1)}20%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,-2000,0);transform:matrix(.7,0,0,.7,-2000,0)}}@keyframes backOutLeft{0%{opacity:1;-webkit-transform:scale(1);transform:scale(1)}20%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,-2000,0);transform:matrix(.7,0,0,.7,-2000,0)}}.animate__backOutLeft{-webkit-animation-name:backOutLeft;animation-name:backOutLeft}@-webkit-keyframes backOutRight{0%{opacity:1;-webkit-transform:scale(1);transform:scale(1)}20%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,2000,0);transform:matrix(.7,0,0,.7,2000,0)}}@keyframes backOutRight{0%{opacity:1;-webkit-transform:scale(1);transform:scale(1)}20%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,2000,0);transform:matrix(.7,0,0,.7,2000,0)}}.animate__backOutRight{-webkit-animation-name:backOutRight;animation-name:backOutRight}@-webkit-keyframes backOutUp{0%{opacity:1;-webkit-transform:scale(1);transform:scale(1)}20%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,0,-700);transform:matrix(.7,0,0,.7,0,-700)}}@keyframes backOutUp{0%{opacity:1;-webkit-transform:scale(1);transform:scale(1)}20%{opacity:.7;-webkit-transform:scale(.7);transform:scale(.7)}to{opacity:.7;-webkit-transform:matrix(.7,0,0,.7,0,-700);transform:matrix(.7,0,0,.7,0,-700)}}.animate__backOutUp{-webkit-animation-name:backOutUp;animation-name:backOutUp}@-webkit-keyframes bounceIn{0%,20%,40%,60%,80%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1);animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}20%{-webkit-transform:scale3d(1.1,1.1,1.1);transform:scale3d(1.1,1.1,1.1)}40%{-webkit-transform:scale3d(.9,.9,.9);transform:scale3d(.9,.9,.9)}60%{opacity:1;-webkit-transform:scale3d(1.03,1.03,1.03);transform:scale3d(1.03,1.03,1.03)}80%{-webkit-transform:scale3d(.97,.97,.97);transform:scale3d(.97,.97,.97)}to{opacity:1;-webkit-transform:scaleX(1);transform:scaleX(1)}}@keyframes bounceIn{0%,20%,40%,60%,80%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1);animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}20%{-webkit-transform:scale3d(1.1,1.1,1.1);transform:scale3d(1.1,1.1,1.1)}40%{-webkit-transform:scale3d(.9,.9,.9);transform:scale3d(.9,.9,.9)}60%{opacity:1;-webkit-transform:scale3d(1.03,1.03,1.03);transform:scale3d(1.03,1.03,1.03)}80%{-webkit-transform:scale3d(.97,.97,.97);transform:scale3d(.97,.97,.97)}to{opacity:1;-webkit-transform:scaleX(1);transform:scaleX(1)}}.animate__bounceIn{-webkit-animation-duration:.75s;animation-duration:.75s;-webkit-animation-duration:calc(var(--animate-duration)*.75);animation-duration:calc(var(--animate-duration)*.75);-webkit-animation-name:bounceIn;animation-name:bounceIn}@-webkit-keyframes bounceInDown{0%,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1);animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;-webkit-transform:matrix(1,0,0,3,0,-3000);transform:matrix(1,0,0,3,0,-3000)}60%{opacity:1;-webkit-transform:matrix(1,0,0,.9,0,25);transform:matrix(1,0,0,.9,0,25)}75%{-webkit-transform:matrix(1,0,0,.95,0,-10);transform:matrix(1,0,0,.95,0,-10)}90%{-webkit-transform:matrix(1,0,0,.985,0,5);transform:matrix(1,0,0,.985,0,5)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes bounceInDown{0%,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1);animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;-webkit-transform:matrix(1,0,0,3,0,-3000);transform:matrix(1,0,0,3,0,-3000)}60%{opacity:1;-webkit-transform:matrix(1,0,0,.9,0,25);transform:matrix(1,0,0,.9,0,25)}75%{-webkit-transform:matrix(1,0,0,.95,0,-10);transform:matrix(1,0,0,.95,0,-10)}90%{-webkit-transform:matrix(1,0,0,.985,0,5);transform:matrix(1,0,0,.985,0,5)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__bounceInDown{-webkit-animation-name:bounceInDown;animation-name:bounceInDown}@-webkit-keyframes bounceInLeft{0%,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1);animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;-webkit-transform:matrix(3,0,0,1,-3000,0);transform:matrix(3,0,0,1,-3000,0)}60%{opacity:1;-webkit-transform:translate(25px);transform:translate(25px)}75%{-webkit-transform:matrix(.98,0,0,1,-10,0);transform:matrix(.98,0,0,1,-10,0)}90%{-webkit-transform:matrix(.995,0,0,1,5,0);transform:matrix(.995,0,0,1,5,0)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes bounceInLeft{0%,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1);animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;-webkit-transform:matrix(3,0,0,1,-3000,0);transform:matrix(3,0,0,1,-3000,0)}60%{opacity:1;-webkit-transform:translate(25px);transform:translate(25px)}75%{-webkit-transform:matrix(.98,0,0,1,-10,0);transform:matrix(.98,0,0,1,-10,0)}90%{-webkit-transform:matrix(.995,0,0,1,5,0);transform:matrix(.995,0,0,1,5,0)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__bounceInLeft{-webkit-animation-name:bounceInLeft;animation-name:bounceInLeft}@-webkit-keyframes bounceInRight{0%,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1);animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;-webkit-transform:matrix(3,0,0,1,3000,0);transform:matrix(3,0,0,1,3000,0)}60%{opacity:1;-webkit-transform:translate(-25px);transform:translate(-25px)}75%{-webkit-transform:matrix(.98,0,0,1,10,0);transform:matrix(.98,0,0,1,10,0)}90%{-webkit-transform:matrix(.995,0,0,1,-5,0);transform:matrix(.995,0,0,1,-5,0)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes bounceInRight{0%,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1);animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;-webkit-transform:matrix(3,0,0,1,3000,0);transform:matrix(3,0,0,1,3000,0)}60%{opacity:1;-webkit-transform:translate(-25px);transform:translate(-25px)}75%{-webkit-transform:matrix(.98,0,0,1,10,0);transform:matrix(.98,0,0,1,10,0)}90%{-webkit-transform:matrix(.995,0,0,1,-5,0);transform:matrix(.995,0,0,1,-5,0)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__bounceInRight{-webkit-animation-name:bounceInRight;animation-name:bounceInRight}@-webkit-keyframes bounceInUp{0%,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1);animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;-webkit-transform:matrix(1,0,0,5,0,3000);transform:matrix(1,0,0,5,0,3000)}60%{opacity:1;-webkit-transform:matrix(1,0,0,.9,0,-20);transform:matrix(1,0,0,.9,0,-20)}75%{-webkit-transform:matrix(1,0,0,.95,0,10);transform:matrix(1,0,0,.95,0,10)}90%{-webkit-transform:matrix(1,0,0,.985,0,-5);transform:matrix(1,0,0,.985,0,-5)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes bounceInUp{0%,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1);animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;-webkit-transform:matrix(1,0,0,5,0,3000);transform:matrix(1,0,0,5,0,3000)}60%{opacity:1;-webkit-transform:matrix(1,0,0,.9,0,-20);transform:matrix(1,0,0,.9,0,-20)}75%{-webkit-transform:matrix(1,0,0,.95,0,10);transform:matrix(1,0,0,.95,0,10)}90%{-webkit-transform:matrix(1,0,0,.985,0,-5);transform:matrix(1,0,0,.985,0,-5)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__bounceInUp{-webkit-animation-name:bounceInUp;animation-name:bounceInUp}@-webkit-keyframes bounceOut{20%{-webkit-transform:scale3d(.9,.9,.9);transform:scale3d(.9,.9,.9)}50%,55%{opacity:1;-webkit-transform:scale3d(1.1,1.1,1.1);transform:scale3d(1.1,1.1,1.1)}to{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}}@keyframes bounceOut{20%{-webkit-transform:scale3d(.9,.9,.9);transform:scale3d(.9,.9,.9)}50%,55%{opacity:1;-webkit-transform:scale3d(1.1,1.1,1.1);transform:scale3d(1.1,1.1,1.1)}to{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}}.animate__bounceOut{-webkit-animation-duration:.75s;animation-duration:.75s;-webkit-animation-duration:calc(var(--animate-duration)*.75);animation-duration:calc(var(--animate-duration)*.75);-webkit-animation-name:bounceOut;animation-name:bounceOut}@-webkit-keyframes bounceOutDown{20%{-webkit-transform:matrix(1,0,0,.985,0,10);transform:matrix(1,0,0,.985,0,10)}40%,45%{opacity:1;-webkit-transform:matrix(1,0,0,.9,0,-20);transform:matrix(1,0,0,.9,0,-20)}to{opacity:0;-webkit-transform:matrix(1,0,0,3,0,2000);transform:matrix(1,0,0,3,0,2000)}}@keyframes bounceOutDown{20%{-webkit-transform:matrix(1,0,0,.985,0,10);transform:matrix(1,0,0,.985,0,10)}40%,45%{opacity:1;-webkit-transform:matrix(1,0,0,.9,0,-20);transform:matrix(1,0,0,.9,0,-20)}to{opacity:0;-webkit-transform:matrix(1,0,0,3,0,2000);transform:matrix(1,0,0,3,0,2000)}}.animate__bounceOutDown{-webkit-animation-name:bounceOutDown;animation-name:bounceOutDown}@-webkit-keyframes bounceOutLeft{20%{opacity:1;-webkit-transform:matrix(.9,0,0,1,20,0);transform:matrix(.9,0,0,1,20,0)}to{opacity:0;-webkit-transform:matrix(2,0,0,1,-2000,0);transform:matrix(2,0,0,1,-2000,0)}}@keyframes bounceOutLeft{20%{opacity:1;-webkit-transform:matrix(.9,0,0,1,20,0);transform:matrix(.9,0,0,1,20,0)}to{opacity:0;-webkit-transform:matrix(2,0,0,1,-2000,0);transform:matrix(2,0,0,1,-2000,0)}}.animate__bounceOutLeft{-webkit-animation-name:bounceOutLeft;animation-name:bounceOutLeft}@-webkit-keyframes bounceOutRight{20%{opacity:1;-webkit-transform:matrix(.9,0,0,1,-20,0);transform:matrix(.9,0,0,1,-20,0)}to{opacity:0;-webkit-transform:matrix(2,0,0,1,2000,0);transform:matrix(2,0,0,1,2000,0)}}@keyframes bounceOutRight{20%{opacity:1;-webkit-transform:matrix(.9,0,0,1,-20,0);transform:matrix(.9,0,0,1,-20,0)}to{opacity:0;-webkit-transform:matrix(2,0,0,1,2000,0);transform:matrix(2,0,0,1,2000,0)}}.animate__bounceOutRight{-webkit-animation-name:bounceOutRight;animation-name:bounceOutRight}@-webkit-keyframes bounceOutUp{20%{-webkit-transform:matrix(1,0,0,.985,0,-10);transform:matrix(1,0,0,.985,0,-10)}40%,45%{opacity:1;-webkit-transform:matrix(1,0,0,.9,0,20);transform:matrix(1,0,0,.9,0,20)}to{opacity:0;-webkit-transform:matrix(1,0,0,3,0,-2000);transform:matrix(1,0,0,3,0,-2000)}}@keyframes bounceOutUp{20%{-webkit-transform:matrix(1,0,0,.985,0,-10);transform:matrix(1,0,0,.985,0,-10)}40%,45%{opacity:1;-webkit-transform:matrix(1,0,0,.9,0,20);transform:matrix(1,0,0,.9,0,20)}to{opacity:0;-webkit-transform:matrix(1,0,0,3,0,-2000);transform:matrix(1,0,0,3,0,-2000)}}.animate__bounceOutUp{-webkit-animation-name:bounceOutUp;animation-name:bounceOutUp}@-webkit-keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate__fadeIn{-webkit-animation-name:fadeIn;animation-name:fadeIn}@-webkit-keyframes fadeInDown{0%{opacity:0;-webkit-transform:translateY(-100%);transform:translateY(-100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes fadeInDown{0%{opacity:0;-webkit-transform:translateY(-100%);transform:translateY(-100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__fadeInDown{-webkit-animation-name:fadeInDown;animation-name:fadeInDown}@-webkit-keyframes fadeInDownBig{0%{opacity:0;-webkit-transform:translateY(-2000px);transform:translateY(-2000px)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes fadeInDownBig{0%{opacity:0;-webkit-transform:translateY(-2000px);transform:translateY(-2000px)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__fadeInDownBig{-webkit-animation-name:fadeInDownBig;animation-name:fadeInDownBig}@-webkit-keyframes fadeInLeft{0%{opacity:0;-webkit-transform:translate(-100%);transform:translate(-100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes fadeInLeft{0%{opacity:0;-webkit-transform:translate(-100%);transform:translate(-100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__fadeInLeft{-webkit-animation-name:fadeInLeft;animation-name:fadeInLeft}@-webkit-keyframes fadeInLeftBig{0%{opacity:0;-webkit-transform:translate(-2000px);transform:translate(-2000px)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes fadeInLeftBig{0%{opacity:0;-webkit-transform:translate(-2000px);transform:translate(-2000px)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__fadeInLeftBig{-webkit-animation-name:fadeInLeftBig;animation-name:fadeInLeftBig}@-webkit-keyframes fadeInRight{0%{opacity:0;-webkit-transform:translate(100%);transform:translate(100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes fadeInRight{0%{opacity:0;-webkit-transform:translate(100%);transform:translate(100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__fadeInRight{-webkit-animation-name:fadeInRight;animation-name:fadeInRight}@-webkit-keyframes fadeInRightBig{0%{opacity:0;-webkit-transform:translate(2000px);transform:translate(2000px)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes fadeInRightBig{0%{opacity:0;-webkit-transform:translate(2000px);transform:translate(2000px)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__fadeInRightBig{-webkit-animation-name:fadeInRightBig;animation-name:fadeInRightBig}@-webkit-keyframes fadeInUp{0%{opacity:0;-webkit-transform:translateY(100%);transform:translateY(100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes fadeInUp{0%{opacity:0;-webkit-transform:translateY(100%);transform:translateY(100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__fadeInUp{-webkit-animation-name:fadeInUp;animation-name:fadeInUp}@-webkit-keyframes fadeInUpBig{0%{opacity:0;-webkit-transform:translateY(2000px);transform:translateY(2000px)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes fadeInUpBig{0%{opacity:0;-webkit-transform:translateY(2000px);transform:translateY(2000px)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__fadeInUpBig{-webkit-animation-name:fadeInUpBig;animation-name:fadeInUpBig}@-webkit-keyframes fadeInTopLeft{0%{opacity:0;-webkit-transform:translate(-100%,-100%);transform:translate(-100%,-100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes fadeInTopLeft{0%{opacity:0;-webkit-transform:translate(-100%,-100%);transform:translate(-100%,-100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__fadeInTopLeft{-webkit-animation-name:fadeInTopLeft;animation-name:fadeInTopLeft}@-webkit-keyframes fadeInTopRight{0%{opacity:0;-webkit-transform:translate(100%,-100%);transform:translate(100%,-100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes fadeInTopRight{0%{opacity:0;-webkit-transform:translate(100%,-100%);transform:translate(100%,-100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__fadeInTopRight{-webkit-animation-name:fadeInTopRight;animation-name:fadeInTopRight}@-webkit-keyframes fadeInBottomLeft{0%{opacity:0;-webkit-transform:translate(-100%,100%);transform:translate(-100%,100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes fadeInBottomLeft{0%{opacity:0;-webkit-transform:translate(-100%,100%);transform:translate(-100%,100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__fadeInBottomLeft{-webkit-animation-name:fadeInBottomLeft;animation-name:fadeInBottomLeft}@-webkit-keyframes fadeInBottomRight{0%{opacity:0;-webkit-transform:translate(100%,100%);transform:translate(100%,100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes fadeInBottomRight{0%{opacity:0;-webkit-transform:translate(100%,100%);transform:translate(100%,100%)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__fadeInBottomRight{-webkit-animation-name:fadeInBottomRight;animation-name:fadeInBottomRight}@-webkit-keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.animate__fadeOut{-webkit-animation-name:fadeOut;animation-name:fadeOut}@-webkit-keyframes fadeOutDown{0%{opacity:1}to{opacity:0;-webkit-transform:translateY(100%);transform:translateY(100%)}}@keyframes fadeOutDown{0%{opacity:1}to{opacity:0;-webkit-transform:translateY(100%);transform:translateY(100%)}}.animate__fadeOutDown{-webkit-animation-name:fadeOutDown;animation-name:fadeOutDown}@-webkit-keyframes fadeOutDownBig{0%{opacity:1}to{opacity:0;-webkit-transform:translateY(2000px);transform:translateY(2000px)}}@keyframes fadeOutDownBig{0%{opacity:1}to{opacity:0;-webkit-transform:translateY(2000px);transform:translateY(2000px)}}.animate__fadeOutDownBig{-webkit-animation-name:fadeOutDownBig;animation-name:fadeOutDownBig}@-webkit-keyframes fadeOutLeft{0%{opacity:1}to{opacity:0;-webkit-transform:translate(-100%);transform:translate(-100%)}}@keyframes fadeOutLeft{0%{opacity:1}to{opacity:0;-webkit-transform:translate(-100%);transform:translate(-100%)}}.animate__fadeOutLeft{-webkit-animation-name:fadeOutLeft;animation-name:fadeOutLeft}@-webkit-keyframes fadeOutLeftBig{0%{opacity:1}to{opacity:0;-webkit-transform:translate(-2000px);transform:translate(-2000px)}}@keyframes fadeOutLeftBig{0%{opacity:1}to{opacity:0;-webkit-transform:translate(-2000px);transform:translate(-2000px)}}.animate__fadeOutLeftBig{-webkit-animation-name:fadeOutLeftBig;animation-name:fadeOutLeftBig}@-webkit-keyframes fadeOutRight{0%{opacity:1}to{opacity:0;-webkit-transform:translate(100%);transform:translate(100%)}}@keyframes fadeOutRight{0%{opacity:1}to{opacity:0;-webkit-transform:translate(100%);transform:translate(100%)}}.animate__fadeOutRight{-webkit-animation-name:fadeOutRight;animation-name:fadeOutRight}@-webkit-keyframes fadeOutRightBig{0%{opacity:1}to{opacity:0;-webkit-transform:translate(2000px);transform:translate(2000px)}}@keyframes fadeOutRightBig{0%{opacity:1}to{opacity:0;-webkit-transform:translate(2000px);transform:translate(2000px)}}.animate__fadeOutRightBig{-webkit-animation-name:fadeOutRightBig;animation-name:fadeOutRightBig}@-webkit-keyframes fadeOutUp{0%{opacity:1}to{opacity:0;-webkit-transform:translateY(-100%);transform:translateY(-100%)}}@keyframes fadeOutUp{0%{opacity:1}to{opacity:0;-webkit-transform:translateY(-100%);transform:translateY(-100%)}}.animate__fadeOutUp{-webkit-animation-name:fadeOutUp;animation-name:fadeOutUp}@-webkit-keyframes fadeOutUpBig{0%{opacity:1}to{opacity:0;-webkit-transform:translateY(-2000px);transform:translateY(-2000px)}}@keyframes fadeOutUpBig{0%{opacity:1}to{opacity:0;-webkit-transform:translateY(-2000px);transform:translateY(-2000px)}}.animate__fadeOutUpBig{-webkit-animation-name:fadeOutUpBig;animation-name:fadeOutUpBig}@-webkit-keyframes fadeOutTopLeft{0%{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}to{opacity:0;-webkit-transform:translate(-100%,-100%);transform:translate(-100%,-100%)}}@keyframes fadeOutTopLeft{0%{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}to{opacity:0;-webkit-transform:translate(-100%,-100%);transform:translate(-100%,-100%)}}.animate__fadeOutTopLeft{-webkit-animation-name:fadeOutTopLeft;animation-name:fadeOutTopLeft}@-webkit-keyframes fadeOutTopRight{0%{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}to{opacity:0;-webkit-transform:translate(100%,-100%);transform:translate(100%,-100%)}}@keyframes fadeOutTopRight{0%{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}to{opacity:0;-webkit-transform:translate(100%,-100%);transform:translate(100%,-100%)}}.animate__fadeOutTopRight{-webkit-animation-name:fadeOutTopRight;animation-name:fadeOutTopRight}@-webkit-keyframes fadeOutBottomRight{0%{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}to{opacity:0;-webkit-transform:translate(100%,100%);transform:translate(100%,100%)}}@keyframes fadeOutBottomRight{0%{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}to{opacity:0;-webkit-transform:translate(100%,100%);transform:translate(100%,100%)}}.animate__fadeOutBottomRight{-webkit-animation-name:fadeOutBottomRight;animation-name:fadeOutBottomRight}@-webkit-keyframes fadeOutBottomLeft{0%{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}to{opacity:0;-webkit-transform:translate(-100%,100%);transform:translate(-100%,100%)}}@keyframes fadeOutBottomLeft{0%{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}to{opacity:0;-webkit-transform:translate(-100%,100%);transform:translate(-100%,100%)}}.animate__fadeOutBottomLeft{-webkit-animation-name:fadeOutBottomLeft;animation-name:fadeOutBottomLeft}@-webkit-keyframes flip{0%{-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out;-webkit-transform:perspective(400px)scaleX(1)translateZ(0)rotateY(-1turn);transform:perspective(400px)scaleX(1)translateZ(0)rotateY(-1turn)}40%{-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out;-webkit-transform:perspective(400px)scaleX(1)translateZ(150px)rotateY(-190deg);transform:perspective(400px)scaleX(1)translateZ(150px)rotateY(-190deg)}50%{-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;-webkit-transform:perspective(400px)scaleX(1)translateZ(150px)rotateY(-170deg);transform:perspective(400px)scaleX(1)translateZ(150px)rotateY(-170deg)}80%{-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;-webkit-transform:matrix3d(.95,0,0,0,0,.95,0,0,0,0,.95,-.002375,0,0,0,1);transform:matrix3d(.95,0,0,0,0,.95,0,0,0,0,.95,-.002375,0,0,0,1)}to{-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;-webkit-transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,-.0025,0,0,0,1);transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,-.0025,0,0,0,1)}}@keyframes flip{0%{-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out;-webkit-transform:perspective(400px)scaleX(1)translateZ(0)rotateY(-1turn);transform:perspective(400px)scaleX(1)translateZ(0)rotateY(-1turn)}40%{-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out;-webkit-transform:perspective(400px)scaleX(1)translateZ(150px)rotateY(-190deg);transform:perspective(400px)scaleX(1)translateZ(150px)rotateY(-190deg)}50%{-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;-webkit-transform:perspective(400px)scaleX(1)translateZ(150px)rotateY(-170deg);transform:perspective(400px)scaleX(1)translateZ(150px)rotateY(-170deg)}80%{-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;-webkit-transform:matrix3d(.95,0,0,0,0,.95,0,0,0,0,.95,-.002375,0,0,0,1);transform:matrix3d(.95,0,0,0,0,.95,0,0,0,0,.95,-.002375,0,0,0,1)}to{-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;-webkit-transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,-.0025,0,0,0,1);transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,-.0025,0,0,0,1)}}.animate__animated.animate__flip{-webkit-backface-visibility:visible;backface-visibility:visible;-webkit-animation-name:flip;animation-name:flip}@-webkit-keyframes flipInX{0%{opacity:0;-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;-webkit-transform:perspective(400px)rotateX(90deg);transform:perspective(400px)rotateX(90deg)}40%{-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;-webkit-transform:perspective(400px)rotateX(-20deg);transform:perspective(400px)rotateX(-20deg)}60%{opacity:1;-webkit-transform:perspective(400px)rotateX(10deg);transform:perspective(400px)rotateX(10deg)}80%{-webkit-transform:perspective(400px)rotateX(-5deg);transform:perspective(400px)rotateX(-5deg)}to{-webkit-transform:perspective(400px);transform:perspective(400px)}}@keyframes flipInX{0%{opacity:0;-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;-webkit-transform:perspective(400px)rotateX(90deg);transform:perspective(400px)rotateX(90deg)}40%{-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;-webkit-transform:perspective(400px)rotateX(-20deg);transform:perspective(400px)rotateX(-20deg)}60%{opacity:1;-webkit-transform:perspective(400px)rotateX(10deg);transform:perspective(400px)rotateX(10deg)}80%{-webkit-transform:perspective(400px)rotateX(-5deg);transform:perspective(400px)rotateX(-5deg)}to{-webkit-transform:perspective(400px);transform:perspective(400px)}}.animate__flipInX{-webkit-animation-name:flipInX;animation-name:flipInX;-webkit-backface-visibility:visible!important;backface-visibility:visible!important}@-webkit-keyframes flipInY{0%{opacity:0;-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;-webkit-transform:perspective(400px)rotateY(90deg);transform:perspective(400px)rotateY(90deg)}40%{-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;-webkit-transform:perspective(400px)rotateY(-20deg);transform:perspective(400px)rotateY(-20deg)}60%{opacity:1;-webkit-transform:perspective(400px)rotateY(10deg);transform:perspective(400px)rotateY(10deg)}80%{-webkit-transform:perspective(400px)rotateY(-5deg);transform:perspective(400px)rotateY(-5deg)}to{-webkit-transform:perspective(400px);transform:perspective(400px)}}@keyframes flipInY{0%{opacity:0;-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;-webkit-transform:perspective(400px)rotateY(90deg);transform:perspective(400px)rotateY(90deg)}40%{-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;-webkit-transform:perspective(400px)rotateY(-20deg);transform:perspective(400px)rotateY(-20deg)}60%{opacity:1;-webkit-transform:perspective(400px)rotateY(10deg);transform:perspective(400px)rotateY(10deg)}80%{-webkit-transform:perspective(400px)rotateY(-5deg);transform:perspective(400px)rotateY(-5deg)}to{-webkit-transform:perspective(400px);transform:perspective(400px)}}.animate__flipInY{-webkit-animation-name:flipInY;animation-name:flipInY;-webkit-backface-visibility:visible!important;backface-visibility:visible!important}@-webkit-keyframes flipOutX{0%{-webkit-transform:perspective(400px);transform:perspective(400px)}30%{opacity:1;-webkit-transform:perspective(400px)rotateX(-20deg);transform:perspective(400px)rotateX(-20deg)}to{opacity:0;-webkit-transform:perspective(400px)rotateX(90deg);transform:perspective(400px)rotateX(90deg)}}@keyframes flipOutX{0%{-webkit-transform:perspective(400px);transform:perspective(400px)}30%{opacity:1;-webkit-transform:perspective(400px)rotateX(-20deg);transform:perspective(400px)rotateX(-20deg)}to{opacity:0;-webkit-transform:perspective(400px)rotateX(90deg);transform:perspective(400px)rotateX(90deg)}}.animate__flipOutX{-webkit-animation-duration:.75s;animation-duration:.75s;-webkit-animation-duration:calc(var(--animate-duration)*.75);animation-duration:calc(var(--animate-duration)*.75);-webkit-animation-name:flipOutX;animation-name:flipOutX;-webkit-backface-visibility:visible!important;backface-visibility:visible!important}@-webkit-keyframes flipOutY{0%{-webkit-transform:perspective(400px);transform:perspective(400px)}30%{opacity:1;-webkit-transform:perspective(400px)rotateY(-15deg);transform:perspective(400px)rotateY(-15deg)}to{opacity:0;-webkit-transform:perspective(400px)rotateY(90deg);transform:perspective(400px)rotateY(90deg)}}@keyframes flipOutY{0%{-webkit-transform:perspective(400px);transform:perspective(400px)}30%{opacity:1;-webkit-transform:perspective(400px)rotateY(-15deg);transform:perspective(400px)rotateY(-15deg)}to{opacity:0;-webkit-transform:perspective(400px)rotateY(90deg);transform:perspective(400px)rotateY(90deg)}}.animate__flipOutY{-webkit-animation-duration:.75s;animation-duration:.75s;-webkit-animation-duration:calc(var(--animate-duration)*.75);animation-duration:calc(var(--animate-duration)*.75);-webkit-animation-name:flipOutY;animation-name:flipOutY;-webkit-backface-visibility:visible!important;backface-visibility:visible!important}@-webkit-keyframes lightSpeedInRight{0%{opacity:0;-webkit-transform:translate(100%)skew(-30deg);transform:translate(100%)skew(-30deg)}60%{opacity:1;-webkit-transform:skew(20deg);transform:skew(20deg)}80%{-webkit-transform:skew(-5deg);transform:skew(-5deg)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes lightSpeedInRight{0%{opacity:0;-webkit-transform:translate(100%)skew(-30deg);transform:translate(100%)skew(-30deg)}60%{opacity:1;-webkit-transform:skew(20deg);transform:skew(20deg)}80%{-webkit-transform:skew(-5deg);transform:skew(-5deg)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__lightSpeedInRight{-webkit-animation-name:lightSpeedInRight;animation-name:lightSpeedInRight;-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out}@-webkit-keyframes lightSpeedInLeft{0%{opacity:0;-webkit-transform:translate(-100%)skew(30deg);transform:translate(-100%)skew(30deg)}60%{opacity:1;-webkit-transform:skew(-20deg);transform:skew(-20deg)}80%{-webkit-transform:skew(5deg);transform:skew(5deg)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes lightSpeedInLeft{0%{opacity:0;-webkit-transform:translate(-100%)skew(30deg);transform:translate(-100%)skew(30deg)}60%{opacity:1;-webkit-transform:skew(-20deg);transform:skew(-20deg)}80%{-webkit-transform:skew(5deg);transform:skew(5deg)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__lightSpeedInLeft{-webkit-animation-name:lightSpeedInLeft;animation-name:lightSpeedInLeft;-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out}@-webkit-keyframes lightSpeedOutRight{0%{opacity:1}to{opacity:0;-webkit-transform:translate(100%)skew(30deg);transform:translate(100%)skew(30deg)}}@keyframes lightSpeedOutRight{0%{opacity:1}to{opacity:0;-webkit-transform:translate(100%)skew(30deg);transform:translate(100%)skew(30deg)}}.animate__lightSpeedOutRight{-webkit-animation-name:lightSpeedOutRight;animation-name:lightSpeedOutRight;-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in}@-webkit-keyframes lightSpeedOutLeft{0%{opacity:1}to{opacity:0;-webkit-transform:translate(-100%)skew(-30deg);transform:translate(-100%)skew(-30deg)}}@keyframes lightSpeedOutLeft{0%{opacity:1}to{opacity:0;-webkit-transform:translate(-100%)skew(-30deg);transform:translate(-100%)skew(-30deg)}}.animate__lightSpeedOutLeft{-webkit-animation-name:lightSpeedOutLeft;animation-name:lightSpeedOutLeft;-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in}@-webkit-keyframes rotateIn{0%{opacity:0;-webkit-transform:rotate(-200deg);transform:rotate(-200deg)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes rotateIn{0%{opacity:0;-webkit-transform:rotate(-200deg);transform:rotate(-200deg)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__rotateIn{-webkit-transform-origin:50%;transform-origin:50%;-webkit-animation-name:rotateIn;animation-name:rotateIn}@-webkit-keyframes rotateInDownLeft{0%{opacity:0;-webkit-transform:rotate(-45deg);transform:rotate(-45deg)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes rotateInDownLeft{0%{opacity:0;-webkit-transform:rotate(-45deg);transform:rotate(-45deg)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__rotateInDownLeft{-webkit-transform-origin:0 100%;transform-origin:0 100%;-webkit-animation-name:rotateInDownLeft;animation-name:rotateInDownLeft}@-webkit-keyframes rotateInDownRight{0%{opacity:0;-webkit-transform:rotate(45deg);transform:rotate(45deg)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes rotateInDownRight{0%{opacity:0;-webkit-transform:rotate(45deg);transform:rotate(45deg)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__rotateInDownRight{-webkit-transform-origin:100% 100%;transform-origin:100% 100%;-webkit-animation-name:rotateInDownRight;animation-name:rotateInDownRight}@-webkit-keyframes rotateInUpLeft{0%{opacity:0;-webkit-transform:rotate(45deg);transform:rotate(45deg)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes rotateInUpLeft{0%{opacity:0;-webkit-transform:rotate(45deg);transform:rotate(45deg)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__rotateInUpLeft{-webkit-transform-origin:0 100%;transform-origin:0 100%;-webkit-animation-name:rotateInUpLeft;animation-name:rotateInUpLeft}@-webkit-keyframes rotateInUpRight{0%{opacity:0;-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes rotateInUpRight{0%{opacity:0;-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__rotateInUpRight{-webkit-transform-origin:100% 100%;transform-origin:100% 100%;-webkit-animation-name:rotateInUpRight;animation-name:rotateInUpRight}@-webkit-keyframes rotateOut{0%{opacity:1}to{opacity:0;-webkit-transform:rotate(200deg);transform:rotate(200deg)}}@keyframes rotateOut{0%{opacity:1}to{opacity:0;-webkit-transform:rotate(200deg);transform:rotate(200deg)}}.animate__rotateOut{-webkit-transform-origin:50%;transform-origin:50%;-webkit-animation-name:rotateOut;animation-name:rotateOut}@-webkit-keyframes rotateOutDownLeft{0%{opacity:1}to{opacity:0;-webkit-transform:rotate(45deg);transform:rotate(45deg)}}@keyframes rotateOutDownLeft{0%{opacity:1}to{opacity:0;-webkit-transform:rotate(45deg);transform:rotate(45deg)}}.animate__rotateOutDownLeft{-webkit-transform-origin:0 100%;transform-origin:0 100%;-webkit-animation-name:rotateOutDownLeft;animation-name:rotateOutDownLeft}@-webkit-keyframes rotateOutDownRight{0%{opacity:1}to{opacity:0;-webkit-transform:rotate(-45deg);transform:rotate(-45deg)}}@keyframes rotateOutDownRight{0%{opacity:1}to{opacity:0;-webkit-transform:rotate(-45deg);transform:rotate(-45deg)}}.animate__rotateOutDownRight{-webkit-transform-origin:100% 100%;transform-origin:100% 100%;-webkit-animation-name:rotateOutDownRight;animation-name:rotateOutDownRight}@-webkit-keyframes rotateOutUpLeft{0%{opacity:1}to{opacity:0;-webkit-transform:rotate(-45deg);transform:rotate(-45deg)}}@keyframes rotateOutUpLeft{0%{opacity:1}to{opacity:0;-webkit-transform:rotate(-45deg);transform:rotate(-45deg)}}.animate__rotateOutUpLeft{-webkit-transform-origin:0 100%;transform-origin:0 100%;-webkit-animation-name:rotateOutUpLeft;animation-name:rotateOutUpLeft}@-webkit-keyframes rotateOutUpRight{0%{opacity:1}to{opacity:0;-webkit-transform:rotate(90deg);transform:rotate(90deg)}}@keyframes rotateOutUpRight{0%{opacity:1}to{opacity:0;-webkit-transform:rotate(90deg);transform:rotate(90deg)}}.animate__rotateOutUpRight{-webkit-transform-origin:100% 100%;transform-origin:100% 100%;-webkit-animation-name:rotateOutUpRight;animation-name:rotateOutUpRight}@-webkit-keyframes hinge{0%{-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}20%,60%{-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out;-webkit-transform:rotate(80deg);transform:rotate(80deg)}40%,80%{opacity:1;-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out;-webkit-transform:rotate(60deg);transform:rotate(60deg)}to{opacity:0;-webkit-transform:translateY(700px);transform:translateY(700px)}}@keyframes hinge{0%{-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}20%,60%{-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out;-webkit-transform:rotate(80deg);transform:rotate(80deg)}40%,80%{opacity:1;-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out;-webkit-transform:rotate(60deg);transform:rotate(60deg)}to{opacity:0;-webkit-transform:translateY(700px);transform:translateY(700px)}}.animate__hinge{-webkit-animation-duration:2s;animation-duration:2s;-webkit-animation-duration:calc(var(--animate-duration)*2);animation-duration:calc(var(--animate-duration)*2);-webkit-transform-origin:0 0;transform-origin:0 0;-webkit-animation-name:hinge;animation-name:hinge}@-webkit-keyframes jackInTheBox{0%{opacity:0;-webkit-transform-origin:bottom;transform-origin:bottom;-webkit-transform:scale(.1)rotate(30deg);transform:scale(.1)rotate(30deg)}50%{-webkit-transform:rotate(-10deg);transform:rotate(-10deg)}70%{-webkit-transform:rotate(3deg);transform:rotate(3deg)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@keyframes jackInTheBox{0%{opacity:0;-webkit-transform-origin:bottom;transform-origin:bottom;-webkit-transform:scale(.1)rotate(30deg);transform:scale(.1)rotate(30deg)}50%{-webkit-transform:rotate(-10deg);transform:rotate(-10deg)}70%{-webkit-transform:rotate(3deg);transform:rotate(3deg)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}.animate__jackInTheBox{-webkit-animation-name:jackInTheBox;animation-name:jackInTheBox}@-webkit-keyframes rollIn{0%{opacity:0;-webkit-transform:translate(-100%)rotate(-120deg);transform:translate(-100%)rotate(-120deg)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes rollIn{0%{opacity:0;-webkit-transform:translate(-100%)rotate(-120deg);transform:translate(-100%)rotate(-120deg)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__rollIn{-webkit-animation-name:rollIn;animation-name:rollIn}@-webkit-keyframes rollOut{0%{opacity:1}to{opacity:0;-webkit-transform:translate(100%)rotate(120deg);transform:translate(100%)rotate(120deg)}}@keyframes rollOut{0%{opacity:1}to{opacity:0;-webkit-transform:translate(100%)rotate(120deg);transform:translate(100%)rotate(120deg)}}.animate__rollOut{-webkit-animation-name:rollOut;animation-name:rollOut}@-webkit-keyframes zoomIn{0%{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes zoomIn{0%{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}50%{opacity:1}}.animate__zoomIn{-webkit-animation-name:zoomIn;animation-name:zoomIn}@-webkit-keyframes zoomInDown{0%{opacity:0;-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19);-webkit-transform:translateY(-100px)scale3d(.1,.1,.1);transform:translateY(-100px)scale3d(.1,.1,.1)}60%{opacity:1;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1);-webkit-transform:scale3d(.475,.475,.475)translateY(60px);transform:scale3d(.475,.475,.475)translateY(60px)}}@keyframes zoomInDown{0%{opacity:0;-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19);-webkit-transform:translateY(-100px)scale3d(.1,.1,.1);transform:translateY(-100px)scale3d(.1,.1,.1)}60%{opacity:1;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1);-webkit-transform:scale3d(.475,.475,.475)translateY(60px);transform:scale3d(.475,.475,.475)translateY(60px)}}.animate__zoomInDown{-webkit-animation-name:zoomInDown;animation-name:zoomInDown}@-webkit-keyframes zoomInLeft{0%{opacity:0;-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19);-webkit-transform:translate(-100px)scale3d(.1,.1,.1);transform:translate(-100px)scale3d(.1,.1,.1)}60%{opacity:1;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1);-webkit-transform:scale3d(.475,.475,.475)translate(10px);transform:scale3d(.475,.475,.475)translate(10px)}}@keyframes zoomInLeft{0%{opacity:0;-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19);-webkit-transform:translate(-100px)scale3d(.1,.1,.1);transform:translate(-100px)scale3d(.1,.1,.1)}60%{opacity:1;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1);-webkit-transform:scale3d(.475,.475,.475)translate(10px);transform:scale3d(.475,.475,.475)translate(10px)}}.animate__zoomInLeft{-webkit-animation-name:zoomInLeft;animation-name:zoomInLeft}@-webkit-keyframes zoomInRight{0%{opacity:0;-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19);-webkit-transform:translate(100px)scale3d(.1,.1,.1);transform:translate(100px)scale3d(.1,.1,.1)}60%{opacity:1;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1);-webkit-transform:scale3d(.475,.475,.475)translate(-10px);transform:scale3d(.475,.475,.475)translate(-10px)}}@keyframes zoomInRight{0%{opacity:0;-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19);-webkit-transform:translate(100px)scale3d(.1,.1,.1);transform:translate(100px)scale3d(.1,.1,.1)}60%{opacity:1;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1);-webkit-transform:scale3d(.475,.475,.475)translate(-10px);transform:scale3d(.475,.475,.475)translate(-10px)}}.animate__zoomInRight{-webkit-animation-name:zoomInRight;animation-name:zoomInRight}@-webkit-keyframes zoomInUp{0%{opacity:0;-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19);-webkit-transform:translateY(100px)scale3d(.1,.1,.1);transform:translateY(100px)scale3d(.1,.1,.1)}60%{opacity:1;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1);-webkit-transform:scale3d(.475,.475,.475)translateY(-60px);transform:scale3d(.475,.475,.475)translateY(-60px)}}@keyframes zoomInUp{0%{opacity:0;-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19);-webkit-transform:translateY(100px)scale3d(.1,.1,.1);transform:translateY(100px)scale3d(.1,.1,.1)}60%{opacity:1;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1);-webkit-transform:scale3d(.475,.475,.475)translateY(-60px);transform:scale3d(.475,.475,.475)translateY(-60px)}}.animate__zoomInUp{-webkit-animation-name:zoomInUp;animation-name:zoomInUp}@-webkit-keyframes zoomOut{0%{opacity:1}50%{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}to{opacity:0}}@keyframes zoomOut{0%{opacity:1}50%{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}to{opacity:0}}.animate__zoomOut{-webkit-animation-name:zoomOut;animation-name:zoomOut}@-webkit-keyframes zoomOutDown{40%{opacity:1;-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19);-webkit-transform:scale3d(.475,.475,.475)translateY(-60px);transform:scale3d(.475,.475,.475)translateY(-60px)}to{opacity:0;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1);-webkit-transform:translateY(200px)scale3d(.1,.1,.1);transform:translateY(200px)scale3d(.1,.1,.1)}}@keyframes zoomOutDown{40%{opacity:1;-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19);-webkit-transform:scale3d(.475,.475,.475)translateY(-60px);transform:scale3d(.475,.475,.475)translateY(-60px)}to{opacity:0;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1);-webkit-transform:translateY(200px)scale3d(.1,.1,.1);transform:translateY(200px)scale3d(.1,.1,.1)}}.animate__zoomOutDown{-webkit-transform-origin:bottom;transform-origin:bottom;-webkit-animation-name:zoomOutDown;animation-name:zoomOutDown}@-webkit-keyframes zoomOutLeft{40%{opacity:1;-webkit-transform:scale3d(.475,.475,.475)translate(42px);transform:scale3d(.475,.475,.475)translate(42px)}to{opacity:0;-webkit-transform:matrix(.1,0,0,.1,-200,0);transform:matrix(.1,0,0,.1,-200,0)}}@keyframes zoomOutLeft{40%{opacity:1;-webkit-transform:scale3d(.475,.475,.475)translate(42px);transform:scale3d(.475,.475,.475)translate(42px)}to{opacity:0;-webkit-transform:matrix(.1,0,0,.1,-200,0);transform:matrix(.1,0,0,.1,-200,0)}}.animate__zoomOutLeft{-webkit-transform-origin:0;transform-origin:0;-webkit-animation-name:zoomOutLeft;animation-name:zoomOutLeft}@-webkit-keyframes zoomOutRight{40%{opacity:1;-webkit-transform:scale3d(.475,.475,.475)translate(-42px);transform:scale3d(.475,.475,.475)translate(-42px)}to{opacity:0;-webkit-transform:matrix(.1,0,0,.1,200,0);transform:matrix(.1,0,0,.1,200,0)}}@keyframes zoomOutRight{40%{opacity:1;-webkit-transform:scale3d(.475,.475,.475)translate(-42px);transform:scale3d(.475,.475,.475)translate(-42px)}to{opacity:0;-webkit-transform:matrix(.1,0,0,.1,200,0);transform:matrix(.1,0,0,.1,200,0)}}.animate__zoomOutRight{-webkit-transform-origin:100%;transform-origin:100%;-webkit-animation-name:zoomOutRight;animation-name:zoomOutRight}@-webkit-keyframes zoomOutUp{40%{opacity:1;-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19);-webkit-transform:scale3d(.475,.475,.475)translateY(60px);transform:scale3d(.475,.475,.475)translateY(60px)}to{opacity:0;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1);-webkit-transform:translateY(-200px)scale3d(.1,.1,.1);transform:translateY(-200px)scale3d(.1,.1,.1)}}@keyframes zoomOutUp{40%{opacity:1;-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19);-webkit-transform:scale3d(.475,.475,.475)translateY(60px);transform:scale3d(.475,.475,.475)translateY(60px)}to{opacity:0;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1);-webkit-transform:translateY(-200px)scale3d(.1,.1,.1);transform:translateY(-200px)scale3d(.1,.1,.1)}}.animate__zoomOutUp{-webkit-transform-origin:bottom;transform-origin:bottom;-webkit-animation-name:zoomOutUp;animation-name:zoomOutUp}@-webkit-keyframes slideInDown{0%{visibility:visible;-webkit-transform:translateY(-100%);transform:translateY(-100%)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes slideInDown{0%{visibility:visible;-webkit-transform:translateY(-100%);transform:translateY(-100%)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__slideInDown{-webkit-animation-name:slideInDown;animation-name:slideInDown}@-webkit-keyframes slideInLeft{0%{visibility:visible;-webkit-transform:translate(-100%);transform:translate(-100%)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes slideInLeft{0%{visibility:visible;-webkit-transform:translate(-100%);transform:translate(-100%)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__slideInLeft{-webkit-animation-name:slideInLeft;animation-name:slideInLeft}@-webkit-keyframes slideInRight{0%{visibility:visible;-webkit-transform:translate(100%);transform:translate(100%)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes slideInRight{0%{visibility:visible;-webkit-transform:translate(100%);transform:translate(100%)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__slideInRight{-webkit-animation-name:slideInRight;animation-name:slideInRight}@-webkit-keyframes slideInUp{0%{visibility:visible;-webkit-transform:translateY(100%);transform:translateY(100%)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes slideInUp{0%{visibility:visible;-webkit-transform:translateY(100%);transform:translateY(100%)}to{-webkit-transform:translateZ(0);transform:translateZ(0)}}.animate__slideInUp{-webkit-animation-name:slideInUp;animation-name:slideInUp}@-webkit-keyframes slideOutDown{0%{-webkit-transform:translateZ(0);transform:translateZ(0)}to{visibility:hidden;-webkit-transform:translateY(100%);transform:translateY(100%)}}@keyframes slideOutDown{0%{-webkit-transform:translateZ(0);transform:translateZ(0)}to{visibility:hidden;-webkit-transform:translateY(100%);transform:translateY(100%)}}.animate__slideOutDown{-webkit-animation-name:slideOutDown;animation-name:slideOutDown}@-webkit-keyframes slideOutLeft{0%{-webkit-transform:translateZ(0);transform:translateZ(0)}to{visibility:hidden;-webkit-transform:translate(-100%);transform:translate(-100%)}}@keyframes slideOutLeft{0%{-webkit-transform:translateZ(0);transform:translateZ(0)}to{visibility:hidden;-webkit-transform:translate(-100%);transform:translate(-100%)}}.animate__slideOutLeft{-webkit-animation-name:slideOutLeft;animation-name:slideOutLeft}@-webkit-keyframes slideOutRight{0%{-webkit-transform:translateZ(0);transform:translateZ(0)}to{visibility:hidden;-webkit-transform:translate(100%);transform:translate(100%)}}@keyframes slideOutRight{0%{-webkit-transform:translateZ(0);transform:translateZ(0)}to{visibility:hidden;-webkit-transform:translate(100%);transform:translate(100%)}}.animate__slideOutRight{-webkit-animation-name:slideOutRight;animation-name:slideOutRight}@-webkit-keyframes slideOutUp{0%{-webkit-transform:translateZ(0);transform:translateZ(0)}to{visibility:hidden;-webkit-transform:translateY(-100%);transform:translateY(-100%)}}@keyframes slideOutUp{0%{-webkit-transform:translateZ(0);transform:translateZ(0)}to{visibility:hidden;-webkit-transform:translateY(-100%);transform:translateY(-100%)}}.animate__slideOutUp{-webkit-animation-name:slideOutUp;animation-name:slideOutUp}code[class*=language-],pre[class*=language-]{color:#000;text-shadow:0 1px #fff;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-hyphens:none;-moz-hyphens:none;-ms-hyphens:none;hyphens:none;background:0 0;font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;font-size:1em;line-height:1.5}pre[class*=language-]::-moz-selection,pre[class*=language-] ::-moz-selection,code[class*=language-]::-moz-selection,code[class*=language-] ::-moz-selection{text-shadow:none;background:#b3d4fc}pre[class*=language-]::selection,pre[class*=language-] ::selection,code[class*=language-]::selection,code[class*=language-] ::selection{text-shadow:none;background:#b3d4fc}@media print{code[class*=language-],pre[class*=language-]{text-shadow:none}}pre[class*=language-]{margin:.5em 0;padding:1em;overflow:auto}:not(pre)>code[class*=language-],pre[class*=language-]{background:#f5f2f0}:not(pre)>code[class*=language-]{white-space:normal;border-radius:.3em;padding:.1em}.token.comment,.token.prolog,.token.doctype,.token.cdata{color:#708090}.token.punctuation{color:#999}.token.namespace{opacity:.7}.token.property,.token.tag,.token.boolean,.token.number,.token.constant,.token.symbol,.token.deleted{color:#905}.token.selector,.token.attr-name,.token.string,.token.char,.token.builtin,.token.inserted{color:#690}.token.operator,.token.entity,.token.url,.language-css .token.string,.style .token.string{color:#9a6e3a;background:#ffffff80}.token.atrule,.token.attr-value,.token.keyword{color:#07a}.token.function,.token.class-name{color:#dd4a68}.token.regex,.token.important,.token.variable{color:#e90}.token.important,.token.bold{font-weight:700}.token.italic{font-style:italic}.token.entity{cursor:help}pre[class*=language-].line-numbers{counter-reset:linenumber;padding-left:3.8em;position:relative}pre[class*=language-].line-numbers>code{white-space:inherit;position:relative}.line-numbers .line-numbers-rows{pointer-events:none;width:3em;letter-spacing:-1px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border-right:1px solid #999;font-size:100%;position:absolute;top:0;left:-3.8em}.line-numbers-rows>span{counter-increment:linenumber;display:block}.line-numbers-rows>span:before{content:counter(linenumber);color:#999;text-align:right;padding-right:.8em;display:block}#vl-menu{z-index:1200;position:relative}.vlmenu,.vlmenu ul{margin:0;padding:0;list-style:none}.vlmenu>li{float:left;padding:0 20px}.vlmenu li li{position:relative}.vlmenu li>a{display:block}.vlmenu a i{padding-right:10px;font-size:10px}.vlmenu .search a i,.vlmenu a i.arrow{padding-right:0}.vlmenu>li>a>i.arrow{margin-top:3px;margin-left:10px}.vlmenu a{color:#222;text-decoration:none}.vlmenu>li>a{padding:20px 0}.vlmenu>li{padding:0 20px}.vlmenu>li>a:hover,.vlmenu>li.active>a{color:#000}.vlmenu ul{width:190px;z-index:1300;display:none;position:absolute}.vlmenu>li.menu-right>ul ul{left:-190px}.vlmenu ul a{color:#222;padding:10px 20px}.vlmenu li:hover>ul{display:block}.vlmenu ul ul{top:0;left:190px}.container-fluid .vlmenu>li.menu-right>ul,.container-fluid .vlmenu>li.menu-right>div{right:0}.vlmenu li a i.arrow{float:right;margin-top:5px}.vlmenu li.search a i.arrow{display:none}.vlmenu ul a:hover,.mega-menu ol li a:hover{background:#ffffff1a}.vlmenu li>div{padding:10px}.mega-menu ol{padding-left:0;list-style:none}.mega-menu ol li a{color:#222;padding:10px 20px}.mega-menu h1,.mega-menu h2,.mega-menu h3,.mega-menu h4,.mega-menu h5,.mega-menu h6,.mega-menu p{padding-left:20px;font-weight:400}.vlmenu .full-nav,.vlmenu .half-nav,.vlmenu .quarter-nav{z-index:1300;display:none;position:absolute}.vlmenu>li:hover>div{display:block}.vlmenu .full-nav{width:100%;left:0;right:0}.vlmenu .half-nav{width:50%;left:auto;right:auto}.vlmenu .quarter-nav{width:25%;left:auto;right:auto}.vlmenu li.menu-right .half-nav{width:50%;left:auto;right:0}.vlmenu li.menu-right .quarter-nav{width:25%;left:auto;right:0}.vlmenu li>div input{box-shadow:none;border:none;border-radius:0}.vlmenu.light-sub-menu input{border:1px solid #ddd}.vlmenu li>div input:focus,.vlmenu.light-sub-menu input:focus{box-shadow:none}.light-sub-menu .mega-menu li a span,.dark-sub-menu .mega-menu li a span{color:#bbb;display:block}.light-sub-menu .mega-menu li a:hover span,.dark-sub-menu .mega-menu li a:hover span{color:#fff}.light-sub-menu .mega-menu li a span,.light-sub-menu .mega-menu li a:hover span,.dark-sub-menu .mega-menu li a span{-webkit-transition:all .3s;-moz-transition:all .3s;transition:all .3s}.vlmenu .col1,.vlmenu .col2,.vlmenu .col3,.vlmenu .col4,.vlmenu .col5,.vlmenu .col6{float:left}.mega-menu .col1{width:100%}.mega-menu .col2{width:50%}.mega-menu .col3{width:33.33%}.mega-menu .col4{width:25%}.mega-menu .col5{width:20%}.mega-menu .col6{width:16.66%}.grid .col1,.grid .col2,.grid .col3,.grid .col4,.grid .col5,.grid .col6{margin-right:1%;padding:5px;display:inline-block}.grid.gray .col1,.grid.gray .col2,.grid.gray .col3,.grid.gray .col4,.grid.gray .col5,.grid.gray .col6{background:#ddd}.grid .mega-menu .col1{width:99%}.grid .mega-menu .col2{width:49%}.grid .mega-menu .col3{width:32.33%}.grid .mega-menu .col4{width:24%}.grid .mega-menu .col5{width:19%}.grid .mega-menu .col6{width:15.66%}.menu-row{width:100%;margin-bottom:10px;margin-left:.5%;display:inline-block}.menu-row:last-child{margin-bottom:0}.dark-sub-menu ul,.dark-sub-menu li>div{background:#222}.dark-sub-menu ul a,.dark-sub-menu li>div a,.dark-sub-menu li>div h1,.dark-sub-menu li>div h2,.dark-sub-menu li>div h3,.dark-sub-menu li>div h4,.dark-sub-menu li>div h5,.dark-sub-menu li>div h6,.dark-sub-menu li>div p{color:#fff}.light-sub-menu ul,.light-sub-menu li>div{background:#fff;box-shadow:0 0 1px #d1d1d1}.light-sub-menu ul a,.light-sub-menu li>div a,.light-sub-menu li>div h1,.light-sub-menu li>div h2,.light-sub-menu li>div h3,.light-sub-menu li>div h4,.light-sub-menu li>div h5,.light-sub-menu li>div h6,.light-sub-menu li>div p{color:#222}.light-sub-menu ul a:hover,.light-sub-menu ol li a:hover{color:#fff}.light-sub-menu ul a:hover,.light-sub-menu ol li a:hover{color:#fff;background:#222}.container header{width:100%;display:inline-block}.container header .vl-logo{margin-left:20px}.container header .nav-btn{margin-right:20px}.container header.float-menu{width:100%;margin-top:50px;display:inline-block}.container header.float-menu .vl-logo{margin-left:20px}.container header.float-menu .nav-btn{margin-right:20px}.center-menu{text-align:center}.center-menu .center-logo,.center-menu .vlmenu{display:inline-block}.center-menu .vlmenu ul,.center-menu .vlmenu li>div{text-align:left!important}.no-bg{background:0 0}.dark-menu{background:#000}.dark-menu a{color:#fff}.menu-bg{background-position:100% 100%!important;background-repeat:no-repeat!important;background-size:auto!important}.grid .mega-menu .col1 img,.grid .mega-menu .col2 img,.grid .mega-menu .col3 img,.grid .mega-menu .col4 img,.grid .mega-menu .col5 img,.grid .mega-menu .col6 img{width:100%;height:auto;margin-bottom:10px}.contact-form{padding:0 20px}.contact-form input,.contact-form textarea{width:100%;height:35px;color:#222;background:#fff;border:1px solid #ddd;margin-bottom:10px;padding-left:10px;padding-right:10px;display:inline-block}input[type=checkbox]{width:auto;height:auto;float:left;margin-right:10px}.contact-form input:focus,.contact-form textarea:focus{outline:0}.contact-form textarea{height:150px}.vl-btn{border:none;padding:10px 20px}@media (max-width:1480px){#blog-menu>ul{right:-100px}}@media (max-width:1024px){.menu,.menu ul,div.mega-menu{display:inline-block;background:#333!important}.mega-menu p{padding-left:40px!important}.vl-logo{margin-top:10px}.vlmenu,.vlmenu ul,div.mega-menu{display:inline-block;background:#333!important}.vlmenu a{color:#fff!important}.vlmenu li{z-index:1300;background:#333;position:relative}.vlmenu>li{width:100%;border-bottom:1px solid #ffffff0d;padding:0;display:block}.vlmenu>li>a,.vlmenu>li>a>i.arrow{line-height:50px}.vlmenu>li>a{padding:0 20px}.vlmenu>li a:hover{background:#111}.vlmenu>li>a>i.arrow{margin-right:0}.vlmenu ul{width:100%;border:none;display:none;position:relative;overflow:hidden}.hidden-sub{display:none!important}.visible-sub{visibility:visible;opacity:1;display:block!important}.vlmenu ul a,.vlmenu li>div,.mega-menu ol li a{padding:10px 20px}.mega-menu ol li a,.vlmenu ul a{border-top:1px solid #ffffff0d}.vlmenu li>div{padding:10px 0}.vlmenu ul ul,.vlmenu>li.menu-right>ul ul{left:0}.vlmenu li li a{padding-left:40px}.vlmenu li li li a{padding-left:60px}.vlmenu li li li li a{padding-left:80px}.vlmenu li li li li li a{padding-left:100px}.vlmenu li li li li li li a{padding-left:120px}.vlmenu .full-nav,.vlmenu .half-nav,.vlmenu .quarter-nav{display:block;position:relative}.vlmenu .col1,.vlmenu .col2,.vlmenu .col3,.vlmenu .col4,.vlmenu .col5,.vlmenu .col6,.mega-menu ol,.grid .col1,.grid .col2,.grid .col3,.grid .col4,.grid .col5,.grid .col6{width:100%!important}.grid .col1,.grid .col2,.grid .col3,.grid .col4,.grid .col5,.grid .col6{margin-bottom:10px;display:inline-block}.vlmenu li>div{border:none}.vlmenu h1,.vlmenu h2,.vlmenu h3,.vlmenu h4,.vlmenu h5,.vlmenu h6{color:#fff;margin:10px 20px}.vlmenu p{color:#fff;padding:10px 20px}.vlmenu ul a:hover,.mega-menu ol li a:hover{color:#fff;background:#111}.mega-menu ol li a{margin-bottom:0}.wrapper,.vlmenu .half-nav,.vlmenu .quarter-nav,.vlmenu li.menu-right .half-nav,.vlmenu li.menu-right .quarter-nav{width:100%}.vlmenu{width:100%;display:none}.light-sub-menu ul a,.light-sub-menu li>div a,.light-sub-menu li>div h1,.light-sub-menu li>div h2,.light-sub-menu li>div h3,.light-sub-menu li>div h4,.light-sub-menu li>div h5,.light-sub-menu li>div h6,.light-sub-menu li>div p,.light-sub-menu li>div span{color:#fff}.light-sub-menu ul,.light-sub-menu li>div{box-shadow:none}.vlmenu ul,.vlmenu li>div{top:auto}.vlmenu>li>a{height:53px;border-radius:0;border:none!important}.vlmenu>li,.menu-row{margin:0}.center-menu .vlmenu ul,.center-menu .vlmenu li>div{top:0}.center-menu{text-align:left}.center-menu .vlmenu{display:none}.nav-btn{float:right;cursor:pointer;margin-top:10px;margin-bottom:10px;margin-right:0;display:block}.nav-btn .bars{vertical-align:bottom;height:2px;width:30px;background-color:#333;display:inline-block;position:relative;top:-5px}.nav-btn .bars:before,.nav-btn .bars:after{content:"";width:30px;height:2px;background-color:#333;display:inline-block;position:absolute;top:-8px}.nav-btn .bars:after{top:8px}#blog-menu>ul{right:0}}.introjs-overlay{box-sizing:content-box;z-index:999999;opacity:0;background-color:#000;background:-moz-radial-gradient( center,ellipse farthest-corner,#0006 0,#000000e6 100% );background:-webkit-gradient( radial,center center,0px,center center,100%,color-stop(0%,#0006),color-stop(100%,#000000e6));background:-webkit-radial-gradient( center,ellipse farthest-corner,#0006 0,#000000e6 100% );background:-o-radial-gradient( center,ellipse farthest-corner,#0006 0,#000000e6 100% );background:-ms-radial-gradient( center,ellipse farthest-corner,#0006 0,#000000e6 100% );background:radial-gradient( center,ellipse farthest-corner,#0006 0,#000000e6 100% );filter:"progid:DXImageTransform.Microsoft.gradient(startColorstr='#66000000',endColorstr='#e6000000',GradientType=1)";-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";filter:alpha(opacity=50);-o-transition:all .3s ease-out;-webkit-transition:all .3s ease-out;-moz-transition:all .3s ease-out;-ms-transition:all .3s ease-out;transition:all .3s ease-out;position:absolute}.introjs-fixParent{z-index:auto!important;opacity:1!important;-webkit-transform:none!important;-moz-transform:none!important;-ms-transform:none!important;-o-transform:none!important;transform:none!important}.introjs-showElement,tr.introjs-showElement>td,tr.introjs-showElement>th{z-index:9999999!important}.introjs-disableInteraction{opacity:0;filter:alpha(opacity=0);background-color:#fff;position:absolute;z-index:99999999!important}.introjs-relativePosition,tr.introjs-showElement>td,tr.introjs-showElement>th{position:relative}.introjs-helperLayer{box-sizing:content-box;z-index:9999998;-o-transition:all .3s ease-out;background-color:#ffffffe6;border:1px solid #00000080;border-radius:4px;-webkit-transition:all .3s ease-out;-moz-transition:all .3s ease-out;-ms-transition:all .3s ease-out;transition:all .3s ease-out;position:absolute;box-shadow:0 2px 15px #0006}.introjs-tooltipReferenceLayer{box-sizing:content-box;visibility:hidden;z-index:100000000;-o-transition:all .3s ease-out;background-color:#0000;-webkit-transition:all .3s ease-out;-moz-transition:all .3s ease-out;-ms-transition:all .3s ease-out;transition:all .3s ease-out;position:absolute}.introjs-helperLayer *,.introjs-helperLayer :before,.introjs-helperLayer :after{-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;-ms-box-sizing:content-box;-o-box-sizing:content-box}.introjs-helperNumberLayer{box-sizing:content-box;visibility:visible;color:#fff;text-align:center;text-shadow:1px 1px 1px #0000004d;background:-moz-linear-gradient(#cf0404 0%,#ff3019 100%);background:-ms-linear-gradient(top,#ff3019 0%,#cf0404 100%);width:20px;height:20px;filter:"progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff3019', endColorstr='#cf0404', GradientType=0)";filter:"progid:DXImageTransform.Microsoft.Shadow(direction=135, strength=2, color=ff0000)";background:-moz-linear-gradient(#cf0404 0%,#ff3019 100%);background:-webkit-linear-gradient(#cf0404 0%,#ff3019 100%);background:-webkit-gradient(linear,0 0,0 100%,from(#ff3019),to(#cf0404));background:-moz-linear-gradient(#cf0404 0%,#ff3019 100%);background:-o-linear-gradient(#cf0404 0%,#ff3019 100%);background:linear-gradient(#ff3019 0%,#cf0404 100%);border:3px solid #fff;border-radius:50%;padding:2px;font-family:Arial,verdana,tahoma;font-size:13px;font-weight:700;line-height:20px;position:absolute;top:-16px;left:-16px;box-shadow:0 2px 5px #0006;z-index:2147483647!important}.introjs-arrow{content:"";border:5px solid #0000;position:absolute}.introjs-arrow.top{border-bottom-color:#fff;top:-10px}.introjs-arrow.top-right{border-bottom-color:#fff;top:-10px;right:10px}.introjs-arrow.top-middle{border-bottom-color:#fff;margin-left:-5px;top:-10px;left:50%}.introjs-arrow.right{border-left-color:#fff;top:10px;right:-10px}.introjs-arrow.right-bottom{border-left-color:#fff;bottom:10px;right:-10px}.introjs-arrow.bottom{border-top-color:#fff;bottom:-10px}.introjs-arrow.bottom-right{border-top-color:#fff;bottom:-10px;right:10px}.introjs-arrow.bottom-middle{border-top-color:#fff;margin-left:-5px;bottom:-10px;left:50%}.introjs-arrow.left{border-right-color:#fff;top:10px;left:-10px}.introjs-arrow.left-bottom{border-right-color:#fff;bottom:10px;left:-10px}.introjs-tooltip{box-sizing:content-box;visibility:visible;min-width:200px;max-width:300px;-o-transition:opacity .1s ease-out;background-color:#fff;border-radius:3px;padding:10px;-webkit-transition:opacity .1s ease-out;-moz-transition:opacity .1s ease-out;-ms-transition:opacity .1s ease-out;transition:opacity .1s ease-out;position:absolute;box-shadow:0 1px 10px #0006}.introjs-tooltipbuttons{text-align:right;white-space:nowrap}.introjs-button{box-sizing:content-box;text-shadow:1px 1px #fff;color:#333;white-space:nowrap;cursor:pointer;background-color:#ececec;background-image:linear-gradient(#f4f4f4,#ececec);-webkit-background-clip:padding;-moz-background-clip:padding;-o-background-clip:padding-box;zoom:1;background-image:-webkit-gradient(linear,0 0,0 100%,from(#f4f4f4),to(#ececec));background-image:-moz-linear-gradient(#f4f4f4,#ececec);background-image:-o-linear-gradient(#f4f4f4,#ececec);border:1px solid #d4d4d4;-webkit-border-radius:.2em;-moz-border-radius:.2em;border-radius:.2em;outline:none;margin:10px 0 0;padding:.3em .8em;font:11px sans-serif;text-decoration:none;display:inline;position:relative;overflow:visible}.introjs-button:hover{border-color:#bcbcbc;text-decoration:none;box-shadow:0 1px 1px #e3e3e3}.introjs-button:focus,.introjs-button:active{background-image:-webkit-gradient(linear,0 0,0 100%,from(#ececec),to(#f4f4f4));background-image:-moz-linear-gradient(#ececec,#f4f4f4);background-image:-o-linear-gradient(#ececec,#f4f4f4);background-image:linear-gradient(#ececec,#f4f4f4)}.introjs-button::-moz-focus-inner{border:0;padding:0}.introjs-skipbutton{box-sizing:content-box;color:#7a7a7a;margin-right:5px}.introjs-prevbutton{border-right:none;-webkit-border-radius:.2em 0 0 .2em;-moz-border-radius:.2em 0 0 .2em;border-radius:.2em 0 0 .2em}.introjs-prevbutton.introjs-fullbutton{border:1px solid #d4d4d4;-webkit-border-radius:.2em;-moz-border-radius:.2em;border-radius:.2em}.introjs-nextbutton{-webkit-border-radius:0 .2em .2em 0;-moz-border-radius:0 .2em .2em 0;border-radius:0 .2em .2em 0}.introjs-nextbutton.introjs-fullbutton{-webkit-border-radius:.2em;-moz-border-radius:.2em;border-radius:.2em}.introjs-disabled,.introjs-disabled:hover,.introjs-disabled:focus{color:#9a9a9a;box-shadow:none;cursor:default;background-color:#f4f4f4;background-image:none;border-color:#d4d4d4;text-decoration:none}.introjs-hidden{display:none}.introjs-bullets{text-align:center}.introjs-bullets ul{box-sizing:content-box;clear:both;margin:15px auto 0;padding:0;display:inline-block}.introjs-bullets ul li{box-sizing:content-box;float:left;margin:0 2px;list-style:none}.introjs-bullets ul li a{box-sizing:content-box;width:6px;height:6px;cursor:pointer;background:#ccc;-webkit-border-radius:10px;-moz-border-radius:10px;border-radius:10px;text-decoration:none;display:block}.introjs-bullets ul li a:hover{background:#999}.introjs-bullets ul li a.active{background:#999}.introjs-progress{box-sizing:content-box;height:10px;background-color:#ecf0f1;border-radius:4px;margin:10px 0 5px;overflow:hidden}.introjs-progressbar{box-sizing:content-box;float:left;width:0%;height:100%;text-align:center;background-color:#08c;font-size:10px;line-height:10px}.introjsFloatingElement{height:0;width:0;position:absolute;top:50%;left:50%}.introjs-fixedTooltip{position:fixed}.introjs-hint{box-sizing:content-box;width:20px;height:15px;cursor:pointer;background:0 0;position:absolute}.introjs-hint:focus{border:0;outline:0}.introjs-hidehint{display:none}.introjs-fixedhint{position:fixed}.introjs-hint:hover>.introjs-hint-pulse{border:5px solid #3c3c3c91}.introjs-hint-pulse{box-sizing:content-box;width:10px;height:10px;z-index:10;-o-transition:all .2s ease-out;background-color:#8888883d;border:5px solid #3c3c3c45;-webkit-border-radius:30px;-moz-border-radius:30px;border-radius:30px;-webkit-transition:all .2s ease-out;-moz-transition:all .2s ease-out;-ms-transition:all .2s ease-out;transition:all .2s ease-out;position:absolute}.introjs-hint-no-anim .introjs-hint-dot{-webkit-animation:none;-moz-animation:none;animation:none}.introjs-hint-dot{box-sizing:content-box;height:50px;width:50px;z-index:1;opacity:0;background:0 0;border:10px solid #9292925c;-webkit-border-radius:60px;-moz-border-radius:60px;border-radius:60px;-webkit-animation:introjspulse 3s ease-out infinite;-moz-animation:introjspulse 3s ease-out infinite;animation:introjspulse 3s ease-out infinite;position:absolute;top:-25px;left:-25px}@-webkit-keyframes introjspulse{0%{opacity:0;-webkit-transform:scale(0)}25%{opacity:.1;-webkit-transform:scale(0)}50%{opacity:.3;-webkit-transform:scale(.1)}75%{opacity:.5;-webkit-transform:scale(.5)}to{opacity:0;-webkit-transform:scale(1)}}@-moz-keyframes introjspulse{0%{opacity:0;-moz-transform:scale(0)}25%{opacity:.1;-moz-transform:scale(0)}50%{opacity:.3;-moz-transform:scale(.1)}75%{opacity:.5;-moz-transform:scale(.5)}to{opacity:0;-moz-transform:scale(1)}}@keyframes introjspulse{0%{opacity:0;transform:scale(0)}25%{opacity:.1;transform:scale(0)}50%{opacity:.3;transform:scale(.1)}75%{opacity:.5;transform:scale(.5)}to{opacity:0;transform:scale(1)}}@font-face{font-family:iconfont;src:url(iconfont.960c72b2.eot#iefix)format("embedded-opentype"),url(iconfont.a07d77e0.woff2)format("woff2"),url(iconfont.b2a06094.woff)format("woff")}.icon{line-height:1}.icon:before{vertical-align:top;font-style:normal;font-family:iconfont!important;font-weight:400!important}.icon-close-fullscreen:before{content:""}.icon-open-fullscreen:before{content:""}.icon-output:before{content:""}.icon-coverage:before{content:""}.icon-more:before{content:""}.icon-copy:before{content:""}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-ms-text-size-adjust:100%;font-family:Nunito,sans-serif;font-size:16px;font-weight:400;line-height:1.6;overflow-x:hidden}html{scroll-behavior:smooth}a{color:#09c;word-break:break-word;text-decoration:none;transition:all .3s}a:hover{color:#069;text-decoration:none}button,a,.btn{outline:0;transition:all .3s}button:focus,a:focus,.btn:focus{outline:none;text-decoration:none;box-shadow:none!important}img{max-width:100%;height:auto}h1,.h1,h2,.h2,h3,.h3,h4,.h4,h5,.h5,h6,.h6{font-family:Nunito,sans-serif;font-weight:700;transition:all .3s}h1 a,.h1 a,h2 a,.h2 a,h3 a,.h3 a,h4 a,.h4 a,h5 a,.h5 a,h6 a,.h6 a{color:#242424}h1 a:hover,.h1 a:hover,h2 a:hover,.h2 a:hover,h3 a:hover,.h3 a:hover,h4 a:hover,.h4 a:hover,h5 a:hover,.h5 a:hover,h6 a:hover,.h6 a:hover{color:#09c;text-decoration:none}@media (min-width:576px){h1,.h1,h2,.h2,h3,.h3,h4,.h4,h5,.h5,h6,.h6{margin-top:-64px;padding-top:64px}}h1,.h1{font-size:32px}h2,.h2{font-size:28px}h3,.h3{font-size:24px}h4,.h4{font-size:20px}h5,.h5{font-size:18px}h6,.h6{font-size:16px}.section-gap{padding-top:3rem;padding-bottom:3rem;position:relative}@media (max-width:991px){h1,.h1{font-size:32px}h2,.h2{font-size:28px}h3,.h3{font-size:24px}h4,.h4{font-size:20px}h5,.h5{font-size:18px}h6,.h6{font-size:16px}.app-header+.section-gap{padding-top:5rem}}@media (max-width:767px){h1,.h1{font-size:28px}h2,.h2{font-size:26px}h3,.h3{font-size:24px}h4,.h4{font-size:20px}h5,.h5{font-size:18px}h6,.h6{font-size:16px}}@media (max-width:667px){h1,.h1{font-size:26px}h2,.h2{font-size:24px}h3,.h3{font-size:22px}h4,.h4{font-size:20px}h5,.h5{font-size:18px}h6,.h6{font-size:16px}}@media (min-width:769px){.section-gap{padding-top:7.5rem;padding-bottom:7.5rem}}.vlmenu>li>a:hover,.vlmenu>li.active>a{color:#09c}.hamburger{cursor:pointer;font:inherit;color:inherit;text-transform:none;background-color:#0000;border:0;margin:10px 0 0;padding:0;transition-property:opacity,filter;transition-duration:.15s;transition-timing-function:linear;display:inline-block;overflow:visible}.hamburger:hover{opacity:.7}.hamburger.is-active:hover{opacity:.7}.hamburger.is-active .hamburger-inner,.hamburger.is-active .hamburger-inner:before,.hamburger.is-active .hamburger-inner:after{background-color:#000}@media screen and (prefers-color-scheme:dark){.hamburger.is-active .hamburger-inner,.hamburger.is-active .hamburger-inner:before,.hamburger.is-active .hamburger-inner:after{background-color:#fff}}.hamburger-box{width:20px;height:17px;display:inline-block;position:relative}.hamburger-inner{margin-top:-2px;display:block;top:50%}.hamburger-inner,.hamburger-inner:before,.hamburger-inner:after{width:20px;height:2px;background-color:#000;border-radius:4px;transition-property:transform;transition-duration:.15s;transition-timing-function:ease;position:absolute}@media screen and (prefers-color-scheme:dark){.hamburger-inner,.hamburger-inner:before,.hamburger-inner:after{background-color:#fff}}.hamburger-inner:before,.hamburger-inner:after{content:"";display:block}.hamburger-inner:before{top:-10px}.hamburger-inner:after{bottom:-10px}.hamburger--slider .hamburger-inner{top:2px}.hamburger--slider .hamburger-inner:before{width:14px;transition-property:transform,opacity;transition-duration:.15s;transition-timing-function:ease;top:7px}.hamburger--slider .hamburger-inner:after{top:14px}.hamburger--slider.is-active .hamburger-inner{transform:translateY(7px)rotate(45deg)}.hamburger--slider.is-active .hamburger-inner:before{opacity:0;transform:rotate(-45deg)translate(-5.71429px,-6px)}.hamburger--slider.is-active .hamburger-inner:after{transform:translateY(-14px)rotate(-90deg)}.vl-accordion{font-family:Nunito,sans-serif!important}@media (max-width:1024px){.vlmenu{margin-top:10px}.app-header{width:100%;z-index:10;background:#fff;padding:.3em 0;position:absolute;top:auto}.app-header .logo-dark{height:50px;display:block}.app-header .logo-light{display:none}}@media screen and (max-width:1024px) and (prefers-color-scheme:dark){.app-header{background:#000}}@media (max-width:1024px){.app-header.transparent-header .logo-light{display:none}.header-links.navbar{position:absolute;right:15px}.vlmenu .vl-accordion .fa-angle-down{display:none}.vlmenu li li a{font-family:Nunito,sans-serif}.vlmenu>li>a{cursor:pointer}.mega-menu h3{font-size:14px;font-weight:700}.vlmenu .vl-accordion .fa-angle-down,.nav-extra-link{display:none}}@media (max-width:767px){.header-links.navbar{right:25px}}@media (min-width:1025px){.app-header{width:100%;z-index:10;background:#fff;transition:all .1s;position:absolute;top:auto}.app-header .navbar-brand{margin-top:0}.app-header .logo-light{display:none}.app-header.transparent-header .logo-light{display:block}.app-header.sticky-nav{z-index:1030;background:#fff;padding:0;animation:smoothScroll .3s forwards;position:fixed;top:0;bottom:auto;box-shadow:0 1px 10px #97a4af26}@keyframes smoothScroll{0%{transform:translateY(-100px)}to{transform:translateY(0)}}.transparent-header{background:0 0;padding-top:2rem;top:auto}.transparent-header .vlmenu>li>a{color:#fff}.transparent-header .vlmenu>li>a:hover{opacity:.7}.transparent-header .logo-dark{height:70px;display:none}.transparent-header.sticky-nav{background:#fff;top:0;box-shadow:0 1px 10px #97a4af26}.transparent-header.sticky-nav .vlmenu>li>a{color:#242424}.transparent-header.sticky-nav .vlmenu>li>a:hover{color:#09c}.transparent-header.sticky-nav .logo-light{display:none}.transparent-header.sticky-nav .logo-dark{height:50px;display:block}}@media screen and (min-width:1025px) and (prefers-color-scheme:dark){.transparent-header.sticky-nav{background:#000;box-shadow:0 2px 4px -1px #0003,0 4px 5px #00000024,0 1px 10px #0000001f}.transparent-header.sticky-nav .vlmenu>li>a{color:#fff}}@media (min-width:1025px){.transparent-header-dark-nav .vlmenu>li>a{color:#242424}.transparent-header-dark-nav .vlmenu>li>a:hover{color:#09c}}@media screen and (min-width:1025px) and (prefers-color-scheme:dark){.transparent-header-dark-nav .vlmenu>li>a{color:#fff}}@media (min-width:1025px){.transparent-header-dark-nav .logo-dark{display:block}.transparent-header-dark-nav .logo-light{display:none!important}.vlmenu>li>a>i.arrow{display:none;position:relative;top:2px}.light-sub-menu ul,.light-sub-menu li>div{box-shadow:0 1px 15px 1px #45414e1a}}@media screen and (min-width:1025px) and (prefers-color-scheme:dark){.light-sub-menu ul,.light-sub-menu li>div{color:#fff;background-color:#141414}}@media (min-width:1025px){.vlmenu ul{width:250px;padding-top:15px;padding-bottom:15px}.vlmenu ul a{padding:12px 30px;font-size:14px}.vlmenu ul ul{left:251px}.vlmenu li>div{padding:30px}.vlmenu li>div p{font-size:12px}.vlmenu>li.menu-right>ul ul{left:-251px}.vlmenu h3{margin-bottom:20px;font-size:14px;font-weight:700}.vlmenu .mega-menu ol li a{border-radius:6px;padding:12px 20px;font-size:14px}.vlmenu>li{padding:0 10px}}@media screen and (min-width:1025px) and (prefers-color-scheme:dark){.light-sub-menu ul a,.light-sub-menu ol li a{color:#fff}}@media (min-width:1025px){.light-sub-menu ul a:hover,.light-sub-menu ol li a:hover{color:#fff;background:#09c}}@media screen and (min-width:1025px) and (prefers-color-scheme:dark){.light-sub-menu ul a:hover,.light-sub-menu ol li a:hover{color:#fff}}@media (min-width:1025px){.vlmenu>li>a{cursor:pointer;padding:19.5px 0}.nav-btn{display:none}.vlmenu .half-nav,.vlmenu .full-nav,.vlmenu ul{border-radius:6px}.nav-extra-link .mt-3{margin-top:.85rem!important}}.overlay-nav{z-index:6;position:relative;top:1.7rem}.toggle-wrap{height:16px;width:20px;cursor:pointer;z-index:100;-webkit-transition:opacity .25s;transition:opacity .25s;position:absolute;top:3%;right:0}.toggle-wrap.active .top{background:#fff;-webkit-transform:translateY(7px)rotate(45deg);transform:translateY(7px)rotate(45deg)}.toggle-wrap.active .middle{opacity:0;background:#fff}.toggle-wrap.active .bottom{background:#fff;-webkit-transform:translateY(-7px)translate(0)rotate(-45deg);transform:translateY(-7px)translate(0)rotate(-45deg)}.toggle-wrap span{height:2px;width:100%;cursor:pointer;background:#242424;border:none;-webkit-transition:all .35s;transition:all .35s;position:absolute;top:0;left:0}.toggle-wrap span:nth-of-type(2){width:60%;top:7px}.toggle-wrap span:nth-of-type(3){top:14px}.overlay{width:100%;height:0;opacity:0;visibility:hidden;background:#242424;-webkit-transition:opacity .35s,visibility .35s,height .35s;transition:opacity .35s,visibility .35s,height .35s;position:fixed;top:0;left:0;overflow:hidden}.overlay.open{opacity:1;visibility:visible;height:100%}.overlay.open li{-webkit-animation:fadeInDown .5s .35s forwards;animation:fadeInDown .5s .35s forwards}.overlay.open li:nth-of-type(2){-webkit-animation-delay:.4s;animation-delay:.4s}.overlay.open li:nth-of-type(3){-webkit-animation-delay:.45s;animation-delay:.45s}.overlay.open li:nth-of-type(4){-webkit-animation-delay:.5s;animation-delay:.5s}.overlay.open li:nth-of-type(5){-webkit-animation-delay:.55s;animation-delay:.55s}.overlay.open li:nth-of-type(6){-webkit-animation-delay:.6s;animation-delay:.6s}.overlay.open li:nth-of-type(7){-webkit-animation-delay:.65s;animation-delay:.65s}.overlay.open li:nth-of-type(8){-webkit-animation-delay:.7s;animation-delay:.7s}.overlay nav{height:60%;text-align:center;font-size:1.5rem;position:relative;top:45%;-webkit-transform:translateY(-50%);transform:translateY(-50%)}.overlay ul{height:100%;margin:0 auto;padding:0;list-style:none;display:inline-block;position:relative}.overlay ul li{height:10%;min-height:50px;opacity:0;display:block;position:relative}.overlay ul li a{color:#fff;padding:0 0 10px;text-decoration:none;display:block;position:relative;overflow:hidden}.overlay ul li a:hover{color:#09c}.overlay ul li a:hover:after,.overlay ul li a:focus:after,.overlay ul li a:active:after{width:100%}.overlay ul li a:after{content:"";width:0%;height:1px;background:#09c;-webkit-transition:all .35s;transition:all .35s;position:absolute;bottom:5px;left:50%;-webkit-transform:translate(-50%);transform:translate(-50%)}.overlay-nav-social-link a{color:#8c8c8c;opacity:0;margin:0 .8rem;font-size:18px}.overlay-nav-social-link a:hover{color:#09c}.overlay-nav-social-link.open a{-webkit-animation:fadeInDown .6s .8s forwards;animation:fadeInDown .6s .8s forwards}@-webkit-keyframes fadeInDown{0%{opacity:0;-webkit-transform:translateY(-100%);transform:translateY(-100%)}to{opacity:1;-webkit-transform:translate(0,0);transform:translate(0,0)}}@keyframes fadeInDown{0%{opacity:0;-webkit-transform:translateY(-100%);transform:translateY(-100%)}to{opacity:1;-webkit-transform:translate(0,0);transform:translate(0,0)}}.fadeInDown{-webkit-animation-name:fadeInDown;animation-name:fadeInDown}.app-footer{border-top:1px solid #e8e8e8;padding:3rem 0;font-family:Arial,Helvetica,sans-serif}.app-footer .footer-link{margin-bottom:.5rem;padding:0}.app-footer .footer-link li{margin-bottom:.5rem;margin-right:15px;display:inline-block}.app-footer .footer-link li a{text-transform:uppercase;color:#8c8c8c;font-size:12px}.app-footer .footer-link li a:hover{color:#242424;text-decoration:none}.app-footer .footer-link li:last-child{margin-right:0}.app-footer .social-links li a{font-size:16px}.app-footer .copyright{color:#8c8c8c;margin:0;font-size:14px}@media screen and (prefers-color-scheme:dark){.app-footer{border-color:#414141}}.app-footer.bg-dark{color:#fff;padding:4rem 0}.app-footer.bg-dark .border-right{border-right:1px solid #616161!important}.app-footer.bg-dark .border-left{border-left:1px solid #616161!important}.app-footer.bg-dark .border-top{border-top:1px solid #616161!important}.app-footer.bg-dark .border-bottom{border-bottom:1px solid #616161!important}.app-secondary-footer{background:#171717;padding:2rem 0}.two-col-link li{width:50%;float:left;box-sizing:border-box;margin-right:0!important}.instagram-feed a{width:75px;height:75px;margin:0 .3rem .2rem 0;display:inline-block;overflow:hidden}.instagram-feed a img{width:100%;height:100%}.social-media-list{padding:0;list-style:none}.social-media-list a{text-transform:capitalize;color:#242424;margin-bottom:.5rem;font-size:18px;font-weight:700;display:inline-block}.social-media-list a:hover{color:#09c}.go-up-link i{font-weight:700}.go-up-link:hover{text-decoration:none}@media (max-width:767px){.app-footer .border-right,.app-footer.bg-dark .border-right{border-right:none!important}.app-footer,.app-footer.bg-dark{padding:2rem 0}.social-media-list a{font-size:14px}.footer-logo{max-height:32px}}img.footer-icon{width:28px;height:28px;margin:0}@media screen and (prefers-color-scheme:dark){code[class*=language-],pre[class*=language-]{color:#c5c8c6;text-shadow:0 1px #0000004d;direction:ltr;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-hyphens:none;-moz-hyphens:none;-ms-hyphens:none;hyphens:none;font-family:Inconsolata,Monaco,Consolas,Courier New,Courier,monospace;line-height:1.5}pre[class*=language-]{border-radius:.3em;margin:.5em 0;padding:1em;overflow:auto}:not(pre)>code[class*=language-],pre[class*=language-]{background:#1d1f21}:not(pre)>code[class*=language-]{border-radius:.3em;padding:.1em}.token.comment,.token.prolog,.token.doctype,.token.cdata{color:#7c7c7c}.token.punctuation{color:#c5c8c6}.namespace{opacity:.7}.token.property,.token.keyword,.token.tag{color:#96cbfe}.token.class-name{color:#ffffb6;text-decoration:underline}.token.boolean,.token.constant{color:#9c9}.token.symbol,.token.deleted{color:#f92672}.token.number{color:#ff73fd}.token.selector,.token.attr-name,.token.string,.token.char,.token.builtin,.token.inserted{color:#a8ff60}.token.variable{color:#c6c5fe}.token.operator{color:#ededed;background-color:inherit}.token.entity{color:#ffffb6;cursor:help}.token.url{color:#96cbfe}.language-css .token.string,.style .token.string{color:#87c38a}.token.atrule,.token.attr-value{color:#f9ee98}.token.function{color:#dad085}.token.regex{color:#e9c062}.token.important{color:#fd971f}.token.important,.token.bold{font-weight:700}.token.italic{font-style:italic}}.hero-img{background-position:50%;background-repeat:no-repeat;background-size:cover}.hero-img,.bg-overlay,.bg-overlay:before,.bg-theme-overlay,.bg-theme-overlay:before,.bg-navy-overlay,.bg-navy-overlay:before,.bg-gradient-overlay,.bg-gradient-overlay:before{position:absolute;inset:0}.bg-overlay:before{content:"";background-color:#242424}.bg-theme-overlay:before{content:"";background:#09c}.bg-navy-overlay:before{content:"";background:#1d2b40}.bg-gradient-overlay:before{content:"";background-image:linear-gradient(90deg,#09c 0%,#7431ff 100%)}[data-overlay="0"]:before{opacity:0}[data-overlay="1"]:before{opacity:.1}[data-overlay="2"]:before{opacity:.2}[data-overlay="3"]:before{opacity:.3}[data-overlay="4"]:before{opacity:.4}[data-overlay="5"]:before{opacity:.5}[data-overlay="6"]:before{opacity:.6}[data-overlay="7"]:before{opacity:.7}[data-overlay="8"]:before{opacity:.8}[data-overlay="9"]:before{opacity:.9}@media (max-width:768px){.section-top{padding-top:5rem}.hero-avatar-bottom{position:relative;bottom:-3rem}.scroll-down{bottom:10px;left:0;right:0}.scroll-down span{color:#09c;display:block}.scroll-down-circle{display:none}}@media (min-width:769px){.section-full>.section-full-exception,.section-full>.container:not(#homepage-container)>.row{min-height:calc(100vh - 20.8125rem)}.section-full .container>.row:before{min-height:inherit;content:""}.section-top{padding-top:13.3125rem}.scroll-down{bottom:50px;left:0;right:0}.scroll-down span{color:#09c;display:block}.scroll-down-circle{width:80px;height:80px;background:#fff;border-radius:50%;line-height:80px;position:absolute;bottom:-100px;left:50%;transform:translate(-50%);box-shadow:0 .2rem .8rem #24242426}}.btn{text-transform:uppercase;white-space:nowrap;padding:.75rem 2rem;font-size:11px;font-weight:700}.btn.btn-sm{padding:.485rem 1.2rem;font-size:10px;font-weight:700;line-height:1.6}.btn.btn-lg{padding:.965rem 2rem}.btn-pill{border-radius:5rem}.btn-theme{background:#09c;border:2px solid #09c;color:#fff!important}.btn-theme:hover{color:#fff;background:#069;border:2px solid #069}.btn-rv-blue{background:#09c;border:2px solid #09c;color:#fff!important}.btn-rv-blue:hover{color:#fff;background:#069;border:2px solid #069}.btn-outline{cursor:pointer;color:#242424;background:#fff;border:2px solid #e8e8e8;margin-left:2em}.btn-outline:hover{background:#242424;border-color:#242424;color:#fff!important}@media screen and (prefers-color-scheme:dark){.btn-outline{color:#fff;background:#000;border-color:#e8e8e8}.btn-outline:hover{border-color:#777}}.btn-outline-dark{color:#242424;background:0 0;border:2px solid #242424}.btn-outline-dark:hover{color:#fff;background:#242424;border-color:#242424}.btn-outline-light{color:#fff;background:0 0;border:2px solid #fff}.btn-outline-light:hover{color:#242424;background:#fff;border-color:#fff}.btn-solid-light{color:#242424;background:#fff;border:2px solid #fff}.btn-solid-light:hover{color:#fff;background:#09c;border-color:#09c}.btn-solid-dark{color:#fff;background:#242424;border:2px solid #242424}.btn-solid-dark:hover{color:#fff;background:#09c;border-color:#09c}.video-btn .video-play-icon,.video-btn span{display:inline-block}.video-btn .video-play-icon{width:46px;height:46px;text-align:center;color:#242424;cursor:pointer;background:#fff;border-radius:50%;line-height:46px;box-shadow:0 3px 6px #0000000d}.video-btn .video-play-icon i{font-size:12px;position:relative;top:0;left:2px}.video-btn .video-play-icon:hover i{color:#09c}.video-btn span{text-transform:uppercase;font-size:11px;font-weight:700;position:relative;left:10px}.video-play-btn-align-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.btn-read-more{display:inline-block;position:relative}.btn-read-more:hover{text-decoration:none}.btn-read-more:hover:after{right:-30px}@media (max-width:767px){.btn.btn-sm{padding:.4rem 1rem}.btn{padding:.5rem 1.3rem}.btn.btn-lg{padding:.7rem 1.4rem}}.accordion .card{border-color:#e8e8e8}.accordion .card p{color:#8c8c8c}.accordion .card-header{border-color:#e8e8e8;padding:0}.accordion .card-header h6{margin-bottom:0;font-size:16px;font-weight:400}.accordion .card-header a{cursor:pointer;color:#09c;background:#fff;border-radius:4px 4px 0 0;padding:1.2rem 1.5rem;display:block;position:relative}.accordion .card-header a:hover{color:#09c}.accordion .card-header .collapsed{color:#242424}.accordion .card-header .collapsed:after{content:""}.accordion .accordion-list{list-style:none}.accordion .accordion-list li{margin-bottom:.5rem}.accordion .accordion-list li a{color:#8c8c8c}.accordion .accordion-list li a i{font-size:14px}.accordion .accordion-list li a:hover{color:#09c;text-decoration:none}.accordion.accordion-style-1 .card-header a{color:#09c;background:#fff}.accordion.accordion-style-1 .card-header a:hover{color:#09c}.accordion.accordion-style-1 .card-header a:hover:after{color:#fff;background:#09c;border:1px solid #09c;transition:all .3s}.accordion.accordion-style-1 .card-header .collapsed{color:#242424}.accordion.accordion-style-1 .card-header .collapsed:after{content:"";color:#8c8c8c;background:#fff;border:1px solid #ccc}.accordion.accordion-style-2 .card{border-radius:4px;margin-bottom:10px}.accordion.accordion-style-2 .card .card-header{background:0 0;border:none;margin-bottom:0}.accordion.accordion-style-2 .card .card-header a:after{content:"";font-family:fontawesome;font-size:14px;position:absolute;top:35%;right:20px}.accordion.accordion-style-2 .card .card-header a.collapsed{border-radius:4px;position:relative}.accordion.accordion-style-2 .card .card-header a.collapsed:after{content:""}.accordion.accordion-style-2 .card:not(:first-of-type):not(:last-of-type){border-radius:4px}.accordion.accordion-style-2 .card:first-of-type,.accordion.accordion-style-2 .card:not(:first-of-type):not(:last-of-type){border-bottom:1px solid #e8e8e8}.accordion.accordion-style-3 .card,.accordion.accordion-style-3 .card-header,.accordion.accordion-style-3 .card-header a{background:0 0;border:none}.accordion.accordion-style-3 .card-header a{color:#09c;padding:1.2rem 0 1.2rem 4rem}.accordion.accordion-style-3 .card-header a:before{width:40px;height:40px;text-align:center;color:#fff;content:"";background:#09c;border-radius:50%;font-family:fontawesome;font-size:14px;line-height:40px;position:absolute;top:8px;left:5px}.accordion.accordion-style-3 .card-header a:after{content:""}.accordion.accordion-style-3 .card-header .collapsed{color:#242424}.accordion.accordion-style-3 .card-header .collapsed:before{content:"";width:40px;height:40px;text-align:center;color:#242424;background:#fff;border:1px solid #f5f5f5;border-radius:50%;line-height:38px;box-shadow:0 3px 6px #0000000d}.accordion.accordion-style-3 .card-body{padding:1.25rem 0 1.25rem 4rem}.accordion.accordion-style-4 .card{border-radius:4px;margin-bottom:10px}.accordion.accordion-style-4 .card .card-header{background:0 0;border:none;margin-bottom:0;position:relative}.accordion.accordion-style-4 .card .card-header a{color:#242424;padding:2.5rem 1.5rem;font-weight:700}.accordion.accordion-style-4 .card .card-header a.collapsed{border-radius:4px;position:relative}.accordion.accordion-style-4 .card .card-header a.collapsed:after{content:""}.accordion.accordion-style-4 .card .card-header i{color:#09c;position:absolute;top:28px}.accordion.accordion-style-4 .card .card-header span{padding-left:3rem}.accordion.accordion-style-4 .card:not(:first-of-type):not(:last-of-type){border-radius:4px}.accordion.accordion-style-4 .card:first-of-type,.accordion.accordion-style-4 .card:not(:first-of-type):not(:last-of-type){border-bottom:1px solid #e8e8e8}.blurb i{margin-bottom:2rem;font-size:3rem;display:inline-block}.blurb p{color:#8c8c8c;padding-right:2rem}.blurb.text-right p{padding-left:2rem;padding-right:0}.blurb-border{background:#fff;border:1px solid #e8e8e8;border-radius:6px;padding:1.8rem}.blurb-border p{margin-bottom:.5rem;padding:0}@media (max-width:767px){.blurb i{font-size:2.5rem}.blurb-border{margin-bottom:1.5rem}}.list-group-right-arrow a{position:relative}.list-group-right-arrow a:after{content:"";width:25px;height:25px;text-align:center;border:1px solid #e8e8e8;border-radius:50%;padding-left:2px;font-family:fontawesome;font-size:14px;line-height:23px;position:absolute;top:30%;right:20px}.list-group-right-arrow a:hover:after{color:#fff;background:#09c;border-color:#09c;transition:all .3s}.list-group-right-arrow .list-group-item.active{color:#09c;background:#fff;border-color:#e8e8e8}.list-group-right-arrow .list-group-item.active:after{color:#fff;background:#09c;border-color:#09c}.list-group-right-arrow-on-hover a:after{opacity:0;width:30px;height:30px;border:3px solid #fff;line-height:25px;top:33%;right:13px}.list-group-right-arrow-on-hover a:hover:after{opacity:1;width:30px;height:30px;border:3px solid #fff;line-height:25px;right:-13px}.list-group-right-arrow-on-hover .list-group-item.active:after{opacity:1;width:30px;height:30px;border:3px solid #fff;line-height:25px;right:-13px}.list-group .list-group-item h6{color:#242424}.list-group .list-group-item:hover h6{color:#09c}.list-group-gap .list-group-item{border-radius:6px;margin-bottom:10px;padding:1.8rem 1.25rem}@media (prefers-color-scheme:dark){.list-group-item{color:#fff;background-color:#1b1b1b;border-color:#414141}}.custom-list{padding:0;list-style:none}.custom-list li{padding:.8rem 0}.custom-list li a{color:#242424}.custom-list li a:hover{color:#09c;text-decoration:none}.custom-list-border li{border-bottom:1px solid #e8e8e8}.custom-list-border li:first-child{border-top:1px solid #e8e8e8}@media (prefers-color-scheme:dark){.list-group-item{color:#fff;background-color:#1b1b1b;border-color:#414141}}.clients-thumb{width:100%;max-width:10rem;height:auto;opacity:.5;margin-left:auto;margin-right:auto}.clients-thumb:hover{opacity:1}.dot-style-1.owl-theme .owl-dots .owl-dot span{width:6px;height:6px;background:#242424;transition:all .3s}.dot-style-1.owl-theme .owl-dots .owl-dot.active span{transform:scale(1.5)}.dot-style-2.owl-theme .owl-dots .owl-dot span{width:10px;height:10px;background:#ccc;transition:all .3s}.dot-style-2.owl-theme .owl-dots .owl-dot.active span{width:20px;height:10px;background:#09c;margin:5px 3px}.owl-carousel.text-center .owl-stage{display:inline-block}.carousel-highlighter.owl-carousel .owl-item{opacity:.2}.carousel-highlighter.owl-carousel .owl-item .card-img-overlay{opacity:0}.carousel-highlighter.owl-carousel .owl-item.center,.carousel-highlighter.owl-carousel .owl-item.center .card-img-overlay{opacity:1}.carousel-zoom-img .owl-stage-outer{overflow:visible}.carousel-zoom-img .owl-item .item h6{opacity:0}.carousel-zoom-img .owl-item.center .item{z-index:100;position:relative;transform:scale(1.2)}.carousel-zoom-img .owl-item.center .item h6{opacity:1}.carousel-zoom-img .owl-dots{margin-top:4rem}.owl-theme .owl-nav,.owl-theme .owl-nav.disabled+.owl-dots{margin-top:30px}.nav-circle.owl-theme .owl-nav [class*=owl-],.nav-circle-light.owl-theme .owl-nav [class*=owl-],.nav-circle-solid-light.owl-theme .owl-nav [class*=owl-]{width:50px;height:50px;text-align:center;color:#8c8c8c;border:1px solid #ccc;border-radius:50%;margin-bottom:2rem;font-size:12px;line-height:50px;position:relative}.nav-circle.owl-theme .owl-nav [class*=owl-]:hover,.nav-circle-light.owl-theme .owl-nav [class*=owl-]:hover,.nav-circle-solid-light.owl-theme .owl-nav [class*=owl-]:hover{color:#fff;background:#242424;border-color:#242424}.nav-circle-light.owl-theme .owl-nav [class*=owl-]:hover{color:#242424;background:#fff;border-color:#fff}.nav-circle-solid-light.owl-theme .owl-nav [class*=owl-]{color:#242424;background:#fff;border-color:#fff}.nav-circle-solid-light.owl-theme .owl-nav [class*=owl-]:hover{color:#fff;background:#09c;border-color:#09c}.nav-round.owl-theme .owl-nav [class*=owl-]{width:40px;height:90px;text-align:center;color:#fff;background:#0000004d;border-radius:6px;margin-bottom:2rem;font-size:12px;line-height:90px;position:relative}.nav-round.owl-theme .owl-nav [class*=owl-]:hover{background:#242424}.nav-round.owl-carousel .owl-nav .owl-prev,.nav-round.owl-carousel .owl-nav .owl-next{margin-top:-90px;position:absolute;top:50%}.nav-round.owl-carousel .owl-nav .owl-prev{border-radius:0 6px 6px 0;left:-5px}.nav-round.owl-carousel .owl-nav .owl-next{border-radius:6px 0 0 6px;right:-5px}.custom-testimonial.owl-theme .owl-nav{margin-top:0;bottom:2%}.custom-testimonial.owl-theme .owl-nav [class*=owl-]{width:35px;height:35px;text-align:center;color:#8c8c8c;border:1px solid #ccc;border-radius:50%;font-size:12px;line-height:35px;position:relative}.custom-testimonial.owl-theme .owl-nav [class*=owl-]:hover{color:#fff;background:#242424;border-color:#242424}.owl-carousel .owl-item img{width:auto}@media (min-width:1025px){.nav-circle.owl-carousel .owl-nav .owl-prev,.nav-circle.owl-carousel .owl-nav .owl-next,.nav-circle-light.owl-carousel .owl-nav .owl-prev,.nav-circle-light.owl-carousel .owl-nav .owl-next,.nav-circle-solid-light.owl-carousel .owl-nav .owl-prev,.nav-circle-solid-light.owl-carousel .owl-nav .owl-next,.nav-inside.owl-carousel .owl-nav .owl-prev,.nav-inside.owl-carousel .owl-nav .owl-next{margin-top:-50px;position:absolute;top:50%}.nav-circle.owl-carousel .owl-nav .owl-prev,.nav-circle-light.owl-carousel .owl-nav .owl-prev,.nav-circle-solid-light.owl-carousel .owl-nav .owl-prev{left:-8%}.nav-circle.owl-carousel .owl-nav .owl-next,.nav-circle-light.owl-carousel .owl-nav .owl-next,.nav-circle-solid-light.owl-carousel .owl-nav .owl-next{right:-8%}.nav-inside.owl-carousel .owl-nav .owl-prev,.nav-inside.owl-carousel .owl-nav .owl-prev{left:3%}.nav-inside.owl-carousel .owl-nav .owl-next,.nav-inside.owl-carousel .owl-nav .owl-next{right:3%}.custom-testimonial.owl-theme .owl-nav{z-index:100;margin-top:0;position:absolute;bottom:8%;right:11%}}.t-star-icon{font-size:8px;position:relative;bottom:2px}.justify-content-between .card-arrow-icon{width:25px;height:25px;text-align:center;border:1px solid #ddd;border-radius:50%;line-height:25px;transition:all .3s;position:relative}.justify-content-between .card-arrow-icon:after{content:"";font-family:fontawesome;font-size:14px;position:absolute;top:-1px;left:9px}.justify-content-between>a{text-decoration:none}.justify-content-between>a:hover+.card-arrow-icon{color:#fff;background:#09c;border-color:#09c}.card-img-overlay{top:auto;left:auto;right:auto}.box-hover,img.box-hover{transition:top .2s,box-shadow .2s;position:relative;top:0;box-shadow:0 0 #0000}.box-hover:hover,img.box-hover:hover{top:-.5rem;box-shadow:0 .2rem .8rem #24242426}@media (min-width:768px){.card.flex-md-row .card-img{object-fit:cover;border-radius:.375rem 0 0 .375rem}.card.flex-md-row .card-img-right{object-fit:cover;border-radius:0 .375rem .375rem 0}}@media (max-width:991.98px){.card.flex-column .card-img{border-radius:.375rem .375rem 0 0}.card.flex-md-row .card-img-right{border-radius:0 0 .375rem .375rem}}.form-control,.custom-select,.custom-file,.custom-file-input,.custom-file-label{height:calc(2.25rem + 12px);border:1px solid #e8e8e8}.form-control:focus,.custom-select:focus,.custom-file:focus,.custom-file-input:focus,.custom-file-label:focus{box-shadow:none}@media screen and (prefers-color-scheme:dark){.form-control,.form-control:focus{color:#fff;background-color:#1b1b1b;border-color:#414141}}.form-inline .form-control{height:calc(2.25rem + 8px)}.custom-file{border:none}.custom-file-label{padding:.65rem .75rem}.custom-file-label:after{height:2.85rem;padding:inherit;background:#fafafa;border-radius:0 .15rem .15rem 0}.icon-field,.icon-field-right{position:relative}.icon-field i,.icon-field-right i{user-select:none;cursor:default;color:#8c8c8c;position:absolute}.icon-field i{top:15px;left:15px}.icon-field input{padding-left:45px}.icon-field-right i{top:15px;right:15px}.icon-field-right input{padding-right:45px}.custom-control-label:before,.custom-control-label:after{width:1.3rem;height:1.3rem;top:.1rem;left:-1.5rem}.custom-control-label:before{border:1px solid #e8e8e8}.custom-control-label{padding-left:10px}.custom-switch .custom-control-label:before{width:40px;pointer-events:all;height:24px;background:#e8e8e8;border-radius:5rem;left:-2.25rem}.custom-switch .custom-control-label:after{width:calc(1.4rem - 2px);height:calc(1.4rem - 2px);background-color:#fff;border-radius:5rem;top:calc(.25rem - 1px);left:calc(3px - 2.25rem)}.custom-switch .custom-control-input:checked~.custom-control-label:after{transform:translate(.95rem)}.custom-switch .custom-control-label{padding-left:20px}.custom-file-input:focus~.custom-file-label,.custom-control-input:focus~.custom-control-label:before{box-shadow:none}.custom-control-input:checked~.custom-control-label:before,.custom-control-input:focus:not(:checked)~.custom-control-label:before{border:1px solid #e8e8e8}.custom-select{background:#fff url(select-arrow.b8e89c0c.svg) right .75rem center/8px 10px no-repeat}.login-content{color:#fff;text-align:center;width:100%;padding:2rem;position:absolute;top:50%;transform:translateY(-50%)}.login-circle-logo{width:80px;height:80px;background:#fff;border-radius:50%;line-height:80px;display:inline-block;box-shadow:0 .2rem .8rem #24242426}.c-form-content,.coming-soon-social{color:#fff;text-align:center;width:100%;padding:3rem;position:absolute;bottom:3%}.coming-soon-social{left:0}@media (max-width:991px){.coming-soon-social{margin-top:3rem;padding:0;position:relative}}@media (max-width:767px){.form-inline .form-control{height:2.25rem}}.steps-solid,.steps-dashed,.steps-dashed-light{width:150px;height:150px;text-align:center;background:#fff;border:2px solid #e8e8e8;border-radius:50%;line-height:150px;display:inline-block;position:relative}.steps-solid:after,.steps-dashed:after,.steps-dashed-light:after{content:"";width:100px;border-bottom:1px dashed #ccc;position:absolute;top:50%;right:-110%}.steps-solid i,.steps-dashed i,.steps-dashed-light i{line-height:150px}.steps-solid .step-number,.steps-dashed .step-number,.steps-dashed-light .step-number{color:#fff;background:#09c;border:3px solid #fff;border-radius:30px;padding:2px 10px;font-size:12px;font-weight:700;line-height:normal;position:absolute;top:10px;right:5px}.steps-solid.step-last:after,.steps-dashed.step-last:after,.steps-dashed-light.step-last:after{border-bottom:none}.steps-dashed{background:0 0;border:2px dashed #ccc}.steps-dashed-light{background:0 0;border:2px dashed #fff}.steps-dashed-light i{color:#fff}.steps-dashed-light:after{border-bottom:2px dashed #fff}.steps-dashed-light+.steps-info{color:#fff}.steps-info{padding:0 2rem}@media (max-width:1024px){.steps-solid:after,.steps-dashed:after,.steps-dashed-light:after{width:100%;top:50%;right:-110%}}@media (max-width:991px){.steps-solid:after,.steps-dashed:after,.steps-dashed-light:after{width:55%;right:-60%}}@media (max-width:767px){.steps-solid,.steps-dashed,.steps-dashed-light{width:100px;height:100px;line-height:100px}.steps-solid i,.steps-dashed i,.steps-dashed-light i{line-height:100px}.steps-solid:after,.steps-dashed:after,.steps-dashed-light:after{border-bottom:none}.steps-solid .step-number,.steps-dashed .step-number,.steps-dashed-light .step-number{right:-15px}.steps-info{margin-bottom:2rem}}.block-image{width:100%;height:100%;z-index:0;top:0;left:0}img.block-image{object-fit:cover}.block-image:not([class*=absolute]){position:absolute}.img-caption{width:70%;background:#ffffffe6;border-radius:0 .375rem .375rem 0;padding:1.5rem;position:absolute;bottom:10%;left:0}@media (min-width:1025px){.parallax-img{background-attachment:fixed}}@media (max-width:767px){.img-caption{padding:1rem}}.custom-progress{height:2px;box-shadow:none;background:#e8e8e8;border-radius:0;margin-top:4rem;position:relative}.custom-progress .progress-bar .skills-info{color:#242424;text-align:left;font-size:14px;position:relative;top:-20px}.custom-progress .progress-bar span{float:right;color:#242424;line-height:normal;position:relative;bottom:0}.custom-progress:first-child{margin-top:1.5rem}.custom-progress.progress{overflow:visible}.custom-progress.dark-progress .progress-bar,.custom-progress-inside.dark-progress .progress-bar{background:#242424}.progress-light-txt .progress-bar .skills-info,.progress-light-txt .progress-bar span{color:#fff}.custom-progress-inside{height:30px;background:#e8e8e8;margin-top:2rem}.custom-progress-inside .progress-bar .skills-info{color:#fff;text-align:left;padding:0 1rem;font-size:14px;position:relative;top:0}.custom-progress-inside .progress-bar span{float:right;color:#fff;line-height:normal;position:relative;bottom:0}.custom-progress-inside:first-child{margin-top:0}.nav.nav-group{display:inline-block}.nav.nav-group>li{text-align:center;float:left;margin:0 auto}.nav.nav-group>li .nav-link{color:#242424;padding:1rem 2rem;display:block}@media screen and (prefers-color-scheme:dark){.nav.nav-group>li .nav-link{color:#fff}}.nav.nav-group li a{background:#f9f9f9;border:1px solid #e8e8e8;margin-right:-1px}@media screen and (prefers-color-scheme:dark){.nav.nav-group li a{color:#fff;background-color:#000;border:1px solid #2f2f2f}}.nav.nav-group li a.active{color:#09c;background:#fff}@media screen and (prefers-color-scheme:dark){.nav.nav-group li a.active{background-color:#000}}.nav.nav-group li:first-child a{border-radius:30px 0 0 30px}.nav.nav-group li:last-child a{border-radius:0 30px 30px 0}.nav-line{border-bottom:1px solid #e8e8e8}.nav-line>li .nav-link{color:#242424;border-bottom:1px solid #0000;padding:1.5rem 3rem;display:block;position:relative;bottom:-1px}.nav-line>li a.active{color:#09c;border-bottom:1px solid #242424}.nav-vertical{border-right:1px solid #e8e8e8}.nav-vertical .nav-link{color:#242424;border-right:1px solid #0000;padding:1rem;display:block;position:relative;right:-1px}.nav-vertical i{position:relative;top:5px}.nav-vertical a.active{color:#09c;border-right:1px solid #242424}@media (max-width:1024px){.nav.nav-group>li .nav-link,.nav.nav-line>li .nav-link{padding:.6rem 1.5rem}}@media (max-width:767px){.nav-vertical{margin-bottom:2rem}}@media screen and (prefers-color-scheme:dark){.nav-tabs{border-color:#777}.nav-tabs .nav-link{color:#fff!important}.nav-tabs .nav-link.active{background-color:inherit;border-color:#777}}.vl-custom-table{border-spacing:0 1em;border-collapse:separate}.vl-custom-table h6{color:#616161;margin-top:0;padding-top:0;font-size:16px}.vl-custom-table thead th{vertical-align:middle;border-bottom:none;padding:.5rem 1.75rem}.vl-custom-table th,.vl-custom-table td{vertical-align:middle;border-top:none;font-family:Nunito,sans-serif}.vl-custom-table td:first-child{border-left:1px solid #e8e8e8;border-top-left-radius:10px;border-bottom-left-radius:10px}.vl-custom-table td:last-child{border-right:1px solid #e8e8e8;border-top-right-radius:10px;border-bottom-right-radius:10px}.vl-custom-table tbody td{background:#fff;border-top:1px solid #e8e8e8;border-bottom:1px solid #e8e8e8;padding:1.75rem}@media screen and (prefers-color-scheme:dark){.vl-custom-table h6{color:#777}.vl-custom-table td:first-child,.vl-custom-table td:last-child{border-color:#414141}.vl-custom-table tbody .report-row-header>td{background-color:#000;border-color:#414141}.vl-custom-table tbody .report-output-row>td{color:#fff;background-color:#000}.vl-custom-table tbody .report-output-row>td .report-view-box{color:#fff}.vl-custom-table tbody td{background-color:inherit}}.table-striped td,.table-striped th{vertical-align:middle}.table-striped tbody tr:nth-of-type(2n+1){background-color:#00000006}.table thead th{border-bottom-width:1px}.table .btn{white-space:nowrap}@media screen and (prefers-color-scheme:dark){.table thead,.table td{color:#fff}}.team-card{cursor:pointer;position:relative;overflow:hidden;box-shadow:0 8px 16px #0000001a}.team-card:hover{transition:all .3s;box-shadow:0 8px 16px #0003}@media screen and (prefers-color-scheme:dark){.team-card{color:#fff;background-color:#000}}.team-info .top-section{flex-direction:row;display:flex}.team-info .top-section .profile-img{width:200px;height:200px;background-color:#efefef;background-size:cover;margin-bottom:24px;margin-right:24px}.team-info .top-section .team-title p.team-position{margin-bottom:.5rem;font-size:14px}.team-info .top-section .team-social-links a{display:inline-block}@media (max-width:568px){.team-info .top-section{flex-direction:column;margin-bottom:16px}.team-info .top-section .profile-img{margin:0 auto 24px}}.team-info .modal-header{border-bottom:none;padding-bottom:0}@media screen and (prefers-color-scheme:dark){.team-info{color:#fff;background-color:#000}}.social-links a{color:#8c8c8c;margin-right:15px;display:inline-block}.social-links a:hover{color:#09c}@-webkit-keyframes blink{0%{opacity:1}50%{opacity:0}to{opacity:1}}@keyframes blink{0%{opacity:1}50%{opacity:0}to{opacity:1}}.typist-blink:after{height:26px;content:" ";border-right:2px solid;margin-left:3px;margin-right:7px;animation:blink 1s step-start infinite;display:inline-block;position:relative;top:3px}@media (max-width:667px){.typist-blink:after{height:22px;top:2px}}.typist-blink>.selectedText{display:none}.typist-mark>.selectedText{color:#fff;background-color:#242424;font-style:normal}@media screen and (max-width:1080px) and (min-width:768px){.firefly-typist-header{min-height:180px}}@media screen and (max-width:767px) and (min-width:668px){.firefly-typist-header{min-height:102px}}@media screen and (max-width:667px){.firefly-typist-header{min-height:124px}}.count-block{width:150px;height:150px;text-align:center;margin:0 20px;display:inline-block}.count-block h2{margin:2.5rem 0 0;font-weight:700}.count-block span{font-size:16px}.count-solid-light .count-block{background:#fff;border:1px solid #e8e8e8;margin-bottom:20px}.count-solid-dark .count-block{background:#242424;margin-bottom:20px}.count-solid-dark .count-block h2,.count-solid-dark .count-block span{color:#fff}.circle .count-block{border-radius:50%}.round .count-block{border-radius:6px}@media screen and (max-width:767px){.count-block{width:100px;height:100px}.count-block h2{margin:1.5rem 0 0}}.portfolio-filter{margin-bottom:50px;padding:0 1rem;list-style:none}.portfolio-filter li{margin:0 20px;font-family:Lora,serif;display:inline-block;position:relative}.portfolio-filter li a{color:#8c8c8c;text-transform:capitalize;font-size:16px;text-decoration:none}.portfolio-filter li a:hover{color:#242424}.portfolio-filter li:after{content:"/";color:#8c8c8c;position:absolute;top:0;right:-30px}.portfolio-filter li:last-child:after{content:" "}.portfolio-filter li.active a{color:#242424}.portfolio-grid .portfolio-item{float:left}.portfolio-grid .portfolio-item a{text-decoration:none}.portfolio-grid .portfolio-item a:focus{outline:none}.portfolio-grid .portfolio-item .portfolio-image{display:block;position:relative}.portfolio-grid .portfolio-item .portfolio-image img{width:100%;height:auto;display:block}.portfolio-grid .portfolio-item .portfolio-image .portfolio-hover-title{opacity:0;background-color:#242424e6;justify-content:center;align-items:center;margin:0;padding:30px;transition:all .3s;position:absolute;inset:0}.portfolio-grid .portfolio-item .portfolio-image .portfolio-hover-title .portfolio-content{width:100%;text-align:left;transition:all .3s;position:absolute;bottom:2rem;left:2rem}.portfolio-grid .portfolio-item .portfolio-image .portfolio-hover-title .portfolio-content h6{color:#fff;margin-bottom:.2rem;font-size:16px}.portfolio-grid .portfolio-item .portfolio-image .portfolio-hover-title .portfolio-content .portfolio-category span{color:#ccc;margin-right:5px;font-family:Lora,serif;font-size:14px}.portfolio-grid .portfolio-item:hover .portfolio-hover-title{opacity:1}.portfolio-grid .portfolio-title{margin:5% 0}.portfolio-grid .portfolio-title .portfolio-content h6{color:#242424;margin-bottom:.2rem}.portfolio-grid .portfolio-title .portfolio-content span{color:#8c8c8c;font-family:Lora,serif}.portfolio-grid.grid-2 .portfolio-item{width:50%}@media (max-width:768px){.portfolio-grid.grid-2 .portfolio-item{width:50%}}@media (max-width:568px){.portfolio-grid.grid-2 .portfolio-item{width:100%}}.portfolio-grid.grid-3 .portfolio-item{width:33.33%}@media (max-width:768px){.portfolio-grid.grid-3 .portfolio-item{width:50%}}@media (max-width:568px){.portfolio-grid.grid-3 .portfolio-item{width:100%}}.portfolio-grid.grid-4 .portfolio-item{width:25%}@media (max-width:768px){.portfolio-grid.grid-4 .portfolio-item{width:50%}}@media (max-width:568px){.portfolio-grid.grid-4 .portfolio-item{width:100%}}.portfolio-grid.grid-4 .portfolio-item .portfolio-content h6{font-size:16px}.portfolio-grid.grid-4 .portfolio-item .portfolio-content span{font-size:14px}.portfolio-grid.grid-5 .portfolio-item{width:20%}@media (max-width:768px){.portfolio-grid.grid-5 .portfolio-item{width:50%}}@media (max-width:568px){.portfolio-grid.grid-5 .portfolio-item{width:100%}}.portfolio-grid.grid-5 .portfolio-item .portfolio-content h6,.portfolio-grid.grid-5 .portfolio-item .portfolio-content span{font-size:14px}.portfolio-grid.grid-2.gutter{margin-right:-2%}.portfolio-grid.grid-2.gutter .portfolio-item{width:48%;margin-bottom:2%;margin-right:2%}@media (max-width:768px){.portfolio-grid.grid-2.gutter .portfolio-item{width:48%}}@media (max-width:568px){.portfolio-grid.grid-2.gutter .portfolio-item{width:98%}}.portfolio-grid.grid-3.gutter{margin-right:-2%}.portfolio-grid.grid-3.gutter .portfolio-item{width:31.33%;margin-bottom:2%;margin-right:2%}@media (max-width:768px){.portfolio-grid.grid-3.gutter .portfolio-item{width:48%}}@media (max-width:568px){.portfolio-grid.grid-3.gutter .portfolio-item{width:98%}}.portfolio-grid.grid-4.gutter{margin-right:-2%}.portfolio-grid.grid-4.gutter .portfolio-item{width:23%;margin-bottom:2%;margin-right:2%}@media (max-width:768px){.portfolio-grid.grid-4.gutter .portfolio-item{width:48%}}@media (max-width:568px){.portfolio-grid.grid-4.gutter .portfolio-item{width:98%}}.portfolio-grid.grid-5.gutter{margin-right:-2%}.portfolio-grid.grid-5.gutter .portfolio-item{width:18%;margin-bottom:2%;margin-right:2%}@media (max-width:768px){.portfolio-grid.grid-5.gutter .portfolio-item{width:48%}}@media (max-width:568px){.portfolio-grid.grid-5.gutter .portfolio-item{width:98%}}.portfolio-masonry .portfolio-title{padding-left:3%}.portfolio-masonry.gutter .portfolio-title{padding-left:0}.portfolio-grid.gutter .portfolio-item .portfolio-image .portfolio-hover-title,.portfolio-masonry.gutter .portfolio-item .portfolio-image .portfolio-hover-title,.portfolio-grid.gutter img,.portfolio-masonry.gutter img{border-radius:6px}.isotope-item{z-index:2}.isotope-hidden.isotope-item{pointer-events:none;z-index:1}.isotope,.isotope .isotope-item{transition-duration:.8s}.isotope{transition-property:height,width}.isotope .isotope-item{transition-property:transform,opacity}.isotope.no-transition,.isotope.no-transition .isotope-item,.isotope .isotope-item.no-transition{transition-duration:0s}.isotope.infinite-scrolling{transition:none}.twitter-feed-style{background:#fff;border:1px solid #e8e8e8;position:relative}.twitter-feed-style:after{content:"";color:#e8e8e8;font-family:FontAwesome;font-size:24px;position:absolute;top:1rem;right:1.5rem}.twitter-feed-style ul{margin-bottom:0;padding:0;list-style:none}.twitter-feed-style ul li{padding:2rem;position:relative;overflow:hidden}.twitter-feed-style .user{width:18%;float:left;margin-bottom:.928571em}.twitter-feed-style .user img{max-width:80%;height:auto;border-radius:50%}.twitter-feed-style .user [data-scribe=component\:author]{margin-left:1.3rem;position:absolute;top:10%;left:18%}.twitter-feed-style .user [data-scribe=component\:author] a{text-decoration:none}.twitter-feed-style .user [data-scribe=component\:author] span{display:block}.twitter-feed-style .user [data-scribe=component\:author] [data-scribe=element\:name]{color:#242424;font-weight:700}.twitter-feed-style .user [data-scribe=component\:author] [data-scribe=element\:screen_name]{color:#8c8c8c;font-size:14px}.twitter-feed-style .tweet{color:#8c8c8c;word-break:break-all;margin-top:4rem;margin-bottom:.464286em}.twitter-feed-style .tweet a{margin:0 3px}.twitter-feed-style .tweet,.twitter-feed-style .timePosted{width:82%;float:right}.twitter-feed-style .timePosted{margin-bottom:0;font-size:14px}.twitter-feed-style .timePosted a{color:#8c8c8c}.twitter-feed-style .interact{display:none}.twitter-feed-alt .user [data-scribe=component\:author]{display:none}.twitter-feed-alt .tweet{margin-top:0}.twitter-feed-alt:after{content:""}.floating-search-wrap{position:fixed;top:40%;left:3%}.floating-search-wrap a{color:#242424;margin-bottom:1.5rem;text-decoration:none;display:block}.floating-search-wrap a:hover{color:#09c}.floating-social-link{position:fixed;top:70%;right:0%;transform:translate(30%)rotate(-90deg)}.floating-social-link a{color:#242424;margin-left:.5rem;text-decoration:none}.floating-social-link a:hover{color:#09c}.floating-social-link span{color:#ccc}@media (max-width:1249px){.floating-search-wrap,.floating-social-link{display:none}}.blog-post{border-bottom:1px solid #ccc;margin-bottom:3.5rem;padding-bottom:3rem}.meta a,.meta.text-white a{color:#616161}.meta .meta-separator,.meta.text-white .meta-separator{width:30px;border-top:1px solid #616161;margin:0 15px;display:inline-block;position:relative;bottom:3px}.meta.text-white a{color:#fff}.meta.text-white .meta-separator{border-top:1px solid #fff}.blog-widget .instagram-feed a{width:95px;height:95px}.blog-single p{margin-bottom:3rem}.single-post .comments-area,.single-post .comments{margin-bottom:5rem;display:block}.single-post .comments-area .comments-title,.single-post .comments .comments-title{margin-bottom:5rem;font-size:28px}.single-post .comments-area ol,.single-post .comments-area ul,.single-post .comments ol,.single-post .comments ul,.single-post .comments-area ol ol,.single-post .comments-area ol ul,.single-post .comments-area ul ol,.single-post .comments-area ul ul,.single-post .comments ol ol,.single-post .comments ol ul,.single-post .comments ul ol,.single-post .comments ul ul{list-style:none}.single-post .comment-list,.single-post .comments>ul{margin:0;padding:0;list-style:none}.single-post .comment-list li,.single-post .comments>ul li{margin-bottom:1rem}.single-post .comment-list li .comment-body,.single-post .comments>ul li .comment-body{border-bottom:1px solid #e8e8e8;margin-bottom:3rem;padding-bottom:1.5rem;position:relative}.single-post .comment-list .comment-meta,.single-post .comments>ul .comment-meta{margin-bottom:1rem}.single-post .comment-list .comment-meta .comment-author img,.single-post .comments>ul .comment-meta .comment-author img{width:100px;height:100px;float:left;border-radius:6px;margin-right:2rem}.single-post .comment-list .comment-meta .comment-author a,.single-post .comments>ul .comment-meta .comment-author a{font-size:16px;font-weight:700}.single-post .comment-list .comment-meta .comment-author .says,.single-post .comments>ul .comment-meta .comment-author .says{display:none}.single-post .comment-list .comment-meta .comment-metadata a,.single-post .comments>ul .comment-meta .comment-metadata a{color:#8c8c8c;font-size:14px}.single-post .comment-list .comment-content,.single-post .comments>ul .comment-content{overflow:hidden}.single-post .comment-list .reply,.single-post .comments>ul .reply{position:absolute;top:0;right:0}.single-post .comment-list .reply a,.single-post .comments>ul .reply a{color:#09c}.single-post .comment-list .reply a:hover,.single-post .comments>ul .reply a:hover{color:#242424}@media (max-width:991px){.single-post .comments-area .comments-title,.comment-reply-title{font-size:1.5rem}.single-post .comments-area .comments-title{margin-bottom:3rem}}@media (max-width:767px){.single-post .comments-area .comments-title,.comment-reply-title{font-size:1.2rem}.single-post .comments-area .comment-list .comment-meta .comment-author img{width:50px;height:auto}.blog-post{margin-bottom:1.5rem;padding-bottom:1.5rem}}.form-qty{height:calc(2.25rem + 8px)}.bd-toc{order:2;padding-top:1.5rem;padding-bottom:1.5rem;font-size:.875rem}@supports (position: sticky){.bd-toc{height:calc(100vh - 4rem);position:sticky;top:4rem;overflow-y:auto}}.section-nav{border-left:1px solid #eee;padding-left:0}.section-nav ul{padding-left:1rem}.toc-entry{display:block}.toc-entry a{color:#77757a;padding:.125rem 1.5rem;display:block}.toc-entry a:hover{color:#007bff;text-decoration:none}.bd-sidebar{order:0}@media (min-width:768px){.bd-sidebar{border-right:1px solid #0000001a}@supports (position: sticky){.bd-sidebar{z-index:1000;height:calc(100vh - 4rem);position:sticky;top:4rem}}}@media (min-width:1200px){.bd-sidebar{flex:0 320px}}@media (prefers-color-scheme:dark){.bd-sidebar{border-right-color:#414141}}.bd-links{margin-left:-15px;margin-right:-15px;padding-top:1rem;padding-bottom:1rem}@media (min-width:768px){@supports (position: sticky){.bd-links{max-height:calc(100vh - 9rem);overflow-y:auto}}.bd-links{display:block!important}}.bd-search{border-bottom:1px solid #0000000d;margin-left:-15px;margin-right:-15px;padding:1rem 15px;position:relative}.bd-search .form-control:focus{border-color:#fc0;box-shadow:0 0 0 3px #ffcc0040}.bd-search-docs-toggle{color:#212529}@media screen and (prefers-color-scheme:dark){.bd-search-docs-toggle{color:#ccc}.bd-search-docs-toggle:hover{color:#e8e8e8}}.bd-sidenav{display:none}.bd-toc-link{color:#000000a6;padding:.25rem 1.5rem;font-weight:600;display:block}.bd-toc-link:hover{color:#000000d9;text-decoration:none}.bd-toc-link code{color:#e83e8c}.bd-toc-link.selected{color:#09c;font-weight:800}.bd-toc-link.selected:hover{color:#069}@media screen and (prefers-color-scheme:dark){.bd-toc-link{color:#fff}.bd-toc-link:hover{color:#ccc}}.bd-toc-item.active{margin-bottom:1rem}.bd-toc-item.active:not(:first-child){margin-top:1rem}.bd-toc-item.active>.bd-toc-link{color:#000000d9}.bd-toc-item.active>.bd-toc-link:hover{background-color:#0000}.bd-toc-item.active>.bd-sidenav{display:block}.bd-sidebar .nav>li>a{color:#000000a6;padding:.25rem 1.5rem;font-size:90%;display:block}.bd-sidebar .nav>li>a:hover{color:#000000d9;background-color:#0000;text-decoration:none}.bd-sidebar .nav>.active>a,.bd-sidebar .nav>.active:hover>a{color:#000000d9;background-color:#0000;font-weight:600}.navbar{flex-wrap:wrap;justify-content:space-between;align-items:center;padding:.5rem 1rem;display:flex;position:relative}.navbar>.container,.navbar>.container-fluid{flex-wrap:wrap;justify-content:space-between;align-items:center;display:flex}.navbar-brand{font-size:1.25rem;line-height:inherit;white-space:nowrap;margin-right:1rem;padding-top:.3125rem;padding-bottom:.3125rem;display:inline-block}.navbar-brand:hover,.navbar-brand:focus{text-decoration:none}.navbar-nav{flex-direction:column;margin-bottom:0;padding-left:0;list-style:none;display:flex}.navbar-nav .nav-link{padding-left:0;padding-right:0}.navbar-nav .dropdown-menu{float:none;position:static}.navbar-text{padding-top:.5rem;padding-bottom:.5rem;display:inline-block}.navbar-collapse{flex-grow:1;flex-basis:100%;align-items:center}.navbar-toggler{background-color:#0000;border:1px solid #0000;border-radius:.25rem;padding:.25rem .75rem;font-size:1.25rem;line-height:1}.navbar-toggler:hover,.navbar-toggler:focus{text-decoration:none}.navbar-toggler:not(:disabled):not(.disabled){cursor:pointer}.navbar-toggler-icon{width:1.5em;height:1.5em;vertical-align:middle;content:"";background:50%/100% 100% no-repeat;display:inline-block}@media (max-width:575.98px){.navbar-expand-sm>.container,.navbar-expand-sm>.container-fluid{padding-left:0;padding-right:0}}@media (min-width:576px){.navbar-expand-sm{flex-flow:row;justify-content:flex-start}.navbar-expand-sm .navbar-nav{flex-direction:row}.navbar-expand-sm .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-sm .navbar-nav .dropdown-menu-right{left:auto;right:0}.navbar-expand-sm .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand-sm>.container,.navbar-expand-sm>.container-fluid{flex-wrap:nowrap}.navbar-expand-sm .navbar-collapse{flex-basis:auto;display:flex!important}.navbar-expand-sm .navbar-toggler{display:none}.navbar-expand-sm .dropup .dropdown-menu{top:auto;bottom:100%}}@media (max-width:767.98px){.navbar-expand-md>.container,.navbar-expand-md>.container-fluid{padding-left:0;padding-right:0}}@media (min-width:768px){.navbar-expand-md{flex-flow:row;justify-content:flex-start}.navbar-expand-md .navbar-nav{flex-direction:row}.navbar-expand-md .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-md .navbar-nav .dropdown-menu-right{left:auto;right:0}.navbar-expand-md .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand-md>.container,.navbar-expand-md>.container-fluid{flex-wrap:nowrap}.navbar-expand-md .navbar-collapse{flex-basis:auto;display:flex!important}.navbar-expand-md .navbar-toggler{display:none}.navbar-expand-md .dropup .dropdown-menu{top:auto;bottom:100%}}@media (max-width:991.98px){.navbar-expand-lg>.container,.navbar-expand-lg>.container-fluid{padding-left:0;padding-right:0}}@media (min-width:992px){.navbar-expand-lg{flex-flow:row;justify-content:flex-start}.navbar-expand-lg .navbar-nav{flex-direction:row}.navbar-expand-lg .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-lg .navbar-nav .dropdown-menu-right{left:auto;right:0}.navbar-expand-lg .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand-lg>.container,.navbar-expand-lg>.container-fluid{flex-wrap:nowrap}.navbar-expand-lg .navbar-collapse{flex-basis:auto;display:flex!important}.navbar-expand-lg .navbar-toggler{display:none}.navbar-expand-lg .dropup .dropdown-menu{top:auto;bottom:100%}}@media (max-width:1199.98px){.navbar-expand-xl>.container,.navbar-expand-xl>.container-fluid{padding-left:0;padding-right:0}}@media (min-width:1200px){.navbar-expand-xl{flex-flow:row;justify-content:flex-start}.navbar-expand-xl .navbar-nav{flex-direction:row}.navbar-expand-xl .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-xl .navbar-nav .dropdown-menu-right{left:auto;right:0}.navbar-expand-xl .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand-xl>.container,.navbar-expand-xl>.container-fluid{flex-wrap:nowrap}.navbar-expand-xl .navbar-collapse{flex-basis:auto;display:flex!important}.navbar-expand-xl .navbar-toggler{display:none}.navbar-expand-xl .dropup .dropdown-menu{top:auto;bottom:100%}}.navbar-expand{flex-flow:row;justify-content:flex-start}.navbar-expand>.container,.navbar-expand>.container-fluid{padding-left:0;padding-right:0}.navbar-expand .navbar-nav{flex-direction:row}.navbar-expand .navbar-nav .dropdown-menu{position:absolute}.navbar-expand .navbar-nav .dropdown-menu-right{left:auto;right:0}.navbar-expand .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand>.container,.navbar-expand>.container-fluid{flex-wrap:nowrap}.navbar-expand .navbar-collapse{flex-basis:auto;display:flex!important}.navbar-expand .navbar-toggler{display:none}.navbar-expand .dropup .dropdown-menu{top:auto;bottom:100%}.navbar-light .navbar-brand{color:#000000e6}.navbar-light .navbar-brand:hover,.navbar-light .navbar-brand:focus{color:#000000e6}.navbar-light .navbar-nav .nav-link{color:#00000080}.navbar-light .navbar-nav .nav-link:hover,.navbar-light .navbar-nav .nav-link:focus{color:#000000b3}.navbar-light .navbar-nav .nav-link.disabled{color:#0000004d}.navbar-light .navbar-nav .show>.nav-link,.navbar-light .navbar-nav .active>.nav-link,.navbar-light .navbar-nav .nav-link.show,.navbar-light .navbar-nav .nav-link.active{color:#000000e6}.navbar-light .navbar-toggler{color:#00000080;border-color:#0000001a}.navbar-light .navbar-toggler-icon{background-image:url("data:image/svg+xml,")}.navbar-light .navbar-text{color:#00000080}.navbar-light .navbar-text a{color:#000000e6}.navbar-light .navbar-text a:hover,.navbar-light .navbar-text a:focus{color:#000000e6}.navbar-dark .navbar-brand{color:#fff}.navbar-dark .navbar-brand:hover,.navbar-dark .navbar-brand:focus{color:#fff}.navbar-dark .navbar-nav .nav-link{color:#ffffff80}.navbar-dark .navbar-nav .nav-link:hover,.navbar-dark .navbar-nav .nav-link:focus{color:#ffffffbf}.navbar-dark .navbar-nav .nav-link.disabled{color:#ffffff40}.navbar-dark .navbar-nav .show>.nav-link,.navbar-dark .navbar-nav .active>.nav-link,.navbar-dark .navbar-nav .nav-link.show,.navbar-dark .navbar-nav .nav-link.active{color:#fff}.navbar-dark .navbar-toggler{color:#ffffff80;border-color:#ffffff1a}.navbar-dark .navbar-toggler-icon{background-image:url("data:image/svg+xml,")}.navbar-dark .navbar-text{color:#ffffff80}.navbar-dark .navbar-text a{color:#fff}.navbar-dark .navbar-text a:hover,.navbar-dark .navbar-text a:focus{color:#fff}.bd-navbar{min-height:4rem;background-color:#fff;box-shadow:0 .5rem 1rem #0000000d,inset 0 -1px #0000001a}@media (max-width:991.98px){.bd-navbar{padding-left:.5rem;padding-right:.5rem}.bd-navbar .navbar-nav-scroll{max-width:100%;height:2.5rem;margin-top:.25rem;font-size:.875rem;overflow:hidden}.bd-navbar .navbar-nav-scroll .navbar-nav{white-space:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:2rem;overflow-x:auto}}@media (min-width:768px){@supports (position: sticky){.bd-navbar{z-index:1071;position:sticky;top:0}}}.bd-navbar .navbar-nav .nav-link{color:#09c;padding-left:.5rem;padding-right:.5rem}.bd-navbar .navbar-nav .nav-link.active,.bd-navbar .navbar-nav .nav-link:hover{color:#069;background-color:#0000}.bd-navbar .navbar-nav .nav-link.active{font-weight:500}.bd-navbar .navbar-nav-svg{width:1rem;height:1rem;vertical-align:text-top;display:inline-block}.bd-navbar .dropdown-menu{font-size:.875rem}.bd-navbar .dropdown-item.active{color:#212529;background-color:#0000;background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath fill='%23292b2c' d='M2.3 6.73L.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3E%3C/svg%3E");background-position:.4rem .6rem;background-repeat:no-repeat;background-size:.75rem .75rem;font-weight:500}@media screen and (prefers-color-scheme:dark){.bd-navbar{color:#fff;background-color:#0f0f0f;box-shadow:0 2px 4px -1px #0003,0 4px 5px #00000024,0 1px 10px #0000001f}}.bg-primary{background:#09c}.bg-success{background:#96be5d}.bg-warning{background:#fab63f}.bg-info{background:#18b9d4}.bg-danger{background:#ef5a5a}.text-primary{color:#09c}.text-purple{color:#7431ff}.text-muted{color:#8c8c8c!important}.rounded{border-radius:6px!important}.card{border-color:#e8e8e8;border-radius:6px}.card-img-top{border-top-left-radius:6px;border-top-right-radius:6px}.card-footer{background:0 0;border-top:1px solid #0000000f;padding:1.1rem 1.25rem}.bg-dark .card-footer{border-top:1px solid #ffffff0f}.alert-secondary{color:#242424;background-color:#f4f5f7;border-color:#e8e8e8}.alert-warning{color:#fab63f;background-color:#fef8ec;border-color:#fab63f}.alert-success{color:#7dad14;background-color:#f3f8ed;border-color:#7dad14}.alert-danger{color:#ef5a5a;background-color:#fdeced;border-color:#ef5a5a}.alert-primary{color:#09c;background-color:#eaf4ff;border-color:#09c}.alert-solid-secondary{color:#242424;background-color:#e8e8e8;border-color:#e8e8e8}.alert-solid-warning{color:#fff;background-color:#fab63f;border-color:#fab63f}.alert-solid-success{color:#fff;background-color:#7dad14;border-color:#7dad14}.alert-solid-danger{color:#fff;background-color:#ef5a5a;border-color:#ef5a5a}.alert-solid-primary{color:#fff;background-color:#09c;border-color:#09c}.list-group-item{color:#8c8c8c;border-color:#e8e8e8;padding:1.3rem 1.25rem}.badge{position:relative;bottom:1px}.custom-modal .modal-body{padding:2.5rem}.custom-modal .modal-content{border:none}.custom-modal .modal-header{padding:1rem}.custom-modal .modal-header .close{padding:.5rem 1rem}.modal-body{padding:1.8rem}.modal-header,.modal-footer{padding:1rem 1.8rem}@media screen and (prefers-color-scheme:dark){.modal-header{border-bottom-color:#414141}.modal-footer{border-top-color:#414141}}.modal-image{border-top-left-radius:.25rem;border-top-right-radius:.25rem;position:relative}.modal-image .close{width:50px;height:50px;opacity:1;text-shadow:none;background:#fff;border-radius:50%;line-height:50px;position:absolute;top:1.875rem;right:1.875rem}.modal-image .close:hover{color:#fff;opacity:1;background:#09c}@media (min-width:576px){.modal-dialog{max-width:600px}}@media (min-width:992px){.modal-lg,.modal-xl{max-width:800px}}.ls-2{letter-spacing:1rem}.ls-3{letter-spacing:2rem}.lh-35{line-height:35px}.lh-45{line-height:45px}.h60{height:60%}.h70{height:70%}.curve-bottom-1,.curve-bottom-right{clip-path:polygon(0 0,100% 0,100% 85%,70% 100%,0 85%)}.curve-top-bottom{clip-path:polygon(100% 6%,100% 100%,68% 94%,0% 100%,0 10%,28% 0)}.curve-bottom-center{clip-path:polygon(0 0,100% 0,100% 70%,50% 100%,0 70%)}.font-lora{font-family:Lora,serif}.font-weight-300{font-weight:300}.font-weight-400{font-weight:400}.font-weight-600{font-weight:600}.font-weight-700{font-weight:700}.font-weight-800{font-weight:800}.font-size-12{font-size:12px}.font-size-14{font-size:14px}.font-size-16{font-size:16px}.font-size-20{font-size:20px!important}.font-size-60{font-size:60px}.font-size-72{font-size:72px}.i-size-60{font-size:60px}.section-gray,.bg-gray{background-color:#e8e8e8}@media screen and (prefers-color-scheme:dark){.section-gray,.bg-gray{background-color:#2f2f2f}.text-dark{color:#e8e8e8!important}}.bg-white{background:#fff}.bg-dark{background:#242424!important}.bg-dark hr{border-top:1px solid #ffffff80}@media screen and (prefers-color-scheme:dark){hr{border-top-color:#414141}}.bg-green-light{background:#d7f5e3}.bg-dark-alt{background:#303030}.bg-extra{background:#e5e8ec}.component-section{padding:4rem 0;position:relative;overflow:hidden}.show-markup-section{position:relative}.demo .btn{margin:0 .4rem 1rem}.title-separator{margin-bottom:4rem;position:relative}.title-separator:after{content:"";width:60px;height:2px;background:#fff;position:absolute;bottom:-2rem;left:0}.gradient-primary{background-image:linear-gradient(90deg,#09c 0%,#7431ff 100%)}.cta-img{background-position:50%;background-repeat:no-repeat;background-size:cover;position:relative;overflow:hidden}.border-light{border-color:#ffffff20!important}.custom-dropdown{border:none;box-shadow:0 1px 10px #97a4af26}.custom-dropdown .dropdown-item{font-size:12px}.custom-dropdown-sm{min-width:6rem}.opacity-30{opacity:.3}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-80{opacity:.8}.opacity-90{opacity:.9}.opacity-100{opacity:1}.avatar-sm{width:35px;height:35px}.avatar,.avatar-md{width:70px;height:70px}.avatar-lg{width:140px;height:140px}.icon-sm{font-size:28px}.icon-md{font-size:42px}.icon-lg{font-size:56px}.ft-tag{color:#fff;background:#09c;border-radius:30px;padding:3px 12px;font-size:11px;font-weight:700}.ft-inside-tl{position:absolute;top:1rem;left:1rem}.ft-inside-tr{position:absolute;top:1rem;right:1rem}.ft-inside-bl{position:absolute;bottom:1rem;left:1rem}.ft-inside-br{position:absolute;bottom:1rem;right:1rem}.ft-overflow-bl{border:2px solid #fff;position:absolute;bottom:-.8rem;left:1rem}.ft-overflow-br{border:2px solid #fff;position:absolute;bottom:-.8rem;right:1rem}.ft-overflow-bc{border:2px solid #fff;position:absolute;bottom:-.8rem;left:50%;transform:translate(-50%)}.ft-overflow-tl{border:2px solid #fff;position:absolute;top:2rem;left:-2rem}.ft-overflow-tr{border:2px solid #fff;position:absolute;top:2rem;right:-2rem}.ft-overflow-tc{border:2px solid #fff;position:absolute;top:-1rem;left:50%;transform:translate(-50%)}@media (max-width:991px){.component-section{padding:3rem 0}}@media (max-width:767px){.i-size-60{font-size:3rem}.lh-35,.lh-45{line-height:normal}.ls-2{letter-spacing:.5rem}.font-size-60{font-size:28px}.font-size-72{font-size:32px}.icon-md{font-size:2rem}.icon-lg{font-size:2.5rem}.border-sm-right-0{border-right:none!important}.curve-top-bottom,.curve-bottom-1,.curve-bottom-right{clip-path:polygon(0 0,100% 0,100% 100%,0 100%)}.btn-sm-block{width:100%;padding:.75rem 2rem;display:block}}@media (min-width:991px){.neg-mt-100{margin-top:-100px}.neg-mt-300{margin-top:-300px}.clab-shape{padding-bottom:13.5rem;overflow:hidden}.clab-shape:after{content:"ă";color:#1420f11a;font-size:1200px;font-weight:800;position:absolute;top:-35%;left:50%;transform:translate(-50%)}.clab-shape .container{z-index:1;position:relative}}.markup-example{position:relative}.markup-example .btn{z-index:2;padding:.385rem 1rem;line-height:normal;position:absolute;top:.5rem;right:.5rem}.markup-example pre[class*=language-]{background:#e8e8e8;border-radius:6px;padding:3rem 1rem 1rem}.component-section>button,.show-markup-section>button{z-index:1000;opacity:0;transition:opacity .2s linear;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.component-section:hover>button,.show-markup-section:hover>button{opacity:1}.clip-txt{text-align:center;color:#0000;background-position:50%;background-size:cover;background-clip:text;-webkit-background-clip:text;font-size:15rem;font-weight:700;line-height:normal}@media (max-width:565px){.clip-txt{font-size:6rem}}@media (min-width:769px){.clip-txt{font-size:25rem}}.landing-slider .owl-carousel .owl-item img{width:100%}@media screen and (max-width:991px){.wow{visibility:visible!important;animation-name:none!important}}.buy-link{color:#fff;z-index:1200;text-transform:uppercase;text-align:center;background:#82b440;border-radius:0 5px 5px 0;padding:.6rem;font-size:12px;font-weight:700;transition:all .3s;position:fixed;top:30%;left:-5px}.buy-link:hover{color:#fff;text-decoration:none;left:0}html body{background-color:#fff}@media screen and (prefers-color-scheme:dark){html body{color:#fff;background-color:#000}}body.modal-open{overflow:hidden}.report-view-box{height:80vh;white-space:pre-wrap;cursor:default;overflow:hidden}.report-view-box>div{height:100%;max-width:1035px;margin:auto;overflow:auto}.report-view-box .split-view-container{display:flex;overflow:hidden}.report-view-box .split-view-container .solidity-coverage-container{width:100%;min-width:0;flex-direction:column;flex-grow:0;display:flex}.report-view-box .split-view-container .solidity-coverage-container .solidity-coverage{height:100%;overflow:auto}.report-view-box .split-view-container .solidity-coverage-container .message-box{height:25%}@media screen and (prefers-color-scheme:dark){.report-view-box .split-view-container .solidity-coverage-container .message-box table.table-light{color:#fff;background-color:#000}}.report-view-box .split-view-container .bytecode-coverage{max-width:25%;overflow:auto}.report-view-box .split-view-container .contract-explorer{width:25%;background-color:#fcfcfc;padding:8px 0;font-size:.9rem;overflow:auto}.report-view-box .split-view-container .contract-explorer>ul>li{cursor:pointer;padding:4px 8px;transition:background .3s}.report-view-box .split-view-container .contract-explorer>ul>li:hover{background:#ddd}.report-view-box .split-view-container .contract-explorer>ul>li.active{background:#8ed3f1}.report-view-box .split-view-container .contract-explorer>ul>li:first-child{font-size:1rem}.report-view-box .split-view-container .contract-explorer>ul>li:not(:first-child){border-left:1px solid #ccc;margin-left:.75rem}@media screen and (prefers-color-scheme:dark){.report-view-box .split-view-container .contract-explorer{color:#fff;background-color:#000}.report-view-box .split-view-container .contract-explorer>ul>li.active{background:#09c}}.report-view-box .split-view-container tr{border-bottom:2px solid #0000}.report-view-box .split-view-container tr:hover{cursor:pointer}.report-view-box .split-view-container tr.covered:hover{border-bottom:2px solid #91daa6}.report-view-box .split-view-container tr.weak-covered:hover{border-bottom:2px solid #d2da91}.report-view-box .split-view-container tr.not-covered:hover{border-bottom:2px solid #da919a}.report-view-box .split-view-container tr.active{filter:brightness(85%)}.report-view-box .split-view-container tr.covered.active{border-bottom:2px solid #91daa6}.report-view-box .split-view-container tr.weak-covered.active{border-bottom:2px solid #d2da91}.report-view-box .split-view-container tr.not-covered.active{border-bottom:2px solid #da919a}.report-view-box .split-view-container .has-highlight tr.text-muted.not-covered,.report-view-box .split-view-container .has-highlight tr.text-muted.covered,.report-view-box .split-view-container .has-highlight tr.text-muted.weak-covered,.report-view-box .split-view-container .has-highlight tr.text-muted tr,.report-view-box .split-view-container .has-highlight tr.text-muted td{background-color:inherit!important}.report-view-box .split-view-container .has-highlight tr.message-muted{display:none}.benefits{padding-bottom:48px}.has-highlighted>table tr:not(.highlighted) *{color:#ccc!important;background-color:inherit!important}pre[class*=language-]{background-color:inherit;padding:0}.coverage{height:100%;font-size:14px;overflow:auto}.coverage:not(.solidity-coverage){font-size:13px}.coverage tr td,.coverage tr th{white-space:nowrap;border:0;padding:0 0 0 1em;border-radius:0!important}.coverage tr td pre,.coverage tr th pre{background:inherit;margin:0;padding:0}.coverage tr th{border-bottom:1px solid #dfdfdf;font-size:16px}.coverage tr td.index,.coverage tr th.index{text-align:right;width:3em;border-right:1px solid #ccc;padding-right:1ch}.coverage tr td.index{background-color:#fafbfc}.coverage tr td.opcode{font-weight:600}.coverage tr td.hit-count{text-align:center}.coverage tr.covered,.coverage tr.covered td{background-color:#e6ffed}.coverage tr.covered td.index{background-color:#dbffe3}.coverage tr.not-covered,.coverage tr.not-covered td{background-color:#ffe6e8}.coverage tr.not-covered td.index{background-color:#ffdbdf}.coverage tr.weak-covered,.coverage tr.weak-covered td{background-color:#fcffe6}.coverage tr.weak-covered td.index{background-color:#fbffdb}@media screen and (prefers-color-scheme:dark){.coverage{color:#ccc}.coverage th{color:#fff}.coverage tr.not-covered td.index,.coverage tr.covered td.index{color:#ccc}.coverage tr th.index{border-color:#414141}.coverage tr td.index{background-color:#000;border-color:#414141}.coverage tr td.opcode{color:#ccc}.coverage tr.covered,.coverage tr.covered td{background-color:#295234}.coverage tr.covered td.index{background-color:#214129}.coverage tr.not-covered,.coverage tr.not-covered td{background-color:#692217}.coverage tr.not-covered td.index{background-color:#541b12}.coverage tr.weak-covered,.coverage tr.weak-covered td{background-color:#68360b}.coverage tr.weak-covered td.index{background-color:#512a09}}.coverage table{width:100%}.mouse-pointer{cursor:pointer}.wizard-grid div{padding:10px}.wizard-grid .btn-outline,.wizard-box .btn-outline{margin-left:0}a.wizard-link:visited{color:purple}.code{background-color:#fafbfc;padding:10px}@media screen and (prefers-color-scheme:dark){.code{color:#fff;background-color:#2f2f2f}}.code-block-selectors{color:#000;width:fit-content;background-color:#e5e5e5;border-radius:4px;margin-bottom:8px;padding:2px 12px;position:absolute;top:0;left:0}@media screen and (prefers-color-scheme:dark){.code-block-selectors{color:#fff;background-color:#616161}}.nav-item{cursor:pointer}.ns-form{grid-column-gap:1rem;grid-template-columns:75% 25%;display:grid}.btn-disabled{background:#fff;border:2px solid #e8e8e8;margin-left:2em;color:gray!important}#firefly-reports,#firefly-report{margin-bottom:100px}#firefly-reports thead tr th,#firefly-report thead tr th{text-align:center;padding:.5rem .75rem}#firefly-reports tbody .report-row-header td,#firefly-report tbody .report-row-header td{text-align:center}#firefly-reports tbody .report-row-header td .report-id,#firefly-report tbody .report-row-header td .report-id{color:#09c;text-decoration:underline}#firefly-reports tbody .report-row-header td .report-id:hover,#firefly-report tbody .report-row-header td .report-id:hover{color:#007aa3}#firefly-reports .center-image,#firefly-report .center-image{padding-bottom:0;padding-left:21px;padding-right:21px}.report-buttons>ul{align-items:center;margin:0;display:flex}.report-buttons>ul>li p{margin:0}.report-buttons>ul>li:not(:last-child){margin-right:1.5rem}.report-buttons>ul .dropdown{display:inline-block}.report-buttons>ul .dropdown.show{outline:2px solid #09c}.report-buttons>ul .dropdown img{height:2rem}.report-buttons>ul .dropdown img:hover{outline:1px solid #09c}.report-buttons>ul .dropdown-toggle:after{content:none}@media screen and (prefers-color-scheme:dark){.report-buttons>ul{color:#fff}.report-buttons>ul .dropdown-menu,.report-buttons>ul .dropdown-item{color:#fff;background-color:#000}.report-buttons>ul .dropdown-item:hover{color:#c2c2c2}}@media (prefers-color-scheme:dark){.dropdown-menu,.dropdown-item{color:#fff;background-color:#1b1b1b}.dropdown-item:hover{color:#fff;background-color:#2f2f2f}}.report-coverage-row td{position:relative}.report-coverage-row .report-container .fullscreen-btn{cursor:pointer;color:#09c;font-size:2rem;position:absolute;top:.5rem;right:2rem}.report-coverage-row .report-container.fullscreen{width:100%;height:100%;z-index:10;background-color:#000000e6;padding:2rem;transition:all .15s linear;position:fixed;top:0;left:0}.report-coverage-row .report-container.fullscreen .report-wrapper{height:100%;background-color:#fff;border-radius:.3rem;padding:2rem;animation-name:zoom;animation-duration:.6s;position:relative;overflow:auto}.report-coverage-row .report-container.fullscreen .report-wrapper .fullscreen-btn{position:fixed;top:2rem;right:2.8rem}.report-coverage-row .report-container.fullscreen .report-wrapper .report-view-box{height:calc(100vh - 256px)}@media screen and (prefers-color-scheme:dark){.report-coverage-row .report-container.fullscreen .report-wrapper{background-color:#000}.report-coverage-row .report-container.fullscreen .report-wrapper th{color:#fff}}.report-coverage-row .report-container.fullscreen .coverage,.report-coverage-row .report-container.fullscreen .split-view-container{max-width:initial}.introjs-hint.introjs-fixedhint{z-index:11}i.fa{margin:0 1ch}.expandable-title{padding:.3rem 0;transition:all .3s}.expandable-title:hover{cursor:pointer;color:#09c}.expandable-title:not(.contract-title){font-weight:400}.contract-title .contract-coverage{float:right}.contract-hint-trigger{text-align:center;display:block}.contract-hint-trigger:hover{cursor:pointer;color:#fc0}.contract-hint-trigger .contract-hint-trigger-hidden{display:none}.source-name{border-bottom:1px solid #ccc;font-size:12px}@media screen and (prefers-color-scheme:dark){.source-name{color:#fff;border-color:#414141}}.indent-2{padding-left:2ch}.btn-download-report{background-image:url(Firefly-Download-Icon.8094a4f0.png)}.btn-download-report:hover{background-image:url(Firefly-Download-Icon-Inverted.32636383.png)}.btn-copy-report-id{cursor:pointer;background-size:cover;display:inline-block;font-size:1rem!important}@media (min-width:1025px){#firefly-header:not(.sticky-nav)>.container>.row>.col-12{min-height:150px}.vlmenu>li:not(:last-child){margin-right:20px}.vlmenu>li>a{padding-bottom:0}.vlmenu li:hover{border-bottom:2px solid #fc0}.vlmenu li.active{border-bottom:2px solid #fc0}.vlmenu li>ul{z-index:1}#dashboard-submenu{position:relative}#dashboard-submenu>ul{z-index:0;box-shadow:none;width:260px;justify-content:space-between;display:flex;position:absolute;top:50px;right:0}#dashboard-submenu>ul>li{display:inline-block}#dashboard-submenu>ul>li>a{padding:0;display:inline-block}#dashboard-submenu>ul>li>a:hover{color:#000;background:0 0}}@media screen and (min-width:1025px) and (prefers-color-scheme:dark){#dashboard-submenu>ul>li>a:hover{color:#fff}}.breadcrumb{background-color:inherit}.breadcrumb-item+.breadcrumb-item:before{content:">"!important}div.table-responsive{padding:0 8px}#youtube-video{height:303.75px;width:540px;max-width:100%;background-color:#d7d7d7;justify-content:center;align-items:center;display:flex}video{width:100%!important;height:auto!important}.gif:hover{opacity:.7}.custom-control-input:checked~.custom-control-label:before{background-color:#09c}.divider-bar-closed{color:#fff;background:#09c}.divider-bar-closed:hover{background:#008ab8}.divider-bar-opened{background:#fc0}.divider-bar-opened:hover{background:#e6b800}.divider-bar{cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;transition:background .2s ease-in-out;display:flex}.divider-bar span{letter-spacing:1px}@media screen and (prefers-color-scheme:dark){.divider-bar{color:#fff;background:#343434}.divider-bar:hover{background-color:#393939}}.divider-bar-vertical{width:1.3rem;flex-direction:column}.divider-bar-vertical span{writing-mode:vertical-lr;text-orientation:sideways}.divider-bar-vertical i{margin:1ch 0}.divider-bar-horizontal{height:1.3rem;flex-direction:row}#contact-links li:hover{cursor:pointer;border:none!important}#contact-links img{height:1.5rem}#firefly-profile .btn{margin:4px auto;padding:4px 1rem}.icon{color:#09c;font-size:2rem;transition:color .2s}.icon:hover{color:#069}.icon.active{color:#fc0}.icon.active:hover{color:#ccb400}@media screen and (prefers-color-scheme:dark){.introjs-tooltip{background-color:#000}.introjs-helperLayer{background-color:#414141e6}}.modal{width:100%;height:100%;background-color:#000000e6;display:none;position:fixed;top:0;left:0;overflow:auto}#email-modal{z-index:2000}.modal-content{width:80%;max-width:1024px;margin:auto;display:block}@media screen and (prefers-color-scheme:dark){.modal-content{color:#fff;background-color:#141414}}video.modal-content{margin-top:100px}#modal-caption{width:80%;max-width:700px;text-align:center;color:#ccc;margin:auto;padding:10px 0;display:block}.modal-content,#modal-caption{animation-name:zoom;animation-duration:.6s}@keyframes zoom{0%{transform:scale(0)}to{transform:scale(1)}}.close{color:#09c;z-index:99;font-size:50px;font-weight:700;transition:all .3s;position:absolute;top:15px;right:35px}.close:hover,.close:focus{color:#fc0;cursor:pointer;text-decoration:none}@media only screen and (max-width:1024px){.modal-content{width:100%}}#firefly-feedback{z-index:999;position:fixed;bottom:30px;right:30px}#firefly-feedback>picture>img{width:100px}#firefly-feedback img{cursor:pointer;opacity:.7;transition:opacity .3s}#firefly-feedback img:hover{opacity:1}#firefly-feedback .feedback-form{background:#fff;border-radius:4px;flex-direction:column;justify-content:space-evenly;padding:24px;display:flex;box-shadow:1px 2px 10px #0003}#firefly-feedback .feedback-form .fa-times{cursor:pointer;opacity:.5;transition:opacity .3s;position:absolute;top:25px;right:25px}#firefly-feedback .feedback-form .fa-times:hover{opacity:1}#firefly-feedback .feedback-form .feedback-rating{justify-content:space-evenly;display:flex}#firefly-feedback .feedback-form .feedback-rating>picture>img{height:120px;margin:4px 18px}#firefly-feedback .feedback-form .feedback-message{float:left;width:100%;height:150px;margin-top:10px;margin-bottom:10px;overflow:scroll}@media only screen and (max-width:767px){#firefly-feedback .feedback-form{position:fixed;bottom:8px;left:8px;right:8px}#firefly-feedback .feedback-form .feedback-rating>picture>img{height:100px}}@media screen and (prefers-color-scheme:dark){#firefly-feedback .feedback-form{color:#fff;background-color:#000}}#contact-links img{margin-right:1rem}#bytecodes,#solidity-files,#contract-links{margin-bottom:24px}.drop-area{text-align:center;height:64px;cursor:pointer;background-color:#f7f8fa;border-style:dashed;border-color:#616161;margin-top:0;margin-bottom:0}.drop-area:hover{background-color:#edf1f4}.drop-area p{margin:0;position:relative;top:50%;transform:translateY(-50%)}.drop-area.uploader{margin-bottom:0}@media screen and (prefers-color-scheme:dark){.drop-area{color:#242424;border-color:#777}}.ratings,.ratings p{display:inline-block}.ratings #positive{text-align:left}.ratings #indifferent{text-align:center}.ratings #negative{text-align:right}.feedback-table{height:70%}.color-erc20-green{color:#007f3a!important}.background-color-erc20-green{background-color:#007f3a!important}#erc20-dashboard .bytecode-row-header h6 a,#erc20-bytecode .bytecode-row-header h6 a,#erc20-dev-dashboard .bytecode-row-header h6 a{color:#09c;text-decoration:underline}#erc20-dashboard .bytecode-row-header h6 a:hover,#erc20-bytecode .bytecode-row-header h6 a:hover,#erc20-dev-dashboard .bytecode-row-header h6 a:hover{color:#007aa3}#erc20-dashboard .markdown-preview,#erc20-bytecode .markdown-preview,#erc20-dev-dashboard .markdown-preview{border:1px solid #e8e8e8;border-radius:4px;margin-bottom:32px;padding:8px}#erc20-dashboard .markdown-preview pre[class*=language-],#erc20-bytecode .markdown-preview pre[class*=language-],#erc20-dev-dashboard .markdown-preview pre[class*=language-]{word-break:normal;white-space:pre-wrap;background-color:#f7f8fa;padding:16px;font-size:.85rem;overflow:auto}@media screen and (prefers-color-scheme:dark){#erc20-dashboard .markdown-preview,#erc20-bytecode .markdown-preview,#erc20-dev-dashboard .markdown-preview{color:#e8e8e8;border:1px solid #414141}#erc20-dashboard .markdown-preview pre[class*=language-],#erc20-bytecode .markdown-preview pre[class*=language-],#erc20-dev-dashboard .markdown-preview pre[class*=language-]{background-color:#1d1f21}#erc20-dashboard,#erc20-bytecode,#erc20-dev-dashboard,#erc20-dashboard .table,#erc20-bytecode .table,#erc20-dev-dashboard .table{color:#fff}}.logo-link{color:#242424}@media screen and (prefers-color-scheme:dark){.logo-link{color:#fff}}pre[class*=language-],pre{word-break:normal;white-space:pre-wrap;background-color:#f7f8fa;padding:16px;font-family:Inconsolata,Monaco,Consolas,Courier New,Courier,monospace;font-size:.85rem;overflow:auto}code[class*=language-]{font-family:Inconsolata,Monaco,Consolas,Courier New,Courier,monospace}pre[class*=language-]{border-radius:.3em;margin:.5em 0;padding:1em;overflow:auto}@media screen and (prefers-color-scheme:dark){pre[class*=language-],pre{color:#c5c8c6;background-color:#1d1f21}}.h1 a,.h2 a,.h3 a,.h4 a,.h5 a,.h6 a,h1 a,h2 a,h3 a,h4 a,h5 a,h6 a{color:#09c}.h1 a:hover,.h2 a:hover,.h3 a:hover,.h4 a:hover,.h5 a:hover,.h6 a:hover,h1 a:hover,h2 a:hover,h3 a:hover,h4 a:hover,h5 a:hover,h6 a:hover{color:#069}.rv-btn{color:#242424;background-color:#fff;border-color:#242424}.rv-btn:hover{background-color:#f2f2f2;border-color:#171717}@media screen and (prefers-color-scheme:dark){.rv-btn{color:#fff;background-color:#242424;border-color:#fff}.rv-btn:hover{color:#fff;background-color:#212121;border-color:#f2f2f2}}.rv-btn-yellow{color:#242424;background-color:#fc0;border-color:#fc0}.rv-btn-yellow:hover{background-color:#e6b800;border-color:#e6b800}@media screen and (prefers-color-scheme:dark){.rv-btn-yellow{background-color:#ccb400;border-color:#ccb400}.rv-btn-yellow:hover{background-color:#b39e00;border-color:#b39e00}}.rv-btn-blue{background-color:#09c;border-color:#09c;color:#fff!important}.rv-btn-blue:hover{background-color:#0086b3;border-color:#0086b3;color:#fff!important}@media screen and (prefers-color-scheme:dark){.rv-btn-blue{background-color:#069;border-color:#069}.rv-btn-blue:hover{background-color:#005580;border-color:#005580}}.rv-btn-red{background-color:#f04124;border-color:#f04124;color:#fff!important}.rv-btn-red:hover{background-color:#ea2f10;border-color:#ea2f10;color:#fff!important}@media screen and (prefers-color-scheme:dark){.rv-btn-red{background-color:#cf2a0e;border-color:#cf2a0e}.rv-btn-red:hover{background-color:#b7250c;border-color:#b7250c}}.rv-btn-green{background-color:#007f3a;border-color:#007f3a;color:#fff!important}.rv-btn-green:hover{background-color:#00662e;border-color:#00662e;color:#fff!important}@media screen and (prefers-color-scheme:dark){.rv-btn-green{background-color:#007f3a;border-color:#007f3a}.rv-btn-green:hover{background-color:#00662e;border-color:#00662e}}.card{position:relative;overflow:hidden;box-shadow:0 8px 16px #0000001a}.card:hover{transition:all .3s;box-shadow:0 8px 16px #0003}@media screen and (prefers-color-scheme:dark){.card{color:#fff;background-color:#141414;border-color:#414141}}blockquote{font-size:inherit;color:#5c5c5c;background-color:#f0f0f0;border-left:4px solid #d6d6d6;margin:16px 0;padding:0 15px}@media screen and (prefers-color-scheme:dark){blockquote{font-size:inherit;color:#fdfdfd;background-color:#323232;border-left:4px solid #474747;margin:16px 0;padding:0 15px}}.page-toc{background-color:#fff;border-left:1px solid #0000001a;border-right:none;overflow:auto}@media (max-width:767.98px){.page-toc{z-index:2000;height:100%;background-color:#fff;border:none;display:none;position:fixed;top:0;overflow:auto}}@media screen and (prefers-color-scheme:dark){.page-toc{background:#000;border-left-color:#414141}}.page-toc .bd-toc-link-wrapper .bd-toc-link{white-space:nowrap;padding:.25rem 0;display:inline}.page-toc .bd-toc-link-wrapper.highlighted .bd-toc-link{color:#09c;font-weight:800}.page-toc-toggle-btn{width:48px;height:48px;z-index:3000;border-radius:100%;padding:0;font-size:150%;display:none;position:fixed;bottom:12px;right:12px}@media (max-width:767.98px){.page-toc-toggle-btn{justify-content:center;align-items:center;display:flex}} \ No newline at end of file diff --git a/assets/css/owl.video.play.e7a23fb2.png b/assets/css/owl.video.play.e7a23fb2.png new file mode 100644 index 0000000000000000000000000000000000000000..aa387f962d13c7486d96919f339c9295b3c5c676 GIT binary patch literal 2794 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 literal 0 HcmV?d00001 diff --git a/assets/css/select-arrow.b8e89c0c.svg b/assets/css/select-arrow.b8e89c0c.svg new file mode 100644 index 00000000000..4c24a2a3427 --- /dev/null +++ b/assets/css/select-arrow.b8e89c0c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/assets/img/404.png b/assets/img/404.png new file mode 100644 index 0000000000000000000000000000000000000000..7e858c28a121b086601727f7365f3dca55c5c931 GIT binary patch literal 33413 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 literal 0 HcmV?d00001 diff --git a/assets/img/500.png b/assets/img/500.png new file mode 100644 index 0000000000000000000000000000000000000000..953bc1b5b15b19060d7a29c823d380cac7be42a8 GIT binary patch literal 45305 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 literal 0 HcmV?d00001 diff --git a/assets/img/android-chrome-192x192.png b/assets/img/android-chrome-192x192.png new file mode 100644 index 0000000000000000000000000000000000000000..358dc4b20ad91ce24436d86128bcd706df97c648 GIT binary patch literal 8642 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 Rcs2th|3T$_g_KF~{{va$*(3k} literal 0 HcmV?d00001 diff --git a/assets/img/android-chrome-512x512.png b/assets/img/android-chrome-512x512.png new file mode 100644 index 0000000000000000000000000000000000000000..ff0646b01242590af44e40ce662c92533d6693c7 GIT binary patch literal 17774 zcmd6Pc{r3``1d0^RqD?#RU+#>?u6|lXdHrck3i=%1vW8)OzG? ztb2+l<=a@mz5f6E35thf($VIqo<#RFbSU5ZxGfAC!7kxkmgTgC)!d!OvI^iS5X=Y} z6+MCJG&(3Ko)_~8%>n0t<3$i@ome8@p?<#tN=D6Yi7ZC}#T3Km5w)iMo!H425e-u_ zgd6eV>ismR+I@vY2x{g-NTYTVwqkqhJR=h{YBlxr5v+~9(h!s$H;Cv@KqufZ!B}np~u3 zz&%WEu91&Vjk>zJfq?<~_3KmbkG%6$>NitYImI7)(Xr*bQGKo&Izo09)cXB;+OXAO z&vv-}n2C`wCnrbk>({TjIXOC-n(v9xHGCl`lRZvZDCjhLoO$W`nm_MER)X*&{N}pF zQmiWHPz&?1u_~uW`MB2-x8*}YLWzwwN8tDH+COjE#h*7%BuUs;67@?g9^cFG|sJ`_*7XmdblJAz@+Ra`pyIR#sNK!JJrH+594N?{%i>>;jYi zn2)qxf4bff^Ws8Cw@tyjpy?U8FYZqTe;`g~7Bm-8L6Qe?4F}%LjMx!TxErmzI`Zo~SCy>ix*t%D1Pb=P7PU4P9)5Z=(z@ zwQ^Wl8X6j!H2T+w><&D@Ip>Fu3l}vO_V<6pYW;x{UCuyZ`Y2jmg8s}s3Co4+DQ-PA zcEkCfNbE05-H-N|U(V+mmee~GjYo+>N}prPQ_vlcaW|IT7R^ZBSY3XKoAkGX{d(n zd8BKMX;i&}>FRn&l=^N!1RD@BWEJ2rkx2{v4naReRJAVC7T0*;klGxwo*MxJnYCta zgo@mpvj-GW7Ko0~W$x3^8x3$S-n}+oUvWF!mdbI7mT#Aqm2D5N(ciT=NgrGNn&O!Il@ss&YD)JU6vm2BJyU}kvDuGgU7qxzB1(x+SMCrd z?DyU=-K9;qPXlpR!sj)TIOmodYD#7m`b6sfE+48qC?Whu#d*PX)YKA!O0L?zj1k^h zuGtj0_0ul}16IZ>>~($+s41aQ zNkpCcHCnsvsZskPET+6%oG8Vt9%)kkGTrc7z1{9@FyuBu8&)#zv)Xqrw4bMezI;Fjo-QeM zT3xLp>RMZWAhA>NX%n%Ex5u9u^WxnpA&i#Zv#qLq&2EcgB^oyIwSclOa}HgjE_W{s zq{1M*SoD3qgwrLcBfG=5G%_oH-Rh^g1^4{czbd6Ny~?KuGT^}vaU1o%M~eGKvPpLB z1Xz9x*mL@$!$^{6{ju=r1tUETl`%PvWUzSD+Nn08@wU1EJr-a&- z^xmRHgCDa7p4cHUp{>T>436f|^tn-P%vXvaWqu)n{fR^3wQJWZRtoEUEat*1hj-U? ziC!A;uk4VTGAhcDAoZDYy}N4KwvI6FZ7~_nW4m0A@1xz@L*1r<;Fl1+4+1-nr&OJ<-zQytGZSxNjVo$t&{p%rC?!c+Q)_>|#{85j}#kta|Rx=05%yWE^>q_3ZO z%d*YK0v-O`cx8A3lYf1gE1tsvY7#&Y&%7cg!f9A;{vyvjWK@}|BeFEdkKrJtQTSJl zB!=c|MtXX=Q5<`*ieHW1vrFlEczB5GXY1)%QbNyS2le_<+)hUf0-8onPKBhFk3Urf zQr-2+^s=ozVQXqX^^ zow-IlFREMbPUi4ZkuAVUKo`$rCl7=(%)Y`gHofLJX44Gsm7$U8Fi*QFdx%>NMN9X) zvB)sb$j9PE_)Lwq!lC%M?eH|DbP=Ay-qc{BpY_miwpFuUv{-rF)YG%ly6Yorw?W>A z@-m8`mumZN7p0E9rv0YL-__&Qn3$Lz$P$uRpjTJ%iWHM%4>G~a+u~vPrGhNYWV;`4 zb0jJ3;a2QW@l`wytW}lMC!Q1%FQ{ujz%M#3bY}!oLc?jO!9s&+kAg{O;syI;w~BMH zfwEmtQ>7Xk6Twd3$f&TsUXFNPK)2MruSGYIY0-`ndctG-vOKSAyyDFAXh|IDOq}4D z@50z(MoMZOJ2d(kJ(6i=W>jDTypjX)JfCiifz z0YBg(uJ2KRzCa1xojg#D=A1?9!qpSN@i#DG8>*|$Vudi8{e(W;fq>TMIpkfqdc}AZ z@k>WX4z68d5K_}biA3%!DEc=~;F#}a7!ZDDMn!p2r#V6B%Lp6gI#>U-Z-T`0+`745 zdrXg1WE0$If(E(qYD10Jo5v=cu`9?wycy#-HU*v}ys022mLg^nF7X~*@NdB%9J3tH ze#6$**2`(un`4lgIjUB*?4DZxPhBowi@#wxPR7Q@CfER^_<&ywMT|dOB93v$g5KPZ zKtqhULho3^;WddE8tPH}ofqpKPZ1*rw^DVRO+@Q*1Gz$J_=!0Q`8>@l8zrD;lfKhUnGD|blm@^kn zcn&plAuP>oJUu)rc1A6=iRT&VTPmYCWFKszoAfBT8`WyZJXAFLhek|Skk5EBUez8I zNhz0^`rAOwR0y)NSTfkETg3C1=tCxYfoHNFs~&~cH1yaJUkl52Q@o}(8!ytwrVSSe zM_M!dnuOL=^**iqohnWbqdL6!_0?3Z>bB<^HDwbWBCV!p5}Y_;S=kBlDP`q=y1D+& zjIq;lHYdUVYhTy+hZ|3PExf}771;LvEWP{?XAV=k19#-=c95U@^`k-bjxwX-{G9l^ z9Wo>hQ*uCb=rL;V&yF01YV(6=}r?_-aZ%g!x< z)x6E{ZXnk0Z8nICC^Jrjq}3k8x;}?fNo>$J)L^@Zijk2~uFGsIj+vQ9Ju;)X3pyKx zev2Be?fH2~Qv5}JeNQ=DKkaZQ+L~d_f|8pB)##ZLE;YI4MT|H{&u6YJzwHj*lPM*) z3~Ilwr|F*=DTfKVJZXF$va+FnO=t>w#fu3>tBVT;Q|0P}ms_KkNmc z*(L=!U=aD^*xS^2)zNF|%eR&P`pn}+~u$9P@?XDMPyX!tYW}{lR z#(gjEQ4uYn?-y`&+lMZ*xV)lyNJraU)H2Mi5V!8G8rj8Sp+l_*!%~VMbV6?;e#_XH+GM<0$Omm4n zGxZ!}!Y%$D_Wje6XsT#}p;(iBu%3|?A#zkkYT>>t;V`NL0zzT-nGdu8W_+|5V9=In zA+ciS&N}Zj=SungCCfrCWC?}dC-jApvCXys8^5%J^~p1VwQ5C;M_G~%qrbPH zI94(1H@@|(te>=Izhso^2^;1AY9Psf0iMN2k=VC2yjEpsjNe&~s9UWSh_O`D&=?86 z&*>@iwg6Lz(M2FIS=wpod4-L`dRBTcbJ|{PgSOgC2n;`UNTi<8yA5S4k@&-D;w<7L55eERs z%(eZi-B@V?X_GB)e``!MNq?{v!lT*Ho&DzLb*!FF7qu{1HQSYwiNyB{v@ky zYio<^wYg5V#FkyR3EAor>y6|eHg&;TDgq8+Bl=$P6nY`(L|a z(iLsf((%*cXo)RTQZnkJ*QvSi%D4&*5n57sQZq6PFU+mJJd zlY7fq$<9%`a%OtHZd;*pTg7%62Oo}SwdL@Ka&UExL=iXn?h$tGF*Vom%XG*EX=0o- zYs6NkMV?W?yS)%23_zWzdVOnE$Q>5S$P9x9v(pxNP*?3m(_p&al7O`ecL0qg!IcThY0(qr3b4 zt{g~;wOR)i@&d+6=jo5Vw)bwf1g!A|C+{;fQqZbC>4lJ3<*N#Q{hMDM$VC0quEDt688e*a@a^DN*GeSmd?p$)Ae6{o})DO%!zl=dX z*;vXv-aKNBE2*z^G}P7oDpe>o2v7o31&X&a2YWISDiIT6EHG8?6cBilS& zaH>1h8qwJNKym3k`X{!sK9=gO+zhfb>z)I2DK9fxde}b9vFoHF zObI~OfTOC93nH9^NV--+p_c!a7CG!G<2X?3u`>A8UW%A@!*F?^ZI5Qjf)&89W&G_9 zstYVjNK}^k$%Vf#O-z>$+hN{dX&ww2rb@&kCsuJ3ex&Ql2G^naP($b1`P^a$07aw{SARx2CHeu z`&BFRbv@Af!+z=s-G&!V!aB^vMI|Rods1s$JY(267q~{%==-mFewpUpW{QiEd~02 z1E*>zVYLslWndTNddW8F`}PA_?^mo2C!uxa{?N)y@1fiwoWQf(Rv34{gkKucAzP1Q zXlO|0@699I8#q6}@R*6ZG*Zm`hgK2c-3_ALo4^*0Ld`ZHE%@ANFs=;jTK#k0iyW&w zqul&__nIyXc5Y5JHV0YX#jZ~)$c?YA4$w?doR&h1C)-dSlDvacJpTX(!q0DCOfo9~ zrJqphj;gCCh*x13;dex5m^>L!6WY}V(KJf_Tg1TWncE?f zCDz?+5_W^5U?Y}HW_Oy~m{9!}E=nTg9aQaIT*3h#)1X}mW&|ArYmLe|Ua&AQ$Oj2} zL*V6ijd5D8N3=ixgPl#j!g&CQ_TYML@#mDk>jcuS*vWb#i=^Xt7a7hg2`TvbE{RnRWJQ6n1Ck0#Vp_;+$28=Q2gjvH?A+H;B4r%u zY0=01TNSsmKsYGoYNefm205jy_eZ?{8u|DC+asI=jbpawnL;%=^YR#mBOhPaGyo3mT@5W_EH+O zulyT5SYjyv>|k8$y^QCS2XJH|GgXn17e>;DzCnGc7l+ZwU>|6QxY&c1CT!A>lr?)K z`5Cp7VOXiD#`DGBp*|hLkHCDngR^v^;fte?^2iaHE9c!i>Iqxjwtoa@na=aU^xy$E z3OhLA1@s7YWGlN2(&IVg_g^0@DSzYI1=60&axCZM<_>fEZEYPH3zqCJ=M|Z~op?!E zje4>DC}qC$k$0M4`SvJO?QyU!kXt*xj2PWs9xkXO_1+7AWNx0i64NOebOSLwt>Clv z?J7=y+EHE-+A;HA=d09DkLvH&^H{A9Caq|PPk?x6_7*n*E9S$iPsFxHOU{B#^E5kH zTyj2|pP&Di7gS_77lJUaHQNhS!i^Op$D6;w(+fa6*?22=5Jq6k$pq|Ifl1X)z?6_Q zAZCR`e!MEC;NcU}*GuR=>qly!tJkI-_jG`GR-$AJ(gMudmL=>5(Fg|O$Y)eGgVvpP zD?z82_-8?CYRh)A-%Tp)=8>+yDlI9C39XSFHnImRj{&*+kGE_P+H-XeqTsoTmz?NJ zIKhF>{|($W_uaFaNVjM^ICCCcxsYV9*=~$2+poLOd5Ti`o*t(A=l=eRbAvYZyX%tB z6DMFGj&G3-)?J_H583ox6Jul3H#S@o|BUrP6VGLH0VPIFjC;)!L8CNv`?i=FS9xhT zAS8UTjqz+#$4$W^_qU!B-%P%)fbwuxx<;sq!&j8*<iZzcJ$BztNtJD-!tXSvJKr{_cYE8p0S>GI`q+VvYIC9ZsQ%c-s&wSM`8Rc4EoIFg_zOXbgcF}alEE|ScNNB)j8!&Fi%^?%I+ z1hHdiWd%TkW8{jjg9ME#Dr16eki}S3>PaY|^Dh-nkc9mHme>eN9b24~#fT$`dS#%L zK)C%vilvFg5^m-o<~m$7{Tul!4v8tHSemMf?tX<+e()d!;PO^HwzIQyGvK|D#FIw< zkj_`mb`WCLL8W`9C8B}OyHu1(5~AYr59`*!HJ8o{59S)$pK!$)4u}F<-|YJ9o!X| zoj(`p#awQVwl}_*f+pPux+Q;jF#rTtJM+ipOIPJM~WZl|j+|h0eCS-m6il4n@S#YeVuAz~TI5JH3$R4!)853%nbzd=f z5RNaB6%oAOKB zb{QNTTneJ3-B6$v++&wo)n8e+jq!D$YNwTTUstGZFHoL>{H4C(DFjgHwj+{vmqO@@ zETu`669IW$$JGmX_v(j<-(Z*)&o?hN-Y>klK`#XX@ZuP{|g+h>3HKk#SIgiOL}U>e*7h`gVr-t*3dN*K{AA#UfzOkZAcDRW)2t<;MCU zP(qCc#WoRn!Q3lp^lLv%3FS*#Wf-p^j1V2NE$e4G@*1MgtK+U+%RgrQ(#$QPCiBz! zMOUhP8##!dq~}PfV{TpuSdI|S0Alr~(~4z&Vc{?Z)s-crgO2OYT-**__ib>4{D5?y z{VhC>O1vh~jvd16=+*-umYy*q?xUgx)3>vMG^jK*yQ50WTzgyt z-Ah+dCMgId9{BCGPVZ*dr?UL$k}qGBx|5_x3MztouHK<7*MjE+I%%4!U1sa)tX)M7 zPlkiyd3wqsD8eQrBp7qe#tYTIjCk$b99HER`usiGGM`eP>G`u+5jAbTCWwG0Zu z+BN#Qllz(gUeo}m2^mZ*+Fa!D80^yu93~T^FAydd=PNv9T0zRZt>7dmy}!{}l;4(i zcjFQk_EC>-ANCtZUd9~+5&#m59!T4penLD;IFPb?u{}qauHRhs!?n@!1yI6LiMJ1G zS>Xc4PLTJdr_U3?5!ydm!1@%`ZzOG}2_t|Xvwk`9JHL#amzCAJ&mxLFP$$lYUQ(p; zVu1@FC>>Nzu?IDa=t@CP$jQg8CzLdxkcgdNyt;lmgI*!ShSA3rL+ z`;A+=eZxxWA7l$^Z&03uF8C}xTTu+`PO6anVWLNf2nPCy%i|R+(#!XOX#zIc-24e~ zHtbRrD719?P9i#PsVSf;t60y})7~l3Xr^gO59M$=Tm(OPfEluWsexMP`jl5*UanL4 z;KyHw8y1a|`z#}cW-G`mx--LBn(QmL1Z-`B=U#|WQ=cF4<7%2S&vk$zZ^>-rSUSAj zacRktfxiiK`+A z8Q$jU3wO55#Xd)^wHnxd+c#%2InyIC>E&KTfK*&;;F5Q9P7u@%*TP z+8N9CdO5Oyt->w1M^bSdP!VU}UCIN6`^5C&Y3{wzsMm@Ie=h!;H$s#Atsbgqt zjA?z(9_oo~jXwSkUdVbf#fy~S5?H%x|D|NzSL-dzeq8l)M!8O4AC~(ok_WIAqUM)Y zog1%PG=lM+9UVi}E)2xkh)db@#K#RV6%_RaR5Uu;LFL;@5f+bJLp{ONgAK_UG54Fe zusz-NSz4^zelSOu7o6oMT(jkPvHECH_0LJ-wllYx##!LZ2+~+&ka5|f_rLo(gZu7x zS`=2Xu3~*&{k)%UmTl%arU?-DaNF*(eUTrRW&9oKJ6+s0YNbc&IpM+IGy}CtId0$`*=&CNAOmXRN#MvwHY6%T}97%LKnQZH5AeT3Lq{D z={trZ3F}vUAHN&{HE*JeOsi#-d=L3?<}MMF9cmJNBY2JngZaVz<#Z&-69F_<>-;dL z_^zrNtqgL?bh8uqVuy?bk`}uG{$8?o=I-jKWpo+m6R@MGp-naC+Hfv0{^t(R^1_BQ z0Tmw`OF!=6=2H_3x3aeO<#J=3mab2#t-9+PTi$Pd+F$Y6Ytn!JR`g_=H>#X5}SfOp1GiHxmK=II-reQow@4>a)HYGc2VGl?or)m0kEOoK4;7L&;hEPoY*Q;9Lkr=?kaTV@9D-(jke#A^Qy+<2=0+s+B7A>&!rhnSiAZPw;Kqw)fk&HGmHPKl z;?{qwe?^sm_XRX|#R{!e(||qQ%-M_0@qKEjGtPOF9j99!OS+1bdK4jK1-0E zWMtd}8ZuHqfY3oe>g^%V>PZ`LCu7Bn$fHv@nu{kqP9dSnxu~NaD2Tuwg?N6p z9~pNxfTt2;-^p*SWmf)p@%gT+tFd^kCt(?RaR6`$7ahpNz%QNReH%=|_vCxFS4Mz0 zJSpL(Sx{F6)5-u4m@lrTh1wsBdJF3EzFf`a^WY(;(~jKJ3F5JEX8*<4w3` zXZSSY0S$3@MgOla&LK~?1VIXRXe9wZMKUpdhGTl>d3u!@rb)~=}+xT1R%<3&8Ir+c{%IGaBb{<{+*`YOHHT|Hot z8$wQ4*0s@DZEvut$qow(MHf)X=nK;R%ufM41KIK+APZiRcP2nC9tp>T#Owlrg;>Ao zlx=y%8@C5e%^3?PC;gR@r!fa`Gh(UEK?xW39-}C*u&S;uK!%sK`t|_G@@Bs$2&7vb z`z(36dB9xWX;xm)3x<1<0Eh`#^$TL+@V>V};1AA~(`*%awH0yo9?)u`dC>J7NXJuNoz4vYO=6|yU z4|2C3*=L}r&!2Cg`+GtYPrp^z%LO1>C8$b)xD zJd=@;@tq854*{cBH8$3A9ybDom0EYg<#87g2NJN?3MZ2G2} z{BYh6QE#i_G%!v3L=mvR-SmBX<-Tm||E=>pLqlw4d852J%Y`tmh9du1^#yZRy5;mUN?8_&;GQ=Xv%w`f^j zHIm#OdX`WGF(GVZ3TRRM4}mtSDO>%d_NY99F1}fL+~ZJ2u{1)wPF%bZIb2i~F!BM8 z&&iBFM_^Ip6dT5~kfx87z|-&)S#=r>kBo9xAlUHbGHPr)!>@?J3QS320;N>`&Ayby z(*a~vImv(YFSyi+aC7E4S#{lMR0lmdIjIv>^31amtkeb>39vOtHZ6e*0VExikLW-d zypVSdaKX<%^5)uY$GuAs=B>T_zm?6}mBP&c-1l6Nc*=IC2+&P}9dUl_l zctI@&q@2%@NE&Wiua(%c*njNRZ|w!36X&U=?fh^f;-oxUP^AK@na@0Nd(3ybQ!Jxp z70NCDo={%G1Stw$Rpip)L4Tzi5N~xz2BC$`RChLrbTD@#hi+li3?r`kO(aQ06~;IMb-qR&QDLr2z1BNx*= zKU^c!yG4f;eH*x+_I_`DbPc)cU;gwD&jcp(Kg!cn}a(f^yXC zewW`q$N)+YA0NjC?Kdx$OFKoPcMs^~h_63#^}arHo>zf$da*~9hHX?k9oYS^=*`Xb zooEUS08}InuZ@5x%u)ZqKtT~^6nbizi+mPySf&-IYhseS(4Fj;cA*{B{bcF;om5q> zhy%k*!K)3^7%qfO;`g; zD!(+5mDN5tym66}U9Gm9rqZ_Z4dMh+_BnUTL zvFuH4$PYAG&%+)b@&mh(?51Fc2DMR#BS}(vrg|AW1W@T^3?Ch{NwciDsR#tf=^PW~ zwgbEhg}J%cJXVIM$a`CTQL?Ly>ptVf&w{IF<$%NHRp{wH3BPu~iqlDMnibMdDT8jr zm4El~*nN;J>4Otc$pG$GqdRJ?J&=86s!kgO2fzcDDKx5b`c0B+w)+M#13WT{B>}Mm zmA*i102D#3pxii3uF=}wy#Y19fs%0Xg2PQrK}J9U=T?IJ--K}!5)3rX-{wr z(4Q0I;KLq&M|D9QR|l$`Yr?|%R#x-;HT9_;PwedMmJg1bYaizn78Y(E>zf#5egA%M zN_LlmI8xc@RF6;F->D-SnwsW=Ld)XH$}F3cdBTs(*Hs=j0D9aaR88mI4Tj;03_%eb zy2Xo0&zL+7IyIKo8dX6dr6eb0HhT5h;)i40@}UX4r8`MJ*gx&v8xZU5i6b{YxlKZ7 zcJ524B*6|%C18NGGP`s*0gYcki_M)haO!*@wvSlV%N00-n9kNsMwE$0ZkXrY zJA3g1_1a0?zDs}FGUSeFQc@dY^u4ivAO9e+WrU@_7-Tln_@yacNG3Jod_Tk zG7oo)=Qe#46IJCW_4~nLZ|EI*;q<#{(?PUd02cP)WH_kA5|Ni`fMlxhYv%`5@;ZHb zveQxM$jTv(%(bg<<{W+;Yr2Rm)@`^KW7_|C@i|UsTC!5{q6c56DcmB>FntZ*-AaMA!ZV>k} zh#Rw$MtNDa?%YQ)uR_wf2g>n+fCvnfvid^t{BD27ODT#xqavfSh3*FJ>pU6Wz2Ba} z!p4ulsB4wh{}xfvuVU z_xJOn8w%}VVKW7jlUWYXMJ&9575sPF@qr>S?tPeGs?26r8L);%MD49G%_gy4xkco6 zdioZP^=j z{hq`A7Heha;u+Z513hk{p;?3Pds4fq@?4omNJyoIO(lgt3N*B!xFt`?ImL(Rl}I{n zdaEX`~hcbDfEktaX{O>cbX>yZi_!V0qvcS)BOM<;DFpA@^!3hY^>t4?* ztUL?mj%$Rot6wST)@w;G>goK0)@!)*DwjNK$m(EW6 zmD1~yHGvYbbeMF&zVq@plMfi&UyKB$=;4s0v?00_cQz+e5%7}A+i_QhlI*lYXkis7- zznB=A_P4K_EV!+7J0_m18PMgx=T;2#$k%JXG$n#36qlx(o zcNDcn>ahRUmga8)dckl4^7OH{R1z%$LbheBgACHgiD&$|2Kk@1Mt=IA&)gQfZ73m! z2z2^g$5U{8%zfHzg}rdW3b(Zw3eblVfVvhue!70`y9SOK;!*Ejt??@EEUn0<&`Ute zA(+4%pdTqbso9Cbl;cedA3d57dBg`4A2G{tB-0?j(#*HJ%8cfI#D?h3+uKnTIvV{n zcb!ft>^?=4LjDUwVWn_a7D|=3Z$kkBwq6J;a6$FXjuSYIV?N8H-oqyT^2R-^o*iB%JJSFOQU@r`1ae-U&J!!Z%!qYxX%V1j+uc+Js&jN zStZUd2vattpdAo#!IP&MnVIdehdZRkoQt{#iNILPdsv`vG47f%$q>Sq*g*1Wxk>L> zK~iMFm)1X&0KHM5lZ)n?6D3*!xwF~$6U?fZ@|?ircI?+2quf7JT$Do;ovEk#wc=cl zN0wa8*j@f)ljdfuMNJbl8teY?lz&4p9K>GRG$d)eap_|0G0@eTC89bn1dXBw@Aa4e zu7oN;`91sc4exi{y4OfkBnHzD(XN!-a;T$AYn)1eTwV4W9>XzT<)OxcsP_n*PZ5na zCYVw++#|LeKI#}GZrlH&!f|4l{90N0kA&N>L*jgfvK}QRw?C?%Po8CoR!Ps$umVO? z+e^++RxT+zmez7Uh(oW?Kv;N1LOFl+4W$B)73v|&M6-HP9c9Mkld@Z4s5&LLf?5Yk z99}&USO5wt$b)qj;&~?eGt*&J)1GE*QR2`{1iA+`468b`I~BrwXv_~92{Ili_l*n? zJg}(ppC@vE&a-Q{<780Pw;h@C+-&rw*L5$jz~VeuN2j4MXVAlXjppwvHkM8W3B;T* z9P=%nQeyWr=NhfUd6?4k7@#|jfoEH6OeFzA#*Cb}QZH()%;*z(#r385fWic%b{)l* zw?p!zta|nXMwrYDC55~Xt26_cZ^eM?IRqC$c%AkpPB$+_x7m>i6Mh!I!*Y)JHBGj0<__CP@(bF|CQAR45MF^S{XG|-!=?-h+3{Q0jHME%;? zzdhJb686J(b%e^zMwUxojck){OXNz0k#0kJ!RTZ@Ln?5YmCQb_Jk8|#JC9kyQCL8s zNhRU;Q4|1bc2h5f8qAsX02o+;Q!U>5Uki=L zvTe4iti0DvNH5tg4epKHsv_SI2EA3&&M$bC7?qJb6N=+PKCu))Sir{GbQll;m@@Y< zt3=`VQnZ((fufsAbrY?KV6%a~0P>FM$MoeG^vuk2Gmq^G9J79gaxPFb7@C`N61F;T zLd6oOeU0&phlGHYqpj@oz+C5%E`0A6J#juZfRc@hrWk+PXq1p+g77%u>dFJqwzG6_s_(^`Py=AX@#m6A#{^!6=su&iyMB>(q7~!YzfCJliN4sqS zIOafg!rKN3xu4JEzd=eFv4cwehj$C##)39!kmhjtV(E44Do6_C+>8vKpXqW4y;{&h z_;s9_c8XW%*U+s?K%@kkI?S5us06JY0nxxFyE^bCbX5m5BHpVIy&`jKDdF}dP}fNU zIi8lnJm}-Rpq{!~Z?98cv{umj2?n7O&;#&p8sGUyWsvCOuIzm9-5KvB)4aJP9?T#M zL1#Elz89bjC}WLQsLuy;COtsyh(j^daDtGn`Y&NyG&S`wevjFF@T9ySpr5{51T0d* zZ6W{hg%%o=323yG0F9RKjl$@da(jd66wq2JGCtTo9si2M9fHJ3cQ8$z6b*!y0iE$j zm+}%M^+47+tgkI!09^YNxjXcrVpdCb1@x6f%OL3^6X5Sy?Ke zb!ONPFw=3`3PWU?XuFg4mF@XQ7ALqdKfPE>FWd3GC8We?KsK47<4bs3Q9B_hbYm#_ z$J@N#05ayJdCU1NM(4*{nxQfq?S}P*C(kTaT@h8va^4hBpFV*%l&qe_vXkp<352x! z2b=4FUzN($NG!xTe`wbO8zj>3*A8no1|4?)j1+?E*;ji5f*c53WOl2^@CI8dXL zTMIgAQwZhstOh2k0mKnF=Oy-$noZjAz+*~})=xIe#K7Y^fW|2SPW?r~Pkit}!CJi^ zpMt)_F(v5aL!8BPP_tGCB0tb$584GvsHv&9K%Xt}_5cEZ`F8SE1u3$>;pp zXWJ%Sp*5unx+}|kctl0Jb% z6_vPEjIQ=})qJUTp}r>-dY)i=0qUHLs9%KPQUzgZo$XBA@1l8?kcdEBXnXBV)X`2|Gmz zT@(k1gusi}LwF&4)hm)i5GZTM!P^lZ9JZ!4kLG)Q5&g5+gX1gLIP=c`|M%@6|Ia51 cdVfqMtFd``6VC)33HZK@2U^O7_nyA~KUJ4fz5oCK literal 0 HcmV?d00001 diff --git a/assets/img/apple-touch-icon.png b/assets/img/apple-touch-icon.png new file mode 100644 index 0000000000000000000000000000000000000000..5a7099aa748bc404c5633c15b7fff27d2a3de445 GIT binary patch literal 7679 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 WAe?S~ughSqtK;r0hgaqRZZjBAm&@4F! zXK-@AQbJns;USf$Y!$?3We=cjNQC8b`OFPGP9{^hf#GmStJOOA58Jjs zx`9XObov0O)oSRvPNh=W19V;A0qRxYR=?l><_5f8FNR@IE|B%`EW28e3fPSVDGD~ou2N1 z`$x|SglDtaTTRn0j)fIPVLTpxI2v|ANyl;Cn5Ox?R4S3r=P?Xp<2cScAox$fg~fme f!0j6auT#GPP;3b_nH$PV00000NkvXXu0mjf?(pHz literal 0 HcmV?d00001 diff --git a/assets/img/favicon-32x32.png b/assets/img/favicon-32x32.png new file mode 100644 index 0000000000000000000000000000000000000000..1b098ea27dfa4c4feeedda35e6ce8de9d873f1b2 GIT binary patch literal 972 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 literal 0 HcmV?d00001 diff --git a/assets/img/hero/kerc20-hero-image.png b/assets/img/hero/kerc20-hero-image.png new file mode 100644 index 0000000000000000000000000000000000000000..0908db01fcbeaf52c15e0b64741f7919cf7f8794 GIT binary patch literal 208144 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 z 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

aTjtYb7S8~sQxW=6 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 literal 0 HcmV?d00001 diff --git a/assets/img/hero/test-coverage-hero-image.png b/assets/img/hero/test-coverage-hero-image.png new file mode 100644 index 0000000000000000000000000000000000000000..b8a7bfe67394b003bf93afe511bbfb6aa5f60f7d GIT binary patch literal 56813 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 z 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

aTjtYb7S8~sQxW=6 zQKr^BPaK%C*5N^vxz0k=uDbrU$Vr&eZ~5)_Jw%`_)?J(ijj0 z0ahhtk!^459Sa88M8tm$O>qC0EHx6_|BBZ?Xn!7;B`#gGxM5nE@x{hm_Gx!plGY(# z3iD%?`(gqKcJtC8E2uJsi}B6tYrq7E({IiK!C=f1nKthyqrWRlRfqFt_i4pqe2JbU z-Bd_Cg-9naoqqndU6=fkfULry#?8bPUQvC5o7EXH4PbvFovqjUhC=NR zqGjI6bbX_H(YIgonA9C;iEe%j2a?L#D3D&zqQW#${$_xf3tjhh672$vO%GaNFtnuT zzm?ox(#lF;!2G^Vg4cs?63p9ft3rhN{Sx``GG{v>W40zK^IEksUXCQ#+E;$<=s0wh zj4yNJ?oS~fJzSf~aS@#yk_eP^TkAg6DBCv z+hHNE`t#nX!H+qcc?D93aoPmk8XFBpjT9cz>mghLbC;(IXvr|j0=B<91?{{K zTDO9X?&i*OD>n861P?X_P<9+sR-=S)Wn@nK|F}=7XEj8O>)PufhgS7&?Wi6@n7HS0 zH~RVC#I@-rz5mo7n>zqxrNEk87NQc9A)FB2+iDKkiOK*Unowjy@+#a(1X_byc4f690GlhFe%V4dyEQho#0?L;j9XXN{XZt+4@LeP}fE z$bKRV%L0S{=H!Q4^O*h7wd7DIF9CJ{Oj-cjO0hiF(^}uRwN$uwvf(D?I{Jba#f$-z zPJWo@g0*D13af*b{k%$0E$X z0riML1pP9wJ=+pWS+HIgLpR=Fo$m@edo845*KdSDS8Pzjf+)|rHw>2g7{C4^0%Yn0 zIA>F)tYkVV@WgK9BsUyv`Nd5+anD5C$QjXJtB`r^LOT9b*;zH)oLUF>21 zwT;u*spw+%h%fedOrhL{j@?2&ztJp6uR;ti*A=b54mxpl0>6vdW{Tf(+x`_4U!c}V z9;(It70I@*TYbk3p%=&v(%?DV@81)UG(lN3yB@Cu-jMz;z&xm%_hvuy%8q}*<>TR- z_@qw^^%dc>g5ej?)dAKm))`b6G)<%>ufzD@ZB@=Yak2f~aCjq4rX z1KfBmuPW1-y>Y(Ap5_`_(+zhl%>?q6-k1N~qid$VN+?|(lmy29EPPj(!;!Ycy2x|W!b8eeCS{D)`52vHd?dhCO@))xJc~Qv<|6JClryE2{(Y|cVQT%) z@1*IB{o|Fx*oHdg>c{gXqDCsWw!(C_AfYcL-m#o?K}QI2^k`I%E?`uND$w0r&Oz}T z0o&GATh>CfmJ&AEkho{4+SwL8E#xX&b~_sr3%lN-Z0eT*#*N*)7SbhoGKpD%slon> zo5=qDsqBIB2~8`iExoeS=JJ)&`~T@p?$jkN@kLWU?5d^g?Rya4~3=j^7Z2 zUaGzsb!}}1hlH*zkl5U0a&7OLi)aD;uGzgX(uL zZ+gNS*-d@NA-REP4uC>c?$8JjW#$v2Njy|Se!J$e^Zn7|3-1yp6^r>vFgKeS9;QM} zzf4*noZ^!CnOGL37PYAgmOyeMWPNRzeLRW4V%aT)jwvk#^x4NI^64he zKVh1g4Uh5bQ=MTJ4V-@o4_uJz!H}HKglWY$KyXg;%mG3$hE2Ghm5ai{kqd0?F`jZ} zQ?w3;b0VKxGSXta`mjqLls=oAw?)EIyb*oIRIq!Jl?tr*(g|*bmm-wsB;f-M!fifP z8Im4|08dOA*ocp@_%9pdN5pp=Hc__)%aqD_aVBg)&3O4OVFOA7==~VD_ao=2Sm6Dm zHby{1vsa%H-Ph9a4a&(rt>JFgK(}3C$0DpfcQf#rH){rs`gQ#T5Pk*VSFYvd`1GK_ zWJ+o^T-gs$rZ;`piOp_J7aqUjpes);Js7gsVL+xm?F}U%PhS8F zIext!Q=7A61;xS2SMdNdG9`N+8b6!Q@{Z;I;p!^`qVAh^rMsl0OG>(9DQQ7kx}>DL zySp3dMnSr}ySsBqVM*zQJ$t|BJC--r)WyEXx1E zt6eJeZU$n5FU`E1Ydx&IGK)w+s^_m$;3|Y*Zc!46#qr?4h~?-F^(cH{cwHs)6Zc|Z z^w>zX>X0}kZB~~4$mHZ?KJ}&7B*xDDTzDws`G`n_e7~96TT!&eR|~em88)>&+LqK! z5$^+lm{*4`>a9oZH+R^Pe(;TKJxl%nZSW#%HRZe<{Q_(+98aY}Z5_yZmkNJjT23A32;&{-0jSHi%|0anW7quY1Dp zK!7W$!IS$c+^k3tYli^>aX5X?^R7elof;wC#zMaDyijCsbu5_DCVm`dqnRi3XdBgnD@> zO4q+okm_Qip^)*cW6t;C%!Uqvz zsfLIP>t6KvODNP>IdP0r(`lWNs=EQhi58*!B%+AbU_30MS;oF@ss9#3MMm=%{g3UR zukP4B%675K7j^DfM&eAawY&-7ou*9xT@1e-xUZ(N#+N`V;)c+*{>H!%4qahzV(k?& zi+MOBRA4_?Y+0BBvmg0$cNjU(778wF+hF$D%?K!e(Mg&!ut?-{lxdh2puD5SJ*b1J zw-8%KNKx&?_E~n@?D^C?SWAUlFE(Zco4PhJoRL=Uoe+mM8RLDzr4RMAcfS?9^*Y3^ zhHhls2@2dw1*zdHs*6a9Z zdTTurntZjcT~SVrZ#Lg`zD5tzeHJh#H*Zzw>1#3~BhPpBK(01(wU3S68#LX6(=m4< z!H{Kp=25ET2+5{TkDdjp1d##SbeV`HUn7~=pvttl(&mRFx2(Y)yjG=%5pE&A(^zw|yqJ6&4%Y}G-*I2)= z+yoQnHJ@7mJvT|}4Fb5rTM_#+Vn>WM(fsGr*wa$7S_9XpKF$v>f#?^rmR$A01-d-S zvHYY$8j0TRe34H07QA%C!P^~7WvdC$nxB}Axc|}b&G4+Ng#pCeZcf8gVLm?{67gY!;rpDt{z)-RP5ke?f8;ZQ`^_QQZm^M0NtYLS0 z{!6q_VJ?rIMoB3u6+MEz45Cv%lAh7tOEqW{qpy1R+JuoFxmbxvY{~>0E9XQDSdQ8F z-At`Xj@%8of0#kQkrDYTG1l|XG~w9mnxD!`&*Q@8jop6M zmQA~Yw3}|w975oCnQ>wRo7~(P!%5k67%zz%0%foFH&11#+fxi##ex_exD*kb3L z6R=;bDI;u<7nTEle}wSXtD@_~MW<3v1fldV2==-yt^(`bcUO9PTOTOv4j(>lt#!Ch zOBMrr91oYZY&2KGvgx-CS(e_*7478GMUMcTv;2WC8K2Yr@r z((ofvwm*F_Vkea(_fL9qCgm#^N|6*OYfxxlg-~PR&NBWj(99B<2>*9JpfJ>;B|^r7hDh3SjJ+et5kK4DPNo*(;RAshLk+8&7g|F7UJ@%x-4k@|1{0 zx%;SE)3lBXh~BZ?5bUe0w>lN7akr1UZO*c8EKa5zVF%T1Pia(g{m-Su;$W1)hX-A7{mfiL@`a*{+tyaf8@<)$3#S%Zj(v~t%+U~d*M^7xPOU+T;;y3^7&LiNMD zv1L(ss>dKu;rHsfT_3(Kbr+nZAO^^2T%2L|Jm$h9)xNoLUzlTE!!;w(=DFp1qUN9g zi-2-%0h7=dyp4L)ebbOzg^IQufg06{RIXzBkm#OW(nh zoo?Ohhr15?c4D?>gDk{=*5Y{7U;-zPOdTDVY>WdHbJX>>8ngHG8Kp=P_1RwE`7VE` z-XI769PUno{`hr7VO!qkc%5&tAYtUUfahNwL^0QurrFSvkO#2H#5`%0F!@JVZ_MU_ z&Ja#x&`1o_9VjFuSw{LdpJSfFY#?znJ6-r^Y`8$%@W3(wcN{&mqvCkyR@3ztN+|K+ z{N>LDhnPRVLK2hT5nn#(Fvu;uI635fP83ZwNn0HLj?OJa zKRKKDn)mR`gX~oV`1$qsZ$CD`$L(Ir&mV7WT#&wt#i39ku}qeo!M_cIVRXSu$qkWz=W6h@369A6O80{i#;Ys6zmY$T>4H++2hBlvzs7O+J)*;ax%^S73s zALm@i4A$oPxDERafPr*lMAr8-y;<9l$2MR8>dH6>;P`PH{U^y89SP_Su=S-S$H%!b z)ULKGx$5_B9zZ=5@M9$MD+!a?lv9hAR%q$fV7MQ@){oiQ63eyl7gy_Y3UN$nh9Z)j zrk96>@C4s)M!bzHYJwlyAEug8KZKmk3lYu%NLYGhPDky3X(7fgUVF%@F`T@-IM@tN z--}n&wS1g>v!1}HVodAg)jFy<|Ggw~W>CkXNNKEKzT;&wa!}f|P{@(j58V!ANse2{ z6%zYbjB)|kt^B^)kGNz#FYKFdDj@9JRO7ENJl%e|tc<}9tqhmOxDV@u@WgMb06<*s zVY!`cGOtdHD*NUi1qqx!H^$Cw#D}Wyg~&Ev;goioN@{fR_{(VFQGx@GU^ zh%rYpF2J|JgS7~AX^v@SIWkFArid_MQ?B7QPCatE^12MTTLoxpZvS_n}9$LH^;lyN1*Y@+=+dD;Om%ZIiP7`8`xq_C0-Bk(LkW$>bCXiJ?K;V1!Lb$ zeL0H6o4FP8ysfRLRwHuqu56*4{ZEz*ppB$e!z(wYQ}*1m;)e6Fe*5MCI*`K($WcfC z3MTRpA7tk|_|)hT(B@smM_pj~`h0V>$g*Ue`#VeKK#9|&YBw(T#*w7j8(L9=hw{g(6(52gTm$5|8VBa3Lp(4ZrVWt5$7-nY zHca4ywf&C@`d&GAH}ju}QNyjH(R9rV_E%q91R4 zi%E4Fg1q45ig$Md{pz#1fo=Vf1SaiHfNTCf$aA54VVuXIfP*UEFIRGoLRxG6SC7k! zPm(Toe+NS(BcWw@rtME;{$dz|Vp=?+(o||3)>LTvCi`0aBbMS^=(nz8{L9wox9w77 zqTQgqRWw)@rQL1-9zRY|&;khQ7H+(|p?bH8HkfXouln>MnFb3oz*=cxQm z{m;rms|Yv63$tk=8^f$i3MqbqJcYEMcPkn5^S8}@Q3_l->+l48w`gLKj)VNt_f@^U z@n;tN4tOG-HZkZlqHO5kF~8?itPA80wUr0m($Hn~`p`ryb#4}piVjeVLu~+R>E-gS zr48UJ;!W~OdzM$WTPs1gpMuF7Pk7rnsCjTp)dO-$o9h`IF4Git53#l)CZD7CXPk9l zmYtU8IQlIxWl2(}lr!g>t1)O_5Wk-gem~6O&9jyu>hUPGFwqZfzdmVX5N{izpl$TR z&CKnrplzaAOZKddyn&fI$??+Ob6>ou(m^4J>{TKu29v00nWT9vRCk0LtFK#dbBzA= zIke_hq;7uG?<{Q%=kUOJarBE$=M}n){NUY~B4u2fg?P17UWOwXVDrY|Voa7GQM`UxMOiuxPwZwu>zu{1`^XpIgI8~v z^9zC3B{Vz=1T||CO}!P1oA*5%NVv*SW3zTxVO$IopZsVMbyb!a6i=5|V2kT9Ts1J= zIoONUG1Pyqop0Uf=M2s*!O-kOgt!Yh^ATG-2zKk|YT~WG%)@)5j%LMZIDv}MYD)pjRq`FL9pM#OtK#MMTkMxg_h)#{bTzj5 zdO4>}R=0y;L7+yJ$@B5D4WD@X+^w%8vKgvkLk6~Y(7QX5uMVRLiwdKhJk`sd6`l($U)T zufn6O(uGoLP;}Hzf%@7R5i!O4Hzm%13uS>Wqv8vo@HM}c&EY7=(byEhFaqxVsv%UD|CM5nJ2BEYnL1f2eoH;jAmaHOe<%AE^;ICm8$Ly$kX2ItVMZy2}ZeiJ<9(Q5^ z_J~IN4?qbvb>!A@ESl{Vh8-*{S`h>|Z#w`xfK;5ETvPAeBaZ%^_{ha3 z-os?43(SV2k!eZcGxblhR=|48#>J0I4(T&b|DW`Cc5w!t5eDn;9NGFui#qgNYS>N# zYzwHPJ1N`z&uHBeL3POm(_`M4j zZgw8*8>OU}jL!nys*zL&>bM~hjV>Sew&=+tT6AT$B^zX=Zr+H0Vwm;BEGl_~{~mZW z1Y47h8c#AC#J^4vpzEF4o)rQ6ubL$Zj^DD;e?`E%%az=HEo;H$Vh~C?486stnnNNt z+c;uU!jbM`d!bYmjR8mB$54j&R3(UnY}^9dVoyt84eUN0!#)6x60pTFGt|dKuBt6z20%k20&ym8O;^$MLIo(97uaPr9LNoXS zNXZjt`N_F7Wi9!!=X}u>j^x#g8eBrXX0bM!-gKr~eTM+Mg1c`W9KV@(+=K=Cx0x$- zbZpO@3Shd-XRl_oSsoU}A zkab-M;z5e&skZBS3Q&B^4{A^Tp!osyTft`e1i^ukCnF9yPt2w7%N3{D=ZfALo0f9Y z81;za?)0$!;az*1=7}POhBr|8qQ)(Ew~DSX7yOzk_1`&+=^v^kQxl@gV4IA@Tz&Xm zbXK)%0b5gkwPXk%I5d4p*)Yb|PDh-J%6mJY-jd8=areybO=YSC(`|mD{L@X(Td#er zAIrAssJWyM%N9kbYA&<|Q#cTy@!Z|nh-qurjl$>n-VgV8OTtye^I(SBpdq(~t%lf@ zhyOlMGEH|q=2xEM51WRV(PlPoy^f8MCA?pjI_!h3%6Jch^7ElyUn)2juk`_OahiOn zEfyrb%hCG;?-k{e`6Sp<>WKqSw7oa5rovdcKVp0KbO}F;fq(fF-?<8@_!%+AZ`OeW z>cXC}TsGRwb`H`NgzjTGyKX>l4g6{&p54*-h1h3*+)UDV=9A2xy52Y3Z^P3{wsQzr zC`?`I^084_3$8=kgcDhOmr<7~(1p4vZJ$;)R+9I$-gf01YD zVQQW@P`x{Fj>(_G>&DPIyp(bbw!C$Pce+I7DzJu%aXoSS4ZyfH8ZOJ7> z03UXtt|h!&yi~KMnTLOjly@1nI)f%MgFpAkje|W!P=E^=%rcU@_AddwEqW$Dx{4xTTUHMwJn% zNITmZp?Wz2+yh(A5f9$f5V;=(#7Ka9G+uK>1*(us4WgZTLM$2ZqESmy)aa%DpBErW z^b?-EU-ESn{H+p9|IB*g#CI?`J{*KrCwFp;Y$1N?w(3B9K5&Y@96jeehXm2SX>-;0 z13V7K&33?68~8p*X@r^@^>2wT;#;3TRk`PFxAfI31ljq5!nrKYNN-`s=l(3jtvH=? zAe}R2V-bU@+f#oyKF#(^>VQ%n*A)|%WI6lwSLDY`C&x*bU~H$ge_GK%wF_#H|F?GG zw&^ptyj5HelS<*GGFA9OlV)D37$Iolee$J9!_bw*gFf73Y34r1IsGkSFV^{Ic~ltN z2@b4hO?u2NbDNz$FNAMD;R`GoG^E23K9FSb`#DhLuG?RWR4rdsrW^F~8Mcx8Ks0ps za_9Zj0_&ZLu$tUv8A`3?F?A9rV?VFk%6>Kf3|C=f(fj3t)Dbkc^=jHk%J0YDiu)xu zqzvX(r!DNJV@AjIhd7Qn0I=H!GKM@vg-Ab<+&PH(ueyZ>o4a=&(Dz-$ba)y+-gfxTn-gbtaPe2vvJ@vz|RslGx-Uc7b-!ef%9K_W2Xzk zzJ8Xk+~NoCIA*dt@r86)qJk%H-H=;PzXt_pNzowFK&CWc{MD_)DG}jDLD){-HKLs* zmn}{~1kG4>L=O{PJ>38~+&VSv&} zN0l$Xb+zxz-^q9<+`v_2o^!F%w&Qva?V&Fnf@k=Ace4TzvdYWpjVuU){K(%URi5@I zvzFWK(|v{Oc(^tInp>J32wa4QhbHAf-JT|kk$|VFr_)k7+((e?YyrY_*+$N!;@Wo zL;FWPQBM^G2sp5hO)7YXd7sW=cJ$smxY$7+c8&iwL+qLH&J3A zVgei$(!cSQ#UYrmEHnO<2G9P5Gv?{2HP|FW^LCUt5lX4vZ~zzEn{te+66_A`2l(xD z>nOy@caY*CPi`>XUP=f?`;hC7u*~1hX0Kf~;R){1#C}zW(&smi+mMaSXb2+WYqM|U zSW~1sGSY_#qGqIfTD(h=oHH%Hkc~rs&|bAY!DR*3m;2HITT4$65vs|3YmhPu;M+u< zHc3MG(Z#fKm$xw09%21f1-#mvdqE0v z>D4`&h9Jx0NDjeQj#!`DOyh_?pCcu|`~;w`-$8Rvi%z(@$)_Yl)rJB_`~=x)F!d=_ z&^_msmb23!HcQNoKnY7mGXKMa(}Sz{N`C~U6s3!-ChFaNB+%CaiqEW?c;)z52fxb^ zk~R6N0Plq8#+drM{VMJnb&jPkHpqN~WV#!nxPxsrrnT|DSKFV^oe78bZ~i&rQ2hUr z3aH*ng$@w4jnT5c{VROh@P6MDf*AjmAjAc9j0-j%+~HddqoP{1funPIAE)hs@aAmF zuVATacFvFud`udDJ0;ix_UnrZw}jT>=s;{I{~e|Nq4aVopQ7{FjWkeDABk%q4~;yq zJgUlSp^yfa)RH&>Nt5kjTTVbazbh47+nG5<>12f)($sCY+Tw1!>r=_^BqACBK80L2 z2fw*~zoCI!{WO)g*S_54em1AAn>c<4o=z11h*jEndlz}$Vlb1oVYOz_q{kl?o;>%P zwr}=vuzw2MVoOmsGO4qHQ~)d%>(z0 zII;giz>}$+F9t1(^eSyHmKIBzt@VI0O$_duOqMMDK3NE7u(d*MB?k=jgtdeM1&72i zfEx`tG%>FVru#)K4ui^lFf`G3lkz5f8SMH#6c3*@3w8TlJ&W07-duRXFhUgKg(jS( z36InHdF7RJ=hIZQ^7+?eK_k+z$cx~ZD!K4oQI?epXghtjWjX&RV@qY%D~L0u-~ zOEN`_MKv2U@(=dl4EZbx{M&*f>HLqr+VO;fcm5(c(QgREybxs4PH=2&|G9*-Y1mkR zZr#RyZLiydAR5wfo_|uM_JST3?7vQC#e9t=+BcTIHgZErw`+h|jLx zM=>2aDtk*PbQk=z8J_s6Dc9()0cI=sD&8Nb*4Ol5H&=UD{&3U=sgbfwIL4=h*;}*S zgyhG7o}t}ZC~b_*%0K9W5CAb}9ZKR;Ma^D#`2=SN(^x*C!0`CPlhq#pO;Zbo@>Z|` zHC`|}G0?VJ=;pdeDtx!Gl*L+2r*H=JI94%P}=;$%6-;9Lm+}s0r*?T+)reiQxYTIj~$&BL6 zCg2+!&o~3(QDBGAR)B*;Lk+RhcJ1w()$#6zt`u!tsmnv6YN{u!Kjl<^mUrdlu%v!S z{XX`Y?Do$=x}+pG-rhKq^P%Irn~VGI8NuIw)EYmn^^?85+7M}s@LF%xE;1`$vi|)H z@(KcA8|^O-G{K3AiX5u1r*u{|8Rp@p@)VQZQHokHil^Jc?y9zLdwyi7zkXilwd-Bg zIrVCd`H2hiALZRIXlYZo$(+>edgXqt#)6pRea0O%g`Kq+z@oO!MAe4&u!7QZS-K(Y z=q60;Vf&7aTM5+|SfS<{XX^9wE9=kIq(TI}#>;4mr{}HE6mr#R-;G|&)?G=#AFCeo%R@RB{ zC2D;d@oL-n=S{DoWJ5h=2)G@c3RmSHi^hM}2ox670kMiao>2G`mnk0ct3RL3i_Xg* zD?PMUe0>AnF*Nk-Ndp;`EU=Df`9B|R!)1~XZ1*Zs{Gz}-an$P+lThJ)fB!U@uv0MkEhqTRj46L5eT}HpLXl?apI3kH&=XS z8LLFpHp;MhS7mzb>iihp{fZ}Y9ohYH^mmhXjW#ne)Jhw>aa&SVMs?So16zx$5&tY} za@j)q-fbLaUv8y^Sj?@{>T<;vM+kH1CNpRZMShs^W(ScIZ$2PL;o=>=?Qop+wwUYycCB~MH@=lw#!f)7+*Ou7z568mnM=8P_4&|#>dRK`o ztC4UXDlTy=^6@E+%ehmzt!1%&LtT7^T;=(aD*1s(e6@=rYdJ>sx=O1*ZNQlZ?C3$5sk^t2qwavnieYVe69QX3 zj5$`|AC>DDm9q0e`P)q02YVuPDhdMX1fR#cu*ut(&C=&;^??>uGy?!PQYu`|7IY=1 zrtIi4DBbDyGjV1AaOK_Ce&cASS-bD`7q`%*0o1?$wWOiJUJlp(njh5+fI+ z^*Hx>*;h8;Ige*{C(xI!@Ai#BnZd2zi;O-otj5xf3Zt?8qZ7o%<45fV;-3~B9``#z z6wUlO9TU|*!i*N(E*Gsy9xkDuZo2c2)Ak|5I45(TY9PRHw$Mn}&Qm$!*X{`Y*Cf`uTSH9U3|oJB#N645GQzD~kYmLFD`;b=WoQlbv$V!0vsyXq5BvHu&B22E3l|E!N2Stx+_8wn@v2{sdhD}_EB-9 zUr!u+9E3z;vXg&zJK?B3^sBxTSeMYVZ63TMe?8TF)0*=`U;O&9x~IM!D_Nd?in7`j znY$LF)t#(qR#D_}w7b`t&G7h{TB;96G(peW@8#R{d}6eKhnsUSs3an`L<V_-zZDaaPNbGg7Ru*6Sd}%v+NJretVgw*kF<* zVIs$hYBz-TTc#}qXa6;4B5`u&**LustQ+AH3AC$(@Y2tY{g8k|y8T1iKjjj=Ghy8@ zk!!M2)r+8#x?gU~oBCX;UED*9@(VP8*CKZM?Xg8^$@agOaN>XfN^!l}o}`1g6e09w zaTAEMWzRDa%!~TyaSO)es_xE>F-x&!FPGb~p2$o|Q0HnCVTd6U)jkp~>J|RA{~l!NNgXdlaT5sEe_Qu|(Aq>w#TPaAT*u(&n) zhJ(>5i%7-0UP$r+ljYqzZBlvn73b4=!g9P01g4;^^*7VDxYyN_SlXvFTFE}6iKz+7 zRCFDr95z2xmHL%+mw~Qq`DRQS8CxOOiJrNP(4;dPqy+tHVq`a6_;}&!x14sEACO>x zPH=T3Az2mol^B3_p51*pG-uB>fUr9zaV^GzF{a%&w5d15XGkEekqSf>g|geGRt@6U z)2V66D$Wog_)zdAHI_o}mM>{gJ(>+xWm@&}ur&7v@!yE=?b|mER0P433#HVnjxzTX zT#`j2ah*g%U_gs)gvGzRP2#TPRDr{@%nMs@9IUH!5b3%5waGxzdp`+F2)(x+3SDM` zFnBHms+Neh!GH~n03l$H77lFfZpuR1$DAt=`!#)Mg6L4*S^=5F2!6cm$9JBiE)_=m za>$Rp9A@FzPL!LqJgvJpE;u4~d?j-HEm_zHE*$I5$g753>*vxRH|@wPbIL>wKZR{D zeirw29$tEz5?c~jrHmt~NH>(9l9i}G-Zvl$R-c|f!IN$>-Emszz18ED_~E zQyj^vjwb2SswEE`6ZLQi1xoG z1P59ySU5R8*H_Ltu#YNIc)^%r@KWQtj$`Bm3k+j(;(#zjRo?zbk(rgn0gVjxRrhB2 zLlP}ymh4FM7}SU*VO!juuBXZ*?l%s<8i@`-*Pgl|rcp>Y>0z<$lWySK!mdlo9C%E=KWCp~S1R!LhzPJ?D{Kmltk~X~2ePHgjhNPt9M-*>nT-&l zE;_!AgdZ9jQf6inrbltsJleMRoX)u>gI0nBsUuki8i(JfSSRI!*=}Jb-X@VJzY}PzWpx!S$1?0)SSeh zU|WXOiGKix`1$lW+cMmuSrWO`WAEj)yB`||gaBy_|1YB{okZsUZVE&p^>An}#z?*; zrgYqbdgFubMkb9|TwRZi)*(Tz)DVxUx`olloyVijp9?1iTZN~u7h}Os(}+gz>1tj0 zR@yJVaxZgt&s1y3KO!SQm#FfZa=ls@T7}DM&bLJiWgpV1Dl9iWY)c)4&fGXO>T`yE z)B40Xp&T9sW5tAsiw742R1Imfck|1Vi1#TJ3TnGhu(oE!+^#G#ueaKzq28n)juJ@;!|t zgFp+j;g>Rc>1$}*+oEm$R^37~mjpZh9$ZCuB{Nbe2)ncx8A9TF4<5!Kx)3ZiCfE$+5LKO1aUnhC z1hZcq6$x&IBvB}DOmR10q8z;^^4CKbpTKR4iA_3%fa7X{S=J@wHoKJEIe>R2uIjMO zS#PdO%y*de`|V7CcdO1?kuD+#P4sICo=^9=t#Ppi-t*C3@YF-kW6u}EixrwL0geFL z`j9Mnc`aT2+pIvEMC8)4GMxC~{1Iv!A%e5y+@ofyXv!*NxX5)$8m9u~fb#Mh(9@C5 zd6wajo)uzrGMcdHx5|wBvNA~^S#UMgV!u1{%0nE&R{*jc*}vR6a74>4h`5T%I}f{i4D2B1yvzlCjyhz z#(a~#eAL~5S0UYmaLEQrCB@a5KfUC~+`sYE1J}=g;Q~lko1T^4N%nK)co2^dF;zU9 zJJ6*OAW<}|Y%?{RMh_=M=m9lotUhM@j%j(YNkDIa^8HJ{8evlCKycfm3L)^nm}#V` z;Ch>af-)stacN;szq!?@KT*7nooRw`m~wLOO&yUBYz+#b<$^*%a#S5{e@F3tBn?`y zknS2j0U@dAIdi7G$ zicupQZOrr7rRtr|utePx9v|qruGXl_J+p2YPc}!^g9oB)Lyy6!@gEo>=pGEKoqT>< zF%|g#LwewzoF1$< z9*1cm>3ji4bL;U1b4jEtnB>dNbZ~&Bj%dm{A8z7AlE>IZS~vzG2h&0OPa520b#?xu zXO@$dT_X11$#pu%I<(NSY+kE1P#>0okPrZMIub7yYK-I?&y@N$vcBP%ck_V<+5vdk z3KA+`zCg+?>bv>2tkyu&RbnnFk=RaG0~dW5IlF#h|KHOhL#`6^wpdT>zyCSnZ^RzB zxpm7|wRi4Qpp_5W4u`|tfScXfZgD*ABG@{g0Dzqs4jyA>T^Y)fk)4X7W z&p6S9=AO+*av|*wz9C^=%4W)E?TN5yq*My`tHLIUNY2@=8B;jku{;VX8mI6(pax%B zb}w0kxQp^X1uytt*p-YSyp~MB&EFyOAyz?<8+9CT~&?B8>$q z7`2{0hw|(+mJLuERZ#8@;uEq}wR;FOHy=ByTnLl;WsJsQv|4CNjOJR@EJ?C^Ua}m! z({BDgE%M)ym!O_>FcmVn=OcZYzU2Y`84&#{zJ7M`!zIR;4b~97 zS=Jcleag&)#-{(7%lrV`E51KkUM$uufYF+ma1ApShQHaJ>RR81+(FQk1mrSgBI%~n*{8zaLy_hS0lguvGx z8o?W;{2sP`#pjJU{ZEF=8Ov1)bhMVb-Q5y(tn@n8CHYO!Px>e$&B7J|k_<$~>=-Rc z@S2M+U+c=P5*A+ldB`dmM?Qa$TESrR;+s_7KD>>{98xOjii6guXI_Q!^v^A_rKFN3 zm4@`f(RDov$ z{zT`EE=g|ee|48Y*NnBq;jMfc-`>!!+TladpCGK4#ld1*^BR`09OxTqG};%Pvi6W! z=*5*THbHJJRDb75fGLttfkCB7oR_63tB6YAAZ}YCw@g22ViU>SX}8u2=RQQNao&gV|I0;3P+GwRI7<##YGI{jt zw{M8`T=Ra9q;WU_Sr$*tE>81a4^ScrnrI3Wm0TUTt9_-mS z|6<*dbV|sy$9)i=#x5vU+)M?SjrPKeWFey34B`8~AYo=$+$)>~pIXe$Ns;l4_DM$B zyE5FaDm31al;l9CI_em3T5(*wy~l&Hj=1bnjVh}6h`spFZxe@Ku4oxvLDdTY8|CWP z-wa5BDIRZ6yvh4+YfbdGhm-MtWQxoj2>!}8CXZ@=R^B=ocwaiUOg7wGBAg)R!=+8i%Jh}Jhr&`84C4|A@OJz>^mCyDC32Z&=7#>w5`$@uB^h!BBwUJ*b zMh=}8A3=DMZol59RQqGj^1Zx6-94_NSpM?fq6MF7Y2i$0C{6(+n85rigWN9i?(Vmp zm#jg6jIs&4c8!!;U13kMIz#!In)NjkkNq=`TGCFV#eSF3xyTt9T6Q`FUSX#O@9y6u z^#6D(5*IHp^G5}X0;w3sCq7LlCk_^*L(@C@_WyYS;)!@l;pDOtB~iDE@zulCe;-m- zf?hhm(k4c@kbXa&F+u(w5f=E@N^ELDya7UMH?UDRnf9drlbA^HLrl25dH*}_UP;ph z628=&Ze#4-!9c`Bd_pBx97zJd_h0(dqQYX6qEYmRrpt%ikUhdf@d8bpg+d^0Cr`VR z6y)2ORGM-o!4pcSW|4BX{*9I3XI4VXAChQwE@1Rrz)g9sIa8=O%^z7z%yssBVqgB) z76Mqgk2`)$IYWDuQlz4Ou;29vTJ@&vr3j!&#w$nv3*6p4-RNjpbI#WrzPGVr%dV0@ zlS?7O?=IMPWYNRmaXnjX?bX)8j+E8D0X~uFJ`z8RWh}<>Oq zsDiMHAFq_7Z}WdA(Ec1)&ZgKdY?rRU}a5d@o4YhG#X2{0c=Z{R*1Q-;OM z7}iWTi=2o>lYEydg_BKZtP8!7HB(sHb=Cd{bG7g7_(GP!R1`{uA z6d|*`ECt%gh`5DE(Rb_h>2siP?FRckL9&f#IC@TG+RzvF-xE>Do-zos67+G}5wqqZ zhhDYl*hy{`MDeqYJ~;V3AF&a>_c7O#o>;e2#1GtG`k0?XtB%50=_eo!eMaAfBjw$@ z5D^;hHB6LL3d-BQm;jAPDBHtYVV-LaD^ z_jB=3bJUv5#5w)5Xx_0;Qno)a5;|nW_olNFK+na zY;htAP{v~O6b}Q!Y)`?+)1tT!2}!!K5|asj+InO{Ts=|BsLM&V!d~#xm~-sbv=Y#u z4e2m#dx-pm5-*FGJ455~0k{)co6|o6<=g|a2{!zx-|YfPSVi7oT*T<=hb9&Q7O1)f zRd7q+1+v#!h^3h;86WI#YDJ!Lc2JEg_uJ&3hS_HN(fneD9Wn675^=a?w=xtVg%+Ce zbjN#r_uVG7va9RC=vUCP-A2#a8u7Ppr5pe*3~hK}0JA*j_kqemU4>@ra@6syRwI7M z9#=+|aOmJDu-(TL6e)JSvX5sB#2u-sehl1qldFnFD%89bYw!$FX9_Z_xPSBNr{mV= zF)Grr>p$rFh9f2TiSZM6RXRnrnw3|lk3dl`qaB6R-e@_+*9s42)t=KnzN@we&(9X1 zd)(i-7Q%6o!UKhvdyx`LysWVrMKu(C>HCN4fGx{stGsQy2t>Nl$^vCUl}%rK?NCtD zBZ-8SA0}QUf&I0l%p2(7#%=Sj)>`m>EphVuuo1mM_{^TYL=ziDL^u(JJ5HQDyA%16 zd{4UETSb|`$C(I(r1l>WR~z&EZArM+Lh-KSqK;5UB}kM-Qd26}5*!CZHkIvsh2a>aYtNf5;)@;a zZE&#^^m=U`c5--(7A(rcEfyrW52=Y=SG|P39PnN$)}LLbI{)S-``FUQL3(ubmI~*yd61CCiV#*E${?Gp|@C(@^0(f>1+>j*^SX&^L%w2&F zEdmM22PbWmSw=KzyJxgJCIk-I3=9~0YB5!k7h=G8UBVZn_H1*irNlTw7Lb>%H>3JcV|C-U6V4L90T2#|WVrKE+0o5x;>iGSOvqw-CXQnl=(e3J*9u zLYvPX>MLciTyeO={{8cp;Lmd_!_i%a;)VBeKN&YN1Y(2M^6oUDWh+eF*I+Gpyq39# zwbxm1#0{nH$f%p9fT_YdLb?#TaxM#6!mEV{&s_9{%*;#6UdC;p0|?v11VNndDH?;& zA7B0L)7XNu+{0Cd_uI#(f22R^G3^B|;0q;K8D!Yo?*6kH>Hsp@=9$Et5ihHYB3SoxF8((@f1hrAiFyCj2pL2^ik8t-1 zT?y!8ijeijA2}Ei9C`03T>@-|Jo|$@;)QkJ~Y(}uV8RHSQR`s zB4j$O;&9UzCGH47c002{CP~lIbxEK28d33)!IKVN@^07giPrV#yUvtD-=}&i0c7wJ zvuYW3T{USFI8_U!8-omD)_mnj+<8^bPF8(xfGo3V9A0Eee{hWf}9x^ZFV*835%(ajyaZQ#s-(E+>{6sR+7 z#8r2;I!GUBBc8(u#y^OU_1&y~f~aycqCqS$cU%jVO83?+xu$LXrXSPM48u5^Me4>y zf19q}1P}iovfer@>Zo}iMgc+T?pjj1JETKWTDrTt7M1RjE&&CR?(UWnX%<)-X_ju@ zkI$pO@8k9IC)e)TbI#0}x#ymlbCUblRp)~8D`DR5=Y+zJgz}~UH=D+Yw+iAPR7#mH zhabeFEo!J?!z9!A?UBL%)FH*9YG+IT=KCx};R7}=shVyB-(HM*d|?e{j?PA=q2eZlI zp(#ubb1w6JJI?sUmB^nFPftq~hi@5JB?p(jp^-(^n_&rxzI7NdNR(kIW%9UlDY~5& z&H6w@-g$y`E~_(?zw+h#Z5gU=%4)rJx6=S_?)#QUWF>dX-weiW%s)ugwU@vhK&rth zq6j>fskb-B(kn~e0M8x9vRbD5smm{s3V<{^0Y+2oYQNolB z=45lggYCPLC;9SF^QvyU6R21S-*qWiutJ`!2F|&{Fg&=NreC(U9lFMDZxcyiI}0+d zdvEIDJ_lD`1?xlK`U{cvw%$N?XB2%rL6fc9`-w==n+o2?irdC+TqJSieq$6`(JuZx z0mOm1*%XQlx)|bWNOhA36tgZX3%oS5q1%n|Qo~hySK|x!_Ckj;oDCB$rKVNksfOU^ zUQiE$!iKK zw`TX+W3j{gdX0AD1o82PFV_cs#~#1R8o^3A_ryuaXN@0t>_~4we&^@g@nPSO)1f_j zJd6$1=AZ9O_!bcJnP>v=H0e1WsF%4Bo&<_ zG(N%__jr=#|JZgi`5e+9jz@HcK3S}{K2NK!N7_q6y}M<+l|oErkmRT0gZ;q#AtWkW zl_#cNtLihcUT*n`TkXAZ)=ohe(j~euSq;3&QyMHF>sArFiK^k3~Jd*ZdN72+iZ+fQbPZ{w1 zRJt9Lg#)c|)oHCa-8ZGa@>&u_Xa1noVO6bVdj3}IBCK>%JS9?x$gnayfr06{*sPi`f`xKTG+OwpOHYJx3zZd;c^_ei&&Lie z16pR%?@41(y(4Z1Y8)EDAL<00{pT3Im}lXQRL~l9lCNhj5$uoIv{=-6+dVnn@vh@$ zf7@ki<0*LGkGyNA2?5vU6w?t_Ao<2@nm~OZnHVL3$|r=niWTreB(Xeb;2%0!7UI)= z^Z11PhkTPWvfr?E6D{Q4I3(3+oEmX2ErTUcsV2KtnrP)*osaXF8^Q%W=2Depx3vl- zWrO3R=)nYzzfk#Dv0@PZm-`FvC7AjzT(~(2%i9tYnbHJ3mE@Y_Owsu!B&}}YUhVFi@UA9;k4YG&hb`(P;Kb^Y5vdfHv z!owfe0`L^v?!<*Z05>h=XA221NI?(3Zg=;mrz@-R1$W+-j6gOFc452$n z`8wB@T^KY%S`f9%Y~F4Gf{LQ(Gvl5?7fo)^Q7i72167(=pC@@0hAkxV(Lf;WP9OY) z4WABHP1KY6dcv5ldY_N#$O^ehv!x1|WH`smyu1HEG4(}!bQ@9vp0o^Ox)fuw1ZToo zAgdQG(&Oca$p@n**S^O#i)7;ry6S7;lWSqpqL#vq*O{kRL2*mLHbj1Jm!0_$3})kp zwv1CoQq~vs4F?`Ca%W)+esr)?F~Xjz4HJInHR}Wk9C7syyVT1r-|9?J_B}~%;wZ~? zg&#VTK`T{azuJ&)cdX;@P%UpSjR5*m3Q1i@smC>lvYLkJVa2CR%&c}{Q;9y5zd?lT z>2G}W^&fon^*xS2SocBThaU^FpBw{F6I*ybYH~MFO1J?*u&vy;XNj}p1XU-k@89IL ze1fvmVgMP3K2JiTWM|1GjDy2T7X+YjEHWHYKQbzq*OM`AG8(pGb8s0Uj?=Xv+vjZW zCo^uTY&I_tnmLA`l|}df{khSZlFw_;td#+E-EUUa-F$m=1^yv59vELfqt7OK0s=w<4a>wM}R94 zZHZU~Ni{QdI-z9VS1S6HnwSc(AKrGwXIRJG6)7YEBjaS}TBK#}jFYM58O?s6UL`U? zRD9JBLQecSYvG&H#HYi8{4bXeERUB{nm9eFj3_8pMHLEY%7II#1@)HOXa}o*x>u?f zi9l;Xi#hHqO?htYmX9pI&e_=%ul-n*gIK2x9e7q*l}T8hI4XYN zDeKCaHc>fpy7K08Oxdb*q;)CaeqS=fkDtvTYDM3Yk!Y5DxrA?GwvZjxey-~sYfuJv zNz8h0RjM8M@_}t3c-zv7gGU4nQeRcw8l60?*|9k%d3v?xlRHij&xTuHbl?MK5WtV3 zN>{v^Wf|_i>3_zVuGn+Zn3j_SD>q&XV#xB5rx^M zPBIxiTteMQ#m)(Zve2K(=LQMiS_aCObw7L2ce7oiUkh=TCE<0GN*plc|Y#J`_0&>ZrhhT_8X(r=Z#7|GQ~PI73Y|ujsk@=Cd!Zc z+Lslz-h7cVnNBES27_p_s3G0txFJVJQ!T00V%lwSHXFvo*X1Z3Nvld(**C(of@C_N zV0~d2*!#qJEKyQwis^wz>HiAirrwu~b?aR5F!WJKSZ_Wb+~R^aGFalKo>j<3yOn(D zV0M6rV@IH*b32zvDmH~z2RRsgbFU<{T$F%J4&fr+mq#1>jLzp-*-@|igW!HuzsGAG z^hw{j+j~B(=NnE>K2bk?HHX+sIw4;3akCPa+@%^YnX@m3q_T?A+7)d5f!uHX#)G+{ z{N`Xli1rd~(!P1L+QI%yLuFH4h#Y@(1Ps@*sEC6@G$oNs17W^a5FiLJ- z^r$^8n_H`aWMkrUF8n+bEOOCZ8u<@2N0uUTO4@$e3Yd$I?b>;Bw)@%8Rg&B&Yj4r~ zRe_zy(uh!((DXRc2IN63F|Uem#0nz9;9)ef^Ez21LO|=?G5;Yxrx58~(L>ZJg4mt~zOM@$$<^!0@b2K;};|Wa%+4OV*hk9quf3}AvViYX_uZdv^Di>GA z**L53zQ-WnAEJ+2a)HqBfK99xsc{pT1@)f!C{QE~FxlqDmdFBco5EP{ho*QJJAHIjC@qiuUJB z5wBgWCytr!c&sXGd?Y4`P?D56crD?8;?i)?Q}8vcdo>T)XZXj`o`co2j|=3^Gk4jy z53I&8!=}Ec>gJcRK&TCi2-KeCqPb6xj$|N*@i4PqJd9sg5sgwPKb=-R*~&*0 z;<~zMgsF|kd$M{Rn1F!%IkKa(rG}XMK8rFf7E&Gujm`uielP_qj>FecA!%BvR(oYCZ7@@fL&-}jL9V)x_=VRhbedD4kp{A) z)|CP58V;Z4oLK9x_2*Tnri1ax_r+b1BIYReE`|yz-ORX7FSe`uXN#;qKG{;k)0!Og znSA&uANfK)an%Ryh=44XnBi?rxb#tMfs6N z&d@EY4kUnFoC$9f8r04B5^PPFeC%Aj<$GP+sp^v27>QoikLeab;&uz?#$A1HsCT=d zdn-6}>>AitE4@)F^i4%pS8a7}6JDkHD+}KNKS-E29zFc$M#UA9I1UyW?p-ST|7#ck zI&YPRWzK5iM!FJQTC1phOAAPjoIfEIG(vB(t(aG_IN0q-jj zdnOw)zL^$3@>``ruO-AuZs&&(0u!M&kw>MP4Wxw2wb&Xf7wCNj>03HSL1;nbCTYewJ7xhXsN!J$+Kig%}#_-TiVU)c+ZFhaY}^ku}< zs#xALvZq`7ekQc!>xDG=@FD-pW8{kf9Tm5d)(6z84WiG64g!(Y)JU_04~!k82NrzI zgdm5s%At38pbmQ~zmni?KwzOUrp+yu(?Mg|sw+0wSuS|0v|{$mV9x;$?}g=VDEGqJ zTP%#v<)o2iXJ=n3y`>jiTIFa+gX7WQw~cVAHV%6#j)P)ZtD6?dQ*e=YsP6h7uSM^c z=*1%9%U9d|j`~iw$BzUS{V^k)7lzb%^|)GAe5-7CzL;ey(blOsINff7T}TlNv4n{y z7DnAqZ6#bj`!rpG5G9h3Qj~_d_H%Dn1mc7x4kAZ?p;!B) zlR->5$gxOyW{(#;$6ywa8q`2{{+fr1_<2S=npp51c2V#!rQnf9UJ~O8@G~GKByVw%afim)C6j^= zizYTh$GXz)8-643_y07Bs8RU1q5?J1ln}9qA8SYAFTuq}CECHr%23D4HnOJdjpBIV z^`vGC@oN1I{2+DEHYaOVKD=LZp!kOEyTgNCIo zqYn3L*KsOyac(Ne#qt6{;8|E80!9Z+>EXO&wtSWuy0S1JGA`X7e`GqcnjyT!9=r$- z$^2#`HLn@f{Iu~ zM`@UfHs%BOx=|_~ULwuy5iI-ZAYRiOQ=KUJDI6>b)*SDSN2lk2$nhSfWB;#I)*227 z+xl>hg5LN)1Bmiad!xf!MaF|crq?fC^mQR#Ey#}|nS}PopZt=(50~Sws(fe79lCAg zO)gz9cPcn!>Bj!L#R+f5gY0oD6-?yx(A97y25ojhvm7dY5XFu#=E^1?tj8Wcn6Bj? zPK@43e`#-T-^o21dr5{np)Ua556^xR7)R=Kd*5G`nRJQe(8PB7awDi>f{CRcJU91( zSOLj}_bIUhxf!1Opicb;hBYcngZ0~38OBv}jh^Av$~`{jBiUhBMFXh`AL(-|O-&QX zQXntKflKhz=o1z)wWIy3xEmx+z)ZT|_5R_FZ2#l%O~1fF^ViwP_iHU~t2g{Q`3i4LHp= z6&*-`JX=Z{4E)m;aJBx{0$hK|b0{^P_-dGHLG(M_d;BwF58Z)?SSh+i757HZ&ZM^{Y8@duKB#G z9VroTtS}CO%)J-9ycW+ABVs?*6j>eDZD$4zM&_>o6_c`p*Nz+awaq31llcxw118w^hNlhpx>x00p<0BL) zJRBY69}Xh4H^~g>9ocOl5BV=m9gtmRJ(HE?$qrUDp}fYN)L=ulwNCDo+1#caQDYbc z!>I%xF%~Tq7OZ+;jI44QwS`Pi*EJ9LnVNJtJ+}F8x~lATc^G`I(bb`~o83D~IJ#lI z+kLztVF~ntt%c+i(!Pyx7hfp>aa^W%%gppPq3!08kwqvVcW2jxAFe|i-cwjI!xFc^(!rN7 zd6m#020Wf@F*@9nuz-*NL5OD}ZBTMfx0cgC=Osir3Lz2f(NvZSdm)zne~kuMXz9o_ zB&SF3>>p{)HZdee1Dh*QI$xc1X+9^K&6#QbiB0gr@1cH4{*70>A|kaeZAjM!^;Y(g zFM;T>UPnlB9c46W+yD@*#_Y{j6qtKZFyNzg&+E6Bb2Jjr<8Q%^pywrxr#ZI^%X>GY znc1mbE|pbH5oM#?ob#x{Sg$U6PbKtk9`PQ#bc7={7(*gp&&9G92N@a!RLF!vy@j`s z>S~(y+YbrNo_iT>i+x9x4B3M#r0Q|0Cy9yrLet%Vh+@c{X*5j3=QgEHhBc8#`QZ2x zH)!@+qN!lFt?s$KQnwy#JfQZeP)3$v94bgvxCsM`=w3VqlMcUp+oV zuLmulFzfdD18u7cyPzw;h=R3p-r0*z&LUzznKl0o3vybEx;#ty zV6SZY+BH{-T0E_h*O(N&1>9*eC4mk~E8Te|jK!R^j?lHCU{;Mx=hnf0)sOx1Zrth7 zNBDR}8#dH&P2zuhckP#uzodLu3vmR zUr!b+LG{>dCNwuU*Xhj|GBosDs(aP;s_|#2ev=|CPFikyh%Tqg=?q9~manosx!<8k z*;F_^*g{v82XAsxom~m1WN)u5RScha!82|kR))mYVQvnCNN;Y^E*jh5orYtZI~hrx zdV+p|%4?-58H|_`$*u-l!SB%}9vFt2=k?+n2Stw8_wdB!hHdaX=G#pF~;nHi)C zdIVJCWARm#^SJMafA{ze<4olB|8GyjL^$UAjqYL$381oWVIfzdp6xQAE1v^GA*INk zs+KUy`EgNBz0LMhBd>nx4y1u1#rT6a>IC6kUN`%cE&n|Ce1?B~W5~^Hw07H8-NW$- z$~J6AB>)%YM|FbjVYk z>(J0ZyoCCx_{{&%WOzI4vFN$`5t`+{b3)tdzr%UhvZpNePJ~ZrFRrGscJTrR+{lUo zilaqW!PKoS1&BEBwqN!0-VHRmmq#`vnO(THmU)d$;-ZRzCo-^r_@hzx+W9ZS8X|`k z@S3C+R`$8Nc^v+WatM-NT%+2rNWQ9~_A}uQQwdm0xhO7d9ID)NR zpMrI~EIdXr=(bN0f$-oq5JWz3Hic_=zfuCb;cLeNKCCi6d_XkZ=;>xdsV9v6d>y#_ zxNCQznL-&oOcFeKa&q#blvNobiVCX=B9OvIVwn5#X-TIQJzV&*63Vo39Gv^o4v#K% zX+$+OBs}~g)vjFf1!ArjuI4G5*9%JRe%KU(DmuuEnx8@CX=IsfIce|UC(dbCP(@hP zF}b&E^j=7K?7v9}nUBcS5Lj3q&=#{hGeFs-2e0?z(@US*?S&t@n;&mFk3U$|mG$Dq zh?{cP;s(86dvCKSMk-rePsf!d{C2UfLOea-^8shTb|(3GSY$=u_3J@PPVbwYq7Qn) zS1jFY3Y+P8F*2}7A*1(5sC zIKZVfv_UtjfK!Mim5=qgp+0`dQfQ2x^o`&{yHRf!R>5MSA;g(E2U0I0SoSM1EV9#(xigqM#;U^0=h=+mk|>A`okdD}(% z;Ug$*#QEeGN5vfx2sRnN*5FZR4}~?)-loR+A6=qtR(&+Q!^{DjxDCKuuUnyWtxZjc z<8JrP?mUzR=&y$(qlY4%135*>*}6iTMKHvn(f5EDNX>g?LAy0>Ro%p-^Ose(Ced6v zBfQ5V;guDst^IL}zEWtqUgO>sZaNfwZ*^U7|9e^N*42<&)jF{;4=J{uAj~Dcr{hs_j8Vi~jOye)}uNIv^uFwiEG8yuepHYFx zetUNOfz%7!1MY$`QXu{l@mdO_MrW*yax<_a{!nik6ih0mECLieEAobwjVdvhm701u zka10_>!f9tC_DMuE@14Il~r_kG}{@GhgMbHKgWwGT$d0p4~-3*c7(FI{?g&`+G*t3 zQ%$7w;iWn5#0TXU^wwzI!za_oUqFxWG*5#Df#AdNI=eS1%Q2N*KyVL{rqrGF$l?c+4iCQunjd?7!wrbEa9X`%@lH8Ud?q^i z7nBB;;-{qQmVbKe_Gnipk&K4Wf%4y1mw{?kkEztTL76h`HlBu2H_qCzq-kh4q@A7W&L>3s!LTBO?6UKPoNw&K7rmp|j22cq|F0+C@7KZ-jP69N^_)UIZw4rfVF9|><6~Xk7mx4s8h0P> zrYx#fUy~gbe2t`#I1EK5g9dD8>lo+(c`1abt!*Gp^Mci&N$?734&G(=TpW9K9q{A& z7srUV$;Tf9ZSeRq1Gnw>djRA(0d|Ywk;_{-jVZMs$bB0U7x42Uq(oVweir?V_e}D8 zp~mEAW@~UzHSi>C_q%c*aFi><{xuTvn?N9yy|v$BGC;AFL7Pt<_Ye4jS42pRx%PTh zABcVPeSlD|5Wd8~j}!j8pBYOa@x=lGrrdD(`MR#}a zg(_QWKCBq@SslbTMfaN%XR3Q})f!%En?n=0v(2KpkzH~8v~%WfpAzj`Btl}jGqff}aE`y+i4D7n^ zQV@h&F4=AOZBJa2XRdyl*I!>&pjCXsa~J-*s}C~^GJTkEaF4hjXU~vO4IOw)ObDm} zarnpG{=zh&Opi_U6n|dw`Rd80gkk9VGnVgQ;}uLI=4 zADfGu^328F`LB0eqm9(D4C3VmDkFsHHQ;Wa2t0Cr-kVb>f~~z~>%!|YGYBiRnT7#j zfY$7c^SK}<+Fn|&9suHY9uMcLo_|i12YS3FoW|;;2#fXdY~V@)bTJN48RwGZ1O~VJ zisv_3`$g0C*OY>3v7}_wYZX1`fVaBbaeZbOg(rfT5sw1D6?S=+mYd#`XE0wPB=Lu< zpxQj9QG6j*{%^%Bh+|xgJ-!$0Ml#Z51f)|3>cpj{-uM_!d2?tAaq2Q@5JK8+?bpH%>K#EU)cF)2CH4FI+H4+(#Ol*fTRjsPEl>B>Vn_YRA8#BLW z@u6qm@?wJp2$X+smHOg`MAs9|jBj-Ui^b{mvW@40UxSnQ_=3iV*W462cW#ix$fi}R z$^5uRn!Gxb^zPn^OG*911&~>;MZIxZnETnQM<_>!EgtFoLjl70c^}9HN}dFL4+Wkk z_>PYrpgKP!dV~=p^{R<%e8>xxoX__p#2Lc7p|w_J4DZ8o(gG?K<`N0nDSpXZ!7MrH z{^-kq+kd(pG_cBFfCtd*AA;~z<{sjge^xf-kv0d+FgkXgN}X>}L7}C5V-3_5oG*qi>rZWR8pNKh;;{7+$pM!e7V0h9IFEc*b^v?G=>;D9l|9xjb;+8VLX1BppUXE#{TDN1vpsNIB#7oO;eD@vOlx&V0T{XHk+t_^nkoAr1YBZwI1o zmIJ`93I2QPkbzTYed+mv5k*TLmI+uDQDi3VjO2Sr@$+bmO`K0WUUeptC}@HgKF}F3l5nqnfjth^XoA$?{`# z$(?Ivc=)b&$X@*C*%YV5Pd3D*-^0oUyR5kC+;J2hglQ@U@#Ybg&M{+r2}#^y^--#M zV3QBf5hE2SVmI0>2pqrc9+=2qNHab_2lhk3^`>WO2<*1*dslLrB z4c%1Z7*$6E97pB~s9j($28ki59-1dVR~cLB1-V;)z7QS{p?Ucr`9`CSF1+==*8;A| zZz4RZiUT7dZI5CKxK$9y_2YxHSq7z~ME(T};WgNC*YNPbc9&s^Rc5`AgLkWaNX>XHlj4BT&2pW7lz zJM>|^S9p9Sry-rpIPu7U%}pEp&6T52AtHtfu}Yxm`9`a9(81}Z{n66lU5-!AuFu7V z26QnJ3DWL7+&^~a{i0JA4*v{C(r9WNVeEL1l`IT?zWk9We0V~|}^MogGz~8%{ zmht*Vfuh7t0h~V%-SD5$4Nj}?dXd@^a`mk!jkYNMn)_foJ(4q>^|!2bg0I87KJC-agatNnv@9NrN5Ks5xli8ZG*{j zoL_X1o%eUKJUKCvVSz$T4$ke-;)<+}4vKgcBVAvdR8hp0dYE>wA$B_8fZ%`64NjYI zRKzgn=b zF($c@Yz}j;^=eQdCA>X673Y5@;B2tI^W_(K=?zT**M#sbiJH-4aL7}~p+~<1u!uL0v16N1EB;{>I?;p9dw@Q>WJ4UPj02iqM>lNPhRn z{>@RFp(SM&-+&~O`LNb~6R%$#)fJD8bn=GE!a33HVQLGPQ0Ulfnt=I3Tf zKJVaKqA`j7Go{AjwbYt6Br)=#UqKVz>t6Zo7cFYTS}erQk{uUfkwg8{5*wZ^WCL*& z9bX{iVxG*qHX?>1rwe$q1X!-T<@gV*`^Mq=!LR(fwrV%Jo#SPSlB9~VrHa&}R^{@B zmbE6S;Bmfr_o&01Vv37}3$1ESVx$)JIS_rkptoOp|ICx;q) zXUq+~GyhDG6Kh^;3VX-&aWcMRuB4S=9mc zGCa?1Ns6=y_EX|my*74vJLhehX>zg1cKYg{39$?c~}(WVYLW^E`}F_GA^}V295pPVUP9xXCP}4 zl{UtQmZg|m(zMK|2CWJ)kG6UH{vLYeUSMXH#I7k;v%y1`3nL@TCXon}UYtD9Z;9;I*n5qA26r|lo`c*9jJsv&i!?u5wa&SZ zkrNu1VQG1gQa3)jIU0v9b8jd;UZNOvC&S za&Ar~1+=ktvVT%V>hYH>$S!*hqJnEIf&9nvI3!KSNgs8^$+Fza{g3v%H_5#kiSoLr zTFrLkd$@DUjgl$A8nvuJO+X3~KfAr38}yB0zh1cY@LL*mG$TGyW~3u_Ei>(2U-a)? zyxW{rC^BH9r@Qp6`{izzU{OfNWz$Oc9-^)&n3FR!{Hrm|UEkjoPKaIw-_-dmH#v6! zzH^EC&sNnNz$O~*dsL)J!HmQNIT1J4R-gk>t2`47znc)GwY!^(ULI+G{Vd*vwM?Xb z-5lv6zgzXRZOiRQ*`|YAs2s;?yq(Y{H5I& zZSksH$jeL@V5PsV9Er*A@(4+( zC}xd3Burz-atc}vtgeH2+zxLfr6Q;**v~W1$;eQS(@B$Y7u=-CivQa)! zJe%$LuNEb|2%hN#MmcPjQ_C~r4H+@kyqO$)eoYM7Le7*62cFTg1%s#Ijtw|%U7v)Z z-yla&m;_n+-az)aMtf;^+SZoz>r06Ofmj(XQ^$uB3<7$1XAx;<{R)CE7jmu|lBC!u zz9#m08MmXjhpM=bPL7Diu73sK$NE14C>6yypH`9Ld|Sm)`MTAUwQUo#2|3Qn%5wcj zo}|n1N|)T^=ja&f6HZZbblC)1@*3&1ECQDw_EVGGk(tpl1^gY<@HcuwutTBy&0 zgx-Fl4#SWYT^K`cy1KgX*Q1CNI;~sVFs#782eX7yyKr_I)(UJk^5AWLT$d@hY6#&& zJ>dPLCkfMW2bW*q(&Qw}|D%}3rnpIEfN`l1{<5@b-FjX8wIR1&oPE`>#hD*u*tR3S z90<+hcfFDu86TI;*`C;`UEiOdHFIzf5nNI}yA9%e#kz65<#YYGNdUk=4!#B~_FR6L zGijP%TkCzMQ+dBLcWW8qTOFNn*zR_NhYQAt739X-zGDyQtc1yAEkd#B2_}=C%!zzo zX-qbXj!_a=Mu~*;alR@hRAKwiOs)UU6ol7dPu}71GI1iTpz6jRa7(1pV)>U~);^H}{6EcblnZ9v(b5K_)~*Mv*Zcp>^lyI(kM?+D1Y+qm~7zserNR zTzs!1(n0LhdaY%yTZeoF={SH;A9YlfMG1Pn3U4LB%Uc++|5#M!+vZEefPn;99^SPL zW*i3i#n->JV4H&{IaNJ&Z`5?5>g9l+yp~b)>MBN`^TW`6J1$(yhd-V@&AM;k=mJ9w z&*iH4YlRp^OoJ$q&80x*Gn`T|$173KeVwVjbN=6U`Q$s3g(9gQ9XYfdg ztUnXb4}WG-VZu`+^xpK@ahaB-_Ajyyyn3+qj@wJqyWI+Vh{V{aB^}!#hx8mTkH@B4 zv#;-oGa&$sZUc%hN`;#qNLb!w&we$^auiOIEoc(h(Q$4~eIEbBlm3s3t+b2YB4<+> z`lZOde3kvR;@)wpT9X9%a&E{;kaS$wt64Za==2nJZuEFQVav<+bVJ*S1%5*)Caz)k z!guov^Z43m!!l#RMuBYP(C~oiL3aqh-(d`)6(7cjj_XYFhyo1KxQo>GR)+x(W56-p zugFX$g#~ek_PljpAbEdcUCSY!zQlq9>WRf6O`=EPczd1U(bUEeUxr%;_%72x8r(6zIfR_n50{Q@XkQtkJZ_??HjnjFZ%6-OGQa` zLJZxe5dYQ!6j2kE&1p17wQrJO7~Gfyp3INS%#%BLz1MGjPBmPxbhvyBw3+LNcNt?2 z#EM`#`5k-TO*2)<@V0w$p5VlZ87fPXx8H?9Jnh|TbOl}#lxxX&s$;pGYJ<)85H{ER z`J;cib30XTvkP?6sbp=)%y=$J?V^hNKv-~|dDhx$51QeTo|JA_r)A5W% zR4@4quXPfYtniMzpF3pt@AnQo&F4oY3mqHuo()Qe-(7%Yz~|G1acnA#qQLRL+snNV zIoT_{*9PW;g7TECIA!wZ*gykEiDV(nc|h$OnCXdb7M|$sc~Xtc+T5$#@)xgq${8R!o^olF!DLC zyJ~LeU?Jysr2(L>uTMbDe01)0Q*MiU3v8j-L7?9BW__{sD)K;0afWqmqXd4F;gNL8 zjGJMMO-1eS9DoTR3*%eBHN(6XM-<6zh$k{Qm(n2Aub$08{%Tf^rlLG6c-|oEcQ~@_ z%lmVz27uiTg7!57%lC&@z4Q-|SY|sc%8IfI?Pit0A8}k(hH-BXTt8i_h@Qo*Wl{uK zU3=8um~N~e){{a5!m9Ne@fMqki`9BH0N7H8F>NzjKuE~?=Giw)lA5II8`J1*C=)P& z^}iEnXU{QYRH@siRs+Jd-R<0n+S{zrFb7v-Fx9fpiJsZ@)P*9^^3;x}SwLHW-lc(4 zh3p22Q6TgZ>~wceaWjzG&L?;|?;zA4gks8a*p@yYQ@m)z^oHE3?$@O$wHA5AN0SOB z(0a^Vqc@i%7U4EYUe#P0nFhjOPY*>T0Bci-j43ex0RLMBj);=05N{U+8LRyNT37)1 zuZ6%h6mvY7`V0&}@0TF>ptu2DeI321RcGgcxH|U}z4d{IzK+%t*lauS4?TYV+~-Yc z-h5FX!-8s~6K|zI>-T@}!?l?FXu>z2WxJRWDF-~O3wX~PzQ_HZCC(f$NCqhv7f@HO zzv>G8zB`Z~cvTz@V73K=*nYinnFSwS+xc$1&Jr#i+J@!<{ko!zc`qIc_pZgNmeNEmD5gs2ta?%fX z-Gw=GM|K$#`s7Hrqdftxq&d2Zy}Ay(d_Ai#CV0Bz;ByB;<#I@DbF{Tx=Xt1;*fjli z;;b6wqNS)E%lU@Y)WTC{Ss0r`(8}ZTos3AFOhKBp{+$ox3gw5CnP=3*;;otUSk30yAMQV4pcy-!6ZL2F3QK=Jgk$Z2~7(nCSK9Y1w6q`(qUJ5sBjJmH$-% zMa$t6ug8r65Q+bJY{Mzp5n*KS3O-=fxqg<%CZl9Ka!$NXo5oP-RMRivb(Cc}QeH4| zNzRn+FC?nbvpDY~9Pi)*zz5sO#xQB(vA12m+yjXN(J)B4r*Vkvlok6GDy~ImiG;!pBFqDatB3V1aJ4Z~w zN9?k*S6s}T$o+kC>SJfxJzypu2p1m%66%!a0^rJD|8Y0YNZ%Q*?`qVX#2kp`XR8IhGabEfk zeHqr49icK`#_Bt}E}lu2A08Rm9JYCj(4T5%rpB?@WO@TT{^4gT+-A=6q|xG!*?8xm zB{dW?Z3R##ehFu(ENr*^A?a~_*TwW5Tay9ni}P1KkLO50Jig<-nXH{ZyVs{}=ySg2 z96@WZBK5;t(aP}yF5Lu@INWoH!-)n`S0CH6r;afPr z8#NICBRKrU5lcbQ*A=o_Plf~6xs+0uV(R@1$&~xD@%PtB{(fBq__>PR*$$?$vB!;G z;THc|@;0$s?F6)TUq~F4#4|Y05`gSjzrO5uUKIgCf_YiE`s_b|b%h*Av*!ufMI5x8PFTk_{2rtpV(BlO5y&j#7N=(f zcS!tqfZ&Db#H7Rjgd+GVfb)F+b|&`b<`jU7z+PzYpm&Ha%LP)N^aQS#lX{B2jawalccacAN~2wLhNLYggfTa=p?eeAwcI8&e2J1eYePw{Dgc_au$`ueKVL zXMJ3J(Eofe{yQ+tR;&fERNWz@Alu(Bx{y3#p}Rn>WPIs@%BqB||JS0Gnfu{nLR?FO ze@C$vdDtPzz~cK61amm!HS^zAv|UK%6pFXLLra3t+54Br+ozI$bmyKi46nV{r@6P# z8}8KunB0rwF2W62v-nmK+w*j}LUdV&-CuQKqP7Fx_rnQsf(ah&*z0xU(343fI*M_{ zZ5LzFsPy!aGqc}6RrZCD>`IR#Lxf0oFBt8qvG!l&u&?%CEyt9<)R=;(KrB5&3@ga* z4Ov2i-k$l^4OWL6cJNm$ove;4T9IsX`EY0W)E1tkWf1!SbTtkwz}g6(<`9l&M+4kj z0(}iH@;d|BKPImdW2)NobM_{uqVjKwORw%=U!g~wxM#Ia?PR3%2O(UVKM>l2G7TeF z-w!B?JTq4Lf0L5@XZ>uzPt85i4dCdnIf{kt3z-SmnD27H`NjUxd*j^KG5|4@6oP5!lg`cwcTc;8JSy`aa-0?@dQ65gnt zVER7?eT0O3-Ln+;P(CgXaJmJy3G(A+&%%oX6Wus3>K!E za{F=iPrkk&hbssD9i<*v{eSSry#`I2SQNm+Qayp2s{@dvx%v?!JsH8O%Z#82*OL{y zzss&5 zHM%O0^BewcI02IUQc>Wb@m$V)lHN?XjS$eQ%qMV=SAQhZ8Czm;ASX1OP%lRC$3F|g z!3h;+c?!4Tt`|#B#y&Ad`g;x=_Yx=4<%Ehr24Z;fN8`c3iWlok>u`0~SAqR716Eu; z^E~P~oL9sjF}(A0v`fqK%!zqhZ>tUm*C_Mb#@tj5>ZKN#0VA(0|HTOGF8{Yqn@dC! zPPk4{p5N=-`9i3|l7bUgbHl-g2$x3rcfaWjvFM8KlU+?+f8N%}$uRMv!5PQBELh)? zOi&WTU7s-(H~_TC{_n>T?)ufSYKIyd^87_48D`~uVpZvg`g%S z9llPuNTCLhl?L3q=T$s{{j;Sz?YK5h0*MdR z1W(~Q(QqeRX8akdcfw2;-$s{ubia85_jf6C8j4EgfJT&cnA&o}Rk8udYmj7s8aOks zDPYz7B^0OsU%OWR)Z`I{mt#_|(MD>(1cLU{34t03DnelhA`O+2co3@? z0SVqh0|p_eU{s`vwj2$D%3hn$S0vsJnf$5CO?W0`5?2dEYmg4MXicc5OESS` zHl(>FzRM4qO2@($Wv(Td{OQq_?D59drjeid7*Oei=&iCDHUkwQnvpEY>TITufon=Q z8A$)97NR=jL=KWOd>4b;OU$Y|zktzmU}>W^iz17WOM!xp$V9Q$F$4pAIAmWBXZs=5 z_uiJkS!&J}aAv`C$IZHh!Mm3y_IXP7U#wz)O6II=3sD2ztO8KyPx133U3Fg264=Jc zE}8xdHXLi_1LrVkmgrw3ajPP|t zA&(*-Y&B!#4n%2)@dPO>tc%P2D#`2c;&9d`VgoKXz0=1^u~U8KSW{F^AWXR9g)Eqq zCIZvxJBO+gptw7OZ(8xJJgp;(SR{swtA56VMw-74M0-Jv==(*(jj+B2A&Yqv-No^6 zSz((YpRESEeUUs@J=a4%{5;hMLI+J~-Zm=`Dn=G^yFBi&0K4K^Lw@NZiT+Pk$E%!PyTH-uIRV)oBKDI`OWBCG#rN&9rCdFnVZsNS-Eb03e8E*x21Y}0B5pa_!_Ms7ilki0i_HKox^Y(PZ ztCYNC?`At7Dnx1lNa-4+4+J!%-Jn&xiYS(rG1{h6VONd}Vt<2ucPM}YcJkibu>*+| z{nz2#dB7jB!SDy&MK|m_PUZ9NcQ`IC(@ie7bbhiZV@&DVD5MhlhL!r-G3D=e(0QFf z^4W`n&0qa-)hK`2kt%H8s~`+HzhkyEGZy*m(JE~IyCLKVg8$k?JA}4;7a{qU}(L!M@y88`YXt^Rl|si!Q`)B-i#*Pa(c-r zDy`qwCNLt6yLYs!=yUsc*4t3}C&^Y199pn~<^f1^+0HhJ(I;{Hf)pD|X|t{{~_NjZywg!eA&;&!odRZf1cnxFyA4w;Q1DrF%B!w`ibrN$5dH{|}u7@?mt!hnKlgaM_B2?kVmCLGYJV!{EfnMNGm zn-@cf)=U#Q{tMgd=yZ4W7nX27N7uh*?>zqQwAo)Y(M`_>j5A$oV|x2z3`8t*TfrDn zv8MNJ#sD2;gaH5)i2nl+5oP|(0L+yJ)7OU?){Dx-oOKik6bQ5inmK?1fdT;l>XXbY oK!HGkK#ve+4xm8%OF$&lEWwPrhdAsOY&Co#m=QuR4~RYdH?VRKRsaA1 literal 0 HcmV?d00001 diff --git a/assets/img/k-logo-dark.png b/assets/img/k-logo-dark.png new file mode 100644 index 0000000000000000000000000000000000000000..3982958bae0974175e18b929cb5ea5cdc8704b13 GIT binary patch literal 32908 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 NyLJf8RZ?WI1_11iV2uC( literal 0 HcmV?d00001 diff --git a/assets/img/rv-logo-dark.png b/assets/img/rv-logo-dark.png new file mode 100644 index 0000000000000000000000000000000000000000..50f488b7b3b3f80d1dfa55a17de91047a7603096 GIT binary patch literal 3624 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 e5FyO~fd2<6@yD|3^Bcne00004B` zcrAjWvZe|Sw{wr0CQ(~gS66{RHZsuJt3}e)**XG2p-@7CLQ=xQQaVaFC7u5q-V*?W z1Y`hL5TXnSU?3m{!fOK*0008xE4Cni1|k4LVQ>Tzg%;#5)QJKD5D*lAf-o2q%HIy> z&jBa~CZ?oq0vEUQKqv=E=tRZeL#miowPNji7w{y{;A<$fGqznK!E)3r#0EL23#Fh&p5XNs11BEGR!^KSO5FSC|$~sX<3Dfv{ zRjnu$lKleKGq@KmiPs%hUEHGmF8g<|YyV634feNd6c7R-{O5rfU_Y?NVUW55WrWLi zSNd;oN9j3D;fb6WvChj%HzlB5?DMzb9bnFwbNS}UBCB!w(76!lv+hK;rgkS$XWuFq zziGe`(L4SKbA;d(Z+WSsH#BkZF!zD6c>*cLqw$4#tD9UxWQe}A(et|oY{#L>#nNF~ zuV%S^=Wdt0ul6PFSHbMLyHC6})poLmt>h$4O4gi-lvY)CTd{=pogS4R1>&e5HnGM2 zGA#)k^kQg`WvGhnX-VTYv$kLC0XYD-oG}oIoeiR%(8bUmk2;LF%6{&h!my$K86@$6 zSXpq4z#yOC((hM#FxS&51C-o_*UT1D-|Cw7v+#k4Wppm##uZA*=4kdUe3WaMlie9` zan`}+-H6M4b+1p-fczjK{yj3R=i%DvM>a+7wo`WIB{mVs!OcT-BR@xdeN)tx8l0WC zF2f=aWr<&tDh_d7k4>4tZJ(P+&f*sF0F+YV`Q0&kWZ5q-*pE|7k`>S^{>H9Wi@W+B zd@NTfh@59K-mn(uM=J5V^0T=O0dC!ucb-TO=dski@MBp#>b!-32gibl$?7ZWqf=rCE*pj}SM`YqP4j?- z*uy#81eY$nSR8RaoJ(1H6>LS`NQ-NuN{r4ie@&{%lVp0Fqj%L15NOL+d%cWGFJ13z za!j4zl+$R!iFx|R``so2%19c z+|JZn?ueDkPnyciA4MK*TLI)V&~NhgU&uC8Adx2fRkGe|+`5WCb;Q$jpIN~1uzmFM UMDmx$wPIUqYthE^{k)Oi03Y0)IRF3v literal 0 HcmV?d00001 diff --git a/assets/js/index.js b/assets/js/index.js new file mode 100644 index 00000000000..670ddccf7bb --- /dev/null +++ b/assets/js/index.js @@ -0,0 +1,212 @@ +var e="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:"undefined"!=typeof window?window:"undefined"!=typeof global?global:{};var t={},n={},i=e.parcelRequire2b1d;null==i&&((i=function(e){if(e in t)return t[e].exports;if(e in n){var i=n[e];delete n[e];var o={id:e,exports:{}};return t[e]=o,i.call(o.exports,o,o.exports),o.exports}var s=new Error("Cannot find module '"+e+"'");throw s.code="MODULE_NOT_FOUND",s}).register=function(e,t){n[e]=t},e.parcelRequire2b1d=i),i.register("lJ4Q2",(function(e,t){ +/*! + * jQuery JavaScript Library v3.6.0 + * https://jquery.com/ + * + * Includes Sizzle.js + * https://sizzlejs.com/ + * + * Copyright OpenJS Foundation and other contributors + * Released under the MIT license + * https://jquery.org/license + * + * Date: 2021-03-02T17:08Z + */ +!function(t,n){"use strict";"object"==typeof e.exports?e.exports=t.document?n(t,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return n(e)}:n(t)}("undefined"!=typeof window?window:e.exports,(function(e,t){"use strict";var n=[],i=Object.getPrototypeOf,o=n.slice,s=n.flat?function(e){return n.flat.call(e)}:function(e){return n.concat.apply([],e)},r=n.push,a=n.indexOf,l={},c=l.toString,u=l.hasOwnProperty,d=u.toString,h=d.call(Object),f={},p=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType&&"function"!=typeof e.item},m=function(e){return null!=e&&e===e.window},g=e.document,v={type:!0,src:!0,nonce:!0,noModule:!0};function y(e,t,n){var i,o,s=(n=n||g).createElement("script");if(s.text=e,t)for(i in v)(o=t[i]||t.getAttribute&&t.getAttribute(i))&&s.setAttribute(i,o);n.head.appendChild(s).parentNode.removeChild(s)}function b(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?l[c.call(e)]||"object":typeof e}var _="3.6.0",w=function(e,t){return new w.fn.init(e,t)};function x(e){var t=!!e&&"length"in e&&e.length,n=b(e);return!p(e)&&!m(e)&&("array"===n||0===t||"number"==typeof t&&t>0&&t-1 in e)}w.fn=w.prototype={jquery:_,constructor:w,length:0,toArray:function(){return o.call(this)},get:function(e){return null==e?o.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=w.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return w.each(this,e)},map:function(e){return this.pushStack(w.map(this,(function(t,n){return e.call(t,n,t)})))},slice:function(){return this.pushStack(o.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(w.grep(this,(function(e,t){return(t+1)%2})))},odd:function(){return this.pushStack(w.grep(this,(function(e,t){return t%2})))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(n>=0&&n+~]|[\\x20\\t\\r\\n\\f])[\\x20\\t\\r\\n\\f]*"),U=new RegExp(H+"|>"),V=new RegExp(R),Q=new RegExp("^"+j+"$"),G={ID:new RegExp("^#("+j+")"),CLASS:new RegExp("^\\.("+j+")"),TAG:new RegExp("^("+j+"|[*])"),ATTR:new RegExp("^"+M),PSEUDO:new RegExp("^"+R),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\([\\x20\\t\\r\\n\\f]*(even|odd|(([+-]|)(\\d*)n|)[\\x20\\t\\r\\n\\f]*(?:([+-]|)[\\x20\\t\\r\\n\\f]*(\\d+)|))[\\x20\\t\\r\\n\\f]*\\)|)","i"),bool:new RegExp("^(?:"+P+")$","i"),needsContext:new RegExp("^[\\x20\\t\\r\\n\\f]*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\([\\x20\\t\\r\\n\\f]*((?:-\\d)?\\d*)[\\x20\\t\\r\\n\\f]*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,X=/^(?:input|select|textarea|button)$/i,K=/^h\d$/i,Z=/^[^{]+\{\s*\[native \w/,J=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}[\\x20\\t\\r\\n\\f]?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},ie=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,oe=function(e,t){return t?"\0"===e?"�":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},se=function(){h()},re=_e((function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()}),{dir:"parentNode",next:"legend"});try{L.apply(O=$.call(w.childNodes),w.childNodes),O[w.childNodes.length].nodeType}catch(e){L={apply:O.length?function(e,t){N.apply(e,$.call(t))}:function(e,t){for(var n=e.length,i=0;e[n++]=t[i++];);e.length=n-1}}}function ae(e,t,i,o){var s,a,c,u,d,p,v,y=t&&t.ownerDocument,w=t?t.nodeType:9;if(i=i||[],"string"!=typeof e||!e||1!==w&&9!==w&&11!==w)return i;if(!o&&(h(t),t=t||f,m)){if(11!==w&&(d=J.exec(e)))if(s=d[1]){if(9===w){if(!(c=t.getElementById(s)))return i;if(c.id===s)return i.push(c),i}else if(y&&(c=y.getElementById(s))&&b(t,c)&&c.id===s)return i.push(c),i}else{if(d[2])return L.apply(i,t.getElementsByTagName(e)),i;if((s=d[3])&&n.getElementsByClassName&&t.getElementsByClassName)return L.apply(i,t.getElementsByClassName(s)),i}if(n.qsa&&!k[e+" "]&&(!g||!g.test(e))&&(1!==w||"object"!==t.nodeName.toLowerCase())){if(v=e,y=t,1===w&&(U.test(e)||q.test(e))){for((y=ee.test(e)&&ve(t.parentNode)||t)===t&&n.scope||((u=t.getAttribute("id"))?u=u.replace(ie,oe):t.setAttribute("id",u=_)),a=(p=r(e)).length;a--;)p[a]=(u?"#"+u:":scope")+" "+be(p[a]);v=p.join(",")}try{return L.apply(i,y.querySelectorAll(v)),i}catch(t){k(e,!0)}finally{u===_&&t.removeAttribute("id")}}}return l(e.replace(B,"$1"),t,i,o)}function le(){var e=[];return function t(n,o){return e.push(n+" ")>i.cacheLength&&delete t[e.shift()],t[n+" "]=o}}function ce(e){return e[_]=!0,e}function ue(e){var t=f.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function de(e,t){for(var n=e.split("|"),o=n.length;o--;)i.attrHandle[n[o]]=t}function he(e,t){var n=t&&e,i=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(i)return i;if(n)for(;n=n.nextSibling;)if(n===t)return-1;return e?1:-1}function fe(e){return function(t){return"input"===t.nodeName.toLowerCase()&&t.type===e}}function pe(e){return function(t){var n=t.nodeName.toLowerCase();return("input"===n||"button"===n)&&t.type===e}}function me(e){return function(t){return"form"in t?t.parentNode&&!1===t.disabled?"label"in t?"label"in t.parentNode?t.parentNode.disabled===e:t.disabled===e:t.isDisabled===e||t.isDisabled!==!e&&re(t)===e:t.disabled===e:"label"in t&&t.disabled===e}}function ge(e){return ce((function(t){return t=+t,ce((function(n,i){for(var o,s=e([],n.length,t),r=s.length;r--;)n[o=s[r]]&&(n[o]=!(i[o]=n[o]))}))}))}function ve(e){return e&&void 0!==e.getElementsByTagName&&e}for(t in n=ae.support={},s=ae.isXML=function(e){var t=e&&e.namespaceURI,n=e&&(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},h=ae.setDocument=function(e){var t,o,r=e?e.ownerDocument||e:w;return r!=f&&9===r.nodeType&&r.documentElement?(p=(f=r).documentElement,m=!s(f),w!=f&&(o=f.defaultView)&&o.top!==o&&(o.addEventListener?o.addEventListener("unload",se,!1):o.attachEvent&&o.attachEvent("onunload",se)),n.scope=ue((function(e){return p.appendChild(e).appendChild(f.createElement("div")),void 0!==e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length})),n.attributes=ue((function(e){return e.className="i",!e.getAttribute("className")})),n.getElementsByTagName=ue((function(e){return e.appendChild(f.createComment("")),!e.getElementsByTagName("*").length})),n.getElementsByClassName=Z.test(f.getElementsByClassName),n.getById=ue((function(e){return p.appendChild(e).id=_,!f.getElementsByName||!f.getElementsByName(_).length})),n.getById?(i.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},i.find.ID=function(e,t){if(void 0!==t.getElementById&&m){var n=t.getElementById(e);return n?[n]:[]}}):(i.filter.ID=function(e){var t=e.replace(te,ne);return function(e){var n=void 0!==e.getAttributeNode&&e.getAttributeNode("id");return n&&n.value===t}},i.find.ID=function(e,t){if(void 0!==t.getElementById&&m){var n,i,o,s=t.getElementById(e);if(s){if((n=s.getAttributeNode("id"))&&n.value===e)return[s];for(o=t.getElementsByName(e),i=0;s=o[i++];)if((n=s.getAttributeNode("id"))&&n.value===e)return[s]}return[]}}),i.find.TAG=n.getElementsByTagName?function(e,t){return void 0!==t.getElementsByTagName?t.getElementsByTagName(e):n.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,i=[],o=0,s=t.getElementsByTagName(e);if("*"===e){for(;n=s[o++];)1===n.nodeType&&i.push(n);return i}return s},i.find.CLASS=n.getElementsByClassName&&function(e,t){if(void 0!==t.getElementsByClassName&&m)return t.getElementsByClassName(e)},v=[],g=[],(n.qsa=Z.test(f.querySelectorAll))&&(ue((function(e){var t;p.appendChild(e).innerHTML="",e.querySelectorAll("[msallowcapture^='']").length&&g.push("[*^$]=[\\x20\\t\\r\\n\\f]*(?:''|\"\")"),e.querySelectorAll("[selected]").length||g.push("\\[[\\x20\\t\\r\\n\\f]*(?:value|"+P+")"),e.querySelectorAll("[id~="+_+"-]").length||g.push("~="),(t=f.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||g.push("\\[[\\x20\\t\\r\\n\\f]*name[\\x20\\t\\r\\n\\f]*=[\\x20\\t\\r\\n\\f]*(?:''|\"\")"),e.querySelectorAll(":checked").length||g.push(":checked"),e.querySelectorAll("a#"+_+"+*").length||g.push(".#.+[+~]"),e.querySelectorAll("\\\f"),g.push("[\\r\\n\\f]")})),ue((function(e){e.innerHTML="";var t=f.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&g.push("name[\\x20\\t\\r\\n\\f]*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&g.push(":enabled",":disabled"),p.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&g.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),g.push(",.*:")}))),(n.matchesSelector=Z.test(y=p.matches||p.webkitMatchesSelector||p.mozMatchesSelector||p.oMatchesSelector||p.msMatchesSelector))&&ue((function(e){n.disconnectedMatch=y.call(e,"*"),y.call(e,"[s!='']:x"),v.push("!=",R)})),g=g.length&&new RegExp(g.join("|")),v=v.length&&new RegExp(v.join("|")),t=Z.test(p.compareDocumentPosition),b=t||Z.test(p.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,i=t&&t.parentNode;return e===i||!(!i||1!==i.nodeType||!(n.contains?n.contains(i):e.compareDocumentPosition&&16&e.compareDocumentPosition(i)))}:function(e,t){if(t)for(;t=t.parentNode;)if(t===e)return!0;return!1},I=t?function(e,t){if(e===t)return d=!0,0;var i=!e.compareDocumentPosition-!t.compareDocumentPosition;return i||(1&(i=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!n.sortDetached&&t.compareDocumentPosition(e)===i?e==f||e.ownerDocument==w&&b(w,e)?-1:t==f||t.ownerDocument==w&&b(w,t)?1:u?z(u,e)-z(u,t):0:4&i?-1:1)}:function(e,t){if(e===t)return d=!0,0;var n,i=0,o=e.parentNode,s=t.parentNode,r=[e],a=[t];if(!o||!s)return e==f?-1:t==f?1:o?-1:s?1:u?z(u,e)-z(u,t):0;if(o===s)return he(e,t);for(n=e;n=n.parentNode;)r.unshift(n);for(n=t;n=n.parentNode;)a.unshift(n);for(;r[i]===a[i];)i++;return i?he(r[i],a[i]):r[i]==w?-1:a[i]==w?1:0},f):f},ae.matches=function(e,t){return ae(e,null,null,t)},ae.matchesSelector=function(e,t){if(h(e),n.matchesSelector&&m&&!k[t+" "]&&(!v||!v.test(t))&&(!g||!g.test(t)))try{var i=y.call(e,t);if(i||n.disconnectedMatch||e.document&&11!==e.document.nodeType)return i}catch(e){k(t,!0)}return ae(t,f,null,[e]).length>0},ae.contains=function(e,t){return(e.ownerDocument||e)!=f&&h(e),b(e,t)},ae.attr=function(e,t){(e.ownerDocument||e)!=f&&h(e);var o=i.attrHandle[t.toLowerCase()],s=o&&A.call(i.attrHandle,t.toLowerCase())?o(e,t,!m):void 0;return void 0!==s?s:n.attributes||!m?e.getAttribute(t):(s=e.getAttributeNode(t))&&s.specified?s.value:null},ae.escape=function(e){return(e+"").replace(ie,oe)},ae.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},ae.uniqueSort=function(e){var t,i=[],o=0,s=0;if(d=!n.detectDuplicates,u=!n.sortStable&&e.slice(0),e.sort(I),d){for(;t=e[s++];)t===e[s]&&(o=i.push(s));for(;o--;)e.splice(i[o],1)}return u=null,e},o=ae.getText=function(e){var t,n="",i=0,s=e.nodeType;if(s){if(1===s||9===s||11===s){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===s||4===s)return e.nodeValue}else for(;t=e[i++];)n+=o(t);return n},i=ae.selectors={cacheLength:50,createPseudo:ce,match:G,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||ae.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&ae.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&V.test(n)&&(t=r(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=C[e+" "];return t||(t=new RegExp("(^|[\\x20\\t\\r\\n\\f])"+e+"("+H+"|$)"),C(e,(function(e){return t.test("string"==typeof e.className&&e.className||void 0!==e.getAttribute&&e.getAttribute("class")||"")})))},ATTR:function(e,t,n){return function(i){var o=ae.attr(i,e);return null==o?"!="===t:!t||(o+="","="===t?o===n:"!="===t?o!==n:"^="===t?n&&0===o.indexOf(n):"*="===t?n&&o.indexOf(n)>-1:"$="===t?n&&o.slice(-n.length)===n:"~="===t?(" "+o.replace(F," ")+" ").indexOf(n)>-1:"|="===t&&(o===n||o.slice(0,n.length+1)===n+"-"))}},CHILD:function(e,t,n,i,o){var s="nth"!==e.slice(0,3),r="last"!==e.slice(-4),a="of-type"===t;return 1===i&&0===o?function(e){return!!e.parentNode}:function(t,n,l){var c,u,d,h,f,p,m=s!==r?"nextSibling":"previousSibling",g=t.parentNode,v=a&&t.nodeName.toLowerCase(),y=!l&&!a,b=!1;if(g){if(s){for(;m;){for(h=t;h=h[m];)if(a?h.nodeName.toLowerCase()===v:1===h.nodeType)return!1;p=m="only"===e&&!p&&"nextSibling"}return!0}if(p=[r?g.firstChild:g.lastChild],r&&y){for(b=(f=(c=(u=(d=(h=g)[_]||(h[_]={}))[h.uniqueID]||(d[h.uniqueID]={}))[e]||[])[0]===x&&c[1])&&c[2],h=f&&g.childNodes[f];h=++f&&h&&h[m]||(b=f=0)||p.pop();)if(1===h.nodeType&&++b&&h===t){u[e]=[x,f,b];break}}else if(y&&(b=f=(c=(u=(d=(h=t)[_]||(h[_]={}))[h.uniqueID]||(d[h.uniqueID]={}))[e]||[])[0]===x&&c[1]),!1===b)for(;(h=++f&&h&&h[m]||(b=f=0)||p.pop())&&((a?h.nodeName.toLowerCase()!==v:1!==h.nodeType)||!++b||(y&&((u=(d=h[_]||(h[_]={}))[h.uniqueID]||(d[h.uniqueID]={}))[e]=[x,b]),h!==t)););return(b-=o)===i||b%i==0&&b/i>=0}}},PSEUDO:function(e,t){var n,o=i.pseudos[e]||i.setFilters[e.toLowerCase()]||ae.error("unsupported pseudo: "+e);return o[_]?o(t):o.length>1?(n=[e,e,"",t],i.setFilters.hasOwnProperty(e.toLowerCase())?ce((function(e,n){for(var i,s=o(e,t),r=s.length;r--;)e[i=z(e,s[r])]=!(n[i]=s[r])})):function(e){return o(e,0,n)}):o}},pseudos:{not:ce((function(e){var t=[],n=[],i=a(e.replace(B,"$1"));return i[_]?ce((function(e,t,n,o){for(var s,r=i(e,null,o,[]),a=e.length;a--;)(s=r[a])&&(e[a]=!(t[a]=s))})):function(e,o,s){return t[0]=e,i(t,null,s,n),t[0]=null,!n.pop()}})),has:ce((function(e){return function(t){return ae(e,t).length>0}})),contains:ce((function(e){return e=e.replace(te,ne),function(t){return(t.textContent||o(t)).indexOf(e)>-1}})),lang:ce((function(e){return Q.test(e||"")||ae.error("unsupported lang: "+e),e=e.replace(te,ne).toLowerCase(),function(t){var n;do{if(n=m?t.lang:t.getAttribute("xml:lang")||t.getAttribute("lang"))return(n=n.toLowerCase())===e||0===n.indexOf(e+"-")}while((t=t.parentNode)&&1===t.nodeType);return!1}})),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===p},focus:function(e){return e===f.activeElement&&(!f.hasFocus||f.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:me(!1),disabled:me(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!i.pseudos.empty(e)},header:function(e){return K.test(e.nodeName)},input:function(e){return X.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:ge((function(){return[0]})),last:ge((function(e,t){return[t-1]})),eq:ge((function(e,t,n){return[n<0?n+t:n]})),even:ge((function(e,t){for(var n=0;nt?t:n;--i>=0;)e.push(i);return e})),gt:ge((function(e,t,n){for(var i=n<0?n+t:n;++i1?function(t,n,i){for(var o=e.length;o--;)if(!e[o](t,n,i))return!1;return!0}:e[0]}function xe(e,t,n,i,o){for(var s,r=[],a=0,l=e.length,c=null!=t;a-1&&(s[c]=!(r[c]=d))}}else v=xe(v===r?v.splice(p,v.length):v),o?o(null,r,v,l):L.apply(r,v)}))}function Ce(e){for(var t,n,o,s=e.length,r=i.relative[e[0].type],a=r||i.relative[" "],l=r?1:0,u=_e((function(e){return e===t}),a,!0),d=_e((function(e){return z(t,e)>-1}),a,!0),h=[function(e,n,i){var o=!r&&(i||n!==c)||((t=n).nodeType?u(e,n,i):d(e,n,i));return t=null,o}];l1&&we(h),l>1&&be(e.slice(0,l-1).concat({value:" "===e[l-2].type?"*":""})).replace(B,"$1"),n,l0,o=e.length>0,s=function(s,r,a,l,u){var d,p,g,v=0,y="0",b=s&&[],_=[],w=c,E=s||o&&i.find.TAG("*",u),C=x+=null==w?1:Math.random()||.1,S=E.length;for(u&&(c=r==f||r||u);y!==S&&null!=(d=E[y]);y++){if(o&&d){for(p=0,r||d.ownerDocument==f||(h(d),a=!m);g=e[p++];)if(g(d,r||f,a)){l.push(d);break}u&&(x=C)}n&&((d=!g&&d)&&v--,s&&b.push(d))}if(v+=y,n&&y!==v){for(p=0;g=t[p++];)g(b,_,r,a);if(s){if(v>0)for(;y--;)b[y]||_[y]||(_[y]=D.call(l));_=xe(_)}L.apply(l,_),u&&!s&&_.length>0&&v+t.length>1&&ae.uniqueSort(l)}return u&&(x=C,c=w),b};return n?ce(s):s}(s,o)),a.selector=e}return a},l=ae.select=function(e,t,n,o){var s,l,c,u,d,h="function"==typeof e&&e,f=!o&&r(e=h.selector||e);if(n=n||[],1===f.length){if((l=f[0]=f[0].slice(0)).length>2&&"ID"===(c=l[0]).type&&9===t.nodeType&&m&&i.relative[l[1].type]){if(!(t=(i.find.ID(c.matches[0].replace(te,ne),t)||[])[0]))return n;h&&(t=t.parentNode),e=e.slice(l.shift().value.length)}for(s=G.needsContext.test(e)?0:l.length;s--&&(c=l[s],!i.relative[u=c.type]);)if((d=i.find[u])&&(o=d(c.matches[0].replace(te,ne),ee.test(l[0].type)&&ve(t.parentNode)||t))){if(l.splice(s,1),!(e=o.length&&be(l)))return L.apply(n,o),n;break}}return(h||a(e,f))(o,t,!m,n,!t||ee.test(e)&&ve(t.parentNode)||t),n},n.sortStable=_.split("").sort(I).join("")===_,n.detectDuplicates=!!d,h(),n.sortDetached=ue((function(e){return 1&e.compareDocumentPosition(f.createElement("fieldset"))})),ue((function(e){return e.innerHTML="","#"===e.firstChild.getAttribute("href")}))||de("type|href|height|width",(function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)})),n.attributes&&ue((function(e){return e.innerHTML="",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")}))||de("value",(function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue})),ue((function(e){return null==e.getAttribute("disabled")}))||de(P,(function(e,t,n){var i;if(!n)return!0===e[t]?t.toLowerCase():(i=e.getAttributeNode(t))&&i.specified?i.value:null})),ae}(e);w.find=E,w.expr=E.selectors,w.expr[":"]=w.expr.pseudos,w.uniqueSort=w.unique=E.uniqueSort,w.text=E.getText,w.isXMLDoc=E.isXML,w.contains=E.contains,w.escapeSelector=E.escape;var C=function(e,t,n){for(var i=[],o=void 0!==n;(e=e[t])&&9!==e.nodeType;)if(1===e.nodeType){if(o&&w(e).is(n))break;i.push(e)}return i},S=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},T=w.expr.match.needsContext;function k(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var I=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function A(e,t,n){return p(t)?w.grep(e,(function(e,i){return!!t.call(e,i,e)!==n})):t.nodeType?w.grep(e,(function(e){return e===t!==n})):"string"!=typeof t?w.grep(e,(function(e){return a.call(t,e)>-1!==n})):w.filter(t,e,n)}w.filter=function(e,t,n){var i=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===i.nodeType?w.find.matchesSelector(i,e)?[i]:[]:w.find.matches(e,w.grep(t,(function(e){return 1===e.nodeType})))},w.fn.extend({find:function(e){var t,n,i=this.length,o=this;if("string"!=typeof e)return this.pushStack(w(e).filter((function(){for(t=0;t1?w.uniqueSort(n):n},filter:function(e){return this.pushStack(A(this,e||[],!1))},not:function(e){return this.pushStack(A(this,e||[],!0))},is:function(e){return!!A(this,"string"==typeof e&&T.test(e)?w(e):e||[],!1).length}});var O,D=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(w.fn.init=function(e,t,n){var i,o;if(!e)return this;if(n=n||O,"string"==typeof e){if(!(i="<"===e[0]&&">"===e[e.length-1]&&e.length>=3?[null,e,null]:D.exec(e))||!i[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(i[1]){if(t=t instanceof w?t[0]:t,w.merge(this,w.parseHTML(i[1],t&&t.nodeType?t.ownerDocument||t:g,!0)),I.test(i[1])&&w.isPlainObject(t))for(i in t)p(this[i])?this[i](t[i]):this.attr(i,t[i]);return this}return(o=g.getElementById(i[2]))&&(this[0]=o,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):p(e)?void 0!==n.ready?n.ready(e):e(w):w.makeArray(e,this)}).prototype=w.fn,O=w(g);var N=/^(?:parents|prev(?:Until|All))/,L={children:!0,contents:!0,next:!0,prev:!0};function $(e,t){for(;(e=e[t])&&1!==e.nodeType;);return e}w.fn.extend({has:function(e){var t=w(e,this),n=t.length;return this.filter((function(){for(var e=0;e-1:1===n.nodeType&&w.find.matchesSelector(n,e))){s.push(n);break}return this.pushStack(s.length>1?w.uniqueSort(s):s)},index:function(e){return e?"string"==typeof e?a.call(w(e),this[0]):a.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(w.uniqueSort(w.merge(this.get(),w(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),w.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return C(e,"parentNode")},parentsUntil:function(e,t,n){return C(e,"parentNode",n)},next:function(e){return $(e,"nextSibling")},prev:function(e){return $(e,"previousSibling")},nextAll:function(e){return C(e,"nextSibling")},prevAll:function(e){return C(e,"previousSibling")},nextUntil:function(e,t,n){return C(e,"nextSibling",n)},prevUntil:function(e,t,n){return C(e,"previousSibling",n)},siblings:function(e){return S((e.parentNode||{}).firstChild,e)},children:function(e){return S(e.firstChild)},contents:function(e){return null!=e.contentDocument&&i(e.contentDocument)?e.contentDocument:(k(e,"template")&&(e=e.content||e),w.merge([],e.childNodes))}},(function(e,t){w.fn[e]=function(n,i){var o=w.map(this,t,n);return"Until"!==e.slice(-5)&&(i=n),i&&"string"==typeof i&&(o=w.filter(i,o)),this.length>1&&(L[e]||w.uniqueSort(o),N.test(e)&&o.reverse()),this.pushStack(o)}}));var z=/[^\x20\t\r\n\f]+/g;function P(e){return e}function H(e){throw e}function j(e,t,n,i){var o;try{e&&p(o=e.promise)?o.call(e).done(t).fail(n):e&&p(o=e.then)?o.call(e,t,n):t.apply(void 0,[e].slice(i))}catch(e){n.apply(void 0,[e])}}w.Callbacks=function(e){e="string"==typeof e?function(e){var t={};return w.each(e.match(z)||[],(function(e,n){t[n]=!0})),t}(e):w.extend({},e);var t,n,i,o,s=[],r=[],a=-1,l=function(){for(o=o||e.once,i=t=!0;r.length;a=-1)for(n=r.shift();++a-1;)s.splice(n,1),n<=a&&a--})),this},has:function(e){return e?w.inArray(e,s)>-1:s.length>0},empty:function(){return s&&(s=[]),this},disable:function(){return o=r=[],s=n="",this},disabled:function(){return!s},lock:function(){return o=r=[],n||t||(s=n=""),this},locked:function(){return!!o},fireWith:function(e,n){return o||(n=[e,(n=n||[]).slice?n.slice():n],r.push(n),t||l()),this},fire:function(){return c.fireWith(this,arguments),this},fired:function(){return!!i}};return c},w.extend({Deferred:function(t){var n=[["notify","progress",w.Callbacks("memory"),w.Callbacks("memory"),2],["resolve","done",w.Callbacks("once memory"),w.Callbacks("once memory"),0,"resolved"],["reject","fail",w.Callbacks("once memory"),w.Callbacks("once memory"),1,"rejected"]],i="pending",o={state:function(){return i},always:function(){return s.done(arguments).fail(arguments),this},catch:function(e){return o.then(null,e)},pipe:function(){var e=arguments;return w.Deferred((function(t){w.each(n,(function(n,i){var o=p(e[i[4]])&&e[i[4]];s[i[1]]((function(){var e=o&&o.apply(this,arguments);e&&p(e.promise)?e.promise().progress(t.notify).done(t.resolve).fail(t.reject):t[i[0]+"With"](this,o?[e]:arguments)}))})),e=null})).promise()},then:function(t,i,o){var s=0;function r(t,n,i,o){return function(){var a=this,l=arguments,c=function(){var e,c;if(!(t=s&&(i!==H&&(a=void 0,l=[e]),n.rejectWith(a,l))}};t?u():(w.Deferred.getStackHook&&(u.stackTrace=w.Deferred.getStackHook()),e.setTimeout(u))}}return w.Deferred((function(e){n[0][3].add(r(0,e,p(o)?o:P,e.notifyWith)),n[1][3].add(r(0,e,p(t)?t:P)),n[2][3].add(r(0,e,p(i)?i:H))})).promise()},promise:function(e){return null!=e?w.extend(e,o):o}},s={};return w.each(n,(function(e,t){var r=t[2],a=t[5];o[t[1]]=r.add,a&&r.add((function(){i=a}),n[3-e][2].disable,n[3-e][3].disable,n[0][2].lock,n[0][3].lock),r.add(t[3].fire),s[t[0]]=function(){return s[t[0]+"With"](this===s?void 0:this,arguments),this},s[t[0]+"With"]=r.fireWith})),o.promise(s),t&&t.call(s,s),s},when:function(e){var t=arguments.length,n=t,i=Array(n),s=o.call(arguments),r=w.Deferred(),a=function(e){return function(n){i[e]=this,s[e]=arguments.length>1?o.call(arguments):n,--t||r.resolveWith(i,s)}};if(t<=1&&(j(e,r.done(a(n)).resolve,r.reject,!t),"pending"===r.state()||p(s[n]&&s[n].then)))return r.then();for(;n--;)j(s[n],a(n),r.reject);return r.promise()}});var M=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;w.Deferred.exceptionHook=function(t,n){e.console&&e.console.warn&&t&&M.test(t.name)&&e.console.warn("jQuery.Deferred exception: "+t.message,t.stack,n)},w.readyException=function(t){e.setTimeout((function(){throw t}))};var R=w.Deferred();function F(){g.removeEventListener("DOMContentLoaded",F),e.removeEventListener("load",F),w.ready()}w.fn.ready=function(e){return R.then(e).catch((function(e){w.readyException(e)})),this},w.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--w.readyWait:w.isReady)||(w.isReady=!0,!0!==e&&--w.readyWait>0||R.resolveWith(g,[w]))}}),w.ready.then=R.then,"complete"===g.readyState||"loading"!==g.readyState&&!g.documentElement.doScroll?e.setTimeout(w.ready):(g.addEventListener("DOMContentLoaded",F),e.addEventListener("load",F));var B=function(e,t,n,i,o,s,r){var a=0,l=e.length,c=null==n;if("object"===b(n))for(a in o=!0,n)B(e,t,a,n[a],!0,s,r);else if(void 0!==i&&(o=!0,p(i)||(r=!0),c&&(r?(t.call(e,i),t=null):(c=t,t=function(e,t,n){return c.call(w(e),n)})),t))for(;a1,null,!0)},removeData:function(e){return this.each((function(){X.remove(this,e)}))}}),w.extend({queue:function(e,t,n){var i;if(e)return t=(t||"fx")+"queue",i=Y.get(e,t),n&&(!i||Array.isArray(n)?i=Y.access(e,t,w.makeArray(n)):i.push(n)),i||[]},dequeue:function(e,t){t=t||"fx";var n=w.queue(e,t),i=n.length,o=n.shift(),s=w._queueHooks(e,t);"inprogress"===o&&(o=n.shift(),i--),o&&("fx"===t&&n.unshift("inprogress"),delete s.stop,o.call(e,(function(){w.dequeue(e,t)}),s)),!i&&s&&s.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return Y.get(e,n)||Y.access(e,n,{empty:w.Callbacks("once memory").add((function(){Y.remove(e,[t+"queue",n])}))})}}),w.fn.extend({queue:function(e,t){var n=2;return"string"!=typeof e&&(t=e,e="fx",n--),arguments.length\x20\t\r\n\f]*)/i,me=/^$|^module$|\/(?:java|ecma)script/i;de=g.createDocumentFragment().appendChild(g.createElement("div")),(he=g.createElement("input")).setAttribute("type","radio"),he.setAttribute("checked","checked"),he.setAttribute("name","t"),de.appendChild(he),f.checkClone=de.cloneNode(!0).cloneNode(!0).lastChild.checked,de.innerHTML="",f.noCloneChecked=!!de.cloneNode(!0).lastChild.defaultValue,de.innerHTML="",f.option=!!de.lastChild;var ge={thead:[1,"","
"],col:[2,"","
"],tr:[2,"","
"],td:[3,"","
"],_default:[0,"",""]};function ve(e,t){var n;return n=void 0!==e.getElementsByTagName?e.getElementsByTagName(t||"*"):void 0!==e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&k(e,t)?w.merge([e],n):n}function ye(e,t){for(var n=0,i=e.length;n",""]);var be=/<|&#?\w+;/;function _e(e,t,n,i,o){for(var s,r,a,l,c,u,d=t.createDocumentFragment(),h=[],f=0,p=e.length;f-1)o&&o.push(s);else if(c=oe(s),r=ve(d.appendChild(s),"script"),c&&ye(r),n)for(u=0;s=r[u++];)me.test(s.type||"")&&n.push(s);return d}var we=/^([^.]*)(?:\.(.+)|)/;function xe(){return!0}function Ee(){return!1}function Ce(e,t){return e===function(){try{return g.activeElement}catch(e){}}()==("focus"===t)}function Se(e,t,n,i,o,s){var r,a;if("object"==typeof t){for(a in"string"!=typeof n&&(i=i||n,n=void 0),t)Se(e,a,n,i,t[a],s);return e}if(null==i&&null==o?(o=n,i=n=void 0):null==o&&("string"==typeof n?(o=i,i=void 0):(o=i,i=n,n=void 0)),!1===o)o=Ee;else if(!o)return e;return 1===s&&(r=o,o=function(e){return w().off(e),r.apply(this,arguments)},o.guid=r.guid||(r.guid=w.guid++)),e.each((function(){w.event.add(this,t,o,i,n)}))}function Te(e,t,n){n?(Y.set(e,t,!1),w.event.add(e,t,{namespace:!1,handler:function(e){var i,s,r=Y.get(this,t);if(1&e.isTrigger&&this[t]){if(r.length)(w.event.special[t]||{}).delegateType&&e.stopPropagation();else if(r=o.call(arguments),Y.set(this,t,r),i=n(this,t),this[t](),r!==(s=Y.get(this,t))||i?Y.set(this,t,!1):s={},r!==s)return e.stopImmediatePropagation(),e.preventDefault(),s&&s.value}else r.length&&(Y.set(this,t,{value:w.event.trigger(w.extend(r[0],w.Event.prototype),r.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Y.get(e,t)&&w.event.add(e,t,xe)}w.event={global:{},add:function(e,t,n,i,o){var s,r,a,l,c,u,d,h,f,p,m,g=Y.get(e);if(Q(e))for(n.handler&&(n=(s=n).handler,o=s.selector),o&&w.find.matchesSelector(ie,o),n.guid||(n.guid=w.guid++),(l=g.events)||(l=g.events=Object.create(null)),(r=g.handle)||(r=g.handle=function(t){return void 0!==w&&w.event.triggered!==t.type?w.event.dispatch.apply(e,arguments):void 0}),c=(t=(t||"").match(z)||[""]).length;c--;)f=m=(a=we.exec(t[c])||[])[1],p=(a[2]||"").split(".").sort(),f&&(d=w.event.special[f]||{},f=(o?d.delegateType:d.bindType)||f,d=w.event.special[f]||{},u=w.extend({type:f,origType:m,data:i,handler:n,guid:n.guid,selector:o,needsContext:o&&w.expr.match.needsContext.test(o),namespace:p.join(".")},s),(h=l[f])||((h=l[f]=[]).delegateCount=0,d.setup&&!1!==d.setup.call(e,i,p,r)||e.addEventListener&&e.addEventListener(f,r)),d.add&&(d.add.call(e,u),u.handler.guid||(u.handler.guid=n.guid)),o?h.splice(h.delegateCount++,0,u):h.push(u),w.event.global[f]=!0)},remove:function(e,t,n,i,o){var s,r,a,l,c,u,d,h,f,p,m,g=Y.hasData(e)&&Y.get(e);if(g&&(l=g.events)){for(c=(t=(t||"").match(z)||[""]).length;c--;)if(f=m=(a=we.exec(t[c])||[])[1],p=(a[2]||"").split(".").sort(),f){for(d=w.event.special[f]||{},h=l[f=(i?d.delegateType:d.bindType)||f]||[],a=a[2]&&new RegExp("(^|\\.)"+p.join("\\.(?:.*\\.|)")+"(\\.|$)"),r=s=h.length;s--;)u=h[s],!o&&m!==u.origType||n&&n.guid!==u.guid||a&&!a.test(u.namespace)||i&&i!==u.selector&&("**"!==i||!u.selector)||(h.splice(s,1),u.selector&&h.delegateCount--,d.remove&&d.remove.call(e,u));r&&!h.length&&(d.teardown&&!1!==d.teardown.call(e,p,g.handle)||w.removeEvent(e,f,g.handle),delete l[f])}else for(f in l)w.event.remove(e,f+t[c],n,i,!0);w.isEmptyObject(l)&&Y.remove(e,"handle events")}},dispatch:function(e){var t,n,i,o,s,r,a=new Array(arguments.length),l=w.event.fix(e),c=(Y.get(this,"events")||Object.create(null))[l.type]||[],u=w.event.special[l.type]||{};for(a[0]=l,t=1;t=1))for(;c!==this;c=c.parentNode||this)if(1===c.nodeType&&("click"!==e.type||!0!==c.disabled)){for(s=[],r={},n=0;n-1:w.find(o,this,null,[c]).length),r[o]&&s.push(i);s.length&&a.push({elem:c,handlers:s})}return c=this,l\s*$/g;function Oe(e,t){return k(e,"table")&&k(11!==t.nodeType?t:t.firstChild,"tr")&&w(e).children("tbody")[0]||e}function De(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function Ne(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Le(e,t){var n,i,o,s,r,a;if(1===t.nodeType){if(Y.hasData(e)&&(a=Y.get(e).events))for(o in Y.remove(t,"handle events"),a)for(n=0,i=a[o].length;n1&&"string"==typeof g&&!f.checkClone&&Ie.test(g))return e.each((function(o){var s=e.eq(o);v&&(t[0]=g.call(this,o,s.html())),ze(s,t,n,i)}));if(h&&(r=(o=_e(t,e[0].ownerDocument,!1,e,i)).firstChild,1===o.childNodes.length&&(o=r),r||i)){for(l=(a=w.map(ve(o,"script"),De)).length;d0&&ye(r,!l&&ve(e,"script")),a},cleanData:function(e){for(var t,n,i,o=w.event.special,s=0;void 0!==(n=e[s]);s++)if(Q(n)){if(t=n[Y.expando]){if(t.events)for(i in t.events)o[i]?w.event.remove(n,i):w.removeEvent(n,i,t.handle);n[Y.expando]=void 0}n[X.expando]&&(n[X.expando]=void 0)}}}),w.fn.extend({detach:function(e){return Pe(this,e,!0)},remove:function(e){return Pe(this,e)},text:function(e){return B(this,(function(e){return void 0===e?w.text(this):this.empty().each((function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)}))}),null,e,arguments.length)},append:function(){return ze(this,arguments,(function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||Oe(this,e).appendChild(e)}))},prepend:function(){return ze(this,arguments,(function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=Oe(this,e);t.insertBefore(e,t.firstChild)}}))},before:function(){return ze(this,arguments,(function(e){this.parentNode&&this.parentNode.insertBefore(e,this)}))},after:function(){return ze(this,arguments,(function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)}))},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(w.cleanData(ve(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map((function(){return w.clone(this,e,t)}))},html:function(e){return B(this,(function(e){var t=this[0]||{},n=0,i=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!ke.test(e)&&!ge[(pe.exec(e)||["",""])[1].toLowerCase()]){e=w.htmlPrefilter(e);try{for(;n=0&&(l+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-s-l-a-.5))||0),l}function Je(e,t,n){var i=je(e),o=(!f.boxSizingReliable()||n)&&"border-box"===w.css(e,"boxSizing",!1,i),s=o,r=Fe(e,t,i),a="offset"+t[0].toUpperCase()+t.slice(1);if(He.test(r)){if(!n)return r;r="auto"}return(!f.boxSizingReliable()&&o||!f.reliableTrDimensions()&&k(e,"tr")||"auto"===r||!parseFloat(r)&&"inline"===w.css(e,"display",!1,i))&&e.getClientRects().length&&(o="border-box"===w.css(e,"boxSizing",!1,i),(s=a in e)&&(r=e[a])),(r=parseFloat(r)||0)+Ze(e,t,n||(o?"border":"content"),s,i,r)+"px"}function et(e,t,n,i,o){return new et.prototype.init(e,t,n,i,o)}w.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=Fe(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,gridArea:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnStart:!0,gridRow:!0,gridRowEnd:!0,gridRowStart:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,i){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var o,s,r,a=V(t),l=Ge.test(t),c=e.style;if(l||(t=Ve(a)),r=w.cssHooks[t]||w.cssHooks[a],void 0===n)return r&&"get"in r&&void 0!==(o=r.get(e,!1,i))?o:c[t];"string"===(s=typeof n)&&(o=te.exec(n))&&o[1]&&(n=ae(e,t,o),s="number"),null!=n&&n==n&&("number"!==s||l||(n+=o&&o[3]||(w.cssNumber[a]?"":"px")),f.clearCloneStyle||""!==n||0!==t.indexOf("background")||(c[t]="inherit"),r&&"set"in r&&void 0===(n=r.set(e,n,i))||(l?c.setProperty(t,n):c[t]=n))}},css:function(e,t,n,i){var o,s,r,a=V(t);return Ge.test(t)||(t=Ve(a)),(r=w.cssHooks[t]||w.cssHooks[a])&&"get"in r&&(o=r.get(e,!0,n)),void 0===o&&(o=Fe(e,t,i)),"normal"===o&&t in Xe&&(o=Xe[t]),""===n||n?(s=parseFloat(o),!0===n||isFinite(s)?s||0:o):o}}),w.each(["height","width"],(function(e,t){w.cssHooks[t]={get:function(e,n,i){if(n)return!Qe.test(w.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?Je(e,t,i):Me(e,Ye,(function(){return Je(e,t,i)}))},set:function(e,n,i){var o,s=je(e),r=!f.scrollboxSize()&&"absolute"===s.position,a=(r||i)&&"border-box"===w.css(e,"boxSizing",!1,s),l=i?Ze(e,t,i,a,s):0;return a&&r&&(l-=Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-parseFloat(s[t])-Ze(e,t,"border",!1,s)-.5)),l&&(o=te.exec(n))&&"px"!==(o[3]||"px")&&(e.style[t]=n,n=w.css(e,t)),Ke(0,n,l)}}})),w.cssHooks.marginLeft=Be(f.reliableMarginLeft,(function(e,t){if(t)return(parseFloat(Fe(e,"marginLeft"))||e.getBoundingClientRect().left-Me(e,{marginLeft:0},(function(){return e.getBoundingClientRect().left})))+"px"})),w.each({margin:"",padding:"",border:"Width"},(function(e,t){w.cssHooks[e+t]={expand:function(n){for(var i=0,o={},s="string"==typeof n?n.split(" "):[n];i<4;i++)o[e+ne[i]+t]=s[i]||s[i-2]||s[0];return o}},"margin"!==e&&(w.cssHooks[e+t].set=Ke)})),w.fn.extend({css:function(e,t){return B(this,(function(e,t,n){var i,o,s={},r=0;if(Array.isArray(t)){for(i=je(e),o=t.length;r1)}}),w.Tween=et,et.prototype={constructor:et,init:function(e,t,n,i,o,s){this.elem=e,this.prop=n,this.easing=o||w.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=i,this.unit=s||(w.cssNumber[n]?"":"px")},cur:function(){var e=et.propHooks[this.prop];return e&&e.get?e.get(this):et.propHooks._default.get(this)},run:function(e){var t,n=et.propHooks[this.prop];return this.options.duration?this.pos=t=w.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):et.propHooks._default.set(this),this}},et.prototype.init.prototype=et.prototype,et.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=w.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){w.fx.step[e.prop]?w.fx.step[e.prop](e):1!==e.elem.nodeType||!w.cssHooks[e.prop]&&null==e.elem.style[Ve(e.prop)]?e.elem[e.prop]=e.now:w.style(e.elem,e.prop,e.now+e.unit)}}},et.propHooks.scrollTop=et.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},w.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},w.fx=et.prototype.init,w.fx.step={};var tt,nt,it=/^(?:toggle|show|hide)$/,ot=/queueHooks$/;function st(){nt&&(!1===g.hidden&&e.requestAnimationFrame?e.requestAnimationFrame(st):e.setTimeout(st,w.fx.interval),w.fx.tick())}function rt(){return e.setTimeout((function(){tt=void 0})),tt=Date.now()}function at(e,t){var n,i=0,o={height:e};for(t=t?1:0;i<4;i+=2-t)o["margin"+(n=ne[i])]=o["padding"+n]=e;return t&&(o.opacity=o.width=e),o}function lt(e,t,n){for(var i,o=(ct.tweeners[t]||[]).concat(ct.tweeners["*"]),s=0,r=o.length;s1)},removeAttr:function(e){return this.each((function(){w.removeAttr(this,e)}))}}),w.extend({attr:function(e,t,n){var i,o,s=e.nodeType;if(3!==s&&8!==s&&2!==s)return void 0===e.getAttribute?w.prop(e,t,n):(1===s&&w.isXMLDoc(e)||(o=w.attrHooks[t.toLowerCase()]||(w.expr.match.bool.test(t)?ut:void 0)),void 0!==n?null===n?void w.removeAttr(e,t):o&&"set"in o&&void 0!==(i=o.set(e,n,t))?i:(e.setAttribute(t,n+""),n):o&&"get"in o&&null!==(i=o.get(e,t))?i:null==(i=w.find.attr(e,t))?void 0:i)},attrHooks:{type:{set:function(e,t){if(!f.radioValue&&"radio"===t&&k(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,i=0,o=t&&t.match(z);if(o&&1===e.nodeType)for(;n=o[i++];)e.removeAttribute(n)}}),ut={set:function(e,t,n){return!1===t?w.removeAttr(e,n):e.setAttribute(n,n),n}},w.each(w.expr.match.bool.source.match(/\w+/g),(function(e,t){var n=dt[t]||w.find.attr;dt[t]=function(e,t,i){var o,s,r=t.toLowerCase();return i||(s=dt[r],dt[r]=o,o=null!=n(e,t,i)?r:null,dt[r]=s),o}}));var ht=/^(?:input|select|textarea|button)$/i,ft=/^(?:a|area)$/i;function pt(e){return(e.match(z)||[]).join(" ")}function mt(e){return e.getAttribute&&e.getAttribute("class")||""}function gt(e){return Array.isArray(e)?e:"string"==typeof e&&e.match(z)||[]}w.fn.extend({prop:function(e,t){return B(this,w.prop,e,t,arguments.length>1)},removeProp:function(e){return this.each((function(){delete this[w.propFix[e]||e]}))}}),w.extend({prop:function(e,t,n){var i,o,s=e.nodeType;if(3!==s&&8!==s&&2!==s)return 1===s&&w.isXMLDoc(e)||(t=w.propFix[t]||t,o=w.propHooks[t]),void 0!==n?o&&"set"in o&&void 0!==(i=o.set(e,n,t))?i:e[t]=n:o&&"get"in o&&null!==(i=o.get(e,t))?i:e[t]},propHooks:{tabIndex:{get:function(e){var t=w.find.attr(e,"tabindex");return t?parseInt(t,10):ht.test(e.nodeName)||ft.test(e.nodeName)&&e.href?0:-1}}},propFix:{for:"htmlFor",class:"className"}}),f.optSelected||(w.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),w.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],(function(){w.propFix[this.toLowerCase()]=this})),w.fn.extend({addClass:function(e){var t,n,i,o,s,r,a,l=0;if(p(e))return this.each((function(t){w(this).addClass(e.call(this,t,mt(this)))}));if((t=gt(e)).length)for(;n=this[l++];)if(o=mt(n),i=1===n.nodeType&&" "+pt(o)+" "){for(r=0;s=t[r++];)i.indexOf(" "+s+" ")<0&&(i+=s+" ");o!==(a=pt(i))&&n.setAttribute("class",a)}return this},removeClass:function(e){var t,n,i,o,s,r,a,l=0;if(p(e))return this.each((function(t){w(this).removeClass(e.call(this,t,mt(this)))}));if(!arguments.length)return this.attr("class","");if((t=gt(e)).length)for(;n=this[l++];)if(o=mt(n),i=1===n.nodeType&&" "+pt(o)+" "){for(r=0;s=t[r++];)for(;i.indexOf(" "+s+" ")>-1;)i=i.replace(" "+s+" "," ");o!==(a=pt(i))&&n.setAttribute("class",a)}return this},toggleClass:function(e,t){var n=typeof e,i="string"===n||Array.isArray(e);return"boolean"==typeof t&&i?t?this.addClass(e):this.removeClass(e):p(e)?this.each((function(n){w(this).toggleClass(e.call(this,n,mt(this),t),t)})):this.each((function(){var t,o,s,r;if(i)for(o=0,s=w(this),r=gt(e);t=r[o++];)s.hasClass(t)?s.removeClass(t):s.addClass(t);else void 0!==e&&"boolean"!==n||((t=mt(this))&&Y.set(this,"__className__",t),this.setAttribute&&this.setAttribute("class",t||!1===e?"":Y.get(this,"__className__")||""))}))},hasClass:function(e){var t,n,i=0;for(t=" "+e+" ";n=this[i++];)if(1===n.nodeType&&(" "+pt(mt(n))+" ").indexOf(t)>-1)return!0;return!1}});var vt=/\r/g;w.fn.extend({val:function(e){var t,n,i,o=this[0];return arguments.length?(i=p(e),this.each((function(n){var o;1===this.nodeType&&(null==(o=i?e.call(this,n,w(this).val()):e)?o="":"number"==typeof o?o+="":Array.isArray(o)&&(o=w.map(o,(function(e){return null==e?"":e+""}))),(t=w.valHooks[this.type]||w.valHooks[this.nodeName.toLowerCase()])&&"set"in t&&void 0!==t.set(this,o,"value")||(this.value=o))}))):o?(t=w.valHooks[o.type]||w.valHooks[o.nodeName.toLowerCase()])&&"get"in t&&void 0!==(n=t.get(o,"value"))?n:"string"==typeof(n=o.value)?n.replace(vt,""):null==n?"":n:void 0}}),w.extend({valHooks:{option:{get:function(e){var t=w.find.attr(e,"value");return null!=t?t:pt(w.text(e))}},select:{get:function(e){var t,n,i,o=e.options,s=e.selectedIndex,r="select-one"===e.type,a=r?null:[],l=r?s+1:o.length;for(i=s<0?l:r?s:0;i-1)&&(n=!0);return n||(e.selectedIndex=-1),s}}}}),w.each(["radio","checkbox"],(function(){w.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=w.inArray(w(e).val(),t)>-1}},f.checkOn||(w.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})})),f.focusin="onfocusin"in e;var yt=/^(?:focusinfocus|focusoutblur)$/,bt=function(e){e.stopPropagation()};w.extend(w.event,{trigger:function(t,n,i,o){var s,r,a,l,c,d,h,f,v=[i||g],y=u.call(t,"type")?t.type:t,b=u.call(t,"namespace")?t.namespace.split("."):[];if(r=f=a=i=i||g,3!==i.nodeType&&8!==i.nodeType&&!yt.test(y+w.event.triggered)&&(y.indexOf(".")>-1&&(b=y.split("."),y=b.shift(),b.sort()),c=y.indexOf(":")<0&&"on"+y,(t=t[w.expando]?t:new w.Event(y,"object"==typeof t&&t)).isTrigger=o?2:3,t.namespace=b.join("."),t.rnamespace=t.namespace?new RegExp("(^|\\.)"+b.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,t.result=void 0,t.target||(t.target=i),n=null==n?[t]:w.makeArray(n,[t]),h=w.event.special[y]||{},o||!h.trigger||!1!==h.trigger.apply(i,n))){if(!o&&!h.noBubble&&!m(i)){for(l=h.delegateType||y,yt.test(l+y)||(r=r.parentNode);r;r=r.parentNode)v.push(r),a=r;a===(i.ownerDocument||g)&&v.push(a.defaultView||a.parentWindow||e)}for(s=0;(r=v[s++])&&!t.isPropagationStopped();)f=r,t.type=s>1?l:h.bindType||y,(d=(Y.get(r,"events")||Object.create(null))[t.type]&&Y.get(r,"handle"))&&d.apply(r,n),(d=c&&r[c])&&d.apply&&Q(r)&&(t.result=d.apply(r,n),!1===t.result&&t.preventDefault());return t.type=y,o||t.isDefaultPrevented()||h._default&&!1!==h._default.apply(v.pop(),n)||!Q(i)||c&&p(i[y])&&!m(i)&&((a=i[c])&&(i[c]=null),w.event.triggered=y,t.isPropagationStopped()&&f.addEventListener(y,bt),i[y](),t.isPropagationStopped()&&f.removeEventListener(y,bt),w.event.triggered=void 0,a&&(i[c]=a)),t.result}},simulate:function(e,t,n){var i=w.extend(new w.Event,n,{type:e,isSimulated:!0});w.event.trigger(i,null,t)}}),w.fn.extend({trigger:function(e,t){return this.each((function(){w.event.trigger(e,t,this)}))},triggerHandler:function(e,t){var n=this[0];if(n)return w.event.trigger(e,t,n,!0)}}),f.focusin||w.each({focus:"focusin",blur:"focusout"},(function(e,t){var n=function(e){w.event.simulate(t,e.target,w.event.fix(e))};w.event.special[t]={setup:function(){var i=this.ownerDocument||this.document||this,o=Y.access(i,t);o||i.addEventListener(e,n,!0),Y.access(i,t,(o||0)+1)},teardown:function(){var i=this.ownerDocument||this.document||this,o=Y.access(i,t)-1;o?Y.access(i,t,o):(i.removeEventListener(e,n,!0),Y.remove(i,t))}}}));var _t=e.location,wt={guid:Date.now()},xt=/\?/;w.parseXML=function(t){var n,i;if(!t||"string"!=typeof t)return null;try{n=(new e.DOMParser).parseFromString(t,"text/xml")}catch(e){}return i=n&&n.getElementsByTagName("parsererror")[0],n&&!i||w.error("Invalid XML: "+(i?w.map(i.childNodes,(function(e){return e.textContent})).join("\n"):t)),n};var Et=/\[\]$/,Ct=/\r?\n/g,St=/^(?:submit|button|image|reset|file)$/i,Tt=/^(?:input|select|textarea|keygen)/i;function kt(e,t,n,i){var o;if(Array.isArray(t))w.each(t,(function(t,o){n||Et.test(e)?i(e,o):kt(e+"["+("object"==typeof o&&null!=o?t:"")+"]",o,n,i)}));else if(n||"object"!==b(t))i(e,t);else for(o in t)kt(e+"["+o+"]",t[o],n,i)}w.param=function(e,t){var n,i=[],o=function(e,t){var n=p(t)?t():t;i[i.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(null==e)return"";if(Array.isArray(e)||e.jquery&&!w.isPlainObject(e))w.each(e,(function(){o(this.name,this.value)}));else for(n in e)kt(n,e[n],t,o);return i.join("&")},w.fn.extend({serialize:function(){return w.param(this.serializeArray())},serializeArray:function(){return this.map((function(){var e=w.prop(this,"elements");return e?w.makeArray(e):this})).filter((function(){var e=this.type;return this.name&&!w(this).is(":disabled")&&Tt.test(this.nodeName)&&!St.test(e)&&(this.checked||!fe.test(e))})).map((function(e,t){var n=w(this).val();return null==n?null:Array.isArray(n)?w.map(n,(function(e){return{name:t.name,value:e.replace(Ct,"\r\n")}})):{name:t.name,value:n.replace(Ct,"\r\n")}})).get()}});var It=/%20/g,At=/#.*$/,Ot=/([?&])_=[^&]*/,Dt=/^(.*?):[ \t]*([^\r\n]*)$/gm,Nt=/^(?:GET|HEAD)$/,Lt=/^\/\//,$t={},zt={},Pt="*/".concat("*"),Ht=g.createElement("a");function jt(e){return function(t,n){"string"!=typeof t&&(n=t,t="*");var i,o=0,s=t.toLowerCase().match(z)||[];if(p(n))for(;i=s[o++];)"+"===i[0]?(i=i.slice(1)||"*",(e[i]=e[i]||[]).unshift(n)):(e[i]=e[i]||[]).push(n)}}function Mt(e,t,n,i){var o={},s=e===zt;function r(a){var l;return o[a]=!0,w.each(e[a]||[],(function(e,a){var c=a(t,n,i);return"string"!=typeof c||s||o[c]?s?!(l=c):void 0:(t.dataTypes.unshift(c),r(c),!1)})),l}return r(t.dataTypes[0])||!o["*"]&&r("*")}function Rt(e,t){var n,i,o=w.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((o[n]?e:i||(i={}))[n]=t[n]);return i&&w.extend(!0,e,i),e}Ht.href=_t.href,w.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:_t.href,type:"GET",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(_t.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Pt,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":w.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?Rt(Rt(e,w.ajaxSettings),t):Rt(w.ajaxSettings,e)},ajaxPrefilter:jt($t),ajaxTransport:jt(zt),ajax:function(t,n){"object"==typeof t&&(n=t,t=void 0),n=n||{};var i,o,s,r,a,l,c,u,d,h,f=w.ajaxSetup({},n),p=f.context||f,m=f.context&&(p.nodeType||p.jquery)?w(p):w.event,v=w.Deferred(),y=w.Callbacks("once memory"),b=f.statusCode||{},_={},x={},E="canceled",C={readyState:0,getResponseHeader:function(e){var t;if(c){if(!r)for(r={};t=Dt.exec(s);)r[t[1].toLowerCase()+" "]=(r[t[1].toLowerCase()+" "]||[]).concat(t[2]);t=r[e.toLowerCase()+" "]}return null==t?null:t.join(", ")},getAllResponseHeaders:function(){return c?s:null},setRequestHeader:function(e,t){return null==c&&(e=x[e.toLowerCase()]=x[e.toLowerCase()]||e,_[e]=t),this},overrideMimeType:function(e){return null==c&&(f.mimeType=e),this},statusCode:function(e){var t;if(e)if(c)C.always(e[C.status]);else for(t in e)b[t]=[b[t],e[t]];return this},abort:function(e){var t=e||E;return i&&i.abort(t),S(0,t),this}};if(v.promise(C),f.url=((t||f.url||_t.href)+"").replace(Lt,_t.protocol+"//"),f.type=n.method||n.type||f.method||f.type,f.dataTypes=(f.dataType||"*").toLowerCase().match(z)||[""],null==f.crossDomain){l=g.createElement("a");try{l.href=f.url,l.href=l.href,f.crossDomain=Ht.protocol+"//"+Ht.host!=l.protocol+"//"+l.host}catch(e){f.crossDomain=!0}}if(f.data&&f.processData&&"string"!=typeof f.data&&(f.data=w.param(f.data,f.traditional)),Mt($t,f,n,C),c)return C;for(d in(u=w.event&&f.global)&&0==w.active++&&w.event.trigger("ajaxStart"),f.type=f.type.toUpperCase(),f.hasContent=!Nt.test(f.type),o=f.url.replace(At,""),f.hasContent?f.data&&f.processData&&0===(f.contentType||"").indexOf("application/x-www-form-urlencoded")&&(f.data=f.data.replace(It,"+")):(h=f.url.slice(o.length),f.data&&(f.processData||"string"==typeof f.data)&&(o+=(xt.test(o)?"&":"?")+f.data,delete f.data),!1===f.cache&&(o=o.replace(Ot,"$1"),h=(xt.test(o)?"&":"?")+"_="+wt.guid+++h),f.url=o+h),f.ifModified&&(w.lastModified[o]&&C.setRequestHeader("If-Modified-Since",w.lastModified[o]),w.etag[o]&&C.setRequestHeader("If-None-Match",w.etag[o])),(f.data&&f.hasContent&&!1!==f.contentType||n.contentType)&&C.setRequestHeader("Content-Type",f.contentType),C.setRequestHeader("Accept",f.dataTypes[0]&&f.accepts[f.dataTypes[0]]?f.accepts[f.dataTypes[0]]+("*"!==f.dataTypes[0]?", "+Pt+"; q=0.01":""):f.accepts["*"]),f.headers)C.setRequestHeader(d,f.headers[d]);if(f.beforeSend&&(!1===f.beforeSend.call(p,C,f)||c))return C.abort();if(E="abort",y.add(f.complete),C.done(f.success),C.fail(f.error),i=Mt(zt,f,n,C)){if(C.readyState=1,u&&m.trigger("ajaxSend",[C,f]),c)return C;f.async&&f.timeout>0&&(a=e.setTimeout((function(){C.abort("timeout")}),f.timeout));try{c=!1,i.send(_,S)}catch(e){if(c)throw e;S(-1,e)}}else S(-1,"No Transport");function S(t,n,r,l){var d,h,g,_,x,E=n;c||(c=!0,a&&e.clearTimeout(a),i=void 0,s=l||"",C.readyState=t>0?4:0,d=t>=200&&t<300||304===t,r&&(_=function(e,t,n){for(var i,o,s,r,a=e.contents,l=e.dataTypes;"*"===l[0];)l.shift(),void 0===i&&(i=e.mimeType||t.getResponseHeader("Content-Type"));if(i)for(o in a)if(a[o]&&a[o].test(i)){l.unshift(o);break}if(l[0]in n)s=l[0];else{for(o in n){if(!l[0]||e.converters[o+" "+l[0]]){s=o;break}r||(r=o)}s=s||r}if(s)return s!==l[0]&&l.unshift(s),n[s]}(f,C,r)),!d&&w.inArray("script",f.dataTypes)>-1&&w.inArray("json",f.dataTypes)<0&&(f.converters["text script"]=function(){}),_=function(e,t,n,i){var o,s,r,a,l,c={},u=e.dataTypes.slice();if(u[1])for(r in e.converters)c[r.toLowerCase()]=e.converters[r];for(s=u.shift();s;)if(e.responseFields[s]&&(n[e.responseFields[s]]=t),!l&&i&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),l=s,s=u.shift())if("*"===s)s=l;else if("*"!==l&&l!==s){if(!(r=c[l+" "+s]||c["* "+s]))for(o in c)if((a=o.split(" "))[1]===s&&(r=c[l+" "+a[0]]||c["* "+a[0]])){!0===r?r=c[o]:!0!==c[o]&&(s=a[0],u.unshift(a[1]));break}if(!0!==r)if(r&&e.throws)t=r(t);else try{t=r(t)}catch(e){return{state:"parsererror",error:r?e:"No conversion from "+l+" to "+s}}}return{state:"success",data:t}}(f,_,C,d),d?(f.ifModified&&((x=C.getResponseHeader("Last-Modified"))&&(w.lastModified[o]=x),(x=C.getResponseHeader("etag"))&&(w.etag[o]=x)),204===t||"HEAD"===f.type?E="nocontent":304===t?E="notmodified":(E=_.state,h=_.data,d=!(g=_.error))):(g=E,!t&&E||(E="error",t<0&&(t=0))),C.status=t,C.statusText=(n||E)+"",d?v.resolveWith(p,[h,E,C]):v.rejectWith(p,[C,E,g]),C.statusCode(b),b=void 0,u&&m.trigger(d?"ajaxSuccess":"ajaxError",[C,f,d?h:g]),y.fireWith(p,[C,E]),u&&(m.trigger("ajaxComplete",[C,f]),--w.active||w.event.trigger("ajaxStop")))}return C},getJSON:function(e,t,n){return w.get(e,t,n,"json")},getScript:function(e,t){return w.get(e,void 0,t,"script")}}),w.each(["get","post"],(function(e,t){w[t]=function(e,n,i,o){return p(n)&&(o=o||i,i=n,n=void 0),w.ajax(w.extend({url:e,type:t,dataType:o,data:n,success:i},w.isPlainObject(e)&&e))}})),w.ajaxPrefilter((function(e){var t;for(t in e.headers)"content-type"===t.toLowerCase()&&(e.contentType=e.headers[t]||"")})),w._evalUrl=function(e,t,n){return w.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,converters:{"text script":function(){}},dataFilter:function(e){w.globalEval(e,t,n)}})},w.fn.extend({wrapAll:function(e){var t;return this[0]&&(p(e)&&(e=e.call(this[0])),t=w(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map((function(){for(var e=this;e.firstElementChild;)e=e.firstElementChild;return e})).append(this)),this},wrapInner:function(e){return p(e)?this.each((function(t){w(this).wrapInner(e.call(this,t))})):this.each((function(){var t=w(this),n=t.contents();n.length?n.wrapAll(e):t.append(e)}))},wrap:function(e){var t=p(e);return this.each((function(n){w(this).wrapAll(t?e.call(this,n):e)}))},unwrap:function(e){return this.parent(e).not("body").each((function(){w(this).replaceWith(this.childNodes)})),this}}),w.expr.pseudos.hidden=function(e){return!w.expr.pseudos.visible(e)},w.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},w.ajaxSettings.xhr=function(){try{return new e.XMLHttpRequest}catch(e){}};var Ft={0:200,1223:204},Bt=w.ajaxSettings.xhr();f.cors=!!Bt&&"withCredentials"in Bt,f.ajax=Bt=!!Bt,w.ajaxTransport((function(t){var n,i;if(f.cors||Bt&&!t.crossDomain)return{send:function(o,s){var r,a=t.xhr();if(a.open(t.type,t.url,t.async,t.username,t.password),t.xhrFields)for(r in t.xhrFields)a[r]=t.xhrFields[r];for(r in t.mimeType&&a.overrideMimeType&&a.overrideMimeType(t.mimeType),t.crossDomain||o["X-Requested-With"]||(o["X-Requested-With"]="XMLHttpRequest"),o)a.setRequestHeader(r,o[r]);n=function(e){return function(){n&&(n=i=a.onload=a.onerror=a.onabort=a.ontimeout=a.onreadystatechange=null,"abort"===e?a.abort():"error"===e?"number"!=typeof a.status?s(0,"error"):s(a.status,a.statusText):s(Ft[a.status]||a.status,a.statusText,"text"!==(a.responseType||"text")||"string"!=typeof a.responseText?{binary:a.response}:{text:a.responseText},a.getAllResponseHeaders()))}},a.onload=n(),i=a.onerror=a.ontimeout=n("error"),void 0!==a.onabort?a.onabort=i:a.onreadystatechange=function(){4===a.readyState&&e.setTimeout((function(){n&&i()}))},n=n("abort");try{a.send(t.hasContent&&t.data||null)}catch(e){if(n)throw e}},abort:function(){n&&n()}}})),w.ajaxPrefilter((function(e){e.crossDomain&&(e.contents.script=!1)})),w.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return w.globalEval(e),e}}}),w.ajaxPrefilter("script",(function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")})),w.ajaxTransport("script",(function(e){var t,n;if(e.crossDomain||e.scriptAttrs)return{send:function(i,o){t=w(" + + + + + + + diff --git a/docs/ktools/index.html b/docs/ktools/index.html new file mode 100644 index 00000000000..78fdefa0993 --- /dev/null +++ b/docs/ktools/index.html @@ -0,0 +1,726 @@ + + + + + + + + + + + + + + +K Tools | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + +

+ + + +
+
+
+ + +
+ +
+

K Tools

+

Here we document how to use some of the most commonly used K tools.

+

Minimizing Output

+

When one is working with kore-repl or the prover in general and looking at +specific configurations using config, sometimes the configurations can be huge.

+

One tool to help print configuration compactly is the pyk print utility:

+
sh
pyk print +
+

We are going to use --minimize option (which is actually used automatically +when printing with pyk). This will filter out many uninteresting cells for the +current config and make the result more compact.

+

Then, when invoking the prover, you can minimize your output by piping it into +the pyk print ... facility with arguments for controlling the output:

+
sh
kprove --output json --definition DEFN ... \ + | jq .term \ + | pyk print DEFN /dev/stdin --omit-labels ... --keep-labels ... +
+

You can also use this in the kore-repl more easily, by making a help script. +In your current directory, save a new script pykprint.sh:

+
sh
#!/bin/bash + +kast --input kore --output json --definition $1 /dev/stdin \ + | jq .term \ + | pyk print $1 /dev/stdin --omit-labels $2 +
+

Now call config | bash pykprint.sh DEFN in Kore REPL to make the output +smaller.

+

The options you have to control the output are as follows:

+
    +
  • --no-minimize: do not remove uninteresting cells.
  • +
  • --omit-cells: remove the selected cells from the output.
  • +
  • --keep-cells: keep only the selected cells in the output.
  • +
+

Note: Make sure that there is no whitespace around , in the omit list, +otherwise you'll get an error (, is a list separator, so this +requirement is strict).

+

Debugging

+

The LLVM Backend has support for integration with GDB. You can run the debugger +on a particular program by passing the --debugger flag to krun, or by +invoking the llvm backend interpreter directly. Below we provide a simple +tutorial to explain some of the basic commands supported by the LLVM backend.

+

LLDB Support

+

GDB is not well-supported on macOS, particularly on newer OS versions and Apple +Silicon ARM hardware. Consequently, if the --debugger option is passed to krun +on macOS, LLDB[^1] is launched instead of GDB. However, the K-specific debugger +scripts that GDB uses have not been ported to LLDB yet, and so the instructions +in the rest of this section will not work.

+

The K Definition

+

Here is a sample K definition we will use to demonstrate debugging +capabilities:

+
k
module TEST + imports INT + + configuration <k> foo(5) </k> + rule [test]: I:Int => I +Int 1 requires I <Int 10 + + syntax Int ::= foo(Int) [function] + rule foo(I) => 0 -Int I + +endmodule +
+

You should compile this definition with --backend llvm --enable-llvm-debug to +use the debugger most effectively.

+

Stepping

+

Important: When you first run krun with option --debugger, GDB / LLDB +will instruct you on how to modify ~/.gdbinit or ~/.lldbinit to enable +printing abstract syntax of K terms in the debugger. If you do not perform this +step, you can still use all the other features, but K terms will be printed as +their raw address in memory.

+

GDB will need the kompiled interpreter in its safe path in order to access the +pretty printing python script within it. A good way to do this would be to pick +a minimum top-level path that covers all of your kompiled semantics (ie. set auto-load safe-path ~/k-semantics). LLDB has slightly different security +policies that do not require fully-arbitrary code execution.

+

This section uses GDB syntax to demonstrate the debugging features. Please +refer to the GDB to LLDB command map on +macOS.

+

You can break before every step of execution is taken by setting a breakpoint +on the k_step function.

+
(gdb) break definition.kore:k_step
+Breakpoint 1 at 0x25e340
+(gdb) run
+Breakpoint 1, 0x000000000025e340 in step (subject=`<generatedTop>{}`(`<k>{}`(`kseq{}`(`inj{Int{}, KItem{}}`(#token("0", "Int")),dotk{}(.KList))),`<generatedCounter>{}`(#token("0", "Int"))))
+(gdb) continue
+Continuing.
+
+Breakpoint 1, 0x000000000025e340 in step (subject=`<generatedTop>{}`(`<k>{}`(`kseq{}`(`inj{Int{}, KItem{}}`(#token("1", "Int")),dotk{}(.KList))),`<generatedCounter>{}`(#token("0", "Int"))))
+(gdb) continue 2
+Will ignore next crossing of breakpoint 1.  Continuing.
+
+Breakpoint 1, 0x000000000025e340 in step (subject=`<generatedTop>{}`(`<k>{}`(`kseq{}`(`inj{Int{}, KItem{}}`(#token("3", "Int")),dotk{}(.KList))),`<generatedCounter>{}`(#token("0", "Int"))))
+(gdb)
+
+

Breaking on a specific rule

+

You can break when a rule is applied by giving the rule a rule label. If the +module name is TEST and the rule label is test, you can break when the rule +applies by setting a breakpoint on the TEST.test.rhs function:

+
(gdb) break TEST.test.rhs
+Breakpoint 1 at 0x25e250: file /home/dwightguth/test/./test.k, line 4.
+(gdb) run
+Breakpoint 1, TEST.test.rhs (VarDotVar0=`<generatedCounter>{}`(#token("0", "Int")), VarDotVar1=dotk{}(.KList), VarI=#token("0", "Int")) at /home/dwightguth/test/./test.k:4
+4         rule [test]: I:Int => I +Int 1 requires I <Int 10
+(gdb)
+
+

Note that the substitution associated with that rule is visible in the +description of the frame.

+

You can also break when a side condition is applied using the TEST.test.sc +function:

+
(gdb) break TEST.test.sc
+Breakpoint 1 at 0x25e230: file /home/dwightguth/test/./test.k, line 4.
+(gdb) run
+Breakpoint 1, TEST.test.sc (VarI=#token("0", "Int")) at /home/dwightguth/test/./test.k:4
+4         rule [test]: I:Int => I +Int 1 requires I <Int 10
+(gdb)
+
+

Note that every variable used in the side condition can have its value +inspected when stopped at this breakpoint, but other variables are not visible.

+

You can also break on a rule by its location:

+
(gdb) break test.k:4
+Breakpoint 1 at 0x25e230: test.k:4. (2 locations)
+(gdb) run
+Breakpoint 1, TEST.test.sc (VarI=#token("0", "Int")) at /home/dwightguth/test/./test.k:4
+4         rule [test]: I:Int => I +Int 1 requires I <Int 10
+(gdb) continue
+Continuing.
+
+Breakpoint 1, TEST.test.rhs (VarDotVar0=`<generatedCounter>{}`(#token("0", "Int")), VarDotVar1=dotk{}(.KList), VarI=#token("0", "Int")) at /home/dwightguth/test/./test.k:4
+4         rule [test]: I:Int => I +Int 1 requires I <Int 10
+(gdb) continue
+Continuing.
+
+Breakpoint 1, TEST.test.sc (VarI=#token("1", "Int")) at /home/dwightguth/test/./test.k:4
+4         rule [test]: I:Int => I +Int 1 requires I <Int 10
+(gdb)
+
+

Note that this sets a breakpoint at two locations: one on the side condition +and one on the right hand side. If the rule had no side condition, the first +would not be set. You can also view the locations of the breakpoints and +disable them individually:

+
(gdb) info breakpoint
+Num     Type           Disp Enb Address            What
+1       breakpoint     keep y   <MULTIPLE>
+        breakpoint already hit 3 times
+1.1                         y     0x000000000025e230 in TEST.test.sc at /home/dwightguth/test/./test.k:4
+1.2                         y     0x000000000025e250 in TEST.test.rhs at /home/dwightguth/test/./test.k:4
+(gdb) disable 1.1
+(gdb) continue
+Continuing.
+
+Breakpoint 1, TEST.test.rhs (VarDotVar0=`<generatedCounter>{}`(#token("0", "Int")), VarDotVar1=dotk{}(.KList), VarI=#token("1", "Int")) at /home/dwightguth/test/./test.k:4
+4         rule [test]: I:Int => I +Int 1 requires I <Int 10
+(gdb) continue
+Continuing.
+
+Breakpoint 1, TEST.test.rhs (VarDotVar0=`<generatedCounter>{}`(#token("0", "Int")), VarDotVar1=dotk{}(.KList), VarI=#token("2", "Int")) at /home/dwightguth/test/./test.k:4
+4         rule [test]: I:Int => I +Int 1 requires I <Int 10
+(gdb)
+
+

Now only the breakpoint when the rule applies is enabled.

+

Breaking on a function

+

You can also break when a particular function in your semantics is invoked:

+
(gdb) info functions foo
+All functions matching regular expression "foo":
+
+File /home/dwightguth/test/./test.k:
+struct __mpz_struct *Lblfoo'LParUndsRParUnds'TEST'UndsUnds'Int(struct __mpz_struct *);
+(gdb) break Lblfoo'LParUndsRParUnds'TEST'UndsUnds'Int
+Breakpoint 1 at 0x25e640: file /home/dwightguth/test/./test.k, line 6.
+(gdb) run
+Breakpoint 1, Lblfoo'LParUndsRParUnds'TEST'UndsUnds'Int (_1=#token("1", "Int")) at /home/dwightguth/test/./test.k:6
+6         syntax Int ::= foo(Int) [function]
+(gdb)
+
+

In this case, the variables have numbers instead of names because the names of +arguments in functions in K come from rules, and we are stopped before any +specific rule has applied. For example, _1 is the first argument to the +function.

+

You can also set a breakpoint in this location by setting it on the line +associated with its production:

+
(gdb) break test.k:6
+Breakpoint 1 at 0x25e640: file /home/dwightguth/test/./test.k, line 6.
+(gdb) run
+Breakpoint 1, Lblfoo'LParUndsRParUnds'TEST'UndsUnds'Int (_1=#token("1", "Int")) at /home/dwightguth/test/./test.k:6
+6         syntax Int ::= foo(Int) [function]
+
+

These two syntaxes are equivalent; use whichever is easier for you.

+

You can also view the stack of function applications:

+
(gdb) bt
+#0  Lblfoo'LParUndsRParUnds'TEST'UndsUnds'Int (_1=#token("1", "Int")) at /home/dwightguth/test/./test.k:6
+#1  0x000000000025e5f8 in apply_rule_111 (VarDotVar0=`<generatedCounter>{}`(#token("0", "Int")), VarDotVar1=dotk{}(.KList)) at /home/dwightguth/test/./test.k:9
+#2  0x0000000000268a52 in take_steps ()
+#3  0x000000000026b7b4 in main ()
+(gdb)
+
+

Here we see that foo was invoked while applying the rule on line 9 of test.k, +and we also can see the substitution of that rule. If foo was evaluated while +evaluating another function, we would also be able to see the arguments of that +function as well, unless the function was tail recursive, in which case no +stack frame would exist once the tail call was performed.

+

Breaking on a set of rules or functions

+

Using rbreak <regex> you can set breakpoints on multiple functions.

+
    +
  • +

    rbreak Lbl - sets a breakpoint on all non hooked functions

    +
  • +
  • +

    rbreak Lbl.*TEST - sets a breakpoint on all functions from module TEST

    +
  • +
  • +

    rbreak hook_INT - sets a breakpoint on all hooks from module INT

    +
  • +
+

Other debugger issues

+
    +
  • <optimized out> try kompiling without -O1, -O2, or -O3.
  • +
  • (gdb) break definition.kore:break -> No source file named definition.kore. +send --enable-llvm-debug to kompile in order to generate debug info symbols.
  • +
+

Profiling your K semantics

+

The first thing to be aware of is in order to get meaningful data, +you need to build the semantics and all of its dependencies with +optimizations enabled but without the frame pointer elimination +optimization. For example, for EVM, this means rebuilding GMP, MPFR, +JEMalloc, Crypto++, SECP256K1, etc with the following exports.

+
sh
export CFLAGS="-DNDEBUG -O2 -fno-omit-frame-pointer" +export CXXFLAGS="-DNDEBUG -O2 -fno-omit-frame-pointer" +
+

You can skip this step, but if you do, any samples within these +libraries will not have correct stack trace information, which means +you will likely not get a meaningful set of data that will tell you +where the majority of time is really being spent. Don't worry about +rebuilding literally every single dependency though. Just focus on the +ones that you expect to take a non-negligible amount of runtime. You +will be able to tell if you haven't done enough later, and you can go +back and rebuild more. Once this is done, you then build K with +optimizations and debug info enabled, like so:

+
sh
mvn package -Dproject.build.type="FastBuild" +
+

Next, you build the semantics with optimizations and debug info +enabled (i.e., kompile -ccopt -O2 --iterated -ccopt -fno-omit-frame-pointer).

+

Once all this is done, you should be ready to profile your +application. Essentially, you should run whatever test suite you +usually run, but with perf record -g -- prefixed to the front. For +example, for KEVM it's the following command. (For best data, don't +run this step in parallel.)

+
sh
perf record -g -- make test-conformance +
+

Finally, you want to filter out just the samples that landed within +the llvm backend and view the report. For this, you need to know the +name of the binary that was generated by your build system. Normally +it is interpreter, but e.g. if you are building the web3 client for +kevm, it would be kevm-client. You will want to run the following +command.

+
sh
perf report -g -c $binary_name +
+

If all goes well, you should see a breakdown of where CPU time has +been spent executing the application. You will know that sufficient +time was spent rebuilding dependencies with the correct flags when the +total time reported by the main method is close to 100%. If it's not +close to 100%, this is probably because a decent amount of self time +was reported in stack traces that were not built with frame pointers +enabled, meaning that perf was unable to walk the stack. You will have +to go back, rebuild the appropriate libraries, and then record your +trace again.

+

Your ultimate goal is to identify the hotspots that take the most +time, and make them execute faster. Entries like step and +step_1234 like functions refer to the cost of matching. An entry +like side_condition_1234 is a side condition and apply_rule_1234 +is constructing the rhs of a rule. You can convert from this rule +ordinal to a location using the llvm-kompile-compute-loc script in +the bin folder of the llvm backend repo. For example,

+
sh
llvm-kompile-compute-loc 5868 evm-semantics/.build/defn/llvm/driver-kompiled +
+

spits out the following text.

+
Line: 18529
+/home/dwightguth/evm-semantics/./.build/defn/llvm/driver.k:493:10
+
+

This is the line of definition.kore that the axiom appears on as +well as the original location of the rule in the K semantics. You can +use this information to figure out which rules and functions are +causing the most time and optimize them to be more efficient.

+

Running tests - kserver

+

The kserver is a front-end tool based on Nailgun +which helps to reduce the startup time of the JVM. Calling kserver in a terminal +window will wait for all kompile/kprove calls and force them to run in the same process +and share the same threads. This also reduces the thread contention significantly. kompile +uses all the threads available to do rule parsing. Another benefit is that it saves caches, +and each time you call kprove/kast, you can access those directly w/o extra disk usage. +Running the regression-new integration tests on a powerful machine (32 threads) takes 8m, +with the kserver active it takes 2m. You can start the kserver in two ways.

+
    +
  • blocking: call kserver in the command line. Close it after you are done testing. Useful for quick testing.
  • +
  • non-blocking: call spawn-kserver <log.flie> and close it with stop-kserver - this is used for automation on CI
  • +
+

Because we reuse caches, you should stop and restart the server between runs. +The Nailgun implementation hasn't been updated in the last 3-5 years, and it's not compatible with Java 18 onwards.

+
+
+ + + +
+ +
+
+ + + + + + + + + + + + diff --git a/docs/user_manual/index.html b/docs/user_manual/index.html new file mode 100644 index 00000000000..e012acff8ce --- /dev/null +++ b/docs/user_manual/index.html @@ -0,0 +1,3945 @@ + + + + + + + + + + + + + + +K User Manual | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+ + +
+ +
+

K User Manual

+

NOTE: The K User Manual is still under construction; some features of K +may have partial or missing documentation.

+

Introduction

+

Why K?

+

The K Framework is a programming language and system design toolkit made for +practioners and researchers alike.

+

K For Practioners: +K is a framework for deriving programming languages tools from their semantic +specifications.

+

Typically, programming language tool development follows a similar pattern. +After a new programming language is designed, separate teams will develop +separate language tools (e.g. a compiler, interpreter, parser, symbolic +execution engine, etc). Code reuse is uncommon. The end result is that for each +new language, the same basic tools and patterns are re-implemented again and +again.

+

K approaches the problem differently -- it generates each of these tools from a single language specification. +The work of programming language design and tool implementation are made separate concerns. +The end result is that the exercise of +designing new languages and their associated tooling is now reduced to +developing a single language specification from which we derive our tooling for +free.

+

K For Researchers: +K is a configuration- and rewrite-based executable semantic framework.

+

In more detail, K specifications are:

+
    +
  1. Executable: compile into runnable and testable programs;
  2. +
  3. Semantic: correspond to a logical theory with a sound and relatively +complete proof system;
  4. +
  5. Configuration-based: organize system states into compositional, +hierarchical, labelled units called cells;
  6. +
  7. Rewrite-based: define system transitions using rewrite rules.
  8. +
+

K specifications are compiled into particular matching logic theories, giving +them a simple and expressive semantics. K semantic rules are implicitly defined +over the entire configuration structure, but omit unused cells, enabling a +highly modular definitional style. Furthermore, K has been used to develop +programming languages, type systems, and formal analysis tools.

+

Manual Objectives

+

As mentioned in the Why K? section above, the K Framework is designed as a +collection of language-generic command-line interface (CLI) tools which revolve +around K specifications. These tools cover a broad range of uses, but they +typically fall into one of the following categories:

+
    +
  1. Transforming K Specs (e.g. compilation)
  2. +
  3. Running K Specs (e.g. concrete and symbolic execution)
  4. +
  5. Analyzing K Specs (e.g. theorem proving)
  6. +
+

The main user-facing K tools include:

+
    +
  • kompile - the K compiler driver
  • +
  • kparse - the stanadlone K parser and abstract syntax tree (AST) +transformation tool
  • +
  • krun - the K interpreter and symbolic execution engine driver
  • +
  • kprove - the K theorem prover
  • +
+

This user manual is designed to be a tool reference. +In particular, it is not desgined to be a tutorial on how to write K +specifications or to teach the logical foundations of K. New K users should +consult our dedicated +K tutorial, +or the more language-design oriented +PL tutorial. +Researchers seeking to learn more about the logic underlying K are encouraged +to peruse the +growing literature on K and matching logic. +We will consider the manual complete when it provides a complete description of +all user-facing K tools and features.

+

Introduction to K

+

Since K specifications are the primary input into the entire system, let us +take a moment to describe them. At the highest level, K specifications describe +a programming language or system using three different pieces:

+
    +
  1. the system primitives, the base datatypes used during system operation, +e.g., numbers, lists, maps, etc;
  2. +
  3. the system state, a tuple or record over system primitives which gives a +complete snapshot of the system at any given moment;
  4. +
  5. the system behavior, a set of rules which defines possible system +evolutions.
  6. +
+

K specifications are then defined by a collection of sentences which +correspond to the three concepts above:

+
    +
  1. syntax declarations encode the system primitives;
  2. +
  3. configuration declarations encode the system state;
  4. +
  5. context and rule declarations encode the system behavior.
  6. +
+

K sentences are then organized into one or modules which are stored in one or +more files. In this scheme, files may require other files and modules may +import other modules, giving rise to a hierarchy of files and modules. We +give an intuitive sketch of the two levels of grouping in the diagram below:

+
   example.k file
+  +=======================+
+  | requires ".." --------|--> File_1
+  | ...                   |
+  | requires ".." --------|--> File_N
+  |                       |
+  |  +-----------------+  |
+  |  | module ..       |  |
+  |  |   imports .. ---|--|--> Module_1
+  |  |   ...           |  |
+  |  |   imports .. ---|--|--> Module_M
+  |  |                 |  |
+  |  |   sentence_1    |  |
+  |  |   ...           |  |
+  |  |   sentence_K    |  |
+  |  | endmodule       |  |
+  |  +-----------------+  |
+  |                       |
+  +=======================+
+
+

where:

+
    +
  • files and modules are denoted by double-bordered and single-borded boxes +respectively;
  • +
  • file or module identifiers are denoted by double dots (..);
  • +
  • potential repititions are denoted by triple dots (...).
  • +
+

In the end, we require that the file and module hierarchies both form a +directed acyclic graph (DAG). This is, no file may recursively require itself, +and likewise, no module may recursively import itself.

+

We now zoom in further to discuss the various kinds of sentences contained in K +specifications:

+
    +
  1. +

    sentences that define our system's primitives, including:

    +
      +
    • sort declarations: define new categories of primitive datatypes
    • +
    • Backus-Naur Form (BNF) grammar declarations: define the +operators that inhabit our primitive datatypes
    • +
    • lexical syntax declarations: define lexemes/tokens for the +lexer/tokenizer
    • +
    • syntax associativity declarations: specify the +associativity/grouping of our declared operators
    • +
    • syntax priority declarations: specify the priority of +potential ambiguous operators
    • +
    +
  2. +
  3. +

    sentences that define our system's state, including:

    +
      +
    • configuration declarations: define labelled, hierarchical records +using an nested XML-like syntax
    • +
    +
  4. +
  5. +

    sentences that define our system's behavior, including:

    +
      +
    • context declarations: describe how primitives and configurations +can simplify
    • +
    • context alias declarations: define templates that can generate new +contexts
    • +
    • rule declarations: define how the system transitions from one state +to the next
    • +
    +
  6. +
+

K Process Overview

+

We now examine how the K tools are generally used. The main input to all of the +K tools is a K specification. For effieciency reasons, this specification is +first compiled into an intermediate representation called Kore. Once we have +obtained this intermediate representation, we can use it to do:

+
    +
  1. parsing/pretty-printing, i.e., converting a K term, whose syntax is defined +by a K specification, into a alternate representation
  2. +
  3. concrete and abstract execution of a K specification
  4. +
  5. theorem proving, i.e., verifying whether a set of claims about a K +specification hold
  6. +
+

We represent the overall process using the graphic below:

+
 K Compilation Process
++============================================================+
+|                     +---------+                            |
+|  K Specification ---| kompile |--> Kore Specification --+  |
+|                     +---------+                         |  |
++=========================================================|==+
+                                                          |
+ K Execution Process                                      |
++=========================================================|==+
+|                                                         |  |
+|             +-------------------------------------------+  |
+|             |                                              |
+|             |       +---------+                            |
+|  K Term ----+-------| kparse  |--> K Term                  |
+|             |       +---------+                            |
+|             |                                              |
+|             |       +---------+                            |
+|  K Term ----+-------|  krun   |--> K Term                  |
+|             |       +---------+                            |
+|             |                                              |
+|             |       +---------+                            |
+|  K Claims --+-------| kprove  |--> K Claims                |
+|                     +---------+                            |
+|                                                            |
++============================================================+
+
+

where:

+
    +
  • process outlines are denoted by boxes with double-lined borders
  • +
  • executables are denoted by boxes with single-lined borders
  • +
  • inputs and outputs are denoted by words attached to lines
  • +
  • K terms typically correspond to programs defined in a particular +language's syntax (which are either parsed using kparse or executed using +krun)
  • +
  • K claims are a notation for describing how certain K programs should +execute (which are checked by our theorem prover kprove)
  • +
+

K Compilation Process: +Let us start with a description of the compilation process. According to the +above diagram, the compiler driver is called kompile. For our purposes, it is +enough to view the K compilation process as a black box that transforms a K +specification into a lower-level Kore specification that encodes the same +information, but that is easier to work with programmatically.

+

K Execution Process: +We now turn our attention to the K execution process. Abstractly, we can divide +the K execution process into the following stages:

+
    +
  1. the kore specification is loaded (which defines a lexer, parser, and +unparser among other things)
  2. +
  3. the input string is lexed into a token stream
  4. +
  5. the token stream is parsed into K terms/claims
  6. +
  7. the K term/claims are transformed according the K tool being used (e.g. +kparse, krun, or kprove)
  8. +
  9. the K term/claims are unparsed into a string form and printed
  10. +
+

Note that all of the above steps performed in K execution process are fully +prescribed by the input K specification. Of course, there are entire languages +devoted to encoding these various stages proces individually, e.g., flex for +lexers, bison for parsers, etc. What K offers is a consistent language to +package the above concepts in a way that we believe is convenient and practical +for a wide range of uses.

+

Module Declaration

+

K modules are declared at the top level of a K file. They begin with the +module keyword and are followed by a module ID and an optional set of +attributes. They continue with zero or more imports and zero or more sentences +until the endmodule keyword is reached.

+

A module ID consists of an optional # at the beginning, followed by one or +more components separated by hyphens. Each component can contain letters, +numbers, or underscores.

+

After the module ID, attributes can be specified in square brackets. See below +for an (incomplete) list of allowed module attributes.

+

Following the attributes, a module can contain zero or more imports. An +import consists of the import or imports keywords followed by a module ID. +An import tells the compiler that this module should contain all the sentences +(recursively) contained by the module being imported.

+

Imports can be public or private. By default, they are public, which +means that all the imported syntax can be used by any module that imports the +module doing the import. However, you can explicitly override the visibility +of the import with the public or private keyword immediately prior to the +module name. A module imported privately does not export its syntax to modules +that import the module doing the import.

+

Following imports, a module can contain zero or more sentences. A sentence can +be a syntax declaration, a rule, a configuration declaration, a context, a +claim, or a context alias. Details on each of these can be found in subsequent +sections.

+

private attribute

+

If the module is given the private attribute, all of its imports and syntax +are private by default. Individual pieces of syntax can be made public with +the public attribute, and individual imports can be made public with the +public keyword. See relevant sections on syntax and modules for more details +on what it means for syntax and imports to be public or private.

+

symbolic and concrete attribute

+

These attributes may be placed on modules to indicate that they should only +be used by the Haskell and LLVM backends respectively. If the definition is +compiled on the opposite backend, they are implicitly removed from the +definition prior to parsing anywhere they are imported. This can be useful when +used in limited capacity in order to provide alternate semantics for certain +features on different backends. It should be used sparingly as it makes it more +difficult to trust the correctness of your semantics, even in the presence of +testing.

+

Syntax Declaration

+

Named Non-Terminals

+

We have added a syntax to Productions which allows non-terminals to be given a +name in productions. This significantly improves the ability to document K, by +providing a way to explicitly explain what a field in a production corresponds +to instead of having to infer it from a comment or from the rule body.

+

The syntax is:

+
k
name: Sort +
+

This syntax can be used anywhere in a K definition that expects a non-terminal.

+

klabel(_) and symbol attributes

+

By default K generates for each syntax definition a long and obfuscated klabel +string, which serves as a unique internal identifier and also is used in kast +format of that syntax. If we need to reference a certain syntax production +externally, we have to manually define the klabels using the klabel attribute. +One example of where you would want to do this is to be able to refer to a given +symbol via the syntax priorities attribute, or to enable overloading of a +given symbol.

+

If you only provide the klabel attribute, you can use the provided klabel to +refer to that symbol anywhere in the frontend K code. However, the internal +identifier seen by the backend for that symbol will still be the long obfuscated +generated string. Sometimes you want control over the internal identfier used as +well, in which case you use the symbol attribute. This tells the frontend to +use whatever the declared klabel is directly as the internal identfier.

+

For example:

+
k
module MYMODULE + syntax FooBarBaz ::= #Foo( Int, Int ) [klabel(#Foo), symbol] // symbol1 + | #Bar( Int, Int ) [klabel(#Bar)] // symbol2 + | #Baz( Int, Int ) // symbol3 +endmodule +
+

Here, we have that:

+
    +
  • In frontend K, you can refer to "symbol1" as #Foo (from klabel(#Foo)), +and the backend will see 'Hash'Foo as the symbol name.
  • +
  • In frontend K, you can refer to "symbol2" as #Bar (from klabel(#Bar)), +and the backend will see +'Hash'Bar'LParUndsCommUndsRParUnds'MYMODULE'Unds'FooBarBaz'Unds'Int'Unds'Int +as the symbol name.
  • +
  • In frontend K, you can refer to "symbol3" as +#Baz(_,_)_MYMODULE_FooBarBaz_Int_Int (from auto-generated klabel), and +the backend will see +'Hash'Baz'LParUndsCommUndsRParUnds'MYMODULE'Unds'FooBarBaz'Unds'Int'Unds'Int +as the symbol name.
  • +
+

The symbol provided must be unique to this definition. This is enforced by K. +In general, it's recommended to use symbol attribute whenever you use klabel +unless you explicitely have a reason not to (eg. you want to overload symbols, +or you're using a deprecated backend). It can be very helpful use the symbol +attribute for debugging, as many debugging messages are printed in Kast format +which will be more readable with the symbol names you explicitely declare. +In addition, if you are programatically manipulating definitions via the JSON +Kast format, building terms using the user-provided pretty +symbol, klabel(...) is easier and less error-prone when the auto-generation +process for klabels changes.

+

Parametric productions and bracket attributes

+

Some syntax productions, like the rewrite operator, the bracket operator, and +the #if #then #else #fi operator, cannot have their precise type system +expressed using only concrete sorts.

+

Prior versions of K solved this issue by using the K sort in this case, but +this introduces inexactness in which poorly typed terms can be created even +without having a cast operator present in the syntax, which is a design +consideration we would prefer to avoid.

+

It also introduces cases where terms cannot be placed in positions where they +ought to be well sorted unless their return sort is made to be KBott, which in +turn vastly complicates the grammar and makes parsing much slower.

+

In order to introduce this, we provide a new syntax for parametric productions +in K. This allows you to express syntax that has a sort signature based on +parametric polymorphism. We do this by means of an optional curly-brace- +enclosed list of parameters prior to the return sort of a production.

+

Some examples:

+
k
syntax {Sort} Sort ::= "(" Sort ")" [bracket] +syntax {Sort} KItem ::= Sort +syntax {Sort} Sort ::= KBott +syntax {Sort} Sort ::= Sort "=>" Sort +syntax {Sort} Sort ::= "#if" Bool "#then" Sort "#else" Sort "#fi" +syntax {Sort1, Sort2} Sort1 ::= "#fun" "(" Sort2 "=>" Sort1 ")" "(" Sort2 ")" +
+

Here we have:

+
    +
  1. Brackets, which can enclose any sort but should be of the same sort that was +enclosed.
  2. +
  3. Every sort is a KItem.
  4. +
  5. A KBott term can appear inside any sort.
  6. +
  7. Rewrites, which can rewrite a value of any sort to a value of the same sort. +Note that this allows the lhs or rhs to be a subsort of the other.
  8. +
  9. If then else, which can return any sort but which must contain that sort on +both the true and false branches.
  10. +
  11. lambda applications, in which the argument and parameter must be the same +sort, and the return value of the application must be the same sort as the +return value of the function.
  12. +
+

Note the last case, in which two different parameters are specified separated +by a comma. This indicates that we have multiple independent parameters which +must be the same each place they occur, but not the same as the other +parameters.

+

In practice, because every sort is a subsort of K, the Sort2 +parameter in #6 above does nothing during parsing. It cannot +actually reject any parse, because it can always infer that the sort of the +argument and parameter are K, and it has no effect on the resulting sort of +the term. However, it will nevertheless affect the kore generated from the term +by introducing an additional parameter to the symbol generated for the term.

+

function and total attributes

+

Many times it becomes easier to write a semantics if you have "helper" +functions written which can be used in the RHS of rules. The function +attribute tells K that a given symbol should be simplified immediately when it +appears anywhere in the configuration. Semantically, it means that evaluation +of that symbol will result in at most one return value (that is, the symbol is +a partial function).

+

The total attribute indicates that a symbol cannot be equal to matching logic +bottom; in other words, it has at least one value for every possible set of +arguments. It can be added to a production with the function attribute to +indicate to the symbolic reasoning engine that a given symbol is a +total function, that is it has exactly one return value for every possible +input. Other uses of the total attribute (i.e., on multi-valued symbols to +indicate they always have at least one value) are not yet implemented.

+

For example, here we define the _+Word_ total function and the _/Word_ +partial function, which can be used to do addition/division modulo +2 ^Int 256. These functions can be used anywhere in the semantics where +integers should not grow larger than 2 ^Int 256. Notice how _/Word_ is +not defined when the denominator is 0.

+
k
syntax Int ::= Int "+Word" Int [function, total] + | Int "/Word" Int [function] + +rule I1 +Word I2 => (I1 +Int I2) modInt (2 ^Int 256) +rule I1 /Word I2 => (I1 /Int I2) modInt (2 ^Int 256) requires I2 =/=Int 0 +
+

freshGenerator attribute

+

In K, you can access "fresh" values in a given domain using the syntax +!VARNAME:VarSort (with the !-prefixed variable name). This is supported for +builtin sorts Int and Id already. For example, you can generate fresh +memory locations for declared identifiers as such:

+
k
rule <k> new var x ; => . ... </k> + <env> ENV => ENV [ x <- !I:Int ] </env> + <mem> MEM => MEM [ !I <- 0 ] </mem> +
+

Each time a !-prefixed variable is encountered, a new integer will be used, +so each variable declared with new var _ ; will get a unique position in the +<mem>.

+

Sometimes you want to have generation of fresh constants in a user-defined +sort. For this, K will still generate a fresh Int, but can use a converter +function you supply to turn it into the correct sort. For example, here we can +generate fresh Foos using the freshFoo(_) function annotated with +freshGenerator.

+
k
syntax Foo ::= "a" | "b" | "c" | d ( Int ) + +syntax Foo ::= freshFoo ( Int ) [freshGenerator, function, total] + +rule freshFoo(0) => a +rule freshFoo(1) => b +rule freshFoo(2) => c +rule freshFoo(I) => d(I) [owise] + +rule <k> new var x ; => . ... </k> + <env> ENV => ENV [ x <- !I:Int ] </env> + <mem> MEM => MEM [ !I <- !F:Foo ] </mem> +
+

Now each newly allocated memory slot will have a fresh Foo placed in it.

+

token attribute

+

The token attribute signals to the Kore generator that the associated sort +will be inhabited by domain values. Sorts inhabited by domain values must not +have any constructors declared.

+
k
syntax Bytes [hook(BYTES.Bytes), token] +
+

Converting between [token] sorts

+

You can convert between tokens of one sort via Strings by defining functions +implemented by builtin hooks. +The hook STRING.token2string allows conversion of any token to a string:

+
k
syntax String ::= FooToString(Foo) [function, total, hook(STRING.token2string)] +
+

Similarly, the hook STRING.string2Token allows the inverse:

+
k
syntax Bar ::= StringToBar(String) [function, total, hook(STRING.string2token)] +
+

WARNING: This sort of conversion does NOT do any sort of parsing or validation. +Thus, we can create arbitary tokens of any sort:

+
StringToBar("The sun rises in the west.")
+
+

Composing these two functions lets us convert from Foo to Bar

+
k
syntax Bar ::= FooToBar(Foo) [function] +rule FooToBar(F) => StringToBar(FooToString(F)) +
+

Parsing comments, and the #Layout sort

+

Productions for the #Layout sort are used to describe tokens that are +considered "whitespace". The scanner removes tokens matching these productions +so they are not even seen by the parser. Below, we use it to define +lines begining with ; (semicolon) as comments.

+
k
syntax #Layout ::= r"(;[^\\n\\r]*)" // Semi-colon comments + | r"([\\ \\n\\r\\t])" // Whitespace +
+

prec attribute

+

Consider the following naive attempt at creating a language what syntax that +allows two types of variables: names that contain underbars, and names that +contain sharps/hashes/pound-signs:

+
k
syntax NameWithUnderbar ::= r"[a-zA-Z][A-Za-z0-9_]*" [token] +syntax NameWithSharp ::= r"[a-zA-Z][A-Za-z0-9_#]*" [token] +syntax Pgm ::= underbar(NameWithUnderbar) + | sharp(NameWithSharp) +
+

Although, it seems that K has enough information to parse the programs +underbar(foo) and sharp(foo) with, the lexer does not take into account +whether a token is being parsed for the sharp or for the underbar +production. It chooses an arbitary sort for the token foo (perhaps +NameWithUnderbar). Thus, during paring it is unable to construct a valid term +for one of those programs (sharp(foo)) and produces the error message: +Inner Parser: Parse error: unexpected token 'foo'.

+

Since calculating inclusions and intersections between regular expressions is +tricky, we must provide this information to K. We do this via the prec(N) +attribute. The lexer will always prefer longer tokens to shorter tokens. +However, when it has to choose between two different tokens of equal length, +token productions with higher precedence are tried first. Note that the default +precedence value is zero when the prec attribute is not specified.

+

For example, the BUILTIN-ID-TOKENS module defines #UpperId and #LowerId with +the prec(2) attribute.

+
k
syntax #LowerId ::= r"[a-z][a-zA-Z0-9]*" [prec(2), token] + syntax #UpperId ::= r"[A-Z][a-zA-Z0-9]*" [prec(2), token] +
+

Furthermore, we also need to make sorts with more specific tokens subsorts of ones with more +general tokens. We add the token attribute to this production so that all +tokens of a particular sort are marked with the sort they are parsed as and not a +subsort thereof. e.g. we get underbar(#token("foo", "NameWithUnderbar")) +instead of underbar(#token("foo", "#LowerId"))

+
k
imports BUILTIN-ID-TOKENS +syntax NameWithUnderbar ::= r"[a-zA-Z][A-Za-z0-9_]*" [prec(1), token] + | #UpperId [token] + | #LowerId [token] +syntax NameWithSharp ::= r"[a-zA-Z][A-Za-z0-9_#]*" [prec(1), token] + | #UpperId [token] + | #LowerId [token] +syntax Pgm ::= underbar(NameWithUnderbar) + | sharp(NameWithSharp) +
+

unused attribute

+

K will warn you if you declare a symbol that is not used in any of the rules of +your definition. Sometimes this is intentional, however; in this case, you can +suppress the warning by adding the unused attribute to the production or +cell.

+
k
syntax Foo ::= foo() [unused] + +configuration <foo unused=""> .K </foo> +
+

Symbol priority and associativity

+

Unlike most other parser generators, K combines the task of parsing with AST +generation. A production declared with the syntax keyword in K is both a +piece of syntax used when parsing, and a symbol that is used when rewriting. +As a result, it is generally convenient to describe expression grammars using +priority and associativity declarations rather than explicitly transforming +your grammar into a series of nonterminals, one for each level of operator +precedence. Thus, for example, a simple grammar for addition and multiplication +will look like this:

+
k
syntax Exp ::= Exp "*" Exp + | Exp "+" Exp +
+

However, this grammar is ambiguous. The term x+y*z might refer to x+(y*z) +or to (x+y)*z. In order to differentiate this, we introduce a partial +ordering between productions known as priority. A symbol "has tighter priority" +than another symbol if the first symbol can appear under the second, but the +second cannot appear under the first without a bracket. For example, in +traditional arithmetic, multiplication has tighter priority than addition, +which means that x+y*z cannot parse as (x+y)*z because the addition +operator would appear directly beneath the multiplication, which is forbidden +by the priority filter.

+

Priority is applied individually to each possible ambiguous parse of a term. It +then either accepts or rejects that parse. If there is only a single remaining +parse (after all the other disambiguation steps have happened), this is the +parse that is chosen. If all the parses were rejected, it is a parse error. If +multiple parses remain, they might be resolved by further disambiguation such +as via the prefer and avoid attributes, but if multiple parses remain after +disambiguation finishes, this is an ambiguous parse error, indicating there is +not a unique parse for that term. In the vast majority of cases, this is +an error and indicates that you ought to either change your grammar or add +brackets to the term in question.

+

Priority is specified in K grammars by means of one of two different +mechanisms. The first, and simplest, simply replaces the | operator in a +sequence of K productions with the > operator. This operator indicates that +everything prior to the > operator (including transitively) binds tighter +than what comes after. For example, a more complete grammar for simple +arithmetic might be:

+
k
syntax Exp ::= Exp "*" Exp + | Exp "/" Exp + > Exp "+" Exp + | Exp "-" Exp +
+

This indicates that multiplication and division bind tigher than addition +and subtraction, but that there is no relationship in priority between +multiplication and division.

+

As you may have noticed, this grammar is also ambiguous. x*y/z might refer to +x*(y/z) or to (x*y)/z. Indeed, if we removed division and subtraction +entirely, the grammar would still be ambiguous: x*y*z might parse as +x*(y*z), or as (x*y)*z. To resolve this, we introduce another feature: +associativity. Roughly, asssociativity tells us how symbols are allowed to nest +within other symbols with the same priority. If a set of symbols is left +associative, then symbols in that set cannot appear as the rightmost child +of other symbols in that set. If a set of symbols is right associative, then +symbols in that set cannot appear as the leftmost child of other symbols in +that set. Finally, if a set of symbols is non-associative, then symbols +in that set cannot appear as the rightmost or leftmost child of other symbols +in that set. For example, in the above example, if addition and subtraction +are left associative, then x+y+z will parse as (x+y)+z and x+y-z will +parse as (x+y)-z (because the other parse will have been rejected).

+

You might notice that this seems to apply only to binary infix operators. In +fact, the real behavior is slightly more complicated. Priority and +associativity (for technical reasons that go beyond the scope of this document) +really only apply when the rightmost or leftmost item in a production is a +nonterminal. If the rightmost nonterminal is followed by a terminal (or +respectively the leftmost preceded), priority and associativity do not apply. +Thus we can generalize these concepts to arbitrary context-free grammars.

+

Note that in some cases, this is not the behavior you want. You may actually +want to reject parses even though the leftmost and rightmost item in a +production are terminals. You can accomplish this by means of the +applyPriority attribute. When placed on a production, it tells the parser +which nonterminals of a production the priority filter ought to reject children +under, overriding the default behavior. For example, I might have a production +like syntax Exp ::= foo(Exp, Exp) [applyPriority(1)]. This tells the parser +to reject terms with looser priority binding under the first Exp, but not +the second. By default, with this production, neither position would apply +to the priority filter, because the first and last items of the production +are both terminals.

+

Associativity is specified in K grammars by means of one of two different +mechanisms. The first, and simplest, adds the associativity of a priority block +of symbols prior to that block. For example, we can remove the remaining +ambiguities in the above grammar like so:

+
k
syntax Exp ::= left: + Exp "*" Exp + | Exp "/" Exp + > right: + Exp "+" Exp + | Exp "-" Exp +
+

This indicates that multiplication and division are left-associative, ie, after +symbols with higher priority are parsed as innermost, symbols are nested with +the rightmost on top. Addition and subtraction are right associative, which +is the opposite and indicates that symbols are nested with the leftmost on top. +Note that this is similar but different from evaluation order, which also +concerns itself with the ordering of symbols, which is described in the next +section.

+

You may note we have not yet introduced the second syntax for priority +and associativity. In some cases, syntax for a grammar might be spread across +multiple modules, sometimes for very good reasons with respect to code +modularity. As a result, it becomes infeasible to declare priority and +associativity inline within a set of productions, because the productions +are not contiguous within a single file.

+

For this purpose, we introduce the equivalent syntax priorities, +syntax left, syntax right, and syntax non-assoc declarations. For +example, the above grammar can be written equivalently as:

+
k
syntax Exp ::= Exp "*" Exp [group(mult)] + | Exp "/" Exp [group(div)] + | Exp "+" Exp [group(add)] + | Exp "-" Exp [group(sub)] + +syntax priorities mult div > add sub +syntax left mult div +syntax right add sub +
+

Here, the group(_) attribute is used to create user-defined groups of +sentences. A particular group name collectively refers to the whole set of +sentences within that group. The sets are flattened together, so we could +equivalently have written:

+
k
syntax Exp ::= Exp "*" Exp [group(mult)] + | Exp "/" Exp [group(mult)] + | Exp "+" Exp [group(add)] + | Exp "-" Exp [group(add)] + +syntax priorities mult > add +syntax left mult +syntax right add +
+

Note that syntax [left|right|non-assoc] should not be used to group together +productions with different priorities. For example, this code would be invalid:

+
k
syntax priorities mult > add +syntax left mult add +
+

Note that there is one other way to describe associativity, but it is +prone to a very common mistake. You can apply the attribute left, right, +or non-assoc directly to a production to indicate that it is, by itself, +left-, right-, or non-associative.

+

However, this often does not mean what users think it means. In particular:

+
k
syntax Exp ::= Exp "+" Exp [left] + | Exp "-" Exp [left] +
+

is not equivalent to:

+
k
syntax Exp ::= left: + Exp "+" Exp + | Exp "-" Exp +
+

Under the first, each production is associative with itself, but not each +other. Thus, x+y+z will parse unambiguously as (x+y)+z, but x+y-z will +be ambiguous. However, in the second, x+y-z will parse unambiguously as +(x+y)-z.

+

Think carefully about how you want your grammar to parse. In general, if you're +not sure, it's probably best to group associativity together into the same +blocks you use for priority, rather than using left, right, or non-assoc +attributes on the productions.

+

Lexical identifiers

+

Sometimes it is convenient to be able to give a certain regular expression a +name and then refer to it in one or more regular expression terminals. This +can be done with a syntax lexical sentence in K:

+
k
syntax lexical Alphanum = r"[0-9a-zA-Z]" +
+

This defines a lexical identifier Alphanum which can be expanded in any +regular expression terminal to the above regular expression. For example, I +might choose to then implement the syntax of identifiers as follows:

+
k
syntax Id ::= r"[a-zA-Z]{Alphanum}*" [token] +
+

Here {Alphanum} expands to the above regular expression, making the sentence +equivalent to the following:

+
k
syntax Id ::= r"[a-zA-Z]([0-9a-zA-Z])*" [token] +
+

This feature can be used to more modularly construct the lexical syntax of your +language. Note that K does not currently check that lexical identifiers used +in regular expressions have been defined; this will generate an error when +creating the scanner, however, and the user ought to be able to debug what +happened.

+

assoc, comm, idem, and unit attributes

+

These attributes are used to indicate whether a collection or a production +is associative, commutative, idempotent, and/or has a unit. +In general, you should not need to apply these attributes to productions +yourself, however, they do have certain special meaning to K. K will generate +axioms related to each of these concepts into your definition for you +automatically. It will also automatically sort associative-commutative +collections, and flatten the indentation of associative collections, when +unparsing.

+

public and private attribute

+

K allows users to declare certain pieces of syntax as either public or private. +All syntax is public by default. Public syntax can be used from any module that +imports that piece of syntax. A piece of syntax can be declared private with +the private attribute. This means that that syntax can only be used in the +module in which it is declared; it is not visible from modules that import +that module.

+

You can also change the default visibility of a module with the private +attribute, when it is placed directly on a module. A module with the private +attribute has all syntax private by default; this can be overridden on +specific sentences with the public attribute.

+

Note that the private module attribute also changes the default visiblity +of imports; please refer to the appropriate section elsewhere in the manual +for more details.

+

Here is an example usage:

+
k
module WIDGET-SYNTAX + + syntax Widget ::= foo() + syntax WidgetHelper ::= bar() [private] // this production is not visible + // outside this module +endmodule + +module WIDGET [private] + imports WIDGET-SYNTAX + + syntax Widget ::= fooImpl() // this production is not visible outside this + // module + + // this production is visible outside this module + syntax KItem ::= adjustWidget(Widget) [function, public] +endmodule +
+

Configuration Declaration

+

exit attribute

+

A single configuration cell containing an integer may have the "exit" +attribute. This integer will then be used as the return value on the console +when executing the program.

+

For example:

+
k
configuration <k> $PGM:Pgm </k> + <status-code exit=""> 1 </status-code> +
+

declares that the cell status-code should be used as the exit-code for +invocations of krun. Additionally, we state that the default exit-code is 1 +(an error state). One use of this is for writing testing harnesses which assume +that the test fails until proven otherwise and only set the <status-code> cell +to 0 if the test succeeds.

+

Collection Cells: multiplicity and type attributes

+

Sometimes a semantics needs to allow multiple copies of the same cell, for +example if you are making a concurrent multi-threading programming language. +For this purpose, K supports the multiplicity and type attributes on cells +declared in the configuration.

+

multiplicity can take on values * and ?. Declaring multiplicity="*" +indicates that the cell may appear any number of times in a runtime +configuration. Setting multiplicity="?" indicates that the cell may only +appear exactly 0 or 1 times in a runtime configuration. If there are no +configuration variables present in the cell collection, the initial +configuration will start with exactly 0 instances of the cell collection. If +there are configuration variables present in the cell collection, the initial +configuration will start with exactly 1 instance of the cell collection.

+

type can take on values Set, List, and Map. For example, here we declare +several collecion cells:

+
k
configuration <k> $PGM:Pgm </k> + <sets> <set multiplicity="?" type="Set"> 0:Int </set> </sets> + <lists> <list multiplicity="*" type="List"> 0:Int </list> </lists> + <maps> + <map multiplicity="*" type="Map"> + <map-key> 0:Int </map-key> + <map-value-1> "":String </map-value-1> + <map-value-2> 0:Int </map-value-2> + </map> + </maps> +
+

Declaring type="Set" indicates that duplicate occurrences of the cell should +be de-duplicated, and accesses to instances of the cell will be nondeterministic +choices (constrained by any other parts of the match and side-conditions). +Similarly, declaring type="List" means that new instances of the cell can be +added at the front or back, and elements can be accessed from the front or back, +and the order of the cells will be maintained. The following are examples of +introduction and elimination rules for these collections:

+
k
rule <k> introduce-set(I:Int) => . ... </k> + <sets> .Bag => <set> I </set> </sets> + +rule <k> eliminate-set => I ... </k> + <sets> <set> I </set> => .Bag </sets> + +rule <k> introduce-list-start(I:Int) => . ... </k> + <lists> (.Bag => <list> I </list>) ... </lists> + +rule <k> introduce-list-end(I:Int) => . ... </k> + <lists> ... (.Bag => <list> I </list>) </lists> + +rule <k> eliminate-list-start => I ... </k> + <lists> (<list> I </list> => .Bag) ... </lists> + +rule <k> eliminate-list-end => I ... </k> + <lists> ... (<list> I </list> => .Bag) </lists> +
+

Notice that for multiplicity="?", we only admit a single <set> instance at +a time. For the type=List cell, we can add/eliminate cells from the from or +back of the <lists> cell. Also note that we use .Bag to indicate the empty +cell collection in all cases.

+

Declaring type="Map" indicates that the first sub-cell will be used as a +cell-key. This means that matching on those cells will be done as a map-lookup +operation if the cell-key is mentioned in the rule (for performance). If the +cell-key is not mentioned, it will fallback to normal nondeterministic +constrained by other parts of the match and any side-conditions. Note that there +is no special meaning to the name of the cells (in this case <map>, +<map-key>, <map-value-1>, and <map-value-2>). Additionally, any number of +sub-cells are allowed, and the entire instance of the cell collection is +considered part of the cell-value, including the cell-key (<map-key> in this +case) and the surrounding collection cell (<map> in this case).

+

For example, the following rules introduce, set, retrieve from, and eliminate +type="Map" cells:

+
k
rule <k> introduce-map(I:Int) => . ... </k> + <maps> ... (.Bag => <map> <map-key> I </map-key> ... </map>) ... </maps> + +rule <k> set-map-value-1(I:Int, S:String) => . ... </k> + <map> <map-key> I </map-key> <map-value-1> _ => S </map-value-1> ... </map> + +rule <k> set-map-value-2(I:Int, V:Int) => . ... </k> + <map> <map-key> I </map-key> <map-value-2> _ => V </map-value-2> ... </map> + +rule <k> retrieve-map-value-1(I:Int) => S ... </k> + <map> <map-key> I </map-key> <map-value-1> S </map-value-1> ... </map> + +rule <k> retrieve-map-value-2(I:Int) => V ... </k> + <map> <map-key> I </map-key> <map-value-2> V </map-value-2> ... </map> + +rule <k> eliminate-map(I:Int) => . ... </k> + <maps> ... (<map> <map-key> I </map-key> ... </map> => .Bag) ... </maps> +
+

Note how each rule makes sure that <map-key> cell is mentioned, and we +continue to use .Bag to indicate the empty collection. Also note that +when introducing new map elements, you may omit any of the sub-cells which are +not the cell-key. In case you do omit sub-cells, you must use structural +framing ... to indicate the missing cells, they will receive the default +value given in the configuration ... declaration.

+

Rule Declaration

+

Rule Structure

+

Each K rule follows the same basic structure (given as an example here):

+
k
rule LHS => RHS requires REQ ensures ENS [ATTRS] +
+

The portion between rule and requires is referred to as the rule body, +and may contain one or more rewrites (though not nested). Here, the rule body is +LHS => RHS, where LHS and RHS are used as placeholders for the pre- and +post- states. Note that we lose no generality referring to the LHS or the +RHS, even in the presence of multiple rewrites, as the rewrites are pulled to +the top-level anyway.

+

Next is the requires clause, represented here as REQ. The requires clause is +an additional predicate (function-like term of sort Bool), which is to be +evaluated before applying the rule. If the requires clause does not evaluate to +true, then the rule does not apply.

+

Finally is the ensures clause, represented here as ENS. The ensures clause +is to be interpreted as a post-condition, and will be automatically added to the +path condition if the rule applies. It may cause the entire term to become +undefined, but the backend will not stop itself from applying the rule in this +case. Note that concrete backends (eg. the LLVM backend) are free to ignore the +ensures clause.

+

Overall, the transition represented by such a rule is from a state +LHS #And REQ ending in a state RHS #And ENS. When backends apply this rule +as a transition/rewrite, they should:

+
    +
  • Check if pattern LHS matches (or unifies) with the current term, giving +substitution alpha.
  • +
  • Check if the instantiation alpha(REQ) is valid (or satisfiable).
  • +
  • Build the new term alpha(RHS #And ENS), and check if it's satisfiable.
  • +
+

Pattern Matching operator

+

Sometimes when you want to express a side condition, you want to say that a +rule matches if a particular term matches a particular pattern, or if it +instead does /not/ match a particular pattern.

+

The syntax in K for this is :=K and :/=K. It has similar meaning to ==K and +=/=K, except that where ==K and =/=K express equality, :=K and =/=K express +model membership. That is to say, whether or not the rhs is a member of the set +of terms expressed by the lhs pattern. Because the lhs of these operators is a +pattern, the user can use variables in the lhs of the operator. However, due to +current limitations, these variables are NOT bound in the rest of the term. +The user is thus encouraged to use anonymous variables only, although this is +not required.

+

This is compiled by the K frontend down to an efficient pattern matching on a +fresh function symbol.

+

Anonymous function applications

+

There are a number of cases in K where you would prefer to be able to take some +term on the RHS, bind it to a variable, and refer to it in multiple different +places in a rule.

+

You might also prefer to take a variable for which you know some of its +structure, and modify some of its internal structure without requiring you to +match on every single field contained inside that structure.

+

In order to do this, we introduce syntax to K that allows you to construct +anonymous functions in the RHS of a rule and apply them to a term.

+

The syntax for this is:

+
#fun(RuleBody)(Argument)
+
+

Note the limitations currently imposed by the implementation. These functions +are not first-order: you cannot bind them to a variable and inject them like +you can with a regular klabel for a function. You also cannot express multiple +rules or multiple parameters, or side conditions. All of these are extensions +we would like to support in the future, however.

+

In the following, we use three examples to illustrate the behavior of #fun. +We point out that the support for #fun is provided by the frontend, not the +backends.

+

The three examples are real examples borrowed or modified from existing language +semantics.

+

Example 1 (A Simple Self-Explained Example).

+
#fun(V:Val => isFoo(V) andBool isBar(V))(someFunctionReturningVal())
+
+

Example 2 (Nested #fun).

+
   #fun(C
+=> #fun(R
+=> #fun(E
+=> foo1(E, R, C)
+  )(foo2(C))
+  )(foo3(0))
+  )(foo4(1))
+
+

This example is from the beacon +semantics:https://github.com/runtimeverification/beacon-chain-spec/blob/master/b +eacon-chain.k at line 302, with some modification for simplicity. Note how +variables C, R, E are bound in the nested #fun.

+

Example 3 (Matching a structure).

+
rule foo(K, RECORD) =>
+  #fun(record(... field: _ => K))(RECORD)
+
+

Unlike previous examples, the LHS of #fun in this example is no longer a +variable, but a structure. It has the same spirit as the first two examples, +but we match the RECORD with a structure record( DotVar, field: X), instead +of a standalone variable. We also use K's local rewrite syntax (i.e., the +rewriting symbol => does not occur at the top-level) to prevent writing +duplicate expressions on the LHS and RHS of the rewriting.

+

Macros and Aliases

+

A production can be tagged with the macro, alias, macro-rec, or alias-rec +attributes. In all cases, what this signifies is that this is a macro production. +Macro rules are rules where the top symbol of the left-hand-side are macro +labels. Macro rules are applied statically during compilation on all terms that +they match, and statically before program execution on the initial configuration. +Currently, macro rules are required to not have side conditions, although they +can contain sort checks.

+

alias rules are also applied statically in reverse prior to unparsing on the +final configuration. Note that a macro rule can have unbound variables in the +right hand side. When such a macro exists, it should be used only on the left +hand side of rules, unless the user is performing symbolic execution and expects +to introduce symbolic terms into the subject being rewritten.

+

However, when used on the left hand side of a rule, it functions similarly to a +pattern alias, and allows the user to concisely express a reusable pattern that +they wish to match on in multiple places.

+

For example, consider the following semantics:

+
k
syntax KItem ::= "foo" [alias] | "foobar" +syntax KItem ::= bar(KItem) [macro] | baz(Int, KItem) +rule foo => foobar +rule bar(I) => baz(?_, I) +rule bar(I) => I +
+

This will rewrite baz(0, foo) to foo. First baz(0, foo) will be rewritten +statically to baz(0, foobar). Then the non-macro rule will apply (because +the rule will have been rewritten to rule baz(_, I) => I). Then foobar will +be rewritten statically after rewriting finishes to foo via the reverse form +of the alias.

+

Note that macros do not apply recursively within their own expansion. This is +done so as to ensure that macro expansion will always terminate. If the user +genuinely desires a recursive macro, the macro-rec and alias-rec attributes +can be used to provide this behavior.

+

For example, consider the following semantics:

+
k
syntax Exp ::= "int" Exp ";" | "int" Exps ";" [macro] | Exp Exp | Id +syntax Exps ::= List{Exp,","} + +rule int X:Id, X':Id, Xs:Exps ; => int X ; int X', Xs ; +
+

This will expand int x, y, z; to int x; int y, z; because the macro does +not apply the second time after applying the substitution of the first +application. However, if the macro attribute were changed to the macro-rec +attribute, it would instead expand (as the user likely intended) to +int x; int y; int z;.

+

The alias-rec attribute behaves with respect to the alias attribute the +same way the macro-rec attribute behaves with respect to macro.

+

anywhere rules

+

Some rules are not functional, but you want them to apply anywhere in the +configuration (similar to functional rules). You can use the anywhere +attribute on a rule to instruct the backends to make sure they apply anywhere +they match in the entire configuration.

+

For example, if you want to make sure that some associative operator is always +right-associated anywhere in the configuration, you can do:

+
k
syntax Stmt ::= Stmt ";" Stmt + +rule (S1 ; S2) ; S3 => S1 ; (S2 ; S3) [anywhere] +
+

Then after every step, all occurrences of _;_ will be re-associated. Note that +this allows the symbol _;_ to still be a constructor, even though it is +simplified similarly to a function.

+

trusted claims

+

You may add the trusted attribute to a given claim for the K prover to +automatically add it to the list of proven circularities, instead of trying to +discharge it separately.

+

Projection and Predicate functions

+

K automatically generates certain predicate and projection functions from the +syntax you declare. For example, if you write:

+
k
syntax Foo ::= foo(bar: Bar) +
+

It will automatically generate the following K code:

+
k
syntax Bool ::= isFoo(K) [function] +syntax Foo ::= "{" K "}" ":>Foo" [function] +syntax Bar ::= bar(Foo) [function] + +rule isFoo(F:Foo) => true +rule isFoo(_) => false [owise] + +rule { F:Foo }:>Foo => F +rule bar(foo(B:Bar)) => B +
+

The first two types of functions are generated automatically for every sort in +your K definition, and the third type of function is generated automatically +for each named nonterminal in your definition. Essentially, isFoo for some +sort Foo will tell you whether a particular term of sort K is a Foo, +{F}:>Foo will cast F to sort Foo if F is of sort Foo and will be +undefined (i.e., theoretically defined as #Bottom, the bottom symbol in +matching logic) otherwise. Finally, bar will project out the child of a foo +named bar in its production declaration.

+

Note that if another term of equal or smaller sort to Foo exists and has a +child named bar of equal or smaller sort to Bar, this will generate an +ambiguity during parsing, so care should be taken to ensure that named +nonterminals are sufficiently unique from one another to prevent such +ambiguities. Of course, the compiler will generate a warning in this case.

+

simplification attribute

+

The simplification attribute identifies rules outside the main semantics that +are used to simplify function patterns.

+

Conditions: A simplification rule is applied by matching the function +arguments, instead of unification as when applying function definition +rules. This allows function symbols to appear nested as arguments to other +functions on the left-hand side of a simplification rule, which is forbidden in +function definition rules. For example, this rule would not be accepted as a +function definition rule:

+
k
rule (X +Int Y) +Int Z => X +Int (Y +Int Z) [simplification] +
+

A simplification rule is only applied when the current side condition implies +the requires clause of the rule, like function definition rules.

+

Order: The simplification attribute accepts an optional integer argument +which is the rule's simplification priority; if the optional argument is not +specified, it is equivalent to a simplification priority of 50. Backends +should attempt simplification rules in order of their simplification +priority, but are not required to do so; in fact, the backend is free to apply +simplification rules at any time. Because of this, users must ensure that +simplification rules are sound regardless of their order of application. This +differs from the priority attribute in that rules with the priority +attribute must be applied in their priority order by the backend. It is an +error to have the priority attribute on a simplification rule.

+

For example, for the following definition:

+
k
syntax WordStack ::= Int ":" WordStack | ".WordStack" + syntax Int ::= sizeWordStack ( WordStack ) [function] + | sizeWordStackAux ( WordStack , Int ) [function] + // -------------------------------------------------------------- + rule sizeWordStack(WS) => sizeWordStackAux(WS, 0) + + rule sizeWordStackAux(.WordStack, N) => N + rule sizeWordStackAux(W : WS , N) => sizeWordStackAux(WS, N +Int 1) +
+

We might add the following simplification lemma:

+
k
rule sizeWordStackAux(WS, N) => N +Int sizeWordStackAux(WS, 0) + requires N =/=Int 0 + [simplification] +
+

Then this simplification rule will only apply if the Haskell backend can prove +that notBool N =/=Int 0 is unsatisfiable. This avoids an infinite cycle of +applying this simplification lemma.

+

NOTE: The frontend and Haskell backend do not check that supplied +simplification rules are sound, this is the developer's responsibility. In +particular, rules with the simplification attribute must preserve definedness; +that is, if the left-hand side refers to any partial function then:

+
    +
  • the right-hand side must be #Bottom when the left-hand side is #Bottom, or
  • +
  • the rule must have an ensures clause that is false when the left-hand +side is #Bottom, or
  • +
  • the rule must have a requires clause that is false when the left-hand +side is #Bottom.
  • +
+

These conditions are in order of decreasing preference: the best option is to +preserve #Bottom on the right-hand side, the next best option is to have an +ensures clause, and the least-preferred option is to have a requires clause. +The most preferred option is to write total functions and avoid the entire issue.

+

NOTE: The Haskell backend does not attempt to prove claims which right-hand +side is #Bottom. The reason for this is that the general case is undecidable, +and the backend might enter an infinite loop. Therefore, the backend emits a +warning if it encounters such a claim.

+

concrete and symbolic attributes (Haskell backend)

+

Users can control the application of simplification rules using the concrete +and the symbolic attributes by specifying the type of patterns the rule's +arguments are to match.

+

A concrete pattern is a pattern which does not contain variables or unevaluated +functions, otherwise the pattern is symbolic.

+

The semantics of the two attributes is defined as follows:

+
    +
  • If a simplification rule is marked concrete, then all arguments must be +concrete for the rule to match.
  • +
  • If a simplification rule is marked symbolic, then all arguments must be +symbolic for the rule to match.
  • +
  • The following syntax concrete(<variables>) (resp. symbolic(<variables>)), +where <variables> is a list of variable names separated by commas, can be used +to specify the exact arguments the user expects to match concrete (resp. symbolic) +patterns.
  • +
+

For example, the following will only match when all arguments +are concrete:

+
k
rule X +Int (Y +Int Z) => (X +Int Y) +Int Z [simplification, concrete] +
+

Conversely, the following will only match when all arguments +are symbolic:

+
k
rule X +Int (Y +Int Z) => (X +Int Y) +Int Z [simplification, symbolic] +
+

In practice, the following rules will re-associate and commute terms to combine +concrete arguments:

+
k
rule (A +Int Y) +Int Z => A +Int (Y +Int Z) + [concrete(Y, Z), symbolic(A), simplification] + +rule X +Int (B +Int Z) => B +Int (X +Int Z) + [concrete(X, Z), symbolic(B), simplification] +
+

The unboundVariables attribute

+

Normally, K rules are not allowed to contain regular (i.e., not fresh, not +existential) variables in the RHS / requires / ensures clauses which are not +bound in the LHS.

+

However, in certain cases this behavior might be desired, like, for example, +when specifying a macro rule which is to be used in the LHS of other rules. +To allow for such cases, but still be useful and perform the unboundness checks +in regular cases, the unboundVariables attributes allows the user to specify +a comma-separated list of names of variables which can be unbound in the rule.

+

For example, in the macro declaration

+
k
rule cppEnumType => bar(_, scopedEnum() #Or unscopedEnum() ) [unboundVariables(_)] +
+

the declaration unboundVariables(_) allows the rule to pass the unbound +variable checks, and this in turn allows for cppEnumType to be used in +the LHS of a rule to mean the pattern above:

+
k
rule inverseConvertType(cppEnumType, foo((cppEnumType #as T::CPPType => underlyingType(T)))) +
+

The memo attribute

+

The memo attribute is a hint from the user to the backend to memoize a +function. Not all backends support memoization, but when the attribute is used +and the definition is compiled for a memo-supporting backend, then calls to +the function may be cached. At the time of writing, only the Haskell +backend supports memoization.

+

Limitations of memoization with the Haskell backend

+

The Haskell backend will only cache a function call if all arguments are concrete.

+

It is recommended not to memoize recursive functions, as each recursive call +will be stored in the cache, but only the first iteration will be retrieved from +the cache; that is, the cache will be filled with many unreachable +entries. Instead, we recommend to perform a worker-wrapper transformation on +recursive functions, and apply the memo attribute to the wrapper.

+

Warning: A function declared with the memo attribute must not use +uninterpreted functions in the side-condition of any rule. Memoizing such an +impure function is unsound. To see why, consider the following rules:

+
k
syntax Bool ::= impure( Int ) [function] + +syntax Int ::= unsound( Int ) [function, memo] +rule unsound(X:Int) => X +Int 1 requires impure(X) +rule unsound(X:Int) => X requires notBool impure(X) +
+

Because the function impure is not given rules to cover all inputs, unsound +can be memoized incoherently. For example,

+
{unsound(0) #And {impure(0) #Equals true}} #Equals 1
+
+

but

+
{unsound(0) #And {impure(0) #Equals false}} #Equals 0
+
+

The memoized value of unsound(0) would be incoherently determined by which +pattern the backend encounters first.

+

Variable Sort Inference

+

In K, it is not required that users declare the sorts of variables in rules or +in the initial configuration. If the user does not explicitly declare the sort +of a variable somewhere via a cast (see below), the sort of the variable is +inferred from context based on the sort signature of every place the variable +appears in the rule.

+

As an example, consider the rule for addition in IMP:

+
k
syntax Exp ::= Exp "+" Exp | Int + + rule I1 + I2 => I1 +Int I2 +
+

Here +Int is defined in the INT module with the following signature:

+
k
syntax Int ::= Int "+Int" Int [function] +
+

In the rule above, the sort of both I1 and I2 is inferred as Int. This is because +a variable must have the same sort every place it appears within the same rule. +While a variable appearing only on the left-hand-side of the rule could have +sort Exp instead, the same variable appears as a child of +Int, which +constriants the sorts of I1 and I2 more tightly. Since the sort must be a +subsort of Int or equal to Int, and Int has no subsorts, we infer Int +as the sorts of I1 and I2. This means that the above rule will not match +until I1 and I2 become integers (i.e., have already been evaluated).

+

More complex examples are possible, however:

+
k
syntax Exp ::= Exp "+" Int | Int + rule _ + _ => 0 +
+

Here we have two anonymous variables. They do not refer to the same variable +as one another, so they can have different sorts. The right side is constrained +by + to be of sort Int, but the left side could be either Exp or Int. +When this occurs, we have multiple solutions to the sorts of the variables in +the rule. K will only choose solutions which are maximal, however. To be +precise, if two different solutions exist, but the sorts of one solution are +all greater than or equal to the sorts of the other solution, K will discard +the smaller solution. Thus, in the case above, the variable on the left side +of the + is inferred of sort Exp, because the solution (Exp, Int) is +strictly greater than the solution (Int, Int).

+

It is possible, however, for terms to have multiple maximal solutions:

+
k
syntax Exp ::= Exp "+" Int | Int "+" Exp | Int + rule I1 + I2 => 0 +
+

In this example, there is an ambiguous parse. This could parse as either +the first + or the second. In the first case, the maximal solution chosen is +(Exp, Int). In the second, it is (Int, Exp). Neither of these solutions is +greater than the other, so both are allowed by K. As a result, this program +will emit an error because the parse is ambiguous. To pick one solution over +the other, a cast or a prefer or avoid attribute can be used.

+

Casting

+

There are three main types of casts in K: the semantic cast, the strict cast, +and the projection cast.

+

Semantic casts

+

For every sort S declared in your grammar, K will define the following +production for you for use in rules:

+
k
syntax S ::= S ":S" +
+

The meaning of this cast is that the term inside the cast must be less than +or equal to Sort. This can be used to resolve ambiguities, but its principle +purpose is to guide execution by telling K what sort variables must match in +order for the rule to apply. When compiled, it will generate a pattern that +matches on an injection into Sort.

+

Strict casts

+

K also introduces the strict cast:

+
k
syntax S ::= S "::S" +
+

The meaning at runtime is exactly the same as the semantic cast; however, it +restricts the sort of the term inside the cast to exactly Sort. That is +to say, if you use it on something that is a strictly smaller sort, it will +generate a type error. This is useful in certain circumstances to help +disambiguate terms, when a semantic cast would not have resolved the ambiguity. +As such, it is primarily used to solve ambiguities rather than to guide +execution.

+

Projection casts

+

K also introduces the projection cast:

+
k
syntax {S2} S ::= "{" S2 "}" ":>S" +
+

The meaning of this cast at runtime is that if the term inside is of sort +Sort, it should have it injection stripped away and the value inside is +returned as a term of static sort Sort. However, if the term is of a +different sort, it is an error and execution will get stuck. Thus the primary +usefulness of this cast is to cast the return value of a function with a +greater sort down to a strictly smaller sort that you expect the return value +of the function to have. For example:

+
k
syntax Exp ::= foo(Exp) [function] | bar(Int) | Int + rule foo(I:Int) => I + rule bar(I) => bar({foo(I +Int 1)}:>Int) +
+

Here we know that foo(I +Int 1) will return an Int, but the return sort of +foo is Exp. So we project the result into the Int sort so that it can +be placed as the child of a bar.

+

owise and priority attributes.

+

Sometimes, it is simply not convenient to explicitly describe every +single negative case under which a rule should not apply. Instead, +we simply wish to say that a rule should only apply after some other set of +rules have been tried. K introduces two different attributes that can be +added to rules which will automatically generate the necessary matching +conditions in a manner which is performant for concrete execution (indeed, +it generally outperforms during concrete execution code where the conditions +are written explicitly).

+

The first is the owise attribute. Very roughly, rules without an attribute +indicating their priority apply first, followed by rules with the owise +attribute only if all the other rules have been tried and failed. For example, +consider the following function:

+
k
syntax Int ::= foo(Int) [function] +rule foo(0) => 0 +rule foo(_) => 1 [owise] +
+

Here foo(0) is defined explicitly as 0. Any other integer yields the +integer 1. In particular, the second rule above will only be tried after the +first rule has been shown not to apply.

+

This is because the first rule has a lower number assigned for its priority +than the second rule. In practice, each rule in your semantics is implicitly +or explicitly assigned a numerical priority. Rules are tried in increasing +order of priority, starting at zero and trying each increasing numerical value +successively.

+

You can specify the priority of a rule with the priority attribute. For +example, I could equivalently write the second rule above as:

+
k
rule foo(_) => 1 [priority(200)] +
+

The number 200 is not chosen at random. In fact, when you use the owise +attribute, what you are doing is implicitly setting the priority of the rule +to 200. This has a couple of implications:

+
    +
  1. Multiple rules with the owise attribute all have the same priority and thus +can apply in any order.
  2. +
  3. Rules with priority higher than 200 apply after all rules with the +owise attribute have been tried.
  4. +
+

There is one more rule by which priorities are assigned: a rule with no +attributes indicating its priority is assigned the priority 50. Thus, +with each priority explicitly declared, the above example looks like:

+
k
syntax Int ::= foo(Int) [function] +rule foo(0) => 0 [priority(50)] +rule foo(_) => 1 [owise] +
+

One final note: the llvm backend reserves priorities between 50 and 150 +inclusive for certain specific purposes. Because of this, explicit +priorities which are given within this region may not behave precisely as +described above. This is primarily in order that it be possible where necessary +to provide guidance to the pattern matching algorithm when it would otherwise +make bad choices about which rules to try first. You generally should not +give any rule a priority within this region unless you know exactly what the +implications are with respect to how the llvm backend orders matches.

+

Evaluation Strategy

+

strict and seqstrict attributes

+

The strictness attributes allow defining evaluation strategies without having +to explicitly make rules which implement them. This is done by injecting +heating and cooling rules for the subterms. For this to work, you need to +define what a result is for K, by extending the KResult sort.

+

For example:

+
k
syntax AExp ::= Int + | AExp "+" AExp [strict, klabel(addExp)] +
+

This generates two heating rules (where the hole syntaxes "[]" "+" AExp and +AExp "+" "[]" is automatically added to create an evaluation context):

+
k
rule [addExp1-heat]: <k> HOLE:AExp + AE2:AExp => HOLE ~> [] + AE2 ... </k> [heat] +rule [addExp2-heat]: <k> AE1:AExp + HOLE:AExp => HOLE ~> AE1 + [] ... </k> [heat] +
+

And two corresponding cooling rules:

+
k
rule [addExp1-cool]: <k> HOLE:AExp ~> [] + AE2 => HOLE + AE2 ... </k> [cool] +rule [addExp2-cool]: <k> HOLE:AExp ~> AE1 + [] => AE1 + HOLE ... </k> [cool] +
+

Note that the rules are given labels based on the klabel of the production, which +nonterminal is the hole, and whether it's the heating or the cooling rule.

+

You will note that these rules can apply one after another infinitely. In +practice, the KResult sort is used to break this cycle by ensuring that only +terms that are not part of the KResult sort will be heated. The heat and +cool attributes are used to tell the compiler that these are heating and +cooling rules and should be handled in the manner just described. Nothing stops +the user from writing such heating and cooling rules directly if they wish, +although we describe other more convenient syntax for most of the advanced +cases below.

+

One other thing to note is that in the above sentences, HOLE is just a +variable, but it has special meaning in the context of sentences with the +heat or cool attribute. In heating or cooling rules, the variable named +HOLE is considered to be the term being heated or cooled and the compiler +will generate isKResult(HOLE) and notBool isKResult(HOLE) side conditions +appropriately to ensure that the backend does not loop infinitely. The module +BOOL will also be automatically and privately included for semantic +purposes. The syntax for parsing programs will not be affected.

+

In order for this functionality to work, you need to define the KResult sort. +For instance, we tell K that a term is fully evaluated once it becomes an Int +here:

+
k
syntax KResult ::= Int +
+

Note that you can also say that a given expression is only strict only in +specific argument positions. Here we use this to define "short-circuiting" +boolean operators.

+
k
syntax KResult ::= Bool + +syntax BExp ::= Bool + | BExp "||" BExp [strict(1)] + | BExp "&&" BExp [strict(1)] + +rule <k> true || _ => true ... </k> +rule <k> false || REST => REST ... </k> + +rule <k> true && REST => REST ... </k> +rule <k> false && _ => false ... </k> +
+

If you want to force a specific evaluation order of the arguments, you can use +the variant seqstrict to do so. For example, this would make the boolean +operators short-circuit in their second argument first:

+
k
syntax KResult ::= Bool + +syntax BExp ::= Bool + | BExp "||" BExp [seqstrict(2,1)] + | BExp "&&" BExp [seqstrict(2,1)] + +rule <k> _ || true => true ... </k> +rule <k> REST || false => REST ... </k> + +rule <k> REST && true => REST ... </k> +rule <k> _ && false => false ... </k> +
+

This will generate rules like this in the case of _||_ (note that BE1 will +not be heated unless isKResult(BE2) is true, meaning that BE2 must be +evaluated first):

+
k
rule <k> BE1:BExp || HOLE:BExp => HOLE ~> BE1 || [] ... </k> [heat] +rule <k> HOLE:BExp || BE2:BExp => HOLE ~> [] || BE2 ... </k> requires isKResult(BE2) [heat] + +rule <k> HOLE:BExp ~> [] || BE2 => HOLE || BE2 ... </k> [cool] +rule <k> HOLE:BExp ~> BE1 || [] => BE1 || HOLE ... </k> [cool] +
+

Context Declaration

+

Sometimes more advanced evaluation strategies are needed. By default, the +strict and seqstrict attributes are limited in that they cannot describe +the context in which heating or cooling should occur. When this type of +control over the evaluation strategy is required, context sentences can be +used to simplify the process of declaring heating and cooling when it would be +unnecessarily verbose to write heating and cooling rules directly.

+

For example, if the user wants to heat a term if it exists under a foo +constructor if the term to be heated is of sort bar, one might write the +following context (with the optional label):

+
k
context [foo]: foo(HOLE:Bar) +
+

Once again, note that HOLE is just a variable, but one that has special +meaning to the compiler indicating the position in the context that should +be heated or cooled.

+

This will automatically generate the following sentences:

+
k
rule [foo-heat]: <k> foo(HOLE:Bar) => HOLE ~> foo([]) ... </k> [heat] +rule [foo-cool]: <k> HOLE:Bar ~> foo([]) => foo(HOLE) ... </k> [cool] +
+

The user may also write the K cell explicitly in the context declaration +if they want to match on another cell as well, for example:

+
k
context <k> foo(HOLE:Bar) ... </k> <state> .Map </state> +
+

This context will now only heat or cool if the state cell is empty.

+

Side conditions in context declarations

+

The user is allowed to write a side condition in a context declaration, like +so:

+
k
context foo(HOLE:Bar) requires baz(HOLE) +
+

This side condition will be appended verbatim to the heating rule that is +generated, however, it will not affect the cooling rule that is generated:

+
k
rule <k> foo(HOLE:Bar) => HOLE ~> foo([]) ... </k> requires baz(HOLE) [heat] +rule <k> HOLE:Bar ~> foo([]) => foo(HOLE) ... </k> [cool] +
+

Rewrites in context declarations

+

The user can also include exactly one rewrite operation in a context +declaration if that rule rewrites the variable HOLE on the left hand side +to a term containing HOLE on the right hand side. For exampl;e:

+
k
context foo(HOLE:Bar => bar(HOLE)) +
+

In this case, the code generated will be as follows:

+
k
rule <k> foo(HOLE:Bar) => bar(HOLE) ~> foo([]) ... </k> [heat] +rule <k> bar(HOLE:Bar) ~> foo([]) => foo(HOLE) ... </k> [cool] +
+

This can be useful if the user wishes to evaluate a term using a different +set of rules than normal.

+

result attribute

+

Sometimes it is necessary to be able to evaluate a term to a different sort +than KResult. This is done by means of adding the result attribute to +a strict production, a context, or an explicit heating or cooling rule:

+
k
syntax BExp ::= Bool + | BExp "||" BExp [seqstrict(2,1), result(Bool)] +
+

In this case, the sort check used by seqstrict and by the heat and cool +attributes will be isBool instead of isKResult. This particular example +does not really require use of the result attribute, but if the user wishes +to evaluate a term of sort KResult further, the result attribute would be +required.

+

hybrid attribute

+

In certain situations, it is desirable to treat a particular production which +has the strict attribute as a result if the term has had its arguments fully +evaluated. This can be accomplished by means of the hybrid attribute:

+
k
syntax KResult ::= Bool + +syntax BExp ::= Bool + | BExp "||" BExp [strict(1), hybrid] +
+

This attribute is equivalent in this case to the following additional axiom +being added to the definition of isKResult:

+
k
rule isKResult(BE1:BExp || BE2:BExp) => true requires isKResult(BE1) +
+

Sometimes you wish to declare a production hybrid with respect to a predicate +other than isKResult. You can do this by specifying a sort as the body of the +hybrid attribute, e.g.:

+
k
syntax BExp ::= BExp "||" BExp [strict(1), hybrid(Foo)] +
+

generates the rule:

+
k
rule isFoo(BE1:BExp || BE2:BExp) => true requires isFoo(BE1) +
+

Properly speaking, hybrid takes an optional comma-separated list of sort +names. If the list is empty, the attribute is equivalent to hybrid(KResult). +Otherwise, it generates hybrid predicates for exactly the sorts named.

+

Context aliases

+

Sometimes it is necessary to define a fairly complicated evaluation strategy +for a lot of different operators. In this case, the user could simply write +a number of complex context declarations, however, this quickly becomes +tedious. For this purpose, K has a concept called a context alias. A context +alias is a bit like a template for describing contexts. The template can then +be instantiated against particular productions using the strict and +seqstrict attributes.

+

Here is a (simplified) example taken from the K semantics of C++:

+
k
context alias [c]: <k> HERE:K ... </k> <evaluate> false </evaluate> +context alias [c]: <k> HERE:K ... </k> <evaluate> true </evaluate> [result(ExecResult)] + +syntax Expr ::= Expr "=" Init [strict(c; 1)] +
+

This defines the evaluation strategy during the translation phase of a C++ +program for the assignment operator. It is equivalent to writing the following +context declarations:

+
k
context <k> HOLE:Expr = I:Init ... </k> <evaluate> false </evaluate> +context <k> HOLE:Expr = I:Init ... </k> <evaluate> true </evaluate> [result(ExecResult)] +
+

What this is saying is, if the evaluate cell is false, evaluate the term +like normal to a KResult. But if the evaluate cell is true, instead +evaluate it to the ExecResult sort.

+

Essentially, we have given a name to this evaluation strategy in the form of +the rule label on the context alias sentences (in this case, c). We can +then say that we want to use this evaluation strategy to evaluate particular +arguments of particular productions by referring to it by name in a strict +attribute. For example, strict(c) will instantiate these contexts once for +each argument of the production, whereas strict(c; 1) will instantiate it +only for the first argument. The special variable HERE is used to tell the +compiler where you want to place the production that is to be heated or cooled.

+

You can also specify multiple context aliases for different parts of a production, +for example:

+
k
syntax Exp ::= foo(Exp, Exp) [strict(left; 1; right; 2)] +
+

This says that we can evaluate the left and right arguments in either order, but to evaluate +the left using the left context alias and the right using the right context alias.

+

We can also say seqstrict(left; 1; right; 2), in which case we additionally must evaluate +the left argument before the right argument. Note, all strict positions are considered collectively +when determining the evaluation order of seqstrict or the hybrid predicates.

+

A strict attribute with no rule label associated with it is equivalent to +a strict attribute given with the following context alias:

+
k
context alias [default]: <k> HERE:K ... </k> +
+

One syntactic convenience that is provided is that if you wish to declare the following context:

+
k
context foo(HOLE => bar(HOLE)) +
+

you can simply write the following:

+
k
syntax Foo ::= foo(Bar) [strict(alias)] + +context alias [alias]: HERE [context(bar)] +
+

Pattern Matching

+

As Patterns

+

New syntax has been added to K for matching a pattern and binding the resulting +match in its entirety to a variable.

+

The syntax is:

+
Pattern #as V::Var
+
+

In this case, Pattern, including any variables, is matched and the resulting +variables are added to the substitution if matching succeeds. Furthermore, the +term matched by Pattern is added to the substitution as V.

+

This code can also be used outside of any rewrite, in which case matching +occurs as if it appeared on the left hand side, and the right hand side becomes +a variable corresponding to the alias.

+

It is an error to use an as pattern on the right hand side of a rule.

+

Record-like KApply Patterns

+

We have added a syntax for matching on KApply terms which mimics the record +syntax in functional languages. This allows us to more easily express patterns +involving a KApply term in which we don't care about some or most of the +children, without introducing a dependency into the code on the number of +arguments which could be changed by a future refactoring.

+

The syntax is:

+
record(... field1: Pattern1, field2: Pattern2)
+
+

Note that this only applies to productions that are prefix productions. +A prefix production is considered by the implementation to be any production +whose production items match the following regular expression:

+
(Terminal(_)*) Terminal("(")
+(NonTerminal (Terminal(",") NonTerminal)* )?
+Terminal(")")
+
+

In other words, any sequence of terminals followed by an open parenthesis, an +optional comma separated list of non-terminals, and a close parenthesis.

+

If a prefix production has no named nonterminals, a record(...) syntax is +allowed, but in order to reference specific fields, it is necessary to give one +or more of the non-terminals in the production names.

+

Note: because the implementation currently creates one production per possible +set of fields to match on, and because all possible permutations of all +possible subsets of a list of n elements is a number that scales factorially +and reaches over 100 thousand productions at n=8, we currently do not allow +fields to be matched in any order like a true record, but only in the same +order as appears in the production itself.

+

Given that this only reduces the number of productions to the size of the power +set, this will still explode the parsing time if we create large productions of +10 or more fields that all have names. This is something that should probably +be improved, however, productions with that large of an arity are rare, and +thus it has not been viewed as a priority.

+

Or Patterns

+

Sometimes you wish to express that a rule should match if one out of multiple +patterns should match the same subterm. We can now express this in K by means +of using the #Or ML connective on the left hand side of a rule.

+

For example:

+
k
rule foo #Or bar #Or baz => qux +
+

Here any of foo, bar, or baz will match this rule. Note that the behavior is +ill-defined if it is not the case that all the clauses of the or have the same +bound variables.

+

Matching global context in function rules

+

On occasion it is highly desirable to be able to look up information from the +global configuration and match against it when evaluating a function. For this +purpose, we introduce a new syntax for function rules.

+

This syntax allows the user to match on function context from within a +function rule:

+
k
syntax Int ::= foo(Int) [function] + +rule [[ foo(0) => I ]] + <bar> I </bar> + +rule something => foo(0) +
+

This is completely desugared by the K frontend and does not require any special +support in the backend. It is an error to have a rewrite inside function +context, as we do not currently support propagating such changes back into the +global configuration. It is also an error if the context is not at the top +level of a rule body.

+

Desugared code:

+
k
syntax Int ::= foo(Int, GeneratedTopCell) [function] + +rule foo(0, <generatedTop> + <bar> I </bar> + ... + </generatedTop> #as Configuration) => I +rule <generatedTop> + <k> something ... </k> + ... + </generatedTop> #as Configuration + => <generatedTop> + <k> foo(0, Configuration> ... </k> + ... + </generatedTop> +
+

Collection patterns

+

It is allowed to write patterns on the left hand side of rules which refer to +complex terms of sort Map, List, and Set, despite these patterns ostensibly +breaking the rule that terms which are functions should not appear on the left +hand side of rules. Such terms are destructured into pattern matching +operations.

+

The following forms are allowed:

+
// 0 or more elements followed by 0 or 1 variables of sort List followed by
+// 0 or more elements
+ListItem(E1) ListItem(E2) L:List ListItem(E3) ListItem(E4)
+
+// the empty list
+.List
+
+// 0 or more elements in any order plus 0 or 1 variables of sort Set
+// in any order
+SetItem(K1) SetItem(K2) S::Set SetItem(K3) SetItem(K4)
+
+// the empty set
+.Set
+
+// 0 or more elements in any order plus by 0 or 1 variables of sort Map
+// in any order
+K1 |-> E1 K2 |-> E2 M::Map K3 |-> E3 K4 |-> E4
+
+// the empty map
+.Map
+
+

Here K1, K2, K3, K4 etc can be any pattern except a pattern containing both +function symbols and unbound variables. An unbound variable is a variable whose +binding cannot be determined by means of decomposing non-set-or-map patterns or +map elements whose keys contain no unbound variables.

+

This is determined recursively, ie, the term K1 |-> E2 E2 |-> E3 E3 |-> E4 is +considered to contain no unbound variables.

+

Note that in the pattern K1 |-> E2 K3 |-> E4 E4 |-> E5, K1 and K3 are +unbound, but E4 is bound because it is bound by deconstructing the key E3, even +though E3 is itself unbound.

+

In the above examples, E1, E2, E3, and E4 can be any pattern that is normally +allowed on the lhs of a rule.

+

When a map or set key contains function symbols, we know that the variables in +that key are bound (because of the above restriction), so it is possible to +evaluate the function to a concrete term prior to performing the lookup.

+

Indeed, this is the precise semantics which occurs; the function is evaluated +and the result is looked up in the collection.

+

For example:

+
k
syntax Int ::= f(Int) [function] +rule f(I:Int) => I +Int 1 +rule <k> I:Int => . ... </k> <state> ... SetItem(f(I)) ... </state> +
+

This will rewrite I to . if and only if the state cell contains +I +Int 1.

+

Note that in the case of Set and Map, one guarantee is that K1, K2, K3, and K4 +represent /distinct/ elements. Pattern matching fails if the correct number of +distinct elements cannot be found.

+

Matching on cell fragments

+

K allows matching fragments of the configuration and using them to construct +terms and use as function parameters.

+
k
configuration <t> + <k> #init ~> #collectOdd ~> $PGM </k> + <fs> + <f multiplicity="*" type="Set"> 1 </f> + </fs> + </t> +
+

The #collectOdd construct grabs the entire content of the <fs> cell. +We may also match on only a portion of its content. Note that the fragment +must be wrapped in a <f> cell at the call site.

+
k
syntax KItem ::= "#collectOdd" +rule <k> #collectOdd => collectOdd(<fs> Fs </fs>) ... </k> + <fs> Fs </fs> +
+

The collectOdd function collects the items it needs

+
k
syntax Set ::= collectOdd(FsCell) [function] +rule collectOdd(<fs> <f> I </f> REST </fs>) => SetItem(I) collectOdd(<fs> REST </fs>) requires I %Int 2 ==Int 1 +rule collectOdd(<fs> <f> I </f> REST </fs>) => collectOdd(<fs> REST </fs>) requires I %Int 2 ==Int 0 +rule collectOdd(<fs> .Bag </fs>) => .Set +
+

all-path and one-path attributes to distinguish reachability claims

+

As the Haskell backend can handle both one-path and all-path reachability +claims, but both these are encoded as rewrite rules in K, these attributes can +be used to clarify what kind of claim a rule is.

+

In addition of being able to annotate a rule with one of them +(if annotating with more at the same time, only one of them would be chosen), +one can also annotate whole modules, to give a default claim type for all rules +in that module.

+

Additionally, the Haskell backend introduces an extra command line option +for the K frontend, --default-claim-type, with possible values +all-path and one-path to allow choosing a default type for all +claims.

+

Set Variables

+

Motivation

+

Set variables were introduced as part of Matching Mu Logic, the mathematical +foundations for K. In Matching Mu Logic, terms evaluate to sets of values. +This is useful for both capturing partiality (as in 3/0) and capturing +non-determinism (as in 3 #Or 5). Consequently, symbol interpretation is +extended to have a collective interpretation over sets of input values.

+

Usually, K rules are given using regular variables, which expect that the term +they match is both defined and has a unique interpretation.

+

However, it is sometimes useful to have simplification rules which work over +any kind of pattern, be it undefined or non-deterministic. This behavior can be +achieved by using set variables to stand for any kind of pattern.

+

Syntax

+

Any variable prefixed by @ will be considered a set variable.

+

Example

+

Below is a simplification rule which motivated this extension:

+
  rule #Ceil(@I1:Int /Int @I2:Int) =>
+    {(@I2 =/=Int 0) #Equals true} #And #Ceil(@I1) #And #Ceil(@I2)
+    [anywhere]
+
+

This rule basically says that @I1:Int /Int @I2:Int is defined if @I1 and +@I2 are defined and @I2 is not 0. Using sets variables here is important as +it allows the simplification rule to apply any symbolic patterns, without +caring whether they are defined or not.

+

This allows simplifying the expression #Ceil((A:Int /Int B:Int) / C:Int) to:

+
{(C =/=Int 0) #Equals true} #And #Ceil(C) #And ({(B =/=Int 0) #Equals true}
+#And #Ceil(B) #And #Ceil(A)`
+
+

See kframework/kore#729 for +more details.

+

SMT Translation

+

K makes queries to an SMT solver (Z3) to discharge proof obligations when doing +symbolic execution. You can control how these queries are made using the +attributes smtlib, smt-hook, and smt-lemma on declared productions. +These attributes guide the prover when it tries to apply rules to discharge a +proof obligation.

+
    +
  • smt-hook(...) allows you to specify a term in SMTLIB2 format which should +be used to encode that production, and assumes that all symbols appearing in +the term are already declared by the SMT solver.
  • +
  • smtlib(...) allows you to declare a new SMT symbol to be used when that +production is sent to Z3, and gives it uninterpreted function semantics.
  • +
  • smt-lemma can be applied to a rule to encode it as a conditional equality +when sending queries to Z3. A rule rule LHS => RHS requires REQ will be +encoded as the conditional equality (=> REQ (= (LHS RHS)). Every symbol +present in the rule must have an smt-hook(...) or smtlib(...) attribute.
  • +
+
k
syntax Int ::= "~Int" Int [function, klabel(~Int_), symbol, + smtlib(notInt)] + | Int "^%Int" Int Int [function, klabel(_^%Int__), symbol, + smt-hook((mod (^ #1 #2) #3))] +
+

In the example above, we declare two productions ~Int_ and _^%Int__, and +tell the SMT solver to:

+
    +
  • use uninterpreted function semantics for ~Int_ via SMTLIB2 symbol +notInt, and
  • +
  • use the SMTLIB2 term (mod (^ #1 #2) #3) (where #N marks the Nth +production non-terminal argument positions) for _^%Int__, where mod and +^ already are declared by the SMT solver.
  • +
+

Caution

+

Set variables are currently only supported by the Haskell backend. +The use of rules with set variables should be sound for all other backends +which just execute by rewriting, however it might not be safe for backends +which want to guarantee coverage.

+

Variables occurring only in the RHS of a rule

+

This section presents possible scenarios requiring variables to only appear in +the RHS of a rule.

+

Summary

+

Except for ? variables and ! (fresh) variables, which are +required to only appear in the RHS of a rule, all other variables must +also appear in the LHS of a rule. This restriction also applies to anonymous +variables; in particular, for claims, ?_ (not _) should be used in the RHS +to indicate that something changes but we don't care to what value.

+

To support specifying random-like behavior, the above restriction can be relaxed +by annotating a rule with the unboundVariables attribute whenever the rule +intentionally contains regular variables only occurring in the RHS.

+

Introduction

+

K uses question mark variables of the form ?X to refer to +existential variables, and uses ensures to specify logical constraints on +those variables. +These variables are only allowed to appear in the RHS of a K rule.

+

If the rules represent rewrite (semantic) steps or verification claims, +then the ? variables are existentially quantified at the top of the RHS; +otherwise, if they represent equations, the ? variables are quantified at the +top of the entire rule.

+

Note that when both ?-variables and regular variables are present, +regular variables are (implicitly) universally quantified on top of the rule +(already containing the existential quantifications). +This essentially makes all ? variables depend on all regular variables.

+

All examples below are intended more for program verification / +symbolic execution, and thus concrete implementations might choose to ignore +them altogether or to provide ad-hoc implementations for them.

+

Example: Verification claims

+

Consider the following definition of a (transition) system:

+
k
module A + rule foo => true + rule bar => true + rule bar => false +endmodule +
+

Consider also, the following specification of claims about the definition above:

+
k
module A-SPEC + rule [s1]: foo => ?X:Bool + rule [s2]: foo => X:Bool [unboundVariables(X)] + rule [s3]: bar => ?X:Bool + rule [s4]: bar => X:Bool [unboundVariables(X)] +endmodule +
+
One-path interpretation
+
    +
  • (s1) says that there exists a path from foo to some boolean, which is +satisfied easily using the foo => true rule
  • +
  • (s3) says the same thing about bar and can be satisfied by either of +bar => true and bar => false rules
  • +
  • (s2) and (s4) can be better understood by replacing them with instances for +each element of type Bool, which can be interpreted that +both true and false are reachable from foo for (s2), or bar for (s4), +respectively. +
      +
    • (s2) cannot be verified as we cannot find a path from foo to false.
    • +
    • (s4) can be verified by using bar => true to show true is reachable and +bar => false to achieve the same thing for false
    • +
    +
  • +
+
All-path interpretation
+
    +
  • +

    (s1) says that all paths from foo will reach some boolean, which is +satisfied by the foo => true rule and the lack of other rules for foo

    +
  • +
  • +

    (s3) says the same thing about bar and can be satisfied by checking that +both bar => true and bar => false end in a boolean, and there are no +other rules for bar

    +
  • +
  • +

    (s2) and (s4) can be better understood by replacing them with instances for +each element of type Bool, which can be interpreted that +both true and false are reachable in all paths originating in +foo for (s2), or bar for (s4), respectively. +This is a very strong claim, requiring that all paths originating in +foo (bar) pass through both true and false, +so neither (s2) nor (s4) can be verified.

    +

    Interestingly enough, adding a rule like false => true would make both +(s2) and (s4) hold.

    +
  • +
+

Example: Random Number Construct rand()

+

The random number construct rand() is a language construct which could be +easily conceived to be part of the syntax of a programming language:

+
k
Exp ::= "rand" "(" ")" +
+

The intended semantics of rand() is that it can rewrite to any integer in +a single step. This could be expressed as the following following infinitely +many rules.

+
k
rule rand() => 0 +rule rand() => 1 +rule rand() => 2 + ... ... +rule rand() => (-1) +rule rand() => (-2) + ... ... +
+

Since we need an instance of the rule for every integer, one could summarize +the above infinitely many rules with the rule

+
rule rand() => I:Int [unboundVariables(I)]
+
+

Note that I occurs only in the RHS in the rule above, and thus the rule +needs the unboundVariables(I) attribute to signal that this is intentionally.

+

One can define variants of rand() by further constraining the output variable +as a precondition to the rule.

+
Rand-like examples
+
    +
  1. +

    randBounded(M,N) can rewrite to any integer between M and N

    +
    k
    syntax Exp ::= randBounded(Int, Int) +rule randBounded(M, N) => I + requires M <=Int I andBool I <=Int N + [unboundVariables(I)] +
    +
  2. +
  3. +

    randInList(Is) takes a list Is of items +and can rewrite in one step to any item in Is.

    +
    k
    syntax Exp ::= randInList (List) +rule randInList(Is) => I + requires I inList Is + [unboundVariables(I)] +
    +
  4. +
  5. +

    randNotInList(Is) takes a list Is of items +and can rewrite in one step to any item not in Is.

    +
    k
    syntax Exp ::= randNotInList (List) +rule randNotInList(Is) => I + requires notBool(I inList Is) + [unboundVariables(I)] +
    +
  6. +
  7. +

    randPrime(), can rewrite to any prime number.

    +
    k
    syntax Exp ::= randPrime () +rule randPrime() => X:Int + requires isPrime(X) + [unboundVariables(X)] +
    +

    where isPrime(_) is a predicate that can be defined in the usual way.

    +
  8. +
+

Note 1: all above are not function symbols, but language constructs.

+

Note 2: Currently the frontend does not allow rules with universally quantified +variables in the RHS which are not bound in the LHS.

+

Note 3. Allowing these rules in a concrete execution engine would require an +algorithm for generating concrete instances for such variables, satisfying the +given constraints; thus the unboundVariables attribute serves two purposes:

+
    +
  • to allow such rules to pass the variable checks, and
  • +
  • to signal (concrete execution) backends that specialized algorithm would be +needed to instantiate these variables.
  • +
+

Example: Fresh Integer Construct fresh(Is)

+

The fresh integer construct fresh(Is) is a language construct.

+
Exp ::= ... | "fresh" "(" List{Int} ")"
+
+

The intended semantics of fresh(Is) is that it can always rewrite to an +integer that in not in Is.

+

Note that fresh(Is) and randNotInList(Is) are different; the former +does not need to be able to rewrite to every integers not in Is, +while the latter requires so.

+

For example, it is correct to implement fresh(Is) so it always returns the +smallest positive integer that is not in Is, but same implementation for +randNotInList(Is) might be considered inadequate. +In other words, there exist multiple correct implementations of fresh(Is), +some of which may be deterministic, but there only exists a unique +implementation of randNotInList(Is). +Finally, note that randNotInList(Is) is a correct implementation +for fresh(Is); Hence, concrete execution engines can choose to handle +such rules accordingly.

+

We use the following K syntax to define fresh(Is)

+
k
syntax Exp ::= fresh (List{Int}) +rule fresh(Is:List{Int}) => ?I:Int + ensures notBool (?I inList{Int} Is) +
+

A variant of this would be a choiceInList(Is) language construct which would +choose some number from a list:

+
k
syntax Exp ::= choiceInList (List{Int}) +rule choiceInList(Is:List{Int}) => ?I:Int + ensures ?I inList{Int} Is +
+

Note: This definition is different from one using a ! variable to indicate +freshness because using ! is just syntactic sugar for generating globally +unique instances and relies on a special configuration cell, and cannot be +constrained, while the fresh described here is local and can be constrained. +While the first is more appropriate for concrete execution, this might be +better for symbolic execution / program verification.

+

Example: Arbitrary Number (Unspecific Function) arb()

+

The function arb() is not a PL construct, but a mathematical function. +Therefore, its definition should not be interpreted as an execution step, but +rather as an equality.

+

The intended semantics of arb() is that it is an unspecified nullary function. +The exact return value of arb() is unspecified in the semantics but up to the +implementations. +However, being a mathematical function, arb() must return the same value in +any one implementation.

+

We do not need special frontend syntax to define arb(). +We only need to define it in the usual way as a function +(instead of a language construct), and provide no axioms for it. +The total attribute ensures that the function is total, i.e., +that it evaluates to precisely one value for each input.

+
Variants
+

There are many variants of arb(). For example, arbInList(Is) is +an unspecified function whose return value must be an element from Is.

+

Note that arbInList(Is) is different from choiceInList(Is), because +choiceInList(Is) transitions to an integer in Is (could be a different one +each time it is used), while arbInList(Is) is equal to a (fixed) +integer not in Is.

+

W.r.t. the arb variants, we can use ? variables and the function +annotation to signal that we're defining a function and the value of the +function is fixed, but non-determinate.

+
k
syntax Int ::= arbInList(List{Int}) [function] +rule arbInList(Is:List{Int}) => ?I:Int + ensures ?I inList{Int} Is +
+

If elimination of existentials in equational rules is needed, one possible +approach would be through Skolemization, +i.e., replacing the ? variable with a new uninterpreted function depending +on the regular variables present in the function.

+

Example: Interval (Non-function Symbols) interval()

+

The symbol interval(M,N) is not a PL construct, nor a function in the +first-order sense, but a proper matching-logic symbol, whose interpretation is +in the powerset of its domain. +Its axioms will not use rewrites but equalities.

+

The intended semantics of interval(M,N) is that it equals the set of +integers that are larger than or equal to M and smaller than or equal to N.

+

Since expressing the axiom for interval requires an an existential +quantification on the right-hand-side, thus making it a non-total symbol +defined through an equation, using ? variables might be confusing since their +usage would be different from that presented in the previous sections.

+

Hence, the proposal to support this would be to write this as a proper ML rule. +A possible syntax for this purpose would be:

+
eq  interval(M,N)
+    ==
+    #Exists X:Int .
+        (X:Int #And { X >=Int M #Equals true } #And { X <=Int N #Equals true })
+
+

Additionally, the symbol declaration would require a special attribute to +signal the fact that it is not a constructor but a defined symbol.

+

Since this feature is not clearly needed by K users at the moment, it is only +presented here as an example; its implementation will be postponed for such time +when its usefulness becomes apparent.

+

Parser Generation

+

In addition to on-the-fly parser generation using kast, K is capable of +ahead-of-time parser generation of LR(1) or GLR parsers using Flex and Bison. +This can be done one of two different ways.

+
    +
  1. You can explicitly request for a particular parser to be generated by +invoking kast --gen-parser <outputFile> or +kast --gen-glr-parser <outputFile> respectively. kast will then create a +parser based on the same command line flags that govern on-the-fly parsing, +like -s to specify the starting sort, and -m to specify the module to +parse under. By default, this generates a parser for the sort of the $PGM +configuration variable in the main syntax module of the definition.
  2. +
  3. You can request that a specific set of parsers be generated for all the +configuration variables of your definition by passing the +--gen-bison-parser or --gen-glr-bison-parser flags to kompile. +kompile will decide the sorts to use as start symbols based on the sorts +in the configuration declaration for the configuration variables. The $PGM +configuration variable will be generated based on the main syntax module +of the definition. The user must explicitly annotate the configuration +declaration with the other modules to use to parse the other configuration +variables as attributes. For example, if I have the following cell in the +configuration declaration: <cell> foo($FOO:Foo, $BAR:Bar) </cell>, +One might annotate it with the attribute pair parser="FOO, TEST; BAR, TEST2" +to indicate that configuration variable $FOO should be parsed in the +TEST module, and configuration variable $BAR should be parsed in the +TEST2 module. If the user forgets to annotate the declaration with the +parser attribute, only the $PGM parser will be generated.
  4. +
+

Bison-generated parsers are extremely fast compared to kast, but they have +some important limitations:

+
    +
  • Bison parsers will always output Kore. You can then pass the resulting AST +directly to llvm-krun or kore-exec and bypass the krun frontend, making +them very fast, but lower-level.
  • +
  • Bison parsers do not yet support macros. This may change in a future release. +Note that you can use anywhere rules instead of macros in most cases to get +around this limitation, although they will not benefit from unparsing via the +alias attribute.
  • +
  • Obligation falls on the user to ensure that the grammar they write is LR(1) +if they choose to use LR(1) parsing. If this does not happen, the parser +generated will have shift/reduce or reduce/reduce conflicts and the parser +may behave differently than kast would (kast is a GLL parser, ie, it +is based on LL parsers and parses all unambiguous context-free grammars). +K provides an attribute, not-lr1, which can be applied to modules known to +not be LR(1), and will trigger a warning if the user attempts to generate an +LR(1) parser which recursively imports that module.
  • +
  • If you are using LR(1) based parsing, the prefer and avoid attributes are +ignored. It is only possible to implement these attributes by means of +generalized LL or LR parsing and a postprocessing on the AST to remove the +undesirable ambiguity.
  • +
  • Obligation falls on the user to ensure that the grammar they write has as +few conflicts as possible if they are using GLR parsing. Bison's GLR support +is quite primitive, and in the worst case it can use exponential space and +time to parse a program, which generally leads the generated parser to report +"memory exhausted", indicating that the parse could not be completed within +the stack space allocated by Bison. It's best to ensure that the grammar is +as close to LR(1) as possible and only utilizes conflicts where absolutely +necessary. One tool that can be used to facilitate this is to pass +--bison-lists to kompile. This will disable support for the List{Sort} +syntax production, and it will make NeList{Sort} left associative, but the +resulting productions generated for NeList{Sort} will be LR(1) and use bounded +stack space.
  • +
  • If the grammar you are parsing is context-sensitive (for example, because +it requires a symbol table to parse), one thing you can do to make this +language parse in K is to implement the language as an ambiguous grammar. +Bison's GLR parser will generate an amb production that is parametric in +the sort of the ambiguity. You can then import the K-AMBIGUITIES module +and use rewriting to resolve the ambiguities using whatever preprocessing +mechanisms you prefer.
  • +
+

Location Information

+

K is able to insert file, line, and column metadata into the parse tree on a +per-sort basis when parsing using a bison-generated parser. To enable this, +mark the sort with the locations attribute.

+
k
syntax Exp [locations] + syntax Exp ::= Exp "/" Exp | Int +
+

K implicitly wraps productions of these sorts in a #location term (see the +K-LOCATIONS module in kast.md). The metadata can thus be accessed with +ordinary rewrite rules:

+
k
rule #location(_ / 0, File, StartLine, _StartColumn, _EndLine, _EndColumn) => + "Error: Division by zero at " +String File +String ":" Int2String(StartLine) +
+

Sometimes it is desirable to allow code to be written in a file which +overwrites the current location information provided by the parser. This can be +done via a combination of the #LineMarker sort and the --bison-file flag to +the parser generator. If you declare a production of sort #LineMarker which +contains a regular expression terminal, this will be treated as a +line marker by the bison parser. The user will then be expected to provide +an implementation of the parser for the line marker in C. The function expected +by the parser has the signature void line_marker(char *, yyscan_t), where +yyscan_t is a +reentrant flex scanner. +The string value of the line marker token as specified by your regular +expression can be found in the first parameter of the function, and you can +set the line number used by the scanner using yyset_lineno(int, yyscan_t). If +you declare the variable extern char *filename, you can also set the current +file name by writing a malloc'd, zero-terminated string to that variable.

+

Unparsing

+

A number of factors go into how terms are unparsed in K. Here we describe some +of the features the user can use to control how unparsing happens.

+

Brackets

+

One of the phases that the unparser goes through is to insert productions +tagged with the bracket attribute where it believes this is necessary +in order to create a correct string that will be parsed back into the original +AST. The most common case of this is in expression grammars. For example, +consider the following grammar:

+
k
syntax Exp ::= Int + | Exp "*" Exp + > Exp "+" Exp +
+

Here we have declared that expressions can contain integer addition and +multiplication, and that multiplication binds tighter than addition. As a +result, when writing a program, if we want to write an expression that first +applies addition, then multiplication, we must use brackets: (1 + 2) * 3. +Similarly, if we have such an AST, we must insert brackets into the AST +in order to faithfully unparse the term in a manner that will be parsed back +into the same ast, because if we do not, we end up unparsing the term as +1 + 2 * 3, which will be parsed back as 1 + (2 * 3) because of the priority +declaration in the grammar.

+

You can control how the unparser will insert such brackets by adding a +production with the bracket attribute and the correct sort. For example, if, +instead of parentheses, you want to use curly braces, you could write:

+
k
syntax Exp ::= "{" Exp "}" [bracket] +
+

This would signal to the unparser how brackets should look for terms of sort +Exp, and it will use this syntax when unparsing terms of sort Exp.

+

Commutative collections

+

One thing that K will do (unless you pass the --no-sort-collections flag to +krun) is to sort associative, commutative collections (such as Set and Map) +alphanumerically. For example, if I have a collection whose keys are sort Id +and they have the values a, b, c, and d, then unparsing will always print +first the key a, then b, then c, then d, because this is the alphabetic order +of these keys when unparsed.

+

Furthermore, K will sort numeric keys numerically. For example, if I have a +collection whose keys are 1, 2, 5, 10, 30, it will first display 1, then 2, +then 5, then 10, then 30, because it will sort these keys numerically. Note +that this is different than an alphabetic sort, which would sort them as +1, 10, 2, 30, 5. We believe the former is more intuitive to users.

+

Substitution filtering

+

K will remove substitution terms corresponding to anonymous variables when +using the --pattern flag if those anonymous variables provide no information +about the named variables in your serach pattern. You can disable this behavior +by passing --no-substitution-filtering to krun. When this flag is not passed, +and you are using the Haskell backend, any equality in a substitution (ie, an +#Equals under an #And under an #Or), will be hidden from the user if the +left hand side is a variable that was anonymous in the --pattern passed by +the user, unless that variable appears elsewhere in the substitution. If you +want to see that variable in the substitution, you can either disable this +filtering, or give that variable a name in the original search pattern.

+

Variable alpha renaming

+

K will automatically rename variables that appear in the output configuration. +Similar to commutative collections, this is done to normalize the resulting +configuration so that equivalent configurations will be printed identically +regardless of how they happen to be reached. This pass can be disabled by +passing --no-alpha-renaming to krun.

+

Macro expansion

+

K will apply macros in reverse on the output configuration if the macro was +created with the alias or alias-rec attribute. See the section on macro +expansion for more details.

+

Formatting

+

format attribute

+

K allows you to control how terms are unparsed using the format attribute. +By default, a domain value is unparsed by printing its string value verbatim, +and an application pattern is unparsed by printing its terminals and children +in the sequence implied by its concrete syntax, separated by spaces. However, +K gives you complete control over how you want to unparse the symbol.

+

A format attribute is a string containing zero or more escape sequences that +tell K how to unparse the symbol. Escape sequences begin with a '%' and are +followed by either an integer, or a single non-digit character. Below is a +list of escape sequences recognized by the formatter:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Escape SequenceMeaning
nInsert '\n' followed by the current indentation level
iIncrease the current indentation level by 1
dDecrease the current indentation level by 1
cMove to the next color in the list of colors for this production
rReset color to the default foreground color for the terminal (See below for more information on how colors work)
an integerPrint a terminal or nonterminal from the production (See below for more information)
any other charPrint that character verbatim
+

Using the integer escape sequence

+

In the integer escape sequence %a, the integer a is treated as a 1-based +index into the terminals and nonterminals of the production.

+
    +
  • +

    If the offset refers to a terminal, move to the next color in the list of +colors for this production, print the value of that terminal, then reset the +color to the default foreground color for the terminal.

    +
  • +
  • +

    If the offset refers to a regular expression terminal, it is an error.

    +
  • +
  • +

    If the offset refers to a nonterminal, print the unparsed representation of +the corresponding child of the current term.

    +
  • +
+

color and colors attributes

+

K allows you to take advantage of ANSI terminal codes for foreground color +in order to colorize output pretty-printed by the unparser. This is controlled +via the color and colors attributes of productions. These attributes +combine with the format attribute to control how a term is colorized.

+

The first thing to understand about how colorization works is that the color +and colors attributes are used to construct a list of colors associated +with each production, and the format attribute then uses that list to choose +the color for each part of the production. For more information on how the +format attribute chooses a color from the list, see above, but essentially, +each terminal or %c in the format attribute advances the pointer in the list +by one element, and terminals and %r reset the current color to the default +foreground color of the terminal afterwards.

+

There are two ways you can construct a list of colors associated with a +production:

+
    +
  • +

    The color attribute creates the entire list all with the same color, as +specified by the value of the attribute. When combined with the default format +attribute, this will color all the terminals in that production that color, but +more advanced techniques can be used as well.

    +
  • +
  • +

    The colors attribute creates the list from a manual, comma-separated list +of colors. The attribute is invalid if the length of the list is not equal to +the number of terminals in the production plus the number of %c substrings in +the format attribute.

    +
  • +
+

Attributes Reference

+

Attribute Syntax Overview

+

In K, many different syntactic categories accept an optional trailing list of +keywords known as attributes. Attribute lists have two different syntaxes, +depending on where they occur. Each attribute also has a type which describes +where it may occur.

+

The first syntax is a square-bracketed ([]) list of words. This syntax is +available for following attribute types:

+
    +
  1. module attributes - may appear immediately after the module keyword
  2. +
  3. sort attributes - may appear immediately after a sort declaration
  4. +
  5. production attributes - may appear immediately after a BNF production +alternative
  6. +
  7. rule attributes - may appear immediately after a rule
  8. +
  9. context attributes - may appear immediately after a context or context +alias
  10. +
  11. context alias attributes - may appear immediately after a context alias
  12. +
  13. claim attributes - may appear immediately after a claim
  14. +
+

The second syntax is the XML attribute syntax, i.e., a space delemited list of +key-and-quoted-value pairs appearing inside the start tag of an XML element: +<element key1="value" key2="value2" ... > </element>. This syntax is +available for the following attribute types:

+
    +
  1. cell attributes - may appear inside of the cell start tag in +configuration declarations
  2. +
+

Unrecognized attributes are reported as an error. When we talk about +the type of an attribute, we mean a syntactic category to which an attribute +can be attached where the attribute has some semantic effect.

+

Attribute Index

+

We now provide an index of available attributes organized alphabetically with a +brief description of each. Note that the same attribute may appear in the index +multiple times to indicate its effect in different contexts or with/without +arguments. A legend describing how to interpret the index follows.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
NameTypeBackendReference
alias-recprodallMacros and Aliases
aliasprodallMacros and Aliases
all-pathclaimhaskellall-path and one-path attributes to distinguish reachability claims
anywhereruleallanywhere rules
applyPriority(_)prodallSymbol priority and associativity
avoidprodallSymbol priority and associativity
binderprodallNo reference yet.
bracketprodallParametric productions and bracket attributes
color(_)prodallcolor and colors attributes
colors(_)prodallcolor and colors attributes
concretemodllvmsymbolic and concrete attribute
concrete(_)rulehaskellconcrete and symbolic attributes (Haskell backend)
concreterulehaskellconcrete and symbolic attributes (Haskell backend)
context(_)aliasallContext aliases
exit = ""cellallexit attribute
formatprodallformat attribute
freshGeneratorprodallfreshGenerator attribute
functionprodallfunction and total attributes
group(_)allallSymbol priority and associativity
hook(_)prodallNo reference yet
hybrid(_)prodallhybrid attribute
hybridprodallhybrid attribute
klabel(_)prodallklabel(_) and symbol attributes
latex(_)prodallNo reference yet
leftprodallSymbol priority and associativity
locationssortallLocation Information
macro-recprodallMacros and Aliases
macroprodallMacros and Aliases
memorulehaskellThe memo attribute
multiplicity = "_"cellallCollection Cells: multiplicity and type attributes
non-assocprodallSymbol priority and associativity
one-pathclaimhaskellall-path and one-path attributes to distinguish reachability claims
owiseruleallowise and priority attributes
prec(_)tokenallprec attribute
preferprodallSymbol priority and associativity
priority(_)ruleallowise and priority attributes
privatemodallprivate attribute
privateprodallpublic and private attribute
publicmodallNo reference yet.
publicprodallpublic and private attribute
result(_)ctxtallresult attribute
result(_)ruleallresult attribute
rightprodallSymbol priority and associativity
seqstrict(_)prodallstrict and seqstrict attributes
seqstrictprodallstrict and seqstrict attributes
simplificationrulehaskellsimplification attribute (Haskell backend)
simplification(_)rulehaskellsimplification attribute (Haskell backend)
smt-hook(_)prodhaskellSMT Translation
smtlib(_)prodhaskellSMT Translation
smt-lemmarulehaskellSMT Translation
strictprodallstrict and seqstrict attributes
strict(_)prodallstrict and seqstrict attributes
symbolicmodhaskellsymbolic and concrete attribute
symbolicrulehaskellconcrete and symbolic attributes (Haskell backend)
symbolic(_)rulehaskellconcrete and symbolic attributes (Haskell backend)
symbolprodallklabel(_) and symbol attributes
tokenprodalltoken attribute
tokensortalltoken attribute
totalprodallfunction and total attributes
trustedclaimhaskelltrusted attribute
type = "_"cellallCollection Cells: multiplicity and type attributes
unboundVariables(_)ruleallThe unboundVariables attribute
unusedprodallunused attribute
kastmodallSpecify that this module should only be included in KAST backends (Java backend).
koremodallSpecify that this module should only be included in Kore backends (Haskell/LLVM backend).
concretemodallSpecify that this module should only be included in concrete backends (LLVM backend).
symbolicmodallSpecify that this module should only be included in symbolic backends (Haskell/Java backend).
stream = "_"cellallSpecify that this cell should be hooked up to a stream, either stdin, stdout, or stderr.
+

Internal Attribute Index

+

Some attributes should not generally appear in user code, except in some +unusual or complex examples. Such attributes are typically generated by the +compiler and used internally. We list these attributes below as a reference for +interested readers:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
NameTypeBackendReference
assocprodallassoc, comm, idem and unit attributes
commprodallassoc, comm, idem and unit attributes
digestmodallContains the hash of the textual contents of the module.
idemprodallassoc, comm, idem and unit attributes
unitprodallassoc, comm, idem and unit attributes
userListprodallIdentifies the desugared form of Lst ::= List{Elm,"delim"}
predicateprodallSpecifies the sort of a predicate label
elementprodallSpecifies the label of the elements in a list
bracketLabelprodallKeep track of the label of a bracket production since it can't have a klabel
injectiveprodallLabel a given production as injective (unique output for each input)
internalprodallProduction is reserved for internal use by the compiler
coolruleallstrict and seqstrict attributes
heatruleallstrict and seqstrict attributes
+

Index Legend

+
    +
  • +

    Name - the attribute's name (optionally followed by an underscore _ to indicate the attribute takes arguments)

    +
  • +
  • +

    Type - the syntactic categories where this attribute is not ignored; +the possible values are the types mentioned above or shorthands:

    +
      +
    1. all - short for any type except cell
    2. +
    3. mod - short for module
    4. +
    5. sort
    6. +
    7. prod - short for production
    8. +
    9. rule
    10. +
    11. ctxt - short for context or context alias
    12. +
    13. claim
    14. +
    15. cell
    16. +
    +
  • +
  • +

    Backend - the backends that do not ignore this attribute; possible values:

    +
      +
    1. all - all backends
    2. +
    3. llvm - the LLVM backend
    4. +
    5. haskell - the Haskell backend
    6. +
    +
  • +
  • +

    Effect - the attribute's effect (when it applies)

    +
  • +
+

Pending Documentation

+

Backend features not yet given documentation:

+
    +
  • Parser of KORE terms and definitions
  • +
  • Term representation of K terms
  • +
  • Hooked sorts and symbols
  • +
  • Substituting a substitution into the RHS of a rule +
      +
    • domain values
    • +
    • functions
    • +
    • variables
    • +
    • symbols
    • +
    • polymorphism
    • +
    • hooks
    • +
    • injection compaction
    • +
    • overload compaction
    • +
    +
  • +
  • Pattern Matching / Unification of subject and LHS of rule +
      +
    • domain values
    • +
    • symbols
    • +
    • side conditions
    • +
    • and/or patterns
    • +
    • list patterns
    • +
    • nonlinear variables
    • +
    • map/set patterns +
        +
      • deterministic
      • +
      • nondeterministic
      • +
      +
    • +
    • modulo injections
    • +
    • modulo overloads
    • +
    +
  • +
  • Stepping +
      +
    • initialization
    • +
    • termination
    • +
    +
  • +
  • Print kore terms
  • +
  • Equality/comparison of terms
  • +
  • Owise rules
  • +
  • Strategy #STUCK axiom
  • +
  • User substitution +
      +
    • binders
    • +
    • kvar
    • +
    +
  • +
+

To get a complete list of hooks supported by K, you can run:

+
grep -P -R "(?<=[^-])hook\([^)]*\)" k-distribution/include/kframework/builtin/ \
+     --include "*.k" -ho | \
+sed 's/hook(//' | sed 's/)//' | sort | uniq | grep -v org.kframework
+
+

All of these hooks will also eventually need documentation.

+
+
+ + +
+ +
+
+ + K User Manual + +
+
+ + Introduction + + +
+
+ + Introduction to K + + +
+
+ + Module Declaration + + +
+
+ + Syntax Declaration + + +
+
+ + Configuration Declaration + + +
+
+ + Rule Declaration + + +
+
+ + Evaluation Strategy + + +
+
+ + Pattern Matching + +
+
+ + Set Variables + + +
+
+ + Variables occurring only in the RHS of a rule + + +
+ +
+
+
+ + Unparsing + + +
+
+ + Attributes Reference + + +
+ +
+
+ +
+ +
+
+ +
+
+ + + + + + + + + + + + diff --git a/editor_support/index.html b/editor_support/index.html new file mode 100644 index 00000000000..7978e8eb736 --- /dev/null +++ b/editor_support/index.html @@ -0,0 +1,455 @@ + + + + + + + + + + + + + + +Editor Support | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+ + +
+ +
+

Editor Support

+

This page lists (alphabetically) known Editor/IDE plugins for K.

+

Please feel free to contribute to any of the projects below (via pull requests) or to suggest new entries.

+

Atom

+

K/Maude syntax highlighter for Atom based on the BBEdit grammar described below

+
    +
  • Source: https://github.com/traiansf/language-k
  • +
+

BBEdit/TextWrangler

+

K/Maude syntax highlighter for TextWrangler/BBEdit

+
    +
  • Source: https://github.com/kframework/k-editor-support/tree/master/BBEdit
  • +
+

Emacs

+

Emacs mode for K

+
    +
  • Source: https://github.com/kframework/k-editor-support/tree/master/emacs
  • +
+

IntelliJ Idea

+
    +
  • Comprehensive plugin for IntelliJ Idea
  • +
  • Binary: https://github.com/kframework/k-editor-support/blob/master/k-idea-plugin.jar
  • +
  • Source: https://github.com/kframework/k-editor-support/tree/master/k-idea-plugin-src
  • +
+

Notepad++

+

K syntax highlighter for Notepad++

+
    +
  • Source: https://github.com/kframework/k-editor-support/tree/master/notepad%2B%2B
  • +
+

Pygments

+

Support for https://pygments.org/ Pygments

+
    +
  • Source: https://github.com/kframework/k-editor-support/tree/master/pygments
  • +
  • Note: the lexer is far from being complete.
  • +
+

Vim

+

K/Maude syntax highlighter for vim

+
    +
  • Source: https://github.com/kframework/k-editor-support/tree/master/vim
  • +
+

Visual Studio Code

+

K extension for Visual Studio Code

+
    +
  • Extension page on Visual Studio Marketplace: https://marketplace.visualstudio.com/items?itemName=clv.kframework
  • +
  • Source code: https://github.com/LucianCumpata/K-VSCode
  • +
+
+
+ + + +
+ +
+
+ + + + + + + + + + + + diff --git a/events/k-a-rewriting-based-language-definitional-framework/index.html b/events/k-a-rewriting-based-language-definitional-framework/index.html new file mode 100644 index 00000000000..93922825866 --- /dev/null +++ b/events/k-a-rewriting-based-language-definitional-framework/index.html @@ -0,0 +1,401 @@ + + + + + + + + + + + + + + +K: A Rewriting-Based Language Definitional Framework | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+ + +
+ +
+

K: A Rewriting-Based Language Definitional Framework

+

Tutorial at the 33rd ACM SIGPLAN International Conference on Programming Language Design and Implementation (PLDI)

+
    +
  • June 16, 2012 – Beijing (China)
  • +
  • Presenter: Grigore Rosu (the main designer of K)
  • +
  • Duration: Half a day
  • +
  • Expected participants: ~20
  • +
+

Description

+

K is an executable semantic framework in which programming languages, calculi, as well as type systems or formal analysis tools can be defined. K is a suitable framework for defining truly concurrent languages or calculi, even in the presence of sharing. Since computations can be handled like any other terms in a rewriting environment, that is, they can be matched, moved from one place to another in the original term, modified, or even deleted, K is also suitable for defining control-intensive language features such as abrupt termination, exceptions, or call/cc. K has been used to define real world languages like C.

+

This tutorial will provide participants with a basic knowledge of the framework, as well as hands-on experience with using K to define a real programming language. Definitional techniques available in K, as well as comparisons of such techniques with other formalisms will be described. Time will be spent showing how one can automatically generate an interpreter, debugger, state space search, and a model checker from a single semantic definition. After attending the tutorial, participants will be able to use K to define their own languages or calculi and then derive similar tools from their semantics for free.

+ +
    +
  • http://k-framework.org: The main page for the K framework (see the Quick Overview section for a movie, demo and slides).
  • +
  • http://k-framework.googlecode.com: The Googlecode page for the K tool.
  • +
+

Tutorial format

+

Material and instructions will be provided to participants to load software and examples on their laptops. The presenter will give background material and an introduction to K, then the majority of the time will be spent working through examples in the K tool. The examples will be used to demonstrate both features of K, as well as design decisions that must take place when defining a language. Participants will be encouraged to examine and understand the example languages, then guided through making their own changes/improvements to those languages.

+

Expected audience

+

The audience should be interested in practical aspects of programming language semantics. This includes interest in semantics as objects to be created/studied, as well as interest in the using such semantics for different program analyses. They need no previous knowledge, although a basic understanding of other definitional styles (such as SOS or evaluation contexts) may be helpful.

+
+
+ + + +
+ +
+
+ + + + + + + + + + + + diff --git a/exports/K.epub b/exports/K.epub new file mode 100644 index 0000000000000000000000000000000000000000..a9e6d7293adfb42ceb0035a7b5586f6ad8246774 GIT binary patch literal 952873 zcmb5UV~{98vn@KdZQHhO+qU-Dwr%dQZQHhO+cR%}=e&sb&i!?6M^r~tcUE^)byu!j zD^o!l7z70X00IEO%FkBa-msG9Uk~6v?cXH;TT5G0XAcKcLk9;NOJhT4OM5$dQwJ9# zYEMfCh5vUX#D9(aXAA)JpVPks@?Vn`RS~3>loO)|2Kb+b@p)j*ng0x){x!7!zoD_c zowK2(ov9<8yRD6CY(Lxp0fNY_FX(!u z@Z$pxERI)ljIf{<9O@2<_g~UXPBdWY*vR^}zeHeE6ac>>hdBR^{6qG!oQt0Q7+DOn~w_4X{EG{KrID6KrS+e)leEp$` zwCQ1ZS2GD|if4hVM2`tnIBoBVk)Le2!aM(REJ7REk_iV$W-B*6B-59-i>4%NZ}3!| zS8jYOo!A;;!5UC_FS47eNHCS$MQzY(-h+hkRGKkK656gXdU$XIso_1IoEMKr)9*#% z*VF%flJdrnh_aUd;zB^jcN-d(=RWuh^YnG7_&I!z`q6y1sPJGsSPXUPU5?uA`M5Yf zyOs|#5vrOBBSp+md= zAVWHpxNA?XWHrNtpy;UF|C>vn=~WuwSl_rrx|1MBg90fE6(3LCxS&C9k}~LAl_=YC zBVoi$Gi!3K<(-x<14C)OUq|)emTxhy+~jX5kW`6u)#Jv7M=JQK#)c(?(B7gM#p}2x zSSS&#mgZ7`bx?P}+btqfyjNNYrEN?P{b^~EfFya0mAy?#XbbC0+X&AzmsF~mBr?$c zl|i%Si#(f@4{hJN;pvFP!|~B~nJ@LVEwMnV=t)j!^D7%_+$X9kiY0|W7vthAWZ0*p zK{&Gxp+U4+bN=pP$PFz2^fD*DE z-;pNOP|%Y(YsKN9jYH$dctGHB_e9Fe>%4aAhpXG&UD{B;R`)$lu%u)cV)<4(!Esg_ zsuOS20;yIQSeXkn4o@{Ue=~Lh2EId%VM8qF7Ppsfq6&FEMsatW+Leo|*(oq0PB?_R zjwZ*UEI-ziIOJ3?v0*#ho?CH_ksXoW7B$m01~r63sg0ZHPIz&5UwMNpax?hsEmo^@ z-7duC&zh`*%@u<L1lBHiB02*jI&pI2*zlC4HLo^26=Io06SP@#N2?CcV;BWGDqKeDZ9&%S-QMiv)_>_ z);*7MXt%s7MpD8R=?uKHDgfBgs$8f|Moe!K&xjnCHBLF}o2shT9V-|UaR9QeX(4k}k8)jwWcMTe-q-~ImHwtL! zwH~|esU|qTm_s~&@HvN)3xsb|CZNHqh89Zzw3Y)k=>+@zOZQDc+esex&~h^aY>IGx zuh3T27O%kBc*+_F|i$g*Y?3M^7QDsIV?D%%@h*=jfpBoH5zPX zF+@VkBAD7bGN4#FcY@z2Bj=M96+OX~r?)9js7R%%e4BJ-kHmbO7C1)a^yyN=s{uB5 zpKfSv6VsM3H)@)04o0pwoK4I;3)|>K;h^PBr)O`T9J$eo$ax0HKM*X+1Zz1F1{PBg z2a`s>n;21ss?yseg3x&x6**L|4rc`HFq=<5=azm@DdPKj5bh-pl!MR&$(B1gq=M>e zLA5;?+W;znVmOqv2ap$dfnPWYFFTmyR_MB0s+kN%REciph#s475Ai7Wa55H_So8fK zi~+m2V!UWwHqfrOP7stO)`tEYx~yBq@sGUkaObKeB+qkt`_rpJ^usGnM#9a-%=_)| z<+z1@0-!kR3dGG(pPTi|^JLZ@l^FF#dCBcBA?{cR`4{&+r?5;;ARJx@ov6h+9Erui zMNZ-JJ~<)39^wYq+q3+%q65+wu<9`*Ut@toj zeu&WqpIKHTvRma)X94;3X{cGdFC`-ZHu78JN&%^OU!Oc~250+~y@UJTBI!1;q@NRj zh(rpMWsS+}p=S_;&$gbK1XjWCG7BE)KvO#Z3P#T0nbbk}-itK4zxrdsNS9YgkFQGK zx2S9I0xEI)c@ZulYh<*U%g;M19muUM8o1noAURKWJYb@a*U6ZvltvCLB&=U`W=qzc znm}GLO$$)nqr_>MAH9;G0q^WtP-`0c)V(HufoYIKotGgzJ%{)JQ4Xrf?Jr^n%N~md z%^h-w3wUEMjVPF;Ql|78rFP>ImgdKnk{)myLxJA^>7Vqdl1Pw~Bs4kV7sY~9!w#vS zp-(oa(8|13)@qL?fE2|rBJR__W7=JVU+hoz_fZY)(nX06ny}+Z2Ucx8mJ-&wS)geV zQe7d|Ve`~NtA3(L-om!!iDCa(x!qwfPci}uEQoawsbZjLz@n0}<+u|vMXCWu+NPqT zkKJqGNK;%I>{&F`cKq#CaPusHzHX_7pj1|8POlDLcAS^ipgPWKRYG@EEL$VRyQQkD zu^#Ks)-s>y3~Zik$v+TY*XlGL(Zj|nw#q~laJFGD+UkDdw2lH_Acfy=^NIVdro0!& z;CKQTr~+e)k@7GIj9*zkG|U2*_!U?_YqM^vdWQ0nl}V~JyF%?Jj$E@{zjVAOD`yUq zYMEnSI@}1|hYt(2Q&`Rd{OM!GY<(P=+fi=Peo<2Jr`Z;{8X6NqV}z+rjbp)slS1ty z3>MJNqLPQ?E4g25^=!gFx0a|cQbXPc43Yq%6rUYbXPW&kVq-wmQiXht%8}u>IV|8F zAbc%QNg3a03E`ioyL-d4NFOTV)mClA3UL}&UDrEuG&=^SU**6O>rJEn`MmvAC}>n* zSW^j0?LH)FeoYx#2opfm7=i4)^C#jIxw8d$6G@*C4DDGXyPnkgz!0l|uvMOcjAbZD zi;xRwtxg+iS|pP@JB>s+#=7J_o-o znWxre94SlCroO>kkWE+mW15tG8<_e#M*_WrbQ{2MxgmN65D z+QcrkyceiYXs-_@Gd3o`ZEv!VSxTHHMxBS^9&D&3%d=1nMT(QCTNLm-7gj*$P2GRWT3|4V2mK!Wd$&&Lrk^k4ecUNykeGwCVb}iel_8fmbAfs zl^>jfy*G`FZ7#n=dcOMB9$M?jb#n4hj!Vbi0%Sv4Y2B;~-OA`aNpjxbUXd~?wFJOh z3}2TNH4Z?9LG2O|XS6>bKAJ{yt24v~?8cWTSIVfNs{lCe^+|(4F**({WGn?@Xoam2 z`et?B@SJY75HQ|L9=*L6U_AOqh64lR7ADh5zb(6WFl^dF4Y+C1Vb8E>mEN^;r7uCt z8s2H(*?ZxO>F9KD)$*@QL33`iYDuO$pu8&@I<0~G`X7pI@ko~TAidKD0QBof2DV)U z?JT0*cH!_JqSr)TN?qOHdo$}>YCrk=(VJ6Tw#b|FZ zGf1a`9(2C)u66desHNlwAJVSqa{I*UW~h*0opfyjKhd<_m!ktO*`E*O-3Tc)j}F6Q zH}&M$@N9ZrwZHm30iRc7pkL#a<^0NHv>N1b>Yd!h1)O`5dAL$Sd(p6(lWefa3ivQ5Gbz(p-2`!j_nygyY!#X9wiN^;GuK1EXw`YX%0Rzs$Wp*f8jeF z!lK%f9@cQ!033RzR_Lwvr&2!+AhH*i1z1)WU6~lV$-|-UKPPut+Js<4f(1zI`pYSW zDKAjf%VTb*=EQGl@EoBM>K!AQ?>4ajxlyzyR zkIzazLu5?coms<7RqpG9GF0ah#y5e=b9*`-dbvFemPu&dKEq~veZ615>q+x`zwh3s z`OjL#;b|V&v23?)J}>ijyMFJ^;o}F#vEMdnR$IONjPlIi61i&Jh4{xhJYV?#CpT>@ zJSolt2LLcZ{oiv_W(L;(;-)zow)UGGNI$vyf@ji7eUY{2v>mdx^p2Z&3O2j`W`A1q z;F4Kd+zTXVCD;G>ee(%RHC)DQln5YEqi|-YndfHQAEbSXMbUEBR%zz)cYlqx6DV&; zWlTSGL0^8IKI*HPM{yZow_x>7T_9{+zI(TB>fYq)YPDwY``jN4f91ZKR5BByv5rUL z-(jfCHGSAJ%EMdM7Z8Lbz|uBW|JAkD9TTyXB|uJHms2g!Q)^NsJ-*M&P!Izpb-9r) zw}fPEe6Ocbqb%j;Zq_yHCF6X*?kOfN54ai3R`sTw(BhIe#GIB6MAORP-j|?f#(&B5 zmIcWHGIZ~8W}IyH>I5}2@;y4 z8;5L}Vzre#olV75kuyqL7av2NtsO39zvb)k@uAg&O&rcrYt|KX|O1z@pfo{S-&Xp3*4+xGdGWV5m|b)anYuxzeBb{g1%~*J3HdjfzT;& zquwu1AS+W+X^ORI6kBuQ*~Nr2SGj|WmZ8nHuZ zfwrU~7)f$A<((MvVG37jDH!aGfYu;?!1Is_iVQo8EIfnq2i)IeVFrXDQ+1_UVnCy$ ze-8d)9e3vqK2$gYZu7^Hqh@wlhA5(J-GbTVB=3F*I36S)6Y*WM(C(wwK2N4$A%uzV ze>GtKw31q#NoG_Ft9zFw+^OI;GWE-e2y^Wl99i?vmkDP*0-id?ND%P`Th5vRSCn3} zgT)m&EE{tf;L!i~wajnND^9^p+0eMFNYPa{#^~(b}&` z#}ly29xR%M5vcF=oYAxP@i5u;JV1}<-j0!28PScjWnac4Z2uW# za%}0mCXD5-2Fh5E=K%1=NIII$Ed0kojAbXo?;NPNL&D)FoXs!C(Zt2Uxc^o{{AVQd zI^pZ<^6k)@fN z_+#Z|)C?v(oQINR+*TeNg#fTt&xar><2@Sg(f3%a!lJU5Jwgkp8~_f*1A2XK@bLm= zxnj?bf@d$~0gOVv(VV+MaA8H$T`9Id@lkKj-S|b_Q+aTj$ss7h}@k(hkJjVv)bvM+j>zhNa|4bV$p?sq~(VPa8f- zE*fk7XcEJHQ8*dHojAt`#|#S*xzdNW!Y=f`S4*oDN#e}1NFjKbv4cgdeoRvUSY1Oj z&mPv?{2Gs>2d6o{05llVVeLix@#|}LF+qzqS3SrNv)_uZ8`gXU3|KdI#EbqTF-3Q< z@+5W`HBje(V?iwW7yNr}StGKTU}$*=yH4CdSVz1RJr`|4uT$oGxH7_LWNbXha86D9 zEDy1d{ z>(%r!Kt7SW48*7Ne%{}n&U(%35yr7`qgZ{Evh96~@|w9z>>V0}^4o6X`h@&P$6?FRGlb! z7`c}=Uim~rhZ~Vl)&NPJQ>ibexY=U(Nwj2!s;j4~D+;d{T5JyRCxYh{T8nF+q-6Ea z68*uL4boR*+x@!(|JSZG=QNjv-7%Ml+05 z&~T5)nH%Ju<^`+%z7KuNV%$jluyl?+VbYdT(YR(ki-cf|Q$40zWyywZ1dn0ck|(Y^ zfRt9c6kKWGgDS!P_ zsJ+YKUJg}Ld0Sxv(dh|@62H(-MlrsW3ZL*w2APuxEQdm9iV$!ST#V=#_948L6z2D= z0D7`K0rnh}cHkm`niO_)+6kmfq)q6^pMnk*4JEL=7|b;?>HuvE>HWDC9^pMIaynJf zWh3D?ptl!lUPsN$pRtYyslSA2oJ|MgSzY`D=qZP1t3%G8*j_B?fm_A2@IQpfWyJf`jzHkOr-)Mw|FL5`rLjS0I zMjRqf;=)IlNC&+)?iS6gRP8=LOEfyLLyQtMu#`mPkJy&3mT7F9GRJ-?LiPUMzdV0t zZ5jvm6F5D79O~cNe@b73Ys`8NVdHQRahjh`3SMM{(a4IqKRzV~j?SP*S=6_2{64Ys z-tsM84!?dw<8H~8E<*PTUs7TxSy4lCj#32f$;3w1im@CK^ z{SkTn>QD0KDHQ&_7Uce+rsVxZ|Nk6?<-hdaD|^l=|3633^^X<&Z?jblEdT8&a#RKF zH@RSXPSp{5o{%=BH-N13a&YlnFgkl<)!q~|Ips=VU*XJf7(tP0=8Qmv3+~yfK)bcn%2y(l$7D z7k;XP6r?o=OCmdqv(7V+X!L+_DM?yS*%f}VA~-j7Op0&##$0cx^vN-w21sJBDdBMu zu8Y`;a4@RI=sFqFOnk_;6ha34Mk8^0W|_yE|?Z6GydySwsW~crfZPcn?Z9!Hn{3$Y^tn{~GPNa?c5uqb+Gwby&pkCey zxnrxLap91%I!1(hBTkqu#SaUcVnAbc>i*vkzv5Uba3Mfay%7?sZHC8y2$!i;dp4s$ zJB*tcTsv7B56cd>cFWHAJ;y?(H$BcKuOgq4;oy1eY`&%y4TkL371KK@26m>U2Mohf z6xYZquuLH=YN})27@6Me4)L^EyWp-lHg+l=OGdUwav#hyxT(R>0GfT~7R@i9|G5$0 ziKWUtzyJX5F#az#A~WNEA@=frsQEv{zR~YL7hVKP%_#zGDQSu9xdx?O0lIGeOHFZZ zgP1CjQbgl57PpH_IUZ~5(TwP9jX;9p;pTl4GRiHNTOFBAD~Mfi^mJw9>^mYrMuqCg z$6I+t^L2cs$&zk@HXg5%X&JAntrs`yq8oQHN?d$;7)36h8?7#aECM`2hIy9^#?drz zg3z52{oN;zX26-$_5>hNd;EXR!R#X>wS|I5TryPtK z-D-+hgwUgA#0jhC$+cio<+bU*9)u5J9BlYdD1K9<2t_imC=IGiPyCMkcgW)|_OoeAJ3IAcMAU?o>uz?b@h{YEMD*+kGDIDfFPac@URT$!1tzc`)K=dnIMyi&{ONpdv z{VTE$dQd#bfSES0=f+zqJLfyLmqRcW-%Ti*c1Ekk;$I_;8At|%4~o*bS+G!gp+}A* z@Yn!}Wd4yc;iS5#<}@7@SXkWs%2;C+ASi4ZE6Y$gaC4GYWfQ8tef9@|75ohc{?39C z6WRQTXnXuRiesY!mT3T#`l%T{8VsZTf(7SKSYbV6ZdkH5o>j;=M}7)Aig!RBs$)q> z|6geo&a`x)lk`TilB0&47Arue@UBO4W39-w%~gE9u1_a?-L?2F-9Z&6-{sDZeQ(zM zua2<3s^a5Hv;pW4Ey8KtiAjQvo9)v*BLrFPdpGp?m4IbbkZ%%-FXhHa@G7cTB_10J zM?=9!Z~Ey%;Wz$QV2Hn2gHTiMc0c@BZ3_mcry#|6V83`MBClsXD5q+uqt?7vyWdpd zMpGZqb-VL6{60bJu}sk0%B9+-YLaf)JGB>K#0P-%6Qwt^KAVAb4fvC2e%q~(YEr)j zWNq#3_SoLw$T(fJn-fz0mc?wES&B%;@Fy>n%W1v>$5Gh%mtO+sg9lFO&6H7Xy*chK z(I!RP;*d<;s;LHkp{(*vwHRM#QkIsw)7Mh-AiCnHkI|B4<$*1zYNk)$W<$QH8*2rX zbFt;aIy^jI4`tNg)yqURHu_Qi=~Tk9(SK9P0v6P2wA>sWT;ak6jF)Y28Gx5akiVpq z45g(|Ku1P>&ndLRYEDLJ%X&n+=V~<^(MX%Y#Z@z=Rd*>?SXf3S){x`$)GAS3xxOPg zuno24j=LOncjTf*>zwrnG-+*I|L$Vp-g?@vo%SF`$1)Qy$8B~GFm}~ATc?X(y{A5` z0Z5|>*VJ_jUOK~ODMtyxeCFbzV%4TYX%`SW)XHn2t`R_;fUwd_u?g=ueIWf*&$((0eqk~}2;H8YcgO=D?y=2lgT~~`;v5Je{ zvfF$^4kj-Im0sF*h5`So{DFa*7|x23_T=ivRc0In4&Y$>Zgle~H0Ry~o-)U5lFK4C zy6V06WT^2{U*IK2kzx-xQiAY|^gh8eh@O>l$M9m^#gX5&b&~C&Gr4d}&MCy0ea)kptMc1i?hwbbIZn$JXLCy9Sbb z>6W<_15;JZ%uqN2YKsF6{3FX2ujoG-P|PZNjke^9d50^%*9D^{&=gIL}>` z3vZQgx{QI2%AzCUbL&qlr;^u|#Sqrc#hD_|%}I3X3Xbj#ygey7p@>tik8b%j!sO_) z^i&wd^!$he`~5%axDq|hr}aSr01E$AKmD&`Nj8T6CY|b=c3W%+KCkL9PYUe*#m~h8 z$mY$0%1veaPe4udqKYiZELw=v2~?8To{CSqUJ|-A+-kt36bAH7D4b3wQyG{yAJe+Z zi@7l=TE(U4ns)7*0t)D|AI=K8YJ76$|&_( zz3Q8ABF2mJ4r^DnC+o1F6l2@hJD zbg?=nW*DW_kgd2%*;N_o1_|Psrk&v(fJC&xie;)Ecg)p=dc@enm9uI@*+YH&qRIoY zbln1Ys=q%~i<~pp?Xk5B5DZ?*mQQqRf1{3$S-Y{T=H*{k#$*tiH^?3$(^=s%( z=Rxjl=n4^L!|7UdoNk)x=gpo3`QxnfuN<8m8|?5iewjAD$|O$P?-Kb63vbF0#knAk z$1FD*E)Fd^HpW}bI*J1)2^gwrQpDIv#)!HyS2NxLco$d;C{3p!zq#5FnwRs3)OO-j zJho9`lr^g#anBR46gmH(t2=5hzq#qmT?c}z5F}Lw6Bna)M*3)#&)Hbo=FIQ?%u~)) zG-=m>DhzCDj$?Y-+TlWef)NK};Y5hF(fbO6P?**y{~BarXL#fVEOSl3;U$ka?UKFfBj@djD_Kz>JoUL!Qmo%cgb$E;m^+G}Jh<%YhE{wn8 zPQEP~7djMz5y(dH$=E;beftEV_@sS*AeTBUMzpZSXV2ZQqS}%vBdBfTgv?H4Kr>*GSTx4 z>oOGd;I*XuZ>M=njgz(FaE)R1Jo^C9LmY_Mu-H?^Zapr)MZPOkisguL@=A`^p#DxL z0nCuMzADfG0o)nMfuY>l-o1kW@>{UWBog?18Oj*Iyct7w^LmC{DaILUyiA%%c(v_I;-|G4>H|5b-edLel zd2k*`k>+bdc)oM7Zh=R=$4m{T>yHs^{GiP>wP~OUt5??KwowBwvAfwgT4J*ASB7LU z_(G>FunaB*$?XMgy@53y^|xw3aI_CBdC4V zHcyZLA8A0UBqporf29B6UqSEx+EFvH{dXErRo4EWqwfAxhjG3iPByZSTq$n?%q$X| zhX=9n$AOi?sSYpxM>W(se|wmdZK_u1``aN&D;uIv#0uC{G|><5YA8x9CrV{+zG~XKdwc0)aguCn0Vd#z4?t-P zW5HVeQir?J*}bBXs;=rM;IK;j-_r#TZA7puZ5F6pQwDQCR^$X66;4vyyc3@PnY+v{0RW!rNg9?O6gQ}z8|LVdxug<;iDKs^?T>?kO1f-PfJ6Xa-G0&&^ zq$cdQ?ePHb{eI;B%Bu6P+mjv$oHf^&rQFqX;M={qnW2^(n%^}oPbIxEEW^L?ooUI7 zJ;TOjh!=3%tgKwfkREE)O#C(S8tfc2y^>#l3AzNgMUZ;n(DUsLGSuwx(L!7xI?swx zc<-TkJ3=GF<&KxpYf}^1CaxPO!hwyif~~;makUr^;PvTic%dK4pK-GTIy{SyML5O- z76JEdswHYmBMd~aiyp)$8@A~VqtE-* zJ4^wNv90uhuYRP?ma`+lSQNT43Eog7405xwiFZW++9qcSG-SC4vsxewxko29CTYC@ zpoI+KqmK$OpE*<4JSA?~NNhlG=8q3?)qClF@*W1kC34$oc2*YMn)i{y>9Tpjup~`c z;2~wFP6?@xMadS*F9musa3(%=%Ot{Gh$OdfTFC1=p!1pDk0Zqmo{13?>^5Vu6*MgL zveY=>3&7-2!ZMZ{M>EM&*@{(?#r;>=An7bnXRPm(DYo&9g9mN}pxauumwyc1kY|Iz zI}=l27idzrP*yjeC{Dm(Wkeffr=}z!FLOS#3cHukSkD4D!s3pUx*7A(iz92rC1=WR}O3fUvN)fA5 zzNRrwz<)MnFA^LhdDusCdP6$HE7ggSq~BYKcPSgl+3AX&y*#5U?X0=Kk-!-KOOuQ} zXfr?7x|2*n8!Tk?4)rAjqQHhLIpC^J+@1_RPBrnUF}QU&TJA}vx(~yDe)aMt`K$b4 zj`Ag4jQjI$U;6|8KP3nVFE1IafAJeL;{SzP;P`I|Vq0VTKN5uBtG=KEyd?N!MGlZQ zlceavNr6QwnuNa(il%_Hc~qT<6^ZHk_Dk=rgk)@zgdL8vj|QGmW>*}3+~_VYZkOIM zre@%RPUM{dkEe%#z!1~E5guN$*~z#29TyfzxgaA7DpyfC<8Z{Sx+-f$teDdD_x=5S zeQyI33l;)WQ6Ca_U%@_E(3#KPYLF)r_+YpJXRz~l0aX!G@{ke+0$CBNybKmu-4Ubv z&1AeoKdgC1sd1`cI74}_?WEAd-fSYh@JC6@p>8eoT7#8=sW5hkjb1_A(pkQWQ9QsEn`EYg#rC@;PieA+UD7(?O0&B%nHd&`iR7# z*}DoL7^}ovL(cT1H}h~({D8_th&k+Dfro{v^nT1JvV3ibVf}u6+8^6FKUzx?xjrPO zTZ$rx3N@JXkVTTie^RJWjh3#X;^j^li?6?>7gvrAu}hzTY}ufe!4d5Q_#6*im(X~- zQG3b!sMZ-Fm<-TEJ>r1B?B9L@3OsHe-HYDVxAvo4v$TWfXak*-m%3^fd+?q%?MK?SGLT(pal>RRT<61`P6=X$ z)}NiylrxV5RbJV1XSXqBsO?}WPW{m;@_|33kNT$Yx>0AfewfHfaF*m^>ULbet|KSV z2)U>opIp0i?rdDP4q&<+1c_d&u+Z2$$7N9^wY1BO(i9u@w`liTHIyz9SGdweO!B~~ zux141km@rK%1$)2|I)JEs84r@1HfLMu=3V4b1Q%s1?A@(@8zIPiW1hs10n}~BuY3K zi4CNwQ0vCH^JY9FHDIu;=72Lr&um2I2#rcXqSl%|5>zH)A}W+SW2|8twz$h?#o@N7 z#HpXU&tAsd&8&bWoSr^p+XKHLcC&fTnq0T~3%wtzHL({x+I$^CpliR7) zUY>*9u~u#>%IDB9Xr0>h1vefdcU=xM$-_ftIrx4rAB=>9NkeB>-aZ&CXG32+_Zhl5 z6_S_^U;0ZNJzf=4Ac%%FTFU4_z&NWRg$ZRG%V(|*eRl34ac3G@&v~T z6M!xr?5HFeI@(2|ve^DYmdDX=SbXw3f|az}?;dd&`|*Z@{r(>^FJNufA6gs$08$*l z|8?la#K`ntq1QF9wbLP6;_f50!outUWBC${s1VXB zN&!L<>xS3Y%cWgB3TYBbIXJCTj+E>;Nw^)$M~GPApNCg^<1AhWb*%x;?~~>E*IkAi zjDe=?{d4vnc8jl1c0YSx7p8}NOcs|TOWPxlB=*tK#q%eNkHG|ou+duIulvzM`n8gk zugLlufZKz`oIMvuqA@%oPfyx8_qW^w$-#f_lhQsjM4Rx^mv!&o=1EUglDF4p%T z(>t(lMe|f+k5oJMqJqsYl({P0(NCddtS|UoPmb!GN?)w*_25y@=Qs3Q48^YqOycd7 zE$-s|@>n^W$#!$PR(b1%taY7O4)AQAGvc?U_=XWNI{YDRoPFi9{JB$PpE3S&v-#Ii z!g0Befo#UX6;cH(FzaVsI1ygP>ae@>HGJ_nn#ZP*PoXXLI^guCP|A^xV*rNdHDs~D z6ZkE=F1~6&u!?0%TB{a_i)Ey$x5N2M4lt1T&RXkW;klc|qTlo9%HE~SYh&1x=>D!a zy}{C?;-4Qi>j4%_x>t@v{kDCtKHn$6q#uxXL8dDqnYPM9ZjT{PV(Er}TZ}h$=fi0X z9*1DJ1vmTxXckzm12SeG^pU9}n=SMf(<#Cg%{=T5dXE8awwGdXKP@I$f5H)DY%zn` zwZ7x*2*9M&acpmfy-@N?8Ml96onJn9rjwS{WB6<<7me6rUh%C6mHcW1wRjo`;l74Q zzX(SsNcME47g@fNs(OxPsRR(Eeb$@uFpWEC0{GK>$=pFYvgD7R8E z6jzTSUpeAt%6Q9+8$b?%DDxOj>~nYqUKP#W~*lEm(tD|0X;EdJ}F!x*kif2zT8i@qwhuTek$Zg$$b?Vx^^Y@Y|D z0A;esi}91J1>h&+)`=?0}jPhmK78np=*1kUsKZMjBiQMQ5snMPA)!-vRfBz`y$k&wLj5^VKR z7^JASek|bwU?lhfc9jv7Hh66jA0tRnW|o(_ekH z!C!kf&sI`J7(vxQBmCJKDPqjN3ZUtx28a^X0IlsPS4*LYIx2z2%gGnjN|H>(Dyq4w zifzitXYzlq(>%TESYB+Ru2xPhL=4gZ{YarG&50bd6z{a~p@}kss6=A1cA3!PMXa)# zyGmQ}@DKquNXg$=_Rv&IHc$;TTdi&&vHIiIOyWdHwXzBm$N}DO{yJ2*viQ5FflXy1KdCzerKj zVz7W~0A4h6v$t+^ZmPA?STp>mpQF3oGDA0^B?>x6CBUu$?>dRR2A~Cc<~o1zGDAma zXRrOMsdZriQV;ahdDC;*@>|*D4GLNfvq#&>cN266*&jTGQU3B=&A|%_9q@S-=K84bIzCU^2!mQ8q2x!a;s%V zDvD?pP%X%_wc4(-$weHX1}K?(l`E&Q)!<#LILA6yxC-KX!lWBQ57c6HerG48g}u^W z)!*ux?m@sZtQA26v6B zsy8R8uTLA;sDK>gCEC58160?~LWigZE2Qc?2Z}1Vv$d$-c-=U&9LYGo*oUeWZgt_KR_&p=X$s?x*HOQn3CieE0ShIXu{v-`o-7xI@y@Igb5)Gs z(8Fif1_k3uRZ{f!K!_}y#1W?u1`SOVPK$sX{Y1m!NX{wKtXql~(ci{!YHYRtvhq%lymBjrUn72e6;1sA0nXO4+-C-Mb z-sSF#$O6vDa=J>_mp;2#)7{5SdJ2kWjEkZ9U;Cd=6{oMkvJAnA$~4_^aLeE z%8Aag1k($&i6e4L-oZXGWI&rCh!OVgo#ik9{jPiYrsE})>Ini&YUL-1&*@7{c*DFs znQR;{-fx|F^ZYI6!0XMPA&2Nzw1&p+S~;>>ZV@~v0mo+wc`%@20>_Bhy~q#WotKN& z3v-M2KK5OcYVPcDwIA=5=oJ$YkJf-ww%o_ibGXCUWw?*6^2I4j@+2v>d#8);qs)k5 zAg^Y^zRHk+*Lpo>66)`)4W*;GRjMCf#M~7)#^kN-CM>c7ATMxo3O9L#{rMueni|=P*}2 zGyIS*Om=L%#~W9>di%a@J7+(Uj>_VEJE9XNid%IDrTn?~@OMUHU~iT16Hb>nM&!7z z1Df=K*I}yNCoVv9i+W5a`Z`BiK+3h1P7qJ-O@RqLABKk(eJV#@WI=-Q9ygZPd1`>Qx^8Fch`?+%`AIvVxY?dqb4$1IIv<9F{%J~o?=bTs8a5|#z2kiyfJ7*{-n_lx zkRy)tJf(TKe$7kC`f_wKTo)2e4xC-t`$!IK0PYR!BDdRH_Be2nebz!B6~Y@&J}fRz zCqE`n0NjK86%KMK_3eYxJx*`*258q_E^o;m=gNr|TywTFvAU*?VcxgZD1=X~((r2f zmxY^jCAjkm!bA5u_T_!fF`EDa;dqRIDILv{laJ;TyxcM(L}>@7QP%L-pzk|l6tFfn zUzbwgbf&(CfinpYU)l`n1R^e=@anRK*O=iFzAY+B7@#{?W1>mW*oHdV(BKUkj2Z3! zq3j*IL}9XJ-Lh@lwr$(CZQHh1*|v>Uwzl2pmd;N@(AR8BpBry*p5X;+@q0*`YMkPgqWIa zQj*0gNH^|rR6k=BhWIJCxh8^Ii7|Y3_s0L6icv;s7aAfMm-F@(keks{faxT+mB}Du z?PGa))Ouw#&?QcDxdw(5mi{7H!W8V>aP`>bho=p6`f(89!S@?9_Uo{8sc9r%&g=FD z>#XLL(TZ%@ZgTiD&8gUPt={Bk+o|ASAor8XH;S|c6p zoN~&WdwOTcbCOzhR)EHWE>8#Ry*D%x0j0}w3jS(L>!HT0$tRoq0^n43*P8KOeU4R& zD-Z(*R)&i-Bo4zvD6XRGR8Yo;{tCcoN$M4kjd+#VOJk#p8WV16D=R<`6&NH% z4|(naXhI>b-IiTtu3_bJUti`cbx3vh@8qQn6+}2C ze5d*X&bHv#!>jLC#21cQi*i0@i?2D1COoNtAM*%V-MJVvIfpUydkRR!5HOxuA)J*X z#}!s_1ro-!v~b!fWGG1S!dKfg4#GXg@M=kszzxvKrCU8N#Qqlw+v$V2xMC}-qbW$u zCV+=J83l&A(+jxfvE%ag)5X-H*AczW(&yER_@)#sa_AXt~Eh*8-;r4okVSUQ}}=#0mnGn;Ae`}=E4K-;u8{Ya(6o&RX?!|Qn}YTKQnwl zD4Ox0)6A`73%pwsytR1GlvM6gnW}7uNK_S&kyyb|<92}2!Y*NbRCmfWu|AesF4P^$ z1waofn}&ENqLy@t1zpW@2LVl_FxcCAv%A|(G4mPeHY3eu3hpwW^klv|$0pe5C=y|t zm%mgN<&h}%7IQ+um(8?9p?Gs+h9_iXytmE6%w!cQRGhYs z9K|$I)KA3fYWoQ~tnSs%{R6_xw4Qx_T>JIp63Bc}r!Jfx#<};-i-kKVt&sfdGR5(0 z-i$}^TQx<|v4A)^jSm?3FztI4Yf=ef1wo`0kZ@EHg>lkag7tk6a#WanRMQ1GR}6~* za`UfoPvNsyn!pGkScX}KYCX;QTPE|kY~t~3YYZeIUfB2*PXU#{;7jfXm`wG)oJy&f zk=PcH2($nTjj{m5uTp&WHS8z5G@$~;TY>x0EQ4%t3MzsvgD#h1bz-(aw9Y3Q;{_46 z-WHG(8q-e$Zw{<=l^M4skAr&>Rwx~YljZ^OK%=QL#s&+1g3xv z2gLVG1z$mwS9V?rvldL{=K_oya-~gmQ@ccV$A>@o2tHjX?Gm+KM0z6n8EO+i1Zhy7 z^h9{Mcs+Vy$*$LzhxpaXpjsIPJ+T8k1FgHC;z*$eGZ|)}R(s@B-M5f&YS*lFi>nd0 z#{BsZT$vyziazl5@`1$ci7Q&iLNQQ)3q3nSaR5S1?Jg4T5Vrg9EuwIYn|wD1>!6m` z#;SnaSHPQ}Gf#EuQwU}?RC)UONvJ&xiO*&hYQwhXina_*Zi6rq>BLMy5`2^-w&Ji< z{|4NKon|2c-+k2Z8>#K3#mu{am22%`1%|#IB1;)fLQLe8wrvb1M1Y0 zcIuDzO^8)Bda8IjDjXX{(KxU^A`FN6fvT&lQ3X96et9xgZf9f=SzJ)>-^_u{$1F&b zxqIn1)~PF5KijbF-*&O&o*@pZP@>SfGRYSBR905N&wi3K`^wGPF?7ClCA{-*G&iN8 zTbxh+AWfi8-_9hUrfh>FkW1Y>_!?i|hd=HdK0!HXRu2RGO)gz9P3t9=TbWmvAG^sN znObDpxM+XWJ~otMG9j6~`>eWN^T9_pGrrU?N@A@%&^7JQ@KV+o6Z@pzGq_8YKrm|< zijFf}oAoYWyXJ1eyDWBEXS~(>3NJ0&c%N;H{)Qnrx=q$s``4ArvCaNc<^w$(QgTAF zC}B~q2&yUmsYFJc?I@2lQR(?YqNcW(Y2h~vqagC*{>lLUKT}(wg5koN>-=DK zl267mZ0}n~$k;sLo+6McqDDYwZ++O4l_uZnR54aD`F>gG&x@4i2=Iq*`4_g`o^e{T;%McEkfM=7O<63Wcg$d! z)Vx>|UCo`@ede(D(>S3h&U%GQVG@VN?b&dPWw;SyhjO|On^@W!HZK({B8*u_3Le;c zgiY@#GVBfG?j3*_#4k7|)%o&}^grCiLROHQw-2n>RbM+iN@6Aw7zT3gZ6tJ_pGb?h zA}&7m(VrQk7AWk!n*=9lsQYASoXr+;vQo8p0!R$EYnk`8aaU zvZniOu}kvC;;%}!&-N_DlYrZ(rEIDC#P2dX(z~23K|*2XfPJ%~BbTQpVaY<1!bf2k zMH%=?<|_co)nmnB+;6+xB0}Aw{6}DhCYNCR{O+XAxozi@B-Uo4Q!-cG;&78z;DqSo zNv@irx}}Gnv!?ORibR{@Vq85LLkm-eV4FDR-Bl5&)5aq%Yzwg;?6-Bs8|O^io!i`I z+vQ{E_)3mUlh~2@*=rG-$qYejD?#t3+HH0c*XWC_u!~?RK6GxhIVRSb>_X?RSmdG8 z#XI1d6St*K=bigpH1Cg|c z@bcGH;uuZ<9)|XexUSOK(`w?9O-J_hJj;b~#h0sOdTtK6UB7OP zMD?prqfvER3(Ie%umy7O@uK&RbTPk3E)%L&$$ok{LGEINxeSiDzixquR^wCuR-bTA zCE_eyrsj03hwNvMA<6~{6f%Yyu)tQT7GQ!I~`&R)f!cH(GBR?Qr#NflmpI7yn zSWzW9-Y8BhQQYq)B)*y8ug}jT_VB3L-<2KB&Cb2!`}hFc;QBd+#Gg?=Wm2@NmV?&dUYsl%OLv3kYq087k)Cwtgk+%x2841SaTJY`tn zkVxTv71`P~9f zcgU%Zy40tyUzj()7mO3d=;_$y2{)bgq-Yo?$*t1jF#}yt{yraF6`PO@7bFb>XDkJ7 z_8gm4F*Isbr50Qo^3lC1gQ_`|2h7w>Dv;hf_d@%t@D&HO@!m6pdwt5De>)r2{G#BZ z?M${6qfbqNjVDYX=8a2y_rhs(#+d9@hdDXM5N#k;rM3)L{g{o8*3=1cuY%~xx+mW+A$rxV5$YP69JOujJo^;1m*P3SlrOZoLe~~!a8!u~RWPg$qgqK_YCfp<;wE1f zaI;+B&WHX6myJ`epKL??-)T&_j0C$YVtRFq>b;M{OPikV_Ry8!xn*gHkEE6i{^c#N zNLN0Zq;jbwWcJXARz5W^CFy2kuy1I(LeAkAs_+7F#4M!W-_4nFz0 zl72^_Xqfj*f@oWTZQ{P$CTM|Y&}mLir2LB_*e?ClC0XHA4BK3^9%4S?2ry*Rd9U}! zDNI1=MUxWj41^+!3jsxtkF6#=)W3lGbg!L$3X=!Z)41zx`RD(D68=;3^653F#QO_l z)CT!qtah;f8~l)(+~Bmy02AiU4;mMpE>TG*{7Xe8EavRAD~?wxNH&*JiIi~M?;}Vl zTY2$eZdiQa)!zqT;QVMoJA*;wAZIK6EuA;t+Shzb@>-nBZ0DK&sdnMFW%hX?N|uEO zU6g0;!yDtvo=S?my!9Eb42fzUgrfJg}Rdf=gXv33~1m-v1G|BMAc`|M-u$>Mhy$Z?in>i~~ zq9mOS?N}=7EleOSN+MlavDh)0-*`6*Y+`_1yNSEM}Isl(<; z`Jz4v62ll{_=wz!6W9_}lLp8i0@4Sojs!kCzvFP$MWOI``|q3Gim0Go?6@X@weEu> zdfrr$eJ)b&WWaA}IbF-B_!`R<5rveH(xqudbT3!)zt2${HR1RXQDE~oSavHLDh-s6 z?1v+Q`DKpp9|jZt8M++eBploXrda*sb@b#$E;BQ?rx=@dtzw~2HU0_!YrpleYpdABkSGyTPM+88IHzQD$(a~@ z?K3?7adw~Wx#jWgqIA-dzDSuLzw_{Ll2M|UseGj3to>x-|(2md{b7020GHQ@+_-s?UAbD>YjWRd;bGTrtG)N8~Bj>uOBa)dqsT)bS1GMX3k#0oV z*J||gUPNoU*dd9nbvPJk2~u^e7PMqpxw5%gNOfJOk|p9~H>EoTAfW}LV(#LD)^xYV zIx{&qOtd0YV@mU+rC9_`W@!)L@mpw9H$dDQOZWFA}y7wtumu%W_2H?P#4|RO{lLayM=IT z$ki4vBo@d66#-Q=y}}F^(F-0zJjX4N@zOQ_g2A8#cUIJCjKe`+(QF~0+%fY7_+ih| zy^ORH7*DrA4aqF6`4Zq%6d5||f{ElzWV<&;1N;rHr6m)vvDO91T3V=e#2EwWFn^aE zsmFIbV%{tqMO>ilw7g|Fqk=bNgB>1>D0RdngHRN{sL1KfWC%QA^kUU_MIyoax-4?*vTg$*zi0MCVSwf#OM_Qzd zr+oh~(N|#JL2+Es&n~RPS0){UX265n;LyzCX=nBFK3c7d_v6d?em_fy-G&o~60xk9 z!)mMVu%IhlI(A1(wyh&2>!f@vWVy7ehv((-$80onPB*Oiu3k-QPqU}Lys?r0fE{X` zKv{Fi1y=~BK~1g`yo6;JID6jCpDn#V ze!V^K51r9nbvabgK=-)E0NI?WgX&`2_Y~|y>3xDy1p3Bo zCWOrSeQFkUyAJk8z58csN0#w*ghFD%a#k{E3DIs)q1U#^^@+AJxYIXY*5Y;|ibVCm z!()UnCyGuJNt>>y~yRk&v!tE z6H-)YyGV+veWw3l#9W~RsM}ZlUgaI{qelcAQ}}=fcUA{SiCDf3Nd7^%x0=PCei<``h<4I40N)q-Yv6J_zF-YtuXeqm7JxHX5>D%BAv#?agVv zV94d!ZV_B%nL+WT)s6^T7T8IsZ4lDL*sEam$kN@${_kNK`~-m0RrnYHgUBVcebx zN|t<4*Hq<}VSPEkJ*nVv(}tbsAtKs!lo9-pP*?xm{dfKS4qvLQ!)9NeYIP3YG9Bo zi4RkLziIr;vzxQS`u^$msBM~FUpJHb$JNP+>u`sHpSNQ%kALgz1+D9=g-s5aR#RLW z(V}Cg@$Zp8|L*MvS}HyE@y{8(jDx=%c)XwuvMWHWigHJ?cvOjOOgtz9)MM^KB`>v_nlQsl$t#8#e@f2-t55z+|UA~ zfKmZXCqYQDgt1rBZ(#-!YZ6GY6^b>by~>6-jKdWKEF_x}s7jGQ=~Uty{$~M9Q7Nly z=L$uTOd33A*CY-En@nF zV6rG2Y$Y8pFjV2`#v)6mzytiL?2W(Sfo-($cj9TrZ5qOKr18mcrz)omF|3rzk9=G0 zE^MVxgAC2CP;Vdx3-0>QYxX`qC$y%yK|$$P4A-d483e|U0b50;;X$A)!=wh}K9tsW zf|Hw?7WI4qH#hWIr!}}%SSHk(8s_xSxmKvZf{UB&pAH_-Ic_#x=P&m3F(znoWRi~C z$YwR(8%riSLAzZmo8k6)dOlVLi$v_ibfinh>7>kky^CEqaI1VmM7vt%ZN>~9_zceI zxFSv8ImWl*CLK)7Yg5F0lTgsi0nx>tq(!Xj({JsD0F!nHO&28mbjCXqD_JDBis8Mu z+?6DO?VDXE`v0iAtY5`i-t_KlUvd@W;dowlHj~6_6*aQOXZwzw?NoiQ-c_|~Q$4b* zMGq}YjLteV4M~ptIfBcygIye#|Ig|B$K>i_kmAYxJ$?Ou4ak38Yhd^{dAlZM!0sQD zd*cZu%YDeC*|6w3Zq~830R-Hs+qn%rYGyRhm?GJjb9p8{Y`KeO+W;sE5KiWoh%c#p zHe9P%4E&d6V1y;!L!Ub(dsviwis=bq=siou`D+?@o{B7^U)js?rCxvHadBf zbQ2V2hAgxIb;!cK`FGq4^o8##lG(40JHAN!PoBIZ4(H>a1@i$vXE5vELte=NP*k-=yr}v%vIhBE?&&e9N$`L8GHF zKvq_Io!8@6D`$rZB}H{ig(gIRuyLv-fl0o}t+z4*C@uvWbQDCe%-jw6p97P-WE*4m z)EG=S$^o)RfdYcItYwxDM3^Atx+EJWN$n>RB_a4Pul<}wn(260sDWfnrg-zaY}(`T zq${&0J=ghB{;mh_Hr0ilS+f(xjN^~dW#gV2b~OG}W!+6$rV) z%GstA>NhltyRxQ}c`fiX)($)UvaV284ILo@_0oQyjT5}K2U$e)=o3U}7G7?@UV7r~ zgh>LDzMxy%fi(JXaGn4yz%V_N7oO>D{M|eOI@HI<1QCrO)U0i{;sia!UR1FSfBi5Xo&+JdTh}cgXhO zTjY3j5RV~rrpbN(_qn_(>9o`STeU$H{O`{t3oGZpRPjhh*LkxQ$@itMzux`)FwSII z&Q6;=iOKm-b8>^SJ64~$fD>sU5F{D^=|f3hPZt5HawCN{l<9;dS#rT`0|$q9J+y$z z`;DFPcxisD!uam%<6*clm}I_CVhs3bCa$YLpC3EVxj5P{!^Ph)-D4Y%vUTjgrsd4) zO3f*jO(*WdBOtOQ5mFDTk)V(j0hWm z?a73&VTCfH06MRQ!y`pB2258$bOr$oy?QEXgO)=3m>F?B&_i>sWpjmwD?_z6i6iVa z5gcv%;kF*3gncQKAQuV1a~nE9kO2wEqS+>D0~zt6Sz;<_<;qcDZI*eDj9+zFv>$J# zDK9>#rZfpU1WO$o2Ui1%pM@E7(nmDADUkO1f%PjS(_!)#J1v&Wi@i5;C`h|Bg)oHT zQDdv2>IYCvUY`1ec|`L9-H*5$7U8#02T;Qy=emIwU%=Yi02GKkZ)rgKM%XTDhV`5g80e8HBt^f>>NiN##y?qe^c& zD;i-YRLxRGD7xWq2)9!J2cUHoYR1#XLKYzn92JOa1t@0&>rTk2o@FDiGHVf}l_LE@ zf1`dLSh+*tK{1|w!&nKRepY5Bu4AR+sp5We5PT1W1y!UB97WW{WX>K|G~t6F znUq^8{Wf$UK|`zwa&xg4E(6ynb2oqC-ZHgo{1025dX&DRB~@CyUwQ00<>m47$ZFWx z4b472Jsv{JfpV8EKk9wrzF~4EVWBw0T2LEKF%JJOjv_skT4Id&mIUrl1R z*eUEck}FAQSoeSm4}f_+PHdfH@*Fv$0BSo&Tu20*aYf!XYqCjH6~b)Uhi7!>R47xO z*DGYax3LJ9`zgj0Pa`xzUT?7I6K$u7u7SGsv4%~*2E{Z;&&eVj-9w@`)G?SC5z>_U z(BB z3==|1jlfU^V2oy_tR6gJ8saDGvaH&$TQ{8fo|8PhGD#ZpUn%e1TLy7!#jn2OrSd#P zDM=p!*)?s(NyOS=*ps#qUSh~f^3_!|V$8>-J6#@oNTY9Hj9zdp99c9X-Ol!zSU? zoAc@Getdpz1)Ap$RDgzMA-JvYJvkKxyFgj@shWx)^?ev9Xm^T%__={9@%=X|M&^VB*xSHhTV8s=%tnYv-HbH zHdwl3672=MyONQ={3)UEvR#^>c4$Z!v8+^@f%UQ91C^j;?-hDrV$zo%cIHy3%n zg=Nx|M9cE@YPJvSBG^e!e66~d@#p06r}hUKLC>X41!c2WG-7pTk=U3-5&LlayfIlb z3D*w9U&&2uP#dn)jOCzjAi0Jg%x|jkW|?8Z!_KahwN1Z0MjBfbDZ2P6ZpMZAO$UuZ zY!^pZ!PmMxeIqo)I(sW_k=wEcU+jC;3)b9399mj*cIohK88l#zlP`C`1Me{LlyOLUO$&ye8YrJ6;*Co*3_XbXX9SgLaf~4BMP@3mQ zsT^i4m{wQl`l!1CcF)}{yCSUf2lOaOU*sSAM_YQHhby=XO-iTe8|rJlhEih2FD}5J zg{nv7G2J@}iz!1v5|j4VH%N)~bytcPYIsA9{>hhS-Q=A=b!BtcX*ucB5B)w`Nw8@cFnLs4#cOAQhFsLu~Bfwrm zkqL2mHQYT7LlaYZMfgB;9j7gFw@iWrY9c{nL8I$14%Fxb>@j7ws*nTMm;!kaj-LHY z=#)t2P^FO^FZ4gUTp_(-iF18QSb(a`e;G_fi8pM0WR?r93M&f)BaBv0n4crn;R#8h zrxcX~VuV`6JON3=%u#2xp%e`eJFe)ZIz zuM>315+pr?3gU95R|k*3+YAz@4~vj&;vQ|P+I^|oL0!pmfjHc2y{B?mF|3&qwj|YL zlK7@r9JW6ijT0OyNszX}6K}rI5IROkK2!^v+k6>ZCbM@if-(cGoKSk(%Mj|mfD-%% z8xI$Dfwq!AanBy5l&_2+EhadQWH%2!3s+@L(4w7U{cgq}>*_Z^83w2gqIgDh#;C-F zk!Q`jC8es-Hv;qz-psY~>5DGLXcLjr&#l9gyJ zE3Wu#?gU|+jKevTj)14wN2pK*IsbxwNnP)^HdHZm4XRD19&HneKFvHdSghln$0FbY z;Vc(o@)R8^y%SwOJdn&jzj)+p6L1FQS|+JtNaWx{#XdzSQnXlwM*sq%t?{l!=kgI1 z#02{@)Xi$u+~}6|{6|U~Kel6R723foDD=ZaaWFV<11O)iO#k5CRe7(MnN_pCvG zP82?cL`CO(qM}r7-fSM?^$CuN7PTLd{g^C~*AE4puGm2WS_qa#4VLEyi}NAdvn&pO&u$;8qM;cvL)lUBGP=QccRA5$s z`uUHWok8UUrW(Yij-#z9CJoT6TUYDW*0y(HL8?(zs*)C z0f^Rk^9bKArt!>aTxtBu;Iq1pfzX6VVg{PBd{Ml}4mvTH+oAdU+rh6p$)T}O)>?ab=X8}P8CtS3 zdf8<3*%@77l*=N|(1#wSdn{{g@zGP*9&73Nb9CeRS3RpG!Ap8`;CGmOKaS;dl1JK` z%O!PGW`8Rbl3|?F{Mm1?m@;mdG@g$M?-Cuf{k_Y*xZ(P&v6>mr0CBO1Aw~)lb$6xM z6B+|&82BzPAI3?tj`zUjU03x&Sy$#C-F!9p<9bjZ!Vju$#tZk|E>Mqc>SNl_-x886 z)o$2-@@KgI;v132gN_j{Vx2fD_vNmdxgY%#t@m-Bjj!{4b{*s|7M|VwL{CyzvhP|G zXxf*>ZfF_|f=Zy$6M)pWXKv65Xv3pC=UZ`28eZ$Qe7GxWcH@GW4bCA%oToc4TPK@v zWV}qDXYtSEVmD{sws$BXTP-vX@94)ZzdgRY>!H+8!>T%c@fDHnj;>rSRQONC?UnCu zBTw`Z?FC`*Wogl)^NYtLf|fe+i{bL>q6S}?zKqw8ssLW_ZnorU#uZswRlb(Pd~U3^ zKidoyD}Y^yOHYShcjx6>Dc)MF*&nM;<5!}5cAChC8URKW+VU4~=JC3zn%v2rwB8|8udD(pb!v%PWKB&+b_9^ltFypBOR@36 z+;VQIx(-~V$&}21Nl3yUlBDAFq%p}L{8fhQx=L<;pM}s;&CvkGw~{jK_pBghHEZj9 zN`E*{hiotU$467Lyk=2vAp1G!nz-RIC#0U8qe8rum6FkX6j>9m-5S|nM!7ndXMBxwgl}5(g07S#z(bM_u z`fMq)BHMU_C!GN}$N?^wO-2WN`9}$(W<|qk5QW@XmjZ8kx{sphR5nT=@0fw`5M8%` z#VlqsJsyoz6|5bho`pDCs3e!MA_KQS)LQ~NJR70kxlzJ3eXX60p1p;c-OF+4%( znKPvQ*Ay2dLT_yv(C!K}!>B3Vide8i+UZ+fLT8g;Bm5l2z-o1U&hIpVagzZYk4qIR zZ43eXRLCX3aF9t`!g*d2`x@IeA7_LcTu)Lm2Fz7&d1zywg7d>povx#%xRNSBo1St& ztlL#R$V(u_RnQK$PseGTO=$mJ7wcbv_UE!ugsd8IPq(JeR!}mYOSamlHCVcl?jG<2 z>OxY3#mldRuFFbwjLv-@Vl{G}%~s7W_XX#2@Bk06NyruhVS@vuX}2KOy@VMgX;AW= z?lsz{Bm4pH3fG-9q)UTrOLvP08W!Gh)}SVakME2p;{eU+c{HMsPo=-m?BoZqnlKYL z5NRCZM(1^q;O&@oCFG#`4jt~!L6jh)%_rG2=+Zo#rwC2?8gzlM6DjSNz7?3L71+Ar zUhDfg1nL8`R|kHWGeT@f92z-@&{+9nje%F|YiOViW}?|62XVxWiemK$ULyuaMoMl%GC2MjG!PDPjMyVf5@|V7Cq#WZ;HEY z3e>KCz8oiQb=sV~5%^w4`tU)D#!+|L7OGa>e*J;=8UFaH zbHUT8zip3NmX|KBD~YqsT%vfH_lCF0Av-zkO~lT;O~WdN5rQvC|~*cT-~3q*S)hDFk5^)2aN23@Rj<00BYq}4^~DW?7Go!NTO%4 zdyRj%O7r7(XWm2Tf5U04JI^cSt?XxmSN^Q$H5BZ)B?goIGQ;a&?RLHS<$nD0Gr?V0 zBe$~&wPR$)^|xX4$Ue{fe)(Z+&e@wLuW!(a)AEJL2Z`OUuagqb*TD0-f&b3V-2BQv zOH$d&Sulkgsz|}qIE`CfZm7QYLXj8KvI(Zn-rjyFHr{X? zfM6og+)q%NJp1?I355-MO@qLw;2n^0E1E|71_xM$8eD3$CM{F?C}yo_l;8scNI?j) z4j9`Jl5yeqpfQa+W&aL!L)>~78u@EG?H$DO-biTfK5j85JDToR$|{hkQaLI{3S*NU z_55+f?{P%2HrAFjK|2RW9L9S!pmq!I@$}cFu&bAF?(xEonbrg;J4s6_wJF%7az(Ng zZfiwU@8mI~uzzV?zA&_uosI*thGGg*FiedGm3^5x%T^>SSjoKfQ1sw0QuWCw2*fV5 z(KD8Wb}>vDBe4|iwG3Vax-FT#whw(gvzxNpML5jsm$6$1fv|PJw@Ihkyk%#bnbA>I zHqipircya3<&hw{WK#aiRgym(m@tL+m|L*Y*Q%p#5K7evSrFT>djQ6P*dSXeU^O@X zJ2WeqR8M%RfeUce2XMc5oFC8!U7W&ci38%XpstZQcf)h~OF(K6P>jq5EXPop<>mXjdFT$t}Xr!Xe$-md&u4aap+-cLdFv_%{^fdCzkM64+5IBUJ- zmj`ho=YGvYQZdsP?Og7KNXa%?L$C_T&h?UPtGLiKrYll+JZ-bG2hCPI80zIDrASv{ zlNi6EDYQ<71r!}wcqD>&d_j)p5rSo3{w{YeX6}PAX+vMtQ7ca272I-G!?o=^OOYt? zAUwFE%LFgNJfj*SEw9Wd!erC+MBF;Wkh7IXcyTSb+39YaHlzz_h^rM=RI9zhUH=`R z*DT-eASh>JF=H~SewxC>S!S(}CK0@+ZhGLFY*R8=12rs zQdj(7EPkG1mZ-K!L1USZz&O@^5IFz1Z=e^0PiZo&Riyxp+qCQ_ay3FIZGp0xh(d-VLcW>vt6H+*EsXQg1@C? zN$*$&-K)th>k>1%lRli(PcZPu8`Z_j%u6!Af*0_;U*x!7h+TKo;cpuHfW=NKeF`3o zhKJClzHe|_T{m`3*MEpP4OhI={Ij7SL+ z8(2E2W~IC_e$r?AX1Vbmi5MiRPm>>_^@${QVhetD$)bO(6JWkU{^OATi9ww7c}Xn( zVweZG|9j0~;rO>^9BIos|J97YXf%U0xoj7j2DPnHIT6#+nNgR^rJRu$7?D~L6@q>s z0!qF2%`O5<%_LGyH3>yIr!k4&Mt8T{bZ7uI-2P&b@~jQ3Y-f0=5sd#|TjUFPQI<#j1rAHc*xoP`Sje*p4hnQ_3- zeb~Jf_+SJUh|EFokeen9D`AGe{-q#|I5VMT%s~^F^0`FOlZQZ>VI1LJDZ}9nx@>vs zqbY%Z%W9l+qL<{&$l?uUs{<<^XhqmZ;4763cnm*EiTlp{4x!l1Es~uP33TboF{ZH?l@Gqe?8hNXZfX=68{yoZ%Q>^b}#PosD{WJyDR$|5OZL0Ss6 zXwU_+VMr?Q8kh|$aBvCWVq1fy{|zh8SB5~t?liIe-GlApaRHNpA#yNtlMWdB6iW~t zm}ev!)|u4vsI=crs8PX+;I;jCcU+*teLe<4DdQ{HiM|mPMa$9}8<`U40GUji0vIUs z7IKEfpYKwd(S*9A`rPvAXujaWH@1(H&aS_kJCnswXFh=gBt z0Lao@Tn?w3pqSsuLLSGFGMU(dGg(u>u}TcGjHG$MdYLhm9X5=d#^*VVP8&dlv*Bq9 zNWioy#KyRDCSnvYRo6QOh|-;++d!!7=5enzF8W)K8Hf(%#O+{=Fn_OLS{Ua7A~hz7 zAL5+~2s!glDjnwZ_z}K(+V12<-wr@>$y=4AF^&3UbR)~p=brdfbbnCPoH zhO8KdoVCJC)?9<a!-e?3zOIIm>|nMFot|l>})D= zx8Td_W@cYdvzm0hxB<^knrB{hgw=CGVw?YPw+yc$$dksNIJa5#7Dr7xi3t4HLa;xWCDgLZ7SL;K^@IwfEH5#AgGZ1NzlSZ^TJF3nQzfvxn;-yA8GDf44v4 zxBuFh4E(v;hWa+mnV@TM2YB-1v%E<=UV;B+)_@+Zy15UDtP<1)Wj0N+caKz+uJkQ* zoSr-_2ytc&@TFbd7`{)~Ou83o$u_@MSTgx#-}8&-foZ-zscdHVxlB1}4JN0kq z4^2<+Hmbs1SO@#Wi`MmiFNs~D)nzv()OtMe30WQYFx7%J+*U$1@2M@c;zQi4I5Mkn z(P1CgDy%Rc5S7vYl;6Uoexna-BR8Ja(k;GCNHHOjozeO`<`g4j{ruUMmCd%EMQl1? zk<4Ja@6`5u&_ZujID$Dd0}a@=+@v)%ttJH1>A~c{MsQUaf(207ne?lb$hO+zn`G87 zy4zR1ET$0jZ{TmakGmwsisy%{%G`ECf%YbQ=~w0t7h&G}$B?%oVr%r5$>u$ItX3Dj z1wlN&BAJ!1d*koj+qEIOMD_F}!SoB4E2E}XApe})HG$#zG2-3#wsR1m+^PS-jt zXV&gz+ixI>@*lOog1{ahvfyqE`bukXHuw{92Z4P>FLD?8MSHP(>i?e`>mQfvG4w1c z^v_KHzj3)N|3j2gm$pA-`_~U1Tr6Gv9$O@|3nZ=RzPLeu=z^|@(hDhAm`2gW(sU&8 z%%4}&8+m6pqKh|$;d^9El8FBP<3UR5`Jh6nQRKRC`uJ(|{luA%MwZ?wF^k<7)64Cj zoI_ed&djt-XIk>|WQ)^g%WYqGJc4#NJUuP@iDIMS29}UA_E4W+lCEd?%oh0}N?$$a zJl8##QbXF>(vTa-uu=3(X>EEv$uio4g5iqKoS@}3u6hWfo`EEThW`$gK=j#^c#-n8 z_7TZvXT@`Sem6b}xQ`o=q#e$8wQzw;Ds_&kp+f2GS2ULz5i*_}Z&>9JCur&DX~77u zZRp?fomjYz3e6jiGvmf+n+=}pk* z;0xWi{d0eNeWLwpd4YNDp1WswgSmahi(lsKm^53^-pw=BC=GQ*dU4-e?)=%z78|`K z7QKK)%deiO`T>_*z@U?D{^QC2I?_nirok__E`xL zcqH9|+yTbpOgx29TUM1=CCSDh{4VZ(pr7_d;l5K$7AHyhwg!{Q4f)&I`rLpjK6BH{ zO*e3`Tl&wg!P=r=3|HZ!-@0i3?7lm2wSd|9sz>&yhQY2~#B(;0>$;T{6v{%uhD+qH z02peE5+(4SxfdOSvV$IF`PViL#|lHlPNateuK`Qb06FlASC06HNC8P1izr@TJ%oPE`ebEPISURLTwHQ0F3eM)GuQQw zV5l>Y)dkf*D2l`BjTSci%|3!|IxxU8vTApzZl_wt>VOs;NVLao%ArYG2D2Td=McqF z%_S(N>3Yi)^cMtWd__Kkf}{E@mQ`0SuDK;{OFD}&AUO1Q+v@KOzislQC)o?CAUo?% zg}vVnvfdejln(@p*;oKaU6c==!3|EqH{=d0!sf!{K8Ume(@7>zgWOo32J&ysLR~&Upeh6<6Jt;NOxKx1(`i1W z-ns^stzNn9)Gsev6XC<&99?Fw4Bp0;%fIcoz|%^=5yfFFK0Y-!{FUE~%ntm;Y+n{a z8a95+tv>v(O3Sh3&)Nia=dkPWT0B@aE-Ua^y}vj)`s}eI;&7uuB6EAh`<65x*Qwh(P z7ayfzq*&A~S$!U?Z=ay~|8U@qz6+g?UhC+4<><{)i%gqU);*OtSN%A1YSpU7&%Fw# zjo#0nE>;)4^^%Lx0h*vh2hd&4imMoVa%6`@+t>4v^F@LmOeh_ftqzdJTAa$acr?cc zRUd%TnMNCa7=S8@lMC@Sb(T2DnUl|IY1k}d`dpnj<-gGmWBfJR+KHFI>>Y z8qZJncnki2l)YnnD9pC3oy^#_ZQHgvW81cE+qP|E#$>gQJF~mD0%*s;&zjpL+Xzr* zA%!qIG|+8Pkuhn=uksM3h|`O^$WnzB;;vAIZJ0k3rxoKl0w68a3ld>q$>Sg~N664p z5iGpO(u}Wkn2pAT zN>aSp#>^fBH?cx&A1F{0eWsBjtwVij#A@B%Qwz8F;#_7cNtzAiL-bRlTvMJ=yAT<8 z#C@R0%X|#E?)El(e9kGs_b^XqYtIvKbL2}NxU=YxuQOdjO&pwDWf_KwpGBBn{G`~> zT==KDsM4%TJ(G?KVaGibjt&qYrK);@OEHd^Zgbk~B{dw8vPmV~`~%sHkBVF6ztg zr=PK+hJrRkDKXJ5lpD9gSTIQ$gE3X>t!w=vI*2>ZSZYC6fWl}CK{tW+_#tusKAkQ; zOpBS+7v z!^7X_5q+jQ3nyX8gzZ}`JLxebU0?S@=YZ3b*Cx}Az(~>Vun5wMKq}e;NQ>WKxpMoC zvFH6Lbg>}!sjqP+!jeso?3$snvep5sW{%#hEwpCKb*Z*5ZyX8e7(Nm7c%AshOsn<} zy!5e2^Yo#LIMA-=twe5rTJa__kzQLX=0bG7iSL6^7CfwUb8cj9V-&V$f%{oU0H{T_ z^mpC(Ks{_s1#O4ck?c^>*XLU*@r1E5nvJ-I?iFbads}&|-&4KG8)~TME+=Oehs8M< zGV?Lw-?rEi_)~=*#?_YFe$Gy#Ni?g zijey*gOZDS8j?S_MChOzIv{?E4UVNUXa3_Fp`yl-%%BZDXVnL&OkcUtUg(BmGq%*M1E zeoG@)bl{}K3H;-93GGt2vW&~;^dttsuP(GN>>K1WmWtp?Ze8tb!re}GwC1LdE{IqR z2Qv+xyE+rFqN#lAN|IbUOJ8^jNM03?$jC2xGc45guZ?`9qQ*VIX4ObOA};I5y+Drh z@KLaDt_SLqtp~-;aq$z1>ry*=oe0Bx_96Q!%nt;=-jv4DoO+ux^OKK28Ex1rrd-hi z&(iemSZE;a)(|q*Zy5+C!cH-r;6ZJKE*$!?$hnBqMnvn#3cQbkl!#Jka-*|Q3N*GC z=K4`U%1M#C=iTx@qktd&%+Mz!n?zH`u4b=ZFn^G)!C8e~?}&DpoKA@Jw_|#=C7HJ->?t9_UUZM zBHceB;LZx2Lf&@}fBjZfH;~cFYP_2`IC-G6O&}BBXKY8Bq1FBSKae0S=oN|ipONsJ z_J4mkm^uDE5^iaHEB#2$-#os-)18*Pv?IYS7v$ldSXb8`ee+b<7q-gv$!gJr?g?3a zHm$whatYSIhG1Fs>+FL;&(6*sdd|)!zISeBxK#6J7H z?E;w!81~&nLASFKL@0}%<%!!!wcxryqMaGT#-$^Qrt1b zdEbZ%AN*ZUUtdjsQ>gD(j1|K|4*?;Qs8JSxsdA5&&5-93O04!Ny+QT6 zFe!GpFEeG`(2on~!;|2=68XVEE0SVQr>v%JB=xgTI`|a35k)z#$(2K7P=XE{xoY^7 zEBrBkVM3Bslf{a6*crg%?T|smgQVX@RuAa)-Ev9R7sW4|AAnTg%q}KWcnydk z8{Dn4L!VuK*O|MDlch2mjiP`(KHwtT%Ivv?BQcgKg&eHT==T4wo(< z)P02h2A&B&2)zx97mWb8n(_dDSanE=i-RduYvYzcPX}N~0nNG3oE^$#xHLKx<4n5l9s}9IN$T|M{$qK-J=)Ff{blQowvQpQzO!_gkJ!78V+6451%t} z6GWP3x`%_$M(#SF`TMow@8dWW&Vr9#N)S0=)RPu-fPdxCMe=g(y*O5&v3MI#*cAB) zVGFxGE;S}Lx{MH+A4Mftv^U_rvAJJo)xR5th<$?A9J4Ai%dA}i;4 z6@?Sn#A4$a7^2G0%*1D{9HvajOOxvnLO!I zlej?Yys8#7WjUwnJ;lFhQT9oUiMyhMv0_{a>bi@PZp-oM%grLD^6>azhhsI{s)633 zw5Q4Ep%0I~O@yH)0|v;6<%4d61JmoZ=@YukYpmfTZ#hT2^-Eo05vPP=1jCxjBR;}W+p}bH+>IE+8YHty;P_yR5Xa!_c`1D~OS>`&t7E*c3 z%AfOYw64davTvp$uhMJqSF2@4yP|FGsRd@V0MP5;s=!J~m3hvJX`u_kfSgBc0xFX9 z%OTVSEFXzHcsT11Zh>K|p|RYi%Y7Xo&k7YaXX=Xf%LQ&lAYcM`&+$@mQ1SsoEOC5V zae8GULbG=(=+#sd6*p-pfcZt2Ym4?X$CZ#&_K%#%Z{4us-j73U-Edu{X3AMaxM0W7 zCdeLBj)1{r>g()>SdTx=dM#0L4kMiQJE_Zh1G3j1J!c0oKJF+{0}f)rNn2iI64ZUP zbqN<`mFb!qiBA^o#hn@VA&yIT#lvzvzhlY0(`?aw;z8)DdlVje^a*D8c*XB$R4!CK z&<@b1TV$-H?dZDw>~7aJO+bZQO^XtXwM*l154`uk3Madk{adO5rF))Bne#Wpp55!- z!M-p$ij?OeLU#GP677DdIxg~w)kAhG;bfM&oJI+H@QL#CezJo?F8k$ z%*6a}FfLn3#`a&ha4q^<13n9cLZn_QF^#exWd#3h4i#BCsVWZF>cJK*SE?~aI0*H-l63o~k27yBYcc4lw zh;25_1fapHK@o~As3c3~;ZzEGv%Z&p@&Ul9{xoeviyKCB%9V}CyJTdl6kOO&0f{n^ zNGbzT5uA}Td1dYO;^ug^@RCLHXnOJ`lk=hl)d<~W_n1V@btwYYw_Xw8ofT-WWF8Y# z+*o>=K294A#4AUjkYm+1O>k5Wfj#9C6soODBP<&UFVDwQhmV5-d3 zLw)7bB4c`f@wD7V!Hla?>8{LmiY}WA_}l)mVzxVYy+JfLu5=6&B|4-_oH>}6pLzP- zg9y&c$EKaJXw+D>uWv_GS+FawphIg`DNVlMeEMsSV$G~lZq~xZFauye$#MOGL9tg> zZE;1Z$#cs%;Adp{!7%ksnip5(pa32}?}g&_za$P^iRx?mcdnn4sl zIVBsvLO!2yNY?6+BU5?>G1aakNcwD=<#>a2B2#<|G|55rEQa{m3frasfNJ+QN zEk?R`WOv@k2LI%tM?hY2#50Uxtz^%fe7@z;Ee(0Uy+2vH>KkK!2gT_FGdH2RnWydT z>Oybr7obP=%M+SG=P()4%M~%gLKM;CN1aTnn-S6lVL;`je%p(t>4hk4F906x5=f6~ zuNV_N?cO9!ai0j~m%1jB)Ript4YZ-|Ya$9Oo73yq=;WLINl!xr*>r3gV?PB4V8B>Z zpoM925iio~qMd6kEYmAJg2?XE4PLeA?kuumPtX_rCCkDXJ<<^Wi`W^xVaypq0J9?rLidpLB~2U(kqe7%i) zRi;8tz_kLxGxBK?mh!DBuc%#Al3|&-9t(-9-skx%8-f|WGN6D1dT9i@gfy|ee9TWA zfF;zz3^?^Kap-BK591Yz3>dNVoc2?GCu;Idb`oSNURe=6yWa?$^P&o#<>7ITg6%29 z3EXIglqYI0mdI#vj`7%S0N@BjNWzpxBbWfnOfd{Z2gEFKI~(JgiDhL#S&rsQYWA|j z#KUF8d=})$vrhf&g_J}>(x7&~2RS6hCw^B}`X6j;=tPIsXzwGX^Xs$bmw*O$qu}d; zF9}O0s)bO5o_ywK>Oqs3*^0wlQG{o1*K6!JVn}BjB!$;MW}Q(|rmC{@+7M;S*Jsf? zKn~nFlR|4lYjYhTL1#ghJC6D)NnWy_y>2TyFCCidXOw)KXL!+(?0DWaE3`FBg>xI% zcw;uB-02Jt#1@Ci)F=Nkg<;-eoO_->`A{1(=Y~8xnEWe=675|0r#XB|C=U;IJvOqa zGH>{^js|#(0JIw=EYjA!<|ZZ5Gk1i&VYO1&$KGp&gza~)ZZ`pE0!4{8flSWmLsqL3 zUkNvekM`$7eI-Vtga+~AF`}twj;4BmdGfuQMIZ~ZRrT;tYAO%4oITDo(WcJ!4}e>BbmECb+H25}FM2dp!9Gbgxx1FHx4v?_xzPBNqHh zR8WelN^7hsVVyHn2;hiRiVYrW=B%9Xi8Xc7d zO)gPzZ0K|`{JIMvyya8vC+fD0aEuY#v==5R5&>X;98HSxsRmNydezm(xcjc*=2GY= z9&Yzt9BP&T)L}~p0@YryFDy* zu#E?Q66gU!UbY8ObMgiEo&u%_n1?W+u|Dpqo=K-S3}Pb3@)F?!6%NtGGW-;#rn%=T zZ0Ord{bct`gm8Y82EJ*zpcJpn#Cy9~@@XZRWAtY!XHAtvI1!UKzYCY-Z=t#H;<{_m zev|bY%LN}7N=U^c{FFM=%`R;h(kDvYwM@ryi;Jy1(e4#x-fRa%p)UI#iP6R}NMD&j zRdvgkqd&XlnIZ4;(h|Yp#U0*O(N)i97DiMf%aJH=oEQJHR9tj+G7iGfoqPy28uwxu z>6*}pXwQSXBIggeDScgtMiTQj20dLsr_|ts)qFq4R6OUv<}gN(Y8ip z9XXJ{=r%iVkJ^Ftos#t6{dz{%#rfzOqgk14Pn&i6!mWpiE@F z*YUJj6s-t!R(=Ru!hX#4BU(x40+owV%*Gjyr@?#2+H%ugy1%>{W?7Eu4+mAA1ZJ_T z8|}IJ(pu^wnoF)mUF|%?2^32gpAUIi>u@%auHQ^M|J~B^jw6b7slIR1XO7fxoh$45 zlxDP5I|^^g$N~o46rb==?d2XvFJzNrm1X_nyXM@sex@O?i<44rku!QU0F*03rR^`FatxAA9XR2>Sbm)LKG*5u)+f zbq4TVAi>?{%p0t2%Yz4sm>Hm;;`C5hIG$_it?wAG0WPMAjw8^RZ?wi z%4DteXNPud>KRb2$;-Xr;o$CZx4IRfKM?-FYk@w>$|Aenu9sJXF7%)x@I(x4ZUXx0 zcKP)897=sjk*Un``B;4c?|Rlc?_rD;>_97JDl?Lt zIE<)PD=zm=@pPuWe#|$7c+Le*HBN-Q#B*RLg{TqpF02CoNd1Ag&2i+@0(Fhb!%0ky zg(P)~2`zAHJt#`{$i^<|upofK>ZJXi6g7UM>`pbVHkJK-I4l~oRWaYsPlzLn_fu<$ znat{(jT+dSR}EZPu_JI+*g*6>8EB3j_Vg%Soh<#CIryLep0V{;KzZ542G&;chCgj_%pc=1!OsySdk0yPqZeCS_I&`%eLS>dm=g_x{>$v%|M7>wDi*>tO-WrWa|B6$`E zHmE4OX!8jAjmkirmdxeC=Tzzk)akb%(AZpa^5VdGe&hxaH5(YF72Cp_xd&I|#!A=w zZ?Iay2$yG|@eukT0(Ttrmt!nSMn|g{V?sAO6k$}aqN|;g?iz^oC#d6&bt+?gGw!@+ z;WDZYkB%{|l|>nQP4r4$lh2QdX6u-oOi%PMX zQ0rs@u?#ki&(s?8y_lt9e$&2Omt=rLf~*i*lo>lx98j<13Y5e%0xg|NAVtL{OyBvh z37ddKuUU;;>)`m>y<8a%uLfmTI8(_NzRM#0kG|U6O!^51Vz0 z+owF2pYl<&yOnx#%=6b!w+~J$FS>IGYb~ogBl>dz^L2Hl?~X_t*plaC zIo9FZXlV3h$kYDLsn+zcTXMx- znaQvBxX+lH{XZAp|0VG9A1A`)#7-OJj~-F;pHv+G|D;p3N`K4-`@b{^JWd+=n9OvS zIVY-L>#i!t6n;i(GapuNAX#qU+MUGJB8$opLS-*mvfxv zPA-iaJw1Sn!4$>YCTut=cb%DVZ-mw1TdOLa)D_|DFB0=FpAEgbn4L1J7f+lVZn@;T z07Wbj^LVe~3CPE}3r6hFBcKv~s4ymTItDwKQV7VRNEYJ-Iw{JgB-h6N_OERqA<@YIg`4ylp;u`R60VI&-l zS0bb%F^o_&+0h298?d~nc~AjqA#X>}@WR?Cc`>F?Z>8OX2P4K%O&J`G5Tdcr9Qib{ zYBQx9rHiyNn4ozA^faX@WY67M;J9`eXK#}_VJJo08(R^Pd!dSAU_lX5vEdLTV(I-s zhOQSw*)c_6!j*44mGTQ-a`?pciR$YU@9U!n2%Q0dcHAvBP&KtUK7O~UVGtMeL<31C z>m7A@cpc>&=fjyrozFj*-#UsEu~_8T&m`BHOn=+f+;H4!RrngzpLHMwP;(xK`!yqU zoyUW-BTWYSeSfym%GWzmyK*Mtq^MIhS4A6qOrz_L}yT2#ANdMGLDHa)b#&p2h6O%+64Td23E;Ne9 zcGhGf71(u|1a@A^hQ?j&h(5+SebVwq%5Cad9{kMS#}ztrou4d1+IhK030>Z~lYkCR zzI9%za%K#`i=Zly}z ze|zJz6B%qb=;4E1zaxOq=<-zvgtC7^WDArao$hpI_tyvs<0;(}s(g0}jj${tq0bED z;au@{xN;&>r8fHf2sCaMS$DkGe|3ywT})eSEJ$3p(jAqQg-^6CijY_oTyso}*l$M1 za^X#@e?2}XX)8vPvjK=iuNMK~jVT5mS;o_Zide-nvu_n31`gLh_ya3%BXBAjG=*3g z+ts0rza0QpH5xe+85UzHTPYb?sx}bc{k8=o>7m7TPvg{5fS^kviPX)ja1Il7xa%vJ8Yfeg;%x( ztp8??fj77K8=k8By?gr_@|Nx~Z{&U7kv1MD9>U-7PV1my(A^w3+&(4M)LzP4+SAyk@J=Qx!{w|zdTpFoz zlnJP;F;`?+)+7{NbeO*wRLG=jb$L8ds=H^CbLm^DBGCN>!p*izXn<=h@;ybfbjYI6 zQNpAFagJuCHE36jNs=m*MXr&A(ul~~zh%__p-^%~=NafR<^~&@F;(H+L%;g93{9;1@mT|1!}H&O zw=x@8I`g{S>n^^GK~}6Q!x={jn!=dV5$y!P&Z=QYbsDWtE)vM*!j9E9hH!pDkytib ze;Hc}Y>0R zN{B##eJJ9VupE$XZ5b$Lgjjm$H}f<9fy101^B(!*O0e$ z`WEJodT8UawD~BqKVe-+*ags;O z1Aa5IC>35C(cbDna1k<3aTb-FhwQGkzi-UyW|-%_i@XUzC^K{h!mRb3tlEh>1@=M) zM*`!llXx%haA?@RnkjgeXbyLP(9>SRwJ}D+M9ciz8MV25QgkiJwVPGk^lAZ=N2F6* z?7K=nDrfX{t1)j~1f!N|%bo>1ySE(W_@xF%PXI$0V~7QBo->B=Z>(rrWKnfaemq1S zDp%>hGYt83CpX((7trI5g$Noe+c)GIWf_4A>|BV!*@a-OvOT^RZ!hcw?mTp_3UoD4 zo=NA`m0K&|-aI?owHYVlY(@7<6sx9(dbz>_RJ>^6t?L}xe9@z!JA>K}U8eWLH)b^< zv)J-)4C4twTi#wTcM)rntqrRe9LaS;nET7jNjMqO*Ob1kCk;;rEjJOFkr*#L)pcX* zvuLQ8S1pZuh@)PbXM$4NHKV2p@QRPAe+4`_5>H8xL>C;+!H`@&?w*6(#v_CTM5BJ#mmWkUA3DFA1-O)#+LMK*Difa9h0;H3JnHz_+tA#<#c>qD(r zKpnEZO@nOHLgR&rVtKfk23?e<0LG@H7BUa{{PouZ*2YqJhvnFJPBZTEAMwR@Q<&o1 ztJp^FQCUr&-y-#3UOpa-={9?0;JgulS^szPzYOcFP&Pn5iY-tJ zd%~|KkoP!L^g4rDK$2`4S>*EgB&)%x@18<(E{BY&iHRuwd|B6>E$^4Wv8|f;*}{6k zN~azztrVngoJbTk*Hp(EFuvhyFKUGVkPsh{|ne2p=hJSHzw^yRjnY7kH0ZS#t8yu^lV z-hw0A*e;qBGXSF*cm1!vyCaUVDK7aG3CK2Y;9r*U9@T+gpZ0l#s5#>-m=?mo-Jrh- znAbTeO%}{ZUS`#)_i(e8=V=q#p7KER4`Y}L%Y_In^u6eu6~qK67d1W>#by#JWyGBG zjJl2=uxs;iV)?RVliaE^RmFp#Mp(<#XscAKo~DdwZ+7cSY-4XPTYo8v4B`mRcKzDo z%wVOZh_ALov6I`4D>JiG&6Mp9csjQg0otF12ZQZ02GAeA$?Yk62y_mq_+)>_OE{{q$VkRaY|g+D%GN+Xc#!y!=b{mq}rP(k)3f2T#*_(w(|J~9i9 zr2>)C#xm(Xd>ZW)%Zh?qUf4Gr*-_}DpHl{`GO4KVYLV%?V{F6&XtWwZM{#A9h7 zMKHU%*~HMq7~8-LfB$>w=)CKcpqYXX1}%c6$Do zbk0LT_pL!(VU}@QDZV@T1sHI7`dq%#b$-iZ&=t$|0!r4|l*SpDW$*$TR7qCka?y>K z?gRb4{8jN81|icmGj&(i90n817SNDLmWewP4Rx1wXaG)wr>z@|?=z`+j;F`^RP~k& zvz`=HliJJ`$1qR(nt^FuG9-uYvLiM-m*(~H?lUdJxACA%OHEk()lKEqb823j$~c{l zTYJ!1YJ<+ktrMMgljzG{rvLRjmAuj{n3Q3LTUWxSNAu9>&g)BBVHT=Z^J)U?{m|j* z`)aZO?a$UZzhQKRrH?#tMovS~&nD~oF^r-0Hb^iwOPsu4%7o>qqtMzBeCw-?T|B4I z3wYzmSAS2(g+w`)`7x88%IF5|z&+lugLEdxDSk$Lbmxfp&UxJA`+qR+z>IL9#_#|D zuVw%H`+|}F-$f5s+CQ>Z3+mUlu7KNWMpgV4`_|U_FvW5;V1&(@ovqzmzB!aefi+=5 zSwhm4)rId4!IQySijh(Z3Yk4$Q;qOFc1~)jtypL&U1?6_ND$Qc-|d5g=Y`R*S60U| zzDpk1qrUgOyNO1zQX+`qyfQkE>iDGoNLf?H^d>Sg>ygmxgOizD*OCh9i%SH-QlbEy zCmBIq6V=vC_>K;PX(b;+NW9s zGMieG!)U3YF!)^wK`eU}%`j9ZK|y+zhDb~Fis7t zoW;9e)t3hfY!m*Z;%=?Q?qL(&kng!2a=o_M-R__7Ebm{Prl*_6YLq>{M7_gl1#96( zKtHbpBl~}0l)ZwP8lJ<0u^#~|_#cMh+aE}Ai&**9#s1u=LqOSros%nY?zxgNZ_y}r z21>@`rQSV@AaM_RIarhB*#3YDSkTbjBHq+~jLZ>paj!u_Q@x6m5%EQuAX8A`-e8WU z(X?U_&howI1K`MjSCT0+JtmTQ_-F3lqH~n^bED5JciGS8WPi|hkFvVZ!JGq)W(8+P zS7E}#JYZ-E%K%^r-x~NCLbQob>%?QgpSP;X`QSb6KhkpqWVnd%YUomx^qm}y$cQBpJ;$Ou{R6j^IXGu2u zNLXT=Q?{jjrIfiB?9CKCizup`O%)kPA^{EiL75_?B5z2c z1K+ZV|6apu1#FtwlMl>x=@3D8Dpw}2om?}~ftRE={lO63{HH0v^vFlzsrl{D;Z%&H z*kiQ&R|>OTaO{2}Fm+BPG258$GY?8Fl*w)QNKl?R7>aMSEoXXPaflu!aO~l`p(O&W6@vh%iAo$lEkUulMUKT3lz`H z=NIPae4nUG)L!^CL+jun3ohteSpJ%XE5W&zVbPjtKE>>~+aUBGk|-ePoh$}G_4`E) z%1kZ4<04cF4pHaJlu49!>zZ{-CZ;x+D1%LSTyk(GTphjLCoODg@JmTopVa|u%X9&6 z90uD1dP4eC06LI`<1qei7TwF0kw;b}aa0wiL}6F#P7i7U1Wd}x9#rZ+h4OCP_}Q7t zL-G^wqPb=Pq$KiFADn7ud955A;P_w^F-6qpV$x6+JWyP$n^Wkd_v>rHScid%_O6$Y zj@H+sG-ZM#xL`?cUR4L8o1BJr);ha8cBi6P)5brrjUTX5z5pjxZJ6KYXs{s_Z$DM@ z@;j38eV9(uw7W>X=PxRCh4by#`FZ%$-qA+|F<>ESzr3^8CsDglRR?r>%NuY(fjlds4>W{e)q( z9-RC_{nz#@P_w(MW9XCXJ^qucKOJt%^nH-1m#IyeN0KI`DKk|az#SPe z8M;(}&ga)htqIGvR@ES|G!VOVk|-I+#sJw|OP$W(l#8*UXU-J999JO{$zWFSM=tf^ zgpb;$gXDD|p;m*8LrpyVm%I8OPul0>A2(t6aWIVJ9d@DMHTaXABc6EXfnKc94ftD3ocI}vxb+Q`eR!38 zhEu4B9KCaZlN4JgLk6d?^F!{ANcZ=2oof(?nArft;+^I`zC7 zP!@;OAcyWY$U%rMy(%^Hm&VElx=f%@t#>jp^-5pfH4V99z847=UPO2@I7$d_N=`Uy zbAk~eOH^{?@zqjp%&KGGwbR}QG?g`zB5K$%8N~E_vzzPp zv)kV=Auy3jtGANQp6!lalS3LMek&!ePfg7VqPF|Zo44H`4vW8jCF@AZAkRJ~umgP* zs}d!x{!<1vA|Hrzh}+O^B+pr^p@1dDNK>i9T^g9`J4)9(&XYsMgZQnuAA?u9aH(3j zRzv}2HSb4JtB*kkxiJ}f%Hnmf!F7(6IdDR{dfq?4Kf_F0kUl^{vY*h6i-ec_q0)b$ zh(^xR@T8^3W`8(7=rAPlMW5c}8yx&sS?4Ep5LD5(-C5*F5{h*+eLmF{ce5|;0=RX4 zD=Y$iY0WT+LA1OUKEV*r>J-LD7j(O{?LY@vJiT5>0#|bs^{%G zshfZD&c@O~BF{NSA+Adn&pAt=hdZZF16VgGKU|d8im4S!EI2N+OL$%HXwAl8jqs@F z|BjWFlCK!PgacKo{w z@?zpH+UCh6g~86MtYI7F!=DgvVls}m zNEfU9oi~gJf}E41>-@ZzN`(4p6E|%*dt($zi9^%3*1N~|Gh&U)5->Q%H+A{Ymk6O!M5M}$fi#^35mqM3$8 z{;FKLR8^qt`YUXs(joG>Z?km(u)H=uW<_NX&Ehr2D*kM_JU?s`y`kfrRqR)Xx$#>% zHMyC}tpy6yl%T4l>N!W0U-$G|8b_W=~7W2}r3`<3! zW}Q`O8p@4F)&}rJ?ei9&m(7qsD%B>Ij)9>jEGi{f%^EU+57}#TPc?8OOa07_`<$-AP(X3 z7_t8P$$64QJEsv#)f{7?22q*hP&cmEc$Rs z{B3AY62ZZyA3@A7oMzk;jvhyj5{q>Z3*9=HhN$o{BnJw0>V0c*hH@emg~Y@XJ7J}? z1SKw~1~w_w55IKtbjVmylBHahw%igz55a-;4da3+${!n6#D@*0F*b=e9u&N0^3I9* zDeb{X?pDu0{2Q~XOdw=cI%bD{SG`H+tfEM}zT%d8>9Cwoz3$#&{r+05e4IPDu7%dR zcMnYNzu(|`NZ&ife<-a)lCMwJhVa_;7bF11PW@>TOw0u$ z&rEFLM%3A)4fHQ;`BI`IH9McIo!OEtai`8{hL)+n411Kn`p=O#2!>kssfAFVfBZO~ z6^&;_$PrS-5Q~fLSNH}NPc&s680iwm$Rv0ZGg7Si4$Qfum4YTAtde0D2MtMqUKt`M zg>S9J`4b2zcL?M%HAYk&npfaYLa%aj2vx_hu^7$;ozXa`&)NpYHtvyvfXefbOB@z1 zFgpe%lt16wVrFd-)4IT}>5E7(eX~R2W4uvww&R7Ssf!|U47UF2Y&X_;l7nbEsu1B? zECi?AfEbH3MjQKghhkWQamXat&7+h$EGUxOh3mYyQRm;pOI`LRq#O4lG@msEhUbx@ z{^cy_cbIsgmsQ!RQtoV*S{rVusJCjG%KDh)#iq!pSi(&7fFrywqQjcz^~oa0(>sKf zwIRXwYC~fL`jo_Fahz5%GJlRYLhIkGk!O$NUscxv?${v!k-%Tp+@ypYU54v*nqJ>T znf^MYYIA(*(k-a)Mv{DWTnqYUJ8xvH6z^1^&pe^vQ;`{<6kJqNn(}n1%bsa66)Oit zT^N&sk82Cbw}0p?XLNY=8GyP?A;8|@#BwmDO5S!K%-(J8>_*QDmj3*j-53*cJfBZ> z|KED^A4!qJVTUN-#{q8pA654J+e4JBEb}8N{>b#d;X4i$HKjTRJJx9Hn$;q8LaJW` zTh7G8sNLVgGJW~RWgDCN0#F1HkAgkCyoj~6_+BtwPP-aPv}*3*r1%$BRnukKqw*(s zX=*D)2!MhW%I-)K37~U1@J1Q%=o~Lty_}t$hjW#nD^UT0h386uZ~`GQD?U4y}xSfi4=nW+s#) zN9ekE$7g+I4#l~7K%0nIZ}Bv1x;Ws>M?J1eESg@qTiJj<~m6bG&W{0InXPtWMQwLom699KV$wc&^+ zBhQn3p*#qGTxV_UL88p2Cft(7*R#sQ9TJ+^IG=^CsIbl8mNR=^N(d0v)e6yn)UcQmpAznQIW z=|?Vs!nWAsNdl*IjSvpomlL(y;#s0g3Fl{#af$tjc`k&6T#m)vf9byb$8w^W=^;n* zv#R&`ah3mXF<1s>=6}Ua{_8BW{}UYt-4?1PIhL@nMNC!B&nHX63RSda$**J>2`*AW zOtSX*gd^E<;jt$~3(Aw>{%|}cc4xC1|>vSz{;o}eI!?}Z+XHkLd{7kF<4qB2-jG&VAt5_;YnB4X4KOB7$5>*iAJhu4KZ~e@hoJO zjNq?68d%)C*=SypblA+lEKKjm#;z*r17y)nj&hq;Bl%$T7f3l=1M>O+0Rsk;17m-E zgt~U!|Nkg^r^e8_H48KLj&0kvZQIzfZQFLTW81cE+sTgY&R3_p`&3=kxtRZ8&ADET z@r*Uldq>B_+!dxdvDAjL{JUs?SGTC$wELj8>XHPLsDI0f@>l88oP z@H!>W`jutz`&#P+c%}XsQG!|xMK81P)IeAJWc9-8xxGEGmL$MYb@C3a34?jpkI1I) zvyTKe8=}^pY;Y2V;Fdwr4VMDdr|+0&sbXV8q>}jO?5Ts|ua-%re&h&{=N?QbD;yop z`Pq#R;^i#t(f!*`F}$+LqV0v{jnjEB67d!&E%O#{m$Y{uL*-&b48uZ1V3b46*`(nY z6xr$<1e6}=Yix)!9z zTs4DRF(f)oeYMxVvwChYFLENV;ugaBtgp>wVg&~jJTe{^hEL#bblphId)aPoA%qJU zDqeRm@E>@agR47B#XD#v#Vqx*zvrzBhGY)hiKK{iX?%eG=dZ(O+5*Sz$5>3l{C~f0 zEDZlL4_*G7fn#7E#-)+;vYE9xvg#rve@gSutM2Ul+P-u=ro`H9&kha+hmR6wiR1zD zS*RvLY>C(mPbU|n?Ddif?HY0vismC+F7CJ2C_f1&ip3@$^;YTo#$H9A0G*>*Nb&en z!DQRM3HHqIhJ&@UI@W`ivq&_$eX06zFz~2H#$5`X-6AB}{#_k9ShT(0urW+Sj;CTu zfDM9JXm!F=;Ny=4>Eb%eat4%$r*C+i(&T#}sXCced}Uu9(@y1B%>@r<@@y z6y4&dXKR6TV5l2p7coqGkQ=Ixxb{b!->vPRGh?#bkTs(%LdvAHXsc9KoxbcNqXjDX$7Tz-8$|M$Lig&1x=|U*dl-*PiEgK>xM{Woe^c zNEloW3OLX_77Cj2Bh#QKu;6Hrw}avN`*mY79)lr7(F6~rI9YErk(5&xCFkFk{+n9{ zbSz1#IP$zdMaXvTHeGI7i$7l9B2#yfom{+Q67~EMk zi||m5KoCK+0=wZ71F03JV$l)}(J6$AOVBzGF&HY}Ix;vp*k93^*J!uEDi1}X8WE{w z(qaS0+i$+RR{`JnihGU%?fI?KbUAnAcGeU0xjUJ9t~}@ zCgq|bSEM_pYKyn1;{xOL?A~m4;BSGYW{qeqNS31qN)La))E}i9&tjC{BU=ggxmf>+CN2&S%d2yy?96Iun;7YlG@K3*`^uANpA}sx>BZLH#KSp~Ym6(B)8I zb1S=QrGo$p@S6PIBJ+D-Qesu6f%jB6TT-0rwEdTdK)}_^7DW?K?!AI2q?G-thk_15 zUZFnkv-JvPh&=^n@BlJb`gr_MQY_6jF$Ta{Nz2d-rrkfdMKQ6E^H<4QLz)&4a5f5C zaRR-ioch_{`V+!5gk`gqW~RB{yMO6yO=G;k^1)w9mSmJp+vdT(NHB_P1@ZPZ!I%6V-cKdhKsocK)KV#_ zWyJ=4#j~aJ?bJ%+uf!6EDEtmBwD+g!G3l2ZK-C`o7Leq{zt5Xq3rV`C= z3Y<)nDau@Be1A`Y>+$=Q}tOQ6kE*{&+PbuhoxFDHr zyyDQkRPlbiuAlcj8LH#7ZNjOje=ech;0^J_uU;Okx)5KdSLNcq1Z=`aQ|@iyzk^&= zKQ0ybSEsJvh}u~JC`U@y;qiWXcP~Ae;9#V7u%<<>ly0QThjd$gD_yXqYBHWwQCe4Q z*|T^|N3x1EBQJW-X?Vlllr~16z?!%hESusbHzO{4&uOxkw6>Nn$9iZjVabtNLrv$} zHItV|zg$MvqK59pman^A>6s*G^z~>Edae}js{(t@Y_y7?^sJ9;T>$nm=IBtYH@=f# z4&IW=dd$uaO3_|DG!De}c4fOZ_NZUINcY8ljN$mUffo)&&7ON~8QbX@W^(7$v0Mq` zy^M|cJeX0DSe8j_MCu65k7rmR%&z39Hl?EXxAb3I-(v7|%t1c881HplxdKnMCv|In zS1}HF8fejoP}z6g%5u=c?8=p;Re!|3arFwkQ6YB<`O-15zxr zf|#>um-xGL;`KID%6{IIHF&YW4IzzDwBgrIo6`f<8_djC<&l`Kw^a}1@4MQyZG263k$fFzNRQuW(x^Gy>sb8p=BGl!s%cwQzYE(TvlpBQ`AH9Pm4N`wqvZq*lwv%UVML z!#+gQ{(|c=GFc_GyDT{FQ-uc`j!gnew3hL=9B?mOv`0BhMzOgpsOrcTZCIewudVQi zj2KE1N+6{KrY5;lg*i~7?VUk=VSl*3=FE)LF)~ROj<@opJ$xFGWebJ%B-n~C;!**BtEBTJ616>w^*OqP}Mvkz-ocr zsY^n_gNwAG&!^@>Hh3tVy<45@x>o%rzIiBY14k1`I{VK9 zfMPK(K3Mar;Y21UO2am46?|ZiK3C{cuZ^&uCaC(HINtx49UvB{>Ka>;(0fGULRL%T) zz5*f^d500XBjF|Eoe|Evsi&La?eJ^F^!C<}Z2l+y-9VXeV*KuR-F8WtT3rPtA;SBxwxXiQIR z;07K{%I-&n+Rv^5rLMBx8f5a5fnt+YDSQ=S4=WWfaK3}h^iMEAG3x>1u-R|MzY~Os zif(F=N9?bTaf#g;YO{&wyYs)s22ZG|TI+U)x4ZDoh=VohfgQ5cTT=9)0UF2hqJCTc zw(f@lZup8o!W04Yw61x<{=!Ldeh;NFE-0H`p-$W+oIkBh!{nD2Yg2D7Fwt=lBE%!3 zU-F1g0D#fdv_F_HDMK+KA(-lmXv??vf(zlQ3u-blID=P;(y2=U&uMDXzlzyhQFxZ83HpfIU{$qqa@FZuogUub% zFs<_MKf>*`eGrZS)mm=D<;S-bS7#E89GsZH%wG@VIJyD2GBR>sLIjS>ZJ`NO{S2ym z4W?5zA$XJhTueHfdxMNHro=1aKdLmC4Po@enEf6mW)pq?pi@Y+51=_YRAKiRQ|WU| z1_{1KM8iWz`?r%q9Qd7K9+OI|Hxm-HE=XYuxO)Q=)+!*>NzVje$U7VfhcE;>IKq(wAsaC99S(8HShbjK=13;S-~!uqGC364)PRguT3N^w5KAQ_*5b(g$5W_13S3E}4P$W3Yr}^K(1Am7s_be@h zA;OS(01W>@6oi6C_Rz;kGIOPGE7)ozk?N+>@`7Tx4DXsJZ5dI}^FEIkBhiD;I)w?u zXulq%rN#ye2l~~SZV7ZaHw%@!9uz(&kQql&IR<%wqS{)0+v%sP>m1yN1f-&1EkDP6 zQIC%Eg|#dhI6sSg;aUSy9NuCtOHx>e-HrZSP!w_((7X3AwRKS{#g5zpM zU!}veD>Hb5=?0xH#9wS#Y1j6vi()*WcO2O5ezw1tskO9#S8HJlSVpU)2C= z0b1@Iw^aI-1N1IXUx?Q7}XcBZ!SyFO;lqZ;sN{Xb`H65b@>Fvx>y*q1X4+H zZ&U_kAb^WNzVR%qV1k2&h1B=hR~go{77^o#6v_*CIQf~irG>c?Ljb_{lLaaqHLuW2 zBWnV}FLC*ab4s!K;~bH_S?hCZ>b6Sr^PAQ=B?BOg&Uof05KIajt}Cpg6k_nqTkTq> ze5lGEw~_vK{PWqOs~AA&d1{wbP|@H z$EV27^v7H*PhU^T{`?G>gv;H9i~*Y;Sp<3{UVhyRWxDjQ8Pwh8p}UdTleIa8ou&&Q zys52w8rtvK9ZRA}pU#+xueczuu3v8Yt zJg=CueYrY509|b-{jhYB=r_)H-GvD^0^Y9kH{X#7*kg?91ASYd^fw>(2An@z^!zSd zGs(pC01R7*r9Rx=ytHEzgS-0%0kgfWhPe~2UU>v<$oTje9U%hjVFJN{`aaZ9C-JzU zhv7EAcf2UR#HJCh54v8FU0c`+#5yZ;-cviGZt*$YGo)o(F1bIfXmzi5z9UY*+|AA^ z9$?wOX|8hg7)2tNwhnxr!tK}$b^n5Wn5ko=Z9Z&7`wEx|QTb(=v{SoVq^uVv5JUY70%ejZ$OCn`V{Pu z7$ct96JM36Fo;KcPkS|S|dkCM{;p#IhE35Mfp(~YRQ?&1(|U= zim{m{MS3<$@;Xt7)I+r1L5sG3({%nbSY~;)1T*@nlQn+|nE&fwndSe}fJ-?p(8G71 zsF^w8r&1OJ{uVcCYXqg89hrUV9V<}JR7cWaOvxJQF-76R0f%9Nk#QUyy|C^1eA-j- z>ZV}U5I9O=@p9wz;33v$q)OJfF}OVW`+38SG1w-CE*O2l{M^kQng8g)quGP8W`U3` zOPXkgM9+)?k9dM_%)UEERr8b8CN`DFfVvCHkPjfM2DMyN#Z8jVf*W<>R8=_B7L+{h zcZn+-#yC!ump%~$7Q<-1cm$Pz{!zLVu}~2b%3~#UTI;d;LN1<_K#i6RJmY%CB3!5X zTY_>ni?e5G*8yPhFuuTfDyx9FMt@r*DgXuYYpe?yS{!RN(YKLKgS)}uM|py+ikYa= z099LBr(Dt1R2oT^n2^;!xlRHNvdSD%IgQEs`+mK49RxC=&EvQhuxW(0A>9t2!hExH zYSsiaqw5G6g_SzXXKOC*7V`DOO-M5b$zg}2-6{-rDCaA`*>ZYh3)>|j4|72Wm4=qa z^sHknh!jn+9A3oCL5)Id5174j;U~9fzaEG%7_G9N9Txcng|=xbrLm5ZsU?dxx6s@G zl|?n1R9#;Us=;^f5)npbbJ?wqz=TYepX5*|!|=_UwlbJ|o7=1B{o&R&?k6zzVk2{_ z5%)`%<|C?8Kp_XKC*u#)5odVIrm1g*NSWE`6X7E*w6GzL#>N+~x`LV(N7 zzwX@n;$cWLbmQbjpnn7xRY|UXi@}>0#~Yr$zP5gORuH_a6d2;wS6~HAZO7&s{PSHJ zWlz$12F*IxC+H`xj7a+${F@xOA*O#RIK^&^G%)vnj%8tupYA7rwt3z-|G~%l-^SY| zjel`L4*;C@>A*GVFqOUD%G7!N zD3BxTp)*tiGnjIJ1vAa3X`G{)5@d z@Js3z^j4^t8J&%Z4%|Xa8zwwpv}j$LaFzhTfiX;h``l7SqV!J>xk8I8f_}va606^Z zw$+oD(Rsa#92nBRm~=tOocgwspR6^w7jqX@$?acMIBh5%iqII)-akJPIYo9EvV17A zl+?k!fDHSR5vy-SBg`O4hjJKa2S`L=S*Eli0UTjcGmOad-1uavCxw0-_}QRYD;(3- zj<=!u}ob#t?DHx?NF6 zW3?7LH9ibG5A}P^t!kRX59ihB7koAhKC;ARpwNsO3g{&u=YK&t*MP@28H|Qpz_7$s zFY=BVp6ViCzn>#0jP?Yj4r~!u)aK39;VIhI?Jy|n3Pka0Y^=UX z$M0p1B~_R2#)kO%<&a<&Q;P`rFb_EFhfWOGwt)Y8baUm=g{V(kYWB(xEMi z-<=`3f4t_n4NaB9V8-g2zeK%}c~rO6pCaV;)K@=Ztrt07R3UwGf|6w;U87x{4wZ{7 z{43UF8>ROW)m60BbctI#NHYCdqp)Pr{;D^6p31WPdVchVczomG5|#a;Sz8}`vF!Sw zwpWb5kbJNtL5yoH3hlmPzAO9p*-+B3_dYbWpl(U|Cc5iCGTyn;0oye1fb|I62Mcn$W%0|2eFE}GY94;FB5)c2p zF7ud(rT44LG8rUcRd5~F>F@LL?{1-_<&MK3?IbNOl+|7gvL%RgysPUFaPhSwv~+7x z%L39E+Z~e#1W(@XlMZG{(e9qi#jm}A+nW-c7%{#vyQnk&@N6=1jK!MZ-I4jFkp{xe znq;&-MUvw+RhxU|WSWt#J@1e-5_lv^FGpRymE_{8r91mTf44B$b=`@BN2~$J?u+7p z=c0(VbYpNZr~u?0@42}(3MH3H|4cA7V*nuJ$iH<$o$tC&L%0npZNt?YJbO|_krUvN z1)x#mWx-BEngCMyoL$#!i7J^lZqv1dy*is$f#LcL&nIFSL2yCJ=iOUAL~E(E3p4-{&J*oDYwCn z{=MDPe>aOFD+9dM$fb_Rj4p0giLW607yf*6(7LkNIPq~h+cF@0d(gJuBl7T-bGWuJm8j`(e6i6@0|*cJY}nhWGJ){#bM9p z>|%2!?+s%w{p-J1SL-bq;2tahS?~q?aEtPY7zWo3MsnZ_V+bh_^346T*hpE!QBn|I zq9n!h!4#0jr(kZ9f-l^Q0Oto`S=)+*#vwoQdcsg_2%W z*4F#ryP;vw)LWBXW%y)-P7v%d+T@4C{e*++YsAS>Yl?ah5P~u9?lHwVDnQGcxCMY$ zvTLXpmmJ2jv7ku1V&de5$qj`gbwEpyqi(!hlA@6mh^_F?=vbPXe(TIq5-3rcG!?n> zRC((`y@(QWrN6`r*G(!yL16LIXcH&Zq<(;1+imh1?8*E63(_!VEWNiTSd)j$y&}4^ zeaf@-bzIMtQ*xnIop9-6X)XH4Ls2zY&+XSOEqTw7k;ZzKVPLL06sfm@W3dfG-jC%klm2Qz)Qr(ds9Fys z^=(G<1^d@&_l$IeHBFu(VIx zD0yRNEMXn}=eJf^Xe{O60Si>!A(HdtQ~U$83)c!q&1Cj{sV>!ah39MjRbc#eW@h7b zS@hlv$Se;5;~{mG-2{ERYWY#QAObd}-||Ymb1Fnl9LOvAoU7fZDnL8V{ZRD=2eQgl z=yB%O{oBPV!$=O&j_1US(3m*D5PL7+DHALq^^!slphq|e1z6o1p<=c+J6OOOh8~5& zqhvHk{OZ|l@(RL6#ZcBSc1*}PL=2!J|I^;V0x)r*{ZKy$cp}>HT;VV=q&SF8x%^3h z@L*!6KkXuad0wH%9HN!7PfesY$u*K%g^2CuOdvhdz=%*chYYIHti#26tkMzh>bG7! zd>+OI9d4VpUfmw~HRIxaR*~gOE^q!$q&B#)Sc9jMm1H9o3?miPPp_R6JPlnu^XOuu ztc<>$9Jg2S@@e|oYIU&n40K?=gzd+9XGZC2D;jxsuqA)=8%b42V$g9_rKt33ANV?s zD^AJ%7h$t4~SNo+}PJJ|gj74n(ZZ!L<8(}%5 zss!lCUt~?vB4I3&1y^~q7)+2U%Y$u)DIXpITuBRtQ#p6xlPS@*_+ zr^Q7b+x{i5Nb#*k4RgLs(!RE0wgnStxCKp%UrsTnyiRe02wUTDUt@^vDh0;_g7L>l zX&^oSi|h|n9FDc~gM;b&Pu6$L|FW7UC-B5(^23LCen-r)+Su&fpoCwm%Sz4*rxJ=J zv1;nm6VXwx>GV$5%m6e8)2U!G!(4ZA-^X|7U;+bk$~CKO5PNI_H3!p_@swKQQNG&0 zXIRg3)zM^cFo<+MWyBGGU75@8-|rLo zW^rk^fpG`B33~bGFHalEJ9W6PoSr=O)XO#Pe4_n#L|+MChG3km?>i{bzN z!qKy`{+BTF63fyStL?VKcgV@V!kRyJRW{R6R#E<4k-1gd(M%CLqM5u@M{?qxwk$z= zOfcg+VJAUv8N{T2qF$AYGN}N&#m)%j3iX~YYcz*2uZ6s%iPbXhuK7;WmG4n1#ZIXj6+^AH z*x~p3l@SPoS*BZ&20_T4r30r;z|f{$6DKz(Q1tl3{Jpz?9dh948GbA292>jEYuPz$ z?oQP9-nbmJ2mR{FY-x&#)kmCcbEoUS1b9F!fNUU!Ja{=dF(+B$cp^o86+jQIASp5( zrSMm?kH$tHLXQAHsaT|{GD_hd~cu+Vpp~foH?r}e8C-~Jh)5!yZ ze@)nw4ryfNi$+k}{}c`c1kr5TT5KyJ^x_qpP~ljz74SM>OeV9cNz5pn>8cV4N~s6p zhTzr2qZb8$)X)Y>`ue}AkLizH`VfK&+C{^$wu$q=Yp^S_(n;{cLmbr$SEYj?@yDd{ zv<3kn*#sNxhZP|7m8S`QgGGbRHb(O&lRMK+EC#H;0IEr6g+egeGxFySvx!X`sIulR zS4EmBXUrx}T(!C~oi2>eo!txghEQ@Yh~qU>R-ka^hYeRVqU;EFtBr4yIz`)k2>LgsLH_|>l z^pX+jU&>^wi3L)cQq*+On)0%A>@Zq)XZFA)Hoewo##F6s0k>Dmf1U%}WIhu@21AVg zT0$KF+`T$9|N8K-=-H?{HD`9%E{qm#)(<#I{IZJP3glqm=-nFAoztO6zSQ$=Z|2j( zAM=;sX8M@r-W=%xW5a0jn@SdcGVj}=qFEh+NFB>4>9qsgnl)RgdxF)WZqt2ONzuqL zIt5mmy30C)MQ?nPmIldo`r1v~GcZ2O8vVhyNRHi0d|U$LYyqlSRQ3*3(t9Zy_rfQG zuzUrNpmy#Mm+0VS2;@eOz|Ns?uWcGA#KXEe>=@27waPr(Z+3h<(N4-)cu`?aLoj8j z>)a^0#lG#lyvh5>qEjjzc(S+~VT)gUbe4DVgoDNMVkbx8szxZ&c!ddpvrsGhGmNxG z*vV7Cvk#M7u^vb-lsI`7Lvc}MC2XDw^42r^6N8LWSNeM2?8qWd#XO!(8PEw^ElyQY zywr5jAHWnP(GbwlBN9%H@F@uhKu4(e2PA@8L^>1#oU7e1LE;`s5}A32dmzky=DMdi z(-#Xsrx)z816K^3!EO#Ada3KyFW!3M5wUMNZ5~xRfk@M4G8mG>NP~iwr^)W6usNAG zAr^0DXl8o&5j-(~t%U50WW=w0ICo&AWmH`oeot*44FeVX^NP1p&%=7 zB5GMCT=RgqaeNOhd&pjN+!FN^rMeIUU&Z??OsOcU0dao5DA3!sNv}*MOaau5Hoxvx zlVLTjoAR-g1f$Q?RqY#_gL zm8@fdmEpmc`SJZuc|QhgLv=hh8`#%9z*pR{%!ee~s2j1KmCEqzpbU+{C6r0i-IyYXoh#ii@NRYFk-luYir3`n%TE?NsyZGNmb6Gg;63uCcc0 zkCh0rEw(l2ca%fwGS@REaXTN_){b0Nczxnz`1#jYR4|xdexZ$)hDC?O%`T)c2nCnh zaC@np&Sx5NwYC;5QMVAC3Kf-#LK%a{*PR)FhhDvs`(a86Jyp9T&$*3#&c z$%EO@wKI+59W@raBltSOVWz-p6!fc!BSr#Pbn>3a!7^2iGgWIXVu7hYu_ubyscimBK&c*dh*z&9NSa+C? z3!RceG-if3_D>;+z|OrGA-RpjY;3i@&Har5CSGkG;AGhTYo*s`5=jf*C&B$R%tkXT?(10af zAYU6a5vrFwC{mR}{yV&7G!}Z4%10NRK}qe>mNv=NFz$4_(cIUNWB zI&RpIhx{426#-XxCqn4-#b35yp;-$ljg2L-RRrSN(X?S^fJAB|O>D6Wo`)K;vvqmP zB0T@qVjtIX<-+I$qusF0sU)YpgY|{!^H%)UQ2y-Js098+d(WFj4jz!nBAX`Ex5;hL z7FrPJa}~-Jfg=iY@}1XlHri{i}rka}x~icrCd=N4l|>xUv&{ps}?Z|@E%3106) zr;=#fXF0m_&C+Q}SouZQJ{oU@7b&_zI!f$lwD~lSuFfM))DXD0Gm+h)dzNBWrS2!~ z4q94vQ@d2@DLtlz%O~gLYK)_{&Tl0eWhW1fV;Y*I)pSL+N#6oO=SJ1|{wGg09t+hZ zR?bW$wqliRyiGkyIcukR+cj_fR~NvF+_2Ymy{ur5Il9O2FQUQI)1Cj-r+;yKu>ADt z3IB;z?Z1P}vXf+N|7mxwzfcOgUJRwnh?*oc9Lzi=i*y}omg!k5dTG~idcU5t8DgZA zL?S!|2F#B4vgz*Lh5kjqd|=e_RR?OHS6jY(tS`~Ib9dLHzRO^b64F^LCq2KKcfuZd zY}I(Lm2248*m%HaC|3tKWXX_(Vf~?B4hiMR4j)>@!>}*ptNs`L5;^IIemQT^h_ck) z-rK_r+O=6iroKh?>#i+t*8eRyJ>&a#I=)6xHI|6H}+z(ttcnh7>1c@M#JD$n! zZnT92V$~SoWc7o;to*@W%F-Aq%Y$!D5iReV^s1a?uN~A-{7uO1ZlvCMJBKhaB6Q7& zY})YKT+*^Jx5eDFH3@V%JAfB*EfO6erd)m{_*oKc~zs>9aqd!id z=kVbtQ$H7RBm+_9lZ75v)sV^c;!@oE3=Qfdo77|SyF6_o%l*Qt`jc2?UgV?W5cL{q zP-ik?i11oh;-xTR1T*hK=!7U>2XKkC|G`{8l6yDLGRj&0T|w6~hG=^175TV<)NG7Mh)&yw8q~@};4@u) zMittUl4z~LoopXIuJl9L1^TAO1#;KwcFb6|Oqu#NY3VNP+#Zid3$GE!{IziS#4O`s zI5($p^NcO&;XMKv)Wbq@6M+S@Dl?_@brC|AqJnvug6MH=-YK&x#fVQlqCCl?q{TX! zqGF20sNs%!^`f+|jnYTvc36k~*o_F6Le6$aBh}j`aYqd;2PNN5e6xI&Hbj;)bK@=5 z#HsK7&Ix7C zY?{m>e1-Kt5KSXh257%IL-D5KC^|zGWqVO*{7?l9;ILp#)+VP~r=KaksUo#{VvL?N z(J7j-bb+gGSSxyXOUrf5U~CmS!O&xOnzzVI!CG}bSHbIR^^>kfIZ@5mpO}U`Yyaif zA6}*+j@1KW#-}h#_%BGAdRh@1)_#mVSA6lcL^#>-OyQ3JwDpWGltlN>U6@)$DZxjo zlq3y0oi)jcDtX%UsEReyrMEt)_5teB_}gw;GJ{>`NgstJV}ZFp$X`2APbf`-`||iL z1q4G-E(99w@o7qwSQDo6{fhn!$r0^Jaz^bIYI=Nf zZfxT*Iw_)o!77``!zE4-?Hzk70B`5180IQe_YfCFfsNp){f9qqWC$UsdREH3Mz)A{Ih2y_B!r`2F5 z*!~VRcqLKG=(H}=PU8%gy|3CC#wZYzCOXXORn1$97!g@w=L`Ncy9t96EEt@pBnI~d z10fMFI@tYM75ZQjQ+KuC%Aj)nF>PE0J9qNJ5a^jdza6MaJ#$JR`ry9v#WB~p`0;N4 znH<)x7SO`(xiSh-!RS+hx5R=O=eJ~!37z4Jgi*zk25Fnqz%qftP*hgQG@*%9P{-&r zn!)_IC;zKT<5B=$-=kcliZCONeUHO2t2#Q_Lz4s0?yGs(-*X=NN!n5K26$@{(r$ha zZ~;;NCT&F}xn#I;w6ay{3Eyaf-z-AHfqaUxUm1&zvFAKh>;eCQbPK!@1*E}VWTaLz z6Hw4Zi8n*2t*3b`e{#k8*NkJBs~j2&F?5S?tR$;g(XWxYiSS)Lg0Wc#Hz8z1G#SH- z-5Fo`LVWvG!F1bFKd#NnM3VL>q%*q-8~_$Q29qPrRmsjQ~41Oq76<8vW;z5**fQfFaWnxuq+8ao_2;G;J^QG#^TfXjlR{ zNuGQJy!n~??sc>r<1=hzv3*H5-F3U=hn(OGRk z%-r=k`Q1UQz!5<>aB}1lKLs*h;!^11>X*CLuVDYrZqL= zF(=rVeT|jd2LM=p)FgWU9yu3U2s=dQrTmnMeCUtMI{mRBo5P1cuM#t%8I`erlhl#- zD-$P5M6*3z9EJCmj|AG+VsaoJ@F+34d#dsO`p(q3YVR`c=XGBgLJgdH3Nghj zM9Mnl#4H@jhzEC<8?diG5wQJYBwg&L3vt0Dprj1t)lmI56$(F8Royple&g>3fDOkj z=7@-p5Oc7K{2JZ(xOau?bny9l6s+nh@yw?0moL zUZ^${oo&hJClbOfJ)d+=q0Ip+84F6F>CExsftZ-fP!Wbawm7Pn900YSmJkFeajtt-ZvFqC>6F_YM?aAs=I5XndIhn%m#;aFYAGxo~be$2$R{~nT$eIapubyJtpm^3Po1S= z48VFAIz0$CY!SS$eC=KA-F;kqFnnFzZz;REw5%UFUyoNhZ28tCsh-dFH&P*e*5Q5n75`4JH=H$AuSv@0EOR zb+|M)I$!T|N!a?%v7c8pF-Kd!*oG6vqcr8dpJK}$X-@dNG^HpM__I*E+jDy`hA{h) zHcs9f;QSuT9Z(y>rvh$^uejx)5-Qa#G~Z}0csd(xcjxSGZ56l8hob@m&g%7|-F9g{ys#3G?T!=2{GKtWy!N7FWvW!7kq zMxh{iX;YP%-hN;oTe1$;Dh0F^#H8p3QE)h6IMi|HkuOfx@Ds{r!n0v{LyTt!?N<+m zy2eO?HQm51FeC8`{9!teTx?q-252sF$fR3bg6x44~?{u<-Ey`oN&#RqbR^zAHqBsXvEZcU1ido^?RNSI0k_6^9@R z7$Lz(zR@?0Q;6Kx!9^-n9k`!5rJ(Z4r4>a+NVK%=Q-aeUoGQM`^e__ENhrWu>sIsF;}$mvr<#tCdFNSE2aYz1fOF5xzXAyn$-b zW1!;+V(~IR&a*nsta>xrCnlI}Q|Fbm3k-*z_{wA^MKaDi!d%Wz!TbpBzJy}e1CDJ= zIS*8}ysot2*IC3adizA_{%9MFK$9)r->y!;+E(>nj>_s*$gDPq(w`8zOw zXn}0ZBl$j|p@JBp9?e4U$`<44`3R4u{Nz;bn?VguX?3fpmGubFi>mQSt7+8CtCh`3 z%k_rJKbI0D8IQvFLoig@RSZ%G!gWSpaH=1F?E53cI6Jik9*=5pUASi0rk~rQzn+X; zXI*+0l3Um->$@ZO4yHjzTRvPlKbkW-*V8YDbSW#{O#6Ly6T>`#Bo+>sy~9k3rd)RW zyIH0v?n*`w-5^kcnD!jr&iF~l_md>CMGR}zBEK~o@Em!!wYIML6nias`Hmsp%4q$4 z-zis}AwTX-k82X|_ZsEFn?F8NzbHgFlhy{zAHI8xe2z1Jmuws~0X$&t$7!GGyjA!r zhHQr|yg>R<-x`T9y!c}2*_nxU)wa2>)px1W* zMjnvf$Ye!YHzsXa2$dxxvhr6ko=7(4eY@zmQ-c{JnQa?`UcEd2yS8){&zxgp1ZY{z zoEq-CX6;JrPvQ^bUjIPH)PNs2adv2kjlnFmAp9nmCgh$_{Cr8KgOfcJextrb z6mn88vCM3JPD2F=wS_QxZ7FRRqb(EDI@UL5jX%#8Q}Rq6OTI|8`DRo9z+ z12El-!|yg7;69lH3N>S-uG7jhW3LdRDu!hc8PrTLDM8ZrCW2;&h*O3c=(uJHXIa%u z>B&#@RF``to4B*MxKy5_mw;3h=Q6Z${?AarHTrRiCZjBK+_EA^Tbu)~#ie_eqKYJ` z5ySS0B`&1CvL&etW%p>R%fJD>j}W-FKdBSmxXFdop&OWBxH$$EZUZW-_is3R zpS5@B0(ukPY1g7f71v`jAwG8vq7bp}T^a<6B#Pw?1oS>kW@nG%< zlCV1j_K-F}si=8J(&#b+xlF>8fhc?_gk6@$fvsNx`ur)aV^94_Cpo4NHTU$3@bJ+{ z$S)%H0QsZIns zRsd2i$UVzyxCh_&*jjGN_}NrwG}%wD7A4eCzO?-2xx^#bt_VFr7K^(?T79;78hS%P z+9410p5a9FZ^08#CnO!*#Tk^FwgTQWF|haVgdUZUn1e@S|IPpj&Q09+4#<>IO6>!` zzP>S)_G+Vzy_PKeCS|}1`@B<5V#j|^UQ`P%n#G>3TpAWy%+21l!8)fHX#+g^NS*Fz zORbVsM!I-*qBciaEz(g!lm{0n!^NvX`>d!aaF0`+RJVvD{qkzc_u*zMM`1s6*r-%h z_|{19n)p@So>d?*2fk}m_V?+f2fiJN*+9(h*;-7f3GIOYNyrI3diVHwCw<>e(J-?H z>Y&a2PwK$J$%g%%)CYADUvrxr-(U)YVkuH;!tuxF!dN_st5uzh^u!k#>h4`2CRY|Q zydsiN=th6SBcS+ifPsO~-Su5OP<;R0$_5DgiXmXHIHhoHDrL+(H8sOd<3yXq5b@!q z62lEGR@z(!mAQ>VYn;E_#xO zqcx8%TibZcC<7M-+Hob1jps8+F9Pk_ohvfwJ+6<#lWk8=QAEqnhx@$$7I*&HTc$-j zcTIk@#i9QK9mLG|uWpnor9K%fdibsrN-Df`6@!C#UkyF$Li=*QeYxx1OPP8VY!AyB zlf4_xZRvczl=4{}MAPG`zZtC4hbb|Z6D;ugcQVm2q&XwdT6>ZQ$@ZJOgzp^PN(G$) z{s@c0W0Zq$TA|I>q*qq^0}9wVSy^EtfqNE%YC3*23x3gNv;OVV!ak<~mV8s0Isu1R zK-O14_A0I+yK?u-iE3krEXBT+?|%j(8O<7}4DzVO;>U&vRO1u-W`?bZd(PeJJ4!HN z)evyyiNnw;OC3Xf>n&?Y$E*HOqV`JQ-i--V{t`n%9BFP0jccIj-G`?amnU>pbgN3S z+ZlLzG%!`?c|Jm-tc*TnVzxX67+vgS%J^wRt9&LjZY};mb=fWj-QHNeZ0DoCha!rm_G@R))nJ`R$UOx%c22S z+!o*3zrJ|=JR6Iwz|%uB+5iOP=D4RG1GzjP$N#Izx=c z?4$*zS0s`JA{&!XqS>vkTj`3&Y_mtAd&S+jPL1Ubq&3%SShYpt=M55Fv8YF*AOLeH z+x9lGn^*ydO53bdarI1R(>8KtBNGiXo&cuzG<$>#D$Z-euNtr>Thk)8HkPy4&G>3^ zGWcG3@q~z#e&u0mx~V+g^~ZmpJEv#7f9d(2x0~~hcHf+6z9-y!F5c}){CGYX-ds|F z_{xF#?SGUf|KsSOo1sxX|Jk!WVgBXKa|vsk$Aauf5XnW>P#w(b?Y70oB42 zOoHS~CYt>U0Fz~hn2=LYi_7OrV40y*f^2y!5z zj2*^mqGV*)Z>X3$uA*Pxm4m-cc3Rl_7ODq{ltMJo+{110r`qaH_kVYxlEn*D_2ovU zIdO)uh!V?0)3ukCH9^}4OdN!!wIKGYFGzOx^RCx^e$=K=X`EVtl^rH078?!ql&@w8p)zWjb-{A|LZK#W`_pHwCoC@k&CqC2)S1;iXGh9{o+wfSO$%w8tW`xp zD0HcTU9!Np4{B_O#F)R?KYSTyxA%nW?eTK-=j$5R`!sG(KL$Dm%qSHvmRIKFT%Bj+ z_~VUj;x{?dO68ctK-4Z&*d}^6RG8O8AHR*M4jB*|)2!gQxY# ze#=oN>BH*2mS|2Z9$7!XDJK#}1q6$M3B(43hoNe}y(JZ~zNu>}xAjiKA(4$@ z$4~8qS$ow$t%dVY8<9RH1H?>~WlOZrig{|J)I>{!NUVS~dgo688}kN&A?XE*OgSR@ z<6)r`U>L4l^_a9FCj)#$Co0t~Q7p;~o44_JKjlXdIZUj@`(0p5R!Y_8wNNxUm^*1P zpxZhxJ99W{)bE8)KF(HNJNnMT z?23PPTrNS!Df*0AeC)E9NO>LW=qBnxa2(_a9|z%t`gUsB@(2T z@VnuB9zQMTQm-B8xVt2J7VJ?!HDC~nJav1Y(_I&SfQR`!$fo+*i8Z=s{eNfN-+pT~ zj31Ay0qTGLpFz*?FT3EBntaR;g5jqw7XQI6<5#hfTf)Wl@Y5a(z%}d`ikWQ$5Au+I zyjesO@wwQz#&cfJXLla)$abasoy{BzoO)Vu@Xn;?&g5*w4eq%ARbick>O=%vrZ$~= z5r^WEiQ8N&b5Hw=4YT?o>_%-<{RF;Cb$3{Pv-Q9e!=ee&(8|in9MBbn3eqrY8!`s> z?i{)5=+cPrBDZ5ik)ywIe&U2)iP6vZ0ATX@_}DmgfQm7Vu8Dn#!q{gBxnh#N1oCEa zeyn6KbiSb`aM*+{R+A>^4JYS^jqU_dg$z$?D1Nu0IZb4e&DqukG&Q8Mbz0mIL#>Uj zScW8o6fDb|s-h)OGFBVUHo`mwbmpTwHOqbXhO;X#ra-fpW3#C_0Tm&Psj>mFfBWd7 zjT&{veQjaAF+NgNOC~hFIkrkwwJWynU#Z_yCV~-F_Ut=G5G%oG!pXpu9%E<7w3kMG zv?&0$PAtiNq_%-W`kr0`JkTcSY5KgLt;XxMvN=4PpfSF~F|oL`Cw~n;aI2aA_IkvE zS14qk*CQ*N1T0Z|nGBc$n|7y5p^E1%T-8K5-^YEvlHkbkYJ3XTYN(kq+41@VaRp|7 zA{5)8%D0#gY0<0!F8WyUWH+??csjWD$7z~m(b*u(aZ-Yon)c9K>|OP#|AvNU8uo1* z%2r;dM*J(x#gC!997I(oX(AT__B}@$w6<8fz81S>zHHGDB);`4b0Wz&h$0CI*1}XK zSuUHdd{tHycI_g#DBqyCZ2G>6g##o=jUb(33gcw?EFEgZZ{-p!M>z;QH1g~bYX5pG z(O40jRJ7C8S*6&jD$>cc!}eCxYVGNZZJ_<<0(I}0O--R!ZgGgjp8#0r)$Bm&tD94=&?(=gc#uv z7A@q7pQmQngE2;u+C-mU2pKqa2rK2claWadM$>DR!pK1zCsoKNj|PdtZWvWW5iCf1 z8Twi%A9Qd&>Bzc7gnCVCX4*#JsUvw@B=Lh zwo+ovxD6$#z_4hq*S{xC)WWfksTlgU>hayvFLsT<1w)B zH%@)e18F>;LNbkf@z3d?svMMlB{PXO(zkHaGYqv6?>VYsM4JC+(0VkEoegHrL+KPs zdF6_h>Qan+IP;=Ci?#%~Asgua7_;(U1iV51Wid@%-iEU^QE#rIUcH5mrJ3dP9Gtr- zt0;d>Lq@;NuzbIFZ-;N1FwZKMsJrwGXXdL2vn3HH$V~u49ALc z4a@YZ_XJ3JYfP%(ZZ>SJYAp@xNFygBr{x7=zAKNnna#@NnFd_<0Imwp;8rFR$T1STU{D#d*7ZW4N4ZtO9o zWmx1q$;^6_m!Me-RPhD-zoY2AcjP4z2ibn@8Z)+wXlm+KGJRaTc z->f~Iu6iD?E|RR{eMT3ld&oCCu2`|2VV`?3-qE=0>;x*}biKLVf;cxX#AgI&XLi3y zmF_-I;-D6D5U-~6^tXA>QqIr%$s z|Lx^BLW}H5Df^HWk@Y}cl`T`&b2SH*UyEs8m-tprj>OJ_@!YT%;WK|qN~UZq1h)oJ z!I_r&ryPa@Ste5yu?d&Vo<|LJ#=Y~~G_lWb*m?ERKXaW5huk z)c0)?$J?!?K~hEvf#HDbh0o<}MFF4~I5oO+o~Xmx*Yh)%E>bWH~Q2s6tOV2;?wPC*J%4<>5fBP<69}5)Kiu9C6l9KI+4e zdW)ICJooE=`JPS0dr0R@m+o9T;`H*xoO6uTD$BjE=oQh%aGFCS^HFd__xDAw9=km(b|8A|jE<8M*+hYZ4iXGnQ* z_+{G*Hd!LYVm6^^XdrO?eXhw@?n`x0Nz&%Pmi$iUV`;w02%+PJY1uDW5Y@t zUVTIhO*MY%zR;f6n_m-rI|O-}Wu%$5UuBvY#|U$5e>E4>femYD%%G+gssN z8VGD0ULH@M@;r4kZMkVcnDm5on45v@HR87N%6g@o-r0KyTr0Tzm%^~6Ut5=o>?KTQ z6c_8j(p%6)zF0ChqtMnPhG7_%g&<9DV9cnVVJBUrY14zWxp#9c6s=0K!c|CqI>R}} zi|?{0yiB?nkK1IQhhM6sqA0jLn;&~8S;$6(e6J9QrzqC)%_gnYgbgBt8@5>T5pRoJ z2?cqEit&MBZM7`gVuY)|oySG9-;cyl_jVx+w$lp}z>s@S2o1)#! zBI^kfJ%)wI*H!iML-qwf4lXaZ=AMTlUG!5rR8(_|#~|M%g1BPFlxPw&=9Dl1?dWd9 zAupV!@kgTALUL`{;Tr&WU_|Vtz9d0N&-8RmLC4V-R5%1GF;}+Q5GSLVA272poq`YN zA8mE3@FSGu$%MJ~0S2)7(DNs-e5Ut?eDnoC9p57%!?w#0ukv=0k{SWOu;k~&?#g9g z^xK8y(ApMYAdFKB2zV0a(>3SK;&4Q;dM|9q#79K{uozNh&R;{M0_{`m_}{FA=HaAX z&RsQ=t=K16UcAM(t{A?@zk$2Se*?S)Kpt zqF#NCmTc`gn}I=l@`9`K>E~+A`Kh4e#m{WWp<~ul-$Y<2a2sItcWS*l2dNKiK`L4p zY%_~4{~qVXxL$?4GEnKXJV%K&B?_Q;E^5%zP^o)5e~5n6PRgH)-nh5%>r6rL$Oq{b z*b_h*8s~xy9pRx?>1#!oQ_jS+Q*M(dA+C4ywsOK%ds5iTJJ2rsVh9tcJSA4ohYV zjna3^Xtkc|L2W^>tuSg{vrMqRFtA+RX-pH#0R+Fsa;6sBo%u0sq_C%!ieODLw*9`p zz8%KIVR!~KHC*g+*f)ieDB>|%1KED7QWTy$n;)qE|#1Iq zxcjj1G^?Q?)p(3)AXOL}d?U`)nl8qT$9hD)wOFqa%tM$MY6EM%awQU64+~|)TAk$8 zOc3DRddu!@w=A;?GLrN|WrwM%+iFOjsG~<)H22!|{xCQ&cF5pnnpif+_(FP|G(uF;-%fLW-a+QfUlYSnq;XJ;*uSC%0GTad1WCblJ@Yc~j`67F^n_-l{ zAw9f)V^y>?)<06`)-=UO7vsM#l8NVkQ{=|cy9+oKBw-!jjxGj;&O~^sp2mhM&oBJW zRyudyDbO}Le&o2s|qy4)sSKb7#HB-N}S z-lI%yoPljAhL^A(x7`Sd5DwCx(*4n##y4lB%9|L$p{Z{n7bt>a%@6YCYsD0$ocmSb z3yIBL-rJZ?xCTjHxI6ds8fha8wW&{NS>^shRfw4CjYSytC&ukW0Ex9tPL56+@uxmu zZot_%1%$$$S%iD6szSg3@sIjpy@Ve%1moDWR+o!AW{;Z%CU=yzj97!^zWm^V&9w9u z&Fu%c;vC7+(1@IWG^fa#O_Ld&T#mEiw&et4EL0jXfS>HcHX&P*z&;$X_7@07*~Yx40Ro;g9;pe&+(=^C+Fwp6FvHi!giH zT}XK?N6yq@AHnVp%)Os;S}c&Yc7+u>sJcp4N{C7#`SFZwc#O7{>(u+JRg+3Umtb^^ zbCfYM)}R$uwJzzC^+^|wid zG_h{IWlyF~9?H_N!tocz{A7OSFfK<{A_gt4c7Ioc8~eIAN50oYuoVfb?slu<^p9BW zyZ9C2(=92-v0LtfP|7im*X=r3oiAw> zM$@dPb8D_GTU{8#VQa%7sE|^ToPi7>5MU%no|uqhr@v>Zl105|)lA9M%#J;IZxt^} z1{}vht8a>j*yiom+qb}fk5C`st8(3<5!*;{vA@2Kq$1#UqS56g#Crdx@jZUi%4NiJS(2=CA~wAUtXQU+I}yVF}!N+bGY4{cv(W*LMYfUVmf}%7=p+MiZ zT>H?*@@eM&+0@EDvWd#sL6|AFo1sOuJlAAW#?KAK!7H~#Sa(~gwdq_6J!c8Y16udj z-t93`-1?I#KH%lRqn=Xbr)@O7)4S8OVx;?M_YWS39HR&bK&RVt(1PMvjDUgiIotRq zl8H+9MDAEfI}>R5`)~?2y7M$QxV+p)e5jxIv-VLIv&dkkES^SBF~MO1bB)(ua+K;r zKr4!DN8Z`1N+B=Jfh|0@@2AU$tM`Jx%%%<_+lTFJG*Aj_NDNcrxj}3s4oc!bc0rGx zv$4aLhWmCI>d(8|%flDz>tj5e9IKdFVfyi%$W6grByK0X7OJn|(1V4)_HfwQSy`*y zJOYKzyAdsk#v8G#0?4vCpXstY2?Yxu0K7fyU^=Xm44vseOG>yx%goa;Vj<+;% zQ#AOK(sGyAL-V_RmX2S?Pa0 zVO>R;HjeS;=k|-S@j75*CiXT&h(9406n6Wa+~HV>F0FAB6zKeH~3waJ$_I1XdCZnmm2Eh+(N zO0+t9rc$A14-!S=i{lL{q>0nSM1?&6OEiOtb44N<-Lt}J;H+^;|F0K_X*q&3y(H?5 zxV!`&{=J}Em7GnZHWFO$0{kL1UwlzH`NTr0J5+juSCruq>jcqIq!u= zGHvF1LjS05*08~2KM)JEYWrD!hPwl#`4Bl(re*`Nub^QmW~Q-Wv-5QAAs>Cyh{=V2 zd@`oCUn3}V#}Tr2Q(7huj>4ELAFgRbNq~p2Oj`|ilsCN-F3re^3fy#W%vqlmqLXB^ zWA+eYsuCpF1yyu&TyZd;aC8YAhu?Xrhh+N_%vtlBkg!4q^5bB6$&s@+rHVLb<%7o3-o8MIb=XiFm}E#@tkDKw zaQnu4EK8}OccKyMZUKan;h^;a<>LoJ4z_$+v^hA@2MX6Z=r0?T8_xd5XIYCOOLdON zWQ`NFxenN&s;_(uTcMnRrKy~vl#GeQZ-xkV9%xr1;p{zWkH;Z`y+70QhJJAmm0{a( z|9<@bk&Hw{>-6h?VkI1m|M}xb_kX}l|GPzH^dB%b{cZ>wztkD=$?Ojpn@!g%N`HWS z+NMTW9$V#5K`ZpIzC*GLdFbbnr+}*vAf@4=V@eAZW_oycAs5YU)SjM%K(p)~mT_xp>R-*XR4S z|FUZVkuU$Gx)|JxS)lmKsl}`loDJPkF#oUu&x48oj6+!@nBOGy%;aoF#O&Ze?2J&a z*ZUr@(C~y@G>{4 zS!}2kWH_myY=&{a(xj z1h?r<1f<1z5az@2Fw4~9b*jDbIeYOSGqbxX@e895<)bnAw#}^z=KXx&PmfI#b9_a& z>D4mf6cPgUm<5tU&WxG@9Z^z_SfYITWYbLjESzin%Zuz`x}~jS$2L?enu^EFZaRx# z6NVk*tVt=0VdZ;4K>>fa{>@G2+%sl!{jaIx-eLP;*~-gUQB-gAB=(TD_~3xqTyz-< z@Nmb-Ga|)pKiO2VMq@e^&Awhm6)t1KfnRcb+L=u-jm(I6+gWNbfK^#!(^B<;6k_;N zVAr$hVr15QSlKOR2pEC!`}rhk=EUgJ{^;nDL4HaUGSeu-Zz{nMM$;%kH^88&AD)Uf zc=z{rTjytsSTMTMlOg;m&XJ?-0)m5!;t~4LTlE}JgJkTO4H!d;=#z3{@QJaZQ-wFC@VAu zRh#o`(ooU)krK43=V3pvp&DbD--7f3l20oeeV)p+zcu0VdC9c_zya4hC(OJ zImTf>$dn_TyY*77(H%I*5ZaA`#eRonCZM2N$HkWwgf#H8ibe~5;~NFPN*Gw*gL|Kh z>M71dg;T{3))sXGPf^tZx)z9J`ZNeUW8R(Oux-^K{?)gL^IqfZn1t>On&|d=S&G)l z(q3cMZW$#J_Co3`8cO-J@UniCPh&q#?9YLDcyVycS2C@GHXW3uX%(YlaZ=5D(+xg; zG_eZCn(iU*`aZhk`!+lzr+{a#KjBC#AFORV-rr^Tm4+S{bA?P8-i#0mlayyw9}rr} zDn^nVOM!FMT4JRU&}|eQC^{Sy#*U37mI7&jxDw1sEuv)-OKHT4aLeqbfU!@W%??N2 zP)nRv{$vv;Q8rD#=9Qgao7gbPf}!u%M59MJ)-ET3ioyK5I!-fH2BPw6p>My`O5cPe zDy7mwap{agy|c0mP&*7#*vc8Ot^yUO)qBI-#UZe z*&wN<@Ce>7+WgXPFB~2r`Ku{-C~hZ{K!H9w`4wV`gVS ziOM~n(9R~Tq*XVn+g&%*W@QNle&2$9n>d*+T<>KSH~a-`$?kFvJ`?dU)f&Nee>ico zixudmT%oJUF)g5&CA||&<4fLG) z8>$W%XrS)Uyf9tY^vZlV2@Mln+GA_C#p$uU$!M7Mf|vBP6>e7gC+9c72&px@$X6kw zL3~oNL#yR!R9BW&f%f5&Ec9W1_txo@geHUAc->+1i#@B4b03@kpyfAmT25RIzHrt5m1D6a9> zkL7+k32vTLZR)k1@!1d>i3;#q!A;69?tnkWBxBWWo9AS^xz>+rp`7~+LFKMw=Zm_g zd3+8Xd1{?&pRRuK+B@tsUHhyb@LcBOgqO@~pHfDPI7lHeKGbc<yuX)t6SH8alK{-w=##- zvAfd2HC*QjgkuJq18#%^ZVT)hEUWnK+dr=+$s4yl&Am?!Mo_xi_OrzN-MXyfem{rB z5y$JI{v9F`%7ZZ7v;_PJ zH9SREsB~+nxI_AhMW@k99>KvSYt|cvZ@jR5xPpM%e^ooAWI}<8Z(@RzX-jTW;{_f4D>}KYRCox_Z;G|I3lGrJ?y#3WDoL2&8=+#hY{(20W7zk{N5|Zlp2;pc_S7R?Iz~h5 zrL$^Q{oW=T;*UtfN%YzFkN(LNb5?%TZ$dhRkoW-5ncd-Y_^m)5Hp$nq8B+ zkO4v5$VSa3crLueghgsCo|LLtcN%=AZBJ>CBhMekZ>n^oFo#~>84t8L98-`;~a-kN`Z4mBCDSQeyn*5 zzbq-!fqLQ-VaKNJ;wVHEK$TEj)pr5YR2lYRqMNnog3gnXN z)a17f4&dCw?W&^^lK9VHTu19WP+f|;nh?AgN&gP&Uoh%~Rn!I7BLS<2=YyBbXjdmo zLk)|nLSbc;BR-!4!NQs7k4@78DRmHRrE&WkE_`4KByS=tW+tNm@#gE0{E-~NyN{_) zdIjAcAzu*z2x|!|Z$q0QMsNs8;*x7r8Am*bou>$CW7vmPyY(89CLR@@EQt#LHpFx3 zA=Me0Fx`o~_fUU`-4%n0NePig(%(f%kl=QxG6z3!x|79zrZ)N_8|3bPya1T%3FN~? zxuXQVC17JS?BO&HJ5bA&8E4J3BrmflyX!_4LPSwV!a(&hvy}%uUVCRIX<&8v8+H z`tcM92|f@5-Kq9WzA?L!1BP9~x|Bi{=&HOGff-;3 zb-RKX%&XERSRE%+0_>|eDsh2jJg?XX|K|&s-x;})e|!!0IrZu;(zI3evM!`ljG=G> zdw`xj8H_oV|1BqPmykL8^5?O7}~ zxv6wYUI{@n#YOCjS;XZ$l6;Yj!9R@lv}KM_26b>k!`!h|`O}^2I~BzTt4y-eY3+H ze{e9}MzAaJr>wI8zu3dE{>mpW*W_1fpb;7_vM)j|&+N7(fPI$C^Sp*Oq;8JNb;X?1 zcaU(alOK5l34}_B_b%c+mS))P;+wZdb2nv#%sZXa*6tvv!j&hSAV6j%XtY_xxS(LtmkJgy_R?ne<$(uhmPW|x^Rt3B6e*)4==PcmR#$vzC37(Eu%kurxP|~v|x(A3s#kQ3zxcT z7=6*qj(<+y3uQv&g<6n#dwj!L&u+J`x;ROQTXaw8Yi;d6b&+*-?Ujk-s!?HbbDDdRDdkF^pKY{7;(S4vAngA)%hxQ=_6vp?TGr@?{)p_`eV@junylV zy)dT-Q2SYVUIe|dSns3nqa~$oFSN&&peJ7b-Mc@bbGy6WF7U11^GM(M8jeNBbg*oP zTM=S=F)Isfd-FX*>MpBp;Mln46MaBTU?Fk#co(gN#5r)?wQpK>b)csnUHG#W!Q;VZ zJf+}R_x2ZjVMI+)KV&x_C&w%8zjd{Lc1!oCkj>#ASvUQ^Nc7OLv;J@9WzqjAwtuKy z&t8BvsF^S>gqr5=b(dAKYvOXPsSnj|<9;xYBeE!*Mb7ye5D#5W%jkv=XVF((( zLS99GKvSWx?j@1rzyz8_3^CG*4ox%2%Mu5ItcrjsF+xXK=>)|_Ic)CM0cM;`K|!=T z5z`@=JYKOHpS)i;YyEita}?=wv&FSvqP2in%oEC(I!kms-J-G z1!WpL^Q+&Gz?+Ss>Rrt8>DwYG)vK)0dn)HLh%IdO)dHk?lLVR!-Vq$_V;~b)qiUwGRQHUjz#yUYl&|3 z8OAC(jN9RT_YJqwq0J|&tog30%3OSbmX5t|N~uoxP#81p*#{@HG8-EQ(P_NAUoUr8 zmV?#aqw%q-gSWyqx3qaoD5K>H0sJX)9`@yhVa%HCreAlyWCvl~KppLom_DBa-rS{^ zS%kn4)eGPuYrCMle@j)B0zCQSRr!ON6^E20_k&>g4Y7=g)xpLC_VV7NriX94Iwn)1 z4g$&U$+XpFL3-^FyYb7MoUe===E%v3Z!vZHGJDSU5_jXZ-5oWb#4XLLo-M{~)}q&= zJx>KoojB-%W14;V6^W*B3kQ7RDoDyoSQg(ysLThhR?hSNzM{LFuvRyw{aV_wFl+6b z{SKzIwFdSG|Cn=KD(1B9bu80|D}JOF{1FD&TWtS*>WLmCxA_f?DYn03EQ+3!oT`SS zf?K=qc;pgur-w3_r2iO@QRoynQwnm`d)sxAT zIp=09{n<#q%>{sIu4xSWxWM=R(NglR%-7ZW0d&%>fN|~%=co)@jMB(GqFhlDyT72e zX?8WHSIB5)D7{VD{5v#9$op$Jp%BKd@>v(#?sMa1wysRPa+Gxqe$#Cw6Iumk2$jWB z`Cnvim=X`MCa2)2rV*}Rb_@0*kIRP{*4yAUg)>(?J8&Y1tf?SeCb7#2Nu5uT96r^I z#mVy*mouqw83ymLJVL;=9xtAvzO-vVT~k0kZmk>B>Z0+d&FcGJ{G>^uIafT=f~W=^ znpG4Pcyrq(^2Z^!4x>k)Eqpiv5$|Tm$2HJOR)(H|YXUx4-CZ&0hsEm|)->UU%E6O3 zk>Ty3lc^@vfZ_p7-M;cG0{A^B|?{%6=rrJeveRX{Z|T`CH5PMyc|}|^oJA7Z^4ODx@K{qUWnB|k3WbGa@gpW`#8;}+)m`ePUhE`5{zymd{--V zSA3;_x2B?&seA2t!4v3hwIQV4qJEY6`9Q?uB)C0@)ms-{#)6v0BZhYrJpz{K&FJI} zy2=Kv86h^irMi2YDrA9t7=oEmqf2h8G_$Ui!RoXb5$w?;NM`;ZH+pa?`j+)x?2bP! zXSbj%=*(`2;^e8aSf&9wA3X6(6csdZx;-ndk9EEAU+k#{u=?U|)2~#%|G(EUJgoH~ z|7Sdn|2J31|C_i^lvdoJ`+?cLqHuCBp<$=Y*7#cghM8rs769$fBNb_8t@~YnC{Yje z-Ce;3;WsbS_OP$sKFtMF;GY3|Atw zmN))^W~joZKx;@E)kZj34TTPPoB#kP$=qeA#YjO{OsCp3eN6=XP>=X+Qjm-^iA%9r zz|rZFCwm86?~fHhqm#1YPe{Iq2tA&v{)|6|8k(3uG;CsSLLJb*>$x-cmjXbisdFEy z)6%-*aj)4}zWguPC~?c8IfY6gXjz#&O?s8a@{tUp+vHE_DTeDWYYn+S2mbtYHOjFC zC{Rbj?i1KobWXJl?)t9k?&|hUrQ}!=RY7c7Ac$Cree#oJJINRgn=jYp57(dX0FpMfhvQ+B3OjG&B}mFM zp?K;Hl<=3!VB`{AfcoaGSo)0=pMiy&2HQaB{#A;SKpO7`8tf8Nw(9dDM{K$=`6{_5 z-8k7}MN7R{G{mwbxO^I%b|5aXSla542!tF8FW9Rg7D(M2!lG1e0~6=Oke}g)aOSg0 znx^NI044F)lw(2t*skSRm%{qOpOw%8(>QRE#Yh8OR}G76@lEA&4mb@*HX+Rgz44VhsJ-wk^}dK;THC+oV~drh6mP8FOCi;K>1bxuM7}_9F4NM!o&pe z-YWc&eac9(bpO4I{d3~nW}ba_{0XYg{TDJH1KYnwPnE{IEfy={*Om`R1<*Ni9WkfO z0+$t<%N2KIqqyH;H8(aaNRy;FL{+k8Jf(Wy=iT#E?0c+Lxsz3{SQ3m2TjmJs4)pW> zMusx^@;HZe`NToP*jb&NvWdMmHBAf_FJ2GV*VFlF{_Rf~KdA#7WqYNjWMRsLaV=9e zQd??9r^}tWE04LLf{1_ylEmT7FGuHHLA$FfH5hMiPr{9yqD>*Cph+cTU5ytpt*o>B zWc9KHG%xJ>?8^CTIT_LM%_{6ZQ zd_;!^^`R=SU2`(Z~oA0 zSnJnaNr|j(L=682)?Ho_@8_%y{`M1A=<^k52N)-oHVhn#t41b_>_mv7^Wcc}%wbh! zrpc#mjhCjvADi^M3`2oXu9#@P79Bm^Ux zrFm0k5+p&odXqq^lzIu_-kGy&GhBW7@wQJd4c zG)?j2Qr7fKD7CF-I!wUTZk#=j3M+GC-1h3#1=*;xsLdm`_8q5g^8cdjoPsn9+BN$X zyKLLGZQHKuvTavamu=g&ZQHhOYx&|`d+L57$d5Ri?@LtY zzQ*eA5sPVN(3mODFXtXu3{$VBoRzn?C;a!|&+zAThpofsif>y0QMu2a?ni&ZMb}pM zIf*kp0511!EBFCaS27nl6FF@nR-_|f)|oOgb)!=?xYMy>7h+1 zS!Pfi6fX&~aN4rCg21}Krw>~N5Uk^2qE10#OKPl{4jawBG0#tKOzh=+OkGM;IC7(T zkXHjoxk1e-v+Rx_hiId$sgDke*_$PT3ee31HdYrAP=pR5Pp)7 zhy&t{LU4lHUdr551=e!PN!p+OJ*oAO(?{`<^F)Qn*yS-A;py-y`wy6{+}82WOZxn@>6l?*Xxhqa$@QJ`rNmkefJ0!&b1OOilKP9H>=AAwN=xvoG^VMZ@=N$qg0f*g z#}Kl^W^6PxSGU}?>2)HoPW%fwTql;@#9tx_kvWYPk!dX+<49_~i0E<+1q<;hjWB%{ z0xyzMBsZYJ`Sli{Z(aws&5TBqolgPE(VOPw( zf1tBg&}xbDFU5x5{u`|MDFa@-4pEh~G)c0y?1e+$_RFwPx%}c#s4d7Sg9%-_=sY&S zu&C`U{>3hTH~{>~o})=Fn;&BdHwTywlr-x?G$7Ex%(%F$G-=Rp0A{}Iy`f0VaK(wC z6A3IyGWt!YqY{Ymx`;E5J$!&%veZs_0qE{mkQfquqa(M$Lc)c>CV~KV7Kz9p0);b{ zyczu**6xoSPu@vgjECU9hp!-p)UWU?Ue|FfE7c^M9>Wy!=hZ+sndIrf=R-K`O+HEv z(J~O+BM_~oI<7GH&D#>>7tiVFZ30(|mSj^H`}(7l{w1U!t|GN^rmdso1O{)6Lr4yR zwL{*at^tcP8t*{w@LP;LU(%L8d*E;5T?`HDnAWoj{>AfYIEkZ<#4Wd3kc7c34&dS` zgjtT~b^~>1WvcEE3E`E4PC?={-LP1*}(|=gugk z!qho)J= zT2VtH%Z0cHF}5vn9hJrkDL>RxtL>kT4}(of>9t%Ga$w zg}m*au(Gplv{wc;l9V`4dcg6R4fw(?)86Y?e(EfzqXyx|k+*_~y_L%Xa1vejK_!SD zh)MVR^ins`G%xHsEilte%Ohq54&Mz90JZFPWf@PSD`I-jvu4L zVdgXT-KrFTO^<6jE(ODO3t@V^581&Si`7kX>oSU!SB6cqv!-p?dX*v)^A2(clQG81 zziv`S$+EbUUUp%7N6{ofkni7sv_d{1LuaLqu+b4BE{5k(hiE$sf-_8L;3eEm=G$E2 zL>wY5$x87%jk>piM#XoE&H^&#ZO^>>fr2%pwOx;W=tu#AKrL`A|G=?+5zbnoosuQG zBMFC40TJMz-Z!tsE027PNR7HeXqu~Q?xzi-fp>k0`DrKNH8~Hg+Kb&mDhTw_?t~(Y z{Tz%Yt{6Dk+Uhj2#w*!fA{5~B2d#(=!LL{bToF>IVi3g^MhAyLhe0fyP=W?GhV3k- zjW;wDX%nO*`ZeN4hAI2;0I|3{jd2ESl;lYN-X_9Hbhm!gWC_=v>m*y^?d(2hHodLp-j4cYg77Kc% z52w~*x-S=ZAVNo4_udDy962e31)=joh!J63h#pF!5P6ryiq_-tgk*^qV}P=`+mL@O z+2?B-w2od0Se| z;$JakV!xX>k~-LpeT(3nJ5%RtdC-E4@O(ohMIfYT5oQm;HY7LWQNNS*#k2md7(a8a zO@9s{UH6sT24%gunn@vqIai$}*cs0_?N_XVA8bP4*>PuC>ZL&HPVpKdV$kfWvGJ7f z%HJFFWfcTv%{+@S{DjIa3MX!+2i_I(=q{m0a{qWnLw&;o9M0Wa zK_o%m#g!#%gi{}*os?|)wB%3ngX}636e-S8RRatG{#g`?x%G=1tBlWiaeRJ5MuKy& zXt)?iHzn-`a~}njAOT4|foxU-FkCR~&#h|?+<&;rRz{E;zrO-I?5BQ zh?PjlV=$QifVs7*?3Ilx%!R)&-7S>;Y8Pj6qKh&ku?t{gUAF2;5t5^it#C92&eG{> zLq-#_e!y;6C6*d-5#-1ZqCCVTux;%sq~&mHos*4o< z&iFoKbQ=}zE?ED9l2>;*D6u!&svYLuCczEaS^k>tgc#!9l)Y1-bEKSxLFKQ=w}T8N zn?b_Jn zqt~4|`>Wiq{UKob`SXS^XDTk zKkeTY?m}mhMu2ajWBwBQ=pJ9jcX}IK*X(>09oQcpq8%&TP zV;zF_J$@uCEw5=ne#f-!K_jj(fCyZHU!g-viD|l}baj^3n3nsi_{V?M| zc2X*HTvydnND(xiJaVwChD7R!stE-+e6xNJ@o5w$(_(=kCPL1mb5hCAg;uq`l{j&} zYib??(oMyA=}(&a%|%2>*sCZJi@i^^MGcD3MtX+h|3dE@QB4_w#;vsSiPF4NAa_=D zGGYH$kpBKJNN_3H6sW8NDseCMQ!PH&tQ{BTsZ zDu}%-jd3W~T4MR+?D7rtIIx|tRtF-@n^Cj`-5!&R?}Xw22&>H|k$qp)d}MRBaVRnc2Xi=yCNi;OI;016P^H1nN30jyDv=PrQDKR) z92@7dYXPc<{;3pb4Q;ge=Aux`i=~FqWAQpK`0zD6{wn;pAC32vgLAgz(GSt>`RNkr zaVpWr45`sG>luk9aoEHCVWvlqvV?Ju{ovgV3EU-j|$X-mWJ5 z>;D2={r4n&oRZ`jBmkhV`M>|`m{=J8qb$=ov)h+I`^oOfKU|iH4(2e>;@+^BggG-N zkzh}gH7kr%>xiq1(BG@L0`8~z=((Z(Z6nd9!$&Zy#U~=y_8GmyU9R^g_>p2ZA;Nt5 z7HmWva#CUz01{$U$0gyaVrdhSN9#THL3yp{K`nBy`27=HdyIGDtvnz1etlON7(Npcq%Br4eTep4|~GPEyFp*2kt;*p`=2 zmw%9!w`Y1Q4}#e&2(x7Uo^ELfHkf$GLQAED?3abbEc%WyZ?R3UlbJ7d%N$o0iXY3S z#*2?ksz6V&$Oh~6m&ckaULK9?c?2Us2Gm?6#u$Q#I$-h=bNc zFPhK_9@od8MfnNHLSY%h6GOn}VweW6saTE4_%u8)B%0Ym30S|exCHpXK9oaiVUXFH zO*#FBUJQwc-YaQ613Q!y{A;X|oTBM343NNN%T<9KKB?j07_s26GE|=daz0#D8{5;3v7a_3T6^AzpJ3=PhgTh zZ%+0*J{~893^`taLcpo|G5n6xf~eQP91Oj@;709E3_eJ>#43 zfZDuj|1qg#!xJn;yHzbVzBO~UYVN&n{+%i!4Y%%yg)IkXPaleED_X-$WAYRn@hw!V zPE$w3sER65bdQ>N>DCNrtQ>(YTMJtHrtVYWF+W`|2V&`(;ipGpjgcNelYXL?d_|eD>vI0voJz?h)pP(t=hxAiB5S@Vv>o~RetoM1$huDpfY|Y0n#vPMN zt$%==P)fyk=vsz+h!pJX78aJ=_SBNxj5meoe)Z!lu@ATS%3x00s5#kg1EV+jRz&SF z&f`pEA&vSs3PRYnr&q1ht(2(UeB(!aS|*Qmb;*UGi*Uk?VOqt2%x0Ll;zfH!-7 z0aF9e5PrAk(YaNlOz0H%PrcSh_~zc|(WNM;(soST_8ggb7bfp8eOz*}HHRUxFr(XA zc^OZ?x;b;VbaWaYW=DvNIy_tK{o3GI9@npTdh!cv3Guo9IR7irG0kJgtSdwD-6;6v z%(OZ@{-NMb{(AqU3%l&Gi!_F4q;R}h0PZZhyCoApS^;RQ8JM@TTRT2!r{w3gD`2Z4 zY+iL;dwt1^H;U^Mi3w3jRTmE^FaX-_kEUtu%CE zlWc*suZSnAZ^D!NFoA76h1IpIK2r4+@e-QQ$F)oGE>0P?aD7^4#V|ihr=%bbsZ6;^ zMh)HkiNW9@hs!B(Dt3tOs{h)W8f>j9FAE~Yk1<_thX2L?`?)+@4{67%2x-`Yj@2+l zo}9kIipE_3-Z>+t2mjqQ+ZrDyO3e8)^=wyMVEexHj2&Bt%Crxpx4*mBlpgAK)b+mV zK&B((_u)M8j{7SW@kPX4KSQzDX3%#-THgZs{!iaxdF{iV@KZ;~8Z3khLXWTOMKNu* zBF?pQZ7#rs2y8ZneDTp+xKw|V`Z7Nn}X14QWxiz}WfRk>%6A>v%&z<$p zajVB;Bh7l9$?x~w*-*%+S2L`^4vaSs!iQyGc&h8heci_@*Jq!6OZmF3(@T^z?oJaM z=0EtlEfh$0FPs_y(0Ue52ou5RJ4l9ehv6$fb7?k-lcIfnk(u_gMF841w ziw&pOKyWDPdtK%sFU5{9?nfEyE}5bN#|6rj12-{N2C3pjqr|X@F;}LBTD9^VAF)3O zt~zmZOmPWe(y1dj{zo1d4$lL2wq!?n=yc)AsLl{M^ijHQGCF09&B}&8(co zu}Or0Ns#Q!@9RIkR`?RLiOl~u8#~&HRj?dp!Te0O9}GDajBuL<-rVcQ!#F81$;7MN z+mCwe50T1TA!1MAJT8k+CkhJ5j943|uwJR2PwGzg_l^Ki<#2aXS0_SnUdE`)u#hJy zMf%4zUultUb|rG8PM3TaizR`WW%CcPjuQ#$QzFFnTm-oq4b51S1c18u4XSE)87z;) z4_JJ_99QMdMTk0u(#FN#1W=}YklaTS&OGQ6e$L(6&~7f=F@|IzCE^-)rr&b#w`lDk zXGLDVD?2;y&^E;M5o=18Von;X48{oOu1%nc3I1w0G^I~0*DWdthw6MX^_nQXND10g zfcz^$fM8iL2Trlda4gO2yf7*(5GpNwsL+B2eL4{1A)FOKM2GVq~C7O*%ksC%N(1AUk=dyZa+4L=E^ST}ysabnF9jtdz&!8GCl za7Ml(o7b zaGXyz=n6sHhsdv_JRk{yz!n`R*U3RDS6ZTV9EdgWr49;9_4>sROqQLT=;P=Q<qP6s&LFR4i;zB9d64 z6_#iOaVv89{n&V=u;dU;amIt^0GvvRD1wGC!DOuGYS*r_^E>uEq zm?_o0T9t(O%q!uEFU@X34_+P&;+f=z!4bIiLXpaidvT8X^e1BFqkkB>=A~q{b5umO zerM=l_`>0c`k>Ww`6I9PrQR8`=7oy}{qpIP7HsuHXfKND%c;wj>Zx6;xLwJ$Ztki) z3I1}EJ3MQk-#li%62dHGA0qzEmx?D=el0|ZJpQbS(KD1MLrf!n3VZRIbwX(IE8BC6f8IE zrm$&2{z-flcuAFpZ}jzH1OHqO^jqS$6sCGX4%{xX1}ZTreh}ML%zS4&r0kCjP1Z5**`ZLwDLclGO_7l2cSmGzIY zJ44&AvRe42{m;!k*%tgRhZW+aQJNL=swZBIZ~H}l5{DJbo~v(ap>yox>d;VrvS%KZ z7J%W^g?!J#E1NxJM?`z+WVXj+-lpSuv`ZBex6ujA|QX*v{B~_moZAu>^!zi zNEh}eL+Nk$Z-=E;W8ykvBZd_pzQ9yoPQT}?H=pJ#+CX1FbWZhY-#0+WI{mt`93DS&%KDzNs2__@{%!j296YPfimUI(kH{aw-(a}9 zJH)}otJz*{(ltl}DR00l&cGCM83FW~Uycvip1gJ=eR@x)@9jVB#v%h1Osjfv2J(6_ z!Y|ElCM%{N+IAc+=XMM`J*M(xbvAF_$~_j|whU#bhF{Tn_;!3gWNjG}6}IH6v(!}9 zo$12+=Y{Fjg>=-DL;_aBA&zh=xaiZs@1xIU-cBtdPrk$zzSL!Z8Fl1K?L(QtEG9u} zU4%VYGb`f8CRVK1WJR77!l5cz<}bn4b7xy!i}|K1V=6l)M?h#Uh<>0x|m+jiCDaG%4+U? zvkIhH64omzsv!SO`zQd)l*Z;-Fh!H8&!3T_IPSXoVT@+AF6MveMSBlO)VosupLF!U zb1IZvF*Y~=fRpWipHs20{wEzB(%y>3Zb9vSQATLLqsz@%ms}WLw%z4`(_) z2VxbLyqu0*AQabnDu z;q_zuT5!sfF?F(0Q=h@^$^3kJV_%s$wu&*)u-sfSzw&vqWZST9S-3)1)~+$7@BV(j zSi`Nt)a6Gu>{eqcfqy-1qF;Q1f6#nIz)K#NHZU%$7Q?P;POAEnFkW^y`CKxuaO&wE zUlKF3?Ek@lwrO0cPi>V!JBPB4HucdOoEQ0On9Hb`+Ym6jw@@#`Q?0rFjMVU^t#7K# zx>xt^6foB_ccQjb)rrd7K^?D30+z>P*{?`*BCe}ms_!wBk{8sUy-3n2+v%^r{?erW z$0k4KjzgUnoad<2TZ9tII`LfKqs^%IDtxGj)6($bCInVk2UW>pO+Zi3wu+E63Jvl8 zCx^6SrdcgDygyok_zZNb7URE{-XGHVw0C+aINjztJQzYG{u;SR@p(?gR_(!I3~<=8 zTiS1-?|HX${xaS3re%&%?&w${T%{G2#_U(n+A|M}Dk<5bgb;Mzvr=&$T|Tj?)T z!m448t02XOjy6j9^yQJ|&?1~F_XjTi`@{Qt@kI{AN8hYWx|6u;UtTOB0fgjeqKgN?|N11iGpRXCZ?=9UVftRR|3tQ`OQiwpTeX$Y%PqwP@eJmb;Qyn!1*% zhtah8Ucsr2&28Awnke~}XkeG|Xnz#q7V*Mj@%ho6RPkzF4V`t%9sLD(bIR_qI(-At z9^)tLRz-W3$f(nG>NZGRHP`cNwUu6!B-s|#A2h*!*@hP!(Tn4(L}&X7%E#b759Nrj z*xi&_(==QAF+nvYavNBEPiVk@sm4Or_tW)RR_HG%6TJER<7{PH+dAwD|D9t)a)yV9 zmQ)inmlyN*V?TVl99?)aP9n*MR#o#Qr+ZY99odx;8Patf7F8oS z9<4u59h6oaiuvuDLvWAnTJjdD*T!cbbpc&6-!&miNhtI3$$XlIo-bqFBU6+pJN$sjsOq(Nj34N^8E_`@J0!|!j6f`pk9 zl=R4f4PWfyu%`HMpFBlV^y~>X!H9Fmrx@C!thqo&xF(s4e_4+OH(E9{XrC6@84a?? z$B<2l94+|I{z+>yaaUZ@64*V1in$2Qj3xg2Z;t;51*$b)V5OoqqC}4^FF|0XX5O!$ zQufecn?+(*zV4s16a1Yp=#oW(;Ki&$=W|oSs_FGgoYW4SlE=}zToHsh&fXxxQCW@r z>La*&O*S&4h_>BQOkM{R9w+BCrq0kJirw(4XDeTa`c>IouP8$R5E6tN>h=+f{AhwK zkm#>h%$0LSe1toSb2VKft$o&3PoQ<%Cl5Q#R~^4Z9qR6 z@?^=4j5p3PKsrFMC=;yagz1}SAP$}keYe=q1gp}zWP#Fpo0hxE;O)*T+F~@HeJw0} zqfp8BcVXOCLQ)b#5F}glWswT1uL_rTV{8FbfW$H>XxEWdctPLFMAv_rkyPk9JE&Xq zhn7ifXNexl;*JX|b@DRh6;+A;x)=fVeZhEAxpjnH?V2GhOsx(AvV2*xj}e@HIpi)> zPm5m^_8MaU4c&#py%9>gl)OEBLRjb;`3;9^uOk?>NONsBq9&eEc_hYYIK)TkbOn9K zLm;qp;4_15d<z0)AGhum?SOPxpj)4REH@v)km64*Ron=cEz z^pR)wL==KwT>cIb9GR+pd0C@81_gl;D$5GXD@@lh7(?i!It8emPhb`%$&Ipf6BSm; z`I(?V^ftmQeW>Htq`rofs;*SGW_U|i|2bsr`p|}SUUu*JAg`AtEjj6RATO-iiyndE zN@Yc?LmbS6vDi~N1rBc7RQE(0sMmCIFW&-8;e7VK;)V4aZ^Te2JIA_|ng;$QFKG|r za+r`O6{xV!Ubet^ZIaU~4EUbX+Z@qjARH0G4q6i48Pq>+-sg zptsJgBObLHBTfdyhyg}VQk@x7yZ-*Sw^5f z1@TtVN(PF0EGj8oo`16qNY%fPwy5an<#wB0=?Y3id`c#Y55N8Lt{;Wa*KhO?m5QrP zS+pT5j`CA#RmR!bmCzj({}GXRw$=4@S7HM=o2FIl!A_E81&2Z$lb%Z=yXslK7Fme@ zoUYnRwEa4BT1J5{l*a3K_`v(&*4~fdus?btaVm}Ck{#ExrX0P7>80VF>@~dNO&)ZrKByo%1EpMp9is1c;Y9o<-5dor(p$O}M z+c1u#02tvq+4Ynp7{*8y#Es%iWFCWl0^}@UJKc)o(G2jc_n%#MNLQmgt9q@w(PC<* z;LA7{qiE(iA#=W8RgnY6$NzSS$tQt$hvl}EleEeBQTNR{tGE^A;c;ODXGn$?SQ9Z# z#UAnOP_BS-8dg$5T^+q^GgYfIB2b}hGcuX7)_TclH$ho6ov;c& zwyUK$j3;*j#A`)+8K^Vj!S8>@AEvAvDs#J}@?NmK;o0uU)Yv%x=f2T>W;t=bC^bH+ zTZjSYboWAOT%FKMJKx60`$*o+7xNKGo|buwP8g|A_`KJINOo|H`eZ+{mU5U&{dM zu-cz0W0xpbtG$+FyEGDB4)r7`jWDd-lSiOu$2v>_Fry;6J4G5E%)3{;gDktcsopI5 z;sp!rO1iQ?hh4&Gk%=2)&_YI1pbnPUn!&GBXAMuOmh=8&J>-#JyZ%Na7BUqeO_)|>g1re{ zLrrK5otGTR*Tkafo5D5FntvipMKLn$LaS`zZng-;{NjF%WhYhB9k@3*yd?SMzAC>w zL}QD-Jo?i0x9eN2sf$ZWb32Kl-rze1VmAb~Deyz&sBGh4eVSNGy={jQ7@cPrTU8kn z5~90;T-Kc4ulVZ-)llmA?Q<)RQOU1VeqM*qL&iN6NfW;xVYklMD);7eroS@>ZTh?1 zyEpYHV`YH&KRy^qLS)vFS*;Zr07J2~gUzQoZfr?_OI4F^%uAEsz?_VmH0i~T#JYow z*J`WMX8?zsbhUr04%nA1Htvl<^NDZbq}Ywdpz7utdB66)z8LG^seoP@xbLR?F*awz z7}jd^*wD?dtG(DUmsvyHQ9<%1_C&1Vre#6Z^fk|Ez7+U!q|XsV=@sSCqO2BqYbQgd_T`fd5Uty_zs|`?ogKI`+nbB$mm&^3BuDrv1Ms@?YOb^^?djq7}*hoBd^)B zYtXTS`yS+*xg~YcxeN3acKN#W`=9&gf31lQSpWuLnJ?E!U|y4TeaVZ z>ofgAUjD4wL4hq$kmmpr07Mn?`v%bGPRJ~ld*p>EoAqWRW_PYVbgh_#hWnJ(-cCWV zA8erCuVq`^7Mqzk>R$E?(^;SvGkLWC>k7sI1 ze1*Bi`DIR5otH<vL;MTMHizF-%NS*w{a; zjGU}fIvP4!rd74-oIOuSz=1*EzMpPS>rfX>rdL{fO+^1bY8^a${H?NDx#Fz%-Jpby z%XlGu#`EbEoWETv**uSe!b-tZYQbx?i&tC3SsVGRTHj&$h@nJ#{E=+nNByw#R0Jp* z5W3$7wg6N7fhP&9prdQHRg!am^gH|+{qZBA9r59yzufSd@-lOtXdpp!v9W@lbxh+B z4|cz;U}0-&mYCZh>$j{DS0-hvmj-N#f_`LdiXcK^VKcsACxHrdSp9A;8n+66&s6!i zRDFzjVdRnA+Y6V#aftYOgaZ<*dZSqOe&O-3WyOH-`+5x%CPa;iE#-lp0`(hlZW! zUR>$8)M@`rSYiKiRW4U0W!}Y^n*(mp#i!wUgrvd~4We<$sy(-uRs6#ts*uMZm(!Kr zjL}Qe!I9q)x*{3XS>g<>)`g-B+~S{gxgunP0*KGvvXx)IgJhXjWxh7p zi4`41Xj9%HCFm|B3Lnkl%jkRC-9dWY>i)>}0D_MTD870E$j9&){zHbKCM>(wzyqZ=UOgpmH zB{3V<76X{;(2GgkHyeeOdPbiz0wMf-2T;W*c`zmxjSpMnpJ(Eu171~uV)N?*$BUK& zRjUK9BaR+siR6cC9%?0wyWaOy9EY1o{l7(juIw}=ingmSEep)Bx` z13-Y~`q6d#(RliYTk=kwLx^09k69j{s zbp&_lANTJ{U^GLZpAX(u>Woxxh*Qe}CnS7-$~L7#BmXBhal0-7P&j!Ce3i#ni`bcA z;FK?FQUmT2LP8G=Ta+p!|I9(bF)H!S#2_I8w5w27Pxl(f!^qR)fqPH-iS3&K<9u6O zF__A3U&Yf;BQ_oLub*(O`$>}7aa7cE+zTlP4j&yoAY>siijf;hv6pg8^R+xphMF`+$2xd5XP(q zk2b7GP8_IKGLW2-dy_BWsGK3;9yXq8mOnPvmh3lbscTS)HNhHPhH$Gty;KMZ$dz!G z8mIs&a78Y}_qBF+;`FY}*R^)S7?{I+=@9XAXlCjMaPIUuBM3grsflakO)AIrs0Z_qr;ek^vxl$av>5=w@f*CWef~Yv z%^9I2MP$;~e=jWy6;M0my7JD2xs%z`hT5FUT!Qqrv3}1hW&zxrb?a^r_9hyb<6{oV zbIb)mLsie%Jt02J+r-0H-8Nqa0-YD-`eEzxh4q#jS(U*vo$%!b%gk1cEzf9rSSP*{d^ivpl4>TY-?WIJu*F(kSM39C zFMq>;yqGxeYL6L8G7qeA_cE;vE=^<#-FblbH$8bW@?*v~7IF6B{RjaX)3ekAb@^zt zQ9p64o(N+!|~EG5GP`dhhrPONG)k^Nh*|PZ>g)6n2>EdtMXTE zZ!x?br!^;1M*s~=nPm?4jD;%5oU4IX1NtP#7FsuyFC2Qe1V?1+ zFkNx%SQk@o)x)@td6};)$mSLAJh}*f`#gsCD$vu+1z%o<_ijdXzAVjN%Df-0gzvZI z!dC$=QfA19el9C9VY1(XJlU`5*FMK2%`& zP=8z=+K{^isgJ98wpA8?#kQAW*R9bp3<9bZXOPEz=x+J3LuFTT;@D3UISgj=FlYeN z<&nu_lyi&t9y5RCx);~?+etG7s1akxKq}|oNODd#ZW2h`UQ!dBUQsI_Jmq^EXV zPU8E9v`zT6d~+Yo9(`xVPAZqNN8@Z6ig@>{=WTdah>tUQYQ>kS)4@dTaau68+y!+< zpJ1VDC%AShMT5QZCSsH?{(Vgj2;of)z+$Qe9@3z!zPQ$MNV5^AzS`HAq%~>khG|Fw zf7I;8ndqfxnA*) z!@Kk3n!q*T=p2m&-KkEjPl$?1?Ay+&gHw}{dd^?z8)6)$E4WX&I04!~y~%gJ_UO_a zC=oo8)Ids5|J5WdhdO7JI263d4bRUx_@TMDn0F(QHjTddpT8ie2mPI%KTtY~qwt`RrOgtfx&bAGkFY1MR)=MK5>a@2mcNg1Q<|V}q z!ZjnwYesO5_vmKzqyu4nYK>@p!3GcS*9dT4@q?i zm5B>D35mxh7!s7esYT3B&YTqu{;f^1RIu`CJsHO|1;G^GF64vsq?IJ~erC=`%Cj3vM`C8%gjY&^Y5y;LP{C1^K+~`SiDUaV$jqpxm z^~&ehD7Q9(nI*@XE}nR(N+N0~e@}gv&kUr7rwy*#e3p4OuLJwFl$bEOm|ibl{}#FJ z+0}4kZagTku!~pvl|~d^=L`S#Nwif4ML&?3Q(}Zb_g%B8eB6!4{_}+TQTWUG(Orv6 zMA@%g?57sRo`4er(-|YpJ7kV@C*lqT;MFmwi!(l3dX8RU^&x{~EB5itBlStr1YZKl zMKGkp!%C=0cCOjB%*)S6?q?(PU=h1~RsM}aT2X^CerkiltaFC}(d2bce0RbjC}i6j5=#D60-+4zZ!c`CET&F@yjp}X>95}eKXX=dA^&oIeT%s%&IvZ z-6+}FNOBqURiYD;}7bsR(63JVUc&DiywvcP(OyLgJdb zaktXK*y8#`_qhLwpdrXMfHJZ?&I#6e7?xOH?ZCrKSm34yOe5b2ZjcPi3s)@vhNBrj5{KDnlK4DVRo_+P65#?urS2^X#XA2zdtwP~_ z^0h#q4rE85S6@mC>)J|5a(HUdblO3%{Q`OU5+`gq74iU)%Xx>MF!|~eiA)wCm9zA1 z-6pkV8v$oQH?P#w1=CtWZ`OVHZZ-u4ifc0D)K+8!1G&cU_LDWLyVa5*%NtdxDduBz zTQ4G|Ig!ylb02A!zQWBG<>?#oS@5;mp{bi!EM6T5nt1F7Rg@y}5IW}bPm;{Q0m{ni z{Hoo_uwtE6?T&+(4#~B|jgya+PxLXU;z;FUMY@R#L!80XxI!K-dpGg@YVfbx9Jn1J zH3L_aY3tDajUeN+CBlL9DUZBm(ZwqYbYOtF!QdKD!NvBk>gjcsp&(zq5Uv#@eUh@Q z@k;S7E<4v2)d~>S&pM@Qr)k0*PW(Y;%;9I84gB4*n%NIQe+^o+-8+n!{j>TVj?{>c z<#bnEr9(8)Q;{u@Gdn{@Y0hP6*e^6uARv=&PW+pYz#X(1Jv7MX7MvgtFi(=FAUTgt zo;~ldk#cb*$v9w8jMSFYEgpBnf(-h=b6m&iQkknOp_OjZ>I#*ivKxP654EIKr`a0y z0*G_TxER@O?h?yIukafvz@;~bRO9$(8UP{5OtrwX7QEhHHa>Uo`vM;L7i_*ZT>qv+ z=T0UNpY&*G&g)u`@7Th=nX2uGE~g{c8oU3zB_dd>f<$J34)8%7K!LQ{S}b8Uo|x)7 zOHIp^{BM8Kg6n4!bJPKoMI{!vPDX=lUX_T*Z{{hTYo6-~rNHkEtB&O6Be1vE&rglc zi0#6p%8N9Q({#(~=Z(rFfkstZ?Y_m&dMX_|EN~w!o-S1^H-nO%6(I1Shz&>z__nN| z5mrQbLSs_y#7Ba?^uOxgXVW1s(&ciQ8zRLo!&IsP5_r{CcJz7!?3*vu@R3hNT&U<` z**qxF^(<~HoOEW?4TjxuRkouXkH=jf2Zz4s)EIs^g>Kcv#^)NCk)mtlxYz0Fb8m3U z;?42CVkYJs;3X5bCe1now$wfBBn!S~ojP`bEg8Uk-&iS7RW6g7W&MW<_oIXkS$*so6qVqTgUo5US=QL#iO7gF&5hqH5R(j*Mh^*ilp+nly- zP209@+qS1|+qP}nw(aiiv*$!?oNv2Zf1n~NBC9I%$@{v_;`!~0`HiA5Jg^~q%Ak@Y z%;ihn2g^3S5!Qs>7?pJG4kG5@zWzKyfS?p_zaNhA8LR2UcfZ4BZi;6=4cthu|2l53 zhXjXVx&J}XLSqSgnse7uOtxpqm=J?v2*wQH8Lsda8sVv8f=ETQT|WsdgFj`Hs<)Yd zC|A>}1hCYD_SAe73lKvWw^35V9wgC5W;hnQKKE%qAE*8KbkW@7S;aI@tJ;j zdxD0YZN@R^S?~GQjMiV%4Bkyr$b10Sc@%~^AYcrVc(3q0n9?j+YrLx$7uoJqw-6hf ze(#B4C3dOv<~qI5CN;DB46^5EyU8ZyBXyyubZZbpu?rG|A#cG4WUS^M^RntgUY;My z-IL4bo<$uISm~m2x`GJ13vjRI%9byZ7IKw7>D9n5mUIP-1;2%OSZwPK;{FYAX=}I} znyiDh-l+GJP_!P3hqKY%*gHdzM4nqV;Hr510>~R0ck|KzygOaC2D1Ana3JAnyKxrn zr!g^(gc1XS4`Q5XL9;G}Ts$qYm|;$MZ?9(E0qh4 z@wmLK`;<(_eb^m7WDvU-z!vgd*_}Tp=Rg;zzH<`*Z1ef3gmy!&%~RsnzxxI~ioJ<% zwlT4vtxPR7dn>9HWqT$%5{oR5>KV7su%$I9^O&Y3Hv9E5hLk#Wwi?7chmd_(BTv7T ztuo`&h3#T%EnLgyFyTuyD9_N?gPtZpvGe_o%m~+0`V@_j-j9GZR-raBZe}$sF%6K9 zLss*uo3_8LWmtZhH}0}=>%`sveUb~_>v7F9P$Rk^QykpNiS;UU52?8nmWTXi9KZKy zu|Dt)FjiJIvhg1Gmj+QG%-hZ`@*xdEhIVfVZ&|z6O@<-tbA&teh^~n1D~^`t)nvo; z(4?rlJ_$CM+JBbDT`#A;^0tnX{Tkz~f{XR#(_Q3CY3;>jjS;hzs*nHX+ z+h$eg8tN^GIEoOOj))TZlPdag3dIYgbuy~b#MlMDGBCU8oY$PKu*&0=&i*~8^zbK< znkqPvb%4s8La+~vF>w7kA;;|Y1KC#*SXf;-zy6S#2Z!9ULp&)41ymis3NvPqvhxA3 z6YFi#_EMpIoe(XX6*bfxZh5G*J2wa_ig!Iasp!vtn^P4GB#636=OfabUF#V>Eb|aK zNv?FetANr6TNA7@o>YhdmpW&pjg$+bnQfL2mq{sgX5l-mDbk|pWO7|bo|>PAGXTPv zOZ;avs2Suhp;Bq%U9B*z}D`uBeZpmd8`SKqcoOAoIepwvZkMU7g5&oU9Pluq{ua zxl9nCCI9R^I@qVeC0n{&G86umrfy|*?_%TR$y)Bc%Ir^n6t3n}%J=SLBE_x4ZXqXr zijH=zz)t5Wk67F`1E9Z^w&YWDX5Pl0C^WnBF*_N~cRoq6EtQ40=S3jUe^Zdqn;blotDWf0$}S4{|JCa!!%F zK7`vuMkcp7yv{Jp^f=0u&h1|s!#cJj$IRXF5>3-;i9&I|*D@KGJ`~U|r!>R~Mb=75 zN)I00?xEs{-k`a%Y^9+umdG%(0n5KA&^ie^?5|}cF#1n2CExsv_Uab8O;X+z{ZNSY z&H~HG*#+BIXC zQjosamnu5hf0uI#Tsh75RfN@viw(QHtbYXb@m36?NO*c7GA7Z8&AV81`dctG=HT2N z&Ma_b&TY@Y*zO6mcd?2UPy&WbOfTBR{+pRr0%C^=nRG*);y6ta2!Qqi|MGG-#EmVb z(@2zkK5{w7**)LZVVa__ujoOIp>xFaG%!aU!7joe_hIrHZPcb|QkQ)=nObq`@kM5p z0*|@7IL&zb<;@mPRnxj6bnNKHZCT?kKPmG9B5GJ!uYeXQlB@QysblMNHXDYo4MDxh z!H8rwyrIX$JB6a@bnS}imz(@B4>HZvg6+rYg)JqTh^dxg5R-QiIMMuQ=?o8Q7dh?c zt4=PWUY&Hhrbm^DKzQB$^D3Kp^S`;Q7r5=@H2tYx^cXLlUe1I?0V zyQhE;yy`}odt*~v-rvhWAb({ACJz~}E90&W93?Y!0_L zF`swR6hK8TXfg4U)9NZr96~e#@Qv;p|JiFSEYk9kC1xTxU8b$T^?P3t8&Fa=4Rarv z2yOW_KD(-qbCU&=jXb<9>vRm4f>PE~_Xom5^T&okN42Ue>fImi_kGo!vyypLo;zmz zfzecXR=H?Nu+*z2>LPe<)EXp%tWU9bCb(a+QmYZ`U^-5>&#dil1c~%czjVMiwfZaxSNn`P$^|a@4d2fhwA? zw294cd~FJLeLF8xHaaap=puu=hu(mylOSNhMTM-!yXLd5IHICctYRasj;&Fyma`{U zZFJpX++$oy&F=&4J(Zhw4<%KrGvRX@k86sfq^WfFnxJoB;Qff^qkWvkOlh&C-V!T` z7>oN4rvYOC!Y3+x=;r#Lr5o}|%b455>vfl!W#Wr^0l_U6-!*}JNPr;0l(d)&Ly1Uh!UIsc z!>kWI$)*B_V}Ae?nnMmvE%4A*a10c+JEw9qtj#7(8p?Y`sIlW zg%M(k`1k+`c`A7bePGLRr<~*nV*Uk*_cq;=9L*Fi z|B;?Dfwjhp5m7We#?%m8Ns&jog}byj=d-KXy?Q{-mc?D#9DCxN|OcUeN`%)u`Cj0rU4^7mYP2b-~5B}pTNWfB({s;`x_2lZP6L|Vys4PsR zlm-KukK)b(#te)CRpc~m{}KP-E|yj)RNNsDez6k3Gj4a278wx8`3-r)6&c96tQ>0qL5| zpe8qksURuSupH6t9ml1b<9-D3`cF-E1zhQ^HRI%|hKPw}!lHaDBHEL)`B`R1XAGc& zX(#CE>TZob_nV|LVZpH}r7PNEPdsr}UewvGN(%cHM}x2(4vbjatNf{HYnU_uZ~8SB z_hvf)HlA(rPX{LFgY(xze3aUod)q$i(VZpXDX_^$?f5vC zEl2w!?WRfsp9AHd4Qx^w*5?c#*bCd{o3;Bv%U%c>C%KZ5Q?bKp?$H~)2$c5mTT8m> zs94_q^k*Wa_{p&Bw?H10$MNSUX2surf_r2n=x?t<{#Lm13g3tG%|#O}|~ z`MIyYg9C?*VFlM)2AY=viR=D>n2j7L&k#z_iqGU%U8a*M7F=l^Pbs;G;>k<)-`agg zMV(VF!CthV(~Z&Ql}rnvklhXT#S!z>dC~slHVD6VRPXbhUo}a*(zICeem@~a=OkoT=%(H3>-;h>LQ3-z4P%A^1H8Ia)Oc5>c!X^eqA+K(H%_BO zOhPm;=?@~#NePv$dgZMM!;;`fd-wWT8GLc*TUe~vr56G^J-@uH0FYecbJ&NFp7{G0 zC$A6L7TIg7l@;mkO1czNP!!k)OCOLBNgkW~5mt?mBI)KpVe2XeWG&;|ha1w!D%x*i zH7ryF*Rh|C)7_i5kA#ksF%6=|#;^33OpIRwXv-_QE9JSKBsRtvQiM#Qzv1Sy>*VVv zC`6>XuK&LCB|F@ZbVv*ThEDcR^O=@OawU3xcfkTAL;{xKX;yN6pxy{X$^^;>Z+;p;Dry>fOs>7+GLdWll!>~0XkTV(V zalUqryRA`mnvI7sZxxU{`c>H{ygfT-EPC+4jwls^RQo=EAsu5n07)QavQNO_~Y*60jq1xW?9jr*$@aESJ=0k zVRCoDGpJK@k4fUEpZm{otNFa;6cp8jH5aUly_uakn@iVS4R44;ydF8GNf=Wxl$BdH zIWhgo*)5CAh>`koBz$c&Dj(wr_P|XTKGrOWw~BLp&foh!WwKWXujBr>x}g|8+8>mu zFe0e!&9rH$;%MfD&x~F86feCZvS=5eJ$KMQDc`A9 zX@;9G+`=w@)rhRlLFu%e?A@8OAGH7}LQw|;4|AWzZizZ%hF6Dsf?F7|&PyhZ7yc5Z z0SFfGcrFFsN;MzXr4{0Umd2{DE&2QTe{Jfa&*zzrdHtq;<**K{YY+fy1ubFHMukWrK5iBMC4j|bt$Z8qeSXddOG&g-tPb8BGPF^uW92=6)P0MuRt7V z(r49m3~SoCjr5|e@6V}N&Ec9q$2C#U=A$qX(arobKb#>3wlpQvqM1GY+KTh)I#YVx}5w>odcZmF%?x$E7N zFTLRmMX1n`CWXP@+FwUf6HRnQoYX$j#s-Ya3g ze5Geeq+ptv6+GY${n5CU^&b&7{m!E9(X*2Mt)LZwmxn0g*{bs|x-t$4z2qno zuq3|pKw{*pL?aExrtf6v4$SoOr_;aWO0$8Tc@0|~{Q4JCa zc9koxQL~ZG)DDwk)t-Q4KGK_J*oiQ%?`D*$&`9F$9vgj*#Rs=kt7;F^%=o$YRx=sD zerxf$m5iEUXk!gp@_~zoLa%RN>~LP^I(72BnB7N)71A|$tMaXT-+Gl|8$1E zzX4cD8z1h`(Zh)2)<6M+4ys7?z{O)_bTdrJ8RGR{c5;D#V!u*u%s9+O_X{w-{H(f5 z=e-*3i@Jn2Tl8CE#T6E9;rrls$HdQ@9D95oNT=pfVeb16(B^2+@>aessJ=rZgF-4y zV-vLtPxIaRO77FB(KstP>&5D?AdTFJ5nT8^2`i^IJkSR==WuDeYXNX!0fy+xVKv7K@fU{DCo> zctQE~FRFER9pY#S3{iD@WrFi-+f#6r?jV%^Zl1n*=GjZ2%L!=14T-C}x)|gy;Syeel}`uq&qVREnhi}S z7*A_G#0Iu2Rimmf@dzrHG)a+odf)q%5hyFr@FS%@z6T000xbmD1c*I8^CZ{|5EzrrBtw9U5^u;R5zbmbJ{%!h_4olp2uoiXNY3 zgm-`BFR*&JmF6cBou<3*t$Nc_vlo7^gTKC11;9?vhQ-sH&(eZ@H)#T2W2 zh2?7A@Z{7((!_r5s}8o_!sk6bUin@xM(vR>XVe_WE4We|3X1$kffNKF8$Un54)Tom zIJ_+pbymGZihmE09jKB^L)$`*+<2$r0^v(CUdX12r-D>bUg!t&FmGm@WW9+pWcMsv zp}>-fBXaxm^Dp-PEj{h=Rw>*mPnCH1^_ekeYg&}=n?juCrI02@;_w?Rh3ZL4*WFB1ZtBJKk@(C@Xh z)6Xoqg}>em(t;(?C#|i^;%Qm024ESWH7Fn8vZ;DShoyeS>H)_LZXMq9)=QOznQT)c z`X?Lu)XP(zIB4HWhKw&yYW(RO7NxI|86uZP@GIQs#8ZxZv{nImucYw{m;Z5`p(6xi z#vXUici%RCOTRV-$Sqvk^+C{3-+XCIil z<@c3vKdNw%lN<7OZLz9=zB_fsEvh2ep(mVrGMcx)=?31Qsf5=`dyv`+* z`K}4)k2b2vMX;Dh8u3ca&Wr&?&&O4ln})I%q}PAqUf$Bbf~7qJRblPY?Etrv)u0WluhXS;<6oCL9_(#%5@iRzyn`uRHDe-S&ok z&gjt**9roU;RD>xgVUXjnuB+xF997mQEw0%X0!{0bBFk&dH)PxleL*W;~2VXaq+E= zNe|FPe62_RxwcYvzhxQ$6>$$zTIsAX^Y8Y;i-ccsy9_q%2os+yL!f~Zj#6U!u%04# z$?)>nrL+uAiG5Mse&znX3>JocLs6`T+0v6>yWs6}-};9ACjK|Fc}zRk()!3KlcXjq z55t_030-i}yffKxEV3DN)=H*R53{I!t8yeEQu!~tK%6r#Dahlyaq(M7k>V&$OCFQ* zxX7rQUjoM>_L?ckI%qy=QD-M;9S!ytn-^or*muf=Zl(;qHh*9u;W0Hz8do4FW{8>L ztx^NdPd=FJyf2DWdkhV0_XYnMSEl{%tnB&go=iFq!Jp(G^xjCP8<_^+LOA#@csrU3 zuDoeUA{gxIEIv%^j^v-Ym3_(V^M?D2$pVgn9SiMo*ah+BUt13@J`^~Kr>8xl%u}3` z0?%EL{J(icwZyx18g$<%J-Pnv#LIf~>m*qma-1l4(dzlH=bqKrF5Lar2=uVSG^}D! zvT*9mSTSc6v;ghl*&k$jeioQ&S+4&jEZ<;!WxY{J^NX%2X7#rG9;9nY==bZ9(lWBj z0INMN1JTu<8kn@iW^iYiZS8svp(#Y5#4hgDZ3w9*Be+)MHpR(_<{7DNO*=i(lS^o1 z1jsC3OIr?B$inFOm6;ah1K z|B8w59b+u0RO%+Q!f`+Kj?9hS)oLrOZ^?xTp8jd(B9G~;5SSyv6BuLRezsb^>f`y2 zleo1kaXO{8_RrCoVmj_ae>G(nRFnSuyqpC1#6rFGlRxne-Un;!9#VyhrHCbV!K_(; zrsXLTKtiJ?ghUn863TL8hR+~C#jEKcXe2yRdI{ypOvL{Ug7Tsm5K8Nxkwa?iLe56e zln>0OXSjDN(MPr*Tha7ZG}u9UN$?Vi#~fnOJ?*qt8gym`$^_+`+Cmxz)MNWIB>#pY z@^Cluq6xoFrR{hNdRT=i(h80m;fzc$!3|uzRTQviTq^rkJmw>zlx-G3w&W%O?UK}{ zX_pH)Tl@T+7QBi5>U9oo)sO#l8}%>-bHGil9-`4e_* zz><@+r4mg%@X)ujmg7=l$1>z#7>FUnczy_vD>v3_6dpFBzmhn_fh^=1Y@=x<#Foo@ z544b^Pc5OGB*(%C+M~C`{v@$2tE^cHsL>V7B>ijj1XI#dv|y5Bfd^hZY3ldd%4tDs z`j+THiEV&ZpR+Y$ks;NiwL~NrZu&3(wdm{bGc}#?JyY^_-?SnkfW9Q^(=S@(#n`V@ zSd?=Q==514XKdgy5Z*jji?BMnc&DiY%R0vnfgGrIKOL&CPC5PAwD_^+ZTthm*92-GA+D>%pG3;~V2KW@AV)rFDHKGY;3( zA1AUqKBuxzY!~&W81-EdxX%GOws3>|lBIP>^YA@3((aq^eZ0LUQF;8js8cP1*2Bfm zATrI;bSkl;Oc}NA5XvluC$K_W5WTq0OgOO4a%zXkj__NnslSH1!Hd%e%j$F3f#&!P z2c@kCEqGg!t^;p7O z*##6eWk`kS0bo0Zi5~1torH)I0~z4;C|UL)TM7=>y+>?o-o_D{y=N4%B7^X&YHJ;B z1;{+!dWz>7sg0+$JcwVqM@`^eHqYWY{^Dj2Q8;%_E(|7Hwj6FdH^yx7VJZ&SyAArs z5u$%QtGQwq30LcW&JRbdSeVzRgaHp}7(Hy~1{|mLoYJJDTVXT?&&DXyTQ;Pn+m#dU z7Dvkl87E*G>-IZ&4t?jvljbZG?FPaJHnaqsKT5}TyXxHp2`u&IYyw)B4|G0i^5yom zo%PW?ht^k^YrXh~vk&o2<^AUaw6&-hJH1Yhpng8U$d7oP}9s= zVcT(_G&!I>nM{T-k{Q>6PH7B#P`@3v8N;X>B)xe-IlHxLCA|kmRCvAdcn2xxuxNv-rPtB9rM9xn+;#bw(d*>VpXo^LHIo)a!c1K*dsJMc+ zUtb!zqh;tNg0OF!Btx#Q4l`tyIbkgga_P)@M3g1TY@FR*=AP3G?!|9ut5mvQudi<=i5=rq+ilO ziZf{?a;iIcDOPa1&0|ot5BP6leDxg86mNiLVp4^9MQN7I`~FLOF`9oCK(fe7Z+*T8 zMYQ?MVTYqv#E?YX7db003*pa8IK6a7=oasQBc{j+cJB5>Wlko6s;tKw&glABWSOUT z+R2KZzDCLC_Mw?tv89Cp4Th!cl>Nvx$PZP+5GAy4)V!$_+L3zd+GR2Z8GI@M^LNbtO4Cl^x)o%%318ydAcQ{pwM2aN!d_p`?=+;mg zxNV`)r*Z7mxo|jB;}f{hH^!LIo_XcuX8!n3F)$ihH zHky$KIlI`pcIJ_%-;ku?#4fpecb+(JlLQJbq_v*4uR7!xoa9N9v|gfmS7=%>y-Mnp z94^JU%x0yepew&f=_p$iG>hqYgPlnkuMVtZQs|lzl{-10#3zue6futLf<$klsUudo zriIr2Mku;!^AT4Ysj4r$CVLFCO4c0rL@hp*kFCA@R_K}cR zXxpd(n*hk>d+;3|8g0q)a|YQsPgEvZKg&&aBJob*!aIB#2d$y;b^`oy)JAnWFC~q&fXP zh)6fZB-z(a$3nS)mXJPD&-bK0`m=~MDyV??Tq^pb zw~r;;jwGANLX_r8okoJ&Vi8Bef^u_%p8?U;Ei8&iFw2~5GjRZV2k(;^ALB}jfKql~Ws)a@P`_xU4iNYCI8Y~E zUX|?XOTjEV67ZhlmAykQ$LarD!YOAg=ZlYj88o#-?r*ltK5wp8@f`AYLLV&x=V56} z$J&(G#bO?3Wzjsc+AF?s^d9Ja5!qlhoY^M(+oqP}hMu9tgJn7vZsI9dr`t|E^&t7U zVit3b40j!J`%NQ1YuMDla^mhQV*Q6hJTj%{rR+}**pZbChe$%-<0GSre3h2XKG-$4 zM<9$@EDxX8!sIx@Z@*-;Y3@KnlY|#EpfXp+hx-e4)A-HMOcp01CPTNos2oq#*C{irQJlZfVRDr#2`8>-elE*DGO9wYiq zsSGB$GCQPo^t(-NU-6M$24n#fs2wg|8gj?=hI)?s)7%J88X{ToE2f5aPZ2IqYKJso zpnC!98dM>`UX}?j9Vl^d0M z^89;y>f;HF;+687by{0*yr1xa%%AqF&rKN{Q}f`i#RZy_UdP}4Ro!LaR%;yU48^qc z{1A(cw0D8=Ma0l}~d_u`Ow zG#fpkuig){okkKo!dxn_ssj}$&L8-jZ|aL|ZG0dBed9M>bgyl#MMfyGnNkG=F9bD~F_v-1%hp>9W6za6GTKR7sg7MyJ1p<^8>iIwU z>2&TW)XHL$Pqt2BmNagpDw=t|RyMT469mrs@bt2BNuH&~KyN8UwzUBuwtw{A-*Vl-fp6rt?JHx zRsxK;E#pe#l!_zc?gqLz$nw{SERU~4c{9-DG?iujQLlM{hGpn9H#qPTqYSLyt6}&y$HRnA<72?|*HHG4rzF zSY~qjLmad;3X0PzU1{wf3PQ|JX~SEDO~G<7Ut+tQHzx5Yi731fPMzP(#WrV|mucsg zw25d&>x`sZf|PaX($r?$IPAA}Q^aN^LsmNO5jNhF0)^#nnQ3+2it99k7O-wXE&||J zzef*2Hv~#=23I-yQx9Y#$zYl1ro9xDv);)luPgjEpRf0a%$z@qk943tVxeDdOE@pa za2zHs^+t_VFdb_miYTi!rlKe_URn!Sl!WHXPsmbhKa}t{1tTaZgE~6~4yI-Em2htt zeG3p8L#?JL_(&Y;7m6t9;=@yYaUjf6=i#sBSjiqz+EZPGwX~75M-V`4(fY{B&Oe8=>16wufsMpAJUP@hh6GV zymh*`Y8>0!Cq8EjRKNo)(vEzH2u_ex)h2WXBUANaYK$UZrujUUmvDl1S(dv7v*h2_ zUUz%b1de3|K5sEo2xXB9rl0(7-Afv(H0@H-)pyTAeo0cpej8{{?}okQ>lsO?#go5? zW4{q!Ve^jtO>=prW|=A~3K4RX(|#Zq0`eFz(0*^Hm=&4eL2P~818?15%^1jB+^))+ zTyrzOMD1?m`F;4sNF`S^5+9{YChX3xp)Lo=u_-F-R!#|zQ$he3U@qUU_Eks*!;yAs zW*#}+&d%0v%TQfp>E6|}9&amN5eEA)g1$C?dU+O$d7zG~Mi&0E;Ep3uAF#Fz6+SARm4(QZ|Z z$!DM5#l$@15>c$DiSnKtE^$<5HAzvJI06ihoG_&rj(vyUlq%(zu+jEoE?*RT7}Ylp7w>-UUnjlCVWS#7#LGyO`fwQcxfl1PX} zl1a`iG6>#}K}qw&DD70C(&!Y$!pF-jY}1GIhBBzsBD#CYrc<(A&_YoWfYprKxQHI= zYh^UY1mmF-)<(Lv?cRMVCkG6s`b9A|?skgn8)JaDh&#>mf{4tnbp@*P2sVY&2cJ&5 zDb>6%u}5Q=R~T~AXKp@jE;-9c<+_fD<(w_|r$v2(cp1C(dA=YVsMBYpg-rXCNz06a-R~wZ zuR7zMDy8Kuy}2M%Pu=eqm-Xov2`{&XZj#wo_vIMBRoAF#k7DvzxLe;J<*jf(D}Q$a9Z#&8EX+Q5G_vhXda+P#=JMta%z{-)nY^Q>N(aF<PLXu+?D!iwrN76;;lpC{sJ zTH;(6qDW!Tl7RVp{e<@Btz^5@W3_!o?SB7>Q9FtfoSl5Ty#5_D&=VlN^yFHlJ(F`^p zm2>Q^al0|BRZ%9Dr=TDdA=tj2ZjtCKXZ2i23!xq8a3Vp&Y{tVc)Uwe9ds3P4m@xK) zK{tk36e~=yLXe@%6yIdyd9z>~GVCIvJ9U;@ay0k`sj5uA%y-$s9{sHvZ;^fcNE}j9 z#2n+o@uE8$qbPs&q+iT$OtA{2H&aQUHZ{O2b}xfztpA766M`@`VZXj4{Y= zX07%v%)J&-jO5DupRAU^n!`@SsJytwa#wBLc)!)y207SegR2E6d)_Uy_ZO5()O}>~ z9BVjIGA-=|*CVdkN%~(_?vl+`r$coM(&Pm;j`;mN*i4~J;#GPipG!NNWZO?@IPS3+ zoJZ;Y%p>R>ANzqSAFgU_ImJk_A#F-cNa!YmMU}E)w46?GD}{mD=wk+R=68B%sj$4l zWIRs^%+>hij+uLl?w9uuA2q$~`c);t&Xz0lae^}DSk0GEdxF1+gS`UP7v7$4F&^!)R9gT3*wA8AG)r|#JTMsAh1FF#5+XW zRccT_u$%wY^&&%;dijp^|6_EZuVnPdfdPP9u>S$Zm67>B+3|^rKawjp_|A6~XxCdB zUA6QEp?F34*-b~kJTq*3^0h3WG;9e?g@UAlikEE{venYN-MmipJKLj4kC^_^t*u2& zmXnS;l5E_`?=&Dxy+Q^f9;G=NzQNf^8{!m8oPWDlFw`m zvV8wNj$40=i7*n0Vbxf9|Llg4&P!UP6Qr4}iIFAcR>3)HAsU6V2?Vkd=E} zRwIdw&>a9ug(#D?EGezMa0U25h86--Mn>=O;NBke)bmaadJh_>ZOhv)STx=qyl@Wp z0(0!D=wWpavy*7GYUgB^bt)U3F3-Vmi;C9Y;;wf$Eh&<9M+kcs%AS0x4y0?cU^ZEI);GPv^pQ0JIDMLgkZFv2+bw#5Mg#?e25IG2O_F^V`X1?8VJNW@mmVO zv|qZSDE2l?cDFaSVo}46lw2o^8V?3KVw3}T{^6pt~dnI zdRRLmdg=v?U)e60C!e9|LSM5B9(9abmeyBAZ5m|f_~kj|d3_%Z$yyRR;|pk~wnMME zB(U7!h#-jIxa^Xe@bVuceJm)KEJG>k>)186yK6oJjD>{TCU~$fFkvXoDK(-T;~foqzv$dAhVZd1KN~Q>m1OH!ppVE=pNIm&sS2&` zc9LaH@e1tn<%zDo^zU%~tK|Lwq)kdfsH!C8#qvS-8}!KyfFHVR~&)EU`-5{>$b2coxVixx6lItw204uRQX7%(3=- zSfEjqb+jG8+JdPQN)x#2l_WKvAbl-=zGm6HeO>SH zfN&U0cCE^C3tG(wI(eAPrJk0# zAjc<``J!%4<4azrQ5l+W!<)~6vUgt=&ovFaT>{1vLiNWxr!9WUfh_4xIaibNo-m{;)HDtCIOY0;qQ&W~8FD$ru&Mc0 z$^772%;#c38o#a4r350Vt?6&YPUcbTW*N+?p{A%Iu^<|=bc$M<*|t)UO1|DD2)0`3 zEfgTna$y442#CwM%`a|lEkm-gnQEEr5e^RQES@mdoOafN=A*0IB%fZRXR;(nb2ojA z4l>?qTGL^J*42Z4tlVs&*9~$Ri>L)L8I=0m(Ng%m`@Z900$7yZ)0_#{p%2+=$@n>) zqfof~Sii@PNy=wDWo+<1ceU@^V`qd2vxYOJANfbdTs`qB6D&TmZ$n|&uB*NwoC$s`)8~n82{hL(IuOL`MXRZJC== zeDtWrqBGz0LdkwC4jq~5h}!hFaLzBhFH$M=0H>A|F}NO#{rTuTY#I2n!=qmW~(+CDtd$U(ZSR?)B?@q3CYKCpY~md9*srp z%YOCCHrS5tck+0;77vbpCdK2BO%|wXZ%NzG{0>zmk*r8g4if9HrqvNfi|Poa+ir9dwT#4r zZGU3QT*JzEz6XV9qG(1ZftIDxup?<13e*MNz-~K(0eCZ%6>(x(;=oV!Z=j@aEHBYr zxXq~Ag`-`{$X+DZs4%q0r!U52jOwjR1d=@aqu1{4q+yv(oJ0kzD%SeD5{ODYRJ{>- z_mWFfZc-m-j7bs-0gH-`#1;vj*2XZhj&ooUw|^U!kZagF`AIWAkbl3!P_hWXwEhqMslRf)c1&^X^i{buGryt2#Ry@kydh*RP1w)EzP`ctk;Uk{!)D9$|wlH>{;B40KTq{k;#No@`RUIr5jbZM4P z9;E6lvtmmrfGA1qUr<)E!RF#Jh5Kz zfTHehO&0oWj$Z>EXx4)YFkd4DwAic!!T4|Xkv=o})Xx4B`bXQGwIwk|D=Ni{H{Yk- zHak(NlvQ0OiJa0jsF*kR`PZ$R}1<@F# zeCpHA1`vwU?@R^_O&2saW>M%5-`15QY!ae;PGszw-4kG>7!IZ_t#U+g2v0ue1T-f<@M_U>&tXBU zU69!ML8_RyRkT?kkF)#H552ZH&XbBa$3?T!bB16){n5fU8A@1l23|=|gM{uPpl?kr zm9^>O`;s$*3QwRZqg7RmsS^<~`7$b;KU@f{eQa%xq65zX97zn2zZdRloUB5es;hDj z7sy|oN*GD+3lNkQmds0eV1TF+3``5!@A0zAJ z50!Ytf@h6U zrs5Q8X=La)H6GdBl>%UN!?l{!PJDg0Q=bc+Tva+*fP?-DS}nl z|D0JOn*g6UeP6rZle+#9IF7&nHYrY1c=UQxti-B`l0v)sQodw?GtQp5mN67^qS-!f z|0D{W4rau~T>K}W2rDv(ivd51ki3H(Er z^D>s#ao$=EhO4wvr3%N(biLtQxK3j$`L%^@RPBvbd&}Z2_)v{YxBMO>cfnSA+IvyJ zc+^0gDGj`w-5D}{f@J{uD9O6Pd!iqd{~wgSV|%FWk~AD!E4FRh#)@s*Hdbugw(YFg zwr$(Vn|t=W$9`r$?fD1ShwH4auIlb8rLZE283sh-g_#tcDz9LFl4yEt?)f_;n@#=r z{Nd(Q+E!6qzI(LOa4D+WGOPNTQG7%LXLAWNm)A}8-Xb{v_$cy8VHPWMap^MCo zc9`zUL|MS|BQk?7Ixp&ybD(j?&IXJJ<1-VBWRayCoBMmPs!ESRYK8XfD`FaY?ry^8 zW&q{goVEQ0{C`$Kel+L8=^sK__>%$lp9U4vvoih{q0Ca2j`^vAUDq|KcQe+1lF-*F z>NCWl=A7U~>iOj_yaghNBIx;);_EMbbMlPZbV{I|92ri2y}lexX6WDA+cICw{Ot9( zca3ao0k5q|7_%KZ<7Hety%{Cy5gF~p`=3pO!n zTNwfpsbI_FW_6(4eB(gO%t_RiG?ianp{dSW)}8dE-ndFuOhg|l?Y)etQ=+Q#Z8&FE z%8dCO0!bI=p`Z~TPdr{c`MtW|`2vCgAxLYEYZ1^}$Ga}>*^}b9pYc(z5EQdxTeWBN z_9A!G6%`fv9ey6e<-;nVl=Z@Dma4XZ&y)lFK7hxNi21-o%@B1W2$n5EsUSdryLtts z1%&k8emDYS2A4gCQircVh#9l~Q%C$@(3JY{mw-wjgnD(PO1tpxyj`=qE7G#nddj~z^^fhGG#e`kAtMvIhWtxvMri_dQ7+H;n6>K8 zd}6v)0D(uFCF?o7(-t&YJ)Q_VC1<6g(0c058kn-?B!tHvOSjeD3N84foSm`@$utOH ze@@SZYXQ*YanWvPt2iB^`k)rS1N3}=L^<}La%WZXtEHv4$ZvJZC9Q-*fG_uh5hXQ9 zNlR0AlF^o9^a%Tk!|_wvm0Rf!v_ zXE|1sa<`jCM6Sh`$z!4s@zclkyR0ww#<6I&7UwxogF+=IY^ZXt$fG|Yp`3Ge%S_I~ zvOG&jTM%ZRlXy~jNur~h)vSU9a8{AdrCFf!0CRWYn`L;qv8YLddQ53x!O4%CSNba0g z#xZZC?L>pS2yB855xvFy5QuB>1-ZcW<@epwhd+M;OgVK{QgtzdFp;xlkV1#}W17vz z>4Vg?kn@)m9X>2|Hm*Q;;ck`s4A!;wQb_2kJiu1_q}8?le_;ZT5eF z;g|}n{lGvyOfh#-We(`l7){1D;z><^FtzT!a!+x-?y zl8?`&24`KJLdC_G{kxrPrKGlm^T-vr>Tu77@6`3&kUmy3Wrj$U<7Wvm#;`pXuXPg# zam@7e^k~I4(xI!cd4K*LyqnWpQ|9%&kw+>jmy3Vm344T0{ICudntWN3;bFa5Vv=Qj zxNQ9a`^QSG(wxNXP%|=(X)XrIvRbyn#5c@cqDYS{`)!Nkv}$RzuJ#_qm!vUKq;X2n z18Ht!(wTVhI(7ZkM!j`v?Ds%r~OV(iFL~Ts6u_?%wpP@ zikcGU=vW_pc)H46W2K9bt9raLs(s!g!xI1k4OsairOyV>z;G+VVVttDVP5$P3pQIH zZku%q+ArylEL!`U0qc)MksS_w<5?+yg5k@nU8Kt&6*L+^%&&kBY2%Kto#4x@|HGqg zRr?s}q+wNrpnz>p{tFdFWbM$^)!Y~O*)h@A5=^Rz9t$%K)80T~O`gP>Lv0*M^~2$( z=8Bg1Z;n*7GAeGt>H*d(%#O79FC2E4}q;OZonOZ z30Gi7-tN09&B60+=jIW4m3Qs3;*kDG%j8$7v|CdgbT)&jV&z5YXO=9Lr-wx6+er<2 z5T@(|cjf_ekU{Ek;9&pK-?FvuD~r90)U}>3oaRF|md$qp_Rq5KQ($Y9d8$IoukKZD zlj3Q4fVFSji|`6kHLay5P`^yl-aS62m5NNhH$hCZ{KF2-2o^$eVQUIsxFm4iPlE{a zdUtn>7coC)w3cjpO6Al@RY%o)m&;vG%JtwA{%e`#1iuCLbZb=RE8;m-ph$n%vC136 z8(1B+*vc!i2_T)uj3{W2dwCrV1TpnF-;aMsR~#*qwdGhr;M+!8R~lT!3S`AO->UF# z3@CpoxG*Ejip~PujPK%Tc$LSlclbs3A+*lFd&3iXSO4esT(C>QteDLCQz(5OsC%ch zGY=$1?g^ub2N9S46cq#98WEIpads1%n%&IFeU3#SB81*az%T7%-zGsEu;2PxR7eaZ zsBvg92`076?h~ zk9CZxI&13$Ney#eGhO@Zxv+68I?xGfQr|mT8Lhs!+D2U}Lllx~)_^cj^V77}&IG*A zgt<^GBX=Wv-(XTQd%|X@?)2o)V#Oc^i?xC_Eh7QHFlO{gqd+%F+EEZh^hJ8t~oH8}to5bp3zBO#i_wwpY+ph#xZZ_up-@$x&~XyWY47brKVa^tb>8nZ+{VUGUK}lxghIk#hJ_a;CE-bT>}PMj zOWES3q}$uoRrL=9dcq6*}A_@BXAtfiM_aRQiSWO`_a+EI0 zQc36wrRdqWLx@EA!op}TT9#sJ#esJ%0foRG&Bda<@xMr$HJBTQBwo4f;+=k-@l!-a z=eJ<_!c+|)A)F}LDwy6uBk7?WLj`TmK$Ia7-UG}=X*)g9Z1n@Wz*e5TTWZM@)^+|` zQqwZ`wH8;g($Y|i*7eSswusrms(k%is!z zR_8|B;mm2ISL^Xr*luDciK1}MPKZ&c-E*Y}Y3}<@IX1L?d%D^_B?7 z0oBWar6EJ9NeNLt>!FUaAuu~)qIC(j#QWrrQsJoO{u3K)AfkK-_e5z8I8 zf&<5~cz`NcilS@)PtKdb8SCWv7Ks5M6^O>QRb?cvSXu7G4##CFgQ8m!3Jy2Jqk!46 zbmjon{;HXQf4Uf7ePt9wh3#@4M>wv3glKm5)SG^G_#ohKU-lqZ#GjtRtl1H_>{nJU9>n+6E73#S_gJ^cj#t+)Cs-abBQ|P)Zc@wLm+HwlBoCdch!eN4 zRd+Xie4!)myt$#chDm4mXpNE)MpdeBlE9uaiY-{0C$@Rnw#F7DkPy{6vcx;fX_`zi z7@=&aEmO0x?LRsSi?r>sEnGz&p`8t#Xu?cjN3Nf}J1$KdffJipj97fe3hqGjEWDO% zU*TWalg81h{KBYk?T4`4>G7<4bFI7sGk$L%KI*zV8Kp`}5yEb!H0}GECjAEZHw*Yj zB+EoU&!7ec0AT%zN%&9O17`Yvv4Ba{?SDivpJ`oz8xk6eK}$|6OVhHI7$B;2f__ZB z7+{(#>psM?xI|;%_x)!a3XU*E&{HA5Ljrm6txeZ$Z`VZB>t|^imxIn`Qa)er+sQV3 z#Wl$cXP>Pg<){AF_dTmRNcP}@p<@Rm!FL

-VpGUq}5-kFU4O^_F{{oVdX>gb3KO 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 z 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%0D9H$V5y+(&;x3nRbRxLI2D0-uJIg4 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

Ky6>LP(17AFN-W9?Q(f!p|Jk4$j!uXD-JtjX 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

mzTF+bp&R_ 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

mayURNf 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

pt}0@N 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
+

K

+ +

Table of Contents

+ +
+
+

K is a rewrite-based
+executable semantic framework in which programming languages, type
+systems and formal analysis tools can be defined using configurations
+and rules. Configurations organize the state in units called cells,
+which are labeled and can be nested. K rewrite rules make it explicit
+which parts of the term are read-only, write-only, read-write, or
+unused. This makes K suitable for defining truly concurrent languages
+even in the presence of sharing. Computations are represented as
+syntactic extensions of the original language abstract syntax, using a
+nested list structure which sequentializes computational tasks, such
+as program fragments. Computations are like any other terms in a
+rewriting environment: they can be matched, moved from one place to
+another, modified, or deleted. This makes K suitable for defining
+control-intensive features such as abrupt termination, exceptions, or
+call/cc.

+

K Tool Download

+ +
    +
  • Install from the latest K GitHub Release.
  • +
  • Try our Editor Support page for links to K syntax highlighting definitions for various popular editors/IDEs. Please feel free to contribute.
  • +
  • Build or browse the code on GitHub, where you can also report bugs.
  • +
+

Learn K

+ + +

Support

+ + +

Resources

+ + +

K Tutorial

+ +

The purpose of this series of lessons is to teach developers how to program in
+K. While the primary use of K is in the specification of operational semantics
+of programming languages, this tutorial is agnostic on how the knowledge of K
+is used. For a more detailed tutorial explaining the basic principles of
+programming language design, refer to the
+K PL Tutorial. Note that that tutorial is somewhat
+out of date presently.

+

This K tutorial is a work in progress. Many lessons are currently simply
+placeholders for future content.

+

To start the K tutorial, begin with
+Section 1: Basic Programming in K.

+

Section 1: Basic K Concepts

+ +

The goal of this first section of the K tutorial is to teach the basic
+principles of K to someone with no prior experience with K as a programming
+language. However, this is not written with the intended audience of someone
+who is a complete beginner to programming. We are assuming that the reader
+has a firm grounding in computer science broadly, as well as that they have
+experience writing code in functional programming languages before.

+

By the end of this section, the reader ought to be able to write specifications
+of simple languages in K, use these specifications to generate a fast
+interpreter for their programming language, as well as write basic deductive
+program verification proofs over programs in their language. This should give
+them the theoretical grounding they need to begin expanding their knowledge
+of K in Section 2: Intermediate K Concepts.

+

To begin this section, refer to
+Lesson 1.1: Setting up a K Environment.

+

Lesson 1.1: Setting up a K Environment

+ +

The first step to learning K is to install K on your system, and configure your
+editor for K development.

+

Installing K

+ +

You have two options for how to install K, depending on how you intend to
+interact with the K codebase. If you are solely a user of K, and have no
+interest in developing or making changes to K, you most likely will want to
+install one of our binary releases of K. However, if you are going to be a K
+developer, or simply want to build K from source, you should follow the
+instructions for a source build of K.

+

Installing K from a binary release

+ +

K is developed as a rolling release, with each change to K that passes our
+CI infrastructure being deployed on GitHub for download. The latest release of
+K can be downloaded here.
+This page also contains information on how to install K. It is recommended
+that you fully uninstall the old version of K prior to installing the new one,
+as K does not maintain entries in package manager databases, with the exception
+of Homebrew on MacOS.

+

Installing K from source

+ +

You can clone K from GitHub with the following Git command:

+
git clone https://github.com/runtimeverification/k --recursive
+

Instructions on how to build K from source can be found
+here.

+

Configuring your editor

+ +

K maintains a set of scripts for a variety of text editors, including vim and
+emacs, in various states of maintenance. You can download these scripts with
+the following Git command:

+
git clone https://github.com/kframework/k-editor-support
+

Because K allows users to define their own grammars for parsing K itself,
+not all features of K can be effectively highlighted. However, at the cost of
+occasionally highlighting things incorrectly, you can get some pretty good
+results in many cases. With that being said, some of the editor scripts in the
+above repository are pretty out of date. If you manage to improve them, we
+welcome pull requests into the repository.

+

Troubleshooting

+ +

If you have problems installing K, we encourage you to reach out to us. If you
+follow the above install instructions and run into a problem, you can
+Create a bug report on GitHub

+

Next lesson

+ +

Once you have set up K on your system to your satisfaction, you can continue to
+Lesson 1.2: Basics of Functional K.

+

Lesson 1.2: Basics of Functional K

+ +

The purpose of this lesson is to explain the basics of productions and
+rules in K. These are two types of K sentences. A K file consists of
+one or more requires or modules in K. Each module consists of one or
+more imports or sentences. For more information on requires, modules, and
+sentences, refer to Lesson 1.5. However, for the time
+being, just think of a module as a container for sentences, and don't worry
+about requires or imports just yet.

+

Our first K program

+ +

To start with, input the following program into your editor as file
+lesson-02-a.k:

+
module LESSON-02-A
+
+  syntax Color ::= Yellow() | Blue()
+  syntax Fruit ::= Banana() | Blueberry()
+  syntax Color ::= colorOf(Fruit) [function]
+
+  rule colorOf(Banana()) => Yellow()
+  rule colorOf(Blueberry()) => Blue()
+
+endmodule
+

Save this file and then run:

+
kompile lesson-02-a.k
+

kompile is K's compiler. By default, it takes a program or specification
+written in K and compiles it into an interpreter for that input. Right now we
+are compiling a single file. A set of K files that are compiled together are
+called a K definition. We will cover multiple file K definitions later on.
+kompile will output a directory containing everything needed to execute
+programs and perform proofs using that definition. In this case, kompile will
+(by default) create the directory lesson-02-a-kompiled under the current
+directory.

+

Now, save the following input file in your editor as banana.color in the same
+directory as lesson-02-a.k:

+
colorOf(Banana())
+

We can now evaluate this K term by running (from the same directory):

+
krun banana.color
+

krun will use the interpreter generated by the first call to kompile to
+execute this program.

+

You will get the following output:

+
<k>
+  Yellow ( ) ~> .
+</k>
+

For now, don't worry about the <k>, </k>, or ~> . portions of this
+output file.

+

You can also execute small programs directly by specifying them on the command
+line instead of putting them in a file. For example, the same program above
+could also have been executed by running the following command:

+
krun -cPGM='colorOf(Banana())'
+

Now, let's look at what this definition and program did.

+

Productions, Constructors, and Functions

+ +

The first thing to realize is that this K definition contains 5 productions.
+Productions are introduced with the syntax keyword, followed by a sort,
+followed by the operator ::= followed by the definition of one or more
+productions themselves, separated by the | operator. There are different
+types of productions, but for now we only care about constructors and
+functions. Each declaration separated by the | operator is individually
+a single production, and the | symbol simply groups together productions that
+have the same sort. For example, we could equally have written an identical K
+definition lesson-02-b.k like so:

+
module LESSON-02-B
+
+  syntax Color ::= Yellow()
+  syntax Color ::= Blue()
+  syntax Fruit ::= Banana()
+  syntax Fruit ::= Blueberry()
+  syntax Color ::= colorOf(Fruit) [function]
+
+  rule colorOf(Banana()) => Yellow()
+  rule colorOf(Blueberry()) => Blue()
+
+endmodule
+

You can try compiling and running lesson-02-b.k to see that it produces the same output as lesson-02-a.k:

+
kompile lesson-02-b.k
+krun -cPGM='colorOf(Banana())' --definition 'lesson-02-b-kompiled'
+

where the --definition attribute points to the directory containing a compiled version of LESSON-02-B.
+Even the following definition is equivalent:

+
module LESSON-02-C
+
+  syntax Color ::= Yellow()
+                 | Blue()
+                 | colorOf(Fruit) [function]
+  syntax Fruit ::= Banana()
+                 | Blueberry()
+
+  rule colorOf(Banana()) => Yellow()
+  rule colorOf(Blueberry()) => Blue()
+
+endmodule
+

Each of these types of productions named above has the same underlying syntax,
+but context and attributes are used to distinguish between the different
+types. Tokens, brackets, lists, macros, aliases, and anywhere productions will
+be covered in a later lesson, but this lesson does introduce us to constructors
+and functions. Yellow(), Blue(), Banana(), and Blueberry() are
+constructors. You can think of a constructor like a constructor for an
+algebraic data type, if you're familiar with a functional language. The data
+type itself is the sort that appears on the left of the ::= operator. Sorts
+in K consist of uppercase identifiers.

+

Constructors can have arguments, but these ones do not. We will cover the
+syntax of productions in detail in the next lesson, but for now, you can write
+a production with no arguments as an uppercase or lowercase identifier followed
+by the () operator.

+

A function is distinguished from a constructor by the presence of the
+function attribute. Attributes appear in a comma separated list between
+square brackets after any sentence, including both productions and rules.
+Various attributes with built-in meanings exist in K and will be discussed
+throughout the tutorial.

+

Exercise

+ +

Use krun to compute the return value of the colorOf function on a
+Blueberry().

+

Rules, Matching, and Variables

+ +

Functions in K are given definitions using rules. A rule begins with the rule
+keyword and contains at least one rewrite operator. The rewrite operator
+is represented by the syntax =>. The rewrite operator is one of the built-in
+productions in K, and we will discuss in more detail how it can be used in
+future lessons, but for now, you can think of a rule as consisting of a
+left-hand side and a right-hand side, separated by the rewrite
+operator. On the left-hand side is the name of the function and zero or more
+patterns corresponding to the parameters of the function. On the right-hand
+side is another pattern. The meaning of the rule is relatively simple, having
+defined these components. If the function is called with arguments that
+match the patterns on the left-hand side, then the return value of the
+function is the pattern on the right-hand side.

+

For example, in the above example, if the argument of the colorOf function
+is Banana(), then the return value of the function is Yellow().

+

So far we have introduced that a constructor is a type of pattern in K. We
+will introduce more complex patterns in later lessons, but there is one other
+type of basic pattern: the variable. A variable, syntactically, consists
+of an uppercase identifier. However, unlike a constructor, a variable will
+match any pattern with one exception: Two variables with the same name
+must match the same pattern.

+

Here is a more complex example (lesson-02-d.k):

+
module LESSON-02-D
+
+  syntax Container ::= Jar(Fruit)
+  syntax Fruit ::= Apple() | Pear()
+
+  syntax Fruit ::= contentsOfJar(Container) [function]
+
+  rule contentsOfJar(Jar(F)) => F
+
+endmodule
+

Here we see that Jar is a constructor with a single argument. You can write a
+production with multiple arguments by putting the sorts of the arguments in a
+comma-separated list inside the parentheses.

+

In this example, F is a variable. It will match either Apple() or Pear().
+The return value of the function is created by substituting the matched
+values of all of the variables into the variables on the right-hand side of
+the rule.

+

To demonstrate, compile this definition and execute the following program with
+krun:

+
contentsOfJar(Jar(Apple()))
+

You will see when you run it that the program returns Apple(), because that
+is the pattern that was matched by F.

+

Exercises

+ +
    +
  1. Extend the definition in lesson-02-a.k with the addition of blackberries
    +and kiwis. For simplicity, blackberries are black and kiwis are green. Then
    +compile your definition and test that your additional fruits are correctly
    +handled by the colorOf function.
  2. +
  3. Create a new definition which defines an outfit as a multi-argument
    +constructor consisting of a hat, shirt, pants, and shoes. Define a new sort,
    +Boolean, with two constructors, true and false. Each of hat, shirt, pants,
    +and shoes will have a single argument (a color), either black or
    +white. Then define an outfitMatching function that will return true if all
    +the pieces of the outfit are the same color. You do not need to define the
    +case that returns false. Write some tests that your function behaves the way
    +you expect.
  4. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.3: BNF Syntax and Parser Generation.

+

Lesson 1.3: BNF Syntax and Parser Generation

+ +

The purpose of this lesson is to explain the full syntax and semantics of
+productions in K as well as how productions and other syntactic
+sentences can be used to define grammars for use parsing both rules as well
+as programs.

+

K's approach to parsing

+ +

K's grammar is divided into two components: the outer syntax of K and the
+inner syntax of K. Outer syntax refers to the parsing of requires,
+modules, imports, and sentences in a K definition. Inner syntax
+refers to the parsing of rules and programs. Unlike the outer syntax of
+K, which is predetermined, much of the inner syntax of K is defined by you, the
+developer. When rules or programs are parsed, they are parsed within the
+context of a module. Rules are parsed in the context of the module in which
+they exist, whereas programs are parsed in the context of the
+main syntax module of a K definition. The productions and other syntactic
+sentences in a module are used to construct the grammar of the module, which
+is then used to perform parsing.

+

Basic BNF productions

+ +

To illustrate how this works, we will consider a simple K definition which
+defines a relatively basic calculator capable of evaluating Boolean expressions
+containing and, or, not, and xor.

+

Input the following program into your editor as file lesson-03-a.k:

+
module LESSON-03-A
+
+  syntax Boolean ::= "true" | "false"
+                   | "!" Boolean [function]
+                   | Boolean "&&" Boolean [function]
+                   | Boolean "^" Boolean [function]
+                   | Boolean "||" Boolean [function]
+
+endmodule
+

You will notice that the productions in this file look a little different than
+the ones from the previous lesson. In point of fact, K has two different
+mechanisms for defining productions. We have previously been focused
+exclusively on the first mechanism, where the ::= symbol is followed by an
+alphanumeric identifier followed by a comma-separated list of sorts in
+parentheses. However, this is merely a special case of a more generic mechanism
+for defining the syntax of productions using a variant of
+BNF Form.

+

For example, in the previous lesson, we had the following set of productions:

+
module LESSON-03-B
+  syntax Color ::= Yellow() | Blue()
+  syntax Fruit ::= Banana() | Blueberry()
+  syntax Color ::= colorOf(Fruit) [function]
+endmodule
+

It turns out that this is equivalent to the following definition which defines
+the same grammar, but using BNF notation:

+
module LESSON-03-C
+  syntax Color ::= "Yellow" "(" ")" | "Blue" "(" ")"
+  syntax Fruit ::= "Banana" "(" ")" | "Blueberrry" "(" ")"
+  syntax Color ::= "colorOf" "(" Fruit ")" [function]
+endmodule
+

In this example, the sorts of the argument to the function are unchanged, but
+everything else has been wrapped in double quotation marks. This is because
+in BNF notation, we distinguish between two types of production items:
+terminals and non-terminals. A terminal represents simply a literal
+string of characters that is verbatim part of the syntax of that production.
+A non-terminal, conversely, represents a sort name, where the syntax of that
+production accepts any valid term of that sort at that position.

+

This is why, when we wrote the program colorOf(Banana()), krun was able to
+execute that program: because it represented a term of sort Color that was
+parsed and interpreted by K's interpreter. In other words, krun parses and
+interprets terms according to the grammar defined by the developer. It is
+automatically converted into an AST of that term, and then the colorOf
+function is evaluated using the function rules provided in the definition.

+

You can ask yourself: How does K match the strings between the double quotes?
+The answer is that K uses Flex to generate a scanner for the grammar. Flex looks
+for the longest possible match of a regular expression in the input. If there
+are ambiguities between 2 or more regular expressions, it will pick the one with
+the highest prec attribute. You can learn more about how Flex matching works
+here.

+

Bringing us back to the file lesson-03-a.k, we can see that this grammar
+has given a simple BNF grammar for expressions over Booleans. We have defined
+constructors corresponding to the Boolean values true and false, and functions
+corresponding to the Boolean operators for and, or, not, and xor. We have also
+given a syntax for each of these functions based on their syntax in the C
+programming language. As such, we can now write programs in the simple language
+we have defined.

+

Input the following program into your editor as and.bool in the same
+directory:

+
true && false
+

We cannot interpret this program yet, because we have not given rules defining
+the meaning of the && function yet, but we can parse it. To do this, you can
+run (from the same directory):

+
kast --output kore and.bool
+

kast is K's just-in-time parser. It will generate a grammar from your K
+definition on the fly and use it to parse the program passed on the command
+line. The --output flag controls how the resulting AST is represented; don't
+worry about the possible values yet, just use kore.

+

You ought to get the following AST printed on standard output, minus the
+formatting:

+
inj{SortBoolean{}, SortKItem{}}(
+  Lbl'UndsAnd-And-UndsUnds'LESSON-03-A'Unds'Boolean'Unds'Boolean'Unds'Boolean{}(
+    Lbltrue'Unds'LESSON-03-A'Unds'Boolean{}(),
+    Lblfalse'Unds'LESSON-03-A'Unds'Boolean{}()
+  )
+)
+

Don't worry about what exactly this means yet, just understand that it
+represents the AST of the program that you just parsed. You ought to be able
+to recognize the basic shape of it by seeing the words true, false, and
+And in there. This is Kore, the intermediate representation of K, and we
+will cover it in detail later.

+

Note that you can also tell kast to print the AST in other formats. For a
+more direct representation of the original K, while still maintaining the
+structure of an AST, you can say kast --output kast and.bool. This will
+yield the following output:

+
`_&&__LESSON-03-A_Boolean_Boolean_Boolean`(
+  `true_LESSON-03-A_Boolean`(.KList),
+  `false_LESSON-03-A_Boolean`(.KList)
+)
+

Note how the first output is largely a name-mangled version of the second
+output. The one difference is the presence of the inj symbol in the KORE
+output. We will talk more about this in later lessons.

+

Exercise

+ +

Parse the expression false || true with --output kast. See if you can
+predict approximately what the corresponding output would be with
+--output kore, then run the command yourself and compare it to your
+prediction.

+

Ambiguities

+ +

Now let's try a slightly more advanced example. Input the following program
+into your editor as and-or.bool:

+
true && false || false
+

When you try and parse this program, you ought to see the following error:

+
[Error] Inner Parser: Parsing ambiguity.
+1: syntax Boolean ::= Boolean "||" Boolean [function]
+
+`_||__LESSON-03-A_Boolean_Boolean_Boolean`(`_&&__LESSON-03-A_Boolean_Boolean_Boolean`(`true_LESSON-03-A_Boolean`(.KList),`false_LESSON-03-A_Boolean`(.KList)),`false_LESSON-03-A_Boolean`(.KList))
+2: syntax Boolean ::= Boolean "&&" Boolean [function]
+
+`_&&__LESSON-03-A_Boolean_Boolean_Boolean`(`true_LESSON-03-A_Boolean`(.KList),`_||__LESSON-03-A_Boolean_Boolean_Boolean`(`false_LESSON-03-A_Boolean`(.KList),`false_LESSON-03-A_Boolean`(.KList)))
+        Source(./and-or.bool)
+        Location(1,1,1,23)
+

This error is saying that kast was unable to parse this program because it is
+ambiguous. K's just-in-time parser is a GLL parser, which means it can handle
+the full generality of context-free grammars, including those grammars which
+are ambiguous. An ambiguous grammar is one where the same string can be parsed
+as multiple distinct ASTs. In this example, it can't decide whether it should
+be parsed as (true && false) || false or as true && (false || false). As a
+result, it reports the error to the user.

+

Brackets

+ +

Currently there is no way of resolving this ambiguity, making it impossible
+to write complex expressions in this language. This is obviously a problem.
+The standard solution in most programming languages to this problem is to
+use parentheses to indicate the appropriate grouping. K generalizes this notion
+into a type of production called a bracket. A bracket production in K
+is any production with the bracket attribute. It is required that such a
+production only have a single non-terminal, and the sort of the production
+must equal the sort of that non-terminal. However, K does not otherwise
+impose restrictions on the grammar the user provides for a bracket. With that
+being said, the most common type of bracket is one in which a non-terminal
+is surrounded by terminals representing some type of bracket such as
+(), [], {}, <>, etc. For example, we can define the most common
+type of bracket, the type used by the vast majority of programming languages,
+quite simply.

+

Consider the following modified definition, which we will save to
+lesson-03-d.k:

+
module LESSON-03-D
+
+  syntax Boolean ::= "true" | "false"
+                   | "(" Boolean ")" [bracket]
+                   | "!" Boolean [function]
+                   | Boolean "&&" Boolean [function]
+                   | Boolean "^" Boolean [function]
+                   | Boolean "||" Boolean [function]
+
+endmodule
+

In this definition, if the user does not explicitly define parentheses, the
+grammar remains ambiguous and K's just-in-time parser will report an error.
+However, you are now able to parse more complex programs by means of explicitly
+grouping subterms with the bracket we have just defined.

+

Consider and-or-left.bool:

+
(true && false) || false
+

Now consider and-or-right.bool:

+
true && (false || false)
+

If you parse these programs with kast, you will once again get a single
+unique AST with no error. If you look, you might notice that the bracket itself
+does not appear in the AST. In fact, this is a property unique to brackets:
+productions with the bracket attribute are not represented in the parsed AST
+of a term, and the child of the bracket is folded immediately into the parent
+term. This is the reason for the requirement that a bracket production have
+a single non-terminal of the same sort as the production itself.

+

Exercise

+ +

Write out what you expect the AST to be arising from parsing these two programs
+above with --output kast, then parse them yourself and compare them to the
+AST you expected. Confirm for yourself that the bracket production does not
+appear in the AST.

+

Tokens

+ +

So far we have seen how we can define the grammar of a language. However,
+the grammar is not the only relevant part of parsing a language. Also relevant
+is the lexical syntax of the language. Thus far, we have implicitly been using
+K's automatic lexer generation to generate a token in the scanner for each
+terminal in our grammar. However, sometimes we wish to define more complex
+lexical syntax. For example, consider the case of integers in C: an integer
+consists of a decimal, octal, or hexadecimal number followed by an optional
+suffix indicating the type of the literal.

+

In theory it would be possible to define this syntax via a grammar, but not
+only would it be cumbersome and tedious, you would also then have to deal with
+an AST generated for the literal which is not convenient to work with.

+

Instead of doing this, K allows you to define token productions, where
+a production consists of a regular expression followed by the token
+attribute, and the resulting AST consists of a typed string containing the
+value recognized by the regular expression.

+

For example, the builtin integers in K are defined using the following
+production:

+
syntax Int ::= r"[\\+-]?[0-9]+" [token]
+

Here we can see that we have defined that an integer is an optional sign
+followed by a nonzero sequence of digits. The r preceding the terminal
+indicates that what appears inside the double quotes is a regular expression,
+and the token attribute indicates that terms which parse as this production
+should be converted into a token by the parser.

+

It is also possible to define tokens that do not use regular expressions. This
+can be useful when you wish to declare particular identifiers for use in your
+semantics later. For example:

+
syntax Id ::= "main" [token]
+

Here, we declare that main is a token of sort Id. Instead of being parsed
+as a symbol, it gets parsed as a token, generating a typed string in the AST.
+This is useful in a semantics of C because the parser generally does not treat
+the main function in C specially; only the semantics treats it specially.

+

Of course, languages can have more complex lexical syntax. For example, if we
+wish to define the syntax of integers in C, we could use the following
+production:

+
syntax IntConstant ::= r"(([1-9][0-9]*)|(0[0-7]*)|(0[xX][0-9a-fA-F]+))(([uU][lL]?)|([uU]((ll)|(LL)))|([lL][uU]?)|(((ll)|(LL))[uU]?))?" [token]
+

As you may have noted above, long and complex regular expressions
+can be hard to read. They also suffer from the problem that unlike a grammar,
+they are not particularly modular.

+

We can get around this restriction by declaring explicit regular expressions,
+giving them a name, and then referring to them in productions.

+

Consider the following (equivalent) way to define the lexical syntax of
+integers in C:

+
syntax IntConstant ::= r"({DecConstant}|{OctConstant}|{HexConstant})({IntSuffix}?)" [token]
+syntax lexical DecConstant = r"{NonzeroDigit}({Digit}*)"
+syntax lexical OctConstant = r"0({OctDigit}*)"
+syntax lexical HexConstant = r"{HexPrefix}({HexDigit}+)"
+syntax lexical HexPrefix = r"0x|0X"
+syntax lexical NonzeroDigit = r"[1-9]"
+syntax lexical Digit = r"[0-9]"
+syntax lexical OctDigit = r"[0-7]"
+syntax lexical HexDigit = r"[0-9a-fA-F]"
+syntax lexical IntSuffix = r"{UnsignedSuffix}({LongSuffix}?)|{UnsignedSuffix}{LongLongSuffix}|{LongSuffix}({UnsignedSuffix}?)|{LongLongSuffix}({UnsignedSuffix}?)"
+syntax lexical UnsignedSuffix = r"[uU]"
+syntax lexical LongSuffix = r"[lL]"
+syntax lexical LongLongSuffix = r"ll|LL"
+

As you can see, this is rather more verbose, but it has the benefit of both
+being much easier to read and understand, and also increased modularity.
+Note that we refer to a named regular expression by putting the name in curly
+brackets. Note also that only the first sentence actually declares a new piece
+of syntax in the language. When the user writes syntax lexical, they are only
+declaring a regular expression. To declare an actual piece of syntax in the
+grammar, you still must actually declare an explicit token production.

+

One final note: K uses Flex to implement
+its lexical analysis. As a result, you can refer to the
+Flex Manual
+for a detailed description of the regular expression syntax supported. Note
+that for performance reasons, Flex's regular expressions are actually a regular
+language, and thus lack some of the syntactic convenience of modern
+"regular expression" libraries. If you need features that are not part of the
+syntax of Flex regular expressions, you are encouraged to express them via
+a grammar instead.

+

Ahead-of-time parser generation

+ +

So far we have been entirely focused on K's support for just-in-time parsing,
+where the parser is generated on the fly prior to being used. This benefits
+from being faster to generate the parser, but it suffers in performance if you
+have to repeatedly parse strings with the same parser. For this reason, it is
+generally encouraged that when parsing programs, you use K's ahead-of-time
+parser generation. K makes use of
+GNU Bison to generate parsers.

+

By default, you can enable ahead-of-time parsing via the --gen-bison-parser
+flag to kompile. This will make use of Bison's LR(1) parser generator. As
+such, if your grammar is not LR(1), it may not parse exactly the same as if
+you were to use the just-in-time parser, because Bison will automatically pick
+one of the possible branches whenever it encounters a shift-reduce or
+reduce-reduce conflict. In this case, you can either modify your grammar to be
+LR(1), or you can enable use of Bison's GLR support by instead passing
+--gen-glr-bison-parser to kompile. Note that if your grammar is ambiguous,
+the ahead-of-time parser will not provide you with particularly readable error
+messages at this time.

+

If you have a K definition named foo.k, and it generates a directory when
+you run kompile called foo-kompiled, you can invoke the ahead-of-time
+parser you generated by running foo-kompiled/parser_PGM <file> on a file.

+

Exercises

+ +
    +
  1. +

    Compile lesson-03-d.k with ahead-of-time parsing enabled. Then compare
    +how long it takes to run kast --output kore and-or-left.bool with how long it
    +takes to run lesson-03-d-kompiled/parser_PGM and-or-left.bool. Confirm for
    +yourself that both produce the same result, but that the latter is faster.

    +
  2. +
  3. +

    Define a simple grammar consisting of integers, brackets, addition,
    +subtraction, multiplication, division, and unary negation. Integers should be
    +in decimal form and lexically without a sign, whereas negative numbers can be
    +represented via unary negation. Ensure that you are able to parse some basic
    +arithmetic expressions using a generated ahead-of-time parser. Do not worry
    +about disambiguating the grammar or about writing rules to implement the
    +operations in this definition.

    +
  4. +
  5. +

    Write a program where the meaning of the arithmetic expression based on
    +the grammar you defined above is ambiguous, and then write programs that
    +express each individual intended meaning using brackets.

    +
  6. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.4: Disambiguating Parses.

+

Lesson 1.4: Disambiguating Parses

+ +

The purpose of this lesson is to teach how to use K's builtin features for
+disambiguation to transform an ambiguous grammar into an unambiguous one that
+expresses the intended ASTs.

+

Priority blocks

+ +

In practice, very few formal languages outside the domain of natural language
+processing are ambiguous. The main reason for this is that parsing unambiguous
+languages is asymptotically faster than parsing ambiguous languages.
+Programming language designers instead usually use the notions of operator
+precedence and associativity to make expression grammars unambiguous. These
+mechanisms work by instructing the parser to reject certain ASTs in favor of
+others in case of ambiguities; it is often possible to remove all ambiguities
+in a grammar with these techniques.

+

While it is sometimes possible to explicitly rewrite the grammar to remove
+these parses, because K's grammar specification and AST generation are
+inextricably linked, this is generally discouraged. Instead, we use the
+approach of explicitly expressing the relative precedence of different
+operators in different situations in order to resolve the ambiguity.

+

For example, in C, && binds tighter in precedence than ||, meaning that
+the expression true && false || false has only one valid AST:
+(true && false) || false.

+

Consider, then, the third iteration on the grammar of this definition
+(lesson-04-a.k):

+
module LESSON-04-A
+
+  syntax Boolean ::= "true" | "false"
+                   | "(" Boolean ")" [bracket]
+                   > "!" Boolean [function]
+                   > Boolean "&&" Boolean [function]
+                   > Boolean "^" Boolean [function]
+                   > Boolean "||" Boolean [function]
+
+endmodule
+

In this example, some of the | symbols separating productions in a single
+block have been replaced with >. This serves to describe the
+priority groups associated with this block of productions.
+The first priority group consists of the atoms of the
+language: true, false, and the bracket operator. In general, a priority
+group starts either at the ::= or > operator and extends until either the
+next > operator or the end of the production block. Thus, we can see that the
+second, third, fourth, and fifth priority groups in this grammar all consist
+of a single production.

+

The meaning of these priority groups becomes apparent when parsing programs:
+A symbol with a lesser priority, (i.e., one that binds looser), cannot
+appear as the direct child of a symbol with a greater priority (i.e.,
+one that binds tighter. In this case, the > operator can be seen as a
+greater-than operator describing a transitive partial ordering on the
+productions in the production block, expressing their relative priority.

+

To see this more concretely, let's look again at the program
+true && false || false. As noted before, previously this program was
+ambiguous because the parser could either choose that && was the child of ||
+or vice versa. However, because a symbol with lesser priority (i.e., ||)
+cannot appear as the direct child of a symbol with greater priority
+(i.e., &&), the parser will reject the parse where || is under the
+&& operator. As a result, we are left with the unambiguous parse
+(true && false) || false. Similarly, true || false && false parses
+unambiguously as true || (false && false). Conversely, if the user explicitly
+wants the other parse, they can express this using brackets by explicitly
+writing true && (false || false). This still parses successfully because the
+|| operator is no longer the direct child of the && operator, but is
+instead the direct child of the () operator, and the && operator is an
+indirect parent, which is not subject to the priority restriction.

+

Astute readers, however, will already have noticed what seems to be a
+contradiction: we have defined () as also having greater priority than ||.
+One would think that this should mean that || cannot appear as a direct
+child of (). This is a problem because priority groups are applied to every
+possible parse separately. That is to say, even if the term is unambiguous
+prior to this disambiguation rule, we still reject that parse if it violates
+the rule of priority.

+

In fact, however, we do not reject this program as a parse error. Why is that?
+Well, the rule for priority is slightly more complex than previously described.
+In actual fact, it applies only conditionally. Specifically, it applies in
+cases where the child is either the first or last production item in the
+parent's production. For example, in the production Bool "&&" Bool, the
+first Bool non-terminal is not preceded by any terminals, and the last Bool
+non-terminal is not followed by any terminals. As a result of this, we apply
+the priority rule to both children of &&. However, in the () operator,
+the sole non-terminal is both preceded by and followed by terminals. As a
+result, the priority rule is not applied when () is the parent. Because of
+this, the program we mentioned above successfully parses.

+

Exercise

+ +

Parse the program true && false || false using kast, and confirm that the AST
+places || as the top level symbol. Then modify the definition so that you
+will get the alternative parse.

+

Associativity

+ +

Even having broken the expression grammar into priority blocks, the resulting
+grammar is still ambiguous. We can see this if we try to parse the following
+program (assoc.bool):

+
true && false && false
+

Priority blocks will not help us here: the problem comes between two parses
+where both possible parses have a direct parent and child which is within a
+single priority block (in this case, && is in the same block as itself).

+

This is where the notion of associativity comes into play. Associativity
+applies the following additional rules to parses:

+
    +
  • a left-associative symbol cannot appear as a direct rightmost child of a
    +symbol with equal priority;
  • +
  • a right-associative symbol cannot appear as a direct leftmost child of a
    +symbol with equal priority; and
  • +
  • a non-associative symbol cannot appear as a direct leftmost or rightmost
    +child of a symbol with equal priority.
  • +
+

In C, binary operators are all left-associative, meaning that the expression
+true && false && false parses unambiguously as (true && false) && false,
+because && cannot appear as the rightmost child of itself.

+

Consider, then, the fourth iteration on the grammar of this definition
+(lesson-04-b.k):

+
module LESSON-04-B
+
+  syntax Boolean ::= "true" | "false"
+                   | "(" Boolean ")" [bracket]
+                   > "!" Boolean [function]
+                   > left: Boolean "&&" Boolean [function]
+                   > left: Boolean "^" Boolean [function]
+                   > left: Boolean "||" Boolean [function]
+
+endmodule
+

Here each priority group, immediately after the ::= or > operator, can
+be followed by a symbol representing the associativity of that priority group:
+either left: for left associativity, right: for right associativity, or
+non-assoc: for non-associativity. In this example, each priority group we
+apply associativity to has only a single production, but we could equally well
+write a priority block with multiple productions and an associativity.

+

For example, consider the following, different grammar (lesson-04-c.k):

+
module LESSON-04-C
+
+  syntax Boolean ::= "true" | "false"
+                   | "(" Boolean ")" [bracket]
+                   > "!" Boolean [function]
+                   > left:
+                     Boolean "&&" Boolean [function]
+                   | Boolean "^" Boolean [function]
+                   | Boolean "||" Boolean [function]
+
+endmodule
+

In this example, unlike the one above, &&, ^, and || have the same
+priority. However, viewed as a group, the entire group is left associative.
+This means that none of &&, ^, and || can appear as the right child of
+any of &&, ^, or ||. As a result of this, this grammar is also not
+ambiguous. However, it expresses a different grammar, and you are encouraged
+to think about what the differences are in practice.

+

Exercise

+ +

Parse the program true && false && false yourself, and confirm that the AST
+places the rightmost && at the top of the expression. Then modify the
+definition to generate the alternative parse.

+

Explicit priority and associativity declarations

+ +

Previously we have only considered the case where all of the productions
+which you wish to express a priority or associativity relation over are
+co-located in the same block of productions. However, in practice this is not
+always feasible or desirable, especially as a definition grows in size across
+multiple modules.

+

As a result of this, K provides a second way of declaring priority and
+associativity relations.

+

Consider the following grammar, which we will name lesson-04-d.k and which
+will express the exact same grammar as lesson-04-b.k

+
module LESSON-04-D
+
+  syntax Boolean ::= "true" [group(literal)] | "false" [group(literal)]
+                   | "(" Boolean ")" [group(atom), bracket]
+                   | "!" Boolean [group(not), function]
+                   | Boolean "&&" Boolean [group(and), function]
+                   | Boolean "^" Boolean [group(xor), function]
+                   | Boolean "||" Boolean [group(or), function]
+
+  syntax priorities literal atom > not > and > xor > or
+  syntax left and
+  syntax left xor
+  syntax left or
+endmodule
+

This introduces a couple of new features of K. First, the group(_) attribute
+is used to conceptually group together sets of sentences under a common
+user-defined name. For example, literal in the syntax priorities sentence is
+used to refer to all the productions marked with the group(literal) attribute,
+i.e., true and false. A production can belong to multiple groups using
+syntax such as group(myGrp1,myGrp2).

+

Once we understand this, it becomes relatively straightforward to understand
+the meaning of this grammar. Each syntax priorities sentence defines a
+priority relation where > separates different priority groups. Each priority
+group is defined by a list of one or more group names, and consists of all
+productions which are members of at least one of those named groups.

+

In the same way, a syntax left, syntax right, or syntax non-assoc sentence
+defines an associativity relation among left-, right-, or non-associative
+groups. Specifically, this means that:

+
syntax left a b
+

is different to:

+
syntax left a
+syntax left b
+

As a consequence of this, syntax [left|right|non-assoc] should not be used to
+group together labels with different priority.

+

Prefer/avoid

+ +

Sometimes priority and associativity prove insufficient to disambiguate a
+grammar. In particular, sometimes it is desirable to be able to choose between
+two ambiguous parses directly while still not rejecting any parses if the term
+parsed is unambiguous. A good example of this is the famous "dangling else"
+problem in imperative C-like languages.

+

Consider the following definition (lesson-04-E.k):

+
module LESSON-04-E
+
+  syntax Exp ::= "true" | "false"
+  syntax Stmt ::= "if" "(" Exp ")" Stmt
+                | "if" "(" Exp ")" Stmt "else" Stmt
+                | "{" "}"
+endmodule
+

We can write the following program (dangling-else.if):

+
if (true) if (false) {} else {}
+

This is ambiguous because it is unclear whether the else clause is part of
+the outer if or the inner if. At first we might try to resolve this with
+priorities, saying that the if without an else cannot appear as a child of
+the if with an else. However, because the non-terminal in the parent symbol
+is both preceded and followed by a terminal, this will not work.

+

Instead, we can resolve the ambiguity directly by telling the parser to
+"prefer" or "avoid" certain productions when ambiguities arise. For example,
+when we parse this program, we see the following ambiguity as an error message:

+
[Error] Inner Parser: Parsing ambiguity.
+1: syntax Stmt ::= "if" "(" Exp ")" Stmt
+
+`if(_)__LESSON-04-E_Stmt_Exp_Stmt`(`true_LESSON-04-E_Exp`(.KList),`if(_)_else__LESSON-04-E_Stmt_Exp_Stmt_Stmt`(`false_LESSON-04-E_Exp`(.KList),`;_LESSON-04-E_Stmt`(.KList),`;_LESSON-04-E_Stmt`(.KList)))
+2: syntax Stmt ::= "if" "(" Exp ")" Stmt "else" Stmt
+
+`if(_)_else__LESSON-04-E_Stmt_Exp_Stmt_Stmt`(`true_LESSON-04-E_Exp`(.KList),`if(_)__LESSON-04-E_Stmt_Exp_Stmt`(`false_LESSON-04-E_Exp`(.KList),`;_LESSON-04-E_Stmt`(.KList)),`;_LESSON-04-E_Stmt`(.KList))
+        Source(./dangling-else.if)
+        Location(1,1,1,30)
+

Roughly, we see that the ambiguity is between an if with an else or an if
+without an else. Since we want to pick the first parse, we can tell K to
+"avoid" the second parse with the avoid attribute. Consider the following
+modified definition (lesson-04-f.k):

+
module LESSON-04-F
+
+  syntax Exp ::= "true" | "false"
+  syntax Stmt ::= "if" "(" Exp ")" Stmt
+                | "if" "(" Exp ")" Stmt "else" Stmt [avoid]
+                | "{" "}"
+endmodule
+

Here we have added the avoid attribute to the else production. As a result,
+when an ambiguity occurs and one or more of the possible parses has that symbol
+at the top of the ambiguous part of the parse, we remove those parses from
+consideration and consider only those remaining. The prefer attribute behaves
+similarly, but instead removes all parses which do not have that attribute.
+In both cases, no action is taken if the parse is not ambiguous.

+

Exercises

+ +
    +
  1. +

    Parse the program if (true) if (false) {} else {} using lesson-04-f.k
    +and confirm that else clause is part of the innermost if statement. Then
    +modify the definition so that you will get the alternative parse.

    +
  2. +
  3. +

    Modify your solution from Lesson 1.3, Exercise 2 so that unary negation should
    +bind tighter than multiplication and division, which should bind tighter than
    +addition and subtraction, and each binary operator should be left associative.
    +Write these priority and associativity declarations explicitly, and then
    +try to write them inline.

    +
  4. +
  5. +

    Write a simple grammar containing at least one ambiguity that cannot be
    +resolved via priority or associativity, and then use the prefer attribute to
    +resolve that ambiguity.

    +
  6. +
  7. +

    Explain why the following grammar is not labeled ambiguous by the K parser when parsing abb, then make the parser realize the ambiguity.

    +
  8. +
+
module EXERCISE4
+
+syntax Expr ::= "a" Expr "b"
+              | "abb"
+              | "b"
+
+endmodule
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.5: Modules, Imports, and Requires.

+

Lesson 1.5: Modules, Imports, and Requires

+ +

The purpose of this lesson is to explain how K definitions can be broken into
+separate modules and files and how these distinct components combine into a
+complete K definition.

+

K's outer syntax

+ +

Recall from Lesson 1.3 that K's grammar is broken
+into two components: the outer syntax of K and the inner syntax of K.
+Outer syntax, as previously mentioned, consists of requires, modules,
+imports, and sentences. A K semantics is expressed by the set of
+sentences contained in the definition. The scope of what is considered
+contained in that definition is determined both by the main semantics
+module
of a K definition, as well as the requires and imports present
+in the file that contains that module.

+

Basic module syntax

+ +

The basic unit of grouping sentences in K is the module. A module consists
+of a module name, an optional list of attributes, a list of
+imports, and a list of sentences.

+

A module name consists of one or more groups of letters, numbers, or
+underscores, separated by a hyphen. Here are some valid module names: FOO,
+FOO-BAR, foo0, foo0_bar-Baz9. Here are some invalid module names: -,
+-FOO, BAR-, FOO--BAR. Stylistically, modules names are usually all
+uppercase with hyphens separating words, but this is not strictly enforced.

+

Some example modules include an empty module:

+
module LESSON-05-A
+
+endmodule
+

A module with some attributes:

+
module LESSON-05-B [group(attr1,attr2), private]
+
+endmodule
+

A module with some sentences:

+
module LESSON-05-C
+  syntax Boolean ::= "true" | "false"
+  syntax Boolean ::= "not" Boolean [function]
+  rule not true => false
+  rule not false => true
+endmodule
+

Imports

+ +

Thus far we have only discussed definitions containing a single module.
+Definitions can also contain multiple modules, in which one module imports
+others.

+

An import in K appears at the top of a module, prior to any sentences. It can
+be specified with the imports keyword, followed by a module name.

+

For example, here is a simple definition with two modules (lesson-05-d.k):

+
module LESSON-05-D-1
+  syntax Boolean ::= "true" | "false"
+  syntax Boolean ::= "not" Boolean [function]
+endmodule
+
+module LESSON-05-D
+  imports LESSON-05-D-1
+
+  rule not true => false
+  rule not false => true
+endmodule
+

This K definition is equivalent to the definition expressed by the single module
+LESSON-05-C. Essentially, by importing a module, we include all of the
+sentences in the module being imported into the module that we import from.
+There are a few minor differences between importing a module and simply
+including its sentences in another module directly, but we will cover these
+differences later. Essentially, you can think of modules as a way of
+conceptually grouping sentences in a larger K definition.

+

Exercise

+ +

Modify lesson-05-d.k to include four modules: one containing the syntax, two
+with one rule each that imports the first module, and a final module
+LESSON-05-D containing no sentences that imports the second and third module.
+Check to make sure the definition still compiles and that you can still evaluate
+the not function.

+

Parsing in the presence of multiple modules

+ +

As you may have noticed, each module in a definition can express a distinct set
+of syntax. When parsing the sentences in a module, we use the syntax
+of that module, enriched with the basic syntax of K, in order to parse
+rules in that module. For example, the following definition is a parser error
+(lesson-05-e.k):

+
module LESSON-05-E-1
+  rule not true => false
+  rule not false => true
+endmodule
+
+module LESSON-05-E-2
+  syntax Boolean ::= "true" | "false"
+  syntax Boolean ::= "not" Boolean [function]
+endmodule
+

This is because the syntax referenced in module LESSON-05-E-1, namely, not,
+true, and false, is not imported by that module. You can solve this problem
+by simply importing the modules containing the syntax you want to use in your
+sentences.

+

Main syntax and semantics modules

+ +

When we are compiling a K definition, we need to know where to start. We
+designate two specific entry point modules: the main syntax module
+and the main semantics module. The main syntax module, as well as all the
+modules it imports recursively, are used to create the parser for programs that
+you use to parse programs that you execute with krun. The main semantics
+module, as well as all the modules it imports recursively, are used to
+determine the rules that can be applied at runtime in order to execute a
+program. For example, in the above example, if the main semantics module is
+module LESSON-05-D-1, then not is an uninterpreted function (i.e., has no
+rules associated with it), and the rules in module LESSON-05-D are not
+included.

+

While you can specify the entry point modules explicitly by passing the
+--main-module and --syntax-module flags to kompile, by default, if you
+type kompile foo.k, then the main semantics module will be FOO and the
+main syntax module will be FOO-SYNTAX.

+

Splitting a definition into multiple files

+ +

So far, while we have discussed ways to break definitions into separate
+conceptual components (modules), K also provides a mechanism for combining
+multiple files into a single K definition, namely, the requires directive.

+

In K, the requires keyword has two meanings. The first, the requires
+statement, appears at the top of a K file, prior to any module declarations. It
+consists of the keyword requires followed by a double-quoted string. The
+second meaning of the requires keyword will be covered in a later lesson,
+but it is distinguished because the second case occurs only inside modules.

+

The string passed to the requires statement contains a filename. When you run
+kompile on a file, it will look at all of the requires statements in that
+file, look up those files on disk, parse them, and then recursively process all
+the requires statements in those files. It then combines all the modules in all
+of those files together, and uses them collectively as the set of modules to
+which imports statements can refer.

+

Putting it all together

+ +

Putting it all together, here is one possible way in which we could break the
+definition lesson-02-c.k from Lesson 1.2 into
+multiple files and modules:

+

colors.k:

+
module COLORS
+  syntax Color ::= Yellow()
+                 | Blue()
+endmodule
+

fruits.k:

+
module FRUITS
+  syntax Fruit ::= Banana()
+                 | Blueberry()
+endmodule
+

colorOf.k:

+
requires "fruits.k"
+requires "colors.k"
+
+module COLOROF-SYNTAX
+  imports COLORS
+  imports FRUITS
+
+  syntax Color ::= colorOf(Fruit) [function]
+endmodule
+
+module COLOROF
+  imports COLOROF-SYNTAX
+
+  rule colorOf(Banana()) => Yellow()
+  rule colorOf(Blueberry()) => Blue()
+endmodule
+

You would then compile this definition with kompile colorOf.k and use it the
+same way as the original, single-module definition.

+

Exercise

+ +

Modify the name of the COLOROF module, and then recompile the definition.
+Try to understand why you now get a compiler error. Then, resolve this compiler
+error by passing the --main-module and --syntax-module flags to kompile.

+

Include path

+ +

One note can be made about how paths are resolved in requires statements.

+

By default, the path you specify is allowed to be an absolute or a relative
+path. If the path is absolute, that exact file is imported. If the path is
+relative, a matching file is looked for within all of the
+include directories specified to the compiler. By default, the include
+directories include the current working directory, followed by the
+include/kframework/builtin directory within your installation of K. You can
+also pass one or more directories to kompile via the -I command line flag,
+in which case these directories are prepended to the beginning of the list.

+

Exercises

+ +
    +
  1. +

    Take the solution to Lesson 1.4, Exercise 2 which included the explicit
    +priority and associativity declarations, and modify the definition so that
    +the syntax of integers and brackets is in one module, the syntax of addition,
    +subtraction, and unary negation is in another module, and the syntax of
    +multiplication and division is in a third module. Make sure you can still parse
    +the same set of expressions as before. Place priority declarations in the main
    +module.

    +
  2. +
  3. +

    Modify lesson-02-d.k from Lesson 1.2 so that the rules and syntax are in
    +separate modules in separate files.

    +
  4. +
  5. +

    Place the file containing the syntax from Exercise 2 in another directory,
    +then recompile the definition. Observe why a compilation error occurs. Then
    +fix the compiler error by passing -I to kompile.

    +
  6. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.6: Integers and Booleans.

+

Lesson 1.6: Integers and Booleans

+ +

The purpose of this lesson is to explain the two most basic types of builtin
+sorts in K, the Int sort and the Bool sort, representing
+arbitrary-precision integers and Boolean algebra.

+

Builtin sorts in K

+ +

K provides definitions of some useful sorts in
+domains.md, found in the
+include/kframework/builtin directory of the K installation. This file is
+defined via a
+Literate programming
+style that we will discuss in a future lesson. We will not cover all of the
+sorts found there immediately, however, this lesson discusses some of the
+details surrounding integers and Booleans, as well as providing information
+about how to look up more detailed knowledge about builtin functions in K's
+documentation.

+

Booleans in K

+ +

The most basic builtin sort K provides is the Bool sort, representing
+Boolean values (i.e., true and false). You have already seen how we were
+able to create this type ourselves using K's parsing and disambiguation
+features. However, in the vast majority of cases, we prefer instead to import
+the version of Boolean algebra defined by K itself. Most simply, you can do
+this by importing the module BOOL in your definition. For example
+(lesson-06-a.k):

+
module LESSON-06-A
+  imports BOOL
+
+  syntax Fruit ::= Blueberry() | Banana()
+  syntax Bool ::= isBlue(Fruit) [function]
+
+  rule isBlue(Blueberry()) => true
+  rule isBlue(Banana()) => false
+endmodule
+

Here we have defined a simple predicate, i.e., a function returning a
+Boolean value. We are now able to perform the usual Boolean operations of
+and, or, and not over these values. For example (lesson-06-b.k):"

+
module LESSON-06-B
+  imports BOOL
+
+  syntax Fruit ::= Blueberry() | Banana()
+  syntax Bool ::= isBlue(Fruit) [function]
+
+  rule isBlue(Blueberry()) => true
+  rule isBlue(Banana()) => false
+
+  syntax Bool ::= isYellow(Fruit) [function]
+                | isBlueOrYellow(Fruit) [function]
+
+  rule isYellow(Banana()) => true
+  rule isYellow(Blueberry()) => false
+
+  rule isBlueOrYellow(F) => isBlue(F) orBool isYellow(F)
+endmodule
+

In the above example, Boolean inclusive or is performed via the orBool
+function, which is defined in the BOOL module. As a matter of convention,
+many functions over builtin sorts in K are suffixed with the name of the
+primary sort over which those functions are defined. This happens so that the
+syntax of K does not (generally) conflict with the syntax of any other
+programming language, which would make it harder to define that programming
+language in K.

+

Exercise

+ +

Write a function isBlueAndNotYellow which computes the appropriate Boolean
+expression. If you are unsure what the appropriate syntax is to use, you
+can refer to the BOOL module in
+domains.md. Add a term of
+sort Fruit for which isBlue and isYellow both return true, and test that
+the isBlueAndNotYellow function behaves as expected on all three Fruits.

+

Syntax Modules

+ +

For most sorts in domains.md, K defines more than one module that can be
+imported by users. For example, for the Bool sort, K defines the BOOL
+module that has previously already been discussed, but also provides the
+BOOL-SYNTAX module. This module, unlike the BOOL module, only declares the
+values true and false, but not any of the functions that operate over the
+Bool sort. The rationale is that you may want to import this module into the
+main syntax module of your definition in some cases, whereas you generally do
+not want to do this with the version of the module that includes all the
+functions over the Bool sort. For example, if you were defining the semantics
+of C++, you might import BOOL-SYNTAX into the syntax module of your
+definition, because true and false are part of the grammar of C++, but
+you would only import the BOOL module into the main semantics module, because
+C++ defines its own syntax for and, or, and not that is different from the
+syntax defined in the BOOL module.

+

Here, for example, is how we might redefine our Boolean expression calculator
+to use the Bool sort while maintaining an idiomatic structure of modules
+and imports, for the first time including the rules to calculate the values of
+expressions themselves (lesson-06-c.k):

+
module LESSON-06-C-SYNTAX
+  imports BOOL-SYNTAX
+
+  syntax Bool ::= "(" Bool ")" [bracket]
+                > "!" Bool [function]
+                > left:
+                  Bool "&&" Bool [function]
+                | Bool "^" Bool [function]
+                | Bool "||" Bool [function]
+endmodule
+
+module LESSON-06-C
+  imports LESSON-06-C-SYNTAX
+  imports BOOL
+
+  rule ! B => notBool B
+  rule A && B => A andBool B
+  rule A ^ B => A xorBool B
+  rule A || B => A orBool B
+endmodule
+

Note the encapsulation of syntax: the LESSON-06-C-SYNTAX module contains
+exactly the syntax of our Boolean expressions, and no more, whereas any other
+syntax needed to implement those functions is in the LESSON-06-C module
+instead.

+

Exercise

+ +

Add an "implies" function to the above Boolean expression calculator, using the
+-> symbol to represent implication. You can look up K's builtin "implies"
+function in the BOOL module in domains.md.

+

Integers in K

+ +

Unlike most programming languages, where the most basic integer type is a
+fixed-precision integer type, the most commonly used integer sort in K is
+the Int sort, which represents the mathematical integers, ie,
+arbitrary-precision integers.

+

K provides three main modules for import when using the Int sort. The first,
+containing all the syntax of integers as well as all of the functions over
+integers, is the INT module. The second, which provides just the syntax
+of integer literals themselves, is the INT-SYNTAX module. However, unlike
+most builtin sorts in K, K also provides a third module for the Int sort:
+the UNSIGNED-INT-SYNTAX module. This module provides only the syntax of
+non-negative integers, i.e., natural numbers. The reasons for this involve
+lexical ambiguity. Generally speaking, in most programming languages, -1 is
+not a literal, but instead a literal to which the unary negation operator is
+applied. K thus provides this module to ease in specifying the syntax of such
+languages.

+

For detailed information about the functions available over the Int sort,
+refer to domains.md. Note again how we append Int to the end of most of the
+integer operations to ensure they do not collide with the syntax of other
+programming languages.

+

Exercises

+ +
    +
  1. +

    Extend your solution from Lesson 1.4, Exercise 2 to implement the rules
    +that define the behavior of addition, subtraction, multiplication, and
    +division. Do not worry about the case when the user tries to divide by zero
    +at this time. Use /Int to implement division. Test your new calculator
    +implementation by executing the arithmetic expressions you wrote as part of
    +Lesson 1.3, Exercise 2. Check to make sure each computes the value you expected.

    +
  2. +
  3. +

    Combine the Boolean expression calculator from this lesson with your
    +solution to Exercise 1, and then extend the combined calculator with the <,
    +<=, >, >=, ==, and != expressions. Write some Boolean expressions
    +that combine integer and Boolean operations, and test to ensure that these
    +expressions return the expected truth value.

    +
  4. +
  5. +

    Compute the following expressions using your solution from Exercise 2:
    +7 / 3, 7 / -3, -7 / 3, -7 / -3. Then replace the /Int function in
    +your definition with divInt instead, and observe how the value of the above
    +expressions changes. Why does this occur?

    +
  6. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.7: Side Conditions and Rule Priority.

+

Lesson 1.7: Side Conditions and Rule Priority

+ +

The purpose of this lesson is to explain how to write conditional rules in K,
+and to explain how to control the order in which rules are tried.

+

Side Conditions

+ +

So far, all of the rules we have discussed have been unconditional rules.
+If the left-hand side of the rule matches the arguments to the function, the
+rule applies. However, there is another type of rule, a conditional rule.
+A conditional rule consists of a rule body containing the patterns to
+match, and a side condition representing a Boolean expression that must
+evaluate to true in order for the rule to apply.

+

Side conditions in K are introduced via the requires keyword immediately
+following the rule body. For example, here is a rule with a side condition
+(lesson-07-a.k):

+
module LESSON-07-A
+  imports BOOL
+  imports INT
+
+  syntax Grade ::= "letter-A"
+                 | "letter-B"
+                 | "letter-C"
+                 | "letter-D"
+                 | "letter-F"
+                 | gradeFromPercentile(Int) [function]
+
+  rule gradeFromPercentile(I) => letter-A requires I >=Int 90
+endmodule
+

In this case, the gradeFromPercentile function takes a single integer
+argument. The function evaluates to letter-A if the argument passed is
+greater than 90. Note that the side condition is allowed to refer to variables
+that appear on the left-hand side of the rule. In the same manner as variables
+appearing on the right-hand side, variables that appear in the side condition
+evaluate to the value that was matched on the left-hand side. Then the
+functions in the side condition are evaluated, which returns a term of sort
+Bool. If the term is equal to true, then the rule applies. Bear in mind
+that the side condition is only evaluated at all if the patterns on the
+left-hand side of the rule match the term being evaluated.

+

Exercise

+ +

Write a rule that evaluates gradeFromPercentile to letter-B if the argument
+to the function is in the range [80,90). Test that the function correctly
+evaluates various numbers between 80 and 100.

+

owise Rules

+ +

So far, all the rules we have introduced have had the same priority. What
+this means is that K does not necessarily enforce an order in which the rules
+are tried. We have only discussed functions so far in K, so it is not
+immediately clear why this choice was made, given that a function is not
+considered well-defined if multiple rules for evaluating it are capable of
+evaluating the same arguments to different results. However, in future lessons
+we will discuss other types of rules in K, some of which can be
+non-deterministic. What this means is that if more than one rule is capable
+of matching, then K will explore both possible rules in parallel, and consider
+each of their respective results when executing your program. Don't worry too
+much about this right now, but just understand that because of the potential
+later for nondeterminism, we don't enforce a total ordering on the order in
+which rules are attempted to be applied.

+

However, sometimes this is not practical; It can be very convenient to express
+that a particular rule applies if no other rules for that function are
+applicable. This can be expressed by adding the owise attribute to a rule.
+What this means, in practice, is that this rule has lower priority than other
+rules, and will only be tried to be applied after all the other,
+higher-priority rules have been tried and they have failed.

+

For example, in the above exercise, we had to add a side condition containing
+two Boolean comparisons to the rule we wrote to handle letter-B grades.
+However, in practice this meant that we compare the percentile to 90 twice. We
+can more efficiently and more idiomatically write the letter-B case for the
+gradeFromPercentile rule using the owise attribute (lesson-07-b.k):

+
module LESSON-07-B
+  imports BOOL
+  imports INT
+
+  syntax Grade ::= "letter-A"
+                 | "letter-B"
+                 | "letter-C"
+                 | "letter-D"
+                 | "letter-F"
+                 | gradeFromPercentile(Int) [function]
+
+  rule gradeFromPercentile(I) => letter-A requires I >=Int 90
+  rule gradeFromPercentile(I) => letter-B requires I >=Int 80 [owise]
+endmodule
+

This rule is saying, "if all the other rules do not apply, then the grade is a
+B if the percentile is greater than or equal to 80." Note here that we use both
+a side condition and an owise attribute on the same rule. This is not
+required (as we will see later), but it is allowed. What this means is that the
+side condition is only tried if the other rules did not apply and the
+left-hand side of the rule matched. You can even use more complex matching on
+the left-hand side than simply a variable. More generally, you can also have
+multiple higher-priority rules, or multiple owise rules. What this means in
+practice is that all of the non-owise rules are tried first, in any order,
+followed by all the owise rules, in any order.

+

Exercise

+ +

The grades D and F correspond to the percentile ranges [60, 70) and [0, 60)
+respectively. Write another implementation of gradeFromPercentile which
+handles only these cases, and uses the owise attribute to avoid redundant
+Boolean comparisons. Test that various percentiles in the range [0, 70) are
+evaluated correctly.

+

Rule Priority

+ +

As it happens, the owise attribute is a specific case of a more general
+concept we call rule priority. In essence, each rule is assigned an integer
+priority. Rules are tried in increasing order of priority, starting with a
+rule with priority zero, and trying each increasing numerical value
+successively.

+

By default, a rule is assigned a priority of 50. If the rule has the owise
+attribute, it is instead given the priority 200. You can see why this will
+cause owise rules to be tried after regular rules.

+

However, it is also possible to directly assign a numerical priority to a rule
+via the priority attribute. For example, here is an alternative way
+we could express the same two rules in the gradeFromPercentile function
+(lesson-07-c.k):

+
module LESSON-07-C
+  imports BOOL
+  imports INT
+
+  syntax Grade ::= "letter-A"
+                 | "letter-B"
+                 | "letter-C"
+                 | "letter-D"
+                 | "letter-F"
+                 | gradeFromPercentile(Int) [function]
+
+  rule gradeFromPercentile(I) => letter-A requires I >=Int 90 [priority(50)]
+  rule gradeFromPercentile(I) => letter-B requires I >=Int 80 [priority(200)]
+endmodule
+

We can, of course, assign a priority equal to any non-negative integer. For
+example, here is a more complex example that handles the remaining grades
+(lesson-07-d.k):

+
module LESSON-07-D
+  imports BOOL
+  imports INT
+
+  syntax Grade ::= "letter-A"
+                 | "letter-B"
+                 | "letter-C"
+                 | "letter-D"
+                 | "letter-F"
+                 | gradeFromPercentile(Int) [function]
+
+  rule gradeFromPercentile(I) => letter-A requires I >=Int 90 [priority(50)]
+  rule gradeFromPercentile(I) => letter-B requires I >=Int 80 [priority(51)]
+  rule gradeFromPercentile(I) => letter-C requires I >=Int 70 [priority(52)]
+  rule gradeFromPercentile(I) => letter-D requires I >=Int 60 [priority(53)]
+  rule gradeFromPercentile(_) => letter-F                     [priority(54)]
+endmodule
+

Note that we have introduced a new piece of syntax here: _. This is actually
+just a variable. However, as a special case, when a variable is named _, it
+does not bind a value that can be used on the right-hand side of the rule, or
+in a side condition. Effectively, _ is a placeholder variable that means "I
+don't care about this term."

+

In this example, we have explicitly expressed the order in which the rules of
+this function are tried. Since rules are tried in increasing numerical
+priority, we first try the rule with priority 50, then 51, then 52, 53, and
+finally 54.

+

As a final note, remember that if you assign a rule a priority higher than 200,
+it will be tried after a rule with the owise attribute, and if you assign
+a rule a priority less than 50, it will be tried before a rule with no
+explicit priority.

+

Exercises

+ +
    +
  1. +

    Write a function isEven that returns whether an integer is an even number.
    +Use two rules and one side condition. The right-hand side of the rules should
    +be Boolean literals. Refer back to
    +domains.md for the relevant
    +integer operations.

    +
  2. +
  3. +

    Modify the calculator application from Lesson 1.6, Exercise 2, so that division
    +by zero will no longer make krun crash with a "Divison by zero" exception.
    +Instead, the / function should not match any of its rules if the denominator
    +is zero.

    +
  4. +
  5. +

    Write your own implementation of ==, <, <=, >, >= for integers and modify your solution from Exercise 2 to use it.
    +You can use any arithmetic operations in the INT module, but do not use any built-in boolean functions for comparing integers.

    +

    Hint: Use pattern matching and recursive definitions with rule priorities.

    +
  6. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.8: Literate Programming with Markdown.

+

Lesson 1.8: Literate Programming with Markdown

+ +

The purpose of this lesson is to teach a paradigm for performing literate
+programming in K, and explain how this can be used to create K definitions
+that are also documentation.

+

Markdown and K

+ +

The K tutorial so far has been written in
+Markdown. Markdown,
+for those not already familiar, is a lightweight plain-text format for styling
+text. From this point onward, we assume you are familiar with Markdown and how
+to write Markdown code. You can refer to the above link for a tutorial if you
+are not already familiar.

+

What you may not necessarily realize, however, is that the K tutorial is also
+a sequence of K definitions written in the manner of
+Literate Programming.
+For detailed information about Literate Programming, you can read the linked
+Wikipedia article, but the short summary is that literate programming is a way
+of intertwining documentation and code together in a manner that allows
+executable code to also be, simultaneously, a documented description of that
+code.

+

K is provided with built-in support for literate programming using Markdown.
+By default, if you pass a file with the .md file extension to kompile, it
+will look for any code blocks containing k code in that file, extract out
+that K code into pure K, and then compile it as if it were a .k file.

+

A K code block begins with a line of text containing the keyword ```k,
+and ends when it encounters another ``` keyword.

+

For example, if you view the markdown source of this document, this is a K
+code block:

+
module LESSON-08
+  imports INT
+

Only the code inside K code blocks will actually be sent to the compiler. The
+rest, while it may appear in the document when rendered by a markdown viewer,
+is essentially a form of code comment.

+

When you have multiple K code blocks in a document, K will append each one
+together into a single file before passing it off to the outer parser.

+

For example, the following code block contains sentences that are part of the
+LESSON-08 module that we declared the beginning of above:

+
  syntax Int ::= Int "+" Int [function]
+  rule I1 + I2 => I1 +Int I2
+

Exercise

+ +

Compile this file with kompile README.md --main-module LESSON-08. Confirm
+that you can use the resulting compiled definition to evaluate the +
+function.

+

Markdown Selectors

+ +

On occasion, you may want to generate multiple K definitions from a single
+Markdown file. You may also wish to include a block of syntax-highlighted K
+code that nonetheless does not appear as part of your K definition. It is
+possible to accomplish this by means of the built-in support for syntax
+highlighting in Markdown. Markdown allows a code block that was begun with
+``` to be immediately followed by a string which is used to signify what
+programming language the following code is written in. However, this feature
+actually allows arbitrary text to appear describing that code block. Markdown
+parsers are able to parse this text and render the code block differently
+depending on what text appears after the backticks.

+

In K, you can use this functionality to specify one or more
+Markdown selectors which are used to describe the code block. A Markdown
+selector consists of a sequence of characters containing letters, numbers, and
+underscores. A code block can be designated with a single selector by appending
+the selector immediately following the backticks that open the code block.

+

For example, here is a code block with the foo selector:

+
foo bar
+

Note that this is not K code. By convention, K code should have the k
+selector on it. You can express multiple selectors on a code block by putting
+them between curly braces and prepending each with the . character. For
+example, here is a code block with the foo and k selectors:

+
  syntax Int ::= foo(Int) [function]
+  rule foo(0) => 0
+

Because this code block contains the k Markdown selector, by default it is
+included as part of the K definition being compiled.

+

Exercise

+ +

Confirm this fact by using krun to evaluate foo(0).

+

Markdown Selector Expressions

+ +

By default, as previously stated, K includes in the definition any code block
+with the k selector. However, this is merely a specific instance of a general
+principle, namely, that K allows you to control which selectors get included
+in your K definition. This is done by means of the --md-selector flag to
+kompile. This flag accepts a Markdown selector expression, which you
+can essentially think of as a kind of Boolean algebra over Markdown selectors.
+Each selector becomes an atom, and you can combine these atoms via the &,
+|, !, and () operators.

+

Here is a grammar, written in K, of the language of Markdown selector
+expressions:

+
  syntax Selector ::= r"[0-9a-zA-Z_]+" [token]
+  syntax SelectorExp ::= Selector
+                       | "(" SelectorExp ")" [bracket]
+                       > right:
+                         "!" SelectorExp
+                       > right:
+                         SelectorExp "&" SelectorExp
+                       > right:
+                         SelectorExp "|" SelectorExp
+

Here is a selector expression that selects all the K code blocks in this
+definition except the one immediately above:

+
k & (! selector)
+

Addendum

+ +

This code block exists in order to make the above lesson a syntactically valid
+K definition. Consider why it is necessary.

+
endmodule
+

Exercises

+ +
    +
  1. +

    Compile this lesson with the selector expression k & (! foo) and confirm
    +that you get a parser error if you try to evaluate the foo function with the
    +resulting definition.

    +
  2. +
  3. +

    Compile Lesson 1.3
    +as a K definition. Identify why it fails to compile. Then pass an appropriate
    +--md-selector to the compiler in order to make it compile.

    +
  4. +
  5. +

    Modify your calculator application from Lesson 1.7, Exercise 2, to be written
    +in a literate style. Consider what text might be appropriate to turn the
    +resulting markdown file into documentation for your calculator.

    +
  6. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.9: Unparsing and the format and color attributes.

+

Lesson 1.9: Unparsing and the format and color attributes

+ +

The purpose of this lesson is to teach the user about how terms are
+pretty-printed in K, and how the user can make adjustments to the default
+settings for how to print specific terms.

+

Parsing, Execution, and Unparsing

+ +

When you use krun to interpret a program, the tool passes through three major
+phases. In the first, parsing, the program itself is parsed using either kast
+or an ahead-of-time parser generated via Bison, and the resulting AST becomes
+the input to the interpreter. In the second phase, execution, K evaluates
+functions and (as we will discuss in depth later) performs rewrite steps to
+iteratively transform the program state. The third and final phase is called
+unparsing, because it consists of taking the final state of the application
+after the program has been interpreted, and converting it from an AST back into
+text that (in theory, anyway) could be parsed back into the same AST that was
+the output of the execution phase.

+

In practice, parsing is not always precisely reversible. It turns out
+(although we are not going to cover exactly why this is here), that
+constructing a sound algorithm that takes a grammar and an AST and emits text
+that could be parsed via that grammar to the original AST is an
+NP-hard problem. As a result, in the interests of avoiding exponential time
+algorithms when users rarely care about unparsing being completely sound, we
+take certain shortcuts that provide a linear-time algorithm that approximates
+a sound solution to the problem while sacrificing the notion that the result
+can be parsed into the exact original term in all cases.

+

This is a lot of theoretical explanation, but at root, the unparsing process
+is fairly simple: it takes a K term that is the output of execution and pretty
+prints it according to the syntax defined by the user in their K definition.
+This is useful because the original AST is not terribly user-readable, and it
+is difficult to visualize the entire term or decipher information about the
+final state of the program at a quick glance. Of course, in rare cases, the
+pretty-printed configuration loses information of relevance, which is why K
+allows you to obtain the original AST on request.

+

As an example of all of this, consider the following K definition
+(lesson-09-a.k):

+
module LESSON-09-A
+  imports BOOL
+
+  syntax Exp ::= "(" Exp ")" [bracket]
+               | Bool
+               > "!" Exp
+               > left:
+                 Exp "&&" Exp
+               | Exp "^" Exp
+               | Exp "||" Exp
+
+  syntax Exp ::= id(Exp) [function]
+  rule id(E) => E
+endmodule
+

This is similar to the grammar we defined in LESSON-06-C, with the difference
+that the Boolean expressions are now constructors of sort Exp and we define a
+trivial function over expressions that returns its argument unchanged.

+

We can now parse a simple program in this definition and use it to unparse some
+Boolean expressions. For example (exp.bool):

+
id(true&&false&&!true^(false||true))
+

Here is a program that is not particularly legible at first glance, because all
+extraneous whitespace has been removed. However, if we run krun exp.bool, we
+see that the result of the unparser will pretty-print this expression rather
+nicely:

+
<k>
+  true && false && ! true ^ ( false || true ) ~> .
+</k>
+

Notably, not only does K insert whitespace where appropriate, it is also smart
+enough to insert parentheses where necessary in order to ensure the correct
+parse. For example, without those parentheses, the expression above would parse
+equivalent to the following one:

+
(((true && false) && ! true) ^ false) || true
+

Indeed, you can confirm this by passing that exact expression to the id
+function and evaluating it, then looking at the result of the unparser:

+
<k>
+  true && false && ! true ^ false || true ~> .
+</k>
+

Here, because the meaning of the AST is the same both with and without
+parentheses, K does not insert any parentheses when unparsing.

+

Exercise

+ +

Modify the grammar of LESSON-09-A above so that the binary operators are
+right associative. Try unparsing exp.bool again, and note how the result is
+different. Explain the reason for the difference.

+

Custom unparsing of terms

+ +

You may have noticed that right now, the unparsing of terms is not terribly
+imaginative. All it is doing is taking each child of the term, inserting it
+into the non-terminal positions of the production, then printing the production
+with a space between each terminal or non-terminal. It is easy to see why this
+might not be desirable in some cases. Consider the following K definition
+(lesson-09-b.k):

+
module LESSON-09-B
+  imports BOOL
+
+  syntax Stmt ::= "{" Stmt "}" | "{" "}"
+                > right:
+                  Stmt Stmt
+                | "if" "(" Bool ")" Stmt
+                | "if" "(" Bool ")" Stmt "else" Stmt [avoid]
+endmodule
+

This is a statement grammar, simplified to the point of meaninglessness, but
+still useful as an object lesson in unparsing. Consider the following program
+in this grammar (if.stmt):

+
if (true) {
+  if (true) {}
+  if (false) {}
+  if (true) {
+    if (false) {} else {}
+  } else {
+    if (false) {}
+  }
+}
+

This is how that term would be unparsed if it appeared in the output of krun:

+
if ( true ) { if ( true ) { } if ( false ) { } if ( true ) { if ( false ) { } else { } } else { if ( false ) { } } }
+

This is clearly much less legible than we started with! What are we to do?
+Well, K provides an attribute, format, that can be applied to any production,
+which controls how that production gets unparsed. You've seen how it gets
+unparsed by default, but via this attribute, the developer has complete control
+over how the term is printed. Of course, the user can trivially create ways to
+print terms that would not parse back into the same term. Sometimes this is
+even desirable. But in most cases, what you are interested in is controlling
+the line breaking, indentation, and spacing of the production.

+

Here is an example of how you might choose to apply the format attribute
+to improve how the above term is unparsed (lesson-09-c.k):

+
module LESSON-09-C
+  imports BOOL
+
+  syntax Stmt ::= "{" Stmt "}" [format(%1%i%n%2%d%n%3)] | "{" "}" [format(%1%2)]
+                > right:
+                  Stmt Stmt [format(%1%n%2)]
+                | "if" "(" Bool ")" Stmt [format(%1 %2%3%4 %5)]
+                | "if" "(" Bool ")" Stmt "else" Stmt [avoid, format(%1 %2%3%4 %5 %6 %7)]
+endmodule
+

If we compile this new definition and unparse the same term, this is the
+result we get:

+
if (true) {
+  if (true) {}
+  if (false) {}
+  if (true) {
+    if (false) {} else {}
+  } else {
+    if (false) {}
+  }
+}
+

This is the exact same text we started with! By adding the format attributes,
+we were able to indent the body of code blocks, adjust the spacing of if
+statements, and put each statement on a new line.

+

How exactly was this achieved? Well, each time the unparser reaches a term,
+it looks at the format attribute of that term. That format attribute is a
+mix of characters and format codes. Format codes begin with the %
+character. Each character in the format attribute other than a format code is
+appended verbatim to the output, and each format code is handled according to
+its meaning, transformed (possibly recursively) into a string of text, and
+spliced into the output at the position the format code appears in the format
+string.

+

Provided for reference is a table with a complete list of all valid format
+codes, followed by their meaning:

+ + + + + + + + + +
Format Code Meaning
n Insert '\n' followed by the current indentation + level
i Increase the current indentation level by 1
d Decrease the current indentation level by 1
c Move to the next color in the list of colors for + this production (see next section)
r Reset color to the default foreground color for + the terminal (see next section)
an integer Print a terminal or non-terminal from the + production. The integer is treated as a 1-based + index into the terminals and non-terminals of + the production. +
+
If the offset refers to a terminal, move to the + next color in the list of colors for this + production, print the value of that terminal, + then reset the color to the default foreground + color for the terminal. +
+
If the offset refers to a regular expression + terminal, it is an error. +
+
If the offset refers to a non-terminal, unparse + the corresponding child of the current term + (starting with the current indentation level) + and print the resulting text, then set the + current color and indentation level to the color + and indentation level following unparsing that + term.
other char Print that character verbatim
+

Exercise

+ +

Change the format attributes for LESSON-09-C so that if.stmt will unparse
+as follows:

+
if (true)
+{
+  if (true)
+  {
+  }
+  if (false)
+  {
+  }
+  if (true)
+  {
+    if (false)
+    {
+    }
+    else
+    {
+    }
+  }
+  else
+  {
+    if (false)
+    {
+    }
+  }
+}
+

Output coloring

+ +

When the output of unparsing is displayed on a terminal supporting colors, K
+is capable of coloring the output, similar to what is possible with a syntax
+highlighter. This is achieved via the color and colors attributes.

+

Essentially, both the color and colors attributes are used to construct a
+list of colors associated with each production, and then the format attribute
+is used to control how those colors are used to unparse the term. At its most
+basic level, you can set the color attribute to color all the terminals in
+the production a certain color, or you can use the colors attribute to
+specify a comma-separated list of colors for each terminal in the production.
+At a more advanced level, the %c and %r format codes control how the
+formatter interacts with the list of colors specified by the colors
+attribute. You can essentially think of the color attribute as a way of
+specifying that you want all the colors in the list to be the same color.

+

Note that the %c and %r format codes are relatively primitive in nature.
+The color and colors attributes merely maintain a list of colors, whereas
+the %c and %r format codes merely control how to advance through that list
+and how individual text is colored.

+

It is an error if the colors attribute does not provide all the colors needed
+by the terminals and escape codes in the production. %r does not change the
+position in the list of colors at all, so the next %c will advance to the
+following color.

+

As a complete example, here is a variant of LESSON-09-A which colors the
+various boolean operators:

+
module LESSON-09-D
+  imports BOOL
+
+  syntax Exp ::= "(" Exp ")" [bracket]
+               | Bool
+               > "!" Exp [color(yellow)]
+               > left:
+                 Exp "&&" Exp [color(red)]
+               | Exp "^" Exp [color(blue)]
+               | Exp "||" Exp [color(green)]
+
+  syntax Exp ::= id(Exp) [function]
+  rule id(E) => E
+endmodule
+

For a complete list of allowed colors, see
+here.

+

Exercises

+ +
    +
  1. +

    Use the color attribute on LESSON-09-C to color the keywords true and
    +false one color, the keywords if and else another color, and the operators
    +(, ), {, and } a third color.

    +
  2. +
  3. +

    Use the format, color, and colors attributes to tell the unparser to
    +style the expression grammar from Lesson 1.8, Exercise 3 according to your own
    +personal preferences for syntax highlighting and code formatting. You can
    +view the result of the unparser on a function term without evaluating that
    +function by means of the command kparse <file> | kore-print -.

    +
  4. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.10: Strings.

+

Lesson 1.10: Strings

+ +

The purpose of this lesson is to explain how to use the String sort in K to
+represent sequences of characters, and explain where to find additional
+information about builtin functions over strings.

+

The String Sort

+ +

In addition to the Int and Bool sorts covered in
+Lesson 1.6, K provides, among others, the
+String sort to represent sequences of characters. You can import this
+functionality via the STRING-SYNTAX module, which contains the syntax of
+string literals in K, and the STRING module, which contains all the functions
+that operate over the String type.

+

Strings in K are double-quoted. The following list of escape sequences is
+supported:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Escape SequenceMeaning
\"The literal character "
\\The literal character \
\nThe newline character (ASCII code 0x0a)
\rThe carriage return character (ASCII code 0x0d)
\tThe tab character (ASCII code 0x09)
\fThe form feed character (ASCII code 0x0c)
\x00\x followed by 2 hexadecimal digits indicates a code point between 0x00 and 0xFF
\u0000\u followed by 4 hexadecimal digits indicates a code point between 0x0000 and 0xFFFF
\U00000000\U followed by 8 hexadecimal digits indicates a code point between 0x000000 and 0x10FFFF
+

Please note that as of the current moment, K's unicode support is not fully
+complete, so you may run into errors using code points greater than 0xff.

+

As an example, you can construct a string literal containing the following
+block of text:

+
This is an example block of text.
+Here is a quotation: "Hello world."
+	This line is indented.
+ÁÉÍÓÚ
+

Like so:

+
"This is an example block of text.\nHere is a quotation: \"Hello world.\"\n\tThis line is indented.\n\xc1\xc9\xcd\xd3\xda\n"
+

Basic String Functions

+ +

The full list of functions provided for the String sort can be found in
+domains.md, but here we
+describe a few of the more basic ones.

+

String concatenation

+ +

The concatenation operator for strings is +String. For example, consider
+the following K rule that constructs a string from component parts
+(lesson-10.k):

+
module LESSON-10
+  imports STRING
+
+  syntax String ::= msg(String) [function]
+  rule msg(S) => "The string you provided: " +String S +String "\nHave a nice day!"
+endmodule
+

Note that this operator is O(N), so repeated concatenations are inefficient.
+For information about efficient string concatenation, refer to
+Lesson 2.14.

+

String length

+ +

The function to return the length of a string is lengthString. For example,
+lengthString("foo") will return 3, and lengthString("") will return 0.
+The return value is the length of the string in code points.

+

Substring computation

+ +

The function to compute the substring of a string is substrString. It
+takes two string indices, starting from 0, and returns the substring within the
+range [start..end). It is only defined if end >= start, start >= 0, and
+end <= length of string. Here, for example, we return the first 5 characters
+of a string:

+
substrString(S, 0, 5)
+

Here we return all but the first 3 characters:

+
substrString(S, 3, lengthString(S))
+

Exercises

+ +
    +
  1. Write a function that takes a paragraph of text (i.e., a sequence of
    +sentences, each ending in a period), and constructs a new (nonsense) sentence
    +composed of the first word of each sentence, followed by a period. Do not
    +worry about capitalization or periods within the sentence which do not end the
    +sentence (e.g. "Dr."). You can assume that all whitespace within the paragraph
    +are spaces. For more information about the functions over strings required to
    +implement such a function, refer to domains.md.
  2. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.11: Casting Terms.

+

Lesson 1.11: Casting Terms

+ +

The purpose of this lesson is to explain how to use cast expressions in
+order to disambiguate terms using sort information. We also explain how the
+variable sort inference algorithm works in K, and how to change the default
+behavior by casting variables to a particular sort.

+

Casting in K

+ +

Sometimes the grammar you write for your rules in K can be a little bit
+ambiguous on purpose. While grammars for programming languages may be
+unambiguous when considered in their entirety, K allows you to write rules
+involving arbitrary fragments of that grammar, and those fragments can
+sometimes be ambiguous by themselves, or similar enough to other fragments
+of the grammar to trigger ambiguity. As a result, in addition to the tools
+covered in Lesson 1.4, K provides one
+additional powerful tool for disambiguation: cast expressions.

+

K provides three main types of casts: the semantic cast, the strict cast, and
+the projection cast. We will cover each of them, and their similarities and
+differences, in turn.

+

Semantic casts

+ +

The most basic, and most common, type of cast in K is called the
+semantic cast. For every sort S declared in a module, K provides the
+following (implicit) production for use in sentences:

+
  syntax S ::= S ":S"
+

Note that S simply represents the name of the sort. For example, if we
+defined a sort Exp, the actual production for that sort would be:

+
  syntax Exp ::= Exp ":Exp"
+

At runtime, this expression will not actually exist; it is merely an annotation
+to the compiler describing the sort of the term inside the cast. It is telling
+the compiler that the term inside the cast must be of sort Exp. For example,
+if we had the following grammar:

+
module LESSON-11-A
+  imports INT
+
+  syntax Exp ::= Int | Exp "+" Exp
+  syntax Stmt ::= "if" "(" Exp ")" Stmt | "{" "}"
+endmodule
+

Then we would be able to write 1:Exp, or (1 + 2):Exp, but not {}:Exp.

+

You can also restrict the sort that a variable in a rule will match by casting
+it. For example, consider the following additional module:

+
module LESSON-11-B
+  imports LESSON-11-A
+  imports BOOL
+
+  syntax Term ::= Exp | Stmt
+  syntax Bool ::= isExpression(Term) [function]
+
+  rule isExpression(_E:Exp) => true
+  rule isExpression(_) => false [owise]
+endmodule
+

Here we have defined a very simple function that decides whether a term is
+an expression or a statement. It does this by casting the variable inside the
+isExpression rule to sort Exp. As a result, that variable will only match terms
+of sort Exp. Thus, isExpression(1) will return true, as will isExpression(1 + 2), but
+isExpression({}) will return false.

+

Exercise

+ +

Verify this fact for yourself by running isExpression on the above examples. Then
+write an isStatement function, and test that it works as expected.

+

Strict casts

+ +

On occasion, a semantic cast is not strict enough. It might be that you want
+to, for disambiguation purposes, say exactly what sort a term is. For
+example, consider the following definition:

+
module LESSON-11-C
+  imports INT
+
+  syntax Exp ::= Int | Exp "+" Exp [group(exp)]
+  syntax Exp2 ::= Exp | Exp2 "+" Exp2 [group(exp2)]
+endmodule
+

This grammar is a little ambiguous and contrived, but it serves to demonstrate
+how a semantic cast might be insufficient to disambiguate a term. If we were
+to write the term (I1:Int + I2:Int):Exp2, the term would be ambiguous,
+because the cast is not sufficiently strict to determine whether you mean
+to derive the "+" production in the group exp or the one in the group exp2.

+

In this situation, there is a solution: the strict cast. For every sort
+S in your grammar, K also defines the following production:

+
  syntax S ::= S "::S"
+

This may at first glance seem the same as the previous cast. And indeed,
+from the perspective of the grammar and from the perspective of rewriting,
+they are in fact identical. However, the second variant has a unique meaning
+in the type system of K: namely, the term inside the cast cannot be a
+subsort, i.e., a term of another sort S2 such that the production
+syntax S ::= S2 exists.

+

As a result, if we were to write in the above grammar the term
+(I1:Int + I2:Int)::Exp2, then we would know that the second derivation above
+should be chosen, whereas if we want the first derivation, we could write
+(I1:Int + I2:Int)::Exp.

+

Projection casts

+ +

Thus far we have focused entirely on casts which exist solely to inform the
+compiler about the sort of terms. However, sometimes when dealing with grammars
+containing subsorts, it can be desirable to reason with the subsort production
+itself, which injects one sort into another. Remember from above that such
+a production looks like syntax S ::= S2. This type of production, called a
+subsort production, can be thought of as a type of inheritance involving
+constructors. If we have the above production in our grammar, we say that S2
+is a subsort of S, or that any S2 is also an S. K implicitly maintains a
+symbol at runtime which keeps track of where such subsortings occur; this
+symbol is called an injection.

+

Sometimes, when one sort is a subsort of another, it can be the case that
+a function returns one sort, but you actually want to cast the result of
+calling that function to another sort which is a subsort of the first sort.
+This is similar to what happens with inheritance in an object-oriented
+language, where you might cast a superclass to a subclass if you know for
+sure the object at runtime is in fact an instance of that class.

+

K provides something similar for subsorts: the projection cast.

+

For each pair of sorts S and S2, K provides the following production:

+
  syntax S ::= "{" S2 "}" ":>S"
+

What this means is that you take any term of sort S2 and cast it to sort
+S. If the term of sort S2 consists of an injection containing a term of sort
+S, then this will return that term. Otherwise, an error occurs and rewriting
+fails, returning the projection function which failed to apply. The sort is
+not actually checked at compilation time; rather, it is a runtime check
+inserted into the code that runs when the rule applies.

+

For example, here is a module that makes use of projection casts:

+
module LESSON-11-D
+  imports INT
+  imports BOOL
+
+  syntax Exp ::= Int | Bool | Exp "+" Exp | Exp "&&" Exp
+
+  syntax Exp ::= eval(Exp) [function]
+  rule eval(I:Int) => I
+  rule eval(B:Bool) => B
+  rule eval(E1 + E2) => {eval(E1)}:>Int +Int {eval(E2)}:>Int
+  rule eval(E1 && E2) => {eval(E1)}:>Bool andBool {eval(E2)}:>Bool
+endmodule
+

Here we have defined constructors for a simple expression language over
+Booleans and integers, as well as a function eval that evaluates these
+expressions to a value. Because that value could be an integer or a Boolean,
+we need the casts in the last two rules in order to meet the type signature of
++Int and andBool. Of course, the user can write ill-formed expressions like
+1 && true or false + true, but these will cause errors at runtime, because
+the projection cast will fail.

+

Exercises

+ +
    +
  1. +

    Extend the eval function in LESSON-11-D to include Strings and add a .
    +operator which concatenates them.

    +
  2. +
  3. +

    Modify your solution from Lesson 1.9, Exercise 2 by using an Exp sort to
    +express the integer and Boolean expressions that it supports, in the same style
    +as LESSON-11-D. Then write an eval function that evaluates all terms of
    +sort Exp to either a Bool or an Int.

    +
  4. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.12: Syntactic Lists.

+

Lesson 1.12: Syntactic Lists

+ +

The purpose of this lesson is to explain how K provides support for syntactic
+repetition through the use of the List{} and NeList{} constructs,
+generally called syntactic lists.

+

The List{} construct

+ +

Sometimes, when defining a grammar in K, it is useful to define a syntactic
+construct consisting of an arbitrary-length sequence of items. For example,
+you might wish to define a function call construct, and need to express a way
+of passing arguments to the function. You can in theory simply define these
+productions using ordinary constructors, but it can be tricky to get the syntax
+exactly right in K without a lot of tedious glue code.

+

For this reason, K provides a way of specifying that a non-terminal represents
+a syntactic list (lesson-12-a.k):

+
module LESSON-12-A-SYNTAX
+  imports INT-SYNTAX
+
+  syntax Ints ::= List{Int,","}
+endmodule
+
+module LESSON-12-A
+  imports LESSON-12-A-SYNTAX
+endmodule
+

Note that instead of a sequence of terminals and non-terminals, the right hand
+side of the Ints production contains the symbol List followed by two items
+in curly braces. The first item is the non-terminal which is the element type
+of the list, and the second item is a terminal representing the separator of
+the list. As a special case, lists which are separated only by whitespace can
+be specified with a separator of "".

+

This List{} construct is roughly equivalent to the following definition
+(lesson-12-b.k):

+
module LESSON-12-B-SYNTAX
+  imports INT-SYNTAX
+
+  syntax Ints ::= Int "," Ints | ".Ints"
+endmodule
+
+module LESSON-12-B
+  imports LESSON-12-B-SYNTAX
+endmodule
+

As you can see, the List{} construct represents a cons-list with an element
+at the head and another list at the tail. The empty list is represented by
+a . followed by the sort of the list.

+

However, the List{} construct provides several key syntactic conveniences
+over the above definition. First of all, when writing a list in a rule,
+explicitly writing the terminator is not always required. For example, consider
+the following additional module (lesson-12-c.k):

+
module LESSON-12-C
+  imports LESSON-12-A
+  imports INT
+
+  syntax Int ::= sum(Ints) [function]
+  rule sum(I:Int) => I
+  rule sum(I1:Int, I2:Int, Is:Ints) => sum(I1 +Int I2, Is)
+endmodule
+

Here we see a function that sums together a non-empty list of integers. Note in
+particular the first rule. We do not explicitly mention .Ints, but in fact,
+the rule in question is equivalent to the following rule:

+
  rule sum(I:Int, .Ints) => I
+

The reason for this is that K will automatically insert a list terminator
+anywhere a syntactic list is expected, but an element of that list appears
+instead. This works even with lists of more than one element:

+
  rule sum(I1:Int, I2:Int) => I1 +Int I2
+

This rule is redundant, but here we explicitly match a list of exactly two
+elements, because the .Ints is implicitly added after I2.

+

Parsing Syntactic Lists in Programs

+ +

An additional syntactic convenience takes place when you want to express a
+syntactic list in the input to krun. In this case, K will automatically
+transform the grammar in LESSON-12-B-SYNTAX into the following
+(lesson-12-d.k):

+
module LESSON-12-D
+  imports INT-SYNTAX
+
+  syntax Ints ::= #NonEmptyInts | #IntsTerminator
+  syntax #NonEmptyInts ::= Int "," #NonEmptyInts
+                         | Int #IntsTerminator
+  syntax #IntsTerminator ::= ""
+endmodule
+

This allows you to express the usual comma-separated list of arguments where
+an empty list is represented by the empty string, and you don't have to
+explicitly terminate the list. Because of this, we can write the syntax
+of function calls in C very easily (lesson-12-e.k):

+
module LESSON-12-E
+  syntax Id ::= r"[a-zA-Z_][a-zA-Z0-9_]*" [token]
+  syntax Exp ::= Id | Exp "(" Exps ")"
+  syntax Exps ::= List{Exp,","}
+endmodule
+

Exercise

+ +

Write a function concat which takes a list of String and concatenates them
+all together. Do not worry if the function is O(n^2).
+Test your implementation using the syntactic sugar for lists added by the parser.

+

Then write some function call expressions using identifiers in C and verify with
+kast that the above grammar captures the intended syntax. Make sure to test
+with function calls with zero, one, and two or more arguments.

+

The NeList{} construct

+ +

One limitation of the List{} construct is that it is always possible to
+write a list of zero elements where a List{} is expected. While this is
+desirable in a number of cases, it is sometimes not what the grammar expects.

+

For example, in C, it is not allowable for an enum definition to have zero
+members. In other words, if we were to write the grammar for enumerations like
+so (lesson-12-f.k):

+
module LESSON-12-F
+  syntax Id ::= r"[a-zA-Z_][a-zA-Z0-9_]*" [token]
+  syntax Exp ::= Id
+
+  syntax EnumSpecifier ::= "enum" Id "{" Ids "}"
+  syntax Ids ::= List{Id,","}
+endmodule
+

Then we would be syntactically allowed to write enum X {}, which instead,
+ought to be a syntax error.

+

For this reason, we introduce the additional NeList{} construct. The syntax
+is identical to List{}, except with NeList instead of List before the
+curly braces. When parsing rules, it behaves identically to the List{}
+construct. However, when parsing inputs to krun, the above grammar, if we
+replaced syntax Ids ::= List{Id,","} with syntax Ids ::= NeList{Id,","},
+would become equivalent to the following (lesson-12-g.k):

+
module LESSON-12-G
+  syntax Id ::= r"[a-zA-Z_][a-zA-Z0-9_]*" [token]
+  syntax Exp ::= Id
+
+  syntax EnumSpecifier ::= "enum" Id "{" Ids "}"
+  syntax Ids ::= Id | Id "," Ids
+endmodule
+

In other words, only non-empty lists of Id would be allowed.

+

Exercises

+ +
    +
  1. +

    Modify the sum function in LESSON-12-C so that the Ints sort is an
    +NeList{}. Verify that calling sum() with no arguments is now a syntax
    +error.

    +
  2. +
  3. +

    Write a modified sum function with the List construct that can also sum
    +up an empty list of arguments. In such a case, the sum ought to be 0.

    +
  4. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.13: Basics of K Rewriting.

+

Lesson 1.13: Basics of K Rewriting

+ +

The purpose of this lesson is to explain how rewrite rules that are not the
+definition of a function behave, and how, using these rules, you can construct
+a semantics of programs in a programming language in K.

+

Recap: Function rules in K

+ +

Recall from Lesson 1.2 that we have, thus far,
+introduced two types of productions in K: constructors and functions.
+A function is identified by the function attribute placed on the
+production. As you may recall, when we write a rule with a function on the
+left-hand side of the => operator, we are defining the meaning of that
+function for inputs which match the patterns on the left-hand side of the rule.
+If the argument to the function match the patterns, then the function is
+evaluated to the value constructed by substituting the bindings for the
+variables into the right-hand side of the rule.

+

Top-level rules

+ +

However, function rules are not the only type of rule permissible in K, nor
+even the most frequently used. K also has a concept of a
+top-level rewrite rule. The simplest way to ensure that a rule is treated
+as a top-level rule is for the left-hand side of the rule to mention one or
+more cells. We will cover how cells work and are declared in more detail
+in a later lesson, but for now, what you should know is that when we ran krun
+in our very first example in Lesson 1.2 and got the following output:

+
<k>
+  Yellow ( ) ~> .
+</k>
+

<k> is a cell, known by convention as the K cell. This cell is available
+by default in any definition without needing to be explicitly declared.

+

The K cell contains a single term of sort K. K is a predefined sort in K
+with two constructors, that can be roughly represented by the following
+grammar:

+
  syntax K ::= KItem "~>" K
+             | "."
+

As a syntactic convenience, K allows you to treat ~> like it is an
+associative list (i.e., as if it were defined as syntax K ::= K "~>" K).
+When a definition is compiled, it will automatically transform the rules you
+write so that they treat the K sort as a cons-list. Another syntactic
+convenience is that, for disambiguation purposes, you can write .K anywhere
+you would otherwise write . and the meaning is identical.

+

Now, you may notice that the above grammar mentions the sort KItem. This is
+another built-in sort in K. For every sort S declared in a definition (with
+the exception of K and KItem), K will implicitly insert the following
+production:

+
  syntax KItem ::= S
+

In other words, every sort is a subsort of the sort KItem, and thus a term
+of any sort can be injected as an element of a term of sort K, also called
+a K sequence.

+

By default, when you krun a program, the AST of the program is inserted as
+the sole element of a K sequence into the <k> cell. This explains why we
+saw the output we did in Lesson 1.2.

+

With these preliminaries in mind, we can now explain how top-level rewrite
+rules work in K. Put simply, any rule where there is a cell (such as the K
+cell) at the top on the left-hand side will be a top-level rewrite rule. Once
+the initial program has been inserted into the K cell, the resulting term,
+called the configuration, will be matched against all the top-level
+rewrite rules in the definition. If only one rule matches, the substitution
+generated by the matching will be applied to the right-hand side of the rule
+and the resulting term is rewritten to be the new configuration. Rewriting
+proceeds by iteratively applying rules, also called taking steps, until
+no top-level rewrite rule can be applied. At this point the configuration
+becomes the final configuration and is output by krun.

+

If more than one top-level rule applies, by default, K will pick just one
+of those rules, apply it, and continue rewriting. However, it is
+non-deterministic which rule applies. In theory, it could be any of them.
+By passing the --search flag to krun, you are able to tell krun to
+explore all possible non-deterministic choices, and generate a complete list of
+all possible final configurations reachable by each nondeterminstic choice that
+can be made. Note that the --search flag to krun only works if you pass
+--enable-search to kompile first.

+

Unlike top-level rewrite rules, function rules are not associated with any
+particular set of cells in the configuration (although they can contain cells
+in their function arguments and return value). While top-level rewrite rules
+apply to the entire term being rewritten, function rules apply anywhere a
+function application for that function appears, and are immediately rewritten
+to their return value in that position.

+

Another key distinction between top-level rules and function rules is that
+function symbols, i.e., productions with the function attribute, are
+mathematical functions rather than constructors. While a constructor is
+logically distinct from any other constructor of the same sort, and can be
+matched against unconditionally, a function does not necessaraily have the
+same restriction unless it happens to be an injective function. Thus, two
+function symbols with different arguments may still ultimately produce the
+same value and thus compare equal to one another. Due to this, concrete
+execution (i.e., all K definitions introduced thus far; see Lesson 1.21)
+introduces the restriction that you cannot match on a function symbol on the
+left-hand side of a rule, except as the top symbol on the left-hand side of
+a function rule. This restriction will be later lifted when we introduce the
+Haskell Backend which performs symbolic execution.

+

Exercise

+ +

Pass a program containing no functions to krun. You can use a term of sort
+Exp from LESSON-11-D. Observe the output and try to understand why you get
+the output you do. Then write two rules that rewrite that program to another.
+Run krun --search on that program and observe both results. Then add a third
+rule that rewrites one of those results again. Test that that rule applies as
+well.

+

Using top-level rules to evaluate expressions

+ +

Thus far, we have focused primarily on defining functions over constructors
+in K. However, now that we have a basic understanding of top-level rules,
+it is possible to introduce a rewrite system to our definitions. A rewrite
+system is a collection of top-level rewrite rules which performs an organized
+transformation of a particular program into a result which expresses the
+meaning of that program. For example, we might rewrite an expression in a
+programming language into a value representing the result of evaluating that
+expression.

+

Recall in Lesson 1.11, we wrote a simple grammar of Boolean and integer
+expressions that looked roughly like this (lesson-13-a.k):

+
module LESSON-13-A
+  imports INT
+
+  syntax Exp ::= Int
+               | Bool
+               | Exp "+" Exp
+               | Exp "&&" Exp
+endmodule
+

In that lesson, we defined a function eval which evaluated such expressions
+to either an integer or Boolean.

+

However, it is more idiomatic to evaluate such expressions using top-level
+rewrite rules. Here is how one might do so in K (lesson-13-b.k):

+
module LESSON-13-B-SYNTAX
+  imports UNSIGNED-INT-SYNTAX
+  imports BOOL-SYNTAX
+
+  syntax Val ::= Int | Bool
+  syntax Exp ::= Val
+               > left: Exp "+" Exp
+               > left: Exp "&&" Exp
+endmodule
+
+module LESSON-13-B
+  imports LESSON-13-B-SYNTAX
+  imports INT
+  imports BOOL
+
+  rule <k> I1:Int + I2:Int ~> K:K </k> => <k> I1 +Int I2 ~> K </k>
+  rule <k> B1:Bool && B2:Bool ~> K:K </k> => <k> B1 andBool B2 ~> K </k>
+
+  syntax KItem ::= freezer1(Val) | freezer2(Exp)
+                 | freezer3(Val) | freezer4(Exp)
+
+  rule <k> E1:Val + E2:Exp ~> K:K </k> => <k> E2 ~> freezer1(E1) ~> K </k> [priority(51)]
+  rule <k> E1:Exp + E2:Exp ~> K:K </k> => <k> E1 ~> freezer2(E2) ~> K </k> [priority(52)]
+  rule <k> E1:Val && E2:Exp ~> K:K </k> => <k> E2 ~> freezer3(E1) ~> K </k> [priority(51)]
+  rule <k> E1:Exp && E2:Exp ~> K:K </k> => <k> E1 ~> freezer4(E2) ~> K </k> [priority(52)]
+
+  rule <k> E2:Val ~> freezer1(E1) ~> K:K </k> => <k> E1 + E2 ~> K </k>
+  rule <k> E1:Val ~> freezer2(E2) ~> K:K </k> => <k> E1 + E2 ~> K </k>
+  rule <k> E2:Val ~> freezer3(E1) ~> K:K </k> => <k> E1 && E2 ~> K </k>
+  rule <k> E1:Val ~> freezer4(E2) ~> K:K </k> => <k> E1 && E2 ~> K </k>
+endmodule
+

This is of course rather cumbersome currently, but we will soon introduce
+syntactic convenience which makes writing definitions of this type considerably
+easier. For now, notice that there are roughly 3 types of rules here: the first
+matches a K cell in which the first element of the K sequence is an Exp whose
+arguments are values, and rewrites the first element of the sequence to the
+result of that expression. The second also matches a K cell with an Exp in
+the first element of its K sequence, but it matches when one or both arguments
+of the Exp are not values, and replaces the first element of the K sequence
+with two new elements: one being an argument to evaluate, and the other being
+a special constructor called a freezer. Finally, the third matches a K
+sequence where a Val is first, and a freezer is second, and replaces them
+with a partially evaluated expression.

+

This general pattern is what is known as heating an expression,
+evaluating its arguments, cooling the arguments into the expression
+again, and evaluating the expression itself. By repeatedly performing
+this sequence of actions, we can evaluate an entire AST containing a complex
+expression down into its resulting value.

+

Exercise

+ +

Write an addition expression with integers. Use krun --depth 1 to see the
+result of rewriting after applying a single top-level rule. Gradually increase
+the value of --depth to see successive states. Observe how this combination
+of rules is eventually able to evaluate the entire expression.

+

Simplifying the evaluator: Local rewrites and cell ellipses

+ +

As you saw above, the definition we wrote is rather cumbersome. Over the
+remainder of Lessons 1.13 and 1.14, we will greatly simplify it. The first step
+in doing so is to teach a bit more about the rewrite operator, =>. Thus far,
+all the rules we have written look like rule LHS => RHS. However, this is not
+the only way the rewrite operator can be used. It is actually possible to place
+a constructor or function at the very top of the rule, and place rewrite
+operators inside that term. While a rewrite operator cannot appear nested
+inside another rewrite operator, by doing this, we can express that some parts
+of what we are matching are not changed by the rewrite operator. For
+example, consider the following rule from above:

+
  rule <k> I1:Int + I2:Int ~> K:K </k> => <k> I1 +Int I2 ~> K </k>
+

We can equivalently write it like following:

+
  rule <k> (I1:Int + I2:Int => I1 +Int I2) ~> _:K </k>
+

When you put a rewrite inside a term like this, in essence, you are telling
+the rule to only rewrite part of the left-hand side to the right-hand side.
+In practice, this is implemented by lifting the rewrite operator to the top of
+the rule by means of duplicating the surrounding context.

+

There is a way that the above rule can be simplified further, however. K
+provides a special syntax for each cell containing a term of sort K, indicating
+that we want to match only on some prefix of the K sequence. For example, the
+above rule can be simplified further like so:

+
  rule <k> I1:Int + I2:Int => I1 +Int I2 ...</k>
+

Here we have placed the symbol ... immediately prior to the </k> which ends
+the cell. What this tells the compiler is to take the contents of the cell,
+treat it as the prefix of a K sequence, and insert an anonymous variable of
+sort K at the end. Thus we can think of ... as a way of saying we
+don't care about the part of the K sequence after the beginning, leaving
+it unchanged.

+

Putting all this together, we can rewrite LESSON-13-B like so
+(lesson-13-c.k):

+
module LESSON-13-C-SYNTAX
+  imports UNSIGNED-INT-SYNTAX
+  imports BOOL-SYNTAX
+
+  syntax Val ::= Int | Bool
+  syntax Exp ::= Val
+               > left: Exp "+" Exp
+               > left: Exp "&&" Exp
+endmodule
+
+module LESSON-13-C
+  imports LESSON-13-C-SYNTAX
+  imports INT
+  imports BOOL
+
+  rule <k> I1:Int + I2:Int => I1 +Int I2 ...</k>
+  rule <k> B1:Bool && B2:Bool => B1 andBool B2 ...</k>
+
+  syntax KItem ::= freezer1(Val) | freezer2(Exp)
+                 | freezer3(Val) | freezer4(Exp)
+
+  rule <k> E1:Val + E2:Exp => E2 ~> freezer1(E1) ...</k> [priority(51)]
+  rule <k> E1:Exp + E2:Exp => E1 ~> freezer2(E2) ...</k> [priority(52)]
+  rule <k> E1:Val && E2:Exp => E2 ~> freezer3(E1) ...</k> [priority(51)]
+  rule <k> E1:Exp && E2:Exp => E1 ~> freezer4(E2) ...</k> [priority(52)]
+
+  rule <k> E2:Val ~> freezer1(E1) => E1 + E2 ...</k>
+  rule <k> E1:Val ~> freezer2(E2) => E1 + E2 ...</k>
+  rule <k> E2:Val ~> freezer3(E1) => E1 && E2 ...</k>
+  rule <k> E1:Val ~> freezer4(E2) => E1 && E2 ...</k>
+endmodule
+

This is still rather cumbersome, but it is already greatly simplified. In the
+next lesson, we will see how additional features of K can be used to specify
+heating and cooling rules much more compactly.

+

Exercises

+ +
    +
  1. Modify LESSON-13-C to add rules to evaluate integer subtraction.
  2. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.14: Defining Evaluation Order.

+

Lesson 1.14: Defining Evaluation Order

+ +

The purpose of this lesson is to explain how to use the heat and cool
+attributes, context and context alias sentences, and the strict and
+seqstrict attributes to more compactly express heating and cooling in K,
+and to express more advanced evaluation strategies in K.

+

The heat and cool attributes

+ +

Thus far, we have been using rule priority and casts to express when to heat
+an expression and when to cool it. For example, the rules for heating have
+lower priority, so they do not apply if the term could be evaluated instead,
+and the rules for heating are expressly written only to apply if the argument
+of the expression is a value.

+

However, K has built-in support for deciding when to heat and when to cool.
+This support comes in the form of the rule attributes heat and cool as
+well as the specially named function isKResult.

+

Consider the following definition, which is equivalent to LESSON-13-C
+(lesson-14-a.k):

+
module LESSON-14-A-SYNTAX
+  imports UNSIGNED-INT-SYNTAX
+  imports BOOL-SYNTAX
+
+  syntax Exp ::= Int
+               | Bool
+               > left: Exp "+" Exp
+               > left: Exp "&&" Exp
+endmodule
+
+module LESSON-14-A
+  imports LESSON-14-A-SYNTAX
+  imports INT
+  imports BOOL
+
+  rule <k> I1:Int + I2:Int => I1 +Int I2 ...</k>
+  rule <k> B1:Bool && B2:Bool => B1 andBool B2 ...</k>
+
+  syntax KItem ::= freezer1(Exp) | freezer2(Exp)
+                 | freezer3(Exp) | freezer4(Exp)
+
+  rule <k> E:Exp + HOLE:Exp => HOLE ~> freezer1(E) ...</k>
+    requires isKResult(E) [heat]
+  rule <k> HOLE:Exp + E:Exp => HOLE ~> freezer2(E) ...</k> [heat]
+  rule <k> E:Exp && HOLE:Exp => HOLE ~> freezer3(E) ...</k>
+    requires isKResult(E) [heat]
+  rule <k> HOLE:Exp && E:Exp => HOLE ~> freezer4(E) ...</k> [heat]
+
+  rule <k> HOLE:Exp ~> freezer1(E) => E + HOLE ...</k> [cool]
+  rule <k> HOLE:Exp ~> freezer2(E) => HOLE + E ...</k> [cool]
+  rule <k> HOLE:Exp ~> freezer3(E) => E && HOLE ...</k> [cool]
+  rule <k> HOLE:Exp ~> freezer4(E) => HOLE && E ...</k> [cool]
+
+  syntax Bool ::= isKResult(K) [function, symbol]
+  rule isKResult(_:Int) => true
+  rule isKResult(_:Bool) => true
+  rule isKResult(_) => false [owise]
+endmodule
+

We have introduced three major changes to this definition. First, we have
+removed the Val sort. We replace it instead with a function isKResult.
+The function in question must have the same signature and attributes as seen in
+this example. It ought to return true whenever a term should not be heated
+(because it is a value) and false when it should be heated (because it is not
+a value). We thus also insert isKResult calls in the side condition of two
+of the heating rules, where the Val sort was previously used.

+

Second, we have removed the rule priorities on the heating rules and the use of
+the Val sort on the cooling rules, and replaced them with the heat and
+cool attributes. These attributes instruct the compiler that these rules are
+heating and cooling rules, and thus should implicitly apply only when certain
+terms on the LHS either are or are not a KResult (i.e., isKResult returns
+true versus false).

+

Third, we have renamed some of the variables in the heating and cooling rules
+to the special variable HOLE. Syntactically, HOLE is just a special name
+for a variable, but it is treated specially by the compiler. By naming a
+variable HOLE, we have informed the compiler which term is being heated
+or cooled. The compiler will automatically insert the side condition
+requires isKResult(HOLE) to cooling rules and the side condition
+requires notBool isKResult(HOLE) to heating rules.

+

Exercise

+ +

Modify LESSON-14-A to add rules to evaluate integer subtraction.

+

Simplifying further with Contexts

+ +

The above example is still rather cumbersome to write. We must explicitly write
+both the heating and the cooling rule separately, even though they are
+essentially inverses of one another. It would be nice to instead simply
+indicate which terms should be heated and cooled, and what part of them to
+operate on.

+

To do this, K introduces a new type of sentence, the context. Contexts
+begin with the context keyword instead of the rule keyword, and usually
+do not contain a rewrite operator.

+

Consider the following definition which is equivalent to LESSON-14-A
+(lesson-14-b.k):

+
module LESSON-14-B-SYNTAX
+  imports UNSIGNED-INT-SYNTAX
+  imports BOOL-SYNTAX
+
+  syntax Exp ::= Int
+               | Bool
+               > left: Exp "+" Exp
+               > left: Exp "&&" Exp
+endmodule
+
+module LESSON-14-B
+  imports LESSON-14-B-SYNTAX
+  imports INT
+  imports BOOL
+
+  rule <k> I1:Int + I2:Int => I1 +Int I2 ...</k>
+  rule <k> B1:Bool && B2:Bool => B1 andBool B2 ...</k>
+
+  context <k> E:Exp + HOLE:Exp ...</k>
+    requires isKResult(E)
+  context <k> HOLE:Exp + _:Exp ...</k>
+  context <k> E:Exp && HOLE:Exp ...</k>
+    requires isKResult(E)
+  context <k> HOLE:Exp && _:Exp ...</k>
+
+  syntax Bool ::= isKResult(K) [function, symbol]
+  rule isKResult(_:Int) => true
+  rule isKResult(_:Bool) => true
+  rule isKResult(_) => false [owise]
+endmodule
+

In this example, the heat and cool rules have been removed entirely, as
+have been the productions defining the freezers. Don't worry, they still exist
+under the hood; the compiler is just generating them automatically. For each
+context sentence like above, the compiler generates a #freezer production,
+a heat rule, and a cool rule. The generated form is equivalent to the
+rules we wrote manually in LESSON-14-A. However, we are now starting to
+considerably simplify the definition. Instead of 3 sentences, we just have one.

+

context alias sentences and the strict and seqstrict attributes

+ +

Notice that the contexts we included in LESSON-14-B still seem rather
+similar in form. For each expression we want to evaluate, we are declaring
+one context for each operand of that expression, and they are each rather
+similar to one another. We would like to be able to simplify further by
+simply annotating each expression production with information about how
+it is to be evaluated instead. We can do this with the seqstrict attribute.

+

Consider the following definition, once again equivalent to those above
+(lesson-14-c.k):

+
module LESSON-14-C-SYNTAX
+  imports UNSIGNED-INT-SYNTAX
+  imports BOOL-SYNTAX
+
+  syntax Exp ::= Int
+               | Bool
+               > left: Exp "+" Exp [seqstrict(exp; 1, 2)]
+               > left: Exp "&&" Exp [seqstrict(exp; 1, 2)]
+endmodule
+
+module LESSON-14-C
+  imports LESSON-14-C-SYNTAX
+  imports INT
+  imports BOOL
+
+  rule <k> I1:Int + I2:Int => I1 +Int I2 ...</k>
+  rule <k> B1:Bool && B2:Bool => B1 andBool B2 ...</k>
+
+  context alias [exp]: <k> HERE ...</k>
+
+  syntax Bool ::= isKResult(K) [function, symbol]
+  rule isKResult(_:Int) => true
+  rule isKResult(_:Bool) => true
+  rule isKResult(_) => false [owise]
+endmodule
+

This definition has two important changes from the one above. The first is
+that the individual context sentences have been removed and have been
+replaced with a single context alias sentence. You may notice that this
+sentence begins with an identifier in square brackets followed by a colon. This
+syntax is a way of naming individual sentences in K for reference by the tool
+or by other sentences. The context alias sentence also has a special variable
+HERE.

+

The second is that the productions in LESSON-14-C-SYNTAX have been given a
+seqstrict attribute. The value of this attribute has two parts. The first
+is the name of a context alias sentence. The second is a comma-separated list
+of integers. Each integer represents an index of a non-terminal in the
+production, counting from 1. For each integer present, the compiler implicitly
+generates a new context sentence according to the following rules:

+
    +
  1. The compiler starts by looking for the context alias sentence named. If
    +there is more than one, then one context sentence is created per
    +context alias sentence with that name.
  2. +
  3. For each context created, the variable HERE in the context alias is
    +substituted with an instance of the production the seqstrict attribute is
    +attached to. Each child of that production is a variable. The non-terminal
    +indicated by the integer offset of the seqstrict attribute is given the name
    +HOLE.
  4. +
  5. For each integer offset prior in the list to the one currently being
    +processed, the predicate isKResult(E) is conjuncted together and included
    +as a side condition, where E is the child of the production term with that
    +offset, starting from 1. For example, if the attribute lists 1, 2, then
    +the rule generated for the 2 will include isKResult(E1) where E1 is the
    +first child of the production.
  6. +
+

As you can see if you work through the process, the above code will ultimately
+generate the same contexts present in LESSON-14-B.

+

Finally, note that there are a few minor syntactic conveniences provided by the
+seqstrict attribute. First, in the special case of the context alias sentence
+being <k> HERE ...</k>, you can omit both the context alias sentence
+and the name from the seqstrict attribute.

+

Second, if the numbered list of offsets contains every non-terminal in the
+production, it can be omitted from the attribute value.

+

Thus, we can finally produce the idiomatic K definition for this example
+(lesson-14-d.k):

+
module LESSON-14-D-SYNTAX
+  imports UNSIGNED-INT-SYNTAX
+  imports BOOL-SYNTAX
+
+  syntax Exp ::= Int
+               | Bool
+               > left: Exp "+" Exp [seqstrict]
+               > left: Exp "&&" Exp [seqstrict]
+endmodule
+
+module LESSON-14-D
+  imports LESSON-14-D-SYNTAX
+  imports INT
+  imports BOOL
+
+  rule <k> I1:Int + I2:Int => I1 +Int I2 ...</k>
+  rule <k> B1:Bool && B2:Bool => B1 andBool B2 ...</k>
+
+  syntax Bool ::= isKResult(K) [function, symbol]
+  rule isKResult(_:Int) => true
+  rule isKResult(_:Bool) => true
+  rule isKResult(_) => false [owise]
+endmodule
+

Exercise

+ +

Modify LESSON-14-D to add a production and rule to evaluate integer
+subtraction.

+

Nondeterministic evaluation order with the strict attribute

+ +

Thus far, we have focused entirely on deterministic evaluation order. However,
+not all languages are deterministic in the order they evaluate expressions.
+For example, in C, the expression a() + b() + c() is guaranteed to parse
+to (a() + b()) + c(), but it is not guaranteed that a will be called before
+b before c. In fact, this evaluation order is non-deterministic.

+

We can express non-deterministic evaluation orders with the strict attribute.
+Its behavior is identical to the seqstrict attribute, except that step 3 in
+the above list (with the side condition automatically added) does not take
+place. In other words, if we wrote syntax Exp ::= Exp "+" Exp [strict]
+instead of syntax Exp ::= Exp "+" Exp [seqstrict], it would generate the
+following two contexts instead of the ones found in LESSON-14-B:

+
  context <k> _:Exp + HOLE:Exp ...</k>
+  context <k> HOLE:Exp + _:Exp ...</k>
+

As you can see, these contexts will generate heating rules that can both
+apply to the same term. As a result, the choice of which heating rule
+applies first is non-deterministic, and as we saw in Lesson 1.13, we can
+get all possible behaviors by passing --search to krun.

+

Exercises

+ +
    +
  1. +

    Add integer division to LESSON-14-D. Make division and addition strict
    +instead of seqstrict, and write a rule evaluating integer division with a
    +side condition that the denominator is non-zero. Run krun --search on the
    +program 1 / 0 + 2 / 1 and observe all possible outputs of the program. How
    +many are there total, and why?

    +
  2. +
  3. +

    Rework your solution from Lesson 1.9, Exercise 2 to evaluate expressions from left to right using the seqstrict attribute.

    +
  4. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.15: Configuration Declarations and Cell Nesting.

+

Lesson 1.15: Configuration Declarations and Cell Nesting

+ +

The purpose of this lesson is to explain how to store additional information
+about the state of your interpreter by declaring cells using the
+configuration sentence, as well as how to add additional inputs to your
+definition.

+

Cells and Configuration Declarations

+ +

We have already covered the absolute basics of cells in K by looking at the
+<k> cell. As explained in Lesson 1.13, the
+<k> cell is available without being explicitly declared. It turns out this is
+because, if the user does not explicitly specify a configuration sentence
+anywhere in the main module of their definition, the configuration sentence
+from the DEFAULT-CONFIGURATION module of
+kast.md is imported
+automatically. Here is what that sentence looks like:

+
  configuration <k> $PGM:K </k>
+

This configuration declaration declares a single cell, the <k> cell. It also
+declares that at the start of rewriting, the contents of that cell should be
+initialized with the value of the $PGM configuration variable.
+Configuration variables function as inputs to krun. These terms are supplied
+to krun in the form of ASTs parsed using a particular module. By default, the
+$PGM configuration variable uses the main syntax module of the definition.

+

The cast on the configuration variable also specifies the sort that is used as
+the entry point to the parser, in this case the K sort. It is often
+useful to cast to other sorts there as well for better control over the accepted
+language. The sort used for the $PGM variable is referred to as the start
+symbol. During parsing, the default start symbol K subsumes all user-defined
+sorts except for syntactic lists. These are excluded because they will always
+produce an ambiguity error when parsing a single element.

+

Note that we did not explicitly specify the $PGM configuration variable when
+we invoked krun on a file. This is because krun handles the $PGM variable
+specially, and allows you to pass the term for that variable via a file passed
+as a positional argument to krun. We did, however, specify the PGM name
+explicitly when we called krun with the -cPGM command line argument in
+Lesson 1.2. This is the other, explicit, way of
+specifying an input to krun.

+

This explains the most basic use of configuration declarations in K. We can,
+however, declare multiple cells and multiple configuration variables. We can
+also specify the initial values of cells statically, rather than dynamically
+via krun.

+

For example, consider the following definition (lesson-15-a.k):

+
module LESSON-15-A-SYNTAX
+  imports INT-SYNTAX
+
+  syntax Ints ::= List{Int,","}
+endmodule
+
+module LESSON-15-A
+  imports LESSON-15-A-SYNTAX
+  imports INT
+
+  configuration <k> $PGM:Ints </k>
+                <sum> 0 </sum>
+
+  rule <k> I:Int, Is:Ints => Is ...</k>
+       <sum> SUM:Int => SUM +Int I </sum>
+endmodule
+

This simple definition takes a list of integers as input and sums them
+together. Here we have declared two cells: <k> and <sum>. Unlike <k>,
+<sum> does not get initialized via a configuration variable, but instead
+is initialized statically with the value 0.

+

Note the rule in the second module: we have explicitly specified multiple
+cells in a single rule. K will expect each of these cells to match in order for
+the rule to apply.

+

Here is a second example (lesson-15-b.k):

+
module LESSON-15-B-SYNTAX
+  imports INT-SYNTAX
+endmodule
+
+module LESSON-15-B
+  imports LESSON-15-B-SYNTAX
+  imports INT
+  imports BOOL
+
+  configuration <k> . </k>
+                <first> $FIRST:Int </first>
+                <second> $SECOND:Int </second>
+
+  rule <k> . => FIRST >Int SECOND </k>
+       <first> FIRST </first>
+       <second> SECOND </second>
+endmodule
+

This definition takes two integers as command-line arguments and populates the
+<k> cell with a Boolean indicating whether the first integer is greater than
+the second. Notice that we have specified no $PGM configuration variable
+here. As a result, we cannot invoke krun via the syntax krun $file.
+Instead, we must explicitly pass values for each configuration variable via the
+-cFIRST and -cSECOND command line flags. For example, if we invoke
+krun -cFIRST=0 -cSECOND=1, we will get the value false in the K cell.

+

You can also specify both a $PGM configuration variable and other
+configuration variables in a single configuration declaration, in which case
+you would be able to initialize $PGM with either a positional argument or the
+-cPGM command line flag, but the other configuration variables would need
+to be explicitly initialized with -c.

+

Exercise

+ +

Modify your solution to Lesson 1.14, Exercise 2 to add a new cell with a
+configuration variable of sort Bool. This variable should determine whether
+the / operator is evaluated using /Int or divInt. Test that by specifying
+different values for this variable, you can change the behavior of rounding on
+division of negative numbers.

+

Cell Nesting

+ +

It is possible to nest cells inside one another. A cell that contains other
+cells must contain only other cells, but in doing this, you are able to
+create a hierarchical structure to the configuration. Consider the following
+definition (lesson-15-c.k), which is equivalent to the one in LESSON-15-B:

+
module LESSON-15-C-SYNTAX
+  imports INT-SYNTAX
+endmodule
+
+module LESSON-15-C
+  imports LESSON-15-C-SYNTAX
+  imports INT
+  imports BOOL
+
+  configuration <T>
+                  <k> . </k>
+                  <state>
+                    <first> $FIRST:Int </first>
+                    <second> $SECOND:Int </second>
+                  </state>
+                </T>
+
+  rule <k> . => FIRST >Int SECOND </k>
+       <first> FIRST </first>
+       <second> SECOND </second>
+endmodule
+

Note that we have added some new cells to the configuration declaration:
+the <T> cell wraps the entire configuration, and the <state> cell is
+introduced around the <first> and <second> cells.

+

However, we have not changed the rule in this definition. This is because of
+a concept in K called configuration abstraction. K allows you to specify
+any number of cells in a rule (except zero) in any order you want, and K will
+compile the rules into a form that matches the structure of the configuration
+specified by the configuration declaration.

+

Here then, is how this rule would look after the configuration abstraction
+has been resolved:

+
  rule <T>
+         <k> . => FIRST >Int SECOND </k>
+         <state>
+           <first> FIRST </first>
+           <second> SECOND </second>
+         </state>
+       </T>
+

In other words, K will complete cells to the top of the configuration by
+inserting parent cells where appropriate based on the declared structure of
+the configuration. This is useful because as a definition evolves, the
+configuration may change, but you don't want to have to modify every single
+rule each time. Thus, K follows the principle that you should only mention the
+cells in a rule that are actually needed in order to accomplish its specific
+goal. By following this best practice, you can significantly increase the
+modularity of the definition and make it easier to maintain and modify.

+

Note that unlike top-level rewrite rules, cells that appear inside function
+rules are not necessarily completed to the top of the configuration. They still
+participate in cell ccompletion in the sense that you can mention cell
+structure loosely inside a function rule and it will be completed into the
+correct cell structure specified by the configuration declaration. However,
+they do not complete all the way to the top, instead completing only up to
+the top-most cell mentioned in the rule.

+

For example, if I write the following function rule in the above definition:

+
  rule doStuff(<first> FIRST </first>) => FIRST
+

The function will only match on the first cell, rather than the entire
+configuration. However, if we had mentioned a parent cell in the rule, it still
+would have completed the children of that parent cell as needed to ensure that
+the resulting term is well formed.

+

Exercise

+ +

Modify your definition from the previous exercise in this lesson to wrap the
+two cells you have declared in a top cell <T>. You should not have to change
+any other rules in the definition.

+

Cell Variables

+ +

Sometimes it is desirable to explicitly match a variable against certain
+fragments of the configuration. Because K's configuration is hierarchical,
+we can grab subsets of the configuration as if they were just another term.
+However, configuration abstraction applies here as well.
+In particular, for each cell you specify in a configuration declaration, a
+unique sort is assigned for that cell with a single constructor (the cell
+itself). The sort name is taken by removing all special characters,
+capitalizing the first letter and each letter after a hyphen, and adding the
+word Cell at the end. For example, in the above example, the cell sorts are
+TCell, KCell, StateCell, FirstCell, and SecondCell. If we had declared
+a cell as <first-number>, then the cell sort name would be FirstNumberCell.

+

You can explicitly reference a variable of one of these sorts anywhere you
+might instead write that cell. For example, consider the following rule:

+
  rule <k> true => S </k>
+       (S:StateCell => <state>... .Bag ...</state>)
+

Here we have introduced two new concepts. The first is the variable of sort
+StateCell, which matches the entire <state> part of the configuration. The
+second is that we have introduced the concept of ... once again. When a cell
+contains other cells, it is also possible to specify ... on either the left,
+right or both sides of the cell term. Each of these three syntaxes are
+equivalent in this case. When they appear on the left-hand side of a rule, they
+indicate that we don't care what value any cells not explicitly named might
+have. For example, we might write <state>... <first> 0 </first> ...</state> on
+the left-hand side of a rule in order to indicate that we want to match the
+rule when the <first> cell contains a zero, regardless of what the <second>
+cell contains. If we had not included this ellipsis, it would have been a
+syntax error, because K would have expected you to provide a value for each of
+the child cells.

+

However, if, as in the example above, the ... appeared on the right-hand side
+of a rule, this instead indicates that the cells not explicitly mentioned under
+the cell should be initialized with their default value from the configuration
+declaration. In other words, that rule will set the value of <first> and
+<second> to zero.

+

You may note the presence of the phrase .Bag here. You can think of this as
+the empty set of cells. It is used as the child of a cell when you want to
+indicate that no cells should be explicitly named. We will cover other uses
+of this term in later lessons.

+

Exercises

+ +
    +
  1. Modify the definition from the previous exercise in this lesson so that the
    +Boolean cell you created is initialized to false. Then add a production
    +syntax Stmt ::= Bool ";" Exp, and a rule that uses this Stmt to set the
    +value of the Boolean flag. Then add another production
    +syntax Stmt ::= "reset" ";" Exp which sets the value of the Boolean flag back
    +to its default value via a ... on the right-hand side. You will need to add
    +an additional cell around the Boolean cell to make this work.
  2. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.16: Maps, Semantic Lists, and Sets.

+

Lesson 1.16: Maps, Semantic Lists, and Sets

+ +

The purpose of this lesson is to explain how to use the data structure sorts
+provided by K: maps, lists, and sets.

+

Maps

+ +

The most frequently used type of data structure in K is the map. The sort
+provided by K for this purpose is the Map sort, and it is provided in
+domains.md in the MAP
+module. This type is not (currently) polymorphic. All Map terms are maps that
+map terms of sort KItem to other terms of sort KItem. A KItem can contain
+any sort except a K sequence. If you need to store such a term in a
+map, you can always use a wrapper such as syntax KItem ::= kseq(K).

+

A Map pattern consists of zero or more map elements (as represented by the
+symbol syntax Map ::= KItem "|->" KItem), mixed in any order, separated by
+whitespace, with zero or one variables of sort Map. The empty map is
+represented by .Map. If all of the bindings for the variables in the keys
+of the map can be deterministically chosen, these patterns can be matched in
+O(1) time. If they cannot, then each map element that cannot be
+deterministically constructed contributes a single dimension of polynomial
+time to the cost of the matching. In other words, a single such element is
+linear, two are quadratic, three are cubic, etc.

+

Patterns like the above are the only type of Map pattern that can appear
+on the left-hand-side of a rule. In other words, you are not allowed to write
+a Map pattern on the left-hand-side with more than one variable of sort Map
+in it. You are, however, allowed to write such patterns on the right-hand-side
+of a rule. You can also write a function pattern in the key of a map element
+so long as all the variables in the function pattern can be deterministically
+chosen.

+

Note the meaning of matching on a Map pattern: a map pattern with no
+variables of sort Map will match if the map being matched has exactly as
+many bindings as |-> symbols in the pattern. It will then match if each
+binding in the map pattern matches exactly one distinct binding in the map
+being matched. A map pattern with one Map variable will also match any map
+that contains such a map as a subset. The variable of sort Map will be bound
+to whatever bindings are left over (.Map if there are no bindings left over).

+

Here is an example of a simple definition that implements a very basic
+variable declaration semantics using a Map to store the value of variables
+(lesson-16-a.k):

+
module LESSON-16-A-SYNTAX
+  imports INT-SYNTAX
+  imports ID-SYNTAX
+
+  syntax Exp ::= Id | Int
+  syntax Decl ::= "int" Id "=" Exp ";" [strict(2)]
+  syntax Pgm ::= List{Decl,""}
+endmodule
+
+module LESSON-16-A
+  imports LESSON-16-A-SYNTAX
+  imports BOOL
+
+  configuration <T>
+                  <k> $PGM:Pgm </k>
+                  <state> .Map </state>
+                </T>
+
+  // declaration sequence
+  rule <k> D:Decl P:Pgm => D ~> P ...</k>
+  rule <k> .Pgm => . ...</k>
+
+  // variable declaration
+  rule <k> int X:Id = I:Int ; => . ...</k>
+       <state> STATE => STATE [ X <- I ] </state>
+
+  // variable lookup
+  rule <k> X:Id => I ...</k>
+       <state>... X |-> I ...</state>
+
+  syntax Bool ::= isKResult(K) [symbol, function]
+  rule isKResult(_:Int) => true
+  rule isKResult(_) => false [owise]
+endmodule
+

There are several new features in this definition. First, note we import
+the module ID-SYNTAX. This module is defined in domains.md and provides a
+basic syntax for identifiers. We are using the Id sort provided by this
+module in this definition to implement the names of program variables. This
+syntax is only imported when parsing programs, not when parsing rules. Later in
+this lesson we will see how to reference specific concrete identifiers in a
+rule.

+

Second, we introduce a single new function over the Map sort. This function,
+which is represented by the symbol
+syntax Map ::= Map "[" KItem "<-" KItem "]", represents the map update
+operation. Other functions over the Map sort can be found in domains.md.

+

Finally, we have used the ... syntax on a cell containing a Map. In this
+case, the meaning of <state>... Pattern ...</state>,
+<state>... Pattern </state>, and <state> Pattern ...</state> are the same:
+it is equivalent to writing <state> (Pattern) _:Map </state>.

+

Consider the following program (a.decl):

+
int x = 0;
+int y = 1;
+int a = x;
+

If we run this program with krun, we will get the following result:

+
<T>
+  <k>
+    .
+  </k>
+  <state>
+    a |-> 0
+    x |-> 0
+    y |-> 1
+  </state>
+</T>
+

Note that krun has automatically sorted the collection for you. This doesn't
+happen at runtime, so you still get the performance of a hash map, but it will
+help make the output more readable.

+

Exercise

+ +

Create a sort Stmt that is a subsort of Decl. Create a production of sort
+Stmt for variable assignment in addition to the variable declaration
+production. Feel free to use the syntax syntax Stmt ::= Id "=" Exp ";". Write
+a rule that implements variable assignment using a map update function. Then
+write the same rule using a map pattern. Test your implementations with some
+programs to ensure they behave as expected.

+

Semantic Lists

+ +

In a previous lesson, we explained how to represent lists in the AST of a
+program. However, this is not the only context where lists can be used. We also
+frequently use lists in the configuration of an interpreter in order to
+represent certain types of program state. For this purpose, it is generally
+useful to have an associative-list sort, rather than the cons-list sorts
+provided in Lesson 1.12.

+

The type provided by K for this purpose is the List sort, and it is also
+provided in domains.md, in the LIST module. This type is also not
+(currently) polymorphic. Like Map, all List terms are lists of terms of the
+KItem sort.

+

A List pattern in K consists of zero or more list elements (as represented by
+the ListItem symbol), followed by zero or one variables of sort List,
+followed by zero or more list elements. An empty list is represented by
+.List. These patterns can be matched in O(log(N)) time. This is the only
+type of List pattern that can appear on the left-hand-side of a rule. In
+other words, you are not allowed to write a List pattern on the
+left-hand-side with more than one variable of sort List in it. You are,
+however, allowed to write such patterns on the right-hand-side of a rule.

+

Note the meaning of matching on a List pattern: a list pattern with no
+variables of sort List will match if the list being matched has exactly as
+many elements as ListItem symbols in the pattern. It will then match if each
+element in sequence matches the pattern contained in the ListItem symbol. A
+list pattern with one variable of sort List operates the same way, except
+that it can match any list with at least as many elements as ListItem
+symbols, so long as the prefix and suffix of the list match the patterns inside
+the ListItem symbols. The variable of sort List will be bound to whatever
+elements are left over (.List if there are no elements left over).

+

The ... syntax is allowed on cells containing lists as well. In this case,
+the meaning of <cell>... Pattern </cell> is the same as
+<cell> _:List (Pattern) </cell>, the meaning of <cell> Pattern ...</cell>
+is the same as <cell> (Pattern) _:List</cell>. Because list patterns with
+multiple variables of sort List are not allowed, it is an error to write
+<cell>... Pattern ...</cell>.

+

Here is an example of a simple definition that implements a very basic
+function-call semantics using a List as a function stack (lesson-16-b.k):

+
module LESSON-16-B-SYNTAX
+  imports INT-SYNTAX
+  imports ID-SYNTAX
+
+  syntax Exp ::= Id "(" ")" | Int
+  syntax Stmt ::= "return" Exp ";" [strict]
+  syntax Decl ::= "fun" Id "(" ")" "{" Stmt "}"
+  syntax Pgm ::= List{Decl,""}
+  syntax Id ::= "main" [token]
+endmodule
+
+module LESSON-16-B
+  imports LESSON-16-B-SYNTAX
+  imports BOOL
+  imports LIST
+
+  configuration <T>
+                  <k> $PGM:Pgm ~> main () </k>
+                  <functions> .Map </functions>
+                  <fstack> .List </fstack>
+                </T>
+
+  // declaration sequence
+  rule <k> D:Decl P:Pgm => D ~> P ...</k>
+  rule <k> .Pgm => . ...</k>
+
+  // function definitions
+  rule <k> fun X:Id () { S } => . ...</k>
+       <functions>... .Map => X |-> S ...</functions>
+
+  // function call
+  syntax KItem ::= stackFrame(K)
+  rule <k> X:Id () ~> K => S </k>
+       <functions>... X |-> S ...</functions>
+       <fstack> .List => ListItem(stackFrame(K)) ...</fstack>
+
+  // return statement
+  rule <k> return I:Int ; ~> _ => I ~> K </k>
+       <fstack> ListItem(stackFrame(K)) => .List ...</fstack>
+
+  syntax Bool ::= isKResult(K) [function, symbol]
+  rule isKResult(_:Int) => true
+  rule isKResult(_) => false [owise]
+endmodule
+

Notice that we have declared the production syntax Id ::= "main" [token].
+Since we use the ID-SYNTAX module, this declaration is necessary in order to
+be able to refer to the main identifier directly in the configuration
+declaration. Our <k> cell now contains a K sequence initially: first we
+process all the declarations in the program, then we call the main function.

+

Consider the following program (foo.func):

+
fun foo() { return 5; }
+fun main() { return foo(); }
+

When we krun this program, we should get the following output:

+
<T>
+  <k>
+    5 ~> .
+  </k>
+  <functions>
+    foo |-> return 5 ;
+    main |-> return foo ( ) ;
+  </functions>
+  <fstack>
+    .List
+  </fstack>
+</T>
+

Note that we have successfully put on the <k> cell the value returned by the
+main function.

+

Exercise

+ +

Add a term of sort Id to the stackFrame operator to keep track of the
+name of the function in that stack frame. Then write a function
+syntax String ::= printStackTrace(List) that takes the contents of the
+<fstack> cell and pretty prints the current stack trace. You can concatenate
+strings with +String in the STRING module in domains.md, and you can
+convert an Id to a String with the Id2String function in the ID module.
+Test this function by creating a new expression that returns the current stack
+trace as a string. Make sure to update isKResult and the Exp sort as
+appropriate to allow strings as values.

+

Sets

+ +

The final primary data structure sort in K is a set, i.e., an idempotent
+unordered collection where elements are deduplicated. The sort provided by K
+for this purpose is the Set sort and it is provided in domains.md in the
+SET module. Like maps and lists, this type is not (currently) polymorphic.
+Like Map and List, all Set terms are sets of terms of the KItem sort.

+

A Set pattern has the exact same restrictions as a Map pattern, except that
+its elements are treated like keys, and there are no values. It has the same
+performance characteristics as well. However, syntactically it is more similar
+to the List sort: An empty Set is represented by .Set, but a set element
+is represented by the SetItem symbol.

+

Matching behaves similarly to the Map sort: a set pattern with no variables
+of sort Set will match if the set has exactly as many bindings as SetItem
+symbols, and if each element pattern matches one distinct element in the set.
+A set with a variable of sort Set also matches any superset of such a set.
+As with map, the elements left over will be bound to the Set variable (or
+.Set if no elements are left over).

+

Like Map, the ... syntax on a set is syntactic sugar for an anonymous
+variable of sort Set.

+

Here is an example of a simple modification to LESSON-16-A which uses a Set
+to ensure that variables are never declared more than once. In practice, you
+would likely just use the in_keys symbol over maps to test for this, but
+it's still useful as an example of sets in practice:

+
module LESSON-16-C-SYNTAX
+  imports LESSON-16-A-SYNTAX
+endmodule
+
+module LESSON-16-C
+  imports LESSON-16-C-SYNTAX
+  imports BOOL
+  imports SET
+
+  configuration <T>
+                  <k> $PGM:Pgm </k>
+                  <state> .Map </state>
+                  <declared> .Set </declared>
+                </T>
+
+  // declaration sequence
+  rule <k> D:Decl P:Pgm => D ~> P ...</k>
+  rule <k> .Pgm => . ...</k>
+
+  // variable declaration
+  rule <k> int X:Id = I:Int ; => . ...</k>
+       <state> STATE => STATE [ X <- I ] </state>
+       <declared> D => D SetItem(X) </declared>
+    requires notBool X in D
+
+  // variable lookup
+  rule <k> X:Id => I ...</k>
+       <state>... X |-> I ...</state>
+       <declared>... SetItem(X) ...</declared>
+
+  syntax Bool ::= isKResult(K) [symbol, function]
+  rule isKResult(_:Int) => true
+  rule isKResult(_) => false [owise]
+endmodule
+

Now if we krun a program containing duplicate declarations, it will get
+stuck on the declaration.

+

Exercises

+ +
    +
  1. Modify your solution to Lesson 1.14, Exercise 2 and introduce the sorts
    +Decls, Decl, and Stmt which include variable and function declaration
    +(without function parameters), and return and assignment statements, as well
    +as call expressions. Use List and Map to implement these operators, making
    +sure to consider the interactions between components, such as saving and
    +restoring the environment of variables at each call site. Don't worry about
    +local function definitions or global variables for now. Make sure to test the
    +resulting interpreter.
  2. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.17: Cell Multiplicity and Cell Collections.

+

Lesson 1.17: Cell Multiplicity and Cell Collections

+ +

The purpose of this lesson is to explain how you can create optional cells
+and cells that repeat multiple times in a configuration using a feature called
+cell multiplicity.

+

Cell Multiplicity

+ +

K allows you to specify attributes for cell productions as part of the syntax
+of configuration declarations. Unlike regular productions, which use the []
+syntax for attributes, configuration cells use an XML-like attribute syntax:

+
configuration <k color="red"> $PGM:K </k>
+

This configuration declaration gives the <k> cell the color red during
+unparsing using the color attribute as discussed in
+Lesson 1.9.

+

However, in addition to the usual attributes for productions, there are some
+other attributes that can be applied to cells with special meaning. One such
+attribute is the multiplicity attribute. By default, each cell that is
+declared occurs exactly once in every configuration term. However, using the
+multiplicity attribute, this default behavior can be changed. There are two
+values that this attribute can have: ? and *.

+

Optional cells

+ +

The first cell multiplicity we will discuss is ?. Similar to a regular
+expression language, this attribute tells the compiler that this cell can
+appear 0 or 1 times in the configuration. In other words, it is an
+optional cell. By default, K does not create optional cells in the initial
+configuration, unless that optional cell has a configuration variable inside
+it. However, it is possible to override the default behavior and create that
+cell initially by adding the additional cell attribute initial="".

+

K uses the .Bag symbol to represent the absence of any cells in a particular
+rule. Consider the following module:

+
module LESSON-17-A
+  imports INT
+
+  configuration <k> $PGM:K </k>
+                <optional multiplicity="?"> 0 </optional>
+
+  syntax KItem ::= "init" | "destroy"
+
+  rule <k> init => . ...</k>
+       (.Bag => <optional> 0 </optional>)
+  rule <k> destroy => . ...</k>
+       (<optional> _ </optional> => .Bag)
+
+endmodule
+

In this definition, when the init symbol is executed, the <optional> cell
+is added to the configuration, and when the destroy symbol is executed, it
+is removed. Any rule that matches on that cell will only match if that cell is
+present in the configuration.

+

Exercise

+ +

Create a simple definition with a Stmts sort that is a List{Stmt,""} and
+a Stmt sort with the constructors
+syntax Stmt ::= "enable" | "increment" | "decrement" | "disable". The
+configuration should have an optional cell that contains an integer that
+is created with the enable command, destroyed with the disable command,
+and its value is incremented or decremented by the increment and decrement
+command.

+

Cell collections

+ +

The second type of cell multiplicity we will discuss is *. Simlar to a
+regular expression language, this attribute tells the compiler that this cell
+can appear 0 or more times in the configuration. In other words, it is a
+cell collection. Cells with multiplicity * must be the only child of
+their parent cell. As a convention, the inner cell is usually named with the
+singular form of what it contains, and the outer cell with the plural form, for
+example, "thread" and "threads".

+

All cell collections are required to have the type attribute set to either
+Set or Map. A Set cell collection is represented as a set and behaves
+internally the same as the Set sort, although it actually declares a new
+sort. A Map cell collection is represented as a Map in which the first
+subcell of the cell collection is the key and the remaining cells are the
+value.

+

For example, consider the following module:

+
module LESSON-17-B
+  imports INT
+  imports BOOL
+  imports ID-SYNTAX
+
+  syntax Stmt ::= Id "=" Exp ";" [strict(2)]
+                | "return" Exp ";" [strict]
+  syntax Stmts ::= List{Stmt,""}
+  syntax Exp ::= Id
+               | Int
+               | Exp "+" Exp [seqstrict]
+               | "spawn" "{" Stmts "}"
+               | "join" Exp ";" [strict]
+
+  configuration <threads>
+                  <thread multiplicity="*" type="Map">
+                    <id> 0 </id>
+                    <k> $PGM:K </k>
+                  </thread>
+                </threads>
+                <state> .Map </state>
+                <next-id> 1 </next-id>
+
+  rule <k> X:Id => I:Int ...</k>
+       <state>... X |-> I ...</state>
+  rule <k> X:Id = I:Int ; => . ...</k>
+       <state> STATE => STATE [ X <- I ] </state>
+  rule <k> S:Stmt Ss:Stmts => S ~> Ss ...</k>
+  rule <k> I1:Int + I2:Int => I1 +Int I2 ...</k>
+
+  rule <thread>...
+         <k> spawn { Ss } => NEXTID ...</k>
+       ...</thread>
+       <next-id> NEXTID => NEXTID +Int 1 </next-id>
+       (.Bag =>
+       <thread>
+         <id> NEXTID </id>
+         <k> Ss </k>
+       </thread>)
+
+  rule <thread>...
+         <k> join ID:Int ; => I ...</k>
+       ...</thread>
+       (<thread>
+         <id> ID </id>
+         <k> return I:Int ; ...</k>
+       </thread> => .Bag)
+
+  syntax Bool ::= isKResult(K) [function, symbol]
+  rule isKResult(_:Int) => true
+  rule isKResult(_) => false [owise]
+endmodule
+

This module implements a very basic fork/join semantics. The spawn expression
+spawns a new thread to execute a sequence of statements and returns a thread
+id, and the join statement waits until a thread executes return and then
+returns the return value of the thread.

+

Note something quite novel here: the <k> cell is inside a cell of
+multiplicity *. Since the <k> cell is just a regular cell (mostly), this
+is perfectly allowable. Rules that don't mention a specific thread are
+automatically completed to match any thread.

+

When you execute programs in this language, the cells in the cell collection
+get sorted and printed like any other collection, but they still display like
+cells. Rules in this language also benefit from all the structural power of
+cells, allowing you to omit cells you don't care about or complete the
+configuration automatically. This allows you to have the power of cells while
+still being a collection under the hood.

+

Exercises

+ +
    +
  1. Modify the solution from Lesson 1.16, Exercise 1 so that the cell you use to
    +keep track of functions in a Map is now a cell collection. Run some programs
    +and compare how they get unparsed before and after this change.
  2. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.18: Term Equality and the Ternary Operator.

+

Lesson 1.18: Term Equality and the Ternary Operator

+ +

The purpose of this lesson is to introduce how to compare equality of terms in
+K, and how to put conditional expressions directly into the right-hand side of
+rules.

+

Term Equality

+ +

One major way you can compare whether two terms are equal in K is to simply
+match both terms with a variable with the same name. This will only succeed
+in matching if the two terms are equal structurally. However, sometimes this
+is impractical, and it is useful to have access to a way to actually compare
+whether two terms in K are equal. The operator for this is found in
+domains.md in the K-EQUAL
+module. The operator is ==K and takes two terms of sort K and returns a
+Bool. It returns true if they are equal. This includes equality over builtin
+types such as Map and Set where equality is not purely structural in
+nature. However, it does not include any notion of semantic equality over
+user-defined syntax. The inverse symbol for inequality is =/=K.

+

Ternary Operator

+ +

One way to introduce conditional logic in K is to have two separate rules,
+each with a side condition (or one rule with a side condition and another with
+the owise attribute). However, sometimes it is useful to explicitly write
+a conditional expression directly in the right-hand side of a rule. For this
+purpose, K defines one more operator in the K-EQUAL module, which corresponds
+to the usual ternary operator found in many languages. Here is an example of its
+usage (lesson-18.k):

+
module LESSON-18
+  imports INT
+  imports BOOL
+  imports K-EQUAL
+
+  syntax Exp ::= Int | Bool | "if" "(" Exp ")" Exp "else" Exp [strict(1)]
+
+  syntax Bool ::= isKResult(K) [function, symbol]
+  rule isKResult(_:Int) => true
+  rule isKResult(_:Bool) => true
+
+  rule if (B:Bool) E1:Exp else E2:Exp => #if B #then E1 #else E2 #fi
+endmodule
+

Note the symbol on the right-hand side of the final rule. This symbol is
+polymorphic: B must be of sort Bool, but E1 and E2 could have been
+any sort so long as both were of the same sort, and the sort of the entire
+expression becomes equal to that sort. K supports polymorphic built-in
+operators, but does not yet allow users to write their own polymorphic
+productions.

+

The behavior of this function is to evaluate the Boolean expression to a
+Boolean, then pick one of the two children and return it based on whether the
+Boolean is true or false. Please note that it is not a good idea to use this
+symbol in cases where one or both of the children is potentially undefined
+(for example, an integer expression that divides by zero). While the default
+implementation is smart enough to only evaluate the branch that happens to be
+picked, this will not be true when we begin to do program verification. If
+you need short circuiting behavior, it is better to use a side condition.

+

Exercises

+ +
    +
  1. +

    Write a function in K that takes two terms of sort K and returns an
    +Int: the Int should be 0 if the terms are equal and 1 if the terms are
    +unequal.

    +
  2. +
  3. +

    Modify your solution to Lesson 1.16, Exercise 1 and introduce an if
    +Stmt to the syntax of the language, then implement it using the #if symbol.
    +Make sure to write tests for the resulting interpreter.

    +
  4. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.19: Debugging with GDB.

+

Lesson 1.19: Debugging with GDB or LLDB

+ +

The purpose of this lesson is to teach how to debug your K interpreter using
+the K-language support provided in GDB or
+LLDB.

+

Caveats

+ +

This lesson has been written with GDB support on Linux in mind. Unfortunately,
+on macOS, GDB has limited support. To address this, we have introduced early
+experimental support for debugging with LLDB on macOS. In some cases, the
+features supported by LLDB are slightly different to those supported by GDB; the
+tutorial text will make this clear where necessary. If you use a macOS with an
+LLVM version older than 15, you may need to upgrade it to use the LLDB
+correctly. If you encounter an issue on either operating system, please open an
+issue against the K repository.

+

Getting started

+ +

On Linux, you will need GDB in order to complete this lesson. If you do not
+already have GDB installed, then do so. Steps to install GDB are outlined in
+this GDB Tutorial.

+

On macOS, LLDB should already have been installed with K's build dependencies
+(whether you have built K from source, or installed it using kup or Homebrew).

+

The first thing neccessary in order to debug a K interpreter is to build the
+interpreter with full debugging support enabled. This can be done relatively
+simply. First, run kompile with the command line flag --enable-llvm-debug.
+The resulting compiled K definition will be ready to support debugging.

+

Once you have a compiled K definition and a program you wish to debug, you can
+start the debugger by passing the --debugger flag to krun. This will
+automatically load the program you are executing into GDB and drop you into a
+GDB shell ready to start executing the program.

+

As an example, consider the following K definition (lesson-19-a.k):

+
module LESSON-19-A
+  imports INT
+
+  rule I => I +Int 1
+    requires I <Int 100
+endmodule
+

If we compile this definition with kompile lesson-19-a.k --enable-llvm-debug,
+and run the program 0 in the debugger with krun -cPGM=0 --debugger, we will
+see the following output (roughly, and depending on which platform you are
+using):

+

GDB / Linux

+ +
GNU gdb (Ubuntu 9.2-0ubuntu1~20.04) 9.2
+Copyright (C) 2020 Free Software Foundation, Inc.
+License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
+This is free software: you are free to change and redistribute it.
+There is NO WARRANTY, to the extent permitted by law.
+Type "show copying" and "show warranty" for details.
+This GDB was configured as "x86_64-linux-gnu".
+Type "show configuration" for configuration details.
+For bug reporting instructions, please see:
+<http://www.gnu.org/software/gdb/bugs/>.
+Find the GDB manual and other documentation resources online at:
+    <http://www.gnu.org/software/gdb/documentation/>.
+
+For help, type "help".
+Type "apropos word" to search for commands related to "word"...
+Reading symbols from ./lesson-19-a-kompiled/interpreter...
+warning: File "/home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-a-kompiled/interpreter" auto-loading has been declined by your `auto-load safe-path' set to "$debugdir:$datadir/auto-load".
+To enable execution of this file add
+        add-auto-load-safe-path /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-a-kompiled/interpreter
+line to your configuration file "/home/dwightguth/.gdbinit".
+To completely disable this security protection add
+        set auto-load safe-path /
+line to your configuration file "/home/dwightguth/.gdbinit".
+For more information about this security protection see the
+"Auto-loading safe path" section in the GDB manual.  E.g., run from the shell:
+        info "(gdb)Auto-loading safe path"
+(gdb)
+

To make full advantage of the GDB features of K, you should follow the first
+command listed in this output message and add the corresponding
+add-auto-load-safe-path command to your ~/.gdbinit file as prompted.
+Please note that the path will be different on your machine than the one
+listed above. Adding directories to the "load safe path" effectively tells GDB
+to trust those directories. All content under a given directory will be recursively
+trusted, so if you want to avoid having to add paths to the "load safe path" every
+time you kompile a different K definition, then you can just trust a minimal
+directory containing all your kompiled files; however, do not choose a top-level directory containing arbitrary files as this amounts to trusting arbitrary files and is a security risk. More info on the load safe path
+can be found here.

+

LLDB / macOS

+ +
(lldb) target create "./lesson-19-a-kompiled/interpreter"
+warning: 'interpreter' contains a debug script. To run this script in this debug session:
+
+    command script import "/Users/brucecollie/code/scratch/lesson-19-a-kompiled/interpreter.dSYM/Contents/Resources/Python/interpreter.py"
+
+To run all discovered debug scripts in this session:
+
+    settings set target.load-script-from-symbol-file true
+
+Current executable set to '/Users/brucecollie/code/scratch/lesson-19-a-kompiled/interpreter' (x86_64).
+(lldb) settings set -- target.run-args  ".krun-2023-03-20-11-22-46-TcYt9ffhb2/tmp.in.RupiLwHNfn" "-1" ".krun-2023-03-20-11-22-46-TcYt9ffhb2/result.kore"
+(lldb) 
+

LLDB applies slightly different security policies to GDB. To load K's debugging
+scripts for this session only, you can run the command script import line at
+the LLDB prompt. The loaded scripts will not persist across debugging sessions
+if you do this. It is also possible to configure LLDB to automatically load the
+K scripts when an interpreter is started in LLDB; doing so requires a slightly
+less broad permission than GDB.

+

On macOS, the .dSYM directory that contains debugging symbols for an
+executable can also contain Python scripts in Contents/Resources/Python. If
+there is a Python script with a name matching the name of the current executable
+(here, interpreter and interpreter.py), it will be automatically loaded if
+the target.load-script-from-symbol-file setting is set). You can therefore add
+the settings set command to your ~/.lldbinit without enabling full arbitrary
+code execution, but you should be aware of the paths from which code can be
+executed if you do so.

+

Basic commands

+ +
+

LLDB Note: the k start and k step commands are currently not
+implemented in the K LLDB scripts. To work around this limitation temporarily,
+you can run process launch --stop-at-entry instead of k start. To emulate
+k step, first run rbreak k_step once, then continue instead of each k step. We hope to address these limitations soon.

+
+

The most basic commands you can execute in the K GDB session are to run your
+program or to step through it. The first can be accomplished using GDB's
+built-in run command. This will automatically start the program and begin
+executing it. It will continue until the program aborts or finishes, or the
+debugger is interrupted with Ctrl-C.

+

Sometimes you want finer-grained control over how you proceed through the
+program you are debugging. To step through the rule applications in your
+program, you can use the k start and k step GDB commands.

+

k start is similar to the built-in start command in that it starts the
+program and then immediately breaks before doing any work. However, unlike
+the start command which will break immediately after the main method of
+a program is executed, the K start program will initialize the rewriter,
+evaluate the initial configuration, and break immediately prior to applying
+any rewrite steps.

+

In the example above, here is what we see when we run the k start command:

+
Temporary breakpoint 1 at 0x239210
+Starting program: /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-a-kompiled/interpreter .krun-2021-08-13-14-10-50-sMwBkbRicw/tmp.in.01aQt85TaA -1 .krun-2021-08-13-14-10-50-sMwBkbRicw/result.kore
+[Thread debugging using libthread_db enabled]
+Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
+
+Temporary breakpoint 1, 0x0000000000239210 in main ()
+0x0000000000231890 in step (subject=<k>
+  0 ~> .
+</k>)
+(gdb)
+

As you can see, we are stopped at the step function in the interpreter.
+This function is responsible for taking top-level rewrite steps. The subject
+parameter to this function is the current K configuration.

+

We can step through K rewrite steps one at a time by running the k step
+command. By default, this takes a single rewrite step (including any function
+rule applications that are part of that step).

+

Here is what we see when we run that command:

+
Continuing.
+
+Temporary breakpoint -22, 0x0000000000231890 in step (subject=<k>
+  1 ~> .
+</k>)
+(gdb)
+

As we can see, we have taken a single rewrite step. We can also pass a number
+to the k step command which indicates the number of rewrite steps to take.

+

Here is what we see if we run k step 10:

+
Continuing.
+
+Temporary breakpoint -23, 0x0000000000231890 in step (subject=<k>
+  11 ~> .
+</k>)
+(gdb)
+

As we can see, ten rewrite steps were taken.

+

Breakpoints

+ +

The next important step in debugging an application in GDB is to be able to
+set breakpoints. Generally speaking, there are three types of breakpoints we
+are interested in a K semantics: Setting a breakpoint when a particular
+function is called, setting a breakpoint when a particular rule is applied,
+and setting a breakpoint when a side condition of a rule is evaluated.

+

The easiest way to do the first two things is to set a breakpoint on the
+line of code containing the function or rule.

+

For example, consider the following K definition (lesson-19-b.k):

+
module LESSON-19-B
+  imports BOOL
+
+  syntax Bool ::= isBlue(Fruit) [function]
+  syntax Fruit ::= Blueberry() | Banana()
+  rule isBlue(Blueberry()) => true
+  rule isBlue(Banana()) => false
+
+  rule F:Fruit => isBlue(F)
+endmodule
+

Once this program has been compiled for debugging, we can run the program
+Blueberry(). We can then set a breakpoint that stops when the isBlue
+function is called with the following command in GDB:

+
break lesson-19-b.k:4
+

Similarly, in LLDB, run:

+
breakpoint set --file lesson-19-b.k --line 4
+

Here is what we see if we set this breakpoint and then run the interpreter:

+
(gdb) break lesson-19-b.k:4
+Breakpoint 1 at 0x231040: file /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b.k, line 4.
+(gdb) run
+Starting program: /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b-kompiled/interpreter .krun-2021-08-13-14-20-27-vXOQmV6lwS/tmp.in.fga98yqXlc -1 .krun-2021-08-13-14-20-27-vXOQmV6lwS/result.kore
+[Thread debugging using libthread_db enabled]
+Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
+
+Breakpoint 1, LblisBlue'LParUndsRParUnds'LESSON-19-B'Unds'Bool'Unds'Fruit (_1=Blueberry ( )) at /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b.k:4
+4         syntax Bool ::= isBlue(Fruit) [function]
+(gdb)
+
(lldb) breakpoint set --file lesson-19-b.k --line 4
+Breakpoint 1: where = interpreter`LblisBlue'LParUndsRParUnds'LESSON-19-B'Unds'Bool'Unds'Fruit + 20 at lesson-19-b.k:4:19, address = 0x0000000100003ff4
+(lldb) run
+Process 50546 launched: '/Users/brucecollie/code/scratch/lesson-19-b-kompiled/interpreter' (x86_64)
+Process 50546 stopped
+* thread #1, queue = 'com.apple.main-thread', stop reason = breakpoint 1.1
+    frame #0: 0x0000000100003ff4 interpreter`LblisBlue'LParUndsRParUnds'LESSON-19-B'Unds'Bool'Unds'Fruit(_1=Blueberry ( )) at lesson-19-b.k:4:19
+   1   	module LESSON-19-B
+   2   	  imports BOOL
+   3   	
+-> 4   	  syntax Bool ::= isBlue(Fruit) [function]
+   5   	  syntax Fruit ::= Blueberry() | Banana()
+   6   	  rule isBlue(Blueberry()) => true
+   7   	  rule isBlue(Banana()) => false
+(lldb)
+

As we can see, we have stopped at the point where we are evaluating that
+function. The value _1 that is a parameter to that function shows the
+value passed to the function by the caller.

+

We can also break when the isBlue(Blueberry()) => true rule applies by simply
+changing the line number to the line number of that rule:

+
(gdb) break lesson-19-b.k:6
+Breakpoint 1 at 0x2af710: file /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b.k, line 6.
+(gdb) run
+Starting program: /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b-kompiled/interpreter .krun-2021-08-13-14-32-36-7kD0ic7XwD/tmp.in.8JNH5Qtmow -1 .krun-2021-08-13-14-32-36-7kD0ic7XwD/result.kore
+[Thread debugging using libthread_db enabled]
+Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
+
+Breakpoint 1, apply_rule_138 () at /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b.k:6
+6         rule isBlue(Blueberry()) => true
+(gdb)
+
(lldb) breakpoint set --file lesson-19-b.k --line 6
+Breakpoint 1: where = interpreter`apply_rule_140 at lesson-19-b.k:6:8, address = 0x0000000100004620
+(lldb) run
+Process 50681 launched: '/Users/brucecollie/code/scratch/lesson-19-b-kompiled/interpreter' (x86_64)
+Process 50681 stopped
+* thread #1, queue = 'com.apple.main-thread', stop reason = breakpoint 1.1
+    frame #0: 0x0000000100004620 interpreter`apply_rule_140 at lesson-19-b.k:6:8
+   3   	
+   4   	  syntax Bool ::= isBlue(Fruit) [function]
+   5   	  syntax Fruit ::= Blueberry() | Banana()
+-> 6   	  rule isBlue(Blueberry()) => true
+   7   	  rule isBlue(Banana()) => false
+   8   	
+   9   	  rule F:Fruit => isBlue(F)
+(lldb) 
+

We can also do the same with a top-level rule:

+
(gdb) break lesson-19-b.k:9
+Breakpoint 1 at 0x2aefa0: lesson-19-b.k:9. (2 locations)
+(gdb) run
+Starting program: /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b-kompiled/interpreter .krun-2021-08-13-14-33-13-9fC8Sz4aO3/tmp.in.jih1vtxSiQ -1 .krun-2021-08-13-14-33-13-9fC8Sz4aO3/result.kore
+[Thread debugging using libthread_db enabled]
+Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
+
+Breakpoint 1, apply_rule_107 (Var'Unds'DotVar0=<generatedCounter>
+  0
+</generatedCounter>, Var'Unds'DotVar1=., VarF=Blueberry ( )) at /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b.k:9
+9         rule F:Fruit => isBlue(F)
+(gdb)
+
(lldb) breakpoint set --file lesson-19-b.k --line 9
+Breakpoint 1: 2 locations.
+(lldb) run
+Process 50798 launched: '/Users/brucecollie/code/scratch/lesson-19-b-kompiled/interpreter' (x86_64)
+Process 50798 stopped
+* thread #1, queue = 'com.apple.main-thread', stop reason = breakpoint 1.1
+    frame #0: 0x0000000100003f2e interpreter`apply_rule_109(Var'Unds'DotVar0=<generatedCounter>
+  0
+</generatedCounter>, Var'Unds'DotVar1=., VarF=Blueberry ( )) at lesson-19-b.k:9:8
+   6   	  rule isBlue(Blueberry()) => true
+   7   	  rule isBlue(Banana()) => false
+   8   	
+-> 9   	  rule F:Fruit => isBlue(F)
+   10  	endmodule
+(lldb)  
+

Unlike the function rule above, we see several parameters to this function.
+These are the substitution that was matched for the function. Variables only
+appear in this substitution if they are actually used on the right-hand side
+of the rule.

+

Advanced breakpoints

+ +

Sometimes it is inconvenient to set the breakpoint based on a line number.

+

It is also possible to set a breakpoint based on the rule label of a particular
+rule. Consider the following definition (lesson-19-c.k):

+
module LESSON-19-C
+  imports INT
+  imports BOOL
+
+  syntax Bool ::= isEven(Int) [function]
+  rule [isEven]: isEven(I) => true requires I %Int 2 ==Int 0
+  rule [isOdd]: isEven(I) => false requires I %Int 2 =/=Int 0
+
+endmodule
+

We will run the program isEven(4). We can set a breakpoint for when a rule
+applies by means of the MODULE-NAME.label.rhs syntax:

+
(gdb) break LESSON-19-C.isEven.rhs
+Breakpoint 1 at 0x2afda0: file /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c.k, line 6.
+(gdb) run
+Starting program: /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c-kompiled/interpreter .krun-2021-08-13-14-40-29-LNNT8YEZ61/tmp.in.ZG93vWCGGC -1 .krun-2021-08-13-14-40-29-LNNT8YEZ61/result.kore
+[Thread debugging using libthread_db enabled]
+Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
+
+Breakpoint 1, LESSON-19-C.isEven.rhs () at /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c.k:6
+6         rule [isEven]: isEven(I) => true requires I %Int 2 ==Int 0
+(gdb)
+
(lldb) breakpoint set --name LESSON-19-C.isEven.rhs
+Breakpoint 1: where = interpreter`LESSON-19-C.isEven.rhs at lesson-19-c.k:6:18, address = 0x00000001000038e0
+(lldb) run
+Process 51205 launched: '/Users/brucecollie/code/scratch/lesson-19-c-kompiled/interpreter' (x86_64)
+Process 51205 stopped
+* thread #1, queue = 'com.apple.main-thread', stop reason = breakpoint 1.1
+    frame #0: 0x00000001000038e0 interpreter`LESSON-19-C.isEven.rhs at lesson-19-c.k:6:18
+   3   	  imports BOOL
+   4   	
+   5   	  syntax Bool ::= isEven(Int) [function]
+-> 6   	  rule [isEven]: isEven(I) => true requires I %Int 2 ==Int 0
+   7   	  rule [isOdd]: isEven(I) => false requires I %Int 2 =/=Int 0
+   8   	
+   9   	endmodule
+(lldb) 
+

We can also set a breakpoint for when a rule's side condition is evaluated
+by means of the MODULE-NAME.label.sc syntax:

+
(gdb) break LESSON-19-C.isEven.sc
+Breakpoint 1 at 0x2afd70: file /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c.k, line 6.
+(gdb) run
+Starting program: /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c-kompiled/interpreter .krun-2021-08-13-14-41-48-1BoGfJRbYc/tmp.in.kg4F8cwfCe -1 .krun-2021-08-13-14-41-48-1BoGfJRbYc/result.kore
+[Thread debugging using libthread_db enabled]
+Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
+
+Breakpoint 1, LESSON-19-C.isEven.sc (VarI=4) at /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c.k:6
+6         rule [isEven]: isEven(I) => true requires I %Int 2 ==Int 0
+(gdb) finish
+Run till exit from #0  LESSON-19-C.isEven.sc (VarI=4) at /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c.k:6
+0x00000000002b2662 in LblisEven'LParUndsRParUnds'LESSON-19-C'Unds'Bool'Unds'Int (_1=4) at /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c.k:5
+5         syntax Bool ::= isEven(Int) [function]
+Value returned is $1 = true
+(gdb)
+
(lldb) breakpoint set --name LESSON-19-C.isEven.sc
+Breakpoint 1: where = interpreter`LESSON-19-C.isEven.sc + 1 at lesson-19-c.k:6:18, address = 0x00000001000038c1
+(lldb) run
+Process 52530 launched: '/Users/brucecollie/code/scratch/lesson-19-c-kompiled/interpreter' (x86_64)
+Process 52530 stopped
+* thread #1, queue = 'com.apple.main-thread', stop reason = breakpoint 1.1
+    frame #0: 0x00000001000038c1 interpreter`LESSON-19-C.isEven.sc(VarI=0x0000000101800088) at lesson-19-c.k:6:18
+   3   	  imports BOOL
+   4   	
+   5   	  syntax Bool ::= isEven(Int) [function]
+-> 6   	  rule [isEven]: isEven(I) => true requires I %Int 2 ==Int 0
+   7   	  rule [isOdd]: isEven(I) => false requires I %Int 2 =/=Int 0
+   8   	
+   9   	endmodule
+(lldb) finish
+Process 52649 stopped
+* thread #1, queue = 'com.apple.main-thread', stop reason = step out
+Return value: (bool) $0 = true
+
+    frame #0: 0x00000001000069e5 interpreter`LblisEven'LParUndsRParUnds'LESSON-19-C'Unds'Bool'Unds'Int(_1=0x0000000101800088) at lesson-19-c.k:5:19
+   2   	  imports INT
+   3   	  imports BOOL
+   4   	
+-> 5   	  syntax Bool ::= isEven(Int) [function]
+   6   	  rule [isEven]: isEven(I) => true requires I %Int 2 ==Int 0
+   7   	  rule [isOdd]: isEven(I) => false requires I %Int 2 =/=Int 0
+   8
+(lldb)
+

Here we have used the built-in command finish to tell us whether the side
+condition returned true or not. Note that once again, we see the substitution
+that was matched from the left-hand side. Like before, a variable will only
+appear here if it is used in the side condition.

+

Debugging rule matching

+ +

Sometimes it is useful to try to determine why a particular rule did or did
+not apply. K provides some basic debugging commands which make it easier
+to determine this.

+

Consider the following K definition (lesson-19-d.k):

+
module LESSON-19-D
+
+  syntax Foo ::= foo(Bar)
+  syntax Bar ::= bar(Baz) | bar2(Baz)
+  syntax Baz ::= baz() | baz2()
+
+  rule [baz]: foo(bar(baz())) => .K
+
+endmodule
+

Suppose we try to run the program foo(bar(baz2())). It is obvious from this
+example why the rule in this definition will not apply. However, in practice,
+such cases are not always obvious. You might look at a rule and not immediately
+spot why it didn't apply on a particular term. For this reason, it can be
+useful to get the debugger to provide a log about how it tried to match that
+term. You can do this with the k match command. If you are stopped after
+having run k start or k step, you can obtain this log for any rule after
+any step by running the command k match MODULE.label subject for a particular
+top-level rule label.

+

For example, with the baz rule above, we get the following output:

+
(gdb) k match LESSON-19-D.baz subject
+Subject:
+baz2 ( )
+does not match pattern:
+baz ( )
+
(lldb) k match LESSON-19-D.baz subject
+Subject:
+baz2 ( )
+does not match pattern:
+baz ( )
+

As we can see, it provided the exact subterm which did not match against the
+rule, as well as the particular subpattern it ought to have matched against.

+

This command does not actually take any rewrite steps. In the event that
+matching actually succeeds, you will still need to run the k step command
+to advance to the next step.

+

Final notes

+ +

In addition to the functionality provided above, you have the full power of
+GDB or LLDB at your disposal when debugging. Some features are not particularly
+well-adapted to K code and may require more advanced knowledge of the
+term representation or implementation to use effectively, but anything that
+can be done in GDB or LLDB can in theory be done using this debugging functionality.
+We suggest you refer to the
+GDB Documentation or
+LLDB Tutorial if you
+want to try to do something and are unsure as to how.

+

Exercises

+ +
    +
  1. Compile your solution to Lesson 1.18, Exercise 2 with debugging support
    +enabled and step through several programs you have previously used to test.
    +Then set a breakpoint on the isKResult function and observe the state of the
    +interpreter when stopped at that breakpoint. Set a breakpoint on the rule for
    +addition and run a program that causes it to be stopped at that breakpoint.
    +Finally, step through the program until the addition symbol is at the top
    +of the K cell, and then use the k match command to report the reason why
    +the subtraction rule does not apply. You may need to modify the definition
    +to insert some rule labels.
  2. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.20: K Backends and the Haskell Backend.

+

Lesson 1.20: K Backends and the Haskell Backend

+ +

The purpose of this lesson is to teach about the multiple backends of K,
+in particular the Haskell Backend which is the complement of the backend we
+have been using so far.

+

K Backends

+ +

Thus far, we have not discussed the distinction between the K frontend and
+the K backends at all. We have simply assumed that if you run kompile on a
+K definition, there will be a compiler backend that will allow you to execute
+the K definition you have compiled.

+

K actually has multiple different backends. The one we have been using so far
+implicitly, the default backend, is called the LLVM Backend. It is
+designed to support efficient, optimized concrete execution and search. It
+does this by compiling your K definition to LLVM bitcode and then using LLVM
+to generate machine code for it that is compiled and linked and executed.
+However, K is a formal methods toolkit at the end of the day, and the primary
+goal many people have when defining a programming language in K is to
+ultimately be able to perform more advanced verification on programs in their
+programming language.

+

It is for this purpose that K also provides the Haskell Backend, so called
+because it is implemented in Haskell. While we will cover the features of the
+Haskell Backend in more detail in the next two lessons, the important thing to
+understand is that it is a separate backend which is optimized for more formal
+reasoning about programming languages. While it is capable of performing
+concrete execution, it does not do so as efficiently as the LLVM Backend.
+In exchange, it provides more advanced features.

+

Choosing a backend

+ +

You can choose which backend to use to compile a K definition by means of the
+--backend flag to kompile. By default, if you do not specify this flag, it
+is equivalent to if you had specified --backend llvm. However, to use the
+Haskell Backend instead, you can simply say kompile --backend haskell on a
+particular K definition.

+

As an example, here is a simple K definition that we have seen before in the
+previous lesson (lesson-20.k):

+
module LESSON-20
+  imports INT
+
+  rule I => I +Int 1
+    requires I <Int 100
+endmodule
+

Previously we compiled this definition using the LLVM Backend, but if we
+instead execute the command kompile lesson-20.k --backend haskell, we
+will get an interpreter for this K definition that is implemented in Haskell
+instead. Unlike the default LLVM Backend, the Haskell Backend is not a
+compiler per se. It does not generate new Haskell code corresponding to your
+programming language and then compile and execute it. Instead, it is an
+interpreter which reads the generated IR from kompile and implements in
+Haskell an interpreter that is capable of interpreting any K definition.

+

Note that on arm64 macOS (Apple Silicon), there is a known issue with the Compact
+library that causes crashes in the Haskell backend. Pass the additional flag
+--no-haskell-binary to kompile to resolve this.
+This flag is also needed when using krun.

+

Exercise

+ +

Try running the program 0 in this K definition on the Haskell Backend and
+compare the final configuration to what you would get compiling the same
+definition with the LLVM Backend.

+

Legacy backends

+ +

As a quick note, K does provide one other backend, which exists primarily as
+legacy code which should be considered deprecated. This is the
+Java Backend. The Java Backend is essentially a precursor to the Haskell
+Backend. We will not cover this backend in any detail since it is deprecated,
+but we still mention it here for the purposes of understanding.

+

Exercises

+ +
    +
  1. Compile your solution to Lesson 1.18, Exercise 2 with the Haskell Backend
    +and execute some programs. Compare the resulting configurations with the
    +output of the same program on the LLVM Backend. Note that if you are getting
    +different behaviors on the Haskell backend, you might have some luck debugging
    +by passing --search to krun when using the LLVM backend.
  2. +
+

Next lesson

+ +

Once you have completed the above exercises, you can continue to
+Lesson 1.21: Unification and Symbolic Execution.

+

Lesson 1.21: Unification and Symbolic Execution

+ +

The purpose of this lesson is to teach the basic concepts of symbolic execution
+in order to introduce the unique capabilities of the Haskell Backend at a
+conceptual level.

+

Symbolic Execution

+ +

Thus far, all of the programs we have run using K have been concrete
+configurations. What this means is that the configuration we use to initialize
+the K rewrite engine is concrete; in other words, contains no logical
+variables. The LLVM Backend is a concrete execution engine, meaning that
+it is only capable of rewriting concrete configurations.

+

By contrast, the Haskell Backend performs symbolic execution, which is
+capable of rewriting any configuration, including those where parts of the
+configuration are symbolic, ie, contain variables or uninterpreted
+functions.

+

Unification

+ +

Previously, we have introduced the concept that K rewrite rules operate by
+means of pattern matching: the current configuration being rewritten is pattern
+matched against the left-hand side of the rewrite rule, and the substitution
+is used in order to construct a new term from the right-hand side. In symbolic
+execution, we use
+unification
+instead of pattern matching. To summarize, unification behaves akin to a
+two-way pattern matching where both the configuration and the left-hand side
+of the rule can contain variables, and the algorithm generates a
+most general unifier containing substitutions for the variables in both
+which will make both terms equal.

+

Feasibility

+ +

Unification by itself cannot completely solve the problem of symbolic
+execution. One task symbolic execution must perform is to identify whether
+a particular symbolic term is feasible, that is to say, that there actually
+exists a concrete instantiation of that term such that all the logical
+constraints on that term can actually be satisfied. The Haskell Backend
+delegates this task to Z3, an
+SMT solver.
+This solver is used to periodically trim configurations that are determined
+to be mathematically infeasible.

+

Symbolic terms

+ +

The final component of symbolic execution consists of the task of introducing
+symbolic terms into the configuration. This can be done one of two different
+ways. First, the term being passed to krun can actually be symbolic. This
+is less frequently used because it requires the user to construct an AST
+that contains variables, something which our current parsing capabilities are
+not well-equipped to do. The second, more common, way of introducing symbolic
+terms into a configuration consists of writing rules where there exists an
+existentially qualified variable on the right-hand side of the rule that does
+not exist on the left-hand side of the rule.

+

In order to prevent users from writing such rules by accident, K requires
+that such variables begin with the ? prefix. For example, here is a rule
+that rewrites a constructor foo to a symbolic integer:

+
rule <k> foo => ?X:Int ...</k>
+

When this rule applies, a fresh variable is introduced to the configuration, which
+then is unified against the rules that might apply in order to symbolically
+execute that configuration.

+

ensures clauses

+ +

We also introduce here a new feature of K rules that applies when a rule
+has this type of variable on the right-hand side: the ensures clause.
+An ensures clause is similar to a requires clause and can appear after
+a rule body, or after a requires clause. The ensures clause is used to
+introduce constraints that might apply to the variable that was introduced by
+that rule. For example, we could write the rule above with the additional
+constraint that the symbolic integer that was introduced must be less than
+five, by means of the following rule:

+
rule <k> foo => ?X:Int ...</k> ensures ?X <Int 5
+

Putting it all together

+ +

Putting all these pieces together, it is possible to use the Haskell Backend
+to perform symbolic reasoning about a particular K module, determining all the
+possible states that can be reached by a symbolic configuration.

+

For example, consider the following K definition (lesson-21.k):

+
module LESSON-21
+    imports INT
+
+    rule <k> 0 => ?X:Int ... </k> ensures ?X =/=Int 0
+    rule <k> X:Int => 5  ... </k> requires X >=Int 10
+endmodule
+

When we symbolically execute the program 0, we get the following output
+from the Haskell Backend:

+
    <k>
+      5 ~> .
+    </k>
+  #And
+    {
+      true
+    #Equals
+      ?X:Int >=Int 10
+    }
+  #And
+    #Not ( {
+      ?X:Int
+    #Equals
+      0
+    } )
+#Or
+    <k>
+      ?X:Int ~> .
+    </k>
+  #And
+    #Not ( {
+      true
+    #Equals
+      ?X:Int >=Int 10
+    } )
+  #And
+    #Not ( {
+      ?X:Int
+    #Equals
+      0
+    } )
+

Note some new symbols introduced by this configuration: #And, #Or, and
+#Equals. While andBool, orBool, and ==K represent functions of sort
+Bool, #And, #Or, and #Equals are matching logic connectives. We
+will discuss matching logic in more detail later in the tutorial, but the basic
+idea is that these symbols represent Boolean operators over the domain of
+configurations and constraints, as opposed to over the Bool sort.

+

Notice that the configuration listed above is a disjunction of conjunctions.
+This is the most common form of output that can be produced by the Haskell
+Backend. In this case, each conjunction consists of a configuration and a set
+of constraints. What this conjunction describes, essentially, is a
+configuration and a set of information that was derived to be true while
+rewriting that configuration.

+

Similar to how we saw --search in a previous lesson, the reason we have
+multiple disjuncts is because there are multiple possible output states
+for this program, depending on whether or not the second rule applied. In the
+first case, we see that ?X is greater than or equal to 10, so the second rule
+applied, rewriting the symbolic integer to the concrete integer 5. In the
+second case, we see that the second rule did not apply because ?X is less
+than 10. Moreover, because of the ensures clause on the first rule, we know
+that ?X is not zero, therefore the first rule will not apply a second time.
+If we had omitted this constraint, we would have ended up infinitely applying
+the first rule, leading to krun not terminating.

+

In the next lesson, we will cover how symbolic execution forms the backbone
+of deductive program verification in K and how we can use K to prove programs
+correct against a specification.

+

Exercises

+ +
    +
  1. Create another rule in LESSON-21 that rewrites odd integers greater than
    +ten to a symbolic even integer less than 10 and greater than 0. This rule will
    +now apply nondeterministically along with the existing rules. Predict what the
    +resulting output configuration will be from rewriting 0 after adding this
    +rule. Then run the program and see whether your prediction is correct.
  2. +
+

Once you have completed the above exercises, you can continue to
+Lesson 1.22: Basics of Deductive Program Verification using K.

+

Lesson 1.22: Basics of Deductive Program Verification using K

+ +

In this lesson, you will familiarize yourself with the basics of using K for
+deductive program verification.

+

1. Setup: Simple Programming Language with Function Calls

+ +

We base this lesson on a simple programming language with functions,
+assignment, if conditionals, and while loops. Take your time to study its
+formalization below (lesson-22.k):

+
module LESSON-22-SYNTAX
+    imports INT-SYNTAX
+    imports BOOL-SYNTAX
+    imports ID-SYNTAX
+
+    syntax Exp ::= IExp | BExp
+
+    syntax IExp ::= Id | Int
+
+    syntax KResult ::= Int | Bool | Ints
+
+    // Take this sort structure:
+    //
+    //     IExp
+    //    /    \
+    // Int      Id
+    //
+    // Through the List{_, ","} functor.
+    // Must add a `Bot`, for a common subsort for the empty list.
+
+    syntax Bot
+    syntax Bots ::= List{Bot, ","} [klabel(exps)]
+    syntax Ints ::= List{Int, ","} [klabel(exps)]
+                  | Bots
+    syntax Ids  ::= List{Id, ","}  [klabel(exps)]
+                  | Bots
+    syntax Exps ::= List{Exp, ","} [klabel(exps), seqstrict]
+                  | Ids | Ints
+
+    syntax IExp ::= "(" IExp ")" [bracket]
+                  | IExp "+" IExp [seqstrict]
+                  | IExp "-" IExp [seqstrict]
+                  > IExp "*" IExp [seqstrict]
+                  | IExp "/" IExp [seqstrict]
+                  > IExp "^" IExp [seqstrict]
+                  | Id "(" Exps ")" [strict(2)]
+
+    syntax BExp ::= Bool
+
+    syntax BExp ::= "(" BExp ")" [bracket]
+                  | IExp "<=" IExp [seqstrict]
+                  | IExp "<"  IExp [seqstrict]
+                  | IExp ">=" IExp [seqstrict]
+                  | IExp ">"  IExp [seqstrict]
+                  | IExp "==" IExp [seqstrict]
+                  | IExp "!=" IExp [seqstrict]
+
+    syntax BExp ::= BExp "&&" BExp
+                  | BExp "||" BExp
+
+    syntax Stmt ::=
+         Id "=" IExp ";" [strict(2)]                        // Assignment
+       | Stmt Stmt [left]                                   // Sequence
+       | Block                                              // Block
+       | "if" "(" BExp ")" Block "else" Block [strict(1)]   // If conditional
+       | "while" "(" BExp ")" Block                         // While loop
+       | "return" IExp ";"                    [seqstrict]   // Return statement
+       | "def" Id "(" Ids ")" Block                         // Function definition
+
+    syntax Block ::=
+         "{" Stmt "}"    // Block with statement
+       | "{" "}"         // Empty block
+endmodule
+
+module LESSON-22
+    imports INT
+    imports BOOL
+    imports LIST
+    imports MAP
+    imports LESSON-22-SYNTAX
+
+    configuration
+      <k> $PGM:Stmt </k>
+      <store> .Map </store>
+      <funcs> .Map </funcs>
+      <stack> .List </stack>
+
+ // -----------------------------------------------
+    rule <k> I1 + I2 => I1 +Int I2 ... </k>
+    rule <k> I1 - I2 => I1 -Int I2 ... </k>
+    rule <k> I1 * I2 => I1 *Int I2 ... </k>
+    rule <k> I1 / I2 => I1 /Int I2 ... </k>
+    rule <k> I1 ^ I2 => I1 ^Int I2 ... </k>
+
+    rule <k> I:Id => STORE[I] ... </k>
+         <store> STORE </store>
+
+ // ------------------------------------------------
+    rule <k> I1 <= I2 => I1  <=Int I2 ... </k>
+    rule <k> I1  < I2 => I1   <Int I2 ... </k>
+    rule <k> I1 >= I2 => I1  >=Int I2 ... </k>
+    rule <k> I1  > I2 => I1   >Int I2 ... </k>
+    rule <k> I1 == I2 => I1  ==Int I2 ... </k>
+    rule <k> I1 != I2 => I1 =/=Int I2 ... </k>
+
+    rule <k> B1 && B2 => B1 andBool B2 ... </k>
+    rule <k> B1 || B2 => B1  orBool B2 ... </k>
+
+    rule <k> S1:Stmt S2:Stmt => S1 ~> S2 ... </k>
+
+    rule <k> ID = I:Int ; => . ... </k>
+         <store> STORE => STORE [ ID <- I ] </store>
+
+    rule <k> { S } => S ... </k>
+    rule <k> {   } => . ... </k>
+
+    rule <k> if (true)   THEN else _ELSE => THEN ... </k>
+    rule <k> if (false) _THEN else  ELSE => ELSE ... </k>
+
+    rule <k> while ( BE ) BODY => if ( BE ) { BODY while ( BE ) BODY } else { } ... </k>
+
+    rule <k> def FNAME ( ARGS ) BODY => . ... </k>
+         <funcs> FS => FS [ FNAME <- def FNAME ( ARGS ) BODY ] </funcs>
+
+    rule <k> FNAME ( IS:Ints ) ~> CONT => #makeBindings(ARGS, IS) ~> BODY </k>
+         <funcs> ... FNAME |-> def FNAME ( ARGS ) BODY ... </funcs>
+         <store> STORE => .Map </store>
+         <stack> .List => ListItem(state(CONT, STORE)) ... </stack>
+
+    rule <k> return I:Int ; ~> _ => I ~> CONT </k>
+         <stack> ListItem(state(CONT, STORE)) => .List ... </stack>
+         <store> _ => STORE </store>
+
+    rule <k> return I:Int ; ~> . => I </k>
+         <stack> .List </stack>
+
+    syntax KItem ::= #makeBindings(Ids, Ints)
+                   | state(continuation: K, store: Map)
+ // ----------------------------------------------------
+    rule <k> #makeBindings(.Ids, .Ints) => . ... </k>
+    rule <k> #makeBindings((I:Id, IDS => IDS), (IN:Int, INTS => INTS)) ... </k>
+         <store> STORE => STORE [ I <- IN ] </store>
+endmodule
+

Next, compile this example using kompile lesson-22.k --backend haskell. If
+your processor is an Apple Silicon processor, add the --no-haskell-binary
+flag if the compilation fails.

+

2. Setup: Proof Environment

+ +

Next, take the following snippet of K code and save it in lesson-22-spec.k.
+This is a skeleton of the proof environment, and we will complete it as the
+lesson progresses.

+
requires "lesson-22.k"
+requires "domains.md"
+
+module LESSON-22-SPEC-SYNTAX
+    imports LESSON-22-SYNTAX
+
+endmodule
+
+module VERIFICATION
+    imports K-EQUAL
+    imports LESSON-22-SPEC-SYNTAX
+    imports LESSON-22
+    imports MAP-SYMBOLIC
+
+endmodule
+
+module LESSON-22-SPEC
+    imports VERIFICATION
+
+endmodule
+

3. Claims

+ +
    +
  1. The first claim we will ask K to prove is that 3 + 4, in fact, equals 7.
    +Claims are stated using the claim keyword, followed by the claim
    +statement:
  2. +
+
claim <k> 3 + 4 => 7 ... </k>
+

Add this claim to the LESSON-22-SPEC module and run the K prover using the
+command kprove lesson-22-spec.k. You should get back the output #Top,
+which denotes the Matching Logic equivalent of true and means, in this
+context, that all claims have been proven correctly.

+
    +
  1. The second claim reasons about the if statement that has a concrete condition:
  2. +
+
claim <k> if ( 3 + 4 == 7 ) {
+            $a = 1 ;
+            } else {
+            $a = 2 ;
+            }
+        => . ... </k>
+        <store> STORE => STORE [ $a <- 1 ] </store>
+

stating that the given program terminates (=> .), and when it does, the value
+of the variable $a is set to 1, meaning that the execution will have taken
+the then branch. Add this claim to the LESSON-22-SPEC module, but also add

+
syntax Id ::= "$a" [token]
+

to the LESSON-22-SPEC-SYNTAX module in order to declare $a as a token so
+that it can be used as a program variable. Re-run the K prover, which should
+again return #Top.

+
    +
  1. Our third claim demonstrates how to reason about both branches of an if
    +statement at the same time:
  2. +
+
claim <k> $a = A:Int ; $b = B:Int ;
+          if ($a < $b) {
+            $c = $b ;
+          } else {
+            $c = $a ;
+          }
+        => . ... </k>
+        <store> STORE => STORE [ $a <- A ] [ $b <- B ] [ $c <- ?C:Int ] </store>
+    ensures (?C ==Int A) orBool (?C ==Int B)
+

The program in question first assigns symbolic integers A and B to program
+variables $a and $b, respectively, and then executes the given if
+statement, which has a symbolic condition (A < B), updating the value of the
+program variable $c in both branches. The specification we give states that
+the if statement terminates, with $a and $b updated, respectively, to A
+and B, and $c updated to some symbolic integer value ?C. Via the
+ensures clause, which is used to specify additional constraints that hold
+after execution, we also state that this existentially quantified ?C equals
+either A or B.

+

Add the productions declaring $b and $c as tokens to the
+LESSON-22-SPEC-SYNTAX module, the claim to the LESSON-22-SPEC module, run
+the K prover again, and observe the output, which should not be #Top this
+time. This means that K was not able to prove the claim, and we now need to
+understand why. We do so by examining the output, which should look as follows:

+
    (InfoReachability) while checking the implication:
+    The configuration's term unifies with the destination's term,
+    but the implication check between the conditions has failed.
+
+  #Not (
+    #Exists ?C . {
+        STORE [ $a <- A:Int ] [ $b <- B:Int ] [ $c <- ?C:Int ]
+      #Equals
+        STORE [ $a <- A:Int ] [ $b <- B:Int ] [ $c <- B:Int ]
+    }
+  #And
+    {
+      true
+    #Equals
+      ?C ==Int A orBool ?C ==Int B
+    }
+  )
+#And
+  <generatedTop>
+    <k>
+      _DotVar1
+    </k>
+    <store>
+      STORE [ $a <- A:Int ] [ $b <- B:Int ] [ $c <- B:Int ]
+    </store>
+    <funcs>
+      _Gen3
+    </funcs>
+    <stack>
+      _Gen5
+    </stack>
+  </generatedTop>
+#And
+  {
+    true
+  #Equals
+    A <Int B
+  }
+

This output starts with a message telling us at which point the proof failed,
+followed by the final state, which consists of three parts: some negative
+Matching Logic (ML) constraints, the final configuration (<generatedTop> ... </generatedTop>), and some positive ML constraints. Generally speaking,
+these positive and the negative constraints could arise from various sources,
+such as (but not limited to) branches taken by the execution
+(e.g. { true #Equals A <Int B } or #Not ( { true #Equals A <Int B } )),
+or ensures constraints.

+

First, we examine the message:

+
(InfoReachability) while checking the implication:
+The configuration's term unifies with the destination's term,
+but the implication check between the conditions has failed.
+

which tells us that the structure of the final configuration is as expected,
+but that some of the associated constraints cannot be proven. We next look at
+the final configuration, in which the relevant item is the <store> ... </store> cell, because it is the only one that we are reasoning about. By
+inspecting its contents:

+
STORE [ $a <- A:Int ] [ $b <- B:Int ] [ $c <- B:Int ]
+

we see that we should be within the constraints of the ensures, since the
+value of $c in the store equals B in this branch. We next examine the
+negative and positive constraints of the output and, more often than not, the
+goal is to instruct K how to use the information from the final configuration
+and the positive constraints to falsify one of the negative constraints. This
+is done through simplifications.

+

So, the positive constraint that we have is

+
{ true #Equals A <Int B }
+

meaning that A <Int B holds. Given the analysed program, this tells us that
+we are in the then branch of the if. The negative constraint is

+
  #Not (
+    #Exists ?C . {
+        STORE [ $a <- A:Int ] [ $b <- B:Int ] [ $c <- ?C:Int ]
+      #Equals
+        STORE [ $a <- A:Int ] [ $b <- B:Int ] [ $c <- B:Int ]
+    }
+  #And
+    { true #Equals ?C ==Int A orBool ?C ==Int B }
+  )
+

and we observe, from the first equality, that the existential ?C should be
+instantiated with B. This would make both branches of the #And true,
+falsifying the outside #Not. We just need to show K how to conclude that
+?C ==Int B. We do so by introducing the following simplification into the
+VERIFICATION module:

+
rule { M:Map [ K <- V ] #Equals M [ K <- V' ] } => { V #Equals V' } [simplification]
+

which formalizes our internal understanding of ?C ==Int B. The rule states
+that when we update the same key in the same map with two values, and the
+resulting maps are equal, then the two values must be equal as well. The
+[simplification] attribute indicates to K to use this rule to simplify the
+state when trying to prove claims. Like function rules, simplification rules
+do not complete to the top of the configuration, but instead apply anywhere
+their left-hand-side matches. Re-run the K prover, which should now return
+#Top, indicating that K was able to use the simplification and prove the
+required claims.

+
    +
  1. Next, we show how to state and prove properties of while loops. In
    +particular, we consider the following loop
  2. +
+
claim
+    <k>
+        while ( 0 < $n ) {
+            $s = $s + $n;
+            $n = $n - 1;
+            } => . ...
+    </k>
+    <store>
+        $s |-> (S:Int => S +Int ((N +Int 1) *Int N /Int 2))
+        $n |-> (N:Int => 0)
+    </store>
+    requires N >=Int 0
+

which adds the sum of the first $n integers to $s, assuming the value of $n
+is non-negative to begin with. This is reflected in the store by stating that,
+after the execution of the loop, the original value of $s (which is set to
+equal some symbolic integer S) is incremented by ((N +Int 1) *Int N /Int 2), and the value of $n always equals 0. Add $n and $s as tokens in
+the LESSON-22-SPEC-SYNTAX module, the above claim to the LESSON-22-SPEC
+module, and run the K prover, which should return #Top.

+
    +
  1. Finally, our last claim is about a program that uses function calls:
  2. +
+
claim
+    <k>
+        def $sum($n, .Ids) {
+            $s = 0 ;
+            while (0 < $n) {
+                $s = $s + $n;
+                $n = $n - 1;
+            }
+            return $s;
+        }
+
+        $s = $sum(N:Int, .Ints);
+    => . ... </k>
+    <funcs> .Map => ?_ </funcs>
+    <store> $s |-> (_ => ((N +Int 1) *Int N /Int 2)) </store>
+    <stack> .List </stack>
+    requires N >=Int 0
+

Essentially, we have wrapped the while loop from claim 3.4 into a function
+$sum, and then called that function with a symbolic integer N, storing the
+return value in the variable $s. The specification states that this program
+ends up storing the sum of the first N integers in the variable $n. Add $sum
+to the LESSON-22-SPEC-SYNTAX module, the above claim to the
+LESSON-22-SPEC module, and run the K prover, which should again return
+#Top.

+

Exercises

+ +
    +
  1. +

    Change the condition of the if statement in part 3.2 to take the else
    +branch and adjust the claim so that the proof passes.

    +
  2. +
  3. +

    The post-condition of the specification in part 3.3 loses some information.
    +In particular, the value of ?C is in fact the maximum of A and B.
    +Prove the same claim as in 3.2, but with the post-condition ensures (?C ==Int maxInt(A, B)). For this, you will need to extend the VERIFICATION
    +module with two simplifications that capture the meaning of maxInt(A:Int, B:Int). Keep in mind that any rewriting rule can be used as a
    +simplification; in particular, that simplifications can have requires
    +clauses.

    +
  4. +
  5. +

    Following the pattern shown in part 3.4, assuming a non-negative initial
    +value of $b, specify and verify the following while loop:

    +
  6. +
+
while ( 0 < $b ) {
+    $a = $a + $c;
+    $b = $b - 1;
+    $c = $c - 1;
+}
+

Hint: You will not need additional simplifications---once you've got the
+specification right, the proof will go through.

+
    +
  1. Write an arbitrary yet not-too-complex function (or several functions
    +interacting with each other), and try to specify and verify it (them) in K.
  2. +
+

Section 2: Intermediate K Concepts

+ +

The goal of this second section is to supplement a beginning developer's
+knowledge of K after they have gained a basic understanding of K. Each lesson
+in this section can be completed independently in order to learn about a
+particular facet of the K language. The lessons are written to provide basic
+understanding of less commonly-used features of K to someone who is still
+learning K. For more complete references of these features, the reader ought to
+consult the User Manual.

+

The reader ought to be able to complete lessons in this section as needed in
+order to learn about specific features of interest, but if desired, can also
+complete the entire section in one go. Someone who has completed this entire
+section ought to be able to read and understand most K specifications, as well
+as write their own specifications of some complexity, and use them to perform
+most common K-related tasks. They can then read about specific lessons in
+Section 3: Advanced K Concepts if they want to
+learn more.

+

Table of Contents

+ +
    +
  1. Macros, Aliases, and Anywhere Rules
  2. +
  3. Fresh Constants
  4. +
  5. KLabels and Abstract Syntax
  6. +
  7. Overloaded Symbols
  8. +
  9. Matching Logic Connectives and #Or Patterns
  10. +
  11. Function Context
  12. +
  13. Record Productions and Named Nonterminals
  14. +
  15. #fun and #let
  16. +
  17. #as patterns
  18. +
  19. The Matching Operators, :=K and :/=K
  20. +
  21. Uncommon Evaluation Order Concepts
  22. +
  23. IEEE 754 Floating Point and Fixed Width Integers
  24. +
  25. Alpha-renaming-aware Substitution
  26. +
  27. File I/O
  28. +
  29. String Buffers and Byte Sequences
  30. +
  31. The Intermediate Language of K, KORE
  32. +
  33. Debugging Proofs using the Haskell Backend REPL
  34. +
+

Lesson 2.1: Macros, Aliases, and Anywhere Rules

+ +

The purpose of this lesson is to explain the behavior of the macro,
+macro-rec, alias, and alias-rec production attributes, as well as the
+anywhere rule attribute. These attributes control the meaning of how rules
+associated with them are applied.

+

Macros

+ +

Thus far in the K tutorial, we have described three different types of rules:

+
    +
  1. Top-level rewrite rules, which rewrite a configuration composed of cells to
    +another configuration;
  2. +
  3. Function rules, which define the behavior of a function written over
    +arbitrary input and output types; and
  4. +
  5. Simplification rules, which describe ways in which the symbolic execution
    +engine ought to simplify terms containing symbolic values.
  6. +
+

This lesson introduces three more types of rules, the first of which are
+macros. A production is a macro if it has the macro attribute, and all
+rules whose top symbol on the left hand side is a macro are macro rules
+which define the behavior of the macro. Like function rules and simplification
+rules, macro rules do not participate in cell completion. However, unlike
+function rules and simplification rules, macro rules are applied statically
+before rewriting begins, and the macro symbol is expected to no longer appear
+in the initial configuration for rewriting once all macros in that
+configuration are rewritten.

+

The rationale behind macros is they allow you to define one piece of syntax
+in terms of another piece of syntax without any runtime overhead associated
+with the cost of rewriting one to the other. This process is a common one in
+programming language design and specification and is referred to as
+desugaring; The syntax that is transformed is typically also referred to as
+syntactic sugar for another type of syntax. For example, in a language with
+if statements and curly braces, you could write the following fragment
+(lesson-01.k):

+
module LESSON-01
+  imports BOOL
+
+  syntax Stmt ::= "if" "(" Exp ")" Stmt             [macro]
+                | "if" "(" Exp ")" Stmt "else" Stmt
+                | "{" Stmts "}"
+  syntax Stmts ::= List{Stmt,""}
+  syntax Exp ::= Bool
+
+  rule if ( E ) S => if ( E ) S else { .Stmts }
+endmodule
+

In this example, we see that an if statement without an else clause is
+defined in terms of one with an else clause. As a result, we would only
+need to give a single rule for how to rewrite if statements, rather than
+two separate rules for two types of if statements. This is a common pattern
+for dealing with program syntax that contains an optional component to it.

+

It is worth noting that by default, macros are not applied recursively. To be
+more precise, by default a macro that arises as a result of the expansion of
+the same macro is not rewritten further. This is primarily to simplify the
+macro expansion process and reduce the risk that improperly defined macros will
+lead to non-terminating behavior.

+

It is possible, however, to tell K to expand a macro recursively. To do this,
+simply replace the macro attribute with the macro-rec attribute. Note that
+K does not do any kind of checking to ensure termination here, so it is
+important that rules be defined correctly to always terminate, otherwise the
+macro expansion phase will run forever. Fortunately, in practice it is very
+simple to ensure this property for most of the types of macros that are
+typically used in real-world semantics.

+

Exercise

+ +

Using a Nat sort containing the constructors 0 and S (i.e., a
+Peano-style axiomatization of the
+natural numbers where S(N) = N + 1, S(S(N)) = N + 2, etc), write a macro
+that will compute the sum of two numbers.

+

Aliases

+ +

NOTE: This lesson introduces the concept of "aliases", which are a variant
+of macros. While similar, this is different from the concept of "aliases" in
+matching logic, which is introduced in Lesson 2.16.

+

Macros can be very useful in helping you define a programming language.
+However, they can be disruptive while pretty printing a configuration. For
+example, you might write a set of macros that transforms the code the user
+wrote into equivalent code that is slightly harder to read. This can make it
+more difficult to understand the code when it is pretty printed as part of the
+output of rewriting.

+

K defines a relatively straightforward but novel solution to this problem,
+which is known as a K alias. An alias in K is very similar to a macro,
+with the exception that the rewrite rule will also be applied backwards
+during the pretty-printing process.

+

It is very simple to make a production be an alias instead of a macro: simply
+use the alias or alias-rec attributes instead of the macro or macro-rec
+attributes. For example, if the example involving if statements above was
+declared using an alias instead of a macro, the Stmt term if (E) {} else {}
+would be pretty-printed as if (E) {}. This is because during pretty-printing,
+the term participates in another macro-expansion pass. However, this macro
+expansion step will only apply rules with the alias or alias-rec attribute,
+and, critically, it will reverse the rule by treating the left-hand side as if
+it were the right-hand side, and vice versa.

+

This can be very useful to allow you to define one construct in terms of
+another while still being able to pretty-print the result as if it were
+the original term in question. This can be especially useful for applications
+of K where we are taking the output of rewriting and attempting to use it as
+a code fragment that we then execute, such as with test generation.

+

Exercise

+ +

Modify LESSON-01 above to use an alias instead of a macro and experiment
+with how various terms are pretty-printed by invoking krun on them.

+

anywhere rules

+ +

The last type of rule introduced in this lesson is the anywhere rule. An
+anywhere rule is specified by adding the anywhere attribute to a rule. Such a
+rule is similar to a function rule in that it does not participate in cell
+completion, and will apply anywhere that the left-hand-side matches in the
+configuration, but distinct in that the symbol in question can still be matched
+against in the left-hand side of other rules, even during concrete rewriting.
+The reasoning behind this is that instead of the symbol in question being a
+constructor, it is a constructor modulo the axioms defined with the
+anywhere attribute. Essentially, the rules with the anywhere attribute will
+apply as soon as they appear in the right-hand side of a rule being applied,
+but the symbol in question will still be treated as a symbol that can be
+matched on if it is not completely removed by those rules.

+

This can be useful in certain cases to allow you to define transformations over
+particular pieces of syntax while still generally giving those pieces of syntax
+another meaning when the anywhere rule does not apply. For example, the ISO C
+standard defines the semantics of *&x as exactly equal to x, with no
+reading or writing of memory taking place, and the K semantics of C implements
+this functionality using an anywhere rule that is applied at compilation time.

+

NOTE: the anywhere attribute is only implemented on the LLVM backend
+currently. Attempting to use it in a semantics that is compiled with the
+Haskell backend will result in an error being reported by the compiler. This
+should be remembered when using this attribute, as it may not be suitable for
+a segment of a semantics which is intended to be symbolically executed.

+

Exercises

+ +
    +
  1. Write a version of the calculator from Lesson 1.14 Exercise 1, which uses
    +the same syntax for evaluating expressions, but defines its arithmetic logic
    +using anywhere rules rather than top-level rewrite rules.
  2. +
+

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.2: Fresh Constants

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.3: KLabels and Abstract Syntax

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.4: Overloaded Symbols

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.5: Matching Logic Connectives and #Or Patterns

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.6: Function Context

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.7: Record Productions and Named Nonterminals

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.8: #fun and #let

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.9: #as Patterns

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.10: The Matching Operators, :=K and :/=K

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.11: Uncommon Evaluation Order Concepts

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.12: IEEE 754 Floating Point and Fixed Width Integers

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.13: Alpha-renaming-aware Substitution

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.14: File I/O

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.15: String Buffers and Byte Sequences

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.16: The Intermediate Language of K, KORE

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

Lesson 2.17: Debugging Proofs using the Haskell Backend REPL

+ +

Return to Top

+ +

Click here to return to the Table of Contents for Section 2.

+

K User Manual

+

NOTE: The K User Manual is still under construction; some features of K
+may have partial or missing documentation.

+

Introduction

+

Why K?

+ +

The K Framework is a programming language and system design toolkit made for
+practioners and researchers alike.

+

K For Practioners:
+K is a framework for deriving programming languages tools from their semantic
+specifications.

+

Typically, programming language tool development follows a similar pattern.
+After a new programming language is designed, separate teams will develop
+separate language tools (e.g. a compiler, interpreter, parser, symbolic
+execution engine, etc). Code reuse is uncommon. The end result is that for each
+new language, the same basic tools and patterns are re-implemented again and
+again.

+

K approaches the problem differently -- it generates each of these tools from a single language specification.
+The work of programming language design and tool implementation are made separate concerns.
+The end result is that the exercise of
+designing new languages and their associated tooling is now reduced to
+developing a single language specification from which we derive our tooling for
+free
.

+

K For Researchers:
+K is a configuration- and rewrite-based executable semantic framework.

+

In more detail, K specifications are:

+
    +
  1. Executable: compile into runnable and testable programs;
  2. +
  3. Semantic: correspond to a logical theory with a sound and relatively
    +complete proof system;
  4. +
  5. Configuration-based: organize system states into compositional,
    +hierarchical, labelled units called cells;
  6. +
  7. Rewrite-based: define system transitions using rewrite rules.
  8. +
+

K specifications are compiled into particular matching logic theories, giving
+them a simple and expressive semantics. K semantic rules are implicitly defined
+over the entire configuration structure, but omit unused cells, enabling a
+highly modular definitional style. Furthermore, K has been used to develop
+programming languages, type systems, and formal analysis tools.

+

Manual Objectives

+ +

As mentioned in the Why K? section above, the K Framework is designed as a
+collection of language-generic command-line interface (CLI) tools which revolve
+around K specifications. These tools cover a broad range of uses, but they
+typically fall into one of the following categories:

+
    +
  1. Transforming K Specs (e.g. compilation)
  2. +
  3. Running K Specs (e.g. concrete and symbolic execution)
  4. +
  5. Analyzing K Specs (e.g. theorem proving)
  6. +
+

The main user-facing K tools include:

+
    +
  • kompile - the K compiler driver
  • +
  • kparse - the stanadlone K parser and abstract syntax tree (AST)
    +transformation tool
  • +
  • krun - the K interpreter and symbolic execution engine driver
  • +
  • kprove - the K theorem prover
  • +
+

This user manual is designed to be a tool reference.
+In particular, it is not desgined to be a tutorial on how to write K
+specifications or to teach the logical foundations of K. New K users should
+consult our dedicated
+K tutorial,
+or the more language-design oriented
+PL tutorial.
+Researchers seeking to learn more about the logic underlying K are encouraged
+to peruse the
+growing literature on K and matching logic.
+We will consider the manual complete when it provides a complete description of
+all user-facing K tools and features.

+

Introduction to K

+

Since K specifications are the primary input into the entire system, let us
+take a moment to describe them. At the highest level, K specifications describe
+a programming language or system using three different pieces:

+
    +
  1. the system primitives, the base datatypes used during system operation,
    +e.g., numbers, lists, maps, etc;
  2. +
  3. the system state, a tuple or record over system primitives which gives a
    +complete snapshot of the system at any given moment;
  4. +
  5. the system behavior, a set of rules which defines possible system
    +evolutions.
  6. +
+

K specifications are then defined by a collection of sentences which
+correspond to the three concepts above:

+
    +
  1. syntax declarations encode the system primitives;
  2. +
  3. configuration declarations encode the system state;
  4. +
  5. context and rule declarations encode the system behavior.
  6. +
+

K sentences are then organized into one or modules which are stored in one or
+more files. In this scheme, files may require other files and modules may
+import other modules, giving rise to a hierarchy of files and modules. We
+give an intuitive sketch of the two levels of grouping in the diagram below:

+
   example.k file
+  +=======================+
+  | requires ".." --------|--> File_1
+  | ...                   |
+  | requires ".." --------|--> File_N
+  |                       |
+  |  +-----------------+  |
+  |  | module ..       |  |
+  |  |   imports .. ---|--|--> Module_1
+  |  |   ...           |  |
+  |  |   imports .. ---|--|--> Module_M
+  |  |                 |  |
+  |  |   sentence_1    |  |
+  |  |   ...           |  |
+  |  |   sentence_K    |  |
+  |  | endmodule       |  |
+  |  +-----------------+  |
+  |                       |
+  +=======================+
+

where:

+
    +
  • files and modules are denoted by double-bordered and single-borded boxes
    +respectively;
  • +
  • file or module identifiers are denoted by double dots (..);
  • +
  • potential repititions are denoted by triple dots (...).
  • +
+

In the end, we require that the file and module hierarchies both form a
+directed acyclic graph (DAG). This is, no file may recursively require itself,
+and likewise, no module may recursively import itself.

+

We now zoom in further to discuss the various kinds of sentences contained in K
+specifications:

+
    +
  1. +

    sentences that define our system's primitives, including:

    +
      +
    • sort declarations: define new categories of primitive datatypes
    • +
    • Backus-Naur Form (BNF) grammar declarations: define the
      +operators that inhabit our primitive datatypes
    • +
    • lexical syntax declarations: define lexemes/tokens for the
      +lexer/tokenizer
    • +
    • syntax associativity declarations: specify the
      +associativity/grouping of our declared operators
    • +
    • syntax priority declarations: specify the priority of
      +potential ambiguous operators
    • +
    +
  2. +
  3. +

    sentences that define our system's state, including:

    +
      +
    • configuration declarations: define labelled, hierarchical records
      +using an nested XML-like syntax
    • +
    +
  4. +
  5. +

    sentences that define our system's behavior, including:

    +
      +
    • context declarations: describe how primitives and configurations
      +can simplify
    • +
    • context alias declarations: define templates that can generate new
      +contexts
    • +
    • rule declarations: define how the system transitions from one state
      +to the next
    • +
    +
  6. +
+

K Process Overview

+ +

We now examine how the K tools are generally used. The main input to all of the
+K tools is a K specification. For effieciency reasons, this specification is
+first compiled into an intermediate representation called Kore. Once we have
+obtained this intermediate representation, we can use it to do:

+
    +
  1. parsing/pretty-printing, i.e., converting a K term, whose syntax is defined
    +by a K specification, into a alternate representation
  2. +
  3. concrete and abstract execution of a K specification
  4. +
  5. theorem proving, i.e., verifying whether a set of claims about a K
    +specification hold
  6. +
+

We represent the overall process using the graphic below:

+
 K Compilation Process
++============================================================+
+|                     +---------+                            |
+|  K Specification ---| kompile |--> Kore Specification --+  |
+|                     +---------+                         |  |
++=========================================================|==+
+                                                          |
+ K Execution Process                                      |
++=========================================================|==+
+|                                                         |  |
+|             +-------------------------------------------+  |
+|             |                                              |
+|             |       +---------+                            |
+|  K Term ----+-------| kparse  |--> K Term                  |
+|             |       +---------+                            |
+|             |                                              |
+|             |       +---------+                            |
+|  K Term ----+-------|  krun   |--> K Term                  |
+|             |       +---------+                            |
+|             |                                              |
+|             |       +---------+                            |
+|  K Claims --+-------| kprove  |--> K Claims                |
+|                     +---------+                            |
+|                                                            |
++============================================================+
+

where:

+
    +
  • process outlines are denoted by boxes with double-lined borders
  • +
  • executables are denoted by boxes with single-lined borders
  • +
  • inputs and outputs are denoted by words attached to lines
  • +
  • K terms typically correspond to programs defined in a particular
    +language's syntax (which are either parsed using kparse or executed using
    +krun)
  • +
  • K claims are a notation for describing how certain K programs should
    +execute (which are checked by our theorem prover kprove)
  • +
+

K Compilation Process:
+Let us start with a description of the compilation process. According to the
+above diagram, the compiler driver is called kompile. For our purposes, it is
+enough to view the K compilation process as a black box that transforms a K
+specification into a lower-level Kore specification that encodes the same
+information, but that is easier to work with programmatically.

+

K Execution Process:
+We now turn our attention to the K execution process. Abstractly, we can divide
+the K execution process into the following stages:

+
    +
  1. the kore specification is loaded (which defines a lexer, parser, and
    +unparser among other things)
  2. +
  3. the input string is lexed into a token stream
  4. +
  5. the token stream is parsed into K terms/claims
  6. +
  7. the K term/claims are transformed according the K tool being used (e.g.
    +kparse, krun, or kprove)
  8. +
  9. the K term/claims are unparsed into a string form and printed
  10. +
+

Note that all of the above steps performed in K execution process are fully
+prescribed by the input K specification. Of course, there are entire languages
+devoted to encoding these various stages proces individually, e.g., flex for
+lexers, bison for parsers, etc. What K offers is a consistent language to
+package the above concepts in a way that we believe is convenient and practical
+for a wide range of uses.

+

Module Declaration

+

K modules are declared at the top level of a K file. They begin with the
+module keyword and are followed by a module ID and an optional set of
+attributes. They continue with zero or more imports and zero or more sentences
+until the endmodule keyword is reached.

+

A module ID consists of an optional # at the beginning, followed by one or
+more components separated by hyphens. Each component can contain letters,
+numbers, or underscores.

+

After the module ID, attributes can be specified in square brackets. See below
+for an (incomplete) list of allowed module attributes.

+

Following the attributes, a module can contain zero or more imports. An
+import consists of the import or imports keywords followed by a module ID.
+An import tells the compiler that this module should contain all the sentences
+(recursively) contained by the module being imported.

+

Imports can be public or private. By default, they are public, which
+means that all the imported syntax can be used by any module that imports the
+module doing the import. However, you can explicitly override the visibility
+of the import with the public or private keyword immediately prior to the
+module name. A module imported privately does not export its syntax to modules
+that import the module doing the import.

+

Following imports, a module can contain zero or more sentences. A sentence can
+be a syntax declaration, a rule, a configuration declaration, a context, a
+claim, or a context alias. Details on each of these can be found in subsequent
+sections.

+

private attribute

+ +

If the module is given the private attribute, all of its imports and syntax
+are private by default. Individual pieces of syntax can be made public with
+the public attribute, and individual imports can be made public with the
+public keyword. See relevant sections on syntax and modules for more details
+on what it means for syntax and imports to be public or private.

+

symbolic and concrete attribute

+ +

These attributes may be placed on modules to indicate that they should only
+be used by the Haskell and LLVM backends respectively. If the definition is
+compiled on the opposite backend, they are implicitly removed from the
+definition prior to parsing anywhere they are imported. This can be useful when
+used in limited capacity in order to provide alternate semantics for certain
+features on different backends. It should be used sparingly as it makes it more
+difficult to trust the correctness of your semantics, even in the presence of
+testing.

+

Syntax Declaration

+

Named Non-Terminals

+ +

We have added a syntax to Productions which allows non-terminals to be given a
+name in productions. This significantly improves the ability to document K, by
+providing a way to explicitly explain what a field in a production corresponds
+to instead of having to infer it from a comment or from the rule body.

+

The syntax is:

+
name: Sort
+

This syntax can be used anywhere in a K definition that expects a non-terminal.

+

klabel(_) and symbol attributes

+ +

By default K generates for each syntax definition a long and obfuscated klabel
+string, which serves as a unique internal identifier and also is used in kast
+format of that syntax. If we need to reference a certain syntax production
+externally, we have to manually define the klabels using the klabel attribute.
+One example of where you would want to do this is to be able to refer to a given
+symbol via the syntax priorities attribute, or to enable overloading of a
+given symbol.

+

If you only provide the klabel attribute, you can use the provided klabel to
+refer to that symbol anywhere in the frontend K code. However, the internal
+identifier seen by the backend for that symbol will still be the long obfuscated
+generated string. Sometimes you want control over the internal identfier used as
+well, in which case you use the symbol attribute. This tells the frontend to
+use whatever the declared klabel is directly as the internal identfier.

+

For example:

+
module MYMODULE
+    syntax FooBarBaz ::= #Foo( Int, Int ) [klabel(#Foo), symbol] // symbol1
+                       | #Bar( Int, Int ) [klabel(#Bar)]         // symbol2
+                       | #Baz( Int, Int )                        // symbol3
+endmodule
+

Here, we have that:

+
    +
  • In frontend K, you can refer to "symbol1" as #Foo (from klabel(#Foo)),
    +and the backend will see 'Hash'Foo as the symbol name.
  • +
  • In frontend K, you can refer to "symbol2" as #Bar (from klabel(#Bar)),
    +and the backend will see
    +'Hash'Bar'LParUndsCommUndsRParUnds'MYMODULE'Unds'FooBarBaz'Unds'Int'Unds'Int
    +as the symbol name.
  • +
  • In frontend K, you can refer to "symbol3" as
    +#Baz(_,_)_MYMODULE_FooBarBaz_Int_Int (from auto-generated klabel), and
    +the backend will see
    +'Hash'Baz'LParUndsCommUndsRParUnds'MYMODULE'Unds'FooBarBaz'Unds'Int'Unds'Int
    +as the symbol name.
  • +
+

The symbol provided must be unique to this definition. This is enforced by K.
+In general, it's recommended to use symbol attribute whenever you use klabel
+unless you explicitely have a reason not to (eg. you want to overload symbols,
+or you're using a deprecated backend). It can be very helpful use the symbol
+attribute for debugging, as many debugging messages are printed in Kast format
+which will be more readable with the symbol names you explicitely declare.
+In addition, if you are programatically manipulating definitions via the JSON
+Kast format, building terms using the user-provided pretty
+symbol, klabel(...) is easier and less error-prone when the auto-generation
+process for klabels changes.

+

Parametric productions and bracket attributes

+ +

Some syntax productions, like the rewrite operator, the bracket operator, and
+the #if #then #else #fi operator, cannot have their precise type system
+expressed using only concrete sorts.

+

Prior versions of K solved this issue by using the K sort in this case, but
+this introduces inexactness in which poorly typed terms can be created even
+without having a cast operator present in the syntax, which is a design
+consideration we would prefer to avoid.

+

It also introduces cases where terms cannot be placed in positions where they
+ought to be well sorted unless their return sort is made to be KBott, which in
+turn vastly complicates the grammar and makes parsing much slower.

+

In order to introduce this, we provide a new syntax for parametric productions
+in K. This allows you to express syntax that has a sort signature based on
+parametric polymorphism. We do this by means of an optional curly-brace-
+enclosed list of parameters prior to the return sort of a production.

+

Some examples:

+
syntax {Sort} Sort ::= "(" Sort ")" [bracket]
+syntax {Sort} KItem ::= Sort
+syntax {Sort} Sort ::= KBott
+syntax {Sort} Sort ::= Sort "=>" Sort
+syntax {Sort} Sort ::= "#if" Bool "#then" Sort "#else" Sort "#fi"
+syntax {Sort1, Sort2} Sort1 ::= "#fun" "(" Sort2 "=>" Sort1 ")" "(" Sort2 ")"
+

Here we have:

+
    +
  1. Brackets, which can enclose any sort but should be of the same sort that was
    +enclosed.
  2. +
  3. Every sort is a KItem.
  4. +
  5. A KBott term can appear inside any sort.
  6. +
  7. Rewrites, which can rewrite a value of any sort to a value of the same sort.
    +Note that this allows the lhs or rhs to be a subsort of the other.
  8. +
  9. If then else, which can return any sort but which must contain that sort on
    +both the true and false branches.
  10. +
  11. lambda applications, in which the argument and parameter must be the same
    +sort, and the return value of the application must be the same sort as the
    +return value of the function.
  12. +
+

Note the last case, in which two different parameters are specified separated
+by a comma. This indicates that we have multiple independent parameters which
+must be the same each place they occur, but not the same as the other
+parameters.

+

In practice, because every sort is a subsort of K, the Sort2
+parameter in #6 above does nothing during parsing. It cannot
+actually reject any parse, because it can always infer that the sort of the
+argument and parameter are K, and it has no effect on the resulting sort of
+the term. However, it will nevertheless affect the kore generated from the term
+by introducing an additional parameter to the symbol generated for the term.

+

function and total attributes

+ +

Many times it becomes easier to write a semantics if you have "helper"
+functions written which can be used in the RHS of rules. The function
+attribute tells K that a given symbol should be simplified immediately when it
+appears anywhere in the configuration. Semantically, it means that evaluation
+of that symbol will result in at most one return value (that is, the symbol is
+a partial function).

+

The total attribute indicates that a symbol cannot be equal to matching logic
+bottom; in other words, it has at least one value for every possible set of
+arguments. It can be added to a production with the function attribute to
+indicate to the symbolic reasoning engine that a given symbol is a
+total function, that is it has exactly one return value for every possible
+input. Other uses of the total attribute (i.e., on multi-valued symbols to
+indicate they always have at least one value) are not yet implemented.

+

For example, here we define the _+Word_ total function and the _/Word_
+partial function, which can be used to do addition/division modulo
+2 ^Int 256. These functions can be used anywhere in the semantics where
+integers should not grow larger than 2 ^Int 256. Notice how _/Word_ is
+not defined when the denominator is 0.

+
syntax Int ::= Int "+Word" Int [function, total]
+             | Int "/Word" Int [function]
+
+rule I1 +Word I2 => (I1 +Int I2) modInt (2 ^Int 256)
+rule I1 /Word I2 => (I1 /Int I2) modInt (2 ^Int 256) requires I2 =/=Int 0
+

freshGenerator attribute

+ +

In K, you can access "fresh" values in a given domain using the syntax
+!VARNAME:VarSort (with the !-prefixed variable name). This is supported for
+builtin sorts Int and Id already. For example, you can generate fresh
+memory locations for declared identifiers as such:

+
rule <k> new var x ; => . ... </k>
+     <env> ENV => ENV [ x <- !I:Int ] </env>
+     <mem> MEM => MEM [ !I <- 0     ] </mem>
+

Each time a !-prefixed variable is encountered, a new integer will be used,
+so each variable declared with new var _ ; will get a unique position in the
+<mem>.

+

Sometimes you want to have generation of fresh constants in a user-defined
+sort. For this, K will still generate a fresh Int, but can use a converter
+function you supply to turn it into the correct sort. For example, here we can
+generate fresh Foos using the freshFoo(_) function annotated with
+freshGenerator.

+
syntax Foo ::= "a" | "b" | "c" | d ( Int )
+
+syntax Foo ::= freshFoo ( Int ) [freshGenerator, function, total]
+
+rule freshFoo(0) => a
+rule freshFoo(1) => b
+rule freshFoo(2) => c
+rule freshFoo(I) => d(I) [owise]
+
+rule <k> new var x ; => . ... </k>
+     <env> ENV => ENV [ x <- !I:Int  ] </env>
+     <mem> MEM => MEM [ !I <- !F:Foo ] </mem>
+

Now each newly allocated memory slot will have a fresh Foo placed in it.

+

token attribute

+ +

The token attribute signals to the Kore generator that the associated sort
+will be inhabited by domain values. Sorts inhabited by domain values must not
+have any constructors declared.

+
syntax Bytes [hook(BYTES.Bytes), token]
+

Converting between [token] sorts

+ +

You can convert between tokens of one sort via Strings by defining functions
+implemented by builtin hooks.
+The hook STRING.token2string allows conversion of any token to a string:

+
syntax String ::= FooToString(Foo)  [function, total, hook(STRING.token2string)]
+

Similarly, the hook STRING.string2Token allows the inverse:

+
syntax Bar ::= StringToBar(String) [function, total, hook(STRING.string2token)]
+

WARNING: This sort of conversion does NOT do any sort of parsing or validation.
+Thus, we can create arbitary tokens of any sort:

+
StringToBar("The sun rises in the west.")
+

Composing these two functions lets us convert from Foo to Bar

+
syntax Bar ::= FooToBar(Foo) [function]
+rule FooToBar(F) => StringToBar(FooToString(F))
+

Parsing comments, and the #Layout sort

+ +

Productions for the #Layout sort are used to describe tokens that are
+considered "whitespace". The scanner removes tokens matching these productions
+so they are not even seen by the parser. Below, we use it to define
+lines begining with ; (semicolon) as comments.

+
syntax #Layout ::= r"(;[^\\n\\r]*)"    // Semi-colon comments
+                 | r"([\\ \\n\\r\\t])" // Whitespace
+

prec attribute

+ +

Consider the following naive attempt at creating a language what syntax that
+allows two types of variables: names that contain underbars, and names that
+contain sharps/hashes/pound-signs:

+
syntax NameWithUnderbar ::= r"[a-zA-Z][A-Za-z0-9_]*"  [token]
+syntax NameWithSharp    ::= r"[a-zA-Z][A-Za-z0-9_#]*" [token]
+syntax Pgm ::= underbar(NameWithUnderbar)
+             | sharp(NameWithSharp)
+

Although, it seems that K has enough information to parse the programs
+underbar(foo) and sharp(foo) with, the lexer does not take into account
+whether a token is being parsed for the sharp or for the underbar
+production. It chooses an arbitary sort for the token foo (perhaps
+NameWithUnderbar). Thus, during paring it is unable to construct a valid term
+for one of those programs (sharp(foo)) and produces the error message:
+Inner Parser: Parse error: unexpected token 'foo'.

+

Since calculating inclusions and intersections between regular expressions is
+tricky, we must provide this information to K. We do this via the prec(N)
+attribute. The lexer will always prefer longer tokens to shorter tokens.
+However, when it has to choose between two different tokens of equal length,
+token productions with higher precedence are tried first. Note that the default
+precedence value is zero when the prec attribute is not specified.

+

For example, the BUILTIN-ID-TOKENS module defines #UpperId and #LowerId with
+the prec(2) attribute.

+
  syntax #LowerId ::= r"[a-z][a-zA-Z0-9]*"                    [prec(2), token]
+  syntax #UpperId ::= r"[A-Z][a-zA-Z0-9]*"                    [prec(2), token]
+

Furthermore, we also need to make sorts with more specific tokens subsorts of ones with more
+general tokens. We add the token attribute to this production so that all
+tokens of a particular sort are marked with the sort they are parsed as and not a
+subsort thereof. e.g. we get underbar(#token("foo", "NameWithUnderbar"))
+instead of underbar(#token("foo", "#LowerId"))

+
imports BUILTIN-ID-TOKENS
+syntax NameWithUnderbar ::= r"[a-zA-Z][A-Za-z0-9_]*" [prec(1), token]
+                          | #UpperId                [token]
+                          | #LowerId                [token]
+syntax NameWithSharp ::= r"[a-zA-Z][A-Za-z0-9_#]*" [prec(1), token]
+                       | #UpperId                 [token]
+                       | #LowerId                 [token]
+syntax Pgm ::= underbar(NameWithUnderbar)
+             | sharp(NameWithSharp)
+

unused attribute

+ +

K will warn you if you declare a symbol that is not used in any of the rules of
+your definition. Sometimes this is intentional, however; in this case, you can
+suppress the warning by adding the unused attribute to the production or
+cell.

+
syntax Foo ::= foo() [unused]
+
+configuration <foo unused=""> .K </foo>
+

Symbol priority and associativity

+ +

Unlike most other parser generators, K combines the task of parsing with AST
+generation. A production declared with the syntax keyword in K is both a
+piece of syntax used when parsing, and a symbol that is used when rewriting.
+As a result, it is generally convenient to describe expression grammars using
+priority and associativity declarations rather than explicitly transforming
+your grammar into a series of nonterminals, one for each level of operator
+precedence. Thus, for example, a simple grammar for addition and multiplication
+will look like this:

+
syntax Exp ::= Exp "*" Exp
+             | Exp "+" Exp
+

However, this grammar is ambiguous. The term x+y*z might refer to x+(y*z)
+or to (x+y)*z. In order to differentiate this, we introduce a partial
+ordering between productions known as priority. A symbol "has tighter priority"
+than another symbol if the first symbol can appear under the second, but the
+second cannot appear under the first without a bracket. For example, in
+traditional arithmetic, multiplication has tighter priority than addition,
+which means that x+y*z cannot parse as (x+y)*z because the addition
+operator would appear directly beneath the multiplication, which is forbidden
+by the priority filter.

+

Priority is applied individually to each possible ambiguous parse of a term. It
+then either accepts or rejects that parse. If there is only a single remaining
+parse (after all the other disambiguation steps have happened), this is the
+parse that is chosen. If all the parses were rejected, it is a parse error. If
+multiple parses remain, they might be resolved by further disambiguation such
+as via the prefer and avoid attributes, but if multiple parses remain after
+disambiguation finishes, this is an ambiguous parse error, indicating there is
+not a unique parse for that term. In the vast majority of cases, this is
+an error and indicates that you ought to either change your grammar or add
+brackets to the term in question.

+

Priority is specified in K grammars by means of one of two different
+mechanisms. The first, and simplest, simply replaces the | operator in a
+sequence of K productions with the > operator. This operator indicates that
+everything prior to the > operator (including transitively) binds tighter
+than what comes after. For example, a more complete grammar for simple
+arithmetic might be:

+
syntax Exp ::= Exp "*" Exp
+             | Exp "/" Exp
+             > Exp "+" Exp
+             | Exp "-" Exp
+

This indicates that multiplication and division bind tigher than addition
+and subtraction, but that there is no relationship in priority between
+multiplication and division.

+

As you may have noticed, this grammar is also ambiguous. x*y/z might refer to
+x*(y/z) or to (x*y)/z. Indeed, if we removed division and subtraction
+entirely, the grammar would still be ambiguous: x*y*z might parse as
+x*(y*z), or as (x*y)*z. To resolve this, we introduce another feature:
+associativity. Roughly, asssociativity tells us how symbols are allowed to nest
+within other symbols with the same priority. If a set of symbols is left
+associative, then symbols in that set cannot appear as the rightmost child
+of other symbols in that set. If a set of symbols is right associative, then
+symbols in that set cannot appear as the leftmost child of other symbols in
+that set. Finally, if a set of symbols is non-associative, then symbols
+in that set cannot appear as the rightmost or leftmost child of other symbols
+in that set. For example, in the above example, if addition and subtraction
+are left associative, then x+y+z will parse as (x+y)+z and x+y-z will
+parse as (x+y)-z (because the other parse will have been rejected).

+

You might notice that this seems to apply only to binary infix operators. In
+fact, the real behavior is slightly more complicated. Priority and
+associativity (for technical reasons that go beyond the scope of this document)
+really only apply when the rightmost or leftmost item in a production is a
+nonterminal. If the rightmost nonterminal is followed by a terminal (or
+respectively the leftmost preceded), priority and associativity do not apply.
+Thus we can generalize these concepts to arbitrary context-free grammars.

+

Note that in some cases, this is not the behavior you want. You may actually
+want to reject parses even though the leftmost and rightmost item in a
+production are terminals. You can accomplish this by means of the
+applyPriority attribute. When placed on a production, it tells the parser
+which nonterminals of a production the priority filter ought to reject children
+under, overriding the default behavior. For example, I might have a production
+like syntax Exp ::= foo(Exp, Exp) [applyPriority(1)]. This tells the parser
+to reject terms with looser priority binding under the first Exp, but not
+the second. By default, with this production, neither position would apply
+to the priority filter, because the first and last items of the production
+are both terminals.

+

Associativity is specified in K grammars by means of one of two different
+mechanisms. The first, and simplest, adds the associativity of a priority block
+of symbols prior to that block. For example, we can remove the remaining
+ambiguities in the above grammar like so:

+
syntax Exp ::= left:
+               Exp "*" Exp
+             | Exp "/" Exp
+             > right:
+               Exp "+" Exp
+             | Exp "-" Exp
+

This indicates that multiplication and division are left-associative, ie, after
+symbols with higher priority are parsed as innermost, symbols are nested with
+the rightmost on top. Addition and subtraction are right associative, which
+is the opposite and indicates that symbols are nested with the leftmost on top.
+Note that this is similar but different from evaluation order, which also
+concerns itself with the ordering of symbols, which is described in the next
+section.

+

You may note we have not yet introduced the second syntax for priority
+and associativity. In some cases, syntax for a grammar might be spread across
+multiple modules, sometimes for very good reasons with respect to code
+modularity. As a result, it becomes infeasible to declare priority and
+associativity inline within a set of productions, because the productions
+are not contiguous within a single file.

+

For this purpose, we introduce the equivalent syntax priorities,
+syntax left, syntax right, and syntax non-assoc declarations. For
+example, the above grammar can be written equivalently as:

+
syntax Exp ::= Exp "*" Exp [group(mult)]
+             | Exp "/" Exp [group(div)]
+             | Exp "+" Exp [group(add)]
+             | Exp "-" Exp [group(sub)]
+
+syntax priorities mult div > add sub
+syntax left mult div
+syntax right add sub
+

Here, the group(_) attribute is used to create user-defined groups of
+sentences. A particular group name collectively refers to the whole set of
+sentences within that group. The sets are flattened together, so we could
+equivalently have written:

+
syntax Exp ::= Exp "*" Exp [group(mult)]
+             | Exp "/" Exp [group(mult)]
+             | Exp "+" Exp [group(add)]
+             | Exp "-" Exp [group(add)]
+
+syntax priorities mult > add
+syntax left mult
+syntax right add
+

Note that syntax [left|right|non-assoc] should not be used to group together
+productions with different priorities. For example, this code would be invalid:

+
syntax priorities mult > add
+syntax left mult add
+

Note that there is one other way to describe associativity, but it is
+prone to a very common mistake. You can apply the attribute left, right,
+or non-assoc directly to a production to indicate that it is, by itself,
+left-, right-, or non-associative.

+

However, this often does not mean what users think it means. In particular:

+
syntax Exp ::= Exp "+" Exp [left]
+             | Exp "-" Exp [left]
+

is not equivalent to:

+
syntax Exp ::= left:
+               Exp "+" Exp
+             | Exp "-" Exp
+

Under the first, each production is associative with itself, but not each
+other. Thus, x+y+z will parse unambiguously as (x+y)+z, but x+y-z will
+be ambiguous. However, in the second, x+y-z will parse unambiguously as
+(x+y)-z.

+

Think carefully about how you want your grammar to parse. In general, if you're
+not sure, it's probably best to group associativity together into the same
+blocks you use for priority, rather than using left, right, or non-assoc
+attributes on the productions.

+

Lexical identifiers

+ +

Sometimes it is convenient to be able to give a certain regular expression a
+name and then refer to it in one or more regular expression terminals. This
+can be done with a syntax lexical sentence in K:

+
syntax lexical Alphanum = r"[0-9a-zA-Z]"
+

This defines a lexical identifier Alphanum which can be expanded in any
+regular expression terminal to the above regular expression. For example, I
+might choose to then implement the syntax of identifiers as follows:

+
syntax Id ::= r"[a-zA-Z]{Alphanum}*" [token]
+

Here {Alphanum} expands to the above regular expression, making the sentence
+equivalent to the following:

+
syntax Id ::= r"[a-zA-Z]([0-9a-zA-Z])*" [token]
+

This feature can be used to more modularly construct the lexical syntax of your
+language. Note that K does not currently check that lexical identifiers used
+in regular expressions have been defined; this will generate an error when
+creating the scanner, however, and the user ought to be able to debug what
+happened.

+

assoc, comm, idem, and unit attributes

+ +

These attributes are used to indicate whether a collection or a production
+is associative, commutative, idempotent, and/or has a unit.
+In general, you should not need to apply these attributes to productions
+yourself, however, they do have certain special meaning to K. K will generate
+axioms related to each of these concepts into your definition for you
+automatically. It will also automatically sort associative-commutative
+collections, and flatten the indentation of associative collections, when
+unparsing.

+

public and private attribute

+ +

K allows users to declare certain pieces of syntax as either public or private.
+All syntax is public by default. Public syntax can be used from any module that
+imports that piece of syntax. A piece of syntax can be declared private with
+the private attribute. This means that that syntax can only be used in the
+module in which it is declared; it is not visible from modules that import
+that module.

+

You can also change the default visibility of a module with the private
+attribute, when it is placed directly on a module. A module with the private
+attribute has all syntax private by default; this can be overridden on
+specific sentences with the public attribute.

+

Note that the private module attribute also changes the default visiblity
+of imports; please refer to the appropriate section elsewhere in the manual
+for more details.

+

Here is an example usage:

+
module WIDGET-SYNTAX
+
+  syntax Widget ::= foo()
+  syntax WidgetHelper ::= bar() [private] // this production is not visible
+                                          // outside this module
+endmodule
+
+module WIDGET [private]
+  imports WIDGET-SYNTAX
+
+  syntax Widget ::= fooImpl() // this production is not visible outside this
+                              // module
+
+  // this production is visible outside this module
+  syntax KItem ::= adjustWidget(Widget) [function, public]
+endmodule
+

Configuration Declaration

+

exit attribute

+ +

A single configuration cell containing an integer may have the "exit"
+attribute. This integer will then be used as the return value on the console
+when executing the program.

+

For example:

+
configuration <k> $PGM:Pgm </k>
+              <status-code exit=""> 1 </status-code>
+

declares that the cell status-code should be used as the exit-code for
+invocations of krun. Additionally, we state that the default exit-code is 1
+(an error state). One use of this is for writing testing harnesses which assume
+that the test fails until proven otherwise and only set the <status-code> cell
+to 0 if the test succeeds.

+

Collection Cells: multiplicity and type attributes

+ +

Sometimes a semantics needs to allow multiple copies of the same cell, for
+example if you are making a concurrent multi-threading programming language.
+For this purpose, K supports the multiplicity and type attributes on cells
+declared in the configuration.

+

multiplicity can take on values * and ?. Declaring multiplicity="*"
+indicates that the cell may appear any number of times in a runtime
+configuration. Setting multiplicity="?" indicates that the cell may only
+appear exactly 0 or 1 times in a runtime configuration. If there are no
+configuration variables present in the cell collection, the initial
+configuration will start with exactly 0 instances of the cell collection. If
+there are configuration variables present in the cell collection, the initial
+configuration will start with exactly 1 instance of the cell collection.

+

type can take on values Set, List, and Map. For example, here we declare
+several collecion cells:

+
configuration <k> $PGM:Pgm </k>
+              <sets>  <set  multiplicity="?" type="Set">  0:Int </set>  </sets>
+              <lists> <list multiplicity="*" type="List"> 0:Int </list> </lists>
+              <maps>
+                <map multiplicity="*" type="Map">
+                  <map-key> 0:Int </map-key>
+                  <map-value-1> "":String </map-value-1>
+                  <map-value-2> 0:Int     </map-value-2>
+                </map>
+              </maps>
+

Declaring type="Set" indicates that duplicate occurrences of the cell should
+be de-duplicated, and accesses to instances of the cell will be nondeterministic
+choices (constrained by any other parts of the match and side-conditions).
+Similarly, declaring type="List" means that new instances of the cell can be
+added at the front or back, and elements can be accessed from the front or back,
+and the order of the cells will be maintained. The following are examples of
+introduction and elimination rules for these collections:

+
rule <k> introduce-set(I:Int) => . ... </k>
+     <sets> .Bag => <set> I </set> </sets>
+
+rule <k> eliminate-set => I ... </k>
+     <sets> <set> I </set> => .Bag </sets>
+
+rule <k> introduce-list-start(I:Int) => . ... </k>
+     <lists> (.Bag => <list> I </list>) ... </lists>
+
+rule <k> introduce-list-end(I:Int) => . ... </k>
+     <lists> ... (.Bag => <list> I </list>) </lists>
+
+rule <k> eliminate-list-start => I ... </k>
+     <lists> (<list> I </list> => .Bag) ... </lists>
+
+rule <k> eliminate-list-end => I ... </k>
+     <lists> ... (<list> I </list> => .Bag) </lists>
+

Notice that for multiplicity="?", we only admit a single <set> instance at
+a time. For the type=List cell, we can add/eliminate cells from the from or
+back of the <lists> cell. Also note that we use .Bag to indicate the empty
+cell collection in all cases.

+

Declaring type="Map" indicates that the first sub-cell will be used as a
+cell-key. This means that matching on those cells will be done as a map-lookup
+operation if the cell-key is mentioned in the rule (for performance). If the
+cell-key is not mentioned, it will fallback to normal nondeterministic
+constrained by other parts of the match and any side-conditions. Note that there
+is no special meaning to the name of the cells (in this case <map>,
+<map-key>, <map-value-1>, and <map-value-2>). Additionally, any number of
+sub-cells are allowed, and the entire instance of the cell collection is
+considered part of the cell-value, including the cell-key (<map-key> in this
+case) and the surrounding collection cell (<map> in this case).

+

For example, the following rules introduce, set, retrieve from, and eliminate
+type="Map" cells:

+
rule <k> introduce-map(I:Int) => . ... </k>
+     <maps> ... (.Bag => <map> <map-key> I </map-key> ... </map>) ... </maps>
+
+rule <k> set-map-value-1(I:Int, S:String) => . ... </k>
+     <map> <map-key> I </map-key> <map-value-1> _ => S </map-value-1> ... </map>
+
+rule <k> set-map-value-2(I:Int, V:Int) => . ... </k>
+     <map> <map-key> I </map-key> <map-value-2> _ => V </map-value-2> ... </map>
+
+rule <k> retrieve-map-value-1(I:Int) => S ... </k>
+     <map> <map-key> I </map-key> <map-value-1> S </map-value-1> ... </map>
+
+rule <k> retrieve-map-value-2(I:Int) => V ... </k>
+     <map> <map-key> I </map-key> <map-value-2> V </map-value-2> ... </map>
+
+rule <k> eliminate-map(I:Int) => . ... </k>
+     <maps> ... (<map> <map-key> I </map-key> ... </map> => .Bag) ... </maps>
+

Note how each rule makes sure that <map-key> cell is mentioned, and we
+continue to use .Bag to indicate the empty collection. Also note that
+when introducing new map elements, you may omit any of the sub-cells which are
+not the cell-key. In case you do omit sub-cells, you must use structural
+framing ... to indicate the missing cells, they will receive the default
+value given in the configuration ... declaration.

+

Rule Declaration

+

Rule Structure

+ +

Each K rule follows the same basic structure (given as an example here):

+
rule LHS => RHS requires REQ ensures ENS [ATTRS]
+

The portion between rule and requires is referred to as the rule body,
+and may contain one or more rewrites (though not nested). Here, the rule body is
+LHS => RHS, where LHS and RHS are used as placeholders for the pre- and
+post- states. Note that we lose no generality referring to the LHS or the
+RHS, even in the presence of multiple rewrites, as the rewrites are pulled to
+the top-level anyway.

+

Next is the requires clause, represented here as REQ. The requires clause is
+an additional predicate (function-like term of sort Bool), which is to be
+evaluated before applying the rule. If the requires clause does not evaluate to
+true, then the rule does not apply.

+

Finally is the ensures clause, represented here as ENS. The ensures clause
+is to be interpreted as a post-condition, and will be automatically added to the
+path condition if the rule applies. It may cause the entire term to become
+undefined, but the backend will not stop itself from applying the rule in this
+case. Note that concrete backends (eg. the LLVM backend) are free to ignore the
+ensures clause.

+

Overall, the transition represented by such a rule is from a state
+LHS #And REQ ending in a state RHS #And ENS. When backends apply this rule
+as a transition/rewrite, they should:

+
    +
  • Check if pattern LHS matches (or unifies) with the current term, giving
    +substitution alpha.
  • +
  • Check if the instantiation alpha(REQ) is valid (or satisfiable).
  • +
  • Build the new term alpha(RHS #And ENS), and check if it's satisfiable.
  • +
+

Pattern Matching operator

+ +

Sometimes when you want to express a side condition, you want to say that a
+rule matches if a particular term matches a particular pattern, or if it
+instead does /not/ match a particular pattern.

+

The syntax in K for this is :=K and :/=K. It has similar meaning to ==K and
+=/=K, except that where ==K and =/=K express equality, :=K and =/=K express
+model membership. That is to say, whether or not the rhs is a member of the set
+of terms expressed by the lhs pattern. Because the lhs of these operators is a
+pattern, the user can use variables in the lhs of the operator. However, due to
+current limitations, these variables are NOT bound in the rest of the term.
+The user is thus encouraged to use anonymous variables only, although this is
+not required.

+

This is compiled by the K frontend down to an efficient pattern matching on a
+fresh function symbol.

+

Anonymous function applications

+ +

There are a number of cases in K where you would prefer to be able to take some
+term on the RHS, bind it to a variable, and refer to it in multiple different
+places in a rule.

+

You might also prefer to take a variable for which you know some of its
+structure, and modify some of its internal structure without requiring you to
+match on every single field contained inside that structure.

+

In order to do this, we introduce syntax to K that allows you to construct
+anonymous functions in the RHS of a rule and apply them to a term.

+

The syntax for this is:

+
#fun(RuleBody)(Argument)
+

Note the limitations currently imposed by the implementation. These functions
+are not first-order: you cannot bind them to a variable and inject them like
+you can with a regular klabel for a function. You also cannot express multiple
+rules or multiple parameters, or side conditions. All of these are extensions
+we would like to support in the future, however.

+

In the following, we use three examples to illustrate the behavior of #fun.
+We point out that the support for #fun is provided by the frontend, not the
+backends.

+

The three examples are real examples borrowed or modified from existing language
+semantics.

+

Example 1 (A Simple Self-Explained Example).

+
#fun(V:Val => isFoo(V) andBool isBar(V))(someFunctionReturningVal())
+

Example 2 (Nested #fun).

+
   #fun(C
+=> #fun(R
+=> #fun(E
+=> foo1(E, R, C)
+  )(foo2(C))
+  )(foo3(0))
+  )(foo4(1))
+

This example is from the beacon
+semantics:https://github.com/runtimeverification/beacon-chain-spec/blob/master/b
+eacon-chain.k at line 302, with some modification for simplicity. Note how
+variables C, R, E are bound in the nested #fun.

+

Example 3 (Matching a structure).

+
rule foo(K, RECORD) =>
+  #fun(record(... field: _ => K))(RECORD)
+

Unlike previous examples, the LHS of #fun in this example is no longer a
+variable, but a structure. It has the same spirit as the first two examples,
+but we match the RECORD with a structure record( DotVar, field: X), instead
+of a standalone variable. We also use K's local rewrite syntax (i.e., the
+rewriting symbol => does not occur at the top-level) to prevent writing
+duplicate expressions on the LHS and RHS of the rewriting.

+

Macros and Aliases

+ +

A production can be tagged with the macro, alias, macro-rec, or alias-rec
+attributes. In all cases, what this signifies is that this is a macro production.
+Macro rules are rules where the top symbol of the left-hand-side are macro
+labels. Macro rules are applied statically during compilation on all terms that
+they match, and statically before program execution on the initial configuration.
+Currently, macro rules are required to not have side conditions, although they
+can contain sort checks.

+

alias rules are also applied statically in reverse prior to unparsing on the
+final configuration. Note that a macro rule can have unbound variables in the
+right hand side. When such a macro exists, it should be used only on the left
+hand side of rules, unless the user is performing symbolic execution and expects
+to introduce symbolic terms into the subject being rewritten.

+

However, when used on the left hand side of a rule, it functions similarly to a
+pattern alias, and allows the user to concisely express a reusable pattern that
+they wish to match on in multiple places.

+

For example, consider the following semantics:

+
syntax KItem ::= "foo" [alias] | "foobar"
+syntax KItem ::= bar(KItem) [macro] | baz(Int, KItem)
+rule foo => foobar
+rule bar(I) => baz(?_, I)
+rule bar(I) => I
+

This will rewrite baz(0, foo) to foo. First baz(0, foo) will be rewritten
+statically to baz(0, foobar). Then the non-macro rule will apply (because
+the rule will have been rewritten to rule baz(_, I) => I). Then foobar will
+be rewritten statically after rewriting finishes to foo via the reverse form
+of the alias.

+

Note that macros do not apply recursively within their own expansion. This is
+done so as to ensure that macro expansion will always terminate. If the user
+genuinely desires a recursive macro, the macro-rec and alias-rec attributes
+can be used to provide this behavior.

+

For example, consider the following semantics:

+
syntax Exp ::= "int" Exp ";" | "int" Exps ";" [macro] | Exp Exp | Id
+syntax Exps ::= List{Exp,","}
+
+rule int X:Id, X':Id, Xs:Exps ; => int X ; int X', Xs ;
+

This will expand int x, y, z; to int x; int y, z; because the macro does
+not apply the second time after applying the substitution of the first
+application. However, if the macro attribute were changed to the macro-rec
+attribute, it would instead expand (as the user likely intended) to
+int x; int y; int z;.

+

The alias-rec attribute behaves with respect to the alias attribute the
+same way the macro-rec attribute behaves with respect to macro.

+

anywhere rules

+ +

Some rules are not functional, but you want them to apply anywhere in the
+configuration (similar to functional rules). You can use the anywhere
+attribute on a rule to instruct the backends to make sure they apply anywhere
+they match in the entire configuration.

+

For example, if you want to make sure that some associative operator is always
+right-associated anywhere in the configuration, you can do:

+
syntax Stmt ::= Stmt ";" Stmt
+
+rule (S1 ; S2) ; S3 => S1 ; (S2 ; S3) [anywhere]
+

Then after every step, all occurrences of _;_ will be re-associated. Note that
+this allows the symbol _;_ to still be a constructor, even though it is
+simplified similarly to a function.

+

trusted claims

+ +

You may add the trusted attribute to a given claim for the K prover to
+automatically add it to the list of proven circularities, instead of trying to
+discharge it separately.

+

Projection and Predicate functions

+ +

K automatically generates certain predicate and projection functions from the
+syntax you declare. For example, if you write:

+
syntax Foo ::= foo(bar: Bar)
+

It will automatically generate the following K code:

+
syntax Bool ::= isFoo(K) [function]
+syntax Foo ::= "{" K "}" ":>Foo" [function]
+syntax Bar ::= bar(Foo) [function]
+
+rule isFoo(F:Foo) => true
+rule isFoo(_) => false [owise]
+
+rule { F:Foo }:>Foo => F
+rule bar(foo(B:Bar)) => B
+

The first two types of functions are generated automatically for every sort in
+your K definition, and the third type of function is generated automatically
+for each named nonterminal in your definition. Essentially, isFoo for some
+sort Foo will tell you whether a particular term of sort K is a Foo,
+{F}:>Foo will cast F to sort Foo if F is of sort Foo and will be
+undefined (i.e., theoretically defined as #Bottom, the bottom symbol in
+matching logic) otherwise. Finally, bar will project out the child of a foo
+named bar in its production declaration.

+

Note that if another term of equal or smaller sort to Foo exists and has a
+child named bar of equal or smaller sort to Bar, this will generate an
+ambiguity during parsing, so care should be taken to ensure that named
+nonterminals are sufficiently unique from one another to prevent such
+ambiguities. Of course, the compiler will generate a warning in this case.

+

simplification attribute

+ +

The simplification attribute identifies rules outside the main semantics that
+are used to simplify function patterns.

+

Conditions: A simplification rule is applied by matching the function
+arguments, instead of unification as when applying function definition
+rules. This allows function symbols to appear nested as arguments to other
+functions on the left-hand side of a simplification rule, which is forbidden in
+function definition rules. For example, this rule would not be accepted as a
+function definition rule:

+
rule (X +Int Y) +Int Z => X +Int (Y +Int Z) [simplification]
+

A simplification rule is only applied when the current side condition implies
+the requires clause of the rule, like function definition rules.

+

Order: The simplification attribute accepts an optional integer argument
+which is the rule's simplification priority; if the optional argument is not
+specified, it is equivalent to a simplification priority of 50. Backends
+should attempt simplification rules in order of their simplification
+priority
, but are not required to do so; in fact, the backend is free to apply
+simplification rules at any time. Because of this, users must ensure that
+simplification rules are sound regardless of their order of application. This
+differs from the priority attribute in that rules with the priority
+attribute must be applied in their priority order by the backend. It is an
+error to have the priority attribute on a simplification rule.

+

For example, for the following definition:

+
    syntax WordStack ::= Int ":" WordStack | ".WordStack"
+    syntax Int ::= sizeWordStack    ( WordStack       ) [function]
+                 | sizeWordStackAux ( WordStack , Int ) [function]
+ // --------------------------------------------------------------
+    rule sizeWordStack(WS) => sizeWordStackAux(WS, 0)
+
+    rule sizeWordStackAux(.WordStack, N) => N
+    rule sizeWordStackAux(W : WS    , N) => sizeWordStackAux(WS, N +Int 1)
+

We might add the following simplification lemma:

+
    rule sizeWordStackAux(WS, N) => N +Int sizeWordStackAux(WS, 0)
+      requires N =/=Int 0
+      [simplification]
+

Then this simplification rule will only apply if the Haskell backend can prove
+that notBool N =/=Int 0 is unsatisfiable. This avoids an infinite cycle of
+applying this simplification lemma.

+

NOTE: The frontend and Haskell backend do not check that supplied
+simplification rules are sound, this is the developer's responsibility. In
+particular, rules with the simplification attribute must preserve definedness;
+that is, if the left-hand side refers to any partial function then:

+
    +
  • the right-hand side must be #Bottom when the left-hand side is #Bottom, or
  • +
  • the rule must have an ensures clause that is false when the left-hand
    +side is #Bottom, or
  • +
  • the rule must have a requires clause that is false when the left-hand
    +side is #Bottom.
  • +
+

These conditions are in order of decreasing preference: the best option is to
+preserve #Bottom on the right-hand side, the next best option is to have an
+ensures clause, and the least-preferred option is to have a requires clause.
+The most preferred option is to write total functions and avoid the entire issue.

+

NOTE: The Haskell backend does not attempt to prove claims which right-hand
+side is #Bottom. The reason for this is that the general case is undecidable,
+and the backend might enter an infinite loop. Therefore, the backend emits a
+warning if it encounters such a claim.

+

concrete and symbolic attributes (Haskell backend)

+ +

Users can control the application of simplification rules using the concrete
+and the symbolic attributes by specifying the type of patterns the rule's
+arguments are to match.

+

A concrete pattern is a pattern which does not contain variables or unevaluated
+functions, otherwise the pattern is symbolic.

+

The semantics of the two attributes is defined as follows:

+
    +
  • If a simplification rule is marked concrete, then all arguments must be
    +concrete for the rule to match.
  • +
  • If a simplification rule is marked symbolic, then all arguments must be
    +symbolic for the rule to match.
  • +
  • The following syntax concrete(<variables>) (resp. symbolic(<variables>)),
    +where <variables> is a list of variable names separated by commas, can be used
    +to specify the exact arguments the user expects to match concrete (resp. symbolic)
    +patterns.
  • +
+

For example, the following will only match when all arguments
+are concrete:

+
rule X +Int (Y +Int Z) => (X +Int Y) +Int Z [simplification, concrete]
+

Conversely, the following will only match when all arguments
+are symbolic:

+
rule X +Int (Y +Int Z) => (X +Int Y) +Int Z [simplification, symbolic]
+

In practice, the following rules will re-associate and commute terms to combine
+concrete arguments:

+
rule (A +Int Y) +Int Z => A +Int (Y +Int Z)
+  [concrete(Y, Z), symbolic(A), simplification]
+
+rule X +Int (B +Int Z) => B +Int (X +Int Z)
+  [concrete(X, Z), symbolic(B), simplification]
+

The unboundVariables attribute

+ +

Normally, K rules are not allowed to contain regular (i.e., not fresh, not
+existential) variables in the RHS / requires / ensures clauses which are not
+bound in the LHS.

+

However, in certain cases this behavior might be desired, like, for example,
+when specifying a macro rule which is to be used in the LHS of other rules.
+To allow for such cases, but still be useful and perform the unboundness checks
+in regular cases, the unboundVariables attributes allows the user to specify
+a comma-separated list of names of variables which can be unbound in the rule.

+

For example, in the macro declaration

+
  rule cppEnumType => bar(_, scopedEnum() #Or unscopedEnum() ) [unboundVariables(_)]
+

the declaration unboundVariables(_) allows the rule to pass the unbound
+variable checks, and this in turn allows for cppEnumType to be used in
+the LHS of a rule to mean the pattern above:

+
  rule inverseConvertType(cppEnumType, foo((cppEnumType #as T::CPPType => underlyingType(T))))
+

The memo attribute

+ +

The memo attribute is a hint from the user to the backend to memoize a
+function. Not all backends support memoization, but when the attribute is used
+and the definition is compiled for a memo-supporting backend, then calls to
+the function may be cached. At the time of writing, only the Haskell
+backend supports memoization.

+

Limitations of memoization with the Haskell backend

+ +

The Haskell backend will only cache a function call if all arguments are concrete.

+

It is recommended not to memoize recursive functions, as each recursive call
+will be stored in the cache, but only the first iteration will be retrieved from
+the cache; that is, the cache will be filled with many unreachable
+entries. Instead, we recommend to perform a worker-wrapper transformation on
+recursive functions, and apply the memo attribute to the wrapper.

+

Warning: A function declared with the memo attribute must not use
+uninterpreted functions in the side-condition of any rule. Memoizing such an
+impure function is unsound. To see why, consider the following rules:

+
syntax Bool ::= impure( Int ) [function]
+
+syntax Int ::= unsound( Int ) [function, memo]
+rule unsound(X:Int) => X +Int 1 requires impure(X)
+rule unsound(X:Int) => X        requires notBool impure(X)
+

Because the function impure is not given rules to cover all inputs, unsound
+can be memoized incoherently. For example,

+
{unsound(0) #And {impure(0) #Equals true}} #Equals 1
+

but

+
{unsound(0) #And {impure(0) #Equals false}} #Equals 0
+

The memoized value of unsound(0) would be incoherently determined by which
+pattern the backend encounters first.

+

Variable Sort Inference

+ +

In K, it is not required that users declare the sorts of variables in rules or
+in the initial configuration. If the user does not explicitly declare the sort
+of a variable somewhere via a cast (see below), the sort of the variable is
+inferred from context based on the sort signature of every place the variable
+appears in the rule.

+

As an example, consider the rule for addition in IMP:

+
    syntax Exp ::= Exp "+" Exp | Int
+
+    rule I1 + I2 => I1 +Int I2
+

Here +Int is defined in the INT module with the following signature:

+
    syntax Int ::= Int "+Int" Int [function]
+

In the rule above, the sort of both I1 and I2 is inferred as Int. This is because
+a variable must have the same sort every place it appears within the same rule.
+While a variable appearing only on the left-hand-side of the rule could have
+sort Exp instead, the same variable appears as a child of +Int, which
+constriants the sorts of I1 and I2 more tightly. Since the sort must be a
+subsort of Int or equal to Int, and Int has no subsorts, we infer Int
+as the sorts of I1 and I2. This means that the above rule will not match
+until I1 and I2 become integers (i.e., have already been evaluated).

+

More complex examples are possible, however:

+
    syntax Exp ::= Exp "+" Int | Int
+    rule _ + _ => 0
+

Here we have two anonymous variables. They do not refer to the same variable
+as one another, so they can have different sorts. The right side is constrained
+by + to be of sort Int, but the left side could be either Exp or Int.
+When this occurs, we have multiple solutions to the sorts of the variables in
+the rule. K will only choose solutions which are maximal, however. To be
+precise, if two different solutions exist, but the sorts of one solution are
+all greater than or equal to the sorts of the other solution, K will discard
+the smaller solution. Thus, in the case above, the variable on the left side
+of the + is inferred of sort Exp, because the solution (Exp, Int) is
+strictly greater than the solution (Int, Int).

+

It is possible, however, for terms to have multiple maximal solutions:

+
    syntax Exp ::= Exp "+" Int | Int "+" Exp | Int
+    rule I1 + I2 => 0
+

In this example, there is an ambiguous parse. This could parse as either
+the first + or the second. In the first case, the maximal solution chosen is
+(Exp, Int). In the second, it is (Int, Exp). Neither of these solutions is
+greater than the other, so both are allowed by K. As a result, this program
+will emit an error because the parse is ambiguous. To pick one solution over
+the other, a cast or a prefer or avoid attribute can be used.

+

Casting

+ +

There are three main types of casts in K: the semantic cast, the strict cast,
+and the projection cast.

+

Semantic casts

+ +

For every sort S declared in your grammar, K will define the following
+production for you for use in rules:

+
    syntax S ::= S ":S"
+

The meaning of this cast is that the term inside the cast must be less than
+or equal to Sort. This can be used to resolve ambiguities, but its principle
+purpose is to guide execution by telling K what sort variables must match in
+order for the rule to apply. When compiled, it will generate a pattern that
+matches on an injection into Sort.

+

Strict casts

+ +

K also introduces the strict cast:

+
    syntax S ::= S "::S"
+

The meaning at runtime is exactly the same as the semantic cast; however, it
+restricts the sort of the term inside the cast to exactly Sort. That is
+to say, if you use it on something that is a strictly smaller sort, it will
+generate a type error. This is useful in certain circumstances to help
+disambiguate terms, when a semantic cast would not have resolved the ambiguity.
+As such, it is primarily used to solve ambiguities rather than to guide
+execution.

+

Projection casts

+ +

K also introduces the projection cast:

+
    syntax {S2} S ::= "{" S2 "}" ":>S"
+

The meaning of this cast at runtime is that if the term inside is of sort
+Sort, it should have it injection stripped away and the value inside is
+returned as a term of static sort Sort. However, if the term is of a
+different sort, it is an error and execution will get stuck. Thus the primary
+usefulness of this cast is to cast the return value of a function with a
+greater sort down to a strictly smaller sort that you expect the return value
+of the function to have. For example:

+
    syntax Exp ::= foo(Exp) [function] | bar(Int) | Int
+    rule foo(I:Int) => I
+    rule bar(I) => bar({foo(I +Int 1)}:>Int)
+

Here we know that foo(I +Int 1) will return an Int, but the return sort of
+foo is Exp. So we project the result into the Int sort so that it can
+be placed as the child of a bar.

+

owise and priority attributes.

+ +

Sometimes, it is simply not convenient to explicitly describe every
+single negative case under which a rule should not apply. Instead,
+we simply wish to say that a rule should only apply after some other set of
+rules have been tried. K introduces two different attributes that can be
+added to rules which will automatically generate the necessary matching
+conditions in a manner which is performant for concrete execution (indeed,
+it generally outperforms during concrete execution code where the conditions
+are written explicitly).

+

The first is the owise attribute. Very roughly, rules without an attribute
+indicating their priority apply first, followed by rules with the owise
+attribute only if all the other rules have been tried and failed. For example,
+consider the following function:

+
syntax Int ::= foo(Int) [function]
+rule foo(0) => 0
+rule foo(_) => 1 [owise]
+

Here foo(0) is defined explicitly as 0. Any other integer yields the
+integer 1. In particular, the second rule above will only be tried after the
+first rule has been shown not to apply.

+

This is because the first rule has a lower number assigned for its priority
+than the second rule. In practice, each rule in your semantics is implicitly
+or explicitly assigned a numerical priority. Rules are tried in increasing
+order of priority, starting at zero and trying each increasing numerical value
+successively.

+

You can specify the priority of a rule with the priority attribute. For
+example, I could equivalently write the second rule above as:

+
rule foo(_) => 1 [priority(200)]
+

The number 200 is not chosen at random. In fact, when you use the owise
+attribute, what you are doing is implicitly setting the priority of the rule
+to 200. This has a couple of implications:

+
    +
  1. Multiple rules with the owise attribute all have the same priority and thus
    +can apply in any order.
  2. +
  3. Rules with priority higher than 200 apply after all rules with the
    +owise attribute have been tried.
  4. +
+

There is one more rule by which priorities are assigned: a rule with no
+attributes indicating its priority is assigned the priority 50. Thus,
+with each priority explicitly declared, the above example looks like:

+
syntax Int ::= foo(Int) [function]
+rule foo(0) => 0 [priority(50)]
+rule foo(_) => 1 [owise]
+

One final note: the llvm backend reserves priorities between 50 and 150
+inclusive for certain specific purposes. Because of this, explicit
+priorities which are given within this region may not behave precisely as
+described above. This is primarily in order that it be possible where necessary
+to provide guidance to the pattern matching algorithm when it would otherwise
+make bad choices about which rules to try first. You generally should not
+give any rule a priority within this region unless you know exactly what the
+implications are with respect to how the llvm backend orders matches.

+

Evaluation Strategy

+

strict and seqstrict attributes

+ +

The strictness attributes allow defining evaluation strategies without having
+to explicitly make rules which implement them. This is done by injecting
+heating and cooling rules for the subterms. For this to work, you need to
+define what a result is for K, by extending the KResult sort.

+

For example:

+
syntax AExp ::= Int
+              | AExp "+" AExp [strict, klabel(addExp)]
+

This generates two heating rules (where the hole syntaxes "[]" "+" AExp and
+AExp "+" "[]" is automatically added to create an evaluation context):

+
rule [addExp1-heat]: <k> HOLE:AExp +  AE2:AExp => HOLE ~>  [] + AE2 ... </k> [heat]
+rule [addExp2-heat]: <k>  AE1:AExp + HOLE:AExp => HOLE ~> AE1 +  [] ... </k> [heat]
+

And two corresponding cooling rules:

+
rule [addExp1-cool]: <k> HOLE:AExp ~>  [] + AE2 => HOLE +  AE2 ... </k> [cool]
+rule [addExp2-cool]: <k> HOLE:AExp ~> AE1 +  [] =>  AE1 + HOLE ... </k> [cool]
+

Note that the rules are given labels based on the klabel of the production, which
+nonterminal is the hole, and whether it's the heating or the cooling rule.

+

You will note that these rules can apply one after another infinitely. In
+practice, the KResult sort is used to break this cycle by ensuring that only
+terms that are not part of the KResult sort will be heated. The heat and
+cool attributes are used to tell the compiler that these are heating and
+cooling rules and should be handled in the manner just described. Nothing stops
+the user from writing such heating and cooling rules directly if they wish,
+although we describe other more convenient syntax for most of the advanced
+cases below.

+

One other thing to note is that in the above sentences, HOLE is just a
+variable, but it has special meaning in the context of sentences with the
+heat or cool attribute. In heating or cooling rules, the variable named
+HOLE is considered to be the term being heated or cooled and the compiler
+will generate isKResult(HOLE) and notBool isKResult(HOLE) side conditions
+appropriately to ensure that the backend does not loop infinitely. The module
+BOOL will also be automatically and privately included for semantic
+purposes. The syntax for parsing programs will not be affected.

+

In order for this functionality to work, you need to define the KResult sort.
+For instance, we tell K that a term is fully evaluated once it becomes an Int
+here:

+
syntax KResult ::= Int
+

Note that you can also say that a given expression is only strict only in
+specific argument positions. Here we use this to define "short-circuiting"
+boolean operators.

+
syntax KResult ::= Bool
+
+syntax BExp ::= Bool
+              | BExp "||" BExp [strict(1)]
+              | BExp "&&" BExp [strict(1)]
+
+rule <k> true  || _    => true ... </k>
+rule <k> false || REST => REST ... </k>
+
+rule <k> true  && REST => REST  ... </k>
+rule <k> false && _    => false ... </k>
+

If you want to force a specific evaluation order of the arguments, you can use
+the variant seqstrict to do so. For example, this would make the boolean
+operators short-circuit in their second argument first:

+
syntax KResult ::= Bool
+
+syntax BExp ::= Bool
+              | BExp "||" BExp [seqstrict(2,1)]
+              | BExp "&&" BExp [seqstrict(2,1)]
+
+rule <k> _    || true  => true ... </k>
+rule <k> REST || false => REST ... </k>
+
+rule <k> REST && true  => REST  ... </k>
+rule <k> _    && false => false ... </k>
+

This will generate rules like this in the case of _||_ (note that BE1 will
+not be heated unless isKResult(BE2) is true, meaning that BE2 must be
+evaluated first):

+
rule <k>  BE1:BExp || HOLE:BExp => HOLE ~> BE1 ||  [] ... </k> [heat]
+rule <k> HOLE:BExp ||  BE2:BExp => HOLE ~>  [] || BE2 ... </k> requires isKResult(BE2) [heat]
+
+rule <k> HOLE:BExp ~>  [] || BE2 => HOLE ||  BE2 ... </k> [cool]
+rule <k> HOLE:BExp ~> BE1 ||  [] =>  BE1 || HOLE ... </k> [cool]
+

Context Declaration

+ +

Sometimes more advanced evaluation strategies are needed. By default, the
+strict and seqstrict attributes are limited in that they cannot describe
+the context in which heating or cooling should occur. When this type of
+control over the evaluation strategy is required, context sentences can be
+used to simplify the process of declaring heating and cooling when it would be
+unnecessarily verbose to write heating and cooling rules directly.

+

For example, if the user wants to heat a term if it exists under a foo
+constructor if the term to be heated is of sort bar, one might write the
+following context (with the optional label):

+
context [foo]: foo(HOLE:Bar)
+

Once again, note that HOLE is just a variable, but one that has special
+meaning to the compiler indicating the position in the context that should
+be heated or cooled.

+

This will automatically generate the following sentences:

+
rule [foo-heat]: <k> foo(HOLE:Bar) => HOLE ~> foo([]) ... </k> [heat]
+rule [foo-cool]: <k> HOLE:Bar ~> foo([]) => foo(HOLE) ... </k> [cool]
+

The user may also write the K cell explicitly in the context declaration
+if they want to match on another cell as well, for example:

+
context <k> foo(HOLE:Bar) ... </k> <state> .Map </state>
+

This context will now only heat or cool if the state cell is empty.

+

Side conditions in context declarations

+ +

The user is allowed to write a side condition in a context declaration, like
+so:

+
context foo(HOLE:Bar) requires baz(HOLE)
+

This side condition will be appended verbatim to the heating rule that is
+generated, however, it will not affect the cooling rule that is generated:

+
rule <k> foo(HOLE:Bar) => HOLE ~> foo([]) ... </k> requires baz(HOLE) [heat]
+rule <k> HOLE:Bar ~> foo([]) => foo(HOLE) ... </k> [cool]
+

Rewrites in context declarations

+ +

The user can also include exactly one rewrite operation in a context
+declaration if that rule rewrites the variable HOLE on the left hand side
+to a term containing HOLE on the right hand side. For exampl;e:

+
context foo(HOLE:Bar => bar(HOLE))
+

In this case, the code generated will be as follows:

+
rule <k> foo(HOLE:Bar) => bar(HOLE) ~> foo([]) ... </k> [heat]
+rule <k> bar(HOLE:Bar) ~> foo([]) => foo(HOLE) ... </k> [cool]
+

This can be useful if the user wishes to evaluate a term using a different
+set of rules than normal.

+

result attribute

+ +

Sometimes it is necessary to be able to evaluate a term to a different sort
+than KResult. This is done by means of adding the result attribute to
+a strict production, a context, or an explicit heating or cooling rule:

+
syntax BExp ::= Bool
+              | BExp "||" BExp [seqstrict(2,1), result(Bool)]
+

In this case, the sort check used by seqstrict and by the heat and cool
+attributes will be isBool instead of isKResult. This particular example
+does not really require use of the result attribute, but if the user wishes
+to evaluate a term of sort KResult further, the result attribute would be
+required.

+

hybrid attribute

+ +

In certain situations, it is desirable to treat a particular production which
+has the strict attribute as a result if the term has had its arguments fully
+evaluated. This can be accomplished by means of the hybrid attribute:

+
syntax KResult ::= Bool
+
+syntax BExp ::= Bool
+              | BExp "||" BExp [strict(1), hybrid]
+

This attribute is equivalent in this case to the following additional axiom
+being added to the definition of isKResult:

+
rule isKResult(BE1:BExp || BE2:BExp) => true requires isKResult(BE1)
+

Sometimes you wish to declare a production hybrid with respect to a predicate
+other than isKResult. You can do this by specifying a sort as the body of the
+hybrid attribute, e.g.:

+
syntax BExp ::= BExp "||" BExp [strict(1), hybrid(Foo)]
+

generates the rule:

+
rule isFoo(BE1:BExp || BE2:BExp) => true requires isFoo(BE1)
+

Properly speaking, hybrid takes an optional comma-separated list of sort
+names. If the list is empty, the attribute is equivalent to hybrid(KResult).
+Otherwise, it generates hybrid predicates for exactly the sorts named.

+

Context aliases

+ +

Sometimes it is necessary to define a fairly complicated evaluation strategy
+for a lot of different operators. In this case, the user could simply write
+a number of complex context declarations, however, this quickly becomes
+tedious. For this purpose, K has a concept called a context alias. A context
+alias is a bit like a template for describing contexts. The template can then
+be instantiated against particular productions using the strict and
+seqstrict attributes.

+

Here is a (simplified) example taken from the K semantics of C++:

+
context alias [c]: <k> HERE:K ... </k> <evaluate> false </evaluate>
+context alias [c]: <k> HERE:K ... </k> <evaluate> true </evaluate> [result(ExecResult)]
+
+syntax Expr ::= Expr "=" Init [strict(c; 1)]
+

This defines the evaluation strategy during the translation phase of a C++
+program for the assignment operator. It is equivalent to writing the following
+context declarations:

+
context <k> HOLE:Expr = I:Init ... </k> <evaluate> false </evaluate>
+context <k> HOLE:Expr = I:Init ... </k> <evaluate> true </evaluate> [result(ExecResult)]
+

What this is saying is, if the evaluate cell is false, evaluate the term
+like normal to a KResult. But if the evaluate cell is true, instead
+evaluate it to the ExecResult sort.

+

Essentially, we have given a name to this evaluation strategy in the form of
+the rule label on the context alias sentences (in this case, c). We can
+then say that we want to use this evaluation strategy to evaluate particular
+arguments of particular productions by referring to it by name in a strict
+attribute. For example, strict(c) will instantiate these contexts once for
+each argument of the production, whereas strict(c; 1) will instantiate it
+only for the first argument. The special variable HERE is used to tell the
+compiler where you want to place the production that is to be heated or cooled.

+

You can also specify multiple context aliases for different parts of a production,
+for example:

+
syntax Exp ::= foo(Exp, Exp) [strict(left; 1; right; 2)]
+

This says that we can evaluate the left and right arguments in either order, but to evaluate
+the left using the left context alias and the right using the right context alias.

+

We can also say seqstrict(left; 1; right; 2), in which case we additionally must evaluate
+the left argument before the right argument. Note, all strict positions are considered collectively
+when determining the evaluation order of seqstrict or the hybrid predicates.

+

A strict attribute with no rule label associated with it is equivalent to
+a strict attribute given with the following context alias:

+
context alias [default]: <k> HERE:K ... </k>
+

One syntactic convenience that is provided is that if you wish to declare the following context:

+
context foo(HOLE => bar(HOLE))
+

you can simply write the following:

+
syntax Foo ::= foo(Bar) [strict(alias)]
+
+context alias [alias]: HERE [context(bar)]
+

Pattern Matching

+

As Patterns

+ +

New syntax has been added to K for matching a pattern and binding the resulting
+match in its entirety to a variable.

+

The syntax is:

+
Pattern #as V::Var
+

In this case, Pattern, including any variables, is matched and the resulting
+variables are added to the substitution if matching succeeds. Furthermore, the
+term matched by Pattern is added to the substitution as V.

+

This code can also be used outside of any rewrite, in which case matching
+occurs as if it appeared on the left hand side, and the right hand side becomes
+a variable corresponding to the alias.

+

It is an error to use an as pattern on the right hand side of a rule.

+

Record-like KApply Patterns

+ +

We have added a syntax for matching on KApply terms which mimics the record
+syntax in functional languages. This allows us to more easily express patterns
+involving a KApply term in which we don't care about some or most of the
+children, without introducing a dependency into the code on the number of
+arguments which could be changed by a future refactoring.

+

The syntax is:

+
record(... field1: Pattern1, field2: Pattern2)
+

Note that this only applies to productions that are prefix productions.
+A prefix production is considered by the implementation to be any production
+whose production items match the following regular expression:

+
(Terminal(_)*) Terminal("(")
+(NonTerminal (Terminal(",") NonTerminal)* )?
+Terminal(")")
+

In other words, any sequence of terminals followed by an open parenthesis, an
+optional comma separated list of non-terminals, and a close parenthesis.

+

If a prefix production has no named nonterminals, a record(...) syntax is
+allowed, but in order to reference specific fields, it is necessary to give one
+or more of the non-terminals in the production names.

+

Note: because the implementation currently creates one production per possible
+set of fields to match on, and because all possible permutations of all
+possible subsets of a list of n elements is a number that scales factorially
+and reaches over 100 thousand productions at n=8, we currently do not allow
+fields to be matched in any order like a true record, but only in the same
+order as appears in the production itself.

+

Given that this only reduces the number of productions to the size of the power
+set, this will still explode the parsing time if we create large productions of
+10 or more fields that all have names. This is something that should probably
+be improved, however, productions with that large of an arity are rare, and
+thus it has not been viewed as a priority.

+

Or Patterns

+ +

Sometimes you wish to express that a rule should match if one out of multiple
+patterns should match the same subterm. We can now express this in K by means
+of using the #Or ML connective on the left hand side of a rule.

+

For example:

+
rule foo #Or bar #Or baz => qux
+

Here any of foo, bar, or baz will match this rule. Note that the behavior is
+ill-defined if it is not the case that all the clauses of the or have the same
+bound variables.

+

Matching global context in function rules

+ +

On occasion it is highly desirable to be able to look up information from the
+global configuration and match against it when evaluating a function. For this
+purpose, we introduce a new syntax for function rules.

+

This syntax allows the user to match on function context from within a
+function rule:

+
syntax Int ::= foo(Int) [function]
+
+rule [[ foo(0) => I ]]
+     <bar> I </bar>
+
+rule something => foo(0)
+

This is completely desugared by the K frontend and does not require any special
+support in the backend. It is an error to have a rewrite inside function
+context, as we do not currently support propagating such changes back into the
+global configuration. It is also an error if the context is not at the top
+level of a rule body.

+

Desugared code:

+
syntax Int ::= foo(Int, GeneratedTopCell) [function]
+
+rule foo(0, <generatedTop>
+              <bar> I </bar>
+              ...
+            </generatedTop> #as Configuration) => I
+rule <generatedTop>
+       <k> something ... </k>
+       ...
+     </generatedTop> #as Configuration
+  => <generatedTop>
+       <k> foo(0, Configuration> ... </k>
+       ...
+     </generatedTop>
+

Collection patterns

+ +

It is allowed to write patterns on the left hand side of rules which refer to
+complex terms of sort Map, List, and Set, despite these patterns ostensibly
+breaking the rule that terms which are functions should not appear on the left
+hand side of rules. Such terms are destructured into pattern matching
+operations.

+

The following forms are allowed:

+
// 0 or more elements followed by 0 or 1 variables of sort List followed by
+// 0 or more elements
+ListItem(E1) ListItem(E2) L:List ListItem(E3) ListItem(E4)
+
+// the empty list
+.List
+
+// 0 or more elements in any order plus 0 or 1 variables of sort Set
+// in any order
+SetItem(K1) SetItem(K2) S::Set SetItem(K3) SetItem(K4)
+
+// the empty set
+.Set
+
+// 0 or more elements in any order plus by 0 or 1 variables of sort Map
+// in any order
+K1 |-> E1 K2 |-> E2 M::Map K3 |-> E3 K4 |-> E4
+
+// the empty map
+.Map
+

Here K1, K2, K3, K4 etc can be any pattern except a pattern containing both
+function symbols and unbound variables. An unbound variable is a variable whose
+binding cannot be determined by means of decomposing non-set-or-map patterns or
+map elements whose keys contain no unbound variables.

+

This is determined recursively, ie, the term K1 |-> E2 E2 |-> E3 E3 |-> E4 is
+considered to contain no unbound variables.

+

Note that in the pattern K1 |-> E2 K3 |-> E4 E4 |-> E5, K1 and K3 are
+unbound, but E4 is bound because it is bound by deconstructing the key E3, even
+though E3 is itself unbound.

+

In the above examples, E1, E2, E3, and E4 can be any pattern that is normally
+allowed on the lhs of a rule.

+

When a map or set key contains function symbols, we know that the variables in
+that key are bound (because of the above restriction), so it is possible to
+evaluate the function to a concrete term prior to performing the lookup.

+

Indeed, this is the precise semantics which occurs; the function is evaluated
+and the result is looked up in the collection.

+

For example:

+
syntax Int ::= f(Int) [function]
+rule f(I:Int) => I +Int 1
+rule <k> I:Int => . ... </k> <state> ... SetItem(f(I)) ... </state>
+

This will rewrite I to . if and only if the state cell contains
+I +Int 1.

+

Note that in the case of Set and Map, one guarantee is that K1, K2, K3, and K4
+represent /distinct/ elements. Pattern matching fails if the correct number of
+distinct elements cannot be found.

+

Matching on cell fragments

+ +

K allows matching fragments of the configuration and using them to construct
+terms and use as function parameters.

+
configuration <t>
+                <k> #init ~> #collectOdd ~> $PGM </k>
+                <fs>
+                  <f multiplicity="*" type="Set"> 1 </f>
+                </fs>
+              </t>
+

The #collectOdd construct grabs the entire content of the <fs> cell.
+We may also match on only a portion of its content. Note that the fragment
+must be wrapped in a <f> cell at the call site.

+
syntax KItem ::= "#collectOdd"
+rule <k> #collectOdd => collectOdd(<fs> Fs </fs>) ... </k>
+     <fs> Fs </fs>
+

The collectOdd function collects the items it needs

+
syntax Set ::= collectOdd(FsCell) [function]
+rule collectOdd(<fs> <f> I </f> REST </fs>) => SetItem(I) collectOdd(<fs> REST </fs>) requires I %Int 2 ==Int 1
+rule collectOdd(<fs> <f> I </f> REST </fs>) =>            collectOdd(<fs> REST </fs>) requires I %Int 2 ==Int 0
+rule collectOdd(<fs> .Bag </fs>) => .Set
+

all-path and one-path attributes to distinguish reachability claims

+ +

As the Haskell backend can handle both one-path and all-path reachability
+claims, but both these are encoded as rewrite rules in K, these attributes can
+be used to clarify what kind of claim a rule is.

+

In addition of being able to annotate a rule with one of them
+(if annotating with more at the same time, only one of them would be chosen),
+one can also annotate whole modules, to give a default claim type for all rules
+in that module.

+

Additionally, the Haskell backend introduces an extra command line option
+for the K frontend, --default-claim-type, with possible values
+all-path and one-path to allow choosing a default type for all
+claims.

+

Set Variables

+ +

Motivation

+ +

Set variables were introduced as part of Matching Mu Logic, the mathematical
+foundations for K. In Matching Mu Logic, terms evaluate to sets of values.
+This is useful for both capturing partiality (as in 3/0) and capturing
+non-determinism (as in 3 #Or 5). Consequently, symbol interpretation is
+extended to have a collective interpretation over sets of input values.

+

Usually, K rules are given using regular variables, which expect that the term
+they match is both defined and has a unique interpretation.

+

However, it is sometimes useful to have simplification rules which work over
+any kind of pattern, be it undefined or non-deterministic. This behavior can be
+achieved by using set variables to stand for any kind of pattern.

+

Syntax

+ +

Any variable prefixed by @ will be considered a set variable.

+

Example

+ +

Below is a simplification rule which motivated this extension:

+
  rule #Ceil(@I1:Int /Int @I2:Int) =>
+    {(@I2 =/=Int 0) #Equals true} #And #Ceil(@I1) #And #Ceil(@I2)
+    [anywhere]
+

This rule basically says that @I1:Int /Int @I2:Int is defined if @I1 and
+@I2 are defined and @I2 is not 0. Using sets variables here is important as
+it allows the simplification rule to apply any symbolic patterns, without
+caring whether they are defined or not.

+

This allows simplifying the expression #Ceil((A:Int /Int B:Int) / C:Int) to:

+
{(C =/=Int 0) #Equals true} #And #Ceil(C) #And ({(B =/=Int 0) #Equals true}
+#And #Ceil(B) #And #Ceil(A)`
+

See kframework/kore#729 for
+more details.

+

SMT Translation

+ +

K makes queries to an SMT solver (Z3) to discharge proof obligations when doing
+symbolic execution. You can control how these queries are made using the
+attributes smtlib, smt-hook, and smt-lemma on declared productions.
+These attributes guide the prover when it tries to apply rules to discharge a
+proof obligation.

+
    +
  • smt-hook(...) allows you to specify a term in SMTLIB2 format which should
    +be used to encode that production, and assumes that all symbols appearing in
    +the term are already declared by the SMT solver.
  • +
  • smtlib(...) allows you to declare a new SMT symbol to be used when that
    +production is sent to Z3, and gives it uninterpreted function semantics.
  • +
  • smt-lemma can be applied to a rule to encode it as a conditional equality
    +when sending queries to Z3. A rule rule LHS => RHS requires REQ will be
    +encoded as the conditional equality (=> REQ (= (LHS RHS)). Every symbol
    +present in the rule must have an smt-hook(...) or smtlib(...) attribute.
  • +
+
syntax Int ::= "~Int" Int          [function, klabel(~Int_), symbol,
+                                    smtlib(notInt)]
+             | Int "^%Int" Int Int [function, klabel(_^%Int__), symbol,
+                                    smt-hook((mod (^ #1 #2) #3))]
+

In the example above, we declare two productions ~Int_ and _^%Int__, and
+tell the SMT solver to:

+
    +
  • use uninterpreted function semantics for ~Int_ via SMTLIB2 symbol
    +notInt, and
  • +
  • use the SMTLIB2 term (mod (^ #1 #2) #3) (where #N marks the Nth
    +production non-terminal argument positions) for _^%Int__, where mod and
    +^ already are declared by the SMT solver.
  • +
+

Caution

+ +

Set variables are currently only supported by the Haskell backend.
+The use of rules with set variables should be sound for all other backends
+which just execute by rewriting, however it might not be safe for backends
+which want to guarantee coverage.

+

Variables occurring only in the RHS of a rule

+ +

This section presents possible scenarios requiring variables to only appear in
+the RHS of a rule.

+

Summary

+ +

Except for ? variables and ! (fresh) variables, which are
+required to only appear in the RHS of a rule, all other variables must
+also appear in the LHS of a rule. This restriction also applies to anonymous
+variables; in particular, for claims, ?_ (not _) should be used in the RHS
+to indicate that something changes but we don't care to what value.

+

To support specifying random-like behavior, the above restriction can be relaxed
+by annotating a rule with the unboundVariables attribute whenever the rule
+intentionally contains regular variables only occurring in the RHS.

+

Introduction

+ +

K uses question mark variables of the form ?X to refer to
+existential variables, and uses ensures to specify logical constraints on
+those variables.
+These variables are only allowed to appear in the RHS of a K rule.

+

If the rules represent rewrite (semantic) steps or verification claims,
+then the ? variables are existentially quantified at the top of the RHS;
+otherwise, if they represent equations, the ? variables are quantified at the
+top of the entire rule.

+

Note that when both ?-variables and regular variables are present,
+regular variables are (implicitly) universally quantified on top of the rule
+(already containing the existential quantifications).
+This essentially makes all ? variables depend on all regular variables.

+

All examples below are intended more for program verification /
+symbolic execution, and thus concrete implementations might choose to ignore
+them altogether or to provide ad-hoc implementations for them.

+

Example: Verification claims

+ +

Consider the following definition of a (transition) system:

+
module A
+  rule foo => true
+  rule bar => true
+  rule bar => false
+endmodule
+

Consider also, the following specification of claims about the definition above:

+
module A-SPEC
+  rule [s1]: foo => ?X:Bool
+  rule [s2]: foo =>  X:Bool  [unboundVariables(X)]
+  rule [s3]: bar => ?X:Bool
+  rule [s4]: bar =>  X:Bool  [unboundVariables(X)]
+endmodule
+
One-path interpretation
+ +
    +
  • (s1) says that there exists a path from foo to some boolean, which is
    +satisfied easily using the foo => true rule
  • +
  • (s3) says the same thing about bar and can be satisfied by either of
    +bar => true and bar => false rules
  • +
  • (s2) and (s4) can be better understood by replacing them with instances for
    +each element of type Bool, which can be interpreted that
    +both true and false are reachable from foo for (s2), or bar for (s4),
    +respectively. +
      +
    • (s2) cannot be verified as we cannot find a path from foo to false.
    • +
    • (s4) can be verified by using bar => true to show true is reachable and
      +bar => false to achieve the same thing for false
    • +
    +
  • +
+
All-path interpretation
+ +
    +
  • +

    (s1) says that all paths from foo will reach some boolean, which is
    +satisfied by the foo => true rule and the lack of other rules for foo

    +
  • +
  • +

    (s3) says the same thing about bar and can be satisfied by checking that
    +both bar => true and bar => false end in a boolean, and there are no
    +other rules for bar

    +
  • +
  • +

    (s2) and (s4) can be better understood by replacing them with instances for
    +each element of type Bool, which can be interpreted that
    +both true and false are reachable in all paths originating in
    +foo for (s2), or bar for (s4), respectively.
    +This is a very strong claim, requiring that all paths originating in
    +foo (bar) pass through both true and false,
    +so neither (s2) nor (s4) can be verified.

    +

    Interestingly enough, adding a rule like false => true would make both
    +(s2) and (s4) hold.

    +
  • +
+

Example: Random Number Construct rand()

+ +

The random number construct rand() is a language construct which could be
+easily conceived to be part of the syntax of a programming language:

+
Exp ::= "rand" "(" ")"
+

The intended semantics of rand() is that it can rewrite to any integer in
+a single step. This could be expressed as the following following infinitely
+many rules.

+
rule  rand() => 0
+rule  rand() => 1
+rule  rand() => 2
+  ...    ...
+rule rand() => (-1)
+rule rand() => (-2)
+  ...    ...
+

Since we need an instance of the rule for every integer, one could summarize
+the above infinitely many rules with the rule

+
rule rand() => I:Int [unboundVariables(I)]
+

Note that I occurs only in the RHS in the rule above, and thus the rule
+needs the unboundVariables(I) attribute to signal that this is intentionally.

+

One can define variants of rand() by further constraining the output variable
+as a precondition to the rule.

+
Rand-like examples
+ +
    +
  1. +

    randBounded(M,N) can rewrite to any integer between M and N

    +
    syntax Exp ::= randBounded(Int, Int)
    +rule randBounded(M, N) => I
    +  requires M <=Int I andBool I <=Int N
    +  [unboundVariables(I)]
    +
  2. +
  3. +

    randInList(Is) takes a list Is of items
    +and can rewrite in one step to any item in Is.

    +
    syntax Exp ::= randInList (List)
    +rule randInList(Is) => I
    +  requires I inList Is
    +  [unboundVariables(I)]
    +
  4. +
  5. +

    randNotInList(Is) takes a list Is of items
    +and can rewrite in one step to any item not in Is.

    +
    syntax Exp ::= randNotInList (List)
    +rule randNotInList(Is) => I
    +  requires notBool(I inList Is)
    +  [unboundVariables(I)]
    +
  6. +
  7. +

    randPrime(), can rewrite to any prime number.

    +
    syntax Exp ::= randPrime ()
    +rule randPrime() => X:Int
    +  requires isPrime(X)
    +  [unboundVariables(X)]
    +

    where isPrime(_) is a predicate that can be defined in the usual way.

    +
  8. +
+

Note 1: all above are not function symbols, but language constructs.

+

Note 2: Currently the frontend does not allow rules with universally quantified
+variables in the RHS which are not bound in the LHS.

+

Note 3. Allowing these rules in a concrete execution engine would require an
+algorithm for generating concrete instances for such variables, satisfying the
+given constraints; thus the unboundVariables attribute serves two purposes:

+
    +
  • to allow such rules to pass the variable checks, and
  • +
  • to signal (concrete execution) backends that specialized algorithm would be
    +needed to instantiate these variables.
  • +
+

Example: Fresh Integer Construct fresh(Is)

+ +

The fresh integer construct fresh(Is) is a language construct.

+
Exp ::= ... | "fresh" "(" List{Int} ")"
+

The intended semantics of fresh(Is) is that it can always rewrite to an
+integer that in not in Is.

+

Note that fresh(Is) and randNotInList(Is) are different; the former
+does not need to be able to rewrite to every integers not in Is,
+while the latter requires so.

+

For example, it is correct to implement fresh(Is) so it always returns the
+smallest positive integer that is not in Is, but same implementation for
+randNotInList(Is) might be considered inadequate.
+In other words, there exist multiple correct implementations of fresh(Is),
+some of which may be deterministic, but there only exists a unique
+implementation of randNotInList(Is).
+Finally, note that randNotInList(Is) is a correct implementation
+for fresh(Is); Hence, concrete execution engines can choose to handle
+such rules accordingly.

+

We use the following K syntax to define fresh(Is)

+
syntax Exp ::= fresh (List{Int})
+rule fresh(Is:List{Int}) => ?I:Int
+  ensures notBool (?I inList{Int} Is)
+

A variant of this would be a choiceInList(Is) language construct which would
+choose some number from a list:

+
syntax Exp ::= choiceInList (List{Int})
+rule choiceInList(Is:List{Int}) => ?I:Int
+  ensures ?I inList{Int} Is
+

Note: This definition is different from one using a ! variable to indicate
+freshness because using ! is just syntactic sugar for generating globally
+unique instances and relies on a special configuration cell, and cannot be
+constrained, while the fresh described here is local and can be constrained.
+While the first is more appropriate for concrete execution, this might be
+better for symbolic execution / program verification.

+

Example: Arbitrary Number (Unspecific Function) arb()

+ +

The function arb() is not a PL construct, but a mathematical function.
+Therefore, its definition should not be interpreted as an execution step, but
+rather as an equality.

+

The intended semantics of arb() is that it is an unspecified nullary function.
+The exact return value of arb() is unspecified in the semantics but up to the
+implementations.
+However, being a mathematical function, arb() must return the same value in
+any one implementation.

+

We do not need special frontend syntax to define arb().
+We only need to define it in the usual way as a function
+(instead of a language construct), and provide no axioms for it.
+The total attribute ensures that the function is total, i.e.,
+that it evaluates to precisely one value for each input.

+
Variants
+ +

There are many variants of arb(). For example, arbInList(Is) is
+an unspecified function whose return value must be an element from Is.

+

Note that arbInList(Is) is different from choiceInList(Is), because
+choiceInList(Is) transitions to an integer in Is (could be a different one
+each time it is used), while arbInList(Is) is equal to a (fixed)
+integer not in Is.

+

W.r.t. the arb variants, we can use ? variables and the function
+annotation to signal that we're defining a function and the value of the
+function is fixed, but non-determinate.

+
syntax Int ::= arbInList(List{Int}) [function]
+rule arbInList(Is:List{Int}) => ?I:Int
+  ensures ?I inList{Int} Is
+

If elimination of existentials in equational rules is needed, one possible
+approach would be through Skolemization,
+i.e., replacing the ? variable with a new uninterpreted function depending
+on the regular variables present in the function.

+

Example: Interval (Non-function Symbols) interval()

+ +

The symbol interval(M,N) is not a PL construct, nor a function in the
+first-order sense, but a proper matching-logic symbol, whose interpretation is
+in the powerset of its domain.
+Its axioms will not use rewrites but equalities.

+

The intended semantics of interval(M,N) is that it equals the set of
+integers that are larger than or equal to M and smaller than or equal to N.

+

Since expressing the axiom for interval requires an an existential
+quantification on the right-hand-side, thus making it a non-total symbol
+defined through an equation, using ? variables might be confusing since their
+usage would be different from that presented in the previous sections.

+

Hence, the proposal to support this would be to write this as a proper ML rule.
+A possible syntax for this purpose would be:

+
eq  interval(M,N)
+    ==
+    #Exists X:Int .
+        (X:Int #And { X >=Int M #Equals true } #And { X <=Int N #Equals true })
+

Additionally, the symbol declaration would require a special attribute to
+signal the fact that it is not a constructor but a defined symbol.

+

Since this feature is not clearly needed by K users at the moment, it is only
+presented here as an example; its implementation will be postponed for such time
+when its usefulness becomes apparent.

+

Parser Generation

+

In addition to on-the-fly parser generation using kast, K is capable of
+ahead-of-time parser generation of LR(1) or GLR parsers using Flex and Bison.
+This can be done one of two different ways.

+
    +
  1. You can explicitly request for a particular parser to be generated by
    +invoking kast --gen-parser <outputFile> or
    +kast --gen-glr-parser <outputFile> respectively. kast will then create a
    +parser based on the same command line flags that govern on-the-fly parsing,
    +like -s to specify the starting sort, and -m to specify the module to
    +parse under. By default, this generates a parser for the sort of the $PGM
    +configuration variable in the main syntax module of the definition.
  2. +
  3. You can request that a specific set of parsers be generated for all the
    +configuration variables of your definition by passing the
    +--gen-bison-parser or --gen-glr-bison-parser flags to kompile.
    +kompile will decide the sorts to use as start symbols based on the sorts
    +in the configuration declaration for the configuration variables. The $PGM
    +configuration variable will be generated based on the main syntax module
    +of the definition. The user must explicitly annotate the configuration
    +declaration with the other modules to use to parse the other configuration
    +variables as attributes. For example, if I have the following cell in the
    +configuration declaration: <cell> foo($FOO:Foo, $BAR:Bar) </cell>,
    +One might annotate it with the attribute pair parser="FOO, TEST; BAR, TEST2"
    +to indicate that configuration variable $FOO should be parsed in the
    +TEST module, and configuration variable $BAR should be parsed in the
    +TEST2 module. If the user forgets to annotate the declaration with the
    +parser attribute, only the $PGM parser will be generated.
  4. +
+

Bison-generated parsers are extremely fast compared to kast, but they have
+some important limitations:

+
    +
  • Bison parsers will always output Kore. You can then pass the resulting AST
    +directly to llvm-krun or kore-exec and bypass the krun frontend, making
    +them very fast, but lower-level.
  • +
  • Bison parsers do not yet support macros. This may change in a future release.
    +Note that you can use anywhere rules instead of macros in most cases to get
    +around this limitation, although they will not benefit from unparsing via the
    +alias attribute.
  • +
  • Obligation falls on the user to ensure that the grammar they write is LR(1)
    +if they choose to use LR(1) parsing. If this does not happen, the parser
    +generated will have shift/reduce or reduce/reduce conflicts and the parser
    +may behave differently than kast would (kast is a GLL parser, ie, it
    +is based on LL parsers and parses all unambiguous context-free grammars).
    +K provides an attribute, not-lr1, which can be applied to modules known to
    +not be LR(1), and will trigger a warning if the user attempts to generate an
    +LR(1) parser which recursively imports that module.
  • +
  • If you are using LR(1) based parsing, the prefer and avoid attributes are
    +ignored. It is only possible to implement these attributes by means of
    +generalized LL or LR parsing and a postprocessing on the AST to remove the
    +undesirable ambiguity.
  • +
  • Obligation falls on the user to ensure that the grammar they write has as
    +few conflicts as possible if they are using GLR parsing. Bison's GLR support
    +is quite primitive, and in the worst case it can use exponential space and
    +time to parse a program, which generally leads the generated parser to report
    +"memory exhausted", indicating that the parse could not be completed within
    +the stack space allocated by Bison. It's best to ensure that the grammar is
    +as close to LR(1) as possible and only utilizes conflicts where absolutely
    +necessary. One tool that can be used to facilitate this is to pass
    +--bison-lists to kompile. This will disable support for the List{Sort}
    +syntax production, and it will make NeList{Sort} left associative, but the
    +resulting productions generated for NeList{Sort} will be LR(1) and use bounded
    +stack space.
  • +
  • If the grammar you are parsing is context-sensitive (for example, because
    +it requires a symbol table to parse), one thing you can do to make this
    +language parse in K is to implement the language as an ambiguous grammar.
    +Bison's GLR parser will generate an amb production that is parametric in
    +the sort of the ambiguity. You can then import the K-AMBIGUITIES module
    +and use rewriting to resolve the ambiguities using whatever preprocessing
    +mechanisms you prefer.
  • +
+

Location Information

+

K is able to insert file, line, and column metadata into the parse tree on a
+per-sort basis when parsing using a bison-generated parser. To enable this,
+mark the sort with the locations attribute.

+
  syntax Exp [locations]
+  syntax Exp ::= Exp "/" Exp | Int
+

K implicitly wraps productions of these sorts in a #location term (see the
+K-LOCATIONS module in kast.md). The metadata can thus be accessed with
+ordinary rewrite rules:

+
  rule #location(_ / 0, File, StartLine, _StartColumn, _EndLine, _EndColumn) =>
+  "Error: Division by zero at " +String File +String ":" Int2String(StartLine)
+

Sometimes it is desirable to allow code to be written in a file which
+overwrites the current location information provided by the parser. This can be
+done via a combination of the #LineMarker sort and the --bison-file flag to
+the parser generator. If you declare a production of sort #LineMarker which
+contains a regular expression terminal, this will be treated as a
+line marker by the bison parser. The user will then be expected to provide
+an implementation of the parser for the line marker in C. The function expected
+by the parser has the signature void line_marker(char *, yyscan_t), where
+yyscan_t is a
+reentrant flex scanner.
+The string value of the line marker token as specified by your regular
+expression can be found in the first parameter of the function, and you can
+set the line number used by the scanner using yyset_lineno(int, yyscan_t). If
+you declare the variable extern char *filename, you can also set the current
+file name by writing a malloc'd, zero-terminated string to that variable.

+

Unparsing

+

A number of factors go into how terms are unparsed in K. Here we describe some
+of the features the user can use to control how unparsing happens.

+

Brackets

+ +

One of the phases that the unparser goes through is to insert productions
+tagged with the bracket attribute where it believes this is necessary
+in order to create a correct string that will be parsed back into the original
+AST. The most common case of this is in expression grammars. For example,
+consider the following grammar:

+
syntax Exp ::= Int
+             | Exp "*" Exp
+             > Exp "+" Exp
+

Here we have declared that expressions can contain integer addition and
+multiplication, and that multiplication binds tighter than addition. As a
+result, when writing a program, if we want to write an expression that first
+applies addition, then multiplication, we must use brackets: (1 + 2) * 3.
+Similarly, if we have such an AST, we must insert brackets into the AST
+in order to faithfully unparse the term in a manner that will be parsed back
+into the same ast, because if we do not, we end up unparsing the term as
+1 + 2 * 3, which will be parsed back as 1 + (2 * 3) because of the priority
+declaration in the grammar.

+

You can control how the unparser will insert such brackets by adding a
+production with the bracket attribute and the correct sort. For example, if,
+instead of parentheses, you want to use curly braces, you could write:

+
syntax Exp ::= "{" Exp "}" [bracket]
+

This would signal to the unparser how brackets should look for terms of sort
+Exp, and it will use this syntax when unparsing terms of sort Exp.

+

Commutative collections

+ +

One thing that K will do (unless you pass the --no-sort-collections flag to
+krun) is to sort associative, commutative collections (such as Set and Map)
+alphanumerically. For example, if I have a collection whose keys are sort Id
+and they have the values a, b, c, and d, then unparsing will always print
+first the key a, then b, then c, then d, because this is the alphabetic order
+of these keys when unparsed.

+

Furthermore, K will sort numeric keys numerically. For example, if I have a
+collection whose keys are 1, 2, 5, 10, 30, it will first display 1, then 2,
+then 5, then 10, then 30, because it will sort these keys numerically. Note
+that this is different than an alphabetic sort, which would sort them as
+1, 10, 2, 30, 5. We believe the former is more intuitive to users.

+

Substitution filtering

+ +

K will remove substitution terms corresponding to anonymous variables when
+using the --pattern flag if those anonymous variables provide no information
+about the named variables in your serach pattern. You can disable this behavior
+by passing --no-substitution-filtering to krun. When this flag is not passed,
+and you are using the Haskell backend, any equality in a substitution (ie, an
+#Equals under an #And under an #Or), will be hidden from the user if the
+left hand side is a variable that was anonymous in the --pattern passed by
+the user, unless that variable appears elsewhere in the substitution. If you
+want to see that variable in the substitution, you can either disable this
+filtering, or give that variable a name in the original search pattern.

+

Variable alpha renaming

+ +

K will automatically rename variables that appear in the output configuration.
+Similar to commutative collections, this is done to normalize the resulting
+configuration so that equivalent configurations will be printed identically
+regardless of how they happen to be reached. This pass can be disabled by
+passing --no-alpha-renaming to krun.

+

Macro expansion

+ +

K will apply macros in reverse on the output configuration if the macro was
+created with the alias or alias-rec attribute. See the section on macro
+expansion for more details.

+

Formatting

+ +

format attribute

+ +

K allows you to control how terms are unparsed using the format attribute.
+By default, a domain value is unparsed by printing its string value verbatim,
+and an application pattern is unparsed by printing its terminals and children
+in the sequence implied by its concrete syntax, separated by spaces. However,
+K gives you complete control over how you want to unparse the symbol.

+

A format attribute is a string containing zero or more escape sequences that
+tell K how to unparse the symbol. Escape sequences begin with a '%' and are
+followed by either an integer, or a single non-digit character. Below is a
+list of escape sequences recognized by the formatter:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Escape SequenceMeaning
nInsert '\n' followed by the current indentation level
iIncrease the current indentation level by 1
dDecrease the current indentation level by 1
cMove to the next color in the list of colors for this production
rReset color to the default foreground color for the terminal (See below for more information on how colors work)
an integerPrint a terminal or nonterminal from the production (See below for more information)
any other charPrint that character verbatim
+

Using the integer escape sequence

+ +

In the integer escape sequence %a, the integer a is treated as a 1-based
+index into the terminals and nonterminals of the production.

+
    +
  • +

    If the offset refers to a terminal, move to the next color in the list of
    +colors for this production, print the value of that terminal, then reset the
    +color to the default foreground color for the terminal.

    +
  • +
  • +

    If the offset refers to a regular expression terminal, it is an error.

    +
  • +
  • +

    If the offset refers to a nonterminal, print the unparsed representation of
    +the corresponding child of the current term.

    +
  • +
+

color and colors attributes

+ +

K allows you to take advantage of ANSI terminal codes for foreground color
+in order to colorize output pretty-printed by the unparser. This is controlled
+via the color and colors attributes of productions. These attributes
+combine with the format attribute to control how a term is colorized.

+

The first thing to understand about how colorization works is that the color
+and colors attributes are used to construct a list of colors associated
+with each production, and the format attribute then uses that list to choose
+the color for each part of the production. For more information on how the
+format attribute chooses a color from the list, see above, but essentially,
+each terminal or %c in the format attribute advances the pointer in the list
+by one element, and terminals and %r reset the current color to the default
+foreground color of the terminal afterwards.

+

There are two ways you can construct a list of colors associated with a
+production:

+
    +
  • +

    The color attribute creates the entire list all with the same color, as
    +specified by the value of the attribute. When combined with the default format
    +attribute, this will color all the terminals in that production that color, but
    +more advanced techniques can be used as well.

    +
  • +
  • +

    The colors attribute creates the list from a manual, comma-separated list
    +of colors. The attribute is invalid if the length of the list is not equal to
    +the number of terminals in the production plus the number of %c substrings in
    +the format attribute.

    +
  • +
+

Attributes Reference

+

Attribute Syntax Overview

+ +

In K, many different syntactic categories accept an optional trailing list of
+keywords known as attributes. Attribute lists have two different syntaxes,
+depending on where they occur. Each attribute also has a type which describes
+where it may occur.

+

The first syntax is a square-bracketed ([]) list of words. This syntax is
+available for following attribute types:

+
    +
  1. module attributes - may appear immediately after the module keyword
  2. +
  3. sort attributes - may appear immediately after a sort declaration
  4. +
  5. production attributes - may appear immediately after a BNF production
    +alternative
  6. +
  7. rule attributes - may appear immediately after a rule
  8. +
  9. context attributes - may appear immediately after a context or context
    +alias
  10. +
  11. context alias attributes - may appear immediately after a context alias
  12. +
  13. claim attributes - may appear immediately after a claim
  14. +
+

The second syntax is the XML attribute syntax, i.e., a space delemited list of
+key-and-quoted-value pairs appearing inside the start tag of an XML element:
+<element key1="value" key2="value2" ... > </element>. This syntax is
+available for the following attribute types:

+
    +
  1. cell attributes - may appear inside of the cell start tag in
    +configuration declarations
  2. +
+

Unrecognized attributes are reported as an error. When we talk about
+the type of an attribute, we mean a syntactic category to which an attribute
+can be attached where the attribute has some semantic effect.

+

Attribute Index

+ +

We now provide an index of available attributes organized alphabetically with a
+brief description of each. Note that the same attribute may appear in the index
+multiple times to indicate its effect in different contexts or with/without
+arguments. A legend describing how to interpret the index follows.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
NameTypeBackendReference
alias-recprodallMacros and Aliases
aliasprodallMacros and Aliases
all-pathclaimhaskellall-path and one-path attributes to distinguish reachability claims
anywhereruleallanywhere rules
applyPriority(_)prodallSymbol priority and associativity
avoidprodallSymbol priority and associativity
binderprodallNo reference yet.
bracketprodallParametric productions and bracket attributes
color(_)prodallcolor and colors attributes
colors(_)prodallcolor and colors attributes
concretemodllvmsymbolic and concrete attribute
concrete(_)rulehaskellconcrete and symbolic attributes (Haskell backend)
concreterulehaskellconcrete and symbolic attributes (Haskell backend)
context(_)aliasallContext aliases
exit = ""cellallexit attribute
formatprodallformat attribute
freshGeneratorprodallfreshGenerator attribute
functionprodallfunction and total attributes
group(_)allallSymbol priority and associativity
hook(_)prodallNo reference yet
hybrid(_)prodallhybrid attribute
hybridprodallhybrid attribute
klabel(_)prodallklabel(_) and symbol attributes
latex(_)prodallNo reference yet
leftprodallSymbol priority and associativity
locationssortallLocation Information
macro-recprodallMacros and Aliases
macroprodallMacros and Aliases
memorulehaskellThe memo attribute
multiplicity = "_"cellallCollection Cells: multiplicity and type attributes
non-assocprodallSymbol priority and associativity
one-pathclaimhaskellall-path and one-path attributes to distinguish reachability claims
owiseruleallowise and priority attributes
prec(_)tokenallprec attribute
preferprodallSymbol priority and associativity
priority(_)ruleallowise and priority attributes
privatemodallprivate attribute
privateprodallpublic and private attribute
publicmodallNo reference yet.
publicprodallpublic and private attribute
result(_)ctxtallresult attribute
result(_)ruleallresult attribute
rightprodallSymbol priority and associativity
seqstrict(_)prodallstrict and seqstrict attributes
seqstrictprodallstrict and seqstrict attributes
simplificationrulehaskellsimplification attribute (Haskell backend)
simplification(_)rulehaskellsimplification attribute (Haskell backend)
smt-hook(_)prodhaskellSMT Translation
smtlib(_)prodhaskellSMT Translation
smt-lemmarulehaskellSMT Translation
strictprodallstrict and seqstrict attributes
strict(_)prodallstrict and seqstrict attributes
symbolicmodhaskellsymbolic and concrete attribute
symbolicrulehaskellconcrete and symbolic attributes (Haskell backend)
symbolic(_)rulehaskellconcrete and symbolic attributes (Haskell backend)
symbolprodallklabel(_) and symbol attributes
tokenprodalltoken attribute
tokensortalltoken attribute
totalprodallfunction and total attributes
trustedclaimhaskelltrusted attribute
type = "_"cellallCollection Cells: multiplicity and type attributes
unboundVariables(_)ruleallThe unboundVariables attribute
unusedprodallunused attribute
kastmodallSpecify that this module should only be included in KAST backends (Java backend).
koremodallSpecify that this module should only be included in Kore backends (Haskell/LLVM backend).
concretemodallSpecify that this module should only be included in concrete backends (LLVM backend).
symbolicmodallSpecify that this module should only be included in symbolic backends (Haskell/Java backend).
stream = "_"cellallSpecify that this cell should be hooked up to a stream, either stdin, stdout, or stderr.
+

Internal Attribute Index

+ +

Some attributes should not generally appear in user code, except in some
+unusual or complex examples. Such attributes are typically generated by the
+compiler and used internally. We list these attributes below as a reference for
+interested readers:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
NameTypeBackendReference
assocprodallassoc, comm, idem and unit attributes
commprodallassoc, comm, idem and unit attributes
digestmodallContains the hash of the textual contents of the module.
idemprodallassoc, comm, idem and unit attributes
unitprodallassoc, comm, idem and unit attributes
userListprodallIdentifies the desugared form of Lst ::= List{Elm,"delim"}
predicateprodallSpecifies the sort of a predicate label
elementprodallSpecifies the label of the elements in a list
bracketLabelprodallKeep track of the label of a bracket production since it can't have a klabel
injectiveprodallLabel a given production as injective (unique output for each input)
internalprodallProduction is reserved for internal use by the compiler
coolruleallstrict and seqstrict attributes
heatruleallstrict and seqstrict attributes
+

Index Legend

+ +
    +
  • +

    Name - the attribute's name (optionally followed by an underscore _ to indicate the attribute takes arguments)

    +
  • +
  • +

    Type - the syntactic categories where this attribute is not ignored;
    +the possible values are the types mentioned above or shorthands:

    +
      +
    1. all - short for any type except cell
    2. +
    3. mod - short for module
    4. +
    5. sort
    6. +
    7. prod - short for production
    8. +
    9. rule
    10. +
    11. ctxt - short for context or context alias
    12. +
    13. claim
    14. +
    15. cell
    16. +
    +
  • +
  • +

    Backend - the backends that do not ignore this attribute; possible values:

    +
      +
    1. all - all backends
    2. +
    3. llvm - the LLVM backend
    4. +
    5. haskell - the Haskell backend
    6. +
    +
  • +
  • +

    Effect - the attribute's effect (when it applies)

    +
  • +
+

Pending Documentation

+

Backend features not yet given documentation:

+
    +
  • Parser of KORE terms and definitions
  • +
  • Term representation of K terms
  • +
  • Hooked sorts and symbols
  • +
  • Substituting a substitution into the RHS of a rule +
      +
    • domain values
    • +
    • functions
    • +
    • variables
    • +
    • symbols
    • +
    • polymorphism
    • +
    • hooks
    • +
    • injection compaction
    • +
    • overload compaction
    • +
    +
  • +
  • Pattern Matching / Unification of subject and LHS of rule +
      +
    • domain values
    • +
    • symbols
    • +
    • side conditions
    • +
    • and/or patterns
    • +
    • list patterns
    • +
    • nonlinear variables
    • +
    • map/set patterns +
        +
      • deterministic
      • +
      • nondeterministic
      • +
      +
    • +
    • modulo injections
    • +
    • modulo overloads
    • +
    +
  • +
  • Stepping +
      +
    • initialization
    • +
    • termination
    • +
    +
  • +
  • Print kore terms
  • +
  • Equality/comparison of terms
  • +
  • Owise rules
  • +
  • Strategy #STUCK axiom
  • +
  • User substitution +
      +
    • binders
    • +
    • kvar
    • +
    +
  • +
+

To get a complete list of hooks supported by K, you can run:

+
grep -P -R "(?<=[^-])hook\([^)]*\)" k-distribution/include/kframework/builtin/ \
+     --include "*.k" -ho | \
+sed 's/hook(//' | sed 's/)//' | sort | uniq | grep -v org.kframework
+

All of these hooks will also eventually need documentation.

+

K Cheat Sheet

+

This is a quick reference of the most commonly used K tools.

+
kompile (--gen-bison-parser)? {file}                : generate parser, optionally with ahead of time
+krun {file}                                         : interpret file
+krun -cPGM='{string}'                               : interpret string
+kast --output (kore | kast) (-e|{file})             : parse expression or file
+kompile (--enable-search --backend haskell)? {file} : generate parser, enabling non-deterministic run
+krun (--search-all)? {file}                         : interpret file, evaluating non-deterministic runs as well
+foo-kompiled/parser_PGM {file}                      : ahead of time parse
+kompile (--main-module)? (--syntax-module)? {file}  : generate parser for {file}.k {file}-syntax.k, explicitly state main modules
+kparse <file> | kore-print -                        : parse and unparse a file
+kompile {file} --enable-llvm-debug                  : generate debuggable output for {file}.k
+krun {file} --debugger                              : debug K code
+kprove {file}                                       : Verify specs in {file}
+

During GDB debugging session (see here for
+LLDB breakpoint syntax):

+
break {file}:{linenum}                              : add a breakpoint to {file}'s {linenum} numbered line
+k match {module}.{label} subject                    : investigate matching
+

K Tools

+

Here we document how to use some of the most commonly used K tools.

+

Minimizing Output

+

When one is working with kore-repl or the prover in general and looking at
+specific configurations using config, sometimes the configurations can be huge.

+

One tool to help print configuration compactly is the pyk print utility:

+
pyk print
+

We are going to use --minimize option (which is actually used automatically
+when printing with pyk). This will filter out many uninteresting cells for the
+current config and make the result more compact.

+

Then, when invoking the prover, you can minimize your output by piping it into
+the pyk print ... facility with arguments for controlling the output:

+
kprove --output json --definition DEFN ... \
+    | jq .term                             \
+    | pyk print DEFN /dev/stdin --omit-labels ... --keep-labels ...
+

You can also use this in the kore-repl more easily, by making a help script.
+In your current directory, save a new script pykprint.sh:

+
#!/bin/bash
+
+kast --input kore --output json --definition $1 /dev/stdin \
+    | jq .term                                             \
+    | pyk print $1 /dev/stdin --omit-labels $2
+

Now call config | bash pykprint.sh DEFN in Kore REPL to make the output
+smaller.

+

The options you have to control the output are as follows:

+
    +
  • --no-minimize: do not remove uninteresting cells.
  • +
  • --omit-cells: remove the selected cells from the output.
  • +
  • --keep-cells: keep only the selected cells in the output.
  • +
+

Note: Make sure that there is no whitespace around , in the omit list,
+otherwise you'll get an error (, is a list separator, so this
+requirement is strict).

+

Debugging

+

The LLVM Backend has support for integration with GDB. You can run the debugger
+on a particular program by passing the --debugger flag to krun, or by
+invoking the llvm backend interpreter directly. Below we provide a simple
+tutorial to explain some of the basic commands supported by the LLVM backend.

+

LLDB Support

+ +

GDB is not well-supported on macOS, particularly on newer OS versions and Apple
+Silicon ARM hardware. Consequently, if the --debugger option is passed to krun
+on macOS, LLDB[^1] is launched instead of GDB. However, the K-specific debugger
+scripts that GDB uses have not been ported to LLDB yet, and so the instructions
+in the rest of this section will not work.

+

The K Definition

+ +

Here is a sample K definition we will use to demonstrate debugging
+capabilities:

+
module TEST
+  imports INT
+
+  configuration <k> foo(5) </k>
+  rule [test]: I:Int => I +Int 1 requires I <Int 10
+
+  syntax Int ::= foo(Int) [function]
+  rule foo(I) => 0 -Int I
+
+endmodule
+

You should compile this definition with --backend llvm --enable-llvm-debug to
+use the debugger most effectively.

+

Stepping

+ +

Important: When you first run krun with option --debugger, GDB / LLDB
+will instruct you on how to modify ~/.gdbinit or ~/.lldbinit to enable
+printing abstract syntax of K terms in the debugger. If you do not perform this
+step, you can still use all the other features, but K terms will be printed as
+their raw address in memory.

+

GDB will need the kompiled interpreter in its safe path in order to access the
+pretty printing python script within it. A good way to do this would be to pick
+a minimum top-level path that covers all of your kompiled semantics (ie. set auto-load safe-path ~/k-semantics). LLDB has slightly different security
+policies that do not require fully-arbitrary code execution.

+

This section uses GDB syntax to demonstrate the debugging features. Please
+refer to the GDB to LLDB command map on
+macOS.

+

You can break before every step of execution is taken by setting a breakpoint
+on the k_step function.

+
(gdb) break definition.kore:k_step
+Breakpoint 1 at 0x25e340
+(gdb) run
+Breakpoint 1, 0x000000000025e340 in step (subject=`<generatedTop>{}`(`<k>{}`(`kseq{}`(`inj{Int{}, KItem{}}`(#token("0", "Int")),dotk{}(.KList))),`<generatedCounter>{}`(#token("0", "Int"))))
+(gdb) continue
+Continuing.
+
+Breakpoint 1, 0x000000000025e340 in step (subject=`<generatedTop>{}`(`<k>{}`(`kseq{}`(`inj{Int{}, KItem{}}`(#token("1", "Int")),dotk{}(.KList))),`<generatedCounter>{}`(#token("0", "Int"))))
+(gdb) continue 2
+Will ignore next crossing of breakpoint 1.  Continuing.
+
+Breakpoint 1, 0x000000000025e340 in step (subject=`<generatedTop>{}`(`<k>{}`(`kseq{}`(`inj{Int{}, KItem{}}`(#token("3", "Int")),dotk{}(.KList))),`<generatedCounter>{}`(#token("0", "Int"))))
+(gdb)
+

Breaking on a specific rule

+ +

You can break when a rule is applied by giving the rule a rule label. If the
+module name is TEST and the rule label is test, you can break when the rule
+applies by setting a breakpoint on the TEST.test.rhs function:

+
(gdb) break TEST.test.rhs
+Breakpoint 1 at 0x25e250: file /home/dwightguth/test/./test.k, line 4.
+(gdb) run
+Breakpoint 1, TEST.test.rhs (VarDotVar0=`<generatedCounter>{}`(#token("0", "Int")), VarDotVar1=dotk{}(.KList), VarI=#token("0", "Int")) at /home/dwightguth/test/./test.k:4
+4         rule [test]: I:Int => I +Int 1 requires I <Int 10
+(gdb)
+

Note that the substitution associated with that rule is visible in the
+description of the frame.

+

You can also break when a side condition is applied using the TEST.test.sc
+function:

+
(gdb) break TEST.test.sc
+Breakpoint 1 at 0x25e230: file /home/dwightguth/test/./test.k, line 4.
+(gdb) run
+Breakpoint 1, TEST.test.sc (VarI=#token("0", "Int")) at /home/dwightguth/test/./test.k:4
+4         rule [test]: I:Int => I +Int 1 requires I <Int 10
+(gdb)
+

Note that every variable used in the side condition can have its value
+inspected when stopped at this breakpoint, but other variables are not visible.

+

You can also break on a rule by its location:

+
(gdb) break test.k:4
+Breakpoint 1 at 0x25e230: test.k:4. (2 locations)
+(gdb) run
+Breakpoint 1, TEST.test.sc (VarI=#token("0", "Int")) at /home/dwightguth/test/./test.k:4
+4         rule [test]: I:Int => I +Int 1 requires I <Int 10
+(gdb) continue
+Continuing.
+
+Breakpoint 1, TEST.test.rhs (VarDotVar0=`<generatedCounter>{}`(#token("0", "Int")), VarDotVar1=dotk{}(.KList), VarI=#token("0", "Int")) at /home/dwightguth/test/./test.k:4
+4         rule [test]: I:Int => I +Int 1 requires I <Int 10
+(gdb) continue
+Continuing.
+
+Breakpoint 1, TEST.test.sc (VarI=#token("1", "Int")) at /home/dwightguth/test/./test.k:4
+4         rule [test]: I:Int => I +Int 1 requires I <Int 10
+(gdb)
+

Note that this sets a breakpoint at two locations: one on the side condition
+and one on the right hand side. If the rule had no side condition, the first
+would not be set. You can also view the locations of the breakpoints and
+disable them individually:

+
(gdb) info breakpoint
+Num     Type           Disp Enb Address            What
+1       breakpoint     keep y   <MULTIPLE>
+        breakpoint already hit 3 times
+1.1                         y     0x000000000025e230 in TEST.test.sc at /home/dwightguth/test/./test.k:4
+1.2                         y     0x000000000025e250 in TEST.test.rhs at /home/dwightguth/test/./test.k:4
+(gdb) disable 1.1
+(gdb) continue
+Continuing.
+
+Breakpoint 1, TEST.test.rhs (VarDotVar0=`<generatedCounter>{}`(#token("0", "Int")), VarDotVar1=dotk{}(.KList), VarI=#token("1", "Int")) at /home/dwightguth/test/./test.k:4
+4         rule [test]: I:Int => I +Int 1 requires I <Int 10
+(gdb) continue
+Continuing.
+
+Breakpoint 1, TEST.test.rhs (VarDotVar0=`<generatedCounter>{}`(#token("0", "Int")), VarDotVar1=dotk{}(.KList), VarI=#token("2", "Int")) at /home/dwightguth/test/./test.k:4
+4         rule [test]: I:Int => I +Int 1 requires I <Int 10
+(gdb)
+

Now only the breakpoint when the rule applies is enabled.

+

Breaking on a function

+ +

You can also break when a particular function in your semantics is invoked:

+
(gdb) info functions foo
+All functions matching regular expression "foo":
+
+File /home/dwightguth/test/./test.k:
+struct __mpz_struct *Lblfoo'LParUndsRParUnds'TEST'UndsUnds'Int(struct __mpz_struct *);
+(gdb) break Lblfoo'LParUndsRParUnds'TEST'UndsUnds'Int
+Breakpoint 1 at 0x25e640: file /home/dwightguth/test/./test.k, line 6.
+(gdb) run
+Breakpoint 1, Lblfoo'LParUndsRParUnds'TEST'UndsUnds'Int (_1=#token("1", "Int")) at /home/dwightguth/test/./test.k:6
+6         syntax Int ::= foo(Int) [function]
+(gdb)
+

In this case, the variables have numbers instead of names because the names of
+arguments in functions in K come from rules, and we are stopped before any
+specific rule has applied. For example, _1 is the first argument to the
+function.

+

You can also set a breakpoint in this location by setting it on the line
+associated with its production:

+
(gdb) break test.k:6
+Breakpoint 1 at 0x25e640: file /home/dwightguth/test/./test.k, line 6.
+(gdb) run
+Breakpoint 1, Lblfoo'LParUndsRParUnds'TEST'UndsUnds'Int (_1=#token("1", "Int")) at /home/dwightguth/test/./test.k:6
+6         syntax Int ::= foo(Int) [function]
+

These two syntaxes are equivalent; use whichever is easier for you.

+

You can also view the stack of function applications:

+
(gdb) bt
+#0  Lblfoo'LParUndsRParUnds'TEST'UndsUnds'Int (_1=#token("1", "Int")) at /home/dwightguth/test/./test.k:6
+#1  0x000000000025e5f8 in apply_rule_111 (VarDotVar0=`<generatedCounter>{}`(#token("0", "Int")), VarDotVar1=dotk{}(.KList)) at /home/dwightguth/test/./test.k:9
+#2  0x0000000000268a52 in take_steps ()
+#3  0x000000000026b7b4 in main ()
+(gdb)
+

Here we see that foo was invoked while applying the rule on line 9 of test.k,
+and we also can see the substitution of that rule. If foo was evaluated while
+evaluating another function, we would also be able to see the arguments of that
+function as well, unless the function was tail recursive, in which case no
+stack frame would exist once the tail call was performed.

+

Breaking on a set of rules or functions

+ +

Using rbreak <regex> you can set breakpoints on multiple functions.

+
    +
  • +

    rbreak Lbl - sets a breakpoint on all non hooked functions

    +
  • +
  • +

    rbreak Lbl.*TEST - sets a breakpoint on all functions from module TEST

    +
  • +
  • +

    rbreak hook_INT - sets a breakpoint on all hooks from module INT

    +
  • +
+

Other debugger issues

+ +
    +
  • <optimized out> try kompiling without -O1, -O2, or -O3.
  • +
  • (gdb) break definition.kore:break -> No source file named definition.kore.
    +send --enable-llvm-debug to kompile in order to generate debug info symbols.
  • +
+

Profiling your K semantics

+

The first thing to be aware of is in order to get meaningful data,
+you need to build the semantics and all of its dependencies with
+optimizations enabled but without the frame pointer elimination
+optimization
. For example, for EVM, this means rebuilding GMP, MPFR,
+JEMalloc, Crypto++, SECP256K1, etc with the following exports.

+
export CFLAGS="-DNDEBUG -O2 -fno-omit-frame-pointer"
+export CXXFLAGS="-DNDEBUG -O2 -fno-omit-frame-pointer"
+

You can skip this step, but if you do, any samples within these
+libraries will not have correct stack trace information, which means
+you will likely not get a meaningful set of data that will tell you
+where the majority of time is really being spent. Don't worry about
+rebuilding literally every single dependency though. Just focus on the
+ones that you expect to take a non-negligible amount of runtime. You
+will be able to tell if you haven't done enough later, and you can go
+back and rebuild more. Once this is done, you then build K with
+optimizations and debug info enabled, like so:

+
mvn package -Dproject.build.type="FastBuild"
+

Next, you build the semantics with optimizations and debug info
+enabled (i.e., kompile -ccopt -O2 --iterated -ccopt -fno-omit-frame-pointer).

+

Once all this is done, you should be ready to profile your
+application. Essentially, you should run whatever test suite you
+usually run, but with perf record -g -- prefixed to the front. For
+example, for KEVM it's the following command. (For best data, don't
+run this step in parallel.)

+
perf record -g -- make test-conformance
+

Finally, you want to filter out just the samples that landed within
+the llvm backend and view the report. For this, you need to know the
+name of the binary that was generated by your build system. Normally
+it is interpreter, but e.g. if you are building the web3 client for
+kevm, it would be kevm-client. You will want to run the following
+command.

+
perf report -g -c $binary_name
+

If all goes well, you should see a breakdown of where CPU time has
+been spent executing the application. You will know that sufficient
+time was spent rebuilding dependencies with the correct flags when the
+total time reported by the main method is close to 100%. If it's not
+close to 100%, this is probably because a decent amount of self time
+was reported in stack traces that were not built with frame pointers
+enabled, meaning that perf was unable to walk the stack. You will have
+to go back, rebuild the appropriate libraries, and then record your
+trace again.

+

Your ultimate goal is to identify the hotspots that take the most
+time, and make them execute faster. Entries like step and
+step_1234 like functions refer to the cost of matching. An entry
+like side_condition_1234 is a side condition and apply_rule_1234
+is constructing the rhs of a rule. You can convert from this rule
+ordinal to a location using the llvm-kompile-compute-loc script in
+the bin folder of the llvm backend repo. For example,

+
llvm-kompile-compute-loc 5868 evm-semantics/.build/defn/llvm/driver-kompiled
+

spits out the following text.

+
Line: 18529
+/home/dwightguth/evm-semantics/./.build/defn/llvm/driver.k:493:10
+

This is the line of definition.kore that the axiom appears on as
+well as the original location of the rule in the K semantics. You can
+use this information to figure out which rules and functions are
+causing the most time and optimize them to be more efficient.

+

Running tests - kserver

+

The kserver is a front-end tool based on Nailgun
+which helps to reduce the startup time of the JVM. Calling kserver in a terminal
+window will wait for all kompile/kprove calls and force them to run in the same process
+and share the same threads. This also reduces the thread contention significantly. kompile
+uses all the threads available to do rule parsing. Another benefit is that it saves caches,
+and each time you call kprove/kast, you can access those directly w/o extra disk usage.
+Running the regression-new integration tests on a powerful machine (32 threads) takes 8m,
+with the kserver active it takes 2m. You can start the kserver in two ways.

+
    +
  • blocking: call kserver in the command line. Close it after you are done testing. Useful for quick testing.
  • +
  • non-blocking: call spawn-kserver <log.flie> and close it with stop-kserver - this is used for automation on CI
  • +
+

Because we reuse caches, you should stop and restart the server between runs.
+The Nailgun implementation hasn't been updated in the last 3-5 years, and it's not compatible with Java 18 onwards.

+

K Builtins

+

The K Builtins (also referred to as the K Prelude or the K Standard Library)
+consists of several files which contain definitions that make working with K
+simpler. These files can be found under include/kframework/builtin in your K
+installation directory, and can be imported with requires "FILENAME" (without
+the path prefix).

+
    +
  • domains: Basic datatypes which are universally useful.
  • +
  • kast: Representation of K internal data-structures (not to be
    +included in normal definitions).
  • +
  • prelude: Automatically included into every K definition.
  • +
  • ffi: FFI interface for calling out to native C code from K.
  • +
  • json: JSON datatype and parsers/unparsers for JSON strings.
  • +
  • rat: Rational number representation.
  • +
  • substitution: Hooked implementation of capture-aware
    +sustitution for K definitions.
  • +
  • unification: Hooked implementation of unification
    +exposed directly to K definitions.
  • +
+

Basic Builtin Types in K

+

A major piece of the K prelude consists of a series of modules that contain
+implementations of basic data types and language features in K. You do not need
+to require this file yourself; it is required automatically in every K
+definition unless --no-prelude is passed to kompile. K may not work correctly
+if some of these modules do not exist or do not declare certain functions.

+

Note that some functions in the K prelude functions are not total, that is,
+they are not defined on all possible input values. When you invoke such a
+function on an undefined input, the behavior is undefined. In particular, when
+this happens, interpreters generated by the K LLVM backend may crash.

+
require "kast.md"
+

Default Modules

+

K declares certain modules that contain most of the builtins you usually want
+when defining a language in K. In particular, this includes integers, booleans,
+strings, identifiers, I/O, lists, maps, and sets. The DOMAINS-SYNTAX module
+is designed to be imported by the syntax module of the language and contains
+only the program-level syntax of identifiers, integers, booleans, and strings.
+The DOMAINS module contains the rest of the syntax, including builtin
+functions over those and the remaining types.

+

Note that not all modules are included in DOMAINS. A few less-common modules
+are not, including ARRAY, COLLECTIONS, FLOAT, STRING-BUFFER, BYTES,
+K-REFLECTION, MINT, and STRATEGY.

+
module DOMAINS-SYNTAX
+  imports SORT-K
+  imports ID-SYNTAX
+  imports UNSIGNED-INT-SYNTAX
+  imports BOOL-SYNTAX
+  imports STRING-SYNTAX
+endmodule
+
+module DOMAINS
+  imports DOMAINS-SYNTAX
+  imports INT
+  imports BOOL
+  imports STRING
+  imports BASIC-K
+  imports LIST
+  imports K-IO
+  imports MAP
+  imports SET
+  imports ID
+  imports K-EQUAL
+endmodule
+

Arrays

+

Provided here is an implementation for fixed-sized, contiguous maps from Int
+to KItem. In some previous versions of K, the Array type was a builtin type
+backed by mutable arrays of objects. However, in modern K, the Array type is
+implemented by means of the List type; users should not access this interface
+directly and should instead make only of the functions listed below. Users of
+this module should import only the ARRAY module.

+
module ARRAY-SYNTAX
+  imports private LIST
+
+  syntax Array [hook(ARRAY.Array)]
+

Array lookup

+ +

You can look up an element in an Array by its index in O(log(N)) time. Note
+that the base of the logarithm is a relatively high number and thus the time is
+effectively constant.

+
  syntax KItem ::= Array "[" Int "]" [function, hook(ARRAY.lookup)]
+

Array update

+ +

You can create a new Array with a new value for a key in O(log(N)) time, or
+effectively constant.

+
  syntax Array ::= Array "[" key: Int "<-" value: KItem "]" [function, hook(ARRAY.update), klabel(_[_<-_]), symbol]
+

Array reset

+ +

You can create a new Array where a particular key is reset to its default
+value in O(log(N)) time, or effectively constant.

+
  syntax Array ::= Array "[" Int "<-" "undef" "]" [function, hook(ARRAY.remove)]
+

Multiple array update

+ +

You can create a new Array from a List L of size N where the N
+elements starting at index are replaced with the contents of L, in
+O(N*log(K)) time (where K is the size of the array), or effectively linear.
+Having index + N > K yields an exception.

+
  syntax Array ::= updateArray(Array, index: Int, List) [function, hook(ARRAY.updateAll)]
+

Array fill

+ +

You can create a new Array where the length elements starting at index
+are replaced with value, in O(length*log(N)) time, or effectively linear.

+
  syntax Array ::= fillArray(Array, index: Int, length: Int, value: KItem) [function, hook(ARRAY.fill)]
+

Array range check

+ +

You can test whether an integer is within the bounds of an array in O(1) time.

+
  syntax Bool ::= Int "in_keys" "(" Array ")" [function, total, hook(ARRAY.in_keys)]
+
endmodule
+
+module ARRAY-IN-K [private]
+  imports public ARRAY-SYNTAX
+  imports private LIST
+  imports private K-EQUAL
+  imports private INT
+  imports private BOOL
+

Array creation

+ +

You can create an array with length elements where each element is
+initialized to value in O(1) time. Note that the array is stored in a manner
+where only the highest element that is actually modified is given a value
+in its internal representation, which means that subsequent array operations
+may incur a one-time O(N) resizing cost, possibly amortized across multiple
+operations.

+
  syntax Array ::= makeArray(length: Int, value: KItem) [function, hook(ARRAY.make), public]
+

Implementation of Arrays

+ +

The remainder of this section consists of an implementation in K of the
+operations listed above. Users of the ARRAY module should not make use
+of any of the syntax defined in any of these modules.

+
  syntax Array ::= arr(List, Int, KItem)
+
+  rule makeArray(I::Int, D::KItem) => arr(.List, I, D)
+
+  rule arr(L::List, _, _       ) [ IDX::Int ] => L[IDX] requires 0 <=Int IDX andBool IDX  <Int size(L)
+  rule arr(_      , _, D::KItem) [ _        ] => D      [owise]
+
+  syntax List ::= ensureOffsetList(List, Int, KItem) [function]
+  rule ensureOffsetList(L::List, IDX::Int, D::KItem) => L makeList(IDX +Int 1 -Int size(L), D) requires         IDX >=Int size(L)
+  rule ensureOffsetList(L::List, IDX::Int, _::KItem) => L                                      requires notBool IDX >=Int size(L)
+
+  rule arr(L::List, I::Int, D::KItem) [ IDX::Int <- VAL::KItem ] => arr(ensureOffsetList(L, IDX, D) [ IDX <- VAL ], I, D)
+
+  rule arr(L::List, I::Int, D::KItem) [ IDX::Int <- undef ] => arr(L, I, D) [ IDX <- D ]
+
+  rule updateArray(arr(L::List, I::Int, D::KItem), IDX::Int, L2::List) => arr(updateList(ensureOffsetList(L, IDX +Int size(L2) -Int 1, D), IDX, L2), I, D)
+
+  rule fillArray(arr(L::List, I::Int, D::KItem), IDX::Int, LEN::Int, VAL::KItem) => arr(fillList(ensureOffsetList(L, IDX +Int LEN -Int 1, D), IDX, LEN, VAL), I, D)
+
+  rule IDX::Int in_keys(arr(_, I::Int, _)) => IDX >=Int 0 andBool IDX <Int I
+endmodule
+
+module ARRAY-SYMBOLIC [symbolic]
+  imports ARRAY-IN-K
+endmodule
+
+module ARRAY-KORE [kore]
+  imports ARRAY-IN-K
+endmodule
+
+module ARRAY
+  imports ARRAY-SYMBOLIC
+  imports ARRAY-KORE
+endmodule
+

Maps

+

Provided here is the syntax of an implementation of immutable, associative,
+commutative maps from KItem to KItem. This type is hooked to an
+implementation of maps provided by the backend. For more information on
+matching on maps and allowable patterns for doing so, refer to K's
+user documentation.

+
module MAP
+  imports private BOOL-SYNTAX
+  imports private INT-SYNTAX
+  imports private LIST
+  imports private SET
+
+  syntax Map [hook(MAP.Map)]
+

Map concatenation

+ +

The Map sort represents a generalized associative array. Each key can be
+paired with an arbitrary value, and can be used to reference its associated
+value. Multiple bindings for the same key are not allowed.

+

You can construct a new Map consisting of key/value pairs of two Maps. The
+result is #False if the maps have keys in common (in particular, this will
+yield an exception during concrete execution). This operation is O(Nlog(M))
+where N is the size of the smaller map, when it appears on the right hand side.
+When it appears on the left hand side and all variables are bound, it is
+O(N
log(M)) where M is the size of the map it is matching and N is the number
+of elements being matched. When it appears on the left hand side containing
+variables not bound elsewhere in the term, it is O(N^K) where N is the size of
+the map it is matching and K is the number of unbound keys being matched. In
+other words, one unbound variable is linear, two is quadratic, three is cubic,
+etc.

+
  syntax Map ::= Map Map                        [left, function, hook(MAP.concat), klabel(_Map_), symbol, assoc, comm, unit(.Map), element(_|->_), index(0), format(%1%n%2)]
+

Map unit

+ +

The map with zero elements is represented by .Map.

+
  syntax Map ::= ".Map"                         [function, total, hook(MAP.unit), klabel(.Map), symbol, latex(\dotCt{Map})]
+

Map elements

+ +

An element of a Map is constructed via the |-> operator. The key is on the
+left and the value is on the right.

+
  syntax Map ::= KItem "|->" KItem                      [function, total, hook(MAP.element), klabel(_|->_), symbol, latex({#1}\mapsto{#2}), injective]
+
+  syntax priorities _|->_ > _Map_ .Map
+  syntax non-assoc _|->_
+

Map lookup

+ +

You can look up the value associated with the key of a map in O(log(N)) time.
+Note that the base of the logarithm is a relatively high number and thus the
+time is effectively constant. The value is #False if the key is not in the
+map (in particular, this will yield an exception during concrete execution).

+
  syntax KItem ::= Map "[" KItem "]"                    [function, hook(MAP.lookup), klabel(Map:lookup), symbol]
+

Map lookup with default

+ +

You can also look up the value associated with the key of a map using a
+total function that assigns a specific default value if the key is not present
+in the map. This operation is also O(log(N)), or effectively constant.

+
  syntax KItem ::= Map "[" KItem "]" "orDefault" KItem      [function, total, hook(MAP.lookupOrDefault), klabel(Map:lookupOrDefault)]
+

Map update

+ +

You can insert a key/value pair into a map in O(log(N)) time, or effectively
+constant.

+
  syntax Map ::= Map "[" key: KItem "<-" value: KItem "]"           [function, total, klabel(Map:update), symbol, hook(MAP.update), prefer]
+

Map delete

+ +

You can remove a key/value pair from a map via its key in O(log(N)) time, or
+effectively constant.

+
  syntax Map ::= Map "[" KItem "<-" "undef" "]"     [function, total, hook(MAP.remove), klabel(_[_<-undef]), symbol]
+

Map difference

+ +

You can remove the key/value pairs in a map that are present in another map in
+O(N*log(M)) time (where M is the size of the first map and N is the size of the
+second), or effectively linear. Note that only keys whose value is the same
+in both maps are removed. To remove all the keys in one map from another map,
+you can say removeAll(M1, keys(M2)).

+
  syntax Map ::= Map "-Map" Map                 [function, total, hook(MAP.difference), latex({#1}-_{\it Map}{#2})]
+

Multiple map update

+ +

You can update a map by adding all the key/value pairs in the second map in
+O(N*log(M)) time (where M is the size of the first map and N is the size of the
+second map), or effectively linear. If any keys are present in both maps, the
+value from the second map overwrites the value in the first. This function is
+total, which is distinct from map concatenation, a partial function only
+defined on maps with disjoint keys.

+
  syntax Map ::= updateMap(Map, Map)            [function, total, hook(MAP.updateAll)]
+

Multiple map removal

+ +

You can remove a Set of keys from a map in O(N*log(M)) time (where M is the
+size of the Map and N is the size of the Set), or effectively linear.

+
  syntax Map ::= removeAll(Map, Set)            [function, total, hook(MAP.removeAll)]
+

Map keys (as Set)

+ +

You can get a Set of all the keys in a Map in O(N) time.

+
  syntax Set ::= keys(Map)                      [function, total, hook(MAP.keys)]
+

Map keys (as List)

+ +

You can get a List of all the keys in a Map in O(N) time.

+
  syntax List ::= "keys_list" "(" Map ")"       [function, hook(MAP.keys_list)]
+

Map key membership

+ +

You can check whether a key is present in a map in O(1) time.

+
  syntax Bool ::= KItem "in_keys" "(" Map ")"       [function, total, hook(MAP.in_keys)]
+

Map values (as List)

+ +

You can get a List of all the values in a map in O(N) time.

+
  syntax List ::= values(Map)                   [function, hook(MAP.values)]
+

Map size

+ +

You can get the number of key/value pairs in a map in O(1) time.

+
  syntax Int ::= size(Map)                      [function, total, hook(MAP.size), klabel(sizeMap)]
+

Map inclusion

+ +

You can determine whether a Map is a strict subset of another Map in O(N)
+time (where N is the size of the first map). Only keys that are bound to the
+same value are considered equal.

+
  syntax Bool ::= Map "<=Map" Map               [function, total, hook(MAP.inclusion)]
+

Map choice

+ +

You can get an arbitrarily chosen key of a Map in O(1) time. The same key
+will always be returned for the same map, but no guarantee is given that two
+different maps will return the same element, even if they are similar.

+
  syntax KItem ::= choice(Map)                      [function, hook(MAP.choice), klabel(Map:choice)]
+

Implementation of Maps

+ +

The remainder of this section contains lemmas used by the Java and Haskell
+backend to simplify expressions of sort Map. They do not affect the semantics
+of maps, merely describing additional rules that the backend can use to
+simplify terms.

+
endmodule
+
+module MAP-KORE-SYMBOLIC [kore,symbolic,haskell]
+  imports MAP
+  imports private K-EQUAL
+  imports private BOOL
+
+  rule #Ceil(@M:Map [@K:KItem]) => {(@K in_keys(@M)) #Equals true} #And #Ceil(@M) #And #Ceil(@K) [simplification]
+
+  // Symbolic update
+
+  // Adding the definedness condition `notBool (K in_keys(M))` in the ensures clause of the following rule would be redundant
+  // because K also appears in the rhs, preserving the case when it's #Bottom.
+  rule (K |-> _ M:Map) [ K <- V ] => (K |-> V M) [simplification]
+  rule M:Map [ K <- V ] => (K |-> V M) requires notBool (K in_keys(M)) [simplification]
+  rule M:Map [ K <- _ ] [ K <- V ] => M [ K <- V ] [simplification]
+  // Adding the definedness condition `notBool (K1 in_keys(M))` in the ensures clause of the following rule would be redundant
+  // because K1 also appears in the rhs, preserving the case when it's #Bottom.
+  rule (K1 |-> V1 M:Map) [ K2 <- V2 ] => (K1 |-> V1 (M [ K2 <- V2 ])) requires K1 =/=K K2 [simplification]
+
+  // Symbolic remove
+  rule (K |-> _ M:Map) [ K <- undef ] => M ensures notBool (K in_keys(M)) [simplification]
+  rule M:Map [ K <- undef ] => M requires notBool (K in_keys(M)) [simplification]
+  // Adding the definedness condition `notBool (K1 in_keys(M))` in the ensures clause of the following rule would be redundant
+  // because K1 also appears in the rhs, preserving the case when it's #Bottom.
+  rule (K1 |-> V1 M:Map) [ K2 <- undef ] => (K1 |-> V1 (M [ K2 <- undef ])) requires K1 =/=K K2 [simplification]
+
+  // Symbolic lookup
+  rule (K  |->  V M:Map) [ K ]  => V ensures notBool (K in_keys(M)) [simplification]
+  rule (K1 |-> _V M:Map) [ K2 ] => M [K2] requires K1 =/=K K2 ensures notBool (K1 in_keys(M)) [simplification]
+  rule (_MAP:Map [ K  <-  V1 ]) [ K ]  => V1 [simplification]
+  rule ( MAP:Map [ K1 <- _V1 ]) [ K2 ] => MAP [ K2 ] requires K1 =/=K K2 [simplification]
+
+  rule (K  |->  V M:Map) [  K ] orDefault _ => V ensures notBool (K in_keys(M)) [simplification]
+  rule (K1 |-> _V M:Map) [ K2 ] orDefault D => M [K2] orDefault D requires K1 =/=K K2 ensures notBool (K1 in_keys(M)) [simplification]
+  rule (_MAP:Map [ K  <-  V1 ]) [ K ] orDefault _ => V1 [simplification]
+  rule ( MAP:Map [ K1 <- _V1 ]) [ K2 ] orDefault D => MAP [ K2 ] orDefault D requires K1 =/=K K2 [simplification]
+  rule .Map [ _ ] orDefault D => D [simplification]
+
+  // Symbolic in_keys
+  rule K in_keys(_M [ K <- undef ]) => false [simplification]
+  rule K in_keys(_M [ K <- _ ]) => true [simplification]
+  rule K1 in_keys(M [ K2 <- _ ]) => true requires K1 ==K K2 orBool K1 in_keys(M) [simplification]
+  rule K1 in_keys(M [ K2 <- _ ]) => K1 in_keys(M) requires K1 =/=K K2 [simplification]
+
+  rule {false #Equals @Key in_keys(.Map)} => #Ceil(@Key) [simplification]
+  rule {@Key in_keys(.Map) #Equals false} => #Ceil(@Key) [simplification]
+  rule {false #Equals @Key in_keys(Key' |-> Val @M)} => #Ceil(@Key) #And #Ceil(Key' |-> Val @M) #And #Not({@Key #Equals Key'}) #And {false #Equals @Key in_keys(@M)} [simplification]
+  rule {@Key in_keys(Key' |-> Val @M) #Equals false} => #Ceil(@Key) #And #Ceil(Key' |-> Val @M) #And #Not({@Key #Equals Key'}) #And {@Key in_keys(@M) #Equals false} [simplification]
+
+/*
+// The rule below is automatically generated by the frontend for every sort
+// hooked to MAP.Map. It is left here to serve as documentation.
+
+  rule #Ceil(@M:Map (@K:KItem |-> @V:KItem)) => {(@K in_keys(@M)) #Equals false} #And #Ceil(@M) #And #Ceil(@K) #And #Ceil(@V)
+    [simplification]
+*/
+endmodule
+
+module MAP-SYMBOLIC
+  imports MAP-KORE-SYMBOLIC
+endmodule
+

Range Maps

+

Provided here is the syntax of an implementation of immutable, associative,
+commutative range maps from Int to KItem. This type is hooked to an
+implementation of range maps provided by the LLVM backend.
+Currently, this type is not supported by other backends.
+Although the underlying range map data structure supports any key sort, the
+current implementation by the backend only supports Int keys due to
+limitations of the underlying ordering function.

+
module RANGEMAP
+  imports private BOOL-SYNTAX
+  imports private INT-SYNTAX
+  imports private LIST
+  imports private SET
+
+

Range, bounded inclusively below and exclusively above.

+ +
  syntax Range ::= "[" KItem "," KItem ")"    [klabel(Rangemap:Range), symbol]
+
+  syntax RangeMap [hook(RANGEMAP.RangeMap)]
+

Range map concatenation

+ +

The RangeMap sort represents a map whose keys are stored as ranges, bounded
+inclusively below and exclusively above. Contiguous or overlapping ranges that
+map to the same value are merged into a single range.

+

You can construct a new RangeMap consisting of range/value pairs of two
+RangeMaps. If the RangeMaps have overlapping ranges an exception will be
+thrown during concrete execution. This operation is O(N*log(M)) (where N is
+the size of the smaller map and M is the size of the larger map).

+
  syntax RangeMap ::= RangeMap RangeMap                        [left, function, hook(RANGEMAP.concat), klabel(_RangeMap_), symbol, assoc, comm, unit(.RangeMap), element(_r|->_), index(0), format(%1%n%2)]
+

Range map unit

+ +

The RangeMap with zero elements is represented by .RangeMap.

+
  syntax RangeMap ::= ".RangeMap"                         [function, total, hook(RANGEMAP.unit), klabel(.RangeMap), symbol, latex(\dotCt{RangeMap})]
+

Range map elements

+ +

An element of a RangeMap is constructed via the r|-> operator. The range
+of keys is on the left, and the value is on the right.

+
  syntax RangeMap ::= Range "r|->" KItem                      [function, hook(RANGEMAP.elementRng), klabel(_r|->_), symbol, latex({#1}\mapsto{#2}), injective]
+
+  syntax priorities _r|->_ > _RangeMap_ .RangeMap
+  syntax non-assoc _r|->_
+

Range map lookup

+ +

You can look up the value associated with a key of a RangeMap in O(log(N))
+time (where N is the size of the RangeMap). This will yield an exception
+during concrete execution if the key is not in the range map.

+
  syntax KItem ::= RangeMap "[" KItem "]"                    [function, hook(RANGEMAP.lookup), klabel(RangeMap:lookup), symbol]
+

Range map lookup with default

+ +

You can also look up the value associated with a key of a RangeMap using a
+total function that assigns a specific default value if the key is not present
+in the RangeMap. This operation is also O(log(N)) (where N is the size of
+the range map).

+
  syntax KItem ::= RangeMap "[" KItem "]" "orDefault" KItem      [function, total, hook(RANGEMAP.lookupOrDefault), klabel(RangeMap:lookupOrDefault)]
+

Range map lookup for range of key

+ +

You can look up for the range that a key of a RangeMap is stored in in
+O(log(N)) time (where N is the size of the RangeMap). This will yield an
+exception during concrete execution if the key is not in the range map.

+
  syntax Range ::= "find_range" "(" RangeMap "," KItem ")"                    [function, hook(RANGEMAP.find_range), klabel(RangeMap:find_range)]
+

Range map update

+ +

You can insert a range/value pair into a RangeMap in O(log(N)) time (where N
+is the size of the RangeMap). Any ranges adjacent to or overlapping with the
+range to be inserted will be updated accordingly.

+
  syntax RangeMap ::= RangeMap "[" keyRange: Range "<-" value: KItem "]"           [function, klabel(RangeMap:update), symbol, hook(RANGEMAP.updateRng), prefer]
+

Range map delete

+ +

You can remove a range/value pair from a RangeMap in O(log(N)) time (where N
+is the size of the RangeMap). If all or any part of the range is present in
+the range map, it will be removed.

+
  syntax RangeMap ::= RangeMap "[" Range "<-" "undef" "]"     [function, hook(RANGEMAP.removeRng), klabel(_r[_<-undef]), symbol]
+

Range map difference

+ +

You can remove the range/value pairs in a RangeMap that are also present in
+another RangeMap in O(max{M,N}*log(M)) time (where M is the size of the
+first RangeMap and N is the size of the second RangeMap). Note that only
+the parts of overlapping ranges whose value is the same in both range maps
+will be removed.

+
  syntax RangeMap ::= RangeMap "-RangeMap" RangeMap                 [function, total, hook(RANGEMAP.difference), latex({#1}-_{\it RangeMap}{#2})]
+

Multiple range map update

+ +

You can update a RangeMap by adding all the range/value pairs in the second
+RangeMap in O(N*log(M+N)) time (where M is the size of the first RangeMap
+and N is the size of the second RangeMap). If any ranges are overlapping,
+the value from the second range map overwrites the value in the first for the
+parts where ranges are overlapping. This function is total, which is distinct
+from range map concatenation, a partial function only defined on range maps
+with non overlapping ranges.

+
  syntax RangeMap ::= updateRangeMap(RangeMap, RangeMap)            [function, total, hook(RANGEMAP.updateAll)]
+

Multiple range map removal

+ +

You can remove a Set of ranges from a RangeMap in O(N*log(M)) time (where
+M is the size of the RangeMap and N is the size of the Set). For every
+range in the set, all or any part of it that is present in the range map will
+be removed.

+
  syntax RangeMap ::= removeAll(RangeMap, Set)            [function, hook(RANGEMAP.removeAll)]
+

Range map keys (as Set)

+ +

You can get a Set of all the ranges in a RangeMap in O(N) time (where N
+is the size of the RangeMap).

+
  syntax Set ::= keys(RangeMap)                      [function, total, hook(RANGEMAP.keys)]
+

Range map keys (as List)

+ +

You can get a List of all the ranges in a RangeMap in O(N) time (where N
+is the size of the RangeMap).

+
  syntax List ::= "keys_list" "(" RangeMap ")"       [function, hook(RANGEMAP.keys_list)]
+

Range map key membership

+ +

You can check whether a key is present in a RangeMap in O(log(N)) time (where
+N is the size of the RangeMap).

+
  syntax Bool ::= KItem "in_keys" "(" RangeMap ")"       [function, total, hook(RANGEMAP.in_keys)]
+

Range map values (as List)

+ +

You can get a List of all values in a RangeMap in O(N) time (where N is the
+size of the RangeMap).

+
  syntax List ::= values(RangeMap)                   [function, hook(RANGEMAP.values)]
+

Range map size

+ +

You can get the number of range/value pairs in a RangeMap in O(1) time.

+
  syntax Int ::= size(RangeMap)                      [function, total, hook(RANGEMAP.size), klabel(sizeRangeMap)]
+

Range map inclusion

+ +

You can determine whether a RangeMap is a strict subset of another RangeMap
+in O(M+N) time (where M is the size of the first RangeMap and N is the size
+of the second RangeMap). Only keys within equal or overlapping ranges that
+are bound to the same value are considered equal.

+
  syntax Bool ::= RangeMap "<=RangeMap" RangeMap               [function, total, hook(RANGEMAP.inclusion)]
+

Range map choice

+ +

You can get an arbitrarily chosen key of a RangeMap in O(1) time. The same
+key will always be returned for the same range map, but no guarantee is given
+that two different range maps will return the same element, even if they are
+similar.

+
  syntax KItem ::= choice(RangeMap)                      [function, hook(RANGEMAP.choice), klabel(RangeMap:choice)]
+endmodule
+

Sets

+

Provided here is the syntax of an implementation of immutable, associative,
+commutative sets of KItem. This type is hooked to an implementation of sets
+provided by the backend. For more information on matching on sets and allowable
+patterns for doing so, refer to K's
+user documentation.

+
module SET
+  imports private INT-SYNTAX
+  imports private BASIC-K
+
+  syntax Set [hook(SET.Set)]
+

Set concatenation

+ +

The Set sort represents a mathematical set (A collection of unique items).
+The sets are nilpotent, i.e., the concatenation of two sets containing elements
+in common is #False (note however, this may be silently allowed during
+concrete execution). If you intend to add an element to a set that might
+already be present in the set, use the |Set operator instead.

+

The concatenation operator is O(Nlog(M)) where N is the size of the smaller
+set, when it appears on the right hand side. When it appears on the left hand
+side and all variables are bound, it is O(N
log(M)) where M is the size of the
+set it is matching and N is the number of elements being matched. When it
+appears on the left hand side containing variables not bound elsewhere in the
+term, it is O(N^K) where N is the size of the set it is matching and K is the
+number of unbound keys being mached. In other words, one unbound variable is
+linear, two is quadratic, three is cubic, etc.

+
  syntax Set ::= Set Set                  [left, function, hook(SET.concat), klabel(_Set_), symbol, assoc, comm, unit(.Set), idem, element(SetItem), format(%1%n%2)]
+

Set unit

+ +

The set with zero elements is represented by .Set.

+
  syntax Set ::= ".Set"                   [function, total, hook(SET.unit), klabel(.Set), symbol, latex(\dotCt{Set})]
+

Set elements

+ +

An element of a Set is constructed via the SetItem operator.

+
  syntax Set ::= SetItem(KItem)               [function, total, hook(SET.element), klabel(SetItem), symbol, injective]
+

Set union

+ +

You can compute the union of two sets in O(N*log(M)) time (Where N is the size
+of the smaller set). Note that the base of the logarithm is a relatively high
+number and thus the time is effectively linear. The union consists of all the
+elements present in either set.

+
  syntax Set ::= Set "|Set" Set              [left, function, total, hook(SET.union), comm]
+  rule S1:Set |Set S2:Set => S1 (S2 -Set S1) [concrete]
+

Set intersection

+ +

You can compute the intersection of two sets in O(N*log(M)) time (where N
+is the size of the smaller set), or effectively linear. The intersection
+consists of all the elements present in both sets.

+
  syntax Set ::= intersectSet(Set, Set)   [function, total, hook(SET.intersection), comm]
+

Set complement

+ +

You can compute the relative complement of two sets in O(N*log(M)) time (where
+N is the size of the second set), or effectively linear. This is the set of
+elements in the first set that are not present in the second set.

+
  syntax Set ::= Set "-Set" Set           [function, total, hook(SET.difference), latex({#1}-_{\it Set}{#2}), klabel(Set:difference), symbol]
+

Set membership

+ +

You can compute whether an element is a member of a set in O(1) time.

+
  syntax Bool ::= KItem "in" Set              [function, total, hook(SET.in), klabel(Set:in), symbol]
+

Set inclusion

+ +

You can determine whether a Set is a strict subset of another Set in O(N)
+time (where N is the size of the first set).

+
  syntax Bool ::= Set "<=Set" Set         [function, total, hook(SET.inclusion)]
+

Set size

+ +

You can get the number of elements (the cardinality) of a set in O(1) time.

+
  syntax Int ::= size(Set)                [function, total, hook(SET.size)]
+

Set choice

+ +

You can get an arbitrarily chosen element of a Set in O(1) time. The same
+element will always be returned for the same set, but no guarantee is given
+that two different sets will return the same element, even if they are similar.

+
  syntax KItem ::= choice(Set)                [function, hook(SET.choice), klabel(Set:choice)]
+
endmodule
+

Implementation of Sets

+ +

The following lemmas are simplifications that the Haskell backend can
+apply to simplify expressions of sort Set.

+
module SET-KORE-SYMBOLIC [kore,symbolic,haskell]
+  imports SET
+  imports private K-EQUAL
+  imports private BOOL
+
+  //Temporarly rule for #Ceil simplification, should be generated in front-end
+
+// Matching for this version not implemented.
+  // rule #Ceil(@S1:Set @S2:Set) =>
+  //        {intersectSet(@S1, @S2) #Equals .Set} #And #Ceil(@S1) #And #Ceil(@S2)
+  //   [simplification]
+
+//simpler version
+  rule #Ceil(@S:Set SetItem(@E:KItem)) =>
+         {(@E in @S) #Equals false} #And #Ceil(@S) #And #Ceil(@E)
+    [simplification]
+
+  // -Set simplifications
+  rule S              -Set .Set           => S          [simplification]
+  rule .Set           -Set  _             => .Set       [simplification]
+  rule SetItem(X)     -Set (S SetItem(X)) => .Set
+                               ensures notBool (X in S) [simplification]
+  rule S              -Set (S SetItem(X)) => .Set
+                               ensures notBool (X in S) [simplification]
+  rule (S SetItem(X)) -Set S              => SetItem(X)
+                               ensures notBool (X in S) [simplification]
+  rule (S SetItem(X)) -Set SetItem(X)     => S
+                               ensures notBool (X in S) [simplification]
+  // rule SetItem(X)     -Set S              => SetItem(X)
+  //                            requires notBool (X in S)  [simplification]
+  // rule (S1 SetItem(X)) -Set (S2 SetItem(X))  => S1 -Set S2
+  //                             ensures notBool (X in S1)
+  //                             andBool notBool (X in S2) [simplification]
+
+
+
+  // |Set simplifications
+  rule S    |Set .Set => S    [simplification, comm]
+  rule S    |Set S    => S    [simplification]
+
+  rule (S SetItem(X)) |Set SetItem(X) => S SetItem(X)
+                             ensures notBool (X in S) [simplification, comm]
+  // Currently disabled, see runtimeverification/haskell-backend#3301
+  // rule (S SetItem(X)) |Set S          => S SetItem(X)
+  //                            ensures notBool (X in S) [simplification, comm]
+
+  // intersectSet simplifications
+  rule intersectSet(.Set, _   ) => .Set    [simplification, comm]
+  rule intersectSet( S  , S   ) =>  S      [simplification]
+
+  rule intersectSet( S SetItem(X), SetItem(X))     => SetItem(X)
+                                                        ensures notBool (X in S)      [simplification, comm]
+  // Currently disabled, see runtimeverification/haskell-backend#3294
+  // rule intersectSet( S SetItem(X) , S)             => S ensures notBool (X in S)      [simplification, comm]
+  rule intersectSet( S1 SetItem(X), S2 SetItem(X)) => intersectSet(S1, S2) SetItem(X)
+                                                        ensures notBool (X in S1)
+                                                        andBool notBool (X in S2)     [simplification]
+
+  // membership simplifications
+  rule _E in .Set           => false   [simplification]
+  rule E  in (S SetItem(E)) => true
+              ensures notBool (E in S) [simplification]
+
+// These two rules would be sound but impose a giant overhead on `in` evaluation:
+  // rule E1 in (S SetItem(E2)) => true requires E1 in S
+  //                                 ensures notBool (E2 in S) [simplification]
+  // rule E1 in (S SetItem(E2)) => E1 in S requires E1 =/=K E2
+  //                                 ensures notBool (E2 in S) [simplification]
+
+  rule X in ((SetItem(X) S) |Set  _            ) => true
+                                    ensures notBool (X in S) [simplification]
+  rule X in ( _             |Set (SetItem(X) S)) => true
+                                    ensures notBool (X in S) [simplification]
+
+endmodule
+
+module SET-SYMBOLIC
+  imports SET-KORE-SYMBOLIC
+endmodule
+

Lists

+

Provided here is the syntax of an implementation of immutable, associative
+lists of KItem. This type is hooked to an implementation of lists provided
+by the backend. For more information on matching on lists and allowable
+patterns for doing so, refer to K's
+user documentation.

+
module LIST
+  imports private INT-SYNTAX
+  imports private BASIC-K
+
+  syntax List [hook(LIST.List)]
+

List concatenation

+ +

The List sort is an ordered collection that may contain duplicate elements.
+They are backed by relaxed radix balanced trees, which means that they support
+efficiently adding elements to both sides of the list, concatenating two lists,
+indexing, and updating elements.

+

The concatenation operator is O(log(N)) (where N is the size of the longer
+list) when it appears on the right hand side. When it appears on the left hand
+side, it is O(N), where N is the number of elements matched on the front and
+back of the list.

+
  syntax List ::= List List               [left, function, total, hook(LIST.concat), klabel(_List_), symbol, smtlib(smt_seq_concat), assoc, unit(.List), element(ListItem), format(%1%n%2)]
+

List unit

+ +

The list with zero elements is represented by .List.

+
  syntax List ::= ".List"                 [function, total, hook(LIST.unit), klabel(.List), symbol, smtlib(smt_seq_nil), latex(\dotCt{List})]
+

List elements

+ +

An element of a List is constucted via the ListItem operator.

+
  syntax List ::= ListItem(KItem)             [function, total, hook(LIST.element), klabel(ListItem), symbol, smtlib(smt_seq_elem)]
+

List indexing

+ +

You can get an element of a list by its integer offset in O(log(N)) time, or
+effectively constant. Positive indices are 0-indexed from the beginning of the
+list, and negative indices are -1-indexed from the end of the list. In other
+words, 0 is the first element and -1 is the last element.

+
  syntax KItem ::= List "[" Int "]"           [function, hook(LIST.get), klabel(List:get), symbol]
+

List update

+ +

You can create a new List with a new value at a particular index in
+O(log(N)) time, or effectively constant.

+
  syntax List ::= List "[" index: Int "<-" value: KItem "]" [function, hook(LIST.update), klabel(List:set)]
+

List of identical elements

+ +

You can create a list with length elements, each containing value, in O(N)
+time.

+
  syntax List ::= makeList(length: Int, value: KItem) [function, hook(LIST.make)]
+

Multiple list update

+ +

You can create a new List which is equal to dest except the N elements
+starting at index are replaced with the contents of src in O(N*log(K)) time
+(where K is the size of destand N is the size of src), or effectively linear. Having index + N > K yields an exception.

+
  syntax List ::= updateList(dest: List, index: Int, src: List) [function, hook(LIST.updateAll)]
+

List fill

+ +

You can create a new List where the length elements starting at index
+are replaced with value, in O(length*log(N)) time, or effectively linear.

+
  syntax List ::= fillList(List, index: Int, length: Int, value: KItem) [function, hook(LIST.fill)]
+

List slicing

+ +

You can compute a new List by removing fromFront elements from the front
+of the list and fromBack elements from the back of the list in
+O((fromFront+fromBack)*log(N)) time, or effectively linear.

+
  syntax List ::= range(List, fromFront: Int, fromBack: Int)   [function, hook(LIST.range), klabel(List:range), symbol]
+

List membership

+ +

You can compute whether an element is in a list in O(N) time. For repeated
+comparisons, it is much better to first convert to a set using List2Set.

+
  syntax Bool ::= KItem "in" List             [function, total, hook(LIST.in), klabel(_inList_)]
+

List size

+ +

You can get the number of elements of a list in O(1) time.

+
  syntax Int ::= size(List)               [function, total, hook(LIST.size), klabel (sizeList), smtlib(smt_seq_len)]
+
endmodule
+

Collection Conversions

+

It is possible to convert from a List to a Set or from a Set to a list.
+Converting from a List to a Set and back will not provide the same list;
+duplicates will have been removed and the list may be reordered. Converting
+from a Set to a List and back will generate the same set.

+

Note that because sets are unordered and lists are ordered, converting from a
+Set to a List will generate some arbitrary ordering of elements, which may
+be different from the natural ordering you might assume, or may not. Two
+equal sets are guaranteed to generate the same ordering, but no guarantee is
+otherwise provided about what the ordering will be. In particular, adding an
+element to a set may completely reorder the elements already in the set, when
+it is converted to a list.

+
module COLLECTIONS
+  imports LIST
+  imports SET
+  imports MAP
+
+  syntax List ::= Set2List(Set) [function, total, hook(SET.set2list)]
+  syntax Set ::= List2Set(List) [function, total, hook(SET.list2set)]
+
+endmodule
+

Booleans

+

Provided here is the syntax of an implementation of boolean algebra in K.
+This type is hooked to an implementation of booleans provided by the backend.
+Note that this algebra is different from the builtin truth in matching logic.
+You can, however, convert from the truth of the Bool sort to the truth in
+matching logic via the expression {B #Equals true}.

+

The boolean values are true and false.

+
module SORT-BOOL
+  syntax Bool [hook(BOOL.Bool)]
+endmodule
+
+module BOOL-SYNTAX
+  imports SORT-BOOL
+  syntax Bool ::= "true"  [token]
+  syntax Bool ::= "false" [token]
+endmodule
+
+module BOOL-COMMON
+  imports private BASIC-K
+  imports BOOL-SYNTAX
+

Basic boolean arithmetic

+ +

You can:

+
    +
  • Negate a boolean value.
  • +
  • AND two boolean values.
  • +
  • XOR two boolean values.
  • +
  • OR two boolean values.
  • +
  • IMPLIES two boolean values (i.e., P impliesBool Q is the same as
    +notBool P orBool Q)
  • +
  • Check equality of two boolean values.
  • +
  • Check inequality of two boolean values.
  • +
+

Note that only andThenBool and orElseBool are short-circuiting. andBool
+and orBool may be short-circuited in concrete backends, but in symbolic
+backends, both arguments will be evaluated.

+
  syntax Bool ::= "notBool" Bool          [function, total, klabel(notBool_), symbol, smt-hook(not), group(boolOperation), latex(\neg_{\scriptstyle\it Bool}{#1}), hook(BOOL.not)]
+                > Bool "andBool" Bool     [function, total, klabel(_andBool_), symbol, left, smt-hook(and), group(boolOperation), latex({#1}\wedge_{\scriptstyle\it Bool}{#2}), hook(BOOL.and)]
+                | Bool "andThenBool" Bool [function, total, klabel(_andThenBool_), symbol, left, smt-hook(and), group(boolOperation), hook(BOOL.andThen)]
+                | Bool "xorBool" Bool     [function, total, klabel(_xorBool_), symbol, left, smt-hook(xor), group(boolOperation), hook(BOOL.xor)]
+                | Bool "orBool" Bool      [function, total, klabel(_orBool_), symbol, left, smt-hook(or), group(boolOperation), latex({#1}\vee_{\scriptstyle\it Bool}{#2}), hook(BOOL.or)]
+                | Bool "orElseBool" Bool  [function, total, klabel(_orElseBool_), symbol, left, smt-hook(or), group(boolOperation), hook(BOOL.orElse)]
+                | Bool "impliesBool" Bool [function, total, klabel(_impliesBool_), symbol, left, smt-hook(=>), group(boolOperation), hook(BOOL.implies)]
+                > left:
+                  Bool "==Bool" Bool      [function, total, klabel(_==Bool_), symbol, left, comm, smt-hook(=), hook(BOOL.eq)]
+                | Bool "=/=Bool" Bool     [function, total, klabel(_=/=Bool_), symbol, left, comm, smt-hook(distinct), hook(BOOL.ne)]
+

Implementation of Booleans

+ +

The remainder of this section consists of an implementation in K of the
+operations listed above.

+
  rule notBool true => false
+  rule notBool false => true
+
+  rule true andBool B:Bool => B:Bool
+  rule B:Bool andBool true => B:Bool [simplification]
+  rule false andBool _:Bool => false
+  rule _:Bool andBool false => false [simplification]
+
+  rule true andThenBool K::Bool => K
+  rule K::Bool andThenBool true => K [simplification]
+  rule false andThenBool _ => false
+  rule _ andThenBool false => false  [simplification]
+
+  rule false xorBool B:Bool => B:Bool
+  rule B:Bool xorBool false => B:Bool [simplification]
+  rule B:Bool xorBool B:Bool => false
+
+  rule true orBool _:Bool => true
+  rule _:Bool orBool true => true [simplification]
+  rule false orBool B:Bool => B
+  rule B:Bool orBool false => B   [simplification]
+
+  rule true orElseBool _ => true
+  rule _ orElseBool true => true     [simplification]
+  rule false orElseBool K::Bool => K
+  rule K::Bool orElseBool false => K [simplification]
+
+  rule true impliesBool B:Bool => B
+  rule false impliesBool _:Bool => true
+  rule _:Bool impliesBool true => true       [simplification]
+  rule B:Bool impliesBool false => notBool B [simplification]
+
+  rule B1:Bool =/=Bool B2:Bool => notBool (B1 ==Bool B2)
+endmodule
+
+module BOOL-KORE [kore, symbolic]
+  imports BOOL-COMMON
+
+  rule {true #Equals notBool @B} => {false #Equals @B} [simplification]
+  rule {notBool @B #Equals true} => {@B #Equals false} [simplification]
+  rule {false #Equals notBool @B} => {true #Equals @B} [simplification]
+  rule {notBool @B #Equals false} => {@B #Equals true} [simplification]
+
+  rule {true #Equals @B1 andBool @B2} => {true #Equals @B1} #And {true #Equals @B2} [simplification]
+  rule {@B1 andBool @B2 #Equals true} => {@B1 #Equals true} #And {@B2 #Equals true} [simplification]
+  rule {false #Equals @B1 orBool @B2} => {false #Equals @B1} #And {false #Equals @B2} [simplification]
+  rule {@B1 orBool @B2 #Equals false} => {@B1 #Equals false} #And {@B2 #Equals false} [simplification]
+endmodule
+
+module BOOL
+  imports BOOL-COMMON
+  imports BOOL-KORE
+endmodule
+

Integers

+

Provided here is the syntax of an implementation of arbitrary-precision
+integer arithmetic in K. This type is hooked to an implementation of integers
+provided by the backend. For a fixed-width integer type, see the MINT module
+below.

+

The UNSIGNED-INT-SYNTAX module provides a syntax of whole numbers in K.
+This is useful because often programming languages implement the sign of an
+integer as a unary operator rather than part of the lexical syntax of integers.
+However, you can also directly reference integers with a sign using the
+INT-SYNTAX module.

+
module UNSIGNED-INT-SYNTAX
+  syntax Int [hook(INT.Int)]
+  syntax Int ::= r"[0-9]+" [prefer, token, prec(2)]
+endmodule
+
+module INT-SYNTAX
+  imports UNSIGNED-INT-SYNTAX
+  syntax Int ::= r"[\\+-]?[0-9]+" [prefer, token, prec(2)]
+endmodule
+
+module INT-COMMON
+  imports INT-SYNTAX
+  imports private BOOL
+

Integer arithmetic

+ +

You can:

+
    +
  • Compute the bitwise complement ~Int of an integer value in twos-complement.
  • +
  • Compute the exponentiation ^Int of two integers.
  • +
  • Compute the exponentiation of two integers modulo another integer (^%Int).
    +A ^%Int B C is equal in value to (A ^Int B) %Int C, but has a better
    +asymptotic complexity.
  • +
  • Compute the product *Int of two integers.
  • +
  • Compute the quotient /Int or modulus %Int of two integers using
    +t-division, which rounds towards zero. Division by zero is #False.
  • +
  • Compute the quotient divInt or modulus modInt of two integers using
    +Euclidean division, in which the remainder is always non-negative. Division
    +by zero is #False.
  • +
  • Compute the sum +Int or difference -Int of two integers.
  • +
  • Compute the arithmetic right shift >>Int of two integers. Shifting by a
    +negative quantity is #False.
  • +
  • Compute the left shift of two integers. Shifting by a negative quantity is
    +#False.
  • +
  • Compute the bitwise and of two integers in twos-complement.
  • +
  • Compute the bitwise xor of two integers in twos-complement.
  • +
  • Compute the bitwise inclusive-or of two integers in twos-complement.
  • +
+
  syntax Int ::= "~Int" Int                     [function, klabel(~Int_), symbol, total, latex(\mathop{\sim_{\scriptstyle\it Int}}{#1}), hook(INT.not), smtlib(notInt)]
+               > left:
+                 Int "^Int" Int                 [function, klabel(_^Int_), symbol, left, smt-hook(^), latex({#1}\mathrel{{\char`\^}_{\!\scriptstyle\it Int}}{#2}), hook(INT.pow)]
+               | Int "^%Int" Int Int            [function, klabel(_^%Int__), symbol, left, smt-hook((mod (^ #1 #2) #3)), hook(INT.powmod)]
+               > left:
+                 Int "*Int" Int                 [function, total, klabel(_*Int_), symbol, left, comm, smt-hook(*), latex({#1}\mathrel{\ast_{\scriptstyle\it Int}}{#2}), hook(INT.mul)]
+               /* FIXME: translate /Int and %Int into smtlib */
+               /* /Int and %Int implement t-division, which rounds towards 0 */
+               | Int "/Int" Int                 [function, klabel(_/Int_), symbol, left, smt-hook(div), latex({#1}\mathrel{\div_{\scriptstyle\it Int}}{#2}), hook(INT.tdiv)]
+               | Int "%Int" Int                 [function, klabel(_%Int_), symbol, left, smt-hook(mod), latex({#1}\mathrel{\%_{\scriptstyle\it Int}}{#2}), hook(INT.tmod)]
+               /* divInt and modInt implement e-division according to the Euclidean division theorem, therefore the remainder is always positive */
+               | Int "divInt" Int               [function, klabel(_divInt_), symbol, left, smt-hook(div), hook(INT.ediv)]
+               | Int "modInt" Int               [function, klabel(_modInt_), symbol, left, smt-hook(mod), hook(INT.emod)]
+               > left:
+                 Int "+Int" Int                 [function, total, klabel(_+Int_), symbol, left, comm, smt-hook(+), latex({#1}\mathrel{+_{\scriptstyle\it Int}}{#2}), hook(INT.add)]
+               | Int "-Int" Int                 [function, total, klabel(_-Int_), symbol, left, smt-hook(-), latex({#1}\mathrel{-_{\scriptstyle\it Int}}{#2}), hook(INT.sub)]
+               > left:
+                 Int ">>Int" Int                [function, klabel(_>>Int_), symbol, left, latex({#1}\mathrel{\gg_{\scriptstyle\it Int}}{#2}), hook(INT.shr), smtlib(shrInt)]
+               | Int "<<Int" Int                [function, klabel(_<<Int_), symbol, left, latex({#1}\mathrel{\ll_{\scriptstyle\it Int}}{#2}), hook(INT.shl), smtlib(shlInt)]
+               > left:
+                 Int "&Int" Int                 [function, total, klabel(_&Int_), symbol, left, comm, latex({#1}\mathrel{\&_{\scriptstyle\it Int}}{#2}), hook(INT.and), smtlib(andInt)]
+               > left:
+                 Int "xorInt" Int               [function, total, klabel(_xorInt_), symbol, left, comm, latex({#1}\mathrel{\oplus_{\scriptstyle\it Int}}{#2}), hook(INT.xor), smtlib(xorInt)]
+               > left:
+                 Int "|Int" Int                 [function, total, klabel(_|Int_), symbol, left, comm, latex({#1}\mathrel{|_{\scriptstyle\it Int}}{#2}), hook(INT.or), smtlib(orInt)]
+

Integer minimum and maximum

+ +

You can compute the minimum and maximum minInt and maxInt of two integers.

+
  syntax Int ::= "minInt" "(" Int "," Int ")"   [function, total, smt-hook((ite (< #1 #2) #1 #2)), hook(INT.min)]
+               | "maxInt" "(" Int "," Int ")"   [function, total, smt-hook((ite (< #1 #2) #2 #1)), hook(INT.max)]
+

Absolute value

+ +

You can compute the absolute value absInt of an integer.

+
  syntax Int ::= absInt ( Int )                 [function, total, smt-hook((ite (< #1 0) (- 0 #1) #1)), hook(INT.abs)]
+

Log base 2

+ +

You can compute the log base 2, rounded towards zero, of an integer. The log
+base 2 of an integer is equal to the index of the highest bit set in the
+representation of a positive integer. Log base 2 of zero or a negative number
+is #False.

+
  syntax Int ::= log2Int ( Int )                [function, hook(INT.log2)]
+

Bit slicing

+ +

You can compute the value of a range of bits in the twos-complement
+representation of an integer, as interpeted either unsigned or signed, of an
+integer. index is offset from 0 and length is the number of bits, starting
+with index, that should be read. The number is assumed to be represented
+in little endian notation with each byte going from least significant to
+most significant. In other words, 0 is the least-significant bit, and each
+successive bit is more significant than the last.

+
  syntax Int ::= bitRangeInt           ( Int, index: Int, length: Int ) [function, hook(INT.bitRange)]
+               | signExtendBitRangeInt ( Int, index: Int, length: Int ) [function, hook(INT.signExtendBitRange)]
+

Integer comparisons

+ +

You can compute whether two integers are less than or equal to, less than,
+greater than or equal to, greater than, equal, or unequal to another integer.

+
  syntax Bool ::= Int "<=Int" Int         [function, total, klabel(_<=Int_), symbol, smt-hook(<=), latex({#1}\mathrel{\leq_{\scriptstyle\it Int}}{#2}), hook(INT.le)]
+                | Int "<Int" Int          [function, total, klabel(_<Int_), symbol, smt-hook(<), latex({#1}\mathrel{<_{\scriptstyle\it Int}}{#2}), hook(INT.lt)]
+                | Int ">=Int" Int         [function, total, klabel(_>=Int_), symbol, smt-hook(>=), latex({#1}\mathrel{\geq_{\scriptstyle\it Int}}{#2}), hook(INT.ge)]
+                | Int ">Int" Int          [function, total, klabel(_>Int_), symbol, smt-hook(>), latex({#1}\mathrel{>_{\scriptstyle\it Int}}{#2}), hook(INT.gt)]
+                | Int "==Int" Int         [function, total, klabel(_==Int_), symbol, comm, smt-hook(=), latex({#1}\mathrel{{=}{=}_{\scriptstyle\it Int}}{#2}), hook(INT.eq)]
+                | Int "=/=Int" Int        [function, total, klabel(_=/=Int_), symbol, comm, smt-hook(distinct), latex({#1}\mathrel{{=}{/}{=}_{\scriptstyle\it Int}}{#2}), hook(INT.ne)]
+

Divides

+ +

You can compute whether one integer evenly divides another. This is the
+case when the second integer modulo the first integer is equal to zero.

+
  syntax Bool ::= Int "dividesInt" Int    [function]
+

Random integers

+ +

You can, on concrete backends, compute a pseudorandom integer, or seed the
+pseudorandom number generator. These operations are represented as
+uninterpreted functions on symbolic backends.

+
  syntax Int ::= randInt(Int) [function, hook(INT.rand), impure]
+  syntax K ::= srandInt(Int) [function, hook(INT.srand), impure]
+

Implementation of Integers

+ +

The remainder of this section consists of an implementation in K of some
+of the operators above, as well as lemmas used by the Java and Haskell backend
+to simplify expressions of sort Int. They do not affect the semantics of
+integers, merely describing additional rules that the backend can use to
+simplify terms.

+
endmodule
+
+module INT-SYMBOLIC [symbolic]
+  imports INT-COMMON
+  imports INT-SYMBOLIC-KORE
+  imports private BOOL
+
+  // Arithmetic Normalization
+  rule I +Int 0 => I [simplification]
+  rule I -Int 0 => I [simplification]
+
+  rule X modInt N => X requires 0 <=Int X andBool X <Int N [simplification]
+  rule X   %Int N => X requires 0 <=Int X andBool X <Int N [simplification]
+
+  // Bit-shifts
+  rule X <<Int 0 => X [simplification]
+  rule 0 <<Int _ => 0 [simplification]
+  rule X >>Int 0 => X [simplification]
+  rule 0 >>Int _ => 0 [simplification]
+endmodule
+
+module INT-SYMBOLIC-KORE [symbolic, kore, haskell]
+  imports INT-COMMON
+  imports ML-SYNTAX
+  imports private BOOL
+
+  // Definability Conditions
+  rule #Ceil(@I1:Int /Int   @I2:Int) => {(@I2 =/=Int 0) #Equals true} #And #Ceil(@I1) #And #Ceil(@I2) [simplification]
+  rule #Ceil(@I1:Int %Int   @I2:Int) => {(@I2 =/=Int 0) #Equals true} #And #Ceil(@I1) #And #Ceil(@I2) [simplification]
+  rule #Ceil(@I1:Int modInt @I2:Int) => {(@I2 =/=Int 0) #Equals true} #And #Ceil(@I1) #And #Ceil(@I2) [simplification]
+  rule #Ceil(@I1:Int >>Int  @I2:Int) => {(@I2 >=Int 0)  #Equals true} #And #Ceil(@I1) #And #Ceil(@I2) [simplification]
+  rule #Ceil(@I1:Int <<Int  @I2:Int) => {(@I2 >=Int 0)  #Equals true} #And #Ceil(@I1) #And #Ceil(@I2) [simplification]
+endmodule
+
+module INT-KORE [kore, symbolic]
+  imports private K-EQUAL
+  imports private BOOL
+  imports INT-COMMON
+
+  rule I1:Int ==K I2:Int => I1 ==Int I2 [simplification]
+  rule {K1 ==Int K2 #Equals true} => {K1 #Equals K2} [simplification]
+  rule {true #Equals K1 ==Int K2} => {K1 #Equals K2} [simplification]
+  rule {K1 ==Int K2 #Equals false} => #Not({K1 #Equals K2}) [simplification]
+  rule {false #Equals K1 ==Int K2} => #Not({K1 #Equals K2}) [simplification]
+  rule {K1 =/=Int K2 #Equals true} => #Not({K1 #Equals K2}) [simplification]
+  rule {true #Equals K1 =/=Int K2} => #Not({K1 #Equals K2}) [simplification]
+  rule {K1 =/=Int K2 #Equals false} => {K1 #Equals K2} [simplification]
+  rule {false #Equals K1 =/=Int K2} => {K1 #Equals K2} [simplification]
+
+  // Arithmetic Normalization
+  rule I +Int B => B +Int I          [concrete(I), symbolic(B), simplification(51)]
+  rule A -Int I => A +Int (0 -Int I) [concrete(I), symbolic(A), simplification(51)]
+
+  rule (A +Int I2) +Int I3 => A +Int (I2 +Int I3) [concrete(I2, I3), symbolic(A), simplification]
+  rule I1 +Int (B +Int I3) => B +Int (I1 +Int I3) [concrete(I1, I3), symbolic(B), simplification]
+  rule I1 -Int (B +Int I3) => (I1 -Int I3) -Int B [concrete(I1, I3), symbolic(B), simplification]
+  rule I1 +Int (I2 +Int C) => (I1 +Int I2) +Int C [concrete(I1, I2), symbolic(C), simplification]
+  rule I1 +Int (I2 -Int C) => (I1 +Int I2) -Int C [concrete(I1, I2), symbolic(C), simplification]
+  rule (I1 -Int B) +Int I3 => (I1 +Int I3) -Int B [concrete(I1, I3), symbolic(B), simplification]
+  rule I1 -Int (I2 +Int C) => (I1 -Int I2) -Int C [concrete(I1, I2), symbolic(C), simplification]
+  rule I1 -Int (I2 -Int C) => (I1 -Int I2) +Int C [concrete(I1, I2), symbolic(C), simplification]
+  rule (C -Int I2) -Int I3 => C -Int (I2 +Int I3) [concrete(I2, I3), symbolic(C), simplification]
+
+  rule I1 &Int (I2 &Int C) => (I1 &Int I2) &Int C [concrete(I1, I2), symbolic(C), simplification]
+endmodule
+
+module INT
+  imports INT-COMMON
+  imports INT-SYMBOLIC
+  imports INT-KORE
+  imports private K-EQUAL
+  imports private BOOL
+
+  rule bitRangeInt(I::Int, IDX::Int, LEN::Int) => (I >>Int IDX) modInt (1 <<Int LEN)
+
+  rule signExtendBitRangeInt(I::Int, IDX::Int, LEN::Int) => (bitRangeInt(I, IDX, LEN) +Int (1 <<Int (LEN -Int 1))) modInt (1 <<Int LEN) -Int (1 <<Int (LEN -Int 1))
+
+  rule I1:Int divInt I2:Int => (I1 -Int (I1 modInt I2)) /Int I2
+  requires I2 =/=Int 0
+  rule
+    I1:Int modInt I2:Int
+  =>
+    ((I1 %Int absInt(I2)) +Int absInt(I2)) %Int absInt(I2)
+  requires I2 =/=Int 0    [concrete, simplification]
+
+  rule minInt(I1:Int, I2:Int) => I1 requires I1 <=Int I2
+  rule minInt(I1:Int, I2:Int) => I2 requires I1 >=Int I2
+
+  rule I1:Int =/=Int I2:Int => notBool (I1 ==Int I2)
+  rule (I1:Int dividesInt I2:Int) => (I2 %Int I1) ==Int 0
+
+  syntax Int ::= freshInt(Int)    [freshGenerator, function, total, private]
+  rule freshInt(I:Int) => I
+endmodule
+

IEEE 754 Floating-point Numbers

+

Provided here is the syntax of an implementation of arbitrary-precision
+floating-point arithmetic in K based on a generalization of the IEEE 754
+standard. This type is hooked to an implementation of floats provided by the
+backend.

+

The syntax of ordinary floating-point values in K consists of an optional sign
+(+ or -) followed by an optional integer part, followed by a decimal point,
+followed by an optional fractional part. Either the integer part or the
+fractional part must be specified. The mantissa is followed by an optional
+exponent part, which consists of an e or E, an optional sign (+ or -),
+and an integer. The expoennt is followed by an optional suffix, which can be
+either f, F, d, D, or pNxM where N and M are positive integers.
+p and x can be either upper or lowercase.

+

The value of a floating-point literal is computed as follows: First the
+mantissa is read as a rational number. Then it is multiplied by 10 to the
+power of the exponent, which is interpreted as an integer, and defaults to
+zero if it is not present. Finally, it is rounded to the nearest possible
+value in a floating-point type represented like an IEEE754 floating-point type,
+with the number of bits of precision and exponent specified by the suffix.
+A suffix of f or f represents the IEEE binary32 format. A suffix of d
+or D, or no suffix, represents the IEEE binary64 format. A suffix of
+pNxM (either upper or lowercase) specifies exactly N bits of precision and
+M bits of exponent. The number of bits of precision is assumed to include
+any optional 1 that precedes the IEEE 754 mantissa. In other words, p24x8
+is equal to the IEEE binary32 format, and p53x11 is equal to the IEEE
+binary64 format.

+
module FLOAT-SYNTAX
+  syntax Float [hook(FLOAT.Float)]
+  syntax Float ::= r"([\\+-]?[0-9]+(\\.[0-9]*)?|\\.[0-9]+)([eE][\\+-]?[0-9]+)?([fFdD]|([pP][0-9]+[xX][0-9]+))?" [token, prec(1)]
+  syntax Float ::= r"[\\+-]?Infinity([fFdD]|([pP][0-9]+[xX][0-9]+))?" [token, prec(3)]
+  syntax Float ::= r"NaN([fFdD]|([pP][0-9]+[xX][0-9]+))?" [token, prec(3)]
+endmodule
+
+module FLOAT
+  imports FLOAT-SYNTAX
+  imports private BOOL
+  imports private INT-SYNTAX
+

Float precision

+ +

You can retrieve the number of bits of precision in a Float.

+
  syntax Int ::= precisionFloat(Float) [function, total, hook(FLOAT.precision)]
+

Float exponent bits

+ +

You can retrieve the number of bits of exponent range in a Float.

+
  syntax Int ::= exponentBitsFloat(Float) [function, total, hook(FLOAT.exponentBits)]
+

Float exponent

+ +

You can retrieve the value of the exponent bits of a Float as an integer.

+
  syntax Int ::= exponentFloat(Float) [function, total, hook(FLOAT.exponent)]
+

Float sign

+ +

You can retrieve the value of the sign bit of a Float as a boolean. True
+means the sign bit is set.

+
  syntax Bool ::= signFloat(Float)      [function, total, hook(FLOAT.sign)]
+

Float special values

+ +

You can check whether a Float value is infinite or Not-a-Number.

+
  syntax Bool ::= isNaN(Float)          [function, total, smt-hook(fp.isNaN), hook(FLOAT.isNaN)]
+                | isInfinite(Float)     [function, total]
+

Float arithmetic

+ +

You can:

+
    +
  • Compute the unary negation --Float of a float. --Float X is distinct
    +from 0.0 -Float X. For example, 0.0 -Float 0.0 is positive zero.
    +--Float 0.0 is negative zero.
  • +
  • Compute the exponentation ^Float of two floats.
  • +
  • Compute the product *Float, quotient /Float, or remainder %Float of two
    +floats. The remainder is computed based on rounding the quotient of the two
    +floats to the nearest integer.
  • +
  • Compute the sum +Float or difference -Float of two floats.
  • +
+
  syntax Float ::= "--Float" Float             [function, total, smt-hook(fp.neg), hook(FLOAT.neg)]
+                 > Float "^Float" Float        [function, left, latex({#1}^{#2}), hook(FLOAT.pow)]
+                 > left:
+                   Float "*Float" Float        [function, left, smt-hook((fp.mul roundNearestTiesToEven #1 #2)), latex({#1}\mathrel{\ast_{\scriptstyle\it Float}}{#2}), hook(FLOAT.mul)]
+                 | Float "/Float" Float        [function, left, smt-hook((fp.div roundNearestTiesToEven #1 #2)), latex({#1}\mathrel{\div_{\scriptstyle\it Float}}{#2}), hook(FLOAT.div)]
+                 | Float "%Float" Float        [function, left, smt-hook((fp.rem roundNearestTiesToEven #1 #2)), latex({#1}\mathrel{\%_{\scriptstyle\it Float}}{#2}), hook(FLOAT.rem)]
+                 > left:
+                   Float "+Float" Float        [function, left, smt-hook((fp.add roundNearestTiesToEven #1 #2)), latex({#1}\mathrel{+_{\scriptstyle\it Float}}{#2}), hook(FLOAT.add)]
+                 | Float "-Float" Float        [function, left, smt-hook((fp.sub roundNearestTiesToEven #1 #2)), latex({#1}\mathrel{-_{\scriptstyle\it Float}}{#2}), hook(FLOAT.sub)]
+

Floating-point mathematics

+ +

You can:

+
    +
  • Compute the Nth integer root rootFloat of a float.
  • +
  • Compute the absolute value absFloat of a float.
  • +
  • Round a floating-point number to a specified precision and exponent
    +range (roundFloat). The resulting Float will yield the specified values
    +when calling precisionFloat and exponentBitsFloat and when performing
    +further computation.
  • +
  • Round a float to the next lowest floating-point value which is an integer
    +(floorFloat).
  • +
  • Round a float to the next highest floating-point value which is an integer
    +(ceilFloat).
  • +
  • Round a float to the next closest floating-point value which is an integer, in
    +the direction of zero (truncFloat).
  • +
  • Compute the natural exponential expFloat of a float (i.e. e^x).
  • +
  • Compute the natural logarithm logFloat of a float.
  • +
  • Compute the sine sinFloat of a float.
  • +
  • Compute the cosine cosFloat of a float.
  • +
  • Compute the tangent tanFlooat of a float.
  • +
  • Compute the arcsine asinFloat of a float.
  • +
  • Compute the arccosine acosFloat of a float.
  • +
  • Compute the arctangent atanFloat of a float.
  • +
  • Compute the arctangent atan2Float of two floats.
  • +
  • Compute the maximum maxFloat of two floats.
  • +
  • Compute the minimum minFloat of two floats.
  • +
  • Compute the square root sqrtFloat of a float.
  • +
  • Compute the largest finite value expressible in a specified precision and
    +exponent range (maxValueFloat).
  • +
  • Compute the smallest positive finite value expressible in a specified
    +precision and exponent range (minValueFloat).
  • +
+
  syntax Float ::= rootFloat(Float, Int)        [function, hook(FLOAT.root)]
+                 | absFloat(Float)              [function, total, smt-hook(fp.abs), hook(FLOAT.abs)]
+                 | roundFloat(Float, precision: Int, exponentBits: Int)  [function, hook(FLOAT.round)]
+                 | floorFloat(Float)            [function, total, hook(FLOAT.floor)]
+                 | ceilFloat(Float)             [function, total, hook(FLOAT.ceil)]
+                 | truncFloat(Float)            [function, total, hook(FLOAT.trunc)]
+                 | expFloat(Float)              [function, total, hook(FLOAT.exp)]
+                 | logFloat(Float)              [function, hook(FLOAT.log)]
+                 | sinFloat(Float)              [function, total, hook(FLOAT.sin)]
+                 | cosFloat(Float)              [function, total, hook(FLOAT.cos)]
+                 | tanFloat(Float)              [function, hook(FLOAT.tan)]
+                 | asinFloat(Float)             [function, hook(FLOAT.asin)]
+                 | acosFloat(Float)             [function, hook(FLOAT.acos)]
+                 | atanFloat(Float)             [function, total, hook(FLOAT.atan)]
+                 | atan2Float(Float, Float)     [function, hook(FLOAT.atan2)]
+                 | maxFloat(Float, Float)       [function, smt-hook(fp.max), hook(FLOAT.max)]
+                 | minFloat(Float, Float)       [function, smt-hook(fp.min), hook(FLOAT.min)]
+                 | sqrtFloat(Float)             [function]
+                 | maxValueFloat(precision: Int, exponentBits: Int)      [function, hook(FLOAT.maxValue)]
+                 | minValueFloat(precision: Int, exponentBits: Int)      [function, hook(FLOAT.minValue)]
+

Floating-point comparisons

+ +

Compute whether a float is less than or equasl to, less than, greater than or
+equal to, greater than, equal, or unequal to another float. Note that
+X ==Float Y and X ==K Y might yield different values. The latter should be
+used in cases where you want to compare whether two values of sort Float
+contain the same term. The former should be used when you want to implement
+the == operator of a programming language. In particular, NaN =/=Float NaN
+is true, because NaN compares unequal to all values, including itself, in
+IEEE 754 arithmetic. 0.0 ==Float -0.0 is also true.

+
  syntax Bool ::= Float "<=Float" Float       [function, smt-hook(fp.leq), latex({#1}\mathrel{\leq_{\scriptstyle\it Float}}{#2}), hook(FLOAT.le)]
+                | Float "<Float" Float        [function, smt-hook(fp.lt), latex({#1}\mathrel{<_{\scriptstyle\it Float}}{#2}), hook(FLOAT.lt)]
+                | Float ">=Float" Float       [function, smt-hook(fp.geq), latex({#1}\mathrel{\geq_{\scriptstyle\it Float}}{#2}), hook(FLOAT.ge)]
+                | Float ">Float" Float        [function, smt-hook(fg.gt), latex({#1}\mathrel{>_{\scriptstyle\it Float}}{#2}), hook(FLOAT.gt)]
+                | Float "==Float" Float       [function, comm, smt-hook(fp.eq), latex({#1}\mathrel{==_{\scriptstyle\it Float}}{#2}), hook(FLOAT.eq), klabel(_==Float_)]
+                | Float "=/=Float" Float      [function, comm, smt-hook((not (fp.eq #1 #2))), latex({#1}\mathrel{\neq_{\scriptstyle\it Float}}{#2})]
+
+  rule F1:Float =/=Float F2:Float => notBool (F1 ==Float F2)
+

Conversion between integer and float

+ +

You can convert an integer to a floating-point number with the specified
+precision and exponent range. You can also convert a floating-point number
+to the nearest integer. This operation rounds to the nearest integer, but it
+also avoids the double-rounding that is present in ceilFloat and floorFloat
+if the nearest integer is not representable in the specified floating-point
+type.

+
  syntax Float ::= Int2Float(Int, precision: Int, exponentBits: Int)    [function, latex({\\it{}Int2Float}), hook(FLOAT.int2float)]
+  syntax Int ::= Float2Int(Float)    [function, total, latex({\\it{}Float2Int}), hook(FLOAT.float2int)]
+

Implementation of Floats

+ +

The remainder of this section consists of an implementation in K of some of the
+operators above.

+
  rule sqrtFloat(F:Float) => rootFloat(F, 2)
+
+  rule isInfinite(F:Float) => F >Float maxValueFloat(precisionFloat(F), exponentBitsFloat(F)) orBool F <Float --Float maxValueFloat(precisionFloat(F), exponentBitsFloat(F))
+
+endmodule
+

Strings

+

Provided here is the syntax of an implementation of Unicode strings in K. This
+type is hooked to an implementation of strings provided by the backend. The
+implementation is currently incomplete and does not fully support encodings
+and code points beyond the initial 256 code points of the Basic Latin and
+Latin-1 Supplement blocks. In the future, there may be breaking changes to
+the semantics of this module in order to support this functionality.

+

The syntax of strings in K is delineated by double quotes. Inside the double
+quotes, any character can appear verbatim except double quotes, backslash,
+newline, and carriage return. K also supports the following escape sequences:

+
    +
  • " - the " character
  • +
  • \ - the \ character
  • +
  • \n - newline character
  • +
  • \r - carriage return character
  • +
  • \t - tab character
  • +
  • \f - form feed character
  • +
  • \xFF - \x followed by two hexadecimal characters indicates a code point
    +between 0x00 and 0xff
  • +
  • \uFFFF - \u followed by four hexadecimal characters indicates a code point
    +between 0x0000 and 0xffff
  • +
  • \UFFFFFFFF - \U followed by eight hexadecimal characters indicates a code
    +point between 0x000000 and 0x10ffff
  • +
+
module STRING-SYNTAX
+  syntax String [hook(STRING.String)]
+  syntax String ::= r"[\\\"](([^\\\"\\n\\r\\\\])|([\\\\][nrtf\\\"\\\\])|([\\\\][x][0-9a-fA-F]{2})|([\\\\][u][0-9a-fA-F]{4})|([\\\\][U][0-9a-fA-F]{8}))*[\\\"]"      [token]
+endmodule
+
+module STRING-COMMON
+  imports STRING-SYNTAX
+  imports private INT
+  imports private FLOAT-SYNTAX
+  imports private K-EQUAL
+  imports private BOOL
+

String concatenation

+ +

You can concatenate two strings in O(N) time. For successive concatenation
+operations, it may be better to use the STRING-BUFFER module.

+
  syntax String ::= String "+String" String    [function, total, left, latex({#1}+_{\scriptstyle\it String}{#2}), hook(STRING.concat)]
+

String length

+ +

You can get the length of a string in O(1) time.

+
  syntax Int ::= lengthString ( String ) [function, total, hook(STRING.length)]
+

Character and integer conversion

+ +

You can convert between a character (as represented by a string containing
+a single code point) and an integer in O(1) time.

+
  syntax String ::= chrChar ( Int )      [function, hook(STRING.chr)]
+  syntax Int ::= ordChar ( String )      [function, hook(STRING.ord)]
+

String substring

+ +

You can compute a substring of a string in O(N) time (where N is the
+length of the substring). There are two important facts to note:

+
    +
  1. the range generated includes the character at startIndex but excludes the
    +character at endIndex, i.e., the range is [startIndex..endIndex).
  2. +
  3. this function is only defined on valid indices (i.e., it is defined when
    +startIndex < endIndex and endIndex is less than or equal to the string
    +length).
  4. +
+
  syntax String ::= substrString ( String , startIndex: Int , endIndex: Int ) [function, total, hook(STRING.substr)]
+
+ +

You can find the first (respectively, last) occurrence of a substring, starting
+at a certain index, in another string in O(N*M) time.
+Returns -1 if the substring is not found.

+
  syntax Int ::= findString ( haystack: String , needle: String , index: Int )   [function, hook(STRING.find)]
+  syntax Int ::= rfindString ( haystack: String , needle: String , index: Int )  [function, hook(STRING.rfind)]
+
+ +

You can find the first (respectively, last) occurrence of one of the characters
+of the search string, starting at a certain index, in another string in
+O(N*M) time.

+
  syntax Int ::= findChar ( haystack: String , needles: String , index: Int )     [function, hook(STRING.findChar)]
+  syntax Int ::= rfindChar ( haystack: String , needles: String , index: Int )    [function, hook(STRING.rfindChar)]
+

String and Bool conversion

+ +
  syntax String ::= Bool2String(Bool) [function, total]
+  rule Bool2String(true)  => "true"
+  rule Bool2String(false) => "false"
+
  syntax Bool ::= String2Bool(String) [function]
+  rule String2Bool("true")  => true
+  rule String2Bool("false") => false
+

String and float conversion

+ +

You can convert between a String and a Float. The String will be
+represented in the syntax of the Float sort (see the section on the FLOAT
+module above for details of that syntax). Which particular string is returned
+by Float2String is determined by the backend, but the same Float is
+guaranteed to return the same String, and converting that String back to a
+Float is guaranteed to return the original Float.

+

You can also convert a Float to a string in a particular syntax using the
+variant of Float2String with a format. In this case, the resulting string
+is one which results directly from passing that format to mpfr_printf. This
+functionality may not be supported on backends that do not use Gnu MPFR to
+implement floating-point numbers.

+
  syntax String ::= Float2String ( Float )              [function, total, hook(STRING.float2string)]
+  syntax String ::= Float2String ( Float , format: String )     [function, klabel(FloatFormat), hook(STRING.floatFormat)]
+  syntax Float  ::= String2Float ( String )             [function, hook(STRING.string2float)]
+

String and integer conversions

+ +

You can convert between a String and an Int. The String will be represented
+in the syntax of the INT module (i.e., a nonempty sequence of digits
+optionally prefixed by a sign). When converting from an Int to a String,
+the sign will not be present unless the integer is negative.

+

You can also convert between a String and an Int in a particular radix.
+This radix can be anywhere between 2 and 36. For a radix 2 <= N <= 10, the
+digits 0 to N-1 will be used. For a radix 11 <= N <= 36, the digits 0 to 9
+and the first N-10 letters of the Latin alphabet will be used. Both uppercase
+and lowercase letters are supported by String2Base. Whether the letters
+returned by Base2String are upper or lowercase is determined by the backend,
+but the backend will consistently choose one or the other.

+
  syntax Int    ::= String2Int   ( String )             [function, hook(STRING.string2int)]
+  syntax String ::= Int2String   ( Int )                [function, total, hook(STRING.int2string)]
+  syntax String ::= Base2String  ( Int , base: Int )          [function, hook(STRING.base2string)]
+  syntax Int    ::= String2Base  ( String , base: Int )       [function, hook(STRING.string2base)]
+

String count and replace

+ +

You can replace one, some, or all occurrences of a string within another
+string in O(N*M) time. The replaceAll, replace, and replaceFirst methods
+are identical, except replaceFirst replaces exactly one ocurrence of the
+string, the first occurrence. replace replaces the first times occurrences.
+And replaceAll replaces every occurrence.

+

You can also count the number of times a string occurs within another string
+using countAllOccurrences.

+
  syntax String ::= "replaceAll" "(" haystack: String "," needle: String "," replacement: String ")"      [function, total, hook(STRING.replaceAll)]
+  syntax String ::= "replace" "(" haystack: String "," needle: String "," replacement: String "," times: Int ")" [function, hook(STRING.replace)]
+  syntax String ::= "replaceFirst" "(" haystack: String "," needle: String "," replacement: String ")"    [function, total, hook(STRING.replaceFirst)]
+  syntax Int ::= "countAllOccurrences" "(" haystack: String "," needle: String ")"            [function, total, hook(STRING.countAllOccurrences)]
+

String equality and lexicographic comparison

+ +

You can compare whether two strings are equal or unequal, or whether one string
+is less than, less than or equal to, greater than, or greater than or equal to
+another according to the natural lexicographic ordering of strings.

+
  syntax Bool ::= String "==String" String  [function, total, comm, hook(STRING.eq)]
+                | String "=/=String" String [function, total, comm, hook(STRING.ne)]
+  rule S1:String =/=String S2:String => notBool (S1 ==String S2)
+
+  syntax Bool ::= String  "<String" String [function, total, hook(STRING.lt)]
+                | String "<=String" String [function, total, hook(STRING.le)]
+                | String  ">String" String [function, total, hook(STRING.gt)]
+                | String ">=String" String [function, total, hook(STRING.ge)]
+

Implementation of Strings

+ +

What follows is a few String hooks which are deprecated and only are supported
+on certain outdated backends of K, as well as an implementation of several
+of the above operations in K.

+
  syntax String ::= categoryChar(String)       [function, hook(STRING.category)]
+                  | directionalityChar(String) [function, hook(STRING.directionality)]
+
+  syntax String ::= "newUUID" [function, hook(STRING.uuid), impure]
+
+  rule S1:String <=String S2:String => notBool (S2 <String S1)
+  rule S1:String >String S2:String => S2 <String S1
+  rule S1:String >=String S2:String => notBool (S1 <String S2)
+
+  rule findChar(S1:String, S2:String, I:Int) => #if findString(S1, substrString(S2, 0, 1), I) ==Int -1 #then findChar(S1, substrString(S2, 1, lengthString(S2)), I) #else #if findChar(S1, substrString(S2, 1, lengthString(S2)), I) ==Int -1 #then findString(S1, substrString(S2, 0, 1), I) #else minInt(findString(S1, substrString(S2, 0, 1), I), findChar(S1, substrString(S2, 1, lengthString(S2)), I)) #fi #fi requires S2 =/=String ""
+  rule findChar(_, "", _) => -1
+  rule rfindChar(S1:String, S2:String, I:Int) => maxInt(rfindString(S1, substrString(S2, 0, 1), I), rfindChar(S1, substrString(S2, 1, lengthString(S2)), I)) requires S2 =/=String ""
+  rule rfindChar(_, "", _) => -1
+
+  rule countAllOccurrences(Source:String, ToCount:String) => 0
+            requires findString(Source, ToCount, 0) <Int 0
+  rule countAllOccurrences(Source:String, ToCount:String) => 1 +Int countAllOccurrences(substrString(Source, findString(Source, ToCount, 0) +Int lengthString(ToCount), lengthString(Source)), ToCount)
+            requires findString(Source, ToCount, 0) >=Int 0
+
+  rule replaceFirst(Source:String, ToReplace:String, Replacement:String) => substrString(Source, 0, findString(Source, ToReplace, 0))
+                +String Replacement +String substrString(Source, findString(Source, ToReplace, 0) +Int lengthString(ToReplace), lengthString(Source))
+                requires findString(Source, ToReplace, 0) >=Int 0
+  rule replaceFirst(Source:String, ToReplace:String, _:String) => Source
+        requires findString(Source, ToReplace, 0) <Int 0
+
+
+  rule replace(Source:String, ToReplace:String, Replacement:String, Count:Int) =>
+       substrString(Source, 0, findString(Source, ToReplace, 0)) +String Replacement +String
+       replace(substrString(Source, findString(Source, ToReplace, 0) +Int lengthString(ToReplace), lengthString(Source)), ToReplace, Replacement, Count -Int 1)
+        requires Count >Int 0
+  rule replace(Source:String, _, _, 0) => Source
+  rule replaceAll(Source:String, ToReplace:String, Replacement:String) => replace(Source, ToReplace, Replacement, countAllOccurrences(Source, ToReplace))
+
+endmodule
+
+module STRING-KORE [kore, symbolic]
+  imports private K-EQUAL
+  imports STRING-COMMON
+
+  rule S1:String ==K S2:String => S1 ==String S2 [simplification]
+
+endmodule
+
+module STRING
+  imports STRING-COMMON
+  imports STRING-KORE
+endmodule
+

String Buffers

+

It is a well known fact that repeated string concatenations are quadratic
+in performance whereas use of an efficient mutable representation of arrays
+can yield linear performance. We thus provide such a sort, the StringBuffer
+sort. Axiomatically, it is implemented below on symbolic backends using the
+String module. However, on concrete backends it provides an efficient
+implementation of string concatenation. There are three operations:

+
    +
  • .StringBuffer creates a new StringBuffer with current content equal
    +to the empty string.
  • +
  • +String takes a StringBuffer and a String and appends the String to
    +the end of the StringBuffer
  • +
  • StringBuffer2String converts a StringBuffer to a String. This operation
    +copies the string so that subsequent modifications to the StringBuffer
    +will not change the value of the String returned by this function.
  • +
+
module STRING-BUFFER-IN-K [symbolic]
+  imports private BASIC-K
+  imports STRING
+
+  syntax StringBuffer ::= ".StringBuffer" [function, total]
+  syntax StringBuffer ::= StringBuffer "+String" String [function, total, avoid]
+  syntax StringBuffer ::= String
+  syntax String ::= StringBuffer2String ( StringBuffer ) [function, total]
+
+  rule {SB:String +String S:String}<:StringBuffer => (SB +String S)::String
+  rule .StringBuffer => ""
+  rule StringBuffer2String(S:String) => S
+endmodule
+
+module STRING-BUFFER-HOOKED [concrete]
+  imports private BASIC-K
+  imports STRING
+
+  syntax StringBuffer [hook(BUFFER.StringBuffer)]
+  syntax StringBuffer ::= ".StringBuffer" [function, total, hook(BUFFER.empty), impure]
+  syntax StringBuffer ::= StringBuffer "+String" String [function, total, hook(BUFFER.concat), avoid]
+  syntax String ::= StringBuffer2String ( StringBuffer ) [function, total, hook(BUFFER.toString)]
+endmodule
+
+module STRING-BUFFER
+  imports STRING-BUFFER-HOOKED
+  imports STRING-BUFFER-IN-K
+endmodule
+

Byte Arrays

+

Provided here is the syntax of an implementation of fixed-width arrays of Bytes
+in K. This type is hooked to an implementation of bytes provided by the
+backend. In concrete backends, this representation is mutable and thus multiple
+references can occur to the same Bytes object and when one is modified, the
+others are also modified. Care should be taken not to rely on this fact however
+as this is not the case in symbolic backends and thus you will experience
+divergent behavior unless the Bytes type is used in a manner that preserves
+consistency.

+
module BYTES-SYNTAX
+  imports private STRING-SYNTAX
+
+  syntax Bytes [hook(BYTES.Bytes)]
+  syntax Bytes ::= r"b[\\\"](([\\x20\\x21\\x23-\\x5B\\x5D-\\x7E])|([\\\\][tnfr\\\"\\\\])|([\\\\][x][0-9a-fA-F]{2}))*[\\\"]"      [token]
+endmodule
+
module BYTES-STRING-ENCODE [kore, symbolic]
+  imports BYTES-SYNTAX
+

Encoding/decoding between Bytes and String

+ +

You can encode/decode between Bytes and String using UTF-8, UTF-16LE, UTF-16BE, UTF-32LE, and UTF-32BE

+
    syntax String ::= decodeBytes ( encoding: String , contents: Bytes ) [function, hook(BYTES.decodeBytes)]
+    syntax Bytes ::= encodeBytes ( encoding: String , contents: String ) [function, hook(BYTES.encodeBytes)]
+endmodule
+
module BYTES-HOOKED
+  imports STRING-SYNTAX
+  imports BYTES-SYNTAX
+  imports BYTES-STRING-ENCODE
+

Empty byte array

+ +

The byte array of length zero is represented by .Bytes.

+
  syntax Bytes ::= ".Bytes" [function, total, hook(BYTES.empty)]
+

Endianness

+ +

When converting to/from an integer, byte arrays can be treated as either little
+endian (ie, least significant byte first) or big endian (ie, most significant
+byte first).

+
  syntax Endianness ::= "LE" [klabel(littleEndianBytes), symbol]
+                      | "BE" [klabel(bigEndianBytes), symbol]
+

Signedness

+ +

When converting to/from an integer, byte arrays can be treated as either signed
+or unsigned.

+
  syntax Signedness ::= "Signed" [klabel(signedBytes), symbol]
+                      | "Unsigned" [klabel(unsignedBytes), symbol]
+

Integer and Bytes conversion

+ +

You can convert from a Bytes to an Int. In order to do this, the endianness
+and signedness of the Bytes must be provided. The resulting integer is
+created by means of interpreting the Bytes as either a twos-complement
+representation, or an unsigned representation, of an integer, in the specified
+byte order.

+

You can also convert from an Int to a Bytes. This comes in two variants.
+In the first, the length of the resulting Bytes in bytes is explicitly
+specified. If the length is greater than the highest set bit in the magnitude
+of the integer, the result is padded with 0 bits if the number is positive
+and 1 bits if the number is negative. If the length is less than the highest
+bit set in the magnitude of the integer, the most-significant bits of the
+integer will be truncated. The endianness of the resulting Bytes object
+is as specified.

+

In the second variant, both endianness and signedness are specified, and
+the resulting Bytes object will be the smallest number of bytes necessary
+for the resulting Bytes object to be convertible back to the original integer
+via Bytes2Int. In other words, if the highest bit set in the magnitude of the
+integer is N, then the byte array will be at least N+1 bits long, rounded up
+to the nearest byte.

+
  syntax Int ::= Bytes2Int(Bytes, Endianness, Signedness) [function, total, hook(BYTES.bytes2int)]
+  syntax Bytes ::= Int2Bytes(length: Int, Int, Endianness) [function, total, hook(BYTES.int2bytes)]
+                 | Int2Bytes(Int, Endianness, Signedness) [function, total, klabel(Int2BytesNoLen)]
+

String and Bytes conversion

+ +

You can convert between a Bytes and a String in O(N) time. The resulting
+value is a copy of the original and will not be affected by subsequent
+mutations of the input or output value.

+
  syntax String ::= Bytes2String(Bytes) [function, total, hook(BYTES.bytes2string)]
+  syntax Bytes ::= String2Bytes(String) [function, total, hook(BYTES.string2bytes)]
+

Bytes update

+ +

You can set the value of a particular byte in a Bytes object in O(1) time.
+The result is #False if value is not in the range [0..255] or if index
+is not a valid index (ie, less than zero or greater than or equal to the length
+of the Bytes term).

+
  syntax Bytes ::= Bytes "[" index: Int "<-" value: Int "]" [function, hook(BYTES.update)]
+

Bytes lookup

+ +

You can get the value of a particular byte in a Bytes object in O(1) time.
+The result is #False if index is not a valid index (see above).

+
  syntax Int ::= Bytes "[" Int "]" [function, hook(BYTES.get)]
+

Bytes substring

+ +

You can get a new Bytes object containing a range of bytes from the input
+Bytes in O(N) time (where N is the length of the substring). The range
+of bytes included is [startIndex..endIndex). The resulting Bytes is
+a copy and mutations to it do not affect mutations to the original Bytes.
+The result is #False if startIndex or endIndex are not valid.

+
  syntax Bytes ::= substrBytes(Bytes, startIndex: Int, endIndex: Int) [function, hook(BYTES.substr)]
+

Multiple bytes update

+ +

You can modify a Bytes to return a Bytes which is equal to dest except
+the N elements starting at index are replaced with the contents of src in
+O(N) time. This does not create a new Bytes object and will instead modify
+the original on concrete backends. The result is #False if index + N
+is not a valid index.

+
  syntax Bytes ::= replaceAtBytes(dest: Bytes, index: Int, src: Bytes) [function, hook(BYTES.replaceAt)]
+

Multiple bytes update

+ +

You can modify a Bytes to return a Bytes which is equal to dest except
+the count bytes starting at index are replaced with count bytes of value
+Int2Bytes(1, v, LE/BE) in O(count) time. This does not create a new Bytes
+object and will instead modify the original on concrete backends.
+This will throw an exception if index + count is not a valid index.
+The acceptable range of values for v is -128 to 127. This will throw an
+exception if v is outside of this range.
+This is implemented only for the LLVM backend.

+
  syntax Bytes ::= memsetBytes(dest: Bytes, index: Int, count: Int, v: Int) [function, hook(BYTES.memset)]
+

Bytes padding

+ +

You can create a new Bytes object which is at least length bytes long
+by taking the input sequence and padding it on the right (respectively, on the
+left) with the specified value. This does not create a new Bytes object
+if the input is already at least length bytes long, and will instead
+return the input unchanged. The result is #False if value is not in the
+range [0..255], or if the length is negative.

+
  syntax Bytes ::= padRightBytes(Bytes, length: Int, value: Int) [function, hook(BYTES.padRight)]
+                 | padLeftBytes(Bytes, length: Int, value: Int) [function, hook(BYTES.padLeft)]
+

Bytes reverse

+ +

You can reverse a Bytes object in O(N) time. This does not create a new
+Bytes object and will instead modify the original on concrete backends.

+
  syntax Bytes ::= reverseBytes(Bytes) [function, total, hook(BYTES.reverse)]
+

Bytes length

+ +

You can get the length of a Bytes term in O(1) time.

+
  syntax Int ::= lengthBytes(Bytes) [function, total, hook(BYTES.length), smtlib(lengthBytes)]
+

Bytes concatenation

+ +

You can create a new Bytes object by concatenating two Bytes objects
+together in O(N) time.

+
  syntax Bytes ::= Bytes "+Bytes" Bytes [function, total, hook(BYTES.concat), right]
+
+endmodule
+

Implementation of Bytes

+ +

The remainder of this module consists of an implementation of some of the
+operators listed above in K.

+
module BYTES-CONCRETE [concrete]
+  imports BYTES-HOOKED
+endmodule
+
+module BYTES-KORE [kore]
+  imports BYTES-HOOKED
+  imports BYTES-SYMBOLIC-CEIL
+endmodule
+
+module BYTES-SYMBOLIC-CEIL [symbolic, kore]
+  imports BYTES-HOOKED
+  imports private INT
+  imports private BOOL
+
+  rule #Ceil(padRightBytes(_, LEN, VAL)) => {(0 <=Int LEN andBool 0 <=Int VAL andBool VAL <Int 256) #Equals true} [simplification]
+  rule #Ceil(padLeftBytes(_, LEN, VAL))  => {(0 <=Int LEN andBool 0 <=Int VAL andBool VAL <Int 256) #Equals true} [simplification]
+endmodule
+
+module BYTES
+  imports BYTES-CONCRETE
+  imports BYTES-KORE
+  imports private INT
+
+  rule Int2Bytes(I::Int, E::Endianness, Unsigned) => Int2Bytes((log2Int(I) +Int 8) /Int 8, I, E)
+    requires I >Int 0
+  rule Int2Bytes(0, _::Endianness, _) => .Bytes
+  rule Int2Bytes(I::Int, E::Endianness, Signed) => Int2Bytes((log2Int(I) +Int 9) /Int 8, I, E)
+    requires I >Int 0
+  rule Int2Bytes(I::Int, E::Endianness, Signed) => Int2Bytes((log2Int(~Int I) +Int 9) /Int 8, I, E)
+    requires I <Int -1
+  rule Int2Bytes(-1, E::Endianness, Signed) => Int2Bytes(1, -1, E)
+endmodule
+

Program identifiers

+

Provided here is an implementation for program identifiers in K. Developers
+of semantics for a particular language may wish to use their own implementation
+instead of the one provided here if their syntax differs from the syntax
+defined below. However, this is provided for convenience for developers who
+do not care about the lexical syntax of identifiers.

+

Provided are the following pieces of functionality:

+
    +
  • Id2String - Convert an Id to a String containing its name
  • +
  • String2Id - Convert a String to an Id with the specified name
  • +
  • !X:Id - You can get a fresh identifier distinct from any previous identifier
    +generated by this syntax.
  • +
+
module ID-SYNTAX-PROGRAM-PARSING
+  imports BUILTIN-ID-TOKENS
+  syntax Id ::= r"(?<![A-Za-z0-9\\_])[A-Za-z\\_][A-Za-z0-9\\_]*"     [prec(1), token]
+              | #LowerId                                             [token]
+              | #UpperId                                             [token]
+endmodule
+
+module ID-SYNTAX
+  syntax Id [token]
+endmodule
+
+module ID-COMMON
+  imports ID-SYNTAX
+  imports private STRING
+
+  syntax String ::= Id2String ( Id )    [function, total, hook(STRING.token2string)]
+  syntax Id ::= String2Id (String) [function, total, hook(STRING.string2token)]
+  syntax Id ::= freshId(Int)    [freshGenerator, function, total, private]
+
+  rule freshId(I:Int) => String2Id("_" +String Int2String(I))
+endmodule
+
+module ID
+  imports ID-COMMON
+endmodule
+

Equality and conditionals

+

Provided here are implementations of two important primitives in K:

+
    +
  • ==K - the equality between two terms. Returns true if they are equal
    +and false if they are not equal.
  • +
  • #if #then #else #fi - polymorphic conditional function. If the first
    +argument evaluates to true, the second argument is returned. Otherwise,
    +the third argument is returned. Note that this does not short-circuit on
    +symbolic backends.
  • +
+
module K-EQUAL-SYNTAX
+  imports private BOOL
+  imports private BASIC-K
+
+  syntax Bool ::= left:
+                  K "==K" K           [function, total, comm, smt-hook(=), hook(KEQUAL.eq), klabel(_==K_), symbol, latex({#1}\mathrel{=_K}{#2}), group(equalEqualK)]
+                | K "=/=K" K          [function, total, comm, smt-hook(distinct), hook(KEQUAL.ne), klabel(_=/=K_), symbol, latex({#1}\mathrel{\neq_K}{#2}), group(notEqualEqualK)]
+
+  syntax priorities equalEqualK notEqualEqualK > boolOperation mlOp
+
+  syntax {Sort} Sort ::= "#if" Bool "#then" Sort "#else" Sort "#fi"   [function, total, smt-hook(ite), hook(KEQUAL.ite)]
+
+endmodule
+
+module K-EQUAL-KORE [kore, symbolic]
+  import private BOOL
+  import K-EQUAL-SYNTAX
+
+  rule K1:Bool ==K K2:Bool => K1 ==Bool K2 [simplification]
+  rule {K1 ==K K2 #Equals true} => {K1 #Equals K2} [simplification]
+  rule {true #Equals K1 ==K K2} => {K1 #Equals K2} [simplification]
+  rule {K1 ==K K2 #Equals false} => #Not({K1 #Equals K2}) [simplification]
+  rule {false #Equals K1 ==K K2} => #Not({K1 #Equals K2}) [simplification]
+  rule {K1 =/=K K2 #Equals true} => #Not({K1 #Equals K2}) [simplification]
+  rule {true #Equals K1 =/=K K2} => #Not({K1 #Equals K2}) [simplification]
+  rule {K1 =/=K K2 #Equals false} => {K1 #Equals K2} [simplification]
+  rule {false #Equals K1 =/=K K2} => {K1 #Equals K2} [simplification]
+
+endmodule
+
+module K-EQUAL
+  import private BOOL
+  import K-EQUAL-SYNTAX
+  import K-EQUAL-KORE
+
+  rule K1:K =/=K K2:K => notBool (K1 ==K K2)
+
+  rule #if C:Bool #then B1::K #else _ #fi => B1 requires C
+  rule #if C:Bool #then _ #else B2::K #fi => B2 requires notBool C
+
+endmodule
+

Meta operations

+

Provided below are a few miscellaneous, mostly deprecated functions in K.
+It is not recommended to use any of them directly as they are largely
+unsupported in modern K. There are a few exceptions:

+
    +
  • #getenv - Returns the value of an environment variable
  • +
  • #parseKORE - Takes a String containing a K intermediate representation of
    +a term such as is returned by kast -o kore and converts it to a term.
    +This is NOT type-safe. The responsibility is on the user to ensure that the
    +string they provide is a valid representation of a term of the sort exactly
    +equal to the sort where the function appears.
  • +
  • #kompiledDirectory - Returns the path to the current compiled K definition
    +directory.
  • +
  • #unparseKORE = Takes a K term and converts it to a string.
  • +
+
module K-REFLECTION
+  imports BASIC-K
+  imports STRING
+
+  syntax K ::= "#configuration" [function, impure, hook(KREFLECTION.configuration)]
+  syntax String ::= #sort(K) [function, hook(KREFLECTION.sort)]
+  syntax KItem ::= #fresh(String)   [function, hook(KREFLECTION.fresh), impure]
+  syntax KItem ::= getKLabel(K)  [function, hook(KREFLECTION.getKLabel)]
+
+  syntax K ::= #getenv(String) [function, impure, hook(KREFLECTION.getenv)]
+
+  syntax String ::= #kompiledDirectory() [function, hook(KREFLECTION.kompiledDir)]
+
+  // meaningful only for the purposes of compilation to a binary, otherwise
+  // undefined
+  syntax List ::= #argv() [function, hook(KREFLECTION.argv)]
+
+  // Takes as input a string and returns a K term
+  syntax {Sort} Sort ::= #parseKORE(String) [function, hook(KREFLECTION.parseKORE)]
+  syntax {Sort} String ::= #unparseKORE(Sort) [function, hook(KREFLECTION.printKORE)]
+  syntax IOError ::= "#noParse" "(" String ")" [klabel(#noParse), symbol]
+
+endmodule
+

I/O in K

+

Concrete execution in K supports I/O operations. This functionality is not
+supported during symbolic execution, because symbolic execution must exist
+completely free of side-effects, and I/O is an irreducible type of side effect.
+However, it is useful in many cases when defining concrete execution to be able
+to make reference to I/O operations.

+

The design of these I/O operations is based on the POSIX standard, for the most
+part. For example, the #read K function maps to the read POSIX function. We
+do not at this time have a higher-level API for I/O, but this may be
+implemented at some point in the future.

+

I/O operations generally return either their result, or an IOError term
+corresponding to the errno returned by the underlying system call.

+
module K-IO
+  imports private LIST
+  imports private STRING
+  imports private INT
+

I/O errors

+ +

Aside from EOF, which is returned by #getc if the file is at end-of-file, all
+of the below I/O errors correspond to possible values for errno after calling
+a library function. If the errno returned is not one of the below errnos
+known to K, #unknownIOError is returned along with the integer errno value.

+
  syntax IOError ::= "#EOF" [klabel(#EOF), symbol] | #unknownIOError(errno: Int) [symbol]
+                   | "#E2BIG" [klabel(#E2BIG), symbol]
+                   | "#EACCES" [klabel(#EACCES), symbol]
+                   | "#EAGAIN" [klabel(#EAGAIN), symbol]
+                   | "#EBADF" [klabel(#EBADF), symbol]
+                   | "#EBUSY" [klabel(#EBUSY), symbol]
+                   | "#ECHILD" [klabel(#ECHILD), symbol]
+                   | "#EDEADLK" [klabel(#EDEADLK), symbol]
+                   | "#EDOM" [klabel(#EDOM), symbol]
+                   | "#EEXIST" [klabel(#EEXIST), symbol]
+                   | "#EFAULT" [klabel(#EFAULT), symbol]
+                   | "#EFBIG" [klabel(#EFBIG), symbol]
+                   | "#EINTR" [klabel(#EINTR), symbol]
+                   | "#EINVAL" [klabel(#EINVAL), symbol]
+                   | "#EIO" [klabel(#EIO), symbol]
+                   | "#EISDIR" [klabel(#EISDIR), symbol]
+                   | "#EMFILE" [klabel(#EMFILE), symbol]
+                   | "#EMLINK" [klabel(#EMLINK), symbol]
+                   | "#ENAMETOOLONG" [klabel(#ENAMETOOLONG), symbol]
+                   | "#ENFILE" [klabel(#ENFILE), symbol]
+                   | "#ENODEV" [klabel(#ENODEV), symbol]
+                   | "#ENOENT" [klabel(#ENOENT), symbol]
+                   | "#ENOEXEC" [klabel(#ENOEXEC), symbol]
+                   | "#ENOLCK" [klabel(#ENOLCK), symbol]
+                   | "#ENOMEM" [klabel(#ENOMEM), symbol]
+                   | "#ENOSPC" [klabel(#ENOSPC), symbol]
+                   | "#ENOSYS" [klabel(#ENOSYS), symbol]
+                   | "#ENOTDIR" [klabel(#ENOTDIR), symbol]
+                   | "#ENOTEMPTY" [klabel(#ENOTEMPTY), symbol]
+                   | "#ENOTTY" [klabel(#ENOTTY), symbol]
+                   | "#ENXIO" [klabel(#ENXIO), symbol]
+                   | "#EPERM" [klabel(#EPERM), symbol]
+                   | "#EPIPE" [klabel(#EPIPE), symbol]
+                   | "#ERANGE" [klabel(#ERANGE), symbol]
+                   | "#EROFS" [klabel(#EROFS), symbol]
+                   | "#ESPIPE" [klabel(#ESPIPE), symbol]
+                   | "#ESRCH" [klabel(#ESRCH), symbol]
+                   | "#EXDEV" [klabel(#EXDEV), symbol]
+                   | "#EWOULDBLOCK" [klabel(#EWOULDBLOCK), symbol]
+                   | "#EINPROGRESS" [klabel(#EINPROGRESS), symbol]
+                   | "#EALREADY" [klabel(#EALREADY), symbol]
+                   | "#ENOTSOCK" [klabel(#ENOTSOCK), symbol]
+                   | "#EDESTADDRREQ" [klabel(#EDESTADDRREQ), symbol]
+                   | "#EMSGSIZE" [klabel(#EMSGSIZE), symbol]
+                   | "#EPROTOTYPE" [klabel(#EPROTOTYPE), symbol]
+                   | "#ENOPROTOOPT" [klabel(#ENOPROTOOPT), symbol]
+                   | "#EPROTONOSUPPORT" [klabel(#EPROTONOSUPPORT), symbol]
+                   | "#ESOCKTNOSUPPORT" [klabel(#ESOCKTNOSUPPORT), symbol]
+                   | "#EOPNOTSUPP" [klabel(#EOPNOTSUPP), symbol]
+                   | "#EPFNOSUPPORT" [klabel(#EPFNOSUPPORT), symbol]
+                   | "#EAFNOSUPPORT" [klabel(#EAFNOSUPPORT), symbol]
+                   | "#EADDRINUSE" [klabel(#EADDRINUSE), symbol]
+                   | "#EADDRNOTAVAIL" [klabel(#EADDRNOTAVAIL), symbol]
+                   | "#ENETDOWN" [klabel(#ENETDOWN), symbol]
+                   | "#ENETUNREACH" [klabel(#ENETUNREACH), symbol]
+                   | "#ENETRESET" [klabel(#ENETRESET), symbol]
+                   | "#ECONNABORTED" [klabel(#ECONNABORTED), symbol]
+                   | "#ECONNRESET" [klabel(#ECONNRESET), symbol]
+                   | "#ENOBUFS" [klabel(#ENOBUFS), symbol]
+                   | "#EISCONN" [klabel(#EISCONN), symbol]
+                   | "#ENOTCONN" [klabel(#ENOTCONN), symbol]
+                   | "#ESHUTDOWN" [klabel(#ESHUTDOWN), symbol]
+                   | "#ETOOMANYREFS" [klabel(#ETOOMANYREFS), symbol]
+                   | "#ETIMEDOUT" [klabel(#ETIMEDOUT), symbol]
+                   | "#ECONNREFUSED" [klabel(#ECONNREFUSED), symbol]
+                   | "#EHOSTDOWN" [klabel(#EHOSTDOWN), symbol]
+                   | "#EHOSTUNREACH" [klabel(#EHOSTUNREACH), symbol]
+                   | "#ELOOP" [klabel(#ELOOP), symbol]
+                   | "#EOVERFLOW" [klabel(#EOVERFLOW), symbol]
+

I/O result sorts

+ +

Here we see sorts defined to contain either an Int or an IOError, or
+either a String or an IOError. These sorts are used to implement the
+return sort of functions that may succeed, in which case they return a value,
+or may fail, in which case their return value indicates an error and the
+error indicated is returned via errno.

+
  syntax IOInt ::= Int | IOError
+  syntax IOString ::= String | IOError
+

Opening a file

+ +

You can open a file in K using #open. An optional mode indicates the file
+open mode, which can have any value allowed by the fopen function in C.
+The returned value is the file descriptor that was opened, or an error.

+
  syntax IOInt ::= "#open" "(" path: String ")" [function]
+               | "#open" "(" path: String "," mode: String ")" [function, hook(IO.open), impure]
+
+  rule #open(S:String) => #open(S:String, "r+")
+

Get/set position in file

+ +

You can get the current offset in a file using #tell. You can also seek
+to a particular offset using #seek or #seekEnd. #seek is implemented via
+a call to lseek with the SEEK_SET whence. #seekEnd is implemented via a
+call to lseek with the SEEK_END whence. You can emulate the SEEK_CUR
+whence by means of #seek(FD, #tell(FD) +Int Offset).

+
  syntax IOInt ::= "#tell" "(" fd: Int ")" [function, hook(IO.tell), impure]
+  syntax K ::= "#seek" "(" fd: Int "," index: Int ")" [function, hook(IO.seek), impure]
+             | "#seekEnd" "(" fd: Int "," fromEnd: Int ")" [function, hook(IO.seekEnd), impure]
+

Read from file

+ +

You can read a single character from a file using #getc. #EOF is returned
+if you are at end-of-fie.

+

You can also read up to length characters in a file using #read. The
+resulting read characters are returned, which may be fewer characters than
+requested. A string of zero length being returned indicates end-of-file.

+
  syntax IOInt ::= "#getc" "(" fd: Int ")"             [function, hook(IO.getc), impure]
+  syntax IOString ::= "#read" "(" fd: Int "," length: Int ")"    [function, hook(IO.read), impure]
+

Write to file

+ +

You can write a single character to a file using #putc. You can also write
+a string to a file using #write. The returned value on success is .K.

+
  syntax K ::= "#putc" "(" fd: Int "," value: Int ")"      [function, hook(IO.putc), impure]
+             | "#write" "(" fd: Int "," value: String ")" [function, hook(IO.write), impure]
+

Closing a file

+ +

You can close a file using #close. The returned value on success is .K.

+
  syntax K ::= "#close" "(" fd: Int ")" [function, hook(IO.close), impure]
+

Locking/unlocking a file

+ +

You can lock or unlock parts of a file using the #lock and #unlock
+functions. The lock starts at the beginning of the file and continues for
+endIndex bytes. Note that Unix systems do not actually prevent locked files
+from being read and modified; you will have to lock both sides of a concurrent
+access to guarantee exclusivity.

+
  syntax K ::= "#lock" "(" fd: Int "," endIndex: Int ")" [function, hook(IO.lock), impure]
+             | "#unlock" "(" fd: Int "," endIndex: Int ")" [function, hook(IO.unlock), impure]
+

Networking

+ +

You can accept a connection on a socket using #accept, or shut down the
+write end of a socket with #shutdownWrite. Note that facility is not provided
+for opening, binding, and listening on sockets. These functions are implemented
+in order to support creating stateful request/response servers where the
+request loop is implemented using rewriting in K, but the connection
+initialization is written in native code and linked into the LLVM backend.

+
  syntax IOInt ::= "#accept" "(" fd: Int ")" [function, hook(IO.accept), impure]
+  syntax K ::= "#shutdownWrite" "(" fd: Int ")" [function, hook(IO.shutdownWrite), impure]
+

Time

+ +

You can get the current time in seconds since midnight UTC on January 1, 1970
+using #time.

+
  syntax Int ::= "#time" "(" ")" [function, hook(IO.time), impure]
+

Builtin file descriptors

+ +

Provided here are functions that return the file descriptor for standard input,
+standard output, and standard error.

+
  syntax Int ::= "#stdin"   [function, total]
+                | "#stdout" [function, total]
+                | "#stderr" [function, total]
+
+  rule #stdin => 0
+  rule #stdout => 1
+  rule #stderr => 2
+

Shell access

+ +

You can execute a command using the shell using the #system operator. Care
+must be taken to sanitize inputs to this function or security issues may
+result. Note that K has no facility for reasoning about logic that happens
+outside its process, so any functionality that you wish to be able to formally
+reason about in K should not be implemented via the #system operator.

+
  syntax KItem ::= #system ( String ) [function, hook(IO.system), impure]
+                 | "#systemResult" "(" Int /* exit code */ "," String /* stdout */ "," String /* stderr */ ")" [klabel(#systemResult), symbol]
+

Temporary files

+ +

You can get a temporary file and open it atomically using the #mkstemp
+operator. The resulting file will be closed and deleted when K rewriting ends.
+For more info on the argument to #mkstemp, see man mkstemp.

+
  syntax IOFile ::= #mkstemp(template: String) [function, hook(IO.mkstemp), impure]
+  syntax IOFile ::= IOError
+                  | "#tempFile" "(" path: String "," fd: Int ")" [klabel(#tempFile), symbol]
+

Deleting a file

+ +

You can delete a file using its absolute or relative path using the #remove
+operator. It returns .K on success or an IOError on failure.

+
  syntax K ::= #remove(path: String) [function, total, hook(IO.remove), impure]
+

Logging

+ +

You can log information to disk using the #logToFile operator. Semantically,
+this operator returns .K. However, it has a side effect that is not reasoned
+about which is that value will be written to a uniquely-identified file
+containing name in its name. The file is only flushed to disk when rewriting
+finishes.

+
  syntax K ::= #logToFile(name: String, value: String) [function, total, hook(IO.log), impure, returnsUnit, symbol]
+

Strings can also be logged via the logging mechanisms available to the backend.
+On the LLVM backend, this just means logging the text to standard error. On the
+Haskell backend, a log message of type InfoUserLog is created with the
+specified text.

+
  syntax K ::= #log(value: String) [function, total, hook(IO.logString), impure, returnsUnit, symbol]
+

Terms can also be logged to standard error in surface syntax, rather than as
+KORE using #trace. This operator has similar semantics to #logToFile (i.e.
+it returns .K, but prints as an impure side effect). Note that calling
+#trace is equivalent to invoking the kprint tool for the first term that is
+logged, which requires re-parsing the underlying K definition. Subsequent calls
+do not incur this overhead again; the definition is cached.

+
  syntax K ::= #trace(value: KItem) [function, total, hook(IO.traceTerm), impure, returnsUnit, symbol]
+             | #traceK(value: K)    [function, total, hook(IO.traceTerm), impure, returnsUnit, symbol]
+

Implementation of high-level I/O streams in K

+ +

Below is an implementation of the stream="stdin" and stream="stdout"
+cell attributes in K. You should not refer to these symbols or modules directly
+in your definition. It is provided only so that the K compiler can make use of
+it. For more information on how to use this feature, refer to IMP++ in the K
+tutorial.

+
  syntax Stream ::= #buffer(K)
+                  | #istream(Int)
+                  | #parseInput(String, String)
+                  | #ostream(Int)
+
+endmodule
+
+// NOTE: DO NOT DIRECTLY IMPORT *-STREAM MODULES
+// These stream modules will be automatically instantiated and implicitly imported
+// into the main module when `stream` attributes appear in configuration cells.
+// Only `Stream` productions and `[stream]` rules will be imported.
+// The cell name will be replaced with the one of the main configuration.
+
+module STDIN-STREAM
+  imports K-IO
+  imports K-REFLECTION
+  imports LIST
+  imports INT
+  imports BOOL
+
+  configuration <stdin> ListItem(#buffer($STDIN:String)) ListItem($IO:String) ListItem(#istream(#stdin)) </stdin>
+
+  // read one character at a time until we read whitespace
+  rule [stdinGetc]:
+       <stdin>
+       ListItem(#parseInput(_:String, Delimiters:String))
+       ListItem(#buffer(S:String => S +String chrChar({#getc(N)}:>Int)))
+       ListItem("on")
+       ListItem(#istream(N:Int))
+       </stdin>
+    requires findChar(S, Delimiters, 0) ==Int -1 // [stdin]
+       [stream, priority(200)]
+
+  // when we reach whitespace, if it parses create a ListItem
+  rule [stdinParseString]:
+       <stdin>
+       (ListItem(#parseInput("String", Delimiters:String)) => ListItem(S))
+       ListItem(#buffer(S:String => ""))
+       _:List
+       </stdin>
+    requires findChar(S, Delimiters, 0) =/=Int -1 // [stdin]
+       [stream]
+
+  // a hack: handle the case when we read integers without the help of the IO server
+  rule [stdinParseInt]:
+       <stdin>
+       (ListItem(#parseInput("Int", Delimiters:String))
+       => ListItem(String2Int(substrString(S, 0, findChar(S, Delimiters, 0)))))
+       ListItem(#buffer(S:String => substrString(S,findChar(S, Delimiters, 0) +Int 1, lengthString(S))))
+       _:List
+       </stdin>
+    requires findChar(S, Delimiters, 0) =/=Int -1
+       andBool lengthString(S) >Int 1 // [stdin]
+       [stream]
+
+  rule [stdinTrim]:
+       <stdin>
+       ListItem(#parseInput(Sort:String, Delimiters:String))
+       ListItem(#buffer(S:String => substrString(S, 1, lengthString(S))))
+       _:List
+       </stdin>
+    requires findChar(S, Delimiters, 0) =/=Int -1
+       andBool Sort =/=String "String"
+       andBool lengthString(S) <=Int 1 // [stdin]
+       [stream]
+
+  // NOTE: This unblocking rule will be instantiated and inserted carefully
+  // when necessary according to user-defined rules, since otherwise it will
+  // lead to a diverging (i.e., non-terminating) transition system definition.
+  // Currently, it supports only a simple pattern matching on the top of the
+  // input stream cell, e.g.,
+  //   rule <k> read() => V ... </k> <in> ListItem(V:Int) => .List ...  </in>
+  // Non-supported rules that refer to the input stream cell in a sophisticated
+  // way will get stuck in concrete execution mode with real IO enabled (i.e.,
+  // under `--io on` option), while they will still work in symbolic execution
+  // mode or concrete execution mode with real IO disabled (i.e., under `--io
+  // off`, `--search`, or `--debug` options).
+  //
+  // TODO: More patterns need to be supported as well. In that case, we need to
+  // have a way to specify such patterns.
+  rule [stdinUnblock]:
+       <stdin>
+         (.List => ListItem(#parseInput(?Sort:String, ?Delimiters:String)))
+         ListItem(#buffer(_:String))
+         ...
+       </stdin>
+
+  /*
+  syntax Stream ::= "#noIO"
+
+  rule ListItem(#buffer(_))
+       (ListItem(#noIO) ListItem(#istream(_:Int)) => .List) [stdin]
+  */
+
+endmodule
+
+module STDOUT-STREAM
+  imports K-IO
+  imports LIST
+  imports STRING
+
+  configuration <stdout> ListItem(#ostream(#stdout)) ListItem($IO:String) ListItem(#buffer("")) </stdout>
+//configuration <stderr> ListItem(#ostream(#stderr)) ListItem($IO:String) ListItem(#buffer("")) </stderr>
+
+  rule [stdoutBufferFloat]:
+       <stdout>
+       ListItem(#ostream(_))
+       ListItem(_)
+       ListItem(#buffer(Buffer:String => Buffer +String Float2String(F)))
+       (ListItem(F:Float) => .List)
+       _:List
+       </stdout>
+       // [stdout, stderr]
+       [stream, priority(25)]
+  rule [stdoutBufferInt]:
+       <stdout>
+       ListItem(#ostream(_))
+       ListItem(_)
+       ListItem(#buffer(Buffer:String => Buffer +String Int2String(I)))
+       (ListItem(I:Int) => .List)
+       _:List
+       </stdout>
+       // [stdout, stderr]
+       [stream, priority(25)]
+  rule [stdoutBufferString]:
+       <stdout>
+       ListItem(#ostream(_))
+       ListItem(_)
+       ListItem(#buffer(Buffer:String => Buffer +String S))
+       (ListItem(S:String) => .List)
+       _:List
+       </stdout>
+       // [stdout, stderr]
+       [stream, priority(25)]
+
+  // Send first char from the buffer to the server
+  rule [stdoutWrite]:
+       <stdout>
+       ListItem(#ostream(N:Int => {#write(N, S) ~> N:Int}:>Int))
+       ListItem("on")
+       ListItem(#buffer(S:String => ""))
+       _:List
+       </stdout>
+    requires S =/=String "" // [stdout, stderr]
+       [stream, priority(30)]
+
+  /*
+  syntax Stream ::= "#noIO"
+
+  rule ListItem(#buffer(Buffer:String => Buffer +String Float2String(F)))
+       (ListItem(F:Float) => .List)
+       _:List [stdout, stderr]
+  rule ListItem(#buffer(Buffer:String => Buffer +String Int2String(I)))
+       (ListItem(I:Int) => .List)
+       _:List [stdout, stderr]
+  rule ListItem(#buffer(Buffer:String => Buffer +String S))
+       (ListItem(S:String) => .List)
+       _:List [stdout, stderr]
+
+  rule (ListItem(#ostream(_:Int)) ListItem(#noIO) => .List)
+       ListItem(#buffer(_))
+       _:List [stdout, stderr]
+  */
+
+endmodule
+

Machine Integers

+

Provided here is an implementation of arbitrarily large fixed-precision binary
+integers in K. This type is hooked to an implementation of integers provided
+by the backend, and in particular makes use of native machine integers for
+certain sizes of integer. For arbitrary-precision integers, see the INT
+module above.

+

The syntax of machine integers in K is the same as arbitrary-precision integers
+(i.e., an optional sign followed by a sequence of digits) except that machine
+integers always end in a suffix pN where N is an integer indicating the
+width in bits of the integer. The MInt sort is parametric, and this is
+reflected in the literals. For example, the sort of 0p8 is MInt{8}.

+
module MINT-SYNTAX
+  /*@\section{Description} The MInt implements machine integers of arbitrary
+   * bit width represented in 2's complement. */
+  syntax {Width} MInt{Width} [hook(MINT.MInt)]
+
+  /*@ Machine integer of bit width and value. */
+  syntax {Width} MInt{Width} ::= r"[\\+-]?[0-9]+[pP][0-9]+" [token, prec(2), hook(MINT.literal)]
+endmodule
+
+module MINT
+  imports MINT-SYNTAX
+  imports private INT
+  imports private BOOL
+

Bitwidth of MInt

+ +

You can get the number of bits of width in an MInt using bitwidthMInt.

+
  syntax {Width} Int ::= bitwidthMInt(MInt{Width})   [function, total, hook(MINT.bitwidth)]
+

Int and MInt conversions

+ +

You can convert from an MInt to an Int using the MInt2Signed and
+MInt2Unsigned functions. an MInt does not have a sign; its sign is instead
+reflected in how operators interpret its value either as a signed integer or as
+an unsigned integer. Thus, you can interpret a MInt as a signed integer witth
+MInt2Signed, or as an unsigned integer respectively using MInt2Unsigned.

+

You can also convert from an Int to an MInt using Int2MInt. Care must
+be given to ensure that the sort context where the Int2MInt operator appears
+has the correct bitwidth, as this will influence the width of the resulting
+MInt.

+
  syntax {Width} Int ::= MInt2Signed(MInt{Width})     [function, total, hook(MINT.svalue)]
+                       | MInt2Unsigned(MInt{Width})     [function, total, hook(MINT.uvalue), smt-hook(bv2int)]
+
+  syntax {Width} MInt{Width} ::= Int2MInt(Int) [function, total, hook(MINT.integer), smt-hook(int2bv)]
+

MInt min and max values

+ +

You can get the minimum and maximum values of a signed or unsigned MInt
+with az specified bit width using sminMInt, smaxMInt, uminMInt, and
+umaxMInt.

+
  syntax Int ::= sminMInt(Int)    [function]
+               | smaxMInt(Int)    [function]
+               | uminMInt(Int)    [function]
+               | umaxMInt(Int)    [function]
+  rule sminMInt(N:Int) => 0 -Int (1 <<Int (N -Int 1))
+  rule smaxMInt(N:Int) => (1 <<Int (N -Int 1)) -Int 1
+  rule uminMInt(_:Int) => 0
+  rule umaxMInt(N:Int) => (1 <<Int N) -Int 1
+

MInt bounds checking

+ +

You can check whether a specified Int will be represented in an MInt
+with a specified width without any loss of precision when interpreted as
+a signed or unsigned integer using soverflowMInt and uoverflowMInt.

+
  syntax Bool ::= soverflowMInt(width: Int, Int)   [function]
+                | uoverflowMInt(width: Int, Int)   [function]
+  rule
+    soverflowMInt(N:Int, I:Int)
+  =>
+    I <Int sminMInt(N) orBool I >Int smaxMInt(N)
+  rule
+    uoverflowMInt(N:Int, I:Int)
+  =>
+    I <Int uminMInt(N) orBool I >Int umaxMInt(N)
+

MInt arithmetic

+ +

You can:

+
    +
  • Compute the bitwise complement ~MInt of an MInt.
  • +
  • Compute the unary negation --MInt of an MInt.
  • +
  • Compute the product *MInt of two MInts.
  • +
  • Compute the quotient /sMInt of two MInts interpreted as signed integers.
  • +
  • Compute the modulus %sMInt of two MInts interpreted as signed integers.
  • +
  • Compute the quotient /uMInt of two MInts interpreted as unsigned
    +integers.
  • +
  • Compute the modulus %uMInt of two MInts interpreted as unsigned integers.
  • +
  • Compute the sum +MInt of two MInts.
  • +
  • Compute the difference -MInt of two MInts.
  • +
  • Compute the left shift <<MInt of two MInts. The second MInt is always
    +interpreted as positive.
  • +
  • Compute the arithmetic right shift >>aMInt of two MInts. The second
    +MInt is always interpreted as positve.
  • +
  • Compute the logical right shift >>lMInt of two MInts. The second MInt
    +is always interpreted as positive.
  • +
  • Compute the bitwise and &MInt of two MInts.
  • +
  • Compute the bitwise xor xorMInt of two MInts.
  • +
  • Compute the bitwise inclusive or |MInt of two MInts.
  • +
+
  syntax {Width} MInt{Width} ::= "~MInt" MInt{Width} [function, total, hook(MINT.not), smt-hook(bvnot)]
+                               | "--MInt" MInt{Width} [function, total, hook(MINT.neg), smt-hook(bvuminus)]
+                               > left:
+                                 MInt{Width} "*MInt" MInt{Width} [function, total, hook(MINT.mul), smt-hook(bvmul)]
+                               | MInt{Width} "/sMInt" MInt{Width} [function, hook(MINT.sdiv), smt-hook(bvsdiv)]
+                               | MInt{Width} "%sMInt" MInt{Width} [function, hook(MINT.srem), smt-hook(bvsrem)]
+                               | MInt{Width} "/uMInt" MInt{Width} [function, hook(MINT.udiv), smt-hook(bvudiv)]
+                               | MInt{Width} "%uMInt" MInt{Width} [function, hook(MINT.urem), smt-hook(bvurem)]
+                               > left:
+                                 MInt{Width} "+MInt" MInt{Width} [function, total, hook(MINT.add), smt-hook(bvadd)]
+                               | MInt{Width} "-MInt" MInt{Width} [function, total, hook(MINT.sub), smt-hook(bvsub)]
+                               > left:
+                                 MInt{Width} "<<MInt" MInt{Width} [function, hook(MINT.shl), smt-hook(bvshl)]
+                               | MInt{Width} ">>aMInt" MInt{Width} [function, hook(MINT.ashr), smt-hook(bvashr)]
+                               | MInt{Width} ">>lMInt" MInt{Width} [function, hook(MINT.lshr), smt-hook(bvlshr)]
+                               > left:
+                                 MInt{Width} "&MInt" MInt{Width} [function, total, hook(MINT.and), smt-hook(bvand)]
+                               > left:
+                                 MInt{Width} "xorMInt" MInt{Width} [function, total, hook(MINT.xor), smt-hook(bvxor)]
+                               > left:
+                                 MInt{Width} "|MInt" MInt{Width} [function, total, hook(MINT.or), smt-hook(bvor)]
+

MInt comparison

+ +

You can compute whether one MInt is less than, less than or equal to, greater
+than, or greater than or equal to another MInt when interpreted as signed
+or unsigned integers. You can also compute whether one MInt is equal to or
+unequal to another MInt.

+
  syntax {Width} Bool ::= MInt{Width} "<sMInt" MInt{Width} [function, total, hook(MINT.slt), smt-hook(bvslt)]
+                        | MInt{Width} "<uMInt" MInt{Width} [function, total, hook(MINT.ult), smt-hook(bvult)]
+                        | MInt{Width} "<=sMInt" MInt{Width} [function, total, hook(MINT.sle), smt-hook(bvsle)]
+                        | MInt{Width} "<=uMInt" MInt{Width} [function, total, hook(MINT.ule), smt-hook(bvule)]
+                        | MInt{Width} ">sMInt" MInt{Width} [function, total, hook(MINT.sgt), smt-hook(bvsgt)]
+                        | MInt{Width} ">uMInt" MInt{Width} [function, total, hook(MINT.ugt), smt-hook(bvugt)]
+                        | MInt{Width} ">=sMInt" MInt{Width} [function, total, hook(MINT.sge), smt-hook(bvsge)]
+                        | MInt{Width} ">=uMInt" MInt{Width} [function, total, hook(MINT.uge), smt-hook(bvuge)]
+                        | MInt{Width} "==MInt" MInt{Width} [function, total, hook(MINT.eq), smt-hook(=)]
+                        | MInt{Width} "=/=MInt" MInt{Width} [function, total, hook(MINT.ne), smt-hook(distinct)]
+

MInt min/max

+ +

You can compute the signed minimum sMinMInt, the signed maximum sMaxMInt,
+the unsigned minimum uMinMInt, and the unsigned maximum uMaxMInt of two
+MInts.

+
  syntax {Width} MInt{Width} ::= sMaxMInt(MInt{Width}, MInt{Width}) [function, total, hook(MINT.smax), smt-hook((ite (bvslt #1 #2) #2 #1))]
+                               | sMinMInt(MInt{Width}, MInt{Width}) [function, total, hook(MINT.smin), smt-hook((ite (bvslt #1 #2) #1 #2))]
+                               | uMaxMInt(MInt{Width}, MInt{Width}) [function, total, hook(MINT.umax), smt-hook((ite (bvult #1 #2) #2 #1))]
+                               | uMinMInt(MInt{Width}, MInt{Width}) [function, total, hook(MINT.umin), smt-hook((ite (bvult #1 #2) #1 #2))]
+

MInt to MInt conversion

+ +

You can convert an MInt of one width to another width with roundMInt.
+The resulting MInt will be truncated starting from the most significant bit
+if the resulting width is smaller than the input. The resulting MInt will be
+zero-extended with the same low-order bits if the resulting width is larger
+than the input.

+
  syntax {Width1, Width2} MInt{Width1} ::= roundMInt(MInt{Width2}) [function, total, hook(MINT.round)]
+
endmodule
+

Strategies

+

K supports a built-in strategy language that allows you to control how rules
+apply. In order to enable it, simply import the STRATEGY module in your
+definition. This includes the following basic strategy constructs:

+
    +
  • ^ Category:#RuleTag - This is a strategy that indicates that you should
    +apply a rule with the specified category exactly once. By default, all rules
    +get the regular tag. This can be changed on individual rules with the tag
    +attribute.
  • +
  • ~ Category:#RuleTag - This is the state the strategy cell will be in
    +after a rule has applied. In other words, all rules that do not mention the
    +strategy cell are automatically instrumented so that they rewrite the current
    +top of the <s> cell from ^ to ~
  • +
  • <s> - This is the strategy cell and contains the current strategy.
  • +
  • #STUCK() - By default, a rule is automatically inserted into the definition
    +which adds #STUCK() to the top of the <s> cell if no other rules apply
    +and if it is not already at the top of the <s> cell.
  • +
+
module STRATEGY
+    imports ML-SYNTAX
+    imports KVARIABLE-SYNTAX
+    imports private K-EQUAL
+
+    syntax #RuleTag ::= #KVariable
+
+    syntax Strategy ::= #STUCK()    [symbol]
+                      | "^" #RuleTag [symbol, klabel(#applyRule)]
+                      | "~" #RuleTag [symbol, klabel(#appliedRule)]
+
+    configuration <s> $STRATEGY:K </s>
+endmodule
+
+module RULE-TAG-SYNTAX
+    imports BUILTIN-ID-TOKENS
+
+    syntax #RuleTag ::= #LowerId [token]
+endmodule
+

This is not a complete strategy language. However, it provides several basics.
+The user can extend this strategy language into a complete strategy language
+in one of three ways. First, they can import the DEFAULT-STRATEGY module,
+which provides a very basic strategy that is essentially equivalent to
+execution without a strategy. This can be useful if you wish to wholly
+manipulate the strategy cell yourself within other rules.

+
module DEFAULT-STRATEGY-CONCRETE [concrete]
+    imports STRATEGY
+    imports RULE-TAG-SYNTAX
+    rule ~ regular => ^ regular [anywhere]
+endmodule
+
+module DEFAULT-STRATEGY-SYMBOLIC [symbolic]
+    imports STRATEGY
+    imports RULE-TAG-SYNTAX
+    rule <s> ~ regular => ^ regular ... </s>
+endmodule
+
+module DEFAULT-STRATEGY
+    imports STRATEGY
+    imports DEFAULT-STRATEGY-CONCRETE
+    imports DEFAULT-STRATEGY-SYMBOLIC
+
+    rule initSCell(_) => <s> ^ regular </s> [priority(25)]
+endmodule
+

The second way you can extend the strategy language is with the
+STRATEGY-ABSTRACT module. This provides a slightly more advanced set of
+strategies which you can use to compose the basic strategies in the STRATEGY
+module into more complex strategies. Note however that the functionality
+provided is still relatively basic.

+
module STRATEGY-ABSTRACT
+    imports STRATEGY
+
+    syntax #RuleTag ::= "(" #RuleTag ")" [bracket]
+ // ----------------------------------------------
+
+    syntax Strategy ::= ".Strategy"
+                      | "(" Strategy ")" [bracket]
+ // ----------------------------------------------
+    rule <s> .Strategy => . ... </s>
+
+    syntax KItem ::= #catchSTUCK ( Strategy )
+ // -----------------------------------------
+    rule <s> #catchSTUCK(_) => . ... </s>
+    rule <s> #STUCK() ~> (_S:Strategy => .) ... </s>
+    rule <s> #STUCK() ~> #catchSTUCK(S) => S ... </s>
+
+    syntax Strategy ::= Strategy ";" Strategy [left]
+ // ------------------------------------------------
+    rule <s> S:Strategy ; S':Strategy => S ~> S' ... </s>
+
+    syntax #RuleTag ::= #RuleTag "|" #RuleTag [left, klabel(#alternateRule)]
+ // ------------------------------------------------------------------------
+    rule <s> ^ RT:#RuleTag | RT':#RuleTag => ^ RT ~> #catchSTUCK(^ RT') ... </s>
+
+    syntax #RuleTag ::= #RuleTag "*" [klabel(#repeatRule)]
+ // ------------------------------------------------------
+    rule <s> ^ RT:#RuleTag * => ^ RT ~> ^ RT * ~> #catchSTUCK(.Strategy) ... </s>
+endmodule
+

The third mechanism for extending the strategy language is to define your own
+strategy language. No special facility is required in K in order to compose
+strategies together, so you are free to write whatever rules that manipulate
+the strategy cell you want, and thus whatever more complex strategies you can
+compose from the base builtin strategies.

+

K Language Features

+

Defined below is a series of modules used to parse inner syntax in K (ie, the
+contents of rules, configuration declarations, and contexts).

+

Much of this file exists in tight correspondence with the K implementation, and
+K will not work correctly if it is altered without corresponding changes to the
+source code of the K tools.

+

Users should only import a few modules from this file. In particular, this
+includes SORT-K, BASIC-K, ML-SYNTAX, DEFAULT-LAYOUT,
+DEFAULT-CONFIGURATION, and K-AMBIGUITIES. The remaining modules should not
+be imported by the user; they are used implicitly by the implementation of K.

+

Basic K Sorts

+

The SORT-K module declares the K sort, and nothing else.

+
module SORT-K
+  syntax K [hook(K.K)]
+endmodule
+

The BASIC-K module declares the K, KItem, and KConfigVar sorts, and
+imports the syntax of matching logic.

+
module BASIC-K
+  imports ML-SYNTAX
+  imports SORT-BOOL
+  syntax KItem [hook(K.KItem)]
+  syntax K     ::= KItem
+  syntax KConfigVar [token]
+  syntax KItem ::= KConfigVar
+endmodule
+

KAST Abstract Syntax

+

Below is defined the abstract syntax of concrete terms in K, the KAST syntax.
+Users should rarely if ever have to refer to this syntax; in general, it
+suffices to use concrete syntax in rules, configuration declarations, contexts,
+etc.

+

This syntax is used directly by the K implementation, and exists here as a
+reference for the syntax of KAST, but it should not be imported directly by
+the user.

+
module KSTRING
+  syntax KString ::= r"[\\\"](([^\\\"\\n\\r\\\\])|([\\\\][nrtf\\\"\\\\])|([\\\\][x][0-9a-fA-F]{2})|([\\\\][u][0-9a-fA-F]{4})|([\\\\][U][0-9a-fA-F]{8}))*[\\\"]"      [token]
+  // optionally qualified strings, like in Scala "abc", i"abc", r"a*bc", etc.
+endmodule
+
+module BUILTIN-ID-TOKENS
+  syntax #LowerId ::= r"[a-z][a-zA-Z0-9]*"                    [prec(2), token]
+  syntax #UpperId ::= r"[A-Z][a-zA-Z0-9]*"                    [prec(2), token]
+endmodule
+
+module SORT-KBOTT
+  imports SORT-K
+  syntax KBott
+endmodule
+
+module KAST
+  imports BASIC-K
+  imports SORT-KBOTT
+  imports KSTRING
+  imports BUILTIN-ID-TOKENS
+
+  syntax KBott ::= "#token" "(" KString "," KString ")"  [klabel(#KToken), symbol]
+                 | "#klabel" "(" KLabel ")"              [klabel(#WrappedKLabel), symbol]
+                 | KLabel "(" KList ")"                  [klabel(#KApply), symbol]
+  syntax KItem ::= KBott
+
+  syntax KLabel ::= r"`(\\\\`|\\\\\\\\|[^`\\\\\\n\\r])+`" [token]
+                  | #LowerId                                   [token]
+                  | r"(?<![a-zA-Z0-9])[#a-z][a-zA-Z0-9]*"               [token, prec(1)]
+                       // something that doesn't collide with meta-variables
+
+  syntax KList ::= K
+                 | ".KList"          [klabel(#EmptyKList), symbol]
+                 | ".::KList"        [klabel(#EmptyKList), symbol]
+                 | KList "," KList   [klabel(#KList), left, assoc, unit(#EmptyKList), symbol, prefer]
+endmodule
+
+
+// To be used when parsing/pretty-printing ground configurations
+module KSEQ
+  imports KAST
+  imports K-TOP-SORT
+  syntax K ::= ".K"      [klabel(#EmptyK), symbol, unparseAvoid]
+             | "."       [klabel(#EmptyK), symbol]
+             | ".::K"    [klabel(#EmptyK), symbol, unparseAvoid]
+  syntax K ::= K "~>" K  [klabel(#KSequence), left, assoc, unit(#EmptyK), symbol]
+  syntax left #KSequence
+  syntax {Sort} Sort     ::= "(" Sort ")"    [bracket, group(defaultBracket), applyPriority(1)]
+endmodule
+

Syntax of Matching Logic

+

K provides direct access to the symbols of Matching Logic, while giving them
+their own concrete syntax distinct from the syntax of the KORE intermediate
+representation. These symbols are primarily used during symbolic execution.
+The LLVM Backend has relatively little understanding of Matching Logic directly
+and use of these symbols directly in rules is likely to cause it to crash.
+However, these symbols are necessary when providing lemmas and other types of
+logical assistance to proofs and symbolic execution in the Haskell Backend.

+

The correspondance between K symbols and KORE symbols is as follows:

+
    +
  • #Top - \top
  • +
  • #Bottom - \bottom
  • +
  • #Not - \not
  • +
  • #Ceil - \ceil
  • +
  • #Floor - \floor
  • +
  • #Equals - \equals
  • +
  • #And - \and
  • +
  • #Or - \or
  • +
  • #Implies - \implies
  • +
  • #Exists - \exists
  • +
  • #Forall - \forall
  • +
  • #AG - allPathGlobally
  • +
  • #wEF - weakExistsFinally
  • +
  • #wAF - weakAlwaysFinally
  • +
+
module ML-SYNTAX [not-lr1]
+  imports SORT-K
+
+  syntax {Sort} Sort ::= "#Top" [klabel(#Top), symbol, group(mlUnary)]
+                       | "#Bottom" [klabel(#Bottom), symbol, group(mlUnary)]
+                       | "#True" [klabel(#Top), symbol, group(mlUnary), unparseAvoid]
+                       | "#False" [klabel(#Bottom), symbol, group(mlUnary), unparseAvoid]
+                       | "#Not" "(" Sort ")" [klabel(#Not), symbol, mlOp, group(mlUnary)]
+
+  syntax {Sort1, Sort2} Sort2 ::= "#Ceil" "(" Sort1 ")" [klabel(#Ceil), symbol, mlOp, group(mlUnary)]
+                                | "#Floor" "(" Sort1 ")" [klabel(#Floor), symbol, mlOp, group(mlUnary)]
+                                | "{" Sort1 "#Equals" Sort1 "}" [klabel(#Equals), symbol, mlOp, group(mlEquals), comm, format(%1%i%n%2%d%n%3%i%n%4%d%n%5)]
+
+  syntax priorities mlUnary > mlEquals > mlAnd
+
+  syntax {Sort} Sort ::= Sort "#And" Sort [klabel(#And), symbol, assoc, left, comm, unit(#Top), mlOp, group(mlAnd), format(%i%1%d%n%2%n%i%3%d)]
+                       > Sort "#Or" Sort [klabel(#Or), symbol, assoc, left, comm, unit(#Bottom), mlOp, format(%i%1%d%n%2%n%i%3%d)]
+                       > Sort "#Implies" Sort [klabel(#Implies), symbol, mlOp, group(mlImplies), format(%i%1%d%n%2%n%i%3%d)]
+
+  syntax priorities mlImplies > mlQuantifier
+
+  syntax {Sort1, Sort2} Sort2 ::= "#Exists" Sort1 "." Sort2 [klabel(#Exists), symbol, mlOp, mlBinder, group(mlQuantifier)]
+                                | "#Forall" Sort1 "." Sort2 [klabel(#Forall), symbol, mlOp, mlBinder, group(mlQuantifier)]
+
+  syntax {Sort} Sort ::= "#AG" "(" Sort ")" [klabel(#AG), symbol, mlOp]
+                       | "#wEF" "(" Sort ")" [klabel(weakExistsFinally), symbol, mlOp]
+                       | "#wAF" "(" Sort ")" [klabel(weakAlwaysFinally), symbol, mlOp]
+endmodule
+

Variables in K

+

Provided below is the syntax of variables in K. There are four types of
+variables in K:

+
    +
  1. Regular variables. These are denoted by variables that begin with an
    +underscore or a capital letter. These variables match exactly one value
    +and can be used to refer to it on the right-hand-side.
  2. +
  3. Fresh constants. These are denoted by variables that begin with an !. This
    +is a convenience syntax which can be used on the right-hand-side only, and
    +refer to a unique value of the specified sort which is distinct from any
    +other value that has been generated or will be generated by the !X syntax.
    +Note that this may not be distinct from values produced via other means.
  4. +
  5. Existential variables. This refers to variables that are existentially
    +quantified and begin with a ?. They are not required to appear on the
    +left-hand-side prior to appearing on the right-hand-side, and generally
    +refer to symbolic quantities that are introduced during rewriting. Refer to
    +K's documentation for more details.
  6. +
  7. Set variables. These are denoted by variables that begin with a @.
    +These variables refer to a set of values and are generally used when writing
    +simplification rules in the Haskell Backend. For more information, refer to
    +K's documentation.
  8. +
+

There is also a fifth type of "variable", although it is not technically a
+variable. This refers to configuration variables, which are used to insert
+values into the initial configuration that come from outside the semantics.
+The most common of these is the $PGM variable, which conventionally contains
+the program being executed and is placed in the <k> cell in the configuration
+declaration. These "variables" begin with a $ and their values are populated
+by the frontend prior to symbolic or concrete execution of a program.

+
module KVARIABLE-SYNTAX
+  syntax #KVariable
+endmodule
+
+// To be used when parsing/pretty-printing symbolic configurations
+module KSEQ-SYMBOLIC
+  imports KSEQ
+  imports ML-SYNTAX
+  imports KVARIABLE-SYNTAX
+
+  syntax #KVariable ::= r"(?<![A-Za-z0-9_\\$!\\?@])(\\!|\\?|@)?([A-Z][A-Za-z0-9'_]*|_|_[A-Z][A-Za-z0-9'_]*)"   [token, prec(1)]
+                      | #UpperId                                                          [token]
+  syntax KConfigVar ::= r"(?<![A-Za-z0-9_\\$!\\?@])(\\$)([A-Z][A-Za-z0-9'_]*)"            [token]
+  syntax KBott      ::= #KVariable
+  syntax KBott      ::= KConfigVar
+  syntax KLabel     ::= #KVariable
+endmodule
+

Syntax of Cells

+

While the backend treats cells as regular productions like any other, the
+frontend provides a significant amount of convenience notation for dealing with
+groups of cells, in order to make writing modular definitions easier. As a
+result, we need a syntax for groups of cells and for referring to cells within
+rules, configuration declarations, and functions.

+

For historical reasons, the Bag sort is used to refer to groups of cells.
+This may change in a future release. Users can combine cells in any order
+by concatenating them together, and can refer to the absence of any cells with
+the .Bag symbol. You can also refer to cells within a function by placing
+the cell context symbol, [[ K ]] at the top of a rule, placing a function
+symbol inside, and referring to cells afterwards. This implicitly inserts
+a reference to the configuration at the time prior to the currently-applied
+rule being applied which can be matched on within the function. Functions with
+such context cannot be referred to in the initial configuration, because the
+prior configuration does not yet exist.

+
module KCELLS
+  imports KAST
+
+  syntax Cell
+  syntax Bag ::= Bag Bag  [left, assoc, klabel(#cells), symbol, unit(#cells)]
+               | ".Bag"   [klabel(#cells), symbol]
+               | ".::Bag" [klabel(#cells), symbol]
+               | Cell
+  syntax Bag ::= "(" Bag ")" [bracket]
+  syntax KItem ::= Bag
+  syntax #RuleBody ::= "[" "[" K "]" "]" Bag    [klabel(#withConfig), symbol, avoid]
+  syntax non-assoc #withConfig
+  syntax Bag ::= KBott
+endmodule
+

Users can also refer to cells in rules. When doing so, an optional ... can
+be placed immediately after the start of the cell or immediately before the
+end. In a cell whose contents are commutative, these are equivalent to one
+another and are also equivalent to placing ... in both places. This means
+that what is placed in the cell will be combined with the cell contents'
+concatenation operator with an unnamed variable. In other words, you match on
+some number of elements in the collection and do not care about the rest of
+the collection.

+

In a cell whose contents are not commutative, the ... operators correspond
+to a variable on the respective side of the contents of the cell that the
+... appears. For example, <foo>... L </foo>, if L is a list, means
+some number of elements followed by L. Note that not all combinations are
+supported. Cells whose contents are sort K can only have ... appear at the
+tail of the cell, and cells whose contents are sort List can only have ...
+appear on at most one side in a single rule.

+
module RULE-CELLS
+  imports KCELLS
+  imports RULE-LISTS
+  // if this module is imported, the parser automatically
+  // generates, for all productions that have the attribute 'cell' or 'maincell',
+  // a production like below:
+  //syntax Cell ::= "<top>" #OptionalDots K #OptionalDots "</top>" [klabel(<top>)]
+
+  syntax #OptionalDots ::= "..." [klabel(#dots), symbol]
+                         | ""    [klabel(#noDots), symbol]
+
+  syntax Int
+  // this production will be added by the compiler to help handle bang variables,
+  // however, it is valuable to put it here because without this production, it
+  // will not exist at the point in time when rules and claims are parsed, and
+  // as a result it makes it very difficult to write proof claims over fragments
+  // of code that exercise rules containing bang variables. We put it here because
+  // this production will "vanish" after parsing finishes and not be picked up
+  // by the compiler, which is the behavior we want in this case since an actual
+  // production will be generated by the compiler later on.
+  syntax GeneratedCounterCell ::= "<generatedCounter>" Int "</generatedCounter>" [cell, klabel(<generatedCounter>), symbol, internal]
+endmodule
+

Users can also declare cells in a configuration declaration. This generates a
+specific set of productions that is used internally to implement the cell. The
+most important of these is the cell itself, and attributes on this production
+can be specified in an xml-attribute-like syntax.

+

You can also use an xml-short-tag-like syntax to compose configuration cells
+together which were defined in different modules. However, it is a requirement
+that any K definition have at most one fully-composed configuration; thus, all
+other configuration declarations must appear composed within another
+configuration declaration.

+
module CONFIG-CELLS
+  imports KCELLS
+  imports RULE-LISTS
+  syntax #CellName ::= r"[a-zA-Z][a-zA-Z0-9\\-]*"  [token, prec(1)]
+                     | #LowerId            [token]
+                     | #UpperId            [token]
+
+  syntax Cell ::= "<" #CellName #CellProperties ">" K "</" #CellName ">" [klabel(#configCell), symbol]
+  syntax Cell ::= "<" #CellName "/>" [klabel(#externalCell), symbol]
+
+  syntax #CellProperties ::= #CellProperty #CellProperties [klabel(#cellPropertyList), symbol]
+                           | ""                            [klabel(#cellPropertyListTerminator), symbol]
+  syntax #CellProperty ::= #CellName "=" KString           [klabel(#cellProperty), symbol]
+endmodule
+

Syntax of Rules

+

Rules can have an optional requires clause or an ensures clause. For backwards-
+compatibility, you can refer to the requires clause with both the requires
+and when keywords; The latter, however, is deprecated and may be removed in
+a future release.

+

The requires clause specifies the preconditions that must be true in order
+for the rule to apply. The ensures clause specifies the information which
+becomes true after the rule has applied. It is a requirement that information
+present in the ensures clause refer to existential variables only.

+

When doing concrete execution, you can think of the requires clause as a
+side-condition. In other words, even if the rule matches, it will not apply
+unless the requires clause, which must be of sort Bool, evaluates to
+true.

+
module REQUIRES-ENSURES
+  imports BASIC-K
+
+  syntax #RuleBody ::= K
+
+  syntax #RuleContent ::= #RuleBody                                 [klabel("#ruleNoConditions"), symbol]
+                        | #RuleBody "requires" Bool                 [klabel("#ruleRequires"), symbol]
+                        | #RuleBody "when" Bool                     [klabel("#ruleRequires"), symbol]
+                        | #RuleBody "ensures"  Bool                 [klabel("#ruleEnsures"), symbol]
+                        | #RuleBody "requires" Bool "ensures" Bool  [klabel("#ruleRequiresEnsures"), symbol]
+                        | #RuleBody "when" Bool "ensures" Bool      [klabel("#ruleRequiresEnsures"), symbol]
+endmodule
+

Miscellaneous modules

+

The below modules are used in various ways as indicators to the implementation
+that certain automatically generated syntax should be created by the parser.
+These modules should not be imported directly by the user.

+
module K-TOP-SORT
+  imports SORT-KBOTT
+  syntax KItem ::= KBott
+  syntax {Sort} KItem ::= Sort
+endmodule
+
+module K-BOTTOM-SORT
+  imports SORT-KBOTT
+  syntax KItem ::= KBott
+  syntax {Sort} Sort ::= KBott
+endmodule
+
+module K-SORT-LATTICE
+  imports K-TOP-SORT
+  imports K-BOTTOM-SORT
+endmodule
+
+module AUTO-CASTS
+  // if this module is imported, the parser automatically
+  // generates, for all sorts, productions of the form:
+  // Sort  ::= Sort ":Sort"  // semantic cast - force the inner term to be `Sort` or a subsort
+  // Sort  ::= Sort "::Sort" // strict cast - force the inner term to be exactly `Sort`. Useful for disambiguation
+  // Sort ::= "{" Sort "}" "<:Sort" // synonym for strict cast
+  // Sort  ::= "{" K "}"    ":>Sort" // projection cast. Allows any term to be placed in a context that expects `Sort`
+  // this is part of the mechanism that allows concrete user syntax in K
+endmodule
+
+module AUTO-FOLLOW
+  // if this module is imported, the parser automatically
+  // generates a follow restriction for every terminal which is a prefix
+  // of another terminal. This is useful to prevent ambiguities such as:
+  // syntax K ::= "a"
+  // syntax K ::= "b"
+  // syntax K ::= "ab"
+  // syntax K ::= K K
+  // #parse("ab", "K")
+  // In the above example, the terminal "a" is not allowed to be followed by a "b"
+  // because it would turn the terminal into the terminal "ab".
+endmodule
+
+module PROGRAM-LISTS
+  imports SORT-K
+  // if this module is imported, the parser automatically
+  // replaces the default productions for lists:
+  // Es ::= E "," Es [userList("*"), klabel('_,_)]
+  //      | ".Es"    [userList("*"), klabel('.Es)]
+  // into a series of productions more suitable for programs:
+  // Es#Terminator ::= ""      [klabel('.Es)]
+  // Ne#Es ::= E "," Ne#Es     [klabel('_,_)]
+  //         | E Es#Terminator [klabel('_,_)]
+  // Es ::= Ne#Es
+  //      | Es#Terminator      // if the list is *
+endmodule
+
+module RULE-LISTS
+  // if this module is imported, the parser automatically
+  // adds the subsort production to the parsing module only:
+  // Es ::= E        [userList("*")]
+
+endmodule
+
+module RECORD-PRODUCTIONS
+  // if this module is imported, prefix productions of the form
+  // syntax Sort ::= name(Args)
+  // will be able to be parsed with don't-care variables according
+  // to their nonterminal's names
+endmodule
+
+module SORT-PREDICATES
+  // if this module is imported, the Bool sort will be annotated with
+  // syntax Bool ::= isSort(K) [function]
+  // and all sorts will be annotated with
+  // syntax Sort ::= project:Sort(K) [function]
+endmodule
+

Additional Syntax for K Terms in Rules

+

Certain additional features are available when parsing the contents of rules
+and contexts. For more information on each of these, refer to K's
+documentation.

+
module KREWRITE
+  syntax {Sort} Sort ::= Sort "=>" Sort [klabel(#KRewrite), symbol]
+  syntax non-assoc #KRewrite
+  syntax priority #KRewrite > #withConfig
+endmodule
+
+// To be used to parse semantic rules
+module K
+  imports KSEQ-SYMBOLIC
+  imports REQUIRES-ENSURES
+  imports RECORD-PRODUCTIONS
+  imports SORT-PREDICATES
+  imports K-SORT-LATTICE
+  imports AUTO-CASTS
+  imports AUTO-FOLLOW
+  imports KREWRITE
+
+  syntax {Sort} Sort ::= Sort "#as" Sort [klabel(#KAs), symbol]
+  // functions that preserve sorts and can therefore have inner rewrites
+  syntax {Sort} Sort ::= "#fun" "(" Sort ")" "(" Sort ")" [klabel(#fun2), symbol, prefer]
+  // functions that do not preserve sort and therefore cannot have inner rewrites
+  syntax {Sort1, Sort2} Sort1 ::= "#fun" "(" Sort2 "=>" Sort1 ")" "(" Sort2 ")" [klabel(#fun3), symbol]
+
+  syntax {Sort1, Sort2} Sort1 ::= "#let" Sort2 "=" Sort2 "#in" Sort1 [klabel(#let), symbol]
+
+  /*@ Set membership over terms. In addition to equality over
+      concrete patterns, K also supports computing equality
+      between a concrete pattern and a symbolic pattern.
+      This is compiled efficiently down to pattern matching,
+      and can be used by putting a term with unbound variables
+      in the left child of :=K or =/=K. Note that this does not
+      bind variables used on the lhs however (although this may
+      change in the future).*/
+
+  syntax Bool ::= left:
+                  K ":=K" K           [function, total, klabel(_:=K_), symbol, group(equalEqualK)]
+                | K ":/=K" K          [function, total, klabel(_:/=K_), symbol, group(notEqualEqualK)]
+endmodule
+
+// To be used to parse terms in full K
+module K-TERM
+  imports KSEQ-SYMBOLIC
+  imports RECORD-PRODUCTIONS
+  imports SORT-PREDICATES
+  imports K-SORT-LATTICE
+  imports AUTO-CASTS
+  imports AUTO-FOLLOW
+  imports KREWRITE
+endmodule
+

Layout Information

+

When constructing a scanner for use during parsing, often you wish to ignore
+certain types of text, such as whitespace and comments. However, the specific
+syntax which each language must ignore is a little different from language
+to language, and thus you wish to specify it manually. You can do this by
+defining productions of the #Layout sort. For more information, refer to
+K's documentation. However, this module will be implicitly imported if no
+productions are declared of sort #Layout. This module will also be used
+for the purposes of parsing K rules. If you wish to declare a language with
+no layout productions, simply create a sort declaration for the #Layout sort
+in your code (e.g. syntax #Layout).

+
module DEFAULT-LAYOUT
+    syntax #Layout ::= r"(\\/\\*([^\\*]|(\\*+([^\\*\\/])))*\\*+\\/)" // C-style multi-line comments
+                     | r"(\\/\\/[^\\n\\r]*)"                         // C-style single-line comments
+                     | r"([\\ \\n\\r\\t])"                           // Whitespace
+endmodule
+

Default Configuration

+

If the user has no configuration declaration in their seamantics, the below
+configuration declaration will be implicitly imported.

+
module DEFAULT-CONFIGURATION
+  imports BASIC-K
+
+  configuration <k> $PGM:K </k>
+endmodule
+

Parsing Ambiguous Languages

+

On occasion, it may be desirable to parse a language with an ambiguous grammar
+when parsing a program, and perform additional semantic analysis at a later
+time in order to resolve the ambiguities. A good example of this is as a
+substitute for the lexer hack in parsers of the C programming language.

+

The following module contains a declaration for ambiguities in K. Usually,
+an ambiguous parse is an error. However, when you use the --gen-glr-parser
+flag to kast, or the --gen-glr-bison-parser flag to kompile, ambiguities
+instead become instances of the below parametric production, which you can use
+regular K rules to disambiguate as necessary.

+
module K-AMBIGUITIES
+
+  syntax {Sort} Sort ::= amb(Sort, Sort) [symbol]
+
+endmodule
+

Annotating Parses with Locations

+

Another feature of K's Bison parser is the ability to annotate terms parsed
+with location information about the file and line where they occurred. For
+more information about how to use this, refer to K's documentation. However,
+the below module exists to provide a user syntax for the annotations that
+are generated by the parser.

+
module K-LOCATIONS
+  imports STRING-SYNTAX
+  imports INT-SYNTAX
+
+  // filename, startLine, startCol, endLine, endCol
+  syntax {Sort} Sort ::= #location(Sort, String, Int, Int, Int, Int) [symbol, format(%3)]
+
+endmodule
+

K Prelude

+

The following files, integral to defining semantics in K, are automatically
+required by every definition via this file. This behavior can be disabled
+via kompile --no-prelude, however, semantics will likely break unless
+they provide their own versions of these files, which are assumed to exist
+by the compiler. There are, however, circumstances where passing this flag is
+appropriate, such as if you are manually requiring these files in your
+definition, if your definition was automatically condensed into a single file
+with kompile -E, or if you wish to modify the inner syntax of K by providing
+your own version of these files with different syntax.

+
require "kast.md"
+require "domains.md"
+

K Foreign Function Interface

+

The K Foreign Function Interface (FFI) module provides a way to call native
+functions directly from a K semantics using the C ABI. It also provides
+utilities for allocating and deallocating byte buffers with static addresses
+that are suitable for being passed to native code.

+

It is built off of the underlying libffi library
+(https://sourceware.org/libffi/) and is subject to some of the same
+limitations as that library. Bear in mind, because this library exposes
+a number of unsafe C APIs directly, misuse of the library is likely to lead
+to memory corruption in your interpreter and can cause segmentation faults or
+corrupted term representations that lead to undefined behavior at runtime.

+
require "domains.md"
+
+module FFI-SYNTAX
+  imports private LIST
+

The FFIType sort is used to declare the native C ABI types of operands passed
+to the #ffiCall function. These types roughly correspond to the types
+declared in ffi.h by libffi.

+
  syntax FFIType ::= "#void" [klabel(#ffi_void), symbol]
+                  | "#uint8" [klabel(#ffi_uint8), symbol]
+                  | "#sint8" [klabel(#ffi_sint8), symbol]
+                  | "#uint16" [klabel(#ffi_uint16), symbol]
+                  | "#sint16" [klabel(#ffi_sint16), symbol]
+                  | "#uint32" [klabel(#ffi_uint32), symbol]
+                  | "#sint32" [klabel(#ffi_sint32), symbol]
+                  | "#uint64" [klabel(#ffi_uint64), symbol]
+                  | "#sint64" [klabel(#ffi_sint64), symbol]
+                  | "#float" [klabel(#ffi_float), symbol]
+                  | "#double" [klabel(#ffi_double), symbol]
+                  | "#uchar" [klabel(#ffi_uchar), symbol]
+                  | "#schar" [klabel(#ffi_schar), symbol]
+                  | "#ushort" [klabel(#ffi_ushort), symbol]
+                  | "#sshort" [klabel(#ffi_sshort), symbol]
+                  | "#uint" [klabel(#ffi_uint), symbol]
+                  | "#sint" [klabel(#ffi_sint), symbol]
+                  | "#ulong" [klabel(#ffi_ulong), symbol]
+                  | "#slong" [klabel(#ffi_slong), symbol]
+                  | "#longdouble" [klabel(#ffi_longdouble), symbol]
+                  | "#pointer" [klabel(#ffi_pointer), symbol]
+                  | "#complexfloat" [klabel(#ffi_complexfloat), symbol]
+                  | "#complexdouble" [klabel(#ffi_complexdouble), symbol]
+                  | "#complexlongdouble" [klabel(#ffi_complexlongdouble), symbol]
+                  | "#struct" "(" List ")" [klabel(#ffi_struct), symbol]
+endmodule
+
+module FFI
+  imports FFI-SYNTAX
+  imports private BYTES
+  imports private STRING
+  imports private BOOL
+  imports private LIST
+  imports private INT
+
+

FFI Calls

+

The #ffiCall functions are designed to call a native C ABI function and
+return a native result. They come in three variants:

+

Non-variadic

+ +

In the first variant, #ffiCall(Address, Args, ArgTypes, ReturnType) takes
+an integer address of a function (which can be obtained from
+#functionAddress), a List of Bytes containing the arguments of the
+function, a List of FFITypes containing the types of the parameters of the
+function, and an FFIType containing the return type of the function, and
+returns the return value of the function as a Bytes.

+
  syntax Bytes ::= "#ffiCall" "(" Int "," List "," List "," FFIType ")" [function, hook(FFI.call)]
+

Variadic

+ +

In the second variant,
+#ffiCall(Address, Args, FixedTypes, VariadicTypes, ReturnType takes an
+integer address of a function, a List of Bytes containing the arguments
+of the call, a List of FFITypes containing the types of the fixed
+parameters of the function, a List of FFITypes containing the types of the
+variadic parameters of the function, and an FFIType containing the return
+type of the function, and returns the return value of the function as a
+Bytes.

+
  syntax Bytes ::= "#ffiCall" "(" Int "," List "," List "," List "," FFIType ")" [function, hook(FFI.call_variadic)]
+

Generic

+ +

In the third variant,
+#ffiCall(IsVariadic, Address, Args, ArgTypes, NFixed, ReturnType takes
+a boolean indicating whether the function is variadic or not, an integer
+address of a function, a List of Bytes containing the arguments of the
+call, a List of FFITypes containing the parameter typess of the call
+followed by the types of the variadic arguments of the call, if any, an Int
+containing how many of the arguments of the call are fixed or not, and an
+FFIType containing the return type of the function, and returns the return
+value of the function as a Bytes.

+
  syntax Bytes ::= "#ffiCall" "(" Bool "," Int "," List "," List "," Int "," FFIType ")" [function]
+
+  rule #ffiCall(false, Addr::Int, Args::List, Types::List, _, Ret::FFIType) => #ffiCall(Addr, Args, Types, Ret)
+  rule #ffiCall(true, Addr::Int, Args::List, Types::List, NFixed::Int, Ret::FFIType) => #ffiCall(Addr, Args, range(Types, 0, size(Types) -Int NFixed), range(Types, NFixed, 0), Ret)
+

Symbol Lookup

+

The FFI module provides a mechanism to look up any function symbol and return
+that function's address.

+
  syntax Int ::= "#functionAddress" "(" String ")" [function, hook(FFI.address)]
+

Direct Memory Management

+

Most memory used by the LLVM backend to represent terms is managed
+automatically via garbage collection. However, a consequence of this is that
+a particular term does not have a fixed address across its entire lifetime
+in most cases. Sometimes this is undesirable, especially if you intend for
+the address of the memory to be taken by the semantics or if you intend
+to pass this memory directly to native code. As a result, the FFI module
+exposes the following unsafe APIs for memory management. Note that use of
+these APIs leaves the burden of memory management completely on the user,
+and thus misuse of these functions can lead to things like use-after-free
+and other memory corruption bugs.

+

Allocation

+ +

#alloc(Key, Size, Align) will allocate Size bytes with an alignment
+requirement of Align (which must be a power of two), and return it as a
+Bytes term. The memory is uniquely identified by its key and that key will
+be used later to free the memory. The memory is not implicitly freed by garbage
+collection; failure to call #free on the memory at a later date can lead to
+memory leaks.

+
  syntax Bytes ::= "#alloc" "(" KItem "," Int "," Int ")" [function, hook(FFI.alloc)]
+

Addressing

+ +

#addess(B) will return an Int representing the address of the first byte of
+B, which must be a Bytes. Unless the Bytes term was allocated by #alloc,
+the return value is unspecified and may not be the same across multipl
+invocations on the same byte buffer. However, it is guaranteed that memory
+allocated by #alloc will have the same address throughout its lifetime.

+
  syntax Int ::= "#address" "(" Bytes ")" [function, hook(FFI.bytes_address)]
+

Deallocation

+ +

#free(Key) will free the memory of the Bytes object that was allocated
+by a previous call to #alloc. If Key was not used in a previous call to
+#alloc, or the memory was already freed, no action is taken. It will generate
+undefined behavior if the Bytes term returned by the previous call to
+#alloc is still referenced by any other term in the configuration or a
+currently evaluating rule. The function returns .K.

+
  syntax K ::= "#free" "(" KItem ")" [function, hook(FFI.free)]
+

Reading

+ +

#nativeRead(Addr, Mem) will read native memory at address Addr into Mem,
+reading exactly lengthBytes(Mem) bytes. This will generate undefined behavior
+if Addr does not point to a readable segment of memory at least
+lengthBytes(Mem) bytes long.

+
  syntax K ::= "#nativeRead" "(" Int "," Bytes ")" [function, hook(FFI.read)]
+

Writing

+ +

#nativeWrite(Addr, Mem) will write the contents of Mem to native memory at
+address Addr. The memory will be read prior to being written, and a write
+will only happen if the memory has a different value than the current value of
+Mem. This will generate undefined behavior if Addr does not point to a
+readable segment of memory at least lengthBytes(Mem) bytes long, or if the
+memory at address Addr has a different value than currently contained in
+Mem, and the memory in question is not writeable.

+
  syntax K ::= "#nativeWrite" "(" Int "," Bytes ")" [function, hook(FFI.write)]
+endmodule
+

Syntax of JSON

+

K provides builtin support for reading/writing to JSON. While the JSON-SYNTAX
+module is not precisely the syntax of JSON (utilizing K's syntax for strings,
+integers, and floating point numbers rather than the syntax used by JSON),
+you can still convert directly to/from the actual syntax of JSON using
+the JSON2String and String2JSON hooks.

+
module JSON-SYNTAX
+    imports INT-SYNTAX
+    imports STRING-SYNTAX
+    imports BOOL-SYNTAX
+    imports FLOAT-SYNTAX
+
+    syntax JSONs   ::= List{JSON,","}      [klabel(JSONs)      , symbol]
+    syntax JSONKey ::= String
+    syntax JSON    ::= "null"              [klabel(JSONnull)   , symbol]
+                     | String | Int | Float | Bool
+                     | JSONKey ":" JSON    [klabel(JSONEntry)  , symbol]
+                     | "{" JSONs "}"       [klabel(JSONObject) , symbol]
+                     | "[" JSONs "]"       [klabel(JSONList)   , symbol]
+endmodule
+

Conversion between JSON and String

+

Given a string written in valid JSON, you can convert it to the JSON
+sort with the String2JSON function. Assuming the user has not extended
+the syntax of the JSON sort with their own constructors, any term of sort
+JSON can also be converted to a String using the JSON2String function.

+
module JSON
+    imports JSON-SYNTAX
+
+    syntax String ::= JSON2String(JSON) [function, hook(JSON.json2string)]
+
+    syntax JSON ::= String2JSON(String) [function, hook(JSON.string2json)]
+endmodule
+

Rational Numbers in K

+

K provides support for arbitrary-precision rational numbers represented as a
+quotient between two integers. The sort representing these values is Rat.
+Int is a subsort of Rat, and it is guaranteed that any integer will be
+represented as an Int and can be matched as such on the left hand side
+of rules. K also supports the usual arithmetic operators over rational numbers.

+
module RAT-SYNTAX
+  imports INT-SYNTAX
+  imports private BOOL
+
+  syntax Rat
+
+  syntax Rat ::= Int
+

Arithmetic

+

You can:

+
    +
  • Raise a rational number to any negative or nonnegative integer.
  • +
  • Multiply or divide two rational numbers to obtain a product or quotient.
  • +
  • Add or subtract two rational numbers to obtain a sum or difference.
  • +
+
  syntax Rat ::= left:
+                 Rat "^Rat" Int [function, total, klabel(_^Rat_), symbol, smtlib(ratpow), hook(RAT.pow)]
+               > left:
+                 Rat "*Rat" Rat [function, total, klabel(_*Rat_), symbol, left, smtlib(ratmul), hook(RAT.mul)]
+               | Rat "/Rat" Rat [function,             klabel(_/Rat_), symbol, left, smtlib(ratdiv), hook(RAT.div)]
+               > left:
+                 Rat "+Rat" Rat [function, total, klabel(_+Rat_), symbol, left, smtlib(ratadd), hook(RAT.add)]
+               | Rat "-Rat" Rat [function, total, klabel(_-Rat_), symbol, left, smtlib(ratsub), hook(RAT.sub)]
+

Comparison

+

You can determine whether two rational numbers are equal, unequal, or compare
+one of less than, less than or equalto, greater than, or greater than or equal
+to the other:

+
  syntax Bool ::= Rat  "==Rat" Rat [function, total, klabel(_==Rat_),  symbol, smtlib(rateq), hook(RAT.eq)]
+                | Rat "=/=Rat" Rat [function, total, klabel(_=/=Rat_), symbol, smtlib(ratne), hook(RAT.ne)]
+                | Rat   ">Rat" Rat [function, total, klabel(_>Rat_),   symbol, smtlib(ratgt), hook(RAT.gt)]
+                | Rat  ">=Rat" Rat [function, total, klabel(_>=Rat_),  symbol, smtlib(ratge), hook(RAT.ge)]
+                | Rat   "<Rat" Rat [function, total, klabel(_<Rat_),   symbol, smtlib(ratlt), hook(RAT.lt)]
+                | Rat  "<=Rat" Rat [function, total, klabel(_<=Rat_),  symbol, smtlib(ratle), hook(RAT.le)]
+

Min/Max

+

You can compute the minimum and maximum of two rational numbers:

+
  syntax Rat ::= minRat(Rat, Rat) [function, total, klabel(minRat), symbol, smtlib(ratmin), hook(RAT.min)]
+               | maxRat(Rat, Rat) [function, total, klabel(maxRat), symbol, smtlib(ratmax), hook(RAT.max)]
+

Conversion to Floating Point

+

You can convert a rational number to the nearest floating point number that
+is representable in a Float of a specified number of precision and exponent
+bits:

+
  syntax Float ::= Rat2Float(Rat, precision: Int, exponentBits: Int) [function]
+endmodule
+

Implementation of Rational Numbers

+

The remainder of this file consists of an implementation in K of the
+operations listed above. Users of the RAT module should not use any of the
+syntax defined in any of these modules.

+

As a point of reference for users, it is worth noting that rational numbers
+are normalized to a canonical form by this module,. with the canonical form
+bearing the property that it is either an Int, or a pair of integers
+I /Rat J such that
+I =/=Int 0 andBool J >=Int 2 andBool gcdInt(I, J) ==Int 1 is always true.

+
module RAT-COMMON
+  imports RAT-SYNTAX
+
+  // invariant of < I , J >Rat : I =/= 0, J >= 2, and I and J are coprime
+  syntax Rat ::= "<" Int "," Int ">Rat" [format(%2 /Rat %4)]
+endmodule
+
+module RAT-SYMBOLIC [symbolic, kore]
+  imports private RAT-COMMON
+  imports ML-SYNTAX
+  imports private BOOL
+
+  rule
+    #Ceil(@R1:Rat /Rat @R2:Rat)
+  =>
+    {(@R2 =/=Rat 0) #Equals true} #And #Ceil(@R1) #And #Ceil(@R2)
+  [simplification]
+endmodule
+
+module RAT-KORE [kore]
+  imports private RAT-COMMON
+  imports private K-EQUAL
+
+  /*
+   * equalities
+   */
+
+  // NOTE: the two rules below may not work correctly in non-kore backends
+
+  rule R ==Rat S => R ==K S
+
+  rule R =/=Rat S => R =/=K S
+endmodule
+
+module RAT [private]
+  imports private RAT-COMMON
+  imports public RAT-SYMBOLIC
+  imports public RAT-KORE
+  imports public RAT-SYNTAX
+  imports private INT
+  imports private BOOL
+
+  /*
+   * arithmetic
+   */
+
+  rule < I , I' >Rat +Rat < J , J' >Rat => ((I *Int J') +Int (I' *Int J)) /Rat (I' *Int J')
+  rule I:Int         +Rat < J , J' >Rat => ((I *Int J') +Int J) /Rat J'
+  rule < J , J' >Rat +Rat I:Int         => I +Rat < J , J' >Rat
+  rule I:Int         +Rat J:Int         => I +Int J
+
+  rule < I , I' >Rat *Rat < J , J' >Rat => (I *Int J) /Rat (I' *Int J')
+  rule I:Int         *Rat < J , J' >Rat => (I *Int J) /Rat J'
+  rule < J , J' >Rat *Rat I:Int         => I *Rat < J , J' >Rat
+  rule I:Int         *Rat J:Int         => I *Int J
+
+  rule < I , I' >Rat /Rat < J , J' >Rat => (I *Int J') /Rat (I' *Int J)
+  rule I:Int         /Rat < J , J' >Rat => (I *Int J') /Rat J
+  rule < I , I' >Rat /Rat J:Int         => I /Rat (I' *Int J) requires J =/=Int 0
+  rule I:Int         /Rat J:Int         => makeRat(I, J)      requires J =/=Int 0
+
+  // derived
+
+  rule R -Rat S => R +Rat (-1 *Rat S)
+
+  // normalize
+
+  syntax Rat ::= makeRat(Int, Int)      [function]
+               | makeRat(Int, Int, Int) [function]
+
+  rule makeRat(0, J) => 0 requires J =/=Int 0
+
+  rule makeRat(I, J) => makeRat(I, J, gcdInt(I,J)) requires I =/=Int 0 andBool J =/=Int 0
+
+  // makeRat(I, J, D) is defined when I =/= 0, J =/= 0, D > 0, and D = gcd(I,J)
+  rule makeRat(I, J, D) => I /Int D                       requires J ==Int D // implies J > 0 since D > 0
+  rule makeRat(I, J, D) => < I /Int D , J /Int D >Rat     requires J >Int 0 andBool J =/=Int D
+  rule makeRat(I, J, D) => makeRat(0 -Int I, 0 -Int J, D) requires J <Int 0
+
+  // gcdInt(a,b) computes the gcd of |a| and |b|, which is positive.
+  syntax Int ::= gcdInt(Int, Int) [function, public]
+
+  rule gcdInt(A, 0) => A        requires A >Int 0
+  rule gcdInt(A, 0) => 0 -Int A requires A <Int 0
+  rule gcdInt(A, B) => gcdInt(B, A %Int B) requires B =/=Int 0 // since |A %Int B| = |A| %Int |B|
+
+  /*
+   * exponentiation
+   */
+
+  rule _ ^Rat 0 => 1
+  rule 0 ^Rat N => 0 requires N =/=Int 0
+
+  rule < I , J >Rat ^Rat N => powRat(< I , J >Rat, N) requires N >Int 0
+  rule X:Int        ^Rat N => X ^Int N                requires N >Int 0
+
+  rule X ^Rat N => (1 /Rat X) ^Rat (0 -Int N) requires X =/=Rat 0 andBool N <Int 0
+
+  // exponentiation by squaring
+
+  syntax Rat ::= powRat(Rat, Int) [function]
+
+  // powRat(X, N) is defined when X =/= 0 and N > 0
+  rule powRat(X, 1) => X
+  rule powRat(X, N) => powRat(X *Rat X, N /Int 2) requires N >Int 1 andBool N %Int 2  ==Int 0
+  rule powRat(X, N) => powRat(X, N -Int 1) *Rat X requires N >Int 1 andBool N %Int 2 =/=Int 0
+
+  /*
+   * inequalities
+   */
+
+  rule R >Rat S => R -Rat S >Rat 0 requires S =/=Rat 0
+
+  rule < I , _ >Rat >Rat 0 => I >Int 0
+  rule I:Int        >Rat 0 => I >Int 0
+
+  // derived
+
+  rule R >=Rat S => notBool R <Rat S
+
+  rule R <Rat S => S >Rat R
+
+  rule R <=Rat S => S >=Rat R
+
+  rule minRat(R, S) => R requires R <=Rat S
+  rule minRat(R, S) => S requires S <=Rat R
+
+  rule maxRat(R, S) => R requires R >=Rat S
+  rule maxRat(R, S) => S requires S >=Rat R
+
+  syntax Float ::= #Rat2Float(Int, Int, Int, Int) [function, hook(FLOAT.rat2float)]
+  rule Rat2Float(Num:Int, Prec:Int, Exp:Int) => #Rat2Float(Num, 1, Prec, Exp)
+  rule Rat2Float(< Num, Dem >Rat, Prec, Exp) => #Rat2Float(Num, Dem, Prec, Exp)
+
+endmodule
+

Capture-Aware Substitution in K

+

One of the traditional ways in which functional languages are given operational
+semantics is via substitution. In particular, you can view a function as
+declaring a particular bound variable, the parameter of the function, as well
+as the body of the function, within which both bound and free variables can
+occur, and implement the process of beta-reduction (one of the axioms of the
+lambda calculus) by means of a substitution operator which is aware of the
+difference between free variables and bound variables and prevents variable
+capture.

+

In K this is implemented using two mechanisms: The KVar sort, and the
+binder attribute.

+

The KVar Sort

+

K introduces a new hooked sort, KVar, which the substitution operator
+(defined below) understands in a particular way. The syntax of KVar is the
+same as for sort Id in DOMAINS, but with a different sort name. Similarly,
+some of the same operators are defined over KVar which are defined for Id,
+such as conversion from String to KVar and support for the !Var:KVar
+syntax.

+

A KVar is simply an identifier with special meaning during substitution.
+KVars must begin with a letter or underscore,
+and can be followed by zero or more letters, numbers, or underscores.

+
module KVAR-SYNTAX-PROGRAM-PARSING
+  imports BUILTIN-ID-TOKENS
+
+  syntax KVar ::= r"(?<![A-Za-z0-9\\_])[A-Za-z\\_][A-Za-z0-9\\_]*"     [prec(1), token]
+                | #LowerId                                             [token]
+                | #UpperId                                             [token]
+endmodule
+
+module KVAR-SYNTAX
+  syntax KVar [token, hook(KVAR.KVar)]
+endmodule
+
+module KVAR-COMMON
+  imports KVAR-SYNTAX
+  imports private STRING
+
+  syntax KVar ::= String2KVar (String) [function, total, hook(STRING.string2token)]
+  syntax KVar ::= freshKVar(Int)    [freshGenerator, function, total, private]
+
+  rule freshKVar(I:Int) => String2KVar("_" +String Int2String(I))
+endmodule
+
+module KVAR
+  imports KVAR-COMMON
+endmodule
+

The binder Attribute

+

A production can be given the attribute binder. Such a production must have
+at least two nonterminals. The first nonterminal from left to right must be of
+sort KVar, and contains the bound variable. The last nonterminal from left
+to right contains the term that is bound. For example, I could describe lambdas
+in the lambda calculus with the production
+syntax Val ::= "lambda" KVar "." Exp [binder].

+

Substitution

+

K provides a hooked implementation of substitution, currently only implemented
+on the Java and LLVM backends. Two variants exist: the first substitutes
+a single KVar for a single KItem. The second takes a Map with KVar
+keys and KItem values, and substitutes each element in the map atomically.

+

Internally, this is implemented in the LLVM backend by a combination of
+de Bruijn indices for bound variables and names for free variables. Free
+variables are also sometimes given a unique numeric identifier in order to
+prevent capture, and the rewriter will automatically assign unique names to
+such identifiers when rewriting finishes. The names assigned will always begin
+with the original name of the variable and be followed by a unique integer
+suffix. However, the names assigned after rewriting finishes might be different
+from the names that would be assigned if rewriting were to halt prematurely,
+for example due to krun --depth.

+
module SUBSTITUTION
+  imports private MAP
+  imports KVAR
+
+  syntax {Sort} Sort ::= Sort "[" KItem "/" KItem "]"  [function, hook(SUBSTITUTION.substOne), impure]
+  syntax {Sort} Sort ::= Sort "[" Map "]"      [function, hook(SUBSTITUTION.substMany), impure]
+endmodule
+

K PL Tutorial

+ +

Here you will learn how to use the K tool to define languages by means of a series of screencast movies. It is recommended to do these in the indicated order, because K features already discussed in a previous language definition will likely not be rediscussed in latter definitions. The screencasts follow quite closely the structure of the files under the tutorial folder in the K tool distribution. If you'd rather follow the instructions there and do the tutorial exercises yourself, then go back to https://kframework.org and download the K tool, if you have not done it already. Or, you can first watch the screencasts below and then do the exercises, or do them in parallel.

+

K Overview

+ +

Make sure you watch the K overview video before you do the K tutorial:

+ +

Learning K

+ +

[34'46"] Part 1: Defining LAMBDA

+ +

Here you will learn how to define a very simple functional language in K and the basics of how to use the K tool. The language is a call-by-value variant of lambda calculus with builtins and mu, and its definition is based on substitution.

+ +

[37'07"] Part 2: Defining IMP

+ +

Here you will learn how to define a very simple, prototypical textbook C-like imperative language, called IMP, and several new features of the K tool.

+ +

[33'10"] Part 3: Defining LAMBDA++

+ +

Here you will learn how to define constructs which abruptly change the execution control, as well as how to define functional languages using environments and closures. LAMBDA++ extends the LAMBDA language above with a callcc construct.

+ +

[46'46"] Part 4: Defining IMP++

+ +

Here you will learn how to refine configurations, how to generate fresh elements, how to tag syntactic constructs and rules, how to exhaustively search the space of non-deterministic or concurrent program executions, etc. IMP++ extends the IMP language above with increment, blocks and locals, dynamic threads, input/output, and abrupt termination.

+ +

[17'03"] Part 5: Defining Type Systems

+ +

Here you will learn how to define various kinds of type systems following various approaches or styles using K.

+ +

[??'??"] Part 6: Miscellaneous Other K Features

+ +

Here you will learn a few other K features, and better understand how features that you have already seen work.

+
    +
  • [??'??"] ...
  • +
+

Learning Language Design and Semantics using K

+ +

[??'??"] Part 7: SIMPLE: Designing Imperative Programming Languages

+ +

Here you will learn how to design imperative programming languages using K. SIMPLE is an imperative language with functions, threads, pointers, exceptions, multi-dimensional arrays, etc. We first define an untyped version of SIMPLE, then a typed version. For the typed version, we define both a static and a dynamic semantics.

+ +

[??'??"] Part 8: KOOL: Designing Object-Oriented Programming Languages

+ +

Here woul will learn how to design object-oriented programming languages using K. KOOL is an object-oriented language that extends SIMPLE with classes and objects. We first define an untyped version of KOOL, then a typed version, with both a dynamic and a static semantics.

+ +

[??'??"] Part 9: FUN: Designing Functional Programming Languages

+ +

H
+ere woul will learn how to design functional programming languages using K. FUN is a higher-order functional language with general let, letrec, pattern matching, references, lists, callcc, etc. We first define an untyped version of FUN, then a let-polymorphic type inferencer.

+ +

[??'??"] Part 10: LOGIK: Designing Logic Programming Languages

+ +

Here you will learn how to design a logic programming language using K.

+ +

K overview

+ + +

Go to Youtube mirror, if the above does not work.

+

Go back to https://kframework.org for further links, the K tool and contact information.

+

Learning K

+ +

We start by introducing the basic features of K by means of a series
+of very simple languages. The objective here is neither to learn those
+languages nor to study their underlying paradigm, but simply to learn K.

+
    +
  • LAMBDA: Lambda calculus defined.
  • +
  • IMP: A simple imperative language.
  • +
  • LAMBDA++: LAMBDA extended with control flow.
  • +
  • IMP++: IMP extended with threads and IO.
  • +
  • TYPES: LAMBDA type system.
  • +
+

Part 1: Defining LAMBDA

+ +

Here you will learn how to define a very simple language in K and the basics
+of how to use the K tool. The language is a variant of call-by-value lambda
+calculus and its definition is based on substitution. Specifically, you will
+learn the following:

+
    +
  • How to define a module.
  • +
  • How to define a language syntax.
  • +
  • How to use the defined syntax to parse programs.
  • +
  • How to import predefined modules.
  • +
  • How to define evaluation strategies using strictness attributes.
  • +
  • How to define semantic rules.
  • +
  • How the predefined generic substitution works.
  • +
  • How to generate PDF and HTML documentation from ASCII definitions.
  • +
  • How to include builtins (integers and Booleans) into your language.
  • +
  • How to define derived language constructs.
  • +
+

This folder contains several lessons, each adding new features to LAMBDA.

+

Syntax Modules and Basic K Commands

+ +

Here we define our first K module, which contains the initial syntax of the
+LAMBDA language, and learn how to use the basic K commands.

+

Let us create an empty working folder, and open a terminal window
+(to the left) and an editor window (to the right). We will edit our K
+definition in the right window in a file called lambda.k, and will call
+the K tool commands in the left window.

+

Let us start by defining a K module, containing the syntax of LAMBDA.

+

K modules are introduced with the keywords module ... endmodule.

+

The keyword syntax adds new productions to the syntax grammar, using a
+BNF-like notation.

+

Terminals are enclosed in double-quotes, like strings.

+

You can define multiple productions for the same non-terminal in the same
+syntax declaration using the | separator.

+

Productions can have attributes, which are enclosed in square brackets.

+

The attribute left tells the parser that we want the lambda application to be
+left associative. For example, a b c d will then parse as (((a b) c) d).

+

The attribute bracket tells the parser to not generate a node for the
+parenthesis production in the abstract syntax trees associated to programs.
+In other words, we want to allow parentheses to be used for grouping, but we
+do not want to bother to give them their obvious (ignore) semantics.

+

In our variant of lambda calculus defined here, identifiers and lambda
+abstractions are meant to be irreducible, that is, are meant to be values.
+However, so far Val is just another non-terminal, just like Exp,
+without any semantic meaning. It will get a semantic meaning later.

+

After we are done typing our definition in the file lambda.k, we can kompile
+it with the command:

+
kompile lambda.k
+
+

If we get no errors then a parser has been generated. This parser will be
+called from now on by default by the krun tool. To see whether and how the
+parser works, we are going to write some LAMBDA programs and store them in
+files with the extension .lambda.

+

Let us create a file identity.lambda, which contains the identity lambda
+abstraction:

+
lambda x . x
+
+

Now let us call krun on identity.lambda:

+
krun identity.lambda
+
+

Make sure you call the krun command from the folder containing your language
+definition (otherwise type krun --help to learn how to pass a language
+definition as a parameter to krun). The krun command produces the output:

+
<k>
+  lambda x . x
+</k>
+
+

If you see such an output it means that your program has been parsed (and then
+pretty printed) correctly. If you want to see the internal abstract syntax
+tree (AST) representation of the parsed program, which we call the K AST, then
+type kast in the command instead of krun:

+
kast identity.lambda
+
+

You should normally never need to see this internal representation in your
+K definitions, so do not get scared (yes, it is ugly for humans, but it is
+very convenient for tools).

+

Note that krun placed the program in a <k> ... </k> cell. In K, computations
+happen only in cells. If you do not define a configuration in your definition,
+like we did here, then a configuration will be created automatically for you
+which contains only one cell, the default k cell, which holds the program.

+

Next, let us create a file free-variable-capture.lambda, which contains an
+expression which, in order to execute correctly in a substitution-based
+semantics of LAMBDA, the substitution operation needs to avoid
+variable-capture:

+
a (((lambda x.lambda y.x) y) z)
+
+

Next, file closed-variable-capture.lambda shows an expression which also
+requires a capture-free substitution, but this expression is closed (that is,
+it has no free variables) and all its bound variables are distinct (I believe
+this is the smallest such expression):

+
(lambda z.(z z)) (lambda x.lambda y.(x y))
+
+

Finally, the file omega.lambda contains the classic omega combinator
+(or closed expression), which is the smallest expression which loops forever
+(not now, but after we define the semantics of LAMBDA):

+
(lambda x.(x x)) (lambda x.(x x))
+
+

Feel free to define and parse several other LAMBDA programs to get a feel for
+how the parser works. Parse also some incorrect programs, to see how the
+parser generates error messages.

+

In the next lesson we will see how to define semantic rules that iteratively
+rewrite expressions over the defined syntax until they evaluate to a result.
+This way, we obtain our first programming language defined using K.

+

Go to Lesson 2, LAMBDA: Module Importing, Rules, Variables

+

MOVIE (out of date) [4'07"]

+

Module Importing, Rules, Variables

+ +

We here learn how to include a predefined module (SUBSTITUTION), how to
+use it to define a K rule (the characteristic rule of lambda calculus),
+and how to make proper use of variables in rules.

+

Let us continue our lambda.k definition started in the previous lesson.

+

The requires keyword takes a .k file containing language features that
+are needed for the current definition, which can be found in the
+k-distribution/include/kframework/builtin folder. Thus, the command

+
require "substitution.k"
+
+

says that the subsequent definition of LAMBDA needs the generic substitution,
+which is predefined in file substitution.k under the folder
+k-distribution/include/kframework/builtin. Note that substitution can be defined itself in K,
+although it uses advanced features that we have not discussed yet in this
+tutorial, so it may not be easy to understand now.

+

Using the imports keyword, we can now modify LAMBDA to import the module
+SUBSTITUTION, which is defined in the required substitution.k file.

+

Now we have all the substitution machinery available for our definition.
+However, since our substitution is generic, it cannot know which language
+constructs bind variables, and what counts as a variable; however, this
+information is critical in order to correctly solve the variable capture
+problem. Thus, you have to tell the substitution that your lambda construct
+is meant to be a binder, and that your Id terms should be treated as variables
+for substitution. The former is done using the attribute binder.
+By default, binder binds all the variables occurring anywhere in the first
+argument of the corresponding syntactic construct within its other arguments;
+you can configure which arguments are bound where, but that will be discussed
+in subsequent lectures. To tell K which terms are meant to act as variables
+for binding and substitution, we have to explicitly subsort the desired syntactic
+categories to the builtin KVariable sort.

+

Now we are ready to define our first K rule. Rules are introduced with the
+keyword rule and make use of the rewrite symbol, =>. In our case,
+the rule defines the so-called lambda calculus beta-reduction, which
+makes use of substitution in its right-hand side, as shown in lambda.k.

+

By convention, variables that appear in rules start with a capital letter
+(the current implementation of the K tool may even enforce that).

+

Variables may be explicitly tagged with their syntactic category (also called
+sort). If tagged, the matching term will be checked at run-time for
+membership to the claimed sort. If not tagged, then no check will be made.
+The former is safer, but involves the generation of a side condition to the
+rule, so the resulting definition may execute slightly slower overall.

+

In our rule in lambda.k we tagged all variables with their sorts, so we chose
+the safest path. Only the V variable really needs to be tagged there,
+because we can prove (using other means, not the K tool, as the K tool is not
+yet concerned with proving) that the first two variables will always have the
+claimed sorts whenever we execute any expression that parses within our
+original grammar.

+

Let us compile the definition and then run some programs. For example,

+
krun closed-variable-capture.lambda
+
+

yields the output

+
<k>
+  lambda y . ((lambda x . (lambda y . (x  y))) y)
+</k> 
+
+

Notice that only certain programs reduce (some even yield non-termination,
+such as omega.lambda), while others do not. For example,
+free-variable-capture.lambda does not reduce its second argument expression
+to y, as we would expect. This is because the K rewrite rules between syntactic
+terms do not apply anywhere they match. They only apply where they have been
+given permission to apply by means of appropriate evaluation strategies of language
+constructs, which is done using strictness attributes, evaluation contexts,
+heating/cooling rules, etc., as discussed in the next lessons.

+

The next lesson will show how to add LAMBDA the desired evaluation strategies
+using strictness attributes.

+

Go to Lesson 3, LAMBDA: Evaluation Strategies using Strictness

+

MOVIE (out of date) [4'03"]

+

Evaluation Strategies using Strictness

+ +

Here we learn how to use the K strict attribute to define desired evaluation
+strategies. We will also learn how to tell K which terms are already
+evaluated, so it does not attempt to evaluate them anymore and treats them
+internally as results of computations.

+

Recall from the previous lecture that the LAMBDA program
+free-variable-capture.lambda was stuck, because K was not given permission
+to evaluate the arguments of the lambda application construct.

+

You can use the attribute strict to tell K that the corresponding construct
+has a strict evaluation strategy, that is, that its arguments need to be
+evaluated before the semantics of the construct applies. The order of
+argument evaluation is purposely unspecified when using strict, and indeed
+the K tool allows us to detect all possible non-deterministic behaviors that
+result from such intended underspecification of evaluation strategies. We will
+learn how to do that when we define the IMP language later in this tutorial;
+we will also learn how to enforce a particular order of evaluation.

+

In order for the above strictness declaration to work effectively and
+efficiently, we need to tell the K tool which expressions are meant to be
+results of computations, so that it will not attempt to evaluate them anymore.
+One way to do it is to make Val a syntactic subcategory of the builtin
+KResult syntactic category. Since we use the same K parser to also parse
+the semantics, we use the same syntax keyword to define additional syntax
+needed exclusively for the semantics (like KResults). See lambda.k.

+

Compile again and then run some programs. They should all work as expected.
+In particular, free-variable-capture.lambda now evaluates to a y.

+

We now got a complete and working semantic definition of call-by-value
+lambda-calculus. While theoretically correct, our definition is not
+easy to use and disseminate. In the next lessons we will learn how to
+generate formatted documentation for LAMBDA and how to extend LAMBDA
+in order to write human readable and interesting programs.

+

Go to Lesson 4, LAMBDA: Generating Documentation; Latex Attributes.

+

MOVIE (out of date) [2'20"]

+

Generating Documentation; Latex Attributes

+ +

In this lesson we learn how to generate formatted documentation from K
+language definitions. We also learn how to use Latex attributes to control
+the formatting of language constructs, particularly of ones which have a
+mathematical flavor and we want to display accordingly.

+

To enhance readability, we may want to replace the keyword lambda by the
+mathematical lambda symbol in the generated documentation. We can control
+the way we display language constructs in the generated documentation
+by associating them Latex attributes.

+

This is actually quite easy. All we have to do is to associate a latex
+attribute to the production defining the construct in question, following
+the Latex syntax for defining new commands (or macros).

+

In our case, we associate the attribute latex(\lambda{#1}.{#2}) to the
+production declaring the lambda abstraction (recall that in Latex, #n refers
+to the n-th argument of the defined new command).

+

We will later see, in Lesson 9, that we can add arbitrarily complex Latex
+comments and headers to our language definitions, which give us maximum
+flexibility in formatting our language definitions.

+

Now we have a simple programming language, with a nice documentation. However,
+it is not easy to write interesting programs in this language. Almost all
+programming languages build upon existing data-types and libraries. The K
+tool provides a few of these (and you can add more).

+

In the next lesson we show how we can add builtin integers and Booleans to
+LAMBDA, so we can start to evaluate meaningful expressions.

+

Go to Lesson 5, LAMBDA: Adding Builtins; Side Conditions.

+

MOVIE (out of date) [3'13"]

+

Adding Builtins; Side Conditions

+ +

We have already added the builtin identifiers (sort Id) to LAMBDA expressions,
+but those had no operations on them. In this lesson we add integers and
+Booleans to LAMBDA, and extend the builtin operations on them into
+corresponding operations on LAMBDA expressions. We will also learn how to add
+side conditions to rules, to limit the number of instances where they can
+apply.

+

The K tool provides several builtins, which are automatically included in all
+definitions. These can be used in the languages that we define, typically by
+including them in the desired syntactic categories. You can also define your
+own builtins in case the provided ones are not suitable for your language
+(e.g., the provided builtin integers and operations on them are arbitrary
+precision).

+

For example, to add integers and Booleans as values to our LAMBDA, we have to
+add the productions

+
syntax Val ::= Int | Bool
+
+

Int and Bool are the nonterminals that correspond to these builtins.

+

To make use of these builtins, we have to add some arithmetic operation
+constructs to our language. We prefer to use the conventional infix notation
+for these, and the usual precedences (i.e., multiplication and division bind
+tighter than addition, which binds tighter than relational operators).
+Inspired from SDF, we use > instead of
+| to state that all the previous constructs bind tighter than all the
+subsequent ones. See lambda.k.

+

The only thing left is to link the LAMBDA arithmetic operations to the
+corresponding builtin operations, when their arguments are evaluated.
+This can be easily done using trivial rewrite rules, as shown in lambda.k.
+In general, the K tool attempts to uniformly add the corresponding builtin
+name as a suffix to all the operations over builtins. For example, the
+addition over integers is an infix operation named +Int.

+

Compile the new lambda.k definition and evaluate some simple arithmetic
+expressions. For example, if arithmetic.lambda is (1+2*3)/4 <= 1, then

+
krun arithmetic.lambda
+
+

yields, as expected, true. Note that the parser took the desired operation
+precedence into account.

+

Let us now try to evaluate an expression which performs a wrong computation,
+namely a division by zero. Consider the expression arithmetic-div-zero.lambda
+which is 1/(2/3). Since division is strict and 2/3 evaluates to 0, this
+expression reduces to 1/0, which further reduces to 1 /Int 0 by the rule for
+division, which is now stuck (with the current back-end to the K tool).

+

In fact, depending upon the back-end that we use to execute K definitions and
+in particular to evaluate expressions over builtins, 1 /Int 0 can evaluate to
+anything. It just happens that the current back-end keeps it as an
+irreducible term. Other K back-ends may reduce it to an explicit error
+element, or issue a segmentation fault followed by a core dump, or throw an
+exception, etc.

+

To avoid requesting the back-end to perform an illegal operation, we may use a
+side condition in the rule of division, to make sure it only applies when the
+denominator is non-zero.

+

Like in other operational formalisms, the role of the K side
+conditions is to filter the number of instances of the rule. The notion
+of a side condition comes from logics, where a sharp distinction is made
+between a side condition (cheap) and a premise (expensive). Premises are
+usually resolved using further (expensive) logical derivations, while side
+conditions are simple (cheap) conditions over the rule meta-variables within
+the underlying mathematical domains (which in K can be extended by the user,
+as we will see in future lessons). Regarded as a logic, K derives rewrite
+rules from other rewrite rules; therefore, the K side conditions cannot
+contain other rewrites in them (using =>). This contrasts other rewrite
+engines, for example Maude, which
+allow conditional rules with rewrites in conditions.
+The rationale behind this deliberate restriction in K is twofold:

+
    +
  • On the one hand, general conditional rules require a complex, and thus slower
    +rewrite engine, which starts recursive (sometimes exhaustive) rewrite sessions
    +to resolve the rewrites in conditions. In contrast, the side conditions in K
    +can be evaluated efficiently by back-ends, for example by evaluating builtin
    +expressions and/or by calling builtin functions.
  • +
  • On the other hand, the semantic definitional philosophy of K is that rule
    +premises are unnecessary, so there is no need to provide support for them.
  • +
+

Having builtin arithmetic is useful, but writing programs with just lambda
+and arithmetic constructs is still a pain. In the next two lessons we will
+add conditional (if_then_else) and binding (let and letrec) constructs,
+which will allow us to write nicer programs.

+

Go to Lesson 6, LAMBDA: Selective Strictness; Anonymous Variables.

+

MOVIE (out of date) [4'52"]

+

Selective Strictness; Anonymous Variables

+ +

We here show how to define selective strictness of language constructs,
+that is, how to state that certain language constructs are strict only
+in some arguments. We also show how to use anonymous variables.

+

We next define a conditional if construct, which takes three arguments,
+evaluates only the first one, and then reduces to either the second or the
+third, depending on whether the first one evaluated to true or to false.

+

K allows to define selective strictness using the same strict attribute,
+but passing it a list of numbers. The numbers correspond to the arguments
+in which we want the defined construct to be strict. In our case,

+
syntax Exp ::= "if" Exp "then" Exp "else" Exp   [strict(1)]
+
+

states that the conditional construct is strict in the first argument.

+

We can now assume that its first argument will eventually reduce to a value, so
+we only write the following two semantic rules:

+
rule if true  then E else _ => E
+rule if false then _ else E => E
+
+

Thus, we assume that the first argument evaluates to either true or false.

+

Note the use of the anonymous variable _. We use such variables purely for
+structural reasons, to state that something is there but we don't care what.
+An anonymous variable is therefore completely equivalent to a normal variable
+which is unsorted and different from all the other variables in the rule. If
+you use _ multiple times in a rule, they will all be considered distinct.

+

Compile lambda.k and write and execute some interesting expressions making
+use of the conditional construct. For example, the expression

+
if 2<=1 then 3/0 else 10
+
+

evaluates to 10 and will never evaluate 3/0, thus avoiding an unwanted
+division-by-zero.

+

In the next lesson we will introduce two new language constructs, called
+let and letrec and conventionally found in functional programming
+languages, which will allow us to already write interesting LAMBDA programs.

+

Go to Lesson 7, LAMBDA: Derived Constructs; Extending Predefined Syntax.

+

MOVIE (out of date) [2'14"]

+

Derived Constructs, Extending Predefined Syntax

+ +

In this lesson we will learn how to define derived language constructs, that
+is, ones whose semantics is defined completely in terms of other language
+constructs. We will also learn how to add new constructs to predefined
+syntactic categories.

+

When defining a language, we often want certain language constructs to be
+defined in terms of other constructs. For example, a let-binding construct
+of the form

+
let x = e in e'
+
+

is nothing but syntactic sugar for

+
(lambda x . e') e
+
+

This can be easily achieved with a rule, as shown in lambda.k.

+

Compile lambda.k and write some programs using let binders.

+

For example, consider a lets.lambda program which takes arithmetic.lambda
+and replaces each integer by a let-bound variable. It should evaluate to
+true, just like the original arithmetic.lambda.

+

Let us now consider a more interesting program, namely one that calculates the
+factorial of 10:

+
let f = lambda x . (
+        (lambda t . lambda x . (t t x))
+        (lambda f . lambda x . (if x <= 1 then 1 else (x * (f f (x + -1)))))
+        x
+      )
+in (f 10)
+
+

This program follows a common technique to define fixed points in untyped
+lambda calculus, based on passing a function to itself.

+

We may not like to define fixed-points following the approach above, because
+it requires global changes in the body of the function meant to be recursive,
+basically to pass it to itself (f f in our case above). The approach below
+isolates the fixed-point aspect of the function in a so-called fixed-point
+combinator
, which we call fix below, and then apply it to the function
+defining the body of the factorial, without any changes to it:

+
let fix = lambda f . (
+          (lambda x . (f (lambda y . (x x y))))
+          (lambda x . (f (lambda y . (x x y))))
+        )
+in let f = fix (lambda f . lambda x .
+                (if x <= 1 then 1 else (x * (f (x + -1)))))
+   in (f 10)
+
+

Although the above techniques are interesting and powerful (indeed, untyped
+lambda calculus is in fact Turing complete), programmers will probably not
+like to write programs this way.

+

We can easily define a more complex derived construct, called letrec and
+conventionally encountered in functional programming languages, whose semantics
+captures the fixed-point idea above. In order to keep its definition simple
+and intuitive, we define a simplified variant of letrec, namely one which only
+allows to define one recursive one-argument function. See lambda.k.

+

There are two interesting observations here.

+

First, note that we have already in-lined the definition of the fix
+combinator in the definition of the factorial, to save one application of the
+beta reduction rule (and the involved substitution steps). We could have
+in-lined the definition of the remaining let, too, but we believe that the
+current definition is easier to read.

+

Second, note that we extended the predefined Id syntactic category with two
+new constants, $x and $y. The predefined identifiers cannot start with
+$, so programs that will be executed with this semantics cannot possibly
+contain the identifiers xandx andy. In other words, by adding them to Id they
+become indirectly reserved for the semantics. This is indeed desirable,
+because any possible uses of xinthebodyofthefunctiondefinedusingletrecwouldbecapturedbythelambdax in the body of the function defined +using `letrec` would be captured by the `lambdaxdeclaration in the definition ofletrec`.

+

Using letrec, we can now write the factorial program as elegantly as it can
+be written in a functional language:

+
letrec f x = if x <= 1 then 1 else (x * (f (x + -1)))
+in (f 10)
+
+

In the next lesson we will discuss an alternative definition of letrec, based
+on another binder, mu, specifically designed to define fixed points.

+

Go to Lesson 8, LAMBDA: Multiple Binding Constructs.

+

MOVIE (out of date) [5'10"]

+

Multiple Binding Constructs

+ +

Here we learn how multiple language constructs that bind variables can
+coexist. We will also learn about or recall another famous binder besides
+lambda, namely mu, which can be used to elegantly define all kinds of
+interesting fixed-point constructs.

+

The mu binder has the same syntax as lambda, except that it replaces
+lambda with mu.

+

Since mu is a binder, in order for substitution to know how to deal with
+variable capture in the presence of mu, we have to tell it that mu is a
+binding construct, same like lambda. We take advantage of being there and
+also add mu its desired latex attribute.

+

The intuition for

+
mu x . e
+
+

is that it reduces to e, but each free occurrence of x in e behaves
+like a pointer that points back to mu x . e.

+

With that in mind, let us postpone the definition of mu and instead redefine
+letrec F X = E in E' as a derived construct, assuming mu available. The
+idea is to simply regard F as a fixed-point of the function

+
lambda X . E
+
+

that is, to first calculate

+
mu F . lambda X . E
+
+

and then to evaluate E' where F is bound to this fixed-point:

+
let F = mu F . lambda X . E in E'
+
+

This new definition of letrec may still look a bit tricky, particularly
+because F is bound twice, but it is much simpler and cleaner than our
+previous definition. Moreover, now it is done in a type-safe manner
+(this aspect goes beyond our objective in this tutorial).

+

Let us now define the semantic rule of mu.

+

The semantics of mu is actually disarmingly simple. We just have to
+substitute mu X . E for each free occurrence of X in E:

+
mu X . E => E[(mu X . E) / X]
+
+

Compile lambda.k and execute some recursive programs. They should be now
+several times faster. Write a few more recursive programs, for example ones
+for calculating the Ackermann function, for calculating the number of moves
+needed to solve the Hanoi tower problem, etc.

+

We have defined our first programming language in K, which allows us to
+write interesting functional programs. In the next lesson we will learn how
+to fully document our language definition, in order to disseminate it, to ship
+it to colleagues or friends, to publish it, to teach it, and so on.

+

Go to Lesson 9, LAMBDA: A Complete and Commented Definition.

+

MOVIE (out of date) [2'40"]

+

A Complete and Documented K Definition

+ +

In this lesson you will learn how to add formal comments to your K definition,
+in order to nicely document it. The generated document can be then used for
+various purposes: to ease understanding the K definition, to publish it,
+to send it to others, etc.

+

The K tool allows a literate programming style, where the executable
+language definition can be documented by means of annotations. One such
+annotation is the latex(_) annotation, where you can specify how to format
+the given production when producing Latex output via the --output latex
+option to krun, kast, and kprove.

+

There are three types of comments, which we discuss next.

+

Ordinary comments

+ +

These use // or /* ... */, like in various programming languages. These
+comments are completely ignored.

+

Document annotations

+ +

Use the @ symbol right after // or /* in order for the comment to be
+considered an annotation and thus be processed by the K tool when it
+generates documentation.

+

As an example, we can go ahead and add such an annotation at the beginning
+of the LAMBDA module, explaining how we define the syntax of this language.

+

Header annotations

+ +

Use the ! symbol right after // or /* if you want the comment to be
+considered a header annotation, that is, one which goes before
+\begin{document} in the generated Latex. You typically need header
+annotations to include macros, or to define a title, etc.

+

As an example, let us set a Latex length and then add a title and an
+author to this K definition.

+

Compile the documentation and take a look at the results. Notice the title.

+

Feel free to now add lots of annotations to lambda.k.

+

Then compile and check the result. Depending on your PDF viewer, you
+may also see a nice click-able table of contents, with all the sections
+of your document. This could be quite convenient when you define large
+languages, because it helps you jump to any part of the semantics.

+

Tutorial 1 is now complete. The next tutorial will take us through the
+definition of a simple imperative language and will expose us to more
+feature of the K framework and the K tool.

+

MOVIE (out of date) [6'07"]

+

Part 2: Defining IMP

+ +

Here you will learn how to define a very simple imperative language in K
+and the basics of how to work with configurations, cells, and computations.
+Specifically, you will learn the following:

+
    +
  • How to define languages using multiple modules.
  • +
  • How to define sequentially strict syntactic constructs.
  • +
  • How to use K's syntactic lists.
  • +
  • How to define, initialize and configure configurations.
  • +
  • How the language syntax is swallowed by the builtin K syntactic category.
  • +
  • The additional syntax of the K syntactic category.
  • +
  • How the strictness annotations are automatically desugared into rules.
  • +
  • The first steps of the configuration abstraction mechanism.
  • +
+

Like in the previous tutorial, this folder contains several lessons, each
+adding new features to IMP. Do them in order. Also, make sure you completed
+and understood the previous tutorial.

+

Defining a More Complex Syntax

+ +

Here we learn how to define a more complex language syntax than LAMBDA's,
+namely the C-like syntax of IMP. Also, we will learn how to define languages
+using multiple modules, because we are going to separate IMP's syntax from
+its semantics using modules. Finally, we will also learn how to use K's
+builtin support for syntactic lists.

+

The K tool provides modules for grouping language features. In general, we
+can organize our languages in arbitrarily complex module structures.
+While there are no rigid requirements or even guidelines for how to group
+language features in modules, we often separate the language syntax from the
+language semantics in different modules.

+

In our case here, we start by defining two modules, IMP-SYNTAX and IMP, and
+import the first in the second, using the keyword imports. As their names
+suggest, we will place all IMP's syntax definition in IMP-SYNTAX and all its
+semantics in IMP.

+

Note, however, that K does no more than simply includes all the
+contents of the imported module in the one which imports it (making sure
+that everything is only kept once, even if you import it multiple times).
+In other words, there is currently nothing fancy in K tool's module system.

+

IMP has six syntactic categories, as shown in imp.k: AExp for arithmetic
+expressions, BExp for Boolean expressions, Block for blocks, Stmt for
+statements, Pgm for programs and Ids for comma-separated lists of
+identifiers. Blocks are special statements, whose role is to syntactically
+constrain the conditional statement and the while loop statement to only
+take blocks as branches and body, respectively.

+

There is nothing special about arithmetic and Boolean expressions. They
+are given the expected strictness attributes, except for <= and &&,
+for demonstration purposes.

+

The <= is defined to be seqstrict, which means that it evaluates its
+arguments in order, from left-to-right (recall that the strict operators
+can evaluate their arguments in any, fully interleaved, orders). Like
+strict, the seqstrict annotation can also be configured; for example, one
+can specify in which arguments and in what order. By default, seqstrict
+refers to all the arguments, in their left-to-right order. In our case here,
+it is equivalent with seqstrict(1 2).

+

The && is only strict in its first argument, because we will give it a
+short-circuited semantics (its second argument will only be evaluated when
+the first evaluates to true). Recall the K tool also allows us to associate
+LaTex attributes to constructs, telling the document generator how to display
+them. For example, we associate <= the attribute latex({#1}\leq{#2}),
+which makes it be displayed \leq everywhere in the generated LaTex
+documentation.

+

In this tutorial we take the freedom to associate the various constructs
+parsing precedences that we have already tested and we know work well, so that
+we can focus on the semantics here instead of syntax. In practice, though,
+you typically need to experiment with precedences until you obtain the desired
+parser.

+

Blocks are defined using curly brackets, and they can either be empty or
+hold a statement.

+

Nothing special about the IMP statements. Note that ; is an assignment
+statement terminator, not a statement separator. Note also that blocks are
+special statements.

+

An IMP program declares a comma-separated list of variables using the keyword
+int like in C, followed by a semicolon ;, followed by a statement.
+Syntactically, the idea here is that we can wrap any IMP program within a
+main(){...} function and get a valid C program. IMP does not allow variable
+declarations anywhere else except through this construct, at the top-level of
+the program. Other languages provided with the K distribution (see, e.g., the
+IMP++ language also discussed in this tutorial) remove this top-level program
+construct of IMP and add instead variable declaration as a statement construct,
+which can be used anywhere in the program, not only at the top level.

+

Note how we defined the comma-separated list of identifiers using
+List{Id,","}. The K tool provides builtin support for generic syntactic
+lists. In general,

+
syntax B ::= List{A,T}
+
+

declares a new non-terminal, B, corresponding to T-separated sequences of
+elements of A, where A is a non-terminal and T is a terminal. These
+lists can also be empty, that is, IMP programs declaring no variable are also
+allowed (e.g., int; {} is a valid IMP program). To instantiate and use
+the K builtin lists, you should alias each instance with a (typically fresh)
+non-terminal in your syntax, like we do with the Ids nonterminal.

+

Like with other K features, there are ways to configure the syntactic lists,
+but we do not discuss them here.

+

Recall from Tutorial 1 (LAMBDA) that in order for strictness to work well
+we also need to tell K which computations are meant to be results. We do
+this as well now, in the module IMP: integers and Booleans are K results.

+

Kompile imp.k and test the generated parser by running some programs.
+Since IMP is a fragment of C, you may want to select the C mode in your
+editor when writing these programs. This will also give your the feel that
+you are writing programs in a real programming language.

+

For example, here is sum.imp, which sums in sum all numbers up to n:

+
int n, sum;
+n = 100;
+sum=0;
+while (!(n <= 0)) {
+  sum = sum + n;
+  n = n + -1;
+}
+
+

Now krun it and see how it looks parsed in the default k cell.

+

The program collatz.imp tests the Collatz conjecture for all numbers up to
+m and accumulates the total number of steps in s:

+
int m, n, q, r, s;
+m = 10;
+while (!(m<=2)) {
+  n = m;
+  m = m + -1;
+  while (!(n<=1)) {
+    s = s+1;
+    q = n/2;
+    r = q+q+1;
+    if (r<=n) {
+      n = n+n+n+1;         // n becomes 3*n+1 if odd
+    } else {n=q;}          //        of   n/2 if even
+  }
+}
+
+

Finally, program primes.imp counts in s all the prime numbers up to m:

+
int i, m, n, q, r, s, t, x, y, z;
+m = 10;  n = 2;
+while (n <= m) {
+  // checking primality of n and writing t to 1 or 0
+  i = 2;  q = n/i;  t = 1;
+  while (i<=q && 1<=t) {
+    x = i;
+    y = q;
+    // fast multiplication (base 2) algorithm
+    z = 0;
+    while (!(x <= 0)) {
+      q = x/2;
+      r = q+q+1;
+      if (r <= x) { z = z+y; } else {}
+      x = q;
+      y = y+y;
+    } // end fast multiplication
+    if (n <= z) { t = 0; } else { i = i+1;  q = n/i; }
+  } // end checking primality
+  if (1 <= t) { s = s+1; } else {}
+  n = n+1;
+}
+
+

All the programs above will run once we define the semantics of IMP. If you
+want to execute them now, wrap them in a main(){...} function and compile
+them and run them with your favorite C compiler.

+

Before we move to the K semantics of IMP, we would like to make some
+clarifications regarding the K builtin parser, kast. Although it is quite
+powerful, you should not expect magic from it! While the K parser can parse
+many non-trivial languages (see, for example, the KOOL language in
+pl-tutorial/2_languages) in the K distribution), it was
+never meant to be a substitute for real parsers. We often call the syntax
+defined in K the syntax of the semantics, to highlight the fact that its
+role is to serve as a convenient notation when writing the semantics, not
+necessarily as a means to define concrete syntax of arbitrarily complex
+programming languages. See the KERNELC language for an example on how to connect an external parser for concrete syntax to
+the K tool.

+

The above being said, we strongly encourage you to strive to make the
+builtin parser work with your desired language syntax! Do not give up
+simply because you don't want to deal with syntactic problems. On the
+contrary, fight for your syntax! If you really cannot define your desired
+syntax because of tool limitations, we would like to know. Please tell us.

+

Until now we have only seen default configurations. In the next lesson we
+will learn how to define a K custom configuration.

+

Go to Lesson 2, IMP: Defining a Configuration.

+

MOVIE (out of date) [09'15"]

+

Defining a Configuration

+ +

Here we learn how to define a configuration in K. We also learn how to
+initialize and how to display it.

+

As explained in the overview presentation on K, configurations are quite
+important, because all semantic rules match and apply on them.
+Moreover, they are the backbone of configuration abstraction, which allows
+you to only mention the relevant cells in each semantic rule, the rest of
+the configuration context being inferred automatically. The importance of
+configuration abstraction will become clear when we define more complex
+languages (even in IMP++). IMP does not really need it. K configurations
+are constructed making use of cells, which are labeled and can be arbitrarily
+nested.

+

Configurations are defined with the keyword configuration. Cells are
+defined using an XML-ish notation stating clearly where the cell starts
+and where it ends.

+

While not enforced by the tool, we typically like to put the entire
+configuration in a top-level cell, called T. So let's define it:

+
configuration <T>...</T>
+
+

Cells can have other cells inside. In our case of IMP, we need a cell to
+hold the remaining program, cell which we typically call k, and a cell to
+hold the program state. Let us add them:

+
configuration <T> <k>...</k> <state>...</state> </T>
+
+

K allows us to also specify how to initialize a configuration at the same
+time with declaring the configuration. All we have to do is to fill in
+the contents of the cells with some terms. The syntactic categories of
+those terms will also indirectly define the types of the corresponding
+cells.

+

For example, we want the k cell to initially hold the program that is passed
+to krun. K provides a builtin configuration variable, called $PGM, which
+is specifically designed for this purpose: krun will place its program there
+(after it parses it, or course). The K tool allows users to define their own
+configuration variables, too, which can be used to develop custom
+initializations of program configurations with the help of krun; this can be
+quite useful when defining complex languages, but we do not discuss it in
+this tutorial.

+
configuration <T> <k> $PGM </k> <state>...</state>  </T>
+
+

Moreover, we want the program to be a proper Pgm term (because we do not
+want to allow krun to take fragments of programs, for example, statements).
+Therefore, we tag $PGM with the desired syntactic category, Pgm:

+
configuration <T> <k> $PGM:Pgm </k> <state>...</state>  </T>
+
+

Like for other variable tags in K, a run-time check will be performed and the
+semantics will get stuck if the passed term is not a well-formed program.

+

We next tell K that the state cell should be initialized with the empty map:

+
configuration <T> <k> $PGM:Pgm </k> <state> .Map </state>  </T>
+
+

Recall that in K . stands for nothing. However, since there are various
+types of nothing, to avoid confusion we can suffix the . with its desired
+type. K has several builtin data-types, including lists, sets, bags, and
+maps. .Map is the empty map.

+

Kompile imp.k and run several programs to see how the configuration is
+initialized as desired.

+

When configurations get large, and they do when defining large programming
+languages, you may want to color the cells in order to more easily distinguish
+them. This can be easily achieved using the color cell attribute, following
+again an XML-ish style:

+
configuration <T color="yellow">
+                <k color="green"> $PGM:Pgm </k>
+                <state color="red"> .Map </state>
+              </T>
+
+

In the next lesson we will learn how to write rules that involve cells.

+

Go to Lesson 3, IMP: Computations, Results, Strictness; Rules Involving Cells.

+

MOVIE (out of date) [04'21"]

+

Computations, Results, Strictness; Rules Involving Cells

+ +

In this lesson we will learn about the syntactic category K of computations,
+about how strictness attributes are in fact syntactic sugar for rewrite rules
+over computations, and why it is important to tell the tool which
+computations are results. We will also see a K rule that involves cells.

+

K Computations

+ +

Computation structures, or more simply computations, extend the abstract
+syntax of your language with a list structure using ~> (read followed
+by
or and then, and written \curvearrowright in Latex) as a separator.
+K provides a distinguished sort, K, for computations. The extension of the
+abstract syntax of your language into computations is done automatically by
+the K tool when you declare constructs using the syntax keyword, so the K
+semantic rules can uniformly operate only on terms of sort K. The intuition
+for computation structures of the form

+
t1 ~> t2 ~> ... ~> tn
+
+

is that the listed tasks are to be processed in order. The initial
+computation typically contains the original program as its sole task, but
+rules can then modify it into task sequences, as seen shortly.

+

Strictness in Theory

+ +

The strictness attributes, used as annotations to language constructs,
+actually correspond to rules over computations. For example, the
+strict(2) attribute of the assignment statement corresponds to the
+following two opposite rules (X ranges over Id and A over AExp):

+
X=A; => A ~> X=[];
+A ~> X=[]; => X=A;
+
+

The first rule pulls A from the syntactic context X=A; and schedules it
+for processing. The second rule plugs A back into its context.
+Inspired from the chemical abstract machine, we call rules of the first
+type above heating rules and rules of the second type cooling rules.
+Similar rules are generated for other arguments in which operations are
+strict. Iterative applications of heating rules eventually bring to the
+top of the computation atomic tasks, such as a variable lookup, or a
+builtin operation, which then make computational progress by means of other
+rules. Once progress is made, cooling rules can iteratively plug the result
+back into context, so that heating rules can pick another candidate for
+reduction, and so on and so forth.

+

When operations are strict only in some of their arguments, the corresponding
+positions of the arguments in which they are strict are explicitly enumerated
+in the argument of the strict attribute, e.g., strict(2) like above, or
+strict(2 3) for an operation strict in its second and third arguments, etc.
+If an operation is simply declared strict then it means that it is strict
+in all its arguments. For example, the strictness of addition yields:

+
A1+A2 => A1 ~> []+A2
+A1 ~> []+A2 => A1+A2
+A1+A2 => A2 ~> A1+[]
+A2 ~> A1+[] => A1+A2
+
+

It can be seen that such heating/cooling rules can easily lead to
+non-determinism, since the same term may be heated many different ways;
+these different evaluation orders may lead to different behaviors in some
+languages (not in IMP, because its expressions do not have side effects,
+but we will experiment with non-determinism in its successor, IMP++).

+

A similar desugaring applies to sequential strictness, declared with the
+keyword seqstrict. While the order of arguments of strict is irrelevant,
+it matters in the case of seqstrict: they are to be evaluated in the
+specified order; if no arguments are given, then they are assumed by default
+to be evaluated from left-to-right. For example, the default heating/cooling
+rules associated to the sequentially strict <= construct above are
+(A1, A2 range over AExp and I1 over Int):

+
A1<=A2 => A1 ~> []<=A2
+A1 ~> []<=A2 => A1<=A2
+I1<=A2 => A2 ~> I1<=[]
+A2 ~> I1<=[] => I1<=A2
+
+

In other words, A2 is only heated/cooled after A1 is already evaluated.

+

While the heating/cooling rules give us a nice and uniform means to define
+all the various allowable ways in which a program can evaluate, all based
+on rewriting, the fact that they are reversible comes with a serious practical
+problem: they make the K definitions unexecutable, because they lead to
+non-termination.

+

Strictness in Practice; K Results

+ +

To break the reversibility of the theoretical heating/cooling rules, and,
+moreover, to efficiently execute K definitions, the current implementation of
+the K tool relies on users giving explicit definitions of their languages'
+results.

+

The K tool provides a predicate isKResult, which is automatically defined
+as we add syntactic constructs to KResult (in fact the K tool defines such
+predicates for all syntactic categories, which are used, for example, as
+rule side conditions to check user-declared variable memberships, such as
+V:Val stating that V belongs to Val).

+

The kompile tool, depending upon what it is requested to do, changes the
+reversible heating/cooling rules corresponding to evaluation strategy
+definitions (e.g., those corresponding to strictness attributes) to avoid
+non-termination. For example, when one is interested in obtaining an
+executable model of the language (which is the default compilation mode of
+kompile), then heating is performed only when the to-be-pulled syntactic
+fragment is not a result, and the corresponding cooling only when the
+to-be-plugged fragment is a result. In this case, e.g., the heating/cooling
+rules for assignment are modified as follows:

+
X=A; => A ~> X=[];  requires notBool isKResult(A)
+A ~> X=[]; => X=A;  requires isKResult(A)
+
+

Note that non-termination of heating/cooling is avoided now. The only thing
+lost is the number of possible behaviors that a program can manifest, but
+this is irrelevant when all we want is one behavior.

+

As will be discussed in the IMP++ tutorial, the heating/cooling rules are
+modified differently by kompile when we are interested in other aspects
+of the language definition, such us, for example, in a search-able model that
+comprises all program behaviors. This latter model is obviously more general
+from a theoretical perspective, but, in practice, it is also slower to execute.
+The kompile tool strives to give you the best model of the language for the
+task you are interested in.

+

Can't Results be Inferred Automatically?

+ +

This is a long story, but the short answer is: No!. Maybe in some cases
+it is possible, but we prefer to not attempt it in the K tool. For example,
+you most likely do not want any stuck computation to count as a result,
+since some of them can happen simply because you forgot a semantic rule that
+could have further reduce it! Besides, in our experience with defining large
+languages, it is quite useful to take your time and think of what the results
+of your language's computations are. This fact in itself may help you improve
+your overall language design. We typically do it at the same time with
+defining the evaluation strategies of our languages. Although in theory K
+could infer the results of your language as the stuck computations, based on
+the above we have deliberately decided to not provide this feature, in spite
+of requests from some users. So you currently do have to explicitly define
+your K results if you want to effectively use the K tool. Note, however, that
+theoretical definitions, not meant to be executed, need not worry about
+defining results (that's because in theory semantic rules apply modulo the
+reversible heating/cooling rules, so results are not necessary).

+

A K Rule Involving Cells

+ +

All our K rules so far in the tutorial were of the form

+
rule left => right requires condition
+
+

where left and right were syntactic, or more generally computation, terms.

+

Here is our first K rule explicitly involving cells:

+
rule <k> X:Id => I ...</k> <state>... X |-> I ...</state>
+
+

Recall that the k cell holds computations, which are sequences of tasks
+separated by ~>. Also, the state cell holds a map, which is a set of
+bindings, each binding being a pair of computations (currently, the
+K builtin data-structures, like maps, are untyped; or, said differently,
+they are all over the type of computations, K).

+

Therefore, the two cells mentioned in the rule above hold collections
+of things, ordered or not. The ...s, which we also call cell frames,
+stand for more stuff there, which we do not care about.

+

The rewrite relation => is allowed in K to appear anywhere in a term, its
+meaning being that the corresponding subterm is rewritten as indicated in the
+shown context. We say that K's rewriting is local.

+

The rule above says that if the identifier X is the first task in the k
+cell, and if X is bound to I somewhere in the state, then X rewrites
+to I locally in the k cell. Therefore, IMP variables need to be already
+declared when looked up.

+

Of course, the K rule above can be translated into an ordinary rewrite rule
+of the form

+
rule <k> X ~> Rest </k> <state> Before (X |-> I) After </state>
+  => <k> I ~> Rest </k> <state> Before (X |-> I) After </state>
+
+

Besides being more verbose and thus tedious to write, this ordinary rule
+is also more error-prone; for example, we may forget the Rest variable
+in the right-hand-side, etc. Moreover, the concurrent semantics of K
+allows for its rules to be interpreted as concurrent transactions, where
+the context is the read-only component of the transaction, while the
+subterms which are rewritten are read/write component of the transaction;
+thus, K rule instances can apply concurrently if they only overlap
+on read-only parts, while they cannot if regarded as ordinary rewrite logic
+rules. Note: our current implementation of the K tool is not concurrent,
+so K rules are in fact desugared as normal rewrite rules in the K tool.

+

Kompile imp.k using a documentation option and check out how the K rule
+looks in the generated document. The ... frames are displayed as cell
+tears, metaphorically implying that those parts of the cells that we
+do not care about are torn away. The rewrite relation is replaced by a
+horizontal line: specifically, the subterm which rewrites, X, is
+underlined, and its replacement is written underneath the line.

+

In the next lesson we define the complete K semantics of IMP and
+run the programs we parsed in the first lesson.

+

Go to Lesson 4, IMP: Configuration Abstraction, Part 1; Types of Rules.

+

MOVIE (out of date) [10'30"]

+

Configuration Abstraction, Part 1; Types of Rules

+ +

Here we will complete the K definition of IMP and, while doing so, we will
+learn the very first step of what we call configuration abstraction.

+

The IMP Semantic Rules

+ +

Let us add the remaining rules, in the order in which the language constructs
+were defined in IMP-SYNTAX.

+

The rules for the arithmetic and Boolean constructs are self-explanatory.
+Note, however, that K will infer the correct sorts of all the variables in
+these rules, because they appear as arguments of the builtin operations
+(_+Int_, etc.). Moreover, the inferred sorts will be enforced dynamically.
+Indeed, we do not want to apply the rule for addition, for example, when the
+two arguments are not integers. In the rules for &&, although we prefer to
+not do it here for simplicity, we could have eliminated the dynamic check by
+replacing B (and similarly for _) with B:K. Indeed, it can be shown
+that whenever any of these rules apply, B (or _) is a BExp anyway.
+That's because there is no rule that can touch such a B (or _); this
+will become clearer shortly, when we discuss the first step of configuration
+abstraction. Therefore, since we know that B will be a BExp anyway, we
+could save the time it takes to check its sort; such times may look minor,
+but they accumulate, so some designers may prefer to avoid run-time checks
+whenever possible.

+

The block rules are trivial. However, the rule for non-empty blocks is
+semantically correct only because we do not have local variable declarations
+in IMP. We will have to change this rule in IMP++.

+

The assignment rule has two =>: one in the k cell dissolving the
+assignment statement, and the other in the state cell updating the value of
+the assigned variable. Note that the one in the state is surrounded by
+parentheses: (_ => I). That is because => is greedy: it matches as much
+as it can to the left and to the right, until it reaches the cell boundaries
+(closed or open). If you want to limit its scope, or for clarity, you can use
+parentheses like here.

+

The rule for sequential composition simply desugars S1 S2 into S1 ~> S2.
+Indeed, the two have exactly the same semantics. Note that statements
+evaluate to nothing (.), so once S1 is processed in S1 ~> S2, then the
+next task is automatically S2, without wasting any step for the transition.

+

The rules for the conditional and while statements are clear. One thing to
+keep in mind now is that the while unrolling rule will not apply
+indefinitely in the positive branch of the resulting conditional, because
+of K's configuration abstraction, which will be discussed shortly.

+

An IMP program declares a set of variables and then executes a
+statement in the state obtained after initializing all those variables
+to 0. The rules for programs initialize the declared variables one by one,
+checking also that there are no duplicates. We check for duplicates only for
+demonstration purposes, to illustrate the keys predefined operation that
+returns the set of keys of a map, and the set membership operation in.
+In practice, we typically define a static type checker for our language,
+which we execute before the semantics and reject inappropriate programs.

+

The use of the .Ids in the second rule is not necessary. We could have
+written int; S instead of int .Ids; S and the K tool would parse it and
+kompile the definition correctly, because it uses the same parser used for
+parsing programs also to parse the semantics. However, we typically prefer to
+explicitly write the nothing values in the semantics, for clarity;
+the parser has been extended to accept these. Note that the first rule
+matches the entire k cell, because int_;_ is the top-level program
+construct in IMP, so there is nothing following it in the computation cell.
+The anonymous variable stands for the second argument of this top-level program
+construct, not for the rest of the computation. The second rule could have
+also been put in a complete k cell, but we preferred not to, for simplicity.

+

Our IMP semantics is now complete, but there are a few more things that we
+need to understand and do.

+

Configuration Abstraction, Part 1

+ +

First, let us briefly discuss the very first step of configuration abstraction.
+In K, all semantic rules are in fact rules between configurations. As soon
+explained in the IMP++ tutorial, the declared configuration cell structure is
+used to automatically complete the missing configuration parts in rules.
+However, many rules do not involve any cells, being rules between syntactic
+terms (of sort K); for example, we had only three rules involving cells in our
+IMP semantics. In this case, the k cell will be added automatically and the
+actual rewrite will happen on top of the enclosed computation. For example,
+the rule for the while loop is automatically translated into the following:

+
rule <k> while (B) S => if (B) {S while (B) S} else {} ...</k>
+
+

Since the first task in computations is what needs to be done next, the
+intuition for this rule completion is that the syntactic transition
+only happens when the term to rewrite is ready for processing. This explains,
+for example, why the while loop unrolling does not indefinitely apply in the
+positive branch of the conditional: the inner while loop is not ready for
+evaluation yet. We call this rule completion process, as well as other
+similar ones, configuration abstraction. That is because the incomplete
+rule abstracts away the configuration structure, thus being easier to read.
+As seen soon when we define IMP++, configuration abstraction is not only a
+user convenience; it actually significantly increases the modularity of our
+definitions. The k-cell-completion is only the very first step, though.

+

If you really want certain rewrites over syntactic terms to apply
+anywhere they match, then you should tag the rule with the attribute
+anywhere, which was discussed in Tutorial 1, Lesson 2.5.

+

Kompile and then krun the programs that you only parsed in Lesson 1. They
+should all execute as expected. The state cell shows the final state
+of the program. The k cell shows the final code contents, which should be
+empty whenever the IMP program executes correctly.

+

Kompile also with the documentation option and take a look at the generated
+documentation. The assignment rule should particularly be of interest,
+because it contains two local rewrites.

+

In the next lesson we comment the IMP definition and conclude this tutorial.

+

Go to Lesson 5, IMP: Completing and Documenting IMP.

+

MOVIE (out of date) [09'16"]

+

Completing and Documenting IMP

+ +

We here learn no new concepts, but it is a good moment to take a break
+and contemplate what we learned so far.

+

Let us add lots of formal annotations to imp.k.

+

Once we are done with the annotations, we kompile with the documentation
+option and then take a look at the produced document. We often call these
+documents language posters. Depending on how much information you add to
+these language posters, they can serve as standalone, formal presentations
+of your languages. For example, you can print them as large posters and
+post them on the wall, or in poster sessions at conferences.

+

This completes our second tutorial. The next tutorials will teach us more
+features of the K framework, such as how to define languages with complex
+control constructs (like callcc), languages which are concurrent, and so on.

+

MOVIE (out of date) [03'45"]

+

Part 3: Defining LAMBDA++

+ +

Here you will learn how to define language constructs which abruptly change
+the execution control flow, and how to define language semantics following
+and environment/store style. Specifically, you will learn the following:

+
    +
  • How to define constructs like callcc, which allow you to take snapshots of
    +program executions and to go back in time at any moment.
  • +
  • How to define languages in an environment/store style.
  • +
  • Some basic notions about the use of closures and closure-like semantic
    +structures to save and restore execution environments.
  • +
  • Some basic intuitions about reusing existing semantics in new languages,
    +as well as some of the pitfalls in doing so.
  • +
+

Abrupt Changes of Control

+ +

Here we add call-with-current-continuation (callcc) to the definition of
+LAMBDA completed in Tutorial 1, and call the resulting language LAMBDA++.
+While doing so, we will learn how to define language constructs that
+abruptly change the execution control flow.

+

Take over the lambda.k definition from Lesson 8 in Part 1 of this Tutorial,
+which is the complete definition of the LAMBDA language, but without the
+comments.

+

callcc is a good example for studying the capabilities of a framework to
+support abrupt changes of control, because it is one of the most
+control-intensive language constructs known. Scheme is probably the first
+programming language that incorporated the callcc construct, although
+similar constructs have been recently included in many other languages in
+one form or another.

+

Here is a quick description: callcc e passes the remaining computation
+context, packaged as a function k, to e (which is expected to be a function);
+if during its evaluation e passes any value to k, then the current
+execution context is discarded and replaced by the one encoded by k and
+the value is passed to it; if e evaluates normally to some value v and
+passes nothing to k in the process, then v is returned as a result of
+callcc e and the execution continues normally. For example, we want the
+program callcc-jump.lambda:

+
(callcc (lambda k . ((k 5) + 2))) + 10
+
+

to evaluate to 15, not 17! Indeed, the computation context [] + 10 is
+passed to callcc's argument, which then sends it a 5, so the computation
+resumes to 5 + 10. On the other hand, the program callcc-not-jump.lambda

+
(callcc (lambda k . (5 + 2))) + 10
+
+

evaluates to 17.

+

If you like playing games, you can metaphorically think of callcc e as
+saving your game state in a file and passing it to your friend e.
+Then e can decide at some moment to drop everything she was doing, load
+your game and continue to play it from where you were.

+

The behavior of many popular control-changing constructs can be obtained
+using callcc. The program callcc-return.lambda shows, for example, how to
+obtain the behavior of a return statement, which exits the current execution
+context inside a function and returns a value to the caller's context:

+
letrec f x = callcc (lambda return . (
+  f (if (x <= 0) then ((return 1) / 0) else 2)
+))
+in (f -3)
+
+

This should evaluate to 1, in spite of the recursive call to f
+and of the division by zero! Note that return is nothing but a variable
+name, but one which is bound to the current continuation at the beginning of
+the function execution. As soon as 1 is passed to return, the computation
+jumps back in time to where callcc was defined! Change -3 to 3 and the
+program will loop forever.

+

callcc is quite a powerful and beautiful language construct, although one
+which is admittedly hard to give semantics to in some frameworks.
+But not in K 😃 Here is the entire K syntax and semantics of callcc:

+
syntax Exp ::= "callcc" Exp  [strict]
+syntax Val ::= cc(K)
+rule <k> (callcc V:Val => V cc(K)) ~> K </k>
+rule <k> cc(K) V ~> _ =>  V ~> K </k>
+
+

Let us first discuss the annotated syntax. We declared callcc strict,
+because its argument may not necessarily be a function yet, so it may need
+to be evaluated. As explained above, we need to encode the remaining
+computation somehow and pass it to callcc's argument. More specifically,
+since LAMBDA is call-by-value, we have to encode the remaining computation as
+a value. We do not want to simply subsort computations to Val, because there
+are computations which we do not want to be values. A simple solution to
+achieve our goal here is to introduce a new value construct, say cc (from
+current-continuation), which holds any computation.

+

Note that, inspired from SDF,
+K allows you to define the syntax of helping semantic operations, like cc,
+more compactly. Typically, we do not need a fancy syntax for such operators;
+all we need is a name, followed by open parenthesis, followed by a
+comma-separated list of arguments, followed by closed parenthesis. If this
+is the syntax that you want for a particular construct, then K allows you to
+drop all the quotes surrounding the terminals, as we did above for cc.

+

The semantic rules do exactly what the English semantics of callcc says.
+Note that here, unlike in our definition of LAMBDA in Tutorial 1, we had
+to mention the cell <k/> in our rules. This is because we need to make sure
+that we match the entire remaining computation, not only a fragment of it!
+For example, if we replace the two rules above with

+
rule (callcc V:Val => V cc(K)) ~> K
+rule cc(K) V ~> _ =>  V ~> K
+
+

then we get a callcc which is allowed to non-deterministically pick a
+prefix of the remaining computation and pass it to its argument, and then
+when invoked within its argument, a non-deterministic prefix of the new
+computation is discarded and replaced by the saved one. Wow, that would
+be quite a language! Would you like to write programs in it? 😃

+

Consequently, in K we can abruptly change the execution control flow of a
+program by simply changing the contents of the <k/> cell. This is one of
+the advantages of having an explicit representation of the execution context,
+like in K or in reduction semantics with evaluation contexts. Constructs like
+callcc are very hard and non-elegant to define in frameworks such as SOS,
+because those implicitly represent the execution context as proof context,
+and the latter cannot be easily changed.

+

Now that we know how to handle cells in configurations and use them in rules,
+in the next lesson we take a fresh look at LAMBDA and define it using
+an environment-based style, which avoids the complexity of substitution
+(e.g., having to deal with variable capture) and is closer in spirit to how
+functional languages are implemented.

+

Go to Lesson 2, LAMBDA++: Semantic (Non-Syntactic) Computation Items.

+

MOVIE (out of date) [6'28"]

+

Semantic (Non-Syntactic) Computation Items

+ +

In this lesson we start another semantic definition of LAMBDA++, which
+follows a style based on environments instead of substitution. In terms of
+K, we will learn how easy it is to add new items to the syntactic category
+of computations K, even ones which do not have a syntactic nature.

+

An environment binds variable names of interest to locations where their
+values are stored. The idea of environment-based definitions is to maintain
+a global store mapping locations to values, and then have environments
+available when we evaluate expressions telling where the variables are
+located in the store. Since LAMBDA++ is a relatively simple language, we
+only need to maintain one global environment. Following a similar style
+like in IMP, we place all cells into a top cell T:

+
configuration <T>
+                <k> $PGM:Exp </k>
+                <env> .Map </env>
+                <store> .Map </store>
+              </T>
+
+

Recall that $PGM is where the program is placed by krun after parsing. So
+the program execution starts with an empty environment and an empty store.

+

In environment-based definitions of lambda-calculi, lambda abstractions
+evaluate to so-called closures:

+
rule <k> lambda X:Id . E => closure(Rho,X,E) ...</k>
+     <env> Rho </env>
+
+

A closure is like a lambda abstraction, but it also holds the environment
+in which it was declared. This way, when invoked, a closure knows where to
+find in the store the values of all the variables that its body expression
+refers to. We will define the lookup rule shortly.

+

Therefore, unlike in the substitution-based definitions of LAMBDA and
+LAMBDA++, neither the lambda abstractions nor the identifiers are values
+anymore here, because they both evaluate further: lambda abstractions to
+closures and identifiers to their values in the store. In fact, the only
+values at this moment are the closures, and they are purely semantic entities,
+which cannot be used explicitly in programs. That's why we modified the
+original syntax of the language to include no Val syntactic category
+anymore, and that's why we need to add closures as values now; same like
+before, we add a Val syntactic category which is subsorted
+to KResult. In general, whenever you have any strictness attributes,
+your should also define some K results.

+

Invoking a closure is a bit more involved than the substitution-based
+beta-reduction: we need to switch to the closure's environment, then create a
+new, or fresh, binding for the closure's parameter to the value passed to the
+closure, then evaluate the closure's body, and then switch back to the
+caller's environment, which needs to be stored somewhere in the meanwhile.
+We can do all these with one rule:

+
rule <k> closure(Rho,X,E) V:Val => E ~> Rho' ...</k>
+     <env> Rho' => Rho[X <- !N] </env>
+     <store>... .Map => (!N:Int |-> V) ...</store>
+
+

Therefore, we atomically do all the following:

+
    +
  • switch the computation to the closure's body, E, followed by a
    +caller-environment-recovery task Rho' (note that Rho' is the
    +current environment),
  • +
  • generate a fresh location !N (the ! is important, we discuss it below),
    +bind X to !N in closure's environment and switch the current environment
    +Rho' to that one,
  • +
  • write the value passed to the closure, V, at location !N.
  • +
+

This was the most complex K rule we've seen so far in the tutorial. Note,
+however, that this one rule achieves a lot. It is, in fact, quite compact
+considering how much it does. Note also that everything that this K rule
+mentions is needed also conceptually in order to achieve this task, so it
+is minimal from that point of view. That would not be the case if we
+used, instead, a conventional rewrite rule, because we would have had to
+mention the remaining store, say Sigma, in both sides of the rule, to say
+it stays unchanged. Here we just use ....

+

The declaration of the fresh variable above, !N, is new and needs
+some explanation. First, note that !N appears only in the right-hand-side
+terms in the rule, that is, it is not matched when the rule is applied.
+Instead, a fresh Nat element is generated each time the rule is applied.
+In K, we can define syntactic categories which have the capability to
+generate fresh elements like above, using unbound variables whose name starts
+with a !. The details of how to do that are beyond the scope of this
+tutorial (see Tutorial 6). All we need to know here is that an arbitrary
+fresh element of that syntactic category is generated each time the rule
+is applied. We cannot rely on the particular name or value of the generated
+element, because that can change with the next version of the K tool, or
+even from execution to execution with the same version. All you can rely
+on is that each newly generated element is distinct from the previously
+generated elements for the same syntactic category.

+

Unlike in the substitution-based definition, we now also need a lookup rule:

+
rule <k> X => V ...</k>
+     <env>... X |-> N ...</env>
+     <store>... N |-> V ...</store>
+
+

This rule speaks for itself: replace X by the value V located in the store
+at X's location N in the current environment.

+

The only thing left to define is the auxiliary environment-recovery operation:

+

rule _:Val ~> (Rho => .) ... _ => Rho

+

When the item preceding the environment recovery task Rho in the
+computation becomes a value, replace the current environment with Rho
+and dissolve Rho from the computation.

+

Let us kompile and ... fail:

+
kompile lambda
+
+

gives a parsing error saying that V:Val does not fit there in the closure
+invocation rule. That's because Val and Exp are currently completely
+disconnected, so K rightfully complains that we want to apply a value to
+another one, because application was defined to work with expressions, not
+values. What we forgot here was to state that Exp includes Val:

+
syntax Exp ::= Val
+
+

Now everything works, but it is a good time to reflect a bit.

+

So we added closures, which are inherently semantic entities, to the syntax
+of expressions. Does that mean that we can now write LAMBDA programs with
+closures in them? Interestingly, with our current definition of LAMBDA,
+which purposely did not follow the nice organization of IMP into syntax and
+semantic modules, and with K's default parser, kast, you can. But you are
+not supposed to speculate this! In fact, if you use an external parser, that
+parser will reject programs with explicit closures. Also, if we split the
+LAMBDA definition into two modules, one called LAMBDA-SYNTAX containing
+exclusively the desired program syntax and one called LAMBDA importing the
+former and defining the syntax of the auxiliary operations and the semantics,
+then even K's default parser will reject programs using auxiliary syntactic
+constructs.

+

Indeed, when you kompile a language, say lang.k, the tool will by default
+attempt to find a module LANG-SYNTAX and generate the program parser from
+that. If it cannot find it, then it will use the module LANG instead. There
+are also ways to tell kompile precisely which syntax module you want to use
+for the program parser if you don't like the default convention.
+See kompile --help.

+

Another insightful thought to reflect upon, is the relationship between your
+language's values and other syntactic categories. It is often the case that
+values form a subset of the original language syntax, like in IMP (Part 2 of
+the tutorial), but sometimes that is not true, like in our case here. When
+that happens, in order for the semantics to be given smoothly and uniformly
+using the original syntax, you need to extend your language's original
+syntactic categories with the new values. The same holds true in other
+semantic approaches, not only in K, even in ones which are considered purely
+syntactic. As it should be clear by now, K does not enforce you to use a
+purely syntactic style in your definitions; nevertheless, K does allow you to
+develop purely syntactic definitions, like LAMBDA in Part 1 of the tutorial,
+if you prefer those.

+

krun some programs, such as those provided in Lesson 1 of the LAMBDA
+tutorial (Part 1). Note the closures, both as results in the <k/> cell,
+and as values in the store. Also, since variables are not values anymore,
+expressions that contain free variables may get stuck with one of those on
+top of their computation. See, for example, free-variable-capture.lambda,
+which gets stuck on z, because z is free, so it cannot evaluate it.
+If you want, you can go ahead and manually provide a configuration with
+z mapped to some location in the environment and that location mapped to
+some value in the store, and then you can also execute this program. The
+program omega.lambda should still loop.

+

Although we completely changed the definitional style of LAMBDA, the semantics
+of the other constructs do not need to change, as seen in the next lesson.

+

Go to Lesson 3, LAMBDA++: Reusing Existing Semantics.

+

MOVIE (out of date) [8'02"]

+

Reusing Existing Semantics

+ +

In this lesson we will learn that, in some cases, we can reuse existing
+semantics of language features without having to make any change!

+

Although the definitional style of the basic LAMBDA language changed quite
+radically in our previous lesson, compared to its original definition in
+Part 1 of the tutorial, we fortunately can reuse a large portion of the
+previous definition. For example, let us just cut-and-paste the rest of the
+definition from Lesson 7 in Part 1 of the tutorial.

+

Let us kompile and krun all the remaining programs from Part 1 of the
+tutorial. Everything should work fine, although the store contains lots of
+garbage. Garbage collection is an interesting topic, but we do not do it
+here. Nevertheless, much of this garbage is caused by the intricate use of
+the fixed-point combinator to define recursion. In a future lesson in this
+tutorial we will see that a different, environment-based definition of
+fixed-points will allocate much less memory.

+

One interesting question at this stage is: how do we know when we can reuse
+an existing semantics of a language feature? Well, I'm afraid the answer is:
+we don't. In the next lesson we will learn how reuse can fail for quite subtle
+reasons, which are impossible to detect statically (and some non-experts may
+fail to even detect them at all).

+

Go to Lesson 4, LAMBDA++: Do Not Reuse Blindly!.

+

MOVIE (out of date) [3'21"]

+

Do Not Reuse Blindly!

+ +

It may be tempting to base your decision to reuse an existing semantics of
+a language feature solely on syntactic considerations; for example, to reuse
+whenever the parser does not complain. As seen in this lesson, this could
+be quite risky.

+

Let's try (and fail) to reuse the definition of callcc from Lesson 1:

+
syntax Exp ::= "callcc" Exp  [strict]
+syntax Val ::= cc(K)
+rule <k> (callcc V:Val => V cc(K)) ~> K </k>
+rule <k> cc(K) V ~> _ =>  V ~> K </k>
+
+

The callcc examples that we tried in Lesson 1 work, so it may look it works.

+

However, the problem is that cc(K) should also include an environment,
+and that environment should also be restored when cc(K) is invoked.
+Let's try to illustrate this bug with callcc-env1.lambda

+
let x = 1 in
+  ((callcc lambda k . (let x = 2 in (k x))) + x)
+
+

where the second argument of +, x, should be bound to the top x, which
+is 1. However, since callcc does not restore the environment, that x
+should be looked up in the wrong, callcc-inner environment, so we should see
+the overall result 4.

+

Hm, we get the right result, 3 ... (Note: you may get 4, depending on
+your version of K and platform; but both 3 and 4 are possible results, as
+explained below and seen in the tests). How can we get 3? Well, recall that
++ is strict, which means that it can evaluate its arguments in any order.
+It just happened that in the execution that took place above its second
+argument was evaluated first, to 1, and then the callcc was evaluated, but
+its cc value K had already included the 1 instead of x ... In Part 4 of
+the tutorial we will see how to explore all the non-deterministic behaviors of
+a program; we could use that feature of K to debug semantics, too.
+For example, in this case, we could search for all behaviors of this program
+and we would indeed get two possible value results: 3 and 4.

+

One may think that the problem is the non-deterministic evaluation order
+of +, and thus that all we need to do is to enforce a deterministic order
+in which the arguments of + are evaluated. Let us follow this path to
+see what happens. There are two simple ways to make the evaluation order
+of +'s arguments deterministic. One is to make + seqstrict in the
+semantics, to enforce its evaluation from left-to-right. Do it and then
+run the program above again; you should get only one behavior for the
+program above, 4, which therefore shows that copying-and-pasting our old
+definition of callcc was incorrect. However, as seen shortly, that only
+fixed the problem for the particular example above, but not in general.
+Another conventional approach to enforce the desired evaluation order is to
+modify the program to enforce the left-to-right evaluation order using let
+binders, as we do in callcc-env2.lambda:

+
let x = 1 in
+  let a = callcc lambda k . (let x = 2 in (k x)) in
+    let b = x in
+      (a + b)
+
+

With your installation of K you may get the "expected" result 4 when you
+execute this program, so it may look like our non-deterministic problem is
+fixed. Unfortunately, it is not. Using the K tool to search for all the
+behaviors in the program above reveals that the final result 3 is still
+possible. Moreover, both the 3 and the 4 behaviors are possible regardless
+of whether + is declared to be seqstrict or just strict. How is that
+possible? The problem is now the non-deterministic evaluation strategy of
+the function application construct. Indeed, recall that the semantics of
+the let-in construct is defined by desugaring to lambda application:

+
rule let X = E in E' => (lambda X . E') E
+
+

With this, the program above eventually reduces to

+
(lambda a . ((lambda b . a + b) x))
+(callcc lambda k . (let x = 2 in (k x)))
+
+

in an environment where x is 1. If the first expression evaluates first,
+then it does so to a closure in which x is bound to a location holding 1,
+so when applied later on to the x inside the argument of callcc (which is
+2), it will correctly lookup x in its enclosed environment and thus the
+program will evaluate to 3. On the other hand, if the second expression
+evaluates first, then the cc value will freeze the first expression as is,
+breaking the relationship between its x and the current environment in which
+it is bound to 1, being inadvertently captured by the environment of the
+let-in construct inside the callcc and thus making the entire expression
+evaluate to 4.

+

So the morale is: Do not reuse blindly. Think!

+

In the next lesson we fix the environment-based semantics of callcc by having
+cc also wrap an environment, besides a computation. We will also give a more
+direct semantics to recursion, based on environments instead of fixed-point
+combinators.

+

Go to Lesson 5, LAMBDA++: More Semantic Computation Items.

+

MOVIE (out of date) [3'37"]

+

More Semantic Computation Items

+ +

In this lesson we see more examples of semantic (i.e., non-syntactic)
+computational items, and how useful they can be. Specifically, we fix the
+environment-based definition of callcc and give an environment-based
+definition of the mu construct for recursion.

+

Let us first fix callcc. As discussed in Lesson 4, the problem that we
+noticed there was that we only recovered the computation, but not the
+environment, when a value was passed to the current continuation. This is
+quite easy to fix: we modify cc to take both an environment and a
+computation, and its rules to take a snapshot of the current environment with
+it, and to recover it at invocation time:

+
syntax Val ::= cc(Map,K)
+rule <k> (callcc V:Val => V cc(Rho,K)) ~> K </k> <env> Rho </env>
+rule <k> cc(Rho,K) V:Val ~> _ =>  V ~> K </k> <env> _ => Rho </env>
+
+

Let us kompile and make sure it works with the callcc-env2.lambda program,
+which should evaluate to 3, not to 4.

+

Note that the cc value, which can be used as a computation item in the <k/>
+cell, is now quite semantic in nature, pretty much the same as the closures.

+

Let us next add one more closure-like semantic computational item, for mu.
+But before that, let us reuse the semantics of letrec in terms of mu that
+was defined in Lesson 8 of Part 1 of the tutorial on LAMBDA:

+
syntax Exp ::= "letrec" Id Id "=" Exp "in" Exp [macro]
+             | "mu" Id "." Exp                 [latex(\mu{#1}.{#2})]
+rule letrec F:Id X = E in E' => let F = mu F . lambda X . E in E'
+
+

We removed the binder annotation of mu, because it is not necessary
+anymore (since we do not work with substitutions anymore).

+

To save the number of locations needed to evaluate mu X . E, let us replace
+it with a special closure which already binds X to a fresh location holding
+the closure itself:

+
syntax Exp ::= muclosure(Map,Exp)
+
+rule <k> mu X . E => muclosure(Rho[X <- !N], E) ...</k>
+     <env> Rho </env>
+     <store>... .Map => (!N:Int |-> muclosure(Rho[X <- !N], E)) ...</store>
+
+

Since each time mu X . E is encountered during the evaluation it needs to
+evaluate E, we conclude that muclosure cannot be a value. We can declare
+it as either an expression or as a computation. Let's go with the former.

+

Finally, here is the rule unrolling the muclosure:

+

rule muclosure(Rho,E) => E ~> Rho' ...
+ Rho' => Rho

+

Note that the current environment Rho' needs to be saved before and
+restored after E is executed, because the fixed point may be invoked
+from a context with a completely different environment from the one
+in which mu X . E was declared.

+

We are done. Let us now kompile and krun factorial-letrec.lambda from
+Lesson 7 in Part 1 of the tutorial on LAMBDA. Recall that in the previous
+lesson this program generated a lot of garbage into the store, due to the
+need to allocate space for the arguments of all those lambda abstractions
+needed to run the fixed-point combinator. Now we need much fewer locations,
+essentially only locations for the argument of the factorial function, one at
+each recursive call. Anyway, much better than before.

+

In the next lesson we wrap up the environment definition of LAMBDA++ and
+generate its documentation.

+

Go to Lesson 6, LAMBDA++: Wrapping Up and Documenting LAMBDA++.

+

MOVIE (out of date) [5'19"]

+

Wrapping Up and Documenting LAMBDA++

+ +

In this lesson we wrap up and nicely document LAMBDA++. In doing so, we also
+take the freedom to reorganize the semantics a bit, to make it look better.

+

See the lambda.k file, which is self-explanatory.

+

Part 3 of the tutorial is now complete. Part 4 will teach you more features
+of the K framework, in particular how to exhaustively explore the behaviors
+of non-deterministic or concurrent programs.

+

MOVIE (out of date) [6'23"]

+

Part 4: Defining IMP++

+ +

IMP++ extends IMP, which was discussed in Part 2 of this tutorial, with several
+new syntactic constructs. Also, some existing syntax is generalized, which
+requires non-modular changes of the existing IMP semantics. For example,
+global variable declarations become local declarations and can occur
+anywhere a statement can occur. In this tutorial we will learn the following:

+
    +
  • That (and how) existing syntax/semantics may change as a language evolves.
  • +
  • How to refine configurations as a language evolves.
  • +
  • How to define and use fresh elements of desired sorts.
  • +
  • How to tag syntactic constructs and rules, and how to use such tags
    +with the superheat/supercool/transition options of kompile.
  • +
  • How the search option of krun works.
  • +
  • How to stream cells holding semantic lists to the standard input/output,
    +and thus obtain interactive interpreters for the defined languages.
  • +
  • How to delete, save and restore cell contents.
  • +
  • How to add/delete cells dynamically.
  • +
  • More details on how the configuration abstraction mechanism works.
  • +
+

Like in the previous tutorials, this folder contains several lessons, each
+adding new features to IMP++. Do them in order and make sure you completed
+and understood the previous tutorials.

+

Extending/Changing an Existing Language Syntax

+ +

Here we learn how to extend the syntax of an existing language, both with
+new syntactic constructs and with more general uses of existing constructs.
+The latter, in particular, requires changes of the existing semantics.

+

Consider the IMP language, as defined in Lesson 4 of Part 2 of the tutorial.

+

Let us first add the new syntactic constructs, with their precedences:

+
    +
  • variable increment, ++, which increments an integer variable and
    +evaluates to the new value;
  • +
  • read, which reads and evaluates to a new integer from the input buffer;
  • +
  • print, which takes a comma-separated list of arithmetic expressions and
    +evaluates and prints each of them in order, from left to right, to the
    +output buffer; we therefore define a new list syntactic category, AExps,
    +which we pass as an argument to print; note we do not want to declare
    +print to be strict, because we do not want to first evaluate the
    +arguments and then print them (for example, if the second argument performs
    +an illegal operation, say division by zero, we still want to print the first
    +argument); we also go ahead and add strings as arithmetic expressions,
    +because we intend print to also take strings, in order to print nice
    +messages to the user;
  • +
  • halt, which abruptly terminates the program; and
  • +
  • spawn, which takes a statement and creates a new concurrent thread
    +executing it and sharing its environment with the parent thread.
  • +
+

Also, we want to allow local variable declarations, which can appear anywhere
+a statement can appear. Their scope ranges from the place they are defined
+until the end of the current block, and they can shadow previous declarations,
+both inside and outside the current block. The simplest way to define the
+syntax of the new variable declarations is as ordinary statements, at the same
+time removing the previous Pgm syntactic category and its construct.
+Programs are now just statements.

+

We are now done with adding the new syntax and modifying the old one.
+Note that the old syntax was modified in a way which makes the previous IMP
+programs still parse, but this time as statements. Let us then modify
+the configuration variable $PGM to have the sort Stmt instead of Pgm,
+and let us try to run the old IMP programs, for example sum.imp.

+

Note that they actually get stuck with the global declaration on the top
+of their computations. This is because variable declarations are now treated
+like any statements, in particular, the sequential composition rule applies.
+This makes the old IMP rule for global variable declarations not match anymore.
+We can easily fix it by replacing the anonymous variable _, which matched
+the program's statement that now turned into the remaining computation in
+the <k/> cell, with the cell frame variable ..., which matches the
+remaining computation. Similarly, we have to change the rule for the case
+where there are no variables left to declare into one that dissolves itself.

+

We can now run all the previous IMP programs, in spite of the fact that
+our IMP++ semantics is incomplete and, more interestingly, in spite of the
+fact that our current semantics of blocks is incorrect in what regards the
+semantics of local variable declarations (note that the old IMP programs do
+not declare block-local variables, which is why they still run correctly).

+

Let us also write some proper IMP++ programs, which we would like to execute
+once we give semantics to the new constructs.

+

div.imp is a program manifesting non-deterministic behaviors due to the
+desired non-deterministic evaluation strategy of division and the fact that
+expressions will have side effects once we add variable increment. We will
+be able to see all the different behaviors of this program. Challenge: can
+you identify the behavior where the program performs a division-by-zero?

+

If we run div.imp now, it will get stuck with the variable increment
+construct on top of the computation cell. Once we give it a semantics,
+div.imp will execute completely (all the other constructs in div.imp
+already have their semantics defined as part of IMP).

+

Note that some people prefer to define all their semantics in a by need
+style, that is, they first write and parse lots of programs, and then they
+add semantics to each language construct on which any of the programs gets
+stuck, and so on and so forth until they can run all the programs.

+

io.imp is a program which exercises the input/output capabilities of the
+language: reads two integers and prints three strings and an integer.
+Note that the variable declaration is not the first statement anymore.

+

sum-io.imp is an interactive variant of the sum program.

+

spawn.imp is a program which dynamically creates two threads that interact
+with the main thread via the shared variable x. Lots of behaviors will be
+seen here once we give spawn the right semantics.

+

Finally, locals.imp tests whether variable shadowing/unshadowing works well.

+

In the next lesson we will prepare the configuration for the new constructs,
+and will see what it takes to adapt the semantics to the new configuration.
+Specifically, we will split the state cell into an environment cell and a
+store cell, like in LAMBDA++ in Part 3 of the tutorial.

+

Go to Lesson 2, IMP++: Configuration Refinement; Freshness.

+

MOVIE (out of date) [07'47"]

+

Configuration Refinement; Freshness

+ +

To prepare for the semantics of threads and local variables, in this lesson we
+split the state cell into an environment and a store. The environment and
+the store will be similar to those in the definition of LAMBDA++ in Part
+3 of the Tutorial. This configuration refinement will require us to change
+some of IMP's rules, namely those that used the state.

+

To split the state map, which binds program variables to values, into an
+environment mapping program variables to locations and a store mapping
+locations to values, we replace in the configuration declaration the cell

+
<state color="red"> .Map </state>
+
+

with two cells

+
<env color="LightSkyBlue"> .Map </env>
+<store color="red"> .Map </store>
+
+

Structurally speaking, this split of a cell into other cells is a major
+semantic change, which, unfortunately, requires us to revisit the existing
+rules that used the state cell. One could, of course, argue that we could
+have avoided this problem if we had followed from the very beginning the
+good-practice style to work with an environment and a store, instead of a
+monolithic state. While that is a valid argument, highlighting the fact that
+modularity is not only a feature of the framework alone, but one should also
+follow good practices to achieve it, it is also true that if all we wanted
+in Part 2 of the tutorial was to define IMP as is, then the split of the state
+in an environment and a store is unnecessary and not really justified.

+

The first rule which used a state cell is the lookup rule:

+
rule <k> X:Id => I ...</k> <state>... X |-> I ...</state>
+
+

We modify it as follows:

+
rule <k> X:Id => I ...</k>
+     <env>... X |-> N ...</env>
+     <store>... N |-> I ...</store>
+
+

So we first match the location N of X in the environment, then the value
+I at location N in the store, and finally we rewrite X to I into the
+computation. This rule also shows an instance of a more complex
+multiset matching, where two variables (X and N) are matched each twice.

+

The assignment rule is modified quite similarly.

+

The variable declaration rule is trickier, though, because we need to allocate
+a fresh location in the store and bind the newly declared variable to it.
+This is quite similar to the way we allocated space for variables in
+the environment-based definition of LAMBDA++ in Part 3 of the tutorial.

+
rule <k> int (X,Xs => Xs); ...</k>
+     <env> Rho => Rho[X <- !N:Int] </env>
+     <store>... .Map => !N |-> 0 ...</store>
+
+

Note the use of the fresh (!N) variable notation above. Recall from
+the LAMBDA++ tutorial that each time the rule with fresh (!) variables is
+applied, fresh elements of corresponding sorts are generated for the fresh
+variables, distinct from all the previously generated elements; also, we
+cannot and should not assume anything about the particular element that is
+being generated, except that it is different from the previous ones.

+

kompile and krun sum.imp to see how the fresh locations have been
+generated and used. There were two fresh locations needed, for the two
+variables. Note also that a cell holding the counter has been added to the
+configuration.

+

In the next lesson we will add the semantics of variable increment, and see
+how that yields non-deterministic behaviors in programs and how to explore
+those behaviors using the K tool.

+

Go to Lesson 3, IMP++: Tagging; Superheat/Supercool Kompilation Options.

+

MOVIE (out of date) [04'06"]

+

Tagging; Transition Kompilation Option

+ +

In this lesson we add the semantics of variable increment. In doing so, we
+learn how to tag syntactic constructs and rules and then use such tags to
+instruct the kompile tool to generate the desired language model that is
+amenable for exhaustive analysis.

+

The variable increment rule is self-explanatory:

+
rule <k> ++X => I +Int 1 ...</k>
+     <env>... X |-> N ...</env>
+     <store>... N |-> (I => I +Int 1) ...</store>
+
+

We can now run programs like our div.imp program introduced in Lesson 1.
+Do it.

+

The addition of increment makes the evaluation of expressions have side
+effects. That, in combination with the non-determinism allowed by the
+strictness attributes in how expression constructs evaluate their
+arguments, makes expressions in particular and programs in general have
+non-deterministic behaviors. One possible execution of the div.imp program
+assigns 1 to y's location, for example, but this program manifests several
+other behaviors, too.

+

To see all the (final-state) behaviors that a program can have, you can call
+the krun tool with the option --search. For example:

+
krun div.imp --search
+
+

Oops, we see only one solution, the same as when we ran it without search.

+

Here is what happens. krun can only explore as much of the transition
+system associated to a program as kompile allowed the generated language
+model to yield. Since most of the K users are interested in language models
+that execute efficiently, that is, in faster interpreters for the defined
+languages, by default kompile optimizes the generated language model for
+execution. In particular, it inserts no backtracking markers, which krun
+uses when called with the --search option in order to systematically generate
+the entire transition system associated to a program. This is why krun
+showed us only one solution when run with the --search option on div.imp.

+

We next explain how to tell kompile what kind of language model we are
+interested in for analysis purposes. When you experiment with non-determinism
+in a language semantics, you should keep it in mind that the --transition
+option of kompile allows you to configure what counts as a transition in
+your language model. We here only discuss transitions due to the
+non-deterministic evaluation strategies of language constructs, but we will
+see in future lectures (see Lesson 6 of IMP++, where we add concurrency) that
+we can also have transitions due to non-deterministic applications of rewrite
+rules.

+

If you want to explore the entire behavior space due to non-deterministic
+evaluation strategies, then you should include all the language constructs
+in the --transition option. This may sound like the obvious thing to
+always do, but as soon as you do it you soon realize that it is way too much
+in practice when you deal with large languages or programs. There are simply
+too many program behaviors to consider, and krun will likely hang
+on you or crush. For example, a small ten-statement program where each
+statement uses one strict expression construct already has 1000+ behaviors for
+krun to explore! Driven by practical needs of its users, the K tool
+therefore allows you to finely tune the generated language models using the
+--transition option.

+

To state which constructs are to be considered to generate transitions in the
+generated language model, and for other reasons, too, the K tool allows you to
+tag any production and any rule by putting the tag in brackets. You can associate
+multiple tags to the same construct or rule, and more than one construct or
+rule can have the same tag. As an example, let us tag the division construct
+with division, the lookup rule with lookup and the increment rule with
+increment. The tags of the rules are not needed in this lesson, we do it only
+to demonstrate that rules can also be tagged.

+

The least intrusive way to enforce our current language to explore the
+entire space of behaviors due to the strictness of division is to kompile it
+with the following option:

+
kompile imp.k --transition "division"
+
+

It is interesting to note that the lookup and increment rules are the only
+two rules which can trigger non-deterministic behaviors for division, because
+no other rule but these two can ever apply while a division operation is
+heated. Previous versions of K allowed you to also specify which rules could
+trigger non-deterministic behaviors of operator evaluation strategies,
+but that option was rarely used and is not available anymore.

+

Note that it is highly non-trivial to say precisely whether a strict language
+construct may yield non-deterministic behaviors. For example, division's
+strictness would yield no non-determinism if the language had no side effects.
+It is even harder to say so for a particular program. Consequently, our K
+implementation makes no attempt to automatically detect which operations
+should be tagged as transitions. Instead, it provides the functionality to
+let you decide it.

+

Now the command

+
krun div.imp --search
+
+

shows us all five behaviors of this program. Interestingly, one
+of the five behaviors yields a division by zero!

+

The --transition option can be quite useful when you experiment with your
+language designs or when you formally analyze programs for certain kinds of
+errors. Please let us know if you ever need more finer-grained control over
+the non-determinism of your language models.

+

Before we conclude this lesson, we'd like to let you know one trick, which
+you will hopefully not overuse: you can tag elements in your K definition with
+kompile option names, and those elements will be automatically included in
+their corresponding options. For example, if you tag the division production
+with transition then the command

+
kompile imp
+
+

is completely equivalent to the previous kompile command.

+

Please use this default behavior with caution, or even better, try to avoid
+using it! You may be tempted to add the transition tag to lots of elements
+and then forget about them; your language models will then be increasingly slower
+when you execute them and you may wonder why ... This convention is typically
+convenient when you want to quickly experiment with non-determinism and do not
+want to bother inventing tag names and calling kompile with options.

+

In the next lesson we add input/output to our language and learn how to
+generate a model of it which behaves like an interactive interpreter!

+

Go to Lesson 4, IMP++: Semantic Lists; Input/Output Streaming.

+

MOVIE (out of date) [06'56"]

+

Semantic Lists; Input/Output Streaming

+ +

In this lesson we add semantics to the read and print IMP++ constructs.
+In doing so, we also learn how to use semantic lists and how to connect
+cells holding semantic lists to the standard input and standard output.
+This allows us to turn the K semantics into an interactive interpreter.

+

We start by adding two new cells to the configuration,

+
<in color="magenta"> .List </in>
+<out color="Orchid"> .List </out>
+
+

each holding a semantic list, initially empty. Semantic lists are
+space-separated sequences of items, each item being a term of the form
+ListItem(t), where t is a term of sort K. Recall that the semantic maps,
+which we use for states, environments, stores, etc., are sets of pairs
+t1 |-> t2, where t1 and t2 are terms of sort K. The ListItem wrapper
+is currently needed, to avoid parsing ambiguities.

+

Since we want the print statement to also print strings, we need to tell
+K that strings are results. To make it more interesting, let us also overload
+the + symbol on arithmetic expressions to also take strings and, as a
+result, to concatenate them. Since + is already strict, we only need to add
+a rule reducing the IMP addition of strings to the builtin operation +String
+which concatenates two strings.

+

The semantics of read is immediate: read and consumes the first integer item
+from the <in/> cell; note that our read only reads integer values (it gets
+stuck if the first item in the <in/> cell is not an integer).

+

The semantics of print is a bit trickier. Recall that print takes an
+arbitrary number of arithmetic expression arguments, and evaluates and outputs
+each of them in order, from left to right. For example,
+print("Hello", 3/0, "Bye"); outputs "Hello" and then gets stuck on the
+illegal division by zero operation. In other words, we do not want it to
+first evaluate all its arguments and then print them, because that would miss
+outputting potentially valuable information. So the first step is to evaluate
+the first argument of print. In some sense, what we'd like to say is that
+print has the evaluation strategy strict(1). However, strictness
+attributes only work with individual language constructs, while what we need
+is an evaluation strategy that involves two constructs: print and the list
+(comma) construct of AExps. If we naively associate print the strict(1)
+evaluation strategy then its first and unique argument, an AExps list, will
+be scheduled for evaluation and the execution will get stuck because we have
+no rules for evaluating AExps terms. If we make the list construct of
+AExps strict then we get the wrong semantics for print which first
+evaluates all its arguments and then outputs them. The correct way to
+tell K that print should evaluate only its first argument is by using a
+context declaration:

+
context print(HOLE:AExp, _);
+
+

Note the HOLE of sort AExp above. Contexts allow us to define finer-grain
+evaluation strategies than the strictness attributes, involving potentially
+more than one language construct, like above. The HOLE indicates the
+argument which is requested to be evaluated. For example, the strict
+attribute of division corresponds to two contexts:

+
context HOLE / _
+context _ / HOLE
+
+

In their full generality, contexts can be any terms with precisely one
+occurrence of a HOLE, and with arbitrary side conditions on any variables
+occurring in the context term as well as on the HOLE. See Part 6 of the
+tutorial for more examples.

+

Once evaluated, the first argument of print is expected to become either an
+integer or a string. Since we want to print both integers and string values,
+to avoid writing two rules, one for each type of value, we instead add a new
+syntactic category, Printable, which is the union of integers and strings.

+

Let us kompile and krun the io.imp program discussed in Lesson 1. As
+expected, it gets stuck with a read construct on top of the computation and
+with an empty <in/> cell. To run it, we need to provide some items in the
+<in/> cell, so that the rule of read can match. Let us add

+
<in> ListItem(3) ListItem(5) ListItem(7) </in>
+
+

Now, if we krun io.imp, we can see that its execution completes normally
+(the <k/> cell is empty), that the first two items have been removed by the
+two read constructs from the <in/> cell, and that the desired strings and
+numbers have been placed into the <out/> cell.

+

Cells holding semantic lists can be connected to the standard input and
+standard output buffers, and krun knows how to handle these appropriately.
+Let us connect the <in/> cell to the standard input using the cell attribute
+stream="stdin" and the <out/> cell to the standard output with the
+attribute stream="sdtout". A cell connected to the standard input will
+take its items from the standard input and block the rewriting process when
+an input is needed until an item is available in the standard input buffer.
+A cell connected to the standard output buffer will send all its items, in
+order, to the standard output.

+

Let us kompile and krun io.imp again. It prints the message and then
+waits for your input numbers. Type in two numbers, then press <Enter>.
+A message with their sum is then printed, followed by the final configuration.
+If you do not want to see the final configuration, and thus obtain a realistic
+interpreter for our language, then call krun with the option --output none:

+
krun io.imp --output none
+
+

Let us now krun our interactive sum program, which continuously reads numbers
+from the console and prints the sum of numbers up to them:

+
krun sum-io.imp
+
+

Try a few numbers, then 0. Note that the program terminated, but with junk
+in the <k/> cell, essentially with a halt statement on its top. Of course,
+because halt has been reached and it has no semantics yet.

+

In the next lesson we give the semantics of halt and also fix the semantics
+of blocks with local variable declarations.

+

Go to Lesson 5, IMP++: Deleting, Saving and Restoring Cell Contents.

+

MOVIE (out of date) [05'21"]

+

Deleting, Saving and Restoring Cell Contents

+ +

In this lesson we will see how easily we can delete, save and/or restore
+contents of cells in order to achieve the desired semantics of language
+constructs that involve abrupt changes of control or environments. We have
+seen similar or related K features in the LAMBDA++ language in Part 3 of the
+tutorial.

+

Let us start by adding semantics to the halt statement. As its name says,
+what we want is to abruptly terminate the execution of the program. Moreover,
+we want the program configuration to look as if the program terminated
+normally, with an empty computation cell. The simplest way to achieve that is
+to simply empty the computation cell when halt is encountered:

+
rule <k> halt; ~> _ => . </k>
+
+

It is important to mention the entire <k/> cell here, with both its membranes
+closed, to make sure that its entire contents is discarded. Note the
+anonymous variable, which matches the rest of the computation.

+

kompile and krun sum-io.imp. Note that unlike in Lesson 4, the program
+terminates with an empty computation cell now.

+

As mentioned earlier, the semantics of blocks that was inherited from IMP is
+wrong. Program locals.imp shows it very clearly: the environments are not
+correctly restored at block exits. One way to fix the problem is to take
+a snapshot of the current environment when a block is entered and save it
+somewhere, and then to restore it when the block is left. There are many
+ways to do this, which you can explore on your own: for example you can add
+a new list cell for this task where to push/pop the environment snapshots in
+a stack style; or you can use the existing environment cell for this purpose,
+but then you need to change the variable access rules to search through the
+stacked environments for the variable.

+

My preferred solution is to follow a style similar to how we saved/restored
+LAMBDA++ environments in Part 3 of the Tutorial, namely to use the already
+existing <k/> cell for such operations. More specifically, we place a
+reminder item in the computation whenever we need to take a snapshot of
+some cell contents; the item simply consists of the entire contents of the cell.
+Then, when the reminder item is reached, we restore the contents of the cell:

+
rule <k> {S} => S ~> Rho ...</k> <env> Rho </env>
+
+

The only thing left now is to give the definition of environment restore:

+
rule <k> Rho => . ...</k> <env> _ => Rho </env>
+
+

Done. kompile and krun locals.imp. Everything should work correctly now.
+Note that the rule above is different from the one we had for LAMBDA++ in
+Part 3 of the tutorial, in that here there is no value preceding the environment
+restoration item in the computation; that's because IMP++ statements,
+unlike LAMBDA++'s expressions, evaluate to nothing (.).

+

In the next lesson we will give semantics to the spawn S construct, which
+dynamically creates a concurrent shared-memory thread executing statement S.

+

Go to Lesson 6, IMP++: Adding/Deleting Cells Dynamically; Configuration Abstraction, Part 2.

+

MOVIE (out of date) [04'30"]

+

Adding/Deleting Cells Dynamically; Configuration Abstraction, Part 2

+ +

In this lesson we add dynamic thread creation and termination to IMP, and
+while doing so we learn how to define and use configurations whose structure
+can evolve dynamically.

+

Recall that the intended semantics of spawn S is to spawn a new concurrent
+thread that executes S. The new thread is being passed at creation time
+its parent's environment, so it can share with its parent the memory
+locations that its parent had access to at creation time. No other locations
+can be shared, and no other memory sharing mechanism is available.
+The parent and the child threads can evolve unrestricted, in particular they
+can change their environments by declaring new variables or shadowing existing
+ones, can create other threads, and so on.

+

The above suggests that each thread should have its own computation and its
+own environment. This can be elegantly achieved if we group the <k/> and
+<env/> cells in a <thread/> cell in the configuration. Since at any given
+moment during the execution of a program there could be zero, one or more
+instances of such a <thread/> cell in the configuration, it is a good idea
+to declare the <thread/> cell with multiplicity * (i.e., zero, one or more):

+
<thread multiplicity="*" color="blue">
+  <k color="green"> $PGM:Stmt </k>
+  <env color="LightSkyBlue"> .Map </env>
+</thread>
+
+

This multiplicity declaration is not necessary, but it is a good idea to do
+it for several reasons:

+
    +
  1. it may help the configuration abstraction process,
    +which may in turn significantly increase the compactness and modularity of
    +your subsequent rules;
  2. +
  3. it may help various analysis and execution tools,
    +for example static analyzers to give you error messages when you create cells
    +where you should not, or K compilers to improve performance by starting
    +actual concurrent hardware threads or processes corresponding to each cell
    +instance; and
  4. +
  5. it may help you better understand and control the dynamics
    +of your configuration, and thus your overall semantics.
  6. +
+

For good encapsulation, I also prefer to put all thread cells into one cell,
+<threads/>. This is technically unnecessary, though; to convince yourself
+that this is indeed the case, you can remove this cell once we are done with
+the semantics and everything will work without having to make any changes.

+

Before we continue, let us kompile an krun some programs that used to
+work, say sum-io.imp. In spite of the relatively radical configuration
+reorganization, those programs execute just fine! How is that possible?
+In particular, why do rules like the lookup and assignment still work,
+unchanged, in spite of the fact that the <k/> and <env/> cells are not at
+the same level with the <store/> cell in the configuration anymore?

+

Welcome to configuration abstraction, part 2. Recall that the role of
+configuration abstraction is to allow you to only write the relevant
+information in each rule, and have the compiler fill-in the obvious and boring
+details. According to the configuration that we declared for our new
+language, there is only one reasonable way to complete rules like the lookup,
+namely to place the <k/> and </env> cells inside a <thread/> cell,
+inside a <threads/> cell:

+
rule <threads>...
+       <thread>...
+         <k> X:Id => I ...</k>
+         <env>... X |-> N ...</env>
+       ...</thread>
+     ...<threads/>
+     <store>... N |-> I ...</store>  [lookup]
+
+

This is the most direct, compact and local way to complete the configuration
+context of the lookup rule. If for some reason you wanted here to match the
+<k/> cell of one thread and the <env/> cell of another thread, then you
+would need to explicitly tell K so, by mentioning the two thread cells,
+for example:

+
rule <thread>...
+         <k> X:Id => I ...</k>
+     ...</thread>
+     <thread>...
+         <env>... X |-> N ...</env>
+     ...</thread>
+     <store>... N |-> I ...</store>  [lookup]
+
+

By default, K completes rules in a greedy style. Think this way: what is the
+minimal number of changes to my rule to make it fit the declared
+configuration? That's what the K tool will do.

+

Configuration abstraction is technically unnecessary, but once you start
+using it and get a feel for how it works, it will become your best friend.
+It allows you to focus on the essentials of your semantics, and at the same
+time gives you flexibility in changing the configuration later on without
+having to touch the rules. For example, it allows you to remove the
+<threads/> cell from the configuration, if you don't like it, without
+having to touch any rule.

+

We are now ready to give the semantics of spawn:

+
rule <k> spawn S => . ...</k> <env> Rho </env>
+     (. => <thread>... <k> S </k> <env> Rho </env> ...</thread>)
+
+

Note configuration abstraction at work, again. Taking into account
+the declared configuration, and in particular the multiplicity information
+* in the <thread/> cell, the only reasonable way to complete the rule
+above is to wrap the <k/> and <env/> cells on the first line within a
+<thread/> cell, and to fill-in the ...s in the child thread with the
+default contents of the other subcells in <thread/>. In this case there
+are no other cells, so we can get rid of those ...s, but that would
+decrease the modularity of this rule: indeed, we may later on add other
+cells within <thread/> as the language evolves, for example a function
+or an exception stack, etc.

+

In theory, we should be able to write the rule above even more compactly
+and modularly, namely as

+
rule <k> spawn S => . ...</k> <env> Rho </env>
+     (. => <k> S </k> <env> Rho </env>)
+
+

Unfortunately, this currently does not work in the K tool, due to some
+known limitations of our current configuration abstraction algorithm.
+This latter rule would be more modular, because it would not even depend
+on the cell name thread. For example, we may later decide to change
+thread into agent, and we would not have to touch this rule.
+We hope this current limitation will be eliminated soon.

+

Once a thread terminates, its computation cell becomes empty. When that
+happens, we can go ahead and remove the useless thread cell:

+
rule <thread>... <k> . </k> ...</thread> => .
+
+

Let's see what we've got. kompile and krun spawn.imp.
+Note the following:

+
    +
  • The <threads/> cell is empty, so all threads terminated normally;
  • +
  • The value printed is different from the value in the store; the store value
    +is not even the one obtained if the threads executed sequentially.
  • +
+

Therefore, interesting behaviors may happen; we would like to see them all!

+

Based on prior experience with krun's search option, we would hope that

+
krun spawn.imp --search
+
+

shows all the behaviors. However, the above does not work, for two reasons.

+

First, spawn.imp is an interactive program, which reads a number from the
+standard input. When analyzing programs exhaustively using the search option,
+krun has to disable the streaming capabilities (just think about it and you
+will realize why). The best you can do in terms of interactivity with search
+is to pipe some input to krun: krun will flush the standard input buffer
+into the cells connected to it when creating the initial configuration (will
+do that no matter whether you run it with or without the --search option).
+For example:

+
echo 23 | krun spawn.imp --search
+
+

puts 23 in the standard input buffer, which is then transferred in the
+<in/> cell as a list item, and then the exhaustive search procedure is
+invoked.

+

Second, even after piping some input, the spawn.imp program still manifests
+only one behavior, which does not seem right. There should be many more.

+

As explained in Lesson 3, by default kompile optimizes the generated
+language model for execution. In particular, it does not insert any
+backtracking markers where transition attempts should be made, so krun
+lacks the information it needs to exhaustively search the generated language
+model. Like we did in Lesson 3 with the language constructs, we also have
+to explicitly tell kompile which rules should be considered as actual
+transitions. A theoretically correct but practically unfeasible approach
+to search all possible behaviors is to consider all rules as transitions.
+Even more than with the non-deterministic strictness of language constructs
+in Lesson 3, such a naive solution would make the number of behaviors, and
+thus krun, explode. Remember that a two-thread program with 150 statements
+each manifests more behaviors than particles in the known universe!
+Consequently, unless your multi-threaded programs are very small, you will
+most likely want to control which rules should be considered transitions and
+which should not.

+

A good rule of thumb is to include as transitions only those rules which
+compete for behaviors. That is, those rules which may yield a different
+behavior if we choose to apply them when other rules match as well.
+The rule for addition, for example, is a clear example of a rule which
+should not be a transition: indeed, 3+7 will rewrite to 10 now and also
+later. On the other hand, the lookup rule should be a transition. Indeed,
+if we delay the lookup of variable x, then other threads may write x in the
+meanwhile (with an increment or an assignment rule) and thus yield a
+different behavior.

+

Let us discuss and tag those rules which should be transitions: lookup and
+increment need to be transitions and we already tagged them in Lesson 3;
+the read rule needs to also be a transition, because it may complete with
+other instances of itself in other threads; assignment needs to also be a
+transition, and so should be the first rule for print.

+

Let us now kompile with the transition option set as desired:

+
kompile imp --transition "lookup increment assignment read print"
+
+

Now echo 23 | krun spawn.imp --search gives us all 12 behaviors of the
+spawn.imp program.

+

Like for non-deterministically strict operations which can be tagged as
+transitions, it is highly non-trivial to say precisely which rules need
+to be transitions. So krun makes no attempt to automatically detect it.
+Instead, it provides the functionality to let you decide it.

+

We currently have no mechanism for thread synchronization. In the next lesson
+we add a join statement, which allows a thread to wait until another completes.

+

Go to Lesson 7, IMP++: Everything Changes: Syntax, Configuration, Semantics.

+

MOVIE (out of date) [11'40"]

+

Everything Changes: Syntax, Configuration, Semantics

+ +

In this lesson we add thread joining, one of the simplest thread
+synchronization mechanisms. In doing so, we need to add unique ids
+to threads in the configuration, and to modify the syntax to allow spawn
+to return the id of the newly created thread. This gives us an opportunity
+to make several other small syntactic and semantics changes to the language,
+which make it more powerful or more compact at a rather low cost.

+

Before we start, let us first copy and modify the previous spawn.imp program
+from Lesson 1 to make use of thread joining. Recall from Lesson 6 that in some
+runs of this program the main thread completed before the child threads,
+printing a possibly undesired value of x. What we want now is to assign
+unique ids to the two spawned threads, and then to modify the main thread to
+join the two child threads before printing. To avoid adding a new type to
+the language, let's assume that thread ids are integer numbers. So we declare
+two integers, t1 and t2, and assign them the two spawn commands. In order
+for this to parse, we will have to change the syntax of spawn to be an
+arithmetic expression construct instead of a statement. Once we do that,
+we have a slight syntactic annoyance: we need to put two consecutive ;
+after the spawn assignment, one for the assignment statement inside the spawn,
+and another for the outer assignment. To avoid the two consecutive semicolons,
+we can syntactically enforce spawn to take a block as argument, instead of a
+statement. Now it looks better. The new spawn.imp program is still
+non-deterministic, because the two threads can execute in any order and even
+continue to have a data-race on the shared variable x, but we should see fewer
+behaviors when we use the join statements. If we want to fully synchronize
+this program, we can have the second thread start with a join(t1) statement.
+Then we should only see one behavior for this program.

+

Let us now modify the language semantics. First, we move the spawn
+construct from statements to expressions, and make it take a block.
+Second, we add one more sub-cell to the thread cell in the configuration,
+<id/>, to hold the unique identifier of the thread. We want the main
+thread to have id 0, so we initialize this cell with 0. Third, we modify
+the spawn rule to generate a fresh integer identifier, which is put in the
+<id/> cell of the child thread and returned as a result of spawn in the
+parent thread. Fourth, let us add the join statement to the language,
+both syntactically and semantically. So in order for the join(T) statement
+to execute, thread T must have its computation empty. However, in order
+for this to work we have to get rid of the thread termination cleanup rule.
+Indeed, we need to store somewhere the information that thread T terminated;
+the simplest way to do it is to not remove the terminated threads. Feel free
+to experiment with other possibilities, too, here. For example, you may add
+another cell, <done/>, in which you can store all the thread ids of the
+terminated and garbage-collected threads.

+

Let us now kompile imp.k and convince ourselves that the new spawn.imp
+with join statements indeed has fewer behaviors than its variant without
+join statements. Also, let us convince ourselves that the fully synchronized
+variant of it indeed has only one behavior.

+

Note that now spawn, like variable increment, makes the evaluation of
+expressions to have side effects. Many programming languages in fact allow
+expressions to be evaluated only for their side effects, and not for their
+value. This is typically done by simply adding a ; after the expression
+and thus turning it into a statement. For example, ++x;. Let as also
+allow arithmetic expressions in our language to be used as statements, by
+simply adding the production AExp ";" to Stmt, with evaluation strategy
+strict and with the expected semantics discarding the value of the AExp.

+

Another simple change in syntax and semantics which gives our language more
+power, is to remove the ; from the syntax of variable assignments and to make
+them expression instead of statement constructs. This change, combined with
+the previous one, will still allow us to parse all the programs that we could
+parse before, but will also allow us to parse more programs. For example, we
+can now do sequence assignments like in C: x = y = z = 0. The semantics
+of assignment now has to return the assigned value also to the computation,
+because we want the assignment expression to evaluate to the assigned value.

+

Let us also make another change, but this time one which only makes the
+definition more compact. Instead of defining statement sequential
+composition as a binary construct for statements, let us define a new
+syntactic construct, Stmts, as whitespace-separated lists of Stmt. This
+allows us to get rid of the empty blocks, because we can change the syntax of
+blocks to {Stmts} and Stmts also allows the empty sequence of statements.
+However, we do have to make sure that .Stmts dissolves.

+

In general, unless you are defining a well-established programming language,
+it is quite likely that your definitions will suffer lots of changes like the
+ones seen in this lecture. You add a new construct, which suggests changes
+in the existing syntax making in fact your language parse more programs,
+which then requires corresponding changes in the semantics, and so on.
+Also, compact definitions are desirable in general, because they are easier
+to read and easier to change if needed later.

+

In the next lesson we wrap up and document the definition of IMP++.

+

Go to Lesson 8, IMP++: Wrapping up Larger Languages.

+

Wrapping up Larger Languages

+ +

In this lesson we wrap up IMP++'s semantics and also generate its poster.
+While doing so, we also learn how to display larger configurations in order
+to make them easier to read and print.

+

Note that we rearrange a bit the semantics, to group the semantics of old
+IMP's constructs together, and separate it from the new IMP++'s semantics.

+

There is a detailed discussion at the end of the document about the
+--transition option of kompile, because that is important and we want
+the poster to include everything we learned in this part of the tutorial.

+

You can go even further and manually edit the generated Latex document.
+You typically want to do that when you want to publish your language
+definition, or parts of it, and you need to finely tune it to fit the
+editing requirements. For example, you may want to insert some negative
+spaces, etc.

+

Part 4 of the tutorial is now complete. At this moment you should know most
+of K framework's features and how to use the K tool. You can now define or
+design your own programming languages, and then execute and analyze programs.

+

MOVIE (out of date) [06'26"]

+

Part 5: Defining Type Systems

+ +

In this part of the tutorial we will show that defining type systems for
+languages is essentially no different from defining semantics. The major
+difference is that programs and fragments of programs now rewrite to their
+types, instead of to concrete values. In terms of K, we will learn how
+to use it for a certain particular but important kind of applications.

+

Imperative, Environment-Based Type Systems

+ +

In this lesson you learn how to define a type system for an imperative
+language (the IMP++ language defined in Part 4 of the tutorial), using a style
+based on type environments.

+

Let us copy the imp.k file from Part 4 of the tutorial, Lesson 7, which holds
+the semantics of IMP++, and modify it into a type system. The resulting type
+system, when executed, yields a type checker.

+

We start by defining the new strictness attributes of the IMP++ syntax.
+While doing so, remember that programs and fragments of programs now reduce
+to their types. So types will be the new results of our new (type) semantics.
+We also clean up the semantics by removing the unnecessary tags, and also
+use strict instead of seqstrict wherever possible, because strict gives
+implementations more freedom. Interestingly, note that spawn is strict now,
+because the code of the child thread should type in the current parent's type
+environment. Note that this is not always the case for threads, see for example
+SIMPLE in the languages tutorial, but it works here for our simpler IMP++.

+

From a typing perspective, the && construct is strict in both its arguments;
+its short-circuit (concrete) semantics is irrelevant for its (static) type
+system. Similarly, both the conditional and the while loop are strict
+constructs when regarded through the typing lenses.

+

Finally, the sequential composition is now sequentially strict! Indeed,
+statements are now going to reduce to their type, stmt, and it is critical
+for sequential composition to type its argument statements left-to-right;
+for example, imagine that the second argument is a variable declaration (whose
+type semantics will modify the type environment).

+

We continue by defining the new results of computations, that is, the actual
+types. In this simple imperative language, we only have a few constant types:
+int, bool, string, block and stmt.

+

We next define the new configuration, which is actually quite simple. Besides
+the <k/> cell, all we need is a type environment cell, <tenv/>, which will
+hold a map from identifiers to their types. A type environment is therefore
+like a state in the abstract domain of type values.

+

Let us next modify the semantic rules, turning them into a type system. In
+short, the idea is to reduce the basic values to their types, and then have a
+rule for each language construct reducing it to its result type whenever its
+arguments have the expected types.

+

We write the rules in the order given by the syntax declarations, to make
+sure we do not forget any construct.

+

Integers reduce to their type, int.

+

So do the strings.

+

Variables are now looked up in the type environment and reduced to their type
+there. Since we only declare integer variables in IMP++, their type in tenv
+will always be int. Nevertheless, we write the rule generically, so that we
+would not have to change it later if we add other type declarations to IMP++.
+Note that we reject programs which lookup undeclared variables. Rejection,
+in this case, means rewriting getting stuck.

+

Variable increment types to int, provided the variable has type int.

+

Read types to int, because we only allow integer input.

+

Division is only allowed on integers, so it rewrites to int provided that its
+arguments rewrite to int. Note, however, that in order to write int / int,
+we have to explicitly add int to the syntax of arithmetic expressions.
+Otherwise, the K parser rightfully complains, because / was declared on
+arithmetic expressions, not on types. One simple and generic way to allow
+types to appear anywhere, is to define Type as a syntactic subcategory of all
+the other syntactic categories. Let's do it on a by-need basis, though.

+

Addition is overloaded, so we add two typing rules for it: one for integers
+and another for strings.

+

As discussed, spawn types to stmt provided that its argument types to
+block.

+

The assignment construct was strict(2); its typing policy is that the declared
+type of X should be identical to the type of the assigned value. Like for
+lookup, we define this rule more generically than needed for IMP++, for any
+type, not only for int.

+

The typing rules for Boolean expression constructs are in the same spirit.
+Note that we need only one rule for &&.

+

The typing of blocks is a bit trickier. First, note that we still need to
+recover the environment after the block is typed, because we do not want the
+block-local variables to be visible in the outer type environment. We recover
+the type environment only after the block-enclosed statements type; moreover,
+we also opportunistically yield a block type on the computation when we
+discard the type environment recovery item. To account for the fact that the
+block-enclosed statement can itself be a block (e.g., {{S}}), we would need an
+additional rule. Since we do not like repetition, we instead group the types
+block and stmt into one syntactic category, BlockOrStmtType, and now we
+can have only one rule. We also include BlockOrStmtType in Type, as a
+replacement for the two basic types.

+

The expression statement types as expected. Recall that we only allow
+arithmetic expressions, which type to int, to be used as statements in IMP++.

+

The conditional was declared strict in all its arguments. Its typing policy
+is that its first argument types to bool and its two branches to block.
+If that is the case, then it yields a stmt type.

+

For while, its first argument should type to bool and its second to block.

+

Variable declarations add new bindings to the type environment. Recall that
+we can only declare variables of integer type in IMP++.

+

The typing policy of print is that it can only print integer or string values,
+and in that case it types to stmt. Like for BlockOrStmtType, to avoid
+having two similar rules, one for int and another for string, we prefer to
+introduce an additional syntactic category, PrintableType, which includes both
+int and string types.

+

halt types to stmt; so its subsequent code is also typed.

+

join types to stmt, provided that its argument types to int.

+

Sequential composition was declared as a whitespace-separated sequentially
+strict list. Its typing policy is that all the statements in the list should
+type to stmt or block in order for the list to type to stmt. Since
+lists are maintained internally as cons-lists, this is probably the simplest
+way to do it:

+
rule .Stmts => stmt
+rule _:BlockOrStmtType Ss => Ss
+
+

Note that the first rule, which types the empty sequence of statements to stmt,
+is needed anyway, to type empty blocks {} (together with the block rule).

+

kompile imp.k and krun all the programs in Part 4 of the tutorial. They
+should all type to stmt.

+

In the next lesson we will define a substitution-based type system for LAMBDA.

+

Go to Lesson 2, Type Systems: Substitution-Based Higher-Order Type Systems.

+

MOVIE (out of date) [10'11"]

+

Substitution-Based Higher-Order Type Systems

+ +

In this lesson you learn how to define a substitution-based type system for
+a higher-order language, namely the LAMBDA language defined in Part 1 of the
+tutorial.

+

Let us copy the definition of LAMBDA from Part 1 of the tutorial, Lesson 8.
+We are going to modify it into a type systems for LAMBDA.

+

Before we start, it is important to clarify an important detail, namely that
+our type system will yield a type checker when executed, not a type
+inferencer. In particular, we are going to change the LAMBDA syntax
+to allow us to associate a type to each declared variable. The
+constructs which declare variables are lambda, let, letrec and mu.
+The syntax of all these will therefore change.

+

Since here we are not interested in a LAMBDA semantics anymore, we take the
+freedom to eliminate the Val syntactic category, our previous results.
+Our new results are going to be the types, because programs will now reduce
+to their types.

+

As explained, the syntax of the lambda construct needs to change, to also
+declare the type of the variable that it binds. We add the new syntactic
+category Type, with the following constructs: int, bool, the function
+type (which gives it its higher-order status), and parentheses as bracket.
+Also, we make types our K results.

+

We are now ready to define the typing rules.

+

Let us start with the typing rule for lambda abstraction: lambda X : T . E
+types to the function type T -> T', where T' is the type obtained by further
+typing E[T/X]. This can be elegantly achieved by reducing the lambda
+abstraction to T -> E[T/X], provided that we extend the function type construct
+to take expressions, not only types, as arguments, and to be strict.
+This can be easily achieved by redeclaring it as a strict expression construct
+(strictness in the second argument would suffice in this example, but it is
+more uniform to define it strict overall).

+

The typing rule for application is as simple as it can get: (T1->T2) T1 => T2.

+

Let us now give the typing rules of arithmetic and Boolean expression
+constructs. First, let us get rid of Val. Second, rewrite each value to its
+type, similarly to the type system for IMP++ in the previous lesson. Third,
+replace each semantic rule by its typing rule. Fourth, make sure you
+do not forget to subsort Type to Exp, so your rules above will parse.

+

The typing policy of the conditional statement is that its first argument
+should type to bool and its other two arguments should type to the same type
+T, which will also be the result type of the conditional. So we make the
+conditional construct strict in all its three arguments and we write the
+obvious rule: if bool then T:Type else T => T. We want a runtime check that
+the latter arguments are actually typed, so we write T:Type.

+

There is nothing special about let, except that we have to make sure we
+change its syntax to account for the type of the variable that it binds.
+This rule is a macro, so the let is desugared statically.

+

Similarly, the syntax of letrec and mu needs to change to account for the
+type of the variable that they bind. The typing of letrec remains based on
+its desugaring to mu; we have to make sure the types are also included now.

+

The typing policy of mu is that its body should type to the same type T of
+its variable, which is also the type of the entire mu expression. This can
+be elegantly achieved by rewriting it to (T -> T) E[T/X]. Recall that
+application is strict, so E[T/X] will be eventually reduced to its type.
+Then the application types correctly only if that type is also T, and in
+that case the result type will also be T.

+

kompile and krun some programs. You can, for example, take the LAMBDA
+programs from the first tutorial, modify them by adding types to their
+variable declarations, and then type check them using krun.

+

In the next lesson we will discuss an environment-based type system
+for LAMBDA.

+

Go to Lesson 3, Type Systems: Environment-Based Higher-Order Type Systems.

+

MOVIE (out of date) [6'52"]

+

Environment-Based Higher-Order Type Systems

+ +

In this lesson you learn how to define an environment-based type system for
+a higher-order language, namely the LAMBDA language defined in Part 1 of the
+tutorial.

+

The simplest and fastest way to proceed is to copy the substitution-based
+type system of LAMBDA from the previous lesson and modify it into an
+environment-based one. A large portion of the substitution-based definition
+will remain unchanged. We only have to modify the rules that use
+substitution.

+

We do not need the substitution anymore, so we can remove the require and
+import statements. The syntax of types and expressions stays unchanged, but
+we can now remove the binder tag of lambda.

+

Like in the type system of IMP++ in Lesson 1, we need a configuration that
+contains, besides the <k/> cell, a <tenv/> cell that will hold the type
+environment.

+

In an environment-based definition, unlike in a substitution-based one, we
+need to lookup variables in the environment. So let us start with the
+type lookup rule:

+
rule <k> X:Id => T ...</k> <tenv>... X |-> T ...</k>
+
+

The type environment is populated by the semantic rule of lambda:

+
rule <k> lambda X : T . E => (T -> E) ~> Rho ...</k>
+     <tenv> Rho => Rho[X <- T] </tenv>
+
+

So X is bound to its type T in the type environment, and then T -> E
+is scheduled for processing. Recall that the arrow type construct has been
+extended into a strict expression construct, so E will be eventually reduced
+to its type. Like in other environment-based definitions, we need to make
+sure that we recover the type environment after the computation in the scope
+of the declared variable terminates.

+

The typing rule of application does not change, so it stays as elegant as it
+was in the substitution-based definition:

+
rule (T1 -> T2) T1 => T2
+
+

So do the rules for arithmetic and Boolean constructs, and those for the
+if, and let, and letrec.

+

The mu rule needs to change, because it was previously defined using
+substitution. We modify it in the same spirit as we modified the lambda
+rule: bind X to its type in the environment, schedule its body for typing
+in its right context, and then recover the type environment.

+

Finally, we give the semantics of environment recovery, making sure
+the environment is recovered only after the preceding computation is
+reduced to a type:

+

rule _:Type ~> (Rho => .) ... _ => Rho

+

The changes that we applied to the substitution-based definition were
+therefore quite systematic: each substitution invocation was replaced with
+an appropriate type environment update/recovery.

+

Go to Lesson 4, Type Systems: A Naive Substitution-Based Type Inferencer.

+

A Naive Substitution-Based Type Inferencer

+ +

In this lesson you learn how to define a naive substitution-based type
+inferencer for a higher-order language, namely the LAMBDA language
+defined in Part 1 of the tutorial.

+

Unlike in the type checker defined in Lessons 2 and 3, where we had to
+associate a type with each declared variable, a type inferencer
+attempts to infer the types of all the variables from the way those
+variables are used. Let us take a look at this program, say plus.lambda:

+
lambda x . lambda y . x + y
+
+

Since x and y are used in an integer addition context, we can infer
+that they must have the type int and the result of the addition is
+also an int, so the type of the entire expression is int -> int -> int.
+Similarly, the program if.lambda

+
lambda x . lambda y . lambda z .
+  if x then y else z
+
+

can only make sense when x has type bool and y and z have the same
+type, say t, in which case the type of the entire expression is
+bool -> t -> t -> t. Since the type t can be anything, we say that
+the type of this expression is polymorphic. That means that the code
+above can be used in different contexts, where t can be an int, a
+bool, a function type int -> int, and so on.

+

In the identity.lambda program

+
let f = lambda x . x
+in f 1
+
+

f has such a polymorphic type, which is then applied to an integer,
+so this program is type-safe and its type is int.

+

A typical polymorphic expression is the composition

+
lambda f . lambda g . lambda x .
+  g (f x)
+
+

which has the type (t1 -> t2) -> (t2 -> t3) -> (t1 -> t3), polymorphic
+in 3 types.

+

Let us now define our naive type inferencer and then we discuss more
+examples. The idea is quite simple: we conceptually do the same
+operations like we did within the type checker defined in Lesson 2,
+with two important differences:

+
    +
  1. instead of declaring a type with each declared variable, we assume
    +a fresh type for that variable; and
  2. +
  3. instead of checking that the types of expressions satisfy the
    +type properties of the context in which they are used, we impose
    +those properties as type equality constraints. A general-purpose
    +unification-based constraint solving mechanism is then used to solve
    +the generated type constraints.
  4. +
+

Let us start with the syntax, which is essentially identical to that
+of the type checker in Lesson 2, except that bound variables are not
+declared a type anymore. Also, to keep things more compact, we put
+all the Exp syntax declarations in one syntax declaration this time.

+

Before we modify the rules, let us first define our machinery for
+adding and solving constraints. First, we require and import the
+unification procedure. We do not discuss unification here, but if you
+are interested you can consult the unification.k files under
+k-distribution/include/kframework/builtin, which contains our current generic
+definition of unification, which is written also in K. The generic unification
+provides a sort, Mgu, for most-general-unifier, an operation
+updateMgu(Mgu,T1,T2) which updates Mgu with additional constraints
+generated by forcing the terms T1 and T2 to be equal, and an operation
+applyMgu(Mgu,T) which applies Mgu to term T. For our use
+of unification here, we do not even need to know how Mgu terms are
+represented internally.

+

We define a K item construct, =, which takes two Type terms and
+enforces them to be equal by means of updating the current Mgu.
+Once the constraints are added to the Mgu, the equality dissolves
+itself. With this semantics of = in mind, we can now go ahead and
+modify the rules of the type checker systematically into rules
+for a type inferencer. The changes are self-explanatory and
+mechanical: for example, the rule

+
rule int * int => int
+
+

changes into rule

+
rule T1:Type  * T2:Type => T1 = int ~> T2 = int ~> int
+
+

generating the constraints that the two arguments of multiplication
+have the type int, and the result type is int. Recall that each type
+equality on the <k/> cell updates the current Mgu appropriately and
+then dissolves itself; thus, the above says that after imposing the
+constraints T1=int and T2=int, multiplication yields a type int.

+

As mentioned above, since types of variables are not declared anymore,
+but inferred, we have to generate a fresh type for each variable at its
+declaration time, and then generate appropriately constraints for it.
+For example, the type semantics of lambda and mu become:

+
rule lambda X . E => T -> E[T/X]  when fresh(T:Type)
+rule mu X . E => (T -> T) E[T/X]  when fresh(T:Type)
+
+

that is, we add a condition stating that the previously declared type
+is now a fresh one. This type will be further constrained by how the
+variable X is being used within E.

+

Interestingly, the previous typing rule for lambda application is not
+powerful enough anymore. Indeed, since types are not given anymore,
+it may very well be the case that the inferred type of the first
+argument of the application construct is not yet a function type
+(remember, for example, the program composition.lambda above). What
+we have to do is to enforce it to be a function type, by means of
+fresh types and constraints. We can introduce a fresh type for the
+result of the application, and then write the expected rule as
+follows:

+
rule T1:Type T2:Type => T1 = (T2 -> T) ~> T  when fresh(T:Type)
+
+

The conditional requires that its first argument is a bool and its
+second and third arguments have the same type, which is also the
+result type.

+

The macros do not change, in particular let is desugared into lambda
+application. We will next see that this is a significant restriction,
+because it limits the polymorphism of our type system.

+

We are done. We have a working type inferencer for LAMBDA.

+

Let's kompile it and krun the programs above. They all work as
+expected. Let us also try some additional programs, to push it to its
+limits.

+

First, let us test mu by means of a letrec example:

+
letrec f x = 3
+in f
+
+

We can also try all the programs that we had in our first tutorial, on
+lambda, for example the factorial.imp program:

+
letrec f x = if x <= 1 then 1 else (x * (f (x + -1)))
+in (f 10)
+
+

Those programs are simple enough that they should all work as
+expected with our naive type inferencer here.

+

Let us next try to type some tricky programs, which involve more
+complex and indirect type constraints.

+

tricky-1.lambda:

+
lambda f . lambda x . lambda y . (
+  (f x y) + x + (let x = y in x)
+)
+
+

tricky-2.lambda:

+
lambda x .
+  let f = lambda y . if true then y else x
+  in (lambda x . f 0)
+
+

tricky-3.lambda:

+
lambda x . let f = lambda y . if true then x 7 else x y
+           in f
+
+

tricky-4.lambda:

+
lambda x . let f = lambda x . x
+           in let d = (f x) + 1
+              in x
+
+

tricky-5.lambda:

+
lambda x . let f = lambda y . x y
+           in let z = x 0 in f
+
+

It is now time to see the limitations of this naive type inferencer.
+Consider the program

+
let id = lambda x . x
+in if (id true) then (id 1) else (id 2)
+
+

Our type inferencer fails graciously with a clash in the <mgu/> cell
+between int and bool. Indeed, the desugaring macro of let turns it
+into a lambda and an application, which further enforce id to have a
+type of the form t -> t for some fresh type t. The first use of id
+in the condition of if will then constrain t to be bool, while the
+other uses in the two branches will enforce t to be int. Thus the
+clash in the <mgu/> cell.

+

Similarly, the program

+
let id = lambda x . x
+in id id
+
+

yields a different kind of conflict: if id has type t -> t, in order
+to apply id to itself it must be the case that its argument, t, equals
+t -> t. These two type terms cannot be unified because there is a
+circular dependence on t, so we get a cycle in the <mgu/> cell.

+

Both limitations above will be solved when we change the semantics of
+let later on, to account for the desired polymorphism.

+

Before we conclude this lesson, let us see one more interesting
+example, where the lack of let-polymorphism leads not to a type error,
+but to a less generic type:

+
let f1 = lambda x . x in
+  let f2 = f1 in
+    let f3 = f2 in
+      let f4 = f3 in
+        let f5 = f4 in
+          if (f5 true) then f2 else f3
+
+

Our current type inferencer will infer the type bool -> bool for the
+program above. Nevertheless, since all functions f1, f2, f3, f4, f5
+are the identity function, which is polymorphic, we would expect the
+entire program to type to the same polymorphic identity function type.

+

This limitation will be also addressed when we define our
+let-polymorphic type inferencer.

+

Before that, in the next lesson we will show how easily we can turn
+the naive substitution-based type inferencer discussed in this lesson
+into a similarly naive, but environment-based type inferencer.

+

Go to Lesson 5, Type Systems: A Naive Environment-Based Type Inferencer.

+

A Naive Environment-Based Type Inferencer

+ +

In this lesson you learn how to define a naive environment-based type
+inferencer for a higher-order language. Specifically, we take the
+substitution-based type inferencer for LAMBDA defined in Lesson 4 and
+turn it into an environment-based one.

+

Recall from Lesson 3, where we defined an environment-based type
+checker for LAMBDA based on the substitution-based one in Lesson 2,
+that the transition from a substitution-based definition to an
+environment-based one was quite systematic and mechanical: each
+substitution occurrence E[T/X] is replaced by E, but at the same time
+the variable X is bound to type T in the type environment. One benefit
+of using type environments instead of substitution is that we replace
+a linear complexity operation (the substitution) with a constant
+complexity one (the variable lookup).

+

There is not much left to say which has not been already said in
+Lesson 3: we remove the unnecessary binder annotations for the
+variable binding operations, then add a <tenv/> cell to the
+configuration to hold the type environment, then add a new rule for
+variable lookup, and finally apply the transformation of substitutions
+E[T/X] into E as explained above.

+

The resulting type inferencer should now work exactly the same way as
+the substitution-based one, except, of course, that the resulting
+configurations will contain a <tenv/> cell now.

+

As sanity check, let us consider two more LAMBDA programs that test
+the static scoping nature of the inferencer. We do that because
+faulty environment-based definitions often have this problem. The
+program

+
let x = 1
+in let f = lambda a . x
+   in let x = true
+      in f 3
+
+

should type to int, not to bool, and so it does. Similarly, the
+program

+
let y = 0
+in letrec f x = if x <= 0
+                then y
+                else let y = true
+                     in f (x + 1)
+   in f 1
+
+

should also type to int, not bool, and so it does, too.

+

The type inferencer defined in this lesson has the same limitations,
+in terms of polymorphism, as the one in Lesson 4. In the next
+lesson we will see how it can be parallelized, and in further lessons
+how to make it polymorphic.

+

Go to Lesson 6, Type Systems: Parallel Type Checkers/Inferencers.

+

Parallel Type Checkers/Inferencers

+ +

In this lesson you learn how to define parallel type checkers or
+inferencers. For the sake of a choice, we will parallelize the one in
+the previous lesson, but the ideas are general. We are using the same
+idea to define type checkers for other languages in the K tool
+distribution, such as SIMPLE and KOOL.

+

The idea is in fact quite simple. Instead of one monolithic typing
+task, we generate many smaller tasks, which can be processed in
+parallel. We use the same approach to define parallel semantics as we
+used for threads in IMP++ in Part 4 of the tutorial, that is, we add a
+cell holding all the parallel tasks, making sure we declare the cell
+holding a task with multiplicity *. For the particular type
+inferencer that we chose here, the one in Lesson 5, each task will
+hold an expression to type together with a type environment (so it
+knows where to lookup its free variables). We have the following
+configuration then:

+
configuration <tasks color="yellow">
+                <task color="orange" multiplicity="*">
+                  <k color="green"> $PGM:Exp </k>
+                  <tenv color="red"> .Map </tenv>
+                </task>
+              </tasks>
+              <mgu color="blue"> .Mgu </mgu>
+
+

Now we have to take each typing rule we had before and change it to
+yield parallel typing. For example, our rule for typing
+multiplication was the following in Lesson 5:

+
rule T1:Type * T2:Type => T1 = int ~> T2 = int ~> int
+
+

Since * was strict, its two arguments eventually type, and once that
+happens the rule above fires. Unfortunately, the strictness of
+multiplication makes the typing of the two expressions sequential in
+our previous definition. To avoid typing the two expressions
+sequentially and instead generating two parallel tasks, we remove the
+strict attribute of multiplication and replace the rule above with the
+following:

+
rule <k> E1 * E2 => int ...</k> <tenv> Rho </tenv>
+     (. => <task> <k> E1 = int </k> <tenv> Rho </tenv> </task>
+           <task> <k> E2 = int </k> <tenv> Rho </tenv> </task>)
+
+

Therefore, we generate two tasks for typing E1 and E2 in the same type
+environment as the current task, and let the current task continue by
+simply optimistically reducing E1*E2 to its expected result type, int.
+If E1 or E2 will not type to int, then either their corresponding
+tasks will get stuck or the <mgu/> cell will result into a clash or cycle,
+so the program will not type overall in spite of the fact that we
+allowed the task containing the multiplication to continue. This is
+how we get maximum of parallelism in this case.

+

Before we continue, note that the new tasks hold equalities in them,
+where one of its arguments is an expression, while previously the
+equality construct was declared to take types. What we want now is
+for the equality construct to possibly take any expressions, and first
+type them and then generate the type constraint like before. This can
+be done very easily by just extending the equality construct to
+expressions and declaring it strict:

+
syntax KItem ::= Exp "=" Exp  [strict]
+
+

Unlike before, where we only passed types to the equality construct,
+we now need a runtime check that its arguments are indeed types before
+we can generate the updateMgu command:

+
rule <k> T:Type = T':Type => . ...</k>
+     <mgu> Theta:Mgu => updateMgu(Theta,T,T') </mgu>
+
+

Like before, an equality will therefore update the <mgu/> cell and then
+it dissolves itself, letting the <k/> cell in the corresponding task
+empty. Such empty tasks are unnecessary, so they can be erased:

+
rule <task>... <k> . </k> ...</task> => .
+
+

We can now follow the same style as for multiplication to write the
+parallel typing rules of the other arithmetic constructs, and even for
+the conditional.

+

To parallelize the typing of lambda we generate two fresh types, one
+for the variable and one for the body, and make sure that we generate
+the correct type constraint and environment in the body task:

+
rule <k> lambda X . E => Tx -> Te ...</k> <tenv> TEnv </tenv>
+     (. => <task> <k> E = Te </k> <tenv> TEnv[Tx/X] </tenv> </task>)
+  when fresh(Tx:Type) andBool fresh(Te:Type)
+
+

Note that the above also allows us to not need to change and then
+recover the environment of the current cell.

+

For function application we also need to generate two fresh types:

+
rule <k> E1 E2 => T ...</k> <tenv> Rho </tenv>
+     (. => <task> <k> E1 = T2 -> T </k> <tenv> Rho </tenv> </task>
+           <task> <k> E2 = T2 </k> <tenv> Rho </tenv> </task>)
+  when fresh(T2:Type) andBool fresh(T:Type)
+
+

The only rule left is that of mu X . E. In this case we only need one
+fresh type, because X, E and mu X . E have all the same type:

+
rule <k> mu X . E => T ...</k>  <tenv> TEnv </tenv>
+     (. => <task> <k> E = T </k> <tenv> TEnv[T/X] </tenv> </task>)
+  when fresh(T:Type)
+
+

We do not need the type environment recovery operation, so we delete it.

+

We can now kompile and krun all the programs that we typed in Lesson 5.
+Everything should work.

+

In this lesson we only aimed at parallelizing the type inferencer in
+Lesson 5, not to improve its expressiveness; it still has the same
+limitations in terms of polymorphism. The next lessons are dedicated
+to polymorphic type inferencers.

+

Go to Lesson 7, Type Systems: A Naive Substitution-based Polymorphic Type Inferencer.

+

A Naive Substitution-based Polymorphic Type Inferencer

+ +

In this lesson you learn how little it takes to turn a naive monomorphic
+type inferencer into a naive polymorphic one, basically only changing
+a few characters. In terms of the K framework, you will learn that
+you can have complex combinations of substitutions in K, both over
+expressions and over types.

+

Let us start directly with the change. All we have to do is to take
+the LAMBDA type inferencer in Lesson 4 and only change the macro

+
rule let X = E in E' => (lambda X . E') E  [macro]
+
+

as follows:

+
rule let X = E in E' => E'[E/X]  [macro]
+
+

In other words, we are inlining the beta-reduction rule of
+lambda-calculus within the original rule. In terms of typing,
+the above forces the type inferencer to type E in place for each
+occurrence of X in E'. Unlike in the first rule, where X had to get
+one type only which satisfied the constrains of all X's occurrences in
+E', we now never associate any type to X anymore.

+

Let us kompile and krun some examples. Everything that worked with
+the type inferencer in Lesson 4 should still work here, although the
+types of some programs can now be more general. For example, reconsider
+the nested-lets.lambda program

+
let f1 = lambda x . x in
+  let f2 = f1 in
+    let f3 = f2 in
+      let f4 = f3 in
+        let f5 = f4 in
+          if (f5 true) then f2 else f3
+
+

which was previously typed to bool -> bool. With the new rule above,
+the sequence of lets is iteratively eliminated and we end up with the
+program

+
if (lambda x . x) true then (lambda x . x) else (lambda x . x)
+
+

which now types (with both type inferencers) to a type of the form
+t -> t, for some type variable t, which is more general than the
+previous bool -> bool type that the program typed to in Lesson 4.

+

We can also now type programs that were not typable before, such as

+
let id = lambda x . x
+in if (id true) then (id 1) else (id 2)
+
+

and

+
let id = lambda x . x
+in id id
+
+

Let us also test it on some trickier programs, also not typable
+before, such as

+
let f = lambda x . x
+in let g = lambda y . f y
+   in g g
+
+

which gives us a type of the form t -> t for some type variable t,
+and as

+
let f = let g = lambda x . x
+        in let h = lambda x . lambda x . (g g g g)
+           in h
+in f
+
+

which types to t1 -> t2 -> t3 -> t3 for some type variables t1, t2, t3.

+

Here is another program which was not typable before, which is
+trickier than the others above in that a lambda-bound variable appears
+free in a let-bound expression:

+
lambda x . (
+  let y = lambda z . x
+  in if (y true) then (y 1) else (y (lambda x . x))
+)
+
+

The above presents no problem now, because once lambda z . x gets
+substituted for y we get a well-typed expression which yields that x
+has the type bool, so the entire expression types to bool -> bool.

+

The cheap type inferencer that we obtained above therefore works as
+expected. However, it has two problems which justify a more advanced
+solution. First, substitution is typically considered an elegant
+mathematical instrument which is not too practical in implementations,
+so an implementation of this type inferencer will likely be based on
+type environments anyway. Additionally, we mix two kinds of
+substitutions in this definition, one where we substitute types and
+another where we substitute expressions, which can only make things
+harder to implement efficiently. Second, our naive substitution of E
+for X in E' can yield an exponential explosion in size of the original
+program. Consider, for example, the following classic example which
+is known to generate a type whose size is exponential in the size of
+the program (and is thus used as an argument for why let-polymorphic
+type inference is exponential in the worst-case):

+
let f00 = lambda x . lambda y . x in
+  let f01 = lambda x . f00 (f00 x) in
+    let f02 = lambda x . f01 (f01 x) in
+      let f03 = lambda x . f02 (f02 x) in
+        let f04 = lambda x . f03 (f03 x) in
+          // ... you can add more nested lets here
+          f04
+
+

The particular instance of the pattern above generates a type which
+has 17 type variables! The desugaring of each let doubles the size of
+the program and of its resulting type. While such programs are little
+likely to appear in practice, it is often the case that functions can
+be quite complex and large while their type can be quite simple in the
+end, so we should simply avoid retyping each function each time it is
+used.

+

This is precisely what we will do next. Before we present the classic
+let-polymorphic type inferencer in Lesson 9, which is based on
+environments, we first quickly discuss in Lesson 8 an intermediate
+step, namely a naive environment-based variant of the inferencer
+defined here.

+

Go to Lesson 8, Type Systems: A Naive Environment-based Polymorphic Type Inferencer.

+

A Naive Environment-based Polymorphic Type Inferencer

+ +

In this short lesson we discuss how to quickly turn a naive
+environment-based monomorphic type inferencer into a naive let-polymorphic
+one. Like in the previous lesson, we only need to change a few
+characters. In terms of the K framework, you will learn how to have
+both environments and substitution in the same definition.

+

Like in the previous lesson, all we have to do is to take the LAMBDA
+type inferencer in Lesson 5 and only change the rule

+
rule let X = E in E' => (lambda X . E') E
+
+

as follows:

+
rule let X = E in E' => E'[E/X]
+
+

The reasons why this works have already been explained in the previous
+lesson, so we do not repeat them here.

+

Since our new let rule uses substitution, we have to require the
+substitution module at the top and also import SUBSTITUTION in the
+current module, besides the already existing UNIFICATION.

+

Everything which worked with the type inferencer in Lesson 7 should
+also work now. Let us only try the exponential type example,

+
let f00 = lambda x . lambda y . x in
+  let f01 = lambda x . f00 (f00 x) in
+    let f02 = lambda x . f01 (f01 x) in
+      let f03 = lambda x . f02 (f02 x) in
+        let f04 = lambda x . f03 (f03 x) in
+          f04
+
+

As expected, this gives us precisely the same type as in Lesson 7.

+

So the only difference between this type inferencer and the one in
+Lesson 7 is that substitution is only used for LAMBDA-to-LAMBDA
+transformations, but not for infusing types within LAMBDA programs.
+Thus, the syntax of LAMBDA programs is preserved intact, which some
+may prefer. Nevertheless, this type inferencer is still expensive and
+wasteful, because the let-bound expression is typed over and over
+again in each place where the let-bound variable occurs.

+

In the next lesson we will discuss a type inferencer based on the
+classic Damas-Hindley-Milner type system, which maximizes the reuse of
+typing work by means of parametric types.

+

Go to Lesson 9, Type Systems: Let-Polymorphic Type Inferencer (Damas-Hindley-Milner).

+

Let-Polymorphic Type Inferencer (Damas-Hindley-Milner)

+ +

In this lesson we discuss a type inferencer based on what we call today
+the Damas-Hindley-Milner type system, which is at the core of many
+modern functional programming languages. The first variant of it was
+proposed by Hindley in 1969, then, interestingly, Milner rediscovered
+it in 1978 in the context of the ML language. Damas formalized it as
+a type system in his PhD thesis in 1985. More specifically, our type
+inferencer here, like many others as well as many implementations of
+it, follows more closely the syntax-driven variant proposed by Clement
+in 1987.

+

In terms of K, we will see how easily we can turn one definition which
+is considered naive (our previous type inferencer in Lesson 8) into a
+definition which is considered advanced. All we have to do is to
+change one existing rule (the rule of the let binder) and to add a new
+one. We will also learn some new predefined features of K, which make
+the above possible.

+

The main idea is to replace the rule

+
rule let X = E in E' => E'[E/X]
+
+

which creates potentially many copies of E within E' with a rule
+which types E once and then reuses that type in each place where X
+occurs free in E'. The simplest K way to type E is to declare the
+let construct strict(2). Now we cannot simply bind X to the type
+of E, because we would obtain a variant of the naive type inferencer
+we already discussed, together with its limitations, in Lesson 5 of this
+tutorial. The trick here is to parameterize the type of E in all its
+unconstrained fresh types, and then create fresh copies of those
+parameters in each free occurrence of X in E'.

+

Let us discuss some examples, before we go into the technical details.
+Consider the first let-polymorphic example which failed to be typed
+with our first naive type-inferencer:

+
let id = lambda x . x
+in if (id true) then (id 1) else (id 2)
+
+

When typing lambda x . x, we get a type of the form t -> t, for some
+fresh type t. Instead of assigning this type to id as we did in the
+naive type inferencers, we now first parametrize this type in its
+fresh variable t, written

+
(forall t) t -> t
+
+

and then bind id to this parametric type. The intuition for the
+parameter is that it can be instantiated with any other type, so this
+parametric type stands, in fact, for infinitely many non-parametric
+types. This is similar to what happens in formal logic proof systems,
+where rule schemas stand for infinitely many concrete instances of
+them. For this reason, parametric types are also called type schemas.

+

Now each time id is looked up within the let-body, we create a fresh
+copy of the parameter t, which can this way be independently
+constrained by each local context. Let's suppose that the three id
+lookups yield the types t1 -> t1, t2 -> t2, and respectively t3 -> t3.
+Then t1 will be constrained to be bool, and t2 and t3 to be int,
+so we can now safely type the program above to int.

+

Therefore, a type schema comprises a summary of all the typing work
+that has been done for typing the corresponding expression, and an
+instantiation of its parameters with fresh copies represents an
+elegant way to reuse all that typing work.

+

There are some subtleties regarding what fresh types can be made
+parameters. Let us consider another example, discussed as part of
+Lesson 7 on naive let-polymorphism:

+
lambda x . (
+  let y = lambda z . x
+  in if (y true) then (y 1) else (y (lambda x . x))
+)
+
+

This program should type to bool -> bool, as explained in Lesson 7.
+The lambda construct will bind x to some fresh type tx. Then the
+let-bound expression lambda z . x types to tz -> tx for some
+additional fresh type tz. The question now is what should the
+parameters of this type be when we generate the type schema? If we
+naively parameterize in all fresh variables, that is in both tz and
+tx obtaining the type schema (forall tz,tx) tz -> tx, then there will
+be no way to infer that the type of x, tx, must be a bool! The
+inferred type of this expression would then wrongly be tx -> t for
+some fresh types tx and t. That's because the parameters are replaced
+with fresh copies in each occurrence of y, and thus their relationship
+to the original x is completely lost. This tells us that we cannot
+parameterize in all fresh types that appear in the type of the
+let-bound expression. In particular, we cannot parameterize in those
+which some variables are already bound to in the current type
+environment (like x is bound to tx in our example above).
+In our example, the correct type schema is (forall tz) tz -> tx,
+which now allows us to correctly infer that tx is bool.

+

Let us now discuss another example, which should fail to type:

+
lambda x .
+  let f = lambda y . x y
+  in if (f true) then (f 1) else (f 2)
+
+

This should fail to type because lambda y . x y is equivalent to x,
+so the conditional imposes the conflicting constraints that x should be
+a function whose argument is either a bool or an int. Let us try to
+type it using our currently informal procedure. Like in the previous
+example, x will be bound to a fresh type tx. Then the let-bound
+expression types to ty -> tz with ty and tz fresh types, adding also
+the constraint tx = ty -> tz. What should the parameters of this type
+be? If we ignore the type constraint and simply make both ty and tz
+parameters because no variable is bound to them in the type
+environment (indeed, the only variable x in the type environment is
+bound to tx), then we can wrongly type this program to tx -> tz
+following a reasoning similar to the one in the example above.
+In fact, in this example, none of ty and tz can be parameters, because
+they are constrained by tx.

+

The examples above tell us two things: first, that we have to take the
+type constraints into account when deciding the parameters of the
+schema; second, that after applying the most-general-unifier solution
+given by the type constraints everywhere, the remaining fresh types
+appearing anywhere in the type environment are consequently constrained
+and cannot be turned into parameters. Since the type environment can in
+fact also hold type schemas, which already bind some types, we only need
+to ensure that none of the fresh types appearing free anywhere in the
+type environment are turned into parameters of type schemas.

+

Thanks to generic support offered by the K tool, we can easily achieve
+all the above as follows.

+

First, add syntax for type schemas:

+
syntax TypeSchema ::= "(" "forall" Set ")" Type  [binder]
+
+

The definition below will be given in such a way that the Set argument
+of a type schema will always be a set of fresh types. We also declare
+this construct to be a binder, so that we can make use of the generic
+free variable function provided by the K tool.

+

We now replace the old rule for let

+
rule let X = E in E' => E'[E/X]
+
+

with the following rule:

+
rule <k> let X = T:Type in E => E ~> tenv(TEnv) ...</k>
+     <mgu> Theta:Mgu </mgu>
+     <tenv> TEnv
+      => TEnv[(forall freeVariables(applyMgu(Theta, T)) -Set
+                      freeVariables(applyMgu(Theta, values TEnv))
+              ) applyMgu(Theta, T) / X]
+     </tenv>
+
+

So the type T of E is being parameterized and then bound to X in the
+type environment. The current mgu Theta, which comprises all the type
+constraints accumulated so far, is applied to both T and the types in
+the type environment. The remaining fresh types in T which do not
+appear free in the type environment are then turned into type parameters.
+The function freeVariables returns, as expected, the free variables of
+its argument as a Set; this is why we declared the type schema to be a
+binder above.

+

Now a LAMBDA variable in the type environment can be bound to either a
+type or a type schema. In the first case, the previous rule we had
+for variable lookup can be reused, but we have to make sure we check
+that T there is of sort Type (adding a sort membership, for example).
+In the second case, as explained above, we have to create fresh copies
+of the parameters. This can be easily achieved with another
+predefined K function, as follows:

+
rule <k> X:Id => freshVariables(Tvs,T) ...</k>
+     <tenv>... X |-> (forall Tvs) T ...</tenv>
+
+

Indeed, freshVariables takes a set of variables and a term, and returns the
+same term but with each of the given variables replaced by a fresh copy.

+

The operations freeVariables and freshVariables are useful in many K
+definitions, so they are predefined in module substitution.k.

+

Our definition of this let-polymorphic type inferencer is now
+complete. To test it, kompile it and then krun all the LAMBDA
+programs discussed since Lesson 4. They should all work as expected.

+

K Languages

+ +

Here we present several "real-world" language examples. These languages
+demonstrate many of the features you would expect to find in a full-fledged
+programming language.

+
    +
  • SIMPLE: Imperative programming language with threads.
  • +
  • KOOL: SIMPLE extended with object-oriented features.
  • +
  • FUN: A functional language with algebraic data-types and pattern-matching.
  • +
  • LOGIK: A logical programming language based on clause unification.
  • +
+

SIMPLE — Untyped

+ +

Author: Grigore Roșu (grosu@illinois.edu)
+Organization: University of Illinois at Urbana-Champaign

+

Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
+Organization: University of Bucharest

+

Abstract

+ +

This is the K semantic definition of the untyped SIMPLE language.
+SIMPLE is intended to be a pedagogical and research language that captures
+the essence of the imperative programming paradigm, extended with several
+features often encountered in imperative programming languages.
+A program consists of a set of global variable declarations and
+function definitions. Like in C, function definitions cannot be
+nested and each program must have one function called main,
+which is invoked when the program is executed. To make it more
+interesting and to highlight some of K's strengths, SIMPLE includes
+the following features in addition to the conventional imperative
+expression and statement constructs:

+
    +
  • +

    Multidimensional arrays and array references. An array evaluates
    +to an array reference, which is a special value holding a location (where
    +the elements of the array start) together with the size of the array;
    +the elements of the array can be array references themselves (particularly
    +when the array is multi-dimensional). Array references are ordinary values,
    +so they can be assigned to variables and passed/received by functions.

    +
  • +
  • +

    Functions and function values. Functions can have zero or
    +more parameters and can return abruptly using a return statement.
    +SIMPLE follows a call-by-value parameter passing style, with static scoping.
    +Function names evaluate to function abstractions, which hereby become ordinary
    +values in the language, same like the array references.

    +
  • +
  • +

    Blocks with locals. SIMPLE variables can be declared
    +anywhere, their scope being from the place where they are declared
    +until the end of the most nested enclosing block.

    +
  • +
  • +

    Input/Output. The expression read() evaluates to the
    +next value in the input buffer, and the statement write(e)
    +evaluates e and outputs its value to the output buffer. The
    +input and output buffers are lists of values.

    +
  • +
  • +

    Exceptions. SIMPLE has parametric exceptions (the value thrown as
    +an exception can be caught and bound).

    +
  • +
  • +

    Concurrency via dynamic thread creation/termination and
    +synchronization. One can spawn a thread to execute any statement.
    +The spawned thread shares with its parent its environment at creation time.
    +Threads can be synchronized via a join command which blocks the current thread
    +until the joined thread completes, via re-entrant locks which can be acquired
    +and released, as well as through rendezvous commands.

    +
  • +
+

Like in many other languages, some of SIMPLE's constructs can be
+desugared into a smaller set of basic constructs. We do that at the end
+of the syntax module, and then we only give semantics to the core constructs.

+

Note: This definition is commented slightly more than others, because it is
+intended to be one of the first non-trivial definitions that the new
+user of K sees. We recommend the beginner user to first check the
+language definitions discussed in the K tutorial.

+
module SIMPLE-UNTYPED-SYNTAX
+  imports DOMAINS-SYNTAX
+

Syntax

+ +

We start by defining the SIMPLE syntax. The language constructs discussed
+above have the expected syntax and evaluation strategies. Recall that in K
+we annotate the syntax with appropriate strictness attributes, thus giving
+each language construct the desired evaluation strategy.

+

Identifiers

+ +

Recall from the K tutorial that identifiers are builtin and come under the
+syntactic category Id. The special identifier for the function
+main belongs to all programs, and plays a special role in the semantics,
+so we declare it explicitly. This would not be necessary if the identifiers
+were all included automatically in semantic definitions, but that is not
+possible because of parsing reasons (e.g., K variables used to match
+concrete identifiers would then be ambiguously parsed as identifiers). They
+are only included in the parser generated to parse programs (and used by the
+kast tool). Consequently, we have to explicitly declare all the
+concrete identifiers that play a special role in the semantics, like
+main below.

+
  syntax Id ::= "main" [token]
+

Declarations

+ +

There are two types of declarations: for variables (including arrays) and
+for functions. We are going to allow declarations of the form
+var x=10, a[10,10], y=23;, which is why we allow the var
+keyword to take a list of expressions. The non-terminals used in the two
+productions below are defined shortly.

+
  syntax Stmt ::= "var" Exps ";"
+                | "function" Id "(" Ids ")" Block
+

Expressions

+ +

The expression constructs below are standard. Increment (++) takes
+an expression rather than a variable because it can also increment an array
+element. Recall that the syntax we define in K is what we call the syntax
+of the semantics
: while powerful enough to define non-trivial syntaxes
+(thanks to the underlying SDF technology that we use), we typically refrain
+from defining precise syntaxes, that is, ones which accept precisely the
+well-formed programs (that would not be possible anyway in general). That job
+is deferred to type systems, which can also be defined in K. In other words,
+we are not making any effort to guarantee syntactically that only variables
+or array elements are passed to the increment construct, we allow any
+expression. Nevertheless, we will only give semantics to those, so expressions
+of the form ++5, which parse (but which will be rejected by our type
+system in the typed version of SIMPLE later), will get stuck when executed.
+Arrays can be multidimensional and can hold other arrays, so their
+lookup operation takes a list of expressions as argument and applies to an
+expression (which can in particular be another array lookup), respectively.
+The construct sizeOf gives the size of an array in number of elements
+of its first dimension. Note that almost all constructs are strict. The only
+constructs which are not strict are the increment (since its first argument
+gets updated, so it cannot be evaluated), the input read which takes no
+arguments so strictness is irrelevant for it, the logical and and or constructs
+which are short-circuited, the thread spawning construct which creates a new
+thread executing the argument expression and return its unique identifier to
+the creating thread (so it cannot just evaluate its argument in place), and the
+assignment which is only strict in its second argument (for the same reason as
+the increment).

+
  syntax Exp ::= Int | Bool | String | Id
+               | "(" Exp ")"             [bracket]
+               | "++" Exp
+               > Exp "[" Exps "]"        [strict]
+               > Exp "(" Exps ")"        [strict]
+               | "-" Exp                 [strict]
+               | "sizeOf" "(" Exp ")"    [strict]
+               | "read" "(" ")"
+               > left:
+                 Exp "*" Exp             [strict, left]
+               | Exp "/" Exp             [strict, left]
+               | Exp "%" Exp             [strict, left]
+               > left:
+                 Exp "+" Exp             [strict, left]
+               | Exp "-" Exp             [strict, left]
+               > non-assoc:
+                 Exp "<" Exp             [strict, non-assoc]
+               | Exp "<=" Exp            [strict, non-assoc]
+               | Exp ">" Exp             [strict, non-assoc]
+               | Exp ">=" Exp            [strict, non-assoc]
+               | Exp "==" Exp            [strict, non-assoc]
+               | Exp "!=" Exp            [strict, non-assoc]
+               > "!" Exp                 [strict]
+               > left:
+                 Exp "&&" Exp            [strict(1), left]
+               | Exp "||" Exp            [strict(1), left]
+               > "spawn" Block
+               > Exp "=" Exp             [strict(2), right]
+

We also need comma-separated lists of identifiers and of expressions.
+Moreover, we want them to be strict, that is, to evaluate to lists of results
+whenever requested (e.g., when they appear as strict arguments of
+the constructs above).

+
  syntax Ids  ::= List{Id,","}           [klabel(Exps)]
+  syntax Exps ::= List{Exp,","}          [klabel(Exps), strict]  // automatically hybrid now
+  syntax Exps ::= Ids
+  syntax Val
+  syntax Vals ::= List{Val,","}          [klabel(Exps)]
+  syntax Bottom
+  syntax Bottoms ::= List{Bottom,","}    [klabel(Exps)]
+  syntax Ids ::= Bottoms
+

Statements

+ +

Most of the statement constructs are standard for imperative languages.
+We syntactically distinguish between empty and non-empty blocks, because we
+chose Stmts not to be a (;-separated) list of
+Stmt. Variables can be declared anywhere inside a block, their scope
+ending with the block. Expressions are allowed to be used for their side
+effects only (followed by a semicolon ;). Functions are allowed
+to abruptly return. The exceptions are parametric, i.e., one can throw a value
+which is bound to the variable declared by catch. Threads can be
+dynamically created and terminated, and can synchronize with join,
+acquire, release and rendezvous. Note that the
+strictness attributes obey the intended evaluation strategy of the various
+constructs. In particular, the if-then-else construct is strict only in its
+first argument (the if-then construct will be desugared into if-then-else),
+while the loop constructs are not strict in any arguments. The print
+statement construct is variadic, that is, it takes an arbitrary number of
+arguments.

+
  syntax Block ::= "{" "}"
+                | "{" Stmt "}"
+
+  syntax Stmt ::= Block
+                | Exp ";"                               [strict]
+                | "if" "(" Exp ")" Block "else" Block   [avoid, strict(1)]
+                | "if" "(" Exp ")" Block                [macro]
+                | "while" "(" Exp ")" Block
+                | "for" "(" Stmt Exp ";" Exp ")" Block  [macro]
+                | "return" Exp ";"                      [strict]
+                | "return" ";"                          [macro]
+                | "print" "(" Exps ")" ";"              [strict]
+// NOTE: print strict allows non-deterministic evaluation of its arguments
+// Either keep like this but document, or otherwise make Exps seqstrict.
+// Of define and use a different expression list here, which is seqstrict.
+                | "try" Block "catch" "(" Id ")" Block
+                | "throw" Exp ";"                       [strict]
+                | "join" Exp ";"                        [strict]
+                | "acquire" Exp ";"                     [strict]
+                | "release" Exp ";"                     [strict]
+                | "rendezvous" Exp ";"                  [strict]
+

The reason we allow Stmts as the first argument of for
+instead of Stmt is because we want to allow more than one statement
+to be executed when the loop is initialized. Also, as seens shorly, macros
+may expand one statement into more statements; for example, an initialized
+variable declaration statement var x=0; desugars into two statements,
+namely var x; x=0;, so if we use Stmt instead of Stmts
+in the production of for above then we risk that the macro expansion
+of statement var x=0; happens before the macro expansion of for,
+also shown below, in which case the latter would not apply anymore because
+of syntactic mismatch.

+
  syntax Stmt ::= Stmt Stmt                          [right]
+
+// I wish I were able to write the following instead, but confuses the parser.
+//
+// syntax Stmts ::= List{Stmt,""}
+// syntax Top ::= Stmt | "function" Id "(" Ids ")" Block
+// syntax Pgm ::= List{Top,""}
+//
+// With that, I could have also eliminated the empty block
+

Desugared Syntax

+ +

This part desugars some of SIMPLE's language constructs into core ones.
+We only want to give semantics to core constructs, so we get rid of the
+derived ones before we start the semantics. All desugaring macros below are
+straightforward.

+
  rule if (E) S => if (E) S else {}
+  rule for(Start Cond; Step) {S} => {Start while (Cond) {S Step;}}
+  rule for(Start Cond; Step) {} => {Start while (Cond) {Step;}}
+  rule var E1:Exp, E2:Exp, Es:Exps; => var E1; var E2, Es;
+  rule var X:Id = E; => var X; X = E;
+

For the semantics, we can therefore assume from now on that each
+conditional has both branches, that there are only while loops, and
+that each variable is declared alone and without any initialization as part of
+the declaration.

+
endmodule
+
+
+module SIMPLE-UNTYPED
+  imports SIMPLE-UNTYPED-SYNTAX
+  imports DOMAINS
+

Basic Semantic Infrastructure

+ +

Before one starts adding semantic rules to a K definition, one needs to
+define the basic semantic infrastructure consisting of definitions for
+values and configuration. As discussed in the definitions
+in the K tutorial, the values are needed to know when to stop applying
+the heating rules and when to start applying the cooling rules corresponding
+to strictness or context declarations. The configuration serves as a backbone
+for the process of configuration abstraction which allows users to only
+mention the relevant cells in each semantic rule, the rest of the configuration
+context being inferred automatically. Although in some cases the configuration
+could be automatically inferred from the rules, we believe that it is very
+useful for language designers/semanticists to actually think of and design
+their configuration explicitly, so the current implementation of K requires
+one to define it.

+

Values

+ +

We here define the values of the language that the various fragments of
+programs evaluate to. First, integers and Booleans are values. As discussed,
+arrays evaluate to special array reference values holding (1) a location from
+where the array's elements are contiguously allocated in the store, and
+(2) the size of the array. Functions evaluate to function values as
+λ-abstractions (we do not need to evaluate functions to closures
+because each function is executed in the fixed global environment and
+function definitions cannot be nested). Like in IMP and other
+languages, we finally tell the tool that values are K results.

+
  syntax Val ::= Int | Bool | String
+               | array(Int,Int)
+               | lambda(Ids,Stmt)
+  syntax Exp ::= Val
+  syntax Exps ::= Vals
+  syntax Vals ::= Bottoms
+  syntax KResult ::= Val
+                   | Vals  // TODO: should not need this
+

The inclusion of values in expressions follows the methodology of
+syntactic definitions (like, e.g., in SOS): extend the syntax of the language
+to encompass all values and additional constructs needed to give semantics.
+In addition to that, it allows us to write the semantic rules using the
+original syntax of the language, and to parse them with the same (now extended
+with additional values) parser. If writing the semantics directly on the K
+AST, using the associated labels instead of the syntactic constructs, then one
+would not need to include values in expressions.

+

Configuration

+ +

The K configuration of SIMPLE consists of a top level cell, T,
+holding a threads cell, a global environment map cell genv
+mapping the global variables and function names to their locations, a shared
+store map cell store mapping each location to some value, a set cell
+busy holding the locks which have been acquired but not yet released
+by threads, a set cell terminated holding the unique identifiers of
+the threads which already terminated (needed for join), input
+and output list cells, and a nextLoc cell holding a natural
+number indicating the next available location. Unlike in the small languages
+in the K tutorial, where we used the fresh predicate to generate fresh
+locations, in larger languages, like SIMPLE, we prefer to explicitly manage
+memory. The location counter in nextLoc models an actual physical
+location in the store; for simplicity, we assume arbitrarily large memory and
+no garbage collection. The threads cell contains one thread
+cell for each existing thread in the program. Note that the thread cell has
+multiplicity *, which means that at any given moment there could be zero,
+one or more thread cells. Each thread cell contains a
+computation cell k, a control cell holding the various
+control structures needed to jump to certain points of interest in the program
+execution, a local environment map cell env mapping the thread local
+variables to locations in the store, and finally a holds map cell
+indicating what locks have been acquired by the thread and not released so far
+and how many times (SIMPLE's locks are re-entrant). The control cell
+currently contains only two subcells, a function stack fstack which
+is a list and an exception stack xstack which is also a list.
+One can add more control structures in the control cell, such as a
+stack for break/continue of loops, etc., if the language is extended with more
+control-changing constructs. Note that all cells except for k are
+also initialized, in that they contain a ground term of their corresponding
+sort. The k cell is initialized with the program that will be passed
+to the K tool, as indicated by the $PGM variable, followed by the
+execute task (defined shortly).

+
  // the syntax declarations below are required because the sorts are
+  // referenced directly by a production and, because of the way KIL to KORE
+  // is implemented, the configuration syntax is not available yet
+  // should simply work once KIL is removed completely
+  // check other definitions for this hack as well
+
+  syntax ControlCell
+  syntax ControlCellFragment
+
+  configuration <T color="red">
+                  <threads color="orange">
+                    <thread multiplicity="*" type="Map" color="yellow">
+                      <id color="pink"> -1 </id>
+                      <k color="green"> $PGM:Stmt ~> execute </k>
+                    //<br/> // TODO(KORE): support latex annotations #1799
+                      <control color="cyan">
+                        <fstack color="blue"> .List </fstack>
+                        <xstack color="purple"> .List </xstack>
+                      </control>
+                    //<br/> // TODO(KORE): support latex annotations #1799
+                      <env color="violet"> .Map </env>
+                      <holds color="black"> .Map </holds>
+                    </thread>
+                  </threads>
+                //<br/> // TODO(KORE): support latex annotations #1799
+                  <genv color="pink"> .Map </genv>
+                  <store color="white"> .Map </store>
+                  <busy color="cyan"> .Set </busy>
+                  <terminated color="red"> .Set </terminated>
+                //<br/> // TODO(KORE): support latex annotations #1799
+                  <input color="magenta" stream="stdin"> .List </input>
+                  <output color="brown" stream="stdout"> .List </output>
+                  <nextLoc color="gray"> 0 </nextLoc>
+                </T>
+

Declarations and Initialization

+ +

We start by defining the semantics of declarations (for variables,
+arrays and functions).

+

Variable Declaration

+ +

The SIMPLE syntax was desugared above so that each variable is
+declared alone and its initialization is done as a separate statement.
+The semantic rule below matches resulting variable declarations of the
+form var X; on top of the k cell
+(indeed, note that the k cell is complete, or round, to the
+left, and is torn, or ruptured, to the right), allocates a fresh
+location L in the store which is initialized with a special value
+ (indeed, the unit ., or nothing, is matched anywhere
+in the map ‒note the tears at both sides‒ and replaced with the
+mapping L ↦ ⊥), and binds X to L in the local
+environment shadowing previous declarations of X, if any.
+This possible shadowing of X requires us to therefore update the
+entire environment map, which is expensive and can significantly slow
+down the execution of larger programs. On the other hand, since we know
+that L is not already bound in the store, we simply add the binding
+L ↦ ⊥ to the store, thus avoiding a potentially complete
+traversal of the the store map in order to update it. We prefer the approach
+used for updating the store whenever possible, because, in addition to being
+faster, it offers more true concurrency than the latter; indeed, according
+to the concurrent semantics of K, the store is not frozen while
+L ↦ ⊥ is added to it, while the environment is frozen during the
+update operation Env[L/X]. The variable declaration command is
+also removed from the top of the computation cell and the fresh location
+counter is incremented. The undefined symbol added in the store
+is of sort KItem, instead of Val, on purpose; this way, the
+store lookup rules will get stuck when one attempts to lookup an
+uninitialized location. All the above happen in one transactional step,
+with the rule below. Note also how configuration abstraction allows us to
+only mention the needed cells; indeed, as the configuration above states,
+the k and env cells are actually located within a
+thread cell within the threads cell, but one needs
+not mention these: the configuration context of the rule is
+automatically transformed to match the declared configuration
+structure.

+
  syntax KItem ::= "undefined"  [latex(\bot)]
+
+  rule <k> var X:Id; => . ...</k>
+       <env> Env => Env[X <- L] </env>
+       <store>... .Map => L |-> undefined ...</store>
+       <nextLoc> L => L +Int 1 </nextLoc>
+

Array Declaration

+ +

The K semantics of the uni-dimensional array declaration is somehow similar
+to the above declaration of ordinary variables. First, note the
+context declaration below, which requests the evaluation of the array
+dimension. Once evaluated, say to a natural number N, then
+N +Int 1 locations are allocated in the store for
+an array of size N, the additional location (chosen to be the first
+one allocated) holding the array reference value. The array reference
+value array(L,N) states that the array has size N and its
+elements are located contiguously in the store starting with location
+L. The operation L … L' ↦ V, defined at the end of this
+file in the auxiliary operation section, initializes each location in
+the list L … L' to V. Note that, since the dimensions of
+array declarations can be arbitrary expressions, this virtually means
+that we can dynamically allocate memory in SIMPLE by means of array
+declarations.

+
  context var _:Id[HOLE];
+
+  rule <k> var X:Id[N:Int]; => . ...</k>
+       <env> Env => Env[X <- L] </env>
+       <store>... .Map => L |-> array(L +Int 1, N)
+                          (L +Int 1) ... (L +Int N) |-> undefined ...</store>
+       <nextLoc> L => L +Int 1 +Int N </nextLoc>
+    requires N >=Int 0
+

SIMPLE allows multi-dimensional arrays. For semantic simplicity, we
+desugar them all into uni-dimensional arrays by code transformation.
+This way, we only need to give semantics to uni-dimensional arrays.
+First, note that the context rule above actually evaluates all the array
+dimensions (that's why we defined the expression lists strict!):
+Upon evaluating the array dimensions, the code generation rule below
+desugars multi-dimensional array declaration to uni-dimensional declarations.
+To this aim, we introduce two special unique variable identifiers,
+$1 and $2. The first variable, $1, iterates
+through and initializes each element of the first dimension with an array
+of the remaining dimensions, declared as variable $2:

+
  syntax Id ::= "$1" [token] | "$2" [token]
+  rule var X:Id[N1:Int, N2:Int, Vs:Vals];
+    => var X[N1];
+       {
+         for(var $1 = 0; $1 <= N1 - 1; ++$1) {
+           var $2[N2, Vs];
+           X[$1] = $2;
+         }
+       }
+

Ideally, one would like to perform syntactic desugarings like the one
+above before the actual semantics. Unfortunately, that was not possible in
+this case because the dimension expressions of the multi-dimensional array need
+to be evaluated first. Indeed, the desugaring rule above does not work if the
+dimensions of the declared array are arbitrary expressions, because they can
+have side effects (e.g., a[++x,++x]) and those side effects would be
+propagated each time the expression is evaluated in the desugaring code (note
+that both the loop condition and the nested multi-dimensional declaration
+would need to evaluate the expressions given as array dimensions).

+

Function declaration

+ +

Functions are evaluated to λ-abstractions and stored like any other
+values in the store. A binding is added into the environment for the function
+name to the location holding its body. Similarly to the C language, SIMPLE
+only allows function declarations at the top level of the program. More
+precisely, the subsequent semantics of SIMPLE only works well when one
+respects this requirement. Indeed, the simplistic context-free parser
+generated by the grammar above is more generous than we may want, in that it
+allows function declarations anywhere any declaration is allowed, including
+inside arbitrary blocks. However, as the rule below shows, we are not
+storing the declaration environment with the λ-abstraction value as
+closures do. Instead, as seen shortly, we switch to the global environment
+whenever functions are invoked, which is consistent with our requirement that
+functions should only be declared at the top. Thus, if one declares local
+functions, then one may see unexpected behaviors (e.g., when one shadows a
+global variable before declaring a local function). The type checker of
+SIMPLE, also defined in K (see examples/simple/typed/static),
+discards programs which do not respect this requirement.

+
  rule <k> function F(Xs) S => . ...</k>
+       <env> Env => Env[F <- L] </env>
+       <store>... .Map => L |-> lambda(Xs, S) ...</store>
+       <nextLoc> L => L +Int 1 </nextLoc>
+

When we are done with the first pass (pre-processing), the computation
+cell k contains only the token execute (see the configuration
+declaration above, where the computation item execute was placed
+right after the program in the k cell of the initial configuration)
+and the cell genv is empty. In this case, we have to call
+main() and to initialize the global environment by transferring the
+contents of the local environment into it. We prefer to do it this way, as
+opposed to processing all the top level declarations directly within the global
+environment, because we want to avoid duplication of semantics: the syntax of
+the global declarations is identical to that of their corresponding local
+declarations, so the semantics of the latter suffices provided that we copy
+the local environment into the global one once we are done with the
+pre-processing. We want this separate pre-processing step precisely because
+we want to create the global environment. All (top-level) functions end up
+having their names bound in the global environment and, as seen below, they
+are executed in that same global environment; all these mean, in particular,
+that the functions "see" each other, allowing for mutual recursion, etc.

+
  syntax KItem ::= "execute"
+  rule <k> execute => main(.Exps); </k>
+       <env> Env </env>
+       <genv> .Map => Env </genv>
+

Expressions

+ +

We next define the K semantics of all the expression constructs.

+

Variable lookup

+ +

When a variable X is the first computational task, and X is bound to some
+location L in the environment, and L is mapped to some value V in the
+store, then we rewrite X into V:

+
  rule <k> X:Id => V ...</k>
+       <env>... X |-> L ...</env>
+       <store>... L |-> V:Val ...</store>  [group(lookup)]
+

Note that the rule above excludes reading , because is not
+a value and V is checked at runtime to be a value.

+

Variable/Array increment

+ +

This is tricky, because we want to allow both ++x and ++a[5].
+Therefore, we need to extract the lvalue of the expression to increment.
+To do that, we state that the expression to increment should be wrapped
+by the auxiliary lvalue operation and then evaluated. The semantics
+of this auxiliary operation is defined at the end of this file. For now, all
+we need to know is that it takes an expression and evaluates to a location
+value. Location values, also defined at the end of the file, are integers
+wrapped with the operation loc, to distinguish them from ordinary
+integers.

+
  context ++(HOLE => lvalue(HOLE))
+  rule <k> ++loc(L) => I +Int 1 ...</k>
+       <store>... L |-> (I => I +Int 1) ...</store>  [group(increment)]
+

Arithmetic operators

+ +

There is nothing special about the following rules. They rewrite the
+language constructs to their library counterparts when their arguments
+become values of expected sorts:

+
  rule I1 + I2 => I1 +Int I2
+  rule Str1 + Str2 => Str1 +String Str2
+  rule I1 - I2 => I1 -Int I2
+  rule I1 * I2 => I1 *Int I2
+  rule I1 / I2 => I1 /Int I2 requires I2 =/=K 0
+  rule I1 % I2 => I1 %Int I2 requires I2 =/=K 0
+  rule - I => 0 -Int I
+  rule I1 < I2 => I1 <Int I2
+  rule I1 <= I2 => I1 <=Int I2
+  rule I1 > I2 => I1 >Int I2
+  rule I1 >= I2 => I1 >=Int I2
+

The equality and inequality constructs reduce to syntactic comparison
+of the two argument values (which is what the equality on K terms does).

+
  rule V1:Val == V2:Val => V1 ==K V2
+  rule V1:Val != V2:Val => V1 =/=K V2
+

The logical negation is clear, but the logical conjunction and disjunction
+are short-circuited:

+
  rule ! T => notBool(T)
+  rule true  && E => E
+  rule false && _ => false
+  rule true  || _ => true
+  rule false || E => E
+

Array lookup

+ +

Untyped SIMPLE does not check array bounds (the dynamically typed version of
+it, in examples/simple/typed/dynamic, does check for array out of
+bounds). The first rule below desugars the multi-dimensional array access to
+uni-dimensional array access; recall that the array access operation was
+declared strict, so all sub-expressions involved are already values at this
+stage. The second rule rewrites the array access to a lookup operation at a
+precise location; we prefer to do it this way to avoid locking the store.
+The semantics of the auxiliary lookup operation is straightforward,
+and is defined at the end of the file.

+
// The [anywhere] feature is underused, because it would only be used
+// at the top of the computation or inside the lvalue wrapper. So it
+// may not be worth, or we may need to come up with a special notation
+// allowing us to enumerate contexts for [anywhere] rules.
+  rule V:Val[N1:Int, N2:Int, Vs:Vals] => V[N1][N2, Vs]
+    [anywhere]
+
+  rule array(L,_)[N:Int] => lookup(L +Int N)
+    [anywhere]
+

Size of an array

+ +

The size of the array is stored in the array reference value, and the
+sizeOf construct was declared strict, so:

+
  rule sizeOf(array(_,N)) => N
+

Function call

+ +

Function application was strict in both its arguments, so we can
+assume that both the function and its arguments are evaluated to
+values (the former expected to be a λ-abstraction). The first
+rule below matches a well-formed function application on top of the
+computation and performs the following steps atomically: it switches
+to the function body followed by return; (for the case in
+which the function does not use an explicit return statement); it
+pushes the remaining computation, the current environment, and the
+current control data onto the function stack (the remaining
+computation can thus also be discarded from the computation cell,
+because an unavoidable subsequent return statement ‒see
+above‒ will always recover it from the stack); it switches the
+current environment (which is being pushed on the function stack) to
+the global environment, which is where the free variables in the
+function body should be looked up; it binds the formal parameters to
+fresh locations in the new environment, and stores the actual
+arguments to those locations in the store (this latter step is easily
+done by reducing the problem to variable declarations, whose semantics
+we have already defined; the auxiliary operation mkDecls is
+defined at the end of the file). The second rule pops the
+computation, the environment and the control data from the function
+stack when a return statement is encountered as the next
+computational task, passing the returned value to the popped
+computation (the popped computation was the context in which the
+returning function was called). Note that the pushing/popping of the
+control data is crucial. Without it, one may have a function that
+contains an exception block with a return statement inside, which
+would put the xstack cell in an inconsistent state (since the
+exception block modifies it, but that modification should be
+irrelevant once the function returns). We add an artificial
+nothing value to the language, which is returned by the
+nulary return; statements.

+
  syntax KItem ::=  (Map,K,ControlCellFragment)
+
+  rule <k> lambda(Xs,S)(Vs:Vals) ~> K => mkDecls(Xs,Vs) S return; </k>
+       <control>
+         <fstack> .List => ListItem((Env,K,C)) ...</fstack>
+         C
+       </control>
+       <env> Env => GEnv </env>
+       <genv> GEnv </genv>
+
+  rule <k> return(V:Val); ~> _ => V ~> K </k>
+       <control>
+         <fstack> ListItem((Env,K,C)) => .List ...</fstack>
+         (_ => C)
+       </control>
+       <env> _ => Env </env>
+
+  syntax Val ::= "nothing"
+  rule return; => return nothing;
+

Like for division-by-zero, it is left unspecified what happens
+when the nothing value is used in domain calculations. For
+example, from the the perspective of the language semantics,
+7 +Int nothing can evaluate to anything, or
+may not evaluate at all (be undefined). If one wants to make sure that
+such artificial values are never misused, then one needs to define a static
+checker (also using K, like our the type checker in
+examples/simple/typed/static) and reject programs that do.
+Note that, unlike the undefined symbol which had the sort K
+instead of Val, we defined nothing to be a value. That
+is because, as explained above, we do not want the program to get
+stuck when nothing is returned by a function. Instead, we want the
+behavior to be unspecified; in particular, if one is careful to never
+use the returned value in domain computation, like it happens when we
+call a function for its side effects (e.g., with a statement of the
+form f(x);), then the program does not get stuck.

+

Read

+ +

The read() expression construct simply evaluates to the next
+input value, at the same time discarding the input value from the
+in cell.

+
  rule <k> read() => I ...</k> <input> ListItem(I:Int) => .List ...</input>  [group(read)]
+

Assignment

+ +

In SIMPLE, like in C, assignments are expression constructs and not statement
+constructs. To make it a statement all one needs to do is to follow it by a
+semi-colon ; (see the semantics for expression statements below).
+Like for the increment, we want to allow assignments not only to variables but
+also to array elements, e.g., e1[e2] = e3 where e1 evaluates
+to an array reference, e2 to a natural number, and e3 to any
+value. Thus, we first compute the lvalue of the left-hand-side expression
+that appears in an assignment, and then we do the actual assignment to the
+resulting location:

+
  context (HOLE => lvalue(HOLE)) = _
+
+  rule <k> loc(L) = V:Val => V ...</k> <store>... L |-> (_ => V) ...</store>
+    [group(assignment)]
+

Statements

+ +

We next define the K semantics of statements.

+

Blocks

+ +

Empty blocks are simply discarded, as shown in the first rule below.
+For non-empty blocks, we schedule the enclosed statement but we have to
+make sure the environment is recovered after the enclosed statement executes.
+Recall that we allow local variable declarations, whose scope is the block
+enclosing them. That is the reason for which we have to recover the
+environment after the block. This allows us to have a very simple semantics
+for variable declarations, as we did above. One can make the two rules below
+computational if one wants them to count as computational steps.

+
  rule {} => .
+  rule <k> { S } => S ~> setEnv(Env) ...</k>  <env> Env </env>
+

The basic definition of environment recovery is straightforward and
+given in the section on auxiliary constructs at the end of the file.

+

There are two common alternatives to the above semantics of blocks.
+One is to keep track of the variables which are declared in the block and only
+recover those at the end of the block. This way one does more work for
+variable declarations but conceptually less work for environment recovery; we
+say conceptually because it is not clear that it is indeed the case that
+one does less work when AC matching is involved. The other alternative is to
+work with a stack of environments instead of a flat environment, and push the
+current environment when entering a block and pop it when exiting it. This
+way, one does more work when accessing variables (since one has to search the
+variable in the environment stack in a top-down manner), but on the other hand
+uses smaller environments and the definition gets closer to an implementation.
+Based on experience with dozens of language semantics and other K definitions,
+we have found that our approach above is the best trade-off between elegance
+and efficiency (especially since rewrite engines have built-in techniques to
+lazily copy terms, by need, thus not creating unnecessary copies),
+so it is the one that we follow in general.

+

Sequential composition

+ +

Sequential composition is desugared into K's builtin sequentialization
+operation (recall that, like in C, the semi-colon ; is not a
+statement separator in SIMPLE — it is either a statement terminator or a
+construct for a statement from an expression). Note that K allows
+to define the semantics of SIMPLE in such a way that statements eventually
+dissolve from the top of the computation when they are completed; this is in
+sharp contrast to (artificially) evaluating them to a special
+skip statement value and then getting rid of that special value, as
+it is the case in other semantic approaches (where everything must evaluate
+to something). This means that once S₁ completes in the rule below, S₂
+becomes automatically the next computation item without any additional
+(explicit or implicit) rules.

+
  rule S1:Stmt S2:Stmt => S1 ~> S2
+

A subtle aspect of the rule above is that S₁ is declared to have sort
+Stmts and not Stmt. That is because desugaring macros can indeed
+produce left associative sequential composition of statements. For example,
+the code var x=0; x=1; is desugared to
+(var x; x=0;) x=1;, so although originally the first term of
+the sequential composition had sort Stmt, after desugaring it became
+of sort Stmts. Note that the attribute [right] associated
+to the sequential compositon production is an attribute of the syntax, and not
+of the semantics: e.g., it tells the parser to parse
+var x; x=0; x=1; as var x; (x=0; x=1;), but it
+does not tell the rewrite engine to rewrite (var x; x=0;) x=1; to
+var x; (x=0; x=1;).

+

Expression statements

+ +

Expression statements are only used for their side effects, so their result
+value is simply discarded. Common examples of expression statements are ones
+of the form ++x;, x=e;, e1[e2]=e3;, etc.

+
  rule _:Val; => .
+

Conditional

+ +

Since the conditional was declared with the strict(1) attribute, we
+can assume that its first argument will eventually be evaluated. The rules
+below cover the only two possibilities in which the conditional is allowed to
+proceed (otherwise the rewriting process gets stuck).

+
  rule if ( true) S else _ => S
+  rule if (false) _ else S => S
+

While loop

+ +

The simplest way to give the semantics of the while loop is by unrolling.
+Note, however, that its unrolling is only allowed when the while loop reaches
+the top of the computation (to avoid non-termination of unrolling). The
+simple while loop semantics below works because our while loops in SIMPLE are
+indeed very basic. If we allowed break/continue of loops then we would need
+a completely different semantics, which would also involve the control cell.

+
  rule while (E) S => if (E) {S while(E)S}
+

Print

+ +

The print statement was strict, so all its arguments are now
+evaluated (recall that print is variadic). We append each of
+its evaluated arguments to the output buffer, and discard the residual
+print statement with an empty list of arguments.

+
  rule <k> print(V:Val, Es => Es); ...</k> <output>... .List => ListItem(V) </output>
+    [group(print)]
+  rule print(.Vals); => .
+

Exceptions

+ +

SIMPLE allows parametric exceptions, in that one can throw and catch a
+particular value. The statement try S₁ catch(X) S₂
+proceeds with the evaluation of S₁. If S₁ evaluates normally, i.e.,
+without any exception thrown, then S₂ is discarded and the execution
+continues normally. If S₁ throws an exception with a statement of the
+form throw E, then E is first evaluated to some value V
+(throw was declared to be strict), then V is bound to X, then
+S₂ is evaluated in the new environment while the reminder of S₁ is
+discarded, then the environment is recovered and the execution continues
+normally with the statement following the try S₁ catch(X) S₂ statement.
+Exceptions can be nested and the statements in the
+catch part (S₂ in our case) can throw exceptions to the
+upper level. One should be careful with how one handles the control data
+structures here, so that the abrupt changes of control due to exception
+throwing and to function returns interact correctly with each other.
+For example, we want to allow function calls inside the statement S₁ in
+a try S₁ catch(X) S₂ block which can throw an exception
+that is not caught by the function but instead is propagated to the
+try S₁ catch(X) S₂ block that called the function.
+Therefore, we have to make sure that the function stack as well as other
+potential control structures are also properly modified when the exception
+is thrown to correctly recover the execution context. This can be easily
+achieved by pushing/popping the entire current control context onto the
+exception stack. The three rules below modularly do precisely the above.

+
  syntax KItem ::= (Id,Stmt,K,Map,ControlCellFragment)
+
+  syntax KItem ::= "popx"
+
+  rule <k> (try S1 catch(X) {S2} => S1 ~> popx) ~> K </k>
+       <control>
+         <xstack> .List => ListItem((X, S2, K, Env, C)) ...</xstack>
+         C
+       </control>
+       <env> Env </env>
+
+  rule <k> popx => . ...</k>
+       <xstack> ListItem(_) => .List ...</xstack>
+
+  rule <k> throw V:Val; ~> _ => { var X = V; S2 } ~> K </k>
+       <control>
+         <xstack> ListItem((X, S2, K, Env, C)) => .List ...</xstack>
+         (_ => C)
+       </control>
+       <env> _ => Env </env>
+

The catch statement S₂ needs to be executed in the original environment,
+but where the thrown value V is bound to the catch variable X. We here
+chose to rely on two previously defined constructs when giving semantics to
+the catch part of the statement: (1) the variable declaration with
+initialization, for binding X to V; and (2) the block construct for
+preventing X from shadowing variables in the original environment upon the
+completion of S₂.

+

Threads

+ +

SIMPLE's threads can be created and terminated dynamically, and can
+synchronize by acquiring and releasing re-entrant locks and by rendezvous.
+We discuss the seven rules giving the semantics of these operations below.

+

Thread creation

+ +

Threads can be created by any other threads using the spawn S
+construct. The spawn expression construct evaluates to the unique identifier
+of the newly created thread and, at the same time, a new thread cell is added
+into the configuration, initialized with the S statement and sharing the
+same environment with the parent thread. Note that the newly created
+thread cell is torn. That means that the remaining cells are added
+and initialized automatically as described in the definition of SIMPLE's
+configuration. This is part of K's configuration abstraction mechanism.

+
  rule <thread>...
+         <k> spawn S => !T:Int ...</k>
+         <env> Env </env>
+       ...</thread>
+       (.Bag => <thread>...
+               <k> S </k>
+               <env> Env </env>
+               <id> !T </id>
+             ...</thread>)
+

Thread termination

+ +

Dually to the above, when a thread terminates its assigned computation (the
+contents of its k cell) is empty, so the thread can be dissolved.
+However, since no discipline is imposed on how locks are acquired and released,
+it can be the case that a terminating thread still holds locks. Those locks
+must be released, so other threads attempting to acquire them do not deadlock.
+We achieve that by removing all the locks held by the terminating thread in its
+holds cell from the set of busy locks in the busy cell
+(keys(H) returns the domain of the map H as a set, that is, only
+the locks themselves ignoring their multiplicity). As seen below, a lock is
+added to the busy cell as soon as it is acquired for the first time
+by a thread. The unique identifier of the terminated thread is also collected
+into the terminated cell, so the join construct knows which
+threads have terminated.

+
  rule (<thread>... <k>.</k> <holds>H</holds> <id>T</id> ...</thread> => .Bag)
+       <busy> Busy => Busy -Set keys(H) </busy>
+       <terminated>... .Set => SetItem(T) ...</terminated>
+

Thread joining

+ +

Thread joining is now straightforward: all we need to do is to check whether
+the identifier of the thread to be joined is in the terminated cell.
+If yes, then the join statement dissolves and the joining thread
+continues normally; if not, then the joining thread gets stuck.

+
  rule <k> join T:Int; => . ...</k>
+       <terminated>... SetItem(T) ...</terminated>
+

Acquire lock

+ +

There are two cases to distinguish when a thread attempts to acquire a lock
+(in SIMPLE any value can be used as a lock):
+(1) The thread does not currently have the lock, in which case it has to
+take it provided that the lock is not already taken by another thread (see
+the side condition of the first rule).
+(2) The thread already has the lock, in which case it just increments its
+counter for the lock (the locks are re-entrant). These two cases are captured
+by the two rules below:

+
  rule <k> acquire V:Val; => . ...</k>
+       <holds>... .Map => V |-> 0 ...</holds>
+       <busy> Busy (.Set => SetItem(V)) </busy>
+    requires (notBool(V in Busy))  [group(acquire)]
+
+  rule <k> acquire V; => . ...</k>
+       <holds>... V:Val |-> (N => N +Int 1) ...</holds>
+

Release lock

+ +

Similarly, there are two corresponding cases to distinguish when a thread
+releases a lock:
+(1) The thread holds the lock more than once, in which case all it needs to do
+is to decrement the lock counter.
+(2) The thread holds the lock only once, in which case it needs to remove it
+from its holds cell and also from the the shared busy cell,
+so other threads can acquire it if they need to.

+
  rule <k> release V:Val; => . ...</k>
+       <holds>... V |-> (N => N -Int 1) ...</holds>
+    requires N >Int 0
+
+  rule <k> release V; => . ...</k> <holds>... V:Val |-> 0 => .Map ...</holds>
+       <busy>... SetItem(V) => .Set ...</busy>
+

Rendezvous synchronization

+ +

In addition to synchronization through acquire and release of locks, SIMPLE
+also provides a construct for rendezvous synchronization. A thread whose next
+statement to execute is rendezvous(V) gets stuck until another
+thread reaches an identical statement; when that happens, the two threads
+drop their rendezvous statements and continue their executions. If three
+threads happen to have an identical rendezvous statement as their next
+statement, then precisely two of them will synchronize and the other will
+remain blocked until another thread reaches a similar rendezvous statement.
+The rule below is as simple as it can be. Note, however, that, again, it is
+K's mechanism for configuration abstraction that makes it work as desired:
+since the only cell which can multiply containing a k cell inside is
+the thread cell, the only way to concretize the rule below to the
+actual configuration of SIMPLE is to include each k cell in a
+thread cell.

+
  rule <k> rendezvous V:Val; => . ...</k>
+       <k> rendezvous V; => . ...</k>  [group(rendezvous)]
+

Auxiliary declarations and operations

+ +

In this section we define all the auxiliary constructs used in the
+above semantics.

+

Making declarations

+ +

The mkDecls auxiliary construct turns a list of identifiers
+and a list of values in a sequence of corresponding variable
+declarations.

+
  syntax Stmt ::= mkDecls(Ids,Vals)  [function]
+  rule mkDecls((X:Id, Xs:Ids), (V:Val, Vs:Vals)) => var X=V; mkDecls(Xs,Vs)
+  rule mkDecls(.Ids,.Vals) => {}
+

Location lookup

+ +

The operation below is straightforward. Note that we place it in the same
+lookup group as the variable lookup rule defined above. This way,
+both rules will be considered transitions when we include the lookup
+tag in the transition option of kompile.

+
  syntax Exp ::= lookup(Int)
+  rule <k> lookup(L) => V ...</k> <store>... L |-> V:Val ...</store>  [group(lookup)]
+

Environment recovery

+ +

We have already discussed the environment recovery auxiliary operation in the
+IMP++ tutorial:

+
// TODO: eliminate the env wrapper, like we did in IMP++
+
+  syntax KItem ::= setEnv(Map)
+  rule <k> setEnv(Env) => . ...</k> <env> _ => Env </env>
+

While theoretically sufficient, the basic definition for environment
+recovery alone is suboptimal. Consider a loop while (E)S,
+whose semantics (see above) was given by unrolling. S
+is a block. Then the semantics of blocks above, together with the
+unrolling semantics of the while loop, will yield a computation
+structure in the k cell that increasingly grows, adding a new
+environment recovery task right in front of the already existing sequence of
+similar environment recovery tasks (this phenomenon is similar to the ``tail
+recursion'' problem). Of course, when we have a sequence of environment
+recovery tasks, we only need to keep the last one. The elegant rule below
+does precisely that, thus avoiding the unnecessary computation explosion
+problem:

+
  rule (setEnv(_) => .) ~> setEnv(_)
+

In fact, the above follows a common convention in K for recovery
+operations of cell contents: the meaning of a computation task of the form
+cell(C) that reaches the top of the computation is that the current
+contents of cell cell is discarded and gets replaced with C. We
+did not add support for these special computation tasks in our current
+implementation of K, so we need to define them as above.

+

lvalue and loc

+ +

For convenience in giving the semantics of constructs like the increment and
+the assignment, that we want to operate the same way on variables and on
+array elements, we used an auxiliary lvalue(E) construct which was
+expected to evaluate to the lvalue of the expression E. This is only
+defined when E has an lvalue, that is, when E is either a variable or
+evaluates to an array element. lvalue(E) evaluates to a value of
+the form loc(L), where L is the location where the value of E
+can be found; for clarity, we use loc to structurally distinguish
+natural numbers from location values. In giving semantics to lvalue
+there are two cases to consider. (1) If E is a variable, then all we need
+to do is to grab its location from the environment. (2) If E is an array
+element, then we first evaluate the array and its index in order to identify
+the exact location of the element of concern, and then return that location;
+the last rule below works because its preceding context declarations ensure
+that the array and its index are evaluated, and then the rule for array lookup
+(defined above) rewrites the evaluated array access construct to its
+corresponding store lookup operation.

+
// For parsing reasons, we prefer to allow lvalue to take a K
+
+  syntax Exp ::= lvalue(K)
+  syntax Val ::= loc(Int)
+
+// Local variable
+
+  rule <k> lvalue(X:Id => loc(L)) ...</k> <env>... X |-> L:Int ...</env>
+
+// Array element: evaluate the array and its index;
+// then the array lookup rule above applies.
+
+  context lvalue(_::Exp[HOLE::Exps])
+  context lvalue(HOLE::Exp[_::Exps])
+
+// Finally, return the address of the desired object member
+
+  rule lvalue(lookup(L:Int) => loc(L))
+

Initializing multiple locations

+ +

The following operation initializes a sequence of locations with the same
+value:

+
  syntax Map ::= Int "..." Int "|->" K
+    [function, latex({#1}\ldots{#2}\mapsto{#3})]
+  rule N...M |-> _ => .Map  requires N >Int M
+  rule N...M |-> K => N |-> K (N +Int 1)...M |-> K  requires N <=Int M
+

The semantics of SIMPLE is now complete. Make sure you kompile the
+definition with the right options in order to generate the desired model.
+No kompile options are needed if you only only want to execute the definition
+(and thus get an interpreter), but if you want to search for a different
+program behaviors then you need to kompile with the transition option
+including rule groups such as lookup, increment, acquire, etc. See the
+IMP++ tutorial for what the transition option means how to use it.

+
endmodule
+

Go to Lesson 2, SIMPLE typed static

+

SIMPLE — Untyped

+ +

Author: Grigore Roșu (grosu@illinois.edu)
+Organization: University of Illinois at Urbana-Champaign

+

Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
+Organization: University of Bucharest

+

Abstract

+ +

This is the K semantic definition of the untyped SIMPLE language.
+SIMPLE is intended to be a pedagogical and research language that captures
+the essence of the imperative programming paradigm, extended with several
+features often encountered in imperative programming languages.
+A program consists of a set of global variable declarations and
+function definitions. Like in C, function definitions cannot be
+nested and each program must have one function called main,
+which is invoked when the program is executed. To make it more
+interesting and to highlight some of K's strengths, SIMPLE includes
+the following features in addition to the conventional imperative
+expression and statement constructs:

+
    +
  • +

    Multidimensional arrays and array references. An array evaluates
    +to an array reference, which is a special value holding a location (where
    +the elements of the array start) together with the size of the array;
    +the elements of the array can be array references themselves (particularly
    +when the array is multi-dimensional). Array references are ordinary values,
    +so they can be assigned to variables and passed/received by functions.

    +
  • +
  • +

    Functions and function values. Functions can have zero or
    +more parameters and can return abruptly using a return statement.
    +SIMPLE follows a call-by-value parameter passing style, with static scoping.
    +Function names evaluate to function abstractions, which hereby become ordinary
    +values in the language, same like the array references.

    +
  • +
  • +

    Blocks with locals. SIMPLE variables can be declared
    +anywhere, their scope being from the place where they are declared
    +until the end of the most nested enclosing block.

    +
  • +
  • +

    Input/Output. The expression read() evaluates to the
    +next value in the input buffer, and the statement write(e)
    +evaluates e and outputs its value to the output buffer. The
    +input and output buffers are lists of values.

    +
  • +
  • +

    Exceptions. SIMPLE has parametric exceptions (the value thrown as
    +an exception can be caught and bound).

    +
  • +
  • +

    Concurrency via dynamic thread creation/termination and
    +synchronization. One can spawn a thread to execute any statement.
    +The spawned thread shares with its parent its environment at creation time.
    +Threads can be synchronized via a join command which blocks the current thread
    +until the joined thread completes, via re-entrant locks which can be acquired
    +and released, as well as through rendezvous commands.

    +
  • +
+

Like in many other languages, some of SIMPLE's constructs can be
+desugared into a smaller set of basic constructs. We do that at the end
+of the syntax module, and then we only give semantics to the core constructs.

+

Note: This definition is commented slightly more than others, because it is
+intended to be one of the first non-trivial definitions that the new
+user of K sees. We recommend the beginner user to first check the
+language definitions discussed in the K tutorial.

+
module SIMPLE-UNTYPED-SYNTAX
+  imports DOMAINS-SYNTAX
+

Syntax

+ +

We start by defining the SIMPLE syntax. The language constructs discussed
+above have the expected syntax and evaluation strategies. Recall that in K
+we annotate the syntax with appropriate strictness attributes, thus giving
+each language construct the desired evaluation strategy.

+

Identifiers

+ +

Recall from the K tutorial that identifiers are builtin and come under the
+syntactic category Id. The special identifier for the function
+main belongs to all programs, and plays a special role in the semantics,
+so we declare it explicitly. This would not be necessary if the identifiers
+were all included automatically in semantic definitions, but that is not
+possible because of parsing reasons (e.g., K variables used to match
+concrete identifiers would then be ambiguously parsed as identifiers). They
+are only included in the parser generated to parse programs (and used by the
+kast tool). Consequently, we have to explicitly declare all the
+concrete identifiers that play a special role in the semantics, like
+main below.

+
  syntax Id ::= "main" [token]
+

Declarations

+ +

There are two types of declarations: for variables (including arrays) and
+for functions. We are going to allow declarations of the form
+var x=10, a[10,10], y=23;, which is why we allow the var
+keyword to take a list of expressions. The non-terminals used in the two
+productions below are defined shortly.

+
  syntax Stmt ::= "var" Exps ";"
+                | "function" Id "(" Ids ")" Block
+

Expressions

+ +

The expression constructs below are standard. Increment (++) takes
+an expression rather than a variable because it can also increment an array
+element. Recall that the syntax we define in K is what we call the syntax
+of the semantics
: while powerful enough to define non-trivial syntaxes
+(thanks to the underlying SDF technology that we use), we typically refrain
+from defining precise syntaxes, that is, ones which accept precisely the
+well-formed programs (that would not be possible anyway in general). That job
+is deferred to type systems, which can also be defined in K. In other words,
+we are not making any effort to guarantee syntactically that only variables
+or array elements are passed to the increment construct, we allow any
+expression. Nevertheless, we will only give semantics to those, so expressions
+of the form ++5, which parse (but which will be rejected by our type
+system in the typed version of SIMPLE later), will get stuck when executed.
+Arrays can be multidimensional and can hold other arrays, so their
+lookup operation takes a list of expressions as argument and applies to an
+expression (which can in particular be another array lookup), respectively.
+The construct sizeOf gives the size of an array in number of elements
+of its first dimension. Note that almost all constructs are strict. The only
+constructs which are not strict are the increment (since its first argument
+gets updated, so it cannot be evaluated), the input read which takes no
+arguments so strictness is irrelevant for it, the logical and and or constructs
+which are short-circuited, the thread spawning construct which creates a new
+thread executing the argument expression and return its unique identifier to
+the creating thread (so it cannot just evaluate its argument in place), and the
+assignment which is only strict in its second argument (for the same reason as
+the increment).

+
  syntax Exp ::= Int | Bool | String | Id
+               | "(" Exp ")"             [bracket]
+               | "++" Exp
+               > Exp "[" Exps "]"        [strict]
+               > Exp "(" Exps ")"        [strict]
+               | "-" Exp                 [strict]
+               | "sizeOf" "(" Exp ")"    [strict]
+               | "read" "(" ")"
+               > left:
+                 Exp "*" Exp             [strict, left]
+               | Exp "/" Exp             [strict, left]
+               | Exp "%" Exp             [strict, left]
+               > left:
+                 Exp "+" Exp             [strict, left]
+               | Exp "-" Exp             [strict, left]
+               > non-assoc:
+                 Exp "<" Exp             [strict, non-assoc]
+               | Exp "<=" Exp            [strict, non-assoc]
+               | Exp ">" Exp             [strict, non-assoc]
+               | Exp ">=" Exp            [strict, non-assoc]
+               | Exp "==" Exp            [strict, non-assoc]
+               | Exp "!=" Exp            [strict, non-assoc]
+               > "!" Exp                 [strict]
+               > left:
+                 Exp "&&" Exp            [strict(1), left]
+               | Exp "||" Exp            [strict(1), left]
+               > "spawn" Block
+               > Exp "=" Exp             [strict(2), right]
+

We also need comma-separated lists of identifiers and of expressions.
+Moreover, we want them to be strict, that is, to evaluate to lists of results
+whenever requested (e.g., when they appear as strict arguments of
+the constructs above).

+
  syntax Ids  ::= List{Id,","}           [klabel(Exps)]
+  syntax Exps ::= List{Exp,","}          [klabel(Exps), strict]  // automatically hybrid now
+  syntax Exps ::= Ids
+  syntax Val
+  syntax Vals ::= List{Val,","}          [klabel(Exps)]
+  syntax Bottom
+  syntax Bottoms ::= List{Bottom,","}    [klabel(Exps)]
+  syntax Ids ::= Bottoms
+

Statements

+ +

Most of the statement constructs are standard for imperative languages.
+We syntactically distinguish between empty and non-empty blocks, because we
+chose Stmts not to be a (;-separated) list of
+Stmt. Variables can be declared anywhere inside a block, their scope
+ending with the block. Expressions are allowed to be used for their side
+effects only (followed by a semicolon ;). Functions are allowed
+to abruptly return. The exceptions are parametric, i.e., one can throw a value
+which is bound to the variable declared by catch. Threads can be
+dynamically created and terminated, and can synchronize with join,
+acquire, release and rendezvous. Note that the
+strictness attributes obey the intended evaluation strategy of the various
+constructs. In particular, the if-then-else construct is strict only in its
+first argument (the if-then construct will be desugared into if-then-else),
+while the loop constructs are not strict in any arguments. The print
+statement construct is variadic, that is, it takes an arbitrary number of
+arguments.

+
  syntax Block ::= "{" "}"
+                | "{" Stmt "}"
+
+  syntax Stmt ::= Block
+                | Exp ";"                               [strict]
+                | "if" "(" Exp ")" Block "else" Block   [avoid, strict(1)]
+                | "if" "(" Exp ")" Block                [macro]
+                | "while" "(" Exp ")" Block
+                | "for" "(" Stmt Exp ";" Exp ")" Block  [macro]
+                | "return" Exp ";"                      [strict]
+                | "return" ";"                          [macro]
+                | "print" "(" Exps ")" ";"              [strict]
+// NOTE: print strict allows non-deterministic evaluation of its arguments
+// Either keep like this but document, or otherwise make Exps seqstrict.
+// Of define and use a different expression list here, which is seqstrict.
+                | "try" Block "catch" "(" Id ")" Block
+                | "throw" Exp ";"                       [strict]
+                | "join" Exp ";"                        [strict]
+                | "acquire" Exp ";"                     [strict]
+                | "release" Exp ";"                     [strict]
+                | "rendezvous" Exp ";"                  [strict]
+

The reason we allow Stmts as the first argument of for
+instead of Stmt is because we want to allow more than one statement
+to be executed when the loop is initialized. Also, as seens shorly, macros
+may expand one statement into more statements; for example, an initialized
+variable declaration statement var x=0; desugars into two statements,
+namely var x; x=0;, so if we use Stmt instead of Stmts
+in the production of for above then we risk that the macro expansion
+of statement var x=0; happens before the macro expansion of for,
+also shown below, in which case the latter would not apply anymore because
+of syntactic mismatch.

+
  syntax Stmt ::= Stmt Stmt                          [right]
+
+// I wish I were able to write the following instead, but confuses the parser.
+//
+// syntax Stmts ::= List{Stmt,""}
+// syntax Top ::= Stmt | "function" Id "(" Ids ")" Block
+// syntax Pgm ::= List{Top,""}
+//
+// With that, I could have also eliminated the empty block
+

Desugared Syntax

+ +

This part desugars some of SIMPLE's language constructs into core ones.
+We only want to give semantics to core constructs, so we get rid of the
+derived ones before we start the semantics. All desugaring macros below are
+straightforward.

+
  rule if (E) S => if (E) S else {}
+  rule for(Start Cond; Step) {S} => {Start while (Cond) {S Step;}}
+  rule for(Start Cond; Step) {} => {Start while (Cond) {Step;}}
+  rule var E1:Exp, E2:Exp, Es:Exps; => var E1; var E2, Es;
+  rule var X:Id = E; => var X; X = E;
+

For the semantics, we can therefore assume from now on that each
+conditional has both branches, that there are only while loops, and
+that each variable is declared alone and without any initialization as part of
+the declaration.

+
endmodule
+
+
+module SIMPLE-UNTYPED
+  imports SIMPLE-UNTYPED-SYNTAX
+  imports DOMAINS
+

Basic Semantic Infrastructure

+ +

Before one starts adding semantic rules to a K definition, one needs to
+define the basic semantic infrastructure consisting of definitions for
+values and configuration. As discussed in the definitions
+in the K tutorial, the values are needed to know when to stop applying
+the heating rules and when to start applying the cooling rules corresponding
+to strictness or context declarations. The configuration serves as a backbone
+for the process of configuration abstraction which allows users to only
+mention the relevant cells in each semantic rule, the rest of the configuration
+context being inferred automatically. Although in some cases the configuration
+could be automatically inferred from the rules, we believe that it is very
+useful for language designers/semanticists to actually think of and design
+their configuration explicitly, so the current implementation of K requires
+one to define it.

+

Values

+ +

We here define the values of the language that the various fragments of
+programs evaluate to. First, integers and Booleans are values. As discussed,
+arrays evaluate to special array reference values holding (1) a location from
+where the array's elements are contiguously allocated in the store, and
+(2) the size of the array. Functions evaluate to function values as
+λ-abstractions (we do not need to evaluate functions to closures
+because each function is executed in the fixed global environment and
+function definitions cannot be nested). Like in IMP and other
+languages, we finally tell the tool that values are K results.

+
  syntax Val ::= Int | Bool | String
+               | array(Int,Int)
+               | lambda(Ids,Stmt)
+  syntax Exp ::= Val
+  syntax Exps ::= Vals
+  syntax Vals ::= Bottoms
+  syntax KResult ::= Val
+                   | Vals  // TODO: should not need this
+

The inclusion of values in expressions follows the methodology of
+syntactic definitions (like, e.g., in SOS): extend the syntax of the language
+to encompass all values and additional constructs needed to give semantics.
+In addition to that, it allows us to write the semantic rules using the
+original syntax of the language, and to parse them with the same (now extended
+with additional values) parser. If writing the semantics directly on the K
+AST, using the associated labels instead of the syntactic constructs, then one
+would not need to include values in expressions.

+

Configuration

+ +

The K configuration of SIMPLE consists of a top level cell, T,
+holding a threads cell, a global environment map cell genv
+mapping the global variables and function names to their locations, a shared
+store map cell store mapping each location to some value, a set cell
+busy holding the locks which have been acquired but not yet released
+by threads, a set cell terminated holding the unique identifiers of
+the threads which already terminated (needed for join), input
+and output list cells, and a nextLoc cell holding a natural
+number indicating the next available location. Unlike in the small languages
+in the K tutorial, where we used the fresh predicate to generate fresh
+locations, in larger languages, like SIMPLE, we prefer to explicitly manage
+memory. The location counter in nextLoc models an actual physical
+location in the store; for simplicity, we assume arbitrarily large memory and
+no garbage collection. The threads cell contains one thread
+cell for each existing thread in the program. Note that the thread cell has
+multiplicity *, which means that at any given moment there could be zero,
+one or more thread cells. Each thread cell contains a
+computation cell k, a control cell holding the various
+control structures needed to jump to certain points of interest in the program
+execution, a local environment map cell env mapping the thread local
+variables to locations in the store, and finally a holds map cell
+indicating what locks have been acquired by the thread and not released so far
+and how many times (SIMPLE's locks are re-entrant). The control cell
+currently contains only two subcells, a function stack fstack which
+is a list and an exception stack xstack which is also a list.
+One can add more control structures in the control cell, such as a
+stack for break/continue of loops, etc., if the language is extended with more
+control-changing constructs. Note that all cells except for k are
+also initialized, in that they contain a ground term of their corresponding
+sort. The k cell is initialized with the program that will be passed
+to the K tool, as indicated by the $PGM variable, followed by the
+execute task (defined shortly).

+
  // the syntax declarations below are required because the sorts are
+  // referenced directly by a production and, because of the way KIL to KORE
+  // is implemented, the configuration syntax is not available yet
+  // should simply work once KIL is removed completely
+  // check other definitions for this hack as well
+
+  syntax ControlCell
+  syntax ControlCellFragment
+
+  configuration <T color="red">
+                  <threads color="orange">
+                    <thread multiplicity="*" type="Map" color="yellow">
+                      <id color="pink"> -1 </id>
+                      <k color="green"> $PGM:Stmt ~> execute </k>
+                    //<br/> // TODO(KORE): support latex annotations #1799
+                      <control color="cyan">
+                        <fstack color="blue"> .List </fstack>
+                        <xstack color="purple"> .List </xstack>
+                      </control>
+                    //<br/> // TODO(KORE): support latex annotations #1799
+                      <env color="violet"> .Map </env>
+                      <holds color="black"> .Map </holds>
+                    </thread>
+                  </threads>
+                //<br/> // TODO(KORE): support latex annotations #1799
+                  <genv color="pink"> .Map </genv>
+                  <store color="white"> .Map </store>
+                  <busy color="cyan"> .Set </busy>
+                  <terminated color="red"> .Set </terminated>
+                //<br/> // TODO(KORE): support latex annotations #1799
+                  <input color="magenta" stream="stdin"> .List </input>
+                  <output color="brown" stream="stdout"> .List </output>
+                  <nextLoc color="gray"> 0 </nextLoc>
+                </T>
+

Declarations and Initialization

+ +

We start by defining the semantics of declarations (for variables,
+arrays and functions).

+

Variable Declaration

+ +

The SIMPLE syntax was desugared above so that each variable is
+declared alone and its initialization is done as a separate statement.
+The semantic rule below matches resulting variable declarations of the
+form var X; on top of the k cell
+(indeed, note that the k cell is complete, or round, to the
+left, and is torn, or ruptured, to the right), allocates a fresh
+location L in the store which is initialized with a special value
+ (indeed, the unit ., or nothing, is matched anywhere
+in the map ‒note the tears at both sides‒ and replaced with the
+mapping L ↦ ⊥), and binds X to L in the local
+environment shadowing previous declarations of X, if any.
+This possible shadowing of X requires us to therefore update the
+entire environment map, which is expensive and can significantly slow
+down the execution of larger programs. On the other hand, since we know
+that L is not already bound in the store, we simply add the binding
+L ↦ ⊥ to the store, thus avoiding a potentially complete
+traversal of the the store map in order to update it. We prefer the approach
+used for updating the store whenever possible, because, in addition to being
+faster, it offers more true concurrency than the latter; indeed, according
+to the concurrent semantics of K, the store is not frozen while
+L ↦ ⊥ is added to it, while the environment is frozen during the
+update operation Env[L/X]. The variable declaration command is
+also removed from the top of the computation cell and the fresh location
+counter is incremented. The undefined symbol added in the store
+is of sort KItem, instead of Val, on purpose; this way, the
+store lookup rules will get stuck when one attempts to lookup an
+uninitialized location. All the above happen in one transactional step,
+with the rule below. Note also how configuration abstraction allows us to
+only mention the needed cells; indeed, as the configuration above states,
+the k and env cells are actually located within a
+thread cell within the threads cell, but one needs
+not mention these: the configuration context of the rule is
+automatically transformed to match the declared configuration
+structure.

+
  syntax KItem ::= "undefined"  [latex(\bot)]
+
+  rule <k> var X:Id; => . ...</k>
+       <env> Env => Env[X <- L] </env>
+       <store>... .Map => L |-> undefined ...</store>
+       <nextLoc> L => L +Int 1 </nextLoc>
+

Array Declaration

+ +

The K semantics of the uni-dimensional array declaration is somehow similar
+to the above declaration of ordinary variables. First, note the
+context declaration below, which requests the evaluation of the array
+dimension. Once evaluated, say to a natural number N, then
+N +Int 1 locations are allocated in the store for
+an array of size N, the additional location (chosen to be the first
+one allocated) holding the array reference value. The array reference
+value array(L,N) states that the array has size N and its
+elements are located contiguously in the store starting with location
+L. The operation L … L' ↦ V, defined at the end of this
+file in the auxiliary operation section, initializes each location in
+the list L … L' to V. Note that, since the dimensions of
+array declarations can be arbitrary expressions, this virtually means
+that we can dynamically allocate memory in SIMPLE by means of array
+declarations.

+
  context var _:Id[HOLE];
+
+  rule <k> var X:Id[N:Int]; => . ...</k>
+       <env> Env => Env[X <- L] </env>
+       <store>... .Map => L |-> array(L +Int 1, N)
+                          (L +Int 1) ... (L +Int N) |-> undefined ...</store>
+       <nextLoc> L => L +Int 1 +Int N </nextLoc>
+    requires N >=Int 0
+

SIMPLE allows multi-dimensional arrays. For semantic simplicity, we
+desugar them all into uni-dimensional arrays by code transformation.
+This way, we only need to give semantics to uni-dimensional arrays.
+First, note that the context rule above actually evaluates all the array
+dimensions (that's why we defined the expression lists strict!):
+Upon evaluating the array dimensions, the code generation rule below
+desugars multi-dimensional array declaration to uni-dimensional declarations.
+To this aim, we introduce two special unique variable identifiers,
+$1 and $2. The first variable, $1, iterates
+through and initializes each element of the first dimension with an array
+of the remaining dimensions, declared as variable $2:

+
  syntax Id ::= "$1" [token] | "$2" [token]
+  rule var X:Id[N1:Int, N2:Int, Vs:Vals];
+    => var X[N1];
+       {
+         for(var $1 = 0; $1 <= N1 - 1; ++$1) {
+           var $2[N2, Vs];
+           X[$1] = $2;
+         }
+       }
+

Ideally, one would like to perform syntactic desugarings like the one
+above before the actual semantics. Unfortunately, that was not possible in
+this case because the dimension expressions of the multi-dimensional array need
+to be evaluated first. Indeed, the desugaring rule above does not work if the
+dimensions of the declared array are arbitrary expressions, because they can
+have side effects (e.g., a[++x,++x]) and those side effects would be
+propagated each time the expression is evaluated in the desugaring code (note
+that both the loop condition and the nested multi-dimensional declaration
+would need to evaluate the expressions given as array dimensions).

+

Function declaration

+ +

Functions are evaluated to λ-abstractions and stored like any other
+values in the store. A binding is added into the environment for the function
+name to the location holding its body. Similarly to the C language, SIMPLE
+only allows function declarations at the top level of the program. More
+precisely, the subsequent semantics of SIMPLE only works well when one
+respects this requirement. Indeed, the simplistic context-free parser
+generated by the grammar above is more generous than we may want, in that it
+allows function declarations anywhere any declaration is allowed, including
+inside arbitrary blocks. However, as the rule below shows, we are not
+storing the declaration environment with the λ-abstraction value as
+closures do. Instead, as seen shortly, we switch to the global environment
+whenever functions are invoked, which is consistent with our requirement that
+functions should only be declared at the top. Thus, if one declares local
+functions, then one may see unexpected behaviors (e.g., when one shadows a
+global variable before declaring a local function). The type checker of
+SIMPLE, also defined in K (see examples/simple/typed/static),
+discards programs which do not respect this requirement.

+
  rule <k> function F(Xs) S => . ...</k>
+       <env> Env => Env[F <- L] </env>
+       <store>... .Map => L |-> lambda(Xs, S) ...</store>
+       <nextLoc> L => L +Int 1 </nextLoc>
+

When we are done with the first pass (pre-processing), the computation
+cell k contains only the token execute (see the configuration
+declaration above, where the computation item execute was placed
+right after the program in the k cell of the initial configuration)
+and the cell genv is empty. In this case, we have to call
+main() and to initialize the global environment by transferring the
+contents of the local environment into it. We prefer to do it this way, as
+opposed to processing all the top level declarations directly within the global
+environment, because we want to avoid duplication of semantics: the syntax of
+the global declarations is identical to that of their corresponding local
+declarations, so the semantics of the latter suffices provided that we copy
+the local environment into the global one once we are done with the
+pre-processing. We want this separate pre-processing step precisely because
+we want to create the global environment. All (top-level) functions end up
+having their names bound in the global environment and, as seen below, they
+are executed in that same global environment; all these mean, in particular,
+that the functions "see" each other, allowing for mutual recursion, etc.

+
  syntax KItem ::= "execute"
+  rule <k> execute => main(.Exps); </k>
+       <env> Env </env>
+       <genv> .Map => Env </genv>
+

Expressions

+ +

We next define the K semantics of all the expression constructs.

+

Variable lookup

+ +

When a variable X is the first computational task, and X is bound to some
+location L in the environment, and L is mapped to some value V in the
+store, then we rewrite X into V:

+
  rule <k> X:Id => V ...</k>
+       <env>... X |-> L ...</env>
+       <store>... L |-> V:Val ...</store>  [group(lookup)]
+

Note that the rule above excludes reading , because is not
+a value and V is checked at runtime to be a value.

+

Variable/Array increment

+ +

This is tricky, because we want to allow both ++x and ++a[5].
+Therefore, we need to extract the lvalue of the expression to increment.
+To do that, we state that the expression to increment should be wrapped
+by the auxiliary lvalue operation and then evaluated. The semantics
+of this auxiliary operation is defined at the end of this file. For now, all
+we need to know is that it takes an expression and evaluates to a location
+value. Location values, also defined at the end of the file, are integers
+wrapped with the operation loc, to distinguish them from ordinary
+integers.

+
  context ++(HOLE => lvalue(HOLE))
+  rule <k> ++loc(L) => I +Int 1 ...</k>
+       <store>... L |-> (I => I +Int 1) ...</store>  [group(increment)]
+

Arithmetic operators

+ +

There is nothing special about the following rules. They rewrite the
+language constructs to their library counterparts when their arguments
+become values of expected sorts:

+
  rule I1 + I2 => I1 +Int I2
+  rule Str1 + Str2 => Str1 +String Str2
+  rule I1 - I2 => I1 -Int I2
+  rule I1 * I2 => I1 *Int I2
+  rule I1 / I2 => I1 /Int I2 requires I2 =/=K 0
+  rule I1 % I2 => I1 %Int I2 requires I2 =/=K 0
+  rule - I => 0 -Int I
+  rule I1 < I2 => I1 <Int I2
+  rule I1 <= I2 => I1 <=Int I2
+  rule I1 > I2 => I1 >Int I2
+  rule I1 >= I2 => I1 >=Int I2
+

The equality and inequality constructs reduce to syntactic comparison
+of the two argument values (which is what the equality on K terms does).

+
  rule V1:Val == V2:Val => V1 ==K V2
+  rule V1:Val != V2:Val => V1 =/=K V2
+

The logical negation is clear, but the logical conjunction and disjunction
+are short-circuited:

+
  rule ! T => notBool(T)
+  rule true  && E => E
+  rule false && _ => false
+  rule true  || _ => true
+  rule false || E => E
+

Array lookup

+ +

Untyped SIMPLE does not check array bounds (the dynamically typed version of
+it, in examples/simple/typed/dynamic, does check for array out of
+bounds). The first rule below desugars the multi-dimensional array access to
+uni-dimensional array access; recall that the array access operation was
+declared strict, so all sub-expressions involved are already values at this
+stage. The second rule rewrites the array access to a lookup operation at a
+precise location; we prefer to do it this way to avoid locking the store.
+The semantics of the auxiliary lookup operation is straightforward,
+and is defined at the end of the file.

+
// The [anywhere] feature is underused, because it would only be used
+// at the top of the computation or inside the lvalue wrapper. So it
+// may not be worth, or we may need to come up with a special notation
+// allowing us to enumerate contexts for [anywhere] rules.
+  rule V:Val[N1:Int, N2:Int, Vs:Vals] => V[N1][N2, Vs]
+    [anywhere]
+
+  rule array(L,_)[N:Int] => lookup(L +Int N)
+    [anywhere]
+

Size of an array

+ +

The size of the array is stored in the array reference value, and the
+sizeOf construct was declared strict, so:

+
  rule sizeOf(array(_,N)) => N
+

Function call

+ +

Function application was strict in both its arguments, so we can
+assume that both the function and its arguments are evaluated to
+values (the former expected to be a λ-abstraction). The first
+rule below matches a well-formed function application on top of the
+computation and performs the following steps atomically: it switches
+to the function body followed by return; (for the case in
+which the function does not use an explicit return statement); it
+pushes the remaining computation, the current environment, and the
+current control data onto the function stack (the remaining
+computation can thus also be discarded from the computation cell,
+because an unavoidable subsequent return statement ‒see
+above‒ will always recover it from the stack); it switches the
+current environment (which is being pushed on the function stack) to
+the global environment, which is where the free variables in the
+function body should be looked up; it binds the formal parameters to
+fresh locations in the new environment, and stores the actual
+arguments to those locations in the store (this latter step is easily
+done by reducing the problem to variable declarations, whose semantics
+we have already defined; the auxiliary operation mkDecls is
+defined at the end of the file). The second rule pops the
+computation, the environment and the control data from the function
+stack when a return statement is encountered as the next
+computational task, passing the returned value to the popped
+computation (the popped computation was the context in which the
+returning function was called). Note that the pushing/popping of the
+control data is crucial. Without it, one may have a function that
+contains an exception block with a return statement inside, which
+would put the xstack cell in an inconsistent state (since the
+exception block modifies it, but that modification should be
+irrelevant once the function returns). We add an artificial
+nothing value to the language, which is returned by the
+nulary return; statements.

+
  syntax KItem ::=  (Map,K,ControlCellFragment)
+
+  rule <k> lambda(Xs,S)(Vs:Vals) ~> K => mkDecls(Xs,Vs) S return; </k>
+       <control>
+         <fstack> .List => ListItem((Env,K,C)) ...</fstack>
+         C
+       </control>
+       <env> Env => GEnv </env>
+       <genv> GEnv </genv>
+
+  rule <k> return(V:Val); ~> _ => V ~> K </k>
+       <control>
+         <fstack> ListItem((Env,K,C)) => .List ...</fstack>
+         (_ => C)
+       </control>
+       <env> _ => Env </env>
+
+  syntax Val ::= "nothing"
+  rule return; => return nothing;
+

Like for division-by-zero, it is left unspecified what happens
+when the nothing value is used in domain calculations. For
+example, from the the perspective of the language semantics,
+7 +Int nothing can evaluate to anything, or
+may not evaluate at all (be undefined). If one wants to make sure that
+such artificial values are never misused, then one needs to define a static
+checker (also using K, like our the type checker in
+examples/simple/typed/static) and reject programs that do.
+Note that, unlike the undefined symbol which had the sort K
+instead of Val, we defined nothing to be a value. That
+is because, as explained above, we do not want the program to get
+stuck when nothing is returned by a function. Instead, we want the
+behavior to be unspecified; in particular, if one is careful to never
+use the returned value in domain computation, like it happens when we
+call a function for its side effects (e.g., with a statement of the
+form f(x);), then the program does not get stuck.

+

Read

+ +

The read() expression construct simply evaluates to the next
+input value, at the same time discarding the input value from the
+in cell.

+
  rule <k> read() => I ...</k> <input> ListItem(I:Int) => .List ...</input>  [group(read)]
+

Assignment

+ +

In SIMPLE, like in C, assignments are expression constructs and not statement
+constructs. To make it a statement all one needs to do is to follow it by a
+semi-colon ; (see the semantics for expression statements below).
+Like for the increment, we want to allow assignments not only to variables but
+also to array elements, e.g., e1[e2] = e3 where e1 evaluates
+to an array reference, e2 to a natural number, and e3 to any
+value. Thus, we first compute the lvalue of the left-hand-side expression
+that appears in an assignment, and then we do the actual assignment to the
+resulting location:

+
  context (HOLE => lvalue(HOLE)) = _
+
+  rule <k> loc(L) = V:Val => V ...</k> <store>... L |-> (_ => V) ...</store>
+    [group(assignment)]
+

Statements

+ +

We next define the K semantics of statements.

+

Blocks

+ +

Empty blocks are simply discarded, as shown in the first rule below.
+For non-empty blocks, we schedule the enclosed statement but we have to
+make sure the environment is recovered after the enclosed statement executes.
+Recall that we allow local variable declarations, whose scope is the block
+enclosing them. That is the reason for which we have to recover the
+environment after the block. This allows us to have a very simple semantics
+for variable declarations, as we did above. One can make the two rules below
+computational if one wants them to count as computational steps.

+
  rule {} => .
+  rule <k> { S } => S ~> setEnv(Env) ...</k>  <env> Env </env>
+

The basic definition of environment recovery is straightforward and
+given in the section on auxiliary constructs at the end of the file.

+

There are two common alternatives to the above semantics of blocks.
+One is to keep track of the variables which are declared in the block and only
+recover those at the end of the block. This way one does more work for
+variable declarations but conceptually less work for environment recovery; we
+say conceptually because it is not clear that it is indeed the case that
+one does less work when AC matching is involved. The other alternative is to
+work with a stack of environments instead of a flat environment, and push the
+current environment when entering a block and pop it when exiting it. This
+way, one does more work when accessing variables (since one has to search the
+variable in the environment stack in a top-down manner), but on the other hand
+uses smaller environments and the definition gets closer to an implementation.
+Based on experience with dozens of language semantics and other K definitions,
+we have found that our approach above is the best trade-off between elegance
+and efficiency (especially since rewrite engines have built-in techniques to
+lazily copy terms, by need, thus not creating unnecessary copies),
+so it is the one that we follow in general.

+

Sequential composition

+ +

Sequential composition is desugared into K's builtin sequentialization
+operation (recall that, like in C, the semi-colon ; is not a
+statement separator in SIMPLE — it is either a statement terminator or a
+construct for a statement from an expression). Note that K allows
+to define the semantics of SIMPLE in such a way that statements eventually
+dissolve from the top of the computation when they are completed; this is in
+sharp contrast to (artificially) evaluating them to a special
+skip statement value and then getting rid of that special value, as
+it is the case in other semantic approaches (where everything must evaluate
+to something). This means that once S₁ completes in the rule below, S₂
+becomes automatically the next computation item without any additional
+(explicit or implicit) rules.

+
  rule S1:Stmt S2:Stmt => S1 ~> S2
+

A subtle aspect of the rule above is that S₁ is declared to have sort
+Stmts and not Stmt. That is because desugaring macros can indeed
+produce left associative sequential composition of statements. For example,
+the code var x=0; x=1; is desugared to
+(var x; x=0;) x=1;, so although originally the first term of
+the sequential composition had sort Stmt, after desugaring it became
+of sort Stmts. Note that the attribute [right] associated
+to the sequential compositon production is an attribute of the syntax, and not
+of the semantics: e.g., it tells the parser to parse
+var x; x=0; x=1; as var x; (x=0; x=1;), but it
+does not tell the rewrite engine to rewrite (var x; x=0;) x=1; to
+var x; (x=0; x=1;).

+

Expression statements

+ +

Expression statements are only used for their side effects, so their result
+value is simply discarded. Common examples of expression statements are ones
+of the form ++x;, x=e;, e1[e2]=e3;, etc.

+
  rule _:Val; => .
+

Conditional

+ +

Since the conditional was declared with the strict(1) attribute, we
+can assume that its first argument will eventually be evaluated. The rules
+below cover the only two possibilities in which the conditional is allowed to
+proceed (otherwise the rewriting process gets stuck).

+
  rule if ( true) S else _ => S
+  rule if (false) _ else S => S
+

While loop

+ +

The simplest way to give the semantics of the while loop is by unrolling.
+Note, however, that its unrolling is only allowed when the while loop reaches
+the top of the computation (to avoid non-termination of unrolling). The
+simple while loop semantics below works because our while loops in SIMPLE are
+indeed very basic. If we allowed break/continue of loops then we would need
+a completely different semantics, which would also involve the control cell.

+
  rule while (E) S => if (E) {S while(E)S}
+

Print

+ +

The print statement was strict, so all its arguments are now
+evaluated (recall that print is variadic). We append each of
+its evaluated arguments to the output buffer, and discard the residual
+print statement with an empty list of arguments.

+
  rule <k> print(V:Val, Es => Es); ...</k> <output>... .List => ListItem(V) </output>
+    [group(print)]
+  rule print(.Vals); => .
+

Exceptions

+ +

SIMPLE allows parametric exceptions, in that one can throw and catch a
+particular value. The statement try S₁ catch(X) S₂
+proceeds with the evaluation of S₁. If S₁ evaluates normally, i.e.,
+without any exception thrown, then S₂ is discarded and the execution
+continues normally. If S₁ throws an exception with a statement of the
+form throw E, then E is first evaluated to some value V
+(throw was declared to be strict), then V is bound to X, then
+S₂ is evaluated in the new environment while the reminder of S₁ is
+discarded, then the environment is recovered and the execution continues
+normally with the statement following the try S₁ catch(X) S₂ statement.
+Exceptions can be nested and the statements in the
+catch part (S₂ in our case) can throw exceptions to the
+upper level. One should be careful with how one handles the control data
+structures here, so that the abrupt changes of control due to exception
+throwing and to function returns interact correctly with each other.
+For example, we want to allow function calls inside the statement S₁ in
+a try S₁ catch(X) S₂ block which can throw an exception
+that is not caught by the function but instead is propagated to the
+try S₁ catch(X) S₂ block that called the function.
+Therefore, we have to make sure that the function stack as well as other
+potential control structures are also properly modified when the exception
+is thrown to correctly recover the execution context. This can be easily
+achieved by pushing/popping the entire current control context onto the
+exception stack. The three rules below modularly do precisely the above.

+
  syntax KItem ::= (Id,Stmt,K,Map,ControlCellFragment)
+
+  syntax KItem ::= "popx"
+
+  rule <k> (try S1 catch(X) {S2} => S1 ~> popx) ~> K </k>
+       <control>
+         <xstack> .List => ListItem((X, S2, K, Env, C)) ...</xstack>
+         C
+       </control>
+       <env> Env </env>
+
+  rule <k> popx => . ...</k>
+       <xstack> ListItem(_) => .List ...</xstack>
+
+  rule <k> throw V:Val; ~> _ => { var X = V; S2 } ~> K </k>
+       <control>
+         <xstack> ListItem((X, S2, K, Env, C)) => .List ...</xstack>
+         (_ => C)
+       </control>
+       <env> _ => Env </env>
+

The catch statement S₂ needs to be executed in the original environment,
+but where the thrown value V is bound to the catch variable X. We here
+chose to rely on two previously defined constructs when giving semantics to
+the catch part of the statement: (1) the variable declaration with
+initialization, for binding X to V; and (2) the block construct for
+preventing X from shadowing variables in the original environment upon the
+completion of S₂.

+

Threads

+ +

SIMPLE's threads can be created and terminated dynamically, and can
+synchronize by acquiring and releasing re-entrant locks and by rendezvous.
+We discuss the seven rules giving the semantics of these operations below.

+

Thread creation

+ +

Threads can be created by any other threads using the spawn S
+construct. The spawn expression construct evaluates to the unique identifier
+of the newly created thread and, at the same time, a new thread cell is added
+into the configuration, initialized with the S statement and sharing the
+same environment with the parent thread. Note that the newly created
+thread cell is torn. That means that the remaining cells are added
+and initialized automatically as described in the definition of SIMPLE's
+configuration. This is part of K's configuration abstraction mechanism.

+
  rule <thread>...
+         <k> spawn S => !T:Int ...</k>
+         <env> Env </env>
+       ...</thread>
+       (.Bag => <thread>...
+               <k> S </k>
+               <env> Env </env>
+               <id> !T </id>
+             ...</thread>)
+

Thread termination

+ +

Dually to the above, when a thread terminates its assigned computation (the
+contents of its k cell) is empty, so the thread can be dissolved.
+However, since no discipline is imposed on how locks are acquired and released,
+it can be the case that a terminating thread still holds locks. Those locks
+must be released, so other threads attempting to acquire them do not deadlock.
+We achieve that by removing all the locks held by the terminating thread in its
+holds cell from the set of busy locks in the busy cell
+(keys(H) returns the domain of the map H as a set, that is, only
+the locks themselves ignoring their multiplicity). As seen below, a lock is
+added to the busy cell as soon as it is acquired for the first time
+by a thread. The unique identifier of the terminated thread is also collected
+into the terminated cell, so the join construct knows which
+threads have terminated.

+
  rule (<thread>... <k>.</k> <holds>H</holds> <id>T</id> ...</thread> => .Bag)
+       <busy> Busy => Busy -Set keys(H) </busy>
+       <terminated>... .Set => SetItem(T) ...</terminated>
+

Thread joining

+ +

Thread joining is now straightforward: all we need to do is to check whether
+the identifier of the thread to be joined is in the terminated cell.
+If yes, then the join statement dissolves and the joining thread
+continues normally; if not, then the joining thread gets stuck.

+
  rule <k> join T:Int; => . ...</k>
+       <terminated>... SetItem(T) ...</terminated>
+

Acquire lock

+ +

There are two cases to distinguish when a thread attempts to acquire a lock
+(in SIMPLE any value can be used as a lock):
+(1) The thread does not currently have the lock, in which case it has to
+take it provided that the lock is not already taken by another thread (see
+the side condition of the first rule).
+(2) The thread already has the lock, in which case it just increments its
+counter for the lock (the locks are re-entrant). These two cases are captured
+by the two rules below:

+
  rule <k> acquire V:Val; => . ...</k>
+       <holds>... .Map => V |-> 0 ...</holds>
+       <busy> Busy (.Set => SetItem(V)) </busy>
+    requires (notBool(V in Busy))  [group(acquire)]
+
+  rule <k> acquire V; => . ...</k>
+       <holds>... V:Val |-> (N => N +Int 1) ...</holds>
+

Release lock

+ +

Similarly, there are two corresponding cases to distinguish when a thread
+releases a lock:
+(1) The thread holds the lock more than once, in which case all it needs to do
+is to decrement the lock counter.
+(2) The thread holds the lock only once, in which case it needs to remove it
+from its holds cell and also from the the shared busy cell,
+so other threads can acquire it if they need to.

+
  rule <k> release V:Val; => . ...</k>
+       <holds>... V |-> (N => N -Int 1) ...</holds>
+    requires N >Int 0
+
+  rule <k> release V; => . ...</k> <holds>... V:Val |-> 0 => .Map ...</holds>
+       <busy>... SetItem(V) => .Set ...</busy>
+

Rendezvous synchronization

+ +

In addition to synchronization through acquire and release of locks, SIMPLE
+also provides a construct for rendezvous synchronization. A thread whose next
+statement to execute is rendezvous(V) gets stuck until another
+thread reaches an identical statement; when that happens, the two threads
+drop their rendezvous statements and continue their executions. If three
+threads happen to have an identical rendezvous statement as their next
+statement, then precisely two of them will synchronize and the other will
+remain blocked until another thread reaches a similar rendezvous statement.
+The rule below is as simple as it can be. Note, however, that, again, it is
+K's mechanism for configuration abstraction that makes it work as desired:
+since the only cell which can multiply containing a k cell inside is
+the thread cell, the only way to concretize the rule below to the
+actual configuration of SIMPLE is to include each k cell in a
+thread cell.

+
  rule <k> rendezvous V:Val; => . ...</k>
+       <k> rendezvous V; => . ...</k>  [group(rendezvous)]
+

Auxiliary declarations and operations

+ +

In this section we define all the auxiliary constructs used in the
+above semantics.

+

Making declarations

+ +

The mkDecls auxiliary construct turns a list of identifiers
+and a list of values in a sequence of corresponding variable
+declarations.

+
  syntax Stmt ::= mkDecls(Ids,Vals)  [function]
+  rule mkDecls((X:Id, Xs:Ids), (V:Val, Vs:Vals)) => var X=V; mkDecls(Xs,Vs)
+  rule mkDecls(.Ids,.Vals) => {}
+

Location lookup

+ +

The operation below is straightforward. Note that we place it in the same
+lookup group as the variable lookup rule defined above. This way,
+both rules will be considered transitions when we include the lookup
+tag in the transition option of kompile.

+
  syntax Exp ::= lookup(Int)
+  rule <k> lookup(L) => V ...</k> <store>... L |-> V:Val ...</store>  [group(lookup)]
+

Environment recovery

+ +

We have already discussed the environment recovery auxiliary operation in the
+IMP++ tutorial:

+
// TODO: eliminate the env wrapper, like we did in IMP++
+
+  syntax KItem ::= setEnv(Map)
+  rule <k> setEnv(Env) => . ...</k> <env> _ => Env </env>
+

While theoretically sufficient, the basic definition for environment
+recovery alone is suboptimal. Consider a loop while (E)S,
+whose semantics (see above) was given by unrolling. S
+is a block. Then the semantics of blocks above, together with the
+unrolling semantics of the while loop, will yield a computation
+structure in the k cell that increasingly grows, adding a new
+environment recovery task right in front of the already existing sequence of
+similar environment recovery tasks (this phenomenon is similar to the ``tail
+recursion'' problem). Of course, when we have a sequence of environment
+recovery tasks, we only need to keep the last one. The elegant rule below
+does precisely that, thus avoiding the unnecessary computation explosion
+problem:

+
  rule (setEnv(_) => .) ~> setEnv(_)
+

In fact, the above follows a common convention in K for recovery
+operations of cell contents: the meaning of a computation task of the form
+cell(C) that reaches the top of the computation is that the current
+contents of cell cell is discarded and gets replaced with C. We
+did not add support for these special computation tasks in our current
+implementation of K, so we need to define them as above.

+

lvalue and loc

+ +

For convenience in giving the semantics of constructs like the increment and
+the assignment, that we want to operate the same way on variables and on
+array elements, we used an auxiliary lvalue(E) construct which was
+expected to evaluate to the lvalue of the expression E. This is only
+defined when E has an lvalue, that is, when E is either a variable or
+evaluates to an array element. lvalue(E) evaluates to a value of
+the form loc(L), where L is the location where the value of E
+can be found; for clarity, we use loc to structurally distinguish
+natural numbers from location values. In giving semantics to lvalue
+there are two cases to consider. (1) If E is a variable, then all we need
+to do is to grab its location from the environment. (2) If E is an array
+element, then we first evaluate the array and its index in order to identify
+the exact location of the element of concern, and then return that location;
+the last rule below works because its preceding context declarations ensure
+that the array and its index are evaluated, and then the rule for array lookup
+(defined above) rewrites the evaluated array access construct to its
+corresponding store lookup operation.

+
// For parsing reasons, we prefer to allow lvalue to take a K
+
+  syntax Exp ::= lvalue(K)
+  syntax Val ::= loc(Int)
+
+// Local variable
+
+  rule <k> lvalue(X:Id => loc(L)) ...</k> <env>... X |-> L:Int ...</env>
+
+// Array element: evaluate the array and its index;
+// then the array lookup rule above applies.
+
+  context lvalue(_::Exp[HOLE::Exps])
+  context lvalue(HOLE::Exp[_::Exps])
+
+// Finally, return the address of the desired object member
+
+  rule lvalue(lookup(L:Int) => loc(L))
+

Initializing multiple locations

+ +

The following operation initializes a sequence of locations with the same
+value:

+
  syntax Map ::= Int "..." Int "|->" K
+    [function, latex({#1}\ldots{#2}\mapsto{#3})]
+  rule N...M |-> _ => .Map  requires N >Int M
+  rule N...M |-> K => N |-> K (N +Int 1)...M |-> K  requires N <=Int M
+

The semantics of SIMPLE is now complete. Make sure you kompile the
+definition with the right options in order to generate the desired model.
+No kompile options are needed if you only only want to execute the definition
+(and thus get an interpreter), but if you want to search for a different
+program behaviors then you need to kompile with the transition option
+including rule groups such as lookup, increment, acquire, etc. See the
+IMP++ tutorial for what the transition option means how to use it.

+
endmodule
+

Go to Lesson 2, SIMPLE typed static

+

SIMPLE — Typed — Static

+ +

Author: Grigore Roșu (grosu@illinois.edu)
+Organization: University of Illinois at Urbana-Champaign

+

Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
+Organization: University of Bucharest

+

Abstract

+ +

This is the K definition of the static semantics of the typed SIMPLE
+language, or in other words, a type system for the typed SIMPLE
+language in K. We do not re-discuss the various features of the
+SIMPLE language here. The reader is referred to the untyped version of
+the language for such discussions. We here only focus on the new and
+interesting problems raised by the addition of type declarations, and
+what it takes to devise a type system/checker for the language.

+

When designing a type system for a language, no matter in what
+paradigm, we have to decide upon the intended typing policy. Note
+that we can have multiple type systems for the same language, one for
+each typing policy. For example, should we accept programs which
+don't have a main function? Or should we allow functions that do not
+return explicitly? Or should we allow functions whose type expects
+them to return a value (say an int) to use a plain
+return; statement, which returns no value, like in C?
+And so on and so forth. Typically, there are two opposite tensions
+when designing a type system. On the one hand, you want your type
+system to be as permissive as possible, that is, to accept as many
+programs that do not get stuck when executed with the untyped
+semantics as possible; this will keep the programmers using your
+language happy. On the other hand, you want your type system to have
+a reasonable performance when implemented; this will keep both the
+programmers and the implementers of your language happy. For example,
+a type system for rejecting programs that could perform
+division-by-zero is not expected to be feasible in general. A simple
+guideline when designing typing policies is to imagine how the
+semantics of the untyped language may get stuck and try to prevent
+those situations from happening.

+

Before we give the K type system of SIMPLE formally, we discuss,
+informally, the intended typing policy:

+
    +
  • +

    Each program should contain a main() function. Indeed,
    +the untyped SIMPLE semantics will get stuck on any program which does
    +not have a main function.

    +
  • +
  • +

    Each primitive value has its own type, which can be int
    +bool, or string. There is also a type void
    +for nonexistent values, for example for the result of a function meant
    +to return no value (but only be used for its side effects, like a
    +procedure).

    +
  • +
  • +

    The syntax of untyped SIMPLE is extended to allow type
    +declarations for all the variables, including array variables. This is
    +done in a C/Java-style. For example, int x; or
    +int x=7, y=x+3;, or int[][][] a[10,20];
    +(the latter defines a 10 × 20 matrix of arrays of integers).
    +Recall from untyped SIMPLE that, unlike in C/Java, our multi-dimensional
    +arrays use comma-separated arguments, although they have the array-of-array
    +semantics.

    +
  • +
  • +

    Functions are also typed in a C/Java style. However, since in SIMPLE
    +we allow functions to be passed to and returned by other functions, we also
    +need function types. We will use the conventional higher-order arrow-notation
    +for function types, but will separate the argument types with commas. For
    +example, a function returning an array of bool elements and
    +taking as argument an array x of two-integer-argument functions
    +returning an integer, is declared using a syntax of the form
    +bool[] f(((int,int)->int)[] x) { ... }
    +and has the type ((int,int)->int)[] -> bool[].

    +
  • +
  • +

    We allow any variable declarations at the top level. Functions
    +can only be declared at the top level. Each function can only access the
    +other functions and variables declared at the top level, or its own locally
    +declared variables. SIMPLE has static scoping.

    +
  • +
  • +

    The various expression and statement constructs take only elements of
    +the expected types.

    +
  • +
  • +

    Increment and assignment can operate both on variables and on array
    +elements. For example, if f has type int->int[][] and
    +function g has the type int->int, then the
    +increment expression ++f(7)[g(2),g(3)] is valid.

    +
  • +
  • +

    Functions should only return values of their declared result
    +type. To give the programmers more flexibility, we allow functions to
    +use return; statements to terminate without returning an
    +actual value, or to not explicitly use any return statement,
    +regardless of their declared return type. This flexibility can be
    +handy when writing programs using certain functions only for their
    +side effects. Nevertheless, as the dynamic semantics shows, a return
    +value is automatically generated when an explicit return
    +statement is not encountered.

    +
  • +
  • +

    For simplicity, we here limit exceptions to only throw and catch
    +integer values. We let it as an exercise to the reader to extend the
    +semantics to allow throwing and catching arbitrary-type exceptions.
    +Like in programming languages like Java, one can go even further and
    +define a semantics where thrown exceptions are propagated through
    +try-catch statements until one of the corresponding type is found.
    +We will do this when we define the KOOL language, not here.
    +To keep the definition if SIMPLE simple, here we do not attempt to
    +reject programs which throw uncaught exceptions.

    +
  • +
+

Like in untyped SIMPLE, some constructs can be desugared into a
+smaller set of basic constructs. In general, it should be clear why a
+program does not type by looking at the top of the k cells in
+its stuck configuration.

+
module SIMPLE-TYPED-STATIC-SYNTAX
+  imports DOMAINS-SYNTAX
+

Syntax

+ +

The syntax of typed SIMPLE extends that of untyped SIMPLE with support
+for declaring types to variables and functions.

+
  syntax Id ::= "main" [token]
+

Types

+ +

Primitive, array and function types, as well as lists (or tuples) of types.
+The lists of types are useful for function arguments.

+
  syntax Type ::= "void" | "int" | "bool" | "string"
+                | Type "[" "]"
+                | "(" Type ")"             [bracket]
+                > Types "->" Type
+
+  syntax Types ::= List{Type,","}          [klabel(exps)]
+

Declarations

+ +

Variable and function declarations have the expected syntax. For variables,
+we basically just replaced the var keyword of untyped SIMPLE with a
+type. For functions, besides replacing the function keyword with a
+type, we also introduce a new syntactic category for typed variables,
+Param, and lists over it.

+
  syntax Param ::= Type Id
+  syntax Params ::= List{Param,","}
+
+  syntax Stmt ::= Type Exps ";"
+                | Type Id "(" Params ")" Block
+

Expressions

+ +

The syntax of expressions is identical to that in untyped SIMPLE,
+except for the logical conjunction and disjunction which have
+different strictness attributes, because they now have different
+evaluation strategies.

+
  syntax Exp ::= Int | Bool | String | Id
+               | "(" Exp ")"             [bracket]
+               | "++" Exp
+               > Exp "[" Exps "]"        [strict]
+               > Exp "(" Exps ")"        [strict]
+               | "-" Exp                 [strict]
+               | "sizeOf" "(" Exp ")"    [strict]
+               | "read" "(" ")"
+               > left:
+                 Exp "*" Exp             [strict, left]
+               | Exp "/" Exp             [strict, left]
+               | Exp "%" Exp             [strict, left]
+               > left:
+                 Exp "+" Exp             [strict, left]
+               | Exp "-" Exp             [strict, left]
+               > non-assoc:
+                 Exp "<" Exp             [strict, non-assoc]
+               | Exp "<=" Exp            [strict, non-assoc]
+               | Exp ">" Exp             [strict, non-assoc]
+               | Exp ">=" Exp            [strict, non-assoc]
+               | Exp "==" Exp            [strict, non-assoc]
+               | Exp "!=" Exp            [strict, non-assoc]
+               > "!" Exp                 [strict]
+               > left:
+                 Exp "&&" Exp            [strict, left]
+               | Exp "||" Exp            [strict, left]
+               > "spawn" Block
+               > Exp "=" Exp             [strict(2), right]
+

Note that spawn has not been declared strict. This may
+seem unexpected, because the child thread shares the same environment
+with the parent thread, so from a typing perspective the spawned
+statement makes the same sense in a child thread as it makes in the
+parent thread. The reason for not declaring it strict is because we
+want to disallow programs where the spawned thread calls the
+return statement, because those programs would get stuck in
+the dynamic semantics. The type semantics of spawn below will reject
+such programs.

+

We still need lists of expressions, defined below, but note that we do
+not need lists of identifiers anymore. They have been replaced by the lists
+of parameters.

+
  syntax Exps ::= List{Exp,","}          [strict, klabel(exps)]
+

Statements

+ +

The statements have the same syntax as in untyped SIMPLE, except for
+the exceptions, which now type their parameter. Note that, unlike in untyped
+SIMPLE, all statement constructs which have arguments and are not desugared
+are strict, including the conditional and the while. Indeed, from a
+typing perspective, they are all strict: first type their arguments and then
+type the actual construct.

+
  syntax Block ::= "{" "}"
+                | "{" Stmt "}"
+
+  syntax Stmt ::= Block
+                | Exp ";"                                  [strict]
+                | "if" "(" Exp ")" Block "else" Block      [avoid, strict]
+                | "if" "(" Exp ")" Block                   [macro]
+                | "while" "(" Exp ")" Block                [strict]
+                | "for" "(" Stmt Exp ";" Exp ")" Block     [macro]
+                | "return" Exp ";"                         [strict]
+                | "return" ";"
+                | "print" "(" Exps ")" ";"                 [strict]
+                | "try" Block "catch" "(" Param ")" Block  [strict(1)]
+                | "throw" Exp ";"                          [strict]
+                | "join" Exp ";"                           [strict]
+                | "acquire" Exp ";"                        [strict]
+                | "release" Exp ";"                        [strict]
+                | "rendezvous" Exp ";"                     [strict]
+

Note that the sequential composition is now sequentially strict,
+because, unlike in the dynamic semantics where statements dissolved,
+they now reduce to the stmt type, which is a result.

+
  syntax Stmt ::= Stmt Stmt                             [seqstrict, right]
+

Desugaring macros

+ +

We use the same desugaring macros like in untyped SIMPLE, but, of
+course, including the types of the involved variables.

+
  rule if (E) S => if (E) S else {}
+  rule for(Start Cond; Step) {S:Stmt} => {Start while(Cond){S Step;}}
+  rule for(Start Cond; Step) {} => {Start while(Cond){Step;}}
+  rule T:Type E1:Exp, E2:Exp, Es:Exps; => T E1; T E2, Es;               [anywhere]
+  rule T:Type X:Id = E; => T X; X = E;                                  [anywhere]
+
+endmodule
+
+
+module SIMPLE-TYPED-STATIC
+  imports SIMPLE-TYPED-STATIC-SYNTAX
+  imports DOMAINS
+

Static semantics

+ +

Here we define the type system of SIMPLE. Like concrete semantics,
+type systems defined in K are also executable. However, K type
+systems turn into type checkers instead of interpreters when executed.

+

The typing process is done in two (overlapping) phases. In the first
+phase the global environment is built, which contains type bindings
+for all the globally declared variables and functions. For functions,
+the declared types will be ``trusted'' during the first phase and
+simply bound to their corresponding function names and placed in the
+global type environment. At the same time, type-checking tasks that
+the function bodies indeed respect their claimed types are generated.
+All these tasks are (concurrently) verified during the second phase.
+This way, all the global variable and function declarations are
+available in the global type environment and can be used in order to
+type-check each function code. This is consistent with the semantics
+of untyped SIMPLE, where functions can access all the global variables
+and can call any other function declared in the same program. The
+two phases may overlap because of the K concurrent semantics. For
+example, a function task can be started while the first phase is still
+running; moreover, it may even complete before the first phase does,
+namely when all the global variables and functions that it needs have
+already been processed and made available in the global environment by
+the first phase task.

+

Extended syntax and results

+ +

The idea is to start with a configuration holding the program to type
+in one of its cells, then apply rewrite rules on it mixing types and
+language syntax, and eventually obtain a type instead of the original
+program. In other words, the program reduces to its type using
+the K rules giving the type system of the language. In doing so,
+additional typing tasks for function bodies are generated and solved
+the same way. If this rewriting process gets stuck, then we say that
+the program is not well-typed. Otherwise the program is well-typed
+(by definition). We did not need types for statements and for blocks
+as part of the typed SIMPLE syntax, because programmers are not allowed
+to use such types explicitly. However, we are going to need them in the
+type system, because blocks and statements reduce to them.

+

We start by allowing types to be used inside expressions and statements in
+our language. This way, types can be used together with language syntax in
+subsequent K rules without any parsing errors. Like in the type system of
+IMP++ in the K tutorial, we prefer to group the block and statement types
+under one syntactic sub-category of types, because this allows us to more
+compactly state that certain terms can be either blocks or statements. Also,
+since programs and fragments of program will reduce to their types, in order
+for the strictness and context declarations to be executable we state that
+types are results (same like we did in the IMP++ tutorial).

+
  syntax Exp ::= Type
+  syntax Exps ::= Types
+  syntax BlockOrStmtType ::= "block" | "stmt"
+  syntax Type ::= BlockOrStmtType
+  syntax Block ::= BlockOrStmtType
+  syntax KResult ::= Type
+                   | Types    //TODO: remove this, eventually
+

Configuration

+ +

The configuration of our type system consists of a tasks cell
+holding various typing task cells, and a global type environment.
+Each task includes a k cell holding the code to type, a tenv
+cell holding the local type environment, and a return cell holding
+the return type of the currently checked function. The latter is needed in
+order to check whether return statements return values of the expected type.
+Initially, the program is placed in a k cell inside a
+task cell. Since the cells with multiplicity ? are not
+included in the initial configuration, the task cell holding
+the original program in its k cell will contain no other
+subcells.

+
  configuration <T color="yellow">
+                  <tasks color="orange">
+                    <task multiplicity="*" color="yellow" type="Set">
+                      <k color="green"> $PGM:Stmt </k>
+                      <tenv multiplicity="?" color="cyan"> .Map </tenv>
+                      <returnType multiplicity="?" color="black"> void </returnType>
+                    </task>
+                  </tasks>
+//                  <br/>
+                  <gtenv color="blue"> .Map </gtenv>
+                </T>
+

Variable declarations

+ +

Variable declarations type as statements, that is, they reduce to the
+type stmt. There are only two cases that need to be
+considered: when a simple variable is declared and when an array
+variable is declared. The macros at the end of the syntax module
+above take care of reducing other variable declarations, including
+ones where the declared variables are initialized, to only these two
+cases. The first case has two subcases: when the variable declaration
+is global (i.e., the task cell contains only the k
+cell), in which case it is added to the global type environment
+checking at the same time that the variable has not been already
+declared; and when the variable declaration is local (i.e., a
+tenv cell is available), in which case it is simply added to
+the local type environment, possibly shadowing previous homonymous
+variables. The third case reduces to the second, incrementally moving
+the array dimension into the type until the array becomes a simple
+variable.

+
  rule <task> <k> T:Type X:Id; => stmt ...</k> </task>
+       <gtenv> Rho (.Map => X |-> T) </gtenv>
+    requires notBool(X in keys(Rho))
+  rule <k> T:Type X:Id; => stmt ...</k> <tenv> Rho => Rho[X <- T] </tenv>
+
+  context _:Type _::Exp[HOLE::Exps];
+// The rule below may need to sort E to Exp in the future, if the
+// parser gets stricter; without that information, it may not be able
+// to complete the LHS into T E[int,Ts],.Exps; (and similarly for the RHS)
+  rule T:Type E:Exp[int,Ts:Types]; => T[] E[Ts];
+// I want to write the rule below as _:Type (E:Exp[.Types] => E),
+// but the list completion seems to not work well with that.
+  rule T:Type E:Exp[.Types]; => T E;
+

Function declarations

+ +

Functions are allowed to be declared only at the top level (the
+task cell holds only its k subcell). Each function
+declaration reduces to a variable declaration (a binding of its name
+to its declared function type), but also adds a task into the
+tasks cell. The task consists of a typing of the statement
+declaring all the function parameters followed by the function body,
+together with the expected return type of the function. The
+getTypes and mkDecls functions, defined at the end of
+the file in the section on auxiliary operations, extracts the list of
+types and makes a sequence of variable declarations from a list of
+function parameters, respectively. Note that, although in the dynamic
+semantics we include a terminating return statement at the
+end of the function body to eliminate from the analysis the case when
+the function does not provide an explicit return, we do not need to
+include such a similar return statement here. That's because
+the return statements type to stmt anyway, and the
+entire code of the function body needs to type anyway.

+
  rule <task> <k> T:Type F:Id(Ps:Params) S => getTypes(Ps)->T F; ...</k> </task>
+       (.Bag => <task>
+               <k> mkDecls(Ps) S </k> <tenv> .Map </tenv> <returnType> T </returnType>
+             </task>)
+

Checking if main() exists}

+ +

Once the entire program is processed (generating appropriate tasks
+to type check its function bodies), we can dissolve the main
+task cell (the one holding only a k subcell). Since
+we want to enforce that programs include a main function, we also
+generate a function task executing main() to ensure that it
+types (remove this task creation if you do not want your type system
+to reject programs without a main function).

+
  rule <task> <k> stmt => main(.Exps); </k> (.Bag => <tenv> .Map </tenv>) </task>
+

Collecting the terminated tasks

+ +

Similarly, once a non-main task (i.e., one which contains a
+tenv subcells) is completed using the subsequent rules (i.e.,
+its k cell holds only the block or stmt
+type), we can dissolve its corresponding cell. Note that it is
+important to ensure that we only dissolve tasks containing a
+tenv cell with the rule below, because the main task should
+not dissolve this way! It should do what the above rule says.
+In the end, there should be no task cell left in the configuration
+when the program correctly type checks.

+
  rule <task>... <k> _:BlockOrStmtType </k> <tenv> _ </tenv> ...</task> => .Bag
+

Basic values

+ +

The first three rewrite rules below reduce the primitive values to
+their types, as we typically do when we define type systems in K.

+
  rule _:Int => int
+  rule _:Bool => bool
+  rule _:String => string
+

Variable lookup

+ +

There are three cases to distinguish for variable lookup: (1) if the
+variable is bound in the local type environment, then look its type up
+there; (2) if a local environment exists and the variable is not bound
+in it, then look its type up in the global environment; (3) finally,
+if there is no local environment, meaning that we are executing the
+top-level pass, then look the variable's type up in the global
+environment, too.

+
  rule <k> X:Id => T ...</k> <tenv>... X |-> T ...</tenv>
+
+  rule <k> X:Id => T ...</k> <tenv> Rho </tenv> <gtenv>... X |-> T ...</gtenv>
+    requires notBool(X in keys(Rho))
+
+  rule <task> <k> X:Id => T ...</k> </task> <gtenv>... X |-> T ...</gtenv>
+

Increment

+ +

We want the increment operation to apply to any lvalue, including
+array elements, not only to variables. For that reason, we define a
+special context extracting the type of the argument of the increment
+operation only if that argument is an lvalue. Otherwise the rewriting
+process gets stuck. The operation ltype is defined at the
+end of this file, in the auxiliary operation section. It essentially
+acts as a filter, getting stuck if its argument is not an lvalue and
+letting it reduce otherwise. The type of the lvalue is expected to be
+an integer in order to be allowed to be incremented, as seen in the
+rule ++ int => int below.

+
  context ++(HOLE => ltype(HOLE))
+  rule ++ int => int
+

Common expression constructs

+ +

The rules below are straightforward and self-explanatory:

+
  rule int + int => int
+  rule string + string => string
+  rule int - int => int
+  rule int * int => int
+  rule int / int => int
+  rule int % int => int
+  rule - int => int
+  rule int < int => bool
+  rule int <= int => bool
+  rule int > int => bool
+  rule int >= int => bool
+  rule T:Type == T => bool
+  rule T:Type != T => bool
+  rule bool && bool => bool
+  rule bool || bool => bool
+  rule ! bool => bool
+

Array access and size

+ +

Array access requires each index to type to an integer, and the
+array type to be at least as deep as the number of indexes:

+
// NOTE:
+// We used to need parentheses in the RHS, to avoid capturing Ts as an attribute
+// Let's hope that is not a problem anymore.
+
+  rule (T[])[int, Ts:Types] => T[Ts]
+  rule T:Type[.Types] => T
+

sizeOf only needs to check that its argument is an array:

+
  rule sizeOf(_T[]) => int
+

Input/Output

+ +

The read expression construct types to an integer, while print types
+to a statement provided that all its arguments type to integers or
+strings.

+
  rule read() => int
+
+  rule print(T:Type, Ts => Ts); requires T ==K int orBool T ==K string
+  rule print(.Types); => stmt
+

Assignment

+ +

The special context and the rule for assignment below are similar
+to those for increment: the LHS of the assignment must be an lvalue
+and, in that case, it must have the same type as the RHS, which then
+becomes the type of the assignment.

+
  context (HOLE => ltype(HOLE)) = _
+  rule T:Type = T => T
+

Function application and return

+ +

Function application requires the type of the function and the
+types of the passed values to be compatible. Note that a special case
+is needed to handle the no-argument case:

+
  rule (Ts:Types -> T)(Ts) => T requires Ts =/=K .Types
+  rule (void -> T)(.Types) => T
+

The returned value must have the same type as the declared
+function return type. If an empty return is encountered, than
+we should check that we are in a function (and not a thread)
+context, that is, a return cell must be available:

+
  rule <k> return T:Type; => stmt ...</k> <returnType> T </returnType>
+  rule <k> return; => stmt ...</k> <returnType> _ </returnType>
+

Blocks

+ +

To avoid having to recover type environments after blocks, we prefer
+to start a new task for block body, making sure that the new task
+is passed the same type environment and return cells. The value
+returned by return statements must have the same type as
+stated in the return cell. The print variadic
+function is allowed to only print integers and strings. The thrown
+exceptions can only have integer type.

+
  rule {} => block
+
+  rule <task> <k> {S} => block ...</k> <tenv> Rho </tenv> R </task>
+       (.Bag => <task> <k> S </k> <tenv> Rho </tenv> R </task>)
+

Expression statement

+ +
  rule _:Type; => stmt
+

Conditional and while loop

+ +
  rule if (bool) block else block => stmt
+  rule while (bool) block => stmt
+

Exceptions

+ +

We currently force the parameters of exceptions to only be integers.
+Moreover, for simplicity, we assume that integer exceptions can be
+thrown from anywhere, including from functions which do not define
+any try-catch block (with the currently unchecked ‒also for
+simplicity‒ expectation that the caller functions would catch those
+exceptions).

+
  rule try block catch(int X:Id) {S} => {int X; S}
+  rule try block catch(int X:Id) {} => {int X;}
+  rule throw int; => stmt
+

Concurrency

+ +

Nothing special about typing the concurrency constructs, except that
+we do not want the spawned thread to return, so we do not include any
+return cell in the new task cell for the thread statement.
+Same like with the functions above, we do not check for thrown
+exceptions which are not caught.

+
  rule <k> spawn S => int ...</k> <tenv> Rho </tenv>
+       (.Bag => <task> <k> S </k> <tenv> Rho </tenv> </task>)
+  rule join int; => stmt
+  rule acquire _:Type; => stmt
+  rule release _:Type; => stmt
+  rule rendezvous _:Type; => stmt
+
+  rule _:BlockOrStmtType _:BlockOrStmtType => stmt
+

Auxiliary constructs

+ +

The function mkDecls turns a list of parameters into a
+list of variable declarations.

+
  syntax Stmt ::= mkDecls(Params)  [function]
+  rule mkDecls(T:Type X:Id, Ps:Params) => T X; mkDecls(Ps)
+  rule mkDecls(.Params) => {}
+

The ltype context allows only expressions which have an
+lvalue to evaluate.

+
  syntax LValue ::= Id
+  rule isLValue(_:Exp[_:Exps]) => true
+  syntax Exp ::= LValue  // K should be able to infer this
+                         // if not added, then it gets stuck with an Id on k cell
+
+// Instead of the second LValue production above you can use a rule:
+//  rule isLValue(_:Exp[_:Exps]) => true
+
+  syntax Exp ::= ltype(Exp)
+//  context ltype(HOLE:LValue)
+// The above context does not work due to some error, so we write instead
+  context ltype(HOLE) requires isLValue(HOLE)
+

The function getTypes is the same as in SIMPLE typed dynamic.

+
  syntax Types ::= getTypes(Params)  [function]
+  rule getTypes(T:Type _:Id) => T, .Types   // I would like to not use .Types
+  rule getTypes(T:Type _:Id, P, Ps) => T, getTypes(P,Ps)
+  rule getTypes(.Params) => void, .Types
+
+endmodule
+

Go to Lesson 3, SIMPLE typed dynamic

+

SIMPLE — Typed — Dynamic

+ +

Author: Grigore Roșu (grosu@illinois.edu)
+Organization: University of Illinois at Urbana-Champaign

+

Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
+Organization: University of Bucharest

+

Abstract

+ +

This is the K dynamic semantics of the typed SIMPLE language.
+It is very similar to the semantics of the untyped SIMPLE, the
+difference being that we now dynamically check the typing policy
+described in the static semantics of typed SIMPLE. Because of the
+dynamic nature of the semantics, we can also perform some additional
+checks which were not possible in the static semantics, such as
+memory leaks due to accessing an array out of its bounds. We will
+highlight the differences between the dynamically typed and the
+untyped SIMPLE as we proceed with the semantics. We recommend the
+reader to consult the typing policy and the syntax of types discussed
+in the static semantics of the typed SIMPLE language.

+
module SIMPLE-TYPED-DYNAMIC-SYNTAX
+  imports DOMAINS-SYNTAX
+

Syntax

+ +

The syntax of typed SIMPLE extends that of untyped SIMPLE with support
+for declaring types to variables and functions.

+

The syntax below is identical to that of the static semantics of typed
+SIMPLE. However, the K strictness attributes are like those of the untyped
+SIMPLE, to capture the desired evaluation strategies of the various language
+constructs.

+
  syntax Id ::= "main" [token]
+

Types

+ +
  syntax Type ::= "void" | "int" | "bool" | "string"
+                | Type "[" "]"
+                | "(" Type ")"           [bracket]
+                > Types "->" Type
+  syntax Types ::= List{Type,","}        [klabel(exps)]
+

Declarations

+ +
  syntax Param ::= Type Id
+  syntax Params ::= List{Param,","}
+
+  syntax Stmt ::= Type Exps ";"
+                | Type Id "(" Params ")" Block
+

Expressions

+ +
  syntax Exp ::= Int | Bool | String | Id
+               | "(" Exp ")"             [bracket]
+               | "++" Exp
+               > Exp "[" Exps "]"        [strict]
+               > Exp "(" Exps ")"        [strict]
+               | "-" Exp                 [strict]
+               | "sizeOf" "(" Exp ")"    [strict]
+               | "read" "(" ")"
+               > left:
+                 Exp "*" Exp             [strict, left]
+               | Exp "/" Exp             [strict, left]
+               | Exp "%" Exp             [strict, left]
+               > left:
+                 Exp "+" Exp             [strict, left]
+               | Exp "-" Exp             [strict, left]
+               > non-assoc:
+                 Exp "<" Exp             [strict, non-assoc]
+               | Exp "<=" Exp            [strict, non-assoc]
+               | Exp ">" Exp             [strict, non-assoc]
+               | Exp ">=" Exp            [strict, non-assoc]
+               | Exp "==" Exp            [strict, non-assoc]
+               | Exp "!=" Exp            [strict, non-assoc]
+               > "!" Exp                 [strict]
+               > left:
+                 Exp "&&" Exp            [strict(1), left]
+               | Exp "||" Exp            [strict(1), left]
+               > "spawn" Block
+               > Exp "=" Exp             [strict(2), right]
+

Like in the static semantics, there is no need for lists of identifiers
+(because we now have lists of parameters).

+
  syntax Exps ::= List{Exp,","}          [strict, klabel(exps)]
+  syntax Val
+  syntax Vals ::= List{Val,","}          [klabel(exps)]
+

Statements

+ +
  syntax Block ::= "{" "}"
+                | "{" Stmt "}"
+
+  syntax Stmt ::= Block
+                | Exp ";"                               [strict]
+                | "if" "(" Exp ")" Block "else" Block   [avoid, strict(1)]
+                | "if" "(" Exp ")" Block                [macro]
+                | "while" "(" Exp ")" Block
+                | "for" "(" Stmt Exp ";" Exp ")" Block  [macro]
+                | "print" "(" Exps ")" ";"              [strict]
+                | "return" Exp ";"                      [strict]
+                | "return" ";"
+                | "try" Block "catch" "(" Param ")" Block
+            | "throw" Exp ";"                       [strict]
+                | "join" Exp ";"                        [strict]
+                | "acquire" Exp ";"                     [strict]
+                | "release" Exp ";"                     [strict]
+                | "rendezvous" Exp ";"                  [strict]
+
+  syntax Stmt ::= Stmt Stmt                          [right]
+

The same desugaring macros like in the statically typed SIMPLE.

+
  rule if (E) S => if (E) S else {}
+  rule for(Start Cond; Step) {S:Stmt} => {Start while(Cond){S Step;}}
+  rule for(Start Cond; Step) {} => {Start while(Cond){Step;}}
+  rule T:Type E1:Exp, E2:Exp, Es:Exps; => T E1; T E2, Es;               [anywhere]
+  rule T:Type X:Id = E; => T X; X = E;                                  [anywhere]
+
+endmodule
+
+
+module SIMPLE-TYPED-DYNAMIC
+  imports SIMPLE-TYPED-DYNAMIC-SYNTAX
+  imports DOMAINS
+

Semantics

+ +

Values and results

+ +

These are similar to those of untyped SIMPLE, except that the array
+references and the function abstrations now also hold their types.
+These types are needed in order to easily compute the type of any
+value in the language (see the auxiliary typeOf operation at
+the end of this module).

+
  syntax Val ::= Int | Bool | String
+               | array(Type,Int,Int)
+               | lambda(Type,Params,Stmt)
+  syntax Exp ::= Val
+  syntax Exps ::= Vals
+  syntax KResult ::= Val
+                   | Vals  // TODO: should not need this
+

Configuration

+ +

The configuration is almost identical to that of untyped SIMPLE,
+except for a return cell inside the control cell.
+This return cell will hold, like in the static semantics of
+typed SIMPLE, the expected type of the value returned by the function
+being executed. The contents of this cell will be set whenever a
+function is invoked and will be checked whenever the evaluation of the
+function body encounters an explicit return statement.

+
  // the syntax declarations below are required because the sorts are
+  // referenced directly by a production and, because of the way KIL to KORE
+  // is implemented, the configuration syntax is not available yet
+  // should simply work once KIL is removed completely
+  // check other definitions for this hack as well
+
+  syntax ControlCell
+  syntax ControlCellFragment
+
+  configuration <T color="red">
+                  <threads color="orange">
+                    <thread multiplicity="*" color="yellow" type="Map">
+                      <id color="pink"> 0 </id>
+                      <k color="green"> ($PGM:Stmt ~> execute) </k>
+//                      <br/>
+                      <control color="cyan">
+                        <fstack color="blue"> .List </fstack>
+                        <xstack color="purple"> .List </xstack>
+                        <returnType color="LimeGreen"> void </returnType>
+                       </control>
+//                      <br/>
+                      <env color="violet"> .Map </env>
+                      <holds color="black"> .Map </holds>
+                    </thread>
+                  </threads>
+//                  <br/>
+                  <genv color="pink"> .Map </genv>
+                  <store color="white"> .Map </store>
+                  <busy color="cyan">.Set</busy>
+                  <terminated color="red"> .Set </terminated>
+                  <input color="magenta" stream="stdin"> .List </input>
+                  <output color="brown" stream="stdout"> .List </output>
+                  <nextLoc color="gray"> 0 </nextLoc>
+                </T>
+

Declarations and Initialization

+ +

Variable Declaration

+ +

The undefined construct is now parameterized by a type.
+A main difference between untyped SIMPLE and dynamically typed SIMPLE
+is that the latter assigns a type to each of its locations and that
+type cannot be changed during the execution of the program. We do not
+do any memory management in our semantic definitions here, so
+locations cannot be reclaimed, garbage collected and/or reused. Each
+location corresponds precisely to an allocated variable or array
+element, whose type was explicitly or implicitly declared in the
+program and does not change. It is therefore safe to type each
+location and then never allow that type to change. The typed
+undefined values effectively assign both a type and an undefined value
+to a location.

+
  syntax KItem ::= undefined(Type)  [latex(\bot_{#1})]
+
+  rule <k> T:Type X:Id; => . ...</k>
+       <env> Env => Env[X <- L] </env>
+       <store>... .Map => L |-> undefined(T) ...</store>
+       <nextLoc> L:Int => L +Int 1 </nextLoc>
+

Array Declaration

+ +

The dynamic semantics of typed array declarations is similar to that
+in untyped SIMPLE, but we have to make sure that we associate the
+right type to the allocated locations.

+
  rule <k> T:Type X:Id[N:Int]; => . ...</k>
+       <env> Env => Env[X <- L] </env>
+       <store>... .Map => L |-> array(T, L +Int 1, N)
+                          (L +Int 1)...(L +Int N) |-> undefined(T) ...</store>
+       <nextLoc> L:Int => L +Int 1 +Int N </nextLoc>
+    when N >=Int 0
+
+  context _:Type _::Exp[HOLE::Exps];
+

The desugaring of multi-dimensional arrays into unidimensional
+ones is also similar to that in untyped SIMPLE, although we have to
+make sure that all the declared variables have the right types. The
+auxiliary operation T<Vs>, defined at the end of the file,
+adds the length of Vs dimensions to the type T.

+
// TODO: Check the desugaring below to be consistent with the one for untyped simple
+
+  syntax Id ::= "$1" [token] | "$2" [token]
+  rule T:Type X:Id[N1:Int, N2:Int, Vs:Vals];
+    => T[]<Vs> X[N1];
+       {
+         T[][]<Vs> $1=X;
+         for(int $2=0; $2 <= N1 - 1; ++$2) {
+           T X[N2,Vs];
+           $1[$2] = X;
+         }
+       }
+

Function declaration

+ +

Store all function parameters, as well as the return type, as part
+of the lambda abstraction. In the spirit of dynamic typing, we will
+make sure that parameters are well typed when the function is invoked.

+
  rule <k> T:Type F:Id(Ps:Params) S => . ...</k>
+       <env> Env => Env[F <- L] </env>
+       <store>... .Map => L |-> lambda(T, Ps, S) ...</store>
+       <nextLoc> L => L +Int 1 </nextLoc>
+

Calling main()

+ +

When done with the first pass, call main().

+
  syntax KItem ::= "execute"
+  rule <k> execute => main(.Exps); </k>
+       <env> Env </env>
+       <genv> .Map => Env </genv>
+

Expressions

+ +

Variable lookup

+ +
  rule <k> X:Id => V ...</k>
+       <env>... X |-> L ...</env>
+       <store>... L |-> V:Val ...</store>  [group(lookup)]
+

Variable/Array increment

+ +
  context ++(HOLE => lvalue(HOLE))
+  rule <k> ++loc(L) => I +Int 1 ...</k>
+       <store>... L |-> (I:Int => I +Int 1) ...</store>  [group(increment)]
+

Arithmetic operators

+ +
  rule I1 + I2 => I1 +Int I2
+  rule Str1 + Str2 => Str1 +String Str2
+  rule I1 - I2 => I1 -Int I2
+  rule I1 * I2 => I1 *Int I2
+  rule I1 / I2 => I1 /Int I2 when I2 =/=K 0
+  rule I1 % I2 => I1 %Int I2 when I2 =/=K 0
+  rule - I => 0 -Int I
+  rule I1 < I2 => I1 <Int I2
+  rule I1 <= I2 => I1 <=Int I2
+  rule I1 > I2 => I1 >Int I2
+  rule I1 >= I2 => I1 >=Int I2
+  rule V1:Val == V2:Val => V1 ==K V2
+  rule V1:Val != V2:Val => V1 =/=K V2
+  rule ! T => notBool(T)
+  rule true  && E => E
+  rule false && _ => false
+  rule true  || _ => true
+  rule false || E => E
+

Array lookup

+ +

Check array bounds, as part of the dynamic typing policy.

+
// Same comment as for simple untyped regarding [anywhere]
+  rule V:Val[N1:Int, N2:Int, Vs:Vals] => V[N1][N2, Vs]
+    [anywhere]
+
+// Same comment as for simple untyped regarding [anywhere]
+  rule array(_:Type, L:Int, M:Int)[N:Int] => lookup(L +Int N)
+    when N >=Int 0 andBool N <Int M  [anywhere]
+

Size of an array

+ +
  rule sizeOf(array(_,_,N)) => N
+

Function call

+ +

Define function call and return together, to see their relationship.
+Note that the operation mkDecls now declares properly typed
+instantiated variables, and that the semantics of return also
+checks that that type of the returned value is expected one.

+
  syntax KItem ::= (Type,Map,K,ControlCellFragment)
+
+  rule <k> lambda(T,Ps,S)(Vs:Vals) ~> K => mkDecls(Ps,Vs) S return; </k>
+       <control>
+         <fstack> .List => ListItem((T',Env,K,C)) ...</fstack>
+         <returnType> T' => T </returnType>
+         C
+       </control>
+       <env> Env => GEnv </env>
+       <genv> GEnv </genv>
+
+  rule <k> return V:Val; ~> _ => V ~> K </k>
+       <control>
+         <fstack> ListItem((T',Env,K,C)) => .List ...</fstack>
+         <returnType> T => T' </returnType>
+         (_ => C)
+       </control>
+       <env> _ => Env </env>
+    when typeOf(V) ==K T   // check the type of the returned value
+

Like the undefined above, nothing also gets
+tagged with a type now. The empty return statement is
+completed to return the nothing value tagged as expected.

+
  syntax Val ::= nothing(Type)
+  rule <k> return; => return nothing(T); ...</k> <returnType> T </returnType>
+

Read

+ +
  rule <k> read() => I ...</k> <input> ListItem(I:Int) => .List ...</input>  [group(read)]
+

Assignment

+ +

The assignment now checks that the type of the assigned location is
+preserved:

+
  context (HOLE => lvalue(HOLE)) = _
+
+  rule <k> loc(L) = V:Val => V ...</k> <store>... L |-> (V' => V) ...</store>
+    when typeOf(V) ==K typeOf(V')  [group(assignment)]
+

Statements

+ +

Blocks

+ +
  rule {} => .
+  rule <k> { S } => S ~> setEnv(Env) ...</k>  <env> Env </env>
+

Sequential composition

+ +
  rule S1:Stmt S2:Stmt => S1 ~> S2
+

Expression statements

+ +
  rule _:Val; => .
+

Conditional

+ +
  rule if ( true) S else _ => S
+  rule if (false) _ else S => S
+

While loop

+ +
  rule while (E) S => if (E) {S while(E)S}
+

Print

+ +

We only allow printing integers and strings:

+
  rule <k> print(V:Val, Es => Es); ...</k> <output>... .List => ListItem(V) </output>
+    when typeOf(V) ==K int orBool typeOf(V) ==K string  [group(print)]
+  rule print(.Vals); => .
+

Exceptions

+ +

Exception parameters are now typed, but note that the semantics below
+works correctly only when the thrown exception has the same type as
+the innermost try-catch paramete. To keep things simple, for the time
+being we can assume that SIMPLE only throws and catches integer
+values, in which case our semantics below works fine:

+
  syntax KItem ::= (Param,Stmt,K,Map,ControlCellFragment)  // Param instead of Id
+
+  syntax KItem ::= "popx"
+
+  rule <k> (try S1 catch(P) S2 => S1 ~> popx) ~> K </k>
+       <control>
+         <xstack> .List => ListItem((P, S2, K, Env, C)) ...</xstack>
+         C
+       </control>
+       <env> Env </env>
+
+  rule <k> popx => . ...</k>
+       <xstack> ListItem(_) => .List ...</xstack>
+
+  rule <k> throw V:Val; ~> _ => { T X = V; S2 } ~> K </k>
+       <control>
+         <xstack> ListItem((T:Type X:Id, S2, K, Env, C)) => .List ...</xstack>
+         (_ => C)
+       </control>
+       <env> _ => Env </env>
+

Threads

+ +

Thread creation

+ +
   rule <thread>...
+          <k> spawn S => !T:Int +Int 1 ...</k>
+          <env> Env </env>
+        ...</thread>
+        (.Bag => <thread>...
+                <k> S </k>
+                <env> Env </env>
+                <id> !T +Int 1 </id>
+              ...</thread>)
+

Thread termination

+ +
   rule (<thread>... <k>.</k> <holds>H</holds> <id>T</id> ...</thread> => .Bag)
+        <busy> Busy => Busy -Set keys(H) </busy>
+        <terminated>... .Set => SetItem(T) ...</terminated>
+

Thread joining

+ +
   rule <k> join T:Int; => . ...</k>
+        <terminated>... SetItem(T) ...</terminated>
+

Acquire lock

+ +
   rule <k> acquire V:Val; => . ...</k>
+        <holds>... .Map => V |-> 0 ...</holds>
+        <busy> Busy (.Set => SetItem(V)) </busy>
+     when (notBool(V in Busy:Set))  [group(acquire)]
+
+   rule <k> acquire V; => . ...</k>
+        <holds>... V:Val |-> (N:Int => N +Int 1) ...</holds>
+

Release lock

+ +
   rule <k> release V:Val; => . ...</k>
+        <holds>... V |-> (N => N:Int -Int 1) ...</holds>
+      when N >Int 0
+
+   rule <k> release V; => . ...</k> <holds>... V:Val |-> 0 => .Map ...</holds>
+        <busy>... SetItem(V) => .Set ...</busy>
+

Rendezvous synchronization

+ +
   rule <k> rendezvous V:Val; => . ...</k>
+        <k> rendezvous V; => . ...</k>  [group(rendezvous)]
+

Auxiliary declarations and operations

+ +

Turns a list of parameters and a list of instance values for them
+into a list of variable declarations.

+
  syntax Stmt ::= mkDecls(Params,Vals)  [function]
+  rule mkDecls((T:Type X:Id, Ps:Params), (V:Val, Vs:Vals))
+    => T X=V; mkDecls(Ps,Vs)
+  rule mkDecls(.Params,.Vals) => {}
+

Location lookup.

+
  syntax Exp ::= lookup(Int)  // see NOTES.md for why Exp instead of KItem
+  rule <k> lookup(L) => V ...</k> <store>... L |-> V:Val ...</store>  [group(lookup)]
+

Environment recovery.

+
// TODO: same comment regarding setEnv(...) as for simple untyped
+
+  syntax KItem ::= setEnv(Map)
+  rule <k> setEnv(Env) => . ...</k>  <env> _ => Env </env>
+  rule (setEnv(_) => .) ~> setEnv(_)
+

lvalue and loc

+
  syntax Exp ::= lvalue(K)
+  syntax Val ::= loc(Int)
+
+  rule <k> lvalue(X:Id => loc(L)) ...</k>  <env>... X |-> L:Int ...</env>
+
+  //context lvalue(_[HOLE])
+  //context lvalue(HOLE[_])
+  context lvalue(_::Exp[HOLE::Exps])
+  context lvalue(HOLE::Exp[_::Exps])
+
+  rule lvalue(lookup(L:Int) => loc(L))
+

Adds the corresponding depth to an array type

+
  syntax Type ::= Type "<" Vals ">"  [function]
+  rule T:Type<_,Vs:Vals> => T[]<Vs>
+  rule T:Type<.Vals> => T
+

Sequences of locations.

+
  syntax Map ::= Int "..." Int "|->" K
+    [function, latex({#1}\ldots{#2}\mapsto{#3})]
+  rule N...M |-> _ => .Map  when N >Int M
+  rule N...M |-> K => N |-> K (N +Int 1)...M |-> K  when N <=Int M
+
+// Type of a value.
+  syntax Type ::= typeOf(K)  [function]
+  rule typeOf(_:Int) => int
+  rule typeOf(_:Bool) => bool
+  rule typeOf(_:String) => string
+  rule typeOf(array(T,_,_)) => (T[])   // () needed! K parses [] as "no tags"
+  rule typeOf(lambda(T,Ps,_)) => getTypes(Ps) -> T
+  rule typeOf(undefined(T)) => T
+  rule typeOf(nothing(T)) => T
+

List of types of a parameter.

+
  syntax Types ::= getTypes(Params)  [function]
+  rule getTypes(T:Type _:Id) => T, .Types   // I would like to not use .Types
+  rule getTypes(T:Type _:Id, P, Ps) => T, getTypes(P,Ps)
+  rule getTypes(.Params) => void, .Types
+endmodule
+

KOOL — Untyped

+ +

Author: Grigore Roșu (grosu@illinois.edu)
+Organization: University of Illinois at Urbana-Champaign

+

Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
+Organization: University of Bucharest

+

Abstract

+ +

This is the K semantic definition of the untyped KOOL language. KOOL
+is aimed at being a pedagogical and research language that captures
+the essence of the object-oriented programming paradigm. Its untyped
+variant discussed here is simpler than the typed one, ignoring several
+intricate aspects of types in the presence of objects. A program
+consists of a set of class declarations. Each class can extend at
+most one other class (KOOL is single-inheritance). A class can
+declare a set of fields and a set of methods, all public and called
+the class' members. Specifically, KOOL includes the
+following features:

+
    +
  • +

    Class declarations, where a class may or may not explicitly
    +extend another class. In case a class does not explicitly extend
    +another class, then it is assumed that it extends the default top-most
    +and empty (i.e., no members) class called Object. Each class
    +is required to declare precisely one homonymous method, called its
    +constructor. Each valid program should contain one class
    +named Main, whose constructor, Main(), takes no
    +arguments. The execution of a program consists of creating an object
    +instance of class Main and invoking the constructor
    +Main() on it, that is, of executing new Main();.

    +
  • +
  • +

    All features of SIMPLE (see examples/simple/untyped),
    +i.e., multidimensional arrays, function (here called "method")
    +abstractions with call-by-value parameter passing style and static
    +scoping, blocks with locals, input/output, parametric exceptions, and
    +concurrency via dynamic thread creation/termination and synchronization.
    +The only change in the syntax of SIMPLE when imported in KOOL is the
    +function declaration keyword, function, which is changed into
    +method. The exact same desugaring macros from SIMPLE are
    +also included in KOOL. We can think of KOOL's classes as embedding
    +SIMPLE programs (extended with OO constructs, as discussed next).

    +
  • +
  • +

    Object creation using the new C(e1,...,en)
    +expression construct. An object instance of class C is first
    +created and then the constructor C(e1,...,en) is implicitly
    +called on that object. KOOL only allows (and requires) one
    +constructor per class. The class constructor can be called either
    +implicitly during a new object creation for the class, or explicitly.
    +The superclass constructor is not implicitly invoked when a
    +class constructor is invoked; if you want to invoke the superclass
    +constructor from a subclass constructor then you have to do it
    +explicitly.

    +
  • +
  • +

    An expression construct this, which evaluates to the
    +current object.

    +
  • +
  • +

    An expression construct super, which is used (only) in
    +combination with member lookup (see next) to refer to a superclass
    +field or method.

    +
  • +
  • +

    A member lookup expression construct e.x, where e
    +is an expression (either an expression expected to evaluate to an object
    +or the super construct) and x is a class member name,
    +that is, a field or a method name.

    +
  • +
  • +

    Expression constructs e instanceOf C and
    +(C) e, where e is an expression expected
    +to evaluate to an object and C a class name. The former
    +tells whether the class of e is a subclass of C,
    +that is, whether e can be used as an instance of C,
    +and the latter changes the class of e to C. These
    +operations always succeed: the former returns a Boolean value, while
    +the latter changes the current class of e to C
    +regardless of whether it is safe to do so or not. The typed version
    +of KOOL will check the safety of casting by ensuring that the instance
    +class of the object is a subclass of C. In untyped KOOL we
    +do not want to perform this check because we want to allow the
    +programmer maximum of flexibility: if one always accesses only
    +available members, then the program can execute successfully despite
    +the potentially unsafe cast.

    +
  • +
+

There are some specific aspects of KOOL that need to be discussed.

+

First, KOOL is higher-order, allowing function abstractions to be
+treated like any other values in the language. For example, if
+m is a method of object e then e.m
+evaluates to the corresponding function abstraction. The function
+abstraction is in fact a closure, because in addition to the method
+parameters and body it also encapsulates the object value (i.e., the
+environment of the object together with its current class—see below)
+that e evaluates to. This way, function abstractions can be
+invoked anywhere and have the capability to change the state of their
+object. For example, if m is a method of object e
+which increments a field c of e when invoked, and if
+getm is another method of e which simply returns
+m when invoked, then the double application
+(e.getm())() has the same effect as e.m(), that is,
+increments the counter c of e. Note that the
+higher-order nature of KOOL was not originally planned; it came as a
+natural consequence of evaluating methods to closures and we decided
+to keep it. If you do not like it then do not use it.

+

Second, since all the fields and methods are public in KOOL and since
+they can be redeclared in subclasses, it is not immediately clear how
+to lookup the member x when we write e.x and
+e is different from super. We distinguish two cases,
+depending on whether e.x occurs in a method invocation
+context (i.e., e.x(...)) or in a field context. KOOL has
+dynamic method dispatch, so if e.x is invoked as a method
+then x will be searched for starting with the instance class of
+the object value to which e evaluates. If e.x
+occurs in a non-method-invocation context then x will be
+treated as a field (although it may hold a method closure due to the
+higher-order nature of KOOL) and thus will be searched starting with
+the current class of the object value of e (which, because of
+this and casting, may be different from its instance class).
+In order to achieve the above, each object value will consist of a
+pair holding the current class of the object and an environment stack
+with one layer for each class in the object's instance class hierarchy.

+

Third, although KOOL is dynamic method dispatch, its capabilities
+described above are powerful enough to allow us to mimic static
+method dispatch. For example, suppose that you want to invoke method
+m() statically. Then all you need to do is to declare a
+local variable and bind it to m, for example var staticm = m;, and
+then call staticm(). This works because
+staticm is first bound to the method closure that m
+evaluates to, and then looked up as any local variable when invoked.
+We only enable the dynamic method dispatch when we have an object
+member on an application position, e.g., m().

+

In what follows, we limit our comments to the new, KOOL-specific
+aspects of the language. We refer the reader to the untyped SIMPLE
+language for documentation on the the remaining features, because
+those were all borrowed from SIMPLE.

+
module KOOL-UNTYPED-SYNTAX
+  imports DOMAINS-SYNTAX
+

Syntax

+ +

The syntax of KOOL extends that of SIMPLE with object-oriented
+constructs. We removed from the K annotated syntax of SIMPLE two
+constructs, namely the one for function declarations (because we want
+to call them methods now) and the one for function application
+(because application is not strict in the first argument
+anymore—needs to initiate dynamic method dispatch). The additional
+syntax includes:

+
    +
  • First, we need a new dedicated identifier, Object, for
    +the default top-most class.
  • +
  • Second, we rename the function keyword of SIMPLE into method.
  • +
  • Third, we add syntax for class declarations together with a
    +macro making classes which extend nothing to extend Object.
  • +
  • Fourth, we change the strictness attribute of application
    +into strict(2).
  • +
  • Finally, we add syntax and corresponding strictness
    +for the KOOL object-oriented constructs.
  • +
+
  syntax Id ::= "Object" [token] | "Main" [token]
+
+  syntax Stmt ::= "var" Exps ";"
+                | "method" Id "(" Ids ")" Block  // called "function" in SIMPLE
+                | "class" Id Block               // KOOL
+                | "class" Id "extends" Id Block  // KOOL
+
+  syntax Exp ::= Int | Bool | String | Id
+               | "this"                                 // KOOL
+               | "super"                                // KOOL
+               | "(" Exp ")"             [bracket]
+               | "++" Exp
+               | Exp "instanceOf" Id     [strict(1)]    // KOOL
+               | "(" Id ")" Exp          [strict(2)]    // KOOL  cast
+               | "new" Id "(" Exps ")"   [strict(2)]    // KOOL
+               | Exp "." Id                             // KOOL
+               > Exp "[" Exps "]"        [strict]
+               > Exp "(" Exps ")"        [strict(2)]    // was strict in SIMPLE
+               | "-" Exp                 [strict]
+               | "sizeOf" "(" Exp ")"    [strict]
+               | "read" "(" ")"
+               > left:
+                 Exp "*" Exp             [strict, left]
+               | Exp "/" Exp             [strict, left]
+               | Exp "%" Exp             [strict, left]
+               > left:
+                 Exp "+" Exp             [strict, left]
+               | Exp "-" Exp             [strict, left]
+               > non-assoc:
+                 Exp "<" Exp             [strict, non-assoc]
+               | Exp "<=" Exp            [strict, non-assoc]
+               | Exp ">" Exp             [strict, non-assoc]
+               | Exp ">=" Exp            [strict, non-assoc]
+               | Exp "==" Exp            [strict, non-assoc]
+               | Exp "!=" Exp            [strict, non-assoc]
+               > "!" Exp                 [strict]
+               > left:
+                 Exp "&&" Exp            [strict(1), left]
+               | Exp "||" Exp            [strict(1), left]
+               > "spawn" Block
+               > Exp "=" Exp             [strict(2), right]
+
+  syntax Ids  ::= List{Id,","}
+
+  syntax Exps ::= List{Exp,","}          [strict, klabel(exps)]
+  syntax Val
+  syntax Vals ::= List{Val,","}          [klabel(exps)]
+
+  syntax Block ::= "{" "}"
+                | "{" Stmt "}"
+
+  syntax Stmt ::= Block
+                | Exp ";"                               [strict]
+                | "if" "(" Exp ")" Block "else" Block   [avoid, strict(1)]
+                | "if" "(" Exp ")" Block                [macro]
+                | "while" "(" Exp ")" Block
+                | "for" "(" Stmt Exp ";" Exp ")" Block  [macro]
+                | "return" Exp ";"                      [strict]
+                | "return" ";"                          [macro]
+                | "print" "(" Exps ")" ";"              [strict]
+                | "try" Block "catch" "(" Id ")" Block
+                | "throw" Exp ";"                       [strict]
+                | "join" Exp ";"                        [strict]
+                | "acquire" Exp ";"                     [strict]
+                | "release" Exp ";"                     [strict]
+                | "rendezvous" Exp ";"                  [strict]
+
+  syntax Stmt ::= Stmt Stmt                          [right]
+

Old desugaring rules, from SIMPLE

+
  rule if (E) S => if (E) S else {}
+  rule for(Start Cond; Step) {S} => {Start while (Cond) {S Step;}}
+  rule var E1::Exp, E2::Exp, Es::Exps; => var E1; var E2, Es;       [anywhere]
+  rule var X::Id = E; => var X; X = E;                              [anywhere]
+

New desugaring rule

+
  rule class C:Id S => class C extends Object S                     // KOOL
+
+endmodule
+

Semantics

+ +

We first discuss the new configuration of KOOL, which extends that of
+SIMPLE. Then we include the semantics of the constructs borrowed from
+SIMPLE unchanged; we refrain from discussing those, because they were
+already discussed in the K definition of SIMPLE. Then we discuss
+changes to SIMPLE's semantics needed for the more general meaning of
+the previous SIMPLE constructs (for example for thread spawning,
+assignment, etc.). Finally, we discuss in detail the
+semantics of the additional KOOL constructs.

+
module KOOL-UNTYPED
+  imports KOOL-UNTYPED-SYNTAX
+  imports DOMAINS
+

Configuration

+ +

KOOL removes one cell and adds two nested cells to the configuration
+of SIMPLE. The cell which is removed is the one holding the global
+environment, because a KOOL program consists of a set of classes only,
+with no global declarations. In fact, since informally speaking each
+KOOL class now includes a SIMPLE program, it is safe to say that the
+global variables in SIMPLE became class fields in KOOL. Let us now
+discuss the new cells that are added to the configuration of SIMPLE.

+
    +
  • +

    The cell crntObj holds data pertaining to the current
    +object, that is, the object environment in which the code in cell
    +k executes: crntClass holds the current class (which
    +can change as methods of the current object are invoked);
    +envStack holds the stack of environments as a list,
    +each layer corresponding to one class in the objects' instance class
    +hierarchy; location, which is optional, holds the location in
    +the store where the current object is or has to be located (this is
    +useful both for method closures and for the semantics of object
    +creation).

    +
  • +
  • +

    The cell classes holds all the declared classes, each
    +class being held in its own class cell which contains a name
    +(className), a parent (extends), and the actual
    +member declarations (declarations).

    +
  • +
+
  // the syntax declarations below are required because the sorts are
+  // referenced directly by a production and, because of the way KIL to KORE
+  // is implemented, the configuration syntax is not available yet
+  // should simply work once KIL is removed completely
+  // check other definitions for this hack as well
+  syntax EnvCell
+  syntax ControlCell
+  syntax EnvStackCell
+  syntax CrntObjCellFragment
+
+  configuration <T color="red">
+                  <threads color="orange">
+                    <thread multiplicity="*" type="Set" color="yellow">
+                      <k color="green"> $PGM:Stmt ~> execute </k>
+                    //<br/> // TODO(KORE): support latex annotations #1799
+                      <control color="cyan">
+                        <fstack color="blue"> .List </fstack>
+                        <xstack color="purple"> .List </xstack>
+                      //<br/> // TODO(KORE): support latex annotations #1799
+                        <crntObj color="Fuchsia">  // KOOL
+                           <crntClass> Object </crntClass>
+                           <envStack> .List </envStack>
+                           <location multiplicity="?"> .K </location>
+                        </crntObj>
+                      </control>
+                    //<br/> // TODO(KORE): support latex annotations #1799
+                      <env color="violet"> .Map </env>
+                      <holds color="black"> .Map </holds>
+                      <id color="pink"> 0 </id>
+                    </thread>
+                  </threads>
+                //<br/> // TODO(KORE): support latex annotations #1799
+                  <store color="white"> .Map </store>
+                  <busy color="cyan">.Set </busy>
+                  <terminated color="red"> .Set </terminated>
+                  <input color="magenta" stream="stdin"> .List </input>
+                  <output color="brown" stream="stdout"> .List </output>
+                  <nextLoc color="gray"> 0 </nextLoc>
+                //<br/> // TODO(KORE): support latex annotations #1799
+                  <classes color="Fuchsia">        // KOOL
+                     <classData multiplicity="*" type="Map" color="Fuchsia">
+                        // the Map has as its key the first child of the cell,
+                        // in this case the className cell.
+                        <className color="Fuchsia"> Main </className>
+                        <baseClass color="Fuchsia"> Object </baseClass>
+                        <declarations color="Fuchsia"> .K </declarations>
+                     </classData>
+                  </classes>
+                </T>
+

Unchanged Semantics from untyped SIMPLE

+ +

The semantics below is taken over from SIMPLE unchanged.
+The semantics of function declaration and invocation, including the
+use of the special lambda abstraction value, needs to change
+in order to account for the fact that methods are now invoked into
+their object's environment. The semantics of function return actually
+stays unchanged. Also, the semantics of program initialization is
+different: now we have to create an instance of the Main
+class which also calls the constructor Main(), while in
+SIMPLE we only had to invoke the function Main().
+Finally, the semantics of thread spawning needs to change, too: the
+parent thread needs to also share its object environment with the
+spawned thread (in addition to its local environment, like in SIMPLE).
+This is needed in order to be able to spawn method invokations under
+dynamic method dispatch; for example, spawn { run(); }
+will need to look up the method run() in the newly created
+thread, operation which will most likely fail unless the child thread
+sees the object environment of the parent thread. Note that the
+spawn statement of KOOL is more permissive than the threads
+of Java. In fact, the latter can be implemented in terms of our
+spawn—see the program threads.kool for a sketch.

+

Below is a subset of the values of SIMPLE, which are also values
+of KOOL. We will add other values later in the semantics, such as
+object and method closures.

+
  syntax Val ::= Int | Bool | String
+               | array(Int,Int)
+  syntax Exp ::= Val
+  syntax Exps ::= Vals
+  syntax KResult ::= Val
+  syntax KResult ::= Vals
+

The semantics below are taken verbatim from the untyped SIMPLE
+definition.

+
  syntax KItem ::= "undefined"  [latex(\bot)]
+
+  rule <k> var X:Id; => . ...</k>
+       <env> Env => Env[X <- L] </env>
+       <store>... .Map => L |-> undefined ...</store>
+       <nextLoc> L:Int => L +Int 1 </nextLoc>
+
+
+  context var _:Id[HOLE];
+
+  rule <k> var X:Id[N:Int]; => . ...</k>
+       <env> Env => Env[X <- L] </env>
+       <store>... .Map => L |-> array(L +Int 1, N)
+                          (L +Int 1) ... (L +Int N) |-> undefined ...</store>
+       <nextLoc> L:Int => L +Int 1 +Int N </nextLoc>
+    when N >=Int 0
+
+
+  syntax Id ::= "$1" [token] | "$2" [token]
+  rule var X:Id[N1:Int, N2:Int, Vs:Vals];
+    => var X[N1];
+       {
+         var $1=X;
+         for(var $2=0; $2 <= N1 - 1; ++$2) {
+           var X[N2,Vs];
+           $1[$2] = X;
+         }
+       }
+
+
+  rule <k> X:Id => V ...</k>
+       <env>... X |-> L ...</env>
+       <store>... L |-> V:Val ...</store>  [group(lookup)]
+
+
+  context ++(HOLE => lvalue(HOLE))
+  rule <k> ++loc(L) => I +Int 1 ...</k>
+       <store>... L |-> (I:Int => I +Int 1) ...</store>  [group(increment)]
+
+
+  rule I1 + I2 => I1 +Int I2
+  rule Str1 + Str2 => Str1 +String Str2
+  rule I1 - I2 => I1 -Int I2
+  rule I1 * I2 => I1 *Int I2
+  rule I1 / I2 => I1 /Int I2 when I2 =/=K 0
+  rule I1 % I2 => I1 %Int I2 when I2 =/=K 0
+  rule - I => 0 -Int I
+  rule I1 < I2 => I1 <Int I2
+  rule I1 <= I2 => I1 <=Int I2
+  rule I1 > I2 => I1 >Int I2
+  rule I1 >= I2 => I1 >=Int I2
+
+  rule V1:Val == V2:Val => V1 ==K V2
+  rule V1:Val != V2:Val => V1 =/=K V2
+  rule ! T => notBool(T)
+  rule true  && E => E
+  rule false && _ => false
+  rule true  || _ => true
+  rule false || E => E
+
+
+  rule V:Val[N1:Int, N2:Int, Vs:Vals] => V[N1][N2, Vs]
+    [anywhere]
+
+  rule array(L,_)[N:Int] => lookup(L +Int N)
+    [anywhere]
+
+
+  rule sizeOf(array(_,N)) => N
+

The semantics of function application needs to change into dynamic
+method dispatch invocation, which is defined shortly. However,
+interestingly, the semantics of return stays unchanged.

+
  rule <k> return(V:Val); ~> _ => V ~> K </k>
+       <control>
+         <fstack> ListItem(fstackFrame(Env,K,XS,<crntObj> CO </crntObj>)) => .List ...</fstack>
+         <xstack> _ => XS </xstack>
+         <crntObj> _ => CO </crntObj>
+       </control>
+       <env> _ => Env </env>
+
+  syntax Val ::= "nothing"
+  rule return; => return nothing;
+
+
+  rule <k> read() => I ...</k> <input> ListItem(I:Int) => .List ...</input>  [group(read)]
+
+
+  context (HOLE => lvalue(HOLE)) = _
+
+  rule <k> loc(L) = V:Val => V ...</k> <store>... L |-> (_ => V) ...</store>
+    [group(assignment)]
+
+
+  rule {} => .
+  rule <k> { S } => S ~> setEnv(Env) ...</k>  <env> Env </env>
+
+
+  rule S1::Stmt S2::Stmt => S1 ~> S2
+
+  rule _:Val; => .
+
+  rule if ( true) S else _ => S
+  rule if (false) _ else S => S
+
+  rule while (E) S => if (E) {S while(E)S}
+
+  rule <k> print(V:Val, Es => Es); ...</k> <output>... .List => ListItem(V) </output>
+    [group(print)]
+  rule print(.Vals); => .
+
+
+  syntax KItem ::= xstackFrame(Id,Stmt,K,Map,K)
+  // TODO(KORE): drop the additional production once parsing issue #1842 is fixed
+                 | (Id,Stmt,K,Map,K)
+
+  syntax KItem ::= "popx"
+
+  rule <k> (try S1 catch(X) {S2} => S1 ~> popx) ~> K </k>
+       <control>
+         <xstack> .List => ListItem(xstackFrame(X, S2, K, Env, C)) ...</xstack>
+         C
+       </control>
+       <env> Env </env>
+
+  rule <k> popx => . ...</k>
+       <xstack> ListItem(_) => .List ...</xstack>
+
+  rule <k> throw V:Val; ~> _ => { var X = V; S2 } ~> K </k>
+       <control>
+         <xstack> ListItem(xstackFrame(X, S2, K, Env, C)) => .List ...</xstack>
+         (_ => C)
+       </control>
+       <env> _ => Env </env>
+

Thread spawning needs a new semantics, because we want the child
+thread to also share the object environment with its parent. The new
+semantics of thread spawning will be defined shortly. However,
+interestingly, the other concurrency constructs keep their semantics
+from SIMPLE unchanged.

+
  // TODO(KORE): ..Bag should be . throughout this definition #1772
+  rule (<thread>... <k>.</k> <holds>H</holds> <id>T</id> ...</thread> => .Bag)
+  /*
+  rule (<thread>... <k>.</k> <holds>H</holds> <id>T</id> ...</thread> => .)
+  */
+       <busy> Busy => Busy -Set keys(H) </busy>
+       <terminated>... .Set => SetItem(T) ...</terminated>
+
+  rule <k> join T:Int; => . ...</k>
+       <terminated>... SetItem(T) ...</terminated>
+
+  rule <k> acquire V:Val; => . ...</k>
+       <holds>... .Map => V |-> 0 ...</holds>
+       <busy> Busy (.Set => SetItem(V)) </busy>
+    when (notBool(V in Busy:Set))  [group(acquire)]
+
+  rule <k> acquire V; => . ...</k>
+       <holds>... V:Val |-> (N:Int => N +Int 1) ...</holds>
+
+  rule <k> release V:Val; => . ...</k>
+       <holds>... V |-> (N => N:Int -Int 1) ...</holds>
+    when N >Int 0
+
+  rule <k> release V; => . ...</k> <holds>... V:Val |-> 0 => .Map ...</holds>
+       <busy>... SetItem(V) => .Set ...</busy>
+
+  rule <k> rendezvous V:Val; => . ...</k>
+       <k> rendezvous V; => . ...</k>  [group(rendezvous)]
+

Unchanged auxiliary operations from untyped SIMPLE

+ +
  syntax Stmt ::= mkDecls(Ids,Vals)  [function]
+  rule mkDecls((X:Id, Xs:Ids), (V:Val, Vs:Vals)) => var X=V; mkDecls(Xs,Vs)
+  rule mkDecls(.Ids,.Vals) => {}
+
+  // TODO(KORE): clarify sort inferences #1803
+  syntax Exp ::= lookup(Int)
+  /*
+  syntax KItem ::= lookup(Int)
+  */
+  rule <k> lookup(L) => V ...</k> <store>... L |-> V:Val ...</store>  [group(lookup)]
+
+  syntax KItem ::= setEnv(Map)
+  rule <k> setEnv(Env) => . ...</k>  <env> _ => Env </env>
+  rule (setEnv(_) => .) ~> setEnv(_)
+  // TODO: How can we make sure that the second rule above applies before the first one?
+  //       Probably we'll deal with this using strategies, eventually.
+
+  syntax Exp ::= lvalue(K)
+  syntax Val ::= loc(Int)
+
+  rule <k> lvalue(X:Id => loc(L)) ...</k> <env>... X |-> L:Int ...</env>
+
+  context lvalue(_::Exp[HOLE::Exps])
+  context lvalue(HOLE::Exp[_::Exps])
+
+  rule lvalue(lookup(L:Int) => loc(L))
+
+
+  syntax Map ::= Int "..." Int "|->" K
+    [function, latex({#1}\ldots{#2}\mapsto{#3})]
+  rule N...M |-> _ => .Map  when N >Int M
+  rule N...M |-> K => N |-> K (N +Int 1)...M |-> K  when N <=Int M
+

Changes to the existing untyped SIMPLE semantics

+ +

When we extend a language, sometimes we need to do more than just add
+new language constructs and semantics for them. Sometimes we want to
+also extend the semantics of existing language constructs, in order to
+get more from them.

+

Program initialization

+ +

In SIMPLE, once all the global declarations were processed, the
+function main() was invoked. In KOOL, the global
+declarations are classes, and their specific semantics is given
+shortly; essentially, they are pre-processed one by one and added
+into the class cell structure in the configuration.
+Once all the classes are processed, the computation item
+execute, which was placed right after the program in the
+initial configuration, is reached. In SIMPLE, the program was
+initialized by calling the method main(). In KOOL, the
+program is initialized by creating an object instance of class
+Main. This will also implicitly call the method
+Main() (the Main class constructor). The emptiness
+of the env cell below is just a sanity check, to make sure
+that the user has not declared anything but classes at the top level
+of the program.

+
  syntax KItem ::= "execute"
+  rule <k> execute => new Main(.Exps); </k> <env> .Map </env>
+

The semantics of new (defined below) requires the
+execution of all the class' declarations (and also of its
+superclasses').

+

Object and method closures

+ +

Before we can define the semantics of method application (previously
+called function application in SIMPLE), we need to add two more values
+to the language, namely object and method closures:

+
  syntax Val ::= objectClosure(Id, List)
+               | methodClosure(Id,Int,Ids,Stmt)
+

An object value consists of an objectClosure-wrapped bag
+containing the current class of the object and the environment stack
+of the object. The current class of an object will always be one of
+the classes mapped to an environment in the environment stack of the
+object. A method closure encapsulates the method's parameters and
+code (last two arguments), as well as the object context in which the
+method code should execute. This object context includes the current
+class of the object (the first argument of methodClosure) and
+the object environment stack (located in the object stored at the
+location specified as the second argument of methodClosure).

+

Method application

+ +

KOOL has a complex mechanism to invoke methods, because it allows both
+dynamic method dispatch and methods as first-class-citizen values (the
+latter making it a higher-order language). The invocation mechanism
+will be defined later. What is sufficient to know for now is that
+the two arguments of the application construct eventually reduce to
+values, the first being a method closure and the latter a list of
+values. The semantics of the method closure application is then as
+expected: the local environment and control are stacked, then we
+switch to method closure's class and object environment and execute
+the method body. The mkDecls construct is the one that came
+with the unchanged semantics of SIMPLE above.

+
  syntax KItem ::= fstackFrame(Map,K,List,K)
+  // TODO(KORE): drop the additional production once parsing issue #1842 is fixed
+                 | (Map,K,K)
+
+  rule <k> methodClosure(Class,OL,Xs,S)(Vs:Vals) ~> K
+           => mkDecls(Xs,Vs) S return; </k>
+       <env> Env => .Map </env>
+       <store>... OL |-> objectClosure(_, EnvStack)...</store>
+     //<br/> // TODO(KORE): support latex annotations #1799
+       <control>
+          <xstack> XS </xstack>
+          <fstack> .List => ListItem(fstackFrame(Env, K, XS, <crntObj> Obj' </crntObj>))
+          ...</fstack>
+          <crntObj> Obj' => <crntClass> Class </crntClass> <envStack> EnvStack </envStack> </crntObj>
+       </control>
+

Spawn

+ +

We want to extend the semantics of spawn to also share the
+current object environment with the child thread, in addition to the
+current environment. This extension will allow us to also use method
+invocations in the spawned statements, which will be thus looked up as
+expected, using dynamic method dispatch. This lookup operation would
+fail if the child thread did not have access to its parent's object
+environment.

+
  rule <thread>...
+         <k> spawn S => !T:Int ...</k>
+         <env> Env </env>
+         <crntObj> Obj </crntObj>
+       ...</thread>
+       (.Bag => <thread>...
+               <k> S </k>
+               <env> Env </env>
+               <id> !T </id>
+               <crntObj> Obj </crntObj>
+             ...</thread>)
+

Semantics of the new KOOL constructs

+ +

Class declaration

+ +

Initially, the classes forming the program are moved into their
+corresponding cells:

+
  rule <k> class Class1 extends Class2 { S } => . ...</k>
+       <classes>... (.Bag => <classData>
+                            <className> Class1 </className>
+                            <baseClass> Class2 </baseClass>
+                            <declarations> S </declarations>
+                        </classData>)
+       ...</classes>
+

Method declaration

+ +

Like in SIMPLE, method names are added to the environment and bound
+to their code. However, unlike in SIMPLE where each function was
+executed in the same environment, namely the program global
+environment, a method in KOOL needs to be executed into its object's
+environment. Thus, methods evaluate to closures, which encapsulate
+their object's context (i.e., the current class and environment stack
+of the object) in addition to method's parameters and body. This
+approach to bind method names to method closures in the environment
+will also allow objects to pass their methods to other objects, to
+dynamically change their methods by assigning them other method
+closures, and even to allow all these to be done from other objects.
+This gives the KOOL programmer a lot of power; one should use this
+power wisely, though, because programs can become easily hard to
+understand and reason about if one overuses these features.

+
  rule <k> method F:Id(Xs:Ids) S => . ...</k>
+       <crntClass> Class:Id </crntClass>
+       <location> OL:Int </location>
+       <env> Env => Env[F <- L] </env>
+       <store>... .Map => L |-> methodClosure(Class,OL,Xs,S) ...</store>
+       <nextLoc> L => L +Int 1 </nextLoc>
+

New

+ +

The semantics of new consists of two actions: memory
+allocation for the new object and execution of the corresponding
+constructor. Then the created object is returned as the result of the
+new operation; the value returned by the constructor, if any,
+is discarded. The current environment and object are stored onto the
+stack and recovered after new (according to the semantics of
+return borrowed from SIMPLE, when the statement
+return this; in the rule below is reached and evaluated),
+because the object creation part of new will destroy them.
+The rule below also initializes the object creation process by
+emptying the local environment and the current object, and allocating
+a location in the store where the created object will be eventually
+stored (this is what the storeObj task after the object
+creation task in the rule below will do—its rule is defined
+shortly). The location where the object will be stored is also made
+available in the crntObj cell, so that method closures can
+refer to it (see rule above).

+
  syntax KItem ::= "envStackFrame" "(" Id "," Map ")"
+
+  rule <k> new Class:Id(Vs:Vals) ~> K
+           => create(Class) ~> storeObj ~> Class(Vs); return this; </k>
+       <env> Env => .Map </env>
+       <nextLoc> L:Int => L +Int 1 </nextLoc>
+     //<br/> // TODO(KORE): support latex annotations #1799
+       <control> <xstack> XS </xstack>
+         <crntObj> Obj
+                   => <crntClass> Object </crntClass>
+                      <envStack> ListItem(envStackFrame(Object, .Map)) </envStack>
+                      <location> L </location>
+         </crntObj>
+         <fstack> .List => ListItem(fstackFrame(Env, K, XS, <crntObj> Obj </crntObj>)) ...</fstack>
+       </control>
+

The creation of a new object (the memory allocation part only) is
+a recursive process, requiring to first create an object for the
+superclass. A memory object representation is a layered structure:
+for each class on the path from the instance class to the root of the
+hierarchy there is a layer including the memory allocated for the
+members (both fields and methods) of that class.

+
  syntax KItem ::= create(Id)
+
+  rule <k> create(Class:Id)
+           => create(Class1) ~> setCrntClass(Class) ~> S ~> addEnvLayer ...</k>
+       <className> Class </className>
+       <baseClass> Class1:Id </baseClass>
+       <declarations> S </declarations>
+
+  rule <k> create(Object) => . ...</k>
+

The next operation sets the current class of the current object.
+This is necessary to be done at each layer, because the current class
+of the object is enclosed as part of the method closures (see the
+semantics of method declarations above).

+
  syntax KItem ::= setCrntClass(Id)
+
+  rule <k> setCrntClass(C) => . ...</k>
+       <crntClass> _ => C </crntClass>
+

The next operation adds a new tagged environment layer to the
+current object and gets ready for the next layer by clearing the
+environment (note that create expects the environment to be
+empty).

+
  syntax KItem ::= "addEnvLayer"
+
+  rule <k> addEnvLayer => . ...</k>
+       <env> Env => .Map </env>
+       <crntClass> Class:Id </crntClass>
+       <envStack> .List => ListItem(envStackFrame(Class, Env)) ...</envStack>
+

The following operation stores the created object at the location
+reserved by new. Note that the location reserved by
+new was temporarily stored in the crntObj cell
+precisely for this purpose. Now that the newly created object is
+stored at its location and that all method closures are aware of it,
+the location is unnecessary and thus we delete it from the
+crntObj cell.

+
  syntax KItem ::= "storeObj"
+
+  rule <k> storeObj => . ...</k>
+       <crntObj> <crntClass> CC </crntClass> <envStack> ES </envStack> (<location> L:Int </location> => .Bag) </crntObj>
+       <store>... .Map => L |-> objectClosure(CC, ES) ...</store>
+

Self reference

+ +

The semantics of this is straightforward: evaluate to the
+current object.

+
  rule <k> this => objectClosure(CC, ES) ...</k>
+       <crntObj> <crntClass> CC </crntClass> <envStack> ES </envStack> </crntObj>
+

Object member access

+ +

We can access an object member (field or method) either explicitly,
+using the construct e.x, or implicitly, using only the member
+name x directly. The borrowed semantics of SIMPLE will
+already lookup a sole name in the local environment. The first rule
+below reduces implicit member access to explicit access when the name
+cannot be found in the local environment. There are two cases to
+analyze for explicit object member access, depending upon whether the
+object is a proper object or it is just a redirection to the parent
+class via the construct super. In the first case, we
+evaluate the object expression and lookup the member starting with the
+current class (static scoping). Note the use of the conditional
+evaluation context. In the second case, we just lookup the member
+starting with the superclass of the current class. In both cases,
+the lookupMember task eventually yields a lookup(L)
+task for some appropriate location L, which will be further
+solved with the corresponding rule borrowed from SIMPLE. Note that the
+current object is not altered by super, so future method
+invocations see the entire object, as needed for dynamic method dispatch.

+
  rule <k> X:Id => this . X ...</k> <env> Env:Map </env>
+    when notBool(X in keys(Env))
+
+  context HOLE._::Id when (HOLE =/=K super)
+
+// TODO: explain how Assoc matching has been replaced with two rules here.
+// Maybe also improve it a bit.
+
+/*  rule objectClosure(<crntClass> Class:Id </crntClass>
+                     <envStack>... envStackFrame(Class,EnvC) EStack </envStack>)
+       . X:Id
+    => lookupMember(envStackFrame(Class,EnvC) EStack, X) */
+
+  rule objectClosure(Class:Id, ListItem(envStackFrame(Class,Env)) EStack)
+       . X:Id
+    => lookupMember(ListItem(envStackFrame(Class,Env)) EStack, X)
+  rule objectClosure(Class:Id, (ListItem(envStackFrame(Class':Id,_)) => .List) _)
+       . _X:Id
+    when Class =/=K Class'
+
+/*  rule <k> super . X => lookupMember(EStack, X) ...</k>
+       <crntClass> Class </crntClass>
+       <envStack>... envStackFrame(Class,EnvC) EStack </envStack> */
+  rule <k> super . X => lookupMember(EStack, X) ...</k>
+       <crntClass> Class:Id </crntClass>
+       <envStack> ListItem(envStackFrame(Class,_)) EStack </envStack>
+  rule <k> super . _X ...</k>
+       <crntClass> Class </crntClass>
+       <envStack> ListItem(envStackFrame(Class':Id,_)) => .List ...</envStack>
+    when Class =/=K Class'
+

Method invocation

+ +

Unlike in SIMPLE, in KOOL application was declared strict only in its
+second argument. That is because we want to ensure dynamic method
+dispatch when the first argument is a method access. As a
+consequence, we need to consider all the cases of interest for the
+first argument and to explicitly say what to do in each case. In all
+cases except for method access in a proper object (i.e., not
+super), we want the same behavior for the first argument as
+if it was not in a method invocation position. When it is a member
+access (the third rule below), we look it up starting with the
+instance class of the corresponding object. This ensures dynamic
+dispatch for methods; it actually dynamically dispatches field
+accesses, too, which is correct in KOOL, because one can assign method
+closures to fields and the field appeared in a method invocation
+context. The last context declaration below says that method
+applications or array accesses are also allowed as first argument to
+applications; that is because methods are allowed to return methods
+and arrays are allowed to hold methods in KOOL, since it is
+higher-order. If that is the case, then we want to evaluate the
+method call or the array access.

+
  rule <k> (X:Id => V)(_:Exps) ...</k>
+       <env>... X |-> L ...</env>
+       <store>... L |-> V:Val ...</store>  [group(lookup)]
+
+  rule <k> (X:Id => this . X)(_:Exps) ...</k>
+       <env> Env </env>
+    when notBool(X in keys(Env))
+
+  context HOLE._::Id(_) when HOLE =/=K super
+
+  rule (objectClosure(_, EStack) . X
+    => lookupMember(EStack, X:Id))(_:Exps)
+
+/*  rule <k> (super . X
+            => lookupMember(EStack,X))(_:Exps)...</k>
+       <crntClass> Class </crntClass>
+       <envStack>... envStackFrame(Class,_) EStack </envStack> */
+  rule <k> (super . X
+            => lookupMember(EStack,X))(_:Exps)...</k>
+       <crntClass> Class </crntClass>
+       <envStack> ListItem(envStackFrame(Class,_)) EStack </envStack>
+  rule <k> (super . _X)(_:Exps) ...</k>
+       <crntClass> Class </crntClass>
+       <envStack> ListItem(envStackFrame(Class':Id,_)) => .List ...</envStack>
+    when Class =/=K Class'
+
+  // TODO(KORE): fix getKLabel #1801
+  rule (A:Exp(B:Exps))(C:Exps) => A(B) ~> #freezerFunCall(C)
+  rule (A:Exp[B:Exps])(C:Exps) => A[B] ~> #freezerFunCall(C)
+  rule V:Val ~> #freezerFunCall(C:Exps) => V(C)
+  syntax KItem ::= "#freezerFunCall" "(" K ")"
+  /*
+  context HOLE(_:Exps)
+    when getKLabel(HOLE) ==K #klabel(`_(_)`) orBool getKLabel(HOLE) ==K #klabel(`_[_]`)
+  */
+

Eventually, each of the rules above produces a lookup(L)
+task as a replacement for the method. When that happens, we just
+lookup the value at location L:

+
  rule <k> (lookup(L) => V)(_:Exps) ...</k>  <store>... L |-> V:Val ...</store>
+    [group(lookup)]
+

The value V looked up above is expected to be a method closure,
+in which case the semantics of method application given above will
+apply. Otherwise, the execution will get stuck.

+

Instance Of

+ +

It searches the object environment for a layer corresponding to the
+desired class. It returns true iff it can find the class,
+otherwise it returns false; it only gets stuck when its first
+argument does not evaluate to an object.

+
  rule objectClosure(_, ListItem(envStackFrame(C,_)) _)
+       instanceOf C => true
+
+  rule objectClosure(_, (ListItem(envStackFrame(C,_)) => .List) _)
+       instanceOf C'  when C =/=K C'
+//TODO: remove the sort cast ::Id of C above, when sort inference bug fixed
+
+  rule objectClosure(_, .List) instanceOf _ => false
+

Cast

+ +

In untyped KOOL, we prefer to not check the validity of casting. In
+other words, any cast is allowed on any object, simply changing the
+current class of the object to the desired class. The execution will
+get stuck later if one attempts to access a field which is not
+available. Moreover, the execution may complete successfully even
+in the presence of invalid casts, provided that each accessed member
+during the current execution is, or happens to be, available.

+
  rule (C) objectClosure(_ , EnvStack) => objectClosure(C ,EnvStack)
+

KOOL-specific auxiliary declarations and operations

+ +

Here we define all the auxiliary constructs used in the above
+KOOL-specific semantics (those used in the SIMPLE fragment
+have already been defined in a corresponding section above).

+

Objects as lvalues

+ +

The current machinery borrowed with the semantics of SIMPLE allows us
+to enrich the set of lvalues, this way allowing new means to assign
+values to locations. In KOOL, we want object member names to be
+lvalues, so that we can assign values to them using the already
+existing machinery. The first rule below ensures that the object is
+always explicit, the evaluation context enforces the object to be
+evaluated, and finally the second rule initiates the lookup for the
+member's location based on the current class of the object.

+
  rule <k> lvalue(X:Id => this . X) ...</k>  <env> Env </env>
+    when notBool(X in keys(Env))
+
+  context lvalue((HOLE . _)::Exp)
+
+/*  rule lvalue(objectClosure(<crntClass> C </crntClass>
+                            <envStack>... envStackFrame(C,EnvC) EStack </envStack>)
+              . X
+              => lookupMember(<envStack> envStackFrame(C,EnvC) EStack </envStack>,
+                              X))  */
+  rule lvalue(objectClosure(Class, ListItem(envStackFrame(Class,Env)) EStack)
+              . X
+              => lookupMember(ListItem(envStackFrame(Class,Env)) EStack,
+                              X))
+  rule lvalue(objectClosure(Class, (ListItem(envStackFrame(Class':Id,_)) => .List) _)
+              . _X)
+    when Class =/=K Class'
+

Lookup member

+ +

It searches for the given member in the given environment stack,
+starting with the most concrete class and going up in the hierarchy.

+
  // TODO(KORE): clarify sort inferences #1803
+  syntax Exp ::= lookupMember(List, Id)  [function]
+  /*
+  syntax KItem ::= lookupMember(EnvStackCell,Id)  [function]
+  */
+
+//  rule lookupMember(<envStack> envStackFrame(_, <env>... X|->L ...</env>) ...</envStack>, X)
+//    => lookup(L)
+  rule lookupMember(ListItem(envStackFrame(_, X|->L _)) _, X)
+    => lookup(L)
+
+//  rule lookupMember(<envStack> envStackFrame(_, <env> Env </env>) => .List ...</envStack>, X)
+//    when notBool(X in keys(Env))
+  rule lookupMember(ListItem(envStackFrame(_, Env)) Rest, X) =>
+       lookupMember(Rest, X)
+    when notBool(X in keys(Env))
+//TODO: beautify the above
+
+endmodule
+

Go to Lesson 2, KOOL typed dynamic.

+

KOOL — Untyped

+ +

Author: Grigore Roșu (grosu@illinois.edu)
+Organization: University of Illinois at Urbana-Champaign

+

Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
+Organization: University of Bucharest

+

Abstract

+ +

This is the K semantic definition of the untyped KOOL language. KOOL
+is aimed at being a pedagogical and research language that captures
+the essence of the object-oriented programming paradigm. Its untyped
+variant discussed here is simpler than the typed one, ignoring several
+intricate aspects of types in the presence of objects. A program
+consists of a set of class declarations. Each class can extend at
+most one other class (KOOL is single-inheritance). A class can
+declare a set of fields and a set of methods, all public and called
+the class' members. Specifically, KOOL includes the
+following features:

+
    +
  • +

    Class declarations, where a class may or may not explicitly
    +extend another class. In case a class does not explicitly extend
    +another class, then it is assumed that it extends the default top-most
    +and empty (i.e., no members) class called Object. Each class
    +is required to declare precisely one homonymous method, called its
    +constructor. Each valid program should contain one class
    +named Main, whose constructor, Main(), takes no
    +arguments. The execution of a program consists of creating an object
    +instance of class Main and invoking the constructor
    +Main() on it, that is, of executing new Main();.

    +
  • +
  • +

    All features of SIMPLE (see examples/simple/untyped),
    +i.e., multidimensional arrays, function (here called "method")
    +abstractions with call-by-value parameter passing style and static
    +scoping, blocks with locals, input/output, parametric exceptions, and
    +concurrency via dynamic thread creation/termination and synchronization.
    +The only change in the syntax of SIMPLE when imported in KOOL is the
    +function declaration keyword, function, which is changed into
    +method. The exact same desugaring macros from SIMPLE are
    +also included in KOOL. We can think of KOOL's classes as embedding
    +SIMPLE programs (extended with OO constructs, as discussed next).

    +
  • +
  • +

    Object creation using the new C(e1,...,en)
    +expression construct. An object instance of class C is first
    +created and then the constructor C(e1,...,en) is implicitly
    +called on that object. KOOL only allows (and requires) one
    +constructor per class. The class constructor can be called either
    +implicitly during a new object creation for the class, or explicitly.
    +The superclass constructor is not implicitly invoked when a
    +class constructor is invoked; if you want to invoke the superclass
    +constructor from a subclass constructor then you have to do it
    +explicitly.

    +
  • +
  • +

    An expression construct this, which evaluates to the
    +current object.

    +
  • +
  • +

    An expression construct super, which is used (only) in
    +combination with member lookup (see next) to refer to a superclass
    +field or method.

    +
  • +
  • +

    A member lookup expression construct e.x, where e
    +is an expression (either an expression expected to evaluate to an object
    +or the super construct) and x is a class member name,
    +that is, a field or a method name.

    +
  • +
  • +

    Expression constructs e instanceOf C and
    +(C) e, where e is an expression expected
    +to evaluate to an object and C a class name. The former
    +tells whether the class of e is a subclass of C,
    +that is, whether e can be used as an instance of C,
    +and the latter changes the class of e to C. These
    +operations always succeed: the former returns a Boolean value, while
    +the latter changes the current class of e to C
    +regardless of whether it is safe to do so or not. The typed version
    +of KOOL will check the safety of casting by ensuring that the instance
    +class of the object is a subclass of C. In untyped KOOL we
    +do not want to perform this check because we want to allow the
    +programmer maximum of flexibility: if one always accesses only
    +available members, then the program can execute successfully despite
    +the potentially unsafe cast.

    +
  • +
+

There are some specific aspects of KOOL that need to be discussed.

+

First, KOOL is higher-order, allowing function abstractions to be
+treated like any other values in the language. For example, if
+m is a method of object e then e.m
+evaluates to the corresponding function abstraction. The function
+abstraction is in fact a closure, because in addition to the method
+parameters and body it also encapsulates the object value (i.e., the
+environment of the object together with its current class—see below)
+that e evaluates to. This way, function abstractions can be
+invoked anywhere and have the capability to change the state of their
+object. For example, if m is a method of object e
+which increments a field c of e when invoked, and if
+getm is another method of e which simply returns
+m when invoked, then the double application
+(e.getm())() has the same effect as e.m(), that is,
+increments the counter c of e. Note that the
+higher-order nature of KOOL was not originally planned; it came as a
+natural consequence of evaluating methods to closures and we decided
+to keep it. If you do not like it then do not use it.

+

Second, since all the fields and methods are public in KOOL and since
+they can be redeclared in subclasses, it is not immediately clear how
+to lookup the member x when we write e.x and
+e is different from super. We distinguish two cases,
+depending on whether e.x occurs in a method invocation
+context (i.e., e.x(...)) or in a field context. KOOL has
+dynamic method dispatch, so if e.x is invoked as a method
+then x will be searched for starting with the instance class of
+the object value to which e evaluates. If e.x
+occurs in a non-method-invocation context then x will be
+treated as a field (although it may hold a method closure due to the
+higher-order nature of KOOL) and thus will be searched starting with
+the current class of the object value of e (which, because of
+this and casting, may be different from its instance class).
+In order to achieve the above, each object value will consist of a
+pair holding the current class of the object and an environment stack
+with one layer for each class in the object's instance class hierarchy.

+

Third, although KOOL is dynamic method dispatch, its capabilities
+described above are powerful enough to allow us to mimic static
+method dispatch. For example, suppose that you want to invoke method
+m() statically. Then all you need to do is to declare a
+local variable and bind it to m, for example var staticm = m;, and
+then call staticm(). This works because
+staticm is first bound to the method closure that m
+evaluates to, and then looked up as any local variable when invoked.
+We only enable the dynamic method dispatch when we have an object
+member on an application position, e.g., m().

+

In what follows, we limit our comments to the new, KOOL-specific
+aspects of the language. We refer the reader to the untyped SIMPLE
+language for documentation on the the remaining features, because
+those were all borrowed from SIMPLE.

+
module KOOL-UNTYPED-SYNTAX
+  imports DOMAINS-SYNTAX
+

Syntax

+ +

The syntax of KOOL extends that of SIMPLE with object-oriented
+constructs. We removed from the K annotated syntax of SIMPLE two
+constructs, namely the one for function declarations (because we want
+to call them methods now) and the one for function application
+(because application is not strict in the first argument
+anymore—needs to initiate dynamic method dispatch). The additional
+syntax includes:

+
    +
  • First, we need a new dedicated identifier, Object, for
    +the default top-most class.
  • +
  • Second, we rename the function keyword of SIMPLE into method.
  • +
  • Third, we add syntax for class declarations together with a
    +macro making classes which extend nothing to extend Object.
  • +
  • Fourth, we change the strictness attribute of application
    +into strict(2).
  • +
  • Finally, we add syntax and corresponding strictness
    +for the KOOL object-oriented constructs.
  • +
+
  syntax Id ::= "Object" [token] | "Main" [token]
+
+  syntax Stmt ::= "var" Exps ";"
+                | "method" Id "(" Ids ")" Block  // called "function" in SIMPLE
+                | "class" Id Block               // KOOL
+                | "class" Id "extends" Id Block  // KOOL
+
+  syntax Exp ::= Int | Bool | String | Id
+               | "this"                                 // KOOL
+               | "super"                                // KOOL
+               | "(" Exp ")"             [bracket]
+               | "++" Exp
+               | Exp "instanceOf" Id     [strict(1)]    // KOOL
+               | "(" Id ")" Exp          [strict(2)]    // KOOL  cast
+               | "new" Id "(" Exps ")"   [strict(2)]    // KOOL
+               | Exp "." Id                             // KOOL
+               > Exp "[" Exps "]"        [strict]
+               > Exp "(" Exps ")"        [strict(2)]    // was strict in SIMPLE
+               | "-" Exp                 [strict]
+               | "sizeOf" "(" Exp ")"    [strict]
+               | "read" "(" ")"
+               > left:
+                 Exp "*" Exp             [strict, left]
+               | Exp "/" Exp             [strict, left]
+               | Exp "%" Exp             [strict, left]
+               > left:
+                 Exp "+" Exp             [strict, left]
+               | Exp "-" Exp             [strict, left]
+               > non-assoc:
+                 Exp "<" Exp             [strict, non-assoc]
+               | Exp "<=" Exp            [strict, non-assoc]
+               | Exp ">" Exp             [strict, non-assoc]
+               | Exp ">=" Exp            [strict, non-assoc]
+               | Exp "==" Exp            [strict, non-assoc]
+               | Exp "!=" Exp            [strict, non-assoc]
+               > "!" Exp                 [strict]
+               > left:
+                 Exp "&&" Exp            [strict(1), left]
+               | Exp "||" Exp            [strict(1), left]
+               > "spawn" Block
+               > Exp "=" Exp             [strict(2), right]
+
+  syntax Ids  ::= List{Id,","}
+
+  syntax Exps ::= List{Exp,","}          [strict, klabel(exps)]
+  syntax Val
+  syntax Vals ::= List{Val,","}          [klabel(exps)]
+
+  syntax Block ::= "{" "}"
+                | "{" Stmt "}"
+
+  syntax Stmt ::= Block
+                | Exp ";"                               [strict]
+                | "if" "(" Exp ")" Block "else" Block   [avoid, strict(1)]
+                | "if" "(" Exp ")" Block                [macro]
+                | "while" "(" Exp ")" Block
+                | "for" "(" Stmt Exp ";" Exp ")" Block  [macro]
+                | "return" Exp ";"                      [strict]
+                | "return" ";"                          [macro]
+                | "print" "(" Exps ")" ";"              [strict]
+                | "try" Block "catch" "(" Id ")" Block
+                | "throw" Exp ";"                       [strict]
+                | "join" Exp ";"                        [strict]
+                | "acquire" Exp ";"                     [strict]
+                | "release" Exp ";"                     [strict]
+                | "rendezvous" Exp ";"                  [strict]
+
+  syntax Stmt ::= Stmt Stmt                          [right]
+

Old desugaring rules, from SIMPLE

+
  rule if (E) S => if (E) S else {}
+  rule for(Start Cond; Step) {S} => {Start while (Cond) {S Step;}}
+  rule var E1::Exp, E2::Exp, Es::Exps; => var E1; var E2, Es;       [anywhere]
+  rule var X::Id = E; => var X; X = E;                              [anywhere]
+

New desugaring rule

+
  rule class C:Id S => class C extends Object S                     // KOOL
+
+endmodule
+

Semantics

+ +

We first discuss the new configuration of KOOL, which extends that of
+SIMPLE. Then we include the semantics of the constructs borrowed from
+SIMPLE unchanged; we refrain from discussing those, because they were
+already discussed in the K definition of SIMPLE. Then we discuss
+changes to SIMPLE's semantics needed for the more general meaning of
+the previous SIMPLE constructs (for example for thread spawning,
+assignment, etc.). Finally, we discuss in detail the
+semantics of the additional KOOL constructs.

+
module KOOL-UNTYPED
+  imports KOOL-UNTYPED-SYNTAX
+  imports DOMAINS
+

Configuration

+ +

KOOL removes one cell and adds two nested cells to the configuration
+of SIMPLE. The cell which is removed is the one holding the global
+environment, because a KOOL program consists of a set of classes only,
+with no global declarations. In fact, since informally speaking each
+KOOL class now includes a SIMPLE program, it is safe to say that the
+global variables in SIMPLE became class fields in KOOL. Let us now
+discuss the new cells that are added to the configuration of SIMPLE.

+
    +
  • +

    The cell crntObj holds data pertaining to the current
    +object, that is, the object environment in which the code in cell
    +k executes: crntClass holds the current class (which
    +can change as methods of the current object are invoked);
    +envStack holds the stack of environments as a list,
    +each layer corresponding to one class in the objects' instance class
    +hierarchy; location, which is optional, holds the location in
    +the store where the current object is or has to be located (this is
    +useful both for method closures and for the semantics of object
    +creation).

    +
  • +
  • +

    The cell classes holds all the declared classes, each
    +class being held in its own class cell which contains a name
    +(className), a parent (extends), and the actual
    +member declarations (declarations).

    +
  • +
+
  // the syntax declarations below are required because the sorts are
+  // referenced directly by a production and, because of the way KIL to KORE
+  // is implemented, the configuration syntax is not available yet
+  // should simply work once KIL is removed completely
+  // check other definitions for this hack as well
+  syntax EnvCell
+  syntax ControlCell
+  syntax EnvStackCell
+  syntax CrntObjCellFragment
+
+  configuration <T color="red">
+                  <threads color="orange">
+                    <thread multiplicity="*" type="Set" color="yellow">
+                      <k color="green"> $PGM:Stmt ~> execute </k>
+                    //<br/> // TODO(KORE): support latex annotations #1799
+                      <control color="cyan">
+                        <fstack color="blue"> .List </fstack>
+                        <xstack color="purple"> .List </xstack>
+                      //<br/> // TODO(KORE): support latex annotations #1799
+                        <crntObj color="Fuchsia">  // KOOL
+                           <crntClass> Object </crntClass>
+                           <envStack> .List </envStack>
+                           <location multiplicity="?"> .K </location>
+                        </crntObj>
+                      </control>
+                    //<br/> // TODO(KORE): support latex annotations #1799
+                      <env color="violet"> .Map </env>
+                      <holds color="black"> .Map </holds>
+                      <id color="pink"> 0 </id>
+                    </thread>
+                  </threads>
+                //<br/> // TODO(KORE): support latex annotations #1799
+                  <store color="white"> .Map </store>
+                  <busy color="cyan">.Set </busy>
+                  <terminated color="red"> .Set </terminated>
+                  <input color="magenta" stream="stdin"> .List </input>
+                  <output color="brown" stream="stdout"> .List </output>
+                  <nextLoc color="gray"> 0 </nextLoc>
+                //<br/> // TODO(KORE): support latex annotations #1799
+                  <classes color="Fuchsia">        // KOOL
+                     <classData multiplicity="*" type="Map" color="Fuchsia">
+                        // the Map has as its key the first child of the cell,
+                        // in this case the className cell.
+                        <className color="Fuchsia"> Main </className>
+                        <baseClass color="Fuchsia"> Object </baseClass>
+                        <declarations color="Fuchsia"> .K </declarations>
+                     </classData>
+                  </classes>
+                </T>
+

Unchanged Semantics from untyped SIMPLE

+ +

The semantics below is taken over from SIMPLE unchanged.
+The semantics of function declaration and invocation, including the
+use of the special lambda abstraction value, needs to change
+in order to account for the fact that methods are now invoked into
+their object's environment. The semantics of function return actually
+stays unchanged. Also, the semantics of program initialization is
+different: now we have to create an instance of the Main
+class which also calls the constructor Main(), while in
+SIMPLE we only had to invoke the function Main().
+Finally, the semantics of thread spawning needs to change, too: the
+parent thread needs to also share its object environment with the
+spawned thread (in addition to its local environment, like in SIMPLE).
+This is needed in order to be able to spawn method invokations under
+dynamic method dispatch; for example, spawn { run(); }
+will need to look up the method run() in the newly created
+thread, operation which will most likely fail unless the child thread
+sees the object environment of the parent thread. Note that the
+spawn statement of KOOL is more permissive than the threads
+of Java. In fact, the latter can be implemented in terms of our
+spawn—see the program threads.kool for a sketch.

+

Below is a subset of the values of SIMPLE, which are also values
+of KOOL. We will add other values later in the semantics, such as
+object and method closures.

+
  syntax Val ::= Int | Bool | String
+               | array(Int,Int)
+  syntax Exp ::= Val
+  syntax Exps ::= Vals
+  syntax KResult ::= Val
+  syntax KResult ::= Vals
+

The semantics below are taken verbatim from the untyped SIMPLE
+definition.

+
  syntax KItem ::= "undefined"  [latex(\bot)]
+
+  rule <k> var X:Id; => . ...</k>
+       <env> Env => Env[X <- L] </env>
+       <store>... .Map => L |-> undefined ...</store>
+       <nextLoc> L:Int => L +Int 1 </nextLoc>
+
+
+  context var _:Id[HOLE];
+
+  rule <k> var X:Id[N:Int]; => . ...</k>
+       <env> Env => Env[X <- L] </env>
+       <store>... .Map => L |-> array(L +Int 1, N)
+                          (L +Int 1) ... (L +Int N) |-> undefined ...</store>
+       <nextLoc> L:Int => L +Int 1 +Int N </nextLoc>
+    when N >=Int 0
+
+
+  syntax Id ::= "$1" [token] | "$2" [token]
+  rule var X:Id[N1:Int, N2:Int, Vs:Vals];
+    => var X[N1];
+       {
+         var $1=X;
+         for(var $2=0; $2 <= N1 - 1; ++$2) {
+           var X[N2,Vs];
+           $1[$2] = X;
+         }
+       }
+
+
+  rule <k> X:Id => V ...</k>
+       <env>... X |-> L ...</env>
+       <store>... L |-> V:Val ...</store>  [group(lookup)]
+
+
+  context ++(HOLE => lvalue(HOLE))
+  rule <k> ++loc(L) => I +Int 1 ...</k>
+       <store>... L |-> (I:Int => I +Int 1) ...</store>  [group(increment)]
+
+
+  rule I1 + I2 => I1 +Int I2
+  rule Str1 + Str2 => Str1 +String Str2
+  rule I1 - I2 => I1 -Int I2
+  rule I1 * I2 => I1 *Int I2
+  rule I1 / I2 => I1 /Int I2 when I2 =/=K 0
+  rule I1 % I2 => I1 %Int I2 when I2 =/=K 0
+  rule - I => 0 -Int I
+  rule I1 < I2 => I1 <Int I2
+  rule I1 <= I2 => I1 <=Int I2
+  rule I1 > I2 => I1 >Int I2
+  rule I1 >= I2 => I1 >=Int I2
+
+  rule V1:Val == V2:Val => V1 ==K V2
+  rule V1:Val != V2:Val => V1 =/=K V2
+  rule ! T => notBool(T)
+  rule true  && E => E
+  rule false && _ => false
+  rule true  || _ => true
+  rule false || E => E
+
+
+  rule V:Val[N1:Int, N2:Int, Vs:Vals] => V[N1][N2, Vs]
+    [anywhere]
+
+  rule array(L,_)[N:Int] => lookup(L +Int N)
+    [anywhere]
+
+
+  rule sizeOf(array(_,N)) => N
+

The semantics of function application needs to change into dynamic
+method dispatch invocation, which is defined shortly. However,
+interestingly, the semantics of return stays unchanged.

+
  rule <k> return(V:Val); ~> _ => V ~> K </k>
+       <control>
+         <fstack> ListItem(fstackFrame(Env,K,XS,<crntObj> CO </crntObj>)) => .List ...</fstack>
+         <xstack> _ => XS </xstack>
+         <crntObj> _ => CO </crntObj>
+       </control>
+       <env> _ => Env </env>
+
+  syntax Val ::= "nothing"
+  rule return; => return nothing;
+
+
+  rule <k> read() => I ...</k> <input> ListItem(I:Int) => .List ...</input>  [group(read)]
+
+
+  context (HOLE => lvalue(HOLE)) = _
+
+  rule <k> loc(L) = V:Val => V ...</k> <store>... L |-> (_ => V) ...</store>
+    [group(assignment)]
+
+
+  rule {} => .
+  rule <k> { S } => S ~> setEnv(Env) ...</k>  <env> Env </env>
+
+
+  rule S1::Stmt S2::Stmt => S1 ~> S2
+
+  rule _:Val; => .
+
+  rule if ( true) S else _ => S
+  rule if (false) _ else S => S
+
+  rule while (E) S => if (E) {S while(E)S}
+
+  rule <k> print(V:Val, Es => Es); ...</k> <output>... .List => ListItem(V) </output>
+    [group(print)]
+  rule print(.Vals); => .
+
+
+  syntax KItem ::= xstackFrame(Id,Stmt,K,Map,K)
+  // TODO(KORE): drop the additional production once parsing issue #1842 is fixed
+                 | (Id,Stmt,K,Map,K)
+
+  syntax KItem ::= "popx"
+
+  rule <k> (try S1 catch(X) {S2} => S1 ~> popx) ~> K </k>
+       <control>
+         <xstack> .List => ListItem(xstackFrame(X, S2, K, Env, C)) ...</xstack>
+         C
+       </control>
+       <env> Env </env>
+
+  rule <k> popx => . ...</k>
+       <xstack> ListItem(_) => .List ...</xstack>
+
+  rule <k> throw V:Val; ~> _ => { var X = V; S2 } ~> K </k>
+       <control>
+         <xstack> ListItem(xstackFrame(X, S2, K, Env, C)) => .List ...</xstack>
+         (_ => C)
+       </control>
+       <env> _ => Env </env>
+

Thread spawning needs a new semantics, because we want the child
+thread to also share the object environment with its parent. The new
+semantics of thread spawning will be defined shortly. However,
+interestingly, the other concurrency constructs keep their semantics
+from SIMPLE unchanged.

+
  // TODO(KORE): ..Bag should be . throughout this definition #1772
+  rule (<thread>... <k>.</k> <holds>H</holds> <id>T</id> ...</thread> => .Bag)
+  /*
+  rule (<thread>... <k>.</k> <holds>H</holds> <id>T</id> ...</thread> => .)
+  */
+       <busy> Busy => Busy -Set keys(H) </busy>
+       <terminated>... .Set => SetItem(T) ...</terminated>
+
+  rule <k> join T:Int; => . ...</k>
+       <terminated>... SetItem(T) ...</terminated>
+
+  rule <k> acquire V:Val; => . ...</k>
+       <holds>... .Map => V |-> 0 ...</holds>
+       <busy> Busy (.Set => SetItem(V)) </busy>
+    when (notBool(V in Busy:Set))  [group(acquire)]
+
+  rule <k> acquire V; => . ...</k>
+       <holds>... V:Val |-> (N:Int => N +Int 1) ...</holds>
+
+  rule <k> release V:Val; => . ...</k>
+       <holds>... V |-> (N => N:Int -Int 1) ...</holds>
+    when N >Int 0
+
+  rule <k> release V; => . ...</k> <holds>... V:Val |-> 0 => .Map ...</holds>
+       <busy>... SetItem(V) => .Set ...</busy>
+
+  rule <k> rendezvous V:Val; => . ...</k>
+       <k> rendezvous V; => . ...</k>  [group(rendezvous)]
+

Unchanged auxiliary operations from untyped SIMPLE

+ +
  syntax Stmt ::= mkDecls(Ids,Vals)  [function]
+  rule mkDecls((X:Id, Xs:Ids), (V:Val, Vs:Vals)) => var X=V; mkDecls(Xs,Vs)
+  rule mkDecls(.Ids,.Vals) => {}
+
+  // TODO(KORE): clarify sort inferences #1803
+  syntax Exp ::= lookup(Int)
+  /*
+  syntax KItem ::= lookup(Int)
+  */
+  rule <k> lookup(L) => V ...</k> <store>... L |-> V:Val ...</store>  [group(lookup)]
+
+  syntax KItem ::= setEnv(Map)
+  rule <k> setEnv(Env) => . ...</k>  <env> _ => Env </env>
+  rule (setEnv(_) => .) ~> setEnv(_)
+  // TODO: How can we make sure that the second rule above applies before the first one?
+  //       Probably we'll deal with this using strategies, eventually.
+
+  syntax Exp ::= lvalue(K)
+  syntax Val ::= loc(Int)
+
+  rule <k> lvalue(X:Id => loc(L)) ...</k> <env>... X |-> L:Int ...</env>
+
+  context lvalue(_::Exp[HOLE::Exps])
+  context lvalue(HOLE::Exp[_::Exps])
+
+  rule lvalue(lookup(L:Int) => loc(L))
+
+
+  syntax Map ::= Int "..." Int "|->" K
+    [function, latex({#1}\ldots{#2}\mapsto{#3})]
+  rule N...M |-> _ => .Map  when N >Int M
+  rule N...M |-> K => N |-> K (N +Int 1)...M |-> K  when N <=Int M
+

Changes to the existing untyped SIMPLE semantics

+ +

When we extend a language, sometimes we need to do more than just add
+new language constructs and semantics for them. Sometimes we want to
+also extend the semantics of existing language constructs, in order to
+get more from them.

+

Program initialization

+ +

In SIMPLE, once all the global declarations were processed, the
+function main() was invoked. In KOOL, the global
+declarations are classes, and their specific semantics is given
+shortly; essentially, they are pre-processed one by one and added
+into the class cell structure in the configuration.
+Once all the classes are processed, the computation item
+execute, which was placed right after the program in the
+initial configuration, is reached. In SIMPLE, the program was
+initialized by calling the method main(). In KOOL, the
+program is initialized by creating an object instance of class
+Main. This will also implicitly call the method
+Main() (the Main class constructor). The emptiness
+of the env cell below is just a sanity check, to make sure
+that the user has not declared anything but classes at the top level
+of the program.

+
  syntax KItem ::= "execute"
+  rule <k> execute => new Main(.Exps); </k> <env> .Map </env>
+

The semantics of new (defined below) requires the
+execution of all the class' declarations (and also of its
+superclasses').

+

Object and method closures

+ +

Before we can define the semantics of method application (previously
+called function application in SIMPLE), we need to add two more values
+to the language, namely object and method closures:

+
  syntax Val ::= objectClosure(Id, List)
+               | methodClosure(Id,Int,Ids,Stmt)
+

An object value consists of an objectClosure-wrapped bag
+containing the current class of the object and the environment stack
+of the object. The current class of an object will always be one of
+the classes mapped to an environment in the environment stack of the
+object. A method closure encapsulates the method's parameters and
+code (last two arguments), as well as the object context in which the
+method code should execute. This object context includes the current
+class of the object (the first argument of methodClosure) and
+the object environment stack (located in the object stored at the
+location specified as the second argument of methodClosure).

+

Method application

+ +

KOOL has a complex mechanism to invoke methods, because it allows both
+dynamic method dispatch and methods as first-class-citizen values (the
+latter making it a higher-order language). The invocation mechanism
+will be defined later. What is sufficient to know for now is that
+the two arguments of the application construct eventually reduce to
+values, the first being a method closure and the latter a list of
+values. The semantics of the method closure application is then as
+expected: the local environment and control are stacked, then we
+switch to method closure's class and object environment and execute
+the method body. The mkDecls construct is the one that came
+with the unchanged semantics of SIMPLE above.

+
  syntax KItem ::= fstackFrame(Map,K,List,K)
+  // TODO(KORE): drop the additional production once parsing issue #1842 is fixed
+                 | (Map,K,K)
+
+  rule <k> methodClosure(Class,OL,Xs,S)(Vs:Vals) ~> K
+           => mkDecls(Xs,Vs) S return; </k>
+       <env> Env => .Map </env>
+       <store>... OL |-> objectClosure(_, EnvStack)...</store>
+     //<br/> // TODO(KORE): support latex annotations #1799
+       <control>
+          <xstack> XS </xstack>
+          <fstack> .List => ListItem(fstackFrame(Env, K, XS, <crntObj> Obj' </crntObj>))
+          ...</fstack>
+          <crntObj> Obj' => <crntClass> Class </crntClass> <envStack> EnvStack </envStack> </crntObj>
+       </control>
+

Spawn

+ +

We want to extend the semantics of spawn to also share the
+current object environment with the child thread, in addition to the
+current environment. This extension will allow us to also use method
+invocations in the spawned statements, which will be thus looked up as
+expected, using dynamic method dispatch. This lookup operation would
+fail if the child thread did not have access to its parent's object
+environment.

+
  rule <thread>...
+         <k> spawn S => !T:Int ...</k>
+         <env> Env </env>
+         <crntObj> Obj </crntObj>
+       ...</thread>
+       (.Bag => <thread>...
+               <k> S </k>
+               <env> Env </env>
+               <id> !T </id>
+               <crntObj> Obj </crntObj>
+             ...</thread>)
+

Semantics of the new KOOL constructs

+ +

Class declaration

+ +

Initially, the classes forming the program are moved into their
+corresponding cells:

+
  rule <k> class Class1 extends Class2 { S } => . ...</k>
+       <classes>... (.Bag => <classData>
+                            <className> Class1 </className>
+                            <baseClass> Class2 </baseClass>
+                            <declarations> S </declarations>
+                        </classData>)
+       ...</classes>
+

Method declaration

+ +

Like in SIMPLE, method names are added to the environment and bound
+to their code. However, unlike in SIMPLE where each function was
+executed in the same environment, namely the program global
+environment, a method in KOOL needs to be executed into its object's
+environment. Thus, methods evaluate to closures, which encapsulate
+their object's context (i.e., the current class and environment stack
+of the object) in addition to method's parameters and body. This
+approach to bind method names to method closures in the environment
+will also allow objects to pass their methods to other objects, to
+dynamically change their methods by assigning them other method
+closures, and even to allow all these to be done from other objects.
+This gives the KOOL programmer a lot of power; one should use this
+power wisely, though, because programs can become easily hard to
+understand and reason about if one overuses these features.

+
  rule <k> method F:Id(Xs:Ids) S => . ...</k>
+       <crntClass> Class:Id </crntClass>
+       <location> OL:Int </location>
+       <env> Env => Env[F <- L] </env>
+       <store>... .Map => L |-> methodClosure(Class,OL,Xs,S) ...</store>
+       <nextLoc> L => L +Int 1 </nextLoc>
+

New

+ +

The semantics of new consists of two actions: memory
+allocation for the new object and execution of the corresponding
+constructor. Then the created object is returned as the result of the
+new operation; the value returned by the constructor, if any,
+is discarded. The current environment and object are stored onto the
+stack and recovered after new (according to the semantics of
+return borrowed from SIMPLE, when the statement
+return this; in the rule below is reached and evaluated),
+because the object creation part of new will destroy them.
+The rule below also initializes the object creation process by
+emptying the local environment and the current object, and allocating
+a location in the store where the created object will be eventually
+stored (this is what the storeObj task after the object
+creation task in the rule below will do—its rule is defined
+shortly). The location where the object will be stored is also made
+available in the crntObj cell, so that method closures can
+refer to it (see rule above).

+
  syntax KItem ::= "envStackFrame" "(" Id "," Map ")"
+
+  rule <k> new Class:Id(Vs:Vals) ~> K
+           => create(Class) ~> storeObj ~> Class(Vs); return this; </k>
+       <env> Env => .Map </env>
+       <nextLoc> L:Int => L +Int 1 </nextLoc>
+     //<br/> // TODO(KORE): support latex annotations #1799
+       <control> <xstack> XS </xstack>
+         <crntObj> Obj
+                   => <crntClass> Object </crntClass>
+                      <envStack> ListItem(envStackFrame(Object, .Map)) </envStack>
+                      <location> L </location>
+         </crntObj>
+         <fstack> .List => ListItem(fstackFrame(Env, K, XS, <crntObj> Obj </crntObj>)) ...</fstack>
+       </control>
+

The creation of a new object (the memory allocation part only) is
+a recursive process, requiring to first create an object for the
+superclass. A memory object representation is a layered structure:
+for each class on the path from the instance class to the root of the
+hierarchy there is a layer including the memory allocated for the
+members (both fields and methods) of that class.

+
  syntax KItem ::= create(Id)
+
+  rule <k> create(Class:Id)
+           => create(Class1) ~> setCrntClass(Class) ~> S ~> addEnvLayer ...</k>
+       <className> Class </className>
+       <baseClass> Class1:Id </baseClass>
+       <declarations> S </declarations>
+
+  rule <k> create(Object) => . ...</k>
+

The next operation sets the current class of the current object.
+This is necessary to be done at each layer, because the current class
+of the object is enclosed as part of the method closures (see the
+semantics of method declarations above).

+
  syntax KItem ::= setCrntClass(Id)
+
+  rule <k> setCrntClass(C) => . ...</k>
+       <crntClass> _ => C </crntClass>
+

The next operation adds a new tagged environment layer to the
+current object and gets ready for the next layer by clearing the
+environment (note that create expects the environment to be
+empty).

+
  syntax KItem ::= "addEnvLayer"
+
+  rule <k> addEnvLayer => . ...</k>
+       <env> Env => .Map </env>
+       <crntClass> Class:Id </crntClass>
+       <envStack> .List => ListItem(envStackFrame(Class, Env)) ...</envStack>
+

The following operation stores the created object at the location
+reserved by new. Note that the location reserved by
+new was temporarily stored in the crntObj cell
+precisely for this purpose. Now that the newly created object is
+stored at its location and that all method closures are aware of it,
+the location is unnecessary and thus we delete it from the
+crntObj cell.

+
  syntax KItem ::= "storeObj"
+
+  rule <k> storeObj => . ...</k>
+       <crntObj> <crntClass> CC </crntClass> <envStack> ES </envStack> (<location> L:Int </location> => .Bag) </crntObj>
+       <store>... .Map => L |-> objectClosure(CC, ES) ...</store>
+

Self reference

+ +

The semantics of this is straightforward: evaluate to the
+current object.

+
  rule <k> this => objectClosure(CC, ES) ...</k>
+       <crntObj> <crntClass> CC </crntClass> <envStack> ES </envStack> </crntObj>
+

Object member access

+ +

We can access an object member (field or method) either explicitly,
+using the construct e.x, or implicitly, using only the member
+name x directly. The borrowed semantics of SIMPLE will
+already lookup a sole name in the local environment. The first rule
+below reduces implicit member access to explicit access when the name
+cannot be found in the local environment. There are two cases to
+analyze for explicit object member access, depending upon whether the
+object is a proper object or it is just a redirection to the parent
+class via the construct super. In the first case, we
+evaluate the object expression and lookup the member starting with the
+current class (static scoping). Note the use of the conditional
+evaluation context. In the second case, we just lookup the member
+starting with the superclass of the current class. In both cases,
+the lookupMember task eventually yields a lookup(L)
+task for some appropriate location L, which will be further
+solved with the corresponding rule borrowed from SIMPLE. Note that the
+current object is not altered by super, so future method
+invocations see the entire object, as needed for dynamic method dispatch.

+
  rule <k> X:Id => this . X ...</k> <env> Env:Map </env>
+    when notBool(X in keys(Env))
+
+  context HOLE._::Id when (HOLE =/=K super)
+
+// TODO: explain how Assoc matching has been replaced with two rules here.
+// Maybe also improve it a bit.
+
+/*  rule objectClosure(<crntClass> Class:Id </crntClass>
+                     <envStack>... envStackFrame(Class,EnvC) EStack </envStack>)
+       . X:Id
+    => lookupMember(envStackFrame(Class,EnvC) EStack, X) */
+
+  rule objectClosure(Class:Id, ListItem(envStackFrame(Class,Env)) EStack)
+       . X:Id
+    => lookupMember(ListItem(envStackFrame(Class,Env)) EStack, X)
+  rule objectClosure(Class:Id, (ListItem(envStackFrame(Class':Id,_)) => .List) _)
+       . _X:Id
+    when Class =/=K Class'
+
+/*  rule <k> super . X => lookupMember(EStack, X) ...</k>
+       <crntClass> Class </crntClass>
+       <envStack>... envStackFrame(Class,EnvC) EStack </envStack> */
+  rule <k> super . X => lookupMember(EStack, X) ...</k>
+       <crntClass> Class:Id </crntClass>
+       <envStack> ListItem(envStackFrame(Class,_)) EStack </envStack>
+  rule <k> super . _X ...</k>
+       <crntClass> Class </crntClass>
+       <envStack> ListItem(envStackFrame(Class':Id,_)) => .List ...</envStack>
+    when Class =/=K Class'
+

Method invocation

+ +

Unlike in SIMPLE, in KOOL application was declared strict only in its
+second argument. That is because we want to ensure dynamic method
+dispatch when the first argument is a method access. As a
+consequence, we need to consider all the cases of interest for the
+first argument and to explicitly say what to do in each case. In all
+cases except for method access in a proper object (i.e., not
+super), we want the same behavior for the first argument as
+if it was not in a method invocation position. When it is a member
+access (the third rule below), we look it up starting with the
+instance class of the corresponding object. This ensures dynamic
+dispatch for methods; it actually dynamically dispatches field
+accesses, too, which is correct in KOOL, because one can assign method
+closures to fields and the field appeared in a method invocation
+context. The last context declaration below says that method
+applications or array accesses are also allowed as first argument to
+applications; that is because methods are allowed to return methods
+and arrays are allowed to hold methods in KOOL, since it is
+higher-order. If that is the case, then we want to evaluate the
+method call or the array access.

+
  rule <k> (X:Id => V)(_:Exps) ...</k>
+       <env>... X |-> L ...</env>
+       <store>... L |-> V:Val ...</store>  [group(lookup)]
+
+  rule <k> (X:Id => this . X)(_:Exps) ...</k>
+       <env> Env </env>
+    when notBool(X in keys(Env))
+
+  context HOLE._::Id(_) when HOLE =/=K super
+
+  rule (objectClosure(_, EStack) . X
+    => lookupMember(EStack, X:Id))(_:Exps)
+
+/*  rule <k> (super . X
+            => lookupMember(EStack,X))(_:Exps)...</k>
+       <crntClass> Class </crntClass>
+       <envStack>... envStackFrame(Class,_) EStack </envStack> */
+  rule <k> (super . X
+            => lookupMember(EStack,X))(_:Exps)...</k>
+       <crntClass> Class </crntClass>
+       <envStack> ListItem(envStackFrame(Class,_)) EStack </envStack>
+  rule <k> (super . _X)(_:Exps) ...</k>
+       <crntClass> Class </crntClass>
+       <envStack> ListItem(envStackFrame(Class':Id,_)) => .List ...</envStack>
+    when Class =/=K Class'
+
+  // TODO(KORE): fix getKLabel #1801
+  rule (A:Exp(B:Exps))(C:Exps) => A(B) ~> #freezerFunCall(C)
+  rule (A:Exp[B:Exps])(C:Exps) => A[B] ~> #freezerFunCall(C)
+  rule V:Val ~> #freezerFunCall(C:Exps) => V(C)
+  syntax KItem ::= "#freezerFunCall" "(" K ")"
+  /*
+  context HOLE(_:Exps)
+    when getKLabel(HOLE) ==K #klabel(`_(_)`) orBool getKLabel(HOLE) ==K #klabel(`_[_]`)
+  */
+

Eventually, each of the rules above produces a lookup(L)
+task as a replacement for the method. When that happens, we just
+lookup the value at location L:

+
  rule <k> (lookup(L) => V)(_:Exps) ...</k>  <store>... L |-> V:Val ...</store>
+    [group(lookup)]
+

The value V looked up above is expected to be a method closure,
+in which case the semantics of method application given above will
+apply. Otherwise, the execution will get stuck.

+

Instance Of

+ +

It searches the object environment for a layer corresponding to the
+desired class. It returns true iff it can find the class,
+otherwise it returns false; it only gets stuck when its first
+argument does not evaluate to an object.

+
  rule objectClosure(_, ListItem(envStackFrame(C,_)) _)
+       instanceOf C => true
+
+  rule objectClosure(_, (ListItem(envStackFrame(C,_)) => .List) _)
+       instanceOf C'  when C =/=K C'
+//TODO: remove the sort cast ::Id of C above, when sort inference bug fixed
+
+  rule objectClosure(_, .List) instanceOf _ => false
+

Cast

+ +

In untyped KOOL, we prefer to not check the validity of casting. In
+other words, any cast is allowed on any object, simply changing the
+current class of the object to the desired class. The execution will
+get stuck later if one attempts to access a field which is not
+available. Moreover, the execution may complete successfully even
+in the presence of invalid casts, provided that each accessed member
+during the current execution is, or happens to be, available.

+
  rule (C) objectClosure(_ , EnvStack) => objectClosure(C ,EnvStack)
+

KOOL-specific auxiliary declarations and operations

+ +

Here we define all the auxiliary constructs used in the above
+KOOL-specific semantics (those used in the SIMPLE fragment
+have already been defined in a corresponding section above).

+

Objects as lvalues

+ +

The current machinery borrowed with the semantics of SIMPLE allows us
+to enrich the set of lvalues, this way allowing new means to assign
+values to locations. In KOOL, we want object member names to be
+lvalues, so that we can assign values to them using the already
+existing machinery. The first rule below ensures that the object is
+always explicit, the evaluation context enforces the object to be
+evaluated, and finally the second rule initiates the lookup for the
+member's location based on the current class of the object.

+
  rule <k> lvalue(X:Id => this . X) ...</k>  <env> Env </env>
+    when notBool(X in keys(Env))
+
+  context lvalue((HOLE . _)::Exp)
+
+/*  rule lvalue(objectClosure(<crntClass> C </crntClass>
+                            <envStack>... envStackFrame(C,EnvC) EStack </envStack>)
+              . X
+              => lookupMember(<envStack> envStackFrame(C,EnvC) EStack </envStack>,
+                              X))  */
+  rule lvalue(objectClosure(Class, ListItem(envStackFrame(Class,Env)) EStack)
+              . X
+              => lookupMember(ListItem(envStackFrame(Class,Env)) EStack,
+                              X))
+  rule lvalue(objectClosure(Class, (ListItem(envStackFrame(Class':Id,_)) => .List) _)
+              . _X)
+    when Class =/=K Class'
+

Lookup member

+ +

It searches for the given member in the given environment stack,
+starting with the most concrete class and going up in the hierarchy.

+
  // TODO(KORE): clarify sort inferences #1803
+  syntax Exp ::= lookupMember(List, Id)  [function]
+  /*
+  syntax KItem ::= lookupMember(EnvStackCell,Id)  [function]
+  */
+
+//  rule lookupMember(<envStack> envStackFrame(_, <env>... X|->L ...</env>) ...</envStack>, X)
+//    => lookup(L)
+  rule lookupMember(ListItem(envStackFrame(_, X|->L _)) _, X)
+    => lookup(L)
+
+//  rule lookupMember(<envStack> envStackFrame(_, <env> Env </env>) => .List ...</envStack>, X)
+//    when notBool(X in keys(Env))
+  rule lookupMember(ListItem(envStackFrame(_, Env)) Rest, X) =>
+       lookupMember(Rest, X)
+    when notBool(X in keys(Env))
+//TODO: beautify the above
+
+endmodule
+

Go to Lesson 2, KOOL typed dynamic.

+

KOOL — Typed — Dynamic

+ +

Author: Grigore Roșu (grosu@illinois.edu)
+Organization: University of Illinois at Urbana-Champaign

+

Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
+Organization: University of Bucharest

+

Abstract

+ +

This is the K dynamic semantics of the typed KOOL language. It is
+very similar to the semantics of the untyped KOOL, the difference
+being that we now check the typing policy dynamically. Since we have
+to now declare the types of variables and methods, we adopt a syntax
+for those which is close to Java. Like in the semantics of
+untyped KOOL, where we borrowed almost all the semantics of untyped
+SIMPLE, we are going to also borrow much of the semantics of
+dynamically typed SIMPLE here. We will highlight the differences
+between the dynamically typed and the untyped KOOL as we proceed with
+the semantics. In general, the type policy of the typed KOOL language
+is similar to that of Java. You may find it useful to also read
+the discussion in the preamble of the static semantics of typed KOOL
+before proceeding.

+
module KOOL-TYPED-DYNAMIC-SYNTAX
+  imports DOMAINS-SYNTAX
+

Syntax

+ +

Like for the untyped KOOL language, the syntax of typed KOOL extends
+that of typed SIMPLE with object-oriented constructs.
+The syntax below was produced by copying and modifying/extending the
+syntax of dynamically typed SIMPLE. In fact, the only change we made
+to the existing syntax of dynamically typed SIMPLE was to change the
+strictness of the application construct like in untyped KOOL, from
+strict to strict(2) (because application is not
+strict in the first argument anymore due to dynamic method dispatch).
+The KOOL-specific syntactic extensions are identical to those in
+untyped KOOL.

+
  syntax Id ::= "Object" [token] | "Main" [token]
+

Types

+ +
  syntax Type ::= "void" | "int" | "bool" | "string"
+                | Id                              // KOOL class
+                | Type "[" "]"
+                | "(" Type ")"           [bracket]
+                > Types "->" Type
+  // TODO(KORE): drop klabel once issues #1913 are fixed
+  syntax Types ::= List{Type,","}   [klabel(_,_::Types)]
+  /*
+  syntax Types ::= List{Type,","}
+  */
+

Declarations

+ +
  syntax Param ::= Type Id
+  syntax Params ::= List{Param,","}
+
+  syntax Stmt ::= Type Exps ";" [avoid]
+                | Type Id "(" Params ")" Block    // stays like in typed SIMPLE
+                | "class" Id Block                // KOOL
+                | "class" Id "extends" Id Block   // KOOL
+

Expressions

+ +
  syntax Exp ::= Int | Bool | String | Id
+               | "this"                                 // KOOL
+               | "super"                                // KOOL
+               | "(" Exp ")"             [bracket]
+               | "++" Exp
+               | Exp "instanceOf" Id     [strict(1)]    // KOOL
+               | "(" Id ")" Exp          [strict(2)]    // KOOL  cast
+               | "new" Id "(" Exps ")"   [strict(2)]    // KOOL
+               | Exp "." Id                             // KOOL
+               > Exp "[" Exps "]"        [strict]
+               > Exp "(" Exps ")"        [strict(2)]    // was strict in SIMPLE
+               | "-" Exp                 [strict]
+               | "sizeOf" "(" Exp ")"    [strict]
+               | "read" "(" ")"
+               > left:
+                 Exp "*" Exp             [strict, left]
+               | Exp "/" Exp             [strict, left]
+               | Exp "%" Exp             [strict, left]
+               > left:
+                 Exp "+" Exp             [strict, left]
+               | Exp "-" Exp             [strict, left]
+               > non-assoc:
+                 Exp "<" Exp             [strict, non-assoc]
+               | Exp "<=" Exp            [strict, non-assoc]
+               | Exp ">" Exp             [strict, non-assoc]
+               | Exp ">=" Exp            [strict, non-assoc]
+               | Exp "==" Exp            [strict, non-assoc]
+               | Exp "!=" Exp            [strict, non-assoc]
+               > "!" Exp                 [strict]
+               > left:
+                 Exp "&&" Exp            [strict(1), left]
+               | Exp "||" Exp            [strict(1), left]
+               > "spawn" Block
+               > Exp "=" Exp             [strict(2), right]
+
+  syntax Exps ::= List{Exp,","}          [strict, klabel(exps)]
+  syntax Val
+  syntax Vals ::= List{Val,","}          [klabel(exps)]
+

Statements

+ +
  syntax Block ::= "{" "}"
+                | "{" Stmt "}"
+
+  syntax Stmt ::= Block
+                | Exp ";"                               [strict]
+                | "if" "(" Exp ")" Block "else" Block   [avoid, strict(1)]
+                | "if" "(" Exp ")" Block                [macro]
+                | "while" "(" Exp ")" Block
+                | "for" "(" Stmt Exp ";" Exp ")" Block  [macro]
+                | "print" "(" Exps ")" ";"              [strict]
+                | "return" Exp ";"                      [strict]
+                | "return" ";"
+                | "try" Block "catch" "(" Param ")" Block
+                | "throw" Exp ";"                       [strict]
+                | "join" Exp ";"                        [strict]
+                | "acquire" Exp ";"                     [strict]
+                | "release" Exp ";"                     [strict]
+                | "rendezvous" Exp ";"                  [strict]
+
+  syntax Stmt ::= Stmt Stmt                          [right]
+

Desugaring macros

+ +
  rule if (E) S => if (E) S else {}
+  rule for(Start Cond; Step) {S::Stmt} => {Start while(Cond){S Step;}}
+  rule T::Type E1::Exp, E2::Exp, Es::Exps; => T E1; T E2, Es;           [anywhere]
+  rule T::Type X::Id = E; => T X; X = E;                                [anywhere]
+
+  rule class C:Id S => class C extends Object S                     // KOOL
+
+endmodule
+

Semantics

+ +

We first discuss the new configuration, then we include the semantics of
+the constructs borrowed from SIMPLE which stay unchanged, then those
+whose semantics had to change, and finally the semantics of the
+KOOL-specific constructs.

+
module KOOL-TYPED-DYNAMIC
+  imports KOOL-TYPED-DYNAMIC-SYNTAX
+  imports DOMAINS
+

Configuration

+ +

The configuration of dynamically typed KOOL is almost identical to
+that of its untyped variant. The only difference is the cell
+return, inside the control cell, whose role is to
+hold the expected return type of the invoked method. That is because
+we want to dynamically check that the value that a method returns has
+the expected type.

+
  // the syntax declarations below are required because the sorts are
+  // referenced directly by a production and, because of the way KIL to KORE
+  // is implemented, the configuration syntax is not available yet
+  // should simply work once KIL is removed completely
+  // check other definitions for this hack as well
+  syntax EnvCell
+  syntax ControlCellFragment
+  syntax EnvStackCell
+  syntax CrntObjCellFragment
+
+  configuration <T color="red">
+                  <threads color="orange">
+                    <thread multiplicity="*" type="Set" color="yellow">
+                      <k color="green"> ($PGM:Stmt ~> execute) </k>
+                    //<br/> // TODO(KORE): support latex annotations #1799
+                      <control color="cyan">
+                        <fstack color="blue"> .List </fstack>
+                        <xstack color="purple"> .List </xstack>
+                        <returnType color="LimeGreen"> void </returnType>  // KOOL
+                      //<br/> // TODO(KORE): support latex annotations #1799
+                        <crntObj color="Fuchsia">  // KOOL
+                           <crntClass> Object </crntClass>
+                           <envStack> .List </envStack>
+                           <location multiplicity="?"> .K </location>
+                        </crntObj>
+                      </control>
+                    //<br/> // TODO(KORE): support latex annotations #1799
+                      <env color="violet"> .Map </env>
+                      <holds color="black"> .Map </holds>
+                      <id color="pink"> 0 </id>
+                    </thread>
+                  </threads>
+                //<br/> // TODO(KORE): support latex annotations #1799
+                  <store color="white"> .Map </store>
+                  <busy color="cyan">.Set </busy>
+                  <terminated color="red"> .Set </terminated>
+                  <input color="magenta" stream="stdin"> .List </input>
+                  <output color="brown" stream="stdout"> .List </output>
+                  <nextLoc color="gray"> 0 </nextLoc>
+                //<br/> // TODO(KORE): support latex annotations #1799
+                  <classes color="Fuchsia">        // KOOL
+                     <classData multiplicity="*" type="Map" color="Fuchsia">
+                        <className color="Fuchsia"> Main </className>
+                        <baseClass color="Fuchsia"> Object </baseClass>
+                        <declarations color="Fuchsia"> .K </declarations>
+                     </classData>
+                  </classes>
+                </T>
+

Unchanged semantics from dynamically typed SIMPLE

+ +

The semantics below is taken over from dynamically typed SIMPLE
+unchanged. Like for untyped KOOL, the semantics of function/method
+declaration and invocation, and of program initialization needs to
+change. Moreover, due to subtyping, the semantics of several imported
+SIMPLE constructs can be made more general, such as that of the
+return statement, that of the assignment, and that of the exceptions.
+We removed all these from the imported semantics of SIMPLE below and
+gave their modified semantics right after, together with the extended
+semantics of thread spawning (which is identical to that of untyped
+KOOL).

+
  syntax Val ::= Int | Bool | String
+               | array(Type,Int,Int)
+  syntax Exp ::= Val
+  syntax Exps ::= Vals
+  syntax KResult ::= Val
+  syntax KResult ::= Vals
+
+
+  syntax KItem ::= undefined(Type)  [latex(\bot_{#1})]
+
+  rule <k> T:Type X:Id; => . ...</k>
+       <env> Env => Env[X <- L] </env>
+       <store>... .Map => L |-> undefined(T) ...</store>
+       <nextLoc> L:Int => L +Int 1 </nextLoc>
+
+
+  rule <k> T:Type X:Id[N:Int]; => . ...</k>
+       <env> Env => Env[X <- L] </env>
+       <store>... .Map => L |-> array(T, L +Int 1, N)
+                          (L +Int 1)...(L +Int N) |-> undefined(T) ...</store>
+       <nextLoc> L:Int => L +Int 1 +Int N </nextLoc>
+    requires N >=Int 0
+
+  context _:Type _::Exp[HOLE::Exps];
+
+
+  syntax Id ::= "$1" [token] | "$2" [token]
+  rule T:Type X:Id[N1:Int, N2:Int, Vs:Vals];
+    => T[]<Vs> X[N1];
+       {
+         T[][]<Vs> $1=X;
+         for(int $2=0; $2 <= N1 - 1; ++$2) {
+           T X[N2,Vs];
+           $1[$2] = X;
+         }
+       }
+
+
+  rule <k> X:Id => V ...</k>
+       <env>... X |-> L ...</env>
+       <store>... L |-> V:Val ...</store>  [group(lookup)]
+
+
+  context ++(HOLE => lvalue(HOLE))
+  rule <k> ++loc(L) => I +Int 1 ...</k>
+       <store>... L |-> (I:Int => I +Int 1) ...</store>  [group(increment)]
+
+
+  rule I1 + I2 => I1 +Int I2
+  rule Str1 + Str2 => Str1 +String Str2
+  rule I1 - I2 => I1 -Int I2
+  rule I1 * I2 => I1 *Int I2
+  rule I1 / I2 => I1 /Int I2 requires I2 =/=K 0
+  rule I1 % I2 => I1 %Int I2 requires I2 =/=K 0
+  rule - I => 0 -Int I
+  rule I1 < I2 => I1 <Int I2
+  rule I1 <= I2 => I1 <=Int I2
+  rule I1 > I2 => I1 >Int I2
+  rule I1 >= I2 => I1 >=Int I2
+  rule V1:Val == V2:Val => V1 ==K V2
+  rule V1:Val != V2:Val => V1 =/=K V2
+  rule ! T => notBool(T)
+  rule true  && E => E
+  rule false && _ => false
+  rule true  || _ => true
+  rule false || E => E
+
+
+  rule V:Val[N1:Int, N2:Int, Vs:Vals] => V[N1][N2, Vs]
+    [anywhere]
+
+  rule array(_:Type, L:Int, M:Int)[N:Int] => lookup(L +Int N)
+    requires N >=Int 0 andBool N <Int M  [anywhere]
+
+  rule sizeOf(array(_,_,N)) => N
+
+
+  syntax Val ::= nothing(Type)
+  rule <k> return; => return nothing(T); ...</k> <returnType> T </returnType>
+
+
+  rule <k> read() => I ...</k> <input> ListItem(I:Int) => .List ...</input>  [group(read)]
+
+
+  context (HOLE => lvalue(HOLE)) = _
+
+
+  rule {} => .
+  rule <k> { S } => S ~> setEnv(Env) ...</k>  <env> Env </env>
+
+
+  rule S1:Stmt S2:Stmt => S1 ~> S2
+
+
+  rule _:Val; => .
+
+
+  rule if ( true) S else _ => S
+  rule if (false) _ else S => S
+
+
+  rule while (E) S => if (E) {S while(E)S}
+
+
+  rule <k> print(V:Val, Es => Es); ...</k> <output>... .List => ListItem(V) </output>
+    requires typeOf(V) ==K int orBool typeOf(V) ==K string  [group(print)]
+  rule print(.Vals); => .
+
+
+  rule (<thread>... <k>.</k> <holds>H</holds> <id>T</id> ...</thread> => .Bag)
+       <busy> Busy => Busy -Set keys(H) </busy>
+       <terminated>... .Set => SetItem(T) ...</terminated>
+
+  rule <k> join T:Int; => . ...</k>
+       <terminated>... SetItem(T) ...</terminated>
+
+  rule <k> acquire V:Val; => . ...</k>
+       <holds>... .Map => V |-> 0 ...</holds>
+       <busy> Busy (.Set => SetItem(V)) </busy>
+    requires (notBool(V in Busy:Set))  [group(acquire)]
+
+  rule <k> acquire V; => . ...</k>
+       <holds>... V:Val |-> (N:Int => N +Int 1) ...</holds>
+
+  rule <k> release V:Val; => . ...</k>
+       <holds>... V |-> (N => N:Int -Int 1) ...</holds>
+    requires N >Int 0
+
+  rule <k> release V; => . ...</k> <holds>... V:Val |-> 0 => .Map ...</holds>
+       <busy>... SetItem(V) => .Set ...</busy>
+
+  rule <k> rendezvous V:Val; => . ...</k>
+       <k> rendezvous V; => . ...</k>  [group(rendezvous)]
+

Unchanged auxiliary operations from dynamically typed SIMPLE

+ +
  syntax Stmt ::= mkDecls(Params,Vals)  [function]
+  rule mkDecls((T:Type X:Id, Ps:Params), (V:Val, Vs:Vals))
+    => T X=V; mkDecls(Ps,Vs)
+  rule mkDecls(.Params,.Vals) => {}
+
+  syntax Exp ::= lookup(Int)
+  rule <k> lookup(L) => V ...</k> <store>... L |-> V:Val ...</store>  [group(lookup)]
+
+  syntax KItem ::= setEnv(Map)
+  rule <k> setEnv(Env) => . ...</k>  <env> _ => Env </env>
+  rule (setEnv(_) => .) ~> setEnv(_)
+
+  syntax Exp ::= lvalue(K)
+  syntax Val ::= loc(Int)
+  rule <k> lvalue(X:Id => loc(L)) ...</k>  <env>... X |-> L:Int ...</env>
+
+  context lvalue(_::Exp[HOLE::Exps])
+  context lvalue(HOLE::Exp[_::Exps])
+
+  rule lvalue(lookup(L:Int) => loc(L))
+
+  syntax Type ::= Type "<" Vals ">"  [function]
+  rule T:Type<_,Vs:Vals> => T[]<Vs>
+  rule T:Type<.Vals> => T
+
+  syntax Map ::= Int "..." Int "|->" K
+    [function, latex({#1}\ldots{#2}\mapsto{#3})]
+  rule N...M |-> _ => .Map  requires N >Int M
+  rule N...M |-> K => N |-> K (N +Int 1)...M |-> K  requires N <=Int M
+
+  syntax Type ::= typeOf(K)  [function]
+  rule typeOf(_:Int) => int
+  rule typeOf(_:Bool) => bool
+  rule typeOf(_:String) => string
+  rule typeOf(array(T,_,_)) => (T[])
+  rule typeOf(undefined(T)) => T
+  rule typeOf(nothing(T)) => T
+
+  syntax Types ::= getTypes(Params)  [function]
+  rule getTypes(T:Type _:Id) => T, .Types
+  rule getTypes(T:Type _:Id, P, Ps) => T, getTypes(P,Ps)
+  rule getTypes(.Params) => void, .Types
+

Changes to the existing dynamically typed SIMPLE semantics

+ +

We extend/change the semantics of several SIMPLE constructs in order
+to take advantage of the richer KOOL semantic infrastructure and thus
+get more from the existing SIMPLE constructs.

+

Program initialization

+ +

Like in untyped KOOL.

+
  syntax KItem ::= "execute"
+  rule <k> execute => new Main(.Exps); </k> <env> .Map </env>
+

Method application

+ +

The only change to untyped KOOL's values is that method closures are
+now typed (their first argument holds their type):

+
 syntax Val ::= objectClosure(Id,List)
+              | methodClosure(Type,Id,Int,Params,Stmt)
+

The type held by a method clossure will be the entire type of the
+method, not only its result type like the lambda-closure of typed
+SIMPLE. The reason for this change comes from the the need to
+dynamically upcast values when passed to contexts where values of
+superclass types are expected; since we want method closures to be
+first-class-citizen values in our language, we have to be able to
+dynamically upcast them, and in order to do that elegantly it is
+convenient to store the entire ``current type'' of the method closure
+instead of just its result type. Note that this was unnecessary in
+the semantics of the dynamically typed SIMPLE language.

+

Method closure application needs to also set a new return type in
+the return cell, like in dynamically typed SIMPLE, in order
+for the values returned by its body to be checked against the return
+type of the method. To do this correctly, we also need to stack the
+current status of the return cell and then pop it when the
+method returns. We have to do the same with the current object
+environment, so we group them together in the stack frame.

+
  syntax KItem ::= fstackFrame(Map, K, List, Type, K)
+
+  rule <k> methodClosure(_->T,Class,OL,Ps,S)(Vs:Vals) ~> K
+           => mkDecls(Ps,Vs) S return; </k>
+       <env> Env => .Map </env>
+       <store>... OL |-> objectClosure(_, EStack)...</store>
+     //<br/> // TODO(KORE): support latex annotations #1799
+       <control>
+          <fstack> .List => ListItem(fstackFrame(Env, K, XS, T', <crntObj> Obj' </crntObj>)) ...</fstack>
+          <xstack> XS </xstack>
+          <returnType> T' => T </returnType>
+          <crntObj> Obj' => <crntClass> Class </crntClass> <envStack> EStack </envStack> </crntObj>
+       </control>
+

At method return, we have to check that the type of the returned
+value is a subtype of the expected return type. Moreover, if that is
+the case, then we also upcast the returned value to one of the
+expected type. The computation item unsafeCast(V,T) changes
+the typeof V to T without any additional checks; however, it only
+does it when V is an object or a method, otherwise it returns V
+unchanged.

+
  rule <k> return V:Val; ~> _
+           => subtype(typeOf(V), T) ~> true? ~> unsafeCast(V, T) ~> K
+       </k>
+       <control>
+         <fstack> ListItem(fstackFrame(Env, K, XS, RT, <crntObj> CO </crntObj>)) => .List ...</fstack>
+         <xstack> _ => XS </xstack>
+         <returnType> T:Type => RT </returnType>
+         <crntObj> _ => CO </crntObj>
+       </control>
+       <env> _ => Env </env>
+

Assignment

+ +

Typed KOOL allows to assign subtype instance values to supertype
+lvalues. The semantics of assignment below is similar in spirit to
+dynamically typed SIMPLE's, but a check is performed that the assigned
+value's type is a subtype of the location's type. If that is the
+case, then the assigned value is returned as a result and stored, but
+it is upcast appropriately first, so the context will continue to see
+a value of the expected type of the location. Note that the type of a
+location is implicit in the type of its contents and it never changes
+during the execution of a program; its type is assigned when the
+location is allocated and initialized, and then only type-preserving
+values are allowed to be stored in each location.

+
  rule <k> loc(L) = V:Val
+           => subtype(typeOf(V),typeOf(V')) ~> true?
+              ~> unsafeCast(V, typeOf(V')) ...</k>
+       <store>... L |-> (V' => unsafeCast(V, typeOf(V'))) ...</store>
+    [group(assignment)]
+

Typed exceptions

+ +

Exceptions are propagated now until a catch that can handle them is
+encountered.

+
  syntax KItem ::= xstackFrame(Param, Stmt, K, Map, K)
+  syntax KItem ::= "popx"
+
+  rule <k> (try S1 catch(P) S2 => S1 ~> popx) ~> K </k>
+       <control>
+         <xstack> .List => ListItem(xstackFrame(P, S2, K, Env, C)) ...</xstack>
+         C
+       </control>
+       <env> Env </env>
+
+  rule <k> popx => . ...</k>
+       <xstack> ListItem(_) => .List ...</xstack>
+
+  rule <k> throw V:Val; ~> _
+        => if (subtype(typeOf(V),T)) { T X = V; S2 } else { throw V; } ~> K
+       </k>
+       <control>
+         <xstack> ListItem(xstackFrame(T:Type X:Id, S2, K, Env, C)) => .List ...</xstack>
+         (_ => C)
+       </control>
+       <env> _ => Env </env>
+

Spawn

+ +

Like in untyped KOOL.

+
  rule <thread>...
+         <k> spawn S => !T:Int ...</k>
+         <env> Env </env>
+         <crntObj> Obj </crntObj>
+       ...</thread>
+       (.Bag => <thread>...
+               <k> S </k>
+               <env> Env </env>
+               <id> !T </id>
+               <crntObj> Obj </crntObj>
+             ...</thread>)
+

Semantics of the new KOOL constructs

+ +

Class declaration

+ +

Like in untyped KOOL.

+
  rule <k> class Class1 extends Class2 { S } => . ...</k>
+       <classes>... (.Bag => <classData>
+                            <className> Class1 </className>
+                            <baseClass> Class2 </baseClass>
+                            <declarations> S </declarations>
+                        </classData>)
+       ...</classes>
+

Method declaration

+ +

Methods are now typed and we need to store their types in their
+closures, so that their type contract can be checked at invocation
+time. The rule below is conceptually similar to that of untyped KOOL;
+the only difference is the addition of the types.

+
  rule <k> T:Type F:Id(Ps:Params) S => . ...</k>
+       <crntClass> C </crntClass>
+       <location> OL </location>
+       <env> Env => Env[F <- L] </env>
+       <store>... .Map => L|->methodClosure(getTypes(Ps)->T,C,OL,Ps,S) ...</store>
+       <nextLoc> L => L +Int 1 </nextLoc>
+

New

+ +

The semantics of new in dynamically typed KOOL is also
+similar to that in untyped KOOL, the main difference being the
+management of the return types. Indeed, when a new object is created
+we also have to stack the current type in the return cell in
+order to be recovered after the creation of the new object. Only the
+first rule below needs to be changed; the others are identical to
+those in untyped KOOL.

+
  syntax KItem ::= envStackFrame(Id, Map)
+
+  rule <k> new Class:Id(Vs:Vals) ~> K
+           => create(Class) ~> (storeObj ~> ((Class(Vs)); return this;)) </k>
+       <env> Env => .Map </env>
+       <nextLoc> L:Int => L +Int 1 </nextLoc>
+     //<br/> // TODO(KORE): support latex annotations #1799
+       <control>
+         <xstack> XS </xstack>
+         <crntObj> Obj
+                   => <crntClass> Object </crntClass>
+                      <envStack> ListItem(envStackFrame(Object, .Map)) </envStack>
+                      <location> L </location>
+         </crntObj>
+         <returnType> T => Class </returnType>
+         <fstack> .List => ListItem(fstackFrame(Env, K, XS, T, <crntObj>Obj</crntObj>)) ...</fstack>
+       </control>
+
+  syntax KItem ::= create(Id)
+
+  rule <k> create(Class:Id)
+           => create(Class1) ~> setCrntClass(Class) ~> S ~> addEnvLayer ...</k>
+       <className> Class </className>
+       <baseClass> Class1:Id </baseClass>
+       <declarations> S </declarations>
+
+  rule <k> create(Object) => . ...</k>
+
+  syntax KItem ::= setCrntClass(Id)
+
+  rule <k> setCrntClass(C) => . ...</k>
+       <crntClass> _ => C </crntClass>
+
+  syntax KItem ::= "addEnvLayer"
+
+  rule <k> addEnvLayer => . ...</k>
+       <env> Env => .Map </env>
+       <crntClass> Class:Id </crntClass>
+       <envStack> .List => ListItem(envStackFrame(Class, Env)) ...</envStack>
+
+  syntax KItem ::= "storeObj"
+
+  rule <k> storeObj => . ...</k>
+       <crntObj>
+         <crntClass> Class </crntClass>
+         <envStack> EStack </envStack>
+         (<location> L:Int </location> => .Bag)
+       </crntObj>
+       <store>... .Map => L |-> objectClosure(Class, EStack) ...</store>
+

Self reference

+ +

Like in untyped KOOL.

+
  rule <k> this => objectClosure(Class, EStack) ...</k>
+       <crntObj>
+         <crntClass> Class </crntClass>
+         <envStack> EStack </envStack>
+         ...
+       </crntObj>
+

Object member access

+ +

Like in untyped KOOL.

+
  rule <k> X:Id => this . X ...</k> <env> Env:Map </env>
+    requires notBool(X in keys(Env))
+
+  context HOLE . _::Id requires (HOLE =/=K super)
+
+/*  rule objectClosure(<crntObj> <crntClass> Class:Id </crntClass>
+                     <envStack>... ListItem((Class,EnvC:EnvCell)) EStack </envStack> </crntObj>)
+       . X:Id
+    => lookupMember(<envStack> ListItem((Class,EnvC)) EStack </envStack>, X) */
+  rule objectClosure(Class:Id,
+                     ListItem(envStackFrame(Class,Env)) EStack)
+       . X:Id
+    => lookupMember(ListItem(envStackFrame(Class,Env)) EStack, X)
+  rule objectClosure(Class:Id,
+                     (ListItem(envStackFrame(Class':Id,_)) => .List) _EStack)
+       . _X:Id
+    requires Class =/=K Class'
+
+/*  rule <k> super . X => lookupMember(<envStack>EStack</envStack>, X) ...</k>
+       <crntClass> Class </crntClass>
+       <envStack>... ListItem((Class,EnvC:EnvCell)) EStack </envStack> */
+  rule <k> super . X => lookupMember(EStack, X) ...</k>
+       <crntClass> Class:Id </crntClass>
+       <envStack> ListItem(envStackFrame(Class,_)) EStack </envStack>
+  rule <k> super . _X ...</k>
+       <crntClass> Class:Id </crntClass>
+       <envStack> (ListItem(envStackFrame(Class':Id,_)) => .List) _EStack </envStack>
+    requires Class =/=K Class'
+

Method invocation

+ +

The method lookup is the same as in untyped KOOL.

+
  rule <k> (X:Id => V)(_:Exps) ...</k>
+       <env>... X |-> L ...</env>
+       <store>... L |-> V:Val ...</store>  [group(lookup)]
+
+  rule <k> (X:Id => this . X)(_:Exps) ...</k>
+       <env> Env </env>
+    requires notBool(X in keys(Env))
+
+  context HOLE._::Id(_) requires HOLE =/=K super
+
+  rule (objectClosure(_, EStack) . X
+    => lookupMember(EStack, X:Id))(_:Exps)
+
+/*  rule <k> (super . X
+            => lookupMember(<envStack>EStack</envStack>,X))(_:Exps)...</k>
+       <crntClass> Class </crntClass>
+       <envStack>... ListItem((Class,_)) EStack </envStack> */
+  rule <k> (super . X
+            => lookupMember(EStack,X))(_:Exps)...</k>
+       <crntClass> Class:Id </crntClass>
+       <envStack> ListItem(envStackFrame(Class,_)) EStack </envStack>
+  rule <k> (super . _X)(_:Exps)...</k>
+       <crntClass> Class:Id </crntClass>
+       <envStack> (ListItem(envStackFrame(Class':Id,_)) => .List) _EStack </envStack>
+    requires Class =/=K Class'
+
+  // TODO(KORE): fix getKLabel #1801
+  rule (A:Exp(B:Exps))(C:Exps) => A(B) ~> #freezerFunCall(C)
+  rule (A:Exp[B:Exps])(C:Exps) => A[B] ~> #freezerFunCall(C)
+  rule V:Val ~> #freezerFunCall(C:Exps) => V(C)
+  syntax KItem ::= "#freezerFunCall" "(" K ")"
+  /*
+  context HOLE(_:Exps)
+    requires getKLabel HOLE ==KLabel '_`(_`) orBool getKLabel HOLE ==KLabel '_`[_`]
+  */
+
+  rule <k> (lookup(L) => V)(_:Exps) ...</k>  <store>... L |-> V:Val ...</store>
+    [group(lookup)]
+

Instance of

+ +

Like in untyped KOOL.

+
  rule objectClosure(_, ListItem(envStackFrame(C,_)) _)
+       instanceOf C => true
+
+  rule objectClosure(_, (ListItem(envStackFrame(C::Id,_)) => .List) _)
+       instanceOf C'  requires C =/=K C'
+
+  rule objectClosure(_, .List) instanceOf _ => false
+

Cast

+ +

Unlike in untyped KOOL, in typed KOOL we actually check that the object
+can indeed be cast to the claimed type.

+
  rule (C:Id) objectClosure(Irrelevant, EStack)
+    => objectClosure(Irrelevant, EStack) instanceOf C ~> true?
+       ~> objectClosure(C, EStack)
+

KOOL-specific auxiliary declarations and operations

+ +

Objects as lvalues

+ +

Like in untyped KOOL.

+
  rule <k> lvalue(X:Id => this . X) ...</k>  <env> Env </env>
+    requires notBool(X in keys(Env))
+
+  context lvalue((HOLE . _)::Exp)
+
+/*  rule lvalue(objectClosure(<crntObj> <crntClass> C </crntClass>
+                            <envStack>... ListItem((C,EnvC:EnvCell)) EStack </envStack> </crntObj>)
+              . X
+              => lookupMember(<envStack> ListItem((C,EnvC)) EStack </envStack>,
+                              X)) */
+  rule lvalue(objectClosure(C:Id,
+                            ListItem(envStackFrame(C,Env)) EStack)
+              . X
+              => lookupMember(ListItem(envStackFrame(C,Env)) EStack,
+                              X))
+  rule lvalue(objectClosure(C,
+                            (ListItem(envStackFrame(C',_)) => .List) _EStack)
+              . _X)
+    requires C =/=K C'
+

Lookup member

+ +

Like in untyped KOOL.

+
  syntax Exp ::= lookupMember(List,Id)  [function]
+
+  rule lookupMember(ListItem(envStackFrame(_, X |-> L _)) _, X) => lookup(L)
+
+  // TODO: fix rule below as shown once we support functions with deep rewrites
+  // rule lookupMember(<envStack> ListItem((_, <env> Env </env>)) => .List
+  //                     ...</envStack>, X)
+  //   requires notBool(X in keys(Env))
+  rule lookupMember(ListItem(envStackFrame(_, Env)) L, X)
+    => lookupMember(L, X)
+    requires notBool(X in keys(Env))
+

typeOf for the additional values}

+ +
  rule typeOf(objectClosure(C,_)) => C
+  rule typeOf(methodClosure(T:Type,_,_,_Ps:Params,_)) => T
+

Subtype checking

+ +

The subclass relation induces a subtyping relation.

+
  syntax Exp ::= subtype(Types,Types)
+
+  rule subtype(T:Type, T) => true
+
+  rule <k> subtype(C1:Id, C:Id) => subtype(C2, C) ...</k>
+       <className> C1 </className>
+       <baseClass> C2:Id </baseClass>
+    requires C1 =/=K C
+
+  rule subtype(Object,Class:Id) => false
+    requires Class =/=K Object
+
+  rule subtype(Ts1->T2,Ts1'->T2') => subtype(((T2)::Type,Ts1'),((T2')::Type,Ts1))
+
+// Note that the following rule would be wrong!
+//  rule subtype(T[],T'[]) => subtype(T,T')
+
+  rule subtype((T:Type,Ts),(T':Type,Ts')) => subtype(T,T') && subtype(Ts,Ts')
+    requires Ts =/=K .Types
+  rule subtype(.Types,.Types) => true
+

Unsafe Casting

+ +

Performs unsafe casting. One should only use it in combination with
+the subtype relation above.

+
  syntax Val ::= unsafeCast(Val,Type)  [function]
+
+  rule unsafeCast(objectClosure(_,EStack), C:Id)
+    => objectClosure(C,EStack)
+
+  rule unsafeCast(methodClosure(_T',C,OL,Ps,S), T) => methodClosure(T,C,OL,Ps,S)
+
+  rule unsafeCast(V:Val, T:Type) => V  requires typeOf(V) ==K T
+

Generic guard

+ +

A generic computational guard: it allows the computation to continue
+only if a prefix guard evaluates to true.

+
  syntax KItem ::= "true?"
+  rule true ~> true? => .
+
+endmodule
+

Go to Lesson 3, KOOL typed static.

+

KOOL — Typed — Static

+ +

Author: Grigore Roșu (grosu@illinois.edu)
+Organization: University of Illinois at Urbana-Champaign

+

Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
+Organization: University of Bucharest

+

Abstract

+ +

This is the K static semantics of the typed KOOL language.
+It extends the static semantics of typed SIMPLE with static semantics
+for the object-oriented constructs. Also, the static semantics of
+some of the existing SIMPLE constructs need to change, in order to
+become more generous with regards to the set of accepted programs,
+mostly due to subtyping. For example, the assignment construct
+x = e required that both the variable x and the
+expression e had the same type in SIMPLE. In KOOL, the type
+of e can be a subtype of the type of x.
+Specifically, we define the following typing policy for KOOL,
+everything else not mentioned below borrowing its semantics from
+SIMPLE:

+
    +
  • +

    Each class C yields a homonymous type, which can be
    +explicitly used in programs to type variables and methods, possibly in
    +combination with other types.

    +
  • +
  • +

    Since now we have user-defined types, we check that each type
    +used in a KOOL program is well-formed, that is, it is constructed only
    +from primitive and class types corresponding to declared classes.

    +
  • +
  • +

    Class members and their types form a class type
    +environment
    . Each class will have such a type environment.
    +Each member in a class is allowed to be declared only once. Since in
    +KOOL we allow methods to be assigned to fields, we make no distinction
    +between field and method members; in other words, we reject programs
    +declaring both a field and a method with the same name.

    +
  • +
  • +

    If an identifier is not found in the local type environment, it
    +will be searched for in the current class type environment. If not
    +there, then it will be searched for in its superclass' type
    +environment. And so on and so forth. If not found until the
    +Object class is reached, a typing error is reported.

    +
  • +
  • +

    The assignment allows variables to be assigned values of
    +more concrete types. The result type of the assignment expression
    +construct will be the (more abstract) type of the assigned variable,
    +and not the (more concrete) type of the expression, like in Java.

    +
  • +
  • +

    Exceptions are changed (from SIMPLE) to allow throwing and
    +catching only objects, like in Java. Also, unlike in SIMPLE, we do
    +not check whether the type of the thrown exception matches the type of
    +the caught variable, because exceptions can be caught by other
    +try/catch blocks, even by ones in other methods. To avoid
    +having to annotate each method with what exceptions it can throw, we
    +prefer to not check the type safety of exceptions (although this is an
    +excellent homework!). We only check that the try block
    +type-checks and that the catch block type-checks after we bind
    +the caught variable to its claimed type.

    +
  • +
  • +

    Class declarations are not allowed to have any cycles in their
    +extends relation. Such cycles would lead to non-termination of
    +new, as it actually does in the dynamic semantics of KOOL
    +where no such circularity checks are performed.

    +
  • +
  • +

    Methods overriding other methods should be in the right subtyping
    +relationship with the overridden methods: co-variant in the codomain
    +and contra-variant in the domain.

    +
  • +
+
module KOOL-TYPED-STATIC-SYNTAX
+  imports DOMAINS-SYNTAX
+

Syntax

+ +

The syntax of statically typed KOOL is identical to that of
+dynamically typed KOOL, they both taking as input the same programs.
+What differs is the K strictness attributes. Like in statically
+typed SIMPLE, almost all language constructs are strict now, since we
+want each to type its arguments almost all the time. Like in the
+other two KOOL definitions, we prefer to copy and then modify/extend
+the syntax of statically typed SIMPLE.

+

Note: This paragraph is old, now we can do things better. We keep
+it here only for historical reasons, to see how much we used to suffer 😃

+

Annoying K-tool technical problem:
+Currently, the K tool treats the "non-terminal" productions (i.e.,
+productions consisting of just one non-terminal), also called
+"subsorting" production, differently from the other productions.
+Specifically, it does not insert a node in the AST for them. This may
+look desirable at first, but it has a big problem: it does not allow
+us to treat the subsort differently in different context. For
+example, since we want Id to be both a type (a class name) and a
+program variable, and since we want expressions to reduce to their
+types, we are in an impossible situations in which we do not know how
+to treat an identifier in the semantics: as a type, i.e., a result of
+computations, or as a program variable, i.e., a non-result. Ideally,
+we would like to tag the identifiers at parse-time with their local
+interpretation, but that, unfortunately, is not possible with the
+current parsing capabilities of the K tool, because it requires to
+insert additional information in the AST for the subsort productions.
+This will be fixed soon. Until then, unfortunately, we have to do the
+job of the parser manually. Instead of subsorting Id directly
+to Type, we "wrap" it first, say with a wrapper called
+class(...), exactly how the parser should have done.
+The major drawback of this is that all the typed KOOL programs
+in kool/typed/programs need to also be modified to always
+declare class types accordingly. The modified programs can be found
+in kool/typed/static/programs. So make sure you execute the
+static semantics of KOOL using the modified programs. To avoid seeing
+the wrapper in the generated documentation, we associate it an
+"invisibility" latex attribute below.

+
  syntax Id ::= "Object" [token] | "Main" [token]
+

Types

+ +
  syntax Type ::= "void" | "int" | "bool" | "string"
+                | Id                     [klabel("class"), symbol, avoid]  // see next
+                | Type "[" "]"
+                | "(" Type ")"           [bracket]
+                > Types "->" Type
+
+  syntax Types ::= List{Type,","}        [klabel(exps)]
+

Declarations

+ +
  syntax Param ::= Type Id
+  syntax Params ::= List{Param,","}
+
+  syntax Stmt ::= Type Exps ";" [avoid]
+                | Type Id "(" Params ")" Block
+                | "class" Id Block
+                | "class" Id "extends" Id Block
+

Expressions

+ +
  syntax FieldReference ::= Exp "." Id          [strict(1)]
+  syntax ArrayReference ::= Exp "[" Exps "]"    [strict]
+
+  syntax Exp ::= Int | Bool | String | Id
+               | "this"
+               | "super"
+               | "(" Exp ")"             [bracket]
+               | "++" Exp
+               | Exp "instanceOf" Id     [strict(1)]
+               | "(" Id ")" Exp          [strict(2)]
+               | "new" Id "(" Exps ")"   [strict(2)]
+               > Exp "(" Exps ")"        [strict]
+               | "-" Exp                 [strict]
+               | "sizeOf" "(" Exp ")"    [strict]
+               | "read" "(" ")"
+               > left:
+                 Exp "*" Exp             [strict, left]
+               | Exp "/" Exp             [strict, left]
+               | Exp "%" Exp             [strict, left]
+               > left:
+                 Exp "+" Exp             [strict, left]
+               | Exp "-" Exp             [strict, left]
+               > non-assoc:
+                 Exp "<" Exp             [strict, non-assoc]
+               | Exp "<=" Exp            [strict, non-assoc]
+               | Exp ">" Exp             [strict, non-assoc]
+               | Exp ">=" Exp            [strict, non-assoc]
+               | Exp "==" Exp            [strict, non-assoc]
+               | Exp "!=" Exp            [strict, non-assoc]
+               > "!" Exp                 [strict]
+               > left:
+                 Exp "&&" Exp            [strict, left]
+               | Exp "||" Exp            [strict, left]
+               > "spawn" Block  // not strict: to check return and exceptions
+               > Exp "=" Exp             [strict(2), right]
+
+  syntax Exp ::= FieldReference | ArrayReference
+  syntax priority _.__KOOL-TYPED-STATIC-SYNTAX > _[_]_KOOL-TYPED-STATIC-SYNTAX > _(_)_KOOL-TYPED-STATIC-SYNTAX
+
+  syntax Exps ::= List{Exp,","}          [strict, klabel(exps)]
+

Statements

+ +
  syntax Block ::= "{" "}"
+                | "{" Stmt "}"
+
+  syntax Stmt ::= Block
+                | Exp ";"                                 [strict]
+                | "if" "(" Exp ")" Block "else" Block     [avoid, strict]
+                | "if" "(" Exp ")" Block                  [macro]
+                | "while" "(" Exp ")" Block               [strict]
+                | "for" "(" Stmt Exp ";" Exp ")" Block    [macro]
+                | "return" Exp ";"                        [strict]
+                | "return" ";"
+                | "print" "(" Exps ")" ";"                [strict]
+                | "try" Block "catch" "(" Param ")" Block [strict(1)]
+                | "throw" Exp ";"                         [strict]
+                | "join" Exp ";"                          [strict]
+                | "acquire" Exp ";"                       [strict]
+                | "release" Exp ";"                       [strict]
+                | "rendezvous" Exp ";"                    [strict]
+
+  syntax Stmt ::= Stmt Stmt                            [seqstrict, right]
+

Desugaring macros

+ +
  rule if (E) S => if (E) S else {}
+  rule for(Start Cond; Step) {S:Stmt} => {Start while(Cond){S Step;}}
+  rule T:Type E1:Exp, E2:Exp, Es:Exps; => T E1; T E2, Es;               [anywhere]
+  rule T:Type X:Id = E; => T X; X = E;                                  [anywhere]
+
+  rule class C:Id S => class C extends Object S
+
+endmodule
+

Static semantics

+ +

We first discuss the configuration, then give the static semantics
+taken over unchanged from SIMPLE, then discuss the static semantics of
+SIMPLE syntactic constructs that needs to change, and in the end we
+discuss the static semantics and additional checks specifically
+related to the KOOL proper syntax.

+
module KOOL-TYPED-STATIC
+  imports KOOL-TYPED-STATIC-SYNTAX
+  imports DOMAINS
+

Configuration

+ +

The configuration of our type system consists of a tasks
+cell with the same meaning like in statically typed SIMPLE, of an
+out cell streamed to the standard output that will be used to
+display typing error messages, and of a cell classes holding
+data about each class in a separate class cell. The
+task cells now have two additional optional subcells, namely
+ctenvT and inClass. The former holds a temporary
+class type environment; its contents will be transferred into the
+ctenv cell of the corresponding class as soon as all the
+fields and methods in the task are processed. In fact, there will be
+three types of tasks in the subsequent semantics, each determined by
+the subset of cells that it holds:

+
    +
  1. +

    Main task, holding only a k cell holding the
    +original program as a set of classes. The role of this task is to
    +process each class, generating a class task (see next) for each.

    +
  2. +
  3. +

    Class task, holding k, ctenvT, and
    +inClass subcells. The role of this task type is to process
    +a class' contents, generating a class type environment in the
    +ctenvT cell and a method task (see next) for each method in
    +the class. To avoid interference with object member lookup rules
    +below, it is important to add the class type environment to a class
    +atomically; this is the reason for which we use ctenvT
    +temporary cells within class tasks (instead of adding each member
    +incrementally to the class' type environment).

    +
  4. +
  5. +

    Method task, holding k, tenv and
    +return cells. These tasks are similar to SIMPLE's function
    +tasks, so we do not discuss them here any further.

    +
  6. +
+

Each class cell hods its name (in the className
+cell) and the name of the class it extends (in the extends
+cell), as well as its type environment (in the ctenv cell)
+and the set of all its superclasses (in the extendsAll cell).
+The later is useful for example for checking whether there are cycles
+in the class extends relation.

+
  configuration <T multiplicity="?" color="yellow">
+                  <tasks color="orange" multiplicity="?">
+                    <task multiplicity="*" color="yellow" type="Set">
+                      <k color="green"> $PGM:Stmt </k>
+                      <tenv multiplicity="?" color="cyan"> .Map </tenv>
+                      <ctenvT multiplicity="?" color="blue"> .Map </ctenvT>
+                      <returnType multiplicity="?" color="black"> void </returnType>
+                      <inClass multiplicity="?" color="Fuchsia"> .K </inClass>
+                    </task>
+                  </tasks>
+//                  <br/>
+                  <classes color="Fuchsia">
+                    <classData multiplicity="*" type="Map">
+                      <className color="Fuchsia"> Object </className>
+                      <baseClass color="Fuchsia"> .K </baseClass>
+                      <baseClasses color="Fuchsia"> .Set </baseClasses>
+                      <ctenv multiplicity="?" color="blue"> .Map </ctenv>
+                    </classData>
+                  </classes>
+                </T>
+                <output color="brown" stream="stdout"> .List </output>
+

Unchanged semantics from statically typed SIMPLE

+ +

The syntax and rules below are borrowed unchanged from statically
+typed SIMPLE, so we do not discuss them much here.

+
  syntax Exp ::= Type
+  syntax Exps ::= Types
+  syntax BlockOrStmtType ::= "block" | "stmt"
+  syntax Type ::= BlockOrStmtType
+  syntax Block ::= BlockOrStmtType
+  syntax KResult ::= Type
+                   | Types  // TODO: should not be needed
+
+
+  context _:Type _::Exp[HOLE::Exps];
+
+  rule T:Type E:Exp[int,Ts:Types]; => T[] E[Ts];
+  rule T:Type E:Exp[.Types]; => T E;
+
+
+  rule <task>... <k> _:BlockOrStmtType </k> <tenv> _ </tenv> ...</task> => .Bag
+
+
+  rule _:Int => int
+  rule _:Bool => bool
+  rule _:String => string
+
+
+  rule <k> X:Id => T ...</k> <tenv>... X |-> T ...</tenv>
+
+
+  context ++(HOLE => ltype(HOLE))
+  rule ++ int => int
+  rule int + int => int
+  rule string + string => string
+  rule int - int => int
+  rule int * int => int
+  rule int / int => int
+  rule int % int => int
+  rule - int => int
+  rule int < int => bool
+  rule int <= int => bool
+  rule int > int => bool
+  rule int >= int => bool
+  rule T:Type == T => bool
+  rule T:Type != T => bool
+  rule bool && bool => bool
+  rule bool || bool => bool
+  rule ! bool => bool
+
+
+  rule (T[])[int, Ts:Types] => T[Ts]
+  rule T:Type[.Types] => T
+
+  rule sizeOf(_T[]) => int
+
+
+  rule read() => int
+
+  rule print(T:Type, Ts => Ts); when T ==K int orBool T ==K string
+  rule print(.Types); => stmt
+
+
+  context (HOLE => ltype(HOLE)) = _
+
+
+  rule <k> return; => stmt ...</k> <returnType> _ </returnType>
+
+
+  rule {} => block
+
+  rule <task> <k> {S:Stmt} => block ...</k> <tenv> Rho </tenv> R </task>
+       (.Bag => <task> <k> S </k> <tenv> Rho </tenv> R </task>)
+
+  rule _:Type; => stmt
+  rule if (bool) block else block => stmt
+  rule while (bool) block => stmt
+
+  rule join int; => stmt
+  rule acquire _:Type; => stmt
+  rule release _:Type; => stmt
+  rule rendezvous _:Type; => stmt
+
+  syntax Stmt ::= BlockOrStmtType
+  rule _:BlockOrStmtType _:BlockOrStmtType => stmt
+

Unchanged auxiliary operations from dynamically typed SIMPLE

+ +
  syntax Stmt ::= mkDecls(Params)  [function]
+  rule mkDecls(T:Type X:Id, Ps:Params) => T X; mkDecls(Ps)
+  rule mkDecls(.Params) => {}
+
+  syntax LValue ::= Id
+                  | FieldReference
+                  | ArrayReference
+  syntax Exp ::= LValue
+
+  syntax Exp ::= ltype(Exp)
+// We would like to say:
+//  context ltype(HOLE:LValue)
+// but we currently cannot type the HOLE
+  context ltype(HOLE) when isLValue(HOLE)
+
+// OLD approach:
+//  syntax Exp ::= ltype(Exp)  [function]
+//  rule ltype(X:Id) => X
+//  rule ltype(E:Exp [Es:Exps]) => E[Es]
+
+  syntax Types ::= getTypes(Params)  [function]
+  rule getTypes(T:Type _:Id) => T, .Types
+  rule getTypes(T:Type _:Id, P, Ps) => T, getTypes(P,Ps)
+  rule getTypes(.Params) => void, .Types
+

Changes to the existing statically typed SIMPLE semantics

+ +

Below we give the new static semantics for language constructs that
+come from SIMPLE, but whose SIMPLE static semantics was too
+restrictive or too permissive and thus had to change.

+

Local variable declaration

+ +

Since we can define new types in KOOL (corresponding to classes), the
+variable declaration needs to now check that the claimed types exist.
+The operation checkType, defined at the end of this module,
+checks whether the argument type is correct (it actually works with
+lists of types as well).

+
  rule <k> T:Type X:Id; => checkType(T) ~> stmt ...</k>
+       <tenv> Rho => Rho[X <- T] </tenv>
+

Class member declaration

+ +

In class tasks, variable declarations mean class member declarations.
+Since we reduce method declarations to variable declarations (see
+below), a variable declaration in a class task can mean either a field
+or a method declaration. Unlike local variable declarations, which
+can shadow previous homonymous local or member declarations, member
+declarations are regarded as a set, so we disallow multiple
+declarations for the same member (one could improve upon this, like in
+Java, by treating members with different types or number of arguments
+as different, etc., but we do not do it here). We also issue an error
+message if one attempts to redeclare the same class member. The
+framed variable declaration in the second rule below should be read
+"stuck". In fact, it is nothing but a unary operation called
+stuck, which takes a K-term as argument and does nothing
+with it; this stuck operation is displayed as a frame in this
+PDF document because of its latex attribute (see the ASCII .k file,
+at the end of this module).

+
  rule <k> T:Type X:Id; => checkType(T) ~> stmt ...</k>
+       <ctenvT> Rho (.Map => X |-> T) </ctenvT>
+    when notBool(X in keys(Rho))
+
+  rule <k> T:Type X:Id; => stuck(T X;) ...</k>
+       <ctenvT>... X |-> _ ...</ctenvT>
+       <inClass> C:Id </inClass>
+//       <br/>
+       <output>... .List => ListItem("Member \"" +String Id2String(X)
+                              +String "\" declared twice in class \""
+                              +String Id2String(C) +String "\"!\n") </output>
+

Method declaration

+ +

A method declaration requires two conceptual checks to be performed:
+first, that the method's type is consistent with the type of the
+homonymous method that it overrides, if any; and second, that its body
+types correctly. At the same time, it should also be added to the
+type environment of its class. The first conceptual task is performed
+using the checkMethod operation defined below, and the second
+by generating a corresponding method task. To add it to the class
+type environment, we take advantage of the fact that KOOL is higher
+order and reduce the problem to a field declaration problem, which we
+have already defined. The role of the ctenvT cell in the
+rule below is to structurally ensure that the method declaration takes
+place in a class task (we do not want to allow methods to be declared,
+for example, inside other methods).

+
  rule <k> T:Type F:Id(Ps:Params) S
+        => checkMethod(F, getTypes(Ps)->T, C')
+           ~> getTypes(Ps)->T F; ...</k>
+//       <br/>
+       <inClass> C </inClass>
+       <ctenvT> _ </ctenvT> // to ensure we are in a class pass
+       <className> C </className>
+       <baseClass> C' </baseClass>
+//       <br/>
+       (.Bag => <task>
+               <k> mkDecls(Ps) S </k>
+               <inClass> C </inClass>
+               <tenv> .Map </tenv>
+               <returnType> T </returnType>
+             </task>)
+

Assignment

+ +

A more concrete value is allowed to be assigned to a more abstract
+variable. The operation checkSubtype is defined at the end
+of the module and it also works with pairs of lists of types.

+
  rule T:Type = T':Type => checkSubtype(T', T) ~> T
+

Method invocation and return

+ +

Methods can be applied on values of more concrete types than their
+arguments:

+
  rule (Ts:Types -> T:Type) (Ts':Types) => checkSubtype(Ts',Ts) ~> T
+

Similarly, we allow values of more concrete types to be returned by
+methods:

+
  rule <k> return T:Type; => checkSubtype(T,T') ~> stmt ...</k>
+       <returnType> T':Type </returnType>
+

Exceptions

+ +

Exceptions can throw and catch values of any types. Since unlike in Java
+KOOL's methods do not declare the exception types that they can throw,
+we cannot test the full type safety of exceptions. Instead, we
+only check that the try and the catch statements
+type correctly.

+
  rule try block catch(T:Type X:Id) S => {T X; S}
+  rule throw _T:Type ; => stmt
+

Spawn

+ +

The spawned cell needs to also be passed the parent's class.

+
// explain why
+
+  rule <k> spawn S:Block => int ...</k>
+       <tenv> Rho </tenv>
+       <inClass> C </inClass>
+       (.Bag => <task>
+               <k> S </k>
+               <tenv> Rho </tenv>
+               <inClass> C </inClass>
+             </task>)
+

Semantics of the new KOOL constructs

+ +

Class declaration

+ +

We process each class in the main task, adding the corresponding data
+into its class cell and also adding a class task for it. We
+also perform some well-formedness checks on the class hierarchy.

+

Initiate class processing
+We create a class cell and a class task for each task. Also, we start
+the class task with a check that the class it extends is declared
+(this delays the task until that class is processed using another
+instance of this rule).

+
// There seems to be some error with the configuration concretization,
+// as the rule below does not work when rewriting . to both the task
+// and the class cells; I had to include two separate . rewrites
+
+// TODO: the following fails krun; see #2117
+  rule <task> <k> class C:Id extends C':Id { S:Stmt } => stmt ...</k> </task>
+       (.Bag => <classData>...
+               <className> C </className>
+               <baseClass> C' </baseClass>
+             ...</classData>)
+//       <br/>
+       (.Bag => <task>
+                <k> checkType(`class`(C')) ~> S </k>
+                <inClass> C </inClass>
+                <ctenvT> .Map </ctenvT>
+             </task>)
+
+// You may want to try the thing below, but that failed, too
+/*
+syntax Type ::= "stmtStop"
+
+  rule <tasks>...
+       <task> <k> class C:Id extends C':Id { S:Stmt } => stmtStop ...</k> </task>
+       (.Bag => <task>
+                <k> checkType(`class`(C')) ~> S </k>
+                <inClass> C </inClass>
+                <ctenvT> .Map </ctenvT>
+             </task>)
+       ...</tasks>
+       <classes>...
+       .Bag => <classData>...
+               <className> C </className>
+               <baseClass> C' </baseClass>
+             ...</classData>
+       ...</classes>
+//       <br/>
+*/
+

Check for unique class names

+ +
  rule (<T>...
+          <className> C </className>
+          <className> C </className>
+        ...</T> => .Bag)
+       <output>... .List => ListItem("Class \"" +String Id2String(C)
+                                  +String "\" declared twice!\n") </output>
+

Check for cycles in class hierarchy
+We check for cycles in the class hierarchy by transitively closing the
+class extends relation using the extendsAll cells, and
+checking that a class will never appear in its own extendsAll
+cell. The first rule below initiates the transitive closure of the
+superclass relation, the second transitively closes it, and the third
+checks for cycles.

+
  rule <baseClass> C </baseClass>
+       <baseClasses> .Set => SetItem(C) </baseClasses>  [priority(25)]
+
+  rule <classData>...
+         <baseClasses> SetItem(C) Cs:Set (.Set => SetItem(C')) </baseClasses>
+       ...</classData>
+       <classData>... <className>C</className> <baseClass>C'</baseClass> ...</classData>
+    when notBool(C' in (SetItem(C) Cs))  [priority(25)]
+
+  rule (<T>...
+          <className> C </className>
+          <baseClasses>... SetItem(C) ...</baseClasses>
+        ...</T> => .Bag)
+       <output>... .List => ListItem("Class \"" +String Id2String(C)
+                                  +String "\" is in a cycle!\n") </output>
+    [group(inheritance-cycle), priority(25)]
+

New

+ +

To type new we only need to check that the class constructor
+can be called with arguments of the given types, so we initiate a call
+to the constructor method in the corresponding class. If that
+succeeds, meaning that it types to stmt, then we discard the
+stmt type and produce instead the corresponding class type of
+the new object. The auxiliary discard operation is defined
+also at the end of this module.

+
  rule new C:Id(Ts:Types) => `class`(C) . C (Ts) ~> discard ~> `class`(C)
+

Self reference

+ +

The typing rule for this is straightforward: reduce to the
+current class type.

+
  rule <k> this => `class`(C) ...</k>
+       <inClass> C:Id </inClass>
+

Super

+ +

Similarly, super types to the parent class type.
+Note that for typing concerns, super can be considered as an object
+(recall that this was not the case in the dynamic semantics).

+
   rule <k> super => `class`(C') ...</k>
+        <inClass> C:Id </inClass>
+        <className> C </className>
+        <baseClass> C':Id </baseClass>
+

Object member access

+ +

There are several cases to consider here. First, if we are in a class
+task, we should lookup the member into the temporary class type
+environemnt in cell ctenvT. That is because we want to allow
+initialized field declarations in classes, such as int x=10;.
+This is desugared to a declaration of x, which is added to
+ctenvT during the class task processing, followed by an
+assignment of x to 10. In order for the assignment to type
+check, we need to know that x has been declared with type
+int; this information can only be found in the
+ctenvT cell. Second, we should redirect non-local variable
+lookups in method tasks to corresponding member accesses (the
+local variables are handled by the rule borrowed from SIMPLE).
+This is what the second rule below does. Third, we should allow
+object member accesses as lvalues, which is done by the third rule
+below. These last two rules therefore ensure that each necessary
+object member access is explicitly allowed for evaluation. Recall
+from the annotated syntax module above that the member access
+operation is strict in the object. That means that the object is
+expected to evaluate to a class type. The next two rules below define
+the actual member lookup operation, moving the search to the
+superclass when the member is not found in the current class. Note
+that this works because we create the class type environments
+atomically; thus, a class either has its complete type environment
+available, in which case these rules can safely apply, or its cell
+ctenv is not yet available, in which case these rules have to
+wait. Finally, the sixth rule below reports an error when the
+Object class is reached.

+
  rule <k> X:Id => T ...</k>
+       <ctenvT>... X |-> T ...</ctenvT>
+
+  rule <k> X:Id => this . X ...</k>
+       <tenv> Rho </tenv>
+    when notBool(X in keys(Rho))
+
+// OLD approach:
+//  rule ltype(E:Exp . X:Id) => E . X
+
+  rule <k> `class`(C:Id) . X:Id => T ...</k>
+       <className> C </className>
+       <ctenv>... X |-> T:Type ...</ctenv>
+
+  rule <k> `class`(C1:Id => C2) . X:Id ...</k>
+       <className> C1 </className>
+       <baseClass> C2:Id </baseClass>
+       <ctenv> Rho </ctenv>
+    when notBool(X in keys(Rho))
+
+  rule <k> `class`(Object) . X:Id => stuck(`class`(Object) . X) ...</k>
+       <inClass> C:Id </inClass>
+//      <br/>
+       <output>... .List => ListItem("Member \"" +String Id2String(X)
+                              +String "\" not declared! (see class \""
+                              +String Id2String(C) +String "\")\n") </output>
+

Instance of and casting

+ +

As it is hard to check statically whether casting is always safe,
+the programmer is simply trusted from a typing perspective. We only
+do some basic upcasting and downcasting checks, to reject casts which
+will absolutely fail. However, dynamic semantics or implementations
+of the language need to insert runtime checks for downcasting to be safe.

+
  rule `class`(_C1:Id) instanceOf _C2:Id => bool
+  rule (C:Id) `class`(C) => `class`(C)
+  rule <k> (C2:Id) `class`(C1:Id) => `class`(C2) ...</k>
+       <className> C1 </className>
+       <baseClasses>...SetItem(C2)...</baseClasses>    // upcast
+  rule <k> (C2:Id) `class`(C1:Id) => `class`(C2) ...</k>
+       <className> C2 </className>
+       <baseClasses>...SetItem(C1)...</baseClasses>    // downcast
+  rule <k> (C2) `class`(C1:Id) => stuck((C2) `class`(C1)) ...</k>
+       <classData>...
+         <className> C1 </className>
+         <baseClasses> S1 </baseClasses>
+       ...</classData>
+       <classData>...
+         <className> C2 </className>
+         <baseClasses> S2 </baseClasses>
+       ...</classData>
+       <output>... .List => ListItem("Classes \"" +String Id2String(C1)
+                              +String "\" and \"" +String Id2String(C2)
+                              +String "\" are incompatible!\n") </output>
+    when notBool(C1 in S2) andBool notBool(C2 in S1)
+

Cleanup tasks

+ +

Finally, we need to clean up the terminated tasks. Each of the three
+types of tasks is handled differently. The main task is replaced by a
+method task holding new main();, which will ensure that a
+main class with a main() method actually exists
+(first rule below). A class task moves its temporary class type
+environment into its class' cell, and then it dissolves itself (second
+rule). A method task simply dissolves when terminated (third rule);
+the presence of the tenv cell in that rule ensures that that
+task is a method task.
+Finally, when all the tasks are cleaned up, we can also remove the
+tasks cell, issuing a corresponding message. Note that
+checking for cycles or duplicate methods can still be performed after
+the tasks cell has been removed.

+
// discard main task when done, issuing a "new main();" command to
+// make sure that the class main and the method main() are declared.
+
+  rule <task> <k> stmt => new Main(.Exps); </k>
+              (.Bag => <tenv> .Map </tenv>
+                    <returnType> void </returnType>
+                    <inClass> Main </inClass>)
+       </task>
+
+// discard class task when done, adding a ctenv in class
+
+  rule (<task>
+          <k> stmt </k>
+          <ctenvT> Rho </ctenvT>
+          <inClass> C:Id </inClass>
+        </task> => .Bag)
+        <className> C </className>
+        (.Bag => <ctenv> Rho </ctenv>)
+
+// discard method task when done
+
+  rule <task>...
+         <k> stmt </k>
+         <tenv> _ </tenv>  // only to ensure that this is a method task
+       ...</task> => .Bag
+
+// cleanup tasks and output a success message when done
+
+  rule (<T>... <tasks> .Bag </tasks> ...</T> => .Bag)
+       <output>... .List => ListItem("Type checked!\n") </output>
+

KOOL-specific auxiliary declarations and operations

+ +

Subtype checking

+ +

The subclass relation introduces a subtyping relation.

+
  syntax KItem ::= checkSubtype(Types,Types)
+
+  rule checkSubtype(T:Type, T) => .
+
+  rule <k> checkSubtype(`class`(C:Id), `class`(C':Id)) => . ...</k>
+       <className> C </className>
+       <baseClasses>... SetItem(C') ...</baseClasses>
+
+  rule checkSubtype(Ts1->T2,Ts1'->T2')
+    => checkSubtype(((T2)::Type,Ts1'),((T2')::Type,Ts1))
+
+// note that the following rule would be wrong!
+//  rule checkSubtype(T[],T'[]) => checkSubtype(T,T')
+
+  rule checkSubtype((T:Type,Ts),(T':Type,Ts'))
+    => checkSubtype(T,T') ~> checkSubtype(Ts,Ts')
+    when Ts =/=K .Types
+
+  rule checkSubtype(.Types,.Types) => .
+  rule checkSubtype(.Types,void) => .
+

Checking well-formedness of types

+ +

Since now any Id can be used as the type of a class, we need to
+check that the types used in the program actually exists

+
  syntax KItem ::= checkType(Types)
+
+  rule checkType(T:Type,Ts:Types) => checkType(T) ~> checkType(Ts)
+    when Ts =/=K .Types
+  rule checkType(.Types) => .
+  rule checkType(int) => .
+  rule checkType(bool) => .
+  rule checkType(string) => .
+  rule checkType(void) => .
+  rule <k> checkType(`class`(C:Id)) => . ...</k> <className> C </className>
+  rule checkType(`class`(Object)) => .
+  rule checkType(Ts:Types -> T:Type) => checkType(T,Ts)
+  rule checkType(T:Type[]) => checkType(T)
+

Checking correct overiding of methods

+ +

The checkMethod operation below searches to see whether
+the current method overrides some other method in some superclass.
+If yes, then it issues an additional check that the new method's type
+is more concrete than the overridden method's. The types T and T'
+below can only be function types. See the definition of
+checkSubtype on function types at the end of this module (it
+is co-variant in the codomain and contra-variant in the domain).

+
  syntax KItem ::= checkMethod(Id,Type,Id)
+
+  rule <k> checkMethod(F:Id, T:Type, C:Id) => checkSubtype(T, T') ...</k>
+       <className> C </className>
+       <ctenv>... F |-> T':Type ...</ctenv>
+
+  rule <k> checkMethod(F:Id, _T:Type, (C:Id => C')) ...</k>
+       <className> C </className>
+       <baseClass> C':Id </baseClass>
+       <ctenv> Rho </ctenv>
+    when notBool(F in keys(Rho))
+
+  rule checkMethod(_:Id,_,Object) => .
+

Generic operations which could be part of the K framework

+ +
  syntax KItem ::= stuck(K)  [latex(\framebox{${#1}$})]
+
+  syntax KItem ::= "discard"
+  rule _:KResult ~> discard => .
+
+endmodule
+

FUN — Untyped — Environment

+ +

Author: Grigore Roșu (grosu@illinois.edu)
+Organization: University of Illinois at Urbana-Champaign

+

Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
+Organization: University of Bucharest

+

Abstract

+ +

This is the K semantic definition of the untyped FUN language.
+FUN is a pedagogical and research language that captures the essence
+of the functional programming paradigm, extended with several features
+often encountered in functional programming languages.
+Like many functional languages, FUN is an expression language, that
+is, everything, including the main program, is an expression.
+Functions can be declared anywhere and are first class values in the
+language.
+FUN is call-by-value here, but it has been extended (as student
+homework assignments) with other parameter-passing styles.
+To make it more interesting and to highlight some of K's strengths,
+FUN includes the following features:

+
    +
  • +

    The basic builtin data-types of integers, booleans and strings.

    +
  • +
  • +

    Builtin lists, which can hold any elements, including other lists.
    +Lists are enclosed in square brackets and their elements are
    +comma-separated; e.g., [1,2,3].

    +
  • +
  • +

    User-defined data-types, by means of constructor terms.
    +Constructor names start with a capital letter (while any other
    +identifier in the language starts with a lowercase letter), and they
    +can be followed by an arbitrary number of comma-separated arguments
    +enclosed in parentheses; parentheses are not needed when the
    +constructor takes no arguments.
    +For example, Pair(5,7) is a constructor term holding two
    +numbers, Cons(1,Cons(2,Cons(3,Nil))) is a list-like
    +constructor term holding 3 elements, and
    +Tree(Tree(Leaf(1), Leaf(2)), Leaf(3)) is a tree-like
    +constructor term holding 3 elements.
    +In the untyped version of the FUN language, no type checking or
    +inference is performed to ensure that the data constructors are used
    +correctly.
    +The execution will simply get stuck when they are misused.
    +Moreover, since no type checking is performed, the data-types are not
    +even declared in the untyped version of FUN.

    +
  • +
  • +

    Functions and let/letrec binders can take
    +multiple space-separated arguments, but these are desugared to
    +ones that only take one argument, by currying. For example, the
    +expressions

    +
    fun x y -> x y
    +let x y = y in x
    +

    are desugared, respectively, into the following expressions:

    +
    fun x -> fun y -> x y
    +let x = fun y -> y in x
    +
  • +
  • +

    Functions can be defined using pattern matching over the
    +available data-types. For example, the program

    +
    letrec max = fun [h] -> h
    +             |   [h|t] -> let x = max t
    +                          in  if h > x then h else x
    +in max [1, 3, 5, 2, 4, 0, -1, -5]
    +

    defines a function max that calculates the maximum element of
    +a non-empty list, and the function

    +
    letrec ack = fun Pair(0,n) -> n + 1
    +             |   Pair(m,0) -> ack Pair(m - 1, 1)
    +             |   Pair(m,n) -> ack Pair(m - 1, ack Pair(m, n - 1))
    +in ack Pair(2,3)
    +

    calculates the Ackermann function applied to a particular pair of numbers.
    +Patterns can be nested. Patterns can currently only be used in function
    +definitions, and not directly in let/letrec binders.
    +For example, this is not allowed:

    +
    letrec Pai(x,y) = Pair(1,2) in x+y
    +

    But this is allowed:

    +
    let f Pair(x,y) = x+y in f Pair(1,2)
    +

    because it is first reduced to

    +
    let f = fun Pair(x,y) -> x+y in f Pair(1,2)
    +

    by uncurrying of the let binder, and pattern matching is
    +allowed in function arguments.

    +
  • +
  • +

    We include a callcc construct, for two reasons: first,
    +several functional languages support this construct; second, some
    +semantic frameworks have difficulties defining it. Not K.

    +
  • +
  • +

    Finally, we include mutables by means of referencing an
    +expression, getting the reference of a variable, dereferencing and
    +assignment. We include these for the same reasons as above: there are
    +languages which have them, and they are not easy to define in some
    +semantic frameworks.

    +
  • +
+

Like in many other languages, some of FUN's constructs can be
+desugared into a smaller set of basic constructs. We do that as usual,
+using macros, and then we only give semantics to the core constructs.

+

Note:
+We recommend the reader to first consult the dynamic semantics of the
+LAMBDA++ language in the first part of the K Tutorial.
+To keep the comments below small and focused, we will not re-explain
+functional or K features that have already been explained in there.

+

Syntax

+ +
//require "modules/pattern-matching.k"
+
+module FUN-UNTYPED-COMMON
+  imports DOMAINS-SYNTAX
+

FUN is an expression language. The constructs below fall into
+several categories: names, arithmetic constructs, conventional
+functional constructs, patterns and pattern matching, data constructs,
+lists, references, and call-with-current-continuation (callcc).
+The arithmetic constructs are standard; they are present in almost all
+our K language definitions. The meaning of FUN's constructs are
+discussed in more depth when we define their semantics in the next
+module.

+

The Syntactic Constructs

+ +

We start with the syntactic definition of FUN names.
+We have several categories of names: ones to be used for functions and
+variables, others to be used for data constructors, others for types and
+others for type variables. We will introduce them as needed, starting
+with the former category. We prefer the names of variables and functions
+to start with lower case letters. We take the freedom to tacitly introduce
+syntactic lists/sequences for each nonterminal for which we need them:

+
  syntax Name                                      [token]
+  syntax Names ::= List{Name,","}                  [klabel(exps)]
+

Expression constructs will be defined throughtout the syntax module.
+Below are the very basic ones, namely the builtins, the names, and the
+parentheses used as brackets for grouping. Lists of expressions are
+declared strict, so all expressions in the list get evaluated whenever
+the list is on a position which can be evaluated:

+
  syntax Exp ::= Int | Bool | String | Name
+               | "(" Exp ")"                       [bracket]
+  syntax Exps  ::= List{Exp,","}                   [strict, klabel(exps)]
+  syntax Val
+  syntax Exp ::= Val
+  syntax Exps ::= Vals
+  syntax Vals ::= List{Val,","}                    [klabel(exps)]
+  syntax Bottom
+  syntax Bottoms ::= List{Bottom,","}              [klabel(exps)]
+

We next define the syntax of arithmetic constructs, together with
+their relative priorities and left-/non-associativities. We also
+tag all these rules as members of a new group, "arith", so we can more easily
+define global syntax priorities later (at the end of the syntax module).

+
  syntax Exp ::= left:
+                 Exp "*" Exp                       [strict, group(arith)]
+               | Exp "/" Exp                       [strict, group(arith)]
+               | Exp "%" Exp                       [strict, group(arith)]
+               > left:
+                 Exp "+" Exp                       [strict, left, group(arith)]
+               | Exp "^" Exp                       [strict, left, group(arith)]
+// left attribute should not be necessary; currently a parsing bug
+               | Exp "-" Exp                       [strict, prefer, group(arith)]
+// the "prefer" attribute above is to not parse x-1 as x(-1)
+// Due to some parsing problems, we currently cannot add unary minus:
+               | "-" Exp                           [strict, group(arith)]
+               > non-assoc:
+                 Exp "<" Exp                       [strict, group(arith)]
+               | Exp "<=" Exp                      [strict, group(arith)]
+               | Exp ">" Exp                       [strict, group(arith)]
+               | Exp ">=" Exp                      [strict, group(arith)]
+               | Exp "==" Exp                      [strict, group(arith)]
+               | Exp "!=" Exp                      [strict, group(arith)]
+               > "!" Exp                           [strict, group(arith)]
+               > Exp "&&" Exp                      [strict(1), left, group(arith)]
+               > Exp "||" Exp                      [strict(1), left, group(arith)]
+

The conditional construct has the expected evaluation strategy,
+stating that only the first argument is evaluate:

+
  syntax Exp ::= "if" Exp "then" Exp "else" Exp    [strict(1)]
+

FUN's builtin lists are formed by enclosing comma-separated
+sequences of expressions (i.e., terms of sort Exps) in square
+brackets. The list constructor cons adds a new element to the
+top of the list, head and tail get the first element
+and the tail sublist of a list if they exist, respectively, and get
+stuck otherwise, and null?? tests whether a list is empty or
+not; syntactically, these are just expression constants.
+In function patterns, we are also going to allow patterns following the
+usual head/tail notation; for example, the pattern [x_1,...,x_n|t]
+binds x_1, ..., x_n to the first elements of the matched list,
+and t to the list formed with the remaining elements. We define list
+patterns as ordinary expression constructs, although we will make sure that
+we do not give them semantics if they appear in any other place then in a
+function case pattern.

+
  syntax Exp ::= "[" Exps "]"                             [strict, klabel(list)]
+               | "head" [macro] | "tail" [macro] | "null?" [macro]
+               | "[" Exps "|" Exp "]"
+  syntax Val ::= "[" Vals "]"                             [klabel(list)]
+  syntax Cons ::= "cons"
+  syntax Val ::= Cons
+  syntax Val ::= Cons Val                                 [klabel(apply)]
+

Data constructors start with capital letters and they may or may
+not have arguments. We need to use the attribute "prefer" to make
+sure that, e.g., Cons(a) parses as constructor Cons with
+argument a, and not as the expression Cons (because
+constructor names are also expressions) regarded as a function applied
+to the expression a. Also, note that the constructor is strict
+in its second argument, because we want to evaluate its arguments but
+not the constuctor name itsef.

+
  syntax ConstructorName                         [token]
+  syntax Exp ::= ConstructorName
+               | ConstructorName "(" Exps ")"    [prefer, strict(2), klabel(constructor)]
+  syntax Val ::= ConstructorName "(" Vals ")"    [klabel(constructor)]
+

A function is essentially a |-separated ordered
+sequence of cases, each case of the form pattern -> expression,
+preceded by the language construct fun. Patterns will be defined
+shortly, both for the builtin lists and for user-defined constructors.
+Recall that the syntax we define in K is not meant to serve as a
+ultimate parser for the defined language, but rather as a convenient
+notation for K abstract syntax trees, which we prefer when we write
+the semantic rules. It is therefore often the case that we define a
+more ``generous'' syntax than we want to allow programs to use.
+We do it here, too. Specifically, the syntax of Cases
+below allows any expressions to appear as pattern. This syntactic
+relaxation permits many wrong programs to be parsed, but that is not a
+problem because we are not going to give semantics to wrong combinations,
+so those programs will get stuck; moreover, our type inferencer will reject
+those programs anyway. Function application is just concatenation of
+expressions, without worrying about type correctness. Again, the type
+system will reject type-incorrect programs.

+
  syntax Exp ::= "fun" Cases
+               | Exp Exp                              [strict, left, klabel(apply)]
+// NOTE: We would like eventually to also have Exp "(" Exps ")
+  syntax Case  ::= Exp "->" Exp
+  syntax Cases ::= List{Case, "|"}
+

The let and letrec binders have the usual syntax
+and functional meaning. We allow multiple and-separated bindings.
+Like for the function cases above, we allow a more generous syntax for
+the left-hand sides of bindings, noting that the semantics will get stuck
+on incorrect bindings and that the type system will reject those programs.

+
  syntax Exp ::= "let" Bindings "in" Exp
+               | "letrec" Bindings "in" Exp                 [prefer]
+// The "prefer" attribute for letrec currently needed due to tool bug,
+// to make sure that "letrec" is not parsed as "let rec".
+  syntax Binding  ::= Exp "=" Exp
+  syntax Bindings ::= List{Binding,"and"}
+

References are first class values in FUN. The construct ref
+takes an expression, evaluates it, and then it stores the resulting value
+at a fresh location in the store and returns that reference. Syntactically,
+ref is just an expression constant. The construct &
+takes a name as argument and evaluates to a reference, namely the store
+reference where the variable passed as argument stores its value; this
+construct is a bit controversial and is further discussed in the
+environment-based semantics of the FUN language, where we desugar
+ref to it. The construct @ takes a reference
+and evaluates to the value stored there. The construct := takes
+two expressions, the first expected to evaluate to a reference; the value
+of its second argument will be stored at the location to which the first
+points (the old value is thus lost). Finally, since expression evaluation
+now has side effects, it makes sense to also add a sequential composition
+construct, which is sequentially strict. This evaluates to the value of
+its second argument; the value of the first argument is lost (which has
+therefore been evaluated only for its side effects.

+
  syntax Exp ::= "ref"                             [macro]
+               | "&" Name
+               | "@" Exp                                     [strict]
+               | Exp ":=" Exp                                [strict]
+               | Exp ";" Exp                       [strict(1), right]
+

Call-with-current-continuation, named callcc in FUN, is a
+powerful control operator that originated in the Scheme programming
+language, but it now exists in many other functional languages. It works
+by evaluating its argument, expected to evaluate to a function, and by
+passing the current continuation, or evaluation context (or computation,
+in K terminology), as a special value to it. When/If this special value
+is invoked, the current context is discarded and replaced with the one
+held by the special value and the computation continues from there.
+It is like taking a snapshot of the execution context at some moment
+in time and then, when desired, being able to get back in time to that
+point. If you like games, it is like saving the game now (so you can
+work on your homework!) and then continuing the game tomorrow or whenever
+you wish. To issustrate the strength of callcc, we also
+allow exceptions in FUN by means of a conventional try-catch
+construct, which will desugar to callcc. We also need to
+introduce the special expression contant throw, but we need to
+use it as a function argument name in the desugaring macro, so we define
+it as a name instead of as an expression constant:

+
  syntax Exp ::= "try" Exp "catch" "(" Name ")" Exp [macro]
+  syntax Val ::= "callcc"
+  syntax Name ::= "throw" [token]
+

Finally, FUN also allows polymorphic datatype declarations. These
+will be useful when we define the type system later on.

+
  syntax Exp ::= "datatype" Type "=" TypeCases Exp [macro]
+// NOTE: In a future version of K, we want the datatype declaration
+// to be a construct by itself, but that is not possible currently
+// because K's parser wronly identifies the __ operation allowing
+// a declaration to appear in front of an expression with the function
+// application construct, giving ambiguous parsing errors.
+

We next need to define the syntax of types and type cases that appear
+in datatype declarations.

+

Like in many functional languages, type parameters/variables in
+user-defined types are quoted identifiers.

+
  syntax TypeVar                        [token]
+  syntax TypeVars ::= List{TypeVar,","} [klabel(types)]
+

Types can be basic types, function types, or user-defined
+parametric types. In the dynamic semantics we are going to simply ignore
+all the type declations, so here the syntax of types below is only useful
+for generating the desired parser. To avoid syntactic ambiguities with
+the arrow construct for function cases, we use the symbol --> as
+a constructor for function types:

+
  syntax TypeName [token]
+  syntax Type ::= "int" | "bool" | "string"
+                | Type "-->" Type                            [right]
+                | "(" Type ")"                             [bracket]
+                | TypeVar
+                | TypeName             [klabel(TypeName), avoid]
+                | Type TypeName   [klabel(Type-TypeName), symbol, macro]
+                | "(" Types ")" TypeName                    [prefer]
+  syntax Types ::= List{Type,","} [klabel(types)]
+  syntax Types ::= TypeVars
+
+  syntax TypeCase ::= ConstructorName
+                    | ConstructorName "(" Types ")"
+  syntax TypeCases ::= List{TypeCase,"|"}     [klabel(_|TypeCase_)]
+

Additional Priorities

+ +
  syntax priorities @__FUN-UNTYPED-COMMON
+                  > apply
+                  > arith
+                  > _:=__FUN-UNTYPED-COMMON
+                  > let_in__FUN-UNTYPED-COMMON
+                    letrec_in__FUN-UNTYPED-COMMON
+                    if_then_else__FUN-UNTYPED-COMMON
+                  > _;__FUN-UNTYPED-COMMON
+                  > fun__FUN-UNTYPED-COMMON
+                  > datatype_=___FUN-UNTYPED-COMMON
+endmodule
+
+module FUN-UNTYPED-MACROS
+  imports FUN-UNTYPED-COMMON
+

Desugaring macros

+ +

We desugar the list non-constructor operations to functions matching
+over list patterns. In order to do that we need some new variables; for
+those, we follow the same convention like in the K tutorial, where we
+added them as new identifier constructs starting with the character $,
+so we can easily recognize them when we debug or trace the semantics.

+
  syntax Name ::= "$h" [token] | "$t" [token]
+  rule head => fun [$h|$t] -> $h
+  rule tail => fun [$h|$t] -> $t
+  rule null? => fun [.Exps] -> true | [$h|$t] -> false
+

Multiple-head list patterns desugar into successive one-head patterns:

+
  rule [E1,E2,Es:Exps|T] => [E1|[E2,Es|T]]                   [anywhere]
+

Uncurrying of multiple arguments in functions and binders:

+
  rule P1 P2 -> E => P1 -> fun P2 -> E                       [anywhere]
+  rule F P = E => F = fun P -> E                             [anywhere]
+

We desugar the try-catch construct into callcc:

+
  syntax Name ::= "$k" [token] | "$v" [token]
+  rule try E catch(X) E'
+    => callcc (fun $k -> (fun throw -> E)(fun X -> $k E'))
+

For uniformity, we reduce all types to their general form:

+
  rule `Type-TypeName`(T:Type, Tn:TypeName) => (T) Tn
+

The dynamic semantics ignores all the type declarations:

+
  rule datatype _T = _TCs E => E
+
+endmodule
+
+
+module FUN-UNTYPED-SYNTAX
+  imports FUN-UNTYPED-COMMON
+  imports BUILTIN-ID-TOKENS
+
+  syntax Name ::= r"[a-z][_a-zA-Z0-9]*"           [token, prec(2)]
+                | #LowerId                        [token]
+  syntax ConstructorName ::= #UpperId             [token]
+  syntax TypeVar  ::= r"['][a-z][_a-zA-Z0-9]*"    [token]
+  syntax TypeName ::= Name                        [token]
+endmodule
+

Semantics

+ +

The semantics below is environment-based. A substitution-based
+definition of FUN is also available, but that drops the &
+construct as explained above.

+
module FUN-UNTYPED
+  imports FUN-UNTYPED-COMMON
+  imports FUN-UNTYPED-MACROS
+  imports DOMAINS
+  //imports PATTERN-MATCHING
+

Configuration

+ +

The k, env, and store cells are standard
+(see, for example, the definition of LAMBDA++ or IMP++ in the first
+part of the K tutorial).

+
  configuration <T color="yellow">
+                  <k color="green"> $PGM:Exp </k>
+                  <env color="violet"> .Map </env>
+                  <store color="white"> .Map </store>
+                </T>
+

Values and results

+ +

We only define integers, Booleans and strings as values here, but will
+add more values later.

+
  syntax Val ::= Int | Bool | String
+  syntax Vals ::= Bottoms
+  syntax KResult ::= Val
+

Lookup

+ +
  rule <k> X:Name => V ...</k>
+       <env>... X |-> L ...</env>
+       <store>... L |-> V ...</store>
+

Arithmetic expressions

+ +
  rule I1 * I2 => I1 *Int I2
+  rule I1 / I2 => I1 /Int I2 when I2 =/=K 0
+  rule I1 % I2 => I1 %Int I2 when I2 =/=K 0
+  rule I1 + I2 => I1 +Int I2
+  rule S1 ^ S2 => S1 +String S2
+  rule I1 - I2 => I1 -Int I2
+  rule - I => 0 -Int I
+  rule I1 < I2 => I1 <Int I2
+  rule I1 <= I2 => I1 <=Int I2
+  rule I1 > I2 => I1 >Int I2
+  rule I1 >= I2 => I1 >=Int I2
+  rule V1:Val == V2:Val => V1 ==K V2
+  rule V1:Val != V2:Val => V1 =/=K V2
+  rule ! T => notBool(T)
+  rule true  && E => E
+  rule false && _ => false
+  rule true  || _ => true
+  rule false || E => E
+

Conditional

+ +
  rule if  true then E else _ => E
+  rule if false then _ else E => E
+

Lists

+ +

We have already declared the syntactic list of expressions strict, so
+we can assume that all the elements that appear in a FUN list are
+evaluated. The only thing left to do is to state that a list of
+values is a value itself, that is, that the list square-bracket
+construct is indeed a constructor, and to give the semantics of
+cons. Since cons is a builtin function and is
+expected to take two arguments, we have to also state that
+cons itself is a value (specifically, a function/closure
+value, but we do not need that level of detail here), and also that
+cons applied to a value is a value (specifically, it would be
+a function/closure value that expects the second, list argument):

+
  rule cons V:Val [Vs:Vals] => [V,Vs]
+

Data Constructors

+ +

Constructors take values as arguments and produce other values:

+
  syntax Val ::= ConstructorName
+

Functions and Closures

+ +

Like in the environment-based semantics of LAMBDA++ in the first part
+of the K tutorial, functions evaluate to closures. A closure includes
+the current environment besides the function contents; the environment
+will be used at execution time to lookup all the variables that appear
+free in the function body (we want static scoping in FUN).

+
  syntax Val ::= closure(Map,Cases)
+  rule <k> fun Cases => closure(Rho,Cases) ...</k>  <env> Rho </env>
+

Note: The reader may want to get familiar with
+how the pre-defined pattern matching works before proceeding.
+The best way to do that is to consult
+k/include/modules/pattern-matching.k.

+

We distinguish two cases when the closure is applied.
+If the first pattern matches, then we pick the first case: switch to
+the closed environment, get the matching map and bind all its
+variables, and finally evaluate the function body of the first case,
+making sure that the environment is properly recovered afterwards.
+If the first pattern does not match, then we drop it and thus move on
+to the next one.

+
  rule (. => getMatching(P, V)) ~> closure(_, P->_ | _) V:Val
+  rule <k> matchResult(M:Map) ~> closure(Rho, _->E | _) _
+           => bindMap(M) ~> E ~> setEnv(Rho') ...</k>
+       <env> Rho' => Rho </env>
+  rule (matchFailure => .) ~> closure(_, (_->_ | Cs:Cases => Cs)) _
+//  rule <k> closure(Rho, P->E | _) V:Val
+//           => bindMap(getMatching(P,V)) ~> E ~> setEnv(Rho') ...</k>
+//       <env> Rho' => Rho </env>  when isMatching(P,V)
+//  rule closure(_, (P->_ | Cs:Cases => Cs)) V:Val  when notBool isMatching(P,V)
+

Let and Letrec

+ +

To highlight the similarities and differences between let and
+letrec, we prefer to give them direct semantics instead of
+to desugar them like in LAMBDA. See the formal definitions of
+bindTo, bind, and assignTo at the end of
+this module. Informally, bindTo(Xs, Es) first
+evaluates the expressions Es in Exps in the current
+environment (i.e., it is strict in its second argument), then it binds
+the variables in Xs in Names to new locations and adds
+those bindings to the environment, and finally writes the values
+previously obtained after evaluating the expressions Es to those
+new locations; bind(Xs) does only the bindings of
+Xs to new locations and adds those bindings to the environment;
+and assignTo(Xs,Es) evaluates the expressions
+Es in the current environment and then it writes the resulting
+values to the locations to which the variables Xs are already
+bound to in the environment.

+

Therefore, let Xs = Es in E first
+evaluates Es in the current environment, then adds new
+bindings for Xs to fresh locations in the environment, then
+writes the values of Es to those locations, and finally
+evaluates E in the new environment, making sure that the
+environment is properly recovered after the evaluation of E.
+On the other hand, letrec does the same things but in a
+different order: it first adds new bindings for Xs to fresh
+locations in the environment, then it evaluates Es in the new
+environment, then it writes the resulting values to their
+corresponding locations, and finally it evaluates E and
+recovers the environment. The crucial difference is that the
+expressions Es now see the locations of the variables Xs
+in the environment, so if they are functions, which is typically the
+case with letrec, their closures will encapsulate in their
+environments the bindings of all the bound variables, including
+themselves (thus, we may have a closure value stored at location
+L, whose environment contains a binding of the form
+F ↦ L; this way, the closure can invoke
+itself).

+
  rule <k> let Bs in E
+        => bindTo(names(Bs),exps(Bs)) ~> E ~> setEnv(Rho) ...</k>
+       <env> Rho </env>
+
+  rule <k> letrec Bs in E
+        => bind(names(Bs))~>assignTo(names(Bs),exps(Bs))~>E~>setEnv(Rho)...</k>
+       <env> Rho </env>
+

Recall that our syntax allows let and letrec to
+take any expression in place of its binding. This allows us to use
+the already existing function application construct to bind names to
+functions, such as, e.g., let x y = y in ....
+The desugaring macro in the syntax module uncurries such declarations,
+and then the semantic rules above only work when the remaining
+bindings are identifiers, so the semantics will get stuck on programs
+that misuse the let and letrec binders.

+

References

+ +

The semantics of references is self-explanatory, except maybe for the
+desugaring rule of ref, which is further discussed. Note
+that &X grabs the location of X from the environment.
+Sequential composition, which is needed only to accumulate the
+side effects due to assignments, was strict in the first argument.
+Once evaluated, its first argument is simply discarded:

+
  syntax Name ::= "$x" [token]
+  rule ref => fun $x -> & $x
+  rule <k> & X => L ...</k>  <env>... X |-> L ...</env>
+  rule <k> @ L:Int => V:Val ...</k>  <store>... L |-> V ...</store>
+  rule <k> L:Int := V:Val => V ...</k>  <store>... L |-> (_=>V) ...</store>
+  rule _V:Val; E => E
+

The desugaring rule of ref (first rule above) works
+because & takes a variable and returns its location (like in C).
+Note that some ``pure'' functional programming researchers strongly dislike
+the & construct, but favor ref. We refrain from having
+a personal opinion on this issue here, but support & in the
+environment-based definition of FUN because it is, technically speaking,
+more powerful than ref. From a language design perspective, it
+would be equally easy to drop & and instead give a direct
+semantics to ref. In fact, this is precisely what we do in the
+substitution-based definition of FUN, because there appears to be no way
+to give a substitution-based definition to the & construct.

+

Callcc

+ +

As we know it from the LAMBDA++ tutorial, call-with-current-continuation
+is quite easy to define in K. We first need to define a special
+value wrapping an execution context, that is, an environment saying
+where the variables should be looked up, and a computation structure
+saying what is left to execute (in a substitution-based definition,
+this special value would be even simpler, as it would only need to
+wrap the computation structure---see, for example, the
+substitution-based semantics of LAMBDA++ in the the first part of the
+K tutorial, or the substitution-based definition of FUN). Then
+callcc creates such a value containing the current
+environment and the current remaining computation, and passes it to
+its argument function. When/If invoked, the special value replaces
+the current execution context with its own and continues the execution
+normally.

+
  syntax Val ::= cc(Map,K)
+  rule <k> (callcc V:Val => V cc(Rho,K)) ~> K </k>  <env> Rho </env>
+  rule <k> cc(Rho,K) V:Val ~> _ => V ~> K </k>  <env> _ => Rho </env>
+

Auxiliary operations

+ +

Environment recovery

+ +

The environment recovery operation is the same as for the LAMBDA++
+language in the K tutorial and many other languages provided with the
+K distribution. The first ``anywhere'' rule below shows an elegant
+way to achieve the benefits of tail recursion in K.

+
  syntax KItem ::= setEnv(Map)  // TODO: get rid of env
+  //rule (setEnv(_) => .) ~> setEnv(_)  [anywhere]
+  rule <k> _:Val ~> (setEnv(Rho) => .) ...</k> <env> _ => Rho </env>
+

bindTo, bind and assignTo

+ +

The meaning of these operations has already been explained when we
+discussed the let and letrec language constructs
+above.

+
  syntax KItem ::= bindTo(Names,Exps)         [strict(2)]
+                 | bindMap(Map)
+                 | bind(Names)
+
+  rule (. => getMatchingAux(Xs,Vs)) ~> bindTo(Xs:Names,Vs:Vals)
+  rule matchResult(M:Map) ~> bindTo(_:Names, _:Vals) => bindMap(M)
+
+  rule bindMap(.Map) => .
+  rule <k> bindMap((X:Name |-> V:Val => .Map) _:Map) ...</k>
+       <env> Rho => Rho[X <- !L:Int] </env>
+       <store>... .Map => !L |-> V ...</store>
+
+  rule bind(.Names) => .
+  rule <k> bind(X:Name,Xs => Xs) ...</k>
+       <env> Rho => Rho[X <- !_L:Int] </env>
+
+  syntax KItem ::= assignTo(Names,Exps)  [strict(2)]
+
+  rule <k> assignTo(.Names,.Vals) => . ...</k>
+  rule <k> assignTo((X:Name,Xs => Xs),(V:Val,Vs:Vals => Vs)) ...</k>
+       <env>... X |-> L ...</env>
+       <store>... .Map => L |-> V ...</store>
+

Getters

+ +

The following auxiliary operations extract the list of identifiers
+and of expressions in a binding, respectively.

+
  syntax Names ::= names(Bindings)  [function]
+  rule names(.Bindings) => .Names
+  rule names(X:Name=_ and Bs) => (X,names(Bs))::Names
+
+  syntax Exps ::= exps(Bindings)  [function]
+  rule exps(.Bindings) => .Exps
+  rule exps(_:Name=E and Bs) => E,exps(Bs)
+
+  /* Extra kore stuff */
+  syntax KResult ::= Vals
+  syntax Exps ::= Names
+  syntax Names ::= Bottoms
+
+  /* Matching */
+  syntax MatchResult ::= getMatching(Exp, Val)                      [function]
+                       | getMatchingAux(Exps, Vals)                 [function]
+                       | mergeMatching(MatchResult, MatchResult)    [function]
+                       | matchResult(Map)
+                       | "matchFailure"
+
+  rule getMatching(C:ConstructorName(Es:Exps), C(Vs:Vals)) => getMatchingAux(Es, Vs)
+  rule getMatching([Es:Exps], [Vs:Vals])                   => getMatchingAux(Es, Vs)
+  rule getMatching(C:ConstructorName, C) => matchResult(.Map)
+  rule getMatching(B:Bool, B)            => matchResult(.Map)
+  rule getMatching(I:Int, I)             => matchResult(.Map)
+  rule getMatching(S:String, S)          => matchResult(.Map)
+  rule getMatching(N:Name, V:Val) => matchResult(N |-> V)
+  rule getMatching(_, _) => matchFailure        [owise]
+
+  rule getMatchingAux((E:Exp, Es:Exps), (V:Val, Vs:Vals)) => mergeMatching(getMatching(E, V), getMatchingAux(Es, Vs))
+  rule getMatchingAux(.Exps, .Vals)                       => matchResult(.Map)
+  rule getMatchingAux(_, _) => matchFailure     [owise]
+
+  rule mergeMatching(matchResult(M1:Map), matchResult(M2:Map)) => matchResult(M1 M2)
+    requires intersectSet(keys(M1), keys(M2)) ==K .Set
+  //rule mergeMatching(_, _) => matchFailure      [owsie]
+  rule mergeMatching(matchResult(_:Map), matchFailure) => matchFailure
+  rule mergeMatching(matchFailure, matchResult(_:Map)) => matchFailure
+  rule mergeMatching(matchFailure, matchFailure)       => matchFailure
+

Besides the generic decomposition rules for patterns and values,
+we also want to allow [head|tail] matching for lists, so we add
+the following custom pattern decomposition rule:

+
  rule getMatching([H:Exp | T:Exp], [V:Val, Vs:Vals])
+    => getMatchingAux((H, T), (V, [Vs]))
+endmodule
+

Go to Lesson 2, FUN untyped, Substitution-Based.

+

FUN — Untyped — Environment

+ +

Author: Grigore Roșu (grosu@illinois.edu)
+Organization: University of Illinois at Urbana-Champaign

+

Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
+Organization: University of Bucharest

+

Abstract

+ +

This is the K semantic definition of the untyped FUN language.
+FUN is a pedagogical and research language that captures the essence
+of the functional programming paradigm, extended with several features
+often encountered in functional programming languages.
+Like many functional languages, FUN is an expression language, that
+is, everything, including the main program, is an expression.
+Functions can be declared anywhere and are first class values in the
+language.
+FUN is call-by-value here, but it has been extended (as student
+homework assignments) with other parameter-passing styles.
+To make it more interesting and to highlight some of K's strengths,
+FUN includes the following features:

+
    +
  • +

    The basic builtin data-types of integers, booleans and strings.

    +
  • +
  • +

    Builtin lists, which can hold any elements, including other lists.
    +Lists are enclosed in square brackets and their elements are
    +comma-separated; e.g., [1,2,3].

    +
  • +
  • +

    User-defined data-types, by means of constructor terms.
    +Constructor names start with a capital letter (while any other
    +identifier in the language starts with a lowercase letter), and they
    +can be followed by an arbitrary number of comma-separated arguments
    +enclosed in parentheses; parentheses are not needed when the
    +constructor takes no arguments.
    +For example, Pair(5,7) is a constructor term holding two
    +numbers, Cons(1,Cons(2,Cons(3,Nil))) is a list-like
    +constructor term holding 3 elements, and
    +Tree(Tree(Leaf(1), Leaf(2)), Leaf(3)) is a tree-like
    +constructor term holding 3 elements.
    +In the untyped version of the FUN language, no type checking or
    +inference is performed to ensure that the data constructors are used
    +correctly.
    +The execution will simply get stuck when they are misused.
    +Moreover, since no type checking is performed, the data-types are not
    +even declared in the untyped version of FUN.

    +
  • +
  • +

    Functions and let/letrec binders can take
    +multiple space-separated arguments, but these are desugared to
    +ones that only take one argument, by currying. For example, the
    +expressions

    +
    fun x y -> x y
    +let x y = y in x
    +

    are desugared, respectively, into the following expressions:

    +
    fun x -> fun y -> x y
    +let x = fun y -> y in x
    +
  • +
  • +

    Functions can be defined using pattern matching over the
    +available data-types. For example, the program

    +
    letrec max = fun [h] -> h
    +             |   [h|t] -> let x = max t
    +                          in  if h > x then h else x
    +in max [1, 3, 5, 2, 4, 0, -1, -5]
    +

    defines a function max that calculates the maximum element of
    +a non-empty list, and the function

    +
    letrec ack = fun Pair(0,n) -> n + 1
    +             |   Pair(m,0) -> ack Pair(m - 1, 1)
    +             |   Pair(m,n) -> ack Pair(m - 1, ack Pair(m, n - 1))
    +in ack Pair(2,3)
    +

    calculates the Ackermann function applied to a particular pair of numbers.
    +Patterns can be nested. Patterns can currently only be used in function
    +definitions, and not directly in let/letrec binders.
    +For example, this is not allowed:

    +
    letrec Pai(x,y) = Pair(1,2) in x+y
    +

    But this is allowed:

    +
    let f Pair(x,y) = x+y in f Pair(1,2)
    +

    because it is first reduced to

    +
    let f = fun Pair(x,y) -> x+y in f Pair(1,2)
    +

    by uncurrying of the let binder, and pattern matching is
    +allowed in function arguments.

    +
  • +
  • +

    We include a callcc construct, for two reasons: first,
    +several functional languages support this construct; second, some
    +semantic frameworks have difficulties defining it. Not K.

    +
  • +
  • +

    Finally, we include mutables by means of referencing an
    +expression, getting the reference of a variable, dereferencing and
    +assignment. We include these for the same reasons as above: there are
    +languages which have them, and they are not easy to define in some
    +semantic frameworks.

    +
  • +
+

Like in many other languages, some of FUN's constructs can be
+desugared into a smaller set of basic constructs. We do that as usual,
+using macros, and then we only give semantics to the core constructs.

+

Note:
+We recommend the reader to first consult the dynamic semantics of the
+LAMBDA++ language in the first part of the K Tutorial.
+To keep the comments below small and focused, we will not re-explain
+functional or K features that have already been explained in there.

+

Syntax

+ +
//require "modules/pattern-matching.k"
+
+module FUN-UNTYPED-COMMON
+  imports DOMAINS-SYNTAX
+

FUN is an expression language. The constructs below fall into
+several categories: names, arithmetic constructs, conventional
+functional constructs, patterns and pattern matching, data constructs,
+lists, references, and call-with-current-continuation (callcc).
+The arithmetic constructs are standard; they are present in almost all
+our K language definitions. The meaning of FUN's constructs are
+discussed in more depth when we define their semantics in the next
+module.

+

The Syntactic Constructs

+ +

We start with the syntactic definition of FUN names.
+We have several categories of names: ones to be used for functions and
+variables, others to be used for data constructors, others for types and
+others for type variables. We will introduce them as needed, starting
+with the former category. We prefer the names of variables and functions
+to start with lower case letters. We take the freedom to tacitly introduce
+syntactic lists/sequences for each nonterminal for which we need them:

+
  syntax Name                                      [token]
+  syntax Names ::= List{Name,","}                  [klabel(exps)]
+

Expression constructs will be defined throughtout the syntax module.
+Below are the very basic ones, namely the builtins, the names, and the
+parentheses used as brackets for grouping. Lists of expressions are
+declared strict, so all expressions in the list get evaluated whenever
+the list is on a position which can be evaluated:

+
  syntax Exp ::= Int | Bool | String | Name
+               | "(" Exp ")"                       [bracket]
+  syntax Exps  ::= List{Exp,","}                   [strict, klabel(exps)]
+  syntax Val
+  syntax Exp ::= Val
+  syntax Exps ::= Vals
+  syntax Vals ::= List{Val,","}                    [klabel(exps)]
+  syntax Bottom
+  syntax Bottoms ::= List{Bottom,","}              [klabel(exps)]
+

We next define the syntax of arithmetic constructs, together with
+their relative priorities and left-/non-associativities. We also
+tag all these rules as members of a new group, "arith", so we can more easily
+define global syntax priorities later (at the end of the syntax module).

+
  syntax Exp ::= left:
+                 Exp "*" Exp                       [strict, group(arith)]
+               | Exp "/" Exp                       [strict, group(arith)]
+               | Exp "%" Exp                       [strict, group(arith)]
+               > left:
+                 Exp "+" Exp                       [strict, left, group(arith)]
+               | Exp "^" Exp                       [strict, left, group(arith)]
+// left attribute should not be necessary; currently a parsing bug
+               | Exp "-" Exp                       [strict, prefer, group(arith)]
+// the "prefer" attribute above is to not parse x-1 as x(-1)
+// Due to some parsing problems, we currently cannot add unary minus:
+               | "-" Exp                           [strict, group(arith)]
+               > non-assoc:
+                 Exp "<" Exp                       [strict, group(arith)]
+               | Exp "<=" Exp                      [strict, group(arith)]
+               | Exp ">" Exp                       [strict, group(arith)]
+               | Exp ">=" Exp                      [strict, group(arith)]
+               | Exp "==" Exp                      [strict, group(arith)]
+               | Exp "!=" Exp                      [strict, group(arith)]
+               > "!" Exp                           [strict, group(arith)]
+               > Exp "&&" Exp                      [strict(1), left, group(arith)]
+               > Exp "||" Exp                      [strict(1), left, group(arith)]
+

The conditional construct has the expected evaluation strategy,
+stating that only the first argument is evaluate:

+
  syntax Exp ::= "if" Exp "then" Exp "else" Exp    [strict(1)]
+

FUN's builtin lists are formed by enclosing comma-separated
+sequences of expressions (i.e., terms of sort Exps) in square
+brackets. The list constructor cons adds a new element to the
+top of the list, head and tail get the first element
+and the tail sublist of a list if they exist, respectively, and get
+stuck otherwise, and null?? tests whether a list is empty or
+not; syntactically, these are just expression constants.
+In function patterns, we are also going to allow patterns following the
+usual head/tail notation; for example, the pattern [x_1,...,x_n|t]
+binds x_1, ..., x_n to the first elements of the matched list,
+and t to the list formed with the remaining elements. We define list
+patterns as ordinary expression constructs, although we will make sure that
+we do not give them semantics if they appear in any other place then in a
+function case pattern.

+
  syntax Exp ::= "[" Exps "]"                             [strict, klabel(list)]
+               | "head" [macro] | "tail" [macro] | "null?" [macro]
+               | "[" Exps "|" Exp "]"
+  syntax Val ::= "[" Vals "]"                             [klabel(list)]
+  syntax Cons ::= "cons"
+  syntax Val ::= Cons
+  syntax Val ::= Cons Val                                 [klabel(apply)]
+

Data constructors start with capital letters and they may or may
+not have arguments. We need to use the attribute "prefer" to make
+sure that, e.g., Cons(a) parses as constructor Cons with
+argument a, and not as the expression Cons (because
+constructor names are also expressions) regarded as a function applied
+to the expression a. Also, note that the constructor is strict
+in its second argument, because we want to evaluate its arguments but
+not the constuctor name itsef.

+
  syntax ConstructorName                         [token]
+  syntax Exp ::= ConstructorName
+               | ConstructorName "(" Exps ")"    [prefer, strict(2), klabel(constructor)]
+  syntax Val ::= ConstructorName "(" Vals ")"    [klabel(constructor)]
+

A function is essentially a |-separated ordered
+sequence of cases, each case of the form pattern -> expression,
+preceded by the language construct fun. Patterns will be defined
+shortly, both for the builtin lists and for user-defined constructors.
+Recall that the syntax we define in K is not meant to serve as a
+ultimate parser for the defined language, but rather as a convenient
+notation for K abstract syntax trees, which we prefer when we write
+the semantic rules. It is therefore often the case that we define a
+more ``generous'' syntax than we want to allow programs to use.
+We do it here, too. Specifically, the syntax of Cases
+below allows any expressions to appear as pattern. This syntactic
+relaxation permits many wrong programs to be parsed, but that is not a
+problem because we are not going to give semantics to wrong combinations,
+so those programs will get stuck; moreover, our type inferencer will reject
+those programs anyway. Function application is just concatenation of
+expressions, without worrying about type correctness. Again, the type
+system will reject type-incorrect programs.

+
  syntax Exp ::= "fun" Cases
+               | Exp Exp                              [strict, left, klabel(apply)]
+// NOTE: We would like eventually to also have Exp "(" Exps ")
+  syntax Case  ::= Exp "->" Exp
+  syntax Cases ::= List{Case, "|"}
+

The let and letrec binders have the usual syntax
+and functional meaning. We allow multiple and-separated bindings.
+Like for the function cases above, we allow a more generous syntax for
+the left-hand sides of bindings, noting that the semantics will get stuck
+on incorrect bindings and that the type system will reject those programs.

+
  syntax Exp ::= "let" Bindings "in" Exp
+               | "letrec" Bindings "in" Exp                 [prefer]
+// The "prefer" attribute for letrec currently needed due to tool bug,
+// to make sure that "letrec" is not parsed as "let rec".
+  syntax Binding  ::= Exp "=" Exp
+  syntax Bindings ::= List{Binding,"and"}
+

References are first class values in FUN. The construct ref
+takes an expression, evaluates it, and then it stores the resulting value
+at a fresh location in the store and returns that reference. Syntactically,
+ref is just an expression constant. The construct &
+takes a name as argument and evaluates to a reference, namely the store
+reference where the variable passed as argument stores its value; this
+construct is a bit controversial and is further discussed in the
+environment-based semantics of the FUN language, where we desugar
+ref to it. The construct @ takes a reference
+and evaluates to the value stored there. The construct := takes
+two expressions, the first expected to evaluate to a reference; the value
+of its second argument will be stored at the location to which the first
+points (the old value is thus lost). Finally, since expression evaluation
+now has side effects, it makes sense to also add a sequential composition
+construct, which is sequentially strict. This evaluates to the value of
+its second argument; the value of the first argument is lost (which has
+therefore been evaluated only for its side effects.

+
  syntax Exp ::= "ref"                             [macro]
+               | "&" Name
+               | "@" Exp                                     [strict]
+               | Exp ":=" Exp                                [strict]
+               | Exp ";" Exp                       [strict(1), right]
+

Call-with-current-continuation, named callcc in FUN, is a
+powerful control operator that originated in the Scheme programming
+language, but it now exists in many other functional languages. It works
+by evaluating its argument, expected to evaluate to a function, and by
+passing the current continuation, or evaluation context (or computation,
+in K terminology), as a special value to it. When/If this special value
+is invoked, the current context is discarded and replaced with the one
+held by the special value and the computation continues from there.
+It is like taking a snapshot of the execution context at some moment
+in time and then, when desired, being able to get back in time to that
+point. If you like games, it is like saving the game now (so you can
+work on your homework!) and then continuing the game tomorrow or whenever
+you wish. To issustrate the strength of callcc, we also
+allow exceptions in FUN by means of a conventional try-catch
+construct, which will desugar to callcc. We also need to
+introduce the special expression contant throw, but we need to
+use it as a function argument name in the desugaring macro, so we define
+it as a name instead of as an expression constant:

+
  syntax Exp ::= "try" Exp "catch" "(" Name ")" Exp [macro]
+  syntax Val ::= "callcc"
+  syntax Name ::= "throw" [token]
+

Finally, FUN also allows polymorphic datatype declarations. These
+will be useful when we define the type system later on.

+
  syntax Exp ::= "datatype" Type "=" TypeCases Exp [macro]
+// NOTE: In a future version of K, we want the datatype declaration
+// to be a construct by itself, but that is not possible currently
+// because K's parser wronly identifies the __ operation allowing
+// a declaration to appear in front of an expression with the function
+// application construct, giving ambiguous parsing errors.
+

We next need to define the syntax of types and type cases that appear
+in datatype declarations.

+

Like in many functional languages, type parameters/variables in
+user-defined types are quoted identifiers.

+
  syntax TypeVar                        [token]
+  syntax TypeVars ::= List{TypeVar,","} [klabel(types)]
+

Types can be basic types, function types, or user-defined
+parametric types. In the dynamic semantics we are going to simply ignore
+all the type declations, so here the syntax of types below is only useful
+for generating the desired parser. To avoid syntactic ambiguities with
+the arrow construct for function cases, we use the symbol --> as
+a constructor for function types:

+
  syntax TypeName [token]
+  syntax Type ::= "int" | "bool" | "string"
+                | Type "-->" Type                            [right]
+                | "(" Type ")"                             [bracket]
+                | TypeVar
+                | TypeName             [klabel(TypeName), avoid]
+                | Type TypeName   [klabel(Type-TypeName), symbol, macro]
+                | "(" Types ")" TypeName                    [prefer]
+  syntax Types ::= List{Type,","} [klabel(types)]
+  syntax Types ::= TypeVars
+
+  syntax TypeCase ::= ConstructorName
+                    | ConstructorName "(" Types ")"
+  syntax TypeCases ::= List{TypeCase,"|"}     [klabel(_|TypeCase_)]
+

Additional Priorities

+ +
  syntax priorities @__FUN-UNTYPED-COMMON
+                  > apply
+                  > arith
+                  > _:=__FUN-UNTYPED-COMMON
+                  > let_in__FUN-UNTYPED-COMMON
+                    letrec_in__FUN-UNTYPED-COMMON
+                    if_then_else__FUN-UNTYPED-COMMON
+                  > _;__FUN-UNTYPED-COMMON
+                  > fun__FUN-UNTYPED-COMMON
+                  > datatype_=___FUN-UNTYPED-COMMON
+endmodule
+
+module FUN-UNTYPED-MACROS
+  imports FUN-UNTYPED-COMMON
+

Desugaring macros

+ +

We desugar the list non-constructor operations to functions matching
+over list patterns. In order to do that we need some new variables; for
+those, we follow the same convention like in the K tutorial, where we
+added them as new identifier constructs starting with the character $,
+so we can easily recognize them when we debug or trace the semantics.

+
  syntax Name ::= "$h" [token] | "$t" [token]
+  rule head => fun [$h|$t] -> $h
+  rule tail => fun [$h|$t] -> $t
+  rule null? => fun [.Exps] -> true | [$h|$t] -> false
+

Multiple-head list patterns desugar into successive one-head patterns:

+
  rule [E1,E2,Es:Exps|T] => [E1|[E2,Es|T]]                   [anywhere]
+

Uncurrying of multiple arguments in functions and binders:

+
  rule P1 P2 -> E => P1 -> fun P2 -> E                       [anywhere]
+  rule F P = E => F = fun P -> E                             [anywhere]
+

We desugar the try-catch construct into callcc:

+
  syntax Name ::= "$k" [token] | "$v" [token]
+  rule try E catch(X) E'
+    => callcc (fun $k -> (fun throw -> E)(fun X -> $k E'))
+

For uniformity, we reduce all types to their general form:

+
  rule `Type-TypeName`(T:Type, Tn:TypeName) => (T) Tn
+

The dynamic semantics ignores all the type declarations:

+
  rule datatype _T = _TCs E => E
+
+endmodule
+
+
+module FUN-UNTYPED-SYNTAX
+  imports FUN-UNTYPED-COMMON
+  imports BUILTIN-ID-TOKENS
+
+  syntax Name ::= r"[a-z][_a-zA-Z0-9]*"           [token, prec(2)]
+                | #LowerId                        [token]
+  syntax ConstructorName ::= #UpperId             [token]
+  syntax TypeVar  ::= r"['][a-z][_a-zA-Z0-9]*"    [token]
+  syntax TypeName ::= Name                        [token]
+endmodule
+

Semantics

+ +

The semantics below is environment-based. A substitution-based
+definition of FUN is also available, but that drops the &
+construct as explained above.

+
module FUN-UNTYPED
+  imports FUN-UNTYPED-COMMON
+  imports FUN-UNTYPED-MACROS
+  imports DOMAINS
+  //imports PATTERN-MATCHING
+

Configuration

+ +

The k, env, and store cells are standard
+(see, for example, the definition of LAMBDA++ or IMP++ in the first
+part of the K tutorial).

+
  configuration <T color="yellow">
+                  <k color="green"> $PGM:Exp </k>
+                  <env color="violet"> .Map </env>
+                  <store color="white"> .Map </store>
+                </T>
+

Values and results

+ +

We only define integers, Booleans and strings as values here, but will
+add more values later.

+
  syntax Val ::= Int | Bool | String
+  syntax Vals ::= Bottoms
+  syntax KResult ::= Val
+

Lookup

+ +
  rule <k> X:Name => V ...</k>
+       <env>... X |-> L ...</env>
+       <store>... L |-> V ...</store>
+

Arithmetic expressions

+ +
  rule I1 * I2 => I1 *Int I2
+  rule I1 / I2 => I1 /Int I2 when I2 =/=K 0
+  rule I1 % I2 => I1 %Int I2 when I2 =/=K 0
+  rule I1 + I2 => I1 +Int I2
+  rule S1 ^ S2 => S1 +String S2
+  rule I1 - I2 => I1 -Int I2
+  rule - I => 0 -Int I
+  rule I1 < I2 => I1 <Int I2
+  rule I1 <= I2 => I1 <=Int I2
+  rule I1 > I2 => I1 >Int I2
+  rule I1 >= I2 => I1 >=Int I2
+  rule V1:Val == V2:Val => V1 ==K V2
+  rule V1:Val != V2:Val => V1 =/=K V2
+  rule ! T => notBool(T)
+  rule true  && E => E
+  rule false && _ => false
+  rule true  || _ => true
+  rule false || E => E
+

Conditional

+ +
  rule if  true then E else _ => E
+  rule if false then _ else E => E
+

Lists

+ +

We have already declared the syntactic list of expressions strict, so
+we can assume that all the elements that appear in a FUN list are
+evaluated. The only thing left to do is to state that a list of
+values is a value itself, that is, that the list square-bracket
+construct is indeed a constructor, and to give the semantics of
+cons. Since cons is a builtin function and is
+expected to take two arguments, we have to also state that
+cons itself is a value (specifically, a function/closure
+value, but we do not need that level of detail here), and also that
+cons applied to a value is a value (specifically, it would be
+a function/closure value that expects the second, list argument):

+
  rule cons V:Val [Vs:Vals] => [V,Vs]
+

Data Constructors

+ +

Constructors take values as arguments and produce other values:

+
  syntax Val ::= ConstructorName
+

Functions and Closures

+ +

Like in the environment-based semantics of LAMBDA++ in the first part
+of the K tutorial, functions evaluate to closures. A closure includes
+the current environment besides the function contents; the environment
+will be used at execution time to lookup all the variables that appear
+free in the function body (we want static scoping in FUN).

+
  syntax Val ::= closure(Map,Cases)
+  rule <k> fun Cases => closure(Rho,Cases) ...</k>  <env> Rho </env>
+

Note: The reader may want to get familiar with
+how the pre-defined pattern matching works before proceeding.
+The best way to do that is to consult
+k/include/modules/pattern-matching.k.

+

We distinguish two cases when the closure is applied.
+If the first pattern matches, then we pick the first case: switch to
+the closed environment, get the matching map and bind all its
+variables, and finally evaluate the function body of the first case,
+making sure that the environment is properly recovered afterwards.
+If the first pattern does not match, then we drop it and thus move on
+to the next one.

+
  rule (. => getMatching(P, V)) ~> closure(_, P->_ | _) V:Val
+  rule <k> matchResult(M:Map) ~> closure(Rho, _->E | _) _
+           => bindMap(M) ~> E ~> setEnv(Rho') ...</k>
+       <env> Rho' => Rho </env>
+  rule (matchFailure => .) ~> closure(_, (_->_ | Cs:Cases => Cs)) _
+//  rule <k> closure(Rho, P->E | _) V:Val
+//           => bindMap(getMatching(P,V)) ~> E ~> setEnv(Rho') ...</k>
+//       <env> Rho' => Rho </env>  when isMatching(P,V)
+//  rule closure(_, (P->_ | Cs:Cases => Cs)) V:Val  when notBool isMatching(P,V)
+

Let and Letrec

+ +

To highlight the similarities and differences between let and
+letrec, we prefer to give them direct semantics instead of
+to desugar them like in LAMBDA. See the formal definitions of
+bindTo, bind, and assignTo at the end of
+this module. Informally, bindTo(Xs, Es) first
+evaluates the expressions Es in Exps in the current
+environment (i.e., it is strict in its second argument), then it binds
+the variables in Xs in Names to new locations and adds
+those bindings to the environment, and finally writes the values
+previously obtained after evaluating the expressions Es to those
+new locations; bind(Xs) does only the bindings of
+Xs to new locations and adds those bindings to the environment;
+and assignTo(Xs,Es) evaluates the expressions
+Es in the current environment and then it writes the resulting
+values to the locations to which the variables Xs are already
+bound to in the environment.

+

Therefore, let Xs = Es in E first
+evaluates Es in the current environment, then adds new
+bindings for Xs to fresh locations in the environment, then
+writes the values of Es to those locations, and finally
+evaluates E in the new environment, making sure that the
+environment is properly recovered after the evaluation of E.
+On the other hand, letrec does the same things but in a
+different order: it first adds new bindings for Xs to fresh
+locations in the environment, then it evaluates Es in the new
+environment, then it writes the resulting values to their
+corresponding locations, and finally it evaluates E and
+recovers the environment. The crucial difference is that the
+expressions Es now see the locations of the variables Xs
+in the environment, so if they are functions, which is typically the
+case with letrec, their closures will encapsulate in their
+environments the bindings of all the bound variables, including
+themselves (thus, we may have a closure value stored at location
+L, whose environment contains a binding of the form
+F ↦ L; this way, the closure can invoke
+itself).

+
  rule <k> let Bs in E
+        => bindTo(names(Bs),exps(Bs)) ~> E ~> setEnv(Rho) ...</k>
+       <env> Rho </env>
+
+  rule <k> letrec Bs in E
+        => bind(names(Bs))~>assignTo(names(Bs),exps(Bs))~>E~>setEnv(Rho)...</k>
+       <env> Rho </env>
+

Recall that our syntax allows let and letrec to
+take any expression in place of its binding. This allows us to use
+the already existing function application construct to bind names to
+functions, such as, e.g., let x y = y in ....
+The desugaring macro in the syntax module uncurries such declarations,
+and then the semantic rules above only work when the remaining
+bindings are identifiers, so the semantics will get stuck on programs
+that misuse the let and letrec binders.

+

References

+ +

The semantics of references is self-explanatory, except maybe for the
+desugaring rule of ref, which is further discussed. Note
+that &X grabs the location of X from the environment.
+Sequential composition, which is needed only to accumulate the
+side effects due to assignments, was strict in the first argument.
+Once evaluated, its first argument is simply discarded:

+
  syntax Name ::= "$x" [token]
+  rule ref => fun $x -> & $x
+  rule <k> & X => L ...</k>  <env>... X |-> L ...</env>
+  rule <k> @ L:Int => V:Val ...</k>  <store>... L |-> V ...</store>
+  rule <k> L:Int := V:Val => V ...</k>  <store>... L |-> (_=>V) ...</store>
+  rule _V:Val; E => E
+

The desugaring rule of ref (first rule above) works
+because & takes a variable and returns its location (like in C).
+Note that some ``pure'' functional programming researchers strongly dislike
+the & construct, but favor ref. We refrain from having
+a personal opinion on this issue here, but support & in the
+environment-based definition of FUN because it is, technically speaking,
+more powerful than ref. From a language design perspective, it
+would be equally easy to drop & and instead give a direct
+semantics to ref. In fact, this is precisely what we do in the
+substitution-based definition of FUN, because there appears to be no way
+to give a substitution-based definition to the & construct.

+

Callcc

+ +

As we know it from the LAMBDA++ tutorial, call-with-current-continuation
+is quite easy to define in K. We first need to define a special
+value wrapping an execution context, that is, an environment saying
+where the variables should be looked up, and a computation structure
+saying what is left to execute (in a substitution-based definition,
+this special value would be even simpler, as it would only need to
+wrap the computation structure---see, for example, the
+substitution-based semantics of LAMBDA++ in the the first part of the
+K tutorial, or the substitution-based definition of FUN). Then
+callcc creates such a value containing the current
+environment and the current remaining computation, and passes it to
+its argument function. When/If invoked, the special value replaces
+the current execution context with its own and continues the execution
+normally.

+
  syntax Val ::= cc(Map,K)
+  rule <k> (callcc V:Val => V cc(Rho,K)) ~> K </k>  <env> Rho </env>
+  rule <k> cc(Rho,K) V:Val ~> _ => V ~> K </k>  <env> _ => Rho </env>
+

Auxiliary operations

+ +

Environment recovery

+ +

The environment recovery operation is the same as for the LAMBDA++
+language in the K tutorial and many other languages provided with the
+K distribution. The first ``anywhere'' rule below shows an elegant
+way to achieve the benefits of tail recursion in K.

+
  syntax KItem ::= setEnv(Map)  // TODO: get rid of env
+  //rule (setEnv(_) => .) ~> setEnv(_)  [anywhere]
+  rule <k> _:Val ~> (setEnv(Rho) => .) ...</k> <env> _ => Rho </env>
+

bindTo, bind and assignTo

+ +

The meaning of these operations has already been explained when we
+discussed the let and letrec language constructs
+above.

+
  syntax KItem ::= bindTo(Names,Exps)         [strict(2)]
+                 | bindMap(Map)
+                 | bind(Names)
+
+  rule (. => getMatchingAux(Xs,Vs)) ~> bindTo(Xs:Names,Vs:Vals)
+  rule matchResult(M:Map) ~> bindTo(_:Names, _:Vals) => bindMap(M)
+
+  rule bindMap(.Map) => .
+  rule <k> bindMap((X:Name |-> V:Val => .Map) _:Map) ...</k>
+       <env> Rho => Rho[X <- !L:Int] </env>
+       <store>... .Map => !L |-> V ...</store>
+
+  rule bind(.Names) => .
+  rule <k> bind(X:Name,Xs => Xs) ...</k>
+       <env> Rho => Rho[X <- !_L:Int] </env>
+
+  syntax KItem ::= assignTo(Names,Exps)  [strict(2)]
+
+  rule <k> assignTo(.Names,.Vals) => . ...</k>
+  rule <k> assignTo((X:Name,Xs => Xs),(V:Val,Vs:Vals => Vs)) ...</k>
+       <env>... X |-> L ...</env>
+       <store>... .Map => L |-> V ...</store>
+

Getters

+ +

The following auxiliary operations extract the list of identifiers
+and of expressions in a binding, respectively.

+
  syntax Names ::= names(Bindings)  [function]
+  rule names(.Bindings) => .Names
+  rule names(X:Name=_ and Bs) => (X,names(Bs))::Names
+
+  syntax Exps ::= exps(Bindings)  [function]
+  rule exps(.Bindings) => .Exps
+  rule exps(_:Name=E and Bs) => E,exps(Bs)
+
+  /* Extra kore stuff */
+  syntax KResult ::= Vals
+  syntax Exps ::= Names
+  syntax Names ::= Bottoms
+
+  /* Matching */
+  syntax MatchResult ::= getMatching(Exp, Val)                      [function]
+                       | getMatchingAux(Exps, Vals)                 [function]
+                       | mergeMatching(MatchResult, MatchResult)    [function]
+                       | matchResult(Map)
+                       | "matchFailure"
+
+  rule getMatching(C:ConstructorName(Es:Exps), C(Vs:Vals)) => getMatchingAux(Es, Vs)
+  rule getMatching([Es:Exps], [Vs:Vals])                   => getMatchingAux(Es, Vs)
+  rule getMatching(C:ConstructorName, C) => matchResult(.Map)
+  rule getMatching(B:Bool, B)            => matchResult(.Map)
+  rule getMatching(I:Int, I)             => matchResult(.Map)
+  rule getMatching(S:String, S)          => matchResult(.Map)
+  rule getMatching(N:Name, V:Val) => matchResult(N |-> V)
+  rule getMatching(_, _) => matchFailure        [owise]
+
+  rule getMatchingAux((E:Exp, Es:Exps), (V:Val, Vs:Vals)) => mergeMatching(getMatching(E, V), getMatchingAux(Es, Vs))
+  rule getMatchingAux(.Exps, .Vals)                       => matchResult(.Map)
+  rule getMatchingAux(_, _) => matchFailure     [owise]
+
+  rule mergeMatching(matchResult(M1:Map), matchResult(M2:Map)) => matchResult(M1 M2)
+    requires intersectSet(keys(M1), keys(M2)) ==K .Set
+  //rule mergeMatching(_, _) => matchFailure      [owsie]
+  rule mergeMatching(matchResult(_:Map), matchFailure) => matchFailure
+  rule mergeMatching(matchFailure, matchResult(_:Map)) => matchFailure
+  rule mergeMatching(matchFailure, matchFailure)       => matchFailure
+

Besides the generic decomposition rules for patterns and values,
+we also want to allow [head|tail] matching for lists, so we add
+the following custom pattern decomposition rule:

+
  rule getMatching([H:Exp | T:Exp], [V:Val, Vs:Vals])
+    => getMatchingAux((H, T), (V, [Vs]))
+endmodule
+

Go to Lesson 2, FUN untyped, Substitution-Based.

+

FUN — Untyped — Substitution

+ +

Author: Grigore Roșu (grosu@illinois.edu)
+Organization: University of Illinois at Urbana-Champaign

+

Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
+Organization: University of Bucharest

+

Abstract

+ +

This is the substitution-based definition of FUN. For additional
+explanations regarding the semantics of the various FUN constructs,
+the reader should consult the emvironment-based definition of FUN.

+

Syntax

+ +
require "substitution.md"
+//require "modules/pattern-matching.k"
+
+module FUN-UNTYPED-COMMON
+  imports DOMAINS-SYNTAX
+

The Syntactic Constructs

+ +
  syntax Name
+  syntax Names ::= List{Name,","}
+
+  syntax Exp ::= Int | Bool | String | Name
+               | "(" Exp ")"                       [bracket]
+  syntax Exps  ::= List{Exp,","}                   [strict]
+  syntax Val
+  syntax Vals ::= List{Val,","}
+
+  syntax Exp ::= left:
+                 Exp "*" Exp                       [strict, arith]
+               | Exp "/" Exp                       [strict, arith]
+               | Exp "%" Exp                       [strict, arith]
+               > left:
+                 Exp "+" Exp                       [strict, left, arith]
+               | Exp "^" Exp                       [strict, left, arith]
+               | Exp "-" Exp                       [strict, prefer, arith]
+               | "-" Exp                           [strict, arith]
+               > non-assoc:
+                 Exp "<" Exp                       [strict, arith]
+               | Exp "<=" Exp                      [strict, arith]
+               | Exp ">" Exp                       [strict, arith]
+               | Exp ">=" Exp                      [strict, arith]
+               | Exp "==" Exp                      [strict, arith]
+               | Exp "!=" Exp                      [strict, arith]
+               > "!" Exp                           [strict, arith]
+               > Exp "&&" Exp                      [strict(1), left, arith]
+               > Exp "||" Exp                      [strict(1), left, arith]
+
+  syntax Exp ::= "if" Exp "then" Exp "else" Exp    [strict(1)]
+
+  syntax Exp ::= "[" Exps "]"                      [strict]
+               | "cons" |  "head" | "tail" | "null?"
+               | "[" Exps "|" Exp "]"
+  syntax Val ::= "[" Vals "]"
+
+  syntax ConstructorName
+  syntax Exp ::= ConstructorName
+               | ConstructorName "(" Exps ")"      [prefer, strict(2)]
+  syntax Val ::= ConstructorName "(" Vals ")"
+
+  syntax Exp ::= "fun" Cases
+               | Exp Exp                           [strict, left]
+  syntax Case  ::= Exp "->" Exp                    [binder]
+// NOTE: The binder attribute above is the only difference between this
+// module and the syntax module of environment-based FUN.  We need
+// to fix a bug in order to import modules and override the attributes
+// of operations.
+  syntax Cases ::= List{Case, "|"}
+
+  syntax Exp ::= "let" Bindings "in" Exp
+               | "letrec" Bindings "in" Exp                 [prefer]
+  syntax Binding  ::= Exp "=" Exp
+  syntax Bindings ::= List{Binding,"and"}
+
+  syntax Exp ::= "ref"
+               | "&" Name
+               | "@" Exp                           [strict]
+               | Exp ":=" Exp                      [strict]
+               | Exp ";" Exp                       [strict(1), right]
+
+  syntax Exp ::= "callcc"
+               | "try" Exp "catch" "(" Name ")" Exp
+  syntax Name ::= "throw" [token]
+
+  syntax Exp ::= "datatype" Type "=" TypeCases Exp
+
+  syntax TypeVar
+  syntax TypeVars ::= List{TypeVar,","}
+
+  syntax TypeName
+  syntax Type ::= "int" | "bool" | "string"
+                | Type "-->" Type                            [right]
+                | "(" Type ")"                             [bracket]
+                | TypeVar
+                | TypeName             [klabel(TypeName), avoid]
+                | Type TypeName   [klabel(Type-TypeName), onlyLabel]
+                | "(" Types ")" TypeName                    [prefer]
+  syntax Types ::= List{Type,","}
+  syntax Types ::= TypeVars
+
+  syntax TypeCase ::= ConstructorName
+                    | ConstructorName "(" Types ")"
+  syntax TypeCases ::= List{TypeCase,"|"}     [klabel(_|TypeCase_)]
+

Additional Priorities

+ +
  syntax priorities @__FUN-UNTYPED-COMMON
+                  > ___FUN-UNTYPED-COMMON
+                  > arith
+                  > _:=__FUN-UNTYPED-COMMON
+                  > let_in__FUN-UNTYPED-COMMON
+                    letrec_in__FUN-UNTYPED-COMMON
+                    if_then_else__FUN-UNTYPED-COMMON
+                  > _;__FUN-UNTYPED-COMMON
+                  > fun__FUN-UNTYPED-COMMON
+                  > datatype_=___FUN-UNTYPED-COMMON
+endmodule
+
+module FUN-UNTYPED-MACROS
+  imports FUN-UNTYPED-COMMON
+

Desugaring macros

+ +
  rule P1 P2 -> E => P1 -> fun P2 -> E                       [macro-rec]
+  rule F P = E => F = fun P -> E                             [macro-rec]
+
+  rule [E1,E2,Es:Exps|T] => [E1|[E2,Es|T]]                   [macro-rec]
+
+//  rule 'TypeName(Tn:TypeName) => (.TypeVars) Tn              [macro]
+  rule `Type-TypeName`(T:Type, Tn:TypeName) => (T) Tn          [macro]
+
+  syntax Name ::= "$h" | "$t"
+  rule head => fun [$h|$t] -> $h                             [macro]
+  rule tail => fun [$h|$t] -> $t                             [macro]
+  rule null? => fun [.Exps] -> true | [$h|$t] -> false       [macro]
+
+  syntax Name ::= "$k" | "$v"
+  rule try E catch(X) E'
+    => callcc (fun $k -> (fun throw -> E)(fun X -> $k E'))   [macro]
+
+  rule datatype _T = _TCs E => E                               [macro]
+

mu needed for letrec, but we put it here so we can also write
+programs with mu in them, which is particularly useful for testing.

+
  syntax Exp ::= "mu" Case
+
+endmodule
+
+
+module FUN-UNTYPED-SYNTAX
+  imports FUN-UNTYPED-COMMON
+  imports BUILTIN-ID-TOKENS
+
+  syntax Name ::= r"[a-z][_a-zA-Z0-9]*"            [token, prec(2)]
+                | #LowerId                         [token]
+  syntax ConstructorName ::= #UpperId              [token]
+  syntax TypeVar  ::= r"['][a-z][_a-zA-Z0-9]*"     [token]
+  syntax TypeName ::= Name                         [token]
+endmodule
+

Semantics

+ +
module FUN-UNTYPED
+  imports FUN-UNTYPED-COMMON
+  imports FUN-UNTYPED-MACROS
+  imports DOMAINS
+  imports SUBSTITUTION
+  //imports PATTERN-MATCHING
+
+  configuration <T color="yellow">
+                  <k color="green"> $PGM:Exp </k>
+                  <store color="white"> .Map </store>
+                </T>
+

Both Name and functions are values now:

+
  syntax Val ::= Int | Bool | String | Name
+  syntax Exp ::= Val
+  syntax Exps ::= Vals
+  syntax KResult ::= Val
+  syntax Exps ::= Names
+  syntax Vals ::= Names
+
+  rule I1 * I2 => I1 *Int I2
+  rule I1 / I2 => I1 /Int I2 when I2 =/=K 0
+  rule I1 % I2 => I1 %Int I2 when I2 =/=K 0
+  rule I1 + I2 => I1 +Int I2
+  rule S1 ^ S2 => S1 +String S2
+  rule I1 - I2 => I1 -Int I2
+  rule - I => 0 -Int I
+  rule I1 < I2 => I1 <Int I2
+  rule I1 <= I2 => I1 <=Int I2
+  rule I1 > I2 => I1 >Int I2
+  rule I1 >= I2 => I1 >=Int I2
+  rule V1:Val == V2:Val => V1 ==K V2
+  rule V1:Val != V2:Val => V1 =/=K V2
+  rule ! T => notBool(T)
+  rule true  && E => E
+  rule false && _ => false
+  rule true  || _ => true
+  rule false || E => E
+
+  rule if  true then E else _ => E
+  rule if false then _ else E => E
+
+  rule isVal(cons) => true
+  rule isVal(cons _V:Val) => true
+  rule cons V:Val [Vs:Vals] => [V,Vs]
+
+  syntax Val ::= ConstructorName
+
+  rule isVal(fun _) => true
+  syntax KVar ::= Name
+  syntax Name ::= freshName(Int)    [freshGenerator, function]
+  rule freshName(I:Int) => {#parseToken("Name", "#" +String Int2String(I))}:>Name
+
+  rule (. => getMatching(P, V)) ~> (fun P->_ | _) V:Val
+  rule matchResult(M:Map) ~> (fun _->E | _) _ => E[M]
+  rule (matchFailure => .) ~> (fun (_->_ | Cs:Cases => Cs)) _
+//  rule (fun P->E | _) V:Val => E[getMatching(P,V)]  when isMatching(P,V)
+//  rule (fun (P->_ | Cs:Cases => Cs)) V:Val  when notBool isMatching(P,V)
+

We can reduce multiple bindings to one list binding, and then
+apply the usual desugaring of let into function application.
+It is important that the rule below is a macro, so let is eliminated
+immediately, otherwise it may interfere in ugly ways with substitution.

+
  rule let Bs in E => ((fun [names(Bs)] -> E) [exps(Bs)])    [macro]
+

We only give the semantics of one-binding letrec.
+Multipe bindings are left as an exercise.

+
  // changed because of parsing error
+  //rule mu X:Name -> E => E[(mu X -> E) / X]
+  rule mu X:Name -> E => E[X |-> (mu X -> E)]
+  rule letrec F:Name = E in E' => let F = (mu F -> E) in E'  [macro]
+

We cannot have & anymore, but we can give direct
+semantics to ref. We also have to declare ref to
+be a value, so that we will never heat on it.

+
//  rule <k> & X => L ...</k>  <env>... X |-> L </env>
+  rule isVal(ref) => true
+  rule <k> ref V:Val => !L:Int ...</k> <store>... .Map => !L |-> V ...</store>
+  rule <k> @ L:Int => V:Val ...</k>  <store>... L |-> V ...</store>
+  rule <k> L:Int := V:Val => V ...</k>  <store>... L |-> (_=>V) ...</store>
+  rule _V:Val; E => E
+
+  syntax Val ::= cc(K)
+  rule isVal(callcc) => true
+  rule <k> (callcc V:Val => V cc(K)) ~> K </k>
+  rule <k> cc(K) V:Val ~> _ => V ~> K </k>
+

Auxiliary getters

+
  syntax Names ::= names(Bindings)  [function]
+  rule names(.Bindings) => .Names
+  rule names(X:Name=_ and Bs) => X,names(Bs)
+
+  syntax Exps ::= exps(Bindings)  [function]
+  rule exps(.Bindings) => .Exps
+  rule exps(_:Name=E and Bs) => E,exps(Bs)
+
+  /* Extra kore stuff */
+  syntax KResult ::= Vals
+  syntax Exps ::= Names
+
+  /* Matching */
+  syntax MatchResult ::= getMatching(Exp, Val)                      [function]
+                       | getMatchingAux(Exps, Vals)                 [function]
+                       | mergeMatching(MatchResult, MatchResult)    [function]
+                       | matchResult(Map)
+                       | "matchFailure"
+
+  rule getMatching(C:ConstructorName(Es:Exps), C(Vs:Vals)) => getMatchingAux(Es, Vs)
+  rule getMatching([Es:Exps], [Vs:Vals])                   => getMatchingAux(Es, Vs)
+  rule getMatching(C:ConstructorName, C) => matchResult(.Map)
+  rule getMatching(B:Bool, B)            => matchResult(.Map)
+  rule getMatching(I:Int, I)             => matchResult(.Map)
+  rule getMatching(S:String, S)          => matchResult(.Map)
+  rule getMatching(N:Name, V:Val) => matchResult(N |-> V)
+  rule getMatching(_, _) => matchFailure        [owise]
+
+  rule getMatchingAux((E:Exp, Es:Exps), (V:Val, Vs:Vals)) => mergeMatching(getMatching(E, V), getMatchingAux(Es, Vs))
+  rule getMatchingAux(.Exps, .Vals)                       => matchResult(.Map)
+  rule getMatchingAux(_, _) => matchFailure     [owise]
+
+  rule mergeMatching(matchResult(M1:Map), matchResult(M2:Map)) => matchResult(M1 M2)
+    requires intersectSet(keys(M1), keys(M2)) ==K .Set
+  //rule mergeMatching(_, _) => matchFailure      [owsie]
+  rule mergeMatching(matchResult(_:Map), matchFailure) => matchFailure
+  rule mergeMatching(matchFailure, matchResult(_:Map)) => matchFailure
+  rule mergeMatching(matchFailure, matchFailure)       => matchFailure
+

Besides the generic decomposition rules for patterns and values,
+we also want to allow [head|tail] matching for lists, so we add
+the following custom pattern decomposition rule:

+
  rule getMatching([H:Exp | T:Exp], [V:Val, Vs:Vals])
+    => getMatchingAux((H, T), (V, [Vs]))
+endmodule
+

LOGIK

+ +

Author: Grigore Roșu (grosu@illinois.edu)
+Organization: University of Illinois at Urbana-Champaign

+

Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
+Organization: University of Bucharest

+

Abstract

+ +

This is the K semantic definition of LOGIK, a trivial language
+capturing the essence of the logic programming paradigm. In this
+definition, we explicitly focus on simplicity and mathematical
+clarity, not on advanced logic programming features or performance.
+Those are covered in the LOGIK++ extension under examples/logik++.

+

Specifically, a LOGIK program consists of a sequence of Horn clauses
+of the form

+
P :- P1, P2, ..., Pn .
+

followed by a query of the form

+
?- Q1, Q2, ..., Qm .
+

where P, P1, P2, ..., Pn, Q1, Q2,
+..., Qm are literals. The
+symbol :- is read "if". A literal has the form
+p(T1,T2,...,Tk), where p is a predicate symbol
+and where T1,T2,...,Tk are terms. Terms are built as
+usual, with operation symbols and variables. A common
+convention in logic programming languages, also adopted here, is that
+variables are capitalized and operation symbols are not. Operations
+with zero arguments are called constants and are written without
+parentheses, that is, c instead of c(). Horn
+clauses without conditions, called facts, are written
+without :-, that is, P. instead of P :- ..

+

For example, the LOGIK program below gives a few facts about a
+parent predicate, then several clauses defining some useful
+predicates including an ancestor predicate, and finally a
+query asking for those who both have ancestors and are ancestors
+themselves in the parent relation:

+
parent(david,john).
+parent(jim,david).
+parent(steve,jim).
+parent(nathan,steve).
+
+grandparent(A,B):-
+  parent(A,X),
+  parent(X,B).
+
+ancestor(A,B):-
+  parent(A,X),
+  parents(X,B).
+
+parents(X,X).
+parents(A,B):-
+  ancestor(A,B).
+
+both(X) :- ancestor(A,X), ancestor(X,B).
+
+?- both(X).
+

Above, we only have constant operation symbols, so these and variables
+are the only terms that can be used in predicates. As expected, the
+LOGIK program above will give us three solutions for X:
+david, steve, and jim. If we inline the
+both(X) predicate in the query, that is, if we replace the
+query with ?- ancestor(A,X), ancestor(X,B). then we get
+10 solutions, one for for each triple A, X, and
+B satisfying both predicates ancestor(A,X) and
+ancestor(X,B).

+

As another example, the program below defines an append
+predicate followed by a simple goal:

+
append(nil,L,L).
+append(cons(H,T),L,cons(H,Z)) :- append(T,L,Z).
+
+?- append(cons(a,nil), cons(b,nil), V).
+

Besides the predicate symbol append, the program above also
+includes a constant symbol nil and a binary operation symbol
+cons. Additionally, the query also includes two more
+constants, a and b. The capitalized identifiers are
+all variables. As expected, the LOGIK program above yields only one
+solution, namely V = cons(a,cons(b,nil)). On the other hand,
+if we change the query to:

+
?- append(L1, cons(a,L2), cons(a,cons(b,cons(a,nil)))).
+

then LOGIK yields two solutions: one where L1 is
+cons(a,cons(b,nil)) and L2 is nil,
+and another where L1 is nil and L2 is
+cons(a,cons(b,nil)).

+

The programs above all generated ground solutions, that is,
+solutions where the query variables are mapped to ground terms (i.e.,
+terms without variables). Let us now consider the following query:

+
?- append(cons(a,nil), Y, Z).
+

There are obviously infinitely many ground solutions for the query
+above, e.g.,
+Y = nil and Z = cons(a,nil),
+Y = cons(a,nil) and Z = cons(a,cons(a,nil)),
+Y = cons(b,nil) and Z = cons(a,cons(b,nil)),
+Y = cons(c,cons(b,nil)) and Z = cons(a,cons(c,cons(b,nil))),
+etc. However, all the ground solutions for the query above can be
+elegantly characterized by the property that Z is bound to a list
+starting with a and followed by the list that Y is
+bound to. This property can in fact be described as a symbolic solution
+to the query: Z = cons(a,Y) or, equivalently,
+Y = Symb and Z = cons(a,Symb). It is possible to
+define a ``more general than'' relation on such symbolic solutions,
+in the sense that the more particular solution can be obtained as a
+specialization/substitution of the more general one, and then it can
+be shown that the above is the most general solution to the
+stated query. Logic programming languages, including our LOGIK,
+attempt to always compute such most general solutions.

+

Logic programming languages are highly non-deterministic, in that
+several Horn clauses may be used at the same time, each possibly
+resulting in a different solution. Implementations of logic
+programming languages consist of complex, optimized search and
+indexing algorithms, which we are not concerned with here. Instead,
+we here take advantage of K's builtin support for search.
+Specifically, to find all the solutions of a LOGIK program, we have to
+use krun with the option --search. However, note
+that some programs have infinitely many solutions which cannot relate
+to each other by the "more general" relation. For example, the query

+
?- append(L1, cons(a,L2), L3) .
+

To address such cases and terminate, logic programming languages allow
+the user to choose how many solutions to be computed and displayed.
+In LOGIK, we can use the --bound option of krun for
+this purpose.

+

Finally, note that some queries have no solution. In some cases that
+is easy to detect by exhaustive analysis, such as for the following
+query:

+
?- append(cons(a,L1), L2, cons(b,L3)).
+

Logic programming languages, including LOGIK, terminate in such cases
+and report a no solution answer. However, there are cases where
+exhaustive analysis is not sufficient, such as for the query:

+
?- append(cons(a,L), nil, L).
+

In such cases, logic programming languages do not terminate. While
+one may devise techniques to detect non-termination in some cases,
+one cannot do it in general (same like for all Turing-complete
+languages).

+
require "unification.k"
+
+module LOGIK-COMMON
+  imports DOMAINS-SYNTAX
+

Syntax

+ +

The syntax of LOGIK is straightforward: a program is a sequence of
+Horn clauses followed by a query:

+
  syntax Literal
+  syntax Term ::= Literal | Literal "(" Terms ")"
+  syntax Terms ::= List{Term,","}
+  syntax Clause ::= Term ":-" Terms "." | Term "."
+  syntax Query ::= "?-" Terms "."
+  syntax Pgm ::= Query | Clause Pgm
+endmodule
+
+module LOGIK-SYNTAX
+  imports LOGIK-COMMON
+  imports BUILTIN-ID-TOKENS
+

Variables and literals are defined as tokens following the conventions
+used in Prolog (variables start with _ or capital letter, while literals
+start with lower case letters):

+
  syntax #KVariable ::= r"[A-Z_][A-Za-z0-9_]*"   [token, prec(2)]
+                      | #UpperId                 [token]
+  syntax Term ::= #KVariable [klabel(#SemanticCastToTerm)]
+  syntax Literal ::= r"[a-z][a-zA-Z0-9_]*"                 [token]
+                   | #LowerId                              [token]
+endmodule
+
+module LOGIK
+  imports LOGIK-COMMON
+  imports DOMAINS
+  imports UNIFICATION
+

Unification is at the core of logic programming. Here we are
+going to use the predefined unification procedure (the same one we
+used in the type inferencers in Tutorial 5).

+

Configuration

+ +

The configuration stores each clause in its own cell for easy access,
+and the most general unifier in a cell named mgu, same like
+the type inferencers. The k cell holds the query and the
+fresh cell holds a fresh clause instance to be attempted on
+the next query item. To more easily read the solutions, we add a
+second top-level cell, solution. Both top cells are
+optional. Indeed, we start with the main top cell and, when a
+solution is found, we move it into the solution cell and
+discard the main cell.

+
  configuration <T color="yellow" multiplicity="?">
+                  <k color="green"> $PGM:Pgm </k>
+                  <fresh color="orange"> .K </fresh>
+                  <clauses color="red">
+                    <clause color="pink" multiplicity="*"> .K </clause>
+                  </clauses>
+                  <mgu> .K </mgu>
+                </T>
+                <solution multiplicity="?"> .K </solution>
+

Pre- and post-processing

+ +

Before we launch the semantics, we first scan the given program and
+place each clause in its own cell, and then place the query in the
+k cell and initialize the mgu with the variables from the query.

+

Note that we put a fresh instance of the clause to avoid interference with
+the query variables. By a "fresh instance" of a clause we mean one whose
+variables are renamed with fresh names; we need that in order to avoid
+undesired unification conflicts due to particular names chosen for
+variables in the original program, as well as conflicts due to
+subsequent uses of the same clause. It is safe to rename the
+variables in a clause, because clauses are universally quantified in
+their variables. This process of creating a fresh instance of a
+clause is similar to how we created fresh instances of type schemas in
+the higher-order type inferencer discussed in Tutorial 5. Indeed, we
+can safely regard clauses as "clause schemas" comprising infinitely
+many instances, one for each context.

+
  rule <k> C:Clause Pgm => Pgm </k>
+       (.Bag => <clause> #renameVariables(C) </clause>)
+
+  rule <k> ?- Ls:Terms. => Ls ...</k>
+       <mgu> _ => #variablesMap(#variables(Ls)) </mgu>
+

We also sequentialize the goals for easier processing:

+
  rule L:Term, Ls:Terms => L ~> Ls
+  rule .Terms => .
+

When all the goals are solved, indicated by the empty k
+cell, the calculated most general unifier (mgu) is in the mgu
+cell. In that case, to ease reading of the final solution we move the
+mgu in the solution cell and delete the rest of the
+configuration:

+
rule <T>... <k> . </k> <mgu> Theta </mgu> ...</T>
+  => <solution> Theta </solution>
+

Since we are not interested in seeing the failed attempts to solve
+the query, we collapse all the error configurations into an empty
+configuration (recall that both top-level cells in the configuration
+were declared optional). This way, if we see an empty configuration
+when we search for all solutions, we know that some attempts failed
+(but we do not know which ones).

+
// this would be nice, but we need feedback from the external unifier
+// for this.
+//  rule <T>... <mgu> _:MguError </mgu> ...</T> => .
+

Semantics

+ +

Once all the infrastructure is in place, the actual semantics of LOGIK
+is quite simple. All we have to do is to pick some (fresh instance of
+a) clause, then unify its conclusion with the first query literal, and
+then replace that literal with condition of the clause. The intuition
+here is the following: to satisfy the first literal in the query, we
+need to find some instance of some clause that matches it, and then to
+similarly show that we can satisfy the conditions of that clause.
+Mathematically, this is an instance of the proof principle called
+resolution: if p ∨ q and ¬ p ∨ r hold, then so does
+q ∨ r. We let it as an exercise to the reader to see how the two
+relate (hint: assume the negation of the goal together with all the
+clauses, and then derive false).

+

The following two rules are tightly connected and they together
+perform the following core task: pick a fresh instance of a clause
+which unifies with the first goal item, then add its conditions as new
+goals.

+

Pick a clause and generate a fresh instance of it when the
+fresh cell is empty:

+
  rule <fresh> . => #renameVariables(C) </fresh> <clause> C </clause>
+       <k> T:Term ...</k>
+  requires #unifiable(T,head(C))
+
+  syntax Term ::= head(Clause) [function]
+  rule head(L.) => L
+  rule head(L:-_.) => L
+

If the goal is unifiable with the fresh clause's head, replace the goal
+with the clause body, and empty the fresh cell (so that
+another clause can be chosen using the rule above):

+
  rule <k> L:Term => . ...</k>
+       <fresh>  L:Term . => . </fresh>
+
+  rule <k> L:Term :KItem => Ls ...</k>
+       <fresh>  L:Term :- Ls:Terms. => . </fresh>
+

Note that there is no problem if a clause is chosen whose
+conclusion literal does not unify with the first goal literal.
+The search
+option of krun will systematically try all clauses, so no
+solution is missed. Of course, the above is not the most efficient
+way to implement a logic programming language, but recall that our
+objective here was to present a simple and mathematically clean
+solution. We encourage the interested reader to consult the LOGIK++
+language definition for a more efficient definition of a richer logic
+programming language.

+
endmodule
+

LOGIK

+ +

Author: Grigore Roșu (grosu@illinois.edu)
+Organization: University of Illinois at Urbana-Champaign

+

Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
+Organization: University of Bucharest

+

Abstract

+ +

This is the K semantic definition of LOGIK, a trivial language
+capturing the essence of the logic programming paradigm. In this
+definition, we explicitly focus on simplicity and mathematical
+clarity, not on advanced logic programming features or performance.
+Those are covered in the LOGIK++ extension under examples/logik++.

+

Specifically, a LOGIK program consists of a sequence of Horn clauses
+of the form

+
P :- P1, P2, ..., Pn .
+

followed by a query of the form

+
?- Q1, Q2, ..., Qm .
+

where P, P1, P2, ..., Pn, Q1, Q2,
+..., Qm are literals. The
+symbol :- is read "if". A literal has the form
+p(T1,T2,...,Tk), where p is a predicate symbol
+and where T1,T2,...,Tk are terms. Terms are built as
+usual, with operation symbols and variables. A common
+convention in logic programming languages, also adopted here, is that
+variables are capitalized and operation symbols are not. Operations
+with zero arguments are called constants and are written without
+parentheses, that is, c instead of c(). Horn
+clauses without conditions, called facts, are written
+without :-, that is, P. instead of P :- ..

+

For example, the LOGIK program below gives a few facts about a
+parent predicate, then several clauses defining some useful
+predicates including an ancestor predicate, and finally a
+query asking for those who both have ancestors and are ancestors
+themselves in the parent relation:

+
parent(david,john).
+parent(jim,david).
+parent(steve,jim).
+parent(nathan,steve).
+
+grandparent(A,B):-
+  parent(A,X),
+  parent(X,B).
+
+ancestor(A,B):-
+  parent(A,X),
+  parents(X,B).
+
+parents(X,X).
+parents(A,B):-
+  ancestor(A,B).
+
+both(X) :- ancestor(A,X), ancestor(X,B).
+
+?- both(X).
+

Above, we only have constant operation symbols, so these and variables
+are the only terms that can be used in predicates. As expected, the
+LOGIK program above will give us three solutions for X:
+david, steve, and jim. If we inline the
+both(X) predicate in the query, that is, if we replace the
+query with ?- ancestor(A,X), ancestor(X,B). then we get
+10 solutions, one for for each triple A, X, and
+B satisfying both predicates ancestor(A,X) and
+ancestor(X,B).

+

As another example, the program below defines an append
+predicate followed by a simple goal:

+
append(nil,L,L).
+append(cons(H,T),L,cons(H,Z)) :- append(T,L,Z).
+
+?- append(cons(a,nil), cons(b,nil), V).
+

Besides the predicate symbol append, the program above also
+includes a constant symbol nil and a binary operation symbol
+cons. Additionally, the query also includes two more
+constants, a and b. The capitalized identifiers are
+all variables. As expected, the LOGIK program above yields only one
+solution, namely V = cons(a,cons(b,nil)). On the other hand,
+if we change the query to:

+
?- append(L1, cons(a,L2), cons(a,cons(b,cons(a,nil)))).
+

then LOGIK yields two solutions: one where L1 is
+cons(a,cons(b,nil)) and L2 is nil,
+and another where L1 is nil and L2 is
+cons(a,cons(b,nil)).

+

The programs above all generated ground solutions, that is,
+solutions where the query variables are mapped to ground terms (i.e.,
+terms without variables). Let us now consider the following query:

+
?- append(cons(a,nil), Y, Z).
+

There are obviously infinitely many ground solutions for the query
+above, e.g.,
+Y = nil and Z = cons(a,nil),
+Y = cons(a,nil) and Z = cons(a,cons(a,nil)),
+Y = cons(b,nil) and Z = cons(a,cons(b,nil)),
+Y = cons(c,cons(b,nil)) and Z = cons(a,cons(c,cons(b,nil))),
+etc. However, all the ground solutions for the query above can be
+elegantly characterized by the property that Z is bound to a list
+starting with a and followed by the list that Y is
+bound to. This property can in fact be described as a symbolic solution
+to the query: Z = cons(a,Y) or, equivalently,
+Y = Symb and Z = cons(a,Symb). It is possible to
+define a ``more general than'' relation on such symbolic solutions,
+in the sense that the more particular solution can be obtained as a
+specialization/substitution of the more general one, and then it can
+be shown that the above is the most general solution to the
+stated query. Logic programming languages, including our LOGIK,
+attempt to always compute such most general solutions.

+

Logic programming languages are highly non-deterministic, in that
+several Horn clauses may be used at the same time, each possibly
+resulting in a different solution. Implementations of logic
+programming languages consist of complex, optimized search and
+indexing algorithms, which we are not concerned with here. Instead,
+we here take advantage of K's builtin support for search.
+Specifically, to find all the solutions of a LOGIK program, we have to
+use krun with the option --search. However, note
+that some programs have infinitely many solutions which cannot relate
+to each other by the "more general" relation. For example, the query

+
?- append(L1, cons(a,L2), L3) .
+

To address such cases and terminate, logic programming languages allow
+the user to choose how many solutions to be computed and displayed.
+In LOGIK, we can use the --bound option of krun for
+this purpose.

+

Finally, note that some queries have no solution. In some cases that
+is easy to detect by exhaustive analysis, such as for the following
+query:

+
?- append(cons(a,L1), L2, cons(b,L3)).
+

Logic programming languages, including LOGIK, terminate in such cases
+and report a no solution answer. However, there are cases where
+exhaustive analysis is not sufficient, such as for the query:

+
?- append(cons(a,L), nil, L).
+

In such cases, logic programming languages do not terminate. While
+one may devise techniques to detect non-termination in some cases,
+one cannot do it in general (same like for all Turing-complete
+languages).

+
require "unification.k"
+
+module LOGIK-COMMON
+  imports DOMAINS-SYNTAX
+

Syntax

+ +

The syntax of LOGIK is straightforward: a program is a sequence of
+Horn clauses followed by a query:

+
  syntax Literal
+  syntax Term ::= Literal | Literal "(" Terms ")"
+  syntax Terms ::= List{Term,","}
+  syntax Clause ::= Term ":-" Terms "." | Term "."
+  syntax Query ::= "?-" Terms "."
+  syntax Pgm ::= Query | Clause Pgm
+endmodule
+
+module LOGIK-SYNTAX
+  imports LOGIK-COMMON
+  imports BUILTIN-ID-TOKENS
+

Variables and literals are defined as tokens following the conventions
+used in Prolog (variables start with _ or capital letter, while literals
+start with lower case letters):

+
  syntax #KVariable ::= r"[A-Z_][A-Za-z0-9_]*"   [token, prec(2)]
+                      | #UpperId                 [token]
+  syntax Term ::= #KVariable [klabel(#SemanticCastToTerm)]
+  syntax Literal ::= r"[a-z][a-zA-Z0-9_]*"                 [token]
+                   | #LowerId                              [token]
+endmodule
+
+module LOGIK
+  imports LOGIK-COMMON
+  imports DOMAINS
+  imports UNIFICATION
+

Unification is at the core of logic programming. Here we are
+going to use the predefined unification procedure (the same one we
+used in the type inferencers in Tutorial 5).

+

Configuration

+ +

The configuration stores each clause in its own cell for easy access,
+and the most general unifier in a cell named mgu, same like
+the type inferencers. The k cell holds the query and the
+fresh cell holds a fresh clause instance to be attempted on
+the next query item. To more easily read the solutions, we add a
+second top-level cell, solution. Both top cells are
+optional. Indeed, we start with the main top cell and, when a
+solution is found, we move it into the solution cell and
+discard the main cell.

+
  configuration <T color="yellow" multiplicity="?">
+                  <k color="green"> $PGM:Pgm </k>
+                  <fresh color="orange"> .K </fresh>
+                  <clauses color="red">
+                    <clause color="pink" multiplicity="*"> .K </clause>
+                  </clauses>
+                  <mgu> .K </mgu>
+                </T>
+                <solution multiplicity="?"> .K </solution>
+

Pre- and post-processing

+ +

Before we launch the semantics, we first scan the given program and
+place each clause in its own cell, and then place the query in the
+k cell and initialize the mgu with the variables from the query.

+

Note that we put a fresh instance of the clause to avoid interference with
+the query variables. By a "fresh instance" of a clause we mean one whose
+variables are renamed with fresh names; we need that in order to avoid
+undesired unification conflicts due to particular names chosen for
+variables in the original program, as well as conflicts due to
+subsequent uses of the same clause. It is safe to rename the
+variables in a clause, because clauses are universally quantified in
+their variables. This process of creating a fresh instance of a
+clause is similar to how we created fresh instances of type schemas in
+the higher-order type inferencer discussed in Tutorial 5. Indeed, we
+can safely regard clauses as "clause schemas" comprising infinitely
+many instances, one for each context.

+
  rule <k> C:Clause Pgm => Pgm </k>
+       (.Bag => <clause> #renameVariables(C) </clause>)
+
+  rule <k> ?- Ls:Terms. => Ls ...</k>
+       <mgu> _ => #variablesMap(#variables(Ls)) </mgu>
+

We also sequentialize the goals for easier processing:

+
  rule L:Term, Ls:Terms => L ~> Ls
+  rule .Terms => .
+

When all the goals are solved, indicated by the empty k
+cell, the calculated most general unifier (mgu) is in the mgu
+cell. In that case, to ease reading of the final solution we move the
+mgu in the solution cell and delete the rest of the
+configuration:

+
rule <T>... <k> . </k> <mgu> Theta </mgu> ...</T>
+  => <solution> Theta </solution>
+

Since we are not interested in seeing the failed attempts to solve
+the query, we collapse all the error configurations into an empty
+configuration (recall that both top-level cells in the configuration
+were declared optional). This way, if we see an empty configuration
+when we search for all solutions, we know that some attempts failed
+(but we do not know which ones).

+
// this would be nice, but we need feedback from the external unifier
+// for this.
+//  rule <T>... <mgu> _:MguError </mgu> ...</T> => .
+

Semantics

+ +

Once all the infrastructure is in place, the actual semantics of LOGIK
+is quite simple. All we have to do is to pick some (fresh instance of
+a) clause, then unify its conclusion with the first query literal, and
+then replace that literal with condition of the clause. The intuition
+here is the following: to satisfy the first literal in the query, we
+need to find some instance of some clause that matches it, and then to
+similarly show that we can satisfy the conditions of that clause.
+Mathematically, this is an instance of the proof principle called
+resolution: if p ∨ q and ¬ p ∨ r hold, then so does
+q ∨ r. We let it as an exercise to the reader to see how the two
+relate (hint: assume the negation of the goal together with all the
+clauses, and then derive false).

+

The following two rules are tightly connected and they together
+perform the following core task: pick a fresh instance of a clause
+which unifies with the first goal item, then add its conditions as new
+goals.

+

Pick a clause and generate a fresh instance of it when the
+fresh cell is empty:

+
  rule <fresh> . => #renameVariables(C) </fresh> <clause> C </clause>
+       <k> T:Term ...</k>
+  requires #unifiable(T,head(C))
+
+  syntax Term ::= head(Clause) [function]
+  rule head(L.) => L
+  rule head(L:-_.) => L
+

If the goal is unifiable with the fresh clause's head, replace the goal
+with the clause body, and empty the fresh cell (so that
+another clause can be chosen using the rule above):

+
  rule <k> L:Term => . ...</k>
+       <fresh>  L:Term . => . </fresh>
+
+  rule <k> L:Term :KItem => Ls ...</k>
+       <fresh>  L:Term :- Ls:Terms. => . </fresh>
+

Note that there is no problem if a clause is chosen whose
+conclusion literal does not unify with the first goal literal.
+The search
+option of krun will systematically try all clauses, so no
+solution is missed. Of course, the above is not the most efficient
+way to implement a logic programming language, but recall that our
+objective here was to present a simple and mathematically clean
+solution. We encourage the interested reader to consult the LOGIK++
+language definition for a more efficient definition of a richer logic
+programming language.

+
endmodule
+

Projects using K

+ +

A list of projects using the K framework. If you are working on something interesting, and you want to share it with the community,
+let us know on our socials, and we will feature you on this list.

+
+ + +
+
    +
  • +

    KAVM (Feb 2022 - Present)

    +

    The Algorand Virtual Machine and TEAL Semantics in K
    +KAVM leverages the K Framework to empower Algorand smart contracts' developers
    +with property-based testing and formal verification.

    +
  • +
  • +

    KPlutus (2016 - Present)

    +

    The K Semantics of Plutus-Core

    +
  • +
  • +

    Dedukti (Mar 2021 - Present)

    +

    This project aims to translate real K semantics into Dedukti.

    +
  • +
  • +

    KWasm (Aug 2015 - Present)

    +

    KWasm is the K semantics of WebAssembly.
    +WebAssembly is a low-level (but simple and streamlined) assembly language that was originally developed to provide a fast execution engine for browser-based tools.
    +More recently, it has been used in several blockchain smart-contract platforms as the underlying language for executing financial agreements.
    +KWasm has been used for measuring coverage of test-suites over Wasm code and verifying programs which are compiled to Wasm.

    +
  • +
  • +

    KEVM (Sep 2017 - Present)

    +

    KEVM is the K semantics of the Ethereum Virtual Machine.
    +It passes all the Ethereum Test Suite, and is used for verifying EVM programs.

    +
  • +
  • +

    IELE (Oct 2016 - Present)

    +

    IELE is the underlying VM integrated into the Cardano blockchain.
    +IELE is a register-based VM (inspired by LLVM), which attempts to avoid many of the missteps in design present in EVM.

    +
  • +
  • +

    K-Michelson (Oct 2019 - Present)

    +

    K-Michelson is the K semantics of Michelson blockchain programming language, which powers the Tezos blockchain.
    +KMichelson provides additional testing tools for developers, including a unit-testing framework which is extendable to symbolic property testing.

    +
  • +
  • +

    C (Jul 2010 - Present)

    +

    The K semantics of the C programming language specifies the translation, linking, and execution semantics of the C language according to the official C standard.
    +It has been used to build tools like RV-Match, which detects undefined behaviors in users programs by running their test-suites through the C semantics.

    +
  • +
+

Archived

+ + +
+
+ + diff --git a/exports/K.mobi b/exports/K.mobi new file mode 100644 index 0000000000000000000000000000000000000000..84a86e80aba7018f5c3278ba64fbcc17b2a7d80a GIT binary patch literal 2362510 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

$Vyj4#? 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

;2 z%{?o4V-~Zgr{h1&X`|~@Xy*WiV%CTvMmb#$<}-mqIK>aSF=$aPB`m^qo%^KdE6Vpg zOr0{2NRj5c9wAKB+}$9ixLLNxY;PnTMyffg#!bo-7~`I%G~wg&uOF7~0yqku z%tQ4pRJ3{>6Ldc?)%YryF@?a=#cfg{QY#>?1qF)sr`5YhSA>9;fYEin`94FPznW2y z(Z-0J8DO-ga&b*%O{L>|H`ROXS@j;OLbe_#2?2JVmsDzt(9cxm>2r&8qEDJ*@gGu6 z$l`}>UH$_!Ja7H!q6+GKlh2xrOkp)KlG{r1Y=6$x)peH@GK@X5$W_<4Hm@`=N042S z#9&S3<^!+mc#TvAT#G!^a>z)V0ELimLA_)4FcBs7zO30ZkjanMIBgvwNS#VAe5(3GaY_ zEA1NGKUx19Od_M45?G1jW%uruw^sV1$(ng8!qiyLism{~Nh>9CYudplF6{G;vR_5pz zPLW;*D>qe2mo#0~b8X!L{|&OWW(6N40VgtErbhrs^t3U{-Q9dW0@lrQx+lO_{|G=O zVMcJ`Jz2t}Jw>=dbB6vO^7;I*LJJL(zpm0k!$^V#@qj9~^i$&ze(5CMuMAcR*ty8urafy*OK4sm`tZYq z3BU)p#|hYBut!6NAfqRwd!xw9M)Hxu6ozr%AO9$h54KW+g}4FFkT41ii7cr>ZeafE zU^DyzOUQbImy06P{*3xee?$!9l9V<0;hU3`Wtr*^6#dZylRH~xo;mWBj7g=)$`vQE z$7omiFz7(0bGOB55_0P9VrP5*#+~K*zcjd{2|G$8md<~9BqlA@c)7v|moyVI#>LDY z?WJ^Cz7+~G>9SNp#w4!nZwJIQ8ZZ}Zo0@&5>8F_!O|fJuk@ghs`4l$=26|fCI|=w5 zoa5<>VZhThbB?*|m57;(3z710!jw}9UC8v#L+XXA-m+Y<^AIeGVrCmG6sP(-4@qhC zd(-U5G^$2P^7QlbAcTD?yX2%eG2%|H5 zhF_nxXS6)ipP1Pr?34Btp?#vy+Z0%>E^<1V@CO33_lWitL*}thv`2gj_9zf&cr1|h z*AYH^uAC@^+^pQqA&QSlZ z{t7xA%EgSCK(mhqcVm3Q?Bjv!dw}bw@*YhYLfE04q|nLciXNSPww3eU^X2#Z-;#Mb z@6zt#Sr^01Z4Z@sj77Zwh@4G#j!C_MUmeJ%-PP7^`iYM6^c4|I4P>de6Rk0UESv<~ z%($I#mEbxVpm)^kfltC%Ws`Q2v}+un--j#03k=!Ibm=AD+p2?bG@Eg&KEIO$w-AZ}9Ps$X7 zWK@U}aqFo+h3=owPvUbgtoR##Ym3;$Z53rc9mQT5g6h%?_uB*?nFQKf$lAidNXYm* zCb`~^#x8V?nx$y)62{nwQYd0fxE&kUS>6SqY#rcNa$jYpodJ27;dI<9{$I(DkLRut6730D@rmsLR z4Vp2`Sw@tP=2dnH+lNEF&vvA^I9L!0H6JuDRAOoL+9S-gpH%yt9A^{kQ=0J^b|jfS z-&UjsBiSKanbDIXq|LIMTlbvqlhNt#&GB62t(z&=P;{0z2Vlt{S+Yuc_0E zlSg#+s2%f#aLqWA5YF^bECB)WNInc`@YRX?J>$l=cverN&}n>!I(v5VA3NuEGJc6S6q>9E?JboEL&WaC1X4~7b|z6`DyDEfY+^4Tc>af zeVWl^FT?CeqQ|LKI9%08=PZ!g!e|80{w+k{B^q#11ym+<)cOU@5-2*bYfYhl#~!|r zE;l1?Nc0MRjy}`?h8p}+YLaPA{1ssSXzr)n*FwwSIn=r5R1lvz&SQYdIr3E@XaF}X z_gj}p)oDuK%}rF4Zm_FEhW45ClRoh;TD=hUv{9Jo#t#zo=x#`u!?GK9eZB!fo>VSQFMm6K`s&0VR9dD#J zl22hrg&he(l4e{My)xT+gcKo#WC?^6ZwVVIWT=LVFGIMSDh5g_No-CYO1J)C+rL+j zRF6Pf>F0sFLDygnUB}uo+E(d`O`V5bpD#?XU&bt#ed71oCXM9UyjSC}HAGjJboche zTL4g4m(>+;wrM6y-PXl*!Mfh2OeM<^;~l?s#o8M|9xZU@VVz}n(VC0@bHqvE-<&eW zv^~%iDVUlfd6PVnD$nJ9YG9*a^E+?i>)9+eYujd%I+F$xiLt8jS<3Sd?3Xjc%zh2~ zu^$p6F}FNYE$RfnfebOZ3%A)N5W-l z38$eLc@1ZAYkX?i5@9tpOg2oi;|-JjPgzX``pqTa;pOOyf<7z}JEL|OxB7h%7hyT6 zQ||14Q3P)$z;jB@H0y=ANxF3=L!M{Eo3w3c+Ylm>F4-HCdY{t4I(YJh;a%|?hM1~> zlk4=S&?le2-e#~}V>Q{B=L@NoeQ55OLPMx@hN)a8)OkQu0{BAW83|{El?LmJzn}yg zBp&`APcrjpZlP)S{v4IbqZV*l3(8ErapHp@Z><8x!Y^02yH}kmM%Arv+bty)s8v|H}^<3G0ubVozhMf2+C?}9&wprv?L)c#v)IBU|IdB z8uhS~a%5^KpH|ZnX+j7{f1++SN;!m)w`ld%5Wr~^UrDXCmHNwT4+_nKi=HV!FguXF z(khPI@tg_D3$=syR}*CJdi$&7)Glb&)J6m-BfrFKFi|1T{Dlvy_99MU%YA z9QWO4Ew(DzqXKTAL-4U>%f#^M!xE((l}Ty{lO}~gRl0giD3z~DuUcWquS!xYB5H6M z3NdliaNNk=yKoNr+jJ_z#c<_RgmYP9cs#ySZN<@JeY&)-<#g!fe?ABp8-#VDZDznO_rGn6P5k?CyvJEGJqG^5#+Av*{{ zr@5FAUm;LDI*y#WVkK(PqF}mcp)5e$;e~Dc6Ak&qlOsnbs$5IkQTau=3$|f~RB5|h z3iAX|iM`d3k6S>Ib|)csCMRDf+L*$ppT!U27;}$n)H}=+2otU@G0fE^gvsftN+>-o zix1kQLX|&dW%eUmqp`aPO58rPd$;|NjK&Kxeq0`}FPF}`hF!xHm5Ab7MZy^it>qJ* zH|*E3!|ZUX_-lae(tJKl%T>65IORSjPKXmqK_$`TxXfTQV%qV=?bgKo)^{m_pVWU) zW&ea&tq`igT%(rHoe_$F{*+^i^Gk0~cGR{Hu~q`cYqhNh;Sb{@K?}anP&V8nUE%E; zGg5>>hVp|N#KkCU(YbVwP)MgocRw=YW9MbYU2J=3(E$Mi*_PU-fa;G@WkDzYZ_(5i zjixqS)~S?)@Ud*fOc=?3B&r^2FnSPoE*|b$dk+S=%VDi z5h%Lb`CAhBI1umj@avjF{lS z_aQ&9P(Q5G#2=oH?VLLoBgEM@a|gM;UpHBEP#maBNyQMmp4mg}GM%?#h@BWmx6n5{mhm^ z$>$c+7882@evTzYsGMy!Kjp@>2)*dVZ1P-v^}I42I|rgnkf!Uqi`I{R%iz|5##aW? z(3>~KO${vB`FoDFAai_?+5Uy^DW+eTq7i^(e6~D^RPauSSxixOD_$C!@nGHUyKPUo zA@9WngGsoM)8%w7om;826&Un+N;bDQ(}dZ`{B-ihO-iGP^Y-{m#?B-8iBBjn11c}V zAL93BkaZNO&*w&YwusWA+OX*$Z?>jJZ})R=Vr2QqMe8Q6rGHc1WM%E}^IlxB_AEOb zD(@F7Vb6qunF}Jkz5D**0FO&NH>yJ=0}CP5HD*k8%v=)ko&y&R(3A>gTC_~TAZ*RUD0WS#7Nd>BQXB*qt{Fe64a1tWDaHj~OxZBG zL1wZxOxmYZ<^o@UcP2yeBD^YDTlh@8STkAk$)(3&x#j`SgMM?qOk+G zBZ3BXv++1ri4nP}P>dKjM1d54DcZ(5G}u!AiD~xIh}X|-UM-Xf3UVZ@D=~ZLDDZpY ze#;n~HFY$zJKWdN0U(K3;}|nv=_-Qjp2*EDHFK+sd0^NOa^y-zgIJC_KeC9S#9ME1 z9kww0bn-qW!r%wU98p&8aS#l+UkP8w;0*4dm0!olC-|-~>x)gkXltR#!oN#`vMS=l zdkBRhRU@5!wRD21ljDjixL@*dfDREaB)(4KX0r^_FZ2i*JR_bFKAat}C)KRX(KpPq z$OUo%V$PQ>YKt|x@xcHE0%1i{t>fFC14TuSf5UXd+`_j>X|MTO&qMsH(-fT5wzcTe zdrQalC2%EUwbiG5Cv{KML>N4>p6Tc9-Znm!cp(=7Nj5~0xmVt_@guR)Rp}~M$sl58 zXKZJs5P?n{K5@~-R4mapuqfuFvaTt^sc(syrJtC3^GtKbNkvHUAPFg6q$4boP6I9y zEunyN)@t^dP>6XU+a#GAnNBba`O#{UaEi&K1(R9x^t10UtC;2dElFGtXeXEOBV48U z(@&`xPngt4-spku>@|7Iu)6g95b^9p>B#0OdSId-mQ>S9B}|D&w%Su$}BOc z*+IVZ8;JQ4q=KeGtY6jmDJjYM9dSe)q0B(^KvV>i>H(}P{1j@cX9w7winpzh7KaEb zs3V;*$sOq8tI4G9Ju4eCLsO|9teKZ6uB@FnSF_T_)em6QWu$+U4lE75gaFU;Kb1C% zr_IuuqEcxCU7Wx1y%)VG@rHz7DIJZTlEt!wMj%CEQjV}KRS-7JhR))<91rB6ozyC> z$55{)jiC{?hFs24U8Sm17A7bIclmF#eBgCkMa`2^XD`*m$ z@H_Uj9IJNMTE){=(}Rxj}gjuNk2uL9fA+EVaF*3mheN@$t=r z=r!E1+Nx_h*|nr58F}FPH73kfQx*vOlQp2@P}1W%uIMqCY=6WUmecDnyxgF3WqadX zS&Yr;-<;W3vmvW9O*J91Gc6`ny@floJG1E)t{YNIE*@4%3)ldXgNN<6*FdF zFV+`(BRzPteX+Em^ja(s^>_H!dJ6*)y}wWiFy1lWv;AkiD~br)bf1=<#^Q5=t+}iB zEi*UY-OcEBg}Z~ZY_l#W$L)9fxk)x4wI)=30SUqCuM7VTHdB$Xyzf6re%Y1Am|UIE zMsXZ+`f2)uYsh^KA5Dyx&I+kjo)nKjNV7qU6m}jcEo!=3R!|H_nB!lRV8amx0;>VR z!X0bwxc9cz_uX-0-2ij9W5hAS5A(xx!HfTCsaRiFjw>JkQh9^k91&j!@eTh@^Nqkn zvbjgT0!f-3V9W}?bTKOCp*d~LbQ_^Mpb|z#5&)Bf3M`xeJEc}5@pxtZ)w9wACW~@- z;uVThe7g6K&xjM`R>=dY<{cGq>nfJyIOKgZ$1$q9YHi_Aq$DaasB%;ar@teGV^A-| zBvkLL{TavfpAkkJqjg=gx0@Rh#vO+?PvPtrD7DD~%%`{kSWW-9=vQzWKe0=>2|Q*b zP4k*VNjsjbj4q#Po>^PZU($~&LZq6Y?G5Kn`$)Z+d-9CZ??s3>Q>#UtA&7t^O5aDG zX)>btVVbQ_8iEKikePt3Nd2bFX}ZB6?}C*ZghZxYA5tsD(861BSFuaL8a0-}ne!h& z!(9gr_Y^)QHJWrw(TEWeE?t_EymSeBo^a`pmi-nz5c0l+gBbM;Y4}yBl)XknH^8B^ zU9RJZsChQg9!2wG7}=fXh*(S_f$m#U+-c&7`{tSJk5oe`it?l&mz;OMyM)wC_o2k< zK54L2-G0jAPWHrsb!ad`u;LXZ|55aMEgmjMe*z89ddwK}1Rx0t3yEy$KajsG{o3;p z=4{_n9VghJlTcNX%UxrOHe#vg`%G9{jC!7%Zn&-e6oj`3&o~(*PRAX?j$zMuOO%l0 z8Bc|V>I8H%%x5ZSlC39_tR=X8rN^#~OYr@Eu z`qg(;Kg5kH_B;49dcm6T`1`6?A+c1z790|T<*lbJr-{&rwFt5c^6}be2yu3=xA<52 zPUnjzt_#)gLUUkB%wRM4i3Bd2#m&gAX?~x}V$%Vq-=k<6q&=6x%WOCgO_EJN#;bHL zLwwDBgezlHxU!g3i(`)d`3O#Cvp9L{clP^AEEsd?^yOOW)^BQeL|b+g=2TS0SoBus zX~M%expRvD!%lPeac+6fTyDjNiNx2r{kf)+-j~W6kMM`RIS9t|d31yErcTNcof%Z)j%)(DHQ}kN-ISY?xvU7Cig}3UST1vD9s$(_mtj?}}$Y88C73pz+ z=e!IxSZwT9N{FfaBqh%|M@4KQ_tPYH7mDataO12uw4x?3pF*T{6+~Lo*tAqN;iO0G zPq;V_J5I=j0#0A2Z7y~I8_e`!U+t0F-kkrTe01SLVZK6d04GGaD)B$96-6kb(}W@< z79Wu2DJIYAikW2KtDjm*nPX!`MINum%XN7?n8~3xlQICox5}9_&e9kJsG4V?+=S>0 zr+CB$a~1g@ey!dJ#sahj6D8?<$dx-j4Y>w|3}H1@Ti;PpQ0Y}5UPYyO`Z41>P+P8G zezT0vlIKjLoP672tiMgRa*d}eTm#;YKetusY`2^sLN`YpnEWNh5t9L*IF7ML<|3%miGR>hB7ifmL3VO z6Ji}v4P^+o!njC!#Pf(W*-%FO8YR5JHrEDb@Pvl4zrL}zVy|rjwgGOEn-oU56z;}{ z1!a#^8W-LQay`oOLNzdr40cf>Z^K86X8+F6bF&F!sG9|a4;Ih<1@88E0gDBh8Z>bO zEmp+&>vYxtLNpBIixndwiKu@Rl|2f+aIKSZ!OfNZ;hTrWEF~(+;)4C*{ox3Nl5meB zAi^sOi4YWt8T3hi_;VBe3S@)VmxuT${b6Ku#OPU`ps1if%swTJQdp|8m81#!%s#0e zSA>m8&n0Qs0)3(#+4C;~E@=D1ZPkBNKsJ)0<1_dSF$H#G2wclnLSMQv6!YAmvG>x& zbcM>94u=5^-vR9#FpBuAx!QAHf!ym&OBcnY#{4~1Whw}Ta6|JP+@fRgrC{~T`U<|7;YEo@V?IN01Af{9G7}d#;c^|HhQxXu|;<%=>uEn^Wn{v3!pdCNaZ{l6m z8nbbysFq}(YKvDIpeJejwZtNHuV}wBT5kw83g`U>wj%}XLUpS$9BKGz))sNYVmjWz zH`0tc^6$w~gnturZ{m*#0oO)ltk7yD3$XB$ zLPiN64$KKrOgL95Uxksx81G?Lp+?dvf7@WeU@1@?)kuE#K?{2vVKq|%l}#~|x~o5M zo=6maV3%l-N&O{P_LggT%W)I8SH(QIO6qd)!mC-fDV0g#uVmf(e>ITi97 z@Zi1-brvrj7JlwZ`vE=NsxK~qJ#O}vIG4+rOjT{Rug_LpW~zELI!-*Kc{L%*hSCmK zsI=Amh}vqDg$=Gz`q%hn@|1Ue`^&bKi*4z)TN~zTzPCM!3O!w2UF*BNU0y2iP?f36 z3y&2!?QG90?`TzzBxN;Ix-rzwjB`6On5LP06n7GO>5_lM)+K4{C3{)}DHetn><`tN z$V?9}7Yx-zVp4DCwz9jpaWd#bE2jP{G~RAlq`oBC>X2!@8Or*O0TYo*2_*@yzWrB< zC;!M=CSNvFKbZw@d}TY%msXdiSC&KegBM$*(K#MVK1talkbdZA@>Kw8vQ$%kLvd0( zttn;r{aE#=%PGyV>akM$iQw-8+F~q>fa#MR^G{!kG0-#|)frlK!fPXIuly^-7A9Ve z6_gl)qJ?U)Qmj;V70-AzB34dcq%)utMTE0@w_?Jq=`CA{&1 zOSmJgBdsn;&Q_N!?hr|QnL9FQ1&1&4s#bUP?$a|q0`f`{t~=FT&2m`ZRu+6X3Sk04 z(|_Oc)&6Q|5%JE(XS-yD8As8}tln5OL;%7Hl`7R$fnjF#X-uyN7+Y~9v>b4ZcH5H^ z=2F!i;^Q$&<0>u2A?GKY#g#aF-!y+r_r&?0Q2clDc68^ECv^PFSMTCDN0kN)DN~N8 z>J#A+5gYvDKCwiF>G*S1=9IMk3gR=(LZnVvpaG&xon;v-+JNbZV+(o zj7g9S1`AeA&x(pL*|w3$-h8;6$bF=^HEzEBUT!l6RW0BxjwJ@8GlBVUQY+(MV!uJi z)pUjGez;I^6|>-7ec1;FqsdII&|n+itMX#K$#MbzDiuOySyh{Ww=UNd@@M%D6S=Wu18Jft*WzDYMFK$ zgs)pr7zC4>X(u2D_E@foN5QI;J2+0tH}Y!iSiBHzE|BIog_(@*$C64~DiLn9RJK(5 z|ImI(j*x+pOT--t&S{T4PapE9CP!RFOSq6i9Of3pCjwd`94FyhTjs&DwnVi=5vbry z^dD&Y6bkND&svtDD(Skys&n)?2RoKkFy-Y5p8&3l@GYrv_H;K2?U<*32b$+{SG}UE+XxC}cvuos4 zOmyQabDsQ2M-mP=g2~$o^|?>DkD+t`shN(F{;2-%SgdVd6qgv9-{bET;#&TP{knep z{L;2Keu%89fRDC?lk_kd2NB|!)QzVd#9~7kLb#N=qXOa0|9z24W6R_Vl`WIfbvLz# z!67|@!rz{G+rGDF%(H9LdrFh>o1tL2F1V<8M+bb@=E*x2 zF0y}LiBnt)@J7QbJYZ>J)+mb@e!zm~Sx!uSOqG6*eT?1DJ^-Kj|FHKaaB-Da|9G^m zMBlbVyO8KxA#{N#FodX(w1Fg6Nt!CSw8U100WQNBm`i4c3|L$4erI3UW`?jQELkBd z#3e-AN>W>iOG~tGONdsWE}+qpXy5WX=ectS5^;Io+TZ{E{C}^fodw7&_ul6`=X}ri zd{6Zo&O4bqu-za9cA~}A2jMS6@e4c(QNQ>rah~`i%qIT%STfkThutl%XIq(lKkd5t z0g~B1;N0tuV2(Tgw%xBx6OSQLokg$WJ8Dzj#f>QnKQqMg1OKG}-tS-`9NkFa1T^p? zCiPzto0@fGa7?(p8g2=oYg-5heQyFp#wch%OC{j^LKV{sn*?EL;kBA{G58j(=1B-9 zD%!5-+Yx=UWr1fxG)*zi0=-vC15vaPjT9>(y83PV`3bWBR|8mGldLsY*CxFLE=Wj2 zx@YZ`ECZB4)b&IfBOm4XI%hR;pc24;3tV^oI{x2GthJue8<;2R|6a-WTeKW_`uF^& z{4q=*d?_K)5g0WkSy9_*o+TFAQk)C0@Y6W$oOF&W^C_Ki&X_x-_0reeqkyeTG5P|N zTrT{ATOBaiD0Wc`)AdgM#{E*IFS4FleA`zD66Hf>?Xdo&F%VRY5jUmPvt7nL8G^1u`q z&s5=S;JEi*7Mgu9UgI@XM>-;4VvEPOO%c6lSyQ;}k9za6+Op2a+3VcNPMsKKjZlmq zbLyNrNEIQCU`KYh1hefCvWB&=7F(|pJrq7MeKZaY2%#BAm+IxIj+G4)hj&-nt~oS# z=;^?kZKn#b?0=Ry<5={lZ*QE~g@-a7`0ybEiPKc3H!-pC>coSzBNI(XJ@RL0t;$gh zTB~w|yN-NL{l;)#Pz1AwJEv%*S1JZ>z|(t@E-iBh0Ef=vp;XYC;kE)DLkoLQ*D7zo z-Q(_Iho$Sym1PZK+P6agrXFYLq|He8zymC4I`j8N?Tu<#VbLG%KCp;O1@-|k-XlU) zONH;@VAo9V_zHFrvX=e1(z=>!RnAC=IT9ynvJ&sP@6LPIZjyA8jt7ww;l1r6+fUE4 z#CHs*>=@oLEPahE>?-I#2}RjZ#fAT%kqIbmj zL8t)Z`2=bIP!lQxksh@48O)}bcwohpORdWio*4yw9bf|COk$HY4Tc{U!#F!rDJ))g zf4;EDpbJ4VZd;FSr?_2vj$6pIZj@w$>hNK2iQ%A<#XaS^%}A=oICq)N5+c*>*)T>A zJ1mp1bc_b{*G$mgeFh-$m0=ZWwl}PB6B3aIV!L08mZF7Y%G@mMvz6*Yc#Lno_k^YP zIORNV(3z566wZ?<4Vq{)&HhO-N zP`z01V?33H$~SAS@>CR*)K%7BmUPlwtwBds*T+`qO?B(}g}m1KHCv`LS1~@)nq|$x z$M}haXB8SrQ*wS~n~g4qy(STKPVmc^jm};tnexF|?30wdzR)eorO=uOu{;_#qdvkH zs*xRLB+#FQ$uL`CD*8gbL2fPaGDai^G%qH+VGrkq7UKzKv8ik2ZhbjO*4USko{Q>D za<8=zCfhPJup? zK{+VYFEwk$DO+psvMxQua+CpR2k(>{pn^Tg`MG+R&ReAz2rvRnwz=oLu*PfgT5vfF zSM--jUx5jO-gcNlw7GSqmdUH@;o=Bfp9+b16#`~hCq#1$Iev4n4N6Jdb&d#VVjYtH zC^f)fsuOhW!o#n~r|Ou^ou|6`>rzU)lk4J{Y#5+bx9s4Wy7;401p%+srfwy+u9`lp z4y~q-vk>8;3F$k#+r*z8yLI47S2zE5Lv8Z`aX=iv(t*chi^5JuF3)Ivta%d?uqCrk zmOOr=b^P%DmaEL{1^x*$jjRK(Wv+{WEnVL|**(d7;7W*=7bC;m{W23z z?Hz>`I)y^xeXY~lJuf-mupfeL(Eu}5kAUw4rlVQEE!!~zlK#ZFE?a7B z`k@yRlT#8wG18OaAw|_z8d5^x!LG;Tz-sR7ij-SYSFl6;p|rGu0@%g)1Hf2I;hVK= zF5o>&^#=c#ErQKua~0R+sMz+iZOa-yzsjRi477M=jb%8KauKnE;uv5?3ujp}feb*p z?yl)pQA~0gGWhSR(1P`6pbXuIK#@EoKcmzShk&knB}BuwX8kbh?t5I{AtARl)tZX! zw*+UZ4MBr`f-oW8q*yKE!)uK|R;irMHRBGKmE<_J=%Y&eK||pO_d#a~ZNWx50un`V zx!`I+OpJK;^!R0AXZ?{nhAMKZA|m0c4-;aCU&MoAZsY&KU#avCfsSFhdKey&q7m&w zR~ND+m?glJY=lb?U29Lb2QZQXJ%Kn5+misiX^ZnDkj>EZ3V&3T0E4!4W5}f?j*cDjEoydG~DU zq?~1EmU9Da0jYR?;p`4MQvs`vgzt6x-9OrJ?>&t}+eXxL3OJJgqt2;I|6e($?SI!A zz~-LP?SNw9VM8=ij07!_zNW!_(R*8%oPE(!oN_XFiz99yIS1-l;CkREOY&hbN+qTz zq>>oTSsWP(M2iUuq$u!Wj*RY^*#hgn%zc?+79M-$$a9nG8NlD{%j}-sm#G|Hyx#{y za~LkGXkV5<%N}rnsjXT2z{Ff~izSN;D2^>q_EX9P2QT(uQ>^{V%w#P46twazWA1R@ zqpp>#+e4vDW8b#piksrru(A8bm@(!|&mg2riF?m+3xt*M50t#q{vYwX-@#75pQ_p_ z53ql($>jP(u&mp83oH^aPQ#WOxm7~x&Vu-50;A@;%IaxsB?;@EmN(hK)*7}?$`w+B zV~oz1Q$OgV>j%AbO;`GTbUB&d13`j;Igc3*#Q@Nz#7XuG+*p9JY(gk};zEEn*&M8{@% zz>w4k!>0gALaLy(u48Gw5DgdN2?a?qbw^*Mxz}*+5V<#<&wf;(y{uDnop8ZtKE7LV5b z-U!`fFb45O{zL+Q3KP?Mf>MhjBkRTREjQ`L4E)U1YB&CYAz8uBMTst`PYKBCLxq zjk|Z>b7|b&V5MKTe-P}c56rV4`TZS$t|4O_+ZBnYGnhl{mehmU!Y>eKZ z*u;SwZSpVK)nUENa%AsOTDS(7eabfZU*8X z{}U4=yh`660ueEM9ak;>GKF7A;y`Y#j$cjqNaAUJQu4&6lV!l2kiI?}4T^iuscdgk zlG24GqpQqHUsnlN7p4{<;bMOQ!WgCQS2-b%qtlmiHnI(I_U?BPA>{544@iy%>4!qp1Pv>+%6YL6JlGZV@JqY8mreo&2##V;g?d8Jx2 z%)~S3xYsZWl1>*%*^t{Zr{yh^{5m9kfL(!eJUwxq7=7KILeKgFm_4EQRMm~LU0jc6 zf#ZF>vrFl=3P+a7y;K+`2m_!Dyu}JDWV82H zc}xZ%fgKQ&w(7N>b!@8Ioy&QI%-HnA4cMK>0ZU)FzJ75jU^{QlI=5l&H?4S47RnPC!c~PZm7Sn*~Iso%sc6w^MzZxbSb-ZyL5-;mJt|| zbYp0(w|EZI!Zkpu-|LyLqk=EP;U>&WKn7Eb=STFUdEz&$$35(*a#Y@{-Q2ouPeWj* z-TOm`#+mHpNjD|@S~?Vy;(Wa6-yNsfUMe&>k3?s5ZS^id&k)Yka-NUW>|sdPT4^*+7P&hgnvzw-o5}6) z7TK11*BE`>t_k7{3C3zk6i&2&VkD+p)Ex zIW8sG(jkaa-vMmz?nckuLW1hIs z8Qs1vX(%5j@`|U5yR(np#U?j>K<1^9E+@!5xikeJ@^tAd_*HzPk-Im)vbn$UxV*{N zRXe5_pIbYI3!v6h>%j$Jt)gESe(9ZYM?#;%4D<;+(egwKBjc?%L)JXeA`DA9LJSYy zEet);^F%kVc_PSbYIH!adnn6LvuW4KVy$P9vl6(VN6p|lv(0;YyB;&PWI;%J_WPUK#biaKdt4W;AHo@rmd%( z7Uwi0+u*1bhc}D`&oY+_pzf$_7?5d@4TJGrvR~j5fqvHIN$~Q@MQnooTYVSUJ)VRu z1ZK8gw1q&EMC>d8!skK0ww^#Av7jl8O+>xxact+75hOMZntHqZVPCeU+iqiZQ5Uok;?|!Meu{xEVgp$+S)=}`88a_(qYgEw+y6Hnf)H=3}`&DT1sA?ma_7uo3S(Ct4eBENS8J(HYJr7O22^Q5Yp50 z39r%R?$+iSpn?%7B zQqM?$k3ij1>s*%fV&`4Q47@xssNPemI-lk2^GG{%3 ztHb(_$JgzuYHEGlzkNtGDObvc=g|abAA8*YxF5Tn;PU-#zX*Ksaw#t~nHMlp#kd&> zKy4_01;36zzzgA6hD!S;_g}>NKjLttO!M_+Sd)PUmcXf!x|l*>XHkX*W5<7*|p3QP(hTvLr4YVZ&lF)*DwF+@mjYi zxB}i{MM|L_seCnHVb>}s3^E%uNFiJB0uW3Txf5k4NP(TeY-SqOeL($eN|X$!H}f_o z4I7w3py*uxkv;W9f@vKbNtE#PVtPx^A6^0lya6=QWAt1ID;Og9&yc9vGq)o|F&8f2 zilFH&O8s(joGPC*qo6>*b^H~8EF{ZEqLrHEbLRMEbMt)6^u=!yDb7itu8e@-;=3PG z9I(Ahpa&$gs%VmJjfF5Ou(ps0U)NrDCAUlmP5Wr4#Fthu$Y7B4xz}*a2nws zSSuFh5JFW74E_a}2INA4Y_5DoX{2RZId{l)1MV)+#vr@bn_4fMi-^>J;Zo);w{!Q) z_`;Z+z?*@%biJ9j+yx9sM7dmU5LN~nzPcCzd*iNSKul8!YMk!S9YG5_gQk>| zxq+ZX7z=&mF;7JI4WC4(;%-ow#6URm5hk(9!4)Q9`vQg@5X$kiW!h8m8Gc;+nPS0I zYuxO|t<_w5go7#M>X?h?1*74Q@bi*y1m9_(R-=AmPUD^oMt>YpI2fId9@ZBzm;5D6 z2jdPj5QZH>f*O0Y{W=8_48nzirovIm{iST-P#K$_j~O*9F93-(aRAV7S2%hOmN=mg zDAZEG510+Fgg6Kx^Z+tA7%2^VGYg$KIqW^5pe|to#6uIf)9Q8e4h4HKcJ7bzw;O>| z5YNSNap|F;@o%sVQ829(5QDd9%V@q>1|lt#5%*F6m7tLZ1~qlk%xNwEqzNQAWnvO! zmd-h%3Ewm&Jx#o_?csRt*WAOVi%0PZ@%cJl8L?nr#1GpCQEw09 zS@hE|4AK7D9KypB%T~p*&1G^-7*|!uWkTyk(QNE2I%*c0#A%+z=vMWTxS^Cl7wjN9 z0x0Y%n)lWS0D}<-R;tV}C3l1@2hvG1hd1dAY2JT=6JJ-ik2uqdyC_<+=VeZQ7oG67 zRN`)j6~_xO*dIPi$J;UfS^C|>`{ue`TgV}XG2a9KRku3;`qa3>Rd*Zmga7Mv|G#&- zu^4O+2ZWS%C6-X*4y6tQzbAqhVSRG431U430+9$@4!g{( zK>6%Gv+hHlTX=8TvP*rp{d3qMkNXYWCaEi%VC8e&IBo!F%Ekm9S>1HzbLPT3ij=t; z2VtFyY?^+kzX_qm*g~R*7VLyWvwM{20p36Zk;M5=jvu)ARjbqpf}NH|)F6q35YnK~ z((!Et>PJa1qz8#n9Nm!$aTRXIQE0Fo_WsHhTJK0V%n&nk@Qh}`k3 zupDKi6p8)jQe<#A_~Ii{Bz`gpeyG^7>2fN|2%M5kg^0+ta4iiH_&4zR$^OmtG(E{b_dNpF*f zL=hpDxac{U6U>1QC}P;(9Lx!QO7$r3p7&x5(xJ$QL=q7B&}tkZjJapr7e4(}2pL@s z@q4qLFK7vB@F<02A9yw!`#|X~GpK>TAfFk8Ch${hF85m4aon@&nuZexO(s2i8fHkyEDh^>(}XD$7ZMDKf8LfGvQ1dg=DWFR0U+kUZd;};Q~I|30d_{1 zOh*zP;aZX|G!a-(K&=or>22Rsjso7o>CA~u$G`~BBw{7PKWe^-a#(Ldvp;17(atr7 zt&~B0iZFGc2n8e3WP@pPE4QA2k#e#LgDtsoBSf+1%8QEh71o8wd$e9_(3W~O6)|B> zBDC&;rbH$8GQZjW0SaGHLMG2S1dudxOciUPPn>}&B8z-~h3wqLw}$qEwHsfhp~ajw z$HXfWxS;WTnQea&4Ae49L%=`0Kr?}Q(uxNk2BsKncl$_*6i`;d0Wd( zzJ9h>C3zOuHUWfK&F`2-9T3&v87MK~sci4r@lLH(oEE297#h#6_8t$ZrSNCMps4Vx zFenPBGoqrx-$JP9&g8UhtWoU}`QqF?n!4Ry0KnZ{I@itQuTmR9OWWGcA0Egyr9$;!D-$N>6zaxxw6ZaNdftwN<*C%EG(grmEVWEQY z+xkE!zYh&C6`AP;Bs+A{Y$LW29+{pU2}-Ard%To3Qtk@=IFPQGGI@ew*4hnB-g{ zkC{{^Z0OzvjszcKc^0CG-#Z4)5A0}DS7nVQni z)T>+WQH{%jN4rBr5K@i>Ua;IEH-P8R*Dh!D31s}Gb**zq;jk#T&LIqRKtmO71&%g2 z7m+c0Ml8!ZB4Mk$e5-a(vPnfQr8rKO;s^lD{{eppzA$bSF4;)c;F85zA2r!31Ponr z(6d;##!xv~0JQbV_SJPy zQtxP``?O7`>SH9Xk}iK!TRE*|PnqfNUomI=Nxh4iyiAglXb8izh>*b^~M_$d>es)W$X4`2jk-Wia{C3zo%EZTS zPgielx9ZKURZ;oEVY3A@dj)^GtV-|oo7n;exRb*`7~gpH{p=+ew98vgf$k>B0}eVOX}_TAW~O=&Uk9C8o1t$G41>ynFIM z|IRi_g7zTXAA0gZbp@wGnCVsxDCD$=gWfeQPbyL$>g~QSX1JM}mm0tMShwS9*@nF1+A{s)75$F= zfG|C0eaZfF+rMGmggH(ZVHwib1i!jQjd=+| zMg6Pm47bkLcdLf0!VpmG2~}Sy4k*IAB+`ZjkN4vJp>hL+=h4sz>`|@eMiRBfL986f zN215GR|y0u4<+M0(2iPVe+0tap@R#nRlaZT_LDkemzdbz_^Vwk~nTe{2C{2P&VjBBtME@kk3PxMj`N$%Jg zoD_lPiB^+4VJralQ6HQf0ZnZvJ6H2-Znp{&V@9o(SL)y~esVR-=6dQP>LO~pn4G$Z z*-3v*IZgM#(4eLaC1r!8&7Xdx1^*q)G0i{&jTyL=2guMvja7p&nWPD1p(+0e2SuU< zvfy(Q6DHfE+OG*s2yD-VXa@{|ch!_X0|*|(a6bOaw&yAzM*Xtwx$U|5B?*RgPC?oq z2GLig#ukFMF7EP!f$I!XD%d4VA$zxpom8{qxf%^HH&TI<;x8s8ui)R}E+Bk@0198A zF8L3^DAJV#?7*uFNyeLUwp=!{mp(AK0*{y{k?i&!|$tSb8Nr^-c@pJRL9BUG#6KOK5H?CPbe$g zdLVUwjxAErW#ayCi80J>3ZXrrMpL5^N$3ZdOP`nv&*p3b+z4z1i*OU@9K5uqVeE=l z&Lz^;(H`r;^NANHIj^q+(GgFVvOMwD?!;fHSfTJ10cXTWM3R((1G)V-XnDmYB4&H4 zJXMhUK%y@8aARVRrwW#8NREXpZ=9Bkfc2bOy1IZr9^P7u5SKD`lYI$LuH{T4e5@EK+oN70%!-x1KpbniW-hy93`3|$+!kz(XDESV>=s8Y@6eNH`H%K-~ zxEFs#aLfTbgz5nl2RzfnPveWDeeOX44j>%Duz7lB51}yW>GAa7(VKl|+cZoC#UIao zFY;#!?iM;#@Q(2M8LuFaesMuVQ*9+Yf;q44BuJfm}L}i)q7T(K(XBu44Ww z$suD%PR?7xofc|W=`D%3s?CW*(hz`iQKI;!;~@}lm;(5LEw$YVLh-BQ90EyXKG@oarF!6z;(!_LEPI3#w&CUGx4HSin@iZj4&?rr@ zc?5F8G~cns1kGj!Me1nI?T>JbBoDczBf4IeQ&}2J?~Fms^d$b4vRaspvmBMPq~G~L zS#wZ|kQRi1p@zPTfT7H_g@x{gF|p32FoP%7@s{(X<0P;dw^Gnnw)GW=-vdW!V**hU zXDh9f)=9p{`j#WpZBdNNvRZ&w**)mabZ4?X{B-SArTLJ0UumSI%9`h_mlw3$fYc-D zyx|SPuzDuWbQTHFwZ*m{lWdXZ4R)zMOBlfdD;j9H{25&ZswrV!P#@KHqp*q16fzX! zT7-<)bifm~S0V&N3p7C!N&~}n$HRpCcJF2;fSSPd1AAxc2c)mx5*&i-=Z6~=CK}=3Ozca8i#q&IyqNpRp2oC|p(OI@@aW!2{ z^HtTfzJe-DtZQvuT)mykOyD&Dot4stef{O8-HX^n03H2nDxMBCCD_1ok z0-7yC&%_qjgV4;GOqw}iQksSxU3<3tD~(`A*L%Kx5~$#NqEM$ z-b91%mKnXVkbeXYI`sa}wJ#aWw#5X(V7f!Nb>kL?4o5qn301ZTa0<)aS?(+(TX$F4uaI-t zEH(>Z@rL;Jl7wxoW~rAE5Pg7P92`E8P#rO*J$&l;v;KYbYB0g?HKg7cw2C#?ik#0Ji%6Fs{*y? zBEYppAFbxP5cc>*kAinr9|s3Tc2I;nsibG24QEuxEda!1nkj}N0w8wbEt!uNChZmw zyd$>v1=?*FR@P>>rZ8)m02u)m(G+>?d%+KUoIeO~yU{;hOjW*0H~y79RT7x09XB_A zE)W5O1&pen>4@%#4$uKTaf(cD{?0QYpBU7o1a(23^GnbZyVnnb0&7Ei1GR6A1;p@s z(5cb*X*)H1Z>yaeUJSjTyRE|PSqA8!v0-sZdCS8HJpGn39gG1sI(BUQM@)))CE+ZU zQe2tKX6$6T$6Oga?aDx2@b*Pe`0=I?WLv+z*HfV_EY$OFCv=^_c?;WDC6JcbUEYG~ zRj{va`wkY(c=}avbSAbn=~p!cKzZJGx>HxM=V}WyyY)O{YHc&>_ufUbf35A$uY8{} zh6trSBixfc@gPY-CHeJ1Ydk_) zeM?CDcwh4f*VOw*+ajuhD)5~+@tEL)$%D*EZrvLbVz_=8c(+neZ_ZZUyc2z+sFNDet&##+7Ppe7$DXw&T_(cfRaqkqOV|9L;H2 zZ98TE#qx&d`3wA$t?j{Ug~tFdHtx->nXaEyOz_uF#-@L##Qa@+j(e|k^FXdlvl%iC zNep8trM9x_{09zZ}mLN(4JL@>Qe@hSdR zxMB|cmjt6Z%+xu+r=P-u$e(5-Ojvy2T45@RABqp}7HgUPMBqNO+sP?hlY*XeKKY!P zGMV3{|ALE>;y!0CreMx8L0Y9~FGwjJ~M~EJ&kc2_$nzC4L(6vx;RdDl}-~)dWKr9w8e3G z`?|>@<{^w~I|t+(>>6&3G`#`}8#-$5)y3dLVbXV*-b5OTGCI3DGZ?zFQ$v@itsmGD zg3TYT7*LjV-VU8IU3ABo{qUH2I6nzk#H^62eJ%x zd7cyFTKkCury;)I_ZxeiEwB65173D*fv2^A%Leth(`MS?ad`OD?vYSKNT_2d^_G=4 zt(ff?`k}lI9BJyR7a*|vC4@P(zcG0qx*LFqQ!rHK(G!){?`Yvlk7|6|mg>rJ<-nW> zxV39sIjdvg2jZmbUU5=2x6Z9oLTZr4|JIHL!1=dN1@_dZ`Aie_y|n)*Hup4q4hGPS zd)kB-wI%Ne{ibcL&m_Q{)givc{j8*i?yukbu7qL9)hQtC1L%7jX&>bO9R@Ot8)4hV zA*0SgMs^NbJywr%upvr>$LXM&lkXTtYe?m@xB&nG`%zz|Bfg|$$Ise@D(U>?q=_Gg1~R1ZW(dHWVPM>t-T*)C9~%Ww@q*IOZ2<-7}#y4YyobeH?M91wCpij zi13BGS=R2gWk5SphAj=d8EtW_M}V2%q6gnow5|=n&sqhbB6Wsm%euFvhbM&Gf#u)LtLAKF3rNBKM2Vcr0DoK!R9)_fiJp5lJ79=+fX zN@tlGnup?Swe=mmJ98d<{G5U`vz&c8RFHmMk?5T$Eyb1~?9X9cpznVM^!5wD<}!rmtH0Q+ z|8)5!RcRBz+fQoqQ1Co}h;CA9Dvbk5EkI2X+}|T56%U4;c)}s<>{CKe{JYR2g1T+E z^WGMXID`hBg?-`>NclY*s;mqGsUQji)R6r$)2J<^2rw1L#{n>>|Fw0L8_#~@y{QU;c%qFYZ4@o z)1Vqw;yMSs*xVPypMok(jssp|&P%0AghQo>c|dv}jj$m>6o<(x-E`|`^+MnOtX}B$ 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�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­p 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

?6k~*tB~jSdU9+0M=Mf^6?%qVSA<+ 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 K?)BM&xpb% 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 wQMoA=TApT~%o+>dZs&u;?@B<_Y1v#RD&n5i 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

nZ~ezwt?nV;kbY=qI|*_W~G5y3@XxM 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

cn9ljtNARg-{8tjai!7q`;sw0oJGnnxC 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

ei*GH(xo+Y~wAYUwoRJ&LzmbUg9 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≠0W}Vr?r*nw4Neyz6D6%92_`htqG5yj|n0~ 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

gs;V>#rIP470HH>_n!Nr7-nvkOr9 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

$I* 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%0D%p`B_QffgQCX)rX;Dq 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р8~(&KA!X!)uXaVf(}W5Z;WR=b7CvBK`?>kkFemv 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%0D&8^)LUw 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 z + + + + + + + + + + + + + +FAQ | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + +

    + + + +
    +
    +
    + + +
    + +
    +

    FAQ

    +

    General questions

    +

    What is K?

    +

    [13 Dec, 2013] K is a framework for defining programming languages. Once you define a language, K gives you a series of tools for that language, such as: a parser, an interpreter, a state-space explorer (like a model-checker for reachability), and even a deductive program verifier. We continuously work on making these tools better and on adding new tools.

    +

    What is a language definition?

    +

    [13 Dec, 2013] A language definition consists of two parts: syntax and semantics. The syntax is defined using a BNF-style, enriched with several features to ease the semantics. The semantics tells what each language construct is meant to do. This way, a language definition says both how the programs in your language should look like and also what they mean, or how they execute.

    +

    What is the difference between a definition and an implementation?

    +

    [13 Dec, 2013] No difference in K. We think of K definitions as formal, rigorous implementations of the language. In fact, many users of K have no background on programming language semantics, they think of K as a domain-specific language for implementing programming languages. The benefit of implementing your language in K is that you can make use of the tools that K offers, which is not possible when you implement your language in a conventional programming language.

    +

    Why K?

    +

    [13 Dec, 2013] There was and still is a considerable amount of effort spent by many scientists on developing parsing, model-checking, program verification and other formal program analysis techniques. Most of these techniques are language independent, yet a considerable amount of effort is then spent on developing language-specific tools based on these techniques. For example, developing a model-checker or a program verifier for Java, or C, or Python, is a serious endeavor, that only very few highly-skilled people can attempt. We believe that all these language-specific tools can be automatically derived from the K language definition, so that language designers spend the time only once to define their language and then get not only an implementation of their language, but also all the other tools, essentially for free.

    +

    What is the difference between K and ...

    +

    SDF

    +

    [13 Dec, 2013]sdf is a parser generator. Simply speaking, it takes as input a grammar written in the SDF format and a text, and creates the abstract-syntax tree of that text corresponding to the grammar specification. K currently uses SDF for its parsing needs, but we integrated it into a more complex environment suitable for semantic definitions. Using the same language specification, we generate multiple parsers for different purposes: parse programs, parse rewrite rules, etc. Another difference is that we changed a bit the syntax of the grammar specification. We adopted a BNF-style notation whereas SDF uses an algebraic specification, but we keept the same disambiguation system with priorities and associativity filters.

    +

    Maude

    +

    PLT Redex

    +

    [16 Dec, 2013]plt redex is a language definitional framework based on reduction semantics with evaluation contexts, a type of Structural Operational Semantics. A PLT definition consists of the syntax for the language (including the syntax of the execution configuration, if needed), followed by a syntax for evaluation contexts which allows identifying the next reducible expression (redex). The rules can specify the parts of the context (and abstract parts of it using variables), and can alter both the redex and the context. PLT Redex offers a suite of tools built on top of the Racket Scheme-based IDE to help visualize and explore executions. K borrows from PLT Redex the idea of evaluation contexts, and extends it further allowing more complex conditions be put on them. A distinctive difference between Redex and K is the fact that in K evaluation contexts are used only for the computational fragment of the executing configuration, the rules applying modulo the configuration abstraction. This, for example, allows K to more easily specify synchronous communication of agents or threads.

    +

    Spoofax

    +

    Rascal

    +

    OTT

    +

    ATL and Model-Driven Engineering

    +

    [14 Dec, 2013]atl (Atlas Transformation Language) falls in the Model-Driven Engineering (MDE) field and includes a model transformation language and toolkit. ATL is also based on rules, which provide a means to produce a target model Mb conforming to a meta-model MMb, from a source model Ma conforming to a meta-model MMa. It should not be difficult to define such model transformations using K, this way effectively using the target meta-model MMb to give semantics to the source meta-model MMa. Moreover, if MMa and MMb have K semantics themselves, then the K tool can be used for proving the conformance of the transformation. Note, however, that K does not currently supply any explicit support for meta-model technologies, such as EMF (Eclipse Modelling Framework), etc.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + diff --git a/index.html b/index.html new file mode 100644 index 00000000000..c3c9742a259 --- /dev/null +++ b/index.html @@ -0,0 +1,418 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    K is a rewrite-based +executable semantic framework in which programming languages, type +systems and formal analysis tools can be defined using configurations +and rules. Configurations organize the state in units called cells, +which are labeled and can be nested. K rewrite rules make it explicit +which parts of the term are read-only, write-only, read-write, or +unused. This makes K suitable for defining truly concurrent languages +even in the presence of sharing. Computations are represented as +syntactic extensions of the original language abstract syntax, using a +nested list structure which sequentializes computational tasks, such +as program fragments. Computations are like any other terms in a +rewriting environment: they can be matched, moved from one place to +another, modified, or deleted. This makes K suitable for defining +control-intensive features such as abrupt termination, exceptions, or +call/cc.

    +

    K Tool Download

    +
      +
    • Install from the latest K GitHub Release.
    • +
    • Try our Editor Support page for links to K syntax highlighting definitions for various popular editors/IDEs. Please feel free to contribute.
    • +
    • Build or browse the code on GitHub, where you can also report bugs.
    • +
    +

    Learn K

    + +

    Support

    + +

    Resources

    + +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + diff --git a/install b/install new file mode 100644 index 00000000000..70476dbcd6f --- /dev/null +++ b/install @@ -0,0 +1,71 @@ +#!/usr/bin/env bash + +{ # Prevent execution if this script was only partially downloaded + set -e + + GREEN='\033[0;32m' + RED='\033[0;31m' + NC='\033[0m' + + NIX_POST_INSTALL_MESSAGE="To ensure that the necessary environment variables are set, either log in again, or type + + . /nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh + +in your shell." + + oops() { + >&2 echo -e "${RED}error:${NC} $1" + exit 1 + } + + [[ "$(id -u)" -eq 0 ]] && oops "Please run this script as a regular user" + + # Check if nix is already installed and is at least version 2.4 + if command -v nix > /dev/null; then + NIX_VERSION=$(nix --version | sed -ne 's/[^0-9]*\(\([0-9]\.\)\)/\1/p') + NIX_VERSION_MINOR=$(echo "$NIX_VERSION" | cut -d. -f2) + if [ "$NIX_VERSION_MINOR" -gt "3" ]; then + echo -e "Detected nix version $NIX_VERSION. Proceeding with K framework install." + else + oops "It appears that you have a version of nix on your system that's too old. The K framework installer requires nix >=2.4. Please update nix and try again." + fi + else + read -p "It appears that you don't have nix installed. Since the K framework needs nix for distribution, this script will attempt to install nix first. Would you like to proceed? [y/N]" -n 1 -r + echo + if [[ $REPLY =~ ^[Yy]$ ]] + then + echo "Downloading nix and running the installer..." + curl --proto '=https' --tlsv1.2 -sSf -L https://install.determinate.systems/nix | sh -s -- install --no-confirm \ + --extra-conf "trusted-public-keys = cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY= k-framework.cachix.org-1:jeyMXB2h28gpNRjuVkehg+zLj62ma1RnyyopA/20yFE= k-framework-binary.cachix.org-1:pJedQ8iG19BW3v/DMMmiRVtwRBGO3fyMv2Ws0OpBADs=" \ + --extra-conf "substituters = https://cache.nixos.org https://k-framework.cachix.org" + if [ -e '/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh' ]; then + . '/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh' + else + oops "Could not source nix." + fi + NIX_FRESH_INSTALL=true + else + oops "Cannot proceed with the installation without nix." + fi + fi + + PREV_KUP_INSTALL=$(nix profile list --experimental-features 'nix-command flakes' | awk '/packages\..*\.kup/ {print $1}') + if ! [[ -z "$PREV_KUP_INSTALL" ]]; then + echo "Removing previous K framework installer versions ..." + GC_DONT_GC=1 nix profile remove $PREV_KUP_INSTALL \ + --experimental-features 'nix-command flakes' + fi + + echo "Installing the K framework installer utility (kup) ..." + + GC_DONT_GC=1 nix profile install github:runtimeverification/kup#kup \ + --option extra-substituters 'https://k-framework.cachix.org' \ + --option extra-trusted-public-keys 'k-framework.cachix.org-1:jeyMXB2h28gpNRjuVkehg+zLj62ma1RnyyopA/20yFE=' \ + --experimental-features 'nix-command flakes' + + echo -e "${GREEN}All set!${NC}" + if [ -n "$NIX_FRESH_INSTALL" ]; then + echo -e "$NIX_POST_INSTALL_MESSAGE" + fi + +} diff --git a/k-distribution/INSTALL/index.html b/k-distribution/INSTALL/index.html new file mode 100644 index 00000000000..1357f660d21 --- /dev/null +++ b/k-distribution/INSTALL/index.html @@ -0,0 +1,603 @@ + + + + + + + + + + + + + + +Installing the K Framework | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Installing the K Framework

    +

    Fast Installation (preferred)

    +

    If you're on a system that supports Nix, +use this command to install via Nix:

    +
    shell
    bash <(curl https://kframework.org/install) +kup install k +
    +

    You can update K with:

    +
    shell
    kup update k +
    +

    And list available versions with:

    +
    shell
    kup list +
    +

    This will take care of all the dependencies and specific versions used by K. +Note that the first run will take longer to fetch all the libraries and compile +sources. (30m to 1h)

    +

    If you are on Apple Silicon, kup is currently the only way to install K +because of upstream issues in the general Haskell ecosystem.

    +

    Install through packages

    +

    We currently strive to provide packages for the following platforms:

    +
      +
    • Ubuntu Jammy Jellyfish (22.04)
    • +
    • macOS Ventura (13) via Homebrew
    • +
    • Docker Images
    • +
    +

    Pre-installation Notes

    +
      +
    • +

      We do not currently support running K natively on Windows. To use K on +Windows 10, you are encouraged to install the +Windows Subsystem for Linux (version 2) +and follow the instructions for installing Ubuntu Jammy.

      +

      If you have already installed WSL, before proceeding, you will need to +enter the WSL environment. You can do this by:

      +
        +
      1. opening up the command prompt (accessible by searching cmd or +command prompt from the start menu);
      2. +
      3. using the wsl.exe command to access the WSL environment.
      4. +
      +
    • +
    • +

      To use K in other non-linux environments (e.g. Windows 8 or earlier), +you will need to use a virtual machine (VM) software. We assume you have:

      +
        +
      1. Created a virtual machine
      2. +
      3. Installed a Linux distribution (e.g. Ubuntu Jammy Jellyfish) on your +virtual machine
      4. +
      +

      Consult your virtual machine software if you need help with the above +steps. We recommend the free VirtualBox virtual machine software.

      +

      Before proceeding, follow the virtual machine softare UI to start your +Linux virtual machine and enter the command line environment.

      +
    • +
    • +

      WSL and virtual machine users should be aware that, if you use your web +browser to download the package, you will need to make it accessible to +the command line environment. For this reason, we recommend downloading the +package from the command line directly using a tool like wget. For +example, you could copy the package download URL and then type:

      +
      wget <package-download-url>
      +
      +

      where <package-download-url> is replaced by the URL you just copied.

      +
    • +
    • +

      K depends on version 4.8.15 of Z3, which may not be supplied by package +managers. If this is the case, it should be built and installed from source +following the +instructions in +the Z3 repository. Other versions (older and newer) are not supported by K, +and may lead to incorrect behaviour or performance issues.

      +
    • +
    +

    Downloading Packages

    +

    Download the appropriate package from the GitHub, via the +Releases page. +Releases are generated as often as possible from master build.

    +

    Installing Packages

    +

    For version X.Y.Z, distribution DISTRO, and package ID ID, the following +instructions tell you how to install on each system. Note that this typically +requires about ~1.4GB of dependencies and will take some time.

    +
      +
    • On Linux systems, K will typically be installed under /usr.
    • +
    • On macOS/brew, K will typically be installed under /usr/local.
    • +
    +

    Ubuntu Jammy (22.04)

    +
    sh
    sudo apt install ./kframework_amd64_ubuntu_jammy.deb +
    +

    macOS (Homebrew)

    +

    Homebrew (or just brew) is a third-party package manager +for MacOS. +If you have not installed brew, you must do so before installing the K +Framework brew package.

    +

    With brew installed, do the following to install the K Framework brew package +(with build number BN):

    +
    sh
    brew install kframework--X.Y.Z.ID.bottle.BN.tar.gz -v +
    +

    Homebrew Alternate Installation

    +

    To directly install the latest K Framework brew package without needing to +download it separately, do the following:

    +
    sh
    brew install runtimeverification/k/kframework +
    +

    Or, to streamline future K Framework upgrades, you can tap the K Framework +package repository. This lets future installations/upgrades/etc... use the +unprefixed package name.

    +
    sh
    brew tap runtimeverification/k +brew install kframework +
    +

    Docker Images

    +

    Docker images with K pre-installed are available at the +runtimeverification/kframework-k Docker Hub repository.

    +

    Each release at COMMIT_ID has an image associated with it at +runtimeverificationinc/kframework-k:ubuntu-jammy-COMMIT_ID.

    +

    To run the image directly:

    +
    sh
    docker run -it runtimeverificationinc/kframework-k:ubuntu-jammy-COMMIT_ID +
    +

    and to make a Docker Image based on it, use the following line in your +Dockerfile:

    +
    Dockerfile
    FROM runtimeverificationinc/kframework-k:ubuntu-jammy-COMMIT_ID +
    +

    We also create Ubuntu 22.04 images with the ubuntu-jammy-COMMIT_ID tags.

    +

    Testing Packages

    +

    The easiest way to test the K package is to copy a K tutorial language and +check if you can compile and run an included example.

    +
      +
    1. +

      Start by copying the K tutorial to some work directory +(e.g. $HOME/pl-tutorial) from the K distribution root. Using a Linux +package, this command typically will be like:

      +
      sh
      $ cp -R /usr/share/kframework/pl-tutorial $HOME/pl-tutorial +
      +

      On macOS/brew, this command typically will be like:

      +
      sh
      $ cp -R /usr/local/share/kframework/pl-tutorial $HOME/pl-tutorial +
      +

      This step is needed because sometimes only the root user can run the +examples in the default installation directory.

      +
    2. +
    3. +

      Now you can try to run some programs:

      +
      sh
      $ cd $HOME/pl-tutorial/2_languages/1_simple/1_untyped +$ make kompile +$ krun tests/diverse/factorial.simple +
      +
    4. +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/include/kframework/builtin/domains/index.html b/k-distribution/include/kframework/builtin/domains/index.html new file mode 100644 index 00000000000..e5f862361c1 --- /dev/null +++ b/k-distribution/include/kframework/builtin/domains/index.html @@ -0,0 +1,3938 @@ + + + + + + + + + + + + + + +Basic Builtin Types in K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Basic Builtin Types in K

    +

    A major piece of the K prelude consists of a series of modules that contain +implementations of basic data types and language features in K. You do not need +to require this file yourself; it is required automatically in every K +definition unless --no-prelude is passed to kompile. K may not work correctly +if some of these modules do not exist or do not declare certain functions.

    +

    Note that some functions in the K prelude functions are not total, that is, +they are not defined on all possible input values. When you invoke such a +function on an undefined input, the behavior is undefined. In particular, when +this happens, interpreters generated by the K LLVM backend may crash.

    +
    k
    require "kast.md" +
    +

    Default Modules

    +

    K declares certain modules that contain most of the builtins you usually want +when defining a language in K. In particular, this includes integers, booleans, +strings, identifiers, I/O, lists, maps, and sets. The DOMAINS-SYNTAX module +is designed to be imported by the syntax module of the language and contains +only the program-level syntax of identifiers, integers, booleans, and strings. +The DOMAINS module contains the rest of the syntax, including builtin +functions over those and the remaining types.

    +

    Note that not all modules are included in DOMAINS. A few less-common modules +are not, including ARRAY, COLLECTIONS, FLOAT, STRING-BUFFER, BYTES, +K-REFLECTION, MINT, and STRATEGY.

    +
    k
    module DOMAINS-SYNTAX + imports SORT-K + imports ID-SYNTAX + imports UNSIGNED-INT-SYNTAX + imports BOOL-SYNTAX + imports STRING-SYNTAX +endmodule + +module DOMAINS + imports DOMAINS-SYNTAX + imports INT + imports BOOL + imports STRING + imports BASIC-K + imports LIST + imports K-IO + imports MAP + imports SET + imports ID + imports K-EQUAL +endmodule +
    +

    Arrays

    +

    Provided here is an implementation for fixed-sized, contiguous maps from Int +to KItem. In some previous versions of K, the Array type was a builtin type +backed by mutable arrays of objects. However, in modern K, the Array type is +implemented by means of the List type; users should not access this interface +directly and should instead make only of the functions listed below. Users of +this module should import only the ARRAY module.

    +
    k
    module ARRAY-SYNTAX + imports private LIST + + syntax Array [hook(ARRAY.Array)] +
    +

    Array lookup

    +

    You can look up an element in an Array by its index in O(log(N)) time. Note +that the base of the logarithm is a relatively high number and thus the time is +effectively constant.

    +
    k
    syntax KItem ::= Array "[" Int "]" [function, hook(ARRAY.lookup)] +
    +

    Array update

    +

    You can create a new Array with a new value for a key in O(log(N)) time, or +effectively constant.

    +
    k
    syntax Array ::= Array "[" key: Int "<-" value: KItem "]" [function, hook(ARRAY.update), klabel(_[_<-_]), symbol] +
    +

    Array reset

    +

    You can create a new Array where a particular key is reset to its default +value in O(log(N)) time, or effectively constant.

    +
    k
    syntax Array ::= Array "[" Int "<-" "undef" "]" [function, hook(ARRAY.remove)] +
    +

    Multiple array update

    +

    You can create a new Array from a List L of size N where the N +elements starting at index are replaced with the contents of L, in +O(N*log(K)) time (where K is the size of the array), or effectively linear. +Having index + N > K yields an exception.

    +
    k
    syntax Array ::= updateArray(Array, index: Int, List) [function, hook(ARRAY.updateAll)] +
    +

    Array fill

    +

    You can create a new Array where the length elements starting at index +are replaced with value, in O(length*log(N)) time, or effectively linear.

    +
    k
    syntax Array ::= fillArray(Array, index: Int, length: Int, value: KItem) [function, hook(ARRAY.fill)] +
    +

    Array range check

    +

    You can test whether an integer is within the bounds of an array in O(1) time.

    +
    k
    syntax Bool ::= Int "in_keys" "(" Array ")" [function, total, hook(ARRAY.in_keys)] +
    +
    k
    endmodule + +module ARRAY-IN-K [private] + imports public ARRAY-SYNTAX + imports private LIST + imports private K-EQUAL + imports private INT + imports private BOOL +
    +

    Array creation

    +

    You can create an array with length elements where each element is +initialized to value in O(1) time. Note that the array is stored in a manner +where only the highest element that is actually modified is given a value +in its internal representation, which means that subsequent array operations +may incur a one-time O(N) resizing cost, possibly amortized across multiple +operations.

    +
    k
    syntax Array ::= makeArray(length: Int, value: KItem) [function, hook(ARRAY.make), public] +
    +

    Implementation of Arrays

    +

    The remainder of this section consists of an implementation in K of the +operations listed above. Users of the ARRAY module should not make use +of any of the syntax defined in any of these modules.

    +
    k
    syntax Array ::= arr(List, Int, KItem) + + rule makeArray(I::Int, D::KItem) => arr(.List, I, D) + + rule arr(L::List, _, _ ) [ IDX::Int ] => L[IDX] requires 0 <=Int IDX andBool IDX <Int size(L) + rule arr(_ , _, D::KItem) [ _ ] => D [owise] + + syntax List ::= ensureOffsetList(List, Int, KItem) [function] + rule ensureOffsetList(L::List, IDX::Int, D::KItem) => L makeList(IDX +Int 1 -Int size(L), D) requires IDX >=Int size(L) + rule ensureOffsetList(L::List, IDX::Int, _::KItem) => L requires notBool IDX >=Int size(L) + + rule arr(L::List, I::Int, D::KItem) [ IDX::Int <- VAL::KItem ] => arr(ensureOffsetList(L, IDX, D) [ IDX <- VAL ], I, D) + + rule arr(L::List, I::Int, D::KItem) [ IDX::Int <- undef ] => arr(L, I, D) [ IDX <- D ] + + rule updateArray(arr(L::List, I::Int, D::KItem), IDX::Int, L2::List) => arr(updateList(ensureOffsetList(L, IDX +Int size(L2) -Int 1, D), IDX, L2), I, D) + + rule fillArray(arr(L::List, I::Int, D::KItem), IDX::Int, LEN::Int, VAL::KItem) => arr(fillList(ensureOffsetList(L, IDX +Int LEN -Int 1, D), IDX, LEN, VAL), I, D) + + rule IDX::Int in_keys(arr(_, I::Int, _)) => IDX >=Int 0 andBool IDX <Int I +endmodule + +module ARRAY-SYMBOLIC [symbolic] + imports ARRAY-IN-K +endmodule + +module ARRAY-KORE [kore] + imports ARRAY-IN-K +endmodule + +module ARRAY + imports ARRAY-SYMBOLIC + imports ARRAY-KORE +endmodule +
    +

    Maps

    +

    Provided here is the syntax of an implementation of immutable, associative, +commutative maps from KItem to KItem. This type is hooked to an +implementation of maps provided by the backend. For more information on +matching on maps and allowable patterns for doing so, refer to K's +user documentation.

    +
    k
    module MAP + imports private BOOL-SYNTAX + imports private INT-SYNTAX + imports private LIST + imports private SET + + syntax Map [hook(MAP.Map)] +
    +

    Map concatenation

    +

    The Map sort represents a generalized associative array. Each key can be +paired with an arbitrary value, and can be used to reference its associated +value. Multiple bindings for the same key are not allowed.

    +

    You can construct a new Map consisting of key/value pairs of two Maps. The +result is #False if the maps have keys in common (in particular, this will +yield an exception during concrete execution). This operation is O(Nlog(M)) +where N is the size of the smaller map, when it appears on the right hand side. +When it appears on the left hand side and all variables are bound, it is +O(Nlog(M)) where M is the size of the map it is matching and N is the number +of elements being matched. When it appears on the left hand side containing +variables not bound elsewhere in the term, it is O(N^K) where N is the size of +the map it is matching and K is the number of unbound keys being matched. In +other words, one unbound variable is linear, two is quadratic, three is cubic, +etc.

    +
    k
    syntax Map ::= Map Map [left, function, hook(MAP.concat), klabel(_Map_), symbol, assoc, comm, unit(.Map), element(_|->_), index(0), format(%1%n%2)] +
    +

    Map unit

    +

    The map with zero elements is represented by .Map.

    +
    k
    syntax Map ::= ".Map" [function, total, hook(MAP.unit), klabel(.Map), symbol, latex(\dotCt{Map})] +
    +

    Map elements

    +

    An element of a Map is constructed via the |-> operator. The key is on the +left and the value is on the right.

    +
    k
    syntax Map ::= KItem "|->" KItem [function, total, hook(MAP.element), klabel(_|->_), symbol, latex({#1}\mapsto{#2}), injective] + + syntax priorities _|->_ > _Map_ .Map + syntax non-assoc _|->_ +
    +

    Map lookup

    +

    You can look up the value associated with the key of a map in O(log(N)) time. +Note that the base of the logarithm is a relatively high number and thus the +time is effectively constant. The value is #False if the key is not in the +map (in particular, this will yield an exception during concrete execution).

    +
    k
    syntax KItem ::= Map "[" KItem "]" [function, hook(MAP.lookup), klabel(Map:lookup), symbol] +
    +

    Map lookup with default

    +

    You can also look up the value associated with the key of a map using a +total function that assigns a specific default value if the key is not present +in the map. This operation is also O(log(N)), or effectively constant.

    +
    k
    syntax KItem ::= Map "[" KItem "]" "orDefault" KItem [function, total, hook(MAP.lookupOrDefault), klabel(Map:lookupOrDefault)] +
    +

    Map update

    +

    You can insert a key/value pair into a map in O(log(N)) time, or effectively +constant.

    +
    k
    syntax Map ::= Map "[" key: KItem "<-" value: KItem "]" [function, total, klabel(Map:update), symbol, hook(MAP.update), prefer] +
    +

    Map delete

    +

    You can remove a key/value pair from a map via its key in O(log(N)) time, or +effectively constant.

    +
    k
    syntax Map ::= Map "[" KItem "<-" "undef" "]" [function, total, hook(MAP.remove), klabel(_[_<-undef]), symbol] +
    +

    Map difference

    +

    You can remove the key/value pairs in a map that are present in another map in +O(N*log(M)) time (where M is the size of the first map and N is the size of the +second), or effectively linear. Note that only keys whose value is the same +in both maps are removed. To remove all the keys in one map from another map, +you can say removeAll(M1, keys(M2)).

    +
    k
    syntax Map ::= Map "-Map" Map [function, total, hook(MAP.difference), latex({#1}-_{\it Map}{#2})] +
    +

    Multiple map update

    +

    You can update a map by adding all the key/value pairs in the second map in +O(N*log(M)) time (where M is the size of the first map and N is the size of the +second map), or effectively linear. If any keys are present in both maps, the +value from the second map overwrites the value in the first. This function is +total, which is distinct from map concatenation, a partial function only +defined on maps with disjoint keys.

    +
    k
    syntax Map ::= updateMap(Map, Map) [function, total, hook(MAP.updateAll)] +
    +

    Multiple map removal

    +

    You can remove a Set of keys from a map in O(N*log(M)) time (where M is the +size of the Map and N is the size of the Set), or effectively linear.

    +
    k
    syntax Map ::= removeAll(Map, Set) [function, total, hook(MAP.removeAll)] +
    +

    Map keys (as Set)

    +

    You can get a Set of all the keys in a Map in O(N) time.

    +
    k
    syntax Set ::= keys(Map) [function, total, hook(MAP.keys)] +
    +

    Map keys (as List)

    +

    You can get a List of all the keys in a Map in O(N) time.

    +
    k
    syntax List ::= "keys_list" "(" Map ")" [function, hook(MAP.keys_list)] +
    +

    Map key membership

    +

    You can check whether a key is present in a map in O(1) time.

    +
    k
    syntax Bool ::= KItem "in_keys" "(" Map ")" [function, total, hook(MAP.in_keys)] +
    +

    Map values (as List)

    +

    You can get a List of all the values in a map in O(N) time.

    +
    k
    syntax List ::= values(Map) [function, hook(MAP.values)] +
    +

    Map size

    +

    You can get the number of key/value pairs in a map in O(1) time.

    +
    k
    syntax Int ::= size(Map) [function, total, hook(MAP.size), klabel(sizeMap)] +
    +

    Map inclusion

    +

    You can determine whether a Map is a strict subset of another Map in O(N) +time (where N is the size of the first map). Only keys that are bound to the +same value are considered equal.

    +
    k
    syntax Bool ::= Map "<=Map" Map [function, total, hook(MAP.inclusion)] +
    +

    Map choice

    +

    You can get an arbitrarily chosen key of a Map in O(1) time. The same key +will always be returned for the same map, but no guarantee is given that two +different maps will return the same element, even if they are similar.

    +
    k
    syntax KItem ::= choice(Map) [function, hook(MAP.choice), klabel(Map:choice)] +
    +

    Implementation of Maps

    +

    The remainder of this section contains lemmas used by the Java and Haskell +backend to simplify expressions of sort Map. They do not affect the semantics +of maps, merely describing additional rules that the backend can use to +simplify terms.

    +
    k
    endmodule + +module MAP-KORE-SYMBOLIC [kore,symbolic,haskell] + imports MAP + imports private K-EQUAL + imports private BOOL + + rule #Ceil(@M:Map [@K:KItem]) => {(@K in_keys(@M)) #Equals true} #And #Ceil(@M) #And #Ceil(@K) [simplification] + + // Symbolic update + + // Adding the definedness condition `notBool (K in_keys(M))` in the ensures clause of the following rule would be redundant + // because K also appears in the rhs, preserving the case when it's #Bottom. + rule (K |-> _ M:Map) [ K <- V ] => (K |-> V M) [simplification] + rule M:Map [ K <- V ] => (K |-> V M) requires notBool (K in_keys(M)) [simplification] + rule M:Map [ K <- _ ] [ K <- V ] => M [ K <- V ] [simplification] + // Adding the definedness condition `notBool (K1 in_keys(M))` in the ensures clause of the following rule would be redundant + // because K1 also appears in the rhs, preserving the case when it's #Bottom. + rule (K1 |-> V1 M:Map) [ K2 <- V2 ] => (K1 |-> V1 (M [ K2 <- V2 ])) requires K1 =/=K K2 [simplification] + + // Symbolic remove + rule (K |-> _ M:Map) [ K <- undef ] => M ensures notBool (K in_keys(M)) [simplification] + rule M:Map [ K <- undef ] => M requires notBool (K in_keys(M)) [simplification] + // Adding the definedness condition `notBool (K1 in_keys(M))` in the ensures clause of the following rule would be redundant + // because K1 also appears in the rhs, preserving the case when it's #Bottom. + rule (K1 |-> V1 M:Map) [ K2 <- undef ] => (K1 |-> V1 (M [ K2 <- undef ])) requires K1 =/=K K2 [simplification] + + // Symbolic lookup + rule (K |-> V M:Map) [ K ] => V ensures notBool (K in_keys(M)) [simplification] + rule (K1 |-> _V M:Map) [ K2 ] => M [K2] requires K1 =/=K K2 ensures notBool (K1 in_keys(M)) [simplification] + rule (_MAP:Map [ K <- V1 ]) [ K ] => V1 [simplification] + rule ( MAP:Map [ K1 <- _V1 ]) [ K2 ] => MAP [ K2 ] requires K1 =/=K K2 [simplification] + + rule (K |-> V M:Map) [ K ] orDefault _ => V ensures notBool (K in_keys(M)) [simplification] + rule (K1 |-> _V M:Map) [ K2 ] orDefault D => M [K2] orDefault D requires K1 =/=K K2 ensures notBool (K1 in_keys(M)) [simplification] + rule (_MAP:Map [ K <- V1 ]) [ K ] orDefault _ => V1 [simplification] + rule ( MAP:Map [ K1 <- _V1 ]) [ K2 ] orDefault D => MAP [ K2 ] orDefault D requires K1 =/=K K2 [simplification] + rule .Map [ _ ] orDefault D => D [simplification] + + // Symbolic in_keys + rule K in_keys(_M [ K <- undef ]) => false [simplification] + rule K in_keys(_M [ K <- _ ]) => true [simplification] + rule K1 in_keys(M [ K2 <- _ ]) => true requires K1 ==K K2 orBool K1 in_keys(M) [simplification] + rule K1 in_keys(M [ K2 <- _ ]) => K1 in_keys(M) requires K1 =/=K K2 [simplification] + + rule {false #Equals @Key in_keys(.Map)} => #Ceil(@Key) [simplification] + rule {@Key in_keys(.Map) #Equals false} => #Ceil(@Key) [simplification] + rule {false #Equals @Key in_keys(Key' |-> Val @M)} => #Ceil(@Key) #And #Ceil(Key' |-> Val @M) #And #Not({@Key #Equals Key'}) #And {false #Equals @Key in_keys(@M)} [simplification] + rule {@Key in_keys(Key' |-> Val @M) #Equals false} => #Ceil(@Key) #And #Ceil(Key' |-> Val @M) #And #Not({@Key #Equals Key'}) #And {@Key in_keys(@M) #Equals false} [simplification] + +/* +// The rule below is automatically generated by the frontend for every sort +// hooked to MAP.Map. It is left here to serve as documentation. + + rule #Ceil(@M:Map (@K:KItem |-> @V:KItem)) => {(@K in_keys(@M)) #Equals false} #And #Ceil(@M) #And #Ceil(@K) #And #Ceil(@V) + [simplification] +*/ +endmodule + +module MAP-SYMBOLIC + imports MAP-KORE-SYMBOLIC +endmodule +
    +

    Range Maps

    +

    Provided here is the syntax of an implementation of immutable, associative, +commutative range maps from Int to KItem. This type is hooked to an +implementation of range maps provided by the LLVM backend. +Currently, this type is not supported by other backends. +Although the underlying range map data structure supports any key sort, the +current implementation by the backend only supports Int keys due to +limitations of the underlying ordering function.

    +
    k
    module RANGEMAP + imports private BOOL-SYNTAX + imports private INT-SYNTAX + imports private LIST + imports private SET + +
    +

    Range, bounded inclusively below and exclusively above.

    +
    k
    syntax Range ::= "[" KItem "," KItem ")" [klabel(Rangemap:Range), symbol] + + syntax RangeMap [hook(RANGEMAP.RangeMap)] +
    +

    Range map concatenation

    +

    The RangeMap sort represents a map whose keys are stored as ranges, bounded +inclusively below and exclusively above. Contiguous or overlapping ranges that +map to the same value are merged into a single range.

    +

    You can construct a new RangeMap consisting of range/value pairs of two +RangeMaps. If the RangeMaps have overlapping ranges an exception will be +thrown during concrete execution. This operation is O(N*log(M)) (where N is +the size of the smaller map and M is the size of the larger map).

    +
    k
    syntax RangeMap ::= RangeMap RangeMap [left, function, hook(RANGEMAP.concat), klabel(_RangeMap_), symbol, assoc, comm, unit(.RangeMap), element(_r|->_), index(0), format(%1%n%2)] +
    +

    Range map unit

    +

    The RangeMap with zero elements is represented by .RangeMap.

    +
    k
    syntax RangeMap ::= ".RangeMap" [function, total, hook(RANGEMAP.unit), klabel(.RangeMap), symbol, latex(\dotCt{RangeMap})] +
    +

    Range map elements

    +

    An element of a RangeMap is constructed via the r|-> operator. The range +of keys is on the left, and the value is on the right.

    +
    k
    syntax RangeMap ::= Range "r|->" KItem [function, hook(RANGEMAP.elementRng), klabel(_r|->_), symbol, latex({#1}\mapsto{#2}), injective] + + syntax priorities _r|->_ > _RangeMap_ .RangeMap + syntax non-assoc _r|->_ +
    +

    Range map lookup

    +

    You can look up the value associated with a key of a RangeMap in O(log(N)) +time (where N is the size of the RangeMap). This will yield an exception +during concrete execution if the key is not in the range map.

    +
    k
    syntax KItem ::= RangeMap "[" KItem "]" [function, hook(RANGEMAP.lookup), klabel(RangeMap:lookup), symbol] +
    +

    Range map lookup with default

    +

    You can also look up the value associated with a key of a RangeMap using a +total function that assigns a specific default value if the key is not present +in the RangeMap. This operation is also O(log(N)) (where N is the size of +the range map).

    +
    k
    syntax KItem ::= RangeMap "[" KItem "]" "orDefault" KItem [function, total, hook(RANGEMAP.lookupOrDefault), klabel(RangeMap:lookupOrDefault)] +
    +

    Range map lookup for range of key

    +

    You can look up for the range that a key of a RangeMap is stored in in +O(log(N)) time (where N is the size of the RangeMap). This will yield an +exception during concrete execution if the key is not in the range map.

    +
    k
    syntax Range ::= "find_range" "(" RangeMap "," KItem ")" [function, hook(RANGEMAP.find_range), klabel(RangeMap:find_range)] +
    +

    Range map update

    +

    You can insert a range/value pair into a RangeMap in O(log(N)) time (where N +is the size of the RangeMap). Any ranges adjacent to or overlapping with the +range to be inserted will be updated accordingly.

    +
    k
    syntax RangeMap ::= RangeMap "[" keyRange: Range "<-" value: KItem "]" [function, klabel(RangeMap:update), symbol, hook(RANGEMAP.updateRng), prefer] +
    +

    Range map delete

    +

    You can remove a range/value pair from a RangeMap in O(log(N)) time (where N +is the size of the RangeMap). If all or any part of the range is present in +the range map, it will be removed.

    +
    k
    syntax RangeMap ::= RangeMap "[" Range "<-" "undef" "]" [function, hook(RANGEMAP.removeRng), klabel(_r[_<-undef]), symbol] +
    +

    Range map difference

    +

    You can remove the range/value pairs in a RangeMap that are also present in +another RangeMap in O(max{M,N}*log(M)) time (where M is the size of the +first RangeMap and N is the size of the second RangeMap). Note that only +the parts of overlapping ranges whose value is the same in both range maps +will be removed.

    +
    k
    syntax RangeMap ::= RangeMap "-RangeMap" RangeMap [function, total, hook(RANGEMAP.difference), latex({#1}-_{\it RangeMap}{#2})] +
    +

    Multiple range map update

    +

    You can update a RangeMap by adding all the range/value pairs in the second +RangeMap in O(N*log(M+N)) time (where M is the size of the first RangeMap +and N is the size of the second RangeMap). If any ranges are overlapping, +the value from the second range map overwrites the value in the first for the +parts where ranges are overlapping. This function is total, which is distinct +from range map concatenation, a partial function only defined on range maps +with non overlapping ranges.

    +
    k
    syntax RangeMap ::= updateRangeMap(RangeMap, RangeMap) [function, total, hook(RANGEMAP.updateAll)] +
    +

    Multiple range map removal

    +

    You can remove a Set of ranges from a RangeMap in O(N*log(M)) time (where +M is the size of the RangeMap and N is the size of the Set). For every +range in the set, all or any part of it that is present in the range map will +be removed.

    +
    k
    syntax RangeMap ::= removeAll(RangeMap, Set) [function, hook(RANGEMAP.removeAll)] +
    +

    Range map keys (as Set)

    +

    You can get a Set of all the ranges in a RangeMap in O(N) time (where N +is the size of the RangeMap).

    +
    k
    syntax Set ::= keys(RangeMap) [function, total, hook(RANGEMAP.keys)] +
    +

    Range map keys (as List)

    +

    You can get a List of all the ranges in a RangeMap in O(N) time (where N +is the size of the RangeMap).

    +
    k
    syntax List ::= "keys_list" "(" RangeMap ")" [function, hook(RANGEMAP.keys_list)] +
    +

    Range map key membership

    +

    You can check whether a key is present in a RangeMap in O(log(N)) time (where +N is the size of the RangeMap).

    +
    k
    syntax Bool ::= KItem "in_keys" "(" RangeMap ")" [function, total, hook(RANGEMAP.in_keys)] +
    +

    Range map values (as List)

    +

    You can get a List of all values in a RangeMap in O(N) time (where N is the +size of the RangeMap).

    +
    k
    syntax List ::= values(RangeMap) [function, hook(RANGEMAP.values)] +
    +

    Range map size

    +

    You can get the number of range/value pairs in a RangeMap in O(1) time.

    +
    k
    syntax Int ::= size(RangeMap) [function, total, hook(RANGEMAP.size), klabel(sizeRangeMap)] +
    +

    Range map inclusion

    +

    You can determine whether a RangeMap is a strict subset of another RangeMap +in O(M+N) time (where M is the size of the first RangeMap and N is the size +of the second RangeMap). Only keys within equal or overlapping ranges that +are bound to the same value are considered equal.

    +
    k
    syntax Bool ::= RangeMap "<=RangeMap" RangeMap [function, total, hook(RANGEMAP.inclusion)] +
    +

    Range map choice

    +

    You can get an arbitrarily chosen key of a RangeMap in O(1) time. The same +key will always be returned for the same range map, but no guarantee is given +that two different range maps will return the same element, even if they are +similar.

    +
    k
    syntax KItem ::= choice(RangeMap) [function, hook(RANGEMAP.choice), klabel(RangeMap:choice)] +endmodule +
    +

    Sets

    +

    Provided here is the syntax of an implementation of immutable, associative, +commutative sets of KItem. This type is hooked to an implementation of sets +provided by the backend. For more information on matching on sets and allowable +patterns for doing so, refer to K's +user documentation.

    +
    k
    module SET + imports private INT-SYNTAX + imports private BASIC-K + + syntax Set [hook(SET.Set)] +
    +

    Set concatenation

    +

    The Set sort represents a mathematical set (A collection of unique items). +The sets are nilpotent, i.e., the concatenation of two sets containing elements +in common is #False (note however, this may be silently allowed during +concrete execution). If you intend to add an element to a set that might +already be present in the set, use the |Set operator instead.

    +

    The concatenation operator is O(Nlog(M)) where N is the size of the smaller +set, when it appears on the right hand side. When it appears on the left hand +side and all variables are bound, it is O(Nlog(M)) where M is the size of the +set it is matching and N is the number of elements being matched. When it +appears on the left hand side containing variables not bound elsewhere in the +term, it is O(N^K) where N is the size of the set it is matching and K is the +number of unbound keys being mached. In other words, one unbound variable is +linear, two is quadratic, three is cubic, etc.

    +
    k
    syntax Set ::= Set Set [left, function, hook(SET.concat), klabel(_Set_), symbol, assoc, comm, unit(.Set), idem, element(SetItem), format(%1%n%2)] +
    +

    Set unit

    +

    The set with zero elements is represented by .Set.

    +
    k
    syntax Set ::= ".Set" [function, total, hook(SET.unit), klabel(.Set), symbol, latex(\dotCt{Set})] +
    +

    Set elements

    +

    An element of a Set is constructed via the SetItem operator.

    +
    k
    syntax Set ::= SetItem(KItem) [function, total, hook(SET.element), klabel(SetItem), symbol, injective] +
    +

    Set union

    +

    You can compute the union of two sets in O(N*log(M)) time (Where N is the size +of the smaller set). Note that the base of the logarithm is a relatively high +number and thus the time is effectively linear. The union consists of all the +elements present in either set.

    +
    k
    syntax Set ::= Set "|Set" Set [left, function, total, hook(SET.union), comm] + rule S1:Set |Set S2:Set => S1 (S2 -Set S1) [concrete] +
    +

    Set intersection

    +

    You can compute the intersection of two sets in O(N*log(M)) time (where N +is the size of the smaller set), or effectively linear. The intersection +consists of all the elements present in both sets.

    +
    k
    syntax Set ::= intersectSet(Set, Set) [function, total, hook(SET.intersection), comm] +
    +

    Set complement

    +

    You can compute the relative complement of two sets in O(N*log(M)) time (where +N is the size of the second set), or effectively linear. This is the set of +elements in the first set that are not present in the second set.

    +
    k
    syntax Set ::= Set "-Set" Set [function, total, hook(SET.difference), latex({#1}-_{\it Set}{#2}), klabel(Set:difference), symbol] +
    +

    Set membership

    +

    You can compute whether an element is a member of a set in O(1) time.

    +
    k
    syntax Bool ::= KItem "in" Set [function, total, hook(SET.in), klabel(Set:in), symbol] +
    +

    Set inclusion

    +

    You can determine whether a Set is a strict subset of another Set in O(N) +time (where N is the size of the first set).

    +
    k
    syntax Bool ::= Set "<=Set" Set [function, total, hook(SET.inclusion)] +
    +

    Set size

    +

    You can get the number of elements (the cardinality) of a set in O(1) time.

    +
    k
    syntax Int ::= size(Set) [function, total, hook(SET.size)] +
    +

    Set choice

    +

    You can get an arbitrarily chosen element of a Set in O(1) time. The same +element will always be returned for the same set, but no guarantee is given +that two different sets will return the same element, even if they are similar.

    +
    k
    syntax KItem ::= choice(Set) [function, hook(SET.choice), klabel(Set:choice)] +
    +
    k
    endmodule +
    +

    Implementation of Sets

    +

    The following lemmas are simplifications that the Haskell backend can +apply to simplify expressions of sort Set.

    +
    k
    module SET-KORE-SYMBOLIC [kore,symbolic,haskell] + imports SET + imports private K-EQUAL + imports private BOOL + + //Temporarly rule for #Ceil simplification, should be generated in front-end + +// Matching for this version not implemented. + // rule #Ceil(@S1:Set @S2:Set) => + // {intersectSet(@S1, @S2) #Equals .Set} #And #Ceil(@S1) #And #Ceil(@S2) + // [simplification] + +//simpler version + rule #Ceil(@S:Set SetItem(@E:KItem)) => + {(@E in @S) #Equals false} #And #Ceil(@S) #And #Ceil(@E) + [simplification] + + // -Set simplifications + rule S -Set .Set => S [simplification] + rule .Set -Set _ => .Set [simplification] + rule SetItem(X) -Set (S SetItem(X)) => .Set + ensures notBool (X in S) [simplification] + rule S -Set (S SetItem(X)) => .Set + ensures notBool (X in S) [simplification] + rule (S SetItem(X)) -Set S => SetItem(X) + ensures notBool (X in S) [simplification] + rule (S SetItem(X)) -Set SetItem(X) => S + ensures notBool (X in S) [simplification] + // rule SetItem(X) -Set S => SetItem(X) + // requires notBool (X in S) [simplification] + // rule (S1 SetItem(X)) -Set (S2 SetItem(X)) => S1 -Set S2 + // ensures notBool (X in S1) + // andBool notBool (X in S2) [simplification] + + + + // |Set simplifications + rule S |Set .Set => S [simplification, comm] + rule S |Set S => S [simplification] + + rule (S SetItem(X)) |Set SetItem(X) => S SetItem(X) + ensures notBool (X in S) [simplification, comm] + // Currently disabled, see runtimeverification/haskell-backend#3301 + // rule (S SetItem(X)) |Set S => S SetItem(X) + // ensures notBool (X in S) [simplification, comm] + + // intersectSet simplifications + rule intersectSet(.Set, _ ) => .Set [simplification, comm] + rule intersectSet( S , S ) => S [simplification] + + rule intersectSet( S SetItem(X), SetItem(X)) => SetItem(X) + ensures notBool (X in S) [simplification, comm] + // Currently disabled, see runtimeverification/haskell-backend#3294 + // rule intersectSet( S SetItem(X) , S) => S ensures notBool (X in S) [simplification, comm] + rule intersectSet( S1 SetItem(X), S2 SetItem(X)) => intersectSet(S1, S2) SetItem(X) + ensures notBool (X in S1) + andBool notBool (X in S2) [simplification] + + // membership simplifications + rule _E in .Set => false [simplification] + rule E in (S SetItem(E)) => true + ensures notBool (E in S) [simplification] + +// These two rules would be sound but impose a giant overhead on `in` evaluation: + // rule E1 in (S SetItem(E2)) => true requires E1 in S + // ensures notBool (E2 in S) [simplification] + // rule E1 in (S SetItem(E2)) => E1 in S requires E1 =/=K E2 + // ensures notBool (E2 in S) [simplification] + + rule X in ((SetItem(X) S) |Set _ ) => true + ensures notBool (X in S) [simplification] + rule X in ( _ |Set (SetItem(X) S)) => true + ensures notBool (X in S) [simplification] + +endmodule + +module SET-SYMBOLIC + imports SET-KORE-SYMBOLIC +endmodule +
    +

    Lists

    +

    Provided here is the syntax of an implementation of immutable, associative +lists of KItem. This type is hooked to an implementation of lists provided +by the backend. For more information on matching on lists and allowable +patterns for doing so, refer to K's +user documentation.

    +
    k
    module LIST + imports private INT-SYNTAX + imports private BASIC-K + + syntax List [hook(LIST.List)] +
    +

    List concatenation

    +

    The List sort is an ordered collection that may contain duplicate elements. +They are backed by relaxed radix balanced trees, which means that they support +efficiently adding elements to both sides of the list, concatenating two lists, +indexing, and updating elements.

    +

    The concatenation operator is O(log(N)) (where N is the size of the longer +list) when it appears on the right hand side. When it appears on the left hand +side, it is O(N), where N is the number of elements matched on the front and +back of the list.

    +
    k
    syntax List ::= List List [left, function, total, hook(LIST.concat), klabel(_List_), symbol, smtlib(smt_seq_concat), assoc, unit(.List), element(ListItem), format(%1%n%2)] +
    +

    List unit

    +

    The list with zero elements is represented by .List.

    +
    k
    syntax List ::= ".List" [function, total, hook(LIST.unit), klabel(.List), symbol, smtlib(smt_seq_nil), latex(\dotCt{List})] +
    +

    List elements

    +

    An element of a List is constucted via the ListItem operator.

    +
    k
    syntax List ::= ListItem(KItem) [function, total, hook(LIST.element), klabel(ListItem), symbol, smtlib(smt_seq_elem)] +
    +

    List indexing

    +

    You can get an element of a list by its integer offset in O(log(N)) time, or +effectively constant. Positive indices are 0-indexed from the beginning of the +list, and negative indices are -1-indexed from the end of the list. In other +words, 0 is the first element and -1 is the last element.

    +
    k
    syntax KItem ::= List "[" Int "]" [function, hook(LIST.get), klabel(List:get), symbol] +
    +

    List update

    +

    You can create a new List with a new value at a particular index in +O(log(N)) time, or effectively constant.

    +
    k
    syntax List ::= List "[" index: Int "<-" value: KItem "]" [function, hook(LIST.update), klabel(List:set)] +
    +

    List of identical elements

    +

    You can create a list with length elements, each containing value, in O(N) +time.

    +
    k
    syntax List ::= makeList(length: Int, value: KItem) [function, hook(LIST.make)] +
    +

    Multiple list update

    +

    You can create a new List which is equal to dest except the N elements +starting at index are replaced with the contents of src in O(N*log(K)) time +(where K is the size of destand N is the size of src), or effectively linear. Having index + N > K yields an exception.

    +
    k
    syntax List ::= updateList(dest: List, index: Int, src: List) [function, hook(LIST.updateAll)] +
    +

    List fill

    +

    You can create a new List where the length elements starting at index +are replaced with value, in O(length*log(N)) time, or effectively linear.

    +
    k
    syntax List ::= fillList(List, index: Int, length: Int, value: KItem) [function, hook(LIST.fill)] +
    +

    List slicing

    +

    You can compute a new List by removing fromFront elements from the front +of the list and fromBack elements from the back of the list in +O((fromFront+fromBack)*log(N)) time, or effectively linear.

    +
    k
    syntax List ::= range(List, fromFront: Int, fromBack: Int) [function, hook(LIST.range), klabel(List:range), symbol] +
    +

    List membership

    +

    You can compute whether an element is in a list in O(N) time. For repeated +comparisons, it is much better to first convert to a set using List2Set.

    +
    k
    syntax Bool ::= KItem "in" List [function, total, hook(LIST.in), klabel(_inList_)] +
    +

    List size

    +

    You can get the number of elements of a list in O(1) time.

    +
    k
    syntax Int ::= size(List) [function, total, hook(LIST.size), klabel (sizeList), smtlib(smt_seq_len)] +
    +
    k
    endmodule +
    +

    Collection Conversions

    +

    It is possible to convert from a List to a Set or from a Set to a list. +Converting from a List to a Set and back will not provide the same list; +duplicates will have been removed and the list may be reordered. Converting +from a Set to a List and back will generate the same set.

    +

    Note that because sets are unordered and lists are ordered, converting from a +Set to a List will generate some arbitrary ordering of elements, which may +be different from the natural ordering you might assume, or may not. Two +equal sets are guaranteed to generate the same ordering, but no guarantee is +otherwise provided about what the ordering will be. In particular, adding an +element to a set may completely reorder the elements already in the set, when +it is converted to a list.

    +
    k
    module COLLECTIONS + imports LIST + imports SET + imports MAP + + syntax List ::= Set2List(Set) [function, total, hook(SET.set2list)] + syntax Set ::= List2Set(List) [function, total, hook(SET.list2set)] + +endmodule +
    +

    Booleans

    +

    Provided here is the syntax of an implementation of boolean algebra in K. +This type is hooked to an implementation of booleans provided by the backend. +Note that this algebra is different from the builtin truth in matching logic. +You can, however, convert from the truth of the Bool sort to the truth in +matching logic via the expression {B #Equals true}.

    +

    The boolean values are true and false.

    +
    k
    module SORT-BOOL + syntax Bool [hook(BOOL.Bool)] +endmodule + +module BOOL-SYNTAX + imports SORT-BOOL + syntax Bool ::= "true" [token] + syntax Bool ::= "false" [token] +endmodule + +module BOOL-COMMON + imports private BASIC-K + imports BOOL-SYNTAX +
    +

    Basic boolean arithmetic

    +

    You can:

    +
      +
    • Negate a boolean value.
    • +
    • AND two boolean values.
    • +
    • XOR two boolean values.
    • +
    • OR two boolean values.
    • +
    • IMPLIES two boolean values (i.e., P impliesBool Q is the same as +notBool P orBool Q)
    • +
    • Check equality of two boolean values.
    • +
    • Check inequality of two boolean values.
    • +
    +

    Note that only andThenBool and orElseBool are short-circuiting. andBool +and orBool may be short-circuited in concrete backends, but in symbolic +backends, both arguments will be evaluated.

    +
    k
    syntax Bool ::= "notBool" Bool [function, total, klabel(notBool_), symbol, smt-hook(not), group(boolOperation), latex(\neg_{\scriptstyle\it Bool}{#1}), hook(BOOL.not)] + > Bool "andBool" Bool [function, total, klabel(_andBool_), symbol, left, smt-hook(and), group(boolOperation), latex({#1}\wedge_{\scriptstyle\it Bool}{#2}), hook(BOOL.and)] + | Bool "andThenBool" Bool [function, total, klabel(_andThenBool_), symbol, left, smt-hook(and), group(boolOperation), hook(BOOL.andThen)] + | Bool "xorBool" Bool [function, total, klabel(_xorBool_), symbol, left, smt-hook(xor), group(boolOperation), hook(BOOL.xor)] + | Bool "orBool" Bool [function, total, klabel(_orBool_), symbol, left, smt-hook(or), group(boolOperation), latex({#1}\vee_{\scriptstyle\it Bool}{#2}), hook(BOOL.or)] + | Bool "orElseBool" Bool [function, total, klabel(_orElseBool_), symbol, left, smt-hook(or), group(boolOperation), hook(BOOL.orElse)] + | Bool "impliesBool" Bool [function, total, klabel(_impliesBool_), symbol, left, smt-hook(=>), group(boolOperation), hook(BOOL.implies)] + > left: + Bool "==Bool" Bool [function, total, klabel(_==Bool_), symbol, left, comm, smt-hook(=), hook(BOOL.eq)] + | Bool "=/=Bool" Bool [function, total, klabel(_=/=Bool_), symbol, left, comm, smt-hook(distinct), hook(BOOL.ne)] +
    +

    Implementation of Booleans

    +

    The remainder of this section consists of an implementation in K of the +operations listed above.

    +
    k
    rule notBool true => false + rule notBool false => true + + rule true andBool B:Bool => B:Bool + rule B:Bool andBool true => B:Bool [simplification] + rule false andBool _:Bool => false + rule _:Bool andBool false => false [simplification] + + rule true andThenBool K::Bool => K + rule K::Bool andThenBool true => K [simplification] + rule false andThenBool _ => false + rule _ andThenBool false => false [simplification] + + rule false xorBool B:Bool => B:Bool + rule B:Bool xorBool false => B:Bool [simplification] + rule B:Bool xorBool B:Bool => false + + rule true orBool _:Bool => true + rule _:Bool orBool true => true [simplification] + rule false orBool B:Bool => B + rule B:Bool orBool false => B [simplification] + + rule true orElseBool _ => true + rule _ orElseBool true => true [simplification] + rule false orElseBool K::Bool => K + rule K::Bool orElseBool false => K [simplification] + + rule true impliesBool B:Bool => B + rule false impliesBool _:Bool => true + rule _:Bool impliesBool true => true [simplification] + rule B:Bool impliesBool false => notBool B [simplification] + + rule B1:Bool =/=Bool B2:Bool => notBool (B1 ==Bool B2) +endmodule + +module BOOL-KORE [kore, symbolic] + imports BOOL-COMMON + + rule {true #Equals notBool @B} => {false #Equals @B} [simplification] + rule {notBool @B #Equals true} => {@B #Equals false} [simplification] + rule {false #Equals notBool @B} => {true #Equals @B} [simplification] + rule {notBool @B #Equals false} => {@B #Equals true} [simplification] + + rule {true #Equals @B1 andBool @B2} => {true #Equals @B1} #And {true #Equals @B2} [simplification] + rule {@B1 andBool @B2 #Equals true} => {@B1 #Equals true} #And {@B2 #Equals true} [simplification] + rule {false #Equals @B1 orBool @B2} => {false #Equals @B1} #And {false #Equals @B2} [simplification] + rule {@B1 orBool @B2 #Equals false} => {@B1 #Equals false} #And {@B2 #Equals false} [simplification] +endmodule + +module BOOL + imports BOOL-COMMON + imports BOOL-KORE +endmodule +
    +

    Integers

    +

    Provided here is the syntax of an implementation of arbitrary-precision +integer arithmetic in K. This type is hooked to an implementation of integers +provided by the backend. For a fixed-width integer type, see the MINT module +below.

    +

    The UNSIGNED-INT-SYNTAX module provides a syntax of whole numbers in K. +This is useful because often programming languages implement the sign of an +integer as a unary operator rather than part of the lexical syntax of integers. +However, you can also directly reference integers with a sign using the +INT-SYNTAX module.

    +
    k
    module UNSIGNED-INT-SYNTAX + syntax Int [hook(INT.Int)] + syntax Int ::= r"[0-9]+" [prefer, token, prec(2)] +endmodule + +module INT-SYNTAX + imports UNSIGNED-INT-SYNTAX + syntax Int ::= r"[\\+-]?[0-9]+" [prefer, token, prec(2)] +endmodule + +module INT-COMMON + imports INT-SYNTAX + imports private BOOL +
    +

    Integer arithmetic

    +

    You can:

    +
      +
    • Compute the bitwise complement ~Int of an integer value in twos-complement.
    • +
    • Compute the exponentiation ^Int of two integers.
    • +
    • Compute the exponentiation of two integers modulo another integer (^%Int). +A ^%Int B C is equal in value to (A ^Int B) %Int C, but has a better +asymptotic complexity.
    • +
    • Compute the product *Int of two integers.
    • +
    • Compute the quotient /Int or modulus %Int of two integers using +t-division, which rounds towards zero. Division by zero is #False.
    • +
    • Compute the quotient divInt or modulus modInt of two integers using +Euclidean division, in which the remainder is always non-negative. Division +by zero is #False.
    • +
    • Compute the sum +Int or difference -Int of two integers.
    • +
    • Compute the arithmetic right shift >>Int of two integers. Shifting by a +negative quantity is #False.
    • +
    • Compute the left shift of two integers. Shifting by a negative quantity is +#False.
    • +
    • Compute the bitwise and of two integers in twos-complement.
    • +
    • Compute the bitwise xor of two integers in twos-complement.
    • +
    • Compute the bitwise inclusive-or of two integers in twos-complement.
    • +
    +
    k
    syntax Int ::= "~Int" Int [function, klabel(~Int_), symbol, total, latex(\mathop{\sim_{\scriptstyle\it Int}}{#1}), hook(INT.not), smtlib(notInt)] + > left: + Int "^Int" Int [function, klabel(_^Int_), symbol, left, smt-hook(^), latex({#1}\mathrel{{\char`\^}_{\!\scriptstyle\it Int}}{#2}), hook(INT.pow)] + | Int "^%Int" Int Int [function, klabel(_^%Int__), symbol, left, smt-hook((mod (^ #1 #2) #3)), hook(INT.powmod)] + > left: + Int "*Int" Int [function, total, klabel(_*Int_), symbol, left, comm, smt-hook(*), latex({#1}\mathrel{\ast_{\scriptstyle\it Int}}{#2}), hook(INT.mul)] + /* FIXME: translate /Int and %Int into smtlib */ + /* /Int and %Int implement t-division, which rounds towards 0 */ + | Int "/Int" Int [function, klabel(_/Int_), symbol, left, smt-hook(div), latex({#1}\mathrel{\div_{\scriptstyle\it Int}}{#2}), hook(INT.tdiv)] + | Int "%Int" Int [function, klabel(_%Int_), symbol, left, smt-hook(mod), latex({#1}\mathrel{\%_{\scriptstyle\it Int}}{#2}), hook(INT.tmod)] + /* divInt and modInt implement e-division according to the Euclidean division theorem, therefore the remainder is always positive */ + | Int "divInt" Int [function, klabel(_divInt_), symbol, left, smt-hook(div), hook(INT.ediv)] + | Int "modInt" Int [function, klabel(_modInt_), symbol, left, smt-hook(mod), hook(INT.emod)] + > left: + Int "+Int" Int [function, total, klabel(_+Int_), symbol, left, comm, smt-hook(+), latex({#1}\mathrel{+_{\scriptstyle\it Int}}{#2}), hook(INT.add)] + | Int "-Int" Int [function, total, klabel(_-Int_), symbol, left, smt-hook(-), latex({#1}\mathrel{-_{\scriptstyle\it Int}}{#2}), hook(INT.sub)] + > left: + Int ">>Int" Int [function, klabel(_>>Int_), symbol, left, latex({#1}\mathrel{\gg_{\scriptstyle\it Int}}{#2}), hook(INT.shr), smtlib(shrInt)] + | Int "<<Int" Int [function, klabel(_<<Int_), symbol, left, latex({#1}\mathrel{\ll_{\scriptstyle\it Int}}{#2}), hook(INT.shl), smtlib(shlInt)] + > left: + Int "&Int" Int [function, total, klabel(_&Int_), symbol, left, comm, latex({#1}\mathrel{\&_{\scriptstyle\it Int}}{#2}), hook(INT.and), smtlib(andInt)] + > left: + Int "xorInt" Int [function, total, klabel(_xorInt_), symbol, left, comm, latex({#1}\mathrel{\oplus_{\scriptstyle\it Int}}{#2}), hook(INT.xor), smtlib(xorInt)] + > left: + Int "|Int" Int [function, total, klabel(_|Int_), symbol, left, comm, latex({#1}\mathrel{|_{\scriptstyle\it Int}}{#2}), hook(INT.or), smtlib(orInt)] +
    +

    Integer minimum and maximum

    +

    You can compute the minimum and maximum minInt and maxInt of two integers.

    +
    k
    syntax Int ::= "minInt" "(" Int "," Int ")" [function, total, smt-hook((ite (< #1 #2) #1 #2)), hook(INT.min)] + | "maxInt" "(" Int "," Int ")" [function, total, smt-hook((ite (< #1 #2) #2 #1)), hook(INT.max)] +
    +

    Absolute value

    +

    You can compute the absolute value absInt of an integer.

    +
    k
    syntax Int ::= absInt ( Int ) [function, total, smt-hook((ite (< #1 0) (- 0 #1) #1)), hook(INT.abs)] +
    +

    Log base 2

    +

    You can compute the log base 2, rounded towards zero, of an integer. The log +base 2 of an integer is equal to the index of the highest bit set in the +representation of a positive integer. Log base 2 of zero or a negative number +is #False.

    +
    k
    syntax Int ::= log2Int ( Int ) [function, hook(INT.log2)] +
    +

    Bit slicing

    +

    You can compute the value of a range of bits in the twos-complement +representation of an integer, as interpeted either unsigned or signed, of an +integer. index is offset from 0 and length is the number of bits, starting +with index, that should be read. The number is assumed to be represented +in little endian notation with each byte going from least significant to +most significant. In other words, 0 is the least-significant bit, and each +successive bit is more significant than the last.

    +
    k
    syntax Int ::= bitRangeInt ( Int, index: Int, length: Int ) [function, hook(INT.bitRange)] + | signExtendBitRangeInt ( Int, index: Int, length: Int ) [function, hook(INT.signExtendBitRange)] +
    +

    Integer comparisons

    +

    You can compute whether two integers are less than or equal to, less than, +greater than or equal to, greater than, equal, or unequal to another integer.

    +
    k
    syntax Bool ::= Int "<=Int" Int [function, total, klabel(_<=Int_), symbol, smt-hook(<=), latex({#1}\mathrel{\leq_{\scriptstyle\it Int}}{#2}), hook(INT.le)] + | Int "<Int" Int [function, total, klabel(_<Int_), symbol, smt-hook(<), latex({#1}\mathrel{<_{\scriptstyle\it Int}}{#2}), hook(INT.lt)] + | Int ">=Int" Int [function, total, klabel(_>=Int_), symbol, smt-hook(>=), latex({#1}\mathrel{\geq_{\scriptstyle\it Int}}{#2}), hook(INT.ge)] + | Int ">Int" Int [function, total, klabel(_>Int_), symbol, smt-hook(>), latex({#1}\mathrel{>_{\scriptstyle\it Int}}{#2}), hook(INT.gt)] + | Int "==Int" Int [function, total, klabel(_==Int_), symbol, comm, smt-hook(=), latex({#1}\mathrel{{=}{=}_{\scriptstyle\it Int}}{#2}), hook(INT.eq)] + | Int "=/=Int" Int [function, total, klabel(_=/=Int_), symbol, comm, smt-hook(distinct), latex({#1}\mathrel{{=}{/}{=}_{\scriptstyle\it Int}}{#2}), hook(INT.ne)] +
    +

    Divides

    +

    You can compute whether one integer evenly divides another. This is the +case when the second integer modulo the first integer is equal to zero.

    +
    k
    syntax Bool ::= Int "dividesInt" Int [function] +
    +

    Random integers

    +

    You can, on concrete backends, compute a pseudorandom integer, or seed the +pseudorandom number generator. These operations are represented as +uninterpreted functions on symbolic backends.

    +
    k
    syntax Int ::= randInt(Int) [function, hook(INT.rand), impure] + syntax K ::= srandInt(Int) [function, hook(INT.srand), impure] +
    +

    Implementation of Integers

    +

    The remainder of this section consists of an implementation in K of some +of the operators above, as well as lemmas used by the Java and Haskell backend +to simplify expressions of sort Int. They do not affect the semantics of +integers, merely describing additional rules that the backend can use to +simplify terms.

    +
    k
    endmodule + +module INT-SYMBOLIC [symbolic] + imports INT-COMMON + imports INT-SYMBOLIC-KORE + imports private BOOL + + // Arithmetic Normalization + rule I +Int 0 => I [simplification] + rule I -Int 0 => I [simplification] + + rule X modInt N => X requires 0 <=Int X andBool X <Int N [simplification] + rule X %Int N => X requires 0 <=Int X andBool X <Int N [simplification] + + // Bit-shifts + rule X <<Int 0 => X [simplification] + rule 0 <<Int _ => 0 [simplification] + rule X >>Int 0 => X [simplification] + rule 0 >>Int _ => 0 [simplification] +endmodule + +module INT-SYMBOLIC-KORE [symbolic, kore, haskell] + imports INT-COMMON + imports ML-SYNTAX + imports private BOOL + + // Definability Conditions + rule #Ceil(@I1:Int /Int @I2:Int) => {(@I2 =/=Int 0) #Equals true} #And #Ceil(@I1) #And #Ceil(@I2) [simplification] + rule #Ceil(@I1:Int %Int @I2:Int) => {(@I2 =/=Int 0) #Equals true} #And #Ceil(@I1) #And #Ceil(@I2) [simplification] + rule #Ceil(@I1:Int modInt @I2:Int) => {(@I2 =/=Int 0) #Equals true} #And #Ceil(@I1) #And #Ceil(@I2) [simplification] + rule #Ceil(@I1:Int >>Int @I2:Int) => {(@I2 >=Int 0) #Equals true} #And #Ceil(@I1) #And #Ceil(@I2) [simplification] + rule #Ceil(@I1:Int <<Int @I2:Int) => {(@I2 >=Int 0) #Equals true} #And #Ceil(@I1) #And #Ceil(@I2) [simplification] +endmodule + +module INT-KORE [kore, symbolic] + imports private K-EQUAL + imports private BOOL + imports INT-COMMON + + rule I1:Int ==K I2:Int => I1 ==Int I2 [simplification] + rule {K1 ==Int K2 #Equals true} => {K1 #Equals K2} [simplification] + rule {true #Equals K1 ==Int K2} => {K1 #Equals K2} [simplification] + rule {K1 ==Int K2 #Equals false} => #Not({K1 #Equals K2}) [simplification] + rule {false #Equals K1 ==Int K2} => #Not({K1 #Equals K2}) [simplification] + rule {K1 =/=Int K2 #Equals true} => #Not({K1 #Equals K2}) [simplification] + rule {true #Equals K1 =/=Int K2} => #Not({K1 #Equals K2}) [simplification] + rule {K1 =/=Int K2 #Equals false} => {K1 #Equals K2} [simplification] + rule {false #Equals K1 =/=Int K2} => {K1 #Equals K2} [simplification] + + // Arithmetic Normalization + rule I +Int B => B +Int I [concrete(I), symbolic(B), simplification(51)] + rule A -Int I => A +Int (0 -Int I) [concrete(I), symbolic(A), simplification(51)] + + rule (A +Int I2) +Int I3 => A +Int (I2 +Int I3) [concrete(I2, I3), symbolic(A), simplification] + rule I1 +Int (B +Int I3) => B +Int (I1 +Int I3) [concrete(I1, I3), symbolic(B), simplification] + rule I1 -Int (B +Int I3) => (I1 -Int I3) -Int B [concrete(I1, I3), symbolic(B), simplification] + rule I1 +Int (I2 +Int C) => (I1 +Int I2) +Int C [concrete(I1, I2), symbolic(C), simplification] + rule I1 +Int (I2 -Int C) => (I1 +Int I2) -Int C [concrete(I1, I2), symbolic(C), simplification] + rule (I1 -Int B) +Int I3 => (I1 +Int I3) -Int B [concrete(I1, I3), symbolic(B), simplification] + rule I1 -Int (I2 +Int C) => (I1 -Int I2) -Int C [concrete(I1, I2), symbolic(C), simplification] + rule I1 -Int (I2 -Int C) => (I1 -Int I2) +Int C [concrete(I1, I2), symbolic(C), simplification] + rule (C -Int I2) -Int I3 => C -Int (I2 +Int I3) [concrete(I2, I3), symbolic(C), simplification] + + rule I1 &Int (I2 &Int C) => (I1 &Int I2) &Int C [concrete(I1, I2), symbolic(C), simplification] +endmodule + +module INT + imports INT-COMMON + imports INT-SYMBOLIC + imports INT-KORE + imports private K-EQUAL + imports private BOOL + + rule bitRangeInt(I::Int, IDX::Int, LEN::Int) => (I >>Int IDX) modInt (1 <<Int LEN) + + rule signExtendBitRangeInt(I::Int, IDX::Int, LEN::Int) => (bitRangeInt(I, IDX, LEN) +Int (1 <<Int (LEN -Int 1))) modInt (1 <<Int LEN) -Int (1 <<Int (LEN -Int 1)) + + rule I1:Int divInt I2:Int => (I1 -Int (I1 modInt I2)) /Int I2 + requires I2 =/=Int 0 + rule + I1:Int modInt I2:Int + => + ((I1 %Int absInt(I2)) +Int absInt(I2)) %Int absInt(I2) + requires I2 =/=Int 0 [concrete, simplification] + + rule minInt(I1:Int, I2:Int) => I1 requires I1 <=Int I2 + rule minInt(I1:Int, I2:Int) => I2 requires I1 >=Int I2 + + rule I1:Int =/=Int I2:Int => notBool (I1 ==Int I2) + rule (I1:Int dividesInt I2:Int) => (I2 %Int I1) ==Int 0 + + syntax Int ::= freshInt(Int) [freshGenerator, function, total, private] + rule freshInt(I:Int) => I +endmodule +
    +

    IEEE 754 Floating-point Numbers

    +

    Provided here is the syntax of an implementation of arbitrary-precision +floating-point arithmetic in K based on a generalization of the IEEE 754 +standard. This type is hooked to an implementation of floats provided by the +backend.

    +

    The syntax of ordinary floating-point values in K consists of an optional sign +(+ or -) followed by an optional integer part, followed by a decimal point, +followed by an optional fractional part. Either the integer part or the +fractional part must be specified. The mantissa is followed by an optional +exponent part, which consists of an e or E, an optional sign (+ or -), +and an integer. The expoennt is followed by an optional suffix, which can be +either f, F, d, D, or pNxM where N and M are positive integers. +p and x can be either upper or lowercase.

    +

    The value of a floating-point literal is computed as follows: First the +mantissa is read as a rational number. Then it is multiplied by 10 to the +power of the exponent, which is interpreted as an integer, and defaults to +zero if it is not present. Finally, it is rounded to the nearest possible +value in a floating-point type represented like an IEEE754 floating-point type, +with the number of bits of precision and exponent specified by the suffix. +A suffix of f or f represents the IEEE binary32 format. A suffix of d +or D, or no suffix, represents the IEEE binary64 format. A suffix of +pNxM (either upper or lowercase) specifies exactly N bits of precision and +M bits of exponent. The number of bits of precision is assumed to include +any optional 1 that precedes the IEEE 754 mantissa. In other words, p24x8 +is equal to the IEEE binary32 format, and p53x11 is equal to the IEEE +binary64 format.

    +
    k
    module FLOAT-SYNTAX + syntax Float [hook(FLOAT.Float)] + syntax Float ::= r"([\\+-]?[0-9]+(\\.[0-9]*)?|\\.[0-9]+)([eE][\\+-]?[0-9]+)?([fFdD]|([pP][0-9]+[xX][0-9]+))?" [token, prec(1)] + syntax Float ::= r"[\\+-]?Infinity([fFdD]|([pP][0-9]+[xX][0-9]+))?" [token, prec(3)] + syntax Float ::= r"NaN([fFdD]|([pP][0-9]+[xX][0-9]+))?" [token, prec(3)] +endmodule + +module FLOAT + imports FLOAT-SYNTAX + imports private BOOL + imports private INT-SYNTAX +
    +

    Float precision

    +

    You can retrieve the number of bits of precision in a Float.

    +
    k
    syntax Int ::= precisionFloat(Float) [function, total, hook(FLOAT.precision)] +
    +

    Float exponent bits

    +

    You can retrieve the number of bits of exponent range in a Float.

    +
    k
    syntax Int ::= exponentBitsFloat(Float) [function, total, hook(FLOAT.exponentBits)] +
    +

    Float exponent

    +

    You can retrieve the value of the exponent bits of a Float as an integer.

    +
    k
    syntax Int ::= exponentFloat(Float) [function, total, hook(FLOAT.exponent)] +
    +

    Float sign

    +

    You can retrieve the value of the sign bit of a Float as a boolean. True +means the sign bit is set.

    +
    k
    syntax Bool ::= signFloat(Float) [function, total, hook(FLOAT.sign)] +
    +

    Float special values

    +

    You can check whether a Float value is infinite or Not-a-Number.

    +
    k
    syntax Bool ::= isNaN(Float) [function, total, smt-hook(fp.isNaN), hook(FLOAT.isNaN)] + | isInfinite(Float) [function, total] +
    +

    Float arithmetic

    +

    You can:

    +
      +
    • Compute the unary negation --Float of a float. --Float X is distinct +from 0.0 -Float X. For example, 0.0 -Float 0.0 is positive zero. +--Float 0.0 is negative zero.
    • +
    • Compute the exponentation ^Float of two floats.
    • +
    • Compute the product *Float, quotient /Float, or remainder %Float of two +floats. The remainder is computed based on rounding the quotient of the two +floats to the nearest integer.
    • +
    • Compute the sum +Float or difference -Float of two floats.
    • +
    +
    k
    syntax Float ::= "--Float" Float [function, total, smt-hook(fp.neg), hook(FLOAT.neg)] + > Float "^Float" Float [function, left, latex({#1}^{#2}), hook(FLOAT.pow)] + > left: + Float "*Float" Float [function, left, smt-hook((fp.mul roundNearestTiesToEven #1 #2)), latex({#1}\mathrel{\ast_{\scriptstyle\it Float}}{#2}), hook(FLOAT.mul)] + | Float "/Float" Float [function, left, smt-hook((fp.div roundNearestTiesToEven #1 #2)), latex({#1}\mathrel{\div_{\scriptstyle\it Float}}{#2}), hook(FLOAT.div)] + | Float "%Float" Float [function, left, smt-hook((fp.rem roundNearestTiesToEven #1 #2)), latex({#1}\mathrel{\%_{\scriptstyle\it Float}}{#2}), hook(FLOAT.rem)] + > left: + Float "+Float" Float [function, left, smt-hook((fp.add roundNearestTiesToEven #1 #2)), latex({#1}\mathrel{+_{\scriptstyle\it Float}}{#2}), hook(FLOAT.add)] + | Float "-Float" Float [function, left, smt-hook((fp.sub roundNearestTiesToEven #1 #2)), latex({#1}\mathrel{-_{\scriptstyle\it Float}}{#2}), hook(FLOAT.sub)] +
    +

    Floating-point mathematics

    +

    You can:

    +
      +
    • Compute the Nth integer root rootFloat of a float.
    • +
    • Compute the absolute value absFloat of a float.
    • +
    • Round a floating-point number to a specified precision and exponent +range (roundFloat). The resulting Float will yield the specified values +when calling precisionFloat and exponentBitsFloat and when performing +further computation.
    • +
    • Round a float to the next lowest floating-point value which is an integer +(floorFloat).
    • +
    • Round a float to the next highest floating-point value which is an integer +(ceilFloat).
    • +
    • Round a float to the next closest floating-point value which is an integer, in +the direction of zero (truncFloat).
    • +
    • Compute the natural exponential expFloat of a float (i.e. e^x).
    • +
    • Compute the natural logarithm logFloat of a float.
    • +
    • Compute the sine sinFloat of a float.
    • +
    • Compute the cosine cosFloat of a float.
    • +
    • Compute the tangent tanFlooat of a float.
    • +
    • Compute the arcsine asinFloat of a float.
    • +
    • Compute the arccosine acosFloat of a float.
    • +
    • Compute the arctangent atanFloat of a float.
    • +
    • Compute the arctangent atan2Float of two floats.
    • +
    • Compute the maximum maxFloat of two floats.
    • +
    • Compute the minimum minFloat of two floats.
    • +
    • Compute the square root sqrtFloat of a float.
    • +
    • Compute the largest finite value expressible in a specified precision and +exponent range (maxValueFloat).
    • +
    • Compute the smallest positive finite value expressible in a specified +precision and exponent range (minValueFloat).
    • +
    +
    k
    syntax Float ::= rootFloat(Float, Int) [function, hook(FLOAT.root)] + | absFloat(Float) [function, total, smt-hook(fp.abs), hook(FLOAT.abs)] + | roundFloat(Float, precision: Int, exponentBits: Int) [function, hook(FLOAT.round)] + | floorFloat(Float) [function, total, hook(FLOAT.floor)] + | ceilFloat(Float) [function, total, hook(FLOAT.ceil)] + | truncFloat(Float) [function, total, hook(FLOAT.trunc)] + | expFloat(Float) [function, total, hook(FLOAT.exp)] + | logFloat(Float) [function, hook(FLOAT.log)] + | sinFloat(Float) [function, total, hook(FLOAT.sin)] + | cosFloat(Float) [function, total, hook(FLOAT.cos)] + | tanFloat(Float) [function, hook(FLOAT.tan)] + | asinFloat(Float) [function, hook(FLOAT.asin)] + | acosFloat(Float) [function, hook(FLOAT.acos)] + | atanFloat(Float) [function, total, hook(FLOAT.atan)] + | atan2Float(Float, Float) [function, hook(FLOAT.atan2)] + | maxFloat(Float, Float) [function, smt-hook(fp.max), hook(FLOAT.max)] + | minFloat(Float, Float) [function, smt-hook(fp.min), hook(FLOAT.min)] + | sqrtFloat(Float) [function] + | maxValueFloat(precision: Int, exponentBits: Int) [function, hook(FLOAT.maxValue)] + | minValueFloat(precision: Int, exponentBits: Int) [function, hook(FLOAT.minValue)] +
    +

    Floating-point comparisons

    +

    Compute whether a float is less than or equasl to, less than, greater than or +equal to, greater than, equal, or unequal to another float. Note that +X ==Float Y and X ==K Y might yield different values. The latter should be +used in cases where you want to compare whether two values of sort Float +contain the same term. The former should be used when you want to implement +the == operator of a programming language. In particular, NaN =/=Float NaN +is true, because NaN compares unequal to all values, including itself, in +IEEE 754 arithmetic. 0.0 ==Float -0.0 is also true.

    +
    k
    syntax Bool ::= Float "<=Float" Float [function, smt-hook(fp.leq), latex({#1}\mathrel{\leq_{\scriptstyle\it Float}}{#2}), hook(FLOAT.le)] + | Float "<Float" Float [function, smt-hook(fp.lt), latex({#1}\mathrel{<_{\scriptstyle\it Float}}{#2}), hook(FLOAT.lt)] + | Float ">=Float" Float [function, smt-hook(fp.geq), latex({#1}\mathrel{\geq_{\scriptstyle\it Float}}{#2}), hook(FLOAT.ge)] + | Float ">Float" Float [function, smt-hook(fg.gt), latex({#1}\mathrel{>_{\scriptstyle\it Float}}{#2}), hook(FLOAT.gt)] + | Float "==Float" Float [function, comm, smt-hook(fp.eq), latex({#1}\mathrel{==_{\scriptstyle\it Float}}{#2}), hook(FLOAT.eq), klabel(_==Float_)] + | Float "=/=Float" Float [function, comm, smt-hook((not (fp.eq #1 #2))), latex({#1}\mathrel{\neq_{\scriptstyle\it Float}}{#2})] + + rule F1:Float =/=Float F2:Float => notBool (F1 ==Float F2) +
    +

    Conversion between integer and float

    +

    You can convert an integer to a floating-point number with the specified +precision and exponent range. You can also convert a floating-point number +to the nearest integer. This operation rounds to the nearest integer, but it +also avoids the double-rounding that is present in ceilFloat and floorFloat +if the nearest integer is not representable in the specified floating-point +type.

    +
    k
    syntax Float ::= Int2Float(Int, precision: Int, exponentBits: Int) [function, latex({\\it{}Int2Float}), hook(FLOAT.int2float)] + syntax Int ::= Float2Int(Float) [function, total, latex({\\it{}Float2Int}), hook(FLOAT.float2int)] +
    +

    Implementation of Floats

    +

    The remainder of this section consists of an implementation in K of some of the +operators above.

    +
    k
    rule sqrtFloat(F:Float) => rootFloat(F, 2) + + rule isInfinite(F:Float) => F >Float maxValueFloat(precisionFloat(F), exponentBitsFloat(F)) orBool F <Float --Float maxValueFloat(precisionFloat(F), exponentBitsFloat(F)) + +endmodule +
    +

    Strings

    +

    Provided here is the syntax of an implementation of Unicode strings in K. This +type is hooked to an implementation of strings provided by the backend. The +implementation is currently incomplete and does not fully support encodings +and code points beyond the initial 256 code points of the Basic Latin and +Latin-1 Supplement blocks. In the future, there may be breaking changes to +the semantics of this module in order to support this functionality.

    +

    The syntax of strings in K is delineated by double quotes. Inside the double +quotes, any character can appear verbatim except double quotes, backslash, +newline, and carriage return. K also supports the following escape sequences:

    +
      +
    • " - the " character
    • +
    • \ - the \ character
    • +
    • \n - newline character
    • +
    • \r - carriage return character
    • +
    • \t - tab character
    • +
    • \f - form feed character
    • +
    • \xFF - \x followed by two hexadecimal characters indicates a code point +between 0x00 and 0xff
    • +
    • \uFFFF - \u followed by four hexadecimal characters indicates a code point +between 0x0000 and 0xffff
    • +
    • \UFFFFFFFF - \U followed by eight hexadecimal characters indicates a code +point between 0x000000 and 0x10ffff
    • +
    +
    k
    module STRING-SYNTAX + syntax String [hook(STRING.String)] + syntax String ::= r"[\\\"](([^\\\"\\n\\r\\\\])|([\\\\][nrtf\\\"\\\\])|([\\\\][x][0-9a-fA-F]{2})|([\\\\][u][0-9a-fA-F]{4})|([\\\\][U][0-9a-fA-F]{8}))*[\\\"]" [token] +endmodule + +module STRING-COMMON + imports STRING-SYNTAX + imports private INT + imports private FLOAT-SYNTAX + imports private K-EQUAL + imports private BOOL +
    +

    String concatenation

    +

    You can concatenate two strings in O(N) time. For successive concatenation +operations, it may be better to use the STRING-BUFFER module.

    +
    k
    syntax String ::= String "+String" String [function, total, left, latex({#1}+_{\scriptstyle\it String}{#2}), hook(STRING.concat)] +
    +

    String length

    +

    You can get the length of a string in O(1) time.

    +
    k
    syntax Int ::= lengthString ( String ) [function, total, hook(STRING.length)] +
    +

    Character and integer conversion

    +

    You can convert between a character (as represented by a string containing +a single code point) and an integer in O(1) time.

    +
    k
    syntax String ::= chrChar ( Int ) [function, hook(STRING.chr)] + syntax Int ::= ordChar ( String ) [function, hook(STRING.ord)] +
    +

    String substring

    +

    You can compute a substring of a string in O(N) time (where N is the +length of the substring). There are two important facts to note:

    +
      +
    1. the range generated includes the character at startIndex but excludes the +character at endIndex, i.e., the range is [startIndex..endIndex).
    2. +
    3. this function is only defined on valid indices (i.e., it is defined when +startIndex < endIndex and endIndex is less than or equal to the string +length).
    4. +
    +
    k
    syntax String ::= substrString ( String , startIndex: Int , endIndex: Int ) [function, total, hook(STRING.substr)] +
    + +

    You can find the first (respectively, last) occurrence of a substring, starting +at a certain index, in another string in O(N*M) time. +Returns -1 if the substring is not found.

    +
    k
    syntax Int ::= findString ( haystack: String , needle: String , index: Int ) [function, hook(STRING.find)] + syntax Int ::= rfindString ( haystack: String , needle: String , index: Int ) [function, hook(STRING.rfind)] +
    + +

    You can find the first (respectively, last) occurrence of one of the characters +of the search string, starting at a certain index, in another string in +O(N*M) time.

    +
    k
    syntax Int ::= findChar ( haystack: String , needles: String , index: Int ) [function, hook(STRING.findChar)] + syntax Int ::= rfindChar ( haystack: String , needles: String , index: Int ) [function, hook(STRING.rfindChar)] +
    +

    String and Bool conversion

    +
    k
    syntax String ::= Bool2String(Bool) [function, total] + rule Bool2String(true) => "true" + rule Bool2String(false) => "false" +
    +
    k
    syntax Bool ::= String2Bool(String) [function] + rule String2Bool("true") => true + rule String2Bool("false") => false +
    +

    String and float conversion

    +

    You can convert between a String and a Float. The String will be +represented in the syntax of the Float sort (see the section on the FLOAT +module above for details of that syntax). Which particular string is returned +by Float2String is determined by the backend, but the same Float is +guaranteed to return the same String, and converting that String back to a +Float is guaranteed to return the original Float.

    +

    You can also convert a Float to a string in a particular syntax using the +variant of Float2String with a format. In this case, the resulting string +is one which results directly from passing that format to mpfr_printf. This +functionality may not be supported on backends that do not use Gnu MPFR to +implement floating-point numbers.

    +
    k
    syntax String ::= Float2String ( Float ) [function, total, hook(STRING.float2string)] + syntax String ::= Float2String ( Float , format: String ) [function, klabel(FloatFormat), hook(STRING.floatFormat)] + syntax Float ::= String2Float ( String ) [function, hook(STRING.string2float)] +
    +

    String and integer conversions

    +

    You can convert between a String and an Int. The String will be represented +in the syntax of the INT module (i.e., a nonempty sequence of digits +optionally prefixed by a sign). When converting from an Int to a String, +the sign will not be present unless the integer is negative.

    +

    You can also convert between a String and an Int in a particular radix. +This radix can be anywhere between 2 and 36. For a radix 2 <= N <= 10, the +digits 0 to N-1 will be used. For a radix 11 <= N <= 36, the digits 0 to 9 +and the first N-10 letters of the Latin alphabet will be used. Both uppercase +and lowercase letters are supported by String2Base. Whether the letters +returned by Base2String are upper or lowercase is determined by the backend, +but the backend will consistently choose one or the other.

    +
    k
    syntax Int ::= String2Int ( String ) [function, hook(STRING.string2int)] + syntax String ::= Int2String ( Int ) [function, total, hook(STRING.int2string)] + syntax String ::= Base2String ( Int , base: Int ) [function, hook(STRING.base2string)] + syntax Int ::= String2Base ( String , base: Int ) [function, hook(STRING.string2base)] +
    +

    String count and replace

    +

    You can replace one, some, or all occurrences of a string within another +string in O(N*M) time. The replaceAll, replace, and replaceFirst methods +are identical, except replaceFirst replaces exactly one ocurrence of the +string, the first occurrence. replace replaces the first times occurrences. +And replaceAll replaces every occurrence.

    +

    You can also count the number of times a string occurs within another string +using countAllOccurrences.

    +
    k
    syntax String ::= "replaceAll" "(" haystack: String "," needle: String "," replacement: String ")" [function, total, hook(STRING.replaceAll)] + syntax String ::= "replace" "(" haystack: String "," needle: String "," replacement: String "," times: Int ")" [function, hook(STRING.replace)] + syntax String ::= "replaceFirst" "(" haystack: String "," needle: String "," replacement: String ")" [function, total, hook(STRING.replaceFirst)] + syntax Int ::= "countAllOccurrences" "(" haystack: String "," needle: String ")" [function, total, hook(STRING.countAllOccurrences)] +
    +

    String equality and lexicographic comparison

    +

    You can compare whether two strings are equal or unequal, or whether one string +is less than, less than or equal to, greater than, or greater than or equal to +another according to the natural lexicographic ordering of strings.

    +
    k
    syntax Bool ::= String "==String" String [function, total, comm, hook(STRING.eq)] + | String "=/=String" String [function, total, comm, hook(STRING.ne)] + rule S1:String =/=String S2:String => notBool (S1 ==String S2) + + syntax Bool ::= String "<String" String [function, total, hook(STRING.lt)] + | String "<=String" String [function, total, hook(STRING.le)] + | String ">String" String [function, total, hook(STRING.gt)] + | String ">=String" String [function, total, hook(STRING.ge)] +
    +

    Implementation of Strings

    +

    What follows is a few String hooks which are deprecated and only are supported +on certain outdated backends of K, as well as an implementation of several +of the above operations in K.

    +
    k
    syntax String ::= categoryChar(String) [function, hook(STRING.category)] + | directionalityChar(String) [function, hook(STRING.directionality)] + + syntax String ::= "newUUID" [function, hook(STRING.uuid), impure] + + rule S1:String <=String S2:String => notBool (S2 <String S1) + rule S1:String >String S2:String => S2 <String S1 + rule S1:String >=String S2:String => notBool (S1 <String S2) + + rule findChar(S1:String, S2:String, I:Int) => #if findString(S1, substrString(S2, 0, 1), I) ==Int -1 #then findChar(S1, substrString(S2, 1, lengthString(S2)), I) #else #if findChar(S1, substrString(S2, 1, lengthString(S2)), I) ==Int -1 #then findString(S1, substrString(S2, 0, 1), I) #else minInt(findString(S1, substrString(S2, 0, 1), I), findChar(S1, substrString(S2, 1, lengthString(S2)), I)) #fi #fi requires S2 =/=String "" + rule findChar(_, "", _) => -1 + rule rfindChar(S1:String, S2:String, I:Int) => maxInt(rfindString(S1, substrString(S2, 0, 1), I), rfindChar(S1, substrString(S2, 1, lengthString(S2)), I)) requires S2 =/=String "" + rule rfindChar(_, "", _) => -1 + + rule countAllOccurrences(Source:String, ToCount:String) => 0 + requires findString(Source, ToCount, 0) <Int 0 + rule countAllOccurrences(Source:String, ToCount:String) => 1 +Int countAllOccurrences(substrString(Source, findString(Source, ToCount, 0) +Int lengthString(ToCount), lengthString(Source)), ToCount) + requires findString(Source, ToCount, 0) >=Int 0 + + rule replaceFirst(Source:String, ToReplace:String, Replacement:String) => substrString(Source, 0, findString(Source, ToReplace, 0)) + +String Replacement +String substrString(Source, findString(Source, ToReplace, 0) +Int lengthString(ToReplace), lengthString(Source)) + requires findString(Source, ToReplace, 0) >=Int 0 + rule replaceFirst(Source:String, ToReplace:String, _:String) => Source + requires findString(Source, ToReplace, 0) <Int 0 + + + rule replace(Source:String, ToReplace:String, Replacement:String, Count:Int) => + substrString(Source, 0, findString(Source, ToReplace, 0)) +String Replacement +String + replace(substrString(Source, findString(Source, ToReplace, 0) +Int lengthString(ToReplace), lengthString(Source)), ToReplace, Replacement, Count -Int 1) + requires Count >Int 0 + rule replace(Source:String, _, _, 0) => Source + rule replaceAll(Source:String, ToReplace:String, Replacement:String) => replace(Source, ToReplace, Replacement, countAllOccurrences(Source, ToReplace)) + +endmodule + +module STRING-KORE [kore, symbolic] + imports private K-EQUAL + imports STRING-COMMON + + rule S1:String ==K S2:String => S1 ==String S2 [simplification] + +endmodule + +module STRING + imports STRING-COMMON + imports STRING-KORE +endmodule +
    +

    String Buffers

    +

    It is a well known fact that repeated string concatenations are quadratic +in performance whereas use of an efficient mutable representation of arrays +can yield linear performance. We thus provide such a sort, the StringBuffer +sort. Axiomatically, it is implemented below on symbolic backends using the +String module. However, on concrete backends it provides an efficient +implementation of string concatenation. There are three operations:

    +
      +
    • .StringBuffer creates a new StringBuffer with current content equal +to the empty string.
    • +
    • +String takes a StringBuffer and a String and appends the String to +the end of the StringBuffer
    • +
    • StringBuffer2String converts a StringBuffer to a String. This operation +copies the string so that subsequent modifications to the StringBuffer +will not change the value of the String returned by this function.
    • +
    +
    k
    module STRING-BUFFER-IN-K [symbolic] + imports private BASIC-K + imports STRING + + syntax StringBuffer ::= ".StringBuffer" [function, total] + syntax StringBuffer ::= StringBuffer "+String" String [function, total, avoid] + syntax StringBuffer ::= String + syntax String ::= StringBuffer2String ( StringBuffer ) [function, total] + + rule {SB:String +String S:String}<:StringBuffer => (SB +String S)::String + rule .StringBuffer => "" + rule StringBuffer2String(S:String) => S +endmodule + +module STRING-BUFFER-HOOKED [concrete] + imports private BASIC-K + imports STRING + + syntax StringBuffer [hook(BUFFER.StringBuffer)] + syntax StringBuffer ::= ".StringBuffer" [function, total, hook(BUFFER.empty), impure] + syntax StringBuffer ::= StringBuffer "+String" String [function, total, hook(BUFFER.concat), avoid] + syntax String ::= StringBuffer2String ( StringBuffer ) [function, total, hook(BUFFER.toString)] +endmodule + +module STRING-BUFFER + imports STRING-BUFFER-HOOKED + imports STRING-BUFFER-IN-K +endmodule +
    +

    Byte Arrays

    +

    Provided here is the syntax of an implementation of fixed-width arrays of Bytes +in K. This type is hooked to an implementation of bytes provided by the +backend. In concrete backends, this representation is mutable and thus multiple +references can occur to the same Bytes object and when one is modified, the +others are also modified. Care should be taken not to rely on this fact however +as this is not the case in symbolic backends and thus you will experience +divergent behavior unless the Bytes type is used in a manner that preserves +consistency.

    +
    k
    module BYTES-SYNTAX + imports private STRING-SYNTAX + + syntax Bytes [hook(BYTES.Bytes)] + syntax Bytes ::= r"b[\\\"](([\\x20\\x21\\x23-\\x5B\\x5D-\\x7E])|([\\\\][tnfr\\\"\\\\])|([\\\\][x][0-9a-fA-F]{2}))*[\\\"]" [token] +endmodule +
    +
    k
    module BYTES-STRING-ENCODE [kore, symbolic] + imports BYTES-SYNTAX +
    +

    Encoding/decoding between Bytes and String

    +

    You can encode/decode between Bytes and String using UTF-8, UTF-16LE, UTF-16BE, UTF-32LE, and UTF-32BE

    +
    k
    syntax String ::= decodeBytes ( encoding: String , contents: Bytes ) [function, hook(BYTES.decodeBytes)] + syntax Bytes ::= encodeBytes ( encoding: String , contents: String ) [function, hook(BYTES.encodeBytes)] +endmodule +
    +
    k
    module BYTES-HOOKED + imports STRING-SYNTAX + imports BYTES-SYNTAX + imports BYTES-STRING-ENCODE +
    +

    Empty byte array

    +

    The byte array of length zero is represented by .Bytes.

    +
    k
    syntax Bytes ::= ".Bytes" [function, total, hook(BYTES.empty)] +
    +

    Endianness

    +

    When converting to/from an integer, byte arrays can be treated as either little +endian (ie, least significant byte first) or big endian (ie, most significant +byte first).

    +
    k
    syntax Endianness ::= "LE" [klabel(littleEndianBytes), symbol] + | "BE" [klabel(bigEndianBytes), symbol] +
    +

    Signedness

    +

    When converting to/from an integer, byte arrays can be treated as either signed +or unsigned.

    +
    k
    syntax Signedness ::= "Signed" [klabel(signedBytes), symbol] + | "Unsigned" [klabel(unsignedBytes), symbol] +
    +

    Integer and Bytes conversion

    +

    You can convert from a Bytes to an Int. In order to do this, the endianness +and signedness of the Bytes must be provided. The resulting integer is +created by means of interpreting the Bytes as either a twos-complement +representation, or an unsigned representation, of an integer, in the specified +byte order.

    +

    You can also convert from an Int to a Bytes. This comes in two variants. +In the first, the length of the resulting Bytes in bytes is explicitly +specified. If the length is greater than the highest set bit in the magnitude +of the integer, the result is padded with 0 bits if the number is positive +and 1 bits if the number is negative. If the length is less than the highest +bit set in the magnitude of the integer, the most-significant bits of the +integer will be truncated. The endianness of the resulting Bytes object +is as specified.

    +

    In the second variant, both endianness and signedness are specified, and +the resulting Bytes object will be the smallest number of bytes necessary +for the resulting Bytes object to be convertible back to the original integer +via Bytes2Int. In other words, if the highest bit set in the magnitude of the +integer is N, then the byte array will be at least N+1 bits long, rounded up +to the nearest byte.

    +
    k
    syntax Int ::= Bytes2Int(Bytes, Endianness, Signedness) [function, total, hook(BYTES.bytes2int)] + syntax Bytes ::= Int2Bytes(length: Int, Int, Endianness) [function, total, hook(BYTES.int2bytes)] + | Int2Bytes(Int, Endianness, Signedness) [function, total, klabel(Int2BytesNoLen)] +
    +

    String and Bytes conversion

    +

    You can convert between a Bytes and a String in O(N) time. The resulting +value is a copy of the original and will not be affected by subsequent +mutations of the input or output value.

    +
    k
    syntax String ::= Bytes2String(Bytes) [function, total, hook(BYTES.bytes2string)] + syntax Bytes ::= String2Bytes(String) [function, total, hook(BYTES.string2bytes)] +
    +

    Bytes update

    +

    You can set the value of a particular byte in a Bytes object in O(1) time. +The result is #False if value is not in the range [0..255] or if index +is not a valid index (ie, less than zero or greater than or equal to the length +of the Bytes term).

    +
    k
    syntax Bytes ::= Bytes "[" index: Int "<-" value: Int "]" [function, hook(BYTES.update)] +
    +

    Bytes lookup

    +

    You can get the value of a particular byte in a Bytes object in O(1) time. +The result is #False if index is not a valid index (see above).

    +
    k
    syntax Int ::= Bytes "[" Int "]" [function, hook(BYTES.get)] +
    +

    Bytes substring

    +

    You can get a new Bytes object containing a range of bytes from the input +Bytes in O(N) time (where N is the length of the substring). The range +of bytes included is [startIndex..endIndex). The resulting Bytes is +a copy and mutations to it do not affect mutations to the original Bytes. +The result is #False if startIndex or endIndex are not valid.

    +
    k
    syntax Bytes ::= substrBytes(Bytes, startIndex: Int, endIndex: Int) [function, hook(BYTES.substr)] +
    +

    Multiple bytes update

    +

    You can modify a Bytes to return a Bytes which is equal to dest except +the N elements starting at index are replaced with the contents of src in +O(N) time. This does not create a new Bytes object and will instead modify +the original on concrete backends. The result is #False if index + N +is not a valid index.

    +
    k
    syntax Bytes ::= replaceAtBytes(dest: Bytes, index: Int, src: Bytes) [function, hook(BYTES.replaceAt)] +
    +

    Multiple bytes update

    +

    You can modify a Bytes to return a Bytes which is equal to dest except +the count bytes starting at index are replaced with count bytes of value +Int2Bytes(1, v, LE/BE) in O(count) time. This does not create a new Bytes +object and will instead modify the original on concrete backends. +This will throw an exception if index + count is not a valid index. +The acceptable range of values for v is -128 to 127. This will throw an +exception if v is outside of this range. +This is implemented only for the LLVM backend.

    +
    k
    syntax Bytes ::= memsetBytes(dest: Bytes, index: Int, count: Int, v: Int) [function, hook(BYTES.memset)] +
    +

    Bytes padding

    +

    You can create a new Bytes object which is at least length bytes long +by taking the input sequence and padding it on the right (respectively, on the +left) with the specified value. This does not create a new Bytes object +if the input is already at least length bytes long, and will instead +return the input unchanged. The result is #False if value is not in the +range [0..255], or if the length is negative.

    +
    k
    syntax Bytes ::= padRightBytes(Bytes, length: Int, value: Int) [function, hook(BYTES.padRight)] + | padLeftBytes(Bytes, length: Int, value: Int) [function, hook(BYTES.padLeft)] +
    +

    Bytes reverse

    +

    You can reverse a Bytes object in O(N) time. This does not create a new +Bytes object and will instead modify the original on concrete backends.

    +
    k
    syntax Bytes ::= reverseBytes(Bytes) [function, total, hook(BYTES.reverse)] +
    +

    Bytes length

    +

    You can get the length of a Bytes term in O(1) time.

    +
    k
    syntax Int ::= lengthBytes(Bytes) [function, total, hook(BYTES.length), smtlib(lengthBytes)] +
    +

    Bytes concatenation

    +

    You can create a new Bytes object by concatenating two Bytes objects +together in O(N) time.

    +
    k
    syntax Bytes ::= Bytes "+Bytes" Bytes [function, total, hook(BYTES.concat), right] + +endmodule +
    +

    Implementation of Bytes

    +

    The remainder of this module consists of an implementation of some of the +operators listed above in K.

    +
    k
    module BYTES-CONCRETE [concrete] + imports BYTES-HOOKED +endmodule + +module BYTES-KORE [kore] + imports BYTES-HOOKED + imports BYTES-SYMBOLIC-CEIL +endmodule + +module BYTES-SYMBOLIC-CEIL [symbolic, kore] + imports BYTES-HOOKED + imports private INT + imports private BOOL + + rule #Ceil(padRightBytes(_, LEN, VAL)) => {(0 <=Int LEN andBool 0 <=Int VAL andBool VAL <Int 256) #Equals true} [simplification] + rule #Ceil(padLeftBytes(_, LEN, VAL)) => {(0 <=Int LEN andBool 0 <=Int VAL andBool VAL <Int 256) #Equals true} [simplification] +endmodule + +module BYTES + imports BYTES-CONCRETE + imports BYTES-KORE + imports private INT + + rule Int2Bytes(I::Int, E::Endianness, Unsigned) => Int2Bytes((log2Int(I) +Int 8) /Int 8, I, E) + requires I >Int 0 + rule Int2Bytes(0, _::Endianness, _) => .Bytes + rule Int2Bytes(I::Int, E::Endianness, Signed) => Int2Bytes((log2Int(I) +Int 9) /Int 8, I, E) + requires I >Int 0 + rule Int2Bytes(I::Int, E::Endianness, Signed) => Int2Bytes((log2Int(~Int I) +Int 9) /Int 8, I, E) + requires I <Int -1 + rule Int2Bytes(-1, E::Endianness, Signed) => Int2Bytes(1, -1, E) +endmodule +
    +

    Program identifiers

    +

    Provided here is an implementation for program identifiers in K. Developers +of semantics for a particular language may wish to use their own implementation +instead of the one provided here if their syntax differs from the syntax +defined below. However, this is provided for convenience for developers who +do not care about the lexical syntax of identifiers.

    +

    Provided are the following pieces of functionality:

    +
      +
    • Id2String - Convert an Id to a String containing its name
    • +
    • String2Id - Convert a String to an Id with the specified name
    • +
    • !X:Id - You can get a fresh identifier distinct from any previous identifier +generated by this syntax.
    • +
    +
    k
    module ID-SYNTAX-PROGRAM-PARSING + imports BUILTIN-ID-TOKENS + syntax Id ::= r"(?<![A-Za-z0-9\\_])[A-Za-z\\_][A-Za-z0-9\\_]*" [prec(1), token] + | #LowerId [token] + | #UpperId [token] +endmodule + +module ID-SYNTAX + syntax Id [token] +endmodule + +module ID-COMMON + imports ID-SYNTAX + imports private STRING + + syntax String ::= Id2String ( Id ) [function, total, hook(STRING.token2string)] + syntax Id ::= String2Id (String) [function, total, hook(STRING.string2token)] + syntax Id ::= freshId(Int) [freshGenerator, function, total, private] + + rule freshId(I:Int) => String2Id("_" +String Int2String(I)) +endmodule + +module ID + imports ID-COMMON +endmodule +
    +

    Equality and conditionals

    +

    Provided here are implementations of two important primitives in K:

    +
      +
    • ==K - the equality between two terms. Returns true if they are equal +and false if they are not equal.
    • +
    • #if #then #else #fi - polymorphic conditional function. If the first +argument evaluates to true, the second argument is returned. Otherwise, +the third argument is returned. Note that this does not short-circuit on +symbolic backends.
    • +
    +
    k
    module K-EQUAL-SYNTAX + imports private BOOL + imports private BASIC-K + + syntax Bool ::= left: + K "==K" K [function, total, comm, smt-hook(=), hook(KEQUAL.eq), klabel(_==K_), symbol, latex({#1}\mathrel{=_K}{#2}), group(equalEqualK)] + | K "=/=K" K [function, total, comm, smt-hook(distinct), hook(KEQUAL.ne), klabel(_=/=K_), symbol, latex({#1}\mathrel{\neq_K}{#2}), group(notEqualEqualK)] + + syntax priorities equalEqualK notEqualEqualK > boolOperation mlOp + + syntax {Sort} Sort ::= "#if" Bool "#then" Sort "#else" Sort "#fi" [function, total, smt-hook(ite), hook(KEQUAL.ite)] + +endmodule + +module K-EQUAL-KORE [kore, symbolic] + import private BOOL + import K-EQUAL-SYNTAX + + rule K1:Bool ==K K2:Bool => K1 ==Bool K2 [simplification] + rule {K1 ==K K2 #Equals true} => {K1 #Equals K2} [simplification] + rule {true #Equals K1 ==K K2} => {K1 #Equals K2} [simplification] + rule {K1 ==K K2 #Equals false} => #Not({K1 #Equals K2}) [simplification] + rule {false #Equals K1 ==K K2} => #Not({K1 #Equals K2}) [simplification] + rule {K1 =/=K K2 #Equals true} => #Not({K1 #Equals K2}) [simplification] + rule {true #Equals K1 =/=K K2} => #Not({K1 #Equals K2}) [simplification] + rule {K1 =/=K K2 #Equals false} => {K1 #Equals K2} [simplification] + rule {false #Equals K1 =/=K K2} => {K1 #Equals K2} [simplification] + +endmodule + +module K-EQUAL + import private BOOL + import K-EQUAL-SYNTAX + import K-EQUAL-KORE + + rule K1:K =/=K K2:K => notBool (K1 ==K K2) + + rule #if C:Bool #then B1::K #else _ #fi => B1 requires C + rule #if C:Bool #then _ #else B2::K #fi => B2 requires notBool C + +endmodule +
    +

    Meta operations

    +

    Provided below are a few miscellaneous, mostly deprecated functions in K. +It is not recommended to use any of them directly as they are largely +unsupported in modern K. There are a few exceptions:

    +
      +
    • #getenv - Returns the value of an environment variable
    • +
    • #parseKORE - Takes a String containing a K intermediate representation of +a term such as is returned by kast -o kore and converts it to a term. +This is NOT type-safe. The responsibility is on the user to ensure that the +string they provide is a valid representation of a term of the sort exactly +equal to the sort where the function appears.
    • +
    • #kompiledDirectory - Returns the path to the current compiled K definition +directory.
    • +
    • #unparseKORE = Takes a K term and converts it to a string.
    • +
    +
    k
    module K-REFLECTION + imports BASIC-K + imports STRING + + syntax K ::= "#configuration" [function, impure, hook(KREFLECTION.configuration)] + syntax String ::= #sort(K) [function, hook(KREFLECTION.sort)] + syntax KItem ::= #fresh(String) [function, hook(KREFLECTION.fresh), impure] + syntax KItem ::= getKLabel(K) [function, hook(KREFLECTION.getKLabel)] + + syntax K ::= #getenv(String) [function, impure, hook(KREFLECTION.getenv)] + + syntax String ::= #kompiledDirectory() [function, hook(KREFLECTION.kompiledDir)] + + // meaningful only for the purposes of compilation to a binary, otherwise + // undefined + syntax List ::= #argv() [function, hook(KREFLECTION.argv)] + + // Takes as input a string and returns a K term + syntax {Sort} Sort ::= #parseKORE(String) [function, hook(KREFLECTION.parseKORE)] + syntax {Sort} String ::= #unparseKORE(Sort) [function, hook(KREFLECTION.printKORE)] + syntax IOError ::= "#noParse" "(" String ")" [klabel(#noParse), symbol] + +endmodule +
    +

    I/O in K

    +

    Concrete execution in K supports I/O operations. This functionality is not +supported during symbolic execution, because symbolic execution must exist +completely free of side-effects, and I/O is an irreducible type of side effect. +However, it is useful in many cases when defining concrete execution to be able +to make reference to I/O operations.

    +

    The design of these I/O operations is based on the POSIX standard, for the most +part. For example, the #read K function maps to the read POSIX function. We +do not at this time have a higher-level API for I/O, but this may be +implemented at some point in the future.

    +

    I/O operations generally return either their result, or an IOError term +corresponding to the errno returned by the underlying system call.

    +
    k
    module K-IO + imports private LIST + imports private STRING + imports private INT +
    +

    I/O errors

    +

    Aside from EOF, which is returned by #getc if the file is at end-of-file, all +of the below I/O errors correspond to possible values for errno after calling +a library function. If the errno returned is not one of the below errnos +known to K, #unknownIOError is returned along with the integer errno value.

    +
    k
    syntax IOError ::= "#EOF" [klabel(#EOF), symbol] | #unknownIOError(errno: Int) [symbol] + | "#E2BIG" [klabel(#E2BIG), symbol] + | "#EACCES" [klabel(#EACCES), symbol] + | "#EAGAIN" [klabel(#EAGAIN), symbol] + | "#EBADF" [klabel(#EBADF), symbol] + | "#EBUSY" [klabel(#EBUSY), symbol] + | "#ECHILD" [klabel(#ECHILD), symbol] + | "#EDEADLK" [klabel(#EDEADLK), symbol] + | "#EDOM" [klabel(#EDOM), symbol] + | "#EEXIST" [klabel(#EEXIST), symbol] + | "#EFAULT" [klabel(#EFAULT), symbol] + | "#EFBIG" [klabel(#EFBIG), symbol] + | "#EINTR" [klabel(#EINTR), symbol] + | "#EINVAL" [klabel(#EINVAL), symbol] + | "#EIO" [klabel(#EIO), symbol] + | "#EISDIR" [klabel(#EISDIR), symbol] + | "#EMFILE" [klabel(#EMFILE), symbol] + | "#EMLINK" [klabel(#EMLINK), symbol] + | "#ENAMETOOLONG" [klabel(#ENAMETOOLONG), symbol] + | "#ENFILE" [klabel(#ENFILE), symbol] + | "#ENODEV" [klabel(#ENODEV), symbol] + | "#ENOENT" [klabel(#ENOENT), symbol] + | "#ENOEXEC" [klabel(#ENOEXEC), symbol] + | "#ENOLCK" [klabel(#ENOLCK), symbol] + | "#ENOMEM" [klabel(#ENOMEM), symbol] + | "#ENOSPC" [klabel(#ENOSPC), symbol] + | "#ENOSYS" [klabel(#ENOSYS), symbol] + | "#ENOTDIR" [klabel(#ENOTDIR), symbol] + | "#ENOTEMPTY" [klabel(#ENOTEMPTY), symbol] + | "#ENOTTY" [klabel(#ENOTTY), symbol] + | "#ENXIO" [klabel(#ENXIO), symbol] + | "#EPERM" [klabel(#EPERM), symbol] + | "#EPIPE" [klabel(#EPIPE), symbol] + | "#ERANGE" [klabel(#ERANGE), symbol] + | "#EROFS" [klabel(#EROFS), symbol] + | "#ESPIPE" [klabel(#ESPIPE), symbol] + | "#ESRCH" [klabel(#ESRCH), symbol] + | "#EXDEV" [klabel(#EXDEV), symbol] + | "#EWOULDBLOCK" [klabel(#EWOULDBLOCK), symbol] + | "#EINPROGRESS" [klabel(#EINPROGRESS), symbol] + | "#EALREADY" [klabel(#EALREADY), symbol] + | "#ENOTSOCK" [klabel(#ENOTSOCK), symbol] + | "#EDESTADDRREQ" [klabel(#EDESTADDRREQ), symbol] + | "#EMSGSIZE" [klabel(#EMSGSIZE), symbol] + | "#EPROTOTYPE" [klabel(#EPROTOTYPE), symbol] + | "#ENOPROTOOPT" [klabel(#ENOPROTOOPT), symbol] + | "#EPROTONOSUPPORT" [klabel(#EPROTONOSUPPORT), symbol] + | "#ESOCKTNOSUPPORT" [klabel(#ESOCKTNOSUPPORT), symbol] + | "#EOPNOTSUPP" [klabel(#EOPNOTSUPP), symbol] + | "#EPFNOSUPPORT" [klabel(#EPFNOSUPPORT), symbol] + | "#EAFNOSUPPORT" [klabel(#EAFNOSUPPORT), symbol] + | "#EADDRINUSE" [klabel(#EADDRINUSE), symbol] + | "#EADDRNOTAVAIL" [klabel(#EADDRNOTAVAIL), symbol] + | "#ENETDOWN" [klabel(#ENETDOWN), symbol] + | "#ENETUNREACH" [klabel(#ENETUNREACH), symbol] + | "#ENETRESET" [klabel(#ENETRESET), symbol] + | "#ECONNABORTED" [klabel(#ECONNABORTED), symbol] + | "#ECONNRESET" [klabel(#ECONNRESET), symbol] + | "#ENOBUFS" [klabel(#ENOBUFS), symbol] + | "#EISCONN" [klabel(#EISCONN), symbol] + | "#ENOTCONN" [klabel(#ENOTCONN), symbol] + | "#ESHUTDOWN" [klabel(#ESHUTDOWN), symbol] + | "#ETOOMANYREFS" [klabel(#ETOOMANYREFS), symbol] + | "#ETIMEDOUT" [klabel(#ETIMEDOUT), symbol] + | "#ECONNREFUSED" [klabel(#ECONNREFUSED), symbol] + | "#EHOSTDOWN" [klabel(#EHOSTDOWN), symbol] + | "#EHOSTUNREACH" [klabel(#EHOSTUNREACH), symbol] + | "#ELOOP" [klabel(#ELOOP), symbol] + | "#EOVERFLOW" [klabel(#EOVERFLOW), symbol] +
    +

    I/O result sorts

    +

    Here we see sorts defined to contain either an Int or an IOError, or +either a String or an IOError. These sorts are used to implement the +return sort of functions that may succeed, in which case they return a value, +or may fail, in which case their return value indicates an error and the +error indicated is returned via errno.

    +
    k
    syntax IOInt ::= Int | IOError + syntax IOString ::= String | IOError +
    +

    Opening a file

    +

    You can open a file in K using #open. An optional mode indicates the file +open mode, which can have any value allowed by the fopen function in C. +The returned value is the file descriptor that was opened, or an error.

    +
    k
    syntax IOInt ::= "#open" "(" path: String ")" [function] + | "#open" "(" path: String "," mode: String ")" [function, hook(IO.open), impure] + + rule #open(S:String) => #open(S:String, "r+") +
    +

    Get/set position in file

    +

    You can get the current offset in a file using #tell. You can also seek +to a particular offset using #seek or #seekEnd. #seek is implemented via +a call to lseek with the SEEK_SET whence. #seekEnd is implemented via a +call to lseek with the SEEK_END whence. You can emulate the SEEK_CUR +whence by means of #seek(FD, #tell(FD) +Int Offset).

    +
    k
    syntax IOInt ::= "#tell" "(" fd: Int ")" [function, hook(IO.tell), impure] + syntax K ::= "#seek" "(" fd: Int "," index: Int ")" [function, hook(IO.seek), impure] + | "#seekEnd" "(" fd: Int "," fromEnd: Int ")" [function, hook(IO.seekEnd), impure] +
    +

    Read from file

    +

    You can read a single character from a file using #getc. #EOF is returned +if you are at end-of-fie.

    +

    You can also read up to length characters in a file using #read. The +resulting read characters are returned, which may be fewer characters than +requested. A string of zero length being returned indicates end-of-file.

    +
    k
    syntax IOInt ::= "#getc" "(" fd: Int ")" [function, hook(IO.getc), impure] + syntax IOString ::= "#read" "(" fd: Int "," length: Int ")" [function, hook(IO.read), impure] +
    +

    Write to file

    +

    You can write a single character to a file using #putc. You can also write +a string to a file using #write. The returned value on success is .K.

    +
    k
    syntax K ::= "#putc" "(" fd: Int "," value: Int ")" [function, hook(IO.putc), impure] + | "#write" "(" fd: Int "," value: String ")" [function, hook(IO.write), impure] +
    +

    Closing a file

    +

    You can close a file using #close. The returned value on success is .K.

    +
    k
    syntax K ::= "#close" "(" fd: Int ")" [function, hook(IO.close), impure] +
    +

    Locking/unlocking a file

    +

    You can lock or unlock parts of a file using the #lock and #unlock +functions. The lock starts at the beginning of the file and continues for +endIndex bytes. Note that Unix systems do not actually prevent locked files +from being read and modified; you will have to lock both sides of a concurrent +access to guarantee exclusivity.

    +
    k
    syntax K ::= "#lock" "(" fd: Int "," endIndex: Int ")" [function, hook(IO.lock), impure] + | "#unlock" "(" fd: Int "," endIndex: Int ")" [function, hook(IO.unlock), impure] +
    +

    Networking

    +

    You can accept a connection on a socket using #accept, or shut down the +write end of a socket with #shutdownWrite. Note that facility is not provided +for opening, binding, and listening on sockets. These functions are implemented +in order to support creating stateful request/response servers where the +request loop is implemented using rewriting in K, but the connection +initialization is written in native code and linked into the LLVM backend.

    +
    k
    syntax IOInt ::= "#accept" "(" fd: Int ")" [function, hook(IO.accept), impure] + syntax K ::= "#shutdownWrite" "(" fd: Int ")" [function, hook(IO.shutdownWrite), impure] +
    +

    Time

    +

    You can get the current time in seconds since midnight UTC on January 1, 1970 +using #time.

    +
    k
    syntax Int ::= "#time" "(" ")" [function, hook(IO.time), impure] +
    +

    Builtin file descriptors

    +

    Provided here are functions that return the file descriptor for standard input, +standard output, and standard error.

    +
    k
    syntax Int ::= "#stdin" [function, total] + | "#stdout" [function, total] + | "#stderr" [function, total] + + rule #stdin => 0 + rule #stdout => 1 + rule #stderr => 2 +
    +

    Shell access

    +

    You can execute a command using the shell using the #system operator. Care +must be taken to sanitize inputs to this function or security issues may +result. Note that K has no facility for reasoning about logic that happens +outside its process, so any functionality that you wish to be able to formally +reason about in K should not be implemented via the #system operator.

    +
    k
    syntax KItem ::= #system ( String ) [function, hook(IO.system), impure] + | "#systemResult" "(" Int /* exit code */ "," String /* stdout */ "," String /* stderr */ ")" [klabel(#systemResult), symbol] +
    +

    Temporary files

    +

    You can get a temporary file and open it atomically using the #mkstemp +operator. The resulting file will be closed and deleted when K rewriting ends. +For more info on the argument to #mkstemp, see man mkstemp.

    +
    k
    syntax IOFile ::= #mkstemp(template: String) [function, hook(IO.mkstemp), impure] + syntax IOFile ::= IOError + | "#tempFile" "(" path: String "," fd: Int ")" [klabel(#tempFile), symbol] +
    +

    Deleting a file

    +

    You can delete a file using its absolute or relative path using the #remove +operator. It returns .K on success or an IOError on failure.

    +
    k
    syntax K ::= #remove(path: String) [function, total, hook(IO.remove), impure] +
    +

    Logging

    +

    You can log information to disk using the #logToFile operator. Semantically, +this operator returns .K. However, it has a side effect that is not reasoned +about which is that value will be written to a uniquely-identified file +containing name in its name. The file is only flushed to disk when rewriting +finishes.

    +
    k
    syntax K ::= #logToFile(name: String, value: String) [function, total, hook(IO.log), impure, returnsUnit, symbol] +
    +

    Strings can also be logged via the logging mechanisms available to the backend. +On the LLVM backend, this just means logging the text to standard error. On the +Haskell backend, a log message of type InfoUserLog is created with the +specified text.

    +
    k
    syntax K ::= #log(value: String) [function, total, hook(IO.logString), impure, returnsUnit, symbol] +
    +

    Terms can also be logged to standard error in surface syntax, rather than as +KORE using #trace. This operator has similar semantics to #logToFile (i.e. +it returns .K, but prints as an impure side effect). Note that calling +#trace is equivalent to invoking the kprint tool for the first term that is +logged, which requires re-parsing the underlying K definition. Subsequent calls +do not incur this overhead again; the definition is cached.

    +
    k
    syntax K ::= #trace(value: KItem) [function, total, hook(IO.traceTerm), impure, returnsUnit, symbol] + | #traceK(value: K) [function, total, hook(IO.traceTerm), impure, returnsUnit, symbol] +
    +

    Implementation of high-level I/O streams in K

    +

    Below is an implementation of the stream="stdin" and stream="stdout" +cell attributes in K. You should not refer to these symbols or modules directly +in your definition. It is provided only so that the K compiler can make use of +it. For more information on how to use this feature, refer to IMP++ in the K +tutorial.

    +
    k
    syntax Stream ::= #buffer(K) + | #istream(Int) + | #parseInput(String, String) + | #ostream(Int) + +endmodule + +// NOTE: DO NOT DIRECTLY IMPORT *-STREAM MODULES +// These stream modules will be automatically instantiated and implicitly imported +// into the main module when `stream` attributes appear in configuration cells. +// Only `Stream` productions and `[stream]` rules will be imported. +// The cell name will be replaced with the one of the main configuration. + +module STDIN-STREAM + imports K-IO + imports K-REFLECTION + imports LIST + imports INT + imports BOOL + + configuration <stdin> ListItem(#buffer($STDIN:String)) ListItem($IO:String) ListItem(#istream(#stdin)) </stdin> + + // read one character at a time until we read whitespace + rule [stdinGetc]: + <stdin> + ListItem(#parseInput(_:String, Delimiters:String)) + ListItem(#buffer(S:String => S +String chrChar({#getc(N)}:>Int))) + ListItem("on") + ListItem(#istream(N:Int)) + </stdin> + requires findChar(S, Delimiters, 0) ==Int -1 // [stdin] + [stream, priority(200)] + + // when we reach whitespace, if it parses create a ListItem + rule [stdinParseString]: + <stdin> + (ListItem(#parseInput("String", Delimiters:String)) => ListItem(S)) + ListItem(#buffer(S:String => "")) + _:List + </stdin> + requires findChar(S, Delimiters, 0) =/=Int -1 // [stdin] + [stream] + + // a hack: handle the case when we read integers without the help of the IO server + rule [stdinParseInt]: + <stdin> + (ListItem(#parseInput("Int", Delimiters:String)) + => ListItem(String2Int(substrString(S, 0, findChar(S, Delimiters, 0))))) + ListItem(#buffer(S:String => substrString(S,findChar(S, Delimiters, 0) +Int 1, lengthString(S)))) + _:List + </stdin> + requires findChar(S, Delimiters, 0) =/=Int -1 + andBool lengthString(S) >Int 1 // [stdin] + [stream] + + rule [stdinTrim]: + <stdin> + ListItem(#parseInput(Sort:String, Delimiters:String)) + ListItem(#buffer(S:String => substrString(S, 1, lengthString(S)))) + _:List + </stdin> + requires findChar(S, Delimiters, 0) =/=Int -1 + andBool Sort =/=String "String" + andBool lengthString(S) <=Int 1 // [stdin] + [stream] + + // NOTE: This unblocking rule will be instantiated and inserted carefully + // when necessary according to user-defined rules, since otherwise it will + // lead to a diverging (i.e., non-terminating) transition system definition. + // Currently, it supports only a simple pattern matching on the top of the + // input stream cell, e.g., + // rule <k> read() => V ... </k> <in> ListItem(V:Int) => .List ... </in> + // Non-supported rules that refer to the input stream cell in a sophisticated + // way will get stuck in concrete execution mode with real IO enabled (i.e., + // under `--io on` option), while they will still work in symbolic execution + // mode or concrete execution mode with real IO disabled (i.e., under `--io + // off`, `--search`, or `--debug` options). + // + // TODO: More patterns need to be supported as well. In that case, we need to + // have a way to specify such patterns. + rule [stdinUnblock]: + <stdin> + (.List => ListItem(#parseInput(?Sort:String, ?Delimiters:String))) + ListItem(#buffer(_:String)) + ... + </stdin> + + /* + syntax Stream ::= "#noIO" + + rule ListItem(#buffer(_)) + (ListItem(#noIO) ListItem(#istream(_:Int)) => .List) [stdin] + */ + +endmodule + +module STDOUT-STREAM + imports K-IO + imports LIST + imports STRING + + configuration <stdout> ListItem(#ostream(#stdout)) ListItem($IO:String) ListItem(#buffer("")) </stdout> +//configuration <stderr> ListItem(#ostream(#stderr)) ListItem($IO:String) ListItem(#buffer("")) </stderr> + + rule [stdoutBufferFloat]: + <stdout> + ListItem(#ostream(_)) + ListItem(_) + ListItem(#buffer(Buffer:String => Buffer +String Float2String(F))) + (ListItem(F:Float) => .List) + _:List + </stdout> + // [stdout, stderr] + [stream, priority(25)] + rule [stdoutBufferInt]: + <stdout> + ListItem(#ostream(_)) + ListItem(_) + ListItem(#buffer(Buffer:String => Buffer +String Int2String(I))) + (ListItem(I:Int) => .List) + _:List + </stdout> + // [stdout, stderr] + [stream, priority(25)] + rule [stdoutBufferString]: + <stdout> + ListItem(#ostream(_)) + ListItem(_) + ListItem(#buffer(Buffer:String => Buffer +String S)) + (ListItem(S:String) => .List) + _:List + </stdout> + // [stdout, stderr] + [stream, priority(25)] + + // Send first char from the buffer to the server + rule [stdoutWrite]: + <stdout> + ListItem(#ostream(N:Int => {#write(N, S) ~> N:Int}:>Int)) + ListItem("on") + ListItem(#buffer(S:String => "")) + _:List + </stdout> + requires S =/=String "" // [stdout, stderr] + [stream, priority(30)] + + /* + syntax Stream ::= "#noIO" + + rule ListItem(#buffer(Buffer:String => Buffer +String Float2String(F))) + (ListItem(F:Float) => .List) + _:List [stdout, stderr] + rule ListItem(#buffer(Buffer:String => Buffer +String Int2String(I))) + (ListItem(I:Int) => .List) + _:List [stdout, stderr] + rule ListItem(#buffer(Buffer:String => Buffer +String S)) + (ListItem(S:String) => .List) + _:List [stdout, stderr] + + rule (ListItem(#ostream(_:Int)) ListItem(#noIO) => .List) + ListItem(#buffer(_)) + _:List [stdout, stderr] + */ + +endmodule +
    +

    Machine Integers

    +

    Provided here is an implementation of arbitrarily large fixed-precision binary +integers in K. This type is hooked to an implementation of integers provided +by the backend, and in particular makes use of native machine integers for +certain sizes of integer. For arbitrary-precision integers, see the INT +module above.

    +

    The syntax of machine integers in K is the same as arbitrary-precision integers +(i.e., an optional sign followed by a sequence of digits) except that machine +integers always end in a suffix pN where N is an integer indicating the +width in bits of the integer. The MInt sort is parametric, and this is +reflected in the literals. For example, the sort of 0p8 is MInt{8}.

    +
    k
    module MINT-SYNTAX + /*@\section{Description} The MInt implements machine integers of arbitrary + * bit width represented in 2's complement. */ + syntax {Width} MInt{Width} [hook(MINT.MInt)] + + /*@ Machine integer of bit width and value. */ + syntax {Width} MInt{Width} ::= r"[\\+-]?[0-9]+[pP][0-9]+" [token, prec(2), hook(MINT.literal)] +endmodule + +module MINT + imports MINT-SYNTAX + imports private INT + imports private BOOL +
    +

    Bitwidth of MInt

    +

    You can get the number of bits of width in an MInt using bitwidthMInt.

    +
    k
    syntax {Width} Int ::= bitwidthMInt(MInt{Width}) [function, total, hook(MINT.bitwidth)] +
    +

    Int and MInt conversions

    +

    You can convert from an MInt to an Int using the MInt2Signed and +MInt2Unsigned functions. an MInt does not have a sign; its sign is instead +reflected in how operators interpret its value either as a signed integer or as +an unsigned integer. Thus, you can interpret a MInt as a signed integer witth +MInt2Signed, or as an unsigned integer respectively using MInt2Unsigned.

    +

    You can also convert from an Int to an MInt using Int2MInt. Care must +be given to ensure that the sort context where the Int2MInt operator appears +has the correct bitwidth, as this will influence the width of the resulting +MInt.

    +
    k
    syntax {Width} Int ::= MInt2Signed(MInt{Width}) [function, total, hook(MINT.svalue)] + | MInt2Unsigned(MInt{Width}) [function, total, hook(MINT.uvalue), smt-hook(bv2int)] + + syntax {Width} MInt{Width} ::= Int2MInt(Int) [function, total, hook(MINT.integer), smt-hook(int2bv)] +
    +

    MInt min and max values

    +

    You can get the minimum and maximum values of a signed or unsigned MInt +with az specified bit width using sminMInt, smaxMInt, uminMInt, and +umaxMInt.

    +
    k
    syntax Int ::= sminMInt(Int) [function] + | smaxMInt(Int) [function] + | uminMInt(Int) [function] + | umaxMInt(Int) [function] + rule sminMInt(N:Int) => 0 -Int (1 <<Int (N -Int 1)) + rule smaxMInt(N:Int) => (1 <<Int (N -Int 1)) -Int 1 + rule uminMInt(_:Int) => 0 + rule umaxMInt(N:Int) => (1 <<Int N) -Int 1 +
    +

    MInt bounds checking

    +

    You can check whether a specified Int will be represented in an MInt +with a specified width without any loss of precision when interpreted as +a signed or unsigned integer using soverflowMInt and uoverflowMInt.

    +
    k
    syntax Bool ::= soverflowMInt(width: Int, Int) [function] + | uoverflowMInt(width: Int, Int) [function] + rule + soverflowMInt(N:Int, I:Int) + => + I <Int sminMInt(N) orBool I >Int smaxMInt(N) + rule + uoverflowMInt(N:Int, I:Int) + => + I <Int uminMInt(N) orBool I >Int umaxMInt(N) +
    +

    MInt arithmetic

    +

    You can:

    +
      +
    • Compute the bitwise complement ~MInt of an MInt.
    • +
    • Compute the unary negation --MInt of an MInt.
    • +
    • Compute the product *MInt of two MInts.
    • +
    • Compute the quotient /sMInt of two MInts interpreted as signed integers.
    • +
    • Compute the modulus %sMInt of two MInts interpreted as signed integers.
    • +
    • Compute the quotient /uMInt of two MInts interpreted as unsigned +integers.
    • +
    • Compute the modulus %uMInt of two MInts interpreted as unsigned integers.
    • +
    • Compute the sum +MInt of two MInts.
    • +
    • Compute the difference -MInt of two MInts.
    • +
    • Compute the left shift <<MInt of two MInts. The second MInt is always +interpreted as positive.
    • +
    • Compute the arithmetic right shift >>aMInt of two MInts. The second +MInt is always interpreted as positve.
    • +
    • Compute the logical right shift >>lMInt of two MInts. The second MInt +is always interpreted as positive.
    • +
    • Compute the bitwise and &MInt of two MInts.
    • +
    • Compute the bitwise xor xorMInt of two MInts.
    • +
    • Compute the bitwise inclusive or |MInt of two MInts.
    • +
    +
    k
    syntax {Width} MInt{Width} ::= "~MInt" MInt{Width} [function, total, hook(MINT.not), smt-hook(bvnot)] + | "--MInt" MInt{Width} [function, total, hook(MINT.neg), smt-hook(bvuminus)] + > left: + MInt{Width} "*MInt" MInt{Width} [function, total, hook(MINT.mul), smt-hook(bvmul)] + | MInt{Width} "/sMInt" MInt{Width} [function, hook(MINT.sdiv), smt-hook(bvsdiv)] + | MInt{Width} "%sMInt" MInt{Width} [function, hook(MINT.srem), smt-hook(bvsrem)] + | MInt{Width} "/uMInt" MInt{Width} [function, hook(MINT.udiv), smt-hook(bvudiv)] + | MInt{Width} "%uMInt" MInt{Width} [function, hook(MINT.urem), smt-hook(bvurem)] + > left: + MInt{Width} "+MInt" MInt{Width} [function, total, hook(MINT.add), smt-hook(bvadd)] + | MInt{Width} "-MInt" MInt{Width} [function, total, hook(MINT.sub), smt-hook(bvsub)] + > left: + MInt{Width} "<<MInt" MInt{Width} [function, hook(MINT.shl), smt-hook(bvshl)] + | MInt{Width} ">>aMInt" MInt{Width} [function, hook(MINT.ashr), smt-hook(bvashr)] + | MInt{Width} ">>lMInt" MInt{Width} [function, hook(MINT.lshr), smt-hook(bvlshr)] + > left: + MInt{Width} "&MInt" MInt{Width} [function, total, hook(MINT.and), smt-hook(bvand)] + > left: + MInt{Width} "xorMInt" MInt{Width} [function, total, hook(MINT.xor), smt-hook(bvxor)] + > left: + MInt{Width} "|MInt" MInt{Width} [function, total, hook(MINT.or), smt-hook(bvor)] +
    +

    MInt comparison

    +

    You can compute whether one MInt is less than, less than or equal to, greater +than, or greater than or equal to another MInt when interpreted as signed +or unsigned integers. You can also compute whether one MInt is equal to or +unequal to another MInt.

    +
    k
    syntax {Width} Bool ::= MInt{Width} "<sMInt" MInt{Width} [function, total, hook(MINT.slt), smt-hook(bvslt)] + | MInt{Width} "<uMInt" MInt{Width} [function, total, hook(MINT.ult), smt-hook(bvult)] + | MInt{Width} "<=sMInt" MInt{Width} [function, total, hook(MINT.sle), smt-hook(bvsle)] + | MInt{Width} "<=uMInt" MInt{Width} [function, total, hook(MINT.ule), smt-hook(bvule)] + | MInt{Width} ">sMInt" MInt{Width} [function, total, hook(MINT.sgt), smt-hook(bvsgt)] + | MInt{Width} ">uMInt" MInt{Width} [function, total, hook(MINT.ugt), smt-hook(bvugt)] + | MInt{Width} ">=sMInt" MInt{Width} [function, total, hook(MINT.sge), smt-hook(bvsge)] + | MInt{Width} ">=uMInt" MInt{Width} [function, total, hook(MINT.uge), smt-hook(bvuge)] + | MInt{Width} "==MInt" MInt{Width} [function, total, hook(MINT.eq), smt-hook(=)] + | MInt{Width} "=/=MInt" MInt{Width} [function, total, hook(MINT.ne), smt-hook(distinct)] +
    +

    MInt min/max

    +

    You can compute the signed minimum sMinMInt, the signed maximum sMaxMInt, +the unsigned minimum uMinMInt, and the unsigned maximum uMaxMInt of two +MInts.

    +
    k
    syntax {Width} MInt{Width} ::= sMaxMInt(MInt{Width}, MInt{Width}) [function, total, hook(MINT.smax), smt-hook((ite (bvslt #1 #2) #2 #1))] + | sMinMInt(MInt{Width}, MInt{Width}) [function, total, hook(MINT.smin), smt-hook((ite (bvslt #1 #2) #1 #2))] + | uMaxMInt(MInt{Width}, MInt{Width}) [function, total, hook(MINT.umax), smt-hook((ite (bvult #1 #2) #2 #1))] + | uMinMInt(MInt{Width}, MInt{Width}) [function, total, hook(MINT.umin), smt-hook((ite (bvult #1 #2) #1 #2))] +
    +

    MInt to MInt conversion

    +

    You can convert an MInt of one width to another width with roundMInt. +The resulting MInt will be truncated starting from the most significant bit +if the resulting width is smaller than the input. The resulting MInt will be +zero-extended with the same low-order bits if the resulting width is larger +than the input.

    +
    k
    syntax {Width1, Width2} MInt{Width1} ::= roundMInt(MInt{Width2}) [function, total, hook(MINT.round)] +
    +
    k
    endmodule +
    +

    Strategies

    +

    K supports a built-in strategy language that allows you to control how rules +apply. In order to enable it, simply import the STRATEGY module in your +definition. This includes the following basic strategy constructs:

    +
      +
    • ^ Category:#RuleTag - This is a strategy that indicates that you should +apply a rule with the specified category exactly once. By default, all rules +get the regular tag. This can be changed on individual rules with the tag +attribute.
    • +
    • ~ Category:#RuleTag - This is the state the strategy cell will be in +after a rule has applied. In other words, all rules that do not mention the +strategy cell are automatically instrumented so that they rewrite the current +top of the <s> cell from ^ to ~
    • +
    • <s> - This is the strategy cell and contains the current strategy.
    • +
    • #STUCK() - By default, a rule is automatically inserted into the definition +which adds #STUCK() to the top of the <s> cell if no other rules apply +and if it is not already at the top of the <s> cell.
    • +
    +
    k
    module STRATEGY + imports ML-SYNTAX + imports KVARIABLE-SYNTAX + imports private K-EQUAL + + syntax #RuleTag ::= #KVariable + + syntax Strategy ::= #STUCK() [symbol] + | "^" #RuleTag [symbol, klabel(#applyRule)] + | "~" #RuleTag [symbol, klabel(#appliedRule)] + + configuration <s> $STRATEGY:K </s> +endmodule + +module RULE-TAG-SYNTAX + imports BUILTIN-ID-TOKENS + + syntax #RuleTag ::= #LowerId [token] +endmodule +
    +

    This is not a complete strategy language. However, it provides several basics. +The user can extend this strategy language into a complete strategy language +in one of three ways. First, they can import the DEFAULT-STRATEGY module, +which provides a very basic strategy that is essentially equivalent to +execution without a strategy. This can be useful if you wish to wholly +manipulate the strategy cell yourself within other rules.

    +
    k
    module DEFAULT-STRATEGY-CONCRETE [concrete] + imports STRATEGY + imports RULE-TAG-SYNTAX + rule ~ regular => ^ regular [anywhere] +endmodule + +module DEFAULT-STRATEGY-SYMBOLIC [symbolic] + imports STRATEGY + imports RULE-TAG-SYNTAX + rule <s> ~ regular => ^ regular ... </s> +endmodule + +module DEFAULT-STRATEGY + imports STRATEGY + imports DEFAULT-STRATEGY-CONCRETE + imports DEFAULT-STRATEGY-SYMBOLIC + + rule initSCell(_) => <s> ^ regular </s> [priority(25)] +endmodule +
    +

    The second way you can extend the strategy language is with the +STRATEGY-ABSTRACT module. This provides a slightly more advanced set of +strategies which you can use to compose the basic strategies in the STRATEGY +module into more complex strategies. Note however that the functionality +provided is still relatively basic.

    +
    k
    module STRATEGY-ABSTRACT + imports STRATEGY + + syntax #RuleTag ::= "(" #RuleTag ")" [bracket] + // ---------------------------------------------- + + syntax Strategy ::= ".Strategy" + | "(" Strategy ")" [bracket] + // ---------------------------------------------- + rule <s> .Strategy => . ... </s> + + syntax KItem ::= #catchSTUCK ( Strategy ) + // ----------------------------------------- + rule <s> #catchSTUCK(_) => . ... </s> + rule <s> #STUCK() ~> (_S:Strategy => .) ... </s> + rule <s> #STUCK() ~> #catchSTUCK(S) => S ... </s> + + syntax Strategy ::= Strategy ";" Strategy [left] + // ------------------------------------------------ + rule <s> S:Strategy ; S':Strategy => S ~> S' ... </s> + + syntax #RuleTag ::= #RuleTag "|" #RuleTag [left, klabel(#alternateRule)] + // ------------------------------------------------------------------------ + rule <s> ^ RT:#RuleTag | RT':#RuleTag => ^ RT ~> #catchSTUCK(^ RT') ... </s> + + syntax #RuleTag ::= #RuleTag "*" [klabel(#repeatRule)] + // ------------------------------------------------------ + rule <s> ^ RT:#RuleTag * => ^ RT ~> ^ RT * ~> #catchSTUCK(.Strategy) ... </s> +endmodule +
    +

    The third mechanism for extending the strategy language is to define your own +strategy language. No special facility is required in K in order to compose +strategies together, so you are free to write whatever rules that manipulate +the strategy cell you want, and thus whatever more complex strategies you can +compose from the base builtin strategies.

    +
    +
    + + +
    + +
    +
    + + Basic Builtin Types in K + +
    +
    + + Arrays + + +
    +
    + + Maps + + +
    +
    + + Range Maps + + +
    +
    + + Sets + + +
    +
    + + Lists + + +
    +
    + + Booleans + + +
    +
    + + Integers + + +
    +
    + + IEEE 754 Floating-point Numbers + + +
    +
    + + Strings + + +
    +
    + + Byte Arrays + + +
    +
    + + I/O in K + + +
    +
    + + Machine Integers + + +
    + +
    +
    + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/include/kframework/builtin/ffi/index.html b/k-distribution/include/kframework/builtin/ffi/index.html new file mode 100644 index 00000000000..5a7ef4a0cb4 --- /dev/null +++ b/k-distribution/include/kframework/builtin/ffi/index.html @@ -0,0 +1,619 @@ + + + + + + + + + + + + + + +K Foreign Function Interface | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    K Foreign Function Interface

    +

    The K Foreign Function Interface (FFI) module provides a way to call native +functions directly from a K semantics using the C ABI. It also provides +utilities for allocating and deallocating byte buffers with static addresses +that are suitable for being passed to native code.

    +

    It is built off of the underlying libffi library +(https://sourceware.org/libffi/) and is subject to some of the same +limitations as that library. Bear in mind, because this library exposes +a number of unsafe C APIs directly, misuse of the library is likely to lead +to memory corruption in your interpreter and can cause segmentation faults or +corrupted term representations that lead to undefined behavior at runtime.

    +
    k
    require "domains.md" + +module FFI-SYNTAX + imports private LIST +
    +

    The FFIType sort is used to declare the native C ABI types of operands passed +to the #ffiCall function. These types roughly correspond to the types +declared in ffi.h by libffi.

    +
    k
    syntax FFIType ::= "#void" [klabel(#ffi_void), symbol] + | "#uint8" [klabel(#ffi_uint8), symbol] + | "#sint8" [klabel(#ffi_sint8), symbol] + | "#uint16" [klabel(#ffi_uint16), symbol] + | "#sint16" [klabel(#ffi_sint16), symbol] + | "#uint32" [klabel(#ffi_uint32), symbol] + | "#sint32" [klabel(#ffi_sint32), symbol] + | "#uint64" [klabel(#ffi_uint64), symbol] + | "#sint64" [klabel(#ffi_sint64), symbol] + | "#float" [klabel(#ffi_float), symbol] + | "#double" [klabel(#ffi_double), symbol] + | "#uchar" [klabel(#ffi_uchar), symbol] + | "#schar" [klabel(#ffi_schar), symbol] + | "#ushort" [klabel(#ffi_ushort), symbol] + | "#sshort" [klabel(#ffi_sshort), symbol] + | "#uint" [klabel(#ffi_uint), symbol] + | "#sint" [klabel(#ffi_sint), symbol] + | "#ulong" [klabel(#ffi_ulong), symbol] + | "#slong" [klabel(#ffi_slong), symbol] + | "#longdouble" [klabel(#ffi_longdouble), symbol] + | "#pointer" [klabel(#ffi_pointer), symbol] + | "#complexfloat" [klabel(#ffi_complexfloat), symbol] + | "#complexdouble" [klabel(#ffi_complexdouble), symbol] + | "#complexlongdouble" [klabel(#ffi_complexlongdouble), symbol] + | "#struct" "(" List ")" [klabel(#ffi_struct), symbol] +endmodule + +module FFI + imports FFI-SYNTAX + imports private BYTES + imports private STRING + imports private BOOL + imports private LIST + imports private INT + +
    +

    FFI Calls

    +

    The #ffiCall functions are designed to call a native C ABI function and +return a native result. They come in three variants:

    +

    Non-variadic

    +

    In the first variant, #ffiCall(Address, Args, ArgTypes, ReturnType) takes +an integer address of a function (which can be obtained from +#functionAddress), a List of Bytes containing the arguments of the +function, a List of FFITypes containing the types of the parameters of the +function, and an FFIType containing the return type of the function, and +returns the return value of the function as a Bytes.

    +
    k
    syntax Bytes ::= "#ffiCall" "(" Int "," List "," List "," FFIType ")" [function, hook(FFI.call)] +
    +

    Variadic

    +

    In the second variant, +#ffiCall(Address, Args, FixedTypes, VariadicTypes, ReturnType takes an +integer address of a function, a List of Bytes containing the arguments +of the call, a List of FFITypes containing the types of the fixed +parameters of the function, a List of FFITypes containing the types of the +variadic parameters of the function, and an FFIType containing the return +type of the function, and returns the return value of the function as a +Bytes.

    +
    k
    syntax Bytes ::= "#ffiCall" "(" Int "," List "," List "," List "," FFIType ")" [function, hook(FFI.call_variadic)] +
    +

    Generic

    +

    In the third variant, +#ffiCall(IsVariadic, Address, Args, ArgTypes, NFixed, ReturnType takes +a boolean indicating whether the function is variadic or not, an integer +address of a function, a List of Bytes containing the arguments of the +call, a List of FFITypes containing the parameter typess of the call +followed by the types of the variadic arguments of the call, if any, an Int +containing how many of the arguments of the call are fixed or not, and an +FFIType containing the return type of the function, and returns the return +value of the function as a Bytes.

    +
    k
    syntax Bytes ::= "#ffiCall" "(" Bool "," Int "," List "," List "," Int "," FFIType ")" [function] + + rule #ffiCall(false, Addr::Int, Args::List, Types::List, _, Ret::FFIType) => #ffiCall(Addr, Args, Types, Ret) + rule #ffiCall(true, Addr::Int, Args::List, Types::List, NFixed::Int, Ret::FFIType) => #ffiCall(Addr, Args, range(Types, 0, size(Types) -Int NFixed), range(Types, NFixed, 0), Ret) +
    +

    Symbol Lookup

    +

    The FFI module provides a mechanism to look up any function symbol and return +that function's address.

    +
    k
    syntax Int ::= "#functionAddress" "(" String ")" [function, hook(FFI.address)] +
    +

    Direct Memory Management

    +

    Most memory used by the LLVM backend to represent terms is managed +automatically via garbage collection. However, a consequence of this is that +a particular term does not have a fixed address across its entire lifetime +in most cases. Sometimes this is undesirable, especially if you intend for +the address of the memory to be taken by the semantics or if you intend +to pass this memory directly to native code. As a result, the FFI module +exposes the following unsafe APIs for memory management. Note that use of +these APIs leaves the burden of memory management completely on the user, +and thus misuse of these functions can lead to things like use-after-free +and other memory corruption bugs.

    +

    Allocation

    +

    #alloc(Key, Size, Align) will allocate Size bytes with an alignment +requirement of Align (which must be a power of two), and return it as a +Bytes term. The memory is uniquely identified by its key and that key will +be used later to free the memory. The memory is not implicitly freed by garbage +collection; failure to call #free on the memory at a later date can lead to +memory leaks.

    +
    k
    syntax Bytes ::= "#alloc" "(" KItem "," Int "," Int ")" [function, hook(FFI.alloc)] +
    +

    Addressing

    +

    #addess(B) will return an Int representing the address of the first byte of +B, which must be a Bytes. Unless the Bytes term was allocated by #alloc, +the return value is unspecified and may not be the same across multipl +invocations on the same byte buffer. However, it is guaranteed that memory +allocated by #alloc will have the same address throughout its lifetime.

    +
    k
    syntax Int ::= "#address" "(" Bytes ")" [function, hook(FFI.bytes_address)] +
    +

    Deallocation

    +

    #free(Key) will free the memory of the Bytes object that was allocated +by a previous call to #alloc. If Key was not used in a previous call to +#alloc, or the memory was already freed, no action is taken. It will generate +undefined behavior if the Bytes term returned by the previous call to +#alloc is still referenced by any other term in the configuration or a +currently evaluating rule. The function returns .K.

    +
    k
    syntax K ::= "#free" "(" KItem ")" [function, hook(FFI.free)] +
    +

    Reading

    +

    #nativeRead(Addr, Mem) will read native memory at address Addr into Mem, +reading exactly lengthBytes(Mem) bytes. This will generate undefined behavior +if Addr does not point to a readable segment of memory at least +lengthBytes(Mem) bytes long.

    +
    k
    syntax K ::= "#nativeRead" "(" Int "," Bytes ")" [function, hook(FFI.read)] +
    +

    Writing

    +

    #nativeWrite(Addr, Mem) will write the contents of Mem to native memory at +address Addr. The memory will be read prior to being written, and a write +will only happen if the memory has a different value than the current value of +Mem. This will generate undefined behavior if Addr does not point to a +readable segment of memory at least lengthBytes(Mem) bytes long, or if the +memory at address Addr has a different value than currently contained in +Mem, and the memory in question is not writeable.

    +
    k
    syntax K ::= "#nativeWrite" "(" Int "," Bytes ")" [function, hook(FFI.write)] +endmodule +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/include/kframework/builtin/json/index.html b/k-distribution/include/kframework/builtin/json/index.html new file mode 100644 index 00000000000..a319b21e0a9 --- /dev/null +++ b/k-distribution/include/kframework/builtin/json/index.html @@ -0,0 +1,428 @@ + + + + + + + + + + + + + + +Syntax of JSON | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Syntax of JSON

    +

    K provides builtin support for reading/writing to JSON. While the JSON-SYNTAX +module is not precisely the syntax of JSON (utilizing K's syntax for strings, +integers, and floating point numbers rather than the syntax used by JSON), +you can still convert directly to/from the actual syntax of JSON using +the JSON2String and String2JSON hooks.

    +
    k
    module JSON-SYNTAX + imports INT-SYNTAX + imports STRING-SYNTAX + imports BOOL-SYNTAX + imports FLOAT-SYNTAX + + syntax JSONs ::= List{JSON,","} [klabel(JSONs) , symbol] + syntax JSONKey ::= String + syntax JSON ::= "null" [klabel(JSONnull) , symbol] + | String | Int | Float | Bool + | JSONKey ":" JSON [klabel(JSONEntry) , symbol] + | "{" JSONs "}" [klabel(JSONObject) , symbol] + | "[" JSONs "]" [klabel(JSONList) , symbol] +endmodule +
    +

    Conversion between JSON and String

    +

    Given a string written in valid JSON, you can convert it to the JSON +sort with the String2JSON function. Assuming the user has not extended +the syntax of the JSON sort with their own constructors, any term of sort +JSON can also be converted to a String using the JSON2String function.

    +
    k
    module JSON + imports JSON-SYNTAX + + syntax String ::= JSON2String(JSON) [function, hook(JSON.json2string)] + + syntax JSON ::= String2JSON(String) [function, hook(JSON.string2json)] +endmodule +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/include/kframework/builtin/kast/index.html b/k-distribution/include/kframework/builtin/kast/index.html new file mode 100644 index 00000000000..a32605110b4 --- /dev/null +++ b/k-distribution/include/kframework/builtin/kast/index.html @@ -0,0 +1,966 @@ + + + + + + + + + + + + + + +K Language Features | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    K Language Features

    +

    Defined below is a series of modules used to parse inner syntax in K (ie, the +contents of rules, configuration declarations, and contexts).

    +

    Much of this file exists in tight correspondence with the K implementation, and +K will not work correctly if it is altered without corresponding changes to the +source code of the K tools.

    +

    Users should only import a few modules from this file. In particular, this +includes SORT-K, BASIC-K, ML-SYNTAX, DEFAULT-LAYOUT, +DEFAULT-CONFIGURATION, and K-AMBIGUITIES. The remaining modules should not +be imported by the user; they are used implicitly by the implementation of K.

    +

    Basic K Sorts

    +

    The SORT-K module declares the K sort, and nothing else.

    +
    k
    module SORT-K + syntax K [hook(K.K)] +endmodule +
    +

    The BASIC-K module declares the K, KItem, and KConfigVar sorts, and +imports the syntax of matching logic.

    +
    k
    module BASIC-K + imports ML-SYNTAX + imports SORT-BOOL + syntax KItem [hook(K.KItem)] + syntax K ::= KItem + syntax KConfigVar [token] + syntax KItem ::= KConfigVar +endmodule +
    +

    KAST Abstract Syntax

    +

    Below is defined the abstract syntax of concrete terms in K, the KAST syntax. +Users should rarely if ever have to refer to this syntax; in general, it +suffices to use concrete syntax in rules, configuration declarations, contexts, +etc.

    +

    This syntax is used directly by the K implementation, and exists here as a +reference for the syntax of KAST, but it should not be imported directly by +the user.

    +
    k
    module KSTRING + syntax KString ::= r"[\\\"](([^\\\"\\n\\r\\\\])|([\\\\][nrtf\\\"\\\\])|([\\\\][x][0-9a-fA-F]{2})|([\\\\][u][0-9a-fA-F]{4})|([\\\\][U][0-9a-fA-F]{8}))*[\\\"]" [token] + // optionally qualified strings, like in Scala "abc", i"abc", r"a*bc", etc. +endmodule + +module BUILTIN-ID-TOKENS + syntax #LowerId ::= r"[a-z][a-zA-Z0-9]*" [prec(2), token] + syntax #UpperId ::= r"[A-Z][a-zA-Z0-9]*" [prec(2), token] +endmodule + +module SORT-KBOTT + imports SORT-K + syntax KBott +endmodule + +module KAST + imports BASIC-K + imports SORT-KBOTT + imports KSTRING + imports BUILTIN-ID-TOKENS + + syntax KBott ::= "#token" "(" KString "," KString ")" [klabel(#KToken), symbol] + | "#klabel" "(" KLabel ")" [klabel(#WrappedKLabel), symbol] + | KLabel "(" KList ")" [klabel(#KApply), symbol] + syntax KItem ::= KBott + + syntax KLabel ::= r"`(\\\\`|\\\\\\\\|[^`\\\\\\n\\r])+`" [token] + | #LowerId [token] + | r"(?<![a-zA-Z0-9])[#a-z][a-zA-Z0-9]*" [token, prec(1)] + // something that doesn't collide with meta-variables + + syntax KList ::= K + | ".KList" [klabel(#EmptyKList), symbol] + | ".::KList" [klabel(#EmptyKList), symbol] + | KList "," KList [klabel(#KList), left, assoc, unit(#EmptyKList), symbol, prefer] +endmodule + + +// To be used when parsing/pretty-printing ground configurations +module KSEQ + imports KAST + imports K-TOP-SORT + syntax K ::= ".K" [klabel(#EmptyK), symbol, unparseAvoid] + | "." [klabel(#EmptyK), symbol] + | ".::K" [klabel(#EmptyK), symbol, unparseAvoid] + syntax K ::= K "~>" K [klabel(#KSequence), left, assoc, unit(#EmptyK), symbol] + syntax left #KSequence + syntax {Sort} Sort ::= "(" Sort ")" [bracket, group(defaultBracket), applyPriority(1)] +endmodule +
    +

    Syntax of Matching Logic

    +

    K provides direct access to the symbols of Matching Logic, while giving them +their own concrete syntax distinct from the syntax of the KORE intermediate +representation. These symbols are primarily used during symbolic execution. +The LLVM Backend has relatively little understanding of Matching Logic directly +and use of these symbols directly in rules is likely to cause it to crash. +However, these symbols are necessary when providing lemmas and other types of +logical assistance to proofs and symbolic execution in the Haskell Backend.

    +

    The correspondance between K symbols and KORE symbols is as follows:

    +
      +
    • #Top - \top
    • +
    • #Bottom - \bottom
    • +
    • #Not - \not
    • +
    • #Ceil - \ceil
    • +
    • #Floor - \floor
    • +
    • #Equals - \equals
    • +
    • #And - \and
    • +
    • #Or - \or
    • +
    • #Implies - \implies
    • +
    • #Exists - \exists
    • +
    • #Forall - \forall
    • +
    • #AG - allPathGlobally
    • +
    • #wEF - weakExistsFinally
    • +
    • #wAF - weakAlwaysFinally
    • +
    +
    k
    module ML-SYNTAX [not-lr1] + imports SORT-K + + syntax {Sort} Sort ::= "#Top" [klabel(#Top), symbol, group(mlUnary)] + | "#Bottom" [klabel(#Bottom), symbol, group(mlUnary)] + | "#True" [klabel(#Top), symbol, group(mlUnary), unparseAvoid] + | "#False" [klabel(#Bottom), symbol, group(mlUnary), unparseAvoid] + | "#Not" "(" Sort ")" [klabel(#Not), symbol, mlOp, group(mlUnary)] + + syntax {Sort1, Sort2} Sort2 ::= "#Ceil" "(" Sort1 ")" [klabel(#Ceil), symbol, mlOp, group(mlUnary)] + | "#Floor" "(" Sort1 ")" [klabel(#Floor), symbol, mlOp, group(mlUnary)] + | "{" Sort1 "#Equals" Sort1 "}" [klabel(#Equals), symbol, mlOp, group(mlEquals), comm, format(%1%i%n%2%d%n%3%i%n%4%d%n%5)] + + syntax priorities mlUnary > mlEquals > mlAnd + + syntax {Sort} Sort ::= Sort "#And" Sort [klabel(#And), symbol, assoc, left, comm, unit(#Top), mlOp, group(mlAnd), format(%i%1%d%n%2%n%i%3%d)] + > Sort "#Or" Sort [klabel(#Or), symbol, assoc, left, comm, unit(#Bottom), mlOp, format(%i%1%d%n%2%n%i%3%d)] + > Sort "#Implies" Sort [klabel(#Implies), symbol, mlOp, group(mlImplies), format(%i%1%d%n%2%n%i%3%d)] + + syntax priorities mlImplies > mlQuantifier + + syntax {Sort1, Sort2} Sort2 ::= "#Exists" Sort1 "." Sort2 [klabel(#Exists), symbol, mlOp, mlBinder, group(mlQuantifier)] + | "#Forall" Sort1 "." Sort2 [klabel(#Forall), symbol, mlOp, mlBinder, group(mlQuantifier)] + + syntax {Sort} Sort ::= "#AG" "(" Sort ")" [klabel(#AG), symbol, mlOp] + | "#wEF" "(" Sort ")" [klabel(weakExistsFinally), symbol, mlOp] + | "#wAF" "(" Sort ")" [klabel(weakAlwaysFinally), symbol, mlOp] +endmodule +
    +

    Variables in K

    +

    Provided below is the syntax of variables in K. There are four types of +variables in K:

    +
      +
    1. Regular variables. These are denoted by variables that begin with an +underscore or a capital letter. These variables match exactly one value +and can be used to refer to it on the right-hand-side.
    2. +
    3. Fresh constants. These are denoted by variables that begin with an !. This +is a convenience syntax which can be used on the right-hand-side only, and +refer to a unique value of the specified sort which is distinct from any +other value that has been generated or will be generated by the !X syntax. +Note that this may not be distinct from values produced via other means.
    4. +
    5. Existential variables. This refers to variables that are existentially +quantified and begin with a ?. They are not required to appear on the +left-hand-side prior to appearing on the right-hand-side, and generally +refer to symbolic quantities that are introduced during rewriting. Refer to +K's documentation for more details.
    6. +
    7. Set variables. These are denoted by variables that begin with a @. +These variables refer to a set of values and are generally used when writing +simplification rules in the Haskell Backend. For more information, refer to +K's documentation.
    8. +
    +

    There is also a fifth type of "variable", although it is not technically a +variable. This refers to configuration variables, which are used to insert +values into the initial configuration that come from outside the semantics. +The most common of these is the $PGM variable, which conventionally contains +the program being executed and is placed in the <k> cell in the configuration +declaration. These "variables" begin with a $ and their values are populated +by the frontend prior to symbolic or concrete execution of a program.

    +
    k
    module KVARIABLE-SYNTAX + syntax #KVariable +endmodule + +// To be used when parsing/pretty-printing symbolic configurations +module KSEQ-SYMBOLIC + imports KSEQ + imports ML-SYNTAX + imports KVARIABLE-SYNTAX + + syntax #KVariable ::= r"(?<![A-Za-z0-9_\\$!\\?@])(\\!|\\?|@)?([A-Z][A-Za-z0-9'_]*|_|_[A-Z][A-Za-z0-9'_]*)" [token, prec(1)] + | #UpperId [token] + syntax KConfigVar ::= r"(?<![A-Za-z0-9_\\$!\\?@])(\\$)([A-Z][A-Za-z0-9'_]*)" [token] + syntax KBott ::= #KVariable + syntax KBott ::= KConfigVar + syntax KLabel ::= #KVariable +endmodule +
    +

    Syntax of Cells

    +

    While the backend treats cells as regular productions like any other, the +frontend provides a significant amount of convenience notation for dealing with +groups of cells, in order to make writing modular definitions easier. As a +result, we need a syntax for groups of cells and for referring to cells within +rules, configuration declarations, and functions.

    +

    For historical reasons, the Bag sort is used to refer to groups of cells. +This may change in a future release. Users can combine cells in any order +by concatenating them together, and can refer to the absence of any cells with +the .Bag symbol. You can also refer to cells within a function by placing +the cell context symbol, [[ K ]] at the top of a rule, placing a function +symbol inside, and referring to cells afterwards. This implicitly inserts +a reference to the configuration at the time prior to the currently-applied +rule being applied which can be matched on within the function. Functions with +such context cannot be referred to in the initial configuration, because the +prior configuration does not yet exist.

    +
    k
    module KCELLS + imports KAST + + syntax Cell + syntax Bag ::= Bag Bag [left, assoc, klabel(#cells), symbol, unit(#cells)] + | ".Bag" [klabel(#cells), symbol] + | ".::Bag" [klabel(#cells), symbol] + | Cell + syntax Bag ::= "(" Bag ")" [bracket] + syntax KItem ::= Bag + syntax #RuleBody ::= "[" "[" K "]" "]" Bag [klabel(#withConfig), symbol, avoid] + syntax non-assoc #withConfig + syntax Bag ::= KBott +endmodule +
    +

    Users can also refer to cells in rules. When doing so, an optional ... can +be placed immediately after the start of the cell or immediately before the +end. In a cell whose contents are commutative, these are equivalent to one +another and are also equivalent to placing ... in both places. This means +that what is placed in the cell will be combined with the cell contents' +concatenation operator with an unnamed variable. In other words, you match on +some number of elements in the collection and do not care about the rest of +the collection.

    +

    In a cell whose contents are not commutative, the ... operators correspond +to a variable on the respective side of the contents of the cell that the +... appears. For example, <foo>... L </foo>, if L is a list, means +some number of elements followed by L. Note that not all combinations are +supported. Cells whose contents are sort K can only have ... appear at the +tail of the cell, and cells whose contents are sort List can only have ... +appear on at most one side in a single rule.

    +
    k
    module RULE-CELLS + imports KCELLS + imports RULE-LISTS + // if this module is imported, the parser automatically + // generates, for all productions that have the attribute 'cell' or 'maincell', + // a production like below: + //syntax Cell ::= "<top>" #OptionalDots K #OptionalDots "</top>" [klabel(<top>)] + + syntax #OptionalDots ::= "..." [klabel(#dots), symbol] + | "" [klabel(#noDots), symbol] + + syntax Int + // this production will be added by the compiler to help handle bang variables, + // however, it is valuable to put it here because without this production, it + // will not exist at the point in time when rules and claims are parsed, and + // as a result it makes it very difficult to write proof claims over fragments + // of code that exercise rules containing bang variables. We put it here because + // this production will "vanish" after parsing finishes and not be picked up + // by the compiler, which is the behavior we want in this case since an actual + // production will be generated by the compiler later on. + syntax GeneratedCounterCell ::= "<generatedCounter>" Int "</generatedCounter>" [cell, klabel(<generatedCounter>), symbol, internal] +endmodule +
    +

    Users can also declare cells in a configuration declaration. This generates a +specific set of productions that is used internally to implement the cell. The +most important of these is the cell itself, and attributes on this production +can be specified in an xml-attribute-like syntax.

    +

    You can also use an xml-short-tag-like syntax to compose configuration cells +together which were defined in different modules. However, it is a requirement +that any K definition have at most one fully-composed configuration; thus, all +other configuration declarations must appear composed within another +configuration declaration.

    +
    k
    module CONFIG-CELLS + imports KCELLS + imports RULE-LISTS + syntax #CellName ::= r"[a-zA-Z][a-zA-Z0-9\\-]*" [token, prec(1)] + | #LowerId [token] + | #UpperId [token] + + syntax Cell ::= "<" #CellName #CellProperties ">" K "</" #CellName ">" [klabel(#configCell), symbol] + syntax Cell ::= "<" #CellName "/>" [klabel(#externalCell), symbol] + + syntax #CellProperties ::= #CellProperty #CellProperties [klabel(#cellPropertyList), symbol] + | "" [klabel(#cellPropertyListTerminator), symbol] + syntax #CellProperty ::= #CellName "=" KString [klabel(#cellProperty), symbol] +endmodule +
    +

    Syntax of Rules

    +

    Rules can have an optional requires clause or an ensures clause. For backwards- +compatibility, you can refer to the requires clause with both the requires +and when keywords; The latter, however, is deprecated and may be removed in +a future release.

    +

    The requires clause specifies the preconditions that must be true in order +for the rule to apply. The ensures clause specifies the information which +becomes true after the rule has applied. It is a requirement that information +present in the ensures clause refer to existential variables only.

    +

    When doing concrete execution, you can think of the requires clause as a +side-condition. In other words, even if the rule matches, it will not apply +unless the requires clause, which must be of sort Bool, evaluates to +true.

    +
    k
    module REQUIRES-ENSURES + imports BASIC-K + + syntax #RuleBody ::= K + + syntax #RuleContent ::= #RuleBody [klabel("#ruleNoConditions"), symbol] + | #RuleBody "requires" Bool [klabel("#ruleRequires"), symbol] + | #RuleBody "when" Bool [klabel("#ruleRequires"), symbol] + | #RuleBody "ensures" Bool [klabel("#ruleEnsures"), symbol] + | #RuleBody "requires" Bool "ensures" Bool [klabel("#ruleRequiresEnsures"), symbol] + | #RuleBody "when" Bool "ensures" Bool [klabel("#ruleRequiresEnsures"), symbol] +endmodule +
    +

    Miscellaneous modules

    +

    The below modules are used in various ways as indicators to the implementation +that certain automatically generated syntax should be created by the parser. +These modules should not be imported directly by the user.

    +
    k
    module K-TOP-SORT + imports SORT-KBOTT + syntax KItem ::= KBott + syntax {Sort} KItem ::= Sort +endmodule + +module K-BOTTOM-SORT + imports SORT-KBOTT + syntax KItem ::= KBott + syntax {Sort} Sort ::= KBott +endmodule + +module K-SORT-LATTICE + imports K-TOP-SORT + imports K-BOTTOM-SORT +endmodule + +module AUTO-CASTS + // if this module is imported, the parser automatically + // generates, for all sorts, productions of the form: + // Sort ::= Sort ":Sort" // semantic cast - force the inner term to be `Sort` or a subsort + // Sort ::= Sort "::Sort" // strict cast - force the inner term to be exactly `Sort`. Useful for disambiguation + // Sort ::= "{" Sort "}" "<:Sort" // synonym for strict cast + // Sort ::= "{" K "}" ":>Sort" // projection cast. Allows any term to be placed in a context that expects `Sort` + // this is part of the mechanism that allows concrete user syntax in K +endmodule + +module AUTO-FOLLOW + // if this module is imported, the parser automatically + // generates a follow restriction for every terminal which is a prefix + // of another terminal. This is useful to prevent ambiguities such as: + // syntax K ::= "a" + // syntax K ::= "b" + // syntax K ::= "ab" + // syntax K ::= K K + // #parse("ab", "K") + // In the above example, the terminal "a" is not allowed to be followed by a "b" + // because it would turn the terminal into the terminal "ab". +endmodule + +module PROGRAM-LISTS + imports SORT-K + // if this module is imported, the parser automatically + // replaces the default productions for lists: + // Es ::= E "," Es [userList("*"), klabel('_,_)] + // | ".Es" [userList("*"), klabel('.Es)] + // into a series of productions more suitable for programs: + // Es#Terminator ::= "" [klabel('.Es)] + // Ne#Es ::= E "," Ne#Es [klabel('_,_)] + // | E Es#Terminator [klabel('_,_)] + // Es ::= Ne#Es + // | Es#Terminator // if the list is * +endmodule + +module RULE-LISTS + // if this module is imported, the parser automatically + // adds the subsort production to the parsing module only: + // Es ::= E [userList("*")] + +endmodule + +module RECORD-PRODUCTIONS + // if this module is imported, prefix productions of the form + // syntax Sort ::= name(Args) + // will be able to be parsed with don't-care variables according + // to their nonterminal's names +endmodule + +module SORT-PREDICATES + // if this module is imported, the Bool sort will be annotated with + // syntax Bool ::= isSort(K) [function] + // and all sorts will be annotated with + // syntax Sort ::= project:Sort(K) [function] +endmodule +
    +

    Additional Syntax for K Terms in Rules

    +

    Certain additional features are available when parsing the contents of rules +and contexts. For more information on each of these, refer to K's +documentation.

    +
    k
    module KREWRITE + syntax {Sort} Sort ::= Sort "=>" Sort [klabel(#KRewrite), symbol] + syntax non-assoc #KRewrite + syntax priority #KRewrite > #withConfig +endmodule + +// To be used to parse semantic rules +module K + imports KSEQ-SYMBOLIC + imports REQUIRES-ENSURES + imports RECORD-PRODUCTIONS + imports SORT-PREDICATES + imports K-SORT-LATTICE + imports AUTO-CASTS + imports AUTO-FOLLOW + imports KREWRITE + + syntax {Sort} Sort ::= Sort "#as" Sort [klabel(#KAs), symbol] + // functions that preserve sorts and can therefore have inner rewrites + syntax {Sort} Sort ::= "#fun" "(" Sort ")" "(" Sort ")" [klabel(#fun2), symbol, prefer] + // functions that do not preserve sort and therefore cannot have inner rewrites + syntax {Sort1, Sort2} Sort1 ::= "#fun" "(" Sort2 "=>" Sort1 ")" "(" Sort2 ")" [klabel(#fun3), symbol] + + syntax {Sort1, Sort2} Sort1 ::= "#let" Sort2 "=" Sort2 "#in" Sort1 [klabel(#let), symbol] + + /*@ Set membership over terms. In addition to equality over + concrete patterns, K also supports computing equality + between a concrete pattern and a symbolic pattern. + This is compiled efficiently down to pattern matching, + and can be used by putting a term with unbound variables + in the left child of :=K or =/=K. Note that this does not + bind variables used on the lhs however (although this may + change in the future).*/ + + syntax Bool ::= left: + K ":=K" K [function, total, klabel(_:=K_), symbol, group(equalEqualK)] + | K ":/=K" K [function, total, klabel(_:/=K_), symbol, group(notEqualEqualK)] +endmodule + +// To be used to parse terms in full K +module K-TERM + imports KSEQ-SYMBOLIC + imports RECORD-PRODUCTIONS + imports SORT-PREDICATES + imports K-SORT-LATTICE + imports AUTO-CASTS + imports AUTO-FOLLOW + imports KREWRITE +endmodule +
    +

    Layout Information

    +

    When constructing a scanner for use during parsing, often you wish to ignore +certain types of text, such as whitespace and comments. However, the specific +syntax which each language must ignore is a little different from language +to language, and thus you wish to specify it manually. You can do this by +defining productions of the #Layout sort. For more information, refer to +K's documentation. However, this module will be implicitly imported if no +productions are declared of sort #Layout. This module will also be used +for the purposes of parsing K rules. If you wish to declare a language with +no layout productions, simply create a sort declaration for the #Layout sort +in your code (e.g. syntax #Layout).

    +
    k
    module DEFAULT-LAYOUT + syntax #Layout ::= r"(\\/\\*([^\\*]|(\\*+([^\\*\\/])))*\\*+\\/)" // C-style multi-line comments + | r"(\\/\\/[^\\n\\r]*)" // C-style single-line comments + | r"([\\ \\n\\r\\t])" // Whitespace +endmodule +
    +

    Default Configuration

    +

    If the user has no configuration declaration in their seamantics, the below +configuration declaration will be implicitly imported.

    +
    k
    module DEFAULT-CONFIGURATION + imports BASIC-K + + configuration <k> $PGM:K </k> +endmodule +
    +

    Parsing Ambiguous Languages

    +

    On occasion, it may be desirable to parse a language with an ambiguous grammar +when parsing a program, and perform additional semantic analysis at a later +time in order to resolve the ambiguities. A good example of this is as a +substitute for the lexer hack in parsers of the C programming language.

    +

    The following module contains a declaration for ambiguities in K. Usually, +an ambiguous parse is an error. However, when you use the --gen-glr-parser +flag to kast, or the --gen-glr-bison-parser flag to kompile, ambiguities +instead become instances of the below parametric production, which you can use +regular K rules to disambiguate as necessary.

    +
    k
    module K-AMBIGUITIES + + syntax {Sort} Sort ::= amb(Sort, Sort) [symbol] + +endmodule +
    +

    Annotating Parses with Locations

    +

    Another feature of K's Bison parser is the ability to annotate terms parsed +with location information about the file and line where they occurred. For +more information about how to use this, refer to K's documentation. However, +the below module exists to provide a user syntax for the annotations that +are generated by the parser.

    +
    k
    module K-LOCATIONS + imports STRING-SYNTAX + imports INT-SYNTAX + + // filename, startLine, startCol, endLine, endCol + syntax {Sort} Sort ::= #location(Sort, String, Int, Int, Int, Int) [symbol, format(%3)] + +endmodule +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/include/kframework/builtin/prelude/index.html b/k-distribution/include/kframework/builtin/prelude/index.html new file mode 100644 index 00000000000..143f72c69b4 --- /dev/null +++ b/k-distribution/include/kframework/builtin/prelude/index.html @@ -0,0 +1,399 @@ + + + + + + + + + + + + + + +K Prelude | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    K Prelude

    +

    The following files, integral to defining semantics in K, are automatically +required by every definition via this file. This behavior can be disabled +via kompile --no-prelude, however, semantics will likely break unless +they provide their own versions of these files, which are assumed to exist +by the compiler. There are, however, circumstances where passing this flag is +appropriate, such as if you are manually requiring these files in your +definition, if your definition was automatically condensed into a single file +with kompile -E, or if you wish to modify the inner syntax of K by providing +your own version of these files with different syntax.

    +
    k
    require "kast.md" +require "domains.md" +
    +
    +
    + + +
    + + + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/include/kframework/builtin/rat/index.html b/k-distribution/include/kframework/builtin/rat/index.html new file mode 100644 index 00000000000..1fcaea2cce8 --- /dev/null +++ b/k-distribution/include/kframework/builtin/rat/index.html @@ -0,0 +1,620 @@ + + + + + + + + + + + + + + +Rational Numbers in K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Rational Numbers in K

    +

    K provides support for arbitrary-precision rational numbers represented as a +quotient between two integers. The sort representing these values is Rat. +Int is a subsort of Rat, and it is guaranteed that any integer will be +represented as an Int and can be matched as such on the left hand side +of rules. K also supports the usual arithmetic operators over rational numbers.

    +
    k
    module RAT-SYNTAX + imports INT-SYNTAX + imports private BOOL + + syntax Rat + + syntax Rat ::= Int +
    +

    Arithmetic

    +

    You can:

    +
      +
    • Raise a rational number to any negative or nonnegative integer.
    • +
    • Multiply or divide two rational numbers to obtain a product or quotient.
    • +
    • Add or subtract two rational numbers to obtain a sum or difference.
    • +
    +
    k
    syntax Rat ::= left: + Rat "^Rat" Int [function, total, klabel(_^Rat_), symbol, smtlib(ratpow), hook(RAT.pow)] + > left: + Rat "*Rat" Rat [function, total, klabel(_*Rat_), symbol, left, smtlib(ratmul), hook(RAT.mul)] + | Rat "/Rat" Rat [function, klabel(_/Rat_), symbol, left, smtlib(ratdiv), hook(RAT.div)] + > left: + Rat "+Rat" Rat [function, total, klabel(_+Rat_), symbol, left, smtlib(ratadd), hook(RAT.add)] + | Rat "-Rat" Rat [function, total, klabel(_-Rat_), symbol, left, smtlib(ratsub), hook(RAT.sub)] +
    +

    Comparison

    +

    You can determine whether two rational numbers are equal, unequal, or compare +one of less than, less than or equalto, greater than, or greater than or equal +to the other:

    +
    k
    syntax Bool ::= Rat "==Rat" Rat [function, total, klabel(_==Rat_), symbol, smtlib(rateq), hook(RAT.eq)] + | Rat "=/=Rat" Rat [function, total, klabel(_=/=Rat_), symbol, smtlib(ratne), hook(RAT.ne)] + | Rat ">Rat" Rat [function, total, klabel(_>Rat_), symbol, smtlib(ratgt), hook(RAT.gt)] + | Rat ">=Rat" Rat [function, total, klabel(_>=Rat_), symbol, smtlib(ratge), hook(RAT.ge)] + | Rat "<Rat" Rat [function, total, klabel(_<Rat_), symbol, smtlib(ratlt), hook(RAT.lt)] + | Rat "<=Rat" Rat [function, total, klabel(_<=Rat_), symbol, smtlib(ratle), hook(RAT.le)] +
    +

    Min/Max

    +

    You can compute the minimum and maximum of two rational numbers:

    +
    k
    syntax Rat ::= minRat(Rat, Rat) [function, total, klabel(minRat), symbol, smtlib(ratmin), hook(RAT.min)] + | maxRat(Rat, Rat) [function, total, klabel(maxRat), symbol, smtlib(ratmax), hook(RAT.max)] +
    +

    Conversion to Floating Point

    +

    You can convert a rational number to the nearest floating point number that +is representable in a Float of a specified number of precision and exponent +bits:

    +
    k
    syntax Float ::= Rat2Float(Rat, precision: Int, exponentBits: Int) [function] +endmodule +
    +

    Implementation of Rational Numbers

    +

    The remainder of this file consists of an implementation in K of the +operations listed above. Users of the RAT module should not use any of the +syntax defined in any of these modules.

    +

    As a point of reference for users, it is worth noting that rational numbers +are normalized to a canonical form by this module,. with the canonical form +bearing the property that it is either an Int, or a pair of integers +I /Rat J such that +I =/=Int 0 andBool J >=Int 2 andBool gcdInt(I, J) ==Int 1 is always true.

    +
    k
    module RAT-COMMON + imports RAT-SYNTAX + + // invariant of < I , J >Rat : I =/= 0, J >= 2, and I and J are coprime + syntax Rat ::= "<" Int "," Int ">Rat" [format(%2 /Rat %4)] +endmodule + +module RAT-SYMBOLIC [symbolic, kore] + imports private RAT-COMMON + imports ML-SYNTAX + imports private BOOL + + rule + #Ceil(@R1:Rat /Rat @R2:Rat) + => + {(@R2 =/=Rat 0) #Equals true} #And #Ceil(@R1) #And #Ceil(@R2) + [simplification] +endmodule + +module RAT-KORE [kore] + imports private RAT-COMMON + imports private K-EQUAL + + /* + * equalities + */ + + // NOTE: the two rules below may not work correctly in non-kore backends + + rule R ==Rat S => R ==K S + + rule R =/=Rat S => R =/=K S +endmodule + +module RAT [private] + imports private RAT-COMMON + imports public RAT-SYMBOLIC + imports public RAT-KORE + imports public RAT-SYNTAX + imports private INT + imports private BOOL + + /* + * arithmetic + */ + + rule < I , I' >Rat +Rat < J , J' >Rat => ((I *Int J') +Int (I' *Int J)) /Rat (I' *Int J') + rule I:Int +Rat < J , J' >Rat => ((I *Int J') +Int J) /Rat J' + rule < J , J' >Rat +Rat I:Int => I +Rat < J , J' >Rat + rule I:Int +Rat J:Int => I +Int J + + rule < I , I' >Rat *Rat < J , J' >Rat => (I *Int J) /Rat (I' *Int J') + rule I:Int *Rat < J , J' >Rat => (I *Int J) /Rat J' + rule < J , J' >Rat *Rat I:Int => I *Rat < J , J' >Rat + rule I:Int *Rat J:Int => I *Int J + + rule < I , I' >Rat /Rat < J , J' >Rat => (I *Int J') /Rat (I' *Int J) + rule I:Int /Rat < J , J' >Rat => (I *Int J') /Rat J + rule < I , I' >Rat /Rat J:Int => I /Rat (I' *Int J) requires J =/=Int 0 + rule I:Int /Rat J:Int => makeRat(I, J) requires J =/=Int 0 + + // derived + + rule R -Rat S => R +Rat (-1 *Rat S) + + // normalize + + syntax Rat ::= makeRat(Int, Int) [function] + | makeRat(Int, Int, Int) [function] + + rule makeRat(0, J) => 0 requires J =/=Int 0 + + rule makeRat(I, J) => makeRat(I, J, gcdInt(I,J)) requires I =/=Int 0 andBool J =/=Int 0 + + // makeRat(I, J, D) is defined when I =/= 0, J =/= 0, D > 0, and D = gcd(I,J) + rule makeRat(I, J, D) => I /Int D requires J ==Int D // implies J > 0 since D > 0 + rule makeRat(I, J, D) => < I /Int D , J /Int D >Rat requires J >Int 0 andBool J =/=Int D + rule makeRat(I, J, D) => makeRat(0 -Int I, 0 -Int J, D) requires J <Int 0 + + // gcdInt(a,b) computes the gcd of |a| and |b|, which is positive. + syntax Int ::= gcdInt(Int, Int) [function, public] + + rule gcdInt(A, 0) => A requires A >Int 0 + rule gcdInt(A, 0) => 0 -Int A requires A <Int 0 + rule gcdInt(A, B) => gcdInt(B, A %Int B) requires B =/=Int 0 // since |A %Int B| = |A| %Int |B| + + /* + * exponentiation + */ + + rule _ ^Rat 0 => 1 + rule 0 ^Rat N => 0 requires N =/=Int 0 + + rule < I , J >Rat ^Rat N => powRat(< I , J >Rat, N) requires N >Int 0 + rule X:Int ^Rat N => X ^Int N requires N >Int 0 + + rule X ^Rat N => (1 /Rat X) ^Rat (0 -Int N) requires X =/=Rat 0 andBool N <Int 0 + + // exponentiation by squaring + + syntax Rat ::= powRat(Rat, Int) [function] + + // powRat(X, N) is defined when X =/= 0 and N > 0 + rule powRat(X, 1) => X + rule powRat(X, N) => powRat(X *Rat X, N /Int 2) requires N >Int 1 andBool N %Int 2 ==Int 0 + rule powRat(X, N) => powRat(X, N -Int 1) *Rat X requires N >Int 1 andBool N %Int 2 =/=Int 0 + + /* + * inequalities + */ + + rule R >Rat S => R -Rat S >Rat 0 requires S =/=Rat 0 + + rule < I , _ >Rat >Rat 0 => I >Int 0 + rule I:Int >Rat 0 => I >Int 0 + + // derived + + rule R >=Rat S => notBool R <Rat S + + rule R <Rat S => S >Rat R + + rule R <=Rat S => S >=Rat R + + rule minRat(R, S) => R requires R <=Rat S + rule minRat(R, S) => S requires S <=Rat R + + rule maxRat(R, S) => R requires R >=Rat S + rule maxRat(R, S) => S requires S >=Rat R + + syntax Float ::= #Rat2Float(Int, Int, Int, Int) [function, hook(FLOAT.rat2float)] + rule Rat2Float(Num:Int, Prec:Int, Exp:Int) => #Rat2Float(Num, 1, Prec, Exp) + rule Rat2Float(< Num, Dem >Rat, Prec, Exp) => #Rat2Float(Num, Dem, Prec, Exp) + +endmodule +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/include/kframework/builtin/substitution/index.html b/k-distribution/include/kframework/builtin/substitution/index.html new file mode 100644 index 00000000000..1252c0b6080 --- /dev/null +++ b/k-distribution/include/kframework/builtin/substitution/index.html @@ -0,0 +1,484 @@ + + + + + + + + + + + + + + +Capture-Aware Substitution in K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Capture-Aware Substitution in K

    +

    One of the traditional ways in which functional languages are given operational +semantics is via substitution. In particular, you can view a function as +declaring a particular bound variable, the parameter of the function, as well +as the body of the function, within which both bound and free variables can +occur, and implement the process of beta-reduction (one of the axioms of the +lambda calculus) by means of a substitution operator which is aware of the +difference between free variables and bound variables and prevents variable +capture.

    +

    In K this is implemented using two mechanisms: The KVar sort, and the +binder attribute.

    +

    The KVar Sort

    +

    K introduces a new hooked sort, KVar, which the substitution operator +(defined below) understands in a particular way. The syntax of KVar is the +same as for sort Id in DOMAINS, but with a different sort name. Similarly, +some of the same operators are defined over KVar which are defined for Id, +such as conversion from String to KVar and support for the !Var:KVar +syntax.

    +

    A KVar is simply an identifier with special meaning during substitution. +KVars must begin with a letter or underscore, +and can be followed by zero or more letters, numbers, or underscores.

    +
    k
    module KVAR-SYNTAX-PROGRAM-PARSING + imports BUILTIN-ID-TOKENS + + syntax KVar ::= r"(?<![A-Za-z0-9\\_])[A-Za-z\\_][A-Za-z0-9\\_]*" [prec(1), token] + | #LowerId [token] + | #UpperId [token] +endmodule + +module KVAR-SYNTAX + syntax KVar [token, hook(KVAR.KVar)] +endmodule + +module KVAR-COMMON + imports KVAR-SYNTAX + imports private STRING + + syntax KVar ::= String2KVar (String) [function, total, hook(STRING.string2token)] + syntax KVar ::= freshKVar(Int) [freshGenerator, function, total, private] + + rule freshKVar(I:Int) => String2KVar("_" +String Int2String(I)) +endmodule + +module KVAR + imports KVAR-COMMON +endmodule +
    +

    The binder Attribute

    +

    A production can be given the attribute binder. Such a production must have +at least two nonterminals. The first nonterminal from left to right must be of +sort KVar, and contains the bound variable. The last nonterminal from left +to right contains the term that is bound. For example, I could describe lambdas +in the lambda calculus with the production +syntax Val ::= "lambda" KVar "." Exp [binder].

    +

    Substitution

    +

    K provides a hooked implementation of substitution, currently only implemented +on the Java and LLVM backends. Two variants exist: the first substitutes +a single KVar for a single KItem. The second takes a Map with KVar +keys and KItem values, and substitutes each element in the map atomically.

    +

    Internally, this is implemented in the LLVM backend by a combination of +de Bruijn indices for bound variables and names for free variables. Free +variables are also sometimes given a unique numeric identifier in order to +prevent capture, and the rewriter will automatically assign unique names to +such identifiers when rewriting finishes. The names assigned will always begin +with the original name of the variable and be followed by a unique integer +suffix. However, the names assigned after rewriting finishes might be different +from the names that would be assigned if rewriting were to halt prematurely, +for example due to krun --depth.

    +
    k
    module SUBSTITUTION + imports private MAP + imports KVAR + + syntax {Sort} Sort ::= Sort "[" KItem "/" KItem "]" [function, hook(SUBSTITUTION.substOne), impure] + syntax {Sort} Sort ::= Sort "[" Map "]" [function, hook(SUBSTITUTION.substMany), impure] +endmodule +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/include/kframework/index.html b/k-distribution/include/kframework/index.html new file mode 100644 index 00000000000..8bdab9b108b --- /dev/null +++ b/k-distribution/include/kframework/index.html @@ -0,0 +1,405 @@ + + + + + + + + + + + + + + +K Builtins | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    K Builtins

    +

    The K Builtins (also referred to as the K Prelude or the K Standard Library) +consists of several files which contain definitions that make working with K +simpler. These files can be found under include/kframework/builtin in your K +installation directory, and can be imported with requires "FILENAME" (without +the path prefix).

    +
      +
    • domains: Basic datatypes which are universally useful.
    • +
    • kast: Representation of K internal data-structures (not to be +included in normal definitions).
    • +
    • prelude: Automatically included into every K definition.
    • +
    • ffi: FFI interface for calling out to native C code from K.
    • +
    • json: JSON datatype and parsers/unparsers for JSON strings.
    • +
    • rat: Rational number representation.
    • +
    • substitution: Hooked implementation of capture-aware +sustitution for K definitions.
    • +
    • unification: Hooked implementation of unification +exposed directly to K definitions.
    • +
    +
    +
    + + +
    + + + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/01_installing/index.html b/k-distribution/k-tutorial/1_basic/01_installing/index.html new file mode 100644 index 00000000000..ba478c02f06 --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/01_installing/index.html @@ -0,0 +1,473 @@ + + + + + + + + + + + + + + +Lesson 1.1: Setting up a K Environment | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.1: Setting up a K Environment

    +

    The first step to learning K is to install K on your system, and configure your +editor for K development.

    +

    Installing K

    +

    You have two options for how to install K, depending on how you intend to +interact with the K codebase. If you are solely a user of K, and have no +interest in developing or making changes to K, you most likely will want to +install one of our binary releases of K. However, if you are going to be a K +developer, or simply want to build K from source, you should follow the +instructions for a source build of K.

    +

    Installing K from a binary release

    +

    K is developed as a rolling release, with each change to K that passes our +CI infrastructure being deployed on GitHub for download. The latest release of +K can be downloaded here. +This page also contains information on how to install K. It is recommended +that you fully uninstall the old version of K prior to installing the new one, +as K does not maintain entries in package manager databases, with the exception +of Homebrew on MacOS.

    +

    Installing K from source

    +

    You can clone K from GitHub with the following Git command:

    +
    git clone https://github.com/runtimeverification/k --recursive
    +
    +

    Instructions on how to build K from source can be found +here.

    +

    Configuring your editor

    +

    K maintains a set of scripts for a variety of text editors, including vim and +emacs, in various states of maintenance. You can download these scripts with +the following Git command:

    +
    git clone https://github.com/kframework/k-editor-support
    +
    +

    Because K allows users to define their own grammars for parsing K itself, +not all features of K can be effectively highlighted. However, at the cost of +occasionally highlighting things incorrectly, you can get some pretty good +results in many cases. With that being said, some of the editor scripts in the +above repository are pretty out of date. If you manage to improve them, we +welcome pull requests into the repository.

    +

    Troubleshooting

    +

    If you have problems installing K, we encourage you to reach out to us. If you +follow the above install instructions and run into a problem, you can +Create a bug report on GitHub

    +

    Next lesson

    +

    Once you have set up K on your system to your satisfaction, you can continue to +Lesson 1.2: Basics of Functional K.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/02_basics/index.html b/k-distribution/k-tutorial/1_basic/02_basics/index.html new file mode 100644 index 00000000000..5a48d1f608e --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/02_basics/index.html @@ -0,0 +1,612 @@ + + + + + + + + + + + + + + +Lesson 1.2: Basics of Functional K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.2: Basics of Functional K

    +

    The purpose of this lesson is to explain the basics of productions and +rules in K. These are two types of K sentences. A K file consists of +one or more requires or modules in K. Each module consists of one or +more imports or sentences. For more information on requires, modules, and +sentences, refer to Lesson 1.5. However, for the time +being, just think of a module as a container for sentences, and don't worry +about requires or imports just yet.

    +

    Our first K program

    +

    To start with, input the following program into your editor as file +lesson-02-a.k:

    +
    k
    module LESSON-02-A + + syntax Color ::= Yellow() | Blue() + syntax Fruit ::= Banana() | Blueberry() + syntax Color ::= colorOf(Fruit) [function] + + rule colorOf(Banana()) => Yellow() + rule colorOf(Blueberry()) => Blue() + +endmodule +
    +

    Save this file and then run:

    +
    kompile lesson-02-a.k
    +
    +

    kompile is K's compiler. By default, it takes a program or specification +written in K and compiles it into an interpreter for that input. Right now we +are compiling a single file. A set of K files that are compiled together are +called a K definition. We will cover multiple file K definitions later on. +kompile will output a directory containing everything needed to execute +programs and perform proofs using that definition. In this case, kompile will +(by default) create the directory lesson-02-a-kompiled under the current +directory.

    +

    Now, save the following input file in your editor as banana.color in the same +directory as lesson-02-a.k:

    +
    colorOf(Banana())
    +
    +

    We can now evaluate this K term by running (from the same directory):

    +
    krun banana.color
    +
    +

    krun will use the interpreter generated by the first call to kompile to +execute this program.

    +

    You will get the following output:

    +
    <k>
    +  Yellow ( ) ~> .
    +</k>
    +
    +

    For now, don't worry about the <k>, </k>, or ~> . portions of this +output file.

    +

    You can also execute small programs directly by specifying them on the command +line instead of putting them in a file. For example, the same program above +could also have been executed by running the following command:

    +
    krun -cPGM='colorOf(Banana())'
    +
    +

    Now, let's look at what this definition and program did.

    +

    Productions, Constructors, and Functions

    +

    The first thing to realize is that this K definition contains 5 productions. +Productions are introduced with the syntax keyword, followed by a sort, +followed by the operator ::= followed by the definition of one or more +productions themselves, separated by the | operator. There are different +types of productions, but for now we only care about constructors and +functions. Each declaration separated by the | operator is individually +a single production, and the | symbol simply groups together productions that +have the same sort. For example, we could equally have written an identical K +definition lesson-02-b.k like so:

    +
    k
    module LESSON-02-B + + syntax Color ::= Yellow() + syntax Color ::= Blue() + syntax Fruit ::= Banana() + syntax Fruit ::= Blueberry() + syntax Color ::= colorOf(Fruit) [function] + + rule colorOf(Banana()) => Yellow() + rule colorOf(Blueberry()) => Blue() + +endmodule +
    +

    You can try compiling and running lesson-02-b.k to see that it produces the same output as lesson-02-a.k:

    +
    kompile lesson-02-b.k
    +krun -cPGM='colorOf(Banana())' --definition 'lesson-02-b-kompiled'
    +
    +

    where the --definition attribute points to the directory containing a compiled version of LESSON-02-B. +Even the following definition is equivalent:

    +
    k
    module LESSON-02-C + + syntax Color ::= Yellow() + | Blue() + | colorOf(Fruit) [function] + syntax Fruit ::= Banana() + | Blueberry() + + rule colorOf(Banana()) => Yellow() + rule colorOf(Blueberry()) => Blue() + +endmodule +
    +

    Each of these types of productions named above has the same underlying syntax, +but context and attributes are used to distinguish between the different +types. Tokens, brackets, lists, macros, aliases, and anywhere productions will +be covered in a later lesson, but this lesson does introduce us to constructors +and functions. Yellow(), Blue(), Banana(), and Blueberry() are +constructors. You can think of a constructor like a constructor for an +algebraic data type, if you're familiar with a functional language. The data +type itself is the sort that appears on the left of the ::= operator. Sorts +in K consist of uppercase identifiers.

    +

    Constructors can have arguments, but these ones do not. We will cover the +syntax of productions in detail in the next lesson, but for now, you can write +a production with no arguments as an uppercase or lowercase identifier followed +by the () operator.

    +

    A function is distinguished from a constructor by the presence of the +function attribute. Attributes appear in a comma separated list between +square brackets after any sentence, including both productions and rules. +Various attributes with built-in meanings exist in K and will be discussed +throughout the tutorial.

    +

    Exercise

    +

    Use krun to compute the return value of the colorOf function on a +Blueberry().

    +

    Rules, Matching, and Variables

    +

    Functions in K are given definitions using rules. A rule begins with the rule +keyword and contains at least one rewrite operator. The rewrite operator +is represented by the syntax =>. The rewrite operator is one of the built-in +productions in K, and we will discuss in more detail how it can be used in +future lessons, but for now, you can think of a rule as consisting of a +left-hand side and a right-hand side, separated by the rewrite +operator. On the left-hand side is the name of the function and zero or more +patterns corresponding to the parameters of the function. On the right-hand +side is another pattern. The meaning of the rule is relatively simple, having +defined these components. If the function is called with arguments that +match the patterns on the left-hand side, then the return value of the +function is the pattern on the right-hand side.

    +

    For example, in the above example, if the argument of the colorOf function +is Banana(), then the return value of the function is Yellow().

    +

    So far we have introduced that a constructor is a type of pattern in K. We +will introduce more complex patterns in later lessons, but there is one other +type of basic pattern: the variable. A variable, syntactically, consists +of an uppercase identifier. However, unlike a constructor, a variable will +match any pattern with one exception: Two variables with the same name +must match the same pattern.

    +

    Here is a more complex example (lesson-02-d.k):

    +
    k
    module LESSON-02-D + + syntax Container ::= Jar(Fruit) + syntax Fruit ::= Apple() | Pear() + + syntax Fruit ::= contentsOfJar(Container) [function] + + rule contentsOfJar(Jar(F)) => F + +endmodule +
    +

    Here we see that Jar is a constructor with a single argument. You can write a +production with multiple arguments by putting the sorts of the arguments in a +comma-separated list inside the parentheses.

    +

    In this example, F is a variable. It will match either Apple() or Pear(). +The return value of the function is created by substituting the matched +values of all of the variables into the variables on the right-hand side of +the rule.

    +

    To demonstrate, compile this definition and execute the following program with +krun:

    +
    contentsOfJar(Jar(Apple()))
    +
    +

    You will see when you run it that the program returns Apple(), because that +is the pattern that was matched by F.

    +

    Exercises

    +
      +
    1. Extend the definition in lesson-02-a.k with the addition of blackberries +and kiwis. For simplicity, blackberries are black and kiwis are green. Then +compile your definition and test that your additional fruits are correctly +handled by the colorOf function.
    2. +
    3. Create a new definition which defines an outfit as a multi-argument +constructor consisting of a hat, shirt, pants, and shoes. Define a new sort, +Boolean, with two constructors, true and false. Each of hat, shirt, pants, +and shoes will have a single argument (a color), either black or +white. Then define an outfitMatching function that will return true if all +the pieces of the outfit are the same color. You do not need to define the +case that returns false. Write some tests that your function behaves the way +you expect.
    4. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.3: BNF Syntax and Parser Generation.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/03_parsing/index.html b/k-distribution/k-tutorial/1_basic/03_parsing/index.html new file mode 100644 index 00000000000..018cad9255d --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/03_parsing/index.html @@ -0,0 +1,780 @@ + + + + + + + + + + + + + + +Lesson 1.3: BNF Syntax and Parser Generation | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.3: BNF Syntax and Parser Generation

    +

    The purpose of this lesson is to explain the full syntax and semantics of +productions in K as well as how productions and other syntactic +sentences can be used to define grammars for use parsing both rules as well +as programs.

    +

    K's approach to parsing

    +

    K's grammar is divided into two components: the outer syntax of K and the +inner syntax of K. Outer syntax refers to the parsing of requires, +modules, imports, and sentences in a K definition. Inner syntax +refers to the parsing of rules and programs. Unlike the outer syntax of +K, which is predetermined, much of the inner syntax of K is defined by you, the +developer. When rules or programs are parsed, they are parsed within the +context of a module. Rules are parsed in the context of the module in which +they exist, whereas programs are parsed in the context of the +main syntax module of a K definition. The productions and other syntactic +sentences in a module are used to construct the grammar of the module, which +is then used to perform parsing.

    +

    Basic BNF productions

    +

    To illustrate how this works, we will consider a simple K definition which +defines a relatively basic calculator capable of evaluating Boolean expressions +containing and, or, not, and xor.

    +

    Input the following program into your editor as file lesson-03-a.k:

    +
    k
    module LESSON-03-A + + syntax Boolean ::= "true" | "false" + | "!" Boolean [function] + | Boolean "&&" Boolean [function] + | Boolean "^" Boolean [function] + | Boolean "||" Boolean [function] + +endmodule +
    +

    You will notice that the productions in this file look a little different than +the ones from the previous lesson. In point of fact, K has two different +mechanisms for defining productions. We have previously been focused +exclusively on the first mechanism, where the ::= symbol is followed by an +alphanumeric identifier followed by a comma-separated list of sorts in +parentheses. However, this is merely a special case of a more generic mechanism +for defining the syntax of productions using a variant of +BNF Form.

    +

    For example, in the previous lesson, we had the following set of productions:

    +
    k
    module LESSON-03-B + syntax Color ::= Yellow() | Blue() + syntax Fruit ::= Banana() | Blueberry() + syntax Color ::= colorOf(Fruit) [function] +endmodule +
    +

    It turns out that this is equivalent to the following definition which defines +the same grammar, but using BNF notation:

    +
    k
    module LESSON-03-C + syntax Color ::= "Yellow" "(" ")" | "Blue" "(" ")" + syntax Fruit ::= "Banana" "(" ")" | "Blueberrry" "(" ")" + syntax Color ::= "colorOf" "(" Fruit ")" [function] +endmodule +
    +

    In this example, the sorts of the argument to the function are unchanged, but +everything else has been wrapped in double quotation marks. This is because +in BNF notation, we distinguish between two types of production items: +terminals and non-terminals. A terminal represents simply a literal +string of characters that is verbatim part of the syntax of that production. +A non-terminal, conversely, represents a sort name, where the syntax of that +production accepts any valid term of that sort at that position.

    +

    This is why, when we wrote the program colorOf(Banana()), krun was able to +execute that program: because it represented a term of sort Color that was +parsed and interpreted by K's interpreter. In other words, krun parses and +interprets terms according to the grammar defined by the developer. It is +automatically converted into an AST of that term, and then the colorOf +function is evaluated using the function rules provided in the definition.

    +

    You can ask yourself: How does K match the strings between the double quotes? +The answer is that K uses Flex to generate a scanner for the grammar. Flex looks +for the longest possible match of a regular expression in the input. If there +are ambiguities between 2 or more regular expressions, it will pick the one with +the highest prec attribute. You can learn more about how Flex matching works +here.

    +

    Bringing us back to the file lesson-03-a.k, we can see that this grammar +has given a simple BNF grammar for expressions over Booleans. We have defined +constructors corresponding to the Boolean values true and false, and functions +corresponding to the Boolean operators for and, or, not, and xor. We have also +given a syntax for each of these functions based on their syntax in the C +programming language. As such, we can now write programs in the simple language +we have defined.

    +

    Input the following program into your editor as and.bool in the same +directory:

    +
    true && false
    +
    +

    We cannot interpret this program yet, because we have not given rules defining +the meaning of the && function yet, but we can parse it. To do this, you can +run (from the same directory):

    +
    kast --output kore and.bool
    +
    +

    kast is K's just-in-time parser. It will generate a grammar from your K +definition on the fly and use it to parse the program passed on the command +line. The --output flag controls how the resulting AST is represented; don't +worry about the possible values yet, just use kore.

    +

    You ought to get the following AST printed on standard output, minus the +formatting:

    +
    inj{SortBoolean{}, SortKItem{}}(
    +  Lbl'UndsAnd-And-UndsUnds'LESSON-03-A'Unds'Boolean'Unds'Boolean'Unds'Boolean{}(
    +    Lbltrue'Unds'LESSON-03-A'Unds'Boolean{}(),
    +    Lblfalse'Unds'LESSON-03-A'Unds'Boolean{}()
    +  )
    +)
    +
    +

    Don't worry about what exactly this means yet, just understand that it +represents the AST of the program that you just parsed. You ought to be able +to recognize the basic shape of it by seeing the words true, false, and +And in there. This is Kore, the intermediate representation of K, and we +will cover it in detail later.

    +

    Note that you can also tell kast to print the AST in other formats. For a +more direct representation of the original K, while still maintaining the +structure of an AST, you can say kast --output kast and.bool. This will +yield the following output:

    +
    `_&&__LESSON-03-A_Boolean_Boolean_Boolean`(
    +  `true_LESSON-03-A_Boolean`(.KList),
    +  `false_LESSON-03-A_Boolean`(.KList)
    +)
    +
    +

    Note how the first output is largely a name-mangled version of the second +output. The one difference is the presence of the inj symbol in the KORE +output. We will talk more about this in later lessons.

    +

    Exercise

    +

    Parse the expression false || true with --output kast. See if you can +predict approximately what the corresponding output would be with +--output kore, then run the command yourself and compare it to your +prediction.

    +

    Ambiguities

    +

    Now let's try a slightly more advanced example. Input the following program +into your editor as and-or.bool:

    +
    true && false || false
    +
    +

    When you try and parse this program, you ought to see the following error:

    +
    [Error] Inner Parser: Parsing ambiguity.
    +1: syntax Boolean ::= Boolean "||" Boolean [function]
    +
    +`_||__LESSON-03-A_Boolean_Boolean_Boolean`(`_&&__LESSON-03-A_Boolean_Boolean_Boolean`(`true_LESSON-03-A_Boolean`(.KList),`false_LESSON-03-A_Boolean`(.KList)),`false_LESSON-03-A_Boolean`(.KList))
    +2: syntax Boolean ::= Boolean "&&" Boolean [function]
    +
    +`_&&__LESSON-03-A_Boolean_Boolean_Boolean`(`true_LESSON-03-A_Boolean`(.KList),`_||__LESSON-03-A_Boolean_Boolean_Boolean`(`false_LESSON-03-A_Boolean`(.KList),`false_LESSON-03-A_Boolean`(.KList)))
    +        Source(./and-or.bool)
    +        Location(1,1,1,23)
    +
    +

    This error is saying that kast was unable to parse this program because it is +ambiguous. K's just-in-time parser is a GLL parser, which means it can handle +the full generality of context-free grammars, including those grammars which +are ambiguous. An ambiguous grammar is one where the same string can be parsed +as multiple distinct ASTs. In this example, it can't decide whether it should +be parsed as (true && false) || false or as true && (false || false). As a +result, it reports the error to the user.

    +

    Brackets

    +

    Currently there is no way of resolving this ambiguity, making it impossible +to write complex expressions in this language. This is obviously a problem. +The standard solution in most programming languages to this problem is to +use parentheses to indicate the appropriate grouping. K generalizes this notion +into a type of production called a bracket. A bracket production in K +is any production with the bracket attribute. It is required that such a +production only have a single non-terminal, and the sort of the production +must equal the sort of that non-terminal. However, K does not otherwise +impose restrictions on the grammar the user provides for a bracket. With that +being said, the most common type of bracket is one in which a non-terminal +is surrounded by terminals representing some type of bracket such as +(), [], {}, <>, etc. For example, we can define the most common +type of bracket, the type used by the vast majority of programming languages, +quite simply.

    +

    Consider the following modified definition, which we will save to +lesson-03-d.k:

    +
    k
    module LESSON-03-D + + syntax Boolean ::= "true" | "false" + | "(" Boolean ")" [bracket] + | "!" Boolean [function] + | Boolean "&&" Boolean [function] + | Boolean "^" Boolean [function] + | Boolean "||" Boolean [function] + +endmodule +
    +

    In this definition, if the user does not explicitly define parentheses, the +grammar remains ambiguous and K's just-in-time parser will report an error. +However, you are now able to parse more complex programs by means of explicitly +grouping subterms with the bracket we have just defined.

    +

    Consider and-or-left.bool:

    +
    (true && false) || false
    +
    +

    Now consider and-or-right.bool:

    +
    true && (false || false)
    +
    +

    If you parse these programs with kast, you will once again get a single +unique AST with no error. If you look, you might notice that the bracket itself +does not appear in the AST. In fact, this is a property unique to brackets: +productions with the bracket attribute are not represented in the parsed AST +of a term, and the child of the bracket is folded immediately into the parent +term. This is the reason for the requirement that a bracket production have +a single non-terminal of the same sort as the production itself.

    +

    Exercise

    +

    Write out what you expect the AST to be arising from parsing these two programs +above with --output kast, then parse them yourself and compare them to the +AST you expected. Confirm for yourself that the bracket production does not +appear in the AST.

    +

    Tokens

    +

    So far we have seen how we can define the grammar of a language. However, +the grammar is not the only relevant part of parsing a language. Also relevant +is the lexical syntax of the language. Thus far, we have implicitly been using +K's automatic lexer generation to generate a token in the scanner for each +terminal in our grammar. However, sometimes we wish to define more complex +lexical syntax. For example, consider the case of integers in C: an integer +consists of a decimal, octal, or hexadecimal number followed by an optional +suffix indicating the type of the literal.

    +

    In theory it would be possible to define this syntax via a grammar, but not +only would it be cumbersome and tedious, you would also then have to deal with +an AST generated for the literal which is not convenient to work with.

    +

    Instead of doing this, K allows you to define token productions, where +a production consists of a regular expression followed by the token +attribute, and the resulting AST consists of a typed string containing the +value recognized by the regular expression.

    +

    For example, the builtin integers in K are defined using the following +production:

    +
    .k .exclude
    syntax Int ::= r"[\\+-]?[0-9]+" [token] +
    +

    Here we can see that we have defined that an integer is an optional sign +followed by a nonzero sequence of digits. The r preceding the terminal +indicates that what appears inside the double quotes is a regular expression, +and the token attribute indicates that terms which parse as this production +should be converted into a token by the parser.

    +

    It is also possible to define tokens that do not use regular expressions. This +can be useful when you wish to declare particular identifiers for use in your +semantics later. For example:

    +
    .k .exclude
    syntax Id ::= "main" [token] +
    +

    Here, we declare that main is a token of sort Id. Instead of being parsed +as a symbol, it gets parsed as a token, generating a typed string in the AST. +This is useful in a semantics of C because the parser generally does not treat +the main function in C specially; only the semantics treats it specially.

    +

    Of course, languages can have more complex lexical syntax. For example, if we +wish to define the syntax of integers in C, we could use the following +production:

    +
    .k .exclude
    syntax IntConstant ::= r"(([1-9][0-9]*)|(0[0-7]*)|(0[xX][0-9a-fA-F]+))(([uU][lL]?)|([uU]((ll)|(LL)))|([lL][uU]?)|(((ll)|(LL))[uU]?))?" [token] +
    +

    As you may have noted above, long and complex regular expressions +can be hard to read. They also suffer from the problem that unlike a grammar, +they are not particularly modular.

    +

    We can get around this restriction by declaring explicit regular expressions, +giving them a name, and then referring to them in productions.

    +

    Consider the following (equivalent) way to define the lexical syntax of +integers in C:

    +
    .k .exclude
    syntax IntConstant ::= r"({DecConstant}|{OctConstant}|{HexConstant})({IntSuffix}?)" [token] +syntax lexical DecConstant = r"{NonzeroDigit}({Digit}*)" +syntax lexical OctConstant = r"0({OctDigit}*)" +syntax lexical HexConstant = r"{HexPrefix}({HexDigit}+)" +syntax lexical HexPrefix = r"0x|0X" +syntax lexical NonzeroDigit = r"[1-9]" +syntax lexical Digit = r"[0-9]" +syntax lexical OctDigit = r"[0-7]" +syntax lexical HexDigit = r"[0-9a-fA-F]" +syntax lexical IntSuffix = r"{UnsignedSuffix}({LongSuffix}?)|{UnsignedSuffix}{LongLongSuffix}|{LongSuffix}({UnsignedSuffix}?)|{LongLongSuffix}({UnsignedSuffix}?)" +syntax lexical UnsignedSuffix = r"[uU]" +syntax lexical LongSuffix = r"[lL]" +syntax lexical LongLongSuffix = r"ll|LL" +
    +

    As you can see, this is rather more verbose, but it has the benefit of both +being much easier to read and understand, and also increased modularity. +Note that we refer to a named regular expression by putting the name in curly +brackets. Note also that only the first sentence actually declares a new piece +of syntax in the language. When the user writes syntax lexical, they are only +declaring a regular expression. To declare an actual piece of syntax in the +grammar, you still must actually declare an explicit token production.

    +

    One final note: K uses Flex to implement +its lexical analysis. As a result, you can refer to the +Flex Manual +for a detailed description of the regular expression syntax supported. Note +that for performance reasons, Flex's regular expressions are actually a regular +language, and thus lack some of the syntactic convenience of modern +"regular expression" libraries. If you need features that are not part of the +syntax of Flex regular expressions, you are encouraged to express them via +a grammar instead.

    +

    Ahead-of-time parser generation

    +

    So far we have been entirely focused on K's support for just-in-time parsing, +where the parser is generated on the fly prior to being used. This benefits +from being faster to generate the parser, but it suffers in performance if you +have to repeatedly parse strings with the same parser. For this reason, it is +generally encouraged that when parsing programs, you use K's ahead-of-time +parser generation. K makes use of +GNU Bison to generate parsers.

    +

    By default, you can enable ahead-of-time parsing via the --gen-bison-parser +flag to kompile. This will make use of Bison's LR(1) parser generator. As +such, if your grammar is not LR(1), it may not parse exactly the same as if +you were to use the just-in-time parser, because Bison will automatically pick +one of the possible branches whenever it encounters a shift-reduce or +reduce-reduce conflict. In this case, you can either modify your grammar to be +LR(1), or you can enable use of Bison's GLR support by instead passing +--gen-glr-bison-parser to kompile. Note that if your grammar is ambiguous, +the ahead-of-time parser will not provide you with particularly readable error +messages at this time.

    +

    If you have a K definition named foo.k, and it generates a directory when +you run kompile called foo-kompiled, you can invoke the ahead-of-time +parser you generated by running foo-kompiled/parser_PGM <file> on a file.

    +

    Exercises

    +
      +
    1. +

      Compile lesson-03-d.k with ahead-of-time parsing enabled. Then compare +how long it takes to run kast --output kore and-or-left.bool with how long it +takes to run lesson-03-d-kompiled/parser_PGM and-or-left.bool. Confirm for +yourself that both produce the same result, but that the latter is faster.

      +
    2. +
    3. +

      Define a simple grammar consisting of integers, brackets, addition, +subtraction, multiplication, division, and unary negation. Integers should be +in decimal form and lexically without a sign, whereas negative numbers can be +represented via unary negation. Ensure that you are able to parse some basic +arithmetic expressions using a generated ahead-of-time parser. Do not worry +about disambiguating the grammar or about writing rules to implement the +operations in this definition.

      +
    4. +
    5. +

      Write a program where the meaning of the arithmetic expression based on +the grammar you defined above is ambiguous, and then write programs that +express each individual intended meaning using brackets.

      +
    6. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.4: Disambiguating Parses.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/04_disambiguation/index.html b/k-distribution/k-tutorial/1_basic/04_disambiguation/index.html new file mode 100644 index 00000000000..c719820b31e --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/04_disambiguation/index.html @@ -0,0 +1,729 @@ + + + + + + + + + + + + + + +Lesson 1.4: Disambiguating Parses | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.4: Disambiguating Parses

    +

    The purpose of this lesson is to teach how to use K's builtin features for +disambiguation to transform an ambiguous grammar into an unambiguous one that +expresses the intended ASTs.

    +

    Priority blocks

    +

    In practice, very few formal languages outside the domain of natural language +processing are ambiguous. The main reason for this is that parsing unambiguous +languages is asymptotically faster than parsing ambiguous languages. +Programming language designers instead usually use the notions of operator +precedence and associativity to make expression grammars unambiguous. These +mechanisms work by instructing the parser to reject certain ASTs in favor of +others in case of ambiguities; it is often possible to remove all ambiguities +in a grammar with these techniques.

    +

    While it is sometimes possible to explicitly rewrite the grammar to remove +these parses, because K's grammar specification and AST generation are +inextricably linked, this is generally discouraged. Instead, we use the +approach of explicitly expressing the relative precedence of different +operators in different situations in order to resolve the ambiguity.

    +

    For example, in C, && binds tighter in precedence than ||, meaning that +the expression true && false || false has only one valid AST: +(true && false) || false.

    +

    Consider, then, the third iteration on the grammar of this definition +(lesson-04-a.k):

    +
    k
    module LESSON-04-A + + syntax Boolean ::= "true" | "false" + | "(" Boolean ")" [bracket] + > "!" Boolean [function] + > Boolean "&&" Boolean [function] + > Boolean "^" Boolean [function] + > Boolean "||" Boolean [function] + +endmodule +
    +

    In this example, some of the | symbols separating productions in a single +block have been replaced with >. This serves to describe the +priority groups associated with this block of productions. +The first priority group consists of the atoms of the +language: true, false, and the bracket operator. In general, a priority +group starts either at the ::= or > operator and extends until either the +next > operator or the end of the production block. Thus, we can see that the +second, third, fourth, and fifth priority groups in this grammar all consist +of a single production.

    +

    The meaning of these priority groups becomes apparent when parsing programs: +A symbol with a lesser priority, (i.e., one that binds looser), cannot +appear as the direct child of a symbol with a greater priority (i.e., +one that binds tighter. In this case, the > operator can be seen as a +greater-than operator describing a transitive partial ordering on the +productions in the production block, expressing their relative priority.

    +

    To see this more concretely, let's look again at the program +true && false || false. As noted before, previously this program was +ambiguous because the parser could either choose that && was the child of || +or vice versa. However, because a symbol with lesser priority (i.e., ||) +cannot appear as the direct child of a symbol with greater priority +(i.e., &&), the parser will reject the parse where || is under the +&& operator. As a result, we are left with the unambiguous parse +(true && false) || false. Similarly, true || false && false parses +unambiguously as true || (false && false). Conversely, if the user explicitly +wants the other parse, they can express this using brackets by explicitly +writing true && (false || false). This still parses successfully because the +|| operator is no longer the direct child of the && operator, but is +instead the direct child of the () operator, and the && operator is an +indirect parent, which is not subject to the priority restriction.

    +

    Astute readers, however, will already have noticed what seems to be a +contradiction: we have defined () as also having greater priority than ||. +One would think that this should mean that || cannot appear as a direct +child of (). This is a problem because priority groups are applied to every +possible parse separately. That is to say, even if the term is unambiguous +prior to this disambiguation rule, we still reject that parse if it violates +the rule of priority.

    +

    In fact, however, we do not reject this program as a parse error. Why is that? +Well, the rule for priority is slightly more complex than previously described. +In actual fact, it applies only conditionally. Specifically, it applies in +cases where the child is either the first or last production item in the +parent's production. For example, in the production Bool "&&" Bool, the +first Bool non-terminal is not preceded by any terminals, and the last Bool +non-terminal is not followed by any terminals. As a result of this, we apply +the priority rule to both children of &&. However, in the () operator, +the sole non-terminal is both preceded by and followed by terminals. As a +result, the priority rule is not applied when () is the parent. Because of +this, the program we mentioned above successfully parses.

    +

    Exercise

    +

    Parse the program true && false || false using kast, and confirm that the AST +places || as the top level symbol. Then modify the definition so that you +will get the alternative parse.

    +

    Associativity

    +

    Even having broken the expression grammar into priority blocks, the resulting +grammar is still ambiguous. We can see this if we try to parse the following +program (assoc.bool):

    +
    true && false && false
    +
    +

    Priority blocks will not help us here: the problem comes between two parses +where both possible parses have a direct parent and child which is within a +single priority block (in this case, && is in the same block as itself).

    +

    This is where the notion of associativity comes into play. Associativity +applies the following additional rules to parses:

    +
      +
    • a left-associative symbol cannot appear as a direct rightmost child of a +symbol with equal priority;
    • +
    • a right-associative symbol cannot appear as a direct leftmost child of a +symbol with equal priority; and
    • +
    • a non-associative symbol cannot appear as a direct leftmost or rightmost +child of a symbol with equal priority.
    • +
    +

    In C, binary operators are all left-associative, meaning that the expression +true && false && false parses unambiguously as (true && false) && false, +because && cannot appear as the rightmost child of itself.

    +

    Consider, then, the fourth iteration on the grammar of this definition +(lesson-04-b.k):

    +
    k
    module LESSON-04-B + + syntax Boolean ::= "true" | "false" + | "(" Boolean ")" [bracket] + > "!" Boolean [function] + > left: Boolean "&&" Boolean [function] + > left: Boolean "^" Boolean [function] + > left: Boolean "||" Boolean [function] + +endmodule +
    +

    Here each priority group, immediately after the ::= or > operator, can +be followed by a symbol representing the associativity of that priority group: +either left: for left associativity, right: for right associativity, or +non-assoc: for non-associativity. In this example, each priority group we +apply associativity to has only a single production, but we could equally well +write a priority block with multiple productions and an associativity.

    +

    For example, consider the following, different grammar (lesson-04-c.k):

    +
    k
    module LESSON-04-C + + syntax Boolean ::= "true" | "false" + | "(" Boolean ")" [bracket] + > "!" Boolean [function] + > left: + Boolean "&&" Boolean [function] + | Boolean "^" Boolean [function] + | Boolean "||" Boolean [function] + +endmodule +
    +

    In this example, unlike the one above, &&, ^, and || have the same +priority. However, viewed as a group, the entire group is left associative. +This means that none of &&, ^, and || can appear as the right child of +any of &&, ^, or ||. As a result of this, this grammar is also not +ambiguous. However, it expresses a different grammar, and you are encouraged +to think about what the differences are in practice.

    +

    Exercise

    +

    Parse the program true && false && false yourself, and confirm that the AST +places the rightmost && at the top of the expression. Then modify the +definition to generate the alternative parse.

    +

    Explicit priority and associativity declarations

    +

    Previously we have only considered the case where all of the productions +which you wish to express a priority or associativity relation over are +co-located in the same block of productions. However, in practice this is not +always feasible or desirable, especially as a definition grows in size across +multiple modules.

    +

    As a result of this, K provides a second way of declaring priority and +associativity relations.

    +

    Consider the following grammar, which we will name lesson-04-d.k and which +will express the exact same grammar as lesson-04-b.k

    +
    k
    module LESSON-04-D + + syntax Boolean ::= "true" [group(literal)] | "false" [group(literal)] + | "(" Boolean ")" [group(atom), bracket] + | "!" Boolean [group(not), function] + | Boolean "&&" Boolean [group(and), function] + | Boolean "^" Boolean [group(xor), function] + | Boolean "||" Boolean [group(or), function] + + syntax priorities literal atom > not > and > xor > or + syntax left and + syntax left xor + syntax left or +endmodule +
    +

    This introduces a couple of new features of K. First, the group(_) attribute +is used to conceptually group together sets of sentences under a common +user-defined name. For example, literal in the syntax priorities sentence is +used to refer to all the productions marked with the group(literal) attribute, +i.e., true and false. A production can belong to multiple groups using +syntax such as group(myGrp1,myGrp2).

    +

    Once we understand this, it becomes relatively straightforward to understand +the meaning of this grammar. Each syntax priorities sentence defines a +priority relation where > separates different priority groups. Each priority +group is defined by a list of one or more group names, and consists of all +productions which are members of at least one of those named groups.

    +

    In the same way, a syntax left, syntax right, or syntax non-assoc sentence +defines an associativity relation among left-, right-, or non-associative +groups. Specifically, this means that:

    +
    syntax left a b
    +
    +

    is different to:

    +
    syntax left a
    +syntax left b
    +
    +

    As a consequence of this, syntax [left|right|non-assoc] should not be used to +group together labels with different priority.

    +

    Prefer/avoid

    +

    Sometimes priority and associativity prove insufficient to disambiguate a +grammar. In particular, sometimes it is desirable to be able to choose between +two ambiguous parses directly while still not rejecting any parses if the term +parsed is unambiguous. A good example of this is the famous "dangling else" +problem in imperative C-like languages.

    +

    Consider the following definition (lesson-04-E.k):

    +
    k
    module LESSON-04-E + + syntax Exp ::= "true" | "false" + syntax Stmt ::= "if" "(" Exp ")" Stmt + | "if" "(" Exp ")" Stmt "else" Stmt + | "{" "}" +endmodule +
    +

    We can write the following program (dangling-else.if):

    +
    if (true) if (false) {} else {}
    +
    +

    This is ambiguous because it is unclear whether the else clause is part of +the outer if or the inner if. At first we might try to resolve this with +priorities, saying that the if without an else cannot appear as a child of +the if with an else. However, because the non-terminal in the parent symbol +is both preceded and followed by a terminal, this will not work.

    +

    Instead, we can resolve the ambiguity directly by telling the parser to +"prefer" or "avoid" certain productions when ambiguities arise. For example, +when we parse this program, we see the following ambiguity as an error message:

    +
    [Error] Inner Parser: Parsing ambiguity.
    +1: syntax Stmt ::= "if" "(" Exp ")" Stmt
    +
    +`if(_)__LESSON-04-E_Stmt_Exp_Stmt`(`true_LESSON-04-E_Exp`(.KList),`if(_)_else__LESSON-04-E_Stmt_Exp_Stmt_Stmt`(`false_LESSON-04-E_Exp`(.KList),`;_LESSON-04-E_Stmt`(.KList),`;_LESSON-04-E_Stmt`(.KList)))
    +2: syntax Stmt ::= "if" "(" Exp ")" Stmt "else" Stmt
    +
    +`if(_)_else__LESSON-04-E_Stmt_Exp_Stmt_Stmt`(`true_LESSON-04-E_Exp`(.KList),`if(_)__LESSON-04-E_Stmt_Exp_Stmt`(`false_LESSON-04-E_Exp`(.KList),`;_LESSON-04-E_Stmt`(.KList)),`;_LESSON-04-E_Stmt`(.KList))
    +        Source(./dangling-else.if)
    +        Location(1,1,1,30)
    +
    +

    Roughly, we see that the ambiguity is between an if with an else or an if +without an else. Since we want to pick the first parse, we can tell K to +"avoid" the second parse with the avoid attribute. Consider the following +modified definition (lesson-04-f.k):

    +
    k
    module LESSON-04-F + + syntax Exp ::= "true" | "false" + syntax Stmt ::= "if" "(" Exp ")" Stmt + | "if" "(" Exp ")" Stmt "else" Stmt [avoid] + | "{" "}" +endmodule +
    +

    Here we have added the avoid attribute to the else production. As a result, +when an ambiguity occurs and one or more of the possible parses has that symbol +at the top of the ambiguous part of the parse, we remove those parses from +consideration and consider only those remaining. The prefer attribute behaves +similarly, but instead removes all parses which do not have that attribute. +In both cases, no action is taken if the parse is not ambiguous.

    +

    Exercises

    +
      +
    1. +

      Parse the program if (true) if (false) {} else {} using lesson-04-f.k +and confirm that else clause is part of the innermost if statement. Then +modify the definition so that you will get the alternative parse.

      +
    2. +
    3. +

      Modify your solution from Lesson 1.3, Exercise 2 so that unary negation should +bind tighter than multiplication and division, which should bind tighter than +addition and subtraction, and each binary operator should be left associative. +Write these priority and associativity declarations explicitly, and then +try to write them inline.

      +
    4. +
    5. +

      Write a simple grammar containing at least one ambiguity that cannot be +resolved via priority or associativity, and then use the prefer attribute to +resolve that ambiguity.

      +
    6. +
    7. +

      Explain why the following grammar is not labeled ambiguous by the K parser when parsing abb, then make the parser realize the ambiguity.

      +
    8. +
    +
    k
    module EXERCISE4 + +syntax Expr ::= "a" Expr "b" + | "abb" + | "b" + +endmodule +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.5: Modules, Imports, and Requires.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/05_modules/index.html b/k-distribution/k-tutorial/1_basic/05_modules/index.html new file mode 100644 index 00000000000..142e0948e68 --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/05_modules/index.html @@ -0,0 +1,670 @@ + + + + + + + + + + + + + + +Lesson 1.5: Modules, Imports, and Requires | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.5: Modules, Imports, and Requires

    +

    The purpose of this lesson is to explain how K definitions can be broken into +separate modules and files and how these distinct components combine into a +complete K definition.

    +

    K's outer syntax

    +

    Recall from Lesson 1.3 that K's grammar is broken +into two components: the outer syntax of K and the inner syntax of K. +Outer syntax, as previously mentioned, consists of requires, modules, +imports, and sentences. A K semantics is expressed by the set of +sentences contained in the definition. The scope of what is considered +contained in that definition is determined both by the main semantics +module of a K definition, as well as the requires and imports present +in the file that contains that module.

    +

    Basic module syntax

    +

    The basic unit of grouping sentences in K is the module. A module consists +of a module name, an optional list of attributes, a list of +imports, and a list of sentences.

    +

    A module name consists of one or more groups of letters, numbers, or +underscores, separated by a hyphen. Here are some valid module names: FOO, +FOO-BAR, foo0, foo0_bar-Baz9. Here are some invalid module names: -, +-FOO, BAR-, FOO--BAR. Stylistically, modules names are usually all +uppercase with hyphens separating words, but this is not strictly enforced.

    +

    Some example modules include an empty module:

    +
    k
    module LESSON-05-A + +endmodule +
    +

    A module with some attributes:

    +
    k
    module LESSON-05-B [group(attr1,attr2), private] + +endmodule +
    +

    A module with some sentences:

    +
    k
    module LESSON-05-C + syntax Boolean ::= "true" | "false" + syntax Boolean ::= "not" Boolean [function] + rule not true => false + rule not false => true +endmodule +
    +

    Imports

    +

    Thus far we have only discussed definitions containing a single module. +Definitions can also contain multiple modules, in which one module imports +others.

    +

    An import in K appears at the top of a module, prior to any sentences. It can +be specified with the imports keyword, followed by a module name.

    +

    For example, here is a simple definition with two modules (lesson-05-d.k):

    +
    k
    module LESSON-05-D-1 + syntax Boolean ::= "true" | "false" + syntax Boolean ::= "not" Boolean [function] +endmodule + +module LESSON-05-D + imports LESSON-05-D-1 + + rule not true => false + rule not false => true +endmodule +
    +

    This K definition is equivalent to the definition expressed by the single module +LESSON-05-C. Essentially, by importing a module, we include all of the +sentences in the module being imported into the module that we import from. +There are a few minor differences between importing a module and simply +including its sentences in another module directly, but we will cover these +differences later. Essentially, you can think of modules as a way of +conceptually grouping sentences in a larger K definition.

    +

    Exercise

    +

    Modify lesson-05-d.k to include four modules: one containing the syntax, two +with one rule each that imports the first module, and a final module +LESSON-05-D containing no sentences that imports the second and third module. +Check to make sure the definition still compiles and that you can still evaluate +the not function.

    +

    Parsing in the presence of multiple modules

    +

    As you may have noticed, each module in a definition can express a distinct set +of syntax. When parsing the sentences in a module, we use the syntax +of that module, enriched with the basic syntax of K, in order to parse +rules in that module. For example, the following definition is a parser error +(lesson-05-e.k):

    +
    .k .error
    module LESSON-05-E-1 + rule not true => false + rule not false => true +endmodule + +module LESSON-05-E-2 + syntax Boolean ::= "true" | "false" + syntax Boolean ::= "not" Boolean [function] +endmodule +
    +

    This is because the syntax referenced in module LESSON-05-E-1, namely, not, +true, and false, is not imported by that module. You can solve this problem +by simply importing the modules containing the syntax you want to use in your +sentences.

    +

    Main syntax and semantics modules

    +

    When we are compiling a K definition, we need to know where to start. We +designate two specific entry point modules: the main syntax module +and the main semantics module. The main syntax module, as well as all the +modules it imports recursively, are used to create the parser for programs that +you use to parse programs that you execute with krun. The main semantics +module, as well as all the modules it imports recursively, are used to +determine the rules that can be applied at runtime in order to execute a +program. For example, in the above example, if the main semantics module is +module LESSON-05-D-1, then not is an uninterpreted function (i.e., has no +rules associated with it), and the rules in module LESSON-05-D are not +included.

    +

    While you can specify the entry point modules explicitly by passing the +--main-module and --syntax-module flags to kompile, by default, if you +type kompile foo.k, then the main semantics module will be FOO and the +main syntax module will be FOO-SYNTAX.

    +

    Splitting a definition into multiple files

    +

    So far, while we have discussed ways to break definitions into separate +conceptual components (modules), K also provides a mechanism for combining +multiple files into a single K definition, namely, the requires directive.

    +

    In K, the requires keyword has two meanings. The first, the requires +statement, appears at the top of a K file, prior to any module declarations. It +consists of the keyword requires followed by a double-quoted string. The +second meaning of the requires keyword will be covered in a later lesson, +but it is distinguished because the second case occurs only inside modules.

    +

    The string passed to the requires statement contains a filename. When you run +kompile on a file, it will look at all of the requires statements in that +file, look up those files on disk, parse them, and then recursively process all +the requires statements in those files. It then combines all the modules in all +of those files together, and uses them collectively as the set of modules to +which imports statements can refer.

    +

    Putting it all together

    +

    Putting it all together, here is one possible way in which we could break the +definition lesson-02-c.k from Lesson 1.2 into +multiple files and modules:

    +

    colors.k:

    +
    k
    module COLORS + syntax Color ::= Yellow() + | Blue() +endmodule +
    +

    fruits.k:

    +
    k
    module FRUITS + syntax Fruit ::= Banana() + | Blueberry() +endmodule +
    +

    colorOf.k:

    +
    .k .exclude
    requires "fruits.k" +requires "colors.k" + +module COLOROF-SYNTAX + imports COLORS + imports FRUITS + + syntax Color ::= colorOf(Fruit) [function] +endmodule + +module COLOROF + imports COLOROF-SYNTAX + + rule colorOf(Banana()) => Yellow() + rule colorOf(Blueberry()) => Blue() +endmodule +
    +

    You would then compile this definition with kompile colorOf.k and use it the +same way as the original, single-module definition.

    +

    Exercise

    +

    Modify the name of the COLOROF module, and then recompile the definition. +Try to understand why you now get a compiler error. Then, resolve this compiler +error by passing the --main-module and --syntax-module flags to kompile.

    +

    Include path

    +

    One note can be made about how paths are resolved in requires statements.

    +

    By default, the path you specify is allowed to be an absolute or a relative +path. If the path is absolute, that exact file is imported. If the path is +relative, a matching file is looked for within all of the +include directories specified to the compiler. By default, the include +directories include the current working directory, followed by the +include/kframework/builtin directory within your installation of K. You can +also pass one or more directories to kompile via the -I command line flag, +in which case these directories are prepended to the beginning of the list.

    +

    Exercises

    +
      +
    1. +

      Take the solution to Lesson 1.4, Exercise 2 which included the explicit +priority and associativity declarations, and modify the definition so that +the syntax of integers and brackets is in one module, the syntax of addition, +subtraction, and unary negation is in another module, and the syntax of +multiplication and division is in a third module. Make sure you can still parse +the same set of expressions as before. Place priority declarations in the main +module.

      +
    2. +
    3. +

      Modify lesson-02-d.k from Lesson 1.2 so that the rules and syntax are in +separate modules in separate files.

      +
    4. +
    5. +

      Place the file containing the syntax from Exercise 2 in another directory, +then recompile the definition. Observe why a compilation error occurs. Then +fix the compiler error by passing -I to kompile.

      +
    6. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.6: Integers and Booleans.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/06_ints_and_bools/index.html b/k-distribution/k-tutorial/1_basic/06_ints_and_bools/index.html new file mode 100644 index 00000000000..727d3ed4d08 --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/06_ints_and_bools/index.html @@ -0,0 +1,608 @@ + + + + + + + + + + + + + + +Lesson 1.6: Integers and Booleans | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.6: Integers and Booleans

    +

    The purpose of this lesson is to explain the two most basic types of builtin +sorts in K, the Int sort and the Bool sort, representing +arbitrary-precision integers and Boolean algebra.

    +

    Builtin sorts in K

    +

    K provides definitions of some useful sorts in +domains.md, found in the +include/kframework/builtin directory of the K installation. This file is +defined via a +Literate programming +style that we will discuss in a future lesson. We will not cover all of the +sorts found there immediately, however, this lesson discusses some of the +details surrounding integers and Booleans, as well as providing information +about how to look up more detailed knowledge about builtin functions in K's +documentation.

    +

    Booleans in K

    +

    The most basic builtin sort K provides is the Bool sort, representing +Boolean values (i.e., true and false). You have already seen how we were +able to create this type ourselves using K's parsing and disambiguation +features. However, in the vast majority of cases, we prefer instead to import +the version of Boolean algebra defined by K itself. Most simply, you can do +this by importing the module BOOL in your definition. For example +(lesson-06-a.k):

    +
    k
    module LESSON-06-A + imports BOOL + + syntax Fruit ::= Blueberry() | Banana() + syntax Bool ::= isBlue(Fruit) [function] + + rule isBlue(Blueberry()) => true + rule isBlue(Banana()) => false +endmodule +
    +

    Here we have defined a simple predicate, i.e., a function returning a +Boolean value. We are now able to perform the usual Boolean operations of +and, or, and not over these values. For example (lesson-06-b.k):"

    +
    k
    module LESSON-06-B + imports BOOL + + syntax Fruit ::= Blueberry() | Banana() + syntax Bool ::= isBlue(Fruit) [function] + + rule isBlue(Blueberry()) => true + rule isBlue(Banana()) => false + + syntax Bool ::= isYellow(Fruit) [function] + | isBlueOrYellow(Fruit) [function] + + rule isYellow(Banana()) => true + rule isYellow(Blueberry()) => false + + rule isBlueOrYellow(F) => isBlue(F) orBool isYellow(F) +endmodule +
    +

    In the above example, Boolean inclusive or is performed via the orBool +function, which is defined in the BOOL module. As a matter of convention, +many functions over builtin sorts in K are suffixed with the name of the +primary sort over which those functions are defined. This happens so that the +syntax of K does not (generally) conflict with the syntax of any other +programming language, which would make it harder to define that programming +language in K.

    +

    Exercise

    +

    Write a function isBlueAndNotYellow which computes the appropriate Boolean +expression. If you are unsure what the appropriate syntax is to use, you +can refer to the BOOL module in +domains.md. Add a term of +sort Fruit for which isBlue and isYellow both return true, and test that +the isBlueAndNotYellow function behaves as expected on all three Fruits.

    +

    Syntax Modules

    +

    For most sorts in domains.md, K defines more than one module that can be +imported by users. For example, for the Bool sort, K defines the BOOL +module that has previously already been discussed, but also provides the +BOOL-SYNTAX module. This module, unlike the BOOL module, only declares the +values true and false, but not any of the functions that operate over the +Bool sort. The rationale is that you may want to import this module into the +main syntax module of your definition in some cases, whereas you generally do +not want to do this with the version of the module that includes all the +functions over the Bool sort. For example, if you were defining the semantics +of C++, you might import BOOL-SYNTAX into the syntax module of your +definition, because true and false are part of the grammar of C++, but +you would only import the BOOL module into the main semantics module, because +C++ defines its own syntax for and, or, and not that is different from the +syntax defined in the BOOL module.

    +

    Here, for example, is how we might redefine our Boolean expression calculator +to use the Bool sort while maintaining an idiomatic structure of modules +and imports, for the first time including the rules to calculate the values of +expressions themselves (lesson-06-c.k):

    +
    k
    module LESSON-06-C-SYNTAX + imports BOOL-SYNTAX + + syntax Bool ::= "(" Bool ")" [bracket] + > "!" Bool [function] + > left: + Bool "&&" Bool [function] + | Bool "^" Bool [function] + | Bool "||" Bool [function] +endmodule + +module LESSON-06-C + imports LESSON-06-C-SYNTAX + imports BOOL + + rule ! B => notBool B + rule A && B => A andBool B + rule A ^ B => A xorBool B + rule A || B => A orBool B +endmodule +
    +

    Note the encapsulation of syntax: the LESSON-06-C-SYNTAX module contains +exactly the syntax of our Boolean expressions, and no more, whereas any other +syntax needed to implement those functions is in the LESSON-06-C module +instead.

    +

    Exercise

    +

    Add an "implies" function to the above Boolean expression calculator, using the +-> symbol to represent implication. You can look up K's builtin "implies" +function in the BOOL module in domains.md.

    +

    Integers in K

    +

    Unlike most programming languages, where the most basic integer type is a +fixed-precision integer type, the most commonly used integer sort in K is +the Int sort, which represents the mathematical integers, ie, +arbitrary-precision integers.

    +

    K provides three main modules for import when using the Int sort. The first, +containing all the syntax of integers as well as all of the functions over +integers, is the INT module. The second, which provides just the syntax +of integer literals themselves, is the INT-SYNTAX module. However, unlike +most builtin sorts in K, K also provides a third module for the Int sort: +the UNSIGNED-INT-SYNTAX module. This module provides only the syntax of +non-negative integers, i.e., natural numbers. The reasons for this involve +lexical ambiguity. Generally speaking, in most programming languages, -1 is +not a literal, but instead a literal to which the unary negation operator is +applied. K thus provides this module to ease in specifying the syntax of such +languages.

    +

    For detailed information about the functions available over the Int sort, +refer to domains.md. Note again how we append Int to the end of most of the +integer operations to ensure they do not collide with the syntax of other +programming languages.

    +

    Exercises

    +
      +
    1. +

      Extend your solution from Lesson 1.4, Exercise 2 to implement the rules +that define the behavior of addition, subtraction, multiplication, and +division. Do not worry about the case when the user tries to divide by zero +at this time. Use /Int to implement division. Test your new calculator +implementation by executing the arithmetic expressions you wrote as part of +Lesson 1.3, Exercise 2. Check to make sure each computes the value you expected.

      +
    2. +
    3. +

      Combine the Boolean expression calculator from this lesson with your +solution to Exercise 1, and then extend the combined calculator with the <, +<=, >, >=, ==, and != expressions. Write some Boolean expressions +that combine integer and Boolean operations, and test to ensure that these +expressions return the expected truth value.

      +
    4. +
    5. +

      Compute the following expressions using your solution from Exercise 2: +7 / 3, 7 / -3, -7 / 3, -7 / -3. Then replace the /Int function in +your definition with divInt instead, and observe how the value of the above +expressions changes. Why does this occur?

      +
    6. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.7: Side Conditions and Rule Priority.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/07_side_conditions/index.html b/k-distribution/k-tutorial/1_basic/07_side_conditions/index.html new file mode 100644 index 00000000000..67392718a05 --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/07_side_conditions/index.html @@ -0,0 +1,621 @@ + + + + + + + + + + + + + + +Lesson 1.7: Side Conditions and Rule Priority | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.7: Side Conditions and Rule Priority

    +

    The purpose of this lesson is to explain how to write conditional rules in K, +and to explain how to control the order in which rules are tried.

    +

    Side Conditions

    +

    So far, all of the rules we have discussed have been unconditional rules. +If the left-hand side of the rule matches the arguments to the function, the +rule applies. However, there is another type of rule, a conditional rule. +A conditional rule consists of a rule body containing the patterns to +match, and a side condition representing a Boolean expression that must +evaluate to true in order for the rule to apply.

    +

    Side conditions in K are introduced via the requires keyword immediately +following the rule body. For example, here is a rule with a side condition +(lesson-07-a.k):

    +
    k
    module LESSON-07-A + imports BOOL + imports INT + + syntax Grade ::= "letter-A" + | "letter-B" + | "letter-C" + | "letter-D" + | "letter-F" + | gradeFromPercentile(Int) [function] + + rule gradeFromPercentile(I) => letter-A requires I >=Int 90 +endmodule +
    +

    In this case, the gradeFromPercentile function takes a single integer +argument. The function evaluates to letter-A if the argument passed is +greater than 90. Note that the side condition is allowed to refer to variables +that appear on the left-hand side of the rule. In the same manner as variables +appearing on the right-hand side, variables that appear in the side condition +evaluate to the value that was matched on the left-hand side. Then the +functions in the side condition are evaluated, which returns a term of sort +Bool. If the term is equal to true, then the rule applies. Bear in mind +that the side condition is only evaluated at all if the patterns on the +left-hand side of the rule match the term being evaluated.

    +

    Exercise

    +

    Write a rule that evaluates gradeFromPercentile to letter-B if the argument +to the function is in the range [80,90). Test that the function correctly +evaluates various numbers between 80 and 100.

    +

    owise Rules

    +

    So far, all the rules we have introduced have had the same priority. What +this means is that K does not necessarily enforce an order in which the rules +are tried. We have only discussed functions so far in K, so it is not +immediately clear why this choice was made, given that a function is not +considered well-defined if multiple rules for evaluating it are capable of +evaluating the same arguments to different results. However, in future lessons +we will discuss other types of rules in K, some of which can be +non-deterministic. What this means is that if more than one rule is capable +of matching, then K will explore both possible rules in parallel, and consider +each of their respective results when executing your program. Don't worry too +much about this right now, but just understand that because of the potential +later for nondeterminism, we don't enforce a total ordering on the order in +which rules are attempted to be applied.

    +

    However, sometimes this is not practical; It can be very convenient to express +that a particular rule applies if no other rules for that function are +applicable. This can be expressed by adding the owise attribute to a rule. +What this means, in practice, is that this rule has lower priority than other +rules, and will only be tried to be applied after all the other, +higher-priority rules have been tried and they have failed.

    +

    For example, in the above exercise, we had to add a side condition containing +two Boolean comparisons to the rule we wrote to handle letter-B grades. +However, in practice this meant that we compare the percentile to 90 twice. We +can more efficiently and more idiomatically write the letter-B case for the +gradeFromPercentile rule using the owise attribute (lesson-07-b.k):

    +
    k
    module LESSON-07-B + imports BOOL + imports INT + + syntax Grade ::= "letter-A" + | "letter-B" + | "letter-C" + | "letter-D" + | "letter-F" + | gradeFromPercentile(Int) [function] + + rule gradeFromPercentile(I) => letter-A requires I >=Int 90 + rule gradeFromPercentile(I) => letter-B requires I >=Int 80 [owise] +endmodule +
    +

    This rule is saying, "if all the other rules do not apply, then the grade is a +B if the percentile is greater than or equal to 80." Note here that we use both +a side condition and an owise attribute on the same rule. This is not +required (as we will see later), but it is allowed. What this means is that the +side condition is only tried if the other rules did not apply and the +left-hand side of the rule matched. You can even use more complex matching on +the left-hand side than simply a variable. More generally, you can also have +multiple higher-priority rules, or multiple owise rules. What this means in +practice is that all of the non-owise rules are tried first, in any order, +followed by all the owise rules, in any order.

    +

    Exercise

    +

    The grades D and F correspond to the percentile ranges [60, 70) and [0, 60) +respectively. Write another implementation of gradeFromPercentile which +handles only these cases, and uses the owise attribute to avoid redundant +Boolean comparisons. Test that various percentiles in the range [0, 70) are +evaluated correctly.

    +

    Rule Priority

    +

    As it happens, the owise attribute is a specific case of a more general +concept we call rule priority. In essence, each rule is assigned an integer +priority. Rules are tried in increasing order of priority, starting with a +rule with priority zero, and trying each increasing numerical value +successively.

    +

    By default, a rule is assigned a priority of 50. If the rule has the owise +attribute, it is instead given the priority 200. You can see why this will +cause owise rules to be tried after regular rules.

    +

    However, it is also possible to directly assign a numerical priority to a rule +via the priority attribute. For example, here is an alternative way +we could express the same two rules in the gradeFromPercentile function +(lesson-07-c.k):

    +
    k
    module LESSON-07-C + imports BOOL + imports INT + + syntax Grade ::= "letter-A" + | "letter-B" + | "letter-C" + | "letter-D" + | "letter-F" + | gradeFromPercentile(Int) [function] + + rule gradeFromPercentile(I) => letter-A requires I >=Int 90 [priority(50)] + rule gradeFromPercentile(I) => letter-B requires I >=Int 80 [priority(200)] +endmodule +
    +

    We can, of course, assign a priority equal to any non-negative integer. For +example, here is a more complex example that handles the remaining grades +(lesson-07-d.k):

    +
    k
    module LESSON-07-D + imports BOOL + imports INT + + syntax Grade ::= "letter-A" + | "letter-B" + | "letter-C" + | "letter-D" + | "letter-F" + | gradeFromPercentile(Int) [function] + + rule gradeFromPercentile(I) => letter-A requires I >=Int 90 [priority(50)] + rule gradeFromPercentile(I) => letter-B requires I >=Int 80 [priority(51)] + rule gradeFromPercentile(I) => letter-C requires I >=Int 70 [priority(52)] + rule gradeFromPercentile(I) => letter-D requires I >=Int 60 [priority(53)] + rule gradeFromPercentile(_) => letter-F [priority(54)] +endmodule +
    +

    Note that we have introduced a new piece of syntax here: _. This is actually +just a variable. However, as a special case, when a variable is named _, it +does not bind a value that can be used on the right-hand side of the rule, or +in a side condition. Effectively, _ is a placeholder variable that means "I +don't care about this term."

    +

    In this example, we have explicitly expressed the order in which the rules of +this function are tried. Since rules are tried in increasing numerical +priority, we first try the rule with priority 50, then 51, then 52, 53, and +finally 54.

    +

    As a final note, remember that if you assign a rule a priority higher than 200, +it will be tried after a rule with the owise attribute, and if you assign +a rule a priority less than 50, it will be tried before a rule with no +explicit priority.

    +

    Exercises

    +
      +
    1. +

      Write a function isEven that returns whether an integer is an even number. +Use two rules and one side condition. The right-hand side of the rules should +be Boolean literals. Refer back to +domains.md for the relevant +integer operations.

      +
    2. +
    3. +

      Modify the calculator application from Lesson 1.6, Exercise 2, so that division +by zero will no longer make krun crash with a "Divison by zero" exception. +Instead, the / function should not match any of its rules if the denominator +is zero.

      +
    4. +
    5. +

      Write your own implementation of ==, <, <=, >, >= for integers and modify your solution from Exercise 2 to use it. +You can use any arithmetic operations in the INT module, but do not use any built-in boolean functions for comparing integers.

      +

      Hint: Use pattern matching and recursive definitions with rule priorities.

      +
    6. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.8: Literate Programming with Markdown.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/08_literate_programming/index.html b/k-distribution/k-tutorial/1_basic/08_literate_programming/index.html new file mode 100644 index 00000000000..fdf14ca82cc --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/08_literate_programming/index.html @@ -0,0 +1,571 @@ + + + + + + + + + + + + + + +Lesson 1.8: Literate Programming with Markdown | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.8: Literate Programming with Markdown

    +

    The purpose of this lesson is to teach a paradigm for performing literate +programming in K, and explain how this can be used to create K definitions +that are also documentation.

    +

    Markdown and K

    +

    The K tutorial so far has been written in +Markdown. Markdown, +for those not already familiar, is a lightweight plain-text format for styling +text. From this point onward, we assume you are familiar with Markdown and how +to write Markdown code. You can refer to the above link for a tutorial if you +are not already familiar.

    +

    What you may not necessarily realize, however, is that the K tutorial is also +a sequence of K definitions written in the manner of +Literate Programming. +For detailed information about Literate Programming, you can read the linked +Wikipedia article, but the short summary is that literate programming is a way +of intertwining documentation and code together in a manner that allows +executable code to also be, simultaneously, a documented description of that +code.

    +

    K is provided with built-in support for literate programming using Markdown. +By default, if you pass a file with the .md file extension to kompile, it +will look for any code blocks containing k code in that file, extract out +that K code into pure K, and then compile it as if it were a .k file.

    +

    A K code block begins with a line of text containing the keyword ```k, +and ends when it encounters another ``` keyword.

    +

    For example, if you view the markdown source of this document, this is a K +code block:

    +
    k
    module LESSON-08 + imports INT +
    +

    Only the code inside K code blocks will actually be sent to the compiler. The +rest, while it may appear in the document when rendered by a markdown viewer, +is essentially a form of code comment.

    +

    When you have multiple K code blocks in a document, K will append each one +together into a single file before passing it off to the outer parser.

    +

    For example, the following code block contains sentences that are part of the +LESSON-08 module that we declared the beginning of above:

    +
    k
    syntax Int ::= Int "+" Int [function] + rule I1 + I2 => I1 +Int I2 +
    +

    Exercise

    +

    Compile this file with kompile README.md --main-module LESSON-08. Confirm +that you can use the resulting compiled definition to evaluate the + +function.

    +

    Markdown Selectors

    +

    On occasion, you may want to generate multiple K definitions from a single +Markdown file. You may also wish to include a block of syntax-highlighted K +code that nonetheless does not appear as part of your K definition. It is +possible to accomplish this by means of the built-in support for syntax +highlighting in Markdown. Markdown allows a code block that was begun with +``` to be immediately followed by a string which is used to signify what +programming language the following code is written in. However, this feature +actually allows arbitrary text to appear describing that code block. Markdown +parsers are able to parse this text and render the code block differently +depending on what text appears after the backticks.

    +

    In K, you can use this functionality to specify one or more +Markdown selectors which are used to describe the code block. A Markdown +selector consists of a sequence of characters containing letters, numbers, and +underscores. A code block can be designated with a single selector by appending +the selector immediately following the backticks that open the code block.

    +

    For example, here is a code block with the foo selector:

    +
    foo
    foo bar +
    +

    Note that this is not K code. By convention, K code should have the k +selector on it. You can express multiple selectors on a code block by putting +them between curly braces and prepending each with the . character. For +example, here is a code block with the foo and k selectors:

    +
    .k .foo
    syntax Int ::= foo(Int) [function] + rule foo(0) => 0 +
    +

    Because this code block contains the k Markdown selector, by default it is +included as part of the K definition being compiled.

    +

    Exercise

    +

    Confirm this fact by using krun to evaluate foo(0).

    +

    Markdown Selector Expressions

    +

    By default, as previously stated, K includes in the definition any code block +with the k selector. However, this is merely a specific instance of a general +principle, namely, that K allows you to control which selectors get included +in your K definition. This is done by means of the --md-selector flag to +kompile. This flag accepts a Markdown selector expression, which you +can essentially think of as a kind of Boolean algebra over Markdown selectors. +Each selector becomes an atom, and you can combine these atoms via the &, +|, !, and () operators.

    +

    Here is a grammar, written in K, of the language of Markdown selector +expressions:

    +
    .k .selector
    syntax Selector ::= r"[0-9a-zA-Z_]+" [token] + syntax SelectorExp ::= Selector + | "(" SelectorExp ")" [bracket] + > right: + "!" SelectorExp + > right: + SelectorExp "&" SelectorExp + > right: + SelectorExp "|" SelectorExp +
    +

    Here is a selector expression that selects all the K code blocks in this +definition except the one immediately above:

    +
    k & (! selector)
    +
    +

    Addendum

    +

    This code block exists in order to make the above lesson a syntactically valid +K definition. Consider why it is necessary.

    +
    k
    endmodule +
    +

    Exercises

    +
      +
    1. +

      Compile this lesson with the selector expression k & (! foo) and confirm +that you get a parser error if you try to evaluate the foo function with the +resulting definition.

      +
    2. +
    3. +

      Compile Lesson 1.3 +as a K definition. Identify why it fails to compile. Then pass an appropriate +--md-selector to the compiler in order to make it compile.

      +
    4. +
    5. +

      Modify your calculator application from Lesson 1.7, Exercise 2, to be written +in a literate style. Consider what text might be appropriate to turn the +resulting markdown file into documentation for your calculator.

      +
    6. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.9: Unparsing and the format and color attributes.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/09_unparsing/index.html b/k-distribution/k-tutorial/1_basic/09_unparsing/index.html new file mode 100644 index 00000000000..0531b347535 --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/09_unparsing/index.html @@ -0,0 +1,718 @@ + + + + + + + + + + + + + + +Lesson 1.9: Unparsing and the format and color attributes | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.9: Unparsing and the format and color attributes

    +

    The purpose of this lesson is to teach the user about how terms are +pretty-printed in K, and how the user can make adjustments to the default +settings for how to print specific terms.

    +

    Parsing, Execution, and Unparsing

    +

    When you use krun to interpret a program, the tool passes through three major +phases. In the first, parsing, the program itself is parsed using either kast +or an ahead-of-time parser generated via Bison, and the resulting AST becomes +the input to the interpreter. In the second phase, execution, K evaluates +functions and (as we will discuss in depth later) performs rewrite steps to +iteratively transform the program state. The third and final phase is called +unparsing, because it consists of taking the final state of the application +after the program has been interpreted, and converting it from an AST back into +text that (in theory, anyway) could be parsed back into the same AST that was +the output of the execution phase.

    +

    In practice, parsing is not always precisely reversible. It turns out +(although we are not going to cover exactly why this is here), that +constructing a sound algorithm that takes a grammar and an AST and emits text +that could be parsed via that grammar to the original AST is an +NP-hard problem. As a result, in the interests of avoiding exponential time +algorithms when users rarely care about unparsing being completely sound, we +take certain shortcuts that provide a linear-time algorithm that approximates +a sound solution to the problem while sacrificing the notion that the result +can be parsed into the exact original term in all cases.

    +

    This is a lot of theoretical explanation, but at root, the unparsing process +is fairly simple: it takes a K term that is the output of execution and pretty +prints it according to the syntax defined by the user in their K definition. +This is useful because the original AST is not terribly user-readable, and it +is difficult to visualize the entire term or decipher information about the +final state of the program at a quick glance. Of course, in rare cases, the +pretty-printed configuration loses information of relevance, which is why K +allows you to obtain the original AST on request.

    +

    As an example of all of this, consider the following K definition +(lesson-09-a.k):

    +
    k
    module LESSON-09-A + imports BOOL + + syntax Exp ::= "(" Exp ")" [bracket] + | Bool + > "!" Exp + > left: + Exp "&&" Exp + | Exp "^" Exp + | Exp "||" Exp + + syntax Exp ::= id(Exp) [function] + rule id(E) => E +endmodule +
    +

    This is similar to the grammar we defined in LESSON-06-C, with the difference +that the Boolean expressions are now constructors of sort Exp and we define a +trivial function over expressions that returns its argument unchanged.

    +

    We can now parse a simple program in this definition and use it to unparse some +Boolean expressions. For example (exp.bool):

    +
    id(true&&false&&!true^(false||true))
    +
    +

    Here is a program that is not particularly legible at first glance, because all +extraneous whitespace has been removed. However, if we run krun exp.bool, we +see that the result of the unparser will pretty-print this expression rather +nicely:

    +
    <k>
    +  true && false && ! true ^ ( false || true ) ~> .
    +</k>
    +
    +

    Notably, not only does K insert whitespace where appropriate, it is also smart +enough to insert parentheses where necessary in order to ensure the correct +parse. For example, without those parentheses, the expression above would parse +equivalent to the following one:

    +
    (((true && false) && ! true) ^ false) || true
    +
    +

    Indeed, you can confirm this by passing that exact expression to the id +function and evaluating it, then looking at the result of the unparser:

    +
    <k>
    +  true && false && ! true ^ false || true ~> .
    +</k>
    +
    +

    Here, because the meaning of the AST is the same both with and without +parentheses, K does not insert any parentheses when unparsing.

    +

    Exercise

    +

    Modify the grammar of LESSON-09-A above so that the binary operators are +right associative. Try unparsing exp.bool again, and note how the result is +different. Explain the reason for the difference.

    +

    Custom unparsing of terms

    +

    You may have noticed that right now, the unparsing of terms is not terribly +imaginative. All it is doing is taking each child of the term, inserting it +into the non-terminal positions of the production, then printing the production +with a space between each terminal or non-terminal. It is easy to see why this +might not be desirable in some cases. Consider the following K definition +(lesson-09-b.k):

    +
    k
    module LESSON-09-B + imports BOOL + + syntax Stmt ::= "{" Stmt "}" | "{" "}" + > right: + Stmt Stmt + | "if" "(" Bool ")" Stmt + | "if" "(" Bool ")" Stmt "else" Stmt [avoid] +endmodule +
    +

    This is a statement grammar, simplified to the point of meaninglessness, but +still useful as an object lesson in unparsing. Consider the following program +in this grammar (if.stmt):

    +
    if (true) {
    +  if (true) {}
    +  if (false) {}
    +  if (true) {
    +    if (false) {} else {}
    +  } else {
    +    if (false) {}
    +  }
    +}
    +
    +

    This is how that term would be unparsed if it appeared in the output of krun:

    +
    if ( true ) { if ( true ) { } if ( false ) { } if ( true ) { if ( false ) { } else { } } else { if ( false ) { } } }
    +
    +

    This is clearly much less legible than we started with! What are we to do? +Well, K provides an attribute, format, that can be applied to any production, +which controls how that production gets unparsed. You've seen how it gets +unparsed by default, but via this attribute, the developer has complete control +over how the term is printed. Of course, the user can trivially create ways to +print terms that would not parse back into the same term. Sometimes this is +even desirable. But in most cases, what you are interested in is controlling +the line breaking, indentation, and spacing of the production.

    +

    Here is an example of how you might choose to apply the format attribute +to improve how the above term is unparsed (lesson-09-c.k):

    +
    k
    module LESSON-09-C + imports BOOL + + syntax Stmt ::= "{" Stmt "}" [format(%1%i%n%2%d%n%3)] | "{" "}" [format(%1%2)] + > right: + Stmt Stmt [format(%1%n%2)] + | "if" "(" Bool ")" Stmt [format(%1 %2%3%4 %5)] + | "if" "(" Bool ")" Stmt "else" Stmt [avoid, format(%1 %2%3%4 %5 %6 %7)] +endmodule +
    +

    If we compile this new definition and unparse the same term, this is the +result we get:

    +
    if (true) {
    +  if (true) {}
    +  if (false) {}
    +  if (true) {
    +    if (false) {} else {}
    +  } else {
    +    if (false) {}
    +  }
    +}
    +
    +

    This is the exact same text we started with! By adding the format attributes, +we were able to indent the body of code blocks, adjust the spacing of if +statements, and put each statement on a new line.

    +

    How exactly was this achieved? Well, each time the unparser reaches a term, +it looks at the format attribute of that term. That format attribute is a +mix of characters and format codes. Format codes begin with the % +character. Each character in the format attribute other than a format code is +appended verbatim to the output, and each format code is handled according to +its meaning, transformed (possibly recursively) into a string of text, and +spliced into the output at the position the format code appears in the format +string.

    +

    Provided for reference is a table with a complete list of all valid format +codes, followed by their meaning:

    + + + + + + + + + +
    Format Code Meaning
    n Insert '\n' followed by the current indentation + level
    i Increase the current indentation level by 1
    d Decrease the current indentation level by 1
    c Move to the next color in the list of colors for + this production (see next section)
    r Reset color to the default foreground color for + the terminal (see next section)
    an integer Print a terminal or non-terminal from the + production. The integer is treated as a 1-based + index into the terminals and non-terminals of + the production. +
    +
    If the offset refers to a terminal, move to the + next color in the list of colors for this + production, print the value of that terminal, + then reset the color to the default foreground + color for the terminal. +
    +
    If the offset refers to a regular expression + terminal, it is an error. +
    +
    If the offset refers to a non-terminal, unparse + the corresponding child of the current term + (starting with the current indentation level) + and print the resulting text, then set the + current color and indentation level to the color + and indentation level following unparsing that + term.
    other char Print that character verbatim
    +

    Exercise

    +

    Change the format attributes for LESSON-09-C so that if.stmt will unparse +as follows:

    +
    if (true)
    +{
    +  if (true)
    +  {
    +  }
    +  if (false)
    +  {
    +  }
    +  if (true)
    +  {
    +    if (false)
    +    {
    +    }
    +    else
    +    {
    +    }
    +  }
    +  else
    +  {
    +    if (false)
    +    {
    +    }
    +  }
    +}
    +
    +

    Output coloring

    +

    When the output of unparsing is displayed on a terminal supporting colors, K +is capable of coloring the output, similar to what is possible with a syntax +highlighter. This is achieved via the color and colors attributes.

    +

    Essentially, both the color and colors attributes are used to construct a +list of colors associated with each production, and then the format attribute +is used to control how those colors are used to unparse the term. At its most +basic level, you can set the color attribute to color all the terminals in +the production a certain color, or you can use the colors attribute to +specify a comma-separated list of colors for each terminal in the production. +At a more advanced level, the %c and %r format codes control how the +formatter interacts with the list of colors specified by the colors +attribute. You can essentially think of the color attribute as a way of +specifying that you want all the colors in the list to be the same color.

    +

    Note that the %c and %r format codes are relatively primitive in nature. +The color and colors attributes merely maintain a list of colors, whereas +the %c and %r format codes merely control how to advance through that list +and how individual text is colored.

    +

    It is an error if the colors attribute does not provide all the colors needed +by the terminals and escape codes in the production. %r does not change the +position in the list of colors at all, so the next %c will advance to the +following color.

    +

    As a complete example, here is a variant of LESSON-09-A which colors the +various boolean operators:

    +
    k
    module LESSON-09-D + imports BOOL + + syntax Exp ::= "(" Exp ")" [bracket] + | Bool + > "!" Exp [color(yellow)] + > left: + Exp "&&" Exp [color(red)] + | Exp "^" Exp [color(blue)] + | Exp "||" Exp [color(green)] + + syntax Exp ::= id(Exp) [function] + rule id(E) => E +endmodule +
    +

    For a complete list of allowed colors, see +here.

    +

    Exercises

    +
      +
    1. +

      Use the color attribute on LESSON-09-C to color the keywords true and +false one color, the keywords if and else another color, and the operators +(, ), {, and } a third color.

      +
    2. +
    3. +

      Use the format, color, and colors attributes to tell the unparser to +style the expression grammar from Lesson 1.8, Exercise 3 according to your own +personal preferences for syntax highlighting and code formatting. You can +view the result of the unparser on a function term without evaluating that +function by means of the command kparse <file> | kore-print -.

      +
    4. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.10: Strings.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/10_strings/index.html b/k-distribution/k-tutorial/1_basic/10_strings/index.html new file mode 100644 index 00000000000..06c269804b3 --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/10_strings/index.html @@ -0,0 +1,554 @@ + + + + + + + + + + + + + + +Lesson 1.10: Strings | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.10: Strings

    +

    The purpose of this lesson is to explain how to use the String sort in K to +represent sequences of characters, and explain where to find additional +information about builtin functions over strings.

    +

    The String Sort

    +

    In addition to the Int and Bool sorts covered in +Lesson 1.6, K provides, among others, the +String sort to represent sequences of characters. You can import this +functionality via the STRING-SYNTAX module, which contains the syntax of +string literals in K, and the STRING module, which contains all the functions +that operate over the String type.

    +

    Strings in K are double-quoted. The following list of escape sequences is +supported:

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    Escape SequenceMeaning
    \"The literal character "
    \\The literal character \
    \nThe newline character (ASCII code 0x0a)
    \rThe carriage return character (ASCII code 0x0d)
    \tThe tab character (ASCII code 0x09)
    \fThe form feed character (ASCII code 0x0c)
    \x00\x followed by 2 hexadecimal digits indicates a code point between 0x00 and 0xFF
    \u0000\u followed by 4 hexadecimal digits indicates a code point between 0x0000 and 0xFFFF
    \U00000000\U followed by 8 hexadecimal digits indicates a code point between 0x000000 and 0x10FFFF
    +

    Please note that as of the current moment, K's unicode support is not fully +complete, so you may run into errors using code points greater than 0xff.

    +

    As an example, you can construct a string literal containing the following +block of text:

    +
    This is an example block of text.
    +Here is a quotation: "Hello world."
    +	This line is indented.
    +ÁÉÍÓÚ
    +
    +

    Like so:

    +
    "This is an example block of text.\nHere is a quotation: \"Hello world.\"\n\tThis line is indented.\n\xc1\xc9\xcd\xd3\xda\n"
    +
    +

    Basic String Functions

    +

    The full list of functions provided for the String sort can be found in +domains.md, but here we +describe a few of the more basic ones.

    +

    String concatenation

    +

    The concatenation operator for strings is +String. For example, consider +the following K rule that constructs a string from component parts +(lesson-10.k):

    +
    k
    module LESSON-10 + imports STRING + + syntax String ::= msg(String) [function] + rule msg(S) => "The string you provided: " +String S +String "\nHave a nice day!" +endmodule +
    +

    Note that this operator is O(N), so repeated concatenations are inefficient. +For information about efficient string concatenation, refer to +Lesson 2.14.

    +

    String length

    +

    The function to return the length of a string is lengthString. For example, +lengthString("foo") will return 3, and lengthString("") will return 0. +The return value is the length of the string in code points.

    +

    Substring computation

    +

    The function to compute the substring of a string is substrString. It +takes two string indices, starting from 0, and returns the substring within the +range [start..end). It is only defined if end >= start, start >= 0, and +end <= length of string. Here, for example, we return the first 5 characters +of a string:

    +
    substrString(S, 0, 5)
    +
    +

    Here we return all but the first 3 characters:

    +
    substrString(S, 3, lengthString(S))
    +
    +

    Exercises

    +
      +
    1. Write a function that takes a paragraph of text (i.e., a sequence of +sentences, each ending in a period), and constructs a new (nonsense) sentence +composed of the first word of each sentence, followed by a period. Do not +worry about capitalization or periods within the sentence which do not end the +sentence (e.g. "Dr."). You can assume that all whitespace within the paragraph +are spaces. For more information about the functions over strings required to +implement such a function, refer to domains.md.
    2. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.11: Casting Terms.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/11_casts/index.html b/k-distribution/k-tutorial/1_basic/11_casts/index.html new file mode 100644 index 00000000000..27b007740fe --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/11_casts/index.html @@ -0,0 +1,592 @@ + + + + + + + + + + + + + + +Lesson 1.11: Casting Terms | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.11: Casting Terms

    +

    The purpose of this lesson is to explain how to use cast expressions in +order to disambiguate terms using sort information. We also explain how the +variable sort inference algorithm works in K, and how to change the default +behavior by casting variables to a particular sort.

    +

    Casting in K

    +

    Sometimes the grammar you write for your rules in K can be a little bit +ambiguous on purpose. While grammars for programming languages may be +unambiguous when considered in their entirety, K allows you to write rules +involving arbitrary fragments of that grammar, and those fragments can +sometimes be ambiguous by themselves, or similar enough to other fragments +of the grammar to trigger ambiguity. As a result, in addition to the tools +covered in Lesson 1.4, K provides one +additional powerful tool for disambiguation: cast expressions.

    +

    K provides three main types of casts: the semantic cast, the strict cast, and +the projection cast. We will cover each of them, and their similarities and +differences, in turn.

    +

    Semantic casts

    +

    The most basic, and most common, type of cast in K is called the +semantic cast. For every sort S declared in a module, K provides the +following (implicit) production for use in sentences:

    +
      syntax S ::= S ":S"
    +
    +

    Note that S simply represents the name of the sort. For example, if we +defined a sort Exp, the actual production for that sort would be:

    +
      syntax Exp ::= Exp ":Exp"
    +
    +

    At runtime, this expression will not actually exist; it is merely an annotation +to the compiler describing the sort of the term inside the cast. It is telling +the compiler that the term inside the cast must be of sort Exp. For example, +if we had the following grammar:

    +
    k
    module LESSON-11-A + imports INT + + syntax Exp ::= Int | Exp "+" Exp + syntax Stmt ::= "if" "(" Exp ")" Stmt | "{" "}" +endmodule +
    +

    Then we would be able to write 1:Exp, or (1 + 2):Exp, but not {}:Exp.

    +

    You can also restrict the sort that a variable in a rule will match by casting +it. For example, consider the following additional module:

    +
    k
    module LESSON-11-B + imports LESSON-11-A + imports BOOL + + syntax Term ::= Exp | Stmt + syntax Bool ::= isExpression(Term) [function] + + rule isExpression(_E:Exp) => true + rule isExpression(_) => false [owise] +endmodule +
    +

    Here we have defined a very simple function that decides whether a term is +an expression or a statement. It does this by casting the variable inside the +isExpression rule to sort Exp. As a result, that variable will only match terms +of sort Exp. Thus, isExpression(1) will return true, as will isExpression(1 + 2), but +isExpression({}) will return false.

    +

    Exercise

    +

    Verify this fact for yourself by running isExpression on the above examples. Then +write an isStatement function, and test that it works as expected.

    +

    Strict casts

    +

    On occasion, a semantic cast is not strict enough. It might be that you want +to, for disambiguation purposes, say exactly what sort a term is. For +example, consider the following definition:

    +
    k
    module LESSON-11-C + imports INT + + syntax Exp ::= Int | Exp "+" Exp [group(exp)] + syntax Exp2 ::= Exp | Exp2 "+" Exp2 [group(exp2)] +endmodule +
    +

    This grammar is a little ambiguous and contrived, but it serves to demonstrate +how a semantic cast might be insufficient to disambiguate a term. If we were +to write the term (I1:Int + I2:Int):Exp2, the term would be ambiguous, +because the cast is not sufficiently strict to determine whether you mean +to derive the "+" production in the group exp or the one in the group exp2.

    +

    In this situation, there is a solution: the strict cast. For every sort +S in your grammar, K also defines the following production:

    +
      syntax S ::= S "::S"
    +
    +

    This may at first glance seem the same as the previous cast. And indeed, +from the perspective of the grammar and from the perspective of rewriting, +they are in fact identical. However, the second variant has a unique meaning +in the type system of K: namely, the term inside the cast cannot be a +subsort, i.e., a term of another sort S2 such that the production +syntax S ::= S2 exists.

    +

    As a result, if we were to write in the above grammar the term +(I1:Int + I2:Int)::Exp2, then we would know that the second derivation above +should be chosen, whereas if we want the first derivation, we could write +(I1:Int + I2:Int)::Exp.

    +

    Projection casts

    +

    Thus far we have focused entirely on casts which exist solely to inform the +compiler about the sort of terms. However, sometimes when dealing with grammars +containing subsorts, it can be desirable to reason with the subsort production +itself, which injects one sort into another. Remember from above that such +a production looks like syntax S ::= S2. This type of production, called a +subsort production, can be thought of as a type of inheritance involving +constructors. If we have the above production in our grammar, we say that S2 +is a subsort of S, or that any S2 is also an S. K implicitly maintains a +symbol at runtime which keeps track of where such subsortings occur; this +symbol is called an injection.

    +

    Sometimes, when one sort is a subsort of another, it can be the case that +a function returns one sort, but you actually want to cast the result of +calling that function to another sort which is a subsort of the first sort. +This is similar to what happens with inheritance in an object-oriented +language, where you might cast a superclass to a subclass if you know for +sure the object at runtime is in fact an instance of that class.

    +

    K provides something similar for subsorts: the projection cast.

    +

    For each pair of sorts S and S2, K provides the following production:

    +
      syntax S ::= "{" S2 "}" ":>S"
    +
    +

    What this means is that you take any term of sort S2 and cast it to sort +S. If the term of sort S2 consists of an injection containing a term of sort +S, then this will return that term. Otherwise, an error occurs and rewriting +fails, returning the projection function which failed to apply. The sort is +not actually checked at compilation time; rather, it is a runtime check +inserted into the code that runs when the rule applies.

    +

    For example, here is a module that makes use of projection casts:

    +
    k
    module LESSON-11-D + imports INT + imports BOOL + + syntax Exp ::= Int | Bool | Exp "+" Exp | Exp "&&" Exp + + syntax Exp ::= eval(Exp) [function] + rule eval(I:Int) => I + rule eval(B:Bool) => B + rule eval(E1 + E2) => {eval(E1)}:>Int +Int {eval(E2)}:>Int + rule eval(E1 && E2) => {eval(E1)}:>Bool andBool {eval(E2)}:>Bool +endmodule +
    +

    Here we have defined constructors for a simple expression language over +Booleans and integers, as well as a function eval that evaluates these +expressions to a value. Because that value could be an integer or a Boolean, +we need the casts in the last two rules in order to meet the type signature of ++Int and andBool. Of course, the user can write ill-formed expressions like +1 && true or false + true, but these will cause errors at runtime, because +the projection cast will fail.

    +

    Exercises

    +
      +
    1. +

      Extend the eval function in LESSON-11-D to include Strings and add a . +operator which concatenates them.

      +
    2. +
    3. +

      Modify your solution from Lesson 1.9, Exercise 2 by using an Exp sort to +express the integer and Boolean expressions that it supports, in the same style +as LESSON-11-D. Then write an eval function that evaluates all terms of +sort Exp to either a Bool or an Int.

      +
    4. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.12: Syntactic Lists.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/12_syntactic_lists/index.html b/k-distribution/k-tutorial/1_basic/12_syntactic_lists/index.html new file mode 100644 index 00000000000..927958f51a3 --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/12_syntactic_lists/index.html @@ -0,0 +1,577 @@ + + + + + + + + + + + + + + +Lesson 1.12: Syntactic Lists | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.12: Syntactic Lists

    +

    The purpose of this lesson is to explain how K provides support for syntactic +repetition through the use of the List{} and NeList{} constructs, +generally called syntactic lists.

    +

    The List{} construct

    +

    Sometimes, when defining a grammar in K, it is useful to define a syntactic +construct consisting of an arbitrary-length sequence of items. For example, +you might wish to define a function call construct, and need to express a way +of passing arguments to the function. You can in theory simply define these +productions using ordinary constructors, but it can be tricky to get the syntax +exactly right in K without a lot of tedious glue code.

    +

    For this reason, K provides a way of specifying that a non-terminal represents +a syntactic list (lesson-12-a.k):

    +
    k
    module LESSON-12-A-SYNTAX + imports INT-SYNTAX + + syntax Ints ::= List{Int,","} +endmodule + +module LESSON-12-A + imports LESSON-12-A-SYNTAX +endmodule +
    +

    Note that instead of a sequence of terminals and non-terminals, the right hand +side of the Ints production contains the symbol List followed by two items +in curly braces. The first item is the non-terminal which is the element type +of the list, and the second item is a terminal representing the separator of +the list. As a special case, lists which are separated only by whitespace can +be specified with a separator of "".

    +

    This List{} construct is roughly equivalent to the following definition +(lesson-12-b.k):

    +
    k
    module LESSON-12-B-SYNTAX + imports INT-SYNTAX + + syntax Ints ::= Int "," Ints | ".Ints" +endmodule + +module LESSON-12-B + imports LESSON-12-B-SYNTAX +endmodule +
    +

    As you can see, the List{} construct represents a cons-list with an element +at the head and another list at the tail. The empty list is represented by +a . followed by the sort of the list.

    +

    However, the List{} construct provides several key syntactic conveniences +over the above definition. First of all, when writing a list in a rule, +explicitly writing the terminator is not always required. For example, consider +the following additional module (lesson-12-c.k):

    +
    k
    module LESSON-12-C + imports LESSON-12-A + imports INT + + syntax Int ::= sum(Ints) [function] + rule sum(I:Int) => I + rule sum(I1:Int, I2:Int, Is:Ints) => sum(I1 +Int I2, Is) +endmodule +
    +

    Here we see a function that sums together a non-empty list of integers. Note in +particular the first rule. We do not explicitly mention .Ints, but in fact, +the rule in question is equivalent to the following rule:

    +
      rule sum(I:Int, .Ints) => I
    +
    +

    The reason for this is that K will automatically insert a list terminator +anywhere a syntactic list is expected, but an element of that list appears +instead. This works even with lists of more than one element:

    +
      rule sum(I1:Int, I2:Int) => I1 +Int I2
    +
    +

    This rule is redundant, but here we explicitly match a list of exactly two +elements, because the .Ints is implicitly added after I2.

    +

    Parsing Syntactic Lists in Programs

    +

    An additional syntactic convenience takes place when you want to express a +syntactic list in the input to krun. In this case, K will automatically +transform the grammar in LESSON-12-B-SYNTAX into the following +(lesson-12-d.k):

    +
    k
    module LESSON-12-D + imports INT-SYNTAX + + syntax Ints ::= #NonEmptyInts | #IntsTerminator + syntax #NonEmptyInts ::= Int "," #NonEmptyInts + | Int #IntsTerminator + syntax #IntsTerminator ::= "" +endmodule +
    +

    This allows you to express the usual comma-separated list of arguments where +an empty list is represented by the empty string, and you don't have to +explicitly terminate the list. Because of this, we can write the syntax +of function calls in C very easily (lesson-12-e.k):

    +
    k
    module LESSON-12-E + syntax Id ::= r"[a-zA-Z_][a-zA-Z0-9_]*" [token] + syntax Exp ::= Id | Exp "(" Exps ")" + syntax Exps ::= List{Exp,","} +endmodule +
    +

    Exercise

    +

    Write a function concat which takes a list of String and concatenates them +all together. Do not worry if the function is O(n^2). +Test your implementation using the syntactic sugar for lists added by the parser.

    +

    Then write some function call expressions using identifiers in C and verify with +kast that the above grammar captures the intended syntax. Make sure to test +with function calls with zero, one, and two or more arguments.

    +

    The NeList{} construct

    +

    One limitation of the List{} construct is that it is always possible to +write a list of zero elements where a List{} is expected. While this is +desirable in a number of cases, it is sometimes not what the grammar expects.

    +

    For example, in C, it is not allowable for an enum definition to have zero +members. In other words, if we were to write the grammar for enumerations like +so (lesson-12-f.k):

    +
    k
    module LESSON-12-F + syntax Id ::= r"[a-zA-Z_][a-zA-Z0-9_]*" [token] + syntax Exp ::= Id + + syntax EnumSpecifier ::= "enum" Id "{" Ids "}" + syntax Ids ::= List{Id,","} +endmodule +
    +

    Then we would be syntactically allowed to write enum X {}, which instead, +ought to be a syntax error.

    +

    For this reason, we introduce the additional NeList{} construct. The syntax +is identical to List{}, except with NeList instead of List before the +curly braces. When parsing rules, it behaves identically to the List{} +construct. However, when parsing inputs to krun, the above grammar, if we +replaced syntax Ids ::= List{Id,","} with syntax Ids ::= NeList{Id,","}, +would become equivalent to the following (lesson-12-g.k):

    +
    k
    module LESSON-12-G + syntax Id ::= r"[a-zA-Z_][a-zA-Z0-9_]*" [token] + syntax Exp ::= Id + + syntax EnumSpecifier ::= "enum" Id "{" Ids "}" + syntax Ids ::= Id | Id "," Ids +endmodule +
    +

    In other words, only non-empty lists of Id would be allowed.

    +

    Exercises

    +
      +
    1. +

      Modify the sum function in LESSON-12-C so that the Ints sort is an +NeList{}. Verify that calling sum() with no arguments is now a syntax +error.

      +
    2. +
    3. +

      Write a modified sum function with the List construct that can also sum +up an empty list of arguments. In such a case, the sum ought to be 0.

      +
    4. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.13: Basics of K Rewriting.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/13_rewrite_rules/index.html b/k-distribution/k-tutorial/1_basic/13_rewrite_rules/index.html new file mode 100644 index 00000000000..188fbf84aab --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/13_rewrite_rules/index.html @@ -0,0 +1,696 @@ + + + + + + + + + + + + + + +Lesson 1.13: Basics of K Rewriting | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.13: Basics of K Rewriting

    +

    The purpose of this lesson is to explain how rewrite rules that are not the +definition of a function behave, and how, using these rules, you can construct +a semantics of programs in a programming language in K.

    +

    Recap: Function rules in K

    +

    Recall from Lesson 1.2 that we have, thus far, +introduced two types of productions in K: constructors and functions. +A function is identified by the function attribute placed on the +production. As you may recall, when we write a rule with a function on the +left-hand side of the => operator, we are defining the meaning of that +function for inputs which match the patterns on the left-hand side of the rule. +If the argument to the function match the patterns, then the function is +evaluated to the value constructed by substituting the bindings for the +variables into the right-hand side of the rule.

    +

    Top-level rules

    +

    However, function rules are not the only type of rule permissible in K, nor +even the most frequently used. K also has a concept of a +top-level rewrite rule. The simplest way to ensure that a rule is treated +as a top-level rule is for the left-hand side of the rule to mention one or +more cells. We will cover how cells work and are declared in more detail +in a later lesson, but for now, what you should know is that when we ran krun +in our very first example in Lesson 1.2 and got the following output:

    +
    <k>
    +  Yellow ( ) ~> .
    +</k>
    +
    +

    <k> is a cell, known by convention as the K cell. This cell is available +by default in any definition without needing to be explicitly declared.

    +

    The K cell contains a single term of sort K. K is a predefined sort in K +with two constructors, that can be roughly represented by the following +grammar:

    +
      syntax K ::= KItem "~>" K
    +             | "."
    +
    +

    As a syntactic convenience, K allows you to treat ~> like it is an +associative list (i.e., as if it were defined as syntax K ::= K "~>" K). +When a definition is compiled, it will automatically transform the rules you +write so that they treat the K sort as a cons-list. Another syntactic +convenience is that, for disambiguation purposes, you can write .K anywhere +you would otherwise write . and the meaning is identical.

    +

    Now, you may notice that the above grammar mentions the sort KItem. This is +another built-in sort in K. For every sort S declared in a definition (with +the exception of K and KItem), K will implicitly insert the following +production:

    +
      syntax KItem ::= S
    +
    +

    In other words, every sort is a subsort of the sort KItem, and thus a term +of any sort can be injected as an element of a term of sort K, also called +a K sequence.

    +

    By default, when you krun a program, the AST of the program is inserted as +the sole element of a K sequence into the <k> cell. This explains why we +saw the output we did in Lesson 1.2.

    +

    With these preliminaries in mind, we can now explain how top-level rewrite +rules work in K. Put simply, any rule where there is a cell (such as the K +cell) at the top on the left-hand side will be a top-level rewrite rule. Once +the initial program has been inserted into the K cell, the resulting term, +called the configuration, will be matched against all the top-level +rewrite rules in the definition. If only one rule matches, the substitution +generated by the matching will be applied to the right-hand side of the rule +and the resulting term is rewritten to be the new configuration. Rewriting +proceeds by iteratively applying rules, also called taking steps, until +no top-level rewrite rule can be applied. At this point the configuration +becomes the final configuration and is output by krun.

    +

    If more than one top-level rule applies, by default, K will pick just one +of those rules, apply it, and continue rewriting. However, it is +non-deterministic which rule applies. In theory, it could be any of them. +By passing the --search flag to krun, you are able to tell krun to +explore all possible non-deterministic choices, and generate a complete list of +all possible final configurations reachable by each nondeterminstic choice that +can be made. Note that the --search flag to krun only works if you pass +--enable-search to kompile first.

    +

    Unlike top-level rewrite rules, function rules are not associated with any +particular set of cells in the configuration (although they can contain cells +in their function arguments and return value). While top-level rewrite rules +apply to the entire term being rewritten, function rules apply anywhere a +function application for that function appears, and are immediately rewritten +to their return value in that position.

    +

    Another key distinction between top-level rules and function rules is that +function symbols, i.e., productions with the function attribute, are +mathematical functions rather than constructors. While a constructor is +logically distinct from any other constructor of the same sort, and can be +matched against unconditionally, a function does not necessaraily have the +same restriction unless it happens to be an injective function. Thus, two +function symbols with different arguments may still ultimately produce the +same value and thus compare equal to one another. Due to this, concrete +execution (i.e., all K definitions introduced thus far; see Lesson 1.21) +introduces the restriction that you cannot match on a function symbol on the +left-hand side of a rule, except as the top symbol on the left-hand side of +a function rule. This restriction will be later lifted when we introduce the +Haskell Backend which performs symbolic execution.

    +

    Exercise

    +

    Pass a program containing no functions to krun. You can use a term of sort +Exp from LESSON-11-D. Observe the output and try to understand why you get +the output you do. Then write two rules that rewrite that program to another. +Run krun --search on that program and observe both results. Then add a third +rule that rewrites one of those results again. Test that that rule applies as +well.

    +

    Using top-level rules to evaluate expressions

    +

    Thus far, we have focused primarily on defining functions over constructors +in K. However, now that we have a basic understanding of top-level rules, +it is possible to introduce a rewrite system to our definitions. A rewrite +system is a collection of top-level rewrite rules which performs an organized +transformation of a particular program into a result which expresses the +meaning of that program. For example, we might rewrite an expression in a +programming language into a value representing the result of evaluating that +expression.

    +

    Recall in Lesson 1.11, we wrote a simple grammar of Boolean and integer +expressions that looked roughly like this (lesson-13-a.k):

    +
    k
    module LESSON-13-A + imports INT + + syntax Exp ::= Int + | Bool + | Exp "+" Exp + | Exp "&&" Exp +endmodule +
    +

    In that lesson, we defined a function eval which evaluated such expressions +to either an integer or Boolean.

    +

    However, it is more idiomatic to evaluate such expressions using top-level +rewrite rules. Here is how one might do so in K (lesson-13-b.k):

    +
    k
    module LESSON-13-B-SYNTAX + imports UNSIGNED-INT-SYNTAX + imports BOOL-SYNTAX + + syntax Val ::= Int | Bool + syntax Exp ::= Val + > left: Exp "+" Exp + > left: Exp "&&" Exp +endmodule + +module LESSON-13-B + imports LESSON-13-B-SYNTAX + imports INT + imports BOOL + + rule <k> I1:Int + I2:Int ~> K:K </k> => <k> I1 +Int I2 ~> K </k> + rule <k> B1:Bool && B2:Bool ~> K:K </k> => <k> B1 andBool B2 ~> K </k> + + syntax KItem ::= freezer1(Val) | freezer2(Exp) + | freezer3(Val) | freezer4(Exp) + + rule <k> E1:Val + E2:Exp ~> K:K </k> => <k> E2 ~> freezer1(E1) ~> K </k> [priority(51)] + rule <k> E1:Exp + E2:Exp ~> K:K </k> => <k> E1 ~> freezer2(E2) ~> K </k> [priority(52)] + rule <k> E1:Val && E2:Exp ~> K:K </k> => <k> E2 ~> freezer3(E1) ~> K </k> [priority(51)] + rule <k> E1:Exp && E2:Exp ~> K:K </k> => <k> E1 ~> freezer4(E2) ~> K </k> [priority(52)] + + rule <k> E2:Val ~> freezer1(E1) ~> K:K </k> => <k> E1 + E2 ~> K </k> + rule <k> E1:Val ~> freezer2(E2) ~> K:K </k> => <k> E1 + E2 ~> K </k> + rule <k> E2:Val ~> freezer3(E1) ~> K:K </k> => <k> E1 && E2 ~> K </k> + rule <k> E1:Val ~> freezer4(E2) ~> K:K </k> => <k> E1 && E2 ~> K </k> +endmodule +
    +

    This is of course rather cumbersome currently, but we will soon introduce +syntactic convenience which makes writing definitions of this type considerably +easier. For now, notice that there are roughly 3 types of rules here: the first +matches a K cell in which the first element of the K sequence is an Exp whose +arguments are values, and rewrites the first element of the sequence to the +result of that expression. The second also matches a K cell with an Exp in +the first element of its K sequence, but it matches when one or both arguments +of the Exp are not values, and replaces the first element of the K sequence +with two new elements: one being an argument to evaluate, and the other being +a special constructor called a freezer. Finally, the third matches a K +sequence where a Val is first, and a freezer is second, and replaces them +with a partially evaluated expression.

    +

    This general pattern is what is known as heating an expression, +evaluating its arguments, cooling the arguments into the expression +again, and evaluating the expression itself. By repeatedly performing +this sequence of actions, we can evaluate an entire AST containing a complex +expression down into its resulting value.

    +

    Exercise

    +

    Write an addition expression with integers. Use krun --depth 1 to see the +result of rewriting after applying a single top-level rule. Gradually increase +the value of --depth to see successive states. Observe how this combination +of rules is eventually able to evaluate the entire expression.

    +

    Simplifying the evaluator: Local rewrites and cell ellipses

    +

    As you saw above, the definition we wrote is rather cumbersome. Over the +remainder of Lessons 1.13 and 1.14, we will greatly simplify it. The first step +in doing so is to teach a bit more about the rewrite operator, =>. Thus far, +all the rules we have written look like rule LHS => RHS. However, this is not +the only way the rewrite operator can be used. It is actually possible to place +a constructor or function at the very top of the rule, and place rewrite +operators inside that term. While a rewrite operator cannot appear nested +inside another rewrite operator, by doing this, we can express that some parts +of what we are matching are not changed by the rewrite operator. For +example, consider the following rule from above:

    +
      rule <k> I1:Int + I2:Int ~> K:K </k> => <k> I1 +Int I2 ~> K </k>
    +
    +

    We can equivalently write it like following:

    +
      rule <k> (I1:Int + I2:Int => I1 +Int I2) ~> _:K </k>
    +
    +

    When you put a rewrite inside a term like this, in essence, you are telling +the rule to only rewrite part of the left-hand side to the right-hand side. +In practice, this is implemented by lifting the rewrite operator to the top of +the rule by means of duplicating the surrounding context.

    +

    There is a way that the above rule can be simplified further, however. K +provides a special syntax for each cell containing a term of sort K, indicating +that we want to match only on some prefix of the K sequence. For example, the +above rule can be simplified further like so:

    +
      rule <k> I1:Int + I2:Int => I1 +Int I2 ...</k>
    +
    +

    Here we have placed the symbol ... immediately prior to the </k> which ends +the cell. What this tells the compiler is to take the contents of the cell, +treat it as the prefix of a K sequence, and insert an anonymous variable of +sort K at the end. Thus we can think of ... as a way of saying we +don't care about the part of the K sequence after the beginning, leaving +it unchanged.

    +

    Putting all this together, we can rewrite LESSON-13-B like so +(lesson-13-c.k):

    +
    k
    module LESSON-13-C-SYNTAX + imports UNSIGNED-INT-SYNTAX + imports BOOL-SYNTAX + + syntax Val ::= Int | Bool + syntax Exp ::= Val + > left: Exp "+" Exp + > left: Exp "&&" Exp +endmodule + +module LESSON-13-C + imports LESSON-13-C-SYNTAX + imports INT + imports BOOL + + rule <k> I1:Int + I2:Int => I1 +Int I2 ...</k> + rule <k> B1:Bool && B2:Bool => B1 andBool B2 ...</k> + + syntax KItem ::= freezer1(Val) | freezer2(Exp) + | freezer3(Val) | freezer4(Exp) + + rule <k> E1:Val + E2:Exp => E2 ~> freezer1(E1) ...</k> [priority(51)] + rule <k> E1:Exp + E2:Exp => E1 ~> freezer2(E2) ...</k> [priority(52)] + rule <k> E1:Val && E2:Exp => E2 ~> freezer3(E1) ...</k> [priority(51)] + rule <k> E1:Exp && E2:Exp => E1 ~> freezer4(E2) ...</k> [priority(52)] + + rule <k> E2:Val ~> freezer1(E1) => E1 + E2 ...</k> + rule <k> E1:Val ~> freezer2(E2) => E1 + E2 ...</k> + rule <k> E2:Val ~> freezer3(E1) => E1 && E2 ...</k> + rule <k> E1:Val ~> freezer4(E2) => E1 && E2 ...</k> +endmodule +
    +

    This is still rather cumbersome, but it is already greatly simplified. In the +next lesson, we will see how additional features of K can be used to specify +heating and cooling rules much more compactly.

    +

    Exercises

    +
      +
    1. Modify LESSON-13-C to add rules to evaluate integer subtraction.
    2. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.14: Defining Evaluation Order.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/14_evaluation_order/index.html b/k-distribution/k-tutorial/1_basic/14_evaluation_order/index.html new file mode 100644 index 00000000000..214b50e8328 --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/14_evaluation_order/index.html @@ -0,0 +1,707 @@ + + + + + + + + + + + + + + +Lesson 1.14: Defining Evaluation Order | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.14: Defining Evaluation Order

    +

    The purpose of this lesson is to explain how to use the heat and cool +attributes, context and context alias sentences, and the strict and +seqstrict attributes to more compactly express heating and cooling in K, +and to express more advanced evaluation strategies in K.

    +

    The heat and cool attributes

    +

    Thus far, we have been using rule priority and casts to express when to heat +an expression and when to cool it. For example, the rules for heating have +lower priority, so they do not apply if the term could be evaluated instead, +and the rules for heating are expressly written only to apply if the argument +of the expression is a value.

    +

    However, K has built-in support for deciding when to heat and when to cool. +This support comes in the form of the rule attributes heat and cool as +well as the specially named function isKResult.

    +

    Consider the following definition, which is equivalent to LESSON-13-C +(lesson-14-a.k):

    +
    k
    module LESSON-14-A-SYNTAX + imports UNSIGNED-INT-SYNTAX + imports BOOL-SYNTAX + + syntax Exp ::= Int + | Bool + > left: Exp "+" Exp + > left: Exp "&&" Exp +endmodule + +module LESSON-14-A + imports LESSON-14-A-SYNTAX + imports INT + imports BOOL + + rule <k> I1:Int + I2:Int => I1 +Int I2 ...</k> + rule <k> B1:Bool && B2:Bool => B1 andBool B2 ...</k> + + syntax KItem ::= freezer1(Exp) | freezer2(Exp) + | freezer3(Exp) | freezer4(Exp) + + rule <k> E:Exp + HOLE:Exp => HOLE ~> freezer1(E) ...</k> + requires isKResult(E) [heat] + rule <k> HOLE:Exp + E:Exp => HOLE ~> freezer2(E) ...</k> [heat] + rule <k> E:Exp && HOLE:Exp => HOLE ~> freezer3(E) ...</k> + requires isKResult(E) [heat] + rule <k> HOLE:Exp && E:Exp => HOLE ~> freezer4(E) ...</k> [heat] + + rule <k> HOLE:Exp ~> freezer1(E) => E + HOLE ...</k> [cool] + rule <k> HOLE:Exp ~> freezer2(E) => HOLE + E ...</k> [cool] + rule <k> HOLE:Exp ~> freezer3(E) => E && HOLE ...</k> [cool] + rule <k> HOLE:Exp ~> freezer4(E) => HOLE && E ...</k> [cool] + + syntax Bool ::= isKResult(K) [function, symbol] + rule isKResult(_:Int) => true + rule isKResult(_:Bool) => true + rule isKResult(_) => false [owise] +endmodule +
    +

    We have introduced three major changes to this definition. First, we have +removed the Val sort. We replace it instead with a function isKResult. +The function in question must have the same signature and attributes as seen in +this example. It ought to return true whenever a term should not be heated +(because it is a value) and false when it should be heated (because it is not +a value). We thus also insert isKResult calls in the side condition of two +of the heating rules, where the Val sort was previously used.

    +

    Second, we have removed the rule priorities on the heating rules and the use of +the Val sort on the cooling rules, and replaced them with the heat and +cool attributes. These attributes instruct the compiler that these rules are +heating and cooling rules, and thus should implicitly apply only when certain +terms on the LHS either are or are not a KResult (i.e., isKResult returns +true versus false).

    +

    Third, we have renamed some of the variables in the heating and cooling rules +to the special variable HOLE. Syntactically, HOLE is just a special name +for a variable, but it is treated specially by the compiler. By naming a +variable HOLE, we have informed the compiler which term is being heated +or cooled. The compiler will automatically insert the side condition +requires isKResult(HOLE) to cooling rules and the side condition +requires notBool isKResult(HOLE) to heating rules.

    +

    Exercise

    +

    Modify LESSON-14-A to add rules to evaluate integer subtraction.

    +

    Simplifying further with Contexts

    +

    The above example is still rather cumbersome to write. We must explicitly write +both the heating and the cooling rule separately, even though they are +essentially inverses of one another. It would be nice to instead simply +indicate which terms should be heated and cooled, and what part of them to +operate on.

    +

    To do this, K introduces a new type of sentence, the context. Contexts +begin with the context keyword instead of the rule keyword, and usually +do not contain a rewrite operator.

    +

    Consider the following definition which is equivalent to LESSON-14-A +(lesson-14-b.k):

    +
    k
    module LESSON-14-B-SYNTAX + imports UNSIGNED-INT-SYNTAX + imports BOOL-SYNTAX + + syntax Exp ::= Int + | Bool + > left: Exp "+" Exp + > left: Exp "&&" Exp +endmodule + +module LESSON-14-B + imports LESSON-14-B-SYNTAX + imports INT + imports BOOL + + rule <k> I1:Int + I2:Int => I1 +Int I2 ...</k> + rule <k> B1:Bool && B2:Bool => B1 andBool B2 ...</k> + + context <k> E:Exp + HOLE:Exp ...</k> + requires isKResult(E) + context <k> HOLE:Exp + _:Exp ...</k> + context <k> E:Exp && HOLE:Exp ...</k> + requires isKResult(E) + context <k> HOLE:Exp && _:Exp ...</k> + + syntax Bool ::= isKResult(K) [function, symbol] + rule isKResult(_:Int) => true + rule isKResult(_:Bool) => true + rule isKResult(_) => false [owise] +endmodule +
    +

    In this example, the heat and cool rules have been removed entirely, as +have been the productions defining the freezers. Don't worry, they still exist +under the hood; the compiler is just generating them automatically. For each +context sentence like above, the compiler generates a #freezer production, +a heat rule, and a cool rule. The generated form is equivalent to the +rules we wrote manually in LESSON-14-A. However, we are now starting to +considerably simplify the definition. Instead of 3 sentences, we just have one.

    +

    context alias sentences and the strict and seqstrict attributes

    +

    Notice that the contexts we included in LESSON-14-B still seem rather +similar in form. For each expression we want to evaluate, we are declaring +one context for each operand of that expression, and they are each rather +similar to one another. We would like to be able to simplify further by +simply annotating each expression production with information about how +it is to be evaluated instead. We can do this with the seqstrict attribute.

    +

    Consider the following definition, once again equivalent to those above +(lesson-14-c.k):

    +
    .k .alias
    module LESSON-14-C-SYNTAX + imports UNSIGNED-INT-SYNTAX + imports BOOL-SYNTAX + + syntax Exp ::= Int + | Bool + > left: Exp "+" Exp [seqstrict(exp; 1, 2)] + > left: Exp "&&" Exp [seqstrict(exp; 1, 2)] +endmodule + +module LESSON-14-C + imports LESSON-14-C-SYNTAX + imports INT + imports BOOL + + rule <k> I1:Int + I2:Int => I1 +Int I2 ...</k> + rule <k> B1:Bool && B2:Bool => B1 andBool B2 ...</k> + + context alias [exp]: <k> HERE ...</k> + + syntax Bool ::= isKResult(K) [function, symbol] + rule isKResult(_:Int) => true + rule isKResult(_:Bool) => true + rule isKResult(_) => false [owise] +endmodule +
    +

    This definition has two important changes from the one above. The first is +that the individual context sentences have been removed and have been +replaced with a single context alias sentence. You may notice that this +sentence begins with an identifier in square brackets followed by a colon. This +syntax is a way of naming individual sentences in K for reference by the tool +or by other sentences. The context alias sentence also has a special variable +HERE.

    +

    The second is that the productions in LESSON-14-C-SYNTAX have been given a +seqstrict attribute. The value of this attribute has two parts. The first +is the name of a context alias sentence. The second is a comma-separated list +of integers. Each integer represents an index of a non-terminal in the +production, counting from 1. For each integer present, the compiler implicitly +generates a new context sentence according to the following rules:

    +
      +
    1. The compiler starts by looking for the context alias sentence named. If +there is more than one, then one context sentence is created per +context alias sentence with that name.
    2. +
    3. For each context created, the variable HERE in the context alias is +substituted with an instance of the production the seqstrict attribute is +attached to. Each child of that production is a variable. The non-terminal +indicated by the integer offset of the seqstrict attribute is given the name +HOLE.
    4. +
    5. For each integer offset prior in the list to the one currently being +processed, the predicate isKResult(E) is conjuncted together and included +as a side condition, where E is the child of the production term with that +offset, starting from 1. For example, if the attribute lists 1, 2, then +the rule generated for the 2 will include isKResult(E1) where E1 is the +first child of the production.
    6. +
    +

    As you can see if you work through the process, the above code will ultimately +generate the same contexts present in LESSON-14-B.

    +

    Finally, note that there are a few minor syntactic conveniences provided by the +seqstrict attribute. First, in the special case of the context alias sentence +being <k> HERE ...</k>, you can omit both the context alias sentence +and the name from the seqstrict attribute.

    +

    Second, if the numbered list of offsets contains every non-terminal in the +production, it can be omitted from the attribute value.

    +

    Thus, we can finally produce the idiomatic K definition for this example +(lesson-14-d.k):

    +
    k
    module LESSON-14-D-SYNTAX + imports UNSIGNED-INT-SYNTAX + imports BOOL-SYNTAX + + syntax Exp ::= Int + | Bool + > left: Exp "+" Exp [seqstrict] + > left: Exp "&&" Exp [seqstrict] +endmodule + +module LESSON-14-D + imports LESSON-14-D-SYNTAX + imports INT + imports BOOL + + rule <k> I1:Int + I2:Int => I1 +Int I2 ...</k> + rule <k> B1:Bool && B2:Bool => B1 andBool B2 ...</k> + + syntax Bool ::= isKResult(K) [function, symbol] + rule isKResult(_:Int) => true + rule isKResult(_:Bool) => true + rule isKResult(_) => false [owise] +endmodule +
    +

    Exercise

    +

    Modify LESSON-14-D to add a production and rule to evaluate integer +subtraction.

    +

    Nondeterministic evaluation order with the strict attribute

    +

    Thus far, we have focused entirely on deterministic evaluation order. However, +not all languages are deterministic in the order they evaluate expressions. +For example, in C, the expression a() + b() + c() is guaranteed to parse +to (a() + b()) + c(), but it is not guaranteed that a will be called before +b before c. In fact, this evaluation order is non-deterministic.

    +

    We can express non-deterministic evaluation orders with the strict attribute. +Its behavior is identical to the seqstrict attribute, except that step 3 in +the above list (with the side condition automatically added) does not take +place. In other words, if we wrote syntax Exp ::= Exp "+" Exp [strict] +instead of syntax Exp ::= Exp "+" Exp [seqstrict], it would generate the +following two contexts instead of the ones found in LESSON-14-B:

    +
      context <k> _:Exp + HOLE:Exp ...</k>
    +  context <k> HOLE:Exp + _:Exp ...</k>
    +
    +

    As you can see, these contexts will generate heating rules that can both +apply to the same term. As a result, the choice of which heating rule +applies first is non-deterministic, and as we saw in Lesson 1.13, we can +get all possible behaviors by passing --search to krun.

    +

    Exercises

    +
      +
    1. +

      Add integer division to LESSON-14-D. Make division and addition strict +instead of seqstrict, and write a rule evaluating integer division with a +side condition that the denominator is non-zero. Run krun --search on the +program 1 / 0 + 2 / 1 and observe all possible outputs of the program. How +many are there total, and why?

      +
    2. +
    3. +

      Rework your solution from Lesson 1.9, Exercise 2 to evaluate expressions from left to right using the seqstrict attribute.

      +
    4. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.15: Configuration Declarations and Cell Nesting.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/15_configurations/index.html b/k-distribution/k-tutorial/1_basic/15_configurations/index.html new file mode 100644 index 00000000000..b85d620b385 --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/15_configurations/index.html @@ -0,0 +1,663 @@ + + + + + + + + + + + + + + +Lesson 1.15: Configuration Declarations and Cell Nesting | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.15: Configuration Declarations and Cell Nesting

    +

    The purpose of this lesson is to explain how to store additional information +about the state of your interpreter by declaring cells using the +configuration sentence, as well as how to add additional inputs to your +definition.

    +

    Cells and Configuration Declarations

    +

    We have already covered the absolute basics of cells in K by looking at the +<k> cell. As explained in Lesson 1.13, the +<k> cell is available without being explicitly declared. It turns out this is +because, if the user does not explicitly specify a configuration sentence +anywhere in the main module of their definition, the configuration sentence +from the DEFAULT-CONFIGURATION module of +kast.md is imported +automatically. Here is what that sentence looks like:

    +
      configuration <k> $PGM:K </k>
    +
    +

    This configuration declaration declares a single cell, the <k> cell. It also +declares that at the start of rewriting, the contents of that cell should be +initialized with the value of the $PGM configuration variable. +Configuration variables function as inputs to krun. These terms are supplied +to krun in the form of ASTs parsed using a particular module. By default, the +$PGM configuration variable uses the main syntax module of the definition.

    +

    The cast on the configuration variable also specifies the sort that is used as +the entry point to the parser, in this case the K sort. It is often +useful to cast to other sorts there as well for better control over the accepted +language. The sort used for the $PGM variable is referred to as the start +symbol. During parsing, the default start symbol K subsumes all user-defined +sorts except for syntactic lists. These are excluded because they will always +produce an ambiguity error when parsing a single element.

    +

    Note that we did not explicitly specify the $PGM configuration variable when +we invoked krun on a file. This is because krun handles the $PGM variable +specially, and allows you to pass the term for that variable via a file passed +as a positional argument to krun. We did, however, specify the PGM name +explicitly when we called krun with the -cPGM command line argument in +Lesson 1.2. This is the other, explicit, way of +specifying an input to krun.

    +

    This explains the most basic use of configuration declarations in K. We can, +however, declare multiple cells and multiple configuration variables. We can +also specify the initial values of cells statically, rather than dynamically +via krun.

    +

    For example, consider the following definition (lesson-15-a.k):

    +
    k
    module LESSON-15-A-SYNTAX + imports INT-SYNTAX + + syntax Ints ::= List{Int,","} +endmodule + +module LESSON-15-A + imports LESSON-15-A-SYNTAX + imports INT + + configuration <k> $PGM:Ints </k> + <sum> 0 </sum> + + rule <k> I:Int, Is:Ints => Is ...</k> + <sum> SUM:Int => SUM +Int I </sum> +endmodule +
    +

    This simple definition takes a list of integers as input and sums them +together. Here we have declared two cells: <k> and <sum>. Unlike <k>, +<sum> does not get initialized via a configuration variable, but instead +is initialized statically with the value 0.

    +

    Note the rule in the second module: we have explicitly specified multiple +cells in a single rule. K will expect each of these cells to match in order for +the rule to apply.

    +

    Here is a second example (lesson-15-b.k):

    +
    k
    module LESSON-15-B-SYNTAX + imports INT-SYNTAX +endmodule + +module LESSON-15-B + imports LESSON-15-B-SYNTAX + imports INT + imports BOOL + + configuration <k> . </k> + <first> $FIRST:Int </first> + <second> $SECOND:Int </second> + + rule <k> . => FIRST >Int SECOND </k> + <first> FIRST </first> + <second> SECOND </second> +endmodule +
    +

    This definition takes two integers as command-line arguments and populates the +<k> cell with a Boolean indicating whether the first integer is greater than +the second. Notice that we have specified no $PGM configuration variable +here. As a result, we cannot invoke krun via the syntax krun $file. +Instead, we must explicitly pass values for each configuration variable via the +-cFIRST and -cSECOND command line flags. For example, if we invoke +krun -cFIRST=0 -cSECOND=1, we will get the value false in the K cell.

    +

    You can also specify both a $PGM configuration variable and other +configuration variables in a single configuration declaration, in which case +you would be able to initialize $PGM with either a positional argument or the +-cPGM command line flag, but the other configuration variables would need +to be explicitly initialized with -c.

    +

    Exercise

    +

    Modify your solution to Lesson 1.14, Exercise 2 to add a new cell with a +configuration variable of sort Bool. This variable should determine whether +the / operator is evaluated using /Int or divInt. Test that by specifying +different values for this variable, you can change the behavior of rounding on +division of negative numbers.

    +

    Cell Nesting

    +

    It is possible to nest cells inside one another. A cell that contains other +cells must contain only other cells, but in doing this, you are able to +create a hierarchical structure to the configuration. Consider the following +definition (lesson-15-c.k), which is equivalent to the one in LESSON-15-B:

    +
    k
    module LESSON-15-C-SYNTAX + imports INT-SYNTAX +endmodule + +module LESSON-15-C + imports LESSON-15-C-SYNTAX + imports INT + imports BOOL + + configuration <T> + <k> . </k> + <state> + <first> $FIRST:Int </first> + <second> $SECOND:Int </second> + </state> + </T> + + rule <k> . => FIRST >Int SECOND </k> + <first> FIRST </first> + <second> SECOND </second> +endmodule +
    +

    Note that we have added some new cells to the configuration declaration: +the <T> cell wraps the entire configuration, and the <state> cell is +introduced around the <first> and <second> cells.

    +

    However, we have not changed the rule in this definition. This is because of +a concept in K called configuration abstraction. K allows you to specify +any number of cells in a rule (except zero) in any order you want, and K will +compile the rules into a form that matches the structure of the configuration +specified by the configuration declaration.

    +

    Here then, is how this rule would look after the configuration abstraction +has been resolved:

    +
      rule <T>
    +         <k> . => FIRST >Int SECOND </k>
    +         <state>
    +           <first> FIRST </first>
    +           <second> SECOND </second>
    +         </state>
    +       </T>
    +
    +

    In other words, K will complete cells to the top of the configuration by +inserting parent cells where appropriate based on the declared structure of +the configuration. This is useful because as a definition evolves, the +configuration may change, but you don't want to have to modify every single +rule each time. Thus, K follows the principle that you should only mention the +cells in a rule that are actually needed in order to accomplish its specific +goal. By following this best practice, you can significantly increase the +modularity of the definition and make it easier to maintain and modify.

    +

    Note that unlike top-level rewrite rules, cells that appear inside function +rules are not necessarily completed to the top of the configuration. They still +participate in cell ccompletion in the sense that you can mention cell +structure loosely inside a function rule and it will be completed into the +correct cell structure specified by the configuration declaration. However, +they do not complete all the way to the top, instead completing only up to +the top-most cell mentioned in the rule.

    +

    For example, if I write the following function rule in the above definition:

    +
      rule doStuff(<first> FIRST </first>) => FIRST
    +
    +

    The function will only match on the first cell, rather than the entire +configuration. However, if we had mentioned a parent cell in the rule, it still +would have completed the children of that parent cell as needed to ensure that +the resulting term is well formed.

    +

    Exercise

    +

    Modify your definition from the previous exercise in this lesson to wrap the +two cells you have declared in a top cell <T>. You should not have to change +any other rules in the definition.

    +

    Cell Variables

    +

    Sometimes it is desirable to explicitly match a variable against certain +fragments of the configuration. Because K's configuration is hierarchical, +we can grab subsets of the configuration as if they were just another term. +However, configuration abstraction applies here as well. +In particular, for each cell you specify in a configuration declaration, a +unique sort is assigned for that cell with a single constructor (the cell +itself). The sort name is taken by removing all special characters, +capitalizing the first letter and each letter after a hyphen, and adding the +word Cell at the end. For example, in the above example, the cell sorts are +TCell, KCell, StateCell, FirstCell, and SecondCell. If we had declared +a cell as <first-number>, then the cell sort name would be FirstNumberCell.

    +

    You can explicitly reference a variable of one of these sorts anywhere you +might instead write that cell. For example, consider the following rule:

    +
      rule <k> true => S </k>
    +       (S:StateCell => <state>... .Bag ...</state>)
    +
    +

    Here we have introduced two new concepts. The first is the variable of sort +StateCell, which matches the entire <state> part of the configuration. The +second is that we have introduced the concept of ... once again. When a cell +contains other cells, it is also possible to specify ... on either the left, +right or both sides of the cell term. Each of these three syntaxes are +equivalent in this case. When they appear on the left-hand side of a rule, they +indicate that we don't care what value any cells not explicitly named might +have. For example, we might write <state>... <first> 0 </first> ...</state> on +the left-hand side of a rule in order to indicate that we want to match the +rule when the <first> cell contains a zero, regardless of what the <second> +cell contains. If we had not included this ellipsis, it would have been a +syntax error, because K would have expected you to provide a value for each of +the child cells.

    +

    However, if, as in the example above, the ... appeared on the right-hand side +of a rule, this instead indicates that the cells not explicitly mentioned under +the cell should be initialized with their default value from the configuration +declaration. In other words, that rule will set the value of <first> and +<second> to zero.

    +

    You may note the presence of the phrase .Bag here. You can think of this as +the empty set of cells. It is used as the child of a cell when you want to +indicate that no cells should be explicitly named. We will cover other uses +of this term in later lessons.

    +

    Exercises

    +
      +
    1. Modify the definition from the previous exercise in this lesson so that the +Boolean cell you created is initialized to false. Then add a production +syntax Stmt ::= Bool ";" Exp, and a rule that uses this Stmt to set the +value of the Boolean flag. Then add another production +syntax Stmt ::= "reset" ";" Exp which sets the value of the Boolean flag back +to its default value via a ... on the right-hand side. You will need to add +an additional cell around the Boolean cell to make this work.
    2. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.16: Maps, Semantic Lists, and Sets.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/16_collections/index.html b/k-distribution/k-tutorial/1_basic/16_collections/index.html new file mode 100644 index 00000000000..b5e77739aa4 --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/16_collections/index.html @@ -0,0 +1,742 @@ + + + + + + + + + + + + + + +Lesson 1.16: Maps, Semantic Lists, and Sets | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.16: Maps, Semantic Lists, and Sets

    +

    The purpose of this lesson is to explain how to use the data structure sorts +provided by K: maps, lists, and sets.

    +

    Maps

    +

    The most frequently used type of data structure in K is the map. The sort +provided by K for this purpose is the Map sort, and it is provided in +domains.md in the MAP +module. This type is not (currently) polymorphic. All Map terms are maps that +map terms of sort KItem to other terms of sort KItem. A KItem can contain +any sort except a K sequence. If you need to store such a term in a +map, you can always use a wrapper such as syntax KItem ::= kseq(K).

    +

    A Map pattern consists of zero or more map elements (as represented by the +symbol syntax Map ::= KItem "|->" KItem), mixed in any order, separated by +whitespace, with zero or one variables of sort Map. The empty map is +represented by .Map. If all of the bindings for the variables in the keys +of the map can be deterministically chosen, these patterns can be matched in +O(1) time. If they cannot, then each map element that cannot be +deterministically constructed contributes a single dimension of polynomial +time to the cost of the matching. In other words, a single such element is +linear, two are quadratic, three are cubic, etc.

    +

    Patterns like the above are the only type of Map pattern that can appear +on the left-hand-side of a rule. In other words, you are not allowed to write +a Map pattern on the left-hand-side with more than one variable of sort Map +in it. You are, however, allowed to write such patterns on the right-hand-side +of a rule. You can also write a function pattern in the key of a map element +so long as all the variables in the function pattern can be deterministically +chosen.

    +

    Note the meaning of matching on a Map pattern: a map pattern with no +variables of sort Map will match if the map being matched has exactly as +many bindings as |-> symbols in the pattern. It will then match if each +binding in the map pattern matches exactly one distinct binding in the map +being matched. A map pattern with one Map variable will also match any map +that contains such a map as a subset. The variable of sort Map will be bound +to whatever bindings are left over (.Map if there are no bindings left over).

    +

    Here is an example of a simple definition that implements a very basic +variable declaration semantics using a Map to store the value of variables +(lesson-16-a.k):

    +
    k
    module LESSON-16-A-SYNTAX + imports INT-SYNTAX + imports ID-SYNTAX + + syntax Exp ::= Id | Int + syntax Decl ::= "int" Id "=" Exp ";" [strict(2)] + syntax Pgm ::= List{Decl,""} +endmodule + +module LESSON-16-A + imports LESSON-16-A-SYNTAX + imports BOOL + + configuration <T> + <k> $PGM:Pgm </k> + <state> .Map </state> + </T> + + // declaration sequence + rule <k> D:Decl P:Pgm => D ~> P ...</k> + rule <k> .Pgm => . ...</k> + + // variable declaration + rule <k> int X:Id = I:Int ; => . ...</k> + <state> STATE => STATE [ X <- I ] </state> + + // variable lookup + rule <k> X:Id => I ...</k> + <state>... X |-> I ...</state> + + syntax Bool ::= isKResult(K) [symbol, function] + rule isKResult(_:Int) => true + rule isKResult(_) => false [owise] +endmodule +
    +

    There are several new features in this definition. First, note we import +the module ID-SYNTAX. This module is defined in domains.md and provides a +basic syntax for identifiers. We are using the Id sort provided by this +module in this definition to implement the names of program variables. This +syntax is only imported when parsing programs, not when parsing rules. Later in +this lesson we will see how to reference specific concrete identifiers in a +rule.

    +

    Second, we introduce a single new function over the Map sort. This function, +which is represented by the symbol +syntax Map ::= Map "[" KItem "<-" KItem "]", represents the map update +operation. Other functions over the Map sort can be found in domains.md.

    +

    Finally, we have used the ... syntax on a cell containing a Map. In this +case, the meaning of <state>... Pattern ...</state>, +<state>... Pattern </state>, and <state> Pattern ...</state> are the same: +it is equivalent to writing <state> (Pattern) _:Map </state>.

    +

    Consider the following program (a.decl):

    +
    int x = 0;
    +int y = 1;
    +int a = x;
    +
    +

    If we run this program with krun, we will get the following result:

    +
    <T>
    +  <k>
    +    .
    +  </k>
    +  <state>
    +    a |-> 0
    +    x |-> 0
    +    y |-> 1
    +  </state>
    +</T>
    +
    +

    Note that krun has automatically sorted the collection for you. This doesn't +happen at runtime, so you still get the performance of a hash map, but it will +help make the output more readable.

    +

    Exercise

    +

    Create a sort Stmt that is a subsort of Decl. Create a production of sort +Stmt for variable assignment in addition to the variable declaration +production. Feel free to use the syntax syntax Stmt ::= Id "=" Exp ";". Write +a rule that implements variable assignment using a map update function. Then +write the same rule using a map pattern. Test your implementations with some +programs to ensure they behave as expected.

    +

    Semantic Lists

    +

    In a previous lesson, we explained how to represent lists in the AST of a +program. However, this is not the only context where lists can be used. We also +frequently use lists in the configuration of an interpreter in order to +represent certain types of program state. For this purpose, it is generally +useful to have an associative-list sort, rather than the cons-list sorts +provided in Lesson 1.12.

    +

    The type provided by K for this purpose is the List sort, and it is also +provided in domains.md, in the LIST module. This type is also not +(currently) polymorphic. Like Map, all List terms are lists of terms of the +KItem sort.

    +

    A List pattern in K consists of zero or more list elements (as represented by +the ListItem symbol), followed by zero or one variables of sort List, +followed by zero or more list elements. An empty list is represented by +.List. These patterns can be matched in O(log(N)) time. This is the only +type of List pattern that can appear on the left-hand-side of a rule. In +other words, you are not allowed to write a List pattern on the +left-hand-side with more than one variable of sort List in it. You are, +however, allowed to write such patterns on the right-hand-side of a rule.

    +

    Note the meaning of matching on a List pattern: a list pattern with no +variables of sort List will match if the list being matched has exactly as +many elements as ListItem symbols in the pattern. It will then match if each +element in sequence matches the pattern contained in the ListItem symbol. A +list pattern with one variable of sort List operates the same way, except +that it can match any list with at least as many elements as ListItem +symbols, so long as the prefix and suffix of the list match the patterns inside +the ListItem symbols. The variable of sort List will be bound to whatever +elements are left over (.List if there are no elements left over).

    +

    The ... syntax is allowed on cells containing lists as well. In this case, +the meaning of <cell>... Pattern </cell> is the same as +<cell> _:List (Pattern) </cell>, the meaning of <cell> Pattern ...</cell> +is the same as <cell> (Pattern) _:List</cell>. Because list patterns with +multiple variables of sort List are not allowed, it is an error to write +<cell>... Pattern ...</cell>.

    +

    Here is an example of a simple definition that implements a very basic +function-call semantics using a List as a function stack (lesson-16-b.k):

    +
    k
    module LESSON-16-B-SYNTAX + imports INT-SYNTAX + imports ID-SYNTAX + + syntax Exp ::= Id "(" ")" | Int + syntax Stmt ::= "return" Exp ";" [strict] + syntax Decl ::= "fun" Id "(" ")" "{" Stmt "}" + syntax Pgm ::= List{Decl,""} + syntax Id ::= "main" [token] +endmodule + +module LESSON-16-B + imports LESSON-16-B-SYNTAX + imports BOOL + imports LIST + + configuration <T> + <k> $PGM:Pgm ~> main () </k> + <functions> .Map </functions> + <fstack> .List </fstack> + </T> + + // declaration sequence + rule <k> D:Decl P:Pgm => D ~> P ...</k> + rule <k> .Pgm => . ...</k> + + // function definitions + rule <k> fun X:Id () { S } => . ...</k> + <functions>... .Map => X |-> S ...</functions> + + // function call + syntax KItem ::= stackFrame(K) + rule <k> X:Id () ~> K => S </k> + <functions>... X |-> S ...</functions> + <fstack> .List => ListItem(stackFrame(K)) ...</fstack> + + // return statement + rule <k> return I:Int ; ~> _ => I ~> K </k> + <fstack> ListItem(stackFrame(K)) => .List ...</fstack> + + syntax Bool ::= isKResult(K) [function, symbol] + rule isKResult(_:Int) => true + rule isKResult(_) => false [owise] +endmodule +
    +

    Notice that we have declared the production syntax Id ::= "main" [token]. +Since we use the ID-SYNTAX module, this declaration is necessary in order to +be able to refer to the main identifier directly in the configuration +declaration. Our <k> cell now contains a K sequence initially: first we +process all the declarations in the program, then we call the main function.

    +

    Consider the following program (foo.func):

    +
    fun foo() { return 5; }
    +fun main() { return foo(); }
    +
    +

    When we krun this program, we should get the following output:

    +
    <T>
    +  <k>
    +    5 ~> .
    +  </k>
    +  <functions>
    +    foo |-> return 5 ;
    +    main |-> return foo ( ) ;
    +  </functions>
    +  <fstack>
    +    .List
    +  </fstack>
    +</T>
    +
    +

    Note that we have successfully put on the <k> cell the value returned by the +main function.

    +

    Exercise

    +

    Add a term of sort Id to the stackFrame operator to keep track of the +name of the function in that stack frame. Then write a function +syntax String ::= printStackTrace(List) that takes the contents of the +<fstack> cell and pretty prints the current stack trace. You can concatenate +strings with +String in the STRING module in domains.md, and you can +convert an Id to a String with the Id2String function in the ID module. +Test this function by creating a new expression that returns the current stack +trace as a string. Make sure to update isKResult and the Exp sort as +appropriate to allow strings as values.

    +

    Sets

    +

    The final primary data structure sort in K is a set, i.e., an idempotent +unordered collection where elements are deduplicated. The sort provided by K +for this purpose is the Set sort and it is provided in domains.md in the +SET module. Like maps and lists, this type is not (currently) polymorphic. +Like Map and List, all Set terms are sets of terms of the KItem sort.

    +

    A Set pattern has the exact same restrictions as a Map pattern, except that +its elements are treated like keys, and there are no values. It has the same +performance characteristics as well. However, syntactically it is more similar +to the List sort: An empty Set is represented by .Set, but a set element +is represented by the SetItem symbol.

    +

    Matching behaves similarly to the Map sort: a set pattern with no variables +of sort Set will match if the set has exactly as many bindings as SetItem +symbols, and if each element pattern matches one distinct element in the set. +A set with a variable of sort Set also matches any superset of such a set. +As with map, the elements left over will be bound to the Set variable (or +.Set if no elements are left over).

    +

    Like Map, the ... syntax on a set is syntactic sugar for an anonymous +variable of sort Set.

    +

    Here is an example of a simple modification to LESSON-16-A which uses a Set +to ensure that variables are never declared more than once. In practice, you +would likely just use the in_keys symbol over maps to test for this, but +it's still useful as an example of sets in practice:

    +
    k
    module LESSON-16-C-SYNTAX + imports LESSON-16-A-SYNTAX +endmodule + +module LESSON-16-C + imports LESSON-16-C-SYNTAX + imports BOOL + imports SET + + configuration <T> + <k> $PGM:Pgm </k> + <state> .Map </state> + <declared> .Set </declared> + </T> + + // declaration sequence + rule <k> D:Decl P:Pgm => D ~> P ...</k> + rule <k> .Pgm => . ...</k> + + // variable declaration + rule <k> int X:Id = I:Int ; => . ...</k> + <state> STATE => STATE [ X <- I ] </state> + <declared> D => D SetItem(X) </declared> + requires notBool X in D + + // variable lookup + rule <k> X:Id => I ...</k> + <state>... X |-> I ...</state> + <declared>... SetItem(X) ...</declared> + + syntax Bool ::= isKResult(K) [symbol, function] + rule isKResult(_:Int) => true + rule isKResult(_) => false [owise] +endmodule +
    +

    Now if we krun a program containing duplicate declarations, it will get +stuck on the declaration.

    +

    Exercises

    +
      +
    1. Modify your solution to Lesson 1.14, Exercise 2 and introduce the sorts +Decls, Decl, and Stmt which include variable and function declaration +(without function parameters), and return and assignment statements, as well +as call expressions. Use List and Map to implement these operators, making +sure to consider the interactions between components, such as saving and +restoring the environment of variables at each call site. Don't worry about +local function definitions or global variables for now. Make sure to test the +resulting interpreter.
    2. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.17: Cell Multiplicity and Cell Collections.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/17_cell_multiplicity/index.html b/k-distribution/k-tutorial/1_basic/17_cell_multiplicity/index.html new file mode 100644 index 00000000000..892afe4d5cf --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/17_cell_multiplicity/index.html @@ -0,0 +1,577 @@ + + + + + + + + + + + + + + +Lesson 1.17: Cell Multiplicity and Cell Collections | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.17: Cell Multiplicity and Cell Collections

    +

    The purpose of this lesson is to explain how you can create optional cells +and cells that repeat multiple times in a configuration using a feature called +cell multiplicity.

    +

    Cell Multiplicity

    +

    K allows you to specify attributes for cell productions as part of the syntax +of configuration declarations. Unlike regular productions, which use the [] +syntax for attributes, configuration cells use an XML-like attribute syntax:

    +
    configuration <k color="red"> $PGM:K </k>
    +
    +

    This configuration declaration gives the <k> cell the color red during +unparsing using the color attribute as discussed in +Lesson 1.9.

    +

    However, in addition to the usual attributes for productions, there are some +other attributes that can be applied to cells with special meaning. One such +attribute is the multiplicity attribute. By default, each cell that is +declared occurs exactly once in every configuration term. However, using the +multiplicity attribute, this default behavior can be changed. There are two +values that this attribute can have: ? and *.

    +

    Optional cells

    +

    The first cell multiplicity we will discuss is ?. Similar to a regular +expression language, this attribute tells the compiler that this cell can +appear 0 or 1 times in the configuration. In other words, it is an +optional cell. By default, K does not create optional cells in the initial +configuration, unless that optional cell has a configuration variable inside +it. However, it is possible to override the default behavior and create that +cell initially by adding the additional cell attribute initial="".

    +

    K uses the .Bag symbol to represent the absence of any cells in a particular +rule. Consider the following module:

    +
    k
    module LESSON-17-A + imports INT + + configuration <k> $PGM:K </k> + <optional multiplicity="?"> 0 </optional> + + syntax KItem ::= "init" | "destroy" + + rule <k> init => . ...</k> + (.Bag => <optional> 0 </optional>) + rule <k> destroy => . ...</k> + (<optional> _ </optional> => .Bag) + +endmodule +
    +

    In this definition, when the init symbol is executed, the <optional> cell +is added to the configuration, and when the destroy symbol is executed, it +is removed. Any rule that matches on that cell will only match if that cell is +present in the configuration.

    +

    Exercise

    +

    Create a simple definition with a Stmts sort that is a List{Stmt,""} and +a Stmt sort with the constructors +syntax Stmt ::= "enable" | "increment" | "decrement" | "disable". The +configuration should have an optional cell that contains an integer that +is created with the enable command, destroyed with the disable command, +and its value is incremented or decremented by the increment and decrement +command.

    +

    Cell collections

    +

    The second type of cell multiplicity we will discuss is *. Simlar to a +regular expression language, this attribute tells the compiler that this cell +can appear 0 or more times in the configuration. In other words, it is a +cell collection. Cells with multiplicity * must be the only child of +their parent cell. As a convention, the inner cell is usually named with the +singular form of what it contains, and the outer cell with the plural form, for +example, "thread" and "threads".

    +

    All cell collections are required to have the type attribute set to either +Set or Map. A Set cell collection is represented as a set and behaves +internally the same as the Set sort, although it actually declares a new +sort. A Map cell collection is represented as a Map in which the first +subcell of the cell collection is the key and the remaining cells are the +value.

    +

    For example, consider the following module:

    +
    k
    module LESSON-17-B + imports INT + imports BOOL + imports ID-SYNTAX + + syntax Stmt ::= Id "=" Exp ";" [strict(2)] + | "return" Exp ";" [strict] + syntax Stmts ::= List{Stmt,""} + syntax Exp ::= Id + | Int + | Exp "+" Exp [seqstrict] + | "spawn" "{" Stmts "}" + | "join" Exp ";" [strict] + + configuration <threads> + <thread multiplicity="*" type="Map"> + <id> 0 </id> + <k> $PGM:K </k> + </thread> + </threads> + <state> .Map </state> + <next-id> 1 </next-id> + + rule <k> X:Id => I:Int ...</k> + <state>... X |-> I ...</state> + rule <k> X:Id = I:Int ; => . ...</k> + <state> STATE => STATE [ X <- I ] </state> + rule <k> S:Stmt Ss:Stmts => S ~> Ss ...</k> + rule <k> I1:Int + I2:Int => I1 +Int I2 ...</k> + + rule <thread>... + <k> spawn { Ss } => NEXTID ...</k> + ...</thread> + <next-id> NEXTID => NEXTID +Int 1 </next-id> + (.Bag => + <thread> + <id> NEXTID </id> + <k> Ss </k> + </thread>) + + rule <thread>... + <k> join ID:Int ; => I ...</k> + ...</thread> + (<thread> + <id> ID </id> + <k> return I:Int ; ...</k> + </thread> => .Bag) + + syntax Bool ::= isKResult(K) [function, symbol] + rule isKResult(_:Int) => true + rule isKResult(_) => false [owise] +endmodule +
    +

    This module implements a very basic fork/join semantics. The spawn expression +spawns a new thread to execute a sequence of statements and returns a thread +id, and the join statement waits until a thread executes return and then +returns the return value of the thread.

    +

    Note something quite novel here: the <k> cell is inside a cell of +multiplicity *. Since the <k> cell is just a regular cell (mostly), this +is perfectly allowable. Rules that don't mention a specific thread are +automatically completed to match any thread.

    +

    When you execute programs in this language, the cells in the cell collection +get sorted and printed like any other collection, but they still display like +cells. Rules in this language also benefit from all the structural power of +cells, allowing you to omit cells you don't care about or complete the +configuration automatically. This allows you to have the power of cells while +still being a collection under the hood.

    +

    Exercises

    +
      +
    1. Modify the solution from Lesson 1.16, Exercise 1 so that the cell you use to +keep track of functions in a Map is now a cell collection. Run some programs +and compare how they get unparsed before and after this change.
    2. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.18: Term Equality and the Ternary Operator.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/18_equality_and_conditionals/index.html b/k-distribution/k-tutorial/1_basic/18_equality_and_conditionals/index.html new file mode 100644 index 00000000000..52e1b65fb2f --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/18_equality_and_conditionals/index.html @@ -0,0 +1,483 @@ + + + + + + + + + + + + + + +Lesson 1.18: Term Equality and the Ternary Operator | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.18: Term Equality and the Ternary Operator

    +

    The purpose of this lesson is to introduce how to compare equality of terms in +K, and how to put conditional expressions directly into the right-hand side of +rules.

    +

    Term Equality

    +

    One major way you can compare whether two terms are equal in K is to simply +match both terms with a variable with the same name. This will only succeed +in matching if the two terms are equal structurally. However, sometimes this +is impractical, and it is useful to have access to a way to actually compare +whether two terms in K are equal. The operator for this is found in +domains.md in the K-EQUAL +module. The operator is ==K and takes two terms of sort K and returns a +Bool. It returns true if they are equal. This includes equality over builtin +types such as Map and Set where equality is not purely structural in +nature. However, it does not include any notion of semantic equality over +user-defined syntax. The inverse symbol for inequality is =/=K.

    +

    Ternary Operator

    +

    One way to introduce conditional logic in K is to have two separate rules, +each with a side condition (or one rule with a side condition and another with +the owise attribute). However, sometimes it is useful to explicitly write +a conditional expression directly in the right-hand side of a rule. For this +purpose, K defines one more operator in the K-EQUAL module, which corresponds +to the usual ternary operator found in many languages. Here is an example of its +usage (lesson-18.k):

    +
    k
    module LESSON-18 + imports INT + imports BOOL + imports K-EQUAL + + syntax Exp ::= Int | Bool | "if" "(" Exp ")" Exp "else" Exp [strict(1)] + + syntax Bool ::= isKResult(K) [function, symbol] + rule isKResult(_:Int) => true + rule isKResult(_:Bool) => true + + rule if (B:Bool) E1:Exp else E2:Exp => #if B #then E1 #else E2 #fi +endmodule +
    +

    Note the symbol on the right-hand side of the final rule. This symbol is +polymorphic: B must be of sort Bool, but E1 and E2 could have been +any sort so long as both were of the same sort, and the sort of the entire +expression becomes equal to that sort. K supports polymorphic built-in +operators, but does not yet allow users to write their own polymorphic +productions.

    +

    The behavior of this function is to evaluate the Boolean expression to a +Boolean, then pick one of the two children and return it based on whether the +Boolean is true or false. Please note that it is not a good idea to use this +symbol in cases where one or both of the children is potentially undefined +(for example, an integer expression that divides by zero). While the default +implementation is smart enough to only evaluate the branch that happens to be +picked, this will not be true when we begin to do program verification. If +you need short circuiting behavior, it is better to use a side condition.

    +

    Exercises

    +
      +
    1. +

      Write a function in K that takes two terms of sort K and returns an +Int: the Int should be 0 if the terms are equal and 1 if the terms are +unequal.

      +
    2. +
    3. +

      Modify your solution to Lesson 1.16, Exercise 1 and introduce an if +Stmt to the syntax of the language, then implement it using the #if symbol. +Make sure to write tests for the resulting interpreter.

      +
    4. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.19: Debugging with GDB.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/19_debugging/index.html b/k-distribution/k-tutorial/1_basic/19_debugging/index.html new file mode 100644 index 00000000000..9c37e2308dc --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/19_debugging/index.html @@ -0,0 +1,912 @@ + + + + + + + + + + + + + + +Lesson 1.19: Debugging with GDB or LLDB | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.19: Debugging with GDB or LLDB

    +

    The purpose of this lesson is to teach how to debug your K interpreter using +the K-language support provided in GDB or +LLDB.

    +

    Caveats

    +

    This lesson has been written with GDB support on Linux in mind. Unfortunately, +on macOS, GDB has limited support. To address this, we have introduced early +experimental support for debugging with LLDB on macOS. In some cases, the +features supported by LLDB are slightly different to those supported by GDB; the +tutorial text will make this clear where necessary. If you use a macOS with an +LLVM version older than 15, you may need to upgrade it to use the LLDB +correctly. If you encounter an issue on either operating system, please open an +issue against the K repository.

    +

    Getting started

    +

    On Linux, you will need GDB in order to complete this lesson. If you do not +already have GDB installed, then do so. Steps to install GDB are outlined in +this GDB Tutorial.

    +

    On macOS, LLDB should already have been installed with K's build dependencies +(whether you have built K from source, or installed it using kup or Homebrew).

    +

    The first thing neccessary in order to debug a K interpreter is to build the +interpreter with full debugging support enabled. This can be done relatively +simply. First, run kompile with the command line flag --enable-llvm-debug. +The resulting compiled K definition will be ready to support debugging.

    +

    Once you have a compiled K definition and a program you wish to debug, you can +start the debugger by passing the --debugger flag to krun. This will +automatically load the program you are executing into GDB and drop you into a +GDB shell ready to start executing the program.

    +

    As an example, consider the following K definition (lesson-19-a.k):

    +
    k
    module LESSON-19-A + imports INT + + rule I => I +Int 1 + requires I <Int 100 +endmodule +
    +

    If we compile this definition with kompile lesson-19-a.k --enable-llvm-debug, +and run the program 0 in the debugger with krun -cPGM=0 --debugger, we will +see the following output (roughly, and depending on which platform you are +using):

    +

    GDB / Linux

    +
    GNU gdb (Ubuntu 9.2-0ubuntu1~20.04) 9.2
    +Copyright (C) 2020 Free Software Foundation, Inc.
    +License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
    +This is free software: you are free to change and redistribute it.
    +There is NO WARRANTY, to the extent permitted by law.
    +Type "show copying" and "show warranty" for details.
    +This GDB was configured as "x86_64-linux-gnu".
    +Type "show configuration" for configuration details.
    +For bug reporting instructions, please see:
    +<http://www.gnu.org/software/gdb/bugs/>.
    +Find the GDB manual and other documentation resources online at:
    +    <http://www.gnu.org/software/gdb/documentation/>.
    +
    +For help, type "help".
    +Type "apropos word" to search for commands related to "word"...
    +Reading symbols from ./lesson-19-a-kompiled/interpreter...
    +warning: File "/home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-a-kompiled/interpreter" auto-loading has been declined by your `auto-load safe-path' set to "$debugdir:$datadir/auto-load".
    +To enable execution of this file add
    +        add-auto-load-safe-path /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-a-kompiled/interpreter
    +line to your configuration file "/home/dwightguth/.gdbinit".
    +To completely disable this security protection add
    +        set auto-load safe-path /
    +line to your configuration file "/home/dwightguth/.gdbinit".
    +For more information about this security protection see the
    +"Auto-loading safe path" section in the GDB manual.  E.g., run from the shell:
    +        info "(gdb)Auto-loading safe path"
    +(gdb)
    +
    +

    To make full advantage of the GDB features of K, you should follow the first +command listed in this output message and add the corresponding +add-auto-load-safe-path command to your ~/.gdbinit file as prompted. +Please note that the path will be different on your machine than the one +listed above. Adding directories to the "load safe path" effectively tells GDB +to trust those directories. All content under a given directory will be recursively +trusted, so if you want to avoid having to add paths to the "load safe path" every +time you kompile a different K definition, then you can just trust a minimal +directory containing all your kompiled files; however, do not choose a top-level directory containing arbitrary files as this amounts to trusting arbitrary files and is a security risk. More info on the load safe path +can be found here.

    +

    LLDB / macOS

    +
    (lldb) target create "./lesson-19-a-kompiled/interpreter"
    +warning: 'interpreter' contains a debug script. To run this script in this debug session:
    +
    +    command script import "/Users/brucecollie/code/scratch/lesson-19-a-kompiled/interpreter.dSYM/Contents/Resources/Python/interpreter.py"
    +
    +To run all discovered debug scripts in this session:
    +
    +    settings set target.load-script-from-symbol-file true
    +
    +Current executable set to '/Users/brucecollie/code/scratch/lesson-19-a-kompiled/interpreter' (x86_64).
    +(lldb) settings set -- target.run-args  ".krun-2023-03-20-11-22-46-TcYt9ffhb2/tmp.in.RupiLwHNfn" "-1" ".krun-2023-03-20-11-22-46-TcYt9ffhb2/result.kore"
    +(lldb) 
    +
    +

    LLDB applies slightly different security policies to GDB. To load K's debugging +scripts for this session only, you can run the command script import line at +the LLDB prompt. The loaded scripts will not persist across debugging sessions +if you do this. It is also possible to configure LLDB to automatically load the +K scripts when an interpreter is started in LLDB; doing so requires a slightly +less broad permission than GDB.

    +

    On macOS, the .dSYM directory that contains debugging symbols for an +executable can also contain Python scripts in Contents/Resources/Python. If +there is a Python script with a name matching the name of the current executable +(here, interpreter and interpreter.py), it will be automatically loaded if +the target.load-script-from-symbol-file setting is set). You can therefore add +the settings set command to your ~/.lldbinit without enabling full arbitrary +code execution, but you should be aware of the paths from which code can be +executed if you do so.

    +

    Basic commands

    +
    +

    LLDB Note: the k start and k step commands are currently not +implemented in the K LLDB scripts. To work around this limitation temporarily, +you can run process launch --stop-at-entry instead of k start. To emulate +k step, first run rbreak k_step once, then continue instead of each k step. We hope to address these limitations soon.

    +
    +

    The most basic commands you can execute in the K GDB session are to run your +program or to step through it. The first can be accomplished using GDB's +built-in run command. This will automatically start the program and begin +executing it. It will continue until the program aborts or finishes, or the +debugger is interrupted with Ctrl-C.

    +

    Sometimes you want finer-grained control over how you proceed through the +program you are debugging. To step through the rule applications in your +program, you can use the k start and k step GDB commands.

    +

    k start is similar to the built-in start command in that it starts the +program and then immediately breaks before doing any work. However, unlike +the start command which will break immediately after the main method of +a program is executed, the K start program will initialize the rewriter, +evaluate the initial configuration, and break immediately prior to applying +any rewrite steps.

    +

    In the example above, here is what we see when we run the k start command:

    +
    Temporary breakpoint 1 at 0x239210
    +Starting program: /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-a-kompiled/interpreter .krun-2021-08-13-14-10-50-sMwBkbRicw/tmp.in.01aQt85TaA -1 .krun-2021-08-13-14-10-50-sMwBkbRicw/result.kore
    +[Thread debugging using libthread_db enabled]
    +Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
    +
    +Temporary breakpoint 1, 0x0000000000239210 in main ()
    +0x0000000000231890 in step (subject=<k>
    +  0 ~> .
    +</k>)
    +(gdb)
    +
    +

    As you can see, we are stopped at the step function in the interpreter. +This function is responsible for taking top-level rewrite steps. The subject +parameter to this function is the current K configuration.

    +

    We can step through K rewrite steps one at a time by running the k step +command. By default, this takes a single rewrite step (including any function +rule applications that are part of that step).

    +

    Here is what we see when we run that command:

    +
    Continuing.
    +
    +Temporary breakpoint -22, 0x0000000000231890 in step (subject=<k>
    +  1 ~> .
    +</k>)
    +(gdb)
    +
    +

    As we can see, we have taken a single rewrite step. We can also pass a number +to the k step command which indicates the number of rewrite steps to take.

    +

    Here is what we see if we run k step 10:

    +
    Continuing.
    +
    +Temporary breakpoint -23, 0x0000000000231890 in step (subject=<k>
    +  11 ~> .
    +</k>)
    +(gdb)
    +
    +

    As we can see, ten rewrite steps were taken.

    +

    Breakpoints

    +

    The next important step in debugging an application in GDB is to be able to +set breakpoints. Generally speaking, there are three types of breakpoints we +are interested in a K semantics: Setting a breakpoint when a particular +function is called, setting a breakpoint when a particular rule is applied, +and setting a breakpoint when a side condition of a rule is evaluated.

    +

    The easiest way to do the first two things is to set a breakpoint on the +line of code containing the function or rule.

    +

    For example, consider the following K definition (lesson-19-b.k):

    +
    k
    module LESSON-19-B + imports BOOL + + syntax Bool ::= isBlue(Fruit) [function] + syntax Fruit ::= Blueberry() | Banana() + rule isBlue(Blueberry()) => true + rule isBlue(Banana()) => false + + rule F:Fruit => isBlue(F) +endmodule +
    +

    Once this program has been compiled for debugging, we can run the program +Blueberry(). We can then set a breakpoint that stops when the isBlue +function is called with the following command in GDB:

    +
    break lesson-19-b.k:4
    +
    +

    Similarly, in LLDB, run:

    +
    breakpoint set --file lesson-19-b.k --line 4
    +
    +

    Here is what we see if we set this breakpoint and then run the interpreter:

    +
    (gdb) break lesson-19-b.k:4
    +Breakpoint 1 at 0x231040: file /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b.k, line 4.
    +(gdb) run
    +Starting program: /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b-kompiled/interpreter .krun-2021-08-13-14-20-27-vXOQmV6lwS/tmp.in.fga98yqXlc -1 .krun-2021-08-13-14-20-27-vXOQmV6lwS/result.kore
    +[Thread debugging using libthread_db enabled]
    +Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
    +
    +Breakpoint 1, LblisBlue'LParUndsRParUnds'LESSON-19-B'Unds'Bool'Unds'Fruit (_1=Blueberry ( )) at /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b.k:4
    +4         syntax Bool ::= isBlue(Fruit) [function]
    +(gdb)
    +
    +
    (lldb) breakpoint set --file lesson-19-b.k --line 4
    +Breakpoint 1: where = interpreter`LblisBlue'LParUndsRParUnds'LESSON-19-B'Unds'Bool'Unds'Fruit + 20 at lesson-19-b.k:4:19, address = 0x0000000100003ff4
    +(lldb) run
    +Process 50546 launched: '/Users/brucecollie/code/scratch/lesson-19-b-kompiled/interpreter' (x86_64)
    +Process 50546 stopped
    +* thread #1, queue = 'com.apple.main-thread', stop reason = breakpoint 1.1
    +    frame #0: 0x0000000100003ff4 interpreter`LblisBlue'LParUndsRParUnds'LESSON-19-B'Unds'Bool'Unds'Fruit(_1=Blueberry ( )) at lesson-19-b.k:4:19
    +   1   	module LESSON-19-B
    +   2   	  imports BOOL
    +   3   	
    +-> 4   	  syntax Bool ::= isBlue(Fruit) [function]
    +   5   	  syntax Fruit ::= Blueberry() | Banana()
    +   6   	  rule isBlue(Blueberry()) => true
    +   7   	  rule isBlue(Banana()) => false
    +(lldb)
    +
    +

    As we can see, we have stopped at the point where we are evaluating that +function. The value _1 that is a parameter to that function shows the +value passed to the function by the caller.

    +

    We can also break when the isBlue(Blueberry()) => true rule applies by simply +changing the line number to the line number of that rule:

    +
    (gdb) break lesson-19-b.k:6
    +Breakpoint 1 at 0x2af710: file /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b.k, line 6.
    +(gdb) run
    +Starting program: /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b-kompiled/interpreter .krun-2021-08-13-14-32-36-7kD0ic7XwD/tmp.in.8JNH5Qtmow -1 .krun-2021-08-13-14-32-36-7kD0ic7XwD/result.kore
    +[Thread debugging using libthread_db enabled]
    +Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
    +
    +Breakpoint 1, apply_rule_138 () at /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b.k:6
    +6         rule isBlue(Blueberry()) => true
    +(gdb)
    +
    +
    (lldb) breakpoint set --file lesson-19-b.k --line 6
    +Breakpoint 1: where = interpreter`apply_rule_140 at lesson-19-b.k:6:8, address = 0x0000000100004620
    +(lldb) run
    +Process 50681 launched: '/Users/brucecollie/code/scratch/lesson-19-b-kompiled/interpreter' (x86_64)
    +Process 50681 stopped
    +* thread #1, queue = 'com.apple.main-thread', stop reason = breakpoint 1.1
    +    frame #0: 0x0000000100004620 interpreter`apply_rule_140 at lesson-19-b.k:6:8
    +   3   	
    +   4   	  syntax Bool ::= isBlue(Fruit) [function]
    +   5   	  syntax Fruit ::= Blueberry() | Banana()
    +-> 6   	  rule isBlue(Blueberry()) => true
    +   7   	  rule isBlue(Banana()) => false
    +   8   	
    +   9   	  rule F:Fruit => isBlue(F)
    +(lldb) 
    +
    +

    We can also do the same with a top-level rule:

    +
    (gdb) break lesson-19-b.k:9
    +Breakpoint 1 at 0x2aefa0: lesson-19-b.k:9. (2 locations)
    +(gdb) run
    +Starting program: /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b-kompiled/interpreter .krun-2021-08-13-14-33-13-9fC8Sz4aO3/tmp.in.jih1vtxSiQ -1 .krun-2021-08-13-14-33-13-9fC8Sz4aO3/result.kore
    +[Thread debugging using libthread_db enabled]
    +Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
    +
    +Breakpoint 1, apply_rule_107 (Var'Unds'DotVar0=<generatedCounter>
    +  0
    +</generatedCounter>, Var'Unds'DotVar1=., VarF=Blueberry ( )) at /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-b.k:9
    +9         rule F:Fruit => isBlue(F)
    +(gdb)
    +
    +
    (lldb) breakpoint set --file lesson-19-b.k --line 9
    +Breakpoint 1: 2 locations.
    +(lldb) run
    +Process 50798 launched: '/Users/brucecollie/code/scratch/lesson-19-b-kompiled/interpreter' (x86_64)
    +Process 50798 stopped
    +* thread #1, queue = 'com.apple.main-thread', stop reason = breakpoint 1.1
    +    frame #0: 0x0000000100003f2e interpreter`apply_rule_109(Var'Unds'DotVar0=<generatedCounter>
    +  0
    +</generatedCounter>, Var'Unds'DotVar1=., VarF=Blueberry ( )) at lesson-19-b.k:9:8
    +   6   	  rule isBlue(Blueberry()) => true
    +   7   	  rule isBlue(Banana()) => false
    +   8   	
    +-> 9   	  rule F:Fruit => isBlue(F)
    +   10  	endmodule
    +(lldb)  
    +
    +

    Unlike the function rule above, we see several parameters to this function. +These are the substitution that was matched for the function. Variables only +appear in this substitution if they are actually used on the right-hand side +of the rule.

    +

    Advanced breakpoints

    +

    Sometimes it is inconvenient to set the breakpoint based on a line number.

    +

    It is also possible to set a breakpoint based on the rule label of a particular +rule. Consider the following definition (lesson-19-c.k):

    +
    k
    module LESSON-19-C + imports INT + imports BOOL + + syntax Bool ::= isEven(Int) [function] + rule [isEven]: isEven(I) => true requires I %Int 2 ==Int 0 + rule [isOdd]: isEven(I) => false requires I %Int 2 =/=Int 0 + +endmodule +
    +

    We will run the program isEven(4). We can set a breakpoint for when a rule +applies by means of the MODULE-NAME.label.rhs syntax:

    +
    (gdb) break LESSON-19-C.isEven.rhs
    +Breakpoint 1 at 0x2afda0: file /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c.k, line 6.
    +(gdb) run
    +Starting program: /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c-kompiled/interpreter .krun-2021-08-13-14-40-29-LNNT8YEZ61/tmp.in.ZG93vWCGGC -1 .krun-2021-08-13-14-40-29-LNNT8YEZ61/result.kore
    +[Thread debugging using libthread_db enabled]
    +Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
    +
    +Breakpoint 1, LESSON-19-C.isEven.rhs () at /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c.k:6
    +6         rule [isEven]: isEven(I) => true requires I %Int 2 ==Int 0
    +(gdb)
    +
    +
    (lldb) breakpoint set --name LESSON-19-C.isEven.rhs
    +Breakpoint 1: where = interpreter`LESSON-19-C.isEven.rhs at lesson-19-c.k:6:18, address = 0x00000001000038e0
    +(lldb) run
    +Process 51205 launched: '/Users/brucecollie/code/scratch/lesson-19-c-kompiled/interpreter' (x86_64)
    +Process 51205 stopped
    +* thread #1, queue = 'com.apple.main-thread', stop reason = breakpoint 1.1
    +    frame #0: 0x00000001000038e0 interpreter`LESSON-19-C.isEven.rhs at lesson-19-c.k:6:18
    +   3   	  imports BOOL
    +   4   	
    +   5   	  syntax Bool ::= isEven(Int) [function]
    +-> 6   	  rule [isEven]: isEven(I) => true requires I %Int 2 ==Int 0
    +   7   	  rule [isOdd]: isEven(I) => false requires I %Int 2 =/=Int 0
    +   8   	
    +   9   	endmodule
    +(lldb) 
    +
    +

    We can also set a breakpoint for when a rule's side condition is evaluated +by means of the MODULE-NAME.label.sc syntax:

    +
    (gdb) break LESSON-19-C.isEven.sc
    +Breakpoint 1 at 0x2afd70: file /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c.k, line 6.
    +(gdb) run
    +Starting program: /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c-kompiled/interpreter .krun-2021-08-13-14-41-48-1BoGfJRbYc/tmp.in.kg4F8cwfCe -1 .krun-2021-08-13-14-41-48-1BoGfJRbYc/result.kore
    +[Thread debugging using libthread_db enabled]
    +Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
    +
    +Breakpoint 1, LESSON-19-C.isEven.sc (VarI=4) at /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c.k:6
    +6         rule [isEven]: isEven(I) => true requires I %Int 2 ==Int 0
    +(gdb) finish
    +Run till exit from #0  LESSON-19-C.isEven.sc (VarI=4) at /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c.k:6
    +0x00000000002b2662 in LblisEven'LParUndsRParUnds'LESSON-19-C'Unds'Bool'Unds'Int (_1=4) at /home/dwightguth/kframework-5.0.0/k-distribution/k-tutorial/1_basic/19_debugging/lesson-19-c.k:5
    +5         syntax Bool ::= isEven(Int) [function]
    +Value returned is $1 = true
    +(gdb)
    +
    +
    (lldb) breakpoint set --name LESSON-19-C.isEven.sc
    +Breakpoint 1: where = interpreter`LESSON-19-C.isEven.sc + 1 at lesson-19-c.k:6:18, address = 0x00000001000038c1
    +(lldb) run
    +Process 52530 launched: '/Users/brucecollie/code/scratch/lesson-19-c-kompiled/interpreter' (x86_64)
    +Process 52530 stopped
    +* thread #1, queue = 'com.apple.main-thread', stop reason = breakpoint 1.1
    +    frame #0: 0x00000001000038c1 interpreter`LESSON-19-C.isEven.sc(VarI=0x0000000101800088) at lesson-19-c.k:6:18
    +   3   	  imports BOOL
    +   4   	
    +   5   	  syntax Bool ::= isEven(Int) [function]
    +-> 6   	  rule [isEven]: isEven(I) => true requires I %Int 2 ==Int 0
    +   7   	  rule [isOdd]: isEven(I) => false requires I %Int 2 =/=Int 0
    +   8   	
    +   9   	endmodule
    +(lldb) finish
    +Process 52649 stopped
    +* thread #1, queue = 'com.apple.main-thread', stop reason = step out
    +Return value: (bool) $0 = true
    +
    +    frame #0: 0x00000001000069e5 interpreter`LblisEven'LParUndsRParUnds'LESSON-19-C'Unds'Bool'Unds'Int(_1=0x0000000101800088) at lesson-19-c.k:5:19
    +   2   	  imports INT
    +   3   	  imports BOOL
    +   4   	
    +-> 5   	  syntax Bool ::= isEven(Int) [function]
    +   6   	  rule [isEven]: isEven(I) => true requires I %Int 2 ==Int 0
    +   7   	  rule [isOdd]: isEven(I) => false requires I %Int 2 =/=Int 0
    +   8
    +(lldb)
    +
    +

    Here we have used the built-in command finish to tell us whether the side +condition returned true or not. Note that once again, we see the substitution +that was matched from the left-hand side. Like before, a variable will only +appear here if it is used in the side condition.

    +

    Debugging rule matching

    +

    Sometimes it is useful to try to determine why a particular rule did or did +not apply. K provides some basic debugging commands which make it easier +to determine this.

    +

    Consider the following K definition (lesson-19-d.k):

    +
    k
    module LESSON-19-D + + syntax Foo ::= foo(Bar) + syntax Bar ::= bar(Baz) | bar2(Baz) + syntax Baz ::= baz() | baz2() + + rule [baz]: foo(bar(baz())) => .K + +endmodule +
    +

    Suppose we try to run the program foo(bar(baz2())). It is obvious from this +example why the rule in this definition will not apply. However, in practice, +such cases are not always obvious. You might look at a rule and not immediately +spot why it didn't apply on a particular term. For this reason, it can be +useful to get the debugger to provide a log about how it tried to match that +term. You can do this with the k match command. If you are stopped after +having run k start or k step, you can obtain this log for any rule after +any step by running the command k match MODULE.label subject for a particular +top-level rule label.

    +

    For example, with the baz rule above, we get the following output:

    +
    (gdb) k match LESSON-19-D.baz subject
    +Subject:
    +baz2 ( )
    +does not match pattern:
    +baz ( )
    +
    +
    (lldb) k match LESSON-19-D.baz subject
    +Subject:
    +baz2 ( )
    +does not match pattern:
    +baz ( )
    +
    +

    As we can see, it provided the exact subterm which did not match against the +rule, as well as the particular subpattern it ought to have matched against.

    +

    This command does not actually take any rewrite steps. In the event that +matching actually succeeds, you will still need to run the k step command +to advance to the next step.

    +

    Final notes

    +

    In addition to the functionality provided above, you have the full power of +GDB or LLDB at your disposal when debugging. Some features are not particularly +well-adapted to K code and may require more advanced knowledge of the +term representation or implementation to use effectively, but anything that +can be done in GDB or LLDB can in theory be done using this debugging functionality. +We suggest you refer to the +GDB Documentation or +LLDB Tutorial if you +want to try to do something and are unsure as to how.

    +

    Exercises

    +
      +
    1. Compile your solution to Lesson 1.18, Exercise 2 with debugging support +enabled and step through several programs you have previously used to test. +Then set a breakpoint on the isKResult function and observe the state of the +interpreter when stopped at that breakpoint. Set a breakpoint on the rule for +addition and run a program that causes it to be stopped at that breakpoint. +Finally, step through the program until the addition symbol is at the top +of the K cell, and then use the k match command to report the reason why +the subtraction rule does not apply. You may need to modify the definition +to insert some rule labels.
    2. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.20: K Backends and the Haskell Backend.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/20_backends/index.html b/k-distribution/k-tutorial/1_basic/20_backends/index.html new file mode 100644 index 00000000000..b2c7b7c70a8 --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/20_backends/index.html @@ -0,0 +1,503 @@ + + + + + + + + + + + + + + +Lesson 1.20: K Backends and the Haskell Backend | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.20: K Backends and the Haskell Backend

    +

    The purpose of this lesson is to teach about the multiple backends of K, +in particular the Haskell Backend which is the complement of the backend we +have been using so far.

    +

    K Backends

    +

    Thus far, we have not discussed the distinction between the K frontend and +the K backends at all. We have simply assumed that if you run kompile on a +K definition, there will be a compiler backend that will allow you to execute +the K definition you have compiled.

    +

    K actually has multiple different backends. The one we have been using so far +implicitly, the default backend, is called the LLVM Backend. It is +designed to support efficient, optimized concrete execution and search. It +does this by compiling your K definition to LLVM bitcode and then using LLVM +to generate machine code for it that is compiled and linked and executed. +However, K is a formal methods toolkit at the end of the day, and the primary +goal many people have when defining a programming language in K is to +ultimately be able to perform more advanced verification on programs in their +programming language.

    +

    It is for this purpose that K also provides the Haskell Backend, so called +because it is implemented in Haskell. While we will cover the features of the +Haskell Backend in more detail in the next two lessons, the important thing to +understand is that it is a separate backend which is optimized for more formal +reasoning about programming languages. While it is capable of performing +concrete execution, it does not do so as efficiently as the LLVM Backend. +In exchange, it provides more advanced features.

    +

    Choosing a backend

    +

    You can choose which backend to use to compile a K definition by means of the +--backend flag to kompile. By default, if you do not specify this flag, it +is equivalent to if you had specified --backend llvm. However, to use the +Haskell Backend instead, you can simply say kompile --backend haskell on a +particular K definition.

    +

    As an example, here is a simple K definition that we have seen before in the +previous lesson (lesson-20.k):

    +
    k
    module LESSON-20 + imports INT + + rule I => I +Int 1 + requires I <Int 100 +endmodule +
    +

    Previously we compiled this definition using the LLVM Backend, but if we +instead execute the command kompile lesson-20.k --backend haskell, we +will get an interpreter for this K definition that is implemented in Haskell +instead. Unlike the default LLVM Backend, the Haskell Backend is not a +compiler per se. It does not generate new Haskell code corresponding to your +programming language and then compile and execute it. Instead, it is an +interpreter which reads the generated IR from kompile and implements in +Haskell an interpreter that is capable of interpreting any K definition.

    +

    Note that on arm64 macOS (Apple Silicon), there is a known issue with the Compact +library that causes crashes in the Haskell backend. Pass the additional flag +--no-haskell-binary to kompile to resolve this. +This flag is also needed when using krun.

    +

    Exercise

    +

    Try running the program 0 in this K definition on the Haskell Backend and +compare the final configuration to what you would get compiling the same +definition with the LLVM Backend.

    +

    Legacy backends

    +

    As a quick note, K does provide one other backend, which exists primarily as +legacy code which should be considered deprecated. This is the +Java Backend. The Java Backend is essentially a precursor to the Haskell +Backend. We will not cover this backend in any detail since it is deprecated, +but we still mention it here for the purposes of understanding.

    +

    Exercises

    +
      +
    1. Compile your solution to Lesson 1.18, Exercise 2 with the Haskell Backend +and execute some programs. Compare the resulting configurations with the +output of the same program on the LLVM Backend. Note that if you are getting +different behaviors on the Haskell backend, you might have some luck debugging +by passing --search to krun when using the LLVM backend.
    2. +
    +

    Next lesson

    +

    Once you have completed the above exercises, you can continue to +Lesson 1.21: Unification and Symbolic Execution.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/21_symbolic_execution/index.html b/k-distribution/k-tutorial/1_basic/21_symbolic_execution/index.html new file mode 100644 index 00000000000..6476dea2168 --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/21_symbolic_execution/index.html @@ -0,0 +1,583 @@ + + + + + + + + + + + + + + +Lesson 1.21: Unification and Symbolic Execution | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.21: Unification and Symbolic Execution

    +

    The purpose of this lesson is to teach the basic concepts of symbolic execution +in order to introduce the unique capabilities of the Haskell Backend at a +conceptual level.

    +

    Symbolic Execution

    +

    Thus far, all of the programs we have run using K have been concrete +configurations. What this means is that the configuration we use to initialize +the K rewrite engine is concrete; in other words, contains no logical +variables. The LLVM Backend is a concrete execution engine, meaning that +it is only capable of rewriting concrete configurations.

    +

    By contrast, the Haskell Backend performs symbolic execution, which is +capable of rewriting any configuration, including those where parts of the +configuration are symbolic, ie, contain variables or uninterpreted +functions.

    +

    Unification

    +

    Previously, we have introduced the concept that K rewrite rules operate by +means of pattern matching: the current configuration being rewritten is pattern +matched against the left-hand side of the rewrite rule, and the substitution +is used in order to construct a new term from the right-hand side. In symbolic +execution, we use +unification +instead of pattern matching. To summarize, unification behaves akin to a +two-way pattern matching where both the configuration and the left-hand side +of the rule can contain variables, and the algorithm generates a +most general unifier containing substitutions for the variables in both +which will make both terms equal.

    +

    Feasibility

    +

    Unification by itself cannot completely solve the problem of symbolic +execution. One task symbolic execution must perform is to identify whether +a particular symbolic term is feasible, that is to say, that there actually +exists a concrete instantiation of that term such that all the logical +constraints on that term can actually be satisfied. The Haskell Backend +delegates this task to Z3, an +SMT solver. +This solver is used to periodically trim configurations that are determined +to be mathematically infeasible.

    +

    Symbolic terms

    +

    The final component of symbolic execution consists of the task of introducing +symbolic terms into the configuration. This can be done one of two different +ways. First, the term being passed to krun can actually be symbolic. This +is less frequently used because it requires the user to construct an AST +that contains variables, something which our current parsing capabilities are +not well-equipped to do. The second, more common, way of introducing symbolic +terms into a configuration consists of writing rules where there exists an +existentially qualified variable on the right-hand side of the rule that does +not exist on the left-hand side of the rule.

    +

    In order to prevent users from writing such rules by accident, K requires +that such variables begin with the ? prefix. For example, here is a rule +that rewrites a constructor foo to a symbolic integer:

    +
    rule <k> foo => ?X:Int ...</k>
    +
    +

    When this rule applies, a fresh variable is introduced to the configuration, which +then is unified against the rules that might apply in order to symbolically +execute that configuration.

    +

    ensures clauses

    +

    We also introduce here a new feature of K rules that applies when a rule +has this type of variable on the right-hand side: the ensures clause. +An ensures clause is similar to a requires clause and can appear after +a rule body, or after a requires clause. The ensures clause is used to +introduce constraints that might apply to the variable that was introduced by +that rule. For example, we could write the rule above with the additional +constraint that the symbolic integer that was introduced must be less than +five, by means of the following rule:

    +
    rule <k> foo => ?X:Int ...</k> ensures ?X <Int 5
    +
    +

    Putting it all together

    +

    Putting all these pieces together, it is possible to use the Haskell Backend +to perform symbolic reasoning about a particular K module, determining all the +possible states that can be reached by a symbolic configuration.

    +

    For example, consider the following K definition (lesson-21.k):

    +
    k
    module LESSON-21 + imports INT + + rule <k> 0 => ?X:Int ... </k> ensures ?X =/=Int 0 + rule <k> X:Int => 5 ... </k> requires X >=Int 10 +endmodule +
    +

    When we symbolically execute the program 0, we get the following output +from the Haskell Backend:

    +
        <k>
    +      5 ~> .
    +    </k>
    +  #And
    +    {
    +      true
    +    #Equals
    +      ?X:Int >=Int 10
    +    }
    +  #And
    +    #Not ( {
    +      ?X:Int
    +    #Equals
    +      0
    +    } )
    +#Or
    +    <k>
    +      ?X:Int ~> .
    +    </k>
    +  #And
    +    #Not ( {
    +      true
    +    #Equals
    +      ?X:Int >=Int 10
    +    } )
    +  #And
    +    #Not ( {
    +      ?X:Int
    +    #Equals
    +      0
    +    } )
    +
    +

    Note some new symbols introduced by this configuration: #And, #Or, and +#Equals. While andBool, orBool, and ==K represent functions of sort +Bool, #And, #Or, and #Equals are matching logic connectives. We +will discuss matching logic in more detail later in the tutorial, but the basic +idea is that these symbols represent Boolean operators over the domain of +configurations and constraints, as opposed to over the Bool sort.

    +

    Notice that the configuration listed above is a disjunction of conjunctions. +This is the most common form of output that can be produced by the Haskell +Backend. In this case, each conjunction consists of a configuration and a set +of constraints. What this conjunction describes, essentially, is a +configuration and a set of information that was derived to be true while +rewriting that configuration.

    +

    Similar to how we saw --search in a previous lesson, the reason we have +multiple disjuncts is because there are multiple possible output states +for this program, depending on whether or not the second rule applied. In the +first case, we see that ?X is greater than or equal to 10, so the second rule +applied, rewriting the symbolic integer to the concrete integer 5. In the +second case, we see that the second rule did not apply because ?X is less +than 10. Moreover, because of the ensures clause on the first rule, we know +that ?X is not zero, therefore the first rule will not apply a second time. +If we had omitted this constraint, we would have ended up infinitely applying +the first rule, leading to krun not terminating.

    +

    In the next lesson, we will cover how symbolic execution forms the backbone +of deductive program verification in K and how we can use K to prove programs +correct against a specification.

    +

    Exercises

    +
      +
    1. Create another rule in LESSON-21 that rewrites odd integers greater than +ten to a symbolic even integer less than 10 and greater than 0. This rule will +now apply nondeterministically along with the existing rules. Predict what the +resulting output configuration will be from rewriting 0 after adding this +rule. Then run the program and see whether your prediction is correct.
    2. +
    +

    Once you have completed the above exercises, you can continue to +Lesson 1.22: Basics of Deductive Program Verification using K.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/22_proofs/index.html b/k-distribution/k-tutorial/1_basic/22_proofs/index.html new file mode 100644 index 00000000000..63a57bbcf06 --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/22_proofs/index.html @@ -0,0 +1,819 @@ + + + + + + + + + + + + + + +Lesson 1.22: Basics of Deductive Program Verification using K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 1.22: Basics of Deductive Program Verification using K

    +

    In this lesson, you will familiarize yourself with the basics of using K for +deductive program verification.

    +

    1. Setup: Simple Programming Language with Function Calls

    +

    We base this lesson on a simple programming language with functions, +assignment, if conditionals, and while loops. Take your time to study its +formalization below (lesson-22.k):

    +
    module LESSON-22-SYNTAX
    +    imports INT-SYNTAX
    +    imports BOOL-SYNTAX
    +    imports ID-SYNTAX
    +
    +    syntax Exp ::= IExp | BExp
    +
    +    syntax IExp ::= Id | Int
    +
    +    syntax KResult ::= Int | Bool | Ints
    +
    +    // Take this sort structure:
    +    //
    +    //     IExp
    +    //    /    \
    +    // Int      Id
    +    //
    +    // Through the List{_, ","} functor.
    +    // Must add a `Bot`, for a common subsort for the empty list.
    +
    +    syntax Bot
    +    syntax Bots ::= List{Bot, ","} [klabel(exps)]
    +    syntax Ints ::= List{Int, ","} [klabel(exps)]
    +                  | Bots
    +    syntax Ids  ::= List{Id, ","}  [klabel(exps)]
    +                  | Bots
    +    syntax Exps ::= List{Exp, ","} [klabel(exps), seqstrict]
    +                  | Ids | Ints
    +
    +    syntax IExp ::= "(" IExp ")" [bracket]
    +                  | IExp "+" IExp [seqstrict]
    +                  | IExp "-" IExp [seqstrict]
    +                  > IExp "*" IExp [seqstrict]
    +                  | IExp "/" IExp [seqstrict]
    +                  > IExp "^" IExp [seqstrict]
    +                  | Id "(" Exps ")" [strict(2)]
    +
    +    syntax BExp ::= Bool
    +
    +    syntax BExp ::= "(" BExp ")" [bracket]
    +                  | IExp "<=" IExp [seqstrict]
    +                  | IExp "<"  IExp [seqstrict]
    +                  | IExp ">=" IExp [seqstrict]
    +                  | IExp ">"  IExp [seqstrict]
    +                  | IExp "==" IExp [seqstrict]
    +                  | IExp "!=" IExp [seqstrict]
    +
    +    syntax BExp ::= BExp "&&" BExp
    +                  | BExp "||" BExp
    +
    +    syntax Stmt ::=
    +         Id "=" IExp ";" [strict(2)]                        // Assignment
    +       | Stmt Stmt [left]                                   // Sequence
    +       | Block                                              // Block
    +       | "if" "(" BExp ")" Block "else" Block [strict(1)]   // If conditional
    +       | "while" "(" BExp ")" Block                         // While loop
    +       | "return" IExp ";"                    [seqstrict]   // Return statement
    +       | "def" Id "(" Ids ")" Block                         // Function definition
    +
    +    syntax Block ::=
    +         "{" Stmt "}"    // Block with statement
    +       | "{" "}"         // Empty block
    +endmodule
    +
    +module LESSON-22
    +    imports INT
    +    imports BOOL
    +    imports LIST
    +    imports MAP
    +    imports LESSON-22-SYNTAX
    +
    +    configuration
    +      <k> $PGM:Stmt </k>
    +      <store> .Map </store>
    +      <funcs> .Map </funcs>
    +      <stack> .List </stack>
    +
    + // -----------------------------------------------
    +    rule <k> I1 + I2 => I1 +Int I2 ... </k>
    +    rule <k> I1 - I2 => I1 -Int I2 ... </k>
    +    rule <k> I1 * I2 => I1 *Int I2 ... </k>
    +    rule <k> I1 / I2 => I1 /Int I2 ... </k>
    +    rule <k> I1 ^ I2 => I1 ^Int I2 ... </k>
    +
    +    rule <k> I:Id => STORE[I] ... </k>
    +         <store> STORE </store>
    +
    + // ------------------------------------------------
    +    rule <k> I1 <= I2 => I1  <=Int I2 ... </k>
    +    rule <k> I1  < I2 => I1   <Int I2 ... </k>
    +    rule <k> I1 >= I2 => I1  >=Int I2 ... </k>
    +    rule <k> I1  > I2 => I1   >Int I2 ... </k>
    +    rule <k> I1 == I2 => I1  ==Int I2 ... </k>
    +    rule <k> I1 != I2 => I1 =/=Int I2 ... </k>
    +
    +    rule <k> B1 && B2 => B1 andBool B2 ... </k>
    +    rule <k> B1 || B2 => B1  orBool B2 ... </k>
    +
    +    rule <k> S1:Stmt S2:Stmt => S1 ~> S2 ... </k>
    +
    +    rule <k> ID = I:Int ; => . ... </k>
    +         <store> STORE => STORE [ ID <- I ] </store>
    +
    +    rule <k> { S } => S ... </k>
    +    rule <k> {   } => . ... </k>
    +
    +    rule <k> if (true)   THEN else _ELSE => THEN ... </k>
    +    rule <k> if (false) _THEN else  ELSE => ELSE ... </k>
    +
    +    rule <k> while ( BE ) BODY => if ( BE ) { BODY while ( BE ) BODY } else { } ... </k>
    +
    +    rule <k> def FNAME ( ARGS ) BODY => . ... </k>
    +         <funcs> FS => FS [ FNAME <- def FNAME ( ARGS ) BODY ] </funcs>
    +
    +    rule <k> FNAME ( IS:Ints ) ~> CONT => #makeBindings(ARGS, IS) ~> BODY </k>
    +         <funcs> ... FNAME |-> def FNAME ( ARGS ) BODY ... </funcs>
    +         <store> STORE => .Map </store>
    +         <stack> .List => ListItem(state(CONT, STORE)) ... </stack>
    +
    +    rule <k> return I:Int ; ~> _ => I ~> CONT </k>
    +         <stack> ListItem(state(CONT, STORE)) => .List ... </stack>
    +         <store> _ => STORE </store>
    +
    +    rule <k> return I:Int ; ~> . => I </k>
    +         <stack> .List </stack>
    +
    +    syntax KItem ::= #makeBindings(Ids, Ints)
    +                   | state(continuation: K, store: Map)
    + // ----------------------------------------------------
    +    rule <k> #makeBindings(.Ids, .Ints) => . ... </k>
    +    rule <k> #makeBindings((I:Id, IDS => IDS), (IN:Int, INTS => INTS)) ... </k>
    +         <store> STORE => STORE [ I <- IN ] </store>
    +endmodule
    +
    +

    Next, compile this example using kompile lesson-22.k --backend haskell. If +your processor is an Apple Silicon processor, add the --no-haskell-binary +flag if the compilation fails.

    +

    2. Setup: Proof Environment

    +

    Next, take the following snippet of K code and save it in lesson-22-spec.k. +This is a skeleton of the proof environment, and we will complete it as the +lesson progresses.

    +
    requires "lesson-22.k"
    +requires "domains.md"
    +
    +module LESSON-22-SPEC-SYNTAX
    +    imports LESSON-22-SYNTAX
    +
    +endmodule
    +
    +module VERIFICATION
    +    imports K-EQUAL
    +    imports LESSON-22-SPEC-SYNTAX
    +    imports LESSON-22
    +    imports MAP-SYMBOLIC
    +
    +endmodule
    +
    +module LESSON-22-SPEC
    +    imports VERIFICATION
    +
    +endmodule
    +
    +

    3. Claims

    +
      +
    1. The first claim we will ask K to prove is that 3 + 4, in fact, equals 7. +Claims are stated using the claim keyword, followed by the claim +statement:
    2. +
    +
    claim <k> 3 + 4 => 7 ... </k>
    +
    +

    Add this claim to the LESSON-22-SPEC module and run the K prover using the +command kprove lesson-22-spec.k. You should get back the output #Top, +which denotes the Matching Logic equivalent of true and means, in this +context, that all claims have been proven correctly.

    +
      +
    1. The second claim reasons about the if statement that has a concrete condition:
    2. +
    +
    claim <k> if ( 3 + 4 == 7 ) {
    +            $a = 1 ;
    +            } else {
    +            $a = 2 ;
    +            }
    +        => . ... </k>
    +        <store> STORE => STORE [ $a <- 1 ] </store>
    +
    +

    stating that the given program terminates (=> .), and when it does, the value +of the variable $a is set to 1, meaning that the execution will have taken +the then branch. Add this claim to the LESSON-22-SPEC module, but also add

    +
    syntax Id ::= "$a" [token]
    +
    +

    to the LESSON-22-SPEC-SYNTAX module in order to declare $a as a token so +that it can be used as a program variable. Re-run the K prover, which should +again return #Top.

    +
      +
    1. Our third claim demonstrates how to reason about both branches of an if +statement at the same time:
    2. +
    +
    claim <k> $a = A:Int ; $b = B:Int ;
    +          if ($a < $b) {
    +            $c = $b ;
    +          } else {
    +            $c = $a ;
    +          }
    +        => . ... </k>
    +        <store> STORE => STORE [ $a <- A ] [ $b <- B ] [ $c <- ?C:Int ] </store>
    +    ensures (?C ==Int A) orBool (?C ==Int B)
    +
    +

    The program in question first assigns symbolic integers A and B to program +variables $a and $b, respectively, and then executes the given if +statement, which has a symbolic condition (A < B), updating the value of the +program variable $c in both branches. The specification we give states that +the if statement terminates, with $a and $b updated, respectively, to A +and B, and $c updated to some symbolic integer value ?C. Via the +ensures clause, which is used to specify additional constraints that hold +after execution, we also state that this existentially quantified ?C equals +either A or B.

    +

    Add the productions declaring $b and $c as tokens to the +LESSON-22-SPEC-SYNTAX module, the claim to the LESSON-22-SPEC module, run +the K prover again, and observe the output, which should not be #Top this +time. This means that K was not able to prove the claim, and we now need to +understand why. We do so by examining the output, which should look as follows:

    +
        (InfoReachability) while checking the implication:
    +    The configuration's term unifies with the destination's term,
    +    but the implication check between the conditions has failed.
    +
    +  #Not (
    +    #Exists ?C . {
    +        STORE [ $a <- A:Int ] [ $b <- B:Int ] [ $c <- ?C:Int ]
    +      #Equals
    +        STORE [ $a <- A:Int ] [ $b <- B:Int ] [ $c <- B:Int ]
    +    }
    +  #And
    +    {
    +      true
    +    #Equals
    +      ?C ==Int A orBool ?C ==Int B
    +    }
    +  )
    +#And
    +  <generatedTop>
    +    <k>
    +      _DotVar1
    +    </k>
    +    <store>
    +      STORE [ $a <- A:Int ] [ $b <- B:Int ] [ $c <- B:Int ]
    +    </store>
    +    <funcs>
    +      _Gen3
    +    </funcs>
    +    <stack>
    +      _Gen5
    +    </stack>
    +  </generatedTop>
    +#And
    +  {
    +    true
    +  #Equals
    +    A <Int B
    +  }
    +
    +

    This output starts with a message telling us at which point the proof failed, +followed by the final state, which consists of three parts: some negative +Matching Logic (ML) constraints, the final configuration (<generatedTop> ... </generatedTop>), and some positive ML constraints. Generally speaking, +these positive and the negative constraints could arise from various sources, +such as (but not limited to) branches taken by the execution +(e.g. { true #Equals A <Int B } or #Not ( { true #Equals A <Int B } ) ), +or ensures constraints.

    +

    First, we examine the message:

    +
    (InfoReachability) while checking the implication:
    +The configuration's term unifies with the destination's term,
    +but the implication check between the conditions has failed.
    +
    +

    which tells us that the structure of the final configuration is as expected, +but that some of the associated constraints cannot be proven. We next look at +the final configuration, in which the relevant item is the <store> ... </store> cell, because it is the only one that we are reasoning about. By +inspecting its contents:

    +
    STORE [ $a <- A:Int ] [ $b <- B:Int ] [ $c <- B:Int ]
    +
    +

    we see that we should be within the constraints of the ensures, since the +value of $c in the store equals B in this branch. We next examine the +negative and positive constraints of the output and, more often than not, the +goal is to instruct K how to use the information from the final configuration +and the positive constraints to falsify one of the negative constraints. This +is done through simplifications.

    +

    So, the positive constraint that we have is

    +
    { true #Equals A <Int B }
    +
    +

    meaning that A <Int B holds. Given the analysed program, this tells us that +we are in the then branch of the if. The negative constraint is

    +
      #Not (
    +    #Exists ?C . {
    +        STORE [ $a <- A:Int ] [ $b <- B:Int ] [ $c <- ?C:Int ]
    +      #Equals
    +        STORE [ $a <- A:Int ] [ $b <- B:Int ] [ $c <- B:Int ]
    +    }
    +  #And
    +    { true #Equals ?C ==Int A orBool ?C ==Int B }
    +  )
    +
    +

    and we observe, from the first equality, that the existential ?C should be +instantiated with B. This would make both branches of the #And true, +falsifying the outside #Not. We just need to show K how to conclude that +?C ==Int B. We do so by introducing the following simplification into the +VERIFICATION module:

    +
    rule { M:Map [ K <- V ] #Equals M [ K <- V' ] } => { V #Equals V' } [simplification]
    +
    +

    which formalizes our internal understanding of ?C ==Int B. The rule states +that when we update the same key in the same map with two values, and the +resulting maps are equal, then the two values must be equal as well. The +[simplification] attribute indicates to K to use this rule to simplify the +state when trying to prove claims. Like function rules, simplification rules +do not complete to the top of the configuration, but instead apply anywhere +their left-hand-side matches. Re-run the K prover, which should now return +#Top, indicating that K was able to use the simplification and prove the +required claims.

    +
      +
    1. Next, we show how to state and prove properties of while loops. In +particular, we consider the following loop
    2. +
    +
    claim
    +    <k>
    +        while ( 0 < $n ) {
    +            $s = $s + $n;
    +            $n = $n - 1;
    +            } => . ...
    +    </k>
    +    <store>
    +        $s |-> (S:Int => S +Int ((N +Int 1) *Int N /Int 2))
    +        $n |-> (N:Int => 0)
    +    </store>
    +    requires N >=Int 0
    +
    +

    which adds the sum of the first $n integers to $s, assuming the value of $n +is non-negative to begin with. This is reflected in the store by stating that, +after the execution of the loop, the original value of $s (which is set to +equal some symbolic integer S) is incremented by ((N +Int 1) *Int N /Int 2), and the value of $n always equals 0. Add $n and $s as tokens in +the LESSON-22-SPEC-SYNTAX module, the above claim to the LESSON-22-SPEC +module, and run the K prover, which should return #Top.

    +
      +
    1. Finally, our last claim is about a program that uses function calls:
    2. +
    +
    claim
    +    <k>
    +        def $sum($n, .Ids) {
    +            $s = 0 ;
    +            while (0 < $n) {
    +                $s = $s + $n;
    +                $n = $n - 1;
    +            }
    +            return $s;
    +        }
    +
    +        $s = $sum(N:Int, .Ints);
    +    => . ... </k>
    +    <funcs> .Map => ?_ </funcs>
    +    <store> $s |-> (_ => ((N +Int 1) *Int N /Int 2)) </store>
    +    <stack> .List </stack>
    +    requires N >=Int 0
    +
    +

    Essentially, we have wrapped the while loop from claim 3.4 into a function +$sum, and then called that function with a symbolic integer N, storing the +return value in the variable $s. The specification states that this program +ends up storing the sum of the first N integers in the variable $n. Add $sum +to the LESSON-22-SPEC-SYNTAX module, the above claim to the +LESSON-22-SPEC module, and run the K prover, which should again return +#Top.

    +

    Exercises

    +
      +
    1. +

      Change the condition of the if statement in part 3.2 to take the else +branch and adjust the claim so that the proof passes.

      +
    2. +
    3. +

      The post-condition of the specification in part 3.3 loses some information. +In particular, the value of ?C is in fact the maximum of A and B. +Prove the same claim as in 3.2, but with the post-condition ensures (?C ==Int maxInt(A, B)). For this, you will need to extend the VERIFICATION +module with two simplifications that capture the meaning of maxInt(A:Int, B:Int). Keep in mind that any rewriting rule can be used as a +simplification; in particular, that simplifications can have requires +clauses.

      +
    4. +
    5. +

      Following the pattern shown in part 3.4, assuming a non-negative initial +value of $b, specify and verify the following while loop:

      +
    6. +
    +
    while ( 0 < $b ) {
    +    $a = $a + $c;
    +    $b = $b - 1;
    +    $c = $c - 1;
    +}
    +
    +

    Hint: You will not need additional simplifications---once you've got the +specification right, the proof will go through.

    +
      +
    1. Write an arbitrary yet not-too-complex function (or several functions +interacting with each other), and try to specify and verify it (them) in K.
    2. +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/1_basic/index.html b/k-distribution/k-tutorial/1_basic/index.html new file mode 100644 index 00000000000..6f2bd4f6b40 --- /dev/null +++ b/k-distribution/k-tutorial/1_basic/index.html @@ -0,0 +1,401 @@ + + + + + + + + + + + + + + +Section 1: Basic K Concepts | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Section 1: Basic K Concepts

    +

    The goal of this first section of the K tutorial is to teach the basic +principles of K to someone with no prior experience with K as a programming +language. However, this is not written with the intended audience of someone +who is a complete beginner to programming. We are assuming that the reader +has a firm grounding in computer science broadly, as well as that they have +experience writing code in functional programming languages before.

    +

    By the end of this section, the reader ought to be able to write specifications +of simple languages in K, use these specifications to generate a fast +interpreter for their programming language, as well as write basic deductive +program verification proofs over programs in their language. This should give +them the theoretical grounding they need to begin expanding their knowledge +of K in Section 2: Intermediate K Concepts.

    +

    To begin this section, refer to +Lesson 1.1: Setting up a K Environment.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/01_macros/index.html b/k-distribution/k-tutorial/2_intermediate/01_macros/index.html new file mode 100644 index 00000000000..aec2b455858 --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/01_macros/index.html @@ -0,0 +1,567 @@ + + + + + + + + + + + + + + +Lesson 2.1: Macros, Aliases, and Anywhere Rules | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.1: Macros, Aliases, and Anywhere Rules

    +

    The purpose of this lesson is to explain the behavior of the macro, +macro-rec, alias, and alias-rec production attributes, as well as the +anywhere rule attribute. These attributes control the meaning of how rules +associated with them are applied.

    +

    Macros

    +

    Thus far in the K tutorial, we have described three different types of rules:

    +
      +
    1. Top-level rewrite rules, which rewrite a configuration composed of cells to +another configuration;
    2. +
    3. Function rules, which define the behavior of a function written over +arbitrary input and output types; and
    4. +
    5. Simplification rules, which describe ways in which the symbolic execution +engine ought to simplify terms containing symbolic values.
    6. +
    +

    This lesson introduces three more types of rules, the first of which are +macros. A production is a macro if it has the macro attribute, and all +rules whose top symbol on the left hand side is a macro are macro rules +which define the behavior of the macro. Like function rules and simplification +rules, macro rules do not participate in cell completion. However, unlike +function rules and simplification rules, macro rules are applied statically +before rewriting begins, and the macro symbol is expected to no longer appear +in the initial configuration for rewriting once all macros in that +configuration are rewritten.

    +

    The rationale behind macros is they allow you to define one piece of syntax +in terms of another piece of syntax without any runtime overhead associated +with the cost of rewriting one to the other. This process is a common one in +programming language design and specification and is referred to as +desugaring; The syntax that is transformed is typically also referred to as +syntactic sugar for another type of syntax. For example, in a language with +if statements and curly braces, you could write the following fragment +(lesson-01.k):

    +
    k
    module LESSON-01 + imports BOOL + + syntax Stmt ::= "if" "(" Exp ")" Stmt [macro] + | "if" "(" Exp ")" Stmt "else" Stmt + | "{" Stmts "}" + syntax Stmts ::= List{Stmt,""} + syntax Exp ::= Bool + + rule if ( E ) S => if ( E ) S else { .Stmts } +endmodule +
    +

    In this example, we see that an if statement without an else clause is +defined in terms of one with an else clause. As a result, we would only +need to give a single rule for how to rewrite if statements, rather than +two separate rules for two types of if statements. This is a common pattern +for dealing with program syntax that contains an optional component to it.

    +

    It is worth noting that by default, macros are not applied recursively. To be +more precise, by default a macro that arises as a result of the expansion of +the same macro is not rewritten further. This is primarily to simplify the +macro expansion process and reduce the risk that improperly defined macros will +lead to non-terminating behavior.

    +

    It is possible, however, to tell K to expand a macro recursively. To do this, +simply replace the macro attribute with the macro-rec attribute. Note that +K does not do any kind of checking to ensure termination here, so it is +important that rules be defined correctly to always terminate, otherwise the +macro expansion phase will run forever. Fortunately, in practice it is very +simple to ensure this property for most of the types of macros that are +typically used in real-world semantics.

    +

    Exercise

    +

    Using a Nat sort containing the constructors 0 and S (i.e., a +Peano-style axiomatization of the +natural numbers where S(N) = N + 1, S(S(N)) = N + 2, etc), write a macro +that will compute the sum of two numbers.

    +

    Aliases

    +

    NOTE: This lesson introduces the concept of "aliases", which are a variant +of macros. While similar, this is different from the concept of "aliases" in +matching logic, which is introduced in Lesson 2.16.

    +

    Macros can be very useful in helping you define a programming language. +However, they can be disruptive while pretty printing a configuration. For +example, you might write a set of macros that transforms the code the user +wrote into equivalent code that is slightly harder to read. This can make it +more difficult to understand the code when it is pretty printed as part of the +output of rewriting.

    +

    K defines a relatively straightforward but novel solution to this problem, +which is known as a K alias. An alias in K is very similar to a macro, +with the exception that the rewrite rule will also be applied backwards +during the pretty-printing process.

    +

    It is very simple to make a production be an alias instead of a macro: simply +use the alias or alias-rec attributes instead of the macro or macro-rec +attributes. For example, if the example involving if statements above was +declared using an alias instead of a macro, the Stmt term if (E) {} else {} +would be pretty-printed as if (E) {}. This is because during pretty-printing, +the term participates in another macro-expansion pass. However, this macro +expansion step will only apply rules with the alias or alias-rec attribute, +and, critically, it will reverse the rule by treating the left-hand side as if +it were the right-hand side, and vice versa.

    +

    This can be very useful to allow you to define one construct in terms of +another while still being able to pretty-print the result as if it were +the original term in question. This can be especially useful for applications +of K where we are taking the output of rewriting and attempting to use it as +a code fragment that we then execute, such as with test generation.

    +

    Exercise

    +

    Modify LESSON-01 above to use an alias instead of a macro and experiment +with how various terms are pretty-printed by invoking krun on them.

    +

    anywhere rules

    +

    The last type of rule introduced in this lesson is the anywhere rule. An +anywhere rule is specified by adding the anywhere attribute to a rule. Such a +rule is similar to a function rule in that it does not participate in cell +completion, and will apply anywhere that the left-hand-side matches in the +configuration, but distinct in that the symbol in question can still be matched +against in the left-hand side of other rules, even during concrete rewriting. +The reasoning behind this is that instead of the symbol in question being a +constructor, it is a constructor modulo the axioms defined with the +anywhere attribute. Essentially, the rules with the anywhere attribute will +apply as soon as they appear in the right-hand side of a rule being applied, +but the symbol in question will still be treated as a symbol that can be +matched on if it is not completely removed by those rules.

    +

    This can be useful in certain cases to allow you to define transformations over +particular pieces of syntax while still generally giving those pieces of syntax +another meaning when the anywhere rule does not apply. For example, the ISO C +standard defines the semantics of *&x as exactly equal to x, with no +reading or writing of memory taking place, and the K semantics of C implements +this functionality using an anywhere rule that is applied at compilation time.

    +

    NOTE: the anywhere attribute is only implemented on the LLVM backend +currently. Attempting to use it in a semantics that is compiled with the +Haskell backend will result in an error being reported by the compiler. This +should be remembered when using this attribute, as it may not be suitable for +a segment of a semantics which is intended to be symbolically executed.

    +

    Exercises

    +
      +
    1. Write a version of the calculator from Lesson 1.14 Exercise 1, which uses +the same syntax for evaluating expressions, but defines its arithmetic logic +using anywhere rules rather than top-level rewrite rules.
    2. +
    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/02_fresh_constants/index.html b/k-distribution/k-tutorial/2_intermediate/02_fresh_constants/index.html new file mode 100644 index 00000000000..b4b1d166e77 --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/02_fresh_constants/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.2: Fresh Constants | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.2: Fresh Constants

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + +
    + + + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/03_klabels/index.html b/k-distribution/k-tutorial/2_intermediate/03_klabels/index.html new file mode 100644 index 00000000000..338aab3d41c --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/03_klabels/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.3: KLabels and Abstract Syntax | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.3: KLabels and Abstract Syntax

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/04_overloading/index.html b/k-distribution/k-tutorial/2_intermediate/04_overloading/index.html new file mode 100644 index 00000000000..dfb3a300b30 --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/04_overloading/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.4: Overloaded Symbols | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.4: Overloaded Symbols

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/05_matching_logic/index.html b/k-distribution/k-tutorial/2_intermediate/05_matching_logic/index.html new file mode 100644 index 00000000000..2eea6affe2d --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/05_matching_logic/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.5: Matching Logic Connectives and #Or Patterns | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.5: Matching Logic Connectives and #Or Patterns

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/06_function_context/index.html b/k-distribution/k-tutorial/2_intermediate/06_function_context/index.html new file mode 100644 index 00000000000..2f9fd279634 --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/06_function_context/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.6: Function Context | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.6: Function Context

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/07_record_productions/index.html b/k-distribution/k-tutorial/2_intermediate/07_record_productions/index.html new file mode 100644 index 00000000000..b3ebc68385a --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/07_record_productions/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.7: Record Productions and Named Nonterminals | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.7: Record Productions and Named Nonterminals

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/08_fun_and_let/index.html b/k-distribution/k-tutorial/2_intermediate/08_fun_and_let/index.html new file mode 100644 index 00000000000..c357fd7ba46 --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/08_fun_and_let/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.8: #fun and #let | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.8: #fun and #let

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + +
    + + + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/09_as/index.html b/k-distribution/k-tutorial/2_intermediate/09_as/index.html new file mode 100644 index 00000000000..e857bd05ede --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/09_as/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.9: #as Patterns | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.9: #as Patterns

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + +
    + + + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/10_matching_operator/index.html b/k-distribution/k-tutorial/2_intermediate/10_matching_operator/index.html new file mode 100644 index 00000000000..e505bfacac8 --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/10_matching_operator/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.10: The Matching Operators, :=K and :/=K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.10: The Matching Operators, :=K and :/=K

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/11_evaluation_order/index.html b/k-distribution/k-tutorial/2_intermediate/11_evaluation_order/index.html new file mode 100644 index 00000000000..5069d1cc794 --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/11_evaluation_order/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.11: Uncommon Evaluation Order Concepts | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.11: Uncommon Evaluation Order Concepts

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/12_floats_and_machine_ints/index.html b/k-distribution/k-tutorial/2_intermediate/12_floats_and_machine_ints/index.html new file mode 100644 index 00000000000..a060e7be083 --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/12_floats_and_machine_ints/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.12: IEEE 754 Floating Point and Fixed Width Integers | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.12: IEEE 754 Floating Point and Fixed Width Integers

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/13_substitution/index.html b/k-distribution/k-tutorial/2_intermediate/13_substitution/index.html new file mode 100644 index 00000000000..c0fc0867e2a --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/13_substitution/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.13: Alpha-renaming-aware Substitution | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.13: Alpha-renaming-aware Substitution

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/14_io/index.html b/k-distribution/k-tutorial/2_intermediate/14_io/index.html new file mode 100644 index 00000000000..d3f19f7daa1 --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/14_io/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.14: File I/O | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.14: File I/O

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + +
    + + + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/15_string_buffers_and_bytes/index.html b/k-distribution/k-tutorial/2_intermediate/15_string_buffers_and_bytes/index.html new file mode 100644 index 00000000000..e8d955de6f9 --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/15_string_buffers_and_bytes/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.15: String Buffers and Byte Sequences | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.15: String Buffers and Byte Sequences

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/16_kore/index.html b/k-distribution/k-tutorial/2_intermediate/16_kore/index.html new file mode 100644 index 00000000000..c3b856ab681 --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/16_kore/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.16: The Intermediate Language of K, KORE | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.16: The Intermediate Language of K, KORE

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/17_debugging_proofs/index.html b/k-distribution/k-tutorial/2_intermediate/17_debugging_proofs/index.html new file mode 100644 index 00000000000..5fdac1fa106 --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/17_debugging_proofs/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Lesson 2.17: Debugging Proofs using the Haskell Backend REPL | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 2.17: Debugging Proofs using the Haskell Backend REPL

    +

    Return to Top

    +

    Click here to return to the Table of Contents for Section 2.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/2_intermediate/index.html b/k-distribution/k-tutorial/2_intermediate/index.html new file mode 100644 index 00000000000..519c18e7601 --- /dev/null +++ b/k-distribution/k-tutorial/2_intermediate/index.html @@ -0,0 +1,430 @@ + + + + + + + + + + + + + + +Section 2: Intermediate K Concepts | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Section 2: Intermediate K Concepts

    +

    The goal of this second section is to supplement a beginning developer's +knowledge of K after they have gained a basic understanding of K. Each lesson +in this section can be completed independently in order to learn about a +particular facet of the K language. The lessons are written to provide basic +understanding of less commonly-used features of K to someone who is still +learning K. For more complete references of these features, the reader ought to +consult the User Manual.

    +

    The reader ought to be able to complete lessons in this section as needed in +order to learn about specific features of interest, but if desired, can also +complete the entire section in one go. Someone who has completed this entire +section ought to be able to read and understand most K specifications, as well +as write their own specifications of some complexity, and use them to perform +most common K-related tasks. They can then read about specific lessons in +Section 3: Advanced K Concepts if they want to +learn more.

    +

    Table of Contents

    +
      +
    1. Macros, Aliases, and Anywhere Rules
    2. +
    3. Fresh Constants
    4. +
    5. KLabels and Abstract Syntax
    6. +
    7. Overloaded Symbols
    8. +
    9. Matching Logic Connectives and #Or Patterns
    10. +
    11. Function Context
    12. +
    13. Record Productions and Named Nonterminals
    14. +
    15. #fun and #let
    16. +
    17. #as patterns
    18. +
    19. The Matching Operators, :=K and :/=K
    20. +
    21. Uncommon Evaluation Order Concepts
    22. +
    23. IEEE 754 Floating Point and Fixed Width Integers
    24. +
    25. Alpha-renaming-aware Substitution
    26. +
    27. File I/O
    28. +
    29. String Buffers and Byte Sequences
    30. +
    31. The Intermediate Language of K, KORE
    32. +
    33. Debugging Proofs using the Haskell Backend REPL
    34. +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/3_advanced/1_parsing/1_layout/index.html b/k-distribution/k-tutorial/3_advanced/1_parsing/1_layout/index.html new file mode 100644 index 00000000000..0c182942793 --- /dev/null +++ b/k-distribution/k-tutorial/3_advanced/1_parsing/1_layout/index.html @@ -0,0 +1,387 @@ + + + + + + + + + + + + + + +Lesson 3.1.1: Using #Layout to define the syntax of comments and whitespace | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 3.1.1: Using #Layout to define the syntax of comments and whitespace

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/3_advanced/1_parsing/2_ambiguities/index.html b/k-distribution/k-tutorial/3_advanced/1_parsing/2_ambiguities/index.html new file mode 100644 index 00000000000..952a578e983 --- /dev/null +++ b/k-distribution/k-tutorial/3_advanced/1_parsing/2_ambiguities/index.html @@ -0,0 +1,387 @@ + + + + + + + + + + + + + + +Lesson 3.1.2: Using amb for parsing context-sensitive languages | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 3.1.2: Using amb for parsing context-sensitive languages

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/3_advanced/1_parsing/3_locations/index.html b/k-distribution/k-tutorial/3_advanced/1_parsing/3_locations/index.html new file mode 100644 index 00000000000..612cd596aaa --- /dev/null +++ b/k-distribution/k-tutorial/3_advanced/1_parsing/3_locations/index.html @@ -0,0 +1,387 @@ + + + + + + + + + + + + + + +Lesson 3.1.3: Using #location to annotate terms with file, line, and column information | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 3.1.3: Using #location to annotate terms with file, line, and column information

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/3_advanced/2_libraries/1_json/index.html b/k-distribution/k-tutorial/3_advanced/2_libraries/1_json/index.html new file mode 100644 index 00000000000..9b8644cb9a9 --- /dev/null +++ b/k-distribution/k-tutorial/3_advanced/2_libraries/1_json/index.html @@ -0,0 +1,387 @@ + + + + + + + + + + + + + + +Lesson 3.2.1: The JSON Module | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 3.2.1: The JSON Module

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/3_advanced/2_libraries/2_rat/index.html b/k-distribution/k-tutorial/3_advanced/2_libraries/2_rat/index.html new file mode 100644 index 00000000000..5b2e7fc6753 --- /dev/null +++ b/k-distribution/k-tutorial/3_advanced/2_libraries/2_rat/index.html @@ -0,0 +1,387 @@ + + + + + + + + + + + + + + +Lesson 3.2.2: The RAT Module | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 3.2.2: The RAT Module

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/3_advanced/2_libraries/3_ffi/index.html b/k-distribution/k-tutorial/3_advanced/2_libraries/3_ffi/index.html new file mode 100644 index 00000000000..557500f2d54 --- /dev/null +++ b/k-distribution/k-tutorial/3_advanced/2_libraries/3_ffi/index.html @@ -0,0 +1,387 @@ + + + + + + + + + + + + + + +Lesson 3.2.3: The FFI Module | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 3.2.3: The FFI Module

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/3_advanced/3_extending_k/1_custom_hooks/index.html b/k-distribution/k-tutorial/3_advanced/3_extending_k/1_custom_hooks/index.html new file mode 100644 index 00000000000..a7b4064b2b1 --- /dev/null +++ b/k-distribution/k-tutorial/3_advanced/3_extending_k/1_custom_hooks/index.html @@ -0,0 +1,387 @@ + + + + + + + + + + + + + + +Lesson 3.3.1: Extending K by adding new builtin functions | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lesson 3.3.1: Extending K by adding new builtin functions

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/3_advanced/3_extending_k/2_scripting_k/index.html b/k-distribution/k-tutorial/3_advanced/3_extending_k/2_scripting_k/index.html new file mode 100644 index 00000000000..6792eddc339 --- /dev/null +++ b/k-distribution/k-tutorial/3_advanced/3_extending_k/2_scripting_k/index.html @@ -0,0 +1,387 @@ + + + + + + + + + + + + + + +Lessonm 3.3.2: Scripting K to provide language-specific tooling | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Lessonm 3.3.2: Scripting K to provide language-specific tooling

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/3_advanced/index.html b/k-distribution/k-tutorial/3_advanced/index.html new file mode 100644 index 00000000000..cefc95e6ee5 --- /dev/null +++ b/k-distribution/k-tutorial/3_advanced/index.html @@ -0,0 +1,387 @@ + + + + + + + + + + + + + + +Section 3: Advanced K Concepts | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Section 3: Advanced K Concepts

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/k-tutorial/index.html b/k-distribution/k-tutorial/index.html new file mode 100644 index 00000000000..3fceb15846d --- /dev/null +++ b/k-distribution/k-tutorial/index.html @@ -0,0 +1,398 @@ + + + + + + + + + + + + + + +K Tutorial | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    K Tutorial

    +

    The purpose of this series of lessons is to teach developers how to program in +K. While the primary use of K is in the specification of operational semantics +of programming languages, this tutorial is agnostic on how the knowledge of K +is used. For a more detailed tutorial explaining the basic principles of +programming language design, refer to the +K PL Tutorial. Note that that tutorial is somewhat +out of date presently.

    +

    This K tutorial is a work in progress. Many lessons are currently simply +placeholders for future content.

    +

    To start the K tutorial, begin with +Section 1: Basic Programming in K.

    +
    +
    + + +
    + + + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/index.html new file mode 100644 index 00000000000..ae839cc73dd --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/index.html @@ -0,0 +1,404 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Part 1: Defining LAMBDA

    +

    Here you will learn how to define a very simple language in K and the basics +of how to use the K tool. The language is a variant of call-by-value lambda +calculus and its definition is based on substitution. Specifically, you will +learn the following:

    +
      +
    • How to define a module.
    • +
    • How to define a language syntax.
    • +
    • How to use the defined syntax to parse programs.
    • +
    • How to import predefined modules.
    • +
    • How to define evaluation strategies using strictness attributes.
    • +
    • How to define semantic rules.
    • +
    • How the predefined generic substitution works.
    • +
    • How to generate PDF and HTML documentation from ASCII definitions.
    • +
    • How to include builtins (integers and Booleans) into your language.
    • +
    • How to define derived language constructs.
    • +
    +

    This folder contains several lessons, each adding new features to LAMBDA.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_1/NOTES/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_1/NOTES/index.html new file mode 100644 index 00000000000..9557d4acfbe --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_1/NOTES/index.html @@ -0,0 +1,379 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    We now support the following line to the syntax module:

    +
    syntax priority lambda_._ > __  // exact syntax subject to change
    +
    +

    This will allow for fewer parentheses in programs.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_1/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_1/index.html new file mode 100644 index 00000000000..d5724b1eda5 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_1/index.html @@ -0,0 +1,471 @@ + + + + + + + + + + + + + + +Syntax Modules and Basic K Commands | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Syntax Modules and Basic K Commands

    +

    Here we define our first K module, which contains the initial syntax of the +LAMBDA language, and learn how to use the basic K commands.

    +

    Let us create an empty working folder, and open a terminal window +(to the left) and an editor window (to the right). We will edit our K +definition in the right window in a file called lambda.k, and will call +the K tool commands in the left window.

    +

    Let us start by defining a K module, containing the syntax of LAMBDA.

    +

    K modules are introduced with the keywords module ... endmodule.

    +

    The keyword syntax adds new productions to the syntax grammar, using a +BNF-like notation.

    +

    Terminals are enclosed in double-quotes, like strings.

    +

    You can define multiple productions for the same non-terminal in the same +syntax declaration using the | separator.

    +

    Productions can have attributes, which are enclosed in square brackets.

    +

    The attribute left tells the parser that we want the lambda application to be +left associative. For example, a b c d will then parse as (((a b) c) d).

    +

    The attribute bracket tells the parser to not generate a node for the +parenthesis production in the abstract syntax trees associated to programs. +In other words, we want to allow parentheses to be used for grouping, but we +do not want to bother to give them their obvious (ignore) semantics.

    +

    In our variant of lambda calculus defined here, identifiers and lambda +abstractions are meant to be irreducible, that is, are meant to be values. +However, so far Val is just another non-terminal, just like Exp, +without any semantic meaning. It will get a semantic meaning later.

    +

    After we are done typing our definition in the file lambda.k, we can kompile +it with the command:

    +
    kompile lambda.k
    +
    +

    If we get no errors then a parser has been generated. This parser will be +called from now on by default by the krun tool. To see whether and how the +parser works, we are going to write some LAMBDA programs and store them in +files with the extension .lambda.

    +

    Let us create a file identity.lambda, which contains the identity lambda +abstraction:

    +
    lambda x . x
    +
    +

    Now let us call krun on identity.lambda:

    +
    krun identity.lambda
    +
    +

    Make sure you call the krun command from the folder containing your language +definition (otherwise type krun --help to learn how to pass a language +definition as a parameter to krun). The krun command produces the output:

    +
    <k>
    +  lambda x . x
    +</k>
    +
    +

    If you see such an output it means that your program has been parsed (and then +pretty printed) correctly. If you want to see the internal abstract syntax +tree (AST) representation of the parsed program, which we call the K AST, then +type kast in the command instead of krun:

    +
    kast identity.lambda
    +
    +

    You should normally never need to see this internal representation in your +K definitions, so do not get scared (yes, it is ugly for humans, but it is +very convenient for tools).

    +

    Note that krun placed the program in a <k> ... </k> cell. In K, computations +happen only in cells. If you do not define a configuration in your definition, +like we did here, then a configuration will be created automatically for you +which contains only one cell, the default k cell, which holds the program.

    +

    Next, let us create a file free-variable-capture.lambda, which contains an +expression which, in order to execute correctly in a substitution-based +semantics of LAMBDA, the substitution operation needs to avoid +variable-capture:

    +
    a (((lambda x.lambda y.x) y) z)
    +
    +

    Next, file closed-variable-capture.lambda shows an expression which also +requires a capture-free substitution, but this expression is closed (that is, +it has no free variables) and all its bound variables are distinct (I believe +this is the smallest such expression):

    +
    (lambda z.(z z)) (lambda x.lambda y.(x y))
    +
    +

    Finally, the file omega.lambda contains the classic omega combinator +(or closed expression), which is the smallest expression which loops forever +(not now, but after we define the semantics of LAMBDA):

    +
    (lambda x.(x x)) (lambda x.(x x))
    +
    +

    Feel free to define and parse several other LAMBDA programs to get a feel for +how the parser works. Parse also some incorrect programs, to see how the +parser generates error messages.

    +

    In the next lesson we will see how to define semantic rules that iteratively +rewrite expressions over the defined syntax until they evaluate to a result. +This way, we obtain our first programming language defined using K.

    +

    Go to Lesson 2, LAMBDA: Module Importing, Rules, Variables

    +

    MOVIE (out of date) [4'07"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_2.5/NOTES/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_2.5/NOTES/index.html new file mode 100644 index 00000000000..b91a7edbbe9 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_2.5/NOTES/index.html @@ -0,0 +1,379 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    This folder has been added after the original tutorial was made +and after the videos were recorded. Eventually we will renumber +the lessons and redo the videos. A README.md file is also needed +here.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_2/NOTES/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_2/NOTES/index.html new file mode 100644 index 00000000000..86180a4ac43 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_2/NOTES/index.html @@ -0,0 +1,385 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Substitution has been reimplemented in the meanwhile, where the fresh +variables are resolved locally. So there is no global counter for +fresh variables anymore as shown in the video, and fewer variable +renamings take place.

    +

    When calling krun on the programs in lesson_1, a different path is +shown than in the README.md.

    +

    Marking the beta-reduction rule with [anywhere] will give us the +conventional lambda-calculus. A new lesson has been added, 2.5, +showing that. The README.md file should be changed at the end to +point to lesson 2.5.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_2/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_2/index.html new file mode 100644 index 00000000000..2cee8e4a745 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_2/index.html @@ -0,0 +1,453 @@ + + + + + + + + + + + + + + +Module Importing, Rules, Variables | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Module Importing, Rules, Variables

    +

    We here learn how to include a predefined module (SUBSTITUTION), how to +use it to define a K rule (the characteristic rule of lambda calculus), +and how to make proper use of variables in rules.

    +

    Let us continue our lambda.k definition started in the previous lesson.

    +

    The requires keyword takes a .k file containing language features that +are needed for the current definition, which can be found in the +k-distribution/include/kframework/builtin folder. Thus, the command

    +
    require "substitution.k"
    +
    +

    says that the subsequent definition of LAMBDA needs the generic substitution, +which is predefined in file substitution.k under the folder +k-distribution/include/kframework/builtin. Note that substitution can be defined itself in K, +although it uses advanced features that we have not discussed yet in this +tutorial, so it may not be easy to understand now.

    +

    Using the imports keyword, we can now modify LAMBDA to import the module +SUBSTITUTION, which is defined in the required substitution.k file.

    +

    Now we have all the substitution machinery available for our definition. +However, since our substitution is generic, it cannot know which language +constructs bind variables, and what counts as a variable; however, this +information is critical in order to correctly solve the variable capture +problem. Thus, you have to tell the substitution that your lambda construct +is meant to be a binder, and that your Id terms should be treated as variables +for substitution. The former is done using the attribute binder. +By default, binder binds all the variables occurring anywhere in the first +argument of the corresponding syntactic construct within its other arguments; +you can configure which arguments are bound where, but that will be discussed +in subsequent lectures. To tell K which terms are meant to act as variables +for binding and substitution, we have to explicitly subsort the desired syntactic +categories to the builtin KVariable sort.

    +

    Now we are ready to define our first K rule. Rules are introduced with the +keyword rule and make use of the rewrite symbol, =>. In our case, +the rule defines the so-called lambda calculus beta-reduction, which +makes use of substitution in its right-hand side, as shown in lambda.k.

    +

    By convention, variables that appear in rules start with a capital letter +(the current implementation of the K tool may even enforce that).

    +

    Variables may be explicitly tagged with their syntactic category (also called +sort). If tagged, the matching term will be checked at run-time for +membership to the claimed sort. If not tagged, then no check will be made. +The former is safer, but involves the generation of a side condition to the +rule, so the resulting definition may execute slightly slower overall.

    +

    In our rule in lambda.k we tagged all variables with their sorts, so we chose +the safest path. Only the V variable really needs to be tagged there, +because we can prove (using other means, not the K tool, as the K tool is not +yet concerned with proving) that the first two variables will always have the +claimed sorts whenever we execute any expression that parses within our +original grammar.

    +

    Let us compile the definition and then run some programs. For example,

    +
    krun closed-variable-capture.lambda
    +
    +

    yields the output

    +
    <k>
    +  lambda y . ((lambda x . (lambda y . (x  y))) y)
    +</k> 
    +
    +

    Notice that only certain programs reduce (some even yield non-termination, +such as omega.lambda), while others do not. For example, +free-variable-capture.lambda does not reduce its second argument expression +to y, as we would expect. This is because the K rewrite rules between syntactic +terms do not apply anywhere they match. They only apply where they have been +given permission to apply by means of appropriate evaluation strategies of language +constructs, which is done using strictness attributes, evaluation contexts, +heating/cooling rules, etc., as discussed in the next lessons.

    +

    The next lesson will show how to add LAMBDA the desired evaluation strategies +using strictness attributes.

    +

    Go to Lesson 3, LAMBDA: Evaluation Strategies using Strictness

    +

    MOVIE (out of date) [4'03"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_3/NOTES/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_3/NOTES/index.html new file mode 100644 index 00000000000..5b98adb1a75 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_3/NOTES/index.html @@ -0,0 +1,377 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    When we say "previous lesson" we refer to lesson 2. This will need to change +when we incorporate lesson 2.5 properly.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_3/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_3/index.html new file mode 100644 index 00000000000..9fd57178828 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_3/index.html @@ -0,0 +1,418 @@ + + + + + + + + + + + + + + +Evaluation Strategies using Strictness | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Evaluation Strategies using Strictness

    +

    Here we learn how to use the K strict attribute to define desired evaluation +strategies. We will also learn how to tell K which terms are already +evaluated, so it does not attempt to evaluate them anymore and treats them +internally as results of computations.

    +

    Recall from the previous lecture that the LAMBDA program +free-variable-capture.lambda was stuck, because K was not given permission +to evaluate the arguments of the lambda application construct.

    +

    You can use the attribute strict to tell K that the corresponding construct +has a strict evaluation strategy, that is, that its arguments need to be +evaluated before the semantics of the construct applies. The order of +argument evaluation is purposely unspecified when using strict, and indeed +the K tool allows us to detect all possible non-deterministic behaviors that +result from such intended underspecification of evaluation strategies. We will +learn how to do that when we define the IMP language later in this tutorial; +we will also learn how to enforce a particular order of evaluation.

    +

    In order for the above strictness declaration to work effectively and +efficiently, we need to tell the K tool which expressions are meant to be +results of computations, so that it will not attempt to evaluate them anymore. +One way to do it is to make Val a syntactic subcategory of the builtin +KResult syntactic category. Since we use the same K parser to also parse +the semantics, we use the same syntax keyword to define additional syntax +needed exclusively for the semantics (like KResults). See lambda.k.

    +

    Compile again and then run some programs. They should all work as expected. +In particular, free-variable-capture.lambda now evaluates to a y.

    +

    We now got a complete and working semantic definition of call-by-value +lambda-calculus. While theoretically correct, our definition is not +easy to use and disseminate. In the next lessons we will learn how to +generate formatted documentation for LAMBDA and how to extend LAMBDA +in order to write human readable and interesting programs.

    +

    Go to Lesson 4, LAMBDA: Generating Documentation; Latex Attributes.

    +

    MOVIE (out of date) [2'20"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_4/NOTES/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_4/NOTES/index.html new file mode 100644 index 00000000000..5294193bfd1 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_4/NOTES/index.html @@ -0,0 +1,376 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    README.md refers to Lesson 9. This will need to be updated.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_4/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_4/index.html new file mode 100644 index 00000000000..f8d4fa70425 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_4/index.html @@ -0,0 +1,412 @@ + + + + + + + + + + + + + + +Generating Documentation; Latex Attributes | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Generating Documentation; Latex Attributes

    +

    In this lesson we learn how to generate formatted documentation from K +language definitions. We also learn how to use Latex attributes to control +the formatting of language constructs, particularly of ones which have a +mathematical flavor and we want to display accordingly.

    +

    To enhance readability, we may want to replace the keyword lambda by the +mathematical lambda symbol in the generated documentation. We can control +the way we display language constructs in the generated documentation +by associating them Latex attributes.

    +

    This is actually quite easy. All we have to do is to associate a latex +attribute to the production defining the construct in question, following +the Latex syntax for defining new commands (or macros).

    +

    In our case, we associate the attribute latex(\lambda{#1}.{#2}) to the +production declaring the lambda abstraction (recall that in Latex, #n refers +to the n-th argument of the defined new command).

    +

    We will later see, in Lesson 9, that we can add arbitrarily complex Latex +comments and headers to our language definitions, which give us maximum +flexibility in formatting our language definitions.

    +

    Now we have a simple programming language, with a nice documentation. However, +it is not easy to write interesting programs in this language. Almost all +programming languages build upon existing data-types and libraries. The K +tool provides a few of these (and you can add more).

    +

    In the next lesson we show how we can add builtin integers and Booleans to +LAMBDA, so we can start to evaluate meaningful expressions.

    +

    Go to Lesson 5, LAMBDA: Adding Builtins; Side Conditions.

    +

    MOVIE (out of date) [3'13"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_5/NOTES/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_5/NOTES/index.html new file mode 100644 index 00000000000..3a7ad5e75ff --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_5/NOTES/index.html @@ -0,0 +1,381 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    The builtins have changed, they are now generic for all backends.

    +

    Talk about sort inference for variables, for example from I1 +Int I2 +we infer the sort of I1 and I2 is Int.

    +

    Check the entire tutorial for instances where we give the sort of a +variable but we don't have to. Many of those are artifacts since we were +not able to infer sorts that well.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_5/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_5/index.html new file mode 100644 index 00000000000..e5e8dcbc182 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_5/index.html @@ -0,0 +1,465 @@ + + + + + + + + + + + + + + +Adding Builtins; Side Conditions | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Adding Builtins; Side Conditions

    +

    We have already added the builtin identifiers (sort Id) to LAMBDA expressions, +but those had no operations on them. In this lesson we add integers and +Booleans to LAMBDA, and extend the builtin operations on them into +corresponding operations on LAMBDA expressions. We will also learn how to add +side conditions to rules, to limit the number of instances where they can +apply.

    +

    The K tool provides several builtins, which are automatically included in all +definitions. These can be used in the languages that we define, typically by +including them in the desired syntactic categories. You can also define your +own builtins in case the provided ones are not suitable for your language +(e.g., the provided builtin integers and operations on them are arbitrary +precision).

    +

    For example, to add integers and Booleans as values to our LAMBDA, we have to +add the productions

    +
    syntax Val ::= Int | Bool
    +
    +

    Int and Bool are the nonterminals that correspond to these builtins.

    +

    To make use of these builtins, we have to add some arithmetic operation +constructs to our language. We prefer to use the conventional infix notation +for these, and the usual precedences (i.e., multiplication and division bind +tighter than addition, which binds tighter than relational operators). +Inspired from SDF, we use > instead of +| to state that all the previous constructs bind tighter than all the +subsequent ones. See lambda.k.

    +

    The only thing left is to link the LAMBDA arithmetic operations to the +corresponding builtin operations, when their arguments are evaluated. +This can be easily done using trivial rewrite rules, as shown in lambda.k. +In general, the K tool attempts to uniformly add the corresponding builtin +name as a suffix to all the operations over builtins. For example, the +addition over integers is an infix operation named +Int.

    +

    Compile the new lambda.k definition and evaluate some simple arithmetic +expressions. For example, if arithmetic.lambda is (1+2*3)/4 <= 1, then

    +
    krun arithmetic.lambda
    +
    +

    yields, as expected, true. Note that the parser took the desired operation +precedence into account.

    +

    Let us now try to evaluate an expression which performs a wrong computation, +namely a division by zero. Consider the expression arithmetic-div-zero.lambda +which is 1/(2/3). Since division is strict and 2/3 evaluates to 0, this +expression reduces to 1/0, which further reduces to 1 /Int 0 by the rule for +division, which is now stuck (with the current back-end to the K tool).

    +

    In fact, depending upon the back-end that we use to execute K definitions and +in particular to evaluate expressions over builtins, 1 /Int 0 can evaluate to +anything. It just happens that the current back-end keeps it as an +irreducible term. Other K back-ends may reduce it to an explicit error +element, or issue a segmentation fault followed by a core dump, or throw an +exception, etc.

    +

    To avoid requesting the back-end to perform an illegal operation, we may use a +side condition in the rule of division, to make sure it only applies when the +denominator is non-zero.

    +

    Like in other operational formalisms, the role of the K side +conditions is to filter the number of instances of the rule. The notion +of a side condition comes from logics, where a sharp distinction is made +between a side condition (cheap) and a premise (expensive). Premises are +usually resolved using further (expensive) logical derivations, while side +conditions are simple (cheap) conditions over the rule meta-variables within +the underlying mathematical domains (which in K can be extended by the user, +as we will see in future lessons). Regarded as a logic, K derives rewrite +rules from other rewrite rules; therefore, the K side conditions cannot +contain other rewrites in them (using =>). This contrasts other rewrite +engines, for example Maude, which +allow conditional rules with rewrites in conditions. +The rationale behind this deliberate restriction in K is twofold:

    +
      +
    • On the one hand, general conditional rules require a complex, and thus slower +rewrite engine, which starts recursive (sometimes exhaustive) rewrite sessions +to resolve the rewrites in conditions. In contrast, the side conditions in K +can be evaluated efficiently by back-ends, for example by evaluating builtin +expressions and/or by calling builtin functions.
    • +
    • On the other hand, the semantic definitional philosophy of K is that rule +premises are unnecessary, so there is no need to provide support for them.
    • +
    +

    Having builtin arithmetic is useful, but writing programs with just lambda +and arithmetic constructs is still a pain. In the next two lessons we will +add conditional (if_then_else) and binding (let and letrec) constructs, +which will allow us to write nicer programs.

    +

    Go to Lesson 6, LAMBDA: Selective Strictness; Anonymous Variables.

    +

    MOVIE (out of date) [4'52"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_6/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_6/index.html new file mode 100644 index 00000000000..06ba9ba5168 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_6/index.html @@ -0,0 +1,421 @@ + + + + + + + + + + + + + + +Selective Strictness; Anonymous Variables | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Selective Strictness; Anonymous Variables

    +

    We here show how to define selective strictness of language constructs, +that is, how to state that certain language constructs are strict only +in some arguments. We also show how to use anonymous variables.

    +

    We next define a conditional if construct, which takes three arguments, +evaluates only the first one, and then reduces to either the second or the +third, depending on whether the first one evaluated to true or to false.

    +

    K allows to define selective strictness using the same strict attribute, +but passing it a list of numbers. The numbers correspond to the arguments +in which we want the defined construct to be strict. In our case,

    +
    syntax Exp ::= "if" Exp "then" Exp "else" Exp   [strict(1)]
    +
    +

    states that the conditional construct is strict in the first argument.

    +

    We can now assume that its first argument will eventually reduce to a value, so +we only write the following two semantic rules:

    +
    rule if true  then E else _ => E
    +rule if false then _ else E => E
    +
    +

    Thus, we assume that the first argument evaluates to either true or false.

    +

    Note the use of the anonymous variable _. We use such variables purely for +structural reasons, to state that something is there but we don't care what. +An anonymous variable is therefore completely equivalent to a normal variable +which is unsorted and different from all the other variables in the rule. If +you use _ multiple times in a rule, they will all be considered distinct.

    +

    Compile lambda.k and write and execute some interesting expressions making +use of the conditional construct. For example, the expression

    +
    if 2<=1 then 3/0 else 10
    +
    +

    evaluates to 10 and will never evaluate 3/0, thus avoiding an unwanted +division-by-zero.

    +

    In the next lesson we will introduce two new language constructs, called +let and letrec and conventionally found in functional programming +languages, which will allow us to already write interesting LAMBDA programs.

    +

    Go to Lesson 7, LAMBDA: Derived Constructs; Extending Predefined Syntax.

    +

    MOVIE (out of date) [2'14"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_7/NOTES/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_7/NOTES/index.html new file mode 100644 index 00000000000..2a7118e1256 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_7/NOTES/index.html @@ -0,0 +1,379 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    In more recent definitions, we prefer to make some [macro] rules. +Macros apply statically, before the program is executed, thus +increasing the execution performance. The let and letrec constructs +here could be made into [macro].

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_7/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_7/index.html new file mode 100644 index 00000000000..a9b35e7ed4b --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_7/index.html @@ -0,0 +1,459 @@ + + + + + + + + + + + + + + +Derived Constructs, Extending Predefined Syntax | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Derived Constructs, Extending Predefined Syntax

    +

    In this lesson we will learn how to define derived language constructs, that +is, ones whose semantics is defined completely in terms of other language +constructs. We will also learn how to add new constructs to predefined +syntactic categories.

    +

    When defining a language, we often want certain language constructs to be +defined in terms of other constructs. For example, a let-binding construct +of the form

    +
    let x = e in e'
    +
    +

    is nothing but syntactic sugar for

    +
    (lambda x . e') e
    +
    +

    This can be easily achieved with a rule, as shown in lambda.k.

    +

    Compile lambda.k and write some programs using let binders.

    +

    For example, consider a lets.lambda program which takes arithmetic.lambda +and replaces each integer by a let-bound variable. It should evaluate to +true, just like the original arithmetic.lambda.

    +

    Let us now consider a more interesting program, namely one that calculates the +factorial of 10:

    +
    let f = lambda x . (
    +        (lambda t . lambda x . (t t x))
    +        (lambda f . lambda x . (if x <= 1 then 1 else (x * (f f (x + -1)))))
    +        x
    +      )
    +in (f 10)
    +
    +

    This program follows a common technique to define fixed points in untyped +lambda calculus, based on passing a function to itself.

    +

    We may not like to define fixed-points following the approach above, because +it requires global changes in the body of the function meant to be recursive, +basically to pass it to itself (f f in our case above). The approach below +isolates the fixed-point aspect of the function in a so-called fixed-point +combinator, which we call fix below, and then apply it to the function +defining the body of the factorial, without any changes to it:

    +
    let fix = lambda f . (
    +          (lambda x . (f (lambda y . (x x y))))
    +          (lambda x . (f (lambda y . (x x y))))
    +        )
    +in let f = fix (lambda f . lambda x .
    +                (if x <= 1 then 1 else (x * (f (x + -1)))))
    +   in (f 10)
    +
    +

    Although the above techniques are interesting and powerful (indeed, untyped +lambda calculus is in fact Turing complete), programmers will probably not +like to write programs this way.

    +

    We can easily define a more complex derived construct, called letrec and +conventionally encountered in functional programming languages, whose semantics +captures the fixed-point idea above. In order to keep its definition simple +and intuitive, we define a simplified variant of letrec, namely one which only +allows to define one recursive one-argument function. See lambda.k.

    +

    There are two interesting observations here.

    +

    First, note that we have already in-lined the definition of the fix +combinator in the definition of the factorial, to save one application of the +beta reduction rule (and the involved substitution steps). We could have +in-lined the definition of the remaining let, too, but we believe that the +current definition is easier to read.

    +

    Second, note that we extended the predefined Id syntactic category with two +new constants, $x and $y. The predefined identifiers cannot start with +$, so programs that will be executed with this semantics cannot possibly +contain the identifiers xandx andy. In other words, by adding them to Id they +become indirectly reserved for the semantics. This is indeed desirable, +because any possible uses of xinthebodyofthefunctiondefinedusingletrecwouldbecapturedbythelambdax in the body of the function defined +using `letrec` would be captured by the `lambdaxdeclaration in the definition ofletrec`.

    +

    Using letrec, we can now write the factorial program as elegantly as it can +be written in a functional language:

    +
    letrec f x = if x <= 1 then 1 else (x * (f (x + -1)))
    +in (f 10)
    +
    +

    In the next lesson we will discuss an alternative definition of letrec, based +on another binder, mu, specifically designed to define fixed points.

    +

    Go to Lesson 8, LAMBDA: Multiple Binding Constructs.

    +

    MOVIE (out of date) [5'10"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_8/exercises/SK-combinators/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_8/exercises/SK-combinators/index.html new file mode 100644 index 00000000000..2377c229745 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_8/exercises/SK-combinators/index.html @@ -0,0 +1,415 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Define LAMBDA using the S/K combinators instead of substitution. +You new definition will not require the substitution.k module anymore, +and will not use environments (discussed in future lectures), either.

    +

    Recall that the S and K combinators are defined as follows:

    +
    K E1 E2 = E1
    +S E1 E2 E3 = E1 E3 (E2 E3)
    +
    +

    where the application is that of LAMBDA (left associative binary operation), +and that the lambda construct can be desugared to combinators using the +following simple rules:

    +
    lambda X . X = S K K
    +lambda X . Y = K Y    when Y is a name different from X
    +lambda X . (E1 E2) = S (lambda X . E1) (lambda X . E2)
    +lambda X . B = K B    when B is any constant, including S or K
    +
    +

    To distinguish the S and K combinators from K variables and make them +more visible, we prefer to write them as SS and KK instead of S and K.

    +

    If defined correctly and completely, all the tests should pass when you call +ktest on the provided config.xml file. The tests include all the programs +previously executed using LAMBDA (lesson_8), plus the additional program of +the mu-derived exercise, plus a few more simple programs given with this +exercise to help you better test your definition and nail down the notation.

    +

    The syntax of the new LAMBDA should be the same as before, although +mu needs to be desugared as in the mu-desugared exercise (using a macro). +The tricky part is how to deal with the builtin operations. For example, +lambda x . if x then y else z cannot be transformed into combinators as is, +but it can if we assume a builtin conditional function constant, say cond, +and desugar if_then_else_ to it. Then this expression becomes +lambda x . (((cond x) y) z), which we know how to transform. The drawback +of this cond constant approach is that it may induce non-termination +in recursive programs, but that appears to not be a problem in our examples.

    +

    You will have to do the same for all builtin functions, and you will have +to make sure that you define your values correctly! In our previous +definition we were able to say that lambda x . e was a value, but now that +is not possible anymore, because the lambda construct will be eliminated. +Instead, you will have to explicitly say it using the isVal membership +predicate that all the expressions that involve builtin functions and +yield functions are values; for example, isVal(cond V:Val) => true and +isVal(cond V1:Val V2:Val) => true need to be added, but obviously not +isVal(cond V1:Val V2:Val V3:Val) => true.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_8/exercises/mu-derived/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_8/exercises/mu-derived/index.html new file mode 100644 index 00000000000..5861a3483c7 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_8/exercises/mu-derived/index.html @@ -0,0 +1,380 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    The current K LAMBDA semantics of mu (in Lesson 8) is based on +substitution, and then letrec is defined as a derived operation using +mu. Give mu a different semantics, as a derived construct by +translation into other LAMBDA constructs, like we defined letrec in +Lesson 7.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_8/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_8/index.html new file mode 100644 index 00000000000..00bb49e93d5 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_8/index.html @@ -0,0 +1,432 @@ + + + + + + + + + + + + + + +Multiple Binding Constructs | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Multiple Binding Constructs

    +

    Here we learn how multiple language constructs that bind variables can +coexist. We will also learn about or recall another famous binder besides +lambda, namely mu, which can be used to elegantly define all kinds of +interesting fixed-point constructs.

    +

    The mu binder has the same syntax as lambda, except that it replaces +lambda with mu.

    +

    Since mu is a binder, in order for substitution to know how to deal with +variable capture in the presence of mu, we have to tell it that mu is a +binding construct, same like lambda. We take advantage of being there and +also add mu its desired latex attribute.

    +

    The intuition for

    +
    mu x . e
    +
    +

    is that it reduces to e, but each free occurrence of x in e behaves +like a pointer that points back to mu x . e.

    +

    With that in mind, let us postpone the definition of mu and instead redefine +letrec F X = E in E' as a derived construct, assuming mu available. The +idea is to simply regard F as a fixed-point of the function

    +
    lambda X . E
    +
    +

    that is, to first calculate

    +
    mu F . lambda X . E
    +
    +

    and then to evaluate E' where F is bound to this fixed-point:

    +
    let F = mu F . lambda X . E in E'
    +
    +

    This new definition of letrec may still look a bit tricky, particularly +because F is bound twice, but it is much simpler and cleaner than our +previous definition. Moreover, now it is done in a type-safe manner +(this aspect goes beyond our objective in this tutorial).

    +

    Let us now define the semantic rule of mu.

    +

    The semantics of mu is actually disarmingly simple. We just have to +substitute mu X . E for each free occurrence of X in E:

    +
    mu X . E => E[(mu X . E) / X]
    +
    +

    Compile lambda.k and execute some recursive programs. They should be now +several times faster. Write a few more recursive programs, for example ones +for calculating the Ackermann function, for calculating the number of moves +needed to solve the Hanoi tower problem, etc.

    +

    We have defined our first programming language in K, which allows us to +write interesting functional programs. In the next lesson we will learn how +to fully document our language definition, in order to disseminate it, to ship +it to colleagues or friends, to publish it, to teach it, and so on.

    +

    Go to Lesson 9, LAMBDA: A Complete and Commented Definition.

    +

    MOVIE (out of date) [2'40"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_9/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_9/index.html new file mode 100644 index 00000000000..5d3c7e0d321 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_9/index.html @@ -0,0 +1,445 @@ + + + + + + + + + + + + + + +A Complete and Documented K Definition | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    A Complete and Documented K Definition

    +

    In this lesson you will learn how to add formal comments to your K definition, +in order to nicely document it. The generated document can be then used for +various purposes: to ease understanding the K definition, to publish it, +to send it to others, etc.

    +

    The K tool allows a literate programming style, where the executable +language definition can be documented by means of annotations. One such +annotation is the latex(_) annotation, where you can specify how to format +the given production when producing Latex output via the --output latex +option to krun, kast, and kprove.

    +

    There are three types of comments, which we discuss next.

    +

    Ordinary comments

    +

    These use // or /* ... */, like in various programming languages. These +comments are completely ignored.

    +

    Document annotations

    +

    Use the @ symbol right after // or /* in order for the comment to be +considered an annotation and thus be processed by the K tool when it +generates documentation.

    +

    As an example, we can go ahead and add such an annotation at the beginning +of the LAMBDA module, explaining how we define the syntax of this language.

    +

    Header annotations

    +

    Use the ! symbol right after // or /* if you want the comment to be +considered a header annotation, that is, one which goes before +\begin{document} in the generated Latex. You typically need header +annotations to include macros, or to define a title, etc.

    +

    As an example, let us set a Latex length and then add a title and an +author to this K definition.

    +

    Compile the documentation and take a look at the results. Notice the title.

    +

    Feel free to now add lots of annotations to lambda.k.

    +

    Then compile and check the result. Depending on your PDF viewer, you +may also see a nice click-able table of contents, with all the sections +of your document. This could be quite convenient when you define large +languages, because it helps you jump to any part of the semantics.

    +

    Tutorial 1 is now complete. The next tutorial will take us through the +definition of a simple imperative language and will expose us to more +feature of the K framework and the K tool.

    +

    MOVIE (out of date) [6'07"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/1_lambda/lesson_9/lambda/index.html b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_9/lambda/index.html new file mode 100644 index 00000000000..5937509a099 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/1_lambda/lesson_9/lambda/index.html @@ -0,0 +1,510 @@ + + + + + + + + + + + + + + +Tutorial 1 --- LAMBDA | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    K code can be nested inside Markdown using annotated code blocks. +Use the tag k to tell the compiler which blocks to select.

    +

    Inside .k files, C/Java-like comments are available.

    +
    k
    // Single line comment +/* Multiline +comments */ +
    +

    Tutorial 1 --- LAMBDA

    +

    Author: Grigore Roșu (grosu@illinois.edu)
    +Organization: University of Illinois at Urbana-Champaign

    +

    Abstract

    +

    This file defines a simple functional language in K, called LAMBDA, +using a substitution style. The explicit objective here is to teach some +K concepts and how they work in the K tool, and not to teach +λ-calculus or to argue for one definitional style against another +(e.g., some may prefer environment/closure-based definitions of such +languages).

    +

    Note that the subsequent definition is so simple, that it hardly shows any +of the strengths of K. Perhaps the most interesting K aspect it shows is +that substitution can be defined fully generically, and then used to give +semantics to various constructs in various languages.

    +

    Note: +K follows the +literate programming +approach. The various semantic features defined in a K +module can be reordered at will and can be commented using normal +comments like in C/C++/Java. +While comments are useful in general, they can annoy the expert user +of K. To turn them off, you can do one of the following (unless you +want to remove them manually):
    +(1) Use an editor which can +hide or highlight Markdown and conventional C-like comments; or
    +(2) Run kompile --debug <def>. Inside ./.kompiled-xxx/.md2.k/ you will find +all the K code extracted from the markdown files as used for compilation.

    +

    Substitution

    +

    We need the predefined substitution module, so we require it with the command +below. Then we should make sure we import its module called SUBSTITUTION +in our LAMBDA module below.

    +
    k
    require "substitution.md" + +module LAMBDA-SYNTAX + imports DOMAINS-SYNTAX + imports KVAR-SYNTAX +
    +

    Basic Call-by-value λ-Calculus Syntax

    +

    We first define the syntax of conventional call-by-value λ-calculus, making +sure we declare the lambda abstraction construct to be a binder, the +lambda application to be strict, and the parentheses used for grouping as +a bracket.

    +

    Note: +Syntax in K is defined using the familiar BNF notation, with +terminals enclosed in quotes and nonterminals starting with capital +letters. K actually extends BNF with several attributes, which will be +described in this tutorial.

    +

    Note: +The strict constructs can evaluate their arguments in any (fully +interleaved) order.

    +

    The initial syntax of our λ-calculus:

    +
    k
    syntax Val ::= KVar + | "lambda" KVar "." Exp [binder, latex(\lambda{#1}.{#2})] + syntax Exp ::= Val + | Exp Exp [left, strict] + | "(" Exp ")" [bracket] +
    +

    Integer and Boolean Builtins Syntax

    +

    The LAMBDA arithmetic and Boolean expression constructs are simply rewritten +to their builtin counterparts once their arguments are evaluated. +The annotated operators in the right-hand side of the rules below are +builtin and come with the corresponding builtin sort. Note that the +variables appearing in these rules have integer sort. That means that these +rules will only be applied after the arguments of the arithmetic constructs +are fully evaluated to K results; this will happen thanks to their strictness +attributes declared as annotations to their syntax declarations (below).

    +
    k
    syntax Val ::= Int | Bool + syntax Exp ::= "-" Int + > Exp "*" Exp [strict, left] + | Exp "/" Exp [strict] + > Exp "+" Exp [strict, left] + > Exp "<=" Exp [strict] +
    +

    Conditional Syntax

    +

    Note that the if construct is strict only in its first argument.

    +
    k
    syntax Exp ::= "if" Exp "then" Exp "else" Exp [strict(1)] +
    +

    Let Binder

    +

    The let binder is a derived construct, because it can be defined using λ.

    +
    k
    syntax Exp ::= "let" KVar "=" Exp "in" Exp [macro] + rule let X = E in E':Exp => (lambda X . E') E +
    +

    Letrec Binder

    +

    We prefer a definition based on the μ construct. Note that μ is not +really necessary, but it makes the definition of letrec easier to understand +and faster to execute.

    +
    k
    syntax Exp ::= "letrec" KVar KVar "=" Exp "in" Exp [macro] + | "mu" KVar "." Exp [binder, latex(\mu{#1}.{#2})] + rule letrec F:KVar X:KVar = E in E' => let F = mu F . lambda X . E in E' +endmodule +
    +

    LAMBDA module

    +
    k
    module LAMBDA + imports LAMBDA-SYNTAX + imports SUBSTITUTION + imports DOMAINS + + syntax KResult ::= Val +
    +

    β-reduction

    +
    k
    rule (lambda X:KVar . E:Exp) V:Val => E[V / X] +
    +

    Integer Builtins

    +
    k
    rule - I => 0 -Int I + rule I1 * I2 => I1 *Int I2 + rule I1 / I2 => I1 /Int I2 requires I2 =/=Int 0 + rule I1 + I2 => I1 +Int I2 + rule I1 <= I2 => I1 <=Int I2 +
    +

    Conditional

    +
    k
    rule if true then E else _ => E + rule if false then _ else E => E +
    +

    Mu

    +
    k
    rule mu X . E => E[(mu X . E) / X] +endmodule +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/2_imp/NOTES/index.html b/k-distribution/pl-tutorial/1_k/2_imp/NOTES/index.html new file mode 100644 index 00000000000..0f3122bf308 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/2_imp/NOTES/index.html @@ -0,0 +1,379 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +
      +
    • Revise the change of S1 S2 into S1:Stmt S2:Stmt, if needed; only S2 +really needs to be sorted.
    • +
    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/2_imp/index.html b/k-distribution/pl-tutorial/1_k/2_imp/index.html new file mode 100644 index 00000000000..4a8afe6974d --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/2_imp/index.html @@ -0,0 +1,403 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Part 2: Defining IMP

    +

    Here you will learn how to define a very simple imperative language in K +and the basics of how to work with configurations, cells, and computations. +Specifically, you will learn the following:

    +
      +
    • How to define languages using multiple modules.
    • +
    • How to define sequentially strict syntactic constructs.
    • +
    • How to use K's syntactic lists.
    • +
    • How to define, initialize and configure configurations.
    • +
    • How the language syntax is swallowed by the builtin K syntactic category.
    • +
    • The additional syntax of the K syntactic category.
    • +
    • How the strictness annotations are automatically desugared into rules.
    • +
    • The first steps of the configuration abstraction mechanism.
    • +
    +

    Like in the previous tutorial, this folder contains several lessons, each +adding new features to IMP. Do them in order. Also, make sure you completed +and understood the previous tutorial.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/2_imp/lesson_1/index.html b/k-distribution/pl-tutorial/1_k/2_imp/lesson_1/index.html new file mode 100644 index 00000000000..4a1ced7e79e --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/2_imp/lesson_1/index.html @@ -0,0 +1,541 @@ + + + + + + + + + + + + + + +Defining a More Complex Syntax | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Defining a More Complex Syntax

    +

    Here we learn how to define a more complex language syntax than LAMBDA's, +namely the C-like syntax of IMP. Also, we will learn how to define languages +using multiple modules, because we are going to separate IMP's syntax from +its semantics using modules. Finally, we will also learn how to use K's +builtin support for syntactic lists.

    +

    The K tool provides modules for grouping language features. In general, we +can organize our languages in arbitrarily complex module structures. +While there are no rigid requirements or even guidelines for how to group +language features in modules, we often separate the language syntax from the +language semantics in different modules.

    +

    In our case here, we start by defining two modules, IMP-SYNTAX and IMP, and +import the first in the second, using the keyword imports. As their names +suggest, we will place all IMP's syntax definition in IMP-SYNTAX and all its +semantics in IMP.

    +

    Note, however, that K does no more than simply includes all the +contents of the imported module in the one which imports it (making sure +that everything is only kept once, even if you import it multiple times). +In other words, there is currently nothing fancy in K tool's module system.

    +

    IMP has six syntactic categories, as shown in imp.k: AExp for arithmetic +expressions, BExp for Boolean expressions, Block for blocks, Stmt for +statements, Pgm for programs and Ids for comma-separated lists of +identifiers. Blocks are special statements, whose role is to syntactically +constrain the conditional statement and the while loop statement to only +take blocks as branches and body, respectively.

    +

    There is nothing special about arithmetic and Boolean expressions. They +are given the expected strictness attributes, except for <= and &&, +for demonstration purposes.

    +

    The <= is defined to be seqstrict, which means that it evaluates its +arguments in order, from left-to-right (recall that the strict operators +can evaluate their arguments in any, fully interleaved, orders). Like +strict, the seqstrict annotation can also be configured; for example, one +can specify in which arguments and in what order. By default, seqstrict +refers to all the arguments, in their left-to-right order. In our case here, +it is equivalent with seqstrict(1 2).

    +

    The && is only strict in its first argument, because we will give it a +short-circuited semantics (its second argument will only be evaluated when +the first evaluates to true). Recall the K tool also allows us to associate +LaTex attributes to constructs, telling the document generator how to display +them. For example, we associate <= the attribute latex({#1}\leq{#2}), +which makes it be displayed \leq everywhere in the generated LaTex +documentation.

    +

    In this tutorial we take the freedom to associate the various constructs +parsing precedences that we have already tested and we know work well, so that +we can focus on the semantics here instead of syntax. In practice, though, +you typically need to experiment with precedences until you obtain the desired +parser.

    +

    Blocks are defined using curly brackets, and they can either be empty or +hold a statement.

    +

    Nothing special about the IMP statements. Note that ; is an assignment +statement terminator, not a statement separator. Note also that blocks are +special statements.

    +

    An IMP program declares a comma-separated list of variables using the keyword +int like in C, followed by a semicolon ;, followed by a statement. +Syntactically, the idea here is that we can wrap any IMP program within a +main(){...} function and get a valid C program. IMP does not allow variable +declarations anywhere else except through this construct, at the top-level of +the program. Other languages provided with the K distribution (see, e.g., the +IMP++ language also discussed in this tutorial) remove this top-level program +construct of IMP and add instead variable declaration as a statement construct, +which can be used anywhere in the program, not only at the top level.

    +

    Note how we defined the comma-separated list of identifiers using +List{Id,","}. The K tool provides builtin support for generic syntactic +lists. In general,

    +
    syntax B ::= List{A,T}
    +
    +

    declares a new non-terminal, B, corresponding to T-separated sequences of +elements of A, where A is a non-terminal and T is a terminal. These +lists can also be empty, that is, IMP programs declaring no variable are also +allowed (e.g., int; {} is a valid IMP program). To instantiate and use +the K builtin lists, you should alias each instance with a (typically fresh) +non-terminal in your syntax, like we do with the Ids nonterminal.

    +

    Like with other K features, there are ways to configure the syntactic lists, +but we do not discuss them here.

    +

    Recall from Tutorial 1 (LAMBDA) that in order for strictness to work well +we also need to tell K which computations are meant to be results. We do +this as well now, in the module IMP: integers and Booleans are K results.

    +

    Kompile imp.k and test the generated parser by running some programs. +Since IMP is a fragment of C, you may want to select the C mode in your +editor when writing these programs. This will also give your the feel that +you are writing programs in a real programming language.

    +

    For example, here is sum.imp, which sums in sum all numbers up to n:

    +
    int n, sum;
    +n = 100;
    +sum=0;
    +while (!(n <= 0)) {
    +  sum = sum + n;
    +  n = n + -1;
    +}
    +
    +

    Now krun it and see how it looks parsed in the default k cell.

    +

    The program collatz.imp tests the Collatz conjecture for all numbers up to +m and accumulates the total number of steps in s:

    +
    int m, n, q, r, s;
    +m = 10;
    +while (!(m<=2)) {
    +  n = m;
    +  m = m + -1;
    +  while (!(n<=1)) {
    +    s = s+1;
    +    q = n/2;
    +    r = q+q+1;
    +    if (r<=n) {
    +      n = n+n+n+1;         // n becomes 3*n+1 if odd
    +    } else {n=q;}          //        of   n/2 if even
    +  }
    +}
    +
    +

    Finally, program primes.imp counts in s all the prime numbers up to m:

    +
    int i, m, n, q, r, s, t, x, y, z;
    +m = 10;  n = 2;
    +while (n <= m) {
    +  // checking primality of n and writing t to 1 or 0
    +  i = 2;  q = n/i;  t = 1;
    +  while (i<=q && 1<=t) {
    +    x = i;
    +    y = q;
    +    // fast multiplication (base 2) algorithm
    +    z = 0;
    +    while (!(x <= 0)) {
    +      q = x/2;
    +      r = q+q+1;
    +      if (r <= x) { z = z+y; } else {}
    +      x = q;
    +      y = y+y;
    +    } // end fast multiplication
    +    if (n <= z) { t = 0; } else { i = i+1;  q = n/i; }
    +  } // end checking primality
    +  if (1 <= t) { s = s+1; } else {}
    +  n = n+1;
    +}
    +
    +

    All the programs above will run once we define the semantics of IMP. If you +want to execute them now, wrap them in a main(){...} function and compile +them and run them with your favorite C compiler.

    +

    Before we move to the K semantics of IMP, we would like to make some +clarifications regarding the K builtin parser, kast. Although it is quite +powerful, you should not expect magic from it! While the K parser can parse +many non-trivial languages (see, for example, the KOOL language in +pl-tutorial/2_languages) in the K distribution), it was +never meant to be a substitute for real parsers. We often call the syntax +defined in K the syntax of the semantics, to highlight the fact that its +role is to serve as a convenient notation when writing the semantics, not +necessarily as a means to define concrete syntax of arbitrarily complex +programming languages. See the KERNELC language for an example on how to connect an external parser for concrete syntax to +the K tool.

    +

    The above being said, we strongly encourage you to strive to make the +builtin parser work with your desired language syntax! Do not give up +simply because you don't want to deal with syntactic problems. On the +contrary, fight for your syntax! If you really cannot define your desired +syntax because of tool limitations, we would like to know. Please tell us.

    +

    Until now we have only seen default configurations. In the next lesson we +will learn how to define a K custom configuration.

    +

    Go to Lesson 2, IMP: Defining a Configuration.

    +

    MOVIE (out of date) [09'15"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/2_imp/lesson_2/index.html b/k-distribution/pl-tutorial/1_k/2_imp/lesson_2/index.html new file mode 100644 index 00000000000..614497ad342 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/2_imp/lesson_2/index.html @@ -0,0 +1,453 @@ + + + + + + + + + + + + + + +Defining a Configuration | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Defining a Configuration

    +

    Here we learn how to define a configuration in K. We also learn how to +initialize and how to display it.

    +

    As explained in the overview presentation on K, configurations are quite +important, because all semantic rules match and apply on them. +Moreover, they are the backbone of configuration abstraction, which allows +you to only mention the relevant cells in each semantic rule, the rest of +the configuration context being inferred automatically. The importance of +configuration abstraction will become clear when we define more complex +languages (even in IMP++). IMP does not really need it. K configurations +are constructed making use of cells, which are labeled and can be arbitrarily +nested.

    +

    Configurations are defined with the keyword configuration. Cells are +defined using an XML-ish notation stating clearly where the cell starts +and where it ends.

    +

    While not enforced by the tool, we typically like to put the entire +configuration in a top-level cell, called T. So let's define it:

    +
    configuration <T>...</T>
    +
    +

    Cells can have other cells inside. In our case of IMP, we need a cell to +hold the remaining program, cell which we typically call k, and a cell to +hold the program state. Let us add them:

    +
    configuration <T> <k>...</k> <state>...</state> </T>
    +
    +

    K allows us to also specify how to initialize a configuration at the same +time with declaring the configuration. All we have to do is to fill in +the contents of the cells with some terms. The syntactic categories of +those terms will also indirectly define the types of the corresponding +cells.

    +

    For example, we want the k cell to initially hold the program that is passed +to krun. K provides a builtin configuration variable, called $PGM, which +is specifically designed for this purpose: krun will place its program there +(after it parses it, or course). The K tool allows users to define their own +configuration variables, too, which can be used to develop custom +initializations of program configurations with the help of krun; this can be +quite useful when defining complex languages, but we do not discuss it in +this tutorial.

    +
    configuration <T> <k> $PGM </k> <state>...</state>  </T>
    +
    +

    Moreover, we want the program to be a proper Pgm term (because we do not +want to allow krun to take fragments of programs, for example, statements). +Therefore, we tag $PGM with the desired syntactic category, Pgm:

    +
    configuration <T> <k> $PGM:Pgm </k> <state>...</state>  </T>
    +
    +

    Like for other variable tags in K, a run-time check will be performed and the +semantics will get stuck if the passed term is not a well-formed program.

    +

    We next tell K that the state cell should be initialized with the empty map:

    +
    configuration <T> <k> $PGM:Pgm </k> <state> .Map </state>  </T>
    +
    +

    Recall that in K . stands for nothing. However, since there are various +types of nothing, to avoid confusion we can suffix the . with its desired +type. K has several builtin data-types, including lists, sets, bags, and +maps. .Map is the empty map.

    +

    Kompile imp.k and run several programs to see how the configuration is +initialized as desired.

    +

    When configurations get large, and they do when defining large programming +languages, you may want to color the cells in order to more easily distinguish +them. This can be easily achieved using the color cell attribute, following +again an XML-ish style:

    +
    configuration <T color="yellow">
    +                <k color="green"> $PGM:Pgm </k>
    +                <state color="red"> .Map </state>
    +              </T>
    +
    +

    In the next lesson we will learn how to write rules that involve cells.

    +

    Go to Lesson 3, IMP: Computations, Results, Strictness; Rules Involving Cells.

    +

    MOVIE (out of date) [04'21"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/2_imp/lesson_3/index.html b/k-distribution/pl-tutorial/1_k/2_imp/lesson_3/index.html new file mode 100644 index 00000000000..0824a95db7f --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/2_imp/lesson_3/index.html @@ -0,0 +1,591 @@ + + + + + + + + + + + + + + +Computations, Results, Strictness; Rules Involving Cells | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Computations, Results, Strictness; Rules Involving Cells

    +

    In this lesson we will learn about the syntactic category K of computations, +about how strictness attributes are in fact syntactic sugar for rewrite rules +over computations, and why it is important to tell the tool which +computations are results. We will also see a K rule that involves cells.

    +

    K Computations

    +

    Computation structures, or more simply computations, extend the abstract +syntax of your language with a list structure using ~> (read followed +by or and then, and written \curvearrowright in Latex) as a separator. +K provides a distinguished sort, K, for computations. The extension of the +abstract syntax of your language into computations is done automatically by +the K tool when you declare constructs using the syntax keyword, so the K +semantic rules can uniformly operate only on terms of sort K. The intuition +for computation structures of the form

    +
    t1 ~> t2 ~> ... ~> tn
    +
    +

    is that the listed tasks are to be processed in order. The initial +computation typically contains the original program as its sole task, but +rules can then modify it into task sequences, as seen shortly.

    +

    Strictness in Theory

    +

    The strictness attributes, used as annotations to language constructs, +actually correspond to rules over computations. For example, the +strict(2) attribute of the assignment statement corresponds to the +following two opposite rules (X ranges over Id and A over AExp):

    +
    X=A; => A ~> X=[];
    +A ~> X=[]; => X=A;
    +
    +

    The first rule pulls A from the syntactic context X=A; and schedules it +for processing. The second rule plugs A back into its context. +Inspired from the chemical abstract machine, we call rules of the first +type above heating rules and rules of the second type cooling rules. +Similar rules are generated for other arguments in which operations are +strict. Iterative applications of heating rules eventually bring to the +top of the computation atomic tasks, such as a variable lookup, or a +builtin operation, which then make computational progress by means of other +rules. Once progress is made, cooling rules can iteratively plug the result +back into context, so that heating rules can pick another candidate for +reduction, and so on and so forth.

    +

    When operations are strict only in some of their arguments, the corresponding +positions of the arguments in which they are strict are explicitly enumerated +in the argument of the strict attribute, e.g., strict(2) like above, or +strict(2 3) for an operation strict in its second and third arguments, etc. +If an operation is simply declared strict then it means that it is strict +in all its arguments. For example, the strictness of addition yields:

    +
    A1+A2 => A1 ~> []+A2
    +A1 ~> []+A2 => A1+A2
    +A1+A2 => A2 ~> A1+[]
    +A2 ~> A1+[] => A1+A2
    +
    +

    It can be seen that such heating/cooling rules can easily lead to +non-determinism, since the same term may be heated many different ways; +these different evaluation orders may lead to different behaviors in some +languages (not in IMP, because its expressions do not have side effects, +but we will experiment with non-determinism in its successor, IMP++).

    +

    A similar desugaring applies to sequential strictness, declared with the +keyword seqstrict. While the order of arguments of strict is irrelevant, +it matters in the case of seqstrict: they are to be evaluated in the +specified order; if no arguments are given, then they are assumed by default +to be evaluated from left-to-right. For example, the default heating/cooling +rules associated to the sequentially strict <= construct above are +(A1, A2 range over AExp and I1 over Int):

    +
    A1<=A2 => A1 ~> []<=A2
    +A1 ~> []<=A2 => A1<=A2
    +I1<=A2 => A2 ~> I1<=[]
    +A2 ~> I1<=[] => I1<=A2
    +
    +

    In other words, A2 is only heated/cooled after A1 is already evaluated.

    +

    While the heating/cooling rules give us a nice and uniform means to define +all the various allowable ways in which a program can evaluate, all based +on rewriting, the fact that they are reversible comes with a serious practical +problem: they make the K definitions unexecutable, because they lead to +non-termination.

    +

    Strictness in Practice; K Results

    +

    To break the reversibility of the theoretical heating/cooling rules, and, +moreover, to efficiently execute K definitions, the current implementation of +the K tool relies on users giving explicit definitions of their languages' +results.

    +

    The K tool provides a predicate isKResult, which is automatically defined +as we add syntactic constructs to KResult (in fact the K tool defines such +predicates for all syntactic categories, which are used, for example, as +rule side conditions to check user-declared variable memberships, such as +V:Val stating that V belongs to Val).

    +

    The kompile tool, depending upon what it is requested to do, changes the +reversible heating/cooling rules corresponding to evaluation strategy +definitions (e.g., those corresponding to strictness attributes) to avoid +non-termination. For example, when one is interested in obtaining an +executable model of the language (which is the default compilation mode of +kompile), then heating is performed only when the to-be-pulled syntactic +fragment is not a result, and the corresponding cooling only when the +to-be-plugged fragment is a result. In this case, e.g., the heating/cooling +rules for assignment are modified as follows:

    +
    X=A; => A ~> X=[];  requires notBool isKResult(A)
    +A ~> X=[]; => X=A;  requires isKResult(A)
    +
    +

    Note that non-termination of heating/cooling is avoided now. The only thing +lost is the number of possible behaviors that a program can manifest, but +this is irrelevant when all we want is one behavior.

    +

    As will be discussed in the IMP++ tutorial, the heating/cooling rules are +modified differently by kompile when we are interested in other aspects +of the language definition, such us, for example, in a search-able model that +comprises all program behaviors. This latter model is obviously more general +from a theoretical perspective, but, in practice, it is also slower to execute. +The kompile tool strives to give you the best model of the language for the +task you are interested in.

    +

    Can't Results be Inferred Automatically?

    +

    This is a long story, but the short answer is: No!. Maybe in some cases +it is possible, but we prefer to not attempt it in the K tool. For example, +you most likely do not want any stuck computation to count as a result, +since some of them can happen simply because you forgot a semantic rule that +could have further reduce it! Besides, in our experience with defining large +languages, it is quite useful to take your time and think of what the results +of your language's computations are. This fact in itself may help you improve +your overall language design. We typically do it at the same time with +defining the evaluation strategies of our languages. Although in theory K +could infer the results of your language as the stuck computations, based on +the above we have deliberately decided to not provide this feature, in spite +of requests from some users. So you currently do have to explicitly define +your K results if you want to effectively use the K tool. Note, however, that +theoretical definitions, not meant to be executed, need not worry about +defining results (that's because in theory semantic rules apply modulo the +reversible heating/cooling rules, so results are not necessary).

    +

    A K Rule Involving Cells

    +

    All our K rules so far in the tutorial were of the form

    +
    rule left => right requires condition
    +
    +

    where left and right were syntactic, or more generally computation, terms.

    +

    Here is our first K rule explicitly involving cells:

    +
    rule <k> X:Id => I ...</k> <state>... X |-> I ...</state>
    +
    +

    Recall that the k cell holds computations, which are sequences of tasks +separated by ~>. Also, the state cell holds a map, which is a set of +bindings, each binding being a pair of computations (currently, the +K builtin data-structures, like maps, are untyped; or, said differently, +they are all over the type of computations, K).

    +

    Therefore, the two cells mentioned in the rule above hold collections +of things, ordered or not. The ...s, which we also call cell frames, +stand for more stuff there, which we do not care about.

    +

    The rewrite relation => is allowed in K to appear anywhere in a term, its +meaning being that the corresponding subterm is rewritten as indicated in the +shown context. We say that K's rewriting is local.

    +

    The rule above says that if the identifier X is the first task in the k +cell, and if X is bound to I somewhere in the state, then X rewrites +to I locally in the k cell. Therefore, IMP variables need to be already +declared when looked up.

    +

    Of course, the K rule above can be translated into an ordinary rewrite rule +of the form

    +
    rule <k> X ~> Rest </k> <state> Before (X |-> I) After </state>
    +  => <k> I ~> Rest </k> <state> Before (X |-> I) After </state>
    +
    +

    Besides being more verbose and thus tedious to write, this ordinary rule +is also more error-prone; for example, we may forget the Rest variable +in the right-hand-side, etc. Moreover, the concurrent semantics of K +allows for its rules to be interpreted as concurrent transactions, where +the context is the read-only component of the transaction, while the +subterms which are rewritten are read/write component of the transaction; +thus, K rule instances can apply concurrently if they only overlap +on read-only parts, while they cannot if regarded as ordinary rewrite logic +rules. Note: our current implementation of the K tool is not concurrent, +so K rules are in fact desugared as normal rewrite rules in the K tool.

    +

    Kompile imp.k using a documentation option and check out how the K rule +looks in the generated document. The ... frames are displayed as cell +tears, metaphorically implying that those parts of the cells that we +do not care about are torn away. The rewrite relation is replaced by a +horizontal line: specifically, the subterm which rewrites, X, is +underlined, and its replacement is written underneath the line.

    +

    In the next lesson we define the complete K semantics of IMP and +run the programs we parsed in the first lesson.

    +

    Go to Lesson 4, IMP: Configuration Abstraction, Part 1; Types of Rules.

    +

    MOVIE (out of date) [10'30"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/2_imp/lesson_4/exercises/purely-syntactic/index.html b/k-distribution/pl-tutorial/1_k/2_imp/lesson_4/exercises/purely-syntactic/index.html new file mode 100644 index 00000000000..c075a621728 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/2_imp/lesson_4/exercises/purely-syntactic/index.html @@ -0,0 +1,382 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Modify IMP so that the K followed by arrow, ~>, does not explicitly +occur in the definition (it currently occurs in the semantics of +sequential composition).

    +

    Hint: make sequential composition strict(1) or seqstrict, and have +statements reduce to {} instead of .; and don't forget to make +{} a KResult (you may need a new syntactic category for that, which +only includes {} and is included in KResult).

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/2_imp/lesson_4/exercises/uninitialized-variables/index.html b/k-distribution/pl-tutorial/1_k/2_imp/lesson_4/exercises/uninitialized-variables/index.html new file mode 100644 index 00000000000..7f8d66bc41f --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/2_imp/lesson_4/exercises/uninitialized-variables/index.html @@ -0,0 +1,381 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Modify the K definition of IMP to not automatically initialize +variables to 0. Instead, declared variables should stay uninitialized +until assigned a value, and the execution should get stuck when an +uninitialized variable is looked up. Specifically, you should add a +new undefined construct of sort K, and initialize all the declared +variables with it.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/2_imp/lesson_4/index.html b/k-distribution/pl-tutorial/1_k/2_imp/lesson_4/index.html new file mode 100644 index 00000000000..dfd00175a33 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/2_imp/lesson_4/index.html @@ -0,0 +1,497 @@ + + + + + + + + + + + + + + +Configuration Abstraction, Part 1; Types of Rules | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Configuration Abstraction, Part 1; Types of Rules

    +

    Here we will complete the K definition of IMP and, while doing so, we will +learn the very first step of what we call configuration abstraction.

    +

    The IMP Semantic Rules

    +

    Let us add the remaining rules, in the order in which the language constructs +were defined in IMP-SYNTAX.

    +

    The rules for the arithmetic and Boolean constructs are self-explanatory. +Note, however, that K will infer the correct sorts of all the variables in +these rules, because they appear as arguments of the builtin operations +(_+Int_, etc.). Moreover, the inferred sorts will be enforced dynamically. +Indeed, we do not want to apply the rule for addition, for example, when the +two arguments are not integers. In the rules for &&, although we prefer to +not do it here for simplicity, we could have eliminated the dynamic check by +replacing B (and similarly for _) with B:K. Indeed, it can be shown +that whenever any of these rules apply, B (or _) is a BExp anyway. +That's because there is no rule that can touch such a B (or _); this +will become clearer shortly, when we discuss the first step of configuration +abstraction. Therefore, since we know that B will be a BExp anyway, we +could save the time it takes to check its sort; such times may look minor, +but they accumulate, so some designers may prefer to avoid run-time checks +whenever possible.

    +

    The block rules are trivial. However, the rule for non-empty blocks is +semantically correct only because we do not have local variable declarations +in IMP. We will have to change this rule in IMP++.

    +

    The assignment rule has two =>: one in the k cell dissolving the +assignment statement, and the other in the state cell updating the value of +the assigned variable. Note that the one in the state is surrounded by +parentheses: (_ => I). That is because => is greedy: it matches as much +as it can to the left and to the right, until it reaches the cell boundaries +(closed or open). If you want to limit its scope, or for clarity, you can use +parentheses like here.

    +

    The rule for sequential composition simply desugars S1 S2 into S1 ~> S2. +Indeed, the two have exactly the same semantics. Note that statements +evaluate to nothing (.), so once S1 is processed in S1 ~> S2, then the +next task is automatically S2, without wasting any step for the transition.

    +

    The rules for the conditional and while statements are clear. One thing to +keep in mind now is that the while unrolling rule will not apply +indefinitely in the positive branch of the resulting conditional, because +of K's configuration abstraction, which will be discussed shortly.

    +

    An IMP program declares a set of variables and then executes a +statement in the state obtained after initializing all those variables +to 0. The rules for programs initialize the declared variables one by one, +checking also that there are no duplicates. We check for duplicates only for +demonstration purposes, to illustrate the keys predefined operation that +returns the set of keys of a map, and the set membership operation in. +In practice, we typically define a static type checker for our language, +which we execute before the semantics and reject inappropriate programs.

    +

    The use of the .Ids in the second rule is not necessary. We could have +written int; S instead of int .Ids; S and the K tool would parse it and +kompile the definition correctly, because it uses the same parser used for +parsing programs also to parse the semantics. However, we typically prefer to +explicitly write the nothing values in the semantics, for clarity; +the parser has been extended to accept these. Note that the first rule +matches the entire k cell, because int_;_ is the top-level program +construct in IMP, so there is nothing following it in the computation cell. +The anonymous variable stands for the second argument of this top-level program +construct, not for the rest of the computation. The second rule could have +also been put in a complete k cell, but we preferred not to, for simplicity.

    +

    Our IMP semantics is now complete, but there are a few more things that we +need to understand and do.

    +

    Configuration Abstraction, Part 1

    +

    First, let us briefly discuss the very first step of configuration abstraction. +In K, all semantic rules are in fact rules between configurations. As soon +explained in the IMP++ tutorial, the declared configuration cell structure is +used to automatically complete the missing configuration parts in rules. +However, many rules do not involve any cells, being rules between syntactic +terms (of sort K); for example, we had only three rules involving cells in our +IMP semantics. In this case, the k cell will be added automatically and the +actual rewrite will happen on top of the enclosed computation. For example, +the rule for the while loop is automatically translated into the following:

    +
    rule <k> while (B) S => if (B) {S while (B) S} else {} ...</k>
    +
    +

    Since the first task in computations is what needs to be done next, the +intuition for this rule completion is that the syntactic transition +only happens when the term to rewrite is ready for processing. This explains, +for example, why the while loop unrolling does not indefinitely apply in the +positive branch of the conditional: the inner while loop is not ready for +evaluation yet. We call this rule completion process, as well as other +similar ones, configuration abstraction. That is because the incomplete +rule abstracts away the configuration structure, thus being easier to read. +As seen soon when we define IMP++, configuration abstraction is not only a +user convenience; it actually significantly increases the modularity of our +definitions. The k-cell-completion is only the very first step, though.

    +

    If you really want certain rewrites over syntactic terms to apply +anywhere they match, then you should tag the rule with the attribute +anywhere, which was discussed in Tutorial 1, Lesson 2.5.

    +

    Kompile and then krun the programs that you only parsed in Lesson 1. They +should all execute as expected. The state cell shows the final state +of the program. The k cell shows the final code contents, which should be +empty whenever the IMP program executes correctly.

    +

    Kompile also with the documentation option and take a look at the generated +documentation. The assignment rule should particularly be of interest, +because it contains two local rewrites.

    +

    In the next lesson we comment the IMP definition and conclude this tutorial.

    +

    Go to Lesson 5, IMP: Completing and Documenting IMP.

    +

    MOVIE (out of date) [09'16"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/2_imp/lesson_5/imp/index.html b/k-distribution/pl-tutorial/1_k/2_imp/lesson_5/imp/index.html new file mode 100644 index 00000000000..a17a58e2d15 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/2_imp/lesson_5/imp/index.html @@ -0,0 +1,547 @@ + + + + + + + + + + + + + + +IMP | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    IMP

    +

    Author: Grigore Roșu (grosu@illinois.edu)
    +Organization: University of Illinois at Urbana-Champaign

    +

    Abstract

    +

    This is the K semantic definition of the classic IMP language. +IMP is considered a folklore language, without an official inventor, +and has been used in many textbooks and papers, often with slight +syntactic variations and often without being called IMP. It includes +the most basic imperative language constructs, namely basic constructs +for arithmetic and Boolean expressions, and variable assignment, +conditional, while loop and sequential composition constructs for statements.

    +
    k
    module IMP-SYNTAX + imports DOMAINS-SYNTAX +
    +

    Syntax

    +

    This module defines the syntax of IMP. +Note that <= is sequentially strict, and && is strict only in its first +argument, because we want to give it a short-circuit semantics.

    +
    k
    syntax AExp ::= Int | Id + | "-" Int [format(%1%2)] + | AExp "/" AExp [left, strict, color(pink)] + | "(" AExp ")" [bracket] + > AExp "+" AExp [left, strict, color(pink)] + syntax BExp ::= Bool + | AExp "<=" AExp [seqstrict, latex({#1}\leq{#2}), color(pink)] + | "!" BExp [strict, color(pink)] + | "(" BExp ")" [bracket] + > BExp "&&" BExp [left, strict(1), color(pink)] + syntax Block ::= "{" "}" + | "{" Stmt "}" [format(%1%i%n%2%d%n%3)] + syntax Stmt ::= Block + | Id "=" AExp ";" [strict(2), color(pink), format(%1 %2 %3%4)] + | "if" "(" BExp ")" + Block "else" Block [strict(1), colors(yellow, white, white, yellow), format(%1 %2%3%4 %5 %6 %7)] + | "while" "(" BExp ")" Block [colors(yellow,white,white), format(%1 %2%3%4 %5)] + > Stmt Stmt [left, format(%1%n%2)] +
    +

    An IMP program declares a set of variables and then executes a +statement in the state obtained after initializing all those variables +to 0. K provides builtin support for generic syntactic lists: +List{Nonterminal,terminal} stands for terminal-separated lists of Nonterminal elements.

    +
    k
    syntax Pgm ::= "int" Ids ";" Stmt [format(%1 %2%3%n%4), colors(yellow,pink)] + syntax Ids ::= List{Id,","} [format(%1%2 %3)] +endmodule +
    +

    We are done with the definition of IMP's syntax. Make sure +that you write and parse several interesting programs before you move to the +semantics.

    +
    k
    module IMP + imports IMP-SYNTAX + imports DOMAINS +
    +

    Semantics

    +

    This module defines the semantics of IMP. +Before you start adding semantic rules to a K definition, you need to +define the basic semantic infrastructure consisting of definitions for +results and the configuration.

    +

    Values and results

    +

    IMP only has two types of values, or results of computations: integers +and Booleans. We here use the K builtin variants for both of them.

    +
    k
    syntax KResult ::= Int | Bool +
    +

    Configuration

    +

    The configuration of IMP is trivial: it only contains two cells, one +for the computation and another for the state. For good encapsulation +and clarity, we place the two cells inside another cell, the top cell +which is labeled T.

    +
    k
    configuration <T color="yellow"> + <k color="green"> $PGM:Pgm </k> + <state color="red"> .Map </state> + </T> +
    +

    The configuration variable PGM tells the K tool where to +place the program. More precisely, the command +krun program parses the program and places the resulting +K abstract syntax tree in the k cell before invoking the +semantic rules described in the sequel. The . in the +state cell, written .Map in ASCII in the +imp.md file, is K's way to say nothing. Technically, it +is a constant which is the unit, or identity, of all maps in K +(similar dot units exist for other K structures, such as lists, sets, +multi-sets, etc.).

    +

    Arithmetic expressions

    +

    The K semantics of each arithmetic construct is defined below.

    +

    Variable lookup

    +

    A program variable X is looked up in the state by matching a binding +of the form X |-> I in the state cell. If such a binding does not +exist, then the rewriting process will get stuck. Thus our semantics of +IMP disallows uses of uninitialized variables. Note that the variable +to be looked up is the first task in the k cell (the cell is +closed to the left and torn to the right), while the binding can be +anywhere in the state cell (the cell is torn at both sides).

    +
    k
    rule <k> X:Id => I ...</k> <state>... X |-> I ...</state> +
    +

    Arithmetic operators

    +

    There is nothing special about these, but recall that K's configuration +abstraction mechanism is at work here! That means that the rewrites in the +rules below all happen at the beginning of the k cell.

    +
    k
    rule I1 / I2 => I1 /Int I2 requires I2 =/=Int 0 + rule I1 + I2 => I1 +Int I2 + rule - I1 => 0 -Int I1 +
    +

    Boolean expressions

    +

    The rules below are straightforward. Note the short-circuited semantics +of &&; this is the reason we annotated the syntax of +&& with the K attribute strict(1) instead of strict.

    +
    k
    rule I1 <= I2 => I1 <=Int I2 + rule ! T => notBool T + rule true && B => B + rule false && _ => false +
    +

    Blocks and Statements

    +

    There is one rule per statement construct except for the conditional, +which needs two rules.

    +

    Blocks

    +

    The empty block {} is simply dissolved. The . below is the +unit of the computation list structure K, that is, the empty task. +Similarly, the non-empty blocks are dissolved and replaced by their statement +contents, thus effectively giving them a bracket semantics; we can afford to +do this only because we have no block-local variable declarations yet in IMP.

    +
    k
    rule {} => . + rule {S} => S +
    +

    Assignment

    +

    The assigned variable is updated in the state. The variable is expected +to be declared, otherwise the semantics will get stuck. At the same time, +the assignment is dissolved.

    +
    k
    rule <k> X = I:Int; => . ...</k> <state>... X |-> (_ => I) ...</state> +
    +

    Sequential composition

    +

    Sequential composition is simply structurally translated into K's +builtin task sequentialization operation.

    +
    k
    rule S1:Stmt S2:Stmt => S1 ~> S2 +
    +

    Conditional

    +

    The conditional statement has two semantic cases, corresponding to +when its condition evaluates to true or to false. +Recall that the conditional was annotated with the attribute +strict(1) in the syntax module above, so only its first +argument is allowed to be evaluated.

    +
    k
    rule if (true) S else _ => S + rule if (false) _ else S => S +
    +

    While loop

    +

    We give the semantics of the while loop by unrolling.

    +
    k
    rule while (B) S => if (B) {S while (B) S} else {} +
    +

    Programs

    +

    The semantics of an IMP program is that its body statement is executed +in a state initializing all its global variables to 0. Since K's +syntactic lists are internally interpreted as cons-lists (i.e., lists +constructed with a head element followed by a tail list), we need to +distinguish two cases, one when the list has at least one element and +another when the list is empty. In the first case we initialize the +variable to 0 in the state, but only when the variable is not already +declared (all variables are global and distinct in IMP).

    +
    k
    rule <k> int (X,Xs => Xs);_ </k> <state> Rho:Map (.Map => X|->0) </state> + requires notBool (X in keys(Rho)) + rule int .Ids; S => S +endmodule +
    +
    +
    + + +
    + + + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/2_imp/lesson_5/index.html b/k-distribution/pl-tutorial/1_k/2_imp/lesson_5/index.html new file mode 100644 index 00000000000..18e89974be7 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/2_imp/lesson_5/index.html @@ -0,0 +1,400 @@ + + + + + + + + + + + + + + +Completing and Documenting IMP | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Completing and Documenting IMP

    +

    We here learn no new concepts, but it is a good moment to take a break +and contemplate what we learned so far.

    +

    Let us add lots of formal annotations to imp.k.

    +

    Once we are done with the annotations, we kompile with the documentation +option and then take a look at the produced document. We often call these +documents language posters. Depending on how much information you add to +these language posters, they can serve as standalone, formal presentations +of your languages. For example, you can print them as large posters and +post them on the wall, or in poster sessions at conferences.

    +

    This completes our second tutorial. The next tutorials will teach us more +features of the K framework, such as how to define languages with complex +control constructs (like callcc), languages which are concurrent, and so on.

    +

    MOVIE (out of date) [03'45"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/index.html new file mode 100644 index 00000000000..b4b3789fa73 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/index.html @@ -0,0 +1,399 @@ + + + + + + + + + + + + + + +Part 3: Defining LAMBDA++ | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Part 3: Defining LAMBDA++

    +

    Here you will learn how to define language constructs which abruptly change +the execution control flow, and how to define language semantics following +and environment/store style. Specifically, you will learn the following:

    +
      +
    • How to define constructs like callcc, which allow you to take snapshots of +program executions and to go back in time at any moment.
    • +
    • How to define languages in an environment/store style.
    • +
    • Some basic notions about the use of closures and closure-like semantic +structures to save and restore execution environments.
    • +
    • Some basic intuitions about reusing existing semantics in new languages, +as well as some of the pitfalls in doing so.
    • +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/NOTES/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/NOTES/index.html new file mode 100644 index 00000000000..456af0276c8 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/NOTES/index.html @@ -0,0 +1,378 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Maybe we should change the name of calCC, as it is not a good idea to have +two constructs with different semantics but names which cannot be distinguished +easily.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/callCC/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/callCC/index.html new file mode 100644 index 00000000000..92b0c690efb --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/callCC/index.html @@ -0,0 +1,378 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Define a variant of callcc, say callCC, which never returns to the +current context unless a value is specifically passed to its argument +continuation. Follow a substitution-based style.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/from-call-CC-to-callcc/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/from-call-CC-to-callcc/index.html new file mode 100644 index 00000000000..e9eab194233 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/from-call-CC-to-callcc/index.html @@ -0,0 +1,377 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Define callcc in terms of callCC, where callCC is explained in the +callCC exercise under LAMBDA++, Lesson 1. Follow a substitution-based style.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/from-callcc-to-call-CC/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/from-callcc-to-call-CC/index.html new file mode 100644 index 00000000000..e97d697be91 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/exercises/from-callcc-to-call-CC/index.html @@ -0,0 +1,381 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Define callCC in terms of callcc, where callCC is explained in the +callCC exercise under LAMBDA++, Lesson 1. Follow a substitution-based style.

    +

    To facilitate testing, call the main module CALLCC (see tests/config.xml). +For example, you can define a module CALLCC which imports the previous +definition of callcc and adds the definition of callCC in terms of +callcc.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/index.html new file mode 100644 index 00000000000..0c82f20d602 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/index.html @@ -0,0 +1,486 @@ + + + + + + + + + + + + + + +Abrupt Changes of Control | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Abrupt Changes of Control

    +

    Here we add call-with-current-continuation (callcc) to the definition of +LAMBDA completed in Tutorial 1, and call the resulting language LAMBDA++. +While doing so, we will learn how to define language constructs that +abruptly change the execution control flow.

    +

    Take over the lambda.k definition from Lesson 8 in Part 1 of this Tutorial, +which is the complete definition of the LAMBDA language, but without the +comments.

    +

    callcc is a good example for studying the capabilities of a framework to +support abrupt changes of control, because it is one of the most +control-intensive language constructs known. Scheme is probably the first +programming language that incorporated the callcc construct, although +similar constructs have been recently included in many other languages in +one form or another.

    +

    Here is a quick description: callcc e passes the remaining computation +context, packaged as a function k, to e (which is expected to be a function); +if during its evaluation e passes any value to k, then the current +execution context is discarded and replaced by the one encoded by k and +the value is passed to it; if e evaluates normally to some value v and +passes nothing to k in the process, then v is returned as a result of +callcc e and the execution continues normally. For example, we want the +program callcc-jump.lambda:

    +
    (callcc (lambda k . ((k 5) + 2))) + 10
    +
    +

    to evaluate to 15, not 17! Indeed, the computation context [] + 10 is +passed to callcc's argument, which then sends it a 5, so the computation +resumes to 5 + 10. On the other hand, the program callcc-not-jump.lambda

    +
    (callcc (lambda k . (5 + 2))) + 10
    +
    +

    evaluates to 17.

    +

    If you like playing games, you can metaphorically think of callcc e as +saving your game state in a file and passing it to your friend e. +Then e can decide at some moment to drop everything she was doing, load +your game and continue to play it from where you were.

    +

    The behavior of many popular control-changing constructs can be obtained +using callcc. The program callcc-return.lambda shows, for example, how to +obtain the behavior of a return statement, which exits the current execution +context inside a function and returns a value to the caller's context:

    +
    letrec f x = callcc (lambda return . (
    +  f (if (x <= 0) then ((return 1) / 0) else 2)
    +))
    +in (f -3)
    +
    +

    This should evaluate to 1, in spite of the recursive call to f +and of the division by zero! Note that return is nothing but a variable +name, but one which is bound to the current continuation at the beginning of +the function execution. As soon as 1 is passed to return, the computation +jumps back in time to where callcc was defined! Change -3 to 3 and the +program will loop forever.

    +

    callcc is quite a powerful and beautiful language construct, although one +which is admittedly hard to give semantics to in some frameworks. +But not in K :) Here is the entire K syntax and semantics of callcc:

    +
    syntax Exp ::= "callcc" Exp  [strict]
    +syntax Val ::= cc(K)
    +rule <k> (callcc V:Val => V cc(K)) ~> K </k>
    +rule <k> cc(K) V ~> _ =>  V ~> K </k>
    +
    +

    Let us first discuss the annotated syntax. We declared callcc strict, +because its argument may not necessarily be a function yet, so it may need +to be evaluated. As explained above, we need to encode the remaining +computation somehow and pass it to callcc's argument. More specifically, +since LAMBDA is call-by-value, we have to encode the remaining computation as +a value. We do not want to simply subsort computations to Val, because there +are computations which we do not want to be values. A simple solution to +achieve our goal here is to introduce a new value construct, say cc (from +current-continuation), which holds any computation.

    +

    Note that, inspired from SDF, +K allows you to define the syntax of helping semantic operations, like cc, +more compactly. Typically, we do not need a fancy syntax for such operators; +all we need is a name, followed by open parenthesis, followed by a +comma-separated list of arguments, followed by closed parenthesis. If this +is the syntax that you want for a particular construct, then K allows you to +drop all the quotes surrounding the terminals, as we did above for cc.

    +

    The semantic rules do exactly what the English semantics of callcc says. +Note that here, unlike in our definition of LAMBDA in Tutorial 1, we had +to mention the cell <k/> in our rules. This is because we need to make sure +that we match the entire remaining computation, not only a fragment of it! +For example, if we replace the two rules above with

    +
    rule (callcc V:Val => V cc(K)) ~> K
    +rule cc(K) V ~> _ =>  V ~> K
    +
    +

    then we get a callcc which is allowed to non-deterministically pick a +prefix of the remaining computation and pass it to its argument, and then +when invoked within its argument, a non-deterministic prefix of the new +computation is discarded and replaced by the saved one. Wow, that would +be quite a language! Would you like to write programs in it? :)

    +

    Consequently, in K we can abruptly change the execution control flow of a +program by simply changing the contents of the <k/> cell. This is one of +the advantages of having an explicit representation of the execution context, +like in K or in reduction semantics with evaluation contexts. Constructs like +callcc are very hard and non-elegant to define in frameworks such as SOS, +because those implicitly represent the execution context as proof context, +and the latter cannot be easily changed.

    +

    Now that we know how to handle cells in configurations and use them in rules, +in the next lesson we take a fresh look at LAMBDA and define it using +an environment-based style, which avoids the complexity of substitution +(e.g., having to deal with variable capture) and is closer in spirit to how +functional languages are implemented.

    +

    Go to Lesson 2, LAMBDA++: Semantic (Non-Syntactic) Computation Items.

    +

    MOVIE (out of date) [6'28"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_2/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_2/index.html new file mode 100644 index 00000000000..c9ad16e7807 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_2/index.html @@ -0,0 +1,535 @@ + + + + + + + + + + + + + + +Semantic (Non-Syntactic) Computation Items | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Semantic (Non-Syntactic) Computation Items

    +

    In this lesson we start another semantic definition of LAMBDA++, which +follows a style based on environments instead of substitution. In terms of +K, we will learn how easy it is to add new items to the syntactic category +of computations K, even ones which do not have a syntactic nature.

    +

    An environment binds variable names of interest to locations where their +values are stored. The idea of environment-based definitions is to maintain +a global store mapping locations to values, and then have environments +available when we evaluate expressions telling where the variables are +located in the store. Since LAMBDA++ is a relatively simple language, we +only need to maintain one global environment. Following a similar style +like in IMP, we place all cells into a top cell T:

    +
    configuration <T>
    +                <k> $PGM:Exp </k>
    +                <env> .Map </env>
    +                <store> .Map </store>
    +              </T>
    +
    +

    Recall that $PGM is where the program is placed by krun after parsing. So +the program execution starts with an empty environment and an empty store.

    +

    In environment-based definitions of lambda-calculi, lambda abstractions +evaluate to so-called closures:

    +
    rule <k> lambda X:Id . E => closure(Rho,X,E) ...</k>
    +     <env> Rho </env>
    +
    +

    A closure is like a lambda abstraction, but it also holds the environment +in which it was declared. This way, when invoked, a closure knows where to +find in the store the values of all the variables that its body expression +refers to. We will define the lookup rule shortly.

    +

    Therefore, unlike in the substitution-based definitions of LAMBDA and +LAMBDA++, neither the lambda abstractions nor the identifiers are values +anymore here, because they both evaluate further: lambda abstractions to +closures and identifiers to their values in the store. In fact, the only +values at this moment are the closures, and they are purely semantic entities, +which cannot be used explicitly in programs. That's why we modified the +original syntax of the language to include no Val syntactic category +anymore, and that's why we need to add closures as values now; same like +before, we add a Val syntactic category which is subsorted +to KResult. In general, whenever you have any strictness attributes, +your should also define some K results.

    +

    Invoking a closure is a bit more involved than the substitution-based +beta-reduction: we need to switch to the closure's environment, then create a +new, or fresh, binding for the closure's parameter to the value passed to the +closure, then evaluate the closure's body, and then switch back to the +caller's environment, which needs to be stored somewhere in the meanwhile. +We can do all these with one rule:

    +
    rule <k> closure(Rho,X,E) V:Val => E ~> Rho' ...</k>
    +     <env> Rho' => Rho[X <- !N] </env>
    +     <store>... .Map => (!N:Int |-> V) ...</store>
    +
    +

    Therefore, we atomically do all the following:

    +
      +
    • switch the computation to the closure's body, E, followed by a +caller-environment-recovery task Rho' (note that Rho' is the +current environment),
    • +
    • generate a fresh location !N (the ! is important, we discuss it below), +bind X to !N in closure's environment and switch the current environment +Rho' to that one,
    • +
    • write the value passed to the closure, V, at location !N.
    • +
    +

    This was the most complex K rule we've seen so far in the tutorial. Note, +however, that this one rule achieves a lot. It is, in fact, quite compact +considering how much it does. Note also that everything that this K rule +mentions is needed also conceptually in order to achieve this task, so it +is minimal from that point of view. That would not be the case if we +used, instead, a conventional rewrite rule, because we would have had to +mention the remaining store, say Sigma, in both sides of the rule, to say +it stays unchanged. Here we just use ....

    +

    The declaration of the fresh variable above, !N, is new and needs +some explanation. First, note that !N appears only in the right-hand-side +terms in the rule, that is, it is not matched when the rule is applied. +Instead, a fresh Nat element is generated each time the rule is applied. +In K, we can define syntactic categories which have the capability to +generate fresh elements like above, using unbound variables whose name starts +with a !. The details of how to do that are beyond the scope of this +tutorial (see Tutorial 6). All we need to know here is that an arbitrary +fresh element of that syntactic category is generated each time the rule +is applied. We cannot rely on the particular name or value of the generated +element, because that can change with the next version of the K tool, or +even from execution to execution with the same version. All you can rely +on is that each newly generated element is distinct from the previously +generated elements for the same syntactic category.

    +

    Unlike in the substitution-based definition, we now also need a lookup rule:

    +
    rule <k> X => V ...</k>
    +     <env>... X |-> N ...</env>
    +     <store>... N |-> V ...</store>
    +
    +

    This rule speaks for itself: replace X by the value V located in the store +at X's location N in the current environment.

    +

    The only thing left to define is the auxiliary environment-recovery operation:

    +

    rule _:Val ~> (Rho => .) ... _ => Rho

    +

    When the item preceding the environment recovery task Rho in the +computation becomes a value, replace the current environment with Rho +and dissolve Rho from the computation.

    +

    Let us kompile and ... fail:

    +
    kompile lambda
    +
    +

    gives a parsing error saying that V:Val does not fit there in the closure +invocation rule. That's because Val and Exp are currently completely +disconnected, so K rightfully complains that we want to apply a value to +another one, because application was defined to work with expressions, not +values. What we forgot here was to state that Exp includes Val:

    +
    syntax Exp ::= Val
    +
    +

    Now everything works, but it is a good time to reflect a bit.

    +

    So we added closures, which are inherently semantic entities, to the syntax +of expressions. Does that mean that we can now write LAMBDA programs with +closures in them? Interestingly, with our current definition of LAMBDA, +which purposely did not follow the nice organization of IMP into syntax and +semantic modules, and with K's default parser, kast, you can. But you are +not supposed to speculate this! In fact, if you use an external parser, that +parser will reject programs with explicit closures. Also, if we split the +LAMBDA definition into two modules, one called LAMBDA-SYNTAX containing +exclusively the desired program syntax and one called LAMBDA importing the +former and defining the syntax of the auxiliary operations and the semantics, +then even K's default parser will reject programs using auxiliary syntactic +constructs.

    +

    Indeed, when you kompile a language, say lang.k, the tool will by default +attempt to find a module LANG-SYNTAX and generate the program parser from +that. If it cannot find it, then it will use the module LANG instead. There +are also ways to tell kompile precisely which syntax module you want to use +for the program parser if you don't like the default convention. +See kompile --help.

    +

    Another insightful thought to reflect upon, is the relationship between your +language's values and other syntactic categories. It is often the case that +values form a subset of the original language syntax, like in IMP (Part 2 of +the tutorial), but sometimes that is not true, like in our case here. When +that happens, in order for the semantics to be given smoothly and uniformly +using the original syntax, you need to extend your language's original +syntactic categories with the new values. The same holds true in other +semantic approaches, not only in K, even in ones which are considered purely +syntactic. As it should be clear by now, K does not enforce you to use a +purely syntactic style in your definitions; nevertheless, K does allow you to +develop purely syntactic definitions, like LAMBDA in Part 1 of the tutorial, +if you prefer those.

    +

    krun some programs, such as those provided in Lesson 1 of the LAMBDA +tutorial (Part 1). Note the closures, both as results in the <k/> cell, +and as values in the store. Also, since variables are not values anymore, +expressions that contain free variables may get stuck with one of those on +top of their computation. See, for example, free-variable-capture.lambda, +which gets stuck on z, because z is free, so it cannot evaluate it. +If you want, you can go ahead and manually provide a configuration with +z mapped to some location in the environment and that location mapped to +some value in the store, and then you can also execute this program. The +program omega.lambda should still loop.

    +

    Although we completely changed the definitional style of LAMBDA, the semantics +of the other constructs do not need to change, as seen in the next lesson.

    +

    Go to Lesson 3, LAMBDA++: Reusing Existing Semantics.

    +

    MOVIE (out of date) [8'02"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_3/NOTES/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_3/NOTES/index.html new file mode 100644 index 00000000000..2f6cdf35d0d --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_3/NOTES/index.html @@ -0,0 +1,393 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +
      +
    • Cut-and-paste is a poor-man's approach to reuse.
    • +
    +

    Indeed, it is. A better way to reuse, which requires a bit of planning ahead, +is to put each feature in its own module. Then you can simply include the +modules containing the features you want to reuse. Our point in this lesson +was that such reuse is possible, not to teach the best way to do it in +practice. Good methodologies on how to use a technology are equally important.

    +
      +
    • Do we need an env/store split? Couldn't we just work with a state?
    • +
    +

    Since in our language so far we never change the value of a variable, it +happens to be OK to only keep a state. That is, to collapse env/store into +state, then embed the state in closures and restore the state instead of the +environment. However, this simplistic approach breaks as soon as we add +references to our language, because functions can then modify the environment +in which they were declared, so we would have to carry over those changes when +returning from function invocations, which would be quite difficult.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_3/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_3/index.html new file mode 100644 index 00000000000..c67782ab08a --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_3/index.html @@ -0,0 +1,408 @@ + + + + + + + + + + + + + + +Reusing Existing Semantics | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Reusing Existing Semantics

    +

    In this lesson we will learn that, in some cases, we can reuse existing +semantics of language features without having to make any change!

    +

    Although the definitional style of the basic LAMBDA language changed quite +radically in our previous lesson, compared to its original definition in +Part 1 of the tutorial, we fortunately can reuse a large portion of the +previous definition. For example, let us just cut-and-paste the rest of the +definition from Lesson 7 in Part 1 of the tutorial.

    +

    Let us kompile and krun all the remaining programs from Part 1 of the +tutorial. Everything should work fine, although the store contains lots of +garbage. Garbage collection is an interesting topic, but we do not do it +here. Nevertheless, much of this garbage is caused by the intricate use of +the fixed-point combinator to define recursion. In a future lesson in this +tutorial we will see that a different, environment-based definition of +fixed-points will allocate much less memory.

    +

    One interesting question at this stage is: how do we know when we can reuse +an existing semantics of a language feature? Well, I'm afraid the answer is: +we don't. In the next lesson we will learn how reuse can fail for quite subtle +reasons, which are impossible to detect statically (and some non-experts may +fail to even detect them at all).

    +

    Go to Lesson 4, LAMBDA++: Do Not Reuse Blindly!.

    +

    MOVIE (out of date) [3'21"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_4/NOTES/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_4/NOTES/index.html new file mode 100644 index 00000000000..2894ddd91a7 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_4/NOTES/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    With the current version of the tool (as of Sept 12, 2013), the +callcc-env1.lambda program actually evaluates to 4, as expected. +But the comments in the README are still valid, because it could just as +well evaluate to 3. For example, just replace ...+x with x+..., and it +should evaluate to 3 now.

    +

    Also, the first "fix" suggested in the READMEm to make "+" seqstrict, only +works for that particular program. It does not fix the problem if we change +the program as indicated above. In that case "+" it would need to be +seqstrict(2,1).

    +

    Also, callcc-env2.lambda evaluates to 3 instead of 4, because of the +particular order in which the strictness of the application operation is +applied. If you make application seqstrict(2,1) then you get 4.

    +

    Dec 06, 2014: Looks like we should discuss the --search and --transition +options before this lesson, and then kompile the definition with option +--transition = computational and krun it with --search.

    +

    The README.md says "One is to make + seqstrict in the semantics, to +enforce its evaluation from left-to-right. Do it and then run the program +above again;". Then it continues and says "The problem is now the +non-deterministic evaluation strategy of the function application construct". +Grigore will add this as an exercise, asking reader to fix this +non-determinism. Then ask them to propose another example where you still get +non-determinism; can they?

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_4/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_4/index.html new file mode 100644 index 00000000000..074a5b41d34 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_4/index.html @@ -0,0 +1,469 @@ + + + + + + + + + + + + + + +Do Not Reuse Blindly! | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Do Not Reuse Blindly!

    +

    It may be tempting to base your decision to reuse an existing semantics of +a language feature solely on syntactic considerations; for example, to reuse +whenever the parser does not complain. As seen in this lesson, this could +be quite risky.

    +

    Let's try (and fail) to reuse the definition of callcc from Lesson 1:

    +
    syntax Exp ::= "callcc" Exp  [strict]
    +syntax Val ::= cc(K)
    +rule <k> (callcc V:Val => V cc(K)) ~> K </k>
    +rule <k> cc(K) V ~> _ =>  V ~> K </k>
    +
    +

    The callcc examples that we tried in Lesson 1 work, so it may look it works.

    +

    However, the problem is that cc(K) should also include an environment, +and that environment should also be restored when cc(K) is invoked. +Let's try to illustrate this bug with callcc-env1.lambda

    +
    let x = 1 in
    +  ((callcc lambda k . (let x = 2 in (k x))) + x)
    +
    +

    where the second argument of +, x, should be bound to the top x, which +is 1. However, since callcc does not restore the environment, that x +should be looked up in the wrong, callcc-inner environment, so we should see +the overall result 4.

    +

    Hm, we get the right result, 3 ... (Note: you may get 4, depending on +your version of K and platform; but both 3 and 4 are possible results, as +explained below and seen in the tests). How can we get 3? Well, recall that ++ is strict, which means that it can evaluate its arguments in any order. +It just happened that in the execution that took place above its second +argument was evaluated first, to 1, and then the callcc was evaluated, but +its cc value K had already included the 1 instead of x ... In Part 4 of +the tutorial we will see how to explore all the non-deterministic behaviors of +a program; we could use that feature of K to debug semantics, too. +For example, in this case, we could search for all behaviors of this program +and we would indeed get two possible value results: 3 and 4.

    +

    One may think that the problem is the non-deterministic evaluation order +of +, and thus that all we need to do is to enforce a deterministic order +in which the arguments of + are evaluated. Let us follow this path to +see what happens. There are two simple ways to make the evaluation order +of +'s arguments deterministic. One is to make + seqstrict in the +semantics, to enforce its evaluation from left-to-right. Do it and then +run the program above again; you should get only one behavior for the +program above, 4, which therefore shows that copying-and-pasting our old +definition of callcc was incorrect. However, as seen shortly, that only +fixed the problem for the particular example above, but not in general. +Another conventional approach to enforce the desired evaluation order is to +modify the program to enforce the left-to-right evaluation order using let +binders, as we do in callcc-env2.lambda:

    +
    let x = 1 in
    +  let a = callcc lambda k . (let x = 2 in (k x)) in
    +    let b = x in
    +      (a + b)
    +
    +

    With your installation of K you may get the "expected" result 4 when you +execute this program, so it may look like our non-deterministic problem is +fixed. Unfortunately, it is not. Using the K tool to search for all the +behaviors in the program above reveals that the final result 3 is still +possible. Moreover, both the 3 and the 4 behaviors are possible regardless +of whether + is declared to be seqstrict or just strict. How is that +possible? The problem is now the non-deterministic evaluation strategy of +the function application construct. Indeed, recall that the semantics of +the let-in construct is defined by desugaring to lambda application:

    +
    rule let X = E in E' => (lambda X . E') E
    +
    +

    With this, the program above eventually reduces to

    +
    (lambda a . ((lambda b . a + b) x))
    +(callcc lambda k . (let x = 2 in (k x)))
    +
    +

    in an environment where x is 1. If the first expression evaluates first, +then it does so to a closure in which x is bound to a location holding 1, +so when applied later on to the x inside the argument of callcc (which is +2), it will correctly lookup x in its enclosed environment and thus the +program will evaluate to 3. On the other hand, if the second expression +evaluates first, then the cc value will freeze the first expression as is, +breaking the relationship between its x and the current environment in which +it is bound to 1, being inadvertently captured by the environment of the +let-in construct inside the callcc and thus making the entire expression +evaluate to 4.

    +

    So the morale is: Do not reuse blindly. Think!

    +

    In the next lesson we fix the environment-based semantics of callcc by having +cc also wrap an environment, besides a computation. We will also give a more +direct semantics to recursion, based on environments instead of fixed-point +combinators.

    +

    Go to Lesson 5, LAMBDA++: More Semantic Computation Items.

    +

    MOVIE (out of date) [3'37"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_5/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_5/index.html new file mode 100644 index 00000000000..64046cbbe3a --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_5/index.html @@ -0,0 +1,444 @@ + + + + + + + + + + + + + + +More Semantic Computation Items | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    More Semantic Computation Items

    +

    In this lesson we see more examples of semantic (i.e., non-syntactic) +computational items, and how useful they can be. Specifically, we fix the +environment-based definition of callcc and give an environment-based +definition of the mu construct for recursion.

    +

    Let us first fix callcc. As discussed in Lesson 4, the problem that we +noticed there was that we only recovered the computation, but not the +environment, when a value was passed to the current continuation. This is +quite easy to fix: we modify cc to take both an environment and a +computation, and its rules to take a snapshot of the current environment with +it, and to recover it at invocation time:

    +
    syntax Val ::= cc(Map,K)
    +rule <k> (callcc V:Val => V cc(Rho,K)) ~> K </k> <env> Rho </env>
    +rule <k> cc(Rho,K) V:Val ~> _ =>  V ~> K </k> <env> _ => Rho </env>
    +
    +

    Let us kompile and make sure it works with the callcc-env2.lambda program, +which should evaluate to 3, not to 4.

    +

    Note that the cc value, which can be used as a computation item in the <k/> +cell, is now quite semantic in nature, pretty much the same as the closures.

    +

    Let us next add one more closure-like semantic computational item, for mu. +But before that, let us reuse the semantics of letrec in terms of mu that +was defined in Lesson 8 of Part 1 of the tutorial on LAMBDA:

    +
    syntax Exp ::= "letrec" Id Id "=" Exp "in" Exp [macro]
    +             | "mu" Id "." Exp                 [latex(\mu{#1}.{#2})]
    +rule letrec F:Id X = E in E' => let F = mu F . lambda X . E in E'
    +
    +

    We removed the binder annotation of mu, because it is not necessary +anymore (since we do not work with substitutions anymore).

    +

    To save the number of locations needed to evaluate mu X . E, let us replace +it with a special closure which already binds X to a fresh location holding +the closure itself:

    +
    syntax Exp ::= muclosure(Map,Exp)
    +
    +rule <k> mu X . E => muclosure(Rho[X <- !N], E) ...</k>
    +     <env> Rho </env>
    +     <store>... .Map => (!N:Int |-> muclosure(Rho[X <- !N], E)) ...</store>
    +
    +

    Since each time mu X . E is encountered during the evaluation it needs to +evaluate E, we conclude that muclosure cannot be a value. We can declare +it as either an expression or as a computation. Let's go with the former.

    +

    Finally, here is the rule unrolling the muclosure:

    +

    rule muclosure(Rho,E) => E ~> Rho' ... + Rho' => Rho

    +

    Note that the current environment Rho' needs to be saved before and +restored after E is executed, because the fixed point may be invoked +from a context with a completely different environment from the one +in which mu X . E was declared.

    +

    We are done. Let us now kompile and krun factorial-letrec.lambda from +Lesson 7 in Part 1 of the tutorial on LAMBDA. Recall that in the previous +lesson this program generated a lot of garbage into the store, due to the +need to allocate space for the arguments of all those lambda abstractions +needed to run the fixed-point combinator. Now we need much fewer locations, +essentially only locations for the argument of the factorial function, one at +each recursive call. Anyway, much better than before.

    +

    In the next lesson we wrap up the environment definition of LAMBDA++ and +generate its documentation.

    +

    Go to Lesson 6, LAMBDA++: Wrapping Up and Documenting LAMBDA++.

    +

    MOVIE (out of date) [5'19"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/NOTES/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/NOTES/index.html new file mode 100644 index 00000000000..a59838774ae --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/NOTES/index.html @@ -0,0 +1,378 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Maybe we should change the name of calCC, as it is not a good idea to have +two constructs with different semantics but names which cannot be distinguished +easily.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/callCC/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/callCC/index.html new file mode 100644 index 00000000000..e15b933b0b9 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/callCC/index.html @@ -0,0 +1,379 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    (see similar exercise in Lesson 1, with substitution instead of environments)

    +

    Define a variant of callcc, say callCC, which never returns to the +current context unless a value is specifically passed to its argument +continuation. Follow an environment-based style.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/from-call-CC-to-callcc/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/from-call-CC-to-callcc/index.html new file mode 100644 index 00000000000..326c255da15 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/from-call-CC-to-callcc/index.html @@ -0,0 +1,377 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Define callcc in terms of callCC, where callCC is explained in the +callCC exercise under LAMBDA++, Lesson 1. Follow an environment-based style.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/from-callcc-to-call-CC/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/from-callcc-to-call-CC/index.html new file mode 100644 index 00000000000..997c2fc9535 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/exercises/from-callcc-to-call-CC/index.html @@ -0,0 +1,378 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Define callCC in terms of callcc, where callCC is explained in the +callCC exercise under LAMBDA++, Lesson 1. Follow an environment-based +style.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/index.html new file mode 100644 index 00000000000..71c70c7b47b --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/index.html @@ -0,0 +1,394 @@ + + + + + + + + + + + + + + +Wrapping Up and Documenting LAMBDA++ | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Wrapping Up and Documenting LAMBDA++

    +

    In this lesson we wrap up and nicely document LAMBDA++. In doing so, we also +take the freedom to reorganize the semantics a bit, to make it look better.

    +

    See the lambda.k file, which is self-explanatory.

    +

    Part 3 of the tutorial is now complete. Part 4 will teach you more features +of the K framework, in particular how to exhaustively explore the behaviors +of non-deterministic or concurrent programs.

    +

    MOVIE (out of date) [6'23"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/lambda/index.html b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/lambda/index.html new file mode 100644 index 00000000000..9206d1fc032 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/lambda/index.html @@ -0,0 +1,542 @@ + + + + + + + + + + + + + + +Tutorial 3--- LAMBDA++ | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Tutorial 3--- LAMBDA++

    +

    Author: Grigore Roșu (grosu@illinois.edu)
    +Organization: University of Illinois at Urbana-Champaign

    +

    Abstract

    +

    This file contains an environment-based K semantic definition of LAMBDA++, an +extension of the LAMBDA language (defined in Tutorial 1) with a callcc +construct. The objective here is to further disseminate some of the features +of the K framework, in particular to illustrate how popular environment-based +and closure-based semantics can be defined in K.

    +

    For notational/kompilation/krun simplicity and to avoid OS errors, we continue +to write LAMBDA and lambda as names for modules and program extensions, +respectively, in the sequel.

    +

    To restrict the default program parser invoked by krun, namely kast, +to only parse proper LAMBDA++ programs no matter what other syntactic +constructs we add to Exp later on in the semantics, we put the actual program +syntax in a module with the suffix -SYNTAX. This issue was discussed in more +detail in Lesson 2 of this tutorial. In short, the parser generated by kompile +to be used by kast will be by default built only based on the syntax in this +module. Type kompile --help to see how to tell the parser which syntax to use.

    +
    k
    module LAMBDA-SYNTAX + imports DOMAINS-SYNTAX +
    +

    Syntax

    +

    We move all the LAMBDA++ syntax here.

    +
    k
    syntax Val ::= Int | Bool + syntax Exp ::= Val +// Basic lambda-calculus syntax + | Id + | "lambda" Id "." Exp [latex(\lambda{#1}.{#2})] + | Exp Exp [strict, left] + | "(" Exp ")" [bracket] +// Arithmetic + > "-" Int + | Exp "*" Exp [strict, left] + | Exp "/" Exp [strict] + > Exp "+" Exp [strict, left] + > Exp "<=" Exp [strict] +// Other functional constructs + syntax Exp ::= "if" Exp "then" Exp "else" Exp [strict(1)] // Conditional + | "let" Id "=" Exp "in" Exp [macro] // Let binder + | "letrec" Id Id "=" Exp "in" Exp [macro] // Letrec + | "mu" Id "." Exp [latex(\mu{#1}.{#2})] // Mu + | "callcc" Exp [strict] // Callcc +
    +

    One thing you may want to do, now that the entire syntax is in one +place, is to play with precedences. This way, you can make kompile +generate the parser you want for your programs, so that you won't have to +put lots of parentheses in your programs.

    +
    k
    endmodule + + +module LAMBDA + imports LAMBDA-SYNTAX + imports DOMAINS +
    +

    Semantics

    +

    The next module contains the semantics of all the LAMBDA++ constructs, +in the order in which their syntax was declared above.

    +

    The K Results

    +

    We should not forget to define the results of our computations. +Here is a rule of thumb: whenever you have any strictness attributes, your +should also define some K results. Or even simpler: always define your +results! (unless you define a theoretical semantics, for analysis but not +for execution purposes, you will need to define your results)

    +
    k
    syntax KResult ::= Val +
    +

    Configuration

    +

    Since LAMBDA++ is such a simple language, its configuration is minimal +for an environment-based semantics: it only contains the k cell, +an environment cell, and a store cell. An environment binds variable names +to locations, and a store binds locations to values.

    +
    k
    configuration <T color="yellow"> + <k color="green"> $PGM:Exp </k> + <env color="blue"> .Map </env> + <store color="red"> .Map </store> + </T> +
    +

    Recall that $PGM is where the program is placed by krun after parsing.

    +

    Closures

    +

    In environment-based definitions of lambda-calculi, λ-abstractions +evaluate to closures. A closure is like a λ-abstraction, +but it also holds the environment in which it was declared. This way, when +invoked, a closure knows where to find in the store the values of all the +variables that its body expression refers to. +To invoke a closure, we need to switch to closure's environment, then create +a new binding for closure's parameter, then evaluate the closure's body, and +then switch back to caller's environment.

    +
    k
    syntax Val ::= closure(Map,Id,Exp) + [latex(\textsf{closure}_\lambda({#1},{#2},{#3}))] + + rule <k> lambda X:Id . E => closure(Rho,X,E) ...</k> + <env> Rho </env> + rule <k> closure(Rho,X,E) V:Val => E ~> Rho' ...</k> + <env> Rho' => Rho[X <- !N] </env> + <store>... .Map => (!N:Int |-> V) ...</store> + rule <k> X => V ...</k> + <env>... X |-> N ...</env> + <store>... N |-> V ...</store> +
    +

    Environment Recovery

    +

    The environment-recovery computation item defined below is useful in many +semantics, like it was above. It is so useful, that there are discussions +in the K team to add it to the set of pre-defined K features.

    +
    k
    rule <k> _:Val ~> (Rho => .) ...</k> <env> _ => Rho </env> +
    +

    Arithmetic Constructs

    +

    Not much to say here. They have exactly the same semantics as in LAMBDA and +IMP. Note that we let it in programmer's hands to check that the denominator +of a division is different from zero. If a division-by-zero is issued, then +completely non-deterministic result can happen depending upon what back-end +one uses for the K tool. Currently, Maude is used and Maude gets stuck +with a term of the form I /Int 0, but one should not rely on that. +If you want to catch division-by-zero in the semantics, instead of letting +the back-end do whatever it wants, you should add a side condition to the +division rule.

    +
    k
    rule - I => 0 -Int I + rule I1 * I2 => I1 *Int I2 + rule I1 / I2 => I1 /Int I2 + rule I1 + I2 => I1 +Int I2 + rule I1 <= I2 => I1 <=Int I2 +
    +

    Conditional

    +
    k
    rule if true then E else _ => E + rule if false then _ else E => E +
    +

    Let Binder

    +
    k
    rule let X = E in E':Exp => (lambda X . E') E +
    +

    Letrec Binder

    +

    We define letrec in term of mu, whose semantics is below.

    +
    k
    rule letrec F:Id X = E in E' => let F = mu F . lambda X . E in E' +
    +

    Mu

    +

    To save the number of locations needed to evaluate μ X . E, we replace it +with a special closure which binds X to a fresh location holding the closure +itself. This has the same effect as binding X to a reference that points +back to the fixed-point.

    +
    k
    syntax Exp ::= muclosure(Map,Exp) + [latex(\textsf{closure}_\mu({#1},{#2}))] + rule <k> mu X . E => muclosure(Rho[X <- !N], E) ...</k> + <env> Rho </env> + <store>... .Map => (!N:Int |-> muclosure(Rho[X <- !N], E)) ...</store> + rule <k> muclosure(Rho,E) => E ~> Rho' ...</k> + <env> Rho' => Rho </env> +
    +

    Callcc

    +

    For callcc, we need to create a new closure-like value which +wraps both the remaining computation, and the environment in which it is +supposed to be executed. Forget the environment, and you get a wrong +callcc.

    +
    k
    syntax Val ::= cc(Map,K) + [latex(\textsf{closure}_{\texttt{callcc}}({#1},{#2}))] + rule <k> (callcc V:Val => V cc(Rho,K)) ~> K </k> <env> Rho </env> + rule <k> cc(Rho,K) V:Val ~> _ => V ~> K </k> <env> _ => Rho </env> +endmodule +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/4_imp++/index.html b/k-distribution/pl-tutorial/1_k/4_imp++/index.html new file mode 100644 index 00000000000..ad89bf0029d --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/4_imp++/index.html @@ -0,0 +1,408 @@ + + + + + + + + + + + + + + +Part 4: Defining IMP++ | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Part 4: Defining IMP++

    +

    IMP++ extends IMP, which was discussed in Part 2 of this tutorial, with several +new syntactic constructs. Also, some existing syntax is generalized, which +requires non-modular changes of the existing IMP semantics. For example, +global variable declarations become local declarations and can occur +anywhere a statement can occur. In this tutorial we will learn the following:

    +
      +
    • That (and how) existing syntax/semantics may change as a language evolves.
    • +
    • How to refine configurations as a language evolves.
    • +
    • How to define and use fresh elements of desired sorts.
    • +
    • How to tag syntactic constructs and rules, and how to use such tags +with the superheat/supercool/transition options of kompile.
    • +
    • How the search option of krun works.
    • +
    • How to stream cells holding semantic lists to the standard input/output, +and thus obtain interactive interpreters for the defined languages.
    • +
    • How to delete, save and restore cell contents.
    • +
    • How to add/delete cells dynamically.
    • +
    • More details on how the configuration abstraction mechanism works.
    • +
    +

    Like in the previous tutorials, this folder contains several lessons, each +adding new features to IMP++. Do them in order and make sure you completed +and understood the previous tutorials.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/4_imp++/lesson_1/NOTES/index.html b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_1/NOTES/index.html new file mode 100644 index 00000000000..75bf23aa823 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_1/NOTES/index.html @@ -0,0 +1,381 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Add an exercise somewhere with a print which first evaluates all its arguments +and THEN prints them. The idea is to define print to be strict and to +make the AExps list construct seqstrict, so lists of arithmetic +expressions get evaluated from left-to-right whenever they reach the top of +the <k/> cell (replace seqstrict with strict if you want expressions in +a list to evaluate non-deterministically and interleaved).

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/4_imp++/lesson_1/index.html b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_1/index.html new file mode 100644 index 00000000000..32167ca5626 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_1/index.html @@ -0,0 +1,465 @@ + + + + + + + + + + + + + + +Extending/Changing an Existing Language Syntax | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Extending/Changing an Existing Language Syntax

    +

    Here we learn how to extend the syntax of an existing language, both with +new syntactic constructs and with more general uses of existing constructs. +The latter, in particular, requires changes of the existing semantics.

    +

    Consider the IMP language, as defined in Lesson 4 of Part 2 of the tutorial.

    +

    Let us first add the new syntactic constructs, with their precedences:

    +
      +
    • variable increment, ++, which increments an integer variable and +evaluates to the new value;
    • +
    • read, which reads and evaluates to a new integer from the input buffer;
    • +
    • print, which takes a comma-separated list of arithmetic expressions and +evaluates and prints each of them in order, from left to right, to the +output buffer; we therefore define a new list syntactic category, AExps, +which we pass as an argument to print; note we do not want to declare +print to be strict, because we do not want to first evaluate the +arguments and then print them (for example, if the second argument performs +an illegal operation, say division by zero, we still want to print the first +argument); we also go ahead and add strings as arithmetic expressions, +because we intend print to also take strings, in order to print nice +messages to the user;
    • +
    • halt, which abruptly terminates the program; and
    • +
    • spawn, which takes a statement and creates a new concurrent thread +executing it and sharing its environment with the parent thread.
    • +
    +

    Also, we want to allow local variable declarations, which can appear anywhere +a statement can appear. Their scope ranges from the place they are defined +until the end of the current block, and they can shadow previous declarations, +both inside and outside the current block. The simplest way to define the +syntax of the new variable declarations is as ordinary statements, at the same +time removing the previous Pgm syntactic category and its construct. +Programs are now just statements.

    +

    We are now done with adding the new syntax and modifying the old one. +Note that the old syntax was modified in a way which makes the previous IMP +programs still parse, but this time as statements. Let us then modify +the configuration variable $PGM to have the sort Stmt instead of Pgm, +and let us try to run the old IMP programs, for example sum.imp.

    +

    Note that they actually get stuck with the global declaration on the top +of their computations. This is because variable declarations are now treated +like any statements, in particular, the sequential composition rule applies. +This makes the old IMP rule for global variable declarations not match anymore. +We can easily fix it by replacing the anonymous variable _, which matched +the program's statement that now turned into the remaining computation in +the <k/> cell, with the cell frame variable ..., which matches the +remaining computation. Similarly, we have to change the rule for the case +where there are no variables left to declare into one that dissolves itself.

    +

    We can now run all the previous IMP programs, in spite of the fact that +our IMP++ semantics is incomplete and, more interestingly, in spite of the +fact that our current semantics of blocks is incorrect in what regards the +semantics of local variable declarations (note that the old IMP programs do +not declare block-local variables, which is why they still run correctly).

    +

    Let us also write some proper IMP++ programs, which we would like to execute +once we give semantics to the new constructs.

    +

    div.imp is a program manifesting non-deterministic behaviors due to the +desired non-deterministic evaluation strategy of division and the fact that +expressions will have side effects once we add variable increment. We will +be able to see all the different behaviors of this program. Challenge: can +you identify the behavior where the program performs a division-by-zero?

    +

    If we run div.imp now, it will get stuck with the variable increment +construct on top of the computation cell. Once we give it a semantics, +div.imp will execute completely (all the other constructs in div.imp +already have their semantics defined as part of IMP).

    +

    Note that some people prefer to define all their semantics in a by need +style, that is, they first write and parse lots of programs, and then they +add semantics to each language construct on which any of the programs gets +stuck, and so on and so forth until they can run all the programs.

    +

    io.imp is a program which exercises the input/output capabilities of the +language: reads two integers and prints three strings and an integer. +Note that the variable declaration is not the first statement anymore.

    +

    sum-io.imp is an interactive variant of the sum program.

    +

    spawn.imp is a program which dynamically creates two threads that interact +with the main thread via the shared variable x. Lots of behaviors will be +seen here once we give spawn the right semantics.

    +

    Finally, locals.imp tests whether variable shadowing/unshadowing works well.

    +

    In the next lesson we will prepare the configuration for the new constructs, +and will see what it takes to adapt the semantics to the new configuration. +Specifically, we will split the state cell into an environment cell and a +store cell, like in LAMBDA++ in Part 3 of the tutorial.

    +

    Go to Lesson 2, IMP++: Configuration Refinement; Freshness.

    +

    MOVIE (out of date) [07'47"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/4_imp++/lesson_2/NOTES/index.html b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_2/NOTES/index.html new file mode 100644 index 00000000000..b96be5d63b3 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_2/NOTES/index.html @@ -0,0 +1,376 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    update discussion on fresh; it has already been explained in lambda++

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/4_imp++/lesson_2/index.html b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_2/index.html new file mode 100644 index 00000000000..e86f57dec66 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_2/index.html @@ -0,0 +1,447 @@ + + + + + + + + + + + + + + +Configuration Refinement; Freshness | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Configuration Refinement; Freshness

    +

    To prepare for the semantics of threads and local variables, in this lesson we +split the state cell into an environment and a store. The environment and +the store will be similar to those in the definition of LAMBDA++ in Part +3 of the Tutorial. This configuration refinement will require us to change +some of IMP's rules, namely those that used the state.

    +

    To split the state map, which binds program variables to values, into an +environment mapping program variables to locations and a store mapping +locations to values, we replace in the configuration declaration the cell

    +
    <state color="red"> .Map </state>
    +
    +

    with two cells

    +
    <env color="LightSkyBlue"> .Map </env>
    +<store color="red"> .Map </store>
    +
    +

    Structurally speaking, this split of a cell into other cells is a major +semantic change, which, unfortunately, requires us to revisit the existing +rules that used the state cell. One could, of course, argue that we could +have avoided this problem if we had followed from the very beginning the +good-practice style to work with an environment and a store, instead of a +monolithic state. While that is a valid argument, highlighting the fact that +modularity is not only a feature of the framework alone, but one should also +follow good practices to achieve it, it is also true that if all we wanted +in Part 2 of the tutorial was to define IMP as is, then the split of the state +in an environment and a store is unnecessary and not really justified.

    +

    The first rule which used a state cell is the lookup rule:

    +
    rule <k> X:Id => I ...</k> <state>... X |-> I ...</state>
    +
    +

    We modify it as follows:

    +
    rule <k> X:Id => I ...</k>
    +     <env>... X |-> N ...</env>
    +     <store>... N |-> I ...</store>
    +
    +

    So we first match the location N of X in the environment, then the value +I at location N in the store, and finally we rewrite X to I into the +computation. This rule also shows an instance of a more complex +multiset matching, where two variables (X and N) are matched each twice.

    +

    The assignment rule is modified quite similarly.

    +

    The variable declaration rule is trickier, though, because we need to allocate +a fresh location in the store and bind the newly declared variable to it. +This is quite similar to the way we allocated space for variables in +the environment-based definition of LAMBDA++ in Part 3 of the tutorial.

    +
    rule <k> int (X,Xs => Xs); ...</k>
    +     <env> Rho => Rho[X <- !N:Int] </env>
    +     <store>... .Map => !N |-> 0 ...</store>
    +
    +

    Note the use of the fresh (!N) variable notation above. Recall from +the LAMBDA++ tutorial that each time the rule with fresh (!) variables is +applied, fresh elements of corresponding sorts are generated for the fresh +variables, distinct from all the previously generated elements; also, we +cannot and should not assume anything about the particular element that is +being generated, except that it is different from the previous ones.

    +

    kompile and krun sum.imp to see how the fresh locations have been +generated and used. There were two fresh locations needed, for the two +variables. Note also that a cell holding the counter has been added to the +configuration.

    +

    In the next lesson we will add the semantics of variable increment, and see +how that yields non-deterministic behaviors in programs and how to explore +those behaviors using the K tool.

    +

    Go to Lesson 3, IMP++: Tagging; Superheat/Supercool Kompilation Options.

    +

    MOVIE (out of date) [04'06"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/4_imp++/lesson_3/NOTES/index.html b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_3/NOTES/index.html new file mode 100644 index 00000000000..c868e31887e --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_3/NOTES/index.html @@ -0,0 +1,377 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    We eliminated the superheat/supercool optimization. Now we only need to use +the transition option. So the video is out of synch now.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/4_imp++/lesson_3/index.html b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_3/index.html new file mode 100644 index 00000000000..13d42c3890c --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_3/index.html @@ -0,0 +1,492 @@ + + + + + + + + + + + + + + +Tagging; Transition Kompilation Option | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Tagging; Transition Kompilation Option

    +

    In this lesson we add the semantics of variable increment. In doing so, we +learn how to tag syntactic constructs and rules and then use such tags to +instruct the kompile tool to generate the desired language model that is +amenable for exhaustive analysis.

    +

    The variable increment rule is self-explanatory:

    +
    rule <k> ++X => I +Int 1 ...</k>
    +     <env>... X |-> N ...</env>
    +     <store>... N |-> (I => I +Int 1) ...</store>
    +
    +

    We can now run programs like our div.imp program introduced in Lesson 1. +Do it.

    +

    The addition of increment makes the evaluation of expressions have side +effects. That, in combination with the non-determinism allowed by the +strictness attributes in how expression constructs evaluate their +arguments, makes expressions in particular and programs in general have +non-deterministic behaviors. One possible execution of the div.imp program +assigns 1 to y's location, for example, but this program manifests several +other behaviors, too.

    +

    To see all the (final-state) behaviors that a program can have, you can call +the krun tool with the option --search. For example:

    +
    krun div.imp --search
    +
    +

    Oops, we see only one solution, the same as when we ran it without search.

    +

    Here is what happens. krun can only explore as much of the transition +system associated to a program as kompile allowed the generated language +model to yield. Since most of the K users are interested in language models +that execute efficiently, that is, in faster interpreters for the defined +languages, by default kompile optimizes the generated language model for +execution. In particular, it inserts no backtracking markers, which krun +uses when called with the --search option in order to systematically generate +the entire transition system associated to a program. This is why krun +showed us only one solution when run with the --search option on div.imp.

    +

    We next explain how to tell kompile what kind of language model we are +interested in for analysis purposes. When you experiment with non-determinism +in a language semantics, you should keep it in mind that the --transition +option of kompile allows you to configure what counts as a transition in +your language model. We here only discuss transitions due to the +non-deterministic evaluation strategies of language constructs, but we will +see in future lectures (see Lesson 6 of IMP++, where we add concurrency) that +we can also have transitions due to non-deterministic applications of rewrite +rules.

    +

    If you want to explore the entire behavior space due to non-deterministic +evaluation strategies, then you should include all the language constructs +in the --transition option. This may sound like the obvious thing to +always do, but as soon as you do it you soon realize that it is way too much +in practice when you deal with large languages or programs. There are simply +too many program behaviors to consider, and krun will likely hang +on you or crush. For example, a small ten-statement program where each +statement uses one strict expression construct already has 1000+ behaviors for +krun to explore! Driven by practical needs of its users, the K tool +therefore allows you to finely tune the generated language models using the +--transition option.

    +

    To state which constructs are to be considered to generate transitions in the +generated language model, and for other reasons, too, the K tool allows you to +tag any production and any rule by putting the tag in brackets. You can associate +multiple tags to the same construct or rule, and more than one construct or +rule can have the same tag. As an example, let us tag the division construct +with division, the lookup rule with lookup and the increment rule with +increment. The tags of the rules are not needed in this lesson, we do it only +to demonstrate that rules can also be tagged.

    +

    The least intrusive way to enforce our current language to explore the +entire space of behaviors due to the strictness of division is to kompile it +with the following option:

    +
    kompile imp.k --transition "division"
    +
    +

    It is interesting to note that the lookup and increment rules are the only +two rules which can trigger non-deterministic behaviors for division, because +no other rule but these two can ever apply while a division operation is +heated. Previous versions of K allowed you to also specify which rules could +trigger non-deterministic behaviors of operator evaluation strategies, +but that option was rarely used and is not available anymore.

    +

    Note that it is highly non-trivial to say precisely whether a strict language +construct may yield non-deterministic behaviors. For example, division's +strictness would yield no non-determinism if the language had no side effects. +It is even harder to say so for a particular program. Consequently, our K +implementation makes no attempt to automatically detect which operations +should be tagged as transitions. Instead, it provides the functionality to +let you decide it.

    +

    Now the command

    +
    krun div.imp --search
    +
    +

    shows us all five behaviors of this program. Interestingly, one +of the five behaviors yields a division by zero!

    +

    The --transition option can be quite useful when you experiment with your +language designs or when you formally analyze programs for certain kinds of +errors. Please let us know if you ever need more finer-grained control over +the non-determinism of your language models.

    +

    Before we conclude this lesson, we'd like to let you know one trick, which +you will hopefully not overuse: you can tag elements in your K definition with +kompile option names, and those elements will be automatically included in +their corresponding options. For example, if you tag the division production +with transition then the command

    +
    kompile imp
    +
    +

    is completely equivalent to the previous kompile command.

    +

    Please use this default behavior with caution, or even better, try to avoid +using it! You may be tempted to add the transition tag to lots of elements +and then forget about them; your language models will then be increasingly slower +when you execute them and you may wonder why ... This convention is typically +convenient when you want to quickly experiment with non-determinism and do not +want to bother inventing tag names and calling kompile with options.

    +

    In the next lesson we add input/output to our language and learn how to +generate a model of it which behaves like an interactive interpreter!

    +

    Go to Lesson 4, IMP++: Semantic Lists; Input/Output Streaming.

    +

    MOVIE (out of date) [06'56"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/4_imp++/lesson_4/NOTES/index.html b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_4/NOTES/index.html new file mode 100644 index 00000000000..5c02f2f4e7f --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_4/NOTES/index.html @@ -0,0 +1,382 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Make sure cells have the same indentation, which should use normal +spaces, not tabs. Tabs look differently in different editors.

    +

    The tests here include all the imp and imp++ programs, but of course +the imp ones do not display any output, so their .out files are empty. +But this way we at least make sure we test that these programs +do not fail/crash and that nothing is output, so it is better that what +we used to have in K3.6.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/4_imp++/lesson_4/index.html b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_4/index.html new file mode 100644 index 00000000000..c4a87de133f --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_4/index.html @@ -0,0 +1,484 @@ + + + + + + + + + + + + + + +Semantic Lists; Input/Output Streaming | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Semantic Lists; Input/Output Streaming

    +

    In this lesson we add semantics to the read and print IMP++ constructs. +In doing so, we also learn how to use semantic lists and how to connect +cells holding semantic lists to the standard input and standard output. +This allows us to turn the K semantics into an interactive interpreter.

    +

    We start by adding two new cells to the configuration,

    +
    <in color="magenta"> .List </in>
    +<out color="Orchid"> .List </out>
    +
    +

    each holding a semantic list, initially empty. Semantic lists are +space-separated sequences of items, each item being a term of the form +ListItem(t), where t is a term of sort K. Recall that the semantic maps, +which we use for states, environments, stores, etc., are sets of pairs +t1 |-> t2, where t1 and t2 are terms of sort K. The ListItem wrapper +is currently needed, to avoid parsing ambiguities.

    +

    Since we want the print statement to also print strings, we need to tell +K that strings are results. To make it more interesting, let us also overload +the + symbol on arithmetic expressions to also take strings and, as a +result, to concatenate them. Since + is already strict, we only need to add +a rule reducing the IMP addition of strings to the builtin operation +String +which concatenates two strings.

    +

    The semantics of read is immediate: read and consumes the first integer item +from the <in/> cell; note that our read only reads integer values (it gets +stuck if the first item in the <in/> cell is not an integer).

    +

    The semantics of print is a bit trickier. Recall that print takes an +arbitrary number of arithmetic expression arguments, and evaluates and outputs +each of them in order, from left to right. For example, +print("Hello", 3/0, "Bye"); outputs "Hello" and then gets stuck on the +illegal division by zero operation. In other words, we do not want it to +first evaluate all its arguments and then print them, because that would miss +outputting potentially valuable information. So the first step is to evaluate +the first argument of print. In some sense, what we'd like to say is that +print has the evaluation strategy strict(1). However, strictness +attributes only work with individual language constructs, while what we need +is an evaluation strategy that involves two constructs: print and the list +(comma) construct of AExps. If we naively associate print the strict(1) +evaluation strategy then its first and unique argument, an AExps list, will +be scheduled for evaluation and the execution will get stuck because we have +no rules for evaluating AExps terms. If we make the list construct of +AExps strict then we get the wrong semantics for print which first +evaluates all its arguments and then outputs them. The correct way to +tell K that print should evaluate only its first argument is by using a +context declaration:

    +
    context print(HOLE:AExp, _);
    +
    +

    Note the HOLE of sort AExp above. Contexts allow us to define finer-grain +evaluation strategies than the strictness attributes, involving potentially +more than one language construct, like above. The HOLE indicates the +argument which is requested to be evaluated. For example, the strict +attribute of division corresponds to two contexts:

    +
    context HOLE / _
    +context _ / HOLE
    +
    +

    In their full generality, contexts can be any terms with precisely one +occurrence of a HOLE, and with arbitrary side conditions on any variables +occurring in the context term as well as on the HOLE. See Part 6 of the +tutorial for more examples.

    +

    Once evaluated, the first argument of print is expected to become either an +integer or a string. Since we want to print both integers and string values, +to avoid writing two rules, one for each type of value, we instead add a new +syntactic category, Printable, which is the union of integers and strings.

    +

    Let us kompile and krun the io.imp program discussed in Lesson 1. As +expected, it gets stuck with a read construct on top of the computation and +with an empty <in/> cell. To run it, we need to provide some items in the +<in/> cell, so that the rule of read can match. Let us add

    +
    <in> ListItem(3) ListItem(5) ListItem(7) </in>
    +
    +

    Now, if we krun io.imp, we can see that its execution completes normally +(the <k/> cell is empty), that the first two items have been removed by the +two read constructs from the <in/> cell, and that the desired strings and +numbers have been placed into the <out/> cell.

    +

    Cells holding semantic lists can be connected to the standard input and +standard output buffers, and krun knows how to handle these appropriately. +Let us connect the <in/> cell to the standard input using the cell attribute +stream="stdin" and the <out/> cell to the standard output with the +attribute stream="sdtout". A cell connected to the standard input will +take its items from the standard input and block the rewriting process when +an input is needed until an item is available in the standard input buffer. +A cell connected to the standard output buffer will send all its items, in +order, to the standard output.

    +

    Let us kompile and krun io.imp again. It prints the message and then +waits for your input numbers. Type in two numbers, then press <Enter>. +A message with their sum is then printed, followed by the final configuration. +If you do not want to see the final configuration, and thus obtain a realistic +interpreter for our language, then call krun with the option --output none:

    +
    krun io.imp --output none
    +
    +

    Let us now krun our interactive sum program, which continuously reads numbers +from the console and prints the sum of numbers up to them:

    +
    krun sum-io.imp
    +
    +

    Try a few numbers, then 0. Note that the program terminated, but with junk +in the <k/> cell, essentially with a halt statement on its top. Of course, +because halt has been reached and it has no semantics yet.

    +

    In the next lesson we give the semantics of halt and also fix the semantics +of blocks with local variable declarations.

    +

    Go to Lesson 5, IMP++: Deleting, Saving and Restoring Cell Contents.

    +

    MOVIE (out of date) [05'21"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/4_imp++/lesson_5/index.html b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_5/index.html new file mode 100644 index 00000000000..f8bb75a91e3 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_5/index.html @@ -0,0 +1,434 @@ + + + + + + + + + + + + + + +Deleting, Saving and Restoring Cell Contents | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Deleting, Saving and Restoring Cell Contents

    +

    In this lesson we will see how easily we can delete, save and/or restore +contents of cells in order to achieve the desired semantics of language +constructs that involve abrupt changes of control or environments. We have +seen similar or related K features in the LAMBDA++ language in Part 3 of the +tutorial.

    +

    Let us start by adding semantics to the halt statement. As its name says, +what we want is to abruptly terminate the execution of the program. Moreover, +we want the program configuration to look as if the program terminated +normally, with an empty computation cell. The simplest way to achieve that is +to simply empty the computation cell when halt is encountered:

    +
    rule <k> halt; ~> _ => . </k>
    +
    +

    It is important to mention the entire <k/> cell here, with both its membranes +closed, to make sure that its entire contents is discarded. Note the +anonymous variable, which matches the rest of the computation.

    +

    kompile and krun sum-io.imp. Note that unlike in Lesson 4, the program +terminates with an empty computation cell now.

    +

    As mentioned earlier, the semantics of blocks that was inherited from IMP is +wrong. Program locals.imp shows it very clearly: the environments are not +correctly restored at block exits. One way to fix the problem is to take +a snapshot of the current environment when a block is entered and save it +somewhere, and then to restore it when the block is left. There are many +ways to do this, which you can explore on your own: for example you can add +a new list cell for this task where to push/pop the environment snapshots in +a stack style; or you can use the existing environment cell for this purpose, +but then you need to change the variable access rules to search through the +stacked environments for the variable.

    +

    My preferred solution is to follow a style similar to how we saved/restored +LAMBDA++ environments in Part 3 of the Tutorial, namely to use the already +existing <k/> cell for such operations. More specifically, we place a +reminder item in the computation whenever we need to take a snapshot of +some cell contents; the item simply consists of the entire contents of the cell. +Then, when the reminder item is reached, we restore the contents of the cell:

    +
    rule <k> {S} => S ~> Rho ...</k> <env> Rho </env>
    +
    +

    The only thing left now is to give the definition of environment restore:

    +
    rule <k> Rho => . ...</k> <env> _ => Rho </env>
    +
    +

    Done. kompile and krun locals.imp. Everything should work correctly now. +Note that the rule above is different from the one we had for LAMBDA++ in +Part 3 of the tutorial, in that here there is no value preceding the environment +restoration item in the computation; that's because IMP++ statements, +unlike LAMBDA++'s expressions, evaluate to nothing (.).

    +

    In the next lesson we will give semantics to the spawn S construct, which +dynamically creates a concurrent shared-memory thread executing statement S.

    +

    Go to Lesson 6, IMP++: Adding/Deleting Cells Dynamically; Configuration Abstraction, Part 2.

    +

    MOVIE (out of date) [04'30"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/4_imp++/lesson_6/index.html b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_6/index.html new file mode 100644 index 00000000000..1acf8e3d1a0 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_6/index.html @@ -0,0 +1,569 @@ + + + + + + + + + + + + + + +Adding/Deleting Cells Dynamically; Configuration Abstraction, Part 2 | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Adding/Deleting Cells Dynamically; Configuration Abstraction, Part 2

    +

    In this lesson we add dynamic thread creation and termination to IMP, and +while doing so we learn how to define and use configurations whose structure +can evolve dynamically.

    +

    Recall that the intended semantics of spawn S is to spawn a new concurrent +thread that executes S. The new thread is being passed at creation time +its parent's environment, so it can share with its parent the memory +locations that its parent had access to at creation time. No other locations +can be shared, and no other memory sharing mechanism is available. +The parent and the child threads can evolve unrestricted, in particular they +can change their environments by declaring new variables or shadowing existing +ones, can create other threads, and so on.

    +

    The above suggests that each thread should have its own computation and its +own environment. This can be elegantly achieved if we group the <k/> and +<env/> cells in a <thread/> cell in the configuration. Since at any given +moment during the execution of a program there could be zero, one or more +instances of such a <thread/> cell in the configuration, it is a good idea +to declare the <thread/> cell with multiplicity * (i.e., zero, one or more):

    +
    <thread multiplicity="*" color="blue">
    +  <k color="green"> $PGM:Stmt </k>
    +  <env color="LightSkyBlue"> .Map </env>
    +</thread>
    +
    +

    This multiplicity declaration is not necessary, but it is a good idea to do +it for several reasons:

    +
      +
    1. it may help the configuration abstraction process, +which may in turn significantly increase the compactness and modularity of +your subsequent rules;
    2. +
    3. it may help various analysis and execution tools, +for example static analyzers to give you error messages when you create cells +where you should not, or K compilers to improve performance by starting +actual concurrent hardware threads or processes corresponding to each cell +instance; and
    4. +
    5. it may help you better understand and control the dynamics +of your configuration, and thus your overall semantics.
    6. +
    +

    For good encapsulation, I also prefer to put all thread cells into one cell, +<threads/>. This is technically unnecessary, though; to convince yourself +that this is indeed the case, you can remove this cell once we are done with +the semantics and everything will work without having to make any changes.

    +

    Before we continue, let us kompile an krun some programs that used to +work, say sum-io.imp. In spite of the relatively radical configuration +reorganization, those programs execute just fine! How is that possible? +In particular, why do rules like the lookup and assignment still work, +unchanged, in spite of the fact that the <k/> and <env/> cells are not at +the same level with the <store/> cell in the configuration anymore?

    +

    Welcome to configuration abstraction, part 2. Recall that the role of +configuration abstraction is to allow you to only write the relevant +information in each rule, and have the compiler fill-in the obvious and boring +details. According to the configuration that we declared for our new +language, there is only one reasonable way to complete rules like the lookup, +namely to place the <k/> and </env> cells inside a <thread/> cell, +inside a <threads/> cell:

    +
    rule <threads>...
    +       <thread>...
    +         <k> X:Id => I ...</k>
    +         <env>... X |-> N ...</env>
    +       ...</thread>
    +     ...<threads/>
    +     <store>... N |-> I ...</store>  [lookup]
    +
    +

    This is the most direct, compact and local way to complete the configuration +context of the lookup rule. If for some reason you wanted here to match the +<k/> cell of one thread and the <env/> cell of another thread, then you +would need to explicitly tell K so, by mentioning the two thread cells, +for example:

    +
    rule <thread>...
    +         <k> X:Id => I ...</k>
    +     ...</thread>
    +     <thread>...
    +         <env>... X |-> N ...</env>
    +     ...</thread>
    +     <store>... N |-> I ...</store>  [lookup]
    +
    +

    By default, K completes rules in a greedy style. Think this way: what is the +minimal number of changes to my rule to make it fit the declared +configuration? That's what the K tool will do.

    +

    Configuration abstraction is technically unnecessary, but once you start +using it and get a feel for how it works, it will become your best friend. +It allows you to focus on the essentials of your semantics, and at the same +time gives you flexibility in changing the configuration later on without +having to touch the rules. For example, it allows you to remove the +<threads/> cell from the configuration, if you don't like it, without +having to touch any rule.

    +

    We are now ready to give the semantics of spawn:

    +
    rule <k> spawn S => . ...</k> <env> Rho </env>
    +     (. => <thread>... <k> S </k> <env> Rho </env> ...</thread>)
    +
    +

    Note configuration abstraction at work, again. Taking into account +the declared configuration, and in particular the multiplicity information +* in the <thread/> cell, the only reasonable way to complete the rule +above is to wrap the <k/> and <env/> cells on the first line within a +<thread/> cell, and to fill-in the ...s in the child thread with the +default contents of the other subcells in <thread/>. In this case there +are no other cells, so we can get rid of those ...s, but that would +decrease the modularity of this rule: indeed, we may later on add other +cells within <thread/> as the language evolves, for example a function +or an exception stack, etc.

    +

    In theory, we should be able to write the rule above even more compactly +and modularly, namely as

    +
    rule <k> spawn S => . ...</k> <env> Rho </env>
    +     (. => <k> S </k> <env> Rho </env>)
    +
    +

    Unfortunately, this currently does not work in the K tool, due to some +known limitations of our current configuration abstraction algorithm. +This latter rule would be more modular, because it would not even depend +on the cell name thread. For example, we may later decide to change +thread into agent, and we would not have to touch this rule. +We hope this current limitation will be eliminated soon.

    +

    Once a thread terminates, its computation cell becomes empty. When that +happens, we can go ahead and remove the useless thread cell:

    +
    rule <thread>... <k> . </k> ...</thread> => .
    +
    +

    Let's see what we've got. kompile and krun spawn.imp. +Note the following:

    +
      +
    • The <threads/> cell is empty, so all threads terminated normally;
    • +
    • The value printed is different from the value in the store; the store value +is not even the one obtained if the threads executed sequentially.
    • +
    +

    Therefore, interesting behaviors may happen; we would like to see them all!

    +

    Based on prior experience with krun's search option, we would hope that

    +
    krun spawn.imp --search
    +
    +

    shows all the behaviors. However, the above does not work, for two reasons.

    +

    First, spawn.imp is an interactive program, which reads a number from the +standard input. When analyzing programs exhaustively using the search option, +krun has to disable the streaming capabilities (just think about it and you +will realize why). The best you can do in terms of interactivity with search +is to pipe some input to krun: krun will flush the standard input buffer +into the cells connected to it when creating the initial configuration (will +do that no matter whether you run it with or without the --search option). +For example:

    +
    echo 23 | krun spawn.imp --search
    +
    +

    puts 23 in the standard input buffer, which is then transferred in the +<in/> cell as a list item, and then the exhaustive search procedure is +invoked.

    +

    Second, even after piping some input, the spawn.imp program still manifests +only one behavior, which does not seem right. There should be many more.

    +

    As explained in Lesson 3, by default kompile optimizes the generated +language model for execution. In particular, it does not insert any +backtracking markers where transition attempts should be made, so krun +lacks the information it needs to exhaustively search the generated language +model. Like we did in Lesson 3 with the language constructs, we also have +to explicitly tell kompile which rules should be considered as actual +transitions. A theoretically correct but practically unfeasible approach +to search all possible behaviors is to consider all rules as transitions. +Even more than with the non-deterministic strictness of language constructs +in Lesson 3, such a naive solution would make the number of behaviors, and +thus krun, explode. Remember that a two-thread program with 150 statements +each manifests more behaviors than particles in the known universe! +Consequently, unless your multi-threaded programs are very small, you will +most likely want to control which rules should be considered transitions and +which should not.

    +

    A good rule of thumb is to include as transitions only those rules which +compete for behaviors. That is, those rules which may yield a different +behavior if we choose to apply them when other rules match as well. +The rule for addition, for example, is a clear example of a rule which +should not be a transition: indeed, 3+7 will rewrite to 10 now and also +later. On the other hand, the lookup rule should be a transition. Indeed, +if we delay the lookup of variable x, then other threads may write x in the +meanwhile (with an increment or an assignment rule) and thus yield a +different behavior.

    +

    Let us discuss and tag those rules which should be transitions: lookup and +increment need to be transitions and we already tagged them in Lesson 3; +the read rule needs to also be a transition, because it may complete with +other instances of itself in other threads; assignment needs to also be a +transition, and so should be the first rule for print.

    +

    Let us now kompile with the transition option set as desired:

    +
    kompile imp --transition "lookup increment assignment read print"
    +
    +

    Now echo 23 | krun spawn.imp --search gives us all 12 behaviors of the +spawn.imp program.

    +

    Like for non-deterministically strict operations which can be tagged as +transitions, it is highly non-trivial to say precisely which rules need +to be transitions. So krun makes no attempt to automatically detect it. +Instead, it provides the functionality to let you decide it.

    +

    We currently have no mechanism for thread synchronization. In the next lesson +we add a join statement, which allows a thread to wait until another completes.

    +

    Go to Lesson 7, IMP++: Everything Changes: Syntax, Configuration, Semantics.

    +

    MOVIE (out of date) [11'40"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/4_imp++/lesson_7/index.html b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_7/index.html new file mode 100644 index 00000000000..1a729a791b0 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_7/index.html @@ -0,0 +1,465 @@ + + + + + + + + + + + + + + +Everything Changes: Syntax, Configuration, Semantics | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Everything Changes: Syntax, Configuration, Semantics

    +

    In this lesson we add thread joining, one of the simplest thread +synchronization mechanisms. In doing so, we need to add unique ids +to threads in the configuration, and to modify the syntax to allow spawn +to return the id of the newly created thread. This gives us an opportunity +to make several other small syntactic and semantics changes to the language, +which make it more powerful or more compact at a rather low cost.

    +

    Before we start, let us first copy and modify the previous spawn.imp program +from Lesson 1 to make use of thread joining. Recall from Lesson 6 that in some +runs of this program the main thread completed before the child threads, +printing a possibly undesired value of x. What we want now is to assign +unique ids to the two spawned threads, and then to modify the main thread to +join the two child threads before printing. To avoid adding a new type to +the language, let's assume that thread ids are integer numbers. So we declare +two integers, t1 and t2, and assign them the two spawn commands. In order +for this to parse, we will have to change the syntax of spawn to be an +arithmetic expression construct instead of a statement. Once we do that, +we have a slight syntactic annoyance: we need to put two consecutive ; +after the spawn assignment, one for the assignment statement inside the spawn, +and another for the outer assignment. To avoid the two consecutive semicolons, +we can syntactically enforce spawn to take a block as argument, instead of a +statement. Now it looks better. The new spawn.imp program is still +non-deterministic, because the two threads can execute in any order and even +continue to have a data-race on the shared variable x, but we should see fewer +behaviors when we use the join statements. If we want to fully synchronize +this program, we can have the second thread start with a join(t1) statement. +Then we should only see one behavior for this program.

    +

    Let us now modify the language semantics. First, we move the spawn +construct from statements to expressions, and make it take a block. +Second, we add one more sub-cell to the thread cell in the configuration, +<id/>, to hold the unique identifier of the thread. We want the main +thread to have id 0, so we initialize this cell with 0. Third, we modify +the spawn rule to generate a fresh integer identifier, which is put in the +<id/> cell of the child thread and returned as a result of spawn in the +parent thread. Fourth, let us add the join statement to the language, +both syntactically and semantically. So in order for the join(T) statement +to execute, thread T must have its computation empty. However, in order +for this to work we have to get rid of the thread termination cleanup rule. +Indeed, we need to store somewhere the information that thread T terminated; +the simplest way to do it is to not remove the terminated threads. Feel free +to experiment with other possibilities, too, here. For example, you may add +another cell, <done/>, in which you can store all the thread ids of the +terminated and garbage-collected threads.

    +

    Let us now kompile imp.k and convince ourselves that the new spawn.imp +with join statements indeed has fewer behaviors than its variant without +join statements. Also, let us convince ourselves that the fully synchronized +variant of it indeed has only one behavior.

    +

    Note that now spawn, like variable increment, makes the evaluation of +expressions to have side effects. Many programming languages in fact allow +expressions to be evaluated only for their side effects, and not for their +value. This is typically done by simply adding a ; after the expression +and thus turning it into a statement. For example, ++x;. Let as also +allow arithmetic expressions in our language to be used as statements, by +simply adding the production AExp ";" to Stmt, with evaluation strategy +strict and with the expected semantics discarding the value of the AExp.

    +

    Another simple change in syntax and semantics which gives our language more +power, is to remove the ; from the syntax of variable assignments and to make +them expression instead of statement constructs. This change, combined with +the previous one, will still allow us to parse all the programs that we could +parse before, but will also allow us to parse more programs. For example, we +can now do sequence assignments like in C: x = y = z = 0. The semantics +of assignment now has to return the assigned value also to the computation, +because we want the assignment expression to evaluate to the assigned value.

    +

    Let us also make another change, but this time one which only makes the +definition more compact. Instead of defining statement sequential +composition as a binary construct for statements, let us define a new +syntactic construct, Stmts, as whitespace-separated lists of Stmt. This +allows us to get rid of the empty blocks, because we can change the syntax of +blocks to {Stmts} and Stmts also allows the empty sequence of statements. +However, we do have to make sure that .Stmts dissolves.

    +

    In general, unless you are defining a well-established programming language, +it is quite likely that your definitions will suffer lots of changes like the +ones seen in this lecture. You add a new construct, which suggests changes +in the existing syntax making in fact your language parse more programs, +which then requires corresponding changes in the semantics, and so on. +Also, compact definitions are desirable in general, because they are easier +to read and easier to change if needed later.

    +

    In the next lesson we wrap up and document the definition of IMP++.

    +

    Go to Lesson 8, IMP++: Wrapping up Larger Languages.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/4_imp++/lesson_8/imp/index.html b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_8/imp/index.html new file mode 100644 index 00000000000..f6d1ad14e36 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_8/imp/index.html @@ -0,0 +1,954 @@ + + + + + + + + + + + + + + +IMP++ | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    IMP++

    +

    Author: Grigore Roșu (grosu@illinois.edu)
    +Organization: University of Illinois at Urbana-Champaign

    +

    Abstract

    +

    This is the K semantic definition of the IMP++ language. +IMP++ extends the IMP language with the features listed below. We +strongly recommend you to first familiarize yourself with the IMP +language and its K definition in Tutorial 2 before proceeding.

    +

    Strings and concatenation of strings. Strings are useful +for the print statement, which is discussed below. For +string concatenation, we use the same + construct that we use +for addition (so we overload it).

    +

    Variable increment. We only add a pre-increment construct: +++x increments variable x and evaluates to the +incremented value. Variable increment makes the evaluation of +expressions have side effects, and thus makes the evaluation strategies +of the various language constructs have an influence on the set +of possible program behaviors.

    +

    Input and output. IMP++ adds a read() expression +construct which reads an integer number and evaluates to it, and +a variadic (i.e., it has an arbitrary number of arguments) statement +construct print(e1,e2,...,en) which evaluates its arguments +and then outputs their values. Note that the K tool allows to +connect the input and output cells to the standard input and output +buffers, this way compiling the language definition into an +interactive interpreter.

    +

    Abrupt termination. The halt statement simply halts +the program. The K tool shows the resulting configuration, as if the +program terminated normally. We therefore assume that an external +observer does not care whether the program terminates normally or +abruptly, same like with exit statements in conventional +programming languages like C.

    +

    Dynamic threads. The expression construct spawn s +starts a new concurrent thread that executes statement s, +which is expected to be a block, and evaluates immediately to a fresh +thread identifier that is also assigned to the newly created thread. +The new thread is given at creation time the environment of its +parent, so it can access all its parent's variables. This allows for +the parent thread, and the child thread to communicate; it also allows +for races and "unexpected" behaviors, so be careful. +For thread synchronization, IMP++ provides a thread join statement +construct join t;, where t evaluates to a thread +identifier, which stalls the current thread until thread t +completes its computation. For simplicity, we here assume a +sequentially consistent shared memory model. To experiment with other +memory models, see the definition of KERNELC.

    +

    Blocks and local variables. IMP++ allows blocks enclosed by +curly brackets. Also, IMP's global variable declaration construct is +generalized to be used anywhere as a statement, not only at the +beginning of the program. As expected, the scope of the declared +variables is from their declaration point till the end of the most +nested enclosing block.

    +

    What You Will Learn Here

    +
      +
    • How to define a less trivial language in K, as explained above.
    • +
    • How to use the superheat and supercool +options of the K tool kompile to exhaustively explore the +non-determinism due to underspecified evaluation strategies.
    • +
    • How to use the transition option of the K tool to +exhaustively explore the non-determinism due to concurrency.
    • +
    • How to connect certain cells in the configuration to the +standard input and standard output, and thus turn the krun +tool into an interactive interpreter for the defined language.
    • +
    • How to exhaustively search for the non-deterministic behaviors +of a program using the search option of krun.
    • +
    +
    k
    module IMP-SYNTAX + imports DOMAINS-SYNTAX +
    +

    Syntax

    +

    IMP++ adds several syntactic constructs to IMP. Also, since the +variable declaration construct is generalized to be used anywhere a +statement can be used, not only at the beginning of the program, we +need to remove the previous global variable declaration of IMP and +instead add a variable declaration statement construct

    +

    We do not re-discuss the constructs which are taken over from IMP, +except when their syntax has been subtly modified (such as, for +example, the syntax of the previous "statement" assignment which +is now obtained by composing the new assignment expression, and the +new expression statement constructs); go the last lesson of +Tutorial 2 if you are interested in IMP's constructs. For execution +purposes, we tag the addition and division operations as members of the +addition and division groups. These groups have no theoretical significance, +in that they do not affect the semantics of the language in any way. They only +have practical relevance, specific to our implementation of the K tool. +Specifically, we can tell the K tool (using its superheat and supercool +options) that we want to exhaustively explore all the non-deterministic +behaviors (due to strictness) of these language constructs. For performance +reasons, by default the K tool chooses an arbitrary but fixed order to +evaluate the arguments of the strict language constructs, thus possibly losing +behaviors due to missed interleavings. This aspect was irrelevant in IMP, +because its expressions had no side effects, but it becomes relevant in IMP++.

    +

    The syntax of the IMP++ constructs is self-explanatory. Note that assignment +is now an expression construct. Also, print is variadic, taking a +list of expressions as argument. It is also strict, which means that the +entire list of expressions, that is, each expression in the list, will be +evaluated. Note also that we have now defined sequential composition +of statements as a whitespace-separated list of statements, aliased with +the nonterminal Stmts, and block as such a (possibly empty) sequence +of statements surrounded by curly brackets.

    +
    k
    syntax AExp ::= Int | String | Id + | "++" Id + | "read" "(" ")" + | "-" AExp [strict] + | "(" AExp ")" [bracket] + > AExp "/" AExp [left, strict, group(division)] + > AExp "+" AExp [left, strict] + > "spawn" Block + > Id "=" AExp [strict(2)] + syntax BExp ::= Bool + | AExp "<=" AExp [seqstrict, latex({#1}\leq{#2})] + | "!" BExp [strict] + | "(" BExp ")" [bracket] + > BExp "&&" BExp [left, strict(1)] + syntax Block ::= "{" Stmts "}" + syntax Stmt ::= Block + | AExp ";" [strict] + | "if" "(" BExp ")" + Block "else" Block [strict(1)] + | "while" "(" BExp ")" Block + | "int" Ids ";" + | "print" "(" AExps ")" ";" + | "halt" ";" + > "join" AExp ";" [strict] + + syntax Ids ::= List{Id,","} [klabel(exps)] + syntax AExps ::= List{AExp,","} [klabel(exps)] + syntax Stmts ::= List{Stmt,""} + syntax AExps ::= Ids +endmodule + + +module IMP + imports IMP-SYNTAX + imports DOMAINS +
    +

    Semantics

    +

    We next give the semantics of IMP++. We start by first defining its +configuration.

    +

    Configuration

    +

    The original configuration of IMP has been extended to include +all the various additional cells needed for IMP++. +To facilitate the semantics of threads, more specifically +to naturally give them access to their parent's variables, we prefer a +(rather conventional) split of the program state into an +environment and a store. An environment maps +variable names into locations, while a store maps locations +into values. Stores are also sometimes called states, or +heaps, or memory, in the literature. Like values, locations +can be anything. For simplicity, here we assume they are natural +numbers. Moreover, each thread has its own environment, so it knows +where all the variables that it has access to are located in the store +(that includes its locally declared variables as well as the variables +of its parent thread), and its own unique identifier. The store is +shared by all threads. For simplicity, we assume a sequentially consistent +memory model in IMP++. Note that the thread cell has multiplicity +*, meaning that there could be zero, one, or more instances of that cell +in the configuration at any given time. This multiplicity information +is important for K's configuration abstraction process: it tells +K how to complete rules which, in order to increase the modularity of the +definition, choose to not mention the entire configuration context. +The in and out cells hold the input and the output +buffers as lists of items.

    +
    k
    configuration <T color="yellow"> + <threads color="orange"> + <thread multiplicity="*" color="blue" type="Map"> + <id color="black"> 0 </id> + <k color="green"> $PGM:Stmts </k> + <env color="LightSkyBlue"> .Map </env> + </thread> + </threads> +// <br/> + <store color="red"> .Map </store> +// <input color="magenta"> .List </input> +// <output color="Orchid"> .List </output> + <input color="magenta" stream="stdin"> .List </input> + <output color="Orchid" stream="stdout"> .List </output> + </T> +// Replace the <input/> and <output/> cells with the next two in order to +// initialize the input buffer through krun +// <input color="magenta"> $IN:List </input> +// <output color="Orchid"> .List </output> +// Replace the <input/> and <output/> cells with the next two to connect the +// input/output buffers to stdin/stdout through krun +// <input color="magenta" stream="stdin"> .List </input> +// <output color="Orchid" stream="stdout"> .List </output> +// Replace the <input/> and <output/> cells with the next two to connect the +// input/output buffers to stdin/stdout and also allow input through krun +// <input color="magenta" stream="stdin"> $IN:List </input> +// <output color="Orchid" stream="stdout"> .List </output> +
    +

    We can also use configuration variables to initialize +the configuration through krun. For example, we may want to +pass a few list items in the in cell when the program makes +use of read(), so that the semantics does not get stuck. +Recall from IMP that configuration variables start with a ParseError: KaTeX parse error: Expected group after '_' at position 63: …, for example, +_̲PGM) and can be initialized with any string by +krun; or course, the string should parse to a term of the +corresponding sort, otherwise errors will be generated. +Moreover, K allows you to connect list cells to the standard input or +the standard output. For example, if you add the attribute +stream="stdin" to the in cell, then krun +will prompt the user to pass input when the in cell is empty +and any semantic rule needs at least one item to be present there in +order to match. Similarly but dually, if you add the attribute +stream="stdout" to the out cell, then any item +placed into this cell by any rule will be promptly sent to the +standard output. This way, krun can be used to obtain +interactive interpreters based directly on the K semantics of the +language. For example:

    +
    shell
    sh$ krun sum-io.imp --output none +Add numbers up to (<= 0 to quit)? 10 +Sum = 55 +Add numbers up to (<= 0 to quit)? 1000 +Sum = 500500 +Add numbers up to (<= 0 to quit)? 0 +sh$ +
    +

    The option --output none instructs krun to not +display the resulting configuration after the program executes. The +input/output streaming works with or without this option, although +if you don't use the option then a configuration with empty +in and out cells will be displayed after the program +is executed. You can also initialize the configuration using +configuration variables and stream the contents of the cells to +standard input/output at the same time. For example, if you use a +configuration variable in the in cell and pass contents to it +through krun, then that contents will be first consumed and +then the user will be prompted to introduce additional input if the +program's execution encounters more read() constructs.

    +

    The old IMP constructs

    +

    The semantics of the old IMP constructs is almost identical to their +semantics in the original IMP language, except for those constructs +making use of the program state and for those whose syntax has slightly +changed. Indeed, the rules for variable lookup and assignment in IMP +accessed the state cell, but that cell is not available in IMP++ +anymore. Instead, we have to use the combination of environment and store +cells. Thanks to K's implicit configuration abstraction, we do not have +to mention the thread and threads cells: these are +automatically inferred (and added by the K tool at compile time) from the +definition of the configuration above, as there is only one correct +way to complete the configuration context of these rules in order to +match the configuration declared above. In our case here, "correct way" +means that the k and env cells will be considered as +being part of the same thread cell, as opposed to each being part +of a different thread. Configuration abstraction is crucial for modularity, +because it gives us the possibility to write our definitions in a way that +may not require us to revisit existing rules when we change the configuration. +Changes in the configuration are quite frequent in practice, typically +needed in order to accommodate new language features. For example, +imagine that we initially did not have threads in IMP++. There +would be no need for the thread and threads cells in +the configuration then, the cells k and env being simply +placed at the top level in the T cell, together with the +already existing cells. Then the rules below would be exactly the +same. Thus, configuration abstraction allows you to not have to +modify your rules when you make structural changes in your language +configuration.

    +

    Below we list the semantics of the old IMP constructs, referring the +reader to the K semantics of IMP for their meaning. Like we tagged the +addition and the division rules above in the syntax, we also tag the lookup +and the assignment rules below (as members of the groups lookup and +assignment), because we want to refer to them when we generate the +language model (with the kompile tool), basically to allow them to +generate (possibly non-deterministic) transitions. Indeed, these two rules, +unlike the other rules corresponding to old IMP constructs, can yield +non-deterministic behaviors when more threads are executed concurrently. +In terms of rewriting, these two rules can "compete" with each other on +some program configurations, in the sense that they can both match at the +same time and different behaviors may be obtained depending upon which of +them is chosen first.

    +
    k
    syntax KResult ::= Int | Bool +
    +

    Variable lookup

    +
    k
    rule <k> X:Id => I ...</k> + <env>... X |-> N ...</env> + <store>... N |-> I ...</store> [group(lookup)] +
    +

    Arithmetic constructs

    +
    k
    rule I1 / I2 => I1 /Int I2 when I2 =/=Int 0 + rule I1 + I2 => I1 +Int I2 + rule - I => 0 -Int I +
    +

    Boolean constructs

    +
    k
    rule I1 <= I2 => I1 <=Int I2 + rule ! T => notBool T + rule true && B => B + rule false && _ => false +
    +

    Variable assignment

    +

    Note that the old IMP assignment statement X = I; is now composed of two +constructs: an assignment expression construct X = I, followed by a +semicolon ; turning the expression into a statement. The rationale behind +this syntactic restructuring has been explained in Lesson 7. Here is the +semantics of the two constructs:

    +
    k
    rule _:Int; => . + rule <k> X = I:Int => I ...</k> + <env>... X |-> N ...</env> + <store>... N |-> (_ => I) ...</store> [group(assignment)] +
    +

    Sequential composition

    +

    Sequential composition has been defined as a whitespace-separated syntactic +list of statements. Recall that syntactic lists are actually syntactic +sugar for cons-lists. Therefore, the following two rules eventually +sequentialize a syntactic list of statements s1 s2 ... sn.. into the +corresponding computation s1 ~> s2 ~> ... ~> sn.

    +
    k
    rule .Stmts => . + rule S:Stmt Ss:Stmts => S ~> Ss +
    +

    Conditional statement

    +
    k
    rule if (true) S else _ => S + rule if (false) _ else S => S +
    +

    While loop

    +

    The only thing to notice here is that the empty block has been replaced +with the block holding the explicit empty sequence. That's because in +the semantics all empty lists become explicit corresponding dots +(to avoid parsing ambiguities)

    +
    k
    rule while (B) S => if (B) {S while (B) S} else {.Stmts} +
    +

    The new IMP++ constructs

    +

    We next discuss the semantics of the new IMP++ constructs.

    +

    Strings

    +

    First, we have to state that strings are also results. +Second, we give the semantics of IMP++ string concatenation (which +uses the already existing addition symbol + from IMP) by +reduction to the built-in string concatenation operation.

    +
    k
    syntax KResult ::= String + rule Str1 + Str2 => Str1 +String Str2 +
    +

    Variable increment

    +

    Like variable lookup, this is also meant to be a supercool transition: we +want it to count both in the non-determinism due to strict operations above +it in the computation and in the non-determinism due to thread +interleavings. This rule also relies on K's configuration abstraction. +Without abstraction, you would have to also include the thread and +threads cells.

    +
    k
    rule <k> ++X => I +Int 1 ...</k> + <env>... X |-> N ...</env> + <store>... N |-> (I => I +Int 1) ...</store> [group(increment)] +
    +

    Read

    +

    The read() construct evaluates to the first integer in the +input buffer, which it consumes. Note that this rule is put in the group +increment. This is because we will include it in the set of +potentially non-deterministic transitions when we kompile the definition; +we want to do that because two or more threads can "compete" on +reading the next integer from the input buffer, and different choices +for the next transition can lead to different behaviors.

    +
    k
    rule <k> read() => I ...</k> + <input> ListItem(I:Int) => .List ...</input> [group(read)] +
    +

    Print

    +

    The print statement is strict, so all its arguments are +eventually evaluated (recall that print is variadic). We +append each of its evaluated arguments, in order, to the output buffer, +and structurally discard the residual print statement with an +empty list of arguments. We only want to allow printing integers and +strings, so we define a Printable syntactic category including +only these and define the print statement to only print +Printable elements. Alternatively, we could have had two +similar rules, one for integers and one for strings. Recall that, +currently, K's lists are cons-lists, so we cannot simply rewrite the +head of a list (P) into a list (.). The first rule below is tagged, +because we want to include it in the list of transitions when we kompile; +different threads may compete on the output buffer and we want to capture +all behaviors.

    +
    k
    syntax Printable ::= Int | String + +/* currently it is necessary to subsort Printable to AExp, + but future K should be able to infer that automatically. */ + syntax AExp ::= Printable + + context print(HOLE:AExp, _AEs:AExps); + + rule <k> print(P:Printable,AEs => AEs); ...</k> + <output>... .List => ListItem(P) </output> [group(print)] + rule print(.AExps); => . +
    +

    Halt

    +

    The halt statement empties the computation, so the rewriting process +simply terminates as if the program terminated normally. Interestingly, once +we add threads to the language, the halt statement as defined below +will terminate the current thread only. If you want an abrupt termination +statement that halts the entire program, then you need to discard the entire +contents of the threads cell, so the entire computation abruptly +terminates the entire program, no matter how many concurrent threads it has, +because there is nothing else to rewrite.

    +
    k
    rule <k> halt; ~> _ => . </k> +
    +

    Spawn thread

    +

    A spawned thread is passed its parent's environment at creation time. +The spawn expression in the parent thread is immediately +replaced by the unique identifier of the newly created thread, so the +parent thread can continue its execution. We only consider a sequentially +consistent shared memory model for IMP++, but other memory models can also +be defined in K; see, for example, the definition of KERNELC. Note that +the rule below does not need to be tagged in order to make it a transition +when we kompile, because the creation of the thread itself does not interfere +with the execution of other threads. Also, note that K's configuration +abstraction is at heavy work here, in two different places. First, the +parent thread's k and env cells are wrapped within a +thread cell. Second, the child thread's k, env +and id cells are also wrapped within a thread cell. Why +that way and not putting all these four cells together within the +same thread, or even create an additional threads cell at top +holding a thread cell with the new k, env +and id? Because in the original configuration we declared +the multiplicity of the thread cell to be *, which +effectively tells the K tool that zero, one or more such cells can +co-exist in a configuration at any moment. The other cells have the +default multiplicity one, so they are not allowed to multiply. +Thus, the only way to complete the rule below in a way consistent with +the declared configuration is to wrap the first two cells in a +thread cell, and the latter two cells under the . +also in a thread cell. Once the rule applies, the spawning +thread cell will add a new thread cell next to it, which is consistent +with the declared configuration cell multiplicity. The unique identifier +of the new thread is generated using the fresh side condition.

    +
    k
    rule <k> spawn S => !T:Int +Int 1 ...</k> <env> Rho </env> + (.Bag => <thread>... <k> S </k> <env> Rho </env> <id> !T +Int 1 </id> ...</thread>) +
    +

    Join thread

    +

    A thread who wants to join another thread T has to wait until +the computation of T becomes empty. When that happens, the +join statement is simply dissolved. The terminated thread is not removed, +because we want to allow possible other join statements to also dissolve.

    +
    k
    rule <k> join(T); => . ...</k> <thread>... <k>.</k> <id>T</id> ...</thread> +
    +

    Blocks

    +

    The body statement of a block is executed normally, making sure +that the environment at the block entry point is saved in the computation, +in order to be recovered after the block body statement. This step is +necessary because blocks can declare new variables having the same +name as variables which already exist in the environment, and our +semantics of variable declarations is to update the environment map in +the declared variable with a fresh location. Thus, variables which +are shadowed lose their original binding, which is why we take a +snapshot of the environment at block entrance and place it after the +block body (see the semantics of environment recovery at the end of +this module). Note that any store updates through variables which are +not declared locally are kept at the end of the block, since the store +is not saved/restored. An alternative to this environment save/restore +approach is to actually maintain a stack of environments and to push a +new layer at block entrance and pop it at block exit. The variable +lookup/assign/increment operations then also need to change, so we do +not prefer that non-modular approach. Compilers solve this problem by +statically renaming all local variables into fresh ones, to completely +eliminate shadowing and thus environment saving/restoring.

    +
    k
    rule <k> {Ss} => Ss ~> Rho ...</k> <env> Rho </env> +
    +

    Variable declaration

    +

    We allocate a fresh location for each newly declared variable and +initialize it with 0.

    +
    k
    rule <k> int (X,Xs => Xs); ...</k> + <env> Rho => Rho[X <- !N:Int] </env> + <store>... .Map => !N |-> 0 ...</store> + rule int .Ids; => . +
    +

    Auxiliary operations

    +

    We only have one auxiliary operation in IMP++, the environment +recovery. Its role is to discard the current environment in the +env cell and replace it with the environment that it holds.

    +
    k
    rule <k> Rho => . ...</k> <env> _ => Rho </env> +
    +

    If you want to avoid useless environment recovery steps and keep the size +of the computation structure smaller, then you can also add the rule

    +
      rule (_:Map => .) ~> _:Map
    +
    +

    This rule acts like a ``tail recursion'' optimization, but for blocks. */

    +
    k
    // verification ids + syntax Id ::= "n" [token] + | "sum" [token] + | "a" [token] + | "b" [token] + | "c" [token] +endmodule +
    +

    On Kompilation Options

    +

    We are done with the IMP++ semantics. The next step is to kompile the +definition using the kompile tool, this way generating a language +model. Depending upon for what you want to use the generated language model, +you may need to kompile the definition using various options. We here discuss +these options.

    +

    To tell the K tool to exhaustively explore all the behaviors due to the +non-determinism of addition, division, and threads, we have to kompile +with the command:

    +
    shell
    kompile imp.k --transition="addition division lookup assignment increment read print" +
    +

    As already mentioned, the syntax and rule groups play no theoretical or +foundational role in K. They are only a means to allow kompile to +refer to them in its options, like we did above. By default, kompile's +transition option is empty, because this yields the fastest language model when +executed. Transitions may slow down the execution, but they instrument +the language model to allow for formal analysis of program behaviors, even for +exhaustive analysis.

    +

    Theoretically, the heating/cooling rules in K are fully reversible and +unconstrained by side conditions as we showed in the semantics of IMP. +For example, the theoretical heating/cooling rules corresponding to the +strict attribute of division are the following:

    +
    E₁ / E₂ ⇒ E₁ ⤳ □ / E₂
    +E₁ ⤳ □ / E₂ ⇒ E₁ / E₂
    +E₁ / E₂ ⇒ E₂ ⤳ E₁ / □
    +E₂ ⤳ E₁ / □ ⇒ E₁ / E₂
    +
    +

    The other semantic rules apply modulo such structural rules. +For example, using heating rules we can bring a redex (a subterm which +can be reduced with semantic rules) to the front of the computation, +then reduce it, then use cooling rules to reconstruct a term over the +original syntax of the language, then heat again and +non-deterministically pick another redex, and so on and so forth +without losing any opportunities to apply semantic rules. +Nevertheless, these unrestricted heating/cooling rules may create an +immense, often unfeasibly large space of possibilities to analyze. +The --transition option implements an optimization which works +well with other implementation choices made in the current K tool. +Recall from the detailed description of the IMP language semantics that +(theoretical) reversible rules like above are restricted by default +to complementary conditional rules of the form

    +
    E₁ / E₂ ⇒ E₁ ⤳ □ / E₂
    +   if E₁ not in KResult
    +E₁ ⤳ □ / E₂ ⇒ E₁ / E₂
    +   if E₁ in KResult
    +E₁ / E₂ ⇒ E₂ ⤳ E₁ / □
    +   if E₂ not in KResult
    +E₂ ⤳ E₁ / □  ⇒ E₁ / E₂
    +   if  E₂ in KResult
    +
    +

    Therefore, our tool eagerly heats and lazily cools the computation. +In other words, heating rules apply until a redex gets placed on the +top of the computation, then some semantic rule applies and rewrites +that into a result, then a cooling rule is applied to plug the +obtained result back into its context, then another argument may be +chosen and completely heated, and so on. This leads to efficient +execution, but it may and typically does hide program behaviors. +Using the --transition option allows you to interfere with this +process and to obtain all possible non-deterministic behaviors as if +the theoretical heating/cooling rules were applied. Optimizations +of course happen under the hood, but you need not be aware of them. +Used carefully, this mechanism allows us to efficiently explore more of +the non-deterministic behaviors of a program, even all of them (like here). +For example, with the semantics of IMP++ given above, the krun +command with the --search option detects all five behaviors +of the following IMP++ program (x can be 0, 1, 2, 3, or undefined +due to division-by-zero):

    +
      int x,y;
    +  x = 1;
    +  y = ++x / (++x / x);
    +
    +

    Besides non-determinism due to underspecified argument evaluation +orders, which the current K tool addresses as explained above, there +is another important source of non-determinism in programming languages: +non-determinism due to concurrency/parallelism. For example, when two +or more threads are about to access the same location in the store and at +least one of these accesses is a write (i.e., an instance of the variable +assignment rule), there is a high chance that different choices for +the next transition lead to different program behaviors. While in the +theory of K all the count as computational steps +and hereby as transitions in the transition system associated to the +program, in practice that may yield a tremendous number of step +interleavings to consider. Most of these interleavings are behaviorally +equivalent for most purposes. For example, the fact that a thread computes +a step 8+3 ⇒ 11 is likely irrelevant for the other +threads, so one may not want to consider it as an observable transition in +the space of interleavings. Since the K tool cannot know without help which +transitions need to be explored and which do not, our approach is to +let the user say so explicitly using the transition option of +kompile.

    +
    +
    + + +
    + + + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/4_imp++/lesson_8/index.html b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_8/index.html new file mode 100644 index 00000000000..4548e7ea8aa --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/4_imp++/lesson_8/index.html @@ -0,0 +1,404 @@ + + + + + + + + + + + + + + +Wrapping up Larger Languages | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Wrapping up Larger Languages

    +

    In this lesson we wrap up IMP++'s semantics and also generate its poster. +While doing so, we also learn how to display larger configurations in order +to make them easier to read and print.

    +

    Note that we rearrange a bit the semantics, to group the semantics of old +IMP's constructs together, and separate it from the new IMP++'s semantics.

    +

    There is a detailed discussion at the end of the document about the +--transition option of kompile, because that is important and we want +the poster to include everything we learned in this part of the tutorial.

    +

    You can go even further and manually edit the generated Latex document. +You typically want to do that when you want to publish your language +definition, or parts of it, and you need to finely tune it to fit the +editing requirements. For example, you may want to insert some negative +spaces, etc.

    +

    Part 4 of the tutorial is now complete. At this moment you should know most +of K framework's features and how to use the K tool. You can now define or +design your own programming languages, and then execute and analyze programs.

    +

    MOVIE (out of date) [06'26"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/index.html b/k-distribution/pl-tutorial/1_k/5_types/index.html new file mode 100644 index 00000000000..802670a38c8 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/index.html @@ -0,0 +1,392 @@ + + + + + + + + + + + + + + +Part 5: Defining Type Systems | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Part 5: Defining Type Systems

    +

    In this part of the tutorial we will show that defining type systems for +languages is essentially no different from defining semantics. The major +difference is that programs and fragments of programs now rewrite to their +types, instead of to concrete values. In terms of K, we will learn how +to use it for a certain particular but important kind of applications.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_1.9/NOTES/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_1.9/NOTES/index.html new file mode 100644 index 00000000000..fb139c80745 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_1.9/NOTES/index.html @@ -0,0 +1,383 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    This currently does NOT work, because of the rules

    +
    rule _:Int => int                            [anywhere]
    +rule _:Bool => bool                          [anywhere]
    +
    +

    which now rewrite ANY integer ANYWHERE to "int", including integers +that appear in the internal data-structures/functions of the builtins. +We will need to allow a strategy where "anywhere" means anywhere in one +or more computational cells.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_1/NOTES/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_1/NOTES/index.html new file mode 100644 index 00000000000..eb163cb2fc6 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_1/NOTES/index.html @@ -0,0 +1,376 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Explain the lack of tenv(...)?

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_1/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_1/index.html new file mode 100644 index 00000000000..0f5aab19984 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_1/index.html @@ -0,0 +1,492 @@ + + + + + + + + + + + + + + +Imperative, Environment-Based Type Systems | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Imperative, Environment-Based Type Systems

    +

    In this lesson you learn how to define a type system for an imperative +language (the IMP++ language defined in Part 4 of the tutorial), using a style +based on type environments.

    +

    Let us copy the imp.k file from Part 4 of the tutorial, Lesson 7, which holds +the semantics of IMP++, and modify it into a type system. The resulting type +system, when executed, yields a type checker.

    +

    We start by defining the new strictness attributes of the IMP++ syntax. +While doing so, remember that programs and fragments of programs now reduce +to their types. So types will be the new results of our new (type) semantics. +We also clean up the semantics by removing the unnecessary tags, and also +use strict instead of seqstrict wherever possible, because strict gives +implementations more freedom. Interestingly, note that spawn is strict now, +because the code of the child thread should type in the current parent's type +environment. Note that this is not always the case for threads, see for example +SIMPLE in the languages tutorial, but it works here for our simpler IMP++.

    +

    From a typing perspective, the && construct is strict in both its arguments; +its short-circuit (concrete) semantics is irrelevant for its (static) type +system. Similarly, both the conditional and the while loop are strict +constructs when regarded through the typing lenses.

    +

    Finally, the sequential composition is now sequentially strict! Indeed, +statements are now going to reduce to their type, stmt, and it is critical +for sequential composition to type its argument statements left-to-right; +for example, imagine that the second argument is a variable declaration (whose +type semantics will modify the type environment).

    +

    We continue by defining the new results of computations, that is, the actual +types. In this simple imperative language, we only have a few constant types: +int, bool, string, block and stmt.

    +

    We next define the new configuration, which is actually quite simple. Besides +the <k/> cell, all we need is a type environment cell, <tenv/>, which will +hold a map from identifiers to their types. A type environment is therefore +like a state in the abstract domain of type values.

    +

    Let us next modify the semantic rules, turning them into a type system. In +short, the idea is to reduce the basic values to their types, and then have a +rule for each language construct reducing it to its result type whenever its +arguments have the expected types.

    +

    We write the rules in the order given by the syntax declarations, to make +sure we do not forget any construct.

    +

    Integers reduce to their type, int.

    +

    So do the strings.

    +

    Variables are now looked up in the type environment and reduced to their type +there. Since we only declare integer variables in IMP++, their type in tenv +will always be int. Nevertheless, we write the rule generically, so that we +would not have to change it later if we add other type declarations to IMP++. +Note that we reject programs which lookup undeclared variables. Rejection, +in this case, means rewriting getting stuck.

    +

    Variable increment types to int, provided the variable has type int.

    +

    Read types to int, because we only allow integer input.

    +

    Division is only allowed on integers, so it rewrites to int provided that its +arguments rewrite to int. Note, however, that in order to write int / int, +we have to explicitly add int to the syntax of arithmetic expressions. +Otherwise, the K parser rightfully complains, because / was declared on +arithmetic expressions, not on types. One simple and generic way to allow +types to appear anywhere, is to define Type as a syntactic subcategory of all +the other syntactic categories. Let's do it on a by-need basis, though.

    +

    Addition is overloaded, so we add two typing rules for it: one for integers +and another for strings.

    +

    As discussed, spawn types to stmt provided that its argument types to +block.

    +

    The assignment construct was strict(2); its typing policy is that the declared +type of X should be identical to the type of the assigned value. Like for +lookup, we define this rule more generically than needed for IMP++, for any +type, not only for int.

    +

    The typing rules for Boolean expression constructs are in the same spirit. +Note that we need only one rule for &&.

    +

    The typing of blocks is a bit trickier. First, note that we still need to +recover the environment after the block is typed, because we do not want the +block-local variables to be visible in the outer type environment. We recover +the type environment only after the block-enclosed statements type; moreover, +we also opportunistically yield a block type on the computation when we +discard the type environment recovery item. To account for the fact that the +block-enclosed statement can itself be a block (e.g., {{S}}), we would need an +additional rule. Since we do not like repetition, we instead group the types +block and stmt into one syntactic category, BlockOrStmtType, and now we +can have only one rule. We also include BlockOrStmtType in Type, as a +replacement for the two basic types.

    +

    The expression statement types as expected. Recall that we only allow +arithmetic expressions, which type to int, to be used as statements in IMP++.

    +

    The conditional was declared strict in all its arguments. Its typing policy +is that its first argument types to bool and its two branches to block. +If that is the case, then it yields a stmt type.

    +

    For while, its first argument should type to bool and its second to block.

    +

    Variable declarations add new bindings to the type environment. Recall that +we can only declare variables of integer type in IMP++.

    +

    The typing policy of print is that it can only print integer or string values, +and in that case it types to stmt. Like for BlockOrStmtType, to avoid +having two similar rules, one for int and another for string, we prefer to +introduce an additional syntactic category, PrintableType, which includes both +int and string types.

    +

    halt types to stmt; so its subsequent code is also typed.

    +

    join types to stmt, provided that its argument types to int.

    +

    Sequential composition was declared as a whitespace-separated sequentially +strict list. Its typing policy is that all the statements in the list should +type to stmt or block in order for the list to type to stmt. Since +lists are maintained internally as cons-lists, this is probably the simplest +way to do it:

    +
    rule .Stmts => stmt
    +rule _:BlockOrStmtType Ss => Ss
    +
    +

    Note that the first rule, which types the empty sequence of statements to stmt, +is needed anyway, to type empty blocks {} (together with the block rule).

    +

    kompile imp.k and krun all the programs in Part 4 of the tutorial. They +should all type to stmt.

    +

    In the next lesson we will define a substitution-based type system for LAMBDA.

    +

    Go to Lesson 2, Type Systems: Substitution-Based Higher-Order Type Systems.

    +

    MOVIE (out of date) [10'11"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_2/NOTES/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_2/NOTES/index.html new file mode 100644 index 00000000000..b60fcefd682 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_2/NOTES/index.html @@ -0,0 +1,377 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Maybe we should define simply-typed lambda calculus in some earlier +lecture in tutorial 1, and then reuse its examples here.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_2/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_2/index.html new file mode 100644 index 00000000000..80d55159e7e --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_2/index.html @@ -0,0 +1,447 @@ + + + + + + + + + + + + + + +Substitution-Based Higher-Order Type Systems | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Substitution-Based Higher-Order Type Systems

    +

    In this lesson you learn how to define a substitution-based type system for +a higher-order language, namely the LAMBDA language defined in Part 1 of the +tutorial.

    +

    Let us copy the definition of LAMBDA from Part 1 of the tutorial, Lesson 8. +We are going to modify it into a type systems for LAMBDA.

    +

    Before we start, it is important to clarify an important detail, namely that +our type system will yield a type checker when executed, not a type +inferencer. In particular, we are going to change the LAMBDA syntax +to allow us to associate a type to each declared variable. The +constructs which declare variables are lambda, let, letrec and mu. +The syntax of all these will therefore change.

    +

    Since here we are not interested in a LAMBDA semantics anymore, we take the +freedom to eliminate the Val syntactic category, our previous results. +Our new results are going to be the types, because programs will now reduce +to their types.

    +

    As explained, the syntax of the lambda construct needs to change, to also +declare the type of the variable that it binds. We add the new syntactic +category Type, with the following constructs: int, bool, the function +type (which gives it its higher-order status), and parentheses as bracket. +Also, we make types our K results.

    +

    We are now ready to define the typing rules.

    +

    Let us start with the typing rule for lambda abstraction: lambda X : T . E +types to the function type T -> T', where T' is the type obtained by further +typing E[T/X]. This can be elegantly achieved by reducing the lambda +abstraction to T -> E[T/X], provided that we extend the function type construct +to take expressions, not only types, as arguments, and to be strict. +This can be easily achieved by redeclaring it as a strict expression construct +(strictness in the second argument would suffice in this example, but it is +more uniform to define it strict overall).

    +

    The typing rule for application is as simple as it can get: (T1->T2) T1 => T2.

    +

    Let us now give the typing rules of arithmetic and Boolean expression +constructs. First, let us get rid of Val. Second, rewrite each value to its +type, similarly to the type system for IMP++ in the previous lesson. Third, +replace each semantic rule by its typing rule. Fourth, make sure you +do not forget to subsort Type to Exp, so your rules above will parse.

    +

    The typing policy of the conditional statement is that its first argument +should type to bool and its other two arguments should type to the same type +T, which will also be the result type of the conditional. So we make the +conditional construct strict in all its three arguments and we write the +obvious rule: if bool then T:Type else T => T. We want a runtime check that +the latter arguments are actually typed, so we write T:Type.

    +

    There is nothing special about let, except that we have to make sure we +change its syntax to account for the type of the variable that it binds. +This rule is a macro, so the let is desugared statically.

    +

    Similarly, the syntax of letrec and mu needs to change to account for the +type of the variable that they bind. The typing of letrec remains based on +its desugaring to mu; we have to make sure the types are also included now.

    +

    The typing policy of mu is that its body should type to the same type T of +its variable, which is also the type of the entire mu expression. This can +be elegantly achieved by rewriting it to (T -> T) E[T/X]. Recall that +application is strict, so E[T/X] will be eventually reduced to its type. +Then the application types correctly only if that type is also T, and in +that case the result type will also be T.

    +

    kompile and krun some programs. You can, for example, take the LAMBDA +programs from the first tutorial, modify them by adding types to their +variable declarations, and then type check them using krun.

    +

    In the next lesson we will discuss an environment-based type system +for LAMBDA.

    +

    Go to Lesson 3, Type Systems: Environment-Based Higher-Order Type Systems.

    +

    MOVIE (out of date) [6'52"]

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_3/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_3/index.html new file mode 100644 index 00000000000..00abbecbc11 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_3/index.html @@ -0,0 +1,434 @@ + + + + + + + + + + + + + + +Environment-Based Higher-Order Type Systems | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Environment-Based Higher-Order Type Systems

    +

    In this lesson you learn how to define an environment-based type system for +a higher-order language, namely the LAMBDA language defined in Part 1 of the +tutorial.

    +

    The simplest and fastest way to proceed is to copy the substitution-based +type system of LAMBDA from the previous lesson and modify it into an +environment-based one. A large portion of the substitution-based definition +will remain unchanged. We only have to modify the rules that use +substitution.

    +

    We do not need the substitution anymore, so we can remove the require and +import statements. The syntax of types and expressions stays unchanged, but +we can now remove the binder tag of lambda.

    +

    Like in the type system of IMP++ in Lesson 1, we need a configuration that +contains, besides the <k/> cell, a <tenv/> cell that will hold the type +environment.

    +

    In an environment-based definition, unlike in a substitution-based one, we +need to lookup variables in the environment. So let us start with the +type lookup rule:

    +
    rule <k> X:Id => T ...</k> <tenv>... X |-> T ...</k>
    +
    +

    The type environment is populated by the semantic rule of lambda:

    +
    rule <k> lambda X : T . E => (T -> E) ~> Rho ...</k>
    +     <tenv> Rho => Rho[X <- T] </tenv>
    +
    +

    So X is bound to its type T in the type environment, and then T -> E +is scheduled for processing. Recall that the arrow type construct has been +extended into a strict expression construct, so E will be eventually reduced +to its type. Like in other environment-based definitions, we need to make +sure that we recover the type environment after the computation in the scope +of the declared variable terminates.

    +

    The typing rule of application does not change, so it stays as elegant as it +was in the substitution-based definition:

    +
    rule (T1 -> T2) T1 => T2
    +
    +

    So do the rules for arithmetic and Boolean constructs, and those for the +if, and let, and letrec.

    +

    The mu rule needs to change, because it was previously defined using +substitution. We modify it in the same spirit as we modified the lambda +rule: bind X to its type in the environment, schedule its body for typing +in its right context, and then recover the type environment.

    +

    Finally, we give the semantics of environment recovery, making sure +the environment is recovered only after the preceding computation is +reduced to a type:

    +

    rule _:Type ~> (Rho => .) ... _ => Rho

    +

    The changes that we applied to the substitution-based definition were +therefore quite systematic: each substitution invocation was replaced with +an appropriate type environment update/recovery.

    +

    Go to Lesson 4, Type Systems: A Naive Substitution-Based Type Inferencer.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_4/NOTES/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_4/NOTES/index.html new file mode 100644 index 00000000000..90cdc25aa2e --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_4/NOTES/index.html @@ -0,0 +1,380 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    The README needs to be changed to reflect the fact that we now have a builtin +unification procedure. We may even want to merge this lecture with the +next one, and eliminate the approach where we throw equalities on the computation. +This needs some more thinking, though, especialy on how to smoothly glue it +with Lesson 6, where we also use equalities.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_4/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_4/index.html new file mode 100644 index 00000000000..41b7045f341 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_4/index.html @@ -0,0 +1,577 @@ + + + + + + + + + + + + + + +A Naive Substitution-Based Type Inferencer | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    A Naive Substitution-Based Type Inferencer

    +

    In this lesson you learn how to define a naive substitution-based type +inferencer for a higher-order language, namely the LAMBDA language +defined in Part 1 of the tutorial.

    +

    Unlike in the type checker defined in Lessons 2 and 3, where we had to +associate a type with each declared variable, a type inferencer +attempts to infer the types of all the variables from the way those +variables are used. Let us take a look at this program, say plus.lambda:

    +
    lambda x . lambda y . x + y
    +
    +

    Since x and y are used in an integer addition context, we can infer +that they must have the type int and the result of the addition is +also an int, so the type of the entire expression is int -> int -> int. +Similarly, the program if.lambda

    +
    lambda x . lambda y . lambda z .
    +  if x then y else z
    +
    +

    can only make sense when x has type bool and y and z have the same +type, say t, in which case the type of the entire expression is +bool -> t -> t -> t. Since the type t can be anything, we say that +the type of this expression is polymorphic. That means that the code +above can be used in different contexts, where t can be an int, a +bool, a function type int -> int, and so on.

    +

    In the identity.lambda program

    +
    let f = lambda x . x
    +in f 1
    +
    +

    f has such a polymorphic type, which is then applied to an integer, +so this program is type-safe and its type is int.

    +

    A typical polymorphic expression is the composition

    +
    lambda f . lambda g . lambda x .
    +  g (f x)
    +
    +

    which has the type (t1 -> t2) -> (t2 -> t3) -> (t1 -> t3), polymorphic +in 3 types.

    +

    Let us now define our naive type inferencer and then we discuss more +examples. The idea is quite simple: we conceptually do the same +operations like we did within the type checker defined in Lesson 2, +with two important differences:

    +
      +
    1. instead of declaring a type with each declared variable, we assume +a fresh type for that variable; and
    2. +
    3. instead of checking that the types of expressions satisfy the +type properties of the context in which they are used, we impose +those properties as type equality constraints. A general-purpose +unification-based constraint solving mechanism is then used to solve +the generated type constraints.
    4. +
    +

    Let us start with the syntax, which is essentially identical to that +of the type checker in Lesson 2, except that bound variables are not +declared a type anymore. Also, to keep things more compact, we put +all the Exp syntax declarations in one syntax declaration this time.

    + +

    Before we modify the rules, let us first define our machinery for +adding and solving constraints. First, we require and import the +unification procedure. We do not discuss unification here, but if you +are interested you can consult the unification.k files under +k-distribution/include/kframework/builtin, which contains our current generic +definition of unification, which is written also in K. The generic unification +provides a sort, Mgu, for most-general-unifier, an operation +updateMgu(Mgu,T1,T2) which updates Mgu with additional constraints +generated by forcing the terms T1 and T2 to be equal, and an operation +applyMgu(Mgu,T) which applies Mgu to term T. For our use +of unification here, we do not even need to know how Mgu terms are +represented internally.

    +

    We define a K item construct, =, which takes two Type terms and +enforces them to be equal by means of updating the current Mgu. +Once the constraints are added to the Mgu, the equality dissolves +itself. With this semantics of = in mind, we can now go ahead and +modify the rules of the type checker systematically into rules +for a type inferencer. The changes are self-explanatory and +mechanical: for example, the rule

    +
    rule int * int => int
    +
    +

    changes into rule

    +
    rule T1:Type  * T2:Type => T1 = int ~> T2 = int ~> int
    +
    +

    generating the constraints that the two arguments of multiplication +have the type int, and the result type is int. Recall that each type +equality on the <k/> cell updates the current Mgu appropriately and +then dissolves itself; thus, the above says that after imposing the +constraints T1=int and T2=int, multiplication yields a type int.

    +

    As mentioned above, since types of variables are not declared anymore, +but inferred, we have to generate a fresh type for each variable at its +declaration time, and then generate appropriately constraints for it. +For example, the type semantics of lambda and mu become:

    +
    rule lambda X . E => T -> E[T/X]  when fresh(T:Type)
    +rule mu X . E => (T -> T) E[T/X]  when fresh(T:Type)
    +
    +

    that is, we add a condition stating that the previously declared type +is now a fresh one. This type will be further constrained by how the +variable X is being used within E.

    +

    Interestingly, the previous typing rule for lambda application is not +powerful enough anymore. Indeed, since types are not given anymore, +it may very well be the case that the inferred type of the first +argument of the application construct is not yet a function type +(remember, for example, the program composition.lambda above). What +we have to do is to enforce it to be a function type, by means of +fresh types and constraints. We can introduce a fresh type for the +result of the application, and then write the expected rule as +follows:

    +
    rule T1:Type T2:Type => T1 = (T2 -> T) ~> T  when fresh(T:Type)
    +
    +

    The conditional requires that its first argument is a bool and its +second and third arguments have the same type, which is also the +result type.

    +

    The macros do not change, in particular let is desugared into lambda +application. We will next see that this is a significant restriction, +because it limits the polymorphism of our type system.

    +

    We are done. We have a working type inferencer for LAMBDA.

    +

    Let's kompile it and krun the programs above. They all work as +expected. Let us also try some additional programs, to push it to its +limits.

    +

    First, let us test mu by means of a letrec example:

    +
    letrec f x = 3
    +in f
    +
    +

    We can also try all the programs that we had in our first tutorial, on +lambda, for example the factorial.imp program:

    +
    letrec f x = if x <= 1 then 1 else (x * (f (x + -1)))
    +in (f 10)
    +
    +

    Those programs are simple enough that they should all work as +expected with our naive type inferencer here.

    +

    Let us next try to type some tricky programs, which involve more +complex and indirect type constraints.

    +

    tricky-1.lambda:

    +
    lambda f . lambda x . lambda y . (
    +  (f x y) + x + (let x = y in x)
    +)
    +
    +

    tricky-2.lambda:

    +
    lambda x .
    +  let f = lambda y . if true then y else x
    +  in (lambda x . f 0)
    +
    +

    tricky-3.lambda:

    +
    lambda x . let f = lambda y . if true then x 7 else x y
    +           in f
    +
    +

    tricky-4.lambda:

    +
    lambda x . let f = lambda x . x
    +           in let d = (f x) + 1
    +              in x
    +
    +

    tricky-5.lambda:

    +
    lambda x . let f = lambda y . x y
    +           in let z = x 0 in f
    +
    +

    It is now time to see the limitations of this naive type inferencer. +Consider the program

    +
    let id = lambda x . x
    +in if (id true) then (id 1) else (id 2)
    +
    +

    Our type inferencer fails graciously with a clash in the <mgu/> cell +between int and bool. Indeed, the desugaring macro of let turns it +into a lambda and an application, which further enforce id to have a +type of the form t -> t for some fresh type t. The first use of id +in the condition of if will then constrain t to be bool, while the +other uses in the two branches will enforce t to be int. Thus the +clash in the <mgu/> cell.

    +

    Similarly, the program

    +
    let id = lambda x . x
    +in id id
    +
    +

    yields a different kind of conflict: if id has type t -> t, in order +to apply id to itself it must be the case that its argument, t, equals +t -> t. These two type terms cannot be unified because there is a +circular dependence on t, so we get a cycle in the <mgu/> cell.

    +

    Both limitations above will be solved when we change the semantics of +let later on, to account for the desired polymorphism.

    +

    Before we conclude this lesson, let us see one more interesting +example, where the lack of let-polymorphism leads not to a type error, +but to a less generic type:

    +
    let f1 = lambda x . x in
    +  let f2 = f1 in
    +    let f3 = f2 in
    +      let f4 = f3 in
    +        let f5 = f4 in
    +          if (f5 true) then f2 else f3
    +
    +

    Our current type inferencer will infer the type bool -> bool for the +program above. Nevertheless, since all functions f1, f2, f3, f4, f5 +are the identity function, which is polymorphic, we would expect the +entire program to type to the same polymorphic identity function type.

    +

    This limitation will be also addressed when we define our +let-polymorphic type inferencer.

    +

    Before that, in the next lesson we will show how easily we can turn +the naive substitution-based type inferencer discussed in this lesson +into a similarly naive, but environment-based type inferencer.

    +

    Go to Lesson 5, Type Systems: A Naive Environment-Based Type Inferencer.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_5/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_5/index.html new file mode 100644 index 00000000000..0d9d5c24a42 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_5/index.html @@ -0,0 +1,433 @@ + + + + + + + + + + + + + + +A Naive Environment-Based Type Inferencer | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    A Naive Environment-Based Type Inferencer

    +

    In this lesson you learn how to define a naive environment-based type +inferencer for a higher-order language. Specifically, we take the +substitution-based type inferencer for LAMBDA defined in Lesson 4 and +turn it into an environment-based one.

    +

    Recall from Lesson 3, where we defined an environment-based type +checker for LAMBDA based on the substitution-based one in Lesson 2, +that the transition from a substitution-based definition to an +environment-based one was quite systematic and mechanical: each +substitution occurrence E[T/X] is replaced by E, but at the same time +the variable X is bound to type T in the type environment. One benefit +of using type environments instead of substitution is that we replace +a linear complexity operation (the substitution) with a constant +complexity one (the variable lookup).

    +

    There is not much left to say which has not been already said in +Lesson 3: we remove the unnecessary binder annotations for the +variable binding operations, then add a <tenv/> cell to the +configuration to hold the type environment, then add a new rule for +variable lookup, and finally apply the transformation of substitutions +E[T/X] into E as explained above.

    +

    The resulting type inferencer should now work exactly the same way as +the substitution-based one, except, of course, that the resulting +configurations will contain a <tenv/> cell now.

    +

    As sanity check, let us consider two more LAMBDA programs that test +the static scoping nature of the inferencer. We do that because +faulty environment-based definitions often have this problem. The +program

    +
    let x = 1
    +in let f = lambda a . x
    +   in let x = true
    +      in f 3
    +
    +

    should type to int, not to bool, and so it does. Similarly, the +program

    +
    let y = 0
    +in letrec f x = if x <= 0
    +                then y
    +                else let y = true
    +                     in f (x + 1)
    +   in f 1
    +
    +

    should also type to int, not bool, and so it does, too.

    +

    The type inferencer defined in this lesson has the same limitations, +in terms of polymorphism, as the one in Lesson 4. In the next +lesson we will see how it can be parallelized, and in further lessons +how to make it polymorphic.

    +

    Go to Lesson 6, Type Systems: Parallel Type Checkers/Inferencers.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_6/NOTES/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_6/NOTES/index.html new file mode 100644 index 00000000000..ece4a1c6af7 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_6/NOTES/index.html @@ -0,0 +1,377 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    The README needs to be changed to reflect the fact that we now have a builtin +unification procedure.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_6/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_6/index.html new file mode 100644 index 00000000000..11d3bce844b --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_6/index.html @@ -0,0 +1,487 @@ + + + + + + + + + + + + + + +Parallel Type Checkers/Inferencers | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Parallel Type Checkers/Inferencers

    +

    In this lesson you learn how to define parallel type checkers or +inferencers. For the sake of a choice, we will parallelize the one in +the previous lesson, but the ideas are general. We are using the same +idea to define type checkers for other languages in the K tool +distribution, such as SIMPLE and KOOL.

    +

    The idea is in fact quite simple. Instead of one monolithic typing +task, we generate many smaller tasks, which can be processed in +parallel. We use the same approach to define parallel semantics as we +used for threads in IMP++ in Part 4 of the tutorial, that is, we add a +cell holding all the parallel tasks, making sure we declare the cell +holding a task with multiplicity *. For the particular type +inferencer that we chose here, the one in Lesson 5, each task will +hold an expression to type together with a type environment (so it +knows where to lookup its free variables). We have the following +configuration then:

    +
    configuration <tasks color="yellow">
    +                <task color="orange" multiplicity="*">
    +                  <k color="green"> $PGM:Exp </k>
    +                  <tenv color="red"> .Map </tenv>
    +                </task>
    +              </tasks>
    +              <mgu color="blue"> .Mgu </mgu>
    +
    +

    Now we have to take each typing rule we had before and change it to +yield parallel typing. For example, our rule for typing +multiplication was the following in Lesson 5:

    +
    rule T1:Type * T2:Type => T1 = int ~> T2 = int ~> int
    +
    +

    Since * was strict, its two arguments eventually type, and once that +happens the rule above fires. Unfortunately, the strictness of +multiplication makes the typing of the two expressions sequential in +our previous definition. To avoid typing the two expressions +sequentially and instead generating two parallel tasks, we remove the +strict attribute of multiplication and replace the rule above with the +following:

    +
    rule <k> E1 * E2 => int ...</k> <tenv> Rho </tenv>
    +     (. => <task> <k> E1 = int </k> <tenv> Rho </tenv> </task>
    +           <task> <k> E2 = int </k> <tenv> Rho </tenv> </task>)
    +
    +

    Therefore, we generate two tasks for typing E1 and E2 in the same type +environment as the current task, and let the current task continue by +simply optimistically reducing E1*E2 to its expected result type, int. +If E1 or E2 will not type to int, then either their corresponding +tasks will get stuck or the <mgu/> cell will result into a clash or cycle, +so the program will not type overall in spite of the fact that we +allowed the task containing the multiplication to continue. This is +how we get maximum of parallelism in this case.

    +

    Before we continue, note that the new tasks hold equalities in them, +where one of its arguments is an expression, while previously the +equality construct was declared to take types. What we want now is +for the equality construct to possibly take any expressions, and first +type them and then generate the type constraint like before. This can +be done very easily by just extending the equality construct to +expressions and declaring it strict:

    +
    syntax KItem ::= Exp "=" Exp  [strict]
    +
    + +

    Unlike before, where we only passed types to the equality construct, +we now need a runtime check that its arguments are indeed types before +we can generate the updateMgu command:

    +
    rule <k> T:Type = T':Type => . ...</k>
    +     <mgu> Theta:Mgu => updateMgu(Theta,T,T') </mgu>
    +
    +

    Like before, an equality will therefore update the <mgu/> cell and then +it dissolves itself, letting the <k/> cell in the corresponding task +empty. Such empty tasks are unnecessary, so they can be erased:

    +
    rule <task>... <k> . </k> ...</task> => .
    +
    +

    We can now follow the same style as for multiplication to write the +parallel typing rules of the other arithmetic constructs, and even for +the conditional.

    +

    To parallelize the typing of lambda we generate two fresh types, one +for the variable and one for the body, and make sure that we generate +the correct type constraint and environment in the body task:

    +
    rule <k> lambda X . E => Tx -> Te ...</k> <tenv> TEnv </tenv>
    +     (. => <task> <k> E = Te </k> <tenv> TEnv[Tx/X] </tenv> </task>)
    +  when fresh(Tx:Type) andBool fresh(Te:Type)
    +
    +

    Note that the above also allows us to not need to change and then +recover the environment of the current cell.

    +

    For function application we also need to generate two fresh types:

    +
    rule <k> E1 E2 => T ...</k> <tenv> Rho </tenv>
    +     (. => <task> <k> E1 = T2 -> T </k> <tenv> Rho </tenv> </task>
    +           <task> <k> E2 = T2 </k> <tenv> Rho </tenv> </task>)
    +  when fresh(T2:Type) andBool fresh(T:Type)
    +
    +

    The only rule left is that of mu X . E. In this case we only need one +fresh type, because X, E and mu X . E have all the same type:

    +
    rule <k> mu X . E => T ...</k>  <tenv> TEnv </tenv>
    +     (. => <task> <k> E = T </k> <tenv> TEnv[T/X] </tenv> </task>)
    +  when fresh(T:Type)
    +
    +

    We do not need the type environment recovery operation, so we delete it.

    +

    We can now kompile and krun all the programs that we typed in Lesson 5. +Everything should work.

    +

    In this lesson we only aimed at parallelizing the type inferencer in +Lesson 5, not to improve its expressiveness; it still has the same +limitations in terms of polymorphism. The next lessons are dedicated +to polymorphic type inferencers.

    +

    Go to Lesson 7, Type Systems: A Naive Substitution-based Polymorphic Type Inferencer.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_7/NOTES/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_7/NOTES/index.html new file mode 100644 index 00000000000..dee3b68852f --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_7/NOTES/index.html @@ -0,0 +1,378 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    This approach leads to an incorrect type checker, in that programs which +lead to a runtime error will type. See tricky-5 and/or variations of it.

    +

    Discuss monomorphic vs. polymorphic types and type inferencers.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_7/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_7/index.html new file mode 100644 index 00000000000..332042338bd --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_7/index.html @@ -0,0 +1,492 @@ + + + + + + + + + + + + + + +A Naive Substitution-based Polymorphic Type Inferencer | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    A Naive Substitution-based Polymorphic Type Inferencer

    +

    In this lesson you learn how little it takes to turn a naive monomorphic +type inferencer into a naive polymorphic one, basically only changing +a few characters. In terms of the K framework, you will learn that +you can have complex combinations of substitutions in K, both over +expressions and over types.

    +

    Let us start directly with the change. All we have to do is to take +the LAMBDA type inferencer in Lesson 4 and only change the macro

    +
    rule let X = E in E' => (lambda X . E') E  [macro]
    +
    +

    as follows:

    +
    rule let X = E in E' => E'[E/X]  [macro]
    +
    +

    In other words, we are inlining the beta-reduction rule of +lambda-calculus within the original rule. In terms of typing, +the above forces the type inferencer to type E in place for each +occurrence of X in E'. Unlike in the first rule, where X had to get +one type only which satisfied the constrains of all X's occurrences in +E', we now never associate any type to X anymore.

    +

    Let us kompile and krun some examples. Everything that worked with +the type inferencer in Lesson 4 should still work here, although the +types of some programs can now be more general. For example, reconsider +the nested-lets.lambda program

    +
    let f1 = lambda x . x in
    +  let f2 = f1 in
    +    let f3 = f2 in
    +      let f4 = f3 in
    +        let f5 = f4 in
    +          if (f5 true) then f2 else f3
    +
    +

    which was previously typed to bool -> bool. With the new rule above, +the sequence of lets is iteratively eliminated and we end up with the +program

    +
    if (lambda x . x) true then (lambda x . x) else (lambda x . x)
    +
    +

    which now types (with both type inferencers) to a type of the form +t -> t, for some type variable t, which is more general than the +previous bool -> bool type that the program typed to in Lesson 4.

    +

    We can also now type programs that were not typable before, such as

    +
    let id = lambda x . x
    +in if (id true) then (id 1) else (id 2)
    +
    +

    and

    +
    let id = lambda x . x
    +in id id
    +
    +

    Let us also test it on some trickier programs, also not typable +before, such as

    +
    let f = lambda x . x
    +in let g = lambda y . f y
    +   in g g
    +
    +

    which gives us a type of the form t -> t for some type variable t, +and as

    +
    let f = let g = lambda x . x
    +        in let h = lambda x . lambda x . (g g g g)
    +           in h
    +in f
    +
    +

    which types to t1 -> t2 -> t3 -> t3 for some type variables t1, t2, t3.

    +

    Here is another program which was not typable before, which is +trickier than the others above in that a lambda-bound variable appears +free in a let-bound expression:

    +
    lambda x . (
    +  let y = lambda z . x
    +  in if (y true) then (y 1) else (y (lambda x . x))
    +)
    +
    +

    The above presents no problem now, because once lambda z . x gets +substituted for y we get a well-typed expression which yields that x +has the type bool, so the entire expression types to bool -> bool.

    +

    The cheap type inferencer that we obtained above therefore works as +expected. However, it has two problems which justify a more advanced +solution. First, substitution is typically considered an elegant +mathematical instrument which is not too practical in implementations, +so an implementation of this type inferencer will likely be based on +type environments anyway. Additionally, we mix two kinds of +substitutions in this definition, one where we substitute types and +another where we substitute expressions, which can only make things +harder to implement efficiently. Second, our naive substitution of E +for X in E' can yield an exponential explosion in size of the original +program. Consider, for example, the following classic example which +is known to generate a type whose size is exponential in the size of +the program (and is thus used as an argument for why let-polymorphic +type inference is exponential in the worst-case):

    +
    let f00 = lambda x . lambda y . x in
    +  let f01 = lambda x . f00 (f00 x) in
    +    let f02 = lambda x . f01 (f01 x) in
    +      let f03 = lambda x . f02 (f02 x) in
    +        let f04 = lambda x . f03 (f03 x) in
    +          // ... you can add more nested lets here
    +          f04
    +
    +

    The particular instance of the pattern above generates a type which +has 17 type variables! The desugaring of each let doubles the size of +the program and of its resulting type. While such programs are little +likely to appear in practice, it is often the case that functions can +be quite complex and large while their type can be quite simple in the +end, so we should simply avoid retyping each function each time it is +used.

    +

    This is precisely what we will do next. Before we present the classic +let-polymorphic type inferencer in Lesson 9, which is based on +environments, we first quickly discuss in Lesson 8 an intermediate +step, namely a naive environment-based variant of the inferencer +defined here.

    +

    Go to Lesson 8, Type Systems: A Naive Environment-based Polymorphic Type Inferencer.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_8/NOTES/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_8/NOTES/index.html new file mode 100644 index 00000000000..1bd55f68c5c --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_8/NOTES/index.html @@ -0,0 +1,377 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    We also have to redeclare lambda and mu as binders. Program +tricky-2.lambda shows why.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_8/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_8/index.html new file mode 100644 index 00000000000..0929b457054 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_8/index.html @@ -0,0 +1,425 @@ + + + + + + + + + + + + + + +A Naive Environment-based Polymorphic Type Inferencer | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    A Naive Environment-based Polymorphic Type Inferencer

    +

    In this short lesson we discuss how to quickly turn a naive +environment-based monomorphic type inferencer into a naive let-polymorphic +one. Like in the previous lesson, we only need to change a few +characters. In terms of the K framework, you will learn how to have +both environments and substitution in the same definition.

    +

    Like in the previous lesson, all we have to do is to take the LAMBDA +type inferencer in Lesson 5 and only change the rule

    +
    rule let X = E in E' => (lambda X . E') E
    +
    +

    as follows:

    +
    rule let X = E in E' => E'[E/X]
    +
    +

    The reasons why this works have already been explained in the previous +lesson, so we do not repeat them here.

    +

    Since our new let rule uses substitution, we have to require the +substitution module at the top and also import SUBSTITUTION in the +current module, besides the already existing UNIFICATION.

    +

    Everything which worked with the type inferencer in Lesson 7 should +also work now. Let us only try the exponential type example,

    +
    let f00 = lambda x . lambda y . x in
    +  let f01 = lambda x . f00 (f00 x) in
    +    let f02 = lambda x . f01 (f01 x) in
    +      let f03 = lambda x . f02 (f02 x) in
    +        let f04 = lambda x . f03 (f03 x) in
    +          f04
    +
    +

    As expected, this gives us precisely the same type as in Lesson 7.

    +

    So the only difference between this type inferencer and the one in +Lesson 7 is that substitution is only used for LAMBDA-to-LAMBDA +transformations, but not for infusing types within LAMBDA programs. +Thus, the syntax of LAMBDA programs is preserved intact, which some +may prefer. Nevertheless, this type inferencer is still expensive and +wasteful, because the let-bound expression is typed over and over +again in each place where the let-bound variable occurs.

    +

    In the next lesson we will discuss a type inferencer based on the +classic Damas-Hindley-Milner type system, which maximizes the reuse of +typing work by means of parametric types.

    +

    Go to Lesson 9, Type Systems: Let-Polymorphic Type Inferencer (Damas-Hindley-Milner).

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_9.5/NOTES/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_9.5/NOTES/index.html new file mode 100644 index 00000000000..9f3647dceb9 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_9.5/NOTES/index.html @@ -0,0 +1,376 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    We have to test this as well; we need a test folder with a config.xml.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/5_types/lesson_9/index.html b/k-distribution/pl-tutorial/1_k/5_types/lesson_9/index.html new file mode 100644 index 00000000000..f7503b6d306 --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/5_types/lesson_9/index.html @@ -0,0 +1,542 @@ + + + + + + + + + + + + + + +Let-Polymorphic Type Inferencer (Damas-Hindley-Milner) | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Let-Polymorphic Type Inferencer (Damas-Hindley-Milner)

    +

    In this lesson we discuss a type inferencer based on what we call today +the Damas-Hindley-Milner type system, which is at the core of many +modern functional programming languages. The first variant of it was +proposed by Hindley in 1969, then, interestingly, Milner rediscovered +it in 1978 in the context of the ML language. Damas formalized it as +a type system in his PhD thesis in 1985. More specifically, our type +inferencer here, like many others as well as many implementations of +it, follows more closely the syntax-driven variant proposed by Clement +in 1987.

    +

    In terms of K, we will see how easily we can turn one definition which +is considered naive (our previous type inferencer in Lesson 8) into a +definition which is considered advanced. All we have to do is to +change one existing rule (the rule of the let binder) and to add a new +one. We will also learn some new predefined features of K, which make +the above possible.

    +

    The main idea is to replace the rule

    +
    rule let X = E in E' => E'[E/X]
    +
    +

    which creates potentially many copies of E within E' with a rule +which types E once and then reuses that type in each place where X +occurs free in E'. The simplest K way to type E is to declare the +let construct strict(2). Now we cannot simply bind X to the type +of E, because we would obtain a variant of the naive type inferencer +we already discussed, together with its limitations, in Lesson 5 of this +tutorial. The trick here is to parameterize the type of E in all its +unconstrained fresh types, and then create fresh copies of those +parameters in each free occurrence of X in E'.

    +

    Let us discuss some examples, before we go into the technical details. +Consider the first let-polymorphic example which failed to be typed +with our first naive type-inferencer:

    +
    let id = lambda x . x
    +in if (id true) then (id 1) else (id 2)
    +
    +

    When typing lambda x . x, we get a type of the form t -> t, for some +fresh type t. Instead of assigning this type to id as we did in the +naive type inferencers, we now first parametrize this type in its +fresh variable t, written

    +
    (forall t) t -> t
    +
    +

    and then bind id to this parametric type. The intuition for the +parameter is that it can be instantiated with any other type, so this +parametric type stands, in fact, for infinitely many non-parametric +types. This is similar to what happens in formal logic proof systems, +where rule schemas stand for infinitely many concrete instances of +them. For this reason, parametric types are also called type schemas.

    +

    Now each time id is looked up within the let-body, we create a fresh +copy of the parameter t, which can this way be independently +constrained by each local context. Let's suppose that the three id +lookups yield the types t1 -> t1, t2 -> t2, and respectively t3 -> t3. +Then t1 will be constrained to be bool, and t2 and t3 to be int, +so we can now safely type the program above to int.

    +

    Therefore, a type schema comprises a summary of all the typing work +that has been done for typing the corresponding expression, and an +instantiation of its parameters with fresh copies represents an +elegant way to reuse all that typing work.

    +

    There are some subtleties regarding what fresh types can be made +parameters. Let us consider another example, discussed as part of +Lesson 7 on naive let-polymorphism:

    +
    lambda x . (
    +  let y = lambda z . x
    +  in if (y true) then (y 1) else (y (lambda x . x))
    +)
    +
    +

    This program should type to bool -> bool, as explained in Lesson 7. +The lambda construct will bind x to some fresh type tx. Then the +let-bound expression lambda z . x types to tz -> tx for some +additional fresh type tz. The question now is what should the +parameters of this type be when we generate the type schema? If we +naively parameterize in all fresh variables, that is in both tz and +tx obtaining the type schema (forall tz,tx) tz -> tx, then there will +be no way to infer that the type of x, tx, must be a bool! The +inferred type of this expression would then wrongly be tx -> t for +some fresh types tx and t. That's because the parameters are replaced +with fresh copies in each occurrence of y, and thus their relationship +to the original x is completely lost. This tells us that we cannot +parameterize in all fresh types that appear in the type of the +let-bound expression. In particular, we cannot parameterize in those +which some variables are already bound to in the current type +environment (like x is bound to tx in our example above). +In our example, the correct type schema is (forall tz) tz -> tx, +which now allows us to correctly infer that tx is bool.

    +

    Let us now discuss another example, which should fail to type:

    +
    lambda x .
    +  let f = lambda y . x y
    +  in if (f true) then (f 1) else (f 2)
    +
    +

    This should fail to type because lambda y . x y is equivalent to x, +so the conditional imposes the conflicting constraints that x should be +a function whose argument is either a bool or an int. Let us try to +type it using our currently informal procedure. Like in the previous +example, x will be bound to a fresh type tx. Then the let-bound +expression types to ty -> tz with ty and tz fresh types, adding also +the constraint tx = ty -> tz. What should the parameters of this type +be? If we ignore the type constraint and simply make both ty and tz +parameters because no variable is bound to them in the type +environment (indeed, the only variable x in the type environment is +bound to tx), then we can wrongly type this program to tx -> tz +following a reasoning similar to the one in the example above. +In fact, in this example, none of ty and tz can be parameters, because +they are constrained by tx.

    +

    The examples above tell us two things: first, that we have to take the +type constraints into account when deciding the parameters of the +schema; second, that after applying the most-general-unifier solution +given by the type constraints everywhere, the remaining fresh types +appearing anywhere in the type environment are consequently constrained +and cannot be turned into parameters. Since the type environment can in +fact also hold type schemas, which already bind some types, we only need +to ensure that none of the fresh types appearing free anywhere in the +type environment are turned into parameters of type schemas.

    +

    Thanks to generic support offered by the K tool, we can easily achieve +all the above as follows.

    +

    First, add syntax for type schemas:

    +
    syntax TypeSchema ::= "(" "forall" Set ")" Type  [binder]
    +
    +

    The definition below will be given in such a way that the Set argument +of a type schema will always be a set of fresh types. We also declare +this construct to be a binder, so that we can make use of the generic +free variable function provided by the K tool.

    +

    We now replace the old rule for let

    +
    rule let X = E in E' => E'[E/X]
    +
    +

    with the following rule:

    +
    rule <k> let X = T:Type in E => E ~> tenv(TEnv) ...</k>
    +     <mgu> Theta:Mgu </mgu>
    +     <tenv> TEnv
    +      => TEnv[(forall freeVariables(applyMgu(Theta, T)) -Set
    +                      freeVariables(applyMgu(Theta, values TEnv))
    +              ) applyMgu(Theta, T) / X]
    +     </tenv>
    +
    +

    So the type T of E is being parameterized and then bound to X in the +type environment. The current mgu Theta, which comprises all the type +constraints accumulated so far, is applied to both T and the types in +the type environment. The remaining fresh types in T which do not +appear free in the type environment are then turned into type parameters. +The function freeVariables returns, as expected, the free variables of +its argument as a Set; this is why we declared the type schema to be a +binder above.

    +

    Now a LAMBDA variable in the type environment can be bound to either a +type or a type schema. In the first case, the previous rule we had +for variable lookup can be reused, but we have to make sure we check +that T there is of sort Type (adding a sort membership, for example). +In the second case, as explained above, we have to create fresh copies +of the parameters. This can be easily achieved with another +predefined K function, as follows:

    +
    rule <k> X:Id => freshVariables(Tvs,T) ...</k>
    +     <tenv>... X |-> (forall Tvs) T ...</tenv>
    +
    +

    Indeed, freshVariables takes a set of variables and a term, and returns the +same term but with each of the given variables replaced by a fresh copy.

    +

    The operations freeVariables and freshVariables are useful in many K +definitions, so they are predefined in module substitution.k.

    +

    Our definition of this let-polymorphic type inferencer is now +complete. To test it, kompile it and then krun all the LAMBDA +programs discussed since Lesson 4. They should all work as expected.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/1_k/index.html b/k-distribution/pl-tutorial/1_k/index.html new file mode 100644 index 00000000000..197d825f1bb --- /dev/null +++ b/k-distribution/pl-tutorial/1_k/index.html @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + +Learning K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Learning K

    +

    We start by introducing the basic features of K by means of a series +of very simple languages. The objective here is neither to learn those +languages nor to study their underlying paradigm, but simply to learn K.

    +
      +
    • LAMBDA: Lambda calculus defined.
    • +
    • IMP: A simple imperative language.
    • +
    • LAMBDA++: LAMBDA extended with control flow.
    • +
    • IMP++: IMP extended with threads and IO.
    • +
    • TYPES: LAMBDA type system.
    • +
    +
    +
    + + +
    + + + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/2_languages/1_simple/1_untyped/NOTES/index.html b/k-distribution/pl-tutorial/2_languages/1_simple/1_untyped/NOTES/index.html new file mode 100644 index 00000000000..aa7352a356b --- /dev/null +++ b/k-distribution/pl-tutorial/2_languages/1_simple/1_untyped/NOTES/index.html @@ -0,0 +1,393 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    This is not well tested now, and it was not well tested in v3.6 either. +We should add some rules as transitions, too, and then use search on all +the examples.

    +

    Exercises not revised yet.

    +

    .Bag should be . throughout this definition #1772

    +

    There seems to be a problem with defining auxiliary constructs of sort +KItem when we want to use them as a particular sort in rule. We had to +declare them as construct for that sort instead. May want to explain +this a bit in the Latex discussion (related to #1803):

    +
      +
    • syntax Exp ::= lookup(Int)
    • +
    +
      +
    • syntax KItem ::= lookup(Int)
    • +
    +

    We currently add Vals to KResult, but we should have a better pattern for +List{Sort} and in general for any collections, where we make them hybrid +(they become KResults when their elements become KResults)

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/2_languages/1_simple/1_untyped/simple-untyped/index.html b/k-distribution/pl-tutorial/2_languages/1_simple/1_untyped/simple-untyped/index.html new file mode 100644 index 00000000000..3258b78b039 --- /dev/null +++ b/k-distribution/pl-tutorial/2_languages/1_simple/1_untyped/simple-untyped/index.html @@ -0,0 +1,1709 @@ + + + + + + + + + + + + + + +SIMPLE — Untyped | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    SIMPLE — Untyped

    +

    Author: Grigore Roșu (grosu@illinois.edu)
    +Organization: University of Illinois at Urbana-Champaign

    +

    Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
    +Organization: University of Bucharest

    +

    Abstract

    +

    This is the K semantic definition of the untyped SIMPLE language. +SIMPLE is intended to be a pedagogical and research language that captures +the essence of the imperative programming paradigm, extended with several +features often encountered in imperative programming languages. +A program consists of a set of global variable declarations and +function definitions. Like in C, function definitions cannot be +nested and each program must have one function called main, +which is invoked when the program is executed. To make it more +interesting and to highlight some of K's strengths, SIMPLE includes +the following features in addition to the conventional imperative +expression and statement constructs:

    +
      +
    • +

      Multidimensional arrays and array references. An array evaluates +to an array reference, which is a special value holding a location (where +the elements of the array start) together with the size of the array; +the elements of the array can be array references themselves (particularly +when the array is multi-dimensional). Array references are ordinary values, +so they can be assigned to variables and passed/received by functions.

      +
    • +
    • +

      Functions and function values. Functions can have zero or +more parameters and can return abruptly using a return statement. +SIMPLE follows a call-by-value parameter passing style, with static scoping. +Function names evaluate to function abstractions, which hereby become ordinary +values in the language, same like the array references.

      +
    • +
    • +

      Blocks with locals. SIMPLE variables can be declared +anywhere, their scope being from the place where they are declared +until the end of the most nested enclosing block.

      +
    • +
    • +

      Input/Output. The expression read() evaluates to the +next value in the input buffer, and the statement write(e) +evaluates e and outputs its value to the output buffer. The +input and output buffers are lists of values.

      +
    • +
    • +

      Exceptions. SIMPLE has parametric exceptions (the value thrown as +an exception can be caught and bound).

      +
    • +
    • +

      Concurrency via dynamic thread creation/termination and +synchronization. One can spawn a thread to execute any statement. +The spawned thread shares with its parent its environment at creation time. +Threads can be synchronized via a join command which blocks the current thread +until the joined thread completes, via re-entrant locks which can be acquired +and released, as well as through rendezvous commands.

      +
    • +
    +

    Like in many other languages, some of SIMPLE's constructs can be +desugared into a smaller set of basic constructs. We do that at the end +of the syntax module, and then we only give semantics to the core constructs.

    +

    Note: This definition is commented slightly more than others, because it is +intended to be one of the first non-trivial definitions that the new +user of K sees. We recommend the beginner user to first check the +language definitions discussed in the K tutorial.

    +
    k
    module SIMPLE-UNTYPED-SYNTAX + imports DOMAINS-SYNTAX +
    +

    Syntax

    +

    We start by defining the SIMPLE syntax. The language constructs discussed +above have the expected syntax and evaluation strategies. Recall that in K +we annotate the syntax with appropriate strictness attributes, thus giving +each language construct the desired evaluation strategy.

    +

    Identifiers

    +

    Recall from the K tutorial that identifiers are builtin and come under the +syntactic category Id. The special identifier for the function +main belongs to all programs, and plays a special role in the semantics, +so we declare it explicitly. This would not be necessary if the identifiers +were all included automatically in semantic definitions, but that is not +possible because of parsing reasons (e.g., K variables used to match +concrete identifiers would then be ambiguously parsed as identifiers). They +are only included in the parser generated to parse programs (and used by the +kast tool). Consequently, we have to explicitly declare all the +concrete identifiers that play a special role in the semantics, like +main below.

    +
    k
    syntax Id ::= "main" [token] +
    +

    Declarations

    +

    There are two types of declarations: for variables (including arrays) and +for functions. We are going to allow declarations of the form +var x=10, a[10,10], y=23;, which is why we allow the var +keyword to take a list of expressions. The non-terminals used in the two +productions below are defined shortly.

    +
    k
    syntax Stmt ::= "var" Exps ";" + | "function" Id "(" Ids ")" Block +
    +

    Expressions

    +

    The expression constructs below are standard. Increment (++) takes +an expression rather than a variable because it can also increment an array +element. Recall that the syntax we define in K is what we call the syntax +of the semantics: while powerful enough to define non-trivial syntaxes +(thanks to the underlying SDF technology that we use), we typically refrain +from defining precise syntaxes, that is, ones which accept precisely the +well-formed programs (that would not be possible anyway in general). That job +is deferred to type systems, which can also be defined in K. In other words, +we are not making any effort to guarantee syntactically that only variables +or array elements are passed to the increment construct, we allow any +expression. Nevertheless, we will only give semantics to those, so expressions +of the form ++5, which parse (but which will be rejected by our type +system in the typed version of SIMPLE later), will get stuck when executed. +Arrays can be multidimensional and can hold other arrays, so their +lookup operation takes a list of expressions as argument and applies to an +expression (which can in particular be another array lookup), respectively. +The construct sizeOf gives the size of an array in number of elements +of its first dimension. Note that almost all constructs are strict. The only +constructs which are not strict are the increment (since its first argument +gets updated, so it cannot be evaluated), the input read which takes no +arguments so strictness is irrelevant for it, the logical and and or constructs +which are short-circuited, the thread spawning construct which creates a new +thread executing the argument expression and return its unique identifier to +the creating thread (so it cannot just evaluate its argument in place), and the +assignment which is only strict in its second argument (for the same reason as +the increment).

    +
    k
    syntax Exp ::= Int | Bool | String | Id + | "(" Exp ")" [bracket] + | "++" Exp + > Exp "[" Exps "]" [strict] + > Exp "(" Exps ")" [strict] + | "-" Exp [strict] + | "sizeOf" "(" Exp ")" [strict] + | "read" "(" ")" + > left: + Exp "*" Exp [strict, left] + | Exp "/" Exp [strict, left] + | Exp "%" Exp [strict, left] + > left: + Exp "+" Exp [strict, left] + | Exp "-" Exp [strict, left] + > non-assoc: + Exp "<" Exp [strict, non-assoc] + | Exp "<=" Exp [strict, non-assoc] + | Exp ">" Exp [strict, non-assoc] + | Exp ">=" Exp [strict, non-assoc] + | Exp "==" Exp [strict, non-assoc] + | Exp "!=" Exp [strict, non-assoc] + > "!" Exp [strict] + > left: + Exp "&&" Exp [strict(1), left] + | Exp "||" Exp [strict(1), left] + > "spawn" Block + > Exp "=" Exp [strict(2), right] +
    +

    We also need comma-separated lists of identifiers and of expressions. +Moreover, we want them to be strict, that is, to evaluate to lists of results +whenever requested (e.g., when they appear as strict arguments of +the constructs above).

    +
    k
    syntax Ids ::= List{Id,","} [klabel(Exps)] + syntax Exps ::= List{Exp,","} [klabel(Exps), strict] // automatically hybrid now + syntax Exps ::= Ids + syntax Val + syntax Vals ::= List{Val,","} [klabel(Exps)] + syntax Bottom + syntax Bottoms ::= List{Bottom,","} [klabel(Exps)] + syntax Ids ::= Bottoms +
    +

    Statements

    +

    Most of the statement constructs are standard for imperative languages. +We syntactically distinguish between empty and non-empty blocks, because we +chose Stmts not to be a (;-separated) list of +Stmt. Variables can be declared anywhere inside a block, their scope +ending with the block. Expressions are allowed to be used for their side +effects only (followed by a semicolon ;). Functions are allowed +to abruptly return. The exceptions are parametric, i.e., one can throw a value +which is bound to the variable declared by catch. Threads can be +dynamically created and terminated, and can synchronize with join, +acquire, release and rendezvous. Note that the +strictness attributes obey the intended evaluation strategy of the various +constructs. In particular, the if-then-else construct is strict only in its +first argument (the if-then construct will be desugared into if-then-else), +while the loop constructs are not strict in any arguments. The print +statement construct is variadic, that is, it takes an arbitrary number of +arguments.

    +
    k
    syntax Block ::= "{" "}" + | "{" Stmt "}" + + syntax Stmt ::= Block + | Exp ";" [strict] + | "if" "(" Exp ")" Block "else" Block [avoid, strict(1)] + | "if" "(" Exp ")" Block [macro] + | "while" "(" Exp ")" Block + | "for" "(" Stmt Exp ";" Exp ")" Block [macro] + | "return" Exp ";" [strict] + | "return" ";" [macro] + | "print" "(" Exps ")" ";" [strict] +// NOTE: print strict allows non-deterministic evaluation of its arguments +// Either keep like this but document, or otherwise make Exps seqstrict. +// Of define and use a different expression list here, which is seqstrict. + | "try" Block "catch" "(" Id ")" Block + | "throw" Exp ";" [strict] + | "join" Exp ";" [strict] + | "acquire" Exp ";" [strict] + | "release" Exp ";" [strict] + | "rendezvous" Exp ";" [strict] +
    +

    The reason we allow Stmts as the first argument of for +instead of Stmt is because we want to allow more than one statement +to be executed when the loop is initialized. Also, as seens shorly, macros +may expand one statement into more statements; for example, an initialized +variable declaration statement var x=0; desugars into two statements, +namely var x; x=0;, so if we use Stmt instead of Stmts +in the production of for above then we risk that the macro expansion +of statement var x=0; happens before the macro expansion of for, +also shown below, in which case the latter would not apply anymore because +of syntactic mismatch.

    +
    k
    syntax Stmt ::= Stmt Stmt [right] + +// I wish I were able to write the following instead, but confuses the parser. +// +// syntax Stmts ::= List{Stmt,""} +// syntax Top ::= Stmt | "function" Id "(" Ids ")" Block +// syntax Pgm ::= List{Top,""} +// +// With that, I could have also eliminated the empty block +
    +

    Desugared Syntax

    +

    This part desugars some of SIMPLE's language constructs into core ones. +We only want to give semantics to core constructs, so we get rid of the +derived ones before we start the semantics. All desugaring macros below are +straightforward.

    +
    k
    rule if (E) S => if (E) S else {} + rule for(Start Cond; Step) {S} => {Start while (Cond) {S Step;}} + rule for(Start Cond; Step) {} => {Start while (Cond) {Step;}} + rule var E1:Exp, E2:Exp, Es:Exps; => var E1; var E2, Es; + rule var X:Id = E; => var X; X = E; +
    +

    For the semantics, we can therefore assume from now on that each +conditional has both branches, that there are only while loops, and +that each variable is declared alone and without any initialization as part of +the declaration.

    +
    k
    endmodule + + +module SIMPLE-UNTYPED + imports SIMPLE-UNTYPED-SYNTAX + imports DOMAINS +
    +

    Basic Semantic Infrastructure

    +

    Before one starts adding semantic rules to a K definition, one needs to +define the basic semantic infrastructure consisting of definitions for +values and configuration. As discussed in the definitions +in the K tutorial, the values are needed to know when to stop applying +the heating rules and when to start applying the cooling rules corresponding +to strictness or context declarations. The configuration serves as a backbone +for the process of configuration abstraction which allows users to only +mention the relevant cells in each semantic rule, the rest of the configuration +context being inferred automatically. Although in some cases the configuration +could be automatically inferred from the rules, we believe that it is very +useful for language designers/semanticists to actually think of and design +their configuration explicitly, so the current implementation of K requires +one to define it.

    +

    Values

    +

    We here define the values of the language that the various fragments of +programs evaluate to. First, integers and Booleans are values. As discussed, +arrays evaluate to special array reference values holding (1) a location from +where the array's elements are contiguously allocated in the store, and +(2) the size of the array. Functions evaluate to function values as +λ-abstractions (we do not need to evaluate functions to closures +because each function is executed in the fixed global environment and +function definitions cannot be nested). Like in IMP and other +languages, we finally tell the tool that values are K results.

    +
    k
    syntax Val ::= Int | Bool | String + | array(Int,Int) + | lambda(Ids,Stmt) + syntax Exp ::= Val + syntax Exps ::= Vals + syntax Vals ::= Bottoms + syntax KResult ::= Val + | Vals // TODO: should not need this +
    +

    The inclusion of values in expressions follows the methodology of +syntactic definitions (like, e.g., in SOS): extend the syntax of the language +to encompass all values and additional constructs needed to give semantics. +In addition to that, it allows us to write the semantic rules using the +original syntax of the language, and to parse them with the same (now extended +with additional values) parser. If writing the semantics directly on the K +AST, using the associated labels instead of the syntactic constructs, then one +would not need to include values in expressions.

    +

    Configuration

    +

    The K configuration of SIMPLE consists of a top level cell, T, +holding a threads cell, a global environment map cell genv +mapping the global variables and function names to their locations, a shared +store map cell store mapping each location to some value, a set cell +busy holding the locks which have been acquired but not yet released +by threads, a set cell terminated holding the unique identifiers of +the threads which already terminated (needed for join), input +and output list cells, and a nextLoc cell holding a natural +number indicating the next available location. Unlike in the small languages +in the K tutorial, where we used the fresh predicate to generate fresh +locations, in larger languages, like SIMPLE, we prefer to explicitly manage +memory. The location counter in nextLoc models an actual physical +location in the store; for simplicity, we assume arbitrarily large memory and +no garbage collection. The threads cell contains one thread +cell for each existing thread in the program. Note that the thread cell has +multiplicity *, which means that at any given moment there could be zero, +one or more thread cells. Each thread cell contains a +computation cell k, a control cell holding the various +control structures needed to jump to certain points of interest in the program +execution, a local environment map cell env mapping the thread local +variables to locations in the store, and finally a holds map cell +indicating what locks have been acquired by the thread and not released so far +and how many times (SIMPLE's locks are re-entrant). The control cell +currently contains only two subcells, a function stack fstack which +is a list and an exception stack xstack which is also a list. +One can add more control structures in the control cell, such as a +stack for break/continue of loops, etc., if the language is extended with more +control-changing constructs. Note that all cells except for k are +also initialized, in that they contain a ground term of their corresponding +sort. The k cell is initialized with the program that will be passed +to the K tool, as indicated by the $PGM variable, followed by the +execute task (defined shortly).

    +
    k
    // the syntax declarations below are required because the sorts are + // referenced directly by a production and, because of the way KIL to KORE + // is implemented, the configuration syntax is not available yet + // should simply work once KIL is removed completely + // check other definitions for this hack as well + + syntax ControlCell + syntax ControlCellFragment + + configuration <T color="red"> + <threads color="orange"> + <thread multiplicity="*" type="Map" color="yellow"> + <id color="pink"> -1 </id> + <k color="green"> $PGM:Stmt ~> execute </k> + //<br/> // TODO(KORE): support latex annotations #1799 + <control color="cyan"> + <fstack color="blue"> .List </fstack> + <xstack color="purple"> .List </xstack> + </control> + //<br/> // TODO(KORE): support latex annotations #1799 + <env color="violet"> .Map </env> + <holds color="black"> .Map </holds> + </thread> + </threads> + //<br/> // TODO(KORE): support latex annotations #1799 + <genv color="pink"> .Map </genv> + <store color="white"> .Map </store> + <busy color="cyan"> .Set </busy> + <terminated color="red"> .Set </terminated> + //<br/> // TODO(KORE): support latex annotations #1799 + <input color="magenta" stream="stdin"> .List </input> + <output color="brown" stream="stdout"> .List </output> + <nextLoc color="gray"> 0 </nextLoc> + </T> +
    +

    Declarations and Initialization

    +

    We start by defining the semantics of declarations (for variables, +arrays and functions).

    +

    Variable Declaration

    +

    The SIMPLE syntax was desugared above so that each variable is +declared alone and its initialization is done as a separate statement. +The semantic rule below matches resulting variable declarations of the +form var X; on top of the k cell +(indeed, note that the k cell is complete, or round, to the +left, and is torn, or ruptured, to the right), allocates a fresh +location L in the store which is initialized with a special value + (indeed, the unit ., or nothing, is matched anywhere +in the map ‒note the tears at both sides‒ and replaced with the +mapping L ↦ ⊥), and binds X to L in the local +environment shadowing previous declarations of X, if any. +This possible shadowing of X requires us to therefore update the +entire environment map, which is expensive and can significantly slow +down the execution of larger programs. On the other hand, since we know +that L is not already bound in the store, we simply add the binding +L ↦ ⊥ to the store, thus avoiding a potentially complete +traversal of the the store map in order to update it. We prefer the approach +used for updating the store whenever possible, because, in addition to being +faster, it offers more true concurrency than the latter; indeed, according +to the concurrent semantics of K, the store is not frozen while +L ↦ ⊥ is added to it, while the environment is frozen during the +update operation Env[L/X]. The variable declaration command is +also removed from the top of the computation cell and the fresh location +counter is incremented. The undefined symbol added in the store +is of sort KItem, instead of Val, on purpose; this way, the +store lookup rules will get stuck when one attempts to lookup an +uninitialized location. All the above happen in one transactional step, +with the rule below. Note also how configuration abstraction allows us to +only mention the needed cells; indeed, as the configuration above states, +the k and env cells are actually located within a +thread cell within the threads cell, but one needs +not mention these: the configuration context of the rule is +automatically transformed to match the declared configuration +structure.

    +
    k
    syntax KItem ::= "undefined" [latex(\bot)] + + rule <k> var X:Id; => . ...</k> + <env> Env => Env[X <- L] </env> + <store>... .Map => L |-> undefined ...</store> + <nextLoc> L => L +Int 1 </nextLoc> +
    +

    Array Declaration

    +

    The K semantics of the uni-dimensional array declaration is somehow similar +to the above declaration of ordinary variables. First, note the +context declaration below, which requests the evaluation of the array +dimension. Once evaluated, say to a natural number N, then +N +Int 1 locations are allocated in the store for +an array of size N, the additional location (chosen to be the first +one allocated) holding the array reference value. The array reference +value array(L,N) states that the array has size N and its +elements are located contiguously in the store starting with location +L. The operation L … L' ↦ V, defined at the end of this +file in the auxiliary operation section, initializes each location in +the list L … L' to V. Note that, since the dimensions of +array declarations can be arbitrary expressions, this virtually means +that we can dynamically allocate memory in SIMPLE by means of array +declarations.

    +
    k
    context var _:Id[HOLE]; + + rule <k> var X:Id[N:Int]; => . ...</k> + <env> Env => Env[X <- L] </env> + <store>... .Map => L |-> array(L +Int 1, N) + (L +Int 1) ... (L +Int N) |-> undefined ...</store> + <nextLoc> L => L +Int 1 +Int N </nextLoc> + requires N >=Int 0 +
    +

    SIMPLE allows multi-dimensional arrays. For semantic simplicity, we +desugar them all into uni-dimensional arrays by code transformation. +This way, we only need to give semantics to uni-dimensional arrays. +First, note that the context rule above actually evaluates all the array +dimensions (that's why we defined the expression lists strict!): +Upon evaluating the array dimensions, the code generation rule below +desugars multi-dimensional array declaration to uni-dimensional declarations. +To this aim, we introduce two special unique variable identifiers, +$1 and $2. The first variable, $1, iterates +through and initializes each element of the first dimension with an array +of the remaining dimensions, declared as variable $2:

    +
    k
    syntax Id ::= "$1" [token] | "$2" [token] + rule var X:Id[N1:Int, N2:Int, Vs:Vals]; + => var X[N1]; + { + for(var $1 = 0; $1 <= N1 - 1; ++$1) { + var $2[N2, Vs]; + X[$1] = $2; + } + } +
    +

    Ideally, one would like to perform syntactic desugarings like the one +above before the actual semantics. Unfortunately, that was not possible in +this case because the dimension expressions of the multi-dimensional array need +to be evaluated first. Indeed, the desugaring rule above does not work if the +dimensions of the declared array are arbitrary expressions, because they can +have side effects (e.g., a[++x,++x]) and those side effects would be +propagated each time the expression is evaluated in the desugaring code (note +that both the loop condition and the nested multi-dimensional declaration +would need to evaluate the expressions given as array dimensions).

    +

    Function declaration

    +

    Functions are evaluated to λ-abstractions and stored like any other +values in the store. A binding is added into the environment for the function +name to the location holding its body. Similarly to the C language, SIMPLE +only allows function declarations at the top level of the program. More +precisely, the subsequent semantics of SIMPLE only works well when one +respects this requirement. Indeed, the simplistic context-free parser +generated by the grammar above is more generous than we may want, in that it +allows function declarations anywhere any declaration is allowed, including +inside arbitrary blocks. However, as the rule below shows, we are not +storing the declaration environment with the λ-abstraction value as +closures do. Instead, as seen shortly, we switch to the global environment +whenever functions are invoked, which is consistent with our requirement that +functions should only be declared at the top. Thus, if one declares local +functions, then one may see unexpected behaviors (e.g., when one shadows a +global variable before declaring a local function). The type checker of +SIMPLE, also defined in K (see examples/simple/typed/static), +discards programs which do not respect this requirement.

    +
    k
    rule <k> function F(Xs) S => . ...</k> + <env> Env => Env[F <- L] </env> + <store>... .Map => L |-> lambda(Xs, S) ...</store> + <nextLoc> L => L +Int 1 </nextLoc> +
    +

    When we are done with the first pass (pre-processing), the computation +cell k contains only the token execute (see the configuration +declaration above, where the computation item execute was placed +right after the program in the k cell of the initial configuration) +and the cell genv is empty. In this case, we have to call +main() and to initialize the global environment by transferring the +contents of the local environment into it. We prefer to do it this way, as +opposed to processing all the top level declarations directly within the global +environment, because we want to avoid duplication of semantics: the syntax of +the global declarations is identical to that of their corresponding local +declarations, so the semantics of the latter suffices provided that we copy +the local environment into the global one once we are done with the +pre-processing. We want this separate pre-processing step precisely because +we want to create the global environment. All (top-level) functions end up +having their names bound in the global environment and, as seen below, they +are executed in that same global environment; all these mean, in particular, +that the functions "see" each other, allowing for mutual recursion, etc.

    +
    k
    syntax KItem ::= "execute" + rule <k> execute => main(.Exps); </k> + <env> Env </env> + <genv> .Map => Env </genv> +
    +

    Expressions

    +

    We next define the K semantics of all the expression constructs.

    +

    Variable lookup

    +

    When a variable X is the first computational task, and X is bound to some +location L in the environment, and L is mapped to some value V in the +store, then we rewrite X into V:

    +
    k
    rule <k> X:Id => V ...</k> + <env>... X |-> L ...</env> + <store>... L |-> V:Val ...</store> [group(lookup)] +
    +

    Note that the rule above excludes reading , because is not +a value and V is checked at runtime to be a value.

    +

    Variable/Array increment

    +

    This is tricky, because we want to allow both ++x and ++a[5]. +Therefore, we need to extract the lvalue of the expression to increment. +To do that, we state that the expression to increment should be wrapped +by the auxiliary lvalue operation and then evaluated. The semantics +of this auxiliary operation is defined at the end of this file. For now, all +we need to know is that it takes an expression and evaluates to a location +value. Location values, also defined at the end of the file, are integers +wrapped with the operation loc, to distinguish them from ordinary +integers.

    +
    k
    context ++(HOLE => lvalue(HOLE)) + rule <k> ++loc(L) => I +Int 1 ...</k> + <store>... L |-> (I => I +Int 1) ...</store> [group(increment)] +
    +

    Arithmetic operators

    +

    There is nothing special about the following rules. They rewrite the +language constructs to their library counterparts when their arguments +become values of expected sorts:

    +
    k
    rule I1 + I2 => I1 +Int I2 + rule Str1 + Str2 => Str1 +String Str2 + rule I1 - I2 => I1 -Int I2 + rule I1 * I2 => I1 *Int I2 + rule I1 / I2 => I1 /Int I2 requires I2 =/=K 0 + rule I1 % I2 => I1 %Int I2 requires I2 =/=K 0 + rule - I => 0 -Int I + rule I1 < I2 => I1 <Int I2 + rule I1 <= I2 => I1 <=Int I2 + rule I1 > I2 => I1 >Int I2 + rule I1 >= I2 => I1 >=Int I2 +
    +

    The equality and inequality constructs reduce to syntactic comparison +of the two argument values (which is what the equality on K terms does).

    +
    k
    rule V1:Val == V2:Val => V1 ==K V2 + rule V1:Val != V2:Val => V1 =/=K V2 +
    +

    The logical negation is clear, but the logical conjunction and disjunction +are short-circuited:

    +
    k
    rule ! T => notBool(T) + rule true && E => E + rule false && _ => false + rule true || _ => true + rule false || E => E +
    +

    Array lookup

    +

    Untyped SIMPLE does not check array bounds (the dynamically typed version of +it, in examples/simple/typed/dynamic, does check for array out of +bounds). The first rule below desugars the multi-dimensional array access to +uni-dimensional array access; recall that the array access operation was +declared strict, so all sub-expressions involved are already values at this +stage. The second rule rewrites the array access to a lookup operation at a +precise location; we prefer to do it this way to avoid locking the store. +The semantics of the auxiliary lookup operation is straightforward, +and is defined at the end of the file.

    +
    k
    // The [anywhere] feature is underused, because it would only be used +// at the top of the computation or inside the lvalue wrapper. So it +// may not be worth, or we may need to come up with a special notation +// allowing us to enumerate contexts for [anywhere] rules. + rule V:Val[N1:Int, N2:Int, Vs:Vals] => V[N1][N2, Vs] + [anywhere] + + rule array(L,_)[N:Int] => lookup(L +Int N) + [anywhere] +
    +

    Size of an array

    +

    The size of the array is stored in the array reference value, and the +sizeOf construct was declared strict, so:

    +
    k
    rule sizeOf(array(_,N)) => N +
    +

    Function call

    +

    Function application was strict in both its arguments, so we can +assume that both the function and its arguments are evaluated to +values (the former expected to be a λ-abstraction). The first +rule below matches a well-formed function application on top of the +computation and performs the following steps atomically: it switches +to the function body followed by return; (for the case in +which the function does not use an explicit return statement); it +pushes the remaining computation, the current environment, and the +current control data onto the function stack (the remaining +computation can thus also be discarded from the computation cell, +because an unavoidable subsequent return statement ‒see +above‒ will always recover it from the stack); it switches the +current environment (which is being pushed on the function stack) to +the global environment, which is where the free variables in the +function body should be looked up; it binds the formal parameters to +fresh locations in the new environment, and stores the actual +arguments to those locations in the store (this latter step is easily +done by reducing the problem to variable declarations, whose semantics +we have already defined; the auxiliary operation mkDecls is +defined at the end of the file). The second rule pops the +computation, the environment and the control data from the function +stack when a return statement is encountered as the next +computational task, passing the returned value to the popped +computation (the popped computation was the context in which the +returning function was called). Note that the pushing/popping of the +control data is crucial. Without it, one may have a function that +contains an exception block with a return statement inside, which +would put the xstack cell in an inconsistent state (since the +exception block modifies it, but that modification should be +irrelevant once the function returns). We add an artificial +nothing value to the language, which is returned by the +nulary return; statements.

    +
    k
    syntax KItem ::= (Map,K,ControlCellFragment) + + rule <k> lambda(Xs,S)(Vs:Vals) ~> K => mkDecls(Xs,Vs) S return; </k> + <control> + <fstack> .List => ListItem((Env,K,C)) ...</fstack> + C + </control> + <env> Env => GEnv </env> + <genv> GEnv </genv> + + rule <k> return(V:Val); ~> _ => V ~> K </k> + <control> + <fstack> ListItem((Env,K,C)) => .List ...</fstack> + (_ => C) + </control> + <env> _ => Env </env> + + syntax Val ::= "nothing" + rule return; => return nothing; +
    +

    Like for division-by-zero, it is left unspecified what happens +when the nothing value is used in domain calculations. For +example, from the the perspective of the language semantics, +7 +Int nothing can evaluate to anything, or +may not evaluate at all (be undefined). If one wants to make sure that +such artificial values are never misused, then one needs to define a static +checker (also using K, like our the type checker in +examples/simple/typed/static) and reject programs that do. +Note that, unlike the undefined symbol which had the sort K +instead of Val, we defined nothing to be a value. That +is because, as explained above, we do not want the program to get +stuck when nothing is returned by a function. Instead, we want the +behavior to be unspecified; in particular, if one is careful to never +use the returned value in domain computation, like it happens when we +call a function for its side effects (e.g., with a statement of the +form f(x);), then the program does not get stuck.

    +

    Read

    +

    The read() expression construct simply evaluates to the next +input value, at the same time discarding the input value from the +in cell.

    +
    k
    rule <k> read() => I ...</k> <input> ListItem(I:Int) => .List ...</input> [group(read)] +
    +

    Assignment

    +

    In SIMPLE, like in C, assignments are expression constructs and not statement +constructs. To make it a statement all one needs to do is to follow it by a +semi-colon ; (see the semantics for expression statements below). +Like for the increment, we want to allow assignments not only to variables but +also to array elements, e.g., e1[e2] = e3 where e1 evaluates +to an array reference, e2 to a natural number, and e3 to any +value. Thus, we first compute the lvalue of the left-hand-side expression +that appears in an assignment, and then we do the actual assignment to the +resulting location:

    +
    k
    context (HOLE => lvalue(HOLE)) = _ + + rule <k> loc(L) = V:Val => V ...</k> <store>... L |-> (_ => V) ...</store> + [group(assignment)] +
    +

    Statements

    +

    We next define the K semantics of statements.

    +

    Blocks

    +

    Empty blocks are simply discarded, as shown in the first rule below. +For non-empty blocks, we schedule the enclosed statement but we have to +make sure the environment is recovered after the enclosed statement executes. +Recall that we allow local variable declarations, whose scope is the block +enclosing them. That is the reason for which we have to recover the +environment after the block. This allows us to have a very simple semantics +for variable declarations, as we did above. One can make the two rules below +computational if one wants them to count as computational steps.

    +
    k
    rule {} => . + rule <k> { S } => S ~> setEnv(Env) ...</k> <env> Env </env> +
    +

    The basic definition of environment recovery is straightforward and +given in the section on auxiliary constructs at the end of the file.

    +

    There are two common alternatives to the above semantics of blocks. +One is to keep track of the variables which are declared in the block and only +recover those at the end of the block. This way one does more work for +variable declarations but conceptually less work for environment recovery; we +say conceptually because it is not clear that it is indeed the case that +one does less work when AC matching is involved. The other alternative is to +work with a stack of environments instead of a flat environment, and push the +current environment when entering a block and pop it when exiting it. This +way, one does more work when accessing variables (since one has to search the +variable in the environment stack in a top-down manner), but on the other hand +uses smaller environments and the definition gets closer to an implementation. +Based on experience with dozens of language semantics and other K definitions, +we have found that our approach above is the best trade-off between elegance +and efficiency (especially since rewrite engines have built-in techniques to +lazily copy terms, by need, thus not creating unnecessary copies), +so it is the one that we follow in general.

    +

    Sequential composition

    +

    Sequential composition is desugared into K's builtin sequentialization +operation (recall that, like in C, the semi-colon ; is not a +statement separator in SIMPLE — it is either a statement terminator or a +construct for a statement from an expression). Note that K allows +to define the semantics of SIMPLE in such a way that statements eventually +dissolve from the top of the computation when they are completed; this is in +sharp contrast to (artificially) evaluating them to a special +skip statement value and then getting rid of that special value, as +it is the case in other semantic approaches (where everything must evaluate +to something). This means that once S₁ completes in the rule below, S₂ +becomes automatically the next computation item without any additional +(explicit or implicit) rules.

    +
    k
    rule S1:Stmt S2:Stmt => S1 ~> S2 +
    +

    A subtle aspect of the rule above is that S₁ is declared to have sort +Stmts and not Stmt. That is because desugaring macros can indeed +produce left associative sequential composition of statements. For example, +the code var x=0; x=1; is desugared to +(var x; x=0;) x=1;, so although originally the first term of +the sequential composition had sort Stmt, after desugaring it became +of sort Stmts. Note that the attribute [right] associated +to the sequential compositon production is an attribute of the syntax, and not +of the semantics: e.g., it tells the parser to parse +var x; x=0; x=1; as var x; (x=0; x=1;), but it +does not tell the rewrite engine to rewrite (var x; x=0;) x=1; to +var x; (x=0; x=1;).

    +

    Expression statements

    +

    Expression statements are only used for their side effects, so their result +value is simply discarded. Common examples of expression statements are ones +of the form ++x;, x=e;, e1[e2]=e3;, etc.

    +
    k
    rule _:Val; => . +
    +

    Conditional

    +

    Since the conditional was declared with the strict(1) attribute, we +can assume that its first argument will eventually be evaluated. The rules +below cover the only two possibilities in which the conditional is allowed to +proceed (otherwise the rewriting process gets stuck).

    +
    k
    rule if ( true) S else _ => S + rule if (false) _ else S => S +
    +

    While loop

    +

    The simplest way to give the semantics of the while loop is by unrolling. +Note, however, that its unrolling is only allowed when the while loop reaches +the top of the computation (to avoid non-termination of unrolling). The +simple while loop semantics below works because our while loops in SIMPLE are +indeed very basic. If we allowed break/continue of loops then we would need +a completely different semantics, which would also involve the control cell.

    +
    k
    rule while (E) S => if (E) {S while(E)S} +
    +

    Print

    +

    The print statement was strict, so all its arguments are now +evaluated (recall that print is variadic). We append each of +its evaluated arguments to the output buffer, and discard the residual +print statement with an empty list of arguments.

    +
    k
    rule <k> print(V:Val, Es => Es); ...</k> <output>... .List => ListItem(V) </output> + [group(print)] + rule print(.Vals); => . +
    +

    Exceptions

    +

    SIMPLE allows parametric exceptions, in that one can throw and catch a +particular value. The statement try S₁ catch(X) S₂ +proceeds with the evaluation of S₁. If S₁ evaluates normally, i.e., +without any exception thrown, then S₂ is discarded and the execution +continues normally. If S₁ throws an exception with a statement of the +form throw E, then E is first evaluated to some value V +(throw was declared to be strict), then V is bound to X, then +S₂ is evaluated in the new environment while the reminder of S₁ is +discarded, then the environment is recovered and the execution continues +normally with the statement following the try S₁ catch(X) S₂ statement. +Exceptions can be nested and the statements in the +catch part (S₂ in our case) can throw exceptions to the +upper level. One should be careful with how one handles the control data +structures here, so that the abrupt changes of control due to exception +throwing and to function returns interact correctly with each other. +For example, we want to allow function calls inside the statement S₁ in +a try S₁ catch(X) S₂ block which can throw an exception +that is not caught by the function but instead is propagated to the +try S₁ catch(X) S₂ block that called the function. +Therefore, we have to make sure that the function stack as well as other +potential control structures are also properly modified when the exception +is thrown to correctly recover the execution context. This can be easily +achieved by pushing/popping the entire current control context onto the +exception stack. The three rules below modularly do precisely the above.

    +
    k
    syntax KItem ::= (Id,Stmt,K,Map,ControlCellFragment) + + syntax KItem ::= "popx" + + rule <k> (try S1 catch(X) {S2} => S1 ~> popx) ~> K </k> + <control> + <xstack> .List => ListItem((X, S2, K, Env, C)) ...</xstack> + C + </control> + <env> Env </env> + + rule <k> popx => . ...</k> + <xstack> ListItem(_) => .List ...</xstack> + + rule <k> throw V:Val; ~> _ => { var X = V; S2 } ~> K </k> + <control> + <xstack> ListItem((X, S2, K, Env, C)) => .List ...</xstack> + (_ => C) + </control> + <env> _ => Env </env> +
    +

    The catch statement S₂ needs to be executed in the original environment, +but where the thrown value V is bound to the catch variable X. We here +chose to rely on two previously defined constructs when giving semantics to +the catch part of the statement: (1) the variable declaration with +initialization, for binding X to V; and (2) the block construct for +preventing X from shadowing variables in the original environment upon the +completion of S₂.

    +

    Threads

    +

    SIMPLE's threads can be created and terminated dynamically, and can +synchronize by acquiring and releasing re-entrant locks and by rendezvous. +We discuss the seven rules giving the semantics of these operations below.

    +

    Thread creation

    +

    Threads can be created by any other threads using the spawn S +construct. The spawn expression construct evaluates to the unique identifier +of the newly created thread and, at the same time, a new thread cell is added +into the configuration, initialized with the S statement and sharing the +same environment with the parent thread. Note that the newly created +thread cell is torn. That means that the remaining cells are added +and initialized automatically as described in the definition of SIMPLE's +configuration. This is part of K's configuration abstraction mechanism.

    +
    k
    rule <thread>... + <k> spawn S => !T:Int ...</k> + <env> Env </env> + ...</thread> + (.Bag => <thread>... + <k> S </k> + <env> Env </env> + <id> !T </id> + ...</thread>) +
    +

    Thread termination

    +

    Dually to the above, when a thread terminates its assigned computation (the +contents of its k cell) is empty, so the thread can be dissolved. +However, since no discipline is imposed on how locks are acquired and released, +it can be the case that a terminating thread still holds locks. Those locks +must be released, so other threads attempting to acquire them do not deadlock. +We achieve that by removing all the locks held by the terminating thread in its +holds cell from the set of busy locks in the busy cell +(keys(H) returns the domain of the map H as a set, that is, only +the locks themselves ignoring their multiplicity). As seen below, a lock is +added to the busy cell as soon as it is acquired for the first time +by a thread. The unique identifier of the terminated thread is also collected +into the terminated cell, so the join construct knows which +threads have terminated.

    +
    k
    rule (<thread>... <k>.</k> <holds>H</holds> <id>T</id> ...</thread> => .Bag) + <busy> Busy => Busy -Set keys(H) </busy> + <terminated>... .Set => SetItem(T) ...</terminated> +
    +

    Thread joining

    +

    Thread joining is now straightforward: all we need to do is to check whether +the identifier of the thread to be joined is in the terminated cell. +If yes, then the join statement dissolves and the joining thread +continues normally; if not, then the joining thread gets stuck.

    +
    k
    rule <k> join T:Int; => . ...</k> + <terminated>... SetItem(T) ...</terminated> +
    +

    Acquire lock

    +

    There are two cases to distinguish when a thread attempts to acquire a lock +(in SIMPLE any value can be used as a lock):
    +(1) The thread does not currently have the lock, in which case it has to +take it provided that the lock is not already taken by another thread (see +the side condition of the first rule).
    +(2) The thread already has the lock, in which case it just increments its +counter for the lock (the locks are re-entrant). These two cases are captured +by the two rules below:

    +
    k
    rule <k> acquire V:Val; => . ...</k> + <holds>... .Map => V |-> 0 ...</holds> + <busy> Busy (.Set => SetItem(V)) </busy> + requires (notBool(V in Busy)) [group(acquire)] + + rule <k> acquire V; => . ...</k> + <holds>... V:Val |-> (N => N +Int 1) ...</holds> +
    +

    Release lock

    +

    Similarly, there are two corresponding cases to distinguish when a thread +releases a lock:
    +(1) The thread holds the lock more than once, in which case all it needs to do +is to decrement the lock counter.
    +(2) The thread holds the lock only once, in which case it needs to remove it +from its holds cell and also from the the shared busy cell, +so other threads can acquire it if they need to.

    +
    k
    rule <k> release V:Val; => . ...</k> + <holds>... V |-> (N => N -Int 1) ...</holds> + requires N >Int 0 + + rule <k> release V; => . ...</k> <holds>... V:Val |-> 0 => .Map ...</holds> + <busy>... SetItem(V) => .Set ...</busy> +
    +

    Rendezvous synchronization

    +

    In addition to synchronization through acquire and release of locks, SIMPLE +also provides a construct for rendezvous synchronization. A thread whose next +statement to execute is rendezvous(V) gets stuck until another +thread reaches an identical statement; when that happens, the two threads +drop their rendezvous statements and continue their executions. If three +threads happen to have an identical rendezvous statement as their next +statement, then precisely two of them will synchronize and the other will +remain blocked until another thread reaches a similar rendezvous statement. +The rule below is as simple as it can be. Note, however, that, again, it is +K's mechanism for configuration abstraction that makes it work as desired: +since the only cell which can multiply containing a k cell inside is +the thread cell, the only way to concretize the rule below to the +actual configuration of SIMPLE is to include each k cell in a +thread cell.

    +
    k
    rule <k> rendezvous V:Val; => . ...</k> + <k> rendezvous V; => . ...</k> [group(rendezvous)] +
    +

    Auxiliary declarations and operations

    +

    In this section we define all the auxiliary constructs used in the +above semantics.

    +

    Making declarations

    +

    The mkDecls auxiliary construct turns a list of identifiers +and a list of values in a sequence of corresponding variable +declarations.

    +
    k
    syntax Stmt ::= mkDecls(Ids,Vals) [function] + rule mkDecls((X:Id, Xs:Ids), (V:Val, Vs:Vals)) => var X=V; mkDecls(Xs,Vs) + rule mkDecls(.Ids,.Vals) => {} +
    +

    Location lookup

    +

    The operation below is straightforward. Note that we place it in the same +lookup group as the variable lookup rule defined above. This way, +both rules will be considered transitions when we include the lookup +tag in the transition option of kompile.

    +
    k
    syntax Exp ::= lookup(Int) + rule <k> lookup(L) => V ...</k> <store>... L |-> V:Val ...</store> [group(lookup)] +
    +

    Environment recovery

    +

    We have already discussed the environment recovery auxiliary operation in the +IMP++ tutorial:

    +
    k
    // TODO: eliminate the env wrapper, like we did in IMP++ + + syntax KItem ::= setEnv(Map) + rule <k> setEnv(Env) => . ...</k> <env> _ => Env </env> +
    +

    While theoretically sufficient, the basic definition for environment +recovery alone is suboptimal. Consider a loop while (E)S, +whose semantics (see above) was given by unrolling. S +is a block. Then the semantics of blocks above, together with the +unrolling semantics of the while loop, will yield a computation +structure in the k cell that increasingly grows, adding a new +environment recovery task right in front of the already existing sequence of +similar environment recovery tasks (this phenomenon is similar to the ``tail +recursion'' problem). Of course, when we have a sequence of environment +recovery tasks, we only need to keep the last one. The elegant rule below +does precisely that, thus avoiding the unnecessary computation explosion +problem:

    +
    k
    rule (setEnv(_) => .) ~> setEnv(_) +
    +

    In fact, the above follows a common convention in K for recovery +operations of cell contents: the meaning of a computation task of the form +cell(C) that reaches the top of the computation is that the current +contents of cell cell is discarded and gets replaced with C. We +did not add support for these special computation tasks in our current +implementation of K, so we need to define them as above.

    +

    lvalue and loc

    +

    For convenience in giving the semantics of constructs like the increment and +the assignment, that we want to operate the same way on variables and on +array elements, we used an auxiliary lvalue(E) construct which was +expected to evaluate to the lvalue of the expression E. This is only +defined when E has an lvalue, that is, when E is either a variable or +evaluates to an array element. lvalue(E) evaluates to a value of +the form loc(L), where L is the location where the value of E +can be found; for clarity, we use loc to structurally distinguish +natural numbers from location values. In giving semantics to lvalue +there are two cases to consider. (1) If E is a variable, then all we need +to do is to grab its location from the environment. (2) If E is an array +element, then we first evaluate the array and its index in order to identify +the exact location of the element of concern, and then return that location; +the last rule below works because its preceding context declarations ensure +that the array and its index are evaluated, and then the rule for array lookup +(defined above) rewrites the evaluated array access construct to its +corresponding store lookup operation.

    +
    k
    // For parsing reasons, we prefer to allow lvalue to take a K + + syntax Exp ::= lvalue(K) + syntax Val ::= loc(Int) + +// Local variable + + rule <k> lvalue(X:Id => loc(L)) ...</k> <env>... X |-> L:Int ...</env> + +// Array element: evaluate the array and its index; +// then the array lookup rule above applies. + + context lvalue(_::Exp[HOLE::Exps]) + context lvalue(HOLE::Exp[_::Exps]) + +// Finally, return the address of the desired object member + + rule lvalue(lookup(L:Int) => loc(L)) +
    +

    Initializing multiple locations

    +

    The following operation initializes a sequence of locations with the same +value:

    +
    k
    syntax Map ::= Int "..." Int "|->" K + [function, latex({#1}\ldots{#2}\mapsto{#3})] + rule N...M |-> _ => .Map requires N >Int M + rule N...M |-> K => N |-> K (N +Int 1)...M |-> K requires N <=Int M +
    +

    The semantics of SIMPLE is now complete. Make sure you kompile the +definition with the right options in order to generate the desired model. +No kompile options are needed if you only only want to execute the definition +(and thus get an interpreter), but if you want to search for a different +program behaviors then you need to kompile with the transition option +including rule groups such as lookup, increment, acquire, etc. See the +IMP++ tutorial for what the transition option means how to use it.

    +
    k
    endmodule +
    +

    Go to Lesson 2, SIMPLE typed static

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/1_static/NOTES/index.html b/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/1_static/NOTES/index.html new file mode 100644 index 00000000000..89fcf87a836 --- /dev/null +++ b/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/1_static/NOTES/index.html @@ -0,0 +1,380 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    While we disallow global variables with the same name, and that includes +vector variables, we currently do not check that function names are distinct +from each other and from other global variables. Since we can pass functions +around through their names, this can be problematic. May want to make this +into an exercise in the future.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/1_static/exercises/functions-with-throws/tests/index.html b/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/1_static/exercises/functions-with-throws/tests/index.html new file mode 100644 index 00000000000..a2cc9681874 --- /dev/null +++ b/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/1_static/exercises/functions-with-throws/tests/index.html @@ -0,0 +1,379 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    The programs in this folder are typed variants of the SIMPLE untyped programs. +These programs will be executed both with the dynamic and with the static +semantics of the typed SIMPLE language. Each of the semantics contains its +own results folder showing the expected results of executing these programs.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/1_static/simple-typed-static/index.html b/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/1_static/simple-typed-static/index.html new file mode 100644 index 00000000000..e0054683a05 --- /dev/null +++ b/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/1_static/simple-typed-static/index.html @@ -0,0 +1,1150 @@ + + + + + + + + + + + + + + +SIMPLE — Typed — Static | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    SIMPLE — Typed — Static

    +

    Author: Grigore Roșu (grosu@illinois.edu)
    +Organization: University of Illinois at Urbana-Champaign

    +

    Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
    +Organization: University of Bucharest

    +

    Abstract

    +

    This is the K definition of the static semantics of the typed SIMPLE +language, or in other words, a type system for the typed SIMPLE +language in K. We do not re-discuss the various features of the +SIMPLE language here. The reader is referred to the untyped version of +the language for such discussions. We here only focus on the new and +interesting problems raised by the addition of type declarations, and +what it takes to devise a type system/checker for the language.

    +

    When designing a type system for a language, no matter in what +paradigm, we have to decide upon the intended typing policy. Note +that we can have multiple type systems for the same language, one for +each typing policy. For example, should we accept programs which +don't have a main function? Or should we allow functions that do not +return explicitly? Or should we allow functions whose type expects +them to return a value (say an int) to use a plain +return; statement, which returns no value, like in C? +And so on and so forth. Typically, there are two opposite tensions +when designing a type system. On the one hand, you want your type +system to be as permissive as possible, that is, to accept as many +programs that do not get stuck when executed with the untyped +semantics as possible; this will keep the programmers using your +language happy. On the other hand, you want your type system to have +a reasonable performance when implemented; this will keep both the +programmers and the implementers of your language happy. For example, +a type system for rejecting programs that could perform +division-by-zero is not expected to be feasible in general. A simple +guideline when designing typing policies is to imagine how the +semantics of the untyped language may get stuck and try to prevent +those situations from happening.

    +

    Before we give the K type system of SIMPLE formally, we discuss, +informally, the intended typing policy:

    +
      +
    • +

      Each program should contain a main() function. Indeed, +the untyped SIMPLE semantics will get stuck on any program which does +not have a main function.

      +
    • +
    • +

      Each primitive value has its own type, which can be int +bool, or string. There is also a type void +for nonexistent values, for example for the result of a function meant +to return no value (but only be used for its side effects, like a +procedure).

      +
    • +
    • +

      The syntax of untyped SIMPLE is extended to allow type +declarations for all the variables, including array variables. This is +done in a C/Java-style. For example, int x; or +int x=7, y=x+3;, or int[][][] a[10,20]; +(the latter defines a 10 × 20 matrix of arrays of integers). +Recall from untyped SIMPLE that, unlike in C/Java, our multi-dimensional +arrays use comma-separated arguments, although they have the array-of-array +semantics.

      +
    • +
    • +

      Functions are also typed in a C/Java style. However, since in SIMPLE +we allow functions to be passed to and returned by other functions, we also +need function types. We will use the conventional higher-order arrow-notation +for function types, but will separate the argument types with commas. For +example, a function returning an array of bool elements and +taking as argument an array x of two-integer-argument functions +returning an integer, is declared using a syntax of the form +bool[] f(((int,int)->int)[] x) { ... } +and has the type ((int,int)->int)[] -> bool[].

      +
    • +
    • +

      We allow any variable declarations at the top level. Functions +can only be declared at the top level. Each function can only access the +other functions and variables declared at the top level, or its own locally +declared variables. SIMPLE has static scoping.

      +
    • +
    • +

      The various expression and statement constructs take only elements of +the expected types.

      +
    • +
    • +

      Increment and assignment can operate both on variables and on array +elements. For example, if f has type int->int[][] and +function g has the type int->int, then the +increment expression ++f(7)[g(2),g(3)] is valid.

      +
    • +
    • +

      Functions should only return values of their declared result +type. To give the programmers more flexibility, we allow functions to +use return; statements to terminate without returning an +actual value, or to not explicitly use any return statement, +regardless of their declared return type. This flexibility can be +handy when writing programs using certain functions only for their +side effects. Nevertheless, as the dynamic semantics shows, a return +value is automatically generated when an explicit return +statement is not encountered.

      +
    • +
    • +

      For simplicity, we here limit exceptions to only throw and catch +integer values. We let it as an exercise to the reader to extend the +semantics to allow throwing and catching arbitrary-type exceptions. +Like in programming languages like Java, one can go even further and +define a semantics where thrown exceptions are propagated through +try-catch statements until one of the corresponding type is found. +We will do this when we define the KOOL language, not here. +To keep the definition if SIMPLE simple, here we do not attempt to +reject programs which throw uncaught exceptions.

      +
    • +
    +

    Like in untyped SIMPLE, some constructs can be desugared into a +smaller set of basic constructs. In general, it should be clear why a +program does not type by looking at the top of the k cells in +its stuck configuration.

    +
    k
    module SIMPLE-TYPED-STATIC-SYNTAX + imports DOMAINS-SYNTAX +
    +

    Syntax

    +

    The syntax of typed SIMPLE extends that of untyped SIMPLE with support +for declaring types to variables and functions.

    +
    k
    syntax Id ::= "main" [token] +
    +

    Types

    +

    Primitive, array and function types, as well as lists (or tuples) of types. +The lists of types are useful for function arguments.

    +
    k
    syntax Type ::= "void" | "int" | "bool" | "string" + | Type "[" "]" + | "(" Type ")" [bracket] + > Types "->" Type + + syntax Types ::= List{Type,","} [klabel(exps)] +
    +

    Declarations

    +

    Variable and function declarations have the expected syntax. For variables, +we basically just replaced the var keyword of untyped SIMPLE with a +type. For functions, besides replacing the function keyword with a +type, we also introduce a new syntactic category for typed variables, +Param, and lists over it.

    +
    k
    syntax Param ::= Type Id + syntax Params ::= List{Param,","} + + syntax Stmt ::= Type Exps ";" + | Type Id "(" Params ")" Block +
    +

    Expressions

    +

    The syntax of expressions is identical to that in untyped SIMPLE, +except for the logical conjunction and disjunction which have +different strictness attributes, because they now have different +evaluation strategies.

    +
    k
    syntax Exp ::= Int | Bool | String | Id + | "(" Exp ")" [bracket] + | "++" Exp + > Exp "[" Exps "]" [strict] + > Exp "(" Exps ")" [strict] + | "-" Exp [strict] + | "sizeOf" "(" Exp ")" [strict] + | "read" "(" ")" + > left: + Exp "*" Exp [strict, left] + | Exp "/" Exp [strict, left] + | Exp "%" Exp [strict, left] + > left: + Exp "+" Exp [strict, left] + | Exp "-" Exp [strict, left] + > non-assoc: + Exp "<" Exp [strict, non-assoc] + | Exp "<=" Exp [strict, non-assoc] + | Exp ">" Exp [strict, non-assoc] + | Exp ">=" Exp [strict, non-assoc] + | Exp "==" Exp [strict, non-assoc] + | Exp "!=" Exp [strict, non-assoc] + > "!" Exp [strict] + > left: + Exp "&&" Exp [strict, left] + | Exp "||" Exp [strict, left] + > "spawn" Block + > Exp "=" Exp [strict(2), right] +
    +

    Note that spawn has not been declared strict. This may +seem unexpected, because the child thread shares the same environment +with the parent thread, so from a typing perspective the spawned +statement makes the same sense in a child thread as it makes in the +parent thread. The reason for not declaring it strict is because we +want to disallow programs where the spawned thread calls the +return statement, because those programs would get stuck in +the dynamic semantics. The type semantics of spawn below will reject +such programs.

    +

    We still need lists of expressions, defined below, but note that we do +not need lists of identifiers anymore. They have been replaced by the lists +of parameters.

    +
    k
    syntax Exps ::= List{Exp,","} [strict, klabel(exps)] +
    +

    Statements

    +

    The statements have the same syntax as in untyped SIMPLE, except for +the exceptions, which now type their parameter. Note that, unlike in untyped +SIMPLE, all statement constructs which have arguments and are not desugared +are strict, including the conditional and the while. Indeed, from a +typing perspective, they are all strict: first type their arguments and then +type the actual construct.

    +
    k
    syntax Block ::= "{" "}" + | "{" Stmt "}" + + syntax Stmt ::= Block + | Exp ";" [strict] + | "if" "(" Exp ")" Block "else" Block [avoid, strict] + | "if" "(" Exp ")" Block [macro] + | "while" "(" Exp ")" Block [strict] + | "for" "(" Stmt Exp ";" Exp ")" Block [macro] + | "return" Exp ";" [strict] + | "return" ";" + | "print" "(" Exps ")" ";" [strict] + | "try" Block "catch" "(" Param ")" Block [strict(1)] + | "throw" Exp ";" [strict] + | "join" Exp ";" [strict] + | "acquire" Exp ";" [strict] + | "release" Exp ";" [strict] + | "rendezvous" Exp ";" [strict] +
    +

    Note that the sequential composition is now sequentially strict, +because, unlike in the dynamic semantics where statements dissolved, +they now reduce to the stmt type, which is a result.

    +
    k
    syntax Stmt ::= Stmt Stmt [seqstrict, right] +
    +

    Desugaring macros

    +

    We use the same desugaring macros like in untyped SIMPLE, but, of +course, including the types of the involved variables.

    +
    k
    rule if (E) S => if (E) S else {} + rule for(Start Cond; Step) {S:Stmt} => {Start while(Cond){S Step;}} + rule for(Start Cond; Step) {} => {Start while(Cond){Step;}} + rule T:Type E1:Exp, E2:Exp, Es:Exps; => T E1; T E2, Es; [anywhere] + rule T:Type X:Id = E; => T X; X = E; [anywhere] + +endmodule + + +module SIMPLE-TYPED-STATIC + imports SIMPLE-TYPED-STATIC-SYNTAX + imports DOMAINS +
    +

    Static semantics

    +

    Here we define the type system of SIMPLE. Like concrete semantics, +type systems defined in K are also executable. However, K type +systems turn into type checkers instead of interpreters when executed.

    +

    The typing process is done in two (overlapping) phases. In the first +phase the global environment is built, which contains type bindings +for all the globally declared variables and functions. For functions, +the declared types will be ``trusted'' during the first phase and +simply bound to their corresponding function names and placed in the +global type environment. At the same time, type-checking tasks that +the function bodies indeed respect their claimed types are generated. +All these tasks are (concurrently) verified during the second phase. +This way, all the global variable and function declarations are +available in the global type environment and can be used in order to +type-check each function code. This is consistent with the semantics +of untyped SIMPLE, where functions can access all the global variables +and can call any other function declared in the same program. The +two phases may overlap because of the K concurrent semantics. For +example, a function task can be started while the first phase is still +running; moreover, it may even complete before the first phase does, +namely when all the global variables and functions that it needs have +already been processed and made available in the global environment by +the first phase task.

    +

    Extended syntax and results

    +

    The idea is to start with a configuration holding the program to type +in one of its cells, then apply rewrite rules on it mixing types and +language syntax, and eventually obtain a type instead of the original +program. In other words, the program reduces to its type using +the K rules giving the type system of the language. In doing so, +additional typing tasks for function bodies are generated and solved +the same way. If this rewriting process gets stuck, then we say that +the program is not well-typed. Otherwise the program is well-typed +(by definition). We did not need types for statements and for blocks +as part of the typed SIMPLE syntax, because programmers are not allowed +to use such types explicitly. However, we are going to need them in the +type system, because blocks and statements reduce to them.

    +

    We start by allowing types to be used inside expressions and statements in +our language. This way, types can be used together with language syntax in +subsequent K rules without any parsing errors. Like in the type system of +IMP++ in the K tutorial, we prefer to group the block and statement types +under one syntactic sub-category of types, because this allows us to more +compactly state that certain terms can be either blocks or statements. Also, +since programs and fragments of program will reduce to their types, in order +for the strictness and context declarations to be executable we state that +types are results (same like we did in the IMP++ tutorial).

    +
    k
    syntax Exp ::= Type + syntax Exps ::= Types + syntax BlockOrStmtType ::= "block" | "stmt" + syntax Type ::= BlockOrStmtType + syntax Block ::= BlockOrStmtType + syntax KResult ::= Type + | Types //TODO: remove this, eventually +
    +

    Configuration

    +

    The configuration of our type system consists of a tasks cell +holding various typing task cells, and a global type environment. +Each task includes a k cell holding the code to type, a tenv +cell holding the local type environment, and a return cell holding +the return type of the currently checked function. The latter is needed in +order to check whether return statements return values of the expected type. +Initially, the program is placed in a k cell inside a +task cell. Since the cells with multiplicity ? are not +included in the initial configuration, the task cell holding +the original program in its k cell will contain no other +subcells.

    +
    k
    configuration <T color="yellow"> + <tasks color="orange"> + <task multiplicity="*" color="yellow" type="Set"> + <k color="green"> $PGM:Stmt </k> + <tenv multiplicity="?" color="cyan"> .Map </tenv> + <returnType multiplicity="?" color="black"> void </returnType> + </task> + </tasks> +// <br/> + <gtenv color="blue"> .Map </gtenv> + </T> +
    +

    Variable declarations

    +

    Variable declarations type as statements, that is, they reduce to the +type stmt. There are only two cases that need to be +considered: when a simple variable is declared and when an array +variable is declared. The macros at the end of the syntax module +above take care of reducing other variable declarations, including +ones where the declared variables are initialized, to only these two +cases. The first case has two subcases: when the variable declaration +is global (i.e., the task cell contains only the k +cell), in which case it is added to the global type environment +checking at the same time that the variable has not been already +declared; and when the variable declaration is local (i.e., a +tenv cell is available), in which case it is simply added to +the local type environment, possibly shadowing previous homonymous +variables. The third case reduces to the second, incrementally moving +the array dimension into the type until the array becomes a simple +variable.

    +
    k
    rule <task> <k> T:Type X:Id; => stmt ...</k> </task> + <gtenv> Rho (.Map => X |-> T) </gtenv> + requires notBool(X in keys(Rho)) + rule <k> T:Type X:Id; => stmt ...</k> <tenv> Rho => Rho[X <- T] </tenv> + + context _:Type _::Exp[HOLE::Exps]; +// The rule below may need to sort E to Exp in the future, if the +// parser gets stricter; without that information, it may not be able +// to complete the LHS into T E[int,Ts],.Exps; (and similarly for the RHS) + rule T:Type E:Exp[int,Ts:Types]; => T[] E[Ts]; +// I want to write the rule below as _:Type (E:Exp[.Types] => E), +// but the list completion seems to not work well with that. + rule T:Type E:Exp[.Types]; => T E; +
    +

    Function declarations

    +

    Functions are allowed to be declared only at the top level (the +task cell holds only its k subcell). Each function +declaration reduces to a variable declaration (a binding of its name +to its declared function type), but also adds a task into the +tasks cell. The task consists of a typing of the statement +declaring all the function parameters followed by the function body, +together with the expected return type of the function. The +getTypes and mkDecls functions, defined at the end of +the file in the section on auxiliary operations, extracts the list of +types and makes a sequence of variable declarations from a list of +function parameters, respectively. Note that, although in the dynamic +semantics we include a terminating return statement at the +end of the function body to eliminate from the analysis the case when +the function does not provide an explicit return, we do not need to +include such a similar return statement here. That's because +the return statements type to stmt anyway, and the +entire code of the function body needs to type anyway.

    +
    k
    rule <task> <k> T:Type F:Id(Ps:Params) S => getTypes(Ps)->T F; ...</k> </task> + (.Bag => <task> + <k> mkDecls(Ps) S </k> <tenv> .Map </tenv> <returnType> T </returnType> + </task>) +
    +

    Checking if main() exists}

    +

    Once the entire program is processed (generating appropriate tasks +to type check its function bodies), we can dissolve the main +task cell (the one holding only a k subcell). Since +we want to enforce that programs include a main function, we also +generate a function task executing main() to ensure that it +types (remove this task creation if you do not want your type system +to reject programs without a main function).

    +
    k
    rule <task> <k> stmt => main(.Exps); </k> (.Bag => <tenv> .Map </tenv>) </task> +
    +

    Collecting the terminated tasks

    +

    Similarly, once a non-main task (i.e., one which contains a +tenv subcells) is completed using the subsequent rules (i.e., +its k cell holds only the block or stmt +type), we can dissolve its corresponding cell. Note that it is +important to ensure that we only dissolve tasks containing a +tenv cell with the rule below, because the main task should +not dissolve this way! It should do what the above rule says. +In the end, there should be no task cell left in the configuration +when the program correctly type checks.

    +
    k
    rule <task>... <k> _:BlockOrStmtType </k> <tenv> _ </tenv> ...</task> => .Bag +
    +

    Basic values

    +

    The first three rewrite rules below reduce the primitive values to +their types, as we typically do when we define type systems in K.

    +
    k
    rule _:Int => int + rule _:Bool => bool + rule _:String => string +
    +

    Variable lookup

    +

    There are three cases to distinguish for variable lookup: (1) if the +variable is bound in the local type environment, then look its type up +there; (2) if a local environment exists and the variable is not bound +in it, then look its type up in the global environment; (3) finally, +if there is no local environment, meaning that we are executing the +top-level pass, then look the variable's type up in the global +environment, too.

    +
    k
    rule <k> X:Id => T ...</k> <tenv>... X |-> T ...</tenv> + + rule <k> X:Id => T ...</k> <tenv> Rho </tenv> <gtenv>... X |-> T ...</gtenv> + requires notBool(X in keys(Rho)) + + rule <task> <k> X:Id => T ...</k> </task> <gtenv>... X |-> T ...</gtenv> +
    +

    Increment

    +

    We want the increment operation to apply to any lvalue, including +array elements, not only to variables. For that reason, we define a +special context extracting the type of the argument of the increment +operation only if that argument is an lvalue. Otherwise the rewriting +process gets stuck. The operation ltype is defined at the +end of this file, in the auxiliary operation section. It essentially +acts as a filter, getting stuck if its argument is not an lvalue and +letting it reduce otherwise. The type of the lvalue is expected to be +an integer in order to be allowed to be incremented, as seen in the +rule ++ int => int below.

    +
    k
    context ++(HOLE => ltype(HOLE)) + rule ++ int => int +
    +

    Common expression constructs

    +

    The rules below are straightforward and self-explanatory:

    +
    k
    rule int + int => int + rule string + string => string + rule int - int => int + rule int * int => int + rule int / int => int + rule int % int => int + rule - int => int + rule int < int => bool + rule int <= int => bool + rule int > int => bool + rule int >= int => bool + rule T:Type == T => bool + rule T:Type != T => bool + rule bool && bool => bool + rule bool || bool => bool + rule ! bool => bool +
    +

    Array access and size

    +

    Array access requires each index to type to an integer, and the +array type to be at least as deep as the number of indexes:

    +
    k
    // NOTE: +// We used to need parentheses in the RHS, to avoid capturing Ts as an attribute +// Let's hope that is not a problem anymore. + + rule (T[])[int, Ts:Types] => T[Ts] + rule T:Type[.Types] => T +
    +

    sizeOf only needs to check that its argument is an array:

    +
    k
    rule sizeOf(_T[]) => int +
    +

    Input/Output

    +

    The read expression construct types to an integer, while print types +to a statement provided that all its arguments type to integers or +strings.

    +
    k
    rule read() => int + + rule print(T:Type, Ts => Ts); requires T ==K int orBool T ==K string + rule print(.Types); => stmt +
    +

    Assignment

    +

    The special context and the rule for assignment below are similar +to those for increment: the LHS of the assignment must be an lvalue +and, in that case, it must have the same type as the RHS, which then +becomes the type of the assignment.

    +
    k
    context (HOLE => ltype(HOLE)) = _ + rule T:Type = T => T +
    +

    Function application and return

    +

    Function application requires the type of the function and the +types of the passed values to be compatible. Note that a special case +is needed to handle the no-argument case:

    +
    k
    rule (Ts:Types -> T)(Ts) => T requires Ts =/=K .Types + rule (void -> T)(.Types) => T +
    +

    The returned value must have the same type as the declared +function return type. If an empty return is encountered, than +we should check that we are in a function (and not a thread) +context, that is, a return cell must be available:

    +
    k
    rule <k> return T:Type; => stmt ...</k> <returnType> T </returnType> + rule <k> return; => stmt ...</k> <returnType> _ </returnType> +
    +

    Blocks

    +

    To avoid having to recover type environments after blocks, we prefer +to start a new task for block body, making sure that the new task +is passed the same type environment and return cells. The value +returned by return statements must have the same type as +stated in the return cell. The print variadic +function is allowed to only print integers and strings. The thrown +exceptions can only have integer type.

    +
    k
    rule {} => block + + rule <task> <k> {S} => block ...</k> <tenv> Rho </tenv> R </task> + (.Bag => <task> <k> S </k> <tenv> Rho </tenv> R </task>) +
    +

    Expression statement

    +
    k
    rule _:Type; => stmt +
    +

    Conditional and while loop

    +
    k
    rule if (bool) block else block => stmt + rule while (bool) block => stmt +
    +

    Exceptions

    +

    We currently force the parameters of exceptions to only be integers. +Moreover, for simplicity, we assume that integer exceptions can be +thrown from anywhere, including from functions which do not define +any try-catch block (with the currently unchecked ‒also for +simplicity‒ expectation that the caller functions would catch those +exceptions).

    +
    k
    rule try block catch(int X:Id) {S} => {int X; S} + rule try block catch(int X:Id) {} => {int X;} + rule throw int; => stmt +
    +

    Concurrency

    +

    Nothing special about typing the concurrency constructs, except that +we do not want the spawned thread to return, so we do not include any +return cell in the new task cell for the thread statement. +Same like with the functions above, we do not check for thrown +exceptions which are not caught.

    +
    k
    rule <k> spawn S => int ...</k> <tenv> Rho </tenv> + (.Bag => <task> <k> S </k> <tenv> Rho </tenv> </task>) + rule join int; => stmt + rule acquire _:Type; => stmt + rule release _:Type; => stmt + rule rendezvous _:Type; => stmt + + rule _:BlockOrStmtType _:BlockOrStmtType => stmt +
    +

    Auxiliary constructs

    +

    The function mkDecls turns a list of parameters into a +list of variable declarations.

    +
    k
    syntax Stmt ::= mkDecls(Params) [function] + rule mkDecls(T:Type X:Id, Ps:Params) => T X; mkDecls(Ps) + rule mkDecls(.Params) => {} +
    +

    The ltype context allows only expressions which have an +lvalue to evaluate.

    +
    k
    syntax LValue ::= Id + rule isLValue(_:Exp[_:Exps]) => true + syntax Exp ::= LValue // K should be able to infer this + // if not added, then it gets stuck with an Id on k cell + +// Instead of the second LValue production above you can use a rule: +// rule isLValue(_:Exp[_:Exps]) => true + + syntax Exp ::= ltype(Exp) +// context ltype(HOLE:LValue) +// The above context does not work due to some error, so we write instead + context ltype(HOLE) requires isLValue(HOLE) +
    +

    The function getTypes is the same as in SIMPLE typed dynamic.

    +
    k
    syntax Types ::= getTypes(Params) [function] + rule getTypes(T:Type _:Id) => T, .Types // I would like to not use .Types + rule getTypes(T:Type _:Id, P, Ps) => T, getTypes(P,Ps) + rule getTypes(.Params) => void, .Types + +endmodule +
    +

    Go to Lesson 3, SIMPLE typed dynamic

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/2_dynamic/simple-typed-dynamic/index.html b/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/2_dynamic/simple-typed-dynamic/index.html new file mode 100644 index 00000000000..71139699e2a --- /dev/null +++ b/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/2_dynamic/simple-typed-dynamic/index.html @@ -0,0 +1,1142 @@ + + + + + + + + + + + + + + +SIMPLE — Typed — Dynamic | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    SIMPLE — Typed — Dynamic

    +

    Author: Grigore Roșu (grosu@illinois.edu)
    +Organization: University of Illinois at Urbana-Champaign

    +

    Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
    +Organization: University of Bucharest

    +

    Abstract

    +

    This is the K dynamic semantics of the typed SIMPLE language. +It is very similar to the semantics of the untyped SIMPLE, the +difference being that we now dynamically check the typing policy +described in the static semantics of typed SIMPLE. Because of the +dynamic nature of the semantics, we can also perform some additional +checks which were not possible in the static semantics, such as +memory leaks due to accessing an array out of its bounds. We will +highlight the differences between the dynamically typed and the +untyped SIMPLE as we proceed with the semantics. We recommend the +reader to consult the typing policy and the syntax of types discussed +in the static semantics of the typed SIMPLE language.

    +
    k
    module SIMPLE-TYPED-DYNAMIC-SYNTAX + imports DOMAINS-SYNTAX +
    +

    Syntax

    +

    The syntax of typed SIMPLE extends that of untyped SIMPLE with support +for declaring types to variables and functions.

    +

    The syntax below is identical to that of the static semantics of typed +SIMPLE. However, the K strictness attributes are like those of the untyped +SIMPLE, to capture the desired evaluation strategies of the various language +constructs.

    +
    k
    syntax Id ::= "main" [token] +
    +

    Types

    +
    k
    syntax Type ::= "void" | "int" | "bool" | "string" + | Type "[" "]" + | "(" Type ")" [bracket] + > Types "->" Type + syntax Types ::= List{Type,","} [klabel(exps)] +
    +

    Declarations

    +
    k
    syntax Param ::= Type Id + syntax Params ::= List{Param,","} + + syntax Stmt ::= Type Exps ";" + | Type Id "(" Params ")" Block +
    +

    Expressions

    +
    k
    syntax Exp ::= Int | Bool | String | Id + | "(" Exp ")" [bracket] + | "++" Exp + > Exp "[" Exps "]" [strict] + > Exp "(" Exps ")" [strict] + | "-" Exp [strict] + | "sizeOf" "(" Exp ")" [strict] + | "read" "(" ")" + > left: + Exp "*" Exp [strict, left] + | Exp "/" Exp [strict, left] + | Exp "%" Exp [strict, left] + > left: + Exp "+" Exp [strict, left] + | Exp "-" Exp [strict, left] + > non-assoc: + Exp "<" Exp [strict, non-assoc] + | Exp "<=" Exp [strict, non-assoc] + | Exp ">" Exp [strict, non-assoc] + | Exp ">=" Exp [strict, non-assoc] + | Exp "==" Exp [strict, non-assoc] + | Exp "!=" Exp [strict, non-assoc] + > "!" Exp [strict] + > left: + Exp "&&" Exp [strict(1), left] + | Exp "||" Exp [strict(1), left] + > "spawn" Block + > Exp "=" Exp [strict(2), right] +
    +

    Like in the static semantics, there is no need for lists of identifiers +(because we now have lists of parameters).

    +
    k
    syntax Exps ::= List{Exp,","} [strict, klabel(exps)] + syntax Val + syntax Vals ::= List{Val,","} [klabel(exps)] +
    +

    Statements

    +
    k
    syntax Block ::= "{" "}" + | "{" Stmt "}" + + syntax Stmt ::= Block + | Exp ";" [strict] + | "if" "(" Exp ")" Block "else" Block [avoid, strict(1)] + | "if" "(" Exp ")" Block [macro] + | "while" "(" Exp ")" Block + | "for" "(" Stmt Exp ";" Exp ")" Block [macro] + | "print" "(" Exps ")" ";" [strict] + | "return" Exp ";" [strict] + | "return" ";" + | "try" Block "catch" "(" Param ")" Block + | "throw" Exp ";" [strict] + | "join" Exp ";" [strict] + | "acquire" Exp ";" [strict] + | "release" Exp ";" [strict] + | "rendezvous" Exp ";" [strict] + + syntax Stmt ::= Stmt Stmt [right] +
    +

    The same desugaring macros like in the statically typed SIMPLE.

    +
    k
    rule if (E) S => if (E) S else {} + rule for(Start Cond; Step) {S:Stmt} => {Start while(Cond){S Step;}} + rule for(Start Cond; Step) {} => {Start while(Cond){Step;}} + rule T:Type E1:Exp, E2:Exp, Es:Exps; => T E1; T E2, Es; [anywhere] + rule T:Type X:Id = E; => T X; X = E; [anywhere] + +endmodule + + +module SIMPLE-TYPED-DYNAMIC + imports SIMPLE-TYPED-DYNAMIC-SYNTAX + imports DOMAINS +
    +

    Semantics

    +

    Values and results

    +

    These are similar to those of untyped SIMPLE, except that the array +references and the function abstrations now also hold their types. +These types are needed in order to easily compute the type of any +value in the language (see the auxiliary typeOf operation at +the end of this module).

    +
    k
    syntax Val ::= Int | Bool | String + | array(Type,Int,Int) + | lambda(Type,Params,Stmt) + syntax Exp ::= Val + syntax Exps ::= Vals + syntax KResult ::= Val + | Vals // TODO: should not need this +
    +

    Configuration

    +

    The configuration is almost identical to that of untyped SIMPLE, +except for a return cell inside the control cell. +This return cell will hold, like in the static semantics of +typed SIMPLE, the expected type of the value returned by the function +being executed. The contents of this cell will be set whenever a +function is invoked and will be checked whenever the evaluation of the +function body encounters an explicit return statement.

    +
    k
    // the syntax declarations below are required because the sorts are + // referenced directly by a production and, because of the way KIL to KORE + // is implemented, the configuration syntax is not available yet + // should simply work once KIL is removed completely + // check other definitions for this hack as well + + syntax ControlCell + syntax ControlCellFragment + + configuration <T color="red"> + <threads color="orange"> + <thread multiplicity="*" color="yellow" type="Map"> + <id color="pink"> 0 </id> + <k color="green"> ($PGM:Stmt ~> execute) </k> +// <br/> + <control color="cyan"> + <fstack color="blue"> .List </fstack> + <xstack color="purple"> .List </xstack> + <returnType color="LimeGreen"> void </returnType> + </control> +// <br/> + <env color="violet"> .Map </env> + <holds color="black"> .Map </holds> + </thread> + </threads> +// <br/> + <genv color="pink"> .Map </genv> + <store color="white"> .Map </store> + <busy color="cyan">.Set</busy> + <terminated color="red"> .Set </terminated> + <input color="magenta" stream="stdin"> .List </input> + <output color="brown" stream="stdout"> .List </output> + <nextLoc color="gray"> 0 </nextLoc> + </T> +
    +

    Declarations and Initialization

    +

    Variable Declaration

    +

    The undefined construct is now parameterized by a type. +A main difference between untyped SIMPLE and dynamically typed SIMPLE +is that the latter assigns a type to each of its locations and that +type cannot be changed during the execution of the program. We do not +do any memory management in our semantic definitions here, so +locations cannot be reclaimed, garbage collected and/or reused. Each +location corresponds precisely to an allocated variable or array +element, whose type was explicitly or implicitly declared in the +program and does not change. It is therefore safe to type each +location and then never allow that type to change. The typed +undefined values effectively assign both a type and an undefined value +to a location.

    +
    k
    syntax KItem ::= undefined(Type) [latex(\bot_{#1})] + + rule <k> T:Type X:Id; => . ...</k> + <env> Env => Env[X <- L] </env> + <store>... .Map => L |-> undefined(T) ...</store> + <nextLoc> L:Int => L +Int 1 </nextLoc> +
    +

    Array Declaration

    +

    The dynamic semantics of typed array declarations is similar to that +in untyped SIMPLE, but we have to make sure that we associate the +right type to the allocated locations.

    +
    k
    rule <k> T:Type X:Id[N:Int]; => . ...</k> + <env> Env => Env[X <- L] </env> + <store>... .Map => L |-> array(T, L +Int 1, N) + (L +Int 1)...(L +Int N) |-> undefined(T) ...</store> + <nextLoc> L:Int => L +Int 1 +Int N </nextLoc> + when N >=Int 0 + + context _:Type _::Exp[HOLE::Exps]; +
    +

    The desugaring of multi-dimensional arrays into unidimensional +ones is also similar to that in untyped SIMPLE, although we have to +make sure that all the declared variables have the right types. The +auxiliary operation T<Vs>, defined at the end of the file, +adds the length of Vs dimensions to the type T.

    +
    k
    // TODO: Check the desugaring below to be consistent with the one for untyped simple + + syntax Id ::= "$1" [token] | "$2" [token] + rule T:Type X:Id[N1:Int, N2:Int, Vs:Vals]; + => T[]<Vs> X[N1]; + { + T[][]<Vs> $1=X; + for(int $2=0; $2 <= N1 - 1; ++$2) { + T X[N2,Vs]; + $1[$2] = X; + } + } +
    +

    Function declaration

    +

    Store all function parameters, as well as the return type, as part +of the lambda abstraction. In the spirit of dynamic typing, we will +make sure that parameters are well typed when the function is invoked.

    +
    k
    rule <k> T:Type F:Id(Ps:Params) S => . ...</k> + <env> Env => Env[F <- L] </env> + <store>... .Map => L |-> lambda(T, Ps, S) ...</store> + <nextLoc> L => L +Int 1 </nextLoc> +
    +

    Calling main()

    +

    When done with the first pass, call main().

    +
    k
    syntax KItem ::= "execute" + rule <k> execute => main(.Exps); </k> + <env> Env </env> + <genv> .Map => Env </genv> +
    +

    Expressions

    +

    Variable lookup

    +
    k
    rule <k> X:Id => V ...</k> + <env>... X |-> L ...</env> + <store>... L |-> V:Val ...</store> [group(lookup)] +
    +

    Variable/Array increment

    +
    k
    context ++(HOLE => lvalue(HOLE)) + rule <k> ++loc(L) => I +Int 1 ...</k> + <store>... L |-> (I:Int => I +Int 1) ...</store> [group(increment)] +
    +

    Arithmetic operators

    +
    k
    rule I1 + I2 => I1 +Int I2 + rule Str1 + Str2 => Str1 +String Str2 + rule I1 - I2 => I1 -Int I2 + rule I1 * I2 => I1 *Int I2 + rule I1 / I2 => I1 /Int I2 when I2 =/=K 0 + rule I1 % I2 => I1 %Int I2 when I2 =/=K 0 + rule - I => 0 -Int I + rule I1 < I2 => I1 <Int I2 + rule I1 <= I2 => I1 <=Int I2 + rule I1 > I2 => I1 >Int I2 + rule I1 >= I2 => I1 >=Int I2 + rule V1:Val == V2:Val => V1 ==K V2 + rule V1:Val != V2:Val => V1 =/=K V2 + rule ! T => notBool(T) + rule true && E => E + rule false && _ => false + rule true || _ => true + rule false || E => E +
    +

    Array lookup

    +

    Check array bounds, as part of the dynamic typing policy.

    +
    k
    // Same comment as for simple untyped regarding [anywhere] + rule V:Val[N1:Int, N2:Int, Vs:Vals] => V[N1][N2, Vs] + [anywhere] + +// Same comment as for simple untyped regarding [anywhere] + rule array(_:Type, L:Int, M:Int)[N:Int] => lookup(L +Int N) + when N >=Int 0 andBool N <Int M [anywhere] +
    +

    Size of an array

    +
    k
    rule sizeOf(array(_,_,N)) => N +
    +

    Function call

    +

    Define function call and return together, to see their relationship. +Note that the operation mkDecls now declares properly typed +instantiated variables, and that the semantics of return also +checks that that type of the returned value is expected one.

    +
    k
    syntax KItem ::= (Type,Map,K,ControlCellFragment) + + rule <k> lambda(T,Ps,S)(Vs:Vals) ~> K => mkDecls(Ps,Vs) S return; </k> + <control> + <fstack> .List => ListItem((T',Env,K,C)) ...</fstack> + <returnType> T' => T </returnType> + C + </control> + <env> Env => GEnv </env> + <genv> GEnv </genv> + + rule <k> return V:Val; ~> _ => V ~> K </k> + <control> + <fstack> ListItem((T',Env,K,C)) => .List ...</fstack> + <returnType> T => T' </returnType> + (_ => C) + </control> + <env> _ => Env </env> + when typeOf(V) ==K T // check the type of the returned value +
    +

    Like the undefined above, nothing also gets +tagged with a type now. The empty return statement is +completed to return the nothing value tagged as expected.

    +
    k
    syntax Val ::= nothing(Type) + rule <k> return; => return nothing(T); ...</k> <returnType> T </returnType> +
    +

    Read

    +
    k
    rule <k> read() => I ...</k> <input> ListItem(I:Int) => .List ...</input> [group(read)] +
    +

    Assignment

    +

    The assignment now checks that the type of the assigned location is +preserved:

    +
    k
    context (HOLE => lvalue(HOLE)) = _ + + rule <k> loc(L) = V:Val => V ...</k> <store>... L |-> (V' => V) ...</store> + when typeOf(V) ==K typeOf(V') [group(assignment)] +
    +

    Statements

    +

    Blocks

    +
    k
    rule {} => . + rule <k> { S } => S ~> setEnv(Env) ...</k> <env> Env </env> +
    +

    Sequential composition

    +
    k
    rule S1:Stmt S2:Stmt => S1 ~> S2 +
    +

    Expression statements

    +
    k
    rule _:Val; => . +
    +

    Conditional

    +
    k
    rule if ( true) S else _ => S + rule if (false) _ else S => S +
    +

    While loop

    +
    k
    rule while (E) S => if (E) {S while(E)S} +
    +

    Print

    +

    We only allow printing integers and strings:

    +
    k
    rule <k> print(V:Val, Es => Es); ...</k> <output>... .List => ListItem(V) </output> + when typeOf(V) ==K int orBool typeOf(V) ==K string [group(print)] + rule print(.Vals); => . +
    +

    Exceptions

    +

    Exception parameters are now typed, but note that the semantics below +works correctly only when the thrown exception has the same type as +the innermost try-catch paramete. To keep things simple, for the time +being we can assume that SIMPLE only throws and catches integer +values, in which case our semantics below works fine:

    +
    k
    syntax KItem ::= (Param,Stmt,K,Map,ControlCellFragment) // Param instead of Id + + syntax KItem ::= "popx" + + rule <k> (try S1 catch(P) S2 => S1 ~> popx) ~> K </k> + <control> + <xstack> .List => ListItem((P, S2, K, Env, C)) ...</xstack> + C + </control> + <env> Env </env> + + rule <k> popx => . ...</k> + <xstack> ListItem(_) => .List ...</xstack> + + rule <k> throw V:Val; ~> _ => { T X = V; S2 } ~> K </k> + <control> + <xstack> ListItem((T:Type X:Id, S2, K, Env, C)) => .List ...</xstack> + (_ => C) + </control> + <env> _ => Env </env> +
    +

    Threads

    +

    Thread creation

    +
    k
    rule <thread>... + <k> spawn S => !T:Int +Int 1 ...</k> + <env> Env </env> + ...</thread> + (.Bag => <thread>... + <k> S </k> + <env> Env </env> + <id> !T +Int 1 </id> + ...</thread>) +
    +

    Thread termination

    +
    k
    rule (<thread>... <k>.</k> <holds>H</holds> <id>T</id> ...</thread> => .Bag) + <busy> Busy => Busy -Set keys(H) </busy> + <terminated>... .Set => SetItem(T) ...</terminated> +
    +

    Thread joining

    +
    k
    rule <k> join T:Int; => . ...</k> + <terminated>... SetItem(T) ...</terminated> +
    +

    Acquire lock

    +
    k
    rule <k> acquire V:Val; => . ...</k> + <holds>... .Map => V |-> 0 ...</holds> + <busy> Busy (.Set => SetItem(V)) </busy> + when (notBool(V in Busy:Set)) [group(acquire)] + + rule <k> acquire V; => . ...</k> + <holds>... V:Val |-> (N:Int => N +Int 1) ...</holds> +
    +

    Release lock

    +
    k
    rule <k> release V:Val; => . ...</k> + <holds>... V |-> (N => N:Int -Int 1) ...</holds> + when N >Int 0 + + rule <k> release V; => . ...</k> <holds>... V:Val |-> 0 => .Map ...</holds> + <busy>... SetItem(V) => .Set ...</busy> +
    +

    Rendezvous synchronization

    +
    k
    rule <k> rendezvous V:Val; => . ...</k> + <k> rendezvous V; => . ...</k> [group(rendezvous)] +
    +

    Auxiliary declarations and operations

    +

    Turns a list of parameters and a list of instance values for them +into a list of variable declarations.

    +
    k
    syntax Stmt ::= mkDecls(Params,Vals) [function] + rule mkDecls((T:Type X:Id, Ps:Params), (V:Val, Vs:Vals)) + => T X=V; mkDecls(Ps,Vs) + rule mkDecls(.Params,.Vals) => {} +
    +

    Location lookup.

    +
    k
    syntax Exp ::= lookup(Int) // see NOTES.md for why Exp instead of KItem + rule <k> lookup(L) => V ...</k> <store>... L |-> V:Val ...</store> [group(lookup)] +
    +

    Environment recovery.

    +
    k
    // TODO: same comment regarding setEnv(...) as for simple untyped + + syntax KItem ::= setEnv(Map) + rule <k> setEnv(Env) => . ...</k> <env> _ => Env </env> + rule (setEnv(_) => .) ~> setEnv(_) +
    +

    lvalue and loc

    +
    k
    syntax Exp ::= lvalue(K) + syntax Val ::= loc(Int) + + rule <k> lvalue(X:Id => loc(L)) ...</k> <env>... X |-> L:Int ...</env> + + //context lvalue(_[HOLE]) + //context lvalue(HOLE[_]) + context lvalue(_::Exp[HOLE::Exps]) + context lvalue(HOLE::Exp[_::Exps]) + + rule lvalue(lookup(L:Int) => loc(L)) +
    +

    Adds the corresponding depth to an array type

    +
    k
    syntax Type ::= Type "<" Vals ">" [function] + rule T:Type<_,Vs:Vals> => T[]<Vs> + rule T:Type<.Vals> => T +
    +

    Sequences of locations.

    +
    k
    syntax Map ::= Int "..." Int "|->" K + [function, latex({#1}\ldots{#2}\mapsto{#3})] + rule N...M |-> _ => .Map when N >Int M + rule N...M |-> K => N |-> K (N +Int 1)...M |-> K when N <=Int M + +// Type of a value. + syntax Type ::= typeOf(K) [function] + rule typeOf(_:Int) => int + rule typeOf(_:Bool) => bool + rule typeOf(_:String) => string + rule typeOf(array(T,_,_)) => (T[]) // () needed! K parses [] as "no tags" + rule typeOf(lambda(T,Ps,_)) => getTypes(Ps) -> T + rule typeOf(undefined(T)) => T + rule typeOf(nothing(T)) => T +
    +

    List of types of a parameter.

    +
    k
    syntax Types ::= getTypes(Params) [function] + rule getTypes(T:Type _:Id) => T, .Types // I would like to not use .Types + rule getTypes(T:Type _:Id, P, Ps) => T, getTypes(P,Ps) + rule getTypes(.Params) => void, .Types +endmodule +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/programs/index.html b/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/programs/index.html new file mode 100644 index 00000000000..3ce3acf0b98 --- /dev/null +++ b/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/programs/index.html @@ -0,0 +1,379 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    The programs in this folder are typed variants of the SIMPLE untyped programs. +These programs will be executed both with the dynamic and with the static +semantics of the typed SIMPLE language. Each of the semantics contains its +own results folder showing the expected results of executing these programs.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/2_languages/2_kool/1_untyped/kool-untyped/index.html b/k-distribution/pl-tutorial/2_languages/2_kool/1_untyped/kool-untyped/index.html new file mode 100644 index 00000000000..c7e75e29bfb --- /dev/null +++ b/k-distribution/pl-tutorial/2_languages/2_kool/1_untyped/kool-untyped/index.html @@ -0,0 +1,1522 @@ + + + + + + + + + + + + + + +KOOL — Untyped | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    KOOL — Untyped

    +

    Author: Grigore Roșu (grosu@illinois.edu)
    +Organization: University of Illinois at Urbana-Champaign

    +

    Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
    +Organization: University of Bucharest

    +

    Abstract

    +

    This is the K semantic definition of the untyped KOOL language. KOOL +is aimed at being a pedagogical and research language that captures +the essence of the object-oriented programming paradigm. Its untyped +variant discussed here is simpler than the typed one, ignoring several +intricate aspects of types in the presence of objects. A program +consists of a set of class declarations. Each class can extend at +most one other class (KOOL is single-inheritance). A class can +declare a set of fields and a set of methods, all public and called +the class' members. Specifically, KOOL includes the +following features:

    +
      +
    • +

      Class declarations, where a class may or may not explicitly +extend another class. In case a class does not explicitly extend +another class, then it is assumed that it extends the default top-most +and empty (i.e., no members) class called Object. Each class +is required to declare precisely one homonymous method, called its +constructor. Each valid program should contain one class +named Main, whose constructor, Main(), takes no +arguments. The execution of a program consists of creating an object +instance of class Main and invoking the constructor +Main() on it, that is, of executing new Main();.

      +
    • +
    • +

      All features of SIMPLE (see examples/simple/untyped), +i.e., multidimensional arrays, function (here called "method") +abstractions with call-by-value parameter passing style and static +scoping, blocks with locals, input/output, parametric exceptions, and +concurrency via dynamic thread creation/termination and synchronization. +The only change in the syntax of SIMPLE when imported in KOOL is the +function declaration keyword, function, which is changed into +method. The exact same desugaring macros from SIMPLE are +also included in KOOL. We can think of KOOL's classes as embedding +SIMPLE programs (extended with OO constructs, as discussed next).

      +
    • +
    • +

      Object creation using the new C(e1,...,en) +expression construct. An object instance of class C is first +created and then the constructor C(e1,...,en) is implicitly +called on that object. KOOL only allows (and requires) one +constructor per class. The class constructor can be called either +implicitly during a new object creation for the class, or explicitly. +The superclass constructor is not implicitly invoked when a +class constructor is invoked; if you want to invoke the superclass +constructor from a subclass constructor then you have to do it +explicitly.

      +
    • +
    • +

      An expression construct this, which evaluates to the +current object.

      +
    • +
    • +

      An expression construct super, which is used (only) in +combination with member lookup (see next) to refer to a superclass +field or method.

      +
    • +
    • +

      A member lookup expression construct e.x, where e +is an expression (either an expression expected to evaluate to an object +or the super construct) and x is a class member name, +that is, a field or a method name.

      +
    • +
    • +

      Expression constructs e instanceOf C and +(C) e, where e is an expression expected +to evaluate to an object and C a class name. The former +tells whether the class of e is a subclass of C, +that is, whether e can be used as an instance of C, +and the latter changes the class of e to C. These +operations always succeed: the former returns a Boolean value, while +the latter changes the current class of e to C +regardless of whether it is safe to do so or not. The typed version +of KOOL will check the safety of casting by ensuring that the instance +class of the object is a subclass of C. In untyped KOOL we +do not want to perform this check because we want to allow the +programmer maximum of flexibility: if one always accesses only +available members, then the program can execute successfully despite +the potentially unsafe cast.

      +
    • +
    +

    There are some specific aspects of KOOL that need to be discussed.

    +

    First, KOOL is higher-order, allowing function abstractions to be +treated like any other values in the language. For example, if +m is a method of object e then e.m +evaluates to the corresponding function abstraction. The function +abstraction is in fact a closure, because in addition to the method +parameters and body it also encapsulates the object value (i.e., the +environment of the object together with its current class—see below) +that e evaluates to. This way, function abstractions can be +invoked anywhere and have the capability to change the state of their +object. For example, if m is a method of object e +which increments a field c of e when invoked, and if +getm is another method of e which simply returns +m when invoked, then the double application +(e.getm())() has the same effect as e.m(), that is, +increments the counter c of e. Note that the +higher-order nature of KOOL was not originally planned; it came as a +natural consequence of evaluating methods to closures and we decided +to keep it. If you do not like it then do not use it.

    +

    Second, since all the fields and methods are public in KOOL and since +they can be redeclared in subclasses, it is not immediately clear how +to lookup the member x when we write e.x and +e is different from super. We distinguish two cases, +depending on whether e.x occurs in a method invocation +context (i.e., e.x(...)) or in a field context. KOOL has +dynamic method dispatch, so if e.x is invoked as a method +then x will be searched for starting with the instance class of +the object value to which e evaluates. If e.x +occurs in a non-method-invocation context then x will be +treated as a field (although it may hold a method closure due to the +higher-order nature of KOOL) and thus will be searched starting with +the current class of the object value of e (which, because of +this and casting, may be different from its instance class). +In order to achieve the above, each object value will consist of a +pair holding the current class of the object and an environment stack +with one layer for each class in the object's instance class hierarchy.

    +

    Third, although KOOL is dynamic method dispatch, its capabilities +described above are powerful enough to allow us to mimic static +method dispatch. For example, suppose that you want to invoke method +m() statically. Then all you need to do is to declare a +local variable and bind it to m, for example var staticm = m;, and +then call staticm(). This works because +staticm is first bound to the method closure that m +evaluates to, and then looked up as any local variable when invoked. +We only enable the dynamic method dispatch when we have an object +member on an application position, e.g., m().

    +

    In what follows, we limit our comments to the new, KOOL-specific +aspects of the language. We refer the reader to the untyped SIMPLE +language for documentation on the the remaining features, because +those were all borrowed from SIMPLE.

    +
    k
    module KOOL-UNTYPED-SYNTAX + imports DOMAINS-SYNTAX +
    +

    Syntax

    +

    The syntax of KOOL extends that of SIMPLE with object-oriented +constructs. We removed from the K annotated syntax of SIMPLE two +constructs, namely the one for function declarations (because we want +to call them methods now) and the one for function application +(because application is not strict in the first argument +anymore—needs to initiate dynamic method dispatch). The additional +syntax includes:

    +
      +
    • First, we need a new dedicated identifier, Object, for +the default top-most class.
    • +
    • Second, we rename the function keyword of SIMPLE into method.
    • +
    • Third, we add syntax for class declarations together with a +macro making classes which extend nothing to extend Object.
    • +
    • Fourth, we change the strictness attribute of application +into strict(2).
    • +
    • Finally, we add syntax and corresponding strictness +for the KOOL object-oriented constructs.
    • +
    +
    k
    syntax Id ::= "Object" [token] | "Main" [token] + + syntax Stmt ::= "var" Exps ";" + | "method" Id "(" Ids ")" Block // called "function" in SIMPLE + | "class" Id Block // KOOL + | "class" Id "extends" Id Block // KOOL + + syntax Exp ::= Int | Bool | String | Id + | "this" // KOOL + | "super" // KOOL + | "(" Exp ")" [bracket] + | "++" Exp + | Exp "instanceOf" Id [strict(1)] // KOOL + | "(" Id ")" Exp [strict(2)] // KOOL cast + | "new" Id "(" Exps ")" [strict(2)] // KOOL + | Exp "." Id // KOOL + > Exp "[" Exps "]" [strict] + > Exp "(" Exps ")" [strict(2)] // was strict in SIMPLE + | "-" Exp [strict] + | "sizeOf" "(" Exp ")" [strict] + | "read" "(" ")" + > left: + Exp "*" Exp [strict, left] + | Exp "/" Exp [strict, left] + | Exp "%" Exp [strict, left] + > left: + Exp "+" Exp [strict, left] + | Exp "-" Exp [strict, left] + > non-assoc: + Exp "<" Exp [strict, non-assoc] + | Exp "<=" Exp [strict, non-assoc] + | Exp ">" Exp [strict, non-assoc] + | Exp ">=" Exp [strict, non-assoc] + | Exp "==" Exp [strict, non-assoc] + | Exp "!=" Exp [strict, non-assoc] + > "!" Exp [strict] + > left: + Exp "&&" Exp [strict(1), left] + | Exp "||" Exp [strict(1), left] + > "spawn" Block + > Exp "=" Exp [strict(2), right] + + syntax Ids ::= List{Id,","} + + syntax Exps ::= List{Exp,","} [strict, klabel(exps)] + syntax Val + syntax Vals ::= List{Val,","} [klabel(exps)] + + syntax Block ::= "{" "}" + | "{" Stmt "}" + + syntax Stmt ::= Block + | Exp ";" [strict] + | "if" "(" Exp ")" Block "else" Block [avoid, strict(1)] + | "if" "(" Exp ")" Block [macro] + | "while" "(" Exp ")" Block + | "for" "(" Stmt Exp ";" Exp ")" Block [macro] + | "return" Exp ";" [strict] + | "return" ";" [macro] + | "print" "(" Exps ")" ";" [strict] + | "try" Block "catch" "(" Id ")" Block + | "throw" Exp ";" [strict] + | "join" Exp ";" [strict] + | "acquire" Exp ";" [strict] + | "release" Exp ";" [strict] + | "rendezvous" Exp ";" [strict] + + syntax Stmt ::= Stmt Stmt [right] +
    +

    Old desugaring rules, from SIMPLE

    +
    k
    rule if (E) S => if (E) S else {} + rule for(Start Cond; Step) {S} => {Start while (Cond) {S Step;}} + rule var E1::Exp, E2::Exp, Es::Exps; => var E1; var E2, Es; [anywhere] + rule var X::Id = E; => var X; X = E; [anywhere] +
    +

    New desugaring rule

    +
    k
    rule class C:Id S => class C extends Object S // KOOL + +endmodule +
    +

    Semantics

    +

    We first discuss the new configuration of KOOL, which extends that of +SIMPLE. Then we include the semantics of the constructs borrowed from +SIMPLE unchanged; we refrain from discussing those, because they were +already discussed in the K definition of SIMPLE. Then we discuss +changes to SIMPLE's semantics needed for the more general meaning of +the previous SIMPLE constructs (for example for thread spawning, +assignment, etc.). Finally, we discuss in detail the +semantics of the additional KOOL constructs.

    +
    k
    module KOOL-UNTYPED + imports KOOL-UNTYPED-SYNTAX + imports DOMAINS +
    +

    Configuration

    +

    KOOL removes one cell and adds two nested cells to the configuration +of SIMPLE. The cell which is removed is the one holding the global +environment, because a KOOL program consists of a set of classes only, +with no global declarations. In fact, since informally speaking each +KOOL class now includes a SIMPLE program, it is safe to say that the +global variables in SIMPLE became class fields in KOOL. Let us now +discuss the new cells that are added to the configuration of SIMPLE.

    +
      +
    • +

      The cell crntObj holds data pertaining to the current +object, that is, the object environment in which the code in cell +k executes: crntClass holds the current class (which +can change as methods of the current object are invoked); +envStack holds the stack of environments as a list, +each layer corresponding to one class in the objects' instance class +hierarchy; location, which is optional, holds the location in +the store where the current object is or has to be located (this is +useful both for method closures and for the semantics of object +creation).

      +
    • +
    • +

      The cell classes holds all the declared classes, each +class being held in its own class cell which contains a name +(className), a parent (extends), and the actual +member declarations (declarations).

      +
    • +
    +
    k
    // the syntax declarations below are required because the sorts are + // referenced directly by a production and, because of the way KIL to KORE + // is implemented, the configuration syntax is not available yet + // should simply work once KIL is removed completely + // check other definitions for this hack as well + syntax EnvCell + syntax ControlCell + syntax EnvStackCell + syntax CrntObjCellFragment + + configuration <T color="red"> + <threads color="orange"> + <thread multiplicity="*" type="Set" color="yellow"> + <k color="green"> $PGM:Stmt ~> execute </k> + //<br/> // TODO(KORE): support latex annotations #1799 + <control color="cyan"> + <fstack color="blue"> .List </fstack> + <xstack color="purple"> .List </xstack> + //<br/> // TODO(KORE): support latex annotations #1799 + <crntObj color="Fuchsia"> // KOOL + <crntClass> Object </crntClass> + <envStack> .List </envStack> + <location multiplicity="?"> .K </location> + </crntObj> + </control> + //<br/> // TODO(KORE): support latex annotations #1799 + <env color="violet"> .Map </env> + <holds color="black"> .Map </holds> + <id color="pink"> 0 </id> + </thread> + </threads> + //<br/> // TODO(KORE): support latex annotations #1799 + <store color="white"> .Map </store> + <busy color="cyan">.Set </busy> + <terminated color="red"> .Set </terminated> + <input color="magenta" stream="stdin"> .List </input> + <output color="brown" stream="stdout"> .List </output> + <nextLoc color="gray"> 0 </nextLoc> + //<br/> // TODO(KORE): support latex annotations #1799 + <classes color="Fuchsia"> // KOOL + <classData multiplicity="*" type="Map" color="Fuchsia"> + // the Map has as its key the first child of the cell, + // in this case the className cell. + <className color="Fuchsia"> Main </className> + <baseClass color="Fuchsia"> Object </baseClass> + <declarations color="Fuchsia"> .K </declarations> + </classData> + </classes> + </T> +
    +

    Unchanged Semantics from untyped SIMPLE

    +

    The semantics below is taken over from SIMPLE unchanged. +The semantics of function declaration and invocation, including the +use of the special lambda abstraction value, needs to change +in order to account for the fact that methods are now invoked into +their object's environment. The semantics of function return actually +stays unchanged. Also, the semantics of program initialization is +different: now we have to create an instance of the Main +class which also calls the constructor Main(), while in +SIMPLE we only had to invoke the function Main(). +Finally, the semantics of thread spawning needs to change, too: the +parent thread needs to also share its object environment with the +spawned thread (in addition to its local environment, like in SIMPLE). +This is needed in order to be able to spawn method invokations under +dynamic method dispatch; for example, spawn { run(); } +will need to look up the method run() in the newly created +thread, operation which will most likely fail unless the child thread +sees the object environment of the parent thread. Note that the +spawn statement of KOOL is more permissive than the threads +of Java. In fact, the latter can be implemented in terms of our +spawn—see the program threads.kool for a sketch.

    +

    Below is a subset of the values of SIMPLE, which are also values +of KOOL. We will add other values later in the semantics, such as +object and method closures.

    +
    k
    syntax Val ::= Int | Bool | String + | array(Int,Int) + syntax Exp ::= Val + syntax Exps ::= Vals + syntax KResult ::= Val + syntax KResult ::= Vals +
    +

    The semantics below are taken verbatim from the untyped SIMPLE +definition.

    +
    k
    syntax KItem ::= "undefined" [latex(\bot)] + + rule <k> var X:Id; => . ...</k> + <env> Env => Env[X <- L] </env> + <store>... .Map => L |-> undefined ...</store> + <nextLoc> L:Int => L +Int 1 </nextLoc> + + + context var _:Id[HOLE]; + + rule <k> var X:Id[N:Int]; => . ...</k> + <env> Env => Env[X <- L] </env> + <store>... .Map => L |-> array(L +Int 1, N) + (L +Int 1) ... (L +Int N) |-> undefined ...</store> + <nextLoc> L:Int => L +Int 1 +Int N </nextLoc> + when N >=Int 0 + + + syntax Id ::= "$1" [token] | "$2" [token] + rule var X:Id[N1:Int, N2:Int, Vs:Vals]; + => var X[N1]; + { + var $1=X; + for(var $2=0; $2 <= N1 - 1; ++$2) { + var X[N2,Vs]; + $1[$2] = X; + } + } + + + rule <k> X:Id => V ...</k> + <env>... X |-> L ...</env> + <store>... L |-> V:Val ...</store> [group(lookup)] + + + context ++(HOLE => lvalue(HOLE)) + rule <k> ++loc(L) => I +Int 1 ...</k> + <store>... L |-> (I:Int => I +Int 1) ...</store> [group(increment)] + + + rule I1 + I2 => I1 +Int I2 + rule Str1 + Str2 => Str1 +String Str2 + rule I1 - I2 => I1 -Int I2 + rule I1 * I2 => I1 *Int I2 + rule I1 / I2 => I1 /Int I2 when I2 =/=K 0 + rule I1 % I2 => I1 %Int I2 when I2 =/=K 0 + rule - I => 0 -Int I + rule I1 < I2 => I1 <Int I2 + rule I1 <= I2 => I1 <=Int I2 + rule I1 > I2 => I1 >Int I2 + rule I1 >= I2 => I1 >=Int I2 + + rule V1:Val == V2:Val => V1 ==K V2 + rule V1:Val != V2:Val => V1 =/=K V2 + rule ! T => notBool(T) + rule true && E => E + rule false && _ => false + rule true || _ => true + rule false || E => E + + + rule V:Val[N1:Int, N2:Int, Vs:Vals] => V[N1][N2, Vs] + [anywhere] + + rule array(L,_)[N:Int] => lookup(L +Int N) + [anywhere] + + + rule sizeOf(array(_,N)) => N +
    +

    The semantics of function application needs to change into dynamic +method dispatch invocation, which is defined shortly. However, +interestingly, the semantics of return stays unchanged.

    +
    k
    rule <k> return(V:Val); ~> _ => V ~> K </k> + <control> + <fstack> ListItem(fstackFrame(Env,K,XS,<crntObj> CO </crntObj>)) => .List ...</fstack> + <xstack> _ => XS </xstack> + <crntObj> _ => CO </crntObj> + </control> + <env> _ => Env </env> + + syntax Val ::= "nothing" + rule return; => return nothing; + + + rule <k> read() => I ...</k> <input> ListItem(I:Int) => .List ...</input> [group(read)] + + + context (HOLE => lvalue(HOLE)) = _ + + rule <k> loc(L) = V:Val => V ...</k> <store>... L |-> (_ => V) ...</store> + [group(assignment)] + + + rule {} => . + rule <k> { S } => S ~> setEnv(Env) ...</k> <env> Env </env> + + + rule S1::Stmt S2::Stmt => S1 ~> S2 + + rule _:Val; => . + + rule if ( true) S else _ => S + rule if (false) _ else S => S + + rule while (E) S => if (E) {S while(E)S} + + rule <k> print(V:Val, Es => Es); ...</k> <output>... .List => ListItem(V) </output> + [group(print)] + rule print(.Vals); => . + + + syntax KItem ::= xstackFrame(Id,Stmt,K,Map,K) + // TODO(KORE): drop the additional production once parsing issue #1842 is fixed + | (Id,Stmt,K,Map,K) + + syntax KItem ::= "popx" + + rule <k> (try S1 catch(X) {S2} => S1 ~> popx) ~> K </k> + <control> + <xstack> .List => ListItem(xstackFrame(X, S2, K, Env, C)) ...</xstack> + C + </control> + <env> Env </env> + + rule <k> popx => . ...</k> + <xstack> ListItem(_) => .List ...</xstack> + + rule <k> throw V:Val; ~> _ => { var X = V; S2 } ~> K </k> + <control> + <xstack> ListItem(xstackFrame(X, S2, K, Env, C)) => .List ...</xstack> + (_ => C) + </control> + <env> _ => Env </env> +
    +

    Thread spawning needs a new semantics, because we want the child +thread to also share the object environment with its parent. The new +semantics of thread spawning will be defined shortly. However, +interestingly, the other concurrency constructs keep their semantics +from SIMPLE unchanged.

    +
    k
    // TODO(KORE): ..Bag should be . throughout this definition #1772 + rule (<thread>... <k>.</k> <holds>H</holds> <id>T</id> ...</thread> => .Bag) + /* + rule (<thread>... <k>.</k> <holds>H</holds> <id>T</id> ...</thread> => .) + */ + <busy> Busy => Busy -Set keys(H) </busy> + <terminated>... .Set => SetItem(T) ...</terminated> + + rule <k> join T:Int; => . ...</k> + <terminated>... SetItem(T) ...</terminated> + + rule <k> acquire V:Val; => . ...</k> + <holds>... .Map => V |-> 0 ...</holds> + <busy> Busy (.Set => SetItem(V)) </busy> + when (notBool(V in Busy:Set)) [group(acquire)] + + rule <k> acquire V; => . ...</k> + <holds>... V:Val |-> (N:Int => N +Int 1) ...</holds> + + rule <k> release V:Val; => . ...</k> + <holds>... V |-> (N => N:Int -Int 1) ...</holds> + when N >Int 0 + + rule <k> release V; => . ...</k> <holds>... V:Val |-> 0 => .Map ...</holds> + <busy>... SetItem(V) => .Set ...</busy> + + rule <k> rendezvous V:Val; => . ...</k> + <k> rendezvous V; => . ...</k> [group(rendezvous)] +
    +

    Unchanged auxiliary operations from untyped SIMPLE

    +
    k
    syntax Stmt ::= mkDecls(Ids,Vals) [function] + rule mkDecls((X:Id, Xs:Ids), (V:Val, Vs:Vals)) => var X=V; mkDecls(Xs,Vs) + rule mkDecls(.Ids,.Vals) => {} + + // TODO(KORE): clarify sort inferences #1803 + syntax Exp ::= lookup(Int) + /* + syntax KItem ::= lookup(Int) + */ + rule <k> lookup(L) => V ...</k> <store>... L |-> V:Val ...</store> [group(lookup)] + + syntax KItem ::= setEnv(Map) + rule <k> setEnv(Env) => . ...</k> <env> _ => Env </env> + rule (setEnv(_) => .) ~> setEnv(_) + // TODO: How can we make sure that the second rule above applies before the first one? + // Probably we'll deal with this using strategies, eventually. + + syntax Exp ::= lvalue(K) + syntax Val ::= loc(Int) + + rule <k> lvalue(X:Id => loc(L)) ...</k> <env>... X |-> L:Int ...</env> + + context lvalue(_::Exp[HOLE::Exps]) + context lvalue(HOLE::Exp[_::Exps]) + + rule lvalue(lookup(L:Int) => loc(L)) + + + syntax Map ::= Int "..." Int "|->" K + [function, latex({#1}\ldots{#2}\mapsto{#3})] + rule N...M |-> _ => .Map when N >Int M + rule N...M |-> K => N |-> K (N +Int 1)...M |-> K when N <=Int M +
    +

    Changes to the existing untyped SIMPLE semantics

    +

    When we extend a language, sometimes we need to do more than just add +new language constructs and semantics for them. Sometimes we want to +also extend the semantics of existing language constructs, in order to +get more from them.

    +

    Program initialization

    +

    In SIMPLE, once all the global declarations were processed, the +function main() was invoked. In KOOL, the global +declarations are classes, and their specific semantics is given +shortly; essentially, they are pre-processed one by one and added +into the class cell structure in the configuration. +Once all the classes are processed, the computation item +execute, which was placed right after the program in the +initial configuration, is reached. In SIMPLE, the program was +initialized by calling the method main(). In KOOL, the +program is initialized by creating an object instance of class +Main. This will also implicitly call the method +Main() (the Main class constructor). The emptiness +of the env cell below is just a sanity check, to make sure +that the user has not declared anything but classes at the top level +of the program.

    +
    k
    syntax KItem ::= "execute" + rule <k> execute => new Main(.Exps); </k> <env> .Map </env> +
    +

    The semantics of new (defined below) requires the +execution of all the class' declarations (and also of its +superclasses').

    +

    Object and method closures

    +

    Before we can define the semantics of method application (previously +called function application in SIMPLE), we need to add two more values +to the language, namely object and method closures:

    +
    k
    syntax Val ::= objectClosure(Id, List) + | methodClosure(Id,Int,Ids,Stmt) +
    +

    An object value consists of an objectClosure-wrapped bag +containing the current class of the object and the environment stack +of the object. The current class of an object will always be one of +the classes mapped to an environment in the environment stack of the +object. A method closure encapsulates the method's parameters and +code (last two arguments), as well as the object context in which the +method code should execute. This object context includes the current +class of the object (the first argument of methodClosure) and +the object environment stack (located in the object stored at the +location specified as the second argument of methodClosure).

    +

    Method application

    +

    KOOL has a complex mechanism to invoke methods, because it allows both +dynamic method dispatch and methods as first-class-citizen values (the +latter making it a higher-order language). The invocation mechanism +will be defined later. What is sufficient to know for now is that +the two arguments of the application construct eventually reduce to +values, the first being a method closure and the latter a list of +values. The semantics of the method closure application is then as +expected: the local environment and control are stacked, then we +switch to method closure's class and object environment and execute +the method body. The mkDecls construct is the one that came +with the unchanged semantics of SIMPLE above.

    +
    k
    syntax KItem ::= fstackFrame(Map,K,List,K) + // TODO(KORE): drop the additional production once parsing issue #1842 is fixed + | (Map,K,K) + + rule <k> methodClosure(Class,OL,Xs,S)(Vs:Vals) ~> K + => mkDecls(Xs,Vs) S return; </k> + <env> Env => .Map </env> + <store>... OL |-> objectClosure(_, EnvStack)...</store> + //<br/> // TODO(KORE): support latex annotations #1799 + <control> + <xstack> XS </xstack> + <fstack> .List => ListItem(fstackFrame(Env, K, XS, <crntObj> Obj' </crntObj>)) + ...</fstack> + <crntObj> Obj' => <crntClass> Class </crntClass> <envStack> EnvStack </envStack> </crntObj> + </control> +
    +

    Spawn

    +

    We want to extend the semantics of spawn to also share the +current object environment with the child thread, in addition to the +current environment. This extension will allow us to also use method +invocations in the spawned statements, which will be thus looked up as +expected, using dynamic method dispatch. This lookup operation would +fail if the child thread did not have access to its parent's object +environment.

    +
    k
    rule <thread>... + <k> spawn S => !T:Int ...</k> + <env> Env </env> + <crntObj> Obj </crntObj> + ...</thread> + (.Bag => <thread>... + <k> S </k> + <env> Env </env> + <id> !T </id> + <crntObj> Obj </crntObj> + ...</thread>) +
    +

    Semantics of the new KOOL constructs

    +

    Class declaration

    +

    Initially, the classes forming the program are moved into their +corresponding cells:

    +
    k
    rule <k> class Class1 extends Class2 { S } => . ...</k> + <classes>... (.Bag => <classData> + <className> Class1 </className> + <baseClass> Class2 </baseClass> + <declarations> S </declarations> + </classData>) + ...</classes> +
    +

    Method declaration

    +

    Like in SIMPLE, method names are added to the environment and bound +to their code. However, unlike in SIMPLE where each function was +executed in the same environment, namely the program global +environment, a method in KOOL needs to be executed into its object's +environment. Thus, methods evaluate to closures, which encapsulate +their object's context (i.e., the current class and environment stack +of the object) in addition to method's parameters and body. This +approach to bind method names to method closures in the environment +will also allow objects to pass their methods to other objects, to +dynamically change their methods by assigning them other method +closures, and even to allow all these to be done from other objects. +This gives the KOOL programmer a lot of power; one should use this +power wisely, though, because programs can become easily hard to +understand and reason about if one overuses these features.

    +
    k
    rule <k> method F:Id(Xs:Ids) S => . ...</k> + <crntClass> Class:Id </crntClass> + <location> OL:Int </location> + <env> Env => Env[F <- L] </env> + <store>... .Map => L |-> methodClosure(Class,OL,Xs,S) ...</store> + <nextLoc> L => L +Int 1 </nextLoc> +
    +

    New

    +

    The semantics of new consists of two actions: memory +allocation for the new object and execution of the corresponding +constructor. Then the created object is returned as the result of the +new operation; the value returned by the constructor, if any, +is discarded. The current environment and object are stored onto the +stack and recovered after new (according to the semantics of +return borrowed from SIMPLE, when the statement +return this; in the rule below is reached and evaluated), +because the object creation part of new will destroy them. +The rule below also initializes the object creation process by +emptying the local environment and the current object, and allocating +a location in the store where the created object will be eventually +stored (this is what the storeObj task after the object +creation task in the rule below will do—its rule is defined +shortly). The location where the object will be stored is also made +available in the crntObj cell, so that method closures can +refer to it (see rule above).

    +
    k
    syntax KItem ::= "envStackFrame" "(" Id "," Map ")" + + rule <k> new Class:Id(Vs:Vals) ~> K + => create(Class) ~> storeObj ~> Class(Vs); return this; </k> + <env> Env => .Map </env> + <nextLoc> L:Int => L +Int 1 </nextLoc> + //<br/> // TODO(KORE): support latex annotations #1799 + <control> <xstack> XS </xstack> + <crntObj> Obj + => <crntClass> Object </crntClass> + <envStack> ListItem(envStackFrame(Object, .Map)) </envStack> + <location> L </location> + </crntObj> + <fstack> .List => ListItem(fstackFrame(Env, K, XS, <crntObj> Obj </crntObj>)) ...</fstack> + </control> +
    +

    The creation of a new object (the memory allocation part only) is +a recursive process, requiring to first create an object for the +superclass. A memory object representation is a layered structure: +for each class on the path from the instance class to the root of the +hierarchy there is a layer including the memory allocated for the +members (both fields and methods) of that class.

    +
    k
    syntax KItem ::= create(Id) + + rule <k> create(Class:Id) + => create(Class1) ~> setCrntClass(Class) ~> S ~> addEnvLayer ...</k> + <className> Class </className> + <baseClass> Class1:Id </baseClass> + <declarations> S </declarations> + + rule <k> create(Object) => . ...</k> +
    +

    The next operation sets the current class of the current object. +This is necessary to be done at each layer, because the current class +of the object is enclosed as part of the method closures (see the +semantics of method declarations above).

    +
    k
    syntax KItem ::= setCrntClass(Id) + + rule <k> setCrntClass(C) => . ...</k> + <crntClass> _ => C </crntClass> +
    +

    The next operation adds a new tagged environment layer to the +current object and gets ready for the next layer by clearing the +environment (note that create expects the environment to be +empty).

    +
    k
    syntax KItem ::= "addEnvLayer" + + rule <k> addEnvLayer => . ...</k> + <env> Env => .Map </env> + <crntClass> Class:Id </crntClass> + <envStack> .List => ListItem(envStackFrame(Class, Env)) ...</envStack> +
    +

    The following operation stores the created object at the location +reserved by new. Note that the location reserved by +new was temporarily stored in the crntObj cell +precisely for this purpose. Now that the newly created object is +stored at its location and that all method closures are aware of it, +the location is unnecessary and thus we delete it from the +crntObj cell.

    +
    k
    syntax KItem ::= "storeObj" + + rule <k> storeObj => . ...</k> + <crntObj> <crntClass> CC </crntClass> <envStack> ES </envStack> (<location> L:Int </location> => .Bag) </crntObj> + <store>... .Map => L |-> objectClosure(CC, ES) ...</store> +
    +

    Self reference

    +

    The semantics of this is straightforward: evaluate to the +current object.

    +
    k
    rule <k> this => objectClosure(CC, ES) ...</k> + <crntObj> <crntClass> CC </crntClass> <envStack> ES </envStack> </crntObj> +
    +

    Object member access

    +

    We can access an object member (field or method) either explicitly, +using the construct e.x, or implicitly, using only the member +name x directly. The borrowed semantics of SIMPLE will +already lookup a sole name in the local environment. The first rule +below reduces implicit member access to explicit access when the name +cannot be found in the local environment. There are two cases to +analyze for explicit object member access, depending upon whether the +object is a proper object or it is just a redirection to the parent +class via the construct super. In the first case, we +evaluate the object expression and lookup the member starting with the +current class (static scoping). Note the use of the conditional +evaluation context. In the second case, we just lookup the member +starting with the superclass of the current class. In both cases, +the lookupMember task eventually yields a lookup(L) +task for some appropriate location L, which will be further +solved with the corresponding rule borrowed from SIMPLE. Note that the +current object is not altered by super, so future method +invocations see the entire object, as needed for dynamic method dispatch.

    +
    k
    rule <k> X:Id => this . X ...</k> <env> Env:Map </env> + when notBool(X in keys(Env)) + + context HOLE._::Id when (HOLE =/=K super) + +// TODO: explain how Assoc matching has been replaced with two rules here. +// Maybe also improve it a bit. + +/* rule objectClosure(<crntClass> Class:Id </crntClass> + <envStack>... envStackFrame(Class,EnvC) EStack </envStack>) + . X:Id + => lookupMember(envStackFrame(Class,EnvC) EStack, X) */ + + rule objectClosure(Class:Id, ListItem(envStackFrame(Class,Env)) EStack) + . X:Id + => lookupMember(ListItem(envStackFrame(Class,Env)) EStack, X) + rule objectClosure(Class:Id, (ListItem(envStackFrame(Class':Id,_)) => .List) _) + . _X:Id + when Class =/=K Class' + +/* rule <k> super . X => lookupMember(EStack, X) ...</k> + <crntClass> Class </crntClass> + <envStack>... envStackFrame(Class,EnvC) EStack </envStack> */ + rule <k> super . X => lookupMember(EStack, X) ...</k> + <crntClass> Class:Id </crntClass> + <envStack> ListItem(envStackFrame(Class,_)) EStack </envStack> + rule <k> super . _X ...</k> + <crntClass> Class </crntClass> + <envStack> ListItem(envStackFrame(Class':Id,_)) => .List ...</envStack> + when Class =/=K Class' +
    +

    Method invocation

    +

    Unlike in SIMPLE, in KOOL application was declared strict only in its +second argument. That is because we want to ensure dynamic method +dispatch when the first argument is a method access. As a +consequence, we need to consider all the cases of interest for the +first argument and to explicitly say what to do in each case. In all +cases except for method access in a proper object (i.e., not +super), we want the same behavior for the first argument as +if it was not in a method invocation position. When it is a member +access (the third rule below), we look it up starting with the +instance class of the corresponding object. This ensures dynamic +dispatch for methods; it actually dynamically dispatches field +accesses, too, which is correct in KOOL, because one can assign method +closures to fields and the field appeared in a method invocation +context. The last context declaration below says that method +applications or array accesses are also allowed as first argument to +applications; that is because methods are allowed to return methods +and arrays are allowed to hold methods in KOOL, since it is +higher-order. If that is the case, then we want to evaluate the +method call or the array access.

    +
    k
    rule <k> (X:Id => V)(_:Exps) ...</k> + <env>... X |-> L ...</env> + <store>... L |-> V:Val ...</store> [group(lookup)] + + rule <k> (X:Id => this . X)(_:Exps) ...</k> + <env> Env </env> + when notBool(X in keys(Env)) + + context HOLE._::Id(_) when HOLE =/=K super + + rule (objectClosure(_, EStack) . X + => lookupMember(EStack, X:Id))(_:Exps) + +/* rule <k> (super . X + => lookupMember(EStack,X))(_:Exps)...</k> + <crntClass> Class </crntClass> + <envStack>... envStackFrame(Class,_) EStack </envStack> */ + rule <k> (super . X + => lookupMember(EStack,X))(_:Exps)...</k> + <crntClass> Class </crntClass> + <envStack> ListItem(envStackFrame(Class,_)) EStack </envStack> + rule <k> (super . _X)(_:Exps) ...</k> + <crntClass> Class </crntClass> + <envStack> ListItem(envStackFrame(Class':Id,_)) => .List ...</envStack> + when Class =/=K Class' + + // TODO(KORE): fix getKLabel #1801 + rule (A:Exp(B:Exps))(C:Exps) => A(B) ~> #freezerFunCall(C) + rule (A:Exp[B:Exps])(C:Exps) => A[B] ~> #freezerFunCall(C) + rule V:Val ~> #freezerFunCall(C:Exps) => V(C) + syntax KItem ::= "#freezerFunCall" "(" K ")" + /* + context HOLE(_:Exps) + when getKLabel(HOLE) ==K #klabel(`_(_)`) orBool getKLabel(HOLE) ==K #klabel(`_[_]`) + */ +
    +

    Eventually, each of the rules above produces a lookup(L) +task as a replacement for the method. When that happens, we just +lookup the value at location L:

    +
    k
    rule <k> (lookup(L) => V)(_:Exps) ...</k> <store>... L |-> V:Val ...</store> + [group(lookup)] +
    +

    The value V looked up above is expected to be a method closure, +in which case the semantics of method application given above will +apply. Otherwise, the execution will get stuck.

    +

    Instance Of

    +

    It searches the object environment for a layer corresponding to the +desired class. It returns true iff it can find the class, +otherwise it returns false; it only gets stuck when its first +argument does not evaluate to an object.

    +
    k
    rule objectClosure(_, ListItem(envStackFrame(C,_)) _) + instanceOf C => true + + rule objectClosure(_, (ListItem(envStackFrame(C,_)) => .List) _) + instanceOf C' when C =/=K C' +//TODO: remove the sort cast ::Id of C above, when sort inference bug fixed + + rule objectClosure(_, .List) instanceOf _ => false +
    +

    Cast

    +

    In untyped KOOL, we prefer to not check the validity of casting. In +other words, any cast is allowed on any object, simply changing the +current class of the object to the desired class. The execution will +get stuck later if one attempts to access a field which is not +available. Moreover, the execution may complete successfully even +in the presence of invalid casts, provided that each accessed member +during the current execution is, or happens to be, available.

    +
    k
    rule (C) objectClosure(_ , EnvStack) => objectClosure(C ,EnvStack) +
    +

    KOOL-specific auxiliary declarations and operations

    +

    Here we define all the auxiliary constructs used in the above +KOOL-specific semantics (those used in the SIMPLE fragment +have already been defined in a corresponding section above).

    +

    Objects as lvalues

    +

    The current machinery borrowed with the semantics of SIMPLE allows us +to enrich the set of lvalues, this way allowing new means to assign +values to locations. In KOOL, we want object member names to be +lvalues, so that we can assign values to them using the already +existing machinery. The first rule below ensures that the object is +always explicit, the evaluation context enforces the object to be +evaluated, and finally the second rule initiates the lookup for the +member's location based on the current class of the object.

    +
    k
    rule <k> lvalue(X:Id => this . X) ...</k> <env> Env </env> + when notBool(X in keys(Env)) + + context lvalue((HOLE . _)::Exp) + +/* rule lvalue(objectClosure(<crntClass> C </crntClass> + <envStack>... envStackFrame(C,EnvC) EStack </envStack>) + . X + => lookupMember(<envStack> envStackFrame(C,EnvC) EStack </envStack>, + X)) */ + rule lvalue(objectClosure(Class, ListItem(envStackFrame(Class,Env)) EStack) + . X + => lookupMember(ListItem(envStackFrame(Class,Env)) EStack, + X)) + rule lvalue(objectClosure(Class, (ListItem(envStackFrame(Class':Id,_)) => .List) _) + . _X) + when Class =/=K Class' +
    +

    Lookup member

    +

    It searches for the given member in the given environment stack, +starting with the most concrete class and going up in the hierarchy.

    +
    k
    // TODO(KORE): clarify sort inferences #1803 + syntax Exp ::= lookupMember(List, Id) [function] + /* + syntax KItem ::= lookupMember(EnvStackCell,Id) [function] + */ + +// rule lookupMember(<envStack> envStackFrame(_, <env>... X|->L ...</env>) ...</envStack>, X) +// => lookup(L) + rule lookupMember(ListItem(envStackFrame(_, X|->L _)) _, X) + => lookup(L) + +// rule lookupMember(<envStack> envStackFrame(_, <env> Env </env>) => .List ...</envStack>, X) +// when notBool(X in keys(Env)) + rule lookupMember(ListItem(envStackFrame(_, Env)) Rest, X) => + lookupMember(Rest, X) + when notBool(X in keys(Env)) +//TODO: beautify the above + +endmodule +
    +

    Go to Lesson 2, KOOL typed dynamic.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/2_languages/2_kool/2_typed/1_dynamic/kool-typed-dynamic/index.html b/k-distribution/pl-tutorial/2_languages/2_kool/2_typed/1_dynamic/kool-typed-dynamic/index.html new file mode 100644 index 00000000000..beb2fedd28d --- /dev/null +++ b/k-distribution/pl-tutorial/2_languages/2_kool/2_typed/1_dynamic/kool-typed-dynamic/index.html @@ -0,0 +1,1385 @@ + + + + + + + + + + + + + + +KOOL — Typed — Dynamic | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    KOOL — Typed — Dynamic

    +

    Author: Grigore Roșu (grosu@illinois.edu)
    +Organization: University of Illinois at Urbana-Champaign

    +

    Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
    +Organization: University of Bucharest

    +

    Abstract

    +

    This is the K dynamic semantics of the typed KOOL language. It is +very similar to the semantics of the untyped KOOL, the difference +being that we now check the typing policy dynamically. Since we have +to now declare the types of variables and methods, we adopt a syntax +for those which is close to Java. Like in the semantics of +untyped KOOL, where we borrowed almost all the semantics of untyped +SIMPLE, we are going to also borrow much of the semantics of +dynamically typed SIMPLE here. We will highlight the differences +between the dynamically typed and the untyped KOOL as we proceed with +the semantics. In general, the type policy of the typed KOOL language +is similar to that of Java. You may find it useful to also read +the discussion in the preamble of the static semantics of typed KOOL +before proceeding.

    +
    k
    module KOOL-TYPED-DYNAMIC-SYNTAX + imports DOMAINS-SYNTAX +
    +

    Syntax

    +

    Like for the untyped KOOL language, the syntax of typed KOOL extends +that of typed SIMPLE with object-oriented constructs. +The syntax below was produced by copying and modifying/extending the +syntax of dynamically typed SIMPLE. In fact, the only change we made +to the existing syntax of dynamically typed SIMPLE was to change the +strictness of the application construct like in untyped KOOL, from +strict to strict(2) (because application is not +strict in the first argument anymore due to dynamic method dispatch). +The KOOL-specific syntactic extensions are identical to those in +untyped KOOL.

    +
    k
    syntax Id ::= "Object" [token] | "Main" [token] +
    +

    Types

    +
    k
    syntax Type ::= "void" | "int" | "bool" | "string" + | Id // KOOL class + | Type "[" "]" + | "(" Type ")" [bracket] + > Types "->" Type + // TODO(KORE): drop klabel once issues #1913 are fixed + syntax Types ::= List{Type,","} [klabel(_,_::Types)] + /* + syntax Types ::= List{Type,","} + */ +
    +

    Declarations

    +
    k
    syntax Param ::= Type Id + syntax Params ::= List{Param,","} + + syntax Stmt ::= Type Exps ";" [avoid] + | Type Id "(" Params ")" Block // stays like in typed SIMPLE + | "class" Id Block // KOOL + | "class" Id "extends" Id Block // KOOL +
    +

    Expressions

    +
    k
    syntax Exp ::= Int | Bool | String | Id + | "this" // KOOL + | "super" // KOOL + | "(" Exp ")" [bracket] + | "++" Exp + | Exp "instanceOf" Id [strict(1)] // KOOL + | "(" Id ")" Exp [strict(2)] // KOOL cast + | "new" Id "(" Exps ")" [strict(2)] // KOOL + | Exp "." Id // KOOL + > Exp "[" Exps "]" [strict] + > Exp "(" Exps ")" [strict(2)] // was strict in SIMPLE + | "-" Exp [strict] + | "sizeOf" "(" Exp ")" [strict] + | "read" "(" ")" + > left: + Exp "*" Exp [strict, left] + | Exp "/" Exp [strict, left] + | Exp "%" Exp [strict, left] + > left: + Exp "+" Exp [strict, left] + | Exp "-" Exp [strict, left] + > non-assoc: + Exp "<" Exp [strict, non-assoc] + | Exp "<=" Exp [strict, non-assoc] + | Exp ">" Exp [strict, non-assoc] + | Exp ">=" Exp [strict, non-assoc] + | Exp "==" Exp [strict, non-assoc] + | Exp "!=" Exp [strict, non-assoc] + > "!" Exp [strict] + > left: + Exp "&&" Exp [strict(1), left] + | Exp "||" Exp [strict(1), left] + > "spawn" Block + > Exp "=" Exp [strict(2), right] + + syntax Exps ::= List{Exp,","} [strict, klabel(exps)] + syntax Val + syntax Vals ::= List{Val,","} [klabel(exps)] +
    +

    Statements

    +
    k
    syntax Block ::= "{" "}" + | "{" Stmt "}" + + syntax Stmt ::= Block + | Exp ";" [strict] + | "if" "(" Exp ")" Block "else" Block [avoid, strict(1)] + | "if" "(" Exp ")" Block [macro] + | "while" "(" Exp ")" Block + | "for" "(" Stmt Exp ";" Exp ")" Block [macro] + | "print" "(" Exps ")" ";" [strict] + | "return" Exp ";" [strict] + | "return" ";" + | "try" Block "catch" "(" Param ")" Block + | "throw" Exp ";" [strict] + | "join" Exp ";" [strict] + | "acquire" Exp ";" [strict] + | "release" Exp ";" [strict] + | "rendezvous" Exp ";" [strict] + + syntax Stmt ::= Stmt Stmt [right] +
    +

    Desugaring macros

    +
    k
    rule if (E) S => if (E) S else {} + rule for(Start Cond; Step) {S::Stmt} => {Start while(Cond){S Step;}} + rule T::Type E1::Exp, E2::Exp, Es::Exps; => T E1; T E2, Es; [anywhere] + rule T::Type X::Id = E; => T X; X = E; [anywhere] + + rule class C:Id S => class C extends Object S // KOOL + +endmodule +
    +

    Semantics

    +

    We first discuss the new configuration, then we include the semantics of +the constructs borrowed from SIMPLE which stay unchanged, then those +whose semantics had to change, and finally the semantics of the +KOOL-specific constructs.

    +
    k
    module KOOL-TYPED-DYNAMIC + imports KOOL-TYPED-DYNAMIC-SYNTAX + imports DOMAINS +
    +

    Configuration

    +

    The configuration of dynamically typed KOOL is almost identical to +that of its untyped variant. The only difference is the cell +return, inside the control cell, whose role is to +hold the expected return type of the invoked method. That is because +we want to dynamically check that the value that a method returns has +the expected type.

    +
    k
    // the syntax declarations below are required because the sorts are + // referenced directly by a production and, because of the way KIL to KORE + // is implemented, the configuration syntax is not available yet + // should simply work once KIL is removed completely + // check other definitions for this hack as well + syntax EnvCell + syntax ControlCellFragment + syntax EnvStackCell + syntax CrntObjCellFragment + + configuration <T color="red"> + <threads color="orange"> + <thread multiplicity="*" type="Set" color="yellow"> + <k color="green"> ($PGM:Stmt ~> execute) </k> + //<br/> // TODO(KORE): support latex annotations #1799 + <control color="cyan"> + <fstack color="blue"> .List </fstack> + <xstack color="purple"> .List </xstack> + <returnType color="LimeGreen"> void </returnType> // KOOL + //<br/> // TODO(KORE): support latex annotations #1799 + <crntObj color="Fuchsia"> // KOOL + <crntClass> Object </crntClass> + <envStack> .List </envStack> + <location multiplicity="?"> .K </location> + </crntObj> + </control> + //<br/> // TODO(KORE): support latex annotations #1799 + <env color="violet"> .Map </env> + <holds color="black"> .Map </holds> + <id color="pink"> 0 </id> + </thread> + </threads> + //<br/> // TODO(KORE): support latex annotations #1799 + <store color="white"> .Map </store> + <busy color="cyan">.Set </busy> + <terminated color="red"> .Set </terminated> + <input color="magenta" stream="stdin"> .List </input> + <output color="brown" stream="stdout"> .List </output> + <nextLoc color="gray"> 0 </nextLoc> + //<br/> // TODO(KORE): support latex annotations #1799 + <classes color="Fuchsia"> // KOOL + <classData multiplicity="*" type="Map" color="Fuchsia"> + <className color="Fuchsia"> Main </className> + <baseClass color="Fuchsia"> Object </baseClass> + <declarations color="Fuchsia"> .K </declarations> + </classData> + </classes> + </T> +
    +

    Unchanged semantics from dynamically typed SIMPLE

    +

    The semantics below is taken over from dynamically typed SIMPLE +unchanged. Like for untyped KOOL, the semantics of function/method +declaration and invocation, and of program initialization needs to +change. Moreover, due to subtyping, the semantics of several imported +SIMPLE constructs can be made more general, such as that of the +return statement, that of the assignment, and that of the exceptions. +We removed all these from the imported semantics of SIMPLE below and +gave their modified semantics right after, together with the extended +semantics of thread spawning (which is identical to that of untyped +KOOL).

    +
    k
    syntax Val ::= Int | Bool | String + | array(Type,Int,Int) + syntax Exp ::= Val + syntax Exps ::= Vals + syntax KResult ::= Val + syntax KResult ::= Vals + + + syntax KItem ::= undefined(Type) [latex(\bot_{#1})] + + rule <k> T:Type X:Id; => . ...</k> + <env> Env => Env[X <- L] </env> + <store>... .Map => L |-> undefined(T) ...</store> + <nextLoc> L:Int => L +Int 1 </nextLoc> + + + rule <k> T:Type X:Id[N:Int]; => . ...</k> + <env> Env => Env[X <- L] </env> + <store>... .Map => L |-> array(T, L +Int 1, N) + (L +Int 1)...(L +Int N) |-> undefined(T) ...</store> + <nextLoc> L:Int => L +Int 1 +Int N </nextLoc> + requires N >=Int 0 + + context _:Type _::Exp[HOLE::Exps]; + + + syntax Id ::= "$1" [token] | "$2" [token] + rule T:Type X:Id[N1:Int, N2:Int, Vs:Vals]; + => T[]<Vs> X[N1]; + { + T[][]<Vs> $1=X; + for(int $2=0; $2 <= N1 - 1; ++$2) { + T X[N2,Vs]; + $1[$2] = X; + } + } + + + rule <k> X:Id => V ...</k> + <env>... X |-> L ...</env> + <store>... L |-> V:Val ...</store> [group(lookup)] + + + context ++(HOLE => lvalue(HOLE)) + rule <k> ++loc(L) => I +Int 1 ...</k> + <store>... L |-> (I:Int => I +Int 1) ...</store> [group(increment)] + + + rule I1 + I2 => I1 +Int I2 + rule Str1 + Str2 => Str1 +String Str2 + rule I1 - I2 => I1 -Int I2 + rule I1 * I2 => I1 *Int I2 + rule I1 / I2 => I1 /Int I2 requires I2 =/=K 0 + rule I1 % I2 => I1 %Int I2 requires I2 =/=K 0 + rule - I => 0 -Int I + rule I1 < I2 => I1 <Int I2 + rule I1 <= I2 => I1 <=Int I2 + rule I1 > I2 => I1 >Int I2 + rule I1 >= I2 => I1 >=Int I2 + rule V1:Val == V2:Val => V1 ==K V2 + rule V1:Val != V2:Val => V1 =/=K V2 + rule ! T => notBool(T) + rule true && E => E + rule false && _ => false + rule true || _ => true + rule false || E => E + + + rule V:Val[N1:Int, N2:Int, Vs:Vals] => V[N1][N2, Vs] + [anywhere] + + rule array(_:Type, L:Int, M:Int)[N:Int] => lookup(L +Int N) + requires N >=Int 0 andBool N <Int M [anywhere] + + rule sizeOf(array(_,_,N)) => N + + + syntax Val ::= nothing(Type) + rule <k> return; => return nothing(T); ...</k> <returnType> T </returnType> + + + rule <k> read() => I ...</k> <input> ListItem(I:Int) => .List ...</input> [group(read)] + + + context (HOLE => lvalue(HOLE)) = _ + + + rule {} => . + rule <k> { S } => S ~> setEnv(Env) ...</k> <env> Env </env> + + + rule S1:Stmt S2:Stmt => S1 ~> S2 + + + rule _:Val; => . + + + rule if ( true) S else _ => S + rule if (false) _ else S => S + + + rule while (E) S => if (E) {S while(E)S} + + + rule <k> print(V:Val, Es => Es); ...</k> <output>... .List => ListItem(V) </output> + requires typeOf(V) ==K int orBool typeOf(V) ==K string [group(print)] + rule print(.Vals); => . + + + rule (<thread>... <k>.</k> <holds>H</holds> <id>T</id> ...</thread> => .Bag) + <busy> Busy => Busy -Set keys(H) </busy> + <terminated>... .Set => SetItem(T) ...</terminated> + + rule <k> join T:Int; => . ...</k> + <terminated>... SetItem(T) ...</terminated> + + rule <k> acquire V:Val; => . ...</k> + <holds>... .Map => V |-> 0 ...</holds> + <busy> Busy (.Set => SetItem(V)) </busy> + requires (notBool(V in Busy:Set)) [group(acquire)] + + rule <k> acquire V; => . ...</k> + <holds>... V:Val |-> (N:Int => N +Int 1) ...</holds> + + rule <k> release V:Val; => . ...</k> + <holds>... V |-> (N => N:Int -Int 1) ...</holds> + requires N >Int 0 + + rule <k> release V; => . ...</k> <holds>... V:Val |-> 0 => .Map ...</holds> + <busy>... SetItem(V) => .Set ...</busy> + + rule <k> rendezvous V:Val; => . ...</k> + <k> rendezvous V; => . ...</k> [group(rendezvous)] +
    +

    Unchanged auxiliary operations from dynamically typed SIMPLE

    +
    k
    syntax Stmt ::= mkDecls(Params,Vals) [function] + rule mkDecls((T:Type X:Id, Ps:Params), (V:Val, Vs:Vals)) + => T X=V; mkDecls(Ps,Vs) + rule mkDecls(.Params,.Vals) => {} + + syntax Exp ::= lookup(Int) + rule <k> lookup(L) => V ...</k> <store>... L |-> V:Val ...</store> [group(lookup)] + + syntax KItem ::= setEnv(Map) + rule <k> setEnv(Env) => . ...</k> <env> _ => Env </env> + rule (setEnv(_) => .) ~> setEnv(_) + + syntax Exp ::= lvalue(K) + syntax Val ::= loc(Int) + rule <k> lvalue(X:Id => loc(L)) ...</k> <env>... X |-> L:Int ...</env> + + context lvalue(_::Exp[HOLE::Exps]) + context lvalue(HOLE::Exp[_::Exps]) + + rule lvalue(lookup(L:Int) => loc(L)) + + syntax Type ::= Type "<" Vals ">" [function] + rule T:Type<_,Vs:Vals> => T[]<Vs> + rule T:Type<.Vals> => T + + syntax Map ::= Int "..." Int "|->" K + [function, latex({#1}\ldots{#2}\mapsto{#3})] + rule N...M |-> _ => .Map requires N >Int M + rule N...M |-> K => N |-> K (N +Int 1)...M |-> K requires N <=Int M + + syntax Type ::= typeOf(K) [function] + rule typeOf(_:Int) => int + rule typeOf(_:Bool) => bool + rule typeOf(_:String) => string + rule typeOf(array(T,_,_)) => (T[]) + rule typeOf(undefined(T)) => T + rule typeOf(nothing(T)) => T + + syntax Types ::= getTypes(Params) [function] + rule getTypes(T:Type _:Id) => T, .Types + rule getTypes(T:Type _:Id, P, Ps) => T, getTypes(P,Ps) + rule getTypes(.Params) => void, .Types +
    +

    Changes to the existing dynamically typed SIMPLE semantics

    +

    We extend/change the semantics of several SIMPLE constructs in order +to take advantage of the richer KOOL semantic infrastructure and thus +get more from the existing SIMPLE constructs.

    +

    Program initialization

    +

    Like in untyped KOOL.

    +
    k
    syntax KItem ::= "execute" + rule <k> execute => new Main(.Exps); </k> <env> .Map </env> +
    +

    Method application

    +

    The only change to untyped KOOL's values is that method closures are +now typed (their first argument holds their type):

    +
    k
    syntax Val ::= objectClosure(Id,List) + | methodClosure(Type,Id,Int,Params,Stmt) +
    +

    The type held by a method clossure will be the entire type of the +method, not only its result type like the lambda-closure of typed +SIMPLE. The reason for this change comes from the the need to +dynamically upcast values when passed to contexts where values of +superclass types are expected; since we want method closures to be +first-class-citizen values in our language, we have to be able to +dynamically upcast them, and in order to do that elegantly it is +convenient to store the entire ``current type'' of the method closure +instead of just its result type. Note that this was unnecessary in +the semantics of the dynamically typed SIMPLE language.

    +

    Method closure application needs to also set a new return type in +the return cell, like in dynamically typed SIMPLE, in order +for the values returned by its body to be checked against the return +type of the method. To do this correctly, we also need to stack the +current status of the return cell and then pop it when the +method returns. We have to do the same with the current object +environment, so we group them together in the stack frame.

    +
    k
    syntax KItem ::= fstackFrame(Map, K, List, Type, K) + + rule <k> methodClosure(_->T,Class,OL,Ps,S)(Vs:Vals) ~> K + => mkDecls(Ps,Vs) S return; </k> + <env> Env => .Map </env> + <store>... OL |-> objectClosure(_, EStack)...</store> + //<br/> // TODO(KORE): support latex annotations #1799 + <control> + <fstack> .List => ListItem(fstackFrame(Env, K, XS, T', <crntObj> Obj' </crntObj>)) ...</fstack> + <xstack> XS </xstack> + <returnType> T' => T </returnType> + <crntObj> Obj' => <crntClass> Class </crntClass> <envStack> EStack </envStack> </crntObj> + </control> +
    +

    At method return, we have to check that the type of the returned +value is a subtype of the expected return type. Moreover, if that is +the case, then we also upcast the returned value to one of the +expected type. The computation item unsafeCast(V,T) changes +the typeof V to T without any additional checks; however, it only +does it when V is an object or a method, otherwise it returns V +unchanged.

    +
    k
    rule <k> return V:Val; ~> _ + => subtype(typeOf(V), T) ~> true? ~> unsafeCast(V, T) ~> K + </k> + <control> + <fstack> ListItem(fstackFrame(Env, K, XS, RT, <crntObj> CO </crntObj>)) => .List ...</fstack> + <xstack> _ => XS </xstack> + <returnType> T:Type => RT </returnType> + <crntObj> _ => CO </crntObj> + </control> + <env> _ => Env </env> +
    +

    Assignment

    +

    Typed KOOL allows to assign subtype instance values to supertype +lvalues. The semantics of assignment below is similar in spirit to +dynamically typed SIMPLE's, but a check is performed that the assigned +value's type is a subtype of the location's type. If that is the +case, then the assigned value is returned as a result and stored, but +it is upcast appropriately first, so the context will continue to see +a value of the expected type of the location. Note that the type of a +location is implicit in the type of its contents and it never changes +during the execution of a program; its type is assigned when the +location is allocated and initialized, and then only type-preserving +values are allowed to be stored in each location.

    +
    k
    rule <k> loc(L) = V:Val + => subtype(typeOf(V),typeOf(V')) ~> true? + ~> unsafeCast(V, typeOf(V')) ...</k> + <store>... L |-> (V' => unsafeCast(V, typeOf(V'))) ...</store> + [group(assignment)] +
    +

    Typed exceptions

    +

    Exceptions are propagated now until a catch that can handle them is +encountered.

    +
    k
    syntax KItem ::= xstackFrame(Param, Stmt, K, Map, K) + syntax KItem ::= "popx" + + rule <k> (try S1 catch(P) S2 => S1 ~> popx) ~> K </k> + <control> + <xstack> .List => ListItem(xstackFrame(P, S2, K, Env, C)) ...</xstack> + C + </control> + <env> Env </env> + + rule <k> popx => . ...</k> + <xstack> ListItem(_) => .List ...</xstack> + + rule <k> throw V:Val; ~> _ + => if (subtype(typeOf(V),T)) { T X = V; S2 } else { throw V; } ~> K + </k> + <control> + <xstack> ListItem(xstackFrame(T:Type X:Id, S2, K, Env, C)) => .List ...</xstack> + (_ => C) + </control> + <env> _ => Env </env> +
    +

    Spawn

    +

    Like in untyped KOOL.

    +
    k
    rule <thread>... + <k> spawn S => !T:Int ...</k> + <env> Env </env> + <crntObj> Obj </crntObj> + ...</thread> + (.Bag => <thread>... + <k> S </k> + <env> Env </env> + <id> !T </id> + <crntObj> Obj </crntObj> + ...</thread>) +
    +

    Semantics of the new KOOL constructs

    +

    Class declaration

    +

    Like in untyped KOOL.

    +
    k
    rule <k> class Class1 extends Class2 { S } => . ...</k> + <classes>... (.Bag => <classData> + <className> Class1 </className> + <baseClass> Class2 </baseClass> + <declarations> S </declarations> + </classData>) + ...</classes> +
    +

    Method declaration

    +

    Methods are now typed and we need to store their types in their +closures, so that their type contract can be checked at invocation +time. The rule below is conceptually similar to that of untyped KOOL; +the only difference is the addition of the types.

    +
    k
    rule <k> T:Type F:Id(Ps:Params) S => . ...</k> + <crntClass> C </crntClass> + <location> OL </location> + <env> Env => Env[F <- L] </env> + <store>... .Map => L|->methodClosure(getTypes(Ps)->T,C,OL,Ps,S) ...</store> + <nextLoc> L => L +Int 1 </nextLoc> +
    +

    New

    +

    The semantics of new in dynamically typed KOOL is also +similar to that in untyped KOOL, the main difference being the +management of the return types. Indeed, when a new object is created +we also have to stack the current type in the return cell in +order to be recovered after the creation of the new object. Only the +first rule below needs to be changed; the others are identical to +those in untyped KOOL.

    +
    k
    syntax KItem ::= envStackFrame(Id, Map) + + rule <k> new Class:Id(Vs:Vals) ~> K + => create(Class) ~> (storeObj ~> ((Class(Vs)); return this;)) </k> + <env> Env => .Map </env> + <nextLoc> L:Int => L +Int 1 </nextLoc> + //<br/> // TODO(KORE): support latex annotations #1799 + <control> + <xstack> XS </xstack> + <crntObj> Obj + => <crntClass> Object </crntClass> + <envStack> ListItem(envStackFrame(Object, .Map)) </envStack> + <location> L </location> + </crntObj> + <returnType> T => Class </returnType> + <fstack> .List => ListItem(fstackFrame(Env, K, XS, T, <crntObj>Obj</crntObj>)) ...</fstack> + </control> + + syntax KItem ::= create(Id) + + rule <k> create(Class:Id) + => create(Class1) ~> setCrntClass(Class) ~> S ~> addEnvLayer ...</k> + <className> Class </className> + <baseClass> Class1:Id </baseClass> + <declarations> S </declarations> + + rule <k> create(Object) => . ...</k> + + syntax KItem ::= setCrntClass(Id) + + rule <k> setCrntClass(C) => . ...</k> + <crntClass> _ => C </crntClass> + + syntax KItem ::= "addEnvLayer" + + rule <k> addEnvLayer => . ...</k> + <env> Env => .Map </env> + <crntClass> Class:Id </crntClass> + <envStack> .List => ListItem(envStackFrame(Class, Env)) ...</envStack> + + syntax KItem ::= "storeObj" + + rule <k> storeObj => . ...</k> + <crntObj> + <crntClass> Class </crntClass> + <envStack> EStack </envStack> + (<location> L:Int </location> => .Bag) + </crntObj> + <store>... .Map => L |-> objectClosure(Class, EStack) ...</store> +
    +

    Self reference

    +

    Like in untyped KOOL.

    +
    k
    rule <k> this => objectClosure(Class, EStack) ...</k> + <crntObj> + <crntClass> Class </crntClass> + <envStack> EStack </envStack> + ... + </crntObj> +
    +

    Object member access

    +

    Like in untyped KOOL.

    +
    k
    rule <k> X:Id => this . X ...</k> <env> Env:Map </env> + requires notBool(X in keys(Env)) + + context HOLE . _::Id requires (HOLE =/=K super) + +/* rule objectClosure(<crntObj> <crntClass> Class:Id </crntClass> + <envStack>... ListItem((Class,EnvC:EnvCell)) EStack </envStack> </crntObj>) + . X:Id + => lookupMember(<envStack> ListItem((Class,EnvC)) EStack </envStack>, X) */ + rule objectClosure(Class:Id, + ListItem(envStackFrame(Class,Env)) EStack) + . X:Id + => lookupMember(ListItem(envStackFrame(Class,Env)) EStack, X) + rule objectClosure(Class:Id, + (ListItem(envStackFrame(Class':Id,_)) => .List) _EStack) + . _X:Id + requires Class =/=K Class' + +/* rule <k> super . X => lookupMember(<envStack>EStack</envStack>, X) ...</k> + <crntClass> Class </crntClass> + <envStack>... ListItem((Class,EnvC:EnvCell)) EStack </envStack> */ + rule <k> super . X => lookupMember(EStack, X) ...</k> + <crntClass> Class:Id </crntClass> + <envStack> ListItem(envStackFrame(Class,_)) EStack </envStack> + rule <k> super . _X ...</k> + <crntClass> Class:Id </crntClass> + <envStack> (ListItem(envStackFrame(Class':Id,_)) => .List) _EStack </envStack> + requires Class =/=K Class' +
    +

    Method invocation

    +

    The method lookup is the same as in untyped KOOL.

    +
    k
    rule <k> (X:Id => V)(_:Exps) ...</k> + <env>... X |-> L ...</env> + <store>... L |-> V:Val ...</store> [group(lookup)] + + rule <k> (X:Id => this . X)(_:Exps) ...</k> + <env> Env </env> + requires notBool(X in keys(Env)) + + context HOLE._::Id(_) requires HOLE =/=K super + + rule (objectClosure(_, EStack) . X + => lookupMember(EStack, X:Id))(_:Exps) + +/* rule <k> (super . X + => lookupMember(<envStack>EStack</envStack>,X))(_:Exps)...</k> + <crntClass> Class </crntClass> + <envStack>... ListItem((Class,_)) EStack </envStack> */ + rule <k> (super . X + => lookupMember(EStack,X))(_:Exps)...</k> + <crntClass> Class:Id </crntClass> + <envStack> ListItem(envStackFrame(Class,_)) EStack </envStack> + rule <k> (super . _X)(_:Exps)...</k> + <crntClass> Class:Id </crntClass> + <envStack> (ListItem(envStackFrame(Class':Id,_)) => .List) _EStack </envStack> + requires Class =/=K Class' + + // TODO(KORE): fix getKLabel #1801 + rule (A:Exp(B:Exps))(C:Exps) => A(B) ~> #freezerFunCall(C) + rule (A:Exp[B:Exps])(C:Exps) => A[B] ~> #freezerFunCall(C) + rule V:Val ~> #freezerFunCall(C:Exps) => V(C) + syntax KItem ::= "#freezerFunCall" "(" K ")" + /* + context HOLE(_:Exps) + requires getKLabel HOLE ==KLabel '_`(_`) orBool getKLabel HOLE ==KLabel '_`[_`] + */ + + rule <k> (lookup(L) => V)(_:Exps) ...</k> <store>... L |-> V:Val ...</store> + [group(lookup)] +
    +

    Instance of

    +

    Like in untyped KOOL.

    +
    k
    rule objectClosure(_, ListItem(envStackFrame(C,_)) _) + instanceOf C => true + + rule objectClosure(_, (ListItem(envStackFrame(C::Id,_)) => .List) _) + instanceOf C' requires C =/=K C' + + rule objectClosure(_, .List) instanceOf _ => false +
    +

    Cast

    +

    Unlike in untyped KOOL, in typed KOOL we actually check that the object +can indeed be cast to the claimed type.

    +
    k
    rule (C:Id) objectClosure(Irrelevant, EStack) + => objectClosure(Irrelevant, EStack) instanceOf C ~> true? + ~> objectClosure(C, EStack) +
    +

    KOOL-specific auxiliary declarations and operations

    +

    Objects as lvalues

    +

    Like in untyped KOOL.

    +
    k
    rule <k> lvalue(X:Id => this . X) ...</k> <env> Env </env> + requires notBool(X in keys(Env)) + + context lvalue((HOLE . _)::Exp) + +/* rule lvalue(objectClosure(<crntObj> <crntClass> C </crntClass> + <envStack>... ListItem((C,EnvC:EnvCell)) EStack </envStack> </crntObj>) + . X + => lookupMember(<envStack> ListItem((C,EnvC)) EStack </envStack>, + X)) */ + rule lvalue(objectClosure(C:Id, + ListItem(envStackFrame(C,Env)) EStack) + . X + => lookupMember(ListItem(envStackFrame(C,Env)) EStack, + X)) + rule lvalue(objectClosure(C, + (ListItem(envStackFrame(C',_)) => .List) _EStack) + . _X) + requires C =/=K C' +
    +

    Lookup member

    +

    Like in untyped KOOL.

    +
    k
    syntax Exp ::= lookupMember(List,Id) [function] + + rule lookupMember(ListItem(envStackFrame(_, X |-> L _)) _, X) => lookup(L) + + // TODO: fix rule below as shown once we support functions with deep rewrites + // rule lookupMember(<envStack> ListItem((_, <env> Env </env>)) => .List + // ...</envStack>, X) + // requires notBool(X in keys(Env)) + rule lookupMember(ListItem(envStackFrame(_, Env)) L, X) + => lookupMember(L, X) + requires notBool(X in keys(Env)) +
    +

    typeOf for the additional values}

    +
    k
    rule typeOf(objectClosure(C,_)) => C + rule typeOf(methodClosure(T:Type,_,_,_Ps:Params,_)) => T +
    +

    Subtype checking

    +

    The subclass relation induces a subtyping relation.

    +
    k
    syntax Exp ::= subtype(Types,Types) + + rule subtype(T:Type, T) => true + + rule <k> subtype(C1:Id, C:Id) => subtype(C2, C) ...</k> + <className> C1 </className> + <baseClass> C2:Id </baseClass> + requires C1 =/=K C + + rule subtype(Object,Class:Id) => false + requires Class =/=K Object + + rule subtype(Ts1->T2,Ts1'->T2') => subtype(((T2)::Type,Ts1'),((T2')::Type,Ts1)) + +// Note that the following rule would be wrong! +// rule subtype(T[],T'[]) => subtype(T,T') + + rule subtype((T:Type,Ts),(T':Type,Ts')) => subtype(T,T') && subtype(Ts,Ts') + requires Ts =/=K .Types + rule subtype(.Types,.Types) => true +
    +

    Unsafe Casting

    +

    Performs unsafe casting. One should only use it in combination with +the subtype relation above.

    +
    k
    syntax Val ::= unsafeCast(Val,Type) [function] + + rule unsafeCast(objectClosure(_,EStack), C:Id) + => objectClosure(C,EStack) + + rule unsafeCast(methodClosure(_T',C,OL,Ps,S), T) => methodClosure(T,C,OL,Ps,S) + + rule unsafeCast(V:Val, T:Type) => V requires typeOf(V) ==K T +
    +

    Generic guard

    +

    A generic computational guard: it allows the computation to continue +only if a prefix guard evaluates to true.

    +
    k
    syntax KItem ::= "true?" + rule true ~> true? => . + +endmodule +
    +

    Go to Lesson 3, KOOL typed static.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/2_languages/2_kool/2_typed/2_static/NOTES/index.html b/k-distribution/pl-tutorial/2_languages/2_kool/2_typed/2_static/NOTES/index.html new file mode 100644 index 00000000000..1e31652e9fc --- /dev/null +++ b/k-distribution/pl-tutorial/2_languages/2_kool/2_typed/2_static/NOTES/index.html @@ -0,0 +1,380 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Why is the following happening at line 347? It should infer the sort Stmts for S:

    +

    rule {S} => block ... Rho R +(.Bag => S Rho R )

    +

    [Error] Critical: Could not infer a sort for variable 'S' to match every location.

    +

    Similarly at line 517.

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/2_languages/2_kool/2_typed/2_static/kool-typed-static/index.html b/k-distribution/pl-tutorial/2_languages/2_kool/2_typed/2_static/kool-typed-static/index.html new file mode 100644 index 00000000000..b7153874fe1 --- /dev/null +++ b/k-distribution/pl-tutorial/2_languages/2_kool/2_typed/2_static/kool-typed-static/index.html @@ -0,0 +1,1424 @@ + + + + + + + + + + + + + + +KOOL — Typed — Static | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    KOOL — Typed — Static

    +

    Author: Grigore Roșu (grosu@illinois.edu)
    +Organization: University of Illinois at Urbana-Champaign

    +

    Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
    +Organization: University of Bucharest

    +

    Abstract

    +

    This is the K static semantics of the typed KOOL language. +It extends the static semantics of typed SIMPLE with static semantics +for the object-oriented constructs. Also, the static semantics of +some of the existing SIMPLE constructs need to change, in order to +become more generous with regards to the set of accepted programs, +mostly due to subtyping. For example, the assignment construct +x = e required that both the variable x and the +expression e had the same type in SIMPLE. In KOOL, the type +of e can be a subtype of the type of x. +Specifically, we define the following typing policy for KOOL, +everything else not mentioned below borrowing its semantics from +SIMPLE:

    +
      +
    • +

      Each class C yields a homonymous type, which can be +explicitly used in programs to type variables and methods, possibly in +combination with other types.

      +
    • +
    • +

      Since now we have user-defined types, we check that each type +used in a KOOL program is well-formed, that is, it is constructed only +from primitive and class types corresponding to declared classes.

      +
    • +
    • +

      Class members and their types form a class type +environment. Each class will have such a type environment. +Each member in a class is allowed to be declared only once. Since in +KOOL we allow methods to be assigned to fields, we make no distinction +between field and method members; in other words, we reject programs +declaring both a field and a method with the same name.

      +
    • +
    • +

      If an identifier is not found in the local type environment, it +will be searched for in the current class type environment. If not +there, then it will be searched for in its superclass' type +environment. And so on and so forth. If not found until the +Object class is reached, a typing error is reported.

      +
    • +
    • +

      The assignment allows variables to be assigned values of +more concrete types. The result type of the assignment expression +construct will be the (more abstract) type of the assigned variable, +and not the (more concrete) type of the expression, like in Java.

      +
    • +
    • +

      Exceptions are changed (from SIMPLE) to allow throwing and +catching only objects, like in Java. Also, unlike in SIMPLE, we do +not check whether the type of the thrown exception matches the type of +the caught variable, because exceptions can be caught by other +try/catch blocks, even by ones in other methods. To avoid +having to annotate each method with what exceptions it can throw, we +prefer to not check the type safety of exceptions (although this is an +excellent homework!). We only check that the try block +type-checks and that the catch block type-checks after we bind +the caught variable to its claimed type.

      +
    • +
    • +

      Class declarations are not allowed to have any cycles in their +extends relation. Such cycles would lead to non-termination of +new, as it actually does in the dynamic semantics of KOOL +where no such circularity checks are performed.

      +
    • +
    • +

      Methods overriding other methods should be in the right subtyping +relationship with the overridden methods: co-variant in the codomain +and contra-variant in the domain.

      +
    • +
    +
    k
    module KOOL-TYPED-STATIC-SYNTAX + imports DOMAINS-SYNTAX +
    +

    Syntax

    +

    The syntax of statically typed KOOL is identical to that of +dynamically typed KOOL, they both taking as input the same programs. +What differs is the K strictness attributes. Like in statically +typed SIMPLE, almost all language constructs are strict now, since we +want each to type its arguments almost all the time. Like in the +other two KOOL definitions, we prefer to copy and then modify/extend +the syntax of statically typed SIMPLE.

    +

    Note: This paragraph is old, now we can do things better. We keep +it here only for historical reasons, to see how much we used to suffer :)

    +

    Annoying K-tool technical problem: +Currently, the K tool treats the "non-terminal" productions (i.e., +productions consisting of just one non-terminal), also called +"subsorting" production, differently from the other productions. +Specifically, it does not insert a node in the AST for them. This may +look desirable at first, but it has a big problem: it does not allow +us to treat the subsort differently in different context. For +example, since we want Id to be both a type (a class name) and a +program variable, and since we want expressions to reduce to their +types, we are in an impossible situations in which we do not know how +to treat an identifier in the semantics: as a type, i.e., a result of +computations, or as a program variable, i.e., a non-result. Ideally, +we would like to tag the identifiers at parse-time with their local +interpretation, but that, unfortunately, is not possible with the +current parsing capabilities of the K tool, because it requires to +insert additional information in the AST for the subsort productions. +This will be fixed soon. Until then, unfortunately, we have to do the +job of the parser manually. Instead of subsorting Id directly +to Type, we "wrap" it first, say with a wrapper called +class(...), exactly how the parser should have done. +The major drawback of this is that all the typed KOOL programs +in kool/typed/programs need to also be modified to always +declare class types accordingly. The modified programs can be found +in kool/typed/static/programs. So make sure you execute the +static semantics of KOOL using the modified programs. To avoid seeing +the wrapper in the generated documentation, we associate it an +"invisibility" latex attribute below.

    +
    k
    syntax Id ::= "Object" [token] | "Main" [token] +
    +

    Types

    +
    k
    syntax Type ::= "void" | "int" | "bool" | "string" + | Id [klabel("class"), symbol, avoid] // see next + | Type "[" "]" + | "(" Type ")" [bracket] + > Types "->" Type + + syntax Types ::= List{Type,","} [klabel(exps)] +
    +

    Declarations

    +
    k
    syntax Param ::= Type Id + syntax Params ::= List{Param,","} + + syntax Stmt ::= Type Exps ";" [avoid] + | Type Id "(" Params ")" Block + | "class" Id Block + | "class" Id "extends" Id Block +
    +

    Expressions

    +
    k
    syntax FieldReference ::= Exp "." Id [strict(1)] + syntax ArrayReference ::= Exp "[" Exps "]" [strict] + + syntax Exp ::= Int | Bool | String | Id + | "this" + | "super" + | "(" Exp ")" [bracket] + | "++" Exp + | Exp "instanceOf" Id [strict(1)] + | "(" Id ")" Exp [strict(2)] + | "new" Id "(" Exps ")" [strict(2)] + > Exp "(" Exps ")" [strict] + | "-" Exp [strict] + | "sizeOf" "(" Exp ")" [strict] + | "read" "(" ")" + > left: + Exp "*" Exp [strict, left] + | Exp "/" Exp [strict, left] + | Exp "%" Exp [strict, left] + > left: + Exp "+" Exp [strict, left] + | Exp "-" Exp [strict, left] + > non-assoc: + Exp "<" Exp [strict, non-assoc] + | Exp "<=" Exp [strict, non-assoc] + | Exp ">" Exp [strict, non-assoc] + | Exp ">=" Exp [strict, non-assoc] + | Exp "==" Exp [strict, non-assoc] + | Exp "!=" Exp [strict, non-assoc] + > "!" Exp [strict] + > left: + Exp "&&" Exp [strict, left] + | Exp "||" Exp [strict, left] + > "spawn" Block // not strict: to check return and exceptions + > Exp "=" Exp [strict(2), right] + + syntax Exp ::= FieldReference | ArrayReference + syntax priority _.__KOOL-TYPED-STATIC-SYNTAX > _[_]_KOOL-TYPED-STATIC-SYNTAX > _(_)_KOOL-TYPED-STATIC-SYNTAX + + syntax Exps ::= List{Exp,","} [strict, klabel(exps)] +
    +

    Statements

    +
    k
    syntax Block ::= "{" "}" + | "{" Stmt "}" + + syntax Stmt ::= Block + | Exp ";" [strict] + | "if" "(" Exp ")" Block "else" Block [avoid, strict] + | "if" "(" Exp ")" Block [macro] + | "while" "(" Exp ")" Block [strict] + | "for" "(" Stmt Exp ";" Exp ")" Block [macro] + | "return" Exp ";" [strict] + | "return" ";" + | "print" "(" Exps ")" ";" [strict] + | "try" Block "catch" "(" Param ")" Block [strict(1)] + | "throw" Exp ";" [strict] + | "join" Exp ";" [strict] + | "acquire" Exp ";" [strict] + | "release" Exp ";" [strict] + | "rendezvous" Exp ";" [strict] + + syntax Stmt ::= Stmt Stmt [seqstrict, right] +
    +

    Desugaring macros

    +
    k
    rule if (E) S => if (E) S else {} + rule for(Start Cond; Step) {S:Stmt} => {Start while(Cond){S Step;}} + rule T:Type E1:Exp, E2:Exp, Es:Exps; => T E1; T E2, Es; [anywhere] + rule T:Type X:Id = E; => T X; X = E; [anywhere] + + rule class C:Id S => class C extends Object S + +endmodule +
    +

    Static semantics

    +

    We first discuss the configuration, then give the static semantics +taken over unchanged from SIMPLE, then discuss the static semantics of +SIMPLE syntactic constructs that needs to change, and in the end we +discuss the static semantics and additional checks specifically +related to the KOOL proper syntax.

    +
    k
    module KOOL-TYPED-STATIC + imports KOOL-TYPED-STATIC-SYNTAX + imports DOMAINS +
    +

    Configuration

    +

    The configuration of our type system consists of a tasks +cell with the same meaning like in statically typed SIMPLE, of an +out cell streamed to the standard output that will be used to +display typing error messages, and of a cell classes holding +data about each class in a separate class cell. The +task cells now have two additional optional subcells, namely +ctenvT and inClass. The former holds a temporary +class type environment; its contents will be transferred into the +ctenv cell of the corresponding class as soon as all the +fields and methods in the task are processed. In fact, there will be +three types of tasks in the subsequent semantics, each determined by +the subset of cells that it holds:

    +
      +
    1. +

      Main task, holding only a k cell holding the +original program as a set of classes. The role of this task is to +process each class, generating a class task (see next) for each.

      +
    2. +
    3. +

      Class task, holding k, ctenvT, and +inClass subcells. The role of this task type is to process +a class' contents, generating a class type environment in the +ctenvT cell and a method task (see next) for each method in +the class. To avoid interference with object member lookup rules +below, it is important to add the class type environment to a class +atomically; this is the reason for which we use ctenvT +temporary cells within class tasks (instead of adding each member +incrementally to the class' type environment).

      +
    4. +
    5. +

      Method task, holding k, tenv and +return cells. These tasks are similar to SIMPLE's function +tasks, so we do not discuss them here any further.

      +
    6. +
    +

    Each class cell hods its name (in the className +cell) and the name of the class it extends (in the extends +cell), as well as its type environment (in the ctenv cell) +and the set of all its superclasses (in the extendsAll cell). +The later is useful for example for checking whether there are cycles +in the class extends relation.

    +
    k
    configuration <T multiplicity="?" color="yellow"> + <tasks color="orange" multiplicity="?"> + <task multiplicity="*" color="yellow" type="Set"> + <k color="green"> $PGM:Stmt </k> + <tenv multiplicity="?" color="cyan"> .Map </tenv> + <ctenvT multiplicity="?" color="blue"> .Map </ctenvT> + <returnType multiplicity="?" color="black"> void </returnType> + <inClass multiplicity="?" color="Fuchsia"> .K </inClass> + </task> + </tasks> +// <br/> + <classes color="Fuchsia"> + <classData multiplicity="*" type="Map"> + <className color="Fuchsia"> Object </className> + <baseClass color="Fuchsia"> .K </baseClass> + <baseClasses color="Fuchsia"> .Set </baseClasses> + <ctenv multiplicity="?" color="blue"> .Map </ctenv> + </classData> + </classes> + </T> + <output color="brown" stream="stdout"> .List </output> +
    +

    Unchanged semantics from statically typed SIMPLE

    +

    The syntax and rules below are borrowed unchanged from statically +typed SIMPLE, so we do not discuss them much here.

    +
    k
    syntax Exp ::= Type + syntax Exps ::= Types + syntax BlockOrStmtType ::= "block" | "stmt" + syntax Type ::= BlockOrStmtType + syntax Block ::= BlockOrStmtType + syntax KResult ::= Type + | Types // TODO: should not be needed + + + context _:Type _::Exp[HOLE::Exps]; + + rule T:Type E:Exp[int,Ts:Types]; => T[] E[Ts]; + rule T:Type E:Exp[.Types]; => T E; + + + rule <task>... <k> _:BlockOrStmtType </k> <tenv> _ </tenv> ...</task> => .Bag + + + rule _:Int => int + rule _:Bool => bool + rule _:String => string + + + rule <k> X:Id => T ...</k> <tenv>... X |-> T ...</tenv> + + + context ++(HOLE => ltype(HOLE)) + rule ++ int => int + rule int + int => int + rule string + string => string + rule int - int => int + rule int * int => int + rule int / int => int + rule int % int => int + rule - int => int + rule int < int => bool + rule int <= int => bool + rule int > int => bool + rule int >= int => bool + rule T:Type == T => bool + rule T:Type != T => bool + rule bool && bool => bool + rule bool || bool => bool + rule ! bool => bool + + + rule (T[])[int, Ts:Types] => T[Ts] + rule T:Type[.Types] => T + + rule sizeOf(_T[]) => int + + + rule read() => int + + rule print(T:Type, Ts => Ts); when T ==K int orBool T ==K string + rule print(.Types); => stmt + + + context (HOLE => ltype(HOLE)) = _ + + + rule <k> return; => stmt ...</k> <returnType> _ </returnType> + + + rule {} => block + + rule <task> <k> {S:Stmt} => block ...</k> <tenv> Rho </tenv> R </task> + (.Bag => <task> <k> S </k> <tenv> Rho </tenv> R </task>) + + rule _:Type; => stmt + rule if (bool) block else block => stmt + rule while (bool) block => stmt + + rule join int; => stmt + rule acquire _:Type; => stmt + rule release _:Type; => stmt + rule rendezvous _:Type; => stmt + + syntax Stmt ::= BlockOrStmtType + rule _:BlockOrStmtType _:BlockOrStmtType => stmt +
    +

    Unchanged auxiliary operations from dynamically typed SIMPLE

    +
    k
    syntax Stmt ::= mkDecls(Params) [function] + rule mkDecls(T:Type X:Id, Ps:Params) => T X; mkDecls(Ps) + rule mkDecls(.Params) => {} + + syntax LValue ::= Id + | FieldReference + | ArrayReference + syntax Exp ::= LValue + + syntax Exp ::= ltype(Exp) +// We would like to say: +// context ltype(HOLE:LValue) +// but we currently cannot type the HOLE + context ltype(HOLE) when isLValue(HOLE) + +// OLD approach: +// syntax Exp ::= ltype(Exp) [function] +// rule ltype(X:Id) => X +// rule ltype(E:Exp [Es:Exps]) => E[Es] + + syntax Types ::= getTypes(Params) [function] + rule getTypes(T:Type _:Id) => T, .Types + rule getTypes(T:Type _:Id, P, Ps) => T, getTypes(P,Ps) + rule getTypes(.Params) => void, .Types +
    +

    Changes to the existing statically typed SIMPLE semantics

    +

    Below we give the new static semantics for language constructs that +come from SIMPLE, but whose SIMPLE static semantics was too +restrictive or too permissive and thus had to change.

    +

    Local variable declaration

    +

    Since we can define new types in KOOL (corresponding to classes), the +variable declaration needs to now check that the claimed types exist. +The operation checkType, defined at the end of this module, +checks whether the argument type is correct (it actually works with +lists of types as well).

    +
    k
    rule <k> T:Type X:Id; => checkType(T) ~> stmt ...</k> + <tenv> Rho => Rho[X <- T] </tenv> +
    +

    Class member declaration

    +

    In class tasks, variable declarations mean class member declarations. +Since we reduce method declarations to variable declarations (see +below), a variable declaration in a class task can mean either a field +or a method declaration. Unlike local variable declarations, which +can shadow previous homonymous local or member declarations, member +declarations are regarded as a set, so we disallow multiple +declarations for the same member (one could improve upon this, like in +Java, by treating members with different types or number of arguments +as different, etc., but we do not do it here). We also issue an error +message if one attempts to redeclare the same class member. The +framed variable declaration in the second rule below should be read +"stuck". In fact, it is nothing but a unary operation called +stuck, which takes a K-term as argument and does nothing +with it; this stuck operation is displayed as a frame in this +PDF document because of its latex attribute (see the ASCII .k file, +at the end of this module).

    +
    k
    rule <k> T:Type X:Id; => checkType(T) ~> stmt ...</k> + <ctenvT> Rho (.Map => X |-> T) </ctenvT> + when notBool(X in keys(Rho)) + + rule <k> T:Type X:Id; => stuck(T X;) ...</k> + <ctenvT>... X |-> _ ...</ctenvT> + <inClass> C:Id </inClass> +// <br/> + <output>... .List => ListItem("Member \"" +String Id2String(X) + +String "\" declared twice in class \"" + +String Id2String(C) +String "\"!\n") </output> +
    +

    Method declaration

    +

    A method declaration requires two conceptual checks to be performed: +first, that the method's type is consistent with the type of the +homonymous method that it overrides, if any; and second, that its body +types correctly. At the same time, it should also be added to the +type environment of its class. The first conceptual task is performed +using the checkMethod operation defined below, and the second +by generating a corresponding method task. To add it to the class +type environment, we take advantage of the fact that KOOL is higher +order and reduce the problem to a field declaration problem, which we +have already defined. The role of the ctenvT cell in the +rule below is to structurally ensure that the method declaration takes +place in a class task (we do not want to allow methods to be declared, +for example, inside other methods).

    +
    k
    rule <k> T:Type F:Id(Ps:Params) S + => checkMethod(F, getTypes(Ps)->T, C') + ~> getTypes(Ps)->T F; ...</k> +// <br/> + <inClass> C </inClass> + <ctenvT> _ </ctenvT> // to ensure we are in a class pass + <className> C </className> + <baseClass> C' </baseClass> +// <br/> + (.Bag => <task> + <k> mkDecls(Ps) S </k> + <inClass> C </inClass> + <tenv> .Map </tenv> + <returnType> T </returnType> + </task>) +
    +

    Assignment

    +

    A more concrete value is allowed to be assigned to a more abstract +variable. The operation checkSubtype is defined at the end +of the module and it also works with pairs of lists of types.

    +
    k
    rule T:Type = T':Type => checkSubtype(T', T) ~> T +
    +

    Method invocation and return

    +

    Methods can be applied on values of more concrete types than their +arguments:

    +
    k
    rule (Ts:Types -> T:Type) (Ts':Types) => checkSubtype(Ts',Ts) ~> T +
    +

    Similarly, we allow values of more concrete types to be returned by +methods:

    +
    k
    rule <k> return T:Type; => checkSubtype(T,T') ~> stmt ...</k> + <returnType> T':Type </returnType> +
    +

    Exceptions

    +

    Exceptions can throw and catch values of any types. Since unlike in Java +KOOL's methods do not declare the exception types that they can throw, +we cannot test the full type safety of exceptions. Instead, we +only check that the try and the catch statements +type correctly.

    +
    k
    rule try block catch(T:Type X:Id) S => {T X; S} + rule throw _T:Type ; => stmt +
    +

    Spawn

    +

    The spawned cell needs to also be passed the parent's class.

    +
    k
    // explain why + + rule <k> spawn S:Block => int ...</k> + <tenv> Rho </tenv> + <inClass> C </inClass> + (.Bag => <task> + <k> S </k> + <tenv> Rho </tenv> + <inClass> C </inClass> + </task>) +
    +

    Semantics of the new KOOL constructs

    +

    Class declaration

    +

    We process each class in the main task, adding the corresponding data +into its class cell and also adding a class task for it. We +also perform some well-formedness checks on the class hierarchy.

    +

    Initiate class processing
    +We create a class cell and a class task for each task. Also, we start +the class task with a check that the class it extends is declared +(this delays the task until that class is processed using another +instance of this rule).

    +
    k
    // There seems to be some error with the configuration concretization, +// as the rule below does not work when rewriting . to both the task +// and the class cells; I had to include two separate . rewrites + +// TODO: the following fails krun; see #2117 + rule <task> <k> class C:Id extends C':Id { S:Stmt } => stmt ...</k> </task> + (.Bag => <classData>... + <className> C </className> + <baseClass> C' </baseClass> + ...</classData>) +// <br/> + (.Bag => <task> + <k> checkType(`class`(C')) ~> S </k> + <inClass> C </inClass> + <ctenvT> .Map </ctenvT> + </task>) + +// You may want to try the thing below, but that failed, too +/* +syntax Type ::= "stmtStop" + + rule <tasks>... + <task> <k> class C:Id extends C':Id { S:Stmt } => stmtStop ...</k> </task> + (.Bag => <task> + <k> checkType(`class`(C')) ~> S </k> + <inClass> C </inClass> + <ctenvT> .Map </ctenvT> + </task>) + ...</tasks> + <classes>... + .Bag => <classData>... + <className> C </className> + <baseClass> C' </baseClass> + ...</classData> + ...</classes> +// <br/> +*/ +
    +

    Check for unique class names

    +
    k
    rule (<T>... + <className> C </className> + <className> C </className> + ...</T> => .Bag) + <output>... .List => ListItem("Class \"" +String Id2String(C) + +String "\" declared twice!\n") </output> +
    +

    Check for cycles in class hierarchy
    +We check for cycles in the class hierarchy by transitively closing the +class extends relation using the extendsAll cells, and +checking that a class will never appear in its own extendsAll +cell. The first rule below initiates the transitive closure of the +superclass relation, the second transitively closes it, and the third +checks for cycles.

    +
    k
    rule <baseClass> C </baseClass> + <baseClasses> .Set => SetItem(C) </baseClasses> [priority(25)] + + rule <classData>... + <baseClasses> SetItem(C) Cs:Set (.Set => SetItem(C')) </baseClasses> + ...</classData> + <classData>... <className>C</className> <baseClass>C'</baseClass> ...</classData> + when notBool(C' in (SetItem(C) Cs)) [priority(25)] + + rule (<T>... + <className> C </className> + <baseClasses>... SetItem(C) ...</baseClasses> + ...</T> => .Bag) + <output>... .List => ListItem("Class \"" +String Id2String(C) + +String "\" is in a cycle!\n") </output> + [group(inheritance-cycle), priority(25)] +
    +

    New

    +

    To type new we only need to check that the class constructor +can be called with arguments of the given types, so we initiate a call +to the constructor method in the corresponding class. If that +succeeds, meaning that it types to stmt, then we discard the +stmt type and produce instead the corresponding class type of +the new object. The auxiliary discard operation is defined +also at the end of this module.

    +
    k
    rule new C:Id(Ts:Types) => `class`(C) . C (Ts) ~> discard ~> `class`(C) +
    +

    Self reference

    +

    The typing rule for this is straightforward: reduce to the +current class type.

    +
    k
    rule <k> this => `class`(C) ...</k> + <inClass> C:Id </inClass> +
    +

    Super

    +

    Similarly, super types to the parent class type. +Note that for typing concerns, super can be considered as an object +(recall that this was not the case in the dynamic semantics).

    +
    k
    rule <k> super => `class`(C') ...</k> + <inClass> C:Id </inClass> + <className> C </className> + <baseClass> C':Id </baseClass> +
    +

    Object member access

    +

    There are several cases to consider here. First, if we are in a class +task, we should lookup the member into the temporary class type +environemnt in cell ctenvT. That is because we want to allow +initialized field declarations in classes, such as int x=10;. +This is desugared to a declaration of x, which is added to +ctenvT during the class task processing, followed by an +assignment of x to 10. In order for the assignment to type +check, we need to know that x has been declared with type +int; this information can only be found in the +ctenvT cell. Second, we should redirect non-local variable +lookups in method tasks to corresponding member accesses (the +local variables are handled by the rule borrowed from SIMPLE). +This is what the second rule below does. Third, we should allow +object member accesses as lvalues, which is done by the third rule +below. These last two rules therefore ensure that each necessary +object member access is explicitly allowed for evaluation. Recall +from the annotated syntax module above that the member access +operation is strict in the object. That means that the object is +expected to evaluate to a class type. The next two rules below define +the actual member lookup operation, moving the search to the +superclass when the member is not found in the current class. Note +that this works because we create the class type environments +atomically; thus, a class either has its complete type environment +available, in which case these rules can safely apply, or its cell +ctenv is not yet available, in which case these rules have to +wait. Finally, the sixth rule below reports an error when the +Object class is reached.

    +
    k
    rule <k> X:Id => T ...</k> + <ctenvT>... X |-> T ...</ctenvT> + + rule <k> X:Id => this . X ...</k> + <tenv> Rho </tenv> + when notBool(X in keys(Rho)) + +// OLD approach: +// rule ltype(E:Exp . X:Id) => E . X + + rule <k> `class`(C:Id) . X:Id => T ...</k> + <className> C </className> + <ctenv>... X |-> T:Type ...</ctenv> + + rule <k> `class`(C1:Id => C2) . X:Id ...</k> + <className> C1 </className> + <baseClass> C2:Id </baseClass> + <ctenv> Rho </ctenv> + when notBool(X in keys(Rho)) + + rule <k> `class`(Object) . X:Id => stuck(`class`(Object) . X) ...</k> + <inClass> C:Id </inClass> +// <br/> + <output>... .List => ListItem("Member \"" +String Id2String(X) + +String "\" not declared! (see class \"" + +String Id2String(C) +String "\")\n") </output> +
    +

    Instance of and casting

    +

    As it is hard to check statically whether casting is always safe, +the programmer is simply trusted from a typing perspective. We only +do some basic upcasting and downcasting checks, to reject casts which +will absolutely fail. However, dynamic semantics or implementations +of the language need to insert runtime checks for downcasting to be safe.

    +
    k
    rule `class`(_C1:Id) instanceOf _C2:Id => bool + rule (C:Id) `class`(C) => `class`(C) + rule <k> (C2:Id) `class`(C1:Id) => `class`(C2) ...</k> + <className> C1 </className> + <baseClasses>...SetItem(C2)...</baseClasses> // upcast + rule <k> (C2:Id) `class`(C1:Id) => `class`(C2) ...</k> + <className> C2 </className> + <baseClasses>...SetItem(C1)...</baseClasses> // downcast + rule <k> (C2) `class`(C1:Id) => stuck((C2) `class`(C1)) ...</k> + <classData>... + <className> C1 </className> + <baseClasses> S1 </baseClasses> + ...</classData> + <classData>... + <className> C2 </className> + <baseClasses> S2 </baseClasses> + ...</classData> + <output>... .List => ListItem("Classes \"" +String Id2String(C1) + +String "\" and \"" +String Id2String(C2) + +String "\" are incompatible!\n") </output> + when notBool(C1 in S2) andBool notBool(C2 in S1) +
    +

    Cleanup tasks

    +

    Finally, we need to clean up the terminated tasks. Each of the three +types of tasks is handled differently. The main task is replaced by a +method task holding new main();, which will ensure that a +main class with a main() method actually exists +(first rule below). A class task moves its temporary class type +environment into its class' cell, and then it dissolves itself (second +rule). A method task simply dissolves when terminated (third rule); +the presence of the tenv cell in that rule ensures that that +task is a method task. +Finally, when all the tasks are cleaned up, we can also remove the +tasks cell, issuing a corresponding message. Note that +checking for cycles or duplicate methods can still be performed after +the tasks cell has been removed.

    +
    k
    // discard main task when done, issuing a "new main();" command to +// make sure that the class main and the method main() are declared. + + rule <task> <k> stmt => new Main(.Exps); </k> + (.Bag => <tenv> .Map </tenv> + <returnType> void </returnType> + <inClass> Main </inClass>) + </task> + +// discard class task when done, adding a ctenv in class + + rule (<task> + <k> stmt </k> + <ctenvT> Rho </ctenvT> + <inClass> C:Id </inClass> + </task> => .Bag) + <className> C </className> + (.Bag => <ctenv> Rho </ctenv>) + +// discard method task when done + + rule <task>... + <k> stmt </k> + <tenv> _ </tenv> // only to ensure that this is a method task + ...</task> => .Bag + +// cleanup tasks and output a success message when done + + rule (<T>... <tasks> .Bag </tasks> ...</T> => .Bag) + <output>... .List => ListItem("Type checked!\n") </output> +
    +

    KOOL-specific auxiliary declarations and operations

    +

    Subtype checking

    +

    The subclass relation introduces a subtyping relation.

    +
    k
    syntax KItem ::= checkSubtype(Types,Types) + + rule checkSubtype(T:Type, T) => . + + rule <k> checkSubtype(`class`(C:Id), `class`(C':Id)) => . ...</k> + <className> C </className> + <baseClasses>... SetItem(C') ...</baseClasses> + + rule checkSubtype(Ts1->T2,Ts1'->T2') + => checkSubtype(((T2)::Type,Ts1'),((T2')::Type,Ts1)) + +// note that the following rule would be wrong! +// rule checkSubtype(T[],T'[]) => checkSubtype(T,T') + + rule checkSubtype((T:Type,Ts),(T':Type,Ts')) + => checkSubtype(T,T') ~> checkSubtype(Ts,Ts') + when Ts =/=K .Types + + rule checkSubtype(.Types,.Types) => . + rule checkSubtype(.Types,void) => . +
    +

    Checking well-formedness of types

    +

    Since now any Id can be used as the type of a class, we need to +check that the types used in the program actually exists

    +
    k
    syntax KItem ::= checkType(Types) + + rule checkType(T:Type,Ts:Types) => checkType(T) ~> checkType(Ts) + when Ts =/=K .Types + rule checkType(.Types) => . + rule checkType(int) => . + rule checkType(bool) => . + rule checkType(string) => . + rule checkType(void) => . + rule <k> checkType(`class`(C:Id)) => . ...</k> <className> C </className> + rule checkType(`class`(Object)) => . + rule checkType(Ts:Types -> T:Type) => checkType(T,Ts) + rule checkType(T:Type[]) => checkType(T) +
    +

    Checking correct overiding of methods

    +

    The checkMethod operation below searches to see whether +the current method overrides some other method in some superclass. +If yes, then it issues an additional check that the new method's type +is more concrete than the overridden method's. The types T and T' +below can only be function types. See the definition of +checkSubtype on function types at the end of this module (it +is co-variant in the codomain and contra-variant in the domain).

    +
    k
    syntax KItem ::= checkMethod(Id,Type,Id) + + rule <k> checkMethod(F:Id, T:Type, C:Id) => checkSubtype(T, T') ...</k> + <className> C </className> + <ctenv>... F |-> T':Type ...</ctenv> + + rule <k> checkMethod(F:Id, _T:Type, (C:Id => C')) ...</k> + <className> C </className> + <baseClass> C':Id </baseClass> + <ctenv> Rho </ctenv> + when notBool(F in keys(Rho)) + + rule checkMethod(_:Id,_,Object) => . +
    +

    Generic operations which could be part of the K framework

    +
    k
    syntax KItem ::= stuck(K) [latex(\framebox{${#1}$})] + + syntax KItem ::= "discard" + rule _:KResult ~> discard => . + +endmodule +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/2_languages/3_fun/1_untyped/1_environment/fun-untyped/index.html b/k-distribution/pl-tutorial/2_languages/3_fun/1_untyped/1_environment/fun-untyped/index.html new file mode 100644 index 00000000000..c7cec2fd2d5 --- /dev/null +++ b/k-distribution/pl-tutorial/2_languages/3_fun/1_untyped/1_environment/fun-untyped/index.html @@ -0,0 +1,1225 @@ + + + + + + + + + + + + + + +FUN — Untyped — Environment | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    FUN — Untyped — Environment

    +

    Author: Grigore Roșu (grosu@illinois.edu)
    +Organization: University of Illinois at Urbana-Champaign

    +

    Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
    +Organization: University of Bucharest

    +

    Abstract

    +

    This is the K semantic definition of the untyped FUN language. +FUN is a pedagogical and research language that captures the essence +of the functional programming paradigm, extended with several features +often encountered in functional programming languages. +Like many functional languages, FUN is an expression language, that +is, everything, including the main program, is an expression. +Functions can be declared anywhere and are first class values in the +language. +FUN is call-by-value here, but it has been extended (as student +homework assignments) with other parameter-passing styles. +To make it more interesting and to highlight some of K's strengths, +FUN includes the following features:

    +
      +
    • +

      The basic builtin data-types of integers, booleans and strings.

      +
    • +
    • +

      Builtin lists, which can hold any elements, including other lists. +Lists are enclosed in square brackets and their elements are +comma-separated; e.g., [1,2,3].

      +
    • +
    • +

      User-defined data-types, by means of constructor terms. +Constructor names start with a capital letter (while any other +identifier in the language starts with a lowercase letter), and they +can be followed by an arbitrary number of comma-separated arguments +enclosed in parentheses; parentheses are not needed when the +constructor takes no arguments. +For example, Pair(5,7) is a constructor term holding two +numbers, Cons(1,Cons(2,Cons(3,Nil))) is a list-like +constructor term holding 3 elements, and +Tree(Tree(Leaf(1), Leaf(2)), Leaf(3)) is a tree-like +constructor term holding 3 elements. +In the untyped version of the FUN language, no type checking or +inference is performed to ensure that the data constructors are used +correctly. +The execution will simply get stuck when they are misused. +Moreover, since no type checking is performed, the data-types are not +even declared in the untyped version of FUN.

      +
    • +
    • +

      Functions and let/letrec binders can take +multiple space-separated arguments, but these are desugared to +ones that only take one argument, by currying. For example, the +expressions

      +
      fun x y -> x y
      +let x y = y in x
      +
      +

      are desugared, respectively, into the following expressions:

      +
      fun x -> fun y -> x y
      +let x = fun y -> y in x
      +
      +
    • +
    • +

      Functions can be defined using pattern matching over the +available data-types. For example, the program

      +
      letrec max = fun [h] -> h
      +             |   [h|t] -> let x = max t
      +                          in  if h > x then h else x
      +in max [1, 3, 5, 2, 4, 0, -1, -5]
      +
      +

      defines a function max that calculates the maximum element of +a non-empty list, and the function

      +
      letrec ack = fun Pair(0,n) -> n + 1
      +             |   Pair(m,0) -> ack Pair(m - 1, 1)
      +             |   Pair(m,n) -> ack Pair(m - 1, ack Pair(m, n - 1))
      +in ack Pair(2,3)
      +
      +

      calculates the Ackermann function applied to a particular pair of numbers. +Patterns can be nested. Patterns can currently only be used in function +definitions, and not directly in let/letrec binders. +For example, this is not allowed:

      +
      letrec Pai(x,y) = Pair(1,2) in x+y
      +
      +

      But this is allowed:

      +
      let f Pair(x,y) = x+y in f Pair(1,2)
      +
      +

      because it is first reduced to

      +
      let f = fun Pair(x,y) -> x+y in f Pair(1,2)
      +
      +

      by uncurrying of the let binder, and pattern matching is +allowed in function arguments.

      +
    • +
    • +

      We include a callcc construct, for two reasons: first, +several functional languages support this construct; second, some +semantic frameworks have difficulties defining it. Not K.

      +
    • +
    • +

      Finally, we include mutables by means of referencing an +expression, getting the reference of a variable, dereferencing and +assignment. We include these for the same reasons as above: there are +languages which have them, and they are not easy to define in some +semantic frameworks.

      +
    • +
    +

    Like in many other languages, some of FUN's constructs can be +desugared into a smaller set of basic constructs. We do that as usual, +using macros, and then we only give semantics to the core constructs.

    +

    Note:
    +We recommend the reader to first consult the dynamic semantics of the +LAMBDA++ language in the first part of the K Tutorial. +To keep the comments below small and focused, we will not re-explain +functional or K features that have already been explained in there.

    +

    Syntax

    +
    k
    //require "modules/pattern-matching.k" + +module FUN-UNTYPED-COMMON + imports DOMAINS-SYNTAX +
    +

    FUN is an expression language. The constructs below fall into +several categories: names, arithmetic constructs, conventional +functional constructs, patterns and pattern matching, data constructs, +lists, references, and call-with-current-continuation (callcc). +The arithmetic constructs are standard; they are present in almost all +our K language definitions. The meaning of FUN's constructs are +discussed in more depth when we define their semantics in the next +module.

    +

    The Syntactic Constructs

    +

    We start with the syntactic definition of FUN names. +We have several categories of names: ones to be used for functions and +variables, others to be used for data constructors, others for types and +others for type variables. We will introduce them as needed, starting +with the former category. We prefer the names of variables and functions +to start with lower case letters. We take the freedom to tacitly introduce +syntactic lists/sequences for each nonterminal for which we need them:

    +
    k
    syntax Name [token] + syntax Names ::= List{Name,","} [klabel(exps)] +
    +

    Expression constructs will be defined throughtout the syntax module. +Below are the very basic ones, namely the builtins, the names, and the +parentheses used as brackets for grouping. Lists of expressions are +declared strict, so all expressions in the list get evaluated whenever +the list is on a position which can be evaluated:

    +
    k
    syntax Exp ::= Int | Bool | String | Name + | "(" Exp ")" [bracket] + syntax Exps ::= List{Exp,","} [strict, klabel(exps)] + syntax Val + syntax Exp ::= Val + syntax Exps ::= Vals + syntax Vals ::= List{Val,","} [klabel(exps)] + syntax Bottom + syntax Bottoms ::= List{Bottom,","} [klabel(exps)] +
    +

    We next define the syntax of arithmetic constructs, together with +their relative priorities and left-/non-associativities. We also +tag all these rules as members of a new group, "arith", so we can more easily +define global syntax priorities later (at the end of the syntax module).

    +
    k
    syntax Exp ::= left: + Exp "*" Exp [strict, group(arith)] + | Exp "/" Exp [strict, group(arith)] + | Exp "%" Exp [strict, group(arith)] + > left: + Exp "+" Exp [strict, left, group(arith)] + | Exp "^" Exp [strict, left, group(arith)] +// left attribute should not be necessary; currently a parsing bug + | Exp "-" Exp [strict, prefer, group(arith)] +// the "prefer" attribute above is to not parse x-1 as x(-1) +// Due to some parsing problems, we currently cannot add unary minus: + | "-" Exp [strict, group(arith)] + > non-assoc: + Exp "<" Exp [strict, group(arith)] + | Exp "<=" Exp [strict, group(arith)] + | Exp ">" Exp [strict, group(arith)] + | Exp ">=" Exp [strict, group(arith)] + | Exp "==" Exp [strict, group(arith)] + | Exp "!=" Exp [strict, group(arith)] + > "!" Exp [strict, group(arith)] + > Exp "&&" Exp [strict(1), left, group(arith)] + > Exp "||" Exp [strict(1), left, group(arith)] +
    +

    The conditional construct has the expected evaluation strategy, +stating that only the first argument is evaluate:

    +
    k
    syntax Exp ::= "if" Exp "then" Exp "else" Exp [strict(1)] +
    +

    FUN's builtin lists are formed by enclosing comma-separated +sequences of expressions (i.e., terms of sort Exps) in square +brackets. The list constructor cons adds a new element to the +top of the list, head and tail get the first element +and the tail sublist of a list if they exist, respectively, and get +stuck otherwise, and null?? tests whether a list is empty or +not; syntactically, these are just expression constants. +In function patterns, we are also going to allow patterns following the +usual head/tail notation; for example, the pattern [x_1,...,x_n|t] +binds x_1, ..., x_n to the first elements of the matched list, +and t to the list formed with the remaining elements. We define list +patterns as ordinary expression constructs, although we will make sure that +we do not give them semantics if they appear in any other place then in a +function case pattern.

    +
    k
    syntax Exp ::= "[" Exps "]" [strict, klabel(list)] + | "head" [macro] | "tail" [macro] | "null?" [macro] + | "[" Exps "|" Exp "]" + syntax Val ::= "[" Vals "]" [klabel(list)] + syntax Cons ::= "cons" + syntax Val ::= Cons + syntax Val ::= Cons Val [klabel(apply)] +
    +

    Data constructors start with capital letters and they may or may +not have arguments. We need to use the attribute "prefer" to make +sure that, e.g., Cons(a) parses as constructor Cons with +argument a, and not as the expression Cons (because +constructor names are also expressions) regarded as a function applied +to the expression a. Also, note that the constructor is strict +in its second argument, because we want to evaluate its arguments but +not the constuctor name itsef.

    +
    k
    syntax ConstructorName [token] + syntax Exp ::= ConstructorName + | ConstructorName "(" Exps ")" [prefer, strict(2), klabel(constructor)] + syntax Val ::= ConstructorName "(" Vals ")" [klabel(constructor)] +
    +

    A function is essentially a |-separated ordered +sequence of cases, each case of the form pattern -> expression, +preceded by the language construct fun. Patterns will be defined +shortly, both for the builtin lists and for user-defined constructors. +Recall that the syntax we define in K is not meant to serve as a +ultimate parser for the defined language, but rather as a convenient +notation for K abstract syntax trees, which we prefer when we write +the semantic rules. It is therefore often the case that we define a +more ``generous'' syntax than we want to allow programs to use. +We do it here, too. Specifically, the syntax of Cases +below allows any expressions to appear as pattern. This syntactic +relaxation permits many wrong programs to be parsed, but that is not a +problem because we are not going to give semantics to wrong combinations, +so those programs will get stuck; moreover, our type inferencer will reject +those programs anyway. Function application is just concatenation of +expressions, without worrying about type correctness. Again, the type +system will reject type-incorrect programs.

    +
    k
    syntax Exp ::= "fun" Cases + | Exp Exp [strict, left, klabel(apply)] +// NOTE: We would like eventually to also have Exp "(" Exps ") + syntax Case ::= Exp "->" Exp + syntax Cases ::= List{Case, "|"} +
    +

    The let and letrec binders have the usual syntax +and functional meaning. We allow multiple and-separated bindings. +Like for the function cases above, we allow a more generous syntax for +the left-hand sides of bindings, noting that the semantics will get stuck +on incorrect bindings and that the type system will reject those programs.

    +
    k
    syntax Exp ::= "let" Bindings "in" Exp + | "letrec" Bindings "in" Exp [prefer] +// The "prefer" attribute for letrec currently needed due to tool bug, +// to make sure that "letrec" is not parsed as "let rec". + syntax Binding ::= Exp "=" Exp + syntax Bindings ::= List{Binding,"and"} +
    +

    References are first class values in FUN. The construct ref +takes an expression, evaluates it, and then it stores the resulting value +at a fresh location in the store and returns that reference. Syntactically, +ref is just an expression constant. The construct & +takes a name as argument and evaluates to a reference, namely the store +reference where the variable passed as argument stores its value; this +construct is a bit controversial and is further discussed in the +environment-based semantics of the FUN language, where we desugar +ref to it. The construct @ takes a reference +and evaluates to the value stored there. The construct := takes +two expressions, the first expected to evaluate to a reference; the value +of its second argument will be stored at the location to which the first +points (the old value is thus lost). Finally, since expression evaluation +now has side effects, it makes sense to also add a sequential composition +construct, which is sequentially strict. This evaluates to the value of +its second argument; the value of the first argument is lost (which has +therefore been evaluated only for its side effects.

    +
    k
    syntax Exp ::= "ref" [macro] + | "&" Name + | "@" Exp [strict] + | Exp ":=" Exp [strict] + | Exp ";" Exp [strict(1), right] +
    +

    Call-with-current-continuation, named callcc in FUN, is a +powerful control operator that originated in the Scheme programming +language, but it now exists in many other functional languages. It works +by evaluating its argument, expected to evaluate to a function, and by +passing the current continuation, or evaluation context (or computation, +in K terminology), as a special value to it. When/If this special value +is invoked, the current context is discarded and replaced with the one +held by the special value and the computation continues from there. +It is like taking a snapshot of the execution context at some moment +in time and then, when desired, being able to get back in time to that +point. If you like games, it is like saving the game now (so you can +work on your homework!) and then continuing the game tomorrow or whenever +you wish. To issustrate the strength of callcc, we also +allow exceptions in FUN by means of a conventional try-catch +construct, which will desugar to callcc. We also need to +introduce the special expression contant throw, but we need to +use it as a function argument name in the desugaring macro, so we define +it as a name instead of as an expression constant:

    +
    k
    syntax Exp ::= "try" Exp "catch" "(" Name ")" Exp [macro] + syntax Val ::= "callcc" + syntax Name ::= "throw" [token] +
    +

    Finally, FUN also allows polymorphic datatype declarations. These +will be useful when we define the type system later on.

    +
    k
    syntax Exp ::= "datatype" Type "=" TypeCases Exp [macro] +// NOTE: In a future version of K, we want the datatype declaration +// to be a construct by itself, but that is not possible currently +// because K's parser wronly identifies the __ operation allowing +// a declaration to appear in front of an expression with the function +// application construct, giving ambiguous parsing errors. +
    +

    We next need to define the syntax of types and type cases that appear +in datatype declarations.

    +

    Like in many functional languages, type parameters/variables in +user-defined types are quoted identifiers.

    +
    k
    syntax TypeVar [token] + syntax TypeVars ::= List{TypeVar,","} [klabel(types)] +
    +

    Types can be basic types, function types, or user-defined +parametric types. In the dynamic semantics we are going to simply ignore +all the type declations, so here the syntax of types below is only useful +for generating the desired parser. To avoid syntactic ambiguities with +the arrow construct for function cases, we use the symbol --> as +a constructor for function types:

    +
    k
    syntax TypeName [token] + syntax Type ::= "int" | "bool" | "string" + | Type "-->" Type [right] + | "(" Type ")" [bracket] + | TypeVar + | TypeName [klabel(TypeName), avoid] + | Type TypeName [klabel(Type-TypeName), symbol, macro] + | "(" Types ")" TypeName [prefer] + syntax Types ::= List{Type,","} [klabel(types)] + syntax Types ::= TypeVars + + syntax TypeCase ::= ConstructorName + | ConstructorName "(" Types ")" + syntax TypeCases ::= List{TypeCase,"|"} [klabel(_|TypeCase_)] +
    +

    Additional Priorities

    +
    k
    syntax priorities @__FUN-UNTYPED-COMMON + > apply + > arith + > _:=__FUN-UNTYPED-COMMON + > let_in__FUN-UNTYPED-COMMON + letrec_in__FUN-UNTYPED-COMMON + if_then_else__FUN-UNTYPED-COMMON + > _;__FUN-UNTYPED-COMMON + > fun__FUN-UNTYPED-COMMON + > datatype_=___FUN-UNTYPED-COMMON +endmodule + +module FUN-UNTYPED-MACROS + imports FUN-UNTYPED-COMMON +
    +

    Desugaring macros

    +

    We desugar the list non-constructor operations to functions matching +over list patterns. In order to do that we need some new variables; for +those, we follow the same convention like in the K tutorial, where we +added them as new identifier constructs starting with the character $, +so we can easily recognize them when we debug or trace the semantics.

    +
    k
    syntax Name ::= "$h" [token] | "$t" [token] + rule head => fun [$h|$t] -> $h + rule tail => fun [$h|$t] -> $t + rule null? => fun [.Exps] -> true | [$h|$t] -> false +
    +

    Multiple-head list patterns desugar into successive one-head patterns:

    +
    k
    rule [E1,E2,Es:Exps|T] => [E1|[E2,Es|T]] [anywhere] +
    +

    Uncurrying of multiple arguments in functions and binders:

    +
    k
    rule P1 P2 -> E => P1 -> fun P2 -> E [anywhere] + rule F P = E => F = fun P -> E [anywhere] +
    +

    We desugar the try-catch construct into callcc:

    +
    k
    syntax Name ::= "$k" [token] | "$v" [token] + rule try E catch(X) E' + => callcc (fun $k -> (fun throw -> E)(fun X -> $k E')) +
    +

    For uniformity, we reduce all types to their general form:

    +
    k
    rule `Type-TypeName`(T:Type, Tn:TypeName) => (T) Tn +
    +

    The dynamic semantics ignores all the type declarations:

    +
    k
    rule datatype _T = _TCs E => E + +endmodule + + +module FUN-UNTYPED-SYNTAX + imports FUN-UNTYPED-COMMON + imports BUILTIN-ID-TOKENS + + syntax Name ::= r"[a-z][_a-zA-Z0-9]*" [token, prec(2)] + | #LowerId [token] + syntax ConstructorName ::= #UpperId [token] + syntax TypeVar ::= r"['][a-z][_a-zA-Z0-9]*" [token] + syntax TypeName ::= Name [token] +endmodule +
    +

    Semantics

    +

    The semantics below is environment-based. A substitution-based +definition of FUN is also available, but that drops the & +construct as explained above.

    +
    k
    module FUN-UNTYPED + imports FUN-UNTYPED-COMMON + imports FUN-UNTYPED-MACROS + imports DOMAINS + //imports PATTERN-MATCHING +
    +

    Configuration

    +

    The k, env, and store cells are standard +(see, for example, the definition of LAMBDA++ or IMP++ in the first +part of the K tutorial).

    +
    k
    configuration <T color="yellow"> + <k color="green"> $PGM:Exp </k> + <env color="violet"> .Map </env> + <store color="white"> .Map </store> + </T> +
    +

    Values and results

    +

    We only define integers, Booleans and strings as values here, but will +add more values later.

    +
    k
    syntax Val ::= Int | Bool | String + syntax Vals ::= Bottoms + syntax KResult ::= Val +
    +

    Lookup

    +
    k
    rule <k> X:Name => V ...</k> + <env>... X |-> L ...</env> + <store>... L |-> V ...</store> +
    +

    Arithmetic expressions

    +
    k
    rule I1 * I2 => I1 *Int I2 + rule I1 / I2 => I1 /Int I2 when I2 =/=K 0 + rule I1 % I2 => I1 %Int I2 when I2 =/=K 0 + rule I1 + I2 => I1 +Int I2 + rule S1 ^ S2 => S1 +String S2 + rule I1 - I2 => I1 -Int I2 + rule - I => 0 -Int I + rule I1 < I2 => I1 <Int I2 + rule I1 <= I2 => I1 <=Int I2 + rule I1 > I2 => I1 >Int I2 + rule I1 >= I2 => I1 >=Int I2 + rule V1:Val == V2:Val => V1 ==K V2 + rule V1:Val != V2:Val => V1 =/=K V2 + rule ! T => notBool(T) + rule true && E => E + rule false && _ => false + rule true || _ => true + rule false || E => E +
    +

    Conditional

    +
    k
    rule if true then E else _ => E + rule if false then _ else E => E +
    +

    Lists

    +

    We have already declared the syntactic list of expressions strict, so +we can assume that all the elements that appear in a FUN list are +evaluated. The only thing left to do is to state that a list of +values is a value itself, that is, that the list square-bracket +construct is indeed a constructor, and to give the semantics of +cons. Since cons is a builtin function and is +expected to take two arguments, we have to also state that +cons itself is a value (specifically, a function/closure +value, but we do not need that level of detail here), and also that +cons applied to a value is a value (specifically, it would be +a function/closure value that expects the second, list argument):

    +
    k
    rule cons V:Val [Vs:Vals] => [V,Vs] +
    +

    Data Constructors

    +

    Constructors take values as arguments and produce other values:

    +
    k
    syntax Val ::= ConstructorName +
    +

    Functions and Closures

    +

    Like in the environment-based semantics of LAMBDA++ in the first part +of the K tutorial, functions evaluate to closures. A closure includes +the current environment besides the function contents; the environment +will be used at execution time to lookup all the variables that appear +free in the function body (we want static scoping in FUN).

    +
    k
    syntax Val ::= closure(Map,Cases) + rule <k> fun Cases => closure(Rho,Cases) ...</k> <env> Rho </env> +
    +

    Note: The reader may want to get familiar with +how the pre-defined pattern matching works before proceeding. +The best way to do that is to consult +k/include/modules/pattern-matching.k.

    + +

    We distinguish two cases when the closure is applied. +If the first pattern matches, then we pick the first case: switch to +the closed environment, get the matching map and bind all its +variables, and finally evaluate the function body of the first case, +making sure that the environment is properly recovered afterwards. +If the first pattern does not match, then we drop it and thus move on +to the next one.

    +
    k
    rule (. => getMatching(P, V)) ~> closure(_, P->_ | _) V:Val + rule <k> matchResult(M:Map) ~> closure(Rho, _->E | _) _ + => bindMap(M) ~> E ~> setEnv(Rho') ...</k> + <env> Rho' => Rho </env> + rule (matchFailure => .) ~> closure(_, (_->_ | Cs:Cases => Cs)) _ +// rule <k> closure(Rho, P->E | _) V:Val +// => bindMap(getMatching(P,V)) ~> E ~> setEnv(Rho') ...</k> +// <env> Rho' => Rho </env> when isMatching(P,V) +// rule closure(_, (P->_ | Cs:Cases => Cs)) V:Val when notBool isMatching(P,V) +
    +

    Let and Letrec

    +

    To highlight the similarities and differences between let and +letrec, we prefer to give them direct semantics instead of +to desugar them like in LAMBDA. See the formal definitions of +bindTo, bind, and assignTo at the end of +this module. Informally, bindTo(Xs, Es) first +evaluates the expressions Es in Exps in the current +environment (i.e., it is strict in its second argument), then it binds +the variables in Xs in Names to new locations and adds +those bindings to the environment, and finally writes the values +previously obtained after evaluating the expressions Es to those +new locations; bind(Xs) does only the bindings of +Xs to new locations and adds those bindings to the environment; +and assignTo(Xs,Es) evaluates the expressions +Es in the current environment and then it writes the resulting +values to the locations to which the variables Xs are already +bound to in the environment.

    +

    Therefore, let Xs = Es in E first +evaluates Es in the current environment, then adds new +bindings for Xs to fresh locations in the environment, then +writes the values of Es to those locations, and finally +evaluates E in the new environment, making sure that the +environment is properly recovered after the evaluation of E. +On the other hand, letrec does the same things but in a +different order: it first adds new bindings for Xs to fresh +locations in the environment, then it evaluates Es in the new +environment, then it writes the resulting values to their +corresponding locations, and finally it evaluates E and +recovers the environment. The crucial difference is that the +expressions Es now see the locations of the variables Xs +in the environment, so if they are functions, which is typically the +case with letrec, their closures will encapsulate in their +environments the bindings of all the bound variables, including +themselves (thus, we may have a closure value stored at location +L, whose environment contains a binding of the form +F ↦ L; this way, the closure can invoke +itself).

    +
    k
    rule <k> let Bs in E + => bindTo(names(Bs),exps(Bs)) ~> E ~> setEnv(Rho) ...</k> + <env> Rho </env> + + rule <k> letrec Bs in E + => bind(names(Bs))~>assignTo(names(Bs),exps(Bs))~>E~>setEnv(Rho)...</k> + <env> Rho </env> +
    +

    Recall that our syntax allows let and letrec to +take any expression in place of its binding. This allows us to use +the already existing function application construct to bind names to +functions, such as, e.g., let x y = y in .... +The desugaring macro in the syntax module uncurries such declarations, +and then the semantic rules above only work when the remaining +bindings are identifiers, so the semantics will get stuck on programs +that misuse the let and letrec binders.

    +

    References

    +

    The semantics of references is self-explanatory, except maybe for the +desugaring rule of ref, which is further discussed. Note +that &X grabs the location of X from the environment. +Sequential composition, which is needed only to accumulate the +side effects due to assignments, was strict in the first argument. +Once evaluated, its first argument is simply discarded:

    +
    k
    syntax Name ::= "$x" [token] + rule ref => fun $x -> & $x + rule <k> & X => L ...</k> <env>... X |-> L ...</env> + rule <k> @ L:Int => V:Val ...</k> <store>... L |-> V ...</store> + rule <k> L:Int := V:Val => V ...</k> <store>... L |-> (_=>V) ...</store> + rule _V:Val; E => E +
    +

    The desugaring rule of ref (first rule above) works +because & takes a variable and returns its location (like in C). +Note that some ``pure'' functional programming researchers strongly dislike +the & construct, but favor ref. We refrain from having +a personal opinion on this issue here, but support & in the +environment-based definition of FUN because it is, technically speaking, +more powerful than ref. From a language design perspective, it +would be equally easy to drop & and instead give a direct +semantics to ref. In fact, this is precisely what we do in the +substitution-based definition of FUN, because there appears to be no way +to give a substitution-based definition to the & construct.

    +

    Callcc

    +

    As we know it from the LAMBDA++ tutorial, call-with-current-continuation +is quite easy to define in K. We first need to define a special +value wrapping an execution context, that is, an environment saying +where the variables should be looked up, and a computation structure +saying what is left to execute (in a substitution-based definition, +this special value would be even simpler, as it would only need to +wrap the computation structure---see, for example, the +substitution-based semantics of LAMBDA++ in the the first part of the +K tutorial, or the substitution-based definition of FUN). Then +callcc creates such a value containing the current +environment and the current remaining computation, and passes it to +its argument function. When/If invoked, the special value replaces +the current execution context with its own and continues the execution +normally.

    +
    k
    syntax Val ::= cc(Map,K) + rule <k> (callcc V:Val => V cc(Rho,K)) ~> K </k> <env> Rho </env> + rule <k> cc(Rho,K) V:Val ~> _ => V ~> K </k> <env> _ => Rho </env> +
    +

    Auxiliary operations

    +

    Environment recovery

    +

    The environment recovery operation is the same as for the LAMBDA++ +language in the K tutorial and many other languages provided with the +K distribution. The first ``anywhere'' rule below shows an elegant +way to achieve the benefits of tail recursion in K.

    +
    k
    syntax KItem ::= setEnv(Map) // TODO: get rid of env + //rule (setEnv(_) => .) ~> setEnv(_) [anywhere] + rule <k> _:Val ~> (setEnv(Rho) => .) ...</k> <env> _ => Rho </env> +
    +

    bindTo, bind and assignTo

    +

    The meaning of these operations has already been explained when we +discussed the let and letrec language constructs +above.

    +
    k
    syntax KItem ::= bindTo(Names,Exps) [strict(2)] + | bindMap(Map) + | bind(Names) + + rule (. => getMatchingAux(Xs,Vs)) ~> bindTo(Xs:Names,Vs:Vals) + rule matchResult(M:Map) ~> bindTo(_:Names, _:Vals) => bindMap(M) + + rule bindMap(.Map) => . + rule <k> bindMap((X:Name |-> V:Val => .Map) _:Map) ...</k> + <env> Rho => Rho[X <- !L:Int] </env> + <store>... .Map => !L |-> V ...</store> + + rule bind(.Names) => . + rule <k> bind(X:Name,Xs => Xs) ...</k> + <env> Rho => Rho[X <- !_L:Int] </env> + + syntax KItem ::= assignTo(Names,Exps) [strict(2)] + + rule <k> assignTo(.Names,.Vals) => . ...</k> + rule <k> assignTo((X:Name,Xs => Xs),(V:Val,Vs:Vals => Vs)) ...</k> + <env>... X |-> L ...</env> + <store>... .Map => L |-> V ...</store> +
    +

    Getters

    +

    The following auxiliary operations extract the list of identifiers +and of expressions in a binding, respectively.

    +
    k
    syntax Names ::= names(Bindings) [function] + rule names(.Bindings) => .Names + rule names(X:Name=_ and Bs) => (X,names(Bs))::Names + + syntax Exps ::= exps(Bindings) [function] + rule exps(.Bindings) => .Exps + rule exps(_:Name=E and Bs) => E,exps(Bs) + + /* Extra kore stuff */ + syntax KResult ::= Vals + syntax Exps ::= Names + syntax Names ::= Bottoms + + /* Matching */ + syntax MatchResult ::= getMatching(Exp, Val) [function] + | getMatchingAux(Exps, Vals) [function] + | mergeMatching(MatchResult, MatchResult) [function] + | matchResult(Map) + | "matchFailure" + + rule getMatching(C:ConstructorName(Es:Exps), C(Vs:Vals)) => getMatchingAux(Es, Vs) + rule getMatching([Es:Exps], [Vs:Vals]) => getMatchingAux(Es, Vs) + rule getMatching(C:ConstructorName, C) => matchResult(.Map) + rule getMatching(B:Bool, B) => matchResult(.Map) + rule getMatching(I:Int, I) => matchResult(.Map) + rule getMatching(S:String, S) => matchResult(.Map) + rule getMatching(N:Name, V:Val) => matchResult(N |-> V) + rule getMatching(_, _) => matchFailure [owise] + + rule getMatchingAux((E:Exp, Es:Exps), (V:Val, Vs:Vals)) => mergeMatching(getMatching(E, V), getMatchingAux(Es, Vs)) + rule getMatchingAux(.Exps, .Vals) => matchResult(.Map) + rule getMatchingAux(_, _) => matchFailure [owise] + + rule mergeMatching(matchResult(M1:Map), matchResult(M2:Map)) => matchResult(M1 M2) + requires intersectSet(keys(M1), keys(M2)) ==K .Set + //rule mergeMatching(_, _) => matchFailure [owsie] + rule mergeMatching(matchResult(_:Map), matchFailure) => matchFailure + rule mergeMatching(matchFailure, matchResult(_:Map)) => matchFailure + rule mergeMatching(matchFailure, matchFailure) => matchFailure +
    +

    Besides the generic decomposition rules for patterns and values, +we also want to allow [head|tail] matching for lists, so we add +the following custom pattern decomposition rule:

    +
    k
    rule getMatching([H:Exp | T:Exp], [V:Val, Vs:Vals]) + => getMatchingAux((H, T), (V, [Vs])) +endmodule +
    +

    Go to Lesson 2, FUN untyped, Substitution-Based.

    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/2_languages/3_fun/1_untyped/2_substitution/fun-untyped/index.html b/k-distribution/pl-tutorial/2_languages/3_fun/1_untyped/2_substitution/fun-untyped/index.html new file mode 100644 index 00000000000..9e14ec5e009 --- /dev/null +++ b/k-distribution/pl-tutorial/2_languages/3_fun/1_untyped/2_substitution/fun-untyped/index.html @@ -0,0 +1,720 @@ + + + + + + + + + + + + + + +FUN — Untyped — Substitution | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    FUN — Untyped — Substitution

    +

    Author: Grigore Roșu (grosu@illinois.edu)
    +Organization: University of Illinois at Urbana-Champaign

    +

    Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
    +Organization: University of Bucharest

    +

    Abstract

    +

    This is the substitution-based definition of FUN. For additional +explanations regarding the semantics of the various FUN constructs, +the reader should consult the emvironment-based definition of FUN.

    +

    Syntax

    +
    k
    require "substitution.md" +//require "modules/pattern-matching.k" + +module FUN-UNTYPED-COMMON + imports DOMAINS-SYNTAX +
    +

    The Syntactic Constructs

    +
    k
    syntax Name + syntax Names ::= List{Name,","} + + syntax Exp ::= Int | Bool | String | Name + | "(" Exp ")" [bracket] + syntax Exps ::= List{Exp,","} [strict] + syntax Val + syntax Vals ::= List{Val,","} + + syntax Exp ::= left: + Exp "*" Exp [strict, arith] + | Exp "/" Exp [strict, arith] + | Exp "%" Exp [strict, arith] + > left: + Exp "+" Exp [strict, left, arith] + | Exp "^" Exp [strict, left, arith] + | Exp "-" Exp [strict, prefer, arith] + | "-" Exp [strict, arith] + > non-assoc: + Exp "<" Exp [strict, arith] + | Exp "<=" Exp [strict, arith] + | Exp ">" Exp [strict, arith] + | Exp ">=" Exp [strict, arith] + | Exp "==" Exp [strict, arith] + | Exp "!=" Exp [strict, arith] + > "!" Exp [strict, arith] + > Exp "&&" Exp [strict(1), left, arith] + > Exp "||" Exp [strict(1), left, arith] + + syntax Exp ::= "if" Exp "then" Exp "else" Exp [strict(1)] + + syntax Exp ::= "[" Exps "]" [strict] + | "cons" | "head" | "tail" | "null?" + | "[" Exps "|" Exp "]" + syntax Val ::= "[" Vals "]" + + syntax ConstructorName + syntax Exp ::= ConstructorName + | ConstructorName "(" Exps ")" [prefer, strict(2)] + syntax Val ::= ConstructorName "(" Vals ")" + + syntax Exp ::= "fun" Cases + | Exp Exp [strict, left] + syntax Case ::= Exp "->" Exp [binder] +// NOTE: The binder attribute above is the only difference between this +// module and the syntax module of environment-based FUN. We need +// to fix a bug in order to import modules and override the attributes +// of operations. + syntax Cases ::= List{Case, "|"} + + syntax Exp ::= "let" Bindings "in" Exp + | "letrec" Bindings "in" Exp [prefer] + syntax Binding ::= Exp "=" Exp + syntax Bindings ::= List{Binding,"and"} + + syntax Exp ::= "ref" + | "&" Name + | "@" Exp [strict] + | Exp ":=" Exp [strict] + | Exp ";" Exp [strict(1), right] + + syntax Exp ::= "callcc" + | "try" Exp "catch" "(" Name ")" Exp + syntax Name ::= "throw" [token] + + syntax Exp ::= "datatype" Type "=" TypeCases Exp + + syntax TypeVar + syntax TypeVars ::= List{TypeVar,","} + + syntax TypeName + syntax Type ::= "int" | "bool" | "string" + | Type "-->" Type [right] + | "(" Type ")" [bracket] + | TypeVar + | TypeName [klabel(TypeName), avoid] + | Type TypeName [klabel(Type-TypeName), onlyLabel] + | "(" Types ")" TypeName [prefer] + syntax Types ::= List{Type,","} + syntax Types ::= TypeVars + + syntax TypeCase ::= ConstructorName + | ConstructorName "(" Types ")" + syntax TypeCases ::= List{TypeCase,"|"} [klabel(_|TypeCase_)] +
    +

    Additional Priorities

    +
    k
    syntax priorities @__FUN-UNTYPED-COMMON + > ___FUN-UNTYPED-COMMON + > arith + > _:=__FUN-UNTYPED-COMMON + > let_in__FUN-UNTYPED-COMMON + letrec_in__FUN-UNTYPED-COMMON + if_then_else__FUN-UNTYPED-COMMON + > _;__FUN-UNTYPED-COMMON + > fun__FUN-UNTYPED-COMMON + > datatype_=___FUN-UNTYPED-COMMON +endmodule + +module FUN-UNTYPED-MACROS + imports FUN-UNTYPED-COMMON +
    +

    Desugaring macros

    +
    k
    rule P1 P2 -> E => P1 -> fun P2 -> E [macro-rec] + rule F P = E => F = fun P -> E [macro-rec] + + rule [E1,E2,Es:Exps|T] => [E1|[E2,Es|T]] [macro-rec] + +// rule 'TypeName(Tn:TypeName) => (.TypeVars) Tn [macro] + rule `Type-TypeName`(T:Type, Tn:TypeName) => (T) Tn [macro] + + syntax Name ::= "$h" | "$t" + rule head => fun [$h|$t] -> $h [macro] + rule tail => fun [$h|$t] -> $t [macro] + rule null? => fun [.Exps] -> true | [$h|$t] -> false [macro] + + syntax Name ::= "$k" | "$v" + rule try E catch(X) E' + => callcc (fun $k -> (fun throw -> E)(fun X -> $k E')) [macro] + + rule datatype _T = _TCs E => E [macro] +
    +

    mu needed for letrec, but we put it here so we can also write +programs with mu in them, which is particularly useful for testing.

    +
    k
    syntax Exp ::= "mu" Case + +endmodule + + +module FUN-UNTYPED-SYNTAX + imports FUN-UNTYPED-COMMON + imports BUILTIN-ID-TOKENS + + syntax Name ::= r"[a-z][_a-zA-Z0-9]*" [token, prec(2)] + | #LowerId [token] + syntax ConstructorName ::= #UpperId [token] + syntax TypeVar ::= r"['][a-z][_a-zA-Z0-9]*" [token] + syntax TypeName ::= Name [token] +endmodule +
    +

    Semantics

    +
    k
    module FUN-UNTYPED + imports FUN-UNTYPED-COMMON + imports FUN-UNTYPED-MACROS + imports DOMAINS + imports SUBSTITUTION + //imports PATTERN-MATCHING + + configuration <T color="yellow"> + <k color="green"> $PGM:Exp </k> + <store color="white"> .Map </store> + </T> +
    +

    Both Name and functions are values now:

    +
    k
    syntax Val ::= Int | Bool | String | Name + syntax Exp ::= Val + syntax Exps ::= Vals + syntax KResult ::= Val + syntax Exps ::= Names + syntax Vals ::= Names + + rule I1 * I2 => I1 *Int I2 + rule I1 / I2 => I1 /Int I2 when I2 =/=K 0 + rule I1 % I2 => I1 %Int I2 when I2 =/=K 0 + rule I1 + I2 => I1 +Int I2 + rule S1 ^ S2 => S1 +String S2 + rule I1 - I2 => I1 -Int I2 + rule - I => 0 -Int I + rule I1 < I2 => I1 <Int I2 + rule I1 <= I2 => I1 <=Int I2 + rule I1 > I2 => I1 >Int I2 + rule I1 >= I2 => I1 >=Int I2 + rule V1:Val == V2:Val => V1 ==K V2 + rule V1:Val != V2:Val => V1 =/=K V2 + rule ! T => notBool(T) + rule true && E => E + rule false && _ => false + rule true || _ => true + rule false || E => E + + rule if true then E else _ => E + rule if false then _ else E => E + + rule isVal(cons) => true + rule isVal(cons _V:Val) => true + rule cons V:Val [Vs:Vals] => [V,Vs] + + syntax Val ::= ConstructorName + + rule isVal(fun _) => true + syntax KVar ::= Name + syntax Name ::= freshName(Int) [freshGenerator, function] + rule freshName(I:Int) => {#parseToken("Name", "#" +String Int2String(I))}:>Name + + rule (. => getMatching(P, V)) ~> (fun P->_ | _) V:Val + rule matchResult(M:Map) ~> (fun _->E | _) _ => E[M] + rule (matchFailure => .) ~> (fun (_->_ | Cs:Cases => Cs)) _ +// rule (fun P->E | _) V:Val => E[getMatching(P,V)] when isMatching(P,V) +// rule (fun (P->_ | Cs:Cases => Cs)) V:Val when notBool isMatching(P,V) +
    +

    We can reduce multiple bindings to one list binding, and then +apply the usual desugaring of let into function application. +It is important that the rule below is a macro, so let is eliminated +immediately, otherwise it may interfere in ugly ways with substitution.

    +
    k
    rule let Bs in E => ((fun [names(Bs)] -> E) [exps(Bs)]) [macro] +
    +

    We only give the semantics of one-binding letrec. +Multipe bindings are left as an exercise.

    +
    k
    // changed because of parsing error + //rule mu X:Name -> E => E[(mu X -> E) / X] + rule mu X:Name -> E => E[X |-> (mu X -> E)] + rule letrec F:Name = E in E' => let F = (mu F -> E) in E' [macro] +
    +

    We cannot have & anymore, but we can give direct +semantics to ref. We also have to declare ref to +be a value, so that we will never heat on it.

    +
    k
    // rule <k> & X => L ...</k> <env>... X |-> L </env> + rule isVal(ref) => true + rule <k> ref V:Val => !L:Int ...</k> <store>... .Map => !L |-> V ...</store> + rule <k> @ L:Int => V:Val ...</k> <store>... L |-> V ...</store> + rule <k> L:Int := V:Val => V ...</k> <store>... L |-> (_=>V) ...</store> + rule _V:Val; E => E + + syntax Val ::= cc(K) + rule isVal(callcc) => true + rule <k> (callcc V:Val => V cc(K)) ~> K </k> + rule <k> cc(K) V:Val ~> _ => V ~> K </k> +
    +

    Auxiliary getters

    +
    k
    syntax Names ::= names(Bindings) [function] + rule names(.Bindings) => .Names + rule names(X:Name=_ and Bs) => X,names(Bs) + + syntax Exps ::= exps(Bindings) [function] + rule exps(.Bindings) => .Exps + rule exps(_:Name=E and Bs) => E,exps(Bs) + + /* Extra kore stuff */ + syntax KResult ::= Vals + syntax Exps ::= Names + + /* Matching */ + syntax MatchResult ::= getMatching(Exp, Val) [function] + | getMatchingAux(Exps, Vals) [function] + | mergeMatching(MatchResult, MatchResult) [function] + | matchResult(Map) + | "matchFailure" + + rule getMatching(C:ConstructorName(Es:Exps), C(Vs:Vals)) => getMatchingAux(Es, Vs) + rule getMatching([Es:Exps], [Vs:Vals]) => getMatchingAux(Es, Vs) + rule getMatching(C:ConstructorName, C) => matchResult(.Map) + rule getMatching(B:Bool, B) => matchResult(.Map) + rule getMatching(I:Int, I) => matchResult(.Map) + rule getMatching(S:String, S) => matchResult(.Map) + rule getMatching(N:Name, V:Val) => matchResult(N |-> V) + rule getMatching(_, _) => matchFailure [owise] + + rule getMatchingAux((E:Exp, Es:Exps), (V:Val, Vs:Vals)) => mergeMatching(getMatching(E, V), getMatchingAux(Es, Vs)) + rule getMatchingAux(.Exps, .Vals) => matchResult(.Map) + rule getMatchingAux(_, _) => matchFailure [owise] + + rule mergeMatching(matchResult(M1:Map), matchResult(M2:Map)) => matchResult(M1 M2) + requires intersectSet(keys(M1), keys(M2)) ==K .Set + //rule mergeMatching(_, _) => matchFailure [owsie] + rule mergeMatching(matchResult(_:Map), matchFailure) => matchFailure + rule mergeMatching(matchFailure, matchResult(_:Map)) => matchFailure + rule mergeMatching(matchFailure, matchFailure) => matchFailure +
    +

    Besides the generic decomposition rules for patterns and values, +we also want to allow [head|tail] matching for lists, so we add +the following custom pattern decomposition rule:

    +
    k
    rule getMatching([H:Exp | T:Exp], [V:Val, Vs:Vals]) + => getMatchingAux((H, T), (V, [Vs])) +endmodule +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/2_languages/4_logik/basic/logik/index.html b/k-distribution/pl-tutorial/2_languages/4_logik/basic/logik/index.html new file mode 100644 index 00000000000..e7af0d9bb67 --- /dev/null +++ b/k-distribution/pl-tutorial/2_languages/4_logik/basic/logik/index.html @@ -0,0 +1,710 @@ + + + + + + + + + + + + + + +LOGIK | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    LOGIK

    +

    Author: Grigore Roșu (grosu@illinois.edu)
    +Organization: University of Illinois at Urbana-Champaign

    +

    Author: Traian Florin Șerbănuță (traian.serbanuta@unibuc.ro)
    +Organization: University of Bucharest

    +

    Abstract

    +

    This is the K semantic definition of LOGIK, a trivial language +capturing the essence of the logic programming paradigm. In this +definition, we explicitly focus on simplicity and mathematical +clarity, not on advanced logic programming features or performance. +Those are covered in the LOGIK++ extension under examples/logik++.

    +

    Specifically, a LOGIK program consists of a sequence of Horn clauses +of the form

    +
    P :- P1, P2, ..., Pn .
    +
    +

    followed by a query of the form

    +
    ?- Q1, Q2, ..., Qm .
    +
    +

    where P, P1, P2, ..., Pn, Q1, Q2, +..., Qm are literals. The +symbol :- is read "if". A literal has the form +p(T1,T2,...,Tk), where p is a predicate symbol +and where T1,T2,...,Tk are terms. Terms are built as +usual, with operation symbols and variables. A common +convention in logic programming languages, also adopted here, is that +variables are capitalized and operation symbols are not. Operations +with zero arguments are called constants and are written without +parentheses, that is, c instead of c(). Horn +clauses without conditions, called facts, are written +without :-, that is, P. instead of P :- ..

    +

    For example, the LOGIK program below gives a few facts about a +parent predicate, then several clauses defining some useful +predicates including an ancestor predicate, and finally a +query asking for those who both have ancestors and are ancestors +themselves in the parent relation:

    +
    parent(david,john).
    +parent(jim,david).
    +parent(steve,jim).
    +parent(nathan,steve).
    +
    +grandparent(A,B):-
    +  parent(A,X),
    +  parent(X,B).
    +
    +ancestor(A,B):-
    +  parent(A,X),
    +  parents(X,B).
    +
    +parents(X,X).
    +parents(A,B):-
    +  ancestor(A,B).
    +
    +both(X) :- ancestor(A,X), ancestor(X,B).
    +
    +?- both(X).
    +
    +

    Above, we only have constant operation symbols, so these and variables +are the only terms that can be used in predicates. As expected, the +LOGIK program above will give us three solutions for X: +david, steve, and jim. If we inline the +both(X) predicate in the query, that is, if we replace the +query with ?- ancestor(A,X), ancestor(X,B). then we get +10 solutions, one for for each triple A, X, and +B satisfying both predicates ancestor(A,X) and +ancestor(X,B).

    +

    As another example, the program below defines an append +predicate followed by a simple goal:

    +
    append(nil,L,L).
    +append(cons(H,T),L,cons(H,Z)) :- append(T,L,Z).
    +
    +?- append(cons(a,nil), cons(b,nil), V).
    +
    +

    Besides the predicate symbol append, the program above also +includes a constant symbol nil and a binary operation symbol +cons. Additionally, the query also includes two more +constants, a and b. The capitalized identifiers are +all variables. As expected, the LOGIK program above yields only one +solution, namely V = cons(a,cons(b,nil)). On the other hand, +if we change the query to:

    +
    ?- append(L1, cons(a,L2), cons(a,cons(b,cons(a,nil)))).
    +
    +

    then LOGIK yields two solutions: one where L1 is +cons(a,cons(b,nil)) and L2 is nil, +and another where L1 is nil and L2 is +cons(a,cons(b,nil)).

    +

    The programs above all generated ground solutions, that is, +solutions where the query variables are mapped to ground terms (i.e., +terms without variables). Let us now consider the following query:

    +
    ?- append(cons(a,nil), Y, Z).
    +
    +

    There are obviously infinitely many ground solutions for the query +above, e.g.,
    +Y = nil and Z = cons(a,nil),
    +Y = cons(a,nil) and Z = cons(a,cons(a,nil)),
    +Y = cons(b,nil) and Z = cons(a,cons(b,nil)),
    +Y = cons(c,cons(b,nil)) and Z = cons(a,cons(c,cons(b,nil))),
    +etc. However, all the ground solutions for the query above can be +elegantly characterized by the property that Z is bound to a list +starting with a and followed by the list that Y is +bound to. This property can in fact be described as a symbolic solution +to the query: Z = cons(a,Y) or, equivalently, +Y = Symb and Z = cons(a,Symb). It is possible to +define a ``more general than'' relation on such symbolic solutions, +in the sense that the more particular solution can be obtained as a +specialization/substitution of the more general one, and then it can +be shown that the above is the most general solution to the +stated query. Logic programming languages, including our LOGIK, +attempt to always compute such most general solutions.

    +

    Logic programming languages are highly non-deterministic, in that +several Horn clauses may be used at the same time, each possibly +resulting in a different solution. Implementations of logic +programming languages consist of complex, optimized search and +indexing algorithms, which we are not concerned with here. Instead, +we here take advantage of K's builtin support for search. +Specifically, to find all the solutions of a LOGIK program, we have to +use krun with the option --search. However, note +that some programs have infinitely many solutions which cannot relate +to each other by the "more general" relation. For example, the query

    +
    ?- append(L1, cons(a,L2), L3) .
    +
    +

    To address such cases and terminate, logic programming languages allow +the user to choose how many solutions to be computed and displayed. +In LOGIK, we can use the --bound option of krun for +this purpose.

    +

    Finally, note that some queries have no solution. In some cases that +is easy to detect by exhaustive analysis, such as for the following +query:

    +
    ?- append(cons(a,L1), L2, cons(b,L3)).
    +
    +

    Logic programming languages, including LOGIK, terminate in such cases +and report a no solution answer. However, there are cases where +exhaustive analysis is not sufficient, such as for the query:

    +
    ?- append(cons(a,L), nil, L).
    +
    +

    In such cases, logic programming languages do not terminate. While +one may devise techniques to detect non-termination in some cases, +one cannot do it in general (same like for all Turing-complete +languages).

    +
    k
    require "unification.k" + +module LOGIK-COMMON + imports DOMAINS-SYNTAX +
    +

    Syntax

    +

    The syntax of LOGIK is straightforward: a program is a sequence of +Horn clauses followed by a query:

    +
    k
    syntax Literal + syntax Term ::= Literal | Literal "(" Terms ")" + syntax Terms ::= List{Term,","} + syntax Clause ::= Term ":-" Terms "." | Term "." + syntax Query ::= "?-" Terms "." + syntax Pgm ::= Query | Clause Pgm +endmodule + +module LOGIK-SYNTAX + imports LOGIK-COMMON + imports BUILTIN-ID-TOKENS +
    +

    Variables and literals are defined as tokens following the conventions +used in Prolog (variables start with _ or capital letter, while literals +start with lower case letters):

    +
    k
    syntax #KVariable ::= r"[A-Z_][A-Za-z0-9_]*" [token, prec(2)] + | #UpperId [token] + syntax Term ::= #KVariable [klabel(#SemanticCastToTerm)] + syntax Literal ::= r"[a-z][a-zA-Z0-9_]*" [token] + | #LowerId [token] +endmodule + +module LOGIK + imports LOGIK-COMMON + imports DOMAINS + imports UNIFICATION +
    +

    Unification is at the core of logic programming. Here we are +going to use the predefined unification procedure (the same one we +used in the type inferencers in Tutorial 5).

    +

    Configuration

    +

    The configuration stores each clause in its own cell for easy access, +and the most general unifier in a cell named mgu, same like +the type inferencers. The k cell holds the query and the +fresh cell holds a fresh clause instance to be attempted on +the next query item. To more easily read the solutions, we add a +second top-level cell, solution. Both top cells are +optional. Indeed, we start with the main top cell and, when a +solution is found, we move it into the solution cell and +discard the main cell.

    +
    k
    configuration <T color="yellow" multiplicity="?"> + <k color="green"> $PGM:Pgm </k> + <fresh color="orange"> .K </fresh> + <clauses color="red"> + <clause color="pink" multiplicity="*"> .K </clause> + </clauses> + <mgu> .K </mgu> + </T> + <solution multiplicity="?"> .K </solution> +
    +

    Pre- and post-processing

    +

    Before we launch the semantics, we first scan the given program and +place each clause in its own cell, and then place the query in the +k cell and initialize the mgu with the variables from the query.

    +

    Note that we put a fresh instance of the clause to avoid interference with +the query variables. By a "fresh instance" of a clause we mean one whose +variables are renamed with fresh names; we need that in order to avoid +undesired unification conflicts due to particular names chosen for +variables in the original program, as well as conflicts due to +subsequent uses of the same clause. It is safe to rename the +variables in a clause, because clauses are universally quantified in +their variables. This process of creating a fresh instance of a +clause is similar to how we created fresh instances of type schemas in +the higher-order type inferencer discussed in Tutorial 5. Indeed, we +can safely regard clauses as "clause schemas" comprising infinitely +many instances, one for each context.

    +
    k
    rule <k> C:Clause Pgm => Pgm </k> + (.Bag => <clause> #renameVariables(C) </clause>) + + rule <k> ?- Ls:Terms. => Ls ...</k> + <mgu> _ => #variablesMap(#variables(Ls)) </mgu> +
    +

    We also sequentialize the goals for easier processing:

    +
    k
    rule L:Term, Ls:Terms => L ~> Ls + rule .Terms => . +
    +

    When all the goals are solved, indicated by the empty k +cell, the calculated most general unifier (mgu) is in the mgu +cell. In that case, to ease reading of the final solution we move the +mgu in the solution cell and delete the rest of the +configuration:

    +
    k
    rule <T>... <k> . </k> <mgu> Theta </mgu> ...</T> + => <solution> Theta </solution> +
    +

    Since we are not interested in seeing the failed attempts to solve +the query, we collapse all the error configurations into an empty +configuration (recall that both top-level cells in the configuration +were declared optional). This way, if we see an empty configuration +when we search for all solutions, we know that some attempts failed +(but we do not know which ones).

    +
    k
    // this would be nice, but we need feedback from the external unifier +// for this. +// rule <T>... <mgu> _:MguError </mgu> ...</T> => . +
    +

    Semantics

    +

    Once all the infrastructure is in place, the actual semantics of LOGIK +is quite simple. All we have to do is to pick some (fresh instance of +a) clause, then unify its conclusion with the first query literal, and +then replace that literal with condition of the clause. The intuition +here is the following: to satisfy the first literal in the query, we +need to find some instance of some clause that matches it, and then to +similarly show that we can satisfy the conditions of that clause. +Mathematically, this is an instance of the proof principle called +resolution: if p ∨ q and ¬ p ∨ r hold, then so does +q ∨ r. We let it as an exercise to the reader to see how the two +relate (hint: assume the negation of the goal together with all the +clauses, and then derive false).

    +

    The following two rules are tightly connected and they together +perform the following core task: pick a fresh instance of a clause +which unifies with the first goal item, then add its conditions as new +goals.

    +

    Pick a clause and generate a fresh instance of it when the +fresh cell is empty:

    +
    k
    rule <fresh> . => #renameVariables(C) </fresh> <clause> C </clause> + <k> T:Term ...</k> + requires #unifiable(T,head(C)) + + syntax Term ::= head(Clause) [function] + rule head(L.) => L + rule head(L:-_.) => L +
    +

    If the goal is unifiable with the fresh clause's head, replace the goal +with the clause body, and empty the fresh cell (so that +another clause can be chosen using the rule above):

    +
    k
    rule <k> L:Term => . ...</k> + <fresh> L:Term . => . </fresh> + + rule <k> L:Term :KItem => Ls ...</k> + <fresh> L:Term :- Ls:Terms. => . </fresh> +
    +

    Note that there is no problem if a clause is chosen whose +conclusion literal does not unify with the first goal literal. +The search +option of krun will systematically try all clauses, so no +solution is missed. Of course, the above is not the most efficient +way to implement a logic programming language, but recall that our +objective here was to present a simple and mathematically clean +solution. We encourage the interested reader to consult the LOGIK++ +language definition for a more efficient definition of a richer logic +programming language.

    +
    k
    endmodule +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/2_languages/index.html b/k-distribution/pl-tutorial/2_languages/index.html new file mode 100644 index 00000000000..2f2a99d3899 --- /dev/null +++ b/k-distribution/pl-tutorial/2_languages/index.html @@ -0,0 +1,396 @@ + + + + + + + + + + + + + + +K Languages | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    K Languages

    +

    Here we present several "real-world" language examples. These languages +demonstrate many of the features you would expect to find in a full-fledged +programming language.

    +
      +
    • SIMPLE: Imperative programming language with threads.
    • +
    • KOOL: SIMPLE extended with object-oriented features.
    • +
    • FUN: A functional language with algebraic data-types and pattern-matching.
    • +
    • LOGIK: A logical programming language based on clause unification.
    • +
    +
    +
    + + +
    + + + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/NOTES/index.html b/k-distribution/pl-tutorial/NOTES/index.html new file mode 100644 index 00000000000..10a478fcebb --- /dev/null +++ b/k-distribution/pl-tutorial/NOTES/index.html @@ -0,0 +1,455 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Dear reader: these NOTES.md documents are mostly for myself (Grigore), to +keep track of changes and updates that need to be made as things evolve +in the K framework. You can safely ignore them. However, if you are curious +how things will change and decide to read them, I would be grateful if you +let me know whenever you find inconsistencies or things that I forgot to +mention here. Or even better, feel free to make pull requests with suggested +changes or updates.

    +

    Global changes that need to be made:

    +
      +
    • Replace when in rules with requires
    • +
    +

    Things to revise each time the structure of the tutorial changes:

    +
      +
    • 1_k\2_imp\lesson_1\README.md refers to Tutorial 1
    • +
    • 1_k\2_imp\lesson_4\README.md refers to Lesson 1
    • +
    • 1_k\2_imp\lesson_4\README.md refers to Tutorial 1, Lesson 2.5
    • +
    • 1_k\3_lambda++\lesson_1\README.md refers to Lesson 8, Tutorial 1
    • +
    • `1_k\3_lambda++\lesson_1\exercises refers to Lesson 1, tests/config.xml
    • +
    • 1_k\3_lambda++\lesson_2\README.md Lesson 1, Tutorial 1; Tutorial 6; Part 1, 2
    • +
    • 1_k\3_lambda++\lesson_3\README.md refers to Lesson 7, Tutorial 1
    • +
    • 1_k\3_lambda++\lesson_4\README.md refers to Lesson 1
    • +
    • 1_k\3_lambda++\lesson_5\README.md refers to Lesson 4, Lesson 8 and Lesson 7 of Tutorial 1
    • +
    • 1_k\3_lambda++\lesson_6\README.md refers to Parts 3 and 4 of the tutorial
    • +
    • 1_k\4_imp++\lesson_1\README.md refers to Lesson 4, Tutorial 2; also Tutorial 3 (at the end)
    • +
    • 1_k\4_imp++\lesson_2\README.md refers to Tutorial 3; Tutorial 2
    • +
    • 1_k\4_imp++\lesson_3\README.md refers to Lesson 1, Lesson 6
    • +
    • 1_k\4_imp++\lesson_4\README.md refers to Tutorial 6
    • +
    • 1_k\4_imp++\lesson_5\README.md refers to Lesson 4; Tutorial 3
    • +
    • 1_k\4_imp++\lesson_6\README.md refers to Lesson 3
    • +
    • 1_k\4_imp++\lesson_7\README.md refers to Lesson 1, 6
    • +
    • 1_k\5_types\lesson_1\README.md refers to Part 4; SIMPLE
    • +
    • 1_k\5_types\lesson_2\NOTES/README.md refer to Tutorial 1
    • +
    • 1_k\5_types\lesson_3\README.md refers to Part 1; Lesson 1,2
    • +
    • 1_k\5_types\lesson_4\README.md refers to Part 1, and to Lessons 2 and 3
    • +
    • 1_k\5_types\lesson_5\README.md refers to Lessons 4, 3, 2
    • +
    • 1_k\5_types\lesson_6\README.md refers to Lesson 5; SIMPLE, KOOL, IMP++
    • +
    • 1_k\5_types\lesson_7\README.md refers to Lesson 4, 8, 9
    • +
    • 1_k\5_types\lesson_8\README.md refers to Lessons 5, 7
    • +
    • 1_k\5_types\lesson_9\README.md refers to Lessons 8, 5, 7, 4
    • +
    • +
    +

    1_k\4_imp++\lesson_2\README.md states "generates a term of the form +symNat(n) of sort Nat", but the representation of symbolic numbers may +have changed

    +

    Describe/use/explain/justify the terminology "the <k/> cell" as opposed to "the k cell".

    +

    Would it be a good idea to make the README files self contained, that is, +to include the entire lang.k code in them, spread over the entire README, as things +are discussed? In case we decide not to, make sure that the code snippets mentioned +in the READMEs are in perfect correspondence to the code in the actual .k definitions. +Maybe add a tag before each code snippet saying what file and what lines in that +file comes from, then we can use a script to check them to be identical.

    +

    1_k\5_types\lesson_4\README.md refers to polymorphism, but some may say that is not precisely +polymorphism, because the types are not universally quantified. Explain that better.

    +

    Modify the entire tutorial to use . or, if needed, .::Map, etc., +instead of .Map, etc.. Check for each instance specifically, because +the surrounding text may also need to be modified.

    +

    We sometimes use "Kompile", or "kompile", as a verb instead of "Compile", +or "compile", to indicate that we mean compilation with K. Similarly for +"Krun", or "krun", instead of "Run" or "run".

    +

    Add citations to:

    +
      +
    • chemical abstract machine
    • +
    • logics, where the distinction between side condition and premise is explained
    • +
    • reduction semantics with evaluation contexts
    • +
    +

    Replace I1 +Int I2, notBool B, etc., with (I1 + I2)@INT, (not B)@Bool, +etc., when we have module qualification in place and working.

    +

    Explain isSort(T) for all sorts Sort, in one place, when it is first used. +Explain also that T:Sort yields a side condition isSort(T).

    +

    Currently all the K collections are "untyped", that is, over the sort K. +In the future we want to have parametric collections. Make sure the tutorial +is systematically changed when this happens.

    +

    See issue #2023 and modify pl-tutorial/1_k/2_imp/lesson_4 accordingly, if needed.

    +

    All definitions, and corresponding READMEs, should be changed to take advantage +of modules and module operations. Ideally, we'd like to have no code repetition +in any examples, except for demonstration purposes.

    +

    In the PL semantics book, define print(AExps) to have the same semantics as in +IMP++: evaluates and prints each of its arguments in order (as opposed to +first evaluate all of them and then print them---for example, if the second +argument performs a division by zero, I still want to print the first argument.)

    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/pl-tutorial/index.html b/k-distribution/pl-tutorial/index.html new file mode 100644 index 00000000000..fe1e5ddc1cb --- /dev/null +++ b/k-distribution/pl-tutorial/index.html @@ -0,0 +1,578 @@ + + + + + + + + + + + + + + +K PL Tutorial | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    K PL Tutorial

    +

    Here you will learn how to use the K tool to define languages by means of a series of screencast movies. It is recommended to do these in the indicated order, because K features already discussed in a previous language definition will likely not be rediscussed in latter definitions. The screencasts follow quite closely the structure of the files under the tutorial folder in the K tool distribution. If you'd rather follow the instructions there and do the tutorial exercises yourself, then go back to https://kframework.org and download the K tool, if you have not done it already. Or, you can first watch the screencasts below and then do the exercises, or do them in parallel.

    +

    K Overview

    +

    Make sure you watch the K overview video before you do the K tutorial:

    + +

    Learning K

    +

    [34'46"] Part 1: Defining LAMBDA

    +

    Here you will learn how to define a very simple functional language in K and the basics of how to use the K tool. The language is a call-by-value variant of lambda calculus with builtins and mu, and its definition is based on substitution.

    + +

    [37'07"] Part 2: Defining IMP

    +

    Here you will learn how to define a very simple, prototypical textbook C-like imperative language, called IMP, and several new features of the K tool.

    + +

    [33'10"] Part 3: Defining LAMBDA++

    +

    Here you will learn how to define constructs which abruptly change the execution control, as well as how to define functional languages using environments and closures. LAMBDA++ extends the LAMBDA language above with a callcc construct.

    + +

    [46'46"] Part 4: Defining IMP++

    +

    Here you will learn how to refine configurations, how to generate fresh elements, how to tag syntactic constructs and rules, how to exhaustively search the space of non-deterministic or concurrent program executions, etc. IMP++ extends the IMP language above with increment, blocks and locals, dynamic threads, input/output, and abrupt termination.

    + +

    [17'03"] Part 5: Defining Type Systems

    +

    Here you will learn how to define various kinds of type systems following various approaches or styles using K.

    + +

    [??'??"] Part 6: Miscellaneous Other K Features

    +

    Here you will learn a few other K features, and better understand how features that you have already seen work.

    +
      +
    • [??'??"] ...
    • +
    +

    Learning Language Design and Semantics using K

    +

    [??'??"] Part 7: SIMPLE: Designing Imperative Programming Languages

    +

    Here you will learn how to design imperative programming languages using K. SIMPLE is an imperative language with functions, threads, pointers, exceptions, multi-dimensional arrays, etc. We first define an untyped version of SIMPLE, then a typed version. For the typed version, we define both a static and a dynamic semantics.

    + +

    [??'??"] Part 8: KOOL: Designing Object-Oriented Programming Languages

    +

    Here woul will learn how to design object-oriented programming languages using K. KOOL is an object-oriented language that extends SIMPLE with classes and objects. We first define an untyped version of KOOL, then a typed version, with both a dynamic and a static semantics.

    + +

    [??'??"] Part 9: FUN: Designing Functional Programming Languages

    +

    H +ere woul will learn how to design functional programming languages using K. FUN is a higher-order functional language with general let, letrec, pattern matching, references, lists, callcc, etc. We first define an untyped version of FUN, then a let-polymorphic type inferencer.

    + +

    [??'??"] Part 10: LOGIK: Designing Logic Programming Languages

    +

    Here you will learn how to design a logic programming language using K.

    + +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/tests/regression-new/checks/markdownErrorLocation/index.html b/k-distribution/tests/regression-new/checks/markdownErrorLocation/index.html new file mode 100644 index 00000000000..00c87ed233f --- /dev/null +++ b/k-distribution/tests/regression-new/checks/markdownErrorLocation/index.html @@ -0,0 +1,394 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    1

    +
    k
    // keep indentation +module MARKDOWNERRORLOCATION-SYNTAX +endmodule +
    +

    7

    +
    .a .b
    9 +
    +

    11

    +
    .k .x
    module MARKDOWNERRORLOCATION + imports INT +
    +
    {
    } +
    +
    k
    rule 21 // pandoc would think this is line 20, column 7 +
    +
    .y .k
    endmodule // pandoc would miss this last unfinished block + +
    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/tests/regression-new/imp++-llvm/imp/index.html b/k-distribution/tests/regression-new/imp++-llvm/imp/index.html new file mode 100644 index 00000000000..2ccfb5321f8 --- /dev/null +++ b/k-distribution/tests/regression-new/imp++-llvm/imp/index.html @@ -0,0 +1,961 @@ + + + + + + + + + + + + + + +IMP++ | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    IMP++

    +

    Author: Grigore Roșu (grosu@illinois.edu)
    +Organization: University of Illinois at Urbana-Champaign

    +

    Abstract

    +

    This is the K semantic definition of the IMP++ language. +IMP++ extends the IMP language with the features listed below. We +strongly recommend you to first familiarize yourself with the IMP +language and its K definition in Tutorial 2 before proceeding.

    +

    Strings and concatenation of strings. Strings are useful +for the print statement, which is discussed below. For +string concatenation, we use the same + construct that we use +for addition (so we overload it).

    +

    Variable increment. We only add a pre-increment construct: +++x increments variable x and evaluates to the +incremented value. Variable increment makes the evaluation of +expressions have side effects, and thus makes the evaluation strategies +of the various language constructs have an influence on the set +of possible program behaviors.

    +

    Input and output. IMP++ adds a read() expression +construct which reads an integer number and evaluates to it, and +a variadic (i.e., it has an arbitrary number of arguments) statement +construct print(e1,e2,...,en) which evaluates its arguments +and then outputs their values. Note that the K tool allows to +connect the input and output cells to the standard input and output +buffers, this way compiling the language definition into an +interactive interpreter.

    +

    Abrupt termination. The halt statement simply halts +the program. The K tool shows the resulting configuration, as if the +program terminated normally. We therefore assume that an external +observer does not care whether the program terminates normally or +abruptly, same like with exit statements in conventional +programming languages like C.

    +

    Dynamic threads. The expression construct spawn s +starts a new concurrent thread that executes statement s, +which is expected to be a block, and evaluates immediately to a fresh +thread identifier that is also assigned to the newly created thread. +The new thread is given at creation time the environment of its +parent, so it can access all its parent's variables. This allows for +the parent thread, and the child thread to communicate; it also allows +for races and "unexpected" behaviors, so be careful. +For thread synchronization, IMP++ provides a thread join statement +construct join t;, where t evaluates to a thread +identifier, which stalls the current thread until thread t +completes its computation. For simplicity, we here assume a +sequentially consistent shared memory model. To experiment with other +memory models, see the definition of KERNELC.

    +

    Blocks and local variables. IMP++ allows blocks enclosed by +curly brackets. Also, IMP's global variable declaration construct is +generalized to be used anywhere as a statement, not only at the +beginning of the program. As expected, the scope of the declared +variables is from their declaration point till the end of the most +nested enclosing block.

    +

    What You Will Learn Here

    +
      +
    • How to define a less trivial language in K, as explained above.
    • +
    • How to use the superheat and supercool +options of the K tool kompile to exhaustively explore the +non-determinism due to underspecified evaluation strategies.
    • +
    • How to use the transition option of the K tool to +exhaustively explore the non-determinism due to concurrency.
    • +
    • How to connect certain cells in the configuration to the +standard input and standard output, and thus turn the krun +tool into an interactive interpreter for the defined language.
    • +
    • How to exhaustively search for the non-deterministic behaviors +of a program using the search option of krun.
    • +
    +
    k
    module IMP-SYNTAX + imports DOMAINS-SYNTAX +
    +

    Syntax

    +

    IMP++ adds several syntactic constructs to IMP. Also, since the +variable declaration construct is generalized to be used anywhere a +statement can be used, not only at the beginning of the program, we +need to remove the previous global variable declaration of IMP and +instead add a variable declaration statement construct

    +

    We do not re-discuss the constructs which are taken over from IMP, +except when their syntax has been subtly modified (such as, for +example, the syntax of the previous "statement" assignment which +is now obtained by composing the new assignment expression, and the +new expression statement constructs); go the last lesson of +Tutorial 2 if you are interested in IMP's constructs. For execution +purposes, we tag the addition and division operations with the +addition and division tags. These attributes have +no theoretical significance, in that they do not affect the semantics +of the language in any way. They only have practical relevance, +specific to our implementation of the K tool. Specifically, we can +tell the K tool (using its superheat and supercool +options) that we want to exhaustively explore all the non-deterministic +behaviors (due to strictness) of these language constructs. For performance +reasons, by default the K tool chooses an arbitrary but fixed order to +evaluate the arguments of the strict language constructs, thus possibly +losing behaviors due to missed interleavings. This aspect was irrelevant in +IMP, because its expressions had no side effects, but it becomes relevant +in IMP++.

    +

    The syntax of the IMP++ constructs is self-explanatory. Note that assignment +is now an expression construct. Also, print is variadic, taking a +list of expressions as argument. It is also strict, which means that the +entire list of expressions, that is, each expression in the list, will be +evaluated. Note also that we have now defined sequential composition +of statements as a whitespace-separated list of statements, aliased with +the nonterminal Stmts, and block as such a (possibly empty) sequence +of statements surrounded by curly brackets.

    +
    k
    syntax AExp ::= Int | String | Id + | "++" Id + | "read" "(" ")" + | "-" AExp [strict] + | "(" AExp ")" [bracket] + > AExp "/" AExp [left, strict, group(division)] + > AExp "+" AExp [left, strict] + > "spawn" Block + > Id "=" AExp [strict(2)] + syntax BExp ::= Bool + | AExp "<=" AExp [seqstrict, latex({#1}\leq{#2})] + | "!" BExp [strict] + | "(" BExp ")" [bracket] + > BExp "&&" BExp [left, strict(1)] + syntax Block ::= "{" Stmts "}" + syntax Stmt ::= Block + | AExp ";" [strict] + | "if" "(" BExp ")" + Block "else" Block [strict(1)] + | "while" "(" BExp ")" Block + | "int" Ids ";" + | "print" "(" AExps ")" ";" + | "halt" ";" + > "join" AExp ";" [strict] + + syntax Ids ::= List{Id,","} + syntax AExps ::= List{AExp,","} + syntax Stmts ::= List{Stmt,""} + syntax AExps ::= Ids +endmodule + + +module IMP + imports IMP-SYNTAX + imports DOMAINS +
    +

    Semantics

    +

    We next give the semantics of IMP++. We start by first defining its +configuration.

    +

    Configuration

    +

    The original configuration of IMP has been extended to include +all the various additional cells needed for IMP++. +To facilitate the semantics of threads, more specifically +to naturally give them access to their parent's variables, we prefer a +(rather conventional) split of the program state into an +environment and a store. An environment maps +variable names into locations, while a store maps locations +into values. Stores are also sometimes called states, or +heaps, or memory, in the literature. Like values, locations +can be anything. For simplicity, here we assume they are natural +numbers. Moreover, each thread has its own environment, so it knows +where all the variables that it has access to are located in the store +(that includes its locally declared variables as well as the variables +of its parent thread), and its own unique identifier. The store is +shared by all threads. For simplicity, we assume a sequentially consistent +memory model in IMP++. Note that the thread cell has multiplicity +*, meaning that there could be zero, one, or more instances of that cell +in the configuration at any given time. This multiplicity information +is important for K's configuration abstraction process: it tells +K how to complete rules which, in order to increase the modularity of the +definition, choose to not mention the entire configuration context. +The in and out cells hold the input and the output +buffers as lists of items.

    +
    k
    configuration <T color="yellow"> + <threads color="orange"> + <thread multiplicity="*" type="Set" color="blue"> + <k color="green"> $PGM:Stmts </k> + <env color="LightSkyBlue"> .Map </env> + <id color="black"> 0 </id> + </thread> + </threads> +// <br/> + <store color="red"> .Map </store> +// <input color="magenta"> .List </input> +// <output color="Orchid"> .List </output> + <input color="magenta" stream="stdin"> .List </input> + <output color="Orchid" stream="stdout"> .List </output> + </T> +// Replace the <input/> and <output/> cells with the next two in order to +// initialize the input buffer through krun +// <input color="magenta"> $IN:List </input> +// <output color="Orchid"> .List </output> +// Replace the <input/> and <output/> cells with the next two to connect the +// input/output buffers to stdin/stdout through krun +// <input color="magenta" stream="stdin"> .List </input> +// <output color="Orchid" stream="stdout"> .List </output> +// Replace the <input/> and <output/> cells with the next two to connect the +// input/output buffers to stdin/stdout and also allow input through krun +// <input color="magenta" stream="stdin"> $IN:List </input> +// <output color="Orchid" stream="stdout"> .List </output> +
    +

    We can also use configuration variables to initialize +the configuration through krun. For example, we may want to +pass a few list items in the in cell when the program makes +use of read(), so that the semantics does not get stuck. +Recall from IMP that configuration variables start with a ParseError: KaTeX parse error: Expected group after '_' at position 63: …, for example, +_̲PGM) and can be initialized with any string by +krun; or course, the string should parse to a term of the +corresponding sort, otherwise errors will be generated. +Moreover, K allows you to connect list cells to the standard input or +the standard output. For example, if you add the attribute +stream="stdin" to the in cell, then krun +will prompt the user to pass input when the in cell is empty +and any semantic rule needs at least one item to be present there in +order to match. Similarly but dually, if you add the attribute +stream="stdout" to the out cell, then any item +placed into this cell by any rule will be promptly sent to the +standard output. This way, krun can be used to obtain +interactive interpreters based directly on the K semantics of the +language. For example:

    +
    shell
    sh$ krun sum-io.imp --output none +Add numbers up to (<= 0 to quit)? 10 +Sum = 55 +Add numbers up to (<= 0 to quit)? 1000 +Sum = 500500 +Add numbers up to (<= 0 to quit)? 0 +sh$ +
    +

    The option --output none instructs krun to not +display the resulting configuration after the program executes. The +input/output streaming works with or without this option, although +if you don't use the option then a configuration with empty +in and out cells will be displayed after the program +is executed. You can also initialize the configuration using +configuration variables and stream the contents of the cells to +standard input/output at the same time. For example, if you use a +configuration variable in the in cell and pass contents to it +through krun, then that contents will be first consumed and +then the user will be prompted to introduce additional input if the +program's execution encounters more read() constructs.

    +

    The old IMP constructs

    +

    The semantics of the old IMP constructs is almost identical to their +semantics in the original IMP language, except for those constructs +making use of the program state and for those whose syntax has slightly +changed. Indeed, the rules for variable lookup and assignment in IMP +accessed the state cell, but that cell is not available in IMP++ +anymore. Instead, we have to use the combination of environment and store +cells. Thanks to K's implicit configuration abstraction, we do not have +to mention the thread and threads cells: these are +automatically inferred (and added by the K tool at compile time) from the +definition of the configuration above, as there is only one correct +way to complete the configuration context of these rules in order to +match the configuration declared above. In our case here, "correct way" +means that the k and env cells will be considered as +being part of the same thread cell, as opposed to each being part +of a different thread. Configuration abstraction is crucial for modularity, +because it gives us the possibility to write our definitions in a way that +may not require us to revisit existing rules when we change the configuration. +Changes in the configuration are quite frequent in practice, typically +needed in order to accommodate new language features. For example, +imagine that we initially did not have threads in IMP++. There +would be no need for the thread and threads cells in +the configuration then, the cells k and env being simply +placed at the top level in the T cell, together with the +already existing cells. Then the rules below would be exactly the +same. Thus, configuration abstraction allows you to not have to +modify your rules when you make structural changes in your language +configuration.

    +

    Below we list the semantics of the old IMP constructs, referring the +reader to the K semantics of IMP for their meaning. Like we tagged the +addition and the division rules above in the syntax, we also tag the lookup +and the assignment rules below (with tags lookup and +assignment), because we want to refer to them when we generate the +language model (with the kompile tool), basically to allow them to +generate (possibly non-deterministic) transitions. Indeed, these two rules, +unlike the other rules corresponding to old IMP constructs, can yield +non-deterministic behaviors when more threads are executed concurrently. +In terms of rewriting, these two rules can "compete" with each other on +some program configurations, in the sense that they can both match at the +same time and different behaviors may be obtained depending upon which of +them is chosen first.

    +
    k
    syntax KResult ::= Int | Bool +
    +

    Variable lookup

    +
    k
    rule <k> X:Id => I ...</k> + <env>... X |-> N ...</env> + <store>... N |-> I ...</store> [group(lookup)] +
    +

    Arithmetic constructs

    +
    k
    rule I1 / I2 => I1 /Int I2 when I2 =/=Int 0 + rule I1 + I2 => I1 +Int I2 + rule - I => 0 -Int I +
    +

    Boolean constructs

    +
    k
    rule I1 <= I2 => I1 <=Int I2 + rule ! T => notBool T + rule true && B => B + rule false && _ => false +
    +

    Variable assignment

    +

    Note that the old IMP assignment statement X = I; is now composed of two +constructs: an assignment expression construct X = I, followed by a +semicolon ; turning the expression into a statement. The rationale behind +this syntactic restructuring has been explained in Lesson 7. Here is the +semantics of the two constructs:

    +
    k
    rule _:Int; => . + rule <k> X = I:Int => I ...</k> + <env>... X |-> N ...</env> + <store>... N |-> (_ => I) ...</store> [group(assignment)] +
    +

    Sequential composition

    +

    Sequential composition has been defined as a whitespace-separated syntactic +list of statements. Recall that syntactic lists are actually syntactic +sugar for cons-lists. Therefore, the following two rules eventually +sequentialize a syntactic list of statements s1 s2 ... sn.. into the +corresponding computation s1 ~> s2 ~> ... ~> sn.

    +
    k
    rule .Stmts => . + rule S:Stmt Ss:Stmts => S ~> Ss +
    +

    Conditional statement

    +
    k
    rule if (true) S else _ => S + rule if (false) _ else S => S +
    +

    While loop

    +

    The only thing to notice here is that the empty block has been replaced +with the block holding the explicit empty sequence. That's because in +the semantics all empty lists become explicit corresponding dots +(to avoid parsing ambiguities)

    +
    k
    rule while (B) S => if (B) {S while (B) S} else {.Stmts} +
    +

    The new IMP++ constructs

    +

    We next discuss the semantics of the new IMP++ constructs.

    +

    Strings

    +

    First, we have to state that strings are also results. +Second, we give the semantics of IMP++ string concatenation (which +uses the already existing addition symbol + from IMP) by +reduction to the built-in string concatenation operation.

    +
    k
    syntax KResult ::= String + rule Str1 + Str2 => Str1 +String Str2 +
    +

    Variable increment

    +

    Like variable lookup, this is also meant to be a supercool transition: we +want it to count both in the non-determinism due to strict operations above +it in the computation and in the non-determinism due to thread +interleavings. This rule also relies on K's configuration abstraction. +Without abstraction, you would have to also include the thread and +threads cells.

    +
    k
    rule <k> ++X => I +Int 1 ...</k> + <env>... X |-> N ...</env> + <store>... N |-> (I => I +Int 1) ...</store> [group(increment)] +
    +

    Read

    +

    The read() construct evaluates to the first integer in the +input buffer, which it consumes. Note that this rule is tagged +increment. This is because we will include it in the set of +potentially non-deterministic transitions when we kompile the definition; +we want to do that because two or more threads can "compete" on +reading the next integer from the input buffer, and different choices +for the next transition can lead to different behaviors.

    +
    k
    rule <k> read() => I ...</k> + <input> ListItem(I:Int) => .List ...</input> [group(read)] +
    +

    Print

    +

    The print statement is strict, so all its arguments are +eventually evaluated (recall that print is variadic). We +append each of its evaluated arguments, in order, to the output buffer, +and structurally discard the residual print statement with an +empty list of arguments. We only want to allow printing integers and +strings, so we define a Printable syntactic category including +only these and define the print statement to only print +Printable elements. Alternatively, we could have had two +similar rules, one for integers and one for strings. Recall that, +currently, K's lists are cons-lists, so we cannot simply rewrite the +head of a list (P) into a list (.). The first rule below is tagged, +because we want to include it in the list of transitions when we kompile; +different threads may compete on the output buffer and we want to capture +all behaviors.

    +
    k
    syntax Printable ::= Int | String + +/* currently it is necessary to subsort Printable to AExp, + but future K should be able to infer that automatically. */ + syntax AExp ::= Printable + + context print(HOLE:AExp, _AEs:AExps); + + rule <k> print(P:Printable,AEs => AEs); ...</k> + <output>... .List => ListItem(P) </output> [group(print)] + rule print(.AExps); => . +
    +

    Halt

    +

    The halt statement empties the computation, so the rewriting process +simply terminates as if the program terminated normally. Interestingly, once +we add threads to the language, the halt statement as defined below +will terminate the current thread only. If you want an abrupt termination +statement that halts the entire program, then you need to discard the entire +contents of the threads cell, so the entire computation abruptly +terminates the entire program, no matter how many concurrent threads it has, +because there is nothing else to rewrite.

    +
    k
    rule <k> halt; ~> _ => . </k> +
    +

    Spawn thread

    +

    A spawned thread is passed its parent's environment at creation time. +The spawn expression in the parent thread is immediately +replaced by the unique identifier of the newly created thread, so the +parent thread can continue its execution. We only consider a sequentially +consistent shared memory model for IMP++, but other memory models can also +be defined in K; see, for example, the definition of KERNELC. Note that +the rule below does not need to be tagged in order to make it a transition +when we kompile, because the creation of the thread itself does not interfere +with the execution of other threads. Also, note that K's configuration +abstraction is at heavy work here, in two different places. First, the +parent thread's k and env cells are wrapped within a +thread cell. Second, the child thread's k, env +and id cells are also wrapped within a thread cell. Why +that way and not putting all these four cells together within the +same thread, or even create an additional threads cell at top +holding a thread cell with the new k, env +and id? Because in the original configuration we declared +the multiplicity of the thread cell to be *, which +effectively tells the K tool that zero, one or more such cells can +co-exist in a configuration at any moment. The other cells have the +default multiplicity one, so they are not allowed to multiply. +Thus, the only way to complete the rule below in a way consistent with +the declared configuration is to wrap the first two cells in a +thread cell, and the latter two cells under the . +also in a thread cell. Once the rule applies, the spawning +thread cell will add a new thread cell next to it, which is consistent +with the declared configuration cell multiplicity. The unique identifier +of the new thread is generated using the fresh side condition.

    +
    k
    rule <k> spawn S => !T:Int ...</k> <env> Rho </env> + (.Bag => <thread>... <k> S </k> <env> Rho </env> <id> !T </id> ...</thread>) +
    +

    Join thread

    +

    A thread who wants to join another thread T has to wait until +the computation of T becomes empty. When that happens, the +join statement is simply dissolved. The terminated thread is not removed, +because we want to allow possible other join statements to also dissolve.

    +
    k
    rule <k> join(T); => . ...</k> <thread>... <k>.</k> <id>T</id> ...</thread> +
    +

    Blocks

    +

    The body statement of a block is executed normally, making sure +that the environment at the block entry point is saved in the computation, +in order to be recovered after the block body statement. This step is +necessary because blocks can declare new variables having the same +name as variables which already exist in the environment, and our +semantics of variable declarations is to update the environment map in +the declared variable with a fresh location. Thus, variables which +are shadowed lose their original binding, which is why we take a +snapshot of the environment at block entrance and place it after the +block body (see the semantics of environment recovery at the end of +this module). Note that any store updates through variables which are +not declared locally are kept at the end of the block, since the store +is not saved/restored. An alternative to this environment save/restore +approach is to actually maintain a stack of environments and to push a +new layer at block entrance and pop it at block exit. The variable +lookup/assign/increment operations then also need to change, so we do +not prefer that non-modular approach. Compilers solve this problem by +statically renaming all local variables into fresh ones, to completely +eliminate shadowing and thus environment saving/restoring. The rule +below can be structural, because what it effectively does is to take a +snapshot of the current environment; this operation is arguably not a +computational step.

    +
    k
    rule <k> {Ss} => Ss ~> Rho ...</k> <env> Rho </env> +
    +

    Variable declaration

    +

    We allocate a fresh location for each newly declared variable and +initialize it with 0.

    +
    k
    rule <k> int (X,Xs => Xs); ...</k> + <env> Rho => Rho[X <- !N:Int] </env> + <store>... .Map => !N |-> 0 ...</store> + rule int .Ids; => . +
    +

    Auxiliary operations

    +

    We only have one auxiliary operation in IMP++, the environment +recovery. Its role is to discard the current environment in the +env cell and replace it with the environment that it holds. +This rule is structural: we do not want them to count as computational +steps in the transition system of a program.

    +
    k
    rule <k> Rho => . ...</k> <env> _ => Rho </env> +
    +

    If you want to avoid useless environment recovery steps and keep the size +of the computation structure smaller, then you can also add the rule

    +
      rule (_:Map => .) ~> _:Map
    +
    +

    This rule acts like a ``tail recursion'' optimization, but for blocks. */

    +
    k
    // verification ids + syntax Id ::= "n" [token] + | "sum" [token] + | "a" [token] + | "b" [token] + | "c" [token] +endmodule +
    +

    On Kompilation Options

    +

    We are done with the IMP++ semantics. The next step is to kompile the +definition using the kompile tool, this way generating a language +model. Depending upon for what you want to use the generated language model, +you may need to kompile the definition using various options. We here discuss +these options.

    +

    To tell the K tool to exhaustively explore all the behaviors due to the +non-determinism of addition, division, and threads, we have to kompile +with the command:

    +
    shell
    kompile imp.k --transition="addition division lookup assignment increment read print" +
    +

    As already mentioned, the syntax and rule tags play no theoretical or +foundational role in K. They are only a means to allow kompile to +refer to them in its options, like we did above. By default, kompile's +transition option is empty, because this yields the fastest language model when +executed. Transitions may slow down the execution, but they instrument +the language model to allow for formal analysis of program behaviors, even for +exhaustive analysis.

    +

    Theoretically, the heating/cooling rules in K are fully reversible and +unconstrained by side conditions as we showed in the semantics of IMP. +For example, the theoretical heating/cooling rules corresponding to the +strict attribute of division are the following:

    +
    E₁ / E₂ ⇒ E₁ ⤳ □ / E₂
    +E₁ ⤳ □ / E₂ ⇒ E₁ / E₂
    +E₁ / E₂ ⇒ E₂ ⤳ E₁ / □
    +E₂ ⤳ E₁ / □ ⇒ E₁ / E₂
    +
    +

    The other semantic rules apply modulo such structural rules. +For example, using heating rules we can bring a redex (a subterm which +can be reduced with semantic rules) to the front of the computation, +then reduce it, then use cooling rules to reconstruct a term over the +original syntax of the language, then heat again and +non-deterministically pick another redex, and so on and so forth +without losing any opportunities to apply semantic rules. +Nevertheless, these unrestricted heating/cooling rules may create an +immense, often unfeasibly large space of possibilities to analyze. +The --transition option implements an optimization which works +well with other implementation choices made in the current K tool. +Recall from the detailed description of the IMP language semantics that +(theoretical) reversible rules like above are restricted by default +to complementary conditional rules of the form

    +
    E₁ / E₂ ⇒ E₁ ⤳ □ / E₂
    +   if E₁ not in KResult
    +E₁ ⤳ □ / E₂ ⇒ E₁ / E₂
    +   if E₁ in KResult
    +E₁ / E₂ ⇒ E₂ ⤳ E₁ / □
    +   if E₂ not in KResult
    +E₂ ⤳ E₁ / □  ⇒ E₁ / E₂
    +   if  E₂ in KResult
    +
    +

    Therefore, our tool eagerly heats and lazily cools the computation. +In other words, heating rules apply until a redex gets placed on the +top of the computation, then some semantic rule applies and rewrites +that into a result, then a cooling rule is applied to plug the +obtained result back into its context, then another argument may be +chosen and completely heated, and so on. This leads to efficient +execution, but it may and typically does hide program behaviors. +Using the --transition option allows you to interfere with this +process and to obtain all possible non-deterministic behaviors as if +the theoretical heating/cooling rules were applied. Optimizations +of course happen under the hood, but you need not be aware of them. +Used carefully, this mechanism allows us to efficiently explore more of +the non-deterministic behaviors of a program, even all of them (like here). +For example, with the semantics of IMP++ given above, the krun +command with the --search option detects all five behaviors +of the following IMP++ program (x can be 0, 1, 2, 3, or undefined +due to division-by-zero):

    +
      int x,y;
    +  x = 1;
    +  y = ++x / (++x / x);
    +
    +

    Besides non-determinism due to underspecified argument evaluation +orders, which the current K tool addresses as explained above, there +is another important source of non-determinism in programming languages: +non-determinism due to concurrency/parallelism. For example, when two +or more threads are about to access the same location in the store and at +least one of these accesses is a write (i.e., an instance of the variable +assignment rule), there is a high chance that different choices for +the next transition lead to different program behaviors. While in the +theory of K all the rules count as computational steps +and hereby as transitions in the transition system associated to the +program, in practice that may yield a tremendous number of step +interleavings to consider. Most of these interleavings are behaviorally +equivalent for most purposes. For example, the fact that a thread computes +a step 8+3 ⇒ 11 is likely irrelevant for the other +threads, so one may not want to consider it as an observable transition in +the space of interleavings. Since the K tool cannot know without help which +transitions need to be explored and which do not, our approach is to +let the user say so explicitly using the transition option of +kompile.

    +
    +
    + + +
    + + + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/tests/regression-new/kprove-markdown/set-balance-spec/index.html b/k-distribution/tests/regression-new/kprove-markdown/set-balance-spec/index.html new file mode 100644 index 00000000000..dec561d9254 --- /dev/null +++ b/k-distribution/tests/regression-new/kprove-markdown/set-balance-spec/index.html @@ -0,0 +1,433 @@ + + + + + + + + + + + + + + +Balances Module Specifications | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Balances Module Specifications

    +
    keep
    module SET-BALANCE-SPEC + imports VERIFICATION +
    +
    k
    ignore thie code block! +
    +

    total_balance tests

    +
    keep
    claim <k> totalBalance(AID) => 50 </k> + <account> + <accountID> AID </accountID> + <freeBalance> 30 </freeBalance> + <reservedBalance> 20 </reservedBalance> + ... + </account> +
    +

    No Zero-Balance Accounts Exist

    +

    This property shows that set_balance will not result in a zero-balance attack. +TODO: Generalize to any EntryAction. +TODO: Assertions about log events.

    +
    discard
    rule <k> set_balance(Root, WHO, FREE_BALANCE', RESERVED_BALANCE') => . ... </k> + <totalIssuance> TOTAL_ISSUANCE => TOTAL_ISSUANCE +Int ( FREE_BALANCE' -Int FREE_BALANCE ) +Int ( RESERVED_BALANCE' -Int RESERVED_BALANCE ) </totalIssuance> + <existentialDeposit> EXISTENTIAL_DEPOSIT </existentialDeposit> + <account> + <accountID> WHO </accountID> + <freeBalance> FREE_BALANCE => FREE_BALANCE' </freeBalance> + <reservedBalance> RESERVED_BALANCE => RESERVED_BALANCE' </reservedBalance> + ... + </account> + requires #inWidth(96, TOTAL_ISSUANCE +Int (FREE_BALANCE' -Int FREE_BALANCE)) + andBool #inWidth(96, TOTAL_ISSUANCE +Int (FREE_BALANCE' -Int FREE_BALANCE) +Int (RESERVED_BALANCE' -Int RESERVED_BALANCE)) + andBool EXISTENTIAL_DEPOSIT <=Int FREE_BALANCE' + andBool EXISTENTIAL_DEPOSIT <=Int RESERVED_BALANCE' +
    +
    keep
    claim <k> set_balance_reserved ( WHO , RESERVED_BALANCE' ) => . ... </k> + <existentialDeposit> EXISTENTIAL_DEPOSIT </existentialDeposit> + <totalIssuance> TOTAL_ISSUANCE +Int ( FREE_BALANCE' -Int FREE_BALANCE ) => TOTAL_ISSUANCE +Int ( FREE_BALANCE' -Int FREE_BALANCE ) +Int ( RESERVED_BALANCE' -Int RESERVED_BALANCE ) </totalIssuance> + <account> + <accountID> WHO </accountID> + <freeBalance> FREE_BALANCE' </freeBalance> + <reservedBalance> RESERVED_BALANCE => RESERVED_BALANCE' </reservedBalance> + ... + </account> + requires #inWidth(96, TOTAL_ISSUANCE +Int (FREE_BALANCE' -Int FREE_BALANCE) +Int (RESERVED_BALANCE' -Int RESERVED_BALANCE)) + andBool EXISTENTIAL_DEPOSIT <=Int RESERVED_BALANCE' +
    +
    keep
    endmodule +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/tests/regression-new/kprove-markdown/set-balance/index.html b/k-distribution/tests/regression-new/kprove-markdown/set-balance/index.html new file mode 100644 index 00000000000..a0aaa48dfd6 --- /dev/null +++ b/k-distribution/tests/regression-new/kprove-markdown/set-balance/index.html @@ -0,0 +1,1227 @@ + + + + + + + + + + + + + + +set_balance spec | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    set_balance spec

    +

    State Model

    +
    k
    +module SET-BALANCE + imports INT + imports DOMAINS + imports COLLECTIONS + + configuration + <set-balance> + <k> $ACTION:Action </k> + <now> 0 </now> + <events> .List </events> + <return-value> .Result </return-value> + <call-stack> .List </call-stack> + <existentialDeposit> 0 </existentialDeposit> + <creationFee> 0 </creationFee> + <transferFee> 0 </transferFee> + <totalIssuance> 0 </totalIssuance> + <accounts> + <account multiplicity="*" type="Map"> + <accountID> .AccountId:AccountId </accountID> + <freeBalance> 0 </freeBalance> + <reservedBalance> 0 </reservedBalance> + <vestingBalance> 0 </vestingBalance> + <startingBlock> 0 </startingBlock> + <perBlock> 0 </perBlock> + <nonce> .Nonce </nonce> + <locks> .Set </locks> + </account> + </accounts> + </set-balance> +
    +

    Data

    +
      +
    • An AccountId is an Int.
    • +
    • An Origin is an AccountId, Root, or None.
    • +
    • A Nonce is an optional Int.
    • +
    • An Event records some happenning.
    • +
    +
    k
    syntax AccountId ::= ".AccountId" | Int + // --------------------------------------- + + syntax Origin ::= AccountId | ".Root" | ".None" + // ----------------------------------------------- + + syntax Nonce ::= ".Nonce" | Int + // ------------------------------- + + syntax Event ::= DustEvent ( Int ) + // ---------------------------------- +
    +

    Some predicates which help specifying behavior:

    +
      +
    • #inWidth: Specify that a given number is in some bitwidth.
    • +
    +
    k
    syntax Bool ::= #inWidth(Int, Int) [function, total] + // --------------------------------------------------------- + rule #inWidth(N, M) => 0 <=Int M andBool M <Int (2 ^Int N) +
    +

    Results

    +

    A Result is the return value of an execution step.

    +
      +
    • AccountKilled indicates that the free balance goes below the existential threshold.
    • +
    • Updated indicates that an account was updated successfully.
    • +
    +
    k
    syntax Result ::= ".Result" | "AccountKilled" | "Updated" + // --------------------------------------------------------- +
    +

    Public Getters

    +

    total_balance

    +

    Retrieves the total balance of an account. This includes both the free and +reserved balances.

    +
    k
    syntax Int ::= "total_balance" "(" AccountId ")" [function, total] + // ----------------------------------------------------------------------- + rule total_balance(WHO) => free_balance(WHO) +Int reserved_balance(WHO) +
    +

    free_balance

    +

    Gets the free balance of an account.

    +

    Other than when this module is executing, this will never be strictly between +EXISTENTIAL_DEPOSIT and zero.

    +
    k
    syntax Int ::= "free_balance" "(" AccountId ")" [function, total] + // ---------------------------------------------------------------------- + rule free_balance(_) => 0 [owise] + rule [[ free_balance(WHO) => FREE_BALANCE ]] + <account> + <accountID> WHO </accountID> + <freeBalance> FREE_BALANCE </freeBalance> + ... + </account> +
    +

    reserved_balance

    +

    Gets the reserved balance of an account.

    +

    Other than when this module is executing, this will never be strictly between +EXISTENTIAL_DEPOSIT and zero.

    +
    k
    syntax Int ::= "reserved_balance" "(" AccountId ")" [function, total] + // -------------------------------------------------------------------------- + rule reserved_balance(_) => 0 [owise] + rule [[ reserved_balance(WHO) => FREE_BALANCE ]] + <account> + <accountID> WHO </accountID> + <reservedBalance> FREE_BALANCE </reservedBalance> + ... + </account> +
    +

    can_slash

    +

    Determines if an account’s free balance is over the value provided. This is +often used to determine if an account has enough balance to cover a potential +slash, hence the name.

    +
    k
    syntax Bool ::= "can_slash" "(" AccountId "," Int ")" [function, total] + // ---------------------------------------------------------------------------- + rule can_slash(_, _) => false + rule [[ can_slash(WHO, AMOUNT) => FREE_BALANCE >=Int AMOUNT ]] + <account> + <accountID> WHO </accountID> + <freeBalance> FREE_BALANCE </freeBalance> + ... + </account> +
    +

    total_issuance

    +

    Retrieves the total outstanding amount of currency outstanding. This will +always be equal to the sum of all free and reserved balances in all active +accounts, except when the balances module is executing.

    +
    k
    syntax Int ::= "total_issuance" [function, total] + // ------------------------------------------------------ + rule [[ total_issuance => TOTAL_ISSUANCE ]] + <totalIssuance> TOTAL_ISSUANCE </totalIssuance> +
    +

    issue

    +

    Issues currency, creating an imbalance.

    +

    This is not specified, since these semantics do not include the concept of an +imbalance. Without the concept of destructors and move semantics, it would be +almost impossible to use correctly.

    +

    burn

    +

    Burns currency.

    +

    This is not part of the semantics for the same reason burn is not.

    +

    Actions and Results

    +

    An Action is an execution step (or the result of an execution step). +An EntryAction is an Action that can be invoked externally. +A Result is considered an Action, as is an EntryAction.

    +
    k
    syntax Action ::= Result | EntryAction + // -------------------------------------- +
    +

    account_exists

    +
    k
    syntax Bool ::= "account_exists" "(" AccountId ")" [function, total] + // ------------------------------------------------------------------------- + rule account_exists(_) => false [owise] + rule [[ account_exists(WHO) => true ]] + <account> <accountID> WHO </accountID> ... </account> +
    +

    create_account

    +
    k
    syntax Action ::= "create_account" "(" AccountId ")" + // ---------------------------------------------------- + rule <k> create_account(WHO) => . ... </k> + <accounts> ( .Bag => <account> <accountID> WHO </accountID> ... </account> ) ... </accounts> +
    +

    set_free_balance

    +
      +
    • Updates an accounts balance if the new balance is above the existential threshold.
    • +
    • Kills the account if the balance goes below the existential threshold and the reserved balance is non-zero.
    • +
    • Reaps the account if the balance goes below the existential threshold and the reserved balance is zero.
    • +
    +
    k
    syntax Action ::= "set_free_balance" "(" AccountId "," Int ")" + // -------------------------------------------------------------- + rule <k> (. => create_account(WHO)) ~> set_free_balance(WHO, _) ... </k> + requires notBool account_exists(WHO) + + rule [free-account-updated]: + <k> set_free_balance(WHO, BALANCE) => . ... </k> + <existentialDeposit> EXISTENTIAL_DEPOSIT </existentialDeposit> + <account> + <accountID> WHO </accountID> + <freeBalance> _ => BALANCE </freeBalance> + ... + </account> + requires EXISTENTIAL_DEPOSIT <=Int BALANCE + + rule [free-account-killed]: + <k> set_free_balance(WHO, BALANCE) => . ... </k> + <events> ... (.List => ListItem(DustEvent(FREE_BALANCE))) </events> + <existentialDeposit> EXISTENTIAL_DEPOSIT </existentialDeposit> + <totalIssuance> TOTAL_ISSUANCE => TOTAL_ISSUANCE -Int BALANCE </totalIssuance> + <account> + <accountID> WHO </accountID> + <nonce> _ => .Nonce </nonce> + <freeBalance> FREE_BALANCE => 0 </freeBalance> + <reservedBalance> RESERVED_BALANCE </reservedBalance> + ... + </account> + requires BALANCE <Int EXISTENTIAL_DEPOSIT + andBool 0 <Int RESERVED_BALANCE + + rule [free-account-reaped]: + <k> set_free_balance(WHO, BALANCE) => . ... </k> + <events> ... (.List => ListItem(DustEvent(FREE_BALANCE))) </events> + <existentialDeposit> EXISTENTIAL_DEPOSIT </existentialDeposit> + <totalIssuance> TOTAL_ISSUANCE => TOTAL_ISSUANCE -Int BALANCE </totalIssuance> + <accounts> + ( <account> + <accountID> WHO </accountID> + <freeBalance> FREE_BALANCE </freeBalance> + <reservedBalance> 0 </reservedBalance> + ... + </account> + => .Bag + ) + ... + </accounts> + requires BALANCE <Int EXISTENTIAL_DEPOSIT +
    +

    set_reserved_balance

    +
      +
    • Updates an accounts balance if the new balance is above the existential threshold.
    • +
    • Kills the account if the balance goes below the existential threshold and the free balance is non-zero.
    • +
    • Reaps the account if the balance goes below the existential threshold and the free balance is zero.
    • +
    +
    k
    syntax Action ::= "set_reserved_balance" "(" AccountId "," Int ")" + // ------------------------------------------------------------------ + rule <k> (. => create_account(WHO)) ~> set_reserved_balance(WHO, _) ... </k> + requires notBool account_exists(WHO) + + rule [reserved-account-updated]: + <k> set_reserved_balance(WHO, BALANCE) => . ... </k> + <existentialDeposit> EXISTENTIAL_DEPOSIT </existentialDeposit> + <account> + <accountID> WHO </accountID> + <reservedBalance> _ => BALANCE </reservedBalance> + ... + </account> + requires EXISTENTIAL_DEPOSIT <=Int BALANCE + + rule [reserved-account-killed]: + <k> set_reserved_balance(WHO, BALANCE) => . ... </k> + <events> ... (.List => ListItem(DustEvent(RESERVED_BALANCE))) </events> + <existentialDeposit> EXISTENTIAL_DEPOSIT </existentialDeposit> + <totalIssuance> TOTAL_ISSUANCE => TOTAL_ISSUANCE -Int BALANCE </totalIssuance> + <account> + <accountID> WHO </accountID> + <nonce> _ => .Nonce </nonce> + <freeBalance> FREE_BALANCE </freeBalance> + <reservedBalance> RESERVED_BALANCE => 0 </reservedBalance> + ... + </account> + requires BALANCE <Int EXISTENTIAL_DEPOSIT + andBool 0 <Int FREE_BALANCE + + rule [reserved-account-reaped]: + <k> set_reserved_balance(WHO, BALANCE) => . ... </k> + <events> ... (.List => ListItem(DustEvent(RESERVED_BALANCE))) </events> + <existentialDeposit> EXISTENTIAL_DEPOSIT </existentialDeposit> + <totalIssuance> TOTAL_ISSUANCE => TOTAL_ISSUANCE -Int BALANCE </totalIssuance> + <accounts> + ( <account> + <accountID> WHO </accountID> + <freeBalance> 0 </freeBalance> + <reservedBalance> RESERVED_BALANCE </reservedBalance> + ... + </account> + => .Bag + ) + ... + </accounts> + requires BALANCE <Int EXISTENTIAL_DEPOSIT +
    +

    set_balance

    +
      +
    • Sets the new free balance
    • +
    • Creates suitible imbalances (both positive and negative).
    • +
    • Calls set_free_balance with the new free balance.
    • +
    • Calls set_reserved_balance with the new reserved balance.
    • +
    +
    k
    syntax EntryAction ::= "set_balance" "(" AccountId "," AccountId "," Int "," Int ")" + // ------------------------------------------------------------------------------------ + rule [balance-set]: + <k> set_balance(_, WHO, FREE_BALANCE, RESERVED_BALANCE) + => set_balance_free(WHO, FREE_BALANCE) + ~> set_balance_reserved(WHO, RESERVED_BALANCE) + ... + </k> +
    +

    Helpers for calling set_free_balance and set_reserved_balance.

    +
      +
    • Sets the new free balance
    • +
    • Emits an imbalance event
    • +
    • Helper function for set_balance
    • +
    +
    k
    syntax Action ::= "set_balance_free" "(" AccountId "," Int ")" + syntax Action ::= "set_balance_reserved" "(" AccountId "," Int ")" + // ------------------------------------------------------------------ + rule [balance-set-free]: + <k> set_balance_free(WHO, FREE_BALANCE') => set_free_balance(WHO, FREE_BALANCE') ... </k> + <totalIssuance> ISSUANCE => ISSUANCE +Int (FREE_BALANCE' -Int free_balance(WHO)) </totalIssuance> + requires #inWidth(96, ISSUANCE +Int (FREE_BALANCE' -Int free_balance(WHO))) + + rule [balance-set-reserved]: + <k> set_balance_reserved(WHO, RESERVED_BALANCE') => set_reserved_balance(WHO, RESERVED_BALANCE') ... </k> + <totalIssuance> ISSUANCE => ISSUANCE +Int (RESERVED_BALANCE' -Int reserved_balance(WHO)) </totalIssuance> + requires #inWidth(96, ISSUANCE +Int (RESERVED_BALANCE' -Int reserved_balance(WHO))) +
    +

    transfer_raw

    +

    Transfer some liquid free balance to another account.

    +

    transfer will set the FreeBalance of the sender and receiver. +It will decrease the total issuance of the system by the TransferFee. +If the sender's account is below the existential deposit as a result +of the transfer, the account will be reaped.

    +

    The dispatch origin for this call must be Signed by the transactor.

    +
    k
    syntax ExistenceRequirement ::= "AllowDeath" + | "KeepAlive" + + syntax EntryAction ::= transfer(Origin, AccountId, Int) + | "transfer_keep_alive" "(" Origin "," AccountId "," Int ")" + // --------------------------------------------------------------------------------- + + syntax Action ::= rawTransfer(AccountId, AccountId, Int, ExistenceRequirement) + // ------------------------------------------------------------------------------ + rule [transfer-to-raw]: + <k> transfer(ORIGIN:AccountId, DESTINATION, AMOUNT) + => rawTransfer(ORIGIN, DESTINATION, AMOUNT, AllowDeath) + ... + </k> + + rule [transfer-keep-alive]: + <k> transfer_keep_alive(ORIGIN:AccountId, DESTINATION, AMOUNT) + => rawTransfer(ORIGIN, DESTINATION, AMOUNT, KeepAlive) + ... + </k> + + rule <k> (. => create_account(DESTINATION)) ~> rawTransfer(ORIGIN, DESTINATION, _, _) ... </k> + requires account_exists(ORIGIN) + andBool notBool account_exists(DESTINATION) + + rule [transfer-self]: + <k> rawTransfer(ORIGIN:AccountId, ORIGIN, _, _) => . ... </k> + requires account_exists(ORIGIN) + + rule [transfer-existing-account]: + <k> rawTransfer(ORIGIN, DESTINATION, AMOUNT, EXISTENCE_REQUIREMENT) + => set_free_balance(ORIGIN, SOURCE_BALANCE -Int AMOUNT -Int FEE) + ~> set_free_balance(DESTINATION, DESTINATION_BALANCE +Int AMOUNT) + ... + </k> + <totalIssuance> ISSUANCE => ISSUANCE -Int FEE </totalIssuance> + <existentialDeposit> EXISTENTIAL_DEPOSIT </existentialDeposit> + <transferFee> FEE </transferFee> + <accounts> + <account> + <accountID> ORIGIN </accountID> + <freeBalance> SOURCE_BALANCE </freeBalance> + ... + </account> + <account> + <accountID> DESTINATION </accountID> + <freeBalance> DESTINATION_BALANCE </freeBalance> + ... + </account> + </accounts> + requires ORIGIN =/=K DESTINATION + andBool DESTINATION_BALANCE >Int 0 + andBool SOURCE_BALANCE >=Int (AMOUNT +Int FEE) + andBool ensure_can_withdraw(ORIGIN, Transfer, SOURCE_BALANCE -Int AMOUNT -Int FEE) + andBool (EXISTENCE_REQUIREMENT ==K AllowDeath orBool SOURCE_BALANCE -Int AMOUNT -Int FEE >Int EXISTENTIAL_DEPOSIT) + + rule [transfer-create-account]: + <k> rawTransfer(ORIGIN:AccountId, DESTINATION, AMOUNT, EXISTENCE_REQUIREMENT) + => set_free_balance(ORIGIN, SOURCE_BALANCE -Int AMOUNT -Int CREATION_FEE) + ~> set_free_balance(DESTINATION, AMOUNT) + ... + </k> + <totalIssuance> ISSUANCE => ISSUANCE -Int CREATION_FEE </totalIssuance> + <existentialDeposit> EXISTENTIAL_DEPOSIT </existentialDeposit> + <creationFee> CREATION_FEE </creationFee> + <accounts> + <account> + <accountID> ORIGIN </accountID> + <freeBalance> SOURCE_BALANCE </freeBalance> + ... + </account> + <account> + <accountID> DESTINATION </accountID> + <freeBalance> 0 </freeBalance> + <reservedBalance> 0 </reservedBalance> + ... + </account> + ... + </accounts> + requires ORIGIN =/=K DESTINATION + andBool SOURCE_BALANCE >=Int (AMOUNT +Int CREATION_FEE) + andBool EXISTENTIAL_DEPOSIT <=Int AMOUNT + andBool ensure_can_withdraw(ORIGIN, Transfer, SOURCE_BALANCE -Int AMOUNT -Int CREATION_FEE) + andBool (EXISTENCE_REQUIREMENT ==K AllowDeath orBool SOURCE_BALANCE -Int AMOUNT -Int CREATION_FEE >=Int EXISTENTIAL_DEPOSIT) +
    +

    force_transfer

    +

    Force a transfer from any account to any other account. This can only be done by root.

    +
    k
    syntax EntryAction ::= "force_transfer" "(" Origin "," AccountId "," AccountId "," Int ")" + // ------------------------------------------------------------------------------------------ + rule [force-transfer]: + <k> force_transfer(.Root, SOURCE, DESTINATION, AMOUNT) => transfer(SOURCE, DESTINATION, AMOUNT) ... </k> +
    +

    withdraw

    +

    Withdraw funds from an account.

    +
    k
    syntax EntryAction ::= withdraw(AccountId, Int, WithdrawReason, ExistenceRequirement) + // ------------------------------------------------------------------------------------- + rule [withdraw]: // K really needs where clauses + <k> withdraw(WHO, AMOUNT, REASON, EXISTENCE_REQUIREMENT) + => withdrawInner(WHO, AMOUNT, AMOUNT -Int free_balance(WHO), REASON, EXISTENCE_REQUIREMENT) + ... + </k> + + syntax Action ::= withdrawInner(AccountId, Int, Int, WithdrawReason, ExistenceRequirement) + // ------------------------------------------------------------------------------------------ + rule [withdrawInner]: + <k> withdrawInner(WHO, AMOUNT, NEW_BALANCE, REASON, EXISTENCE_REQUIREMENT) + => set_free_balance(WHO, NEW_BALANCE) + ... + </k> + <totalIssuance> ISSUANCE => ISSUANCE -Int AMOUNT </totalIssuance> + <existentialDeposit> EXISTENTIAL_DEPOSIT </existentialDeposit> + requires NEW_BALANCE >=Int 0 + andBool ensure_can_withdraw(WHO, REASON, NEW_BALANCE) + andBool (EXISTENCE_REQUIREMENT ==K AllowDeath orBool NEW_BALANCE >=Int EXISTENTIAL_DEPOSIT) +
    +

    Call Frames

    +

    Function call and return.

    +
    k
    syntax CallFrame ::= frame(continuation: K) + syntax Action ::= call ( Action ) + | return ( Result ) + // ----------------------------------- + rule [call]: + <k> call(Action) ~> CONT => Action </k> + <call-stack> .List => ListItem(frame(CONT)) ... </call-stack> + + rule [return]: + <k> return(R) ~> _ => CONT </k> + <return-value> _ => R </return-value> + <call-stack> ListItem(frame(CONT)) => .List ... </call-stack> + + rule [return-unit]: + <k> . => CONT </k> + <return-value> _ => .Result </return-value> + <call-stack> ListItem(frame(CONT)) => .List ... </call-stack> +
    +

    Ensure that a given amount can be withdrawn from an account.

    +

    FIXME: we do not account for multiple withdrawl reasons, due to K’s +lacking polymorphism.

    +
    k
    syntax WithdrawReason ::= "TransactionPayment" + | "Transfer" + | "Reserve" + | "Fee" + | "Tip" + // ------------------------------- + + + syntax Bool ::= "ensure_can_withdraw" "(" AccountId "," WithdrawReason "," Int ")" [function, total] + // --------------------------------------------------------------------------------------------------------- + rule ensure_can_withdraw(_, _, _) => true [owise] + + rule [[ ensure_can_withdraw(WHO, Transfer #Or Reserve, BALANCE) => false ]] + <account> + <accountID> WHO </accountID> + <vestingBalance> VESTING_BALANCE </vestingBalance> + ... + </account> + requires VESTING_BALANCE <Int BALANCE + + rule [[ ensure_can_withdraw(WHO, REASON, BALANCE) => false ]] + <now> NOW </now> + <account> + <accountID> WHO </accountID> + <locks> ACCOUNT_LOCKS </locks> + ... + </account> + requires activeLocks(ACCOUNT_LOCKS, NOW, REASON, BALANCE) + + syntax LockID ::= "Election" + | "Staking" + | "Democracy" + | "Phragmen" + // ---------------------------- + + syntax AccountLock ::= lock ( id: LockID, until: Int, amount: Int, reasons: Set ) + // --------------------------------------------------------------------------------- + + syntax Bool ::= activeLock (AccountLock, Int, WithdrawReason, Int ) [function] + | activeLocks(Set, Int, WithdrawReason, Int ) [function] + | activeLocks(List, Int, WithdrawReason, Int, Bool) [function, klabel(activeLocksAux)] + // ----------------------------------------------------------------------------------------------------------- + rule activeLock(AL, NOW, REASON, BALANCE) => NOW <Int until(AL) andBool BALANCE <Int amount(AL) andBool REASON in reasons(AL) + + rule activeLocks(ALS, NOW, REASON, BALANCE) => activeLocks(Set2List(ALS), NOW, REASON, BALANCE, false) + + rule activeLocks(.List, _, _, _, RESULT) => RESULT + rule activeLocks((ListItem(AL) => .List) _, NOW, REASON, BALANCE, RESULT => RESULT orBool activeLock(AL, NOW, REASON, BALANCE)) +
    +

    Slashing and repatriation of reserved balances

    +

    The first of these is also used by slash.

    +
      +
    • slash_reserved
    • +
    • repatriate_reserved
    • +
    +
    k
    syntax Action ::= "slash_reserved" "(" AccountId "," Int ")" + // ------------------------------------------------------------ + rule [slash-reserved]: + <k> slash_reserved(ACCOUNT, AMOUNT) + => set_reserved_balance(ACCOUNT, maxInt(0, RESERVED_BALANCE -Int AMOUNT)) + ... + </k> + <accounts> + <account> + <accountID> ACCOUNT </accountID> + <reservedBalance> RESERVED_BALANCE </reservedBalance> + ... + </account> + </accounts> + <totalIssuance> TOTAL_ISSUANCE => TOTAL_ISSUANCE -Int minInt(RESERVED_BALANCE, AMOUNT) </totalIssuance> + + syntax Action ::= "repatriate_reserved" "(" AccountId "," AccountId "," Int ")" + // ------------------------------------------------------------------------------- + rule [repatriate-reserved]: + <k> repatriate_reserved(SLASHED, BENEFICIARY, AMOUNT) + => set_free_balance(BENEFICIARY, BENEFICIARY_FREE_BALANCE +Int minInt(SLASHED_RESERVED_BALANCE, AMOUNT)) + ~> set_reserved_balance(SLASHED, SLASHED_RESERVED_BALANCE -Int minInt(SLASHED_RESERVED_BALANCE, AMOUNT)) + ... + </k> + <accounts> + <account> + <accountID> SLASHED </accountID> + <reservedBalance> SLASHED_RESERVED_BALANCE </reservedBalance> + ... + </account> + <account> + <accountID> BENEFICIARY </accountID> + <reservedBalance> BENEFICIARY_RESERVED_BALANCE </reservedBalance> + <freeBalance> BENEFICIARY_FREE_BALANCE </freeBalance> + ... + </account> + </accounts> + requires BENEFICIARY_FREE_BALANCE +Int BENEFICIARY_RESERVED_BALANCE >Int 0 + andBool SLASHED =/=K BENEFICIARY + + rule [repatriate-reserved-same-account]: + <k> repatriate_reserved(SLASHED, SLASHED, AMOUNT) => unreserve(SLASHED, AMOUNT) ... </k> +
    +

    Slashing

    +

    Used to punish a node for violating the protocol.

    +
    k
    syntax EntryAction ::= slash ( AccountId , Int ) + // ------------------------------------------------ + rule [slash]: + <k> slash(ACCOUNT, AMOUNT) => set_free_balance(ACCOUNT, FREE_BALANCE -Int AMOUNT) ... </k> + <accounts> + <account> + <accountID> ACCOUNT </accountID> + <freeBalance> FREE_BALANCE </freeBalance> + ... + </account> + </accounts> + <totalIssuance> TOTAL_ISSUANCE => TOTAL_ISSUANCE -Int AMOUNT </totalIssuance> + requires FREE_BALANCE >=Int AMOUNT + + rule [slash-empty-free]: + <k> slash(ACCOUNT, AMOUNT) + => set_free_balance(ACCOUNT, 0) + ~> slash_reserved(ACCOUNT, AMOUNT -Int FREE_BALANCE) + ... + </k> + <accounts> + <account> + <accountID> ACCOUNT </accountID> + <freeBalance> FREE_BALANCE </freeBalance> + ... + </account> + </accounts> + <totalIssuance> TOTAL_ISSUANCE => TOTAL_ISSUANCE -Int FREE_BALANCE </totalIssuance> + requires FREE_BALANCE <Int AMOUNT +
    +

    Reservation and unreservation of balances

    +

    Used to move balance from free to reserved and visa versa.

    +
    k
    syntax Action ::= reserve ( AccountId , Int ) + // --------------------------------------------- + rule [reserve]: + <k> reserve(ACCOUNT, AMOUNT) + => set_reserved_balance(ACCOUNT, FREE_BALANCE +Int AMOUNT) + ~> set_free_balance(ACCOUNT, FREE_BALANCE -Int AMOUNT) + ... + </k> + <accounts> + <account> + <accountID> ACCOUNT </accountID> + <freeBalance> FREE_BALANCE </freeBalance> + <reservedBalance> _ </reservedBalance> + ... + </account> + </accounts> + requires FREE_BALANCE >=Int AMOUNT + andBool ensure_can_withdraw(ACCOUNT, Reserve, FREE_BALANCE -Int AMOUNT) + + syntax Action ::= unreserve ( AccountId , Int ) + // ----------------------------------------------- + rule [unreserve]: + <k> unreserve(ACCOUNT, AMOUNT) + => set_free_balance(ACCOUNT, FREE_BALANCE +Int minInt(AMOUNT, RESERVED_BALANCE)) + ~> set_reserved_balance(ACCOUNT, FREE_BALANCE -Int minInt(AMOUNT, RESERVED_BALANCE)) + ... + </k> + <accounts> + <account> + <accountID> ACCOUNT </accountID> + <freeBalance> FREE_BALANCE </freeBalance> + <reservedBalance> RESERVED_BALANCE </reservedBalance> + ... + </account> + </accounts> +
    +

    Vesting

    +
      +
    • locked_at ― amount currently locked
    • +
    • vesting_balance ― get the balance that cannot currently be withdrawn.
    • +
    +
    k
    syntax Int ::= "locked_at" "(" AccountId ")" [function, total] + // ------------------------------------------------------------------- + rule [[ locked_at(WHO) => maxInt(0, VESTING_BALANCE -Int (PER_BLOCK *Int maxInt(0, NOW -Int STARTING_BLOCK))) ]] + <now> NOW </now> + <account> + <accountID> WHO </accountID> + <vestingBalance> VESTING_BALANCE </vestingBalance> + <startingBlock> STARTING_BLOCK </startingBlock> + <perBlock> PER_BLOCK </perBlock> + ... + </account> + + syntax Int ::= "vesting_balance" "(" AccountId ")" [function, total] + // ------------------------------------------------------------------------- + rule [[ vesting_balance(WHO) => minInt(FREE_BALANCE, locked_at(WHO)) ]] + <account> + <accountID> WHO </accountID> + <freeBalance> FREE_BALANCE </freeBalance> + ... + </account> +
    +

    Deposits

    +

    Deposit into an existing account.

    +
    k
    syntax EntryAction ::= "deposit_into_existing" "(" AccountId "," Int ")" + // ------------------------------------------------------------------------ + rule [deposit-into-existing]: + <k> deposit_into_existing(WHO, AMOUNT) => . ... </k> + <totalIssuance> TOTAL_ISSUANCE => TOTAL_ISSUANCE +Int AMOUNT </totalIssuance> + <account> + <accountID> WHO </accountID> + <freeBalance> FREE_BALANCE => FREE_BALANCE +Int AMOUNT </freeBalance> + ... + </account> + requires FREE_BALANCE >Int 0 +
    +

    End of module

    +
    k
    endmodule +
    +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/tests/regression-new/markdownSelectors/a-spec/index.html b/k-distribution/tests/regression-new/markdownSelectors/a-spec/index.html new file mode 100644 index 00000000000..0533b70736b --- /dev/null +++ b/k-distribution/tests/regression-new/markdownSelectors/a-spec/index.html @@ -0,0 +1,381 @@ + + + + + + + + + + + + + + +K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +
    k
    require "test.md" + +module A-SPEC + +endmodule +
    +
    +
    + + +
    + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/k-distribution/tests/regression-new/markdownSelectors/test/index.html b/k-distribution/tests/regression-new/markdownSelectors/test/index.html new file mode 100644 index 00000000000..abf907bc963 --- /dev/null +++ b/k-distribution/tests/regression-new/markdownSelectors/test/index.html @@ -0,0 +1,407 @@ + + + + + + + + + + + + + + +Test | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Test

    +
    k
    module TEST-SYNTAX + imports INT +endmodule +module TEST + imports INT +
    +
    .k
    configuration <k> $PGM:K </k> <r> 0 </r> +
    +
    .discard
    rule <r> 0 => 1 </r> +
    +
    .keep
    rule <k> 0 => 1 </k> +
    +
    .k .keep
    rule <k> 1 => 2 </k> +
    +
    .k .discard .numberLines
    rule <k> 2 => 3 </k> +
    +
    .keep .discard
    rule <r> 0 => 1 </r> +
    +
    k
    endmodule +
    +
    +
    + + +
    + + + +
    +
    + +
    +
    + + + + + + + + + + + + + diff --git a/news/k-framework-demo/index.html b/news/k-framework-demo/index.html new file mode 100644 index 00000000000..9d06aca5706 --- /dev/null +++ b/news/k-framework-demo/index.html @@ -0,0 +1,354 @@ + + + + + + + + + + + + + + +The K Framework Demo | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    The K Framework Demo

    + +
    +
    + + + +
    + +
    +
    + + + + + + + + + + + + diff --git a/overview/index.html b/overview/index.html new file mode 100644 index 00000000000..3869e408e92 --- /dev/null +++ b/overview/index.html @@ -0,0 +1,356 @@ + + + + + + + + + + + + + + +K overview | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    K overview

    + +

    Go to Youtube mirror, if the above does not work.

    +

    Go back to https://kframework.org for further links, the K tool and contact information.

    +
    +
    + + +
    + + + +
    +
    + +
    +
    + + + + + + + + + + + + diff --git a/projects/index.html b/projects/index.html new file mode 100644 index 00000000000..3b957b3669f --- /dev/null +++ b/projects/index.html @@ -0,0 +1,447 @@ + + + + + + + + + + + + + + +Projects using K | Runtime Verification Inc + + + + + + + + + + + + + + + + + + + + + + + +
    +
    +
    + + +
    + +
    +

    Projects using K

    +

    A list of projects using the K framework. If you are working on something interesting, and you want to share it with the community, +let us know on our socials, and we will feature you on this list.

    +
    + +
    +
      +
    • +

      KAVM (Feb 2022 - Present)

      +

      The Algorand Virtual Machine and TEAL Semantics in K
      +KAVM leverages the K Framework to empower Algorand smart contracts' developers +with property-based testing and formal verification.

      +
    • +
    • +

      KPlutus (2016 - Present)

      +

      The K Semantics of Plutus-Core

      +
    • +
    • +

      Dedukti (Mar 2021 - Present)

      +

      This project aims to translate real K semantics into Dedukti.

      +
    • +
    • +

      KWasm (Aug 2015 - Present)

      +

      KWasm is the K semantics of WebAssembly. +WebAssembly is a low-level (but simple and streamlined) assembly language that was originally developed to provide a fast execution engine for browser-based tools. +More recently, it has been used in several blockchain smart-contract platforms as the underlying language for executing financial agreements. +KWasm has been used for measuring coverage of test-suites over Wasm code and verifying programs which are compiled to Wasm.

      +
    • +
    • +

      KEVM (Sep 2017 - Present)

      +

      KEVM is the K semantics of the Ethereum Virtual Machine. +It passes all the Ethereum Test Suite, and is used for verifying EVM programs.

      +
    • +
    • +

      IELE (Oct 2016 - Present)

      +

      IELE is the underlying VM integrated into the Cardano blockchain. +IELE is a register-based VM (inspired by LLVM), which attempts to avoid many of the missteps in design present in EVM.

      +
    • +
    • +

      K-Michelson (Oct 2019 - Present)

      +

      K-Michelson is the K semantics of Michelson blockchain programming language, which powers the Tezos blockchain. +KMichelson provides additional testing tools for developers, including a unit-testing framework which is extendable to symbolic property testing.

      +
    • +
    • +

      C (Jul 2010 - Present)

      +

      The K semantics of the C programming language specifies the translation, linking, and execution semantics of the C language according to the official C standard. +It has been used to build tools like RV-Match, which detects undefined behaviors in users programs by running their test-suites through the C semantics.

      +
    • +
    +

    Archived

    + +
    +
    + + +
    + + + +
    +
    + +
    +
    + + + + + + + + + + + + diff --git a/sitemap.xml b/sitemap.xml new file mode 100644 index 00000000000..5bfb958bd86 --- /dev/null +++ b/sitemap.xml @@ -0,0 +1,711 @@ + + + + https://kframework.org/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/index.html + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/exports/K.pdf + 0.5 + 2023-11-13 + monthly + + + https://kframework.org/exports/K.epub + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/exports/K.mobi + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/exports/K.html + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/01_installing/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/02_basics/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/03_parsing/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/04_disambiguation/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/05_modules/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/06_ints_and_bools/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/07_side_conditions/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/08_literate_programming/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/09_unparsing/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/10_strings/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/11_casts/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/12_syntactic_lists/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/13_rewrite_rules/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/14_evaluation_order/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/15_configurations/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/16_collections/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/17_cell_multiplicity/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/18_equality_and_conditionals/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/19_debugging/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/20_backends/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/21_symbolic_execution/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/1_basic/22_proofs/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/01_macros/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/02_fresh_constants/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/03_klabels/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/04_overloading/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/05_matching_logic/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/06_function_context/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/07_record_productions/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/08_fun_and_let/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/09_as/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/10_matching_operator/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/11_evaluation_order/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/12_floats_and_machine_ints/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/13_substitution/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/14_io/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/15_string_buffers_and_bytes/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/16_kore/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/2_intermediate/17_debugging_proofs/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/docs/user_manual/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/docs/cheat_sheet/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/docs/ktools/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/include/kframework/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/include/kframework/builtin/domains/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/include/kframework/builtin/kast/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/include/kframework/builtin/prelude/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/include/kframework/builtin/ffi/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/include/kframework/builtin/json/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/include/kframework/builtin/rat/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/include/kframework/builtin/substitution/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/overview/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/1_lambda/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/1_lambda/lesson_1/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/1_lambda/lesson_2/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/1_lambda/lesson_3/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/1_lambda/lesson_4/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/1_lambda/lesson_5/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/1_lambda/lesson_6/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/1_lambda/lesson_7/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/1_lambda/lesson_8/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/1_lambda/lesson_9/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/2_imp/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/2_imp/lesson_1/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/2_imp/lesson_2/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/2_imp/lesson_3/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/2_imp/lesson_4/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/2_imp/lesson_5/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/3_lambda++/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_1/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_2/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_3/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_4/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_5/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/3_lambda++/lesson_6/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/4_imp++/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/4_imp++/lesson_1/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/4_imp++/lesson_2/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/4_imp++/lesson_3/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/4_imp++/lesson_4/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/4_imp++/lesson_5/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/4_imp++/lesson_6/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/4_imp++/lesson_7/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/4_imp++/lesson_8/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/5_types/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/5_types/lesson_1/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/5_types/lesson_2/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/5_types/lesson_3/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/5_types/lesson_4/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/5_types/lesson_5/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/5_types/lesson_6/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/5_types/lesson_7/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/5_types/lesson_8/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/1_k/5_types/lesson_9/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/2_languages/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/2_languages/1_simple/1_untyped/simple-untyped/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/1_static/simple-typed-static/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/2_languages/1_simple/2_typed/2_dynamic/simple-typed-dynamic/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/2_languages/2_kool/1_untyped/kool-untyped/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/2_languages/2_kool/2_typed/1_dynamic/kool-typed-dynamic/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/2_languages/2_kool/2_typed/2_static/kool-typed-static/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/2_languages/3_fun/1_untyped/1_environment/fun-untyped/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/2_languages/3_fun/1_untyped/2_substitution/fun-untyped/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/pl-tutorial/2_languages/4_logik/basic/logik/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/projects/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/editor_support/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/faq/ + 1.0 + 2023-11-13 + monthly + + + https://kframework.org/k-distribution/k-tutorial/3_advanced/ + 1.0 + 2023-11-13 + monthly + + \ No newline at end of file

_pjvV1Un$1H^rH?NqFx#KEjbX>`QF zS~Zpz@=hTc2i&$a1A1O?d|>LM?kfLpO45MHo(6dE%S4qVgR$0A^2c`k0FczLKQj&R z@5^!%Z5+%_Xjq3IIOLGzP*30pfR;V|rL^@r(tu)nx$XF4&TdlAL;hBz6Z!1}ALT5Z zGSoO(KaJ)(&rkQ^6l4AHKFSHflDb!xG5$$5Q!(1p6VF~wBk9|Eb@b=^!S(dVt@T1f z584;EW52p5=MHgeht@sTiGB;*vPDGR^Ah{rH6vDc4c-=bJkEFnV zeI?K%ND~wiGrKWmPPH4#fW7f<1Bp+l_z9s5TleK>|y3!mj!L3 zBW-Y5s(xnUCW>nGo@hQsv#YpD`|GxtNC$8k@wpziVa+O!V_!k4Q&2!<^c(-;D0GWU z%aZ|n0@$p)?;Hs`fTdq`hplDjpaMFtPakeD3wv^Vt1F0Zu-mD=Ks4))oE{{?c+9z0 zzNETX7={V7bkvDgBs6fQTQe4<62?)5h2VMCZ z8pwf&X;R65iiK)fiBlA={Nv+aeES%L#y13$R}qGU*AS8U!S{E=2P$`aZ8i)Te>Th8 z<)~q*Lf6(@_8*>-$w<+m-iQ@q3~yFl*{eO3w@HV9lFC%Nf`vV0D%_a!ulBWj>3+~( z*0F7E|1r83_DCj6o`tZ z6YP)LMtO#62}RjsCsO}|J*U(^q;ToeE1|@ z+^t(@&2!FmCUyW7`Llz6DgUv9(Zj(ut7Q&Vg@QbLMmOpjNSIBzgtqjiFrSdMd^-$o z5jCEr7U;?+2@CS)sf{yXS3H|N!Ma&1BVpM{9sL$LXMQl<6!tCj5$3)~r{lGtRKSo^ zL#T8=WP&h{Gr=}Q)#jwh~hyW(g) z7>&}8GU0g^DA*f-#EC?T-aLH!*QS;9$w0_fxe3;XfG zy~XW3tI81mC8kl_Evy%f9%jG1B$^HZm}sUD z1{+HR4S`ZMKqZc^ogffrM`aT~;e%1(efD-rTA=tc?ynorI2+lP=ft676NNRF@>Wo-{joboQ2>hBN96DpZ7R^*Yp?B zsqePOb%Y3`NA7LN+B2g%)%7oJ-e)lv*vj+9kr3W_?>^_9LdaS;+q1n98fyW)M3&RaRd#UHj8z!C2G{1W^B^|FsEGo7_ zFQ|gJm|?#DfS|mP3+83ES?Lr3{dgLDHUc|pIaW)^f9$Sp_84oXJIm9Xim z#7cCyEF{LiUnZMEIzh->T{Zj)v%u7#Pp7+cp;K&6!QLkt`{C7hZyR*QPc$cA6-49gvHN+T4$soj6Z=spVSh-( zMCu#nvQvsHS)Hxiz`${Mi>_u%ML8~}vT;DC6+tUM zW3~i%*>s>pSd0%GldYalUwjX`Cvf{(IF6j%ogW8j380|&2 ze$d*f&Nm}k50J|s1Dqwio8P+mHW8#gEwd+W{L$XIR6omFnitRB4^duWv2zEsQg3-# zw&|_cElR`2rCQb?=Y^cQhP{k^-I{(8)F1Id8>j%!$OSG@t@fVSLsG!P==*&jo+-8b zr(+}Ye?==|WM}_hpx^)b1#bQW8op3|f?SL*#@QM)gn`HgY=d0>>*ev{zbp!G|0pF8 zkxCV1d`*z8q6->%*h-^H`jYTVGW+0_4h;J*FbIFzhc58noxON`<=p6p=@W#>=Y7@3 zTK{3-!52;+<)j(X{p0a6bnt!B!}!fWb~)PqwKp9UXFrIYN2mv@cfUN!-XyI*n7K23 zHz7i){Mk66jbS?7FlEv`Ft$2A3K2k0z}>FgT~CbQBIiG(?4#!aCE;tNj=g?$hSM9y z6CYP7gloe^%Bpi|SVVy%dn>3lw^HpC4uAEViu~*qLBUd@XoI#zP7k63` z-!srQxW;D;E1ylgQFxS$-v$oSuk;S%8ArcxVdbI%uIpQz4z&IQ*w=)RfzGnulgZ-69bnqF$QZ7nUw*Y^H3r?0JhKmaMTQttA@O?#hbxA@rUJs^Ms3bpf1+!}CfxA_UwGO(W5ha(B9T zUU@<-Jv%T2IC9Uy{8n5{$ zz&`fynle452gji3p7*{Yd*dbcX5E2?5$Uq{7N>-{_9?E7E>5b7+u3)rh29;-n}#Wz zARJ|4g9s^Yabv3R$gM;HnD%NEy2+i2jB|b@x_{EJY$It0PR3i|oOM#$fe_iqe3wxC z2v_18%;!fF-9|Wg_DVk~?u|}wm-8q50ts3wAXFN|eA{lCfoo~KXqu2pmmr(biRV>z z-bous3isFETCzEoaACSfI+4RcHMnW%J6FSIkG+$2XfOf^n9liY=i-f~cB~x30nDu0 zJM4ULkFFkvs^^O@(@5CF?8=HwU4u$v-FN8BvR+yDP10S)U9^FA?}JF54dxJ7MsLDU z8%R2#4;mGW`D%+Z@{ADnV)a(?RC5E?3%@juWrG3{dkw}HkJm+%qtY-s9=8Lizrx6( zvl*JR1y+mx?<`sT1fLUul^>qtWai;b?e3H#>XS%xZ3o3bBj~>ynKwFkoGN|N0=EP z?%IX8Vk|y1IhIMf9U>5{l0||3zR)MQ=l|U>XnlUt?5aq1*oF6HgA*H2qCGI;!>MZ zbLldw&ws1Vg;y*i3_0kr_}Sa_ub?kRJMv>WWJ}t)3Xa;mGo2k1*6Vejj;~xF9xBEa zPibWg9~FN>sqLtC#@A$1!W#dYyM08_aUm7AQBF>xhysRt!_~OOb&gfGsif5cL z(%Q(JwQY=XMxj4k%c0}x#H)BEH_}?`r68X)Q|?vc-d<#Xxgw{arGSN4rX`{AH76A~ zYxv8079cF<5(}^xX1fC`%SQF{G+%?_q-jk0VhLGwfM2~}{xxd!yv^7tZ{jtK7H!Vf zS$0gwK+NTSW>=XM5;;p9MWMXfgY1g5nUy!KJOq;#H;?+@YT&_1um$PF_GLk{IJ1u% z!g!;Ff}60I<%hUijvcK=UO73L<|{&Ix>+1}Yy~c4z2sc#TLQTG73_bpa3#UsE#j)w zg}|)?Cg^ki$P}Poy>kr|1|ZRG-8ksbnPj^uCxv#7{))xk?hibmT1>qw-qPqLgRYUho&$@NBz zn8P^L5#3W{lWd@RWz<_KocRX(K$&*N`cj*bz?%qlxX4#qhEU9*yHl*22z4VF)2V%)mRCT1)$|Gv#xp63ke``!u{$0RsHAz2ibLb@RXM)hd z1GgSE_?LqqYfK5I@B4(6y)Z=i55G9({|W=l$iei#B05|Do6aMQI-B1AXXQ^5I2ki; zwb;Tx2+5E9U!w*OW!{6oq3Y>&k|b4nJ^v45@7SGbxNYmkww+XL+qP}nwv&qOq+;8) zZM$MSd1IV9tDUynUhT{e^G7^SAEWnsT%CJsYEF!P@P{HD{!^f#`|G;z>!yzI{C4hm zZS8nUqv`6>et^C%eq_?E$-YDDE@0-t``Zgsm{1st3XC_jzU=2FRPoN4#qjR@r0=ba zU0?jw$Km@S0RFY__6d8};M@DlB++<9ot{JSlKv2QwXap{C+qL_jj&{&?~-p|qic7f zFXZl-@>@>q-~04*pg{Kq%20U7=wtHZPTa==kw=I}5h3(&v~YWRyh(@5g^y>f+P9Zr z`kYT$h`|WLkXr*24)bpxc{TP>=XnL8y^@{51%QRz1VuA;81M~SK)Uh zkS)J<7rONAA)&o|MS38m6V-Er;~J3OSggS)Y;D(8e57yXdkDhC*2&)!(=!=p{)m@jaghvM>O_^slo4Y@^ip% zesE`^DR5W%+$#F`Wjxd8^grEg8#x>KdXJD>;Hd+LV*Yvu#) z2qi<^K}5&&@63FD-i0Fasu}wxvr9}Gv-%3wZ88@S>~i3XoF>dN1;j*c6iWMr>;Vw+ z&VPHTq-W*Tx0ary;x1c>(C8(!IGuhmOJN}2N2RK* zGcXn3FkUK?PcSR3-U52ID0sF(R=8j(+|$H7G-v72p7bo#GF8BDS(nGiMDZoGybk`OA#yr!!XJrc-puUf zCr5KrB8+=~KwTCTW_kE}>g8K}$YGTRZ~Im%Shmx$YcG3H z-w}PTH>SpFzlMns>jQYKmhn$-OTxN0F|d0HxkLuamoFTH3kZ8!qZ=#`jPNvnVPssT zKCxs*&zBh8&JtrllU5BMGAj4TQjxxqCMulVyZP6dKeP$8)7y;=XhdIO^J-hPdyooa`5o_Xob(pJKRmuA_rH}Hq% zo&4xg4j~2V)TmF*P&a6&K9I6=-+m$d^?!q0ox+p*4^qqeUtwdIxETM}g4*+cHPP@c zC_41t{huP5#7LK>|0$vojVdf&Snm~6A`Pnpf=IXoW(Zf$*Z>L)pzN>hjO-u zHqdwW7u?rImk;s39mvqOl)ha#(GCPeH zj9J4=;MpbEj&WmkmUFumx9IhTSu5Wba(k|FS`}l}Ql`*XD!}im>gNIqFNw9C%AC1~TCG3e-_P8P2v zEX*-rW0@eQPpi*6f&>&in8695{vQSczhAl$iqwx;0@(B<5$!!gqDH+hmZAVblP07V z34*@1v%jASZZ8bPR3Q*4o}!nMU7baV5nDFL#EB)Pv{$TKarbW=Qnj{#+@HQ~Qh~z-4Hw?%aJ++#Ma3(R^A@0k3jT?absm3i*@JN?X zI`O3|M*-09Pj{JkYT#Tk>?S0W7RffEQD2i2$^?I)@d%AKf}Fz?<2iy1nPhO}GHEH~ z%O7(b*X{oCgw*wTaR4$&JuAl?+uc{Y4twFWGQcGfaGaqxUuTbU;Mh9j-Hp<-MuZvF zGB$rq?E6AF&IzlAB9`S?Y=@T)5jh)CY>4xgF9CyLHs@0QHOM191kcT`hqq^kUg;`G zn9T3jnv>2}<$SJwV4y_FuH@xl@6Ira3LCqsU!z^rm^zAeh&URi>jpGrbL!R22qg)| z>a~JoG{v9BJJ#z^vAE++M%4eA@sP?__*5+Nh0Fz)> zuNH9d;aG|ou{4S(PM9C2LIZJMN2>L^|!P~%QdC4{V9@Kvfd1#T)WJ9z>N?3$5 zFW0jau4fiaS=0)w#Hy@dzj|kIia=49F_HW11hdN>b(L?~N?Pvg4^1grC(}0-Y>|=h z2cYWHJDcK>q<2X5jYqu{u}}KEZ0lRyZ-_(DFA$BoCou%^BPwP#*JF|E9E@Xvh?WN| zMQmM*w#21)SxQ~kKV=QCDpdr@-w{*pRhxW}7K6jZp^B)T8=`md_j4kN!w?Z-FU&h3 zrXLaTyx%Pq!AJ!R35`spu02k_eRbd(m0>IKk!L4xc%nR>+0fPTFI6LA9#G4dnSQ+j zckwooyvtK6%!l;F!|&OkpR*|CEo82^x= z6Qb4Pl*5LFuYtc8i3TrZK`bV*GlK^pdTv{YvM*|jM3aLbWvdj#3jvFRQx>hPL5plV z?8rfVv|0A1tjvRAm!b?OJUr~g_Mn8fnc9&=El2d%E7P6C=Cheoe{ql7_rEUA;o5^@ zX^mPL{T>_j`L^kb+dD3nrk*@_m%B{mD)QTL^cFgLN58=v8|tn$LB_EfW#VXA!|}Wc zV3fGA4yL@Pd@Abnwx7j&Z?NG_-wrMG&w13YQK;%3ODu=)?Od9F;wy}NP(#&ceY0L~ z)h=lmAFs!&GH~T&(ClQJKu3@xic|{TOZy-v5MBcI`jzi-ZfvLJ(ru>8gSDw^(dqCk z9m+T10IQvZbJ*gJEgk>Ju0$srpE4d9OX>#qD6z-(?a%mTb-|zg$Rwcx%Xfa6E)Ca3 zi}e+cs1Tp3KG5T#<+t|cfaCO$dEmW!)Nph^q+U@NpGpYUA{--k?y(sxfZ3R6A0$fiDD0n zGg)x#*;0MgAkR)ltXe}=quRvRL)&m?I?xXTWcHlKaL11r9y|v7wj~q zZ|C&U63*k)#wO|SylC6fiDOr=Zb_l6^XZtC2p-WY(CMh5taOO34 zipY{box*DA-fx$Hc+1SD)un^1=cPNEbLua7cFDh5@nSD7X(wUMB|Oe`j&;HZ&NCR- zk)Svw=nwC#A8OtrIG``BMoHv$_gfxQzVZy_Fio+zb+`!UkA;t${BJ`#*=1LVS)t;X z(9yA3p>F;+OGddVh<4r&kX3Itm;Q^dEMR;y@*Zh|@P$e<=sjhBX|Or?{;=j$pV|Ua zkK893tnOLG+LMe*rd(Re8myS%e(6Yr{!3PL&-S=1Z79u50yQ^Q8`dsbuyV6LT-a~r zY+IzYyVLO~GQCSq5*;XF$@SPcWDvk-nbR8%tl`>FBKY;Fx_r58;LPAq^A!iiX$}wD zdHHqr(oAY+lLc#Qm1gkl&0JwwOOYMpGCN~L`c|Ue?9dnISx0Ey<`hMmr^nc6TLQktx3rWuoriapPZClZ-LkzAYPewVFRg+ewX08{F+w@L_V=o$=fFBXYvbw*F^R`96E ztQmAsdq7?yAKpV_#cjaEGShdxO17QcRtFuF2_i{P6p713Rf9BB4V?JcHN9!b@&KTf z@izu$?Uqx;o_m%A+9{xyAlcb|_Zo25HtQc1t*;%Xe|?iS**CuBEa~upyuO z>dF4K2$LZ+5dyeXv{zE`%1=1@LdvLP{e-qI6Q&TN@l)jd>ogwG?v)Zi5g|wIdIik z8dHz9hd(IuU$iT&?^~DWkgXQ`s_yXJ0uev{*`IRK7`~3MT1X}PH zhb9@`H4g*_4}yNVou7CFexB#iFUPvkjNs{m45=#%mDUxB1(k7*rg4PbLl7S-y|II5 z+qXTkQS3d?-6)Ekgu?SG*aGr-a5hnTMBwc34|G4g?omb9mY~45_z8Qx5?=Np0(t%Z z2F}2H5u30-3i1|cs%eIPMpb(NQn z14f6oGn!MR8PVW2BCZoQ?t!q5$HRY?&Q#|~`WCnMVuOY(pO0pgnc5l|xu zJATc_>R;cErMLTPSxG*h90ZY`NT!Q%mt$mf-7XUk(%N#XmpP~w`s+Sfdg&X!CMSla zVm9hx2%?L0uPO~LItCuFjqe9$0BYOlDDe}jBo9Ao+7|SyQJ4``H7bh;QSy^|gmW#i z#)6NQ*pJaF7N58cj-|DGx2snhS;^dp=W7m3{;t-d>}=<-t6#3&zf&6CvW6L*`1xnI zcJbFZ@Cogl2tku|rU!h_bB7S|?!~a(nN(s@g+4k}J~jgLY#no+*Zg!1PbW>4Ge55K ze{|ze-_@aSzXijq3di>%^3B82QmW=)8 zdw+uUKlEvALx^tnY2I|!Fm&Bw|6o^tJJ#Lo@nEmt1*j)(IamSNI7P0a-2&P~+gD}? zG5%DADEx>)=JC|g(hY^Y_oU5@%Em8255_!&?_AvUV~f%Fjbh(vvF-?D?VSQ&nDM^_sHsZT6tofG5==U_-#Q|x7wJ}Psu`l__o*!dZzdU|mH^4Dpb9ookEKBIO zVe3+DPU-w9uI;Q$tHXLw$<-YxX|X$-hoISHhRiCjPM3b6P98H2{G#24HDmLxT5iTp z2uwx4zpx+jO#Rq3)m)g`bw#RwyxQ+kTs6nf1QL8x^rWNpiL&RVEu>4O0 z6~}+|a*XSL4^%z>SLRSUaRATC&1i`0*xGLz7P8X3^)Jr;8SajvRbF0r9$ZIeB~dcH zUjbCMPqm5B@_wR5|GpbapX(bk=nK27^Zsf5d}{c7jn?ITgqVJ~*N!ngMm;bxEK@{*eKEkH* zv^}i)_Bij_#*D!5)+>y(F1lzhwPY(aJg*RV7qr(ah#X=+W|O3w}u#s3E7EO3?3V! zTGM&zWYp8p1P?rL`BHbRGaH^eJ|~XSC;et1>As*`18Nd@KQ+dx!kx1$&DvfK z&gQ1dN=q$p#o2Na{u904F~(mq#sMwE!9?ifPf{NsD2PQk0wjR+4yuV@vJDN@O$(x$ zTd4&>qU$5+zIT-LqtgYMpL9KV>}yFyR)b)kdG_Yb;l+gemw4|lB)tYMP)n1Qccxby zu!qK9nwAd7HUUazhXADDv9$$=KK-`fimjm}H^iL3T?wszGrw9z8_+c7-GfQ#L6c3 zytORf&3Fp!Hr$rPVTuSPJ51TE$MI^3gX{hoWHpu z_fbFh3|KJi_cBjt%@bc3^AZ0{KSVtKau7CIRI|NnXXy(rh!R$3mRX#e8qhkHlsyhvadowV_3aWw77M22fAp{it zCk9XV^LlDQjGZ=G1l(GAo#`|vy>6}7HTIdzvc=7)br+) z-XgaB#juP0jSF5i%7v9?xK&1mWiswvik%SY9qE%)xMZIhQgQ?M9#zP{JVUbO*YCIc zm-fFsK(9H#=xIQkyIw|g+0*qG3^{*Ada)N%hGB%b+3w2q%4E9GX}akz?rGbkdhc1u zVX)@$-o&(@Dq(^=Ovgh-_etGCQJoQ2Gdy4MfxDF`yj+%QQ~iwzjuh_7BB~SgqZIhH z!e#z(u{B=1H2!iCdf@9{n1HP-@=YM+%_gYO%`b+u%hk3%4Bb!zGPxAujV7^NK2r90 zgXH(EP9Ot(pNw+gL{d|ZLgv{zV=qJNe~Tsn+O?vItEZqM92xp-Gk30?fcW89ND)ry zt+3!CI@el&hZOT@fM#-BtGf2qMPt{8rPzFjI{$!I8JZe8YqPE0_eY|nU+iYUrRfR_ zFH+U#Rob$G1G+x9O3a)JC#Rg>Ksm2H&$T?oM1Fl$h{{h=R^C#)UcK*nDQYojFfzJE z3?NP-%LFxIZuhNwJ@8ePr0d_8r0X=4{n9=&hw+sBQ>u(t)%puIH)Yq$dmheur0y*S zXV!<_XI1APsF${OB)r#i%PM+mvgbK1f5Krl#1hxA7uvL8225M};@tdm3mx@bXL^KJ zAu%m&U|k#AOU5YecUuPA4?PIJ@5wg*GquiewMx(wCQHs2|1C{7XDXaSMwO%J51GIsQa>f12Q*+JljNhI#! zMz3##X`jF&}LtDdpRECma?W~LZVaei%3*cpJuV#MWC78_ zZOAb>#bA!LJj;q=)m&+D#|tzf7ES(>n2lW_B{KKEJh?gja2y^0E5`?b4~vk6vm>oEHB#O4#XIF zxS@+B#`}`0EzMcwwtsLaKx_x__xxP)f8F?hPxJ-I_w~s4`C~2(V!(TQ_b7OqM=>mk zfwE}J{fib1I5|EmQ$G0mTxz*aQ4anRZU0Sk+2^-;DY^m>mpFP@2LNvRI`l*DG>Y#9 z*1S%>ZC+A+9}R*&z$oo|g74cdXx7sy)pxf6JiAmw!j#Vbecyoh@U1{n+>BIXpw(-J z3xujA8~NbX@_=~{sZFiKG-l>+1dp8qeE)%0SM8`x>xJoA^19HAC^mk~@8<{m4G5d= z1CGnS8IKxIiTR6M+MZB0hJ17L>RkHAX^h|e(50Ga?koSMr&pO?^1Wv> zYNeY}fsR~SCTm}c;CgsunwA+_#C?=J&qh43@7X_w(Fy0P6zpg^EBD7^ru-&nD?|;< zXs0CqrhoCi!gehM2*ekuPF#`&pxYW11`kBp+${sO!&(SqaGuvo{PeTcGGu>Z_t+HG z7=B>|>s31{8I$2od~D-V)ga3)h8c;LsZ9qpLY%G%(S^yYQW68@24X-DVe4G|yMEH$Rk?eWtRpRTo@bZBEf}T&x1Sf(qpKnI&F|IQ<@BjFr@XgE zULfHgJVBZ0zH&joeo=NX#+*Xb(4Nd5B1ndeBNQJT7kix&Mm-n|ong>bnS&|hH~9tA z+kWb}7}Yi>Iq$^*`+4OCnLxmRM54TpH2cj$uMpAq_gVAPCTuuBLr1QMCu7vHDqgI#2FOREnPqC z4a`(@3bTlM_wAiF#g9|=V9iPImn6(b*NANebTq_JoD2wmC2e#+?jpWkd$H}kvNi5F zsU-Rnb^)S`Dnc7BDh<`OQwc6k^(Jc;!;*_5mcqlDA0(Kywuo4=%i8+FJQq$E-nm=V zYnmhFks^}`g4iFMMV>1S2Q(JVInq_MHEsc0~2pr&dMP( z2DUVW3re;{dRAs#QKE#qJLksgP^cyFZK)wNf659c+3aR#Xu%~r$`#;b?rnBqy=>6| zBydPR&$lbgR<)o{>@+){klyVX3@B)$fwcXMM?xCwc;~$(E??727U-Vh%ht6t1Le=f ztm_z|K|Xe|v2CQep28Z&1~=?&G=n4-0mSO+5}ef84M!v+lqvu%&J3h ztPvb4QO2R$8@-Z1jEw7;(0+P~#<|mi%(!UmZW%Co*3=X6>r#?yyH<~yk1HBKt}u-$ z7nH9{PuN8NXe#a-hOr%7CPq|^lYufKRK&cQtlNJJ5Oj2Z;KZ~eAIYoyoQ{>L$w!#3 zsItfJu7zTu9uUF|upg+HRD1d(D|S2=wU^jxP^=)5B4c3OsS)%j^AM!UQ--cZrIPS{ zx`uCaSr6MA$(MS~jiF(a^Cy9}ZAGieL@0662NCBBGV!lnKX^*l1TX0P;At1p2L|0$X3hsc>?p>i+! z+mK?M_f<)2*^IGFzABLAwWy!CENgb78Vh=Sok{nCz6A{RUfDNFOhqP%ez+te75>Gv zQI;bHXXi~J3vR}_sNvDUd{v9!>;^Z?2a=m=WSmJ)&zNB|Q*U|?c-#68*1< z%O0V9OkroEtpBl&PidPcxoNbWo%loTjXI_7Tj@g|#X^QNDOxvG`MRa$@A=L}FuknR zaM+wdx+vD(mbi{iAmb%lJ4bl*MsaNaY>6}BqlaKrqlI539>cOQbNQ!0g)qN)O$;PK z4$x+oQawz+lf&Rwk_LwdkD+@Y1vi$A#b0P!G`jLCL_5AgXBA{+kIS2uv{+oo=3y36 zn92%uhQe)1pggak=0>OWbVW1Q{4n&SF5vb)9`f&glkrQ^Nt{Kf3KiSK&+&r!ppqLF z9s=L5dm!ha*iXjD$8%S{gZYb$Z5o$um-_Sf5f7uc0I`jM9$M;pYq%NM)N-(*5Y24a!FtO7=colEySegNBgT=S^B4=>*OlF^xV8%c$cr6I-4s8x!SWUj z&ryxgQ&TNm{@SD)@@~_HTylFti!8cQDe)U4I@a6M^T@}e36+E2A=_LxD|30Ocx$A5 z$M}6e&0iQp&kfVh*@u?e4PN5B-j1w*i*r&ia~9GxwGdx__ujvNfZfbnlJJi&t$Fc- zo@9AhH1VrA#m)^UhmX#}_W%R?{JmoQ`B|PZpsbl%icZUcOpLdqnOm0%2{6jzF@_)D z!K6Q}|7kS&??|8=|GS%K<{um7@c(0@93+g$f#LW;B|s-^0r|l?JMqj?g}?pCXp%lv(Kk6UCl+vw_P?Af=|=uURDd8bV)OsmgU zSp?16^c1yR;CqZ?<_h5yLG+%%YG~Wp^7UBSF&xucz8rW3bbn#Y^ih)qlc64}zo*4d zhjrA6vzE7ri870!Xv9|vsoTl1k8QmRV;nw{>YR|UqDomr_W8EJQA`FW@K+{|wB4G) zk0~R~X0?V6{kk|h^yuoT9VM0MT7#!|Az5P`}+4 zf(Mg&Qv3BZko^dI&IF`Hm>muzjYKav);<-s1d?wcf)?QxwL_yMWFBck)C;+pJkfir4g+Zn zVu+J}QKNHcxtJ$RplyLf|8PT8aYN+ze3gECtE2O0*RrZUX*iU)R3r2ok7^Gu1QZxH zJFh(Dme>@j9!y&VPNN_84>kY9W#pwL{2;f07v2@ALGqN`c3Nh$C(cC7UHU-%6}mk&ccAjV~sOy_p@OCw2H-(_A9-+}@-fjLvMC zR$jG!B+|wX1H5#4l_vHn$ig3pnpI@mFKRF81N{GGw;19ups@hu-rXq1?$*E@B9UuU zfof{W{hB)71k_}R8|CdCV2^3khSi5vS_`%$c8y8qZoI|$>TS3or((aI0e`fWv7?db zFhAGbnFiWX8i@0w9A1%ZNa|U|QsY&Umbp8#=aOscEiUY<5T4y+xhGMln%>Y}^_U8# zG|m$xK5!%#v#K(J!n{NF(vAETk*9RVn18=N7D5P#a+${A;!j7W$Z!S8XTf@H{+Dlh zb5i%3KAt@>wkkmoD2lB&ipd9kUz6X?6vJhKR+2~RVfX;Rpe$B@*xipmaFvZvMME|tn^@pJLs>6Gq zl9F*Iv8*k_=o86{a2!wKOSH;m-Cga7P^S;hZ6c0)F8NNkHUkhiX}Om9RgvVrwk5FO zhsf3R>yBlI`h4Yy!eLQM?#eH~tJVIvVOk4FT0rTnEDn`G4(Qdr&G-HsHi&6WTm?68 z?8;A9mh~rb<|+V6I%&;KZ-TL|BD!rAdp5c)sYjx#ObZsbk8SlYV)t~(aq(4|S5V6f zu-oObvugPOXYL>P{nAI!w*XwcdHXS{5}tx&M~}E&4zYUEG2q*%gIN&c7WFX8&K9e# ziL$nobPzuqJ))fgB^5E>z1Z=hZ^~%2rHset7|9w|;$IM-F=na^{ znTlsyM8IXod&ewK86ISu$tc4c+jU;Y2|7>^*G{O-slZ^!IGlHb{B@(HExw&_sWxNS zR+Xmu>(ivHD$Bk5iq6iG3!M(L;zI(UnZ(e5GmFk^zbeKFplv2Q&(UNUyzY_Le+|KV z*%n9Fb7(Rq3;jHoz388^+}0*2n_Eo{#&zao$UK(^CQW#@m%rbOXN;jifz?8iEVqks z8}v12cJtbcxOhBCWEDd;7$t*XUSwJMvhQ{%;9C6uovLna4_I{ z7)3)>MFTN}@X4K74P4@KHpg5nD^*kJp!y#+@#kn)c91(H2BovtDC+9M60d;8Hdp$5h zad;ToudrmlovgFD9MB>zR_~>;6Wj%yZ4dX!4!C!Awka>;7Cq=xh1Ku&?%aMN_-zi`C(|A!pL6OC4(J|}CqEZ5zYIR zF+6-t$b?-V@b>gv_qBHW{GJ;SAlug~Z_rz5WfTp;*K@N3C(E!T_di?vRvtrkNXHN0 zeasa#TZ-$B&hv4=?w#g!cOQ zX;>b^V31fZaSt`$rr?l{ZenJwL7D#bUiwO-Ez_Dl;ze$n!HI0&YtqFN*(W2nRa;42ctiuCMM1;C!MBgWc-OnhIp}K0-b*x@cxz!n-@u7UYO(Qfdrba*?NY4|*}B2Xpd!Pgt+i!D zZidPBDP_@Zqqf$~-6RHZ@*vE~lR#)O74(LZQbY=Tpj<;q$;a4GP<>MF8u0u^Ljg+n ztSq^@I3cY@qj&l>rzPkx(e^cQ#kX4dRo`^xxk9q%;H*dxkgbzunGsUun_v3bZOhe6+#f^#x zb>gOq2unIf3X*;XrSn;_y-mpj90Ne@%+Xk1nn$^xB3PC*iFXe}oqDFkC*71zQG7Z-@oLNHx|sF_XM>>xTRKqA6?^tqt;^8opM;Cb z;sGl>Wfuwi6-0ywg;9Rfq-le#6t}0GAscV=WBBb?sLVw?xp`3E3YJ8t0_OhxOJ9de zZE>GIdN%>fUPSoaGuvlTQ!oEWwyrRuY3E(lkchHqSTbMxgbQ(Y7KX>|4uzNpZPB&o zA#EqCZN*AD4la=-r~0V#lVWj6kk(!(}GcTFFJV6{)X((F$3FD2>GO%nm8RWUp$3enk$*m}^EIpo0&{;;n?eR38^3>^hn-q6uv{I`BhSFeswqQ-Z9R+o;; zGzDCMk-*KTGW9lO>w!i#XK#kq_x!Z>ZT0}0FLOXp!?q{(2UBX zJ93QrjX7uIV*33MLu-9{5DRSJQy_a5%%M(>9=!VU9Ca!v!X<(kxQpGlCVR=MnmsfM z*7_7?AgKT-bP>Kb!cLmKxFp?9-y7f(WuJ2Z$sFvNgqin!Uya1do(wP$&W&8My|(M}76 z@nq;ggs5Nj1PM8=ulAQDCYrZf7HQz4FmaQz_P4SbCAjlsjY~ITRA=W++#Ne{zu3Bh zw+pp5lI1giYYc~f4CF`_^$P6}>3f;+BHS+%tl-Sz@YeFT1$OA2{mvieMPKgOC!5dR zWdX>hTv9R?B}?T4*GazBi1q9KJpT5yWe5JSU%OHYz0Pbv9t}pc zGNN{IuwdbDbeg-3AW2m6Ze}tgOW-58mZsQmIaS)QyI@G)E$qbD;(VX5J1kAn5+aUW zV<*%i(;4O+UupJ|2D?`0>KwBnu>4DUoekC4m-?zQ_^Z;P2zaPo1`i-59H5>q2tzm6 z$F6d!yB7HQX7V=r2Ac+lVhXYZps~(Z+`(Yo z!V_X!%{Yu9;g6cqR_f99lYQep*K5v{ZXENcsk}kn9g4Z_3^*v+nwpug_{_HO&Qk*5 zQ`kln?nB~n{tX0=;qe{uH4%ol(V_tBZT36fWtJ=U^VA)F3VP|3FwD>iSVBBP-ZsaK zqvJF&d{rNW0C`5XjnM__fEu>*S-S2hSxo=m16S$?TBRDJtD5Kxlp|q9mX{CGlh+dm(eH&5fz?$Au2*Kx zppL*+qcWOf=5Iv_+s)EzXm-JRK=IRSJJ~P7>e5=37bf@It;kOUGe=JWG^2 zMFw4wm098j)~(^zvNc)FhKOd3luc%4BlePpK^V-2Z&X!w;Esuf*hd} zydZx2YfT#5LVq1No}^BFoYDtA|8aS-JI+i+Qo{0RPPFAGINbX%b-lw2*2|vyj{Na zzyx{(J$jS@{%kb&yDt9zK40)`vu*)EcFV9H4R@0H>w*>z-@$NoT?i{`kShZXd*TrH zaEe(!Lg8wgnPZQHUzvMs+vA?+4xBnpZ5nFZc_rT&(!>`jLr)Fe^JXtjjo2Es)P~ia zOl!j?-?9EXk(e#kXf^oq8;p6^0I^i?6LAvvtJD6FBnk4A^r1U;y>X&OFdF2&k8%{} zZrZMTsw%;=PAkYYDjm?WkEQfX_c3a~45t0yl*zO&y8tGbL753LpQ#lz|0?&20~oJR zy(}1=aq72aA0lB!hO-wCwhjHMzAtQi_nGJzD?@W4sF)(G)yVm?)7g(xZPi8(SrY1? zcXmRCVv@X-Ue9e(MR!UCdVN~#Lk?wBUenqRVPUkZ40#j#LF9Xef4i(}KjacA|2O0x z#C8?lkas$IzFM3ARxxYC8Jd1oe>%U{7S9cl{&yPccQ`Z>A57_5*e^4kG<*O~1zzdG zeX!XdUx#zrTLj;ev1JC%+v2<`hxry6xZ5Dk3_}<&mr}Z`9L|+&eJRP13ZaL z2Wf~Bs+`nyCiP5i?(Wwgh1`3uT4epOdCiqcjf7f~zD3*0bkXWtNqRr|AIxIG%-tij zlsyZb*I6~TKm#{rF-(W$i&#``s9WHkEuFXLp}w>NOw9kJY5$e?$;rv`e@oho=1klc z(LW#;m1j^pV?R>y3ITOXs<#eRTV=R+&v`|--;WHoKisf;%o4yph3Kb$+V_!(#c-Vl zHKr@i5Mn#8>9p_WyvrtF^pfVo**LGy%A6-U@XFO(;%vSVRMe*!6oXZxaEQy4Au1NBQHe*VojS%n=6-4}( z?BsZ~&noveE;<)+Pw@{%xU;yOM|sN5!Y>k@z$sM-KI_`DVT+&Yac<-k2GQWXEC=HO zicMlrshu&UKshu?C6ILt*pe&y21RsioPv*-z$mz1(txJeR_95Q#>%?!=qP0a+pG|3 zmZoXSdy(ABf@Xo#r^9+Y3Eg++DUx)*J@r9#a*XN?H`P$1q3SzaL&{#VeM(uSZhTCcJ-6>gA^Ip#xifI(6#Rxw&F9%8Q%27J0yvo+UB0HVQ9W|ZPGQ9zA zO3iO7FG@zn1<}!f@co3L9Yx~sFUkQr&gCz~LXV(EmsBmvzYTP0zejUU2bC*Cx+;5~ zyJnnXaP?Nw|6$P&i?Qlaap(P*%hlHmhD5<{3WGa+R!M#~A9CGP^a0);oPqMM6ZvGkF& z*-oN;o|F+C>dEDuQoxCy<0k$RwP7f52fz`8vUe7m!|Aec6=4sa#zs}5AHAd~U$iSj zOb~+Zdx{IirRQksA_9}p52R3tSTUqp%iv>iUJ@+iu(M$0t<+agdaiG;)S1lQ!ygCu zivzq6G~8w}V2cC;FQQ808x{*>Sp=c&EX^&NdHvoYkv-lb|I>&2U->c| zod1iYx1-q;x5Wsz`+?>i)Q$qM02K=du?wt6yRX;yV?)4TxU9(YXC$iB8jsWIDm2MW4HpR#GSx#J zZ|jz@xVa`}@9gc~aKJELWgUlVCNg)~COO-JOAs2xbvX$LsB)PyFeI?Dl<=Mv#8%a# zVr_)LEsmsLCCmc1^xNr^96?%rl*+fVvH_ZH9l4g^2aF2aQnn;UqOAS|t6815f(>ra zg4eBUy1_fNl6MnUumT7U-~?gCOu31?s}4tk3^DGAUac5d{H^p%LgFXeMe)-pp> z(-k1uJFM|$O9+b0+z>R=qV=pQ)JDVp9oxV`xdaee0cPdEL6)TchF$9;?Bod2Cw$6U zA8!9KCWqv|p2~IU#IQ__DX5z)5Pk=gOP^Gy6?wq`i(eosNA90xd6~S~ zYZ!Fr%7YSLVlS*-ROBy;+^6TZ_Dz^E?wr$(CRk3Z`HY+wOwrwY!?;qWxdyoDO z_W4?eYt1>IXWrLEWnzH)psgXOIOf;vK(#i`x}XdvWu{yjpc;3zPLZb+K?!Dd6$WCR2lQSL*Lt~52}byypGS9yws`1(CfKcr zLothwnzPAdyw$%SpSS;sc2>54)-T=MY@eAyO!2P*L3DRj{W}-jr@d@j1KEO}oph{< zfvI~>7Q-aA{Li09=xHH|jn;`XS0jFP2R&dc#0^X&qJ~06f;wB6KdTD-M7mnzq_H81 zogOzBs-tAus`sI5ia0UV_30qpq&A3Us-yA32rioe+Dl zv;{q1OAfNwI^2Jy0;ldi`}juhWG-q1qCMBLl7s|&d!xxMtn_)_U}Gl0W~U@Ce0u3S zHr7sk5VT~Ed8_!zU1ax>)`9-pK-f0g zoA~w#NQ5`8>jk7$ZpU5B?<421Uu9m zd1hWK)Eg&w?FBXR?468B#|?Ibr3OLG2AoVI=df4y{T3kieZYu(@0ja?EW%|*Y=_SJ z^mzvV@UUSfH$Z65bDbe2vQ=Fwtc2Rtjsdj$qq8Z7|8OY*oS}_`Nkw@;9djSO?!Jf<$6`RHL4ZZXvc0APE0OC)H6Y$g%t9G1ukfgD6NW zNuiAK7X`9PB?GKBl%UClU}3IT#nj>BH6$7ar$s~CSQU8r79dJA!{6(=P5h>2SqV=n z*Ytd5oG&!Z0>zYojj)BhWVcJ8E7*V!96Y%uH?$xXAH^HoNoedkKN_{$`)_6Tcn_FCIsu!ZMyvdK%7p)Uh_ib~I|gg9c9vrl)UqQ?GaFQ5)`GDj#Oo`@_> z^qFF4Q?3h<1~^6IAXQ34GSF1oCe8}rAnlu{9w^^Jp_79BvzWWwghpx{jc7ZDqOjy3 zLyIG4yMY&V{DXrQQPAy7`!i;fkn808<>%Hg`k>=6! z{sNBS*6`2~C8>u%iPD!*T^TPUqSlIRYwL4uGVemMh^o*H|LUS>?m4Eaa0?9S3|sJk zWWz;L2v?HM7uhF^n9U@hl`euHG11m(jo;YADu>~2UoLy}Dass+PrndVJLFuz`e3e_ zW7XPA@c5-k^6VN|W9W>7WJWy7EPh<-#T(nOkK=tzEiTTIs@WgpO?as$h6}q^`sOp_ zS{A;o`w-13S|Iq=Gfk=fo&#NYnFN&W6x*K*i#>lCCNU4Q$jn-(o5j+f=n=iOFE8RM z&Y5La>K)D{+$bvD6)DXMXtsVzQLD*$#M0t<6JD}m;F2pEj7l3vik0Pk9$R)YVwbaz z@pijW)T!64*%Ckv=(-_0Wx%3k!VqC({HZ19aK!E#2pCCT`G5Pb|98xPc8>qxRyAvk z#T>A~b^p)#U9tEg0?Qi`;s3qnVVH1Iztjh#(8g7s}X#S9h6%A(-R zB-_E>pd{=qdJLK?fc8?G)vfJK4c_Lil4OWp2fv?I`1AQYAAuh&p$M2don*K<^)HGn zI0qr7d66zA^29BEls1WtxQwUfp{Y~^~L32N1J0j-yX}X$0_F>KSAlD0f36Mu|SKj_R%6*t`UY_E=K4cNl}c_#)neUMaINf{Nj@#_1AkwB3N}tC`mdj~v>( z#O96e9c*U;!NGl4Kxa9|j<~BxJNfVxI+52>;`l4!5T>n*8#N4#ZN-WP@LvJ38?}?Y zd115~sODA@pT&0=VFT@V2pd)FsAYTOdt>C75j4^wdWsBbF5~a%m_FA7qvBS9RGks( zO^4}jda?Qj!YUY4L)>!4@|?ZQHWOGq#Kn-^-vtli^O0q{+7@tbjOCEwcC0SGcS?@j zp7WPuaMu}cwmX%j7uv-=?DHb#1QB^1P!+244lUyIjK7WN%%d|WcNj{}-#PImM!l}k zvl;r?!H)&(j9v)oL(e3LFb$ z#}6l2(=yZ0r1eFh#g&Pkwc17@2s&s_f@Hv9T{sbChvU*Mpi`gITq4@^44o$jt{GUVWkJh@97B8qi{ zQJ27sjf_>K&~hi=AfJqj>{~4g*TT;dmF?mudA z5vPWHR97Z3v(;(h04Wctj12&OuER6cv9Iv(hvF_2Pns6b%Jr?8utP_=QD|5;nylrL z4T+0zRxXMzIX#dnc?!Q*DG#=wkd8sK#NFk)Gm^|6lzXRv-M22JH@E1T9SfxG&)w|T zR}?zH3}Zs#5ocpGGD&z?nlAhm9Q*|pOfHhR+!)};u2YDYAIlwcHQR}>m}9WctF$Py ztr)ouw!4pxKnf;4e#sLWN2|I{DN1vTFrK4gZiS7Fvotpm32!EeA$S1oYPu6Zmbo#Y z6*G9jR2a?3c~voKHrvEn;zbru%hNczuqAWw?X(mJm%sXDI`p)D`c69bO7G5|;dm-Z z>VgwysX8(HuupmBcR&<(Yn5L~{q6a;tg~Zd1TMV^k(9FhOk15IMq8~~YD9%8Dt)$F z-h?rImOH;dq<-bKR(Ec(+KOgnVN|Q&qYsi>zAV+6D0>H@3SIdLyipPmvzlS|lJRke z^r%|@C8?Gg#f~uXu;C~^0mPYotImpFCOi!SpV-%F8c6XFi+#Gg=og4RgdM^?)*pd<{o6rknIn79HU_N z>Qo}-#X3h`NtwqU=d?iPKTo802T8xIP)s)_9#JMvnS^Oik9X;j)au^H!aLuBov`qM zG2z294(X9uD@bpd*_yxhCM|mX?QX>9;D-H?iKr(dLbWU<7&>CqTwmgMl12cOx&*nf z;}`~VC=FbSoUat*_c~^)?YI`K(VC~ojT;x{s~A6o6ZfsFyDN)IsiNU(b#0O}NJ{6V zhGp~m5b{ z6#WgQ*Qbf^Z}TzQ|E+}ncL0A5jvp~NjFYpYiGdA_``Z5({dkn{SE)}Q1XTBDzankY zUO$>f4B_b;^`5H1y=;l6(O!QNsyf9TO>e0(=;H952;=H|$guzW{_vCF`%=yCQ-`;g zp0AfyujkCfq!PHX3ojCR61#N+?nSP<>$11k9s%cg+<|WEll;ZXtJ`AsD_Zl@gd>%U zH=etRdK+yEnhzrQYe0|d*z_;E=zI_1NDq+P+t=;WdO?6hO-d$`^%8|koU*2MxeI-! z=DLRuj*=;hgLZ#9QvnWp%a$mm)@h@0>nW1_P(oZDtAP5;#e<83+CnTnd`xW_pt;h` zUEvT%362nM%nPr|!eZFZvX*C?iLPB%e_(;3%C8XdTXeCQXBlAwH_$w@YfaChciKyJ zvzZ5&&dc^bXKkJ4!^5=Gg$3*mth|hR$2z1RgAfrLaMhd`PE=|ABoPIn%8E)M-=qi> z0(AiUysH>9e>&%|4>eZM>z(|wcE!(dGcBs#BALE|mP8Xf1VQ>cjY8qV?# zhh~K%%y2k0EViGGKV`@`{mAmrg9v1-c!|9`2tULr|pCCj~nM z=+1rzt}ZZbltV!IPt$85<`>3hg({7+st2?S!%7}#&^V^aM znDMm0jYgku?qzD#?Jy4 z%{h}vTB6l|d7NPd)k-xRdpw54egU}=DKK)M#9QfnN`Rf^v;YKG(aI~{gc0w9#0kSJ zffW-;)#jh-yyiZJy4A< zP|t0zKDcOx^B@;OCMAhfZdGLL!}bOsG`?=SD~^nNgKKud{(g-?`ACm zw~?46%_u(=gBlLd@C&58-Vz0;RIDj7l#4g4jn@8$5WxQHwzdL?*!rAPRKFv`J)<`( zbGkiHOmvIAh>=*l;Rq|U6y@q*t*ep-MaL4V45zdjb4-Awaw73)o}6OrGz~LC4U#^3 zpA-8TJSI!#h?KO)y)1JR)S-o*8rQxiflM7IGrub54zR^4qVanF_1v?}DP}i=I zbG1}8-p2p#qJ>*J5o*L8nU_f(E2+Ati6|L`cQ`8IgYxb~o661<*=$N3(Bb0)GjJG6 zqr!oKP z=^TK=nnApB{9&<#5r+-nyEveI?l3+Kip|b^;TDKn^9Hp3<_n6`s%D%keO{kr)uDs@ z?(L%8ej~VGk#Od9=)f9Fj~B7-v%)=Gm-_}uQ=B~gU&=Gbf9W$|`w#5Y=1-F0|Cw-? z#TN~+C>DS7lkwYvKG2TlZ|02upD069917_~vvVA7pme^DNqWH#yJ$Y$SK2aRmyeYe z>1*tCzxL*G<>s~VV<>y(f4!z zvQxg_>NJ!lt~lNp96x;xE^GdhPd>X`UJs5A)b zvj-qp{;`MAY3i84l5GGJ)LOUAGo6WV&r_26C~2uW5Obz^J)1xykX z&wKJVXl+eCDk{racXVw(mlO(u%Q&qk29-+|EX$w_= z1gMO}Bp6!4xTW^m@*xRkRtFoV?+?McNzq%*xa9QVe51V7f=Nq~dhJ!EjJp z7*Ua*0XRnTGfir!ut}GUf+t`Kks<{(455wB9bNd9@T7HflMtIo?EJ)&JI2Z@rkoZb zg?e6zNHA!}spIXLLXXVMr@hZWi<-qjLOE`Ms~_!N#NctoIGDt{2=#( z{bl2Bc-eqRy=4yz*eJ`9QH>0$b~WRSMH6wY6k=$r?s9oP`br?PJc!8UZuWa_-%3$j zZnb|2B06!H761~u^k!vrt1ok?o2xI5Uuv1Ih9k%yY{knJ3&_TjCr#jvot37czoLmDO%B|9nuf?Rf&ezjxD2@C&cbE0|C(AN z*kStL>#!C>GuV_9S8T zZdp^(V$ZaPWVBiwogZ`YsAqY|n{>IJ3^sRWRsB_Y{*nEDl|5cjO7sV^h|HRA;Fn>H znkj?ZOc3=aursIV;5G@A%`s=-BZKMz9mUo-9K~~|^lq^ij zDur=J#VG7msq)(Z)%6=0=#L$WISrkVa18MD6%#e>T)j$O9$QpmA$GAde-r?$T)o~x z@1N*U5$=nBcF(WzOKcjSnfX=09$i}g>vj0*6l}s zE?$wDVS3(+@AtnW%ptGi`thD;u5ZuQZJb~!w_tffJNtd@dy5*r!dzt&W)P_R0>_kJ z9Ob;LV4S;X=Yg)aI1wHc;ETA)>A#(QBv)(1S@O=Uo>y_N-7&kN&R0BBaHR`NG-#xB z%rY1U=a9v;54{f#Y$ToqRbWA-nioeibk+9>D3%P*y2m85ubUrnLm##IR>h9~93Uu* z!k!`yE|rSejRs+3|hC8v~e${P|dDeFRiJp>4o-Odn5oFkgZbzrO;tbi<8xG)|2Sq2V)OR&XQZ)kbD$7rqowhMIRh*~qf7?|$G7_MiKQ zt>)2wYJIwuIl3XwmR@0JJ`92>{h6@=8s_B>)-vQLkw!vbi(5LE%#D`sEe1DyU zo?95VOJ`cFTEt%5 zDJ6UT$qorGii@!svO*16#n%VBah#0?II50LZicrHDtA0#w5qIeD$uLTGu0^BkYOnv z^=6jkiau$Gl(LS;+y+nIs@|!%c>cUhv=Fx~HR>f)>QFurU`)*8Ufm=JPnud5h=voT z%-CK~Let?4$iJ$1cS-1yB2QS5)_!e)+p&>>e#k)S3!~gzPHMo%m!}3sPxj8+7tySC zrPSK^Ru4d=Bt4|{DMw4V&wnqd0!PE|@Tl=V;-b$gtAT&!%qe$~lCitas+26WOqNhB%oYE=V;)XJ_--l8x%-h!J8okxi5>~l%b#%q09bFJSKe#GpbG$(UjX3 zj=*5EM?#v=cK_3!WUa&~E=;xo0+xnk&>9vtYJZ89f7<{PB++J8*1%H!9o*lUM&L$;WwX@fU*!Kz0#tRnV;5L46cTINV5QnueMdzJDhnResY9#%mG z(1A!T-cuC=yMs`*hWa%5$(=KK7o0_mwFI2M72lkIKfQkeztjA>f66M{MVtBfG28(x z#v@xFi=b57uW6d#LFw-L{@U0wQDV$SH5bK)g|!g5glplya^zFxz$@o&m*d`6;6om` zIf11D+WMH7RC&t9Xp{(VV@GxBE~3S9k8wo@lvR*$Bg$Z<`jHkOof>T8?4eBKg8<_} zUS2m2S5AGXX(g*}Q30hz?+Tji2+kN~{kF-vv`*l(DplmQ%eoo-YZB?ShQ1suc4j>_ zW6HvzRbmQDT)2_5fNyRZ&Hj(2oyTzOUIFANL8%iL3J3^c-%(p~?8%zt#nGiQbDoS# z>_vj?-N0WB;fiZwX@qkNQFJ5y_@!x2$~^G+SdsdN>O_6nYop{wlP)!Bvj_2^FAXO4 z*G>w5;}lCs9yqGw_G0q68pjqk3gdbD=Kyb=%}z%wy>z0v>m`d0*Kk%VX%%W_nWztL z2F>YLcUxs*)uU8XB#_oy40#60DLCi!OoCX|Y0tWq%{&40&&syPqD~Rj+4XE96PT2j z?!XrI1;rcUC=IbK@H`#L=gy>VHH&M-k|#GJ3i@|3V4H2m%l0WsIGiMo8=TLpHmZ%z z9oF8v0`o^r_PFRKvMsI5Q5fN`2;n^Vb;fF$*g|7hB1biDh_QD}hRZB}rgWd0B29ne zAO4Jd+KG2%ix1!w9+|!g%!v1Pi1IzOc#}JO9(OqRP71r&!SZ-)eKQ#jYYzA#^SxbJ zJ=|}(a9tQU2sTmcH{<0|7%gtsh_W1ZVV@k%`KLw^rNgzgJDw_ia}@hLpfUT{Pqd~M z*M!vCHSpr~UmHhNI0#S!TnLeD1(A((f)=R5PTP1HJzV!JOX4bp9Bc>z{`lQc&q%nW z$UDOxL0kPnPX=8r`xmQ6+t=AS$_|4jqimlv<9}q{Zgu@4KzcHQ81wTnv@MrP&$-;J zX?rATdbts?Tb`aq7Lom3Dk}%#324`W{n==%kDg38h$1$ z-SIt0k& zniwUagMt29Zkm*mu+mgM&R7n-ghM#govBPh;)QM+X4NSRNV-dE334*-1}(Zxx!!Rt z=E*Ujx3C-IF0wfmJWb!B!z_2&^3@V#vO4G35XXdMqmRVd82!U-2P(TtomiY~*5A50 zZm?`@GM$8Mf~$RZG;8f(^p{41e(^9=;YGtLqgFeEITlr_C>Whx|A)%8k(hvk{-(ri;gXg=YMAvd~Q z2O-n^p1U1^L`g8_(}|krHCzzS#_{t?WYqy;gYRF@SzA{`$YSJQtv4%~^^PZjH4^zs zkv_hSRU)4V*tZi(7xe@Gm`}fyzcCt+*Xz57{3SQin(xjA;_$6g9BJkjLO9hx0wIoc^}6%L9s}|Jcp1rVBXV!krHyu*w;F@F>hHrD zmd96P22(mk*egy}#gNT8#n!v^EzGU{7(I&xJ57rJ##PAsgOi!5prNoEb8Xi^`} zGA;Vlt_x{`091IYxpy7IgVOW4=3DMaxPVQE zFqFS1SI3mBCap_g(j46lbw?m{);=6=o`4KSL!#==_Pb}4I)`TzUVuNS-RR+A%G;)o z+$(2YVo&wYWda>{Y*2vngBfRj_UAJH0hJ~^KZmK9jQ2Nj%^pQSsR>fIWbt|U4fSu) zpN;}ODqkvo%bJbW+-Dj^m))f{x;ZsWweic|x@0<0KCkclWY>6iM!TPRC^9ZlE>l;z z%_A;WXAS9UA5x*&)uV=Mmc9jCE;E9*G9)F=CB{l1oJ>S=#bkhwWrg_koJ`)!EH!XOn|8JEc0X8^2CxmPk!JyGD2IIYhD*!*I98esG(h`TF z6L#?0<+;Cu<34W@!nzxo{S+)1uoa@cCWjUm4UyfO9}h(#KO! zpPlU@J?k`@obv))66~H4y2V`1v%gBtrQr3XXk?8~Obon6yaxJkZl-(%PlNYKOu}Gh zFfdUpeY)J;q_SVG{t{42*JPslw!V9jruyEBado8?Nq}ml-C)1t>p#I6(fnK|!Y*}0 z<-riY?%*Aph?u`B{+bxaaz##Np^7|S>u4&Rza3c#O{+xRUYB?D9bXns@7yvBnOaJj zl`PG|u>&fMa7$lTbPzBK4r>~%1;T;;dsQWf`<|=BJgIumyyA9dR!9@#Pii77{_h;4 zu#VR>zxK)^z?RBY_PIgjHQlZz;}q9cs=%}N{QFa_>=8P45W~t|2{Vc=D?19?)!O7% z1AZ#^FTnwp+M0YtF(v+kLq(C$HmvtN^EE4aF& z&`stX-De|vk#s$|CH&3((}wGIra0W}OOt>`p@}agOgvCfP-nQkViYa32v(9%$UQX?pr^^?JH%T-ruzW)C>=?>Or4IY)93f zZnd{ZFj;p%sP&){W=FraecZljt%WJQ*Xfg~uQbW54LEYn(D5DZnFM%~LC2EiPT`D8 zwP|V6K}Y*f(9o4oJ9YIfOc99C_WF;_U#l>(*OuFFyh&Q&WTR20e>5 zBSID>v0bG%1GKoR1Ez59KP}vLL&=aD5?$`VslUGTh|-rs-q6DnYrIur zkwTrq@Lt}Agl^wSJYdbldmP(VUCUR?4>j`&+DkM?b~HR_G*@`={F=;JaV0Jew4^)&RGh zQY+w7(8`egX^g+KFrMHHp+*>sCEfYko8RA}S-$X3Hnuu+oD(vHfx9WR`N62|dJ=HW zUgZb7h-J$C{rRbu9$VAFs!XNZkEN||Z~({qy$+~`tJ**6F~$)qzJpMaQ9;BWM(^0O z${zf*a$T+eA^}A0a`r9TB_@pu!^7pi-d;Di+=EegUte_n{@olu4l6Ut*A;N zU72H?c*+?5dJ~;M=rErg((?4Fg!rGRU$D0FVEBQhnWc5&8m=YApHR1C1UB7>6`aJo zxFMV(ddrTYeJJaU8@pI@nuO9htM5HU%U!YA9t2!otksB#T7sM3aDwzuSkHjL3}=k> z*+8?3LQJk3-aYW0L=Bn0j*J>zC8YjA5;+YvUp&^=?TE#>|?)M7V?^?&R~>d*zXo-kJ+JY8Sp#Y<1;S$6R&0nTZ} zuA3F;GOW-xyQh25P7!_bR@-mRx7Og37?Gt%UVC{dLCRPA2U{E38ZI(@=|Xw@x0;di z@WyZiwwVBy<8Gm-O}9*|W~b3Xi2>3A zy{#SdVJTKf%V$UYiArem^;mb}9Ges+AVYgY%57myuNbV?3}Po=f-Nj^hz6JHL(m-x zorx=1>Hy-!yK$$?9;^)Jl`j;!-GUZyECrG)bHOxR^W|$Kg$lI2>p~pEj$0v0vKBi0 zN^uT0v&4hN(-^Meb&;R=aVZdi%l+cHSF0rZNTMrYr!zAR>HmU1bW(4iGTeT1*Wk4k zDxL9O1A^T($qREBBVH{&kdE9gGgB+zI~eciMpZ_-Lxh4 zJ2N0v|J>SL=5gv~dMxZ>J7mvKePR!R%`8tUsT-|?U$4&RQ-T+Xl~nQM3BTlZ5emYt zVv#NkV&V<}|JuWV{mvd=MOat|9%!R^S}b4A`0g0yF~98v^VOksn>{k)LKxMxZ4ITB zoe^vItSe#)ZXeV*6Gq23yW9lAo@DlF0O^Pu2*dJ|vRDK3b^oEdeR^F}(984=Y>iIb ziMc9-J}?scK;)kzTDrAEiL#r-KcTLF^0o6z5k$4mP9%AY$Ka{*s= z`^V!6dN1LFpl&A=j1O++K@NA;%+Vc(f`-M_co*6|u#Q})0+Z5~4j%QH))oV5Ak9H4 z{l^jewiJ%b9p6zYpa$#$cx3=xtCWqs#Yy#q5*_?vW?2 z3%qVo;ke3Hx0MnlVq7S(S1*k{K%<0n^0H^Wp(Rs?g>t&e7AxR)0}DZ^iw42`7oKMN z8UW$QS45Th8J4%qz*U>>9LZ&(s;0!9z1Hg3_l~Z#c^^{r{`cEZvO5&k&gq;twg0PA zI0>;t6_9(P8{1R25Bc_hGc506``bNY`K0X#+JH=3XVIjSYWn`craW0YPpvn&yhwF8It@9Sy4R_p2UF69`P#G|ag3X4In?w9yED5=NsbBa(aNauMK{7dI2ne z$LRtt>FsHd&!cKW<^SLRurdBuK_?~_rvC^L{?(NEA4^sD|5&Poseigpq=Wz0Qk7%v zd1mnaUHn!ctl3~B_lsh!f0`tPCLuO9wuzpP?u=;A?`-e)2R%K(cW|#SBA=hz_gCA; zo9hqyP|uW+%RaUB_^%Zsj!!!PX=`<2eSao1$unVI_PKZK=dmZ(AMup0(1@2&k`dx5rt)m4WM(JH@>|UTAwVdL9XtoetafEoYIT~ zS!{vTtuq*V?mZ_fNJI9H*?c>pLo`j#G^7PCV|PyW@{%xIDljj; zYr{(rGYQuAgq%};veN7!dMX@X{&f(~(cz4_5Nzv%GU@NmB8M4xpJZI3jtwRJ_|XH! zX{2-mFN`qNOal}u-Czd!2suno&0;h9WLM|7>+f}~E*yIoe>xXtB-|QhHpB}1lV+s8 zER->g@>D7am$$@4`7)fm?j}QsnB@?_uSBTP(RAxe@@`4qqELsa_7GdMo*~zV%B*d^ z`kBQ#VpMczmWb)RerpPL&mxseU`am-nodyGALfB9WJ`tbW}Q#ag-;o6v9aMZ)az=Z zWIa}92gjqCU43@xt&&+%elc-+C2oQfXDmmAyfNw(@-~>@H#{fwk~#`M6etz}zmU*2`(wiP+UWuA)$(s?EE2e@ncQjTJhT!{RM~ zBsGT0eR2)1mZbRqu?TyqN-u^1rSV`N0%01|IGD~)^BRUaJ|x;UmXCLJj-`9W@(JzY zH@wI+dzj~7Ikq&3K0(#HHdX2;@+$^BOMf^IvlC_m-7K;nt59r%_56x-3E!IcOk_o^ zA+caf5F{g|io!5!D5RU;R=5hb(y_8JluR%0XVD93_^lhhmKT63FIVX;y`L!-K~Bgb zB!~k!mP_?ut7IRN6OutjgNqNG=~ssfLAY5*XHq*j@@Y9KT_lrm*kGPiC0D}$nm+|Y zZtnJ5E#4SZZ-wVdbIWnwgCCLYY?8cj##<#}L@C#qn7^DbDe!Ywul&d$gFil?z^)*Nzwns&Rvs_|bXKV>otKG{`*Hn{T-&tP`0-o$}UwHRnjRkR^5Kn9cr zu85F>vMXSjkH!ip>J61V$;K*lkCkHux>Cm)cF6kj=&S22bm-*TtP6^6y*C%t@lN}T zDG8rxe-sI%iedU<{@xNCXnf%>eA$M6WWkF|=MHql zI1G9^`QLxlp0Uv^1Vijs1$6lV<)pInA7*0bQMMrj@QCOnH|Ykrb+UIx2vyK+4}&2v z+h-lT4)s8VQV=G84lT9uxx-fblw|=@(f6ZkO|1o#-y(WnlQ<L{CB$~%D=FUrVO?zqP&W` z$|G>mkbT;l&Z4~`MsoC7-Atd~Oh*BGP6b@YAL?-@j%83z$0F>wpGf~R_VjHFxNSS4kj0)6F zwmzV%fuLhi2;sYG&x%3O? zY3I>JXx(btk$0`y9Mc6+J3o&>^j4Vi)*pK;>jxZjLBaWLKBI%3XwS5H>|7Aw#B3yf z1#43ZDsx>&yd*IDUj7);9IH^R$FWU)XCYjP8l;_zp!;%Xu(hz_?WU4TsysYRxUMIJ${ z*AHynA(nBcwHcHRtx^u&pf1~Nm(@niCWrkzp)(PG5W*G z0b?dre4NAC^vk0AqcTSSTcmR<3SQNi%E8uCd1E7SdImSS_m#B;%F198^Ps<-FP5OR7S0wHC6%av8jJPFTUK zELX@>R!%Tjg^QPW&@Y!f0T-)_-pV>M(NMmU6uMIm`CUZzE}Afpy2$ zy=={_|633DU!Gwx{6`|==L~E5oCRs?9?c^F+sivz*(Cr>{37lP&rkp-869@ZPskf< z<|UyC9nx9$u{GQ%_V{j!eV@jU-ZK83ui5?I_r&4t%Gdev=e^nI`}5u4%H5}&sm9;4 zK3ct*zm&T=>U0QCy{@lozMYb%{F2v2EbB6rFJ8%tJVn7?U$%t4y*keROlvlZXI}V+ z2ba&adQUDaS|gAKs;yG-YO}hMmGl38gyI>wEL!aywfVX4kS|cJTYY+s#>*RYr(qCX zcm#_*2qm;d4sGCePw~61jASwMS1B$01%0gaI3uL-R}S@`cB3l>gXje)lcIYo=K*Y} zDkv(bek0c;)nVL1Tb2rGCNQ07(K<;el_C>EVox$LZz`JZy{eypJlaxHLOT(&{NHHF z9DOo{qc_6H`B1%9j5gz)o?^$9C#Ykx(T-2`5|c zfjy{Ze+Vig^nkEQsWM|lH435IFdB?VY;=>5D;cvps<2nykf$yR$mM`KQ+x;;rvH63=2zak0(=x#*U6#eZP5{%kCl9w= zy_U4SC~g^sogPe7NyE-oqUi=Be3cZoga_;Bm&OW=o)S zSq3PelH#WQnID}vqkG^M%Xp-$maSsYl&-JlPcHSQ=QzYR#qhBDPlnKXINsneSoC8! zz;coIjbk+%;mmf5Mm%F~$?UTVFtJ+L`FXvyB49N1CUX#AQQhH4ZR&OySHbnn_@pjIhQjd19|( z3E)N}PkQbN*8oIi0ul2uRd*t+i%GI#&_hU#t^%kY`bqNXsryp0A-Rd$9>7o&93OJB zDob?IKj9)~sY=LuBJ+3HRG}Pu!#yhz^W3$zHDwM)3YeyG-m!HtC1B}IQ0|iVCou`# z-sTUtU_Vo{2x@ziu%jcqREyJkP^{r$L5ZXbaUF{-Pf-vrFUG_xEv;D=^IJ)WZ48%P zj-_Rh&EAfv(Plu@486ouK!5~q`=Q0@vIA%pRy~35Bt7nNOsfYX!=~8P+<@(ZCgoN$ z)p(K+vQKuf3V?Q(z1+2~b5C<3DbP*jcfW|#Ml}1kDbf&jm1k;kpR6%N1z>z@3~UtBCKH+#2gT`e^Aq+M^@D&C6z-$Tjrh9FWN>Bp+ku6Wv&sEbda~`R}Ox zS`=a`>r+l)DzcsyHCqD&Cs?4?S{w0e?DMH&a`n!~4Cl-(Kwc0_%|3Fx2m;k`^-T7S z6iQLG*r~Kz$N!#EU?+;-1YqH>eKG<&GN$HzyY575*7d*UEf|z$5!H zc4XC6sK`Lf3#oLzyWa7bUq<5s@e|4Uz%+}7QGuig)zC|y`(uzhr3r;N_p`OHD9lzP zbg{@p#egFT5HMu8{X*9Pq4KoNZLL^3bTjYz#RB8~ExoXju=Z5RIN5E{z@1p%E(~GE zKH`IA()Fa`TMs5mA)l|#5O=&A*sbX?Y9ieO0jZ&h1mIg5tDncyt#b2c`&2Xxc>bUvh#(w%rBcf^5DhEfJ;2u|ya z_gq6@9dV6PMcCLDa};$AXhFP&Jduas02x2@SPbH=rfJ+MbS|{BNsK3vcTpo)s<2aC zZQwIsfQxbd7ZLpzhozz7e9a(xB@jFGFoMkIan13T6RjJqu5vJMLLG=m%Tje1ww2Xm zKsU~ykx*-{I}QttV~k<6y`~!r)GO&`F3#s4K^SprVWztZfRzaiPMPa|Z>xeh!Fvy3<}&5* zOpM297xGoB2;e;V@8>OIJC(3wmYIO>R>t^G%Pqp2ocr1XgDw@<7-$Z(b(=awv*F8I zFyKk0O%?}eK3|%?+#WdnKs3t{>L75E6h4-gBl?0|Y4Z{!SJ374qH7h#O=b=U7eOgb z(in-PlF{0f7AT4>G@=m;KLnrUP!3xK`utvGr_oT%LMTy39gj^^76N{S@4s`c$iXZH zgy$_j?-!5}sROzoAUY7-Yx)g_UR_zCa#yU|jj$ zD8{>J!=(BvDqZX9My~7jkvnSIn?Tv5{DJ`Y$wRw4t}d{tpN)+7K(AmQ3HZis`TFZz zK~X-G$Ob7>&Pl}_*x9M17N)K=QmKYHc!fErgnKt$7g(IS4CDTQr;?kI$?11by82L) zNvpBQ0rC{~(Q^Gfo%oJ3qGc$8*X_h<)n!U) z`q;0lNvV0MtLYhZeS@`3h16se63w)yg953G18D2Z-+uOM7THu61iWi5#10 zEpEprj3>^ECl zKh2=8OEEZ@;?VuY7v56>aKX6P?FsGE?zFonqpsO)`MM;bX5ZEse4fIu>+_h%PC?EB z+y2b6cs6KkhU%0ZZ>$&!e5%qOTAdV~38r0Z!UKdfMrp)g#~3-8@qz9{!LZe zM!aRCRIH`+d?j&8yipXM4v0~0Q}QFlhp6&SmS(wjCC$9QJ9|ayy4xIP^a(FRnp!ds zvA09@FwXb7cB9+YBCLimf#+ac{W;TUR8^+tD7|bN3OLdh8F_l;;fr5MiO?9Rt*B7a z3{Qe}G$aXypz#96HxDL-Z5})l3p&iZN}&W=#VD)&Bv!mQfrVi)Ut-DD>R7r{vnzyMO!Q zkUt|v8LeCA0zRy7qnL zO1l<2uey+ojbb;$*#5$qLX5YllApd+a|F(WwKj{f_yZER9v%KI|){(GBf!L2#Xn<{qJpgNCZUgx&SSs+j-D=o2>ToluPgs?xO6;K=WcecVO_}vQq=ig`knh zRR>K9S0hNfs$i%EGTIya)bzV#Dq~TM73*pCSboa=zQ}j4aj)H7NGyi9%j&WEXqE%h zEE{H}NQ-Znp#*Dd9GRw$(R+!t*``I-BLkj&zT$NTT!uj+;Xu|YXH2e|1cOs)6x z{A`3zVMWNfPBUz3Wgi&U)GiXT(E~x$Q^943hkgl%CUUM>ZpNml0(7ZX7iqjO9K&9K zt%7oUb<9Hp^_5T4p^I40yuENNl5uhP(K-MbE7NvcBW88U&0fc$meFZLp`}Wqh)eu7 zZEXpiyUZ}%iE?v)NW>PxUu8#icx7$#dyX&^ZXDN}fzWL-B>U4`*`!g;RM7t5nVI6Z zj%LD49tp;o7F0KFIx069xskR**YsFI$`?eh;Z;D3ETKX}alyg?aia!0q1p-wM6Vvw zMGg>F@mOq9O8U|pG&ImC#4|(jV0cDZbvBRTLG;6lqKV@mG-&zX*bMw$7v;c%lfX7+CpxAk!i)`DUdAY3zsLE98n{-<5EJPV%87aaPtEsNQ><@IVzq`qGYBUm4`x;K^;Dlv!_d$@+cjz5Cn4_npjY58AqHsMl*wnDJYu}_ z^ZrrtPnep3a?~9zM1eNT+yf>BAWi>siU+a7@7`4pf!?m2Asu*bUd)z-x5nbvSXpY5 zo%`lLeFP7m+7}M$4a@a9=Vjm$T^|F@40B7aa_+l9VonJ7rtoXr?z*vD^DKK=p-v>MGt}{m z(hut2?t2b(ugq~x*W9S`&YAwR&yL~5i8aR`)X37Jxrj{Im)AJB9|v+F*Ks)wK{lP2 zsu+u3GGfMbQADMg73+xZFG#8hNUbX1g+ylIf3mP5xEeT0i^<;j%nk<*3|E5fKYjfx zE%qxmx0j{?U%k*pdM|!`H$FesJFD7*^(ns~76V}nNUBYl@))Hx92aMIofIcL9>@l;#G>QJ{Y9dv&3Fo1Jw??qE5eP2AUW?a!v z4qMOuD|!Dv++i{PS9e$pZ1n#NxOn*k*8kbX`pID(fme$!TY=Gclh31^(Dv`3>I}Q> zRd3gv2DXm>V_;i7JRtDiIyCvdrzSC{*umr7IxKGC9n(`h(|Y0W09N!QE9ubf zFLR?Udl;&;cPcRrFdb!Dd=gaezxE)ZOyiT35sa+Kq-zF@S)M$ToiAjlNepz0?ZIs`{$2t}l z7TDk-(w8~nfV2U|NF zTny!hK$xgfSp|ha6}$;^WMy&WoA5#bii4 zn4mA#q8J!+>3Xf5J3cCs5MO#mOi4Nn=<&cClUt=m2LDqoMK+JDzg z%-iqb?G=0Y%4eD#_s@f+&{Q z;#HNsgvl#wgH$orZdbWj8)g_aodYo{`~!C=YF7x!z6Aau{K)IwOszoG1O?4Wo->CK z(1T9iqM>6WI9XF|N+PzGg-z z9ku^WJ~w?=k9uIJ1{%zWJ##T-Zk{!pC-jlQ^ENVYMw_Znlo+rSh_WWtcpRzB$ViBW zlg%;M-W+JKy_0GtM+6a#H;a&;%fd)MD$hZfbh0TplF-n`3r$umuegJms=i6F93>*D zM|1$fx@ecRkq4-xZrHE%8qxGh%q@f(X+zz2AOxi*l%3lA-C_NpedqmRt{y$E{qbuh zOo1jNihu=@vPPs{BBpW;5;+C{r3uo^41$PjufOe}_9IlQBuTGPC4)>UiTDS{DAdaA zCC4`=-jluDA#&cs>2YAVzkghq934lT$+z}9H4rrfTWzWcr!pckS$Xi`=W10L($_JX zV$vhiQ8!ZA#YCZvp_YM|Z>Dlsa|iGFH+T4#j;JT8du(68iHc`@K zJK0Otv-Wd)-jQ5QG2_q8`lpYQCaC(<^hB%_)pU0;vpZUGdc6vdP3?^W{m%~4#q_!y zu8LsE+su*qGA0(y21#JD&T|(z|6TAwx(f(f%>B#Wi^(0zPLm)vo zDxxAJ8`8>}O#$HfG4nIUQ0g6(sBeZrk31DK1gB9}`a8OnNg8xF+{w;eRcz8 zg^Uo@Dz4wEKe)S|Uv=~$H$<(at7l*9oA>!e`j$&ZYn8H?A<}%!A6j#+6-dd$0^9&J zU0fD%umL-r!1G@Cm#+F}Va70ed|+G#yt=-g$(!O{<$bYMdSyioNblrQtYk5>U zBAG}9bP4rGeW5cB(;aPrbjU`u$pzY`AtN61p{hp7oqE+H1jkI$Kv=jBJ%o?A7S^i# zpq(&H+Zh3+aMIPTBjsq-W23@{){iOT{oJ25AWj-L&)%07RE_s-SVn9wMSBEGGe_2U z24_2YXn{0oZQ{XXq+^jAw+#hjE(Nl3%1&MS$9?GZmiv2uxWc%|1KOR(u^w>%tS0D_ zH2cpP-ycQiQ`87%-!V9P=V*4Nt+zeaghI9%i}#5&kttWS8-!@lv-r|o@F=ik^?@Et zG_6;@hIDJ&n479^UTWVXb!N1`Lrq~Vk&h0i1iP+54c^C@$k@$(AN@foGAa^NKL~>P zFN}U)RM`qQ!J8uy`O8a$?eXu3f96im3-ViTgz9!U0}fE=i9Uho9>JCPnfz&RA3uX?qf0htR7R`{VtBUWRD1DSGJ^jY(@Hk?t@Co z@m##?Sst6E_m|fz0u(`tNOE89<#@fgt#+f?WO;Xm+B4$vMOR;j~e?C*ZPDMN3@W$^MaW9S41%p=4LhQ9J(7 zy)sR>Vm%QK6-x*@o4n3B8w;%sZ?AGQSW5sr8c)?_>24@ExVSmPcD<}JtTbMQ?jMak zWr1KG3lO=VlW?x>BliU&`>eUbQ)oP1QsLW(no9yz0q}}-MZqT|T8W6A!>sx9oUwnq=moiRGPMal2 zbrKSf%~pW=z1OKvOlRecrfbrCuY}vowtX3~yv=59i&-}A<8rK9*|98;bX%KQ_}!m_ zmvl@23mW>}8Z6NdGZyn%#PQ$rU7JjX6k#C?L=!_ei}V`izgnE=WY96J?Hv@`8QaAH zu|`re_m?xc6dDSiFgXbuNDDhB+oM|5DspT+>en#o6-&H^v zze@P;jmV`AXoT9aO~gLPOr&Ou>Zx_SHj0`3HefiHk2sTu&zv|-f)#sjQJV|Trt%Pq zW2rvHyDanUmoeF?RUnIv4;dI4@P(003=8YkNjL6haP_noD@OBV*enA)>K$8R1I+?_ z=C$$Tt%u)d9*MucmBh@xyE2Z!{A<#P^%yv(*1e)tBMXPUBkt}1@FqeR_W$ABF#lIO z`)sVN|8r&k@_#Vz%aJG)kPzI-=h04F`CAKxvI%lHx8LbVL?&V#*GO>_O9pb{$BSR? zZ;NEcy0PqVzCDuszjHV~_IA{C`O@ap?k&uCeS!9aM)>tz$%J-ECryR)o5-5DeE)Ky zCptmQDrha-x9m4V@-`-$_9l7+(6UQsrT2)#6^^MLxtgxBK(UGmA;XZPq z?!w~%TZxPz>DpU5a3ml|>Hl@{=r|p_!Zz!?oj?mtjRqkOGnBsvQMtUI?an6Lvx#uv zAMVmOI#V@t(_vPJ6#G4_Oh|z=+Bl^&Py>cGgl%UYNdv;n4*bumBdl9Z83Zz&Ok5G! z@SZ#!5E$tFwbJdjVJf;e_=RNKQs%lV0qZb-$@SQ$J)v}!0ALIalLA3A-jTg z!fTgy_rRTGDbR4d6C)8}NA5<+v6>>SokTJ6V&} zZ!92C=mh;UB6^X_q>~=yv=+%;VAWpXJZNdxuv`~cJnqQpcYQ*3hK z4V!7{vMm*OFWH#IRr*IN18<4p-$W;j+j;uJSCbLtQGq)8jpmqe`$c+>tMs_YU9J`x zh)5~pW=(nM6Lq;;uYDGd|wF4CgdLly70|^j^;)u35|K^{h{E zuM0hd|F-TSLo(ceR-ikZWZY9;a&0=9uiE6AE`AYRT9AOUWEm%hye^`_DL&~^l&J6b|_i0akbmO8#i;IN5iC(}7GSXTXZ z%wy5#ci1C(Urx3WF#oF41Y7Vd(i4}UpGfr0>f}_|-(MAz1^?*`{dWXM4%Yvb`Rvh< ziaTIN=)I@914p{}QN)Tm@&Eo~OEvTJbCq85+N=Nm4%C6~y7;riLx9linz*h~TUnQz z+bieF_{zscGX9-)`dRn!VD;rw_3fMI>zU>I0ZMv~eoQQF_e`-#GUAd+OkMT7v~~H6 zZsg548o-d?H*nEL&HXfU>U%*besHk{ zm~$pjH1J1$x%2ZQb;1Gs_6`fJR)_{8uzG7Pq=DYXZT~?5B7o`fKamGfvGKR}@NSm# zMox^=wS6LAbUVx%r@#7&Vr;e!cK%q^5{=b(-H zXhvHVwtH5QT)&Bc-BRoS*~NGUsBO3y4i~|(=6x=*+13WCx?XA$#}?s%A%U8y9X^1| zo6?~5GJ*7gpf^>}qlK3|3C296aiUk-!3M0U`~#aKqn8;hb#s6=Dbt~LK%$*+xH!&YK;Y+n z5_j`K`8X}qQ;9Nz?evPU${#HW2qxKhX=z!PkR;;lds~=GINvcEYsNf_BYTX2Q@ z`)jYN6n z1tAH$5c0W#$ljXogIqwQGHcYJj1m_K$PSw1Jb}s>EWHhp3#Y5}M#B4TRf1OmEJ^X; zoUv%Gjj@+7?Jsd4#!5_!Nd^>Emb1H&29F?P_KmQhNjpk-UyyTIm6{^hIlfW}yQ-Wb zhd?wx0@Ab+2}zjUq#UO|jhTyKl3f(uUq}*dDs!za+7L8ZKzDuONJS#)b;)tSTU%al{-#zEa~8Naz$@k`bPSDNh@`%iv-H z5P)oqbXto(sn9IX@KX9^D`Bk*12b#v7CK*go|oI_ZfO~E>Q{W#Teue6$y)#$Hs*vEkSoqyuM!uad6$#%T0GWSZ#$MJI;?zi zt@aX(GYozaJ*}raMI1{C!7_{_gs3QPToqtPr2CqPV(O8j{2+Pgdp#*(S}IlZbwW~t zY?HH?a3|>yyvjB!5#lwN(cM$d)vW6Q(a$n?+DQAG-<`;(V57^aqmwOAcIvLRxz8n7 zKs^324ewW2B|NH9gF6z`yAL-gf@rm^oo2s?pN3YiGZ~&>_NSB*P%dP9<}g!*Qm(~I zdxPkugMHAWoJ`B1Hz&^Xs&Wg+)k!qs==26Dg0|Sd$UTVkgTAu~i8|2P$!X9>Gh;uR zwA+cxNihSM7)Mq1G18?v8uHpDm)LgGcSpGFUoFmxCQARh-Awa)TX4u&G46%eDY#4AA}g$N8Dlc|TS1n1XN1&GII4mrxsL$8=6z^5gBn zGLpXq*4~xJ9cQ+3U6>kMV2_s5`vvecJPk%xe#!Y<$eczrD`T&9cxTy+T+o#8Ug1~b z=sE-6*zphb_0YL3;jYiVPq7Zz@N^3mfUk9nI4b(YolcG?;CmleR!%Tn$-<0Y zyfKzV6{)5vAft9-h^V&OMc$mu>F$$1F@DTk9eS}&C%H#o6R#2{XJIP)*m($=0oh_R z$hN^?Knc0F(G`)7zF42=7OXaoMOMX(<}7Mg5LhXlJz$`iHx^okkOcmYIu5G?&wZWkQ(^T)$d!%SElnSxBCC+EO<7MCzphUIE^(oG zut{`uH}1F&$_D$k_iWr%7YVJL#LK)kA-VooTLFcVj?oaIZ|=`0$G1m#AI-EC3OCP=yl!39A~~}%wCju0!>4Bv zh-b=R*fl@hFV4>|$G3$xwqhUqsQXr{Iz=yv;0{Q@zL;IZ+{dkca0&exQKQ7r|61eoPB?MC` zx5pBlk%^KnS-{S6R)v#3|eEOl~Du`O-S-1vI*OwL7lfHXby66cb%L0@QDcqPl8+$B=LS4pc^wRt+% z9ZK}-8?x7VkzBtm*dKcl=DTTXMnT%oMoXPkQ|d#%!=DXyMw6BCpid2AK9+r1rs&4p z0HOELlui9Q_S((Ox4WK3uUOA8mPDfFOD5wx{tYki+Q$*yy??6OjrbEoGUI>?B;j*h z)_eqzPk9z?5gH_~$G{l)tfInu<^dO3|EC=Dl0eY%CA}*_^FRc2zqD(jL!|XrsQ9r1 zvjl0`7T<32SrLG`Ic2HmYO9Ki5aYxw*wr7=mJQstnj)Cy5-WbqL#j_t*aFH2oJ5Je zrJ~c{c#uvD0k~}VrD^>9*x?_7QgvDiZAvjxmT3KgLqZJo@WK#K{N1gonF*Ay%?A|Je0KhQ>O6cWw7VeIBJ_V zhrZT_;;A|=F}nP!z*UZG`LwWFmiGGN*of$;@FO^8p1fiytz^S7XqnElJ<$Ctw+$hx zR>IdHc%G9xhV!S0`k12GH4XvSD0@~AbW3(UGur4Ph=CxU5nvA(VDGZ!e3bJZdrWP< z?>8PO1nhwZlQ0ccozNXpDZ|17?3gQ-;sE+dx*o%7_nKbGDXAb(Q&8mwB0GE20E-5s z4vaR~Of<38Ie~kQ;epUC+9#LF7&6AP<nBMh99^%0@_N_PudjWc7!?dUj^>crBbET1+ z_h4@l$DparOS8m%D@PX7ZLI|DxB(wmX;@p5w8)&?BAPXId)m-b42F_iSl}<$_f@WB zxhV}8I12!6yncRq-U zJSeaGL#*bLhU??PlInLLXvskAaHLhUT4aF=7Cq_cvM_^P<_17Cr2AED=Z1zk>z}Q; zT6i7aZN=qnjckV#&lUReuNX$U1d@wpVR~Ga=5r}Sw~i5?O(PVa8VYw%999FiMJEo2 z*a~>3vOR!GCN!N(ohebP&2^$2Td8cApJiH5s;Rrm6p%5yPUe$gU8)O%jgg4DaB}yp zikg>tR|qbG8i2V%fCMLgL5s_A($I_)f>Lg=^=+-ox({Gux2a8SEQA%m5k2{M2_2TJ z4=eFM958cHn&gKCC{W&wcq3q}uD939mpt(^L|xNoK^7JdNiI>qzR(gW{EsM81XdOpX(N3dEy zCvn%(MHpiPY^NVH%B#c@kJuzz9{baTQy#EC9)(zP>i4y#yg8_Jt_$4bpw=P$y&VvlA$5j@^ToZ_}m3!9evEyl*NoI!w0>TvYEWZ#!MW*Nh zDKNKk4tN*Wg(f71qWbiG)X2JMf83T`>GX8LhNG&EPctjDX}h9rui2Wy51$)fWZ`9` zj^$Er4DX97K6-Pr&h?}ZXF1aau~JPu6}8ax8ra!5B@)F92zc$#Au*$xIgPZV!Hr*8 z)(tB6TC%Hn`%f5b9k4xi-5gR@EvA};z-u!sqb3~qoP8Wvf~kJCV9p3jEkuRdk zjymKYk|#Gv)Q3H4Qx$hbC+$T+9nlbc&tO+lc6iL08!?9QxDo8ABc>D9OY??`)x)=z z)i#8|&XX?_bUG&s{8R%B6m>ObgFX3}LhpexjPrk!1t@{Hp&v}ns02-kk*+*TQ$0n= z{(4?4QAhRm((=IGI$=dhX<;gq;hv`PhXk3`5Xf%TpSC(V=ni@0e$pg20trUGNb0z9 zZtFcx>1DDWK#^GKF?cJ&#}mSZXn#gP?$Hj4Jv{9XPhUm9R6v%!NNtzi2`iyoC!{!+ zya82zyD|5v6Bpyx7#8guA@oQg<#s)7xap4k4sybKiVVN@GVykG>@AO*3+pFZ*wmWo z&2+$X)wzDXbO8{n^r5rUaNljr=o}x z8}Nw~g{kql;TWmDv(OP<9AJ#qZD00rtNp`2S0-=yq~d_O^ib53U^?i2pIG`+vQ1Rf z$H|3DY|L{bHzsjfJ=_!9^YL=%7gTQU`JWo3{|*Mm{{LrZOT}%m{-|)(PT<1{!|e0{ zLII`xc0f<64+wSpxt`Bbql%lN)JdM@Ut^4H-&=z`WU(&1dqwedW&9kj>3&pGodmMG5 ztpfl@jE2R9RwJZB+WhXhvt6Ic^p-gvRLPO6T4r@D9Mr+PD(-s4`WvY>b-xAXc6zWF zkk<;W{aXZ*#|{u1J@@B$kH(4rN_R>pZVg#DmZ(lMXZ1mBqnDZi{SQ)_lHe(1Bx3KB zlTH(vuVP+lTKRzPBC|IL z<~<{=8u~WzIr`$zB!T8Ik_2jLXvyh_VWZZIXzCqdm;Mf+7a~^EhkIj2e zr#T|qKmoi6gF&C+OsHE0BS9hZTb?ek<3$d8aJ8mUD1) z#sy|ccvL@?Hybf{Q-d2VCLEj2pqOu`$F0=6&GPU&E|m_Xm#=x0YKBjyTu4AKE+tM{ z{pOphcI%30t(zd_{B@Ai%u^IB9I8{H`fG~6i!i2&sf4GBT@V0DgS+8%2Q`G#hC)@P z7_nA6D6m!O>pE`%+MrcjYjxSYIRoof(@&ZTL$5N5{4AZR0{){o-w zzHP}8s#V8fmK;nl=z0A1ldlj;4@MwuP#zi%wfNz=X~DVQnw0X2`tS7xF1VL6sZP3UoLWOfF#rqNjNyp_cuxoByUCMvBEOCyd7Z} z%~yv1QG!^jk;};-ya)Zea-&2u9eMqmx_`8q^}4pjx~0X9+4;FyX=WJO**>$W!4toe z^nTp%xE!}Qo!N!-QuX|qNT}t&uH-BJFAEdiJ?gxzGU2W7D$;SVKucAqxfwN-1W)~$ zJW%++UuP6ipT4+R->I=!X)#fjjJQX{8Ux{>fr%f}hYZVFu{PQo|eB9LeI zKqTJa5zk{9IRUB=-g0hTz-Rb|t;B-Eq^GqAZ>eUgm1{b5K6D$selTyP=C47EHhQGs z0_n)UCq4~bNq<0j*qxUH2{!=Z@F;;D-V=h{iZ!)wq$}8vDr0WElVXV41uX<*BNee_yTJCePSM;03qLOV~det$(k`Tf$mu7G9CzEE<$PvCLE`2c|X8wd_HV*Pk5 z9*%u(r{&*hQsnwRpe+Ile*cGZ%t}u{Phe+g3B}D#Cu(8sY~n~KYHi?bB5Y!0XKX?z zZDMQYY)-(y!T!I3|A+sB%_);Kf@}Uj$d5z72J8gwSYOJ(`+wP-S_vYNJUffc2^ax1 z58``@Q&lONy>x~EK%P2v@VB?eC)f55o73*``Tg#E>h82joBJMY`tGh3V_*=U?Eh9{ z?Qd=;+mR80mlS&riOWH~v&jxL^!i&HA4?ri&p`Jg5scPRHC|bNcF61E!|h-a82B{! zXFG>m_c-FcrFP}sptkNnNc3tG+s?B6d&-yLyQo!wTKAF9-iNqSt`;VPxYlk-4aS(H z)>@df!9PNVoTniVtAgHIth_&86DQ)}S14jbTLf8sx?k$)N46Z01Kpwks+`>$fWsg0 zDk3Y510=P^kiy|MJMStYCU=?h&!=uYr7|6rI@jt&5;CxMa84){EOKDOsq9V+^$)7jF3yTP8#X}_*f~i8P7X$=Fe;`GO|f2-)XeUdb~i6_ zL(PlmdADgc8F3bAZ$x2~p(qR4LIDzuZMLq;7K_1?()l!$VZQ|Vu(~@@{_JWzDt{9e z!y9ji;Xn{}us;$F+h>FVnb4~ALm>whr==GfCvOMhDl!G18yp8W8i!0V^YV%R$ME9-QbA;|o+9_86 zyhg@L=ikP6P+!3*IRC|Ngoxtx*)2JHE0!f@j?aLV-UFhK&Y;xYIntg=tRjX0AIDF8 z3VB&u>aNzu$nYc{HtQB0RPAU(H7qPvQ;V~8TjMTvw6roex@YEEb$L0C-BhEa{<2@pU9P+YQoU7T z^z;pTAIYX``Uf&}GGl9{C=m_FQZ(l!_h7rTf9{lU)~>lGPGmy{2)p+YLxL?LLw1IU1Q+T5$VyV;7#FdaX73J}u|UTRN1B z58IB)E1H;q9u<&(invveePBAu;njGpC;8ipen%(5Xo#4$)0{HxE}3 zYWHve(j!pe!@_@VX#P*(t67>wJ8a$1(d|NtO|LfH}Y&6Qbbem<|YILkkHlIaM zj7+`|ng+l@lVv8u!hBq*|E91&;2v!27rUh_JVi*o3;S?GkfAp7-TLP9yoDQ0u-8o% zB#?&+Nv(T?66r;Kav4HGQ0A7 zt>lxN(=-TCu!-Q`rb0N9WY0C1ng*)-jb|)Q=Si40?*Hil92patl(5$s$|4iQWpR$u zeu8q74f}lmsR>~EubKchrvDXIxYXc^`vG)c-BUe)3nvY+)wdJ``)%cRH~JFv4B88%DK8m8=VZywj>c>!>eU-uW9a4Xb6 zH>qL7kf1r5dB~cF`ukV7nA$o4jazJhnu`Zo>zz%IisM9a!qAfgensymRV8j-)b!DB z0fzuLX>p8Q(}T*JKS8}T1ECwS_4y{FDmXDr`%p=>&B(UH;9$NdR`ckZv8SLRj-0Tc zcdL?M12#D<-F1hPc%@vn91Fx{G)4K$PXC@TP;x=x-9wX+rYT;l@q_Xyt{?WJr3E9Y zNYNGd+91=|1}9Q%Yi?FPt9}W1;5~qDRwihkPA4%Df%nrD_lpk z1CLKqF`!E7LOu{|qB}{1gDtdH!;zBQ)mt*s*G-!@ni!i1{d5#$Qlsc$noS4t_d+Nt z$6)l#!C~le3hF6v!r|9*3F&xM@|~h2lXSh#z+Gqs^Xwo5%{fH!&}c_QC|y|Z3g#Wj zrHu?u0C!`cR9325q%DX@Y(j|el_;B#sDR;)Mzp?ur_ryrscm2d`G%FS6l5s7qUEH? zQ#3I+(?gkL2A*v-Vjp1P!L@JUH-NyqnM{#Z^fW0lMdCFH?%!4;`FD2Rd*4g-abjgn z8HRPZ3ighpjT1-4Lw2TH3j4eWk-WsNCFyfBg}*eh2~7^-PW=~2l>fY|_Is#;-vGCkQ6^ zFA|>o!yDuZ$Una@t@bG#LbL?1mT+z&uCc(kI6DC2k7d;vN^I*SFtXc14+RANR4L_I zz@%d>DcT~*h7)}}t$n{D@1GrL35J^MxO3Q@$sE4@kpML{4yXomnY4O7Q9gt3^kq1~m#&17rIYVlq8yXCn0$+q~NZT8=#HAWxqr$&mius9qK98iN*+$%h;p zSmxyt$^O2_&G@}ub%?C&3%#P{`ZuOX5dk#I?h|FLExj+qF51&7U$QImIr@N9QsHVc zM`c>8k!U(0K+e;xQ8};)o>Ub<$zv5WW4oBoo-tmjIV3Iyd}h7c3Ih?=V~FC7gx^CiS2Dh8LB2W`-*YEk(0!t@g|B?k zOY=Rbyz}gPm}GPc=%^a2DiI_Zs=SDz3>zpHlAx-gzmF9znFKNlVe!MV3eC=!kpisf zg|$l4Opx;79LIQN#0Hz>E2-0t1??;s!FbnBhAnGD5hfU;$S(heTp6~Bq{7hnBa!Gw zyUYgjIo>JNe6A&4uk#a$>a%G}KcXhgNHn~T(>Atbap+(T%U_?(7u1o>?#xFD*O2PHV9z&V-e6PRypGm*Fk~WSV!n8L~ z-BI8*h@OQW0qCdA)m4c)nii3Yq7_>_$=k;sh`wrwKbS_?za_t+iom+7pFGFO~Mo)lO5!?MMOSj57O%j4? z3ftuB+e^5eizn1u>in?}X68xp{at}k;Z~QZ1`^9$Nj2(36|n%{<;6W*Sg)0y8ko1+ zIHb8qsR(zlAqWbuwJ@iTl~6}e>*s@h=i077cCe}vKTUkj(Y;l3DHU0;qu6IjyhZX; zP~l#%Yiwa|P_mwL^F7GIxWAur>)jiqvQHL|F_lYpb_c_8_`QWS(`Rfix}mX0CtV~s zXtwfZI@5Calk*Z`QYd@xRFDhd7Ua1OR)Vluyw%G{wRjw1A3ma6f(@sJ{yoqDV^v&| zTxAi5EG|Xu2DcI4(QH3ds_hskraW4`{S|^l{S`{jSKGlaHk3SX z#MH)85Egv79VIWVYa{b0!%)yotcep6HHhi#)zdhm)q8gqYqMm`VCM>_1?{;8o4RiL zW386mUP%UeYV7tTxtN@xQA zk+BIPgukj#xVa>Cs_0tbjYF7a*x(8Ks32_#_=G3~=0OJQh$7@GRE6;03d}zzd1KLX z4O<{Zg@W$3hwcqOeJDN}5eJgHM7ZV%%P6N>RG9)C=iPpJh)|RFBB%p^j7A`me{HWz z;oF{{WO=cj+wj-*Vr1uc>%8U29batznDuE%gwHJ>BY?_{eDnD_KtvJRfO8@)VcxtPce$9ZHZOL@Fuz zJ#}+w1upWL%dBy*m<>Cns7~}fEaHRhpg#suJX!)&Q}9zEF=0}q=ZN86KVpz@d1qd2 zvlFDo%pT@^&|2^l!Ygj5-uu({CbX&JqX~nNRh>X!7)7p-Qp^*&kP7&%0wDDQU6O%^ zWv~uuQF&^zIW!UuzUOc{`ESfot#OJb@(RSC;&rE3b)kheO~r@8=yx_2_0}2VkDQpG zPwQ}5H>=(kW`F&CwhNMxGT-M4!id(qf@>PWrODdC_@P1-`3QTxy zNJqU%oF-mfE>RLaO$XGmBCBqS8O98336-dB9M2@TpXSL!gd3OIGOCrtc*kX}+#4Q& zGh?@J>y)3d6Kr(l$k+h;4y){!YVJvKEbCr}c$$-lebSgcEOSdDO9%{mZ!b{Bmde4k z8SXBBTrU=V;-1r3D?9yg`hm(hj0=o#U zcwt~a@)*GL%mj7CN>o$Mn|TM^{h{WxUtx$e4e8S2gj@l~a+Z_)3(V3*hHWm`*L_z3 zbyh4C=&xzKtx|OWZI8x-uf3aC3fC@oXUIUmep~k;kzMbH2SkWkMYiw?jWIH?m!vRX z^@g`Zi6>?>^gE1|U$rmN?=)s|YPLOQw;dGx{oxj*&Mz;8t0%L!7$07Om3ZvX@hZ)y z+s&7`gE-+p;n?a%lnC_eX=0By^B6&$?{!JZJ-X5fx}x=vjIa(fnr?fzmC2iYD0ia{ zSIMMGOKmuQ!>+AML$qmX%eGNpZ9t0!47nSQ{ON)gH-8yU z()Y9u#aaI>%Z-KAnQ~K#KH+$IaeVvooJJg2&lC@GuMd}BLmg!(2N!HUhM~rp zwd6aPAyRT>s26b#g_O=G*rDhjB>iHOyIFyKa=gBgSc>*>Eaqowr@GH_n=GzEJ0g5ZN2(vPOxlG054BJhg0* z%u8Wh_WRKPA?gKbt>4O3gz9}&NJ&UEBFVipomJE|P#i64AZ4Mk^(5$_`Lj5P5ACp4 zP)8&FIL()78d^~_6~7cu_lZTVOK7y8XN=T$9c4I5I|o~!7S^`QF=>^?JHq=a@P#no zoBsM8PT|3eN}uN1qlNseqJO19K+5eRXn|>tCUNG>aXu8SLj+S4Pp1bd{^1EToL0c3 zdN?oPXJPAIjMyh}an)#3!iM*Dg9L-buDeFpc4iad`jKz8x9{A@eEfP$<#&eUV!Zi8 zW!kjH-+o?$yj}J1uknk@j&9=PMMGvFjMJdKSOnWl(5vT8E_(S$S8G@5>ia))3V(&P>)cnt@7|#_KqeNGTV+vQ1w(d`c0yIFqVMm% z-d}-RlmE6s{cl7e#{ZOlb^kxm>!IW_IxO^m&}*8xO&}*K&oygKp67oJ2t^+SVv_ay zDdb331_|oP1Elvi@%M-C0y@f{QaZqc-;0Oq-M8!4x7*y8*U#hB)ydi3;K>$i+^^&3 z>w{;+FVA+*Fu(2N=lj!0#Tm-uWJS~@$otwK)LuJDjJEIR53#KN28=3AYHNodN4l8l z-wSO0gVWHo!`0PEH0{{*DzoLtmyQ_=moB=knvt|r&PlDD@*l%nhv^U3U>4ti)(85| z2m%L;9v>z*<{MA~pV-`MBAq|){)RP1P)i#$Dyzxq`u4_IO@ZH7qMgdxL!pJ#v{WJLq(iO4! z=%iNf%tw;zgccI}Q?lHrN0v*Vyy&A4YOy;!y79 zTQILCZ?u^Twr#<&7D!94sc&dJ68SiJK&m-3PeSQAM#t07p8^u`Ivcf58DPw2FPt8v ziOkJXU4V@Vn16Ip?DbopZHdGVXbgBK4(jRHP>8NyzbGcq~j(Bg39dMgNt;$b2k- zCN`960tq7i&d_P7DbRC$XW2<~HDIVwLq%d{Oq(mDmkd{+$>_Zt5O|=qsLURNIp3AB zN-mLk^Df>Vu%TEiwpcBpx`bu^HQ#}X0`=rYU1;)eH0{$wbuWpCryVR5gyz|FJ8&;y z(LCCg5Xi^7=GbjZa^~5lk%%qT)_jH_Hy~VYpNtkvQcq1p9yCUwja+XMR=6h@xg-w} znuf4&4loyEg-**^L%-`FvMqXY{6myFl0Oe_m9f6%00J3+h@Ax4h^JcCR|!$HmmkzL z<(@VMO+O73F;9YOXo6UCdO^p%R9Q{E#IzTSSY~3fmB2o&OfT0y5EvGaEKOL8yrsAr zp`ZBsltpBAf?3nYQ>wRR{lJbm&DgF_@i)^9PbmTP!LaB1%rf1^->X3xrdnJv`zRwQ ziA^euIZ&J##xI z8oEv5r=IbWwYL3LgR;iE^+;5St^F4189LRG&Hf$QDruHrFREi1R`j`9NcBiYSvSeRu4v+&2cV2K4FR zTU8DI$>t9v&s+fsMygTR5rPFP;Qb4-F0(wf-h%3nMQLNYOS6*EsO`n|^*Rf;J{0wszLrS~ zC$Nsm31V(H^4Mab?KrBk3No%BAv~XQg$Y#WEF$?a_zU(3>~PYRMo5!Q?$UXW^;O79 z!nt_ID}&E6Nr#~EvuTB*=^Y*fV9k|0yu4RolpI47tO)$Q--&{kD)eh%IyAd=Wt|I8 zS=4%>-oGzVj7w6Hu)}dv+29L$PU^r>8+vxI|A~dH;;MD#$z!3pVKrTR-0Ab5fZ@r; z^w(rFDV^6QQv;Pb_qYXiu`9U>+5O_<0jui$!3GSbC#g0dcH7+bj`%y91;1==Aw;#F z+l#(sXQ@9EML1qfN21D=o(h0U7shi!w3zj z4#E@9zKR&5$93V!3yfzKkFfW-rYbLEU?l*LKnspS30`3o<(JsceQU~Q3pHiK;*F!F~N<3QE<86r!sSh1wNmSbCV`?yoQw)n;&kg0{oF}Zo9MW7j4Z} z{dZi3zk4VmNF}AvadnRAq|8MO$gt3S6eygYW%-VuJQlo$=8+F2&z(y1Wu0I*Rdr+0 zuTw0Usu!W&?mf7K8F1O_;Md@e)9oY$UY@Mcy26_~Oivpdiyr;33kwY+lKT$=Z#21N z5fDj64`2(X1T0T1EENbXK-nxPz8Cxo zKMj_oGt?{x^xxMQm`@KQtOE`+JW}8zFv*1;F%f7z3jw77Moz_cQXah0#A8B>0Ki;5 zN%5H|kx&;{*wp*h;JOYOaLHqzi4(wgak`uoqp2qD)>bj3NG0Bz)f|>>wN$IU47q#@ zFWomakt=#~*w0KJR2q<`+*lrCcaJ1sxa@oZz!*4~SRA}BLll1=OD?g2N_v9lX{k>d zyR^0&yO4n#}pEY&A(aLPd{^WUGU!Dv6J~9=457x@raQ8@)?yex4fgMa-y;*>GX(D7- z`ITtiNpPsgfIJCcBz28fV_DVe9~Q5V>osLnz!E8s-t}mn=WL0s+U?gJOg#z*If3(M zzPM`&C#Our3__aeJgY-CU-WnZZ-)5>=`{sSE@L&jFJ|;v?EKBaFnfPk^z)0F+4?WL z65IbK2>EA7`;W%8rc^9ZD?-od|II{7q3Uh-35Ei!1GHnLW$q7JGCz#}qc28EpjN6I zH)<_d8xjfBQJF7Ii}Cb&#+B~MofIwdIYq?%TrPgvov-pOo~r%)d_TRmE~eVOG*z(h zvv+UH^_QWiEdKkC_)^-sIjh&qdaDW6_Vw^myQra&tBX~rDpyOStuL{Q+T;r5yXVTG z1$ACNDK|-{HB#c><_)3x6|KBHtL{>MH3WO$leJ+tg7{wHN ziH!AtH@E{UBH*-?CqN`M*E5KdalWi>NI*s_Af7R-vdeNwg(BUQM(vg&h%08Ca#A~q z#o5O-m!c2Eq`#hA#~i5%4Wp0brdmvK4%1c^eUKhX5|P^fjE`MF&-!T1}e~ z=^ueKk6 zlbg1=pZjR6i}ZYV?k!I*gH10q;h~b}0dQ^46^4?oTZ390)vN>l_cT{<9AE5+7f7~? z3TsRbnC=6O$#d>W=Oz_$O+?Fdg&;Hxbgm(T_I!iI3zPK7aia7OK>BXHv{hoSFkjqy zoYSgR3w)6n-H-W?uD9|KTcF&_HBj9fbI|2NHwiN#c+JjFZ0n+&m;t9|GiRo9eh^St za@FhG(h&)9`G*6eCBeMOiW#sR#<}+~-V?QIDg*K=PAt**u@C#w9u~Cm+vHZZGII^g zi{pvR-0K6sCciP25Qt_XY-;mx0xUYIC0J>c?O~&mi(|ViYe1QPG+eqj+cZ{jcP^OcZt|b(qA+$?Ka%#kgP(9C(??vhv`;6KihK7d z*(to{E-=2E*`VAsZc3HC+@M@r#zD9e3OSVw)qz<7hn;>n%v)&RHhikPL_Zz~zFn%X zv5%X2IcuavW`@rpnBK<9P_io)Zi`HVy1~1#lPOE(rb&dK?CQrMrgS&o#9=R+i-IfV zloyd;T5Ebn2(=bF;yna`PXAP~Xu}(y!n7cpF|;4cBci1@z6T!up1V@~U5u{4z0eTQ z=9v;quxjllzO{)-9@HnQrs1;BA6T~fK=po$=9+4J8dHT$OC^O8Z_+U4G!mkQ6)Z_o zyX#9wAF0Ipc#&S4z+}(_^>XHZ|G6yB1Q87=Qo>D_4?Sq&_zab>3uxk`6@3G&Hjxt% zC~B&SsB^?ooa_K=xTdyn>nXL9@hzcZh0t1`O*zkss{8bv2CPY>)7F?XVz*}n4Dj3r zMzRwgTMQ(JrI_S{wI(BnBXs9xuQAyLk*NFU7b^)*nkpl^xT@+F3L!I|$14Agtfd|2 zCBBdzsvXVN(don|(=l4`$L{!cv3r0Zn38n8WO^v`$Z4e$Zuy{6Q?_72ZMU<5*FHc3 z68jF6MvwV2ky;N5B%W39*L0KW2|825crOdYumusVV^nmb;`ns+S%+uV?dHmga1O?K zE2#ldZbE+&xa}fB6aicmk+k?GC6rYQ$4rZezabcxUE%{MpPPXosn(Y($GElGOeAX3 z5izxcBk88H6ER?SfH9chMRMK)Z)&4xRo#-;1S5jrgj0vwt49;yzgHEG(IGHxImc$q z71`LuWV(@a++1nnDZsV}V396#yIp)*U^T>rsYY1b?BiE*WT`jKjyajKQ_&w2({7?s zfnGwooRt=4j!~hnr!lNSYCAQ2X>if!8k287I{LoO#$yzN9Tg-7Te1^<&$_yia=#(Q zr6{E}$XTNT5*d0hU^Ob*>)IS72>2%;W%B~IhfN%E#Z%3|pzVTi`Lq8lAVaEP2mJmu!knN8d;AMNv7$H|)~g!6 zfhO33#3sUVY5}M=8DR?!kTr{{Ss`jBRvwkuGAMfCx*lw~YxmQ6D< zx8fWoE2N8%1nlTmz?skEltXT;PoSW!4HJuU1RqF3=C9E@ue-h9QHwb^O1 zv$OqWf+N7A?P?b3d5uA{>gX&EwW;vlWNK4vb~Z1<(ONyr8O*H2n&1-NC9qai6x_~b z4*%KNB<}sAk~0Ob+ZUarBoc9r+LATKZTr^{3#A2@90isftK)Y4A9JJpKL zAj-in!!>?>_MYsKC?{r;8_52JZ37u`Wl!~+AyXO^$y;%oKG$j<7I%LDHjl&I;=Szb3_W?b4u|AbR7&7MALi%Pk}|zntXzKT*o7Onl#w+OG2BM2U)k7 zBOH-1f2HpmQBnJY;S234zv<_BSNB~T65HF_>$~myGtuh@&DRU3*OOs@fd*#l?guLy zyE8pF-T&f+xwE=^E2&YPq_tx^l6Fn^T^~KQ2~N&pf!VyN=jsFOH`=}#8=*G{z}*_) z^7$=40YF=9!XAiqVEPa_8gGWF@|M}N_rh$6*S&p(=|?KSo)(?;KGT|E-33KUc(A9j zO))DoIamYFM?`~qfS%)?@$)p?*~+)$w^`({=&4P5;LdKiIfE}FcR*5CvBR=oygRBWs`Wcr{Q#Q zSKzu4V)04x)2A5;5F03FIG(5;U$klD_lv9BEwk9Y$1>&%%P6fy_!kHf_mAfNU6WELvrI!y%5u_cA%@5J-ZmEoV;GbAO-7%}Zc=Uv4E;*bx z&BAxbL2`6Y6RYELCVetglprfTL+$uteM}EFR-r`#Dc;Fby-lF+j;Px9o0>q6E-Wlu znlej_*aEUPa=WSJhf4a{M!`c577&fd4!zT-6w2bYn3trzp_LCIsjfy*R=2J)Pvu0S7Tca5e47ajZGhMQ?bJCa%ge&-F z*|b2!PV&cNq0=ZtMv*&^g=l{Kbim37=C8Et_U7x3XjpXYzh1H-W1We`6ll?901vs( zD&|^RDRGbFP)os()6>n96<;Jxj6H}KqHiP4s+3^xd|XjZIc8fJ28BcF$P->Ef`*3x zn|kT9_f;;JIT+c8A_apxfOR@Fm*D%X5M3<^0RA%yAow*elLbW?yM89{~hQUxPTsiCLiV*GZ?S%OE&vzV;&3BB#UA<)Fisd zbFI@mN<-1non-MSrAty5peIeL1u|iD)f_s!PMo#i0fW_f07mAhj%hlxTiVFb)5+?S zPihf2Oe9SrP?;$+gsK6ypE*nflw{TbD_Zkc!)IFdrAypNcbt*!w|$VcAB!b(lX_2S6rb#Cu6lG#+^=39Ck2&A0UY zRb`QC;#It$_nU>mXtobpU)Rz>WU4-Ep!JTg+T^GUuX-%26G&%QTe}m44i)Lpp~Ya| zS9QPelrQZJz(G5{#FaR#ny#^;u_^67u{if0fB1F4v)+_zaw!lhL1e1A-}L~}I?oK4 zTwbXfEug?3*o!;do3~mlEYcKrA-*(y!S9pWUuj3yQfE`M;j%0?IQMChD%C+;l{bc+ z{YKTx((tNfpIG#}{IdO!(`&c<6NfnENWwO2oRpqX`vr_()?R5`^LDQgO547E@ZDj~yBMEa%F*F4v&mQ9-~sEZ7v zx-K=5<#A%Qep`IXv*|$axPACEiNC?m*2)2QvNA07ec5FYaA@lX5?4pO>qVaS7lO-t zP4H5hiAQP5KtRn*BTWpX@9bMS|Q znmUFjKZ}sT&CbL_D1L+=LoA{x`WdJh^P*BM7m5Uz84V1WUWn^~#ph{m# z?c+_kUw{=W)T;lsX#7tsE=CrH|2VGFfl)i5I(JETf6?aNl9KdNG?rMEu6*W=%yuNIH z_8!vy3tCm#yGEKNy)KLSyy~tlAOZdZ1lG!UmHI5+e(9=T!JW_cy~tfY#!@#0&@z|a zI)7c^-#*5^F4jidb?`gYNT1oEs6OR-o(omKr=TqBIYwB%02n`sjZlj zY;9or%zmOVjI~ZE`BdDLRE?R1ywwm`iy0mUQu}ytQjxHFP1TkC6|KqCoQ|#$XGZ>k zEdJOz14|mJ%Ajq*ih#XQE_~DEeUsg7IA1jLUQkII6AK`1U`os{=cxg=Gc%I*#Qg9b zo}p=Wf-__~!w$uc&v?zO_Y%U-z9`SSVv$Wa*s=Ta)=CMf* z(~pUNO;s-8Ub}Nzkev2*ohA3GYFCM=Rp~^0FUS#vR^*ArA)$9G|Lc7ay%6F$SG1Af zALP?HKde~Qy~h#$kbY5I1h%V%>o9lZ-I&)0tx$l)CPci&*nMXtvm9>pV1bFBvMIYJ zZ$>;rV;tmaa7|PqQ;gwSb&{tKeX_VdXNBxY4EYBTt03SESXDRd-R{ix9s05t@gfUN zlZdpA7RyD`?M2l(Gdjt$-eTK-#C9)P5X&7_k{OI7$zO;;)n?n2{)QQjXzm!>uXYN< zII`*ZUFrMSBn`Uqk*WhHwm5x2IJmn2??4qN^GGg4K86FGV`+89sjSBH8iT8HLYM#u zT6CGhlGFS{{FI~nrMm_7knDp+fW2W1hsP*JU+18%&Zaop9)ZHCnT!fHHRUn9+bCjh z1j+4wNJL%Qzf?CjtJt1Ncs|DtDL1Xx6Z2vpe2$-L8aU|)kVzzD&P7?v8PBeFtJ>M8U(;LSKz14?+ zome~Vx&}4>oNbF8R3uAt&{?ciMY`c^MyA7R9xdiCSZkE}KZaQMhvSeX<^b`kxb-=2 zGo2t!Ro#32<{El7&7FJ;*uko3jy=Vu)`A;4s?jw1RG)qNq$bQiS#ZR9M9{Inzf0BD zo?tgjh&VlNAS#nuF|tNJfR^h^tJuBwHMVFtKd1K%6C$GCou$7`Zsi^F?~>(gy?EI= z#7q@A9^i=3LTi|QwpkLFTigTsnBwnzG)wh*c}fIl4)elZtX-nRTHLg3b)9CAQq}C~ zU3#i|<;(;*%ai}EBt!k&uzGe!7z?#=>lbw%Q*KYQosMI{QI%_Qx`25&hSTzZl_N(5 zDj1!>PV=6h?&4W<%l$zX_IPEMyM#V!zJ%Vr$(C#HJX`3PwlT7@p0NKFsBXlR&T~i{ zC!!I<*f6^Blf)1U-@NaPF<%qGV}L+Kc*fd%_C4F8B^w~Zjgq2XI2Vhd;(~arSzoW_ zd6sa9baX`eYplg+kf=Nt$)Ab?7blnbgD#`-xeP!UI_9Xp0OG^&(oE($!QB@s(kg%i z6>Ie?q|5y@{p^Zx)C^io;tm7UhZ2lwYtcIe-=`T&FD)}+ug!Hf>`CP1w9+n&T-1JI z+Sd9Duui$_3Cvy@oBY!)@Idp7ZQ!-7;2fjRQjI`ooQ_Ue;2K#g(8WbwCNPuO!1oKb z=0919+tehVl40YYHJ){1=()-FEF+7&eh`P(TH~FGpyr`J407Q&PhPyGAG|oowV+3w zAOy*!GPsQBWAPVY78U?_-AirEaxL9x@g-`IT|`PYL`vtI_PzUI6O8U{SwAypMb8j> zk|hK*%&8uC)CtU>zKXc*VEV`AxnMVG&<{J@;ag+canCuf8`>bvOMTzy<}K=Fi2`Ky z4m6MZNjrPX(33PY1Sx>?kH|1rQ6e6+WO^Ow76T`fvI)u~n;+L#Ug#yXPR-(dZu^ z?AWjb?Fa5J%4P1r`SY7U}Mrb+0(-md&TR6=d~m!FmAzTB)MqojR0)` zP$RvIqT`M#fZ^y(G4!{{Am}4Eu@pff2jevI_!Y-2zg8=Rg(3hMf6zmPozNc6U3yj8 zdod7NP8kdt#wdI_oRL;;Hu?;D**@+b&NP;5U%X!LYcZ@e>)Ml>{X)CGR*!5LYQycB4cqPS|WHo!1BMP`Z zY5bX?EF&hWOZNTn4Z^F7=}U|4J7Vb<%lRBn?Kh5B^?u-fSPw4$%U;ON@ITd_*y;ZR zbUds%S#!wxe|;EV!1v-yi~MmS0kQ!%plzK6k(pR+m9!_nY$zlN3Dz93=}^#|{W8QF zgyn;SpPeluUo{(`r<>!aJPnWY#?`l8)D6M{(J>D*hjC8nPPc5>#v;CvzM+Dz4 z{~)cmjf%KQkh&CJQoCryPhuZ7bYx(((;3W%%)ag*yc45im~K>Z?U_{$*Vt)XPOJCW zRSl9ORi+dsGkQNBpH$^uKumNWi_DA!Jmm{|^Eu=M+@)NW*;VaLn3$Qojy*qnjZHad zr@kNbV56Y{=dh1_K54x>99JLX83fj_a9Uzk@X~M2{*K=sX71O4G=ih8W(*)fRS?jk zBt!?;J5eOA^}dI4UL~)Nv=flNE3m9BLoQdytnlU{yG6hFxb;#5y&Ul9bq&+NdHj*)W2glnn_N!rVbS3MpHEUm<-eP z@SvhYGTNR3wo|^TiE8jmGIB@up`TY$5YTyO7gd&E>asoUG%jXM3xsK8iUW|pT1@k` zQ|z9Sq-j`LC)BLhuC#B_7ELdM8#-sW{T$tViZ=2>A9AI4SkY_?4-7!LOR#TQ2I&<= zh_NH^Q$_#~YU{nfz5-$B##bfd$jZ$|C5;&Jr*A0Au%UPS$)74oUH>>nN!RMy%hrVw z#)#^vQHP|yq)W)68$tnLK&1+tdR7qMz0ov{ot=36J20a{jols@N|{0TPaK=Lf0bh8 z##>+=URHX6?lIONNlcHKqCjExI5^zi6;KtuyLhAf?B{w<}YmtwzfLbD%Eq0*U)C-q#$tMvZA{m6gE`g*b z*&%JC;m<)I!E(sQE!h%(qqQ@f&PC@+78nnvQ^wa{BGozPeupNc6W+q371sVV$J~_I zD}QvDHHu>+q>4c?Ldas$-pibdIWLGN$(KVwd@RJsG6yJR_Dw`t%StR2rarvMd zTnZZiP}bT$4J37VP~X`@m}!SCIq1q+>DWQ_Mq)qb<+KhsOy}KCf1?BpBIZTh>>i|n3^Y$^NVP$779`_p%kT0Qi+1hi$kEO<061@fjq+=nKa@nde!i( zMt@*iD?y&n;cwcY%zD=t8O~%n(8rEs$H!Pj#!leb{(5PLFC&8LgMb1`= z5FeV3135M>OBwbsp4?EX2$@L$y-t9N%GHKe2jY^AvZ2(QoloUE4!Q_h4+Za;NZ6(c z%uzDOJ272kS6ycDlKmbz6Id)G&Jkt5^i-wfp6dG1dj!*UVwYG@c_I5NPXAt@g;!b+ zfL9^$T+>oQ3@rBOIkf6|i|1t7-!l?`BdY6+GJOoVjo3hUT$GimUR_gNnro)*6Jl+T z57d5!V$~JMK&M#X*QmmT#aRFuNHH>G3b!rYCSO6msDmi76_JKN8o5%VUshV_>Jvwg zb|M}@1F*7dt|Dw{|6Z2J{Pw=`qrV06NE0 zL!AX#&F8-<5%w;lSl}U%77!^*Ie&$r6C%jWVq~z_ z18f%~^(8K)bGK8UKysw4(qD+wAazcQwI03i`@cI1cE~S7*+-8@JzbIluGyC9FXh_{ z!)b=Wx-*pWpU>|tlFV%K+or2^!-OWOZrO8Cj`wgzEB}ezDN4|O-IoaLXQmkHCT5Zz ze&RBX)X=m$F{$}9`ecSMtjt0y8rm%0VKP9=znrA5qcoxO0{9Qxy;DUOp>%@8aDohD z0hmB&Ui8ThS&uf@az}Dv{IOnnL%a8qmIM}8eaalv3QB85@hrBOS1ngpnD1>CMXw?0 z%+unCw9Xk?w-?BQR@&Y-!BgIa$Yug%Kz3gMI9`}YA|Rz4>AE!`F|2k`rbFttH$$6V z3S^2}-Fw2;Q6Hd6tymUXeQY@u|B~NYf_A|)JmjQ5KyG#+RMe)j%C@x?syEv^x`1m= zq_}Fc*^U_7t$)p;=y;CVO?N3YvI!EAFLIG?ed_dlzwph-vs?auhbklM|HJoE_OLgh zlQXnba<-w9#b>0a|A!cHbaKXLU}xv}|DlaAvC%X9N6glH@mBMAdu?D8%5+Qw;r6aq}vWuFFOC~&} zPI_GB86}bn3B_J*xpd6iB~|7LPsH1deimVFDdizoq9X|> znKWT?n!ld0TKMyu1Z*;UD94?8*KG3gn~Xgwu$Dvwa+=w z!2n=`aPK~?bO52ME)d^DDm!n1{0G*9(Y**VEb6s`aWJT!H-8Nq1L=O)UI|=te;8gb zUP+ZX+}OTI{35v)6?$!?G(>9;Dh1Y;Xib`+xoYF`%LT zq_}=jGI(Hwf6p>!fWSlZx}ij6znOtsR{y z93+A``k1pT4#e=pUx_gf)P!7PRIFX{i@;o)#O@wkN-_XF5Dmgz9{}(lp)yFF0&5C7 zr#Q-mYmW0$cxH$a%KVW3PCDKm{#=_q3NAek2Rx@+U$6=W+;D(cB?iAl3bw&+Ty826 z0y%?7Gm&=P9>g(d6dhx_6yDJW#x%4l+%?WuEPGC$Pjm?%=q{sC*t~Q#izH|SS!sU> z-2fG#YRgC#0ZP?9n`1y5x9%RE@G#i!FQN9A4#*!KeW)jBJANZ!M&TtPr6F_v2mfe< zVelwKqBux6&~Szsd3=U~4G(!;Xti6KU2yyWH)XFnETX>P_P)*-ro^W>gEb%sDy$QAt~qF!KMcolCk*bZ@R^RYg8eSTd}f|8?Rw!G3( zm&YcG9PMXh6ixUwHgrHaT_A}vR1XN|JS}EVUV#SS_6w%Jq;o%i>QIQL(4e0qzhIj5 z1VRl-IiO5oi`4yP1IyL@@MndNyqnSq9C#i1EN94?ss`Ti@qkcLT*j@;o@v1FjG?fS_rVF?$H*L;M-d_PsF{kg;ugK~aEkFDgGi->rxFgqH?3d&+x54fgkzD?dty zz290ie9HVjUOqo`9xp3=d9HI=ceTIYKQ3l3bM?AEpi10dH${~2W=$VezFm3L?-$_? z*FC z+JRh@Q+6SJ)&ZLm606-+u}ujZ=f@#_*9&}bFI%mt(qZC~;;&G|=7E$aO(?ujNWCgW zz%uZJo4?W=jAOTZJ)9=_<|^wS11!wC<2l3`cKo|6T5PJAGgxAkz$Y7ITz5Z^2>#JN zg_B{rX`U>-yf4$JSiHZm=8+$KZ{oH1sC+KaSXul*T){wnH{a09iakkf?69#%SA__& zsAf)NLPJhy0e-+0|5cfyUN`@XD;|dPS9o9$=Bu&ZbiVg%EcLlT13JKhNecy)W~Fi2 zed7!0CMzoRd)b}0a+dF*l9vxNI<<1xy{_lu$Glm08tw3>C}k(F7aPth+cS}-sB+ia z?dv*rx74OAVl)-rl-b5YJd9C&HOR*#9eBW?t8-GQ$tipD03mIWx0Y<9Jl{8r?S{Vo zDgnGVb>#F>0qfM+7szN?dj{?F+4y1d$$Snkhpkb8Cv6IB6_X1C&NAxau=RH7?%<%7 zkG*s=K>r~k+38-~PZCG7-JDY~J&{Z3kCAY_a}$qp8`+Kb&(xAvwY9{N#_CJIz$>0f zpY5M^usFs)MhIxu54-w_i09P5JQ#AAVfH?(xvb92OyK4SdOvQSuFe6=G`9|nC2S#u zn$j5WRT-MvvAvnuFQAu+iKg{e&t`=?d#xy>?VCPahsxzXnkuZyb;4+Re;*OLNsgc^ zt|mN+?2A=vlN(!z{NGgp6_8)ks=_IemtiCkUyp=``3gI5Fh5|kM}2l|Z?#ie`jOF% zar#YawbwoB$LhCuowjta8gbOW`9xC9ng$J9PAs;j7@?DfQ@Lp(uDb|*y6N0!tP~mc2=-XQ9gOBmCLRF5P=z$ z`lBT;>JnCvk-^*Gz~-T5IuaKtLc-XS^OoM=tWLuc5E3x3rKded$vrmyjf&0whiSB* z?Vkk%v654z_H#3V<%l#pUHm7v#4(7u~>pgG+X$yt_>yi!@P+*<+wDo0L zO5LziNlVvFB6w#1d63S1Fu5I;G`9jtTH7>5VrJ4?4#_tBb8~s0kiFn=hyZ^mMDZAD z7q{ltJK(f_?{22BAZk#210gaVy5Rskn9ZspZ^qML=!D)`d2d;OY z?w9Y2*ja%uZrLj9K((Ht1VJg{{UY4w(*5n=;ZZJYcG>VR$(~z9`x#lnivz>jc~9!3 zrVs(>e}D#=)N*N!tT8oN^d2T#eBPJhm-73&{-rx+OP8XUV z0k`eA(ZSV4&^;sRSk@)+Z(ot-2LWxphDKKF5Wdtz6b-tZ4hY(S^o}@IhdY`0-}Nn9Z2?ZllJF75JO8 zV#=KUDt4u=@gkQ|82NK?j#fomJcI>JE=KUbu zX|2hdxAA`%dk5ysqIO#}Mu#1{W7}58?AW$#+qP}nwr$(S8|UPny7$!Hb@r|LYW{*X zt5(f1o@e0I+N~>qa@ApDoa+;L(SgUxxPmHU4c=b$@lb%{!R}o~|I|wlsq=NneTmwAVy`s~E`v@=LsgS8^s+j-PH4cu zLm=q-oyI1J@4Fcv(?92}Cu5$B>rTxL1&GeBRyi6{bj>{NdGX^F%~2ye@;%_ru=A~o zEh}a@!Og~LnZGIHD2v7Vncoo5fdtT&Ik!xh)xgHcIZ0OOh#Do}Kb{jUDUg_Cc4I6} zGV7-A@lO5SuYmo6hthzzShyj0o}y0aF37d^-m=qm_UZaj0~q1+oQF^DWUQn#6T+#a z;F3$9iW!A6;7v_t+qj7FJ{tgzzBV&6I37;8CKVYfTy`ZXu8?NKY?@B4l}%KEP&H8P zCohUZ=~!2bD~6k``@5N_V6%RE%Q{2j*i7Lu4`C`l79=fURJ0#Co>y_7HfQAv^+)~~ z7fUYb;4FDRRlC2Bk*I13>{hg7l#4CVz| zm2YxXa$aSu$vrMk+l{4PH5>v%`ko!Ffl^y~?n0E)!3I!VELL_Wx(0kYFE7E?FZxCx z#-&C}h9<+J3-%S}Iyl5L(2NU=vWIH;m`8&3>St6bbI?e90wD-FHXG!8&7kjz&l4&DBf90-QKXS$Y9bEk*S5zL|%K@W){+CNJtKr*)$}?EuB+GO7Np}>>bQqg&*ajV* zFBX|(6pk}}!}iDN)p-sb_4`cH_eDo*`#XHcJ1U27V#g*WXNNY2H)Dd4=Eu-_<$dS= z%ez~XXRzn`zWM7bKM}Gh)4L1H;C3TFv28@Q6PtTy>E;eS$mKO!>y83v#$_J)92G=s z1Jwsuz0bEZ;-K%a&JERc`IupPxycQ!)A`|INj;+Bw$ou@Qp$~jeq=r60d9n(gYQTmYg=D5amvo*p zhnGvQZ%vw(+Rm;%E01A*{NeCYGnidP$;8aA)#$*eD2_qHK;_KslE!B=RJ@4X*gnS% z|JD{l1oEgEYn$@WF7Dc8EY_wK%AA zQ2Z$RVetT|vTuO{W2e+>V*682gt*dc#_c^`*uIpiL{x>E7tE>uNxU`r(0Drg3d^3^ z=bX_CXXrQa;i0j2L1GipBIIG}jN%Aiy|2yRT!0v$VRxmoO{>H16)5mFDsA{6Obuc-1A|KAE&04O6X>-P<_>>Cr=6o~f$)n0a3u%OQbFaLg{|N}c7> z{LuciX)GlhyQsDCgY_iL=h?F27Nyi(&$Q0;zJo->s24v7`{o?4vMr{xCcf-X4S; zkhkpgMYE>oU1pXHFjI=kSFBymzp%7<#?nq-;*m+yvv%R>=vL*ZTh~v zw~S}w%psQKSb+$tStW(5rnA&$T2XJvyhI>i+!@!IcZ2W0l_9!>Cu%Lg5PgtD`}FB68?yDAXus$ z2B37=%PS`CQ^q;FSxswR2M1L^jME}=%^gn#PgGC;>I7nF2Ja9Nu`f8r(!2~X-bp~* z38{wA^iTVs_MA=8mM<%y3|!3*kn3dhN)eHfED5O}k^ z26XP16iXxpG>5Ezk-uZvobxP_3r1ckyn2!4NkF$HAn>mw(}1Lrs#Fil65>iTN&V`` zutt6$^QAL!g>Vqu6vo9|W}{cHq>v7m#H^=vPOyn?;PWs zQ?Q6RM6?xu3uB<*Zl)j={YYUEc*xej$fhH#mVY0Q$(@|VxFmvOMOQfXw3>SP!&ogj z6=?^{2_gDanptYsuyBjh)UR&Sjx@S!{Rzp@7E+-3-Q<|=F(%Y%B2LnYud$lCaDs)R zB>8dPIs~3iZOwLD%{g0XlMIG9gdfOd`YByt_ouf?x{ag}O_Y3$5*m*Q8_r=WIZaTelp|8S7nevgT5sBY)DD zCo!jNK|zaw+Mgj#g=i|391=CE%Oqu_qXKD%PvRBkbP<&@?C7oI{*sbq9K|L3=b+7P z?#kJl$2#%`4r0YthY<`}yx=?IFg1)1&CO!)oj;?c>Q>)!iH}1^7}Pq_iyvOOJ;)%0 zY8F-OYnt$ufxY>!98b0q>>lu&aOtTM zqL)sgC|@?<73uHhx%VDD$hJn+{oX~%wz#l7-!cpSy>l)06h4C&#bhw7OED?(>@vTb zPtG;1lq4$nQq8VbiX42ohMk`E?v9BXCorE_^d{plCY@ z6P7>1_I?7stLcTgBakKIQ%Ah_xpgBvrR2>~261{xiWQ6C=xig<4JO|6d;IGeV{mybhA>e+eYjuqj9R5p1#(hv2|dR4qH} z!jvS95}Z6u1+;s1oJNFyKa%i&)X@I<9@gm@xyX3~Y#glsCQ4?m>uE9|ecXCp(=T>W<(dOu9bfj?_} zfCs7G6Nqm+Wx~n;s*dT$Ts-UHtK1czfq1CM9)G2)CGxZoV`FZIT;vr%y8BbvLt6Hi)-%E#5`eb5J$)Q2Q?&+1eHeFXV!4V?tl_}k-J z{n;>$yGF(Fe7{DU;x`HBV515!TRNKR(mK2G4tAxZvBO%#@H%hrg zw{Jc(S%oJ}speh^#-utLz2fX=B*B4&i-HV) z>ZLz20{t$9{ZuV<8k&krhSJRpKjG{j1XTyu5 zZMn@+ukAZk$^L@IY_3;Llxq$J|CQP!*S$o_7D%jL!eMw8=HKsU5HA@;ju$8cp!MSt zsJlcvWT<6g(RZx=gr*p76%Z?Cq5$utD&&p7bkbit&?%1fie;kwZy?FzyW%`pie`s=Ww zhUV3KGcq%`g5ZyJH(Z9}@g%;?0TsUq0$bb$x%h)3d|2gsSh=D5{b3M}zXvlL%aTu( zNvsfF@*V9B@TH8p>}=#E7*n5V6RWdqe}GT@75Fe1nyv329lWPZ1Gw{dS?@bUr$cKRNKMSpPq-y%@`-{b@zaTPbY1O{1tC^CVTN%6b=r6u zk5J|#lA&BHT6$yTq@p3=@H|leG7?eonxgOVAJ`9FR`zDWL;zGTv}p`KojAJ0jCZ<+%9!cakcWGzbMJlX<@2fG3SCQ!I| zPcsjhY$c`;!;rCrxc)+=`Elp*xN7Th1!lw|7HDbWN|YcUlu$yX6qe?nP{uDDNJ0Te zgb3r?la62hB93=P^cJM-q{iV!jVq1vCNPOlzZb^9L6GO15U(9jC%W+f=i!#R^z7|= z+pIJtLSbYUsAKRPqHy(1r4zJ@;Oawt!kPEaAY8?JkL%@Fg3pnE4f;~&=`^+slYvJG zhhPk>UAL$wx7V3q3*qG{T8piW{WdWcwk6TJ^p%Coi7XhmItz1|yE*mPn&r6|{kip5 z{iq{@F?2+gOr&MW(QLt_9|HLfA@-SNe@mj`xFE?78$+k@gNJSERwQ#s(pZ=+m1|Io zkeZ3E^&ZRW=C;Ai1SLk$ z`XacuEZ?Tw1SY8}ep6q8KF2rBSD&p7L^U@~HEb~258BcJo%5g#-Ogz^l9s8U^46Ild~zj5bQ24eCB2`^=MxglWV$aFTq)y6 z+o0!K7xE&gyn?U~0yk(VD^nQQ`*33ZBS$KTg%(U8#U%i!lz*v`P+#4s(zY*R98jYKAgq+=yz=IQ*TOs?8c>YPJPj>pmihWMwqfVzW<{;NAV1sy@RQUiWV_=lT)V{|(u$$V26#^! zI0qJBs?=yp8@^5t(+&v<>)ZH5l8tRf8VvpvdgK<7obaq~+kF9~cDf^`6SS$O47!En z_x_akZRpQQcsf05owl`pzlBAjdxa28t|Xe#hrmZgmQ&nKOVV3WIU2e=_@G>bPV-Ct zBT(M#%BVKdDhe4HejM1N{E8d;lia*u_EJgyA_O=Qp9Q{4n{+RxfqvMOjuV}9W@P!r zVs@uv^DQKl3rMxKh4RmP$es2?EF0(Yj?~#0xS__&?G$D&nCrU|=KDsyO4WC)&&;y^ zzdl(Rlp~;ihfnX&cSp7(+%LihCi&Z?LmA;FV!#?k8)8Qjbl<>1TETAr1GeJ$k3^4* z%nbj1jHMxIL)8Mm4N!SOaOHHj@WqdS+0@SM0QqUCUBoP`pq>8S(d;6RLt??>>N^8H z!3ev;gcJ5A=98a1+7Q-UzLnL?g#BKbc+c6}`tHAod3)G6;sdh6iRMM*M{ zWF2#}PDxo=I)1~bRiu62Rn7~;TXZx3;Bs$GD4mG^H3<-*h@@q#77lMWk2jjCaoh<% z3a=136F|5Z0bungw0NV}7N5J^Z*0s6e5w#6Px*$kKy@}%ErG|~ORZ^YJnAaIvo1s= z2a)BV={c$HysT6#b4rlZ)^7~&BDZv7DNG{fWUWM&FSm4po*iIsHI_dZjp{SkpK(fE}%w}_%XH)#S}GkV}Q6%1D#WlX+5MT)(>&+{5y+}0ZZTXnsX5w^Uz z)RT={ZJ-?WUJ;~~%{yV!5F8yOVsAsM&qeP@~{?A5k(Pn{O>2CaH<;_%yR7o3)PTA*yp#dbeR5gftNm=)r!qSE-m+rKz# z8Xw`tiSL_aR(GK&WrDhM*@8gezmCT%7ay(G2t5=0xE?H${!Ya3VJ1=+si7YjWYh5K zjtjFFybYP^(1k&WliQP{2#Dpui^`$+n`ypNPBlZdIR*QQg?SN{U9pP(9WYW9fDZxR z{te%}x!s|(5JgmXmN*=E7eQZL{`cyH<+ucEfC8phI14aHm=pav#@)X@R8`C*+evpQ zq3>v7MrlDTNSM$_9+Wd4EF-dEVQe>J`p(NM-5b;UtHVgNUd)Y%sr=5y2L2b~z>i}c zD_gz*|CWm$o&}7)C;6X6{bVpSgq$Gifa+}q93&0wB}3ZCCkYvbzfdP_JWXa37GaXt zQ+%NUbnGk*`tHBr0iB?us=O{Y=HxK2fhfejjEQbB4gJCo`#!ZrLpV@~>@ zTc6haCP=Dh38nWt{T~Nvok#pxLD#&kU6Z$*h*P0?WcxkLDU+ge8PGjBDk`^q6Gj!6 z=-a=v>2UI2ZL)B6!7)rcm@)Pd=(O3)=TZk+ZpMoCvt=d|$=Pp(r{$*9NAr!u9^#8W zTyhY2OI5elWYDHockYdUE1sS5W~dWZOei>@5qPqc>f@EOE4^))m#_}o$xpaaez)W+ zw%8}>zcnh(NkcnV08!;s*8<#SuZSCIj_wP6`)f3RUk!E%#i@|3lw5f30YIubRuap` z&)Az-B3hypM)-;SXoFH7r2fTk>^D^d9w~l;iDzzSF!%gsMcaxT#DBJ9Bk z{4=Pn4eN~rskp5`3Up#Ir}rvcgcg0G{kvoktyp-e5BgaKST>i6Kr8GEpi~ZTNbWtx z5&+3pHVUSXg%XdEw#9Vg1o9z$LG5p;o**R|7}Su{AXa5K@_hQ?&X#cMRof*BxqtXQ zG~3L8*r?=p?@AwgSY5nx2RQa5DGdPitEFP{6talj%wThyR#&7{+ z`%{}C{%rzImTGl`rTwho^G7l+84oEoK^iovAP^fSI&v&RhMOY2+m>^dTc8p7W|=vOy`mIOy$DJ&^~IyTr#o`_slg7; zIq@8bG@E0N@9+BYY*~Hgk`PGE6Ge2l0cU~X5kSA^%lW?{sUqs=jtk1a zhgRZ)9$DVom51f9c9S~3%PcMc1cduuo@ep-j0Y21F{K|%cxGw%9KAC(r3gev+9G4h z9~{=|S$gpD7@hzyGEJ=BqRvf$703s`Q`e)_h&wX3=j`n6qYZa;$<2Qd<;c_8wKUcK8~m zqCkQLzL8IqZV!)YJHF|PMd__Kl!fr|X>joyn40(Wz*JkOFS&4a7&CV2ITYZb+ zF+ltrhz0G>o$d=1bj`oFhld@`Ea16w_#Ga_rm;`(E{P{%zCps(GKB4UXIIW+Ab*k) z6#BUbYK}zti0AhitJ6;@pz#XdGa>#Y1jMlKTAW~o9sDCGf4=6`Lj9&q<^!SSBIWpV zo0e0bIe>~U>_nEuEkb!IoW(TMMqFfa7&_=oq}1*le95~)v19tG)Sb; znjtL`idHh@?AGWCHLjRs>)6Zg3%o2~G8!5OIY;wG`>FY~Whm+!UvubB78j`w%2 zt}j(@FO6=`9~yg|esOfweQK4oVL#`|qE2ITlA|)bX-#?^DGnHq`6=Rl@$7)=+v0L# zEM|4>vOD0t*z&qiHb2hB)kCjb+uo{hn&G$()avggvkSVp%Zk@)S+_=)jpW*Y1KZzo zWoL|!)Zm`uLaavUYkJYX@sloygL4oWMmji)q?ttxL1zySdDrEs#o*A@Yf0Q&qByTF zda4CcG^tig;$M&q=9<~ivGJj<_~+baxzSF=40H=bc?hUfhp%TkXp2OuGfi&=Avp$E zg4y*}S1qUd_?N&SM;0Y$>w=3-3Nwd>;_X?YiKm1sKRd^1iwo{hudh=rC-{Ggh~%*Q z*ZC%@WTL~Cj>4@J{9y@(DnZT6McUN}_C8wk8LH_;s$>MUJw+`mAZXKhKB^!D9$YhT zwe=`C#_=9ty+Ni zz`6n%l;U;)xE0QnA}pEqJ*)iKn$Eo>E!+gvb=7keLsEeV=U~`8Q9W-|iwrT8Akm=Z z(7~Q|3Hp-QMV-PzUW8sRHsHz%6uL7_$)Rlu{G~2HlOlHKSsgI(HbESuM}M6XTHT`2 z*1XexD%tCS2sc1lbp8C1QE5#$w=;bkbpZ}mJd zM4iN-X?)E_{X<1T{aaAj=sf(F zTLBB^Jw*ZBVVu%9dQWt9yP{35ul58dc-){}r@k=WkifX;oY3CoKiS_Alx z;CgW@wmdT8NpACS0OpRq1;#76)L8um=2xzpMK39fokC48<+ECsI)9rOF1#SInWAcN zU9)XTm2eXE7_SfE%ruro@NaLUrDH<%93vT|OjctOtjEvj-CeP8ByMusf2}o?=8OEy zj6OGtjFp1Zc5zjt5thuPi)g%PplUyx@_5U#g=cPXJ9xEXg=omuomEOFtp$4)k%7v78ZAzMaub~h~= z1_E4-c}Qw_>PiFmH$yPLWKlof9x;;(d*}+2p(|)=^P})`&RlLCczI&ztCLsaos89X zFl69HU!URBMdOU#IhQ|7%Mf%v6CPzkZ7zUzr!-^A1*TC&hR9M&rz%lkz8P}>*wsmb zQ@~_)Qij&eEiB=fv^YH@vHTM5S#WM19)Kl^e^_fe^IL`04LPVkcg+TQ)dcHAw`-Ap zoN*-|8E0tnbd)$DAv;G-#Cnk|z4Ab=m;_jUI*Ji5*iLBf0~Zq^0Ph|DyRe>=*WJLxdn%Oov+`xgYfDWtZT}uDU}YV#lj|AR z94^9dq`Cvw2zTS4jn6Qp6Q@ei9`)Fa(v}`Z$;j92{5NjY<`~#Qw7cIcFJXV5?csY{ zp87cpb)5Syxf3m+@h(apm&1aJHQhMI+bzzwaC!pM6YJljMgezR#*Y4tcy4f4;fgky zvaV^wRe~fc>D^E0y#SbEc0y~cP?LcH^!vM2U2R0h+lmXNN|!4qM~l(bc5EiMJf7%& z{pnSB&q^(T^uqgaGHOY;S5wC+ivGcw&RUNnIaLE?9-hK7RYL=%>4*(({uh9y-l0p~ zPr)moL!yfGb+l&!I-vz=#Z!2TAwX^Gd~yZIc>}(ro3bpQSQ8eeL*1m={DYlE;~ODl z_A0hp0U1-9)1f_@n-9(GjI#yH^+WdI8r@{|@Pybu+1upuPN|cIXb9x>EY!L4=G+9X zhs-r^L8TwkBQ9tU%F`d*JqQ4ec1T7oSmGEM1d|>B1KGBbC@I~~DR?dScv9pz9F8lgC z(NlnZx%59_ga2Z-5&8db?`36X|F4U(rT?QzdIT{Z+slEX_9UN0JEiH}4#(4{x-JXp z{4OF6`3p}mZei0b9U){(9Wh{I%sZV^@2Ry&c<`smHPq+G{*%i4okiPcd8TGUwq_!x z=aeLLx0j}-Wr$*Lt34BEP`0Dfx~E61tY;9W&=HAGk1MBf`3@a@KTD(C3*6~y#I#x%eYzYO==~Wd~1oFBEatAH4+zv#!y(0U3I0A5ZLtn2SC09O*R!lPQvA znAWL}MFhxTjNxUI?*)h7@jw-_!!o>oi1Vyy(;g=@J9H+xfW@)Zjje!sCjYCLEev$N z@)@=~-c2tmo!1Fw2CMAX*7c}bOhJ~OD1!$TFBk#U0pYVQBxpca%ut&TScE51Fx*W@ z+-7{gS$j9If7~DVJt10P8h?3&Im(c?{`F2cgIYf{{oAu`a8ysF0${F4laYU?K*g~e zfe0GBbji%)0>{I`2&V6jyxB4iG!T?+%VHfd#g}uQ`_Hh^mS?G${LnJfDx|P=(*+v_!T?>x-L}DikgYjF9fu7H0Iw?z>_iFH#Moh+gY?Sf zUDpYjr{SU#7VH+?>GNRpjECZVzi4|O_`VUb8_lRk&@MnDI0Xp57q7c1-6C{bvy5B3 zE}4GTKWDP%LcOSs*SUi7;U{kcaF9Z)@y@hwQn5-D&PLuWeUB_OP2-~P-wD}bOb+r` z=ZMx-fUL&H1#$*10&bo`WXY1MQaKM~Qyv?AkhTH8TD{4317ZEQ>BN3wDLA-{Cy?b^F-B=`pM=A+K21K|4n#VtZ@il$frgLG2=W6-~g ze<0Z4jl+1cr*Lg^H>{{xq(%ltNa=RkT)Yb9Hk2lJW^;JwlW;FrMAOzIo>+RZE#0hn z=O9abrWCk7?KFCR8T=HoI%rP`h>7cEzLAgcoMX9I`L)tzk{)zL!JF3g4&$a)^h-i3 zw$w4X5-L1ex{1bS%0j%)GDt(P_+5tAQy4);l?bP=t27SUF;zrgt{P zfFg1FR5#2MK`oS{)`Ld}wz-(o2im1?2TwpTtOeO;Z>Vz}IU5){t~bWl=`U4*${J+J zWO!hik!7BTmvs%07Ulk44=%f!KXco5R_zm~$qcz`oz4gngnW$dK~P`zxpPpz6cw zM#b=<9JHc4-SSJm@VbF8NBTBs=4dN6R_}4gS941<3+)h9cLeqQHj8PT)k95v9#kU8 zYan1!h%IW0it8(pD*m)^U!C32z7hXGFfJuf@5x6w??2@aQ7sXpFXyj$-%$p0*z?bU~=RTKn4036!JbVmyaKA;iW zj3@v1v&BYF|DOaeFfy?HHyh~G52Za|{eLL!Bj~&>88`+n*eKYjm2WpVhfvj7rhV#n zPvDR2C4#u40~w4-WP@3W*uw3p{Pb*OknH&TZtT~0j&zOByKK+fiq6qZ%-KoG*@Oy9 z)r5Iqn)Wv70J_B{Gxpy1`I*u8=WuF$qo|2A`@T_mVq3K$_`fqCBDt(D|~A$K*-0 zefpb3y=$v5=pa&QUIWIc&}x2Z07^n0J5rJI+wf`d!6={Z-P1y|g<*0&G?r>7S^)BM%1=@sF9IrJ=37{5HdvVw}uqqR8 z=BeIbNZzNcJUW7Ye1*P;?JiR5JMR7MGb-Ew;#&NgMyGaQ=}HC@e`ulxSXSW7SyU`tIA%o%6Q(D^uUV*&8+_Wr{^#K z-<5`%X}>G73x`9F?CQ7!Jr@0-PdJ(ZtPogLg1B-}&MI+5d?K&e14?gU8<(6w6}~+_ z0hrrv5Xj&37$))MzpKS;-p(S9Ahr>O2`>cIw9!mw>}Nm(xj!~9UpamS_bTT=j7SXM zv`4Acl*Soh%&1#aTt}-6nqB)?zoLeq;M>vc0paX?VlSkcGZv9HCPU=oUoan;^lal) z7aa7NIeKE+s*t07Sdoc4asl$N%mj!1%z{e>8aULIJciG&U7V@7WY62 zfSfBDs%zo5lB4M-u`K8&4YY>RqAkuPltCNt#8@AQC$f1Xmh(^CZ` zu$#V79%ynR4ZRq`Nd+YUUg3l-Uxf@QMOMfDTMyl& zh=-n(+PhM?LntcZ^j^c{8stNT`_%n1YX`7)oW0n}5r3Ve(#bB(z&JC8a9uqFM-;RkVqW zO$c}vCD2YIW?{g8=|UYd)ODL-sgl5n!W0TEpW+az29D)R+Xkaeuh<21tnNxsgZ?G3 z)s!Xi_ddO=YUm2X-bbRcOc_5h^^!TK=)`Eqo(1k_{0s6E)>S)g8m{A5Az}pmukj|8 z$Lm~hU=l2=8|Z@x3%^e2@MVdQ`s!aLmaAS0f8#9GhCm7Htp5287!aDAVfCD%|Gwzw z7&#t{j^b&ER+fuMLYvSUP2jj8*WZ_4*J`Fqs$neBk6@6thq#S%60q&Uznd)HSTZ~= zz{8GJ4PRu5{}-6+ht|Ig-Ra8 zV%aZ0YsSqZ0J#_aXtu(m#l-?`J^A89iIbQ0J>2+<%9rsJVu@GVw?Hy8i6^>VvXlE~Df%0pg3nCyvz_Et^K$WmXU~OX|3rAOnpirWN0^u;N%AL> z>BAGLutYQq2-h>TR#S&OloW2xmcY^auQkxuvI8gx7w6q}@0i1vP+Iv{w8wUGB@NxrK+YupIsseX2^XbCyPqLNb?1{b>zC;i~w{8EP4zTY5nCy$m z)UXF{&j#b36^xb5S|`KQ<5$+X*{gz%$Lde`EvK@FGJ_lx(sly7*;vrXqN!ZSwfYg_ z7(!N<=(skbwV4(a9?3*b=N@uNZsXj3rhkTsv8M6UoKh7lcbRfwPtdGyv%>9+)(lu! z!cc?E#plZprFbI}pM_ZK=f^T|ktb?mRGmKPTUFkmy(v*|#dF$Q8O}%ht8l@SO{`?i zTm-xgf2JcEX=H=89ew`}twb0UV)j~n?j%GN+jx<{plg4biB2Lhg7{Y22a!xC2VGgX zkv@6GSV7iZf?1qX7ndo_o33I!QYxy|w{?Lk;W#1r;XY#7V5x*$6-Jjeuo}c@=ypx; zUQ{#t-CsQ%@;VK;<8(1&XL)!N&_B_k1lvZ3S=fGCqE}BHoQmJcytUky$$#CtU_&MX z#tGm>cJxTal38{zF>E%0{)s9Q_$M^OI2hYXdZ6h1Ejw{}FX0>DbYfqp=Si4HPfzZ{ zVRrHIN3%Ue2n!bNX?}(Fhux@zl%H;%B}R1@H-Fk1s}{WZG@I-+yUEekiOs=qq<&y8 z%S;#0wZCJ6X^!C_Hz#?@q5ZJ`Xed?4{Jl&&+y(%i!pTndR20+#nkKmM>fOm>iKkp- z-Op=N**CSI^FUM<3Fmd`iH!eZaOAiL*E(ZB48h1Nv=#Pu0g=ygudrs>BD# zCU4i*hZDm?6CeuwxyadfcraxvrTRp!$}+tWqU^Ocu^ z?+@D2sfAt==yG9ihxomIWcB^i4E#V)q$J;tUlhC&vHVu_(JoQOd+Y6qwetD!tWs#r z;e=RGe|IUhlHRH<@`hiOA{2IYlzHY_aiQEmAX$U1dVmmm(#FH9$>AeJqjiKb>t;j; zT|L+Z&p7vi(yVezCoO^uID-T1Noaz1bvE9lubAq%l4r8uzV^dqi)!wLKT;nmbV+iy zl4H{7S$4`1s@6lP|MkcZd5;&Ak`rT0rp_mlla`b_Qj-qiIF+Krz7Urhn_5?NK*2I2 zuwtaJ@12^El4Qou0oL#~z`tSSs_JbqMC%0bmmrm7fjm20|KnH-RBJPhw|p!#ozIzhap~f6R=+Lg-f9J}==9)4Qi%=dA0hq-#XR*t z#o$AucE`s8-65Q~xf6VylboyD?`q*-+GRqeaLbBTl*cGZhB5t}NJ&QEv3-O=Xyvw$ z1ty$>qUX2WFWT*>CHpL{a@gNqhS_s8YfPXBah|@v8;J?KeYjQ6_}6AxgMzlZhLAHv zqZ#v5KOy>Ph5cH$sZOZ5gS!~jXBZqIoYtBajzMlOgp6> zw-i4UV8AVi2JEuAN&{K)jt21Vcivp%a@OF)W4dz*MuUD?2>9i8&{hn%_)cn>cbnlf zsL!_RS9MyLuyM24+Bs>@sm#vFjeL)L)wE_|eMc0ISeyQYcPZ{=t%~34Zup4oc73a! z=sKMfk1Vr4Xy{@Z*#>3Ul*|8MgnNK&n7^@^AQN1#HT>0^*Bp%BNp|B07|x{&Whx6I z$%UtUCB8m^D899%6idJ*lJ)lgYEt{5TF~K8g}n=rRInQmBCcJ^mR~@(cxf2wh`59Z z)6f@CY-Lp-*7%(%Nec!9tJ#V=Tf!`S`u(6){#YE78yx6^8Zn!{D62e>>$gP=v+B&i zKZE40ImZ=V)Bknx+Hfu|MLPGJh|dVVJK1i%qe%cg>%$iFR|;~gaZ}>jpXc@M7q1Qb zn1E}orw}ztcY9rNa>K zK%gl#L9S=Gu-2qA^-YN0+m5{jG^z63%{}2=I|ZR{ulG)U?aQDG7`BPfA7QoraW0bD zU1$|rA;Suq$3#g3Xj0DKM4|uQ3{h&n6h`Yp10vF9$xBK&zaO%OYVtL@(!`!3*wQNt zuXy%kk)es)7aJZk`SgU6fM$J zmrQlluWjK}BOgo1udx%~NV!0X0$(lVK8#?*-Kk%umaq;;E}!UxaVl+k`*1jE%1&HcZo;D~lc;(BxMskb)ry#S0XrUIfQCn|HVGfQI12%Oyl+@OS5+H| zFSq*zs!~aEBtah0<2MoYX;@i)f3zhf;&_W&H$sAfik|cZ91{EO$-qNf(^!$btn%t| z(YL{X^0r*6xQ2m22`V8q7H3rwaP}HK=gF8$b(N=OkZ5O!x>icw)Nq4#p5+^BLVnBS z2jsB<_98%eXeV0qFLQ`~6W8I7!->I1Xh+%MCTg3;f|E6N9ZNrOSfWy?gdh!1WXGTv zM+A^}R^=6x*SVCb|F!3@(wh!~l~m=0m%3J=BofZ1L8(GF#N7eN;f1o!5nw8xL=Gh+ z3kYqX1JebK;Iw6QNfV!p959t0NNTJu-+nS8>Je5r;@SoR0{se<&p4yxBMWD(FN<(q zc||Gxfz12Nx-59V1m)z;@M@>@K;w+&B~vBqjZytl7F{}j>9Pr* zkxqZZaykI@v;;B$g_sx;=D%pEj-KWcTf(ASWx4Jd&*ff-=+<##ApPA0mn} zX86Jo>eu0;U%UJDu=n`C_tbCMIefu7+aWnV3j>3spvJB}up;yp!+W~DJWsdYUk_0Z zEDqMw*BtF9huOVt%6m*-unw;KTo%zjUEh0!5|m5yyb>i$qXVz|hs&8UkQ93~m5)Tn zP|IG)vD>C`$Krso`+{W~yK9Wf_)^S#<@OXgMhdIBajxVjsR{;JXpy$ElxTJa2D1ou zuk+9a*g|rJ;R6ARM(i(mXZOP4+|gTKEXqU&(L6LuBu>eWDHxezj}kj3oE%&O1bkG5 z1Pu6ov-!1+SblQ*t}caPPWOQr&G`*y#bY;eU=?@C5$5vF&0U+3^i!L}ppN--SKm7t zYFOK%pg7K{e&&6G^cZg%F|t7s0%0I~33cPaY`y^JhN@za6~Xl zu8gjM04S8C-Y57d2M{NeU+8m{VdUxslZP*sLj#F(C8*<($!%)FUn%k=dO;2bs~n+n zTwsa;U-0sKp-OrvQMa~H;#n~~$VUiz$eoemb_IY0QJPe|U3d$aOA5TC-*lqfeiL1@ zS%Nu`8W6cKy4x+3n1Kax$e4wm$5g6-dWsD`w5hctFp*Y54hFug>_+U8qp(;3Ma49m z+|871J_RnmR1buPh2~OtgdzVq_aLU*%!B+kz+G9PfV)DucZ;KbgB}=?uUY z>%}GdRXUC0$dEW&sK`@zWvI;RJ+Q{=i4*}G%$oxq>?Bg#0L*>w-MU#$2-?p{KBQfI z(!Rt3F|TL&7u#s!R}0>1EA81@2RBL!XUJFE_I|ZfFknorHdH8Pd;m(czD$}ZF&g1@ z#s?I9fWim&dt_E66KRbwa+TrkWJN(w4kR&KaIR!4Tf_=`>Zml3%54g%FIgJ zMx|}rwr$(C%_q%D+qP}nwvAIAaiY85=>1{;iFMC4uX&BJyO@yo3q{rDVBuOar^VE| zk2!VRUmA5Y1kJ(4H}t;A-zR?jNPDBD4tMAPD6sSuEvsf?Er^u1!Q10!w-wAXmQU+M zA1Md#rn#M=-e5a4M|a;ns?Bs;5PnkUS)^|dN!`JMswRWZm71W@){~E;cpm1cnl)K* zQt%A&GAgEPJH4Y=fV-;2{{rFWnHvq0ge6)B$Q$<1QEKdyiHhJRL28o2@H8AV)``kY zv1tl=XAo_!;0)^cZ2G=B(V`SoY$ajelfCmi_8%>2G-DI&0xU`;o5Mh-y2mG$(kDR*1SM zvSviKM{2Axduvm@SG+_lBABU-)^v-d(5^i;#IYDmIdgJUgr+``UjtS=S36cd)!R5J z<=NA>YrQDXqN)VXVEyVzFUeeco1UH0?p`QH7L0AO22s2~^>nwdmK(Z$fF;@d9_3o#SIeq{@ohY3HL`-*7rRh*8w=Kla3NIh zSJrXSt5`)pDb4I@w%%u;swGZPfA(3XTZExre3|jwq5dJ&H*gayX>D#t%iB2KJXO1@ z{;_IUw)()CE_OsAx97MZQK8<>O%q>%WZA}PGs-L1G@#}ys-e;Wp_gur@2atqKNN(y zD7r7LGAD^=Gps1o^OHh)5@N(5&K!*KT_xO}ho|a5c`>STGx%bUrQ!1I_99vK;@D{> zLHc$P`n;GP@azyDp?14zYn{(W+_=JNU!daBw7d6CXCo<7;aiCE>_JDb?-{PCdEVcC zZMl)=!9^VRO=YNz+AV2*)JikVM-j{y9ba?r4 zeLXq8UZZ$v3>|i5={CkF7~0;PU3dAe&W@fxD2qIj=P4<+_IrW=_Q{F^N0m*w3rbxQ zWx4}y-sL5mV!Ge%Z&PuGXXFj?^Paf%-gGltpC{TQwWMFecl~DWY#ekOJq_Jmu%27> z-keby&}ztPiF7x9)03&xD(;5Pmd=u()ah*sE4w&S-$w%;>|-P;bVle2;q zl(MfAIWM?LreuK748&8pV<&V1efQj+epe2G2&`frYqXAeDN@v_KN8RJZmel15xRC~ z#W3`-UNaV$biUMEKQeL&wS;@5M>U_8><$ocy-rB4CCWQnlUWzdMwRnUc#6PGj_|_R zB#C(bgz%k&6PNPBK1-n$m|u^$@FQM{kPK>jJzj8KiBo5xiUU2&zkxX~e`Fk+;S81L zq#=sQspIzyv&av45V;aQvX5H)sN8rF{2|tSiEM^!|Et@VGm7-GYVi2C!$961u@G%9 z+>-SdaH71=QT_cXZepN;h&B)p=I*lKH*mc+N z!7R~i3XV*R3a2z+&Yf(w^#GB%-K@Q6tu?gfphhc_wq`w6iuCY)x$%A9!`VjOp&}(T z#Qi3(4?Ga!)`G+)7k$2IFU08T3fnKonjDOTtR*A(Nt*tV-)qz6X&U9M8hzARU z0<6gN!iTF1>gH7i6+}As!uL4CJ?7axUrUltQJ`f(QQ*YX~f9EBlgyTMXF3Znx3t5 z2P0|L7rTUY$yo3va8Vo`05T|RsPkYvd41&`W-Ez1lW}w%#jL%|cA%y;y z@3dg13sUtl8+-K`2%BhaOBtf(vy?duJ9lInx6wL=Wc?E~|cJ zLsP@4wi3EsrHv}!S}m~@h)U(@IMje>_K-^FK5H{of<0wad|VENkVW!ddAUTLI~*C{ zBT+&Vtbj?hjYmEk!+y$i^s+>%-*S%%15~5!o5v6rt}quwvnq7UzG zCL>p9mHI^-b=Mc~9u2K5CS3Is#o+9o2X4cS1o%L5x% zJl-aU=}bch<)m$Z1SuRv|KG)t04laA@x7N$LbqEpv#?a|O~PHFYxmxfojU^bnBmCf zqe_gZ6{7_=?bHZg^~SWnJ!7br{Otb?XhEmLiygnl95US|wv8gAq zGZ0}x7bWFmPxoS-Rwki@6daKQy;rc=z3mFEuweg;&M*$AeeB1Yaqj0^nb)%DxOQdH z(MS5m>)yuWxIsoNh*70ssVR-f4FRE2_v?eV;nuQWyrE)|Wq*6f+x=)K(1XsJ7XL}b zj%=9#AZUPbRbx#4V}@H+;jYlk))84?z(rdaj|0WUZ4-VDp4z3Z8D=)Sl!1Y5N?(1} z(MI9>x?u^QCWd0t+*ghc3kTZvE0trxE#dV^>Ox5Y)slaD%z`4j&ObluJCGH<VKFK82&rGHVYHu|NVE`rP&cn)rL6rh57}upEzU&0s;!w36@1epT4(i>D-hM z^z}37jjAD1U$m^h(&|RQGDI5n#O|Vg_&id~iuqGECG<(xQu8xh;y2v0vvGpIvBTG* z=NlqJQKtpHabn~o>5kqU74&M+GV{^HSJ)U=k#e`NRm3bH3A+;YOxoN#^N7M{cZB|g z>NWP>Hq!i>sdD$=`!#dY)9mMM+q2hbx-oR!JEswZG)}=-fn^38uc?g5GX?OKX*fCY zvWVgtS$i~W_Ca5M=gd?Uv24}pD>)I%k||k>mf3j}%dL?}(rT))f;pNgXB1p)clIwJ zetQh+KFOOjw{1jqUcy7U67dlKL9eLhsfv+nx$jPO;fb%3FQQ=5|Dhi0sv_$$X}4aM zrt$^onk=sp`3BTfKIr*22`@Nykkh%ss*Du?)2tTmmhyiwrK4&&XDRO7jqwieYz($= z;vo(LdC_4Ff14kek|?WetKAfSA4g4tj#Vvi|NSgdNCN5CMVHpOAZ&znnZrWIEj>zl zu4>aI@J4AF> z+-I<`B^ZuXn~t=g?R%^aB(Xz^hrl>BdA+!?xmKJuz6arARNyGIeGfvWtY9GaM8NzR z7+O$Ds4LIYXr57QB7}TB9KrJuQQ|n=@KNHeOWdbDaHy5Lq!lWY8_DC+pqSjFQS`pR zOpGAIUg=vpXX7CAWSp7t-=QzJUDJ{tfT2H>zV(;b#(9pQ~xQu?ibAAQT7!g$L(vj1SuN#kgjl^99vb+|bhB#_UqM#{Q(cC%&h7*svI3QdG;` z>Ftb?!u2Vam^Fc^tI`f8lOD(|-U0W<0JI~p6}KC0*K{|jO4K7qC+gp8QJnXNCis9d zK6%YZiJ1;rSH(z}p&ubtdvkrcbX6#2;~E}fSe#SKXYq<)lg_eQ|5dhzU(*hfS_`F5 z_yfG9e~$av4!$kbDx&9J7v~o^@lR6%A`;+r>vzKtnBZ;;YybDT{QBl$j!3}ELiin*LJ8quJ2Fx>|tVJnrU?ewy zx5&WSSn+uRJGtd(cdXRI%9a2XK$8{xQ72VaKWSY<<#I7z%fiC`nL|E>EVHta&j< zufiF^H38o&!<`hAk$@?dE$20%Fd8=!7F6iLy@Wd@{bX-5&J4t9em2q9gLWShs&lE! zDK3>vo{U+MW8h;@v$He2zNk2obaq0B*3z?rSmiFo&8^85-J}xEt}}%31DWVbC5%Y0 z!P72B?Vv&WO^s2opAv#4KR5DnCHUSlICJZzQ;BP|P%F+Y`x2%BAb(v35e~srv`8A^?v3P3d_{uR;o8)+TakrbVm-w`HL@DUT?=Jz_VOVVT&vE}ZJ z%!_g$M+9Oh$MMuL;;cr{6o-B}P-|^D(4i_CM++iAvE~baNvY2f=Zqp*lqWTWk{~97 z?Q~Ehd6c_g>9>nuM%oDH)zD>thecCtpe*2e%jknz_ZFTdKT`egQ_@G=lVlFZ7N!tj zy)tG=Z7>y3deQj(;>+GJJaBXL5)Nw=1Ad!lW_-@!(`E0itFINZ?f`oEdnoIo=vV(GTWQtQHd5CNkZ<>LY&AjN<4=KjxKHz8HK$|CQ3?T=5TZ_tWIa4fX3 z7o0)4HA0d;N7qP& zng)B#{AZtky7lDaxAqq6a4WbkD^lc`WTNhzAQ`|!E4L*}9{cZ+TXuZcXDsscFe9_p zb!U8}Cs%6{!{S>qqAcH>flGVn`C1binW2M}1Qg6Cz^&31BLxComPh=i+{ui2sc`gQ zyCu&7c%3BPjb>CA>=d*B*wRYSU{s^*BqXxiCygd)y2^#!EFIaS&8!&&`ugmVo_ZYJ zxPk^c3X4o3{Rxb9e=$G9E%+)v8y zo$QCSad{92V%?#;y)NjCcxL^!bKxp>g-Kl#@tGNxdo@eoin$tE*CR^(P--^4%{wr! zMj06LPR+EQIw^!Ull-?M*yrDRM;Vg%VF6ATNhq4{OE!|2&{6FE>?_Y;BEYAoK@wFI z)zS7BDI&{j_VrbSBbMm{+zD)DZIyQNy|z&9D0+PE6QbxToK8pF^u|L8f#@WhdW@}cJFhx?dnZRnfo6!8ROE8=4+-_ zb6Tc=qM<%&J$`qN0tiY$(Fuos6;wPbVQ_!T6CTfVdV8G|&9SU#XK!#55t*QGZ3%Un|AI-nEIWpa@^AJytNet z+%c-J9y_s(`ont$w#Z%yIJqAxzc7ZNBs2t!SLf?O>i5TIdU(HAZJg9B(`e54%&E`K zrSY?;v0I#+mivP<)aTvQI+UX-Qj=VUW z-9Tr77HZ7)j|yQYici}$*x8R5%W!g?Ub1ry zYG+7$kY}m?)TyhMSE=iL6?snr8)ftC*5k2SHxeSv!+ICxkGsijyz=8*M#H&Fl7sIf-g zGm3QFhI(|_Kz&*xEM4_VH;^(3cPc;Duf}(cKP( z^1;I|StyD3$d-9|!3pPN5pYouZ6qD!8tRC>zhnf3{9~+6RB@?pN%MmA zg(U(phwOd7iYieM$SbBPvRDZED*0jn&aV2EYtPq2)eH9y5VEJ;#ef_WM#e zb&~sQEeUHhHDI%-y|bx1ePlJ=sY#&=wbRxp-KRVd3UgvVTQirm!X~YHYEO40W2(n@f zTBZ%n!Y_q%i?x_u=2%`-0bXX&oF_K()M3hLNtMs^tTmQ@=+GrJ`F_fK0zCLK44J zyc$C_QgWd!!Y*#u{Of3j-Y^GA3lQ?_j?POz@^H@=earfn?e^QaoCT;4L(?%%q}d*r0U+6P6ADm5Uzh`kr~Bn_Lx;jP;H*>}*qdtF*&qWddCTdUm^b4oWQu*YO+}wrd z&o?qV%I_t1K=XbsAD?7AUkSe7*F8U7Und987dO|KiBDUo~+*q;+mpsY^OCELJ`z{L)`fZUZQ7R!zd$%yR}B zF&6vY(hK;KYs^anA6ppWb~2t&suW-8ylaWQk1bO~6A%x>BPS)5(wZ&gMr_^}E0kPQ z<>&St=CDz)3|BRjz{Rwgslind>m?uJOe`>_ck(4>Hc`tTT*1Xc%PdioM!OB+pH~OZ zWI1T))yaC)r`FUR?x>m05AHn|gfic*%{)S1*@Y`+bbgst-^~OkZf#zfb{U(iIUC$1 z8=p4uHHY3EQg5wz(@a+!FhcVj-}T(K8Vgo`nqHo;Sz9zLuc1| z;3G3yRO{$;(+bL+Sm$Q6L-|h_Rc}e&gfxsqF$L~Zr-=zeCI6~0EkK&YHA{;&)cV9x z;X4^khOBBq(Y0zt6;Mw)QQBazpxY?ub^^fAq2?;Zww$jo=9={CTFS51^{UnCtg?!g z(`E8bdc9Qx1|+#|a8*U;ibKa>byefX;K{3gaGd z-~?%++g--1MR$)9(4xf+_Bfu`?~F#&6Y0xRW^ULUhX$~A*fa<0IQ8FmqN_QTi>OG1 zIT%I{rL!ORlR`gPn~fvc%q_;8Up(!m-lLpjE%8CX z-#fvzB_0xe+r!cv_o#~F{&_ z+0v5tM>$%f%#}PAkla<6iyO))ZdiFMVJM~z1;s%--JI;{qtjEx+&Dl=Ck0^mB#5Je z&*F?T;HJSo!1zX%Nz_DWmcN47gL4VUa|IQ0`ggKlGQ^OALL9n@EmS%hd!2inZfU0h&yIM@#WVsmxp56x3l zfCO%t#myu}XmmGt?W7-Fj=YDP0|ytFa!%2Z)Zly~oF)YaDa_~RTm0g!>OVaqjQg_k z5?CqgD92~L*tiK&%l{ho()GPVW2p%qGSqZZ#%2wNeGg7qo3_j$_%M-3|NE==%?TrFs3@uZ-TO{p`GKqQ=32K+u#WZNsu};p{h9V9WqC5yOrYz{2bOuM<&5> zj2z{fM`1473JG{1*!Lmk>k?~K2ngQDK4|koD(wuhXo(`o@L<68*aBwv(Y#xH1;-El z1c&R^FKiEF*RW(CygBDvmL#eYV)BGKv85Mp-w zcf)=cgnt(G+90lAyTxgsk_!ZDahgZ+6ay1@6&&M;jyPEvq19a?i3TQE>w3n=D|7wB zTP@2{XC$|0v|php%0-zAj25He+dwhM`nPq9e1kh==SxeyS?ME=@jdAzj+UulZMeqX zb52KUq}RG)$^Qyg0O}aCw==9sr`c20*&~TXI1slOS6l=!(0tye%tE3};SGD-j*6v6 z!A)Y_YWU(Y@;g{xq|If!i=sU3O3Ad&W`Aj{bDNJ6zy;SOrp4)r(%S8Y=)+>kEc;;z z2#iwq;wTT@h@-O4Kv%5n;0|8IEWM=~)IjvCEcS914&4BjDx_-uC>GM%96uI#DKZ-B zTSoy=KnB~_4u}Pi#Yg22<)rL<&RlZDdtM|w88EZzJsf@BVFp0D3hr5J_Z_r0GK zk4*S~8oK_g?gJy^|BTcAX|rQ5SmC#S3U@ zbO6E}(~pgO(~yjHCXxG3L}wFv=ni||xvlEAKW|3|az7VjKW_!TKQ3?IU-w&a_xou~ z`m{H3QHatJ6HC7uMD?~`^mf?Uuuty$+JJx9Hmel_d(JI}sVt#$?NvgXHfuth**3p8*E=SM=WO4MqJ7wT9USYX*zpW9uz7-3WmzQ2uxxfYn}H1KOofBV=`kwG_I9E?vNb1 z93LvMEn2xU9m?CNY4g!|ONx$L^ciu0J!CG#;%2r}#^v{;!d8ONyq{F9+U zFv>$Qkp&>R^*-d$8L6S_#!Qljv{Z`k?++0JtRVc_Shzq?E<`@NmSMDvSNDPv3hA%V z3_eU$wCY9X*j{{!KiinpLD|`MClBzJ1u18$`K$qXv zmvBJ!k(?z@=qfI!U|$Wz5yEEXZLwQVD07#RNcK$hI})ZJKgKyze|PPXX?XOKySCf@ zx4>Pc5I(NFMGjKLO9E;nOU4G6oyi)8+5X)%4c4$yceoeuw%B ziL|@bypqi3n4Nq(oYig+eHKGPa7f?J()N9~3My6vlEXOat2n+!jrn1%!K!B~!UgON)3CfRNRruqAeon?8n2lW#^;*Cj-CH9-AJQy zFry2Y6J)Ne)LYy2ch@Ty9J~)&oGot#xAY7Q%m4Mr6RMZQ ztT$XAUD=>~27R1|itkPniiz^-elWMy>$PA+NXr|)Yx72Jwb{?@6TCs${t3qN-i6V& z8YR|HrGlRqD1bk5o`Wm3pG%|=sm2!z5%0i$r*TqnR!2jjZQ!76D91y6bT2_s2Q?Yu zHw06eBQJ#}*MrIqdr|9CwjYAou}@+YZMWaTWa@9Y>h1LRf{*`kK(q%o+p)(WoA|Ed zk3wz2YEPfi)pOuLK865i^w`ehp$iH~q6(f$CPgqT!?rhbq3)01MVa#l1Dp1J5PZ-+ z{p35%nyp>OfOs;jrb>n*$gqG&Q1PWwv$Uv1}5kVvFMAuMWP z`dF@{V}r=_hk_J%lo@sSc-X;C`nSbq_WojYK?Emo=H@>e+o=M-1EKP%>O<+VwY?;! zlMRIuGHn(t538(%nH~t2_B-vrbrI~kMM(<2U2jTlaJFAx?ZrQ)FT8KQDJk@U60#Z*q`AiQ2uM7N${l)b#cd--)@2{nVT(uHgJ9A(d09@o@gycl|9?zyJjhArj* zP`W1aoVdcX+-+n4htTpR)uPX>7<+ksN(~V&*-nw&iUFUQEK~Zrpk7#}aZJhJr(vOD zu&1A(%Sm(6zA`NCgC;S$z925sjlWxLz@1S}atWdKb)1&($~jINp+K z37eB&v+R3oP({=?_v&m)HGVK}Y5^Y%aT&=V0aU#y$o_hr7{%m6%24#NlIYQZHo?&e z0V~?g{e}Z^5uZ&C$f7tbpR27Ag_69%TxW0g5SzBW-0RM|SLr7uN!mw1C*z1y zir)c8zj8L43@f?P)x7r`r+Zf9Ttav1Mz#YupS7VMvn%mrbWnEXupczD&dEJ?*E0O2 zUP|7|v?~9gs!@ERJjZoh1HtwzDfTMQMaRi@jJL2j*}>K>rH#thC=>pWeQ%vIS@&CXp{&)2=p>&9K_EgAU+J6)5R4ZPnJbRoX?CnQN zSOQQwB(*Y0ATVEAM>DtiChqahStjxRv&bCuqbGaw^ID1HZVUHWlfB)%qgU9dDM|KKjqI-~!*SN2aG!Mo;`V4}yV$AV;z={j$=^ zAf}>Nc>v)-z=LthD;w8(*-e7iA&{R!M!(N4RaLN;Mt~d$kN7(zRb^Wq?3P9SdepK1 z(In1$zT}&vMET#2fFdz{XcfAWOhv<{LjpK?xxEnj9+Y&mpx?7booEBd#22jX&~g3j z=bYlXjfSZ!nG9eWjy2G;x)NRvQ`U*T*9uhPM6(lt1@WH66%6Q3^(fUOTK!%Kj|*lK z+|WZgL**`Ht~B+a*sHO0f=okPw|GC!8cYjVKW1M_I)Gh`JRkXM%~Xs9kYWE$+#{`q z#rRG-_s6){pnwVb6(~DNlrFWz&1I-hwLh*n`)@N1XkO@%~F{RXgN)SE~`jMy-wvnYU4UJ ze`r9>QI=20Mq^*j>=gz;0Qo3I7fo$|k&5_2f3Ty92u}~rqnXZ6OUj=6CUG(go4ztc62Gtx7$x4!YxX$YIT>^| zQ0{!s*t>AXw##6q=GQt)4K9&Dy{?ZNKGlVBE|RpiqBL`n++V;DPx3s^o_|Kvsn7v= zM;q}y?mr#vL2g;Hbk1xk-7{A9MYKK z8z-Z#y%XhGb&#WeGKbgnAR(@$C8ZP8WnEB-IOzr5=-aHDHJM8}*NnyNMrx(faw}gp z;GC7wgtRS4!g><4+G$}ixPQEy!ZVFYR#)PzE)Q>zx0_L0ArsB$20`>PY>I=#n1`~t zO8NJ2-I?n++e05bf~f6|IObmSrU$?5q^|>+kX&7%Cwex?VqWo~*yGXC=DwC_9L0(A?_!t>PpjhEk zf|b&ipaX}~roX0*w5XvPz2(>!A{+895(YwfY=X52M@4GI?j?xM6!^H|)nG-*g}sOx zq25cCy(Fiy9&N8G(EMrdf$Y_dZzM@e1o6t~z=jvPJk#VxYAG@k?{%gPF+;lGqubtc zYfg*Iv`fT6EPqj;-VYmt9qs(Wow8`7IN$CNa_b3lC!i@1(}XL1@MG4dx9Z6UOePW4 z6S#>6HN5K_a;Wk4>b=f*XUD6VJw+VM!}U5f7OAK8l0;*Of**?9a^` zQKNL#ne6g-^CCkU`RF z`0P5e9&~rp_`s+jW*Q4JJr0tTPK$?Zq{J2@?954h9Dp^s%xJZmq~vv5PqOqJ&}uPn zl}G2bFuI239I*psSl88m@eHT$js~5-UB10CtRyy#D;@F72M?yVaI&vl}@5iLo^%%b!$-^+Y3P3U{=Y=a9k9AH-%+!K8BZu5%xw9h>*2F#Kb7==WS72MlLFD{7nH7P> zmTB7l+!8bqV}9A{9>*lAc7P)jUTLAZ?H70wAVQ9788_1a(#Z`S^2VbL9;_+l5l|_Hu@9MDe>)}9;rAX4O4I>V?D1 zX=U#Xxftl15&w4ic#s>bnBh{eGga{al&-yjOJkaedwTzJHUsXs#OeW^Lb)5v8$QJG1WYJe_?#Z(yHfIN5$eUuQ`{ zwrVZ6(9`}wMRRZpFqaPafC%L6o8Y**5#;Fg~)b?DSIw*gx=iMw8 zxL!~82jaBm-Do~PYy@Liq^UHPhdAzr9yI6ux{J(mni~L&aWEahYP&4*h-NHApE++@ zdA~*wL_7ck3JE0}pqJR!CweP{GJH_+k~zMRfHLktQ&HI&K}xXsSNK30tR~|>V;o~= zz}Gb1BTWNJ`+w%`Yu?~KhIw>0l{RH?a*3@d$2j$o28CkQv7UcItmOmvrrgwOGu4a3ca}0{a`7B2d<0> zSrUXxLXzu;Kq z4`yY4<=qvfk84L}1-b`W7yEO23AaWR27MDrU@qC`?n*!%d!)TXYCsku?fp?Go9nlH zLd$vk~-eft=Et)r>+8b#NFD?v#b8dDQA@ z^-qmk6CyGi=Jhp2aO7AWkKj#D9qbamKR5LouUUcHjlclDP_sYlyw*0J^}I^F1+Mgj zdV3B}7g246AzL+*KoQH%p}nq^AnlaA(TfNx@g^H+l%Wp6KM^`%Eo3w!Q|tM6t*Jn2 zgL^?K=CJBGO#@Tz@BT_{9D!}1C7j%C&s#!m%C)SJ<4Ic1i-}9d1)8u=ej*wkd5=*o zBibxSlq~ez}kTR2zC)pX}9FbDI>V zHhIqbMmpsTNFunxvZ}Ci|0e_}v~XIFouRUL=mSfR>2u6R!_XIv3%C?9{Cs~%xDYfK z8*2wgR!A-`D31C=eXV#aqEYRA`DT+D&WQ)Ol9 z5TdDvR{%m9#Yw7U|Ltt-XS1U3d@Nj=!UY%49gziTR#Qr9uDqAgQ@NBxDqjRP_I{8_ z6uN?HL>qgcJg!gWI8@bXl8iPqAlA~lFT{w@jh2$547Cj&Jca5y>Q^&IY+kt~A1u=v zuo*P}h*o?p3r8$%1onlT3|3%jOFjz@k-0LrY&yN-2$Zm=M2H-qSLH6EyNKaER4zwd zZ>7S##msio0xi8c9S;&eT}Xeu@|Gvs-w*9{Ma~|-6r3mxO@*G|Z!3-%Ls6@2o`2a4 z;n$qZ6N4tv%8b(?--*0_ly;6GTwALR|1m<1EaSoZs+nNS5DLk|&jD4Wn7L^R?`0$2 z9aG*cXAE>t!h0bZ|8{Jq9Bi{Ie4re)14g5Jyfxzf#M;H!>O~|az^@Wo)MpZRd1ACB zFiYE}T@)p(DeiuyR2en@k?{#$UU{3WH}K7W2aIc`GKf@8v5gdCV&J9w62qeFB{^p1 z_sxOWl%iQ@v09-G)-l!ao?h=vX}yfQUHQY2uYi5=Jidd1BAI|AJlAiL*DSZ1F%6erF%G~mV)sllnMGL{t zBtW2?ETkZ9s6c%UGlvqMu*InCU&{`+E|4;9vATvZ=Bc=kzNvsYHnO5Dr5KbmaZc0q zPxZx?dYp6lXTtGbOd>f*Rf^2AFCfEuTCC`LLG7;mL7S*-6dIr^c%-;g#d92ImVUnL zBU9$t=*m_`TYRWWUDrUb%B30oM61!=%W4|SnM=2EO?M;B#wnX4qdqBFm*|0)QEW%L zJe99lR_#(Xi}tRLRE!}8_AGILrGd8Y5n2YKtO;Uk&emG^6(!tQr1?M+a-}iK7OJph zK|OEq3cIRD!CQpoUosc*BOc+t{39>KWmU1HJr3HrWNbP2PCTPH2l+9pqtkv?n9n5^ zA-?`q=`xX3^wn-OCNtL4JCwk>Z>;=+fZ|7JrZmlGguOhfV*yJ!_?cx(O-14h_2T z6kx%U9%;hYo$Gr=cfm{|?3V)*(ZrY-&_^^Bw#BlRuB>KF#-^ycAG5odBc@uIZTdK` zS_{_6-c36qhXtRPmb7@S*4V8EWBC+lEb%%?naxBtQ9P zKaJF7rlT&|66@?eE|EECZEIC56r9$2S!mbVp^;UWT)w)Jt4pqA63jV{Ysfo&;Dkr0 z!ps?vY5&YjJM9BJMc)SI_^W-Lsc%c*v^hx+ehbsu2TR8z1ia)Y%;xY1#5E=$Irw#F zg!cIytuJd1`zTHoQ9!0B$1%5Ms@d_uXk~a;Hq{tG`N*0DN93ZA{z&4iHfDytCW2}{ zc}Jq9z5UrdBP!-0GyNhAl4kiFmy2-~5qv(k3cwp4guny=W~jPr`7pJWzDR7h)$I{F z)}qp6-=linf%R3<_hyaTpekpJ?rjq<$}wdHd0`7)^~;6PF!x%Z(M?E~Y}{gQny7i) zQ5TtJv_j&a#brR}xV;yIl#MojiC}zxK}S%UXeBsJRqPL1Lxf;-kA`_oID(9Mm-^p0 z@P^lkf?=AgC4Ta0of@i8#CC9v^_mapU-OC+e=r4$f|`w!dGxkKITcH#Na8i)#yt2a zn<<)F60_}0jw3aXLhUQsJ5#{ybb5V&Gu-A2+;L{})~KIDQD1 z-WwtwGJfNi542;r=H35K7fld}NHLbfum6MDO5;SK+U40KztAEf&HYJ63ccsY+x3Il z{e|=GQ*4);)sQhA)eIxy>g5d;oF(EGSRGp9=czhrr$mHXQ*dM`&bdN z$Ut|k|q^vd5L1VGGXYWo6Z5!~k6xbuF<$CDSIYWig_MuccT*&hEZn2>??Qv7u z_=;&FA?eHxd`z0|-MA5GIaAT=-4SlJ;F1N;Sgq-+mpDvIN*)oFoDdF+ABl@D6*bLP z>pXLh{F6X{v3mSXjw%U3S;s0(TPAb1UopfrrYD={b1=rjT>mc5J$()7hG{AtWsA&Rnz zVoJegx=X|kkXp+mU85nGmg&C;+IlainQZIkMq60L3fhTCWDbLRul8W82skk6o}F=A zhz3Y+s9B}f$io26z!=+Uglm-$gtf+`8A0u5IdoAT_@{ns^tR)AL=yP97lbA}%vve# zwHR)d^rT|b3(Ez|C zv2>WCuEUSTLD3e(TDAJ!u9LVubZvj1!Q3)j-V+ToEW?Ab-H$17dMFdRPdKtjD3DM$ zx?0RS6z|l=IujN^Nf-{VTs>SpP<_gn<*47Zfg_Bs8V zR;Gbf^tpziEOlbts0O*043u4x_&NyuH)n&U887l=zlCfJ{*FI@YeEiHDSNANPi>tF zr=c}Mk-96BHC>7T7DI6Bmzu`ljo+Ot3K;@Y` z*~b=6WSIQWjk;t}x}mOZ8DS9-F2Q*c29tFF1W-97U#hY8mZD4FHlT{q@g&EdP044V z@TF>K)Yy^v*>7LbE z*-uNmq1t9gcfdSK-*>^qJ}Sv$mKs~mC%*XGgVENvdLYRR=V-al$gxay*@@zf{Q^^t z#jS;T*7Qu<@x|8Pe5B>d^%D1HcQNouR9$z_;kD$1p#pExdsE)ZB>ZrRzF&O{fU4DB zBMEPA11A->d|zBr@YXMH`%FWAqJ6F?#(h<`^UA{Qzu6EOgxb~E2|6*^{49|dP1AHm zjT0QKu<(d8vQoT5g=HD0WJvm5>^*&+!07Fbg<$gZjbVvwFy1175>IjV8OU2z@_>Kk z@9Xc`()|zdwc|;cqr95ASK-DjN$@*Tuo^$$-HF=}ee2%W z34Yc)DKlHBrGGx^qyH;SYPK6=GN>w8=YVU9H~NCbV|5VSE9mtRMO*bQrS8yj3n`k> z+RPk5=8Egi{DBXYh&8zs{5)VsTBM3m=hlXGkc0DfReqWkZQ6a`^-X5b_bGEnOScxBCHIVyO|=+)1+1c{;2A1FZ0`GP0(jq+Jj&CYPJp_<@o`0kfZH) z3C#urzDiU>@Q=%Z^X*Y9t>xdRPJIdc!^2xP0%L2;8; zhqZ?P&ML(nV_QY8;kHMjCa#`Rk#BXl1cG)}OYwpFGFpS*=V0=#2U_h!J9(dLO(r}jbH8)P@u$~rPkTy7Bt zeQTS*>qebU_(&p;ei;%Y&jK>1KF%Uz`yL|K6Y(2oA}0+ocGTTn9%&CGa6~g_2L|B@ z52q=VWPGo1-q#LbHvTgrhVQ^)#zLM!Af)A`YBFlqlJZtRU()pRL3)?F zja3GgsWO)3%pIJ*zDsi?W|mWwy)rib)%PR1PT|0L(1IZYFtW&lwoI5L7xe0;IjL*f_LK3^S@mm4?_X`v}KaSya`bpJbB% zcXem1OiUomKX9RRWH0nk2>C=8t;8tWo8IlU%wu4!AU{KW4&910n;X(}5t3qr~J1B+8*Z9f8g8yz!W?rYY|FN{{friVx?d`D{ z{An_67r_?wBhpN1xO4ejE+}d{n;=a&$8qb2;4Z@+o?*>k5cL(d2h?dRYL7lLKZ?l? z;g{vDC`n5X)e$xIQlDly@=DeP>mF}Ojw)!~sPD)-*C6Y55U`iSvjlcOIj=N1ID*{b!w=PB1?<@ z#?J^&{O*b3%nMMdoOGfd6!v@)3J@@xZ_ z#o=z>#wCTAR+E4KUd=FR-Zq#!G9swlA6Jev0bJiF%c z=NJ&$qHM%{taqXkKj1*SLp zV25!az*%v+ZjU0|L1b1P@BQ!3nhfJTdn zmW`v#WAlXf!_8$0IuDVbRj8RzXZGcg(vq-GTXrtpp53PplgX-+av`IwIpx*20YlW= z>C@;lzXR((%3yNNW2iX92H9dC=H!`S;|53wJR&#BX5Jhj2VGyp6ICqcs+&`Z-bGWDUFAj>yJxX;#+wC0VdMKrWAA&{ z;DQb7Tx(DZR*tvfF2*=j_0BJBN~KhsWy7CCYVR@uiR>Pi28!v#$$q+-!84P~$n#%w zDs)?d@yEQ+%idH*kFOx8ju1z98}ME*)v1mZ2Q^1~Q$thRjO%ToCWk8%yctaP)a$qUNSlSnCvFJWC?O*?XYG;fe91ePlsJp}VQCu*RPLFgle^T~-b2R0XQhCw zbJoYONDZy4H{Ig{mwG*N>OI)+_^Dv)uJ9gJzZ_d31GP@Y}Y~)`1DydB1P|`X1-Rn4TJLgW?C{SSj!hiM>^K zwDEqmuA#?rauW)cw;#adz*>>tb4Tr-qxy#!(i+soYP2e`b1!{|H>{NeU@9&p_Q0ig zF!RP*)$@J#tT`J%qT!~m08R=q(HT?#f{d4F-*!uZ@skltc*jA6Kh;ho%Hf1SYSa6V z%SNeX`xNVr(>xMl5g`B=8XVGvY9n{y#|y1G?WLl|a1ZJ_xoR(>Rstt(@87F)0>fA? z3>rIC=_Hp~h~fsS70T?%P*r*4o^ZRq{IM=9$y_BA0{IfKA zA#9T<7+;9vCQ9(A7*uCm*D3B)?Uswkq)K504KuR=F6LpFw& zz{gfOX1feM*d>s!!7If$mFxO1&Grm7Hf(gJo_X)%l0i*%_{HSMkYRCGJ3)jxUX!#U z`kWmKSsBmCEJZ|LS`agry2tzHqPufa>(0vwAMq3+eou6vdT9gsOE^2193NO*kxqOc zIPb1JP4yCzSm9#*Zia?Y^IUTmP@++1QjNp><@oJ74qs}nAv#~aTZKhcn0xAXDtdXrs}-?4gCdoY&n>se-EB!0dyuUcsV(dagDZ7l^TwYzagEDj_;!+ z_}Kg2(DyD4D$%r^b7sZJqcHfCL;dR2ws&h1H0&h|dPX!y+bt)MZnHc8x>Ic-*`tKdf6hLjUZArSIsFjgPB-E zRTapVuLEKZ&{{`kXsi@H(t`}3oi){;t4f`iBKz1zTeiVLTW2&6H&N1+=~A?QcG3;$ z4e_7kUyUbqCg8*zL@}~>s<^3QTBqVke~dgSAd9iV(m1({a!J#0ZjuM+y9nH=Q*kMB zB#bpR?uS#PdI*jHJOgwOh`g=LxYAo;717jD@n)3!_`u72n5iv2aOzP}Z5eN{cKn=r z*;-iPnCLNHqwrEmcba3mZ4C`0M-+U*8FjsGFn(O+Juas%m#(s#;C6J_MY(WJXl4r@ zB!T)cZT#bBWi{()62UEUHy7}7SH8z|QFej&0)OSgkSL{x{$bQB2hZMt9T`49bpt?T zXP<>pL|!m58Uj)3m|iY_paSA`MOKI(5c&E77Se`83^9=j4c~S%2}@a2TI}~EuAAk- z8%?@De+8q7|D~5TN=J?gHI?W5@vJS@QVE{#MEb=tYUlF`U%@|LW_CWlrg(qWR_7|0 z0qrxtBLOL7QFSmn1!~5>dFzU#cjg30BFI*a`*0-i(hJgj79{2c59YV{nVioRzS|T^ z3a}*@PGIz4dRT{krVrDh9p{i0t(qU*5|IEG%H$HZ#>0*WgHq~!!yT$pZ;oFj7Mw3*wVd4ta+}~r zv3j(|jCNc)O(A`gYd%@Zh<75E2_J05d*3&=TZfaFTR>2I6%n>XHet&iX>+6 zDM2DvH?^J%e~bkj6Ol%yEsK`28tT3~E2o#~P#B_R-hOnh`x$xEE6jx;Lp&!@8_4*` zo##JwHG;=rSB){QhYk2j#?rn90ee)@S4;U!esVe*T34M6U3zN(Eqke+Mm(xf2XR?p zC)#zl$W_RmVMpnW=aOF~()BGmPis5s-&l88I#{v7wn2}Vo-t`-^~Dhz%X$48mhzAH;?gXFaMaK3r=?hGi%Gpq^qUf?j? zju#6$tDoz|Q;nq+;nMY;>4BnmIO{2+OyE2dFKvV%8ELdotQd&G^em0+URko3Xl0gV zRJb~)&F{OyPMN$`t=+#?4ARDK|&okkYDgP z%3RO#JB*E2?it{6zG@Q2jA>$u#eH&6ng68xo}ABFycn$J6F&|*#|o&f9n7(#X+&R_ zEam2I0x~%yBF_?0U~$*Q)nm;y3&5e`^0V9(VTJu@tAC(}CAy&9p8AA4|H4qcCxEWLpno z-hzDhIFtFO`wD^tcmEgNl_W45&E<~>FZv45({>ZRxAqB(u-&J@v^&^G9d;hDDodN*@T)1Q?yW<< z%i0M*8s@J+4;8hat|s)V9gJnd%J%Hc`q_2pkf9w*`BrSi#`u z@A}Qq7E6@Dh{s}=g7*e^O)h8_eBQD-h}v4&qtC;wFTc}^)o&QHb7xEdpH9H|>vBH{pEuhCL zk8-kcIUcJ&zU4Ye;u6iw%o}JOf@F2l@?Kt_;wSfC1$0cGistV0^t#>a6I3eT*Z1$OGz6O-ZCnW3YZDh=FX)uG;%C`O$9Ug5#Y(n&4Q<-AX?Dt$ zuM(1(-F17|ZWHv{J(w%21QRuPxIK(eu4N9F-%WSl;dl)nKW<;NSzi@NYSz4YF#qh< zXar$)`}Y5$orh4P9{;`ss|u>5Ufa79s(-CKKq*!HYRl0pmyH*y7OpCqe8yasVsByp zcpkK1-KQ4}O`*+%NQNxHz6{$Q$UAlAN=YePUoN-+3_)zrH0(yY#ogUm$g^?QDR-eF+(Ad+se^kr+d| z9CwJQH8he^UFlje*@UO`C61&8f;TDMJZ&gpV|W=ZUDXY%aO!vpD(GxtO@uxoK8QGPyeW)dR*UX=BUqMmP%5 zO-X3i<3}{WWf!_C-fwnIp@y_Yl@2T-T~I~c;m>=opnMCbSeJ;~zc*)kyJZn*eo%r5 z+BSZP7lIYk6?LLJIBPSIdL_80CP7>NLp|@SvvD$xIEG`F5GDPxKs(()MRP$8q+SD7 zoSKBFmZ#>RBtvvM=o+&hiYta7 zNrbjeo!;*LBfy7HQ4U>jt9ODXmbo7?CA^f8CNUQBLTDwLdW9A(kq+H^1P6^h<=L{C zqI8Ht>k5Vika127vtbI{395D1Y*i;Gxi)xv1G|cb+bGR)Vuv2IgiKNoq_VZ!+bF(} zb2g#>2Yc@Wh*MIPKp>-?4z&~si_CP00uzYM!$pckz+=oI(}rv%xiSw@9M_UjwabOv zEl0{}aW{2kg8gtPWWNF`h{I!yUg!dq@Kx60GJ%?rqggQRxIYT2UWL4~hECUn2Cjr4 z&|eOhMac&kcZNbP@y(v@90wO8>w)52upN?(4H?6Y`(H*$8|hUn7&PZHC!A|=qQ<0< z{sys>$h=I6aWn;IHnA*NJ(B1!%j>$KjFvz70JIPrCkzDZ>fg$38|cX{XCxnYW@rO# zd+sX)5XzCixM7`5e({ZZgpZ`+Ir3JfAd4_A=Sg}4g_vyn=Fr|6obE7S&Iul<8=3c2 zX-Ry?f`vvDWW)I6}17c(P6S7OkcOt~T)& z(fV6z&fKed-u61s4eN~7cCjO1gcvR(pjR4J4+l+Y(9e8V)yaOvJMQ^D{y>r9ScQCp z=%G$7R%RpX<12DN>&w!&me!EQ&1BRE<&-&$es?YO=3P?M2_&bOZwCg=k0 z;>B$OgqqqTZ6#%Rfg_T8Jb>YlMW>9*R0jk!*Q2K7Mg*B%hygMekWa%bwx{A3PuoUA z2qkig=i6F=ULovB%viC6Fu~z1YjXbRq?b_4Zj=YXe?TlW9RPtZVMuc>j2P#ErIYlIF)--w)LnFZzqurAivBzy&mo*;iWXrcU*Y)?j z!6nM=;~OTs<~@@~@W6qi8XQGcy|l_NP$p2^5FK{2%}OXTc!iOh*u&YH{+1}Y&Eb=W zdcYpeVz4w`onU+Yna3_wz}S(;;H_rBFM0Zb#&pk#>m`Sf2(^I#(SArea#~m&TL{Ej zfiAf2{)(r2Xq6k>ON`FkhA zzejsF9hZMwTsiB5acP|dygz_6jucA8h?BGQ;|tLceK)9nk3&Xk?|c9eJJ3g>XXIB5 z@^OX_qIv@K->NXn|5AmSnArY9E7PU%H+J*avi71niI1^T&}~JqD(v4ZU<>&CTZR8I z^FGD>R$-%XB2sz08#2m-zH2vQZ@I&RgG3u$+jF*1-}7U_&s8-tla&qn ze=WaWnHFaa+}4eYgX2Y`#a|xV{q(lZ3qSu|H8ekq||K)XoI}3sfy-U$HLuR1`ZG+Cd?nxoXMu+8|ccW=7 zn$vSIgNsk4=>>X^49 zrdU|+qUzSKa+8BPam!$$hA1R-#s`CUiRS1FcB=}y@XIdL(0h2#=L~4f{fN5;crZIm zFbvQf!Qq5>zM$)5`NFaH)G!c|fA(Pu^SBH6#B&l3&h0&9*T^792RL;4&5qk{>H~9r zPo;#Dm2NYG<(feTRhZX(m0)oW1|Bb&gU9LEAa4P{PQ5o^G@^PIIe}g$Gd4?2xMu`L zvAz$}Kxy%|=gaTw5Y08r>KrG##@fN!nA7^cZ1LJya7D8DFomO}tJv*N5DTstyGEQoI;iWXq6+0zKsQXP`WcFt}8Wth_GLL#y zEx|vs>aeZxvwIxkbC#Upl5zi2sZEv^Uudi`gmnMXmNjj4e#&Aje)0{-XSoZO86#6s zHEcW%*#;u4(O!Ym1sNM_$~?M5`%8LpVuMWJk0^KYGGGx6O}$yPVoDZiQMG#I#FoYw zFc}bTx<83WhhSb`2UrQkC)KZ-R73&R(YBQkv!s9yqG;6!x*=Dcd8b$5Q3&B^sICnA zi_up=Ivi3yA^BGFX?|B_d+PMxl9_{UE*2A^ zfDrkI<_b}J`@=+>4>A}NtK$HpV^qgQ;bVm_P?0P1`?%63>KO%-RzYM%dPOn+k}1@N z9gqZz==9w$a#IKi$Z5;g^&p!TNtOP3`GxiS4{@H(4L1gbCF@n1$DZL$N^dBv5c=S7fXRgd%47vL%8C*fpmU zWzkNnY+L?4LJAK?Go#;yIGh20=7C$0+66Vyh_;-R(E#{YGa{oV@+N#d2Zs^s0z5yb z%67xZAT?}adqS}q8C_D#g|Tc#!n=$oq!vu;ri2Od{(K721+qE}KT79S|Nk(57cFBFZ z*X`}P*k9=~DE?5@dDS-AiRABxw$drJucBmBplEIcmR2n>pqb|qpbC53`TA@|@N!)L zR4|M-jN5s4*d>2L;AWVMf;##(Y&YI=0qyN0TUReBh{1<0Zc?Wwc@+J93|1NOjUT~& zndt;CA1G#l_)y35_*=Z~yc z9~n_JuotqA=Dx}hsa!6)!?>Ee7Z<=yRpoHYZ(6Eo1cI{5y>h6}#F(0)^DRpp>X`m5 zaG!M9-956Iqw^a4FV5MWWGoK}f|rB8j8X9>#^51)Oc~L%=4GL+01aHPUPkZVJtC_? zkn8cYxUY?X`!Vq@RFv@59fwzx#b@T%I`>K3qW z;E_0#;?lT`JCu#nfjE(JIg}IOqROnrD%N*&wi>j^i!aa|;`?0h?Ky(ey&oE|j&U4C zTDrEoVobBl?D~8f?gSkQ%3~r|m|Ni&H0=o?v>ktx9CZ++4jG@9GF2oip3k9ql9TNA zc`>VJnrrA%k~2Tsw|FXUGB#+TF}p$rzikYt0*m=Z5bfsV@Et;-(M?|8pdvb})yy&s zu_giA#{s)hIXkERR(J|_sd%2AU(pgK+UC|tNtL2+Oix_RY13o+@F~E}n9N7|?1UH9 z$dV*0;wKqoWH4l(q_IA(rmV}J4?0*EB(DTX4cdc=pXI$Yz3asf5I{(7sJH+4|3Lu0 zYJ^(iuR!8{ir?HwfhtwvNtV3g@aJnAg5M=G-g9yF$jPD`#iGTu*Sqk1`&{tFE9KAr zZwZP0e@jU0|FP@Z^tmIN$?IpUJ#h@%nefkSK#ut^{Lypi?tp z>|EQoPNb6{ZnZpB!CU-kWF`yu!F)d_c$i|dRAgu{TA~9V8 z-20$<7;5qY5Q)J@NEnBNP@5tSeNkI2kqA~RWdn_0pL^zTaq309;ruogpw`{x93cyT zQ3VJAY2Z5*m%@68PRD&aXcpqduFf)ak@Lr?hP0y^kQpA58JMrxB&Y138xvW$4|ydz zawvH)tG7@$-NEhM#3RG;KpFI(Bsx|mFaI3P;gQ<+qxBaQIf!&B=L#q*hb@FG*6t-! z%~~M{B-3JS7hLvq+3eueg(q97&L0e-GH>pc5ZGK!f=s(Fa~=yu}F-w<`-**%v%D5Rh#$%4IbN8%Xb_p~bi@Gz>3F z=iNYlZ!1wDD=50BsLmQ6$qxj<$KcKwRgox)y^ zXVn}GBwQ>DUgX3dec16u1)$%4ngenT@Swu<6`E>D>^!KAR~Gt`6%Q+o94VE;emb3F zDBcY5&}%SKC+~zBcO(frhzwA`^dYUajF-h&cufcd*9km_gcI^H@|wsF{Y?eaX%RJq zOBUKouEJ#bA@L3v9Er^`U2vW|tt05-pvW-A1JyIk%er_dUVb7(ZBOMFjx)sAHcMLlq6 zSfS(A{UV@mmw`Y(C)H9W#!J;uy7pV4d|-s5C)|IiXOHW5sXJnQGj3k14DvoLJpx+H z6iDD2YURRa+yKp0z>;v2mrFIXCPPg)j+YR7t<_4nyCtiIN(cm0H_r=Njy$r6)d}D@ zm^?#=w0R_G&Cg^OCs*P0AV{z3{%CGM_GwEr2Jq5bWwM}rf3n@YuPm_0=va`tOkx`E z*d78w+4T&E6_8?Obph&32Nl1qkpyQk?V5aG?t|1f6%7fuvhZ92R@01?VOhT+qo^Qb z%4)C`YMv9g-88R)u^3xXheT8f%pjuJmW1x1>|uXp1tbB=2CZoEnJd#42J1~GpQNfb z+uVdrIJEb$$*ehC6H1^IF~TUZQA&b&f&_6{{vKnCmCt@R%X^0LUy^c=p;-gnR91!W zmrwz`{6J9#mKjC|U`gpFQrvZAN|nWF{Ol%#G zQrfubPzl=%LVM^)V(Ar5++;Ki*=UPsy#bKV?U>njbyUkph_>WykFu^61EvJFfoDvL zNW)-5OWBao-7DW&cNHZuHF&*FrwYUn-83ZuiyYu|<^Y!;OTN62)n=-pOiGylk&AOQ zmd$K@bWdYTN08rMXKvr#Bt+@ZXx_*}lQ3)&DXmrZgz1Utvak_39^T@n-a=w3SoW6) zn-d+jY`QS_+_}o|@}T*gOZu6F91tF9RN|VC>8~$|2N^!Csc*~3mDr#h<#-ryvu-!m zI+RI9N6qNiaMjyHqa{1ql>(!L%qmz9o3)ts`Zyq-MmD#=TV|tI%7p}(U)DEmGKWfa zqM^9BtXOK{+wq)g&U_qC$ji7ge0?#Q;~^!5Fzw~B|A$KCce87HMz#`}M8#SgYgk3Q8TDuzBHN`|JW`@0%^idVD!Si?0epen33Pb_sM=!TG zZ?WfXocR{hj|=cHh3$4SqUHfthNQqO#B5Q{uWBuwYL~F zy2Aa{iEkyf7M!c#Dm+2-rA|Ysg@c*OF9I2$S^4T)kjT6+(itT}?^MDH_w=?8r>e_Z z>rlt8Ts4{w0&6FuRix3YFn2Efz@J{YJwmDQ7|)rLGFfyOn|0D*;spYD>4gn!dYFR_ zkQCzQ<9^M_>cm4G?Q#6QUwH!(pL}bLb zw${ZNNS{e~@P9-r-3oUA;+WEyKX5AJMrThM$s4fYyB=$0Pr7*Ec^i;%9d0dQxkCiT zdifdC`S=0;Yz!pq1^(M92AK-jG`c*QOFIlVbP3$uJoGj4Bi!3*E??RmoY_h$ZV^)(37JA(&Yb-MO z@8{=McU}7S5tg=XEO=FY}AAbkvV%%tU#F$7^J> zSL+H;(f*x=^7~q}Bi|`Hvolw#F_u1)k~E-cE`T)~cmTB9H(hx%5E5yJ>NAmTu(z(% z@wgLy6!UJtur^lccjuLvH5HYeI+L4SQ=VjQ<$txYBMr}!SHtsZ*U_UYDcfjR0*Q&= zEEIH{_B9gGyjtgvkIiWNW5c?)xO4$CrcY*6kIPHh*M*=#2Rm)n>NdKqvBxL!V7}5;B1`ZMGRkB8qA!PMbJ4C+oWw)V zp@GdDWd05)o6DgAXO{Bx;(%h{AD2rsGeZ33(1^(jSLk0LPpz;DunH)>#Us_Hx#wE= zIU9;yA~GJfk`u?);=?qmqDK#dUmNR3?ccv3*7T|)DMnLc4yR_Jg#Wi*GkYdd*7U`b zEyL(M5XvZfN8;Ws7+vi`NR$TEs2%*@J6@q%1dP9d8Y(@JwTZksrpcq1cMVc)L|&bJ zSJTqa*s40B$ti0o`YyxypL`~Zm4#6;L-OzoHv)tsD4;2(8Rk_(_*hhCOGc$2IvG=O zXH4)UI}GMRkS~}JpQ!p;C?Qr-)ocY>X#6}VI#SKUQU7qAHBENz;IF<%tS-wcifkS!@_q_7d1j}Sj;~e*nIz%`HHRnxO|Xk61zR%!hOnZwvNoDY{O`(jI8 zRzivEMM!N%fGYo-SEX+#k@;(}z$Rv8v4^B=gpqr#Y}Xc}$|9Q=G}=IU2b_BlLr}pV zQz)2!II}x6*koUHIxUV5J=DDT@H_(niSn9}ebfriA0T)s2cpvZk@?-gU7Au?0EU=j zW!f|nF|Db%rqMpuWTKheW6S4*6@x~IIuaJNI$3eAHu2QK0+{dHdDjn_5^G@g=O0T*1$Nn?#VBIOExv)Ns~i7iPo8%5LI(+kEgWt4Kxl9KkMf^$DMc9Nl?n z%C6M7m-F2`Cn}$7b|SJsdly75$R8d)Gn^mdAB%@q8i@gHa6$- z8&}z4NC(+lA$f!dpOvlVilIgGvcVqI?^sSOuwG1?w2c&*fJ0_x8MIFdy6aE4_(hl4 z>pEyIz{O)EuEh{lFCJm?!m23$s8tjsP~S9aTw_C7dhL`0^L$zqm?uU7yGGS^0&U+J zp7V-TEF9>ch+M_L9JwXxa#=?v=$Z$k+=y{(cy?*(x`BuqMx^_l;9zENLBsQP9DFT% z-6j-Wc@D`R=-A@g@vX{co?Py?-FQgRJPt{h_;j|CZma9N$04OmWr{NP=}H&B>vzmK z$vCShGrxLWqMPSs7>zRjl9kt*d1*nkbXUJ$9R!lm*{DRs_^*+wr8G7|+t->^e zGYxyyJ_%D;s0fw6c#a;F!Dy7nPm!!zo-1F3-fD_%8$Qe3MuJ>CX=&MLDa>seUgtLh zZ|PvSxGmw}R%akIT$lU}96!h$JYxSXaQsi4Tt-f&|3^D1_5V$;x?faZ;iHJ<;Wc~p z;6O8gx_R8vRPsz(ly|T zGm@Vvt9eT748VPw1U>KQOY}tNPQ2gjp0Mdx;RDc(Q{*7X9$z32b`XT*iIU6fe|vX; zr44MhW;`>S|A?cOU&d~Lb}FgkEkw_DOLI$JM?%IMG|H!@DztGTJzV`P}(Q}k# zShq_CwOCt9qESM(n?UyFSy8_u-n$eD!32_3DR^q1u#1|}@)H;~ zM{OC2d5V}seE?h;bQKDkVQqScM37zl#G)ZcP27QbT1B-*F{m}nb{>WUHXTKvWSB;x z2`J%?oJH+~6rttnv)W~4^mifdo2Y*SmJ`Dita#e6X{Xk;(RYe!WAYjq;iVaMBF96q1}kr)$bBWMBqGDR+%NcO|AR zkc`U3(93HF6**xHFsyf;DH9fKmr-qQzzK*2uvKwVaIwKgRgy?R>jsf`B8^0Dt>uNr zQ)7E0&Z&9QumW1krb0e>IrczSQ>6l_ak4KG2qEf-|r<#3GqWp zd;(Xvr4GxlZavdUi43Aa5N;Sy?mkr_!AjG)8PjE5`BVoq#k5#MQA0cGvE3Y5-AJuR z#tSu?`K6XgLFcqFqSe@&m~OWEi7zF1R64V(Cw?9zF}O)p(Zc|2gsS5R(eOccDFlVX zMa_O-o{ObT?cb_YQ-~=Hz$jIH>!hSqUH=TJCQ+ua4MPSEa~w@yi?R|%=HgUU!cu$_ zCacqI$apn1jwc53-bg2mc83cRY*q`Ic*L5A!N0|gKgr3j2rW{xEE_qT(|vzSsGGF+ zB}EX-un~)fAc$&hq$Dy3OmGcCKoF=FU466$8rkEM43zmJwx0 zGIz%)QLmq%?471?P+J7IVkom;s0ML`c0h~4p7-!ld;%?L`W|=*$ z379of;^W5%B`YKco#6!dj7LFcG;6%YtP`@K-CAm8TD}Uy-47>$Xd3aLxCPrQ^c3RQ z9(@w_VYgG$KPvU2`Z7$j>K+NAP3&W_)a-Dy-DmU)nBcXtGMpFhBvyBH@*}l2t>v4w zn>Yl+=d$=whs~n)ssB0Tm=Sllvj~8#C=G_fUX~2hY{VE(sqq{L9Y~*Bs-x9(KCZe3 z_&~~E3mg?^U_#O~@;vvF1`)3`gZfm!Pa01L5-Qd$virT?sy%NFB>X>&{bQ48!2)anwr#sl z+qP}nwr!oZZQHhO+qP}bdGE!<%#FAo?vJQlxhrz5Y$~G26fBH&#hp;##2QTmV>Zrs zoKCoz!aQ||c#C&-Tj@Q}$?FB9`YubJE$S^Tb?ymhyzctU;d^8^8~hf}yaF=PvEj>H z+n|YpZwwqnYEbJ8pPz2AEL+ZdRy0P}n(FdvZ9eC8P_1GTgyiF1A44r+WN1vzAh>JLO^W!6&T~c6;;V%8);Dq@=<8_d zYVTHU?)J0U&lm6a8>7#AMM*FX*wm9_?mrrNYB3S;wY)U-dKLRr)V}7gQ=1d*{=3A? z!gg@7({--(eYl=M%3JuWjPCVqMfL6{^)Ss%qHVCsPp2LzTM@ciWxCV-Mb5+1y3)t> zaq4+#>N)lViB)@2T8?Rd5F&XBmtukV0y6V{p7@fzAG!v7K#*Qeo7sq-CU>CAD>e6^ zx75_mqlJ`u{EJ4|RAB}&2V$?sMsmS1i^ykk1Z6u%Y8ltvX1Nw`h3%Mf04=u;@@&dH zg0$tSs9>Fl8JpziK1F@FEq7`#{fa5GSXAKbM>xPGS4;Nj8!1oo!__c`t$ZQ0DKbKAP56TmsH^Xh} ztlT(i`Jm--?N?cr9ye>&_0K^f2yf3?x>i|D-pHI;@jXD?^}e6rQfXdz<|^tv$}Gh$=B9a`t0Utp4&ixBLrx0{hy&%1dr@v#bjG=Fuy>;sM0OnkH8o zMViMiZbJTyin0SKg9e&GJE^tKi@5a_yi9qSW0|*$>PD=o?;Z@AM`_kwAtu_Q{ip8e zFV!h8l0Ky6iA_LP#hQ>vkBUI_f?U*Vn<4OUb5_Mk6@+H9n7J@@h(@^Of<&f|$oDNE z96|=RJFh8w_4~_GzGBM6zCqzs|SeZU}wCBc5uGz_&)q^T17(|v%gjw11*nz*hqp9Mf z=Qni?okQ^1_l1AH=bUW5>P|eLwx5U$13cyNejD>FK{bec-y;Pv@iJDu283?9x2JMo z_5iGwHq~o8xra71Bg~OkvpzU%>zDv+cVh@e+9y5LfGZ*sOZY9ybr+;KGP?<+bfsti z*e5|!fFGn}w$?-A{xT@LF`n{Fy8P$FJH9|sYfCy$5{5gg2thuhwTd1Sb@t&l=%BuO zFqxYst%@3>;%)LIiD5cY9r=uggMjYGNH~8?5%JYjU0-T|Gjo5O3fWn;u(OiK6$IW= z$rvtCY%zd|o9}|56xZM31^W{8jg;{sd*gw;M|ou$TwM{OW*{5T78N01uod^pbQl(Q{i=NfoPnP^c`D!{Abh|%6h>JZWWC~CkLv& zi9Yt00Ki+3;A!iT4JM8c4XR9#WO*eOLGE*2lSP#d7p5I zK|*Z96*}DeSY?Q!YaGIu8f&v4_cA4uWJL-pky#=kXTBg1i%^UEEy3Ci)u4;eXdXV6=@TUwwn>n05u^X&fumZYG>d5%6Jc%1+u--Ga!Pem{qGT%7b`|_^_Q`axw2^ko zpm!?6Z>dTpHG12jepRsA2AwbR3j$F1X{3Ffo9tsbPGNou^(c2>YNU=`9^co3s2eyI zaW7lvq~w5S)+LZ){dKAi7}ig_tHL~|xAxGuf;}of|4Fjr`+^-VP+$9Rm*)Q_EoET( z4}xO*A3^c|{(k>;H$@6`S?kh-{7e2{cN5{(+3SMf_g7H?iR8i{mMxYLGNFHF4NXMh zXf!s7E|>O#aFEaC9^q$la+VJ?)~%p;qvi#+sjL1_@YlIM~_Yx@-}61S>Vlz zZuXTgx5)WVv72Is*ISQdx$c0SQ>SL#K5bB^<~}NgP4`CvZ->WB#S_Eib?qr1tu8dg zqi!-%W$}970YoF!`p$j&Q~fKrCbfju5+^l(#vN|U)8>Ku62;bELb2YG<^WTo0T%Vb zk=q?B(`qaAzdF+DfB$h5#x*42{rPaVYSsG`m^2mrD*X}-3NGG?eD@A-QiTy(o^ZGB z9*wM%Oi~?oH*D(mC&{Kv=awmm$GtBJ^9Tx5dyQg?WxmGUwcpnjIp)}lWZdw)+K>E9 zp{J}p59Wdk`Z9inL0r{AM`Wjla@O;Af}6!|C_bGdCYJ`9+cK4hv^hG2(RZ)JPRbcM zLwfyx#+lr4C<=p|tRNbTtQx%EB4tyD#YVfxpgYpNFzEs)B4FIprJYqK3A^Uk!Tr7E zRoC00!F0YGUQMo}lBX5e&_{7aE6e0n$VJEAX#v>XE<>s=Jpib27EWRX z1ZkVVR!m`KVt`xVCEJ25OO|+u8C}!Jqy`3`6HQxpS5%<@-eC6);I2g8IPZ$5-L%c& zBV%0^eKWit9cMT;PeDRlYk6{mi*g8nL+!d+6zf@{r393#Avq<1ykN-3`agGl|TByb4$^<5@VdP(>)UFfH zjEV@smI`Jd(^oNk`ST#38oyNdWSp6Ro?;&DmHSa~_1hXY#^L)!6vna2V_$><8MhBRqOQ@sT}6q*r(u)<+JCT`0iMrEYUAtz43A2xzU>5h8JtjKG;K{cR`R;` zA&!D8(dl=PJa3#x>YFO)0<>rK2PhiS((*>oTM%qOt@>guo6+@Y$G9P5=ZWeTM}-m5 zF#kT6fuLolA6aW{ikxmCKUj@brZo&Zl3-Z{w4~8}b66I3y#vRw@nUSFUQ>Zre%%=I z-;V$e`w6vHqrBd(O6xwCc$yh3{JCNiZB$z?qeP;(Kx}JAILdp|C8e6pH#4?$))*GS zGGlq$GAnJkys7;Z0;)jKtwg_YphbfI$)XVF_@T_rt@(&O_T4$c-)9cjL>_uhltdmQ zN275+Yw(-k43^x@kQ*bK(HyW+mG*nWSFXCP0hEhkMg5Fa9*c!P^$^|5OPa-ZWd!a7 z8g(j5vacB!T&ql06Wd&YFQ!Crodo(>>d6)jgX%lE=Yc~AzS%C!`U(RSi-pMazJ9K% zRKdE-nIClPvxZy8`#MtlcCzqz!8j{mjVP9kpOjt8)9j9!$8T^77LxA`4Wux_l=aiD z@_iaJbrjB~F*wuEk2@MgGgcp2mT@@5`&-s&`Z0IBU zYR|aDA|psc{;fZt@##c-{u8j{mbUZKsIQlT)?yIXjBZ!Hs9gxI_&&V#z&zJ%_B@X( zX@KU#IW)s@v>aYhZ$TX^FJeXTx6FmZM)9+^`T1#jC4E|&Yzt-^yrB>{PV!*Is>I#S zTDxAlFw+8h5j;$GeOH=_p9rXzbw{vuYvk$7HTyOG-La8cUN*CCSO)rH+d2qeW$oYi zB&B;h=Vwf4uJ()T6<$bo+LUj6$ChYptb5IpN zLP6;DEj#1c0&Yih$E)YOdSWsVJZoRH$|2ai8<+JCnk_M~f?qTGsQgy-m>@Aa5nylQ z=63J}gyG2%qpw@+>*m6@B1C=ayWKf5?I9_y0tLUDoidQjBt|{Y+>wk~?EQAkX9yKB z`(M%t>;L2kWu#~Qk1{~_fA%J;Au%}r3C500^=$>f6Ir3zUWe4{SIq)4^MMnUOyi$Hy_R;bps&awjNydvXFMFCx->T ztWsMyb90NG1tfi9@#7Y@YS61)u%dgHK2g2DZgj9fS=G8rZ`oIc(n|qP_r){NEe1X? zPl-?~H)LBIv^1*MX~7ndab!*(A1rAWbS5_(Qy4cXj{qs*&%+a$sTAh1ABx;cJzAje z&1G2VfWR9ZwpyiwN;n+A!8<@BfKK$Uc*;PF<6VjVm{9VdwDhW+o$2qx;GykK zDzC;{7MRMYz_bV$P7$Tw!GtJ@4Klw>O=GSQcQ?1C13@gb1Kt zCZtazBJ-5L>XA+qU|bJF8OTdNN`m130hq9iH?{1z4yOW|wUjQQeJ(Vo?OZg2g76r& z;<%o{DDs(p6eXkq950j^vw_1U55Z}I#u41{kd13rVCP4kF{4JRCVtRBn7v&mZDb63 zVW?Ep1*x7VxOQ32CiW>-EmjxPi~)2%dyW?%!=J=UMbCta#Q4md(%jm|#vgRaI9@Zr zq6HA-TR8XDE|^*H{;eJzfD2=KW^kfVR)d>YA-4GvF_)bv>o_YIgG<8$yU=JM0DmSO zcUPNlCah!&+knJJ^4JvJ>-J`zE)Si+pIl8MXHuMS04T4HHG*hJco}o*a2M>gw;9+z zLiyHCMUD~o$Pj_F5z7?QCw0?yOBQ}LKAkeCB8>=l(M6syJ>SMNA+Ej-4t#|28S<|~ zhGRQh>q-On7Tjx2$(@F3WN)12RiXP_=3;Z0^;bouWjcWrgr0Y+;N5 zj7|kanBvuczB$r~isu(-DCG$+*Q}zJ@eMIW(2p>6x2(C^wuo;8e&##S;yct@|I??m z(c;#J`6w`C|InLWY7crzDTwlmP_Im3(NJoPmAz}ia9yC1_5?+G(IQB>T-@89wZRKy zbRtC08ehpMi$S_NR(#&ga%Wwh6|+o`9i{1_yh;ya^&yTIz3&*MTe2bmz}S(WgHlR@ ze+0<}|C=N~7<=z&GYvys&7tM3v2CWu4fja%l8HxH>r<>=MlLCJBF34YXtC+G zBUmP<#hWtTuN@8N$~ZyP;zf>%arTn28o z?cAp!pEbZ!HEq|B$6xF?SOR>@pjt!^$d=!Jtt6XdUt`%*^UwBs&g+mnTaaP~n0#wZ zU9xg{ohm-szczo_jfnMd7;qXwh6dp48MV%+!LDWt1R3(ChJuVx$gI~&z z!g~;ZqWYwq1|%#2e(?+|WL-fL3#y3@bQy~4NDGqHFnsBrc433sjk=Deh6z?IPVDY- zCb5!r{TvOz3?55d)2?>qzX(4{Dzj}yJ`O{ELSq6~IYITzYfd6Z&18}7DbBV0V=}z< zx1!LzRQ@XIj6|HgcjE@T7hGUx32)|DAazd+<9(cVz=>$b1@fn6W#8!)(G1fz2NE*w z^E*RvQ4aYa5&(OoLjMZlLdRrIvra>@DpN4M0vxCUFOL_B6&xwY{;o*nP`>X}iv>Ws zuQZc!F(PV%it*W5WJ<&rrblMKd9XP@e!BkN{&s?ojs9S-we^^4hjUQT8~UxeFwQ`)vG8h*fIk+B5pTPl(jPZ$@kX#4Dr z#x(VUl+{Wf65 zOp9z&b3H}|wv1+7u$aYx42#RM=I9d@hV7M12Kh)(@nf^O^_1-*kmCwZj^n!a-$avx zH2kPlqic`6pw({-2uXK)y3fN)xE?tUtJ?bU6>y{>n}?XkvN3#RY_gV8`X>bIjcnZc z&9)W%BQZD=dtt{LgU@NufoT&?3;149PEaQ?|C_kgm)-)itXe|MV|t)0 z6s*_dc^&F*Uu^isiB&S|K?dpwD_6YE6WSAwGrC()Bo`E%C>*v-VIh?la+&1sqE|y_ zht?;{TcrmQ-@`&Vm9Pf*%);+ zRAY{@2hnw|gR5q{*8J?(yBSemIR{kdR=wxO*+$=JNN;dI$_I1hV>`P+w*X-!!GkOB zBukbJi+p;YB;8|l*cFv^)sgLI;ky?1`)D4Jb#l_fF#vff1ohGT2B5@IM**rUUfwOz z#;8kU`5BLn(Cls)eHlf9fWi(kfRLlB9~=s2{GV_k&=EP^?Z!!j%j2gTIi6AHp zG8B(6#o%%L6RJB5gC9$NdqhAtD*UxD! z&@AkrTk=W~Rej74h=dygA!oRb6IKnG-8k~w<4bWAqx8x0+t}eHeT8?gQK;Gq_KvuV z7R8LGavzh??6q~)6j<0p^C6#KA_&-MzI2I}t~_*dM8`KLS^0SbNI8^sHk7O_&jP~b zlPbyRwNO*=g8|lcuP18diz#zv4tmQN4H1o&C|ynie>6HVwQ1*5X$y&>iWG1LbrRy&@lC$s6de$69`l_dsP54afOTBq2^5hiJ2^RuqjP;*Yvp{A zuerxrFdkQ&R3HK1xP5VdyX6t5idZX(PuuaPz;o2uFLA{pTKX;;H3js?qu|=tXtxRCQ!=&Ss@euN?sYZ@X z-f^p};jaTh+pxUO*1nfb6FwHP)>xqf?3Q-TPN!_vRu0PwJdAB!L^#UXcWuJGR5Rj< zCAT|yCJ_6@x!lapS4$z4cG~Rn&1qgrZCI>l9xP9vu^8|^4o%KhxIEq;l_Lum;-o=3 zRml(#R*9lww0wH+&U4xB*-TY4qSqDOtB;+e59`On#3?C{2%-&Zer>NRm8<^9>+wD= zH3DFpMGeDNx_rhwo4R4vh<{DF>-P>%VI9f;-%`o{WEEv#X8w;p?iRUho?>0ZfvCw&&q(5`D6uP+~!iLIoCyk*B| zFTNy4+n2*PO$58lBD+?OX({`(o~-8O+sVUF8-RU$Pcog8w-;%=##CvoD!Kl&d3R)k z#U=Y}McY4BLirVQtYk3fD-ExSUt7MY#cdbgp85vQ`Oz}y7l#$1T3@+CDIdKzS#*Imfpx-?ltFe`wZY*osnJM3lW@7q=4p1fbw%|mm$xa;Q zxUk&zIY7O1$gf|_RY<-WR}XU z|E;;2Vml{#;9r4fS+M2~oay$gKXYW{_cf|x^B2b38vaB%hf->w z3-=mVTV2ato^?K4s&!)fYv7m=GTbZ2#T*{Tfya{79hNO|bA*L1SHUI-Ds9sJ$p5 zO_dvH2v@3(!=IYxum?5G7m$nS-vK>Mk`Hmy-7hE+h|-CELXkZU|pugo>u5AwXBm zA$uR1cQpvN3F}B_NDHi4!g7(&P(0m-h0_UdBcl^6_uI)X`|RlkCm^6aGmEs_vJZc( z&-XIBwSa7(1VY=dApafrCuUpQ@tce&=F#?HZWvO?>6NR@!!=mvzt#!?%?{IPu!E@> z$r5nb5^%Ix$D7pHGH!|oMSD3ijUuzIu^ZfXU;feHZs9r|S$y`wXkbaE)P7cqk|_AF z&H4M%>jxFG#r2mf%KfDdj8qe))I@M{?1g;X@ehA8!143a&9SN)Q2@i~Uz8rKH@%d1 zOp+$E$h;hoYau<;T6-&Hk&=uqK6cIcKE@2p`k`XCUm4qj@CotM{O862yV3& z85?rA_My_PJ*N<$*viP8v<^(NnMVpK@oexgX~!#t7W_SeyZdh2kn)2Zuhnb$ zuKWVAB=V^|Ruqcll?fgT&Ir3x{nQ(I5lfqSI+!-RzE`;y=4X%8Q^|plJgNq`Az3ie zCE~dQpxKU{TtAw#r(U}PTUSQDLWUVw(#l8LP#^cRmjt>#( zTA1m)I-0~F(>~qZdW_C zckoe#t=9VVp+GYJJ3v>}X9it2|F>|i$Ri$~U=r&VS44wkq{=9w=$(ky1LugapNrE4 z^*em`U^)@2 zYG8*rFl|u1x9!<^CIN146%=>-ZsSeZgp5e|Rk8VRfgHBC3sx_#<3>LBh&&tQLR6F+ zurp?jsQWLdYCN2y$+66P-RZK7jN0AnO3wRu^z}%jxi!jAsBRu z(RDNzI{SW-NZ@c!B^?aV#-;!R>p%zM7m46k>X0xkR06EniRrg<88Ks|Gc|jSzx>Nj zNm3CL^0j5#6aiy)0&kpB6P-QsEEYsMW5-5_!MZOrL8=JSFWJ- zcHG%Uu75eg!QO~PMAWt3=_q%=j3{k0Fx}_dJr{mba?t*iYz|`phn%j|lwMExQt8;1 zjqiaN20u%-3>c?Zkt`OQm%v50X8jB8?zPl)WFzDmk_w1a2j$lU5)=n*Q5zu$wBPJj zu(kj}j8j3Afc5Y;Gn!-VE?S4UkmRK+Y(`T0smR@XK7bChot@?Fu(ef>yii z*J%}1<({u5)>i0dvdVl2bHaEL@m)t__d5NO0&fqXWpOFVKl)Wef9>$!QXl2c(R+Hu z*r(7^cEv=zB0R~%oJz=r6Pxjc7C+tbpFmvMVlIC`RjvOS0*~eKDG-+^ zD?7dCl{G%(C}}m4;Tb|*!Vr`)vb{PB%lB1_kA@e#1PaNyI+j{p1|f?Jx%5mOXXE$6cwNipsEDtABvJLA_FyJ9 zsoA@b4ww4{TmO1GG`@ULs~^Elb%u%2qUP=4Y@D^Tn6cmek=vuO6o5tb5|D@4HTNs#4irwbMxqwI&5-5cJ1{NZ z_?)s9jk_Uo_np36cnha|`U5?cIwkAk#67z%0T6}c@yhy~;McLR<=PazKQ3?!`y*l& z!-JRKP&H9?5cNC=aMo4WEYoF~@y6)ie6vwAlc5i82uBk0=`<9`yv2aR5WDzQk)K6zQ5IFH#xV$_qc?lZ2oFP)M zL&oxD8DPQAQT+S2)XrP25#D1QKiJ|p-qjIycbaTAHB*(%g%Qkiz(NZZjOp&<2HL%Il+#kS_-UNmJ zb^-iP#ykc#dXE495rO4@kn{hI`~M*4D#@i=0BC$DW>8P)y4HfwY}~d|yoaCEhy-#4 ztmxI57LmxIJ9Q$3uTwG7$yN~>#vg^q&^I;OTfY&#-l19i=g-ZD#mk37^zJG{m%WtL z&4Z*ccy#aquFkHT-fr>p3Cup?DCjtv1n$Lqmb?%&yXCEwFR{ zSf=2=L`Q1bQGFt>4Q8%STb~??hd945-+H@_SZ3x>E0TixD~l_iMcQcDHh0|MEWrYn zN`#b6!CRi9!SX&Y8**mMNq#8QdYq~Ts#<6x1AfkYZjGxUSINlXo7{cg1a^AVQb9!M zPkjo^F++j&>}uvjpFb8{ZO@yq!j7?6mL zjlq-FfNa8$<5K~xTIgx6%|A}{A!=8-mf>aHJX!V=y@`vA&d7Q zmeLWo1^u2lm!aN8LRfY&&f6!E_MPQ_ahrcUVZoc`mE^h#(1k{Vmarf_-2<#Gq(zi z@ko9pGG5lc9CLS7Pkx?km;@mj8_}6`oKN19`XmzI!4l|e(QK;Z*N1oR6Kt>i#cltV zLO}(#v?ys-;yloWxJEb3L2laRn!BUUk}$eZ;eT6G<4b7Jv0fngUfp)kGB|;)XMi-N zh=wx9i0$|QcX&Mn z2#DdmnKurxUglFFi!aLVLbpZktyq%UMXClxJe-4F+lO5{^)$yd%yK-sIzrrTQqUz_X)1!E4{jsv%nKo(gOjvcKXP2$elz~}%kYqeXKdqZTFoYzH zp)YM-oiRt0>N!xXD$8%r0@E>sLs>-SL$`YDrx$yk`XVNxQ+bPOZ*Fyc^vbSxr-3>=okae-JMb zy;{nB@Bf2Is7dt!soAzSO1woNoRx`jBDb_?=6SKQ-@W&&(ziE5J!HgpH(GR*^4U=S%PN=r5SgeF%)sp;x~ z6WNP-60E>z++F9xahUnSfcU8E(vY6+0nn}sjXec9l`W_ehW-wgm{a$7?@1<7CvU-n z(4W-Xal}!DCQ&LFN+Qd&4-)#RqCQUlJx}Ll@)t30RTi^)hM60x zAL{S?g6?sSCj4+-Qn>AbIIt>fRwf!8E%T)AqHP}R;D$Vb6)&&XYt@kOgQ`!#fVZ1V{l6kl@{G~m)sD?;1q^%; zo+#Y!L;b7K)4Teh)_$`WrRiJP9<^$Y1Fueq$sOxbzMt)%kM}kG@;iEZTm&=`2u%f( z=k_~wXKD~sa(H>Y%#a%4sek-ux}$McJ*#$b(Vgl;CZ6*%1s zoo`RQt57Z?sW+;bK5F@V->q-`G4xJaQ|SElt-BKD$K}#_p~81erh1@vK@;mn+3UZ% zsL{fWzdP)-=N+#Wq_gb0_yD<+((9sOK*KaBQ~9>Tl?K~ePSY#%;UBNXi9PmzYMR&^ zVy!Rp`;I!tgxSLJt%Qo2yi`yzpmKY0AGZZ)YXjR!ev}t7q{ANeTZE!mfJACI>CvG? zY|Iwh`_b4OwbGwdKAk1SeJ#T=$EX^guAtj8)ViXK_y=+?-3?I})Jeg+t@4~^O$clH z^Sq(~Nm6wfkWP`qr*24SKG#8S#+3)^5zwizx-LbiakzuO!uiSLNy>*=-nL(E>~S{Tk%plhix?xssl{sdW3Y*cM)BG zsZDT(yDYtxKi4P!qnn27D>W2f zOD$PK6~OSFSFw~Xs)}?Oat=5JfuhdhhYH|%wMWs@N}BnWq_+!}B@^-U)Y%0PWuLdcvJm~eg;353e^w7AGgyvy(UoeYqF@W}A}<_hWY7I|%!p6pixRNy6>7>I4? z1JKj%>HXqA3B7^Xi-eM!G2L%NxQL;16F`e{-1&F+P^iUDYyObcF7+~71C4_s&d9FT6kNXQ9!l(=YXalTc&st z+O&S6tbsWO!t_^Q?z#r?L~}8c&8T1Vs4b~@Dat~wQfpHjhL&j*kqg0WL2`Y}=x)jW zjgSt0ULBohdGO6h6w^l{TW!Y?I+7t`$c9N`5Xqe}hPP=<)*tT(OH#e6fYrM%8m*RJ zh_s@D#$9e-1m98!H9ZC{Pxk93T5HSV<(jrB2oG{(rP}i+&n*0UEPcYX9Cy(S90-!9 z*x%Nj2FP`tFeGLupS#pEltok+I|R!|*0*Za$JyzACIwW_^2+>3KrIaoQ2!xTH)CJ(zFT^v0E%_HX zksa}-!b1~ncjMKy!J3+~OASEnYmrOSDnG3h4@8e5GZw5MC8t*{T5D#%%F=UUC6Fb| zZ|7q)utc{`eMh-U>QZe`Jiasug#$&lRdZx#3>r%{ECJAt{UlUg$v^nK9TyG!n}n+- zW@I6iPR#beO=aB9W-3%T23KLm!a;V>)SRNPd$xsQ*#Wp)E072cF)XAhmr9E+=a*>3 z5VM%`_c)a0opLOReiLuA+xE>p400bwkeoC@Z5Y%(+71t7LYw14sR>b`MBD~f29V|t znM5K}CfTY{#Y_XSkTg!z1l28G4L5Ak%2J-MHis>f`Lhw_@3I6PJ1=O@_8SRaaUt_bG{bK&ldD=^bGH>MLZu zkce$5T>}%;h8QZJ-dwMpslsINDgl@ZAa$0-MSr`e<=iyUJ&qj%Jy|bk5nni7A2Y8m zJ-g(581Bh!kck(whlk#Sys8TBb3nOR<>x}SM1=6p4Rqy6yfhLup{CRXxaeMDdGW;> zPD!cNjD;;{ws=hhpv2=j8PT_Oew$QrvOV!V#`&^cGEbsdx`$zF+EnWdOx_L6a`_ek z7B4J>C3yPjR#aR!eu30yKVM<*{&E|Gw{3Sw} zbY8{WRBPUu0^{ln8r(;Oi?3@mH}XX1J;jWZ79SnDXYq%>It3do15DP{Ew7FjRI33A zD3gKN8^_H}rVc;r9TPE|vxJffL{X|S((I{e&{zm(ZMEy~=qkXp23s$ZE@VF7%N%%S zTaL<>8VUNcp5GJ~s*~L)^uG@Dro3_;d!@$GbWfH7`wIwCvR2VE3{tH3oOd7iKQCk% zvdGzjhEwX?qI7I!H-mJ?O(WQMPenD`7vDy0#m7ol+TSpN_>>*LX z=DSB3z0gwa8)F0$*mkq zyQ}Y^!`E{Oe)jSR7lxJjv7|8$Th;3%<@8>ki~T8R0t41gwC1R-@^lT^n~@jpj&6^_ zVkdu}3K+OqhWB82r}U*I?8d__K=^tqd)KC2HcqJas;${B?%BqSOlv9l;@{P4o@&3|3w?gOz8)OjPwh?;gdaBacy-Zhh41bipE>{I5+;AVfN-wz5PI1pGWk5J zza7E?BNWff$%p~`I}9|uRVblKxxWy`S(Nc{uD&g!#tT1G;_o2g0U(CIvU+v4{urST zO?g4tVK7{`e&I5KnAjbwIkJfsm~G?c^)c~-mHo~1K?^&~Pei4-m{Q~p?bLIjcQ0rt ztR12~oqJk2Zv6=_Y#2CWf-;57Tlk95@*17-Ckiqe;SvW^U=5?~1vD7D%qpFS8z$_o zuIW7gx9=k;31Eho%+*#{U1-8H9u1j1EuI=bNiUEYVZw25ByubnObIBU1`|Qf+pe9| z-Z8@#3#2T&w}%0EgcVx=o9BC()bO0uW~BhD)ywi=HbO16y{wt1V*gqup#f!jSA?If z7Is-EA?FXvrCI?9*EExayo@QZNIq4(=rzr9DDHa^HPXl`h@{aRA<84+T}skzF$aF( zSwzba1E(Bj!MTo*UBMVr9`!7Ev8G%C;P$KWP-Hs-FLfoqt zz#utn#U3FlgCF->6JS|(&HDBwZy+BgMg@=h4;O{Bq78f!MnZ*J>V#?f9KTtVIH{>m zkVzlxw|cocQ@$Eavi;1=2C~{f>8w-E5|l{u6qZOW^x6xA3aat5xbXz#SF-|n2-SV} zYJ>o3EQVJvWe`lRA-_*172>OV*QCav#1oY>`pED)|4o`Q;jF~xxX+y*oAhe3PX9s_;3Tp@-@FeRQ;9X!a0$19dAW4_x~h$i z`Gx~g6D{Qu#}V+zXgGv3$Ayz_Xn>EDy0#4fQo^Dhy91b{a1#i|w6>E)7Zy&LCRc9O z>@aH{k6YWk8IKU}n+g_RYz^kX5u-!S25cqYjRAAyV8t6NG*j&^ICNRfl&p03N>>`G zqm<$HWD|~ScG2je^D9Lw|TpG~9c>f!hSEF(pXfa~x#7$O%g%?gvj#)#?IBKhT z5fUwl*SrSBGF!1LFe98OXJVLIABfK4 zo)x2n1LOB9iGu=4l&et+!6IOt@d+1Q;?vfS1Eo1y zflSxbbwm{5Z6tF}?F~8C zF?i!#(*?elS3`7{Xdix$WATYXHJ|Az#53)50z#c_2C8V2iOMmJoaiXVS8~365!WCa z5Y*q92h;0jG>;RTgjkiP1jms?*hPQU8dRP5ML7(z9%15*{G^mg3{N)p8dFn+5=|tP z6NHIBJii&j!9hLm+ZkHc0Ob_sA;xDa4&|ff97&pDdqh+0Oae`y%6JO*e3g_JVNq+y zgV`|_4FRVituG^-yMzt0Y%?^52 zJh!N|sv`K&bG{Rb=hm!R(JWIfY?9MY-g&k&O&!iHhmH!z#+Z^NC0hZT7rrH6WQ-g# zQrl$K-8nwP)V>{xQpcS=qv)J#b!9V79BXi*wOU~9IqgY>rR+R>YBi$IORRbicUP^p z66K)ct?IITSzwzEzG_b8SYA?h)smT%lOq~s)J-JpaUm1}@2HoYs}JkiYnu8|?Ie8o z*;W5i9^`_Vu2?`bNhirzr7aLKC3;@L>Z_~#;sXyObfUCkwe2viGqb7j44QwjGlwh( zp>rrxk>5*uFDos&%2R1pHp7NRJ}}@onwrYdR0L8{z0ZNC*M(mfw#L<5InKwsYLGuQ ze-x_BcZOqPmKGK{u;ogo-Ygv9d~i{bb0E+M77ZAGBzo|}(WGoVqr3H(;dEE5OcdU4 zd*!1kzBGRC4#ih%`uu~s24B<4k*Ho1X7+(i^u}ZFIDC?uKp97Ly9!nFaIvv?oc4B{g$I#5x45T2kG!x= zp`%&&(>}T1t=f707&0+Z7`46qZQ`ic(%*IBc36qCc~0u0@W4dVYqTVouj6`aVs4@R zJeM%wZ^O@3_S*Dvsj#`lAI)AMN4dIIf9Bvd8!CRI5=HWC&1Eb;XyKkbO1Eg8CY*zrUng5j1qX7Sm%Pv|_aOl@+SBXfqGqh|sUULk9i7 zr<0q$Kj*T)AFW-!x;~!TKHoyL)S9qq$IiO{5HW4X27SGk$ImaX(5EK7H5-vBf{(ls+e6q9{ZG%@H7@1CU9#<0HFq6f(vKQKMl z%BG-XcfaTZYKUq1!dsbAOOcBLb$;EyE#JSL-vb6FRoqBZB9Wyq{2Mx(nguZn&A<|t z@WVYBS*3t1DU}^wjR% z7ECPfyAsH#DMz!KjY+@R)~$_2Dw#+yX0zCI-bnum+s02qm>ZE8pSGu)Wgb}MUPBg6 z7_HtegHZ)N~4G*+XkPW@kVtbYOky<8qgYG%lYI;z?Fet^%?%<>$=iz_Y{8QqlG*%Ii zFUtAj>0koPTUF3=tIyT>S5RSL2jh=~QE^^~a%k*mk!?tf*Z%N>&u1AVOG)rTCZXbC zZ0gsxgtMtRYz? zT)<#ZYH(7F6b^1@uhLk8wl}3j+)cU!8wb(QwCroT@~sg z9UoI>iR@Q63{wMBD556M2+0LAnVy!u>%QeU!O+{#+Dz8*_gb15up+&L zx&f9XQvUA3VQ-2)dc|_^7Pv;>E64HO4?*IK>mgYH89nF&twG}( zO=f%>X%%N3(mWDRd{Af^h90ObCC_2jaX{Smx3C40Au_-y6`uTE0QKUc$!8D0xWK5g z+>(ri&4`pk9#|2fXCcgpMZv;kaDZUIr`9?N*L-q!Ez$9gYnDaFBS0Mls7^3Zph~vJ zgOoLDfho=8IDjCb_LerV@F_8!FDt=J!&V%{PsGrGq( z7>BIt%0+JKFU*@%_$3e^bN6qaO5cGlu%(=W)Re6oLQVijf%k4hAzI$pa&rs-Qcfn0 z)KoUYPl$cOKbGHiBws-dYqL72mKL!1tALpo&6o^Y;++8Hgx}>4S=o7nmLC+2BKSnk zx?2n(opVgpy)wM7{}jtPZONH0SO?Y_`03RxVkA!5im0Bw+Q`;gVh4$4i$3NJ z@aQ;RTr}X0@22Uk9=8N-FSgz|mtIdVLw#h&!}Lrd15w>_!Obofv*y-ah$fm?v@F?t zN7c}}k<=9?KVpZ?63IPAQxVS%=B{ayH6SV^^)tPO83yD_D$i?XXtgvfQ`o-G%@0~*yFdDFe!fAUotJp(%#Oz`=AU&bLARdSiZ2iZWodcn08{{5V6tAA@x&(XC$k5Z~2bJs9I= z91Liw=zhTR1yLgPkyTIAr9WShFDGz!af65J^lEM?YsB6&j-Z7-xHv07)Ieuk7)C(o z(!G52Prh|NkM$p%-PuAs7Z@>;eyec3owpj$zDAsSvMV4GM;TWqYPJq$gt;MRL~`rI zsgm^-(!J20Ketgz-paZ(-5+d{4U~S(>Lg5fDoVvN8+@szSc#5~+$dar>`><0WiXK{ zv_UJK`6TRs-H%SIiq>;tj5Oud=D%}Hh-`vimw7KU2^QGd);CK_Bvix=Stixw<=;1J zbPe>4RE}1|qgZb%YMCbY9x21NgTeC})3Tor){6zf(ypSq{7WxU`lXyO3r=F75k=*U zFIvX2s)E%(GVC)+5AWFw+tr^_t^KK$T!4Rm87IwM)njj~OlZlg(^Q^&pn6&uiz;|0 zYeUXT%#f|D0G;OLAqU1&jF18eD#9P3>LOH&;dC}PA%~gUP0~ejFka7Z$AJ=A=G`Ml zFb-GZs7!B1bI4t8Sclr;J^}_x-9@Apy6nNISn{}hk<~6kWGTEZ{AaeEI_x0CF}i#% z1_X#a%C#06(iO~Dxa6)OPIky#`+3^W_{!Kjb#ArOdUyT3{_I4*U;A?-18#6#zW6Ba zCw)$*+}Q5r9ASqK9>NAmbwTLjKcn+QhX_@t3&^@FSd4~Z{(y3{6jgrZUr)REc=ogU za&BS!g1xS5b`GWJXUZY=eIVBNycldhzHnQR2UAvlyBF<7N8wzXiwtF%MHd0LhbH;6pf2%%PoG`?sU=R*{Rz z@?L%FN_;CeWZCm9($2xTM28!Tqm{=ViB6Q-lG`7=$!5{)`TBT#L*M!gU(SBKZvF$p zEynhqC7SN|advOjlLOzCHUgSN^L20e^xD~Q=&;WuA8HLeR|yzW?_~p8-M?{b)jo$G zX?2Cz7yqT|vRQ51%Q&n~&ga(Q(28`TRK*`nAN;g2ueod6*}Z@5o{F`O^9l7a_cmA7 zC|xx}R&o74JZ?pnnN31`Q)Q@)wA1HLSED^Qz9*I5V|Y7FT}&-t_={o!LNyWG&dE&h zSd>vJet7hzS=nWeU zW{{oLXDKP zt#)=HpfkHiS8n(-ABVYu-S0yEO-sTHVy-X#A-T|3d`3{X>aNu`dBK+HFhO&5u~&o!d#kPo;h1>2Y-Z` zSDqOdcMFC-mRUP1)YD&Jr3jz0U|aomv;YxsfcL&mCpJklq17akbqki~eXY5#<_{!k zt_|oxJ7qYv-&d7UfR@gGzVBam- z>g#ocy)LQpS!5L;J0`Ai&8j}<9Y8z>V~5O1%2G2X2O+Z{9??5jRn1j!GSVcNyfGQF zIC@sj_@*RuhPh>ApXF}GXkfdyc^s-lzRu=r;bT4^s$hk>G?->_td4Bo%On418A7at z)QMz2e-m(+|3k>eG*uIDHtD*=_6sVE)kw>DIF_d48p*{zUA5ae)*m$aEbz^f( zZbt?HiP;lEBQ68e5H6o>G&j5+2w8>Kyvkg6BF$8Q5Epq14-^!)8}39f%7>%bi9bx* z7APOa%3l4>eTQ+e!XzPcd&v_1nt7orv7=2au@I@HXn4jTk3|adHEDFzc=d;~oZ5El zG$s*SL2NM#XKQW{Vj$OOIyB94Ix@0fQ2^yA3s3%lYw>oG#F;=^BfgxE`9Laetc!3% zGa1(ojZ$jZeb*hCAEkxzGNgf4-9CZ+LJYzhR#Ocb3EwF{xx76+mS7H68|G%SpSAq_ypvn)N75KeCrHrLpV5!_z`CKC%C zvp*5i-WcrHuSMlJ2Qp|2*RDmXjIp}s8QB+Le`xl-Q||aA-F_dDcCfMt!w^$8NAV9ZA1ACx;{>sWTH8csDNOH*;s#p=y`&b)YPzxZL8%D=hqN}sEI zhH&g(V)u*Y+pwOR)FF4R4U|D`S@>&${G zYREoZynKs%^O=4Mdnl8qqAL{bFr1eLDAyWCVtMX4QjX%2$sBKDF z3gx9+oBO=UDLEGl8cHF25~Hv0X9k_R=96_mC$=}1{90?;TEoaOCTBc0ngDG>a{K61 z%nDE*bw{ccJNOir1nLKL;0yV@Fh>aFVCcqrRs`8d9qy?lMhi(9IqIA{woCb3wACz% z+P`TLrl8jBSkRno`|>?O@QWCv$6o3y2!$aC7j-e)VyJhI-dkDgWnEg*vYp2%UJE$|w^2>>Ia9W;rd_f}NhWx=0!+14MVu z@g%%2a9pe*$o~*WIR7ha4kOEdf^w$S$N$BV|1B7N0zQcw#{J*V#~|Z20lc9d%+wFF z9MXP!i`wW5Xxg_&U^+lGHLL$EYtGL{hsYv)trq-#ojQI(O??mUZGXNPzkk@g->JwY ztAJR$x52h)@l~H1Y74#{N?Kl~!%)6#)+%RqXqZKIcaNM}h!PTSU z96~Ouk&m}NKq5X~UKh{`B9Yhtl4g@L4nraP6CekXW+&$q>Np+RSk7Bt^#JdTTI)!$ zz3w`SF1m}cdIx8B`9alglN{vQWr%qe%I}&G0I-Z}*jl9`T7kqh7EOQywe5vh1jcEC z64t;(4eb{$igE$+kyb@Oramo5^pMUxBf4hQSKmpMv7nnvdNB5+U|-gmtB3An@`edt zv(yqymb6~uMuK~9wdt~lhUt5r``1d`U57lcrFM^kt;D$lGowhjd>EDqs|j5|!cpMJ z_3FYyqh>yeefO}VM8S2r3Ky!@v-Ol4bqb2VNNo3YK*z>V9(y)^U>Q=mmCfJg=%LLiU&-8tKN)O+h428| z(XPrOOx>G(XO(|0ORaw%h8S_nJ?;9cw~>z_f`Zl)kQV`P1th6#I&rG=aBVF?#E(@i zun9p^)6$&a?%oe5*|Ulnk6I*4{-o+j$p-bOAzCo6DN>9zFyL=PEmoo1?sc|uFJ@R{ z(51u{>x|_DQa{&#gK~v37Egd4?G^x0)-nyhcmz*^)?okeN?Bv3l1h^RGe~h|Xe#x= zVA_O5?dwUywX^m>a+G1DpM$jV=07l33hcrvGoD5Gu859X1LLLX?N}#V;A?^W14X=D zIIZ|G>%bR7yc1AIQ7HpN_J+5xLX%oQn7>)D@vvm6R3*Q1MGMQ;0yWZmhv!unBjO}L z789cB$2A$5OjFJ1fk*dxRlo@i;OM_`lfQs1wP6`~F{j#E48dp9n#|PYabd-k!_^%| zI$A83H!zb>%<7x-pD63L$DRPI7t|_3iu+>{4ltue>jj}_%mwbS-$9mAyux-tNxRu= zD(7AdUdVokRCn>;9|m4$ppPdd$qRVJWKbY2m~sjHf{I*0MFqrsckoI?>1s+UgjIS$ zMMAua81R=EDl18edkUwR0k>Xjc8xYf&<}#;YX)3~tS(jVvRqlG&N&~yrzOLpS2yKu ziy6%b((9uX8n++GLD*w6p@u=%&)o77xah1H(e%X%xF4icjc8On{4LM6#-MGHLK_mu{ z0pNJbMj1V@ZW&L4u2qwKf7$#E<{lmTpN{_j%3s37#QYzR$^PvsV~E*d{vG{az$zpb zw0ZmgAJ1ek3HLN<@ava!NibZY{OZCufWX}CYC%xp=#W^s^p@N?;VqZTz3=z<`~%+S z6ZZF~CU;l1w=2izr$9DR4X17K^7|<1jxK8k?rt$h$JVz?%)CZHgS1$)XvvP#vie>X zT4CVXfo)`uJ=jnx%=d}s2k65g1OdDf+U@J9bjoc@3Fu-lY{KszxRUmPxS6#Z>F2PUzfcOBNQ^K zomAUfCv55;U0+e5++_5~5MDz;mR!y8G$xz->M*i#Hu2dasRdqP=|e4TpLth}>4a{h zX4&l2)&A#O7WA8QtC?fDf}B%VrFrz;}li?=Yr!|psRotRfGB(HGKAl6!&aEhb4i#qf9Wa-vgH!LWJJ$ zU|E!JB;{zs11SohG$p>POB$oJ#ofywaw1GwB4v0Q6SuP<_hwsjxW7+a+|~&MBB15V zMPuZnDp~JC!tl=7e^nz&4t~0e?$K>0%xh6bndRo@4%#K)uG{EP3B_c}M*oQrXE8Bi zYuyNk-Je*1q#bm%QHX4b4bzhgHSy$q)zkNk7mv6n&3+Ea3f)1}L7eJhL>rUIr`xA_ zKGb*+uLdNctrti+qv*%F=c73}*qMTvv#Cbm6eNvRWui&}u_!@dhz}y?rAD-GOs*0?|1NYGhqVhLJAL(BNng^4%4{Tcqlt&XVdU zku5dY8bS(@>wtU6?0vm?y}gI%yU-%%-6GI}{N0C?8zAm;BE=g-Xgjm8bw59yNomjEO!JzbbMwc3uBv&}UJ|NZ4Cl_ca# za0i?_ugFu?8_JZN``Rb^B#Fif7~;uxIKe-1C=u<<+;RqE1-HlcSs;LiAR z1c9}PR;0tO4omU~J$`wa?Ra#eLuRk2a142()D!NDWrZ4_C7R=-Lw>DlIVaSbmUH)G^&yo6cg zKS>?z3fSbe?2d|#J8w@qSX?bv8u^DXm-c5CmnjmlVh2GO;1CY2z@WxEoVVS;Hg4l^ z^u6LYSO2sbp{cf_gW-<6q1eUg<2p?%gJiWFr zmRQ!%0*~Kc5YVWr0!;oi3t=RqjIeU2_Hk014<9`5X>lv-)4!{r83qqRJu-jm>v0AG z(+PU+-YGrYccY;=8w&F!n*stxjlBkQCyj^`LF{7H<887S^3E&Q<;;hk(4IT-d+g&x z;plHvVB(Tj9=zR)tGQS!JQdr?TDA5+t?Vr(uE<${ zUK8m;cj12WK+`n4>8G*dN7GPX0FGfKEe)>Ux5&+Yk>h5~p}W9}J`Lswhvo&dDuSD3 zip42_2E2zT3=NbzU9pK83`Q#7xcLacTVMoh@w#KX^WJQD5}HzNEno$;`ivsOT9L9| zVnikeittrbeJCwWsGKISQg_pG7dO(Awzgj@rLXT2sJL0&v5zi#ow<7?nk!Bz^1RR{ z8{WV0%y-k{Z4=dXdCKzKyu4ewx^J_L<#;IUc3E_boMD?HdsHysRXrVwf7e|tSD-bv zV0F7Rr+};RIoJ(O$T-Yru(*xUD}Zd)b6r3lor3~mywl(HE(5Cn^{dmTE4Pq0v|-Vn zZFNZd49n3Lrz@A8YbNh>Z_H_2A41gTkdN2x9<=)8!TD8dHGFSF$0NGk3ydT5f_Z^K zYZAj7T`KK|I$oM9C{|hm*F?OVs}=`qSeS5(-FlhfmWm2skB_x%vQ7@7j^R zb{p$LIAPaCf%c5fg%4b)p$6$g(tEFG;TqC=-h2QSS5Vtp^R(kNs+;T;R@R7X`MNI= zBn7hb`^~ds`0S3OH8J3^&(9+M-Ex?^pqetHLA2aNILq5IE(!I zo94oQGQuL5lbQx?w^y4x&}rbJ9?}sdw=}4kXpZ*rdv15b+1B>1wRYv5SL`&QaWF9# zj@g#`2OmlR|9@Jve!nyd&UweJ}S}1p9uz4Xpd3zoMV` zwg!NMhn62HdK7JUoC?)!3wvJp@|xNZYTf zXW+t#!t<^KH0KF4D%o7DaXnv-i0F7f zVUfXisk%A8u(>|)wY`_0e^Pb%=yrV)(Pz5=9pBylPqRO{%c(%q4~r1V=>TqpA~8P0~7nE^o5sO)!TKCJ^08xaqRwa+8j39I`6EMB(z<- zXX7rWMFl4d&EZAklUcgAB@!QbWaZC7qLEH~^1^WsOJ;yw~9p)L4YJ?ptw!WjgRKaTh++~n4L?n*# z;Wzpoy%H{6j9uXKP7qh#sF8y%sy4cQRhjRgWDL0aZ)y4`-fB6(3Y4M*)uUuA;WW8X z3DZMAo8NyV5+a=lf6M?6=>E-SuqH|R!~+e;cdM8pLh_eC`gF7jE;nb|l&F_1P{C)~ zbC_^ptD9_}@Z5dLkFv{vvK9l`Yg*YrApg*$0LK}Dlo)daLVFZr^-C7gKS@Mbp2xH0 zsE>aVNHFlwlVK_dGK;d5kNl87EpS%~u;4EX?zCC#+av-hFd=`?D^D#^pD>>au$t)x zE^9mBW#x$!6r-CfvlMau$qcA0eNkk@w#bfg6{+}W$Z3jLnu$-c+4qjhE0MyHnIFzd zkO-9-OoSq^f&Q2U*8Ns3Vl?@9=oJ2{mImv5*%EQ|0!s;HmP9kH;pAb%vHY|;vOkZO zpmDvU`W6%Y@xXTmsi^YF8gIocKfEv(6rlMk4^r!xTs3d6F}qnLgPp`^nKbt)$E%8>V31 zN^3}_3N#LeBxC89EX#_6ZW6tI`z}o@@pn`c#{PEOk!86G{c?& zk07ze3DyLnt%kWcUsCx7+rjP%suJdyBIf9nPL%4Bsn}mtKYwL@G`O^{WimX&U;$Ss|!ge29pgyFGR6#yBorl}@&rRNx9)l`NNUg+LT8Bv+!VVz;9kOL$K zQHo8y3lIzDt2pNl=2O@Lm+0IOe`@D(;&H89?u^>N`WSOLPA5Q3L^cIz<=YJp#n7Bs zGE?oC8e=TG0mYFp-#He+^30pqK5=tYkkMj?azt}KyUNm;sKT-El$;&SBQb3NksP;T zh9fr5uZ9GNCsZ)po#rgI1_ePmfmo9|xoGXLu^}S*N}uCI+Md;yUF*lb_mg58|2E`e9-yHm;2ey(DUSaYGk6h4ucF0!u)(%V!9f zV{YDhqn|-XH1%a!&cw}_KtRoee;DX3vu*n6g~cpf5PIjS>*7a^l4$dd%pgq6f=$6%#Ngd4-jysO+t&YEwj zYHdc||VHp6m5N2!~TL^mp5bAiWh(0Z$u*ANILP>u9_GlJ=B7u)17 z0093wSHQ`@mxshk!5*zKnB;|TYDst2NR$^kZsbwX4-FJi$9v@kxI{V7Q5VpJ9^+BI z;8*VTihJZR3l%NT1}E_a;k#294OC$}UJOV3^B%9qHBhbMJKV08beH9as7eKDnFygM zd!j>xjNmsdDzGkZUQ!jM2S>K%mk!t2^EWK#aHob`Tf8%S?>0xj?G5Obe~BclasLQ1 zlOEeS*!tt#?Gd(MO>kbL)g1(SwyG%YhAiaSM!OgCzhk?dq*l#lnOy91GdTU+t&{Z( zId6rpROoJid=j~h?spS^V^&%0^MG%R zT1uO=v#SP@H!7QfKbtN=-7}fHH0NPUFiW)JNh{;yY)NOI`4o|Y$yyS~=kCv$X(Scb zGg-~z#%}f)ihw__pZ`V5sl;Zw6ozSkbZQAR3SP`m?cQK&5${;LM0wm9x=An=gnlY) zGj_bSDG@X9xlB3P)r1rTM7QYEC$zE&mm4qxjtnfyM`c4f4oCn?Qfpaq@+}qltozsKq_ajTD8ruK^4I-xBs5rqO3zTmi(cIABQE+?7{~c@E z_&8`fwo&)}3&q<;ozjshwU>6{-CU$o*c6@5-WgF3MF>mmp;P-F{%JcIB0M%zeLo3g zp)35%s~{qOD)UR8gm178^f9Gf>J{hl)1#Q3>C3vi9pqJW_ORno{hZ3p+;%5|ER|}T z(Hf8SyA)jg14YqIKCUWyL;E8SH*s*>*?jESjRR?Vqc9K-cdcHdP0l^nn*V-5Gz3Q( z&tuTD;^&gU;NqrX(cI%2QtJFva5s_-MLGic68p_ic8txpS$bZyg*OmDnkw_TSjt+~ zV(UKN`NHde`!x$d0gkUqEHqDVDHqu&Jn?3kb3E(&4S#xUjrji$bQ}!-Rh_}a%Jv_8 zjBd^G7?O6_?oa9maKV%^T#BRqz9_(5u(Hg3p})gLvV2p&x>eCg&B7)|uX=O1XE4EN z2?q~i<+i?CL(!rC=qrR@$E~-&!L7a_r@ha+e{6o=y1u_v-5;m08CqvYry)v)teN|& z=38eEck#2ZN87!Ez;7~>5HwJNPTK;bb-llkb~!^ue_-LS%=5gqInj5&%Q&E~>fv8j zh@M*hWwIaYxME0kK@PA1kP2q;3YxG;?3wms<8c0etm@rb2Jf>%!Av$|g^5a3DX8`7 zbun?~KMzqOqblhiTkQ7&ng_*Rhp<-S6k6i2-tr8~C>5p4S)z;s~17cCwb){$S0;|S%rONp!%Chnp&C>ckA zQ#0j6Cb1Q6o1_0!QafIgFyP6G%I=K|fS}#&t1rOi^wggXzdj0|6p)Edq}6Z_J;nIu zZfJD)MG;S;kYpZt%u7V26xmHD@}y23n@+hO-Tai}ROvEs(AFy%;)^`tI_Z_BBJ9zv zUp27ysb!i3;hEv`0bgI%kn6maK3`f1RA; zyby{KHDq5|rMGV{>s;`5SpH1*Dl}`+U6Z+cPIyHxluHUbO{g%r6{@yKucbBF$XV2@ z_VPqDbFEm^C3+H1BoC4(Z{iV4(Xf+pLwOPd{xQ;v_kGi8s~hkt4IUQ{VbprW51r{t z&&>)}x>x7&KxNgO>gSO78yImlF(&jD5pr~hzRfSE;Q%%Hu|C#Tv4;IKS*>@Mn*1h- zm;N=3qwCZ%HVCzQiWgp35ZcfZ;GK(iEPMX`G&+Ewp zMMBfjb$l1!P@^akz%-6xcHq-Q3|Qvu)l#E%2?6 zkyY)D)QQibRDm~EWqzN;seUocEu})nmcgJ4^`|hd5X)MgGRn7m(K0J>{lp2K=yL91 z8xv~B`N1+axI|(+D?z&^>f*@6*`gmnFhoDPH%qh{*Da|Nq~Ufn38y!Xp2{gZSap-o zkmMk0G%N}@FuZr`4|xeSDqeY ziv|$ZhUOE%JFH^QQpf2t)f1dYe$%g+Ox1LO-c2vk(8Mc+KGc(VW1Cfr`wpGlX$hwD zTYmhBU@$EZoda|M4+WnRU&@1s1~YwF_|usu(LF0I#!JUwk8mdgs5lIM(**xhlWUGr zx5w~OvDQ45boW*yrPFyQvnLRLL5<%FQNYVRTqY7(_neS$pbk9Wxr%9AcHl^QKHP3?s!QZHkZQw}9pd zxGeM}ODYZ-2JQKE=|jC~X0nt(GFq{leKw9Ph)G}iyWb`|&W@pg2ZsEl7H|-G;-+{p zKN1ZQsng-_3=?JQ>wrEoE|EC~rD#rHkkzu|9l>f(3x<;5sk_F1k(@G|>V%Mq@2Yb) z=r1~u!LFKOa+YvVQgk2xc86+G3^NaMfeNtPrSFdo9(QO(R-XjhCgyM|1mkIGimMjx z%5{;mzb7N#XlkflisvK&dDY9Bu~Ee?_s8xN{(amYpKUw4WdR*li-ZxAdv0?ol(g;Ez&C7Z1)Q-B_kTg$g)G44^X# zCjvbRH-UoW)5c<6^OBA79P9nwB$kA<7)3-n9FWF&YL0&#tae=q2=jt#SNV4oyX(Ye zBGv@;j{}y^SWO$S6jBG_4LU_g%Xoy9rSXv6eO5 z6{(q7sYCS)ACD9lmx@Gohn13|d+*)Uzu(XrZdCIEj&%*qRCzs+Jjw7UkZI-_-`0EU zvUaF$2B;!lJb?+O>|$KqTJAw!F?=}<+2uElT4%ESsnq;ZLcaqZZ?c!&T}7{v+zK2k zPsg`XJX#6^j~fQbPs!LMjo9f1mylahFmU0g$ZPE!k?@FpWvgpy0KgvMXGCA$<{t;m ztmhizo&gfiO-AnCVpJ!=w{z4$EY%b}I;c~D+mYuw^Jz?OvrUbWS^FPc`=wq$X{CzU z8aq8$qa&YAwCPsG<28HVAPm|(F&EwwP$rYqu3jc=58E{)4aPTEx8Bi?#VM`4k#@Iu zrNxNZ$S6OuMaLPb)OJ!GKRf486>2B{z^bINZ=9*P0JDF~fOKeRh+=Pnlx;eY%Ixl{ z;@>4@Nw(X!m<$RQZXwAgq<98}Cx@Cx%HCPjw86zdQ(j+VPmyaw-p**-ZhR2C6uAd^ z%CirmIX@wh}E3RNKMSG&-wY%dl8dW&WDJ0^Ox>H4@8Hbw$^>e!-EO zuXz@I=LxfedC&xOyNcHiBRHRz<+fE9)hujbYkDd5FH;&%k~wB*?OGH~o_SPdX6d%_ zv&X2iSWFuOIfi{6qcqFb&J<6=G$#4NeCe#dC1T48nwhY^*8=(&Q7Gd}9wUP$;$;tt zR4H5Jr2bie;nSI#Y{efQzX>I$T^5lQlk+S~hT6g-N<bp8xyRZu&(Fi_nJaad{(@-H_u_!?o1R|x zSGxBnp6}P(*SGiU`SD?L_n9=}tWTRSH+3)Q@x{TJpsO);cGQ-gvN~yjr)cTU9+ZAD zti2SzDE>+H&!4_hM)dRYkAe4hLuH=;!*}{Zz$TGm-SaT#BDt!xQv1x>+c?yB;Mmwo(8O4b zg+wp$;N9#QSt}19^KJ>4hFPXR_5-x{(1s^>qso?LIMY0# zrpJ@sN1ZDn_b9nX^4^2(>MHKtzIjH_vc{$H<_9<$$H$?~turk=#J;mgjQLj``<;=3 z?K7^loVM((V8r~RY`tSA>dKe?*!_uV0O7v~Hcp1#1ZrA&*sEvgi*3(G;$9jU=CZ@D zA3!HD3e=-h0|lB%fz5?+n9qej@q!I1V%Xq>&cQ#5(2zxFDxaxrEuF$BBi)n~*nBl3 zMv+Y6MK76y^J9U)P|+5;?ZnhEDo>7ml=;q=>~ha$u5KzOJNH*ZN65kHb#9YSmdDFu z$GjmA)LDV-tG)|QUS_vD3Ec`BL1p08&FA>v#PRR<8kV!MvR>ohO!@b&%f?9LT+{K} zWvhR^=ZHCIi)Or@h%B_>fk=S#yy9-<_!`N-_{4zs*R z?SJo$l&e+G{q4oEdNOmd+1ABmBOvBZ3NHwH;uNYan6(Pu1fq12q!KXXd$Z9eW}tRJ z98RN{`BQ5;_(P;cGNLL$#h2AXd!nMOS;e;ydM4t3UfkcGY1|$)gbN$V#PhQ&$bTMe zX-mdzwYo0!xqMk_pDL%+rbrXesX9Q$;-`M57;nvJ*ZJ}Vcgi6f<=D_x+1{$`uHq8D zA?C~w{z8R(z_v;3l^wqV`J@7>O!92BPE}I;ZJ=HW|2d{=%5|prltZJoGLZvWjXKo{ zS0x4sGYv_)qQGs~lrN(;R%Q=xQ65s}nHXu2LdkgdHF`#K2!3E#qd||1$5pu_t9?E2 zhu>k*r`age1O@qfR%+9)zCRU4UFr%>%m4C@dG+vR0k9m$jQ|YxZ(Lpv273%D*2G*V zi4|>fWhG|06xCz`<7Xc9Ib^kj*8$m-RwQQ`f(2n44u*-I4yauxj1|Je4>@K3qvAu% zs$qVk-Sgc;n;-H{0~28y^0MahnTFCqDv@-LsRO`h&Hfy{28ajTD^x1lxePQza*RfT z+5C9u24YW14#Xv7OFK}PXwe{A;vAQ?$$eCMR$f`N4oPli$ zPRW)!I6g1)v7?w(aOFhIsYsOkR|2oYOGCMCid<;GeZ{ z^hRVQIWn#lj_`w^6yFc=``M!)FsMdz^io4OFjfW8%ovuJ2dgThSS-=eDt`8`?Zz%n zGFRY8T?Lxast!UFexdDYsZjw%q8_XEFr5+#=%%US^Y@E-C+4I_$h2(zyA$1{d?~Oo zB#u2~9b*D>N3YBWF9|snyY| zYEEk%E5h)#`L88Awk3jm=dbJGe3XN*iuDmVR?U5F1^u=j%+xd8qO1exxp16GpitUF z8rIdL8OS2(AYj*5K_cK9x&X@z{$lN*7Jit4D-laB4%Yyig`~aIoaGAbAidMb#Y>uj z{NIYAgr3WM8*)AuWL81f(ft}}VVZRG5i%o$WwqR^0b?@I*1e<8ztho-B$$_d3r;F) z#Y?6X}q8SD}Z%+Hipc3A3!{PuM`RtAHLB8=^+H}{NkGYUg7BTu=ztNu+k zI`9nR2B8THdpT)4JBrDfTzGU@U3-v+u;m86jGhhEB=@mZ08YNJMBTUXEP;#YwH7U| z^@-~>sMg(Lz0-riGuAz(P(W=pFBQrdUX-z{J_()D^`@baw`!2u%+ZT@voKFQCTRVu zG0!9cSG=in9hczmWX8VoCNAiZrBbPU^v9q zH6u;U74DQwrxbUNv~J^@A5>YlJ?YodM!oc}dy~oI5+D3ep>sz06s7Pptmmd04+iC< za_oB*bdC^1!wL$fvY%mEJe$U7KS;qL3@`nTA&r5*hC5t%<1n!_J6*-n25 z(0$y-upj?tku~O|Gj_m4KVvvGPL=bB&h+W_;PRmqakmV1gdbq;8j!fl545K>ZVgPo zZ|#AIJZZSc(R;@G`1qLLm*k)w!rpB7J_b;WI8|Jj)FCjd4h)3CEDj1xi4(=JKt9qD zbTpkihI|EW^vJ6p6a((Qv_%QkDLfE>h?1>yWqf%#cs?cr6GGd(_mtFjsSPxRsnB)ue1-NrfyeiIMAY z%U4*l)a@qYBmf$MeaL9v);hHwhQ|SNFNa!%ftARbOjOHa=~Y@px}-~gK=Xfg{NU*s zUA{u!9cc`P)xOvl9 zJ)6bm@+a9{prYT4m-pSL%iQxv&+pIC>s$O* zT_4s~?@ivf&Cy4+?~}mJZCTh8BBWzy28C}l!k*6NA7 z?VcWcvEKZ><5BXKb54FU<8^A|g?qT2jlj?5J%AFq6|$k2cQM)gx<(qh5B&nQUR{5TGiQJ1KIK_ zUT@@6EyFn(Ik+zO_EqoaW4PS>oHBtNT#*vYI6<+?{I1;{TAD;qB zCR=|P8f9(k;jCTveE#l^nQV>qh(hXnAWPSpQ_(US8drDlOSZCC19%*=&ohgGp@T1B z?Vli0Z)+81Ug5a;F&(Rs?$`mgTyG^5-_2c; zSsU(!#`h>Js)*}-lI-bS1sw+(lmALJ+*ZXsh+iiXl0iFy16v?4W)?mMF?c~&vg%E7 zj2}hDB@66pJ~XRMPuuZK$x@7$hX}Fc5N1=@v+?O^jy}<1-=t|ltm+SC8MD^5jZM;= zGB@s%=>(6{!pcnu8ML!PW%eyEcpwj@+XfUVbIhBi_TmLA{vOrci zH2C{$`*j}x4cK(ET8g2wS8Ghq{Zle0L-IARUg(qLQ|Og1LzC4T%nL-EQp{$geSriD z`5LIrVV;tZI)Psq7jZq}Q3pN!^dkl`^?9B$n5b5rihQ;(o?NfNQzCHyCOcKbOIFWF zmat*8Wg>wHx90SAD5eAiBKJZ7yv93{3FpZNo`5nmKMOYCjNXj)Z`LZ@=d zL)&a@XI-Q)qsp;v;Xzc4obM@x3C6`m4ydLsuaNd0OWOu(iRzDTB0TkWT=XWXsq}Sh z;(a$n0BYw8M&F1kxuJY#%RZv)p?NYnQutT>rTSesF+$v^z{d$*E&BZ1wSyi~df#BpKCMA$zgz1YXYrDwlKZEQ3w8t8dG6(IHb( zG0s=?qS=LaCPmA@5hhu0L>p%#UCnKc5EA2)(^*1o*HkYNXPLrk;?<7Khy4QEp6GM3 zA>12Z`GpUoU|_+n;^3Pv)StiH#@4Z=Xs)=SITO%lQN|dzjszr@?mIX~6+Qhi|Csv* z&lOir}XIh@xn(kMoalj^mOsD_vj$_pt;D@FnlFw0mbN8XiU^C{VT zS4{TOXYqBi$Hd2~`iAB>uk=8-vm`NzD19Cr(UKEb_S1FUKRR-@q1wbW>wKeSCLr{- zC1`@nSu!($jNw(nNvsFTP84W7M3o#Na)OqqEpkSiEdfoCQBcA`WZ?c@C>p5yhH-M? z&J2lo!%>>19c?A$?^^cq-F{s!iC|kNZ2YSP^=aDl%bI~-=Sdx>3n$g#~CQQ4EI|4S)gU+K~0yrpT zbw?df0B}9vHVP{H&X1pXm{9xUu`!7bBdpJq-NH9H!;2md%>A65?hN-ifu&9GxX? z^&&VTI47>NhQre+8dM>uFD77AEC7i2NeTU=Tmg%HA+Non=Naq#Uq*~~z3CjyLTMl`n#Ak5=JDFu?)3>M4GSW!=O;80S)vC24+T1(ees9IM zAy;IJw+G!YgWp3}WFWUCWF)avZ`%CH7xQ0rNk?(_f6VzP4yu+%3cN+|^BT`st9Ay@ zfI%CSf++yQo)FOxmFsWjs1|EL#HXFwM9pNvZv{#|o2%oRt z`vtrMNv6Dlh5JW~Wk(#3&ud-aUN6%wqj_TONQX~2_cP6ny1Lbpfo5^6-kcWvB^bNo z+xe*B{T(@E>n-~Yk7<-Q0+X>pBo=nZv`nV~@3!_*#;1l%%}jHbUkP4(tUwdq%i{xY;s1|h?@LKxFi2h9~4z=%oY zU(1YHwnoiz_Z6NgG*5O2hQ)~tynyUx$i}N!L}=E)x9W=4%FtMfSqRH!!(_O%dd8;T zbM^;PaQL~4*a?CAKqKz7MK?Fm(~(J=b_x~Vh<(TkcTkb(*}Pn^21nZxSC=;uY~Af8 zBL|yvtNy)z^(a4-pZ|vpwX5wYSY|6jw)w*ZpCs}GwA+xAQ^TCMQ4crJG!?jQDd2B0 z92z4|Ec-NGw~pY^&YHtKBo+9jRsgSogB^D%O{$#v^OzQ0F<3*5_=Q{Ah1sOuuFw^v za)C9YqdBhHMNRFsCD(x%Qc2>cWt9c&g{xa?(@#|)!y0Fd8f(2XOZtKw%Px)~$8Nqd zM;>`fS?$46X{!o0c8L0NZ@DRXGfnK^BK*&o4dxqYdQ#aF%ZF|7OkjDFTS5H*&6@l5 zYkJW*mo%>V2%5rYWWQ0X)_*~dx@q|ij6V;gG{&X0^0OuF>GIte1L@bJ0YfyRZS#jxoPvn+-M=xAq z_YKerGP*hv`U*m^A+%SIr4#L>5X>bTttSXf<$h`~(CMSuipQP>Os|)PrhV*+atghh zM5a#ZYb>!2RET;6!MY+5Rn+dw5y5U;ODV7f0=xZaEdgMum%H3m@F(F%Uh4U3Io9EE zC@NUXa6+yoPpf#dvilYinq#i}u6Q>I5uCh;M7>-q7vn4@pp^$R9o)qiXV||*+|{Vo zF%P)qTX^&9@Zv(HEp+|dsu#(7?n^!6+b7J`_H=_;tBWx7;__h6T6H>gt#~!?7MI={ zJ*cW`I^j6?um^zLEt)d5HA9(Vn%P`58Ljh~4>xz^Af4Xtf2_vcrO`AIhpDGGKm1PG zy?_x@cp&tngJ{Lrmd1CP>U67rRY79c0DB~3##CMhNsV54P89tRoE`9EZ%|JVQb30#{nA`1kA4@C0&Mitl#!Vy!?Qii|%NOz!CcSxjpa|L4- z(`FJyxAu6cE+21+>V^D})5CrGJ9hqD*89EW`%muKr|a+1^Z%65O|@t=q`!=fOin}` z-s5#O55rm~^) z89FnNcODOs-AcSe4eiL3L2)e=G44rCi4Gm_?FTZi)1W|UK%@CdzN^Y)Tb2u92Ol#CJkEA~{MrP4TnG zx=PjL#c=B-rKPU7a~B0Ym@m*e{zvudy}cg=CA2UZ!CFa6uhNO}LrSrvPwF2jpKWa~ zkd-bh*o7R5UjY$YbGWSulrkm~Tma+0WW`dSPId`+OF**$BWrO{(e$Pz7fhUCI5=4CzS;yx$l z+hOPsnka_eTW08nBi{A=iXtZG5g?i#ZnJaL+zt`ExtlbM@%@h`WpVg{DUeDG*%MgQ za&8)fO$`C$d0PE&YQ4f+PF`%3fJW*HT?l%U7FHb;&6PdRN02$#;3%O(u!4o2=!KXz zz@d;4tF6c_1}qw|xg=IJa}})#SAmW&GBfL4<#zBYgIb<$t;cmXK@ zIy?YJ09p%jDbH(pe=w!HA!Gu_SB_ttj>s-#1Vz>}--K{ygPPOyga)&jCZYLt8wa`f zQ7hkk!vL{}wA00-Y(IZp972Rds?|44oa8SEN$2QW3XjB~01nMx#bT|Syke0+c$5r@ z$l`|yelwQh%% zS0#7RW+LO!jMF|b!&yMcVz|p1Zz>LLmL~X~CGmj0Lu#ESjT6D;1S%(zJt;AY}fMuBCI~pUxhrF7q zfWsP`W(Pcf{d86$xd#zQQp7%r0+sPX1V&55z8;*a;91kI!FxO7c3!5#{$|M*ll-9c zSs}34=%n;c6@&5hYA_WP2Sk|_9*{vb=0K_U5|%o3T9O}CM;0XNePuoHsal@kTU6Dm znE3N6JIy1Eiq&`y7P%D&?fA4FLAfY>id5qmt5lg*!C91= z9M-DqUc;wFzH&B?Ql}3}yJ3dMs?AG6A`xTsolv;Ps105~%_x0VLXFU%Y3QG3z*L%6 z#;G6r;Qws4O?+0APo{Ci0_mgCc9PsPdp$^{)VzqDN%9#xg+qPC@w{VhF&rzZRFDKt zi*xkuDtHX5N)YudCq-qy{}v_XW?3l6dW`m}M_gsT6XT?~WqW%Sd=1_xSMad~R6t0- zFjzFD=BrhMquQ+iVI|KAE;$r0mY2KnR~cZGZKKnKhidJpiQem-rc}AnbSx82HUk8U ztM1uvpr#!PD9$qm&^rDx9=cs~nZqHVGz^zjziuHs$Q9wnjRSRA$~{H(l>(yO{JbSS zySXV{Ol|-XE8Yp`VOSNI2JS_x$uI+ksnjs{*jtLjGRRWIn9dfVo2(QJqQ0K#tZ4Ju zD7-hmSr;BHnB=b5lF_Ytm>kaBs;P3u;+Xl8Z$pUBgyFd}Ra|dc`3+D( zYKq&xL%E}GLFy-N?|_)Rz~8`L0T)dUTF*K;8FAc=O`+OEL7U26Ib5>SAt}KLx#ibV zj0M#(SJk#^Do%YI5vtJ6jqKYRg{ffU2Bp=Uy87A5W2K&FR68Ab;pVC<{MC@AU~|5n zO9z90_==GcU-U;mo@k)B#8MGSJH5-wp!nF!mN1*%SNS3nFK?{Rhly!;YfWJmXqLIj z)71qRak9-piY~Q_{A6I<~3^2pPn-a%R*WT2$ zAVf5S6y}g|yLovo*i}g@R<7INVn!Q9|9k1O&RrebYprvhM|%q49Tn56joo&PD7jQ~ zi$u<#Y_nBmva1B3KtMdY7a@6%SP`hIkk;b_+qSpjUTn1ltEA;r(TzRN;}Mg$Z;4)X zOCyzKQ^O39p~gBhct`A1J1W_7{Z0zHR>qzp={)J5tJY0n7s3opx8DinYF0zdok zKpg664Ro><%0$d6dBd<{snvShtEbcV;yq*G_Ae)%3zKUYX*i6eh|tN$qU$o8!S4G} z=c}CnhZwaO9Y!3SjhB*_3Lf$_`K%1w)W7wqBXWNlg>n#WWtlKW^4`6v(Hd?~l{H=o5L z96^y5LNWAeFyAfpZAmWt*cwO9B>6)Q3vQ1ROkS?UA>z_I(8{8;rXZiLmiG#czTZ1M zv`h-ge^NmI-H4Z&{eRhDN3^Hvj@l4+PO0C)waB9BAu+Z^0k#C(z;5WqjaaT{si1#; z$b3+Ld8f-(r&xjIj@_hDG^-EGg+3pLW%g9x<@SIF{H`B&`LCC2uW#-j|I@_FZ_oE* zY`5LudEGjFIC(<)^y>DG@ZY(9xSO+=!u)CcrF-Gu6(5*KujSnVAGhzMI(7NTukGJC zvXk)|>b{#Dv{M8%oi~@k>pcm`zr)sVj)8}C>1B1-CZFtXZTH1Uxd+QTw{n-yQJ4A` z;G9pyv(}y$$*f|vZ4sf*W~w(nZM5iX=aqk%O&roAZ_>x^CAB@q6R9fTH=JNP-gun; zPKP7NI<0$c;8x&NYbmNK56GXksyIIOq2#7a8Uf4M%cG>SDaEFMJ|Clv>k3$DyrPv* zEp>J(fU{M)59!m*^xo=Om~1|ye)8&;Sv$HzT^k+yJHk{*IES}Afx3z@py%FM5)!j6 zcyG2Ln;pZ+Vpn;|DsR1%qucA6=RY}@M>n>0#LJm{ZpQ-OI@Es%?SJ#vV*LaIAI^{$ zd>0bG+asF!t8lcPMO_Qddo~1@jqDp;&%OwK$Q!HTqQ|lAg6aj)GCsAU&Hri`BErlj zm5b3jD;tfk-ifx$qmT=9CguC4m=^B%+H!Y07k<$Ud($e%;1A#NiM37xi!6$_Gqn}Fx zL7FV!A?|vmR?Tor5leJmF?l<}Q&US9Wu06w$Kpj<7`Qxk-}m zOi~lE$bf!8zSY@b^bnH$E8sQ6;r2`cfw15+>)Sx7plZVc_lO^h_Nx;S!@{~DfS)M=50m0z_y@K z?8LSZI1+|?->z|=LR<;N^Tr2iQ?E$sdZF|d^4-Lc`LU+FFI?_VFe2yB+8di!jAt)h zc-hA>)IlJsWn4$AyHuIR(XDSEXj(e=jcpUB7+OZPUujqyT-^bwk-@cy&!r~(>uFon z@?YDfn|$ddTaD_uCyNZ_17ob)=WGdK@VdH$V!cf8aMm;`Zo?c*QFjcCDN}w#=C!;7 z(1-Fr(Tr~;#rWJ1Xs8smbd~_ac>=E4s7Dk42*^GWm`R^WsVl=}m9PoGD>h{aE{ecu zki#xEruT1-Q-Zf(jSs1FGclzfePX5J+@4f=$1U8{}Co8&WAh@LSDJv6u%2DghC5^>0S=IRMUzl+cD?A$W)|xnEjYyy2~9``zGSqX^`|rS~i8l3QR~sxj92XSGLv|taW|%N*uekAyr{B7J{ZkJ}V!S zY9;mlOZ)Kc6qb97;YqDmQ&nDTN5a{#!|n&+E-@_C4r5JpZ$?QC^rDEcUAu`t-fkKU zfzUp`d1O4V5o8Rc)AEF53F950LHI$PI246xE-k*vq?uOaWf``cUUodB+N4Q9 z+(e>qHY4Vv?>%_Ar^lM0%sKTfDfXP!14X^DSg(gpr!)t*k=>46?n}(fn3@Db-GG@x z#QYSJ+6Wq;UtEzvwx~pE8ULnXoo;F1@S4N8=I+lZVc>Z&T`O+!%v{Qy-GD$M7wj)> zjbsz7lF0#17hgi*J%8GszegQMUcJEU=W&+sNXCp;9XBbz^iy^~^N)B)D7P=eh4o}w zC!W@=S(ruj2`4=8muD@+n9S2pJW4AZKX9fUP!u01k|`dRWI82rE4>yf6_c|w?c>D6 zCV0Hz+@4Q_jD?pt(Wi22bqm${5GRyNyN$nPaR%}4V=@$8w_=rK>!Sq(^S>?$4s<6i zq1n@;h=xQTiU~tiyiLGnvM_wij#R-dsxVUvNv8Yb|h1dMizs1Aod53N# z+RI)Kzvr`c&FVihN7)E{eBo$zr~jz}mS8y$gE~J)#N?Jt4@cQVWBdOC zsb&&JR0WLT0RIQIovED=?9G)d?emYaAOEJNNTQVm4_nfpy_?jrI`kJxb$t9lgm&{2 zF%tAMm7XsDePRCd*6io6m!W%o|6&BvJW7jBi|NqlqZM-?BhY)dc7J(4!2a{s^X;3w zv&M$iAnkN*bAiI_sf%aNzuSop^c0LE9Q*Vj)VVf~ZhsKiqf3JFi=KEe)&D3v!~4DV zrc&C1^t08zjIT`GFy)`dvDy9eNv-5MM@o4e}U%t@tn$&%3)_B3e z)AF*N#%g;ftrqgS$!S5W2Uk57^iS2*m6JhheWFShuW+^pn>VfL(zUemwZ`)3u8tFv z9S{R*woy_B@`{d?J(`S^b~ITrMV^QH{hc1l$JQ7Tb(u+D1?su7xrF9kKy9@isv6mn)4I{6kHIpDjdhkM zW|d_jk?qp?)Kf0^Vb%nx{MAk5x1vhD`Zjn}Cqs4Wh zpz7|JaaVUJcS8x;n(w(cAwXZD&Yb=%n2pIRiCnn}f(9B@mdq52Pw*(-oJ0JHNKa-f zwCYt)O+dYlM_ktBk={Acb27{S`p`Ma(DWuj(?Im##KS>O>pz+JL`INi8>aweTU= zlk7@3;*tNV_PLpW_ONyY=UM#*R~nf|C&)OfdwK!R5KSi&bZdL*GsMbShN|QQ zJ3n#^iLcH0lD0OuxT!i4-=K1}uiz~Pm}-!9S?EJMs>LdNiBkF(mNAj8J%04m0i!zV zzLtk!XGsWXL*kO%3sLL0GZWrJmYT*y68@z*bZADEL#D7`Q7`< zd(`%)ULKNqxS>YKkQ*q}k>+7QZ{#cHIIRlb>ch0?_vO_$kIXAR&=s~}kjwW8LttyJ zt8r$V&7BN}llfHRL*Bb@?0h3`G@7kLS21bZyX`77C9w;o_UN_L?(>S*klD7ok@{8%(UFatd(PZ!0R6kP|BDS+ZM)O0=W%dQC$)v0>z_*;ZN z4zRh)^GBlvjyoWS8N zEiH+)`!H`6c8RZ{Q7_5NE~p31U2M*c6QUGTIYIf3^3qTfU=b#gEA`ht4!XD?PE$iu zkM*NRloYXVWU;0=1g8Za;-KMN22L34g>tD-!edrmi%#o&TwKmf4-j+C5SyJihsN&j4ue!dq~xm%mvfw16}(}7DI90{jhCQJAr z;5=a}v(+aW4w&klat(Kp&)6BQSHjE(#+LhM#%ZmyA_Y}ZIGjRvSZY=#O$rjSnxh2C zTH{%kfGitaqgA-(L zhtf{ptCoY&9srqxZG{}8zknurcY&vXj_wGq$YA@nM8!%uXvFe-&`1H>ImYILdEAGT zFFlcd=(u(y5edU+ElA!!&EoftW9yBJ(cU$9okUKcy7dMk6pM!Qn zDM>xk8tw#HFDHF2OF?~J!nLE`ia`3gjLP3EBdNk9DnCy z5nb*??L#i4Cq362@eY3*=~1DG(pqR@+D0-k7>f|z@E%6(u|~te1-18CLvAM<pzaw`DxvHt`Q(a(J%W4`UhD-;*v5tYTW)Va zT81Z8uAHfS*?$Jh>iGD_)5W-B80wu-$z$ZyVAyi>kD~uMeovpN0Xg#MnI9Vl8s*V6 z9|?@KKsd?xG#5cZW5|gy=~rVB?T+;`MkiJ5U0`qCndxA-zgb3mjCZ^*v{{0 z4g3G(*1m&_IO_ulh66YTY{N{`juY|*IZY1y_(P^sHI19KFB^kPz-VJsX49Zqd)91hB#pd_3`S;WD_tWO{Rg*Rtl5e}AMt zxVwKGUjIgww;xX}=-6kvnq^q?o?amGGcCP7ZX{qTG0>WpsEk@UrY^LtL!`I=PdMj3C0oe+aS zgNg7l;IFv`1d zn}BbYb;61Im=DvBoN;QvUgwvZZzGM$Iq!)JHPIajJ8bg&68|e6M1dS=gW=BgJGTfA zb(83C>*m39V;2O!%{ZEwiIvWg-50PxOQ}C>;<_C{VWp2N>M#-NR-|rX-?b7;!ZO&N zLQb{wM2~|srj~}Joo}9>8(;-DS(*-G9#7+KDPk^Y(t#>xN^Bt-Y>c1Ao^=^^E9lup zsk({qLJO7tw#Pe`+=Sl5f7fHeNB}+-PR>NQ|@twzIg1K$@4XlBFl+!6KaS+I?5SALV4bq?!pv3fxVJIQ>;-k60dJf`h;O0f;G@Fg z0fRPh-HJ;RRXn&H%oJ&lRTsp5Tz(w`WIVfgMBr_@cn>s#OLHD5-H%dnWV%TRr8M&p z%_hLlP}dk82cP7iE`{&{$;ZPGMl?OBN9in5Vi1U47K5+CkZQ!+AtBR@eN}}wd zh#s%j8hacV)NR}%p}xgl8^;}_=t34-TlMCofN`suBTyVwIWpS8&&-<%%G~$cFaSMj zF4h=6T#Pz7d?vLB)}LVB0qdnuDq!$d?4jv8NY`Vy95O%wVb`*N703-OXK)b9qUEW4 zJ=Bs?SOf}c#$BIMj{FnX9su6cpJHwlM}=!nSQcN9Pl$pAks(>Mi9GKRXM_Mllr?H` zbA=c*c{qlbSy77I5xjf=p?eQuu0$rv=I^i?+pCu z?{%BLTEM|H*s#Fy9CZP)f^>vPfZQ!A=YjfD@p+MCfvBAb6zfr0bN)1CYBfy_pL*Gd zQqpB#jW@Eq>&=4uwC9dH2%L*QqtfjIw*z`GWA&V|vqQwpz+3}oNBO!ASsqNyWDOS}x8ggTy zCii+Fb9fgluTq@#Ie_PwD=zOaGZOnz*i+rFyZ{#A|C2SdTJ#OCic`xIy|FV^&A|(J z<(xwMqs|YY1XIu}Tr@!E zQt2Bg^V#R!Z>+rB{Ly>Pf`-HSa`?-WF_&xM+F!VPh@v_gxIruwubP{G_Gxbk4RvrX zzHeD-uH^GGYfl*EJgLp^(2|d1@iU`-ysmBBW4r~M2|RLbxXsenJy)nVehnhGaeuHZ zMi#|Nsc4;`4coW|B<6`u=5z5Dh(;qyd%WDx4R}2^N-?D}sJk4VkyeRkU2BBS&D-n) z06%>XcwSXfZi>r+3E}rp-kIrYZVYNQpI=zaOV!fW=oQqJR$gt+nW6_FxUeZ*${}Dv)z&r&be^Bs zcarz90$&Sugs`LbeUB1OOWcAQd$@3BIO5Zovm> zHu3i#D2N`41+)wL<4qJ@-C;+zS)!_c|InC33h7o7%~T*VNtml?CYQ4r2YqaIeXJG9 zmvSudJAJmi{#pIr`IG#|cPk=Y$4UPv)!!O>H!HeAg8S$>~^!Ag} zJr`t=27~N&Qokgn1!#CBtM#9+XYt|`BrWSM+rHsxvImcn2lB3zxbqawFXb~wqw9?)Z`d`Jjm9iL!*Xr~2m z4RQp`-}nFJb{;(u|M`-$-cN-t4k63qgb9@#9^BtG?g62#X-1FS$cVtpip^A5gs5KO zMCIEOOJSnLvRGIG(JCmAgcb$n9_BTW*+wg$yt(STDvOrMWGuT8i58>SGOF#EPG4nKiL7ARi-RQ~B#+tR#nFKld8@y(Abm&)E+-ib5}g^nTzTe81Md*0Hc1 zUR6KAS9U%vfB^=G8e%x z%%E!NQJ{U3V_7Q#lBp0|&0PFa5MAA$7P}~H@!OrSIZ38 zZ-&+;UQH9#C%6?EIT)A|yKRVfnEC`zIpZ<`Y7 zL9fb1tPylsxn3nK1wRKBg4)PX5R=`+zMNK@W*uP;*^75)fC{-V!=g5jTiq$+4oft< zG~z5_neS)|XE^dO;b!na7qxB^6F0z>X6a`OVq6r<%em*#N6nJLI6j&DP3p+!_^`P_ zbySrWCJ*|UrJ0%UbZe;dThveAZx%vz2k}4?_w1!mkrim$I3zwy`FDM`LB&#wxQK(TrLS^%S&y+LZ83@A6HRpB`z14LxzcRj4&xn?BR5j}Y;0j@{YwndD zXDKgxYLc^KKOL?Hk)~v8;ie{S=!$)Q0F`KtQ+Iz?{sU-J(){l~6zv=w|IN$C#KiQ! zwn46Sq~nQM5&9me-{E5#t3Ol3oCSbL>>@e|;gTo9puN|T{qyg)Za8vpdfYT)*C`^) zw{+v{^XeFUGlz%I`57?_{C&KBWcK_@*Y=LTriNpfm->^@rY*R6DNX*2JbEsQG5+bg zpL-m8A+eL4ttm3lgFI=Z5rC^1_36v1@zjJ&>++uB8Od5mVNu9QV>R zH7H*n7+i)68g?p-8D+jHM~y3OCBRhrHen<1Ri-sMzct!LB7(&N-QvuYJv}n%j*K*k z2Pj$UEnYBZwO`9D&H~spgXJQlLlvaZWV2I9-oq@#wWrND$pI#|_Ps|0Ad2K#?3GF0@t*$#)v)g*>pB#>y?W3qbyO>AqkV} z_*29ESYvmCvVZ!eLJcR~I(A9PJW-m>Ss1F>tL!Gc?UwQ3p4O6YBz>SAX(S{0G$jxw z^OVcYbLNjUEdz;EqfsFy5mia^kQidf- z+suGpWaQ~c&Oam-LeylOnkfRXv!2bqY6xyWR^u6AT(bo~q(-oVnzb(#D9{!5-~3PR?S- zhZuG@h>Cy^!fhE9)uwtXx5cfExj0m|C2s9;`T=2(EoQYUyIRqs-qmK=+ z3(64ovTzAlWWYA33}35B2&OQ%z#Q19_d9J6lbI?Tn$MM)AvE=YG%aS^gCk|jX9fmh zNr1a!F*PP~s19apiAD}@a%Kh1lqKLN+XU4luW#5#b=d=p&IZK`XpC-T6X$7R0o5J2 z4i>Tj*R|IxmST*~VlKZJ#NKV$;8{}=SS|+k1bC;Z8aLUCEZ*m;*}s)HV=`nROe{@C z;x6JtEBvnzGT(%$=z*~?r0n{sx|B)~jdPH}v5qC!g?YliK(Zud+T;u7el1A=8SPbD z6K4S2PhB8iB^`IwH?cBWx5T@3gwa${#UlizM$#eNJF6l66u6>YHIs!Yxan-32%|7; ze;gq?LDqo;n+X)qcc?MDM1;&8VJ_%xd`_lTf&pA zAH;TYV^|5W`zZ8sQ;pmzE9kc&DRo|8RHENyue4N%@=!U?loBEpsDya;9(xs63_*}9 z?!%w54ix)%DLz>@mB%Dk;MgBgOEB#-OxXA#NKiKIuErh0a3QAq2CpSN%NjS@9!VFI z(HkD*Rt9HXhGRX;vfPu3koy6a$<_jx*gzC{*-jbaThhPG2^eP>BlUVM94RPuX~pZc zTgxM((5%R06IT~oYrdkGe6(#_&K8Zf7zTARt?D6NS3XUQm2vIrr|Lch7_dBFwVGi0 zj>EE(>a{;SAt2CKG-KmdFNG|wQuXPeNt9|n~;$v6|>)Rh>dl&2Cg}QEp5`v>TBGb<##jYSu9i)W-Y_^y*{}R9n*IfJ6@oCCeOL$gb zd-Tn9xyEcJBxfhD<2ueD-u{fJkA@PR+BM?Xm0}T$-6Y#y;^8-A?XcfFI#k&Oa%y){ zkXy>KP=@Dyv?16n29|Y9t`F2Li#y}EcBiIDfNr>2YVLiX6X*QcIa|TmBDFvEgzk<^ zcxhu+weQfB^Fa4~Y*Yi8jCR3$e~De8qB1MhkskfuFRzV;vixOfMpC-mU-s3zonzlO zIa%^mE|O@!EByXzwztY`+z%(4dX)J`S39CjRhw4X=&~^y09aNs%DD%Q(P=|=+1Mw&5&}g_IYKC z>~)RpCiS@pM()gfY><5|kNUsNA=AvetI6#LL#Aky!XHFsy6zjOw`vj3sN+<~nT)?y zZY#_0Y-%gBHHM8^%LB4^Iw)%kV+L1deAV9a@x@A=un&A*r1i^J)(>s8T9r*#rcT=w z5p6)mZq7?~ERtc@^#<`+Y)zM}sbSlB(ZM(Gb>Viag`9N(cu4P1%FDXh5qkF?BD4Rv zz1yMw6#g=~Gh|cQ$*n)ATbA4R(n9|!Wyw5s)Xxy8WC7avh0|EsAw+Dszq3BHG0k?V zwW8)wR(C)0qgVWFMIS1*r;PGi9?2L(n&XA$$@A|HQ& zu>b$26`gh@>7AAF@NT80LylN+wFl8-^a3(gp1J~)MZO=ki7KSTj*~8f)XlFFO&TnYu9HsN1LhbPd?81zAD-8QZ)|QMM@wqYFR!)}+OAygi4P%aDPGG;O;bWLS^>rD99YhP|$I8W7 z{8$CD^qjNQ1}(-4$~2yOYKe2i^5OgfwR&J9bV9ApO%v&Gq6!%EmJ{&q)#mJyJKEdZ zT}q~NJV-ZUyn_%8WLX=@0G2Gw6O#9~4gH?Xm;=nBpxoN?;u%4m9&y4x7-s*aQ)1}7 zVGBLNB+N7EgBZt}f#tu+!Yx;AOr3SR6cq>>hJB?bfSHFR(GIMyp$3B)=GaLKC9%sFjn~?_eABN$7X)8r!iR$&bb){M~O1i2x%wkKN=Vjs= zdph=ly8yT1^{)U<3I4P=L~t_ z$M$QY^?(|qhhB=&E3cOqvT>TM5m#Gk) zKh<=z1iKC?GZLkH#!I8s(XdF2J z-n4v(hUUjpskwxN~m$xy(RF<%7nr8%E}@xG;nbiRw;lrcok0Ku#KciD2Ug> zC!&kPKO&t~N{)7>#yGsop_jVCI7~sJ1zjHkuFOv5VeniiYfiu46ajU-n=3`F81EvB zDh^Ll6eaROhXT=+ItyjrC@FSeTi;5eoKGK1zPmTyl8h7PJRe!eH{TKE? zz*;5DHebcBwTfa&qrQ&|$L%6Q5Igf&LMEwGi!&%x>7F{Myy#CdIb5tUY zuv@K#^5j~Xje5b+BTqg4TMDSUJ%GQ;ZscB1j*1svL-j9$;os?zc<2S-Rb*th)$1Jn zt;J`!WM6xN!~&;xOk!=`s9fqN*1?Y%1;@VcUyFRAev~2g3qFcU(h&h&1qN^@+rA6L zwTvu0#I-SxI74|T9)&U#MS2yxuzCws7Aui4ZFAAfilk;6@R=>0R=C494}o#roE9B< zUK|_$JA=B3(h`W9zvo^TY?Y>(jrp+63%WA4fbL-+RgG8(fLofH-WNG~qw%p^LhLz?^de+|7aT!0V4u;ZO#eb8tlK3^m!s!OO2 zyZ`x;ODYpQD3%7kdpzpvY*a|DzOLH;F|GMsl&&fx%Fu9K$I_kROVj%{fF zPr}UpUkNii=l_|-H*0qP&xP*IBZ?Q`I8l6OgR-JN5+pGNmA?Hzi z;y+({7`LHmgz(HQJATFaX)zh*Z^gLq7k%05??D~^;q&dq?diMQS^R$uMUg_#3 zi#K9Wt{mJScQ>!@uWzChFaF=hkJYEq%O~UHWf`?`f-4>fX>cVk@)FG%gaiAzQ{*=f zV^tpvhrXLD?MzSNLeo(c<3>q(WcoI#ihZ92EQQVz3b%24hd)`5`d&Zz1O1SvaUF@! z($706&UDmABo%hDc!3uOC5o<|633hnW$;#0CdwX3;7REIfrV0%hJ%WyZVQ&4P>htZ zujP75tzH|GP0jRAEOA5LbDB(;Px*uZ1DQo`4Eq}9nwU>aWRM?v{DZ&S3lmWu?n)aF z%$(e5h^9u3^4!~*!QwCT3VueKCo>gU41uxWAel+cT# zj*s9gHzjXZHi4<^hA~wT7vEWQ3QsUwMIi+ zk3UH|>8U7U70N6^JpTj9tw22CvLr!|5tFIC`Y1VXQM?xJX@B2N8l|v;twuU&jK)cR zkPJ?H@kg!js+%J2nU*Z6+EXjEDf=E&<_y*)`eGeF0IO zNzgSVzjR%0MBG9OR&^>9tkVIm#4>fMU&P9Vu?%WE##C?8@MO4=?EA8Cb#-AB*cJp? z8Mi2}lNdYIM_UQ6R+U~?%a1xhV^RTd)VaL-Z;c*ZVpo+`3YQoQ_`#<8u(4pO zdmDAv602^;^~Rz?(20sp8f?(1h8n$T+6?p7aeK49fQi(OheZO@65a%t<;>j5q;*1z zL1Jq^q$wb~dBY5qbIS3?a-=s}x1q3Jo~Lk27d7>U;k9xr2Y-M5AL=L{6mz>j5QB%2 z`!B}bOV{hwpE@0=10$c(#Ex#7y}Rm@g;GZ{<(u=Y zxcNMnnRn#rf;pYCa=vubGY2tZE|M<$BD~|^wa_KsLNirwalYt#;WJeLvnc zFG_W`({D7&f7>>Zox`IG=hEC`p)+wkp1&F|x|;ZOINXYp$_U3tBPWWeH{}3J%Q#ZW zS%fDN(LgWDV~&=_0dirl0C@mKuP^l-m9MpI789pZVpvhb+?e^RbtZyHZwXnMUR!05 z>eU0ZTOWMf0>FxU?n#JS)Zd3No_8)9F_RY5S$h)Dy6zM!2y}W0@izZOrjq?=$WcbR z(RWB5lsd0a>JdYEPA;`WZG?er96gYEQDEcs!MdIF!{@dN+=+B4%3J7}o<6AgHq2UaXPokJ;Q5pCfOBv0iSR-z zoE;_@n*7l~;kT3D45O1C<&n?xp^tek9W3oM-wZ|~t?|K1y+bFv4t{i6B8Vv5exyUi(gXkHwt z$ykZ(#>GJx%KjvJaOUo}6u& z#?K5GpY-mVEdWk==K%u152q0|uGt3k5Ef5Y4#)<(WdGzHGyq9%dT~5d^G!f-UfplQ z!5gdyR6t{TZs998*fU>Qq^!gtlWD6Ebe`BxZ}#D^^%sz-AEoU7ucVy+9UOv@llA|! zxWoU8b!|3wK-G6gD1b!J3iyF`gs}eqvabI~qiPmYG>7 zTiql49y|TA^L^v-|1RCyPtw~@&i0<0qE-R7cJZQ@{c$&J=Lp|*^Ys4mOj&q)2&}sY zZjD;uiVaF#kfdalsJL+y^Qk{^3q;V@LIpp7eryYjo3)djB>0Xj+PP;pZD)5>#R>bo zu50B#XrSRv)uEe+QU%Vn=zYC5>Mvz?)bQToNydzy@uR<8(BRbYOzYA8N~fKk)DBiR zf_0SNx|I97D0e55$ENg}BNYr?2vIO4C!_tmlX1ODLdSQRvv@dVr;?W8(&F}#t9J4g zRIRV_)fl^^ACd(@cCv6!__H#5~&H|7Plx-E^Hq zQKHahv$Sk#dPICN{Ka)ftGxBq1VfY-mA^$S$_#@A`}W10q9qE2cDJT+8zhIuu5{RB zwPm%iRk11X@0)v5@K<+=JwDf`fUI@|xK314+U_kS=TBR?DzyEWTNhD+sVZYbp)=B^ z0zg4)AdQwLK^eEPS_QaH+A>qW8fwCFjkRl4v`!^qXu`F-(E`-C{+ZJ)zm<6_lnxB_T3z8W0`gjCd;SJq{ry(!_Tq3zy zRUv@*TyhNYb?f!jhvJUKlPDK8Ao8>&6sh(uzMU8{o^zcI_mVls%k*p>8e5{7dEfYeh{i}DpyAms#X?k5+mQPrs}A6Gb$AyOJa$%oj%ayrxdEy!HrQnnzZT~0{t5vX`KiHEZ#T9Ez%=xzkFN@$`U?r3Vd z&fnqmDRqm)1H+hg8&{9G3_;053Mqy3p}xrnSP`R&rJ4 zJGp*pq3NN!zDw&m0x3AN2JEjfElvMigSnql4DrcAJdp%&_Pdi0I)}X;-ex115F_SA zI`tt}Mi({Z;dd~=k!YONv&Na?5Cl#Poc4E1oJcHX$I>r|i^VK~Jjg#@2x840w46{G z(-_%a?m59yuoz*YaP6cr+l}qWS@hb^1_M*?peGtRQP526SGs39N z2RPCcL@h^8$e9#R;as$TW-f;wD+d*4rP#hs`W4^D{AcPr@wC&#W(p;gx1b?`DJ358 zw36oapy(#8qEl!^>mo-6HU~L-nTP8LigQHLGERwf04_CMKH{D^n+k%JMnuM7xyNL+ zn$Es6uOntn7~AZtl?Z_nl%{knp#}|{EJ)Y{EmyP7enalKuEFwx`!Fvy7fj@KsJ1jZ(S;>Z^jjeb6*;@aZz&ms;+Wowc?3?NEcW zf>CFAn8+OE`DO|}4ujnV$zxG0INARig1AF`9m_d`4^<8xhPESATMytnXbWJTD)Iu` z?mBM@=R31tkw;?UhbR&;;c@DwfI17JVy$(dB?#~EC}r0s8iaNLTX(rNnGd}8j}r-- zojPz{*)!BN^ZpP!k(T!Z%ud`#{GWvWznx|OpCx|Hzn1wQ+5BJ2{0LNqt@sh^!|3G|veOlVe`@5(e@a4a|^E+`em_O9U;>_NZj_9vAe|7oquZ1VMz zzs}#*zsrt4y?i}U3eTs+^7#d+c|lJ-k?+LVoy6O>VdDrD`>x%p`|$E>qGz94;3p%_ zZ`MDK8f5FD4uPHo`5}z^RwS`)k-ZU5!p!`>y(c+X?sS-!AF@@G2g9RzTsa(BI4>NN zD&`a_O2qq4Wk($pLZIq+D918`or#F*fanqC1}m_{5@nCzL!_y^J_*X`ACb6VKgDs~ z^hnfg-S?VFXOion!k23x5+j)AiQ8Xj5;f$tmIX>vB=Sq{W+X>KHggiM3m68I)k6nx z9PkX$QFT@Z%K!65#OK^#8IF-!B+|s{*mD5PIG?MG=S+;;CtjlnL++9Nvc#S#&x|Lw zIB8()5tM+^e$m7a)84SRg+r9CNYH=y&ZWeUE94K`;5xU?yp_ZEZiUbWm_T}X4$%Y!n z1OPtqlAN{H>tts=0>s6Pa-k7x@x)oeu!A;ctEgI}9|p+{Bm#(M!yDChuNdM<;eHBf zh^Q9tnU!JXiM}uVO{A<33++kvVU88o=P+Cf1q@Ps#NfIjO!V|9>TV3Z<|XZpa(8Wb z_?nv%>iXI_r0sYobFe0~0ioB#SuxXt4b{E9ER0;yQ%> zN{fvu0_WUb-JBI}P(qvjBwy92btzC?931hRES2J}ns8s!i1yq1#L(SwO z3sd;f=l>+O=^<Y7f{eeCS%_T<$s#;-{ z(qHyn1#Dt?%^R|7@H&-?x&rpW+%;>7V>GV$m;MDo;> zg_HEq-@`_NrNZ39s8dQqdtSM|=yOy!+Za$(IoDl}jx%mZ((S5-=}~O7$aobajRF*F z)&MZ%&c3FVzik~w_9@AtIFZ%f?+ko6O0;wEx_A0l-cL1hT~R9&Tr>wpPO4FLsF{iL2AzJJoEU(o!6yG(bVvJ| zT=|J%;o63Ad$T*#_Q$6(bhwQ~+M2UxapKo;jLKCd3sj)X&CEX@_A5v?QZ0j>Kp{RwC?ngdNMV|XZ(rk$-6J>u(|??MBbT^ zpeJYLtmlc?oH>#Rp*W$hm9{nV_F3#Cu_%h{iwUqLbjMoWR4tod)_^q*ohPTXRqjn+ z?7k&`1DywQ5?fl<#@Fj4EHgBVo=@+@u=WoB81|#Y)c_TfVAlnFC9`9!&1vT@@{#H_ z&;c=hsRd<;f|2FZ9Bi$}&a%dW6vpF8%9uE7Zw{o_GM_i1<7H)2RvA8_9ykYj$+t%s zmL*Yp@LJ?b!8=vCLCX|<$_dyMZ6ramz*VSnimQz<#2Cr~2Mf&?@DO-7OnhRI@2xuH znzaLO6s${rd&bm z%tc$BK3fdpp^OZays8>bR^ywE^m>*_sK{{F5+QI5_KqPxpcNzLVx77xv4t{{<1%BU z4(G#~GmW|C$E|i2{-IbJO*?6zAA#;z#Cyp$7`JSvDu75i;!bw6rUP51qvfzVB+a`a(0B7eR_5-mT zm%x4=o-hIg5UcO&PPTH)Qa@j5GM-x+WD=ZCu&a&5#+qj^}oMLibSH4siz6BW`SUjc-$L4pq8`8e{M}?aTBH$B{Lr+5Q0tyK z;4+^<6MFG}!?hikytHrzx1mqdUZX&uc+e$R^nw#(=6!M zE~{cr+Ckw^sVsC=0IlOQ`5tAQX9D_sDt{!jrIVS>KOW+}L^^;>vB1@TpvqF?KrDo* zZD%u4DeL|`_01iW%EXfnNIt>OWXLSd&i9DO#gP>Qn)h>cTN-J7P8B^6iReXmfv1RL z6C6Ss7W*029!>LZL1AuoHC+V$neI!4WMq(sB6`4dEX5-oZ4ke>X$@H;Z^N|u;$Am2Sqa=+ z^Tk^q%oV?YXn%ze!D~i!CN@GVeJSDUJ4&Hk;E+!>qBX*KSmau1T#adx>V#M?B}xjq zlW|Mh!i(4aLp~3-=mCK@en7IK-taxKNYbSlw8M{Dg|@Osquu%JBI>Jb&3KN)nh2HZ zXSRjt-2$O(0A+NB`KL?X68CAg^x;$08*DNhvO(P{oH(>aIGm09bEdF+bi57IF%!*L z!}4@S)Rxdb9JOLqYCj}H_G*|>a%W;mp~qlSOP1z9BLya7?Uk1e8rUEVG0T#m){j(_ z#~rZjDjKk0;$m1)0j3YrkwWuWT7*Q!y2Kbu#-IMdt>L+Kbg)%1x2QRXC7-&%sRJg9NpLdEh zM>Fad0e>b46OivY{9Qt3+It{F(OgWm9Qo7Odv9ubovT+0u#$NwtcdR#(>Upr^;3*S zx*kl6r?bx`&yC#!qFv}qUM21*UvIQYk=eJ%o z26EUwh8lO)XHBX~>?m~Y$}!?pMNRoi@^!NmU$;b*uibR|p*F>#dN-S2*%d-XT{c02 zrH3Y~Vs=DRA6=ZqTk44SU0B)0)!!EJYs8(`6b}B|zvSgj858-n7;)#;A$D8^~vDr*VUY7sKX9iXtE|N z>`ywRxhe)ElX;dm7d$Irl$A2QN+1y1S)@&v@Xk}<+_|%ir+0KNiS508t~qe<@|+uj zsCt`{Uy6$Z#VvMm3fc)!md@U~XsKe}JyK>fq;Oq9iI%-f{%)usb_Bb+BD|_T7gvD7 zsp&!Xg!3rD{TyH zbS2@Ut5mG_n;f#G592;B_1a#DH^S9xczDuzPPh< z+w>5+9zP|)e;9}zx)*(ql<0{Twe%)o8t%O;%ziv*Ex#Y>(p|ot;=z2w<0E7AzL2$5 zUfjXMwJ@w6ejm&mX1xdmK%N|bzia&T&#pwrA~ZFKUhW`oCni{qNG88JU>>50B*f zpSo^x!1UbK-Qm|$EB{khCyjjC`c|NJ+82fhcHZZ?Uw_R6lxK${L9!gWQrseBja1Tv zuQ#L!x82SL<^A0?PYD0YP9JFdyun**FTdL#9#?$6bvryW@LFzNZg#jGS>0O#9$R;< zA3h4u{A6XR^E(`Rsf;@#*|!)&oRcY}p4rizAlNF~^gz*_EtHoKSG%Kz90%IG$O?TIjFk|OKL*hGOnq1jP?Ie*aQr$de@wY|7SG_V?( zw}~bQXe2fW28hqO0Q5We1XKtxq{;j-bPx@CPu(B~yPB4W()7?6h4cX(oUL4Qwi)5) zgkoQm=1@S_Xp15;fg~`;`!M;Adi|jp_@))dr1p9$%zs@>GoOiR#Dyo?`|||^U#ue7 z?Hx7FS(NNap@tL=F?AuZp5zID517uei(4`)IH>%5TYhGUGs|#DZ+f}1&x22UVm9-1 z{T~|m307Pwx?_?wixi|n5ejjQU8eD)=dn=EmwTHNp)2~y*x11ZH4FhaGbr+9K}+Wv z62KXOaW1NTHlg7|r*tElF>9- z?J}YvYxTH5BsZ)gk@M$20hf4F?$iY02`!z6R2H|C`{N%$Vxt+uc(RUbpsUoYf3!~~SPe9V`TOFjcx_{H%4_(9DCC==*+_eqshT@;z8vm*lJ>MgDz{1%(h}~#wk45e*|ug9PGP%l z(%z!`+~F>hQ5?*6#;6T(mD=jVD$%`0udBHiX7ps`v`Dkm5g@iD&-wBY>amL{08cqf z$$Ds`{Z#;E><)jvO!gEFx6WXYV0Ni?3~n&yT8UF#B3lJG1+!nx2zt$OOpl(?+5Q(h zM!5>D3mG_FI{%S8GB7-$`(_u{XHeXbxvQwxJwGx>->yKaPVF}5N^;I?TH_PrNwvxC za>8k9B1BiH{F;0A!$JyT&$5Tav!GviiredkU&*$G-^tw5?yW-4jZarhR- z*i-TCkD1*{U2b0J*%OWCm;VAbw*%l644dD*wT&&n&pdKPc(NUa(Ix)HMmW;Fitu>9 zw4>*HI( z?}k|_-0!l0;Qm(aAK!YsdUy34_wI)2=Z59^I}b9^>3#0Mv%Oiu_~FUvjrQ7k=>7UA zO>mY>iBkGTrA55{e62p>-%Aqbstj5}9U8Iln&=-4oL38f;Xb{aM1v_QXKNm^jw-?z zk;Q(H+95<>PZQV2s52BUp-`@S9A3Q_o0Am=A|$>-C&dLJ6|i(l<4JfM6-5t-%^ZL- z*MloOc!t#6IH3E$VTf6kle3fKet+=z81in$=8_+a*O@J3tY}xz+8WV0Zmyf)K5Rb? z^vVzv9F)*gu<^)VYP-oy$7&L>Z^Ss#IwEgz-kz$fF)GM))hO8#bjW*OYsZ^^h)FpW z>*xD<5Mf4`NIb;%JJ4YlP(Q!3NXnWXrgWb9j(aL_l|mqSF?G@=CT2nEHHvS>1mAt+ z&kXDG{+Ru#zG=HK{3Q`j;@jA$D9To+uqI(eu%IaGHL=K*O38ILZ#wq_7aKC z0CfS$9JB39B}auV(wKPBagfbS^r1Jl#U6RH8SJ?Sa3&-p`^Fu^dg(Q*=~e{V{j;06 z8%Qame*D?LB5ihbiLaNVtLRNG%k@!;R4Hmt2M!s^x*Gxtyd36zWQ; zsBYOc0ZKh$qv&!S{HwbG#(!RBhvVkOf+$0oFc(Z86o}DphHS3_iQQ*<^)e;~s%Ayi zZsq5rW<3Q(Zgg*mwH5Xmy3Z$EGY&PB)31nSdNu|iUH0r8HAfz{H*RW7UA%N)Q=BcZ zM+-Ox<(9#d1&CvD6x6gaWJH88CgGUSIx}A$^}M*kjs~)10krD~8Q)E>ER|)lHo8z( z9jK;lYLZ7{yY0-arV6H#7Tv(?SL0|cI4Ity3oojjcK;(fVj!x1FVp)aH(Z1FkgHstF$2MpW!NZmThSImzlcWbUJ$pEG;DD zN;c@{Watug>zeQ-6=)CkZ4cR}7s;oyHOT%KvWLI_6&!T;*%De|%X|CpZ=(HHBpeh# zWVMrZ4jfv>sp1mQr-IJ<^i42Dy1S3cB~}P?IY3ABdiQvzl!|t$WQ&uM>HX)h8OklJ(iip#C|&*9*An8>Bk`;-?K2u7uy^aa6pD5Kh1@lCg}ucKMn( z5J(k1OC~&??>8M1NjieDnUb8Z*~G7QDM$gJPW&^5{Ga1BQpYgDC~W24-1v@oJ?MAJ zX6sF%c$*+~(;Dr2Sl^O0-3!M(sA|hTaEUOoLuegk;TaEKTFhYEacfu&92bmuGpSE_ z9#Wc7UeQ`EB7E6Ve8MFfa=JPn)E&Il!tkGs7&-Z*>2$? z_4W>fAns@70oEwo({Z{uXT27U?(*vEnNZ$DZop-_;U!YY|}DvjSmAi z;2bA#fqWLE&KIP`{=a_LtVC{I#pv2`;Zm>j(gbgOgtw|iCSYd*lVGsDw@cAxt-|WT~gAJ*J;E*FY3JBBrgwQ0JyC_In^KEvw152 zz8oGIb)Uyzb&r?TiBTAFsq}n3!PBhzu>U7H{qHh5nOXjiC3X2i~D)h`S|q13D`ArB@=r&L)_C3W=nDgJmmE|#bISu6v% z@8#0{ja26!oy~jxoIDSEU3}$VU;LjL-ubuN!~e|ia(IXA-Mx1Gyp^E@DC?4$?zQz( z8t(^2cHN?0S0>k|$YPziwhO3zOZ4$3viuT=Wy@y|r}$<}%yGb-vejKofnuZZH5PqL z(M`9%c5ZKbv;BPdzoim00!^B7|E^MG^rn78S}x%1{vHiwF~~cnlr#E}-=NFXB}}dd zM#*0f$WLkY1jp=R&(OT0d>vI+FoXLC3OJF=VtG(Ep0GaT{)pDyOv_`naq52KCX{yCK#@OZX7bRH zpsnfezX^l>ifbVJPrWrv&$-u7e; z%=CQdF3fX7FfJRW&2x!AIsSxG5(+E)SEmsBmF=z)pN2~kr~krX!5Hb+?q;Phe4{p9 zgco}uGPQmroV$wP{8eAP8pn}CMJ@3)cU`uD^B||T8q{fjDWXA9J)Kp1@0XrIO@*XN z@my}tOjEX-y)ou|NpxCtPp1YbYD%GreXx(qnIv`&rwM=|e-mIU9A-U@^*7yx95a^K z?fU7Pm>)CC2r)+2=ES&C9=#$&Kx#q6kgY5-aFM~KBvC?1@*K}k)GS#_y%%|uap;zoQgsvT=s@G4 zP{;dIRi3DUG)XOgsb}WNeoa(Y&sHs5;)2_s-uS!;cO@nFjY z5rx6RM>z%&s1?KZ&v7`3ff8Gypvg8^+Y$MCycC^gl=&c}lHNL;yf!$N?V!QXB|9a^ zu$y8&iWtJYl*|Iwkqc+FRATs&*LjzP&Qao{5)^I~wEA$L<-erCsWnimYib<;b#hG4 z5#DF4v+jMr;^T=2jPxOU6X;S#?X32wgTCj;&QTtTXI=h3Fg^k9G;|d$PN4J&vY(c2 z*~+*7{*|M%eVk7j!(x=OJ(F{B**dz7=fF_<9(4DLqOZ1~;c|n8s8b$L50hBTNVtr^1L3HY2V%qSFg1S#jv+cf zaX1scDX)1XOCRHhqQFM6ifNeWRvxT8Ls9NUr-pOA+x z8Q4~|yiwWKp%Rz`Op79Q2W2&QgBt{a2||M-$cgy25PE4o4f?gkF9{kU6Vd2StISd2 z#?w`^?jB53&Own%j!YDz`)bA3L(v*-v&55Db+&4Tn7xGa55*RPuQ{r)Wqc<5IB~+N zv>B#ImK5W7g^IkRDV3%%o^@Oy-*uH?%8jL9FlF9vMPH3{HZkI*E$&tb_7ObR@KUwB z=Q*CA$KG_YY~&sb(605%p^nE~%g7XfEjRF^1Emw->b5bl(XL?RRfgQ6QNYHUz%*;y zpZ8!Z(gXETNzbiVQ{D6|1KSItH=OliF3SD8jd)RnYRHUc(`%Y8`N}Dh)ufEzbvb#^ zH84r41^gN{1B4My65_9bnCKY4d={yVLd6_w8v1knvXy53!@ZLY>m?U|tp%m_)Q%TA z)!Z$2D5$I#yRw2piIYLSdP=)E$=!AG5+nVoe6>A&$QZuATAZZ&mfIHcs3sF9e#zzP zp~KU;-%RIbnaOi#xXQaeRol`vKR^)M7Xxb<>K(UYD+ROHFWH8UALNA<)9; zZ(^7uKcPh3&G?TJblCU#A!~%B>Nejqj14CelnrYYj?|OQ6WRFQ*s&|Ku5;UH4QbLv zQ67jX4oXt~B7%(#Hn5p-YiY|Jwg-Lw$pvA(n2(FuHg%MyCMk`(og;NAz1`5M}G;f*CGIt>qMH)+M-_j6emCY zF_SePZxgho9TIR5Yh2+k?V=eGuLtf5A#dS(pq@0;ErLNmv4PvVK6G^Ux~JQ^fje;S z_Qmn^qs{U3b2@6D(C%K7W-AI7OTvm)DT3A#LZC$Q z`26h952N}~{qmhlKI@~Z3b+4lS2N8--$<+9UhPm9Q6>6tqVfKPhN+&#b>rh70dP3`n&&ZOo-$J4pcA>Yr(>`}a9>MH;9_>0IV#qC8+kP0=TRla8_O@8($P&{C-nw9|^M(>%iC+x59EwtWSC{!WBZA><7*m?a#c7EvryM?`24rle-7gt-Kq5^NAnuquU zd`y`4z85sNofY`lfq4RddnHM+qW*kA%9#KNq;-wYq)7)A7~N7!tjhk|jV9FX(l{)2rBrX48Gvu&U%N@ z0Ga+z^A&SOcJ?k0SWSnR(6D-{dBeH&bI(w~Z2lz3RAChg%Vv&YAh zqMhJK5bOG^+K(E2K%fJ#s?5j!8!(1@=QzB*zzdNPlwEE&ghk|j)(RB=EBe>n1~8e zB8RQtCXl!=7AO>g<|7ckNX?rM+Y>Y-BEifKnh^UPC`Ck0)(;sDYYaSrZp!Mz%y6`D zh7+DXi57^~aD|fvL40PXlTcy>{WDSyvYVoz`Ge`+XdBa_<(vxl*yK~VW^hq+Nv=`B z)4;Rl{8&9ef9*ZV5(<2P0+OK+l)5&&=wYBjK@5y2WsBtMK8Dh2^XeqGv2g|>6&4lT z?l5><71=`8MU?dhEX0n21o6@vAuti{Hc+()fLMSrJn0@!Twv^pZLTh%m{qY=BX?== zS=3Tb2Mfn)raK%XU1|~NeIwU1RnyamcbLHmn`)1US{VUSGTL<-)Hct9%8TemMtITjJ!s940$!Jf+HPES*59ZM5q}~2XQCnX3VI)#q>HI!YyCIfAnMbqc^q8^is~A+c zxhk|ZiiU3NdL1l6=u%xUUpPh42*DA5JFT<3=)R>b?8}_aq@8H16535~(?3Ic^buNN zpg0hc&YiMG7M5RvkbQl9>O&={GtknX^i()#dR2vSN*f6s{mO0K4Q&3R0}ZGCv*Um(k5E zpeFfNG4vK#WBgFqK8cgsRToOFhbv1Z7L$8q9pfi*oO}x<%yelm&V7Tb0nA)V))gV+ zG3tfJdb!m=W)7_{Kt89k326Gc3_CT0D-UOp?Qq{_Z-8{3R_(mKs)d>xH5KdMA)YS` z`~7)KGfuc>;WQaqW@4-NJPM%R`JvIQlPp~Z@~pjDR%(m4kR;UPL~CXmbGp+r+QJI*w2^KbyYUTfJ2|T?K$ibFtycdOO*s8P%7AylC9%Tm>q;*;F@{ z$tOsL14$}K8c^V`RxQto8xRa_sCQIah;rViE)^+{+Ug=Ndc%Kz)q+`y?GJT!pI_Jc})6LM3^%ss7J@dyMW3*QG&Xc3<@hI}}qk4)jn~NFksLqDH z2T+WKfXX~8TWz|1rwlZY0g{v~DUqI+kVbVoAw;tICVH!(dN9s};%BG%cz^NCudRz(s>S)qV^-%B%2MmHEwNi#ey>Icx`^h2 z)$~dW2lsMW2qUf<<>BqM?%v-IU$}QLg0u~h@2G{{7NgwC4KEM3Db%oVF5-3`tjOUj zd$NOD^kWAkDVAg3tS(j5aR9sN8X2uWlIapy9=8j$e44NwF`t<(_i)-<&K7Jq z!!+B=_zJ6fNa(X{I{7NAtdB%5hWA+bHHV}`-zyNtNGC*$I4ILR<@@tzt&%Aux;>V> z?Ji`_B)yYn-DC=uY4_9c+3c3-sL>0a-vGfO;Wtx@D*|5vA(qN4kPw`14-Y&pVqZj( z-xlDx_o0!Qy4je5{#<}eqPt<2w%kEOlngggJ;GF(&z*YIbSa7c1N0!fpy%U+t5#(^ zCntpVx5(<)p6^aIb~Q{=nxaI8c@?oOr(&IVc48w_*83vKSkgJ;wY>dQt6t%O^`ffw zGHg^YZ`+PH;P)ma*ft&@-hP2#rZrH6Y^k@pmZnaR%35S81%7{4%1`QV9uq}qgtNnv ztx%-c7gR0+9{^@APu8DYlc+Nz2nVC5@~huzf+>N!i}^B~COl8TyqJJ*H>D*G;a$bs zxY{!jJ&F66>NbLZ{)5%lt`Z(DbZF%g$UseqwFWWa7GkLNS6FA{{kT6^@03{LXMg7zq#dR zVqxU?-+QQGtw5)ALjN50tdCWNzObc{#eB zkj3?ir`24(Rerud3hIPMus?dq^1IKxzR3u5zDr*3kB_e;H#Emcw6cNwX0rUd^yWp^ z;Bsdnee`7Clfx`*-&VB@kt5z=ht)E~YFN^h=>Yg17YoXV3mi!!kQi}~U2WwGE3R;( zeKHDIYAOVaBj-}7bt-xJFK-3cot5-se}c#V#q~#Y9R3J!r-MH}<_ha&y=Xtle5C32 zYuG!`Or^A*E2`f+{E^IF!CKP1hoq>98eo$FUE{vNFU9zv_^PT)YjRDzroV>%^Yu0T zQXj!cGER};1_iy?i(65C7ybV*_72gNhFjNm#WpLpZQIU{ZQH6;Sg~!}wr$(C?fg08 z?|knVr*S&F{j~O4>z;F7^NuR70+^e$6(@?1Mlh8MqmgQD=x?O;`pBVMTDhr5O{&XT zK(x|o*JEpI2D3X=3MvSS^+@tQbVEq$iv+KTXnuw4eb?M^8oO7LSOHvFFM;!dv$Mt( zF1vpEKO-P>ziK-B1+1nV)-&ag`wnyLAd^3};B?|BshQ(KJDefr%1}JzbQI=z9uTWJ zk$FfhOHOC))Ma+P!*K3h&B-|_$$K1Eg`!oKb%N`E2OZ3k>p$F0-M~Cl00=NQ8aNR0 zJcg9td*iEU%kPi(58ly#J9YDBLtyq@7#Ak_Svgw>84HZ>lgo$0x|;^y*ALqV@7l6` z%80UeFgWmF;vNZ}#J6^D2RlYbQg+f{WGXA&sN^5AO9(lbIR3)yTPaX{b}A2210U!QDb#jjo=*#rbLa{@B^Spqo}d`;ZE98 z{xGLH-sPC}dSLFo;uxXSnZv7WVw6ihH9dq7;Uo@s;90Z>?d@rZ?a4h-eJZ?xWno;= z6i($b_V=)qTc6$W}PnQEH1cADL{pqz0X#m74WBm6N8CXR4z#z zO>Cf|2hI3VC&y^)YU~DJl~B_h#aoi3?67@TDWYoz_I&;%SzxlC?w$VEal87bhLK^E z>~Dgv*yxp#dtClZDY=qGC7VGDDP(zPYrjV>LDO2{T}bX9vTZtm)wz^;^^N!t9Al{(_+P7hux_(}blP z(&|g_UB%C>X3LiAPUFb1h9##=(mL(>4^e?M(3q>u0Rl*xgmqPTix$1{?&Gh6rbq7K*!sni3Go0gb=O?Nw-oK#vawb+v z2KTnU1EMjST-n$R^e-mn#&HveZl54POtW8cI{BI4I=`XFykynWq1`P=+tpVSydY#X zuy*@IVbCY>ll&QQoajrb6mU>Pf&*+I<{xx9trB~N##p+!x+v|OrXqN;v2ucp$~tkRgqc0s?J-l{FR`^JH(O2#v&r2}y)$Fx{DY`v-ljY5suv}*V|3^2$G zL$?N@mLJ@N3qBb=qTSx)0i>^|GbmxWQ?SPmuZ8Qe8EfAyby~j|y8;!)8zxOuDpQx2 zv|bTLa{+W<-Y#6+?)?Qt2JVaL)n4p?uI~qWg?~}^|7~$&`Ck?{Mi$2ZW2|h{_yOW` zz-~^fy+G_qEsTTHUF8XI_gp|5v!{su*>q+N|N1r+QC#RxS|rKJgNs|Klfc8n1GM%} z3&Qt(#|MCX>%roGzuEb`Ek{3mIlcVB!tbB?XCH>|7E<}4_{~TEF|&8t08Kj-*wJdx*T)g<%c?FL*s5Z`oEsi-FdZW zl8oN?ho$z|gz)3|xXy$j=T5A3NoRmXPA?jq$uNNv`PKo*UUgkJ1QQ4GlC3aWNoI@< zGl8qR=fqOI0a$l=758^-vepXHTk+QbT-*8mT{34ILx8wJL;rGn0x*W5HTz#!7%*7| zAZAfcQc4r)*ac&@o=ICVd+#>H6?r{b!V$=NY_melqmaPeKZ58mAnMWJ)oUFtGnJt@ zP!%~J-mUQ4Eg(GtrGa%|5|!dMHVrV_#Ns*|oQ|X?e!}fwLnU0R ztc@35(pB7mikHg*!^Xo9Z&SQg^|Ct~X}=__(l|ZI_MC)Ukt%@%2^z7y6i}=Zr%Fvl z!*zhYvg|)a0%+7ED{1MZt2g-Jco$X)^;+pG9#<*l?Qm>g95naH zajXEmytolk$6w6h*Zy0Xq03~N`^p>52`Fab`6_G8N{`AQ4BYhGmhmxZT(DfxQYmTP z-^GNrvzyeqwChMR9cvZVDLBt*2hNq^mpk~V#lvMD(_vluMMX84B>M9E`vblQ;KwUb23^)b*>`v%ulYjGbn~htI20W~ow9yza9Y5$iSoJ|&52k!T>} z*W;ZhK~ML5K2c65yG5uNt9BecH-1vc<+SF$#j^$KjVBW7qG0g02YoKU{1HT}46=5G zp;6}-Dj7yy;|;ltIbx2r3)Kn~iBjmLG#+04q>is(x!BXL?E&&;1 zA5Srrxcfw=Zmw*45Q8snA?4cl+RAd2p`*trt!dA!v}9Y*+P_uE=P2iqmRXAX2u_nx zSle*Ll~bQk;8%Yx;@7EOdaHjM^G157W89LVFlq^=K7 zW@ilHmw)Bcb`fat_93ZIDk_*0Jg;!@`Zi!G>KS;<`q^Xsv8K+jI%yWu-2hx&C_K!iTU2G37_k9DPZ{P>-?(t^+FAxhJ zT$ca#U;aNv(Ab&&-y?kUM@{)@nEg>x9w0>G`-^@1(SY`Tox*Bk6pUnDC{uoXr`t=w zb0$z!qCe^E_2^zyCZ#?9xu22KBWE3bk(b5W^Wp6L!sY+O((_q-uAZN!pAU{^pd>}N zGVpw5;w0^WnZF?DT0b@U{FIb(iJu$&08~$F4q5U2wZHio9=DsPr=KS$Dk>JGfyXIE zOHhzQ(^NI%QsoU0=eo560rX)|x_J6zH3q#z(y84vfOnK--)X4vmoB@T9B!vll(XLQ z9<<*&dFnCqHy^a$;7)6aq9V&@S93_R{CrW6ak$wme9ZM@u1+u&*ap?&7?QkI!=C0z zbpe>8=x;@`g!a>*I%DbGP~%eseA@bIaN>%k+2qv*GDgv$Lk71Ynd0M%OGgA~44qo? zDgg>RY@77c{a5QHAOw4%L54gpYxk_kSrsP0MC_{FMy;erYN?XKLy^=~%xVcL<^i;H zn_B)J+NG7b`c+o8XjE=WQhw$dUosXkA^q5x4w$RZRH|Aj z-yCRa{gl2a1^WW|;$EO$XvnYKof#PIkSMCZf=e3I#2I>QT^(UgyjiYYl`R2gOksB{ z=kdopIxKx1Rua3C|3FB>I6ys5D;OaUU;b5nEX!1p@&+R(MEC+%#}c={QD zi#jc(_6VLGA%Hs0F-}gwDSLu+obC*!U zl@(4?Ia@L@9R6MM(<%R5AVcP$k*+zup?kPRiTx<{NHW-$o!;hMW|01^`AI#i;}t^4 zpw@Fx^C!wUpf)1rg0=erY@yytjIUj_%_iZ%4E-;e!C_|9ud`Eeg~Yu&@z&rN6=~`@ zseRx&Rf+(Bkj7}MZv_^0G!%jm^@irt4RZ4&LxW*hui|$N2hzrVe~3fn=TncZ z-soNrxLjjwHJ9}AYoPhPe_)RwAoK2E8^!`^%Zo}-1TBrPq&{x=e^;RO?JU6AOTTS# zg_i{Y`w~__ak(#4z_BPfAK)QVy$_Q)v8-p;5CM2!*c9$a*Eg1;6h|9h1MP(A)<4z0 z&vAt7tOJbbfm$Vsj6Qdmv_x1tUl6huD3B_+G-CmE z??Cc!ef2I*=_flD?>LqNYS1y(tnXYqh=Gxl=iUpvI>xCR#+giE{TXPQ0O})kYS*R# z(|MeJ?5LN~S$01BrB0_~M@kZ}3TDig>$VJzbDhqd2@4nlzTBwvi(X8AcV~$wNN%qh z+7ocANR;uq8h7jxQ!o~zp0-uj0|-gHSflp7auZ0E!~jR*>2XC`(I=XX2;6HtaANOl zFbp?*arugpVJot)Bu7av`#z#Q%YOIOn^Y*`_7gmkW~8}{AtxH<(^)NA=c1KN3q2;c1%Kju?O7kgTMjL}EK z8Fb9q1KzTnU0Es$9#uiJkR_MD?Y^&aiO%%-2z{wf?TMdrdtcY8u7marK9`-&3b5M_ zZ0$ZuK2oY-&XJev!<~HR8-0W= zYiDmjsIvdQLGW{x{FmZ)PL}`4aRyN z&u_ku53WD2Wx*a9v@5%hjOv_nOK=!4Uz@Pi7i3NSeRR+?;ojrpv zkl4MEqWh41%}%H$x2*Ri&HR)|rZ;B2%x5|*fp!dN++y?Ya5FS88bgmn9tp-Xe1*0M zKP8kvE}g#8rlRQf2sG77vLNu&kkFMrWwER_r)V=RiN)jIQE5%yZ*3> z@)Tg=f{V!QSNH<^!)IA9V7dwFka>4vGMHnEOx_miV08{BOWijd;JOdcRJ7uI_iKly z<P0{7FsLR0q z9m!?Op0efVhtDR2YEP;NosnN2a$x^>Q1W))c4Uy2R|}+9eqSmnO5+OdhZd>MnJx6s zG7n}!Ql&Uiu|!I9a*H14sGsx6!)g>W)P6n4U(Yh}dS^+D%6+gP0bz>#i6u3`Hg6>Q z#jU9j?1?m^BqNHRMg1nR3}holcpPt2Ov>K>@q1xNHBn0fCNdF|93ML@bi5?Tw%nx9 zLkgq34_en_AGazO%|WD|t5qvWthTg^F91rHs`B&_ul=;lORT1T>-1OUAFVoW7ULVZ z-(pNVicQSK*mBIa34eW>vYk-eggOW}DtN)~OJKx{ZK2KDPDQOE%dcZ`>=8z7jRA=D zMe=A_&u9Yufx9uHx0#}0PEkkYAY<-zMk@N|<>1^$KT$ThSG#0oVu2ey z8$#A=l`Y?Eo}daXLxd!53nhxArdQ}fQ-Df2XldDxE@uNnJeA>8+KkEHkB2%~>g|+= zSgCX3IFbQcJghr*OmwXwbG}GvI+d#2)`HB)nOJZo^wnosAOn)d*`%BYw$p7X*zW~s zC!a)+s4_}BD`>O$$u?cVQJoWquicmi!f30xgwut zLtzyoi3#i-t~a9gn9dJwHXWzkWz^VkFJcLII8M2nUA#|G7t4`Qm-kZ|uNEJKp70af zNwv>X4Wp4U2Uz#C#p$3L`X@*A`z1Aw>Qmj|mKA%WQ*uZ0y=911S<91}l0l#qSHC^w z@D(H%f45Omn}gZv>}vyKId(qNgPttqcD0|pyF;9=V?ek+t=HFWcTVjv!Z2ywhU9SWEVNLFf}A*_Y(L5e!kaJ5R6D#>7aYxo z{J0xga6p-BAmgHG=5E6tCP!_)aS2M9&YjsGDPwxMp4OwqXw)o78O?5a>OsJgrbEBL zG_AgV=Q`I)jY7XOW_P=R0+@FNdX+{0+6niZc?=)IKD{oa=SM)hMGF2w$Bh@>}(;-A{eNq_*6G+=+19t26anT2J|@Yd#d@NpIi+ zvS$0+A)DP%sb&-!;r+EeNFBt!;-4_K*A+MWhR=K)Vwo3})%&yY($n&lV;>V|TgM>0 z2TdwZ&8@&+A&pag$B^-E{DBC&bheN9(PdsJHTf(I+7-z8DyMD0m!2?x%<9LRv%i2u zI=46e%jL=Pzr7-IF#ewy;^a?m0*C!SxrsN3wmfejEbsrsCMJ6}{Bca%Huw&AzPm+G zMME_`Q)?qJv-*@vNy5g7UzPX!mjif09^~;lr1*A7pO^dX=!5mXYl2%u zi#K);(@brp2K#4AC%L`cSHJn7c17A;31tw4%I{~X(#0C(iJ`@J<0o$Ab%bxeo0rs&EL#*goG1yfzBvA~PI<-y zZQo1RdPyP9cgtWtKO+`L>rfhXgJwx|Pqo*o(h%1+jm9fniHJXK-pDJ=6A%crVHzRb zVm71ib1)(+g}1AA@9k`cWFjB`v|^M*)ek6GhW7W(^+W9ClZxNPlmativ|7|SkYJZm z3pjT)Cm#7zkWJY$`TRugfTc`ij~Zb$nhB~-1|pcBsB|HJo)GPMD8BOYD@FA3`f!FX zXZvDiTMs@v1f&E+N(IxKppT!FS6RJ?D35&LibFn+-*01zjQ_D=|2X zR7z792Di{D@pSn-b*y@Ihu7jP<-Vs{}B z2AbS~s7hVfzgG2ljei8G9^+Z;Qb_ESzK-Y(GAt!DdmM@m%w2S&7a~>0<+7glaq(1&_8cv)dN@+hBg< z5=X_wbqW@DP|YRNoC1zw&b^rKM6hU(-r2avQ+^N5{=`)-`E)+6B6yvo;il)0rF^tj zbXpQ+$dGqrb{qdHC}?z6AXV7`5?(G9LTV3Cde4lq#K4Yh4*2s`oYdSOn$8z2#dl_; zXsF(nm%R8esL6A}%%lk&ZO7$pQ0dNDb*^T|k%F?S{f_4z@DtC@F++BAE(wC6ptY^m zI02jf2r;%=3vZN5G3huHGuwUW6vH)rY{ct)187uwJKB5xDpbvXKLz1$)xq-2Y8Jn1 zy$vL5Dq;Aou@S4=X}RE6IfSP%FtO-Xkg&X#)Le_GwmGnDe?{nUy0*|^hUuqvvca4loAoumo_Z`vAvRN@VPla0WT%1&y$ z!8O3i{XdImWjXgu`?A>rP2BCYLuGy|(x4vjt+|I`3f1AMv*pUQ-%jf4!SUYw3ytZH zQ8QdrV6}}I3og+jqf8nzq3V>(1>lVc`74xFX{Rb4D3SrG*Kxe9tck4$0xywVrWSkF zv{sI`dW_3mgj>zwZHQL5HWu6IM|eXcgX=%0!j)otv3Bb$olZ(@2=Q&Eu75a=zF3lz zy#4RINTmJICXGJZ*U#rha!W>|ovnwh3MlT5cchS(IVS zNDG!+Qq^+gq_6CmuP_iK^l@;m{emWR8*9bz^I^4qyg2m=wf@uLEo@rcxxYo9D&;}g zr=os>$;bCcC*MzEw72(5960-5t{HkzP3Gz)A}lp;&C#Vx_)jHChGF_x?u{O-;AHcV zXW9l_xC=IQxj|)W4oi0e!l;RuatMd9Fv|KOc*twA%=hn`W8^0g5C<~uGPJuDYBVbN z=<|Ai>A(!4h-FBgaxq70;58JvcxKD*a&f#2HH`{!;b#!bo=#7!Nr7m|nLk#Aw5Aj5 z{{}KfQB2{Rd&^#Vm6u$Q+Ijj|9=~YMI5;H{|Mpr!C`<2DVwqDqj4$F4&kaR8)Ib|Y zsBKoJ^&JB}8+-22Hrf2Cb@wLDaV22?y_xbui#8vKCFL z*lByX5BfD%V|EY%3Hlv#%oXd)@31E)4@wcOpKt7wrxD2gQ258mp@QuP%8^w_Z4eZp zX{t0bZuuT{-v8?;@*V6!Wie>P_ZB>#AlMOFV`@*cjIo``SXTOZ9||1f8^#c0DPZ! z_}x|5+5c^@{*O<(|Cf8Rs5$x5k@5fM`)8#Vs{IIpfj58h{S3`{!IC_yN(k>?$zgFN z_|mQ!o7UlmZbPB8im0N0KP09fY>-i&zXyzazmMlH?Y=MFzVBJ}x@Eh&WV89kEllfy zm^(MgiBpd5otb(nX6M)Mj#Hh+={4WWTO4dTj-mI=V!rD4wcoD6>BuR2qX96-nlIeU zTR+{TZk&GH#p}{Iz;2!q^NJCEFROcxSp$w8a}wI>v=5ULELE-XrlsY2Mx|!x|CCiR zyDj)N-}T1qB>%jWe^|vgtwVT6P(ED_LGBVC=oe0%v#Lr?=+VTzK z=B_r5xtXgSYO!M-_B;YV;T(!$zfG&*oX*uAp@cd$ezV-m9SIbZO2HSOsW~`rJjsyd z=UTLrSW?E{2Tt+tVI9Q{Y6!oztksfKu%RbzGXO<_`z+F7W>?cxizwJUP`tTZ{_yeW zOkjA%hK-`>AWtP{s#^vLu|;kXgc*YM_QPLju))Xvl;lxR`C^AKawQd1D^}N>@k$Zy z?@6>Y0rF!F2P%wOB>s`GUgS&sUgcZyiV~h1^?s|MzCg~PB>tcoH>ISEh?~y=vS%x^ z_Word;8gaE47i2g*o)ryt+XjfE8tLMc8nG!?N41pVFU2&9X-pqnt9a?{~Y1nlgQLY zyAC2JGeD(_1dlNfG=^0ym<=^olI~kALGpklq?2O7e+=4tc6DXjWu1aQZ}k*WN83Z- zBh`~2BgL%-ON>7-hDeM;f9%y+d~0ZnIokDgokI*Dvkl7`Q_5)O^8ypk#Y&^cvG3Ws0Zn!V|j;;d*7KzO+yQ8 z7~)7E_PCu3u9wU2;6Q9B8O&N+(hUjzpy(9kV;T;`eBQv{cSpOU2F&5gM8uek6Ay)$ zB~`EiBzb}}Gr#IFokfrhWd&9t5+9P+FUH#S>X0BW+0TqV{l)>7M7a*jq%dY=vmS8{ zY}epq1z~ZxM$qx}fD*M+)bOv|yZ^H@>!qiDHZ%uf&~GDl5ZnIVLJIgV0?0yg2Ljgp zARY*~N+z%sgxoX=&^**W@eT05ma$pu7fkJc=}m`t3#W~+>vWG1;&FZjEGS2*`7<#g z8RCOvYPgL~jBG)x_rl&K1gv>+_}?z!iOsW2a1CHL441nZr~!(aRVOv^Coy)JoMp}GChZw%$L7*r zBnp7KxVm(YzYITY^7!tHX9#i~ej%4#`8Oc9)gZ7F6rg)|>u55mi-&^iq)1 z0YfJ_!eRN4(Us+*POA13TZ};YsAaWP5Q^`K%4C&noom4<8f2!Iz`ndA$Qmx8 zU7(N6)1ROgR+q!ek^xyJw+bSaoRo3r4^GpVAm`TkSTDdoWFhi@v-^C=OwiG0Ke4Ye zBh=s6>pP{prOuH;a{1gL%+em0^ZvqAClC|4 z^oC5z7h>al!zFN{ubQ;jG`|3&vh*q=Ij*51EjimkUbu4J)zh*z0k!8Y1ln)tz8YDA0=omkqOWy_~Z6jCh+_&<2j>dGImJk76tj#yX)AH zkSEDVkbzWXLkm=|#mB~1J2&d{mc-9CB7CU85IQqGfI6&=+kMb%yUuy9f0@c~Dz)H( z;Ij@#DaIPUuE9h}mz%S){q;@H2Iims1q>vB9XS2W8{Jjm*`YcKIzxn7#`76vs?_kMENM$J3JftUH#h_XRYq3o-X!<}K_0_*Tot`2R|%mp>9JHv4}h)F*@x zvS2%b79s&0f=s`2f7G@3L#lt@J}B_P*N11SoIlh>eVDqIg9&@Q?LP;euU#Skg82<= z5x?#Z53g^|pKo4OySnMS`RKFx$_JV4dT6Gb2O&)(wdBD2nsu|PeX=;!Fs257#wu@S zLA(K|ZH6?YJdQVZ^tQYY?|1FTQ^%jtI1_q}x5EQa6fu%sRen(iO;Ds|0&QSuJ;}^4 z;+Kt^0^7k>d3^_3A7HmA%XzNbxMONzC;Lda@W{~nMo#ik_{T=8Mk#rFW}flbB1)BUisT-c`LOzNR^*%Y*rb-l@04>7JR!1NEXZbv5sFf&HWOc35=j&T5zbM1d#N0)za1}_B4 z9rKLH9+-RPAu*XI3!O({u-#091(6UpNwA(-$ z;_O++#Bd3$1QhdLrBwIbT>Gro9r805ked<<#JC+G{s#PFwnmx@#CdS*6=hA;XiD4g zgf$Obl1Y-;CWyQvo-_X;#O}4FNH((|FY^X+D2hdMKw(RuH=v7>D{FHctqCrJFQ#OYO;;f7k2%Nb3fc6=WQiUxZuhs#d-0-1n{@3f7&YRO{;~fw6wCqFz42PfY+? zT?i2yGBC~gW$H(-)KWMf_{ZDU+OS^afkx=1Bp!V{J8eb#z@%` zMombhZUH2?Gl|WpD(NS4YFG%|q&T-)YBLudSox9N`BO&Dlrm;`nr+6&H0Z~re~`yf z%gzNHK$i#fVlY)V_mSAZrkJ7LW}UPESbk;-o;wU^F)SFSoO`huIBSrclf4zdYj_#_ zt}F>&BDA=dZIg0Z!%df0*Uh=oC`^z1MsM~*4RD(f_9Y#WX?M%DGEW)+H#Uk>?`La< z*3=Y0Mx~XE8ycf~$K_h8#HN|${d!7s@@9lVE?#;U+JdbDZ|mYa*K`L2y0<|C5_{Cq zlg#5^avQ?In0|5^i|S#r@SL-MtR@RKQ|Y-Y%RO?n7hm3MpfBqqmEQbAwI5!_@J7<3 zGq|5;_mkS|1W_Ii9N`nch__Q#tZ28=oP`yFj09ZVBpcT!YNbde?~#8D)bF~3iuL&K zA3bP~0+ChBeF-Hu;`hUya4y>49MSQ3DQahxJXQQ_l7c-(%0OAf&T{`Y5-o!#{g^@0 z^JACg5_cd!$tcZuK}ydlr4E+C>zSjCxLQhaJOJIq*ru704^b;Z_ed~(uQv83abTBM zc)4mM4h3qGQ}CTqT=au@BTMO$P7g_xbYuku`>bGERD_tIj|K`!lEmRw!S`#3;L{w{ zgUdIyP_G!QAE&Dn#a?>*p0#>!x@uMdZw6&~j zTRpFjdyj~*xuPb=)X56gy-AVu$%$;lOLX{T2UCtn8f=gq$r?AOg&~n5NSWa8_sk0cb#709c-^)=(vxM@7@x0JC@XnysD*-8_mI- z_88L^TFk!zHph53nOtoIlrnW@n|VivC%&`%nw{BJYte`CV2GyNaEaZ*G2#|HEt z67>s01@RAwTKytdKq;sBmlw6?%5O8TGs6FnsDIKpNoG8&1r%|kGRC|wFE6nP#dh&o z${+bZ5S!|>s_%jCPdt8~gxI8X;;nT#ei(xZSv~lo#fM>_C?qE^QYr_z>_Sc zx60URGI>2F&Mm#zupNjLSaiN`J_c4Th9@)`->!x3p!^5hwF7X$Svb~)5mgsT9Cz%#4?m^n~Xlc9+LwtX)*=h$BR&K+Fe13tr4$cuWx>9 z0tXbC%QK*%Q~ZN^1g#_5YZXHf<%<>x=XNu`#YgUbdb9uF`^PX$F%D!c2WD?p*8eMN z9()XXK`(TJ3A3kcwQ}4IG>iAQW-u@>qH1`ynhktEbh9u}f1I`t@IlUo^}?G$%r%f2 z@<7rEb0MWnI_dsG#6n){q?AJz`NJEor-p#DktZPT7PB}p zjm8MAc7O@0iBD+|uEs16&A-~Bu&i62(lax$Ou}NkOX{01JSGrKOyS;{*schx#o(V{ z+8R|~AOJ+=*AKggl~YE(VJ4z*85u_=T-w+;h2An3cvY5fpIQeB2+E9*mAv za9R0;u~?PZ<#>yU(%r~r70xDR4&ftF`j6{%K-sc#PN_00v^ClP7DxCRU|$SjnbWG$ zRF7etQe)q$ms67g5=xiYyV5lCA_1M!aw61z2POVs)A_|oJ6QA5Y)-R&yIErJ!awuw z{q!fK!iXtr`B$(pTLm+BHK{v>VOfSZcno)=q}9fX=vL62N>^%(IVbV_`-ij zb6zVU&lj9RRy2^G#5Aq&>d1JM?o87!CIfcwC08uOPm!#}%~r!*KxLODu|U1xK<3%z z|3rjo!_i!k_e#=uy~z~YFU<*!lS|eIcok$67_8&STq6|Fw}P|3uk+EqGz_)Riw}RjO2MN?dZ@V zee)ZzP^nXd-*c?NeAa7z2zW`ICY3rYHQEg}`K@>3#8!`-cJe8_+A!UeNhMYI4E zSRSB=q&VuNioClwX_>>??@(U;y64EN@hxJ;9fx@l8qg<2Wvv}+0yT7CdBkuGKW~s= zE+A$Go2_oM4{R@_98qU)79~!w;TG2(_Zp8Jl0;A^_rZ4XUs$OlJw{;dA&jDja$EaI zcU6aeDE1;`_zZOF^^*!t&8Lf*9)CbDeN?6FRUX zqR&ue5`&G$>l%VozJo64fU-)86=}e4BC|+WV{j8?j%Jo4RX&L#^HuE}EISdZ5HO{_ zR)P<9?Vrcn*%jXVZY&qEuCxtFH)+TjXS_pRT@!uGb|#%6ry+rwFsJTZTjC}`PjuXc zR|TZjt&gS-Qb~oEGKs=iV%=j|d8DOt(I;L9IxIKGktAnSH=Ka8#|F_KK%K2p@j1xd z5-qq9h%k}9C!o^9(M9S6q%q8$vp=kS!ljs%fLFXqrOd>p&S=x&9alRS!1e2Xh~tdv z639n%Y>CMtq2<##g`+M0I=R?9FEJCFF8WP3y^<(*LV9NC2#3PTPzVo1FXtedq;=gH zD0A90C=C~v+n)ZjXcBn;$5uqyYm*QW>wZCG}$yz*Yr8^6X)uzw5gYmI2&)FJ?tD zL&s{_(59c^ev&?gb_-gU;j=&dN6Vsy|9;p+@cy(}Z{9m^dil^ne{56D3A&Q8zu@*~8WZPI#lP!|f$Zr)b@5HE8%aREXXCUS`Yiza`b+i5 zQvBpMNwb{=dO>)lw;bkcmT z5uwEzWus_+Zxd~eu10znK_hB#JoeEvdLwcxu!K6>I-n66~Yt! z)&G;P@P<4h;M2(4;LajM(T&O+{N+u35Ka{GUR49ig=u2CAR&|^z9OIYnPLmBwW33i*}>S5`&MLIW0T1b zn|;|Jt9}a-H*zSj)9#RFp7ON~^cztWyUDdFDUPUG-(^Z@x5}k=#P|%!76YjbA1jyh zcpr(fy}msqS}My3QSTKsi=uvm@FD(ij89>xn$^VogUGK;R0(eBv+w~z62sE;lt@oy zMmyQCD%C(z`kIVZ76U0shAnqmH|z80VE9?-+f;qFG&*a4aX)+7c-DidN2l&zdZw>U zPnu}}`$Gk$F#yI!KJ*AQ}`b2n=i60#~%OPH}74ra7$FD-0O zn93SfVYNv?M96%T30N+qZqfFiq@V?EhW*)F!m9UwLU)Lmb zQv^(af7jJ!3Z0dadnhWz-j9!Ykum$Hz0?LxTz}O%JkrUzXy@x=;;@%q9qze!@}nZj zFbb*lo`+|MY3{AFoSSE=;27B(-A$ssUp+ocsvD)HKdj!R)ZGUPie|sTcdejnoqS_7 zlj>#|Kd<^?)&jWR2IG$kLMpkz3B^AMy^GHy{7mSa*e3;%k#PKEzAC?bD2hD9bRgU_ z1)2@d3Uzz3-f5t}4mpnSIK;xc>^theVB{>9%hZNn>N0}Ykr_`^Rpf5C4g?zxojk9u zkYJIhnYg3_>wYC3`qjl4j`3|8gcW!cEz=3_ULKs*G5kuyi|ff_4k`xu9o4U>xqj ze0A}w)c(qenRThLNH(JIK*BuY&RX&5kCjh#)POk!mrE?T$Q8;v#|<=U9v%pCR%hF9+Yp&$#&o zwfz?%yZioe_+k9~;oiiruL7O^(OuLB^8ttl@1*H=GRxa2D*n^rZ4y-LR9{fk(^Br`Xq^G6g_ql`&-I z%TyMk%LkDx<%#-Abo57JqmAWETe~decooXE_2byCpGgG7=(bRLyOc#*DYE9=q{9rO0kYSo-<;&PS>U4 z<%bK^EC>~Afxmo~;BTN2bUTdfssNRA7k}lV;q#8#3;-oT6i2?{oBwrqK=$clvXnW(U59r8uXgXd5(OgnJ;nu6YXr9{6+3);E& zVb(C91+1FKQvnd&`96@9uU89A!-}6vUCVbuh1H^fI8zVQ+C0ptG@QBRSd{^HynxyO3pX|i z^Ab~hT*^PLif8D)s$I}BttiVKBQ*dPk%@8mba7gq2P+=J_Gh{7kX*?x*Rp`SR9#Nv zdd(}DsSWJ6BtuWdLg^QKlRKo4dWWZUrumgJ|NOP1U(QrskCwGlaC-Yj8%USpttfv6 zR^7W=3nDQ?DwoC9-@@00^?Z%;O)SmU$!^)z@ zF|aWrmI@j;#dxV&P>k!ZQh=QryprL@Nq!g&9TL!rECIIG$K+k==#4WZ>E7Y5K4Y4>v>{Z_Lo26FcH{(5W`s5 zjF%oj&(*WtZ3SMoCxrlPXeSV?GLIkDbBNs;lFxh2G=pljxxv@ibtbC*#2@d$Gb-0S zqv@n;lmTYfb)l`YT9T$hG-L}2-M7CLOwiSA5loiFkQJ5TXze@Eb$pi3%F`t^8Z$3! zP8Ut^7V9fc6l*;il0z4zx)+p8t+gtkP+{{m?I-d)cvIJmjj9b5EfHreR%=TFhiN?Z z!!%fEqsjZ{S_elpTUpWzDQNF85lvmG|3Ajgu{+asZPu}ECmq|ijgD>Gcw*bOZJQn2 zw(WG1j(TUldu*&R=7;qs?z*o!tB%?eH7RluChV&Kz20&@ZeHrDmHvjWT^`TGHd^W= zc3GC-?~Ily&YQ6O23w6WeDc{I62=Ubh5kcovmF=hnMQPksPpou3|#yaDDkMt!MYMt z!ote6D1U6{y-irU+|5R?H$kd~IL8Dg!Am-5N9jL{oIoeq>i$#Y`&`_)%fmi!cq!o( z74SWXy3I?#;#BG+J)iIs%c_{MtKD0rgmy_n`)xq*QA6A37kaB*TCA!6hhQN=Hb26M z+jGG|l@5RBy+%o5KB}{&K7Ko+6oPZ^y=827K6cmcq{ptrbg#$hLhDlcBejuP-Ep!T z$I~`ncJyaVE#+=x(PH4&9(Am-&KG=SRJ?G#`dS8=IoZ-F-b<7`3@8BE!n8g^Z^MX>Rb`BfWi?QzMoXw79v4eF3&(e z%&c=XeX+LfPu^1v58gQndHxBa`}x$b@+`a2WUrw3Pv1b&zB~f&M$z|+ux=Xn%`~o< zlVHp|b1~8x1O{*gtQ;PUnD#;sC)2YbQQIO_D~nAn(v~qa{9o;hTk4mdgmYfqkS;Mx zVTuj>Y<3~wGgkM6SZ!LIv(ZW;uj_PgSCq#~X|9Yqi{an1P+acVbC0{@ z16Oy)v;LzX4tufz1AbsI98owE$cB3Tl|bolew5BU8SbokgCLK@`9DUSpUUc%H9C_! zUjR;5hEii4tz0JU+O6*WRBi4cqfikcis%{ zTjl7`iZ5EdpHB?zaB-afqN(i6|DC4(XU6ebtLHn4@qHRX^8|hz+pqHvi2~{XI!E|M z6(Vb&R{gWRx*w01kW5KO=Y<(Xw8mzWfO4AlI1R`4fj89unTJLD>c_A1_g=m4eKzjT z`{~`~<=t@=jyO9Gny}ULShX6PU0=nYOy%@r2gjkwqa}}q$!HxDQCgw>;la-6 z={}-|X-uSbK<63sU4RgY(%`IQ_)z%@y&Ct&+W)4Fq2>~Sn8JKdx|KLVG_WbR!naErLBrREh%$4F+ zTy+k?AE2nBdB>N1-`pY(cR(P~+9Rk$I^cjPrLwnDs{qq$y5CGy@dMl&W*9OD&-La5{tVM6Us- zG(kCKx6lVzjs6aj6|@RnJ{p0z|0Jj+HlE@u%`ciKwJkBJH4Y-B=O&=kQV^d2_Z+URgq-F^oGBH?`L${J39nHH`!V(QN5==r-a>*gbxQ6f z$Isl4Bf7g_Ylf6*JhLld&bid}^@myEc9%&Q&|j2WPD+IJ#?tXD&qO2|gJA7E367yH zUnerA6W%og21qGz!uP!X7ih{O!LXb38@k&3gpibJX;N!q&c!Jr_QDc_5_nAr1hNQ` z%~vr)1~-cB;&FvB)g?mOn;j&8_pxMJ8?Z}ddW++TFrqEqy8Sy#gKn$>5cFPq+rC^3 zh-g_@*ZPnK1jShk2OD9oTclUx#7I5)w*{CAHqe4yiWLQl;fKxUsy!KS*^;>zpJfk((f zC(ijSeCgK~(W@Qxy~HFdp}?DDp*ov_*lAb!^N$9lY)#kV5Iz$0;^|D-Re~cGPZMFg z*7`xSs(2QEGAV`Ma-3@Tmh6JsugeROOgyfd`C*<2Eb&Bb`I_11Ay0!g0Y&w`5*MTO ziq-G42?GR-Q7{^Tnp148{j@OB%UnP#y(`+Qk+(1oYD{#)Jk5EkzHvkrOry7@St_Qa z+^y1fz*+WqQ+7;~*(~e=1Qid?s#8itP{?|8ObG0=k{H}i;>@yIEfzMn<{=sC@y_2K z*@{z~E&kq8g^)2!y`MLLl^-NQ)!QGKwYOkjn$0*Y^gXxXcl&8^7giUh%iy zUGKp;bTrjle=yadQNO&&py>x?bwv6}7{W=-nHKAGJN}_)uv^^sCs%0QO@wbg^&HFq zJ~V)D!LW>;vSIY z`Fe?$bhie~$U5WKb+5i*#$?%c&(Xt4mZ6b@O(A>o7n>2Gmv#Zy)NQ?CT2d*<;$aBf zJE?9;bFVkq9#hv9*0V29FWLVQ+ZlW~uGP8V#xCxKzCy4!bEMPfNKc<#MRWQPO~{E~ob)Q5bBJ5>fZE>x z!`W8H8tXiGsE`Tkc=Mg)hxhA-(|`DK>g;iq_bI-VY9O7Rlk{foSWTyV%5&SXIGMcqb(^#$oza= zG}o=5$~K+>%Keoca{sbwwAn6bOHnc}XzIBV5sE8tlWnUc0G%mV|I<@C(`0i#%R^`0 z*O3jYg;)`Rh>S%V9`Z-}>bhJb$bNQYisf}Ic(LKe7zI4h#K-)}zRgeE8i|+Y@*nB# z#Cr%Zc>%+SanD2%maB~40x6PrK*(Q{r>kFSjAvc2(%9PUS<_?q6chU*1cRk60FSah zQ*Gb}hX`Bq=bDYjh_h8Y33PY)2tePBj@ePIsAa3($&4-qeagvxy#vkgL|=A=S_zY_ zpAq>nkb@u%eoUVdw@b+tGeAoY$Y7)LOg8$)f4NuLiKjc1_p+ZY{cO{~Je|u`9DG%b zr~6r7ALebEcC{^}UQVVhKEg&oXqHQX%pxQgUncU?3@i!IPA`)!5h4eJPTpb-O2$Pf zRjV^j0T{J3N>`v{S}o9a`G{koV2pvD>`wmUKfWuMoW&a1@4{^{_oB-h6DadB7W2s3 zLDa{QIZ~sO=8_5p)jvuLhBn3SDI))Z%_Gwu3a|1I<=ws>mv58zNk7GcY#StbishGh z79vSJe=o@$ncy3bx4&3I#8f!C?NmGz9{VTI4UQ{_G$8$(2Y6!bjX+gMxw4v0Ynt6$ z$TfN^gy1I<;h8L}A?R#wUl<|>l4@jv-WT^#jZ4Ea6{7~bOElj;Pi#$@b(gN!y*shK zQ2L`ZQ!WiEd2qUTGfKelYIKiXQz=vOz{C&7vFSt+nePa)eu5(LP{`j51?T5hod0;H zzb=MkszSvR!g?a1M5|M0*JL%Txdt8IRSe`E4oj${xlt#aOs$#5gSweUGVYS-R4|rY zFuily=7u?s3=B4LJd`0m%NM<&Ho|p04xsT8@Q7_=An>Bns_BZQoU2J0f4kU2W?)rF z!AE8teAI6qiMIo?M2njX8A`ZMVytVRlWdHWIT>xipY63}QCSBgk3yDe@AC{VmJ6d5 zMXD<@`+5%1m*sH-kghq?{MtboOuRLRAxeRTY@2SELsrWmkMCg>V17H#-nNcyNQO3d z?Ll|l)w(%^O&+_`a%w9?o2SA0?MnBua#BX8c>;%a(lL~?k_MeV-T9u-cS6<18*Ze0RXA3s@6Rk`GlT&pTG265Oq~5~h9kSvv=|>%3q4xj(C1 zSbDm4_`N4dl!8pvH~4xL&tKfN>9@#SQxQ?&IlQ`2FFn}wuT zO^E=gm7>Ds;uYyoD9q*?;r>jRm<@{50!d-B)Cn-CaM5Va}m;CEP^)mh>$C-jTAqzZ~vpbIxU(zcYM&z~g9V zS9Tq#(RF~)A=KvcPMP0h%1XYQoerUS%G+Y*1M9Fko=+WfRF@ek6^{!w(Jc0vdA|%3 z%@(|eSOKg@i%-f0KMTw%h*oCbl6nFZW$))>KH*xF!@lP$7q7DQovgvxqpb(TPqA)o zA}j74;?(bC3fQ^Q3-6GROrV*IELSXg&r!{Bm-wV#w ztn2VUV?)H!g`&$wY1@24jK*suDMMm$am7}pw@H~MZ$;#Y=XKe&e~bM-bNT(+Zf_SE zZWm|!GN>ZY`sHrh#;Nvo)8!Es+H!VI1$K*@IjELZrCDSu7|uaYlMuM4(`7OmLdCmz zc|K-lA*t|d1D?@#vB*F9dz8qI+=7Wo?IUmDRjdPNp+vhBxrX2%uIJTW+m7=7g-pS#*Qj zuL?p!biM>9sb#TChQ^R7NHX5Ha`T77I(DIRC5zjWr2CdweKgD0uQ^D!%Erb`pQQnM zYLsRYIm?tn!SE>xdr7Y<327eN>T?ygq*n^MW*e#`L-fj`6csXE00w^S zr8gES!j0|~EBClZLC#ljS~65Gx z+%T&T^Vc0uYYby^Z84z)Obg+(4hWsY*fgao~+KMxzeJENss& zYfto-kHknLh_I22Z>VgT;M~nTMkq6louIB!{SAq`bZys`U?;d*i*#MM_-QZ5c}Xp?M;B+Rgc)ixl6MTOz4mvWZ^joe z;Kn?n(!M7zN!B|s)b2bvlrH0mepB^nG7Hr^m6(RYA2PrN>_?K+zqZ6^ z)DizN{n5u=w-ts?nUf4=SXfndhy@{@e)>SdigAQAPsg<_FjKvTr1>(L2v3HE1!cu3 zO15fweUl?CBxR@slq?L4fDQvhyB+#zv=5ATPW43bHiaiy^f=HnFCR0U!S=T*^3XBT zw^GeNotwQvzZ`wfX(bX{xZ_6ScU=lP{Rl(5JeJH=pvhEi=&>OVM?GngiP(=KD{y4< z+i8hTE3v=C%J#!z4!?XXJMM)I^)uE&Ad{7xKB1aybKI!{BY13)6da8A@ z7xH)!0{5JO*HZPmfAg9ESl4_hUV4KwLXu{{mQzOPNf{i$ziZ2a4y!_gP+kZ2cwl92 zq@gX-pyibfGzFEM4l9vyb~G5hoHfn#0F`NXj%TngL7BoSsKW()8cHe zzPW;jTmp6FX@~!XYtNDWGqopoTvMlswwLz|22*{a$?A=rTDrg9EZF=7p}yhAp9Vp} z%~%Xs4>8)Ts9GR^JhIkS7T(7V*3Oq387sut#5pI~j!K zK)So#cFAp1vZlJ;IL(OPy*VI(+oeYHtKANKmX~`=`YGWjcA9sD*W|PZc9E0EP(#v> zm@t`c0MK4#FzCpB4PnfRg8ciJY%7x14(GRt&7fVmHcC`W&j#mYTL{C{ z=V27^OCH^e-*(;Z_GzB?XY0pXr}rCen(a30+41iNi(VYtv?vI7)yd1R(-fv@Y}CEl z%}Fth{hR(6rsJClKHpRKzpTB-xBK?cuRD|ab$+ycJ@onx>Wa72f1Db;k24QTR}#ED z5)IGGW+Q2VTBS*{k?@1=b)~cIX^gc291X>qD3bkbUk_->w7Z{Kiuss~tCaB&Is>;~ zS?Zz1FdoHhZCcRfq?V58N^!ieJklNRcCR#5Ya?-zDmX0%T6Mrlmbde8`+O1!WnLi6 zvx0DLGFpy-G`OrD$eYx3w3suiauqwI<*l?}mEt-{d(|8COo!l#562+v_d407XIO5e zgs%#X?=&WWs9GMM9QW~tn^w%Z8>>AsM*ywOdYdE?Exf2r-8=3A@=w|eSAjbw`yf@y zO)R2?3%A~31v=IGJ18Ck8}>mVPckbPc{C>=k{{|x>HziM!sw`G`vgL!LRcyVm~-_H z+wbB`%$dwgIsw%4^RM*bM?AwfxrS0~(yZsVDZ`XT4!?k-?#4EGiS>AkhJ1msv-AMg zX)7;IVC$4+Lhy-10DC@W<2&M#C+TwDMJW^y1nD|PVN-EGhK1Lz`6%RUz1~;6TeLo| z=Nas2fQrbY_=n=7=S;}%enN#8e3N*`I!lt0qQ8X(({tn@=gyfOjxyze)YUqR>{|-o zPJ3$Aa(n~mMNBZb6SyKuDu;V)1{7hm8B>zt)Z`HU8%QNA2~Qh+bJesD(rb&_8vC zrPNk5KWtjD-=hPQZvy;h0!o!oco|K*1Tjq5KO`Pva4=5%PZi56!1JS*1KFRaRt!V5 zBj!+t4$#MU@OANE-HrT5<>tRi7d5V%@jWYv*Qha7T!M0;oj|^vt-R%Ayo%=M2&fT_M9d1M!`OtL)o{%j3wzb)!^UW2|q@OD6veWnExghQ~+B#(Ehi zD4_ZK^ej60k(T-6J?fJE5CTYDW5N1%(L9!I~M>OG#sYQ@gYH6`QmZU#S9ptRDKVWsG zl^;B%)o=Idg40WpSshOEgt|lFPHQ62TJ5lSaDaoBtJbbuAarPsr@Yk})i-R-OCwkV zjulN2{*0t1tA!$+R#lQKx)klQGU7-3Wicg;Jyrlua5VjDt)8J@8{2Hd@oTl)ds3;v zj_(CxnPH6=hVs^cQhe{Pd$GLZ#3VjSarx5DIOW9@i{-HVFGkH=27LLlCDeJKP5E`g@r-0CdE)JcMlEA`vNh+h za)NafoqTo;HJsl@;Cw7|&(iWFRXiH+!J_R+i?G`<>&^I&r@1z)?8PZTM!H$^5t*&c zwkxgY4goz(9WY%*T!n)s+?Bb3N4}glfU+(Ly;gp!>R)T)Q*%?=IV{so*r@8L2LnQ) z&Y~{%3i~Hv^g$xZijfD8(|l~e*KZF}JGNUK2?kRz!j=Lj3efOULdSOqqrm6=XP2@_rkG6mcgn*JwONekUds+f!tyWyc^0(J#UX1*joA)@J z`F+n{oh1AQ(F|gynt55e;mFTZ9?BtOjL2XFOuqkdavDGjIH6<6)-o`L^%Zxd%#}E5 z(_Sr{d?v05CDHLjd;{5^BAI3ae}oGTHrunn&9u2dbO=cI0%Su%p#D9%M<}*4-Z)MF za=T9_#5p)mmRSI=FSzvNS_|1 zwHM?2Jd@5;bKHD2&>C~!E-{w`a=3WE5DFB>ibQA%9wMez@@Q1+FZvVHH)<=Y5Q+b4 z`jNN89>ac2SOQPC8qM^C5Gt4E;okn4NK2F1;F(aO3RE~k={{XJV4tQXh=zc%rXYWw zcT@k|=f@&Phd~yoN{vTJ+l!TI%)T@Vvt9T+H=Hdv-(gFn??#O0vP>P?c7G{>vt8HY zoQAQBgm518xTjUV?g+mV4fgw(>dkPkFm&P(h1Bc9^=70sb7%GxV0IiAG85wm4krL2 zQ2D$q;#x#FtJkb5SB{f3R?x7{F&g!wV-z=`o_`7#=-2%LzdI+~NNIV7UTVumu&~9wi6L_jwV4t(@UZcV_o8!eg(cj&>MGBo)U_ESzBOwXs&wE}m ze;gnmX;Ek+Bd~GfW?|;w3Grt%ThYVf6Y22UrQQL(@)Js$d1U*&#Sov{r9qh{?8$YZ zkaJ=v=Oc6~SOR@tt})vOB=KLS7spVqn|66~sLOs0%8OmMxMlXZu0VVWHtu%izXfpV zZ39Bb`PyK-aj%ALXYW<2TCKvKr*5k$z>ye73}Ud3O>|xDw{%^pJ*}d1#zqh45gMF) z;US3IhKl27MH->HuMs&Uy5^C?a)Ho zVp_CXMS%AS_v?IGaU2~}(N)FLiRtETKO^(PJ{1Xq<|NVeBMaJ@sx3sU9@CukWTuYR z{(2FCk$K1Lb8R0RYA2rftiLai*)K?(-wEB(ukC0%P@x>LWRrIUcBVVqlI9wm+tu8> z7PY1^;IdDF?49Zm$s>QW2Rc4T2hou@PyUlJ<3$k6nI=0f_Oo+jHa1Y`4wFmI?fl^2 zfE)9LioK)B z)r>F61GKUIA=COv4MK;L&Eb)|<{!TUr}bpZhv!tO#+k`_e(u{JRI^ z&7tkUQbU$bO7|!YR@!kj{%XQYt1ytpyx8*uU?^szV-0_zt;9QQ$T7ehT8}1eSeT|1 z7~;`)IBXnfRHX<+s|Z_~EMj74TbH81_X+k5 zviii;0QYs+2SLScH=Zu`+C5eY-)@UXPE|Xc<9vH9EcedC9K4LR3+870M%V3C@&x0Y zqjNs63^p#3;+6b&1qkL3G{6CD_M8nzu@o(};}KHJ>k7j;L_ZD7FNX)J!@E}U0?TFp zQcvBwhvPIqAkCZI{(n<2&j0F|$;kL0Z{X{1V9WpM9+Wcn8^~1szwW`k=i>hWTM!_k z7~KUeqx3_pMsu-xALXpH2WMbY0an(cLdK>$!8DFKhLqWE7nvfAhEH@`P^OQ z(!sA7n&tPCm*i`HRw^l46Z+x%#-EiSRj)*NxJiO0=^%&T0zds~j@2DqiA21?##t56 zVn*+rhQzdeSU04Ry>lNf|Dl{?Z#ATyq+1$2AwYhK%>^}^(bB>5p zqtexZRs^LYh}6jUOHxE5iJb(c)z4Equ_ue9*Qc zM{(;Z#fE+mq2i!m?qGWKg!5iLq+BL;Gy$li#L)=)B7fAqExFPsaLbUbM-XWG2AH?ADxKhsE>k zXfE8@mg6+14gvkak-ocRDnCG2s`H9_EP=aN6y2>dw7%ScM_(Ya_L$41-os%U>%l%# zDY6!F@5xIf*+tjo7URe1Frvy%Mqb!!0oo54?{75J@K85J5)9X8j9zJ;{3ZL{(yYf* zVmh5aRRd?7CL{aa(jxz|ouvTalQ{Xs`GRWqwHBp~h>yotRUIDuqgO3;J*~qu1%E;9 z0!!L14N6;8gkm~0Ie{ZjBoQ`w&&lZi8OgE9iJmstDl_!54VGAy-BvAyRW%n!-{D93 z$Os~CSjf0uvKmVZICc4yW>>qV#`|S=`O9a!Q07y&YA5p+cc%A8xSQX3-JZD~&6O5i z8~ZS$)vqrfH0h+)yQLrGAx6^stuKDLWkDtFMJJOBXwB9rn?sIXZjlrEe{Wn!XHEMz z?`!FgNXe|pTRteiDFU{mdKT4sx`i)M={wL|Dgi$Rs;XMN6|&V69aY}f&Ao4N&M6d2;Hj5LrF^(^Etb`%;H!92 zPyk-Y%bf8mY13bPH2?hI{&dOo{TP;;?Dn`@JkKlwZ&F!dp~l?Nul{EMZr!O&;_YvUVUQ#IR*G%h~PpQc1f+ zr7`EqHQe-$1buldF!jJ4*0ZV~+-roRnw>6IinB%H%p&JsSUAls6#J1bN_>6tf;XI1 zQhkck$#^>BrI|%iH6^$y8n$0$D7_x*9BS0kWz$tHPu1q-HbEto|j2zlKva&u7t_Wz=T>PBpT?-C~nm1Lmt3%<6>ov*Ccp7$XM$kMI8Y7~^Z zJ|~EKI2gK}bjY9SiO}g^mLZ*3Oo^CS?JCCD+0K{GLo?^)xnC=L4_|O;v8WXO%}+DR zHpFg>nC=e}#i%~-a?qh-b6TE})l_4fC#*W-BUQdW1rfz*3djb}d&zo(mr@+&>*CRr zSlCV(A>8_$v%Sp=Iyqf@icq*@OaS&Db*)34j#(TizH)%AR~*(RsAMWaBboV79ZPKd zAzsTAIw$#r{43#186iOUSG+$qsDzLJI$#XT*#!KRj$%snD|P}rZ;)wn6dOxxpiu{G z5G+^W>8Es>(8Rc;|1-+F!FKA*!yX$dS&S5g&f)}yxQTx91kSn1U6VYMGLIxR(h82FKh~#e_su!w6ow5q zW|}$_^F*#(s$(L9!jr(!tdGidm!q5yOKCLDBsf;67|t>zd#DUT7K${KIG$6_fc=NI z$?qPc3LRKGW$HX@;rHcQul)4GSMt+Fx2w1B*0DjPYnMSQPoW*@g7Oat;e3VCX&b@Y z`p5_2TAgx-esE|Fh)=EL8(F4jMyCTYvqe<#zV%Fo7-nXzx^M_MB^fU!O%eL^M z%tDPL;lCQ$yNg1bj9!-#WJ>AVYH=bi&Tz<7%iW~nza_hl%~Ef#4kR|H%JR@DoSa;? zVW;`*o1d9WSEnr4t1SDlLD*0Duzt1y)+HCpC#-{c3I3XJI*gH>e<&)zTfB90*hC4ZN=*qMVJgiG*HwXBjK+w6y~S(4=5q-q!p7F4Di6Mx9t=15{_~O|(*B>z!+z78Vw^CWo!_#e( zJ(Fl##Jpq}v9R8kn4_40*f=G1AKJOMvnDZOZK^5FYio%hoQ(MNlwG1qWlWyk^)=`= z&{Ti!#bowWXhz{9IcnRLc)#u2|N5=1_ix(p-}xb&9RJbd`Uf5VKls0Il!GYE_X=14 z|HuDxY&@?B`}~`BK_{Jx>Sfkw(U3L0QA(LeEWn?AK1xb{^A$es|2|nZDR6V){_>~G z`)|6hPfo9Q%Hot6yr*Z6oE9V6q7*2LmR#McfIjDHsx!cukTb6s%pDSACS?z=?*8w= zLAjX%^6jy8u|qzW1x zm;LoY75NnQj?O##wuDRLU!`A`ROGq;0fQ{0vu=AfgOIbdkl@Ej zt?4u6yu9nxa@dn9!t{p170hR=5TJSJ(jK7HGRtf4hi_mOvHIQ&<(`zByP=%;nY7Hr zlN^b0;c5+tEvj)kQ!gT_aMW~U;ks;@$2Pg2CGvg8|7e@RE3Eo_=JuJ?#M`8`Yo29; zf|H94+6gL2p<$_BLx=<|;A-;RsYck4EWyf5f2QwwT)s#(qS=R!N_PrwFtAM_?EE-wG^o9L-0 z3q+E|6hTU;!T~PZS6(&ze{BfX0JcIrq`bbvt5h43e zcj2ks!cGj=sM5Rhec9?6l$OOcjFTfK9g-8ez7Xwh(jr6Q9u+JK7a6FAuU-T2N)4S~j{Y@*QE4L}?rwwi%; zFqv7K5zv~SG(FhSQ^H0%1}A_SeBY(sBcYLTrQaMIY9Wr}VX*L6gM+a}o$*%%+CI6c& z$eXkU64l0OL-zU|rG6>$9%OM-x1$c6gnrjTrh(#}n;Z@uZ>o16j5A|ohE+$BK<>;m zl&!(+8FcyGQx-_uD=qW0`k@(8Sy}U*<)UF_AP#C`2vEC*)6E1)VeiZ#Hcwv#*^Sbl z5kSz$&$Nh|?jddV7ZFYcvY&a(z@YuPqNJTEG*XQGJcd&tmqFV`LNEtEZRj2pFg&Adm<>TMfb9b*3d7T zN)X&<=$5#|Kuxs2iyIQD{0y#hZTD5N%y6A3E_ABFC`BEWW=%Es+4r7xE@UtCM`V-T z*7A|51w^PDlLj12YHSd(S}K`-xIN0tGrZZ8$Ac;P%O=e!vR$z2Eb2GtqJ z_nWzRo$AVDK@3%Y9`DH34Pu#qo?R2q-kyN%3Y{Z52%_ah%(3LEhNn2&a#Y3r5xjq1 zRlX0~am%U9h{@>-#`(=PsY!sKhGu8sbYkDeu53aJ>k41PsUi4+qMfr}SD-aPAc|s{ zvj`rt9krouYif>a^Ff`SWc|`JNXlrAm;Gq}y(6=daoUzFooD=0okt|KMnKWOGIpQ5UYwX=;{no3}v9G|*F zci7kC^x^)f|E?wQ5;tvLZiuEXW=F}S9<44b9ewNdWk$_;*dds$Eo`Ml-AU7WSV&h< zbN5Yxt|;fX9M4E48>e#=roYadZ2M+REX=(7{+lxYcRmjn^M70_{>kqBpR7aS_yIX^ z5ISRp zFO62Ie%@u%H@7x*ecPxHG#1CgXm$pNH{_2X`?0GihcYvJ zl?Y`dQ-M^bVTw@6DcK>MV{XK-R_Mi!_JYX}H&3aHO@ZPpWN~gr;^#J)1U;rs{3;p+ zjU|S{<{d-;wfOj6%i@yXxhW3#h_l&!o$p_|TiUqpWL#3Gq}rvoAK8l>b@OenGl{F3 z1hg`0ZK2hdgK&*`NwL3|<`+3>$V-HpG}vXZ#oQ5$A}Dzs1k&_x#? z+5sp=W4bQ$(uE;od%Lm^Wwp1tP6GfzIee@bC`?lXg$)5$gb}A)R=vhf82lujzYoaM;9=vxBW}KA& zyax+h?Mg{UafU09_@h^N#D%R$0oNWKE_?D+Zu&x%xJeo&-9ZdyEuk#VL|3LO2W*n8 zURp#p6wlg1%NO1n`n6@PkTdR-f5#w8n0s7_ zVMxCjf+IWGU$u{*dsGtW48uuuw~0|BX2%y;-8$qWK&{CXFHy226Iu<2{WImEZJtDV zJEO#Apg0G|+h$pEO(?odGPqT~PK^3{W?{P;o9dVkTM2{qjg+}f?S7vs5qhdf#-rT!O1LQW!(uQ2J zk0uR@*3Wuf^wc_5O5r*E>(UkS6TdB-PIhbyNnd2nAb~beqI~i-6N@jV;>1g@g=zCe zCPiSXmYh%VjVDU30@fEOSjnPPNuD1zI2i^;VnjI|U7J{Y=5*ybYf5O2i}9#_eHT%>_W`y<$bA2m4qGdQ!c^96N`hdW1t&PDn3 z59#{tE@Llix6!I*4u3eUs(r?m1M_!qD8Ggvb zf({ee7t!ih$5R7(?WYq^+QLfI-%*)?&`=BfdmXbge^mt3=X&yZKqL^v*r2Z2m5Q5( z9m(r0)M`d`?7GM)QwE*p+YzbqhCHzMwDG?AjMJ=)4qotIonC1hb!7ayn)pSR+T_z+ zYG-IW%#ZuKQ6nd;be)P)#Ei5i=*ZadVNC;_UlPZ7#dM0TBlCx;!Z36UZ0drLA9(Yq zs{dAF7fC@aN5v#xz)(o9tsx1=#xM!{wgM;}e$w_XdM6{*l|*`)W|0FWmS+wgu0GeX?yN z;pmm?oH@!ZG7<09`Gs&Chx2C6I5>RX&M%-T3X|?)sFy99(T-ZblWgXGQ|>*v^>Bd-oS5${z6t`d>Sg&Q-FFG?6Y}bJ+04J_ITzD^b+_U8&*Z`J z|6Q=TfYeGTuK{CyLn4BX&kE=O=aO~xa+(lZr(#d-de>=aI4m zl&U9bLFd3VUMc6WhYO!p!@H_@$>07JI{Q%}jcH_*&_s%IfbN=?szx`ip>{0maO`zO zw-KTK2$^$(+S85dE%+mujm`O8t?#(aGIx@OLe4=P&+?SlxP*>%V+4RC@7MFegrAHy zQgIHX1t#XP-(IY&Gf4}e>z02jqKiNIdSmu6BJ3|thFSsP9;kr&!ZW2INq!K%pDSkZgRfQ0n zqF2P_q5YxQfnw7BPttKA)yCtijVuk{4~xnUk38fXvghcvRD?Gd|3B#g#Zky(@~GY- zm%u+tW^&wA)uXP)tC2Ry{}#vqP^YnRAm9R}CQz>=hoPi8=g(XCT7ziZwTHJO$W0^~ zWN}i-8x&Rdn*7bq;Ve>Lpz>>=+i&Fe43_$&mE^}yp~xCBh6 zIFwJ3zpw-DEfroyDV0V+rS9sk)vOX2vZh(&&+;xeX=*%v^vx`rr=(K(kMmN`_6hHn zc;eqbjao4oRbZ~buS(HsjJeCmc+WEO1g>u`R!3mfUdd=s^W{?t!Og~oUC1(Avf+T{ z;1N?IR}yv*E?oNmZYa)(D1AAlq(lO~gR%?axJAgE6E|lBaiKiKkEtU+Gc&(c&+*Rj z2HSuZ7;MMw{q?sS=JsUbZ%gcWPN_J^G$ftNycv82bJNeJn)m}MIFDLmN=ExXaBVW| zd2OXZ> z)MB-GTG^)1SogBmZWP%V<;8ISUyQv|n;=@ctr@nFVcWKCXV|uF+qRXFVcWKC+xCg7 zv!Cu=-F2~U=MR{l#(0P9;C+S{*>7oGumg`)L|z(z`QjiV=7sf<_>7Oay)N(ZFf566 ziKE<6p9A3vJ||m~s{RtI`pIbOT3sg7h|ZwPi5ln-_>z!1IdWTIX37u%0<*0nCO82l zg@EN{e~bG7OxL!{`!uWrPd7bfzLjy0@3of1-&z@3L*{&K<$2g$wX)~g@sEF{+wzx& z89{VTzgWKK9$zid`w)4I+3RvhJ8>f<`3mdc{zTSh`m}W)$euM9$FGt{KUf7*rvU|9 z@utslusLD~EQ++QK-|~c1hn{*Mrv6wNF-eUwqbCmA0;!}#!=Au4Lb6*jy+#fZ`WvdEEODWu2@|+@akHq|HZT;CPQ?lpozxfQewE!2Ct!4fUp3LYO@={!;UOAhy$Hv3~qwHBH z>+s(E3%)nHBNK1S$FNmSb z;P`&>%SrlSG12RsbpLi*TZEP)n(C3WqP*2BY-wmlCH7h~(dikiaSn=P(=qHZ(UwR> z@(~ZGRft+N@Ii>9vlMUG+E=TmJ-YI+qh^O~Y_rL#)b!bdNp?sQ%Oz=Q@~GglOj(zB zLwjChH&3^ob<1B6Hnl7Zy|g2zjWMRGl}n8)kb`NRdL|HMtxRU&%EHU9rL_}I2&ubt z){Z2ta(Pblca-BXrBah(yL?mZlqW&?HvbaM{F-NxdtJ$+cVtTD!k1(sXSO6u`0_^I zx=!;#H8Df_S*FbD0t&cg(1YRmJ4SX!^!D>FXf}+t=xfNwnFsmyMK^ia#-17SjWCkN zq7%#yL)R$Dl`7q58|Uvw-FIgGj(!;$e%sUg^~Z*x(;% zv(}>ApI|+8q}U6wv|^k5$`JK-6FObGM%37pQlRanMyMpl?tPQ5xAFz@^h?tKw-l?h z*))}JX;>p6VO@*loHz7*pRb>h)LBCIyVjE**()Uq)*SlPr{=5oXb+0d25Yd0Axd8b zEkSD(gs!>o6?O@?r}JIxMN?X2dPDI6qp9vW;Y*(`R@0g{YZ$mbE*95<{(vriJ9PVn zPn3K58ntSDQ={fR&6}&UebDJWU%0#U`8)7sI?h!1ifZ&=vQhd096GTX<@3wRyzzB* zrEZRf`*#qq_X0ONP4N8TJED(54}itePaMqyos*Fb@_(z6|19T?p6x%#ikm-Ga-ANg z^Z7^N??Pfx@BbsuTLbDu9jQDSye%rlJ^H32X>^N38@)9OC@^GCA-Rk9B1SE~h=v@x z&DHyL6I(y7>-841oO|^()Rnb*Y@4xYY~53HpA1!V&j|54*scVCjS7* zzTBt#w?HAfuG>5LSuxc)S}y=Mi;iYYz#WRt?8Y%Vw_lQNNtF6w z$b7K9#m#!gTxlqF1}lyn4G1@yN+bq-E?onc=Qf@SfSoI9GhH;@$UHr{1dLD`2ehT<_ zk7vly4Eri5VE%kj2RCMEJ4>gkS(n59y)?vHfXn>LaX6dF$5D};FNKDJjF&oB4646T zFoJRAv%H3=1&A22QU?MAZRGMBy^gK_*SCAlczW3|81^35N@0K$1ar7DLv$TFiYT6V z9`;5oSv)aR!?aidOLZlJgv;i|5DnTkfqU6Rl6Pd5q94>zkP85SM(UBuAorw03xs!cRwv{tsUizRR?v>~n+;V~ zSXPqQ%g+3Zrl*s%qiZLKiET^t ztyBz3g2$4CfS=omqOPLkz_XJWC;5av%zzh(6@*u}EB0Fz4f*gt7Y**@9U;2c!Ytwp zP2$S%>YuNGWnw0VHpV`)u#vHjyYIc!m)2ATj-T4zzvs7mu7mXi6>#t!LqeUzOL(Fi z#!AXk$F2E%3=v#fd6o-Q+Ho~<7z3^Lp7-`nCL(Z6F2Qe=9s0}2_!YWZc)sTPFn?b; zo31*);=@}=AH@tc06Y08BC7!?FKxugu3r=XMl{~qrn}pW%M#2KW4XDpErlC437E(= zhBt1>tx!7OEWv9_Jgg;SLo`G7(GL@IE8I>88?L3q&Tg|+=~QYH+8OnQ$G`;xPE$0~ z3y$w#t}DcpY;Xdiur2=hcz|cS;355Qzs^4k!D3|jk1N=wdTY!9E5hU_>YIPcC?zfu z{Yg(x6`(1!lLFqQ;!2*6zieQfj1XG&}8A#u4 zoOW$Sb$f4WJV^B9Qw)uB;K7efr@aviA|FigF8VuAX?GTt}m=dAcF zB~fNzl6AFn1Hy`Aa&cykk&QZJ?#35P?DzXcW7rYE%2UFjr@P}ctmW=3cR|Ot>>h&X z0Y}B;)1P>n%T-nk9@#l#bU-Z68H{MdG8}7)cV6hDJOAP&vmuDM5_HG}5f`eaOt0OO zFbTaS|8`Wrb)3IKwXhqVb;tbO5bTbqEv5!t@aMRPAKx+d>lJP}&gW5E;4RA~E$BAc z9v@i@C<)eY>AQ_63#b_lvT(CaJdX=L9m!YIz29REnrjbHACEPc=fj%)O=1$$H$(k1 zj_uZXnKsayxNSO3=M%u~S4#*TZ5JEO=S|KR?e{u9Eu7RknBp?hp;W3_!JO{X#wVR< zDL5$7SJsXf6W%M{Tr7NhG{_lx_({vsC~cS0eM_O2VFB|D=Dh?RoxqM|Eq1OV@-$}S zf-E6}8o0e}O{f#;&`guJXow?aQYs<@BEq6`MJa6OiZP|0=jaFXFna~c3bg)#tW)sH zElE0cn5{SfRU}InI;mInuyu!8iw51zzd^iD;dq7Vs9wt(C@20Bp~ysx6#%-8%8HQb z{lOpcLjY|Du^BEW6WEcT8wLTdx2+I~N@-ug%QLJ=;>#pk7u=v5O!IJKrygxMFkps zc5KmIRG^5rZE6mAlx#qKVooIN{*0O=KAg&s>y9BZ8u^}NZSoRQiJZtCEDAeIf+=O= z{0bE|s2^oA63a;0eBAN)fD{P{m%J!d9Oq~9#HVJ7FGanpYN-AqiRHz43Pn4xkbRHk zvq1FfL@&eQT#MgRFb6QRam%5FXfT$47|zOcv^8npIYOKw2Mz0!OhK6nN)>}@7I&6; zm~pl%)j1ko8^Mlu;@BA6k{kgXUR|h-(abLS4j8%Gr3O0>+>`uFN;;U@hrKf4A; zTkZAyc86li%ty=5&a>&=Uglxb0|s;xPq4#Clr|rap}B`U1f9CJmr}J{94Rfi!g(R? zR@rS{D70mJJJq?QOFjn#nV94O$Cd12GW3fM%i8r=^#{d6s$v{v4k1~uH z=~>zTw~1m?bM#-Jx_{d+kKzV#%w7=ik@1@W-+mp;G_5<1>3@AA*^tl{P^()%B27Rv z5z{tyXq@8uz*^;9;bAeid^@p!pI?1BEl=OxFWo;w^&c&nx;!d-C=%8A5++w^qmoBAG$3Sv4tZ`&tDPwzT?9KTlY#vbp2 zUrn8Fw&K8rAeN}DX^j`|UMX=BE(}@^eVW)sU`0f}`%Fc$RwPGS%2w?3_i6~z$d%_l z{%sXSEH-9B(;-yOk)YsqCePUyV0cd&jLQWO1H=*Vyu#lEj$sUMcQDp3Kv&3;#n5lk z98~(gY^OFejzB7`G$ctFt@_hzAUKL`HjIKb{2tvZ8c-N_EBiZBE*@cY`GK5diba85 z9pr~gFH9arg#No8PXM?W+=RJy&70AnSa7sDCDzmSN)Q}ab^~aAM?tPD7=FqX z^jf{q*{3WlmC*L$`FYjkj4@8kQgQwL1LW^`w8fvu&5VK+~NqIlN(sq z-T*_kbT~jAsnif*vgorH#rSdxb+eKA{sqqwu8uiyl_V!dV@dG?c8Te!G-5n99dS1{ zA^W(wLkQz_4thnKp@hjtWXFy&{J5KlT*tGJcIZ=x%n-kJ63Ey3NNA5iilO%FG14d~ zdSpyK+SvLjE&e7UZ=A|Ujay8J`YKLs?ydH-uhnWzJF&%S$~f(Y`&Zd*1Q&jbPg{e| zYS|ihuUPw0c=TAFrS>b^WjLo%#! z8+Is$d%8SJdVjR+$j=M0yGh-#RnTDPd1Bv2m7Rh`)R8P2J715NV&dnq+ zych=IoTKV=Ueb}JVZyVoLwz6CmWq3Tj2X?$A85pc#|4p@=AM2sqGK#lcG!zJY^D@h zKM4x;kVNSs8-eun<2Tt6t!8A>P?$@cqBFL@UvBgBT|Gs!*(T~k@y&#Kc3eTaVsQT5 zvtLkHpP*JxXp)He3!=UXGFy9e+^W6Ia-CMI0$F1d>6@78`NAJkOE6;0IZ&%AvI2;e z(0H)rLjOf*S2B^ceUtf_EUi~b3-%F0np??v{Y+gsTOy? zTBsji6ll_bcyL)KM^;g57rUwoZJL}HIM{;JI~A}N4?Y_ZF*}t{Z+sU+it=yUWd8j` z5D`SJYB^7=GsD{XZlGc5u_=u};03LWJnpXG7W8C}RPBnbp*P(;56U|n8Ebe@%mex` z%}M2!z%Nf|J(br}Wal`_StiG6kdB_YEGW{&6R)%EZ=0yG0SkG?^7N@sTzrA@zN+u7 z6ix0ij4pDgxq-ogS+RBrLztQqHaY|AFfB0nZ0PJAk(4|QJWatd2-hS@QK6zfANRh1 zyxZ2ysZA*=2zlF;(kqS?Irs1os?2?Zv+K_Tmy{I>7mKk*#gm`fQmjf9zm8Qa-OTGLDkRQUORk;{F|mU!i%y#GmDF zvgX8R)->>Xd<{RF7gh`WBTe#i-5>y{@3@zo5=-74mEzp>PFx$;xhV8bX*;byD{S8M zS`xI=^plY~Fx*unWz+xC=D%yWJUJKUH4~kBhTmTIPG?8$UR49B;|mAjtje7tX_PC{ zHK^VOY!i>=E>+W_G$Y}O`OU+p`m4Cv$J`IngEOo>-75;>&b;yLd5P*59{-vZm`+T` z@dV@4pIDx~crgvjqmH^M4HoHXiuo~@;Ixzi4Vo5B8;j+a#e~~0`|^d8E}PPg)B5)8 z8V#y+wqk{H#Xp~b%Tg&@Xm*JUMr=J2pDcbZx^*hxe(8zdtNiqi;=Zo@Jt=dSe)4m> zB(dr7lqLppT~6PJIIM$nT~t%&TnXvL6(56SiXmD;t|&1#C(}$v6grMMxy8BtTD;S8 z-qgxngGP9*W5>vcTiF0*DsSbyKfbS@+s}PE&=IER@y$ukT=NOM(gHR|F2ziR@?x85vk6*9)%ItfaxBG2+`|$nzX8!(WpU%Q=!hELx{+yn2szJG51D@jeBM{4K>rEn! z+aVhj(jO|`TQGdX)%7YLTxv;@{Sie#@X-}*OTHrdRtCdNC)t?J_yj@LOPhy~18Vn| zxED@TSwkiae<|V04S}Q!e$y|F5F-aA>wIp1VZ6NZm&6xW+umzO;O6_DAU{CV?O)?N zH(*V>B&zd?Z;Pt7?qm9`i?NYQ>HjtIknAo?4$u;q|5GX3HlQA`(YvL--Qrr!gC(_L zoLLm!q~e6)uargrc*2OOmjV4fJd!1-7IBH=AuO4E!;rCKq)B zQH_xY`Y96sYe&!ad53+4P5-G%5Bw35zYFC~DL~WP3qKe97S7Mt2e(Vlh9Gl8FqXHt z1~*TT2{HixK_Y6|!hxaKb~2Z?uaCtRx#)23IZ15d_Ijf{B;iI_>l_SY6{i_RRo*`M zevWeV;-s!YlxNVr5VE5-Xa+;t{PJdidIy!wUG%aBT(E@q^aP@0k)cY&DN2r$vuQsd zhItgYD!qQOe6%kK;EzO*k?0Cz6{2zH$VnPDi+Ul1yFs*`u)e%9AK_n<9Y`xH8qu&j z(?O;vV!0qFS%y=m64B@&4gQpwDl0i?V&(oUKkmAlDXrGY5x8K&<&L6Qa_@x>h~`wK(3lou{4X4g9lLTG zTIIWf@Y^2v1}{C66-=3kz$%DB7osq=5$NRWGBUzT!ew2g&~?yIFMHjGu30{@^^J}= zQ?y{z7Ef+%#(T8Tx}xRi;*WN?TQfB~A0dusB~3499p!u190Omalbd9*{UI;>4p-i6&dMNtVWSRSFDdVMP*?rp}Qwy7|UF;faA zaMl)*tTJ%THTzGvg6+`ZrXGw{Vj;Rn#^Z&~Rp*qL#O?_fv%I5gRjQCFhtTx~7?^-# z=LrV-jMUmxT=}ahA#`INjgCjzkWgnRyfXu3pbblWA-H?%Y~Dq-t`S#Fa(zI`LQ~2q zOAt7)CW_J`n*we`X_o#Pw$O}MZK$AlB9)PSv}dI3LdaPXQLweGOIDxk6fN+vjG+>@ zHT3E@9PtaT5Xqr+{lRHuK+$Y8{q(>yErlYk)S*9{M0_|<%u%tSY@bm6`uNk!7biOm z>cd3GC+&(k6ve+CBGQMWbw<-q2bMUuCsMM>gvV#QJi&py;W0)lqYRkgtCZXc*we~8D@lHg6>BtiZ|XJuHqGQSZxv;q&1q^-3vA%5Xtv?2&5t1cUUMZ(yU67 zk20VKF;OQcW)EJqI2!rqc3+sSk3&h_VH~a zW?ckunnofvBqJDFI*wjQkR(CzXsxMz-Hage zlu|<|DH-vv9PrS7kUtz(vES2h%?E5fR>@JU`pmO>m~!sfzdLtfS~zFK(%c^7?DbOl zkxwjk5>$wdQ{Ba+4mA%u8S43JC7u)tmQIz$9z1!H5~7{tb$D;wRS3ifHnLJ-Cd!O; zDm0{_=ffPF5z>?tg9DP&XBNS8UX4UMk>ITAxoy1!~gJY-|aN=#-s!B_9XFcTE! zKDkzN$6{A4G+;QRHCoiuh|#IXTL?%+bP_eNW?`$7JZ=BE8W2wG(va#*9xzoUHdH;Q zhOTsGaDCuMQeBs2y81hP6=n(mE3$%RD!TbDjX|6UzRe4Ch0c79&~dyj#v^d;4tzR7 z0#_w+?DHVyauS7TgZGhLL}-b%7;I35w{R%af#W$(Gx^n-_oPGb$rUE?%%Rulv3`fE z7XAtn?JZ{Zc;H3lwyR+~Zb0Js0YcrBd`kQE4ebz=GCf19VOJtTQC;fw3U{vF^>IVT zvr+qBc!EEZ|33@9Vqv5I-;@83`PAm%fA9(W8Vl9_z1UC50dHcw}{n?bI*QlgZW5twK50T@{6^`b!lR$a@#r& zFq{{GpsBhgF_J(Q38+oeSL`DgZ_QI@oX+XAOe@k_2A9iI+0IG#bjk~22ZjNq5qC~R zUvJ3M^uChgune1K#bP2_2#HP_o#TH#V4x-m+zGtN?g?PN{7ufBdoHG-iIjjki!$5S z!648`|L_@$;iFiLeWI_Fe)ICMV0rL@?vxk9%)YBwMx6dg9U!_(mqhgWdN2~^DRCt% zbmW60&}{SJrr6Edgjv)u{~SjAb^9_q5{VSvlibm*(@v+=5>37#JLrKEH$Ss3FaDW@ z^0-Rw6iVu96?9rmAAOr2>H|YLe)oj*z%kF5klv;Z?eS;%SP&C7P@uGb!e5qo2OWf~GL zb$>@0ixz(mCAz&ti_Eo>^94UEZv+wI^shgT$Nul2mFL1GjJ<@zqYQ;k3Jf@5;t)m; zDLiY;SM7yhZ$_Ly$Yf#DVv+s5AP8D`94Ro(&tt|dj#{Gpfp#e>GNw3_Nc1Z@?ymGw zMJVKjUWsf+8DUZ(IApDxs2C*!<%3cJxAs_;rMgthJ5GsA7=F;m z=~hMBAZ@k=(z>^d-?}(!r*eQ}>k?ZpfSpd2A+9jsX=gm1hQ-ne8SDZ8_aYSE!P0mC zt%9G%3z8_nM40QKWFRx0}N8B4L=&-|1hfqZ} zN+cpP81I@J6IIfKJ*BlF@j%go_Dv(zTh)0-lzVhxx^Z;)ch}-3p5$93$`H?Tos7v} ziMbtDY4%f?0U0)&YE|WA)#mZl6xxI7TIIloD`jdyZ)ORTX!VIyh6=0eA@l(QpZ38& ztVOt`Pi$T~iJd{d3Hom@*v4n>O+hKUkNEE`VIplZjQQ}tRQ&J$kZC>r5$({|puRNv z9-)FNf+l150ngZrw0fwcrYs^_{u$=kUAMZ;++95SI4u`o@PjU zRHx0^3H!__&LWy-ejH+-)A<8k7v zfr9p}6T;a z?pT8+JW@FiYFg&ulTY?~-~65IzqYh+Ue^q9P&veao`Jdic$k)9TL&}J*VecZb^iWZ zDZM(`Y+DxewLk9BU3kAKB%b^z{QH|P1$?!2gcG2^>Da_y4&TWJ``&Vm07T}#jSAExEY|3?V$uYfU&NPmNW3jtu` zG-m^GTs_WycFc;3ku-xY9RpJn#Jy3w!q5_(Vu}U(7cBc2{d_qXJ-#V8-@DCtZlBgy z)vL=wPp|D`5gjvm_5D&M?lup+>lo?#9YUYy(1vve()L3;!3^5_&pd`eIWABrj|Q>a z2JlUiA+8@bC_c3IU^~)Qi9^wWbJ6i*jZ{hGZgC*w0{bw9*|G?-bf<|ca0@DI9*yUN zSQ^OB5J_XPvcIAWbf|#o$a8*J@g`Y^iuYE-?mFbCOOQU5b;%Xb2}}(t8nN2Cr?l^{ zW-K+YeNynhVG2}->`M@#L6zVe=fsn)YbXrhfaPM!^T334?5-BgWK@}UV*{1ZZTT+; zkc^Qu#>At|O_OtG);N^V1)gVOOr9&}s{WpP(#ifYUMW{@f!K+m67l)5IK*}wbCsbFmo^sy)TC^d7gV}3#H1<11v|eX z&5^?0v&#mS{p;HW(^r;^2*mC(x&zs(L>?9hJk;^tvytIyjN7qIbbX7vbm=|gyZ;cm zrY&)@@6ycs{D^+7a~b$@KH$Au4Ssta`J(LrvYg`sID1;teGvv<8VQxOyJy%^gia$x zOGz~Ze`3V6YJ&rAJ|`wu(CQ#lW8Rze3)?Deg2`Ox4gdG;i;dqicyr=r{Nf~q#Evcv zq~cX=7uTRLYNngS*y&OCLWuq9REpY>GJ#Yo>-5E`{5Fb_raK14T2sz5bAo7k|50+E zttgtnD=8ToV{7}xx#w=EzY^We)UJVLIk%h8R;!K=cHu7V&c+WBKuap|`xdGmVZH2@0 zWhN3@w{d(dzdvYeE;@V-Mwt{tM!6=luYbzJ|J+*`F31^{p;?=brYYs{!g4TGX-&y$ z80XB_CXr-+<*bc(a9thoph%BB>f;aBPf*Ztmqs3B2@S|YIQd~g9&|9mxpt!p!a zId1wb``xmXlSwF5jij!mh%!NVUY7)YC~2e|IYPPZj43^edGjPQf;s0LY9u2g2at+G zpK>kXnhdtQTE8S0X!=wkW>hJ$glTR^sUFKiB@uYpM|c0^Xl^GxJp8x53E%Qgu1e-q zLk_skccWwEEOpj7ia?tURlR*H6`Hh*{`NACC%5Z~reL`X&}jJ$8N(8wx85m^0 zoapd%-j`r(n)$zdBMkqHeZb1W_P-m}#UEPAzx}O0Nv%IQh0|aG|8K*(@Af|pYXZ4K z(}58qQ#*}I^oMu>`Q5&lV*2hnKKSnUXs`b_UC24#*ZlR@D_6G(@s)hRzb-wBU&d1W~YGCW6ajE*SxemMj=d%p0QjBhma}bt)eig{bwR zU4lcFObUQRL`*`(&GbcX2+H@F*zV%=L-iXA@9rnd1^yPz#@qCia4&#FOXU5|V<77+ zDHQ9Lg(NQpir9^2)+s8=9i}P$eP&Dc-FY-$>?6}b!0~GX&8X3=RRioF`xHiNwP%&8}TZvjwNM|vF8 zvhW%kOC=IUhEDmwjFT_6muD_m~)2##^yu+fi|^6Y`WX~5D#0f|jR zoNDQJDWXyCih_ht!2-yM@zHecSr(CBIHa<-%;s5^YWTUYvk3PGj>VNx@@(cAD>?PuWTUv;R8V<5+BE%y&8?^TQXwOZ>*l+Hf^t zIv4oB-n@Cay;knnc(mRl#9?!|BF^OOxkYID6ST48w5YHME(cmL<`}0A1@(DeiG%Sm z6Sbx>zGzt%qYT6m|Ep1&!z)x<{$Ue1QQkpv2 zY%6Kc;16z2_oNN*XS4X?9hhRVFjTuHczEofNV@{RD45RVU1+rd>UwA%>;X`*6BQbf zaC{I)@20Satx&8*u2LnjOA_OEN3^HaVf$PvA1#GkdBBb#!V(@48QtN>bsdOmF(8{Xy-zkah)gARZ|FEsd{13DcYHFVVE}vD^?-n0K{D=7 zlu%O8qg8CdFI0w^@bPP5bNO8-r0mIo6ZljrBhKYaMOKs9>9JhDHioF57r^^iGu`kItQ1~Xfk zosIUp@+9X)N?!B%4`f~%!)`(@RInY#e(I|OCN9O|#mj?%K1O?)V342YGk%*Ik#{p&Pd2wG+?s&P@~QZ z6wgI#12tO&wEH9eqTC%b1y90*a5OQ8@o5&m+y+|o;FCq~M7Ov(!L_1~)SW z&`&&udwTp%^rg4EDDRG&Ol9(;=|@v#TSWcV0Q=*1>7btt!;LUSkS_zP?R|O0Q?S^S zwt%M>z_`4LrW&eFM(0WxN$4fxOWVWbim^3g7V09nU%SxB=+UT)= zGm!;lb1lfC)-l4s#mC%ZrmLdZV?fe@(5vm9)pQATm-V=h|%~wacmV8A46W+Oez)ZO-R(+55w5=rJ?y%Gs@Y@T)?7tSee+F`3 zW%-Z0$>z^y=EpAj6G{F6WH7SJr+4vxGmg4Yd4#FjOL6bMQXSZf#O*0657uO@iTgB= zShBjWGYN`!hw;I1zruS3U#3IP`F1a!?LIm`zR-QVv421g|Bg7q%?1Bg#1T4dkS-7R zlrOJc)uJ&-sBakb%8lhN(lm*k&5Lmo(%z=s;9fe6=}>6BDRyG@j#;_N9=j^jraV*l z(6HVVVc?!Z7*sd?EW~Tp^`3Hlm})eNB3x>3>5A`l}~Z^x8ua}}e&0wpS*82HPgy8W;;9PP7ejGtz+ zr7K2qL_Fi_i%~{le@3K`W8|(UX57)}Lu*SBJ4JeTIs*qs0Wj61W#(Tk##5JxUlNqy z`X`(5{!f*muOjE62Knjt8}b3&#G+s0yt76MWV#2s{4!5`Z(l}7yu59}NIkGLHo)ZWsL(Ewa5&bKU z@I@2YqEM88G$5*m7kEP{OqoBCv@6RBrj7zXn$*A+j!_AE997W1jzZm{w)W}$G)EeX(HqpPiqTfFGc$H_L?1?Bi zaTH5O>@Xc#CH;73m=!rv5;I9tNkMe1H1)?#&aE7vmg|%f4+bmQ^iMk*3FKoaAqt~U zPNdK=Iqm6_R=vx9+fqRI4G}??Ha{9D|6U#ge^#X2&u@8D5pde%!Dk?0QJ{!F3D;XW zI=RshLJlD|SSJK4MwX$&NFtf=_gs6=jp^)K1VOq-UaDpDPqylv9lUl1$NpC-s?#RT z5%!p$!n{v&+AY?x_$HQf+VA_3W|_tIU;9!xB9#S8T}zD5!Py9w;|(;grTRn-O(<1C z0tOK@s`0HftXFs1xUTaf#x{TN2}Apfn%WM+H9$jC;CPPsfokA`0Tm3DG};@>fhdBf z+LI#97&Fc&Vv8?OX+~KRd;4L7Y{-S=P@YlB3d?_z@BrxX06w-k0qmQ#oKj=6t(2rK zJMZvAFic~m0kAO0QK=x+yui(^{j!g+Ug_lXj1?PBJk=Lb#l~#JLLY9(sqYm{*rbUG zk1jeY5X4|P={)U`VoEPkod z)!yNVOXEO7&YCHbT%Qzc%ORy~;}5&KqUcmCCBwBwMN_?}CkYh`%;xiOz{tl_ZPuS= zct|dLd(iUjzwP@aGAK;>-*RH)I!9#E5srF<$CzJ<>UKO$Qq3bi_S3xAK@=CS|2XDACv`H< zdXL5+$KqsKbuxKhNIM_GCE1dTjE<48byh6znoyx*ELk5k$ZwMNT7^o|yvjMfj#2xK zc*NsHfs0*r-B-S4ptdx;_$v^_9V>GSv@-D?;O@6La@mBbfR5-!dZn+Oc%tV4hrQw_)x&@stb5c&@6^sFmY2T}A;02-`=WxUPHN@2Ca!vJv zLT|wvSRQ1baRKjL4+Ft8;dH$PQH_@kKq(*F3S}v&&)?gvyiYBB9zaPNe+oNSfpjWo zFKeGaB(Pxg;Aj1M)wMSzCQs+acpBVJnUXo7DYrOQmE9|0$-LfOzwLvlwo?W~E!^GF zQhaGuPY>c+aA8A0gUVbgSt}1OtT*tS)$Va%lK@;f^wj?l0{0Mr0sN`icX`54!ORu) z))Ms`wrceE&H`E}SLC;pgnrGg-otN{D}{3*iWX06sG5_d`6ujZRjA`}&rOc%QpKEG6kr z(Sv51pDa!pRu%b`dL608{)rq3_%@wd`hBvT`|xc0_0je5)#CM5k&;{q(ZbD3N1i6o zo`rCtL>IfNtsejOxRiOtYk~DZyk2g0OpqkMmcUkfn_)a#*#}Q~R$V1jU zrFYugw-6eYu)U|@eQXYMdocL^psp$i2^h7W4AWwnHB+_(qEaG#C3rN`!XTC)1==r+ zf#QvPmAIB>`SM$0Z(~f8XuL9K580y7Eh{wi*oGF>8u-o&O7zY`iHuABg_zhBq#%*r zDjC7qE{6^M!2Z641BO5#(1l1SuIG~jeV|lsSMJC~U>QF>bxxv6Otkp=BpA8eSoGXV zI?rTIc(4i(O6Qh5z}LkY`EMwD964dTM4u*3vSO+MJ9u~nnCNU&U`PF8%!^tqJ9aO{ zv8a8Oef=t$D0CPno> zvkXb4S&I*oE@uer+gL%czKJlzU9$sz{K?Vxf~dJTYVOp<#0y0|JQch=6P1ycHwQE3 zc#h6ou(?1Z4WaxmmI~+kBW2HST3+_@A13@moLkdOP#{WbbVOK;nnV3-4f`FpxkUpf zt)qE&@+SVgB;3c&VM)(UVS_5bn1gFB3X5UQ7~+OXzSKo99l*HVe#<(&B3+q(*6LVg zC8np8wML+N9bgw@{vku1ITs#5CP>AQwS@Z~O0^Xf)Q?AXKx?V>g;k0rA{}tvFPCdX zZwLEuJmflUn5@nf6OWwk5Inu>(rf<3#n7u9*MJMx>28bzsXwJb1GswN*jTxrIaz6= z0rZUaVtlc<`VEP6qKxz*2d}<0WRGsZvnY;;0%_U3oIP?RZP2|-N?Ir39dH|Ci0Z(c zi7L^gr*=3e_Lrjk)P;~ob~y+4+OOCumg^RC@GP=o?myO`pnMZSa|?3|+^7hStAW|) znVO^IkPo(diZO;{aN`{Nj`6}ebrqI$pCD0tFz)uxMA1=hD@(!LNcvW*a>~@XiZtoS zVRf#S=JbO>Htj4j>?r{;%HWWtr(WcZK^>kOv;=E~R5}hKowy{|2~ETwY1M-Ub&?YW z+nOBAb9I)9gSkk;tQ-*ZYrhA18nV`euF2Hay&Jl=#>_U}u?jie{ad8xLM~EQlvPjX zsa)ni$<5JZ5Y#~*+`X2Jw=bqf_J8&sJ?3kMV6vxe*R@Ne_O=NK9C$>Ue#rgl;|xuZ z0i~vHkkc_(%k7duObwnD>RVif#^&Srt znN*V?Uv`O_Q#WSe6_*vc@Ax-$4MZjs!I5192vW_r5*?(*&C5j=XsK`f@r0Y<_ul7R z_D341@_mgo$_7Ff$zxlsEeW&pe|glsaF#{gFc>O6wEUNWDuii96IIAOS6BA8K)u*Qw&+zbiKrQg!dflY@qS-cK~_eFu2 zB|B7Hk&r;57eeB1>r1?^F);-?fkZKmK^=l%DDk5QaWKJC9Lm-efkZf_gw943F(@*d z@*c}9Z_J<#lPnNFDKj-$Qqt0RR=7^zDCF5CxvtMUUN-*;=znVu82=$Z;s0|G(wvMT zB17mprg#ID&U;Cv#v>$&chEGqQGh$Y^^oJZc-QT-RcbJA@7>4IjBu&Ma8;6jToeOT zo_H`cKz9CKDeCE;^l=9VTbag!1eDwYjef}YXMTcxmlDR(8&u8n) zVNE2MYd>s*2Z1!Ecgs6-;pdhFwA=7NlpV#KzjzP_yiuAjac zMw^1odmdzwctElug;7YDCQsI3E1)LU|Ldp4k=;3c^{wK})Xs-U7T@1$N){w;QDZBS z>@!S42jgCq;2m|&_~#={V~)92QFm|U0i}{Vn9Dt_v@O0lM%D|)jhZu{Js`{=3m6sz zmPF4QlDg${9$*BWWDdrm`4=wWte7gDBbKxjb3~QeRd^2wz9Ni4xN+!<*?b3Iv4qCp z;Zk2|*g}cMi-|kP>7z(2l8rjB>WjQqD}LW!0X?c+L?g!un9NvB;l?a-4HNIU%j{P^ zNag&nI4guj$rqj9Y@vXn9Qo3}Z(N20azUz@g=c<#r9RihCN^ezi*SY#lUqrz7pt^J zEYaw?79=0ew8f+PP-3W+vAZMU04Pj2^ZlIcnjjqkzKsqtPe*3yy1t0I`bVXgw5_0d_Y!vK=or_>&~rNc46& ziP&Z}8RwQnCZOr1fdOSaFTCKH=?||kL zqF)!59N7ufKrka;AzBcs57jhys1PM^J;OE|_r83j@v@>>k zgCO2wDDb6w0<7@w*>|-@m#31>OUQ^EpAAJrV$eCE(4)-Z5Cn3n_zU(Y;!9Xb`01Y) zfR9Azu>2=v(`fi&9Zp?{Z?J6`;MJq{)Nx=GrBEciw=ci45?v<<77o=oMs#4Xfp~`{ zoc&u=!H=(iOr}M4aj`Xy9uN@j1hD56AKT=qWll3fGsiOMfJMf$aM`Ptadb@`cHEZq zza9;?0w=E-5UAEfp35nom-9Io4L7|OVLZ+$Zd0M$R-?A`nsfg85PBGjcs7^jO5Sc& z?z0kBU-a`OPHcJ}2#jr2)pSf$XlFRU!S6+qP|0?y7Tfc75w&y+a=(di40CwOe$f7`dP@VYgZ4l0J?J z3VYzw&3Gu(B^w3f?m#FU4=J(!h~14FFw4;;cx{Y3O6%@@ER><*Zp8-mW$k^Sn47p% zht~!Ws8>OoZL0oqGvdu0yb0{l?+TjkiX+W#*h+7it?fOkwJ3+%4a{NgAltK+s=Y~- zFeo5q%c(QiR(CN+88l|7BPn#2T%&05+@*$yztxDaB%*>YrC=%=Xe`81>>UIS94+x` zBm38C)3lQE1l3NlXhf1eRLG(DLlQwyCU0~!k1O|TNLQE|o!abr4fZwQd6`Ruoi>Ru zlISqW<;_lI{#!F_KyJ`wz37S`G{Q*gs)HAf#Ml$o$4k=HgmNxhf|Y~XU#g`TVBvBL zm)iI`NuD%i&;PoqR&-Q(61Avlr}@VU*~majqw`=kN*a!6A!u44N7_ZXeq6-mnK*`U zhEPfDRO~UEjQ?ZocQ;7_2@5jC43#sP|lh^NIrnWRUM~?5iK<5-gkZB;eKR+y~6|hiN|~Q{^Y?fKMaK@886vIK-aPo#@CUHLgTFeBVt1X zh4%GMGbF)bI?yFgxe&rKFaVqepEG*qIisVIo z-t80TM89-m4Lyhkr6rMQs6EEQmmI^jl~sv*gWLl@eMscF=G z3ynKo23!KRWmz|a;VA-@UG8C5Y~dX^VH{5tWGi;Sv>ZAkIP~9;8KWr4H<0d1P5PHU z+2HZBc?pCcV*EVfR>->glUAqmeSfh@G^UxgeLSq?+)DO`h6fY*?dt@+l?)(x(+e#J z$k8tN_N+CaBfG-b*V`G54|D6r@(SVVF-_&}2M$KrpHm0I`6!0=OcY39&CH@b%X%eIU0t+g2?^}zx`b2cNdx0DTPpNTfZ?0B+< z5^@NZP2gXLSZJ=-pU>ar?;GsER{@U%EOJYi{;`s{zN8&(S2!PDdKcZEs2F@Jn{IZWyr9$E_v(q)mL&rk37>{q&l zyhNXDwg%$ZJV+RvgD2TN4Ogz`P=cP7l4#)VD7>oSmD7+NUA+eq$`!p0s9DCDNID+HWgmICcRzUZ z9}tDTjrZ^8lplgA^0PxOSA zl;?&Osy7wn&|}!QJLL*p-(I9@c;+^(eT=U9Iyr>)c6NH$&j5^k0@!qc zjg<_X`ZDsDxva8C(NRs+Ka}Vtc{1ZZZCuALa`y(l#nXzITehTqo@rNxMMMj z{O*d|TqX)jrAR+?u^QTXtEOmbBoiZc1xspCy{o+WLt_l+=uApacl1(loi&!OM(UZ- zZ?aDcH7ECNB>Gvj2QdS|dxVB$P*1=b4bSAAj)PVLsodI@?e<<%@Am9Q+cmM(;~ary zTmAVX27x~?iN{6R)0_!r9LvF2oUFL(O@{;2v3Yiih`lpvj{Epc$Ei%Bv!dYV+;%0iY<7Qpea-E%+@4%6h4X6 zb{8tdc=m)#V^`BIiQBO)R7B+JA6KpcdCsm?2gKI%9l=AFirA>B$y7@$kho{W2WwLY>m^tImiL~k=5hQ?6OhzWw>}UZe8c2KLV+5@jOf!32EwMSR zU?LF~W~0{EyS;~Zldc_7rb(^@1Vf_{vu8{^m5C_^o{EhPtQ48edPOzrCaJ2VkPHGW zNr9c3o429{G0N4fatj!Z{Q9VKa+$LpjR5obDv5^uYd-=vFYXmoE3Bv6!z(1yB`_c9 zecYFZm9-{TzjLIPnF7xZWL<0_MxRiZ$%fa&JVthbDC4SgmQy!H?91|>@iBTe>ReCo z(F#E7W~($+t_I-JNd$zs3J;@bI8A(HU0GCb;uT9t~aWP zxQr+ju%_aFYV=Vem`uIF#Oj>FN7+6{0uS!Z;AuW+fi0u~Abl_UQ*OS%XK~G{58Nq{ zJ*>p}16UXD5jtNF{_K6SIwxuwANOzB6%VYvQDFeEmB|ZaXXApEa-8*)WFl$S7Jq&Z z_O2G+(*MUB(0>PNVPW}S`v*fBGI0mw@ZC4Hw|L-2d9R6@9MQ~;^V_258p!!6zR!DlT=jY` zXv6hWu5|6P7YO~YWmO@}WL`Kwzvf@m+`dnqYOgn}UJi8i>_S{huBhznc`d5<$!8Cc z{*ht5>+TpTs27f?-j%DRHagOM>gpP8$DEdRK1nr=0s4s?7Q$WPRSXiH@YsFQ{>qenGCvK|5 zEMkf;AtPXB@vN|1VtMTa95zW|DLlbgzku842Hp6bT6(b>*UvihSsl!z~mW~>z-r#0zsmujV z0@+3~^J)nr&Ns_kAC|+qNZzm=fgQO#ty`FW%EQsQjIaKN1p_5403&OfPl%U@UPDv? za9=drYTTaFcX#iQ6Dm;}TrYBd16h?(^nxCth1tZRDI7Y^NGi>=R&c?*BsG@53{;eE z9G05}zhx7rRRH03-?BHyPPu$yJV!Ds#KE|ztYA{tG-c|JUUJV07BdXBz{XNa0mhaE z*cbEQFb*_3=T=h+O^YMb@Id@Gzsd&EtwC~4ui%d7)S5!e_P%^>r~B+-{rxvTCzc2^ z49=FLawFv$$}NdmolnyM4IA8KTS|Q~;m$;_*Q~+x*Jpg6@oJ9qHlumXV90 zn`7W35=pZs`I(5XT(2|VaiZ<${?DB|QUhB)!@6o}$_G+LQ|9xDshMuqpEXBd#T^>E zcNhGp!SWK-q@74bQ{W{#u_4orI*(stoQr|nAmco9bCqY+AxCww=GH^PB@x?=hW_F{ zjUv}j9eiPE{8BBbR`F#|^qs+-M>*J0Rjae#JoQq$_Y?`^zCf)CUfk3+bLr#NyNfaK zG_6{N^SJJ1d&hdg`x|vwv?p>w8062#ph_nn${p9sxuga`%x|pfW#F743(b_VYewwt zZp07DOkm+ZRTZZHif6;X&i21h`&YjboQ?mDPw=$pmZzT~?nG=&o=) z#sB!7LGS$b)z79$Kro2aHW8T951AN=6DuOrzpVYCU)KJ_1>ft1TUSr=OzlK1-9%WN z<=rF}{ltU|L!idN-z31##fgcd8M5h^zKMe&4mJOk5GM~`UJ0@@ifsmWFyr?g+_zsF z@Pr-RL@9USrCG8s2gfgS-$L;B)3=a8(z7Roc!iqIic%w#bTjS{GD7yL7zLG~BZz~q zecJ$JUHAqw3)0s%o+U>;64t)Ov=_lN4{{QX-8#;Y6(e`=wHV`1Jh?^tfl4ihn%M_r zTAx+nRp-c^DR`%&i_^mEiXfh$SR5dU3qDIm76tuIm@?v|2dti^31~IxniD-pB-#TV zj*?tiK-S{m?L#pt#ek~E6;4aZO_J#=T6rUS=aI^YqKH?x88gG21z_Q&(_$3O&W}+E zvI_m5AA@ChPRd%A`o% zw}>)1$cVa|$VuQied453@W?`|w|flb{W$VM2P;f0<}s*fAwSlf`?vA0lJsG;YKOf| z=y^)o3uZoy5xWswF5(Tx8=j!ElNYfW^p1sFG#bE|HAg6dOhwwHyy)sAj41}XW!C!- zUkPhS;uTf?nF^ts(fqpHDyiV42sE!R{MAW_qcS!Ue?&-9F_-MGcE)mHC?yv9Hp=f*CBopd@s zVDqz6qs?QzmET!ew%*#sL8?SXz5tg+$&4tgt9D#gdM<&91Q{e#t_|Cizwp zpB5q%M<~;1fEiq^S>cpwy{LMt^(H7~+I|!NNctXVAUG&bxzx4#*HY)p4=1W!i)LHZ z3yk^up=&B?IjLEN-5}(sZslrE&CJxB#fd*uBZid5XD_>g}|Km@!~mWgj0@bBE*iIEa?4ZIFY@gj(c(m|KpqC{<-z z=J@y{Zstk`x4fJrdNmG}U6M*oj`y}|uoZ)+|+LUGzv8U`Pz z50C!*TIW|r%&TQD=Fq{UGHa?Zko(dhS*AZqTwXUhx8gv&AGY}MpuK;Rw|`?ZMXx`_ z#eaSn&U{AJTjzNa&8Bg!J~Bz#wE_4wmjkoHw5wspGt5Wt(?}08s28m_ss>}bT%|Vq z0O~;GcQIC9G}?j8CwKQFAG1W6=h(k9Yk+M)DCLB8CY$0IbpIYIwlTYu3*)7RF!`iI z_jD1NdC1APYw{^K*Q960)+yOX6Wa7EweD;3j{oHzE$PQ# z`*1Q;F`>NUq#{yCY6_oxacQq9E;e*+c~Y8q9~*8q8P4c{Fiw03H%N6WHO`I-aJ*4z%!`EZTEcE!gVRYDIa-p$gP4jt`Li3(a%2 zPWo55Pq(xB$sr zf4hctXWHh*_v)^u#b*e|{u18j3e{yz_>$GWvt%h|W5J5)Ip(&7smaVgkSwahrN?$* zOk@O^&6r2OkCH{w;6~%zo071@%lq&kU(uarAs_9j1ImZP-IK1@?=To^yY|wcKw5d2K9~C z+x2td_jUdAJ(jCS+uNn%`z@o3?F2e`bmhtrDB;$QslR+Wv2lL_b)woUJMU-N->#us zs~Gt6hv{TL+X*FS_v6;;-Uwi1UI{yl>5ILt4bv}V%ukYU-2UgpT;%TiePshL2VVz) zn4O+ML(Yy^G@}iIHUjJY%t3ML4|_@Ugi~}S#QjE*oj7@q5F;{vgzs1S_AuFnhGucL zM^?;1yhNk$_U;%qCv1f0Ts2KNvGsL*Wg{r<`msLX zT}o3gBV2dL8**y}9BqUMQrF3o*UnI)cxx~&%L^D8w{zsQEX+TU`jXe^>T>}Y&pP|O z8ng2HBz71uL~o*SKgRK9Ud>U?#Q+Nv*JeuzNlwa^Ppzc2 zADNTiNq~gc;5ZZXos>Xq{<+hi1LgxJmsa#$%i5lbKRe*<;kO+N&5rEH_T8wb^1`gF zXzg_iZa0+n%>(#L&i3}`@G7k3uQv>0N{3zkE285^gvRQcph(4%f;PF6aGY1{O6Dgs zyZ^@yxgJOy{rKi&f85+#^CxA%Tjo8_5OJEG>V_tL8cj?kulD{A`Jf4{T8kCM?qnKe z3TNgF8-zO1i{dLyp|vg}d`Xcp@ti^;nK#V-KiP4Wqg}&V+d@ksVl}0|&e`P6<=iGA z$=t1Hg44ea*j-)+H`8SIOB9$e5q-+3;SfEl#W4m0&isO68KQj7;dU!0!-V^!_;H$K ziX(14vMaf_q?~ilGUfi{xHJKPCAzL(%f}$Y}Jx<>B9)S|u2-q6sELC{-7Y)zai8_ran{_Pn>9zzi z7+4phb=$;fNcNHn$cwHI^C%~E#jV2?r`cAf;bohxFW?tpD+m;?>`mrnb?R@sIi2Jnc*nu;{@^jcHnrRqE#t|Z z**lt^8iPv%Of;Pzh_C3hNg9M*>}HmWX-ZSsz{QoJp?7PX5sqy_6vRvqVxMJf&>&Lo zMclO)%#G2E)9-Z2#&aPwiN@Px)sLC1iM6L`mg?OcoM4)DBDeV09#AB8*mc{0VBfRU zuznZ{pt}iG0$j`S{;k+?uRIu$l=peWfS{}(TP!lpCsrJpfhgASjjYfxs2S1aT+Nf>T}rWfmr;QnicC(aM-{cd+-M%--@3n)oZ>F?{Bf% z8eO*@=Ug_mn!u$N2fUE)IYih9_o?{PKHd!KFc?W1wnbG2s7i?O=(4n%mM6O&8Oprv zUCp+UD8cJ{&#U{)o1@m4n4^RVFFf#;Al_swntJU#@zgEGl4UU~<2|JgD#`j7r)x%s z;=5I>>j3%-0e6J~OwN%pHINclv#$Y*h)RO7krWS+m#!iVl4ftm0rO~+u;q-~`lsEB zB~C5^?V_mxnVxnr#~`n=_L~x_tyym@Lev?iMiEnvcUML0lpLzTfBlMS^aRYma=S`9 zBXgTPZ!EjnN}zSzyb-Q7)&{;6Zs&dB&ii{Q#tGIosHddoA$Kpre;DfMdFLCRikv8e z-5AcEq_Lt{n5y?-CNzWnfZ%S##8!{kK(BeSp->;6P zUvt1i{X$k_PmpQ%POikk^<}~3Wjkb}jDQIK)K?}ec&e(2N3J6+zuK*01`NT}p%0x) z=P8HRNqKiU6Lr{M1>5*>OD-5`=O(PO_fVD3Vvlp)LUj+$?~zH_IfeR)=?9^6T4gU@ zdd~ZJ=_o_-jbE*j)8C&wM*!0HbFVZV-D?ti(@KS;33{c32udK)rV2juQBS)3D~jU* z4I*Zfr#$po>88>@ExN0utAm)~J+H6JjvV*kL$KhWI$NRUy0V zjn@&3<~KE0)oN8S;l-^NS}KLm+*mI;3V5yzhGzvl(5SNMJHCx(n_d>-JokbJoPhoT z0bo;uekpE-j-%@tqLt}^&lMV1PSDnyEHp}yF_UIpE=%yN%PR_B2H|NhReE(}(sK4T z85rdnH?pB_Hcq7%!XYC?czvF7` z*lII_*uqS09(hAZ)+X5F>ry(~5Xd}Tj$E3OS*fe>5w*>O*3Dm(;Q&TS1)GHqenZ- zlK{>Z{JPka?QAFZ`T7H6IGzSvWmy^N9+cAqf$bU}N>)vJ+XEkI;0$BP^Pif8taR_W zDP`*+WVi($i%WR8a}3^=_2tMXX;48xKW~c*NPjI+O)U9O3+Eas*W!s-!I#m-oc%n z%9+&j1vL#9mr?<>)cpA_TW76o=CocFm$M&lBWWimmt(_d33|1ew6+|%0u)o_G_G?? z(J38Yro!r^`7I55rfu`&U^YI>BK^E}@~8)_vt$3cLUv2H$~|b4;eY%G%t^#YOA>j+ zYo+~hPba;!e#&~ZOTQV$!=A_*&gQP;3@~B4ADFg_HDAOH_xgz7-B0QgGZ>5>YjlX!1tAYDh}SIr`Zg2ql`(eQHLIPNVHwyj#kUJ@cjPjMz0@kPK-h?~YnqMoIlDrLMw!`e<`}9aH0m@QqcmmsxSi8}m~FM)5rR zzZ@S@sG2%5b@r?y(Z*JL?~f`Z&ixuThFkcni`noJ%53XXqBiD6L^EW6AT=wK->dfSzXQ^V5PP^967?cf(jTqTqbY>HaYdeQA-vYOcLCg+G}-gsRkKb-8}Yu>tD+0iE->iL{a+Kj}o;CM;{GuN^!hb z7A4$NPFI2wU*dqCyIfuB;6j!=Wq0jWpshiYoZYT2G&bzvsXY*EDO8N+q`XRiF#Ex~f)@#at=MYAz9;T4K?0{fyF3XE$dSxcT|ziIp?L!1Ss>i1 zH&J^%f8%3tL)M2$v_9FOO(z` zvJT;`)YW8c;{x@N5gQFyV$aPNj=hcJpRXlb&W-lWjgllyi?xmDTwV3bxzdlV#!^>C*S0!u=RH1* zIodHkJC97hB`eL9-Gg?>blzAz1Sj@0eb03vgwBi38YAI3xX0&ThrMmTz))_KD*rN1 z_RqE9Y6;M!QCrV@I$usdB;IU%PTX^H_;e`39Pw~Xbv*lRoU6-M5bC?VeB%?)f{ps& z*_u4UDm)FG6P@$A!zXv;;zCcjcJT_#7UsGnuG-^*lzwHRyw6YY;;bNmK)!t-1YjPk zZI@U`2zhfkXBpxq-Fu+Cq}gl!b46AqporXYC>tvEbX=h=N^ZO_x(yk1gqqnx)h zmEK*{#sF{9Z$kMs?u{|@5A`oHb+TbdI!zk#)_7phNS1(I_U zU;)%$o6i=^uaN<5#bH4O?cpc$T;Tjj410tL7`fWPNb48AaT{My`mr7n+xa7G*8err z`5W23c60km`u4r@eLMYa+}(h&pwq4o_Cy)|^E=gtHoM}^W~fd=JFWJ$pR%OdbePS( zDFd9U_puyKutmK~w!HSfBiR??irwtvZYJS#sa~Yp8RomgC?swUtiROtOmd5U{fpnS z3gf&Hx9M)G)5?T9RziivT57Vby}aM2ef0VHo#6eT)ngs-Bmw_++MY9TGh1Xh*YmrQ zSSS2PIvd>HO6G+#=LtR47j|88uj0>WX0!_VfN$6w#^cV(wdc`Jm=>(SY`*@bE>#PQ~Hw`^V2{h zvB)B3*N{mX;k5nfj0K(k#zFkZxBABcWLeHa1u^Ps$d4zt8#P zD`7b+0KFPz{>qEDO}vhL`NzYk>=Rf4K&-SsBB;j(Th?8S9XO>Y(5FFW-{d3I-Nh;9 z47WM&WH--JL$K7>E%EJtKx-08x-2#SA+VN7+VQAH_&!i7GmAc!lu}f0(as(iru%fs zEXb?Z%eYIWhc$>(4Dx9~W;iYsLGt9U(^?-Q?EGca*B0AJ4o>cbyte@@7Nl|7o(PRA zNfgn+Se7LcXKNVq5558FLp>N5Al0aaTWYQ1k0+t^Q{>-!6a4K*L?~=IkzjI}F-Bv}cw_!j!f#CpcOBBB%=un4M14LQWbR$|TV4rzWo} zN`{iKmV6WKwx-o1RafCRuoi-di4iGand^$jM?$v@sa?0$Kr6$DPnQm~)^O)jE{PbI z%rZ?odZ&to0=jIb`G<%jvERq8ovx)Dn*p)*rIheSrMcmJRVCK2EnBWbj?xGL&)}8M zagMC&sqn3XL2)&FuZ1E?PlHuQaw?1~Bwdl?9bl;-e!t*O90+c3n_p(p|LvV5>%!3OI{p zT4hUi@eT5~F;Id)DLy%zMn=z&k^%7;tMk_!p2o$LJu*B@zb%w#7ElnF2p(YOyJ-vM z4_%+Z^5vr!L!GIY&|a^I3tF;R<;Ef$NTFl`LG>f0?L^=1QU_f&f1ub{)-PqZzDJ*7ZIlGMP5z>@LQPAr}h3kHq1oD6U=|BZz6 zHz|hE)ro<-I%QEYp?h~mF<<5Skh7~ATaZPO*KJU_7r<0w$yQ@yG6`Y!PpjRTZ5He^ z&B-;azb;c@94J4_8w-t*lu4@^2$*Sm*=lN9dGE9pEay%s(&gspIOEXLSl32t-`YF? zyHYnVfWi+CzF9%qqD#V}6HnE0VpF76oBtU`?h_*_WpZ&2u7^OSHW`Mx|7%SkX%1SB zGgwBPr^&Vk*FV-F>r->ti{CC7*eT@ijB*B(y!~T3$)3@rceI6pc+n=xAo*F z<;WXgvnAtg=JJa7eI%<6g-mNS0kYc|2&{u$f7g(Mza$D}5o2SAlA0DKv<E6|J9rPcNJMo?7JN(48#JNDJU6(Z{F%&g$oM*WY-|!ctc) zG_SX&rvg9|6%sSQ=sDNxyF`iDoY*Y*&#rly830x9HVkr2r>cCUw*fxtw`WjxQnECg z)mK{%n+d)-_cNP1xDgNcS+ND)%5eX0lemOfca!_R@Rbwo@zmUJU`9b?-T%}zG5>c! zDP~s2{~IWEq`?*UOF+GTp!x(GPAFdiN0&zU)wo{!Uj-tcJYB0$T>r2k=p}M5cb(Xa z)LE_mrHFhN_f2LVd@;b3{>}^qf7^k+`8jUodw8ne?1k&?hUxv@3u7(;FmV5vOeEsR zbOjtn|GaJa^r0v9XJ9}-`1_d^oxc6h$#u=`{>kZJg-Q>rK0ZCn?+g2ieKg=!*u9%g z=Or?8m)qLgP~T~RndCQ|=LN>g7T`U#GJN~ZVed`8eEr5XZm5^0fp>nN)I?*_^shQH zVxpUXB3OTfnIcfsxxkma@J|bRwNP};B%@9ezRnGr{3w&tS>&WhQPsqXqJ!GUP2*e` zCfZA|0h(~H-<&aO*ERa9i^C?qM?VvbHnkR57&`E$bm&QX7OBC?nNLr-OsfD6cZrXer*<`)R8jYpgvC zw&h8evmdPlV`=JA%m)+($u&_Z9i8#l{gZB+4U$k9!X2S_)G+J#te{L}F64Vqh-Jk>(eWR*w;6!_Z$rdbQPez9BN4y+6Elg#Xaz;ASAJrOTRu*aXYml5Di)E zGPbZKSEx;kk4d=xFa&?-tt#Y#bFjPqxBNB!zz_GeelGDVOTZkuc#=NeI2OkHns2S} z;Ja2sKyV3>GHV4l$yULR=1fP4J;SC|%tg_)RUA}o6_Zh~Xc?2~hn5y*9!757!E*HOvED>2E8{IXO zJftl)pc6n8_@!2o)NwrSQjI>nFq^0+vkhtDlk6pgOn{hHGjbhrr%nU+GPLcxD@%uu zQ3zMHNaa+XY)SRcpRD$nKVD@~nV3-|$#+O^277|F<#VA96MXYP1@^S4HFATbCnFTW z)^2f5Qi#99@cC22GeKiJ5}NFJsA{I=x8nL}8gVYk@+)f-7kkq7_7-wNL=lJbXizCI zs2Z)gnEuct=(!=;iEC!;;84J;ijXe2K(1z8mZ-!@g#quYau|6vHB9|r6a&fKYq(0- z4t}fA82!Vmi2^38qqXf-5E57+V?oA{0m(QN6eX%qhLcXqxD==KtUN}3<|mF3>$n1N zD0Y|ih?Nz)tHbGFpEcq>3+g3xs$vbq&S3hzIyA%_s)(HdXUWM8{~HFV3DG+OuHGg| z9a1UD0Al6r930hV(#6+~eKiwTjeP9feY(zu_V+<|6~p}KWVt>FjscJ@Sp?JG zYfVe{N2xym6ny?D|MBnt-%*y>8Cd`CzyFeEd+aZx;#U;-1uT<5tqViVO0SP$PpZ!} z*gqXRoB;ggx4*B@mEm(G$p~$chnqOnp@&m=wn0o9>-W!?%Kw5z?vk;*pR?4BdAU*Nr45RK)JHT;hy zz7x!0E1rnP2m^#y>n&>qziU4(OzJk1<=fa(XkKKWhT$a-g=n9HTNmm3;wbK{ zHT4WC0;YPkPP!3E8a<(?<()&j^vh*5eEFFo5>;Xza#WRTo(DxHx=9gdv{g`3c0Hce zlBhO;b^b1ZbzinRrmZ0#X7kA{v(wM3xKu9Jr5MM8*~w8LHzI>U{2x1av>Rm?DtG{ ztjEyIRU$i6uzguHCw;8xc$rW|ivB|ZI(QIfy)|GST9TZH;Ix0c`r@{fqno7OWn%%$)iX=ld7CI4k6eoUQlnomrRB2())v)1JLh|+j@DF4%%{W>i>)dWQfaRV zBh~8?A}Z=37^SP%5aqZARY>9*Wps8!lY5zVhm|8=+;1C69#Za-NF=g9L_)*vcRy^G z5m0=pxBp`DH;JQI)2S3Dr~=Gc-`gpb96Q`5n8rQSf;ar@wK1~5>XYU=psedt&jTid zV%d6n=PG%~*GW=fw`?;rr#!3u2_!tC76q9*p$!6!zIERk7nNf#xLC~8{*iA#0&DOI z>eXd92%OO@3Zx*3n!Cfj4**G-?{q&*e?>g0{XX%b3$YzHJ%FueSF2g zbTY(FzYYfm)#S^ft-|0egx3ID)nR2}*16%d3kh%NHaJ0@uBcvaIwKvFqLa4lYJ}aT z!Hxrj)ZMA_4O1vqh+4U}n+_{XE4{{uu3hFvnSnFyi7-F0s(R!w;qN~?Np0dA<-kW( z9O;tDS(Xv;&{07BrEPDnaMK^u(bWM;8Q!8N0iy&56faQuY_Q_KURSa%m`iAMW=aLS zf~gCQG~ptZaSzKWH7Wkm0iS$Ok^OG4Xnj9Iu7)elGwN7(esj^o2`?#BLzuNwIK?i>b9CI zT^Dt@9gDbbikYH*v`MYe_=C$t!Vo0nDy=@2!rav}_w<1AW${zvqJpkW^9MO*3_G>} z5eXHuB~vNN2kw&V#o%4rYSwW$b)5I0{!)KEqWMy>&YB4)M~*TmSIvjxx&9wTCxRN9 z^^}1G}+6UedEPg&+zAP#-D%8dJMeXV&Yeo6LE%APv zvty3)cyFByo(h4X!Uj*Ku0Yd}P%M)pa61*C7Eb`w{nMPEQjutqs>1AIbw;x8CvRQ$ zi?f4V`YxxC?JI>;Gme7HNc>vZrscx<8tWHDsrQa~1r&>1RiusBwZn<_{W3|iT>AY# zgUqcpEzO^C|MED2ZEcR^iOVJqpcE*ud9_})1{77@nz~0u1n)dhi$S1q9A0(?F}Y>d z99jF)1EOtOUjbWtjwa}SfbKU0E&pSE{jV5M3>*yqfBpCWVL%=K4+Cnb7*HS#z`=hL z`V{prevY5_X!oZ#*vsKUM(PsXRY;L7lY04CSLNaUija2m3kePQny;7p=ivK&OGj^F z#x7Mamo}GoVqyRl=KcQBaV`+UhE5IUy0n9P>&JT+oA?Ag>*DB+ve?v0%771HAGPE5*jBPh-(FX1`rO*&sr6d0*}mIjOcv9@#S$sS#WC`Jt51}# zf^mU1BWN`i^02d)?6h)~cO{K<3kzpx5{opKy9ErfjHBT9G{%5E6T7w)|F(9&6R(sLy&Qpzlh^#LUNbq3k&>93d^2Ts9rjw{_GSeqOCPQ|g3lWCA7EsMQT_ z2e;%nSoG>e>jlJ6&lF{?<1wpikRSw?@o+DIGE5ui5LT^#bS9Gg?Neo=5*hD&D5h)0 z6mevr`*(^}L;WF_=t0Fl=lKxr&R{tQBok?0_Ad8jZ|t@I*rSle*oD7BQN`4Qw6xG9 zY(U~N{v8`@o+3>3%6E+7Ym9v$=7zpFHw&el)`lZeV&Pa;5R@?=<_t2D5oeNS!nv&jOjm;(c@N|-J&zKSxPu}3NT)nU<+r;PPM(j}vVO+chUISq!>tW28f5>Ql zC;$yyEbl;k3X%TQAHc3KBiz^FnT@_s>ij%Aza@S^u%D6ngOC=D5fGIbSCj9ktmgwk zxS0wh=fGnm{jOv93xz}rRM!YB);tlQk(KXDryx$3iD`vHplB^(vP(mT3DVp}vSXXG z3pfRDU?>BaX=b)6)7hlAb|AWk%89&1?hOwSGipL*;!xytU30v13Q(0~kO>@Gwi2eM z?i;iQwgm#1sbas#VW& zTo;-wN+ys<=M^wMue8cg zdqzMdg%kMHWaXL|J$|TaY{X0DIC?&>OZo{EsV;YbI#5&j*;45$83+C}gG(wtgoa;c zAU3e3jH^ND(LJBON8nE}PyhQ&oEMw&l7`#T=$@%f9`ymD5V^Wp*^UtT&+H?_egh({ zkW9=J?XF)(R9arWSpo4M`agAV-A0>?Ly~v~;4DU2qw#FT^Qw8*|Co6$^Ix`xd+UXB$^jQB zsSX8nS@i$*Sh44JW)>52(BN&@d`n;4Qgqp{esmNWr0?I;a0ETZ_qd;A=h|ERWdOXK0g~bw zkClPXHKE$f;f9Z;z@(JcuP{oRefq;@Ox2R-AvPMj%N=yp%HQG`%E$+7j0e=<6#vEh znu1}jrKq;EHX=LYS%89%F789Q&{Nadn_$pu^;~#qPkBHAE4}9%Gw(vHnxV|)G4m(4 zG1k{i=QvoT4*pyDnX^jf!pCwr$%^#dgIN+jc6p?c|AV+fL`}fAr}7db|hk zKG~=HWZ!e$Ypr=rU1k{ONEyiY?bF;VndErXV-VAm?nAL{x@KH?l;Z^eXm8G(I7dg; z>Ei^Eqy)IP#aYhM#!IzH7OuB>OqUY-8suqzfI0qQthl`9MVq&zL`K&9R1cDVU~v=0 z`4kXx?tPr0@B3w21pgvKEgD$$D*+rFBC+YjpqlfsC7YZ)jtJzSyN^yGjfc*mufws$n7fx>O~ZAd4OEo7lxn7A~EV%<WeSrR1}k z?`U(!lrZ>>T8u=%;oyMk$D7j*>z`;x@ z6R9g*9G&-DBy#Z@k%P!GUO!&q7$}f@asfTsGphTVbU?}Hy%4@$2_goRw=Tee&aeVw zTTtQ1`wWFinu0Y;E%2o`Eeqy&f__6vDc^EKbs-EX39QIjhY)m=aquIupkR@iM8Fv) zdKYPM(Ni+Ldb>Q>mKBiUbe<*<#rh<|By}+3@;HP#)wn%ufIYav|l~6VgjznbIFyr0o*v*7h)}_)xpUi64gWLpx2pNE4DaHTNIG9K-T3 z)jMj^lC?6CouXh=SVvz{Igv4B#lS=bosF(XARa*`9dIlxy^X;k{KK3G=y7rQl}jCN zR>@qk3>AkAnx0+gO;wJF8S#8gv&jRZS;mbZl@|_H`Uli_$jeT|s3cm`i8H43*Ab~V zL2M^@rVW&JuxpuKFP(C- zQ~+CYsbY$=eocPT8(*NIl_cnb+d*`)QJ*#Cp#a;SQ@S_zf+$;CT=2X{e?D^x-3rr2 zNjr4ZLR}WL3CMLin?nt;dpQICSF)8zK$@e+$|H_D_!w2!npGv@ujv5FjoqFf#PH|p zc+Li6Z=m?#_KpUAOC^3^OD^y>S)#Puq3qT0GXtW!>fj`FHogo$H!F)b!LA-8#09D? zUdyR=GhQXdg$*;&-;=qfEfaPy9IP)Dt$lR(0tsQCv1j$Ya01(Ayp6HWPpNpiHyAKj zBAyy*l^efssWuZ0dB8wvI&&@w%`ZrfpL(0cxso#_bTy)j+u>3d!NA~3BT8XrZh}Z0 zJ8A}e^Zdf3y{s8Ti8ZULZho+*1Ts|Umy`-gD=U+6E;kth;?`6b?G$kofecYSeOW+b z=;(})sm^`YwSvgVkS}+l0xOc5ZHZ{jwDRPmUTA*z`Aq)$054rH=ZCBR`?-%$!(Y#p zJWu1!&w7M~@pR;V%8YZzdpbvJi&rYz8^=J~>>)|RKU)OCP9Z{2cZYo{{X<;<(xtY? zTjFh&$|$j`Vznc{>0u$aO9^g>i44lV9OO0{c(@mdvF&;omJX>i{j|Wky{w!#x+r*) zhSXtUKX$g7Sv^o%Yd_F2q zFk&&(!6roA-_Lf}F(76bJy1CYlpKpC(S-6jMbz>BotTO>fU=JHGKa8Q{gMOWg>|v| zx3Tx(*-PFHm3wV$A~jwfI!E~5w*2(tn_uSF4nOzur=gOB>IU?%2Mc=}fkZ}Xab(2uVa zt?N#->mu^ELwa_L)!{it79ZNa5Ib8{*bFay4veh*AD@!yftqBlK-bWNTR?o2Bmo6i zMPz|GvnN3$<+eBQNb!zx`?}wErii$PhFAtqfkbZzMDbaI>#9iOtJg#k@1o&0Q6S%P z#AU7!x35E9!Z;GC*bD-)GGfo;z;Z9q4#)WArBpP9e1fH9X-|%Ny@PT4FJLL8AEf`N zzyAsl#rXaFzwPM@&Hv++c?Pj^Hb+7H1!;i&KLF)qv5N$RZ-BDKAQc_$qsXGhP?Yg9 zR%800mOihV^lpZNP_dsBXx68+<7Yabk4z2y!AHjP9mS?kEs@-;HGNFvwH354I(H4A z9cB0%kf>xuYkIBpN>L=aq=)Zn##ZYTKSxPf*L5IkbKeSa%!EJjbb3u%>R3SX{h3AiEU z1vx7}O?5s2ZTToQwX2luETgXga8m|K8c02i?zj@hMlzsCsqKEacqFT4HXg^)>5f7x z4M%-6j6u|R83G!!4nm8dpcl_ot{pBIFvi(E0ar(N;_65OWX-;u4#@h!P$O~NPQF3y z$x(q5owcSqLSMPdm*X6s3}}bou0>fqvc2crT1i+zsoaex{WalolxWQ?YNs<)t>@H< zC;%hMZtPs$YA_%&Ha?#am#8H=Mnhd@AhFG8rH@ialr5r}?qDNCSnEj6BdmZPheob@ zj09+9SUdJPARMPzD9nfOxhd|!X3->DS;t7_Iqgsd$G+Wz241Dfi}7@}s4S7sD4hRX z*(aK|AzL~=b8!Edf8~Ntn_<9YuUQ6Bw4r>@>;%uJ^0TXBecBbC}GuUMNEdNj{F8a(ofiH!x`Kcw|nvAm;J;p)pc<4$4x?CJ*i4vh* zhtB=Fay_l{JH}KFtnx&9>)B$=Pyc8%qY@XfPCwPdVs3ObuGf zRO$MzU&cY!NjEe^yipyj83rvz4qGDx6GVn+l&+P$hAec}2DGf}*8wbOxHEeI3GQj4 zx*=OY>z`uWRPnQ5(L1@{qWTj|$(y*r)L+QHBbJZ0d^zg z4Pn;K1}Do7B|7xkP}DexI4ZI>@fBv)goDxGD3t8$52N~8w$W2>hC!r+{jvU0QWjs) zX-ocT_)Y>F9(=sJ-p{e$8N4W8M#dGRM@P6qwu|g-ItviCKQ`4M_D}^7mM^jo8Jpr5 z%6mhqCwsS!-91@1{4Vjsw+W0ad2-p{|7d>8F^C)T2cXs4FWIs15r4xjOr{l>ah6JPp_@sE$PB9(o^$O zE;5VV>9!a(V8(KyFJpi}@dqr+-IpVf*iF_d(6^7;19FjsFndWpdr6iRr%) zu66Bm=lL|}Cyr{G>t9>Jz!Bo?wr*bDC>z{P-TvkMWy)YOTjY#4*YYyxeSUmC?OzoocaAQZ7$K~8U| z*ZAAbHhSeB#LW?HTuETQq!l*h%lr-JH#xA_2Iy|OH9uP4ftwiw8_`b!=&~@5Vp)0E z628ARvJGRUa9XB`Kw2KCU|9=X_m{`;e9AE6%JP5JQ-+pKy{Ql~ptb>&vRsByO{>>c zw-zueBusi)(GIdr0ZuTW0(ZX|AA&VR&Y$xiGHqn8j;%fO52MyIFArEJ%};qXlUfZ% zpkY`5BSE|2u^pqdf4ld!-?BAOw0~+tuQA=O^c}r01@g*TGf|}jms#dF*pQKJs5-Ab zA<=07u3j84qcwoW?Eg5KT{NlA^T%LN`e-U?nXM|M&d+FgxtnJq74DM_#ieVf7*~!k zBvix1b4_9>Nr|rUt+5}?0SiyC&Vq`9k6h~6ytacd*CV6BrppwrH)#dhQI#$^kiN6M zw&9{gtxpI!F{XBd@q}tUdQTO+E`r1ZuZ%jTB`zD-VOO09D4MIPCX`~@@iV^VuGS32 z5$(5|>W%eNT1EG)il#IEav4=rg7u)CD&>0nQ#8_}!EZD%nMB$tg7hb?Ih%yd`%Mw> znD1!;Xil1-#;j$G;523Cz;~_xYlp?%AGI((Bt?P>r$rq<80yAhaMX#L&V2IsbJR!W zP`{~wqNvn0yUyat%xXB%;x*m=1@*}`6-_z_b7qgKC(;tw71y~5a+x^Uo+Qpe=s*r@K8sf zFitfof*h$_FHF``p4Qkz%Z2L0@fyTlPO}Giq(8(&zoJb`-Ks<|sSFTZ_U@^E>E+-i z;wVY|Ijh@EA&KjP8WNQx%HX<{h|xgjQ(2_6Abs)$nqOSg*iefjAE#(dw1I-C!ZEe? zsCobq1x5Q?fox^C-txF2*H0S#ScyQ&cDGKaR59j+p3o!n^5s33OUc3)2SG_TiNTDn#+n#@q33^s3R$C!Va{*jn|RspGyvr-&l&`S@d5V&H@q7EMM z&xEFFg6ceT%&O*9yh}?{!V5NYbputMk0U_9iJHv2kY96Ce9X`#G*W_PpybE*>5gS= zOGcy@cC=_76!bTDE~nRep4qwk;`YsaIKaY9fi?lh*+*rdA&gFt&5{oO4ac~cGR{YY z?aGP79gb8XnpRPHo^}$usYwB(0LjFGjY4gb-C{8dNdEpK-}N$7WK2Y~bPD;p;9(X;oxe}>PAa|V-58dA;QMTF12vmeG?+@i>tp^`_> zNL)v>p{6DABU~4yS&`hf91!D~lR0DTWU-D6Ezcy6N9(c3r3h`d)Fn&3HO4ug&M1|- zIrJVS*V|GWoqpgKyvbjk50k&9Ph8IW{K>9hxR!#n%?~^8QlwE9DMz8`g@@!ctD@Ib zK@YtH-uN@Gn-+xDstQYtQnPFukD>IJz2ImS@lL|z)^ClLx0M}1jzkG5e z+u(?+h$l@rc0W=5AevkAM4GRWoTDFvgqBn}Ir&y&_S8(gd&MNeT-1@#a6xw6o> zy-9_gB|T|jXlP;TjGX=a>fkBJYMIh`&3ZJzly2#y%Vu4R~z6iI65W>=dDrTMsd zrl9RC`ij-toh*Bhpd{fd`+nZgYxyG@1+Y6zJ+42KIMi3@~3Rl3IwAo<&{Uug~ z_Cuv6S`)b==~w@;#@f7BUWUgHCj>&Rp;!^_^bD6oJ7qu z(G>X&TeXRmNh!opu4{D|%g|Li=Z}672`zGBPUbq)P!(J6YOj|^K)1*e)j!f>*!~?o zhLQ8XsjS~c_ZkOc=d}7U#Ka%bItt(b1P~IC30i;qUK}m8OlA0&ukl)q^#=F2i^2r> zHn3*O#m7@s$CFF15-v<%l_P@pvCC&#?>BND{qdux%PZlh%Yw^}Ysh6>Io(*`tP5Aj zzPtrR21pjexn!#JP0Lc&S=PH;+|QYQSN4>@U>_*c}TKv{X>9=#rcCd$z3 zr|`pZ*|>CM$$2Veo9u(*cFcq#gRRH6tXZy!hPsCcbFPus_yG*#b;<)UDq%lJd)pwf z7)fgjF`2oad$Wf_?i%7T;^Or75yOALoK0{z+eP_220U_N4GOGvObB zxFsDU!R5Gq!sG+7{*8%=GH5$USmO~VWyOgOC4}X3d9M~cmxYEX;*_SEPNB z2q))KHjdYT$1B#~A!1u%2yRBbng6w1TWIz`+e#5IBa=qJr76d4+N zlE($anY3Q^)}=6U@}B9qCS3ySmAZYhGgLo=zNUH3dYat{f12+&-QU)w3DyHHN$zTi zz==RtYj?An=Dw_9*O0&d;VHo#R8hyu?&WORXVFuID9X@I{nfYR=M*`$vdQ({2Y^H5 zo8^(%BdUr^3$3)}O8W6AWo&1kv-ryPNt!;?!pwFZ4~FkZm-wZ@UJJC)7VxSzPK0)E z?ke`Z)%Ozd_a-R09nID6u|i=_C$viaTBNLQ~fURs*YLW#@Ytr zT-!Aj16}{8N9CKX!2tKNhCCF1+jJ)(8(+;=R?t_h|BZO9qqN^UTuQ>xWADZJn<+sC zp426G0*@z!M?FLsIaWIE$|ZLi3p-AVW_#+|{p6w9!31t#r%w$c*Wv2qh$qPbUP0m0 z!Q6?ZM=WC=*!)}kP|YB&m}Yjj%;CT(m-5=oP`3PB)5lUm=9WY6cqsTI4}qCr6}TMN zIHL>HA{xPIx-&N7(n(UTXQ87H$FCf^j|%J`A$2ns3eo{>CP6$165QSMwq1dze9Duoul7bgYUq5Qu8@*G=~bgv@_cNooKuRXL549`ycd4 z5{mgIUPIiHZK6i!%gGd{d&BsWcwO+G3O6};zyn`a?r-FqA9&w=hO4EWl%<`cErS`) z%&efD2R3(JaDKR-2sbs@dQ1HJiFG+iOu30UNpto~kx+DeE?jzSn0C5n41=CR;FDk%iQ(KRxJFL4wdd z7Lr)p#9B5M1G&}>6$g%uh!5bwrWj=t9AnU|(e!oFilozPJmCc85xWMOwBiK2Sls$Fan$$Kgdod$E$eDKmr2fiaF?S zT-jZMnFSX)Gl^5J+5Yz=iHf+=O=eezCEVWjoBsC92*k@MG7Q~~s1W@KeH*gkDXtgIr zwyZZo7#13xeL{JfAdE!A($va2ittG6JKJ#=$7VMOJARXHLt9oLE3?L+YV3szD|NCho|vh6Q;qE zKtah4#~v|#ijQ%`JF}U_`1J}d^1g&she|UcC%tmp1Q{oo0XLSIzYkHixE|~ueS#(o zGi6o!CY$E^8#R>Jb>}2=eC*4`&>x}h4u5nXEj16F6d04p38>@Fjr3YDWbE$mbiAV~ zfMs}XEgK)EVV>;Zf_~7LxCKgLi6(|HryW+0!E)oM@~%m4)ufp2+EKBA*v5><__6H; zW{cTxIAbpJ@ZNw$U|NFPm}VRZJm&GM@KKY;vm?{3{1@WU98uQ`CZH z^Z^EIt_FjlM%CV`<=E;g$gqbdUKiloZ!R@ushRboxxsACszL7wHdxBKRpQ>1L?XZ< zZ*Ix##Bv|9VZV%@7SZ}RTtyyOSXH@a4aU=`R-c7)g)?69JlXhn zY%;fatudtk;48fD)H#SWf#pv=@FHE)56Xxy z3z~x=m`4~F{(PIi(D^4Ee`9;Eqw?Y27`A=92Dmq~Jttbe>>IcPpOJFHjwKxq{I$+hdY?FkI*qnj0hDAj`BxYS}wZr zxN6?YW4WDr6Bo5{>>QtzjWFOnjkxKIdSi`tp5ENVzX~Y3btjEmtJrg~rf(m*wadEo zWezIoA*05DWZECajq)OK@347e9NqUqJWRZtUi672^mR+~_AJsNw3l9v4bhrPip+vg zcykt{Mlk!ek!-0vaN`t<5D5_UL9o(YELz0aTyzHi0IbI!L+dCYIW{88BF!Hh*ey#o+I^OIAQ3lomfH1A4tP<~ge%#u*C zXlW3fvzhXf25Q8+NPN^sW6`F2n(7?%NXRr_X|-$8i{;18BSy5onDQ8Jr6<`p>*V=Z zUOWAn!;h2AmC1i@9%_R?Dbp`J2gPp$MW6J?y{$HrJ?$N|=!K}*Tet27b+7$Qq1$Gp zz0JBR4ALQ)kgAB8yYz?e{A?QCX6bB(QCy*D{`(ZvOG(Zr7>~}*+CK{Eze6zme+{wk zIO*y&4%m%p^=F7(srhm6KpJohn2GA14LGy70rvWI(Jwz{&p*hfl&$PtjH^A4G>YQ; zJA?dYOq ze)u8&k%(f@dHt$yXC%SEgy)&nJDV#2LCOPh>Z6?B_aZ?X}D> z7!WC!4+Fzu(<8@e(vN7DDcL{x2&D(RV7e9F(O;8@PLok98e+aK`e?=2@{TC6!evd! zS7#<{rLmCCi&i{xobR!!YP=JRiP_P%>t`N$a%@Y-upbA2;l+on)${Xm&qJ6?>Xxrr z&Iy?!AlSItR!y9EZVwo!_MDa59MvNJ$fJe;1jo}v{f|rOMzue=3v95keWr%QsU2~| zGl%#BIIso#2pCkADGMEeR0+@(JS@@tpUIhkoT*|(cTp{SSVdm(ltit=>rfZ}=GV(z z({ZH$gosrERJw=IZ>p&0%ZkJTva>WEl5K$V=1hv0OZv%m{Ji;m6_Ji7Bk;rr0MYquXG|Xm6UWTB3 zNwAlK%0DDR^RnQDE21<+O9Q3iE1!r<(|IYk{af3jWV?%2HWuNEXpr0KExLM_o}wiF z9JQU<*1o$CKa;dUk(=$WT(m*`AQY{d%SRYZ7hEbC)G3s4n0qukC6i%dlpJ65Af${N zeXFk;_d8ATBT$mZ<4zA`0ZWOR7Dz4>7j#EJYVkm2ze5IVC&^8C5tx;SEhIMK>#!~TKS4V6*n)f{AJTK zz!b!UW{DUr#c0)@Y)A*m8Sgyy$Al6cFHVdrS>A>=Y!rhJ5Y|@jl4i0Q+fj7TfS)(D zvAIp!-bd;nzO@yq|H}@L<&4e2I;AY1PS$8-BL*6Mun?{=xp@s+;Iu!Yps~6KUklKW zKdh7{0ZF!o&LYT9fWl`x-Kay6*r3>u>u5lAsWvFO>tmCQz<=`rL@A13GItGsZj5Jovd zPTE4>z929jLw}LC{=_xJpuZe~E6WU3L8Y8Tv8QV`e@8WCftVa4le5I?N?Rlo@fR*j z9Hcfv!}8HW&Zb9%Q@e7rhR4qRBTn2Hv7P65KQzVkXd)%^wiQ+PAy$@OcCFDEUIi()Ts@Y0!dK5| z;ytWBD%r;9G>DZ>X{50^41vlXorx>vT+Dwj4PgW==q=6eyK|tNo9vk$Co?4_JSW1e z7j$!{qYm1={24_|(}y(MT=4M}&yt>OYJZf99ntF9(0DIqbmG+_FtM;W$l-^`?%xTt zt2Ozv;s?U{LaLu4GzZvLcHr4S>fDdNEs|K#oP*5iDfeWqK-bmPf{Zx7k_TeYq`dzH zvX~x&H`vmY>exH6$uPgt^z4Kd(Fe`ru?I^x@7^q+>U!KaU#BH#S9ASgee=g%7HAE! z$=npbR=+|aI%Fw`h8}pXJ?u!34c!&gqrYvp3p7#N!>394tO3p-vo#iiHbPRz%()bs zn%ke3{8X7%F{7=xI?1PJj=Qg?+IFGT+7zNzy^zl(9)(HHfD6*|uEi2%T4T%HnLc;& zLA2p7eqi($Td3{tPFt`wjg{g0Usw}L-Iz9}2bi@ty0<}Jrl1DmmIfReq+%7fUwx28 zpE%W3N&0^82RiuKAQyE**13 z)e0@Cshxz=24*XzyW}`&wB_S65OD%wNYkqzo_teZpuV^f5^0`tfO;aSa+^1#nhdWrt ziRJs~1ACs;R?t+9PKM@c@R*xc%%iY;NlpT<$S$X`KW9eV6slQVYPU=oc~|g|vZ`?p z3}>@swT7sPLjJPrju|IDe^{p}mhjWpf4=bH^wre5$-IePHcxcmarRgd5!RJ@tdq^d z7^(9EHmy0I!oDt44e2GxLfh>^$Q*Lk&XZ0Ua=aPROTw2w{Ag`!Bz2daN$Z=Cgbu+_ z2a@0dv`)31w&f6e`+kD&#gNSTPk$8qzcZb4GW}PJc~XlzcAX9J+jM>pk-U?EYGCsp z&-ql3iy-vX$)YOs*B2QxNf^B%^@;ZxM!2KaH=o?A3)AYAEj+y6&&Ub+^9XR(eSIeX z{KWbn-{B+E$7@)c8Jo7{x7U!Q(m-hK#E8^+QHFkeD~BWH(34TAKS`5g$!#jh-+HRG z$ok!SCoS>`cT@YCHt5RBJy3q9#yw;UT5bG!EfocIr+Gq!R>7fV7o8FdiE`}ab$VPM za77O=M^;oP3JjilJ=x{0k0F`Au5N4rJmhx>o$}oNZeJ!) z%E|X=fPI>~>{VdmQ+3--wFrKYM(lbZ83oIT1{SBr5(_=gL|=MEV&3zfvM#U~=y^m> z1~Q+7Kc~h<3F1Aw3gR7lGGa8sZ=_-*g(wMffFyYb;l^CAAonE=;^epd~{w zXm-gRd7zPvf{=;hO$)R!$UQbof1re}VYEy@N=xZ&RTf@A;8Prm>~9WwnNwqUT!3exX=2jJh^HYeR5($GP%h#oVq&lngM%R$v<|E2Ol5E%$-1at-GD8@>#UO z)0guHr!PsHLiP%XfVE!_8M>3ak<NOnL4Xghf)+{E7B~~c z)0Ow2kfYsoisMUTt zDQ?dGY9UdqbP;d$HZ329Qybxe3`TBY;Dp6(N z@F-rF`K%458tVA70{U6=yPL0=9Mb#oCM#x%Mv+~nGBO^w<1B;%7+r%CQd#tGYRw4N zMY)Ez>#~xfOxNv(M`|o|)H)bsEtWE;zvBzYhnzR?Joxjmcnsq0;aIejI$ceBWq;c* z3h=`k=>*2t`C~9U@dF9SbF%7EsSWotl;JYhd#^G?DZESFLr~y}Cc=5*m+p;ncnw}* zW^Tw=yUkm|m)1P}MNrURx>j+{VVGL_st586pT_9%SEk+|{q17is@t5Mx09Q}f&)2P zvU*`Y_p2a;S!?TTprLVLw52uW9owo^otm_>rg3glC2U7rn;Mzy4nX*YUR5Ke?17{C z8YFO{7A@!DBeNj!!dR7znr>-_ZKK9D)U*FKC9}wp-Bqq2d|!a+e-4M(&CC_mG6`iC zay~~fM@e3yFd8(Z-CjK%x^|OOKD?G`<@1e)2l1j;5b|L!=026dzBrm0RDd!(zQzdM zCC6KB0S_x5!$)aZ=R6bVe`xn@vucCSio`jy^jOOY$R%Lq@*vSLn^Y3Bgc!IQas)S)DiVI^-R5&y@kZ;)!Lax7FN#&L*0_x9x*A<#O+Dfy3D{x1;%EdLc@b)Yr+9pZ`Dc|?5= za`~`<$_M~3xKQQxKPu=e=sLJtC|F6aIv&XY{ zT-e>6zE<}qp}njYFd3C_`2p@v69Qg!JzNh;s)G^-&Y*{_+jJ8M%N_3XB$80CQbESr zwV>3~tI}GhGq)JI=X*^QKmayb(hZV?8Ffvt+KcJWBx!m@zW_raVGr?|qXZ=;Za8=j zTD>aCPOGSg@<_%y!!HyG1K{KY#0g88ki~vO&aU)}!ICgc9vOc+5;2;dCZ@jmMt-@fsi3tN&s>#AjAtA=G+cuT~JTwiFWO5GtHH*kA5JVqR=%+OA?gkIQU|r1Y%K>))h2^t6)I> zE$c?KybKeC%}KYB0Qeo85BK3+NaffI7~QwkO{TrEf_|nmVVLLZ2-kL?V-cdnc#LOZ zS{Z?7*LpSBY*MZ?i8GG@)P58WNih$kxv^&jqAiOdc~ra|S4YdmY~wPhlq%T7R}-Wn z;lkCR@k;Ep8@S?{M#Ci?^Tk^OSNJ+J;wzbzYvCo06&jB$M2ws|<3zMPtsa(y>{ygD zhjF2;FvCyqyvyJFv0wpiJ5}wn_f~AsfV4veGyOF@+(=c~`cY3QX>q8HItgh&@=fpu z;XK{abJThh4V*L4VOScH_7U}Dl3Tnp5sS>&5~HQ|OO?3YxihfsuAFUmr#es^-Ijkd zcbq^xPpnwS8JVx>af+rxX#&UKzQMpWVk%opK?~!^z*^y&NlSEbE`Q&{t5RzK|FWLYz=rw9GClxHEL z5X#{knEXn#E`!Y~@6a2QY@6hRxl2L7(uYWdf<9`O8A8g?71(He3RxOJsA%w_V9CKY z!eHu0%;7Zo19zh)EN!dPg**ZS>lKJaRR+$}`p%4QW44jNGlSaJE_0RUt&%b{0-Z&x zR4$!lk}5XKpo_KyYqH9vCUaW?fAK_YAFPz83NrbhZ}bP*l#wDEF!{< zAS3gjw&F9D#xh(Ux`heNwc0M+NV1@EL$Ucgev1b34lJTqa>$L+h}LOxchCk5F)VLj zFqyS#tRwM-nfbBKMJA5^<|`>L7p8k#o5W9TB&7UM5#)1~{|&MwS4 zyXePKCzj!PnTo$kx+Kccz4IkIpmHnqh&(*-0#9lX)WJ7M(TM0dY(^##?8svuamG`4 zU0=+Lx}ErWwIBlT7f_dupVuGluflA+&hZLEOoWc{4AyAw=L}j^T<~Fcl0Y<9WMH*K z__PECGHw<-OU-tfcKfPeBlOST*z)8hfe<6vAyMT;zz|SXp)~2Q-_we3)UyLE-hDsc zA?%;+NEH<0&tnuuW~B%+B_qHK?Wy$3wmz`%buxglLoK%6jQ@<< zm#B=8JTRoeG@JU>epctb!giJ_NM_(lpn zU8=Y$NpPD1=_t9$T46yu%%rPdQ)xHw?^!kCdUs7o%*D`cpzVC_;>ne| z-miaxtyTU0N8SCGXaUau@+MAxhkX6-@ND&G1d*iDk^q7*VB3IA^i=KHev^(BWrVjc z`h`g32Zvn~*8n5-)PZEli0RnGl&k-%x_qAx-Jkb4_6Ju_2hGg~OZ@kBbqoHQn|8jW zAQ~wNKxWZ;n@!!*nb_OwSW^p!-8Gq!2w&Q|a##)B6`-5F)Yox*b(OQ9U2UXN0l?2! z&~wh7?U}(%H-bm_b-ts?cD<~$2+}TQAlS%oZhfk#k}oBOo$q&#OGZUop_+0+wW@n; z0%7C}F&uG9o4Is6zNsSbl!hkHQ-C9KNN1rBf0GIU>N^=uhXA9EvW4qvl}}~gl^3;G zr0Ulkl%*L&c6p?l*Gv@lC5iW^<^ve95F$mx;8^e@PV6aE`pV7$CKQD8r1s3hgrmYs zgUsvj$~|)fLT&W9;jG#iPWZH-g%k<;lOg342RW4j!M!90{_9$*k7&8L4-N{FDn$He z+V$8eC)pek%2Fuxfs#D%(vDPrqCMNU>&E)F?Ti$Yle0@?&Z7gD%fLg81zAThnA zcbbK~dwo+678|8ESkOxyT!Ql^P%%h4`Whue^6TuYTcQ=HO2a9Eqv>pRjk^Brzbj02 zwFMc`RBR`NP!=2%j9QCAtYLvzYm15zr1s@j7JzGF)cSI?8P+Ff$Z9F7{5salLB*j4 zdTR&yat?1TO6<+igE3~W7a?Te-kRN}h^l#US=*}eezSyV7-8L}=%;c9Y*jS{7_n+0 zzid0k%JcaIQ@MLyM#0=-85dc z4gW%=6uvC`jHzaAe$G>DfuHKbLnKl115$q0S($TbHtg|TWXvVBC0m@jMcygS_C&ZY z83_VabO_Gvu4m-&?HKj#ojDuglyU|%dtB(+^2jj(I$8d7NRB_xH&@V&Fm?UKi^ES) zokjJ`^@4nlVQ*rf-sA7NPEF+7dSaFG_yQ>TSNV-?h7;Mc{H6^r5|?br$L$*|A>)^* zjVlZT2hiqCaT4pnPw9y9WE@|t{DVSo1EX)-?9-C3d~n|CIiho2_fct9*${j21FIQ( z37sPOZX-Ieawrvl$<7x*EDr4<^?*aj2%bo+n~K(xiQij_WmqRCJ5}CFyyt}|U zdJ(3fJZcU^FWBQExfZaB)_c&`*@)UnlTGe`B$JxvCghv-{IMUvG#pUK<_ib-z?2nP zIeFMnnpGE&y}YARK-!Wm??cVo;ao`U?%}GpJd2c3zMRc0430*^QraB{?3+A%?gn*j}gPm3!Hy)4sf#5PmWwnNluD?&I zmQM=KGutRwkODP{`MmADGM;E4w~$>6R)+kTiJe*-Obzv=vYs6;xJIV*C=d?mW8X(| zd%aDo^2@S(DgKphkn}CE1bRllUrG_@anE<*)g$$wdVhL5Id9|ruhh^(pv<+>Z?Ho- zroF?UQ8T$!+u8$Pe3FodL6hcTvNZ^@UiTRV44~ymg1y;KUy{;46%c6ff?(db%8m&l zx@CvB`5b{{9f7I!)A`{Z9vE?h8h;-vo|gLx7^SvOUM2Imt|nP6@O~3h#_Z9otDd>$ zi2jsAP!^EW5i8uR=UD@WDKXN2qBO`$k7@OfNRsJ3^)Eu(tb+B9TJpv}d!{J;GoiKg ztHFdRb!XfpiYIFtj6B@HK0{(ZF4?6Knr}ogHnbcR>?j;Fly0(#+cXB-UgJ(D3xMEx zQD(m1@NB~5-RUbEs~zLE@8#uQT*oUFJceOrgK50RWjSDJ3_nX8J|#}kygMqQUXtN# zu`)Gx=zL=L%dKLM_hF@2ELau_&?n3EhxNG=3}nd^7HqoAW>eABU#LJ&~aT^CM2+@-4pzR9(h-N%OQ914Dbzo9EBzbrrAg3X+df zB@T1`>gesM*2%S*5wk{G`Nr%r%N0(@LzOj90C%1&Y|{b&)u(D$YV_qpUk;87JZd9! z)Ftw?;}dtUnq7pGn)F_(b1gJ+#Y&B{m;}>xuWZOgz9IrhcMAtK#-h5&&5w*}R}2h_ zt|45&_T$%xZ`CO3Fp7g08QL@iHpCF-i741L+PI6bne=)9wArJ9xD3yPm8tfSLBF=U>waCsB~%tVf>CT7X0*^!{{iNAgNzT8~g9#nJxaF2bXrx-;TB0#HzuREn)W1XxB1EEz-fWxr$rF))5ASzDG=P|_t^ zy9}f2E%3dJW_>3U_QY>(`bz%RFVe{uRjG$Epbbns8ZCIX#lbhfFV@oTF%!a=uDi%`y zUPp;WB$qkz92cXq1;|(>yuvHmq0b{9VI_e?-$7TpO7{rLUDg(sNtK<-*~lI4JvjI> z0=UA`4@3YPT*e6*XcI)E)qIm2zhn)=ZE2hGI5J}{4k6%05aj`)i`-q66lF34SE~`( z5{j+_Hb2h>{x({rN?@^?AO4EBD15Q1WL`yh94ckbjm2ALm$#vY7*r0N|n=33h@@bqor&On9!)8lFrpCO!jmtG$`bH?$i;h78jFAbaZ2wQu1_df;~S? zqy4c$#j!-hjw=hzFb86a=bIdc!E}C}p%!TO`l_;PJCqz$(9o{_0&^^E9|gwRVn5tX+$7VMf8n*QsBi?bqz$kM$tWT35{ z6{e)$6uQ+WRpr!O`(V*(+)PJw5?}eWDMT$aE2)zHgbT@9)*aR(9rKI&BY~s^fAtk9 z8Ev|KrmRd6q|&euYY<+?es(}k)FW{+OdF(R#1Ol(k#HehRYK5EFfPVO$_d5zFFMka ztSw9hePN`QdAr?ab>Cuu>T2F4&BlvdQf1lIjUBsg#Jz)(qG+-DrezYfuMX$b9rM*R z9$Px<>Tv8aSMMbG?|Ss7W(lqRk>9$t6*bd$r-xUz=O>XKO&Y^{{#p6p_oH5)quMRhhNX3 zpA&vCIG`_dUiiCgivDQMpC)cFxwwgCB=CGZ$5)Y5ECiSz# zI{Ev7WE{cl?%0n99I8HGhI!U`4tJ(9i^3HM)Mr7W1^&5Y6TyA~-m*BUqK#{rpJzRZ z1*#cV_FGj&SQRDcc`Xjx%s_S^1{A<3rvFK_V%pug=OclV}y-NjNfzWI1&Rngym6QPkX%#-O=zk<6F{CLC>W zA!&Aqz0xV|YW*VQc*fC#o%d1!kwxXf^WTreR}~?zj@MbEiQO-GC>#iAvJrG8cDI=I zf#-t2(UJ6iyb_t-<`U=0?810d5VI1Q#Hsz*b zd5jRMHu8wMv59Rc99D88w`=7~k;jjfg{P>+I!O=zjAkWNi$u|#J!F?`NW4NZQyS~D zNa-_*HoE#=A}~kqTDTL&tUMt*W|JKwC%bbQ1j6uIS%5w+g%}h6rQo)I18T1_J z5sHU+*rdEEKhC7mp1e?77FSRn|(6|Wi{XHoXo*HB^@TKnl`$!C)pt7pyJQV6YAS+>$eU=kj$+?$$BQJ1aQ%ju#W_EijU)pd#eakK}`{0>L|JerlMqAM@Jq zLH*J0{=uuh_zi0b@kDVm#v&-As=2IDl&K~zh?n^er^UL-X1nY+Hi{j$=&YMUkCR`| z*|i}JiK9fvaV{eM354^`JOrF5j*Ip;%OWBF7*dGTi4Mb(ERYd{f1MvO%q_39JnGrN zd`a6dgTzf+rJJ!orR98LZP*34b|vj=sRgfFLuXuPsQIjZy@r<-i%G+9W5X8hB@9@F zpPbA*xLQVzFV%B3a2BYKR69w$UdD2#%)=>X*@(S9$7mcS2}1i)MnqbuJ^ITv$l_7t z(;26iV@g2C!{1Y<|`)Z-kG!r3sT9*l`Hl!_#2X7u(ZM9eU8yx3tcI3h{~BkNwWia31ne_U5{ z{)F52Yc9~t`o+Z`YCA#d-3Xm%CZFU>ES54Ts|6VNn7xJOscAPKWADu9g>bTUOS~Se`h|?>hH#|wzb~>;UL*6)F+bpD_2M?=lIQh zZGris4-TM&D|?1CIkj)!YzT7V<|lDb@aoYa9 zAf`SeHKzy^RXvH0MzPo41I@(57`{0}t3tQq*SJFQLNr8U!0!~z4iWrZf~{naf7uBX z>x>?h|BPb*e-2`BnyVn4q{ZKvNJc^4;V#rPYiLUAyUo#GQO4u@ z1TItKA^ESz(f_7OU}XM}&f{$j+5hue+5PhKT1i5!h#%u`i11ULB482n@3e!clToBjKlsMqV#tJ5j( z8)VCYfMn>_Jxe_cBYd|QEk%qZV3 zS+mClF|sy~(T0sOz*8{ArB~fO*=Zl2PfHxM!F9#1^`hj`EU!ikuWhhMeQ?_vL^z|a zFXQCSK4Z5pMAAHsE@u@mF91{3TdQZPmRrS(U~ncU#zPDhHH5um;)BnFFo}1f)Ti^& zIs|+(#oYFs!=r~N&7(bg5v_}Vd2frR#fNwhu4Iz>QZv)?UO?qYwmeE-j9Vem}>!^Qsh)h$OFlh59u7#B!4{M z*R7cWUKxo`hBtoxno;Y)UD>~*I}1l0A^gb{8&)7&4e0}i58dgm2OsuKZ{FQ^k5>Q8wUPJ4e~0rf2aybs4=lP&o~UqDYg|(EJWEJ+W4euB~X;WdzgA`|(oH3gL!sg-@{*Yp@<27bqd3lC46VcW;+6)U0n* zm)ytWW>cQE=qc-IaMT3^TLiZ%y8rIks@afS?qZ5+2c+X8iFI#&(?`MRop1bUo)bQo za{|eOn;kBAB{`a<>H&XIMLQL>R(D>A9V;x=sn#8Mx4;C}pUPVv<3knjgK zEpI)oxA#e3Gj_B8+L6HdKk@Kv9RG20U8#5f3{r?YAE;iyl}GVB5d!h~0)O(ffNVrV zH7l51#y;o)ck)f5<;XPbf>tC!B4@AL-{cFI$xtKPx%%K+{AOSD>>mds(mg#5v$!9x zMd>y)APv_;)|+Fhb)Z5<3XQg}&*4rcTR=1MAucaO+Qpfb#3!1aZ}M)#p*P!V5Z;Id z^&XRsE(bV8o_uX5Wbg?m`@8~QxIbQjJ99Y?)Nx#Vc&w&Hx@2tOjAe%fEt~Hkv6e*? zdWWpU7(OUyNv!2L_j=ZSr2geU-GNmdWt)`8Q65qmp}Z)yXoW#2cK?0ryJckq&HldS!&k42d*siJZ*cJ}>r9J<~I zwfJH@LrS>2f397fGRn*($>z` z>(X}STGkvywQ_H46(P^ef-g&{Z~vy2KUmzMENoF-JmT))y?&DY!t0y>>|*a!E&6}h z;6U-XUcTL{sc3vwKtlnM+9{YWo_&gM(r}CZ{dbGa!IZ`Q->z)V|BZ^~{LcmBu;%}F zW&bP~W$3b(vf4UKxv!%xw-ffdb#XQOo03(+!uHRA z)@P4|h04Fp;a!=&kCR^AZ*?DUogRhMIto%%EB}{r5=e-SN6Q|m@|yb6NeyWnFi(2o zVLbT_Z0q75c4(mbFWq}WZ+2Af)tW~G4w#fgb4q^o41$&mIDT#Sl<;AJ^Lxyo6-8n} z{z6fc&$x|F_kidSWrOFqL`YO(Z6nfydmEw`bZ>pP$`WWyxZ1|Uj)U`@$rkHR{MVw3 zBgV}IJb!z-q=1_*V+C8&$eQwj=iz(~t*OO9_myQD2v_85RB`^3Nt5F((~FzN^`N<7 zZ6Tq=_At-CM%%p1{MgmXA!BenSN_a!mi^WJ@g7QuvC84(9>|S(1}XFFH$1N`w&OHz z+DsHe2JBF3YW$S9MgV=YXk!rJQa&94b`Wd{yX{~&GSS$tFjAs0uUbA&N?sd^V}0eH3n98-?F_tc7)(W1h4vc3uAp_j70sb z8UMIsI2edB5aQ$ZIA3cL_{2-LYc6me7M)znzS{UiSr&6bI2^1}EGZ+oBXUb##OdJS zm$*cAmeDu@=sX2W_tw8%iF4@8!M`g@a71B~Je5qM$76(#JcVg9 zC-wgIa7L&iFtdN|`yyB7XT?WvkU~X17 zW(LJZWydH)V1*6~G5!{BJ*4WmdNTE{CC)z8sy z&^U6(@S-!RmNXwi;x2w8$UgOiH>1xI1uL>(O;D*IR>Xc`xT~hf?265~<+XroLu!6C z5kNMTgL0~(j3jU+A+FJ^e^6{Cw*11WHK;}~0GCqyC*tff{!yfySoTEU-pJ2Guy~Td zPd(L@$kLjl&|oh$h0F- zNW0G0+T*{1m*BN?Lw#Yz^bAJditDoWOLG56(;N22U{ie3DC&bDED%Y`Q+L(MUmc`n z)8-1y#zN~!rTq}ler;a{J1+b1ssK5-Err-ZbZXw#*ltY~{^i5MsgS^gLuB6o2!E_3 zkEc$B9a;6mR!w#XGKuHm%8*l_n+fR{$Cc+nmkEgj0f~lR4ck zbZpD~5Wvc2NamYXdZMtSYS^H8yxI`WoBw*Rk}47Nl<~9(Az@pPv3On+NBJ5`D7ZG&F0D_q6NCFks%hpk9W5Ez zbN$VuTVRVjm#-gszWJGrHjQ#&lQr=fc58m-JA?*S&W@v$Xw)KX2MiRp zoQB{|IudV{QD^GzK`GKb)xZN`OyyuNResY@=RI^gqa8X7Nn>Kb$%%`WRZ{`R2@8?+ zcn>J`1^xg8r2N;Z;D1BBS^u*!Z2Kqf`-ATMzj0r~u>*M6cf=obC)2+jjI&KEC(H5n z`={QOGF(=%!3^hD%N%;@hHm_m#NT(W`tSpMHjBPqXOGW7yWYbGw|`$;U-w*JpV+xH z_0UU??`;1+A3BgP;IZTLO^DLBFo~B!#XghsWUav39MBGSog@{)%ff>rl-cn2SE;g} z9dPuGd6I8vD-i-ZJC<(F*~5dARRTej=buVDjk*_@7@Yvp>urreZoJDYN!}Uyn%r5L ze^iiI*}S&O4MDqhzTN-)<5N_M&RCems$>MwbMFicKtd>F%JPAwXn4^z#?PCaPFYknnPftENXs4e*QaJ)?w|2mn5x zPSo~Y9n*OMhKG4!2D*PDf-RULoFq}B9C`UD3m4(j7A}T5b@}COrX0`Aw3Ccp&Ew+| zqz-T(B^WKk_f0`5$84SP?r{I%D{68nQgviCj$>`4T(d!wkAqRt651Jszhr^JXQ@AT z-+OUvWV_S}{-s_Ft@TmUSU~`)hNq9^JauF80Bh6Cc;E%r0Dif+c%)p$oiF2-fhOv^ zd>+C!qpwfHP{R|Mfmc1uQkfybjk@BA_IFkj`tHc;eu4A=QMr?KPqJ;q?*(~0h z{&7%fx9;cFNQe-IFZb3J5J^7!_kt%?Bp>XlgWMSEb!A|O=Rs?-d12~r6l-naWL05C znK4S&eO0Ac$)O~oo&&RC0G#y&JAFu3iHsQME?TipslKrkBOwFIKp&jZCh2jaBB}%* z?qBigt$CUrC!!GlB|}XK>T}epKNQA)~Ld=3`o}fAd{^q91(agJ|cjma2NygKkOw? zs#lgJ>Sx?{C6a+|qVDpExg?taRzBKIsnS_5Kz5Q%DL^`N)+P$#r0Oz;A6=Td^a+ogb ztHc&B74v;)xPYRo=`puUiYWW|1O)_r5SjOZxtaUi$@t>JqMOJ>haA2E3B4T>endRh zu=$&QREiP?ZoK+9Z2o23;Jc9IDnM^bS_93W6&_J}91Y1iDgV8iO!~?TW9VuCI_995 z0O#q~9Re@QIz_=2>5K=HSIpWLarD^l`Rv&!c|IcW1dR_hX?W>kk*2tSWAE*ZxvPs4@Mgv=#dlYJ$VEJttRp}hz^4=X%8*=#EUsa#E;$D|Ic*x#%-*N6#YH{*L zngcAk zD&7Mm5C`2H=CZnP3*9p&}^Xpn&{0e`C zvd-7ygO&Iw=u)j1k=Jv#eWaPAu zR7J$nsN^XovLuwE^p3wArjWiPIp7YnvN|tTb*k-i$gcIqKbRD(z+{(_Nc$VmXauFw z+LB2X8h_;nlj>5{8`rfVWSp!YRBIAsT_d z>DkUQMKKMqtXPPT zL~hyWR2pc{#?~*k9W#LCnekX+8gxgqhGn{S3`|h)_*C7Q-w*vel4aB*gQvR|e z{qmf3vSKUYoG-CQ@m95OBhjuCv!~iex7Rj&dJ=j=LpKNnZm~CmCz1ksxQ@xRXHBtb zqn5CSUGR5G6)Mh|#N;!{3E=)v_Os$9K^|U*bF~Kv?#$Z~Y?HaJvxiap_pt{=sx;5- zcNo==w)}m+14{0R&@bHmwArG-cknDb-%n!wvq$)4LfuZikM8&(y3mCsf2QOL^+G}Z zH)E14XVI0F$w@^5Qm||V%IGq5ve1*2=8`|2S6CmX@0irG@g=O>3Z%&WdJ-vMmDqSR z`_+)eI{cT>YKbOsKC-RsLykh}*!$@m?|N)Rnjt&R`b|=;(f3KJt+dbQT7^9js7OTG ziiz~!FpAy8Pi$#m1{?eZEO}DP{SsMKGPGj zqAV%pXbF{p7h$QpJ_W8wRAP0WwUd5qhXn@|jTytjLYnV+_;`N_47 z>R^g3umcBtSTn(F>tqb1sLrbz051BWj_pbR7ab#IW;$3KF;1NuDopZc79lX2_|kKA zyx+_IK#^!$^u=GU)Khlzd4umcGp3<~gbK@yT`Qw?&=|J2n#}d>Cr8yriu7B)CHwqP z&O;g@)rUa=XFK5R-1&H|`E(8NrF4A}OSX-(0E+C>S-Mjv4yGL1R&Ga*n8`PSWB-A2 zXD^U+Toqh3juChY1?=6+gToQ5Qm(o^Og}Dw(gR!+{;c5up~IOqr-4`IruQra-{O;1 zHg!J7LQy7>fo;hf_r_{;^Ui`>GYd!JZj zt!YQfc`xG;JwAnh9tz1;7NM3*lZ67Ty!ih-5N$%uz_E7mA-#chpXo6b|G3FP<(reu z@DoK=8(hhqD+#kW!&aoyB`A?m)vH>d;rv9(QZ%~!^;l0IhqdZ`&X-l=LW4RK zBf8#w`xU(QXng1F)KX0w7KFX~py3rw$fT>ebEj+-Up>9K zjd=UD=?qwA`w($t0I|jZHGWbxmPRATd-O?}J_5D$32cjb&yt|P{pC~DUfR}V(Csh& z=YZ#)K=F4k4l7P`XH5@Wm-*QgOz(a(SC+q9hW}qdY5Fwy)T84aGiDzTE-Zu9 z<7308&(Rjp$%=gq`uEFJyZh7Xx$|7!7sV?Q^=DZw*zYXDFZMN_!B}&De8By-+UHnT z!uvUY!DVB2!!z@86!NqD1>ox<;K8j5U*ndNeXE|PM4fd-GuM!?tYUb$n@WiGh)DW1`Z6Dbv~czI{-?i zcWd}@a_;dHSScCr*hmu?p2>fQ?>$WHZd-h3{}!j1kT zpkjU+H~OE<8lKFvgZ0k`?IwPdmfil_$rB9S{gZFoNAr>gPguMr-#Y*3zwpGNth<=Y zzmsUDNGYw#sUbc;nY{B?)K#kMk$Om7ceoo3^hF)z8Mh=O%1+M+aB&n#Hpn;#v`c5& zcg0#ZC3Z{w6{avUUF+YEju_MDsBQnQ!7M~j?f5&BSK#)bWQnc)hw0|$ z_qav*{gkILPb0W2;#N0`{i|3Zo#4-0Gk2Q*Fhm+jmbE4gYP5a?gC2^OX`k9UN*5-j z8uR`6wbI}%QkscF*2ieHELHxM^Jhv`DtIZrrOba*i^Kn?@F^{Rfaw%Lm5m*I#?+5Y zvI(1(oQmk2X&&BOa>1L;D1+y5wNrrs*Ct&K9X=XGQn#4~u zGM??2YZL|5n8g2SaU|G07;9<3Vdl-u(MlvSOJ62REVsEY#&GxdTnX(|Fb6*=3_^cb zD2=zia2FLx8^EBnpEL9%#gcS`P*&3_`HRGr2L97G>WQ%39Hr*W$tWjp0JrF|oZdEY zFwbHjFDdK%)DYPq8^h6o08e}D#vKZa@(g_wqckTWzrZMEsfV#MAbSf*#?*poL57;v z4{4<=(MaU%U|D*h6QO8qsaZhmXQ%?twRqdAlkqybLMHC!_d5#6Ibu=fNe4_J@8`7J z&z%++5>60{b`mu9SXUCtC^Ap<&?gf*I#(VT-4j$nP;Q3r*QITr`la)z7Y(=%QD zJK6!F$!MMc?ys+a_@|@=c%Afn^Ix#>iIb7WZ$XOYiZ(k~3EgKQ-(~~VkGBV6>M8*! ziP0(D38djS{jlg5q3abTh!9oC5pyw$r&hNehi$9v7qZV?u~&r&-|QZ^rV5IMSB9b) zYLLS+O&`u~B65a$!o{W+@Ee z^v&Z^cUt`m7avYo2yk{8u;)}E ziBzf#+=l6zT~>DfClFQ|!ds7pY)iAWfjDnV)wrOVKm|JoRkP2!*{y3bWLn5RD@C>} zXQ3k|Xzs+uTMH^R@D85=l?dF+ezSn&%fr-$v}yxqm(VSspO~;a&%N1>Z>vc%1heuZ zbU63X2dSrqHJ<@CnNc}!Z9=zW$mth$U>kHT?vk~%aj-M8Unaj|( zDZ=hmR5dMkO5QEbW#>iXUmLLNXOL8!%oPC}?aI@6UGonF9cZiDcMwwR&J8S3gVpvs z1-iHRd}$M=9wi74lhiS-aXJ>yeI*vld~*w*RwX>@(_80o>h%+S0fkt&iQJ^_N!ly5 zwakgT(Q!3=be(8~nW4jgeMk$_Z6Xq;EOwaPW{}?_A^>2n@vaq>YieW1Wvm;%Y)Nav zKqCcrT+sU6H0m7{G+pqO|q!~TiVFqWFJPc+3EIkV1tl~x`#N3cGI{mi_;c)SH;x$QbN zbqn3vdqAi!5Gwz|&40b6|2O)dmE}K7J^&5rACu3II{7Ep6Gfy*kBxDeFMyoa3gk)c zv4&aec~1EK{U;vvsji!OM;sk2VrZ>ijEM67ko*txC(cyfB0sZ;#7{%c7kRh0{Om5^ zW_JH&bbpeaTgDO^F=W&PBM^EXp%jP;oS$dLH>VjsE{Bp=)5-}j%ND&Jxx&bkMI&Q@ zuI;`Q{aU10Is3O~#I7Sgz1ThRShqqMf(Bw&LvBTY`c8}e4 zlW)!OkQx1I>bc$aImx~|v;YQ1MwU)9DSHXQebR2THC@z%H@Rg)qnH_O%^_|hU#Pez z9B-K8#u7czSrNwGMm*uiG_RrvGyV3?@!1BpYrcGRX`dm6X07WHO;7j4J!Y4>B6 zT}dipaFmCrEReO@`;=ENo)Bev1rf4fGUG@8Kp`V5HCL4&G`tZ_YX6rb-6_~UQYA%Y zWvAsYNncEDL>8mw+k7vr>z84wD;n%5G0DXqW%Qdd5}yHi!Av=2y~%II!#QFhsLvEh zkVU~U*hBx$P)xIERFrf*bIU2+lKB7#4^I?IbWWiNwnSxdzv-$7Fe2ebLBrNwjz;5r z9tbd{)6T?)3C%`Bnj=YIUl3%fAp+ztDYK_vE%^BOD1jM!#PEFshTQ>52VksR5;0Mh4Fn!cFUVt= zT`zmHXft>)angLW_DWD2^NA@WE+Fc`p-is{pq7?75D7AzG2=+_t?JS;k_REr=>YohdNNB4G<3 zPk3R8skOA-u5^fC{Y~i(6KlIS(y2GF*m9~yM_IB7_qLj43=C-3f!|^}1vkne@D7C; z9r1(Nl-kM}@wb{Er#w8MvfY#RGNrk_wX1yhL$I@`X#j~0!zcaifNi^8*ivnaKcV}0 zWkd6wY{L;3_;Ktihn$JN*L-xiFl5psfw`K3@`myIR?TqARm(fJ48v_EHM<~c4(YP| zkkO$VjMG%tc%s|7UAE$=@**Od2{gakZOvkJ?gKUWQ(P0yO04|xZ363#nMcj4>sY(# zuN*_JjB>mia^|0SYi%xNX(+4=ec78>bKjkuq$eXjj^gbNHaYvUi8U79)C|Rzi`7_m z&4lJ8S)^I!`v{T)*@xMSKipmV5dxNB~Ce=@4ycM$A-w0vwm zGPX>sJlALa!8kcUJ%ve~v<4PD+H{tr*0oOvyNGUL_0ff)Y(R*INsMDJI*8L+0r&56 z`LWi;J<1GGCn?|XDm(fFPy0V%irKeQ$Ty01wxDu^<)KRHqO^)95ALC=MC<4i)~C7W z^v;r|oi`PY?rXKt8a>{eOf<)fOJngHv*U}t*6!9VR|9Lb*tCadUFC?yf39fvGP#7) zqA!6jvcFq9YOFoZz5H82z49SprmIgYz>&<^-72NUwz_5?AZoK6r7rbGZ3Ge60=xHv zLZHs>oqXDLK9|A zkJtERtJ|L4oXU>CM7Qdq!M8>Z{s?zw``IEUTDSh}Yg-xHYVkFja0u$Qmda8V@2ETC z=})jXZQNAmy!dRM7Vf=*>)8r8gXuu%>TDpavJoG@y-JzSnDO9}wgyFILV6i`-XlTM z0J|TI1kPbN0e?Fe(Iy+-en<4#WPWg_Jr?rxR%rCR96}2yjF9j5TcTMzpm_YYus9*l z!0-KnF_7>{{;&7R|3goxPKBoW((>iOt_pX55wx3be0Os~)I$?W4t_1oK)*ZXBgJ}%Ge zF%PS5YxYfMAjGH3^xw~~vZQVbK+_+FA7}9AbuyDZ7l-{C4E<|x_Xu^dLs9QR7`(4T zlFDo4+qP_dZ|q?&)pGkH{>d(u!WGaQPLnM}s%mgs17MkV9_tp0dh?KM!jgUdWN4q! z@8-4QlC?*kCuHf#iPULp*(vl{t;i zAmS09GQp#w7YZ2Z>8?F!#^+fhW!C8&Rw!Rlrz-=2M^Qh@#T*8Q*vy^3L`rJDZeTZV zRvvM-w*1^;YwF)ubdLb*!X{+2g*e<`kojwx$?V~{owwb=Al$H}CsN5bs##JC%jL1Iv!tFD} zCEZOd?)SxhO)U%-$mAi^TS9;RBDw$svYea5xB0r@gTO@*lR}RH?LY9%W{WT&>%7K% z<+-PB=SN$NnGkeH`inS@J`$e^_gt=iWuaVj-67C0#R`TdiqP8Xu*_GYbd*^dv<^aS z`?W`mgt}tVUCq_xjW^hi&N*|F;uZ8k|ngph5bOa)g=LL&`(IsioIP2HWwLmmV}1JuHn7M8Yb z%iQb*MUo=6+&%q5T=Ki?`aYE?E7s~2rLhHix$5vq&4VLX+B+GM&4*>gHi|lg`NJjA zi>yWwG3HN(@iowyG{lQ<7qmhevMsmwhJY%cBR=ICyxSXpEj~X;vujA-SW+6%Jm%46 zu7~fEknqoq{J>WFd^6?o9rv)m5PS7GdN}h78~O2V3t4X9JG60hb2#2R1|Z8h+s$*G zgjwFq&afS-@L2?U~PPI#vQ9#_IFkzVY1n(7qVr1RF~W< zmGO|f-b}MBo}`E^`ASH%EjMWfNvd=so4Ps~S3W-1Wu=(v)PghQBoWV8fi6FtBgb5( z`&s2{qs@H#433<~v7W1np+Q@AQI7GyF-1Q$s{{-Lc7~SFJUsMb7S_%tj`U*I2F@lT zCPsF~CiF5Uwr0-e1dQxV|9{Gn?igZr*y{(>2apxXr5m6~T96}#ffaHGfLv08_FGnGzH+o?O4{VH$xe80 zc2V}RCP}}QNy`TR8*t3fmo#-zAj!z_A`%lnN+Vm#ay_+PH1X{s( z8SCjzBcdx=l{>c>ZBFzLhT6Pq$t%=s@ouZsSzJlHuY~63eT!G&Sb!*Iel#earj*Bi z0F@LL_M3ZTuh#?Pf>`;joj2`$iOxoMO^17Ykz`Nm@^K+*0ocny3IpDRKi@={Y2RRQ z9py-TVP~UNW(p-zMcEGE=pmSBL4r^(+1el;C$)XO1ZRs3xD9(NDm#SlMW@-$uDnRq z3}>cIaR$Cv{opS00R7teTo<*?w8OaPDm-2enHggH+O^cdO<$v({{$EMwgW2?1!&`GF>s*1v)H(Wy>y^ralf59WlN4>r5)nDxmDM!f%?%iaQQmm0tkY= zvU(u0QtSKyfQerjKEX-L3aeWJk8J;3GPM*R71(v5xD9yM95y->>qFvI3;a%s-FWvx z1Q_~#Ql)(Z$)y{RH^E;q!i+sbSdhrGx;kon(!#xsw#7!;wMakE&nPAHkw7B-eH<%4*9l6dPrT^iRNDH$pJxAtM|nFbj_LU=&8$&C^w-JlFJ?#<`tG;HxgDAWAk8O zjRv_v1i=8&-r<%#Jb;Rm6=_)XR6VoYx{LvXgQQ!h2-A>bABYlb<}PhsEq*b8o`k0 z$s~=d=Np9OwfB9ZCb&SjnW6pm0bJj68-|c?9*id+22J3T4JfS$lIbXN18su&1}1CdmLAl z^=y$`sN?en)eOrfpq#}Qd1>+T5Maq7Bl%(^TgD^n9wJpHq$zE4l61>#zcKU*Rd+7$ zx<@K+MAA0(LhSpP6P2s>+0 z?BL%)s4Z!9WniCe#?WO()s|-x3nLCbrnpDo{ylbb*$ zrM$KR&$HeJwS62S$Yf`SALA2>g(A>4w~TQ-AW6zx&sU>En|`6u|59LLowv+Ic0f+f z?E+1c8H*o%TXK`0@bs`$B@*Ig@=`UvRApb_kBGe>UutFQMDJys@3p@H|M1jYOtBs+ z7BgLIBJc(Ym~;NOq5JWqk{<58*%icv9!0*Z@Y$=2g7cRW=;61&G4zW5rOQkS{uo}v zM&pY#3-V5`8GeVxCVsCGf7;s;iC1@7>Kk`#!{JQn>2{NU?~t(YZ*I5x9?99O$r!e@ zX`RL1xm??P<@}E?Oqygv6K_r!Io=+cQ$4Xu;-hE47(z_K47k=cw=<%_cHX~5LR9?8 z%gH45$XQ{e$QY6aLL)@ZoW_;NYz7T@+8Mvom2W z4-kwGEtZ%3##upV^oJGSAU9p^!*+i5P6X*4<|;ENKSas&OWdv?Pmdf%uGZ)?`D!~~ zdrbCfe)A(PKE^n4A_Sm&nouDtKIJAdlG}Lv8k{#?FUaR`z@n_23zZQC}xYxgE3@7-QcYv9ZdO?ff5m}Atv`Fmp z#U#aY004XmD3~_Sd(^rB55IBDe<>I)Pb$}%lh2z?CvCfv&!4bP{ z^jGR@AdJlKqA$qaQ`37{uW5Q&LQ%wFR>6f>DQarik^Nw^F^l74d5`$xRBKpKEY$HL zKwZ3FS(vcKK*Mb_Or?T&6gw)ta27T4P@(oy;v+=h$f~VDsg4FdCM<_9Z%H2OIB>g~ z{s)XH0TyBXb(&1EpM~9R!f;!dveywH*KnTn1hmNUo!<${Gn`6N!b9^ARVD0*)t=kc zA^uF3pc(Y8M96#lCj`*H%Q2_!l<9_-b!%HY^6T%>#mweI*hb51wn=HnZElmeYVbnL z6lfC(ApUXuDCE8?tP3g9VT&+|^Y-o*wlIl5Ou>eV0$a)C z32q7@8*7kx;30Q95VnR-9+YrOV~jZC_{&K@HS{teP2GPfq2=ew;&gI>t<%@jT|#30 zko-nP{xAC{rKjucSB_=ZHHTC{KZtxT+QVlk(8B5olHJN%?qM=_{jzv^V(A_Ox>s+|BlN^kp;GID6LM!VyrxC3=lg=QlJPg+ag?y+u>73}FESb}h*|o9bkX%i zOhg4cG16~Ni$O1O`@FavLXdA#u0Q)WBxAsX@1pgAq&e7Bzhb?3s@;hpmpQE*V$rGZtDiXAGRDl7OK8oU;NEk3bj# z#W9)g>POn}FwWS|fcQ*fmLuSr_3W#G1HBJ&*YzrGNV{vdEpWcDS-OZuJHVd-E5#zd!qE#U4? z4kHc{u}c-D$7=_s#cI6cM~Q8L_aK3i?YAK66oLz<2>S?19Nxs}0L(D>6ap=h(S*Um1SJQ_(h%`f=>)}!ds9e zgA9`>ny?_2ppPwKcZQ!A?Klf>A59K)iZwtrN3747sYK5sfXK0eCx{*oD>M9#`G#|2 zZSWBo$CU>{dP>D%2!=gK!rl23nb#ge2G+b%n{~X8HLvg1SEKIamUD*Q zT8@wVYWL;WN@L9w`E|!N1H-nCu5Opt*M}X);5MBL^rl2R^y{Lr$9oTg&bwiow#^y`#ytG*Pfoq;=IyE_ zvCTIO*t92|_vcV0fiznxZkJ9QkF(=~dx+Z+@blcD#%jhFAQM+b(MrWFmY-gO%j z)9u^sk00)Q8P-P?Cft|g4U2cH7skwbeB9qNlWV7jY&O&6#~HSpvfnX2Jy)g~dWg+3 zy$6YdScNg8v<=W!4vrF67r!Xet`ElYtU z`0(#UA#clgEbvp!k1o(#KE6eSc1XF2j;2mKQ|zJIXLQe$GqLA#g)z?fVMvynu3)uP zwcoKx1)5G#^uARS9re##S1h8k_MV;DnJzswOC^`5mYYrY_xF)kokPrzo@cQEAA@XE z5c_rPj(M2X4~l~L2_G1Y7yPTWDJ|T$a!k4xX`TrFZkux-e801NPhyTx8Z>+CUdz0l z+BKccdg#^88^-pQjkH}CoS3jwoV6EflWA7nX^*`b*^eQY2h1kJJM=%@EA}m)-ns^; zcQ&+xBVWsTb)9|nZE8DHY4vk$+ce~oah&P_T5#wv@%dx4t*wUYaEX=0oZplQn?lev zskd8rq9aw-%22X;f&y(H_7Z)*Ra@0-1l@5G8%*QeLmwy^2L-olV8DGas@Vc{f2NE; zxa2|(l1b%Vv2zOm;!UOnddLz7~vC&stly4=oTOydTwQ)o<-NeA;C6| zK3nvGMG|Q;l^rkvJF!AXZ4nRWlfQckEf5j26#LOYp|G+d)zxyAg>YgKdus3EAPJ<{ zAs29v6)^$hRf=z~5JNCgKZbDP5ySk+dst*1V%xKd{#oOIXtsiEpOKp}>s_H6RYgHz zqE`QPhBQy8BT@zB!3HsuJ*r^f^1Zo{5HT!T1nMBtA14 zow-0EjE-~#SqeFW3fI_!t5sJ~qK_63qgOM1{F!bvj@&`b$tlqu6waGf)f(Xkv@3BK8`Y5LZTD2#$pP+r^oDW+di`2!bqqmKvBq) z_+&4j5l)e=#&mol)U;~-M+~IFazP0!RqN@BdsJ5K2k_30izac}Asb3YYCGFOTh*g* zkgcLBINGE42XHt#q`>z7IB>Y|e%AfpC$Vb&xE^h@o^3DAv8tdS2w$yPu{v;~Vlu-T zzh-d8S_hmh&dK)Q8>#iDnq-+YbeChUVmYM0vVxz9UJ;rJ=V!WI$sXgsPZ=>rTBU~z z!)`7WMIr0sJjcHIdco8vx%sKKT0P5NoKxRn&;97HOpV42|8!~pAt0XPxJut75;eK? z5}wxIonYE;y@P{Zeer}Iv2O!b#9l8MOo4_(c1Y&NZ^C_T^ERUsM@($-uF-}|$G@b5 zkdRe(6CJoLNs1JBN34ku;2vxr%C%@|!9?}qfE~6d)qz_JbytB~16iVjxCGrm53EL{ z!3cbkXCt@kk11s`0?(XJbypiI!81JEn}1l^n{Q@TYI|YrXnJX+OH{7rowTjswYfb@ z&VH%{Zz(Ftfyi;VO1Z)$l8m8Y9PapkI2YLf^LlRk`Ko!{{|R54%JEv>6i# zpd1-ps?lx@GXd8b&f>cI$=4B}Ab4c$N<`A(FCpaV92MF4=*%abB-AjD^N> zpl~v>+|Iy~|G8Gz+LxXV6cu;az_59*=%(4-P9dHmVNir2)!A{~b7%qQSOZGfQ@q|drz3L$L8sj*UO`v)dR|@e{XTHfTKv|i2gglJ)S zJW-xGZ76tsHRa9GefT|<(l9in;O0bg`(W6;GLdpQ` zY$V4cXWW=?xcJyh>BznNq&M}+*kvh>R*G@Y@tgC@%lGaAw0Ek+!kX_x)ba z@1B?0Og#9fIA-d5JHZ<^Nth3>U)q(Um-Ejv$Ow(AZ~U-poWHp(k;v~I6rT6 zBU~s>*W{dH#gib=va2Z`@kd)&g3p^bEkV}z2$ksbeExFV`PuC457oAwTu)cF&*wmn zC>sP+$#RQu8PM=Nz%QaNNB7#d#~hFU9JA5&*_qeU#`bheXA1w1=Q%``O@1xXc5;c` z>Ha)Q!uA`L&h|aqxIc6a!*}Obk}?3NK(xn>6H230F2`8{74gvK`^YimZ<_6^Q6y$g zkXP)sRwca7sPo^g{90qi73r|{JSuwQdGQS5IoY&`!F<9L$lw+jEXiIsC=!Q(W@F_- zNimrC6J`#>BMk<~Ma+?n2YeZbWLD%4vw|d8)1#n0iiiEg;N7Ou@$UD}#|Mc$C|L~< zeM0aA5Oe-K*;mdmtLWAzL!|MgF81~mo|tHNF$HH6Kg3k3`;``JWJ@!OU8gvYk`H!; z>Bk0{OpHg`QYJ3d=~vRJwUj7}rwwq!_SmQbcX}Yjept{!zJ|ZvA-f5OVHi%W$178v z$&+#DR0N@19?(x?nIAYgSx zf&S(GIc;D?+=I}6s{m&AQroEw$bgKH8M+2a5puaCK@heO=83Lyc)L4gNey*`?O5e~ z7?Qq#gKCNIcWUCGrh1=LP~L@7M@C1*c6X)_OH$9vh?&Q$onQ& z=h~%jV^GCw=?@Tx?&>-Hg^b6o|Nhz^Ofxm-tV`+zVg@QyE1=4V`k)xqxEVQLoT zT)aD28Ah_3en)_mRvW%=vX)y&C?mpQU_PeSA%7zNT0$j51qt~3^Y&G_2Gh8 z`8oAgcL^39$pDoxJENugTbNDf-z*IM!9a!QH*>UEGS=NOgMPk1?u_G$#KPNGtjwa2 z8U}Su+7%g#wQO`PI(WW>KXhVQk2eEnjq8lz5>Qq&(=JZF#4caE;NwJjjwzQJKeW~@ zRq)WZ)~k?|O;oMq^gdY^!UeHyn$M}SUe~44WaG+6&)P}Ef#cpo=SW+hvWB7-{%tnQ zX1lW>;q%t|d!9x{FW%al2$*73N%)GL7UIyF(_DQdDg=08j|AI+W;@nyzQ}t)RQtD` z__ob8BPBP!i}8qb1{%lgiA79dcTL2Gm3n}vhTBXWFALyK6GOvRoyAuA{2OmLcq?#T z@WK`pp0WbLv)W7))TWe0oj%V>;Y|6@g0H%VD%dqUO2P0*psDMGadBCPxrZaY(kBXX z{boUi#I{WhJPaIeV~dff*Q9cBx*3@tWIMm)}(+d4OA z(!qaTpDaluQ;r(G_|qNha!`7+^%AQYHsCb38=)l|)y;`7Tg>g0(0kfJT(ZhC>wRkM z6sp4jDk0Iq1<5rN1u`FstZ2GP#Kr|!jrG;luaIv3LkB12NWZoxKiLK#U!*u+-VzcaogGn;mtVl{l&u9c za931V?Y2J&OvO&a;Dw5`E+USuD{fL{&r)e${;|UP*l2w;*(?aLm3*xeJx7>?7uqB) zLVrGfHp2^SS?;P(c8nL$pgvaWT;&8MvknMAD|&hn^LyR?{HFceOj2?M*|>xIy4vfb z-oZo=q)1rcd6u1Oe5|P1T}3$WTnDW6CcRFEv+bkZ{O%nimKoCSow1K@^i4a(!bh6Z zXW7`HA#u{ebnSWA$4>7Dt>Ovnd!wG{RnZpRxtF~|L8Rh^_q13Ou% zAuf>lPA;98;8{2u$*`LGMP`KQ^8TEw3vc=Kl947nUR4?Sd2#TG0`@+~lx-c0r7|T? zgHhwf#3;!%#Crwd>zJ5!!D#wXL#4k4Q{wF!? zC+{$_sZ+D`UrS_X*o~YnZqWDM-J6{I8{5Z+j*oB0$HSl3TMVb$gcf~<>1ReKkeif> zc_sDd&aYe2AaJ5gG{Kr(JBFY?@Y8RuZ2J9LPB}Dl54Suh zt_#n#`|)m}UbtR?Pq;^-w#O4xrL_nLW=0SX{o19hrE#no4RHIXsTi zb5RZRfH<6eX1CjxzU}aUe+zqd9gWkh+ugOV4r0FV_pdFHs6Oe7f7&Dg9!4_@3!YPi zdwugvzxyy@s=h0UfUXcn<~XbQY*6(oG;d{#EV+`WAj8)wk#8s{-~N6Dj{EjNW*_fG zF1pguLtEb6p}vd=kv{p=MJ#C{EWz67fgPS`3G^5{41b1WM1QF)!PfUUgS=k7ppn6F zqo*9UW9;s&e^QDiR~sJyi3IO))!&UGl^7fqv_%D?=+^!FSK&2+u9!wGr8_S zKH2bRYxNJy<+B1f{-Nw@@hcOa@w4iaRm_?E_89sFU!$Cn=4Oa#2}ovNR%GSJm# z82v%20@J#3HeMl^{6rC$NbZj1aX z?D7kUV>e9U30+6y{t8v51PI&I!vd4Li&+f>M^R_o)LI@ONYk>xwq9pEieu>2wf#)( zwmG*o>Tp@pY8qr>a&ya}bG|c*8cpC*Oa9cgNXNsq$x95WcN2wVTtB?emTD=Wo+?Dd6d_=8+Z(_#?`hz2 zqe*;Bg5~#%`r**^?r;|@SL3&(Vy+Zn|JH#Ld>sHUI5ZNpE83z%LPO6{mGU#{!B-x? zUyFF>m?6(7OdHk?QZ*JE)FI={CzlSi;V3qT;RtoFdk29u7pyoe&m0AlPm(9jI;h8&bgR`i(mp0V(GM6^P>VL)G#_q zTgr!iI`|QDlev}%2^r6W6|2%q^1h0%BcQ56gsz1uWi!9gBfdht%M~m+BPA9R5e~xT z{lfJSJ8!s~s4(zX#A4u8uLz}zg+}9Z3^jxI@ww#{5T zmCzW+!Is`hBn6XsN5>V^T+vBQ&R1S(0kx;>ypC>}2oJDY z^)sB4(JhNZfYv=}S#_v0#%w{|&}6}N@!hv9=vW$+yQ`K1*rqQZVmPr8wd?gwn5;-F z`YG~^6GH1q!R9|nOFCH`;hB}zazKA)bEjW^4!uhyu6YU_(y~=yiXDpCYL(e2#RXsI6x}T$k#%X(`vndFzri z*oaV)cc_rFQ}WF(R#^65RCV8RV-Ck!;f~OK+rNHV35m^COn9g+0wo~CC8t>=tSmKnOhv7&g)_t= zcU$L*(?nhvB}4gB;X7j)9}m%9W~J70df;HEa3&G%*_FrZvs)j79p!^;SiO2QXM#AA z(KEe0t&9TX8V^BFM1z!|60(_FW)ANob@)v11s*dbJ@(&Tcm8Lp5dbUm|4zY})SUbY zO8v1){Set5$j+uA0{(xVVuD1&4^Q!v0gWs!pLBg}N*ZIxR(~Y!^*xTbEUjC{Q}H$@ z8)Wd?((|3d=bhK5`|ff5;orZ9dplFj8(|7U&X z*gIA2NIPIj19}SesaFc8$(j`{qH>S}3d+B2^GcttujhxcrG+SxXK3-sd1N6<$HF8zsdw98zd4NL;#Hi4X_ftfMJ(qX*v%oR1taL z48H+S_CiE?Fx<{*cA_|Sb7KPwOHbl5rocbzL2_KLUTaO5baR;Y@ zk`p4ue$XM;+vFO2Qs*6tG|?vcCJ>xg@8l5w^uvo=4OYakLH#OZ#>7XQsGi;wh%YZGo5l+xfr;7UEFC z+vMLN+j3=K&+Xy^2H1VhXxDk8LG>Z>if~&a#|D$nPuDL#AAXYr1>+ru+;gB09HtsM z9ygku*URmld{y2w=iGq5OAYmac!X_*G@m!wWx2vE;}|Obj=ykSGe^iNUU50;v;rE0 zBGgCbBW8y8*2UA}776St^2lZe(Bi3o&Y zww{|~Y;ga+iNKQFpI+tpz2X7eWk|1*YZ{UHcC7Eu7j3~S2uSAuR&QZi zobu!`(7Gwep1>&rmGqCd9|Jl)M6oomF^#6TS@ZG2M2kA!wOg)Y2WqGkQB_vqm22%-ox%OT2Q`J{^=! z^-%WdtCh#pnk$oEob508%~^pj~dK~2qN}&iMuN+Nm7t1CFG>& z%-~EHCv43oqx_Sq+aSwudINz@dig)X$clTS@A1s}7+F!-%y2=rbnDadZB4KXC!5`W zQ0oB>hOSn_vi%G7BycTaoBFXCW}>EaJvL6S8L9EsoqENXpBw!z|3D^J$UNFt2860A zN7phJlD9a(E^O*LNH^g(8gr7|ngXZ}^0h|#GIY&~RCUhubMUDjaNbW=7p^EPo6RrELR>h<@ z=YPpnwHpiL1Ii7COVJkxP@ru7@}R~jtG!oo88|Vwo2;58oVp_OMtw6{so_|*@Q4HJ z8-Z^Y`wd_@iCEhc?`{^FR#kbhBTOHKA=q$t%(i9CTM04dZZCa;Rl_Sfu~eEhw0mz` zQ#0DS*g!`QJg0jSc!Jt$A<83x_Lr)(r)8v8cW+8Z>f;bZ^%Nj~{4IGGE;bS7B(6Bpc zFgHbwG9_KAmQSG;8Qi~#nYj0JQ!2O+U|g;{TI1lGpD9+&tFekvb*#zD!VS_ZU3z2! zVqh*@D{%ZR46O6kW%u7fDlO(nA=>IYTzuVUFsQoHo&&EwWeBG+r87Pt7{KsmJi>j57so!ZBcO%OTiDX%EpGVZ-r?}BuxZ| zfG%Agp(3!!ETxdJ9@ThqcH;Y#qigte5r$L?=>}j( ziCMLD(-TY`eF+^d$%NX8t7)%EX=J{V1WC_-2lnKG+|;dx^Y(C9K85r}{!#da`5$kD zUf2Mv*?)Vw|BuE3%uLMxrJ3=cvB3YwMWk~|0fRe2B>eUNa1qr>+++bS-weB|mDKT? z?Ysg}!Z(e=|ACdzTE6g&3cP$DFj9T@U~YZi_V_$6Zy#=757gKVluWy-4-ZjsbZ$ag z43;Kh*~&&IGz_di9Y-RLcW+hJ@7B}^nv(^k4LrUruM_y3u+m53*(%0F2CHQfumXOY z-}^EMj=FuXCt4`C7c4s-^Xjxm)qTlW4fMR*4Kc+;-v&@!E~8phYIecVL*pIDOQCA= zkXGLsVy0yaUm^^W3-Z;?Y@Y8iw2+~M4)q5uF;rjeP8xZEU(TXm;u)2H82_Whuu7%%UFHJD^iVGvA3f5PU>^E;%vd#LGBl7j3)%gz}^!j z&m=|VR|r#y3l1(GEoU$d|IRXYj5NIlYa)`(FIZy6;Y_nq@Ci0sBGrf%RHM*o0H!i7 zUyX5uHqU@FH*4iuQZ-DRORO6#oUPJanbk|uOL}_c5QD^^f*O zp+gl_XEoK#TF^u~-L~KiK5+&T?X6T|F2+xj51k#unyDr5-g{59rxq>(R4C&O=uqH( zR6cWxqG5`11xUL5^0$?BjZ%RTV2uU$YCrg!fo#i~P$8xABmz^)Rr;#aJq1p=h93-8 z+V)`!3CYBvs0(%^udNEEz~F-AtDI{Epgq`hDZtkgn;4;T$JX-0qmTp;13?b52iwTv zQg~qxcNDb`=`pdfE6$b<>;FixHiwM+sRTGQG_)w@*U{@5K6g$ZS2i}DJ{v}dO0AH+sei|%$ zj(UX!9ogNhRwMS$>7qr?9brFTpnJZxmW;liInPjR9e4(feA+zNwWh)NL;LVHq3;a% z@b`#IC@FN0+9G!NbO0@Hy0sB@@30%SFE~lZTUJc*JrBKOf7ha@0w<^nSvnp?G&cv! zqbXih8kSYTi@d!-h*_JeO$n>?xdU_YJkyIFHJUoc&8nFLE*gxRM4e#q#~w9?P3>)B zX9~Cvg)u)~s3&Y$?=ts8h0wj`RU_!G7hbylVmvYn5!K(TKU$+&xv0Y59rd6FaV_gz zSz&VZ!58!w7L@m{F~peDEz4s@tJ_6kF2?qrsF6P9noP>+Sk!egJNSHW(((n&QlTNj zXeyg_tuga9C1FUlj}&kaWL*@rLu@dzympv&ojD|owtNj@ycx3VJEZ)Y)zXZnB4YL+ z8CqzAjdU_QwDCV?S0Sd$ck|;LwDC;1=$?RH1(= zMsC88wG<`DV0iV4A@^jIJ?^5w7X)XVbn;{^NAWVpXXj|#;A}~d^ijk{kclwhkEluZ z0XUT{I6?`FP24puBSu(NPtg!_!!-Bb?vgD;Vx#fiRsxGYG;(RW2DF%%ceUOvGjm2H zp^ZL+oMg$&_fnxzhoqs|kz>m63-A7zC7~i8JC8T0Gqjj~0%@bQ9InHZF~0yGncJgr z36^pQIXMNR$1%n{yrvfxCnpZMb3QDDH3aQ^MH5qbkJ8oW)SI^p)NUv>*?-B4ijI{n z%c%YuQgjPsLdrV&r#oE|B%Z5+Me?;BA@}AS3LZV3_Zewub7WeeDB|Di7cTE?;?2z_$|q?toho8aMBxRZ$D4t-;B*7DMzRa~^3-ynpSl*O`M)cObBt;n zZUhn)W}~ecJqb<^wJE^w^NJb}fE*T>U3yqM@lA(~3^SXE4En#mx?c_BukXP{S2`4p z-XE626!m4PtVXu89-fQqaM26n5e@1OZyfje>6&8TW^?{;O0gWgWp)U`90hN{;JS9C~ETYCH!fo z|LB|C(~AjXXg7%DCTZ=N6Z4SJ;sRvM&-;!Q)%bT*iVaoc?UA563)=@n`rXJSD<74R z0;=fx6J%9`WCUW<5=+G{xVX46$>$!pzr{d_`0sH>IfwcNTNKeDq0>i38A|VqeZ6b5 z*_Zhp1n2r#z>{$UU&ac(_*3v+}!2%NHyB;k4tCU z22zTQF@(6ozH5zW%VPttDPb&MFP!d$9P5UoD#wCG%T@rLXo*w+cr-|!`npE<#~p*P z=JLpYcPU}{A4Qii0oebGVRPu`QgZN`6?k8iLWZ!y!T#33w7{?a?}R|mZ#_7>?>D)g_v4($$K#vze>dlDEVT26 zeLsZZzVWeD4@|ljHI~ke?@p*ZekgAY5d5!4@}RieuE*_DEZ?55$GgyyLd>5OsyUg+ z0O7&zS4d(enww7-Wyx2)-h@OucQ9`hzDb9!xbt?gjp*}RHSOR;WdSNi?s=a#5h013 z>)!L7$4uV^I$hXPh&QPXoMoQsTkT>K~3C`4}hnFc|aK>0lFOg__8GmFE&ibbYvawR2V_w(YYHu zBGCqTl}w_)oNyrrUgt*QKBH)8!|O0rf2Rblz_One;_WzcNldA#c$##3?2Mk|kG^!{ zJYh%7txPBdbQ3GB!egjXs>TTnH@lVHz9F=yf+9m9i1&hkJ67lDBO!Y~k5fHZjRgZ-6ZMx?m&;(=04v{-RH0N5fsk(UWMg=kT1G+g)`>|`^0`PiJz zNFkFkEE^Ke$tEtHBM(vQy6AB2(ib3oQb2PL7n@_t^-d)D{F?b{pvJR~x2V6ZY{6yj znEN&1T=)4%g(x*(OZJX6--=))vO7#N8;BnWi*>0Ygq7fo^327&3L~JGO)?C&=8SBv zQiP{+#EZ@7p81Rok;TeoEll>-xEv(=KM=MD6b=?Zj5M^!Tx^Kuko`RDrv#BPcu3+fmJc*ee)6R%enrP;xruX!Can;^_LnO3 zT8Yp(RfO)nrvp{E$*nhcAH~`K9mJb}xoem{4lbC;Mx)I|uc)xW4c`2LnlX$Z5-iX; zc?gn2jbz#0Ay@krZls(M4+w3SaPr{w#!)t-WhDYKrqSnGyhHP`1Q%LSPE+e!R3?%q zC=eNRolDI7ob2q7Ho%i6I={1}lQ)geWbW13g+Z2s&1|VVwj-H60&7Uh7TQTOKX3-7 zF>QXJ6vMsS<;nseucos>yvT2$i?&h-^xbi0&j9n(=_iPs-y*df3q#GX-Mzk?HK0ec z(7?*1_RebiYww=Zj;a*M1dn2oC@D4b(vvHT-`Mb#y6WBs6DIa)QLT^DcK_)MponEUBC&>kNcNw$`p$ULZv-I%mwoR^8(Vpbcp=w>cqju&r~ zW^ASg3rU98*=KrNb^@E_3tXW48qszJgYo4cJ3|e8sg;MPVB;$E+2gYkZp*VLZ9LvD zNOr3uQfMb|>XfeYY?M8j@-djm1i+K)T11CaF=JgS^>?)ypf(qm?O91k1ej(M4Rg3=)u& z=%e=8$#RK|Ot@>pMtH9A9u)xNk6TN&5KLL)9$QRhzz`nLA{8Fqiak(Iq=}@Mkv4#+ zZq-x2zOsUBnU0|`ePI0KcuC=y8AlT>slqqS3V=_|?WVzk4@S9?yzhOozf)=K5@Mdo zdc8K|m6W>zm560eXcVja0p67h;E@ZID+OAPW_M%uUIZ1+om7n0F+CaGnM$BY`6<@# z)8k?p`|C(tw=-Qq)elTAb+eTe1hu@O__>VMp)|Bdw|TK6aJA!TXs(!_JCVN&tndiP z7@%|%tSVWEn&9?^qIbdRghR7hkrcw$wO$vU7;5@y40hdsO!x-JJ$602@mt4iF|&Hw z7K_kl3DCf{;ru!DaxPIY(sVW@4<5k7Jxg6?J&1ed&IsW(IJr+=W3&5sj-4o#N8^l! zE*V`BhndGzYE(nuXp&|#rcl}Ma?4OBf0iikX{SN`88z@h#4ZVqm#a9WY7nC8YEl38 zc}38g2~_@X&;9>dbQ25ve*tb^{)`&_1Kj?9M-3xPjH3qruKrzUqg5+H34~s2LfhZ< z#AK3*v=k1-S+@QHRtv7;5g#u!Z3E8&2-F|517N!~*i+vjCBFwA<-VTZZ$=zmURL4n zIlXQMZm}uF{5)1$uYQY+GK{qwT;L)G!e z?hbZqx8Lb-pVqdINok{l%*SobhY0P7^@Sg9M@mF^6FVgQt4W|C&%|iac5|WKO0VEd zSSGyggiNPAWI`*PL`hb z8-u98&f+HHXb~dl{UhpK4yI#7!0lN;4cg{g75Yund7HV<*V-NDSoC`R#uTwsBnzff zL~ifP8MoVBE0jnQ=;B;AHenkwFRu>AEJ695P9sp38;uo{C}U@2ag>?!VnTQ`-5E;m ztw<$k^oRVC$`nAa3aMg>Nzpug4PgAmeFG7kZr|dIL_Y_as>>Mi7c2-_cu9d+LQpDS z?gsvq&?7S7aojnX@u)-sFB4^>xsOOeKv^;ep%C12$qYOk!}8T+f`2gFP&OV-DIvy* zImX>0qFoY492-P`NPd8?Q@F}qvjP&^Q8p~V8^x$o^Z=@x?I4sip;77%vrJszA;mD1 zcd?>A3s*xOnYaXyG^$$){E5xak=`W?c*AvpA@)5=?Dg3_jB?ES<;oxg$ zn7vS;zzaZ_v+!nX2)prox06AHvA*`D16Ze5og?Y2yjr`JwOd&3jS6xHIoL|)4yvWi zh0O5qTAyrQR$uv=A6b8%6KBArT<^wxA5pSJ1xYnjQO0xW6sv7dQZst#d>D^8jueKk zMqVmn&Ozl2U~$+OVCn7cbsbc0RVT)^xkAu3cOc&N8V=q^VHK3c$Xg&wM>gztZ_XF?IKp0n^=t$dZ(cW4qAjD`WH?zzPUN+c;?%{0C2ZxaE9`azY zFr*ISE>3T7{tE|X!P2(eC~)igOVdelPv<2JL^bITa@Fzo8IE;*nQi0#4c+zZ=)b#Z zGQrsx_5Gy;zSv!hj{ajvWvThG!Es%?jOFEazP4qxYHfr-iMiRn@lIYw_n6%`)L5A% zqBT_ME~6@nd4upM7hYCEC=?Gv`q%*?sn(`R(MtCYtMVwWi{*`qzh>oclxkzhBkN9q z(f>O{Zv&x|d6v@KQ=bToExBtabMDYLisKoR ze81&h;J`{F%2ICeAjZH*yv`s$4cIuAgtfJ z{626%HwCVY7o7?P99U+F;g}OrRC;_LkOx-p4*%`;{J*(l|L+D^CPvQxvOOPaOvcPJ zB6i=SdiXA@6}%W_U+#ey6zQQbSOt63OnF=eH~}iwRqSV zlYIPM<-GY8arzMfc;8RgoPMtT+2SDRNiVkZf^A-n^)Z2+;oyd?YA9Ys_{|4xK*uM? z4GQ7wk2p1b(iiJRbTIq9^r3=--xr6^=FI|H#Xc}U{prTgFFW4M;Ts5F8d}@8h@hX; z{W@zR>iK|dVYu@fYi%0f|D21b0mwb{x{QwDkuU#T^4>R3yk5 zD0BsPdMH|i0fac!Mu~qV)`@cxqmhKev@p0^u5|M>naI}*m_KFidb$>Rxa!@aQ_eyaVhSh+4OgW`b^VbO*s=holTF)~{c#J5VT)HK zW-V#Vn97KuF^y;?up7p+JsN3Bn^PQ?(~@X`n1@OGOTF{zgdINB3r=G4xA*3Exo=9x zF_fd2@U@BZZxa+q9R%sc>Fie$k54=}TApZE)X=i3cuAsG+ZiXXx`Yuoj2FWHK z2b1>Gltx$K$Mi*ln!@mjjDN+kWn!R-Y6g1z3)uZiWEV#&I}Q;Vr?r(g7;R&OAWaIS z<{u{XB`LSNDUS#2nlQ=N`^6AJwy$o{i-o1SRHH^(fk26VZA`D37Dun35dLz@;t58P z@Vl;U&{IPEZL#XA`HJ=cE?pgUst&FQ^YKFDi5iuF-$8jypc~d_uFI(vG;EHR3fKFxb6iG}KQSZEZuLbl}|5 zkz`Tz_K0~J{aj=m{cDBl_w@v0#{}cPW`Q%=KzyQG>xpZen?kKuZH?iC*6k4lj(qg> zx~vOI9~~N?qD4fZRLua9N&FK_+R|OPBd|fNUzzpa68gy3wvGgEkdSJWLQ@ib5EC}b zs9^P)%VMsNV4F2ejDyR{5o$HBaahZ_$zSp9mhm=_HM{a>xN9b{NYqwlhi0>1XHX1f z!J#N7@;+g`fC)xz49$;~JCf`wJp3&wQwK`N^-7|i_SSA2s`YG>+TtZJvd(u~vdmia zR~0G-p)p6~dT(u=6`78xI?KyYVG@Y)kWG*@uaQ$}|Gkm9IR`XVk2D zc)?jtt~k>;RVt$^0X}PiCBJ_4-f@VUtiH<9u+;69TDNIEB4M)KOfjQ@8*(-1b;5kt zb~AIR83$rcesie0VczrKK(I*-F4Au82>%+K(tLji+{#&}Q}jtEi#I(O%x4kGgn?G^ zw9&ycNVZBgTU;d7tN)9!bBYdhUAlE_+qP}nw%KvVPCB-2+qP}nPCB-A^6xPY_8IG9 z-GAe|teS6C&1aU%!4j^_%rIw=Y$+!wwYXhvx!OEd31q3`R4rstCyZ>Vu`j@dR%>Pw}rhdxM ze_~mbUqJWI^w|^+YkU7A5^d^2?3u1C;Jv>m!igvqqq8^?8g(0iN03OB4oC3kww~o& zsXiBUSx$S-roW3@_!o9s?mo6Z|D5r8GiEJ+{_Q%Ib3}K-ADG4Umz3YhqVw@llad#& zm|vKDIf+y<94uKmb(ds0dBBMV$JWhSeu@Zu~IK207-+7yplm6?bl@_x4K1F zMF;qRnWPG`vad>OwD{y;i6ABu=#?dy2Ye8{!n%fwas`{h7U0~F0#^aXukH~Ru3xFg z30hebmarp!X=Z;-6gLNn?>LS|>!yK7GYYY4D5~6z@6#Yj8}5haMl1nh(Xx+;P=SeI zAQID8+;s~drDhD3?R~ijrh@^pOiksN1Qc7>kkTc6YEMe&^;!Y#LO;!E?F~qQN-W0? z`mi75Zkkwtva4=efQx{Vemqf29f$H&o4E*)AT}tyy0X0*eaC=M$nMQqlvdL(W?ME~ z@Wt{3^|`(iS-cCBI_6!I@hh)R4(!md7!PeQ8N~zlK%sx7C!J z3D=miAZ%pJC&)6Oj&ue2d-04QZIy7s*dq4;mqje-9b{Sje+^4ahJcp%wV^Z#TntbR zR_>+NLmF{4)P0t6?t}O0#o^h(e2Kc%DsAI*tks<`agC!+xKXPuNWt+|8gr<#Zce|r z&q%i5&c#6xlsdJ{wsN$Bx3>BS7aobg!NqRFrsBh3%{@+Sw1>K4+T#F{?L}tXVlaRV z-)v;v;+mg*B*-v#qI74tnjF)14{$^R3g-eVnCziIFEGG&q=DHPA#M{aKIS8K2fqa@AM*KbI!YIRkU#FOrxhLUbNZ zdOGHjMM!eNj{WRdk(f`YsIDw|cFIxu#p7?R6oy{nhRZPgH3f!vRZQD&(vv(9sES}0 zekbZJ=c=6FAvq(^q9w;9oG_R-@3EeuZ+195NxSHYP&5((&;u zy+ceW{ibzd({C#01Y_C$A(K0<781f~9j|V9H#}~rbjvFz0KZ#Wu}=qC=fW4f&83=N zo0QLSiQB0*Mb%A>VQ;o_;BS4E%jPOm?qB!LX|BVN%&?yP+R`k{KVu2?By>G?uy6nPDitgH_>yt9CMT9Of)=?UeM5_^0Dn#u27}s^w_4v_Ws&|~cIn-X z0vlMgs5th%h6!%V#_Xqr7)4rX5m_zjLMp}cuz32yZn2KDHgkY z#PJ}F;eg?oNER7*Mn{pAOrr|H-N{c&D8)uhw5a(9okSB?C)~o$=zv?Up2#!dU1=Ak zgQi!6AmL5w740lau)6Wu?6GRo4797lI+bmb@nUx_phHC4vw3J_)r*52d+Vnxmk?sB zE}Hns0P$O$h1SK8%@M~MKe+Zn&|R}YWpf;>s1aNje=$}?tQ_k~-(ixdGc3krO7>hW z4|!X=Z})R9BeUpZP-5(KsitIf(@3XSR-Q-PlEP|-`UPXve*`^Or>x2TnR;p7rAMks z=|=#!h-Eo9T`4_sJTR8MlpTN0Ty4dy=;s~DzLbkINW_pS9A3{x#9ZBZHZta|@QKD6 zsN!3fSrZru+Ucwvo!fo`T2YQp{8J-g`Ik{GO#gM+IP?SU{XY=+iWX}F#t$MLh_`qzm(|@>ar_7^IO-a&#te} z=MNL-KZlKfv`$!48M?Mha!)XlPf=vvR^)41`1KPV(2F|N#y69oTAX?)Os8HCqe5Ev zK28j^zpeP>l|^z|-pCQwNoU;UR^P4ct@0C;@XUji~%a><2JNf2q* z6Xfk(w1sfOHNWS%IcHS#q@W)n6N$h3m;$QDTfNk(TJRLLgI-*EX%)+@7r5cID^&uvJ{ zqWV>eIYPELV~!xy?$K?MIY*17wVS~fjx7)w{d-kVYuYZ{CyY<)!V=fG4b(Hz>k$=c z5f*Wl`3g&@gm#1rS~>!GHohnrqEp`@1=i9L0hcrduxVHQMyrE9>pEC&j`PET5x9}S z^On=hoykZZBlz5G=gsRl!vhB>?h9od?PtYCk-*W~gzlDJg^UY`eeA;2KP&kIIscv^ zEFskreDZWTfB-A0nBbXrsu@8*a|-GFvSnAjZ4Tcc`Ms!Dy{}clFrqsB$4`CtW9e!^y?Z?KL05NP^3$3VWL@D|i#yC&41hd;~J#15AZ zzy#c;z+Ygo(mvVtDA?2f9uIl{u_VH;<#Lv@Uv#`;L1l7H+jb5Laq}OdH^CdTYssgz zeEMVYQZV04Yvq{nPU|nuo#CWvq_DcTTiBIl?9UDw0FvZw9ttu5XWpC_adL&naeji# z0OUWN-R{G~yM$T6*g@(|-@=`o@!B>&gH|~!|GNR|on^ z4Y=narqwX__n~Jo@ybEF_8yK@tOCh_pB5Z>s1o;VhYD;GoZeEUoUTV6yY=n304Pf% z4ds1M_s(MsQN#+akVfIHr7M#b<@Rgt^NgKv99$(3ywj^ZsrvF%QO@8t3ekPu)v4JoC+75ctbS z5Wqm587_8)(5JxA?g-B$my+YOzzqv+-BH*SzPJF}2Z&QqeRp+8Yx48Q%WWrn?(Dpq z7S`0Y3n54LN-C;(Q5`K#5dfoUDt=6eNgof&e5dv=Yz<;_z@e}VL6Die)aOeQ6P9l( zSTOY(?H;2PSki~XNu&4VMw|S%=BtJDl3&fMn@5Znc@E|b9%T*&_38)7k&HzvC5bw3 zh=}mX=j`D33ewt)rM#QTH3gEE%(sJjRcR4pQMp3I;UE_HER25}#{Q7S?OG$@@H!ftoB26p`>HN_n+>l_0kxe9cdKTr6KLxDWuyZhFjHNntbj6T!Fx57t(&6L(_CEg}B?*PLK`_(N zxeY->KMX<2o0YxTJtqfSv$(!cq0PPjW-~vyWGa!+_B;U2aZ1_FnF8JsaiH|u>wdq+ zj*nW*o#84fSFW{$YyJySD)4yGtkV7QK#%c9@$MhH?7xdz;b8f%3&Sog*_n+W|G@Q6 z)XHE|DLpoY14b>}YE`c%wu`wQJNM=6w@(^HI1=fE+`NmhK5-bWB8uppyM*f-+o|M` zj|UXO_u|8s{Kunb=NDbhPO<(@F?`Ns<8%c$f7cdyjafxWLsWi{d zT@OaEeO%;32QA8u*`o(kp-%i2MYI~)=(byPPibPh+Ch8-(ATKqIDr6HTg_cD|Bv#- zKQ;Ycnp!<6oRXyJ5%YGP>aUJPZJNKb`z$?&T<5XawUA+^7+Wd{RXAJami!uxFqcKk zpug`F`J-|Kl;)wkjE> zQL*{;g{65Od`{+#?2V<`ZvJ_E-Tt42ATq`^#TWMUjgu440TT3F(87Ctx1cA5e)V*D zJe&ITIT}yYsPvU3HCS&w&bE02(a;0H@fVX}lb2;#`6;7KYa6#Ustbkgz_Ezsd5^TI z{fYjnv|Ul=A4S~g6<#B1t^QLME}U)auR~1}z5EP}P@cf`8syk`W1U(@T4%Y&W=tn1blu? znqr7W`r=Wt8sd!JS28K0%RMosT>%5IV;wJHJhfg3@p5t5VHz^9um<0xa6o+mWF15A z!+MLy%01t34`r$~JR(l^O;#*hD@|_mb^LOfFmNwQ1vt0}2jKt$;N^K z;&jn$2{V^6I(5!IU0Txk;IFaI35}{mOt&W{JOFQYVw$mtp(LrAP0FXG*2$`jNO)}` zQtoxGm{4DzeHs}(gP)*!nJ1H?-o0!=4F zpR)k^T~@8}CTR4PXq0HFl9|6#%Cgs>(<>z|SX=li`(`=2J>Q7049UWN8uoNzJ3|y8 z>#+fy6bbwf&)Z_S?vg3D>BUltH-0nX59GF14mKc7SW+()Aq~U`{-`xjIKb()CR0&u z|Jk}w*$k4&7CPkzg1>9GlazRN^-DZdvlb0$7Vs#VR}h+!n4|4p+vK)bSTT{l6_-d) zb0sd)HMx>>N-;Mki>0~AG;2SPf7d$^!^^B8??8e zdbue~RsqSeKTz14?_-@{@xFM$++h$_QXDKIS0cH%D(8XB4L^gp=SiZ2j4vLul;$G> za{_T?wdc!ihdk4=EY~nZshv6<-@O~eSI=&%3)?a~&Wc!cgtHqQocgQPP}L&Ss#LYN z0B@bE`4kiVO+$J}9_6V?mn}C2O%Tya??ft&!w$nC&35&egkf%WjLy(;{B8Ow~(YORnZHu9h=NDxd{<|1= z^By`#ChdiKXmImDExMh`Ly5nUMd+s~Sj*F5_ix*n1V%TaAC)-jsRWFO_UXe>fSdVmqj&X*%I$3-?!jAh4A-O-s`ld zSZv+_V$+g_NBi6TT*yoBH4S!>sGD}+k`+ELbro^5&t-8^o4qlGn9hJ;dykDS!rG-Q zaT9(-1?`>o8&_!DsT~qB#R!+bgaqi-U#skF5&vXFIy3_dzz)>oERe@V!%g)`^&%D;CsuW*^+4YK5Gm;T>o}Q?ltEXzw2*&6TRJ z_ftXLJ{~gD(*&}Cnp_PAC#G9-$-*OFc#ZFjg$a@^m+?}1Xx*buG*c9>kHjy$X zCgcaHw9KN8+TZhNMJFC`gqGai^3HUrSRO=c;j4Hw@#B>V-{pY2W|s!-Zpf$clhpHK^YCi*^2y}& z4i~UkFpm~IVN>hiF`|hyq}Qy&>`?zmVddK277PZMNKe%jGYsL#pt936@s8(!h>oGjgf zxtiphQda4?SdKgl52d)xw8Ubt%+FQWX$YCslsLZQ)}2Q1(4ds9Rm%0pUV=X81xHdp zI*LL328ymFMBu1WJa(3dmCg0FS?gTDVY!%QvE909!+kjT%!<|HYA9V>1aFnR%wREF zWO2^WY*(sFap7E05Ow~nTKb7V-hBQ2SC#YV?@?GO-XM6zz+24-Yhq|3r8T-cqg+DOw^7MPjL4e zev|G&`w-fZt%-(rx=ok1=99x98HQz+P%N&Qgsn70Hs3#cfo5-NzK}aYw=6o+7j(2q zAj)KhtLH?Ao6a{GM4IY}37o{HX-fBnP%^#4k{ISp8#)FWDGUXsM3Y`@ zPHQCW(-ZS^GNdt?E!l|{{U$^sw3;iKyL=Df6jx6fMDoqt7R=u|oi%mpxIrjOFpSJl zSFfVyXqCms?KpWHpFQ5}Lpp|Z0GYEFC02qCM4yZ(h323$L9r~co?vjiUU^|qy)bg(S9YB*@u{bb!oD}k&b511uv#g@u<3(fyD2xvk4Bn zB{*;($o_}1bp7GUCH_q##uW&D25{$P^v&I%ri(YH@DEt0cgqR4Ur6*W|E{~2G@t7; zkF>Y-^v`$lfcPrI>S{7zJz!qSM*6c}D0!~huMAJDyB$jJCtNxa%te3WPN>5^JEYBK zXCWWzN^E#kQbPJ`JUx{yzpL*6Zf$b1jABG$P^m%D(vr z%jG`vZiV|y&bqfGcMsos)}PS;^S-_19Zs|Crte7PYdxWU0T%Jsyw*0KV7?RZJzz%7 zFu!p=u7L`E|HhI7AyV$)>as5?liONH^>NCmaBhY!S?#|^Y#7+-&G=4L>pBMJmI59a zqhi!b+WsU85Sip(QTp@o#LsUhpZQNsiS^&jU0E3Z3q|)oXI}r?QLadOh7WOE+uJN) z3qAQWcgAF6=Dx|X9*6k z&+GXkJc>KOSf@k-T_lhBEXl&4bQpuWU2!A^oDf4zgC3}4czC=W2RmL(G)m`R%0F6B zJMu5MkC2%*rg~d)dk=wE^AZs``zYcn!~pqRN~Ds(Zs}C@k&AyRH6w@*H)OKhYfa5H zS`)p~Rma7w@||atiJ3_J!)Iy+QeggIM%|;=mIh;OJ=)c0Tl-%{f#&T#xgq)Rhxb+d94yFN@K{MEO93Ur3@SSiyJTe zRp@yrO}UrqHBxY0m^hN!tpWfu$mtO2_!m#c9Yu06e-hK|T-tSr(x>2+Q;N}&-XKPk z8U#K?(^#Z{YQ9EWx#=h$^}~@N-H#R8PE;8=cN$Xcb!e8ssUwPK6Xpv@@W2dni z3L0O#1bj9}`(%EyvLJfE*?cQ7>R5C@zZcgrKR0;+Dz{wuQ4nx}E#OK8P^byj8FOt8 z)dh5(aa+p2bl~SfZK)cLX+DP`1?ErIvW}9ttCllj!-zed)#(tANy~POnqGtaRoocW zBp94atcrn!njNj4!vW=8so_8>EYHhOZDz4B<`$dGSrKkQLXv8fFP-0>3WWqBoD^Y0 z%xM?h>wBjmQvfLlXFDOf!>I{JD6#G=W+QC`1bGj-xV`-KCJ7sy|<`g7u_tZKpj|~xTZ6%8oawM1XfeMhbNE)0h-0wkE zI8si$+5j#tZUi*nmK6q11Yd>ahB}U3Xy)yaaz@ZuHmYw_fWVc>wyvakhCHjK*=ph! zfWHDZv|RH0Ci=Ic@CxJen{JJEjk){~uh z+q_p&<4xx*mpFDCyO}I9x4+$t@~5iQE|V{1*GoRhf@!0S){`nz^*XzAl%&BYx$ANl z(HEeQZZWanOL%cbQ?&Gn#Agnd2`NC_liD_Eqiu?!cgsz zj0+@*hWd7m#xjD|VFI6ML1XSTW6{aN$8mB|VP2zb~j5Jsn2)UxA z9)Gq&NB10lwuA;g3~!|bVk#27Ox7>QX54jWI<+Umu@RcbU3{Vda6-|2kACNe^--O| zt%dsl=Lpu^%+=k^MJ9^BcpP}se|c=YefPm00=I|Lwjjovd%9Oqua|+xZR?RNY;~`= zeY|jL^cL?UJwTVlT7 zdcGcVW?tVXE?ZVMYJ5sJm}tQ!FCX2R9qNa-uE0K?y*#(R{vZlz68@qLbU9_70N3!@ z>Ic?og%|3*w^xVy(9gZ8&ZGWyYn*MU)0)4JigjSN5aanlEMt5ZTbo;d#|JM>XTijcKgO{ajc_g$~8vZ6sG2h#*)C)bT9rXfWV! zCo&+zJFOVUiWK?4{dRHpFrC+GqFvQrG4C(@7M#F?UYKi@`em7(#qL*6&o-X|C}0Z;WUn;D>0qHsFkcv@l{ZCP zd7$TqV4ARIzl*%cwbVRq!hU~3ipx^*@45M!w$?HKB39k87p)aLdG&{Mw8#(Yc4%nB zswrtDV+CijQ4O2khC}r#XCm+y7(_k&Ad>M%n&SN2yYk+Xe60wH=&(d5frWfBJA;WS z`xx>{vZ!$sAW)d6Q2tRo3qi4S|2J~h4#0~`1vViGVd0eg(B1PCj$*I$bf2X-*)QAz zOOd?7)W$f8++8HUvxD1I4qQY(v@j}n_|T*{Qu-UFUERXM*=+Ix8!$?+f&H~C^L3MO z$8cbS%o@e8_I`3006{?i?%4is*z>`pGqy^udtHao8`;#6@(BpaUz`KsB&o~^%+RRo zwyh*~CyVFN0%e7(7}yg*Gf7|)GSyFnritv0G}}_&AkHyyrv?13no>caFl=Y*VY}fM zsw-Pb66WAtcMuDz*u@V3mRZCEjU*JoPh$B=BV(u=SCVr@Q@oilFjkazl9U$i+Zel1 zW%~+E2Q$&JYTj5aHC}{iKFEf-atcqkYI^KY!HSZR2%JK5L<+Sml%dqA zN*e9zvRSm*?2jg6#aF#aYLd+oiIMdL7L_ZDt%wcq6icB=^){aBz_vJLDcwaXzN9U+ zIFCnC$@7>@!E~9k$?rb!(1*i^V5!~|SrhvopZUa&`0XHsZw-|{p({|zldtU6=@d!7 znqiHUa~flM+kH-J%=io(SpJF~@KPu?ta5MHN?|=g#cb_Y#yA4aqe_WoALyO^VzC5q zt*i&u`E4eQ=$lYaMN!d=VkOZnf9}ae$30D9KXebrDp~c&<=XOFrAE#@Kn2lYK&=*# z7Fb=CVXVobr>RPa!dIQ$861{h?AzTf=JZ>l2`Zu(M=cQcptagF>VP@XFvFGFf~=TV zTT})?%W!G4s#oWHHr+GLd$B_PSV4nV>09Trs45zdHO>nL=2H0J66x^qHFRWsmq9Rz zE2y)o*Bh2~N7}Ec;=rr@f^ftMRl*tD!Eguo2*KB$@*zeH${t(vZ@K6@tnk;`x0 z-po1lRNkd|yRvF9@|5W!e_Q+#<2KqNE|^*-0!b5<8OaTH&lDWoqv$x7AV~*C*g(Au z5`*&NhQYrxWnEq4?oLS@UJ93guF(1^w5dPO^GOzNvGq6iJ5Rc9+n82))nmiyh~#Er z4dY`Zg4T1L$rfuxhjUtgm4xKfE`z9lMrQLX3+aHRtH~&PwnB~#5B~bC&GfxVF3#fO zd^DWP1BfMMh#(c9vL{J`S3Jm2YNb5Bc3m187y+{Un1GvhXcrl55;af6^#H2y`S6X4 z|Jo7mlNy$VXdbymW7C%414RYNn)MuqkSeO|-3!MaAbGhX01!ZoF zfj(#~Rk|p}pPNLdfQEcQdm8H732!-h7HVwH75vK}tAGsDk*gL*G0Z1R+Yt&m?z;`- zY7tXeWlc(r9yKOQT<(}dM|boS&OztIlW#}&=|?5}xeWwqyoTh$6LGT9#U=_g2%Dv&hb;R>EnjtX@k z0WWA?P=`nwxol4Hz_)LuJ&lLkHpZ(Vk6vU47fVmgf4O$nEnr`HcG-tDK`(zMK%+q| zmMjX8RO}x2MXdQ|d$VtYiJ5MNunI#3{7HuI`2gQt-7@({74)xSznK^~|4Rie{ft+! z+5ZOx`v9Cjw!iM1E9}c5@EhzH?Qj=Qlk;fzyC+aPZm3AR3R8Z!_qVyn5A@mNTD4Ao zM}B|sli$96_xpa~od4^>)#rx<+mrLho74M^Mjl!lCUs%r(*&epIBOd0qlT|*^Q+UY zx);BNTI0LrNZsyBJ>r~G&o{~OcDzki{=g#KyUbR_KVh?rCP+yTNAuJnD5by~5Zt!K0Vg~4Yl$j}t zgRJ)u<{i(pbvR48Q!lRez$VjUs()_}X1^&;{TvZRW3ZqjO~EuxL7mR-k7m zkc7b@3p4=j@CcfDqd-x}m77lO&Y*65aa^>q2oeSfzR%qbU_Ov<{KpgQX~CTt=Y z8aLyID^l3)@^j4qINZD)dN)wL1;PpDH#KxazRMdJZ!IeiP~TzUbTap4mYH^zQ-fTF z>RmzaNFjHuDa`BC#Tu4V2<8R4A>EA*{%+pXs2%`mmRno;5_$+uOCU}mj$&9W?CzrA zH**OHhM~+nbl!7OEPN~IuuyXnJz-86-BTE>K9pZbgj&qNHxy#&$t{3(z&H?IQrzyI z588metrY|5FB2T78mUau?&SXdleGmZ!5K+nYdHHrtLr!m#RPqdEYJsBz%4QwYk)+8 zt@GxL(dA@M%XHfYSYZ8MXLq|SAF*Q0biD%Q?7hVX^JA7{qmoR<0s8%8{+hpFPRm-i z3Z3g1rg81t(%OVoMqXEj+KVKtHHnoy{Py6RPBby5dug}YyO*ky+LUWMS!S-~Enn9jHEkJ?t@>(1=YgXzNalxp4BEON7MD^;2nG)pUu z?q}=ns$pA@jI^1TsX-vb?5XJEf-(Tg+#cxysAaSk3NwUZ@Z)C4jtzFelI$SIp znYGO8<2HAAGboPMm2g}FP~8JhSQlQ#t6JU{;0Z~h_GdPu8h%vXTCs}J zS(_w+YBffJ=mLkIW%js@UxAR)L#7{Ej%Nrq?$_W)8w>#3KwQkv4?V$|tINgJt|a2f<6>`gPy8YEsu|gkdN%pJNl`db33tk*OkYUo zpB0oTk4If1#GOK^Uog2)bGXKjKsK09yeNHkH1$TRCZhXE2b7_p6;r_J9oy;dP&Q|- z&6y#X@Yqd2kbXJ?^3vbSnsIuTh4&V6_3g2Z0}V5EERu?tD}`2L28cgRt<4eR+Xve# zxk60t(Iqqkp+L#yBBW7ImAO{&EO^@|?C^kva-JQlYUme)dNy**>*k zl=(+SC$fM=)u{eqAW}alQyEdvd3&IfAPsGT?H=e?pv{O|N!;?R z)OmA0?(|krqLN?WGmjPW6TzkX8j(msWl{aMus1-*8vsOUp;o-wq|@o5a(Ewd-SQJ8 zz=<^>Xhz=aitet*F%j8Gt8(5V~Axf-^ewpchn7wJE zq1=W^2?`sUuq+KYaNoL|z)+wp=c*{YX41pA6wRamI3UhI$35_*Jh+1CIopzb+72 z%tNRdKh+)NmTZS&+n~UsQM>m+WWZbDLGeM+y;8nPV3qy-RGb*wnrOq(xjBs~>{2iW zNFm`~QoP#-flEmRAH*%W^RLZ`XnFvaDxP!(m> zhNW8O`Y*%BO5VsCx}cUs@pyNeD~JS2@y$kLvTIzkF)O*v+wqKx0>a`0HBa5H+)&km zGlpm%{JgOtDq^nk!p0G!&rBrsQsRu#N}BD0rd4*K<9yccP^n|Az7=%FyVkCuwno3F zE_nC}>*6WTXc@qznjFAcWK~q6vg@jL3RftplNI$~h<`b@79`(yFL{SS!0H^R*?PXS zAdcU#yho@53~h&IbUq8Z>w>MzWsJXve1~8#o)QnZlxDJg_@4nY1FNE`k25m+Ra*;$ zdz*p)tU8@GQL+iaWd4Z?;=DDZxV8JPHsI4yW8fKn4h&cL5CY~VsA+-c@bP2a+r}j+ zXCd~(smp0S=-H*_P+8b5 zs-4Y<78&yfNX=ieC&q^|1QT}0PD?5z1Z1CdGDxMF&v9=#v#Y;*?&SD%L@n7ffF#XN zNaHVExY;$ZO(z^jvm?Zioiv%@(cXmJ3lwmUmhm1C+`UgC^a13_w#Cedz43^pl`v&+ zdfjlfU+*S*&UwP}|4DhU{VNDPBP%oG|4U_U(wwN?U_;n?{!t#kM)#yafasxEK-;11 zTt(4W&@xrgU%zF|IK0B=o1D%G7_B7_?T#nUBd;DDl@bPhEbn~3kDR{IYrY0&V(va2 z-#%^L?xy4fLBM}|c*-zCpch8~?`36eC-?M7Spe{}Q&#oG#Lr89fPC~m8ujf$iMyJ4 zz4a!&Y-|=SUcb=3rnPv*EK?*NK0fBO^eBWxC=sn5fCE+wXxN zAj}e#It33f^GIrHH233fo4krORGRl@$*V1E*I!QKc6+ApG5F&IyhE zFb;VFz?6*oNLRqLk1{}C%UuwmSl{i8xXWk%@(A?ec`qWw6|S+m4{>mZbO>HYCl*RM zx&b^&Z5mW4auo~y4pJ9sr-`1xDa6XRFh;?Z0kffne6MQy$@UZBc2Rb2?7Ks}nBiGI zBIjSN3JcjESR2)Q5YF6tjg7AA`d)rQq_X^mq_~!r6Gib>%sPC-)moRgoK*i--y2>& zLp}*Z&+Mp6%b&ynAO>=({&bp1bR+R8e0!Z)g0+9ezg>LYR@Og=EW#%R@T3FJ?gYp0=m`3bca7w2s4qgBg(?1nqcjS}xM2qP6O|6!&J|W) zZnIuutz+q3(H5|C|7ZkbfuX5OhYWpkk3koO`#Rn4xhnWdSEX21Uc{h8tpzu*CuC;jGm5_rZ515?o-8)ogb`^72;NV`OABB` z4Odh&6zf z2;~>VmlSv)S|Flo?1ox)h5d{2D2P+3$+MynvHMEPvSVGg@YcKlw6_!4PX_|-+_9U$ z+6{vgLUfkvylLyMg_2?hfCwNHj}KhzzQ6At@&Mm#W}thOFw0plBgeAIu_CUHw}a!$X!7YM%%l3onxVsK@8S!coJ|OO z#oh=PD1QC|A>;jYT!Sud(9hUz+wuC>8#ZU%MX94^`a6{Vn(zlQdl;vHoQ^hDu;Fcy z#h47t!kog{ZzFWZHCd`d;xHoo`>kg5R-RhcukmN&#_@6~yuWvc3$QRcen-d>$TpIJ z{)SO+!*GWywP<-xEvf@cdj)n0-Pn&Zl+Fc@lh(G7T&m7jLukng+$Nn_p(2-IpQW{W zecp(cu})gbMvVy?rm-r);%aPM&lF_IB0o>^*Fo`>}P2#xRqi)0VxSl1%Kjxb1|% zyl_*A_C#DB^cRzJ#L{dnS~t7NdRRPsYCRx2nmg0VvW&Q7Ojpijx*?A`8cQ?ulU6+v zcxge4=dOnpV+X%2ozu65_s>o5S1?@TK?%q$_bU`)t;a1%zpn8s zp3he?N^DBiL?yr{ONyh0&!0R8yO0k!+i7gwJ7w~ff7d!?1nkGu$}Ez&lcJc)xatxuS6e z^XOu9qr0PiNRz$j7kH+~9Cc7vCJjix5G&Ri7LDKyjR7|xlue58Ug`UY#FAzO6Bq*f zWfz|}OUNhT(R;xAyS)-X`^m{d5ytgc8F7I6SF_agc+!i9?BWR`>_RZ!$n9?Nv)6OY zIKNl)gdwKd$%Tw;TLVi)Umo5-_yiOA$MtVC=cn>b%f9&@SdIwkH3LYlDJcZ5C-j5v z&Bpo=Ey5G73hujp;R`FJ^+3F8MM9BDp=Yjco zc4}SFR(n5sU8Wb)tj+hE~b{KI-NmvL^=;XbMJXq^zew2(i7_x$m2Kl9-u;iTAuT zLewljDmQ_lYxvOpq7z6Ze>DJ(+}yyayPq8gGMZ%k(P*t2OS92O_8d;xFM( zN&9m$o=eYsPBewz%UVB2IrMr>ZmR#-4gM7fnvwax7rI*-UH`*eyt+sE<992$m;(z_ z3=s<*d*yrSk8;jPrW)?~O-4j1)o494{TrE}72C~b;p6iq?&-#{Hel@gB9`Erec&_4 z>&f%$Q#Xb`M1LpPcE_;RB~#dU?~+l3yO;wu1>zMWxaD!Cf^qwJ$4KVpl>_s@cjmNp zJ9CW5o^5#h_3!r#+JQuJ&8uV~k5r|37_IMw>kT{$w(M8m<&VcA zcxO8pA1MO+*ghITnqnI+Wh|O)9Z6E;8o!k2+`-ON6bXI}{0S7#2!b>#+HZQ+busV` z@z7F>RM-JD8BHG~?&M^{QG4rfgv#u2&Y@%V+yaz-NezFP+0uyoj2l1(v4{)Q1;((9XvPo9{ zqT(pjL|I(7Yp>47^lSj^(DE8>KcCe$UbAncE(1p$ep+I|t~;%082&CrPJaec71+}x zf7|?&<5&uRA~~(Wk^*hq8c9d!GS9)SzF!-$2s0X^g{wcIpGE7J-Kw6xTm%M29@Sy) zs_0K;@`P$h(7)_2JJ1yF0tFr zFgXAnD&yIsaJ7dkLK1u<2Zm^W+)I$RrS1;uQEx^5*(Bx38Y54+NJ>Z97pdJ4n6D5j z$d)815!VW{x4pYAJ{b-+5NUcb4eASyG;Q+zQYkT4Gu|%2(sXNNb6H-M0LSX-dZ}b9 z`$6bBh`5nppD2r6c)_AIordN)Rb5Rqr83l@+uG_|Q0~h&g(FNGQ$_Hz7i`97me0d; z)}#jWoA*-Q<-AAepfWV0bdkc-Uf4A$ISa_|OdDNWM&c%je*Q6QPRa4=a3!u9o|U(J zAr*8jVe1`fyB+>5fNcTq>ITUnQEArJD_WdQ$G2>l|Harlbqf-0OPJfXZL_v*+qP}n zwQbwBZQHhOyX$uM!@Xmihx3s64|2_!u_C_cJvbzas!a3rF!`dz`Xiask!iF8)1N${*{Ur!?z9^vNECmS0B$Zb(X-MvewG2ilC zWbG|$Pg@>8G(PSXv!1g-j`^MwF`wlNAC7dW+Ix7Pzc;+qmu@)z>>B`sq?}BmYHm_A z?xIzhFaJ*92l}ZjjQ?1)!}i}%Z~rjLfcf7fn z_58|4T2zB<;Z8*#SI&GI7ya#)aXNP8qQ;4hBACF;Mw~-;y+%N|Z&4_&RMsXOf_FyI z`g}?2L-y76r}i>)?=}~>uUcpQ;CiuUG|N3254)PF?gRVeJadGDPR^(75+2lva6*Xp zP&ds-D*d)@6B7frNALsy_5<=T?XwK4mdSgn^sJjIT$M54ica zfT6`5ZMa+mA(IOx1S|t7Z@?%olwJmv?i{3^1+w4*LE>v!UC*PUb{sJ35SEiWDEypD zj0ZY&2G$lv#okP^;hkDM7pLWyem;$*prX{|pB`6YIt+*>A;^MqWLVo!M+sp0-kdTA zgS+Ex5fnRJ=RFav-KhEiEp%|SZMTAnM7)f(jT3dLwk8geI__@e4n1vs6Kz}Z{+Y`k z%f>#Y)yGGrixf23{3=kp3!MdB8+052k$ydnTCU%vFq0nhP@7462mn8df>iTThUlu! zVq4iw^ycj=&_m@A;v1d4Gn8b;|nS?0swH-;-xaNN{}AP-7(rQZTxaVjeC4Q zJu4T-W#&6A)ElzjYvlE2SEJ2gZ4}SsCvP)-b(ZywWX^f(wLO0uh17@RmfoquKGS!3vRFl6_EQwwSs6B>UDNQmt7eBLMxgcgd zN#`&XZabrwWG!OCeA3gGt!3|(zvKkP^&=Dx~9SIBzTpew;aCy=;aoRUxA zg@_X==(OCzTP@0iZlm7H7~Va=p6v6xz%eMpe733R^{OyV`F0Qld~#s9v3sc^3j(?u zS!j0Du_C{)lW~8l%C&$y(5zxdjeNso1ae8YD`UETur1x9d6Lu;o242o%;u=fbt6z?;Ha9{!`X_tM&tS^_lO1x$_XQLrd>(+dd#%;GkA6@}Sa?Two@B zd_3v*-V)^hpB6c`{|chX&h~$V;c4}0+pK?(w*O&h%6nbaqnA(QD=L<^ihEUh8bES9 z$G!GC!@SXB1dX#+AT>d^nDxAWnySByfE+%NrvZMPUcH3g_|83F@a?X>Qh$B~S6Okv zX6T4*tOGe$&Cg*)UvYkYjI@KzM4xEGK6M{zZ=LD#Fhht}O17cCg4jNie&ek#B6~&O z`_3RPdSR?6TBN=t(34EgEgI-HGhV}qKsaz98s}xW1r{Ywc3BC|^L+LEkf1XYY|64z zzZ0!q_!Ezb;9D_4DoS(|>mh#^Ddds)@Mi=`TI9b*T0+b|fe1{8X3r6x+A?J>vY$sI z*o3}8nqtNV;F-mN9(|^ie5$C`CGD;Y``aK(DPD14tnAGjR}#%TP7wkyP*tDKRvBe! z+tB-gHyW!^_jCD=A^?MdoUgmv9CCYNI&{AW5|{Orl3EKyxG5AD7XwtuMP*#BtF#9r zKwIS>7bQV9lmmG?&MMPKF8ILB(esYbllVAqtnA1+f#(zH1jThBxolSU8&M`tP?jjO znrqxq^`Y>71WcMp>su{ez_@DY6Yw@aB`C2c@U(tVMaRM6m(UWQo?wR8hjJ}LnRuU; zO(9}-dcwxd$Xt)7y%3p*cvaN(01A!h#Vlz-wGuJeSG0#gGBr~jzMULvad=fDTt{}Nv>)uuk;x)eQU9?R9c(*hXOlK_Hy3D_h0`6rcf8Jd zcGoBfj%MWJ(>)0t9m*x;R`Ri%iwf&L7e={Ln}(yt&=g1v*}y6Y(`(WJZFD*=iT}Y0LEy z{kM0IA-iRGYB7BG5<46ER%W*w4TPU>b&GLnYU3y{S*2$3#T*+bL`K749=4&+!XB4+ z(VS4m7&7sF83}oK!`2ddK)+l`eisknhN^mb`Q6kPvl$y@124TUxfne}~NB|wN^Zu0yU%$BjzX3g> zh=P}j7M>jaku%LEZp9;Fk>&kQ0bJv^QaHQ;KaaOJwykeW-`$7Z+tA&ee^Cen_)2x$ zw!ux>CKQ0n{j+F@@0}XI+#+YjuNuV+5lPt7LQw3SjL4)5AxXQUCbkY&tF{(rcs1K| zW%q+O+0Ylx-p1A~$%C`~anfn9^a5F5hSqY&td2X?}I3A5P}-ouUa5v$-aCbus>#JlN> zp4ug==t=-PX`3a%EJswe$lm83R@|X^*F?BP(C3yeoNE=#S`Ikm-z4k)Q6DQjpU8*a zBqV9ob5(B?Bn+}FJqTmMcN`1r5n*-JG)H@SdvSaI+ztw0=0^jQ_?8B{Nnv=Y2y*3$ zhPWj_n#DfoLdzoa-26)$&J1c)DkbPGU|HEASsBvL4e4BMdo+z~)~hWsF}u0;)l{Yp z&k0!MuaF9e3G#;sQy>W(plm$i%0>k%?udzpvld_(kPv&Dq1_-3f#DDH4muJUx;k)| zg~XAy6u(Pr8(x&!ZM`rdS)UGrM$5_fpqSs`)pE?qPnrrGAX^6!d!_#|PO2it78FJi z6PheU=2tQcH9QDTFg+kF@D3AeOgW>oR9;BTn|~s~n%)KrKJw$mGIAW-cbE&-z=ln* znkVlG+8X2(gk<>lIP{+KN`RUT^m!wRUTh0y zRYAbyCr(MU0LHY>K~!;Ue*L!))T#17FM1q@R;ToO$W*0BetyIa<7R%+US55RQx&FKFdJC1R@}Tb}dwgc-K=(+Bjl%%Bq!b&5Hse+2E44CPd!C3GAk33|W#?D~$+a$n6x04%A6V}8&D(hlt73#+to!A#m@!E&rXa&`g)F51^?#>kfyCdTWc^65k z=hO(iC~7!u%olUSLrZF-p@t9eDcJ~Af>!$T6W-?7`lr)jtc@%#@|9s{)hL79>Q%i+ zM+4~%b`jVNS(?826pccc5F!zWwt(y!z78Rb){axsmrS8M*h&+ZgpCd{4(L`DHVlJ_T(hU65%((gB7Ntx=Ksy#?1?g^l8ZS2z zLAXk=4x3xS6Y$b0S~1kMT?{r28QIiZxt3E_dvL%eZcXy&kEYWfX72}Aj~df7+Hb6b zt&b+9tH$HPGHNx9c%r#I{akFGWG3n$5^&hDWlksg2yLY+`CC1tAh{<^#@c}g7fBgW zro|rTflV^qRZ7u`LtY8lF+bmeg|ENP8&*%I!XB za+F*F`1Ks*m5T9)nL&}6)fmA~Qj^;Z(%jnQyUCBhyZ(%;$1lZK3+O!T(w+YHsRgL`vMlug; z%lco6e-?inl4hA5udFB}bgjQM(IC;S%cUe9>1HWc`~NPF#{jd+cE26POy3KVyVqNW znpt@(w$5?Yp5x|>8E{EgK6!CIcgjZ$-+EM~RTU*k^@^2w3$Jzv592?Bm3yNDQ2fEa z^AsE=KCEK+>nn4Xn)IZ>Nm_-(`(wJ-6AQ*ExBaD0kg>p${0DJPatmI<1!Ce;5k&;~ z$qERMKPW$U(2Cc0_k6R}&lNAMEy$wdYg#}jBm&Iryp2ncO3$V0SSv`ozVM0Hx&!dT z8JXsV`8;cl1pY-HrfVWV|9;?|>RQ8huLknx@&?< z?ADRb@JI`5?faxiEOIw9jSjM+hc+BF>n5|33?UGC;&0o26N>DqGQ{h_*`_DX@g)5( zp!_9;+kc$;|6MGfgXz!zp8Cz2-TyQ7|B0=SKsn+|vr_;gXn>A@3%GSUafUXzO2uuj zc0`gz!WJa8W^O^9A=mN3@%XZzFZW1z zF7(i(!B3WI+P|di?tnFWN?Yy0YCbYt5qa*oy2!Pw=bDeIfFofZBnQYV;vnI)uH?|V z`EQiki@Ej7AzB8|<>>^$y;0`>@Y2WLJ&@0>adh)obmt&9qV@-kS|^6YW8!d2z8WmA zO<1!Y{rzxdcOEihQN{Suu#Ma)Q5akhO&~OTn+8A07SF+5xie7>B8l5-8Bvm{1 zh&7kS(8JuCYWnC895291f&d?h5g#iH4}#V{DKY*0vU{8g0w@&#(k=R`8yl?EsNV%R zzb;!v@B&O)Od;!vr}ZN|_h#UPz$-gxrZxn5%joGv+Jn6=+wv%G_B%P-phUN^K0-hkM|9G53(`Z1pbtG^H<6WD{`HD?+ zfXz*E4w~i+Y6KbrQCM-DuB0Y5_sQZElegSXHT3ubF-jd3Ff$1K(LgQ~)D)?L7&f2I zYa!U#NOKaT%3?d20+W^#s0nrpry{8st6`upp5hAc9a>g3Z0kmW;P@fh28l1H&9&9E zJ?dQk9tVP_moOjVs|qarabpK4c!)zp>8-cC2Uu^^~f8o`#>KQ_fAJ4UMHWQDYZ z<7%*AvGBBuF!%)8-|NW=0rhb!CO?>PJstsN2SM3md=lzvHulm!e7~DaSAEa5BBtD+d7;-2pqrsgm5uI%>cqvsJD4PH` zhLyYx!>7cfBof8?itI$0K35txv{*)x`eMm}J{X%WcFn4rjmWgovIw9ZHE5kHLn?uzTTQpM@g?R$3I*xlf9clLz!?Rm9H=(RL;?t z+B8wWDyV>`eUG+@+M$QRV+3T}%u^(#{v_|_Q;=S6lyct~NX!zRO~?$}g}+Ekp6~n! z?r!f12U&j5e?eqD27t@^RfWrJ(s7N3UmppcK3&XmoJHr|Ri>iH^<``N(xLC4Z3;8i zGFZAJIIZ@=8eXPEJaE+t`~kr+KlQI4Atnh-DK3eExUP2_Os485kE~@*9U3xZ)1GLi zcqjb))S-M z$e+5xiq{r$(~5=M^(Iu5Pq|qVGFdaZf&272YR(Fj)9$;vme6rjy=|bY4>MpFp_ewS zpiUfNz%W1pT|*HC^6Aa;b?c6{;4F;z5A4RRkRbs9zoPbwk6QD>Hh%9|RE}+w@iR&| z7AVA-7zVU4x7Y`#09!x?oxA$HE2H` z#nE-ZILAIcDp9mqXw6}U&*NG3JKiitdTv!iWjK=cdVjrHn|i_%&|!GWsT|Y84ZxEg zx!c&PH5F?SRoRG_1UBTZe2ZTE8oa3e7hs{7e(ULW#E=By+{sv@&lb`Yp$q<<+7j=RH&2f#i7W<|*lDV`)YxA=`#SD;ZAtDgt4A}S5jL7Ola zrFWRnLd9yA8HDuw8d^2BAas#@^kHM1R*_icr)m-n9JB4MR~09kuj&Y!Q_JUSa+}q) zYPRX2K|Afks%uG5`ftwuh05NP+1%gkiBCS_@NC9~w=;SbPCfk5e*H(Iyb7LTiT?3S z`OFNQw?F=dUY|yC$DjWu`U2W&^?#b^9RJmSJR=j^|DoJXV{zC$jWo~JuJI9g-TYG2UiG9z}He2lS!wI-2hI%pB_ebeu&}{hmuPAN#qyf7p3^ z%DsO!{(P<;=i;a8{an*~jQ0mmj&^5hM~$bp>Zf3Q9Us1Ys+8*|MF>#3QO{~neyi+k ze`d1vTxB#MH!1dfC5v$z6kNq{p`JwkRC#&NphuAP_ck1Ozb^_8qxEcUGp0D>@mWu##;sy)PH4p z{EE_i&MCQ22y3{2fKCJ|k@f!G-&@t6XRb)S{HD5ol6>r3uK}d7tM&V=Zum{-vAH62D#7P4C@;0qZI>wh)?jmB>eO@^m1KfY>DggZ%nAQSJx~ z+>z;G49Bh-&|;z7{2G806(|L6skautH*5T{Aa- zOs)cu9?ldtn5}sW&eO3=CPn@#1jUzwJ9)UUuo=%j26`KgN?`O5J%JDS{%c? zdjg@X{BXuo z0=l57s07j33~<{6!})s`hO(R?t;7vjOt?{iK0Gv&L3kD_ORIjGXKyMy z5@;9W95~9Retf0>E*$SBcga7{IGJ2nh-+N_u?;DM7;GM~t7ukClOqrLL*al<4EHWE zO`JZc6feF)0C9&WDf_f~%3nEOL6d*CSO%yXXwlFZGYQEvGNsVze??IfaCtSLZ@f#M zg>WK2^zCjno~=!*-6`p7H&OD4Y$WC)eyRu%L}y*vm6jBI`&HM#5Utyc3m$uhiH}}< zC|wJteb>35#0ViK5(@XMOD#ECWs>=)yEZ=;bFe)v>6YzT_1ud;c63F^tQUi=6_3CC zWOxQ;r8t*+ZdgM9(lON|7RNjaGoN|k_FjT_U~ITik=Weth#=b@FmTY_RcA&o6Lv@i za<@n&p)8Ve4ynn1B~t>aRZr|{0%*vdl-OuOFFXpmS&2B-0|OM)fhKG>swHyfAi0G? zs*{>@`o(|$!g%;D=>4D?!I=6kA`$hDVMDPCv>8-wk0^v%6+zSkfDp1VVK5LuJMC>A zmC5|X0R}5hb#?)cPLLB6`CTnf=4!>*(-}!v|OsDW@zRW z``FMrIE4ntHfs&^d#2H`74=-EU~W?$MVZAXEq8KnRwIzb!seRvxEg7o zH6UF@)e2qku4dbBs6dfZ;jGCGQP?*$QokImST+4xL_Qx~)5Qkq*~gc;w8ocgy?9Fv zq`kR zYKUd}*s{=X;Mi4XBV)k@H2~8uD-^W)zRpUf);DPLy3Og_I7Q#7G*n)D!*m67ZBk7q zX)6}aY`2;OH{DfZqUkS{Wj(F_=gtleRbm*V@H}-0B24KNn~|>EZ~?4=!U}$rL7BXb zHtTh?L0j2%l!5gI_TbvmsyJsO8$Dsy9Nk=cG+S`QWE3)Ujt}HF{)u06ccmkD#{|+$ zhA-sEq^FvcE4`SH_h(NyGGbhR2elfB=O%??T97(^sRx>XjRjHXPn|+Q!fkn@B=%fx z)1eXD1|dch0c2;)@p!rKgvjmi1k7-BxH~WubY~BAZU%r|QZGZ6=koP*e+9x8yU|0; zRS5e>Ux4~-breW&AuDU5IRT5B`X=2PMB*oOOx6V#ye47_&}^}c_~&VdXeeb4W{q?Z z8ykl{w*5GNT;A5Reu>RU1G5fGE~S|4FzN7!y35(785TMY$fqcKKfEJm^A z7{564AkWa;#C4I$g`BG7?N*}sd)dIt4R6&PqC`E^ ziH$nKtJ2>^4~beePFVO^#0CSIZ^XzGc^3V=i&C(!v>f zjdsk#_-mk-(mC{?>jEfp>(M{C*ERIldUkB{Y}tQz+K0=OZ$20-rrI*+4K2V76$doU zT*syXafNDOLkrJuGpC<2LuGnf*%Ez7HHF%(-_&S%0cJhWY;7>wXN52Q?;V;pp1hkP zA_#{kk~&3__c`6R4C4v4zM8E*OTb+9K3z|yka&|4lRhsh^ubV($uLza%x=n$(W%|1+%!FRr-Jg`V)B|EtX9?-z z4%Lb~*2-X4|Me343urf>yzw8_F-FG!%G=Dy{D0B@)mq~*Os$ALr<6}Xi)4{p1XG0m zxCCs#PE3v%62!UQcb|HKs`YIwS{FAUKOylQg|J!6q!zvGcXZ*tlUF8Lr^6G&8h-C}2)`MVtB0|b2zw!QyZ415-kOBkW4kWi z=)8PMY7R*XxsoHj4|ux~Z~bftxocWDZoglD6iF=k1S!Il@dVGF06!{ir6nfc-bEvR z-#=cDS8FG4rz$hKOrWaSod zwq*8t)5$Z84aitD^B0(AO|QY%Il#(olcp_zk+o!z#b4*0Y?U1A z&WdNRP-8E+DAxdamm5B0ph|5>oC+EfNM_+p&=3s7aV-|1ER9?3r%0mox_GRRwvRL* znoL^{DS?THWfJXABH&~v?p;lh*iZ79jx`wDn4@FCctW zq$j^_px>NenDa#0aB}%PYCZd{m|??&)URuC5y@FqJE=I#w$ePvbqEQx^hzY*GyL1p zZkYpP%ls*=?=^~qZ9^7OFN~uq^i;pxrtmb;>K{EaC7f&4c_kd{u|{Lxe+$T%O#Nx@ zuUl`^_EIyk-Z*AtZ>Abd`)O%7kWz=JKc-2d{1n)CI2Z|wURWisb0viBaeZF|q??nr zU^>M2WSr@Vb+4Pm9Z}V8xK;yJKDee6j%W(h-$tL(59 zczm+kt1(SEUi98TLQadVgi}IGw4SsY7>7k_K|MlXE6<$C4_k(PbyksimiZ-(0aU$< z(@J{#D3D)e@ul;+Ca%hrcz7C0;tVZ7(xWehSwtY6bS#G(h0Fd>B|-JMdvy)%!;YBu zVv;fW8>3o3XOCbMY4RXWW~mF8?r(AwOBzS%x$TWQRIUY!GsvzpR!^s-du>j$CE^W@ zpJFyGC9cI8PYeF@j&4jP@YlhRhL3Zi8r1s@*3Bo%f`WID%z#JqpOZ1C+hW{l+#UfV z88x_!5l1?#GMMPXDTZ~cdUY?wr|T`GM{g0vH3)X1_mn+Cd3W)Cg7dXyIJeKugDK^Eeg+$<_3PK(a_JoWAk)m_ZH?LK*HHTT^-FF20Ee6tu+aU0Mtk;xpS9?B>A!zYlJ zq(EsKJF~y$Zm?X4H7?dRp^lJMt~YtkI*f`9u{~E7vuy37iRb)w$~LuSHOe!z;d*&< z!$|Aw;HLVbqstbPxV)Y#HDsG01q5ZbYqo^pT1I=t&ZEv+`$9(T))FcqjX_RLF1&Z$ z_hGLxRTU(XgI&l+WS&*Xu6XPZc)CqerUh4?DDBj_Uam)FRf8j%##TL3^iX^6jHY+2 zo1SBua0~0N8E(z4T5N}>*(*1)eM4_%2Cw>j5?tNtE;UmZCn;1?Z0oM{Fba{az}?kY zQb9JJ5*uOVzzQcVY3rCr(Xz@+?B_NsLY9r()mfKEZQ{zE(wm0sxeIY`l*yciD6B-+=kh~m~PY*9{ISGwx9V{8%(!f2xl;BPWX7VzpQWi6ACd7lp_86 zmT8`F=oMFy{YejZvcW8vYBBXlAr|ncS?T zGf$_U5uqCb^ghmhy@b{4Bg#F73ssDhU4|(ho3`MqTh_uKEd#xsE+y9m6DkXZoR?&^ zHFmh|>Pd9F1L6)!X6jWmaNO|c%WtGeeC4aQjCvSCzmqKUfZbp`NL#KV+srvx<-zOk-J~kDqG*@7Fa?t-&EmN@kVtzeKiq9(=hP#w=4>gmaeUot6+(pGQx{^ zQ7Cw50B#Ef9pmN-ZePNYA5kaq7~PAicl*4H55B{zB{m*Sw9~EBThN<~9Vo+<)R(A6 z)mmnoqph^t*IuntnLOGMXwIQ6q+dkQ#Sw8@4A|=#*s^MYI6GUtYwdwNj z-}t|vqXr|5|7m+;{_n6V4F7j~Th^S6xnzaeex?2bF1+{#2&92(0`2JRyNaMA8!xJ) zyZN<~j4z<2ZaBoq;kB=2s3%oKae0d?+yBf1gZy1WVE#%Se5QB*M9tyD|MA85^~Cr6 z8itV|sr|n5#ScUr&)A=~LhQocvFpt(>iYYLf7=Vo*9*V9VqS>O+xAygj8Z6Jfvfxm z??-pS4%)`zU~|8;2~DE(Z$7Ld7OeEdA&Pfr_HGozoFz;h?yj}%r$6uAGO6d&^OtFL z$V%Rf!k}K9WCeATrf1a*PQWVZV?SQ&7NaBV65nFFRJ>?Q^-zHM@| z?>nv2o`)H;d}O;B+z@3{SL4`S^V9rmJ1Z6D(R#aNu4*GU`|`r%heS|1dJDnn)+&f^ z&@ur>gzWurRCXgBy7NRLB-;O_YU4oZw6txxVK3!_e!m6AN1uJJYhDle z7t*y^QOsafbARg>uyY2wbV>GUCM?#mYosL$9hcsQ4fj&2+LNBR6=2Ph)1#ocP1Z}6 zw}d}}9j=Er>n9ETYz}gcBH}ja5z$Xh2@VR8lY4nrc?Y9S=bpgs=?=y~Uc&&pEvVh2#IWtyuHL2cBEeGkASmX zKmsyZ?kom^xPUtc(s3=Zckz)$7rNwMPyRRivKTB>&SeEo3-ijtrB*fEVl+&jny3Z-30s}i#D@VV>!*AppO_06-Wjc>f%SwF8h(s=TPrF6$<0Z(24%%4b z^(k7EVge&K(2GkQwcuv#$sCB9i(5t`j)#(0lQfjJ4p1zgm>MEndLr(O7J{B@p@{%l zi)uOy#MDL~YV9k5J$@|FZ}b%uhvO*FXKkB5D0W!WJ@3!PT6%5lnQjj~1dyQEF}JD?%daiWN7NcRFcn6tA2=)>GyiQkW-)o~{B zk0}lPiK^4Vpd^4mbJc3?_yZ_&V*=IGtq(U_N2>E#Ap}<~`mA~Evi`J(PQYPy87-7H z)9A;=QIJem(E^1?oRyCYF!_H?y^H+1=lJMWFLv4O;ci_obJ0Vic@#L52EwfMC;#rn=e3@p z{Xp6YNRvm!|4m7)e>D$6+uh2P-|yneWDUpYqwJVKb@#`Vu+D?ffCHZ;f9GMZT^>-` z3TvChSql|MT_cQ0i5EPY?o?mADRK43F55W=K{~rMr|VkG+nbI~4ByW_&~lK)5RoD5 zwuKFH#vl_}RZAiOyW@!aUZB7y7jvPtGf|L-xB^K382YSNIH76K(8-D(0;307afs-YdX~N9o9)4{S$n4ns~ZAW8{2#eJ-VT-@@3zYFei-t6@}@ zjwN`YRD@+WmiAt5%46NsjgH9Vv=$9Ms-sg`r&fN7xG@*fj1PAXpRFV$+Ab>|8X>=20Jj+HYPf zqZ`~GsTg+kNJ^e{xo3RlOr)^N55Vk%<>@o8c;0tT72UdB6GyY{yvY}UjmcF#AXB&( zjLpIrjx9X0Po{JlY|9wVA-5#_1EQd+flnw&xIK`<1004(Em;42PR>w00BrR+LG%gA*Q3dW64RK?-E2H=6Qd$G_8n2 zzwjHY;f&>db>ksa&-B|HV2=wc%UjBs>!DW07tAga>fxr1m@V`W&e^}vt(CX4@hX4< z#!v&73Ou+Tf)VSTL-#?F%Fu%rt7_=HNe#~+dyo3;=eS+6(r;n@S02c_Ak@>RbUUM9-IPhP*0%`h)?|%|JSH6|0?kt5H3(o zYwi}p158l-A{_>I1TBauYDhgZ_@3?lGgzCI4p!3wyk@y^4Th#QwB0mR&2^<(q}6)6 zX{XnOhc^ejy=DYMcxB5nv!j@*l4+kzeQ?m84Lh9e;ZCVSOB7i}K5JY{ z#$yCb7c}DB`o(2%g#^>iyAp;6rF4_BYi+-0BNdAi-C4Srh?#W?9(7bR_ny?+>+LqU zN&2O7lFjsl6H<6qHjoM~#8E;GYK!+qnS?CHR+zY@xOdajLu8%|A}-bIJmi z$k>@0LuT>wo1G#ulo-P#jYjgDRCXOV!v`o}#fE8IdR@_}8@Br8b_+H1CFYxqdldN; z?^y%->hq>GXGd$A6eziAxFA*=7C_NHMM=x?2YVOk2)5L3yoc6J-U@-u_G5Pl`Y@iz z!R&X~K6D^MEt& zv*j(9wyc1gD}|-t0O`>TL6X-Urlei2&Z%bSKLHf^9E*!S%a-spyHnLaa{dQ^jyF2) zE*66il!MH$7OO0Dbq~86cbboXbq9DPdF(&@ajJc0<_UAtvDu+G!LFX#j~=d5e*xBV zfF1wi;Q#NWh(GNA$Jf)W+5QiUfH3`y`VBlt8kq_LL-uEnWzRZb90q)|(n1XG-yW_QFBUkR~HB3_UhW_{ZVBC|L3~)mCv@fd$;F$Iy=jL$JHr1RdIXp(Tx&t;P4Q( zMD44phC^M-g0$&z+wku2TEt3b@&{t}mF?~=+Sf~h9`6klHpmN)wRqK5qV|4W02B4( z%$_xNm+qX!*R)i~5!rMn%>SKqY@=M1w5jS}JcTpgbk7NyKkjaNp`9SQUo37ngQS

;WSRcDqocrRN!nC&1sS^^Tq0Zjnz&t5q)u)2mA0*)H?mkvUV3*Kg%*BOW6S2*!`m zJjDejC-=PJR!_*6C*{F$RT=`oT$j9`$?K$_3rzy;dQx1?4>(;fO4ZGW%V-)ON?MFY zozio*@^U9e)b4EgchjjrE(6(TuL%yj%FnvX8_p}6sys-1gYUspSLJPD&xY>y<=8WX zJt;jcPzFPo9&|z*-e#B1wI63e?UX|sw%5!-ASo9-zp4v7#d1g-khckThqnj#og=8H zEm~>oinK)&fOp|Ga4luNt*Grwp%1ragJ_0eUf#03q251i zZ}|>%6?*qfVoVnr)Zi{*Ygw)41ZX=fr~TKu!Currp`!*%Xl;b zEC6O}Q8JtIO`3etryShVRi4|GiAyO7l*rTaFX5<+34lm~`*d_qN2)eKR=VD= z`SEf$ye7LOQO0zj*<~3DcpoY{GxaWg7^cJV^%D zc!mcYeir^qC#=rFVH9>^^l|rc0|wo&{cAXj(75 zC4YzVJ(Ln124q9iEA3nD`?7t{RIp$o18qN-oYgWNxRIgzyI(Ehj?T>oLY_tL#t<1+a0oaMuHB zv06+jtXkZ%hc9|@%nQ9KUjUFae>hA*D?+KzCFRaT&)4i-N!F$6Fo8|0n6M+-&VZf> zCw8S34{dOIBDOlGr}B;Z$Oc>214IHy_-QS-(-gOnd)+9yLo;K$V9GUdcY1}i>h+{f zCX3S=dF7u-Yc$zz-gb7MMScbjtt;qO3>|v54EDa~yvr#1leRwS7Il2`|3QwzDk+C$ zp)N=A@d9dt>%q7(07f$mE$SMYL&_RA(6yY|8ofzygFohxHgV48A!U$R^(V_4pbI<8 zd{2}+)fH%hocp@_e1+F)0!%+^%a}Kf06xh7!0b2pne63fJT1SVcsK$8FO$45ZGBk# z_1YX}=FDg_w1vt%l`)*Pzs|kJ`sEcZ+fgvcGZ>^-YAdx5dsj%qP=&c}K3hS^#pd-n z`FY_%ev?Wm-*AhvhKSbyCEXio@zXob7I)j#JAq}Myl2`bO)Q~jyaSfd1Y|W5nTUMP z<#t`&{?V%=GeeKIHEPiW;2pG5Hlr26sBfT^k?VtVHTI@;Jr76zkPT1G={iT{`P!Fk z4d-A~L?1N7*00;Pc+td~!`CY@n9bA;UWP%DM&_Fv zT@P;xz1sd1vdx|L2Rl}_9JV1aWzT&<8g5N%{czjA^gjicd2MTh%`iXjKnSF!`(*pm zZEk{E?`YsD#A>;im2c2rDZ5{g_kj1{WpLR4*4Ch(K6qaLqOxUFQcAM?Q__F?GHQBm zZV3F7MR20NN`n(Amz#yOL5FHlbMB@F)46Ace*EMQjt@T(2DG>4K;jEg>a@4r;dPMn z8G2$_jk9!AZs|P}Sy_zlq$h{COTiJB*-uvz2(_**!-3eet{oA%>=kz=J9YnIqi@qKHtr$>w zbVS;$2VC~1OLbqlJ{-s_x3^U{Z4S@tV^pbI^+-=u-^v=Nt+Yx$9=^2HDP_kbR;`YC zqXHBwo`=0*FR&1z=3jGr{;Ty%s?`L9Ypv2@@9MzUwq>k+=|*)-9fMY!qK^4jkg6b; z9Ghslp`|y82qT;bf7Uh+BXnGzR2^+2p;zF^yWex{Y8_EVc`6)Z6GWw)Qj75T0_A8Z zY4W)G0qr=l`45Fk-F2OZJA3wiJn}Hd`0&=D--F2(3s53jaaRd3S-)GJ(%dgROjJ0q zvF)p&&sMp2Y^7Rek94@9KiZG9@SL3;<;Um6iWVPP2cux$2KEWx-b1N-B71t+AL{Mr zYzMA6dHk5sm3@B-B*P<{+&e+YvBPm$&CG6_tpH`T~?=G!o!lYE_PD+5+a-~7<`7?+>7WOF$KG+Rl{T9 zvHRf{2Hv0L!&0?MqI<2gd9wLb!i~}Lv1?n>T0X)ym=hygzD;HVT;$tp*#?S_nh7By z_6+ac&6vxZ#y)0P5T6!#bfFoq#Y;ID!F$;+cgtOWMpGZ1J z1qMwBdOlxt`^_8gxQohiDaV7Jkvf=4U#+DQu$Yz_2oL<2K9L6c>y1Lf;ZW)5E5_{X zz2WNyynDl17th|CRDZxlw0f#x$I9)>tXg;=d?1V%SH0JoS#bBR6&}{U_kn>Azd-)w z@&l_5-YMDBWkZ@rwRq{sSPF8BUt*Cjv*eh! z)x>UrfBVqa9<|kD8m{2Fha&D@9kMBxZu5O8l-?Bs>?57S*TcsAMF(E7AK6qs80>O$ z0(ZM$?F3eqBN?pG#b+#(dA~tvbx^W(-)?!@b>5?_(=XH_BvE_*#Cv&d4`wTz_z%i? zWAi~CSF5p;_2jbKyY6%|OcQj5R{Xl51*+mpzOVk;>C1pNk(2i`Wjky-c^ySs1obOl zZ-?iCoceapntnHrVD>lmZ#N^D{geIAz!?w8-@1n)n2%@5R&>uvRWJL3|B~GHGv0d< z1FY{{Q6AVUNhnG@j7l+>V0X{ z+4|bv$-U3ix*b}zz2@k@+uCN@W?=Yzh(|=ERriDF*)h9^>p+kEXh%+^bUtug>h#VA z<^;gUHP07XU8e#Ll|avqyAM(T@^cJ%r0oj(Ce-} z@;qivK8u1|hl`hJ>A$4eVa-Lng@P|%b8AkXrz$+Dz`_NMXpF%zyn#~OVg2?q<>I4d z78DzSqb0hFW2oHKCOb4!LMalT0G@|EE0U~H025Cd)hE{y2SOkWN-}{Op~v{?@up0f zMciML2|fkAUT`e)F@82OxVIn=oPVK=7Kr&be6HMvvCGiJU1rS^OI7CX6Q?AGL((hr zThOk%=OOVe6n05K(h0q{L&~57cp8DprRiCmgJ(;7(7clNV4_zz{d#*a`R9>mW%Q8C zk!}~wFA%m?f=W=UM_-s+&k-;5SNx38S!k-YQrB0-+JVc^jVXO-XMJ5pw3ds>5E#{jar&KPe6HF1l_^zThVU< z3GC8!$cIixqIQ;^9!lL;q^Hs^k^?}89MMxlsp^!uT!GmFBR<@eMtiq#_rzIRs(;%5 z+}op$f5v|%JKl_N#&B351-W-hOGQhWG%b}CYpIzz5NhJGxmW{|eDD?`pq?45S3Uu& zXVr=PGhi}ub`ZwKi%b$8l#ZNYBh;b$Q>WTe+djyXY1%9#mm!%`5@0MrihnACTs=xZ6m$b^cDg$yScrOo z32lz*1=JL6u6wHc=fo~>QGmonb*FTvXj4+LUZ@wE7uB5Kogz>{bi6q05bB;;2y~H- z7r1vM&_09O0Mcd54BB?XP0B7s1}!MfY!8viZ!DADBkoMO`K*KP4RLLLk92o<7q7{F zhfM|=@OX5&UvLYHiG1Rje_NV=7IP;St(1D2?=q(#j>p(&WXC_aV54c_P;*2$XlUnn zzEc!vgZ#+3MwF)n8O#MU|2~QOhz0}y^$z*>CP#ywK%hptV+oF?PId1^uGb8qsDZ); zDho7V794&4ZTSz->RD>&rp{7%5T&msApRw@pp;nxLPDTn%y{PLh}S>63rdU20Zx_1 z7H}|=hv7oz(O3IzzT+79`$B9z6g;$EFo;;1o}#7^ApD*ZFnF>yFCZYUiC+uLjUy7x zp~zfvMSlpS$IGaSnKQ-X2D@#5EnX{pKFZ3%Pho(@{1V)D@_F(sx&fdDUU(ZWXq1YZQgy4&O@H0ml!|v* zw5x(4LI!2&SCT*`!2pyhZpu$Ix@oFM?I*zG0ihDjA_zyb1hN8GEW@JyGiW8FjY3cw zhA*;z*#hCnX+xgfX+>b&S++BuNQpq1FUU4OBsGLLaFNellQ^bK<(PBWn`a2v7#^pZ zr?@~zK_Tx8DLO(@*I~}LtekJbIumfPaMU_7oj@|e?Vj{etN0ZYw+Fxg#J#CgqiLfb z$sU$zmbn^AIxE5HpJ5H~*ELz0gFtH(5OqWy z?f88f!)~&h!7;Okp}7WwocZyam>P@??nfHZ;P@i_XAT+pxJ%sUoPQ!(|F)|zdBn1C z4WsqYouDA`-AiL7TG|1xIKz})5erE}vi>0pi}vGJ%)3Xg(b>cj?Kf~r#?i!UdMDPW zd4gBzy(=*uA0rQhWqupX`omVLF!zcG^?)pz0>jgY7Bp@7dCxA~wh@zYC`>+QIu4YrpN* zz&LRXvd*DHMA+aKt{c=oc0Tt%-cnva4gYzqmjkTniWT=5D z9d#UqBc)Snx{hndco6Mhv?;WL88=JUw5g%uq2dlJPy`#nrS7CsJU+36?Kk}}!S)Bo z2cNila9rHIDgQ<%h3F4V>!~JnE5$?g=AsYP57nFZ$I_0ai{mI508sf#=Va$3Ei}ES zzlRVi?wnjKeL5#qgF`Y4{^A+=ilU0nIf4C2sF^C*108uhlB~ZW&^FWib2=`J5PTk9 zjMy=6GJ6=D(NfHN7@QfLG4DZ{hpdGx7Sw&;|Al=nVd4kdnmq7hkvx_Lm9JcsX0?mR zWAer>)z9KqFKLYGTT9v^nD+#A$RQPb=fxEh>GXRS zlTLSIGH37CKmGsyg29vsiwGeowy9ebFTGCS4qNdy*fTUQP)99MB17{-7d|^QzYuwb z=CyjM7>`M)gLAM0iI}z^UufXT3H_#?E#w0vGL2*AjyL%mhAc*G1;RLuU2bUHZ$GL7 zH=1z3(T3`0KqknrF{nhf6d006>?%G%bKvFm^rT(B=b~Jp`G*&kHcwXi}Yw77voGxjP{S4m&~_f9A_JA zsTP}O8;{CSNl629Ajvi*veg|9H|RkM|#Uj5Uf&AlHq6{;@zLFil}sT4y|_ z^-q{Qx^o8iIbmKj@Ml8&fVs;36MR1TEMyL`I-IK+>x@e_&NVL?H#iY0p-ZMF8gb%{ zH!{RrjkoJ#7^jzuHZqL2(E!PUgoto|nc(wrYnQNhZ6+*HSl#Bf(etIl-w^<<`}0%> zOgo6j6y<$ekPBuo|ICXkpr+`Gnp^7Mk-R$kuj5o=E)pbpvB^9*E)q7znMbGyq*Cn5 z5=g1d)BY|*NjjF04EX%#6io;pST5>qcT+2`)vc%$R8M27u2`xEf30X)>4w3I8OZ*V#9;|^h zNtT-hCfkHGgl4kOM5!FwN1P7A3f}(BEt4WP~JEdCc zGacjq6Fx7&4H9I+iW8>sLl0$w79sKyNPW<)-<W+OcueC+3FVh!Y*tFV8pATxLWm{>S@UYRNQmiVYSCICZgtpqI= zGr-YQ*lS%FS=1uOKG(aBWR8-qKnAfAObtpkuhyIyM6Pe{{*LtKQ>LAHrI;Z!N59E4 zS-Ab3ScOTA)=DB_O>a=;meffR)iL1qHF2{W11T5Bau=j{`opdW&2NW73YscB+ zTeLW{czm2AdV759mH8GcnrM>STM+!R({vYSoARLf;<&aE`;wnV#_7i~8xy7ekS^I= zgJ;?ISJ9+5c87^`s@0@0S_}dbm3Bl^X^|)k1RgCby9ratxew2XUd*CL*%3n<7cncs zlR|Vi%4hM(lFJV|YWs(KY*oVlNtyUsBQkdy2{`tNSC9$XH$2H($-WNMi*Kek-9)|k zZtAa7gP7zUWw#l)C$<#mh&yZBn7pOzy4=K`W+oU|Zl<}pgp39*irwY=yZ;^b_h9s3 z)Lda@{$Ny~hiIcjI_bfvZ<^K?U}aW(&M8~0EgL%+-IKegzO`5rl-kH9M@rCHC5b%Q zltweTIV&kBLC~NMvO2n__z_`xOq}Vh3G%-BhvdCBrPu&=vGOjMw@Me54V4-gkz>_~F)k&m)q^cj> zqK}E6PDq>gTwymd`EOx%@LBaGNO@=9%2$x`AGoPd+jdzP@)6Ge-Hd`rS<2o%kT zuOMN*)3O-pd&3x|S+9+uU)s1bu8pzz9d0cuu62j|iLocf%so-&kd=!ytPZ7SG;G7xMKLFUE1YzAiuSOk!&+-LPWh%`(R z1RrtqS@l%LVSBw%d$p|b1BqhF+9?j!aWr`Y8a6e9l;l#D7$Z1?mhI(pWVPes{vbwIc zl~F$_dsi_GB!H=R_LUI+@yoU1a;<$O3pre0NwA3X4Dd8POSPzYR@~rlX=0iCEClA| zg11@3ahl*A0N0{V7gG`)TfDT1iv=a2Pz}|U9(?b@YsKF!xK_)eYqk8(Tx*|2O;G(@ zU$(2<{*4FSb)GJ(k*oylCFtX6OMGpMv9`t7N+EAk1v2y%207AcbK0CTugv4o+Lxxy zh!q4Pr1b#-1eorwxCrJ__%94Ro0E;rG-l-!q=*05q-(>ZjnD;{CJ3H;O?!rD zG+j6!-q~WE^M1P72|q!x0BXZVYzrnty86j2yy_C9mPEGX;;BuRMq#UgSz`eJLN3&s-86pl?tlWYULiq3Rsh9Dy{4` z`wy%0?crxP3984f4eaAANTzqd=1UT{nQ{|TP#0Tme!W0777We zP7T%{3ByZ*bv2w|lg9HbKLdQHHE68c6#v!OpkvTRcEEuNtV)qm1eGwzf}>&MHu6bT z#4Ya|ErEn4Z^u0OI|kjxx6E+)9c!IQz6W|opVKj18y4)b?a};1aDx>W-1x1*STfs4 zbe)T{0_skeG>KY>a7kKDgv*DepC)|gCZ$ssZB%e^bXIcCI@sUGwe1NMK4)vUfaXz( zfX7>};o>a|s!SGhuyWH$YRVJxm61OIx688%%IK}Fp zNcOnlJH~K?e*wNEpXK{a9Ok+X{(jSC#5uv zmW+Olh7JgXFi}FC8+D9ATT8fv{qx3Vb7G__JngbUJaWx0l{tDQVIbgF1gX+?_Dtfp zI5P0t#P27rg2mLCM>oKNxsF>ICQ3DLNp7>uacZy4)liR8>=O>q8nN6IBm&;Ir1N?_ z><3lSV!9EA+y&TPuS4vvAYQGom&U?QQv_i88>kpFvs9Ki0)Po3`?Dtpl z(%zmaLtzY?9lEq4t!PnO=|5xm#ouaW&Fg69rrKw8xVX!{4dtoMG7lAXT5Rcg_3!;UWvLbj zH6-t6Xgo1zKQC%Yl|GODW944SudaX-0ab<`Q3h=szb8)S54+ zK|48vf>P9GH-9>i7Wk;r$pyZHRrt2F9CowYvOG-_!9Di!rYj)+&u&BS>KVJsUSq4m zfIgRhV-WX4z&?Vuc@H|F7&qHn!x`DiHFn;gpmT-N9{Bj{)wX(NV=mXYtW8s`D;(%- zMK5giY3fJ>_@!^Mvl$h*&A0fr_uQ*Ddh!O+ z*zsX~;Oo~8lni{e&8Hpa<(84@T~^9EkJ_R|1T4*Xp7Oe5v1mRi8Vb}j;NQxN7kIa{ zjyW`kXz2$Zq@zHTZSN~0vlWJ`focJ7zzeevUkLV96!0$8UDP=onHO^1)E7B>!ZA2z zW9t0aN?s@)tPi3(T&Y*^$i}o1ybJQ50lMSWG#)QE%ELz^6fKB-W#j`%b7Z6EjQZ~< z-Pet#J?YjCqW=46%CWR#A71}tzS{-&Qsb_WVvWyhiT<9C`#oCec0I8bt@6;_WA7D5 zFVwq_R(fiWR!YwtV^4Ofjsy7z@|EHP*N;WVMwBl>4JxZV?@>SbShccJI;Y-Q>8>h& zvg46+Rqj&ML_?AR?huVMj($y)^~ZW*cNtCAV(m`PBNx=ewj-DF&eacR`))b5N3^O^ zTr?c=Ww-Ws4?oYceUG69it9yNnYs#1Xv^%6Jbz-vwnux9zY;pGziLOD4}odQ*B{xU zU7`3;EJ#Jz+IHLHkLbV6JzpEx=&@DUTl^kdLm=B$dm?O{zge$^Iz!DXl#IuYE4cyx zww4R(E!0q^ZMF1@dOq(*fem%)@6B6z@`+#$N)b9fr#)b+dE$$qJsq)*SbO6Wk)BJ@ zthy(?XQff<-LbU?<=<6K{ajUDe-G7qKN*m%1GdP=%qEKc7H_`yn(()GS(bghiUGi+#Mi2Phpc^Ne>%b2;<^v!BEW#p!0}+-YgBsXmzzzaqP6jps6EhDhi z%0IZv?NVDA@I$B-$`|yY^osD7!CzM7AG)8atl5klRDNOKZZE4t^O`lnmr0K-qGq)` zzMk5XQLiE@ziydq`9Vv*ypr9FmiK3QOCk%)E7LX$UUmj;Eztl1GqNh!gnYR5ljxwk zk@xAzxsfD~l7ili>G4ecBEPku?E+25YYB@&b`=d^J?s+wxy}+aW!6+fU|Zw${Q2ea|b(}p>x&jGFw${VCJ{%aql`FX!hzaHg~w&d!WWit2(?L zx`OUeEtdyQmnykv%bbm_(x;sP&=>)lV4&yAS$A#ai_91PZ1V=Rlxw*F(v-fVwi^3QPe4=%AQfE(UI`GAFe3F7_WoN3MgbIzBt_o8#w{VzZ0{Wx|fk0ygH-gL+W0$}@U!Bx@*Na*t%8l0Q;3 zoR)d5ecOn2q&HE)Km1Q3Z-6Hw=rhm>FW~_YLwPhR_!sCgEqkB^c^Z1MX(qcr>hjmS`d zzDeI&uJ@Fox4nK?%CO-Z!Dh?r%6ykd+g;_k-o{IY-4)(}dYioUOB-*Kw!5VbMPI(v zI}NQS;+$XxfguB;jSDXA!fKdNv`7#!xktkNdu*rZMMW5fCk6}X9=N<4}$(Px-q zYPTJKKygqSoLlhC3D|oKvv}6~ZV>J+a*2tlMnd^sm?mz1i*S=&JWX6MbY?V}L7U1c z(=T3ty;?6FuW?t=1T0c*Pf6JvpOgogti%YUL27rTjnj4FO8IL%K7s4xvp}^80%eRq zyw)c8nfy2%X?jRV3+)7kV)5C}+Mh)9U(HwZQF&3X7owpHZLZK$^+vd^iqLe;gl}@! z#w?qKF=}DClxYp4ntKaaO6HZ4@(V;4 zdB_-H2QUkbfQ$cre#nvd{SbUtq%@0#rAIX-)F{pkH4?B%dJK+}of3)=knGakN;DMF z4SSlU;CP=}LUsy42;&R4Q8#`u61qV+gy~UtgeJ{j4^3tkTxD8Y@~kqga4!%Y31r36 z%+vgH%4syu?QS&hP@DFT#XlVLAHK_8Ypxq|cV-ptT%d39Przd`C&2&zk@qg}ZI$=k zcv;(-UWQ=ZD*EofI+(VyAw)@NYe*X#N~vMc7#51t(PA81aojkTYda|E&C+wu(Ji** z*p6i+UqIPRZx@#&h&^1qs`AP!O`rPPSM>cw zQ_7Hap|8`vOb4ikkW`k|{x;kY3@O;M@ECoTL6R&SVig>j_3}Jqt}KSk+M7EX+SDCc ziIywtzgeDds*evK72f0X!Wh%z?aNR&X)vWN^ksrc^{0d&n^0A;af=PL(tT-lT0wW8 z3Eu##zu$n5*i9X#%IQ7#*$)H<1^7&6(*}KjL)cb!EbTj_VF1(DVU4?1fLXj zbdQ_3jqi`QZ|i7pMF5Rc47~)`{HLPHCDxRQrsJh*P2=gpCE**}Y6czZ@0nxJIryjQ zz94%`*ODGjk8xm!lW`(C!ErvMr7gK8dKds6eEdw{-TUSlfIIBda#}9zvyYJ6y>KF& zpxp~6w1ok8+^NoWz;)<+!O1MpOjajN3=UQ%t1VKKtoj1_O?9?32sNEvbw{#BZs9^7 z2FoOC;??nLvd1#HN7EsTNhVw z6zhSR)ZHg%A6=xu(tXao@A5R>n~cY;K2`k87*PWdM|F~mKq>YA33!@loE)|sBiUqx9oA0c1q(~eOx;%*Eok5 zs~@#mi;SY89n^X*c_=VuF5MNC*dR-ErP&Xt6+MT|?CJ3h_I3;1BJ;g(+VG7!5?N2+ zp9H?4PFbXqrH6CFxkOq_c{oSA%MS$;jxO5fn^PK^?q!v7fV!gAl)mybeA-uxu$5I+ z+t|Z=*)ErWq+Ko=EHmNakR%Drgv*YMWK%Ayy1{N9A9PMgv^Bm59QP1CEm5m~+zL(~q~Xv8j}5r@x2BbKnhi4K$h zh3hzp;CX){`wy9aoJ0`O5L^soB>k{A7?OZq(*H{Ur!JA4IUcSV{FUFYmW7JP&W9a} zLOkp!tAcH^)nh9FpqD%hOr#;iJ(hX65;V3%(b$J83y+mef3cyRJP_O%4u|bPc4}Td za3DAEx+R|JCB2eXL`rC|^tgB2JJv1Ff;JH&2r?VRt6EXCyR3?gYqTvwB2cP`8BXiJ z;&cHz9L|wU<7a`p)uh<_B!MUnH$H=xL3hMAUEFD-qJSStbVBFaLuPk!YLO|GtrqCuv`cdqFf9sUulO6 zK{|EmX(nzkUJI#1u5`dAw;&N>Mm#FKKm#CAIbJzdLm)AZ93m5|lF|C0IpgTqnPzj+FW*%@yXKga!WoHN4 zf!ve?2j&=99Qd7e_oYBOUNc@Zmf$B@1BC&rfu@Zk7_U*l6|Ie4zj0gV4s`Qzih-8c zmNZj3Zj)xls~QUg>+#hiUMrwp5CtwUoY9)RG>HZ(BquHYlO#+$155HM|0t;0ACk^m z#gUYK!CdIMN(`ZitA!v0#$kyY#P~V$PqXhA$5Sl4R&7YM);iv3O;wkt1Fhen6gBDH zrs{mP;MZ5>sUNk)=~tmGp-`h|{}@fhT?&7TC<5bkc5)7>xlSz}QnNGWR8oXqJsuJp zAZx{>$3x?xu{1yNP_&yCD3ESEq?Q=slU<(1pI z^5j>Yd!o6Sz&SRdejLeaPs2axY1pa&35KF<#KZ;!%A#FBp4L4rpSq`x2Fpy>N7KWL zYFno3?evVq7d8#`Xk@~Y)>!Ryvr>)*7RF30MC^pKP<)xLo~};DX=A3V?Wizq5@bRJ zv<#fCQBu%&J+39i1mAY6R?nc&byNV&>$A>9Tb!;`vRTwI<}qu47sC_n-^evDa;PUZPt~*G$(WIbE2p5u{nr z1+2G33`ASs+y=M#jo!xpCZ>;0wl-vj(*Cx2{-wNb+F2PP!|zio=pgL8`P2D^t$R2uRPwV%#jS^dDGT9UL^+AJ~o221poZD_Y7;?o-} z4`(gp&o@}&ebdP$t>Dbtmu_tfsG9jO*ayQdaaQ%xNm`89Gy(9!>)$#ZC#aI@@bW{3)> zv8Nf=@;S`0r`cKw{~z;+_cTYn;&&)gjKMN{Jn_1Co#NYUc@Y^l-|pZZUsO*Tti-rn zp*yS5Yhw<%rfOdOE4Uk9*GKOH?L`tBXZ*;aQI^9V`1tlaT$iDMtONzt0$M zI1$GL%@MDELONuA?B3f82>Z15q%9uoODgp0$0{(4LbKkW&dvUZctvVGXVkXq4g`uJ zS=OO-hyV1J&7Rk^b=(Jhs`K>*6gY&xox@=da94je+Wamq4 zp=SbBH5#^VY&zoGRjN4xGkQX_ehzg~H!jceSI{jo`jYqg=o;>jNA!A2&rKaoJsSd# zH8eJQ`)+#C>)#%_W0Q8S|GI`Q5uJf1(VkagtD@m8XgJ%}Wn=rgJOeMWpX%*xjs54v(r8$WQFgJ2pi!0j z@@%RynuZF*!+rY<6d*EifH~gW`lSZ6l?}W} z;V!}FRGo8CEt6ig33ZKVvs&ZE6~Rz26sQgcztGaw^Wcu<#&ewt8nc`H;SNvmRn70C zARs#9-Zx`c@o>RFpVzx4@Q{KabS3ooA7u}-JNusP-0XkpRG0P`4-HZW7}!OjS>gcj zdX*9N^gO8DP~OsZ5-kpU_V<2SD{u7<-l4e=#`khd>|KEk@po557DZqe`X6I{BE z+sDr3-6pl`H+oKP?0?$7LEponDR9xQI~w#Ioo}=S%(yPu%ZsgTYGKEaH20Yo_pJ2r zD8ioUzSO{s7+UwhOj(t&_nW`oHt^DC{tLdE66p*70rl#N{6Y9;YDWA<`#?wVMisGV zBoM<7cdhZ4+$~sw$dupo_UR3X^BQk&+|>sql(w0A1rB^*c@~{4Vl3Gjif)A!qW=hc za1&w@;~QE%)Bfad4-D^quYlvBl*bczexzjN562J?Q^FoXBfYMJkp};+k$DlW6RGc! zgVpxb?|PX&QCv*O)wT1b;BJ!a_B_7TyYI1`=WcC5*Wo*Z{k;RBYdWcl3tK?kaNl1v z+}VJzxSs8e6Jd4{HIW_L+!%aj;?+GD=;w^z;D2K4^k1M|Ua5Fq2wA0KATH6ohGg?= z>UFYfW#4TA&4fvnUeQJ_`&U=uP(?zV8nLABa`PDz(a8%>%EY zhtPQA@i(*DRUO(FcRlLgJozsV-LqUjrX5zWHvW}{wx;Q?${uB%;7(U;yuTfxPUAZw z#%lEMV4-r=WFzv5Xb{a!9Xo4ajeC-ZRFHk1`+96mHikqo7*!!egze+?gH*M{Wwx&nS|Mw#wJvbsFDGqsqF3O_Uod}A83r8%knmC0(`~HsMd<{?eQ5Qe#;OA^x~EwO!kJq zM6OzE7e!w4h=m&FqsH1M3|8Wr-&xep$DQNDxt@@is^;ZW4K0~!DDQruo{;T+p@RE` zMjY&sklQ~|EYIOsUaw7l09TV-qxjBqL;y~9c({1;8&AhZ*nYQ?X!LsEj=T?fKv`4c&*boeQe>9v8pR9tf`W%bh^7g;d0!1$a>3!&ZA=EFSGCXfx|3Z;HhyHep4 z(INOq=7Q;ap6$&D0i8@{F#TlYd$voMs)g&ju{F zZ%$+tXt-Upr0Oz3pjD0m`hq-vquue$KKWI9Vw8^KnyS@pzN*m^Q>M;4Iy*Y6)}xn< z&WeSGvox?d>8TnT5o`txHpk|sYSeaM#XGsTMk!~o3_BttC*CD27G`ng`ThwJC?KHr zuO(JWZkA$q7dQ@&x(DKNtFS%TnoMN=M*B_~=Y4BRdQJqO>A77~*r;vD(ni3jr->px zNmeuJSTbI-V#Q<*M3+Mb>LE(~nx3G$W8GrK>iqVX(1^@NW)%SJFH!5oDMP_pYQ-## zq~uMI0f+1KuZ|zbH<$JR2gI{oCWcv2y~;0j{fT)2E6@{wlYF( zL6_>;i-BJeUD8UCxmM3^BhgImpn7guRX&NjP5eMmD56p9@O8B}Udt=knUwddh-xK@ zCJ+ppWtM$YdGcI$<1`p;+-@vJg9mP~ZMKM&jrzoX;q_h0eRdWSJX$(>VIKJ%Ew$D- zTB?{B5np`bYgfdV9a$GnhLcbf7W52rg_9z|oPHFZYO|LeoRIzyO2rS)u$eved^-qE z<^g&?UW>R>4geOc(G>@z9K+g{7@G)=IG_Sl0jy81SaEQb+i(cvVy=VL2dmXV>5hZd zVp|lgy*F`h?Y&?2=hN53-7{+QBHfYgZpkeF)~&;%|39boT+zqtXKOV4VRsHg5@ zzN&InOh$4-B-G!Czq0YLPb;Q*DQQ`p*eODf_g~rZPsL|QYR3=SDeI+CPiz_}f%m<2 zTzeyuJP(rm$%?|mG!v_rM$26uOa)VVT2JG(B;gLG=ppo75U_+I6>i)TH^!(;xbew0 zUq%6%S6*NJO$mNZxK+c}_D1^S^w=7a)frnJw}m4$!1>%|QeE8Sgh z+r-M<^(e{2`GnfMLtHRZjA@|Tz6rFH*o44tyt*UlZ(WA}Ct^8oj%UbicsfoyoKb?9 zWVUuetWZ!uXsMW+;JhR|op7IU-@7O{uN1!eBm3;!_pR_=$BjHRfle9+!akYDd=JbB zVMlS^@p-cU@YBJ@>d&v;nJy%VcPA|o&2XR&rj7Hmv{7O^-W6|!^O9@F6b3@FlEfqWf->Gas0sp?I_I!Zm-sib=k^2IE7>IBVk_U{jP&!m_c9ada(W zm|QfBj2HvZm<$KY%IFcrx0i&W@oPGek{2(fhHQ3b_=8z{Zd)#_{4Dsg^`km zZn*pB`hUcwmKwS{*#g9fy<4h$M0AzPch{FJnInV@VkLEG^ZgF_5UKF7yVk7=OQnyf zLpY_T2chGhe9MlczC!4L*pb?`bKPp*(^bl0;k2bn)AvdN(H3wG+KOA^TU5AAg@15s zXR*H&1X1vESa3L1ls7-TZi$R{xbE;RhkZgN(3)9tm!pd685mxH>oD5$akv|WCS81Q z;7DclhmvA4sw~8zq@a#CAnZWA#!ej}NY2D-;-5z{cZf6xp)0W`zG?8&QvQ3`Y~UL( zCi?#DV}z92g0_IyPjHmemi2nY0|VKFt4bOmLo?<$K9mX0D5;Nqd{<8VTF=lx&HQev z_4aORPjJqA2K;`*Y*kPqdln!a%1k*SG?s3V)5Vrbrf#z9!rE_8#sy4$jQES@(4exg zb%F+7w_0S!(-bXsC>M5KYZMj*;=FdN(`3TKPvze!08Ik?4LCk?T9tV zEi_k+-%25ex$mjD=c-5Kuhp{kpG>BNKt+<;3^WzGgE)3V_~DY_lEeaKZ}NP|34qA! z-!>-rKHy6lz%qIVrU_JpJq<=&J0@~G{I-8x&_U^zl0`XpCpqPu=V-rB+8`UQTv~%v)5eB(k|b6LG1zCgu}d zX0|37%B1?ZbmxSlsf0W%Yw`_vgtg#d=%JjYy8zf~MrTH6V2@%UaRof^SEl-XBm1H| z@DTKE@E;6-PgRA|wUv~>jsRn948ZIJ&MQ1&+Z_Nh6TkG=t|z5|LpMy+#(AWWW0x`b znetb%KGI?_-0YIKq66V~@883BQ`t;VvkWmahHN~Uo29pkoaj&`jkR8kP zNsnndpL7( z>iKght8)MTClS4nOgnf`y$TLD>Z2|0wMHEg6LNFOakFqr5J$!JML2}LIt!5 zqaHnku^MYV<32r$W$?w&{q3tjMWA_W4O)#@17=P~BiCSn{^0L1@aooIxh!7^(&q+0 zOFtmmiXYSrER5Gm=-^YNplKd1E$|i?ihtZYWlG*}L3@^baHV3vh1#?Kn9z9mH0PMf zhc6?Ocb1kzbCly3*Au30SD0Ea;K9JV@fD7#+|bKE(|7oG6-Wt5^!}Sx(-#Cje6w%o zL<0a!C&ocpzBUk55RuWi`eb}wo{0$51>J7>QKadCXZ|D4b!GB+Lv;U*~J z13T&%c-X#J!x@wAN1;66^|v>~em-8x;nAyssG(O&>3FGJi&t3TqRr!_5H;jV25So^ zfp0KLfxD4~$a5FPtF2{xN^n-jnutt2jj?#vUMd`RVAww$j@Idy_Qp} z5;#mMSbOb+4;KWo0AZ>l3uRT``c}TSt7k_X^dycjcpq^f z=Ff(=C^bKCEs|<+6+U64B<@0lA|K$kl_MqgIbtJgtc_&u1C<9V?Q67R!NevGFBWRU z`m@(s6Kv~RCXiS8ne#BqMBdX{zL;6Kz@`@iS+5oR)8?FdfPG)f(m?sOobejRF%Gpx z)*QdMm1f2TksQul`4W{4T2fW|$bSQSCHv%Uc4-Cw0sL79tFmR3r7GD%I|yX^3~+nF zXz5j3SmHbBZ+xe|lf9ofi|b_XC7d-7rKPaMwO_T9TH+azzqRJw7f;QmX6+}d=MEz< z4bX=T!fWM0I@zq8-iRmlqL9||Mf_H^4+M`~?cZmUvf2AZMEUB#6Nn;7 zvSgLnU`z z*`25CE9LgBf>kUP{}GR;2WeKi1(8O6YzzWd)2!{~lgfJ`DI@?@Gl>P|If#qE7W7K1nzg*q8=R(izaEWkHZoipK4YIm8bv%Wl7BkC{G}u!Dd&-dpnzPZ|N~Oa31z{eQw?O$3k-W}a0ZI}}Sv zoENhCOrjg#i;2#UHjg%ZXJEokcnNjuNw6d!GhmjzKZRF5ELr?k`ww6vU-E++>_6C_ zn(A|_-!RA2#1wa^5#(yQsR_9WJZKsohrj>cc_$82QwyZ!aBnxcP9h!iDiR~Vd3 zvr;kiB|);}c0r(ZCXyjPo;E|<5y==c;#v6qhrBxAfR{PN(4CRA{LgeG&BM=%ruHBS}u6FMytSnb(R+D^%1W@QXTysI9uy!znLND!@^jy$>@FjEwM@I6N2f7Y9x#uE75<`fQCh_qonXY#aj z(9omKL{==BIbv=sU)~&ZErpr9gocXEN@OuIiL4#M6Im0&(ZeM#+(}J7Lgen34p+LmRR1==1FgOkrOejaMC;J zr4@Dx`TtA>^UcsxUNGOncidbf#)LG z!Log60TDvhBhC|f4SU?*L^cR+3iPsMw7O8(9_$`W?{@4)bcGVHcDi;;UMfT?mfl%v zXU8YfC^*33iyDkebLJs0bRnvAm+tRox4}t5^zi_s@*Y2?A;@ zME_NuZcpb7Au$};y}sN!n+;W=`5wQsYv zw$t%rxd!|ZuG8V1;!afTlG|O~%scvCc*O8Pb+jZ5p5CcAHh+Cv@0?N}wS}sK(xJ(-8~|G&{k!AIrTa%Q4fY+3{6^T{owRZ4 zlnrO(c^=o`;bcN;VnqTQK4f3a$o)$K8wPA34^z%F`SXEH@#FgOy74;h=}T%!WEUI{~ou zd?2%IAx}`|L}0SPMg)j0SwvvcD}h`FKjjmFBh~ptfFci$yG;~vgn!+8p>}~t5-ZR%^oc@!bIXw`+=+|Tqv+x+3d*aEkn<#_OX9VS@oougBpp`|!QOz-C%D<=4Y5NxnF_ri#-2-=WkKSE42mQzE zX|W22*cT?_0wL&I{7H(+6o@J4a|z#MypYR8<_X(49l*Qs{_g<3_)th_I66ID5Z>(6 zuZVSp9kzoxt6Y-9GeC4f?1r1UkF~5=G4*vf9wzzuRQHq&%Yc#6F(ql93M&fdPSl`e z@1hKJsZQ04ZDJ*;+j`Q|&pkHWNV{0b%UK#C(a>Xr)Lh1cG0<@C;=Gm?N&=)}(s~IO zCjm^*6BHW#jg15K&qwBn`CvGYB+2yXF$#b$b+FLcw9)1HQ#w+C=OOn z*Bk-p6dV+>Zk$IXg6m?7vBgJ{gLCp=oPssQOE?NSgzf_inLz1PO`k$U>UT&?R@nVc z^F7zErnUQFj*~efwyr4bmkpK1eS8PFY(c(GIgY}X2{6OJ>svI;$Ll57O70Lj!TCs* zMBUg#Y;^5ltyuk1`3MgwuFMWE4lh!44A%sF$lAwe0XD>AX+&>7Ys27ptqp8d{2ZKP zk$DAyy1Pn+bRl7w21^~GI(F3N_t3l0ZLE^YGQk%X-|OA$m4{eIu_5rw)~z4%4tedq zup!CD$P*@fVfcTXG7W^b)ee~~Zy$za+pHP8>HZ?wo&Yz~@8x7-f^J&pY-J5cAhR>nc6RBL6#@qus@wpRY@ zc?)U)6qgnW+8^+bea-G;h)on436W=)!R;6DN{^7XHd+?Gp|-X3uKxdH-?p!ie!vbN z?>^p*0!Sv@(dT@)8_sg#oRuQnrJra`#zj4GDRhG!i%7JhOxd)CLXqAnYPw_zeabGD z?Ap?iS@GrrfX;T5!tG-J7C1#z5xOtvBD-1Eml3jwaFV=Ti)j&~T5RvNR6pG&YOhnG z``UpNbI=ep4G7`9wv)^4p!Ja3sUU}-pRlltU7OKgR{R?}B%!_vk2jggWN0!Z=m{~C z$&lE6i<#J!L;aQT(|T4Rb9fGQaND;XN;0Pyx-AE}{3P!% z{CKS}#S?r0HfEBSQdj_>f(r(Siiuw~E`Oq6C0VQN4ElU*?g1wrkNsK7M8rYP7HBbu zocM)*-AMOHw`D7driv#?M(?}9JWZmHm5A5aq`Gs{yhAQzSe;Gq9v0HI62DcU|9pS> zcHWtXTfEubZuSubm4BUEn66hQMXt&10!MPJ$$a*OdOAkm1=|8@MY7yTq(MTtGMF>S_26n5L@_g}o~ zichZQ|GlYYyJyU$&(H|v%<+cod3G(aQ@v8J3@;q0Iq>;!1xsmJ!BRDjt=-fsF1Id#$re0cH9TfVQ}+AiWd^tbd*gQf5szSY82Rk+!-)z)9*x3<5g zDG&QqZ`NVW6nC9e>2;?QJuDJZuSFS3nDr@() zZ!ZI10dZA4Mqk_&r-78QxNz!6z0u8_AjCOA;F21b)g%6V(7Ayiv zpS05!aX6jT?b#}LIlZ37@0mJ--}4_h?LD2}ll)er_2I?vBAqy(6-k~;%mzzkgZtf) zh5St}CL6HUa=UPVa{<*J_}jPS_{@V*_OT^V4YAh%ghb{^!(L$3ONsw?-%s@A^n_i1 z1~vlXx{B}9HAgJGV<&(r`l)N|_duPG3a}WG3^U=$ zzxRGG(GD7VC9XL%h&D}dfTm~NG-8kX7yL6+_*fN84*H^TvBBuB6puzkhdmo0xRA}v z??rjdxK2mma1-OS{jDF zDT;gG&AKIq}b7c2<;cC{rJmTJvUXW z+&d)O+obzST#IGM!r=fv-_-1s7v);w8u%y63``U|_<;m4Qw(hQ(K>wM_lbp0WW;Rf zHCC_5@6F?W3N4U$2jyD{nyp=0vy?)?%Ab$*5xz_;R0@UtrV0ZKWim1O9dw-KaKjlA zkA>sbF=3-*HOFcU{@<3Lz~BNsEd(0{g>VUv)qkw&Ye3IcMrX<`qvZ+4#$P`)7Pn~J zFwDgKK;%3@z@A;dI+C%DgsuCwVtg{3&R)-7pr(~k=D+tHv1@M0%V*bEC1wHn6A-~o-OMG% zX}Bq;AqXpy+|(Yxb8OyT%Yk@0o36L-$?yc2r$Am2*OwWd*zdL6Tl>xUQ~E2cFGcM! z;#68S!5J-zK@9$OM2eiuG2$G#U@5bXam4^6{jCSPe0SnZ%o?aPR%%7NjFpa+3K}Df zl3-nqbM}!Bq!fN`A&M(M8n>~Zz6GFS<2e~;7%O0r^mKSSyVyR2ng-YV%R2%$wKZ<*Fdl8(;cq~X zt!<6L4O={(_Q0x^4#bIz#LL?^p{}tg-~Wbc2eBgln|5|?-+A#I#;}Va4W;$#Nb3?mMxCVvZ^y!8CI!@?txD)syB5@Ap$)##lAKjm7W5067c-U>IS~i!MkMbHIKKEsO-rJ!;^5ut&8G;*Kh)~Dq=QSmHu zt5aU9&d-u<>{LAVN0#a@rNG00Iy;3uQ+34C8_h0Z3D!pvAON#`cyj1_@lzw^xb}~1 z@pp_w{eR`Z@7}-h@3@W!;cXTaj=G+bBLP37uUne@4Y&Be?DkVvG??7|jJLt`A6)DI zmkN+2Xely3?h?0fJo@`in+bGU`=j6J8KbK0Re(@?8m`}tN=zU%C?{p zVo9_@oPH!B1{9<3<7S`JpP&;_+KHJ@5dRCIrI3bVAN+?XG-iC_GP{3>Tb|DmJsZ)x zs+0JGs+dqTJMX%)=m@bN^K&LJnS=d){xkc13OGj>Mi<0dkb>t>*9slDi0_;7iDKAV z0y{J}m^MM(@ITxNk0^d z{Z!piUrZ@>SUru%zZw^E+qWC`S{H2J$W_E#97I9HFGy5CZy@_-O!*2eWdkWZEXxO` zQ8gT%iYsgzU8JGbq1R2#%2T!!o>_l+vV>NoRG#7SVk!?Dh~g1htkivU0-rdUi6vtP z^GM=S758i2mNtOWC<ZDi}&uu>eZO><1cPmDod834Sswm9PV%0RkbQjD1v^DlRik6{yQZ z)ue$%1T^dw5@q;?R%1gO-a(3MBoB$$^4Kv>#}x1&bR9zh50Id4;37NtkgU5Tg4hBi zGlKZ+;1vCOY+3;nD~Tn~0#FT&U*Fc!K{WYR?x3&Ms*P&a&Azq9aBM8ckX7HJU1f zuOqWZ9xQ~fDVL%}WO@-jv=wCogGVX)B6WU}2)Z+8knqU`N-DIZ6#Zna8OY!uGDD^4 z^8yA@ihfB^vR#L)s2Wx)YjIq+Qt9zxv-DiPUv;W}s@~iTBFjonaqp~=kfdD0X$oYT z>b4iko$9u2#aJQ3ib%_&Vpsji0$#;#FP};X8ATG)8Fnv_ho;JDa*owZCD2}tPfGqI zg8_I|SkB7it0Thqk%I*m~L_TS@0M6`U7sHM_M-vnj3Sfv3Cjd2v zR~#qQJP5BGB>{PI>rTtTZLN$21*3p$g`SqPnpf4e(X)YSqnqPQx4{SDj7*{D2M#p| zYG@r@)6eJ~pTU-fS7NFykyk$#_o7HprAQuPzBTsjA)}OTM|(~>Yfkvv#_H|XYl_$! z`zr*wna=39R*q=^{D@B|OFWh)gj`rb7wq$n{UhZ`VvmLIo4nr#D*Y7)y5sd$TM|>M z0i_Df2*4D9PDcEA3U}uN@9yJwy1tH7~1@hOsfluv!Ac75V;H*i|oDiU*vIYADH#U-S@Q?a-y z_o0PDzbdr-PS&a=lI^#!t$lF{bYQX?@f|o}JlbjwA!sa)UJ&A5TX@6dtxIW4Pacga zT8wO+T@;F?geXJ{+vrE#lueVICx)B3!KVEd{KvY_!lpYstsZni{lCMezf`CZ<|E2c*HMWf%=LfH zrcX>L@(cz&QG`Js5P}Ne3?#8;^gByoKlG2BY&kRs$ZPRJeCzB~bgFhZE*>gLG6Le) zaoS8|79#%%@DGLg!51v#m{Voqr)%xVq5sshau7ka1|2^R{hfg9+bPL+!f^t&LgG%N zq+n|aG-b)~;nibqJtv?@LCv7;#`F5hJP{4&AQA&g7l&2W9 zzsMa@_oEbMQ}bI|-00{x>|7G{H|!PzJp;pp&)Sr!=Beg0Z^~4&pd&&|1us8305+fu z8>~jpPBp7N8O_j8SfINg|8sFkr4K_R`07-0st(nO;-h*AY(#*l3#lAzW0}!eqR*nCmUMcx>jnc!c zgJay&U!bvD>Va*SbVqMm9D@@4iUt7Lw1UD0aS^T~5Ey9LNVhyvguUWA-S3^Mo+5y( zqe0s=DFH@pQX;A5tT5hmQ)R!rr82KYi%3r<4X5P*FP3$6tj2!{{l>r7?ppf2bm%_0ZF@^=OGC#FYUPV| zl-{;ZvsZWE{Pnz9H|hZ;+qH9zNA!DE!$EVzswINzdp8rw z9bDve$-$cU#S0CYY?>ON03%33nP*TFmKUN5*=vw_WyVt-s>MY4AcFU}`6rqgDvBlBlNImM)5GYMvBkm|pIV+pxi=D=X`3N6nU4MV1e zX}oD#s`tJPz40)daUu*Yj7_2?ivTg&mZf`N5lPboR1_JTiToWu9Ky4Cq^7Pdq&+wr zJ6nl$+qnuoLw_va);3&eKVJGp?CZAJtIq?68{X5@SJ(;co_k_NX8{(Ad%@wHCc|9`B_{{J{&Xv9)FDDXZFPYjQ8j>s)!mQ!;e zi?ksZ$1Z}P=JFLwAqew_9VJ2Td!j4 zLJpL9sVD|zyD#Ms0{jAmNb4i6xD3Ziib@w+kzTxGi(`u-rco=Utr+9RL)g7Qmtlj0 z2$`29KfX{%OZq1OgM{UnMIuzSHYVk43l{S%);z^M@z7+JaG6FTok$CO<#sPA{)h~9 zm_<>k0s?|urJmg5)+?(Z~AuSY+Q~~FP8>Q3E0i56E6?>=1Y5f1OgEe3Bdk6iasd+o=wuWXA-L5&!zGKLXLs2V!2jRSXhSY*_W4;-#cr9c;tWC z7>%V~#4-YcEsUWn4)dg2EUjXt?m{TXis=@k@zJ=2Q=@UaxJ?-KZgk|b3*7pDg?`mKTuqvjB)n_^%m9!!cw)BbSA zeRn>(2p1R-3fqefM(bxt7CM(L@ap>OP$6xL#Vy)4;G0B9DlMY;IXyT7xkT`A0pBx9 zNFy-~2^Wul2X(dhK3O*y4hg|W(B9#Yn7^XE!2kOLzC@W9Ct@bXLwP9qd%?qJL6yM3-b6F`3BEmcuYd-uRc|FUDnPGXevc2<` zm~)p`c#3IScOf5N5M?F8>&ZcMr?rUdSY`|~QjEdHL4b%Ddg<7_SPXF#o_C%0t6r=k zPlqy3ILyRjp_tBVS;dlK1*-VM10TN=jkP>H6On8gm8|}O>ZKw@9=+b<+2fTI7v!F2 z4hpFNYf**)sR@820MGqTKnWlwf11vdtdd<`P}f)CJdxWfUQKI3H??B+S#*KT(i8-k z;MAa-=jCg&&wh1@W~@ZCa-mNm&60>GmK;<>NtXMnr#%uyGWhG4K_g|MF8U+6Pen@A z47%;gIX>AY$=&!_ECRYGMkT8plQcldWenv_Ylfe#W5Ct%Yl|nTY$|-%a z_JIHYKT}@?OSK#?1)bRI%BK_KCF5|h@kNx9;xR7CjbeW62-n?4Duuuc)>}(_lYmw7 zPaFwDwGG=;M?Pgyfxg-6+wPfBP>Skw!!Ch;Dl@r%ly{|v^g!jQgFh^4ph)z18%d~9 zlmRut_->hWfvSX=5(INqn8kGEZcSyTGD&CBX{1q7hlUf~E&C)rUtmty^A^;I?}ZP; zPS3}h$0US95_g)CIH%@B&-eOlRBdj5HLL`{N;-R-@2q^M1uif*v~-!GjL5YzyCfsF z6W`#M81Bd%@4a!_J4NQcb=i?sku2lXz%)jF@P>Vkedq3TBh9&+2AgHGRks<u3i`p5rJHKmDhr}?$F~IpSv^$Q z;jgqddAm9}Q*~$%4WX9ZxHBn!r{HvFQh*3sV6L4>wrsWip6bVDTh;?x8``1R@>YaS z%?Y`@ZfB}6rU&1cP`5L6x&4OUuK22edKF!PgLuepsR+43E>3Z(Es9gj!eCqtdb5re zL6icosB{F_0Rj+cWF-pV=3k7=gCNjvvaB-lZ}0%-CA|U;Ps%XsdJ-MEWz5N%jSsJ7 zEijkhhzz$HvDf$m321ZZiTle!V_fXnhW6nn$@@HbA*L60qOgzzw`g4zL>Pm6pvj>u zM)aC5j>pj~rjBwcj5_q#=JRX;1L#+`1i`9w+M&|L!wmkF^SQziQ z!M?8X_)s@3N-c|JV!4q!EGmK)W2GQuL{j;{EppLP`yJS(A~B-q&}kavBiTz2R0?`3 z?txw&K0Zm>xYNY|Or*u1$Qn-Ri8R5jINY7--KoNL?M|KW?Q)~gDmED1s%H%^`LNdR zs+E{O!Ta1!oajFB9okC&*gN#7eBAivr~TVE>N5jBSxKF8uHgmVQRy9dIxlQT6>Vq= zZ?tvoX!kUUBp5TR2Y#zWyI!}pY?WT8*J*o0TJn6;ongpM6hMPmmAue>7M>q z+jy={SLeyLCUZ6~dOO&wo~Ob^um$mf4kKUZb&ppJ|8h3#D)_B7kf7PFiDkBW8a zUfsL=R9m*A$)lH(36(~(rz?Dva(;~G15dfzt3J!!Q`*Xn$Z^`@ANGg*tom zw}}m2o`r2U`qS3v{^nLFajidt%c!A4>+iijd<9C5!0y}WX<8n*I_i$PHFtCc(R6mv zvVajKPf$5FSffqKd#0b5~5@A?`wl=i1l~;uRIdBq&*ef+hU`GFfuc0$~ z)t%lgo~9L#xBWwH?Tx|Dh4f%|u$!UXBRKT2hVZn1dw6)@U5T%=?JXUzwR;*{HnlVk z=1z4kwA|_GeUU;MwMtpq|1&SJpR)6Np59@6ZHKnMy~A@^Ph0Oxp67P>*XS3GJ?a^o z6PjvE+r-o1iy{kV)=#1*TUHhB=vnAl&`JU+y{geO@buUX+k$V7-K0;By|k&NdE3q{ zd;d9@AZaBtRM+!j~yve~}R9eDrFiSYLi4|o3B z)6lqiWOQ^|rIJ4R|nqS`=;+TNSvZ@(CR zlnYCXfn<2*md!z=!|fUV-p^aMQfG#igRjQ^N37&PGU#LRpik=#`ousFU0<*>UKtDp zLxCA>aann?TX*FRr|x99Y0?*eX787i1Ky5`ofV!JwzlsIA6gczjn+aJ`$GT9V6%N3 z9BsQZSRbrsxxhrQ{_e*&dRo1{;S0XDt@GebuQd$c)c5LUPve$7cX)rY4t6tUXMnfguUuN_kDV)~`+gh~F#!OJ&hUh-nN{JY6S&0un zwd*}RDGB%q{l+&;kr;wAR!ggj(Adt_oV3m31GE1k$Opu`3-YzNz_ZGma}&HdKIW?` zU%^%gQBV8GbIt6%FpWUKgAQ1rnpI#;oDG9z^7YO{KcI|u;I-0t;f83y=WK6%V6!A^ zIS4m}nRUF|I*x;LV|Vypt<4M16{_{^e><+7WW8S`>HP1JoQ%lPk;d?vMl ziYyXl>YiogO`c6HZJws*2tg};?cuo~onY#Lr@}*|+g826DI=7DU<1s4foGm?MfqIU z&piI?IvV`H>ReXd(AE?QAzNIU54=G_<$!psXUBQ^A(^WB?QoIp7*~T1u=4tF~ z`*i%cmP478eYHHD_oVRz7&9nk@Ck3{w#fN?-oCUxtR+`bQAo`hdhh38?CkL5BKzWZ z^n5e=KX$ny+qIV)c>9?sTUHKka%T&Ij#_s_>!Nj9UG&z*o>$`=IP?2s=4(48xo5?4 zy`jw$xDFY`P5vu<-d`FQk#!@K5!^j+D!8hZ1c{#E<*%TpN9&F(FUr!tCR)Q@-TTp) z8x>rl{dXv$5=)FMjx0{hP0SgIyOYzIJtcce*y6zqt2V>o1tB>&pGQU<#s`+#2Y1#B z%qXr<27l4_57+cNIWz|_ z2kOw0+DQ+k{pEYEL_W>6{<^&mV-Y>0F|@j#`KoUjiv;b)q8ia(9NaRnXvml)nh<>w z7!h&}EUMLL^SH)eilO~m+knf`{j~-0bx)24l+dHsH+`?WC&5Ku#J3RA(=SX52n-7d zt%-!7IFpqF^@2u|kdEmm3;F_;tP*rfwt-pNQrRziN?j5-$A5)oavHTu$fptE$Y-Km zaCKXj!|ZR!EEafITPL=)GrQ?z+cNF4z;i_L*kf#i_V4=5pm4oh%37&an|P>Qd`&B0 zyu%ap2EAGhcJ$+y`8oi~z{ZB=z!$^+6i5UTRlzH}KvN-JzrHzmY+FZ%CvY_|F!-$h zaOm%Vdj4;KR<(3^+qMR-<`wyrGz&7@zTzjO7esE-x+wGgWUCL&lAa43Yx6JLM6iQ# zYw$1Gh^O`oX+e(jq%Ur{suTZ zLK{MB0~aLb_BzGTl6#$HRl(QPXPCRA6}=O|g+P6ve(;mQQ8~|@FYVmk;C~vznrHjStBufj zS~|BLm~3f-*gf$==klqWcxi-FLqBZ=p`Q9F8hylTAq#?oM?DUo7V@O z>J|T0{#UyKE5$~RhKwr?FC6~qfgkjx+aCEYDkh9g-Wgc7t#{>)UwfLiH3nYts{8Nk zT+V(zb;CwabXCJ~_wh@=JGQg6;pLXV<{9o)#Qi?s^MOv!)`qsOmd4-%0D{{>?#SQv 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

3Wdts{cq}(gBmHdb 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 KA9sQ(EdK|y|I3pA literal 0 HcmV?d00001 diff --git a/exports/K.html b/exports/K.html new file mode 100644 index 00000000000..1bbd29c01c0 --- /dev/null +++ b/exports/K.html @@ -0,0 +1,23816 @@ + + + + + K + + + + + + +