From 33c15eedb3c1861942229862d52088fcaae9116d Mon Sep 17 00:00:00 2001 From: github-actions Date: Thu, 28 Nov 2024 15:26:59 +0000 Subject: [PATCH] Update from GitHub Actions --- .nojekyll | 0 GSG/get_started.html | 688 +++++++++++ GSG/installation.html | 632 ++++++++++ GSG/integrate.html | 708 +++++++++++ GSG/next_steps.html | 812 ++++++++++++ GSG/samples.html | 689 +++++++++++ GSG/system_requirements.html | 631 ++++++++++ _images/dependence_graph.jpg | Bin 0 -> 17375 bytes _images/execution_timeline2node.jpg | Bin 0 -> 25634 bytes _images/execution_timeline_dependence.jpg | Bin 0 -> 28571 bytes _images/fg_api_graph_structure.png | Bin 0 -> 22555 bytes _images/flow_graph.jpg | Bin 0 -> 16326 bytes _images/flow_graph_complex.jpg | Bin 0 -> 24389 bytes .../flow_graph_message_passing_protocol.jpg | Bin 0 -> 17179 bytes _images/flow_graph_reserve_buffers_1.png | Bin 0 -> 9765 bytes _images/flow_graph_reserve_buffers_2.png | Bin 0 -> 9680 bytes _images/flow_graph_reserve_buffers_3.png | Bin 0 -> 9821 bytes _images/flow_graph_reserve_buffers_4.png | Bin 0 -> 9849 bytes _images/flow_graph_reserve_buffers_5.png | Bin 0 -> 9924 bytes _images/flow_graph_reserve_buffers_6.png | Bin 0 -> 12422 bytes _images/flow_graph_reserve_buffers_7.png | Bin 0 -> 9962 bytes _images/how-oneTBB-works.png | Bin 0 -> 53481 bytes _images/image002.jpg | Bin 0 -> 10682 bytes _images/image002a.jpg | Bin 0 -> 30886 bytes _images/image003a.jpg | Bin 0 -> 10918 bytes _images/image004.jpg | Bin 0 -> 3680 bytes _images/image004a.jpg | Bin 0 -> 9075 bytes _images/image005a.jpg | Bin 0 -> 11863 bytes _images/image006.jpg | Bin 0 -> 14805 bytes _images/image006a.jpg | Bin 0 -> 11981 bytes _images/image007.jpg | Bin 0 -> 21448 bytes _images/image007a.jpg | Bin 0 -> 16506 bytes _images/image008.jpg | Bin 0 -> 20556 bytes _images/image008a.jpg | Bin 0 -> 30488 bytes _images/image009.jpg | Bin 0 -> 41411 bytes _images/image009a.jpg | Bin 0 -> 21793 bytes _images/image010.jpg | Bin 0 -> 767 bytes _images/image011.jpg | Bin 0 -> 5852 bytes _images/image012.jpg | Bin 0 -> 5596 bytes _images/image013.jpg | Bin 0 -> 5533 bytes _images/make_edges_example.png | Bin 0 -> 23424 bytes _images/make_edges_usage.png | Bin 0 -> 289439 bytes _sources/GSG/get_started.rst | 49 + _sources/GSG/installation.rst | 7 + _sources/GSG/integrate.rst | 68 + _sources/GSG/next_steps.rst | 157 +++ _sources/GSG/samples.rst | 49 + _sources/GSG/system_requirements.rst | 6 + _sources/index.rst | 15 + _sources/index/index_intro.rst | 5 + _sources/index/toctree.rst | 38 + _sources/index/useful_topics.rst | 5 + _sources/main/intro/Benefits.rst | 88 ++ _sources/main/intro/help_support.rst | 15 + _sources/main/intro/intro_os.rst | 35 + _sources/main/intro/limitations.rst | 46 + _sources/main/intro/notation.rst | 106 ++ _sources/main/intro/testing_approach.rst | 31 + .../reference/concurrent_lru_cache_cls.rst | 163 +++ .../main/reference/constructors_for_nodes.rst | 104 ++ .../main/reference/custom_mutex_chmap.rst | 158 +++ .../follows_and_precedes_functions.rst | 78 ++ .../helpers_for_expressing_graphs.rst | 118 ++ .../main/reference/make_edges_function.rst | 81 ++ .../main/reference/make_node_set_function.rst | 42 + .../reference/parallel_for_each_semantics.rst | 66 + .../parallel_sort_ranges_extension.rst | 72 ++ _sources/main/reference/reference.rst | 53 + _sources/main/reference/rvalue_reduce.rst | 91 ++ .../main/reference/scalable_memory_pools.rst | 44 + .../scalable_memory_pools/fixed_pool_cls.rst | 76 ++ .../malloc_replacement_log.rst | 84 ++ .../memory_pool_allocator_cls.rst | 117 ++ .../scalable_memory_pools/memory_pool_cls.rst | 80 ++ .../main/reference/task_group_extensions.rst | 89 ++ _sources/main/reference/try_put_and_wait.rst | 324 +++++ .../reference/type_specified_message_keys.rst | 69 ++ .../main/tbb_userguide/Advanced_Example.rst | 96 ++ ..._Topic_Other_Kinds_of_Iteration_Spaces.rst | 111 ++ .../tbb_userguide/Allocator_Configuration.rst | 42 + .../main/tbb_userguide/Automatic_Chunking.rst | 23 + .../Bandwidth_and_Cache_Affinity_os.rst | 107 ++ .../Basic_Flow_Graph_concepts.rst | 16 + .../Cancellation_Without_An_Exception.rst | 46 + .../Cancellation_and_Nested_Parallelism.rst | 136 ++ .../Concurrent_Queue_Classes.rst | 108 ++ _sources/main/tbb_userguide/Constraints.rst | 30 + _sources/main/tbb_userguide/Containers.rst | 55 + .../tbb_userguide/Controlling_Chunking_os.rst | 170 +++ .../Cook_Until_Done_parallel_do.rst | 84 ++ .../main/tbb_userguide/Data_Flow_Graph.rst | 198 +++ .../Debug_Versus_Release_Libraries.rst | 56 + .../main/tbb_userguide/Dependence_Graph.rst | 147 +++ _sources/main/tbb_userguide/Edges.rst | 46 + .../Exceptions_and_Cancellation.rst | 76 ++ .../tbb_userguide/Floating_Point_Settings.rst | 60 + .../Flow-Graph-exception-tips.rst | 17 + .../tbb_userguide/Flow-Graph-waiting-tips.rst | 11 + _sources/main/tbb_userguide/Flow_Graph.rst | 14 + .../Flow_Graph_Buffering_in_Nodes.rst | 42 + .../Flow_Graph_Message_Passing_Protocol.rst | 47 + .../tbb_userguide/Flow_Graph_Reservation.rst | 286 +++++ .../Flow_Graph_Single_Vs_Broadcast.rst | 112 ++ .../main/tbb_userguide/Flow_Graph_Tips.rst | 13 + .../Flow_Graph_making_edges_tips.rst | 13 + .../Flow_Graph_nested_parallelism_tips.rst | 10 + .../Flow_Graph_resource_tips.rst | 18 + .../tbb_userguide/Graph_Main_Categories.rst | 21 + _sources/main/tbb_userguide/Graph_Object.rst | 34 + .../Guiding_Task_Scheduler_Execution.rst | 112 ++ .../How_Task_Scheduler_Works.rst | 50 + ...itializing_and_Terminating_the_Library.rst | 22 + ..._Over_a_Concurrent_Queue_for_Debugging.rst | 29 + .../main/tbb_userguide/Lambda_Expressions.rst | 102 ++ ...C_Dynamic_Memory_Interface_Replacement.rst | 78 ++ _sources/main/tbb_userguide/Linux_OS.rst | 36 + .../main/tbb_userguide/Lock_Pathologies.rst | 75 ++ _sources/main/tbb_userguide/Mac_OS.rst | 32 + .../tbb_userguide/Mapping_Nodes2Tasks.rst | 57 + .../main/tbb_userguide/Memory_Allocation.rst | 71 ++ .../main/tbb_userguide/Migration_Guide.rst | 15 + .../Migration_Guide/Mixing_Two_Runtimes.rst | 49 + .../Migration_Guide/Task_API.rst | 453 +++++++ .../Migration_Guide/Task_Scheduler_Init.rst | 158 +++ .../tbb_userguide/More_on_HashCompare.rst | 91 ++ _sources/main/tbb_userguide/Mutex_Flavors.rst | 176 +++ .../main/tbb_userguide/Mutual_Exclusion.rst | 130 ++ _sources/main/tbb_userguide/Nodes.rst | 151 +++ .../tbb_userguide/Non-Linear_Pipelines.rst | 62 + .../tbb_userguide/Package_Contents_os.rst | 18 + .../Parallelizing_Complex_Loops.rst | 17 + .../Parallelizing_Flow_Graph.rst | 102 ++ .../Parallelizing_Simple_Loops_os.rst | 40 + .../Parallelizing_Simple_Loops_toctree.rst | 11 + .../tbb_userguide/Partitioner_Summary.rst | 64 + .../tbb_userguide/Predefined_Node_Types.rst | 54 + .../tbb_userguide/Reader_Writer_Mutexes.rst | 21 + _sources/main/tbb_userguide/References.rst | 19 + .../Scalable_Memory_Allocator.rst | 15 + .../tbb_userguide/Summary_of_Containers.rst | 11 + .../Summary_of_Loops_and_Pipelines.rst | 10 + .../tbb_userguide/Task-Based_Programming.rst | 92 ++ .../tbb_userguide/Task_Scheduler_Bypass.rst | 20 + .../main/tbb_userguide/The_Task_Scheduler.rst | 21 + .../tbb_userguide/Throughput_of_pipeline.rst | 35 + _sources/main/tbb_userguide/Timing.rst | 52 + .../main/tbb_userguide/UpgradeDowngrade.rst | 51 + .../tbb_userguide/Using_Circular_Buffers.rst | 23 + .../tbb_userguide/When_Not_to_Use_Queues.rst | 32 + ...ask-Based_Programming_Is_Inappropriate.rst | 19 + .../Which_Dynamic_Libraries_to_Use.rst | 42 + ...C_Dynamic_Memory_Interface_Replacement.rst | 83 ++ _sources/main/tbb_userguide/Windows_OS_ug.rst | 66 + .../Working_on_the_Assembly_Line_pipeline.rst | 356 ++++++ .../tbb_userguide/always_use_wait_for_all.rst | 43 + _sources/main/tbb_userguide/appendix_A.rst | 48 + _sources/main/tbb_userguide/appendix_B.rst | 74 ++ .../attach_flow_graph_to_arena.rst | 47 + .../automatically-replacing-malloc.rst | 22 + .../avoid_dynamic_node_removal.rst | 27 + .../tbb_userguide/avoiding_data_races.rst | 59 + .../main/tbb_userguide/broadcast_or_send.rst | 134 ++ .../main/tbb_userguide/cancel_a_graph.rst | 86 ++ .../cancelling_nested_parallelism.rst | 21 + .../tbb_userguide/catching_exceptions.rst | 80 ++ .../tbb_userguide/communicate_with_nodes.rst | 106 ++ .../tbb_userguide/concurrent_hash_map.rst | 131 ++ .../tbb_userguide/concurrent_vector_ug.rst | 62 + .../create_token_based_system.rst | 144 +++ .../design_patterns/Agglomeration.rst | 171 +++ .../design_patterns/Design_Patterns.rst | 58 + .../design_patterns/Divide_and_Conquer.rst | 217 ++++ .../design_patterns/Elementwise.rst | 138 +++ .../design_patterns/Fenced_Data_Transfer.rst | 164 +++ .../design_patterns/GUI_Thread.rst | 205 +++ .../design_patterns/General_References.rst | 15 + .../design_patterns/Lazy_Initialization.rst | 109 ++ .../design_patterns/Local_Serializer.rst | 282 +++++ .../Non-Preemptive_Priorities.rst | 177 +++ .../Odd-Even_Communication.rst | 61 + .../design_patterns/Reduction.rst | 281 +++++ .../design_patterns/Reference_Counting.rst | 144 +++ .../design_patterns/Wavefront.rst | 199 +++ .../destroy_graphs_outside_main_thread.rst | 44 + .../estimate_flow_graph_performance.rst | 52 + .../main/tbb_userguide/parallel_for_os.rst | 125 ++ .../tbb_userguide/parallel_for_toctree.rst | 10 + .../main/tbb_userguide/parallel_reduce.rst | 186 +++ _sources/main/tbb_userguide/std_invoke.rst | 217 ++++ _sources/main/tbb_userguide/title.rst | 29 + .../tbb_userguide/use_concurrency_limits.rst | 79 ++ .../main/tbb_userguide/use_graph_reset.rst | 30 + .../main/tbb_userguide/use_input_node.rst | 112 ++ .../main/tbb_userguide/use_limiter_node.rst | 87 ++ _sources/main/tbb_userguide/use_make_edge.rst | 25 + .../tbb_userguide/use_nested_algorithms.rst | 68 + .../tbb_userguide/use_nested_flow_graphs.rst | 132 ++ .../main/tbb_userguide/work_isolation.rst | 139 +++ _static/basic.css | 914 ++++++++++++++ _static/custom.js | 37 + _static/doctools.js | 149 +++ _static/documentation_options.js | 13 + _static/favicons.png | Bin 0 -> 467 bytes _static/file.png | Bin 0 -> 286 bytes _static/images/logo_binder.svg | 19 + _static/images/logo_colab.png | Bin 0 -> 7601 bytes _static/images/logo_deepnote.svg | 1 + _static/images/logo_jupyterhub.svg | 1 + _static/language_data.js | 192 +++ _static/locales/ar/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/bg/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/bn/LC_MESSAGES/booktheme.po | 63 + _static/locales/ca/LC_MESSAGES/booktheme.po | 66 + _static/locales/cs/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/da/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/de/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/el/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/eo/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/es/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/et/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/fi/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/fr/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/hr/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/id/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/it/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/iw/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/ja/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/ko/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/lt/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/lv/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/ml/LC_MESSAGES/booktheme.po | 66 + _static/locales/mr/LC_MESSAGES/booktheme.po | 66 + _static/locales/ms/LC_MESSAGES/booktheme.po | 66 + _static/locales/nl/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/no/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/pl/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/pt/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/ro/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/ru/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/sk/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/sl/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/sr/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/sv/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/ta/LC_MESSAGES/booktheme.po | 66 + _static/locales/te/LC_MESSAGES/booktheme.po | 66 + _static/locales/tg/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/th/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/tl/LC_MESSAGES/booktheme.po | 66 + _static/locales/tr/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/uk/LC_MESSAGES/booktheme.po | 75 ++ _static/locales/ur/LC_MESSAGES/booktheme.po | 66 + _static/locales/vi/LC_MESSAGES/booktheme.po | 75 ++ .../locales/zh_CN/LC_MESSAGES/booktheme.po | 75 ++ .../locales/zh_TW/LC_MESSAGES/booktheme.po | 75 ++ _static/minus.png | Bin 0 -> 90 bytes _static/oneAPI-rgb-rev-100.png | Bin 0 -> 7414 bytes _static/plus.png | Bin 0 -> 90 bytes _static/pygments.css | 152 +++ _static/sbt-webpack-macros.html | 11 + _static/scripts/bootstrap.js | 3 + _static/scripts/bootstrap.js.LICENSE.txt | 5 + _static/scripts/bootstrap.js.map | 1 + _static/scripts/fontawesome.js | 3 + _static/scripts/fontawesome.js.LICENSE.txt | 5 + _static/scripts/fontawesome.js.map | 1 + _static/scripts/pydata-sphinx-theme.js | 2 + _static/scripts/pydata-sphinx-theme.js.map | 1 + _static/scripts/sphinx-book-theme.js | 2 + _static/scripts/sphinx-book-theme.js.map | 1 + _static/searchtools.js | 632 ++++++++++ _static/sphinx_highlight.js | 154 +++ _static/styles/pydata-sphinx-theme.css | 32 + _static/styles/pydata-sphinx-theme.css.map | 1 + _static/styles/sphinx-book-theme.css | 19 + _static/styles/sphinx-book-theme.css.map | 1 + _static/styles/theme.css | 2 + _static/tabs.css | 89 ++ _static/tabs.js | 145 +++ _static/theme_overrides.css | 13 + .../fontawesome/webfonts/fa-brands-400.ttf | Bin 0 -> 209128 bytes .../fontawesome/webfonts/fa-brands-400.woff2 | Bin 0 -> 117852 bytes .../fontawesome/webfonts/fa-regular-400.ttf | Bin 0 -> 67860 bytes .../fontawesome/webfonts/fa-regular-400.woff2 | Bin 0 -> 25392 bytes .../fontawesome/webfonts/fa-solid-900.ttf | Bin 0 -> 420332 bytes .../fontawesome/webfonts/fa-solid-900.woff2 | Bin 0 -> 156400 bytes _static/webpack-macros.html | 24 + genindex.html | 650 ++++++++++ index.html | 798 ++++++++++++ index/index_intro.html | 637 ++++++++++ index/toctree.html | 801 ++++++++++++ index/useful_topics.html | 637 ++++++++++ main/intro/Benefits.html | 696 +++++++++++ main/intro/help_support.html | 636 ++++++++++ main/intro/intro_os.html | 650 ++++++++++ main/intro/limitations.html | 697 +++++++++++ main/intro/notation.html | 717 +++++++++++ main/intro/testing_approach.html | 657 ++++++++++ main/reference/concurrent_lru_cache_cls.html | 859 +++++++++++++ main/reference/constructors_for_nodes.html | 768 ++++++++++++ main/reference/custom_mutex_chmap.html | 824 +++++++++++++ .../follows_and_precedes_functions.html | 739 +++++++++++ .../helpers_for_expressing_graphs.html | 770 ++++++++++++ main/reference/make_edges_function.html | 742 +++++++++++ main/reference/make_node_set_function.html | 705 +++++++++++ .../parallel_for_each_semantics.html | 725 +++++++++++ .../parallel_sort_ranges_extension.html | 746 +++++++++++ main/reference/reference.html | 715 +++++++++++ main/reference/rvalue_reduce.html | 779 ++++++++++++ main/reference/scalable_memory_pools.html | 675 ++++++++++ .../scalable_memory_pools/fixed_pool_cls.html | 747 +++++++++++ .../malloc_replacement_log.html | 730 +++++++++++ .../memory_pool_allocator_cls.html | 792 ++++++++++++ .../memory_pool_cls.html | 752 +++++++++++ main/reference/task_group_extensions.html | 767 ++++++++++++ main/reference/try_put_and_wait.html | 934 ++++++++++++++ .../type_specified_message_keys.html | 729 +++++++++++ main/tbb_userguide/Advanced_Example.html | 705 +++++++++++ ...Topic_Other_Kinds_of_Iteration_Spaces.html | 772 ++++++++++++ .../Allocator_Configuration.html | 658 ++++++++++ main/tbb_userguide/Automatic_Chunking.html | 645 ++++++++++ .../Bandwidth_and_Cache_Affinity_os.html | 693 +++++++++++ .../Basic_Flow_Graph_concepts.html | 642 ++++++++++ .../Cancellation_Without_An_Exception.html | 667 ++++++++++ .../Cancellation_and_Nested_Parallelism.html | 720 +++++++++++ .../Concurrent_Queue_Classes.html | 704 +++++++++++ main/tbb_userguide/Constraints.html | 652 ++++++++++ main/tbb_userguide/Containers.html | 678 ++++++++++ .../Controlling_Chunking_os.html | 749 +++++++++++ .../Cook_Until_Done_parallel_do.html | 685 +++++++++++ main/tbb_userguide/Data_Flow_Graph.html | 772 ++++++++++++ .../Debug_Versus_Release_Libraries.html | 688 +++++++++++ main/tbb_userguide/Dependence_Graph.html | 721 +++++++++++ main/tbb_userguide/Edges.html | 664 ++++++++++ .../Exceptions_and_Cancellation.html | 688 +++++++++++ .../Floating_Point_Settings.html | 677 ++++++++++ .../Flow-Graph-exception-tips.html | 641 ++++++++++ .../Flow-Graph-waiting-tips.html | 637 ++++++++++ main/tbb_userguide/Flow_Graph.html | 693 +++++++++++ .../Flow_Graph_Buffering_in_Nodes.html | 657 ++++++++++ .../Flow_Graph_Message_Passing_Protocol.html | 654 ++++++++++ .../tbb_userguide/Flow_Graph_Reservation.html | 809 ++++++++++++ .../Flow_Graph_Single_Vs_Broadcast.html | 718 +++++++++++ main/tbb_userguide/Flow_Graph_Tips.html | 671 ++++++++++ .../Flow_Graph_making_edges_tips.html | 639 ++++++++++ .../Flow_Graph_nested_parallelism_tips.html | 636 ++++++++++ .../Flow_Graph_resource_tips.html | 646 ++++++++++ main/tbb_userguide/Graph_Main_Categories.html | 645 ++++++++++ main/tbb_userguide/Graph_Object.html | 651 ++++++++++ .../Guiding_Task_Scheduler_Execution.html | 723 +++++++++++ .../How_Task_Scheduler_Works.html | 670 ++++++++++ ...tializing_and_Terminating_the_Library.html | 670 ++++++++++ ...Over_a_Concurrent_Queue_for_Debugging.html | 647 ++++++++++ main/tbb_userguide/Lambda_Expressions.html | 711 +++++++++++ ..._Dynamic_Memory_Interface_Replacement.html | 673 ++++++++++ main/tbb_userguide/Linux_OS.html | 676 ++++++++++ main/tbb_userguide/Lock_Pathologies.html | 674 ++++++++++ main/tbb_userguide/Mac_OS.html | 667 ++++++++++ main/tbb_userguide/Mapping_Nodes2Tasks.html | 667 ++++++++++ main/tbb_userguide/Memory_Allocation.html | 688 +++++++++++ main/tbb_userguide/Migration_Guide.html | 664 ++++++++++ .../Migration_Guide/Mixing_Two_Runtimes.html | 671 ++++++++++ .../Migration_Guide/Task_API.html | 1094 +++++++++++++++++ .../Migration_Guide/Task_Scheduler_Init.html | 809 ++++++++++++ main/tbb_userguide/More_on_HashCompare.html | 698 +++++++++++ main/tbb_userguide/Mutex_Flavors.html | 795 ++++++++++++ main/tbb_userguide/Mutual_Exclusion.html | 734 +++++++++++ main/tbb_userguide/Nodes.html | 740 +++++++++++ main/tbb_userguide/Non-Linear_Pipelines.html | 661 ++++++++++ main/tbb_userguide/Package_Contents_os.html | 641 ++++++++++ .../Parallelizing_Complex_Loops.html | 646 ++++++++++ .../Parallelizing_Flow_Graph.html | 693 +++++++++++ .../Parallelizing_Simple_Loops_os.html | 685 +++++++++++ .../Parallelizing_Simple_Loops_toctree.html | 633 ++++++++++ main/tbb_userguide/Partitioner_Summary.html | 683 ++++++++++ main/tbb_userguide/Predefined_Node_Types.html | 693 +++++++++++ main/tbb_userguide/Reader_Writer_Mutexes.html | 642 ++++++++++ main/tbb_userguide/References.html | 638 ++++++++++ .../Scalable_Memory_Allocator.html | 638 ++++++++++ main/tbb_userguide/Summary_of_Containers.html | 634 ++++++++++ .../Summary_of_Loops_and_Pipelines.html | 635 ++++++++++ .../tbb_userguide/Task-Based_Programming.html | 695 +++++++++++ main/tbb_userguide/Task_Scheduler_Bypass.html | 646 ++++++++++ main/tbb_userguide/The_Task_Scheduler.html | 645 ++++++++++ .../tbb_userguide/Throughput_of_pipeline.html | 654 ++++++++++ main/tbb_userguide/Timing.html | 662 ++++++++++ main/tbb_userguide/UpgradeDowngrade.html | 667 ++++++++++ .../tbb_userguide/Using_Circular_Buffers.html | 644 ++++++++++ .../tbb_userguide/When_Not_to_Use_Queues.html | 649 ++++++++++ ...sk-Based_Programming_Is_Inappropriate.html | 642 ++++++++++ .../Which_Dynamic_Libraries_to_Use.html | 663 ++++++++++ ..._Dynamic_Memory_Interface_Replacement.html | 681 ++++++++++ main/tbb_userguide/Windows_OS_ug.html | 701 +++++++++++ ...Working_on_the_Assembly_Line_pipeline.html | 917 ++++++++++++++ .../always_use_wait_for_all.html | 659 ++++++++++ main/tbb_userguide/appendix_A.html | 665 ++++++++++ main/tbb_userguide/appendix_B.html | 685 +++++++++++ .../attach_flow_graph_to_arena.html | 684 +++++++++++ .../automatically-replacing-malloc.html | 644 ++++++++++ .../avoid_dynamic_node_removal.html | 644 ++++++++++ main/tbb_userguide/avoiding_data_races.html | 676 ++++++++++ main/tbb_userguide/broadcast_or_send.html | 737 +++++++++++ main/tbb_userguide/cancel_a_graph.html | 697 +++++++++++ .../cancelling_nested_parallelism.html | 640 ++++++++++ main/tbb_userguide/catching_exceptions.html | 688 +++++++++++ .../tbb_userguide/communicate_with_nodes.html | 713 +++++++++++ main/tbb_userguide/concurrent_hash_map.html | 741 +++++++++++ main/tbb_userguide/concurrent_vector_ug.html | 675 ++++++++++ .../create_token_based_system.html | 745 +++++++++++ .../design_patterns/Agglomeration.html | 724 +++++++++++ .../design_patterns/Design_Patterns.html | 666 ++++++++++ .../design_patterns/Divide_and_Conquer.html | 781 ++++++++++++ .../design_patterns/Elementwise.html | 708 +++++++++++ .../design_patterns/Fenced_Data_Transfer.html | 739 +++++++++++ .../design_patterns/GUI_Thread.html | 780 ++++++++++++ .../design_patterns/General_References.html | 646 ++++++++++ .../design_patterns/Lazy_Initialization.html | 692 +++++++++++ .../design_patterns/Local_Serializer.html | 840 +++++++++++++ .../Non-Preemptive_Priorities.html | 753 ++++++++++++ .../Odd-Even_Communication.html | 662 ++++++++++ .../design_patterns/Reduction.html | 830 +++++++++++++ .../design_patterns/Reference_Counting.html | 721 +++++++++++ .../design_patterns/Wavefront.html | 756 ++++++++++++ .../destroy_graphs_outside_main_thread.html | 662 ++++++++++ .../estimate_flow_graph_performance.html | 663 ++++++++++ main/tbb_userguide/parallel_for_os.html | 730 +++++++++++ main/tbb_userguide/parallel_for_toctree.html | 620 ++++++++++ main/tbb_userguide/parallel_reduce.html | 766 ++++++++++++ main/tbb_userguide/std_invoke.html | 863 +++++++++++++ main/tbb_userguide/title.html | 839 +++++++++++++ .../tbb_userguide/use_concurrency_limits.html | 690 +++++++++++ main/tbb_userguide/use_graph_reset.html | 650 ++++++++++ main/tbb_userguide/use_input_node.html | 709 +++++++++++ main/tbb_userguide/use_limiter_node.html | 698 +++++++++++ main/tbb_userguide/use_make_edge.html | 642 ++++++++++ main/tbb_userguide/use_nested_algorithms.html | 686 +++++++++++ .../tbb_userguide/use_nested_flow_graphs.html | 745 +++++++++++ main/tbb_userguide/work_isolation.html | 731 +++++++++++ objects.inv | Bin 0 -> 7840 bytes search.html | 545 ++++++++ searchindex.js | 1 + 440 files changed, 129654 insertions(+) create mode 100644 .nojekyll create mode 100644 GSG/get_started.html create mode 100644 GSG/installation.html create mode 100644 GSG/integrate.html create mode 100644 GSG/next_steps.html create mode 100644 GSG/samples.html create mode 100644 GSG/system_requirements.html create mode 100644 _images/dependence_graph.jpg create mode 100644 _images/execution_timeline2node.jpg create mode 100644 _images/execution_timeline_dependence.jpg create mode 100644 _images/fg_api_graph_structure.png create mode 100644 _images/flow_graph.jpg create mode 100644 _images/flow_graph_complex.jpg create mode 100644 _images/flow_graph_message_passing_protocol.jpg create mode 100644 _images/flow_graph_reserve_buffers_1.png create mode 100644 _images/flow_graph_reserve_buffers_2.png create mode 100644 _images/flow_graph_reserve_buffers_3.png create mode 100644 _images/flow_graph_reserve_buffers_4.png create mode 100644 _images/flow_graph_reserve_buffers_5.png create mode 100644 _images/flow_graph_reserve_buffers_6.png create mode 100644 _images/flow_graph_reserve_buffers_7.png create mode 100644 _images/how-oneTBB-works.png create mode 100644 _images/image002.jpg create mode 100644 _images/image002a.jpg create mode 100644 _images/image003a.jpg create mode 100644 _images/image004.jpg create mode 100644 _images/image004a.jpg create mode 100644 _images/image005a.jpg create mode 100644 _images/image006.jpg create mode 100644 _images/image006a.jpg create mode 100644 _images/image007.jpg create mode 100644 _images/image007a.jpg create mode 100644 _images/image008.jpg create mode 100644 _images/image008a.jpg create mode 100644 _images/image009.jpg create mode 100644 _images/image009a.jpg create mode 100644 _images/image010.jpg create mode 100644 _images/image011.jpg create mode 100644 _images/image012.jpg create mode 100644 _images/image013.jpg create mode 100644 _images/make_edges_example.png create mode 100644 _images/make_edges_usage.png create mode 100644 _sources/GSG/get_started.rst create mode 100644 _sources/GSG/installation.rst create mode 100644 _sources/GSG/integrate.rst create mode 100644 _sources/GSG/next_steps.rst create mode 100644 _sources/GSG/samples.rst create mode 100644 _sources/GSG/system_requirements.rst create mode 100644 _sources/index.rst create mode 100644 _sources/index/index_intro.rst create mode 100644 _sources/index/toctree.rst create mode 100644 _sources/index/useful_topics.rst create mode 100644 _sources/main/intro/Benefits.rst create mode 100644 _sources/main/intro/help_support.rst create mode 100644 _sources/main/intro/intro_os.rst create mode 100644 _sources/main/intro/limitations.rst create mode 100644 _sources/main/intro/notation.rst create mode 100644 _sources/main/intro/testing_approach.rst create mode 100644 _sources/main/reference/concurrent_lru_cache_cls.rst create mode 100644 _sources/main/reference/constructors_for_nodes.rst create mode 100644 _sources/main/reference/custom_mutex_chmap.rst create mode 100644 _sources/main/reference/follows_and_precedes_functions.rst create mode 100644 _sources/main/reference/helpers_for_expressing_graphs.rst create mode 100644 _sources/main/reference/make_edges_function.rst create mode 100644 _sources/main/reference/make_node_set_function.rst create mode 100644 _sources/main/reference/parallel_for_each_semantics.rst create mode 100644 _sources/main/reference/parallel_sort_ranges_extension.rst create mode 100644 _sources/main/reference/reference.rst create mode 100644 _sources/main/reference/rvalue_reduce.rst create mode 100644 _sources/main/reference/scalable_memory_pools.rst create mode 100644 _sources/main/reference/scalable_memory_pools/fixed_pool_cls.rst create mode 100644 _sources/main/reference/scalable_memory_pools/malloc_replacement_log.rst create mode 100644 _sources/main/reference/scalable_memory_pools/memory_pool_allocator_cls.rst create mode 100644 _sources/main/reference/scalable_memory_pools/memory_pool_cls.rst create mode 100644 _sources/main/reference/task_group_extensions.rst create mode 100644 _sources/main/reference/try_put_and_wait.rst create mode 100644 _sources/main/reference/type_specified_message_keys.rst create mode 100644 _sources/main/tbb_userguide/Advanced_Example.rst create mode 100644 _sources/main/tbb_userguide/Advanced_Topic_Other_Kinds_of_Iteration_Spaces.rst create mode 100644 _sources/main/tbb_userguide/Allocator_Configuration.rst create mode 100644 _sources/main/tbb_userguide/Automatic_Chunking.rst create mode 100644 _sources/main/tbb_userguide/Bandwidth_and_Cache_Affinity_os.rst create mode 100644 _sources/main/tbb_userguide/Basic_Flow_Graph_concepts.rst create mode 100644 _sources/main/tbb_userguide/Cancellation_Without_An_Exception.rst create mode 100644 _sources/main/tbb_userguide/Cancellation_and_Nested_Parallelism.rst create mode 100644 _sources/main/tbb_userguide/Concurrent_Queue_Classes.rst create mode 100644 _sources/main/tbb_userguide/Constraints.rst create mode 100644 _sources/main/tbb_userguide/Containers.rst create mode 100644 _sources/main/tbb_userguide/Controlling_Chunking_os.rst create mode 100644 _sources/main/tbb_userguide/Cook_Until_Done_parallel_do.rst create mode 100644 _sources/main/tbb_userguide/Data_Flow_Graph.rst create mode 100644 _sources/main/tbb_userguide/Debug_Versus_Release_Libraries.rst create mode 100644 _sources/main/tbb_userguide/Dependence_Graph.rst create mode 100644 _sources/main/tbb_userguide/Edges.rst create mode 100644 _sources/main/tbb_userguide/Exceptions_and_Cancellation.rst create mode 100644 _sources/main/tbb_userguide/Floating_Point_Settings.rst create mode 100644 _sources/main/tbb_userguide/Flow-Graph-exception-tips.rst create mode 100644 _sources/main/tbb_userguide/Flow-Graph-waiting-tips.rst create mode 100644 _sources/main/tbb_userguide/Flow_Graph.rst create mode 100644 _sources/main/tbb_userguide/Flow_Graph_Buffering_in_Nodes.rst create mode 100644 _sources/main/tbb_userguide/Flow_Graph_Message_Passing_Protocol.rst create mode 100644 _sources/main/tbb_userguide/Flow_Graph_Reservation.rst create mode 100644 _sources/main/tbb_userguide/Flow_Graph_Single_Vs_Broadcast.rst create mode 100644 _sources/main/tbb_userguide/Flow_Graph_Tips.rst create mode 100644 _sources/main/tbb_userguide/Flow_Graph_making_edges_tips.rst create mode 100644 _sources/main/tbb_userguide/Flow_Graph_nested_parallelism_tips.rst create mode 100644 _sources/main/tbb_userguide/Flow_Graph_resource_tips.rst create mode 100644 _sources/main/tbb_userguide/Graph_Main_Categories.rst create mode 100644 _sources/main/tbb_userguide/Graph_Object.rst create mode 100644 _sources/main/tbb_userguide/Guiding_Task_Scheduler_Execution.rst create mode 100644 _sources/main/tbb_userguide/How_Task_Scheduler_Works.rst create mode 100644 _sources/main/tbb_userguide/Initializing_and_Terminating_the_Library.rst create mode 100644 _sources/main/tbb_userguide/Iterating_Over_a_Concurrent_Queue_for_Debugging.rst create mode 100644 _sources/main/tbb_userguide/Lambda_Expressions.rst create mode 100644 _sources/main/tbb_userguide/Linux_C_Dynamic_Memory_Interface_Replacement.rst create mode 100644 _sources/main/tbb_userguide/Linux_OS.rst create mode 100644 _sources/main/tbb_userguide/Lock_Pathologies.rst create mode 100644 _sources/main/tbb_userguide/Mac_OS.rst create mode 100644 _sources/main/tbb_userguide/Mapping_Nodes2Tasks.rst create mode 100644 _sources/main/tbb_userguide/Memory_Allocation.rst create mode 100644 _sources/main/tbb_userguide/Migration_Guide.rst create mode 100644 _sources/main/tbb_userguide/Migration_Guide/Mixing_Two_Runtimes.rst create mode 100644 _sources/main/tbb_userguide/Migration_Guide/Task_API.rst create mode 100644 _sources/main/tbb_userguide/Migration_Guide/Task_Scheduler_Init.rst create mode 100644 _sources/main/tbb_userguide/More_on_HashCompare.rst create mode 100644 _sources/main/tbb_userguide/Mutex_Flavors.rst create mode 100644 _sources/main/tbb_userguide/Mutual_Exclusion.rst create mode 100644 _sources/main/tbb_userguide/Nodes.rst create mode 100644 _sources/main/tbb_userguide/Non-Linear_Pipelines.rst create mode 100644 _sources/main/tbb_userguide/Package_Contents_os.rst create mode 100644 _sources/main/tbb_userguide/Parallelizing_Complex_Loops.rst create mode 100644 _sources/main/tbb_userguide/Parallelizing_Flow_Graph.rst create mode 100644 _sources/main/tbb_userguide/Parallelizing_Simple_Loops_os.rst create mode 100644 _sources/main/tbb_userguide/Parallelizing_Simple_Loops_toctree.rst create mode 100644 _sources/main/tbb_userguide/Partitioner_Summary.rst create mode 100644 _sources/main/tbb_userguide/Predefined_Node_Types.rst create mode 100644 _sources/main/tbb_userguide/Reader_Writer_Mutexes.rst create mode 100644 _sources/main/tbb_userguide/References.rst create mode 100644 _sources/main/tbb_userguide/Scalable_Memory_Allocator.rst create mode 100644 _sources/main/tbb_userguide/Summary_of_Containers.rst create mode 100644 _sources/main/tbb_userguide/Summary_of_Loops_and_Pipelines.rst create mode 100644 _sources/main/tbb_userguide/Task-Based_Programming.rst create mode 100644 _sources/main/tbb_userguide/Task_Scheduler_Bypass.rst create mode 100644 _sources/main/tbb_userguide/The_Task_Scheduler.rst create mode 100644 _sources/main/tbb_userguide/Throughput_of_pipeline.rst create mode 100644 _sources/main/tbb_userguide/Timing.rst create mode 100644 _sources/main/tbb_userguide/UpgradeDowngrade.rst create mode 100644 _sources/main/tbb_userguide/Using_Circular_Buffers.rst create mode 100644 _sources/main/tbb_userguide/When_Not_to_Use_Queues.rst create mode 100644 _sources/main/tbb_userguide/When_Task-Based_Programming_Is_Inappropriate.rst create mode 100644 _sources/main/tbb_userguide/Which_Dynamic_Libraries_to_Use.rst create mode 100644 _sources/main/tbb_userguide/Windows_C_Dynamic_Memory_Interface_Replacement.rst create mode 100644 _sources/main/tbb_userguide/Windows_OS_ug.rst create mode 100644 _sources/main/tbb_userguide/Working_on_the_Assembly_Line_pipeline.rst create mode 100644 _sources/main/tbb_userguide/always_use_wait_for_all.rst create mode 100644 _sources/main/tbb_userguide/appendix_A.rst create mode 100644 _sources/main/tbb_userguide/appendix_B.rst create mode 100644 _sources/main/tbb_userguide/attach_flow_graph_to_arena.rst create mode 100644 _sources/main/tbb_userguide/automatically-replacing-malloc.rst create mode 100644 _sources/main/tbb_userguide/avoid_dynamic_node_removal.rst create mode 100644 _sources/main/tbb_userguide/avoiding_data_races.rst create mode 100644 _sources/main/tbb_userguide/broadcast_or_send.rst create mode 100644 _sources/main/tbb_userguide/cancel_a_graph.rst create mode 100644 _sources/main/tbb_userguide/cancelling_nested_parallelism.rst create mode 100644 _sources/main/tbb_userguide/catching_exceptions.rst create mode 100644 _sources/main/tbb_userguide/communicate_with_nodes.rst create mode 100644 _sources/main/tbb_userguide/concurrent_hash_map.rst create mode 100644 _sources/main/tbb_userguide/concurrent_vector_ug.rst create mode 100644 _sources/main/tbb_userguide/create_token_based_system.rst create mode 100644 _sources/main/tbb_userguide/design_patterns/Agglomeration.rst create mode 100644 _sources/main/tbb_userguide/design_patterns/Design_Patterns.rst create mode 100644 _sources/main/tbb_userguide/design_patterns/Divide_and_Conquer.rst create mode 100644 _sources/main/tbb_userguide/design_patterns/Elementwise.rst create mode 100644 _sources/main/tbb_userguide/design_patterns/Fenced_Data_Transfer.rst create mode 100644 _sources/main/tbb_userguide/design_patterns/GUI_Thread.rst create mode 100644 _sources/main/tbb_userguide/design_patterns/General_References.rst create mode 100644 _sources/main/tbb_userguide/design_patterns/Lazy_Initialization.rst create mode 100644 _sources/main/tbb_userguide/design_patterns/Local_Serializer.rst create mode 100644 _sources/main/tbb_userguide/design_patterns/Non-Preemptive_Priorities.rst create mode 100644 _sources/main/tbb_userguide/design_patterns/Odd-Even_Communication.rst create mode 100644 _sources/main/tbb_userguide/design_patterns/Reduction.rst create mode 100644 _sources/main/tbb_userguide/design_patterns/Reference_Counting.rst create mode 100644 _sources/main/tbb_userguide/design_patterns/Wavefront.rst create mode 100644 _sources/main/tbb_userguide/destroy_graphs_outside_main_thread.rst create mode 100644 _sources/main/tbb_userguide/estimate_flow_graph_performance.rst create mode 100644 _sources/main/tbb_userguide/parallel_for_os.rst create mode 100644 _sources/main/tbb_userguide/parallel_for_toctree.rst create mode 100644 _sources/main/tbb_userguide/parallel_reduce.rst create mode 100644 _sources/main/tbb_userguide/std_invoke.rst create mode 100644 _sources/main/tbb_userguide/title.rst create mode 100644 _sources/main/tbb_userguide/use_concurrency_limits.rst create mode 100644 _sources/main/tbb_userguide/use_graph_reset.rst create mode 100644 _sources/main/tbb_userguide/use_input_node.rst create mode 100644 _sources/main/tbb_userguide/use_limiter_node.rst create mode 100644 _sources/main/tbb_userguide/use_make_edge.rst create mode 100644 _sources/main/tbb_userguide/use_nested_algorithms.rst create mode 100644 _sources/main/tbb_userguide/use_nested_flow_graphs.rst create mode 100644 _sources/main/tbb_userguide/work_isolation.rst create mode 100644 _static/basic.css create mode 100644 _static/custom.js create mode 100644 _static/doctools.js create mode 100644 _static/documentation_options.js create mode 100644 _static/favicons.png create mode 100644 _static/file.png create mode 100644 _static/images/logo_binder.svg create mode 100644 _static/images/logo_colab.png create mode 100644 _static/images/logo_deepnote.svg create mode 100644 _static/images/logo_jupyterhub.svg create mode 100644 _static/language_data.js create mode 100644 _static/locales/ar/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/bg/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/bn/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/ca/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/cs/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/da/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/de/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/el/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/eo/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/es/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/et/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/fi/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/fr/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/hr/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/id/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/it/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/iw/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/ja/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/ko/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/lt/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/lv/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/ml/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/mr/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/ms/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/nl/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/no/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/pl/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/pt/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/ro/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/ru/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/sk/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/sl/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/sr/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/sv/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/ta/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/te/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/tg/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/th/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/tl/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/tr/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/uk/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/ur/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/vi/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/zh_CN/LC_MESSAGES/booktheme.po create mode 100644 _static/locales/zh_TW/LC_MESSAGES/booktheme.po create mode 100644 _static/minus.png create mode 100644 _static/oneAPI-rgb-rev-100.png create mode 100644 _static/plus.png create mode 100644 _static/pygments.css create mode 100644 _static/sbt-webpack-macros.html create mode 100644 _static/scripts/bootstrap.js create mode 100644 _static/scripts/bootstrap.js.LICENSE.txt create mode 100644 _static/scripts/bootstrap.js.map create mode 100644 _static/scripts/fontawesome.js create mode 100644 _static/scripts/fontawesome.js.LICENSE.txt create mode 100644 _static/scripts/fontawesome.js.map create mode 100644 _static/scripts/pydata-sphinx-theme.js create mode 100644 _static/scripts/pydata-sphinx-theme.js.map create mode 100644 _static/scripts/sphinx-book-theme.js create mode 100644 _static/scripts/sphinx-book-theme.js.map create mode 100644 _static/searchtools.js create mode 100644 _static/sphinx_highlight.js create mode 100644 _static/styles/pydata-sphinx-theme.css create mode 100644 _static/styles/pydata-sphinx-theme.css.map create mode 100644 _static/styles/sphinx-book-theme.css create mode 100644 _static/styles/sphinx-book-theme.css.map create mode 100644 _static/styles/theme.css create mode 100644 _static/tabs.css create mode 100644 _static/tabs.js create mode 100644 _static/theme_overrides.css create mode 100644 _static/vendor/fontawesome/webfonts/fa-brands-400.ttf create mode 100644 _static/vendor/fontawesome/webfonts/fa-brands-400.woff2 create mode 100644 _static/vendor/fontawesome/webfonts/fa-regular-400.ttf create mode 100644 _static/vendor/fontawesome/webfonts/fa-regular-400.woff2 create mode 100644 _static/vendor/fontawesome/webfonts/fa-solid-900.ttf create mode 100644 _static/vendor/fontawesome/webfonts/fa-solid-900.woff2 create mode 100644 _static/webpack-macros.html create mode 100644 genindex.html create mode 100644 index.html create mode 100644 index/index_intro.html create mode 100644 index/toctree.html create mode 100644 index/useful_topics.html create mode 100644 main/intro/Benefits.html create mode 100644 main/intro/help_support.html create mode 100644 main/intro/intro_os.html create mode 100644 main/intro/limitations.html create mode 100644 main/intro/notation.html create mode 100644 main/intro/testing_approach.html create mode 100644 main/reference/concurrent_lru_cache_cls.html create mode 100644 main/reference/constructors_for_nodes.html create mode 100644 main/reference/custom_mutex_chmap.html create mode 100644 main/reference/follows_and_precedes_functions.html create mode 100644 main/reference/helpers_for_expressing_graphs.html create mode 100644 main/reference/make_edges_function.html create mode 100644 main/reference/make_node_set_function.html create mode 100644 main/reference/parallel_for_each_semantics.html create mode 100644 main/reference/parallel_sort_ranges_extension.html create mode 100644 main/reference/reference.html create mode 100644 main/reference/rvalue_reduce.html create mode 100644 main/reference/scalable_memory_pools.html create mode 100644 main/reference/scalable_memory_pools/fixed_pool_cls.html create mode 100644 main/reference/scalable_memory_pools/malloc_replacement_log.html create mode 100644 main/reference/scalable_memory_pools/memory_pool_allocator_cls.html create mode 100644 main/reference/scalable_memory_pools/memory_pool_cls.html create mode 100644 main/reference/task_group_extensions.html create mode 100644 main/reference/try_put_and_wait.html create mode 100644 main/reference/type_specified_message_keys.html create mode 100644 main/tbb_userguide/Advanced_Example.html create mode 100644 main/tbb_userguide/Advanced_Topic_Other_Kinds_of_Iteration_Spaces.html create mode 100644 main/tbb_userguide/Allocator_Configuration.html create mode 100644 main/tbb_userguide/Automatic_Chunking.html create mode 100644 main/tbb_userguide/Bandwidth_and_Cache_Affinity_os.html create mode 100644 main/tbb_userguide/Basic_Flow_Graph_concepts.html create mode 100644 main/tbb_userguide/Cancellation_Without_An_Exception.html create mode 100644 main/tbb_userguide/Cancellation_and_Nested_Parallelism.html create mode 100644 main/tbb_userguide/Concurrent_Queue_Classes.html create mode 100644 main/tbb_userguide/Constraints.html create mode 100644 main/tbb_userguide/Containers.html create mode 100644 main/tbb_userguide/Controlling_Chunking_os.html create mode 100644 main/tbb_userguide/Cook_Until_Done_parallel_do.html create mode 100644 main/tbb_userguide/Data_Flow_Graph.html create mode 100644 main/tbb_userguide/Debug_Versus_Release_Libraries.html create mode 100644 main/tbb_userguide/Dependence_Graph.html create mode 100644 main/tbb_userguide/Edges.html create mode 100644 main/tbb_userguide/Exceptions_and_Cancellation.html create mode 100644 main/tbb_userguide/Floating_Point_Settings.html create mode 100644 main/tbb_userguide/Flow-Graph-exception-tips.html create mode 100644 main/tbb_userguide/Flow-Graph-waiting-tips.html create mode 100644 main/tbb_userguide/Flow_Graph.html create mode 100644 main/tbb_userguide/Flow_Graph_Buffering_in_Nodes.html create mode 100644 main/tbb_userguide/Flow_Graph_Message_Passing_Protocol.html create mode 100644 main/tbb_userguide/Flow_Graph_Reservation.html create mode 100644 main/tbb_userguide/Flow_Graph_Single_Vs_Broadcast.html create mode 100644 main/tbb_userguide/Flow_Graph_Tips.html create mode 100644 main/tbb_userguide/Flow_Graph_making_edges_tips.html create mode 100644 main/tbb_userguide/Flow_Graph_nested_parallelism_tips.html create mode 100644 main/tbb_userguide/Flow_Graph_resource_tips.html create mode 100644 main/tbb_userguide/Graph_Main_Categories.html create mode 100644 main/tbb_userguide/Graph_Object.html create mode 100644 main/tbb_userguide/Guiding_Task_Scheduler_Execution.html create mode 100644 main/tbb_userguide/How_Task_Scheduler_Works.html create mode 100644 main/tbb_userguide/Initializing_and_Terminating_the_Library.html create mode 100644 main/tbb_userguide/Iterating_Over_a_Concurrent_Queue_for_Debugging.html create mode 100644 main/tbb_userguide/Lambda_Expressions.html create mode 100644 main/tbb_userguide/Linux_C_Dynamic_Memory_Interface_Replacement.html create mode 100644 main/tbb_userguide/Linux_OS.html create mode 100644 main/tbb_userguide/Lock_Pathologies.html create mode 100644 main/tbb_userguide/Mac_OS.html create mode 100644 main/tbb_userguide/Mapping_Nodes2Tasks.html create mode 100644 main/tbb_userguide/Memory_Allocation.html create mode 100644 main/tbb_userguide/Migration_Guide.html create mode 100644 main/tbb_userguide/Migration_Guide/Mixing_Two_Runtimes.html create mode 100644 main/tbb_userguide/Migration_Guide/Task_API.html create mode 100644 main/tbb_userguide/Migration_Guide/Task_Scheduler_Init.html create mode 100644 main/tbb_userguide/More_on_HashCompare.html create mode 100644 main/tbb_userguide/Mutex_Flavors.html create mode 100644 main/tbb_userguide/Mutual_Exclusion.html create mode 100644 main/tbb_userguide/Nodes.html create mode 100644 main/tbb_userguide/Non-Linear_Pipelines.html create mode 100644 main/tbb_userguide/Package_Contents_os.html create mode 100644 main/tbb_userguide/Parallelizing_Complex_Loops.html create mode 100644 main/tbb_userguide/Parallelizing_Flow_Graph.html create mode 100644 main/tbb_userguide/Parallelizing_Simple_Loops_os.html create mode 100644 main/tbb_userguide/Parallelizing_Simple_Loops_toctree.html create mode 100644 main/tbb_userguide/Partitioner_Summary.html create mode 100644 main/tbb_userguide/Predefined_Node_Types.html create mode 100644 main/tbb_userguide/Reader_Writer_Mutexes.html create mode 100644 main/tbb_userguide/References.html create mode 100644 main/tbb_userguide/Scalable_Memory_Allocator.html create mode 100644 main/tbb_userguide/Summary_of_Containers.html create mode 100644 main/tbb_userguide/Summary_of_Loops_and_Pipelines.html create mode 100644 main/tbb_userguide/Task-Based_Programming.html create mode 100644 main/tbb_userguide/Task_Scheduler_Bypass.html create mode 100644 main/tbb_userguide/The_Task_Scheduler.html create mode 100644 main/tbb_userguide/Throughput_of_pipeline.html create mode 100644 main/tbb_userguide/Timing.html create mode 100644 main/tbb_userguide/UpgradeDowngrade.html create mode 100644 main/tbb_userguide/Using_Circular_Buffers.html create mode 100644 main/tbb_userguide/When_Not_to_Use_Queues.html create mode 100644 main/tbb_userguide/When_Task-Based_Programming_Is_Inappropriate.html create mode 100644 main/tbb_userguide/Which_Dynamic_Libraries_to_Use.html create mode 100644 main/tbb_userguide/Windows_C_Dynamic_Memory_Interface_Replacement.html create mode 100644 main/tbb_userguide/Windows_OS_ug.html create mode 100644 main/tbb_userguide/Working_on_the_Assembly_Line_pipeline.html create mode 100644 main/tbb_userguide/always_use_wait_for_all.html create mode 100644 main/tbb_userguide/appendix_A.html create mode 100644 main/tbb_userguide/appendix_B.html create mode 100644 main/tbb_userguide/attach_flow_graph_to_arena.html create mode 100644 main/tbb_userguide/automatically-replacing-malloc.html create mode 100644 main/tbb_userguide/avoid_dynamic_node_removal.html create mode 100644 main/tbb_userguide/avoiding_data_races.html create mode 100644 main/tbb_userguide/broadcast_or_send.html create mode 100644 main/tbb_userguide/cancel_a_graph.html create mode 100644 main/tbb_userguide/cancelling_nested_parallelism.html create mode 100644 main/tbb_userguide/catching_exceptions.html create mode 100644 main/tbb_userguide/communicate_with_nodes.html create mode 100644 main/tbb_userguide/concurrent_hash_map.html create mode 100644 main/tbb_userguide/concurrent_vector_ug.html create mode 100644 main/tbb_userguide/create_token_based_system.html create mode 100644 main/tbb_userguide/design_patterns/Agglomeration.html create mode 100644 main/tbb_userguide/design_patterns/Design_Patterns.html create mode 100644 main/tbb_userguide/design_patterns/Divide_and_Conquer.html create mode 100644 main/tbb_userguide/design_patterns/Elementwise.html create mode 100644 main/tbb_userguide/design_patterns/Fenced_Data_Transfer.html create mode 100644 main/tbb_userguide/design_patterns/GUI_Thread.html create mode 100644 main/tbb_userguide/design_patterns/General_References.html create mode 100644 main/tbb_userguide/design_patterns/Lazy_Initialization.html create mode 100644 main/tbb_userguide/design_patterns/Local_Serializer.html create mode 100644 main/tbb_userguide/design_patterns/Non-Preemptive_Priorities.html create mode 100644 main/tbb_userguide/design_patterns/Odd-Even_Communication.html create mode 100644 main/tbb_userguide/design_patterns/Reduction.html create mode 100644 main/tbb_userguide/design_patterns/Reference_Counting.html create mode 100644 main/tbb_userguide/design_patterns/Wavefront.html create mode 100644 main/tbb_userguide/destroy_graphs_outside_main_thread.html create mode 100644 main/tbb_userguide/estimate_flow_graph_performance.html create mode 100644 main/tbb_userguide/parallel_for_os.html create mode 100644 main/tbb_userguide/parallel_for_toctree.html create mode 100644 main/tbb_userguide/parallel_reduce.html create mode 100644 main/tbb_userguide/std_invoke.html create mode 100644 main/tbb_userguide/title.html create mode 100644 main/tbb_userguide/use_concurrency_limits.html create mode 100644 main/tbb_userguide/use_graph_reset.html create mode 100644 main/tbb_userguide/use_input_node.html create mode 100644 main/tbb_userguide/use_limiter_node.html create mode 100644 main/tbb_userguide/use_make_edge.html create mode 100644 main/tbb_userguide/use_nested_algorithms.html create mode 100644 main/tbb_userguide/use_nested_flow_graphs.html create mode 100644 main/tbb_userguide/work_isolation.html create mode 100644 objects.inv create mode 100644 search.html create mode 100644 searchindex.js diff --git a/.nojekyll b/.nojekyll new file mode 100644 index 0000000000..e69de29bb2 diff --git a/GSG/get_started.html b/GSG/get_started.html new file mode 100644 index 0000000000..165af797b7 --- /dev/null +++ b/GSG/get_started.html @@ -0,0 +1,688 @@ + + + + + + + + + + + Get Started with oneAPI Threading Building Blocks (oneTBB) — oneTBB documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + + + + + + + + +
+ +
+ + + + + +
+
+ + + + +
+ + + + + + + + + + + + + +
+ +
+ + + +
+ +
+
+ +
+
+ +
+ +
+ +
+ + +
+ +
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ + + +
+

Get Started with oneAPI Threading Building Blocks (oneTBB)

+ +
+
+ +
+

Contents

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

Get Started with oneAPI Threading Building Blocks (oneTBB)#

+

oneTBB Get Started Guide provides the information you need to begin working with oneTBB. +It is helpful for new users of parallel programming and experienced developers that want to improve code performance.

+

It is recommended for you to have a basic knowledge of C++ programming and some experience with parallel programming concepts.

+

oneAPI Threading Building Blocks (oneTBB) is a runtime-based parallel programming model for C++ code that uses tasks. +The template-based runtime library can help you harness the latent performance of multi-core processors.

+

oneTBB enables you to simplify parallel programming by breaking computation into parallel running tasks. Within a single process, +parallelism is carried out by mapping tasks to threads. Threads are an operating system mechanism that allows the same or different sets of instructions +to be executed simultaneously. Using threads can make your program work faster and more efficiently.

+

Here you can see one of the possible executions of tasks by threads.

+
+../_images/how-oneTBB-works.png + +
+

Use oneTBB to write scalable applications that:

+
    +
  • Specify logical parallel structure instead of threads.

  • +
  • Emphasize data-parallel programming.

  • +
  • Take advantage of concurrent collections and parallel algorithms.

  • +
+

oneTBB supports nested parallelism and load balancing. It means that you can use the library without worrying about oversubscribing a system, which happens when more tasks are assigned to a system than it can handle efficiently.

+

oneTBB is used in different areas, such as scientific simulations, gaming, data analysis, etc.

+

It is available as a stand-alone product and as part of the Intel® oneAPI Base Toolkit.

+
+

To start using oneTBB, follow the next steps:#

+
    +
  1. See the System Requirements.

  2. +
  3. Install oneTBB.

  4. +
  5. Run your program using oneTBB following the Next Steps.

  6. +
  7. Learn how to Integrate oneTBB into your project using CMake* and pkg-config tool.

  8. +
  9. See oneTBB Samples.

  10. +
+
+
+ + +
+ + + + + + + + +
+ + + + +
+ + +
+
+ + +
+ + +
+
+
+ + + + + + + + \ No newline at end of file diff --git a/GSG/installation.html b/GSG/installation.html new file mode 100644 index 0000000000..cc97ca63ec --- /dev/null +++ b/GSG/installation.html @@ -0,0 +1,632 @@ + + + + + + + + + + + Installation — oneTBB documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + + + + + + + + +
+ +
+ + + + + +
+
+ + + + +
+ + + + + + + + + + + + + +
+ +
+ + + +
+ +
+
+ +
+
+ +
+ +
+ +
+ + +
+ +
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ + + +
+

Installation

+ +
+
+ +
+
+
+ + + + + + + + + + + + + +
+ + + + +
+
+ + +
+ + +
+
+
+ + + + + + + + \ No newline at end of file diff --git a/GSG/integrate.html b/GSG/integrate.html new file mode 100644 index 0000000000..b4b2c12e61 --- /dev/null +++ b/GSG/integrate.html @@ -0,0 +1,708 @@ + + + + + + + + + + + Integrate oneTBB — oneTBB documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + + + + + + + + +
+ +
+ + + + + +
+
+ + + + +
+ + + + + + + + + + + + + +
+ +
+ + + +
+ +
+
+ +
+
+ +
+ +
+ +
+ + +
+ +
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ + + +
+

Integrate oneTBB

+ +
+
+ +
+

Contents

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

Integrate oneTBB#

+

If you want to improve the performance and scalability of your application, you can integrate oneTBB into your project. +For example, you may want to integrate oneTBB if your application needs to process large amounts of data in parallel.

+

To integrate oneTBB, you need to:

+
    +
  • Link oneTBB with the project’s source code.

  • +
  • Provide the necessary compiler and linker flags.

  • +
+

However, you can use CMake* and the pkg-config tool to simplify the process of integrating oneTBB into your project and handling its dependencies. +See the instructions below to learn how to use the tools.

+
+

CMake*#

+

CMake* is a cross-platform build tool that helps you manage dependencies and build systems. +Integrating oneTBB into your project using CMake*:

+
    +
  • Simplifies the process of building and linking against the library.

  • +
  • Ensures that your project can be built and run on multiple platforms.

  • +
  • Lets you manage oneTBB dependencies.

  • +
+

To add oneTBB to another project using CMake*, add the following commands to your CMakeLists.txt file:

+
`find_package(TBB REQUIRED)`
+`target_link_libraries(my_executable TBB::tbb)`
+
+
+

After that, configure your project with CMake* as usual.

+
+
+

Compile a Program Using pkg-config#

+

The pkg-config tool is used to simplify the compilation line by retrieving information about packages +from special metadata files. It helps avoid large hard-coded paths and makes compilation more portable.

+

To compile a test program test.cpp with oneTBB on Linux* OS, +provide the full path to search for included files and libraries, or provide a line as the following:

+
g++ -o test test.cpp $(pkg-config --libs --cflags tbb)
+
+
+

Where:

+

--cflags provides oneTBB library include path:

+
$ pkg-config --cflags tbb
+-I<path-to>/tbb/latest/lib/pkgconfig/../..//include
+
+
+

--libs provides the Intel(R) oneTBB library name and the search path to find it:

+
$ pkg-config libs tbb
+-L<path to>tbb/latest/lib/pkgconfig/../..//lib/intel64/gcc4.8 -ltbb
+
+
+
+

Note

+

For Windows* OS, additionally, use the --msvc-syntax option flag that converts the compiling and linking flags in an appropriate mode.

+
+
+
+ + +
+ + + + + + + + +
+ + + + +
+ + +
+
+ + +
+ + +
+
+
+ + + + + + + + \ No newline at end of file diff --git a/GSG/next_steps.html b/GSG/next_steps.html new file mode 100644 index 0000000000..be33b813f2 --- /dev/null +++ b/GSG/next_steps.html @@ -0,0 +1,812 @@ + + + + + + + + + + + Next Steps — oneTBB documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + + + + + + + + +
+ +
+ + + + + +
+
+ + + + +
+ + + + + + + + + + + + + +
+ +
+ + + +
+ +
+
+ +
+
+ +
+ +
+ +
+ + +
+ +
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ + + + + + + + +
+ +
+

Next Steps#

+

After installing oneTBB, complete the following steps to start working with the library.

+
+

Set the Environment Variables#

+

After installing oneTBB, set the environment variables:

+
    +
  1. Go to the oneTBB installation directory.

  2. +
  3. Set the environment variables using the script in <install_dir> by running:

    +
      +
    • On Linux* OS: vars.{sh|csh} in <install_dir>/tbb/latest/env

    • +
    • On Windows* OS: vars.bat in <install_dir>/tbb/latest/env

    • +
    +
  4. +
+
+

Tip

+

oneTBB can coordinate with Intel(R) OpenMP on CPU resources usage +to avoid excessive oversubscription when both runtimes are used within a process. +To enable this feature set up TCM_ENABLE environment variable to 1.

+
+
+
+

Build and Run a Sample#

+
+
    +
  1. Create a new C++ project using your IDE. In this example, Microsoft* Visual Studio* Code is used.

  2. +
  3. Create an example.cpp file in the project.

  4. +
  5. Copy and paste the code below. It is a typical example of a oneTBB algorithm. The sample calculates a sum of all integer numbers from 1 to 100.

    +
    #include <oneapi/tbb.h>
    +
    +int main (){
    +    int sum = oneapi::tbb::parallel_reduce(
    +        oneapi::tbb::blocked_range<int>(1,101), 0,
    +        [](oneapi::tbb::blocked_range<int> const& r, int init) -> int {
    +            for (int v = r.begin(); v != r.end(); v++) {
    +                init += v;
    +            }
    +            return init;
    +        },
    +        [](int lhs, int rhs) -> int {
    +            return lhs + rhs;
    +        }
    +    );
    +
    +    printf("Sum: %d\n", sum);
    +    return 0;
    +}
    +
    +
    +
  6. +
  7. Open the tasks.json file in the .vscode directory and paste the following lines to the args array:

    +
      +
    • -Ipath/to/oneTBB/include to add oneTBB include directory.

    • +
    • path/to/oneTBB/ to add oneTBB.

    • +
    +

    For example:

    +
    {
    +   "tasks": [
    +        {
    +           "label": "build & run",
    +           "type": "cppbuild",
    +           "group": {
    +           "args": [
    +               "/IC:\\Program Files (x86)\\Intel\\oneAPI\\tbb\\2021.9.0\\include",
    +               "C:\\Program Files (x86)\\Intel\\oneAPI\\tbb\\2021.9.0\\lib\\ia32\\vc14\\tbb12.lib"
    +
    +
    +
  8. +
  9. Build the project.

  10. +
  11. Run the example.

  12. +
  13. If oneTBB is configured correctly, the output displays Sum: 5050.

  14. +
+
+
+
+

Hybrid CPU and NUMA Support#

+

If you need NUMA/Hybrid CPU support in oneTBB, you need to make sure that HWLOC* is installed on your system.

+

HWLOC* (Hardware Locality) is a library that provides a portable abstraction of the hierarchical topology of modern architectures (NUMA, hybrid CPU systems, etc). oneTBB relies on HWLOC* to identify the underlying topology of the system to optimize thread scheduling and memory allocation.

+

Without HWLOC*, oneTBB may not take advantage of NUMA/Hybrid CPU support. Therefore, it’s important to make sure that HWLOC* is installed before using oneTBB on such systems.

+
+

Check HWLOC* on the System#

+

To check if HWLOC* is already installed on your system, run hwloc-ls:

+
    +
  • For Linux* OS, in the command line.

  • +
  • For Windows* OS, in the command prompt.

  • +
+

If HWLOC* is installed, the command displays information about the hardware topology of your system. If it is not installed, you receive an error message saying that the command hwloc-ls could not be found.

+
+

Note

+

For Hybrid CPU support, make sure that HWLOC* is version 2.5 or higher. For NUMA support, install HWLOC* version 1.11 or higher.

+
+
+
+

Install HWLOC*#

+

To install HWLOC*, visit the official Portable Hardware Locality website (https://www-lb.open-mpi.org/projects/hwloc/).

+
    +
  • For Windows* OS, binaries are available for download.

  • +
  • For Linux* OS, only the source code is provided and binaries should be built.

  • +
+

On Linux* OS, HWLOC* can be also installed with package managers, such as APT*, YUM*, etc. To do so, run: sudo apt install hwloc.

+
+

Note

+

For Hybrid CPU support, make sure that HWLOC* is version 2.5 or higher. For NUMA support, install HWLOC* version 1.11 or higher.

+
+
+
+
+ + +
+ + + + + + + + +
+ + + + + + + +
+
+ + +
+ + +
+
+
+ + + + + + + + \ No newline at end of file diff --git a/GSG/samples.html b/GSG/samples.html new file mode 100644 index 0000000000..52c11a445d --- /dev/null +++ b/GSG/samples.html @@ -0,0 +1,689 @@ + + + + + + + + + + + oneTBB Samples — oneTBB documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + + + + + + + + +
+ +
+ + + + + +
+
+ + + + +
+ + + + + + + + + + + + + +
+ +
+ + + +
+ +
+
+ +
+
+ +
+ +
+ +
+ + +
+ +
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ + + +
+

oneTBB Samples

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

oneTBB Samples#

+

To become an expert in using oneTBB, explore its samples and examples to learn how +to properly utilize the features and functionality of oneTBB and avoid common mistakes that may impede your performance.

+

The following samples are available:

+ +
+

Note

+

You can also refer to the oneAPI Samples to learn more about the ecosystem.

+
+
+ + +
+ + + + + + + + +
+ + + + +
+
+ + +
+ + +
+
+
+ + + + + + + + \ No newline at end of file diff --git a/GSG/system_requirements.html b/GSG/system_requirements.html new file mode 100644 index 0000000000..fa56870fe2 --- /dev/null +++ b/GSG/system_requirements.html @@ -0,0 +1,631 @@ + + + + + + + + + + + System Requirements — oneTBB documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + + + + + + + + +
+ +
+ + + + + +
+
+ + + + +
+ + + + + + + + + + + + + +
+ +
+ + + +
+ +
+
+ +
+
+ +
+ +
+ +
+ + +
+ +
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ + + +
+

System Requirements

+ +
+
+ +
+
+
+ + + + + + + + + + + + + +
+ + + + +
+
+ + +
+ + +
+
+
+ + + + + + + + \ No newline at end of file diff --git a/_images/dependence_graph.jpg b/_images/dependence_graph.jpg new file mode 100644 index 0000000000000000000000000000000000000000..d9e4778664821661fb4939737ce5bd542d7b39eb GIT binary patch literal 17375 zcmeHu2UJttw(f=ip$US3bP!Mwr1u&S5fLehfKo+j=v6{T5KvkK1O^7-h$Kh}Exh=jbN%nV@1A$>f8HH$j5n@3V#v-w6Ch;5P!l5%`V3Zv_5lB0%~a^aq7tAW((8 z=On-MhQx$Fbda<-03;^I7C1pWm92{Cag z1u+Q)F)40w83i#(1u<#hKe`40w*Xtfh9I7Q$Q6Ja&;YyuZvaZD>J&xA?cnY0t{^Jv z>Lp@j3MfHf?pD@Lw%*(iZSA41%KTf6t^C|j8)bfDX&o^g zcXe9_=na2QTLXXHyVm|r*77#|5S25ON-zbOi@S@hw-qXCq_sEA#mHKy4K4tn8#8+So`7KeUpx5f&G>u@bhj zkrWrUk(9KNl@^ziuoHjC^LO($*1xQ~`*=G4VcW)9)YjS7#n#o^i-3l>D39ph8vWm8 zlK{~#qyHiN1Rn`y6x2O!t-Nio5k%!@7YmC?2#ZPG{g-YRkrtCv68(4Olth1m@vj>C z-`n#45?U%sHr5K(Kilr+`8V?hwjTd?z3mKD`I~3I6hf7Rc%z`8P!j#u*8X?*|F}X3 zH$nx!f|Kw~?*9kJZzF#R_|aq&-Vb$IQse!pz8go{f|L0vpFgj`Pes zB0LubE(=`|V&xW<6cv=<7ZeiwSqTxCoSc$^l7WhfL6Du9UGOg-r)>ZoIj~K{3L@eG zi0OzxbVR3J02g8Bk(97k`E$GS?*|bvh=i03Oin>bMJP~x79b`9frv>!q@*N-jY^^* z!hL{*j+Fj_xEk5H+g4y64+e?H32(`Hua>tn-WkU5Nj~%pqo8Cu&&ivzKOMst)0CC)X~e^=aDbW&p-T0L}b*{XVHmCFOpMU zzDiBY%FfBn%P)9WSW#J3T~k|E-_X(7)!ozk;p3-~(XlV%$cf1*6nb%Kd1dwM+B$ao z$IkBFKJMV~r(Z+>=x=WQ^6cOFMMv<9n1lpG0{-b25wR~pKy)Oe7sScv)oz2WJkIe* zJSJzjn((%~oq|{L4uu{GNH_QV2J z*pNLQPg>GJfvSIesV4c-vmT=x6B1>+BtC^{kr6rTLsANPsrG(s)C?Jd5 z;WXNp@-goXf@r?k&TFSmX;Wo?{h;?jZ~tX}F5qv-_z}n7D~`)ChaSegUQ^*7eQJ6l zVVx4Y=MCv)`PPYC%cuyY6v+CgM9^_6x8zy2g=5;24D;eQqEf|Q3nfC5-CL=4w9_>Q zagWhADvO;8IcM1r<@a}^FYbKkJU4?VR$NpIXeEbEF*vItePVP}ZgB?I1PvVWZ&-x0 zLm9N$Z_=G5H3R`fL;9eC%;!XW3p6=MwgtVX;;^X=gD24Kdnd^$rUtyAgk<8fM8e1JxN)4+u8!6t*iPCIH5fYfa_xedKXpk@b%c~pj<6m(&Rh2b| z-x+l&Et(H%9@Cc6Iaz){4oS$QVM9kg_Mw)+%VGLq$Q{6Tswt=fSyToo=((}O8(%%? z;NM;PREmwmQa5N1S$1VO184Py%VX%vivB0VQ0~~X0m$@YR_Tx<+o10M$h3l zV!(PQ)I;E`VGRc0_FosG)sXWyYB*`e_|QUn=S-xchGdpM9^WXvR^o)_iZt!U6Md0_ z=}xCUoOeFxnS340tt=!7%0XHXCf>fi{ z-Chc|xArpw+wU`37TE@i{ks{6mhn{eG1@p$H2KyC+T0n(cfO646t-T7!m{ITpH^C7 z{xY0Bs?jvl$f2sy$4B|@fm1JPB)1V`7Zc$2etOUqf4x#dCy4&jr;3UQmNq3Dp2*%g zP}&?o6e>mvFs_DB!l!&JIV^koC2@(~vGH-sS(hQNq=#`E-C{V|_S&hg@WA1`zI&=4 z(;lIvKrNYfL6h-aniR{!jA+;a<~d zSK9UW3lN4G9J0eG(Q<9SPT@P8c0Mqqub=m5AqaJBS+LU}0OIcq78q_a&(VAb3qDkA z^xddJWkY6t*7GOEt36mxfsO$#gD;l%heb-2WQ!rfLAhGX2d%rqDjRrS{_&<#GhFqe z9u+JFLgQevlC=1G=7k66n-9Z_NB!{(2s7`kXy8z!;#eJR&fAf8EiI!pgfY3udh3Rt z^~o2Gdq*@*ZQp{$Vbk}piZI``_q(3AM>ReKPsor6zuWC{dZlcP z7BTGpNvaH`O$LkbxLQ#w)V(~+Y6MHoN7%8RcXL~>+XIhvy_-9y0MW7VP#|so(;{KR zya!5?O9wg6j}TwwN*X$KYeroXscxi5sWOl<6DH3>U?~uaSyaR3rHxPJrpbf$UCB5l z*NewO1h?fxltM5fA;LzM=WrUdhc6*5)s}`z3$)!qDJ{_jCBjw>PkR-}z~iCvrvNGL z6zH5&8NpAYrk9gn&?-#g@4r=vZ5^}W>}fE;>ahmW!+g}ykf_?yw@%`Ts7yuc=lj&) zTln?x(C^WrOT6IcBj!jUW4;-SZC%w$Yh?j#o&ZF?zPAFkd zs!bDY@Bnk|$L-`g`_JMXtDH;vWb;ui(op~6)o793i{ZMM?=cGPZtp&d1dkmrk@oV( zhDx|=cqky^o1oal?>a(lVgs2t=kj=$JNib@-mB+1RAL6-aR_w=vRM~c&S(&#ZWsA< z)8!fL+a1q@NM&t+LK&RrF%Xoyz`c!=)vaq7HqfYtwFEFe=wPP@NCE(lX(^&-m{R~H z6S3eVzUM$v>k0|*5|z-}RgNk{H!cvz3bb*&bNG`9)WgrisIFn-U+twezwo;J@y>M? zy~2#l6QTU9P?blf5U#*8_4dQDEqs_vmq9D>OWHo)_2Uux;_J;D4M~fS;O_!u#sala z0+DY+^1CVqb8q3zhR?J~imeI~@e3t%`}{8wW6NMk zCwqIQhqulwA%*Sgwlb~!sua;~$df=F`$aB_wZpyFU9t(_3Ef*R!_SYx$d85WT5g}D z;|167^a_!W(XV%_M(rTbnzUQV@fILamL632uEB<-rUPCHlmC>D&S8#c)OA^zCw|!% zfuoQ=5ddXoMGFA`i4c{nvAgia(lOBY_X0#SX+Kz$bkLAzFDoZu#EVC~on`gWA#_Rs zIrR_R`<(M*AI*i(`r$9=d7-x$)=mK$@5wo~fLATkC3u7ImvU8ay$(8x`;2DcT62DvE&X0jBg#% zB=GU@k9_O5&I(EwKX_OrkVzwCiqlwVc0S10gzGkeFZ<;oDsM%NF|_fopRqdQ+ci(+ z`Y@`;n6?yWIKkr-!zpq_OO6<&IcE_LTSbz^tTo~v=F1AD2 zG31<(9)U@A$Z%3(##oIIsm#IKE6WFoE7toG1Rba>R-@ zw+|`%$MNhiNSFSLFM*0yyqt->_604 z+-j`R-6TQufcI%p8|M2_N}9R2(yO&!b`+EAtLj*c*cp|-MA?DEgzhvo8q{)8<1dF%hv zuR83O*!S$2m>yfyA-aY)Zm*4erBi30dT1WF?YGTz^#MCZ^GvU_@vZQ?qdV{@dMAAy zHy3DWpNk7e*F$+DaI{U$4~7S1J;NIx2BnDBm|D2&xXx}h$@`a+$cWERG!V0ldT1He zuNPNgA?&5gKY_rO9kh^_ms!}hjyo5lIr><_LoP~xeesJ%8o&9JZF-WGsny~T zsGP-;1;*K@?D|cD0kfW;DJj6c1%`|UC=QIsp3*xh6CiEIuVX7oK^5nbU?cH9HAUR%o%_KojkY zZR0&+ciD%?GTx$#om4R@J`I}p@Ye`6z#^;mw zO1E&5ab2Wl*tYhPmuT>z<+CO*)Kx9Ddax=sWKeE%StR%s?+*r|S>wxC_3JtTsNhzc z&Q&HiDb0qD%yUmd+FlqN->M~$vN;-8YqB*EB~Oq~LccXW)@Q$?>> zr4Alx5V;|xtIbL~j_zM+VZhl@L~?jfXn||=xi-uV0fyTe|4{rgpTqbUW9LG?@07A! z%P@=jp1Y&Y7F3(BcSmSsgSLnBTp2b$a&<(S2OGt6!J0*ucI-UrJ?%CJ&7d;~2;e@-+t!$7 z2r)FPU9)&;wjb7X0lLsiE0XTQJ2P`*Q+au*bwecI)#AF!DUeCr!1`-06dJ(ugE7db zfy#@x+iCMRlZ$p$v-!UzJviSR6c>&|=G>L7c{CLlyJtL>;z4xmUH40YUkFcPLO@}IVORlH+$bY2X*gSPmjOH(Y7O}%xAZr zHJM77!w^P*nN(me^z2a$_7td4%vePh1CQK0IhyD?DWAkklSeB6WI+D#KaQ}U(Z`4= z{;FX7OsZaL^HB%Yk(SDi!KLd#n(jfp(t*zl?>_~o69bIlIOJlY<~!La71l}k*^Stn zQp0iMd#gy^$lfu5-A&cAxYC7ybrE0U?CGTilX}+eyO}O)W)VL+OU29k`g5ytjIxiv&mIvzI<=}LqLJu z|AD|aMP$XLRELyS`+LTA;v=C-ZtV%J-6xWptgT%!eG|mtURi5p#gE}9sbbm{N8#Zc z7WJ7hH%&}UN}6xf4(^JuF^l3Yt3UGZ!l;JYM5=;B2b(*k?9nXuI5WfB8COi^JDWw@Ymf@_5y$4f z3o+g&OT%0AljlwWGs{rDEJWt}*0XpChhQ@6d{ZGO)*ZwZ6PI^=WXiG$>8-k2J6mQn zshEv!1f#S=^%nD6V!#E;L$+qbQ=mu-Tm$#cMI<-p`y^RCaf%N|_$d&8 zJ!qXP^%(JqQ?wZ68S{4f;O26PMeD80r;xTI9|odF|8OlWGI5R%ZZzQZKwHw&(GJIo~`k{y=!>6ex@chT5q-ZPwf7_)w~X zE$!vg(Q1;%jP%38%^u#)S8JG?Ib3p|IE>(IE`&c(p_+9}tHa86HLi^B`jJ0KOdnSN zO1vX?NXilA5A@WHDfwYX+%C=9VS1miFBBr?%}W9@7VuQ~UH`$b7Ip^gxmZ2gU|Y&@*qY%AFN_98apF3NSPOF#!8K)}?2xmbZmwcF@!f?}z=0<9 zyQam$5V&&KLKwvrf1cH~AcGB8X@3&;4xXZXO+@&+GDR;H;`a6_&}gn1*>Wk}8l6(R zuzCHnkY=@-O1gwroq1=dw!im|^}cwi~<3e%&0kChKW z9-jdcM4lp28I6cLbc?7`WVWl4ZMoc78}~WR;izAtBFu1tMojOPt4jJ;&~UYjrQT50 zM<0%d+iXHNu3JD~JHoLlvpO)>O00T!2!m+ua4_Svc0Sa!Mz2IS_kL6mfB#5EAh1Uq zDrXsmAggi%i%#zfXed!mW^O(_#B?UQ6n+s zC^J0B@V z{M>^lVH7gQWf4SPBB_Z(pa&yrhaFlOHgm_S(x|UDcHl?EXO|io>aFwcU+&6+yAn&D1i#}_3 z({gD{vd*NE`CIW|)-^F21>1&0eX@xC9?PhPKsfu{<%)z+d8XyO6MZ_%3$W5||CjMC zJdUg#EO+PXL>W4XVUFA<(&^1FP1psSkFz6Hg62`}iT+C}Nl*20X@B9+`gq{{VFRX{P{u&ynlgmTgT%NE+9fiCcFBdab0wQ`yF-i4KjSxj6n# zR^f*BTnB}qLQ%q&g1+9^B0pA&XxqML@L6{6oOrncLxo6c{trKorv{K(@E|SYrpR@ z+YSy)o7)bWAZ3N%nZ>SSvm?Iej7VevTYv_VLb^g$pq(AN@gA!rUBZ+P)o9 z5KWtSbX#vrGNg}BIdlo$HU$2ZAym^e>H~hVX5gS-6=qq+Rw|~+uhZtk1y|YKJ>N-y zn3Hi#i6t+j!=Sj^x`^+pP)<5Kna^VIH|rIEvw5Rx2+s;r>?|i8IaanQg{MKS=|9aa z&-3pVp90?+K@<^1#Z$arsBda6M*}fh$g1?<=}p#4`OpIOlOt$~s!E-b;UUVW^oa%Y zm}~HSjv9ZIkL`-Gx~5xY1H#8LIjVpcVUnGV>odh5o(czwV+FeTr>6TxeQ*XgvMy8d z#yOtBQMGm8oS);V6&V-GD+iHaya}<~* zgp@*Lg$TdyAV&iWCBk_#ldAQM(q*q4Xp++$PuJWfBzgVVC9D1i+s{R_GTV9!4vpP3 zY;iBUWGt94yW{2W+{8=;4tUK6dFdH%Yd*5$ru9-~ePJw=1B>aZG{21Hia4)T4olOk z%F9Z6B_{dou0VUQ&lSmo@ms-)U(UBFh{m{Xx-3?=+n;evNqAP~lb`H#gcjB!^~ZNQPoh z_PKvd(B`@vTaK-a1k-Q)Fe$&kT+1~4+}%rvoRDH|d7q8JC((qXniaKb^vmy?Y7&P+ z8Zzxdr5p+yaxtS)F@1aL+|`d)1Zb#S?sya+!#Wq80xt2&Mur&=LU| zL?Ngubb`1rb8}*!uFn;QCo03FfBtC}1b7oS9W5j`az&P{|A?L4cxkY1OzmH(b)lEg zQ_WVMf-O3g6K#f|w z7n&zLdz5IFQz0{vZP07;JSjfd;sw#jxbd?l*?d@SXRW_TC3(vDvRFt{+_6Z0CFp~+ zLAwPvqAQsF{CR9I(_0r0>GW^6?HzT_y>PaF!%oK8FO-={a}E{USTJ+nQH2?MrNy-# z^|8C?2WPEV!Yez%vR>5EW6ONjZ#*Yl^W?3!X+eu2awjH6OZDp@5xo#sP!2rTUzo71 zl%WK%!{uYv4{%Q{EKCypT~laZo&to7rB8R@y`e2>IH-9%Hn-ZG6|H=yizspAs#h)6 zypuCWAM9in(sjbC|K*q|qpYN{+c7rnYKtn&+wU0kFDrwOz%_YCSz308Mj;R zq$x#ZWFL?8Z8ojpf>htke-wi)tcysJ1v)g&GJ-tWA#V~!oe@{>WNpm6Yaq+2+tI!M_cd;4iyMAMrSqu^#SP zQvjL^WX>hRlJ8=9gFn0T@(Eh>2%e$*u~a*gRwAjRwB*kw z=e_rW@@(0jMR(()NYz-rdTpq(*LDInmQ3dPhcTt}7E1h;q|+?Cc#=5t0sUbqCsA65 znkl1~bkXCJkFqM6`1umGloGZ0lE%_nhirzx8MyZ+LW?g$ix-!R7RFq2_O3s@4lydd zS}KjX64iYQ&{7o;i~SAN^z49_!z^@9vm!?#pwJ zl{wQv=hc~~`;<;lE+!w_?X6=i)FzD#3URX{5rzFmcuIc?RX{MpIyEq^DQ?vp-4XXT zqZto!(;Ef3m*EF;B?cX=WTj|J1~><9YHV_Vm3hbf;^*M@b3O^Dz}kD7mT*|VqZe;CNt$7|7)I*I+b7&-A1Q!0S$in{P*vgs4Q)k_D>QBEMT+Lq5QFV>Jr8$5Z9o14Gy~aYMT#_FV5a zg+SdFlf&IubeJX%&OR0R{gO5iVi?C^X&M_@jyX$3+acy;J}A7(!O!q}$qcT-&0 zXumCIq|F65TJUNs^YQ`9@i}MO`_@Nhu`1E3T*ZJtRYOngwwU4V6gxS3g;!~s+QfKy3P|VK0&*p WcPAjp*x{f1>Cb=klOf3IFGhj5Cl;|q(q7kG1#LA2L~@XLZo1y2<#tEP22c}xFBd-%LErh z0nX8aV->JLTod3w%8k9>pWhPrErH(>_$`6o68J5F|34)_7Dw_qgkT1t!tFTH@B3v5 z@t^leq$MCIA>nWPe+wrlQ#M5QJDm9cQ*nNe`nLprOW?NzeoNrD1inc?NycYE@xc56nvF=Kew&`_BT$$c~z7= zZR`||scU|{0vsvxe(j5okB_*Iw78q6JzP>=ULGzX1(%W%16PQ7`MG*q`HH!E@qKMT z-PX(6)6w1A(am+|MuS$T-OhR|^PWBHXro|fWhZ;u#zt1`w3W1tn53kQm6(-{w4|7g zw6u+!tmHl^JIT|$UmtH{{r&0gXFbn+ezuJ@-1dyEi><4-7m$V|oEQG3)BmYw0ugm+ zqGV&OV7<|IH_tDRH?Z~i_h$Qyqso_&ecu610)3;RqEdqY__Uvg|M?71H_*U$&pxc(O4+PZ?M)(3>Igf8d+ zL_tPIPDV;WPDV~iK|x8)NCRRFY8HlVw2V7gIM{cv>|o>M5!%JcEx^sTgIAnaVD}yo zQ4x-vaA~-(l#sB9@J1s<6qJF^cCXw%d4&V& z8k$<#ItL95jf_o>pD?wyv9+^zaCGwWK6}o`*UvxnVp#a4%MptRVR300 zyRy15E+UBJ%dozWY|FS9!MKP?Nl8d4HpWFn>;pCuMpCj}lH^QkM=7j4w)09|pk&@3 zpY^bcick6&hUK(pD>W;>OuxYF#?U^G?9UA>C#z25rbO{iRNNw+eE>4XAA*~3|z=Mh><)Qj-Y|6{yG~C=66Haj6yvr^$m%FZ5 z=dV(5r@O~7*=|5Ywp-$OssyJGF>|msU!3Y_5#(u!c~q`PfYi~ou;nEfUKq9YSttG7 zYTXznI4sh9?bEx9cD#%`+2|s4ZU3OhGmB6@u{S*>qKj#WBT2hIO&_yM`rz8KTdB5z zx)-&ONzaF8HHkovC1XSJ_!HJ~g^IpkAD(ez~RE#boLyY+@4k}D-C&>*_s*7pWJ0(luR^9g}7f^8W^@q#{g zr*HJw=)vM^`PsCEPtrK{M({yAlq-*3X2&Yb*THdu#|Y4=iPftqhH>12lZ`1<0%Xyr z_@r^A&{W`H7kefxVyh&yaH0jJVdGkfQ_1>n%O<<{_WG zdVX)~bb-m?(l@q+*2)tmh;9D7&fI9!- zSG68GnIF2xGfq7@`8+#G%Ycuy>)~^Q$C$%f%KP$|F-AkCIG=43cgt-2gWs~g?HbXS zZk&r;xluVS&tiM~1}KPS^E zWtVhA09{&MU6gjj@YTzSzKx`*skf<#=XiU37qZ+R-@FM9N{m3GJU%`jM)Liym9pMTM**2&lB z=?G9mauoWLV?7FrLu1Qlv1=m8cRMvJ|Vo|62T1RJ2W_*=K&)=lcI##fc0EJl= z5TMq>vvTW;FfjdEIN^09KGG)wJp+^yn*uHPi@ZjBox}~pw0RQ0^)XnPCvqP3Rf}f6 zDbY7!0n6}NSeXo3H@}NSamzgYPdz)HQk*ydC-rTproeBHaW)P$cxT)e5KtXP&CI{R z^Ooq7;ZY5U`QO-lU4fPeq3$5x^AR9h|7BrJw-#O>c9;PDp@o03IBf_W)nJB9(r|tR zC_yrp09CjVpzOf{^#TR#QWaR3hy2M)gz#W0Rk@R%-fg<&YfONSmZ|v<&q%K=ORzB0bIU1pG;fyg zrP?t@PGP0Wog9Tbaeu6{;#Flz=V=Z5+enA!a2mI(6v9W{HKiyl+_n2gu3}$LI94_> ze6T7_KCTexD5xtOl<|tzM4q3^zVpdt72ZH87Y+Dgg~_oF@j=!2rn`>x^%6V&*eSY` zm}=6rVPLts{T=f02d>^!WDe3=Z^T_f#SN~!n|S7;tocb3B&}fSz1-KUwsn(DkmRK^ zH|c8lnX=xm+Qja=`!boN=KSurkJBtxgQO@EoT>7~59Q9Q>ndGt$Pl}1)NmlYfxJ+w z4jvZY-KFm=@b2D)+lo8eZX3oOl<2>d{92o0g3JW54Zkht;?g-uT`QK?Rr?;djzqt> zUscS+H|7!gNe>F(XJU65jEl*6E6H=6d37F%wX`56KpAT@I94;{EHfHYSx!cP5X-$- z(I>zV?I!ufnx~n3W;qX*7Xb=sLg9JAq7Nd!lj)m;e|0@?8Z3I5LoW;yT`t=2Xi;Qk zG911cxtrwmd0?=g`!o=sC8<{gC{xT|)~~rbV}%||fbjJv&sI$1?hR znLVbu?lvbAI*#1BrRhRWnm^exC3=x36E9mZXnrtAuA1%5`=;TK+v52`U)pIIc4J+e z`%O*!RWgEPu2`I?lS$|*dQh0}quwBzap1UqpP2GM`9+oIuGtB^j1n(6?V4{WeUc23 zo>XNruUOAO$>@5&6>#Q^a(tI}Fq$dy+Uahc(e^u-n2*b>3Skv*n-z~w$gwtwUJ`xI zDRQNkC>ST~h})ChICudOvUz&RAlukh7Cu6dXasP1_{vRY&=^>FnScf zMu5nYVK@!YEztX|3IfdXVjp}3I4%NIWeX;l@lSTk>`s`9fUk9ZSxg=3(u{4=M9(gn zcwHBM^Muj#(pAzxaE4k>ocwqf0;&fUC}M%K@>`!E zK>oc1NUOmj!op{E6t7)hh+jnGQL(|wR1DKsue?8EqZ&Qj;WX;eOv3F9uQm4JK!q-f zhzN9hc-ZnEg}OXnUZfB3>M5P#t1)npnmCu_zh5QoeA2@m>e&tg>~?V>et52BH-Bhy zN|r`2VoHK>*;xl3j7gsCax4pM(P8%%?jRei z&D=BU8NM@J>)}16T}bj!?(XHtq8%<)MR8;8+s$+@$Q+Rl#4Ylt!j{2`j1rDx4{qj4 z**}(mkQ7)lj(gH82TiHEprbNiO0l7dG$vTAcm98x5Tb! z-0AN0b1*qm7#_1c>`A_OAjEGlC1mvAyR0@PgR_3NK}=4@I?l}gVbx}4O2gL;ckNe= zcH2Qwd6*3H&tZPfm|YUXHEnx@YH{D479tBTj2B+1+#IYJz2$k+1*iFpP~`0Jz|0zl z8#<+hA{+QRqEQ4ja!3)V?Haos0cv5b;3yyM*T-E7M1tEydsm4&vX2mHFmK*0JZ81< zn$4FomL%Z#D5nMgc~m4~Zf~Fx0eW}=xo~o0^?B({(B+MFb~nUM;j~=Nvs+lfBdY;WkW~gV}r7Ddz5pY_CeX^4?cStN1CIU2L1g zM7QDKo&GnNye}(t{sv-2K1df|cMZLe*^zCM3RYZW(}d-cXdMB{A+O;1k}GWF3x8)* zk^=$#m4-LyPmBcUQAI%FPjSv?b0G4%QaM3|##x;P5xa6B`Jpa(EiXUvL7+Kyv`KWi{m=k2IKL? zM8ht2TtvRN=*5X-M>VAA)n^H$J!%%c=ix>?bu@yu>50_*bBJs8)Vp1?|r=T0F=c|%ZfyRRTvKl!!vns%b#_lW0 z&#qSCEuZC1`_xfpnBq}Vp7KHNc`iTYr&3Ox(O9qE9P5d6iMQUp+~%E4_U_(K6_200 zC0Re^qx8~B({4qa6FK->n?F^C*5|~Yto!G+h1mCZ$J&r%U%2NX0~c)0vf>I z7_j;{5D%!|TqZyitP98=djEjUa@#HRqmW5;8m1MWNd?_UdXK8;7i;)f`1Z+@h6p<< zow#2dpWAz22>7epuiNd8WlVC%>B3vioTA7Y3Eus+*Iz_&_dL12a{GmW6Ek9_uLmrd zER>30_D74JW4ahi&%n+y9{>DNZNjb>W#JU>JJNoUCNs!m4G7S#UXVY$Z<50Y7mdC9 z*>VI^3rCmrB$B+i;&jgAu}GOwz(sP&RNK-%`&cJslUjwt5p=noc{tXG<}d$vHn)%Z zQ@8xW^0+F8p^@P`nHBNMSKNz*X7)VCUgoSVy$*oAxD$JPM6c!fBk_a7hc(rzU}=y_ z;Mi{Kqc8&(bHCIc^$ zKUU1u*kMOY4=az6XqFESpl~r642VysEZ14zjV*4CL^e{M$lb)8y;uwg{qps255lnQ zz;jxv5&+h-&b8QW0TxkM!@8&2uo?VW^9t`O#aaT0VMa3r4-Nahz2aF&dCxGft>d8Kmz<0R$-27bw!jqo~|!{Sq~j**p_#e#`q=M zkz1`9OUH>3X`UuMN@b5R7gcsfzNpK*p5v{1V`f*nto1_!VIS>hHuPkl7hu3(@2Y?a z8Y>rq!s-Wtj;Y@VONJa{Vt!}R(|mH7!=7i&Lu0e^yv0C*$R9?h zwP|1?t#>mSgxf1cv3F|x)jNwTFl|fC`XybX`s?>-K9Pll221(zRv4F$4ld*3X0{=p zQh=bRg5$Fl{?is04?H2j+;N_mYMV=wf<(Sy%!4>nsgGV@~5J8_=6LV zX$2Y!T@2*A=g49CLDqTUxb>5HtD;Ap_a0{%Ywgq!IRhXeD4T7t@-F+VaOpG>L}j%Y&RB+zgi2 zwY=o7mzVJYw^r)eA^v(gv+(c*u6{$JXMGTKcN)hoU)+A?lX!xni*Zj6lTD+|`N|{fkhGYj1#3Nc8#5!1iN@Z7%;Kkfs(=nt za9PRZmTzH$1lGB#!Mp^y?NIYRbSzy=(Rnk8(P*x<4qyza(6y*l0g#l1UPD#~i`8J} zr1MOBdK^~+yUr?3mVRiFj2AGbN{!Wif$=|m0}&>hgvq~@Qxu-z?QK_-re5eFy~~O} zFsqYzkRo;A+5KM34V*SubY{I+`AfKsMb|r^wazpGvV)h1epRN4o*kuaNJY)Sn~2!>57Q&$bb9{_D)2|qTWgUxHN^PLwaQiIUO$rOQj3%N3c2UqzzX}?e{RxT|ch?ui=PWlA5irOX)csU&~oTNcw#bjFVELI|)!Y>r(Tlx$$;` zqUNL#?W$eYMhq7c+)wTpWQo}#dDNx{5{=7lHP5$!BmAKk`Ifb107x!Earx52nXsy3 z61Sh^an-L2&2w4@J~`UJHQE`hTn|uTO1ED|sU2s5@!?^EEjFSP-O(h7p{Oy~G$;;a zrw1z&{{l>A*jET*v*fqvPbWZ_e~`{!*{?1Gms$y8tJ5znSC2TijzIa!}`y+YCPlm{K;YgwKv*QYPIo=&l$dHP!YRL_Y8(hC`G zd5*2BTrsgRc@9!)cgB}pRFavW#?uP#t)KT|mv4N3u`k-2#TZUD;iE$TxaD?5agpv( zv8R6Rj@|+&56a1ey?c8LED}E+RppvSWxlc+kQcY~C@y}J`DV(z*X#LxU1_<>gQ#a6 z8X!3Tk}|;1LzjF**WV)+0?%#)0-KKCe!gf+O8KDXENn$7ND*HJTNCLh{gO^>PA4mv zwgjX8%*cu4u|03!6QFnS7K1NY>4qr2Z3XgJIWQL%;vns~y|$9KfsIt5v2(LN>oIb@ zuN+8P?}9{lJ|he<$2|+M@90A07>z{?$cyga4^$$+T}f{1M9!_BTP8_+8>l0gJeVh> zS+=*=?%mC+s+#@6O*?44x*WOaFY#5lH3_THH0`R^%(=D-NjayrD{-Y%-cz~dHWWFt z4*QfqSrc@%b{I>MKcFo?Rj0;sC&DgHY`vzDw9eS!Ts^Z0I}1j&nPxb?`I!GgCQ;zY zyU0^x3h{6F92QSrPSBh$zRZ{S>_DvUUdjb-zq|lCQ(e@yi4>z+rx*v`BtZlGBRLAv zwQyrt;wfacKyHt(mU`Rk2Rt|SCbcGsxE4kn5>+Z5ie|XVq&$04!6NZ2Lqw6@v4yPp zfsh{ViW7XKNqog8x=>C~*M{(ZLQa5EHq^mZI8}I%@1LPp#qN@{jsekyFXNTO5tCPt z!u{vTk&SFEh>ytt2~hSiLC^Mk5FoP~D<(7;X}osj1^f_tRep@5Wi#{;tTyHa02yM2 z18ra;qBi9@9lywPHYt9A=H_()Ejaxm|54iFp8wnKnqfa`{n$F0!VTDJ&MNiUpWtYK zIgt~f!KS+2C7E8N?8YEAYboR}3s5SatxEXd7f|0X8vnB>*tVX(6LaQIe4o@gbf|?i zrv5qxrT+MB;DMaZkM#+c!kwSDc1V>DZI7?YWH6{q%zQH~h?;5GE;ag=*trQ65ok@H z>N?au#s49@YvNPLGrGF>q4YjMAL%Q+%pYPy``RP|jc&#v$MJByFfe0O9U+trIQ~x7 zy;BWcr^m-Tav&S$)mk*>kH<%?3-XHYYn-KB%G`58=qM*;Bcd+6@9d6!6V6J$g|((y zVGBVg4ay_2lY8rUwWsz|<_{T3?5t`$=0lP)j*1PWuVtMTyr}KccjJBK@}b4a8KW7c z6MdZX_DdPt9de5eaxs~2`Ka?V!}ig=macrxAK2o6P*GCgEoPgw^VmjT` z@3!pK#T0a7?BTB34Ej9Lgf?ZQnlGQ7s;ieCCTZu0HjKjqiH8S}5-0P#j38|h~$*8V__VJBO`ve4Y<83_i{aOaG3OdL?3|K89D4H?OIo0jbd0HP)JacQ5WTRlUivF-U_fZ!w9b@6n zoVZi&YEKS@uC$Qr<3uvZ0Hk>5CKw(mvR`YbWu-Zu&j#7U%do2J& zY?*l|JgE@2h1_Jz2><+uw~ec?wRp4Nx}n~hE3?9Hp1)Mw$Zpj^df|DVX@T?I6BbFV zKJI2LYt?%W3{Hj`0}uWuBF4Y?%6dLwNsVL3b@H0vNDj}<7oX-TfAlEzDbKCGcWzh% z1U;BEgFkRLaLy$+gZH6+JOdOXOd2zT4^w1lMAtv{-%WCP)0s^d|Hp54YQK&ttm4>v zhdet6>-wT|y1S%KYR?O~yCY?tpJP{I&ex*$4Y+x?VGB9Tm3~wR;4p-xsNBiL`nSz3 z_1j1_?>zllJzvUifw&^!yR+ULfk6Nx{$Y&&!-$;n3aSgjmfw7=vhVK}cXWX@rEN<% zea4dAzAbDtT@qtyLl#Rt*>euN3FufcAUCXQCgTHavOb;%}qt`mKKxt zea#m7<5z+u6jLFU-hQ^4lTTQkEomJe)z$`&C(zR~AdhH(e2dz?zjvMb9PA1*#?e;< zue_K6#{L`=5hCmQf@RawysvF>?~E z1K=k`UT;R4S}3x#@b}J#r0IPLSAVV@Y^nxrlpTHn`x5^mq5XF5U(JuND@lIrY9t-w z*<+Y}Z|qq#qyEj{J#?Ih$xt8o6yLqOz)s5rJwxqhK?;{}InwHI9c0`_W<(N9p?3IY zFmFk5NE=yrJAb$U|3!^w?D9%MIWxfV+y?D287&N8FA^_6(0#$v7e#IeF|^(+tGYosTo zG*$cdYRU6lO_2*rJ{T|Xq%sMw@n-N3YhmF_>UKNhGHLrCVvmrAg%{c1>ux5y@;JPk z*T)?#&TsyLXxbwbi!y!nw%jFW+_X03>|39({<-p%>=L_3qCM4Y=YyFfPpELWE;f^6 zU1=2Qq{NPmINBuj=Ty#>KTOpOzN#3KX*9L$7+S56|1{sCchal!x}$$_b&x`*(RI7I zC@$%%q+TV7^_m)xvlEZpo7~5Do`#D=U8?Iyq}KG&ZeQt9t{ktr-)SE$e)e8oU0U*o z1LFv{1jUb8#&%sC2@3ERL#aHH+UZcRlbcd!-cWHsezdXrPHlV(FeF4z=5*MV?2`2{ ziA&d!6p8m5g^{*M`-%^SCk(Sk1gY5^pV?8wRtN8PtW>Ia+L~W5q^B^z$$gO1G5?IM zefaT=Q+E5^5A5+s9ddUr&zEu|HKS3y+__$me^%tFJ^D!^)2^ZFs$fG^a^HpmW#9bQ z!GFwHRjSxy?kYb&-5)@3T0zm+Z0!F!E$)uiP zl|4`z5M@>n^{7t;(Xa(6EJ#4e=8!RfqO5L7+jc4)wlxVtFBBPGf;#Spd{>n$6$+9eM+_@ZZ&SF%vLtYmSa-6 zUxR~_Wq(hSsyr9Aw6VcB`7{1}i*9b!dZPb3DD-ArbTd8c@58LYH`t%C3+^4n6l}+u z%vx9BcVO*rjji_Nh!ri~e_puXML>}%F;_TmwW(xVoBfUwrpzr0R<3uMK60Jj&= z+5!SqK#KY{14{+~Z$?#~OB#NoIJn!T-UW^;1PB6Q$N)e>!lp25_|Rj>K0r6zV61Vo zjAmdeDq+YLCw&}o#urvwNzKeE9pEkp8vyz^Gtrp0NjkE62^$3R;d=-SH4@K@!dmn) zpvPo|@I?BbS#(*gf2LE6AGR=F%28E4f^9g<*)_v=-c&s!je*Ksg2rKkM71k?BP0)5 zCa;32_QDI#HeV`d;V#4`;7o(^u3H`5{`|FSe*`H3`}do^|EdxR*?+z3==Wd$PLua}gX)Z$GwT#S zmpf*k)6GWp_no4ghx_v3uSEjJS_T)g@if+l0GYcX7ql}O4$J|HMYUF9%ahOVAUkFa`K*t;AwWc#^jE&M!#ipD#>Hag{41rY)8kxGZfDw(e9Ws1 zck{@Z&8Z39BKu7}M*66}S~^{rBEoB5oEfyXaX?+mhHA9XzHsBq5Z=jmkOm zU6Sq!f>C$JJ9wDiA`7oU z)QYGj0GlTBX7CX#pxUXj4^SEF0K8NNN-SgXe{+b$EEIQ{AODc?pPfann}BTplU*U+ z#UjdL%kf`r8UF(;fVh0L0XBEM5`ZfmCwteKL_pXO=s|!4q5w#97Wn;E-e13N#jsU% ze(Tatg$RnYKuZE-)VIOW%_TrLOm24kbf)EV#I(5%Qn2|Iv@em~mNLk~!OgFrc@vER z#CxM2VqpE1TJ#O?`To6$MDv*l_+!EID_!B{4|V!~X1_pwwgHy}zl2OrgXmScy{bh^Jpnzl8F-E?e{iXFu3velqhCjkxR zrp5;4Ar>+8Fi;UN4@=Oi{D6A>i=dcj)DqNF-uWW%_0EWqcVk6cjvsG4+f&t*EDa|WI{$f9! z_D!c!do&WNCi{;s%a%?tEzeW#~CI>)?xqt#trC-_OIswUk>xqApLYjf|D1P!3 ztC(BoNLs=)Le5wlcI|@H_F(xjI>@K>i}^OWQP99ZD@?RRhrEDVA#K8gSJcV_B?*uU z2Y7Rg+7{GBzP|VAi?zlF%7V0y8C-;{p2alau%MQK-II(1i{;A;q=Wsa6-);K!Wh6e zDxx$EHL&^q0)XJ%w#01EpTQfSY^ZR=Xbo^wRfo`^)(eNxBAdg}0KvNs*pXje9ko!| z0bZG-LjoL63Z$H{Uvy|wQKD^gZ}y-`yQgJfj21TnqI?Si5BPXNrI+icIH!cqfp=I_ ze!&g;<*fedy8q%#532}TU_%dMk#~E1)!xZ!Z_{CSs2Nskf*9DlQcX+_CCMfUYO&Kw zz5TGq9k5)z{Pkg_SB+PL%KmEl;O2fkO#u}J58zE!OS`Dr)T1cJDC z6Px}@0RO3T^YF_)NyRYM^Dwhsvl>(V801gPogF1dIa@G)8ZQqYvWtTzW=z(dE%x%UR zsSpD|_<$C`M%01&Z)uQ3AHN+z1B!!x@o<%CwLxwXI;?-4+VsR`=HwNW52({tr1N3$8&MdNoxV*XPm%$g$ z_LBbNpyE@P2LA+0MgdgxS-Y~3Mb})MA~&wR*O`turp?yKBW7hk&GL?cU`4$s^f~ew zQ`7m&=S6z8W&HRtt~cW*TkUmu2c+IKKHl45xnj3>Xj&*!h`2y&R-p&RFp->6nW&tU zecK}EVwroQjeXkEiW90juIoZ$J-Js~uwsfx5@s~I*Q8@wM%h4*!!?JltUK4yJDEyU zBXXMl$&f@9ssGvh+dr2&|5Mui589D;<96UkFLJqMHm2vYG$nL2c6DF=wOlVU<6~jL z{O;@S{zf9bloKi8=-i2fMrTf^^IUq;O~$90+->E+(}osrPMm8z0Sw&1JH zm9LG9YK7|Db}PI1m@f&H`LVT|VvR=g{Y^LXEp z0~oxh(8n|t;!6Vq^ED~tv8ED{ohQWjQ-`KcM};kolui8i{@}&;^xzk1A_L*W{{woN BvaSFC literal 0 HcmV?d00001 diff --git a/_images/execution_timeline_dependence.jpg b/_images/execution_timeline_dependence.jpg new file mode 100644 index 0000000000000000000000000000000000000000..119a064d440528bcbc36ab625a58661ed7121b92 GIT binary patch literal 28571 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 S{l(WBY?Xff7s{acp8o@>Fr`}n literal 0 HcmV?d00001 diff --git a/_images/fg_api_graph_structure.png b/_images/fg_api_graph_structure.png new file mode 100644 index 0000000000000000000000000000000000000000..05f29c5145cfaeba6259cb6010fb303fce7c4536 GIT binary patch literal 22555 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 _=1G%*m&L7wNnu=t0`f}~-iAbN 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 literal 0 HcmV?d00001 diff --git a/_images/flow_graph_message_passing_protocol.jpg b/_images/flow_graph_message_passing_protocol.jpg new file mode 100644 index 0000000000000000000000000000000000000000..e13291202404b4b02af424d0863ba7ba88a7d607 GIT binary patch literal 17179 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 S2~kB2t8vDEPa&qqh5rq50g@yD literal 0 HcmV?d00001 diff --git a/_images/flow_graph_reserve_buffers_1.png b/_images/flow_graph_reserve_buffers_1.png new file mode 100644 index 0000000000000000000000000000000000000000..e3a00a1dfe55e33f961dca3dad1ff204db100ca2 GIT binary patch literal 9765 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 W{}-SdRO*caps6WoD>j4PMg1T1^?NP= literal 0 HcmV?d00001 diff --git a/_images/flow_graph_reserve_buffers_2.png b/_images/flow_graph_reserve_buffers_2.png new file mode 100644 index 0000000000000000000000000000000000000000..16b3e6511235aa70eecaf8a8759a56432d76248e GIT binary patch literal 9680 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 literal 0 HcmV?d00001 diff --git a/_images/flow_graph_reserve_buffers_5.png b/_images/flow_graph_reserve_buffers_5.png new file mode 100644 index 0000000000000000000000000000000000000000..e501da2c8e42031263ceae92b612e986593f8383 GIT binary patch literal 9924 zcmZ{KbyOQ|@Ghk|rNx~>gA^}L3GP7)!Go0I1PLCrd=ygL0>P!Y1S#&N6sNca=PT~C z6e(72zTds~kNd|xXWyND=Y3}8-93BGKC?5?db;XlB#b0DI5=b)AQdnU&Z8vk^%@Z# z_S}||cZwBwj*2>pI5>5Qq<8P|v2!+C5LgEXCy)yV=bs21oExm_pFJELUm+Zv18W={ zUeLl4MPw4?N!z!Ql{x=>C z!piNiN|CKnltRCex>Lcw$GdG@No5L*JbdCRE6kZy zf{I}mC?ziG|8yUfV}J$Qcb@LbiB7|fT9sCU^ItDWqIQ7Z6!>rS4I65u`eDIaR$-Dd zhxvD3eOPyZ<`k+5J)|7ulEePKmp?nXN)q%PCGSTkeCGi%|9qe$DiC>u1mosU1PwIp z0B!#_m^usnD4(&Y%94#iv8I7mACLNuEtitD)wHc-oC0~@Vzi}9Rd<1hIEkgXA@{Bp zStD|;J%B}}nvm(IAC9V0%izCCs&R-{{iv}8WTFUA>Pb{=Ps4;@%&f+JB>-n10rcTM zG+Hai@|}D;wzpeAQ7mTm!#{DmIlH&UOPrOWfcY1cM6~UF!zbPu<~iI&au|k~A*R4! zUxvVMuVkU+Z(o1Mc|$C|12murP<}=?6dZaM^j+td0TrGS4el=sM?L^-uLsxp;#26A ziS$jI!R!Zx=<;=jU+};x1v#I17cr^cXGcv|nodSFqIAiU=b$jL%oEC2jE9lB`o9pf zLSEi+PGy6{9Oun^cMNnlUsxnSwG=~Jz?A>OQ4K-i?S1B#SGMZDts6obTZGJ0y3Z&< zd#Wa_S_oFD^&#DE8qHlG8VgRO7y`H4R0lluNLH3Oh@*$_#6gmY&dI}yyY?iXPhuu= zY=_jknb;v3lvp3+L*P)4l76o1y8ACal%HFio>2aR$5^oOG+3Ox>%ALcxPg6R&?lv= z6I2yQO1$rxn+LAFIj$T2y;-n5Mb81ynj$HlQx?2T6@I^8T*W?IN;wv;60Dm{vc>+e z4Rm(AuCtUl9F3^AaFhciaw~<2wT+?jB``u#6j#Qt#v=iFuXR%1d&=6BHXCnTz4bP2zho*CNjaPhE z&f&sE=^do&Nbc&F1t^e$h5(l+pdwo@pe2`_owsaDYV-g(x}v>o)U>mjF9t6eO8~3j-#G< z4nv(~ibpYQ;)wEl)yE!9*%y7ph2!R*$}j*5?Hz(RlFBJ@rBv?%?dg)|=( z$>=Y~MAM2|ji(JAiZ|twt43DhlZFr0k=1#<{=;IiPtNL6jk}&Sk9axr^sYEP4B@Qw z4rzr&90-VE%IKY1tw!vN?z;7aEvu-ZG+D@Yp#_C+?UqeQy;i^Uf)j8rV2x*1WGOX~RH!4t{u z@UFKRKeP?H?aYn`K$;^96yY+v0{PBU{5viKuB9`u`wG6h@#jzL!H85*?YI@aK;{7GRwA)s zxe*$W-JjvrMb?lTcH_`td`LxqNO$t{nVe67s3mNh)>4X#vlcqCF|%*w878`7f8k)oIeLQ3HhdS+RejcJ%j_Ht3~i9X zNWLh{9{w&2a&(1Um9F$$UVWAi__~<@FIASbMOh=3Tz?)YgGsbNa-S#y8-!m~nV{vBFb zR_5NQ{5;Qd;(=PV*u|5-JmbQ*9U5|)`zHe&eq5s4#u)M>>1PanmgNzwP0&I`lH%cd z!aEn?rjhBHAT%2J{AW^sGiF!o;IG<@fcO}jUZn+CDLMl0qv?sxW7!w(L7e*1;B#tE z(le>>5X|b|M3HX4&bLj{ihkPQOl^r^UkmOUv7i)OVfzH%#_OA)>A|UQE6)|4krRde zcz+=ApjGtXmi18II&(U}*|+3I$GP$MBp+p1Gis7kGbMLWRj)}MS=Y+5p?LGLxNDQK z1!B|rTU+8&_-WOdZ^P;dI`>Ykfq;iEl~?q;))(8zJpJ$IdV#YI@ym0tl`Zo%_!sXL zcOAlYlHvxz3l{xKO~l`u%tPmpyK(Ph%lfE|B6VUs%BPq4Cmu+;;9j%8XNZbE2~1j_ zT4;e%TZI1QRTv|t&D@0}8Bp?xi=-n)Bywq){qNqp#Ox#KOBg(uU!V7$bJ?F@q?m)H z;#=2&44bo84Jl2X&Yq{h(C)d{heHed57HrH*Ljxe)IYdJGx|`xP5HHG$&rM`wiNCo z-?}MVeB6+neTQ_$O@gvN(IyBRySJC|R8eTdcaG~#`HFI$nHct1uQp|&T38iK zfXCj9Szw-nY;qV|cqA1dnlfiIyd;IRc8^6ECEK~twpmROmuN{A?jMS_+EIQ$eq2D9 z4@E&Efey&OFK8!oL#QNKg(T-Wtp9))H;lJyj(cuGJuv%(;9_bN6h_s=W~q&C(U!q+}OYR`y>$j~208kWN6XZR`+Bq)HBVpbjRg*e(a-9Ot2U@$PxBe9=jj8BWm%6yP-Md&!JEyuZigzv(D*0PxA94jf zXg2035r)>a#{tMe+8SlY$|)wf$6}tC+X|-OX`O%=^sE+2#1nR~>1kq~8Q<1a-G;#k z?3H@a%Bzw$7WCW`v`uV|%tOZ;r7l9ro93GZyCgQGHw9m1pukg91taqTw`9=Q#!kPyCjyi{ z^a@4QVyDhx5Z?qZ6FdPBn_eO{0iOvVywtTT(-|hd@gZlH(6h_1+?a3M%JWt0G}6t# zEAF*ThYj2xKt(|mL>$$_p+QU9C4QnSL|1`J`QpSV zCkpi?^|iW{4!I%4NOrwaaNC#h&p)$LBPPEuK1E5?$|)Z%#p;zp<~mVi zv*Pr`c)De-iy4dB4A=PX*ShgBAFH(xz+Tn*#HDZ`Rll*UtoVTTA( zh+D!J^E#$rxnw`I(T=G*l8UqQ5YEVAU10D8-u9@p`s#i%IJ8j@J;PGm$5%rQ9I`2+ zcTLNVzg!i}Hs!|&t7?o4K(a{Wj`^5rmaD$1rC-$9)^x6$hy0#p+<~o08Xa@Z2TT6R z>`CzJWFal0`dMNZaok)fB)wR1@7)VL1}U}aIdom;`F7_|p_C7CTRUE8uDkb!VNz1tcOa0~Df#Z6&gQQ1_MfOL{X_k3cmq50F6i;u8lzwqJ89bTr4iqDM+Y9rKl4tr6|w6hDQvH4lnL$ZziFNSo&6aD`X_w#U%|3UzsTP# zyXjWnA>lEJ5q7uotL9~NAX4xVhmn+;{ME8P$-ZykLM}zQcaDaYciHXzSZs|%KSyNw zkgsP<6o@TAfvo}@9Wn>4>*#;(TfD|3larwKQiJMfKl{0NxTNI{*R9lQ7y*s$E?aFh z9+D6bcYDKT;9dM+@V`du&Fo9AV&1ZLuQq|1CDF@0PjxSfJ7nxWb}#fsC)BIw#n`n) zwp8>!w8t%s(27%n@+Nn9lT|)VQThtP>yx2|wjWs;elY1uHqNAf8K`@D)xKXEv>IFE zn_-|mq)du=LT9?HgE@c=0LRhUZ#a@VUz8fMQ3Dm*202135thN2zXQO9l)rP@bihFN z+ThHtczE9J>LHIw+i*|m>)EKzdXKS|`SHtRwr!(Vi~W61!Ahb662pE>#db22&Li4d zz?EVD8SGuD<1NvWn*b*nyFcqyv~-?=?{i&J_wz0*sqQw_Sk5*Gq%npKs|OUKE3gm4 zx)MN`#3ivugqAeux+I->zlA05f+qHU;T;q6GZyQ*{MW_dsrLelBb6^GLC=%i^YBI3}PBl9vNLQmGy?G^=mEjntHjAgmFct*~>Bm(6%D_(pIKd=$+%_o7 zy*idxrJj36I$CTy5CW(433m4Xm1T{_o33tTfSU8SfaI4022yBUk_}7MVjk8plEbm*aQt;mt&_I1}brZJGTs<98C#o|a;>u(+%K@h*Qpjxe1`D9Y7 z`tQhjT_kNm>wCeAAXfS#3)}mFi;*Ljn2;yN9f(+`E1~(tJfD2TGLQ4+~fd;Q7RTC;DX{fJWAZYi-YyJZv%kOkGBf$$$hq}BQqzcU&g4}=Tm)EHL%5nr#p9+BQ88xV z5~YBc77ViHw819_3tnx-D`W{IiGWJ%1;v;D3VLiwoZwV>p`JC;?-d?Vjwv`Lt8E|P zDTM`M{-97#MRkfY5C;Mc+C|F!cl|FljiStLD|!w_G3u-#7ZRE)?tW9;MTX$a3=(@g zTf#^i3AZjq8R?9Zkw3<(4JH~tQs{7rLv|Ri%nq&T7S;@7Wl!+S{tyPil(X+`Hgg>- zV6B+UB?rcubL2IF)BtAgdZD`m(hyy`2dfAYnE&KPGnhwEfi$kwknbg<&Tz`n)3zuv z^*hq%&6K?i(3lsPD(yP|RW6;%ex|^N{X20%I_AHu^kA3sTj#3y@NTY!xnu00ouwX4 z9oZNOcRy!ELPxLS`oHX8PSV9dq27~P10vPam4+@9j4;Bv8+#TN8{SlxL+U2{Khb9J zyc_`-{+TS$rVdGn`wkT(=J=3zLZeX-_%k`bV|dz4%;K5s4@>WJk+yqNR(Y@T-Mei0 z_GRWHr^1X@W8si^@gX*vzzQ1rY7OpWGWt|K0N33&#{IoHK|Abj3rc-+PL*Q&`t0hJ zhf)KwS{AEdsP~$(dkDXjujG#O&^Yijk;EX~2CpEg`A|rcP7O zg&qvh-GPgQv~BbJyHe^jnhiEY^|s;V@!VEePYOy1gDNpCbe*o`c!NWrhV{!qDLvM7 zw<4EX)R5Xg_d)JTCat*QUz`iY)uaZn46O6|x%k{C-wjEM=%RSNB_-kz4j|Fr#d7_M z5y5AqODtO!Y<+$4K4Au8hmNf%_shZ`Peq4`#BG+3ICHk~gCMqP4MtFvlD7eCyeM72 z2(b9Uh2*r{7l*nZys;zCn%$~qX_#h8s?KFk|1?)Lr&GLjER@`&c-Y|k;+C$fbnSKs zb|(v9OHyb9YWRwb81le#esL{ngc?=WE5^0pM>;oCKiI(<$70`D!Coe}dO4Fp=N2{E ziVfvf>IGj+Zh3_;yM8lX|IunJF87n_*=<6v5&EiJ@&aDwcI`L0?Lx=qhJVeer zJire=Nh=^X9$RKvsGSR8*cQ>usj;fiY#Kqi7X2bL%xv$eyU-c&^eh06K}-4@k_ThM zaN-4N>5qdhNBu-?aSP%Oj-IpZA6bH8`Skfv7c%bp*bK=b-QE8DO!o20rs71_jv>5t z5n58(G5h}SSbo=@qr)Hdl#VuG5ek-xLE&f@d5u!FgYXg?qb^`|_ z$xSX1$?895rk_JjS>z#u$6apfgIQ$IWxd)9WA@U%zSP6x-()+CvuJ%A6ne!ros%{cy^Jf-Shw&xsC`{$;P$UWe(pgq2XG_|Lp|$>y zK9qwxncIV<+aeursX~LAXJ!?tE?WZytVZ=Xv_u>J_VS78ai#lOS8@K^+sfSgzLfqK z&aNn%jiA z>g$ORB4!nhi=|3o+J2a|=73K)JfvenZ_&I#OY62)Qy(nvzWT{|8B; zlzklhY01;v!!M77!^WJl5LY7-EjIt|W2GLTM1_PC(uB{ZY5$-bZI7TzM^3H?qMH2x zI|e3!^qV^M`4OIZ%?j1Z$44~je@qd*EH0gjR>$+x2^Y!u&2TGhr9g+1i%0Lk;xX#5 zS`Crlpz`-Uhbz2u)NUE&OUzHlxama5SV{MBK@sxFINq@_W6z)J9AlF2zUF%c=oPDI z@)q{312l6gHt!@dIDHne9|4+WpY^kI0xwyJF0Mq$ZuUxy?dK~|v<5u3NV$V2h81dv zGxuh~r+Y#lH%lprizAWLMCS%&d{!UyriFO6M+~_sh>RRs)Lf=8U&_HH^}Um@<+SP! z8;+#sn%vaf`-OCDrD|=~xvTjfj&1@+`cgHV8noVjv1`+d!kZ4?AE6Up06mkp`pR`{ zll>@mNSS1j5KC%Q`qZNEz~nw5Lm!cao*gUA)T8vpMRCnzErZh9#6YRC;u-I=Ym~Ea zua<6;OZp%BM*lGZW7t%u!kZ!mJf!gQ2eO2kd5&YVd_Sbf@=GiQpXPUKPLu?hwdI9^ z<&s3+bRD11{3`)(U6#}l^+CV)t}9#J7bZRTYOS=O6F%j^3Bz;p^DEnT^vm*6E8{7H zd&%S%=GOXFKQu3>&@Ij}&<4!QXa5M&T_|i8v`x5`{a3&GCetB?{bJbn#qT^^auA|H zc2WnkWO-^qC#kh(MW=!GYEhFn+!wo-+0uad&rXlsH3imYyMKh+9UbYFEebGciP&sX z|D%9>e-i3D)3gy_i_~r#WL!TJU;q6N9g0|7>m6bpW=vW?YkT6`O+$GJ&!LKsa}~|j zeneC})>KnQ0YTWSG5s4-Z3bJKpyTc@k?27Hw%Os?KWJQ@h|C#Mk&XNIki>l;2fg9o zOn~Pc>pZ?2V*5QNVjfOHXy$yGPE_3E?a)3LsbtIYLnY|yE7ai-OI_g+rU$h4fkA}Z zk{Be=3^)4Q;4*{zGH`5?WS7bB8Rj}ZlwSRC1@>qY6D8@2CMfHxb&_U zcmG{K#U-^u?wkAcv*_B{Kl@g*u1U_NK$%*8@3(5ZwrEp7y6f?AVxWxU|3oWpTpA7z zzYBi^O&tNfUVc8XtkGme;Pbk_Wq=RM6}{+18qHMqa5#&a?x|>2NL^09+Ud8YPYk$tYE$QJR_RFc9h!Ogf!RvyVn04wC5?gJg)pyh=PWeoaHR-n^-&cc&Gj4TtHw(V#@kBi2%ZMzQJ*#kjk0jo( z2>%Xx%Eb)!9^e_#Y|#Ai^YiG**XlP}xg7yrS7}od(QV`3xTuIZUV)r_Q_|fWD=G$F zTqE3PKPu0@9KA@|=4IY9jI@V;kJ*C&!nW{*`9i9`X_he*ZE3XxJ{4YeW!Lt@5|;12 zk7Ck5Y*H_6GyB!Dx6B9^by0okz|JQ#gE%jfEc>Cj4{I2OQN@9*kyNEpBqA$j;*B&i(ju)oODXN}C#Gfo&bj~KJ-+=QZxmlpLj zP-f~UQFqvPss(x3E??gCRW8A3D(tPh%6kgp;$@=bx)C;3;H(Ks-TPmBg`Q{A=1q3F z-=qr_!_Q=XdAMDE&ON^<7wO$<{?ryk|TGWhNK9^iFP`h0p@lG0yv#+UFSqVze z<7--jBt`|7{)HBMi*Ig`-j<$dR8;SvTU-LLiV27)Cev0tkr!(t1Xh9kLX*J$CX7G({I~#6%qH~ z7GVQuz8-$>?wx3BU*AAd(7LK!Hy~g6$XWDw>6kPYGKN_X+gTWVQHfGZL;nXy3J<-G z`#hwikzc#=G#NRSb-&h|_w%7$T+L8zq$^KyjL1=Qk0!u^h7JF;Dq}R}gNj7H zqTCSZ_Dd~_SZ#jfxun^Bg@lske1epCZ6_OOJOcl;tkR^C-F;6pZm_}Ua9u$0rBI%i z4E6P~+^-KN{n~!oEnAhtO|-EtzubEJ07dRS;Ga|o9%lxZ<=yX0)kdY%#MKZKY1JHZ zm7u|fZ}Z5Fgh4D|;H{ywYAz)zx#d4R?(i$6Fq1B)7}{E<3S*Sr56KzX3=o?oh%vEa zhA3PIX$&afN2)7Q$#w~H94m@m2oIW;XyPp%m$Q?kV{t0wYi@ZaF3A;KnnZ=k>J;R} z#j!+UrWN0KcNY}-6Pq8$FEEl=KLMZm#;-J1)+S;BM5JpXm z&zAIXCdw!MT`pJqubYPEirk5Wb%R$r?e7Bgg>OUwq~8#v_S{5O`H@fEUx$((EMJ;= zYPA^9uA&Chey9J^=mv}(9!P4jF$mYTL13)c3-l#6Bc$uHFA8(9pAu$yk9XJ-s?O(8 z9lsSe`%Gfv*0yk2(X^%S&=&e8#SzM&igj(Y!H8?i!Lb41b)|nE|4IBFkVJuv{7|Tf zbCGOB69}4e9vPTe^igtVZ8w0CGTW|mD{1IcUJx`V#ign(ON~OymQ6}xhN{dXs6nJi zSYstT92mL0Nd9;>O8tym6Aj9uXI&M8ahi=T9Do`kaJmcyuviq$EMB3LL% zWVcjxAY(IILXYF&SznO)!RY6zvmbmwOVBr3i&La|l8aWl)Z8W%QVmx^XL@W5JR19g zzvDy3so2D(iCK!}t!t>rEKW^FEhe}dzJ`Ac>Z=Ki<=M9m(NOVBah!XnHsbTLqeruy zTW?PxXz_cV)zzm_g4`mE^tyZ*eI=4p-b z(cu$AiZ;$?c$AQBI`e^@}wtUZn5GNy}H*m{)^mm(dP^ra5WMz<%e?C>VJ-p#uV&3J_I}R9fkz!c#b}MaxeYj0w8qC{or?BD& zO_F#+O8=?NQqEj6OfAbGY&Zt7e8a@b$;Yruy;)$Bixl;Hq zPu*j?%6P2yC+rbz#=fng^jFM^{eZF6Ci|;D7X+$0K-S=$j`5}uQ_mYt!~Ym4*Ytv~V< z<#(kt!3tt$dsEo#Gb{pnyJXf7@rAd`p~jN=SYa7GS4J9#RtI{qSA^V)-I|ntv!`_y z`qnd5Y#kv(PK3>1XQ63&(V|CoR(vs5BK#U{@AaUq%7~V!;1u~7?>2tWE zNMHpx?eTYgE=&tMpccC}q=xTIrHoKO6u0_+x$aRpS2$B*JESz=;hcA4l2BK1jq9W$ z>MNXE!?w?0GY$YiK5DHW+fYPK%mJ`rSHX>rS|CbR001PE{-@9A|D)Dp!`=7)Cco$m zSq7IS1cy=O=A}fXsj0duShZ(Wy@}eV^+}qxD=|)QtR=jYjyHDp^o-;|H?^9cl7Shk z5;!P-;eQZ1U3KU_t#|J*4t+(Rc8IIKMS(y0A=n%?w(3(ob+g;vN)e#?sF96=qOC}Q zU>_^~FVm-_sG|Ucsi?R{Jg{oN)i@d^s9MH$YjOIhn)=wi^RWlodf8(Ij);)3xPXv^ zfQW>lun3O_~eN- Pz|m0ERjE<3{_wv58yzgP literal 0 HcmV?d00001 diff --git a/_images/flow_graph_reserve_buffers_6.png b/_images/flow_graph_reserve_buffers_6.png new file mode 100644 index 0000000000000000000000000000000000000000..545fbf2e7707d3fedf9b0ebf40f760a6db89ac85 GIT binary patch literal 12422 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 K)vDTm{Qm&=NJi}d literal 0 HcmV?d00001 diff --git a/_images/how-oneTBB-works.png b/_images/how-oneTBB-works.png new file mode 100644 index 0000000000000000000000000000000000000000..f72427a81429a79c3bd783d0a8813dd5427c6800 GIT binary patch literal 53481 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

kg-jbr}xp;4o__~m;PQP`6A)m;J zUY@Kc!Dpb06ceoJYm(?!Wbc-)c|xb79eQr&+6y&YX-K$&*+WM;_bJqgc12oKHC@g~ zADg_h;#E~Bvz|pST8EY0Tl#Z`i?0!1rFI_YIObtJQ#6mv&w_)8dB;g&nGOPbmu07N zD9)ssYEgBUmBi{G``W2Zh4RBcWJ*;CM!J&eO`iJpruNCSdD;qc#d*c0BjK$VRc5u0^}k;97BylSyMqczM3d^R_GpY45{q5s&$o0E zrRqk+bjF=D&i)WDECxf*sK^0M6D%`L<4_=qSBu?_838Yg>krN0S z4agBO=LA{WT?zm&WjCVB&s#6pIge70&ysnrIMU?rHC#oXcI~IGC5|b7*n_SM8iQ%1 zu(ZYjpQv%w&{tduWDpT(TXfIPzs|OVwuJFPjD-1-=&MX3(gL-wbb7~EFBpibCQ*wrw5tt!ut{0FI#ekXk$??K%CC;<%y4V2l>DZuPJfgAO)70;4pNo!E zpwUS%*7T-s7&MbqRc?tJDJ5-gn4Y!+FF}(^Fj?${m8=ezIUw82u178PkC^)KrGF2i*I02nFhb`$jHj9pBfnh zNz>|MK6m(c>*Os2hF z#%?LJyLLdJH><+OO#YX%m>*_B1Cmjv#|axMiaw-UK@c(B0x9#(jZe!zS>iGd5IKQG zPSt(;Rnzw055ni*)T$QvCStqaBgw^_-@TmtCPRY`#huTJ2NFmb^UDl_r)ThBK6>O) zB1*-U&o~rPptM?N#yEt_Aj_-G`0sYzI_lNF){nD!Ka{o*_Lo>%T2LH3$)CeAMs zfCpzGHfnXNWa;eDh6oXzIQKn>M@FWPP{+6<%G@!@ zaXtN%ccdXTAaWuje!924FSLc*y? zLw8jOSWiz}GfNv~e1vyn1h;yr1JsFZ2|LSXVkm?d{m7_$KKAG!F|?56OYWtq5gDZ2 z5vIlm-%(-Beqc(Fi)#}$IFP#tfT}?|0#x`}cUnZ6H5A0a8oa1s8yj2;N^TZl9u^Vh zojzhT>$*AyN}8htxx(7iUM5QOB;ewF3Q27l~E6$4qR_vH^E54liFx zQH+Y-f32-Yb4Ei(wVAPH3CoMl?cpyTKtzc=n%9X*@Xxm6$9Xr%-IsYj&|iK03d&bwK$Hu z_)nR=NR?v8wE+1OoF=0u!yVo0QtY}K%(#-YlgJEpMSs<@vuvPa=w+Qi3CSXMVVE8$ zDbvEdO|>!7@z6-cYyAKytU3iUu-Z8)P0GYy&{$(*IvCsTEwF*6e!A{PbMkjaNP5K7 ze{?i1Q$@h)T?FWyp(p}46oxt$@gsU2f<1+lGQ!oltbL24G00>yR`w@w-Y!Qdoh_NH zOcp`*^kjwgvnVQ>H*|&h^d7sj4;pd2rs$MejvenM)KE`@mtgoHI4yQRI=)DJs?2$# z(o(`xBd24qe83xNIM|}Bf;3ffAz~1yC{eyi$jsPb!5%zCmu%)khFsU8-UWEEFsKM! z5TvZ9uOi~dhAMZb(cV?ViB@EwKJ-SLWrUE0Z~y!-@_PVfFqE1p1gj|@(eetJiD{i= zW5j(uhYD84%3;mVau8zG%W>SYA#UI>=1Dybz%|r^GUb9%kd1*5${HR#iKMO{J$a|u zR|91+DBX(j&Cfo?T-h1SfFjc}A^nOrNv)@n9K2$wDNe3D98B|A9<5cx?l<8iJ7xA0 zO0(G^OC<^QH}W0!9!8iUX06*a<|HracpLMSEL#(5UXi(EU;|`^w6oL?{gS-_=DjW* zixt_L@pA@ktG0tV4$>Vj&^Rj&xj5|-BLEdC61Xpx%XR#X@O5I;9moK2n6>M~UsDk* z2h8zPg*YZK!$8=ps}*lIVbii#=xS~N(EwnC2)lo`A8KyU?!p~%bt42H93y^=r9=>U zMzX`q)qznUtx4TIh?X(h)~Hq*m%${TkVDZGiW@3qZh=vTC)2Y#cxV_D0&0Zfq&Xj_ zP}(!AVsT305a-G}Z|(mlRxezG~hPpC}Nhp(Z3G1zprJ6%-Q?l+)_(jTmH1 zEmKLGG$1=Q@t69??)Xj+Y?2Ey!zmC;m5|Pw7EMxmYzai$z2{o=F{H3K`IznLBT_#r zdu4Cbz=4%$>h0ZJU9E)r8vKN={u49U4~>Yl66iLKZ?nyXyy4 zu8f8CK#oEW{)9|A3fa2pnRFNj?uxzn7^`6xT0*F{6r_a=l57vei^LsMv<89!5#Dqf zDymb2Wr01t%Sni#m90il1Y>Quz*Yh>{VeJaD}|BW7!jyX6h0y9SUijsd7uOH2?BF= zL0e4I`k0|Vc?=Fu5)_sa(J1T=#d20@LN;=`*}_N|EvlgmP>h-(G69rqwpBW&ECUU( zP)o>_wpd*axz>mTxrX$2%xWr}FTzZIa&)m&GY1oQzP!C!-z0zTs;P_Lw*1aVC4{g? zhNnqihF=#)LXy(b!ch#eiHokGqXekhPg!BGn=_KU3z1SzqEf4BuDNbVL*KZr51%1G z;_d89BvYVcE--jvEOW$i!){sRsWvA|g5h_nHS++ClgtPFvMPA^_~@j9AK15SQmY&g zKt?%2DT+^_Fgfj{ZgL>m4E6AVomT4~!O-x0U$VvFwn_kXTHHKG6~~GFu8(W;!%A+g zNg3UyWO&!5xn1T~u4<(AD9oJ{gJy+7+c#^6+tBcy*V`f-2IolEE7Cl~NHNT+BqE4U zawa}qL4rRMY+s&y?>L4i#b)Zu*p2#I%c@@KjS`12^DWQK*_h`v9xRL^g+&dUTL-Y*1ND)YFrRZz5nR#sOhdzosz zzTRe@KM#}KP-{cPVkQu|hM9+@4R?|1M`|1$%!jw3JFeIJ1Dk$md>>sSO@sD~@GdtVX6qR=#inK? zY;C2k7#k}LIz9}s(nxWUo~-`DD&Ok(vYg-Zd(-FoEj86YDq_?~cQ1*E66t0aN2S&Z zB4(g2$p!6fY<{j&|6?BSpcbb6pd5v1>EhSvB3thb6ayVMYEZ)bFSi%eIvOr$19$!3 z$gN?KZVdw5+%3evJ>M@s=7rh+Wa%wyq1?}2=AxzGxc!YTZR~TsSZn6A;b|C!H?{k7 zDb{4a%9==1Ce4Qr<3hx0I+K~u=X&yZTgt_y+2jwKmxZytG-?`*$ZfdcuFfVsju4YN z(wz5q@bBB#KiBIWUascShv^iIc#(po9=i$TA}$vbd!HN0S|)2KbHfKW8;y}!50wsF z=#+oLc(_w%;ZCi0eLWVH-|0^z=7zFlo4eX%NgI-STmar5&g&+S_?`}}Yif&~+%QWA zHKvhQ%75A(l^KWp{P|$R)2aV>wnuI}Qrj<0VR8iX4iX`RQpoLWvo_LL@?+6KcD?NN ztOjwGf@}`mK%ogX9hQG>rT)_&^4`mV?YB*CEkr?aUv5mOy^w%ww z6hRIavRsqW7_ll=pDsO#$F@D>!)n_5zJL9*?fF9biPymtMfM`>{FeJO z#yt34cp3{L+xu>kUhFP8(eF0aq}T7MWx>NWldK9)LmuelXwaZpHafAk*0b|=^{4k8 z`ugqnpF6NebP=#-;q!Nh%(1aO{6zoP(*F0!#P{pP@kFps#9-*N;mmYVY7tNPC2g1O z*K`qhw1D#t|8b%1x9w0b$7`hP4CVHAHBoE7XSKf<*yL}}6X?WBT9)ey#=3o$JzZeQ zfc7spS1&t{MuAU_qIV5miOO0HwB+61r<zD9^}VC-+<&LrYX?s=g5uy-9m;=+Yk`wp5(Dr@bm$!iqvAe53%P;IoX|yIE7{~7m^a;fZ)E1J->I@j~!abYsc$-W9O+4-EZ9MYQ6u*9ja&<>qh7< z1a5Xo>DrB9=`y?MpKP(WHMtLM1714V!I}ulsd@}N#7v?^Q8;vVDP(#|i_Z=H&m!cH z->$t6^RF8ovWqH3D?d?VX$D)c)3SOyS>*Bi?jO9rpo_g*7y2Gm(+d(u?Pg+>can@` z?{drM-c>jy(`1{}swq3Y_FcdK_3A(N_u6d5*I^FlPGlS&aW*Q=Ck&p+&69BueqI-Q zStI{@Wi9p){giEMX`$hV*EuZ3PSYw3|0OiPjg&9sRq-MIi!a9A&h4xhI@(KpR2hO5 z<~RbJ%mkvcfCH#26<_q_RPFCA`CyJ%zO)KA8&bnhy-7LEB_?fl-N#Tx)VCD}IicSd zK2sZHPsD-uFJ6~h2hVl*81!&<(ch$B7!F`tA5N^vUmnTd2CYS(n!DDsxgDqsR-tO( z#+&>5`$_3fU{~+wUn(y9_JSjK-hfj`jgmWvGF+v8Ho*3pLf5#7!=^IWWE`Gu_WJ^mZL(z&QW$0OH|S}0k!QTf3(&BlYbar&gMSenZ<>$O$q zVihxV{AtXO+7RXbi5KahsZ>ypn!FA14M_y)z#*VZptY%U&4y*15L`O2uX9+6w>V~r z(?|G&MP_k|1xFM#JtVm|#oN{W+Pjg9Z}i0QF4@EUwEmQCm^EL=@!evYyXCa}2K0Kj zemlqr1)cg|UUzsn?&xrh< z!mILMo-?MG!{4s4(QJk(Ixb97sEuHyBLK+9rA8}UZnTz~QKKC#wW7JD9EChR zXPlfjPR;XpZo#+!6`ILTU!4Ec=N|pTkNxo{KK1E8`IA36{L+h@v!L7gHJ@|U(9qEM zdV}JWYF82l_obI!di?Rn&z(C5TB#T(j_}8VEJ-U~rRr9yUM28qzF+bDn&QYrJyBIC>?&xMVCO#(Y>zEwt>Q?glm2ulT+n z_-@6wtKN#kDFSf`5fBZLugo{++WCBJ!m7S{IX?n{bH?F|#)*03_zbhVuw)?X<=ky# z)ueeHOA7u*@}-xeAev?YkzpLm;fdgq;j9ez~iwnkS6nn}z0ot%+ zTxc3+7L8L^jI%Sew)3H}92HCLY-YKIRCWdBuXzDW=&>n~UBz?kYT$s0I3^jn?Rqr& zBLBidbZMEU_Ut0XqU5J$NJ36e(}dBQx3Yy+3b))s`Rfkb2a;>zslbm0X|)?kyU}hg zx0=h%upPBp%dIFi-BXulE-j{%4-2?poLwT}K}HllV_cl4{Hf)5u9eKUDIZO$<@kDL#6jBK%qbV=}&+B;~#G} zn^65IimKIW6em~>KacE+rJ-T_SZO*sSxn?%s zEaqGJLNmwdVv}7mzqEXD>dMJeXU<+c--_cP@S}FS;KpU?AWE{xcKQF*Lp*bq8i!#X=K~l9gL*q_gwO3ybZg<<`rG4qv!%;q;l)VClAP#bLWF`fB-H zpV)40+BsG_esy$w!{)6!`-jIDV_W2>3(c(S7IC`RXtv_ZSEi00JAUfa>BXfbXfXz9 z)NWl%eqpEt&0x_^9f(}qpk{Mx`wn9i|Hl7$8&BNwzxy4Z*t?R0UeasI-EqsNY2 zICs7sg^-V-0)>M#O3YF=G_&9t+Q)J|%L_1`hsP#1Z{0CIv8nK?(~WG7jkBuoi_I7u zak;|<=gyx#a|-K%B+W3^6ZLMnNM0j9Gt8jY7aR8WU3-Q`#z#gcmy=|+na^QB zQZftA@;BneW(4^&vvX+n<0nrp%`Z5vjdsOqQb|=UqmF`{d(w_)I&QUpXma!R$<5nP zr1`dSrRmIt)?Cw=Yb4996byBCe(}oG^zZ%d?|$jgM_)aB=#@h+_1A0n-Fp`|TGPbh z{eQiaq;ZomKR-V-Gz1TfJxG8$0_v)U#-9(E`_z6U03-X6k9_3mr=PA=D(YofgaC*D zO~cW$ct6nO%a?qqJD2xjlERD&yE-^Jx@lYA?)f9HGuUHhq0OEaoZ^Pyw!4}MftgvhUwsjEtA{#4oz-d2<-*E%e4XT498@6m8p4{rx2WP>@nlb40YzsD> zJ-gTpv#@dQ^ofsu>|;+q_0-X$uN*&mbi;KUjFg z)JH3K0@Lw_$2Z(}|C{c-|Ba)Ycc*A8-ep$eWoOpR`CM@tdsgw}V_!Ud{K%KS@HxB4 z)2LOk3){%bM-bFg#y|l@v1OFC1+LXFcB&+ldE;d^CKk)FbJ^LPf=wYYYkHuF?eOOt+pyG&bX9@T!`Tb}{$Kvm=|fLf9Md)PANsq0`&WMX!+fSCOASZfG1SnwsnB=BHNGm~OlTwt zR`q=C;)5Uj;75Mzw+69>F>NcTyS08;Be6}K?J-r_>YYsJp%?)0Gteklz@f3p+wXtF z-EVkkaB_p;R&&Qq3p-6S%k;qT%p&n!tLj*-#o5CzJp0Ov&%XHVlTMMq)WTVXd|<|a zS%FB-{36!OOb?tg6$^FyJ#W~5=Y6-`bzg08w4LM;sETQ0;s-N?WHZmeO6{b*I5YL~ zGfy0P?%6Bn&cM#X=E4m3S}Rlqi1Whrs)k!>gh_7u1Eb^jKlI41{kLt}w#)IViDkzL znW6(Ln?*$y^;LpAN$e~<^yTMXdiKe~FFlt>ZAgYNN-Y7pms?rn*oEg;W)_yKeS;`G zSl1gLe%rx&-f-~l`xBU$0w!j7sTIXZ*56mnleUpYsDWK1)0Zzm_)E_{bNRw48%@z+ zAYCBGq_s5E-`9?Lf6uGd6T|Hv9^HS(J-6Nc1~g8X8jG!{(l-DS!FPwyCTRo`V&$3d z6o+4W;n4F>z4-jIVRPQa+;NqB^aV(f=U8dZSM3Yi^Xr2<_Uzwx``vfH@nNUZXL*5o zrKvDoK2!$2WJYP&Ks(2+#*srWJo$yso;!1b-!YZf7^LM_V53P3G-SfZQo%+{yKiLV zwtMb7c<+5X_8x>C&rH65Tp*Uohj^hO^|W#6=!^gL-~X#~#}5Z~5jf_L{^*Z>=x2Xg z^`=M#dh+RfDIK*_kNL^F>*51C^JV^PzxM0D^eexbTTYUjLI2?2`jMY<$96{+KasEo zXeg?T^fZ=PAl((uH~pY8x(UTqaTHJr)Vbn0SQR8u2tpQz?Wi4c2N(nbSE1L!t}JOC zrR$b$Lz%Gz0r>#e_WZ#0YmVpk_xG1NE3&(lq*7uXlSFNx*$CUsG{q7vmEp9~ohmJ| zO1WSl&6dIkK^5!9itSgioZ?U2(}a{CXyEWJz>JMN3A3mjhpkW{PLZDjb0ZB|mP42v z5}F29evr>M);zcBLw>a;PZU(t)5oik+a@0(jKZ+hYM_1idJxuS7^@Vu(vJW#LK^`E zGQz3DyBI;Wj`F(@?s!+r=LobcG=96)2%9bZP1BgKx|zt=LV-&N^H%benwYj@I}TbW zs8y@H84-Yot}7pad^CI5YQlq_RSja7EnW%-lzdsla&_){=-HrJt@@R!<@u4}Vg9lb zKJtv-M?t(iZd^R}Uw-wUTsih-7Ybt*fB#2*?3aJ(Lws?p$RLFIYiQh5XlAK#^MNT5 zQPK)od4YXMq2f>riH%^9w4L2Lb}CK^vSUY1B%?Fi*q9`8lP#B0=^|V4IB8D-u2* z30g(F%WXv-4HFA~$MYSp;`o7Mdz`UzndQMv`IQ??`B|36Y1~f5TD6)@;iB2aOUUcfraelFkR zu~=dj*s`6`iOEiOj75$kK(W-D4q29T<;QV|7;<&3d|Pa%+{KeOcw8S1jz5DVquuHt zT95q9Ecm@7J~2TyLMnywyR75Nlek?Vgq_BFE_?_B!o9!;XXqaolD-B?Wng3@cZzuS z_=~^!Yd<}A`jCS*H_e~DPk*xBwJB&}LsS@p!NTAx2V?{eLn9HyJ z>aT%WW|jvxFuLJy|K!h(-~LEw)p)%ZWF$_Go<>~?&@i=i&o2T*)Y49@-g-j3a0}E? zwK6x&k+a1zqj}jS&=3U579G?cZB1=P{Y?jofr!WhIq#ST6Nw*Qvi;R?U&l{&GJZKJbk@bO6VaDerE*x=0@z|*h0x@MbG6r)I2?{C^ z&K(Cs9ZCuDs1o&?PmMydBKB9oby;#;RjV?@l;$)FtT)tbuo@^ZB};78{`?w(ZSb3~ zos##$!34#YS&^??`7+y8urWT+3*rD222R>}efhoRN5N2}GK*`}mtPcM%vJKC2d$J3 zS(`Dx=@3yj4L8qQ7mxh6U;c^dW6#*4>woV@e&WL){&^P(i^MRmdV@|w<12<{mKt9L zVE$FilJ-|I%Rl^`-?F@*sE+M>;9Y;?Cx2x+_3TO=Hp1f0NS&j2==a|OaY?52& zWfW>ECQkXr8#tp-0hm4hXa%l#{C*^|=S~eKPQ=0ycFoDbgx1;sM2q7XQY`RV+7;oQ zVmQErkV=gM&fYm6aDpKPA)8RK0sdJHcN9Vja49tpN&!qZ+WPwCb3qC=SeJIg}}%W;%EINy~Mh zEEJnoq>&?tsp@_oa}5v~l9dCHPH_N7eKl!4s4Nf%e#wGqRcl`jNJAVYUkWA2pO$(H$#f9_X)>L33IrIT5rdNvSlI+ z-BJ4f8bG77dTd9t@B7Ce$}hvUaTQYg1Q1IeDZmi7PUa zGY|#K;wvtmjpbIQ!jC?Q!@#%mp;2}wpWEid@Y#oGQ7RP+rgAFaZ3$UNd_FwCiX2YW*BO#JQ2t(IH6!D|HC@|v7 zDoU|AHJ%_hm5nZvkXRgYN|^EylipR9!I*i)HR zY0v}T_FUdDI347#}4Fbk@SwPURB9ga-utX1n0CTJYEC+M2%uq(r<5 z`wvsDu3qiX7jU2nDxtDm*V-NeRNnzgKKzi6@^=NUaS(_&jswRpl;aepmbb630oYd2 z4LT_pgoBEBYs7XPATh~wa6|}r2$+TlyHSXk*MOpxJgNqVPjL)rA_O=#$QMe)?N&Hc zwCv2aFk*Rw2O5@O!BX(k`x%#5ECb0IUC+2-i%7Sy#la!cC`#JxxYYvHqJm&q!XL#% zwG9g{HmxWtLgXSl{AdOWW=qK*L6=;@Av+i2QEls@OVcb((xjb)&4dccbfsn@BQAjo z@T3@2I7xGEi*n48*K%J`m0wm{%0VViOSQ5xbWECrA%w@xCchUzaPO8!B_A%9w^b0v zqFNX*>{mD`^E!|SN`2WoY04jCLN2PbS0fdu*#rdxn3B9)#9almq9QyWAaQ>nL`B-0D&$z3fPiKV~lwgP-GEi zl$I1I__I1@#$y37IbR7%a&f##$oqtpNTW=UTe1tD=E)+FLSGu93K*bmOi zeoHgk^=$r}-dg8)mhIZSL(R`=8@6k?zU9kT2B9vi9hXP^);={=_C-4^8jCXW71vNQ z4X@)|3v0K+;_E4VJBB)k6c{!I{CWpSuW!-}N!(Y*){8WULr zfm5kKKA%Up+W8gN3(z-QQF1n6v#$tQ7hQE#@_pY%7T1#R`h0gE?GJxBVM!Jm8X6kk zu(*a%_XM(G$>p`gDqvdqi8hZ$7|!Fj+vt3(@Il2)z9eeXy3w%lPA8D%F5ify5yV+e zvdG_ngcRjqv-q^XYgaMJ^SMFOg!4_?gR?Eqwmk3hG${8@+!V64`H?P2zQF%0j7+aVUS`$@&1;>M2 znh)>+e#mG&2MKGem10ziDFSLc!*x*u?r5w@-gT0+G@6Qp$Z@sk9;B#HDW4lL9mhMP z>pE@+L83slGs**}Lav4?Kf8wUxnsrV<>wC9N>)zxst~ahE~c4Dl(d_O4z28fH9#S` zBwz;%zsw!k0K*lWCj^eYPCkE)c(M$_X~b0p1K|L9^ns5db{ryew@=+ER*u6!9C2{Br!j}lg9A&@V&0^o=U0LL?{^lxw#yrWc2E&9P&afxa!KJ z%-q<=l1s=XT7oQ7Dj;4tV=pRNjQYW;dNCvZToN1PD#zx82dfG$DNuIxaUZ30>p|KX zv3S!Q1?wmf!dFV(>kv)WTl{(1IF4UazDO=tQCR3G`Ix_Yx^E0XklQqcss2;#~jFMTtQ4RtN^#YFt39b zb{$SJ$Ab1LvOv<%*-C^7BZ(9%Qoau$n>c(u+j64Jfa5J}?vOzcO$MYX3s_#oRE!B9 z#V_g%-4e(ioHU@*m(-jZ!Q<; zMGXlyx`59K@&@^8$Lg_CsHCX1ay%`Gm`Ln#&^$iyDZ5{A=yzzLQbckYjk@X(MyQE0Dm()X;q^bj>b zzL?2x=)<8ESx6Df7Qv~?g8PDIVwh=Rl8L5yl#ubp!WLdO1zHj?J z8Uh#Aan-6D1P(uIB}=GMAZLd4q54NX^ohkTzj1qA`M3n(vbfC8%YT(*m6fjm|Q52M| zfvMnqVEI-CrcTc@Jda-&2MW55fq@g-fVq_>39PH24W%XJgJg8PhsSW)t>pYm<69b5 z%(}M4-@TUGMq);ADux@0D7fonR|e%08wg9FfDqU<-YA#*)Nt@{XA{>ta!L!xqO!D7 zetA|=9JhPKDJsdRh#KS?M|y zisdS;jI!JCi&3IwsF)oj(+ythvL;sxa!< zMHF)%G)vh3MxI$Y77H;S?d*|>W0ztgmOSKvvV#{>t@->jzdpKFa*1+rRIXQ|$Y{5X zR!f9mRTw3NZwaB1cq0Im*Ag=4sw=8T)DZ=P!yr^LaGB#jDZ(&qx7S-t31mIQRRtER z&_u=X%WLaFXtA(MRA1hJiK6T}Z`i1PN7>d~0nW?IS7A+5E}vyHvb=m1P&*U=#Xze9 zGW)S?a&a99uVn#Jf`d=$US8GE(9rk>L}|O#AJ|MfnA)_+6R;duG0coYi!d#QG3Hb9 zMa+xJ>cOMz3(QLC5kG8`;t;&;${(DznF{2Frd+la6(dw8Sn*Ccq?Nqj$aoo*LGr?l z*j(A*67hUB)^YfYkuEGCn2k*BxK=tPAE`x-xPpPgcUkOC1aUCh!jgq`z=2sJa~7}T zP$^hYRLTtuuOd%&c7&*k({(bs8q&Ng5Iaefmn8xTv}41F2Z39LUWJbNgY`^1j+Ru3 zy&7mRaZH8el7-`W*Oaf`H-PO^H~mNz`D7$2w?0q+Wt!nv<(Eeet|>nZlkO`Gs#Icg zuUY;-H=q%vZ!M&)N$=I7!{$#TCQun9S=&tnlnh0N8bKqVb2z4P3jK?~1x>>XC2jpu6l7ZM$cnIa0GVB}fI8)xSju>{;|n!H57o$L$<*mJ08vW5 zQfM_uh^r(k*A>{C5j#;FAW5l}EG|~GDes<0q8`TjI=A&TG&D5+A|X>(oMs>=w#z3J z`4XiKv*po%*-jLJ1t`WPbE$1KBg3m2t%#NxRteK0tXKwPB;Ss~3|W!yO}AP!sW1h& z!XKsKPA6GiqAZ0nNuYr0<~8yaei?>ha8pu7(6^-Bs<>tnHehito;~H+Mb2+A(qd*{ zz6mTHI45j<5l5V%1F^pe!pj+XEl_4yC>VN_M7Gd4zh}tUHsuGFX@g-{QAqy22TZNp zHpD4scGy{z8IiyuKp0^6K{#xF;uC>rKpbH*{@g$Xgvk}KEoIPEpsf+3Bi5UMA1E(h z11c2&zsg00UkxQt#Z>4fTo=9Zm1JdS)zzz^p4?SQ6j=J}mLHr40#zKCUBzOr1qf80 zYe+=@u!~H2ngO(ouZ~3-dY7cDjMIUlHlShybwBWpI11a#ZM!G}#{xI*t8tTjVX+7? z9()o|0F(>m1nWTyXthJ0hE|O-FhpC;V0~MoU8*^7KeC|_! z@_+y5|M;m-d}4WVz7|wa5#=CC?KN_@tliG}bOId72KkoUaBs&bE?FP|UeEOwh8qY< zmh!Ve7#~Soq#3l`1Ak77#v&A)D?i`oZ}8Uwrye+{&%#_2;|C5E!7xVBu+_#W@2~lJ z()Jz0_v}1L;wZOGqvD&W%L=-k{*?@ZZyH={j9_>`PoVM8^@I--NoYr{H8eCdZUxYu z@+P06i7@nzYg%ra@tH1|AIo-SQ-d~}UqOf6@wnMxxgZ5JqoAO<{6GY(Cx{(pz~+(> zg@y++1aq9qCWCM*AN~HZR}K|P$dV?hW1F>r6v4BN{+iieHDNcAZ;>+JF4j=Y2qswW`C?*^ zW14JOPvI``@Fo>Er_dbo6dcmRfTAME0vrPrw%kYI-VI-U=jXViC{OahGpYe2Ph;ai4p8$rNrHr_~W z^H-;8p4IO=eZHBs+FlU{X5N^eK7Z(i^Jh+EQP^5u%0PGv4k|vknHOM$gMH5ALzkRtS0yuzt3hTS>gCT7$j_Y4uc_l z3zjR2xGw`U$`7Pxut6;sYwU<@lwVRYjfzXFG<_+8@#QmSyoH!$agIxM&*<|Fw=e?v z>`E3Hi%Z$!ViCriKIdoJNz1U($Vl3rnZvH-VZ%(?=T5wO>hOy*moM5z=30eo<#v&! zVG`Jd8MV_UOrCr%6E;q6&ms49fx=_1MnrnqP6O_F}8O6!DH5uwq}e`$}C9n6As8qEuUz+>i4- z(5=^mL=l3x0;-2q$b))G4nEoMRQe3Bnpqxy<+Ee%RT5;*y>Y%v9=gaqYM5!1gv(jj zfNExOJ8AO=8?l%$Qf_z#j@jqCgEa#L(kZz0ZzZXjCKhN~7#4AyMBHn%4AZyms$;rE zR)kCG@|+ni8m%QS3+w#Z#?&>7fxfz974?eEpXyGbd>Ix(W}Y+`o70yT9V5j6;FG&p z2+A@D$_fY3>RtelMroGD2*YT}laNC*Y_t|<7H6iG=N7Uy7H0+)L(q8NH3n*6%uW%v z8VmDFGfP#M?6bdO4AqR91DBiOQoJ~I{?xIwwG^Q3vl!eL<@DUuzitX#W7KK9E^zVG zxhIYm#)3E1pH|n<(71&FZUqxAyC7*^^bHJ-j80T*ef5!vpx%cN*Rw2_Zwg?hlPBI+CQ+YjjP)7)fg2}z7=rE@wTeAZwP16TMjS6U zqoszGWVB*6qaN5k-+|$#;1JB52kV?el$Ex;A~w^|DU!jOUk#kPZ##Jk8whjh+c4-U z^0o8WNLpqVf@@ku2J(usbvFjqkPtqr8IgAm)QrJCaF!xzM@h5km>GW`D9vbx!>mwj z0sJ_Pd^7PtpFxdVv7Mr_#>8-SFmQY$Zp>e~a{hE{eyScAgB6c=AhmJ5sc5ybIL4x+ z_brPXYT{16n=7h7;M8?I-#>WA-S7Lrx4-NCA9(1IcinN{10&-b3ed9-6YbJUxWIL4 zfty8bGmD)(h9VAEeIJ_VaGk-;@3@_XQPnN#K2~RmTO>~2u3GVcR}2MaznfQ#2=@mo{Ja%AovwvV)KJ(s2~=H5&egc*S+d|E$6@(wb|I57sA#`vhnwyZlJ*NQY&jUqs2zv#z0+MynN=_FMRU%|L1>w`I#ruc5|d3R5Nb3 z8m?_tJdAYk*PDZ$<-`rS*NZjDU(>x_tVw=-cO6tJmCi;bdeefwShnq~dh9?$Lqp^1 z9`d{4fbCcZZ@=>$?|JXr-uccqJowP|oqIC=Zm?{H&^+_uA6PNRG<-9!z_2<7E$+fx z#mammtlR0JZ}d5tpEM0{wI~nFq~e0GB@x(Vl3H18$Bl~7hW&!sg~tq=S+iNBDeo)t zMV!J1H*B?Fxa+P7d)M!qPKLDY#{9IEMOCLT^C%6Q5XxV!0qwIgSlha9vM>g0ddv?} z3jI~C7nsyx{d1INsaeFi1DYH!yLs3z%(!Buz8QOYgp8~-;m=VcM=P#b3FrY_)kOK1 zi&n#EFGdSjE}weki=X=F@BFv_>q~$7@o@eMqQ%Rz$fC?l<7NOv(zfkDz%TO1GnzNj z#PUNo{3~Y)2r%<@JF@-C@pG4+IdpU`vMw#OW*Ygo@dI66jt z>cp#uUw-M0_uUO5b@BY!=_{90%kc*%Cbw+cvuk&)8Z?_tn~zY~?Pg?$Xp}KmTao z;LwLY{L8uN6pn+qON;a8PMuIRO5B=Cb{_uxCE)ys58NoxXBuc6L5V zl1fmU+_ZV?w(a$yaicyEAx#=*VRLTk;^lLv7G|d7I85VsV#B5lTejAR#=L63Q>j}X zAL$C`FJC@)vbD4{H*;}$VQ!!n4D{9N_4;rA=5Jb#_dOr{zP$(U=pP<~<-Kra?!>Vp zQ|C@*Nn}{g;ONBGUHc}tZgc#;FwHF+Bve(BHbSul_JySHBgBv#Q-+%jU2kzLgb@#yL-LYBjIB0z3fbpF^{=$F%@Q=(Mf5y!c+xLFv zL%;SDKk*OvB<*#7H{AZvFMNn0q6CU0$ZW}*>(Gq8!M>4=+Xu(CREHv(G>M#F3Ytf9|QrPd)wk$(No#d+}Tmw+hn^&A_y)Ro_lqjZ?=CJ^kqC zAN|ZHUwZTl$6h(Sv@ka_JF_@HKew-b~ z6{koa|Li9p{rK;Nr(ZEWH#~FU@|CHDFa%eg+^`Yr(6lhCH82t5V z{KCs$e(u;aPhOh36t$XhYZ+GDb)EeO4vdda1l8Kb%U7Oz_W74yeE!)leeTSu6K77J zx^Uq_6vefAe}CVAANcaMxeiaDS3E}ET3V=AgQ{yyT|D>flaD>|=;x8kSrCBJr!QW< zXcqauKWA1vhME0@n6f92W7KXdrYPo4Pkm(LtOdilbIxVbzs(6@cdx3AK1Qo_x#M%@nc8Bv!^{U%Xhyo&x$MOPrdluQ-@yovhP?AKJ?(j?|JvG{RjF6 z2M-^9)eC9^BO`uL%?&H#!vWN7$Khj_E}9|D^DOdhb7tzw^UpqW^p(Tlf)Bmpop1Zr z5A3}2uEF7viOG!{w`{dtZ)tY+)n~r=;!|J5;_ROL-t@q`-hc3cHxKmnOno0?z59sN%|DMRYFcL0SSX^U(cyvH_U+%cb=#ZY{MLK!zRg7otCoHJ zh0@TtJ~Xq`xcLCp%K76R&bNNcx8L*NTR>Njy?Xe<+0#|e85Z#9u;<+at?;9O{>pS25 z@O$5P-y0uHqv+)qUYa>^%&%7Nd&3+0hX-e8=bwA-Y2<7q@q6F@-iP1vmi@OKgoV2@ zHMiVqS8Mfw!C{hvl1-NLvG@ylvDKNrbpG)#e)gs3o~l*+x4h$#Z~3n8-gVpU+js5R zxOwa7=$LEU3v<)QUw-k$=bp5z;_iFyecyNdrMutorZA3AojlcUH!2lx=ZVUQVsTb`?S8FVL6IzhlFutvmJ{ zY$wL$`No%DdS%bSyMn$!!}Mx>UX<|bS%o|T5;fZc{h+x;)NZw#%a4BH^D}48-uLiZ z?!EsF)bFj^y;^^zHaIdq5l2xtfB8!v`=3U*Jig<=oe#giw)w!Oodz;?+`7N7w?k)U2D;S6j8x2KrB<+T*(SRVJ(#{~4GWcE( z%7i!UUN6=pe@*v#u_pOzIr*S!UbtAU=lqcgv>n>BQm>_kv1jl8gZplK%L5PIzHe_| zwc?^b`8-m|E;Tf6A~dtq_-X*_Wbj1?>t>vYrCth+h1i{H6`@sa=Wb@0d@&_AoIJBk zD~8TFcADEonixrI=EA8LKKsexZCiKjyY1i`-#oBoZ{Oth&6~G9`_yBL7mnYydq*%d z9<~}&$DV)j@y}&x_}*{(u1$A59BjI+I<~{9)Z(R?L!bM^<_#m8CPr%m!(V>tsdFzq z)m&b@_nq(GcJG6OyKeUfChXjrxp--DerB+*w)f!vfziRKnaiL3)SnER`N2KA?tk;! z?b_g`?Yjqu#-DxRrHdCY@7;f3baaHD?O3@pM+eS;5Ln>2wLIKk``oAhWa{GCp~1oX z?tjDW_r3{sKXdEg!KuN|voz-~f9$va@4>$6)_wQf`QRgCn|IX)$LoWmubw=4>B{uM zgLe##j*W~@KJm)V5|?TOo;A=_@2+I?kC4n?cg+%UOe^Y&f4_w0Eq zY31I5O28!$ISm<2Hw6xWnkt28UJXSxt@4q=BKYL&0cBFT$nm@)GLyE?!0UBuKjJ(2`!^Kym8}}?R)m_G6w7X@T6%* zNqqA7(dEVYp}y+oiIMG-qjlE^tn}VH_BmP9Uk{2jLQIsl6&h*A5BCH7`nqjpNghXS z{%k70TWUH(L!Rdal`7)IX})XMo_)6+XoqpNT0MF6l^36Ubf9A0ch~I`b@`)31s+~2i2h6*o ziqu=Sn7m0DTi)Kg@4w@Lx4!Ak@3{Ys5AEBtqf!kJLAR!chQ=)gF~LO&!>VrL%9f3j znqJDgy5+nFW~mG@f8mfHmPV+D2;XV8IZ`iuCHZm3r4F`iGZcxdh_R`Fi zq}`gInL2g!aK*`YZQZbO<3_hWVpPqd?o4dovuV>N!!wuXE-%kbC1LCQ*;8iRzWu=7 z?Ys93ZrWn>dG268#NK!B8~dt#u5ASsZ@Ia2^yrZbFFqd_>3s+GWy_0B)^@V6>J=M? z>ircvT%4Z1c-ARmkY8J&F0G@Ie+a9 zhF9Yz0;bmS%z>e?O}h`?@y55j@vZN=>kV(*vSrfqnJK9I;h|Nq>@eX6SjQ(fOipg}0-xX3^1Ok80o%5tC|X=x%(AS} zXq-QPzEY_U4)#}l4|Fe!z#g({;P=(~om&4=vo$k2zqr(xnw_y6d)MymV?zV{P-<>e zeXGB(x@F_WzWP9x6|UDmd9uGLcYzzo8lRmspa^UD){xTUAr8|`TS@9?6>~c|NPXS zeEj*RpO~Av3I7wqAbz>Hqd0{`H4{^8fs|KmSAj_Gkb8fBK~#fAo)j zvvKj*@|81Y()N63p&89LW3(*4@LJ?HKd8yCj&<21+pY)eH>1XC$fhMfq1shN1_9Rz5MLfBS`J?;(YR@d5~Cd_ z36=tu6IARTpK?y~deuyV(7TVd1)6Vzg4!=~|#n}$Zmwrt%#F}bl;?|;*S554)VZ{M(KbG>h< z(pSm&xdtPY-{6ViGeJj8)8;3(!7T5&=bncjeADL5n_V++E-zlbaQ5jZ9((f9&&|(G zwcBks2n^dbZNGnLaO;k(yLa!dR;wdpqX+N0_sws6WW$zimA*lzQp>$c&^M6gS)OJ^ ziethT`DDY`mgWSyEK}3U*M;6WS5Zt%aIG+Ig#}bUlXiBvOsHLFcGl3)(D=Fn<|{JG zs{s2TCSqkiA_b+W*eh`JfLui3h!qUc3)NUr~lfJkFOP%FKTI84(+hJro z9zWBTXIb1VVi;4y&N7IC`3ovF*el0_5E$-gY;@QxU@s##&waiR31(;{@;g7(T3;B( z&1TDR+^suzZQZ$Z$IhMm_TRQ^_uf12y62(yz5lIme`NEPt+pSiPrhe{o1u_~!7W)i zHdA9cF=Erd^9>I@{I+*&-?7tm-LTbo`te6U|EHgL;)|cXaP~ylT&($gA7XfDV0>g` z$F?nZ-hOcZ{=GYP?Y{l~H@)fMx9!|_Fz6cwr_L=f3br1Y0^;*Wl{IcEY<^4CjS1~N8RN$JPeAD0OL!CBOSA3b;viM;mhp!6d{KdsK;`l}C=862q zDOjkY z|DpHzBO8`eyHz-Gfm)*`6wl9k{&^ z!mHIfx`vN+V4g)QGbUP^?OjIF(9qEMItJ&oa#~xNxa1Fm<%~cCi3!6;T3KYgV}o${ zDR3m_U2%|05J%32{4Q3W$mRyP9gLmpS1i6o8n&7t_*%`g{DSt>&f_#}HyiCJO&u?Q z0}bVro2Ou`zG)(6)d6XPyfontliQZ-rJ1qR2o1-3;Nds_gP;7F@A;8`_Pzh;pMUVj zKm5J_@E1S$V;_3Y_x#<>w?Am~Z)n-|&<ks_!PyXPK|H2Ra#4rB!AN%>g z@e?2Z!GH2=Z~3c#ufFq5;n1ErZ{vc$Vb&U%GY7-!WXl_Fm^J-k_)P?qfxiUhdevGT z4%|t7Li!r}m8+C?Rg{k52GssMRT)@`F8ZNTDOyQm4x(mQQJj!{+Afw6rscru+qUR9 z;(}{g{2lZpNo?1t4GvDv%>zjknpslBVIH@!;F_AAx$^4q+_HmupXF6d*H3e!-ELY& zVx&#aOkE?z(j<%{u*uwTk}MzW>mMH*Hj3oz*|YNti>X~{8-ClWwv4J#9m>4G^aHGH z(v-g&S+)4XKNx!8qNovc-ElmS(=6kCRn%x=Y~Bua>_2$5AfiKMwQvnh_fWg^qN&eL*o|1YRf=l z!95gtNO28d%V1NAjNGyS)w5m0a`@Py<-)kZS(e55urMunr%8a;}esc z4JSB#{`~PX7nd_E=g+s>?RwvUQSG}jw*-URj3L%uip*y2=0VM@4JVb6$nB54 zLA!rEaq3HP5gBe~`8j{cQk&JAi6}C-N=frLPTP?ozop$v6t4+##A{)Vx_1C=5h(Fx zCKd=BzsQ=IpoZX)u=H@?R{WSb*c%3k4P7>dN5^;X+aIUK+4Gmqo;}}OTma`w!Zx(| z;^i5`_J&5rM<+K7j82Sg+!AH^p+ko*pFfj_4J(W0rZ1g7efsb#N8`n&?N^gDuT_JI zzM#5kWcuu}m!Ey2h#J+vH;Wv!_1w7&Gt+Zb*BA`!nq>^wksn27Bg_+Sae?(F+)A~) zz;Cpg7cO0HG#WEAGhiwkCdRjK-CV2qMRU1G8pDBc`}XmTTgFZuJ&YAq+?sa_=zoHk zQ!~@2Po7*}Sn!IX&rSAjo7gll*lH|-UxM|Z7?wP0NkVz`6d?mZkAl|(XDBq_YF$K= z7I_LqbQ~Lt0<~@F*jUW)1Fjkx8XC6**34}%2y_LX)W^gJeyPHFA}-JPY?W=BFsWc> z+@iBwq=;iae+H|B$QJCcWx)^^V402+RBN~0ahDrZ&z`^d>Z`BLT)CLGm!qZmQ^#LD zfBw9Y6(i%5{X-)#*IRe)n%KPY#Ho{0S1z?cF0(jlHm+Q`bm;KmOVd-9=i6SjZ)kL6 zY|_}UX=-NS`IlZ^Tx!H|?7FUH6iai{3o}>3i7$Tsa~Dn@2MP9U zBWyK56E0r7BAcjrrBZ>huK8|zd9l4Tm$t!%L%vC@ar5B$d=e1q7pFNNwiL$FQQGUV z$5q!2fzsU#1L^K=5RmTCARyf}99_~W-HeuQ z7R>&Q>)(V<;Y^a--TnOR zR`*UJ06E*Zv5=Sl-cxzg+DPy2?N z=iS|1jZ$UPrJdQM_-(3*f$?m|u5Ak5!)YDtT;JWPYlzvu%dxGoU34pzd|^LsR0F<^ z9lzb15KBW=R<^KT;Jy#b2_WbM2Pk7x=1bD-*@rTMnWjtR`jUdOhSkAik#C>avWCT) z{_~=;p`A-xsLx@VH(M<&4KWepT8b=kd~(&!Az)I+1KTUMhTFJlH(`ukD6Yu4@hGAX zUOh%iJGEWqJ!}ra6yVAN^iRrQLNfv3{(gyZ;6=C_A$u$0S9pN1_73(Rp|V<2xQ^w}H$Agsv-?MIv(5?yd2b9`Ndi-o;zm+(s_12E(XqF`0Zo+IS;G*o<5dig82)U;zO z4jX$mK-iYGiLj(`p#5X>l;dAzIM&=|q?Cg-W|G~PLWfTruM1q?47f&rjb(ONUc(9@ zPv5zG`E3K%FspY6=3(QfnYn2Q)i&a7r_I12_Q{S+AQQSfzG|cJcJ_De>+d%w8f277 zVn_ho7JEB74m!YBj?Ttqfj5{nci6rXyQ`2ZcwF_E5OBA&pC9Dt=@{5o;&2Cex()E! zpnN9*`u_ZUW7|wIFkCsP67Yf!yzkuyq)R3_7~r;f0^=K3tHtiYUa)4d(VNPz+Yts) z=tsNo+1o=D2Rum(2X35}4?JD(EDr75GZveU!T9=a?#X^lBD9d8F1FYiSiYSn0k%6s zccQi@MemOD10OUd;SY0>Qfk}$fQT*DWV#aH8P`TVLrG3vK6?nid>s!ZeFX;IhL?6- zAE%40=;lxolarFHnD{<}bQD}^_;bt{lqmvl7Ka=6-A1diF<@zLs)r(u1%Il>F)%Po zngzUnjiC4<4Eq88mRJJKD0iauSXo>=dklwC_wSPGTaR6SC5MCM@&5zM12LWFxrOX3 zo{Vs^0dtnbG2`w9nXEE;wmv0hQmEVFb7hWF6PTl9DW+=J%rZbB_v4uS4e!C+6|d9! zu-1QCE*aUzzEGGI36Bo=WSIx-QM-%W+)YYJetJYH;&=LlJ1GJ`Y(LFztBBOMw>LRl zmB_5$D~i{xm`Tw!M^?wx-=_BdIrvFBOzJaA_b^(4`kYyJ z^{MZxWslO!@ynxEgp)Z>@PFxJF-IV@evmR~4@T%Z6L`+%)ODtWJ&zL6Vf(syPk+91 z`;^uw^Pffs^oBnPg^>UIOvel&Qc8-d&r)kV(5x6Yt9WvsOND$Vwh8Uf!>JwV=dxX; zFdJQdU{6g!^V+xHws$%(t&pEjWa#%6XYXXuqS!Sw=rVREFE8iDxK(1P^9}4NL|tyj zikIBdOW4Q9{L(5+AL+Q5X)4!Rs4-Tgj9FXP*Y4JJBzQ+B>XI9(mLTQYEIF&-=Wd6V zJ8VopiMd+r`Nzo0xz6sp=vaWs*<(-t4tyrP+V*~+FlOH(a*Ib*XT|nU|EE({45@X;miwAq3!gwvUXfOd#|gxiHE_V$Nfh8<{xI$5 zsdvb}juAk-cw3NyoSc$kgA;6H<>1|0F^e`hqBz-?y}aB#f49&Ul=^7TF$|Cvt1QU!sXl?q zdxmsFkiVYkfHW2@eSvjhD0w&vDtrcMak6*o2r4tiG#tDz={|gJe(BMF?LJssoOgiN zU95L_4A%72V=6ay)kzS+Jws-nuuF}rvE$&Nh~;*dv-MoRyAxvK{KY1Z{Se{PGg1;n zgR)s$u$if(V2wuQd_@3a5iTje!&;}$N_@{W>gWy6i{y`VJ!R7iW9GdRMX|(QCyJh( z$hhBg&a7_MbwSSF?k3jW8}QX@vB~1`G+;X${8@tBqa0HS0|Vn)C#O^Fr3zv|Dmh;S z=R>SEc)+Xf=#B`FPM4RNXr_XTt>g8)SDZVvIIU5iOp)o zHmDA-qb7E!;YB=PQaD#6>N~V@jzt?rJM4Y!l?Da<8@3X=fH9PO@%zmCr84l$U|oZ9 z<;R~$NlD%kRWI+Pcd@5`ixpB*Qsk0#LA#I2@!Wbom5`l6UNE_|9Ml^O+~+AU<>73M zPP+%E;Y+6))EluGQZ`%`I{%$w{Wi!bveF<*X+vnaUolq^qp`BvNDko>lA&Vv4IH&s96F%)YXqgmlYQ00OYu~n1rWMMo#MMrR zu6KX2b$ze`+Zon>hPk|+k@dqNjY2b|22L)2U_n~L-K)tVQbR}X`C zm;KlE8L_i)QRcKWz6_;)*Q??5jjQaY4|OESD864}3Kj?=JFr`cN%u_9yu+MrNyx$v z1cpI%&qp=V;Y%hlgG$~i#En73pJ}>*8}`ZXKVTY;$!WrlBSwDej=rI!~<)T|8 zp~k-YO6H>59b8r!t(q;=%qt$VmPZ);@wckZWHs(LdEa{EReI#(Blk>01!7E8E}k?W zXYX#rQad*<=kHXM8l4*xmT|?!abMtvW=k$K=76u&o(M5ae(X7sjaAl726YLmNaAVU zx&;J|t7Wb9UHR&GWr)%r;Ksxg`RZEoKgPw5J`zR51pGmXwEB**$a*;8nI|g}fY17!=!wXhAyH$xKmNSkUu^nsdNjNL4gQPz0wvy=t zJBoT7;+4oRHSRq9?sfj4!$`B1|MD;Yr528+OEP0f$p0+RHM{7yLf%|ZKanMFqr4O+ zXMB%uEky~!0a*~PHnot%5$H-(Yxnsw$#c_=oltS-ta8Fl6?Z#>KFj0$a7+M$qo^B3 z+2;(MtX(20A5+turd}e~L&UFYSu#`lPcHtPno|m_Aq}+9Q70lQ@G#*3rtt8%;Qsy# zOgd6TcX$JF2$u$J+maN6H-?5s0IqV8FIGvi(jTjL?9DyPXYDIbb)EGsiW3xvIw;!Y$ z1jRYeNPM0GEXW$sT%rB$XHi#N_8>&smx=9V#7K$dsA~&3L5c_NI?0UAs|)uWjyIDH zU3Sx1JLgtFg);wmrL5FX#|w^zsY!A%TV&=r{Z>vTjZ5SePZ-WdIz_e0oQ%8J4Q$Cc zz-9(R!|V#9ARpAp0v-Ik?pSw^pa&w-wAO79tIY0<*MZvS0gjgur>0|H%Q z?9YYh-N1p{z*|5s@M+&u01y4jKI`)6AmnUMZp%-(a&Cl;!Fi3^VV4Qu5S$i>%jH00 z7>kTxHWXEjz{1JUzZu-iYO{Z1<@{lT|!#1r*4UR*CIZ{ z+L9QJnsBwv{ThZ1aud^^hU2?UhfC1EW3ZH3R%N62W3+Yk+M_Xt&W4LFWM+nRjON9y zc9ZKbA)nCAhW2v3-erL_$~FD-6$FWX)xVAvHT<*xr^8?m{S{+tC0d-NcUa}fR-K;-u`z0-Y`83St zhzUb?Nvr$^tzYBgii*tobm8$|jD{}l89v_5ZwI0ZaLgl#@sSPc3U9p^Wm4bhLt7i8X28Pr?*8I{ z4HmUwumOFhxTmDoTTlM#^7X?yua`xVMfVn|&EfK&%iiN~p3<5efEgj`Q1R1%*$7)G zwThBgO|FXLQoY+kXTgQbD5iM0sdSP@mMhADmo7!1^KwLSaryN$yA4hVA`t=QPhJ~E z^2q#;JL?*~7rG`QBW_4STa|;zypG62y2*=dg)F5&a?g|wQWTkX`vp)G8>uv8rjN*w z0D2~$;&scaV2Qe`!HhLj^T8L#*X*S-=;8=)2L&p0ge+ERGJszWCSMPyCLXCt(UY-M zsDGR8KXBgDh8`H1TUeTe@bmtB>Nfcj82lPHYi%AudA?_vNSbC}FS`uc{j)CK*H~bN z$SB_XILgHgnL7T$7zqP*%62#6q_cZf*uI_@i2%9tExSvi@Q~r z1YDFSyu3Wk0J(eVARirxJu$=6_Bdhk&z*=Hm*g8h=eKQkh+(>kLSg{6m}qf3$Qy<2 zK+5m9=5rB>)`B{bx~5r<0Zq&Hra7e2WF*tBa2kIn;l7l48s+?mqGncg4>D79h0|79 z=I#-KWl_@*ERJvNGnY{7E{Pfi{RzaX>)fV=OVp->^f45!dv>;TZbLCm9@8h;@bzR_FH0OV6bL?I$g#JDYE0BqtaZ|hxnPUS5YENz)v_$L&5UtI0dZ<_#oV!vXfbI5aryr5 zNI^C4jx`NweKa$eP_6c^-tt?w*nEe%ve<-ZWNFVyXArTHi3=#97X=IS5aa$)xUw{Z z!e;~l$LK+x7sG=P;x~^8MO)*}B`A-=fv+84NiiroXgS8Ux)h$DBpgU<8%-+vJ`^!sdQ#US%L&GJ=FxI{^qpZ!+oon ztj0^40ufJJ&k5}?(KFxdvNtBou8_Yw3#Ope#P9t5Y<ZkYx%EKn$JPd zGMY}c@BQ9=riK|65A%mT-Bm?GQ4RHipu|aNiTE7dq%Rbwi= zlTMqG8B$M)N1S1Wq&V1EJ0@cT)wb2%OafM11k+J-Bj8Ixm&8@wnM6mz2uUa77iJa@j7P%Z zAOhqWkERC6w6%hqXi-U}fct=ryJ;2w5}Uad&)1&FjjJNSU1dytrZB#0H}AONq-RxC zTxQ)CzrJ+ww;czw;7Rk{_PIUSDC8sI6YEFCnCyY(?qOG!VIN##viQ3(rPD(n_Gi@C zcHMv}o<(`eR*WO!^U}g`eoDRVfX}+799%{;u{u%Caj5eFj5@g&#HAGiT zohkTj&1A*1d6HdGI6B35%^h)O8<`$NG=;w|ru?-+j8||3t)hBYzXWr)2I*G>Bl=BV z_K~|uil9~zf*F-KSuEMGoo`8+nI=RUIx0;&Z~7y1FXJv?1Le~{N|OH=SJ)z#ohTbH zI0x_*c~~ za4hArV7AM*7Etrzypu!=p|{N)k`E0R&B5O%+xQh<+#`_02xbX&c${;!mSJfn83 z{lgUoj!yT7BoXPK7B)C7azv&GHf^Ra_8EZ1QqML_Wz;VO;fhv|{@rR6F5g{3U@T{Z zgErvV*e%9zx?Y=(Z?i{Dd7MS>Lp;KoZ08P+cpfTv%YO#SnfzsB>mrE&2;%f)7sFmZ0OKF z4Ei5nIn2Z->)wi}5u!Bdg3b6GsT)MF`)>ap|M`OsAFqA(J?yWC!K8fFOp%P_7w!CY zJ|l?PLZYocZy8RBtyGI=*9)Fk^^SdmoilB_UBv3?@;e^Qk86p6_4O{HyS`9s7W`Sn+ zvV)kCxODdi=zhWcm1O31S=;}ha3~7zp^G|>oZ0xCn}hN{-+Y|E_Fyl;! zmvn5WR1y`e83=V4qk7Kxea>m6>CzBJe}?K-QNdt}7a&ThW6)9f2>1HX0 zKlLZd81Fz6_}B&jYhu&Ck;wwVQC+LnVe>2gX~}@F?7g(Ie~a}7-;vl`vF58X-ur=+ z|C{0i7lMi3#G&~MbC@)?FJ7YwST~b|plhsD3Ho5o+xW>%M85CYH!)29RkrZ39ODlV zc!S>JiLl?jy@2!6oE3&0zx`9q65X=>k8>%#pi`*;Q!`UPM!0y0;0s44_bEebh zzY?#bi(en6J8&f|!5#}qXW$1pZ=+SQGWe8c>8tuIU>{*ozI;n{M&`nAHCh~*ldv`PA zlSFyQ`Ug5CBxd(ojThVWEG%T_DzVj(mUiNyp#1uj zNz!j0RIvL|Y2-$;7nY4{loF{hQq?^}TEm*$uage!W4eA|(!(#UqsmR+QG8)6!?j$a zu}RY)@QnK^h+9cyq$04f&Jyd**UF^Xl!hCZ{loEUS?U-ssZXF@eTr8vA{cc`eQ7H< zV&CrDNK3S0C%yaRe?3a@qD?XoloSsDIURpsUhMrL63K;ur$jiz6vLyD(x>6ZwoM+e!;L_72X3%d?=Ix}q;uiI}4I6IK%Zp)jU| zESzU}wE!ZPD^E(rcF@B!y&CDae(?ao%PUv#L^hX9NODtwxk&>rD=WJ76Qk?3TL(MIz%jN*pxs#;)(8}jrO^RetJZ-4C*SjxuB*0-m<`)i$7m z?qv;iM)6aF@jf^X{_+SmSrrCQ6A9qQFIC$^vBczMgkmFuqWB4P~-{Re5Jw%TVLL5AG4ZwokT{7_me4 zK)_ws#q-94gHzCs5!~0r1~;KLl2115y0NbA*Vobt^%DGqft@{W zh_kNvN|OHc&`#`LrK&_}>57&Oh}Zt<8eB(RYI2C&Mi%&@1NRCO;5BM`b%&hh?Jh1Z z4#bgqovnAke}{+VR7XToC`bOQ7yT_2T#hkVqm`RecDC5;FbY0_&tyr-NRpfyImu)k z?{!@Z3oiI1oAtw+*E$0pd&1z!z-P}4Bi0aO-1%nkLczIQj(BEeXOj63i`GE4J;clw zu&djT5!n)%)n?}~falc5uaPq~PP_N|?6@uT=ggeHA4>(48Nyq?l;P4{fsk9pA%)!` zts^8C0>>R;cL49nuL&Y>`wpB&DvU)YxOra4IeO{E3XiSxcAlEHWi)cyEZGX9V8xiv zjI(m^=P)XBmR2Shz*E}(eOw9_1vL((&c)mE+tTh|)BYWMtSJZ__}1^?7!oqSQ9Ea7 zJZN><^qp?j8(BMi-&eN|Xn(DF+<+6rpSpptO?aOK+(zXHoa5{W@--oVtjeTPdP@q+ z#!l1p|I;R-F^^GR&*mAYJS9Pt!p2ciN(iGjnJr~g{LirJvaX8%J znARp>Wi&X%E#`ePL_i`i7tP9ZGRCbzOG_wY4`#7^hxYHi4#M2W_ZkEBtOUs1_eqA? zEmAwstOi+ECV?x2wWO6_%C=a&?udWDWhb$ir)fpB5qj}lQQH;EYgyuS_BM{?ct_#5 zrJSK6Iij$?Kj-p}-MpMA*1)Fz_CNPVy>wvExduP@r+`E`PXyw&uk3v(qSF%TtVs$# z3j`UPtWU&<2(XRWYU>k~+l+zZczA}R{yB?Xfw(!m6a(*(W_eUh=uEx|9&I$J4#+NP zShSb~xw(b=zriVuO=e(<$fUb7M^|lKm2D6iM&qda7>3hN{S{%$E$A&j&VY{VTTXEs z1Je&Y6j1B3UFKfcFNpz7^DD^5Qjy-t$cp>D=u}z`)<$?KqE5pxe?0fGOOypjJsq!* zAu%{In~G%zs{P%H*u|_zuXENZ+#vFaJf#n}=xdnPWC%$pou@a=RCRF{vrEAWj$LIIIe19=OLoXx7$imo|=XhCn=RgV3JDrH+AFFR|N80EK8^NYmm!jpEFYMdGrd`&K0 zEeVL}NQHDQeW0XB1Q9$X>*|=OWEwLo^{*2~EgLO&@qR5Q>xjnx{FH^l|F^M{9AuDW zEzc5!#k^+P6zg_O+2h7aTB2fmedv5UW#^D4)mLBYxR$wIrYSP$VQStdh+c$oJAPN) zDMqS|!;d#8LSr}fC!++_%fR086r_AIO+_!_TmeZE{?gDtL``Ees74f7%_`U5Sro-X z6SW)QPrrMl_45`fP675Is5VY-_pE$Y0HdMTx!u;nyKicM9L}A_idE9C>>Rh03fFRL z_}F?f72p_0=v!amqS&Cuj{aLm($c4LM*doqcQVav!D9sponrSFvAj$Tb=-FXjfw$e zu2@E`5ei0w#`d%+kaxIwj$oEQ47Ft(7mVQPn9e$YR3FN8%Q(zqi|jI%K@s*n!DMwL$OG{C?NOdln@SM7LfT760tM$KK@hxxFw~!hu<23xv zIl$N#gE_8-^U;6Ir3lj)yv{je+hn|hcta) zHHBtnMA3Wxhx1m>7!gZAvLr~Yyu0!&B0q;G-guaUKf3Jeij$GJi_VlAwQoDY6vpTt zO6xFmidj^D>+#nWGDxhU2-RFKkHK_}iHv8EWYB$w^32`fr=MQz4QN$tFd9!s$ys|{ zYCl`sCvOjF!8l@7Zr=b_^6#BV+|TM%Or$?Mh-wFn?@&uqoqpC!;@J?5$ptr!Ag&(T z#`&(Oi?VL`!~hZMIh|uxG57f~?%Nn1zzHOX8Av}nSJ9+Trm<=Zu1QF02_GDP59lCf zta9E}ic%4!_BWM$*}hiv{Px*!C`Wp42Yg~e@veM~2i^Y9fsx7P|ehhAk9c zY#Y#?9_ai^slCr)>Et^B?kXy%vreQB%(j9sF4w;(>+-I`q(P6yPo*+A+P(gEnQcW6 z?I)#W^6Z$kSy!`FQ>)J+kvnE>6+U|nUo+=Isd8?wCaNXzCHGBptY%3;l4tkl^sbN$ zI=<}w8j+LT6!Kl&N)-B3!eLF3KP`0f$>yq7yu|E!1o>lcy2gs89452mc%uGtI&No_ zZ~^c?W#xS>l>=yq4ZWR5)wRTHHtNQhv%jet z{mX{y6K&%6%ORP2pT68b8c5pos4s@m>wL{yrhAw7`V80Fh_=5wk@{RV6e zWMV(v>Cc1W-V$_SHENDa8uxZ7-o_2Go=|^`E@U=X4_5Ue_LXK8QN_!1HN&}JwIR^s zF9&1vP2Jt!V%cMWj_#?{_ip3y$tonK+eI}uj&C2zq|$wi~~ z5CaaQk&(Loiti>MTbuCmiptX#vR~|mTPEJ229>tVmU=A9G!mU2LmT{uahl=IMKrOi zTWz5KE#cW)3>KO$Gk#!m>_fN#=vY;wX-OaS2Fc>$i`lsd` zKTzA?+IZhUu$(0-!${>~BErel+!)Sn>sQqgkhods&-Ag&#kABh9R6o*2fD&hRt098 zFIuwgcywQ7A#QTxpVSa>eC~C)6b|&080hg@WNp*lI4n4_s{kP)Jfflk0>XTJ%_44G zt^U0~NZ<$C?>MsCoLZB}k)MQ;S-svXph}Gr#-AaH&8ujw)IK!7{B-KBzI9q@rpzmt zj-$baXDtUqeb-z9bQ=V18oT{{dxn*;$GByNIp0vJR}`!#g4nEgv{wI);dEO|!MNJn z9`v|J+qtwGAyz_`n4a2dEv{00oizpUF{={F9`D#ngH;qHW{jIH(}LCy^y0c#f|W_f zMnHdSV7%79$V_QjX`-iP1*UAwS`eU{*X#fc~kN@MLzEPOomp@u&pCr60HBR&@YO##;C%)kRqB!xa1mo$; z%`56^m5C}Cl+ij#x!)AU#0P48nx>-7(o1D1_}CK7Yn+u0j&}D6+!vj&k}Ef9b{;L8nQ9bSn^nv!N|J`jfYG4Zo zh%UpT&xv#R7}e1D7kvk5kaWAU$9aL#z7I9_=N>j@oRa-A{QkP<(1tQVFD{TPAEbI# zdyUze7H!cM4*kU`oomo$@lh=%?^qM1TxNRKP`GNZGQBt4)Cvz zl-*I41`EF;N28|Gxu9K!MV4gzQBiFP=n69XSuD5HH*n$~Wjxv^wiagjfS(ABI8Tz) z!Sr%&eOG1nHW>IwraVSvIpH&_@Lbr?7^`PJmMsTR$m?<|)2tL2uzMK}_sZtPWGTRF zoK3Tt3by2EX`41lWD2eXe{C{9NAQPgQ=5U%S(ss5965#X`^|YJ^1M#k^3DLJ-|aE! zMuXYpnp4x!*T8BOkcL)O+0>n!qld(_Wml2 zuO8>yhwuqW;}PTMuQ<2xLcY`WlEoL%Inlpa)k@`1V%BHEAT{I~mcYI070{2_$Ib`1 z-1kSB4H}F3UJRKQ&22I~7bbGt^nW@DaWEa3oOw4)PAKxDsKLvmLckC|mGUbQ#hc74 zx^oPIfdbf|)CYuGTa0*zl}4xi&M=hI-+rz$^R@sC$2HHV#X5b<#E=6kX^bqJ4De`g z->fk6*AFW1(w~Ty3a;+g#trZoeR4?fSIUT|&DWO2jva})BFHN$4?D2ZwY!;2%F8da z#*+PhmUtYl?(PGHgh+)5)00Qzz8!T6$Bu~K2^+M~-Fvw;6GEHS=5kFLi6Ds3Ve_?M`5#UL`wVY}z23ir6496kO2FF=F~nWe*Gq$Rau zP|IxCeaa-6Fd)E&sdKUEvJ*4=ZX;zmuqX1~Cav3qvvQ*~xF@{6Kc{Aqs47hlFT||D zw$9K+owmR#vo19*90qsKLKhWOn%Udio&T9PF3A>_b^Pv+lM9qW;{W9JY~pNfV()Ek z@9u4HZ{OE1n4fn{8QP3#;$Y)q>Hy<>yIeJAU!q4KGwoW$1rQM6gKsOsE7tsz#)5u6 zha;=22zOqr=_@=`m!5w}N$Q_%Jxt8~w?Vmnw)qD6#90o1N^EX!bh=YW zMtOgyp(PxPH`lVRlzZyXob%&gChhK4Ewv2Z7E|Fby=Y_n&X@!dr@{_n4k0}7+#nQ%@{ zc{x0X$f8pNHyj_16p!vt!NCnOS-skI&cc)!u?%Vve z{HlU)BP1{^V?$S5HP*JKcJ<}8&Ok^ou2#joU&vD&6!Q%}ZR$-7c6+xMFKk81`CpL) zZX${YbTI#S`sscM*4wf!iP}F8T&jIN3VQq}lkZ5Jmf6&B5|6Te8`AYn8^xrQnusj@ zy12=>g_>*3U8yxDRK;eGn*CTF)rC$@tuh;o6S58lluXg+m*_Ia0t_vIY zC;+b3BNKaHoC{Dti6tadF_0CdA`wrD^) zYpvO=Y$Q^~*sDsU44!AJfrI2;t6m!c@Ifdk5ixowa~ZAIj?#>W!v<8~h;1QFL|FWa z`?0Vthju)LQF#XMB867ZI0tBGDB^!mjLV=ba<}Rx6Hk`e>JC{#OA?fpLH;TYC63>R z6KB>TPOs!%Yk_B^EvL&117Et6(wA8UMqx&Z=L#sc0WlnITF`==^3~P-+#(UL8B02+ z_1zBrF;y@Xvnia(?{f|Ni77EuiT4G@}0*86hQe+Pq2PwD5yH}CiaE| z@n}LzFvdfR!zrnI99KQqwUU5KwL^>V*c4=KSdeCK3mE_oF*NRguexA28~5QsFGmVY zzk`~=yWQBYjX;tm4=?kz-Z7j_k}t+*g}@szcMM<9fF%VA2r4YKXxQm}JC=6EpwfQ7 z^JhkeBS*-Am4ieMowigTT^hL(lz1I%aWr3@&A@L@hC(l3vc$_N$ej7X+M@I9 zyG6|K%C5Ca@$T<_85WpF5Kr{CKuseP;lgJr(7;8p0z6z+G67fJprKa8_y(nyB#~e&N~qjU9qfe)6r5drJyX`5I@7_7n^5nwv zhvRscFbD*)-uc$KXvS(XAvO*h18Z{3iY$fM_PeTXRN8`vLzSZ=u*1wjq6p&4}VnKJ0yUN>H^Uaw?c?_QZs%HqkCcs-xeU&miFtk+C_`2J(c|N3F( zO2N+*g_I0WR0f|s9OC&&6u>vX;&$>EGD9Q4K8^`&*@KGUe+o{nnAc9LJ+yYP(}S3; zX#enAI6NKLOY`3(+ARn_i_j58Xy`siy%3mY5gfe+9^>941$(h05V~|bG99u#hzW=W zzz*l&;k6Ao^K3Pf=c`FJ?lux`PSQYf%yfgZ&)h(y*FtlRtw9^4q&zNMmYCRo5gnqc z@b38v>9Bh9cQUO6o9fK>ZXFW=G~>Y24xK>L2@E=O7UJYQ-)pE-(DrES>HcE!6UK*4 zjW6A-i2jGc-}r6bqgjFC-)>(K2Hje9`NK{^@wmPpw2A_sV_vU-+3LR!e#px*;gMPQ zPD1)aNHj2G4n9xqm`b@`E+xH?7CkR;Pyj^c{Tw`hZ48h5h5LjEebjQ)Ra==|2K(M* zc^u7qcz85}TXeLw|02*Nn=cVeVutJyeT%&v9=m)EZc`l$eif^RtPli|H*iqbBUJQ? zuddo#ilxbiXc)J7o*Z1H?6Vv8zu4QZhxXi<6UfP1r14?0tmxGKTmRh*adT)YT*kR6 zJXs3W%yP5rdH1n)b7hi=c5;S}LzM6Oa55-4o1`K!#-ie}58(Zh4SdC!lzan;r)7u! zMITdtxJU^4J~I>_j$R&`mE!c-^KuA!hfVI;V}i$KtlbGKSSyJBZ14v5WZ27L1DKjr z_Z1~ZI3xKKlDV`La+I#@U-x?7bLVI%m`mCUok-vj4s#Ntn45P8i(Kt&1D<4pu1kZS z!fLcCvkmmkEb!Ue2_zaWm^SNi_<~p(`or@ZNZ(cs@hW=fcB*euiZgYGG4G)_ZQ@T{ zDAO+XXeZMRh9u5()C`)lrB>CP92!5KPejgxYpZ@(|4|%a{$*5o@HxVcz`jk;xzWqj zw?UWpXIYb~>|b6y$cbR`xzMTKj|{)n#4Ayf8|_I5I1=cn_y2ZL?^DOLB``;a9tO`o=^L;TfNZJ@`t zW!EsR!C$*9efZ|M{XY5xwShXbq`0C^v-nZ0G*L?DTyeTtq6Dc@Q0OnVo!>$A!h;Ig zgc7Eor8c-B+A2JwrM}W-5M2EV3%Ut{&EEyq9Zef4vFHqJx#((>D2Th2eW>2y``&(% z-MaJ@wvG7&;J+pWG6mGlwoFR1tG|0RG5_Ol8|dn~%88+;wdOy~6P;N;9MWlg@J>ss2+DZeNu`EP+kB%@BziIxb8g?| z@^pnN|J_a*JvQ~yYm*TifOw75lt=cFxy4xGuWOTZSqO7uvM?{;(wj;S-#2w9xY!BZaVR(h*oeNuq?t#^`vt zs_Kqs7vo~ACdmR`FNd*9oQzHX@ah><5}`*KEL6YTE_7W-Zahvj0v|@A_rMjcwu@Ja z>m^LvQrxw5QQld*zIofI{XE3h#j&FF-K`H!rCu|4!$8HfEN=E4AnS`ux9beKW`LQV z`NO%nqdOg~!cI|;rd~~D<=StXnbu}Ink3mz=?bNLhAZETO-n+6Zalboc7M#Ky+!2t z^6~h5(V7tXh_^bL7|~lAS`e4QzXo<&UZA`}41+T&8xpffgdcnS_MTFYca3OT9--t3 zCqDk4PWwFwh8th4lJs8q8p5~(p!yW|e1%UhP_wg+pv8|`I+{(g{)49sU-08VzYR0! zMi4_|*t8xC@I;aG;|KF`Mkm!XVMsBqr8FN%#V+g_`=fmj+ka74WJ8vo#tz0~7})bg zykCa=mg=+NC)XT*BL^P~DJd_nyYi22)^$AXT+q!oMu_ec&AHQyYPX&qM2l>(&rLp|x3glQxyfmxFUmKNfn{?;fOH7jYixi|xjwE2sO z%q?paEQSG{mlqj8q|}7bP;TcQmoh1-tH!_2qtO@eU#`93?C&&UnONd~V+CmOt>sFsh zo%=x?%-N*<|+OVtMW#Oms2F$*p#Y{~x9y9#EkXhcpc|T;n zWMKh9qR=R;`ZR|XU4P)8e<`9L!4ZjcL+-M~1*L;Hz_3cD+oxoUx4Om)OcN?Vq5B#> zo~qBpdQF~yi~hbg3L3F5!~0<35beLT+o|BcF2*Lszf|A;4WBi_MzYt>qkSLED6K{R zIsD=!PlK}E%Y1`0U4^{9R5~L~2VdJDbFtN?FaLEH82C)O;rsB<>htF|O{KxUvh`_~ zVF)x~$Ej#?0Q+SUJ92|qf$~c+O;qBSCpm3xPp?{oj*_;D3N*2q^QoV^pV{a3Ee54! z_N?gn_WpdEb}mGq2<>~| zzeld-%qrO9u2HDuH_kXerdmOh$>ix(V>{o`(-4Y*LN*X%cBoUt`J^Z*NHJ%s9SRZYH zn6dD5yi*+JWZ-5Nt@Fmf_x?f@8}Rgg>tBAU?YD+D#&6Ug7Uha%wOsix>LunnMzI5R zkSPR=-J2A8O4Brb6-Ll%qFB|&sT=Kw`KtU|UmtcgBJc769`^Tp9w4O|@`l;v<%gTv zplA3UA@aXVWs{ADgF`iAG)U@dxi@F1SQ+{5ZOK1o=SH663W|r}KGtn+!HN5#<3_V`J-%?az40P8$L)XTD^!5jrwNt!MLZAE?BG z-@FYBa-MmoJP2H+QK-23Q;#r5s?M_nWh3O=#^_X@~Be|=j&%`-c z!&t4CjYFU7^V{O*!GmcEWoZy1#gL`79gEeT1kkjv%ImmUwJ#Ld#Y#VZ-WeORqO406i1rq3%$ zY=Rf*WC%E)AVt~mdEWaoqwGmvf@+#tBbVP;GhLLZu$j8U=>oz2-`_a@(~#~*3)bg% zL)5r4w5h)5i1&V@nj8%G{y)ZQs09BXNmm)v*55TL?(Xgy+}(>8cXyYT;=xO?;_mM5 zZUu@YI20}J?k;cs&zqUdRZ=VVvqRpV|= zL_Kb&2fQ{qzCKEPwL<)%JiUwN*xC1TcJOh{{_zSjeg8I6$;L~{3=KcA0o@Ul&2czZOSbX-k?zhNN^}PS30P2I-4lkK@bW$alxe zB=#iZD?r&!Pk zyL?oYX*#J4%N3|KeUA~`*yLX1zc@*{?)AKBc+;bso?)Jwz!)vk?SDc6{OIb3m}9{u z=vd#nhX44q6znZI`WpIx6+(Gf5MQaTtMsEaWg_qqVdI7U9pl3rV*Ml_QSngyI&_)v zU?Sdo(L!<%o6%&MX{J!SL(C&AW{rB67;Ff4aCAez`3V{p@sbiMGrfAO5P828uFr*2 z;aPJ1qfuurB8Ns^Bm(`Eov=*azm{hT85HYu(BJl@`{RC@CY=7+m1Cs1;j*#4vgNMI z^yymsy-NJ#_^`U7hMI3YogCf16Mf%&PHpi8X3TVvba+d(d2*{wd;exQYW(;D`0(-{ z$2JG~u*!1mke zZKxvWayXzG%TqafhtX|ZC3OOjN-)^Gvkkt92O$I`CxJCCgZt#Iw9>TO?7*rR_ePx% z+upDp1QdT=eNH-i3rD5FIX};jOVxnOQ1RCQFRwO6rg&yhlodQ}Ff&(|UCgbCpg(Nh_o*

y}}*XDMm!=2)^%lo$f^%8AiOzGW#w|*8FEt3L$!2I5e zk@rKC<6d{SIq{N2LyJ0{R-(PlMv``?`H=e^;uRN6`l}iF?0YPha`hZHNS}$*WWp zmTcb~Jnh>OY@q!=N^s(zd_^pdF(0;5jvI|!!45Ut&H*9Hcq(;Sx!Iqiil8vYE|=x`o+gCfpRT7=*W}MnsGu8* zd4!@nLZqYx{P@G<@eqpRXW0vym&zJsRZ`W_K0Jzb%leedHc^4yo* z&xEZCbu})F-Hk|^pWryZt(0_%J2zKxRj{s9HbvnlzTp=m2&Zq&a#9s|ndAC?0Qrqv zfqNaD&v@SS2t^()_`PI<9Bzm*IJ5hzR6c#1?U#u55~)xf2WYoqxW;q8x4db)olo}r zomg+0CKib zh}^d?3O^E6J%2l&Ykcc?ttS*G#Gy{BrxaPQ1j~$I|Ef;NCGGazTAP8Xa6B+~PH0~l zzb+#WycK_`>U$2o5Z{<@m!cM?ZAY((jXhWbdl*&L56vaNEb<{@AGP@p9ty|8q#kwh zw8d7Bzbh}y$ZO$N2=7CH@5A-u4q^k>*4OLtCd6CFHB*`iLSd-O6BBZ~3)#(#I=M6n zvodD7d}jCMD%%tr&AN;eW2EFVUg?49W}%9?G%KtOx6&?~>|j&rZgvW8FZixzMw=GV zHcFWxBV;T_6=Laa^H*NQSRmlCXVKK6L(rSBk=fa#?by)N=NVpob5O zf(^C&TN-GW*}8<-yYzJ38}zdc#6x9s)P`Z88WbD!_-CiV!?7#Rf4|})@WJq3)k@Ns zz>Slo)8=!>4g*GSQVy}_H>LqjvO&b7;y+FpOctekqafAD0#ZQ`yT9jSbWj|r>`t2| zWe;Q8?9+>J5$S(5Mjq6AznWy>f}<>vPV`URXl%P*luU)nqK)l;itI&6S9c!(>_IY_ zrE>ckCG%<+N`wrcgj1l6&F=US4Z=o%b>%@LW}=yX*2zilN6*2>c6eZ?i;8Z=aF#Ma zqxzD`OF~X2Fm>D-S`yRDQ~-xjU+%ffjFEsaC5?>i#Dyke)Q8I$9MEWjsy%DG;!!? zy0&;}FQ~CHNKEbOl`?3;=H_#+U1x}j^#@klnr@Khx*{t(xv8CTxKApbUo3i*J;6;A zj%^%yyXSd3FCWy1)O7KEDPG(u@bIWdwf6jUK1rc79A%D77zC?iDg9Ei(Jh0&OP+~n zsDQ0oXY$|VwD|h~1-(UqolNL>=6TPo`~B!$lN@)Fv`~{&loe4iBJQIJPt)18Vl_rG zl;YMP+^5J91Pscact4U;f&c0{G1JYP6{z|)@+0#)yA|0%8%WSB7(+d?ceBH)I^)aN{-jL$_6!Xuh+3Cv4* zgM4r3Bwur^?c?$5F)d$Z(Y;erQdCcUPUAifUof2i;YR&Px3oE+_p3AZ{Wwdr4S%sN zEB7gN6o`z#)PNk40Z7U3082)oortGhe?SAGFsjYbBHIRD2{X9~unqan6ESv&xsp68 zg_CZmxg0z8rlK;HS4}IRhFJpk z%gcY~#B{aAuMM+=d?=Z!7PLr3cX?sGyfvwcE}rjaS3@kcGo7X=w;egO(&G5B8TURz z6DKk|ugBg=&tmh(w~o~3;x4%AAnNF-{?xaXwX>F*TVRl~2sCZG4Q_1403fq1(F)Kh z2#W7kwf=V|K4u567)BZn^ym)G*y(G;(d$uH{3!gngVd;ud`Uxk`hp&Zp`tD`J1ZYb z&7oq^XowpFaGFTrmaEMX`#n4NOW)jhxx*6F1d)TLrB`XJIV+2qJ&JxTGZPsFj_|u7 zzE2)NbL6&oc$hxVHu>F)w0=D!9w#hPOD7ig**xoIDbuig>oil)F)7QmrH!JmHyZlp zg5df1tuO$EO1Wl=>n*g8C;<8*muC^DQkTbRsj6+@z^r4;umy?ld7wHyezKV;4DIL$WCTHlHNyDKeymmUcrv%7$Z2uYUgt z#8L6i&;}bp6KA8KQ?Z>pC2>qW8Z`@1<`DvKM-2H~=W!(yDbJVJ-AC%O1%L~!Ils8fcUzx|NGoaXl9rAEV0Y|yZ9l(!AqO7p4{LTWW)Q{6 zE!G@8pWkd887yG2C~Z0%cOf#5pAprKGZAqG1lckCzE;^R>cIPwq;jIX|-Bth4twnig!bjVr-Ig;o$e~&D9yf$bo!L=th zN3S&B@9XEo9nj36A?z3{c%PG77k?WFaJRucWhRcRHf?%-at*wh`4^|9rJaUYLWxy2 zlp1)!w{UZFH=ib|W|sf+(yyX6GmaB_M@r&WMOSZTS_b7vRduiFX8Bg6sXD~kCo!?Q z8eI-2v9dGwP@uLn^5@p{b~Om0n~~`=-(6XAfsuOkV@ghk@2iBT?-C!%w3?xpNcY3o zh%9g|rn$SZqf7I}@mOg1MgSA<%E8`2LA|a=E5zj9^a;`| znrdpEV7&bdORz;X2`lFa&t(4&RRFmRa&9p0DSyC;1%V* zlbgd$wo@QS?(g)lQ_{&Fq~ldA9{rC{%-3T?cOo+J zgiKg#`xuP6yP!0SsI%Y}pDt3^u~Hl28SN-g&G?8C+CP&TC2T(2^Za>G{4qdDQxxfk zZOI>awmd36-9-LM?9Ow3HVkTIv2HYYy>YO_g(9t8AdF{fFIn4yf7=(p= zZjOh!<?uCieScI`q#G5Tw*Lzf}%jvQU_ zV!l9Dr#hht`Hw()yVmV(^*GVVq@3nnTb_XcWE=(1>v3P(W}l|h0ymn&tmFmXE!v)q z;qe#6XM9x2xn@1UK7YiA&RS*DP@s6ttNJa4J|iW`WcRTYnZ}; zcx7A^F>!MCm5{(`N!?rU@7L3oCI*a)K-=wcS(`ms8&9uRkq5BmhVT2+b`=^K-IGxz} zA13^B>|A{RE2MNZBL0k}I#GlB&9t}mS8MXKN)_VNcHnRvNfVyK9r zB~s#KE-N?6FAg!eCyderPyI3#^Vz)~c+m6wf~x~F;6Edu}H0i=`P45NiKb|ZtIL9bK^kfp}T7W6%B zhZ8&Jba$Xv-DmD@d|-id!+2eRy5 z(bD34lgc`wa+j)}T#&9Hkfv}8BO-v9ZXM(YB_@plNRiV#+vJzGnlVed8P3Q~YACK| z8S6Y9O&6ct+z*Sx7d3nqggdkMG)~Ftkby>`{wH`53cwqdWk5N)K28jIFo@ z`FEI8^ELkYA0a(pGK%_w&OU7rygv`kY*3en6d`IYz{5MuNG+8_dqgtDG7%lIj9}zG zZT^}BO}h@)6BVYlc9{lYZG+nXN~pbwdKm5-)qhddX5WngjWnQ@q#-aH)*d<{75RGOlAHP z97LgRiEuNk)&Qwo7d0}dd$Nzjxrqn zfl!V8t{6T_Ie4vh_j@eNL4Tc1pRaX4W*}zLw2s)QthWMnt&;JuCUMetl+8UUv@1Jl zkMK`_BdvqO?4BwvY0eQs3P*Dfo{b6t33lamS=oenIT=~m**291JYad++3BU~@S@ye zd{+93Aw$xv{oL*S=%nU7ScOk}?#Cp=LW|WVZRUfmXNJdB5jq;r{%RIX6t6IkJ5`F* z+OMPGTavq9c^42hV5$%s5Nc?}zFrJeQMs-{XCJaHUu))CLo(10kji%E1!7sS%;!9i zGuBSEKJKD--bBHp9E(wMw+y+!Zwtq~33f)f!^22ZO6=P&d2-3fcP@r1+tet?wf2?d z&KIWvz^SCWyE`ynx-D20HRj$pkC=?(8${4Te!S2aXC9Sfi!e$E2HC; zqNqMuO?gaen%wV3=rbh~O{Vw%&YAktPwvC4_!$O<+wf^8CYb2Ruf(0u$8o5a-)6?! zpv27dz%69P-)(-nnuz*2xjfojxjSZ=Rfd{YDYJW zeNo)b_HUh4?NrH>c!At)A8e_dB%}zQEYa*)tTXBZ&Sd2LiF6ZbY;4%7=uvHMZGHB7 zk}zrSofnUg2zabs9T`ty$@4v~Xl>==#f462wkh>>HR=o4v#@c2NL(V6mOcuBLtZx- zgC&)UQ7F3YZ9FXFhU&>`<;}Z*F;=T*zN`OnIo9a4j$`%j^f$+b<{Xo=7uGOv9N!^GzTrHdp& zN-CgIU0+KNt9*VIxCHMFRyS2!T}RQ~f96vz0ysgGMO4^h|8XlLQk@i!*8J=^Hr&(6 z-rgQ5Oe#OI)c!ds&_c;Sib8F(>hm`0W6CJ`lqPOPPmllHpSx8)SBqFATX$cl!`~T6 zH*-6~;A|<-!A;`9a)&Zhu!PSBq-|DSZF$13ZHF@Kqxt$DcL+4;Pa&zE%7Ks2%>kr; zt6ffwX$nM%h(F+vb(0;bM_%3v4ld{=0SDK7tzu@*_1VurBjKB$*U>8-yL+H!^?_>8 z6QsMW<$CWeWg4@3nmmJGTw8IhY>)YKzZ!qL>QPN*qetTxNXpSF?Q{ z9cBaN>#{Pg!q)|MJEY%s(X&tq#`_Rx&))O3od3Km`3qc9=SOK-6i_E96hqNPiwdY_ zj!Gq_<>X|OA9Vrmiw#FPZ2X2_e|k7Rh;=aFM~^oCYDCC_^|odxxZOrT?@jijo@lSK z=V6MgJ&8MCZ?SyQIo{aPhq%zLJZZY`gjQTp8E@0%Q|>AKmfPabdu#6B2rBH={0ygV zV&H;_sIFm0RoDgmuaSg2aZow%Ez0+fNM?@$1>M$u9TkK4$DTe+{IegWMaW+`MHg4y z@BS<(Ek}N}Ai&%U!+RVqC4^BLId=e{@Bj7OwfNWwn#AgJ$k;>>wM5U zG3E^mm}Rknu!I=@x`o8%4+wqs)3xTwn*auj@bErF(7708mRc*c;YKd5ga4N1oD-w` z@LddP(;g7CZd7MVY~F`ia~{>G0V7Rh$Av+MQP4^D|Hz2{axb};Jgm^U7v~WP?yp?w zdGBp0_9sXkHIRuoRL1F^!}Em6q#eYJ+$0^Xj_7mPhxw5dhtX%1o_ z@i0c@XMMFusWO8&g4U+!lo;rF>&Cth%s^4i>l;OElK*i>N^6otV~N~pjQiB`6Oq|Q z0rGh3;u0_8A!OJ+Pe)ho46&$d?c-(9ttSo+f9uZHJAEwm0kI%06)KW13V@k91QM|( z+FGQY6CV~s-CEPO)}kI>EDb#|(DlurzbJp52~Q(ahT!IEz%u(t>LoUV5%o8U)xT`W zx6X-YmPgV8b1#6-G`9It_Q9c!Q#oeBIHCeY-Ym@KY`J7J#y3MwuU83_a0= z2#A=J{nxO#iyCyuq9ZV_0wLrk0tj&OooQdz9UnQL^(3ugf0NFPP5r_!74qW}75pQj zlw49{$S3mtxMOYomDh-v2DIvHj|)6HfI(15Ol?GT_#&N%Wkob^rEUA7o99o*rJ8SM=-304kPaCu70X4ce0eLzKtVj+!c7o5_88( zMTTA?y6Wcv%xB;irt?9!%4vqb@aVrV{Cv5meOvx05)Myy4Wo4{e*|+%^*BsGy-{NFD7o5dPl5hJy3isW)L5kW zAC9k~6>CMhq`)V}qQ;@#-L0Q?aB*`A32|XYkN5t(TiEokp2Lpc@8@)KQ3RORJID&ESgr4i?uBZYEuwf1!-Te1J~-`&kx#uIJc}UV#w`j zf2_D&Ns+ORKsdTNY?W3lVHQ=(t>ED5=bOV zO9T1=I`1QkD7r5(#Qh#77B~D)V%|v>Nt>YDzYxb&^}<#8tA3*MT?|5;?)(CSOh z#DS516uA}LP!J%t9G~-R1TuG_lTy9u<@V_HvV{VVn-=!_jzQ}7$K>Rs3dvvDet>8+ zQOC?c?{dZ0eZfp*&q3Pc+s04?&8iToba*2~S{N)j09_`}D8{=iZoB+rp<;WBm#|wL z0}>nU{%r%sB&j&?3>;aITlIw#WvcS~*aZTRfufWpu+giwb8w! zgs#H(KT2&5C|!5Q#>Up(^Ci5{+t>s+S=j}+{App;$96Kn4_XnkdwU!f+2My7^;rLO zm>Wm!^)F2KQTEqI?#WVW?Kq#2$k0N)o0_JKw*F63oBt5tm0s;E(lrOp)ynR2Jj}g^ z-_OSN-fI6~b8GJV3Xrd7DoTHy%*tFzJ9X)xGB5R41AvBKR4jYP(knj$G`^k1@2p6l zq^00vi?T&912JhS+SgXUCvAg_pH~%e6C-I($yRZ23W@Lw9udOT<1Ttsj5}rMb4*r{ z&NR(IGOBlI2H*JoT<<5R%IveF*&CFWHpv=~2tJ%|bl7mky!jrp6SDG3n5b@UY+Ow6 zvsI%NB-jZ0a02uGmOYT#SXr?!5NBX=OBJ5saff7hMBg+zBDWq9#TtK4S82w6#g>KE zM{vC^6Deb!aT?c0db{Yk zxzBR#eqUiZn93cwGGenO4x7#S|1wbWPgdqmKdXZJYH9FCh$SZ|=z*PEE{NRI>5$)` zul4)fTksT%d4+$}Q70Hcthr-Zv23q1x+7EFU0u*y+tkEuq_e*v#fzEk{~ z$m$`UoT4X7S1vyowIZ))+j=&kGNBwdrL4O0d4>zkYMPqHfF4s+6&?-@zJqLg>~6ld znFij~ESmIwy~AEm-H6cz#JscW4{Nu5*(4wNqwuKQ3HZUIKaH#6`DVmyeB)=CpoYz| z8wiVOHIh!+9^k!^bX^1=Y1^i>!57ysfR^fnLkF(mXD>K$|8_$ONo|!Z5bNp z=K0OS$tpe5%a~+u@$ZU;p&^T-(B7<6(FXwzqrLc3Nyt8_`fT&~_;~H)eSD>w`EC=A z<<1UHQLVE=;t!*eXty3!#tU$l;ST-%CBQONS47cr5PgsynvZZ1jG($Zcy07g@aQAu z=?g&|)^L4aTy`7nP0WvYE`5;=T+=j$E8tFr+XQ;4Iu`dWh@g?!@76-$@Q1xc))!`S z0jkqPpzN$1A`&7lv||S*5U6H6kuuuE*X4PwV&`Q&-~_T{=DoMbZq)NF(gDg9ucA*n zP|=T+&c-K=`oT~_6u~5Xh*Z{1TTO5^sP4DwNAG5HBW#||?B50!oP@{$685)O26l*` zd>s~eQ)luzykQK1LWl2ezTfN9b5lf>lG2qqIYmMD60f4`H`rIWu!~J{>S{3lw@kiY zsId&&T#Sv4$ri%4Ka7)}WCy|((VF8~s;{rFYYf{glo~gMii!qlLZ#h4^QPD&hQni> z??lK%LD_R^RIp9>Lb0KYkb|$sOHdY7$;EwlFW+G#ag3Y0bYna1XFUR^Ie?u3cKkCl-bnAw@r4daQ#+C1J4-_<4j>p zw)qPV@1rlD<+K*u@kZv?LiTrg8Av>vs2D=?1v@ets0@z$JVP?nA}Q~&6Ii0^MDWt&HjvuhxIC z4Dgcp$e?elOa#*oe-#Z!!vCr=aAnp`tFJC2TM)|DaECQlXko$}K8XcT*)OJ+_Z zUx;S5Vg7r&_YZ{LIB~6)Q2)jjp2U$>Qf|na!UVV!h`lyH-`rTEJu@he7@s?IsJsBwOTd-DrwwhFQW2 z#Ig;}v^_FUCCcr+9TcHFDMoFYLQt3S<}yOeo3aORW%;6fMn+X* zQH$kXAcuJuVf2r@0AE)|Y|jpq;jwE1v~CJkUgdb^eu`v@)_|=!snrm|NCr=lTQ_a% z+0g^Sre8-h6mTrzsc^f;GNIC;q_|CP;); zSx_n@`(Fc$BXJh&DI+bkm_~h=kuU3B%D^m?bQiLxSeeRdu=%x^PxjEr#2OL4U4j&A z^Nbxn5@C2RxS2D<>+tiUMeNbGybQh+<3B%`TKTcx?laeaTGTDr;lWNcah&>6u(z zEP+K$gut$w;ZL(Dp(NND+lK0MQ9la1yhIK3bri}(7qil{iHX3IQ+U_*i#NYHhZ|Ti z1#yYG5eKbh(+18YI$pHtM|C$86U_lnP!E`FI4H5KOa|$Ko!UVY+IaNGnKX9FYUv2* zf6_+xztTuh5{wfz55|!i;V}D!1O}-}gvoU^PojxSfxK{BH^s%+B%me!$U>vJ6|rS` zng=*oRX-e;SYGtKfj({@KJq^9%06B`UT0O`A0AAfmaqI>CzXHcXlpzF>-5+=UT~mQ z{>rwW-4WT)1R3(&Q#E-X>+A8}{kOc83*L>lv(eR({Y~tyViVe7@R^faoLg+D(O$lz zbac$Bv9YnUuu$q&E??sH;`ml{^HSUaI%)<3id5}gx4N>{xWPh}Iw4+NWLkO-2XbKx zUw9s}(>1Qc=Xgb1D4UeLY32mZvJ=b^^T>)3P_|ZJ4MJJSCs#6BV06ft!(|jA+jp^ zCS-=%Y3IsTO{7q@4Jd6bvLwF!VY1U8u9gUP*%?nN)tJesopJuTg{xeNy+C8oV7C7) z)iJYk*C1ng9aQF;4T;?ZZz+vnpc)Ia7-U?R*DAJ`nCX?$M5(nX)51WN9_tTV*p$X+ zT7@<1j&iNW(^BCg+h>;AG1rYS29H$X_S#9r(&W40a_N(6(y7l$`4SGvr1XQ0Z17N) zzti*D@9sNaW?N7}Oh0Awv8tdoaWieOcIQ34pVpx>Mr1+Ws#|XA$!5;Ra;4gY&fNq& zZM2=Q7_>FFIKn7?Z9l$Wt+Bdc2Z=BdJ#8T2VvH1&YKsiD(v6IRm2ZuNZYEjSNyQ&s zHttaN!9PUBxdpl0woWTTU)G9ov$UF0GCatKFi_dZBPb z-vpZheOSu4f*1mI6pAjzXg@@k2`71ueon?GZt#xj7r){ z;qSZ^Ub}UoYJn{QSHQ~<))PcNlZf3z%*^mI6l!C0CJQXw%X5p%3`>*fp4@3Pv}LZhsn&*v8x6FO#F2qNkW>g?y)zV;x4I3)zULD8Y|| z$)Ui6U~DYAQD%dPZ=A$|_Gq;&iYBmfpY? zYGRVS_~T{Mifg7mqFIt!teOH}ony0_#%ze(7rX?N?AgFrRb>JS!vC-xgB-{@;_nHa zz&C|&J}iO&R-+X~in6~UrqL+g46h&NDG$13<7v3aNaLYt;s#`W)8uvvh>BSw6nh!yHGSJ9_}B>aIQ^$vbE|Bm zDYM>(-6|DCR2JNtdT3xHW(=Nu!RJkoZ*FM`)}M6)K`8}cOE0Uba5Z8shv!G6ENG*t z+(E}A$lC9M!M~jLw96PtGPq*2f9#D%7}cV5+9JvhvMhmjWj};3>r^q~+v3cEXak~o zPof_YYlqQ9_Ylg^loG!my!DY$EA&Q`Eu|uuXA_aM`?_o%>+|uCBR7GWILbzU{nAyQ zoSq^_i-q{F(TaE^z^t$^}M-j?!CslYxH021pkg5a^G zWf84XBK@$H9OGnkm>>hUH8@7$$-Y6rFq;Tw2iFP4VYo5fo?F+(H#xUSp4$IhKKNO3 zg*n95flW&N202q#s|Q+eRxQ>DAB)nUSF;C~*3$_7f_e16{_PT~fAJd%UkZlQozdfJ z_h9FkU+pT71)eZ?zcgnow!9s;UOLz_A42sZ4dD4;zEXNq-z~$m6?Eho53ueY{DH5_ z74>`k7aTpJ38On#^!5~K&caKA-`x&q0F&OJ+S*ucZy&k8YzV!s)Twsg98b899DMdI zvG~IEFCL06PHxsa2Pl>Y+B0)DH`uxIc64;)Aug$P{gf)PEs1L-S**xbNST;kT~Y2> zuBr9Ni;=*8@WvfF+#oXaX>e#j{)i3w+Kan z%%$g1@}9;q?07i}67RB|>3O8s0r1+b+eXI@Lg`CwBQUB%*7%w_v;6l6b;6JzRY#*S zKv^Xw2L0~AL^SZ|bgb$?75(013Ou3TDl2N}ESGE-LN&D1imW*|w?h-E!)LvJ(Ab1y zR`S%rRO~sCxd53x({J<4q1}=qCW{SCwVtEghMMOb*!Pj5!5LtGfxMod*^Ijn_2H4J ziz||LEFtbwV(k|>(YC6_BL2W{z~Xq7a1U1On5ZadPOnYbghHmfG|I8y^viRKY@+RI zcIRF{v}va79c)DB@RxEFcGr5Q1)ap|ZE68tBZDX7?wS6QnGK%c3JKi5VC6jFN1cGw z%5to5=T(Y;?Z^>t3^S3$sH_bF%KoyS9UX$187SC){>>*g5zkMf7G7~fWtBN^inxlX z?9AM5pSSDNUD|SIE!_;`Uq_vX29<}*Asigj!frc|%s9IJjFy%bi0ZalZ!T?ZUE*pU zstS`&Eg9TCisoeB`8_%AY|jM7-4PhxxHQB6*K>1RGD6=i+r`|WJ^w|AzxuQ z@>=TeP}nk(CX+@=FKntrgVF1!$Jq|IA5EdFNq1M9NYw7m4srNPueVD>YI$Y^v@-?o zap+A^wbmUG$&i^#O}pPq7Ax6g8Jz)*2TQ{KW%m;p4~U<|aHGS<9kbOk=zaj&-4dyV zK7aN7{(QZx^s=$?uu>O$9{94qfbygqwao~stUTU|SHb&cCOn@4_sOJyq68{-=ds89 z)tMF>DSR;BCzH*wP?&cma1Wf2gs{<3e-Xotupw}F4!Y=jZGvI{I9=*uzc&>!FD>Pb zV={Y!^m30fn7^fHykS4(p@h&e^1&@&-wp@mp+gVql!6F5{&qi=-eN-M*&uG^2Jrm{ zD{g_G@Y>4v+P~7}Wjpcm_ZcZX`)UNUxJ1t*j1{kY&DWnHa5=p@zmlg5h|5#*kT)3} zFXyV*)|v`<+@6`{1ngY+Vf17R-N9#FaE4DAy=^WOxqdv?=$f{FztaF!YOhlGIjrW| zT8{ZHS-S`1T9+=%e2iwirENStEiZnw9)vDx^bk}pW9fhg@(Ivbbn9Q2q6^cN>083W znDK@6;Uor@fNS;AYiiAst7LK*Cs$V4Q8Vt@Qa0@m$B=E9I#O|-ujhKc?Y6Za$D1XZ zwitb0k2z^mq`rRD4^b&uIHGg1y zQ~NR*E&{(FK+;W^G$Gq~)zk^FZCRPbW>{E7?4?T#1_{C-XOz#r`aUWq^rswQ3Dy%)1j9l<2k0w*@5OQ-T*FOR2ZydL^) z=LTKh9ZsK#7L*zA@RQOW=}5(zWbz9{Ld>Ehta*x@(#EfOly`@3IDZZbL zKgsxXJ5FSlw$?6?wDL52YH8{Ik?Pze+CO#Ms0a-=d0T#Zt3x#v;uD{>1jiaK3+nAj z@eSfS^#3qN3m@d5?&U>F-=j9Oq;s*Qi=^kkN(YQ{T{B}xsuhIx;NFB)T%A7FC*@Gp zW@K3|3;H>DUvF3JxV}GMuGXRdYX_{zu1o%wWlHNtjFlz!Qr*&hcwCL^*C;fM!r2Xy z+2TV!&1(dRN%E;U9VuAtIn(2vt+KreaHtrn(++afU*HJyj{6;aRon?w{b}f6u=gP- za54ZwB}YlAL(qgSPDNp3%a;pUu`{qXR&kd02jEAi4ci$jz6Z$wGC_OZU3mW8X02_x z6lR~)5SFM|31H5$?;m?8Fbab>cZ{+e{qElR&gM*7x*@D}Ve^*qp9z@?C}^Ybz84DUOAuN0;)FMS|M$Skc@eoKs*CKtv%U#5ZJmwl{J_Rovr~ zQTW)Xq)V%!oRKa{IB4gqY~edv_eC%rN-Xrqz!>)wE^H=IPzO9{;@(8y>(*|=%zLjC zz3iOE0C@S9F%h@1W9@uhNg$#IzY#FfAj*qNO&&4SFB6ztVl2-vGu{=fS_+%V%92ZI z_!I4zp^{1=R4-tj)$3COtop5;?59dA*p_G+&~_wpyy$9ye%$~jmfa8$BkEq_s8!5S zf?cDptfSmWC)%0gU#)6As`1Y1Dy^KO;DX-?MS7d~bNAGE3ulh}V$CNBypD@u(&|MK z8U_0gb^^sGLNY-0HJCNL=$fq=yW9I;)V6wfJ@H_kc)^iG(j+|1eemVu9XEvIZ1=SI z=npGO@+T;LVVgoV${;#ch`A*w9m!EPV8lnRC`@rLILWtk>ymL6ocD(5(3HVudtMj0 zHr@PAnNI&;?ezn*LU@MMmO;5`=;=m|Dp_c-C#Yto`1Qien{|V z5%BH&=8@%#$@8A7sn3%x#9;qE5{Cgk{4?rcq7|VUR|`~G-`~*~mW#ftDgwxj((yQ8 zIDBOOS#%;FTtPlrR}A%<34)5&Gw48Eq$+kOP$Tr&4Q5CrY%jE(NoTd0$!1}jK$7So zkKcL%?~Y1Lr9=a@G$ z;`Nx(GX2SLHTSYHU%q1o%Pi1&VI0TJaOH-agxqPknh!p$>UR81RYQh1WP4XZ|K}4*Wh7vIgIn|tu>?zO;vSA!=bKUamv2cDa!`Pbb;y^ZOm&FT3eJNleP($yrZ zaN>Ac`jh#3yVcM1Il06+S%ivc4}wq0CrgjWI<-bm3v~f4ot;9s$WM9js>V5)V73n@*I#yT=Q?yt{ApNnw$oir^lh)CwE(v4xXmX4MEfQS#A=37kL>=Xu`-HijLenLHcSerz1%K^09;uVm+uAfAcCmnr>DpP z@MHh0-p0Jzl=sF$!g>{Cp9`T5;%>Tmb~AEsD(v5WF}_?8T=n-f!l@K*QT~TVnAP-8 ziRolQH#R4NfbidMMp5xf*wP00;?`4zEu`a&gSM%}v$gwQeNW^#ZHv$41si1)O9`K{&W^j@1%k95(BBFE(im@-T zCAOv9O><%2$GP3}lP^ys(G{XY_SB@?KTM+FoUtU_%_HoGY6h!Z^K&Zxh8t|-g{^$I zcEU1W7In0yLoT&+ji;B`{o}cDmy%8@j_gNV1fyo4=>P@EIk%FK?z1YTq`M@A(LltubR6;NJ0CSqW#C+D0e3DOE_>mxM z?H1Ov1s3ALhM`m7zRgB|zl5uU?+W*|ju;9#cGM4MhvTZOF5)h}X4kdlMi;;KMyh0a z>OcepgsD7{Nk}0auXO*~*4JS_*y+aeQ%f+GA@M?6aYu@)@9^?$yO6pa;=HKM6t-{R%`P&SL-d4v(_mm>wYd$pW@42TYL5Xu$u~7=MJwU3-G#J`#+Y>vaPMI z>)I44#T{B4iW8)`dx|^3-QC@xNP*%WJb19;Qlz-MLvgp_TI9`jKkpyNhkfjj5wKo1!Rn+M24GYfGB5f6`#z>xHt;e52|KAosyRI0I?wL)=<7 z;n5~qFxK}W3)rfcfs|R-v)f%}h8dbApjo3^@Axt>9?B3Ghkmc$%I^7+#LXkcS+)uk zQuxrnInM3jWV80*>~_CU7oo(jYr|whoAmqI%BrM>TyX3Mycy5P)vt}Gfu}}08w~a5 z-&$0|DOeiXLYnU=$6r@uXvQ1Ju`>2X*}Ck(`x2MiSqZ9ytjU|^)@^^IIP?ui3GBsj z<`bBqeanw4@O-o*s4n6{XwgF+_z&uF4*wCc{*3h<4vC$^>{_gOqJBFo#UWW*Gcfiz z)#tV*>Mx))3l!6%?HY)2Wb}7@vOji1mB0T{UOswnk>q28g!uB>ydMmhIcYiRNiiK( zFE1u?ux4j+T9QmDQk;X8KmA9i!Ga5Tf6I6w3kF&LlHt(NQLg}w;Ip6$q|1&^#9_q# zY4JWgO+=I45cE6D>8?14bh`V2fiObgAYB!?;8rFwYEiSG`z8`HNS5hs;X&Vm%ywr)`X=FROx609e+t9vxvuY8ND{cbh znr!0GvAUkON6R05+D0Z>I)UVP{}Anv9jKewID`pn9GB|;$?_-NNKFq=g>)~-aw+o3 z-H>w-Lyr=}dY=EdPXaX+22E`p3~nWVQNT!toERQD-+8PwfBq}BPRZDd4|@I_7|c`5 ziKvTHYmL|FY@Wum)J|1$r5TdZ{1lZz>q@Bm(I@DX<_=|q57zJ3C1#2NE@!@R2t$hpRMB)(wj}XPYbnwPg@Vnm~{6B8NUJTn(h|jXMnQFN`!*w}DQG+ZI91RdNf}2_7s~ zggMmXk|bQ4eCG?`Mn#-=6_7>xI4kJyDO;GJChF}1kAahu9O-wx97&;iV3 z)defEzs}^!)HTmAVv+E|mhAR;0A}aO!qT5C6}*)z?efty_BdY?-qZZ1n?X<42%Z@{ zFw6V+UBJ+s#Fl4X-=HZ_ad73jpethE*8a?c~JCF0&dGMfl>-6}1?Mh1O*@YDN^ z9ZCqsmpWRLb(2N<_UQ)hBv!D*P)X{gsG}U8>^)%hB8u-&UL^e*Ao*@^sHoCkw?XmP z^I+z}5SvUf(Xy0ol3djP?-CUcZ-@d~c%!yXxS^(MC#0&{%pl;Oz?Y<=!E!1CtQaWt z5J%P-Bq+Gxb|?DE_9iSJUpq$Q7W=mMcDeDkiPdSOzVTgq3Dchw>Qs1jk^CumnnQ@g zXbs2GH8AkCINk8+TJ#_1E>-|)k;_lCT>8rzgd_wu6wK=1DJmYT$K!%t&DFX!z#XKR zPdpzBO?1*6i2MC{a=^^H9DJrkXyN`V0DR|$gh|4>PxN^xem=n9F%+aM{!sjy$_ghv z(EOC{My)_f8AAmWi@qY&IeVD+oLD|oM$#=h4IoRW&(q?}!K@HhG zWW?Y|67(2skzq+C{KxI`bSuD&Na?2pv6KoSk_d9%?w43P5!6AgN_)NLKsPtN69r$M z@6=inlsald}>7Yd~kD8#fs%EyppLu%&nW@Xy56N$< zU9Vchbd)5-!8kJ*dhnNmfx8Cy@^qLpycEN}MI;;Pzy7X&MhD0> zt=H;F#&6AU+ciNCy`nYHa&@lx22$WVNorKuZDtg)zw}k<-^th|4vV|HyYt?j58j^h zUW~YP;DKRgQkx!}{#c=f`6(G?wcfXF(szG-{;pQp@%ZY_L74fFX{Q_*F#So=RB6)q zc{v67dA{&)2u<;Fa3y4sn{oEG>E+8B9qn|F8)ssRtHx^0Rh}L${p@gfSvYRuPBeFz zPOeAdB~6Zn$77){`VN%?lb)FflyYj28$`nQtIW|5|P3)$M(VYYm*=wPq)LvNw z102lc&Ge+zuSdLv$Wf2ZJ6;xA&5*~2#Vt!HR_>;P?nR%yDg?FYVbRR$#DaV&Hf$sY zt96F4t-QxjxW0jsDoT=wVp}SickTmIn^S`4?YBD=FSmVtVMw72L+<$fr6ZLIvoy!q z#wss5GUc}ZyUR}YL07F$O}7zcI*?Og&YG`=K z#>;>qWzf(nNU%j)Qrsjffd6qhYCWbj`g&GLgvDole_T(~qb4>z^;^hx<6LsQ?=*x9 zJ2N~iFy!4?MBPQzXLcbWe;Bj7H!>a{LpPfYQ89&52)B=HBCRr#bkr<~js{8sYtn3f zscrJm+p9aSq~%i^A|&WU%=|&tS)&_zJgp`Rt_+uqijF=eU?$e$X|BaaQMi5#S?0-NYv%3|$i5tVK9 zp15Iyc1nLQAX*t0c>GD@XDI5euADiHLW3K+Z~=QKDVbuzaC;C|B0qE8fYERmLM;fZ z_4)3%(O}EAMYhw`F1F;+%$Bdy*6S4FDD+8Z6$|c8YcES$Z_a0TgPJv~x*Kgwsya1c zqr&{QXwY%4L&Hv2ETi^8JQiqDN_1;G%}4<@%M&EhELuW7VW$!|?l94tL3Mp@q0@J5 z;Oh9e;4wZd75C*v1zC=`rHW9$hi+NZ$5T_X$BsxykF%Ht8Ucx>{t|6u%5%t^O z_4{|XcMTLzF)=g%7V45f?On)-kZ8WpLgy;&H(DHaCg|H1oI=p~s9Cfnbx_FbvH!9t zA5`KnCIEShhNHfxeYjpOkNO0cO?Qo3EZQE{O{Vr*DJfE~e?xO9*A{y4T`Wc*RA+*4 zSz%&4gS;rM#{UgPEC&wz8OmmD{)%>*t*MkKhGQ;UQiTpLqpyl1)C|b1EU&52uZ5I! z)|M17=2n_JuS(#^Vhw|t?AnT;Nzo_VssoekzDp6h${~b9`%bu|k;eE%|x?;ca zm6bLD*{^iL6jYd)oeopDq7+L9(KF4D=qb{i`0A0<3uOsLxTqLy8 zs4>9g%eMUq3_ad+|8~FY33JI9dK)AXqfy-D{l{agYU-UIl~Cs&pZE4GQbF^~$0sLQ znrYk(bl?>;55?N!Cud+|ku-)fLq;`u9RBs(OI?C2|6^sCv8A>MS^QUb;5-dVHJLjk zUyjvjBr%f=6dwIko7}XMh;~MlFNoF&=89Fufqi#e`1Lf|u-CBhOm%QAAt`Ypl)6VC zKPlz#J;BV$UAK3Furl&AdaJ9ZLaALTP=9pV0yhconZNyxWPDTAGHHzsW;*TX+7`$O zqzD!F2H*iib_rSe?6YeRcQvd>x7E7p{{umRLBpl2vc0{o4%%b_v~UP8)AJiV=Eh)g z*lTQbJ377Ov{LIu@bp~gFhTsS!&P1hsV?-p9jJ1sSe)l>P6y3LKu|!77Qh*N4{vL0 zPg5?@FTXR?4M43fFHf-U+!6CuCmWMLiMulg;z1XAZo%PZM(7W+Um@k{)D+pM%zK!3 z_lBMRk9|>i;S#DCKnMZIwqZ=OHR zKbQ#%3zsVAiMTug!t|oj=}(A9?1*oqii`VmoHNxl*IEPZ4kB2xJpbx6+Soywrg0k} z^m4>3-QH-$b#!96&Jl#>G&S%&GGq=8vR`gFTHEP#HvUYl=q%0=%WFckGb@$il*I`k z#%mHLmd5#SE2)`V-8W+zbwUL)koPqccnZqy-Q=omn6nuK2=(Z)7F2}$*OuP-b?>Us zot?1%yIw_&kAHfQN|zwn$oi5Fo*lJ5-I3J1Y!kgXZ~lG_*-~veNz0F@I7!BEP^{o_ zhc%jcEUKS)3hB--v09_p{z?WZCy2iS2EWB)D9QGIgv;=)bEf@=;eiTb98TKNjxd=j zqDUf*rH9(uZEdA%Y4SESebZ+ukeT-MeL|L2$}x|SJ$bfn1D91g+Uj%!UbnFb60d58 zk5)*vYoUZZs?a9T*ntH&xcCJ5!MUWk*`^#i>y2#{g;k$b3DaA-rDsHL9R8dwAz&J* zs?f90kkRzHk?G(+{c|*I^*=gYc6)3u0FDx`XmK}s@p@LX*ui?7r68Ubk_TW=mZzuF z`tsB|8B>KT&3Fma8j`Bf_t5L}adO-*vzWc{d(%OAC>|)>T#8lCIPHTM$0*XeH<6|6 z*#`av)(xH??kheLj~1n6=1a~o;F8oA&<`KK2QOWu)}u_FdeMA=w~aOAFDwi6kecpW zq-G9<_;M^2l>n)ih(JKdS2uftcUH6_v$5zDztN%`EiL^$8-iTDf3ow&EH*V&{+Fdb zKU5(ISFQ`LS$RtnHF>5`5&K2O`^@9=-0pd{q9gOvil(4)6Wx|JZ?|Z_w%lPs^kMIq z1*>MY_LswWN!mQg@v7z^^w>dlRC~%gsVHeG;m|p@sRfu{+6J#!g~_D+ltPEgfjB>f zFP|z-FmFwrRQ8>od8ERYgamv-OtMqUp&Rn2qC$uO9Atv{0P>0{~)|IE4SM8f+~Nitf*+v?!9%pXy|jB znhx{KB#iIT0==YSk7_+uDGWN!6363(*6KX%DocjZQi;M6j>@CSOJu{5mJy6DrNDm` zAq<TGikATQqPdX@tlA<;wPbL6Qxhu&mo>0ux7Zg09Wy%|k1t_uZDeL&Q60!m{n{ zb$;2LtSGL61>2Gv$9*9Zb33+0`Z09)EJfjkZAuk*m{?fju~?HB21NFS?SS>==~~C} z6>R`~FJ&(S9>R9wqv^L~3LHIc38MY+f}`<&j(4P@o~PTzqrl!Yv%LzQzuH|p(=5O8 zU_9V}`}&PP4JT0`Jx?C@YDEp+T9q+;&^IOx>v?BU^~>~;TKFN1 zA?gqvXct2L4O_cM73GpbzQ8Da)~K!y-oPrw>y?Xos5O=HW9}Prvl@_AiY)JwN8|3< z){--r5v`792)gG>c&DML<`HrJb^elHwoYz*BRYai91*YhtGlck;?U2tU_Emy`h(Iz z>3@FLoXKNut1wfY!>A>gY?c@9;bbt_2`1b&k}QAC%4MinzmcLQcv=0Xz2_*3#vG^KIK9vr&JX70LT?TU!( zRo+mPVKK|jC!2Ds!l$EZ@C#B<+$b3@#WGtKpELEV4lv*;%MQ|GGo}--|)Y42}_J2z!GKnk{NJta8Te8^ca%| zTQjaM))=yUL;|YzUP|dLu9S9OjW^w9>1jGa9d&32nWA%(Jo25k97fZ&v@ug?SQ=%h zKkR(n@qC!;nhKP^`Dqkuc3ofzshsi8gzTc?dJLM^P%=);3dr zjEl~CA0W7B2rDgP@R_*O{uoMy|T8} zW%aI#dw$+nnfu_|r zqIx?4lS$b+PcMK+Jw}0N0g6DX^bA_>>MS?rgId{g40evjY#Z-x7KblQsL#1p zC)M@&=($UNQI01-VmVjakXJ3Z?X;=H^0NC2|F@C)z5o#;lE9()5C-Urrkiyr`K55b z!D^FBeA~0<*Z{R##hZNHthw|5r%cRyYC23Os7BidC9Pohy}lZjJkJ%r+21TqUcOXK z8)foTx&%c1xzwXQzRxR${4f8yhiEiziu@{sPDq++HW=3dTX!L2k^Mb6DWvtJEv|&P zu0<&NsFn0_so-C zj_aSQY%i!~85P9Q=`+aPXy-#z6S(9P9K^3^Kp2D6QLfM^0v)QXqq9~KQ9%U3N+>GE z3@sGyMM3tJ8i5qqBGeTzK~;nxGZPF)nuM$~LtRZAah*_CRQ{v4Ap;-t=!;@36Qv-f zCsK@stGTSGz16v+Pdc*WC)4OB2}+eBdDHG+D17X@?eKT^l1E2U$lcACdC*IKTCsgI zBWwa;{74d7M#_}v%7{&+^0@+K-12vD6lEKrl*z*J`*OF+u*t6=303jwhmV0S#?Bvy zCQ4s;aia>Y#~Dnp36nB7 zJ7!tU`?vqs$-l;B^s_|!Orpkg;v{uNW#QV_gn&utEGZd8t(@tbs^e?Vx{|0Q%tSbw^Bd8k4BjK z%7X1eQwJ-u$E6)!E|88p=xhbnaES9(Tr87fsx~w8M?Yu_&M!=3wW&)9&56%rO@j%^ ziyFxlz6~!r0*_$GmJ#0*f9(oU-|i#6J(j5?H(xuUHI5W0>Q<$HT=;;~`yGY6__@AX z?DcB*3BXDE=u5kkDQo&Km&PD}b8kymd;7AD`Z1u-^>85!`%S`cdUIx|zQ@_m>#?;X+h3E$*ju6-pb#nKmeu$_zwC|sOG z(F}?Bx4EkRaInWQJcgF*a$=W38%9Tc*we94Bu{YezwLX4buGy&ooIO z6YwOLBC{U}0HmsXOQAeNHE#LY>G7V6B zT?xWlsD|H1OXEuq4i3`O54kh0_?M{YES5>(mJ9WTyOHhp6eqmQd$)W6^7jnj)FNaR zjo3gm*t?dfADmjHRV>eTVLa#GX&(Cv2)i$*x@b7+V^)NUON4I%(PNFm}Bq8mKOJp0N)iFaCMINcv@uC1F` zNm0s)&nM|CbY(DrlGA*<9ypj8T7aLuh4Yr*Kuk$bH+*CuVZ zU}CDZ5Kh#? z)D{}%E+DNra~KgEp%_DBYx|4WA#nG|YSDffWVkA|j_7uJdh>fv{Q$GWZGUPNM$Ca& z9fI}8)N7#^oMHh6G0i>y^GF6DG%$NiZEG%U$dRhl|GPgAy6h(sXN`=E6z|6eotz#A z-qZ@ic4y77;+|F5&opWo2ENP_VRdx{ZSH$4GKA5nCJUE|qC{6|TmvJnK69TtzX`g}%nneKo3qoL zg@pqGxTsIfmo(+_H9dIxtDUY#J)>Q({dQfxTWh?Aoz7Re(@#Wzr} zg4v#$;RBz9zebIys1YHM6}*O03%w)0!9kVA9lnC0$sH-+Sn-=akA!kmU@)p6kIa*dPU^YVm;9`u+v zA3pXm6Xr>Qd45HGH*-2q(#Z7#-~=cAfIziWvA69TJo4|QLp{qznr?d&O1JzcL~mI z?0|g?5Qo__KjyLky`n)j|iiuf|gw#h$WqrIuCPVWJ<-TYv(SB@~!Z4 z$w9NdT+lXqDR$-FYhbG!5>@MGWq`l(P|wa;Lpp0|4bwCd4%&(6Dw(X3??TTNtt$_uWXmBMOys8)UmHFI?Qdvi3KoSb|ki9K&_VWC)v8$D#3F(6TJ*s__R zeT@z%uMdZRN!Xn#riHdT6A^K=rRzFNS(=O@Ov?od=Dxo|RVLdaNq|l zFD-PuT#m<|8cfd=48~pNLO8hSt zVFj!>K06#FR_pfq{CK|+^meh;3o9VzBZ%o25D>T%x$JB1dK`~ES@>o_=(fC^S^hY8 z`aJgIi?9vB6$EZ@{fkW%N0#Moa*M!iD)cQWscA>xNpkZ!`PpN`CQ=q@^pe@me5S!2 zTO*?_WBPfjEk9WQYW@r#=|{3wJ+8Uoi(LDl*5Xp302#lb=6bEK14E*DsBNo+^2YDm z+$_3VI1Di{$JQobCXzUuw23KQmZ;m^^VA_Ci#T9ty6$SAWM76R^qE#7Fh)-mWk-}Z zpE5mA{EA29jTGyi*t^h}5PRREaL2a7O%X5lBR+ zmETIh1U+H0J7H8tWaJk8uQD^UTvk6e{+&@jee4s$kA8tscL5Aber|4HhnQ3`w5g!3 zdK!;AJz`0+YpOrN8y`uQe{HvyLSXM6p%saVt8J`ix;@9}%CDPFoHZvL{x+m*SCsFD zPZpb-n4xH(BORhU%y(i%dy9 z(^Ma!;1+h*Chf{{X-KI#;>guy7W>4ODSnW>%nK%?9?vC;?$ccn{Cr6>FV0u#WL#F- z98cI&Ql0+}j;K|>k%8;!lSMzr@^-7dmNdQPZ)NNeCMGSexo?HvLU82^o@Ay8H6j@? zlW~SzA)Dp-hc16|S=njH|1w_8)Hx3gl~iYoV(30jWYu&$&7kpC8y2|D$qcdSh882s z{1rt{QdN?t{d2Bex5>aUORHQMg&_J#`14U$z(I4!fxgXX5Su@*l<7}{4-dM|h-#Ru z)Fa=^H&IM2JQN+)P@ygN?f!IrFUO6UpHisT6&PR4RfF=kIOXlt%jf!Ih-!-qtMxXf z)H)!;NcA@~u65=UkKXj#;qV1XMF?nM^wm|)Cik_R=cKr)wP*Q)-@NS=2(czKmNq)9 zESe{bq4~0E+8Pi#bryd78YiQAxAOt%yb3#`(gCInVnQS@N7KU_{{{i5IF8j1PuTmqM9OpsZ z9so56?#J)yLslT25EC~cu*QclWfgZVLX7y5zxji#?|mnowuz?NTY6c`jRO(1R_AWj zf?wRrO3*FwNAShdta&{0w0j`YBIR2Gr0xUPhaZCGO&#LMG3R->zT)jE%v^-l4rg}0 zhUj<7$njlV@Fx^9AQKmlU7Pu`&bt+Q@g$dA@Lw48gqDwKa!58VX!KhG^)EGG|Q{tbcwgJ9Fc9uZr%=%{_Ydw0?Y zY~jK#d=T6)5Mq6#3#~E`Aa49%Ry51~p$ZECXMa*QDg6eWE14 z$&TH9J5?1^{XBL2m&P4(7L_)t0ESN{&`+yJ($#Mm%9inPI4GH@if?pxf>u{(<)fUn zC+B2-Y?=0Z8M%1SSU2M*I_3J`!Az3IA#ZPGWi^>2ct4x>dIP&F@>9Vj+&nyg*E{~f z=Ig((`m92nSpFioOtTgLUA{RECl5lFL2lARl~hKiC90Ov-qfN=cK=aDo`jF@8)?Stn-{q~s)%2iNYZVyy3=tA(y`M0uH+-x|+INNKKEqSd$z z#|whJAczU0tR4i{2)BfimTsS;;Wu}a`l5(<@5+Q^;T&}ql_|Visu@)c?g67C69=kT@&|E~pqWjA!dag_k@Pn!BIG3wuw|G1GgaKf zL@TDye9oenQYkz4h@A5_w4Y#+zvrNrlX_V zoTN`4hC!_c$^GnM>Q*!)V>5orEh%i1-;+8K?zRCP4~pIV5A;pt$DFLPakRhurE7ot zhcX>ez`L#_Tf+-@aOQU|cE)+yZlvVrnJy<@}7eE~*h9PL}pz?!VJrDO=l!Pps+^az#Q( z`Z!EAm*(?(%wnNq03?E`$REs@ftJ62{h(&ZgBvz4>9&`2k3#n4$;Qj%<%P!|#7eIm zDu>VM1;vDfh>iX{(5*iFRDJp#$~@BYLFq@(>R{yL&!{*UHX!jA3nlACqMV+{Uc$LP zOW5k)(t~74I#ss!I^&<3aHGnny(R6k$YT=i2DF3THensrsNp@*vOFS5xFNo9@3@V> ze2x@02dkee~jON)t%1M1kwpzd)C18++j>ALs#Nu~@Q=N{0wdm}qzeLDE&|#16z- zrw9a`RmreeimQ;)U2xiH|7RntN_-;F|>1Z(L1cmH;`vDV`3YwJC?GkTT8VF+il zPb>Pr)*JG7Bgi+?p)1?}erD8kJ~3JE&CO|W5rHthtiRgadDj4ni5z+OHkJ{|4})K@NL<^{BBW=UL-|% zrbVn*7WT^a*i?8ObZcW`1lE-w@SYcVh_f6I&aOf!`z7iw?VG3(q-cv=T8q51=0V`J z+$<4)>mVNPNN-)9+dwvu`DSKX>|#(sFm671a;PohtpSIIBs=5*>|QeW+c} zt-B_0Ze2p$Xfa()TWdJ9;a5nHVx%b^xa{2kijP2P5P~iFI z-}!SDzj$cp&zFx*J0Qa*d4ks_dg`?TYe=<;1&wNyxnyO{Jw(XQ-2amd-Wx|qvBtOd zTI5EKWVNH_Dizl5FLz$ncA41UVI-oP^%kWZbW-t}O1oq2&k;SjH0p2UholVTuIA@T zFaSIYN=(ZOd-zNg?uGs?4?!)(0}{oPgtr63>ny1*m*pRInvkdTNQnY(i^@8s_&z{Z z_tr4c4|g7~%k6%n*Hb699N{goAeSS<8^WJE6e$0}Km1V3h{aUPZp|$%_hCo3iXv=d zlSDJ@k`4QR|0k)zcAS^qf4U+R*xXBMPUSBAuyI0Y)&~!Ay7^Hzt+IumR$RBL1$$Wj zsC5fH5CMdnyhpbSkO1WQ&dqk#i#WTX%(N$9SaZmsc5MbYQ^f76@8N+Va7$vz;zB$Lfxb=BlWsw*-1W#cqUCrs~4iS81j*{p)-`kbg`h$t$S)0iMk)c2x|HQJ04MzI2?Qpwzors6w|B%|j&0Q+J2@bPr6-m_J z3`gqFM?ReC0|;GgZEcTZdDoYkos5Elx?poObv-&00QMKVScU@+*8D_-X_A4LF-F<^ zZV`kN7U;TmqiHM~uXoK^V6eNvAkHXLxdmn!V_9X=f-b6|K_g%*D(wKabLVPk;-C%d zv$_gbx0(!*jgOBXQY-(8`Zdfld0=mpo9rG_fTHJHb}+ksi~HkgI9dZKy;<#*x!LFl zbcMJRDu~0`ZBb`*U!N`3F;gZob8jto8A*3NXrEp{7A>_*QSFj zrCC4|K*3djQQy<(p@~v%gU8V;?@Oe~=#6Oom5D?S<(7FxMa_@6^~x2{ond(Z*Ol)c!}$#w=r`O>;e9KhI>IY^78b& zgF(KWIv@9khGh6iBSMe={$1}35Nvut36Efw*9%+aC*r1D$1G!SJKgzoJBi+2pPW=y z7M-SLcN+`9y+<_hbo{$?SvVL^8j%`u?BUQ^%qVK?{ajMUhMJ(cj@6x$l^bxs7LZ#6)rfHOrT^7q%^$f!(v4y{=a<*`=}t@;eYm64eM5UE zNhv43=1xV5?|51JPx^}pd^JX7usq=H)Lu$+VQ08)V1k>Vsv?t8u$qsL>#7Hh?N58) zGB=uhE3KS+t>sAw5{MV~a)9Evd5eQgDa8ziO?^004xDi-Y&LG?inUPJ3$W7~k4`0K zL6Xmx^ULL>xw)S#7ponio|Xct(&&U=iy4gZ>qiQJm~_jA3T)(zj5bJ|+TX=5bJ^%3 zKABVX>IeLvb`q?@5XRClRjytNqiez%YT~$HgBz^+aSXR%#>>~l*E|yoo}OgvSK0LTZI(DrgZUT7vAo^$mV^qqpL+YY#j^ zI{`MZZz2A|DcERciIv5*h#)lX7m@i3A*X?-vjGV!&d4|DGR*};;sV9Y=f-h^@f^Dh zVhadQ`Up9n^X5RK-Lk^U&crPBZy|DPSH=~MIE@zEny9(otipoa{GNN;{a*Ly6nVLY zr%95x%&R1;nz98yDH+kil8ym5*3pmuzK1V3V@rV%5rz|_l(9j=_WVsII!RLB7<`23 zSb{Ob19yiKE3|4t^#%ORX&w8Nj%@zZot-B)l_fYtm02X{m2<-gL#?Wz$1wB(dEmnq z3=4lq-4#j8NDDTM-)MsKe#{n28~fs91=(PCz6YUgkWE#+->!jzZWXgUMbug$Q7F+z zz5$Zoh*-0Kd0+aABx^n-Q0&5~Mza+q=YccNS_7}gTIGB3>bWLlXNU!~8a=B(gmeudOC>`1kPQW;)O=f$ z5Tn8+M>oVu4ceVCb)EdFK|h6L<0FoVNmjLZy(+(0-{gL%i>s5)bzL~4_Cv%CjYqvF zWzZRQ!S;9A=f1h{xX?<%pRcQ2SXfy5<&~bAx&;{8gT*4(eNU-qTjcw2Sv;%!ZsQi&V}^j)awuVR_UFa~O+>!UAnlpXDW z;o{yR$SAc1fue%}OT~ii?fBRwAPWN>tK({fnb%QY%O+pYBIdbYKV$G37O(TY*hHRn zv$0jc?7vMVizTbjYH0F_R%;-Wy<0EiZ>w(-0q`C`It>SEXQUv#?S$T4Xhdr4nH|aMqSY;UB`-_!7K$XKD@m+n{= zgT40<#sU4|=b6zsDbqaTH_xfeS`*o#PQf`Sb+~bhT#bv|&5JemUNqtRg9oW;**ds< z_3chNMYdeMd!~poW8Dd#Mu`-4G$jjErW+QjH!hy9Ct*NQ@u<%|uvuKt|KVb2=tD+v z9-+}-P2f|M6&JsZ>Epwis$jT^R|9^#kCxVL{ zz4H(Y`pH~T_XleyCnr|vYr+56SuX=I$OJ>_Nz!9v7QjT9;_>_U@6MNV3O-j&jL1xU zHN5$Fk=tT(2lYh4E*$Z>mjPmux`{2UlV3(~#aw0m;kK-*6DsC}onL_{;ne*SI6dW1 z+kk+VWMz@oldVXm(NS?)oS>phr`LTaOG`^G#oms%t~w#B%va?gt4o>xc9H)6{wbIt zyl4WqPbW2!kDJ8Le_Gw>Ghon03jkp+(p1^flR#QvQc~w_Sg6U$6iCG_KQ$CR)`~yh zY1?mMSxuDTYpr=)1XV8(Gy2!4oT(dL-; zZJ;0L2J3y=2mj9Rux~5~PN4|@gU7ebO>zISVpldqNbLwELRR}Lz0qJ3`jy2{_OrN_1NMkrW|_FC(a90N%kkXJ9DcPb!F+8t zkhVP|L_P~!v`fr20eebr2w{Xw+O_ph-`t#CO&34A!0|8@9aPR@4H_$GOClg~Ni!ay zqz+Ugd{VyP^U!g0*1s^sS&xGc(cq?&3A_$KX|`ow!zIv@LBRcri5EZ`b5XNz=JYwL zu5BQdfSZ{*)nodKNqjot)gnR|r3oC7=Im1}s}7_- z7qNK&zy&mvB|QhGIqz``r!W&bV;XT}>@8I3QNV60Sf={4(Eo)|6q7>aN7#mHO>jH~ z^1BVD|1H$$k;VogNFm%Ip`m(ySG%$zSv!30N;*29QfBVXR<)}2kBsh2oadz?VnU0W zn!I4yvJSIba75fZ$OEG&5opVLo4Uc_9*M(`INE^3UkOb1VAiTy?G#j9>+Abz;vFf% zch`*^SrA=XTIx~@`D6QX@4?1#fw}km7!DYX`HGs6oh=mbbi-!!U1zp9jEy80M@Byp83>A{YLW*O-yd!M!lmS<=}k zuTmIF)0?M%91Fk`%iMMgAH;M**;613a#2aKPY3s_-c89A`FgIcqzw2&i1?T(=o%^k0m5^tFy)N~m(k#! zDg{3gc^>gItJ8Ar_3C8Mx!uOoM6$Bz>U@V%0{-ePdRFBpR{gSlJ=S2&l2!pe@i5&c zBo3chpYFZ$6_q~+Ju;UH!8L;>JfHW|g@_jzu zCPAjcd(xdnwhr&xf$?RH=!mevkz=r6){3SdWWNpdT5O2Fe)oNB?(fnVea8!_c>wy)tOBtaZ33_Lz>KXiVNx@iWgYOa}3MH6{*!y5eks&?Yfn9wP$M5ogR0l`*ZV3;npPIoPR_>yG#Q)q z@DujfRqLjX7`9=z_tV$^hfx+t}K>=XZ6P z01YfGJg9T?xyc`;8*b39n)B=)8W&|gNSVSyY0r<>Y#lcMgDUzi)d7$n##;BmI+@ln1%LRLO8X6B6pNf%1oHqd@WMstt z|IV6&p6a{0ypNcYxxAC7)2gfDg<1nwKM%LjeH#vC(&16mZ9FX_L@6wFwzSz6#4pbm z{_J)A2ZvrzFXu-(J#JRBeUSUT()4vtt&9f{KzpR5Ep`V~MS_GGc&!sQW%I;z@$ z2qNmymBP(n@+_bsQUXgiVEt_I?><85GB1PU#!*#2zuV3xJ;R{lucr&03<#mm@f`rbj^^6$l{yJ?UnQ@`t|9Zdz($+g3M(F7K7=veMwFF*T# z$#NZ+NJD7A)k%<{A-6``io?M8Z`C9Ey6ZG))M7sU^Z+&7s5{yc#ya;YX>ZcO9K`Tn z;ZWTBRs)CB*&h7hoeS`e8&&ZC#vxm8O_)6=Ff&(6&3 zURGhanNwF5hPBvKRaJEcoow8iv~Wp%w3G`A`09*k8Dr03F-dUR&hnA67z{rz&1st) zsAu@3b0wsB1L&QSfbP^%$GXsc#zl)P1ltq2&hGSbT$BFd6Xi|MROaU4j`%$7Ow%qy z`@;6&(*vBp+)p|gnV_II7$xCpMxM=}D{!sO0beiR{>ej+!soEIlzP}#uLuP@D%*K< zf09u4t=qtO$#^9V=NDvXnkz0XRiy)@$i2#2z1C!*e&2S>teHTI)Y2=ZzNv2N?Zs`J zsPo#a(diyGF#~MyK*AaLW5%IaCz@tDdnB>qYM|qGXfsN8hBlUjWkc6FX_p@Ln$=Xw z052l5T6YOs%kWNGxrIx3nqHJJ#gv?($NmVvQL(T91xOY`%e&N*%G6SvE}#0H<2fVM zd{1a!Yl>UWZu!nWQjqdp+zFmPKlN)F$a*w8`CAkjIZe4wlm>WkH~M*a{z( znCLhClB4uZKP@$to0qpnyH-LK-zer$Tf-UF9%1=ky`P$x2SBr_+l!2Z1V&Jx%%EkU zv!*TEz3;s5fPF(s7pi_3cADXwTbEHo$wt$vR$MO zs~{Eg7_ibBMI9HyLTus|sr@F236>dz_VVN({^)z;_46(ErAJ2#s~ZvWS$ol}>gox0 zX?N1EF~?VAg1Wx1&RgG;h3?8VIhD``N4g-;m$W%K|-j2U&`&qI5=O z7i%_udrq}T@+~>etclE_nd!R;bDw}>l&fc--dv-M$C?k(qmql4Jb0dt4-nSK>n^$1 zU0l}I*212!FJhO>3}sq^4`p&CY?-7Ay*7Mhak?S8BplBCF^sOWvFV_LUvG8%8s_SmTUmjz-*cUfN5dqDe0)5srHHKHwY*;Sk7?&v=TE;d?@jer*$+=))ubH=^{LI3-E64=%nGygu5alenk9B&Rcu#-Uyvd6qs;(vB zuC?u0G)4J#i#3XtC5wMW%=^AuXUOlfujC_G6C)?D#&Pj(vmSTE%XQgYk^u18sZ@mo z@-hoY+trjfh<+YwTQnzGhVL7Byxt(_0aHuHf56a0D#^U0I z2~%=Exb4b1O7*Phg4XY!DNDr0tU3W|!|(%Sf(? z&ju=o=B_{fJN1B0($#&2*ykRoa$-d=%opV#dh~;-4EmFATrEws6g8Gb$KWO*k$d8T ztzlNEwt~ETKL~dm`cH|8@o`!@x`CZ~N3{3h*dPLk=l^B4@_`_N6Pm1h(5CoY{9cYD z65wTF0ezVN`}g5_FaBzy9sM6Y;~S0(n4q-gGY7hOxr1o>^a@lmgAE~rH7D*Oy3Nnr zX20S%6A7%rts7+JWJdT%clClb!Vy-W2*jNHQm4mjF<(_0RshH!y1F%^h1RHbs+3x$ zy&Nk8L~_grIO>$Mx3*7=-2q_@520U~>xRQjq>Y{Rih8Lv|fXS`1L3+LtdgRjEmZz@CKGA#ASp+=%BPZc5p;l94m52 zlk>l=U(*hT=!M`=4BLY8BL-2e!>w=W2QuLpSq1pGSn^t$cr0*F?0EAsQ~7Ph)wNl% zP}MQGc`yp;lgPDq=K{V?Af>5;kMIUVSwpYxx+(ddKw^;(`S>-WNUhk!6-^3(j3xU} z_8s8DfNki1@E1tCQ1p!)IoeT=wyAD6T{rdZ7}q^OYHVmR#tX)2>bJgdt9Vw zwo3qgxcs^b#c!4n=m?zubp*m~Dv8XT9KaO51~gh9U?5G$(O+)0Uw^!C4D2i^5m&~r zBKm5a7x08`#>1v?LJB_6Po=HTs5bXXnxO~9ap4E^8-7T+Z|oOQqlWCUzK>VZr&v*E z$Cx+MDmlqGG2z_PIow}VvvJUHI=^ka1R%b?$&_F56|jtia)-yh&nLJK}gPaE>Z@jEzcw;mQV z^=Bd`D*MRov-D7FSptd<+m6OQ%t+?$)5+S*?8#lU)2;O|yx$WUWQ$_W783b%2VRzh zj;=_qMnze@awyXex(;~rh%I1MXj~(qsf_v&w)4?oN7w}lBgjmf*Z|8W+pTKy01&j9 zGjm+oRah#s$Zn%iIy6GV)Mmv5v!owX-KV`D-8-accSR~S_v;=-xi-B2W|HRjg-;_j zCfqPE*ckY{9AF20oUvgu9mOD7m1rztv`~B#Y>$2XGWmo1R+&&bz>&(2D}CqPlwHx9zfK@2k33OV3(x`SyRG zsHF4{tKvB7eR|HcI~DH$}J4* zEkCR%ipy=tP-o0s@4^c+fY*k_Ld95ggPji}!Mtr1t(yJ~eKKBHMFWZ=X&h{<`NBDS ztjN>n`7Wv0}tc zPfr0s89owA9Pkb->z;d=+pBX@6j-oyl@9G82O=1L7AMJaxdOys{s`IWH*3wlS!`ai zV@%s&NyLAc){?N;8R9ar0T3P$jBI`6$o z7)EP_Ye|X1-u!vWYKLTtfaO28XlI=+h*#Oc!GqvUjNVJMGVz^d9qLz_}G+(h=}-o3@73SX5?@xtDkS@ z^zC`d1x$O_J~lfQR%FiNB!mmvLfSobkp6{d#Zpj+O~9sIYSTmwg^q|t1}q3s1yPrh zPOM^Le4?Nuwv>;BZKAp`Wkyc!hoZs{{PrKEQ3t@Iy!gAV>XT@p5&V>DkAfky;uDfr zII$o7rIS-uXz>k*tl6v-p$Vi^ZnC00GIH13>qOv}r;zv8c5uUu^a7SvG1I87#5^T;1-gLP>_lNTQ-%pHl@lD^6*h(!P@sYK6E5yU2ZL2_qrx1<(+__ug#k% zXD%!hF>4E-(+kgkADw^#tLEw71^zh~LM$xm?{?d%mPk*5my(vhX9PTU(lIA7A=UX# zA7P}^%qe2MG>=cbka-{&ES2>Xzr)2|PsINCTi}vgR8ag0nW1-PX_@{bcARSdy{Bo_ z4j5>FUnEs>0gzrnmblVr4(}l-p)V2yLixYN)wt6Kl@xKZnWqW7VTs);{c04wEH)h{eSZ^afopVBj#%><%Uh2 z6J&cKH|j=r;z?8DuC;d`Cm+ZgqtHr1f?43(C$Oh`UQT71x}SIFOutz!c>DuRi93C; zxAiz*?KzUA>)_;VlyG-`#}yMIIQh<0^lq|9-N1!uM z#m3fdvf(YG^k10{4AFu)MFNd`ZhWJWCk-!TSrZw!=sY81uZ=PvIp&67YP};z?N4;{ z-rs!|ziC+}(T6=;$E;;aQK(HG-HDU)aUH?^+wiLmbTTq=!6RTGmE7w$CClNM1y{B#pWf{h6CVyZ#&n>^^$y}>k+I)H!Sy}gSA%&>k#x*yG1khv6 ztI5NM@0yRb>#+#29i95jxkN}xMn*=!z37=Yc3GP*i0CBJc^1De%?!=J^6@`ilKSz& zNJdGPtEE0SzBxXA>|X^ua($f$>37d%H4%(7I!9}4HC|*mI{KckrsQnu@Mo}`ha5;} zW`@s`4a?;pC0LTqX6G-i9*Dwzd^J50gLn`uXHajv9FFlASul_CK!cG8gH4*CR2bFN z09lQV=DKJ8k4<)~jg;E`jb>+oo&TP`t}e#ue7jSnr76T&jzAK`rj1dclU=*o_r7v? zJsBC%AQNEN(qCqeD}X7qme>6>yRNeH?4MXZg&NK(YPk7L;g1f>vszr1{g4C=6s32b zNfmVrFaLmzAQ?z7P^Gcb($dSzOEp>!Zf-3d9UTJ$BrYW-CE*MOV>rzq8VjCqy&##8 zTLIvR3+US&t*wLmgVo#j;`o3NPd5Kox3;WvJ|2*)BH0jn?sl7ZAh4r_-j+J`92XB) zCcU((EryDQm%)?N3kH?@ab^#k8g2O+%mQ{TD8ZrcuT5s{&>qd-YnqPU>gs9|v>3`H z{cdoF@q2=0_Nm;S9yZI&yW3lLc?Mc)W(4BXO4#Td3al*?eh^AfR~$lIZkOln1x2Bc zyRux~xeZ)#0fapBeeC5aotB+TcTWK|HdkYr$02*^WotyLHVSot)?icZrFLSc4w${N zj*PmK3nW5VMyLufdf+@&1ctQdr+#JI=G z0?;zG!9lNJC`c}7S2#tltc+y{kmN$hyD9b(R1!fBez-=@v4hn%FxRAIz1y_$Sp34^ z&iHd-C3c;J3^jcJ)^9ds>-e8;tDup%DD_vB5h-Z0d3;|Y7^*J)C{zrvCz(?3gD#BA z^NqZ=;i*HcE&m}O`1a|>v^DJAfcl7t#a1PWrwnmzGjm1kTh(eKnBP|yMxicJAiyKC zL3wl(A7fGzwG_`1TKO*zZe6kv!`H4TsqhZ zc8Yg0vfXsp?w1YxFFpu;GZlUl*zqE|XfJcqS#v>Mz*Y1Gsa1o!gnQF)`#j zD69pm=&!YrAQ?rZBwArjhrIY8B&Qn#vB6Cl3Bs4*D|>de*icSU>`|cHEG8xmbE43X zU7x3PU!Pa;y`M{b0^sDeCQ>@1$>6aq{B0(C{<2H<({y$6-pzWyN>xvWbofTWzu52- zx+hAUR%tgd^5O8FlX4JnRkT;A5o84yM+(C|ub_QqMA^joS!A21XJ3*1S#}G3m4({7b>Vf>me7D=_(cRrZbX`1m-xur>BAYFKcD;^t|?G|CzL7rQDg zEpb>VmYe*hLW-DQNuscGkKHU8cH?gJQ-W~INB}NDB)v3F_}tvwKqPXgZ6jnbcpnHa z3d}aW*+evG$4?YrPX2Hj5Ywz1d|5`QDDD8T$He?U-8f`sy<%3Ax4#FcxwEw$?33=S!-X25$ z=Hu%FCP*%X7Ey-Q8$c7)m7fBlMMckvM2hGU8#U=Osh7|-+y~n@TAc4#tWE^LXwY_4oO4AX;I9;XNFm}^^OJ^bCm-@_{y0p65 z`UAbs2FXdV5lI~d2F*2ONJ~My$ecYo0ez0b10q8A&0`CC*>tfST{boiEv@*MBxma0 zX-3|uvo*E!LVCiwcV*6;Ot4-}Hx74}e8L4djAh*cjx$M_sAP)hAbyyY>L`d5_7G0>w4-}>anPwPrx^?*dA5K_y`>3PY z=!CewF3}iAb9=(vH$S#USH86PSJ#)fHWz&Fj~lQJ{Z7WpatF0`-CSk)jb(cHEAsiZ zxGbl~5$~2aSbWDayBc+_coMsfaB@MsyDTmb_LATqGC^j*;;`xFcRkQ=}HnkW}jpweR;4D_SJ3RHNy-BodL& z$w6A+%cLt)&+A&PKQv#bPx4I|#aU9Z?7`pIB?qn6m(SH$jfhxUdj_*HP@V5%9)$Y> zr7fd`ABk~dgX-A#P$t!b_c$;Qk&qe$s+{QlISga{M6PZ|#dQO9`9>%6CD{nREmSCczNlek%;EH<=?BG-t*q-1 z3HT63>I&K1H|%H@kEF^AnV=(x z!@{tED*xBMncY>iScD8?)H z%?h>euE7x5g79(91ivC`2a!y{1Vj0EsND49za@2gUIF1#-#$OKzCM7Z%*FAge2JX& zgRGAf92OSmq^|Ru{>rHZ)1v55TxAI%4Wi*$M~7B4`h9FbW#p;LFRAHdqJ&EEexD8=(@@#fSY>_rs&c-y=_T zD=(wJ9X|__Xd|U2!yv3%>=Wq+>3mnLpJi>)#su}*+yn@2(|)Dm_6P^kTkD{NF_tWh zX*D<1be}AqEG@Nou@b>X0?j-rn%gjCY>m8-X4rPt9o1PdA>D)tEPj9$da-Hx=MP+% zfrS2mpFe)|bziLiKEs}Q2jaE@UmrWKI9ppvzW;O&wV=C`@q1`WtzK{QSrBk{#X8wR zn}NYEaQZ_bQEJm{-OS3Xo)LgzaLnh}p85R=Uvqm^Oj+z#W=BRqs*_&jQ5xPZy*rqG`DL2o4VE7!XEuCJie<+#6BgyEC_P_7L-fDe>EizUL;8C_YlU2NwDT z>I2qV5Hk|X%&$OuvvJ47p2JUR9UzIUK9k<*^_N!~K0U5}=RTLRTJ`YH4Y^A!eA|fJdYg@;&a|df{dq>A3 zT+mUhL%c`aQ3V9@$)6#1O&<6x1fyVRz z9PAhx9)DF?$GO?`ti`j%UY%X2tCk5xuie44-YiqVID_)EqCAssEKagcN~C1AO8o~U zChVFW4h}j^_>g!C$8U4Y-=DjzSphRtJKm}Lqb;V$BAZz=M0`GO%e9+0;&Bp^`4XVL z-+N1`&7`>UU)<(z;hh?4E&IF4unA^B7ubQgxHv+-2$lst$KIFc-Vd{Fnl2ewrEjjr2AKF#Vay}!(o@R-~-v#HG(qb!xxbF9sH4|w%VuMknJSZM}7 zWQR7{^G9(|#+px|D##a;Y>X*$)XpEU1Dx%)rXLUY2rU&k7uEiGtm6e}ISot#L8tw&RA{ghg~*m40bkqOBw|xld~^B& z$WZ(_3U{rli))tW|g6L>xUj<(}dOA+}C_ zTihv6VwABik^*kORDiU(f%Q+YLfl1!)t_0VSuJ{OnD~Sz#6;(37Xtpb`_bqly3?Gk zzkfe^cn(EGR=dHe&0IrERU~|*(=PNM^b>+}!lQIB7Wo>{`yQMaYTvj~qFXBewDC$7n? zlZtLGw!K%5{}Bj?Nn72IYnv%3`oPB!oJ6d~xxrGP#VI9`Q0K}tX+t#T6@EDQKfDyM z$w#j!xtKYPh45rub%ol9lS6A^RYJfg-+>|w^f9-Vlt8wCYeefqPNIyOJ3F(ekVU{! z;+e!~E9`*%SK?qf;rY)8Nq<0{vq6<#bw3%Xs-oLLS{=-n$hO+8s_5#%*BJRu`+~q~ zsXt$v0NTjW6?Ze8bESZr_9J8ho~W4fbgfxSePweg_?;| z{ukhCh(sb>YqCV{BK0GqKz51N3+*Sd<9-r5jJ2wRf2D$UiXjIjDAb=VZLvRzK#s%z z=kav8$<%v$IurPL7x?uw^53=__#mo_ipVp<%1S(iou%F7<@f%W+g^SRR-5DF9Wl~U z*ZgA7I|#l%`wSv}qI{IDLrIEvKYrouT>L?$N5fh|ge^=5iD6k>XS=-As`5dYl#`UR zKg?0JTx%#h#kikoo>~pHGMs*}Jmi}yg6*UL5zZWjb+yv7cVT~(ksA_+NkeVWeZyE( z?z77(yEqCZiOL)FNlzp?YYWD$W;VvUX~ho<#&Gu8OsBrM#H7_$U(kWJSNV&Qk_19C zk$yyGmAt4S^{`1Yj^kpr$#=O{|667p;{6l4XEMbmu|i2rb2KTg{L4VSZ~}$w3Z4z@ zsqr(s^#W=JMuPSP>q3QE(&O0R=%~||@K-SS+g4!U8=$a$0WP$?&%3cWJil98kr5?T z<7~Vm&fwo-Y2j?kX7qa;1~!pvH~j+Z+s5-WEAddJ;a7+l)}!$utlgxz#E_|~zDd|+ z(5P!5GKPUbyOIrq3%^-UC%w{#V?YqnT~HLgwR97mS;GsX+uJ^js{;w2rKke)V@}|^ zCAjKS9A_(8R60X{uCYDfBp@RbhHnohcJPIHQ3n*YoG`OUm4kpa1@nJviWQ7{fqv3I zK`)c5@_ zcH{59X6?JQT5af8lX*Lk4;xrqyXW*9@P6FEExCS_(T*0q{8lHB%hASTZEgY5MYSv< zs1Wsuop--prekCYIN9-uD%-mWn+@Tfno|vasMbsc?K!WmPRIJ+-9=5EmR3&JS_?O- zfCik${dF+9bm{Q0|MTC(3GB$jFY)j+vI0 zY@kfupQt)^Kc048+56u8=j}Ej7Csn z%O~iqubnNwBVTLnCJsYo@u{@WbKRGwcl#9PL8nlbQ^)X)eEYJ=G_Ol&NSlwTT4GqhEe6?HipDk@2Nd7659 zdTLrxpc*77v+P66?<=Nap~e{*a;qBiGDAh8p#uK?p<%{814SjjJL|CdSyNagiy(Y# zafHVXg3NwN?G)bf+-cNoaoc|G8huYBn!J;|wU@^3J*_pP^TNgdrR<(Pg*o&LAtS}a zAWY5xZ>stOPRVY7%{1p*;QOY~g+RNZt7_%G|H(w)eU78QXtJ^Jalf*}-b^Gzl&P%j zgkr#LvSZ-ex)o}@T=Sga$6v!5?Iw%MjdrO}9HQr2O4W1`EWjRC@8#;1_GP-g;d6xS~E$=1WOZaUPRP?wdU^I=yHvmHB&M&W3+#V_PXB z3r9OK4lg4!QOYqcK|%oY8WJ2tn%hY(G*%?Jd7?&!haW8-2@S>P+tJC#8wusB$Vqr| zb#X#W@Y^Z`wF_HrD}i0e{xb?=5*{;cI=j0B4hgUY>B^unlJ| z-cb?QRDrL>%t_JL{Zk;%ydSlZr2E+GMBT?jUckW&DFazdNJnfj3Y%LpSyp((;5L3W z{MlZ~z?Jx{n2I&F1?C9p}A?K^; zYTw{5$IfQ&^MTOEV{5NO@85Le)HD#Gzag4l00-;qhWHD0u)D0REI)r6J@0uC9GTw< z=(uEv$q^fU|Nl*hmHT`fdQpxMiI{;bDIslK^SGQumF#j?pKnI%$5Pb?4DXsRcv?!0L z?nf_2(kdZe&Hc&z*hsgx($rm?AvXlP{X{fVy!76?NXm;Z)A)Zreo9?z0MGaZS{r^+S7}O>pM0 zESyNI&}yq`>WED?O(l1Rp7I152-^9`rLm3kiJjCoz$DQYO)=KQ7*j7u)bPO=tn2nJ zZ@t@}3k5a@0vDDGp@F+*X#S ziPu>e#%X{4OZ(b)?D<$Go}_OIGy3}c02=DP>x=+2a^kmu(+ ztw*tqfOnQfke*5Wp&;NA13J{hdD9Fh2S>0xqe0g*uq6Em6?z8G{ypf5nfNXfEVo0J zFGl+UzRr=HW|8VcaS@Cr4aYyhFiuZuB6Y=@dcJ&|ykEJ@S=`5*Fp;TB1m>9YiCXt&6%$1%NL zP33^NOvg-~AD*SQ$Lw%- zHVe#DjmmmJZm4kiiZ{b{XklYT(Gv27;WOaPBqazUCuu+G zG3b?Kt0pWab6QUyQ#?015953_?N(SlUtUk{QX^u<;U{Q+3R9c&!opuj2+7M7fqf5a zgKbAm?B4#h>lGr>MOvE=#V8L2gDxUuY9s!JWam%GvQja73JCQ7w%Yf&lBYM6i? znwa&W#GN0tZv#UqlqnCv?Zf^lW3C&rcwqj zDtft^D*77g`dVsgDjIm>OtAZyI0b%)1B8ZJ50HB0rKR2^Axi!~k`YAjATa~AkPh)7 z%?oy8gssi<{dE2{4>xAOS6VQn_c;B%f0?kL*HIU8)HWY@moo3hqj5*r#}Y=B`{8IU zq5`@HeW#)%W%FAO-9^`=6EdChR6KRLK~3EG#GYW@f^Ll|-8@aE_n5jy@3+TYPS$WU zLGg7XW&|5E!Yl4GV41&vco^Dq25fZHwl+30va$f5FEL`PW&d6^9n2Ic0Xo<3>e>V27D~M|4(ZiHOyP=m&4N;qzouh<0UwF6VgZlwS9a z0<)|(YHz3fp{(6*C2Y(DCXq<$n42mjscv`}S^IVbiEF0fTxbka`OAO=cao-xfyQRN z)zIm1d#sJ+WQ|=q?00b)+xtH*47~|SkON6fGaO(^P{X+S>QfEKm^R+w!6A)O+UC;k zqUr-bB39wg4(W9~MnWf+w|<{KPQhzbSJ`C4OP(JWgfYC`#s~;(2Q5@}RL>>5uP4(p z7r-)nRE25LY|0>b5PLm6u(QdI>G$5mxt}>4K{V@N*^_w*HvQ6%$AUPL+}Y)yj&5bO z#yI%Ae*5aX(&n|vuWx*O`h0i1wXDhFR~+b{te>loR5P56@~%}>xAJ#ePo>0&x5fn+xl!Y4w!&Ym6nLy*p z9KjU!u{%cQ!p4Z-eVXiZ_UA?L5%pSTU?>h)KkDB#Dh@nZIpA@AJoUVf0OSZRR7Ibx z4~q*jvv1_44J*Cx6TSR*lWf=MB#D5%=n1HRM?zmO;;~pe=aF8O9O1e|s)_^OzA=Y^ z%r2E$UvBk&-HZ@_<$c`+l0g+MyuQBH1%8|{6LN>)2DAD_jS%iz6o}mu*3e~C%=q7U zzQE@;?;kOF6}DWSkUoR?tipOX739^U+-al*$@c0?cSo1ID%3U7OUmJ*d_|;%ZY`>d z7g362o6+MD62=WlBu9I(V#SL~PKqu5K$b?T0S!q62`b(3n>BE1V?GCofao_u*#q4q zo+mT^bTZ&hx^o(gLjd;^v zVP*4+w4U1w>4#j(^q3E6L6QcwbABG{)bt@Zm;zJ-5&PE zmhg%fPReq9PA!GrR?q5s<8Tlp0aCI8f@B)Kb_hGjw+MCYWqq2_sd?g8dH7|Sk7?|{ zr*Dda@D|o%pWbIzFN%gA8mZd5P)?%gIe$mfDnQeD7?9W_`*IUQmMY(@x?M#5@dt`c>$l$O)h z%s_LU&38e)sElWZA$!nSq&YnlgQS;SQobn?zuzGD@cKO}rD}hUY4*r4ed-U=lj6Kv zT8s%kn<&aT!lKcjB2t5i9Yt3}#W8!M+|P}tB@i)`QAemMwf$nCROOW4dUMl!7$T&x zk+GI`4TaR1V=t;^Q4=VuH;7-|fG`}J9$Fo_c3=Hj% zs@>{v0TuZ+a>ES3iptHdL6S(#nB|$(qDJq6nFJSxG14&lz{kV0n95XFQ!~SXvYP@_ zkS~@*gQ6MHOpP>h#&FAE%rFG?^i{y*R#paWyxzisr4MWu5Mch)<1jP9=mFHxXv($#LP<+%M|zaS-T81oL+>U@YuC#duf$WY-?B5#++ zxQjKMJu9dUM2d*#GR7w&V^sK~8w@7K0G@UV%XDxbp+@@`{9wSoaVZ5dKSIe4KxQW1kE+Az9DEoExrMMVudk0M#T?#n)od>~)$~6Y&&%jW#KLr0Sy`PO z9V!)S&d$!%7;E*$;ODSteXOL2!{xg%Rgf7ByYwwJ&j=$aauX{40b^9X@S>8XxdAU= z%_#v&7aHMo0qPLofm$vBtVlr)F(=};KDZ;_{1`dgjL%8P#pZnz@Y+hj;v6TEDx|Dm z{!FQ`;ZNU2)E7y`$*|>3hH|^^M>BW&Dt3WI1{Fw0kP*Quuv$eVvdhaq-K@a=6lr3k zNRkEVVLKCI$_bgDwWPbBYlt%ru0~6~jg*5&^lz7SkPp%mDH+mAdeqiq_9$QznLzEs zHOVjm?;c1`8^Fi|IDqH!;+&Y_T+R5y6(;2}+MsT>8=iK1S-XGqmZYXKU=MdyoY7JK zv?={IHfxAf5%sBWu|_Xles~Gpejr*@3l2ub)+5SB?z=+)I0v$+^fXLNk~juC0IAa` zl{@^CTt(g(_=kdJ#3m*t0{oMN2`~O>MKu=oshJsMs8A`8vI!d0ncylAL$FVoEhZq^ zu%tx&w+~5miUv-90(e}>NoGNL^N$>}Ikvko$lTs3I~Yqj?%?H;cYAN!knNtaB8B2PTh?sTITViwb8{|eH3T9jTUKt|(D^Ck_b4Rz7;OmNo6YBl`h&>NdyPyXI&63B zy*M;GgX#TmQ^cRIKdozj20l*(rWWn}!gE3<0Pd6N!k z?}@-Z;FLA6;9zA4n32aCQRmNOAE071*zJe2+dVhm8u%^)wp$)NCk^V^(>2{r_FJii z&8|tWfh8`^K8FGc z@PtDG-$zq00qz+5TmM#^(>(ZhK;ZJxvqC*&7Lwg)zpg6!65jJ(C}p55Z7oiM(QgHf(xjI*RKm{^g%XWy zClMp&$KkHdv2ZF|X?qttuAXNoN2Ex$Kg;<~s`X_NI_Tw?M;0Uzu3ecQ%q<-hRmmdH z6o16>YP5M?!)kyuuNZwbx3A7TcbVJ))d}%Co%I^_$gWZ%<>qx-swVq%y1G!e^S>@{ z04!S?+Qf{V_V+QC5QIOhklG2Y$zn=mrLp?oKLh58+FC}c%>PO~6%W8!Q$pt~Xlg=l zM#CZ}Kw1XQW{Zp4^olA0=@sMjEAxG~RkR_r>BVskb+vErJ;Es2Ds$G(4gu?yXg!uZ zP^45I(P@x5A$@wU)t@nsX@^3lD62ONGxmNqx58|G9YWlWbMxv|%hd+0#&`OjijLXR zRZQm7mfulDGBeoH601ql?$z;BtVW3p))Uln0tl>=g2&{ihZXyo3M}Q|zEclj+n8n< zg*68gj^jCE*>^nK`!*+5`KEeB&i6;iQTu|1c~vf?Qp(!FfJh~H-|Z3Lmh74_nfYBO zm=uE8p}1|}R^ib?5{9)K)*JN$0uFzm+X=njj9@VsWEO-R!EW=L8P?ADPZ+4H&yEid z4+ES}f?<;eK=qWv?QCLX6od}^;8fEmL2Se10r_6vD0(TmkWk>^WCk!%*s*}Ld?WT* zQ_+(PwS=f&t^Fk>n|e_?PbE;|Jm`g6me38@WpmAhf6jR8?gX)Yb4lb;Q~;@6N~&`U zRgEwT2N#GuzhLe8e79EtefWzoh7D5#1c!bg3*N7M6MD!n{5to$@g;N9uuB6^M`U@r zgQ5CGfUkvQEg%oR<0GlUAbzJNDmNrgCOpI_T$`J-AcCgtp}+#pBAW62Qk@-}>7PQ6 zaC-Y)|F0k5b{Z}urB^t9B0WYdZj5*4P>ATTrIpX{kLV4Y*JIWl zdM_U3)zuGLw4z}d)51Wb6K)NuvBO7|sl?_}DPlR1vt+9{Ws(%-RCRJIaT1GjB-Rxbtrp<&mUsDa_k7>LZQmyk%V`6XFEL4jG?o`C`>(2=HCO zw5(BL*r>Oo%S5>4>k+pjM|8aMB%5_XV@2aWYjaXHxFpv1a1OSQ62!l3*c_8N>S`FX zQYI+f0XzW}@gGLydLp&>Annz4b%rf=+RDnP3c+rF50!H2%-BzTQ5PKMUiKTi!YL{qbMhCOA4jWyh^ETuG zi!?0dCI5iPTpw@gbyW^le~s~lZ#~kzI@CrhCgf#O(+Q<$;jzU(7f1%Jx5;*jh9r@k z(t3SnmMy!#ZGI=gAI+yA1k*QE`uRk|Bojksc;YJE3eU;424Y0$cEl{P@LM6nW%G z)^DCzw1i+5D}Nt63AL1*(Rx(e{uY}+GXuTh91>*kn<~86rVzFb^LjanU6#de6{P8l zT3C^qo?frp#~rwdzr$sZWUyHR;t{BLFrqOesOiu$YT$cDvyrs@oxDS+Qv!jzA@V!0 zbN~Y5aEXWx9X)|1kL6S*AOMnF)#-WRMy{fr(nTR~& zzE6Xm=WuddJNMS=O@G~n>o)(skJ|TmnD(J`w`&Z^dHW2`QIOrlXyO?0{gX1n6Pz2E zMA~?18aiH*BN|&It}Tarv>)3vFKq7_BuPh zBOf-NxXl=@+}$yUs0_PNOr&4xFhLZgWQ_2|Z4}RU*9fa(WUp;vULL%;awH9nym`q? zAIA0=$*1=RKWViyEott-Sr%cPZZ|$Pze_z3WbOatt_sVh3H)Bp+I%{H|Fsk@s~Bk| zmdw)wL#$8aghP^caBv`)H`8+A#w)RozmAWo&xJ`)(m8CGfO-S0@rE#$p?2d|oJ4(SWrL7!DD>5>DunS?W2AyN zt|>shwXtHEAIK)r&{=kwuEwHc2KSkUVr_a|;xEAMJK9LQ!6Nnak<6y$cxTU`P_RX> z?S--8|F8*55txZl{K>Eg$=~@ig7yOxnp+W>^1Jikcwq*5GPp>)m8m#|OB%RX?8xsH znAuziw}bWcV`=A^Evw%QnPvO$Y+2NQiowrVDhN3uqB<}JgC6+*cB3&HLS+5N=cuh! zC{c+zxwwFA3Ns9r9LpI_Crbm`FGKW(1JX814x#A;u$p2@ltQ_3-E4O~0vhnjJ^H`p z^M+=TnLb!EUA9zgTV;>e z#cy^^t_e4LvM1Z-WY=Wdwrw|A-zH4)@&%SEY>Ftje|s&&m)#WHno?M9>V=a1Gf)`N66<;W?vd^ zm&>F+(p#R9d1*|@@+M=qp&&Dk9OazUg<^yV&y2AxX8CwQJyF!n#54NqY##Ob@fh(l z3te2k*eCTe3mjb00ln*Sb*MN~!2L*=U*x6Ik(#Td|*l)=}u;Barzg5#D8nf!77s-$U>Pz*s0VD>VRu1^-KzD-o+i=5*&X`@80>tU$)ZWWUoFI+o5X>-i!!9rc1n+;6&sgF;ck+DBmWOT+5FcXX4s%5B8JiEV#1C0OjKB4{ zXoawG*z}EuVg^`YBR<)P{efZpBu|yb!f6ynVXSyA@gor;qf}yFrMj9U6Vw2iV3THG zKCfW;OAAkgA)HY|e~`494cCX~0wT@c4a$M4Nja~iV@3Xx{FP2Zvs$ZZl#s&Q=ChEQ zcAoZ+q-je8jjPH4W|$SXCkK$(KG=btmKKPs2OMpiMH)9~0Sk<`cL$~4BP1%Q)y*0E z-|#s^YqJ(64`{~$Fg>KaeiRrxnhlZU-Na#_iJv%F06~&tWYAG;Hms6HL)~EiCL<*aI3!TzZ~6I?tBCs8jNiWdF-lH zvIbeQq53%`3SS#bx{ljIE;D-BwCt7RVWY(Cj1;luW<7#ntyKR%vQAhH(=@E*OmJpb z&)~*FGe^5~Ns5ZHgMfy)ha^URGz@xJ(f2r_ORG4m>u(>Q{d z)fKoUA>(X?wCgkl2-BY|WQ!*9$t(Db>BZ$ni~-M7j9 zFX>ALepYAM_CRqcg&-5M=SmCI8Qh94xyV;yQi0g1ORPmi!c*RT@>1I!aOheo3hg$0 zb&N^rRu|z-TNqs^GHn5Od-jmIN0~v3Z&E1pJ@>#+xreH)D(qm%&k4&RR@*LeWAfRkY6fgnOXH}}#yWP>lEzoMk`@}G_oOB?lW@}XYY}9Hpyy^K#{t9O z4voUGaI`=Ee=`kUcSrL(-)E5|(f&rqBIk7&Vt|q+BA_<1{u>9nAw!Jz2T2Su=B&64 zPw!I(($t3MY$X5FopAHbvzDse5uVXwN>!@HV*gsO3{lZx@!buB#ZUb@QvPTVix4*i z9Uu3QURaQyFml*RR+~NE=8+=VPO?lZ;fwmxe@I=dZFdd|+MzI{vb(EMXBCaO%tA}F zuw^4H$9gmho(Cgd9FH-8;S`{`>>nItmSrlGE9UX7tgMXIX^}$g=g9NTKqOwz`u^E~ zm`4`^U4f|QTyvkGf6?Cmd301yvmhVe77Z8-^>H8#!0SRxH@%4Ppb*-hrz_+_W^l7Z zXBVrT5u(UK4qq`B?=W=@nA&y95$A(!TkVTQ+IE^HfZ-hPr=>v-ur3tg9!%fg%*77q zUykORyt~bY(U3}^PLwLRczAdymWp8b@+Ftcp4cBdFLjn9u+T(HRzV_sOQAdt{PlTq z&A#*PunGXyx?K-69AAEtBj|AUx`fa7Nv3q^Oi;*H!YeciQ9ThSLYVlN^x22OW>lKVCIOdOr;C$W4XtL2;ztNt%Cxs<5SGP{d z!>(f)*FSjwC`d=8RZtqFdg4IH%j!yZwHz9rw)zZ@VvMK4OcUB4wWHa~VG=24MUBwo zf6VgVxzCZL;?6xP}ujwE6Tw5RE=sJ!* zg}YX<`7cxc%CoKWDb!;nd?>~PVEEwW){M+>A_ueSuU?#|7^BX@7d?;=)L*RZqWreh z`FKj7Bv+AMkdh*D#E_u|MpFNyQI_y}MQj;JOP8yuq@F7)$BQzj!K0?VJ-`}5$fG}r z%gBMc!8Jf4Gtq@cLaURfY=y_%z$pBNw@}p%*$~`ol5i?&<3+PiRh9~Ejr2-MTEh^p z?^|@BGl*^6p;BN);&xACC=R%xo+jP9ZpIAWlXNcMUoJite|EuiLzV}L;(g8A&S@1g zQ%IUgrLqB?gmpQ?QkX9Ku%u+vx?|Ue>MEd0&rPD-7SgLqgyIcI8pCO`HfLtoH z68b#k!SK8BPK-{$^14J@jlb}h1lZSjD@x7eIb<|6G-PCC6qGB(x??I5{U2(GYM>K{ zNjUk7o2Tglcp+!9L@8#x0n&RI7#KkN<68(f-WItf*9}E>B>fw~dZ~}KPZbavOjd|j z@y*`;;{S^Z0Vo#DN7@%1pdhD?ot?daOvf1LZ z6_KV3zssK=bNSyBlbUOIj~y6SeC+!y*GnPNy`&4CndvNHjzJ}|9N1^T^iM0LqpBvK zS_uA}L+U$)fOt%y8fnUq#hF}di~b~Cp6en~Xn!itmKqeaS{6Bj=8IQKBis%4I^^0` z;eh(g*w=XIybvIm10JQHeiK+qo}D(^6^J5+*Q&KJcG#CDM)^U3Un;_LGWI41_%s3x zEaT2gi$%|=qu*3aJWIGqI5g51G*S|HF`VAu2MZtosojWf3u7_Hp~)1r|rG9DQM-)^^FQT5ehwu3N$iMNpsZQOgyNoQo_)MrqAyg+OOP;3+}g z!2s+e@rF)88NJANBcX46<&HDIRtlb^&`ccF$1z6Q5t~WI=N`I0-l+3^FoK)sZ-Lj>P6Npsn9ljFcaP{KS=d6J)75~bRWgq7 zDZBeA8}KI!ee_0xeQ#$j{2n@Jm`@{;prq2;uE{}PAbuisLzqh&1guRS2|R>S=lN|S z?rZ1SU-^PRUcqmfM`Hx?iQ$D-s8_*Wn4i;&%@`C|WJPK~s)3@&VL^T?|M6c+j5h2% zlQ0a+b!fPyFb9c!NlDj@zg{7=A3BaH+iURxOAdNcM=J9?bHQde6a;x08u+C} z3a}M<1WM<YkxbeRjI^lt3tI*o0m&7DCNoF&86#_Gp)4m z0=512zHT|c?Ua8fshJHO!~B{&9om2RIl47UyP@Nak5;v z=072@8I+!m>f+)`l6r}1^j2}VUH8%X6wf+0*lb&u0$1Do-S2t@xJL(Hia;g zij80jU`*~sQs;S`{wUY?y;Fbe23BqPY|gh{@GBsgBPAr6O=`+p7LZkofQFg-11iw_ zT|Ui2$U%NbXaIh|YGqb^OJw+vBM{rxy^;`8G4oo}ND)|ecyf^8QbOP90>&CF7IKC9 za*oF_U=FDyUWyP2VTBOUgBQj09?Q+9rvcDnfyVjyIgp?f9ejCtnYopUl;iHP!FY18 z1C<0W!aaVX6DwoD6GO&=;sGkGG}YB7fHDj~!3A8ZfSmsipDnbGejqHfA3so}%k^0o zcnb%{#l-+w__wG04^NG-CB$(CM~m1r*%E3PgU5}nj}s;X zxe5rKd#0|V#E-{=k2#L(JsiS#2w8Y5c^3_5o^R$^?3Up!M#=>mO33Wt7UjY1#WH1u zG`9k!nSU=%zFP~-EiG)$%<}O~vvE&bmnCgyx7hMh`JU~US_vV&@3x|LmPlio_C+tp zl>{4quB^3kpl&~$LqYb56b!qLl9d^wuZkY4lA*8sZGF}duakrh@9EX!qKi41@0YCW zMyaSuHG{;LWg%%=b-rJi|8W-otfL6sX&R{b{5Iu(j|RYKq;XHi*cwmQOKcEld<7!3 zjgwDKY94~S-+H;aZ}^AdOVs)6ejTE9J)ie!TT^2!KgLMZ6T~J-zlh4@fkw$PP)q{j|*EhwHar%@oUu|Er?h>slwsyDDewYLMwZWea-`IQv} z_vj2uc0@Y}+^^i+Qr8%ofha;sARj0xQDI?WGc!uaPkI0s-PhMwT3TA=Re%^n*XIl& zFmjTiiODIUALk~Na7yURCH~*Faytc}g#I}@v$nQ|s)3FlFA-hB;D>?OGyuUUUpg>35P6JU{+VY8+4kYmJUOAQ%Sh%lMD(kNo#!ILfb|)pELD z=LDalyC1((g_5MNmoQ+#KQ)eH&>q)td?J~8>wf}f`VwV*>UUAKHJRVQ zTdLb+AWw7@phW_UOr2@lk(L>AHyrk?G84FnDJkLIA@TB6b*6X!@)M1@kLgI0{PRGV zCMyX9Spa{WB^u14+AZXF$gCY)3#|rxDFrJlN?Ca%F`u1ZhRUAI-4sen8oC6N zN?pEQQ5(GP{_K9^a>*(|XwVIvflCdU5)J5t$)U-ZQ}lnHv-jB}fQL6J{b#LtT^<&I zJql+w-~jYlN)cqxBo{9)qVde^EaaTS^R1P`4}f%WDLx$sNP0QqBwtlSnYF*GXnKjF zeo{qc=ZX}fz(A*yalXWc1cVZ}*llbGbbn#|AweqMre8u+JfGr+(E%j@l+EX~KLS7i z?*DGAtpb>!>2kyh^4Ws8^~MO{XmZ$ak{=_`;UElI`J4g8+E-+q4ldxRXUvF@UQMG$DW zabL6jNgDIHFyYsf?hQJ~6WzjH56pw_HS^-${n!!zvD;R%`*VIe$(#6TLhvz)U_^1H zy}GIeW>FmMs9>oZr`^acpG*b(M42hBJji&~&tqHMIl*6l+56AU1naw}n^Mstq4-dK zDaA|*4=aF+Y>^jK+hr^GCXiKz^*ypoOrkoWUei+dZwtuyc-k4Lv|vDOGM9~F`~h2Y z9~6LI`K_z$mz`ICwP)(wXIZ++Yed-{gru^w9|B}@$xyew4LqxJKDQshZ?N{`R(UXz zAnEBp!I!=6S6TD4OeSHPQ@PA zw*hwdSgRn3nJe*?`CcHGuqN<>m!Ia=3h(Ao9Y2cE#AlGsZY~J()&+rciM^q8){0)Z zj!~O-O}?z)jP8V2ehpv6(MsJ`R9IZkvA-`U3ix+hl^&RN8A>V7G_Wfwj}ArmB}eWS znJ@*#$fb8xSQsdsUBO~!(XMA#6ktqKQsc+E<-e7KeL6d=?D5Pg(BH1pyB^)QUgGwr z8&i^Cr(CedlLCM3z(0*L-A@U;`~f(*{PpzgD8DZJ-={vF8it8=8ch*i4s~Fs`R5sN zq6-(dQ}p!om=OzmXitI<+~PClH%j1FlV%zc4E1(lVR4Gj%l zUBq$#L!q#u0-n97wUt{?5Nz?34>T`gS={~>8W%6%etcf6W_Aw>|*-n%d!7!@WvoP9f9GnjO`0x9+z3ezeSJ*9qBCav+&!i`nN&vb0lY-7&)B3!r7i;bz9ycG!*P zWX6=te6R=umd`NlHWxyIHm;2BU=U`31DjGjw9uh|1OxR5cmD{RK)|0nCp|xYk569I zB+xypxVS-#jFS~3c2Hu^u{8lb1buFGc6Mn?kQ<{o%7d3*T+MY9H%$cnOG0`0HTfXr z9DxOsZhMjA(72G1)i=~thhazuSwa$zTcepTuoF#C_m&?kWglBx{@&Z;M)^6czi#tC zPClfa(*|gr6L~^r@J!Nf=XH$qwuhUg$i&1Xw?5vt{P({4r>D7UqF|{lzP{(PH0AUt z_7`%pPe}?|ZqK-oD&u^%wPt+_{xWzBgBWbuJgN1YK_yv$D>Vi+|2uEv&Bo7%b04OS z4G9|+R{(z$6ymSUu_7}UE#r`k=X0|zCoPS@V6Lx^7Z~*FqhS`Tx7$~bl&+w9so zrjg?zeBIu5u(yA>WX{}cvY2XVZV|ouL8}(~Na@P2c_|)KbzL%hDo(Gl-r}d)pX2#N ziJfFVFw5vsQS>CtVtY%G#UJ%T?l|$(K+rrGtM2@;?3Sl?#T39#&u< zZjd4{Hpq)TA<8xH^~(LD`C;F0LjFh6Ln+h8jClwvzyvTPFodR^h z=b89TzZct24BRt-TbBQNguMH~yE|PT*+Qt24LxEIM*P3w!&(rHk%h(4``b(J7gR!S zhy4-sR{xTa&!W^Tk=MlkNq`oPka+U?ktf045s8$eb{WZ}<8}mrfYuG@TMRlaHo$8d zUQJD{$J3%TN{7T5l&MtcOfk-q8B7ot*~c*Ba7;@>(6_Q%I74a#pRfm5`+-E*OtGZV z_f4N0c~lZ&s|1X|Uwqt$KFFXR^1y4B0QkPvK$#$oAOjIa2c|BhpG@(|5bKbuFiD8P zVf>F~zmuaADg*Z$6j&1kpbnzqJjD4$VDi04R;&y0n(mUh&+@2|MsmjhGz zj<24ywA>%}-d(Q?_OZO}#gcN0Wh?BIO-^^*5Qx5UY!NCmc|H@N;^RroON}fT!s3Rq z%Pq--wqpUsO)5W*r8L1dCtQAD1kCPGcTB^P?MYy~Qm2w44Y|cr3oLqc-KmJn~z+WW0 zXyA8V_i;<_KY6Z@?{yPG@%xMQ{G&;kQ;asG2^5Mlhpy1l`v#idP`Bs3aNt+8j~&77E=zYB5Tj&o z0$#XOSS1AEP$;)7*UQMZmvHRE`P%=wm4^l2S;&x(kd7v@9~SETTsPWXxqtOV8Sofd zJ7<uBNTuYfGPqhBpFWxHxt4sa-bWpF>aWrtFEKN;jO&!+uMRcPg7snY87?8K`xo z?I7Ow#Eu55LC&#`9!`wcFW_@U-kkH{bhpokwWtMJNQCw(5ZL4T0KEOe9mU^`YapA^ zQ!qq{iQtq1nkMkgJrxjIHH?o`zDqy90}os5g%8sgg4#p+>WuqR1VIY~x&)D?IZV@$ zAdUN}Th*A%@s#3ajgh)1btXW|S(+mP{~@;IaeO|0FAhhe^!{3+CIXoXksSl=6Q-f@ zZJoKMrMI2qe%5z2ISGB zpjLHF8-jBJ8BThIJY9j2_9ngVhgHt`6w?>FI@Cj4Y9hs7s72plQHY+ZNCVDBUoo6M zc?Ws)O0xS({O}ZH48SOSq?4;m4RdcJYkfn?Vkf?*12 z3{4$OwTBY{EhfzRGx%1cP9MbyftU^0kbzE{!j}Ss?d^tPy;h!p>YS&`AroVkF$N`t zKcu!1SQCMVo4}`ymzcoflfn25sx^T$4{VJSzC*0ixL&t0R1iBmH0fg zy75cj#IR8SCMeyS%0X;BEORVPWOp82E01uyV19Y{1)=n#QLo(buQ zObj20<~*oJ41qCopSFWy<@IymSe%6ee%EsZ-P0@^Zcn6S#{v6|pr^;y4F8(lR1%x0meO_gufIfPh%d}jHCv*1;z!Uo5zKEB}gE49DB050Cv=y&y*F<& zo#{_M-zoY1PW+<1gd$$OBJv}`&NGhANUB;ZljSazOf!#*Xq>@&itvA-Rv;1?bRR*5 z+4P!R_sUZlI_UuH1E=EX$NMG7z~m?Bv)8dDD{Gh*D8gdFQn{fTI`z`5WySy9a&1339`)@gNff>^hJz)EE2>&JpmbeGeb{KiZx`^N zwDB-7U>5tUG4)FqMcq6b$$E@Ms1_TC*LMY-nem7ik^oUNSE1Y}y71TmVK^S_f6;l) z-}#niC7q=xGMwW2qm{3&$Zhl#fB;qJ3b+^6JSn5`|A9h@j+@P%!I!1@%ZYO+_-iV_ zCF|XwT@9G+CV>w~0}yl;Jo(xt=?W0VgS7o#*8FRVIrCCIJ-5Gutoo-58m1*Iu|V=5 zrpF0;zncY316w;g2|m7c@cRy!(V&aaFRliIfB~92`3ko6d;Sz$VPP|2@OP2)_dA1+ zyHH$x!=V@{<&ANlFBqB{8ht*&=Y?JMhrkJE1R5DFz=xaVXy|!7d_@XYLD=5$>wcyb z#p>#+5D|&Ad2<044aPjdVvZ*o$iBg9j;i&t<8M3Cek$8e(oJmRf34aXG~*cZ$SY30 zB>vD!hRrbWgqDOu7?^8kBU2Me3`X^_bey`LDl*&)KaVaVx=056G{Y4|Tw zhfKo0s6K!l%Jl3c4bizejA@W%lxct)S0=h-WqA-Kpe+duWLJ0_mtUxfY9Yyef;+ zezek4b_qvgAvCJ$T2>abB1&}S$)!Q15XeUxxx{FQw(QzzhEx{}K`EhaGgtY>_>_C1^W-p1OBS4dFl zdv-!@BDk`qM!&;prOtPEX6rS+o5kY38pip^&;cBTeg7mZm(Xd}u{&n(6k_9C*nwQZ zZLGC~ztTi_C@L_RhIFzs)2r=y4bt~tjLB@WkYi#TaXxwB8g7=?49mayqvm8;-(6K@ z;$k|_>=WoPayQ?MFceTNR&4$^0mY)2#(|Ln^5}ijrJ$GZw4%}EN7Swtg&vGN#<^hq zUFv`#u7n!R+i!JiuB|qNtCF9$0{siA;LV^7*nPB{L|dv>e$Y6^HQbqqXwO1wr1)b3 zYr4)h9cm1inS5U*kP^)Abql;wpSA#2g8fE2cASrgM}~Evu%IsY>jQAKB=$NkRP;Sn z{b%j+;ptuqjJgq3na6S!OND6c>1!i{o6LVe&M+4ivoewmun;Qj{6xgZ4tSIyxsmr{ ze3C{fO1?*z7XfeXA_<=GurP(WhnsZ()ahhkABLn}+} zfy-7b@~HBBzt1@c?-+k#DI?v4bp&58`}03ukHDV$= zoc6RyfI99!#3<=7#*LAra)&5*{X#1}$OWZ%;g`NFr=UG(YyqHbXtw`WI6VP&wU386 zfi?R`5>6&GyC^${+Yyoy0XCRq9bm4PlVYw@dXuY#K!J%UnBsACu+Vf2BmY?B`TiYg z*vmWoNm*Q7>v$LTb*`3?Y`MkFHdVeI~{_%!pSgiw)ktRYU zgn4G5>)Bka3(X^Tl7u`R5EHc>d>E&HBh#SWx0v+}P7k4`>n|agkU-dlECQBr(&q>h z?H?31TDft<6iXp+GH7Vc`2sVG8__SpphqYp^@Ygi8~#KB{`6s@0WVLA0Q#YYlFm&f zme03;29zFv?gJ?_cY<5>;10h%qO(QYZDNpqA^kEWhZr_X57S9=5Z2R(r0)9!mRJ9t1j=ouO+Ml*`zH7#A3CGwvW z7OyiyLga4-UAcQSy6?SEGD6KHue`@;e~96?xW*2m?2{|C6%Z2$+=4tDuRU&AqQ+Iqd2(6q8{QAeMo%c_@)G6r{H^Iys&X$ za*tFS2N(+2{D5Ro55p7y419fbtk)mGoE`daaB#3dvX%U_&un|#o{tK#X&kaq{ObAT z#lZjV4mesn0Sgsi!G$#Gr;TVXDKWh{oanwH=nmY0UiAe~-Il2E_({X+32abC1NGQN ztA{>pamjN6* zN>C+SUbyKrT%0L~C~APzqjF$UL1dvHfCe=7_Wl|b)qv98|MswjHVQNVj*oIXoRi@3 zOgx)r9PF4-^G_U&c%3xkS8>{K>V^7|_ZOQjjbP*@U$uh1;(iYv2dmNalY17!$5GFH zdD>xCrCo{%uFv6Vw?7-3`s4p$+woFuDo%;#!Ig`9TVv34{owZyo&RyZweIjTl+*|m zy&&3|{VCM6{0vYALaWP@cax6?od@f|`iMFI`R398OKazQ@ za^$e8;}QaIt78W9zifGb;Rm8$MR%Mwzf8{C*V@bgqDmjwrr?ohJc)c#J&Nje5N7t} zqU&R^rKTXM*7%VehJJAapXNtq>o|tGi|N8O35*JZ9;pItW?V{4M?>$P_tx6`DpUNQ zRbHq25Q6hyIo~j2@6A_FXRzmE@78PV$K?-6uy&`DwxeUAb(wmW-|(Q4*sKbkN`?lW z(K0-Z<)Jyx^Muhcf0Z96%8S)+6J)}8sT^YxjFS@)JUngSC$(4>OMp9>T~2#_JfcL# zn-<4e@V(FW&!_ z3%*%-C^4I7K;<2Xzyww=>ITHnA;KK8FIxnPN}(ap{E$K(tykko$j?WEY;ZZ54TWqa z9}xqf8Ws`O%7+^r?k4e0L3=^(PJClIteyD4_?Gm86yyp+3Z?kGGUa!_YF!7c_|9j= z8$by+paVF?(AaeV40HQ#B8KGu(rqRH=i)6R0h9wp7B)lx{Up~eoK%_22K7^;)c^m-h?iC})x7WXh_k82fV&Kps!nD)PeZfwhM<{-#%qj0hI5C$!FWZ8 z#&v^i98A5u5!(<%X!k@|Uo6dX`p%K{#>S$taIp`?`x2#Ee^r-|2o_a2u@iHgoRM+y zFR#sQB}bwDV0{xHOgf4B!!IPL5L8B0@9*E|x(y{CPY zg(i#a$yB;&PTvQfuhD90O|qri)#u~I+&w!bE~qp$9cwC+?TpL+=I7tehrF+x>zvjS zCPu=L4}64@_@C0t$aZZdp{H|3^w^k33ODZ!Yvxgt*fh)TP2AgmFAL9g;5I+WFD@Ux%^R0<#4!i8*#*J5Gtw= z$xIE!jR~?1Zvt$AB3;bcphTKYpt^QuumDX8EsTqgPY!XP8~8|lx3(5VH5@9)gBRlB z&bNk4L8NmBu$REeN#u%z5!su0w=WN~V1GrZ#SKif>&UWC;?uPEx(nbUiN5Yw`Dxx` zD?&B>nhW`GNm)W6L`LbWP=#k z==}#wdlOewOA2^KY*`7-MNCc#6{dk2)d64{i{jsPjPTH^1R{8pvN%k-tp%;Et#vQyKco8s9Wju)sw3eBKl|?!t^F{l&g| zX{pm#JfD6)zy&kEXzm*?pC+CbCq_&zT}$m4;G+2NgyI4mG)W1G1Xx&fLOb9Bnaydt zYq15asFPDuM@dI%`E+b$fo&`x@FAJ=ZqXP|3}NGamWjj2N>Io4UqB9&{DC+yoEH(E z0O3c0Xa^M4$0nu27X-E9JPB>*K&?hVk-RM>nCfEe#cDeho1i&1glID)AS^!taZCUN zn9ujLpG;!Pz3*{J5ko`ld#eoX!QHD(3Z^jB)h+(BGTs0p^pNjk|0`~vyVIg^mo zb}&;yBbfmbvDFCO)YZGU{~9a!PgA^!&X+II1)0cuP7L$qcpTYCSmgjyi++xj^l9tM0ujp81`7D&U-W+2EOBM*j#I$Hq z@^JkLpxuv%A()yt>7?}&W@bw)q4+b`RTmW%c6E_3vGdO3g7KApHJ_E3h`zn?=bkic zE2$AO(s1%qp3@5Cn`Y;g1!eacJD`rpw^YZ#bYL;+{m6!_Ct7iyohdxG|CK;^j7n3x z|Lx~igXctPURW?+!SSOYgIuX$nh9PNW(K7MxMXl`bFItyLs<3RGfGfNm&N|%^jG65 zLN5b^211cik+LJaaRr`B1+R)!a*n0J)M)Uqdw0`KtVOn)U22kOl+DYVm#gbU=fl=V zq@w>J@JFT_K|4AM<)Kd^4Asgaqbqj%)r}5vB-_1^PP3Y6qLgQ%9j~jb{MO=PMTW!g z{jA2CT0p5&Ge2#psOjB7Z@uH7Z)H?yN5WGBZ3ryh$W~!^3d-_M-yxJYMowS9M~D>7 z?k;FySFgJAu~))tGjPDNQZ8!UJ3Fwjl*~e5OUHe`1||I$|C*xESM8o zu~e;{d?yFbys=Yd$Jc`=1r0e~3+P)wo7a0W`0e;0-2j$Nv;iF-9vT>QIP0T;1EC;v z8+17^xKxm9LiZdHw)O^u2%`gvXq(f)@4;x?eu|ksu&u2w?sNoTI|TsxWW=U4c*stH zO=bBHOW7Kbz%QS*N&>=TN*A$*=J@>Qmf!P9`M;$EczS|0$QqlQv1Gird>?%On1FSf zEz##QDANv(_uzDy0P)T$*uXemBpcuC7=Sm7TC{K)Kpxh+oT%8{p24#GCkb;!fjg+;cK#JhvE%6=)l1k+{B0aYR+DNc zoFo4+P^XzA^Xv)=D<{+gqG=$|Oa=m+rP{bl?k7)&2&Y2+R*rVQ@^*ML5$=ZKl6#j_ zoRk|8a)(l-$@hF2jJEFn@Q24any!+PEG3GvvCqx6`iTQFb$Hr0&_UYB$V}T&=x%)3 z(8qFwMQ5d_B9mg zaLaY76G&!XQPMBrV21_?7#s$MijLJp`j{;>nyCxAqv8BTnL$v7-)-d$6JfVH9c{-c zS^An%`8(?OZ^YpSua2)1E|C3{>gv25-ju^Au(47!+Yk7)l2cV`xtkskd`63n*+L2q zgrIvY`3eu_nxrphh(l0m7D3u}zLbkwg;h}|YqFZvt!IC~4tJq+r?o^-F9V!|Ilv1T z1xpR**YtgXE>69z&EY7vG?@~!SlI6Yqt zF*JP(XT3az6qhMg0Z_n;{}771(M)-Ko=N4;KsRmr7oGcmUTWaFuU&5lu|KY9#&p!f z4Y7n&%8FbJe9~K5aJ~gf#V`szP9NiWTvkd?L%-{DSB?IX+(oOv8l$7<*B$FQM%Oz8 zY%?-c$)C_+6XN-<;lp@WGB?hk?mzEm7-dkZgFnaOrY)t+v!^VwXm{YH2yU2mXNpaQ%c1BS-X3;o+4g*(l9uaW@4%I(6BW- zdH%0T@NT&{p6}K0t(qtBmrqtDbPbjrZT5mIM;&f-vNb#Gj_RZ>>y?k*m+`5(d<{Ki z6}&5J4LV-d>1-*lQ85=&hYEY{Q`&F(e!|RZ(DL)@G0(>;+{h!Md!(F1 z9ga|pW5+@l?+;rt$ahlag!@JtVX;4LTZvrzR&>n~?4==jFRUK%hUh|}kArIWq|?fw zkz{_Cap0(PU}-Mls>#iXz}&7~U_xtuLnzQGdJdxsMUiGp&MlAo<9n3)wx)0U)lo=+ z5;7_UtOC%j0F-aO$Nr4s7p-QBPxrzY?A|DM7#Bt)Qn}f2W>=WyxQ23mOPDwnl!CFt z2KZsK_cqU@5Zzmvs)99LwE~|mb<#2;Vnt?DXELl--k_j7CK|vbOCxm6`=uiw;!;OJ0@>PaR4YwwK2U=o*Y zu2W5oa7<@BKpVZ;=?@1iz1=3ms1X&ve)#}m5x|^q_w{{qO+#bFJ+t0pysV6>gd^iX zY3dWl4o!6pd`*&4)?QULOT|ZMR?ua!3utt3ERYam93;?)Q05!0lT~1?@j3|#IHZz{ z`|Ekp$)(ThXlUV7pei$rwNjO>;k>os{x-bzc=wglmJWcXo?OxsQu!7Lx-WTpc6!}sG{*S?>t*Z3G02hpqfm^_Hp_EINZrhH)#Xce z7D}<9Q7w%(jUgi&58Bbzdl?k5dwt#6Wv%V#jy^KRYgmiXT&}g9PI%ZMtf*qC%e-QQ zHkmmffM*_R^q0nt8W8U(#SQ?C!nL_(tC~~OLo`|h>oen z7gCIizs=?E0+h~|O>gJcrwmgn5kC&B+d6~po#gz-`8PB^H9?cKvYBFgFZmEgay_Mj z&zbJ@M%e}5A_mi{NJQ+G0QiA8q%WBl{CNn^9XmIIdhuN{#o*=3+3A@PKFjsrlfQ98 zdr9Y7qN2gY{gzXPG&!0|6)%vqUbd3KP7X#-b@10S9*}IZY8tRj6dj>6dC4)v8&3*0 zt;6MXy+VfP&ubUUtqSAXh)}*?DtrFIc_%dazTDs4-VPYEcpOMk^w|dlZf!I8V5}49 zlHB|3puqmBCKaIO1w>CKzpLnf5g4F|S(&*$9Ju)U?E<9XeQLo-5Mqo78OETwKf?LW z_f4^H2#LFYK}eqtgn4?YahUXDz6E?K43dI!LNLdVl~DFe@NU#KF@t66dFN#dxEf(7 zbk&80M|mR(!Dz-PCYhFzLjJ~LzxfLe>~pyj4&DTsNryyQp$E;0gz#$e)dQ}eQWCr| z5yN&1Q(GH!~-mWC? z88NZgtre1314#-uDodmBrj z9`?rmb;#o9y04b)7U*~Eq2>+8NNk)OT0$m6(&epEX0X>uq-L?53?tU>J^ z9iF2u9t@8>k9mL>Pc34L6q*~Qqk;g9ofQ$t`rgi~Dt2D>A#JAvD89=qnoT12^{W%$ zE_P+wn(mKrm2`p9mpu6RE3aPuRahZ=ppY_z5yIgC?QP z(W2s0DzNUkgdYFRwr9I#ArS?je|}sh|0h}fn$e>hVR5k6F)1<~&X;c?i^G&s$O{Lo z{q4nw+*p~hBvwl z{F+P(2^r=Zv7BQP;Q%*wDET~BFH%d*$%bB_g178!h0^uL)F4BEuM`6LfE-pH-^mF< zcL~vepSf0f+yDG=JZrWT$($*#+wkc(hx$S)jerbY24&A&8Xp;VzBUlFG5N1(KB_WU zeFw2(EP@t=N|;_<@#ZQkD90`bYGR6jt7NY=Dp#pUkJ`zpcUN@-& zmTe)THTnkoR*4nsm25>X*lqY6leweBohozxaA#~^I-$nOktIXlE~ute1Sit?y+E=_ zp9H)Q{eL8#16yY8+r_gr*_dowced>&bFytrwynvUY}>Y7Gr6gz{`+~~FVN9Zd++Ny z*SXejp-`7_=7BXyxIN9`&go$cq>m5a$K_H}<4otYxb}Bp(Q7j4v=o)JDHk7?D2LdV zsNfafJ>X@2yO!Mbq-T(J|4|HR>%KcO5X2h^ZDEm?x0Y`E`B=o!`?gNyOMVWN} zVC@CYEVzVkUT3gEd#NK>Bhg|rA>HsM>fY=-npbA4>uQ~?-3@Qs+~J#wa_+jzsX%q; zuFGt9yuj;P5#K47i915> zT=8)gL#-9izjGglZ5o=oW#rz=_9$02KEA6m$IV*L>YB%H<<-3B(Kh!J^0$JH; zQ|KvRF<*^wp~Lxm8!VO&yzWnDe%fa2KU>O2;3AX4b2S@UD4xFa$_?dIB~>)T_RnJ} zKLoWc@teeF)H34Dg*a*WsOQm1@S`~ITaAvMMO(?P|1zhp$trvN`IaZ98S}8kx`>;S(D(yyBF2q8U&`V~uxmO)=#VtqgVa?W zs&vylRZ*{sZ4n^?LWQ->#@(J7EqqO#O!AZ0-@nTm%eV81{U1Fa{UR@pugm|`*>Hhs zH!N7OFBzKiS()g?c|*B%wtwr;X`*RTs{juQ!xWlHAA`m!Bl92T40h9kxzu(7$>YQG6%;=5Ugq+4IW5x(ZW|?4aP>Kf4#qg8`NcHHX ziJbwtjpYB}N8d(wmzTp3fjtiZx>n{7^+F=O>of!&*(Ah36l80=-5w&bAG!P7{CK*50=GMl#pm$PcI%RGx>i;9BvjX9Vg)*u1)@I|a7 z2`+9QF642935XsI@@piF=&~bOZHNA%qwfu|09K~J+f@?~ZZxHXH~cSyNJbA9u}V~; zh(`i5flAMvqYh(IR*aukLf;|!du6bPwz(SCTjr$F2|PvbMF`U%)an`!6=fBo4*%SS z*UR`c(Lk?LkuXiQ!5GBM$mD;v9|0_{V6|%W5!R`bv1>x8<{Q1L|v2TuC3SF;kH5r*M9epQHQNxcOQ%F-75;l;g~!sWp-js*3hG?Rr;>PZiM zuvjwBw2Jc6Z^{ut;IfgPG*!Yh)M^J|@vdDAc1Rw%=R6%QoA;kPzE-UVx^bD+*_yxX z#*3K!_FY^~r z&?-^UfeVL+wDPnqPbS(-LUTbHz)NR8cx2s9R9{2cv!At^}JzXU?P zjCw8aGr!+atSBRK%%Hy<&&aSFn8tAH!aEWL+41uBX-Kw}lt6_bAQgEkP^zQlT>&c~ zwy6fT!+<@XteXH z#fj9OW3FI^Lf}I`_gb(>#Bu-DV{ovSzJl$*ln^S zcE43`7w?+qF4bY=c@U7deP3%vjU>j%Ft!O?5r6xB+&5Wpz(D#h;V@RJ`HiKj{F+le z+Hef^BkVm(RSCI->e&3d`FAY#q|xbT0hajPEv!@XSmW_Ygl{Z>{48^IcXe}bDVN{m zs3~kJ9~9!9tpldzP4_K|5#;c)vx8~C0jz67>?&dBI^}`STp(Han^3d^|AF93Zyt`O zUv%hvwj?u5!bP+V2+0^l-JRoW_Jqq6x-R2Kux4BXr?enK zkZ~GKyexBtnWTWpQpq1PK8A7>>=P+K^UmK!OOLM1685pW|!s-%!W z#Yt0NS>nyR@x=9@ZKevAV&+O@6-w_{2*3E|GS^mH(t)5*RBW}T67ZB0s5FTPeFveM zu;XND5%r_CA-L#Jj3Fc>1jt{n-Any^FTkEbii;g$N@(Bf2yy@q?+-OLGcyA^L*j)$ zUI0;I&q{=}j~LLzUfO5(-ckEYLmk`@`?53_g>^9~_qM_nfpXVFDoAy({Nhg?B%S1!7*5!2% z_&It3xpf6r6KhAw)iGNXq5`FIWN|G4@&Ozf*&Y@LNPkn!hzeEnuH91t3_8e?(57}D zvtVMV?+CG?D1Zw^uhX5;lb2~or{mTQ65%vBtuX3*6Q!Ph&G>aaxtabsuB52NY%;pI zf;5GcRY+q&U8n0uYWsT`B=oJm?)pTKHTG}wAR{PDX5OV`kCyYA(|kTZtMoGMXv_B2I~n7gfk&cCdJr zkX(U%P(*lyT2#qV27aOgCEED&L&2Ac*7*rX>phwS=jJvr_=K@3PIn^`Ip;5s z#`%$F5DjlDT5BZkh6pB`6~{|tp-khU=k0#sPRsMI@A2G>eZx#s(otV9gHg{ruv73o zD~vFX`{uD`r=VYeK)A;gEocLE7OtYJYGbvLNFK3x?kbR&L}*Q#mckL>w(Tmnf@B0* z#!B|53$y^8b1SjGI^G9SsaQLCL`_uz_zNrB=9&|oZ(>YH_|V|vsM(VnjFtX16R3%z zF)bONfoEt!-VauQT>=7RZhl;;QMI>EYDQ>L+x`L8dGNP91Qr#Td76|2ZlRc`Avq13 zt>y<&h2Mdp3SS+`pF@wX7B0k;3QAcwh46-?8%rDy#0ez60asgpEr)qe;JpWod$5(-qw)zpW7 z5}&2OlgEH19~`)Tf))~pT4FR*b7>{G4HNXuF>Pu$W3Dl)j}-}po0C%z=t}^g8n>Q= zf_{@}jPLBP(lJf0lb7&4kP{I2NSl{^nY zpi4o4?*6^F2_M(ZyE|2$!I_zv{lsrlD};;qGV7JhKv@qH4PAKsLRpP5TD;TfFQ=hZ z7#c(@*at;TB34=jDc-3@8e`BZq{$5Wt?0N!Q9Ke43s_4$H5VFW{39@$wzRgA6F;Ez z*dI@%_8YUt_G_!$vyJXj zf!9J5Oh4$ybObPxgDWE}|c#d8VlI(_gBjO{oCmB@guDa3s zwneG|r`N|dps(}!zw^w9@&E_)`;?_n)A#KTzT1#c;LD*6_s1vgU?B?mL7anzn`wz) zu>9b_PZ@)HGbp+)`o&|G|Wb5PNNQ2 z>;I^y+hFAhjf+{L4lE*S8n0zp)mv7&=kZhr4++W|9EMa0k~3+?&mi-LnlHO0fpHH=|Mlv3pRh3nqPci3}3AZJPX)r;TAh1FLbu zR=pAvQe_zMf1#XqRP<&Am0)~Ij5l5C}`k$&dheg|YOLBzK+p!XC=SD#kqcyAt7e~^Px5jqEaESI?jylI^`F$@w}UK62d+5uLOt%bWz23QRA)1T=n z20dNf7xH63rhd7*f`U(Izv}>(jHb>9#2yjaynv6tSF6=7CsXT<=96`wuXVsLI50wn zH!)cIFp_eeMJ{(n7Vvaifr*6u0wwPb2rLy?ba0t_jzG&}0R+pLbc}S%@AW>;{%P|x z2Jodw`Y=T#$;bcJpukniIDrRR%^g@v24Qh>aInM=!G-=9ogi(@TpO!|Dgpl+AzIkj z*a%?o=jT<!+}%f4u_>w!=OP75P}4bX=MKW`^WEb;|ur;;K9MlIy4Ta_a*tCfcm! zQ&vJ(3p{#=6g2yUug*Yni$Mksy&G;9^(pw!vpK>ZPj&w`>g)lD6j-G&Fb^la>M^A#rT)$&?{8gn=k@*xVM#kO?+RFiAx ze2CXVX-2+)==<4uVxo(#;tCdx(@15q4&ol%n)7(JR$b?auM!0?x?P5&|5Gn!0fj5L zpS1SCQnD4PaV24z#yXsiI{7>+D=S|3eXnD4g-+RYjO>d7p|I=IOJQEiVr}l-xwzQ5 z!j=TwF=k(0b-#w4cJ$DIy#_s z>G{tfs#3lXkuRcMHpcxiVaC}QN)=cIhdKm)@V622cmd~C0}m01NEr%rF3nGw%931EG_OfztP{M=3 zd&vxiF@zVzEW=!gwUpgVB>XYeoi(_Lh|a7xTANyrQ!okA1jOGg%2LrM9ayYl4MahF61?p;5Nj z0=Labk%|#C3i1J)ACS%7?mnJj%;ri-#}dI$$`)z~Se@_Yr`UYZk2iE}(-!&8#6p^8 z_JK=}NEj(4xixbNvaYrM%RXY5zVZG2YO;|Kz;m8@8<_##13-qFDg}~EfH5~Lg?EQJsFXQGc!lD31h*BI6}|GAs<90 z;1d7(WwH_QQTI3P0$)F%^+FLzzAeiTWs26N3i4wKkd{XX90D~C8LZI4Cp>n%PJznV zzqj0rv`~!;lQ2|F1s7-#bP(GX%yBF>d_GThOaJ2dZ)j*~gS<)6$zuUzaAEnMFzG>@ zJ2F_b!Nj@DrziJNGMS@5MF3CPbvnWWof1xrHPI;PGR2|WqOiz5UD&gu{S{ZHZyWD-aOh$&TY{x0U|Zk$c-E6U|1sn0Dt&ABYJhrXic;RC%y$S@ z&wu2o!q|_lvcX!gKeS1JNvbT10-v*5D@u2oB%78SlRZCgW@pCpg-CH!a@vf;#b%2% z{gOPTl)#^;L(s(YB-0dDSBWUm6|cDRE@|NHcPDIkTUVDrvf>(pcK&}I8?}n3qWybg z$piZZCNIq(&)WfLVAtDkt#O=`zH;|2Rvw=x=r7%p{GAU*%qNd422#0BEFIJ5yUuq* z-Tj49qb-rky}Gc@^&Yf#mp|l}Y);$H{Y=Q-d1idkf;iP}o*Q4dI@kjmO zV4%+_eZtOx_nEN$8gd-iG6R!zAO((=2i#{QHGz;RoY?0)J?jmh+l4xCL|w#5W5YqL z-G?#-5~7u*hjes)k<=`JKqK$H2V*?2bwG+VlKu`jhJ4S?vg>-E-d%cmJdGXX?#H!V zas6|9im^u=3As!+Qu;y*bN67P5_>*o*da$z`RBoP;pgRRwOgRb`v#KGOXN%K#e^*@ z$z0$v2iN;TVdB4O*E!-M!Tk8~<9Fv<-udDsa*;(D_tK{Gfn&hvdVj6EM&nTPaqMCP zDlBG>g$G4M*Y)tq!ySTGZ7E)xraqHJ7zc9q!|umpK==CqbE|`o%c_sV=Fd>ljYGJ& zR7oAdhBF*LG3vC8qC_LQ>oOC)UC+|i$7XIm8vZi7QcG^G|H|s>N_HJ6)KblnTEUo3 z1(e0?GP#mV&tqc&zrI75qJjB zq?kg>6`JfYQn&7^pL=o}HRzQBtGAbK)< z_rr$H!i@l~1Y6xc9svQuHlw{>aHrEo*C1JeX0Qw^h}NXk$rY5?$=_^FU{lUOCxhb= z8s^x+crvw-=RWieoHV3JgKS{>eKS*FO4}1a2?Y2q2?S<8d{^p>W}U^5W=`BME}>rS zQRYRypoEJ#^xVEC0~6ZEiie@!ZCKf0ge@ICdKB)6tW`kDaYy>e#kaF0rF4vWb*G_# z_q`in-$&_XJvY^O@Xkq}_Md0f|J7A*iUihA_a=vODEoSEy^j%W>4!Zg8cGCEeWl5u zC**U2q}#k0ojD%_cxc;utA-NW^|Mn-m78 zpJQ8XxrD5_xQQGzSe#;suwK+FaS-|ZTh=o4-*2~f=<$C)3tAi7^E6$zlD=B68Hkxf zN~5Q3AyUsx+=(0X+4+6VL$4zjMZGGtX<{I_q$KDUP2od10BMdNk~TIc7M{w>_195}x4JnL1%wHlU~ zTJQq_3Z_iicxT)qlGz*d-X!2WfxtU3B;~M#+G};BtCG+$`XFPV(gN2Z6N?*%U_y&a z5DpJp7035nT&~i(N1$Erbct`%=r>~pYTTBVw*23&f!HU5*B^K|OTd}|2??11mL!tY z8c3teuO1rpWhttcCupM3rUKyOJqkW=L6Vty9hpHMVZcH4(E>8Nfb9x{KLHeEJj)8&UC@O#g^tyFB^%#=X9cErGDH%_= z@w}2<*YiHmB!zNi&Fe#jO%$Yq!3>dr-1RZs&Id|ypFpfY_Z>Y0DNRO^+grxTaCw$! zXsGmf-RJIUB>XygZg?L?y^&{n5fyp)(b=+UND~hX$t$gF-sBthBREfs%DNv zz!IYZIvm*q;Yz6LM^IhstBIZ4F>}e@6OpiJ9*4sugszTF1hN(O;yJJH?DW{4K6UfA zl5BT29UnPSD-gNqi>UQ~4D&r5;FPN1tfwNa%f>!<5W>`pB#8->JQMy3rO0OFqk3;;)+@gY8I!j|ImI= zM@naFybUYq5xyw$bTII>rIxt$le%D zE-+Bg7G4)izy-!ZRNl~#Skh{a^20Y`*ay;hz`{{_@x2i2D%&=@eq*5zM282x%Yp=X z0u^P|fUU^;9n7U_veqb7b-pk;0<}3$fC~8`SThatXf}`i9xz<|bg(PYdKX+Uoa7i6 zQR1Vy$DZ1CJ|*JRIL7xZNp0N7-kc#6cDZZIRGeFQZYiaG(23kLJgg2gpH&Qkd?plb zc6fgBXzlsCkzLpA`o1QUu0K_GMoIz_>R*zcJ;!OLlxk$8$K$p-e;`;ou0?x?Ax1)w zr@x}RC?0PydYmB^c0C#Mw{BKyObXvM(otz~9d8_-OusZ`U#=&rUnT6(0Cy;kY{e<4 zpMzG_LvxbJZ8Zkhzncp0=#mb!V2beJn<2Cn@}E-}JumMV+QS_f8rjc=+ounkh)OlH z7Tx$IFe%`FH1?*q>vj1{%P8Qn6hlGEtSFU+p0Z1G>~T@F|7?2Fk*CXK7=cADCkzz; z?M!+zQv|9uC=INmPXBTKosCSsSu7R*eX|Am0pgjFi3zwN90F;Ern)e|_>^v@b5av= zb+3#T1_Yv;pCQlrkMbf6{5BS0s0X_5X2|^`F; z-lL=YzjSnT|8+q5Ptz6(A9Jg$rOLrgN6t ze9s5Yf2B6UwA$ncJ#VzSwDr#ZvVVd1&PI(z%&HZ=X48s=rODG$M{7FMXsAGJFkq zEKJ}J=yH9LY998@n~{nLFc2P%-8?Teh>Xf6Q-qz=+jpOzATfrqIlhUO3a+|OKg@@` z83r5=8wuSnu`3CAd43Av9~)UVQAU#i>{4I}gERs$VH(X0ws#Kf>Hh}t^ob4<-^4O^ z>5|g-aPdzj$x~%#WucG=#R$4ku}uCaQO3eajd@I|GC_gFd3>uNu*|HB8E?AoXMi52 zP@uvUaQ*`Vx0g(bsfkQiavYiHV!ew_09ye9YMt4(qd}D2&m#2ltls zpC#JT6D|w{!DKgrc_8v&Gn10K%f7r^pIzU_>2xFC$I{by5?(7xjAo$~TxF^GpMO5} zp_vS@WXqFX8X2tIH)P8TZYmGH`3_KzqS~?QLDrbxLHQV$9)xV$8`P9b>MF{f^IQ#9 zh`A;jZQ97N^pG&K&t6N(Fe09dm}*VRs&ECGI;Bfkrca($~^z1v>D;!^44LgYf^W z?tFlSVw5;U1j9%a3L2snJ`9VoD6rkJs|JO5F1)UMzoCb1hM1@~pTvGp0Nn5&v4-nF zo7w#Qm-x|kc2P|RCP#%B`1!&Atg#-x~k{_gqO zXZ5-YVvevo>QcgbJd!{e8qIn1#6h2YA-GB`5=*kh@6a?bXm`Kf2>X%V7AGZqK_yPp z#Te>y6BarSMw3P>fZjDil+87r&)wQax?4`4WQy|i1gz+WipgRAK_#CCxh$$u`_A)- z_LWNp`@i~XCc6=FOs;TBoVIpE={F)6LEyQk{@7~9|H2Y>(qJb?kd7V0*Xu|UcNiRC zRf$PJ%;Q&NUD2x7m{fqDie-*?GHcLu(sHoitbTpq9>UqagMCyM91s?qg*AolgU{8W zDk8IfeYskr-BQw1h8|*0i^Y9NZmCEpLwQ(VlK{)qAGZE`$N_uphJ7ffxvJoSYlL5h zHnmTi`AdB10{m+#ZOJ>F+0Dckl!*RGz-Zv*I3QOB0N>dU_XYbbg`pbRa5A3VA@H|GhC$59?VZ#%t>th=0Irl)x&Ra+f7o&EfZ znkrl^lhX#)eWFQUSF6htaFY~J3uifWASz8V=zn(1JlMmHnn} zQEJ8OvN~_J-Y{QfY^GdlRQMw^P13KCKF$*9>7`W@M_O%>_?ekTTbVEBO%yyfM|iKDLG0ZopLykO1_8U z5{HV514Ac=*~Yf~5@H58SInBV-$SvUNlSuYhl%$uVYi~X45*~Rl957#`8d3$WWJ#$ z2bx7QoqxozcIhU}m&vXBER3{DsJok*F}!PYZ08eWdBuI5=SoAjHn!(neVqIr;4`^? zsDO(m$A>_y-Dn5x2Tf@>Csjj(_`w40a~mR-42zb!TYzINNDxiEy23eSz>>c+4K^+# z0o$o3^~y&$K1sj;lQCUljxRj0e5gzcxy0RtR+=p(HI>REG@Cz zrA_a|&>$fr3azjK5(T2&lRovPZZLIMgSw9$z%Ibt!a76 z=Agk6Wd@u+A@ab_DQj#*zZ0PcLRO+Cd*5`*+`4H89wFT{bck_rd3;}3GSFnOJP*QD4CVHfdLVOm7moBpn$zZG&aUV>}{~B^ShiN@ld|1 zQ=n%8{U_oRjmKU_WNyK22YkUqwR1|k=rhh&6n4xwSX&EDKTV*VvrMNB>H5T#Grmhb z%Wup5R7DV4dStlGPBhax=TMV;6;fRgoTVNQ|7wlE&};rf;;qk*K|(gf)#d?niGAOZ zaQjC>zCyf_p1tcBZjn1iS|QWsRF|(BTlY z>m(ko8r)XC##F8`)Mi*hxLG32f$Fe5I(9{l>r8{wF^eToU&+{|DhTaq_!0$#;7@a9 z0*29`#0yzbiQr|E){DU!<&1dOOlV|0R5cPvx0c)(_)}d~Yn2kCAyjeg`pFPYI#IY} zwEl^Z6R!MIR@aFhwq_8|qA4)_~(a(jh zD}d&a1FUr0?O zz7k-2A4NyJn|&|LBE+p^A$`$g%7qY_*$!xGphx4`Ko&{nX0UjP6 zK;VgAV9V*_{qMUAxnoXpf{Z>2AVmP_RtqNLSjl)|!D#FtioZY;K~`P>odv*;tcHWC zC@Co^EDX}hhOlB_)8Qn$97hAi2ht9LK~AAZ7{>zkX*B$jQ8`31@OQXgLx>LeLNXm5 z!tnUMFq|=#?0aO$X-W%RNH0Ab?Jr8gdJHjowUk||IqZ>{S7A*aoMP#m!)c|>l$l(1 zDBFQH3?Ty(Wq|nQIGuEP7LAWauHn3HqGrXm;G!@tGZOLEp*k-@D@0eClq9SS_ysg| zBw%DE-R*#aLR!ZNy+Uq7MpD($5yRyeX@3zX9cvvOJQ)_Ebk$ocqf=w8Y}@%1D23La zR^B`sPgR*CGhDC8j`lcUt?p*inpOue$clAE^PQ=CDN8AtcLntWyZgeNPujFV)~p{9 zAx=z1;vnpRuF$Q7QVY6p`k@ol7MlS*X;psg$%Q~s)p(NbHmI@GOi#&3o!c_^sKI{H zDj96Om@iu~o`Mt4XEBkip@m9m;KxIYJo-}(348<2#Zhfn zq>6&QJ!1w34FJYzZbk=98qOj1F%S?ChACwoi6GSSYXr<>{l|y}BYmi}Q<+qw$ zl$*@$;TM&Be$`jjjm0$B1~H}v0#N0@X*EWlrmURXj<0^M{YemaC~q?_Ep4)pucKkS zy+tKD_7xKF>OX`ktN@y|jdz*|2q5+gjy94MLnI-VxN^Ty6ruvUff#}m){*{*BypdVatdqETyr^E(ryB$z1;#dE8V|= zUzHX6#$)Ws^E*$4Erq5MAE78yplt3{@3r(|G~zXzC0UaW1tn7TkjH_sSOALgy`~; zq-cOo9Eye%eGe1e7jq^8i8oMwPJXPVw3ISa9th$>a6`B5L1CoO8K4H*{Z|ihxSPNeeTEcmNL4JujF1GUD@( zfmU7nA5Rm*2*|O(amw4t6h@&f;Kc)BF!S%PacqY&QVM$ixwek3v|(dJRhaG3&|A>Y zs<|8beO8%eIcYHwlgH=8z{Mv1hQkpMvo3DXEy# z`TU(lC6Pym8)Cr0ZEruvp}8b+*5ePJqwZhrqS;}152 zO7+u}7yUw+N$Aila%NeIvbcIbE9G61&4ltx&)Q5y%EKs6j!an{>(Q_YZ$mb|j)1o} z;eWTEZ?m7rzllEs{Qn#re*PQlWJYc#WH${Nw-Uf^TBLGP#>X62{krc}nbKG)9<3Gq z#J8cVHnHp0$qE5{;)JczrmIR8*QvNureGqFl{zK zkrc{DtpST-C70q!{tAl`X;ie`+1Ux43-~{V=fr?CH6W(2;1AJivYd$Zg_2LNBIqDw zq=I=_^K1_s+e6U|GxM_{$Um$sd+67B3E z`-on+6A8311$}Ms%(g^J}3-BN7{%p1_H<)$R zCqT&(VDlrh9UG$6(1Ms0ry#YZVO1TS&9RA&MN-DDR2QzX@ZRQ7NG+9V>6kkfxd!0i zG>G_Uv1kY{r_-5&HD%Eh7NrreKKz@TcAH<#O#?3oucR*6H_S=r4-(fs=2 zK)4s*4mzKI+eCYkDFcdF*he+`9VJE8Il5ZQ!t%XcZvC^!LDCcu^!obx@Mw z8LC)CV_d%(Hwf1QI=zexgku>deHN_5paR}Cat8T!TN-C&wE=%l;fk>L#@b*SzK5Ze z!gff^V9p<9HD|xry(gLMsUjj^`SoT?BqJzhAKse7H!eD?Il~JV#m_LIr0vXH=Uht+ z{2z9CoAApt9?kVG=(_%*wc)(29Hg63@2ufrjq%TeEEd`fNP z|74w|T@HlAP$I0I#PXFEIEGtPqh7}LKn`{lB(3wDHAN+k$BoCO62mmGHIiB65wvE= zG?LeH=}a}Xwb+WQoDndco0~<0gAY}CUlmr$62Poc!^Xa^8f_mpu&SN#;FuJogNqiS z>RZ;!*GF*MSXl*bftdE2i{@zrG;M7!_x4E9`!@YtaiC9I0aI^K5I6^NHM%~jHuM&? zGfeI=04_HMkrpaj0gjyn^a=_ZEj_(W=qXhz9`J#qzL(KIfBpcEj7W?!;+?$zCoq_t zA;PPWD-OP#y>fl&$7nrjc9AA~IRHHJtRo<#BN&^Vtt}*(qI{FtIsi-5fj;ZfMA76u z(5@oM4QD2G{xQ&v?o)g~^X_km9m!wUEsSq8m@gEfB~B$|CqziW#O7R53SkWYD%3%kg8KV?In6INBTNXq(%oeLT)&;-8FR+18@&4b%ryA46eQMZv9OOS%IJqp`Jic*v~!2fEqh^ljjdJpwFG`FnmFR77G|$K&mpnB!NjmvW!5gPkZC~ z&Sc}sx-IxVQWfFR>$sO{8UNd_=kRPN@31c4$M$qyi&*&OPVLRe>ziwV!*u0xwnJyJ z_Xm1SiD=&4y~~E@=h@%Enl~f9+q=UE4QqOkp$d?*YO3EQB z(yFfyInxB^1^JfqF8K2eclKAPJ{@+`98o&E9bs)()bUH+_wn*KYv@Oh!F-q=lt2;m z1a&l%Zj<5YN;)r`Bo53!sQ^Yk-`pZObVAZNx$ZE0pDua4LWg4ob6629q=by3K;%L# z#f)^rpu-iua${v>L=lBix7iBFv0k(gc`bGKX48NL7-Y;2(ka7Ep@UcIjZ}!iZb)?jle7)B0Sukj%@*$vqLi@HL8$Cp4Q{1|x_ZTpP6FNKCAI2t z=fLGFl-6PzsjVajyNQ%3?<~8#etvus<$Xkx8Uj6op`t(jU`uEjZVz>x-&<`yar}k9 zjU#B%f*R1t#)ci-U#okLUv3<+G zR74r|*A^Mbvxo_w7f@(-?HY4unBucl~SS-%R#L8DQ>(Y#6Dd?nO?7_Om*F1JEjyeC2qhSnK zqxFxqTW&)Tvt~RFIh7OZ^ndHDjx7lRs z)H_jC$IE^?D(-*r4|ne{mx6%AGJRM3h;@a=s!G{{Gj0+kl`q1%JqPx7fODfB^hz!O z8m2DV04gCOE$LcRAQ(i#Se=u=$LXJn+l0cJ0z5t205n%?Yx-1yx|GF);U5#wO666@@g+3j~8bOzF;N|xM>BE zJa@nj>j{ zr*)G{x?TI`-nUHT6D-;sC$6B8`Jm&W)%-cS`}fl4p-OJ(&2v$nT&9J^UHL;k4Skb) zJB459s$5DX$37I5F*J;Z2E6KV3EU`cvVA=V5sRZnx-YPw#hKWjE&rS7@B*4f_dwzE z(yt9#=8u`I);~|3H``s0Ex!o3nYB9>;;4l$ke$9k&OyX%MtFB7^e#%F=J9q3Z!T8G zB4_j@&vlpVZv@%G=uFF%^XUPx=#33$;xGo?hJ(1y-|HRro0ZG-AzN+7eDE*@B3zp; z=SO;V*PaIv@t=nQ!T~Rjg_EZ>R~4BA)3He2?Ho1t!3E7-NfJT|6eQB91o{aB3Xz85 zgfIFlP`pUFkRKMdJA7%w@^Ve2|JFEs-)3!GNeJgqYB_96XYm@*X+O1ZHT_Ai7 z&>`V;$I_&^I5-~8isL^z1D=2Pd_2~DJ~@0o?Y>X%5(;{&v%<&*YEJKa8jWi5<*#}lwT5W%7l2L2Z1!>Zt-3PP?g zBUDtGRg4O#39V7d(w6*+ zT>J=f>(t%9{ToE7-L2O9a~$HoALIWznFu#mx1C3x*pDSt7;UV3ip@tByNQU(8t+7tVEkv@A2B1v|zdW_x zk1L~*4ZNbyHavJXHukhz?<8H6wWr25(cxP_yU%x$e18LhL`1*Lu@`k%dYx>d_8;t9>g3z7p_0QitZLB8rfFITl9GX-se8pN8|PR0=z3uotZe%<8`Cj1Ugb? zc!R!=GdE05pZ|oQWZ%QkrQMxO5JbX&7@dwoCRuy4sq7>Q#^GsKAXxbiRo3%+e@v8H zFiiOhypXnCgmf=?@^_gfY7ol@stMgainRcNZ6jB&;kfu(7a! zJP%z5h?&CejtX6BDu&E5Ha7K^m_bp-N)CMqs;OGYgBD{4L~l4Wm3ktp*%lD+*$X6ud{; zB3dIR?c=dL;I(}B-;D>*82y_>*gvP(aR>;jIS)8jV1?pBf~6GLKo_J+#SsRDv*~}M zHqGD!On!PTF;j%8HrqpQfiu!Z|CvOAh z^80k~b!;*}y8n`5>~7}S=WE|@_$Hhje1Qh)*7q)X zy9;Bd-r(bBGc8`m!dfC7D|O?>Sbaaxei+D1K2-uz`@%op*0ZuM6tcOQ4ckh}S|ry> zy0pK^R_CJ81uQ#<1XW-;k4Kfg#gMxe*BB6k3%lKg9{!J`bBeCB-J)=e#_&Q%^WVCf zb$d4ZtR^&~QZ#ppu(9F(t%bx6nZMh6pYBC2Xs|3WM2PUb20AJR>#3D?vFK^rqiGU7 zBa3#vHUfu=V$X8nRkrZyGsMtewt@lY8=t$Td38G8TGjA3VFa0p_$OB!-H7r- zR~Cb=pPB{vW}STx0&eQ3FO?)#bhS6YI}la3Dp+0;Clhq5EJMeLr7L zkcb52EL=oHll}tM#w5O6@Mt0Ks9R-C)KF1W{Nm9CvN^C+B^8xs=fg1|q%fPun_+hZ zswZBiy%&m#dw%*YNP^fN29u*5=y!$z9 zMRn|7-1@buH@aL2MG>ZOfLh2zXFs-OA zo12@H6n|!Oemd;(ti8Y{dig!t&@{=@M4=4QHd zImwExClAIEjvq-}9tI0Tv8}MgncwMS#>m6;$L5mPYz!7d$H%o#2Aytce7Gygy_lpF zSg7{>KLU&IlA;sJpR&hQy`YMihs|xuibPYH)|&HB={w7x3vnbw8gs|S&x+ zv(tzxvf=i_m2S#MYariLexfL)c(J}*}6>%mYa{a4z$qo^5+*}pPO2X*#9oL z*X2`C2#GOy?%f3}9D{xNL7xJG8OwAjgCAS$ww81G^a=aN7qswClt0y|A(S!5qI{LI ze*U|G1KXP|S0xJ}3+b)e2eq`zWDd+A#JRS+xVXY6#C6-%Q*Q2PZQhC%b44@_sY;^~ zm>RCoxv$Q`n!p|;P3=BgQF65Ra``nAF8MUaScitIF5{*o>J#RaZD;y!m5d4fUO3a>2){>e|S2xWW|Q>{gc3g)DVUV zRZ)WRg`95&f~XQQ^7}VDG-=;Mk9R{s?nrs0@VEfhbt+|W}NCe{qFSoh}NVYp1Us58I|WCh=DpmyrIJW$*?{ygkg0HXBrUY2Q4~^Glrpm(vM5`>{_a+hDJuLYwKi|Dt zEau}!NGUMPAr?}5&}sWOE6bL%`ttMB(~AcEcV{6L)|TEqcYp|!nBz&=Vm&7REg&TV zoHJHdiy3Nq`W(GUk9EyiVn02XPc0BUwHeeuBuKCWI&z|T*tqtcp2j!%yPbBFx9n6g zm@LAS;!-3FFa8?S=6OXyzorRxMTgDHjuBY15kfjL0%kyT5z^@9Y^uw+Ij(iRmCU+m zvDh57dVOCG#AVa#Dl4mhBWGYzg_Qxu+zG}X(>S1q`yQF*6QOW2NHuji4u#xZ=})5z zJ`yctIM@YIRap0a*r!33BHsEa>1EvZCklCvhN|n-;#m(2`=tnF0rDRC z*KbTFcos5WL<}q}w6DlWnz_L^L}2y-l8aW7;^O~h>w$oS3YLFuQVFqPPEICBSKzkr zB?ud0640npRRAI+c`2NK3lGB&CK+qvf+C%qg7$qMy!6!{I0pc@IZ^Xpo`-Qn@4ume z3bKFyEf<(7o`5CY4rH|kzLKykrNCuld1_H74SE33#bqUFvgB#;9UZ?|H=HrFEEUqUtXxG4>$4?J9SfUa}B(+Ri$qQ?W| zjGRbsJ`ZF{b&vfWh+PoT0{HwX_oiGng*Zv0V#Wm8NUNWfdn6&UVrC}}G@Ad4-3*Gl-_KXyn? zx)>x|XQ@DNb8Z(i5*rain@|Wb- z&lo@4eb~4p%wbdb)T3w8o1`YS>Cu>OLmv#C28Z)(&_jL26xfbj-$H|Ml-RW12dgO> zhVKoP40W~1+&u8>i3x(?;!}|2YT4N2P@2lPHMH^cIlQJ<&EhdwbB;C+bb6@{Xj^ub zHaH(JrzRYT|MqclWq+?ej&f@Xek@Av)rlWI>Z=g*;W!gBz`BOt|Ne3R9oLIC2y6N zD$#H1Z7joVNQt+;9LorVdu{rb13N8=z&ljnplGA#@A@Fwz3AKRC~W6B96?v6V>u zp;O3X#PN~|gn$Hi29#8tUtCNk}5o;(Xbn>ko?BqAvi`O@M?PaG+@G+VmhR3d5@a87R z%HEIn+s}tvAtoNNgsjDdhZkr;O+!_z1j#c&Hi{$sVAy}?-j;(1#|^$&EuoDN3&N@n z?So|U_HJ%HKf5nhGYqFn$B#*Li-d+k?Ix&TqXvS4hWHg-UA%j!)1~J0J4Tl6=VM>H zW?}Ewgt<&P+Lqv43b;v^SlQWl%1`l)HGKqZ@7Wd6Cz*TRm9nd zhh?}?l7`iZiqxTqZ75cq`3{cMC)RuS1xZtjF6$!~7Fta9*`}hP%MGXBT>1nVt#au# z6K=hfdyr|}zk^O%$aIP^)MpIZy(gpFY}a?2eUHx%4w9>*qX&ZwQv459Ajg>yJc}K5 zlI~y6%XBk#UG}o&b;+U*TrCxVB|2{g?HkRfBABLVX>jpykL?M+B^mnOi$ol2 z^Vn*$%`-cNadFKao{B+@Ke$*7957{STp(#xM)HM1_}%+XPmi)w;hNbqk`-L8epu0I zsOh0HChw7!Bv)$4j|Y$whx(rHDkXQ~LQsu0f4(U*V>YETlgFfHR*4EVb+x(xuyf50;4NA0R z0+asRnc=V)$iIb~Q3gnUe$aS0-wTO$%;{2jc%tU&6tCi9#Ml^5nFLV=_IzPtB9K&~RMRzl1$PEx=0>zBel zJUxfq21rI)Ls8hj>qUXWa5W?s*n}fG_*jifXeVw65(_60WjzPrSc$}U3(`I^A$IPD zc7qffB=7^^(Y>OGSfHgf86pTKQV}S9kLRz1su9|vMx?J~m&AcC7ElXd-$+;k)G{qs zhAi!tswX`Jh7l#SX)}2pdxPt<8$#^Pg{{q9&K+K+owdc?RbJmtpWDk#R)Q;gKm82J z*KR0Y#$zbP1P?>}iyo#mKkHIS0~(n18yyLsEkLr4=wd*Kh#~LNmF%8N&=c5pxvYz! zLW+O-F#&FIzsm*t_c>2)ZZI2o$OLES%b~j?7=9u={e%D6hUn227yke`*TJ_d?eAd!iHa;x86+U-QrwY_CC1k zg?{SU*>jP|2f8Kk(=F+SgHmm&KCHygF2iy-YwM)O+@Nerz_ApF0F%3|eP^JpQ}eww z#e2Acnwsjm61$J|@uj1z7vB(Xv zeOLkhG@IvAP{$wwOdO|US+~o*{qZ2HbIw&L*B&=7H z+j7!twTWmMJoH}bU|!>_-l*!B@%4I&{}r8hS<0W%m%_mswt&%64&#ty3xv3IluyDK z{`$C=jXq#E7grx`I*3ePa818en@_4zXUJfLPSnT=%S%BU!Ql2)_c!r1J~@KW3*As8 zMU6t1HDY3teQf`ZqxK-uD21T}a|SRjfg=`-4y-x(?Eour(g?-@W*uceSTE2RdIxlB z>-PC_D&<2&tEqm|1oWaVboTYx(?lvPUPiaAcBT*QFe*m2Z@m1 zlq0t0b-tq;UBMvuLsh&VVD&%80KX&koA}eT&AY*3yR&n0;2^8>m}H;y0MZRW*B5+U zOfU+v5#;T}*91K>Rs{4X(-2*UPDs@~s=5n4vh?@XP`2mnIEca=SGFnYRvJyl1 z`kfT`0PJ%Btt@h5)kpc^`!SjlbQVrx=&?TRR0Z;Cz;}%-2p-bf@bLx+3!y(E{%a;F zLHRCi`-{w8ldBxLv4>|8bL+3+swFs_Sefy@y+VBX)~D@rMk;tXir>H7A#YKWe}KL8 z1|6QL9Fl?mS_ph!3*-Asb;Gf73x-8Ru`H1s^HnXiI~O3W@GCw{5=ssI3pMWi@cxMo zn(UrrUymUk51*ijO-!r=Xps5^Na&xsKv;o=91qCys?5d3-^QVkR$87~tiYaJC7wKM zS=`t*ypQ$2w#~I8lE<2gbc8A|*1i+U7j|klJHw#j)Y(+)c3c~NZVSe*&(DjKlI<&| zk0_;92ngo&FR6h%s&XzbN4Lr8tK=9GC%6Q2e+%2m>(3Ju%wN z>D)4-bS-Lpe=^6U3iF7T6x_QBOgrt2wk-ru1F)4?UtvEcoCv7ci!CL9W6sBAQ_0)E z>%F&VK@PeC3k*2Ky-`q&m0CN!9+$^(c3O7M^-b@l-n!%WGqkEfe{PzLb~awzhRXV? z2FHBXe&f01<}BJvPi6HXJ|C+aq|ckL22M}yf6E>JzOx?OeB5z51=%VKPNJ=6@I_;(f-$>N`srp5Njq0hAU>@TLWvpbM&V7gs z=!ekI8U<$1?yfE)LVzCrekk~PIGe+H*qydkiLGQ=^&n3Tm|^=KmSq3`KSYXeNV)0# z!wCrW`Ci!?hRoK?qYAVCa^$(?&!Twg905KdU)MmD-6)n}C|z?3|9RK>Ql;)yZB0!M zw`=(lF^{@wEHK2<1;JP5zo#bTCAtC~MGFK_sCzGS9&-hP4N$CKuZCY2f*;F*Wdp&F zzee7I7@i8g{s#P4hoSVXS;Ryt6CzfLe?~^A?0 ze8~)|5`((T5CJhMtAzZUj}V1e$xkL)^(b-L>Y=_kmlmgY=!=Ank04 z#Ocz=&Fav}La=LljcwQ=n1(4CQY_&; z^Tfhv6|(f?&qFbCW6%D|+GiaQ=C5GBga1J|{{9Sj`?Vv!}f7UcLU z0U>OH55t@`)z^2Cw)Z@?zOAz@Hk8cjyP$y{MCd!Ly6ihdcNHBTy-Dl;@$ZvGgOw92 zt_)u<`kf;IQ)Ml2Lmp$~feFzt)7&qKX*w%Sr>aVuMQm_PO8~tEqLr!#gTc}{zNe0( z+7=6{Ek$2pyD|mQ?r%xY;P4sz59)asd`8xCOI2k--nI2j|NWz5*^_P^##X~FCIPle z?sydD8rqs_+jHD(3*7Xx6BheAdV4I!SmVATgF%&!?A?l1O!5i0uq zQrR{w5rtcn*b5}f*2u1W##99BN3Ft|jiRxj<>YeP!HXGv1Pp3X*;c5g#NTWz=C;Ud zi68S1E*m~m>`t@$kbe`=hPjGRQw9ll{7C5Sb0$ij44uE_aLM;j5rYaU{hQW83;lMN z@4AajJ~8Hx3c6>X5YogBV{`o^!@u7z68V<#b!%$nAO}kO@O6gF;;!ST878<5{p^t+MkmBp zI8cfu5v)B3733`vM~hlo@+1ZA-S;+d;N#~xDjokF_dvLA>L_+Sd(I@g&A^b)U(;F9 zV(V6^*cWhivXVz&R%`bXN0#$_>8C%Z3j1;#W?9sf6YsZgREJ>8b7&pkg>DgBW>zWM zywsC6Nm^3p+iPB~`5M%jxy6uw(-^1U@L9q(?kyy9&1gvFgWJrG)uDS;@V%=Leig zh;t5jvTt?+_V{Hp=;I_zoTTrDUw9i;%R?3EoC-a4!|wqp!0*0_O04^x)1GZSF#~>I z*WN&^?z4bNy~+>#6i2o44?DD+lHi$!?nYn>f)Hifa8L< z+1>R!XO8ie*^-0Cnt}yihQjfZDYu0C844%=Sa5>rWEtzef;LN4)7|3!%ErX=gp!S! zlNzBfEj_=&2AhptDUV&2Qm zRPrKuKI{_`)_^M@3{2XoUPrZgzq{)u6;s@~uKqA595Y4&e%hT~!?{zxME4-RuF`xv z9Al6kT4U#@Xm} z_2D53+H`tDuW@_b40`PaElo#V4R1bnj%*QlmQbY1sIpD*V^#}Btsc9{`?UCqg!s54 zl|!B19PI4>@sDG(Q>7fYP9T0qhbponQ<6Wx`IrdTV$J7!S-b&NUCy;BANz0oF!W4r z6Uj`na`XFv#uU}KCk(p09-~lX2B^rXA@2!Mc=fT;LrnAE@MV=C%|uFO~kLLpWoEafT@Qjx|!i>z;rr8Msv_Xc~~{2{Vo+;-fm`TU*M# zoyoeB|MBqAm=`}WAbvZ!Rp!9iQu)X)*7Xj*{yzKtrkaGRvCeV?V@206>1 zSQGUGQBET4lPGi%7>w!dU}^(KgB5#>xyua&@j{zO8=q!y5Bl5~6lFqjbFn6qD{ zS^+>GMEw!#4EsNQ_TGLKi{Ja{e6vi@sd04_0Vq8I=yy}J4Zgq@(&2W7%9~cJ7ET-3 zs@XNePrHs@tj0@eLU|!&qc3>2&&S-dD9*ap1jIz4`=o zSo6$ogakM!EhGLvbo*enR1B0kP4|mO0Whsj1^^S%cpIAr+NEk6rC(|TdO48Ov6#;%NEn}l)#M8J zdJdnsv_U}ev)bx4ium^z5<4p=})jSrBx`-y4P<)Lk512 ztB(GEbL{QyVG4*V)T-iXAgkDVK!Y5&+piiv&l`;5PDPG2B^w3+za+qBR8MSA7MyAB z@9*#J{pkN(|I&G8DVt(?5lM|Y-^WkP0hqjqD2wG)P-ib@1VQ*dTW~p|5@- zcCjLT_h}99|M}MdrGPrZ?tCQ2Q?W2x@Hs@V5PESvl>xm)O!zbpqF4gX4&Y>vE&*ai zS#53XK2ZcR`1-kgD{#7q%+0#>phI^@i4DdcG0L#MHR9C>H2rA;5E5a z{kpCPd~W!HzLmWt?3@A;acy=I4jnq~bXm2Ib~gFUH669+U))Q3UT5!{YqD4$ayl&7 zPE(PD^wrk+s@m&n>ufPS>S@R3qoceAzMogSysGw8#G-&B$&982GpHi33A0EoAUha=CR*Tbf*qNA+ZAc=aGdxD!J zW?hy>Z9F5+S}9{a6x(f`dF+bxrGN55b~Yzlz7ME$pR50|edlx8p|Jwdidbl9cGzCQ zkYny+t@cNv(3G+qzwQE(Bb<;?c;E!RKqRT4MaDSbw~efn*SK!hp!;Gw$7yi+Lo+iUDVBqu?SJJM1E8PzW<4*y~Ywa=J!Is3x9+`Fk z!vQ*)iSy|~5jZrWQGJnQZ?ZP({C@x-Kqr_7_+Gxg_{C07m)fPf0LVqBFO(S!TiG7? zx^SBSOklNIO~pk;`~4q3zn=aDeEnn6Wat8lR=*Cvo&`4yRaA;8)lwg%s1bfaD1n`w zods!st~q{a0DOs@i3(!cW6%w=Iw7(5&VskjhJcR?7(D_%!5*p>u_AJy)B8U!T0hW% z1x(2F)Z+T+K1$rm_#BPShZ1Tt7LLz8+o&e|QZ=uWYE6By7b=XF=K)(gc>wjYD ze^$E(7_yfktiD^|QHwE#VtXk6C5Zjd*Z)4X!yWjSE-uYW756N5Nt*+KB@%3_Uhkmkuc!t~+~DKb7LOk<@~?;q>= zy>CeIJb#QRD>IqhYv&{@0eFNVv28<5qp!t?19!o#3Y=T?z`yYH1MBPL2a{ zp^pB1=RI$*O+<=(0k7Zrre%8o(0pDn3nd_GxRu^9dQ`O^s7rx!T z^A<*d=RkyHA~7>J`5uKy#v71}o}Rm0tU5&(wT-RTlwVJ~bfPhCq0yV8{pW;k4>bJa z*9__aop~_Lg;ja4&yB8P&+UC-4HDO22cdq;)vu*jNCwj9TOpZL%J<+z+5#SA%$sS= zok~1Pn4>JDsByPwJ+*1iPUp_qR2iRq(;N$OOjGJAZRK5~SPXVj=Hd9W^cn3XS$p2> z#t@@Y$Hv3Um;~ROnIcXVf|Ij}z2~;Cvy6b33{Jb9chFz^P|z%rfzdQqzk1)s1wZe; z9s|DW_%QLY7o(RhZ=JYMGM8~gg9rry&fcq}84BfOBdMr;c-!F$$?&Ebjld*FBENZ5-W?vsgO;2}it)z#~yyh(< zSw|=s4^}l9Xq3)82HeE`|9WqP8KIz{U|yus?6lY=_haPc zbYz$<9700>gD5Khe;xr?(NQPnNGd8jV8n7|#1t>Ofb6H~f2^sb1X$JHFl+-9TU%S1 zIFynrkk@2JD>2kX(1^T_l1>T&@?%_JFe@eKK*Ew!*unMdRe-{*lTlP)JRNQn#@`*W zlsD$^Gz(?}j{-QyKu*M|DBw9Fz!PY9Ys6_54*ZWU8n?yrOCxM=4ftdVxt z{`y(6zb-kda6}?Y-#F}8w3#<94?r&6trsS(E@_C{=?B%|8)HJRx~x4|izB ze3+ibbd_m5D$na6fof2?k&uxiuI{caUt2mxQ{Nap^`O;6D1Ev}YE@<}4g->21@MDA z;J+ctO_x%kV@TpC3k&_APfMTwbs%}WHRT*4azKe3_U$K4HfasOil@qJF5$|tQuP!4 z$o0aQg^Qi~Q&?(1>p%@y9T)2gdaq9U+F$w@+3B^eBxA<(>92%o5ENVVc3+unC4aiY zFAF{-vy&ok*P_ge03178D>q&VJ_e{zzk|=6+6-8u6fHs98N22(MaV|ZiEpqpfu}Mu zGB65E{paU4p5UZmZpolvpeUi=eD7im&A#&aeLnAqzEJ)wE-nViPc_oSy3WqdHcmG9 zKh``S1B%`Fp>r{T5%s7t5FnPzE&hdh&=uC`v3syb1-8KoHb^qCnpzmRl-lfySml#f zs*IlnFbe$v!Z%=5!>k@uCO+{crku`Y6XHFsDJn7^4oC3VaUKUgmW6(&G0fqaR-QR{ z*`9A#KUw_?DI*XGybt3zfBC=JzcUV_)`l%Rk6f(P4Wk;x)mCW%=$b=*o0vN#g(4E0 z^0=6A^$ys@?xiyfq00wKws_A?vG7t9Vpuc87B&6{*MheleUIHXpcd?&`ndY>hbZ~G z8%GQyXXS3+^|XBkFgSTwH2$>obPBBIslV|Qq1_ewgDmX1jgR`0vW^_sYLRdeWmh`F zSRbp&sWF!eY(&wW(`$74KfTVfA7eD?9rAxtYb)=cg|qV1A|OrAXgiA+TPqwUuL6Ho z&~0bG{BHhZ7VgpvG6sdV>7dNLctinxTt?<_l;W21D8X;(%*j?yJ+9B8I5606%4ep? z?sSNZj0_Qce_-Jf!1OG?AKPl|xr|qD-{^KcrDNz`|MFbN;`sIPVxDttm)p;0pxhu? z+`%LRdsGIkJ(MLTn_ktbp^R-zw7C4wKC-tO;ZB&818kW|bK>rMZc))b zaENI(`?Ydw9At6PjUq&4>M9h!AIE?;U@w>RVTg>UzoUx`esMg(P9 z2fi=1&_PKAI9Cpjl3jWG3XZJ}6YW#cCh0TQF=g`K6EW_h*b&ucIrddnQ=HDt&8YtX zo5OEfTG2)zwb%I{noTgkA1FS?iWPQou(!X8#-J@k0h+!^bb({%J7t!f3%ZCj`cZ8R z7UPf@H)OL&kkST_24JYODXv!D=ot(mO{B51x99h~EqwhU$p;r4miwLNdkSm-246iu>-5;Y9|#kK+41ewBvx5jIS4AOIDAjo3@uF@TEol#`-u~-~E7`y@0+aG}Q&uIYw(&I|0 zSG@pXYwj3Vbpi*G{cod1*}%jN80(*pCR6N46<0kL9<`qTR=b|end{xT3jTAAJte-w zS5c}kB&v)lk_so*_qSw$>Wc;^o8(S3liQM5Vl*fx(Svdwt>lC3i z1Y+$H8)Yy0x$FC$39Fq~9#eWG7KW*>1{-G77PzM3`*jg&)XZL;W=-B+TWH;9*fvLQ!%%XQLZcF zLSAyxe^+8uuT>?I|9U>h?o=!E_GHvn>UVtK!ndzOv>6P$ov+GuHS7D$_osd!xMrlT z%q^f{)EjdLRpP_Qrf9ZMToxZGZK_h+1h->&R_*sKN9>*Vc$QZ@+F4HHh}f(8&5qm} z->+8TFRXU&zZ~9x(&3I{H5I4h$d0jZ-@D?d3ba2gBW8p(T_n1{L}6K#TGwn!_E1HN z(c9%Cyfi9{^$ppNqFU5WL}TDAiaq-klWPCYFk@d`Uf7TEDaVAtio??&PohhrG7hRw z2upFY5kcI+KQ;^!IiX@}9@{Qgsj563tfgzv>ae;?=e-H|J^giX@>${dF|__Qs~PaI zXa77SI$P78RTfuL&z~-y3z|ERSSNhF;(H3Yz%Q^ws+i|g%*R5Ka@%zSsqnPWw{Gb5 zS(T^A|8$@#DB${FPtVDqSUJ&Bq*`MI##cOCF9MgUYnO@BRKU(c4jx3*cmFaU;J;ih z59C;-&VhL2e-SMW)GLrRfQ{#LlII}+V9fuUu5v|pMJwd8%H+r+U5|pQK*Wjl*2{d^ zDU?7m{?xt$vF1_4q$jE8Zr{#Zbw5u+8lj;?&rFEYI5zLjk0;=+HR~tUlhaX|l3Fo29V(0|MfvK9 zjV9XEuYj$z`*BTo6}$}wd6VTlht(2snB!IRGZ$8=R>a@OhS>eEYd;2ofov_Zj>?W7 zXEFL{{AXU}{y4oCidMcn(vaa5rb?BM2%4bP9fB+c*l;uKzPsE{({P+e`fb+Yd=%%x zX7?nj{!mm{Qt`W`b8cA;hprn}+y3`?jbHy>9(AuXyFJadcVnfRRTydF(lscm&w=S7 zje7MGTX>UPD5pJ-7<1c=4|fo|yT6}^nI_{I^y4%oaCT7d=g!bdq4r zrejDN2Q71gJCF-hz6+=1-qdqS(Nh3ZK$9%|)4MSO2e37Lg3_HIofW4c7J<=4dsLy7 z&2(I~9J3)dTf7`PqxHdRMM})_@qw9H zY5qsEWjw*o-}Cqk55Dfh%?brVUOK@;be$}l-Ic+-=N$rD5q~yZaW}wz)`-UL2bmTm zJ(JB|0~lv&YvDOW;Sa^`S!?@`({+I(O3{BKbni{y8}PjfxQfMLkqd#Zc2ay$B!MD} z(hb8-5=D z_t$-#e7zS)fBkX%qC=#p4AE$+@Exsli$$rvQ=#aLUAk4r>BR7JvyQD((d0 zGi=iXzn98nsgqhJ!o2{R#ved>>%XY)29}q0<6$TXl*$}tDA<{BzSP*PCe>c=p(w7_ zwKWZKx#5ewP`4Vu;U`4qlm|3f&492AlLC*3)Qu`@-=!Fqm6+e$nQ1CjkOI{32<3i! z{2zyPlW)*WA;e$}tz=PFq=dt{ z(Irt!2lwYv&2%bi))?wy(KQ#A^xEBLbMzhpjm8(dF`AB*S?r7|I>%eE^D?K4CalWk zp=Z18!-lKPO_>R?KjIIbdlSmACP6J>`(m8ObuI80ey z{D_B3A-tf%KEp5AW6f9u$3=Vhr9Cl^lR#V5PjHJ29Kk}tQlL>%M{XOPoL>T!O1X4? zVb|2IADCnRv=vkGom-bsHQ9?~3ho2D3%y5f`VMA3xF&e?N(Qhn?%_-YerXa)S5RZgY@Rs%S9A^?J$# zUD9;*;Y*P!@{wm zm0XijUsI#{HVLI_h8F#o@xQ}rm`~eUgt93-{Zkd0#$EzsJQ%$PW*D( z?u{0e^TbOTdv7gZtfbm7+56f=jlVfpaU~I$o4^^Xp`Ev*w-<}4F~bYKFU@pVjQrp| z%MtGcfl6URQ`aaa1zV*1o`9J_B|~d!o~F^f(q^Jv+(EEj0&6HBGIDA_YE3#xU8!{k zyit`T7m2bQXW_MuV9#hRKZnL3`f?@_5fBVJ7Fe=n$i_UKwZ(VgQGO^}mvRx(e~+U~ z(MU2MgAXO>VmwIRg;`XEb%%CAC;WUoX##Rm^E8v_JUfiDQ3@P{glJaU1NB4da z$TukAR3~wpC_A|nL{q^!)5Ekc;6#W_f<fLLuvd1`jX!Q!vz^>KCJr2IN_Tvz;u4R$e-x?531h;KMU~>uHYP zl!Qk9mGt3#IN8$TpAIkyK9D|5VvEUP(|%iz-81Ui9B{!|x=2!6lkW_-paRqP?>=~? z&XST?p%N|?1j_bA-60^w12q^7dNQ%01OssfFf3*=?-oRnK7jJtxu1QH^r%cx<>i#@ zyrZ~(KqsVwDnt0u;fQH(VL76_AVfsS#^Aju@S;_nQ$L7n=j0&fTV7~4QX1VqKB2EV~yy7twb;jQEW;>Y5m9D2lT3d7r0gbAj z9PXt2-kUp}u2}Rs5OtbEV&Po9K$45c(eu2!u$6ChARMOBiCNLo$j;V%rtP2)2ae9l zaAc7zA0>&AQxa8T<;i}Qb#zesrayGvwlAd-oZc7$RzBuJhwXMhqupU52O%6I4hWMR z6q|{YYMV<;*Lr%DRxU-Rr>U9vGbkq^ZrlzK;sln-{Hn^OMxSF5KGt$#r zzz`sf55u4l?g3`#^%DJcN$&!f-&A7QX#TkC!$yA&Mq@riL+}^rc(pYEgM8NChtDLn zo5li{w!2skzVf*EN!5lvMpf=6>a7R)*`{Fpm@6M9N(|x(ba*qi`IHl8Fp-)$srB}i zI2ML?wE8^D^w!=+Ino>wf`<<^%9Du%G3E0%uRcj0LCtKCaG0Tjs5wC%N<9_`pA9#0 z!TkoTP~OztYKS`mNn;%gKHy)Vuc@J3H<}Xr1qBrjGY0n)S^?zr7J5uXX3jVl7 zh71)26KdK3$5k7Knj$Z1ol$u3|N8hh{JsC7jIqh!rvrgkB}TX~;aciIw(81J8EGFn z*kdS$GEB~qrlMG7R#8p|*c8+X?k7Tvn35E#7wPKjt9K>ed$K}waYT4{BbrI5Nr9&5 zcg}uh_JOU`@#Hs8E{jgNyX4Wi?P0o>>;~&(P8j;d;_0yD#z@z;DR3o zpPfBsqbhkrL|5er)7weaeqz$(^75qkRg_eUJyk_fFuzcgf>@3}`fL*4z%{lS*2BnT zC83S|G(sxMFcr}-;lCeM^r1THl!VvX9#@mzeaNK|e$%1m)dD>}#cUm&Ju$WJe&F6O zXRNcBoc%}3OTXE_+(JTs{o?#`9u1f6=cfX*_wmG$<8PY?5{4>#a?6Usl4h#(hvj@e zzv~~lGz3;&&s$>3@x|aLX1ufx=A!Hb10`gkD6wlmJ^?2CnvY5&pz5^}Jc#TBaITZ6 zAHi0bnRx<%(&q2Rq));A4WcJ1YvJl)aKp#B=I6@OtrSpbjA4i}@@9XiXNdA|9f)4) zAsN5w#g_@ZE|(shR?@%6^b{C*v*<-AN;Jodg4Ihe){?LtLjEP-`Fs>*icUtPBbk^VLY2bkQyAvK zpXpH&h}j)3Co9UZO6A1H`L;C8J2p0cJV?J+o!#5fTD}=ePRE)oi?U+If+QZj!;MoG zVQ9xD=S4BSXs?;j$Q2${r}{@NB)Y?$1;Z$*eTT!HHB_J5Xd`+yENiHH@&3A&8aE~_ z&uhCJrImcg2sXher8!bwigk31n|kaM<&I%E;2#U9%p9Yp`6S~@EE+X_;+9BZla6;1 z;xw~t^*OEW`OwK#FiFLD9}haexD8_*tN7N#mb zT85E^!QR$IV0uh{ffb)4@N{Co&d=S;vaxQC&vFqBkvEn5t2BC z-1tqQ)HS&fSzIYH6@vTpa$zCyTl$e2yRjeIH!1k`Sa*g zPg_&;r6pis5hL-5Sj`f3LRDHgAjEMBDK}87CHdzMzS{eCH99RV_4N)wv^p2@tjHSp z+SQnGaS@d=+;;a1Ryt*`UA1HAyXiCS;p-Wl*vlcx4JF1>q0_MC<2cNQXotGKRZD?H`eNYNowQ$KuG4o*~ z<-Rs&VVHNT4y24mU(e^D)E^a}2steq31=^LKh+lNao77n-xsL?-Xs?j<^Pd%4i0(t zZyR5>-BvBPY-`!J?Pc4xyR&WEwp*)~y=?xj=Y9JZy07zl;y6Bsf;L7)vhzou3i!wA ziJC7zta9?#I3?nbup;%JvbqN}T314svzX&_P?B$E*>=B0cuG-FS%Rj#oe;arJ;ao6 zfw-{cCh^cwrX^O+s1aPxblv{eTw>VTR;4ZD&h;IUuW) zV9jyTxh5+)2<}C{rpKJf^bFdDFRQZuxx@!|vmD?J{meg5<+EzfEmbaWWFbM7vXHX1lVF9E#}?us3Pv3i z*Z?EQRUuO`0a`bLwqC6v7qCqBJzry@4UkUKTn-4f0sC06N~si~JU{ZQ)Df=< zl&2;`UD8)n`wpm#vUvP{N@})K$YVG33NU3sW!pCC%u0@F;Dswo+@nxiR%zNR-9fMn}gG2{?e8;RU<7Xxd(JRwch9 ze`oDs0cbQ;12|z`Q>QN_FL;etbFoBE%o@uFnt|i;O2HBK=Z+yEGFZuf4jL}!qz)=? zET@?5GMGWi<>fFA)<99#z#%50{ErR;m1?plqm{Syf~i!MD0RIqNegcAfp$HMh(b;>d&3yNhmKZJ;G1i zlV?r-2EQN}T6K~c!X^Cx_+KF`i_{er!5T%l1C%PTi?IcHSl-R0;>@Ad$oGrQ8V*B z#o!MFyyRrn6yxJ@C0A3YnS)8)vWC)5<(p^5i$GLc1sRDx6oKytkB@g_ugC=1#>Vc3 z!cikqG&IsQm79Y6VI`zW!nZ?zyD94;B@ykc@;LvIl@1+Hs2*ikO1J!|iTc8jhaTdQ zV8WasRh*a7Xf_=<6imn^U?^!uoS1YG2HsrS$1+x~;|^Bg4e(c(Gc;XYU32(-xWD?c z+B&vmD)>9)aykh4h(iNuL<|~rU#_V&^AXUmp#A$)bF5<(SOVwZA$8KYzc|N?F!>Km z6*EH+r{CZ%@?@cxc_tbNKr@=pd<(_HOdL1y^ztg6ZE1B%_Aio1!RRR{THwHhe@C11 zh9%kD2gVA-bV<@JU?=9nk%b70YRC+0f=P4_ zM6NBrA>F>Q=KZ{E_lJY0qhfuF{gwjui6Q9jG$*uyxwMrsm^ht|qdJ6N z$NX%q@QF?QcVz8Fp+r+IEhE28mfk2FzFySF+g#~K`seltEB?KI8+8Vwh_yr0HkUX( zQ=^S-IW?PFiIggLSh)xKf8aa%>K;pnlCfa{D~`4+iNP;wPx z7%PSa2rehR78$v(l2GYk`l;t(p-L+~gd@e+MDj9_{09O@sSw0Vab_o!@$7*0eQzI8 z8G?lG?E2cF>j>!VB({^Ua{;;;Abk?uk?yCaoDvM-WBww_tU*&JZc1aoobf$CiRu@S z3Znq;f;ki113<7dE6N5$CS|{*9{{q}JWPpD+4KWo&4Zepc)ASUOM#jlqL7(i0adW) zwm1R4L}48Z-f%DrXU*Bp3dNk3k}{nuK$KX7tlQ(Q>2oHPUD*&Ye)1Jk>ibv#+klA= z03)&B2;y4~!i*y$ZXe770N}vA_mrH_6Lmi^R>pUDQdMyk#zLA{J$kyglUInge)D`TubEdmD^ z2I(^TJz%Va2~m0$968UjV=)Q$--Oyc)i-X~NWB#;Jp87-O1|2P8Hr%?Q`$td0LDlUK=82{YuTZysV(3)k3N!TW46&( zN5=rWuPI%2!gC9*zU?`d#2=<9-_RwLc#$q&4hlc&p#M)LOooCk%sTL63RzKIy)+j6 zU%1A1=g~_=a#!kjbH_k7afDc0{(8V%0+7S{=+?*}a|HbKdd|>hYRfo1G2nra3`RSu zfw?&aGVcciAjK77kVr>S>x+q(K+M}xUf=lGC6a2Ee251ldY*fc5V4;|v$t8Z6EkP9 z>d@Xb5Ck9)VXK5*Dz$jVZ+M+@qC%5{KY%|5f6cFon$FldYrIA`oX9(?%NkVwT<1 z=+sp`>eP&>X)NU{tQVohVopOR6jV5fy+>z&elRdcmpIy8{9Rqa-a-c zq9Xv6Ujx@2bjiI#kRmKD-v)ZK$wQ;bX?6DymGzlfRpj-mbqDf`pepYT$R1PR+3(`aZ$p7?^;yW*5eVYt5Sl8#;JIAFoS@@V3u7~ z;^i9~{}y2M;=D@$p4u7^@$VLgA-i|!f(dzk8d%A>7(3Bw!i&4{J!g}mpu;1u-TImg zl*7#{|G1Jn^$f%hHv17r-W_ySswu={|1B&W*$qfo`VD+W|0jmv)W^D9HpmW^!pVEU z6wDd_t@3=Xm_dxu+}u2VWllIcI?BVtvm-wwpFYu4r0FIG3y|{z8W@6|8GmN6TLAHm|R~U?` z08S}~LT_0q0#W+6TE?07qjDdx(t73~(}H|MPW zQayDrWHh`%M}x2$PKI5hqrJ(hEL>W$IltNZdDRaLhHfs-g8Z9sN80ui6|LS{O!HDd zchrJ2$D{A=yX(C!w^|?cPmdR-!p%e)wM>TBr?J>v%A>8tjmx8__Gz4qI9)>Y2eXnZ zVOvYkZ%$}t8}?})?<8rc-Fn-(5s`0-+X&h>tl$3~2YOJ+v|y9WJ>LRacYfLA2@~d1 z*#w|XQK5#i%;UF$J}3=>w-aoRYJN#aGhNWAaMoxNFdpeHY&C4-g#5b#jD(-A6LU`1KkT89hG0x5)-1}TliJ|MSF zrPt+VWb_|e6G;d5_!aVoipSwLt6?Qhba0XyP(i4h0NcpcB5R)0*i}(i*u&I?I=h}k zaf$~&MLup^w>1uS=!UreUh}3@_PZZ#aD$<1#ZDrb{jeHsVpTemdA*`$CHZ7m69*^v z!|4S;oU9|o_w|+?`Iz&(@w=Pw3-otQmQmr(?fW_Yir8>88pr4G^fX?79qpZ8-qqr9 zF|Zp6s(3lfs{EZmg&5U%&?-@a7jA}#YZAZrT4H)uLT+65=G3Sjm<{##@FAOETcWkupJb$w6nT#8JneIL(R+fa;h+cf12)|^;Fk7t#o+~7G> z#0|AH8{9n zDcey|)#rh)z>2$Ux%2v-EEEU9ppamb3ziA{`0z!@bE|NM-7)%S5C!tVg4sQsR@O3i z?NE7*mG=~Q7J?~K#WdR5+4%vIc?5klD=RA_i4m=Ch|(7ZcHvyQA3uIDFqohJL@D6t zUoyzxEER8xLpVMleo06D>HS)pjHo zp`Q%Z<17*i8cttgTDSCcHp@;ZrrwrL8Y$&+0W~oB+L*CbbVDA7Q1_Nk(up#pr$vB- zL6SctD1~U*VRPnUYt!o?htE&4(MV)%9j_6GURzs9mGZ9uigP~w4U@ND$EKq}G*px` zZ2iuoLSxNQU$e8Y=m#VBVWBEmNV>;CfE#K<*mG3c=40Q{W!r0ycFR_e^KyrVqGgVX z%-6X+#OJ;$)}^1qWz4D3Sn4y{EoS|Z%UY}v?(~l+{MUCZrL(!DorpO?3_(ArU?2w) z`Lh)u9H5rvuu^9A+n$aw z)*x65HStqO;E4XAq+nBDa^A;C;{Zqa0^2bskl#>jEJUIzckqaL+`@Pd9PQ?-mC7*( zy49n+=?5SBOMt zS!}8ZSgDjHQ|^|kn=73c*6D28z95CxndT+}PWPwj)(4ch=>Bxohb(Wnr^WMHc=!Rp znNc$SDV?^ywch%9{~p%q1rwq)M^}H z=@n2OrXQW3+D3LQbt%^K4)CpRVf|KOLZYw*u0j~LZZl>#JxBQ_)oSC?Qn7O0(vkhu z1~PFMf9CF6=Mc9~S*DtgV$*9k8=OdWHvmAkjI7nI<@Xh^s&`c441UC$j?W*RXOz$t z0YengSuKUv8oa)5V+o|A@>yJ~%)Fq5sy1u}TTrL_%x;QUlSWKjipo{}?k$BLT-KLS z3I=6_)3}O(WZJTHsqsHr@za8>B#O!%Olse2OC{xd#J>00TMB|(8=_baEFT{q&lid> z-+G^yS62gBMigXXK0_keW#|H=R669Rr>Ch5`g*|FTKqi_NM|Jk@UZu*`n~*aXC;*I zd*oS90CDOYf*KPmYx1-ikoahTD4k0ClWkQBXAx3k{a5Se2>xlb2Y}8v=?j1;mCH72 zDrCkqlePU;W-Fx635@GN@UMn&^Y3wYyUh+4=WnqKe!{Di3f&aw5kNYeFdyK&Ordiq zz^B1}Ay6Rjqb9!fn2>U?(5dn`oWi0>13nO-%t95XsA|UTG@^1=$PZJf{?htFl!eeF zW1t}lu=5UCr?d2Vjj^K#-8L4@XMXt|wy&(XnjDW6hJXxzaxZ)2%3*fN{*<>$^tjZv z<7?eJ=%06>Ltl07Ec3XCZkM*oG&@NUSqW)f8xU}rX1|Bcx8e4n9f4$?HxZwtwyrqK zJOzO=&8F$7tMgP&Gn|*B%k-^MV^P*`8o| z^{005iKGrWY`RLf$o?61JyHA{Fm)4Dc|e1yyUE&FVVFwOIxvXV1d7knfcL@_QcBaW zK^aO$%Fq?M zxX=br>wE(Il2A?RL!|sJKu!W2Jr%XIUX;iD@CyvIqL~1UNt@^WDKI;)=SUTAD|NbE zhALGea(u6Y*}z}OQ~!^ANO8>?|hPD@LR zdr+T!peZ>fp@;v0v{i@Iqb>}DS2AU#Ss#o=W3-Xw0)eOg6?%hqtoJ8RjNq`t7}qp& zfoP85G^p49dSaPXsIgGD+h_K2&Esw@LWTQmmmd#FYw>ZATY#soet=U1j~I@Xhn?N` z`0Bd5_Hwel2Z-vU((OE1ISn?e=bhq=?=mWDvr=e&O3$2`gn}TDZ)euil51vn0h5Uba#J+%6F469% z_1LzD>Z<;2GkY)Tz+*YMKNJ-3ec8yg`*#T>ie0y%`2R2f3we%{Cr@@#`DG%TBpw=u z@{RZH<*OZ&me3|S8A?kp?G%R^PD}& zNxM1zdMC-{PX%2Q79zZqc)FE-$L945D5=aP_SZ}d&0NR?6m48MRKnmPLn^}bR_PWX zQ(gq!q*|xr5`yg|nT!uKEfR+3{abmAK4-jt)-A}U6VETeH;2ujS(By;N+?Tm(Wci~ z^V{D3eT%ct?-w4?n=8cVtXL8fgB98n{r=GFbG7jt^-ovVSIri8Wg67zFxdhaZNwWB zaJ!Ivp?Z@8WVXF-Walg)@6MjI8mb(hE1FyX`pn|^Uf>YEJu@(9)`PUDrM*W9Yb)IO zag7Pp?}3rrF6U|>M ztnjl0q4U0=M`&VVvt*&Dz23rNtd62nm|fiDQFN4R&#y%uR9 z?rZEUKU#ww;A1A=eP=?I(jZt+POfQcat5+&PG!+dMXL}f08 zit>3pDju7AbwG~GqNv>K{#>yhif4L|($j@O8Y$K|WXL*s(m^y6FH5=4ONSoE&N`jW z=Cu_lDxFrVqpPl71O5l*>)vw3Vb#@;eNW`z6)O!%(tWI1uv6+Hf*M)LZ;DgJZn+ce z(@RLTrn06EUsu)5^YxPUCllGY78hqbzn9;n;<1=|5JRhiUEeN~2!fMi|2oB#moV?r z_^diDWJH3urYg%-XU^yu7ZIGe7O zr#dx@7(7%FLNWfx_Rm69crPnt@{mpsXhzpT9ao$3r@Ys}gUtgbuIZBpOGzKWMECKg zKt`mn@F3RZKJ_Pw^R{^`L~L8V=F{(p~<>V_tXP#+hHtZG=u||5WsWMuMqPw`2pPdE-ruou7IT> zb=>~htq?zwHpo@RedEdJ?T{nUopZ6v^P$M`pBv5jR?2$Waj;MHh@5!>i7nOcl3i7v z;~?4b3Fw_nvAe$hL4Yx&^QSn9RCw^DUZp312ywkE6&x!=Poa52y-Gn-oUjceui4(Q z|MK)42n*i6o$YnMxZ`@R(eH8}$r6om!sY@INT+t+N_`>sDA1o|g?h0~U%MAY7W0<@~g1z1sPzp}aPVp7Xil(wEUE+Qy%*6!D75ak^tch2r^ zUgXz!D5jUC2OjxGU23k?(QBcSW4E3Ql9zb1)REb62$SMQr15i7;NC106P+p8R{qRi zk63r+x}VQK#L9W}4Avc0Z#FsKRtMpY!pn;BseH*yUL0gYV9ge7dksE(*48M&ygB2M zqp09XFF3Gtbr+!8v+BWfnkpb(9m97RO*RAPyP8sn*;!%xGDAS57*1cWfk?4BKmW5W zuo;M9uGMO;C@Cqq8gxhs@XO$Ben`kmhs=XygMjZgK+1Rml>XAuCISKWqp<|h3Ew*- z%@Xn%^bVY}|7U9MyT=+0jKv8bF8v}^ zssS#f0kn}mkDH~Ttg!pVX?mVJAvnPKrd$IpQ87caatIi0L+3gI`SOkdYrw^N^I82U zp|OD1!pR*#Qpy0z*Mjy54-|C-QyJtDxGF3jHiMpyy1Mv|a|bY>*hu0LhQ&MOQ_2zO z5Mdmgg3ZLp$+_&krJ?yU=HPMI1jWia8KX^4M?z$&%|Vpg53KNxMv*58<1y&*Szo{K zoZ{3ppPEhD#99L8iI3WkU541Mcd>;PCsN^H^4XNjkp#ggs{~3}gs+0=k;+a6T6p#v z#eGQL9k}N|PmjiUWI%O=5vNJN%6iRbD|v{XcLbPq0wmGvcbi$v8MFnwPPlnAGaOCi z)|uH54tFNZX&r94^qmG7YW6473H$c5vW~P{2x%rPJZCUyVorXl+>$b9#3BZ(g&Gt6 z%paABmkUrLhDTYJWMpv(FG^Z;)SO1chE`6w?3E!>!1MGgLu3;B7(=gEjn$GfIBb#t zf;2on8bIw)Y?WhasOOjK-H+F!L;`LXS&rXwa71L@B(`6{tjBkFY{sHUl1ADVzn#M1 zrZ{x&l=7L%QY|p)&fYs3lNQSJe+=Euc3a@13B_ScuRCEcO=TsOm8}$BHwDpPysEu) zd%ipL!+K*(;Evt$!n4LR<drfWij=Ve@P;@JFmA(KMF3?AxEA4TE#~ry-@}RiOo2*;FdsNotJRC)n_IZPzV7eu z2P`9eH)Et@kVe5wU*z^NO>skn_}lv`Qjq$JEOF=t&hexSA!>VGsJk5jRx^{HvhpIZ z&|-veSy|rJ$s4grhuK5zBZL=^zET;nIn{!q=W*#1)-E9@b<4<49t-)Ky3>6*OtKR< z`3L&dw6((z_b`J$PwHk((|s_`v%TY=cx2+TY-3uLZF;B3BB_?#*}qdR@29J%+1{&> zE!~6ylD`NB*b8NISxhowkRfd>0dV8;r6Y#{o&#zA^+Zkm$RBw)f6&b$#_Rm-^DY4= zSs!g2As2hjw3JOvS#G<%=3dtGbt3g@^o!VsDXp3nSkwKcP`X&2W{&N1hbU5cAsQp6 z!QG%zy5;N{?RjC~_|(m&r-;N3&R7BnuJrJ&4`CzshNGkeIX^-w8@@3GKD5}BPpm}C zQuLtUU{b9{SAT<5x#YO|xPFf^*V~Hct)aIz%uKW7$z~E!Lq>DxeqY+7)w=`(mug?x zUrUNI%qVPesfE~Xw=SOD#3tWO_hJM1nv?$I{_eEPH5XwWj9q1|`qSmIRZv`^TzWaNJbjX^w9$xFOp;VfU{F3`>#O# zMCIYGa_B5cpZU6$mQ>l}B_M)6$NNTdEyXBlNcth^36qi9VZ)FkSeBYO|Dlpy2ppI? za(o_s152+8yotj@v!!~A`GNuYOC6$O8MgQ!sWK1iFG-=AHTu22e_DPurSZi}kKh7E z)nn`0?v>xa%S}QgF@x1OACnM33KqzMv~`kCcZ>1@)7ukB`k4y)rdj~;7(mS4Jl6>I zQ>z#OsFkeYyaaFR-Qj^gN$4%yS=^El0cJy&lR zn_l83zJ$oxUSUDTry^|W%J?|th&sa@Oy2u`Kdxx| zeZGG>d?;D3q{$a*V%Hl>DO_Ap0sqki*b;^b^3iI$ zZs3FV0J8x{SHHNos>=ta{~>0y5}RysKXBl5{kJ}BP!2?$$tFXMYBgJ_ii$!_qx{mp zh^w5+wZJ6HLzilwvlhbvu)KYMAG5e*1K4)4e`yc4`GFxyF%~dn((dC3=*bc)IczMJ zuJ=YiPjWv_0ICBb%Q12^)k=--E1)E1dQn31lb5+5NFMixj1Ltb_`#sl#>mPF*l~#z z#+rlP)|qk8?J!pN z!+Sp7_Cj7?@L8QS#l;dN2H19ukZ9JGZ?w@xk(qTfYDtk9dGB*`%E)<8>u_YxJ~=rn z6j)MIXJ1jvK$CVNPP^HL{237|^XFvvYWXes@eVqOavr+{@A&8T3;lbR0~()R4;s+@ z^^X$z+|`ff$nf+OieKv@uy1u3Ew+eSvwyu_$nv)2kDS*iiJhzY!S|X$OvF22nt_Nu z7uhw20jkAT;>_Z9&n z?)?0CT~>({`k49waSsM~5e5ebg9X8gqr$6bW8~VF&JbsR8oW?~p4^QEW{&|6vS_^mEVc9zR^+`()X~dA{t_D1oCnGTLY7|t*sf<5Fvvj9V1}V>s$=5o*v3- zisZ6Lwi}RWx_)8L3CgGuntsJ~Q_e}f-dAsT^4)&cT4Fa@2*gi%cBe%2Z8 zoCv86j+6Xm^8wM^GfllAv4W_TxdMnMZe{UM+vXRoOz+jFbbEuRC_rA?hFsg&`pXn`xR@3oKDrO`)i=S^%A} zpXS!L7X5+CJXvQrM*K!IOD83lv7QPr(Tig`*A*tdx&^yKf?Py@5;3SWnkY%5=i?4w z_aTtBw8iPHu+bG#DF#bNikz=Jq{^^Y9yDaAaA!~Ag48uZHdW=wF#4GN$TC7(XNr6x zFVY`Mi{L77G8Ksx6rDHLs}6N8&!+f;_SrhtXTzT#e?MJUYgYfPcM^!No{KmhzG+{0 z8ho6_6tl@{(j~f#*({D;qZnPR(qijF1aph#Gi%+Ls4(OOQmEl_4!7tf)J>p!ZcP30 zJkF*VKQ#9TNhpZKI0GRiGub=*weyD3%!WeTvm05UT54bzH26e^wYbn)u45#YcJ zS9yMNe!fq|YYbRyPlusI!d&SOGgx6)a z8?gA6&wfu}oX#m2%1eta@hq zIyE8NI<3BGC+HOLsH3Wl6vD|@1jAg zRN_dX-qAt{lH&;~MmMPDgR$W0tMuq@Up^YLxT zu$s_bxM|jWP9RxijEY3Jr_wl>+pat0+ACi&@MG{uiqJ6r6+>Yg({{~ zEjX-VES$%*!XK@K*Ky$my+=uh3#f*&JzvI437@YE>8c50F)XeVCo~aSHb1umQ@&b( zj)Z7@SPp+`UFD^wPBUJC^nMkyYY@ZV!$BYa*svULEc!V#OJ08;tjpa`TU;o0Un`3N z-=7|Q)&Ynr{imH>T+rHo{rS(cZQJ|qy33IeA>m3u;zo?^SnbY>Tzvc=xCh*w>}P@% zD?58?axyAGt*}Uz73OK}K(7>_sV)rf{W$C8cRof{`GSw+w_ayBxZ3-1ui0oujt(c1 zf7p~P-NQ8Ul^>g5G^s$a*0e2fs!4Iz~@HOt3}xet<% z@rC4r)%ah}8yTfTJtE)oUjU2D72x+u=W(N7SD#|`n^9HZqspAd_M{JDH8S+_;=vZ3 z6)FNU0d#=#)cuJ_tS53rXgKJu@rb_1Wm{0&{BqohZcvj_Pp3v3jlr7%vR7X00HPEw zK9*20JU@j(1s(^<)E_?T%>~17#ArVJmuD;sBk#VsQ%({A-dEX}IJ9V>@?$U~B8N{Z z#X4>qCL~vZ#_>fb9-8_g8<*zPpDnpde(~OMIRZ>vF888ixu1Kop*XE3Q*}ByFV6l~ z9B>%gQ+T`ZMPQ;uKur@7qwTI}@V2q(GPfTaH`%zZ&*{nOo6aav)Yryfik47h3hAdW zMx6keJ$?+fP_w}mMc(L>P<7)x(0ZBjn!4xs?T;m>>-+qJ0qE_+D=pX8Rc0d6W;5Dt zX16V~-t}b_#7bIhi8rM6RE07_A<;@FImg9gG`}rV zqpMjCgv)|8l1X3$t0V^&67jlU!3aEo!Rhb@A0hybz?EukN&CB(ctk9;a+JOwKoxOz zbwx)2Iw(N`pcw;GVwyBzmUN!VeTaY}P%AhQ8I;_vqu1?dBXIHg^5yeRQsk$~-G7-8 z*FzX%Sro#^fRF~fvhDSvQ*!W$VAL>%eys1u>5z3`oWo3mJ(fzXR#D9iMGUzwAVxFH zpp?%MQJVwc&HVdx-*>fXQ#Zz)>J;GK)e%epwRZz-!$osepLdHa28EiPuqltckXW#Z$WhGdNpC%;ZIlVA>Y;QuUCoMvxxZDh{xibt~zS0 z#RkO7y@^GfZo_z$YqjmT4LHrXtu_%|X>`^W8)Sx< z;GVPjlgLk6Eb}$I!gcmzRT{upK;vP1|Z0Ni_zobSMp{+(k zhV%L76h$K6?G($?TtPv>!oorrp(ij|ilTDT2Jk`+rgJOstLKA9PKpg2AvFG`-Kp#B z%navbXNSH9*6o$Gwd&ts75JEOPD=(FrQ|VC$7-<&=!$bH(h|P3>mZ-LyX4bD}DzNAU*BYWk*G&w*nfeBgcI#9p}O$)|Th3J=c z0yqpLpc5YM?(QBRjp^1PmUC>rR4t#t;+2-tzU>X{zm&=5vCs2I3=msM4=FV{zCQe8 zP0F^4ek^A2u>?B9IjI{N_Ae>!@?~;GLqdUa-N1SeSiaCpg#~JE0U;?FGKbvJa|00) z`9D;KBG*1wKc83SdE4KGv`5=naGKn29=tB($G_#p6sGo3AS!2b&|<~%QWyfm98x=+xKk-P5+OV$*=?GW$%jKuEWs@) zuw0xE%P~1QyD53a@owLh;WS)Jjy5w74zGy2|P*IzR{v z6DM!gZ{R6*K|##o^a#`$CO1u4W?SQKN>rwUm=p`&QKj&B5ZZkiM9ghfR87oXc4)YP zmD3>N$iz5Xy%P?L`*^(cz0CE!+uNg*pLD8M8>soE(`L0-G2J??(KbL|Gx73lrwpdL zG?Y8=_XND?a-58I0Vm9Kju7*t2+5q*5Lyy}h9iloJzr>gc)L~?0hK~(G_4!BA_G4K z9>;xH&#<{Fo%S1G^vMO31(_4*OP&>q+h8iuG{EyNNRg)l*tML^Vq>GD%Xk5588uZR zMd>bT5|aB%o&tFm=RFxQJ+F72(sI^4zzs|{y@;m)E5`dxT5p%gnR2T#uWKBZekdM5IzS(u$PT6$XuZ!#|soE1QW`WwRNI@{I{`Q(lsi;8Om2 z5{ncfSYj>qqt4*VEQWX)^OHEU$ZoB%cY1`!7cv@Rrk3Nu6}46Nc~Bu-lYf&2BO^l) zJcO0#fBF7e%{g+rn2IgsB-Ybv`AGdGnz9(J8Ru`N>o8$D?_E!J&~ODWyMg` zNc6hEgbbgBF6vs@)xckIe$2hZ{0pMEF_TeC*O^&*&RIXLayh1JsDrUNR9IQ$t492| zhqJ&U^FAEb`f0n$%J`VNys0sujyUxBXf5k{? zmO~wP2cbQvCL~Kpyu)}1=koh2pu-F&NeCV8(EVL**vqCfA9>*!ed&Dd{8Lz>sH%sr z1*ZE1;vy(Muwj1%c5=NRFK0kh)48RE#S@SR(`NI#0T3(Cc9{nH{X zEqyXLNIWu-WA{DjuD`2hGohN%t`mun@kIyEJQ zSTY#VX&1HhyQ@tn;1CZ{t+I)#B}tgvW3^1}xeJ^- z@J1B(bI&snjN0)-_@&KKa-|s&d4R}Hk#BVoRe%7GD)pmy2E^^2f0oj@V-q}eb9|lD z!yAuN4dOyD%ec-XM!Sz+Xukcmih6_UjmtrHhz%YIlMAn}cJ0kT7?YB$4g@zFGkKtM zpLyz0q)nI@rV^y_Y}!y@M=-M2p*zU7B2KdZ(pJH=D8J7773N?iln+&n^&o@B2(hw+ zO_iyru5v3=e(fx8clpQe((j@DNYDFZIVdc)bRl+b;>tBb0V zh@4l#dpgF+zbKi~EUGjiVdIiJOaDGvAA6ryd~y6RBd}AFYc{*cO;U;CSUly!2Z~$@ z@D&x;!WASN)Cr~-cJu~YMn@V!ma8k{rQ|?M$&=I0MN?39#L zvR!5je{pE3WL!L0B<+b$jqe}0VPo*J{d9woX!Ps!Zar7K(tqE>KCh>o7#>_7CeExu zztlJww3;1&CxuR@nO{pU2@a96?zqE|RF@88<$RKoRKm|2$%|o*6PDZ>e{Zk4tR(lI znY7c5*XiS_KXq|*hCo0EGm2KbE1Wl9smApF+6eM%!TQJht14|4&=A(XP1G(e1Hsf- z^)N6+C2+TtGUP&qNh?1{_X}(&k|f8#5YK^Q$leZyG2=GiSffn^Q*v=(dq!X*lkn4# z*@f_rr+iChl@&!^7JTTV&H=&&Re@HP5>krgx)Izs*po_ZUw$Tj6votZ8jZ_To5C#W5a*T z{Duzu9dKyq`69Pko%Y0?->)f7)n6Kmgihrcr8YnAlqqMj*v{K3PoBA?jX>U5a&Mp| zU8s{2aKj{}<|{tT2ns_!&5f+DQTVBrV_rNt=Hj~%i8r8iZe^5)jE%mzvctCcsh*$L zYX5#!%gV-}3EOB)1e-_cvGQ1jn$h1TOQBUE#GlFIwNa<_H64>yEgu++XH<#vo?dix z0l;Iwr;ktfi;y&}gVMx85Z)^F8BW!@^Q0~c0Lvp+RD`J}TMAt=DyZ2ZQoBKK8iN;$ zc-s&1v?<4d8{=+9dZl74&q>4kcLuQ7=2x63d9>wPbvc_op9_|0QbCTHI=^>Q?tM_q ze!wHLgl5aTUTikH9ZfP!YVY*e;gGLvG_YxMEoQS%p*Jg-&x^MeznDJ}z$j*&BizuM8r{Vo<%Rx(p1ii5a+Sx_KWD zQxb7Gog0`>W;~?cI%Q_s{%Ikf!eFO(`)q{Rg_Y*0^QeBLk! z+lGr#)0RIa3z$>qXA!{BD(K>;iKpORIKhI?udc#m_?rp^eaG0}K~)LLf``K4s#YjN zM~t8s)3(Sn8U%{*2LSJW-Hl=(Qqi%*-atQ_u;~cE25x(u+j~wdlgBbigyl5rZ-zcdi_yQQ_@7 z`j)!dQoj-%d)|kbGjIONNa(50@8M~&S?_Z2ai3-ROJSP$jO}}sRlEq9=r+;Vrp_eT|VQ8jD8#5n->4)C6S}H2|h$Ly9{0MALMB< zi4idy9xko|irri{F$Sb@I(a`XwAjqJxhxGTwFUliAr@?sEXaS~?`@Ar01$`)h?}M; z8z6rAKe@!`o51HR;E1Ndl$w`XuhilwP7j^c3>0F64K7L`G$stiu*jMQ2(0(fkpCIH zDDo-X@L~*DvSvQcj5{vjtjYvuCoVy_Z260TR{S1z2p|sQQ5d3p%Vx92Zo0woyT&;Q zo#W>$^UQH?AgQ6cf-j??Hm1oMCaghd^ajACZKz5lgMb`769gjJ5w9wNwbFvz&nVvG zeO|&C1(a8af0qA&4u5}b*~$o6NJrDx`<|C!cyR)O<#$l~JuARCVH52SynffU?4K4A zwY;yf(aSLl4GRsC4GWP{&aCP9w_>3O|4wZV?=qC%-+c=AjJf_sjqF7v8nNzr-c&$9 zC3-aU%+0`*J%I%85uyXwxAoe-2{!}MQX+S+zi~t!kiE`NV{kZTXc5vf)pmM~&n>d8 ze_^VZFii1g9T6v!0CdGG&F+ka$e0ot=Qyn?XDMl5BJz~tlprKWe@_V<;&^JG1in%;pL4Mz|X7OYkv{oqxS>d-6`>rT6mKCCv@Xk|Js(pB5b zkb<978rrR6CogaAC2i$Ri_U=m_3LPz{cm@s=&#C7e?K`0OYj-BwG0IloZ9;XK7iM# zyUutNfuZZ_Zt+j&D-40S?~)P=sf*L0-A0$o2}o8pYUT90p{dqQ>wZXQ&oDB1Y-5u#u5MHFoSP`Z5jWvW}Z)S z;d#Ii%px+HGH@;TkRU~RK}ZWyQ$ngU8jc(p5i7p?0X~7SnQ1m5FZl{O%lda#we6t6!fJuZKD>s4Sy#`(pNEBatoh zkWL$ep&EbMGS*C(X7egdoJ5Fs3FgZHD2z#+f>!jF(>|iF2dzgSrcWe#mC92WK?8)d z$ZY(c4gAxS2ruIBYpP$h+3hwu?pNx5MAGh`X_vVMXjbUEAyQTeZC9T--TbrB^?SeX zuI*}>138B5fRNbe(m&kvy)UPgl=9zZ%~1n6uN6VWS>autA5|38k-!L9DLf#d09bG2-n%Qjcbwrv~B*0NhIEiboh z+pcBT>HR%#|3KI2>N@v*fAtBoN4#JmY#tc^dKAF7Zs0W_s))1gjGpT?n2i94)9VA4 zKzs*LtZk|Dl6qE%D0Q-Z1)?&VMi?z>C{gU7cbjjRSt_~;KuMPkVL(RdK41!9$LZ?o z*4rSe{(Y+#Ss=(@M2*#>oB?DV3~1QgYcn-S&dJ+` z_*s`X7gskI|3a8r6?Fgn zIlvwl<@Ys#U4OT<;?+MDsSo{@J zGHkD;H>)!zYAQl87zq0w9Ij>5Y&E;=HP5zNP#Anct(mWp!0amFi^mNWSFB6)tjDM& zMY!*4^~n{n38AV}sQNpE42uwPg#74E?0t5Bz3IW>bl$VkYW#lTxsJgt5{{_~D=(T1 zvUrXJ30~7Qxh!x$hb;d4<7>FtIE0{}+45a(bZN^+^QX<PF})d@-*D2t>0B2T=AM}mPPDM!h~HM$ z?|{dME;4kO?>zK9T=9Pj;06d_;tgsXbKGpyI$i7%HsDK<7LHem!qtI8BoKN7v=GcLPs$33{^@%tQym*@K(R?-;w9;5*PG&j%3c*{?u zSvs8f_IcgA=^dI59WBNut6GXFpIMY&%gX!1oy)vunG9=?S*QbVQ@TJ(l>@wgdJ=h# zMs-eUg+aLce_??)yQ^J=@>HC(g8$f|E&u~@*s$=Uop_T`!N?BdXTz(&4C;|8@dj3( zw=D+;2Z1@#?mPKzm`2Kk7-JWqmzRo+x5|Q3SZc#~w_reDeUcCtht`ObDlR6Qhe6)K zXYVB-sH%vdubKAPJ;SNlMkjT?5BS|>5(ueYj9w!P=;qa9kPkt9)b63Mm9rv_j+emn zd!El}B_P#^F=)Jx)H&^lNudgV+zNLGy!+^sThQVpso74Z?UrHA#cAU*3$9=XW3u>8 zbN#de%<(9BRjT_wUKC)7XB~i{u9Vw%cu4Up3dI;wn`Ut9!Sr@O*P;&#AW(yY+| zQK;e^u8Y;kFvzP|7tE3%H_&M(9g68;Jm(7e``FpV&L$#@|NgI+jSX3KgA{EGYR5uh zjY6Une2gy7|KhTn>bP2KvBWjCLF?InJI)R-&gcHFV&B26l2!;#E(i#zIBQHUGuP`8Cu*$Kz*Fdu4-11ToVj$V2KoZ(bpviCyTQKbA_wwt~Lx)x{c1ekK{l z1o7gT>7U2>XlU|NQ*Zj}KEuRMH?X3=c2T|VXFPIl;q1t9qCoLTVXiaI|vX;s3?eOL^AT*FR+`vf9N+Qj9P&jGlVvK*(xF%}K& z&!5-QaVO<*`J8OuBYjWD6&K&909I*Z-ppF~ctx}5_DC^J>wwp_t;z3PdMUviVrd9e ztBsHMnjRMqoO3+JyXI%+lMU7{tnwn^3+#0G%mDF-wH}Q@O;GfX>H8^c-&OKpsd<{l zNCP7Ox73*nHnVMB0}nqtfrX8^wb|JaY3kr|>dv;jDUq>hroxyV<+!;(1^w@xx2`rW zve%8ooveu`oDbDXWi}MrvAJW>$+(lU8uJc|b?PS+B_)kJfsxV?5ihS>%Z*118HPSL zl@~03UQPk4S=_WT*I|X~pnmjk_OpDt!*a9T+~VONL&|TC*dn>DW5-`(UGJzNjj z>q|R4uo49=*T`i~_@0lA6`YcT+jh^tAA8XHu|;+Fai6)@otN}a9iWO{WolHMLD(i_ zY_KSp7pO#EB*FkWKkBS~dK5r({09mQpVGorf;nA(`+F}*)|wm?MwK!GxL57%U!>kD zuOhv%vx2A|@9%pTj&Eb8!tK+BN25Pw(nBVyL}K%nco@{@|M3R>qli-$xOw7;EZ?8#LVd*Awa??)3>@H9<9j^S7H z{<87kI59xZG6$sGW#~x6J~%rAEER0Qa8wsyuL&mPCpuAQZc>TO_jcTnQiRh~Td0G% zzDJ&If=w)CLHG0hlb-liof413b>LE%hCrQJs;n3TjeyB^ zP#7>*XId}e+|X3jUdyJcCl^boR9d)%$?Y$kMsRj=D&%#%4WtZp)>aE%5uP>HD8;G2 z@~~$Xy|9`5-1yoZSGhAU1~o~}rf)$(89Gu|%-S1qKb)-tqaMl#;5&tawTZ*#pm`4t zCdc><*01Lu%E8xgXqU^+vst%zQh)!Ncg-tVd6?TB_DP;OYIk33rhRUi%CxH={^%^@WqxU0qcI_8Ydh0n=m$ zs3lnq&@(9wkbfKKfqc^PTfOG!O22QK{-#JKvD`u?>@l$mDm(jZhHQ4K@+HK4_=kb^ zF}%85gj?4osp+Je#nC;=9TA_;QyYM+xj88hd|Uqd>)ii#_~f=9e~E)U7=H;MpUr0f zUi+ulY<#vl(K4meB%o>#$}#% z^>&iqn%1NCOTRRzUTzSruSBly2%uZ9|MB$%1X6zBbsXgckmN#|aEgk*sMZKGvwdCj zi;0MIr=_E-{Pim`5u=U8unW0+051h4JvyOGm2z}+^!N?NU1dq)RQ;GQ4>Uqw10-5XKih#y`J1II*l!Wg4& z^SNnB+IC7GBa(`aXvA4H}?uiVI2wEz!PUKT4EibpUvVsp8JUP}^ zm1@G}{x84?qKd#vf_WVoCv%tlO+rdeDnMFdlFN&)7gY}<-~xmX0G9B6ae@%yP$?8T ze7qVqcPDU`-WwgHGwEjM(=?-TPg!4r zr$3LN8qGZby6M?$ndblLUoD&WlewkyqU?sR>4wTt_#<}lq4LvBGMveb%!AyvXQwtc zw)i{8%|Ax?9O(O7O&Qbh@fG9ZVhj!n$BB6)gIcu6Bcx%io0=AtcPw@Sri^sF`>J3X- z;ClbzLOTA(vgg(G_1B}0mq-r$B{T)5Z}LD zvtgbHxl#JjYMU{JYTGk{n6Xj6IbxzIE5596%H}^duTq!=fkS*MPblyO`Ai;f67|mG z)nT%s=2O?2*b^db@CBR>JTC?Zvl%wBx>f%y>-7HDfYRd7_1ZYLXrJ}l$=rO8 za4IIjQm}%l_$=s~b7387z8)zPnr7G#d_D?}1>fSw197H#%K?8GvvRQp*K^V+C1R3BAw?^hF=0eHiYHR-7N448&(*Xiu^uZ z0XUXV!|!iXA8!D4E*vPa7>!qHs>u{uFX5&tn6|b1;1Kamqh}rf1hGg_M)ktO3n547_U>nBDkcv<4k_1h+OZXWJ*eEi5N3s`9>AKyry zcHftdFRRSCfqi zvqlu7J==7(P|QjmHm(L%VwL~ozkG2}U{XLRKJ$zPKArkFT?@Ri)E3;$z8-Ba3%uvw zqBE@HGdC#T>dZzga9PmG&gfQU)c=O0$3&21N%5w)eW0fEM9@IQ>wj@HMeP5&9o)k5 zLwN5_Z&9sZXZw@$8p-Fsj%#I$>Y5ymlRwSnaRIlg!F%#;H#_TFXDe;q$1_&0YO4B^ zI8;Z{^lOG-D=vmnqLDI%*tF0`ImMsDcLRuDSHO?Ya`2w7iD@V z=VLzQu9C3GIw;}8ganVgj~wCGjoQY@;?33?zK=7WkBrN=Ym&X%zDUfQBY!XSXZR)? zDT%=ZUqSL6AD7w(aRnX z-Ech|Clfu;P}B;f4AxU7RXF{d?X&AKuM|u85Fsma@`+vapwRO?xIPJgfq__7-AJUt z@A(Eu5C1aw<8!?`2vj}7#cClkRFnv+3|focrMWAdJwO0RS%Wo?LX`V zz}ne>@$h1T+oIn8>$mKGp<&NK@optPJvb z3*7LJ?wI(p$iB!&M z$CR!xnbmF4UuIstxX8&Z9V2&9R6@k$0v-2ODYLU$mt|u*! zdRMr7rr3J@{=w>XZMFXSH|Hgw^`L!Bbibm_>JPfnv=%v3S-XQ<^sqI(sTz?7MI4mO z@~<@m!FXHX6k*NrhN76yIXs8)Px-_a+Q%g@Dw(B&Pt@h!@k3TLHrlEb!*LHU zE7v>VF4yt|5}&hs*T_d}e|??Ag`%=_;_%47Mc>$ogNFwT;%17d7?v_pH5Y(_h`M?z z_Q)@j)O1{$l#!SAFMgivbotCT`dRd(4tAK-oGUL=oqgWEG~qT8 z;W|u$6wCB3i)XCy8{v0@r8aTaF{^FAv%u##;kP~E(iN-Qa@W_G$9*2o3t)2}7{>sw zb-%9x0={z;?dyLqpq7BMmT79~XlD8~u2?oBuu?7zh^+N^ZVC!^dBj1 zmc0+*^O&|1eC7d=3^mGvajD=?h%bt|Yx-AS;7l);l1Ug^h?*&g08hpCst#WTGxCXu zs5F9*oTD6gE{W`tcx^+Pp>BnnH#CYQ$gG>C3uDN{-s8B3eru49#+aG|9<*0Lulr@y z_SXne=9N1>`}CI^VE?ob-mbW<4WFrpu|5vS%$(=%$dM=Y$Xr=#VVrI=_DJ&K89^jU z((X-9qi0hE#{i*h{(eJfD9Q>5-(dywtC-yH-UZIF=;R$hu)wO6K-Eb`pWIG@_#9>_ z@f#H4KK-Xt;7RtjpP~$$5TOy{KlmR3f`7ctv&yshbx6%dNa*TNE)op?B7%)C@4(l6+-uGv zCUM{k1m8S=HO*kTYt}zLyC5bwCb>MD(F0!aVG})re~KhJ8#*%~7+m>acC083bTHy* z>ePa)jf-fJ_LRd7pUrE6C`^8gl|;UD3>_#UlEhpNPj>;>6KhO4Hz?uC}!p z*JcfzX*g|%orn<=bpJeS-Ny*sKaU{a-igJAfrZ_es%)Ert2kpZSS1wfh1Y1ur?(&b zx&8Js@G=2>uROvylRGT=5bl~Dm^Wiui^K9OR6C&K4QrAy`1p%m9;Zu)9yu%_ks7&^ zC|hy*bb}qeC7cqwahB-x*2bpGw}1_+f@&r~_G#yxbFVFPdpD84dh9<~%;ve{W|Nb5 zB~)c)5x_hVmD0td1K-6MXeL?(uJjo{x8zKYdI=siWSMiMqz!D#*qGVb`7u)5I_`Gw zzozP_Hk34wtLkXXaJDoxTQ7EkIF6WVD;=A$2I-_fPqhOR*5dY9{QD2}SEes@pHaHY zzzE?c>AcrJ@w70YLE+=bU3hK5_wSTr&s zjKDVVd?b#nI7>y|?hjxKI%vBV!2U*va$PB=N=>90(4r)Mo9F~Tm9WZFN)3tx@UM$2 zXrN)x(;Aa|SZz@x2=saF0b2cWl%N+GvcV4nqkw5S1*lRZGJq`RGo68Egvg{m znvxQ5Rh`OmCFxYYDAfTTAw@7gLiYq7L*-AV+S*@L`P#z1o9EACRi~DeqgCfxNyaOD zhE~{?#x$rqxJNd+w1a75i2hKs66>V)X`OmRVi*RmSW&h;jF3YZal_ji<2R2VcPtz} z^E`Xz_Z-IQI7mk6&$<@*5(O@cvx3(27795#sqJ@8xj48d6dYj^B-D*>xdoXK8Dk&= z?hq7nDSlm+CPRU>xq$leJ+-NWhx6rv6k^Z6k-r)LURbqZ?{=-m)4Udj6gpR4#mP0e z2>#{s8K$O4uA|WTNsGy{STv(0psk@P?E5cwwJb~VHUmdvky387FVCoPQ2}2Vzd7A? z;6%bG{iY$uf z&l{)ylOTb3Q}XE51OSkiH+-3`(x~p^*o3Z11eCVHR}i14$-l(1`Z9NQOozvtF_!-- zh5zm7^z=YbLcsQ@4k8zLs=#F)06@nA&jEE>pl<~_aQzY_1;LJ2E0bkYBa%&qMaG8} z!oGuxC*Ct&&>VIF*#A+W1!`e2273CC0ueocum$V6)ntvO4oxkgs;4TeaX{&eLh&L! zNMkjrwsT5A-_D(tB6^>A0Srt6FZ{K|McCJ^7Dp0B^!|dZ)Pe?4=6Vz=Z%G(PNxHad z#o3A+`HCO8O4)+gm<MGBCq{Y&nQYn{Nkl!o}NVRHADt zO=SM`%oW^@`yQft;MsLcR4Y~u)M7q%S-`uE`R|N)MU&4zmr!H0Pj|%SS;v4A)Db*a zto)pWNhuh3CfNOa`QbFr^&YkEn+EZYV3{7`l&tnU++)~Ii55~D>FW&RS3TY&yfwB? zJw1w^hqErY8AANy&*#8hlh5;TfDK#{`P#JOWFdVmD9*#QF;+q;2-)Ued!}WK{^B7D zHu>`EKey<2`(b`5+`}kadn>}}Z=k#R`mpIMylKSB!3r%MOj?;hE*X>D>cbGdKZ`7@ zQY2yXSkp!G$8l@!v5pg676HH@u)@xnt}6NJ>MtDp>E0}vdd!c~ZK>`Ua)ag&S-5-W z|H9y4VP=t;a`Z;SPM*B!qp8l>?AGM=)9Rnr=6qLCQ5PF_Ih% zM{dF?WmOez&^S%0PZGF4@TpPwx$%SJtoOJ|V{8e0`tkCb#?X=_pRO%NoGBbUloi)< zPleXdlWAU$8MD3HvqfDjC*mxzbS)@<`pa~)c(}x#*iOAbYHOQio~MDD-i|P)YMx7danYSoccI=#Lw@b%=9EAX z`@vj0;agurTY*;cZnP*#c6Kx?p{Nxh^$O*fLT;tPJ`#&YuZ85*FriNoVmG?7CnxFf zGvmEBcnFWCeKPXB^L#(xeJS96>*F<0S((q5=XwwFFIvQab8cm2W%p}G_v@VS`&TE@ zWgLiWX=3k^q9Ul&ibS805asSa&U=6VYuXCsAxlcN#c)C$P~lcq0dEB$s1E$!LbTag zTkqTkt02fgz@kS>B*KPFctcyk1P*ZmL%IE3uOY+B%b&E6np-L8Q_2VEa*KnEjXHqK z+z{aLRF>!U0XL*kC+7gSdgBqcF<-dRkiXfvxdXT;OKWRLF46E3AU7-pB+QWHWL(o` zC}#tw%@D$hxLxIdRGPycRaTB+1#xk4;06V(ZxVj8BQshSYpM&M3;FugChWhxn0vFU z{j>;xrj7!^N3{HJ%&Z%Mw~pY66lI|{^D*4KWF&}$k9`p$zS`nhsJMa~aQ;XB$9=~y zVy*+Db+x5`yiUg>N8$@{)^jQ9BQ8+`LA{LD79%y745GcP8_8s_292GuGK}7+%g9)~ zQ*16PW{mhbBjtM>dlZ$+f$oHyRI6z4Rja(;UAp`waQ zp}`Pu(25%Ml6r^|D0~F9RW&t^KWl5ge_NDbs2Z!X5ub5UMQIH|Ryvs_Wf-NOqNy)` zgfh=m5M;B&El;5KE|Pe79BP&owjJ*J_4MGi^xO>=4iM&F#qmffvi$h<@!$!*zkDP9 z36gV%YaF0^67Eqq@4bZ4nt%u|X>#hSdIxCj`CCspj=|c0Zwy-7PuhOHsg;=jpxYow zYHos%P4hqHuuO?nHM^3x@nYWX5u>BQ5BbUJEJ~#+xT6;{gL5n&+8_eWWl@fKt@Q;z zVQRv{H05x-&Z^AV1d_vXABDYTf3(ACS8>_+$;3_dhfp2$8Ke%B06OaQ&|(OrAR&Bs zXcD3zwvEjRyu|2Obv1*{Y5xI^4lDfMXylYosqY?So<`{eoNP2hR@Uc5f6JHy0D3RY zoqcoP5+-O>zJ%C~_S1sNro9XnB}Gcs@rPp|I5LHYMe42dH0xtG|NWE%c*hq*>A@Ks zzuy}dSob8NL!Ll34mgs73Cw4$#uj>6At3dF&M2X)IX>lK`O^l5UziXo{% z1tMT)E=nl^38-KQlAfWhS|Gt`zfh$CEOHP0F%n8detgGgkA3W?Nz=XwF+y@0LYRn* z;0JbrudbXdEot`692`*N#&XcW&{5QMP0#qpl1j~WVor1diV9K{qGa4x_&pR$fF%Ub zADh5HQ%-dCpH~^F0D3}SLO#)^*IwLzq2%rA-+M>@!OqI_175!7zhJX4{;Ei*IvIJH zt#%^dfvN$Y<_s|#T*`W{n$05cxVhOalO4~*p4dPF(mAJKeL5AANsP)ar&sL#IkucD z%^>BP09tDH&pK%eJe)5xWslDB_>0&kS*{$FX6vJ+aRQ3ZlSk~=S=K|`Z5d;RIRzt5 zM6E-d)Nzm@a3VXjz3esZvS^xV8mVx77_#5|RWYa}RXE4Wo=rdwJui8@yp5g3I8UMu zfpmS0EHkjGbyV%}Yk%&79uP-%ui|b4@ACs#7Cl9|c10zhYPMec1K)MKCH=$;X6kQ$ zwW_Kj>Y$f0J!s!_AueX87W6Rc&!s{aB567h3I}poGwfaK8BA;1Z&ZKd)b)d$rHUeN z%+0V%%|t}SCzthNfiyDl{@f~etuI_K(*m*0^2}M1B;<2;h&d+t-XvBbp8%*@S=lQ^MYBWMlcbVS-r z?1T(I3`PU;M?{2_ZC_YFS|xx8VquANjDYu~>|w-^CJ=DGJSlg6rh9wR4zdhliG$dy)b9Zk(JUoO4RJdyZ`*zz-hM1z9juCfOjsn5n$lGvkQk{8e=jI(( ze<5DubbyQ(T)DQ+_Cv->b%=(EzCfpf=c=Iz*>dspnvjp>@tl{Om8S-!n5k}=V-9h1 z9!UPEBVIm~g-{=@D2p@;Vo9bI+vd|KqP?cNwqHVpRUQE@XEs!DY(a!QoKI{Q9BO3L zLGn>)kjcT;%mb)hJGRknne>C(!BhIQ6x!g3VnY)Q2DU!i&tgpm==)Z?pKG?>Gd@mv zW@2b@bKqWj$CLj)@1SWr|79F`f{zi(sF$*sYxEAZq89woyx*Xs%;GvgHO~0F<^&J1 z#lb=!tJj4mKwzs7DI>Hj`_ltv?#>PLkY0s3g!7O+-$Jw`gG4;S8O@dDICXEgkd*{wcbPz7fv>Lf5yc+fzbf9@-n7sFpa;y#S# zNSnu$=TANRX3UgoSJ{n1W0*G&u>hUtr;kfHH#&g~UJ`!ZI)tsY{zhKZ+I?N!ee>G= z(b0fQD!eT;r0r4^1V4|m%fZ1BctaC-14!=*N=ij>5C1k^8M<#606E6N+FG=q4Bw;S zHl1DsiqsL}BUntZcW$$J`t?xaQ^1R6laa4(5uJThN*lw22wxpr)=LHtag?#0ijFxTN((8}40)3DDHT5G ztw#X50yii{o>MUYIF!i@A}-#H7t}NOTpadF4!z#-iVw9S65wSYn~+f47I@?ta0C!@ zml3$%{!@$23_rfa7wI6<_(=pQ_M~su9Pbt`*{bkwP6(2afi^{Gqip}?WltNG$KYK{J~Dlmygi+rMyXhk zUs5LU5-VRA|AaN#A`{#VOsQJgzDW=+Ao?ONj+SpvBgDetxCVDiE)LtDiLHfvn-{{UXN!1?eq$nqM#uEd;xR1xMj0;-CgSe5q|!TPtg--l9N zw;3Oo>t=@YV-oH=4EaFV8a&ipQ9-$aq&_DIi2~^!!n9kLp|7tW_%;;yHpzb}veZuq z_@OC)uGfvCgYbRW9!>Zx1u`(Vg|FAJE}EgulrT3pH#Ic{a-YDOCGcBxbwBU&f@nhG3*?eM>6!&C zF?Ao3|2$F_X!H{%g+!E(iRMBKD1wDJ7e#>(&;~TU;;5_Qx83D_M>o$GNvQq0OdbLF z#JB&{1V3QMA47Ul7}&9Xn<06}7-rjlE_U#lYDU&T5}C^JLNzm<#BGn@nA3JNV?Ki$ z^%sSqY|McCM4Lvl)Bi?XGFeDfH{wnu(GAah^J^UvX~A^SR(N%gt*Az&O+O9nT3cDvlHmD8D?0Up}5 zuji+5N_~pA=JYi(<4(4z*q}`~efZ!B-r#16o>+7uJI)T?jIteBN7Ssi(t-?LA*olQ zFriD&aJ06XjTMPW@-3`Z_N6Ihov&#zUBl(7mw=OAn#S-K-Bd^(%3twQlcLo#T-tdj z{2vf0?u4d~gKV_?r{Q8!b!c?X?%?AF=@4>xY|c%Hc{MV}yv$N^7{Xq8B~$~!(tQg8 zaT5)d)fV5OhYQ`ED6kh|evYh!NO?SGg{tQ_k6*Mx17MHI1@kuMTrM+IL+o;1U+hTQJ#?CdiE z0bsWGj#XDxJ()Yl^h*g{H$F{<_kijL8+!toiT!rBB8pYL4xnlAbh0`S{m_DnAv&Y_ z93%Kk;Me$1VTwXx#9VLRW%>oNnuH!0VU#}_p;-9w1kBJ@VAI}u(E=b?##m#47u5cL z4oEwI=myrYO5Tq5Qyfme;Lf-Gw2IjCjp5C~f<4Mj(sCfT4$=OSY{5@l6T35gN;Qt8 zJKMTJ(97%G9|3)r@wj(I6egBIcJ`C(Ie9xoO{V+=l2Itc3O!A6d%XU)%9943gL|5O ze$C@~=<+rp^*JX)J_1v%WTc;t7<`$8=1F@iKe&!gfU`X|D= zn-*09m{{UkoWpcUUxHx}x6v0jrIm39NxK4IF68lKSZY7s#_^S|>KJ^{;~%&$mbtBD zW{id3SnooV)I6jSB2DG<9KV<0Of5?`!0=x_CBWl6A5;k>ga2<`^TDOO3N#$&%yiE)vqi zTGaV`Mq#|csmH|nK^682sRhMIg8UblZ4+VG@_*FN#5xarIVtZ3Cg}wp*Inz%CZ*fE zMyAkd;qk2PzQbaAU~~1ffgW5ZEwe4yvyj8ZctOq(7?adVm`A%b30FwuP~;)SyhIp! z=-bZfL~6S<9lDS*(bYK5RNY+N^W+1-RlbOKIlyV+mXnsH8JHZnh=P^$X`*ZP6PCWV zS$0vSbNLF8p~i@|r7_yXWddw^Hpr$DrR=V;vOW%h+ue^#zawDT%&Came)YdWjgR%I z_w|?iGw;f0ZDF=nwrjgJ4Rt{{CKjZx+QwfP?vyOb*lRyU9TN67=nGbaKovTqb2i>- z|1KPFp)4~ha|m97S4M!=Y%(p?lqpom*Mg1JgXJ%%fRPo28YZoUc|{WMyZp|?Ns-?q!bJ6Fs1vl0fspl1 zwT&o%GO0iNfX4`R&PoaoL@^uK9X0$*y2vYRIR(&|q6)s^JF>~2_s{iaQ7P9I6nc+^ z^r8Ecg^W}uok}NDxg*StqQR!wcG*cB(vF&icY`f-&|Y95*&_>jyo;3K6HN{pM!TGq z^Qe*}*Qglmyy4Riw3-iAK`G<^M3kW(vZ)_tZQT=bVb)1RQ$bp~=TZcDgcCt)*Vkj7 zQFQ8DN)TH|O_+b%oVKwbQxQBO>MbA6P4HsS3e}rrG~CVgUG-gk{pEF86+-j%roe27 z2~y6POpvYwBqZH#Cu)qi9LVBJ_wn)Z4-Xzqbn!Pe6N?dgv!s0HA|u;gVPEx}R zVV)up{l-FQ#Wgi3FD3xvwECzXnBjCs28x@Kgpn$yK&KzzXUQ0T{rVLc`ZYGR>5Y53 z;9VA^qhZ~z_}HB)>V=&ivuY`hx8sqIwD0o(2YQ~ z@-o>OLRfpT+c{h9sA7)hW7NPT8V7h1iymH|iywMZ?_Kj=cEasR9AG!Tr$GM>x_GOx zMr);bAS0!zz-z|4SB|uM{Z`DVdKJ^}(FKbX;t6MT*jn0%Jm*Q2siThrUGVg%LRU+9GhEn>`f1y}3 zy~1D)$B!!W@xGH#VI_Gm!V8)#itbtY7RA*uNH(-o!VE}$O@32WR%XsXs=KFq(mX84 zHv%OgTgMRD$>VjB5-LFAsc@dkKs1i-LCi8L{0+SMzMZ)RBgHe6rlquUOcXl*5ULtUC7|AO_Tz zmV%t;f!*<-DLz3#6rJe&a4aE2Y;W!lgaRMjuQh(Dq`DD4d1z*}{}4SXRoqby=dbCg8pmqGp8mdK{){%jLdqU!rnCqg}>!(8uu=bHxILa>ecimu7vmef>GU7 z<;uPHE54y|8bZi0F=DDG_w%W+ovz6lD2d$oGFA8lP@6ZJt!W-OYqCQVXW0@|RS7xz7I|UKZ zPNLI-G<%(bw1>J77b@4ly6yG`r6@2M+}kTUPd}v`fs(kY|ivr}VD>;N_+oHfzzBuy9YlFYI&}>S(<41tDN~k5 z-OOLb5QK5+THc(Hgk{oL&^P+T11@R1KK=mlKwzs-U0@e5$|BK7fLB*=9Hf_A?YsPc zABp~{e=`40g%*g$Hv>zXfX$p!7#U3UM!PefP+vIJ8LS=SSbNSxPuAO*R?p#3 zByqiXc;ohH$A1(E&U1LPtYQ8G%^QmowS*h&bY$-Onilq!@t)?Av+ko?rbT#O5r39^ zfUYW{M}JidO}&~6RrXI&At-_SXW^lj1L1ZIy>bKxamtVT-QCj@4FyH?v~U#I;%Na~ zlkXwLo%zX*-x(XjFy)^1gFU6%Z_kJp=jYGY+c*eO_j)6d5T_cuyA6$z66^Pc`7$TW z4OPoY&L3jvdDBHB7TwY7zN4{1ZkX@olaTsBl=~^Ojt=|aA*Of|@-{wNah#0R{P6gfag(_90j|L6+ zD8hSQ%fJ;8O{1qasJRfhgD>ThM3Uq<%YvHr$ZDUFR37=ykTFOG^ zpbd>1Lkwv{R&`p%kGroXpYzidF|=@H7#b`L+QK9wvj)dtG*6eOp)!Ui!Ps+QTF8$n zBu>frvddIykmBFG*kkR|2il!-gzQd<{p7=wEy%+{+$hShhHd$cwDV9%26ldaUw|Iy zCGf8f#~X-|E&>AvhK6Y0`|Oe7c1!VgsZy_^VZ6+)PY$s%g8*6um+c}j6DWd{Sq6|^ zxdjA}@$M+h(zoN^%v<)fRJfzf9NZ}LYQ3u0}aQ^ z&B~p8ugP@ZEX#_+d?8jeyXc^Vt-h!SvqQaYkcST7exhF;BcH+6;1--~41bDEiuqi* ztU%3I-8222YVW0&G}%?S5cu@II9(zICoK>OSfe`>6@p_8)YR0#etDJxwKv*-aah22 zE33bp$HAN^9$=KG-N8bb<`)19pi=cvkfs9018~5C+QQbNVStkrSk#j#RTJoyhDiE0 zJ7{PI!Fkj7+$j9?Pq-7{C#76=3UW?guHvGIn6_?I2#W+29T}57eZLIf7GC+cw&?!c z!vqK3^z};YIn^6*t*>i_m!L(O3D=sIYC#om*PdYF9lB-K@4O4m=z2UwGx%~nsVm4+ zYdL$pR%4`&))!Qso0T8tXplCpwo#6PLVcEY)ekBd~%-`YOh(LLsr$V`b zrx=m>2##}{ien8HmX?4+RLIGD8OAOe#&Z6#$8?F-RY6bxF1qeoYtZKQvVZMbu8gMF zzU4EkH}s%4ZT|p{fkl045IfThS?ck? zejeZGH8*sYKwpvTXvKIpejwOxVTOdS3bEh+I^xAHl%Yg@c-Rmv@$jb_o;;Q{@K}%z zFy1?x^Kv#Uw*>u9pZIy0^GH7blOMFON*lx6BysY99OjKgx{iF~--qd@*(SaXDh~-P zj*JAVtlZ1}@gmhj#TKMN@jqlIsrKpz&d1jk)=SVllTfzHJ4v2ml`2klLyn^Qm98B5 zcJCr0B7k-U@ZFvM?UcDN3=_g?9~dQDTwIKaL41R0BqSi{OZU{>rG=-}#4G6t)We=i zJ+Y6an0>s}dk~9&SF?8L-%!D>a0X=)-lK6TQHS)_fyQv3+K=xRq*+yPt#;6zh;gkB zK1)u!k)fk6e}ZdZUG6hzyj+@Hxx5E2X`rwSZQj#I?qCl;Z@Pqj+pxnN^ zD6u8#bqiv-?d{o-EGn9eM42geht1Z2=f0Jcp@cuT4>^B$I#i5FRtw?%Rp-G`pCXc! z%BOPq<~BAa9{a-tUXF`_L(Ymn?DqL48M7P+ut_>8p?pNAJ05b zBiuH-O=Q2Fw4DLvPu8csoX~%M0}VG1-zRqEQ^&Yg$f6enY8N^#1XMAaXh37XJ=G2pJGAX46Wf4#@CBs$wNL>>znetwSA`9cT zIZ(V*yRVn13I%kc2$u-z7{5peKE{OXNWIcc518`={qKI01ib17K0XFM@*GX(ITK0e zk(`19w3aKQ<&>#Y1O)|IF#+L~x8&?g<^kaFcpXU~0A~=?qoyb`pwh!npu@vl-2w^H zKY#v2i8x+?fmNT~oJ3zZy2heelV9E|0}>Aonoh&Db5=KN6S4@%72cdEw4@?`c<*G* z*~_}*4a>{W)cLUm#vU1axi*5x!#EL*^(90oE7TIRPTYI>S1?OEb<54-zpF?nyTtBv z)q+0*PE(iD!v+?|+@9UFtjwW+h9AqiNxJ9ouOa$1)>uDg(?gd$^QgR+!Qb04{xYzEJ{XJ1%2tLbT$>aCmy&J*mhkoC`>Y0hO ze1UA3)DjTT2Xhc70LT%xB$?LQYHJ-}gdFJR0=GI^?3a-alK)@kVC~i%Y;0D$0|Pk; zK>jd5r3090EcjEXTo*34L$EjG`#r{WSZ!`iB%4wci`t4LheH*re?u^%!p6t`V!6xK zSI9pPPZ&cJB#on|arOKSOJDy6{XF+%A7!cuw1!Ef>2{pfX300tKLRUPPprZ|Y}G#- ztB8szxuxp2HdzAV*wcR2quBf#eqb67#v|z-)#5?1k{-ASvwL0%|s22;1$WvFmh5~OuOpK3U>E$IA|LY zO~IwE;;)Z_rMJy7dc*j=J2O64BNZ)K7JFZ|t1LEY7vA7PZ)G6Zr+i6vkm`G+LpvQs zUc5o>(*1(d+d7{=&nFyrs5GEU^}1>#I?B#NK^|j2Tp-FlK;D0w2PadCk_4-40wi9* zoUPZ2Whes*s1D0@kda0*UZa?Dv^$V+cd&Qjr04*wPpiw%TSEg!UE<3RVto8IV6&qM zZuSaQJ`#4{Z$30n|@aIEOh}P9xgUM zZuV5gLD%S&@pU&B3vxCt;(UUBZZ<(7er^GNp;&u67fvn?>k<=#ye~T@^%6qLw(|^# zstQ^N#4N#~u&*!isJ2Mg4}wmfQy#4a%$&{RGPlB@VHPm>dqGA)qMxuD#kOc6PLss- zK=htt=X3LcPhN?{X!WDeTbRLy&G-DotVTVROZae<6jS2jD!TKIi?BY`)uVpLG;8jB zicG$lNhFWWmdrIXGZ4dG4mJ!0MJ8RZ0)>o}jv1shh=XE_U=5n*(moG0s;r;zsTG(aTM7&Vt_`jJG&+}zS`$5BO zyySEhC~*N|mH_FzZs@^gN}7DHt8cKOGwy#H8(o2E3J(ulL`uwPAV>=UE=|Vff_ATD zcOOBSR>LYg<^_A5ckdas8^^e26Btb|4>%oY!X`cqEN9HRIMBNh1M)hDh!zo`Z;9dj z5UW@EoU2VL1}~V!w5>6hRb9pK&8KT!NfR{XdszJ({qK9BJaFx`9{Rv&!u4HSi@_hS z)0*3%gf8FnxW=K)f(w4(FRpLL_pUT7KlnDi!SfTgcoB{UIfVaye7?xf`UGpAEXYt2 z1G(PMjbYZSY0e4%Z`dHc7d&+ox%44`J6!>VOZX-sf~lwfFz5PJQz?I339WzLrl`a6 zGEZDOzJPg{^=nmMlP_*5wLB%JN*cMgLzP(JvTCTr_$|54i{;18l;N9apbb(s#hFGN zQ}=`8M}^;nkT~MZbtwYoH)_n=8@a)f3{({oHw9dgsTG4Y96z{Cid!O_q%RJl>w>Ex z?)=T@K?KgAwQ=iYl39%i7j`SO%Xb^0VF>bVgKp$vEZwechWrEC4QM?KCM z@{y{lz99`x{keN9Nl6WN`--3JpXgYstC*^P)>>ONg9aa{;2!a)G*zZWn02IzlOnsM z?Ip0brk}Xk#q+85Q{lsl|0$=-7L_`&I^aE-T(7VMIjHz49e>^M%)R0O<;q|WxUJ|o zEWa2`Pn1*peEbrAe;>(XXwOjv9T~p;{q-@k)Q!q_M117i7wRg(B?ck?1Sp-}cgMgo z!nq+Z6bvL6J_dnZUtn;3kK&GK2y$>gTAmj2`0~=Q%a4y-FHwX`j(8Y4#7~F>8Mgi% z5ZAAO#YymiA(%?1yRFR|xOo2OP&RnqTD*l(NB(7DU|`4vRGP`(nZMIOIh#Q_hrhr# zzuqodx{qMU`GlLUuduqW`3;r%va2PT45{&Q+CSrJN+0^0!+J=~dy_!o5EJ~!BT2vo zCrN;m(@95)5JM@KiJ3l!(IZeK*+LS8L>mZUaI-3fw7Ta|JgX zS+S;OKkP<56_=a^)^KAS^RIG?{+TtjRh5C<1hG-2DKNOO7m9xGj81KyEy&RTn~HRm%WTK8Q7FKwiqPX(WN z7dcAaYkc-+d>Q%N*-nZS(EqJpe{KES-~K|X)kqIVBW@RDv95FCxt=3|0rd~I-x)8QT*_i}6L_|2mr@46e zIRv;FID|Rr8FkSFcyjyu+7vh92RRD-xjA?|i45j6lAxfa`Pog8sJ@Ll3!(1HsA9J_ zl`urdT7RnHcVJf=>zQ6jK~`AOSPv3m83|Nb&^zrfVyvwdAFV~5fgbsJLl##+PQH7c z>sGBcrppD$B>XUYfZP9I81lWwZWe7G^Xqqt-+c;ajowWC_;_%jP+$m- z*47sQ{#PC^#Uuc>pA2&Nfbr)`i~U-6z%4BtoRW^b6C)tYSpM0mEec**ZlhQKK3f>d z7$xbC!R5ZZXGHUyN{qtXP>o?y5`9^;g`e@`Lg_MsB)CN)xu9G~9eYywPwU@;^xOOI z)F1UZ=Q`MOE;;I5-A8(X^&g#i4w zxGTbn6*u|}m8lX7dZUrB5?RnbZ?>?G+PfDwl^B#_y~WHpwDR{nixvw~ueulg=#tZb zUjsdsaC4Fe1l$HX>HQR%uqk61L}v2oqXNK?`VeEhjXZ$#n=$%)Y8){ex>84KlIZp9 zuGkYHk9ZcWSOg!_cPxs%sFg$b2#9h?!xTD1Y#T5y&YP&jY#xWROQR8kB_Gtu2Jhp3 zvVe>wiYdA%L`0+z%K%33jzEFz1QhH7n*~h49&{~q+T=R04uS{)dy(}f?R5oSMv_%o z%BvzX$3~+@vhL4iz(;p`RNkt0$^Er-lI*n4VK<5NTuS-NsZq)G=hfkgmpu;yd(lP- z<5(L^%Q07uk=AQg`jly6{ma42~}7Y zI!&2}!3u(fyi1X{6cCflP}0sSYx2!1R8jWMTuEjtF_fnF^9#v-152}-*Z z5wwR~mIQx-+68!AuQtE$iV+L8ON4GyU1ve)16SGg#l=TJiku5D^9hj7J9+>| zDWmr;JixQFH#gwP`z|@z5X>!an1W1cy&kH$L%4Xu1EfX(*PtMGhSZ7Ud*FZvXej|f zX22FmW0o1tb7WvL{lk&GUB48g&p%DI)>;S~!SYM>`ukb35;?oU2#vdC`Hx`Hpm$G@ z_?1!>D$$Jm@f4-NPe-2w&I~%*2QGqHX)2Nq!Ld}jLFqr)3l~FuQ&E5`$ZtPvWZV64 zuiS`tnL!rm@zr&Ut&s_mGoTtPM(REAI`CwN)E+!iAZn+>9FLWhNNXGl+ytgVcU}Nt z)0#awIwnT$!P!lx+xvCk^&Z@Zw?5rs_D?*6nh2PQpp5V|f>I*pIQ!%L>w%5DM42!g zMv_hf41^~7YQ6+xSNlppF$`-09cTN>!6CYSN>YWHWP#Vojqp1%5e<{nS{?PH2J<`Z z#x$MBPY{Vy&Tf1vJjc6(vDVmZe|4`!yhsr@B5zLRO-m`M_L&A4OS`jzebC9oqrpax zRdUyh7?$%^7r{B}K{OrOvbV_0OhRIUHXuG}K3T~w$LD=fiYm@kkBf!FUU-yTL_9kI z3nQGJA(r;%5E*Z#&P2W@#T?aG5%0obxG>UX5%x;-!~76N7M!BF$=@-+9JV!0tFv4i z`{YJtO6hoe8aiI5f4HOR(IScre^)7KDbFORD)?j7#2%CfEgp6Qc2Dp3MF`sTKKwHX ztLmDWoi-NoC}Dx)cV&8I)<1N|)49N7R`kXn-e~k%9*pCQ49h_41!9@Eu1`-r0A`#% z(SKorAV9DOArLnW;LE{>MLLDwLE?i3xPU_S|2N5<_Wrs*(6B_Y92kIG3)1#e_Ok(d zZs5`u1)-l3ANg*W5>LdZE>ZMNkqQ1vYWux^v4%*G!c=3k-f{-W!;?cj0C_|VDDPWH za?urO>xCA07-JtNNqm5Ris%rPXV(2`XjH?%g}RD)cN@`j&YQa3?fE6*cU;_mMO)~j zGqy`)WH~7@?f%-7B-4i!OxpjJk_?i%*e0`K3-!$= zL!YveVP#SaF=igY#nbP}ecdQwXc#=Jtt7WCWq)xLbw?r77&$;^K;rC8CDca-b` zE@2)VbkyV_7*9-<(0%^p@_%lQ={rHF41AjytS}t!fA8D>06&ctXW2?G zz*{bh-Tu1V{<_^zDAP&O4H35B7HL5Mgh6BcubFm!+lv#@-|L=6m3nWr{C+>N3dRVv z4i4-fH5pzT4s50zf(uB8z+gWr1&-&-Gn|KuuJTIFipV)RDKc14mX<(!aWm$gUv=;~ zp7LyhYi>5H6UTth7oS_oCtF%sW@G|fMNPnsu9>l(p|!5>vA(9MZw!vmWIgI#Xv~Z| z&sr}-j^^a#1PqLUSm!b0ySrj|mU*Y7d8Kkz>AJ%;qI4ZT^xuJ`%F0bO8oh4+0xs8G zRa+S{>)F0*7oSC5!j*uh^o4_W!al+)_#Zx!YwqQkC)1ZtTBs)q2s+QCop#>&{ad{r zg06wuY$9#zef08kU+0vX#uRl2*Ozy{{|@*aO*Ix* z{+QleXmqf+3zTw3ISST)+onF?86<@TKKNpV%7WUl9=g9^53kO2W#X^S1@~*iEZ1Eg z`*&R5_@crBLmhB5v?UTKbRZ3iRGRygRckahfeY8x7Lr44Wu=v+Wm#=GatK&nnh3+I zI>9!$Pdy#{By;AB;L->sCD41QN=*UO$@|;eFVyUu;^)J7J-qL9%noJ~I%}pLO6PyF z-&?Nynp`f~i>vw-2U7?zFpq$shB@0<5-+4+f!`ET@>gLRq`Rb^2=NkgWFeaRDLHww z2tKnGJdZJ*D`!NNLP*4O*!_mger1*^ZaY&98w%EIEkttPq z5*Fsc$`CI_etnJWV&q{py^I#S4Mb&dc6C+N0=NM^4h$rjep0MhW4XQ==$7R|t2iy; zJQLLhUNzLd71K%z>cYcqeFA>=X0{H8=UeDoSg1iDdIb3#u_!uuhxqN@>H0nSlM@!$UM0CjH+xY%93B)j5&Nyg~Yl)KcCF6UFc`7mE$fu2lxkk0fd2qysoD0!bZ zO?YSLsV+^mTD`W%Pc~l97e4{c(%K@eD&08@r1A_Tj&2ZnxG&Gmdd0wX_vyBPVk7Emg-J-4EPcu$lpTcQJd*{T7dzP=Xja3zsNV zJ^X%L?R@cZ%fWJMu~_Jk;^lVjc`_G<+bFWS#qn>Jt`7RT>wbE%Qca;W?@O!I)(0>M zFV*TH6GGSzf?O&Yrci7I{9V6+MxTYs$^$XC9m;R+?CALO=MSI-iUl_A00;)~D6@_y zed73Ql5HNsGj@NBH(wFSA$ut1mH0ef3CF4Pow}4cnLmnB+l2Ildm$KGksFS=dy*>v zda4bkZfj=ZOuSBy=JSi&bF-~e9zVyj^GMuGGy*b|zcjQ1gf=qg%hhY0M(g>XUPxD) z-A3z6LC{Zjn;j-op)t*mk1C7JhnR;<DQ1h^p;(kNbum} zoMdENJes@xhNKehUlF8F@o)AWst6)kc2!mme4nRDI^rBVK>Lyaw)29CN!lCvmg$_ zpLe4@L1CO$G^6zP%j-8_jYD<>r8N1<8}tR}|AngZn?yx2mIs(0P6r`FS85SDlrxMn z>j_L3kIqmBs^0XgVt^%5wVU#>adZ4&X8F0|u{(6wI8vLg)3hn{7PAyqu(*w4|Jrgn2(2pITC&Hkb+ig42A^Mm^1l{M!-obaV)Ihmd>rSEkuZs`u);<8=T)q-sA`RRiM)N z0g)8nSVwwnF88e}JNtL97SguP=L^rYS~Cfk_pMhB8FaSi&1>K1hf|>A%!j)Hq4j{? z6)=JXsesHK*!3wi7hjd3UHyvC;7i+)E!pRkhu?UG_z!TLmX(#2p58wrKmxM(pQ7mP z&C@*Y9TPUpWBNjvyDj}CC{^$L4EJ}SNlWR1bJd2=i@|(Iz5J`BllCAz&4!w*0H461 zHVRsrro;k-o~xs;>9mB*vksrr;n3W?T{pAqp|!24cHMmse zx(b=`yIM8lbGaE!c+6y1NmU7@p*i`gF`J{cmMGzqT!H@Oj3Zx5U@r3WPt(senCdaD z$gP|97PN&zOci>1daLEy?PjOrmg>w_>ou6a<>iiiNq2M;ZiEGCtI9N}#NBgTTpVN_ zDU?#6I$?mO)Zr*82&e8dpv@PGa4I?jlXQIKoRM%ONEu6G4ypK|=KFX(an zk0Fe{x9u~&zRLl^v}(20Rn>^W1M!Bwv~8`dCvjj!H8^TzR@EqC0$JQcU2o-(JMQHj zno3%o07yfJyM>s`+59?ZlQzZecWQDNX@Wbc)xHKZVt-4vGz}L!D?2mOkJ-Yg8p?M7 zMj@!<#=9+Azk-)VzSG8UE7~+xJWLp_woi38_Wu1ECJJU0v8^7txsn=5YgbxDWSjXy zdvEX5XskZKT%>hsqlS>1$mhf1%qeA7oV;5ePo9`3kbVKt9zd)5y@dI3x}0Gwz~Q_+ zU9R^&HP-^chHzn#b`5nQNHjU>La+oBrmy;e9IWCJ2^y41W9F2^<2Tm zO~dKY->R_i7Ft5M-ue$9`E025d<>iA_~J!om@^p zx&nD3)B4Rq-p3!2fU8WqD*lrK2WDw;v6YpB=%>5>@-(5zoIQIIv!h1KRmr(mi^-80 z<*zW$PIM=hjFJ@5fsP8ANJ}l&`EMxXn(1ub>(7sQ7q^&NDU|Z1JF)323y1S|CPqpP zNop7#+W|qHPed4kIah`$O=1{m(kf^`vD5Wz$(D9X<6Lu)%rw_GufEhSlV?6{JXOj zg4*|IF137-AV16y;YcJSA&_O6P|C{6tgYl`LR>DR&gVOTRP@SCJN>^fIPe)8dG zrW4>^M2#F_$OJ)`oP!RcHgMsyqwvfdS%nMUV)o;w+ct#v(}cv(k&cVo5$r&P*I1Y- z9n1A(=MV(QooN2);qC0BlUe_zVA3+c)dV#T6BEk0Yz3(9M}Qb2hdl^Vd0Ig57=}dX zc{fG{9sp7s&&@hV$S>vIr|{pz;{_jq=or-;S;Vk@B?KOuvwHIQ9`M(Ny4%Bow&`QE z!ZSKT6U>DCDB)mfA}uL_62fdoB(!1=slcPbTc`#r3be91cQu2g&o% zVfw)?pG<@)KuT(+6=<&Y^K0anT@Js)(}@(vbXOAYxr-BQKb!HGUcKRPJ{dCq*N~Fe z)1}u#{-D)zRYiFsC01ut37Xon zqSn|sb0442NRx?7Ej))xcT&@|2OVB2!kIs2jlYPN#FF(LRS;dn(!JL6Ya}T^z-V#V z=`9@fUNy8)Lh?$6%t{$@J=Y~?sQIQ?*8N@*g2a%V&IY)v;4C7v6(2F*>HKolD3f!) z_V_96rIi$2)Rf09@wu05Ypis1b+^%~ZBl{`uP*89oARK|f5H^$B#2@@%-myaBZ~JJ zo0)K9;}f?zzh&Q3#l~)Soyo?%jHTO)QddpT)60ZCUwfTJjKmS}w0S+}AZoQPEpYsr zs5F)dk{d7s%U2!!EW$JM!}8}4R(K0|-XNXKm6&4k`yr9CXwRytwmrMn)78}hI<2jw zBy3|6Vq}ukm=t&(%=(>=3rlV?n0Am+ zp5DVf(8JME7iWqSe0I_dKGds@*o1EPH}{|H^zcZmQ~jUsM7{?GqAChX@_N)df^qdG z*6m)N03XcG=UfY*_oqukSvvxgj5yw>l~_VE^k1Q`$3nNmh;|vJwg|ux|eZ4I=?n}sFJMmc$t6p zv$;wWR!uxWd<&Ied7kyJHwXt-6!gO3_`?HXfUdNcyL4W?;Lz#2iwN}UZ^G5*4{t-y zy7Phc+HB8HFYr{k^|7(MJyi%3orDV7O4rM+=XQWW_R9FLa4^huae3*iT^9-BUixTYs~2c{NuF924@sCE8t*Z@@6R5WYr`=oRdJ{y9+%?^)EI3 zX|hhr!OdR@mu*(pGk8soI2kcNq@GNPC;zfAmu`9T=4J@rTSV6Rygvm&BlQu6b{|_O zik(=iPOh%50tBG@&h1Zz3(zOwt6TtN4EWCgZOtB)oYD|blBhwce@sB5!#~2dWKjlc z1N{%!vDerC5K&f%VZPYxOl46hq8o?W6Q9|48ys=)Tn;&agMm*Ar;=i^pxTeb#rJKr zoyX=a@`o~+N!jRE!A_d>5zv)qqE`D#);_TYX(r(c&6SgVa>@02Z+5!w!aMJ#)J&(2 zyn3ljZRL4CJ^mU4a*5P>-tM(pE7QK1wG7- zHrz3184h6Hs4SJSs=fI(HieVGX@bbcF&ghpWK?ie>DK#Rt_dUacX&?0Enrrd=4g=S zO@~_-kiNPN9%BF7c^1&2UaVd+KvgIx_K@cWMO7r?_#I8QULa{~J$9xf-zPn-q?|xs zc6}em2m5PHT6&Yy@9qGfzs>ciEhz_+N2%`KWNtPE(aQHS_1|r3@53+^kzYZ6J#Jh? z33Pbodx2=OM1k<%K}*~KvB<|ZlwnpL-{%x!dMIV)nn7@Kf^kT02f2wmcb67Q~ag?{msA9LIGakI3P zTy~*O2Ou_WZSvo>D>1hHg>Uahy}+9OvfoEm^+gMea2Le8g_IZZX8u4A-KPcBQ~qWd zN%w~3&@5y(SkV7|81igF0#+ikkv@0szlWTZWed==M9pBSbjL3(hsoR z=6au>S7|#Zwf>l`2+E8ur{--&U!$!N&R=B7u8iC#@<(>>xJ_7Q&d=zM1zMHDv ziF(W6$B85-H(4c#1MWPz%)IMrJn1oZ>IDLSBqUGoBO8vB!eb(NfdW(~p^K&5j*6 z5PgU`!WqP~K27|{Xne!Ig4RsZzLrx+dqlIq|oN%Lhf#85n3jogGnVb0e@w)Ve^#Dn9`BJM9o0X=^D1v+T)`-54d zB*l95bma||Fe3Q4#kN54CkM+ z1H^I5eN2x;;xu?=J65yp1*tvCT!*+YyOKd|NdmMw`3Sr(1x-E5X95|<5x5&KA(}YT z(Voz4il84`o?wEK=raUJ>MVO2mUM88Wr$`@rL`KSJC*UQj z!ObPO!aqr+!6TH26B%cd31J%=K4B04(QB8VBgBXGp-Jc8)=>ubhtA@TqpcZ&am%LS zyIy0L$$rHXFwbdeWls!}@TGT<6d@SdT>}KpPft(2&z;-d0NKa@$Nd73%0ErA%vf)A z;X3$60ZMs!;B5(lt&ziGXN_|j_`%7^39J>lxGdJ$IVql6TU(bG7VI%ar26VpMaikJ z>1pKuJlLlC42Oir(8J(Li63=G)05k5E3t+hfxW;r^!4^DF(E}k631f$jnUHco9+4* zfS8y$Y)p;)8XR3zTH3(y$@!(0sg*(G^-zzk`*If$Mr5hiBKaGWcru~GYqe5E!k#Xv z0u^x=P1ppxL{tav`LJ2An_|eoB8n`;=ou_ay{>nNakYHX`#tadg34CH2x7Gu5?@+j z&R8W509G$6b1W^1k?l$|6UqH?SeZ64O8;$;UMC!&FR*A(mJIf;nE`UjzG4=q%&mrt zVl^H(R|oZNk~<__qAE2(4cQR#OUF2cQBek~-*j&;&Zx78PI&e{Fuox;{Wr=?+S8sF z=5#yi3_7e>KJN82IpM&U_w<}{IUPx)sq4$pqSMHB+uK!rc|X38;jg;JIbd+5v)+4G zjGgoO(5Tg79jm%HE5VHT%p?s@BZNE}NtYIj>?@4@ptHy5tVX#?Qk|&U#eI471FTjZ zBo+rUQ4Zvz%=YM*q*liC_kZ&#cxC zjM77uGLi+4UFN~6a!VZ<9TgP{W-Co7hQvu@f@Rmlu`&0_`fPjk+Gvr%{JitZg}@6* z5=-aG0hiU*VT*8j7XkxlIpH}`aO3YNB}6Qn95jKFE+SDUa8=ckpF9}hY}k&`{3Mym z+@e4fNywh!Ad@SoYS0t_Ks1hmaVheC4a|>4hW{JN zO0(uSA-{B?{E24v#&7#cq+37Z>VEDK1#*ek&+Gw`D ztd<7^@Okv3FGwSKKVWB7id#Awx~oIF%A9G^qq&hjy1RHe5~Ac*ewF0cOxu5oixwBb z*Z+p}tQO2)r9>-lfWw|E#w(Pn@1%nxp^7w{$M9X6pJo>!1)^#WtSS_VkV3%G-c8Y_ zYU!v!flx(tEFRG7kJtPEQguKzVNK;#Ra@+~dw|6Z0jItHxu-1^90zTF@Uz(eN0v=! z{xt$wt(@D2awI7Jgg*CE94oout9IBajTX zo*-eu{SQ<%s|~6uH2bnEgbp^{ktQRJdP`nK;IAQUs1bi5$WvE+wxGmI_!JW{@P_!D zE1s`G_}Z_{gIA933j*(d^3-jXhmnjuHv^1c1IxgA85Is{G;)`2#X?u$#B}fXWXlf> z7!%YNm5u%+Olt>&?e2ihX8USG{gx7x6+6o=Ap)EJ&LiuQnwsjZE(<3O4G+rPD5^w{ z`6d~uQIq}h;M5tl(5AIBO|icsh*zMG_W`13f|^@H?3*Cn2rZ~9L&~d3BAE(uwtHBx zWoal}dN2~c>i3m_lA`Lcfs(HbK97lu;Kc=Jg25|f6*NSQ0G7szqXHU&0JI2zo?75)3t0k$NJuq2B#XVJ!VEp|M|7 zoVap`E*lIj6!PqZL@P=xAX3Oq!om|uuNAH8ujG_A|Lxmrt8OHscJsVb;>qIT z5@0#ohiCNunxF9o=vtUm15lVXfBKtwkcp$U#%voSo`d!%B6oS^H>429Y(*E zOj^mgQDe9@TA`ADO2^4Bw)&ssD!~}pJ);)bp5NeU5pU1(8$d`_TUn&Qq!4EMz+O8m}i~o3>A-a#LCy|#(aB|05aFCfyd|VAg>3oQ>*q$`qXE~N7^m<;I zo0PAOmxAqCtnd1qm*f9>o$);aFlrT6=FS!Z#Db93#;H0V{&4$mw0JQsO-=t9zG?v* zvPq-I%;S`_tuecEJgpH5E~} z*{!)Vy5D@pbFj1SD30rzy>`OVNr+~Nfoili1A9P_$Dp;#X6&3>A$;9Q^RSu$&8G%{}KUi2H^igQv-K6`LN+1P$9Gowsmg##%U)}Q`E)B z!Grm4p`qqYldRFJ?d|TA$4C7sj&%YB1D7ANg<^-UnC zdaX@HlHv%yUUT2u3Ax=C|Iy7DIBpvn5f{tD!&b7uZG;ek{u#yVMy-+&&U7J!Yf8``I`EeBqZcy#e5TJSBU>T zNWz^p@P{8b2(GTKNXW>8CWn)bfQV<;9;XZ4@^x@SEgWr6YVz0g!cjVnTlJO` zMh}pxq2EgGusyZb%F2wp)mJrK`D;MnOsx%m$WvD zg(Nm@;bonKhx6)itTqF*C=?>3K(^pWzRS1sa%WR(YtroK0PiD8DsLIskf2327fWjQ~2$7`u+>*0q7$O$j-RS<`$!6R zDE973O6WNxFCS%D&z0$-@b(bP`MXA}x+pS=qrH0D@_H&7*;9ullvG9$Mf$k9l-#Kt z-w<4yoBQ=aBFwdOF^!(b zzEQ7;jF+SO1??G2?BmgNoS|<9!9g4ifqb?8`caz8)#jI5)p$G50&WS$@p~ED3%7^0 z4_g8JA_Y**_uQtZ3E@tnjRHS8O2zfo7-Q96uU;6Od-soO8Zz98t zCH$LlakJYz4=wd(Vghn9$J#Y?QrK|EX9``e%qeN)I>UF`*<%`iYp5Yb=0#+XM#LKY zq3WC_>hwL5F{=_|N({7WV&m}py4Q0*NDzx0+%U-JtoHu*rs2GUC9Gl*g1PlMBpCJi zx^<>POT_DFeqD3PrlNo$HG9~8HK8WgyXf~AZCp}8ma*s6awtr#eTIY~IC84BYP>ai zHy$$=cKI#O z_}qqs#Ss8Xy1OYJA{4=V2YN7{%N$j?p`@f9unQD5XoG))vOJ}Ck zDR)y>TTjg;FwM4xiW&)|3NGPUHZ=4RRu>%y>_r6ngW!(h+ZRj%D3G|^J#M_1MvMw! zOAm3H2aUVI0wyLV`@NxvR6SoVtSG_8L6iStRNZ#^0%Bv4%9s|AYYAp0sm~Q>Okke_ z6?08s;Xy(BupVGGU=01mDU;eA58+s&O*A4z3;|jsA|hfuZjJGlnDXex-#7N~zEhXY zWnDnJTidg>x$f3nIdd115^EAzgjZ4sjWG|_t1X?9TCTl%kD&r8EM(gcADFR&t7_|N zeY2LnU;8oWyv@dekM3Ps*!@^PlKXL{*1NW~R&kD30blC08HFc|NuQh}H3G^=gF>=Y zKm_N{4_6IEP1B%^g&1V`=lF=SgtFRM(*80!LHJy(aL&FdD`nu%t2G)71k9A)Z}>Bi zBR_1!cua`ZXRtt(8V{9k#iT{%L*ZrhbHUVLEj+lD=;I&n&l-Of1Pel%KhM=_dOkj{ zKX;0+vp8Ly>yATh4vspbu&^V2)Na7#%|%F>;#Ek=b11x0tV;fby)oo+UCGA5n*O@E zT#LK`^dJOWO}!0pP=n|$*`f8}VDvdViAF-Q2Y(F+-BsCSXgve8Z`*U=t6dIe1H_1b z7Dd^*h|KW{i_bji{AX6^NSElVzSD*uh&iaSV*JCP*)pkx8eZUzBBV)~^Xqws30oaX zL7Wmz4M@gtKK&bm&oP@=2CcIUn4jtaEQ2y?I3^7Fx)(B8R_SdDQr2w1Oqt%2#Y$!0>nZw*1>APOw^~%wr)UofwII=7tOX@6* zMSOZpd(FD$!pJ*3ai!Ze46F)gO%8FK`Q1pBc6zY!BEH=WKd3gteX5~y1D06lGXDn9 zbB(7m*z}Vwit)NN_H>fHkvmt={7dE(XG<*ROWoSC50$~~t;2FED)ezhnDo1~pMK!k?xcwdJLinkA(2=$T$6_L>2>V* zIEeMwJ!;&61MJblQ5S6q)h*BC6+eI&*wE@%W~XoNXz6(#%WK)Rmi z+ubCtP|xnJ{-Gavr7G(|P@Er$8nPB??!n5rvQ8Lf!aFx}7%j4e)tpx#N>gd2EZQV3 zrqssR+$LF7)>MS$2oZVV*(B`=Qn4}(O+mG@{)m~-;2%!;E9lU%q=KffkZjxU^nLs5 zsWtzhp9Dx6%kh0X1r|dLz`9UfbVKb3*ekYS|9+#Ba+mX070T`N0alP91L+wVKu;|L zMEQLJ;&~ndneiZF{@g=QUZWd(*k-Xg&&%5%*Hp5(62=Xxe-M`0iM(GN=3Oy)jRRUG z9(27GP?3#C>TQ^WnZV{9l@%QCOROoj-@aNIi2a6h@MFw{M9^F9HXoAx9`3_pd6ab( z^5<#BAr{6IPfNSN%^8zZT1s4vx>N6s1F$TMWbt%VXlZB(M{=^WBZduYY;a1r*tq9s zSF|;>Xe*gI1@V%`C6UiV&&}a{BkbviM4teNWQ*u>8qUQSRmrC|4_gisS*q;vs9 zmW3iOhU9*LqrD2(b`xMh^Gg_~szi{Ml}31Yd~n%L!#l~&#*z7B`qKF{3^o0RJ8#S7o2i`ltPqeZ%eS1i2K-%d!6Zwt>sxnyi8MDJj_N{e8M28N;{k z9y_i2(=h;<9nf=?kbiqx&KV1(Y?9aduX$M)P}(#Y;G~$8S9Ac_6JR*e)YNoC`(JOQ z@Ky%t+94$RMvzUHwR=V3+*EjUFHeBl;wO7p_20- zdua4Spf2fK!*v0xctMdmJN+B>x3R(o1dPQ z6s^WmadgOPsrxR69p6&~?i2&4)oGf*_+(bvJX!>j6 z$nN?yw9pqbG?aIyQAX?7zJrA=t4X&Lm5AlfQ&3NUjwF2CEOnjZetcq8+w*lck;J+J5PNeakqr(OkGLGr&ETSuLtwf04?(W0UU9lXWFP5oln;Ns@81LQ5;%IISP&OP% zDVE_VL0AaDHU9$e)UG!>J9}C}5o{@ea7LTF^GN*?m6;SCwS()ul?M&>r3JmO#QQ#m(=2`o5`?-9&eMnN+F~T+|x=DtxapjLdBC=bKyt1f~d{a>iGC zLoe&m-#v?B3%q#uZ9Kvg+%69paanlZo|YcR^^_^EXX2Fx8!s+%3L>qzIlJi+>;+5- zcz7v7A{pw36T;Rq>y-|t?JwbX*X!~sYHV+%n>(e?<&n3aCfrnQO*f2I&%-L_Z<-8u zBH*mzV~Iqrgd>xBo$j|QT6SGu;}ie(?Y_L0o2_z;1ovjLxtHhXlf=n)Fcz1WgOqHy zd%8P1@EZCURDrMK_YLZx!G1fN46vcv?DgXxrJ$o!M&Ud>oi7EJ497=D@slPyrS>rp zJ`<^Nx-es+ZHZ4OrOgly>gJ~+4lal1dYIfAn0306^eD@blm1@;_)0)d!goHRJ zJsBB9nAOpHT0NH?Sm)JrO;-6*Ubi5QCtk5Ohx_yMr(?ILbG!LpJ;v6ty61nMcGT-AQ zOLdG(U@~UchWc`GfYotB{i*j)`te8yE#%!jFd}~3DLATaH}8=&JmU1TYy6ArZu_f; zjSFYWWbgf$WyT!-RLNq2gu&gLP(=J3pC=9LZ-1gL>4kx(P`3cus1^RhDWaNO0yyOB z0Dm4HT;an2YnfmZC{qASX`lK!VebRYU)K;K(Hh|#L=%L09bN{x8%{5{0=IoU2)}>y zrRD$!@X3*FrkX-`d^i)lB8L8Ykd*>S zW09&lIzBf${eS{n6<`eERIfa!>#1$WOw^bE(79V7w=ztDhukJS^@=gL1IT%X!a#;onPW z+X~it3@>{=p|vzMG5S$?Sh)Uj|FAczJN`w(MfE+N zNrTl)#y(p*@+gSd>)htVfoVdYX$A0`0};5F>#fVn%b6t_XN`0KF@cY=uGRCPGtjD~ zwRJEvr$XVz+-V7>cpL4s%{<`Rj>+B&BM zkakB%LHLs<@(B}ra3D-#q8#&yv?{ErB zu2rw*H~f$0sG>#FQaySKk4G&}FM;5lj_il)=%<*q0(>h5NiBpvEE#DMQyqhxCR~YO^aMxnv-evIq2H2wYQcEQ!cLyK<>UjT?RF(tExghB0@(@|M$<9e8B-(8cjwZ4G_@Z z>~PWh*u%~b+1WER12Tnxq!dAhq%m?|$C#n-lpuw|P$#<7`+H5I%=Fs{Ax``(4)K@qs|;3-8y3#h2bAnMaf(fDMZ@Ch329}NZ8rnzkujZ4w z3lYI}9`)Bw#%*d&{&mZ8rX$Y1;CYYbU_;Q1=w5fd*zh|M7ZnW|PbojxtaWB|N3h1( z_5#7ySpxwt4D6^0W6lf(4^h=nsR!Jlm)vghDv`c?Nj;vs(uST3GBe}W`6Gt;8a8(o z^vYhlBXaVz!?YXwF7ZXPKc&sTEs@fDQg9*V=7pT7qT@uUorzA7%mXN#53 z*W0~5@2)=sELgV;{yPx;zDWR~36Z7?@_MH-2F|hnQR6#0I>gDrI+%EQeSiT25Ml3c zxb@?7q`~&Q5bbl|Hz9j+7&L$n4n2#)LSV36%~|*V%%L4Bp`r?Vhw7{`HluVIn>WdC zZa#F%eb@F8CYu)Y2Q4Vr2pZ5U@K1O&-yjh*Na{gdW`#U3Ts&*$cDt&ope}txq@T|s zh>Ss=ib2ju4?a+Y#4@eztJ-by`Vq-5+SVgR25(^?tCk{yA|$$WqQpE2M+W-EvZ@~= zH3$MHAYuCnGW(_NZI8(V%F49-Xc1f!_fyeF`_@-7R;vLY1I!n|>G9rRKM$b8vcqnT z1hEkJ`;NnQV&cGPh3BK(B@m{DUCRMOXh{(lO@&y}YbnJs#c`29!(_rNlVWc;?dh|*@(I>jYegBg zcY>dWL7zhyXLXd;QN@dPp)B_NGqL^YB~KyxM7Ye;=Jz~^Oc)wiTaC1WgsUNQcRH0H z29}2-g_nhfkwL^3;7`0#fu@46S4P?cJ-V(d>SAMMb^c%4ioukmXcHvkw%_H&VUieG zK|W_m(u5U_i`Kx=Uu7`gwLOrN%tCXG2?ZAwMbY)iL|iB{6my(!7o5x!(jCGg0>1@O zarenFXigYH`!0PIV5l_$D7HA4ye# z3rLUYsd7uNoOG7GbNLJ{)@x+W;l}Lm*i^7ZxiV)?1LSptKL_J@I{@H-IJx7w54u)f z+Q@$-M>IZFfn9&A|2(nxM^kwivHSiqNJvOIoDKzmHI@L$$;B84YPsTN_tuv7>;X-X z)&xbiZsGNjv0X@+LNMuCIhmMNT@C3AtL4FuD4fi$K#owhCpjDEikR?3g374I$~>{o z=X?pslU4pL+72m-tBoh-mRj(y$Uk$av(>*q@oC7zH`>_VG-zxajcx0h`~SZA2D_V?x#oAB=W#gm zf2b)EQ5uC_6>fPD7bQ;k+7C}&p9^Qyv+fl1Ppvv%TC|8%6**pGdEz4rthw~BD2xNS zWZt9Lf>;j~+GNC%?bz7t=)Y}F20;H=R4%>%cwpiid6@#YDark-ZfI_5J3q*s1w&rh z@qE==Yqg*E+?9t5AFQWM-uY9CeAy!EwS4Ish|ojvD7YLmfboa8!W70?d@MTLxa0_4 zR=Qq%c#w?>eX+zJCs|x#)k|tsE!!dX4R?u+k6^5^H6$>^K3LQz$b!%4x^B1qp6ufZGukT-4q^oL`Mh$^tyR*2?M zbmW8r>6CMV2-Hhx3`I#n07=hekQ{c)@Ie)@r0{kJYvq^&z_7D%{Mh zYMS-abFM~(Jec+81B1?2Th&$RCrp&Ce~3XWyU8%}{*+b&{Kjyy05@RcGG(JP8hC+<7IJ`b&rkUYb49djgx6FqNK+W^V>3OvL6t$BW>{dZJh^%gxdb$*L zA`s=oR8Uw}mog!c%D~{#P-k`B1d0Paj_y^iL>X^wYyWs+x-ZdOwczJ577Qo;GOC7_c*_Fq+V5oUOiK}9M zEhmZ&dvt6!U!~jmZOu+pN>Q-D9CfwhYw@-XoMOR|rEr;_{&zCsL$Q+qD3`#nRJd@2 zGx%C9NM%0CH(DWh*Lg=+BE^$%i=p8@spqeJ8R;i`{wvNT<;BHT*Qt(z_aw^zrnG^% zN4ca!JrZSx=YRLD0OTJ%wM!Z@2Sw6k{x`rr7Z?Vsjx&pw*4AGCqxJ*tRv;rO^TUGG zUE9Ty205zOCbPnha`E@zNlQd&1sJga8sWL5M=1Re*9q>xVp)uciW2iUR4PSA@Mjga zX6R6UPU|J6URf^>Q1J%zBl@D9xRBFDpj}A z2kJKYf^>USotH{B$Yd_Ga-8&`=Q4|j%e9$}n|(q>$~BjA5)Rv^Y>U;w61kTe7OIH{ zFd958bDB2yK_RcOQT&ar@K7gpv&djTs{a6eUosTED*s zye(6c#^su{cwJJqSj9tRIjaxzZkR`EhEuljgOObn`p}c_daGo)Dtr zaa~}EvMZG5ms!r>JqagmE{X|r3e55fa>EO-{tTj3Z)DZ_Dr@p81Urs&-qYbXiZblD z&AiXzd^u_+ab>ee>yPvy`7A(nvx6@oTgf3&Y-_HGDl(S7KCg|^opBff^HIM8eJ$BC z6aoKB+4ofA6sziB=t9Ro%(xSwdHY!PR4|?MH?W|H92Bd_0iv-xlaEd9idy+t4>t0& zJy8V}dQ%WP-7HxAVbAHv*4n_VvR2u+FugWEQH=xX34F`hb0Os0k9Nb$mjf`*a!`6n zez=5GquHSwS47(Bp%7 zxpwu=5(A{7RZ#7Ji{ZlrKD1!-9|u35c-yuv1q9TM!5uZurASOZ zx%{gLur1I41-2i~l(<)Uq!K^8Cz9-pU`n|+Xf~Fmce!}EHKfEdix*qncs?l)6puOd z)T7yOUCF8bovu{P{Hw?I0{M=Sg|knBD@r>Rl+HY9mTZ+%L)i|oEzcprGVGR9{CI27 z>D*Rwt!C#j-B^bRG2e4NR8cXm?En!b+OXm)Wqg;*k8AyInAr^wwP{{({$$X6V3F`s z!2p++djcG&zia`RR*2D@Sdj+6ud`TdzWJY#Cd{-&*#8jITCQ6}(NJ9fISQ9)K}&NX zMNR7x|Ws}}&5vnxDpt;{F#sChQ z0ww>X-vLYVbWIh7COUgTf)vQ(93izH?iB4vX5p`b3mTaD+_^!_uAV2wqGUGR-?p2VuUEUav!4qi47=4>Gm{ArzMlc`ZuBdu3u- zir1k8rncsX;xiAqUS<6LsCP(Mm5@p-4j0J9Vu(X2>eCh^WuN% zLrbz;1plZH5={gpp7}&J2TAf^U^Tu-oCW+TqkhDnMHv_PV(S$wqlomWh6UNCI8Saw zvlLRM$G|Df<9yl^x$xcVZbz`T3~5JQi`$^j12p1}BT0?f%k6hXOS*Z-0=xy`F))w# z{EMW!J6Qsv%ICpS0%@#<0zNkf_g(L=<5l*Xc?DpksxFt?qY3}FP;24W43IB6SF?vq z-A8>^hPvX&Itjw7LTE)&7eiUBU{P+YsUA~JP1_1G8QPB9A5|eRT#Q(m>vbW1Z#=`j z`wwj&P5$%Dy;!mxV#C#D_80kS zx^N#UCq;3T){3^mAoFR-W*sDGiYdxv$W=*ApSk_mgy4<(=V?7-46f^^Wc>T)-wkW& z(%Zu?B&G%0<>daO|n#6FB2wLv6}Q4>MZ-|8as$06m`6TiIn`{(5MR+&jkzZ=@0xS% z)+w37phO7E0pTpaKULa&YEPm7Pp8q1!MyqQQ|$4|Wc7_HIaCLp2MlATqN&t{hAc7AAo|o&Q@-TAld%O?~MIdm;FJ6~U4Od4z zISUN`#;tyEVUsT1CBs^k8^p}z9yDl8jtO&dHtj(f6AI{V2$IeDjMJ+c-#0IMk9nQ8 z(T03}rPEjoMPCm}1ZmKu?~+XhiY2+aPGFf(mFe-}RFrBL%t1(TgDl0!|H+tC+;=mJ zj*%=B&EaT73QL}~xqV;Yt@EC6Azy3TDTgpE7hCVaF%e;$p4q3ZKa9L@xb3Gzp4pqL zQ-Phlt(33 zf2?zEA)bI^`$uWtnk%dVg(%FIZA$1I2AV($?=4ZvJ~}-O_ag|xVyF&0c#spB?1|6z zGn#~!csh{drT{&I5G9xf$7#%G)i z{O=dXvesg4KO0MwRXG{72T%!Nf-s_!QvhQ833QWF+U9-I-nKSyGl;|bFK?&}9TCMm z0>sE08yl07k{oBm#3Da?Ccr}_AHHRORw^{s+>@M&4xgq6<_D|gyS_X|CJzru`O`Z^dmhKd7XOKy z;#8|0Y*VQE5OPcwsm)QWFQxAh?i95+k}}ATvWXZ`h&hzcb}Ao}`3r_=FINQ@5nK++ zf9|+@=O9GRN}yZRisAPrlDMf+(BWQA;|4V8jcbh zpFon%Q#w_oZt+ecKXb9s%gZW_+rNtQsY&6&?(=0wPbd{9A$1p$iV}_v9|$7ovmZ2F zuHB=YEyVknL9s-9P@R!fu0v(Z)i_a@99bGF>$bO6>b%Pa&@lw3oqN<)HYXLOVRl5# zC!nhv`~cJKH|b^)@1srZ3D8ZS>&Svb@?tt^V%Yzl_mc17;Oq$XKk8U{Tr%)qh~ z$)7Rf%s*}}4QKxaLUYRIk(EMc`FDOM1{kghS9KV=q8mIe46}s^BRz(O1|5mrNw6Tj zR;%s3S9H)--^_&Y4Ligqu@oyKa9jko+ivy%)+K*oj^Up?VF9Szc zC3Iz!2dohW!bc6n25Dghw`ogaT4kO4`%W}ivoPVlV8n(LS_aV*!AJ7Dh|eh3UEb_W z?s{%S#@(SniUxa{SoDErt2c-szBIRSa^T{}JqI%moYxcv{6k45so&|GHn1KbxK6!| zI@-18g=4bYRpIwzoFzCyeTf6GjIpwih?nhKU6-w12CoX8yy~kT?ZY{^YLX;p&a^!1 z8~(5VGUQ9*?u|f6S)V*cqnQ}(8tU9{!?F>`*4p+>#Gj+CqLz2dwN4kC%mEV4@q7ii zf}YOS(~$6=>vw)ezzrf@Hc=On3oB{Mz{XZxTDobBPDVs_X}cVqr9d4XCe6{>Q3|VI zJT=T%A8UaebvU)7sf%li`kRR_mMzGCHEy!gSPzYMhDk+p;ntujT1rGy0~ZhXIiAf- zJQ3DMmMR)Un$p?y$&N5&!_}&o_SwmR_*@9U`hpR(stjHql9a3UI(x3E4>lhc+Enf> z#B9ikMo`|mj8lap^PVIRRpB1Q1A>$TdWwGT1FC54PArc+L3F;xyu4z>=6p+Q1%Hq!rs;^m(dNikMH?>sL&0Hq!4Dhh*GmOW3C z#gvt<*kOZ`6k)`_`p3CgqU7qYux~#^U^Rwhiu&Pw!+Zst41`>_c2+?6N@(uJ8Kg%_ z(dc7}sNv$KL!R~{;z3Eb{+zjy_F#Nu#-YQZp`l1X_R;Evm8`ACWvph93?COncTiwW zT?~ME+t{*|#-dSjG>r{godAM$IJ!L)N!*@LeMjXlbodre(cL|0C=>j-eCi-sG180c z)urp#SC}CSWDWJo(ywPahDIA;DKM(`Bn+3!uk~PdDYhm5e?c}YzSU|jUo-gP zQK!XJqt%hCPFA#79sd*&5FNDoyaBjT?eT2lle6Hb)W$5&6aK5d`Off> zBfXhaZNnKAeeGsD$>+MeZi^x6D1*ls_6ee6y#`=rrb#qfMZ$1{}7~C zUX%gXdx{J0&_2!{9#!S-o(?|q>dH3?F7Vk%Si=JBC<`6<9maa> z1S56dL=}^8B}3%Det7(KoH=<0E*^nHym|Ue-=qXw;Z*oLrqRNHBu^@ZD7;!;fNfDaEw4SRqad+SyTrU^2qS%*y^S zN#N$5)#~wIWm9oiUtKG~4^aY0{C#KxOP{ORGHht!p*eGRClr6L|5E*?U=^z`)KH8v z>a7vz`^((n$p2kMp&1grHI) zAzUvG5x1$1&<+s&W`U1>xoMg_b|>;GhT6uOzpJyevzgUALP|yHS36^)jajTHtv~Xt z=p(TVHnXjR(uxsPrEQ5j?78p@opH!T2AhXH#>SY$f15Qnra=I7jE?rX`aem=E=tMz zr{m*sS}Q}&{nn<6!~COu%PbEk(1q7PzoCn6c6rE+h(scd*CO|>i>3r(#5Lu|t>2hp z_f!Qm$(ML`+1Ox_AC;{9)!+{3$^>>#M8EFCajemF?=dzyoFPX9li+rftb! zF5hzg#FAhp0NEZY_+9qf{m}3_=%SmFzJ4cEJ^d_{zc_dCDF`g~GwRXeWv}s?&glDN zrFNJ9Vc%3nLcr8exI4}7!9*GA#3v$}r_t&Nl0L`$r?sKW+BYJ6Y=3Ro4R8gR-|yf8 z;4s;P?KONnyW(}PnAL!fdP(u=%_0!_l<%Wru-QxIT=W+n0glOy@AaO4*cCe~I?5b% z#l-<0K=w`>)I^A)g+05Pqv*&cW9S}J19$b`TzDD1#gN4x=gA0t!+BWq8YGl|AJgf%NGW zGb5u!rivOM*RQ{weqX?YZfbvGP$iwX zsxWN+wtohq#}3Klqj}&3QNFkaqJJ#?hTrd{BEqB_^5rrZ#y=S5b&c28&lovXdwzkp zfrooeBQ;cWYFszdDO_Xd+F;<4*%+YLi-m%Nek14nWkq!Cfqo@lGBpb_9#!2%Ax;R{ zD*0#)V^murTV+*pt^TUcI}v9D^1oiq0^m!r9>#JL(V49{4Gtm;!6}WW`X4Ko@5|f~ za;l7)R3o?|0&7Z#b5JtvCAsn`^O6t6WUPQSzYQ$C>*e7(uuz}M2b5F~vVY*D5~<%z zNk1gq-C44)X{Iz*IhGg1D-R^Oa>gcP5s(fRW93-tEjj4YZ)RHYm5QqdJM1|=+*{;$ z=gIN~Pz15e{N*Z234T%+(pDueE;wEM7{JKE_wx|x5U9JlAR-Il&qSwx{&tP5gE zEyZRm|J7U3a)bEcn@SL%^HtIjiza*uDO~MLEzDJEF}mTnn@T?^hKmP_l`N$yqntl! zt>3cr4v$(EhwX(qDcySB841sLzdaPG4-`uwTxFmx%c^Ox7-+4mF1Prt%~MTqRj(PX zG|4fPUu*nLS-K!!n1iK5w)&*TBqpY_H;zpPVWAqU#g0-Rhx|yUKJg zU#QYW59Zb1ZG;=hr4ABy5=u6!62~TB?RS6aaBNH&f zrE{NkQi+8AV{dAKLMy%}uY|zg6VVBHck^&rPvrXS-;%lI z2+p}~4^M8IFlKAPKV9|N_xAinSVFP6P9l%RxU&<%rwSUD-Tlp zV74b%k-`A;OHWmB=6ghDybN`O?wfEYnl%DF)C8?0c>*a`-Pe(fX!bN71?@Wj%%$GM z4Wf7zOouEfE5s_A#XXyiF;}|vD8*>xM`}`vJFKKXU!&>$m?txq9u5u^zP~%%kCj!O zm1V7Qii3$ubt> zep}{7n=$rh6shiOn~^|v4BZ}WzZ5{yvts=C6RA#=wQXMxf>OmGHkDYS_^Pw&B`&K5 z+Z;q0(u#r@MkQ80q9n}A$>qG;_qW-o&FjY3+W6gQzqNV5*U19AzOC5WC6&TXcH}nE z)eTp(p0jmps&?yg$Y2};u8bK=%Tm_Gap*ISh4|IeSA(S zm*~eM$eAfK+D{wi5}9$i72x#&%m}>qS|6v5k(`n=^igPjX-8iRLL;UR%%@KSP}U}? z`xDvjhWI__0$({Yei4!>#>HiBCYSLs@(6=+l<78a;WZhsRJb!%O>Lwjg#EQ;G2LZn zEul`-)BILsP^{+1Y3eQy7k3V9zI)!!{aj01?+kc~$&sh?t^P%Fc=#)uup3TsqzC4o z445E7i-%PoVtZc<3gZzxus4Js&Df|z+1oT`7JPp3hnzK_t=3Z1>e0ItSp ztbefu$?29zWT5}N2f484bc{E$&a$P<)uokH;PT31ikQ00@jXtUcb^}YePiHY{6_g<&k~@eZp*XILK?}I`^SSL> zEM)M)vyo(Vc-z)JC#K2oB)M)=QDr!+yS!%h&l|8-GX~l2zH~?$<~1c{5S){dWo7)T zQ4qiE9CjuLGXeU6SnuoM$NVZLEe8V}V)hYb|08vvF+F9|pi(tm_zi`eg_N6fIbtea zgX8mOVehM*NH^rMZNN9-NN|E3@~|%t-dkz<5tc*zvj}UdPDa{3>o+|_q95H6rDoaE zQK2@j9Q@62Rq3v~;lyRG5@{rb;?roN$Hd0Hf5z@lHprj{rcN`>^G`&<8EhJaoiR+# z;#^J=BGN>!@1t1VO$u<|g@`oymObl_|LIaBVV(RM%t1&E`LKXO#Qu$48a4(#@`??z zcrooaRD{IWpa8A(FB)gxo6EmZPaRczUPl#z4Wc7*guA>Vsu%I93upL>xYD< ztlk}Osg1!b4KRg^hP|!4MX9-oB_5~V1Z8Wp!aigzJe}m2Se_0+6 zd^*lIG4wZV=#YwcS55HB<${&!)_mmM7Z&y%U`36iAz!qN(#K9@5*vQzlur&SfCH$1 z6%&cUNc`syTh-T=EBN)r@y(&F60`}!@iA#Q>|8l-y-=(XAD%Y(3eFc>PZmu!RGgae zv&8-eVijn80PClw*D=X{WKm+%pAD=KZBreK-E282+-BxSxZ0dilP}$NZYhKC5YHM= z9WQ&!QolV8_DXx4ENkj&Qf<{*EU-3+AvFj4gS3V%I80KdH@rZl3|@!_OutGU8(@$? z_D~Lny+hPveo_gNk~c1852JkteKzl-2b;5#W07x4Ej6zTY^xnUko}`a6uJPn-L>ts z3F7u|kE0?ByOG^zi;E^6R@4PgISKB}Kf_+-qVSl@9Szr;tY)_8a`Zdh&!b`l!TM?T zQ+meeGHqChM^)nHyao}xRB_bM4Y4&ar=RBfz{ydO+^9TCO6jeDNhmRFWEOS9jKl3I!3IY1%(&C zZ`6!E6>xNXK3hBRg8Kbm&iJa;|_Cbw#;kVwK(2%#F&(XhTAp;m>% za!s-K*l^U79ShC{vAj#SgnzuOGqGshq4}06NM)fRpf?qbXg)=f65G5mH6z@hJ?8?z z=``BkS2^>EG0|PSn+hOXFx+fqt@%>bD#4T?iLW|>2Rg*t&D3cP_ zf{;n}=P$K1D`CtmB2v;%C#RW&Cz+%jpFxY<+>`v=iy+VIisUP48F7dUw_8>n`=?+eoqsKP*f3K5?vw`ZK;EQDlmskvq>y195z z@&~iyWf6~$D)sdvV5^H?UIw<-LKbztoB5G{p3luC%{Xf1ntuH1(xL1clSj+fWZuq| zHFs(1Y{`IeVJUk}BFJrCY+hHf;|iRKXG~B_S}5Q#bMCimu@g36xn2T8*kyu(-~4cK zH}ilrJnV|Zo}hpL1i(m#ictt(clI&=%#%eh;jcoNfZ~R}4vz|a`XT&y<_XDGvNru* z1{oYw4X0uG{ZFr8)26|P-oFckg%m!*xZto3Wp!9Cpck`#JnaV)&NntN#4IbEKs7NX zS*~zt*CQvXGKa@5U*LE>L{Kkbi!z$1xYtTTk1NlnllnYNbl!0{URIX;IjL4$Q?Z@Y zhjF!K8jCyU%E(0QN`pUZT!QPb!q~@+76IqelOw+atgMoTU@peM$1l&?Ebn_=J8zoIXCLLC_SkWy;L=hjC*xM@g{scVMqI$8^}cWX z_MOue8~T~+@%{S!;rjbcqj7`;(>Kr64=koDtX^0Xnn=G?DF5-r7SKmZ{5yYtJO9sY zVePRVGWyUE`{_}&!dETc)+z-b6<$JjNGE5Dp#aY#IWOE*GCWn;+9!lG-g}ddRsSXE z6D8DvG)rmt2&MDiV}1K9{Ud$t*#>5GZEhK#MQ2IrSsUi+Kf>B0R)WLAmohF}>7>8I zqx{=>s0G@xtKwuv?0PEazM z)`q^GUs^O5J@jZQ^Lr25>y`2AX>*@R2AvH;uGe1f+x0t5c5_&Gc(q}x+vQ8EpP2xN zo7{Krr4>sDX_m^-@IV2s0|TCfk>noRCMf=dzl!mZ93jyuvI?#&o|XED~Q8Dm=iCG3!AQc=jwpAZQ zsKj&SgIV=dJI!u=gy?4KIro8zr0d-maY9R-InPUAu0&h#yzk9DNQr(T?wj=T5!(6Fs=)KZ+6MCv4Uy zh{H?D>iv|;;rsaLJsZL5$Zf+jP%~!mW8T)h{NZ2!|LO@panH9yFzBdV7#<2J+oSh~ zz)IB;b1L(gB-~~U3E(Df{g0sAN8_iM>bIw^x1;LUa_g>}I8S09u=m`av*Ayys=M2G zw!;GOb+-|_3x}VptOl&~U38vJ$V&$+L4p0`J;ZVhH@O4GpRghSpxbW&rnQAKi1F#-0{6(c25uniJU43KKtc*$M7cZ5+R6$ea89H{g6ZcbiDymJ z2|hN=1}`ei?}(qUqioZQn^GTYJ>?GbFbO8akQGA*L>LlC(@gQ{4Ya6fpFTr3bGY(r z;;?25KHm{lcRu#VL2fIZ+>N@7_+E0-(_A0_;=li}!N0A+qVNCMhCwdscbskhMc}E} zv=_x?PQ>{+2PXf>YEm%u&S;Y>QPKC1_)>|VJVl$gp<1uW^cak`vYcAYRDK*!dE-`= zi5K^`%9w9Jf{Zllen(x|VW}en;v=9;uN#iXMmDk>j26LwaL-0@0K`RuH)L}^mfTs( zMM0)v!Xtdx%Gv=I%K)!RyB@WUE`F6gOF6izg1#Kc>Q>lS*g7~m7_QfuDGq>RPRn_! zR@!{W=GTs!&-I)A-@#+P%L|TddMf{+rO44y9Wx*3brVbPPdDT)BUP%vwEtPo zsaGE8lU4R}lO;1nR{>6q_syf2Ea#E@7seH>GvSwX7KB}uP+~@Otyv&R03atdXL%&; z^%;*=7zvjdiS!ulGZ~LE#ZtJpqK-^jga~5csVuvlCD0{de17Oqg`_0&Gv_P3!ZpN4 zTLgDZwo|}b1db)&!u?!d3$iy$+iq_CEki?KdU^S& z4_jG+5;HW_k_`lq9r08|U(oHyzVjmu?Yn?FJ2#%!?>Uz`&=c7Tt#FV2<*!R~!GW`j zaX)-y{`R||qSpL4a3Dmawfcw)aJ?iLQ5RquoSO#_Rs9rm@p)M!`f}3g5zx_PUsF<_ z5B7TvLlY|35J-)NQ}TNCqLkfc{#5_Fu)#@`61l+b<>9h<-7o8)o-M3rY7OBdf_)}Q ze1|XmV5EILuQbF)kLL<|7G_I^K#c%798NL~TC}JDT#(<`YVJN#hr8137zv-8KYqN; z`&Gf+-TShEvXr#X5J|R?<(7%J>FZ*v-&$ayUw+SfDXvuhhOcYcDO;Oi+~u|f#JEvRy+GuM{=dU7KU9d}gT|UCVQ) z!Mag)?gL=Ma8hoQx7ql@qXN?8-YF4D@tUS0u%-J*W@S0gxk0`Ad7I<&!uhK9OhbqF z-?q%XT}?&Dlo-cdcb2W;ClhZ)Z^ht}QvQ)f7X1rQLjN^?!M;vSqDeT%15zDDAh!>g z60R45wvoL~BKrCyJj+?1sxo`AZ;9I^hJh=J4z}EtBi{*3Z)=HNnVxn5YP(lgS06ZA ziuTPYO6~1)bk!W60yq*5j*gzT?5nL^y*0kr6pg&15U^3xBr40J<}($kh# zHoXG5BJ6rPW07J@99@B(S4#SJcsY)W}ozFcK;sqHX7C`4a{Gp^85V*wAIFKiRtMHhRV1? zQ}FKE!+=v{vBCcIEL@NG1Zklfi%L;0PYG%EAYYE3Afb`mOPO3x3C85pBKr#W5mJww1c?z*oUb_B2~1ox5_sv;Xn?lRUcrU3q)%!%JAO@*L}i$?;Uh z?i7miMx#RJx`>m_V+E#c0+XHo0&v6MzYw1Qy+3f~3i$0zf*Z@Jra0);<#8N#uq_s} z;Z(7Q?FD%p)|#F-uiS|WQ|6K_ODz^+{+gv)s^Y6fYOTYKH+I7uhO=2+wYExNosI|0 z$n#r4S<=GHW1;rn%zI-ki9C2Jmkp*G#L6AOHfJ?+c^RIl=(nV$6*kK)?)Uj6Upn14wqn{p zx>al#tuL}lmiu?Eq9>1Zb4a3>*8MK4s~S$(Rn15*3RfU(br1;dXOiJp#o=Oh=es6B z7brdVhZ13eis#gO2?9qnb99PzlTr6OWhoaVOnr5%Eaz>kSk{??fIHkBbyuG1Qn|PK zQ|#Q^5g5y~2-F5uG{kZ0bK)B#rS(owazcmc=4C`L;S_P)WG5FbNPNJ+;7Mmx_Jh%d zpP7q_lvc>ox!sWpHfBqM03-^-X#`3b?eF^;E1o?llRzi;m;RyvO5 ztNd`Qs%T04hlB_whYNKsTAhX0YxSNG{q3OBBo(9Oj0^>X88_g#!upY(IWSnCl|aj( zbu83&#OgZIE2>seM<2-wO(L@SvkuK^2|pc_XcVG5lb!b0ulmis+QExMzB*pGNw}6I z;U^0N&<4v*3Wlbx8Wxz$@<79S#^$a!d@GgMIcpS=An>+9O(W1k-eT%-&N9FES~!nA zPl*IUvt(FL23exP8E&wsM8YPd4##aLzA(&?#m;`q<`uaJENN@ZvcLnUmzGkkH}hY6 zGB|wxba8I7$pAfV$VVnF8G(uE_f-wX>>uiGdFZI$Olq3C656UngC%Jb#WT(*UZN4j zlLwgh+YVtxC>pA@6VvX@dxLmkslEF7`86smdOu{lm^CzbS@hLc+C~?Kt<*in7p{WL zBBE$UKF69%`IzQK7p z;1F+=1nw`&7syhvW#n%6DgaGwl^(SZICzzB;xAa>lsl0WSxBK* z)242nQyB#16@ILY-4HpQHs-EpUaYS;U!s9jRYc?M{qz+fnMT@&G(zgB1Jc2J+9}RE zd9jYxuZ}~L5J9t$_6H6SG&{qPG4p1@?& zke9I7l<-th^O@DDTE1(8Ea85hWx){5%@quP>F%brIy(4;@+~6z{pVnWjQ&hgSPnbx z%$<8VBGxCHBuFZHjD)%L`JQ1p&nbs~d%D%rY}<5<@F&-p!_@Wp^~I&EuXa<|hud_@ z9rx?)04+f9+snhw4i5KF+us}N5gzW!wGRJ@wUw`(^#B5yU6pF)Pc$`|W6S_E3H8rH zD;>EYn`DB4-ObDD~l6aS(hHn)tQq{xD6g*w2Gi2dmb+HOXl_zBu(?d@~5Amr4EmDTpch zbaI_}za*hRlne*Mu;j1;GY%s)>OLIVwl<2~O^fa^QpKe1TnY9{JWVu2ZE{kE+fQr8 zPfp+O1H0biNS_e88n?4HN;g`w8@WpK^(r;w)HUSQv1JwI%TyCuD1d%Tl)_M++BrXJasX^GbixzSGBI#&e2?^^c-b&7ixpu?J5g z`|}B2DQ7ge!@OB*zaWq0Byz55&9{ zd{h+^6EmavK|uN?h!aCwWfB#h@ER@UyBuA?xm!5||M7;Kc&|2$y1ZF8`|q@XxG@>X z=@+Wu9$u$fHybW!0R^WxGu4qs&4V&htDTtMs>u{Yc-Bs4&}i;te&6OGpO)%SbF9y~ zRxZ%wu+nC3?Q6ZTb8|D0>*uvMJ9KURTr4eJ#tp0nWJ)sivKE|{16HyH@77zr7b;20 zd1;CCW-YW7ttvFaY}o2HpSQQScU^QXz;*`IGMKpSw4+SOfHZ6zA4Djig~K#8H?z{} z;s4y`zO=UoWEx|~&tlz)7S=rWL2&`MInt2%c3W$Uh*#H$lzvnk_pmPb-vX|jrWb5u zAvwzM>G)i+c9y5_nu|DCvK{!mkvLki>{lPoq9KT;`Q~dsb`IXU&q`l72PZ4J)LUw+EUz-s%aup z^*k5>mx-X(g~nfnWpGtDruUp;uTsR6mj%IViA$?QfbcjYxQ!T$zscPuRyTzig@fOT zwNT>Sr=VDLd_=gyp-7@-C@9Y@eaO>TB{~#bCw~WbbItSSdEaNO*II2?-h-O1 z*9Uw&)|cu`Jr|lf*H!>^nd|u-sM%?~4LihY^J*8EO=rIE49-p>X6n!wR$CHcyR)nj zHEjf(Q?;M9cy2eX#gKrc7%LBus1oFUyLd24$8hTHk<;TK*N_WsrAQHYV^#$bp5tTE zBND3)2c9cM$EBj&B(m#oG+14aJ2r20y`By5t|Q$a?6s4v1e{~HlRXTdq6^phpRctR zHw^_D7a2C zJ)La8_(?$3`WXDwmg5HIOgQ1dVv(v_m)kp$=&x~DsY#Mz%%^UgoUWX0s8;lr^Ve@q z0DDrQ3E_QKQc@Jm(Pvg73WJY|UQDn*gV^MGgc%f#UgCF&QvSu1)SypAp|Q4W`|$=d zlNgwzSASg<<4b1jJD^>cbym;2p0@ZRa&FiKxs`vvbu@l+;#s@ZsVd}EL7V+7zP;g( zY9RcGdy{b^MQ$9}_*EViLYFk~d7P~>|FPcM+a zj??HB2`6^PDzQ}``=eao?2mAoX*RiDnqU{1MGgF=etFoDP1kG~IS4_3C*+{oY8m~> zMTVA{lUKx9)01+i!fPssW~U)axs{If=Oi3Jqpmng&S}JCN+(uK$wV8E(z%1Ohs&&D zEd^JaH++w^-?9(@fU(d`*89O(^;_51?+^C&JR6Bs_APE(Y8!9<4lY3z&@42csjPTz z99nL>**5MbwcDFd%FcBhEwkJNv&XsZQ!9xg+luiP&HADyzb<_uAaLnh3}LUe_<9j6 z_|+$5ZEKwki&86{^&jGjT?V`mxmIYcs*dB%?pNP`yvJ?4Z3(egjgv(`&JdAvshHNYvGao}JG}EKNDU?F;CDtn zSMyGmo5luUHB}7zqPc81Lx+v0v=>>MS5o>Y40d(Ou!$*hEs&*|7^{*pr~CvZ1`Ab6 z&n2CHV}ktGB)sduruvI-aNEx*a0 z0A$=92~G3isi1G%|4h9ADkaw61(B8}vITN z!=AH|wT(5U>D)|~G^teID->72<_oUl{VZ7)Yv#l2*JS*!7Utre)2)PEW<|fPxf-T? zDwXORJ2D$Cs5mfF5TrOZIszRS_Ji@=nQ2#})8Q5oy4D#wQ%zh#1%Ncu z63nq*QC~`1t|!-SZ@>2A*?glO!V0l-ym%jg^n;TT3x*Og%XK}PKXL`frLu1T!3-7l zk>AL$LfWkA$3kyt7xtdmPiG{3FI*lUrH9&?1sicDU#A<+c7ZOCdtLtvyk0vNWOUapFGDkML! z$ZX6Tc)O{ag18W;!M!p&KfgS;(C9OD)_mUK>zkDg_B2@AoLfu%tImmsuclf_RR1qK zdi_k7V^f&a3#QgZ^S{u)7W_nxtG=kX&~WL-oosIxary+cb1Sq`Cd3EPG$kMSK4#At zyrH>}F9gDH@?cMu4Ms1mkz`MrKJyrtD{Vxcs#V2+#(!T<9KVIc{ZU&wkqF%N= z)`H=fOU)jcnbI7o3(2}nNx|xuDK<3ClH=2hd(sxvqU>OMS>@*({OpV%u`f_M$GrHO z2H~HdUkQ3L$pdckSuJ&re`Jso zebMjMcPnV497fn44>$f9Pc?ul9A234aDhquF2-pMoM+u9g~%v1-K7Qc?g}!; zYykKUGBIbeD^DNereaJN@G1%o!Sq0|dx4l}vPNZvbXWZ~A`HMvix`c57qf1R^agp@ z`Z@RB5_%>4i2@o)7{9y{Q&M=8Mm?0(ZFAJwAc!+&!@8BL2XRF)0+3m7&je3JO+^)u zO15r3JuEtt^7jHKwnTi)S&%eEVoC8$no`{_ua+|7yW><{TxDvkl{8_EBbkG>PFfD< zWpR!|sKJ@myn+Q5M@80G0rj0mhkJiik=s%29`9#L8_7EE{)4t^YLZKIy77>NdF;X+{N3 zqcxqwFY=FQ_IrPGmU5<|x7KZ9&n#76A3&8kUu=ujcw=mH8s(CF6^_#?z|>kC{s;I&9jQp~gPmN!M0&mjfV-uSO%99$1XxcNGO{pBLm7T zGL-U)xa=0>zIBuR(oihfs#Zw!6=b!#@SDr-u_jac9&I33zvcIvft;M&xu}56qR*}$ zZ}2G-ZZtnbzRW7iTHngKq8poICB08D%>GC^O_XJU>r>HOLR(Q*!Zw%ng43!br;ts4 zNzOZ_;#-4#_c{NvgAHIi(czNo3}EPeVb#>21X<9eHmNWWo`sK}mN|Y*pkJ+^#buwB zg%6`$YtZgz-glpaV7V((ETd;gu{rr1avB}2PBUXbf=6**MWDx@ZErVuc!n$xOmRSE zz6L1>`8^cgE;##OHM&Z3*Yk20HBNW`8@k+Kta0_910mFY0qe@6$6m!_O~I!XD7or0 zRYB+wgS&pZ;$Rj+3r<1Z$5_fvp)iPs-% zdwI{t6J*|rup0y3XmG7I9%9TDC0g!MD_l1kKGf#(W*iI^Yt{_vGu2HaZd^$PGwF+5 zwqyK%R57eMQaOI}Eh(LQsBzixPO)MyMF9wLI$-5hS61gbr^gSizDF1S0b7W@%nhPX zH5_Weea+|Wt4$p0&nt;T2g;d79IBAhtAh>NWl&HPlwWo^Ds!i~xLVw)=XDLFy_3Eg z)uR1O`0+&@i-H)pE>Ut0W-h2q?Q9=LlthWaI^u`uxz|1ysXY7xHBmyrauVy_OBRVs zeiFGNA7tK;V@%T-c}*3;?blQtSaD2-<7hDwH;Fh-%A^Y0(=#P^H&x=}&cMKjIhn!1 zL98gYJP)#xs9vj#Y+E&vw_ZPihrYaAJdu~}&OvDHSq?a5Z36wXtPOQ{#mby7T+mwv z92L~Rzt6htpc<|`3yKsgemf95%tlUOP37LXmdju77NaRHty1r120zyI>}1>%-(CVL zR6@EJkYc~lb91jp|00#HJs)uBf18_jpg7z|gR4I)D8O3}%@Jt2rZ;A(B5eBIFW2`Y zBF41z?3WqNA2s<$6fKV!QvbWt-BH@qFAL}T{GC24 zs}+AHcz{(nI}IUt7ghM<1%+6W$u?#N(|wFa3TEi#Mmg;|LQ;7MG!9=FNM^a=8?TJ{ z%hOgMM5@YP$2c{74HuBkjH4+l+5KHqBpFuCF43R&3;X*#+!)qoH^2V)x07F~{yGqi zNdxv4qI9&VS;s}-2xkV~I;zshdgkAPw;^Q`NTdwQ+6B>V&#!76PiNKedDIZ&jh{Zw z;;Y4qVbGZ(F{rUIR;a!QCZio(@(!p*!ppb`N+!$4CjFO|Y9WPvP~-U&GPjy<)WVba zJ=C)V+MiDgbyqDHbMWCA^ymah_one$&;@V5ENuK=LHRl(G62wr0J%X$cpZ%zjk&*q%?O)b? zzEeo=HnPq#RjJT+-9GhrF|e0%wR%3*?&#b>oz-OFEGYhYdJ!OOQsP9^TB(@Yhn4!M z%|?2w*2T*xjloM2FYYf&DHJPCC_gKWvz&(?EI~CcAkR_11xG`wG!~Pf&@VYYS=kzs zxL2K^U`OCv-H!LQe}eGsk>W;+VHbO%oH?grzk5T_e(q54xB6vBzaBh2#W##vuZe%H z??r~J*otF^E=e}|_=*D?j zW$)igW0As);8~0}wi_z}aMA;{dQ0Z8QmsPkSp=yO5i5hNcY+BDOzpaUa===x`3&8C zTp~?kAe!eZc~gV);Id5bLn=+rU7Rn8pV{DY4q#+9_B1=nR#?Ebz*=t?{X|9M&CG^< zCBxR{=NM6nDs5Tdza=LH|NU9?EmLL{PxLT&sw0chUFB5rLS=nmZ z**B=tZwr~10v>`dH3v&FQD}g|7tHpaLft;W1Z_7_t3WmuRt0tL0*kK962&Sc3bO1BJ;M?qo zGg%Kof`m_=sZ7=zr^@`kQzZViAGQ@U%Xf0%g9WMuSs?yFQ6w6L&mhR+9h9p~)7;to zL8ES3+_p>gPz$$7*>lvPVqa24VtNj1MTB)?t)u?SZXS=?q#XE@3Ly_k_PWPeev%Hh z_b?5T9eYS_qy4xv-e^5Khi*`!C=%75pI=a1yFD6GXb3%JY}TDE@l^^M0T&@0hvkn* zAYhg}635({F{kPrFvZn;I+kLi!x<0%xDE6ST7jh(bE+I(p4#xdT=ShVeBKJY4o#@u z`TKo^(a5zWQU8d$mRt@Q5mh zkN4GS3aIWZZf|avP%k`SGY;1x8Spz_w0Uj){WJe5A92kK;QQ0-bP5<-5N49+jMHeT z@l^Ex8Eapbzd{?dX|~kh&K{Bdw7u8_QX&=dK=Jj@JZ} zrB@r=H>S4$@=@OOvXcrw{{O|``FDd_Q(J&8?&BIm**2olqeGiE&a8@}V?E39Be*GF zbJNp5V@D2gP+5J^dIg*R>>m>!dU2B#(46-LZ7bSjao07`I>Y(RjnB^N($40b;tsC@ z%&&(>>EdB$heMEC4%ztzpxQY;id_QNfRv!j#?kIQas^N74?GV%cMQBd-!bTP@Xu@^Jmj)+K2I2^^$??P zQWGt4G}vdP_Zjw`4H@K8&)ZO4By0uq``orYTs8ZuyD)I}n}HB_dkSEfGHJ z7~alC)XP_o&N`#r*PJVBX}Mf|oh?cTe62DDt@HG>yKg)tE~ohy=rMi$8jYR6diS~< z^w5p=7M-Rwn8YnrFco_GbHpt?t1l>g#c{B_5m}sP#%&Ht~nd9dFSyXi0?Yeuh*0`V!`%gICYm%G77{-eP`C@>Bo!2YN ziCrY8Y@d57m+L%xqXVi`?OANe&3|obS%O%$xZ$y8YQtmOV@4uD@Du!M-!?niZ8t2; zTE8#xiGH)KFpV?TIbKyALgZaS(mW1#(kmy3F{Nza1+qg3agp2bB3lMay(`>8QzuPV zZ~U#OuSbVe(I|`06LrQxfc;DDyn>6VVYe80sG^cI^<#|B`|ROX-JeA9M9ZC_-eJK) zAX8OSXqV%!>Y@`@4Wt9A1jfMobRZ=*{7Gq<>!6`6%I7|8*3wl3g@eO}C&c^jMst`~6 zaH^9xrj!JkG4Pc#erfMJdK$-cOi`U)m6ojxYByE2<7_hB$|H*r0dK$|*rJL?7VB;Z z+-0(pG}bF6HKwx4DzvUtXYPIe>;&gKB!q-TAD{CT5yQtE{5%>6=EroExb(sZ8%n#yxU)ajd1np&NlhBFA@HF7qkq8`mUM(cI{bZnH=OQ> z62-{87OmgMczZ!!$B9&C9j#$;`G#zNnPWpyQe|gl^>R3teBJYYHOlMnD+fh|0k3hp zvg7kUyI1rxG<5P-hkapwx!LD(Sb^J?fIBOLzChAdoF}TK3{Hc`LAbqon0~uUy;&2V zWGG^|6ztdd6hEE2)ZI>`>B;+@8T^WCp^5*kp+yP_+7?xx82(MSJZlncnLl{#m3uHE zq02hL+M5S2iNsKvOnCRAL$#g50buTv=uc+y!l-#N}Vgl{Aq~4Jdgy& zX0oCWX`B*rH`OmUObDb#5UO~Na=yTCUuyi+*KR1_TG&L_J++R^xe$nr2{;;PxAJ!X z>Hv0nh%Un~nW6h}@%H}y-2EzT44$aGCH+|B;&HFDz5p~YJa%AfJD-)``JUpkc%4<` zpO4Ml4FepZc2lB$)oGN`iOKpG+W_SGCTU>-ocGmpGCC)X#$Um2wmAZ)9lfGR@#!y4 zo08e{e!pl%TxYSB@-@w&2N{TTxvLY~T^wuDBK%opNyNxuL$C738j=&frqSTaX17PX z%@zU8l|n1)rhnHYz?Uu5ZBjg9$t+VB%O54?EyiSt^LPw6rOMBF{`WPl3C}sGnbQwu zE$#MG!!_=THMO`MB;E3lP{&e}e}8Or_^B|nuSjt(sw^d{tyG~!z3|VFgMuaO*AMC) z_?2zY9QpdG$0`UEyYf>N=s7qwK(aK$&aO4BcrL~r_pe@^*7Ofz_~k)tG$u(o=j(18 z9YUzDV)SyH2Kbquw+R7m`^lkVrh+#_B&Y`)?9OUXSL{5>Avz-uK2o7_sRiE=3_cSj z3~O;y$&st3Cne;X5#HQ|$AcAc)CAohBDW=DJ|i>tPGd(Q&5K-@fJ1!6Bpz=$B{4Bk z=X00PO#S{F!HKA;M+mInil|<3Tp9{Yd>wunb@R$jHm-$Qz76MISPAaPH~`}db1Uwb z8R)$z5&<!^QG$YY`(s*8s5Al9?d!HZgk!8dzO*)0a=6XEWJ)Y-R z0%a2cXq7nj`-37fHS-~9=CCR5^JMH_VveNA>B}PWkS=(`77~pKTn|g+xZuOktAk4s zp@E@s29z*j5~JY-Cj$|KwwZ2F0oaB9(_3knlH*cRxL>fg)T_4@1+sj2>RXIT*K;v{ z#VZmC0LN}ABNJKBCwG&z#IrVc)pu-#UnF|x(QmF%b-(!!%es*wO9+6?z4nw*kQ0zP zcGpa-+as21xw;8G*#$6JL-i73#3j|$Ag8C>*3um?=uh+4300mmdK1O&{7QXd#2RJ&SV6g!yLNT>9lRZCAduHsEM9G8Af zl2yXJ_PEFaH4=?ggpyH@lJpCk%iX5F>d*Y8I;?FcEQUVE?UvJjgs)(|<9fd!2b%YU zwMIolCf$6Xc`P^Vrw`?46leA*rlK8Av&6 zM-kDzk>+$oSyJmgQ7?8{uWNpceFch6EO|av8+HdAWIbk!OZ)0DGmt%MlrA1fvB*9o z@M86}6Cmh^6{z(?MV8EFMP|# z5{L7dD{H!QWa>2sd{ioC>rg;esWYY+1)etl%marZ5;iYxN(#E$I0izFe7GoSQQE~GbWj-Q-~>qEHTN5=v)q&jl=o6 z^F;1&i;~4`WOO`Ypggs;LWDa_M@f3tK>iH7Lk|T zZZJ4Vm97fxf@Z(LWjrM1|xidVm?X@vXyc=F>8hn-Xeo$8E8AWliA&gwFi2RWi8Qq5I;6@~O)xhH00hZSdpGJyRjV4?qW z6E6=9`Y~&K{_D~r7n(x7H<(OM)Cb=FV*6Nj+6DB3p zj|q-@?ezGATU3c`hAR{^)cZu?O)EZ|OXWj#Q0nOV|I+1QU-EP7=k{8`x|)}yqICF3 zjRm#eYiYHb;L&`ty$zuR+LE5bzu%6*ss|QwR2qdDYzL$A%(+be>i(;X7(H*mo?z3X za0N#l;Cj2_ARRoX@O||I{TodjE6Xo%#}t5JYGp&S@%2xeMIKU_KwmgNki!lyeC##-XE|t^$p?- zXn(&%Y!>zJbxZBGkmqLdB$r;M56`?1YfB7RAQw za<|XY+mvDr@uZSeOn|x5;Ylx;$y5LHha95)UzGjuNE}@wEoz@ZwD~U{ScSCd8g2T8`)s#@p4T0`W^Ed{nri##FM&#hL}3*Y;i&(8p}C+*f1(lb943a@Yny#0ef z8l^v8pF`N(dRen)s-fZ$WhQqVn z_3qTB_-W?1e+*%P_kKj{*MaBy_35E!ymjYIh#`f!f=kcSzVISK0e7oo9D_eGPwjGS zEYp->_v!{G2pSI$p?i@fB;ee#;!aLzM!?;@Q1NZVBCx4}+cz-SOh;SWF#`^H zUCkT8d+8Y&sQao3;S$y**>uKoBjN>4?Tq{%X+&Pf4&C~lDVetZde3a>J9L)WU#6*< zrCFyjH@i=q-<})=K~axSe8}dKy!srLD3*|0FVmzHOaJ-}W-f!ggXLs5RemKTfO#>4 zn5r@w=rW=PsfjNNXdW4F!1C`ew;!ayn-lPp^|0nj^Ttfu(fo78f#((JgMWMHWCEUbsKXzYkF=sx3C(0uCb~|f`4|I|O>b<7tSDhq!osT#cme5NmnsLiA z_vweMMt}A7uxM3BW!lU0)1ebl3@!E00H$N{<9r-)gdH{H^|bC-6mcRFuoOdoJXD47 z@-jr#`C5NPi^lrV#T@X08@d5kYk5NVDb6qKZB2a|3`$vGE&@-sz-LWth@f1pRdn5Pvk_$exVw!OWbbRV+g?;u zRM-3Y77PtPZAkQo(T6cJZqn^ND~@T)HddG+61_w7ihbiz6e5lpSrg;*2>2T`uM?yM z8(*k*->8ARPx}Aa0x^9}14ZFX?NfqV6H!Tou5>mQN$ z2?&a+g6UY#$NKL^z8_QI-^?SB_mfWbx=-TYeODZ{Ce0{v)RB7BaDJ&3{f?9n%C}dt z@+~`prCM-}eT}Y90{d+A2any({h+&Er~>i!{Sd8*(hL>BrbZ_WZ)B{xo~+0dd_3^n z_Bt5#h2P!*mFoW~^{3Q^8c57cD*{lwwGcn7ySJ9pkcD>zQz z;3DbDDhXaW887)t{x)owS7_V;y*CV)9leNdQEej1vm(UuvxaW~qo2^%!2J^3z|UB1 zcL6cSl!Zr6;k%MJ@OlxqXBdHdffEBi?F8yW5`tSIJqNCefepa7K)+B(VZyskBNLmM zuLQij6C*BoG1Y4N)leo*92$pCl7mDtxNerQ3rzL-(nX!W)INa>$tx`x*9dQ0lbFGqq`RBk~M?? zNcHGj$)n|LS5l3PkQRPB98CxSE_T9;ltLkL7S;G}TnY4vF57L|eB+Rcd`c^Qu0pR+ z;@#JO7U~|$uIqiu1KkG-y8#l7*0ii4H5$l<87)UC{D9q{ zNu6(HzlDo#$&C#I{tyfq_zTqC6(i<1iQ>jO?6MVAxIR90KiBSf3)o&3h%pZeyI;+> z_TG0xU-txF0j1DzQ)ov^OxHLipkCubBq<8c>GR^+f0#J!I>RyzH&)J76KO6r74-K% zqXxVb(SVn!FQ_VeP~)21u6o`J6k9jNHWGC4ja8X2CH*W60$+o2ThT5nU&J19M4)Gc zJYHsld5paemeRpV(kteOQh0!D94jg~-y*N4=rhJx*4rB=B+z3OdkD?@mv_VuolAq8 z-;&N9!r{N;22Jm(!IIG1|^4B-ZRCYJ>O=VN<$eUCXy0{Yiw+hgeV ztN%>$O#aA$>2`>Rg11rRgn+OK{Vpk{AyoXFu+-5*gf{PEx}V&vE)pGk69AEc4fgFB zReP*CZ{2CRuZ`rs+MM|9J}Kwpa5LNk&C>JsmV{Ym?NOi(7^@>&+)A2b!Q73%AIRhUdo#6VmN9Rxw~Z*?V}QIREqJt*=Ln;+$fFtqCiuj5QBQJf&qaQiGvq zy4qz^ScKj}PNn0C!pMy0()ZYTw=%rur^t@k^Xf-r>3tfns>|thsxa_4C1yj5puZ|e zl7GYSX18{&V1R%#ZiXcp#&sHEXuE+(Q2f>Vw7lVX6=-Qw8D!8XsdTB+ZGOGQRMm>N zmKIW%=6B2y-jjjH3Qc@)q}c-)RsF3pcuTerL_N;+U|8mN{IVDNzT*?PlkM1Z7mF#A z5Ec-0)z?6%n*LvvOr$xX34J5a>D?ykdi{@%V3xv{$TtmjmY-5nHf1=oM4Tla%a~0_ zXs+FRqqN)8aoZQS%2qme)B4#CG(`GwGsd&y=W1pKbEvSuxxnd8{PaX1AD@n`vEGmv zg_%hWsR&;K1RO|+0Ot|{Kld5@{Vm59v*@UGJy!;e^_tDolWZ7YD--S(kE92u>v>sMkMfNUCYa*`BcgbmnOlwfhOB)Ayf;W9qy{XEe&aPs7=f33-Jb4pa>_hMs~q zB}@8_irk)jdJR~tLyI*qbgIa}VwB^S$qtnAfTrzuU)6@2-S!9K^{c`^&*R|(hZ)y6 znmHEj;N)Aj8Y{noy5WoQlmHJDQ%4Ryq&VUiiD4PPG+f@A!{c-gc^AP{);~kC3G5Ze zOXr^3pxw02s|CFdJPrdIe!mw$LLl&fCeQC~zC?aEg;js4&aUnYZ|X`$Or^9KL}8yd z{QJYr+=;Qz5sk?E>s)eKW@MLM+*Xw*IJmWJT#Yq9@@Hw5UT@$pnnz_++%E}mN&aR~ zJp#JmC!tUc&2mw@ZMj5ygWZ+JV~4YU`ucHAYFMe-o@g7h+AZ2_2Nu?Gj##E6zu8v9Vl(1kS3_$Be)8GsR-tG_OeLj@^2Ll#)eUJ@05nGyyIGz%C z+I*ZnXkTV#(mgqkshZD5FoZ`$6>lw;9=&F_=}`$(73=@zj5R}*qfx=&NEngRq@I?m zl<`$qAWfR{)$qSGh5^=0eXiKqq5l%EzM1|e`?Kf~ED0vGpBU}^6~TG#M~gy2)jQdA z%g&JPvC)C-Dflv4dfD0BVQ~xx=6=DWl7yN1T(zHo8-k{$uRcN8&>Jm-ti`xyw5*1a zgruY*Zh#xqz?VT>Bfr0l{1@+F{TJ35W*)LF(y{2d(x|M#c zzoN`as$aX-kFw`ScU9C^n%^s>&p#hkkpdMs%Mjfi26Rk0|~? zfc|pweLi8ukZFZ5Ye)(N%x~`^*W~DXZn{k5>g%!(DpYZ@-JbS`iujz>8H4e!m?H@X z%u}qK!rz_EQwhlhhhA>zH+x(;}T7kTNQE0WP(&Y*^<4Ch>sR~r5%En{j4x|sRAs0#odzF+r} zV#O-(JS@k95qW!ySM^azlYBGja&K)5~|3SAe?n6L{)&HSsdTdJav;i7_$0cc-Bjt)YxcyoX|ebuIqt zxwU)Uuexu0Vr|KCdaMgh({k=1W0rm-CL^&vQim4Ig4xP z9;TEQF=wqN8kUY)rBQ|UWcTtePgsyt2(7;)Lt_&sFr0N*>jPmLYp@%KRlp})h*PL- zO#BaO3@uGmAt18C$YU!2O7#mt6ISobJ9X1?xHa6_QDh|{06E8&`=b4QIkLCG;o3j? zn3*Xx=MTM~7hu5>eEBTBpzc;9UvIBns8}lyzUey|!X}o8Q&{gZQ&{C3kjUZd+?T%5 zfyHmh_%AGfgx=rI>qOo!8fOIG8z;2khkoTTZ6mN#57r41H70;;nHG``2+| zP0_;gb67R5?lyUS$fI;UAY%roZ(8>VrUZ*rpQ=pvCRW<4`5;quc!NY@Bt^ufRNbM6 zBFB*_eq?iAs@-OgN>W=?x?etS5t6>#)j6)Vr<)UG6duP;?;X&5-bMcRYzMww`I7z- z3M@E$t+Xz%NH@^qC9Y?U@>^kwbiPa=o_6JNJ*!-D5w@BWVj7Dl20Ce)I^Bz%^k-W` zBnZ4gWQ=UOeiQiTB6ce(EAm3NWz8NnK#Ug8XrzeaA4R#HjWW{Vtyxy?Me*hVpjCi6)JnW${Onk_ax%KHU&Lf*8ke#iaFxVex2bm`<*ou0X6i zARN|@425sNQQuU$Pc5sUe5}6k_vO}h+rjpwGH@&Y(s#)YQQe;97Ygy`!x*VQs7&PZ z6W*~~(Eo^tLHR3X6x@z!^=LxA39DB;X`5dw>7j7c=q`c)?@GU$QC-nYgKIV-?i=f! z-!^u_*Ap)VEIQz3=%0b7H2D&+A4NKt7~T2bX&8GITq^|Pe?xdGukn3s5%MK@QQJ7) z@_5&iktb&Xp!N-9byQk6C6KGt+3>S`cfo?JgCjGP9QXb;@r8d8ZC$_spfZu zU3VW-#&XxnVA=zE=tT|b%lHbzcBj`@%e;3M(9sO&Y^)3=z{RdBh&g4b$!%d-|Jomz zz2O*`-}AFMYZNv{X${@A*4BpOOkPxV%&rozc^Q>*yXVR)M?d9*V?I^KG$Gvm z--QmK#Su<%Np6(TMwr@U?Y&#Aa_Y?#?53mSHzz=8y~d9;gjo3;KBvIO)do9(FES@v*h-=?1kj}v=K*q ztpyCHDA8z1EGG(6(gC&yhHp7UXH9#&6Dt`ybdRJdD1j`BK_!I$hgBQmt%rbU7(~%fyo4d zrT`LSEwIgvR}sAjmR!6b=004Wb@NQFAOjJ~{6w;{$|@$O`dSjX_uvVhWXEM9M_M1% zJzk^x0=};2?JN&CM=J6-*xTh+%VK_NiuKm?Jt#v|Jl?`|UQnyj(G}|@lRiSas%5B1 z(zkrzRJ=OMA)dj9+^6{_KOj;m)7$(wO@}S;>fao0uKyc+;NwT@j(4C_7g|O1=qT-! zP>%0)*GX{X)24^-PuosHX<`4Nx%>z_Q_-6{C=%`hTgdfR#90x-cqs}g)@P`1Ipg-dle1f z-S!6?O+ES*y;er!;JIs)IXPdCDE+sQzcuKt#0lF*@WJq(`tP%cSR`XQj_#yoKuk5C5zx)DhTMT;Be}^g!PN159^u6*PbvV1lQim~e79E~D z4R-JoY!9%~^We@_EK$!?urPBOkg8$Akq;kObN%>9IjCfsg}PU<*5TvCHsX%>8WJ&` zTnQgsSIJqDFhidyHFD!C-MJ!N(n_^C>Dt7ql4~*)g%aE+ijCYqSkcc=rc4Zab)6A< zUC8TtSl2H)cxC0x$QrHQXgT>Dx%PjswdHY~SmMDZZUw-_m=+K!q)N$30)cafMo9_h z-#>T0%o_hoPS8sIO(5lS*#24{>e!n`N*F}yKPup`@xCj8DiN$AQ<6tV?o7!hENo`4g`$O(#r7kKiMrrwxR+OGQcaW{l>^^w zJD`dZRMKajdO`iZ;GW33df-R0Wx&(sDaVKTilxuI!uat|Z-@7@Va|C=gqFwr zSNWvMAWj`DF?&6291XpaJ)DsUkxh_=_YWOZVoC&(w(DGh>z?fU7yRMAoL#K(mw!}Q za$@wgCA(6C{pR&)@Q`B?;(s+7+R|vwyBL!uMsMQ<2YGQqV0!U5_w3KZ!Jf zx`Kt}%GK)oYTd_5_S5D{i$`{@E%MZ_AC{aGH~nmK2FG%6-F!8G2<|U2t+$Z}0-1NL zY*towaGVz3pS6CmhwS^9_o@5)f&}V%+h??Y$#PXIeAIAStcB+ZUW`N2BlD)(+^k_B z31Pfdx0Ienm^*iM#;Y^2uD{+ zf=mg`yN^7FJ!1ka&p}#*~%+EM>e2xO#u5j)^<-lqa&n!|z0`y^^6sjjgE;SW3N4 zn@~lIv4<=`C_rs6{*e;K03X<{mF@=9xM=kdr}Y+7ucCv_>NVrpk196=-cBAdei=ek z7J6M_>3SKU$s-X8^v;NIcgv=Bb>BMo*!;M;d=_c3nW%MB*S4}G9&!`ya4XH?ggEr| z+rmz;qJ}cJl5`001DFU}oSsek-fX{LwY@uhrg7ym$w`UE!-bd@g5fu_8q;0Kk%iuW z<;Yyd_1{suo|XfQ$u;qHStlYf;|w7cVGNRjC=BwpYX``)%b)TY14N5lSbDG~3R4WNi27~BJz!{ZDnD9EA+);GC z{%=EM7F-l~99qn2@Nn=VABRQh#@Xhm5$ZB5gzoc9E@9=T^9GX0;HR+ z&x1L(Jg3o&{Qbd&K1pY==)5Jk^C=`-#Un=lX#d>IymcapTF1^318S4CFJ&6JiDL|6cX(52aCsQeB^p&lX=2Ij)vE z1B>V^_{cwZR~mxbve}U3rRVS_zpAwAtgUTb1+NEE`>i@g=XEszYQlkU51G%~zR!Sq z%Gz_V9G8=ao7S&F50>ip=k(3}xoC+=dBDgYcB4;0cnudzr97V}OJz_Q=v?IUQ8`!G z?cwmB8=Z+(IhB=zx#7lf_p`|7RIlrXe}Y-|##}Qr2eowRDd2u?oI|-)iP$CMAtW^ISiq&qC?D+XOZ0BmZ(lKS*dgUa+6{TTV_WjWe-)Tm! z+%5iKHp_!J;Y-}e?>J3s62DO_Tr7TwIB2OR6Ia5ltd-iG)y2)i)8W2Z6;?LlvyRG& z*B=!iV0b90pV!&qe?CRHu~Hi?92HnXe!YC;;`%#%k;Gyb{3;B{QF9vyVnT88o#7L&;O0&n|x-YlgPNU6&2g3@HDA=`ty_^9( zCfkRmD-=patG`hLI&}$JQQn;2SIhIM7Fo@GA-th7%(NnmEI+s8$1Cs^@xxLnN6_8H z&Wl%sD|I$5%-SVu*jx)d zVH4=q1Deci1+V{=;2QhA(I|I69-qs^lMrSz&gx@ujh*Q|#&g*^1Uk(?8*jT_Q%-H! zVsjLnr4^k24G?>@=T|PsuL{wEqFCZZ7#aL>-2gEk>_F<%t*~HiO7^p*U^WuWT@(?# z@dyC?wlD9|?s1=CN)Ud+o6?H0it+So4Eq-sYLt zx?c(@=2SsV%~uzT``Q+rC?7y^0$VZYiDjwd_owhg4|xB^(KAU7NQ6pfX;C>hnq^pg z%T}aXAkGoW*%I>M*LMm1jR{k*?-Q`*EF&Eu+NPX$D)6!=a~Dy?JPjO$5K1#c+1k{$+fFd)U-|oiZ3*nbiph@nCAkJ8#YHI#sJVqzBqH3e65*5Q zRuoo>vj`3pCcdg+MWN}afe&KVFLJv$3UOPmBbT0Ao}@>JL%L%`pD`GsGUA-6a~0xk`p!Jn3Jcb_G<4P|8=%l4WL_75(8<{>1zU%K$!W3IPGWxl}vlWl{; zz)UIp;q2lEm~U_VnXZ)Qcimjke@`hfC}x_~qdf=&+bB%Or{xH=xO+A^ZvO3QZEXcB z$wrbCO1Ku(xZaN2{tDH*q5LVR33*wFkSBPno_^>t^>=ibeGS`$TXT17ih|1%gS{ zty1Q}5R=9%eYiU|`DkHK-J1!#%r4t%HJm#kLQpV_n3;}gaT`eud0h4z9=M132RKT1 znxvge((CecI5tR{C;W6eDprKv9W79h0cPwca-iG1fD;hGrHBD;>RHW=C#WCv-WvGqX*Ky?t3nHV|cP!KNXD&~F092(vny7akIx_Dxn>Sy)FjRRtE8 zLoQe|=w(Idw2zNbBmbysnqvSM>fjOcz3$bc?z{qa-zlNB#ak!4Fz#cTjDEp()N(DJ zbae7_R~t6|9ElgWYWsPRHl;XK6Cq}N1*eiwWjEgveKQr@Cg;2BVk2+Jr&H?!Uh5*_ zcLR*pV>(`Mfci)BjPUVXfDnc-O=7{Q+o!BcKisF>bHG~r>&<|7==0V~t;yol@!h>U zL7WcAW;InnxT=Xx69d1D0~_@?~1*Zax?il_ikOXFOA2kT5j$us{;L`T2sT4qo`Cf3UFx< zxu<^TJno3|i6E;~HavGSzn;bjc4rHZV11e4r6EiIs$YVQnv2;{GQYSQ{<)9`2HCy= zA}RBF2178y!<@s`ko$yxxqZX;a!{8L`sJvstnF#3ZRu+(FE7uXz18L{#9Lyn%i1Q% z{8}Zx3VS0v;%uS=P6?%DWZ>c9!NRSwvTvxwf~@?UoV@JphK$(b{Y}tN2=|V21Vj|+ z{PGsr%Z?ofxxTGCF18Z3t$9|n$<~^d@gw6VkgTfof$eqZuKBNaZjx+oCTZyELPOOG z{QBN#nb{=W5B&@?k_YLXYO2X40jC9>qyZ1AS-x5v+>u0g4F)N?6nJ^TQALFj1^ZQR zZvUne8b3`ft=4ngROi$o<96y~(bS^_VWpJbX$!th{xX;!oM?>C3XV+2Ij@*RA}ZqL zb6~R=q&M^$X(Vv2UEIA2=owZGkgZbMIg$WIHxqMx!HXF zh43Tl>FT@4l>jU`Cd@V3WHXfTV<;rx-=FwSSA=Hrh`dfmcIc3wEwO1VZF@hb>OPKl zJ~k*&AM9Kc!u}zL{THYpIY;2#qoiGC`{?)?$5nz2$0PkI!_j3jA+j|T-dGdFH$Dsc zOM~;U^-p2c(F2s2>1YbKxZQ@B+6&HC)6%}LDz(ED`IcP&lLgTvOQeH!H~#|%LHNEJ z9U3lAjI%JqWi7bI7BadK~ID=o_N*=QWg1|Sz@@W6zM$OsSnryP7wcV{9oY{1odODUJL3v`>ROXagg9 z#YV#);4H*}Rw|J8TB9S(5#`7C1CxInE~0NI6Z?cQ(?Z9e8W_IV*LV8Vr3>dqM}{Xy zN2bPxeVUo(vceP#9Hy(ProuqeTs2r?es2uutNMh(v}fLBkgjj;>Rs2=(bKhheREr9B2&k7)AfR)ADW4bFfhauR6aieorCHaEaivtNHY}4 zOB`e6GE3ydi&#=)T7IxQtL*HqZ%L>*Q=uBkbBq90cEK~b5VPcA;P|U>cp@!QG*{84 z89O!1`bWxRMRm%<>6OjFf%%N8nj@-;q&3>+3ecgK0R5eE6nN-1nxUH?A3lHP#O1T6 zj(qyz=#>l8moLx|Ch5&*n$8T3wQ+m4zNNmgL9=WWQlO~xSslal_@`#+N#a>S z8REf#<2$>@5cQrs^E6Pw@_G!APLzg=Y#2Ixu19;1*(jItr0tHcs<%7q%*Kq>(vT9b zz`4GbQwAh{RUnzA#7#gLgq}w9gil{mm5`BfnfM3|_u)_T=$_OJ|RM@3NcJ{34>{->dYHd?{7t?KK zSh}524Vymy2X#4J&T4a;HbBxC0%*r`E(V8SZ|3T?Q(Vr_R-5ddYGa>BEZOh>d* zguZ@Y;!!4MiIAGXN)EFu8Y&Cih?VoqD}~N2qejzP@?APx{f1&p8`ZVRa){KS4hMf*M6$&X0E=jskOChRb$7hy5{yw zV{4|aQBT(=8haAihGfDB0zdFdV69?n2M>>yVnm>!d`>aC8dQuRVR(Xs)VM|BsfuH) z_O%F=VqHdsJBwNB%yFqxiY}Dt7OnE=x|URHM(=FQ<`T@K*G5#JNu6GZOGw;UNM@d}@OpFx9hbKn{h6gT8j}1G8DbFc- z<&y7|M@L5RZ2B}KlaH(j;5ntQGSjjim`lsDlF4K`oz{~%y{RjaYi?+2t8Z+|WOLcN z2AJJ+uHFGtRgH+|_tV!&kZiIqNWV)7Mv};U(+Ch{2suD&z=tOhjBm!ma|+`s-rKKG zplSv>3q4lHN*#8vsl{I1sAm*D;>J-eP-0U;6$>#-fOJ#;gqJ*h{xP)HW$xo(DO^rOKFg-Fnc=_VlOBXI&zHo7BU@mnI(|YndSR5X4zynn&F!ET+Zg1 z-hfQEA+(jXcMk7Wn$A^mSPW#LIbfY+M9CiTymA0C7T?UOl#uffpJoy+@2f zU!gCq(ad`-^3}*KPft#a3{H*?O;3#%CMPDwM<*vI3xz`D6SIWXz>&ss_-Kxpd6`Hg zU}tg6WHR;j^;V|AZtBQ2w>P!4!hrf=1ZEq;YAQ7K0CpKaUH;8F!=S+?*9}t^?G1=> zqu1cz2>fj%SgRj|;>9=eC^$yQ*)!~Kt%~472=On@c@4zvwU`$KsNBDh1cBOE#6J=8 zdgc2nqc4%Tti=dAlF|A`eRU&CLosnk0t6zz6#}{Nm?d4{v{EpAaB#iMl*y2fSzZaQ z!p?iP2U*8)fdN-4qovcP;@i9AxqI3No_#9dV_ z;e2f=04NCDBkro+yL5yC0&J0M{LYx7be-U%YHu63%F=9$Dvt3 z8H+q|jT3D&hiFS@HNq8Z3&DB_9tP4w?Y3xFsiow92y`*T@LMy7BDP<^|#eJrHTYWq2yF za8#lef4K-;oe98=vVuGii>jQjL=Xmw=JOS|q#1r*M8W-4A#`t50_-vZi{h@)|4b~k zaUn0)CEr&SbakMboZ@#T*@jkqO%ux?M7g9}VwxSStq>LiGDTB4dj$`9`LHDw2K1{_ zU1#jfC_6n6jFclM(ou4j45kA%mPsY;a zivc;D#mS`{1>nd3&m&(4t-~eMM~zYrzvuX&SM&?xkyCKWrE+n~Es}>%(?q@Z!Vr%E z{vi_7UK*BHbwe?1!?X-5q3Je#x8F|L>8xcZ6Ui)eC2Bu~$0LDwRoc`HDO`H`t6E(O z#9fFNxfXQ}6;8y0SmWx8BcGTIANj?ZB|{{4w($6LRdO{8NCucC*t4&gKFm3Vq?1Mz zCW1n1T3y?e>}gQIENLq<+D{4(4P;+erX?h<4aqDeZakupUawN4OE0hB%QH6Wu~S#r z`SEbVRm!m2CZBhRmQbfXdH8%j`Z*sn?eHvSiPNI{j#DwG0#Q+)o}U9F5trx>B+W@D&WHp6F)NrCMu1X?i$ryaSyEb�rUlji}lq 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 r(~R98h&;K7>C3wgnG2 literal 0 HcmV?d00001 diff --git a/_sources/GSG/get_started.rst b/_sources/GSG/get_started.rst new file mode 100644 index 0000000000..2af04be6b0 --- /dev/null +++ b/_sources/GSG/get_started.rst @@ -0,0 +1,49 @@ +.. _Get_Started_Guide: + +Get Started with |full_name| +============================= + +|short_name| Get Started Guide provides the information you need to begin working with oneTBB. +It is helpful for new users of parallel programming and experienced developers that want to improve code performance. + +It is recommended for you to have a basic knowledge of C++ programming and some experience with parallel programming concepts. + +|full_name| is a runtime-based parallel programming model for C++ code that uses tasks. +The template-based runtime library can help you harness the latent performance of multi-core processors. + +oneTBB enables you to simplify parallel programming by breaking computation into parallel running tasks. Within a single process, +parallelism is carried out by mapping tasks to threads. Threads are an operating system mechanism that allows the same or different sets of instructions +to be executed simultaneously. Using threads can make your program work faster and more efficiently. + +Here you can see one of the possible executions of tasks by threads. + +.. figure:: Images/how-oneTBB-works.png + :scale: 70% + :align: center + +Use oneTBB to write scalable applications that: + +* Specify logical parallel structure instead of threads. +* Emphasize data-parallel programming. +* Take advantage of concurrent collections and parallel algorithms. + +oneTBB supports nested parallelism and load balancing. It means that you can use the library without worrying about oversubscribing a system, which happens when more tasks are assigned to a system than it can handle efficiently. + +oneTBB is used in different areas, such as scientific simulations, gaming, data analysis, etc. + +It is available as a stand-alone product and as part of the |base_tk|. + + +To start using oneTBB, follow the next steps: +********************************************* + +#. See the :ref:`System Requirements`. +#. :ref:`Install oneTBB`. +#. Run your program using oneTBB following the :ref:`Next Steps `. +#. Learn how to :ref:`Integrate oneTBB into your project ` using CMake* and pkg-config tool. +#. See :ref:`oneTBB Samples `. + + + + + diff --git a/_sources/GSG/installation.rst b/_sources/GSG/installation.rst new file mode 100644 index 0000000000..e6b6a09c34 --- /dev/null +++ b/_sources/GSG/installation.rst @@ -0,0 +1,7 @@ +.. _installation: + +Installation +============ + +See the `installation instructions `_ +that will help you to install |short_name| successfully. \ No newline at end of file diff --git a/_sources/GSG/integrate.rst b/_sources/GSG/integrate.rst new file mode 100644 index 0000000000..13fd679dab --- /dev/null +++ b/_sources/GSG/integrate.rst @@ -0,0 +1,68 @@ +.. _integrate: + +Integrate oneTBB +================ + +If you want to improve the performance and scalability of your application, you can integrate oneTBB into your project. +For example, you may want to integrate oneTBB if your application needs to process large amounts of data in parallel. + +To integrate oneTBB, you need to: + +* Link oneTBB with the project's source code. +* Provide the necessary compiler and linker flags. + +However, you can use CMake* and the pkg-config tool to simplify the process of integrating oneTBB into your project and handling its dependencies. +See the instructions below to learn how to use the tools. + +CMake* +******* + +CMake* is a cross-platform build tool that helps you manage dependencies and build systems. +Integrating oneTBB into your project using CMake*: + +* Simplifies the process of building and linking against the library. +* Ensures that your project can be built and run on multiple platforms. +* Lets you manage oneTBB dependencies. + +To add oneTBB to another project using CMake*, add the following commands to your ``CMakeLists.txt`` file: + +.. code-block:: + + `find_package(TBB REQUIRED)` + `target_link_libraries(my_executable TBB::tbb)` + +After that, configure your project with CMake* as usual. + + +Compile a Program Using pkg-config +*********************************** + +The pkg-config tool is used to simplify the compilation line by retrieving information about packages +from special metadata files. It helps avoid large hard-coded paths and makes compilation more portable. + +To compile a test program ``test.cpp`` with oneTBB on Linux* OS, +provide the full path to search for included files and libraries, or provide a line as the following: + +.. code-block:: + + g++ -o test test.cpp $(pkg-config --libs --cflags tbb) + +Where: + +``--cflags`` provides oneTBB library include path: + +.. code-block:: + + $ pkg-config --cflags tbb + -I/tbb/latest/lib/pkgconfig/../..//include + +``--libs`` provides the Intel(R) oneTBB library name and the search path to find it: + +.. code-block:: + + $ pkg-config –libs tbb + -Ltbb/latest/lib/pkgconfig/../..//lib/intel64/gcc4.8 -ltbb + +.. note:: + + For Windows* OS, additionally, use the ``--msvc-syntax`` option flag that converts the compiling and linking flags in an appropriate mode. diff --git a/_sources/GSG/next_steps.rst b/_sources/GSG/next_steps.rst new file mode 100644 index 0000000000..aeb4407b10 --- /dev/null +++ b/_sources/GSG/next_steps.rst @@ -0,0 +1,157 @@ +.. _next_steps: + +Next Steps +=========== + +After installing oneTBB, complete the following steps to start working with the library. + +Set the Environment Variables +***************************** + +After installing |short_name|, set the environment variables: + +#. Go to the oneTBB installation directory. + +#. Set the environment variables using the script in ```` by running: + + * On Linux* OS: ``vars.{sh|csh} in /tbb/latest/env`` + * On Windows* OS: ``vars.bat in /tbb/latest/env`` + +.. tip:: + + oneTBB can coordinate with Intel(R) OpenMP on CPU resources usage + to avoid excessive oversubscription when both runtimes are used within a process. + To enable this feature set up ``TCM_ENABLE`` environment variable to ``1``. + + +Build and Run a Sample +********************** + +.. tabs:: + + .. group-tab:: Windows* OS + + #. Create a new C++ project using your IDE. In this example, Microsoft* Visual Studio* Code is used. + #. Create an ``example.cpp`` file in the project. + #. Copy and paste the code below. It is a typical example of a |short_name| algorithm. The sample calculates a sum of all integer numbers from 1 to 100. + + .. code:: + + #include + + int main (){ + int sum = oneapi::tbb::parallel_reduce( + oneapi::tbb::blocked_range(1,101), 0, + [](oneapi::tbb::blocked_range const& r, int init) -> int { + for (int v = r.begin(); v != r.end(); v++) { + init += v; + } + return init; + }, + [](int lhs, int rhs) -> int { + return lhs + rhs; + } + ); + + printf("Sum: %d\n", sum); + return 0; + } + + #. Open the ``tasks.json`` file in the ``.vscode`` directory and paste the following lines to the args array: + + * ``-Ipath/to/oneTBB/include`` to add oneTBB include directory. + * ``path/to/oneTBB/`` to add oneTBB. + + For example: + + .. code-block:: + + { + "tasks": [ + { + "label": "build & run", + "type": "cppbuild", + "group": { + "args": [ + "/IC:\\Program Files (x86)\\Intel\\oneAPI\\tbb\\2021.9.0\\include", + "C:\\Program Files (x86)\\Intel\\oneAPI\\tbb\\2021.9.0\\lib\\ia32\\vc14\\tbb12.lib" + + + #. Build the project. + #. Run the example. + #. If oneTBB is configured correctly, the output displays ``Sum: 5050``. + + .. group-tab:: Linux* OS + + #. Create an ``example.cpp`` file in the project. + #. Copy and paste the code below. It is a typical example of a |short_name| algorithm. The sample calculates a sum of all integer numbers from 1 to 100. + + .. code:: + + #include + + int main(){ + int sum = oneapi::tbb::parallel_reduce( + oneapi::tbb::blocked_range(1,101), 0, + [](oneapi::tbb::blocked_range const& r, int init) -> int { + for (int v = r.begin(); v != r.end(); v++) { + init += v; + } + return init; + }, + [](int lhs, int rhs) -> int { + return lhs + rhs; + } + ); + + printf("Sum: %d\n", sum); + return 0; + } + + #. Compile the code using oneTBB. For example, + + .. code-block:: + + g++ -std=c++11 example.cpp -o example -ltbb + + + #. Run the executable: + + .. code-block:: + + ./example + + #. If oneTBB is configured correctly, the output displays ``Sum: 5050``. + + +Hybrid CPU and NUMA Support +**************************** + +If you need NUMA/Hybrid CPU support in oneTBB, you need to make sure that HWLOC* is installed on your system. + +HWLOC* (Hardware Locality) is a library that provides a portable abstraction of the hierarchical topology of modern architectures (NUMA, hybrid CPU systems, etc). oneTBB relies on HWLOC* to identify the underlying topology of the system to optimize thread scheduling and memory allocation. + +Without HWLOC*, oneTBB may not take advantage of NUMA/Hybrid CPU support. Therefore, it's important to make sure that HWLOC* is installed before using oneTBB on such systems. + +Check HWLOC* on the System +^^^^^^^^^^^^^^^^^^^^^^^^^^^ +To check if HWLOC* is already installed on your system, run ``hwloc-ls``: + +* For Linux* OS, in the command line. +* For Windows* OS, in the command prompt. + +If HWLOC* is installed, the command displays information about the hardware topology of your system. If it is not installed, you receive an error message saying that the command ``hwloc-ls`` could not be found. + +.. note:: For Hybrid CPU support, make sure that HWLOC* is version 2.5 or higher. For NUMA support, install HWLOC* version 1.11 or higher. + +Install HWLOC* +^^^^^^^^^^^^^^ + +To install HWLOC*, visit the official Portable Hardware Locality website (https://www-lb.open-mpi.org/projects/hwloc/). + +* For Windows* OS, binaries are available for download. +* For Linux* OS, only the source code is provided and binaries should be built. + +On Linux* OS, HWLOC* can be also installed with package managers, such as APT*, YUM*, etc. To do so, run: sudo apt install hwloc. + +.. note:: For Hybrid CPU support, make sure that HWLOC* is version 2.5 or higher. For NUMA support, install HWLOC* version 1.11 or higher. diff --git a/_sources/GSG/samples.rst b/_sources/GSG/samples.rst new file mode 100644 index 0000000000..f19a256238 --- /dev/null +++ b/_sources/GSG/samples.rst @@ -0,0 +1,49 @@ +.. _samples: + +oneTBB Samples +============== + +To become an expert in using oneTBB, explore its samples and examples to learn how +to properly utilize the features and functionality of oneTBB and avoid common mistakes that may impede your performance. + +The following samples are available: + +* **Containers** + + * `concurrent_hash_map `_ + * `concurrent_priority_queue `_ + +* `Flow Graph `_ + * `A solution to the binpacking problem using a queue_node, a buffer_node, and function_node. `_ + * `Cholesky Factorization algorithm `_ + * `An implementation of dining philosophers in graph using the reserving join_node `_ + * `A parallel implementation of bzip2 block-sorting file compressor `_ + * `An example of a collection of digital logic gates that can be easily composed into larger circuits `_ + * `An example of a Kohonen Self-Organizing Map using cancellation `_ + * `Split computational kernel for execution between CPU and GPU `_ + +* **Algorithms** + + * `parallel_for `_ + * `Game of life overlay `_ + * `Polygon overlay `_ + * `Parallel seismic wave simulation `_ + * `Parallel 2-D raytracer/renderer `_ + * `Find largest matching substrings `_ + * `Resumable task: Split computational kernel for execution between CPU and GPU `_ + * `parallel_for_each `_ + * `parallel_pipeline `_ + * `parallel_reduce `_ + +* **Task Scheduler** + + * `task_arena `_ + * `task_group `_ + * `Execute similar computational kernels, with one task executing the SYCL* code and the other task executing the oneTBB code `_ + +* **Other** + + * `Compute Fibonacci numbers in different ways `_ + + +.. note:: You can also refer to the `oneAPI Samples `_ to learn more about the ecosystem. \ No newline at end of file diff --git a/_sources/GSG/system_requirements.rst b/_sources/GSG/system_requirements.rst new file mode 100644 index 0000000000..d5e951f35a --- /dev/null +++ b/_sources/GSG/system_requirements.rst @@ -0,0 +1,6 @@ +.. _System_Requirements: + +System Requirements +******************* + +Refer to the `oneTBB System Requirements `_. \ No newline at end of file diff --git a/_sources/index.rst b/_sources/index.rst new file mode 100644 index 0000000000..e49c5c1c47 --- /dev/null +++ b/_sources/index.rst @@ -0,0 +1,15 @@ +|full_name| +=========== + +.. include:: index/index_intro.rst + + +The following are some important topics for the ``novice user``: + +* :ref:`Get_Started_Guide` gives you a brief explanation of what oneTBB is. +* :ref:`Benefits` describes how |short_name| differs from typical threading packages. +* :ref:`Package_Contents` describes dynamic library files and header files for Windows*, Linux*, and macOS* operating systems used in |short_name|. + +.. include:: index/useful_topics.rst + +.. include:: index/toctree.rst diff --git a/_sources/index/index_intro.rst b/_sources/index/index_intro.rst new file mode 100644 index 0000000000..72055fe8d3 --- /dev/null +++ b/_sources/index/index_intro.rst @@ -0,0 +1,5 @@ +.. _index_intro: + +This document contains information about |short_name|. +It is a flexible performance library that let you break computation into parallel running tasks. + diff --git a/_sources/index/toctree.rst b/_sources/index/toctree.rst new file mode 100644 index 0000000000..542a4bb601 --- /dev/null +++ b/_sources/index/toctree.rst @@ -0,0 +1,38 @@ +.. _toctree: + +.. toctree:: + :caption: About + :maxdepth: 1 + + /main/intro/help_support + /main/intro/notation + /main/intro/intro_os + /main/intro/Benefits + /main/intro/testing_approach + /main/intro/limitations.rst + + +.. toctree:: + :caption: Get Started + :maxdepth: 2 + + /GSG/get_started + /GSG/system_requirements + /GSG/installation + /GSG/next_steps + /GSG/integrate + /GSG/samples + + +.. toctree:: + :maxdepth: 3 + :caption: Developer Guide + + /main/tbb_userguide/title + + +.. toctree:: + :maxdepth: 3 + :caption: Developer Reference + + /main/reference/reference diff --git a/_sources/index/useful_topics.rst b/_sources/index/useful_topics.rst new file mode 100644 index 0000000000..8def9339a6 --- /dev/null +++ b/_sources/index/useful_topics.rst @@ -0,0 +1,5 @@ +.. _Usefull_Topics: + +The following is an important topic for the ``experienced user``: + +:ref:`Migration_Guide` describes how to migrate from TBB to oneTBB. \ No newline at end of file diff --git a/_sources/main/intro/Benefits.rst b/_sources/main/intro/Benefits.rst new file mode 100644 index 0000000000..5058cc71e5 --- /dev/null +++ b/_sources/main/intro/Benefits.rst @@ -0,0 +1,88 @@ +.. _Benefits: + +|short_name| Benefits +===================== + + +|full_name| is a library that helps you leverage multi-core performance +without having to be a threading expert. Typically you can improve +performance for multi-core processors by implementing the key points +explained in the early sections of the Developer Guide. As your +expertise grows, you may want to dive into more complex subjects that +are covered in advanced sections. + + +There are a variety of approaches to parallel programming, ranging from +using platform-dependent threading primitives to exotic new languages. +The advantage of oneTBB is that it works at a higher level than raw +threads, yet does not require exotic languages or compilers. You can use +it with any compiler supporting ISO C++. The library differs from +typical threading packages in the following ways: + + +- **oneTBB enables you to specify logical parallelism instead of + threads**. Most threading packages require you to specify threads. + Programming directly in terms of threads can be tedious and lead to + inefficient programs, because threads are low-level, heavy constructs + that are close to the hardware. Direct programming with threads + forces you to efficiently map logical tasks onto threads. In + contrast, the oneTBB run-time library automatically maps logical + parallelism onto threads in a way that makes efficient use of + processor resources. + + +- **oneTBB targets threading for performance**. Most general-purpose + threading packages support many different kinds of threading, such as + threading for asynchronous events in graphical user interfaces. As a + result, general-purpose packages tend to be low-level tools that + provide a foundation, not a solution. Instead, oneTBB focuses on the + particular goal of parallelizing computationally intensive work, + delivering higher-level, simpler solutions. + + +- **oneTBB is compatible with other threading packages.** Because the + library is not designed to address all threading problems, it can + coexist seamlessly with other threading packages. + + +- **oneTBB emphasizes scalable, data parallel programming**. Breaking a + program up into separate functional blocks, and assigning a separate + thread to each block is a solution that typically does not scale well + since typically the number of functional blocks is fixed. In + contrast, oneTBB emphasizes *data-parallel* programming, enabling + multiple threads to work on different parts of a collection. + Data-parallel programming scales well to larger numbers of processors + by dividing the collection into smaller pieces. With data-parallel + programming, program performance increases as you add processors. + + +- **oneTBB relies on generic programming**. Traditional libraries + specify interfaces in terms of specific types or base classes. + Instead, oneAPI Threading Building Blocks uses generic programming. + The essence of generic programming is writing the best possible + algorithms with the fewest constraints. The C++ Standard Template + Library (STL) is a good example of generic programming in which the + interfaces are specified by *requirements* on types. For example, C++ + STL has a template function ``sort`` that sorts a sequence abstractly + defined in terms of iterators on the sequence. The requirements on + the iterators are: + + + - Provide random access + + + - The expression ``*i<*j`` is true if the item pointed to by + iterator ``i`` should precede the item pointed to by iterator + ``j``, and false otherwise. + + + - The expression ``swap(*i,*j)`` swaps two elements. + + +Specification in terms of requirements on types enables the template to +sort many different representations of sequences, such as vectors and +deques. Similarly, the oneTBB templates specify requirements on types, +not particular types, and thus adapt to different data representations. +Generic programming enables oneTBB to deliver high performance +algorithms with broad applicability. + diff --git a/_sources/main/intro/help_support.rst b/_sources/main/intro/help_support.rst new file mode 100644 index 0000000000..278083d658 --- /dev/null +++ b/_sources/main/intro/help_support.rst @@ -0,0 +1,15 @@ +.. _help_support: + +Getting Help and Support +======================== + + +.. container:: section + + + .. rubric:: Getting Technical Support + :class: sectiontitle + + For general information about oneTBB technical support, product + updates, user forums, FAQs, tips and tricks and other support + questions, go to `GitHub issues `_. diff --git a/_sources/main/intro/intro_os.rst b/_sources/main/intro/intro_os.rst new file mode 100644 index 0000000000..b174120036 --- /dev/null +++ b/_sources/main/intro/intro_os.rst @@ -0,0 +1,35 @@ +.. _intro: + +Introduction +============ + + +|full_name| is a library that supports scalable parallel programming using +standard ISO C++ code. It does not require special languages or +compilers. It is designed to promote scalable data parallel programming. +Additionally, it fully supports nested parallelism, so you can build +larger parallel components from smaller parallel components. To use the +library, you specify tasks, not threads, and let the library map tasks +onto threads in an efficient manner. + + +Many of the library interfaces employ generic programming, in which +interfaces are defined by requirements on types and not specific types. +The C++ Standard Template Library (STL) is an example of generic +programming. Generic programming enables oneTBB to be flexible yet +efficient. The generic interfaces enable you to customize components to +your specific needs. + + +.. note:: + |full_name| requires C++11 standard compiler support. + + +The net result is that oneTBB enables you to specify parallelism far +more conveniently than using raw threads, and at the same time can +improve performance. + + + + + diff --git a/_sources/main/intro/limitations.rst b/_sources/main/intro/limitations.rst new file mode 100644 index 0000000000..dde9f772d7 --- /dev/null +++ b/_sources/main/intro/limitations.rst @@ -0,0 +1,46 @@ +.. _limitations: + +Known Limitations +***************** + +This page outlines the known limitations of oneTBB to help you better understand its capabilities. + +Freestanding Compilation Mode +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +**Limitation:** oneTBB does not support the freestanding compilation mode. + +**Risk:** Compiling an application that utilizes oneTBB headers using the Intel(R) oneAPI DPC+/C+ Compiler may result in failure on Windows* OS if the ``/Qfreestanding`` compiler option is employed. + +Static Assert +^^^^^^^^^^^^^ + +**Limitation:** A static assert causes the compilation failures in oneTBB headers if the following conditions are satisfied: + + * Compilation is done with Clang 12.0.0 or a more recent version. + * The LLVM standard library is employed, coupled with the use of the ``-ffreestanding`` flag and C++11/14 compiler options. + +**Risk:** The compilation failures. + +Interface Incompatibilities: TBB vs oneTBB +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +**Limitation:** An application using Parallel STL algorithms in the ``libstdc++`` versions 9 and 10 may fail to compile due to incompatible interface changes between earlier versions of Threading Building Blocks (TBB) and oneAPI Threading Building Blocks (oneTBB). + +**Solution:** Disable support for Parallel STL algorithms by defining ``PSTL_USE_PARALLEL_POLICIES`` (in libstdc++ 9) or ``_GLIBCXX_USE_TBB_PAR_BACKEND`` (in libstdc++ 10) macro to zero before inclusion of the first standard header file in each translation unit. + +Incorrect Installation Location +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +**Limitation:** On Linux* OS, if oneAPI Threading Building Blocks (oneTBB) or Threading Building Blocks (TBB) are installed in a system folder, such as ``/usr/lib64``, the application may fail to link due to the order in which the linker searches for libraries. + +**Risk:** The issue does not affect the program execution. + +**Solution:** Use the ``-L`` linker option to specify the correct location of oneTBB library. + +``fork()`` Support +^^^^^^^^^^^^^^^^^^^ + +**Limitation:** oneTBB does not support ``fork()``. + +**Solution:** To work-around the issue, consider using ``task_scheduler_handle`` to join oneTBB worker threads before using ``fork()``. diff --git a/_sources/main/intro/notation.rst b/_sources/main/intro/notation.rst new file mode 100644 index 0000000000..2cc036b54e --- /dev/null +++ b/_sources/main/intro/notation.rst @@ -0,0 +1,106 @@ +.. _notation: + +Notational Conventions +====================== + + +The following conventions may be used in this document. + + +.. container:: tablenoborder + + + .. list-table:: + :header-rows: 1 + + * - Convention + - Explanation + - Example + * - \ *Italic* + - Used for introducing new terms, denotation of terms, placeholders, or titles of manuals. + - The filename consists of the *basename* and the *extension*. + * - \ ``Monospace`` + - Indicates directory paths and filenames, commands and command line options, function names, methods, classes, data structures in body text, source code. + - \ ``ippsapi.h`` \ ``\alt\include`` Use the okCreateObjs() function to... \ ``printf("hello, world\n");`` + * - [ ] + - Items enclosed in brackets are optional. + - Fa[c] Indicates Fa or Fac. + * - { \| } + - Braces and vertical bars indicate the choice of one item from a selection of two or more items. + - X{K \| W \| P} Indicates XK, XW, or XP. + * - "[" "]" "{" | " }" "|" + - Writing a metacharacter in quotation marks negates the syntactical meaning stated above; | the character is taken as a literal. + - "[" X "]" [ Y ] Denotes the letter X enclosed in brackets, optionally followed by the letter Y. + * - ... + - The ellipsis indicates that the previous item can be repeated several times. + - \ ``filename`` ... Indicates that one or more filenames can be specified. + * - ,... + - The ellipsis preceded by a comma indicates that the previous item can be repeated several times, | separated by commas. + - \ ``word`` ,... Indicates that one or more words can be specified. If more than one word is specified, the words are comma-separated. + + + + +.. container:: section + + + Class members are summarized by informal class declarations that + describe the class as it seems to clients, not how it is actually + implemented. For example, here is an informal declaration of class + ``Foo``: + + + :: + + + class Foo { + public: + int x(); + int y; + ~Foo(); + }; + + + The actual implementation might look like: + + + :: + + + namespace internal { + class FooBase { + protected: + int x(); + }; + + + class Foo_v3: protected FooBase { + private: + int internal_stuff; + public: + using FooBase::x; + int y; + }; + } + + + typedef internal::Foo_v3 Foo; + + + The example shows two cases where the actual implementation departs + from the informal declaration: + + + - ``Foo`` is actually a typedef to ``Foo_v3``. + + + - Method ``x()`` is inherited from a protected base class. + + + - The destructor is an implicit method generated by the compiler. + + + The informal declarations are intended to show you what you need to + know to use the class without the distraction of irrelevant clutter + particular to the implementation. + diff --git a/_sources/main/intro/testing_approach.rst b/_sources/main/intro/testing_approach.rst new file mode 100644 index 0000000000..7914c32573 --- /dev/null +++ b/_sources/main/intro/testing_approach.rst @@ -0,0 +1,31 @@ +.. _testing_approach: + +Testing Approach +================ + +There are four main types of errors/hazards you can encounter in the development of libraries for parallelism: + +* Interface correspondence to specification +* Memory errors +* Data race +* Race conditions and deadlocks + +|short_name| testing approach is designed to provide high coverage of these error types. +All types of errors are covered with unit testing and review. + +Code coverage metrics are tracked to ensure high code coverage with tests. Uncovered branches are analyzed manually. +Memory errors and data races are additionally covered by special tools that include thread and memory sanitizers. + +Race conditions and deadlocks are the most complicated errors. +They are covered by: + +* **Unit tests** that, however, have limited capability to catch such errors +* **Integration tests**. Multiple different functionalities are heavily combined to emulate user use cases that may trigger such errors based on prior knowledge and expertise. +* **Stress testing with different possible combinations**. It ensures that even rarely triggered error conditions are caught by testing. + +.. note:: Every fix is required to be covered by a test to guarantee the detection of such issues in the future. + +Continuous Integration triggers all the tests on each commit. This ensures that: + +* Issues are detected, starting from the early development phase and up to the moment of integration of changes into the library. +* The highest quality of the library is maintained even in such error-prone domains as parallelism. diff --git a/_sources/main/reference/concurrent_lru_cache_cls.rst b/_sources/main/reference/concurrent_lru_cache_cls.rst new file mode 100644 index 0000000000..07b609ba59 --- /dev/null +++ b/_sources/main/reference/concurrent_lru_cache_cls.rst @@ -0,0 +1,163 @@ +.. _concurrent_lru_cache: + +concurrent_lru_cache +==================== + +.. note:: + To enable this feature, define the ``TBB_PREVIEW_CONCURRENT_LRU_CACHE`` macro to 1. + +A Class Template for Least Recently Used cache with concurrent operations. + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +A ``concurrent_lru_cache`` container maps keys to values with the ability +to limit the number of stored unused values. For each key, there is at most one item +stored in the container. + +The container permits multiple threads to concurrently retrieve items from it. + +The container tracks which items are in use by returning a proxy +``concurrent_lru_cache::handle`` object that refers to an item instead of its value. +Once there are no ``handle`` objects holding reference to an item, it is considered unused. + +The container stores all the items that are currently in use plus a limited +number of unused items. Excessive unused items are erased according to +least recently used policy. + +When no item is found for a given key, the container calls the user-specified +``value_function_type`` object to construct a value for the key, and stores that value. +The ``value_function_type`` object must be thread-safe. + +API +*** + +Header +------ + +.. code:: cpp + + #include "oneapi/tbb/concurrent_lru_cache.h" + +Synopsis +-------- + +.. code:: cpp + + namespace oneapi { + namespace tbb { + template + class concurrent_lru_cache { + public: + using key_type = Key; + using value_type = Value; + using pointer = value_type*; + using const_pointer = const value_type*; + using reference = value_type&; + using const_reference = const value_type&; + + using value_function_type = ValueFunctionType; + + class handle { + public: + handle(); + handle( handle&& other ); + + ~handle(); + + handle& operator=( handle&& other ); + + operator bool() const; + value_type& value(); + }; // class handle + + concurrent_lru_cache( value_function_type f, std::size_t number_of_lru_history_items ); + ~concurrent_lru_cache(); + + handle operator[]( key_type key ); + }; // class concurrent_lru_cache + } // namespace tbb + } // namespace oneapi + +Member Functions +---------------- + +.. cpp:function:: concurrent_lru_cache( value_function_type f, std::size_t number_of_lru_history_items ); + + **Effects**: Constructs an empty cache that can keep up to ``number_of_lru_history_items`` + unused values, with a function object ``f`` for constructing new values. + +------------------------------------------------------- + +.. cpp:function:: ~concurrent_lru_cache(); + + **Effects**: Destroys the ``concurrent_lru_cache``. Calls the destructors of the stored elements and + deallocates the used storage. + +The behavior is undefined in case of concurrent operations with ``*this``. + +------------------------------------------------------- + +.. cpp:function:: handle operator[]( key_type k ); + + **Effects**: Searches the container for an item that corresponds to the given key. + If such an item is not found, the user-specified function object is called to + construct a value that is inserted into the container. + + **Returns**: a ``handle`` object holding reference to the matching value. + +Member Objects +-------------- + +``handle`` class +^^^^^^^^^^^^^^^^ + +**Member Functions** + +.. cpp:function:: handle(); + + **Effects**: Constructs a ``handle`` object that does not refer to any value. + +-------------------------------------------------- + +.. cpp:function:: handle( handle&& other ); + + **Effects**: Transfers the reference to the value stored in ``concurrent_lru_cache`` + from ``other`` to the newly constructed object. Upon completion, + ``other`` no longer refers to any value. + +--------------------------------------------------- + +.. cpp:function:: ~handle(); + + **Effects**: Releases the reference (if it exists) to a value stored in ``concurrent_lru_cache``. + +The behavior is undefined for concurrent operations with ``*this``. + +--------------------------------------------------- + +.. cpp:function:: handle& operator=( handle&& other ); + + **Effects**: Transfers the reference to a value stored in ``concurrent_lru_cache`` from ``other`` + to ``*this``. If existed, the previous reference held by ``*this`` is released. Upon + completion ``other`` no longer refers to any value. + + **Returns**: a reference to ``*this``. + +--------------------------------------------------- + +.. cpp:function:: operator bool() const; + + **Returns**: ``true`` if ``*this`` holds reference to a value, ``false`` otherwise. + +--------------------------------------------------- + +.. cpp:function:: value_type& value(); + + **Returns**: a reference to a ``value_type`` object stored in ``concurrent_lru_cache``. + +The behavior is undefined if ``*this`` does not refer to any value. diff --git a/_sources/main/reference/constructors_for_nodes.rst b/_sources/main/reference/constructors_for_nodes.rst new file mode 100644 index 0000000000..56e32c2896 --- /dev/null +++ b/_sources/main/reference/constructors_for_nodes.rst @@ -0,0 +1,104 @@ +.. _constructors_for_fg_nodes: + +Constructors for Flow Graph nodes +================================= + +.. note:: + To enable this feature, define the ``TBB_PREVIEW_FLOW_GRAPH_FEATURES`` macro to 1. + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +The "Helper Functions for Expressing Graphs" feature adds a set of new constructors +that can be used to construct a node that ``follows`` or ``precedes`` a set of nodes. + +Where possible, the constructors support Class Template Argument Deduction (since C++17). + +API +*** + +Header +------ + +.. code:: cpp + + #include + +Syntax +------ + +.. code:: cpp + + // continue_node + continue_node(follows(...), Body body, Policy = Policy()); + continue_node(precedes(...), Body body, Policy = Policy()); + + continue_node(follows(...), int number_of_predecessors, Body body, Policy = Policy()); + continue_node(precedes(...), int number_of_predecessors, Body body, Policy = Policy()); + + // function_node + function_node(follows(...), std::size_t concurrency, Policy = Policy()); + function_node(precedes(...), std::size_t concurrency, Policy = Policy()); + + // input_node + input_node(precedes(...), body); + + // multifunction_node + multifunction_node(follows(...), std::size_t concurrency, Body body); + multifunction_node(precedes(...), std::size_t concurrency, Body body); + + // async_node + async_node(follows(...), std::size_t concurrency, Body body); + async_node(precedes(...), std::size_t concurrency, Body body); + + // overwrite_node + explicit overwrite_node(follows(...)); + explicit overwrite_node(precedes(...)); + + // write_once_node + explicit write_once_node(follows(...)); + explicit write_once_node(precedes(...)); + + // buffer_node + explicit buffer_node(follows(...)); + explicit buffer_node(precedes(...)); + + // queue_node + explicit queue_node(follows(...)); + explicit queue_node(precedes(...)); + + // priority_queue_node + explicit priority_queue_node(follows(...), const Compare& comp = Compare()); + explicit priority_queue_node(precedes(...), const Compare& compare = Compare()); + + // sequencer_node + sequencer_node(follows(...), const Sequencer& s); + sequencer_node(precedes(...), const Sequencer& s); + + // limiter_node + limiter_node(follows(...), std::size_t threshold); + limiter_node(precedes(...), std::size_t threshold); + + // broadcast_node + explicit broadcast_node(follows(...)); + explicit broadcast_node(precedes(...)); + + // join_node + explicit join_node(follows(...), Policy = Policy()); + explicit join_node(precedes(...), Policy = Policy()); + + // split_node + explicit split_node(follows(...)); + explicit split_node(precedes(...)); + + // indexer_node + indexer_node(follows(...)); + indexer_node(precedes(...)); + +See Also +******** +:ref:`follows_precedes` diff --git a/_sources/main/reference/custom_mutex_chmap.rst b/_sources/main/reference/custom_mutex_chmap.rst new file mode 100644 index 0000000000..acf502e66d --- /dev/null +++ b/_sources/main/reference/custom_mutex_chmap.rst @@ -0,0 +1,158 @@ +.. _custom_mutex_chmap: + +The customizing mutex type for ``concurrent_hash_map`` +====================================================== + +.. note:: + To enable this feature, define the ``TBB_PREVIEW_CONCURRENT_HASH_MAP_EXTENSIONS`` macro to 1. + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +oneTBB ``concurrnent_hash_map`` class uses reader-writer mutex +to provide thread safety and avoid data races for insert, lookup, and erasure operations. This feature adds an extra template parameter +for ``concurrent_hash_map`` that allows to customize the type of the reader-writer mutex. + +API +*** + +Header +------ + +.. code:: cpp + + #include + +Synopsis +-------- + +.. code:: cpp + + namespace oneapi { + namespace tbb { + + template , + typename Allocator = tbb_allocator>, + typename Mutex = spin_rw_mutex> + class concurrent_hash_map { + using mutex_type = Mutex; + }; + + } // namespace tbb + } // namespace oneapi + +Type requirements +----------------- + +The type of the mutex passed as a template argument for ``concurrent_hash_map`` should +meet the requirements of `ReaderWriterMutex `_. +It should also provide the following API: + +.. cpp:function:: bool ReaderWriterMutex::scoped_lock::is_writer() const; + +**Returns**: ``true`` if the ``scoped_lock`` object acquires the mutex as a writer, ``false`` otherwise. + +The behavior is undefined if the ``scoped_lock`` object does not acquire the mutex. + +``oneapi::tbb::spin_rw_mutex``, ``oneapi::tbb::speculative_spin_rw_mutex``, ``oneapi::tbb::queuing_rw_mutex``, ``oneapi::tbb::null_rw_mutex``, +and ``oneapi::tbb::rw_mutex`` meet the requirements above. + +.. rubric:: Example + +The example below demonstrates how to wrap ``std::shared_mutex`` (C++17) to meet the requirements +of `ReaderWriterMutex` and how to customize ``concurrent_hash_map`` to use this mutex. + +.. code:: cpp + + #define TBB_PREVIEW_CONCURRENT_HASH_MAP_EXTENSIONS 1 + #include "oneapi/tbb/concurrent_hash_map.h" + #include + + class SharedMutexWrapper { + public: + // ReaderWriterMutex requirements + + static constexpr bool is_rw_mutex = true; + static constexpr bool is_recursive_mutex = false; + static constexpr bool is_fair_mutex = false; + + class scoped_lock { + public: + scoped_lock() : my_mutex_ptr(nullptr), my_writer_flag(false) {} + scoped_lock(SharedMutexWrapper& mutex, bool write = true) + : my_mutex_ptr(&mutex), my_writer_flag(write) + { + if (my_writer_flag) { + my_mutex_ptr->my_mutex.lock(); + } else { + my_mutex_ptr->my_mutex.lock_shared(); + } + } + + ~scoped_lock() { + if (my_mutex_ptr) release(); + } + + void acquire(SharedMutexWrapper& mutex, bool write = true) { + if (my_mutex_ptr) release(); + + my_mutex_ptr = &mutex; + my_writer_flag = write; + + if (my_writer_flag) { + my_mutex_ptr->my_mutex.lock(); + } else { + my_mutex_ptr->my_mutex.lock_shared(); + } + } + + void release() { + if (my_writer_flag) { + my_mutex_ptr->my_mutex.unlock(); + } else { + my_mutex_ptr->my_mutex.unlock_shared(); + } + } + + bool upgrade_to_writer() { + // std::shared_mutex does not have the upgrade/downgrade parallel_for_each_semantics + if (my_writer_flag) return true; // Already a writer + + my_mutex_ptr->my_mutex.unlock_shared(); + my_mutex_ptr->my_mutex.lock(); + return false; // The lock was reacquired + } + + bool downgrade_to_reader() { + if (!my_writer_flag) return true; // Already a reader + + my_mutex_ptr->my_mutex.unlock(); + my_mutex_ptr->my_mutex.lock_shared(); + return false; + } + + bool is_writer() const { + return my_writer_flag; + } + + private: + SharedMutexWrapper* my_mutex_ptr; + bool my_writer_flag; + }; + private: + std::shared_mutex my_mutex; + }; // struct SharedMutexWrapper + + int main() { + using map_type = oneapi::tbb::concurrent_hash_map, + oneapi::tbb::tbb_allocator>, + SharedMutexWrapper>; + + map_type map; // This object will use SharedMutexWrapper for thread safety of insert/find/erase operations + } diff --git a/_sources/main/reference/follows_and_precedes_functions.rst b/_sources/main/reference/follows_and_precedes_functions.rst new file mode 100644 index 0000000000..efeda8ce19 --- /dev/null +++ b/_sources/main/reference/follows_and_precedes_functions.rst @@ -0,0 +1,78 @@ +.. _follows_precedes: + +``follows`` and ``precedes`` function templates +=============================================== + +.. note:: + To enable this feature, define the ``TBB_PREVIEW_FLOW_GRAPH_FEATURES`` macro to 1. + +The ``follows`` and ``precedes`` helper functions aid in expressing +dependencies between nodes when building oneTBB flow graphs. These helper functions can +only be used while constructing the node. + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +The ``follows`` helper function specifies that the node being constructed is +the successor of the set of nodes passed as an argument. + +The ``precedes`` helper function specifies that the node being constructed is +the predecessor of the set of nodes passed as an argument. + +Functions ``follows`` and ``precedes`` are meant to replace the graph argument, which is +passed as the first argument to the constructor of the node. The graph argument for the +node being constructed is obtained either from the specified node set or the sequence of nodes passed +to ``follows`` or ``precedes``. + +If the nodes passed to ``follows`` or ``precedes`` belong to +different graphs, the behavior is undefined. + +API +*** + +Header +------ + +.. code:: cpp + + #include + +Syntax +------ + +.. code:: cpp + + // node_set is an exposition-only name for the type returned from make_node_set function + + template + /*unspecified*/ follows( node_set& set ); + + template + /*unspecified*/ follows( NodeType& node, NodeTypes&... nodes ); + + template + /*unspecified*/ precedes( node_set& set ); + + template + /*unspecified*/ precedes( NodeType& node, NodeTypes&... nodes ); + +Input Parameters +---------------- + +Either a set or a sequence of nodes can be used as arguments for ``follows`` and +``precedes``. The following expressions are equivalent: + +.. code-block:: cpp + :caption: A set of nodes as an input + + auto handlers = make_node_set(n1, n2, n3); + broadcast_node input(precedes(handlers)); + +.. code-block:: cpp + :caption: A sequence of nodes as an input + + broadcast_node input(precedes(n1, n2, n3)); diff --git a/_sources/main/reference/helpers_for_expressing_graphs.rst b/_sources/main/reference/helpers_for_expressing_graphs.rst new file mode 100644 index 0000000000..537fda0f13 --- /dev/null +++ b/_sources/main/reference/helpers_for_expressing_graphs.rst @@ -0,0 +1,118 @@ +.. _helpers_for_expressing_graphs: + +Helper Functions for Expressing Graphs +====================================== + +.. note:: + To enable this feature, define the ``TBB_PREVIEW_FLOW_GRAPH_FEATURES`` macro to 1. + +Helper functions are intended to make creation of the flow graphs less verbose. + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +This feature adds ``make_edges``, ``make_node_set``, +``follows`` and ``precedes`` functions to ``oneapi::tbb::flow`` namespace. +These functions simplify the process of building flow graphs by allowing to gather nodes +into sets and connect them to other nodes in the graph. + +API +*** + +.. toctree:: + :titlesonly: + + constructors_for_nodes + follows_and_precedes_functions + make_node_set_function + make_edges_function + +Example +******* + +Consider the graph depicted below. + +.. figure:: ./Resources/fg_api_graph_structure.png + :align: center + +In the examples below, C++17 Class Template Argument Deduction is used +to avoid template parameter specification where possible. + +**Regular API** + +.. code:: cpp + + #include + + int main() { + using namespace oneapi::tbb::flow; + + graph g; + + broadcast_node input(g); + + function_node doubler(g, unlimited, [](const int& v) { return 2 * v; }); + function_node squarer(g, unlimited, [](const int&) { return v * v; }); + function_node cuber(g, unlimited, [](const int& v) { return v * v * v; }); + + join_node> join(g); + + int sum = 0; + function_node summer(g, serial, [&](const std::tuple& v) { + int sub_sum = std::get<0>(v) + std::get<1>(v) + std::get<2>(v); + sum += sub_sum; + return sub_sum; + }); + + make_edge(input, doubler); + make_edge(input, squarer); + make_edge(input, cuber); + make_edge(doubler, std::get<0>(join.input_ports())); + make_edge(squarer, std::get<1>(join.input_ports())); + make_edge(cuber, std::get<2>(join.input_ports())); + make_edge(join, summer); + + for (int i = 1; i <= 10; ++i) { + input.try_put(i); + } + g.wait_for_all(); + } + +**Preview API** + +.. code:: cpp + + #define TBB_PREVIEW_FLOW_GRAPH_FEATURES 1 + #include + + int main() { + using namespace oneapi::tbb::flow; + + graph g; + + function_node doubler(g, unlimited, [](const int& v) { return 2 * v; }); + function_node squarer(g, unlimited, [](const int&) { return v * v; }); + function_node cuber(g, unlimited, [](const int& v) { return v * v * v; }); + + auto handlers = make_node_set(doubler, squarer, cuber); + + broadcast_node input(precedes(handlers)); + join_node join(follows(handlers)); + + int sum = 0; + function_node summer(follows(join), serial, + [&](const std::tuple& v) { + int sub_sum = std::get<0>(v) + std::get<1>(v) + std::get<2>(v); + sum += sub_sum; + return sub_sum; + }); + + for (int i = 1; i <= 10; ++i) { + input.try_put(i); + } + g.wait_for_all(); + } diff --git a/_sources/main/reference/make_edges_function.rst b/_sources/main/reference/make_edges_function.rst new file mode 100644 index 0000000000..4035463db6 --- /dev/null +++ b/_sources/main/reference/make_edges_function.rst @@ -0,0 +1,81 @@ +.. _make_edges: + +``make_edges`` function template +================================ + +.. note:: + To enable this feature, define the ``TBB_PREVIEW_FLOW_GRAPH_FEATURES`` macro to 1. + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +The ``make_edges`` function template creates edges between a single node +and each node in a set of nodes. + +There are two ways to connect nodes in a set and a single node using +``make_edges``: + +.. figure:: ./Resources/make_edges_usage.png + :align: center + +API +*** + +Header +------ + +.. code:: cpp + + #include + +Syntax +------ + +.. code:: cpp + + // node_set is an exposition-only name for the type returned from make_node_set function + + template + void make_edges(node_set& set, NodeType& node); + + template + void make_edges(NodeType& node, node_set& set); + +Example +------- + +The example implements the graph structure in the picture below. + +.. figure:: ./Resources/make_edges_example.png + :align: center + +.. code:: cpp + + #define TBB_PREVIEW_FLOW_GRAPH_FEATURES 1 + #include + + int main() { + using namespace oneapi::tbb::flow; + + graph g; + broadcast_node input(g); + + function_node doubler(g, unlimited, [](const int& i) { return 2 * i; }); + function_node squarer(g, unlimited, [](const int& i) { return i * i; }); + function_node cuber(g, unlimited, [](const int& i) { return i * i * i; }); + + buffer_node buffer(g); + + auto handlers = make_node_set(doubler, squarer, cuber); + make_edges(input, handlers); + make_edges(handlers, buffer); + + for (int i = 1; i <= 10; ++i) { + input.try_put(i); + } + g.wait_for_all(); + } diff --git a/_sources/main/reference/make_node_set_function.rst b/_sources/main/reference/make_node_set_function.rst new file mode 100644 index 0000000000..bf8eb15b68 --- /dev/null +++ b/_sources/main/reference/make_node_set_function.rst @@ -0,0 +1,42 @@ +.. _make_node_set: + +``make_node_set`` function template +=================================== + +.. note:: + To enable this feature, define the ``TBB_PREVIEW_FLOW_GRAPH_FEATURES`` macro to 1. + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +The ``make_node_set`` function template creates a set of nodes that +can be passed as arguments to ``make_edges``, ``follows`` and ``precedes`` functions. + +API +*** + +Header +------ + +.. code:: cpp + + #include + +Syntax +------ + +.. code:: cpp + + template + /*unspecified*/ make_node_set( Node& node, Nodes&... nodes ); + +See Also +******** + +:ref:`make_edges` + +:ref:`follows_precedes` \ No newline at end of file diff --git a/_sources/main/reference/parallel_for_each_semantics.rst b/_sources/main/reference/parallel_for_each_semantics.rst new file mode 100644 index 0000000000..c007066b3b --- /dev/null +++ b/_sources/main/reference/parallel_for_each_semantics.rst @@ -0,0 +1,66 @@ +.. _parallel_for_each_semantics: + +parallel_for_each Body semantics and requirements +================================================= + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +This page clarifies `ParallelForEachBody `_ +named requirements for ``tbb::parallel_for_each`` algorithm specification. + +.. code:: cpp + + namespace oneapi { + namespace tbb { + + template + void parallel_for_each( InputIterator first, InputIterator last, Body body ); // overload (1) + template + void parallel_for_each( InputIterator first, InputIterator last, Body body, task_group_context& group ); // overload (2) + + template + void parallel_for_each( Container& c, Body body ); // overload (3) + template + void parallel_for_each( Container& c, Body body, task_group_context& group ); // overload (4) + + template + void parallel_for_each( const Container& c, Body body ); // overload (5) + template + void parallel_for_each( const Container& c, Body body, task_group_context& group ); // overload (6) + + } // namespace tbb + } // namespace oneapi + +Terms +----- + +* ``iterator`` determines the type of the iterator passed into ``parallel_for_each`` algorithm (which is ``InputIterator`` for overloads `(1)` and `(2)` + and ``decltype(std::begin(c))`` for overloads `(3) - (6)`) +* ``value_type`` - the type ``typename std::iterator_traits::value_type`` +* ``reference`` - the type ``typename std::iterator_traits::reference``. + +Requirements for different iterator types +----------------------------------------- + +If the ``iterator`` satisfies `Input iterator` named requirements from [input.iterators] ISO C++ Standard section and do not satisfies +`Forward iterator` named requirements from [forward.iterators] ISO C++ Standard section, ``tbb::parallel_for_each`` requires the execution +of the ``body`` with an object of type ``const value_type&`` or ``value_type&&`` to be well-formed. If both forms are well-formed, an overload with +rvalue reference will be preferred. + +.. caution:: + + If the ``Body`` only takes non-const lvalue reference to ``value_type``, named requirements above are violated and the program can be ill-formed. + +If the ``iterator`` satisfies `Forward iterator` named requirements from [forward.iterators] ISO C++ Standard section, ``tbb::parallel_for_each`` requires the execution of the ``body`` +with an object of type ``reference`` to be well-formed. + +Requirements for ``Body`` with ``feeder`` argument +-------------------------------------------------- + +Additional elements submitted into ``tbb::parallel_for_each`` through the ``feeder::add`` passes to the ``Body`` as rvalues and therefore the corresponding +execution of the ``Body`` is required to be well-formed. diff --git a/_sources/main/reference/parallel_sort_ranges_extension.rst b/_sources/main/reference/parallel_sort_ranges_extension.rst new file mode 100644 index 0000000000..cad65b54b0 --- /dev/null +++ b/_sources/main/reference/parallel_sort_ranges_extension.rst @@ -0,0 +1,72 @@ +.. _parallel_sort_ranges_extension: + +parallel_sort ranges interface extension +======================================== + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +|full_name| implementation extends the `oneapi::tbb::parallel_sort specification `_ +with overloads that takes the container by forwarding reference. + + +API +*** + +Header +------ + +.. code:: cpp + + #include + +Syntax +------ + +.. code:: cpp + + namespace oneapi { + namespace tbb { + + template + void parallel_sort( Container&& c ); + template + void parallel_sort( Container&& c, const Compare& comp ); + + } // namespace tbb + } // namespace oneapi + +Functions +--------- + +.. cpp:function:: template void parallel_sort( Container&& c ); + + Equivalent to ``parallel_sort( std::begin(c), std::end(c), comp )``, where `comp` uses `operator<` to determine relative orderings. + +.. cpp:function:: template void parallel_sort( Container&& c, const Compare& comp ); + + Equivalent to ``parallel_sort( std::begin(c), std::end(c), comp )``. + +Example +------- + +This interface may be used for sorting rvalue or constant views: + +.. code:: cpp + + #include + #include // requires C++20 + #include + + std::span get_span() { + static std::array arr = {3, 2, 1}; + return std::span(arr); + } + + int main() { + tbb::parallel_sort(get_span()); + } diff --git a/_sources/main/reference/reference.rst b/_sources/main/reference/reference.rst new file mode 100644 index 0000000000..4c293c02c7 --- /dev/null +++ b/_sources/main/reference/reference.rst @@ -0,0 +1,53 @@ +.. _reference: + +|short_name| API Reference +========================== + +For oneTBB API Reference, refer to `oneAPI Specification `_. The current supported +version of oneAPI Specification is 1.0. + +Specification extensions +************************ + +|full_name| implements the `oneTBB specification `_. +This document provides additional details or restrictions where necessary. +It also describes features that are not included in the oneTBB specification. + +.. toctree:: + :titlesonly: + + parallel_for_each_semantics + parallel_sort_ranges_extension + scalable_memory_pools/malloc_replacement_log + rvalue_reduce + +Preview features +**************** + +A preview feature is a component of oneTBB introduced to receive early feedback from +users. + +The key properties of a preview feature are: + +- It is off by default and must be explicitly enabled. +- It is intended to have a high quality implementation. +- There is no guarantee of future existence or compatibility. +- It may have limited or no support in tools such as correctness analyzers, profilers and debuggers. + + +.. caution:: + A preview feature is subject to change in future. It might be removed or significantly + altered in future releases. Changes to a preview feature do NOT require + usual deprecation and removal process. Therefore, using preview features in production code + is strongly discouraged. + +.. toctree:: + :titlesonly: + + type_specified_message_keys + scalable_memory_pools + helpers_for_expressing_graphs + concurrent_lru_cache_cls + task_group_extensions + custom_mutex_chmap + try_put_and_wait diff --git a/_sources/main/reference/rvalue_reduce.rst b/_sources/main/reference/rvalue_reduce.rst new file mode 100644 index 0000000000..7cf66d86b3 --- /dev/null +++ b/_sources/main/reference/rvalue_reduce.rst @@ -0,0 +1,91 @@ +.. _rvalue_reduce: + +Parallel Reduction for rvalues +============================== + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +|full_name| implementation extends the `ParallelReduceFunc `_ and +`ParallelReduceReduction `_ +to optimize operating with ``rvalues`` using functional form of ``tbb::parallel_reduce`` and ``tbb::parallel_deterministic_reduce`` algorithms. + +API +*** + +Header +------ + +.. code:: cpp + + #include + +ParallelReduceFunc Requirements: Pseudo-Signature, Semantics +------------------------------------------------------------ + +.. cpp:function:: Value Func::operator()(const Range& range, Value&& x) const + +or + +.. cpp:function:: Value Func::operator()(const Range& range, const Value& x) const + + Accumulates the result for a subrange, starting with initial value ``x``. The ``Range`` type must meet the + `Range requirements `_. + The ``Value`` type must be the same as a corresponding template parameter for the `parallel_reduce algorithm `_. + + If both ``rvalue`` and ``lvalue`` forms are provided, the ``rvalue`` is preferred. + +ParallelReduceReduction Requirements: Pseudo-Signature, Semantics +----------------------------------------------------------------- + +.. cpp:function:: Value Reduction::operator()(Value&& x, Value&& y) const + +or + +.. cpp:function:: Value Reduction::operator()(const Value& x, const Value& y) const + + Combines the ``x`` and ``y`` results. The ``Value`` type must be the same as a corresponding template parameter for the `parallel_reduce algorithm `_. + + If both ``rvalue`` and ``lvalue`` forms are provided, the ``rvalue`` is preferred. + +Example +******* + +.. code:: cpp + + // C++17 + #include + #include + #include + #include + + int main() { + std::vector> sets = ...; + + oneapi::tbb::parallel_reduce(oneapi::tbb::blocked_range(0, sets.size()), + std::set{}, // identity element - empty set + [&](const oneapi::tbb::blocked_range& range, std::set&& value) { + for (size_t i = range.begin(); i < range.end(); ++i) { + // Having value as a non-const rvalue reference allows to efficiently + // transfer nodes from sets[i] without copying/moving the data + value.merge(std::move(sets[i])); + } + return value; + }, + [&](std::set&& x, std::set&& y) { + x.merge(std::move(y)); + return x; + } + ); + } + +.. rubric:: See also + +* `oneapi::tbb::parallel_reduce specification `_ +* `oneapi::tbb::parallel_deterministic_reduce specification `_ +* `ParallelReduceFunc specification `_ +* `ParallelReduceReduction specification `_ diff --git a/_sources/main/reference/scalable_memory_pools.rst b/_sources/main/reference/scalable_memory_pools.rst new file mode 100644 index 0000000000..d04cd54a90 --- /dev/null +++ b/_sources/main/reference/scalable_memory_pools.rst @@ -0,0 +1,44 @@ +.. _scalable_memory_pools_reference: + +Scalable Memory Pools +===================== + +.. note:: + To enable this feature, set the ``TBB_PREVIEW_MEMORY_POOL`` macro to 1. + +Memory pools allocate and free memory from a specified region or an underlying allocator using +thread-safe, scalable operations. The following table summarizes the Memory Pool named requirement. +Here, ``P`` represents an instance of the memory pool class. + +.. container:: tablenoborder + + .. list-table:: + :header-rows: 1 + + * - Pseudo-Signature + - Semantics + * - \ ``~P() throw();`` + - Destructor. Frees all the allocated memory. + * - \ ``void P::recycle();`` + - Frees all the allocated memory. + * - \ ``void* P::malloc(size_t n);`` + - Returns a pointer to ``n`` bytes allocated from the memory pool. + * - \ ``void P::free(void* ptr);`` + - Frees the memory object specified via ``ptr`` pointer. + * - \ ``void* P::realloc(void* ptr, size_t n);`` + - Reallocates the memory object pointed by ``ptr`` to ``n`` bytes. + +.. container:: section + + .. rubric:: Model Types + :class: sectiontitle + + The ``memory_pool`` template class and the ``fixed_pool`` class meet the Memory Pool named requirement. + +.. toctree:: + :titlesonly: + + scalable_memory_pools/memory_pool_cls + scalable_memory_pools/fixed_pool_cls + scalable_memory_pools/memory_pool_allocator_cls + diff --git a/_sources/main/reference/scalable_memory_pools/fixed_pool_cls.rst b/_sources/main/reference/scalable_memory_pools/fixed_pool_cls.rst new file mode 100644 index 0000000000..283842572a --- /dev/null +++ b/_sources/main/reference/scalable_memory_pools/fixed_pool_cls.rst @@ -0,0 +1,76 @@ +.. _fixed_pool_cls: + +fixed_pool +========== + +.. note:: + To enable this feature, set the ``TBB_PREVIEW_MEMORY_POOL`` macro to 1. + +A class for scalable memory allocation from a buffer of fixed size. + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +``fixed_pool`` allocates and frees memory in a way that scales with the number of processors. +All the memory available for the allocation is initially passed through arguments of the constructor. +``fixed_pool`` meet the :doc:`Memory Pool named requirement<../scalable_memory_pools>`. + +API +*** + +Header +------ + +.. code:: cpp + + #include "oneapi/tbb/memory_pool.h" + +Synopsis +-------- + +.. code:: cpp + + namespace oneapi { + namespace tbb { + class fixed_pool { + public: + fixed_pool(void *buffer, size_t size); + fixed_pool(const fixed_pool& other) = delete; + fixed_pool& operator=(const fixed_pool& other) = delete; + ~fixed_pool(); + + void recycle(); + void* malloc(size_t size); + void free(void* ptr); + void* realloc(void* ptr, size_t size); + }; + } // namespace tbb + } // namespace oneapi + +Member Functions +---------------- + +.. cpp:function:: fixed_pool(void *buffer, size_t size) + + **Effects**: Constructs a memory pool to manage the memory of size ``size`` pointed to by ``buffer``. + Throws the ``bad_alloc`` exception if the library fails to construct an instance of the class. + +Examples +******** + +The code below provides a simple example of allocation from a fixed pool. + +.. code:: cpp + + #define TBB_PREVIEW_MEMORY_POOL 1 + #include "oneapi/tbb/memory_pool.h" + ... + char buf[1024*1024]; + oneapi::tbb::fixed_pool my_pool(buf, 1024*1024); + void* my_ptr = my_pool.malloc(10); + my_pool.free(my_ptr);} + diff --git a/_sources/main/reference/scalable_memory_pools/malloc_replacement_log.rst b/_sources/main/reference/scalable_memory_pools/malloc_replacement_log.rst new file mode 100644 index 0000000000..8fea89f949 --- /dev/null +++ b/_sources/main/reference/scalable_memory_pools/malloc_replacement_log.rst @@ -0,0 +1,84 @@ +.. _malloc_replacement_log: + +TBB_malloc_replacement_log Function +=================================== + +.. note:: This function is for Windows* OS only. + +Summary +******* + +Provides information about the status of dynamic memory allocation replacement. + +Syntax +******* + +:: + + extern "C" int TBB_malloc_replacement_log(char *** log_ptr); + + +Header +****** + +:: + + #include "oneapi/tbb/tbbmalloc_proxy.h" + + +Description +*********** + +Dynamic replacement of memory allocation functions on Windows* OS uses in-memory binary instrumentation techniques. +To make sure that such instrumentation is safe, oneTBB first searches for a subset of replaced functions in the Visual C++* runtime DLLs +and checks if each one has a known bytecode pattern. If any required function is not found or its bytecode pattern is unknown, the replacement is skipped, +and the program continues to use the standard memory allocation functions. + +The ``TBB_malloc_replacement_log`` function allows the program to check if the dynamic memory replacement happens and to get a log of the performed checks. + +**Returns:** + +* 0, if all necessary functions are successfully found and the replacement takes place. +* 1, otherwise. + +The ``log_ptr`` parameter must be an address of a char** variable or be ``NULL``. If it is not ``NULL``, the function writes there the address of an array of +NULL-terminated strings containing detailed information about the searched functions in the following format: + +:: + + search_status: function_name (dll_name), byte pattern: + + +For more information about the replacement of dynamic memory allocation functions, see :ref:`Windows_C_Dynamic_Memory_Interface_Replacement`. + + +Example +******* + +:: + + #include "oneapi/tbb/tbbmalloc_proxy.h" + #include + + int main(){ + char **func_replacement_log; + int func_replacement_status = TBB_malloc_replacement_log(&func_replacement_log); + + if (func_replacement_status != 0) { + printf("tbbmalloc_proxy cannot replace memory allocation routines\n"); + for (char** log_string = func_replacement_log; *log_string != 0; log_string++) { + printf("%s\n",*log_string); + } + } + + return 0; + } + + +Example output: + +:: + + tbbmalloc_proxy cannot replace memory allocation routines + Success: free (ucrtbase.dll), byte pattern: + Fail: _msize (ucrtbase.dll), byte pattern: diff --git a/_sources/main/reference/scalable_memory_pools/memory_pool_allocator_cls.rst b/_sources/main/reference/scalable_memory_pools/memory_pool_allocator_cls.rst new file mode 100644 index 0000000000..d275c02f5e --- /dev/null +++ b/_sources/main/reference/scalable_memory_pools/memory_pool_allocator_cls.rst @@ -0,0 +1,117 @@ +.. _memory_pool_allocator_cls: + +memory_pool_allocator +===================== + +.. note:: + To enable this feature, set the ``TBB_PREVIEW_MEMORY_POOL`` macro to 1. + +A class template that provides a memory pool with a C++ allocator interface. + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +``memory_pool_allocator`` meets the allocator requirements from the [allocator.requirements] ISO C++ Standard section +It also provides a constructor to allocate and deallocate memory. +This constructor is linked with an instance of either the ``memory_pool`` or the ``fixed_pool`` class. +The class is mainly intended for enabling memory pools within STL containers. + +API +*** + +Header +------ + +.. code:: cpp + + #include "oneapi/tbb/memory_pool.h" + +Synopsis +-------- + +.. code:: cpp + + namespace oneapi { + namespace tbb { + template + class memory_pool_allocator { + public: + using value_type = T; + using pointer = value_type*; + using const_pointer = const value_type*; + using reference = value_type&; + using const_reference = const value_type&; + using size_type = size_t; + using difference_type = ptrdiff_t; + template struct rebind { + using other = memory_pool_allocator; + }; + explicit memory_pool_allocator(memory_pool &pool) throw(); + explicit memory_pool_allocator(fixed_pool &pool) throw(); + memory_pool_allocator(const memory_pool_allocator& src) throw(); + template + memory_pool_allocator(const memory_pool_allocator& src) throw(); + pointer address(reference x) const; + const_pointer address(const_reference x) const; + pointer allocate(size_type n, const void* hint=0); + void deallocate(pointer p, size_type); + size_type max_size() const throw(); + void construct(pointer p, const T& value); + void destroy(pointer p); + }; + + template<> + class memory_pool_allocator { + public: + using pointer = void*; + using const_pointer = const void*; + using value_type = void; + template struct rebind { + using other = memory_pool_allocator; + }; + memory_pool_allocator(memory_pool &pool) throw(); + memory_pool_allocator(fixed_pool &pool) throw(); + memory_pool_allocator(const memory_pool_allocator& src) throw(); + template + memory_pool_allocator(const memory_pool_allocator& src) throw(); + }; + } // namespace tbb + } // namespace oneapi + + template + inline bool operator==( const memory_pool_allocator& a, + const memory_pool_allocator& b); + template + inline bool operator!=( const memory_pool_allocator& a, + const memory_pool_allocator& b); + +Member Functions +---------------- + +.. cpp:function:: explicit memory_pool_allocator(memory_pool &pool) + + **Effects**: Constructs a memory pool allocator serviced by ``memory_pool`` instance pool. + +------------------------------------------------------- + +.. cpp:function:: explicit memory_pool_allocator(fixed_pool &pool) + + **Effects**: Constructs a memory pool allocator serviced by ``fixed_pool`` instance pool. + +Examples +******** + +The code below provides a simple example of container construction with the use of a memory pool. + +.. code:: cpp + + #define TBB_PREVIEW_MEMORY_POOL 1 + #include "oneapi/tbb/memory_pool.h" + ... + typedef oneapi::tbb::memory_pool_allocator + pool_allocator_t; + std::list my_list(pool_allocator_t( my_pool )); diff --git a/_sources/main/reference/scalable_memory_pools/memory_pool_cls.rst b/_sources/main/reference/scalable_memory_pools/memory_pool_cls.rst new file mode 100644 index 0000000000..fefade1c61 --- /dev/null +++ b/_sources/main/reference/scalable_memory_pools/memory_pool_cls.rst @@ -0,0 +1,80 @@ +.. _memory_pool_cls: + +memory_pool +=========== + +.. note:: + To enable this feature, set the ``TBB_PREVIEW_MEMORY_POOL`` macro to 1. + +A class template for scalable memory allocation from memory blocks provided by an underlying allocator. + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +A ``memory_pool`` allocates and frees memory in a way that scales with the number of processors. +The memory is obtained as big chunks from an underlying allocator specified by the template +argument. The latter must satisfy the subset of the allocator requirements from the [allocator.requirements] +ISO C++ Standard section. A ``memory_pool`` meet the :doc:`Memory Pool named requirement<../scalable_memory_pools>`. + +.. caution:: + + If the underlying allocator refers to another scalable memory pool, the inner pool (or pools) + must be destroyed before the outer pool is destroyed or recycled. + +API +*** + +Header +------ + +.. code:: cpp + + #include "oneapi/tbb/memory_pool.h" + +Synopsis +-------- + +.. code:: cpp + + namespace oneapi { + namespace tbb { + template + class memory_pool { + public: + explicit memory_pool(const Alloc &src = Alloc()); + memory_pool(const memory_pool& other) = delete; + memory_pool& operator=(const memory_pool& other) = delete; + ~memory_pool(); + void recycle(); + void *malloc(size_t size); + void free(void* ptr); + void *realloc(void* ptr, size_t size); + }; + } + } + +Member Functions +---------------- + +.. cpp:function:: explicit memory_pool(const Alloc &src = Alloc()) + + **Effects**: Constructs a memory pool with an instance of underlying memory allocator of type ``Alloc`` copied from ``src``. + Throws the ``bad_alloc`` exception if runtime fails to construct an instance of the class. + +Examples +******** + +The code below provides a simple example of allocation from an extensible memory pool. + +.. code:: cpp + + #define TBB_PREVIEW_MEMORY_POOL 1 + #include "oneapi/tbb/memory_pool.h" + ... + oneapi::tbb::memory_pool > my_pool; + void* my_ptr = my_pool.malloc(10); + my_pool.free(my_ptr); diff --git a/_sources/main/reference/task_group_extensions.rst b/_sources/main/reference/task_group_extensions.rst new file mode 100644 index 0000000000..47795f9574 --- /dev/null +++ b/_sources/main/reference/task_group_extensions.rst @@ -0,0 +1,89 @@ +.. _task_group_extensions: + +task_group extensions +===================== + +.. note:: + To enable these extensions, set the ``TBB_PREVIEW_TASK_GROUP_EXTENSIONS`` macro to 1. + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +|full_name| implementation extends the `tbb::task_group specification `_ with the requirements for a user-provided function object. + + +API +*** + +Header +------ + +.. code:: cpp + + #include + +Synopsis +-------- + +.. code:: cpp + + namespace oneapi { + namespace tbb { + + class task_group { + public: + + //only the requirements for the return type of function F are changed + template + task_handle defer(F&& f); + + //only the requirements for the return type of function F are changed + template + task_group_status run_and_wait(const F& f); + + //only the requirements for the return type of function F are changed + template + void run(F&& f); + }; + + } // namespace tbb + } // namespace oneapi + + + +Member Functions +---------------- + +.. cpp:function:: template task_handle defer(F&& f) + +As an optimization hint, ``F`` might return a ``task_handle``, which task object can be executed next. + +.. note:: + The ``task_handle`` returned by the function must be created using ``*this`` ``task_group``. That is, the one for which the run method is called, otherwise it is undefined behavior. + +.. cpp:function:: template task_group_status run_and_wait(const F& f) + +As an optimization hint, ``F`` might return a ``task_handle``, which task object can be executed next. + +.. note:: + The ``task_handle`` returned by the function must be created using ``*this`` ``task_group``. That is, the one for which the run method is called, otherwise it is undefined behavior. + + +.. cpp:function:: template void run(F&& f) + +As an optimization hint, ``F`` might return a ``task_handle``, which task object can be executed next. + +.. note:: + The ``task_handle`` returned by the function must be created with ``*this`` ``task_group``. It means, with the one for which run method is called, otherwise it is an undefined behavior. + + +.. rubric:: See also + +* `oneapi::tbb::task_group specification `_ +* `oneapi::tbb::task_group_context specification `_ +* `oneapi::tbb::task_group_status specification `_ +* `oneapi::tbb::task_handle class `_ diff --git a/_sources/main/reference/try_put_and_wait.rst b/_sources/main/reference/try_put_and_wait.rst new file mode 100644 index 0000000000..4e05961f39 --- /dev/null +++ b/_sources/main/reference/try_put_and_wait.rst @@ -0,0 +1,324 @@ +.. _try_put_and_wait: + +Waiting for Single Messages in Flow Graph +========================================= + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +This feature adds a new ``try_put_and_wait`` interface to the receiving nodes in the Flow Graph. +This function puts a message as an input into a Flow Graph and waits until all work related to +that message is complete. +``try_put_and_wait`` may reduce latency compared to calling ``graph::wait_for_all`` since +``graph::wait_for_all`` waits for all work, including work that is unrelated to the input message, to complete. + +``node.try_put_and_wait(msg)`` performs ``node.try_put(msg)`` on the node and waits until the work on ``msg`` is completed. +Therefore, the following conditions are true: + +* Any task initiated by any node in the Flow Graph that involves working with ``msg`` or any other intermediate result + computed from ``msg`` is completed. +* No intermediate results computed from ``msg`` remain in any buffers in the graph. + +.. caution:: + + To prevent ``try_put_and_wait`` calls from infinite waiting, avoid using buffering nodes at the end of the Flow Graph since the final result + will not be automatically consumed by the Flow Graph. + +.. caution:: + + The ``multifunction_node`` and ``async_node`` classes are not currently supported by this feature. Including one of these nodes in the + Flow Graph may cause ``try_put_and_wait`` to exit early, even if the computations on the initial input message are + still in progress. + +API +*** + +Header +------ + +.. code:: cpp + + #define TBB_PREVIEW_FLOW_GRAPH_FEATURES // macro option 1 + #define TBB_PREVIEW_FLOW_GRAPH_TRY_PUT_AND_WAIT // macro option 2 + #include + +Synopsis +-------- + +.. code:: cpp + + namespace oneapi { + namespace tbb { + template + class continue_node { + public: + bool try_put_and_wait(const continue_msg& input); + }; // class continue_node + + template + class function_node { + public: + bool try_put_and_wait(const Input& input); + }; // class function_node + + template + class overwrite_node { + public: + bool try_put_and_wait(const T& input); + }; // class overwrite_node + + template + class write_once_node { + public: + bool try_put_and_wait(const T& input); + }; // class write_once_node + + template + class buffer_node { + public: + bool try_put_and_wait(const T& input); + }; // class buffer_node + + template + class queue_node { + public: + bool try_put_and_wait(const T& input); + }; // class queue_node + + template > + class priority_queue_node { + public: + bool try_put_and_wait(const T& input); + }; // class priority_queue_node + + template + class sequencer_node { + public: + bool try_put_and_wait(const T& input); + }; // class sequencer_node + + template + class limiter_node { + public: + bool try_put_and_wait(const T& input); + }; // class limiter_node + + template + class broadcast_node { + public: + bool try_put_and_wait(const T& input); + }; // class broadcast_node + + template + class split_node { + public: + bool try_put_and_wait(const TupleType& input); + }; // class split_node + } // namespace tbb + } // namespace oneapi + +Member Functions +---------------- + +.. code:: cpp + + template + bool continue_node::try_put_and_wait(const continue_msg& input) + +**Effects**: Increments the count of input signals received. If the incremented count is equal to the number +of known predecessors, performs the ``body`` function object execution. + +Waits for the completion of the ``input`` in the Flow Graph, meaning all tasks created by each node and +related to ``input`` are executed, and no related objects remain in any buffer within the graph. + +**Returns**: ``true``. + +.. code:: cpp + + template + bool function_node::try_put_and_wait(const Input& input) + +**Effects**: If the concurrency limit allows, executes the user-provided body on the incoming message ``input``. +Otherwise, depending on the ``Policy`` of the node, either queues the incoming message ``input`` or rejects it. + +Waits for the completion of the ``input`` in the Flow Graph, meaning all tasks created by each node and +related to ``input`` are executed, and no related objects remain in any buffer within the graph. + +**Returns**: ``true`` if the input is accepted, ``false`` otherwise. + +.. code:: cpp + + template + bool overwrite_node::try_put_and_wait(const T& input) + +**Effects**: Stores ``input`` in the internal single-item buffer and broadcasts it to all successors. + +Waits for the completion of the ``input`` in the Flow Graph, meaning all tasks created by each node and +related to ``input`` are executed, and no related objects remain in any buffer within the graph. + +**Returns**: ``true``. + +.. caution:: + + Since the input element is not retrieved from ``overwrite_node`` once accepted by the successor, + retrieve it by explicitly calling the ``clear()`` method or by overwriting with another element to prevent + ``try_put_and_wait`` from indefinite waiting. + +.. code:: cpp + + template + bool write_once_node::try_put_and_wait(const T& input) + +**Effects**: Stores ``input`` in the internal single-item buffer if it does not contain a valid value already. +If a new value is set, the node broadcasts it to all successors. + +Waits for the completion of the ``input`` in the Flow Graph, meaning all tasks created by each node and +related to ``input`` are executed, and no related objects remain in any buffer within the graph. + +**Returns**: ``true`` for the first time after construction or a call to ``clear()``. + +.. caution:: + + Since the input element is not retrieved from the ``write_once_node`` once accepted by the successor, + retrieve it by explicitly calling the ``clear()`` method to prevent ``try_put_and_wait`` from indefinite waiting. + +.. code:: cpp + + template + bool buffer_node::try_put_and_wait(const T& input) + +**Effects**: Adds ``input`` to the set of items managed by the node and tries forwarding it to a successor. + +Waits for the completion of the ``input`` in the Flow Graph, meaning all tasks created by each node and +related to ``input`` are executed, and no related objects remain in any buffer within the graph. + +**Returns**: ``true``. + +.. code:: cpp + + template + bool queue_node::try_put_and_wait(const T& input) + +**Effects**: Adds ``input`` to the set of items managed by the node and tries forwarding the least recently added item +to a successor. + +Waits for the completion of the ``input`` in the Flow Graph, meaning all tasks created by each node and +related to ``input`` are executed, and no related objects remain in any buffer within the graph. + +**Returns**: ``true``. + +.. code:: cpp + + template + bool priority_queue_node::try_put_and_wait(const T& input) + +**Effects**: Adds ``input`` to the ``priority_queue_node`` and attempts to forward the item with the highest +priority among all items added to the node but not yet forwarded to the successors. + +Waits for the completion of the ``input`` in the Flow Graph, meaning all tasks created by each node and +related to ``input`` are executed, and no related objects remain in any buffer within the graph. + +**Returns**: ``true``. + +.. code:: cpp + + template + bool sequencer_node::try_put_and_wait(const T& input) + +**Effects**: Adds ``input`` to the ``sequencer_node`` and tries forwarding the next item in sequence to a successor. + +Waits for the completion of the ``input`` in the Flow Graph, meaning all tasks created by each node and +related to ``input`` are executed, and no related objects remain in any buffer within the graph. + +**Returns**: ``true``. + +.. code:: cpp + + template + bool limiter_node::try_put_and_wait(const T& input) + +**Effects**: If the broadcast count is below the threshold, broadcasts ``input`` to all successors. + +Waits for the completion of the ``input`` in the Flow Graph, meaning all tasks created by each node and +related to ``input`` are executed, and no related objects remain in any buffer within the graph. + +**Returns**: ``true`` if ``input`` is broadcasted; ``false`` otherwise. + +.. code:: cpp + + template + bool broadcast_node::try_put_and_wait(const T& input) + +**Effects**: Broadcasts ``input`` to all successors. + +Waits for the completion of the ``input`` in the Flow Graph, meaning all tasks created by each node and +related to ``input`` are executed, and no related objects remain in any buffer within the graph. + +**Returns**: ``true`` even if the node cannot successfully forward the message to any of its successors. + +.. code:: cpp + + template + bool split_node::try_put_and_wait(const TupleType& input); + +**Effects**: Broadcasts each element in the incoming tuple to the nodes connected to the ``split_node`` output ports. +The element at index ``i`` of ``input`` is broadcasted through the output port number ``i``. + +Waits for the completion of the ``input`` in the Flow Graph, meaning all tasks created by each node and +related to ``input`` are executed, and no related objects remain in any buffer within the graph. + +**Returns**: ``true``. + +Example +******* + +.. code:: cpp + + #define TBB_PREVIEW_FLOW_GRAPH_TRY_PUT_AND_WAIT + #include + #include + + struct f1_body; + struct f2_body; + struct f3_body; + struct f4_body; + + int main() { + using namespace oneapi::tbb; + + flow::graph g; + flow::broadcast_node start_node(g); + + flow::function_node f1(g, flow::unlimited, f1_body{}); + flow::function_node f2(g, flow::unlimited, f2_body{}); + flow::function_node f3(g, flow::unlimited, f3_body{}); + + flow::join_node> join(g); + + flow::function_node, int> f4(g, flow::serial, f4_body{}); + + flow::make_edge(start_node, f1); + flow::make_edge(f1, f2); + + flow::make_edge(start_node, f3); + + flow::make_edge(f2, flow::input_port<0>(join)); + flow::make_edge(f3, flow::input_port<1>(join)); + + flow::make_edge(join, f4); + + // Submit work into the graph + parallel_for(0, 100, [](int input) { + start_node.try_put_and_wait(input); + + // Post processing the result of input + }); + } + +Each iteration of ``parallel_for`` submits an input into the Flow Graph. After returning from ``try_put_and_wait(input)``, it is +guaranteed that all of the work related to the completion of ``input`` is done by all of the nodes in the graph. Tasks related to inputs +submitted by other calls are not guaranteed to be completed. diff --git a/_sources/main/reference/type_specified_message_keys.rst b/_sources/main/reference/type_specified_message_keys.rst new file mode 100644 index 0000000000..a50cd7f434 --- /dev/null +++ b/_sources/main/reference/type_specified_message_keys.rst @@ -0,0 +1,69 @@ +.. _class_join_node_extension: + +Type-specified message keys for join_node +========================================= + +.. note:: + To enable this feature, define the ``TBB_PREVIEW_FLOW_GRAPH_FEATURES`` macro to 1. + +.. contents:: + :local: + :depth: 1 + +Description +*********** + +The extension allows a key matching ``join_node`` to obtain keys via functions associated with +its input types. The extension simplifies the existing approach by removing the need to +provide a function object for each input port of ``join_node``. + +API +*** + +Header +------ + +.. code:: cpp + + #include "oneapi/tbb/flow_graph.h" + +Syntax +------ + +The extension adds a special constructor to the ``join_node`` interface when the +``key_matching`` policy is +used. The constructor has the following signature: + +.. code:: cpp + + join_node( graph &g ) + +When constructed this way, a ``join_node`` calls the +``key_from_message`` function for each incoming message to obtain the key associated +with it. The default implementation of ``key_from_message`` is the following + +.. code:: cpp + + namespace oneapi { + namespace tbb { + namespace flow { + template + K key_from_message( const T &t ) { + return t.key(); + } + } + } + } + +``T`` is one of the user-provided types in ``OutputTuple`` and is +used to construct the ``join_node``, and ``K`` is the key type +of the node. +By default, the ``key()`` method defined in the message class will be called. +Alternatively, the user can define its own ``key_from_message`` function in the +same namespace with the message type. This function will be found via C++ argument-dependent +lookup and used in place of the default implementation. + +See Also +******** + +`join_node Specification `_ diff --git a/_sources/main/tbb_userguide/Advanced_Example.rst b/_sources/main/tbb_userguide/Advanced_Example.rst new file mode 100644 index 0000000000..1277754ea7 --- /dev/null +++ b/_sources/main/tbb_userguide/Advanced_Example.rst @@ -0,0 +1,96 @@ +.. _Advanced_Example: + +Advanced Example +================ + + +An example of a more advanced associative operation is to find the index +where ``Foo(i)`` is minimized. A serial version might look like this: + + +:: + + + long SerialMinIndexFoo( const float a[], size_t n ) { + float value_of_min = FLT_MAX; // FLT_MAX from + long index_of_min = -1; + for( size_t i=0; i& r ) { + const float *a = my_a; + for( size_t i=r.begin(); i!=r.end(); ++i ) { + float value = Foo(a[i]); + if( value + index_of_min(-1) + {} +   + + void join( const SumFoo& y ) { + if( y.value_of_min + index_of_min(-1), + {} + }; + + +Now ``SerialMinIndex`` can be rewritten using ``parallel_reduce`` as +shown below: + + +:: + + + long ParallelMinIndexFoo( float a[], size_t n ) { + MinIndexFoo mif(a); + parallel_reduce(blocked_range(0,n), mif ); + + + return mif.index_of_min; + } diff --git a/_sources/main/tbb_userguide/Advanced_Topic_Other_Kinds_of_Iteration_Spaces.rst b/_sources/main/tbb_userguide/Advanced_Topic_Other_Kinds_of_Iteration_Spaces.rst new file mode 100644 index 0000000000..99446ab659 --- /dev/null +++ b/_sources/main/tbb_userguide/Advanced_Topic_Other_Kinds_of_Iteration_Spaces.rst @@ -0,0 +1,111 @@ +.. _Advanced_Topic_Other_Kinds_of_Iteration_Spaces: + +Advanced Topic: Other Kinds of Iteration Spaces +=============================================== + + +The examples so far have used the class ``blocked_range`` to specify ranges. +This class is useful in many situations, but it does not fit every situation. +You can use |full_name| to define your own iteration space objects. The object +must specify how it can be split into subspaces by providing a basic splitting +constructor, an optional proportional splitting constructor, and two predicate +methods. If your class is called ``R``, the methods and constructors should be +as follows: + + +:: + + + class R { + // True if range is empty + bool empty() const; + // True if range can be split into non-empty subranges + bool is_divisible() const; + // Splits r into subranges r and *this + R( R& r, split ); + // (optional) Splits r into subranges r and *this in proportion p + R( R& r, proportional_split p ); + ... + }; + + + + +The method ``empty`` should return true if the range is empty. The +method ``is_divisible`` should return true if the range can be split +into two non-empty subspaces, and such a split is worth the overhead. +The basic splitting constructor should take two arguments: + + +- The first of type ``R`` + + +- The second of type oneapi::tbb::split + + +The second argument is not used; it serves only to distinguish the +constructor from an ordinary copy constructor. The basic splitting +constructor should attempt to split ``r`` roughly into two halves, and +update ``r`` to be the first half, and set the constructed object as the +second half. + + +Unlike the basic splitting constructor, the proportional splitting +constructor is optional and takes the second argument of type +``oneapi::tbb::proportional_split``. The type has methods ``left`` and ``right`` +that return the values of the proportion. These values should be used to +split ``r`` accordingly, so that the updated ``r`` corresponds to the +left part of the proportion, and the constructed object corresponds to +the right part. + + +Both splitting constructors should guarantee that the updated ``r`` part +and the constructed object are not empty. The parallel algorithm +templates call the splitting constructors on ``r`` only if +``r.is_divisible`` is true. + + +The iteration space does not have to be linear. Look at +``oneapi/tbb/blocked_range2d.h`` for an example of a range that is +two-dimensional. Its splitting constructor attempts to split the range +along its longest axis. When used with ``parallel_for``, it causes the +loop to be "recursively blocked" in a way that improves cache usage. +This nice cache behavior means that using ``parallel_for`` over a +``blocked_range2d`` can make a loop run faster than the sequential +equivalent, even on a single processor. + +The ``blocked_range2d`` allows you to use different value types for +its first dimension, *rows*, and the second one, *columns*. +That means you can combine indexes, pointers, and iterators into a joint +iteration space. Use the methods ``rows()`` and ``cols()`` to obtain +``blocked_range`` objects that represent the respective dimensions. + +The ``blocked_range3d`` class template extends this approach to 3D by adding +``pages()`` as the first dimension, followed by ``rows()`` and ``cols()``. + +The ``blocked_nd_range`` class template represents a blocked iteration +space of any dimensionality. Unlike the previously described 2D and 3D ranges, +``blocked_nd_range`` uses the same value type for all its axes, and its +constructor requires you to pass N instances of ``blocked_range`` instead of +individual boundary values. The change in the naming pattern reflects these +differences. + + +Example of a Multidimensional Iteration Space +------------------------------------------------ + +The example demonstrates calculation of a 3-dimensional filter over the pack +of feature maps. + +The ``convolution3d`` function iterates over the output cells, assigning to +each cell the result of the ``kernel3d`` function that combines the values +from a range in the feature maps. + +To run the computation in parallel, ``tbb::parallel_for`` is called with +``tbb::blocked_nd_range`` as an argument. The body function processes +the received 3D subrange in nested loops, using the method ``dim`` to get +the loop boundaries for each dimension. + + +.. literalinclude:: ./snippets/blocked_nd_range_example.h + :language: c++ diff --git a/_sources/main/tbb_userguide/Allocator_Configuration.rst b/_sources/main/tbb_userguide/Allocator_Configuration.rst new file mode 100644 index 0000000000..5d0c235ab0 --- /dev/null +++ b/_sources/main/tbb_userguide/Allocator_Configuration.rst @@ -0,0 +1,42 @@ +.. _Allocator_Configuration: + +Configuring the Memory Allocator +================================ + + +The oneTBB memory allocator provides the following API functions and +environment variables to configure its behavior: + + +- the ``scalable_allocation_command`` function instructs the allocator + to perform a certain action, such as cleaning up its internal memory + buffers. + + +- the ``scalable_allocation_mode`` function allows an application to + set certain parameters for the memory allocator, such as an option to + map memory in huge pages or define a recommended heap size. These + settings take effect until modified by another call to + ``scalable_allocation_mode``. + + +Some of the memory allocator parameters can also be set via system +environment variables. It can be useful to adjust the behavior without +modifying application source code, to ensure that a setting takes effect +as early as possible, or to avoid explicit dependency on the oneTBB +allocator binaries. The following environment variables are recognized: + + +- ``TBB_MALLOC_USE_HUGE_PAGES`` controls usage of huge pages for memory + mapping. + + +- ``TBB_MALLOC_SET_HUGE_OBJECT_THRESHOLD`` defines the lower bound for + the size (bytes), that is interpreted as huge and not released during + regular cleanup operations. + + +These variables only take effect at the time the memory manager is +initialized; later environment changes are ignored. A call to +``scalable_allocation_mode`` overrides the effect of the corresponding +environment variable. diff --git a/_sources/main/tbb_userguide/Automatic_Chunking.rst b/_sources/main/tbb_userguide/Automatic_Chunking.rst new file mode 100644 index 0000000000..54ea2df807 --- /dev/null +++ b/_sources/main/tbb_userguide/Automatic_Chunking.rst @@ -0,0 +1,23 @@ +.. _Automatic_Chunking: + +Automatic Chunking +================== + + +A parallel loop construct incurs overhead cost for every chunk of work +that it schedules. |full_name| +chooses chunk sizes automatically, depending upon load balancing +needs. The heuristic attempts to limit overheads while +still providing ample opportunities for load balancing. + + +.. CAUTION:: + Typically a loop needs to take at least a million clock cycles to + make it worth using ``parallel_for``. For example, a loop that takes + at least 500 microseconds on a 2 GHz processor might benefit from + ``parallel_for``. + + +The default automatic chunking is recommended for most uses. As with +most heuristics, however, there are situations where controlling the +chunk size more precisely might yield better performance. diff --git a/_sources/main/tbb_userguide/Bandwidth_and_Cache_Affinity_os.rst b/_sources/main/tbb_userguide/Bandwidth_and_Cache_Affinity_os.rst new file mode 100644 index 0000000000..274b220a2a --- /dev/null +++ b/_sources/main/tbb_userguide/Bandwidth_and_Cache_Affinity_os.rst @@ -0,0 +1,107 @@ +.. _Bandwidth_and_Cache_Affinity: + +Bandwidth and Cache Affinity +============================ + + +For a sufficiently simple function ``Foo``, the examples might not show +good speedup when written as parallel loops. The cause could be +insufficient system bandwidth between the processors and memory. In that +case, you may have to rethink your algorithm to take better advantage of +cache. Restructuring to better utilize the cache usually benefits the +parallel program as well as the serial program. + + +An alternative to restructuring that works in some cases is +``affinity_partitioner.`` It not only automatically chooses the +grainsize, but also optimizes for cache affinity and tries to distribute +the data uniformly among threads. Using ``affinity_partitioner`` can +significantly improve performance when: + + +- The computation does a few operations per data access. + + +- The data acted upon by the loop fits in cache. + + +- The loop, or a similar loop, is re-executed over the same data. + + +- There are more than two hardware threads available (and especially if + the number of threads is not a power of two). If only two threads are + available, the default scheduling in |full_name| + usually provides sufficient cache affinity. + + +The following code shows how to use ``affinity_partitioner``. + + +:: + + + #include "oneapi/tbb.h" +   + + void ParallelApplyFoo( float a[], size_t n ) { + static affinity_partitioner ap; + parallel_for(blocked_range(0,n), ApplyFoo(a), ap); + } +   + + void TimeStepFoo( float a[], size_t n, int steps ) { + for( int t=0; tcancel_group_execution()``. +The part ``current_context()`` references the ``task_group_context*`` of the currently executing task if any on the current thread. +Calling ``cancel_group_execution()`` cancels all tasks in its ``task_group_context``, which is explained in more detail in :ref:`Cancellation_and_Nested_Parallelism`. +The method returns ``true`` if it actually causes cancellation, ``false`` if the ``task_group_context`` was already cancelled. + +The example below shows how to use ``current_context()->cancel_group_execution()``. + +:: + + #include "oneapi/tbb.h" + + #include + #include +   + using namespace oneapi::tbb; + using namespace std; +   + vector Data; +   + struct Update { + void operator()( const blocked_range& r ) const { + for( int i=r.begin(); i!=r.end(); ++i ) + if( icancel_group_execution() ) + cout << "Index " << i << " caused cancellation\n"; + return; + } + } + }; +   + + int main() { + Data.resize(1000); + parallel_for( blocked_range(0, 2000), Update()); + return 0; + } + diff --git a/_sources/main/tbb_userguide/Cancellation_and_Nested_Parallelism.rst b/_sources/main/tbb_userguide/Cancellation_and_Nested_Parallelism.rst new file mode 100644 index 0000000000..28ceca64d0 --- /dev/null +++ b/_sources/main/tbb_userguide/Cancellation_and_Nested_Parallelism.rst @@ -0,0 +1,136 @@ +.. _Cancellation_and_Nested_Parallelism: + +Cancellation and Nested Parallelism +=================================== + + +The discussion so far was simplified by assuming non-nested parallelism +and skipping details of ``task_group_context``. This topic explains +both. + + +An |full_name| algorithm executes +by creating ``task`` objects that execute the snippets of code that you +supply to the algorithm template. By default, these ``task`` objects are +associated with a ``task_group_context`` created by the algorithm. +Nested oneTBB algorithms create a tree of these ``task_group_context`` +objects. Cancelling a ``task_group_context`` cancels all of its child +``task_group_context`` objects, and transitively all its descendants. +Hence an algorithm and all algorithms it called can be cancelled with a +single request. + + +Exceptions propagate upwards. Cancellation propagates downwards. The +opposition interplays to cleanly stop a nested computation when an +exception occurs. For example, consider the tree in the following +figure. Imagine that each node represents an algorithm and its +``task_group_context``. + + +.. container:: fignone + :name: fig6 + + + Tree of task_group_context + |image0| + + +Suppose that the algorithm in C throws an exception and no node catches +the exception. oneTBB propagates the exception upwards, cancelling +related subtrees downwards, as follows: + + +#. Handle exception in C: + + + a. Capture exception in C. + + + b. Cancel tasks in C. + + + c. Throw exception from C to B. + + +#. Handle exception in B: + + + a. Capture exception in B. + + + b. Cancel tasks in B and, by downwards propagation, in D. + + + c. Throw an exception out of B to A. + + +#. Handle exception in A: + + + a. Capture exception in A. + + + b. Cancel tasks in A and, by downwards propagation, in E, F, and G. + + + c. Throw an exception upwards out of A. + + +If your code catches the exception at any level, then oneTBB does not +propagate it any further. For example, an exception that does not escape +outside the body of a ``parallel_for`` does not cause cancellation of +other iterations. + + +To prevent downwards propagation of cancellation into an algorithm, +construct an 'isolated' ``task_group_context`` on the stack and pass it +to the algorithm explicitly. The example uses C++11 lambda expressions for brevity. + + +:: + + + #include "oneapi/tbb.h" +   + + bool Data[1000][1000]; +   + + int main() { + try { + parallel_for( 0, 1000, 1, + []( int i ) { + task_group_context root(task_group_context::isolated); + parallel_for( 0, 1000, 1, + []( int ) { + Data[i][j] = true; + }, + root); + throw "oops"; + }); + } catch(...) { + } + return 0; + } + + +The example performs two parallel loops: an outer loop over ``i`` and +inner loop over ``j``. The creation of the isolated +``task_group_context`` ``root`` protects the inner loop from downwards +propagation of cancellation from the ``i`` loop. When the exception +propagates to the outer loop, any pending ``outer`` iterations are +cancelled, but not inner iterations for an outer iteration that started. +Hence when the program completes, each row of ``Data`` may be different, +depending upon whether its iteration ``i`` ran at all, but within a row, +the elements will be homogeneously ``false`` or ``true``, not a mixture. + + +Removing the blue text would permit cancellation to propagate down into +the inner loop. In that case, a row of ``Data`` might end up with both +``true`` and ``false`` values. + + +.. |image0| image:: Images/image013.jpg + :width: 261px + :height: 131px + diff --git a/_sources/main/tbb_userguide/Concurrent_Queue_Classes.rst b/_sources/main/tbb_userguide/Concurrent_Queue_Classes.rst new file mode 100644 index 0000000000..566ef505dd --- /dev/null +++ b/_sources/main/tbb_userguide/Concurrent_Queue_Classes.rst @@ -0,0 +1,108 @@ +.. _Concurrent_Queue_Classes: + +Concurrent Queue Classes +======================== + + +Template class ``concurrent_queue`` implements a concurrent +queue with values of type ``T``. Multiple threads may simultaneously +push and pop elements from the queue. The queue is unbounded and has no +blocking operations. The fundamental operations on it are ``push`` and +``try_pop``. The ``push`` operation works just like ``push`` for a +std::queue. The operation ``try_pop`` pops an item if it is available. +The check and popping have to be done in a single operation for sake of +thread safety. + + +For example, consider the following serial code: + + +:: + + + extern std::queue MySerialQueue; + T item; + if( !MySerialQueue.empty() ) { + item = MySerialQueue.front(); + MySerialQueue.pop_front(); + ... process item... + } + + +Even if each std::queue method were implemented in a thread-safe manner, +the composition of those methods as shown in the example would not be +thread safe if there were other threads also popping from the same +queue. For example, ``MySerialQueue.empty()`` might return true just +before another thread snatches the last item from ``MySerialQueue``. + + +The equivalent thread-safe |full_name| code is: + + +:: + + + extern concurrent_queue MyQueue; + T item; + if( MyQueue.try_pop(item) ) { + ...process item... + } + + +In a single-threaded program, a queue is a first-in first-out structure. +But if multiple threads are pushing and popping concurrently, the +definition of "first" is uncertain. Use of ``concurrent_queue`` +guarantees that if a thread pushes two values, and another thread pops +those two values, they will be popped in the same order that they were +pushed. + + +Template class ``concurrent_queue`` is unbounded and has no methods that +wait. It is up to the user to provide synchronization to avoid overflow, +or to wait for the queue to become non-empty. Typically this is +appropriate when the synchronization has to be done at a higher level. + + +Template class ``concurrent_bounded_queue`` is a variant that +adds blocking operations and the ability to specify a capacity. The +methods of particular interest on it are: + + +- ``pop(item)`` waits until it can succeed. + + +- ``push(item)`` waits until it can succeed without exceeding the + queue's capacity. + + +- ``try_push(item)`` pushes ``item`` only if it would not exceed the + queue's capacity. + + +- size() returns a *signed* integer. + + +The value of concurrent_queue::size() is defined as the number of push +operations started minus the number of pop operations started. If pops +outnumber pushes, ``size()`` becomes negative. For example, if a +``concurrent_queue`` is empty, and there are ``n`` pending pop +operations, ``size()`` returns -\ ``n``. This provides an easy way for +producers to know how many consumers are waiting on the queue. Method +``empty()`` is defined to be true if and only if ``size()`` is not +positive. + + +By default, a ``concurrent_bounded_queue`` is unbounded. It may hold any +number of values, until memory runs out. It can be bounded by setting +the queue capacity with method ``set_capacity``.Setting the capacity +causes ``push`` to block until there is room in the queue. Bounded +queues are slower than unbounded queues, so if there is a constraint +elsewhere in your program that prevents the queue from becoming too +large, it is better not to set the capacity. If you do not need the +bounds or the blocking pop, consider using ``concurrent_queue`` instead. + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/Iterating_Over_a_Concurrent_Queue_for_Debugging + ../tbb_userguide/When_Not_to_Use_Queues \ No newline at end of file diff --git a/_sources/main/tbb_userguide/Constraints.rst b/_sources/main/tbb_userguide/Constraints.rst new file mode 100644 index 0000000000..1928fe8eeb --- /dev/null +++ b/_sources/main/tbb_userguide/Constraints.rst @@ -0,0 +1,30 @@ +.. _Constraints: + +Constrained APIs +================ + +Starting from C++20, most of |full_name| APIs are constrained to +enforce `named requirements `_ on +template arguments types. + +The violations of these requirements are detected at a compile time during the template instantiation. + +.. rubric:: Example + +.. code:: cpp + + // Call for body(oneapi::tbb::blocked_range) is ill-formed + // oneapi::tbb::parallel_for call results in constraint failure + auto body = [](const int& r) { /*...*/ }; + oneapi::tbb::parallel_for(oneapi::tbb::blocked_range{1, 10}, body); + + // Error example: + // error: no matching function to call to oneapi::tbb::parallel_for + // note: constraints not satisfied + // note: the required expression 'body(range)' is invalid + body(range); + +.. caution:: + + The code that violates named requirements but compiles successfully until C++20, + may not compile in C++20 mode due to early and strict constraints diagnostics. diff --git a/_sources/main/tbb_userguide/Containers.rst b/_sources/main/tbb_userguide/Containers.rst new file mode 100644 index 0000000000..aa815ffeeb --- /dev/null +++ b/_sources/main/tbb_userguide/Containers.rst @@ -0,0 +1,55 @@ +.. _Containers: + +Containers +========== + + +|full_name| provides highly concurrent +container classes. These containers can be used with raw Windows\* OS or +Linux\* OS threads, or in conjunction with task-based programming. + + +A concurrent container allows multiple threads to concurrently access +and update items in the container. Typical C++ STL containers do not +permit concurrent update; attempts to modify them concurrently often +result in corrupting the container. STL containers can be wrapped in a +mutex to make them safe for concurrent access, by letting only one +thread operate on the container at a time, but that approach eliminates +concurrency, thus restricting parallel speedup. + + +Containers provided by oneTBB offer a much higher level of concurrency, +via one or both of the following methods: + + +- **Fine-grained locking:** Multiple threads operate on the container + by locking only those portions they really need to lock. As long as + different threads access different portions, they can proceed + concurrently. + + +- **Lock-free techniques:** Different threads account and correct for + the effects of other interfering threads. + + +Notice that highly-concurrent containers come at a cost. They typically +have higher overheads than regular STL containers. Operations on +highly-concurrent containers may take longer than for STL containers. +Therefore, use highly-concurrent containers when the speedup from the +additional concurrency that they enable outweighs their slower +sequential performance. + + +.. CAUTION:: + As with most objects in C++, the constructor or destructor of a + container object must not be invoked concurrently with another + operation on the same object. Otherwise the resulting race may cause + the operation to be executed on an undefined object. + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/concurrent_hash_map + ../tbb_userguide/concurrent_vector_ug + ../tbb_userguide/Concurrent_Queue_Classes + ../tbb_userguide/Summary_of_Containers diff --git a/_sources/main/tbb_userguide/Controlling_Chunking_os.rst b/_sources/main/tbb_userguide/Controlling_Chunking_os.rst new file mode 100644 index 0000000000..999419d298 --- /dev/null +++ b/_sources/main/tbb_userguide/Controlling_Chunking_os.rst @@ -0,0 +1,170 @@ +.. _Controlling_Chunking: + +Controlling Chunking +==================== + + +Chunking is controlled by a *partitioner* and a *grainsize.*\ To gain +the most control over chunking, you specify both. + + +- Specify ``simple_partitioner()`` as the third argument to + ``parallel_for``. Doing so turns off automatic chunking. + + +- Specify the grainsize when constructing the range. The thread + argument form of the constructor is + ``blocked_range(begin,end,grainsize)``. The default value of + ``grainsize`` is 1. It is in units of loop iterations per chunk. + + +If the chunks are too small, the overhead may exceed the performance +advantage. + + +The following code is the last example from parallel_for, modified to +use an explicit grainsize ``G``. + + +:: + + + #include "oneapi/tbb.h" +   + + void ParallelApplyFoo( float a[], size_t n ) { + parallel_for(blocked_range(0,n,G), ApplyFoo(a), + simple_partitioner()); + } + + +The grainsize sets a minimum threshold for parallelization. The +``parallel_for`` in the example invokes ``ApplyFoo::operator()`` on +chunks, possibly of different sizes. Let *chunksize* be the number of +iterations in a chunk. Using ``simple_partitioner`` guarantees that +[G/2] <= *chunksize* <= G. + + +There is also an intermediate level of control where you specify the +grainsize for the range, but use an ``auto_partitioner`` and +``affinity_partitioner``. An ``auto_partitioner`` is the default +partitioner. Both partitioners implement the automatic grainsize +heuristic described in :ref:`Automatic_Chunking`. An +``affinity_partitioner`` implies an additional hint, as explained later +in Section :ref:`Bandwidth_and_Cache_Affinity`. Though these partitioners +may cause chunks to have more than G iterations, they never generate +chunks with less than [G/2] iterations. Specifying a range with an +explicit grainsize may occasionally be useful to prevent these +partitioners from generating wastefully small chunks if their heuristics +fail. + + +Because of the impact of grainsize on parallel loops, it is worth +reading the following material even if you rely on ``auto_partitioner`` +and ``affinity_partitioner`` to choose the grainsize automatically. + + +.. container:: tablenoborder + + + .. list-table:: + :header-rows: 1 + + * - |image0| + - |image1| + * - Case A + - Case B + + + + +The above figure illustrates the impact of grainsize by showing the +useful work as the gray area inside a brown border that represents +overhead. Both Case A and Case B have the same total gray area. Case A +shows how too small a grainsize leads to a relatively high proportion of +overhead. Case B shows how a large grainsize reduces this proportion, at +the cost of reducing potential parallelism. The overhead as a fraction +of useful work depends upon the grainsize, not on the number of grains. +Consider this relationship and not the total number of iterations or +number of processors when setting a grainsize. + + +A rule of thumb is that ``grainsize`` iterations of ``operator()`` +should take at least 100,000 clock cycles to execute. For example, if a +single iteration takes 100 clocks, then the ``grainsize`` needs to be at +least 1000 iterations. When in doubt, do the following experiment: + + +#. Set the ``grainsize`` parameter higher than necessary. The grainsize + is specified in units of loop iterations. If you have no idea of how + many clock cycles an iteration might take, start with + ``grainsize``\ =100,000. The rationale is that each iteration + normally requires at least one clock per iteration. In most cases, + step 3 will guide you to a much smaller value. + + +#. Run your algorithm. + + +#. Iteratively halve the ``grainsize`` parameter and see how much the + algorithm slows down or speeds up as the value decreases. + + +A drawback of setting a grainsize too high is that it can reduce +parallelism. For example, if the grainsize is 1000 and the loop has 2000 +iterations, the ``parallel_for`` distributes the loop across only two +processors, even if more are available. However, if you are unsure, err +on the side of being a little too high instead of a little too low, +because too low a value hurts serial performance, which in turns hurts +parallel performance if there is other parallelism available higher up +in the call tree. + + +.. tip:: + You do not have to set the grainsize too precisely. + + +The next figure shows the typical "bathtub curve" for execution time +versus grainsize, based on the floating point ``a[i]=b[i]*c`` +computation over a million indices. There is little work per iteration. +The times were collected on a four-socket machine with eight hardware +threads. + + +.. container:: fignone + :name: fig2 + + + Wall Clock Time Versus Grainsize + |image2| + + +The scale is logarithmic. The downward slope on the left side indicates +that with a grainsize of one, most of the overhead is parallel +scheduling overhead, not useful work. An increase in grainsize brings a +proportional decrease in parallel overhead. Then the curve flattens out +because the parallel overhead becomes insignificant for a sufficiently +large grainsize. At the end on the right, the curve turns up because the +chunks are so large that there are fewer chunks than available hardware +threads. Notice that a grainsize over the wide range 100-100,000 works +quite well. + + +.. tip:: + A general rule of thumb for parallelizing loop nests is to + parallelize the outermost one possible. The reason is that each + iteration of an outer loop is likely to provide a bigger grain of + work than an iteration of an inner loop. + + + +.. |image0| image:: Images/image002.jpg + :width: 161px + :height: 163px +.. |image1| image:: Images/image004.jpg + :width: 157px + :height: 144px +.. |image2| image:: Images/image006.jpg + :width: 462px + :height: 193px + diff --git a/_sources/main/tbb_userguide/Cook_Until_Done_parallel_do.rst b/_sources/main/tbb_userguide/Cook_Until_Done_parallel_do.rst new file mode 100644 index 0000000000..1ef6b61b48 --- /dev/null +++ b/_sources/main/tbb_userguide/Cook_Until_Done_parallel_do.rst @@ -0,0 +1,84 @@ +.. _Cook_Until_Done_parallel_do: + +Cook Until Done: parallel_for_each +================================== + + +For some loops, the end of the iteration space is not known in advance, +or the loop body may add more iterations to do before the loop exits. +You can deal with both situations using the template class ``oneapi::tbb::parallel_for_each``. + + +A linked list is an example of an iteration space that is not known in +advance. In parallel programming, it is usually better to use dynamic +arrays instead of linked lists, because accessing items in a linked list +is inherently serial. But if you are limited to linked lists, the items +can be safely processed in parallel, and processing each item takes at +least a few thousand instructions, you can use ``parallel_for_each`` to +gain some parallelism. + + +For example, consider the following serial code: + + +:: + + + void SerialApplyFooToList( const std::list& list ) { + for( std::list::const_iterator i=list.begin() i!=list.end(); ++i ) + Foo(*i); + } + + +If ``Foo`` takes at least a few thousand instructions to run, you can +get parallel speedup by converting the loop to use +``parallel_for_each``. To do so, define an object with a ``const`` +qualified ``operator()``. This is similar to a C++ function object from +the C++ standard header ````, except that ``operator()`` +must be ``const``. + + +:: + + + class ApplyFoo { + public: + void operator()( Item& item ) const { + Foo(item); + } + }; + + +The parallel form of ``SerialApplyFooToList`` is as follows: + + +:: + + + void ParallelApplyFooToList( const std::list& list ) { + parallel_for_each( list.begin(), list.end(), ApplyFoo() ); + } + + +An invocation of ``parallel_for_each`` never causes two threads to act +on an input iterator concurrently. Thus typical definitions of input +iterators for sequential programs work correctly. This convenience makes +``parallel_for_each`` unscalable, because the fetching of work is +serial. But in many situations, you still get useful speedup over doing +things sequentially. + + +There are two ways that ``parallel_for_each`` can acquire work scalably. + + +- The iterators can be random-access iterators. + + +- The body argument to ``parallel_for_each``, if it takes a second + argument *feeder* of type ``parallel_for_each&``, can add more + work by calling ``feeder.add(item)``. For example, suppose processing + a node in a tree is a prerequisite to processing its descendants. + With ``parallel_for_each``, after processing a node, you could use + ``feeder.add`` to add the descendant nodes. The instance of + ``parallel_for_each`` does not terminate until all items have been + processed. diff --git a/_sources/main/tbb_userguide/Data_Flow_Graph.rst b/_sources/main/tbb_userguide/Data_Flow_Graph.rst new file mode 100644 index 0000000000..a8d1aa715b --- /dev/null +++ b/_sources/main/tbb_userguide/Data_Flow_Graph.rst @@ -0,0 +1,198 @@ +.. _Data_Flow_Graph: + +Data Flow Graph +=============== + + +In a data flow graph, nodes are computations that send and receive data +messages. Some nodes may only send messages, others may only receive +messages, and others may send messages in response to messages that they +receive. + + +In the following data flow graph, the left-most node generates the +integer values from 1 to 10 and passes them to two successor nodes. One +of the successors squares each value it receives and passes the result +downstream. The second successor cubes each value it receives and passes +the result downstream. The right-most node receives values from both of +the middle nodes. As it receives each value, it adds it to a running sum +of values. When the application is run to completion, the value of sum +will be equal to the sum of the sequence of squares and cubes from 1 to +10. + + +.. container:: fignone + :name: simple_data_flow_title + + + Simple Data Flow Graph + + + .. container:: imagecenter + + + |image0| + + +The following code snippet shows an implementation of the **Simple Data +Flow Graph** shown above: + + +:: + + + int sum = 0; + graph g; + function_node< int, int > squarer( g, unlimited, [](const int &v) { + return v*v; + } ); + function_node< int, int > cuber( g, unlimited, [](const int &v) { + return v*v*v; + } ); + function_node< int, int > summer( g, 1, [&](const int &v ) -> int { + return sum += v; + } ); + make_edge( squarer, summer ); + make_edge( cuber, summer ); + + + for ( int i = 1; i <= 10; ++i ) { + squarer.try_put(i); + cuber.try_put(i); + } + g.wait_for_all(); + + + cout << "Sum is " << sum << "\n"; + + +In the implementation above, the following function_nodes are created: + + +- one to square values +- one to cube values +- one to add values to the global sum + + +Since the squarer and cuber nodes are side-effect free, they are created +with an unlimited concurrency. The summer node updates the sum through a +reference to a global variable and therefore is not safe to execute in +parallel. It is therefore created with a concurrency limit of 1. The +node F from **Simple Data Flow Graph** above is implemented as a loop +that puts messages to both the squarer and cuber node. + + +A slight improvement over the first implementation is to introduce an +additional node type, a ``broadcast_node``. A ``broadcast_node`` broadcasts any +message it receives to all of its successors. + + +This enables replacing the two ``try_put``'s in the loop with a single +``try_put``: + + +:: + + + broadcast_node b(g); + make_edge( b, squarer ); + make_edge( b, cuber ); + for ( int i = 1; i <= 10; ++i ) { + b.try_put(i); + } + g.wait_for_all(); + + +An even better option, which will make the implementation even more like +the **Simple Data Flow Graph** above, is to introduce an ``input_node``. An +``input_node``, as the name implies only sends messages and does not +receive messages. Its constructor takes two arguments: + + +:: + + + template< typename Body > input_node( graph &g, Body body) + +The body is a function object, or lambda expression, that contains a +function operator: + + +:: + + + Output Body::operator()( oneapi::tbb::flow_control &fc ); + + +You can replace the loop in the example with an ``input_node`` + + +:: + + + input_node< int > src( g, src_body(10) ); + make_edge( src, squarer ); + make_edge( src, cuber ); + src.activate(); + g.wait_for_all(); + + +The runtime library will repeatedly invoke the function operator in +``src_body`` until ``fc.stop()`` is invoked inside the body. You therefore +need to create body that will act like the body of the loop in the **Simple Data Flow Graph** +above. The final implementation after all of these changes is shown +below: + + +:: + + + class src_body { + const int my_limit; + int my_next_value; + public: + src_body(int l) : my_limit(l), my_next_value(1) {} + int operator()( oneapi::tbb::flow_control& fc ) { + if ( my_next_value <= my_limit ) { + return my_next_value++; + } else { + fc.stop(); + return int(); + } + } + }; + + + int main() { + int sum = 0; + graph g; + function_node< int, int > squarer( g, unlimited, [](const int &v) { + return v*v; + } ); + function_node< int, int > cuber( g, unlimited, [](const int &v) { + return v*v*v; + } ); + function_node< int, int > summer( g, 1, [&](const int &v ) -> int { + return sum += v; + } ); + make_edge( squarer, summer ); + make_edge( cuber, summer ); + input_node< int > src( g, src_body(10) ); + make_edge( src, squarer ); + make_edge( src, cuber ); + src.activate(); + g.wait_for_all(); + cout << "Sum is " << sum << "\n"; + } + + +This final implementation has all of the nodes and edges from the +**Simple Data Flow Graph** above. In this simple example, there is not +much advantage in using an ``input_node`` over an explicit loop. But, +because an ``input_node`` is able to react to the behavior of downstream +nodes, it can limit memory use in more complex graphs. For more +information, see:ref:`create_token_based_system` . + + +.. |image0| image:: Images/flow_graph.jpg + diff --git a/_sources/main/tbb_userguide/Debug_Versus_Release_Libraries.rst b/_sources/main/tbb_userguide/Debug_Versus_Release_Libraries.rst new file mode 100644 index 0000000000..654724615f --- /dev/null +++ b/_sources/main/tbb_userguide/Debug_Versus_Release_Libraries.rst @@ -0,0 +1,56 @@ +.. _Debug_Versus_Release_Libraries: + +Debug Versus Release Libraries +============================== + + +The following table details the |full_name| +dynamic shared libraries that come in debug and release +versions. + + +.. container:: tablenoborder + + + .. list-table:: + :header-rows: 1 + + * - Library + - Description + - When to Use + * - | ``tbb_debug`` + | ``tbbmalloc_debug`` + | ``tbbmalloc_proxy_debug`` + | ``tbbbind_debug`` + - These versions have extensive internal checking for correct use of the library. + - Use with code that is compiled with the macro ``TBB_USE_DEBUG`` set to 1. + * - | ``tbb`` + | ``tbbmalloc`` + | ``tbbmalloc_proxy`` + | ``tbbbind`` + - These versions deliver top performance. They eliminate most checking for correct use of the library. + - Use with code compiled with ``TBB_USE_DEBUG`` undefined or set to zero. + +.. tip:: + Test your programs with the debug versions of the libraries first, to + assure that you are using the library correctly.  With the release + versions, incorrect usage may result in unpredictable program + behavior. + + +oneTBB supports Intel® Inspector, Intel® VTune™ Profiler and Intel® Advisor. +Full support of these tools requires compiling with macro ``TBB_USE_PROFILING_TOOLS=1``. +That symbol defaults to 1 in the following conditions: + +- When ``TBB_USE_DEBUG=1``. +- On the Microsoft Windows\* operating system, when ``_DEBUG=1``. + +The :ref:`reference` section explains the default values in more detail. + + +.. CAUTION:: + The instrumentation support for Intel® Inspector becomes live after + the first initialization of the task library. If the library + components are used before this initialization occurs, Intel® Inspector + may falsely report race conditions that are not really races. + diff --git a/_sources/main/tbb_userguide/Dependence_Graph.rst b/_sources/main/tbb_userguide/Dependence_Graph.rst new file mode 100644 index 0000000000..bbe0245052 --- /dev/null +++ b/_sources/main/tbb_userguide/Dependence_Graph.rst @@ -0,0 +1,147 @@ +.. _Dependence_Graph: + +Dependence Graph +================ + + +In a dependence graph, the nodes invoke body objects to perform +computations and the edges create a partial ordering of these +computations. At runtime, the library spawns and schedules tasks to +execute the body objects when it is legal to do so according to the +specified partial ordering. The following figure shows an example of an +application that could be expressed using a dependence graph. + + +.. container:: fignone + :name: dependence_graph_make_sandwitch + + + Dependence Graph for Making a Sandwich + + + .. container:: imagecenter + + + |image0| + + +Dependence graphs are a special case of data flow graphs, where the data +passed between nodes are of type oneapi::tbb::flow::continue_msg. Unlike a +general data flow graph, nodes in a dependence graph do not spawn a task +for each message they receive. Instead, they are aware of the number of +predecessors they have, count the messages they receive and only spawn a +task to execute their body when this count is equal to the total number +of their predecessors. + + +The following figure shows another example of a dependence graph. It has +the same topology as the figure above, but with simple functions +replacing the sandwich making steps. In this partial ordering, function +A must complete executing before any other computation starts executing. +Function B must complete before C and D start executing; and E must +complete before D and F start executing. This is a partial ordering +because, for example, there is no explicit ordering requirement between +B and E or C and F. + + +.. container:: fignone + :name: simple_dependence_graph + + + Simple Dependence Graph + + + .. container:: imagecenter + + + |image1| + + +To implement this as a flow graph, continue_node objects are used for +the nodes and continue_msg objects as the messages. A continue_node +constructor takes two arguments: + + +:: + + + template< typename Body > continue_node( graph &g, Body body) + + +The first argument is the graph it belongs to and the second is a +function object or lambda expression. Unlike a function_node, a +continue_node is always assumed to have unlimited concurrency and will +immediately spawn a task whenever its dependencies are met. + + +The following code snippet is an implementation of the example in this +figure. + + +:: + + + typedef continue_node< continue_msg > node_t; + typedef const continue_msg & msg_t; + + + int main() { + oneapi::tbb::flow::graph g; + node_t A(g, [](msg_t){ a(); } ); + node_t B(g, [](msg_t){ b(); } ); + node_t C(g, [](msg_t){ c(); } ); + node_t D(g, [](msg_t){ d(); } ); + node_t E(g, [](msg_t){ e(); } ); + node_t F(g, [](msg_t){ f(); } ); + make_edge(A, B); + make_edge(B, C); + make_edge(B, D); + make_edge(A, E); + make_edge(E, D); + make_edge(E, F); + A.try_put( continue_msg() ); + g.wait_for_all(); + return 0; + } + + +One possible execution of this graph is shown below. The execution of D +does not start until both B and E are finished. While a task is waiting +in the wait_for_all, its thread can participate in executing other tasks +from the oneTBB work pool. + + +.. container:: fignone + + + Execution Timeline for a Dependence Graph + + + .. container:: imagecenter + + + |image2| + + +Again, it is important to note that all execution in the flow graph +happens asynchronously. The call to A.try_put returns control to the +calling thread quickly, after incrementing the counter and spawning a +task to execute the body of A. Likewise, the body tasks execute the +lambda expressions and then put a continue_msg to all successor nodes, +if any. Only the call to wait_for_all blocks, as it should, and even in +this case the calling thread may be used to execute tasks from the +oneTBB work pool while it is waiting. + + +The above timeline shows the sequence when there are enough threads to +execute all of the tasks that can be executed concurrently in parallel. +If there are fewer threads, then some tasks that are spawned will need +to wait until a thread is available to execute them. + + +.. |image0| image:: Images/flow_graph_complex.jpg + :width: 440px + :height: 337px +.. |image1| image:: Images/dependence_graph.jpg +.. |image2| image:: Images/execution_timeline_dependence.jpg + diff --git a/_sources/main/tbb_userguide/Edges.rst b/_sources/main/tbb_userguide/Edges.rst new file mode 100644 index 0000000000..ea4c214b06 --- /dev/null +++ b/_sources/main/tbb_userguide/Edges.rst @@ -0,0 +1,46 @@ +.. _Edges: + +Flow Graph Basics: Edges +======================== + + +Most applications contain multiple nodes with edges connecting them to +each other. In the flow graph interface, edges are directed channels +over which messages are passed. They are created by calling the function +``make_edge( p, s )`` with two arguments: ``p``, the predecessor, and ``s``, the +successor. You can modify the example used in the **Nodes** topic to +include a second node that squares the value it receives before printing +it and then connect that to the first node with an edge. + + +:: + + + graph g; + function_node< int, int > n( g, unlimited, []( int v ) -> int { + cout << v; + spin_for( v ); + cout << v; + return v; + } ); + function_node< int, int > m( g, 1, []( int v ) -> int { + v *= v; + cout << v; + spin_for( v ); + cout << v; + return v; + } ); + make_edge( n, m ); + n.try_put( 1 ); + n.try_put( 2 ); + n.try_put( 3 ); + g.wait_for_all(); + + +Now there are two ``function_node`` ``s``, ``n`` and ``m``. The call to ``make_edge`` creates +an edge from ``n`` to ``m``. The node ``n`` is created with unlimited concurrency, +while ``m`` has a concurrency limit of 1. The invocations of ``n`` can all +proceed in parallel, while the invocations of ``m`` will be serialized. +Because there is an edge from ``n`` to ``m``, each value ``v``, returned by ``n``, will +be automatically passed to node ``m`` by the runtime library. + diff --git a/_sources/main/tbb_userguide/Exceptions_and_Cancellation.rst b/_sources/main/tbb_userguide/Exceptions_and_Cancellation.rst new file mode 100644 index 0000000000..290f2f2cc3 --- /dev/null +++ b/_sources/main/tbb_userguide/Exceptions_and_Cancellation.rst @@ -0,0 +1,76 @@ +.. _Exceptions_and_Cancellation: + +Exceptions and Cancellation +=========================== + + +|full_name| supports exceptions and +cancellation. When code inside an oneTBB algorithm throws an exception, +the following steps generally occur: + + +#. The exception is captured. Any further exceptions inside the + algorithm are ignored. + + +#. The algorithm is cancelled. Pending iterations are not executed. If + there is oneTBB parallelism nested inside, the nested parallelism may + also be cancelled as explained in :ref:`Cancellation_and_Nested_Parallelism`. + + +#. Once all parts of the algorithm stop, an exception is thrown on the + thread that invoked the algorithm. + + +As compilers evolve to support this functionality, future versions of +oneTBB might throw the original exception. So be sure your code can +catch either type of exception. The following example demonstrates +exception handling: + + + +:: + + + #include "oneapi/tbb.h" + #include + #include +   + + using namespace oneapi::tbb; + using namespace std; +   + + vector Data; +   + + struct Update { + void operator()( const blocked_range& r ) const { + for( int i=r.begin(); i!=r.end(); ++i ) + Data.at(i) += 1; + } + }; +   + + int main() { + Data.resize(1000); + try { + parallel_for( blocked_range(0, 2000), Update()); + } catch( out_of_range& ex ) { + cout << "out_of_range: " << ex.what() << endl; + } + return 0; + } + + +The ``parallel_for`` attempts to iterate over 2000 elements of a vector +with only 1000 elements. Hence the expression ``Data.at(i)`` sometimes +throws an exception ``std::out_of_range`` during execution of the +algorithm. When the exception happens, the algorithm is cancelled and an +exception thrown at the call site to ``parallel_for``. + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/Cancellation_Without_An_Exception + ../tbb_userguide/Cancellation_and_Nested_Parallelism diff --git a/_sources/main/tbb_userguide/Floating_Point_Settings.rst b/_sources/main/tbb_userguide/Floating_Point_Settings.rst new file mode 100644 index 0000000000..4618f56ae5 --- /dev/null +++ b/_sources/main/tbb_userguide/Floating_Point_Settings.rst @@ -0,0 +1,60 @@ +.. _Floating_Point_Settings: + +Floating-point Settings +======================= + +To propagate CPU-specific settings for floating-point computations to tasks executed by the task scheduler, you can use one of the following two methods: + +* When a ``task_arena`` or a task scheduler for a given application thread is initialized, they capture the current floating-point settings of the thread. +* The ``task_group_context`` class has a method to capture the current floating-point settings. + +By default, worker threads use floating-point settings obtained during the initialization of a ``task_arena`` or the implicit arena of the application thread. The settings are applied to all computations within that ``task_arena`` or started by that application thread. + + +For better control over floating point behavior, a thread may capture the current settings in a task group context. Do it at context creation with a special flag passed to the constructor: + +:: + + task_group_context ctx( task_group_context::isolated, + task_group_context::default_traits | task_group_context::fp_settings ); + + +Or call the ``capture_fp_settings`` method: + +:: + + task_group_context ctx; + ctx.capture_fp_settings(); + + +You can then pass the task group context to most parallel algorithms, including ``flow::graph``, to ensure that all tasks related to this algorithm use the specified floating-point settings. +It is possible to execute the parallel algorithms with different floating-point settings captured to separate contexts, even at the same time. + +Floating-point settings captured to a task group context prevail over the settings captured during task scheduler initialization. It means, if a context is passed to a parallel algorithm, the floating-point settings captured to the context are used. +Otherwise, if floating-point settings are not captured to the context, or a context is not explicitly specified, the settings captured during the task arena initialization are used. + +In a nested call to a parallel algorithm that does not use the context of a task group with explicitly captured floating-point settings, the outer-level settings are used. +If none of the outer-level contexts capture floating-point settings, the settings captured during task arena initialization are used. + +It guarantees that: + +* Floating-point settings are applied to all tasks executed within a task arena, if they are captured: + + * To a task group context. + * During the arena initialization. + +* A call to a oneTBB parallel algorithm does not change the floating-point settings of the calling thread, even if the algorithm uses different settings. + +.. note:: + The guarantees above apply only to the following conditions: + + * A user code inside a task should: + + * Not change the floating-point settings. + * Revert any modifications. + * Restore previous settings before the end of the task. + + * oneTBB task scheduler observers are not used to set or modify floating point settings. + + Otherwise, the stated guarantees are not valid and the behavior related to floating-point settings is undefined. + diff --git a/_sources/main/tbb_userguide/Flow-Graph-exception-tips.rst b/_sources/main/tbb_userguide/Flow-Graph-exception-tips.rst new file mode 100644 index 0000000000..88b0aea35d --- /dev/null +++ b/_sources/main/tbb_userguide/Flow-Graph-exception-tips.rst @@ -0,0 +1,17 @@ +.. _Flow_Graph_exception_tips: + +Flow Graph Tips for Exception Handling and Cancellation +======================================================= + + +The execution of a flow graph can be canceled directly or as a result of +an exception that propagates beyond a node's body. You can then +optionally reset the graph so that it can be re-executed. + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/catching_exceptions + ../tbb_userguide/cancel_a_graph + ../tbb_userguide/use_graph_reset + ../tbb_userguide/cancelling_nested_parallelism diff --git a/_sources/main/tbb_userguide/Flow-Graph-waiting-tips.rst b/_sources/main/tbb_userguide/Flow-Graph-waiting-tips.rst new file mode 100644 index 0000000000..176fe7bb89 --- /dev/null +++ b/_sources/main/tbb_userguide/Flow-Graph-waiting-tips.rst @@ -0,0 +1,11 @@ +.. _Flow_Graph_waiting_tips: + +Flow Graph Tips for Waiting for and Destroying a Flow Graph +=========================================================== + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/always_use_wait_for_all + ../tbb_userguide/avoid_dynamic_node_removal + ../tbb_userguide/destroy_graphs_outside_main_thread diff --git a/_sources/main/tbb_userguide/Flow_Graph.rst b/_sources/main/tbb_userguide/Flow_Graph.rst new file mode 100644 index 0000000000..3daf297092 --- /dev/null +++ b/_sources/main/tbb_userguide/Flow_Graph.rst @@ -0,0 +1,14 @@ +.. _Flow_Graph: + +Parallelizing Data Flow and Dependence Graphs +============================================= + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/Parallelizing_Flow_Graph + ../tbb_userguide/Basic_Flow_Graph_concepts + ../tbb_userguide/Graph_Main_Categories + ../tbb_userguide/Predefined_Node_Types + ../tbb_userguide/Flow_Graph_Tips + ../tbb_userguide/estimate_flow_graph_performance diff --git a/_sources/main/tbb_userguide/Flow_Graph_Buffering_in_Nodes.rst b/_sources/main/tbb_userguide/Flow_Graph_Buffering_in_Nodes.rst new file mode 100644 index 0000000000..232e92efe2 --- /dev/null +++ b/_sources/main/tbb_userguide/Flow_Graph_Buffering_in_Nodes.rst @@ -0,0 +1,42 @@ +.. _Flow_Graph_Buffering_in_Nodes: + +Flow Graph Basics: Buffering and Forwarding +=========================================== + + +|full_name| flow graph nodes use messages +to communicate data and to enforce dependencies. If a node passes a +message successfully to any successor, no further action is taken with +the message by that node. As noted in the section on Single-push vs. +Broadcast-push, a message may be passed to one or to multiple +successors, depending on the type of the node, how many successors are +connected to the node, and whether the message is pushed or pulled. + + +There are times when a node cannot successfully push a message to any +successor. In this case what happens to the message depends on the type +of the node. The two possibilities are: + + +- The node stores the message to be forwarded later. +- The node discards the message. + + +If a node discards messages that are not forwarded, and this behavior is +not desired, the node should be connected to a buffering node that does +store messages that cannot be pushed. + + +If a message has been stored by a node, there are two ways it can be +passed to another node: + + +- A successor to the node can pull the message using ``try_get()`` or + ``try_reserve()``. +- A successor can be connected using ``make_edge()``. + + +If a ``try_get()`` successfully forwards a message, it is removed from +the node that stored it. If a node is connected using ``make_edge`` the +node will attempt to push a stored message to the new successor. + diff --git a/_sources/main/tbb_userguide/Flow_Graph_Message_Passing_Protocol.rst b/_sources/main/tbb_userguide/Flow_Graph_Message_Passing_Protocol.rst new file mode 100644 index 0000000000..7e7e14eb7b --- /dev/null +++ b/_sources/main/tbb_userguide/Flow_Graph_Message_Passing_Protocol.rst @@ -0,0 +1,47 @@ +.. _Flow_Graph_Message_Passing_Protocol: + +Flow Graph Basics: Message Passing Protocol +=========================================== + + +|full_name| flow graph operates by passing +messages between nodes. A node may not be able to receive and process a +message from its predecessor. For a graph to operate most-efficiently, +if this occurs the state of the edge between the nodes can change its +state to pull so when the successor is able to handle a message it can +query its predecessor to see if a message is available. If the edge did +not reverse from push to pull, the predecessor node would have to +repeatedly attempt to forward its message until the successor accepts +it. This would consume resources needlessly. + + +Once the edge is in pull mode, when the successor is not busy, it will +try to pull a message from a predecessor. + + +#. If a predecessor has a message, the successor will process it and the + edge will remain in pull mode. +#. If the predecessor has no message, the edge between the nodes will + switch from pull to push mode. + + +The state diagram of this Push-Pull protocol is: + + +.. container:: fignone + :name: basic_push_pull + + + **The dynamic push / pull protocol.** + + + .. container:: imagecenter + + + |image0| + + +.. |image0| image:: Images/flow_graph_message_passing_protocol.jpg + :width: 442px + :height: 196px + diff --git a/_sources/main/tbb_userguide/Flow_Graph_Reservation.rst b/_sources/main/tbb_userguide/Flow_Graph_Reservation.rst new file mode 100644 index 0000000000..44fc2f0a98 --- /dev/null +++ b/_sources/main/tbb_userguide/Flow_Graph_Reservation.rst @@ -0,0 +1,286 @@ +.. _Flow_Graph_Reservation: + +Flow Graph Basics: Reservation +============================== + + +|full_name| flow graph +``join_node`` has four possible policies: ``queueing``, ``reserving``, +``key_matching`` and ``tag_matching``. ``join_nodes`` need messages at +every input before they can create an output message. The reserving +``join_node`` does not have internal buffering, and it does not pull +messages from its inputs until it has a message at each input. To create +an output message it temporarily reserves a message at each input port, +and only if all input ports succeed reserving messages will an output +message be created. If any input port fails to reserve a message, no +message will be pulled by the ``join_node``. + + +To support the reserving ``join_node`` some nodes support +**reservation** of their outputs. The way reservation works is: + + +- When a node connected to a reserving ``join_node`` in push state + tries to push a message, the ``join_node`` always rejects the push + and the edge connecting the nodes is switched to pull mode. +- The reserving input port calls ``try_reserve`` on each edge in pull + state. This may fail; if so, the reserving input port switches that + edge to push state, and tries to reserve the next node connected by + an edge in pull state. While the input port's predecessor is in + reserved state, no other node can retrieve the reserved value. +- If each input port successfully reserves an edge in pull state, the + reserving ``join_node`` will create a message using the reserved + messages and try to push the resulting message to any nodes connected + to it. +- If the message is successfully pushed to a successor, the + predecessors that were reserved are signaled that the messages were + used (by calling ``try_consume()``.) Those messages will be discarded + by the predecessor nodes, because they have been successfully pushed. +- If the message was not successfully pushed to any successor, the + predecessors that were reserved are signaled that the messages were + not used (by calling ``try_release()``.) At this point, the messages + may be pushed to or pulled by other nodes. + + +Because the reserving ``join_node`` will only attempt to push when each +input port has at least one edge in a pull state, and will only attempt +to create and push a message if all input ports succeed reserving +messages, at least one of the predecessors to each of the reserving +``join_node`` input ports must be reservable. + + +The following example demonstrates a reserving ``join_node``'s behavior. +``buffer_nodes`` buffer their output, so they accept a switch of their +output edge from push to pull mode. ``broadcast_nodes`` do not buffer +messages and do not support ``try_get()`` or ``try_reserve()``. + + +:: + + + void run_example2() { // example for Flow_Graph_Reservation.xml + graph g; + broadcast_node bn(g); + buffer_node buf1(g); + buffer_node buf2(g); + typedef join_node, reserving> join_type; + join_type jn(g); + buffer_node buf_out(g); + join_type::output_type tuple_out; + int icnt; + + + // join_node predecessors are both reservable buffer_nodes + make_edge(buf1,input_port<0>(jn)); + make_edge(bn,input_port<0>(jn)); // attach a broadcast_node + make_edge(buf2,input_port<1>(jn)); + make_edge(jn, buf_out); + bn.try_put(2); + buf1.try_put(3); + buf2.try_put(4); + buf2.try_put(7); + g.wait_for_all(); + while (buf_out.try_get(tuple_out)) { + printf("join_node output == (%d,%d)\n",get<0>(tuple_out), get<1>(tuple_out) ); + } + if(buf1.try_get(icnt)) printf("buf1 had %d\n", icnt); + else printf("buf1 was empty\n"); + if(buf2.try_get(icnt)) printf("buf2 had %d\n", icnt); + else printf("buf2 was empty\n"); + } + + +In the example above, port 0 of the reserving ``join_node`` ``jn`` has +two predecessors: a ``buffer_node`` ``buf1`` and a ``broadcast_node`` +``bn``. Port 1 of the ``join_node`` has one predecessor, ``buffer_node`` +``buf2``. + + +.. container:: fignone + :name: reserve_step1 + + + .. container:: imagecenter + + + |image0| + + +We will discuss one possible execution sequence (the scheduling of tasks +may differ slightly, but the end result will be the same.) + + +:: + + + bn.try_put(2); + + +``bn`` attempts to forward 2 to ``jn``. ``jn`` does not accept the value +and the arc from ``bn`` to ``jn`` reverses. Because neither bn nor jn +buffer messages, the message is dropped. Because not all the inputs to +``jn`` have available predecessors, ``jn`` does nothing further. + + +.. CAUTION:: + Any node which does not support reservation will not work correctly + when attached to a reserving ``join_node``. This program demonstrates + why this occurs; connecting non-reserving nodes to nodes requiring + support for reservation is **not** recommended practice. + + +.. container:: fignone + :name: reserve_step2 + + + .. container:: imagecenter + + + |image1| + + +:: + + + buf1.try_put(3); + + +``buf1`` attempts to forward 3 to ``jn``. ``jn`` does not accept the +value and the arc from ``buf1`` to ``jn`` reverses. Because not all the +inputs to ``jn`` have available predecessors, ``jn`` does nothing +further. + + +.. container:: fignone + :name: reserve_step3 + + + .. container:: imagecenter + + + |image2| + + +:: + + + buf2.try_put(4); + + +``buf2`` attempts to forward 4 to ``jn``. ``jn`` does not accept the +value and the arc from ``buf2`` to ``jn`` reverses. Now both inputs of +``jn`` have predecessors, a task to build and forward a message from +``jn`` will be spawned. We assume that task is not yet executing. + + +.. container:: fignone + :name: reserve_step4 + + + .. container:: imagecenter + + + |image3| + + +:: + + + buf2.try_put(7); + + +``buf2`` has no successor (because the arc to ``jn`` is reversed,) so it +stores the value 7. + + +.. container:: fignone + :name: reserve_step5 + + + .. container:: imagecenter + + + |image4| + + +Now the task spawned to run ``jn`` runs. + + +- ``jn`` tries to reserve ``bn``, which fails. The arc to ``bn`` + switches back to the forward direction. +- ``jn`` tries to reserve ``buf1``, which succeeds (reserved nodes are + colored grey.) ``jn`` receives the value 3 from ``buf1``, but it + remains in ``buf1`` (in case the attempt to forward a message from + ``jn`` fails.) +- ``jn`` tries to reserve ``buf2``, which succeeds. ``jn`` receives the + value 4 from ``buf2``, but it remains in ``buf2``. +- ``jn`` constructs the output message ``tuple<3,4>``. + + +.. container:: fignone + :name: reserve_step6 + + + .. container:: imagecenter + + + |image5| + + +Now ``jn`` pushes its message to ``buf_out``, which accepts it. Because +the push succeeded, ``jn`` signals ``buf1`` and ``buf2`` that the +reserved values were used, and the buffers discard those values. Now +``jn`` attempts to reserve again. + + +- No attempt to pull from ``bn`` is made, because the edge from ``bn`` + to ``jn`` is in push state. +- ``jn`` tries to reserve ``buf1``, which fails. The arc to ``buf1`` + switches back to the forward direction. +- ``jn`` does not try any further actions. + + +.. container:: fignone + :name: reserve_step7 + + + .. container:: imagecenter + + + |image6| + + +No further activity occurs in the graph, and the ``wait_for_all()`` will +complete. The output of this code is + + +:: + + + join_node output == (3,4) + buf1 was empty + buf2 had 7 + + +.. |image0| image:: Images/flow_graph_reserve_buffers_1.png + :width: 400px + :height: 222px +.. |image1| image:: Images/flow_graph_reserve_buffers_2.png + :width: 400px + :height: 222px +.. |image2| image:: Images/flow_graph_reserve_buffers_3.png + :width: 400px + :height: 222px +.. |image3| image:: Images/flow_graph_reserve_buffers_4.png + :width: 400px + :height: 222px +.. |image4| image:: Images/flow_graph_reserve_buffers_5.png + :width: 400px + :height: 222px +.. |image5| image:: Images/flow_graph_reserve_buffers_6.png + :width: 400px + :height: 222px +.. |image6| image:: Images/flow_graph_reserve_buffers_7.png + :width: 400px + :height: 222px + diff --git a/_sources/main/tbb_userguide/Flow_Graph_Single_Vs_Broadcast.rst b/_sources/main/tbb_userguide/Flow_Graph_Single_Vs_Broadcast.rst new file mode 100644 index 0000000000..23d5cd9c39 --- /dev/null +++ b/_sources/main/tbb_userguide/Flow_Graph_Single_Vs_Broadcast.rst @@ -0,0 +1,112 @@ +.. _Flow_Graph_Single_Vs_Broadcast: + +Flow Graph Basics: Single-push vs. Broadcast-push +================================================= + + +Nodes in the |full_name| flow graph +communicate by pushing and pulling messages. Two policies for pushing +messages are used, depending on the type of the node: + + +- **single-push**: No matter how many successors to the node exist and + are able to accept a message, each message will be only sent to one + successor. +- **broadcast-push**: A message will be pushed to every successor which + is connected to the node by an edge in push mode, and which accepts + the message. + + +The following code demonstrates this difference: + + +:: + + + using namespace oneapi::tbb::flow; + + + std::atomic g_cnt; + + + struct fn_body1 { + std::atomic &body_cnt; + fn_body1(std::atomic &b_cnt) : body_cnt(b_cnt) {} + continue_msg operator()( continue_msg /*dont_care*/) { + ++g_cnt; + ++body_cnt; + return continue_msg(); + } + }; + + + void run_example1() { // example for Flow_Graph_Single_Vs_Broadcast.xml + graph g; + std::atomic b1; // local counts + std::atomic b2; // for each function _node body + std::atomic b3; // + function_node f1(g,serial,fn_body1(b1)); + function_node f2(g,serial,fn_body1(b2)); + function_node f3(g,serial,fn_body1(b3)); + buffer_node buf1(g); + // + // single-push policy + // + g_cnt = b1 = b2 = b3 = 0; + make_edge(buf1,f1); + make_edge(buf1,f2); + make_edge(buf1,f3); + buf1.try_put(continue_msg()); + buf1.try_put(continue_msg()); + buf1.try_put(continue_msg()); + g.wait_for_all(); + printf( "after single-push test, g_cnt == %d, b1==%d, b2==%d, b3==%d\n", (int)g_cnt, (int)b1, (int)b2, (int)b3); + remove_edge(buf1,f1); + remove_edge(buf1,f2); + remove_edge(buf1,f3); + // + // broadcast-push policy + // + broadcast_node bn(g); + g_cnt = b1 = b2 = b3 = 0; + make_edge(bn,f1); + make_edge(bn,f2); + make_edge(bn,f3); + bn.try_put(continue_msg()); + bn.try_put(continue_msg()); + bn.try_put(continue_msg()); + g.wait_for_all(); + printf( "after broadcast-push test, g_cnt == %d, b1==%d, b2==%d, b3==%d\n", (int)g_cnt, (int)b1, (int)b2, (int)b3); + } + + +The output of this code is + + +:: + + + after single-push test, g_cnt == 3, b1==3, b2==0, b3==0 + after broadcast-push test, g_cnt == 9, b1==3, b2==3, b3==3 + + +The single-push test uses a ``buffer_node``, which has a "single-push" +policy for forwarding messages. Putting three messages to the +``buffer_node`` results in three messages being pushed. Notice also only +the first ``function_node`` is sent to; in general there is no policy +for which node is pushed to if more than one successor can accept. + + +The broadcast-push test uses a ``broadcast_node``, which will push any +message it receives to all accepting successors. Putting three messages +to the ``broadcast_node`` results in a total of nine messages pushed to +the ``function_nodes``. + + +Only nodes designed to buffer (hold and forward received messages) have +a "single-push" policy; all other nodes have a "broadcast-push" policy. + +Please see the :ref:`broadcast_or_send` section of +:ref:`Flow_Graph_Tips`, and :ref:`Flow_Graph_Buffering_in_Nodes` for more +information. + diff --git a/_sources/main/tbb_userguide/Flow_Graph_Tips.rst b/_sources/main/tbb_userguide/Flow_Graph_Tips.rst new file mode 100644 index 0000000000..7cda5022c8 --- /dev/null +++ b/_sources/main/tbb_userguide/Flow_Graph_Tips.rst @@ -0,0 +1,13 @@ +.. _Flow_Graph_Tips: + +Flow Graph Tips and Tricks +========================== + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/Flow-Graph-waiting-tips + ../tbb_userguide/Flow_Graph_making_edges_tips + ../tbb_userguide/Flow_Graph_nested_parallelism_tips + ../tbb_userguide/Flow_Graph_resource_tips + ../tbb_userguide/Flow-Graph-exception-tips \ No newline at end of file diff --git a/_sources/main/tbb_userguide/Flow_Graph_making_edges_tips.rst b/_sources/main/tbb_userguide/Flow_Graph_making_edges_tips.rst new file mode 100644 index 0000000000..49312b0432 --- /dev/null +++ b/_sources/main/tbb_userguide/Flow_Graph_making_edges_tips.rst @@ -0,0 +1,13 @@ +.. _Flow_Graph_making_edges_tips: + +Flow Graph Tips on Making Edges +=============================== + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/use_make_edge + ../tbb_userguide/broadcast_or_send + ../tbb_userguide/communicate_with_nodes + ../tbb_userguide/use_input_node + ../tbb_userguide/avoiding_data_races diff --git a/_sources/main/tbb_userguide/Flow_Graph_nested_parallelism_tips.rst b/_sources/main/tbb_userguide/Flow_Graph_nested_parallelism_tips.rst new file mode 100644 index 0000000000..cc6824bc60 --- /dev/null +++ b/_sources/main/tbb_userguide/Flow_Graph_nested_parallelism_tips.rst @@ -0,0 +1,10 @@ +.. _Flow_Graph_nested_parallelism_tips: + +Flow Graph Tips on Nested Parallelism +===================================== + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/use_nested_algorithms + ../tbb_userguide/use_nested_flow_graphs \ No newline at end of file diff --git a/_sources/main/tbb_userguide/Flow_Graph_resource_tips.rst b/_sources/main/tbb_userguide/Flow_Graph_resource_tips.rst new file mode 100644 index 0000000000..27dd524c5b --- /dev/null +++ b/_sources/main/tbb_userguide/Flow_Graph_resource_tips.rst @@ -0,0 +1,18 @@ +.. _Flow_Graph_resource_tips: + +Flow Graph Tips for Limiting Resource Consumption +================================================= + + +You may want to control the number of messages allowed to enter parts of +your graph, or control the maximum number of tasks in the work pool. +There are several mechanisms available for limiting resource consumption +in a flow graph. + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/use_limiter_node + ../tbb_userguide/use_concurrency_limits + ../tbb_userguide/create_token_based_system + ../tbb_userguide/attach_flow_graph_to_arena \ No newline at end of file diff --git a/_sources/main/tbb_userguide/Graph_Main_Categories.rst b/_sources/main/tbb_userguide/Graph_Main_Categories.rst new file mode 100644 index 0000000000..9f9d640161 --- /dev/null +++ b/_sources/main/tbb_userguide/Graph_Main_Categories.rst @@ -0,0 +1,21 @@ +.. _Graph_Main_Categories: + +Graph Application Categories +============================ + + +Most flow graphs fall into one of two categories: + + +- **Data flow graphs.** In this type of graph, data is passed along the + graph's edges. The nodes receive, transform and then pass along the + data messages. +- **Dependence graphs.** In this type of graph, the data operated on by + the nodes is obtained through shared memory directly and is not + passed along the edges. + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/Data_Flow_Graph + ../tbb_userguide/Dependence_Graph \ No newline at end of file diff --git a/_sources/main/tbb_userguide/Graph_Object.rst b/_sources/main/tbb_userguide/Graph_Object.rst new file mode 100644 index 0000000000..06fd53312a --- /dev/null +++ b/_sources/main/tbb_userguide/Graph_Object.rst @@ -0,0 +1,34 @@ +.. _Graph_Object: + +Flow Graph Basics: Graph Object +=============================== + + +Conceptually a flow graph is a collection of nodes and edges. Each node +belongs to exactly one graph and edges are made only between nodes in +the same graph. In the flow graph interface, a graph object represents +this collection of nodes and edges, and is used for invoking whole graph +operations such as waiting for all tasks related to the graph to +complete, resetting the state of all nodes in the graph, and canceling +the execution of all nodes in the graph. + + +The code below creates a graph object and then waits for all tasks +spawned by the graph to complete. The call to ``wait_for_all`` in this +example returns immediately since this is a trivial graph with no nodes +or edges, and therefore no tasks are spawned. + + +:: + + + graph g; + g.wait_for_all(); + +The graph object does not own the nodes associated with it. You need to make sure that the graph object's lifetime is longer than the lifetimes of all nodes added to the graph and any activity associated with the graph. + +.. tip:: Call ``wait_for_all`` on a graph object before destroying it to make sure all activities are complete. + + Even when using smart pointers, be aware of the order of destruction for nodes and the graph to make sure that nodes are not deleted before the graph. + + diff --git a/_sources/main/tbb_userguide/Guiding_Task_Scheduler_Execution.rst b/_sources/main/tbb_userguide/Guiding_Task_Scheduler_Execution.rst new file mode 100644 index 0000000000..b0b33fe498 --- /dev/null +++ b/_sources/main/tbb_userguide/Guiding_Task_Scheduler_Execution.rst @@ -0,0 +1,112 @@ +.. _guiding_task_scheduler_execution: + +Guiding Task Scheduler Execution +================================ + +By default, the task scheduler tries to use all available computing resources. In some cases, +you may want to configure the task scheduler to use only some of them. + +.. caution:: + + Guiding the execution of the task scheduler may cause composability issues. + +|full_name| provides the ``task_arena`` interface to guide tasks execution within the arena by: + - setting the preferred computation units; + - restricting part of computation units. + +Such customizations are encapsulated within the ``task_arena::constraints`` structure. +To set the limitation, you have to customize the ``task_arena::constraints`` and then pass +it to the ``task_arena`` instance during the construction or initialization. + +The structure ``task_arena::constraints`` allows to specify the following restrictions: + +- Preferred NUMA node +- Preferred core type +- The maximum number of logical threads scheduled per single core simultaneously +- The level of ``task_arena`` concurrency + +You may use the interfaces from ``tbb::info`` namespace to construct the ``tbb::task_arena::constraints`` +instance. Interfaces from ``tbb::info`` namespace respect the process affinity mask. For instance, +if the process affinity mask excludes execution on some of the NUMA nodes, then these NUMA nodes are +not returned by ``tbb::info::numa_nodes()`` interface. + +The following examples show how to use these interfaces: + +.. rubric:: Setting the preferred NUMA node + +The execution on systems with non-uniform memory access (`NUMA `_ systems) +may cause a performance penalty if threads from one NUMA node access the memory allocated on +a different NUMA node. To reduce this overhead, the work may be divided among several ``task_arena`` +instances, whose execution preference is set to different NUMA nodes. To set execution preference, +assign a NUMA node identifier to the ``task_arena::constraints::numa_id`` field. + +:: + + std::vector numa_indexes = tbb::info::numa_nodes(); + std::vector arenas(numa_indexes.size()); + std::vector task_groups(numa_indexes.size()); + + for(unsigned j = 0; j < numa_indexes.size(); j++) { + arenas[j].initialize(tbb::task_arena::constraints(numa_indexes[j])); + arenas[j].execute([&task_groups, &j](){  + task_groups[j].run([](){/*some parallel stuff*/}); + }); + } + + for(unsigned j = 0; j < numa_indexes.size(); j++) { + arenas[j].execute([&task_groups, &j](){ task_groups[j].wait(); }); + } + +.. rubric:: Setting the preferred core type + +The processors with `Intel® Hybrid Technology `_ +contain several core types, each is suited for different purposes. +In most cases, systems with hybrid CPU architecture show reasonable performance without involving additional API calls. +However, in some exceptional scenarios, performance may be tuned by setting the preferred core type. +To set the preferred core type for the execution, assign a specific core type identifier to the ``task_arena::constraints::core_type`` field. + +The example shows how to set the most performant core type as preferable for work execution: + +:: + + std::vector core_types = tbb::info::core_types(); + tbb::task_arena arena( + tbb::task_arena::constraints{}.set_core_type(core_types.back()) + ); + + arena.execute( [] { + /*the most performant core type is defined as preferred.*/ + }); + +.. rubric:: Limiting the maximum number of threads simultaneously scheduled to one core + +The processors with `Intel® Hyper-Threading Technology `_ +allow more than one thread to run on each core simultaneously. However, there might be situations +when there is need to lower the number of simultaneously running threads per core. In such cases, +assign the desired value to the ``task_arena::constraints::max_threads_per_core`` field. + +The example shows how to allow only one thread to run on each core at a time: + +:: + + tbb::task_arena no_ht_arena( tbb::task_arena::constraints{}.set_max_threads_per_core(1) ); + no_ht_arena.execute( [] { + /*parallel work*/ + }); + +A more composable way to limit the number of threads executing on cores is by setting the maximal +concurrency of the ``tbb::task_arena``: + +:: + + int no_ht_concurrency = tbb::info::default_concurrency( + tbb::task_arena::constraints{}.set_max_threads_per_core(1) + ); + tbb::task_arena arena( no_ht_concurrency ); + arena.execute( [] { + /*parallel work*/ + }); + +Similarly to the previous example, the number of threads inside the arena is equal to the +number of available cores. However, this one results in fewer overheads and better composability +by imposing a less constrained execution. diff --git a/_sources/main/tbb_userguide/How_Task_Scheduler_Works.rst b/_sources/main/tbb_userguide/How_Task_Scheduler_Works.rst new file mode 100644 index 0000000000..744794fc07 --- /dev/null +++ b/_sources/main/tbb_userguide/How_Task_Scheduler_Works.rst @@ -0,0 +1,50 @@ +.. _How_Task_Scheduler_Works.rst: + +How Task Scheduler Works +======================== + + +While the task scheduler is not bound to any particular type of parallelism, +it was designed to work efficiently for fork-join parallelism with lots of forks. +This type of parallelism is typical for parallel algorithms such as `oneapi::tbb::parallel_for +`_. + +Let's consider the mapping of fork-join parallelism on the task scheduler in more detail. + +The scheduler runs tasks in a way that tries to achieve several targets simultaneously: + - Enable as many threads as possible, by creating enough job, to achieve actual parallelism + - Preserve data locality to make a single thread execution more efficient + - Minimize both memory demands and cross-thread communication to reduce an overhead + +To achieve this, a balance between depth-first and breadth-first execution strategies +must be reached. Assuming that the task graph is finite, depth-first is better for +a sequential execution because: + +- **Strike when the cache is hot**. The deepest tasks are the most recently created tasks and therefore are the hottest in the cache. + Also, if they can be completed, tasks that depend on it can continue executing, and though not the hottest in a cache, + they are still warmer than the older tasks deeper in the dequeue. + +- **Minimize space**. Execution of the shallowest task leads to the breadth-first unfolding of a graph. It creates an exponential + number of nodes that co-exist simultaneously. In contrast, depth-first execution creates the same number + of nodes, but only a linear number can exists at the same time, since it creates a stack of other ready + tasks. + +Each thread has its deque of tasks that are ready to run. When a +thread spawns a task, it pushes it onto the bottom of its deque. + +When a thread participates in the evaluation of tasks, it constantly executes +a task obtained by the first rule that applies from the roughly equivalent ruleset: + +- Get the task returned by the previous one, if any. + +- Take a task from the bottom of its deque, if any. + +- Steal a task from the top of another randomly chosen deque. If the + selected deque is empty, the thread tries again to execute this rule until it succeeds. + +Rule 1 is described in :doc:`Task Scheduler Bypass `. +The overall effect of rule 2 is to execute the *youngest* task spawned by the thread, +which causes the depth-first execution until the thread runs out of work. +Then rule 3 applies. It steals the *oldest* task spawned by another thread, +which causes temporary breadth-first execution that converts potential parallelism +into actual parallelism. diff --git a/_sources/main/tbb_userguide/Initializing_and_Terminating_the_Library.rst b/_sources/main/tbb_userguide/Initializing_and_Terminating_the_Library.rst new file mode 100644 index 0000000000..e101a068aa --- /dev/null +++ b/_sources/main/tbb_userguide/Initializing_and_Terminating_the_Library.rst @@ -0,0 +1,22 @@ +.. _Initializing_and_Terminating_the_Library: + +Initializing and Terminating the Library +======================================== + +|full_name| automatically initializes the task scheduler. +The initialization process is involved when a thread uses task scheduling services the first time, +for example any parallel algorithm, flow graph or task group. +The termination happens when the last such thread exits. + +Explicit Library Finalization +***************************** + +oneTBB supports an explicit library termination as a preview feature. +The ``oneapi::tbb::finalize`` function called with an instance of class ``oneapi::tbb::task_scheduler_handle`` blocks the calling thread +until all worker threads implicitly created by the library have completed. +If waiting for thread completion is not safe, e.g. may result in a deadlock +or called inside a task, a parallel algorithm, or a flow graph node, the method fails. + +If you know how many active ``oneapi::tbb::task_scheduler_handle`` instances exist in the program, +it is recommended to call ``oneapi::tbb::release`` function on all but the last one, then call ``oneapi::tbb::finalize`` for the last instance. + diff --git a/_sources/main/tbb_userguide/Iterating_Over_a_Concurrent_Queue_for_Debugging.rst b/_sources/main/tbb_userguide/Iterating_Over_a_Concurrent_Queue_for_Debugging.rst new file mode 100644 index 0000000000..8e88c125e5 --- /dev/null +++ b/_sources/main/tbb_userguide/Iterating_Over_a_Concurrent_Queue_for_Debugging.rst @@ -0,0 +1,29 @@ +.. _Iterating_Over_a_Concurrent_Queue_for_Debugging: + +Iterating Over a Concurrent Queue for Debugging +=============================================== + + +The template classes ``concurrent_queue`` and +``concurrent_bounded_queue`` support STL-style iteration. This support +is intended only for debugging, when you need to dump a queue. The +iterators go forwards only, and are too slow to be very useful in +production code. If a queue is modified, all iterators pointing to it +become invalid and unsafe to use. The following snippet dumps a queue. +The ``operator<<`` is defined for a ``Foo``. + + +:: + + + concurrent_queue q; + ... + typedef concurrent_queue::const_iterator iter; + for(iter i(q.unsafe_begin()); i!=q.unsafe_end(); ++i ) { + cout << *i; + } + + +The prefix ``unsafe_`` on the methods is a reminder that they are not +concurrency safe. + diff --git a/_sources/main/tbb_userguide/Lambda_Expressions.rst b/_sources/main/tbb_userguide/Lambda_Expressions.rst new file mode 100644 index 0000000000..e2408c1e0f --- /dev/null +++ b/_sources/main/tbb_userguide/Lambda_Expressions.rst @@ -0,0 +1,102 @@ +.. _Lambda_Expressions: + +Lambda Expressions +================== + + +C++11 lambda expressions make the |full_name| +``parallel_for`` much easier to use. A lambda expression lets +the compiler do the tedious work of creating a function object. + + +Below is the example from the previous section, rewritten with a lambda +expression. The lambda expression, replaces both the declaration and construction of function object ``ApplyFoo`` in the +example of the previous section. + + +:: + + + #include "oneapi/tbb.h" +   + + using namespace oneapi::tbb; +   + + void ParallelApplyFoo( float* a, size_t n ) { + parallel_for( blocked_range(0,n), + [=](const blocked_range& r) { + for(size_t i=r.begin(); i!=r.end(); ++i) + Foo(a[i]); + } + ); + } + + +The [=] introduces the lambda expression. The expression creates a +function object very similar to ``ApplyFoo``. When local variables like +``a`` and ``n`` are declared outside the lambda expression, but used +inside it, they are "captured" as fields inside the function object. The +[=] specifies that capture is by value. Writing [&] instead would +capture the values by reference. After the [=] is the parameter list and +definition for the ``operator()`` of the generated function object. The +compiler documentation says more about lambda expressions and other +implemented C++11 features. It is worth reading more complete +descriptions of lambda expressions than can fit here, because lambda +expressions are a powerful feature for using template libraries in +general. + + +C++11 support is off by default in the compiler. The following table +shows the option for turning it on. + + +.. container:: tablenoborder + + + .. list-table:: + :header-rows: 1 + + * - Environment + - Intel® C++ Compiler Classic + - Intel® oneAPI DPC++/C++ Compiler + * - Windows\* OS systems + - \ ``icl /Qstd=c++11 foo.cpp`` + - \ ``icx /Qstd=c++11 foo.cpp`` + * - Linux\* OS systems + - \ ``icc -std=c++11 foo.cpp`` + - \ ``icx -std=c++11 foo.cpp`` + + + + +For further compactness, oneTBB has a form of ``parallel_for`` expressly +for parallel looping over a consecutive range of integers. The +expression ``parallel_for(first,last,step,f)`` is like writing +``for(auto i=first; i* to indicate the top-level +installation directory. The following table describes the subdirectory +structure for Linux\*, relative to ** + +.. container:: tablenoborder + + .. list-table:: + :header-rows: 1 + + * - Item + - Location + - Environment Variable + * - Header files + - | ``include/oneapi/tbb.h`` + | ``include/oneapi/tbb/*.h`` + - ``CPATH`` + * - Shared libraries + - ``lib//.so.`` + - | ``LIBRARY_PATH`` + | ``LD_LIBRARY_PATH`` + +Where: + +* ```` - ``ia32`` or ``intel64`` + + .. note:: Starting with oneTBB 2022.0, 32-bit binaries are supported only by the open-source version of the library. + +* ```` - ``libtbb``, ``libtbbmalloc``, ``libtbbmalloc_proxy`` or ``libtbbbind`` +* ```` - ``_debug`` or empty +* ```` - binary version in a form of ``.`` diff --git a/_sources/main/tbb_userguide/Lock_Pathologies.rst b/_sources/main/tbb_userguide/Lock_Pathologies.rst new file mode 100644 index 0000000000..eeff177a6c --- /dev/null +++ b/_sources/main/tbb_userguide/Lock_Pathologies.rst @@ -0,0 +1,75 @@ +.. _Lock_Pathologies: + +Lock Pathologies +================ + + +Locks can introduce performance and correctness problems. If you are new +to locking, here are some of the problems to avoid: + + +.. container:: section + + + .. rubric:: Deadlock + :class: sectiontitle + + Deadlock happens when threads are trying to acquire more than one + lock, and each holds some of the locks the other threads need to + proceed. More precisely, deadlock happens when: + + + - There is a cycle of threads + + + - Each thread holds at least one lock on a mutex, and is waiting on + a mutex for which the *next* thread in the cycle already has a + lock. + + + - No thread is willing to give up its lock. + + + Think of classic gridlock at an intersection – each car has + "acquired" part of the road, but needs to "acquire" the road under + another car to get through. Two common ways to avoid deadlock are: + + + - Avoid needing to hold two locks at the same time. Break your + program into small actions in which each can be accomplished while + holding a single lock. + + + - Always acquire locks in the same order. For example, if you have + "outer container" and "inner container" mutexes, and need to + acquire a lock on one of each, you could always acquire the "outer + sanctum" one first. Another example is "acquire locks in + alphabetical order" in a situation where the locks have names. Or + if the locks are unnamed, acquire locks in order of the mutex’s + numerical addresses. + + + - Use atomic operations instead of locks. + + +.. container:: section + + + .. rubric:: Convoying + :class: sectiontitle + + Another common problem with locks is *convoying*. Convoying occurs + when the operating system interrupts a thread that is holding a lock. + All other threads must wait until the interrupted thread resumes and + releases the lock. Fair mutexes can make the situation even worse, + because if a waiting thread is interrupted, all the threads behind it + must wait for it to resume. + + + To minimize convoying, try to hold the lock as briefly as possible. + Precompute whatever you can before acquiring the lock. + + + To avoid convoying, use atomic operations instead of locks where + possible. + diff --git a/_sources/main/tbb_userguide/Mac_OS.rst b/_sources/main/tbb_userguide/Mac_OS.rst new file mode 100644 index 0000000000..84a9894f64 --- /dev/null +++ b/_sources/main/tbb_userguide/Mac_OS.rst @@ -0,0 +1,32 @@ +.. _Mac_OS: + +macOS\* +======= + +This section uses ** to indicate the top-level installation directory. +The following table describes the subdirectory structure for macOS\*, relative to **. + +.. container:: tablenoborder + + .. list-table:: + :header-rows: 1 + + * - Item + - Location + - Environment Variable + * - Header files + - | ``include/oneapi/tbb.h`` + | ``include/oneapi/tbb/*.h`` + - ``CPATH`` + * - Shared libraries + - ``lib/..dylib`` + - | ``LIBRARY_PATH`` + | ``DYLD_LIBRARY_PATH`` + +where + +* ```` - ``libtbb``, ``libtbbmalloc`` or ``libtbbmalloc_proxy`` + +* ```` - ``_debug`` or empty + +* ```` - binary version in a form of ``.`` diff --git a/_sources/main/tbb_userguide/Mapping_Nodes2Tasks.rst b/_sources/main/tbb_userguide/Mapping_Nodes2Tasks.rst new file mode 100644 index 0000000000..d47ee857f0 --- /dev/null +++ b/_sources/main/tbb_userguide/Mapping_Nodes2Tasks.rst @@ -0,0 +1,57 @@ +.. _Mapping_Nodes2Tasks: + +Flow Graph Basics: Mapping Nodes to Tasks +========================================= + + +The following figure shows the timeline for one possible execution of +the two node graph example in the previous section. The bodies of n and +m will be referred to as λ\ :sub:`n` and λ\ :sub:`m`, respectively. The +three calls to try_put spawn three tasks; each one applies the lambda +expression, λ\ :sub:`n`, on one of the three input messages. Because n +has unlimited concurrency, these tasks can execute concurrently if there +are enough threads available. The call to ``g.wait_for_all()`` blocks until +there are no tasks executing in the graph. As with other ``wait_for_all`` +functions in oneTBB, the thread that calls ``wait_for_all`` is not spinning +idly during this time, but instead can join in executing other tasks +from the work pool. + + +.. container:: fignone + + + **Execution Timeline of a Two Node Graph** + + + .. container:: imagecenter + + + |image0| + + +As each task from n finishes, it puts its output to m, since m is a +successor of n. Unlike node n, m has been constructed with a concurrency +limit of 1 and therefore does not spawn all tasks immediately. Instead, +it sequentially spawns tasks to execute its body, λ\ :sub:`m`, on the +messages in the order that they arrive. When all tasks are complete, the +call to ``wait_for_all`` returns. + + +.. note:: + All execution in the flow graph happens asynchronously. The calls to + try_put return control to the calling thread quickly, after either + immediately spawning a task or buffering the message being passed. + Likewise, the body tasks execute the lambda expressions and then put + the result to any successor nodes. Only the call to ``wait_for_all`` + blocks, as it should, and even in this case the calling thread may be + used to execute tasks from the oneTBB work pool while it is waiting. + + +The above timeline shows the sequence when there are enough threads to +execute all of the tasks that can be executed in parallel. If there are +fewer threads, some spawned tasks will need to wait until a thread is +available to execute them. + + +.. |image0| image:: Images/execution_timeline2node.jpg + diff --git a/_sources/main/tbb_userguide/Memory_Allocation.rst b/_sources/main/tbb_userguide/Memory_Allocation.rst new file mode 100644 index 0000000000..745f0258db --- /dev/null +++ b/_sources/main/tbb_userguide/Memory_Allocation.rst @@ -0,0 +1,71 @@ +.. _Memory_Allocation: + +Memory Allocation +================= + + +|full_name| provides several memory +allocator templates that are similar to the STL template class +std::allocator. Two templates, ``scalable_allocator`` and +``cache_aligned_allocator``, address critical issues in parallel +programming as follows: + + +- **Scalability**. Problems of scalability arise when using memory + allocators originally designed for serial programs, on threads that + might have to compete for a single shared pool in a way that allows + only one thread to allocate at a time. + + + Use the ``scalable_allocator`` template to avoid scalability + bottlenecks. This template can improve the performance of programs + that rapidly allocate and free memory. + + +- **False sharing**. Problems of sharing arise when two threads access + different words that share the same cache line. The problem is that a + cache line is the unit of information interchange between processor + caches. If one processor modifies a cache line and another processor + reads the same cache line, the line must be moved from one processor + to the other, even if the two processors are dealing with different + words within the line. False sharing can hurt performance because + cache lines can take hundreds of clocks to move. + + + Use the ``cache_aligned_allocator`` template to always allocate on + a separate cache line. Two objects allocated by + ``cache_aligned_allocator`` are guaranteed to not have false sharing. + However, if an object is allocated by ``cache_aligned_allocator`` and + another object is allocated some other way, there is no guarantee. + + +You can use these allocator templates as the *allocator* argument to STL +template classes.The following code shows how to declare an STL vector +that uses ``cache_aligned_allocator``\ for allocation: + + +:: + + + std::vector >; + + +.. tip:: + The functionality of ``cache_aligned_allocator`` comes at some + cost in space, because it must allocate at least one cache line’s + worth of memory, even for a small object. So use + ``cache_aligned_allocator`` only if false sharing is likely to be + a real problem. + + +The scalable memory allocator also provides a set of functions +equivalent to the C standard library memory management routines but has +the ``scalable_`` prefix in their names, as well as the way to easily +redirect the standard routines to these functions. + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/Which_Dynamic_Libraries_to_Use + ../tbb_userguide/Allocator_Configuration + ../tbb_userguide/automatically-replacing-malloc diff --git a/_sources/main/tbb_userguide/Migration_Guide.rst b/_sources/main/tbb_userguide/Migration_Guide.rst new file mode 100644 index 0000000000..2ff3a4e293 --- /dev/null +++ b/_sources/main/tbb_userguide/Migration_Guide.rst @@ -0,0 +1,15 @@ +.. _Migration_Guide: + +Migrating from Threading Building Blocks (TBB) +============================================== + +While oneTBB is mostly source compatible with TBB, some interfaces were deprecated +in TBB and redesigned or removed in oneTBB. This section considers the most difficult use cases for +migrating TBB to oneTBB. + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/Migration_Guide/Task_Scheduler_Init + ../tbb_userguide/Migration_Guide/Task_API + ../tbb_userguide/Migration_Guide/Mixing_Two_Runtimes diff --git a/_sources/main/tbb_userguide/Migration_Guide/Mixing_Two_Runtimes.rst b/_sources/main/tbb_userguide/Migration_Guide/Mixing_Two_Runtimes.rst new file mode 100644 index 0000000000..8d467fb620 --- /dev/null +++ b/_sources/main/tbb_userguide/Migration_Guide/Mixing_Two_Runtimes.rst @@ -0,0 +1,49 @@ +.. _Mixing_Two_Runtimes: + +Mixing two runtimes +======================================= + +Threading Building Blocks (TBB) and oneAPI Threading Building Blocks (oneTBB) can be safely used in +the same application. TBB and oneTBB runtimes are named differently and can be loaded safely within +the same process. In addition, the ABI versioning is completely different that prevents symbols +conflicts. + +However, if both runtimes are loaded into the same process it can lead to +oversubscription because each runtime will use its own pool of threads. It might lead to a +performance penalty due to increased number of context switches. To check if both TBB and +oneTBB are loaded to the application, export ``TBB_VERSION=1`` before the application run. If +both runtimes are loaded there will be two blocks of output, for example: + +oneTBB possible output: + +.. code:: text + + oneTBB: SPECIFICATION VERSION 1.0 + oneTBB: VERSION 2021.2 + oneTBB: INTERFACE VERSION 12020 + oneTBB: TBB_USE_DEBUG 1 + oneTBB: TBB_USE_ASSERT 1 + oneTBB: TOOLS SUPPORT disabled + +TBB possible output: + +.. code:: text + + TBB: VERSION 2018.0 + TBB: INTERFACE VERSION 10006 + TBB: BUILD_DATE Mon 01 Mar 2021 01:28:40 PM UTC + TBB: BUILD_HOST localhost (x86_64) + TBB: BUILD_OS Fedora release 32 (Thirty Two) + TBB: BUILD_KERNEL Linux 5.8.9-200.fc32.x86_64 #1 SMP Mon Sep 14 18:28:45 UTC 2020 + TBB: BUILD_GCC g++ (GCC) 10.2.1 20201125 (Red Hat 10.2.1-9) + TBB: BUILD_LIBC 2.31 + TBB: BUILD_LD GNU ld version 2.34-6.fc32 + TBB: BUILD_TARGET intel64 on cc10_libc2.31_kernel5.8.9 + TBB: BUILD_COMMAND g++ -DDO_ITT_NOTIFY -g -O2 -DUSE_PTHREAD -m64 -fPIC -D__TBB_BUILD=1 -Wall -Wno-parentheses -Wno-non-virtual-dtor -I../../src -I../../src/rml/include -I../../include -I. + TBB: TBB_USE_DEBUG 0 + TBB: TBB_USE_ASSERT 0 + TBB: DO_ITT_NOTIFY 1 + TBB: RML private + TBB: Tools support disabled + +.. note:: The ``tbbmalloc`` library in oneTBB is fully binary compatible with TBB. diff --git a/_sources/main/tbb_userguide/Migration_Guide/Task_API.rst b/_sources/main/tbb_userguide/Migration_Guide/Task_API.rst new file mode 100644 index 0000000000..e96e4324b3 --- /dev/null +++ b/_sources/main/tbb_userguide/Migration_Guide/Task_API.rst @@ -0,0 +1,453 @@ +.. _Task_API: + +Migrating from low-level task API +================================= + +The low-level task API of Intel(R) Threading Building Blocks (TBB) was considered complex and hence +error-prone, which was the primary reason it had been removed from oneAPI Threading Building Blocks +(oneTBB). This guide helps with the migration from TBB to oneTBB for the use cases where low-level +task API is used. + +Spawning of individual tasks +---------------------------- +For most use cases, the spawning of individual tasks can be replaced with the use of either +``oneapi::tbb::task_group`` or ``oneapi::tbb::parallel_invoke``. + +For example, ``RootTask``, ``ChildTask1``, and ``ChildTask2`` are the user-side functors that +inherit ``tbb::task`` and implement its interface. Then spawning of ``ChildTask1`` and +``ChildTask2`` tasks that can execute in parallel with each other and waiting on the ``RootTask`` is +implemented as: + +.. code:: cpp + + #include + + int main() { + // Assuming RootTask, ChildTask1, and ChildTask2 are defined. + RootTask& root = *new(tbb::task::allocate_root()) RootTask{}; + + ChildTask1& child1 = *new(root.allocate_child()) ChildTask1{/*params*/}; + ChildTask2& child2 = *new(root.allocate_child()) ChildTask2{/*params*/}; + + root.set_ref_count(3); + + tbb::task::spawn(child1); + tbb::task::spawn(child2); + + root.wait_for_all(); + } + + +Using ``oneapi::tbb::task_group`` +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +The code above can be rewritten using ``oneapi::tbb::task_group``: + +.. code:: cpp + + #include + + int main() { + // Assuming ChildTask1, and ChildTask2 are defined. + oneapi::tbb::task_group tg; + tg.run(ChildTask1{/*params*/}); + tg.run(ChildTask2{/*params*/}); + tg.wait(); + } + +The code looks more concise now. It also enables lambda functions and does not require you to +implement ``tbb::task`` interface that overrides the ``tbb::task* tbb::task::execute()`` virtual +method. With this new approach, you work with functors in a C++-standard way by implementing ``void +operator() const``: + +.. code:: cpp + + struct Functor { + // Member to be called when object of this type are passed into + // oneapi::tbb::task_group::run() method + void operator()() const {} + }; + + +Using ``oneapi::tbb::parallel_invoke`` +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +It is also possible to use ``oneapi::tbb::parallel_invoke`` to rewrite the original code and make it +even more concise: + +.. code:: cpp + + #include + + int main() { + // Assuming ChildTask1, and ChildTask2 are defined. + oneapi::tbb::parallel_invoke( + ChildTask1{/*params*/}, + ChildTask2{/*params*/} + ); + } + + +Adding more work during task execution +-------------------------------------- +``oneapi::tbb::parallel_invoke`` follows a blocking style of programming, which means that it +completes only when all functors passed to the parallel pattern complete their execution. + +In TBB, cases when the amount of work is not known in advance and the work needs to be added during +the execution of a parallel algorithm were mostly covered by ``tbb::parallel_do`` high-level +parallel pattern. The ``tbb::parallel_do`` algorithm logic may be implemented using the task API as: + +.. code:: cpp + + #include + #include + #include + + // Assuming RootTask and OtherWork are defined and implement tbb::task interface. + + struct Task : public tbb::task { + Task(tbb::task& root, int i) + : m_root(root), m_i(i) + {} + + tbb::task* execute() override { + // ... do some work for item m_i ... + + if (add_more_parallel_work) { + tbb::task& child = *new(m_root.allocate_child()) OtherWork; + tbb::task::spawn(child); + } + return nullptr; + } + + tbb::task& m_root; + int m_i; + }; + + int main() { + std::vector items = { 0, 1, 2, 3, 4, 5, 6, 7 }; + RootTask& root = *new(tbb::task::allocate_root()) RootTask{/*params*/}; + + root.set_ref_count(items.size() + 1); + + for (std::size_t i = 0; i < items.size(); ++i) { + Task& task = *new(root.allocate_child()) Task(root, items[i]); + tbb::task::spawn(task); + } + + root.wait_for_all(); + return 0; + } + +In oneTBB ``tbb::parallel_do`` interface was removed. Instead, the functionality of adding new work +was included into the ``oneapi::tbb::parallel_for_each`` interface. + +The previous use case can be rewritten in oneTBB as follows: + +.. code:: cpp + + #include + #include + + int main() { + std::vector items = { 0, 1, 2, 3, 4, 5, 6, 7 }; + + oneapi::tbb::parallel_for_each( + items.begin(), items.end(), + [](int& i, tbb::feeder& feeder) { + + // ... do some work for item i ... + + if (add_more_parallel_work) + feeder.add(i); + } + ); + } + +Since both TBB and oneTBB support nested expressions, you can run additional functors from within an +already running functor. + +The previous use case can be rewritten using ``oneapi::tbb::task_group`` as: + +.. code:: cpp + + #include + #include + #include + + int main() { + std::vector items = { 0, 1, 2, 3, 4, 5, 6, 7 }; + + oneapi::tbb::task_group tg; + for (std::size_t i = 0; i < items.size(); ++i) { + tg.run([&i = items[i], &tg] { + + // ... do some work for item i ... + + if (add_more_parallel_work) + // Assuming OtherWork is defined. + tg.run(OtherWork{}); + + }); + } + tg.wait(); + } + + +Task recycling +-------------- +You can re-run the functor by passing ``*this`` to the ``oneapi::tbb::task_group::run()`` +method. The functor will be copied in this case. However, its state can be shared among instances: + +.. code:: cpp + + #include + #include + + struct SharedStateFunctor { + std::shared_ptr m_shared_data; + oneapi::tbb::task_group& m_task_group; + + void operator()() const { + // do some work processing m_shared_data + + if (has_more_work) + m_task_group.run(*this); + + // Note that this might be concurrently accessing m_shared_data already + } + }; + + int main() { + // Assuming Data is defined. + std::shared_ptr data = std::make_shared(/*params*/); + oneapi::tbb::task_group tg; + tg.run(SharedStateFunctor{data, tg}); + tg.wait(); + } + +Such patterns are particularly useful when the work within a functor is not completed but there is a +need for the task scheduler to react to outer circumstances, such as cancellation of group +execution. To avoid issues with concurrent access, it is recommended to submit it for re-execution +as the last step: + +.. code:: cpp + + #include + #include + + struct SharedStateFunctor { + std::shared_ptr m_shared_data; + oneapi::tbb::task_group& m_task_group; + + void operator()() const { + // do some work processing m_shared_data + + if (need_to_yield) { + m_task_group.run(*this); + return; + } + } + }; + + int main() { + // Assuming Data is defined. + std::shared_ptr data = std::make_shared(/*params*/); + oneapi::tbb::task_group tg; + tg.run(SharedStateFunctor{data, tg}); + tg.wait(); + } + + +Recycling as child or continuation +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +In oneTBB this kind of recycling is done manually. You have to track when it is time to run the +task: + +.. code:: cpp + + #include + #include + #include + #include + #include + + struct ContinuationTask { + ContinuationTask(std::vector& data, int& result) + : m_data(data), m_result(result) + {} + + void operator()() const { + for (const auto& item : m_data) + m_result += item; + } + + std::vector& m_data; + int& m_result; + }; + + struct ChildTask { + ChildTask(std::vector& data, int& result, + std::atomic& tasks_left, std::atomic& tasks_done, + oneapi::tbb::task_group& tg) + : m_data(data), m_result(result), m_tasks_left(tasks_left), m_tasks_done(tasks_done), m_tg(tg) + {} + + void operator()() const { + std::size_t index = --m_tasks_left; + m_data[index] = produce_item_for(index); + std::size_t done_num = ++m_tasks_done; + if (index % 2 != 0) { + // Recycling as child + m_tg.run(*this); + return; + } else if (done_num == m_data.size()) { + assert(m_tasks_left == 0); + // Spawning a continuation that does reduction + m_tg.run(ContinuationTask(m_data, m_result)); + } + } + std::vector& m_data; + int& m_result; + std::atomic& m_tasks_left; + std::atomic& m_tasks_done; + oneapi::tbb::task_group& m_tg; + }; + + + int main() { + int result = 0; + std::vector items(10, 0); + std::atomic tasks_left{items.size()}; + std::atomic tasks_done{0}; + + oneapi::tbb::task_group tg; + for (std::size_t i = 0; i < items.size(); i+=2) { + tg.run(ChildTask(items, result, tasks_left, tasks_done, tg)); + } + tg.wait(); + } + + +Scheduler Bypass +---------------- + +TBB ``task::execute()`` method can return a pointer to a task that can be executed next by the current thread. +This might reduce scheduling overheads compared to direct ``spawn``. Similar to ``spawn``, the returned task +is not guaranteed to be executed next by the current thread. + +.. code:: cpp + + #include + + // Assuming OtherTask is defined. + + struct Task : tbb::task { + task* execute(){ + // some work to do ... + + auto* other_p = new(this->parent().allocate_child()) OtherTask{}; + this->parent().add_ref_count(); + + return other_p; + } + }; + + int main(){ + // Assuming RootTask is defined. + RootTask& root = *new(tbb::task::allocate_root()) RootTask{}; + + Task& child = *new(root.allocate_child()) Task{/*params*/}; + + root.add_ref_count(); + + tbb::task_spawn(child); + + root.wait_for_all(); + } + +In oneTBB, this can be done using ``oneapi::tbb::task_group``. + +.. code:: cpp + + #include + + // Assuming OtherTask is defined. + + int main(){ + oneapi::tbb::task_group tg; + + tg.run([&tg](){ + //some work to do ... + + return tg.defer(OtherTask{}); + }); + + tg.wait(); + } + +Here ``oneapi::tbb::task_group::defer`` adds a new task into the ``tg``. However, the task is not put into a +queue of tasks ready for execution via ``oneapi::tbb::task_group::run``, but bypassed to the executing thread directly +via function return value. + +Deferred task creation +---------------------- +The TBB low-level task API separates the task creation from the actual spawning. This separation allows to +postpone the task spawning, while the parent task and final result production are blocked from premature leave. +For example, ``RootTask``, ``ChildTask``, and ``CallBackTask`` are the user-side functors that +inherit ``tbb::task`` and implement its interface. Then, blocking the ``RootTask`` from leaving prematurely +and waiting on it is implemented as follows: + +.. code:: cpp + + #include + + int main() { + // Assuming RootTask, ChildTask, and CallBackTask are defined. + RootTask& root = *new(tbb::task::allocate_root()) RootTask{}; + + ChildTask& child = *new(root.allocate_child()) ChildTask{/*params*/}; + CallBackTask& cb_task = *new(root.allocate_child()) CallBackTask{/*params*/}; + + root.set_ref_count(3); + + tbb::task::spawn(child); + + register_callback([cb_task&](){ + tbb::task::enqueue(cb_task); + }); + + root.wait_for_all(); + // Control flow will reach here only after both ChildTask and CallBackTask are executed, + // i.e. after the callback is called + } + +In oneTBB, this can be done using ``oneapi::tbb::task_group``. + +.. code:: cpp + + #include + + int main(){ + oneapi::tbb::task_group tg; + oneapi::tbb::task_arena arena; + // Assuming ChildTask and CallBackTask are defined. + + auto cb = tg.defer(CallBackTask{/*params*/}); + + register_callback([&tg, c = std::move(cb), &arena]{ + arena.enqueue(c); + }); + + tg.run(ChildTask{/*params*/}); + + + tg.wait(); + // Control flow gets here once both ChildTask and CallBackTask are executed + // i.e. after the callback is called + } + +Here ``oneapi::tbb::task_group::defer`` adds a new task into the ``tg``. However, the task is not spawned until +``oneapi::tbb::task_arena::enqueue`` is called. + +.. note:: + The call to ``oneapi::tbb::task_group::wait`` will not return control until both ``ChildTask`` and + ``CallBackTask`` are executed. diff --git a/_sources/main/tbb_userguide/Migration_Guide/Task_Scheduler_Init.rst b/_sources/main/tbb_userguide/Migration_Guide/Task_Scheduler_Init.rst new file mode 100644 index 0000000000..6acdb272eb --- /dev/null +++ b/_sources/main/tbb_userguide/Migration_Guide/Task_Scheduler_Init.rst @@ -0,0 +1,158 @@ +.. _Task_Scheduler_Init: + +Migrating from tbb::task_scheduler_init +======================================= + +``tbb::task_scheduler_init`` was a multipurpose functionality in the previous versions of Threading +Building Blocks (TBB). This section considers different use cases and how they can be covered with +oneTBB. + +Managing the number of threads +--------------------------------------- + +Querying the default number of threads +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +* `oneapi::tbb::info::default_concurrency() + `_ + returns the maximum concurrency that will be created by *default* in implicit or explicit ``task_arena``. + +* `oneapi::tbb::this_task_arena::max_concurrency() + `_ + returns the maximum number of threads available for the parallel algorithms within the current context + (or *default* if an implicit arena is not initialized) + +* `oneapi::tbb::global_control::active_value(tbb::global_control::max_allowed_parallelism) + `_ + returns the current limit of the thread pool (or *default* if oneTBB scheduler is not initialized) + +Setting the maximum concurrency +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +* `task_arena(/* max_concurrency */) + `_ + limits the maximum concurrency of the parallel algorithm running inside ``task_arena`` + +* `tbb::global_control(tbb::global_control::max_allowed_parallelism, /* max_concurrency */) + `_ + limits the total number of oneTBB worker threads + +Examples +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +The default parallelism: + +.. code:: cpp + + #include + #include + #include + #include + + int main() { + // Get the default number of threads + int num_threads = oneapi::tbb::info::default_concurrency(); + + // Run the default parallelism + oneapi::tbb::parallel_for( /* ... */ [] { + // Assert the maximum number of threads + assert(num_threads == oneapi::tbb::this_task_arena::max_concurrency()); + }); + + // Create the default task_arena + oneapi::tbb::task_arena arena; + arena.execute([]{ + oneapi::tbb::parallel_for( /* ... */ [] { + // Assert the maximum number of threads + assert(num_threads == oneapi::tbb::this_task_arena::max_concurrency()); + }); + }); + + return 0; + } + +The limited parallelism: + +.. code:: cpp + + #include + #include + #include + #include + #include + + int main() { + // Create the custom task_arena with four threads + oneapi::tbb::task_arena arena(4); + arena.execute([]{ + oneapi::tbb::parallel_for( /* ... */ [] { + // This arena is limited with for threads + assert(oneapi::tbb::this_task_arena::max_concurrency() == 4); + }); + }); + + // Limit the number of threads to two for all oneTBB parallel interfaces + oneapi::tbb::global_control global_limit(oneapi::tbb::global_control::max_allowed_parallelism, 2); + + // the default parallelism + oneapi::tbb::parallel_for( /* ... */ [] { + // No more than two threads is expected; however, tbb::this_task_arena::max_concurrency() can return a bigger value + int thread_limit = oneapi::tbb::global_control::active_value(oneapi::tbb::global_control::max_allowed_parallelism); + assert(thread_limit == 2); + }); + + arena.execute([]{ + oneapi::tbb::parallel_for( /* ... */ [] { + // No more than two threads is expected; however, tbb::this_task_arena::max_concurrency() is four + int thread_limit = oneapi::tbb::global_control::active_value(oneapi::tbb::global_control::max_allowed_parallelism); + assert(thread_limit == 2); + assert(tbb::this_task_arena::max_concurrency() == 4); + }); + }); + + return 0; + } + +Setting thread stack size +--------------------------------------- +Use `oneapi::tbb::global_control(oneapi::tbb::global_control::thread_stack_size, /* stack_size */) +`_ +to set the stack size for oneTBB worker threads: + +.. code:: cpp + + #include + #include + + int main() { + // Set 16 MB of the stack size for oneTBB worker threads. + // Note that the stack size of the main thread should be configured in accordace with the + // system documentation, e.g. at application startup moment + oneapi::tbb::global_control global_limit(tbb::global_control::thread_stack_size, 16 * 1024 * 1024); + + oneapi::tbb::parallel_for( /* ... */ [] { + // Create a big array in the stack + char big_array[10*1024*1024]; + }); + + return 0; + } + +Terminating oneTBB scheduler +--------------------------------------- + +`task_scheduler_handle `_ +allows waiting for oneTBB worker threads completion: + +.. code:: cpp + + #include + #include + + int main() { + oneapi::tbb::task_scheduler_handle handle{tbb::attach{}}; + // Do some parallel work here + oneapi::tbb::parallel_for(/* ... */); + oneapi::tbb::finalize(handle); + return 0; + } diff --git a/_sources/main/tbb_userguide/More_on_HashCompare.rst b/_sources/main/tbb_userguide/More_on_HashCompare.rst new file mode 100644 index 0000000000..5a9c9a725e --- /dev/null +++ b/_sources/main/tbb_userguide/More_on_HashCompare.rst @@ -0,0 +1,91 @@ +.. _More_on_HashCompare: + +More on HashCompare +=================== + + +There are several ways to make the ``HashCompare`` argument for +``concurrent_hash_map`` work for your own types. + + +- Specify the ``HashCompare`` argument explicitly + + +- Let the ``HashCompare`` default to ``tbb_hash_compare`` and do + one of the following: + + + - Define a specialization of template ``tbb_hash_compare``. + + +For example, if you have keys of type ``Foo``, and ``operator==`` is +defined for ``Foo``, you just have to provide a definition of +``tbb_hasher`` as shown below: + + +:: + + + size_t tbb_hasher(const Foo& f) { + size_t h = ...compute hash code for f... + return h; + }; + + +In general, the definition of ``tbb_hash_compare`` or +``HashCompare`` must provide two signatures: + + +- A method ``hash`` that maps a ``Key`` to a ``size_t`` + + +- A method ``equal`` that determines if two keys are equal + + +The signatures go together in a single class because *if two keys are +equal, then they must hash to the same value*, otherwise the hash table +might not work. You could trivially meet this requirement by always +hashing to ``0``, but that would cause tremendous inefficiency. Ideally, +each key should hash to a different value, or at least the probability +of two distinct keys hashing to the same value should be kept low. + + +The methods of ``HashCompare`` should be ``static`` unless you need to +have them behave differently for different instances. If so, then you +should construct the ``concurrent_hash_map`` using the constructor that +takes a ``HashCompare`` as a parameter. The following example is a +variation on an earlier example with instance-dependent methods. The +instance performs both case-sensitive or case-insensitive hashing, and +comparison, depending upon an internal flag ``ignore_case``. + + +:: + + + // Structure that defines hashing and comparison operations + class VariantHashCompare { + // If true, then case of letters is ignored. + bool ignore_case; + public: + size_t hash(const string& x) const { + size_t h = 0; + for(const char* s = x.c_str(); *s; s++) + h = (h*16777179)^*(ignore_case?tolower(*s):*s); + return h; + } + // True if strings are equal + bool equal(const string& x, const string& y) const { + if( ignore_case ) + strcasecmp(x.c_str(), y.c_str())==0; + else + return x==y; + } + VariantHashCompare(bool ignore_case_) : ignore_case(ignore_case_) {} + }; +   + + typedef concurrent_hash_map VariantStringTable; +   + + VariantStringTable CaseSensitiveTable(VariantHashCompare(false)); + VariantStringTable CaseInsensitiveTable(VariantHashCompare(true)); diff --git a/_sources/main/tbb_userguide/Mutex_Flavors.rst b/_sources/main/tbb_userguide/Mutex_Flavors.rst new file mode 100644 index 0000000000..3eaa79f0b5 --- /dev/null +++ b/_sources/main/tbb_userguide/Mutex_Flavors.rst @@ -0,0 +1,176 @@ +.. _Mutex_Flavors: + +Mutex Flavors +============= + + +Connoisseurs of mutexes distinguish various attributes of mutexes. It +helps to know some of these, because they involve tradeoffs of +generality and efficiency. Picking the right one often helps +performance. Mutexes can be described by the following qualities, also +summarized in the table below. + + +- **Scalable**. Some mutexes are called *scalable*. In a strict sense, + this is not an accurate name, because a mutex limits execution to one + thread at a time. A *scalable mutex* is one that does not do *worse* + than this. A mutex can do worse than serialize execution if the + waiting threads consume excessive processor cycles and memory + bandwidth, reducing the speed of threads trying to do real work. + Scalable mutexes are often slower than non-scalable mutexes under + light contention, so a non-scalable mutex may be better. When in + doubt, use a scalable mutex. + + +- **Fair**. Mutexes can be *fair* or *unfair*. A fair mutex lets + threads through in the order they arrived. Fair mutexes avoid + starving threads. Each thread gets its turn. However, unfair mutexes + can be faster, because they let threads that are running go through + first, instead of the thread that is next in line which may be + sleeping on account of an interrupt. + + +- **Yield or Block**. This is an implementation detail that impacts + performance. On long waits, an |full_name| + mutex either *yields* or *blocks*. Here *yields* means to + repeatedly poll whether progress can be made, and if not, temporarily + yield [#]_ the processor. To *block* means to yield the + processor until the mutex permits progress. Use the yielding mutexes + if waits are typically short and blocking mutexes if waits are + typically long. + + +The following is a summary of mutex behaviors: + + +- ``spin_mutex`` is non-scalable, unfair, non-recursive, and spins in + user space. It would seem to be the worst of all possible worlds, + except that it is *very fast* in *lightly contended* situations. If + you can design your program so that contention is somehow spread out + among many ``spin_mutex`` objects, you can improve performance over + using other kinds of mutexes. If a mutex is heavily contended, your + algorithm will not scale anyway. Consider redesigning the algorithm + instead of looking for a more efficient lock. + + +- ``mutex`` has behavior similar to the ``spin_mutex``. However, + the ``mutex`` *blocks* on long waits that makes it + resistant to high contention. + + +- ``queuing_mutex`` is scalable, fair, non-recursive, and spins in user + space. Use it when scalability and fairness are important. + + +- ``spin_rw_mutex`` and ``queuing_rw_mutex`` are similar to + ``spin_mutex`` and ``queuing_mutex``, but additionally support + *reader* locks. + + +- ``rw_mutex`` is similar to ``mutex``, but additionally support + *reader* locks. + + +- ``speculative_spin_mutex`` and ``speculative_spin_rw_mutex`` are + similar to ``spin_mutex`` and ``spin_rw_mutex``, but additionally + provide *speculative locking* on processors that support hardware + transaction memory. Speculative locking allows multiple threads + acquire the same lock, as long as there are no "conflicts" that may + generate different results than non-speculative locking. These + mutexes are *scalable* when work with low conflict rate, i.e. mostly + in speculative locking mode. + + +- ``null_mutex`` and ``null_rw_mutex`` do nothing. They can be useful + as template arguments. For example, suppose you are defining a + container template and know that some instantiations will be shared + by multiple threads and need internal locking, but others will be + private to a thread and not need locking. You can define the template + to take a Mutex type parameter. The parameter can be one of the real + mutex types when locking is necessary, and ``null_mutex`` when + locking is unnecessary. + + +.. container:: tablenoborder + + + .. list-table:: + :header-rows: 1 + + * - Mutex + - Scalable + - Fair + - Recursive + - Long Wait + - Size + * - \ ``spin_mutex`` + - no + - no + - no + - yields + - 1 byte + * - \ ``mutex`` + - ✓ + - no + - no + - blocks + - 1 byte + * - \ ``speculative_spin_mutex`` + - HW dependent + - no + - no + - yields + - 2 cache lines + * - \ ``queuing_mutex`` + - ✓ + - ✓ + - no + - yields + - 1 word + * - \ ``spin_rw_mutex`` + - no + - no + - no + - yields + - 1 word + * - \ ``spin_rw_mutex`` + - ✓ + - no + - no + - blocks + - 1 word + * - \ ``speculative_spin_rw_mutex`` + - HW dependent + - no + - no + - yields + - 3 cache lines + * - \ ``queuing_rw_mutex`` + - ✓ + - ✓ + - no + - yields + - 1 word + * - \ ``null_mutex`` [#]_ + - moot + - ✓ + - ✓ + - never + - empty + * - \ ``null_rw_mutex`` + - moot + - ✓ + - ✓ + - never + - empty + + + + +.. [#] The yielding is implemented via ``SwitchToThread()`` on Microsoft + Windows\* operating systems and by ``sched_yield()`` on other systems. + + +.. [#] Null mutexes are considered fair by oneTBB because they cannot cause + starvation. They lack any non-static data members. + diff --git a/_sources/main/tbb_userguide/Mutual_Exclusion.rst b/_sources/main/tbb_userguide/Mutual_Exclusion.rst new file mode 100644 index 0000000000..76ca8f9aa0 --- /dev/null +++ b/_sources/main/tbb_userguide/Mutual_Exclusion.rst @@ -0,0 +1,130 @@ +.. _Mutual_Exclusion: + +Mutual Exclusion +================ + + +Mutual exclusion controls how many threads can simultaneously run a +region of code. In |full_name|, mutual +exclusion is implemented by *mutexes* and *locks.* A mutex is an object +on which a thread can acquire a lock. Only one thread at a time can have +a lock on a mutex; other threads have to wait their turn. + + +The simplest mutex is ``spin_mutex``. A thread trying to acquire a lock +on a ``spin_mutex`` busy waits until it can acquire the lock. A +``spin_mutex`` is appropriate when the lock is held for only a few +instructions. For example, the following code uses a mutex +``FreeListMutex`` to protect a shared variable ``FreeList``. It checks +that only a single thread has access to ``FreeList`` at a time. + +:: + + Node* FreeList; + typedef spin_mutex FreeListMutexType; + FreeListMutexType FreeListMutex; +   + + Node* AllocateNode() { + Node* n; + { + FreeListMutexType::scoped_lock lock(FreeListMutex); + n = FreeList; + if( n ) + FreeList = n->next; + } + if( !n ) + n = new Node(); + return n; + } +   + + void FreeNode( Node* n ) { + FreeListMutexType::scoped_lock lock(FreeListMutex); + n->next = FreeList; + FreeList = n; + } + + +The constructor for ``scoped_lock`` waits until there are no other locks +on ``FreeListMutex``. The destructor releases the lock. The braces +inside routine ``AllocateNode`` may look unusual. Their role is to keep +the lifetime of the lock as short as possible, so that other waiting +threads can get their chance as soon as possible. + + +.. CAUTION:: + Be sure to name the lock object, otherwise it will be destroyed too + soon. For example, if the creation of the ``scoped_lock`` object in + the example is changed to + + :: + + FreeListMutexType::scoped_lock (FreeListMutex); + + then the ``scoped_lock`` is destroyed when execution reaches the + semicolon, which releases the lock *before* ``FreeList`` is accessed. + + +The following shows an alternative way to write ``AllocateNode``: + + +:: + + + Node* AllocateNode() { + Node* n; + FreeListMutexType::scoped_lock lock; + lock.acquire(FreeListMutex); + n = FreeList; + if( n ) + FreeList = n->next; + lock.release(); + if( !n ) + n = new Node(); + return n; + } + + +Method ``acquire`` waits until it can acquire a lock on the mutex; +method ``release`` releases the lock. + + +It is recommended that you add extra braces where possible, to clarify +to maintainers which code is protected by the lock. + + +If you are familiar with C interfaces for locks, you may be wondering +why there are not simply acquire and release methods on the mutex object +itself. The reason is that the C interface would not be exception safe, +because if the protected region threw an exception, control would skip +over the release. With the object-oriented interface, destruction of the +``scoped_lock`` object causes the lock to be released, no matter whether +the protected region was exited by normal control flow or an exception. +This is true even for our version of ``AllocateNode`` that used methods +``acquire`` and ``release –`` the explicit release causes the lock to be +released earlier, and the destructor then sees that the lock was +released and does nothing. + + +All mutexes in oneTBB have a similar interface, which not only makes +them easier to learn, but enables generic programming. For example, all +of the mutexes have a nested ``scoped_lock`` type, so given a mutex of +type ``M``, the corresponding lock type is ``M::scoped_lock``. + + +.. tip:: + It is recommended that you always use a ``typedef`` for the mutex + type, as shown in the previous examples. That way, you can change the + type of the lock later without having to edit the rest of the code. + In the examples, you could replace the ``typedef`` with + ``typedef queuing_mutex FreeListMutexType``, and the code would still + be correct. + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/Mutex_Flavors + ../tbb_userguide/Reader_Writer_Mutexes + ../tbb_userguide/UpgradeDowngrade + ../tbb_userguide/Lock_Pathologies diff --git a/_sources/main/tbb_userguide/Nodes.rst b/_sources/main/tbb_userguide/Nodes.rst new file mode 100644 index 0000000000..1e8333bbbb --- /dev/null +++ b/_sources/main/tbb_userguide/Nodes.rst @@ -0,0 +1,151 @@ +.. _Nodes: + +Flow Graph Basics: Nodes +======================== + + +A node is a class that inherits from oneapi::tbb::flow::graph_node and also +typically inherits from oneapi::tbb::flow::sender , oneapi::tbb::flow::receiver or +both. A node performs some operation, usually on an incoming message and +may generate zero or more output messages. Some nodes require more than +one input message or generate more than one output message. + + +While it is possible to define your own node types by inheriting from +graph_node, sender and receiver, it is more typical that predefined node +types are used to construct a graph. + + +A ``function_node`` is a predefined type available in ``flow_graph.h`` and +represents a simple function with one input and one output. The +constructor for a ``function_node`` takes three arguments: + + +:: + + + template< typename Body> function_node(graph &g, size_t concurrency, Body body) + + +.. container:: tablenoborder + + + .. list-table:: + :header-rows: 1 + + * - Parameter + - Description + * - Body + - Type of the body object. + * - g + - The graph the node belongs to. + * - concurrency + - The concurrency limit for the node. You can use the concurrency limit to control how many invocations of the node are allowed to proceed concurrently, from 1 (serial) to an unlimited number. + * - body + - User defined function object, or lambda expression, that is applied to the incoming message to generate the outgoing message. + + + + +Below is code for creating a simple graph that contains a single +function_node. In this example, a node n is constructed that belongs to +graph g, and has a second argument of 1, which allows at most 1 +invocation of the node to occur concurrently. The body is a lambda +expression that prints each value v that it receives, spins for v +seconds, prints the value again, and then returns v unmodified. The code +for the function spin_for is not provided. + + +:: + + + graph g; + function_node< int, int > n( g, 1, []( int v ) -> int { + cout << v; + spin_for( v ); + cout << v; + return v; + } ); + + +After the node is constructed in the example above, you can pass +messages to it, either by connecting it to other nodes using edges or by +invoking its function try_put. Using edges is described in the next +section. + + +:: + + + n.try_put( 1 ); + n.try_put( 2 ); + n.try_put( 3 ); + + +You can then wait for the messages to be processed by calling +wait_for_all on the graph object: + + +:: + + + g.wait_for_all(); + + +In the above example code, the function_node n was created with a +concurrency limit of 1. When it receives the message sequence 1, 2 and +3, the node n will spawn a task to apply the body to the first input, 1. +When that task is complete, it will then spawn another task to apply the +body to 2. And likewise, the node will wait for that task to complete +before spawning a third task to apply the body to 3. The calls to +try_put do not block until a task is spawned; if a node cannot +immediately spawn a task to process the message, the message will be +buffered in the node. When it is legal, based on concurrency limits, a +task will be spawned to process the next buffered message. + + +In the above graph, each message is processed sequentially. If however, +you construct the node with a different concurrency limit, parallelism +can be achieved: + + +:: + + + function_node< int, int > n( g, oneapi::tbb::flow::unlimited, []( int v ) -> int { + cout << v; + spin_for( v ); + cout << v; + return v; + } ); + + +You can use unlimited as the concurrency limit to instruct the library +to spawn a task as soon as a message arrives, regardless of how many +other tasks have been spawned. You can also use any specific value, such +as 4 or 8, to limit concurrency to at most 4 or 8, respectively. It is +important to remember that spawning a task does not mean creating a +thread. So while a graph may spawn many tasks, only the number of +threads available in the library's thread pool will be used to execute +these tasks. + + +Suppose you use unlimited in the function_node constructor instead and +call try_put on the node: + + +:: + + + n.try_put( 1 ); + n.try_put( 2 ); + n.try_put( 3 ); + g.wait_for_all(); + + +The library spawns three tasks, each one applying n's lambda expression +to one of the messages. If you have a sufficient number of threads +available on your system, then all three invocations of the body will +occur in parallel. If however, you have only one thread in the system, +they execute sequentially. + diff --git a/_sources/main/tbb_userguide/Non-Linear_Pipelines.rst b/_sources/main/tbb_userguide/Non-Linear_Pipelines.rst new file mode 100644 index 0000000000..b458801655 --- /dev/null +++ b/_sources/main/tbb_userguide/Non-Linear_Pipelines.rst @@ -0,0 +1,62 @@ +.. _Non-Linear_Pipelines: + +Non-Linear Pipelines +==================== + + +Template function ``parallel_pipeline`` supports only linear pipelines. +It does not directly handle more baroque plumbing, such as in the +diagram below. + + +.. container:: fignone + :name: image011 + + + |image0| + + +However, you can still use a pipeline for this. Just topologically sort +the filters into a linear order, like this: + + +The light gray arrows are the original arrows that are now implied by +transitive closure of the other arrows. It might seem that lot of +parallelism is lost by forcing a linear order on the filters, but in +fact the only loss is in the *latency* of the pipeline, not the +throughput. The latency is the time it takes a token to flow from the +beginning to the end of the pipeline. Given a sufficient number of +processors, the latency of the original non-linear pipeline is three +filters. This is because filters A and B could process the token +concurrently, and likewise filters D and E could process the token +concurrently. + + +.. container:: fignone + :name: image012 + + + |image1| + + +In the linear pipeline, the latency is five filters. The behavior of +filters A, B, D and E above may need to be modified in order to properly +handle objects that don’t need to be acted upon by the filter other than +to be passed along to the next filter in the pipeline. + + +The throughput remains the same, because regardless of the topology, the +throughput is still limited by the throughput of the slowest serial +filter. If ``parallel_pipeline`` supported non-linear pipelines, it +would add a lot of programming complexity, and not improve throughput. +The linear limitation of ``parallel_pipeline`` is a good tradeoff of +gain versus pain. + + +.. |image0| image:: Images/image011.jpg + :width: 281px + :height: 107px +.. |image1| image:: Images/image012.jpg + :width: 281px + :height: 107px + diff --git a/_sources/main/tbb_userguide/Package_Contents_os.rst b/_sources/main/tbb_userguide/Package_Contents_os.rst new file mode 100644 index 0000000000..2d9e0a2fe4 --- /dev/null +++ b/_sources/main/tbb_userguide/Package_Contents_os.rst @@ -0,0 +1,18 @@ +.. _Package_Contents: + +Package Contents +================ + + +|full_name| includes dynamic library files and header files for Windows\*, Linux\* +and macOS\* operating systems as described in this section. + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/Debug_Versus_Release_Libraries + ../tbb_userguide/Scalable_Memory_Allocator + ../tbb_userguide/Windows_OS_ug + ../tbb_userguide/Linux_OS + ../tbb_userguide/Mac_OS + diff --git a/_sources/main/tbb_userguide/Parallelizing_Complex_Loops.rst b/_sources/main/tbb_userguide/Parallelizing_Complex_Loops.rst new file mode 100644 index 0000000000..88b1cdba44 --- /dev/null +++ b/_sources/main/tbb_userguide/Parallelizing_Complex_Loops.rst @@ -0,0 +1,17 @@ +.. _Parallelizing_Complex_Loops: + +Parallelizing Complex Loops +=========================== + + +You can successfully parallelize many applications using only the +constructs in the **Parallelizing Simple Loops** section. However, some +situations call for other parallel patterns. This section describes the +support for some of these alternate patterns. + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/Cook_Until_Done_parallel_do + ../tbb_userguide/Working_on_the_Assembly_Line_pipeline + ../tbb_userguide/Summary_of_Loops_and_Pipelines \ No newline at end of file diff --git a/_sources/main/tbb_userguide/Parallelizing_Flow_Graph.rst b/_sources/main/tbb_userguide/Parallelizing_Flow_Graph.rst new file mode 100644 index 0000000000..5d3fc7bf1e --- /dev/null +++ b/_sources/main/tbb_userguide/Parallelizing_Flow_Graph.rst @@ -0,0 +1,102 @@ +.. _Parallelizing_Flow_Graph: + +Parallelizing Data Flow and Dependency Graphs +============================================= + + +In addition to loop parallelism, the |full_name| library also supports graph parallelism. +It's possible to create graphs that are highly scalable, but it is also possible to +create graphs that are completely sequential. + + +Using graph parallelism, computations are represented by nodes and the +communication channels between these computations are represented by +edges. When a node in the graph receives a message, a task is spawned to +execute its body object on the incoming message. Messages flow through +the graph across the edges that connect the nodes. The following +sections present two examples of applications that can be expressed as +graphs. + + +The following figure shows a *streaming* or *data flow* application +where a sequence of values is processed as each value passes through the +nodes in the graph. In this example, the sequence is created by a +function F. For each value in the sequence, G squares the value and H +cubes the value. J then takes each of the squared and cubed values and +adds them to a global sum. After all values in the sequence are +completely processed, sum is equal to the sum of the sequence of squares +and cubes from 1 to 10. In a streaming or data flow graph, the values +actually flow across the edges; the output of one node becomes the input +of its successor(s). + + +.. container:: fignone + :name: simple_data_flow_title + + + **Simple Data Flow Graph** + + + .. container:: imagecenter + + + |image0| + + +The following graphic shows a different form of graph application. In +this example, a dependence graph is used to establish a partial ordering +among the steps for making a peanut butter and jelly sandwich. In this +partial ordering, you must first get the bread before spreading the +peanut butter or jelly on the bread. You must spread on the peanut +butter before you put away the peanut butter jar, and likewise spread on +the jelly before you put away the jelly jar. And, you need to spread on +both the peanut butter and jelly before putting the two slices of bread +together. This is a partial ordering because, for example, it doesn't +matter if you spread on the peanut butter first or the jelly first. It +also doesn't matter if you finish making the sandwich before putting +away the jars. + + +.. container:: fignone + :name: dependence_graph_make_sandwitch + + + **Dependence Graph for Making a Sandwich** + + + .. container:: imagecenter + + + |image1| + + +While it can be inferred that resources, such as the bread, or the jelly +jar, are shared between ordered steps, it is not explicit in the graph. +Instead, only the required ordering of steps is explicit in a dependence +graph. For example, you must "Put jelly on 1 slice" **before** you "Put +away jelly jar". + + +The flow graph interface in the oneTBB library allows you to express +data flow and dependence graphs such as these, as well as more +complicated graphs that include cycles, conditionals, buffering and +more. If you express your application using the flow graph interface, +the runtime library spawns tasks to exploit the parallelism that is +present in the graph. For example, in the first example above, perhaps +two different values might be squared in parallel, or the same value +might be squared and cubed in parallel. Likewise in the second example, +the peanut butter might be spread on one slice of bread in parallel with +the jelly being spread on the other slice. The interface expresses what +is legal to execute in parallel, but allows the runtime library to +choose at runtime what will be executed in parallel. + + +The support for graph parallelism is contained within the namespace +``oneapi::tbb::flow`` and is defined in the ``flow_graph.h`` header file. + + +.. |image0| image:: Images/flow_graph.jpg +.. |image1| image:: Images/flow_graph_complex.jpg + :width: 440px + :height: 337px + diff --git a/_sources/main/tbb_userguide/Parallelizing_Simple_Loops_os.rst b/_sources/main/tbb_userguide/Parallelizing_Simple_Loops_os.rst new file mode 100644 index 0000000000..fce366598f --- /dev/null +++ b/_sources/main/tbb_userguide/Parallelizing_Simple_Loops_os.rst @@ -0,0 +1,40 @@ +.. _Parallelizing_Simple_Loops: + +Parallelizing Simple Loops +========================== + + +The simplest form of scalable parallelism is a loop of iterations that +can each run simultaneously without interfering with each other. The +following sections demonstrate how to parallelize simple loops. + + +.. note:: + |full_name| components are + defined in namespace ``tbb``. For brevity’s sake, the namespace is + explicit in the first mention of a component, but implicit + afterwards. + + +When compiling oneTBB programs, be sure to link in the oneTBB shared +library, otherwise undefined references will occur. The following table +shows compilation commands that use the debug version of the library. +Remove the "``_debug``" portion to link against the production version +of the library. + + +.. container:: tablenoborder + + + .. list-table:: + :header-rows: 1 + + * - Operating System + - Command line + * - Windows\* OS + - ``icl /MD example.cpp tbb_debug.lib`` + * - Linux\* OS + - ``icc example.cpp -ltbb_debug`` + + +.. include:: Parallelizing_Simple_Loops_toctree.rst \ No newline at end of file diff --git a/_sources/main/tbb_userguide/Parallelizing_Simple_Loops_toctree.rst b/_sources/main/tbb_userguide/Parallelizing_Simple_Loops_toctree.rst new file mode 100644 index 0000000000..f83bb1b244 --- /dev/null +++ b/_sources/main/tbb_userguide/Parallelizing_Simple_Loops_toctree.rst @@ -0,0 +1,11 @@ +.. _Parallelizing_Simple_Loops_toctree: + + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/Initializing_and_Terminating_the_Library + ../tbb_userguide/parallel_for_os + ../tbb_userguide/parallel_reduce + ../tbb_userguide/Advanced_Example + ../tbb_userguide/Advanced_Topic_Other_Kinds_of_Iteration_Spaces \ No newline at end of file diff --git a/_sources/main/tbb_userguide/Partitioner_Summary.rst b/_sources/main/tbb_userguide/Partitioner_Summary.rst new file mode 100644 index 0000000000..7cc5171296 --- /dev/null +++ b/_sources/main/tbb_userguide/Partitioner_Summary.rst @@ -0,0 +1,64 @@ +.. _Partitioner_Summary: + +Partitioner Summary +=================== + + +The parallel loop templates ``parallel_for`` and ``parallel_reduce`` +take an optional *partitioner* argument, which specifies a strategy for +executing the loop. The following table summarizes partitioners and +their effect when used in conjunction with ``blocked_range``. + + +.. container:: tablenoborder + + + .. list-table:: + :header-rows: 1 + + * - Partitioner + - Description + - When Used with ``blocked_range(i,j,g)`` + * - ``simple_partitioner`` + - Chunksize bounded by grain size. + - ``g/2 ≤ chunksize ≤ g`` + * - ``auto_partitioner`` (default) + - Automatic chunk size. + - ``g/2 ≤ chunksize`` + * - ``affinity_partitioner`` + - Automatic chunk size, cache affinity and uniform distribution of iterations. + - ``g/2 ≤ chunksize`` + * - ``static_partitioner`` + - Deterministic chunk size, cache affinity and uniform distribution of iterations without load balancing. + - ``max(g/3, problem_size/num_of_resources) ≤ chunksize`` + + + + +An ``auto_partitioner`` is used when no partitioner is specified. In +general, the ``auto_partitioner`` or ``affinity_partitioner`` should be +used, because these tailor the number of chunks based on available +execution resources. ``affinity_partitioner`` and ``static_partitioner`` +may take advantage of ``Range`` ability to split in a given ratio (see +"Advanced Topic: Other Kinds of Iteration Spaces") for distributing +iterations in nearly equal chunks between computing resources. + + +``simple_partitioner`` can be useful in the following situations: + + +- The subrange size for ``operator()`` must not exceed a limit. That + might be advantageous, for example, if your ``operator()`` needs a + temporary array proportional to the size of the range. With a limited + subrange size, you can use an automatic variable for the array + instead of having to use dynamic memory allocation. + + +- A large subrange might use cache inefficiently. For example, suppose + the processing of a subrange involves repeated sweeps over the same + memory locations. Keeping the subrange below a limit might enable the + repeatedly referenced memory locations to fit in cache. + + +- You want to tune to a specific machine. + diff --git a/_sources/main/tbb_userguide/Predefined_Node_Types.rst b/_sources/main/tbb_userguide/Predefined_Node_Types.rst new file mode 100644 index 0000000000..14c009f0d8 --- /dev/null +++ b/_sources/main/tbb_userguide/Predefined_Node_Types.rst @@ -0,0 +1,54 @@ +.. _Predefined_Node_Types: + +Predefined Node Types +===================== + + +You can define your own node types by inheriting from class graph_node, +class sender and class receiver but it is likely that you can create +your graph with the predefined node types already available in +flow_graph.h. Below is a table that lists all of the predefined types +with a basic description. See the Developer Reference for a more +detailed description of each node. + + +.. container:: tablenoborder + + + .. list-table:: + :header-rows: 1 + :widths: 25 25 + + * - Predefined Node Type + - Description + * - input_node + - A single-output node, with a generic output type. + When activated, it executes a user body to generate its output. Its body is invoked if downstream nodes have accepted the previous generated output. + Otherwise, the previous output is temporarily buffered until it is accepted downstream and then the body is again invoked. + * - function_node + - A single-input single-output node that broadcasts its output to all successors. Has generic input and output types. Executes a user body, and has controllable concurrency level and buffering policy. For each input exactly one output is returned. + * - continue_node + - A single-input, single-output node that broadcasts its output to all successors. It has a single input that requires 1 or more inputs of type continue_msg and has a generic output type. It executes a user body when it receives N continue_msg objects at its input. N is equal to the number of predecessors plus any additional offset assigned at construction time. + * - multifunction_node + - A single-input multi-output node. It has a generic input type and several generic output types. It executes a user body, and has controllable concurrency level and buffering policy. The body can output zero or more messages on each output port. + * - broadcast_node + - A single-input, single-output node that broadcasts each message received to all successors. Its input and output are of the same generic type. It does not buffer messages. + * - buffer_node, queue_node, priority_queue_node, and sequencer_node. + - Single-input, single-output nodes that buffer messages and send their output to one successor. The order in which the messages are sent are node specific (see the Developer Reference). These nodes are unique in that they send to only a single successor and not all successors. + * - join_node + - A multi-input, single-output node. There are several generic input types and the output type is a tuple of these generic types. The node combines one message from each input port to create a tuple that is broadcast to all successors. The policy used to combine messages is selectable as queueing, reserving or tag-matching. + * - split_node + - A single-input, multi-output node. The input type is a tuple of generic types and there is one output port for each of the types in the tuple. The node receives a tuple of values and outputs each element of the tuple on a corresponding output port. + * - write_once_node, overwrite_node + - Single-input, single-output nodes that buffer a single message and broadcast their outputs to all successors. After broadcast, the nodes retain the last message received, so it is available to any future successor. A write_once_node will only accept the first message it receives, while the overwrite_node will accept all messages, broadcasting them to all successors, and replacing the old value with the new. + * - limiter_node + - A multi-input, single output node that broadcasts its output to all successors. The main input type and output type are of the same generic type. The node increments an internal counter when it broadcasts a message. If the increment causes it to reach its user-assigned threshold, it will broadcast no more messages. A special input port can be used to adjust the internal count, allowing further messages to be broadcast. The node does not buffer messages. + * - indexer_node + - A multi-input, single-output node that broadcasts its output message to all of its successors. The input type is a list of generic types and the output type is a tagged_msg. The message is of one of the types listed in the input and the tag identifies the port on which the message was received. Messages are broadcast individually as they arrive at the input ports. + * - composite_node + - A node that might have 0, 1 or multiple ports for both input and output. The composite_node packages a group of other nodes together and maintains a tuple of references to ports that border it. This allows for the corresponding ports of the composite_node to be used to make edges which hitherto would have been made from the actual nodes in the composite_node. + * - async_node (preview feature) + - A node that allows a flow graph to communicate with an external activity managed by the user or another runtime. This node receives messages of generic type, invokes the user-provided body to submit a message to an external activity. The external activity can use a special interface to return a generic type and put it to all successors of async_node. + + + diff --git a/_sources/main/tbb_userguide/Reader_Writer_Mutexes.rst b/_sources/main/tbb_userguide/Reader_Writer_Mutexes.rst new file mode 100644 index 0000000000..0303d0c31a --- /dev/null +++ b/_sources/main/tbb_userguide/Reader_Writer_Mutexes.rst @@ -0,0 +1,21 @@ +.. _Reader_Writer_Mutexes: + +Reader Writer Mutexes +===================== + + +Mutual exclusion is necessary when at least one thread *writes* to a +shared variable. But it does no harm to permit multiple readers into a +protected region. The reader-writer variants of the mutexes, denoted by +``_rw_`` in the class names, enable multiple readers by distinguishing +*reader locks* from *writer locks.* There can be more than one reader +lock on a given mutex. + + +Requests for a reader lock are distinguished from requests for a writer +lock via an extra boolean parameter in the constructor for +``scoped_lock``. The parameter is false to request a reader lock and +true to request a writer lock. It defaults to ``true`` so that when +omitted, a ``spin_rw_mutex`` or ``queuing_rw_mutex`` behaves like its +non-``_rw_`` counterpart. + diff --git a/_sources/main/tbb_userguide/References.rst b/_sources/main/tbb_userguide/References.rst new file mode 100644 index 0000000000..d6ab0d3901 --- /dev/null +++ b/_sources/main/tbb_userguide/References.rst @@ -0,0 +1,19 @@ +.. _References: + +References +========== + + +**[1]**   "Memory Consistency & .NET", Arch D. Robison, Dr. Dobb’s +Journal, April 2003. + + +**[2]**   A Formal Specification of Intel® Itanium® Processor Family +Memory Ordering, Intel Corporation, October 2002. + + +**[3]**   "Cilk: An Efficient Multithreaded Runtime System", Robert +Blumofe, Christopher Joerg, Bradley Kuszmaul, C. Leiserson, and Keith +Randall, Proceedings of the fifth ACM SIGPLAN symposium on Principles +and practice of parallel programming, 1995. + diff --git a/_sources/main/tbb_userguide/Scalable_Memory_Allocator.rst b/_sources/main/tbb_userguide/Scalable_Memory_Allocator.rst new file mode 100644 index 0000000000..922033b76e --- /dev/null +++ b/_sources/main/tbb_userguide/Scalable_Memory_Allocator.rst @@ -0,0 +1,15 @@ +.. _Scalable_Memory_Allocator: + +Scalable Memory Allocator +========================= + + +Both the debug and release versions of |full_name| +consists of two dynamic shared libraries, one with +general support and the other with a scalable memory allocator. The +latter is distinguished by ``malloc`` in its name. For example, the +release versions for Windows\* OS are ``tbb.dll`` and ``tbbmalloc.dll`` +respectively. Applications may choose to use only the general library, +or only the scalable memory allocator, or both. See the links below for +more information on memory allocation. + diff --git a/_sources/main/tbb_userguide/Summary_of_Containers.rst b/_sources/main/tbb_userguide/Summary_of_Containers.rst new file mode 100644 index 0000000000..53b7049c96 --- /dev/null +++ b/_sources/main/tbb_userguide/Summary_of_Containers.rst @@ -0,0 +1,11 @@ +.. _Summary_of_Containers: + +Summary of Containers +===================== + + +The high-level containers in |full_name| +enable common idioms for concurrent access. They are suitable for +scenarios where the alternative would be a serial container with a lock +around it. + diff --git a/_sources/main/tbb_userguide/Summary_of_Loops_and_Pipelines.rst b/_sources/main/tbb_userguide/Summary_of_Loops_and_Pipelines.rst new file mode 100644 index 0000000000..a549d293dc --- /dev/null +++ b/_sources/main/tbb_userguide/Summary_of_Loops_and_Pipelines.rst @@ -0,0 +1,10 @@ +.. _Summary_of_Loops_and_Pipelines: + +Summary of Loops and Pipelines +============================== + +The high-level loop and pipeline templates in |full_name| +give you efficient scalable ways to exploit the power of multi-core chips without having to start from scratch. +They let you design your software at a high task-pattern level and not worry about low-level manipulation of threads. +Because they are generic, you can customize them to your specific needs. +Have fun using these templates to unlock the power of multi-core. diff --git a/_sources/main/tbb_userguide/Task-Based_Programming.rst b/_sources/main/tbb_userguide/Task-Based_Programming.rst new file mode 100644 index 0000000000..94e53545ee --- /dev/null +++ b/_sources/main/tbb_userguide/Task-Based_Programming.rst @@ -0,0 +1,92 @@ +.. _Task-Based_Programming: + +Task-Based Programming +====================== + + +When striving for performance, programming in terms of threads can be a +poor way to do multithreaded programming. It is much better to formulate +your program in terms of *logical tasks*, not threads, for several +reasons. + + +- Matching parallelism to available resources + + +- Faster task startup and shutdown + + +- More efficient evaluation order + + +- Improved load balancing + + +- Higher–level thinking + + +The following paragraphs explain these points in detail. + + +The threads you create with a threading package are *logical* threads, +which map onto the *physical threads* of the hardware. For computations +that do not wait on external devices, highest efficiency usually occurs +when there is exactly one running logical thread per physical thread. +Otherwise, there can be inefficiencies from the mismatch\ *. +Undersubscription* occurs when there are not enough running logical +threads to keep the physical threads working. *Oversubscription* occurs +when there are more running logical threads than physical threads. +Oversubscription usually leads to *time sliced* execution of logical +threads, which incurs overheads as discussed in Appendix A, *Costs of +Time Slicing*. The scheduler tries to avoid oversubscription, by having +one logical thread per physical thread, and mapping tasks to logical +threads, in a way that tolerates interference by other threads from the +same or other processes. + + +The key advantage of tasks versus logical threads is that tasks are much +*lighter weight* than logical threads. On Linux systems, starting and +terminating a task is about 18 times faster than starting and +terminating a thread. On Windows systems, the ratio is more than 100. +This is because a thread has its own copy of a lot of resources, such as +register state and a stack. On Linux, a thread even has its own process +id. A task in |full_name|, in contrast, is +typically a small routine, and also, cannot be preempted at the task +level (though its logical thread can be preempted). + + +Tasks in oneTBB are efficient too because *the scheduler is unfair*. Thread schedulers typically +distribute time slices in a round-robin fashion. This distribution is +called "fair", because each logical thread gets its fair share of time. +Thread schedulers are typically fair because it is the safest strategy +to undertake without understanding the higher-level organization of a +program. In task-based programming, the task scheduler does have some +higher-level information, and so can sacrifice fairness for efficiency. +Indeed, it often delays starting a task until it can make useful +progress. + + +The scheduler does *load balancing*. In addition to using the right +number of threads, it is important to distribute work evenly across +those threads. As long as you break your program into enough small +tasks, the scheduler usually does a good job of assigning tasks to +threads to balance load. With thread-based programming, you are often +stuck dealing with load-balancing yourself, which can be tricky to get +right. + + +.. tip:: + Design your programs to try to create many more tasks than there are + threads, and let the task scheduler choose the mapping from tasks to + threads. + + +Finally, the main advantage of using tasks instead of threads is that +they let you think at a higher, task-based, level. With thread-based +programming, you are forced to think at the low level of physical +threads to get good efficiency, because you have one logical thread per +physical thread to avoid undersubscription or oversubscription. You also +have to deal with the relatively coarse grain of threads. With tasks, +you can concentrate on the logical dependences between tasks, and leave +the efficient scheduling to the scheduler. + diff --git a/_sources/main/tbb_userguide/Task_Scheduler_Bypass.rst b/_sources/main/tbb_userguide/Task_Scheduler_Bypass.rst new file mode 100644 index 0000000000..c198f6ac6b --- /dev/null +++ b/_sources/main/tbb_userguide/Task_Scheduler_Bypass.rst @@ -0,0 +1,20 @@ +.. _Task_Scheduler_Bypass: + +Task Scheduler Bypass +===================== + +Scheduler bypass is an optimization where you directly specify the next task to run. +According to the rules of execution described in :doc:`How Task Scheduler Works `, +the spawning of the new task to be executed by the current thread involves the next steps: + + - Push a new task onto the thread's deque. + - Continue to execute the current task until it is completed. + - Take a task from the thread's deque, unless it is stolen by another thread. + +Steps 1 and 3 introduce unnecessary deque operations or, even worse, allow stealing that can hurt +locality without adding significant parallelism. These problems can be avoided by using "Task Scheduler Bypass" technique to directly point the preferable task to be executed next +instead of spawning it. When, as described in :doc:`How Task Scheduler Works `, +the returned task becomes the first candidate for the next task to be executed by the thread. Furthermore, this approach almost guarantees that +the task is executed by the current thread and not by any other thread. + +Please note that at the moment the only way to use this optimization is to use `preview feature of ``onepai::tbb::task_group`` \ No newline at end of file diff --git a/_sources/main/tbb_userguide/The_Task_Scheduler.rst b/_sources/main/tbb_userguide/The_Task_Scheduler.rst new file mode 100644 index 0000000000..d9e6056e1c --- /dev/null +++ b/_sources/main/tbb_userguide/The_Task_Scheduler.rst @@ -0,0 +1,21 @@ +.. _The_Task_Scheduler: + +The Task Scheduler +================== + + +This section introduces the |full_name| +*task scheduler*. The task scheduler is the engine that powers the loop +templates. When practical, use the loop templates instead of +the task scheduler, because the templates hide the complexity of the +scheduler. However, if you have an algorithm that does not naturally map +onto one of the high-level templates, use the task scheduler. + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/Task-Based_Programming + ../tbb_userguide/When_Task-Based_Programming_Is_Inappropriate + ../tbb_userguide/How_Task_Scheduler_Works + ../tbb_userguide/Task_Scheduler_Bypass + ../tbb_userguide/Guiding_Task_Scheduler_Execution \ No newline at end of file diff --git a/_sources/main/tbb_userguide/Throughput_of_pipeline.rst b/_sources/main/tbb_userguide/Throughput_of_pipeline.rst new file mode 100644 index 0000000000..9d1c906a17 --- /dev/null +++ b/_sources/main/tbb_userguide/Throughput_of_pipeline.rst @@ -0,0 +1,35 @@ +.. _Throughput_of_pipeline: + +Throughput of pipeline +====================== + + +The throughput of a pipeline is the rate at which tokens flow through +it, and is limited by two constraints. First, if a pipeline is run with +``N`` tokens, then obviously there cannot be more than ``N`` operations +running in parallel. Selecting the right value of ``N`` may involve some +experimentation. Too low a value limits parallelism; too high a value +may demand too many resources (for example, more buffers). Second, the +throughput of a pipeline is limited by the throughput of the slowest +sequential filter. This is true even for a pipeline with no parallel +filters. No matter how fast the other filters are, the slowest +sequential filter is the bottleneck. So in general you should try to +keep the sequential filters fast, and when possible, shift work to the +parallel filters. + + +The text processing example has relatively poor speedup, because the +serial filters are limited by the I/O speed of the system. Indeed, even +with files that are on a local disk, you are unlikely to see a speedup +much more than 2. To really benefit from a pipeline, the parallel +filters need to be doing some heavy lifting compared to the serial +filters. + + +The window size, or sub-problem size for each token, can also limit +throughput. Making windows too small may cause overheads to dominate the +useful work. Making windows too large may cause them to spill out of +cache. A good guideline is to try for a large window size that still +fits in cache. You may have to experiment a bit to find a good window +size. + diff --git a/_sources/main/tbb_userguide/Timing.rst b/_sources/main/tbb_userguide/Timing.rst new file mode 100644 index 0000000000..89c2f695f4 --- /dev/null +++ b/_sources/main/tbb_userguide/Timing.rst @@ -0,0 +1,52 @@ +.. _Timing: + +Timing +====== + + +When measuring the performance of parallel programs, it is usually *wall +clock* time, not CPU time, that matters. The reason is that better +parallelization typically increases aggregate CPU time by employing more +CPUs. The goal of parallelizing a program is usually to make it run +*faster* in real time. + + +The class ``tick_count`` in |full_name| +provides a simple interface for measuring wall clock time. A +``tick_count`` value obtained from the static method tick_count::now() +represents the current absolute time. Subtracting two ``tick_count`` +values yields a relative time in ``tick_count::interval_t``, which you +can convert to seconds, as in the following example: + + +:: + + + tick_count t0 = tick_count::now(); + ... do some work ... + tick_count t1 = tick_count::now(); + printf("work took %g seconds\n",(t1-t0).seconds()); + + + + +Unlike some timing interfaces, ``tick_count`` is guaranteed to be safe +to use across threads. It is valid to subtract ``tick_count`` values +that were created by different threads. A ``tick_count`` difference can +be converted to seconds. + + +The resolution of ``tick_count`` corresponds to the highest resolution +timing service on the platform that is valid across threads in the same +process. Since the CPU timer registers are *not* valid across threads on +some platforms, this means that the resolution of tick_count can not be +guaranteed to be consistent across platforms. + + +.. note:: + + On Linux\* OS, you may need to add -lrt to the linker command when + you use oneapi::tbb::tick_count class. For more information, see + `http://fedoraproject.org/wiki/Features/ChangeInImplicitDSOLinking + `_. + diff --git a/_sources/main/tbb_userguide/UpgradeDowngrade.rst b/_sources/main/tbb_userguide/UpgradeDowngrade.rst new file mode 100644 index 0000000000..11324b92e3 --- /dev/null +++ b/_sources/main/tbb_userguide/UpgradeDowngrade.rst @@ -0,0 +1,51 @@ +.. _UpgradeDowngrade: + +Upgrade/Downgrade +================= + + +It is possible to upgrade a reader lock to a writer lock, by using the +method ``upgrade_to_writer``. Here is an example. + + +:: + + + std::vector MyVector; + typedef spin_rw_mutex MyVectorMutexType; + MyVectorMutexType MyVectorMutex; +   + + void AddKeyIfMissing( const string& key ) { + // Obtain a reader lock on MyVectorMutex + MyVectorMutexType::scoped_lock lock(MyVectorMutex,/*is_writer=*/false); + size_t n = MyVector.size(); + for( size_t i=0; i`` requires the |full_name| +scalable memory allocator library as +described in **Scalable Memory Allocator**. It does not require the +oneTBB general library, and can be used independently of the rest of +oneTBB. + + +The templates ``tbb_allocator`` and ``cache_aligned_allocator`` +use the scalable allocator library if it is present otherwise it reverts +to using ``malloc`` and ``free``. Thus, you can use these templates even +in applications that choose to omit the scalable memory allocator +library. + + +The rest of |full_name| can be used +with or without the oneTBB scalable memory allocator library. + + +.. container:: tablenoborder + + + .. list-table:: + :header-rows: 1 + + * - Template + - Requirements + - Notes + * - \ ``scalable_allocator`` + - |full_name| scalable memory allocator library. See **Scalable Memory Allocator**. + -   + * - \ ``tbb_allocator`` \ ``cache_aligned_allocator`` + -   + - Uses the scalable allocator library if it is present, otherwise it reverts to using ``malloc`` and ``free``. + + + diff --git a/_sources/main/tbb_userguide/Windows_C_Dynamic_Memory_Interface_Replacement.rst b/_sources/main/tbb_userguide/Windows_C_Dynamic_Memory_Interface_Replacement.rst new file mode 100644 index 0000000000..cd2d2e1a93 --- /dev/null +++ b/_sources/main/tbb_userguide/Windows_C_Dynamic_Memory_Interface_Replacement.rst @@ -0,0 +1,83 @@ +.. _Windows_C_Dynamic_Memory_Interface_Replacement: + +Windows\* OS C/C++ Dynamic Memory Interface Replacement +======================================================= + + +Release version of the proxy library is ``tbbmalloc_proxy.dll``, debug +version is ``tbbmalloc_proxy_debug.dll``. + + +The following dynamic memory functions are replaced: + + +- Standard C library functions: ``malloc``, ``calloc``, ``realloc``, + ``free`` + + +- Replaceable global C++ operators ``new`` and ``delete`` + + +- Microsoft\* C run-time library functions: ``_msize``, + ``_aligned_malloc``, ``_aligned_realloc``, ``_aligned_free``, + ``_aligned_msize`` + + +.. note:: + Replacement of memory allocation functions is not supported for + Universal Windows Platform applications. + + +To do the replacement use one of the following methods: + + +- Add the following header to a source code of any binary which is + loaded during application startup. + + + :: + + + #include "oneapi/tbb/tbbmalloc_proxy.h" + + +- Alternatively, add the following parameters to the linker options for + the .exe or .dll file that is loaded during application startup. + + For 32-bit code (note the triple underscore): + + + :: + + + tbbmalloc_proxy.lib /INCLUDE:"___TBB_malloc_proxy" + + For 64-bit code (note the double underscore): + + + :: + + + tbbmalloc_proxy.lib /INCLUDE:"__TBB_malloc_proxy" + + +The OS program loader must be able to find the proxy library and the +scalable memory allocator library at program load time. For that you may +include the directory containing the libraries in the ``PATH`` +environment variable. + + +The replacement uses in-memory binary instrumentation of Visual C++\* +runtime libraries. To ensure correctness, it must first recognize a +subset of dynamic memory functions in these libraries. If a problem +occurs, the replacement is skipped, and the program continues to use the +standard memory allocation functions. You can use the ``TBB_malloc_replacement_log`` +function to check if the replacement has succeeded and to get additional information. + + +Set the ``TBB_MALLOC_DISABLE_REPLACEMENT`` environment variable to 1 to +disable replacement for a specific program invocation. In this case, the +program will use standard dynamic memory allocation functions. Note that +the oneTBB memory allocation libraries are still required for the +program to start even if their usage is disabled. + diff --git a/_sources/main/tbb_userguide/Windows_OS_ug.rst b/_sources/main/tbb_userguide/Windows_OS_ug.rst new file mode 100644 index 0000000000..85fc3306ce --- /dev/null +++ b/_sources/main/tbb_userguide/Windows_OS_ug.rst @@ -0,0 +1,66 @@ +.. _Windows_OS_ug: + +Windows\* +========= + +This section uses <*tbb_install_dir*> to indicate the top-level +installation directory. The following table describes the subdirectory +structure for Windows\*, relative to <*tbb_install_dir*>. + +.. container:: tablenoborder + + + .. list-table:: + :header-rows: 1 + + * - Item + - Location + - Environment Variable + * - Header files + - | ``include\oneapi\tbb.h`` + | ``include\oneapi\tbb\*.h`` + - ``INCLUDE`` + * - .lib files + - ``lib\\vc\.lib``\ + - ``LIB`` + * - .dll files + - ``redist\\vc\.dll`` + - ``PATH`` + * - .pdb files + - Same as corresponding ``.dll`` file. + - \ + +Where + +* ```` - ``ia32`` or ``intel64`` + + .. note:: Starting with oneTBB 2022.0, 32-bit binaries are supported only by the open-source version of the library. + +* ```` - ``tbb``, ``tbbmalloc``, ``tbbmalloc_proxy`` or ``tbbbind`` +* ```` + + - ``14`` - use for dynamic linkage with the CRT + + - ``14_uwp`` - use for Windows 10 Universal Windows applications + + - ``14_uwd`` - use for Universal Windows Drivers + + - ``_mt`` - use for static linkage with the CRT + +* ```` - ``_debug`` or empty +* ```` - binary version + +The last column shows, which environment variables are used by the +Microsoft\* Visual C++\* or Intel® C++ Compiler Classic or Intel® oneAPI DPC++/C++ Compiler, to find these +subdirectories. + +.. CAUTION:: + Ensure that the relevant product directories are mentioned by the + environment variables; otherwise the compiler might not find the + required files. + + +.. note:: + Microsoft\* C/C++ run-time libraries come in static and dynamic + forms. Either can be used with oneTBB. Linking to the oneTBB library + is always dynamic. diff --git a/_sources/main/tbb_userguide/Working_on_the_Assembly_Line_pipeline.rst b/_sources/main/tbb_userguide/Working_on_the_Assembly_Line_pipeline.rst new file mode 100644 index 0000000000..15299b5151 --- /dev/null +++ b/_sources/main/tbb_userguide/Working_on_the_Assembly_Line_pipeline.rst @@ -0,0 +1,356 @@ +.. _Working_on_the_Assembly_Line_pipeline: + +Working on the Assembly Line: parallel_pipeline +=============================================== + + +*Pipelining* is a common parallel pattern that mimics a traditional +manufacturing assembly line. Data flows through a series of pipeline +filters and each filter processes the data in some way. Given an +incoming stream of data, some of these filters can operate in parallel, +and others cannot. For example, in video processing, some operations on +frames do not depend on other frames, and so can be done on multiple +frames at the same time. On the other hand, some operations on frames +require processing prior frames first. + + +The |full_name| classes +``parallel_pipeline`` and filter implement the pipeline pattern. A +simple text processing example will be used to demonstrate the usage of +``parallel_pipeline`` and filter to perform parallel formatting. The +example reads a text file, squares each decimal numeral in the text, and +writes the modified text to a new file. Below is a picture of the +pipeline. + + +.. CAUTION:: + Since the body object provided to the filters of the + ``parallel_pipeline`` might be copied, its ``operator()`` should not + modify the body. Otherwise the modification might or might not become + visible to the thread that invoked ``parallel_pipeline``, depending + upon whether ``operator()`` is acting on the original or a copy. As a + reminder of this nuance, ``parallel_pipeline`` requires that the body + object's ``operator()`` be declared ``const``. + + +.. container:: tablenoborder + + + .. list-table:: + :header-rows: 0 + + * - Read chunk from input file + - |image0| + - Square numerals in chunk + - |image1| + - Write chunk to output file + + + + +Assume that the raw file I/O is sequential. The squaring filter can be +done in parallel. That is, if you can serially read ``n`` chunks very +quickly, you can transform each of the ``n`` chunks in parallel, as long +as they are written in the proper order to the output file. Though the +raw I/O is sequential, the formatting of input and output can be moved +to the middle filter, and thus be parallel. + + +To amortize parallel scheduling overheads, the filters operate on chunks +of text. Each input chunk is approximately 4000 characters. Each chunk +is represented by an instance of class ``TextSlice``: + + +:: + + + // Holds a slice of text. + /** Instances *must* be allocated/freed using methods herein, because the C++ declaration + represents only the header of a much larger object in memory. */ + class TextSlice { + // Pointer to one past last character in sequence + char* logical_end; + // Pointer to one past last available byte in sequence. + char* physical_end; + public: + // Allocate a TextSlice object that can hold up to max_size characters. + static TextSlice* allocate( size_t max_size ) { + // +1 leaves room for a terminating null character. + TextSlice* t = (TextSlice*)oneapi::tbb::tbb_allocator().allocate( sizeof(TextSlice)+max_size+1 ); + t->logical_end = t->begin(); + t->physical_end = t->begin()+max_size; + return t; + } + // Free this TextSlice object + void free() { + oneapi::tbb::tbb_allocator().deallocate((char*)this, sizeof(TextSlice)+(physical_end-begin())+1); + } + // Pointer to beginning of sequence + char* begin() {return (char*)(this+1);} + // Pointer to one past last character in sequence + char* end() {return logical_end;} + // Length of sequence + size_t size() const {return logical_end-(char*)(this+1);} + // Maximum number of characters that can be appended to sequence + size_t avail() const {return physical_end-logical_end;} + // Append sequence [first,last) to this sequence. + void append( char* first, char* last ) { + memcpy( logical_end, first, last-first ); + logical_end += last-first; + } + // Set end() to given value. + void set_end( char* p ) {logical_end=p;} + }; + + +Below is the top-level code for building and running the pipeline. +``TextSlice`` objects are passed between filters using pointers to avoid +the overhead of copying a ``TextSlice``. + + +:: + + + void RunPipeline( int ntoken, FILE* input_file, FILE* output_file ) { + oneapi::tbb::parallel_pipeline( + ntoken, + oneapi::tbb::make_filter( + oneapi::tbb::filter_mode::serial_in_order, MyInputFunc(input_file) ) + & + oneapi::tbb::make_filter( + oneapi::tbb::filter_mode::parallel, MyTransformFunc() ) + & + oneapi::tbb::make_filter( + oneapi::tbb::filter_mode::serial_in_order, MyOutputFunc(output_file) ) ); + } + + +The parameter ``ntoken`` to method ``parallel_pipeline`` controls the +level of parallelism. Conceptually, tokens flow through the pipeline. In +a serial in-order filter, each token must be processed serially in +order. In a parallel filter, multiple tokens can by processed in +parallel by the filter. If the number of tokens were unlimited, there +might be a problem where the unordered filter in the middle keeps +gaining tokens because the output filter cannot keep up. This situation +typically leads to undesirable resource consumption by the middle +filter. The parameter to method ``parallel_pipeline`` specifies the +maximum number of tokens that can be in flight. Once this limit is +reached, the pipeline never creates a new token at the input filter +until another token is destroyed at the output filter. + + +The second parameter specifies the sequence of filters. Each filter is +constructed by function ``make_filter(mode,functor)``. + + +- The *inputType* specifies the type of values input by a filter. For + the input filter, the type is ``void``. + + +- The *outputType* specifies the type of values output by a filter. For + the output filter, the type is ``void``. + + +- The *mode* specifies whether the filter processes items in parallel, + serial in-order, or serial out-of-order. + + +- The *functor* specifies how to produce an output value from an input + value. + + +The filters are concatenated with ``operator&``. When concatenating two +filters, the *outputType* of the first filter must match the *inputType* +of the second filter. + + +The filters can be constructed and concatenated ahead of time. An +equivalent version of the previous example that does this follows: + + +:: + + + void RunPipeline( int ntoken, FILE* input_file, FILE* output_file ) { + oneapi::tbb::filter f1( oneapi::tbb::filter_mode::serial_in_order, + MyInputFunc(input_file) ); + oneapi::tbb::filter f2(oneapi::tbb::filter_mode::parallel, + MyTransformFunc() ); + oneapi::tbb::filter f3(oneapi::tbb::filter_mode::serial_in_order, + MyOutputFunc(output_file) ); + oneapi::tbb::filter f = f1 & f2 & f3; + oneapi::tbb::parallel_pipeline(ntoken,f); + } + + +The input filter must be ``serial_in_order`` in this example because the +filter reads chunks from a sequential file and the output filter must +write the chunks in the same order. All ``serial_in_order`` filters +process items in the same order. Thus if an item arrives at +``MyOutputFunc`` out of the order established by ``MyInputFunc``, the +pipeline automatically delays invoking ``MyOutputFunc::operator()`` on +the item until its predecessors are processed. There is another kind of +serial filter, ``serial_out_of_order``, that does not preserve order. + + +The middle filter operates on purely local data. Thus any number of +invocations of its functor can run concurrently. Hence it is specified +as a parallel filter. + + +The functors for each filter are explained in detail now. The output +functor is the simplest. All it has to do is write a ``TextSlice`` to a +file and free the ``TextSlice``. + + +:: + + + // Functor that writes a TextSlice to a file. + class MyOutputFunc { + FILE* my_output_file; + public: + MyOutputFunc( FILE* output_file ); + void operator()( TextSlice* item ) const; + }; +   + + MyOutputFunc::MyOutputFunc( FILE* output_file ) : + my_output_file(output_file) + { + } +   + + void MyOutputFunc::operator()( TextSlice* out ) const { + size_t n = fwrite( out->begin(), 1, out->size(), my_output_file ); + if( n!=out->size() ) { + fprintf(stderr,"Can't write into file '%s'\n", OutputFileName); + exit(1); + } + out->free(); + } + + +Method ``operator()`` processes a ``TextSlice``. The parameter ``out`` +points to the ``TextSlice`` to be processed. Since it is used for the +last filter of the pipeline, it returns ``void``. + + +The functor for the middle filter is similar, but a bit more complex. It +returns a pointer to the ``TextSlice`` that it produces. + + +:: + + + // Functor that changes each decimal number to its square. + class MyTransformFunc { + public: + TextSlice* operator()( TextSlice* input ) const; + }; + + + TextSlice* MyTransformFunc::operator()( TextSlice* input ) const { + // Add terminating null so that strtol works right even if number is at end of the input. + *input->end() = '\0'; + char* p = input->begin(); + TextSlice* out = TextSlice::allocate( 2*MAX_CHAR_PER_INPUT_SLICE ); + char* q = out->begin(); + for(;;) { + while( pend() && !isdigit(*p) ) + *q++ = *p++; + if( p==input->end() ) + break; + long x = strtol( p, &p, 10 ); + // Note: no overflow checking is needed here, as we have twice the + // input string length, but the square of a non-negative integer n + // cannot have more than twice as many digits as n. + long y = x*x; + sprintf(q,"%ld",y); + q = strchr(q,0); + } + out->set_end(q); + input->free(); + return out; + } + + +The input functor is the most complicated, because it has to ensure that +no numeral crosses a boundary. When it finds what could be a numeral +crossing into the next slice, it copies the partial numeral to the next +slice. Furthermore, it has to indicate when the end of input is reached. +It does this by invoking method ``stop()`` on a special argument of type +``flow_control``. This idiom is required for any functor used for the +first filter of a pipline. + +:: + + + TextSlice* next_slice = NULL; + + + class MyInputFunc { + public: + MyInputFunc( FILE* input_file_ ); + MyInputFunc( const MyInputFunc& f ) : input_file(f.input_file) { } + ~MyInputFunc(); + TextSlice* operator()( oneapi::tbb::flow_control& fc ) const; + private: + FILE* input_file; + }; + + + MyInputFunc::MyInputFunc( FILE* input_file_ ) : + input_file(input_file_) { } + + + MyInputFunc::~MyInputFunc() { + } + + + TextSlice* MyInputFunc::operator()( oneapi::tbb::flow_control& fc ) const { + // Read characters into space that is available in the next slice. + if( !next_slice ) + next_slice = TextSlice::allocate( MAX_CHAR_PER_INPUT_SLICE ); + size_t m = next_slice->avail(); + size_t n = fread( next_slice->end(), 1, m, input_file ); + if( !n && next_slice->size()==0 ) { + // No more characters to process + fc.stop(); + return NULL; + } else { + // Have more characters to process. + TextSlice* t = next_slice; + next_slice = TextSlice::allocate( MAX_CHAR_PER_INPUT_SLICE ); + char* p = t->end()+n; + if( n==m ) { + // Might have read partial number. + // If so, transfer characters of partial number to next slice. + while( p>t->begin() && isdigit(p[-1]) ) + --p; + assert(p>t->begin(),"Number too large to fit in buffer.\n"); + next_slice->append( p, t->end()+n ); + } + t->set_end(p); + return t; + } + } + + +The copy constructor must be defined because the functor is copied when +the underlying ``oneapi::tbb::filter_t`` is built from the functor, and again when the pipeline runs. + + +.. |image0| image:: Images/image010.jpg + :width: 31px + :height: 26px +.. |image1| image:: Images/image010.jpg + :width: 31px + :height: 26px + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/Using_Circular_Buffers + ../tbb_userguide/Throughput_of_pipeline + ../tbb_userguide/Non-Linear_Pipelines diff --git a/_sources/main/tbb_userguide/always_use_wait_for_all.rst b/_sources/main/tbb_userguide/always_use_wait_for_all.rst new file mode 100644 index 0000000000..be6f89fadb --- /dev/null +++ b/_sources/main/tbb_userguide/always_use_wait_for_all.rst @@ -0,0 +1,43 @@ +.. _always_use_wait_for_all: + +Always Use wait_for_all() +========================= + + +One of the most common mistakes made in flow graph programming is to +forget to call wait_for_all. The function graph::wait_for_all blocks +until all tasks spawned by the graph are complete. This is not only +useful when you want to wait until the computation is done, but it is +necessary to call wait_for_all before destroying the graph, or any of +its nodes. For example, the following function will lead to a program +failure: + + +:: + + + void no_wait_for_all() { + graph g; + function_node< int, int > f( g, 1, []( int i ) -> int { + return spin_for(i); + } ); + f.try_put(1); + + + // program will fail when f and g are destroyed at the + // end of the scope, since the body of f is not complete + } + + +In the function above, the graph g and its node f are destroyed at the +end of the function's scope. However, the task spawned to execute f's +body is still in flight. When the task completes, it will look for any +successors connected to its node, but by then both the graph and the +node have been deleted out from underneath it. Placing a +g.wait_for_all() at the end of the function prevents the premature +destruction of the graph and node. + + +If you use a flow graph and see mysterious behavior, check first to see +that you have called wait_for_all. + diff --git a/_sources/main/tbb_userguide/appendix_A.rst b/_sources/main/tbb_userguide/appendix_A.rst new file mode 100644 index 0000000000..2bd1e9c3b4 --- /dev/null +++ b/_sources/main/tbb_userguide/appendix_A.rst @@ -0,0 +1,48 @@ +.. _appendix_A: + +Appendix A Costs of Time Slicing +================================ + + +Time slicing enables there to be more logical threads than physical +threads. Each logical thread is serviced for a *time slice* by a +physical thread. If a thread runs longer than a time slice, as most do, +it relinquishes the physical thread until it gets another turn. This +appendix details the costs incurred by time slicing. + + +The most obvious is the time for *context switching* between logical +threads. Each context switch requires that the processor save all its +registers for the previous logical thread that it was executing, and +load its registers for the next logical thread that it runs. + + +A more subtle cost is *cache cooling*. Processors keep recently accessed +data in cache memory, which is very fast, but also relatively small +compared to main memory. When the processor runs out of cache memory, it +has to evict items from cache and put them back into main memory. +Typically, it chooses the least recently used items in the cache. (The +reality of set-associative caches is a bit more complicated, but this is +not a cache primer.) When a logical thread gets its time slice, as it +references a piece of data for the first time, this data will be pulled +into cache, taking hundreds of cycles. If it is referenced frequently +enough to not be evicted, each subsequent reference will find it in +cache, and only take a few cycles. Such data is called "hot in cache". +Time slicing undoes this, because if a thread A finishes its time slice, +and subsequently thread B runs on the same physical thread, B will tend +to evict data that was hot in cache for A, unless both threads need the +data. When thread A gets its next time slice, it will need to reload +evicted data, at the cost of hundreds of cycles for each cache miss. Or +worse yet, the next time slice for thread A may be on a different +physical thread that has a different cache altogether. + + +Another cost is *lock preemption.* This happens if a thread acquires a +lock on a resource, and its time slice runs out before it releases the +lock. No matter how short a time the thread intended to hold the lock, +it is now going to hold it for at least as long as it takes for its next +turn at a time slice to come up. Any other threads waiting on the lock +either pointlessly busy-wait, or lose the rest of their time slice. The +effect is called *convoying*, because the threads end up "bumper to +bumper" waiting for the preempted thread in front to resume driving. + diff --git a/_sources/main/tbb_userguide/appendix_B.rst b/_sources/main/tbb_userguide/appendix_B.rst new file mode 100644 index 0000000000..37c638b44e --- /dev/null +++ b/_sources/main/tbb_userguide/appendix_B.rst @@ -0,0 +1,74 @@ +.. _appendix_B: + +Appendix B Mixing With Other Threading Packages +=============================================== + + +|full_name| can be mixed with other +threading packages. No special effort is required to use any part of +oneTBB with other threading packages. + + +Here is an example that parallelizes an outer loop with OpenMP and an +inner loop with oneTBB. + + +:: + + + int M, N; +   + + struct InnerBody { + ... + }; +   + + void TBB_NestedInOpenMP() { + #pragma omp parallel + { + #pragma omp for + for( int i=0; i(0,N,10), InnerBody(i) ); + } + } + } + + +The details of ``InnerBody`` are omitted for brevity. The +``#pragma omp parallel`` causes the OpenMP to create a team of threads, +and each thread executes the block statement associated with the pragma. +The ``#pragma omp for`` indicates that the compiler should use the +previously created thread team to execute the loop in parallel. + + +Here is the same example written using POSIX\* Threads. + + +:: + + + int M, N; +   + + struct InnerBody { + ... + }; +   + + void* OuterLoopIteration( void* args ) { + int i = (int)args; + parallel_for( blocked_range(0,N,10), InnerBody(i) ); + } +   + + void TBB_NestedInPThreads() { + std::vector id( M ); + // Create thread for each outer loop iteration + for( int i=0; i src( g, [&]( oneapi::tbb::flow_control& fc ) -> int { + if ( src_count <= limit ) { + return src_count++; + } else { + fc.stop(); + return int(); + } + } ); + src.activate(); + + function_node< int, int > f( g, unlimited, [&]( int i ) -> int { + global_sum += i; // data race on global_sum + return i; + } ); + + + make_edge( src, f ); + g.wait_for_all(); + + + cout << "global sum = " << global_sum + << " and closed form = " << limit*(limit+1)/2 << "\n"; + + +If you run the above example, it will likely calculate a global sum that +is a bit smaller than the expected solution due to the data race. The +data race could be avoided in this simple example by changing the +allowed concurrency in ``f`` from unlimited to 1, forcing each value to be +processed sequentially by ``f``. You may also note that the ``input_node`` also +updates a global value, ``src_count``. However, since an ``input_node`` always +executes serially, there is no race possible. diff --git a/_sources/main/tbb_userguide/broadcast_or_send.rst b/_sources/main/tbb_userguide/broadcast_or_send.rst new file mode 100644 index 0000000000..68baa7540c --- /dev/null +++ b/_sources/main/tbb_userguide/broadcast_or_send.rst @@ -0,0 +1,134 @@ +.. _broadcast_or_send: + +Sending to One or Multiple Successors +===================================== + + +An important characteristic of the predefined nodes is whether they push +their output to a single successor or broadcast to all successors. The +following predefined nodes push messages to a single successor: + + +- buffer_node +- queue_node +- priority_queue_node +- sequencer_node + + +Other nodes push messages to all successors that will accept them. + + +The nodes that push to only a single successor are all buffer nodes. +Their purpose is to hold messages temporarily, until they are consumed +downstream. Consider the example below: + + +:: + + + void use_buffer_and_two_nodes() { + graph g; + + + function_node< int, int, rejecting > f1( g, 1, []( int i ) -> int { + spin_for(0.1); + cout << "f1 consuming " << i << "\n"; + return i; + } ); + + + function_node< int, int, rejecting > f2( g, 1, []( int i ) -> int { + spin_for(0.2); + cout << "f2 consuming " << i << "\n"; + return i; + } ); + + + priority_queue_node< int > q(g); + + + make_edge( q, f1 ); + make_edge( q, f2 ); + for ( int i = 10; i > 0; --i ) { + q.try_put( i ); + } + g.wait_for_all(); + } + + +First, function_nodes by default queue up the messages they receive at +their input. To make a priority_queue_node work properly with a +function_node, the example above constructs its function_nodes with its +buffer policy set to rejecting. So, f1 and f2 do not internally buffer +incoming messages, but instead rely on upstream buffering in the +priority_queue_node. + + +In the above example, each message buffered by the priority_queue_node +is sent to either f1 or f2, but not both. + + +Let's consider the alternative behavior; that is; what if the +priority_queue_node broadcasts to all successors. What if some, but not +all, nodes accept a message? Should the message be buffered until all +nodes accept it, or be only delivered to the accepting subset? If the +node continues to buffer the message, should it eventually deliver the +messages in the same order to all nodes or in the current priority order +at the time the node accepts the next message? For example, assume a +priority_queue_node only contains "9" when a successor node, f1, accepts +"9" but another successor node, f2, rejects it. Later a value "100" +arrives and f2 is available to accept messages. Should f2 receive "9" +next or "100", which has a higher priority? In any case, trying to +ensure that all successors receive each message creates a garbage +collection problem and complicates reasoning. Therefore, these buffering +nodes push each message to only one successor. And, you can use this +characteristic to create useful graph structures such as the one shown +in the graph above, where each message will be processed in priority +order, by either f1 or f2. + + +But what if you really do want both f1 and f2 to receive all of the +values, and in priority order? You can easily create this behavior by +creating one priority_queue_node for each function_node, and pushing +each value to both queues through a broadcast_node, as shown below: + + +:: + + + graph g; + + + function_node< int, int, rejecting > f1( g, 1, []( int i ) -> int { + spin_for(0.1); + cout << "f1 consuming " << i << "\n"; + return i; + } ); + + + function_node< int, int, rejecting > f2( g, 1, []( int i ) -> int { + spin_for(0.2); + cout << "f2 consuming " << i << "\n"; + return i; + } ); + + + priority_queue_node< int > q1(g); + priority_queue_node< int > q2(g); + broadcast_node< int > b(g); + + + make_edge( b, q1 ); + make_edge( b, q2 ); + make_edge( q1, f1 ); + make_edge( q2, f2 ); + for ( int i = 10; i > 0; --i ) { + b.try_put( i ); + } + g.wait_for_all(); + + +So, when connecting a node in your graph to multiple successors, be sure +to understand whether the output will broadcast to all of the +successors, or just a single successor. + diff --git a/_sources/main/tbb_userguide/cancel_a_graph.rst b/_sources/main/tbb_userguide/cancel_a_graph.rst new file mode 100644 index 0000000000..4ae598d7ea --- /dev/null +++ b/_sources/main/tbb_userguide/cancel_a_graph.rst @@ -0,0 +1,86 @@ +.. _cancel_a_graph: + +Cancel a Graph Explicitly +========================= + + +To cancel a graph execution without an exception, you can create the +graph using an explicit task_group_context, and then call +cancel_group_execution() on that object. This is done in the example +below: + + +:: + + + task_group_context t; + graph g(t); + + + function_node< int, int > f1( g, 1, []( int i ) { return i; } ); + + + function_node< int, int > f2( g, 1, + []( const int i ) -> int { + cout << "Begin " << i << "\n"; + spin_for(0.2); + cout << "End " << i << "\n"; + return i; + } ); + + + function_node< int, int > f3( g, 1, []( int i ) { return i; } ); + + + make_edge( f1, f2 ); + make_edge( f2, f3 ); + f1.try_put(1); + f1.try_put(2); + spin_for(0.1); + t.cancel_group_execution(); + g.wait_for_all(); + + +When a graph execution is canceled, any node that has already started to +execute will execute to completion, but any node that has not started to +execute will not start. So in the example above, f2 will print both the +Begin and End message for input 1, but will not receive the input 2. + + +You can also get the task_group_context that a node belongs to from +within the node body and use it to cancel the execution of the graph it +belongs to: + + +:: + + + graph g; + + + function_node< int, int > f1( g, 1, []( int i ) { return i; } ); + + + function_node< int, int > f2( g, 1, + []( const int i ) -> int { + cout << "Begin " << i << "\n"; + spin_for(0.2); + cout << "End " << i << "\n"; + task::self().group()->cancel_group_execution(); + return i; + } ); + + + function_node< int, int > f3( g, 1, []( int i ) { return i; } ); + + + make_edge( f1, f2 ); + make_edge( f2, f3 ); + f1.try_put(1); + f1.try_put(2); + g.wait_for_all(); + + +You can get the task_group_context from a node's body even if the graph +was not explicitly passed one at construction time. + diff --git a/_sources/main/tbb_userguide/cancelling_nested_parallelism.rst b/_sources/main/tbb_userguide/cancelling_nested_parallelism.rst new file mode 100644 index 0000000000..6fc3ed158b --- /dev/null +++ b/_sources/main/tbb_userguide/cancelling_nested_parallelism.rst @@ -0,0 +1,21 @@ +.. _cancelling_nested_parallelism: + +Canceling Nested Parallelism +============================ + + +Nested parallelism is canceled if the inner context is bound to the +outer context; otherwise it is not. + + +If the execution of a flow graph is canceled, either explicitly or due +to an exception, any tasks started by parallel algorithms or flow graphs +nested within the nodes of the canceled flow graph may or may not be +canceled. + + +As with all of the library's nested parallelism, you can control +cancellation relationships by use of explicit task_group_context +objects. If you do not provide an explicit task_group_context to a flow +graph, it is created with an isolated context by default. + diff --git a/_sources/main/tbb_userguide/catching_exceptions.rst b/_sources/main/tbb_userguide/catching_exceptions.rst new file mode 100644 index 0000000000..17878954ee --- /dev/null +++ b/_sources/main/tbb_userguide/catching_exceptions.rst @@ -0,0 +1,80 @@ +.. _catching_exceptions: + +Catching Exceptions Inside the Node that Throws the Exception +============================================================= + + +If you catch an exception within the node's body, execution continues +normally, as you might expect. If an exception is thrown but is not +caught before it propagates beyond the node's body, the execution of all +of the graph's nodes are canceled and the exception is rethrown at the +call site of graph::wait_for_all(). Take the graph below as an example: + + +:: + + + graph g; + + + function_node< int, int > f1( g, 1, []( int i ) { return i; } ); + + + function_node< int, int > f2( g, 1, + []( const int i ) -> int { + throw i; + return i; + } ); + + + function_node< int, int > f3( g, 1, []( int i ) { return i; } ); + + + make_edge( f1, f2 ); + make_edge( f2, f3 ); + f1.try_put(1); + f1.try_put(2); + g.wait_for_all(); + + +In the code above, the second function_node, f2, throws an exception +that is not caught within the body. This will cause the execution of the +graph to be canceled and the exception to be rethrown at the call to +g.wait_for_all(). Since it is not handled there either, the program will +terminate. If desirable, the exception could be caught and handled +within the body: + + +:: + + + function_node< int, int > f2( g, 1, + []( const int i ) -> int { + try { + throw i; + } catch (int j) { + cout << "Caught " << j << "\n"; + } + return i; + } ); + + +If the exception is caught and handled in the body, then there is no +effect on the overall execution of the graph. However, you could choose +instead to catch the exception at the call to wait_for_all: + + +:: + + + try { + g.wait_for_all(); + } catch ( int j ) { + cout << "Caught " << j << "\n"; + } + + +In this case, the execution of the graph is canceled. For our example, +this means that the input 1 never reaches f3 and that input 2 never +reaches either f2 or f3. + diff --git a/_sources/main/tbb_userguide/communicate_with_nodes.rst b/_sources/main/tbb_userguide/communicate_with_nodes.rst new file mode 100644 index 0000000000..062c35bb57 --- /dev/null +++ b/_sources/main/tbb_userguide/communicate_with_nodes.rst @@ -0,0 +1,106 @@ +.. _communicate_with_nodes: + +Communication Between Graphs +============================ + + +All graph nodes require a reference to a graph object as one of the +arguments to their constructor. It is only safe to construct edges +between nodes that are part of the same graph. An edge expresses the +topology of your graph to the runtime library. Connecting two nodes in +different graphs can make it difficult to reason about whole graph +operations, such as calls to graph::wait_for_all and exception handling. +To optimize performance, the library may make calls to a node's +predecessor or successor at times that are unexpected by the user. + + +If two graphs must communicate, do NOT create an edge between them, but +instead use explicit calls to try_put. This will prevent the runtime +library from making any assumptions about the relationship of the two +nodes, and therefore make it easier to reason about events that cross +the graph boundaries. However, it may still be difficult to reason about +whole graph operations. For example, consider the graphs below: + + +:: + + + graph g; + function_node< int, int > n1( g, 1, [](int i) -> int { + cout << "n1\n"; + spin_for(i); + return i; + } ); + function_node< int, int > n2( g, 1, [](int i) -> int { + cout << "n2\n"; + spin_for(i); + return i; + } ); + make_edge( n1, n2 ); + + + graph g2; + function_node< int, int > m1( g2, 1, [](int i) -> int { + cout << "m1\n"; + spin_for(i); + return i; + } ); + function_node< int, int > m2( g2, 1, [&](int i) -> int { + cout << "m2\n"; + spin_for(i); + n1.try_put(i); + return i; + } ); + make_edge( m1, m2 ); + + + m1.try_put( 1 ); + + + // The following call returns immediately: + g.wait_for_all(); + // The following call returns after m1 & m2 + g2.wait_for_all(); + + + // we reach here before n1 & n2 are finished + // even though wait_for_all was called on both graphs + + +In the example above, m1.try_put(1) sends a message to node m1, which +runs its body and then sends a message to node m2. Next, node m2 runs +its body and sends a message to n1 using an explicit try_put. In turn, +n1 runs its body and sends a message to n2. The runtime library does not +consider m2 to be a predecessor of n1 since no edge exists. + + +If you want to wait until all of the tasks spawned by these graphs are +done, you need to call the function wait_for_all on both graphs. +However, because there is cross-graph communication, the order of the +calls is important. In the (incorrect) code segment above, the first +call to g.wait_for_all() returns immediately because there are no tasks +yet active in g; the only tasks that have been spawned by then belong to +g2. The call to g2.wait_for_all returns after both m1 and m2 are done, +since they belong to g2; the call does not however wait for n1 and n2, +since they belong to g. The end of this code segment is therefore +reached before n1 and n2 are done. + + +If the calls to wait_for_all are swapped, the code works as expected: + + +:: + + + g2.wait_for_all(); + g.wait_for_all(); + + + // all tasks are done + + +While it is not too difficult to reason about how these two very small +graphs interact, the interaction of two larger graphs, perhaps with +cycles, will be more difficult to understand. Therefore, communication +between nodes in different graphs should be done with caution. + diff --git a/_sources/main/tbb_userguide/concurrent_hash_map.rst b/_sources/main/tbb_userguide/concurrent_hash_map.rst new file mode 100644 index 0000000000..8d9ba3a1b7 --- /dev/null +++ b/_sources/main/tbb_userguide/concurrent_hash_map.rst @@ -0,0 +1,131 @@ +.. _concurrent_hash_map: + +concurrent_hash_map +=================== + + +A ``concurrent_hash_map`` is a hash table that +permits concurrent accesses. The table is a map from a key to a type +``T``. The traits type HashCompare defines how to hash a key and how to +compare two keys. + + +The following example builds a ``concurrent_hash_map`` where the keys +are strings and the corresponding data is the number of times each +string occurs in the array ``Data``. + + +:: + + + #include "oneapi/tbb/concurrent_hash_map.h" + #include "oneapi/tbb/blocked_range.h" + #include "oneapi/tbb/parallel_for.h" + #include +   + + using namespace oneapi::tbb; + using namespace std; +   + + // Structure that defines hashing and comparison operations for user's type. + struct MyHashCompare { + size_t hash( const string& x ) const { + size_t h = 0; + for( const char* s = x.c_str(); *s; ++s ) + h = (h*17)^*s; + return h; + } + //! True if strings are equal + bool equal( const string& x, const string& y ) const { + return x==y; + } + }; +   + + // A concurrent hash table that maps strings to ints. + typedef concurrent_hash_map StringTable; +   + + // Function object for counting occurrences of strings. + struct Tally { + StringTable& table; + Tally( StringTable& table_ ) : table(table_) {} + void operator()( const blocked_range range ) const { + for( string* p=range.begin(); p!=range.end(); ++p ) { + StringTable::accessor a; + table.insert( a, *p ); + a->second += 1; + } + } + }; +   + + const size_t N = 1000000; +   + + string Data[N]; +   + + void CountOccurrences() { + // Construct empty table. + StringTable table; +   + + // Put occurrences into the table + parallel_for( blocked_range( Data, Data+N, 1000 ), + Tally(table) ); +   + + // Display the occurrences + for( StringTable::iterator i=table.begin(); i!=table.end(); ++i ) + printf("%s %d\n",i->first.c_str(),i->second); + } + + +A ``concurrent_hash_map`` acts as a container of elements of type +``std::pair``. Typically, when accessing a container +element, you are interested in either updating it or reading it. The +template class ``concurrent_hash_map`` supports these two purposes +respectively with the classes ``accessor`` and ``const_accessor`` that +act as smart pointers. An *accessor* represents *update* (*write*) +access. As long as it points to an element, all other attempts to look +up that key in the table block until the ``accessor`` is done. A +``const_accessor`` is similar, except that is represents *read-only* +access. Multiple ``const_accessors`` can point to the same element at +the same time. This feature can greatly improve concurrency in +situations where elements are frequently read and infrequently updated. + + +The methods ``find`` and ``insert`` take an ``accessor`` or +``const_accessor`` as an argument. The choice tells +``concurrent_hash_map`` whether you are asking for *update* or +*read-only* access. Once the method returns, the access lasts until the +``accessor`` or ``const_accessor`` is destroyed. Because having access +to an element can block other threads, try to shorten the lifetime of +the ``accessor`` or ``const_accessor``. To do so, declare it in the +innermost block possible. To release access even sooner than the end of +the block, use method ``release``. The following example is a rework of +the loop body that uses ``release`` instead of depending upon +destruction to end thread lifetime: + + +:: + + + StringTable accessor a; + for( string* p=range.begin(); p!=range.end(); ++p ) { + table.insert( a, *p ); + a->second += 1; + a.release(); + } + + +The method ``remove(key)`` can also operate concurrently. It implicitly +requests write access. Therefore before removing the key, it waits on +any other extant accesses on ``key``. + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/More_on_HashCompare diff --git a/_sources/main/tbb_userguide/concurrent_vector_ug.rst b/_sources/main/tbb_userguide/concurrent_vector_ug.rst new file mode 100644 index 0000000000..2c1f84b253 --- /dev/null +++ b/_sources/main/tbb_userguide/concurrent_vector_ug.rst @@ -0,0 +1,62 @@ +.. _concurrent_vector_ug: + +concurrent_vector +================= + + +``A concurrent_vector`` is a dynamically growable array of ``T``. It +is safe to grow a ``concurrent_vector`` while other threads are also +operating on elements of it, or even growing it themselves. For safe +concurrent growing, ``concurrent_vector`` has three methods that support +common uses of dynamic arrays: ``push_back``, ``grow_by``, and +``grow_to_at_least``. + + +Method ``push_back(x)`` safely appends x to the array. Method +``grow_by(n)`` safely appends ``n`` consecutive elements initialized +with ``T()``. Both methods return an iterator pointing to the first +appended element. Each element is initialized with ``T()``. So for +example, the following routine safely appends a C string to a shared +vector: + + +:: + + + void Append( concurrent_vector& vector, const char* string ) { + size_t n = strlen(string)+1; + std::copy( string, string+n, vector.grow_by(n) ); + } + + +The related method ``grow_to_at_least(n)``\ grows a vector to size ``n`` +if it is shorter. Concurrent calls to the growth methods do not +necessarily return in the order that elements are appended to the +vector. + + +Method ``size()`` returns the number of elements in the vector, which +may include elements that are still undergoing concurrent construction +by methods ``push_back``, ``grow_by,`` or ``grow_to_at_least``. The +example uses std::copy and iterators, not ``strcpy and pointers``, +because elements in a ``concurrent_vector`` might not be at consecutive +addresses. It is safe to use the iterators while the +``concurrent_vector`` is being grown, as long as the iterators never go +past the current value of ``end()``. However, the iterator may reference +an element undergoing concurrent construction. You must synchronize +construction and access. + + +A ``concurrent_vector`` never moves an element until the array is +cleared, which can be an advantage over the STL std::vector even for +single-threaded code. However, ``concurrent_vector`` does have more +overhead than std::vector. Use ``concurrent_vector`` only if you really +need the ability to dynamically resize it while other accesses are (or +might be) in flight, or require that an element never move. + + +.. CAUTION:: + Operations on ``concurrent_vector`` are concurrency safe with respect + to *growing*, not for clearing or destroying a vector. Never invoke + method ``clear()`` if there are other operations in flight on the + ``concurrent_vector``. diff --git a/_sources/main/tbb_userguide/create_token_based_system.rst b/_sources/main/tbb_userguide/create_token_based_system.rst new file mode 100644 index 0000000000..6d9d642556 --- /dev/null +++ b/_sources/main/tbb_userguide/create_token_based_system.rst @@ -0,0 +1,144 @@ +.. _create_token_based_system: + +Create a Token-Based System +=========================== + + +A more flexible solution to limit the number of messages in a flow graph +is to use tokens. In a token-based system, a limited number of tokens +are available in the graph and a message will not be allowed to enter +the graph until it can be paired with an available token. When a message +is retired from the graph, its token is released, and can be paired with +a new message that will then be allowed to enter. + + +The ``oneapi::tbb::parallel_pipeline`` algorithm relies on a token-based system. In +the flow graph interface, there is no explicit support for tokens, but +``join_node``s can be used to create an analogous system. A ``join_node`` has +two template arguments, the tuple that describes the types of its inputs +and a buffer policy: + + +:: + + + template + class join_node; + + +The buffer policy can be one of the following: + + +- ``queueing``. This type of policy causes inputs to be matched + first-in-first-out; that is, the inputs are joined together to form a + tuple in the order they are received. +- ``tag_matching``. This type of policy joins inputs together that have + matching tags. +- ``reserving``. This type of policy causes the ``join_node`` to do no + internally buffering, but instead to consume inputs only when it can + first reserve an input on each port from an upstream source. If it + can reserve an input at each port, it gets those inputs and joins + those together to form an output tuple. + + +A token-based system can be created by using reserving join_nodes. + + +In the example below, there is an ``input_node`` that generates ``M`` big +objects and a ``buffer_node`` that is pre-filled with three tokens. The +``token_t`` can be anything, for example it could be ``typedef int token_t;``. +The ``input_node`` and ``buffer_node`` are connected to a reserving ``join_node``. +The ``input_node`` will only generate an input when one is pulled from it +by the reserving ``join_node``, and the reserving ``join_node`` will only pull +the input from the ``input_node`` when it knows there is also an item to +pull from the ``buffer_node``. + + +:: + + + graph g; + + + int src_count = 0; + int number_of_objects = 0; + int max_objects = 3; + + + input_node< big_object * > s( g, [&]( oneapi::tbb::flow_control& fc ) -> big_object* { + if ( src_count < M ) { + big_object* v = new big_object(); + ++src_count; + return v; + } else { + fc.stop(); + return nullptr; + } + } ); + s.activate(); + + join_node< tuple_t, reserving > j(g); + + + buffer_node< token_t > b(g); + + + function_node< tuple_t, token_t > f( g, unlimited, + []( const tuple_t &t ) -> token_t { + spin_for(1); + cout << get<1>(t) << "\n"; + delete get<0>(t); + return get<1>(t); + } ); + + + make_edge( s, input_port<0>(j) ); + make_edge( b, input_port<1>(j) ); + make_edge( j, f ); + make_edge( f, b ); + + + b.try_put( 1 ); + b.try_put( 2 ); + b.try_put( 3 ); + + + g.wait_for_all(); + + +In the above code, you can see that the ``function_node`` returns the token +back to the ``buffer_node``. This cycle in the flow graph allows the token +to be recycled and paired with another input from the ``input_node``. So +like in the previous sections, there will be at most four big objects in +the graph. There could be three big objects in the ``function_node`` and one +buffered in the ``input_node``, awaiting a token to be paired with. + + +Since there is no specific ``token_t`` defined for the flow graph, you can +use any type for a token, including objects or pointers to arrays. +Therefore, unlike in the example above, the ``token_t`` doesn't need to be a +dummy type; it could for example be a buffer or other object that is +essential to the computation. We could, for example, modify the example +above to use the big objects themselves as the tokens, removing the need +to repeatedly allocate and deallocate them, and essentially create a +free list of big objects using a cycle back to the ``buffer_node``. + + +Also, in our example above, the ``buffer_node`` was prefilled by a fixed +number of explicit calls to ``try_put``, but there are other options. For +example, an ``input_node`` could be attached to the input of the +``buffer_node``, and it could generate the tokens. In addition, our +``function_node`` could be replaced by a ``multifunction_node`` that can +optionally put 0 or more outputs to each of its output ports. Using a +``multifunction_node``, you can choose to recycle or not recycle a token, or +even generate more tokens, thereby increasing or decreasing the allowed +concurrency in the graph. + + +A token based system is therefore very flexible. You are free to declare +the token to be of any type and to inject or remove tokens from the +system as it is executing, thereby having dynamic control of the allowed +concurrency in the system. Since you can pair the token with an input at +the source, this approach enables you to limit resource consumption +across the entire graph. + diff --git a/_sources/main/tbb_userguide/design_patterns/Agglomeration.rst b/_sources/main/tbb_userguide/design_patterns/Agglomeration.rst new file mode 100644 index 0000000000..72fbd11c8c --- /dev/null +++ b/_sources/main/tbb_userguide/design_patterns/Agglomeration.rst @@ -0,0 +1,171 @@ +.. _Agglomeration: + +Agglomeration +============= + + +.. container:: section + + + .. rubric:: Problem + :class: sectiontitle + + Parallelism is so fine grained that overhead of parallel scheduling + or communication swamps the useful work. + + +.. container:: section + + + .. rubric:: Context + :class: sectiontitle + + Many algorithms permit parallelism at a very fine grain, on the order + of a few instructions per task. But synchronization between threads + usually requires orders of magnitude more cycles. For example, + elementwise addition of two arrays can be done fully in parallel, but + if each scalar addition is scheduled as a separate task, most of the + time will be spent doing synchronization instead of useful addition. + + +.. container:: section + + + .. rubric:: Forces + :class: sectiontitle + + - Individual computations can be done in parallel, but are small. + For practical use of |full_name|, + "small" here means less than 10,000 clock cycles. + + + - The parallelism is for sake of performance and not required for + semantic reasons. + + +.. container:: section + + + .. rubric:: Solution + :class: sectiontitle + + Group the computations into blocks. Evaluate computations within a + block serially. + + + The block size should be chosen to be large enough to amortize + parallel overhead. Too large a block size may limit parallelism or + load balancing because the number of blocks becomes too small to + distribute work evenly across processors. + + + The choice of block topology is typically driven by two concerns: + + + - Minimizing synchronization between blocks. + + + - Minimizing cache traffic between blocks. + + + If the computations are completely independent, then the blocks will + be independent too, and then only cache traffic issues must be + considered. + + + If the loop is "small", on the order of less than 10,000 clock + cycles, then it may be impractical to parallelize at all, because the + optimal agglomeration might be a single block, + + +.. container:: section + + + .. rubric:: Examples + :class: sectiontitle + + TBB loop templates such as ``oneapi::tbb::parallel_for`` that take a *range* + argument support automatic agglomeration. + + + When agglomerating, think about cache effects. Avoid having cache + lines cross between groups if possible. + + + There may be boundary to interior ratio effects. For example, if the + computations form a 2D grid, and communicate only with nearest + neighbors, then the computation per block grows quadratically (with + the block's area), but the cross-block communication grows with + linearly (with the block's perimeter). The following figure shows + four different ways to agglomerate an 8×8 grid. If doing such + analysis, be careful to consider that information is transferred in + cache line units. For a given area, the perimeter may be minimized + when the block is square with respect to the underlying grid of cache + lines, not square with respect to the logical grid. + + + .. container:: fignone + :name: fig1 + + + Four different agglomerations of an 8×8 grid. |image0| + + + Also consider vectorization. Blocks that contain long contiguous + subsets of data may better enable vectorization. + + + For recursive computations, most of the work is towards the leaves, + so the solution is to treat subtrees as a groups as shown in the + following figure. + + + .. container:: fignone + :name: fig2 + + + Agglomeration of a recursive computation |image1| + + + Often such an agglomeration is achieved by recursing serially once + some threshold is reached. For example, a recursive sort might solve + sub-problems in parallel only if they are above a certain threshold + size. + + +.. container:: section + + + .. rubric:: Reference + :class: sectiontitle + + Ian Foster introduced the term "agglomeration" in his book Designing + and Building Parallel Programs http://www.mcs.anl.gov/~itf/dbpp. + There agglomeration is part of a four step **PCAM** design method: + + + #. **P**\ artitioning - break the program into the smallest tasks + possible. + + + #. **C**\ ommunication – figure out what communication is required + between tasks. When using oneTBB, communication is usually cache + line transfers. Though they are automatic, understanding which + ones happen between tasks helps guide the agglomeration step. + + + #. **A**\ gglomeration – combine tasks into larger tasks. His book + has an extensive list of considerations that is worth reading. + + + #. **M**\ apping – map tasks onto processors. The oneTBB task + scheduler does this step for you. + + +.. |image0| image:: Images/image002a.jpg + :width: 301px + :height: 293px +.. |image1| image:: Images/image003a.jpg + :width: 291px + :height: 150px + diff --git a/_sources/main/tbb_userguide/design_patterns/Design_Patterns.rst b/_sources/main/tbb_userguide/design_patterns/Design_Patterns.rst new file mode 100644 index 0000000000..5daa696b5b --- /dev/null +++ b/_sources/main/tbb_userguide/design_patterns/Design_Patterns.rst @@ -0,0 +1,58 @@ +.. _design_patterns: + +Design Patterns +=============== + + +This section provides some common parallel programming patterns and how +to implement them in |full_name|. + + +The description of each pattern has the following format: + + +- **Problem** – describes the problem to be solved. + + +- **Context** – describes contexts in which the problem arises. + + +- **Forces** - considerations that drive use of the pattern. + + +- **Solution** - describes how to implement the pattern. + + +- **Example** – presents an example implementation. + + +Variations and examples are sometimes discussed. The code examples are +intended to emphasize key points and are not full-fledged code. Examples +may omit obvious const overloads of non-const methods. + + +Much of the nomenclature and examples are adapted from Web pages created +by Eun-Gyu and Marc Snir, and the Berkeley parallel patterns wiki. See +links in the **General References** section. + + +For brevity, some of the code examples use C++11 lambda expressions. It +is straightforward, albeit sometimes tedious, to translate such lambda +expressions into equivalent C++03 code. + +.. toctree:: + :maxdepth: 4 + + ../../tbb_userguide/design_patterns/Agglomeration + ../../tbb_userguide/design_patterns/Elementwise + ../../tbb_userguide/design_patterns/Odd-Even_Communication + ../../tbb_userguide/design_patterns/Wavefront + ../../tbb_userguide/design_patterns/Reduction + ../../tbb_userguide/design_patterns/Divide_and_Conquer + ../../tbb_userguide/design_patterns/GUI_Thread + ../../tbb_userguide/design_patterns/Non-Preemptive_Priorities + ../../tbb_userguide/design_patterns/Lazy_Initialization + ../../tbb_userguide/design_patterns/Local_Serializer + ../../tbb_userguide/design_patterns/Fenced_Data_Transfer + ../../tbb_userguide/design_patterns/Reference_Counting + ../../tbb_userguide/design_patterns/General_References diff --git a/_sources/main/tbb_userguide/design_patterns/Divide_and_Conquer.rst b/_sources/main/tbb_userguide/design_patterns/Divide_and_Conquer.rst new file mode 100644 index 0000000000..f09787ea21 --- /dev/null +++ b/_sources/main/tbb_userguide/design_patterns/Divide_and_Conquer.rst @@ -0,0 +1,217 @@ +.. _Divide_and_Conquer: + +Divide and Conquer +================== + + +.. container:: section + + + .. rubric:: Problem + :class: sectiontitle + + Parallelize a divide and conquer algorithm. + + +.. container:: section + + + .. rubric:: Context + :class: sectiontitle + + Divide and conquer is widely used in serial algorithms. Common + examples are quicksort and mergesort. + + +.. container:: section + + + .. rubric:: Forces + :class: sectiontitle + + - Problem can be transformed into subproblems that can be solved + independently. + + + - Splitting problem or merging solutions is relatively cheap + compared to cost of solving the subproblems. + + +.. container:: section + + + .. rubric:: Solution + :class: sectiontitle + + There are several ways to implement divide and conquer in + |full_name|. The best choice depends upon circumstances. + + + - If division always yields the same number of subproblems, use + recursion and ``oneapi::tbb::parallel_invoke``. + + + - If the number of subproblems varies, use recursion and + ``oneapi::tbb::task_group``. + + +.. container:: section + + + .. rubric:: Example + :class: sectiontitle + + Quicksort is a classic divide-and-conquer algorithm. It divides a + sorting problem into two subsorts. A simple serial version looks like [1]_. + + + :: + + + void SerialQuicksort( T* begin, T* end ) { + if( end-begin>1 ) { + using namespace std; + T* mid = partition( begin+1, end, bind2nd(less(),*begin) ); + swap( *begin, mid[-1] ); + SerialQuicksort( begin, mid-1 ); + SerialQuicksort( mid, end ); + } + } + + + The number of subsorts is fixed at two, so ``oneapi::tbb::parallel_invoke`` + provides a simple way to parallelize it. The parallel code is shown + below: + + + :: + + + void ParallelQuicksort( T* begin, T* end ) { + if( end-begin>1 ) { + using namespace std; + T* mid = partition( begin+1, end, bind2nd(less(),*begin) ); + swap( *begin, mid[-1] ); + oneapi::tbb::parallel_invoke( [=]{ParallelQuicksort( begin, mid-1 );}, + [=]{ParallelQuicksort( mid, end );} ); + } + } + + + Eventually the subsorts become small enough that serial execution is + more efficient. The following variation, does sorts of less than 500 elements using the earlier serial code. + + + :: + + + void ParallelQuicksort( T* begin, T* end ) { + if( end-begin>=500 ) { + using namespace std; + T* mid = partition( begin+1, end, bind2nd(less(),*begin) ); + swap( *begin, mid[-1] ); + oneapi::tbb::parallel_invoke( [=]{ParallelQuicksort( begin, mid-1 );}, + [=]{ParallelQuicksort( mid, end );} ); + } else { + SerialQuicksort( begin, end ); + } + } + + + The change is an instance of the Agglomeration pattern. + + + The next example considers a problem where there are a variable + number of subproblems. The problem involves a tree-like description + of a mechanical assembly. There are two kinds of nodes: + + + - Leaf nodes represent individual parts. + + + - Internal nodes represent groups of parts. + + + The problem is to find all nodes that collide with a target node. The + following code shows a serial solution that walks the tree. It + records in ``Hits`` any nodes that collide with ``Target``. + + + :: + + + std::list Hits; + Node* Target; +   + + void SerialFindCollisions( Node& x ) { + if( x.is_leaf() ) { + if( x.collides_with( *Target ) ) + Hits.push_back(&x); + } else { + for( Node::const_iterator y=x.begin();y!=x.end(); ++y ) + SerialFindCollisions(*y); + } + } + + + A parallel version is shown below. + + + :: + + + typedef oneapi::tbb::enumerable_thread_specific > LocalList; + LocalList LocalHits; + Node* Target; // Target node +   + + void ParallelWalk( Node& x ) { + if( x.is_leaf() ) { + if( x.collides_with( *Target ) ) + LocalHits.local().push_back(&x); + } else { + // Recurse on each child y of x in parallel + oneapi::tbb::task_group g; + for( Node::const_iterator y=x.begin(); y!=x.end(); ++y ) + g.run( [=]{ParallelWalk(*y);} ); + // Wait for recursive calls to complete + g.wait(); + } + } +   + + void ParallelFindCollisions( Node& x ) { + ParallelWalk(x); + for(LocalList::iterator i=LocalHits.begin();i!=LocalHits.end(); ++i) + Hits.splice( Hits.end(), *i ); + } + + + The recursive walk is parallelized using class ``task_group`` to do + recursive calls in parallel. + + + There is another significant change because of the parallelism that + is introduced. Because it would be unsafe to update ``Hits`` + concurrently, the parallel walk uses variable ``LocalHits`` to + accumulate results. Because it is of type + ``enumerable_thread_specific``, each thread accumulates its own + private result. The results are spliced together into Hits after the + walk completes. + + + The results will *not* be in the same order as the original serial + code. + + + If parallel overhead is high, use the agglomeration pattern. For + example, use the serial walk for subtrees under a certain threshold. + + +.. [1] Production quality quicksort implementations typically + use more sophisticated pivot selection, explicit stacks instead of + recursion, and some other sorting algorithm for small subsorts. The + simple algorithm is used here to focus on exposition of the parallel + pattern. + diff --git a/_sources/main/tbb_userguide/design_patterns/Elementwise.rst b/_sources/main/tbb_userguide/design_patterns/Elementwise.rst new file mode 100644 index 0000000000..6e5e48b364 --- /dev/null +++ b/_sources/main/tbb_userguide/design_patterns/Elementwise.rst @@ -0,0 +1,138 @@ +.. _Elementwise: + +Elementwise +=========== + + +.. container:: section + + + .. rubric:: Problem + :class: sectiontitle + + Initiate similar independent computations across items in a data set, + and wait until all complete. + + +.. container:: section + + + .. rubric:: Context + :class: sectiontitle + + Many serial algorithms sweep over a set of items and do an + independent computation on each item. However, if some kind of + summary information is collected, use the Reduction pattern instead. + + +.. container:: section + + + .. rubric:: Forces + :class: sectiontitle + + No information is carried or merged between the computations. + + +.. container:: section + + + .. rubric:: Solution + :class: sectiontitle + + If the number of items is known in advance, use + ``oneapi::tbb::parallel_for``. If not, consider using + ``oneapi::tbb::parallel_for_each``. + + + Use agglomeration if the individual computations are small relative + to scheduler overheads. + + + If the pattern is followed by a reduction on the same data, consider + doing the element-wise operation as part of the reduction, so that + the combination of the two patterns is accomplished in a single sweep + instead of two sweeps. Doing so may improve performance by reducing + traffic through the memory hierarchy. + + +.. container:: section + + + .. rubric:: Example + :class: sectiontitle + + Convolution is often used in signal processing. The convolution of a + filter ``c`` and signal ``x`` is computed as: + + + |image0| + Serial code for this computation might look like: + + + :: + + + // Assumes c[0..clen-1] and x[1-clen..xlen-1] are defined + for( int i=0; i(0,xlen+clen-1,1000), + [=]( oneapi::tbb::blocked_range r ) { + int end = r.end(); + for( int i=r.begin(); i!=end; ++i ) { + float tmp = 0; + for( int j=0; j`` for the flag + that indicates when the message is ready. Here is the previous + example with modifications. + + + :: + + + std::atomic Ready; + std::string Message; +   + + void Send( const std::string& src ) {. // Executed by thread 1 + Message=src; + Ready.store(true, std::memory_order_release); + } +   + + bool Receive( std::string& dst ) { // Executed by thread 2 + bool result = Ready.load(std::memory_order_acquire); + if( result ) dst=Message; + return result; // Return true if message was received. + } + + + A write to a ``std::atomic`` value has *release* semantics, which + means that all of its prior writes will be seen before the releasing + write. A read from ``std::atomic`` value has *acquire* semantics, + which means that all of its subsequent reads will happen after the + acquiring read. The implementation of ``std::atomic`` ensures that + both the compiler and the hardware observe these ordering + constraints. + + +.. container:: section + + + .. rubric:: Variations + :class: sectiontitle + + Higher level synchronization constructs normally include the + necessary *acquire* and *release* fences. For example, mutexes are + normally implemented such that acquisition of a lock has *acquire* + semantics and release of a lock has *release* semantics. Thus a + thread that acquires a lock on a mutex always sees any memory writes + done by another thread before it released a lock on that mutex. + + +.. container:: section + + + .. rubric:: Non Solutions + :class: sectiontitle + + Mistaken solutions are so often proposed that it is worth + understanding why they are wrong. + + + One common mistake is to assume that declaring the flag with the + ``volatile`` keyword solves the problem. Though the ``volatile`` + keyword forces a write to happen immediately, it generally has no + effect on the visible ordering of that write with respect to other + memory operations. + + + Another mistake is to assume that conditionally executed code cannot + happen before the condition is tested. However, the compiler or + hardware may speculatively hoist the conditional code above the + condition. + + + Similarly, it is a mistake to assume that a processor cannot read the + target of a pointer before reading the pointer. A modern processor + does not read individual values from main memory. It reads cache + lines. The target of a pointer may be in a cache line that has + already been read before the pointer was read, thus giving the + appearance that the processor presciently read the pointer target. + diff --git a/_sources/main/tbb_userguide/design_patterns/GUI_Thread.rst b/_sources/main/tbb_userguide/design_patterns/GUI_Thread.rst new file mode 100644 index 0000000000..b837468c71 --- /dev/null +++ b/_sources/main/tbb_userguide/design_patterns/GUI_Thread.rst @@ -0,0 +1,205 @@ +.. _GUI_Thread: + +GUI Thread +========== + +.. container:: section + + + .. rubric:: Problem + :class: sectiontitle + + A user interface thread must remain responsive to user requests, and + must not get bogged down in long computations. + + +.. container:: section + + + .. rubric:: Context + :class: sectiontitle + + Graphical user interfaces often have a dedicated thread ("GUI + thread") for servicing user interactions. The thread must remain + responsive to user requests even while the application has long + computations running. For example, the user might want to press a + "cancel" button to stop the long running computation. If the GUI + thread takes part in the long running computation, it will not be + able to respond to user requests. + + +.. container:: section + + + .. rubric:: Forces + :class: sectiontitle + + - The GUI thread services an event loop. + + + - The GUI thread needs to offload work onto other threads without + waiting for the work to complete. + + + - The GUI thread must be responsive to the event loop and not become + dedicated to doing the offloaded work. + + +.. container:: section + + + .. rubric:: Related + :class: sectiontitle + + - Non-Preemptive Priorities + - Local Serializer + + +.. container:: section + + + .. rubric:: Solution + :class: sectiontitle + + The GUI thread offloads the work by firing off a task to do it using + method ``task_arena::enqueue`` of a ``task_arena`` instance. + When finished, the task posts an event to the GUI thread to indicate that the work is done. + The semantics of ``enqueue`` cause the task to eventually run on a worker thread + distinct from the calling thread. + + The following figure sketches the communication paths. Items in black are executed + by the GUI thread; items in blue are executed by another thread. + + |image0| + +.. container:: section + + + .. rubric:: Example + :class: sectiontitle + + The example is for the Microsoft Windows\* operating systems, though + similar principles apply to any GUI using an event loop idiom. For + each event, the GUI thread calls a user-defined function ``WndProc`` to process an event. + + + :: + + + // Event posted from enqueued task when it finishes its work. + const UINT WM_POP_FOO = WM_USER+0; + + + // Queue for transmitting results from enqueued task to GUI thread. + oneapi::tbb::concurrent_queueResultQueue; + + + // GUI thread's private copy of most recently computed result. + Foo CurrentResult; +   + + LRESULT CALLBACK WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam) { + switch(msg) { + case WM_COMMAND: + switch (LOWORD(wParam)) { + case IDM_LONGRUNNINGWORK: + // User requested a long computation. Delegate it to another thread. + LaunchLongRunningWork(hWnd); + break; + case IDM_EXIT: + DestroyWindow(hWnd); + break; + default: + return DefWindowProc(hWnd, msg, wParam, lParam); + } + break; + case WM_POP_FOO: + // There is another result in ResultQueue for me to grab. + ResultQueue.try_pop(CurrentResult); + // Update the window with the latest result. + RedrawWindow( hWnd, NULL, NULL, RDW_ERASE|RDW_INVALIDATE ); + break; + case WM_PAINT: + Repaint the window using CurrentResult + break; + case WM_DESTROY: + PostQuitMessage(0); + break; + default: + return DefWindowProc( hWnd, msg, wParam, lParam ); + } + return 0; + } + + + The GUI thread processes long computations as follows: + + + #. The GUI thread calls ``LongRunningWork``, which hands off the work + to a worker thread and immediately returns. + + + #. The GUI thread continues servicing the event loop. If it has to + repaint the window, it uses the value of\ ``CurrentResult``, which + is the most recent ``Foo`` that it has seen. + + + When a worker finishes the long computation, it pushes the result + into ResultQueue, and sends a message WM_POP_FOO to the GUI thread. + + + #. The GUI thread services a ``WM_POP_FOO`` message by popping an + item from ResultQueue into CurrentResult. The ``try_pop`` always + succeeds because there is exactly one ``WM_POP_FOO`` message for + each item in ``ResultQueue``. + + + Routine ``LaunchLongRunningWork`` creates a function task and launches it + using method ``task_arena::enqueue``. + + :: + + + class LongTask { + HWND hWnd; + void operator()() { + Do long computation + Foo x = result of long computation + ResultQueue.push( x ); + // Notify GUI thread that result is available. + PostMessage(hWnd,WM_POP_FOO,0,0); + } + public: + LongTask( HWND hWnd_ ) : hWnd(hWnd_) {} + }; + + void LaunchLongRunningWork( HWND hWnd ) { + oneapi::tbb::task_arena a; + a.enqueue(LongTask(hWnd)); + } + + + It is essential to use method ``task_arena::enqueue`` here. + Even though, an explicit ``task_arena`` instance is created, + the method ``enqueue`` ensures that the function task eventually executes when resources permit, + even if no thread explicitly waits on the task. In contrast, ``oneapi::tbb::task_group::run`` may + postpone execution of the function task until it is explicitly waited upon with the ``oneapi::tbb::task_group::wait``. + + The example uses a ``concurrent_queue`` for workers to communicate + results back to the GUI thread. Since only the most recent result + matters in the example, and alternative would be to use a shared + variable protected by a mutex. However, doing so would block the + worker while the GUI thread was holding a lock on the mutex, and vice + versa. Using ``concurrent_queue`` provides a simple robust solution. + + If two long computations are in flight, there is a chance that the + first computation completes after the second one. If displaying the + result of the most recently requested computation is important, then + associate a request serial number with the computation. The GUI + thread can pop from ``ResultQueue`` into a temporary variable, check + the serial number, and update ``CurrentResult`` only if doing so + advances the serial number. + +.. |image0| image:: Images/image007a.jpg + :width: 400px + :height: 150px diff --git a/_sources/main/tbb_userguide/design_patterns/General_References.rst b/_sources/main/tbb_userguide/design_patterns/General_References.rst new file mode 100644 index 0000000000..309d4aa602 --- /dev/null +++ b/_sources/main/tbb_userguide/design_patterns/General_References.rst @@ -0,0 +1,15 @@ +.. _General_References: + +General References +================== + + +This section lists general references. References specific to a pattern +are listed at the end of the topic for the pattern. + +- E. Gamma, R. Helm, R. Johnson, J. Vlissides. Design Patterns (1995) +- `Berkeley Pattern Language for Parallel Programming `_ +- T. Mattson, B. Sanders, B. Massingill. Patterns for Parallel Programming (2005) +- `ParaPLoP 2009 `_ +- `ParaPLoP 2010 `_ +- Eun-Gyu Kim and Marc Snir, `Parallel Programming Patterns `_ diff --git a/_sources/main/tbb_userguide/design_patterns/Lazy_Initialization.rst b/_sources/main/tbb_userguide/design_patterns/Lazy_Initialization.rst new file mode 100644 index 0000000000..6812e6c5e9 --- /dev/null +++ b/_sources/main/tbb_userguide/design_patterns/Lazy_Initialization.rst @@ -0,0 +1,109 @@ +.. _Lazy_Initialization: + +Lazy Initialization +==================== + + +.. container:: section + + + .. rubric:: Problem + :class: sectiontitle + + Delay the creation of an object, potentially expensive, until it is accessed. + In parallel programming, initialization must also be guarded against race conditions. + + +.. container:: section + + + .. rubric:: Context + :class: sectiontitle + + The cost of operations that take place during the initialization + of the object may be considerably high. In that case, the object + should be initialized only when needed. Lazy initialization is + the common tactic that allows implementing such an approach. + + +.. container:: section + + + .. rubric:: Solution + :class: sectiontitle + + Using ``oneapi::tbb::collaborative_call_once`` with ``oneapi::tbb::collaborative_once_flag`` + helps to implement thread-safe lazy initialization for a user object. + + + In addition, ``collaborative_call_once`` allows other thread blocked on + the same ``collaborative_once_flag`` to join other |short_name| + parallel constructions called within the initializing function. + + +.. container:: section + + + .. rubric:: Example + :class: sectiontitle + + This example illustrates the implementation of lazy initialization + for the calculation of the Fibonacci numbers. Here is a graphical + representation of the Fibonacci recursion tree for N=4. + + + |image0| + + + As seen in the diagram, some elements are recalculated more than once. These operations are redundant, + so the "lazy initialized" Fibonacci numbers are relevant here. + + + An implementation without the use of lazy initialization would have *O(2^N)* time complexity due to + the full recursion tree traversal and recalculation of values. Since all the nodes are traversed once, + the tree becomes a list, making the time complexity *O(N)*. + + + |image1| + + + Here you can see the code for the implementation. Already calculated values are stored in a buffer + paired with ``collaborative_once_flag`` and will not be recalculated when ``collaborative_call_once`` + is invoked when initialization has already been done. + + + :: + + + using FibBuffer = std::vector>; + + std::uint64_t LazyFibHelper(int n, FibBuffer& buffer) { + // Base case + if (n <= 1) { + return n; + } + // Calculate nth value only once and store it in the buffer. + // Other threads won't be blocked on already taken collaborative_once_flag + // but join parallelism inside functor + oneapi::tbb::collaborative_call_once(buffer[n].first, [&]() { + std::uint64_t a, b; + oneapi::tbb::parallel_invoke([&] { a = LazyFibHelper(n - 2, buffer); }, + [&] { b = LazyFibHelper(n - 1, buffer); }); + buffer[n].second = a + b; + }); + + return buffer[n].second; + } + + std::uint64_t Fib(int n) { + FibBuffer buffer(n+1); + return LazyFibHelper(n, buffer); + } + + +.. |image0| image:: Images/image008a.jpg + :width: 744px + :height: 367px +.. |image1| image:: Images/image009a.jpg + :width: 744px + :height: 367px diff --git a/_sources/main/tbb_userguide/design_patterns/Local_Serializer.rst b/_sources/main/tbb_userguide/design_patterns/Local_Serializer.rst new file mode 100644 index 0000000000..d600bccad9 --- /dev/null +++ b/_sources/main/tbb_userguide/design_patterns/Local_Serializer.rst @@ -0,0 +1,282 @@ +.. _Local_Serializer: + +Local Serializer +================ + + +.. container:: section + + + .. rubric:: Context + :class: sectiontitle + + Consider an interactive program. To maximize concurrency and + responsiveness, operations requested by the user can be implemented + as tasks. The order of operations can be important. For example, + suppose the program presents editable text to the user. There might + be operations to select text and delete selected text. Reversing the + order of "select" and "delete" operations on the same buffer would be + bad. However, commuting operations on different buffers might be + okay. Hence the goal is to establish serial ordering of tasks + associated with a given object, but not constrain ordering of tasks + between different objects. + + +.. container:: section + + + .. rubric:: Forces + :class: sectiontitle + + - Operations associated with a certain object must be performed in + serial order. + + + - Serializing with a lock would be wasteful because threads would be + waiting at the lock when they could be doing useful work + elsewhere. + + +.. container:: section + + + .. rubric:: Solution + :class: sectiontitle + + Sequence the work items using a FIFO (first-in first-out structure). + Always keep an item in flight if possible. If no item is in flight + when a work item appears, put the item in flight. Otherwise, push the + item onto the FIFO. When the current item in flight completes, pop + another item from the FIFO and put it in flight. + + + The logic can be implemented without mutexes, by using + ``concurrent_queue`` for the FIFO and ``atomic`` to count the + number of items waiting and in flight. The example explains the + accounting in detail. + + +.. container:: section + + + .. rubric:: Example + :class: sectiontitle + + The following example builds on the Non-Preemptive Priorities example + to implement local serialization in addition to priorities. It + implements three priority levels and local serializers. The user + interface for it follows: + + + :: + + + enum Priority { + P_High, + P_Medium, + P_Low + }; +   + + template + void EnqueueWork( Priority p, Func f, Serializer* s=NULL ); + + + Template function ``EnqueueWork`` causes functor ``f`` to run when + the three constraints in the following table are met. + + + .. container:: tablenoborder + + + .. list-table:: + :header-rows: 1 + + * - Constraint + - Resolved by class... + * - Any prior work for the ``Serializer`` has completed. + - \ ``Serializer`` + * - A thread is available. + - \ ``RunWorkItem`` + * - No higher priority work is ready to run. + - \ ``ReadyPileType`` + + + + + Constraints on a given functor are resolved from top to bottom in the + table. The first constraint does not exist when s is NULL. The + implementation of ``EnqueueWork`` packages the functor in a + ``SerializedWorkItem`` and routes it to the class that enforces the + first relevant constraint between pieces of work. + + + :: + + + template + void EnqueueWork( Priority p, Func f, Serializer* s=NULL ) { + WorkItem* item = new SerializedWorkItem( p, f, s ); + if( s ) + s->add(item); + else + ReadyPile.add(item); + } + + + A ``SerializedWorkItem`` is derived from a ``WorkItem``, which serves + as a way to pass around a prioritized piece of work without knowing + further details of the work. + + + :: + + + // Abstract base class for a prioritized piece of work. + class WorkItem { + public: + WorkItem( Priority p ) : priority(p) {} + // Derived class defines the actual work. + virtual void run() = 0; + const Priority priority; + }; +   + + template + class SerializedWorkItem: public WorkItem { + Serializer* serializer; + Func f; + /*override*/ void run() { + f(); + Serializer* s = serializer; + // Destroy f before running Serializer’s next functor. + delete this; + if( s ) + s->noteCompletion(); + } + public: + SerializedWorkItem( Priority p, const Func& f_, Serializer* s ) : + WorkItem(p), serializer(s), f(f_) + {} + }; + + + Base class ``WorkItem`` is the same as class WorkItem in the example + for Non-Preemptive Priorities. The notion of serial constraints is + completely hidden from the base class, thus permitting the framework + to extend other kinds of constraints or lack of constraints. Class + ``SerializedWorkItem`` is essentially ``ConcreteWorkItem`` from the + example for Non-Preemptive Priorities, extended with a ``Serializer`` + aspect. + + + Virtual method ``run()`` is invoked when it becomes time to run the + functor. It performs three steps: + + + #. Run the functor. + + + #. Destroy the functor. + + + #. Notify the ``Serializer`` that the functor completed, and thus + unconstraining the next waiting functor. + + + Step 3 is the difference from the operation of ConcreteWorkItem::run. + Step 2 could be done after step 3 in some contexts to increase + concurrency slightly. However, the presented order is recommended + because if step 2 takes non-trivial time, it likely has side effects + that should complete before the next functor runs. + + + Class ``Serializer`` implements the core of the Local Serializer + pattern: + + + :: + + + class Serializer { + oneapi::tbb::concurrent_queue queue; + std::atomic count; // Count of queued items and in-flight item + void moveOneItemToReadyPile() { // Transfer item from queue to ReadyPile + WorkItem* item; + queue.try_pop(item); + ReadyPile.add(item); + } + public: + void add( WorkItem* item ) { + queue.push(item); + if( ++count==1 ) + moveOneItemToReadyPile(); + } + void noteCompletion() { // Called when WorkItem completes. + if( --count!=0 ) + moveOneItemToReadyPile(); + } + }; + + + The class maintains two members: + + + - A queue of WorkItem waiting for prior work to complete. + + + - A count of queued or in-flight work. + + + Mutexes are avoided by using ``concurrent_queue`` and + ``atomic`` along with careful ordering of operations. The + transitions of count are the key understanding how class + ``Serializer`` works. + + + - If method ``add`` increments ``count`` from 0 to 1, this indicates + that no other work is in flight and thus the work should be moved + to the ``ReadyPile``. + + + - If method ``noteCompletion`` decrements count and it is *not* from + 1 to 0, then the queue is non-empty and another item in the queue + should be moved to ``ReadyPile``. + + + Class ``ReadyPile`` is explained in the example for Non-Preemptive + Priorities. + + + If priorities are not necessary, there are two variations on method + ``moveOneItemToReadyPile``, with different implications. + + + - Method ``moveOneItemToReadyPile`` could directly + invoke\ ``item->run()``. This approach has relatively low overhead + and high thread locality for a given ``Serializer``. But it is + unfair. If the ``Serializer`` has a continual stream of tasks, the + thread operating on it will keep servicing those tasks to the + exclusion of others. + + + - Method ``moveOneItemToReadyPile`` could invoke ``task::enqueue`` + to enqueue a task that invokes ``item->run()``. Doing so + introduces higher overhead and less locality than the first + approach, but avoids starvation. + + + The conflict between fairness and maximum locality is fundamental. + The best resolution depends upon circumstance. + + + The pattern generalizes to constraints on work items more general + than those maintained by class Serializer. A generalized + ``Serializer::add`` determines if a work item is unconstrained, and + if so, runs it immediately. A generalized + ``Serializer::noteCompletion`` runs all previously constrained items + that have become unconstrained by the completion of the current work + item. The term "run" means to run work immediately, or if there are + more constraints, forwarding the work to the next constraint + resolver. + diff --git a/_sources/main/tbb_userguide/design_patterns/Non-Preemptive_Priorities.rst b/_sources/main/tbb_userguide/design_patterns/Non-Preemptive_Priorities.rst new file mode 100644 index 0000000000..4a9795e309 --- /dev/null +++ b/_sources/main/tbb_userguide/design_patterns/Non-Preemptive_Priorities.rst @@ -0,0 +1,177 @@ +.. _Non-Preemptive_Priorities: + +Non-Preemptive Priorities +========================= + + +.. container:: section + + + .. rubric:: Problem + :class: sectiontitle + + Choose the next work item to do, based on priorities. + + +.. container:: section + + + .. rubric:: Context + :class: sectiontitle + + The scheduler in |full_name| + chooses tasks using rules based on scalability concerns. The rules + are based on the order in which tasks were spawned or enqueued, and + are oblivious to the contents of tasks. However, sometimes it is best + to choose work based on some kind of priority relationship. + + +.. container:: section + + + .. rubric:: Forces + :class: sectiontitle + + - Given multiple work items, there is a rule for which item should + be done next that is *not* the default oneTBB rule. + + + - Preemptive priorities are not necessary. If a higher priority item + appears, it is not necessary to immediately stop lower priority + items in flight. If preemptive priorities are necessary, then + non-preemptive tasking is inappropriate. Use threads instead. + + +.. container:: section + + + .. rubric:: Solution + :class: sectiontitle + + Put the work in a shared work pile. Decouple tasks from specific + work, so that task execution chooses the actual piece of work to be + selected from the pile. + + +.. container:: section + + + .. rubric:: Example + :class: sectiontitle + + The following example implements three priority levels. The user + interface for it and top-level implementation follow: + + + :: + + + enum Priority { + P_High, + P_Medium, + P_Low + }; +   + + template + void EnqueueWork( Priority p, Func f ) { + WorkItem* item = new ConcreteWorkItem( p, f ); + ReadyPile.add(item); + } + + + The caller provides a priority ``p`` and a functor ``f`` to routine ``EnqueueWork``. + The functor may be the result of a lambda expression. ``EnqueueWork`` packages ``f`` as a ``WorkItem`` and adds + it to global object ``ReadyPile``. + + + Class ``WorkItem`` provides a uniform interface for running functors of unknown type: + + + :: + + + // Abstract base class for a prioritized piece of work. + class WorkItem { + public: + WorkItem( Priority p ) : priority(p) {} + // Derived class defines the actual work. + virtual void run() = 0; + const Priority priority; + }; +   + + template + class ConcreteWorkItem: public WorkItem { + Func f; + /*override*/ void run() { + f(); + delete this; + } + public: + ConcreteWorkItem( Priority p, const Func& f_ ) : + WorkItem(p), f(f_) + {} + }; + + + Class ``ReadyPile`` contains the core pattern. It maintains a + collection of work and fires off tasks through the ``oneapi::tbb::task_group::run`` interface + and then choose a work from the collection: + + + :: + + + class ReadyPileType { + // One queue for each priority level + oneapi::tbb::concurrent_queue level[P_Low+1]; + oneapi::tbb::task_group tg; + public: + void add( WorkItem* item ) { + level[item->priority].push(item); + tg.run(RunWorkItem()); + } + void runNextWorkItem() { + // Scan queues in priority order for an item. + WorkItem* item=NULL; + for( int i=P_High; i<=P_Low; ++i ) + if( level[i].try_pop(item) ) + break; + assert(item); + item->run(); + } + }; +   + + ReadyPileType ReadyPile; + + + The task added by ``add(item)`` does *not* necessarily execute + that item. The task itself executes ``runNextWorkItem()``, which may find a + higher priority item. There is one task for each item, but the + mapping resolves when the task actually executes, not when it is created. + + Here are the details of class ``RunWorkItem``: + + :: + + class RunWorkItem { + void operator()() { + ReadyPile.runNextWorkItem(); + }; + }; + + + ``RunWorkItem`` objects are fungible. They enable the oneTBB + scheduler to choose when to do a work item, not which work item to do. + + + Other priority schemes can be implemented by changing the internals + for ``ReadyPileType``. A priority queue could be used to implement + very fine grained priorities. + + The scalability of the pattern is limited by the scalability of + ``ReadyPileType``. Ideally scalable concurrent containers should be + used for it. + diff --git a/_sources/main/tbb_userguide/design_patterns/Odd-Even_Communication.rst b/_sources/main/tbb_userguide/design_patterns/Odd-Even_Communication.rst new file mode 100644 index 0000000000..749c1b57b1 --- /dev/null +++ b/_sources/main/tbb_userguide/design_patterns/Odd-Even_Communication.rst @@ -0,0 +1,61 @@ +.. _Odd-Even_Communication: + +Odd-Even Communication +====================== + + +.. container:: section + + + .. rubric:: Problem + :class: sectiontitle + + Operations on data cannot be done entirely independently, but data + can be partitioned into two subsets such that all operations on a + subset can run in parallel. + + +.. container:: section + + + .. rubric:: Context + :class: sectiontitle + + Solvers for partial differential equations can often be modified to + follow this pattern. For example, for a 2D grid with only + nearest-neighbor communication, it may be possible to treat the grid + as a checkerboard, and alternate between updating red squares and + black squares. + + + Another context is staggered grid ("leap frog") Finite Difference + Time Domain (FDTD solvers, which naturally fit the pattern. + + +.. container:: section + + + .. rubric:: Forces + :class: sectiontitle + + - Dependencies between items form a bipartite graph. + + +.. container:: section + + + .. rubric:: Solution + :class: sectiontitle + + Alternate between updating one subset and then the other subset. + Apply the elementwise pattern to each subset. + +.. container:: section + + + .. rubric:: References + :class: sectiontitle + + Eun-Gyu Kim and Mark Snir, "Odd-Even Communication Group", + http://snir.cs.illinois.edu/patterns/oddeven.pdf + diff --git a/_sources/main/tbb_userguide/design_patterns/Reduction.rst b/_sources/main/tbb_userguide/design_patterns/Reduction.rst new file mode 100644 index 0000000000..491a95b9d4 --- /dev/null +++ b/_sources/main/tbb_userguide/design_patterns/Reduction.rst @@ -0,0 +1,281 @@ +.. _Reduction: + +Reduction +========= + + +.. container:: section + + + .. rubric:: Problem + :class: sectiontitle + + Perform an associative reduction operation across a data set. + + +.. container:: section + + + .. rubric:: Context + :class: sectiontitle + + Many serial algorithms sweep over a set of items to collect summary + information. + + +.. container:: section + + + .. rubric:: Forces + :class: sectiontitle + + The summary can be expressed as an associative operation over the + data set, or at least is close enough to associative that + reassociation does not matter. + + +.. container:: section + + + .. rubric:: Solution + :class: sectiontitle + + Two solutions exist in |full_name|. + The choice on which to use depends upon several considerations: + + + - Is the operation commutative as well as associative? + + + - Are instances of the reduction type expensive to construct and + destroy. For example, a floating point number is inexpensive to + construct. A sparse floating-point matrix might be very expensive + to construct. + + + Use ``oneapi::tbb::parallel_reduce`` when the objects are inexpensive to + construct. It works even if the reduction operation is not + commutative. + + + Use ``oneapi::tbb::parallel_for`` and ``oneapi::tbb::combinable`` if the reduction + operation is commutative and instances of the type are expensive. + + + If the operation is not precisely associative but a precisely + deterministic result is required, use recursive reduction and + parallelize it using ``oneapi::tbb::parallel_invoke``. + + +.. container:: section + + + .. rubric:: Examples + :class: sectiontitle + + The examples presented here illustrate the various solutions and some + tradeoffs. + + + The first example uses ``oneapi::tbb::parallel_reduce`` to do a + reduction + over sequence of type ``T``. The sequence is defined by a half-open + interval [first,last). + + + :: + + + T AssociativeReduce( const T* first, const T* last, T identity ) { + return oneapi::tbb::parallel_reduce( + // Index range for reduction + oneapi::tbb::blocked_range(first,last), + // Identity element + identity, + // Reduce a subrange and partial sum + [&]( oneapi::tbb::blocked_range r, T partial_sum )->float { + return std::accumulate( r.begin(), r.end(), partial_sum ); + }, + // Reduce two partial sums + std::plus() + ); + } + + + The third and fourth arguments to this form of ``parallel_reduce`` + are a built in form of the agglomeration pattern. If there is an + elementwise action to be performed before the reduction, + incorporating it into the third argument (reduction of a subrange) + may improve performance because of better locality of reference. Note + that the block size for agglomeration is not explicitly specified; + ``parallel_reduce`` defines blocks automatically with the help of + implicitly used ``oneapi::tbb::auto_partitioner``. + + + The second example assumes the + is commutative on ``T``. It is a + good solution when ``T`` objects are expensive to construct. + + + :: + + + T CombineReduce( const T* first, const T* last, T identity ) { + oneapi::tbb::combinable sum(identity); + oneapi::tbb::parallel_for( + oneapi::tbb::blocked_range(first,last), + [&]( oneapi::tbb::blocked_range r ) { + sum.local() += std::accumulate(r.begin(), r.end(), identity); + } + ); + return sum.combine( []( const T& x, const T& y ) {return x+y;} ); + } + + + Sometimes it is desirable to destructively use the partial results to + generate the final result. For example, if the partial results are + lists, they can be spliced together to form the final result. In that + case use class ``oneapi::tbb::enumerable_thread_specific`` instead of + ``combinable``. The ``ParallelFindCollisions`` example in :ref:`Divide_and_Conquer` + demonstrates the technique. + + + Floating-point addition and multiplication are almost associative. + Reassociation can cause changes because of rounding effects. The + techniques shown so far reassociate terms non-deterministically. + Fully deterministic parallel reduction for a not quite associative + operation requires using deterministic reassociation. The code below + demonstrates this in the form of a template that does a + reduction + over a sequence of values of type ``T``. + + + :: + + + template + T RepeatableReduce( const T* first, const T* last, T identity ) { + if( last-first<=1000 ) { + // Use serial reduction + return std::accumulate( first, last, identity ); + } else { + // Do parallel divide-and-conquer reduction + const T* mid = first+(last-first)/2; + T left, right; + oneapi::tbb::parallel_invoke( + [&]{left=RepeatableReduce(first,mid,identity);}, + [&]{right=RepeatableReduce(mid,last,identity);} + ); + return left+right; + } + } + + + The outer if-else is an instance of the agglomeration pattern for + recursive computations. The reduction graph, though not a strict + binary tree, is fully deterministic. Thus the result will always be + the same for a given input sequence, assuming all threads do + identical floating-point rounding. + + + ``oneapi::tbb::parallel_deterministic_reduce`` is a simpler and more + efficient way to get reproducible non-associative reduction. It is + very similar to ``oneapi::tbb::parallel_reduce`` but, unlike the latter, + builds a deterministic reduction graph. With it, the + ``RepeatableReduce`` sample can be almost identical to + ``AssociativeReduce``: + + + :: + + + template + T RepeatableReduce( const T* first, const T* last, T identity ) { + return oneapi::tbb::parallel_deterministic_reduce( + // Index range for reduction + oneapi::tbb::blocked_range(first,last,1000), + // Identity element + identity, + // Reduce a subrange and partial sum + [&]( oneapi::tbb::blocked_range r, T partial_sum )->float { + return std::accumulate( r.begin(), r.end(), partial_sum ); + }, + // Reduce two partial sums + std::plus() + ); + } + + + Besides the function name change, note the grain size of 1000 + specified for ``oneapi::tbb::blocked_range``. It defines the desired block + size for agglomeration; automatic block size selection is not used + due to non-determinism. + + + The final example shows how a problem that typically is not viewed as + a reduction can be parallelized by viewing it as a reduction. The + problem is retrieving floating-point exception flags for a + computation across a data set. The serial code might look something + like: + + + :: + + + feclearexcept(FE_ALL_EXCEPT); + for( int i=0; i r ) { + int end=r.end(); + for( int i=r.begin(); i!=end; ++i ) + C[i] = A[i]/B[i]; + // It is critical to do |= here, not =, because otherwise we + // might lose earlier exceptions from the same thread. + flags |= fetestexcept(FE_ALL_EXCEPT); + } + // Called by parallel_reduce when joining results from two subranges. + void join( Body& other ) { + flags |= other.flags; + } + }; + + + Then invoke it as follows: + + + :: + + + // Construction of cc implicitly resets FP exception state. + ComputeChunk cc; + oneapi::tbb::parallel_reduce( oneapi::tbb::blocked_range(0,N), cc ); + if (cc.flags & FE_DIVBYZERO) ...; + if (cc.flags & FE_OVERFLOW) ...; + ... + diff --git a/_sources/main/tbb_userguide/design_patterns/Reference_Counting.rst b/_sources/main/tbb_userguide/design_patterns/Reference_Counting.rst new file mode 100644 index 0000000000..b82df15a30 --- /dev/null +++ b/_sources/main/tbb_userguide/design_patterns/Reference_Counting.rst @@ -0,0 +1,144 @@ +.. _Reference_Counting: + +Reference Counting +================== + + +.. container:: section + + + .. rubric:: Problem + :class: sectiontitle + + Destroy an object when it will no longer be used. + + +.. container:: section + + + .. rubric:: Context + :class: sectiontitle + + Often it is desirable to destroy an object when it is known that it + will not be used in the future. Reference counting is a common serial + solution that extends to parallel programming if done carefully. + + +.. container:: section + + + .. rubric:: Forces + :class: sectiontitle + + - If there are cycles of references, basic reference counting is + insufficient unless the cycle is explicitly broken. + + + - Atomic counting is relatively expensive in hardware. + + +.. container:: section + + + .. rubric:: Solution + :class: sectiontitle + + Thread-safe reference counting is like serial reference counting, + except that the increment/decrement is done atomically, and the + decrement and test "count is zero?" must act as a single atomic + operation. The following example uses ``std::atomic`` to achieve + this. + + + :: + + + template + class counted { + std::atomic my_count; + T value; + public: + // Construct object with a single reference to it. + counted() {my_count=1;} + // Add reference + void add_ref() {++my_count;} + // Remove reference. Return true if it was the last reference. + bool remove_ref() {return --my_count==0;} + // Get reference to underlying object + T& get() { + assert(my_count>0); + return my_value; + } + }; + + + It is incorrect to use a separate read for testing if the count is + zero. The following code would be an incorrect implementation of + method ``remove_ref``\ () because two threads might both execute the + decrement, and then both read ``my_count`` as zero. Hence two callers + would both be told incorrectly that they had removed the last + reference. + + + :: + + + --my_count; + return my_count==0. // WRONG! + + + The decrement may need to have a *release* fence so that any pending + writes complete before the object is deleted. + + + There is no simple way to atomically copy a pointer and increment its + reference count, because there will be a timing hole between the + copying and the increment where the reference count is too low, and + thus another thread might decrement the count to zero and delete the + object. Two ways to address the problem are "hazard pointers" and + "pass the buck". See the references below for details. + + +.. container:: section + + + .. rubric:: Variations + :class: sectiontitle + + Atomic increment/decrement can be more than an order of magnitude + more expensive than ordinary increment/decrement. The serial + optimization of eliminating redundant increment/decrement operations + becomes more important with atomic reference counts. + + + Weighted reference counting can be used to reduce costs if the + pointers are unshared but the referent is shared. Associate a + *weight* with each pointer. The reference count is the sum of the + weights. A pointer ``x`` can be copied as a pointer ``x'`` without + updating the reference count by splitting the original weight between + ``x`` and ``x'``. If the weight of ``x`` is too low to split, then first add a + constant W to the reference count and weight of ``x``. + + +.. container:: section + + + .. rubric:: References + :class: sectiontitle + + D. Bacon and V.T. Rajan, "Concurrent Cycle Collection in Reference + Counted Systems" in Proc. European Conf. on Object-Oriented + Programming (June 2001). Describes a garbage collector based on + reference counting that does collect cycles. + + + M. Michael, "Hazard Pointers: Safe Memory Reclamation for Lock-Free + Objects" in IEEE Transactions on Parallel and Distributed Systems + (June 2004). Describes the "hazard pointer" technique. + + + M. Herlihy, V. Luchangco, and M. Moir, "The Repeat Offender Problem: + A Mechanism for Supporting Dynamic-Sized, Lock-Free Data Structures" + in Proceedings of the 16th International Symposium on Distributed + Computing (Oct. 2002). Describes the "pass the buck" technique. + diff --git a/_sources/main/tbb_userguide/design_patterns/Wavefront.rst b/_sources/main/tbb_userguide/design_patterns/Wavefront.rst new file mode 100644 index 0000000000..28776e4a8d --- /dev/null +++ b/_sources/main/tbb_userguide/design_patterns/Wavefront.rst @@ -0,0 +1,199 @@ +.. _Wavefront: + +Wavefront +========= + + +.. container:: section + + + .. rubric:: Problem + :class: sectiontitle + + Perform computations on items in a data set, where the computation on + an item uses results from computations on predecessor items. + + +.. container:: section + + + .. rubric:: Context + :class: sectiontitle + + The dependences between computations form an acyclic graph. + + +.. container:: section + + + .. rubric:: Forces + :class: sectiontitle + + - Dependence constraints between items form an acyclic graph. + + + - The number of immediate predecessors in the graph is known in + advance, or can be determined some time before the last + predecessor completes. + + +.. container:: section + + + .. rubric:: Solution + :class: sectiontitle + + The solution is a parallel variant of topological sorting, using + ``oneapi::tbb::parallel_for_each`` to process items. Associate an atomic + counter with each item. Initialize each counter to the number of + predecessors. Invoke ``oneapi::tbb::parallel_for_each`` to process the items that + have no predessors (have counts of zero). After an item is processed, + decrement the counters of its successors. If a successor's counter + reaches zero, add that successor to the ``oneapi::tbb::parallel_for_each`` + via a "feeder". + + + If the number of predecessors for an item cannot be determined in + advance, treat the information "know number of predecessors" as an + additional predecessor. When the number of predecessors becomes + known, treat this conceptual predecessor as completed. + + + If the overhead of counting individual items is excessive, aggregate + items into blocks, and do the wavefront over the blocks. + + +.. container:: section + + + .. rubric:: Example + :class: sectiontitle + + Below is a serial kernel for the longest common subsequence + algorithm. The parameters are strings ``x`` and ``y`` with respective + lengths ``xlen`` and ``ylen``. + + + :: + + + int F[MAX_LEN+1][MAX_LEN+1]; + + + void SerialLCS( const char* x, size_t xlen, const char* y, size_t ylen ) + { + for( size_t i=1; i<=xlen; ++i ) + for( size_t j=1; j<=ylen; ++j ) + F[i][j] = x[i-1]==y[j-1] ? F[i-1][j-1]+1: + max(F[i][j-1],F[i-1][j]); + } + + + The kernel sets ``F[i][j]`` to the length of the longest common + subsequence shared by ``x[0..i-1]`` and ``y[0..j-1]``. It assumes + that F[0][0..ylen] and ``F[0..xlen][0]`` have already been + initialized to zero. + + + The following figure shows the data dependences for calculating + ``F[i][j]``. + + + .. container:: fignone + :name: fig3 + + + Data dependences for longest common substring calculation. + |image0| + + + The following figure shows the gray diagonal dependence is the + transitive closure of other dependencies. Thus for parallelization + purposes it is a redundant dependence that can be ignored. + + + .. container:: fignone + :name: fig4 + + + Diagonal dependence is redundant. + |image1| + + + It is generally good to remove redundant dependences from + consideration, because the atomic counting incurs a cost for each + dependence considered. + + + Another consideration is grain size. Scheduling each ``F[i][j]`` + element calculation separately is prohibitively expensive. A good + solution is to aggregate the elements into contiguous blocks, and + process the contents of a block serially. The blocks have the same + dependence pattern, but at a block scale. Hence scheduling overheads + can be amortized over blocks. + + + The parallel code follows. Each block consists of ``N×N`` elements. + Each block has an associated atomic counter. Array ``Count`` + organizes these counters for easy lookup. The code initializes the + counters and then rolls a wavefront using ``parallel_for_each``, + starting with the block at the origin since it has no predecessors. + + + :: + + + const int N = 64; + std::atomic Count[MAX_LEN/N+1][MAX_LEN/N+1]; +   + + void ParallelLCS( const char* x, size_t xlen, const char* y, size_t ylen ) { + // Initialize predecessor counts for blocks. + size_t m = (xlen+N-1)/N; + size_t n = (ylen+N-1)/N; + for( int i=0; i0)+(j>0); + // Roll the wavefront from the origin. + typedef pair block; + block origin(0,0); + oneapi::tbb::parallel_for_each( &origin, &origin+1, + [=]( const block& b, oneapi::tbb::feeder&feeder ) { + // Extract bounds on block + size_t bi = b.first; + size_t bj = b.second; + size_t xl = N*bi+1; + size_t xu = min(xl+N,xlen+1); + size_t yl = N*bj+1; + size_t yu = min(yl+N,ylen+1); + // Process the block + for( size_t i=xl; i f( g, 1, []( int i ) -> int { + return spin_for(i); + } ); + f.try_put(1); + g.wait_for_all(); + } + }; + + + void no_wait_for_all_enqueue() { + task_arena a; + a.enqueue(background_task()); + // do other things without waiting… + } + + +In the code snippet above, the enqueued task executes at some point, but +it's not clear when. If you need to use the results of the enqueued +task, or even ensure that it completes before the program ends, you will +need to use some mechanism to signal from the enqueued task that the +graph is complete. + diff --git a/_sources/main/tbb_userguide/estimate_flow_graph_performance.rst b/_sources/main/tbb_userguide/estimate_flow_graph_performance.rst new file mode 100644 index 0000000000..e5af0c2468 --- /dev/null +++ b/_sources/main/tbb_userguide/estimate_flow_graph_performance.rst @@ -0,0 +1,52 @@ +.. _estimate_flow_graph_performance: + +Estimating Flow Graph Performance +================================= + + +The performance or scalability of a flow graph is not easy to predict. +However there are a few key points that can guide you in estimating the +limits on performance and speedup of some graphs. + + +.. container:: section + + + .. rubric:: The Critical Path Limits the Scalability in a Dependence + Graph + :class: sectiontitle + + A critical path is the most time consuming path from a node with no + predecessors to a node with no successors. In a dependence graph, the + execution of the nodes along a path cannot be overlapped since they + have a strict ordering. Therefore, for a dependence graph, the + critical path limits scalability. + + + More formally, let T be the total time consumed by all of the nodes + in your graph if executed sequentially. Then let C be the time + consumed along the path that takes the most time. The nodes along + this path cannot be overlapped even in a parallel execution. + Therefore, even if all other paths are executed in parallel with C, + the wall clock time for the parallel execution is at least C, and the + maximum possible speedup (ignoring microarchitectural and memory + effects) is T/C. + + +.. container:: section + + + .. rubric:: There is Overhead in Spawning a Node's Body as a Task + :class: sectiontitle + + The bodies of ``input_nodes``, ``function_nodes``, ``continue_nodes`` and + ``multifunction_nodes`` execute within spawned tasks by default. This + means that you need to take into account the overhead of task + scheduling when estimating the time it takes for a node to execute + its body. All of the rules of thumb for determining the appropriate + granularity of tasks therefore also apply to node bodies as well. If + you have many fine-grained nodes in your flow graph, the impact of + these overheads can noticeably impact your performance. However, + depending on the graph structure, you can reduce such overheads by + using lightweight policy with these nodes. + diff --git a/_sources/main/tbb_userguide/parallel_for_os.rst b/_sources/main/tbb_userguide/parallel_for_os.rst new file mode 100644 index 0000000000..cbc7578f4c --- /dev/null +++ b/_sources/main/tbb_userguide/parallel_for_os.rst @@ -0,0 +1,125 @@ +.. _parallel_for: + +parallel_for +============ + + +Suppose you want to apply a function ``Foo`` to each element of an +array, and it is safe to process each element concurrently. Here is the +sequential code to do this: + + +:: + + + void SerialApplyFoo( float a[], size_t n ) { + for( size_t i=0; i!=n; ++i ) + Foo(a[i]); + } + + +The iteration space here is of type ``size_t``, and goes from ``0`` to +``n-1``. The template function ``oneapi::tbb::parallel_for`` breaks this iteration +space into chunks, and runs each chunk on a separate thread. The first +step in parallelizing this loop is to convert the loop body into a form +that operates on a chunk. The form is an STL-style function object, +called the *body* object, in which ``operator()`` processes a chunk. The +following code declares the body object. + +:: + + #include "oneapi/tbb.h" + + using namespace oneapi::tbb; + + class ApplyFoo { + float *const my_a; + public: + void operator()( const blocked_range& r ) const { + float *a = my_a; + for( size_t i=r.begin(); i!=r.end(); ++i ) + Foo(a[i]); + } + ApplyFoo( float a[] ) : + my_a(a) + {} + }; + + +The ``using`` directive in the example enables you to use the library +identifiers without having to write out the namespace prefix ``oneapi::tbb`` +before each identifier. The rest of the examples assume that such a +``using`` directive is present. + + +Note the argument to ``operator()``. A ``blocked_range`` is a +template class provided by the library. It describes a one-dimensional +iteration space over type ``T``. Class ``parallel_for`` works with other +kinds of iteration spaces too. The library provides ``blocked_range2d``, +``blocked_range3d``, and ``blocked_nd_range`` for multidimensional spaces. +You can define your own spaces as explained +in :ref:`Advanced_Topic_Other_Kinds_of_Iteration_Spaces`. + + +An instance of ``ApplyFoo`` needs member fields that remember all the +local variables that were defined outside the original loop but used +inside it. Usually, the constructor for the body object will initialize +these fields, though ``parallel_for`` does not care how the body object +is created. Template function ``parallel_for`` requires that the body +object have a copy constructor, which is invoked to create a separate +copy (or copies) for each worker thread. It also invokes the destructor +to destroy these copies. In most cases, the implicitly generated copy +constructor and destructor work correctly. If they do not, it is almost +always the case (as usual in C++) that you must define *both* to be +consistent. + + +Because the body object might be copied, its ``operator()`` should not +modify the body. Otherwise the modification might or might not become +visible to the thread that invoked ``parallel_for``, depending upon +whether ``operator()`` is acting on the original or a copy. As a +reminder of this nuance, ``parallel_for`` requires that the body +object's ``operator()`` be declared ``const``. + + +The example ``operator()`` loads ``my_a`` into a local variable ``a``. +Though not necessary, there are two reasons for doing this in the +example: + + +- **Style**. It makes the loop body look more like the original. + + +- **Performance**. Sometimes putting frequently accessed values into + local variables helps the compiler optimize the loop better, because + local variables are often easier for the compiler to track. + + +Once you have the loop body written as a body object, invoke the +template function ``parallel_for``, as follows: + + +:: + + + #include "oneapi/tbb.h" +   + + void ParallelApplyFoo( float a[], size_t n ) { + parallel_for(blocked_range(0,n), ApplyFoo(a)); + } + + +The ``blocked_range`` constructed here represents the entire iteration +space from 0 to n-1, which ``parallel_for`` divides into subspaces for +each processor. The general form of the constructor is +``blocked_range(begin,end,grainsize)``. The ``T`` specifies the value +type. The arguments ``begin`` and ``end`` specify the iteration space +STL-style as a half-open interval [``begin``,\ ``end``). The argument +*grainsize* is explained in the :ref:`Controlling_Chunking` section. The +example uses the default grainsize of 1 because by default +``parallel_for`` applies a heuristic that works well with the default +grainsize. + +.. include:: parallel_for_toctree.rst + diff --git a/_sources/main/tbb_userguide/parallel_for_toctree.rst b/_sources/main/tbb_userguide/parallel_for_toctree.rst new file mode 100644 index 0000000000..75e8fb5c6a --- /dev/null +++ b/_sources/main/tbb_userguide/parallel_for_toctree.rst @@ -0,0 +1,10 @@ +.. _parallel_for_toctree: + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/Lambda_Expressions + ../tbb_userguide/Automatic_Chunking + ../tbb_userguide/Controlling_Chunking_os + ../tbb_userguide/Bandwidth_and_Cache_Affinity_os + ../tbb_userguide/Partitioner_Summary \ No newline at end of file diff --git a/_sources/main/tbb_userguide/parallel_reduce.rst b/_sources/main/tbb_userguide/parallel_reduce.rst new file mode 100644 index 0000000000..328decb8ee --- /dev/null +++ b/_sources/main/tbb_userguide/parallel_reduce.rst @@ -0,0 +1,186 @@ +.. _parallel_reduce: + +parallel_reduce +=============== + + +A loop can do a reduction, as in this summation: + + +:: + + + float SerialSumFoo( float a[], size_t n ) { + float sum = 0; + for( size_t i=0; i!=n; ++i ) + sum += Foo(a[i]); + return sum; + } + + +If the iterations are independent, you can parallelize this loop using +the template class ``parallel_reduce`` as follows: + + +:: + + + float ParallelSumFoo( const float a[], size_t n ) { + SumFoo sf(a); + parallel_reduce( blocked_range(0,n), sf ); + return sf.my_sum; + } + + +The class ``SumFoo`` specifies details of the reduction, such as how to +accumulate subsums and combine them. Here is the definition of class +``SumFoo``: + + +:: + + + class SumFoo { + float* my_a; + public: + float my_sum; + void operator()( const blocked_range& r ) { + float *a = my_a; + float sum = my_sum; + size_t end = r.end(); + for( size_t i=r.begin(); i!=end; ++i ) + sum += Foo(a[i]); + my_sum = sum; + } +   + + SumFoo( SumFoo& x, split ) : my_a(x.my_a), my_sum(0) {} +   + + void join( const SumFoo& y ) {my_sum+=y.my_sum;} + + + SumFoo(float a[] ) : + my_a(a), my_sum(0) + {} + }; + + +Note the differences with class ``ApplyFoo`` from parallel_for. First, +``operator()`` is *not* ``const``. This is because it must update +SumFoo::my_sum. Second, ``SumFoo`` has a *splitting constructor* and a +method ``join`` that must be present for ``parallel_reduce`` to work. +The splitting constructor takes as arguments a reference to the original +object, and a dummy argument of type ``split``, which is defined by the +library. The dummy argument distinguishes the splitting constructor from +a copy constructor. + + +.. tip:: + In the example, the definition of ``operator()`` uses local temporary + variables (``a``, ``sum``, ``end``) for scalar values accessed inside + the loop. This technique can improve performance by making it obvious + to the compiler that the values can be held in registers instead of + memory. If the values are too large to fit in registers, or have + their address taken in a way the compiler cannot track, the technique + might not help. With a typical optimizing compiler, using local + temporaries for only written variables (such as ``sum`` in the + example) can suffice, because then the compiler can deduce that the + loop does not write to any of the other locations, and hoist the + other reads to outside the loop. + + +When a worker thread is available, as decided by the task scheduler, +``parallel_reduce`` invokes the splitting constructor to create a +subtask for the worker. When the subtask completes, ``parallel_reduce`` +uses method ``join`` to accumulate the result of the subtask. The graph +at the top of the following figure shows the split-join sequence that +happens when a worker is available: + + +.. container:: fignone + :name: fig5 + + + Graph of the Split-join Sequence + |image0| + + +An arrows in the above figure indicate order in time. The splitting +constructor might run concurrently while object ``x`` is being used for the +first half of the reduction. Therefore, all actions of the splitting +constructor that creates y must be made thread safe with respect to ``x``. +So if the splitting constructor needs to increment a reference count +shared with other objects, it should use an atomic increment. + + +If a worker is not available, the second half of the iteration is +reduced using the same body object that reduced the first half. That is +the reduction of the second half starts where reduction of the first +half finished. + + +.. CAUTION:: + Since split/join are not used if workers are unavailable, + ``parallel_reduce`` does not necessarily do recursive splitting. + + +.. CAUTION:: + Since the same body might be used to accumulate multiple subranges, + it is critical that ``operator()`` not discard earlier accumulations. + The code below shows an incorrect definition of + ``SumFoo::operator()``. + + +:: + + + class SumFoo { + ... + public: + float my_sum; + void operator()( const blocked_range& r ) { + ... + float sum = 0; // WRONG – should be 'sum = my_sum". + ... + for( ... ) + sum += Foo(a[i]); + my_sum = sum; + } + ... + }; + + +With the mistake, the body returns a partial sum for the last subrange +instead of all subranges to which ``parallel_reduce`` applies it. + + +The rules for partitioners and grain sizes for ``parallel_reduce`` are +the same as for ``parallel_for``. + + +``parallel_reduce`` generalizes to any associative operation. In +general, the splitting constructor does two things: + + +- Copy read-only information necessary to run the loop body. + + +- Initialize the reduction variable(s) to the identity element of the + operation(s). + + +The join method should do the corresponding merge(s). You can do more +than one reduction at the same time: you can gather the min and max with +a single ``parallel_reduce``. + + +.. note:: + The reduction operation can be non-commutative. The example still + works if floating-point addition is replaced by string concatenation. + + +.. |image0| image:: Images/image009.jpg + :width: 512px + :height: 438px + diff --git a/_sources/main/tbb_userguide/std_invoke.rst b/_sources/main/tbb_userguide/std_invoke.rst new file mode 100644 index 0000000000..17ee7add99 --- /dev/null +++ b/_sources/main/tbb_userguide/std_invoke.rst @@ -0,0 +1,217 @@ +.. _std_invoke: + +Invoke a Callable Object +========================== + +Starting from C++17, the requirements for callable objects passed to algorithms or Flow Graph nodes are relaxed. It allows using additional types of bodies. +Previously, the body of the algorithm or Flow Graph node needed to be a Function Object (see `C++ Standard Function Object `_) and provide an +``operator()`` that accepts input parameters. + +Now the body needs to meet the more relaxed requirements of being Callable (see `C++ Standard Callable `_) that covers three types of objects: + +* **Function Objects that provide operator(arg1, arg2, ...)**, which accepts the input parameters +* **Pointers to member functions** that you can use as the body of the algorithm or the Flow Graph node +* **Pointers to member objects** work as the body of the algorithm or parallel construct + +You can use it not only for a Flow Graph but also for algorithms. See the example below: + +.. code:: + + // The class models oneTBB Range + class StrideRange { + public: + StrideRange(int* s, std::size_t sz, std::size_t str) + : start(s), size(sz), stride(str) {} + + // A copy constructor + StrideRange(const StrideRange&) = default; + + // A splitting constructor + StrideRange(StrideRange& other, oneapi::tbb::split) + : start(other.start), size(other.size / 2) + { + other.size -= size; + other.start += size; + } + + ~StrideRange() = default; + + // Indicate if the range is empty + bool empty() const { + return size == 0; + } + + // Indicate if the range can be divided + bool is_divisible() const { + return size >= stride; + } + + void iterate() const { + for (std::size_t i = 0; i < size; i += stride) { + // Performed an action for each element of the range, + // implement the code based on your requirements + } + } + + private: + int* start; + std::size_t size; + std::size_t stride; + }; + +Where: + +* The ``StrideRange`` class models oneTBB range that should be iterated with a specified stride during its initial construction. +* The ``stride`` value is stored in a private field within the range. Therefore, the class provides the member function ``iterate() const`` that implements a loop with the specified stride. + +``range.iterate()`` +******************* + +Before C++17, to utilize a range in a parallel algorithm, such as ``parallel_for``, it was required to provide a ``Function Object`` as the algorithm's body. This Function Object defined the operations to be executed on each iteration of the range: + +.. code:: + + int main() { + std::size_t array_size = 1000; + + int* array_to_iterate = new int[array_size]; + + StrideRange range(array_to_iterate, array_size, /* stride = */ 2); + + // Define a lambda function as the body of the parallel_for loop + auto pfor_body = [] (const StrideRange& range) { + range.iterate(); + }; + + // Perform parallel iteration + oneapi::tbb::parallel_for(range, pfor_body); + + delete[] array_to_iterate; + } + +An additional lambda function ``pfor_body`` was also required. This lambda function invoked the ``rage.iterate()`` function. + +Now with C++17, you can directly utilize a pointer to ``range.iterate()`` as the body of the algorithm: + +.. code:: + + int main() { + std::size_t array_size = 1000; + + int* array_to_iterate = new int[array_size]; + + // Performs the iteration over the array elements with the specified stride + StrideRange range(array_to_iterate, array_size, /* stride = */ 2); + + // Parallelize the iteration over the range object + oneapi::tbb::parallel_for(range, &StrideRange::iterate); + + delete[] array_to_iterate; + } + +``std::invoke`` +**************** + +``std::invoke`` is a function template that provides a syntax for invoking different types of callable objects with a set of arguments. + +oneTBB implementation uses the C++ standard function ``std::invoke(&StrideRange::iterate, range)`` to execute the body. It is the equivalent of ``range.iterate()``. +Therefore, it allows you to invoke a callable object, such as a function object, with the provided arguments. + +.. tip:: Refer to `C++ Standard `_ to learn more about ``std::invoke``. + +Example +^^^^^^^^ + +Consider a specific scenario with ``function_node`` within a Flow Graph. + +In the example below, a ``function_node`` takes an object as an input to read a member object of that input and proceed it to the next node in the graph: + +.. code:: + + struct Object { + int number; + }; + + int main() { + using namespace oneapi::tbb::flow; + + // Lambda function to read the member object of the input Object + auto number_reader = [] (const Object& obj) { + return obj.number; + }; + + // Lambda function to process the received integer + auto number_processor = [] (int i) { /* processing integer */ }; + + graph g; + + // Function node that takes an Object as input and produces an integer + function_node func1(g, unlimited, number_reader); + + // Function node that takes an integer as input and processes it + function_node func2(g, unlimited, number_processor); + + // Connect the function nodes + make_edge(func1, func2); + + // Provide produced input to the graph + func1.try_put(Object{1}); + + // Wait for the graph to complete + g.wait_for_all(); + } + + +Before C++17, the ``function_node`` in the Flow Graph required the body to be a Function Object. A lambda function was required to extract the number from the Object. + +With C++17, you can use ``std::invoke`` with a pointer to the member number directly as the body. + +You can update the previous example as follows: + +.. code:: + + struct Object { + int number; + }; + + int main() { + using namespace oneapi::tbb::flow; + + // The processing logic for the received integer + auto number_processor = [] (int i) { /* processing integer */ }; + + // Create a graph object g to hold the flow graph + graph g; + + // Use a member function pointer to the number member of the Object struct as the body + function_node func1(g, unlimited, &Object::number); + + // Use the number_processor lambda function as the body + function_node func2(g, unlimited, number_processor); + + // Connect the function nodes + make_edge(func1, func2); + + // Connect the function nodes + func1.try_put(Object{1}); + + // Wait for the graph to complete + g.wait_for_all(); + } + +Find More +********* + +The following APIs supports Callable object as Bodies: + +* `parallel_for `_ +* `parallel_reduce `_ +* `parallel_deterministic_reduce `_ +* `parallel_for_each `_ +* `parallel_scan `_ +* `parallel_pipeline `_ +* `function_node `_ +* `multifunction_node `_ +* `async_node `_ +* `sequencer_node `_ +* `join_node with key_matching policy `_ diff --git a/_sources/main/tbb_userguide/title.rst b/_sources/main/tbb_userguide/title.rst new file mode 100644 index 0000000000..8adb7093fe --- /dev/null +++ b/_sources/main/tbb_userguide/title.rst @@ -0,0 +1,29 @@ +.. _title: + +|short_name| Developer Guide +============================ + +|full_name| + +.. toctree:: + :maxdepth: 4 + + ../tbb_userguide/Package_Contents_os + ../tbb_userguide/Parallelizing_Simple_Loops_os + ../tbb_userguide/Parallelizing_Complex_Loops + ../tbb_userguide/Flow_Graph + ../tbb_userguide/work_isolation + ../tbb_userguide/Exceptions_and_Cancellation + ../tbb_userguide/Floating_Point_Settings + ../tbb_userguide/Containers + ../tbb_userguide/Mutual_Exclusion + ../tbb_userguide/Timing + ../tbb_userguide/Memory_Allocation + ../tbb_userguide/The_Task_Scheduler + ../tbb_userguide/design_patterns/Design_Patterns + ../tbb_userguide/Migration_Guide + ../tbb_userguide/Constraints + ../tbb_userguide/std_invoke + ../tbb_userguide/appendix_A + ../tbb_userguide/appendix_B + ../tbb_userguide/References diff --git a/_sources/main/tbb_userguide/use_concurrency_limits.rst b/_sources/main/tbb_userguide/use_concurrency_limits.rst new file mode 100644 index 0000000000..2834372b76 --- /dev/null +++ b/_sources/main/tbb_userguide/use_concurrency_limits.rst @@ -0,0 +1,79 @@ +.. _use_concurrency_limits: + +Use Concurrency Limits +====================== + + +To control the number of instances of a single node, you can use the +concurrency limit on the node. To cause it to reject messages after it +reaches its concurrency limit, you construct it as a "rejecting" node. + + +A function node is constructed with one or more template arguments. The +third argument controls the buffer policy used by the node, and is by +default queueing. With a queueing policy, a ``function_node`` that has +reached its concurrency limit still accepts incoming messages, but +buffers them internally. If the policy is set to rejecting the node will +instead reject the incoming messages. + + +:: + + + template < typename Input, + typename Output = continue_msg, + graph_buffer_policy = queueing > + class function_node; + + +For example, you can control the number of big objects in flight in a +graph by placing a rejecting function_node downstream of an ``input_node``, +as is done below: + + +:: + + + graph g; + + + int src_count = 0; + int number_of_objects = 0; + int max_objects = 3; + + + input_node< big_object * > s( g, [&]( oneapi::tbb::flow_control& fc ) -> big_object* { + if ( src_count < M ) { + big_object* v = new big_object(); + ++src_count; + return v; + } else { + fc.stop(); + return nullptr; + } + } ); + s.activate(); + + function_node< big_object *, continue_msg, rejecting > f( g, 3, + []( big_object *v ) -> continue_msg { + spin_for(1); + delete v; + return continue_msg(); + } ); + + + make_edge( s, f ); + g.wait_for_all(); + + +The ``function_node`` will operate on at most three big objects +concurrently. The node's concurrency threshold that limits the node to +three concurrent invocations. When the ``function_node`` is running three +instances concurrently, it will start rejecting incoming messages from +the ``input_node``, causing the ``input_node`` to buffer its last created +object and temporarily stop invoking its body object. Whenever the +``function_node`` drops below its concurrency limit, it will pull new +messages from the ``input_node``. At most four big objects will exist +simultaneously, three in the ``function_node`` and one buffered in the +``input_node``. + diff --git a/_sources/main/tbb_userguide/use_graph_reset.rst b/_sources/main/tbb_userguide/use_graph_reset.rst new file mode 100644 index 0000000000..2fbcf28652 --- /dev/null +++ b/_sources/main/tbb_userguide/use_graph_reset.rst @@ -0,0 +1,30 @@ +.. _use_graph_reset: + +Use graph::reset() to Reset a Canceled Graph +============================================ + + +When a graph execution is canceled either because of an unhandled +exception or because its task_group_context is canceled explicitly, the +graph and its nodes may be left in an indeterminate state. For example, +in the code samples shown in :ref:`cancel_a_graph` the input 2 may be +left in a buffer. But even beyond remnants in the buffers, there are +other optimizations performed during the execution of a flow graph that +can leave its nodes and edges in an indeterminate state. If you want to +re-execute or restart a graph, you first need to reset the graph: + + +:: + + + try { + g.wait_for_all(); + } catch ( int j ) { + cout << "Caught " << j << "\n"; + // do something to fix the problem + g.reset(); + f1.try_put(1); + f1.try_put(2); + g.wait_for_all(); + } + diff --git a/_sources/main/tbb_userguide/use_input_node.rst b/_sources/main/tbb_userguide/use_input_node.rst new file mode 100644 index 0000000000..79e4952f14 --- /dev/null +++ b/_sources/main/tbb_userguide/use_input_node.rst @@ -0,0 +1,112 @@ +.. _use_input_node: + +Using input_node +================= + + +By default, an ``input_node`` is constructed in the inactive state: + + +:: + + + template< typename Body > input_node( graph &g, Body body, bool is_active=true ) + + +To activate an inactive ``input_node``, you call the node's function +activate: + + +:: + + + input_node< int > src( g, src_body(10), false ); + // use it in calls to make_edge… + src.activate(); + + +All ``input_node`` objects are constructed in the inactive state and usually +activated after the entire flow graph is constructed. + + +For example, you can use the code in :ref:`Data_Flow_Graph`. In that implementation, +the ``input_node`` is constructed in the inactive state and activated after +all other edges are made: + + +:: + + + make_edge( squarer, summer ); + make_edge( cuber, summer ); + input_node< int > src( g, src_body(10), false ); + make_edge( src, squarer ); + make_edge( src, cuber ); + src.activate(); + g.wait_for_all(); + + +In this example, if the ``input_node`` was toggled to the active state at the beginning, +it might send a message to squarer immediately after the edge to +squarer is connected. Later, when the edge to cuber is connected, cuber +will receive all future messages, but may have already missed some. + + +In general it is safest to create your ``input_node`` objects in the inactive +state and then activate them after the whole graph is constructed. +However, this approach serializes graph construction and graph +execution. + + +Some graphs can be constructed safely with ``input_node``s active, allowing +the overlap of construction and execution. If your graph is a directed +acyclic graph (DAG), and each ``input_node`` has only one successor, you +can activate your ``input_node``s just after their construction if you construct the +edges in reverse topological order; that is, make the edges at the +largest depth in the tree first, and work back to the shallowest edges. +For example, if src is an ``input_node`` and ``func1`` and ``func2`` are both +function nodes, the following graph would not drop messages, even though +src is activated just after its construction: + + +:: + + + const int limit = 10; + int count = 0; + graph g; + oneapi::tbb::flow::graph g; + oneapi::tbb::flow::input_node src( g, [&]( oneapi::tbb::flow_control &fc ) -> int { + if ( count < limit ) { + return ++count; + } + fc.stop(); + return {}; + }); + src.activate(); + + oneapi::tbb::flow::function_node func1( g, 1, []( int i ) -> int { + std::cout << i << "\n"; + return i; + } ); + oneapi::tbb::flow::function_node func2( g, 1, []( int i ) -> int { + std::cout << i << "\n"; + return i; + } ); + + + make_edge( func1, func2 ); + make_edge( src, func1 ); + + + g.wait_for_all(); + + +The above code is safe because the edge from ``func1`` to ``func2`` is made +before the edge from src to ``func1``. If the edge from src to func1 were +made first, ``func1`` might generate a message before ``func2`` is attached to +it; that message would be dropped. Also, src has only a single +successor. If src had more than one successor, the successor that is +attached first might receive messages that do not reach the successors +that are attached after it. + diff --git a/_sources/main/tbb_userguide/use_limiter_node.rst b/_sources/main/tbb_userguide/use_limiter_node.rst new file mode 100644 index 0000000000..6414b2ffd5 --- /dev/null +++ b/_sources/main/tbb_userguide/use_limiter_node.rst @@ -0,0 +1,87 @@ +.. _use_limiter_node: + +Using limiter_node +================== + + +One way to limit resource consumption is to use a limiter_node to set a +limit on the number of messages that can flow through a given point in +your graph. The constructor for a limiter node takes two arguments: + + +:: + + + limiter_node( graph &g, size_t threshold ) + + +The first argument is a reference to the graph it belongs to. The second +argument sets the maximum number of items that should be allowed to pass +through before the node starts rejecting incoming messages. + + +A limiter_node maintains an internal count of the messages that it has +allowed to pass. When a message leaves the controlled part of the graph, +a message can be sent to the decrement port on the ``limiter_node`` to +decrement the count, allowing additional messages to pass through. In +the example below, an ``input_node`` will generate ``M`` big objects. But the +user wants to allow at most three big objects to reach the ``function_node`` +at a time, and to prevent the ``input_node`` from generating all ``M`` big +objects at once. + + +:: + + + graph g; + + + int src_count = 0; + int number_of_objects = 0; + int max_objects = 3; + + + input_node< big_object * > s( g, [&]( oneapi::tbb::flow_control& fc ) -> big_object* { + if ( src_count < M ) { + big_object* v = new big_object(); + ++src_count; + return v; + } else { + fc.stop(); + return nullptr; + } + } ); + s.activate(); + + limiter_node< big_object * > l( g, max_objects ); + + + function_node< big_object *, continue_msg > f( g, unlimited, + []( big_object *v ) -> continue_msg { + spin_for(1); + delete v; + return continue_msg(); + } ); + + + + + make_edge( l, f ); + make_edge( f, l.decrement ); + make_edge( s, l ); + g.wait_for_all(); + + +The example above prevents the ``input_node`` from generating all ``M`` big +objects at once. The ``limiter_node`` has a threshold of 3, and will +therefore start rejecting incoming messages after its internal count +reaches 3. When the ``input_node`` sees its message rejected, it stops +calling its body object and temporarily buffers the last generated +value. The ``function_node`` has its output, a ``continue_msg``, sent to the +decrement port of the ``limiter_node``. So, after it completes executing, +the ``limiter_node`` internal count is decremented. When the internal count +drops below the threshold, messages begin flowing from the ``input_node`` +again. So in this example, at most four big objects exist at a time, the +three that have passed through the ``limiter_node`` and the one that is +buffered in the ``input_node``. + diff --git a/_sources/main/tbb_userguide/use_make_edge.rst b/_sources/main/tbb_userguide/use_make_edge.rst new file mode 100644 index 0000000000..01b97609e4 --- /dev/null +++ b/_sources/main/tbb_userguide/use_make_edge.rst @@ -0,0 +1,25 @@ +.. _use_make_edge: + +Use make_edge and remove_edge +============================= + + +These are the basic guidelines for creating and removing edges: + + +- use make_edge and remove_edge + + +- Avoid using register_successor and register_predecessor + + +- Avoid using remove_successor and remove_predecessor + + +As a convention, to communicate the topology, use only functions +flow::make_edge and flow::remove_edge. The runtime library uses node +functions, such as sender::register_successor, to create these edges, +but those functions should not be called directly. The runtime library +calls these node functions directly to implement optimizations on the +topology at runtime. + diff --git a/_sources/main/tbb_userguide/use_nested_algorithms.rst b/_sources/main/tbb_userguide/use_nested_algorithms.rst new file mode 100644 index 0000000000..a20cd55f43 --- /dev/null +++ b/_sources/main/tbb_userguide/use_nested_algorithms.rst @@ -0,0 +1,68 @@ +.. _use_nested_algorithms: + +Use Nested Algorithms to Increase Scalability +============================================= + + +One powerful way to increase the scalability of a flow graph is to nest +other parallel algorithms inside of node bodies. Doing so, you can use a +flow graph as a coordination language, expressing the most +coarse-grained parallelism at the level of the graph, with finer grained +parallelism nested within. + + +In the example below, five nodes are created: an ``input_node``, +``matrix_source``, that reads a sequence of matrices from a file, two +``function_nodes``, ``n1`` and ``n2``, that receive these matrices and generate two +new matrices by applying a function to each element, and two final +``function_nodes``, ``n1_sink`` and ``n2_sink``, that process these resulting +matrices. The ``matrix_source`` is connected to both ``n1`` and ``n2``. The node ``n1`` +is connected to ``n1_sink``, and ``n2`` is connected to ``n2_sink``. In the lambda +expressions for ``n1`` and ``n2``, a ``parallel_for`` is used to apply the functions +to the elements of the matrix in parallel. The functions +``read_next_matrix``, ``f1``, ``f2``, ``consume_f1`` and ``consume_f2`` are not provided +below. + + +:: + + + graph g; + input_node< double * > matrix_source( g, [&]( oneapi::tbb::flow_control &fc ) -> double* { + double *a = read_next_matrix(); + if ( a ) { + return a; + } else { + fc.stop(); + return nullptr; + } + } ); + function_node< double *, double * > n1( g, unlimited, [&]( double *a ) -> double * { + double *b = new double[N]; + parallel_for( 0, N, [&](int i) { + b[i] = f1(a[i]); + } ); + return b; + } ); + function_node< double *, double * > n2( g, unlimited, [&]( double *a ) -> double * { + double *b = new double[N]; + parallel_for( 0, N, [&](int i) { + b[i] = f2(a[i]); + } ); + return b; + } ); + function_node< double *, double * > n1_sink( g, unlimited, + []( double *b ) -> double * { + return consume_f1(b); + } ); + function_node< double *, double * > n2_sink( g, unlimited, + []( double *b ) -> double * { + return consume_f2(b); + } ); + make_edge( matrix_source, n1 ); + make_edge( matrix_source, n2 ); + make_edge( n1, n1_sink ); + make_edge( n2, n2_sink ); + matrix_source.activate(); + g.wait_for_all(); + diff --git a/_sources/main/tbb_userguide/use_nested_flow_graphs.rst b/_sources/main/tbb_userguide/use_nested_flow_graphs.rst new file mode 100644 index 0000000000..55ed8d6c57 --- /dev/null +++ b/_sources/main/tbb_userguide/use_nested_flow_graphs.rst @@ -0,0 +1,132 @@ +.. _use_nested_flow_graphs: + +Use Nested Flow Graphs +====================== + + +In addition to nesting algorithms within a flow graph node, it is also +possible to nest flow graphs. For example, below there is a graph ``g`` with +two nodes, ``a`` and ``b``. When node ``a`` receives a message, it constructs and +executes an inner dependence graph. When node ``b`` receives a message, it +constructs and executes an inner data flow graph: + + +:: + + + graph g; + function_node< int, int > a( g, unlimited, []( int i ) -> int { + graph h; + node_t n1( h, [=]( msg_t ) { cout << "n1: " << i << "\n"; } ); + node_t n2( h, [=]( msg_t ) { cout << "n2: " << i << "\n"; } ); + node_t n3( h, [=]( msg_t ) { cout << "n3: " << i << "\n"; } ); + node_t n4( h, [=]( msg_t ) { cout << "n4: " << i << "\n"; } ); + make_edge( n1, n2 ); + make_edge( n1, n3 ); + make_edge( n2, n4 ); + make_edge( n3, n4 ); + n1.try_put(continue_msg()); + h.wait_for_all(); + return i; + } ); + function_node< int, int > b( g, unlimited, []( int i ) -> int { + graph h; + function_node< int, int > m1( h, unlimited, []( int j ) -> int { + cout << "m1: " << j << "\n"; + return j; + } ); + function_node< int, int > m2( h, unlimited, []( int j ) -> int { + cout << "m2: " << j << "\n"; + return j; + } ); + function_node< int, int > m3( h, unlimited, []( int j ) -> int { + cout << "m3: " << j << "\n"; + return j; + } ); + function_node< int, int > m4( h, unlimited, []( int j ) -> int { + cout << "m4: " << j << "\n"; + return j; + } ); + make_edge( m1, m2 ); + make_edge( m1, m3 ); + make_edge( m2, m4 ); + make_edge( m3, m4 ); + m1.try_put(i); + h.wait_for_all(); + return i; + } ); + make_edge( a, b ); + for ( int i = 0; i < 3; ++i ) { + a.try_put(i); + } + g.wait_for_all(); + + +If the nested graph remains unchanged in structure between invocations +of the node, it is redundant to construct it each time. Reconstructing +the graph only adds overhead to the execution. You can modify the +example above, for example, to have node ``b`` reuse a graph that is +persistent across its invocations: + + +:: + + + graph h; + function_node< int, int > m1( h, unlimited, []( int j ) -> int { + cout << "m1: " << j << "\n"; + return j; + } ); + function_node< int, int > m2( h, unlimited, []( int j ) -> int { + cout << "m2: " << j << "\n"; + return j; + } ); + function_node< int, int > m3( h, unlimited, []( int j ) -> int { + cout << "m3: " << j << "\n"; + return j; + } ); + function_node< int, int > m4( h, unlimited, []( int j ) -> int { + cout << "m4: " << j << "\n"; + return j; + } ); + make_edge( m1, m2 ); + make_edge( m1, m3 ); + make_edge( m2, m4 ); + make_edge( m3, m4 ); + + + graph g; + function_node< int, int > a( g, unlimited, []( int i ) -> int { + graph h; + node_t n1( h, [=]( msg_t ) { cout << "n1: " << i << "\n"; } ); + node_t n2( h, [=]( msg_t ) { cout << "n2: " << i << "\n"; } ); + node_t n3( h, [=]( msg_t ) { cout << "n3: " << i << "\n"; } ); + node_t n4( h, [=]( msg_t ) { cout << "n4: " << i << "\n"; } ); + make_edge( n1, n2 ); + make_edge( n1, n3 ); + make_edge( n2, n4 ); + make_edge( n3, n4 ); + n1.try_put(continue_msg()); + h.wait_for_all(); + return i; + } ); + function_node< int, int > b( g, unlimited, [&]( int i ) -> int { + m1.try_put(i); + h.wait_for_all(); // optional since h is not destroyed + return i; + } ); + make_edge( a, b ); + for ( int i = 0; i < 3; ++i ) { + a.try_put(i); + } + g.wait_for_all(); + + +It is only necessary to call ``h.wait_for_all()`` at the end of each +invocation of ``b``'s body in our modified code, if you wish for this ``b``'s +body to block until the inner graph is done. In the first implementation +of ``b``, it was necessary to call ``h.wait_for_all`` at the end of each +invocation since the graph was destroyed at the end of the scope. So it +would be valid in the body of ``b`` above to call ``m1.try_put(i)`` and then +return without waiting for ``h`` to become idle. + diff --git a/_sources/main/tbb_userguide/work_isolation.rst b/_sources/main/tbb_userguide/work_isolation.rst new file mode 100644 index 0000000000..29e1d9682d --- /dev/null +++ b/_sources/main/tbb_userguide/work_isolation.rst @@ -0,0 +1,139 @@ +.. _work_isolation: + +Work Isolation +============== + + +.. container:: section + + + In |full_name|, a thread waiting for a + group of tasks to complete might execute other available tasks. In + particular, when a parallel construct calls another parallel + construct, a thread can obtain a task from the outer-level construct + while waiting for completion of the inner-level one. + + + In the following example with two ``parallel_for`` calls, the call to + the second (nested) parallel loop blocks execution of the first + (outer) loop iteration: + + + :: + + + // The first parallel loop. + oneapi::tbb::parallel_for( 0, N1, []( int i ) { + // The second parallel loop. + oneapi::tbb::parallel_for( 0, N2, []( int j ) { /* Some work */ } ); + } ); + + + The blocked thread is allowed to take tasks belonging to the first + parallel loop. As a result, two or more iterations of the outer loop + might be simultaneously assigned to the same thread. In other words, + in oneTBB execution of functions constituting a parallel construct is + *unsequenced* even within a single thread. In most cases, this + behavior is harmless or even beneficial because it does not restrict + parallelism available for the thread. + + + However, in some cases such unsequenced execution may result in + errors. For example, a thread-local variable might unexpectedly + change its value after a nested parallel construct: + + + :: + + + oneapi::tbb::enumerable_thread_specific ets; + oneapi::tbb::parallel_for( 0, N1, [&ets]( int i ) { + // Set a thread specific value + ets.local() = i; + oneapi::tbb::parallel_for( 0, N2, []( int j ) { /* Some work */ } ); + // While executing the above parallel_for, the thread might have run iterations + // of the outer parallel_for, and so might have changed the thread specific value. + assert( ets.local()==i ); // The assertion may fail! + } ); + + + In other scenarios, the described behavior might lead to deadlocks + and other issues. In these cases, a stronger guarantee of execution + being sequenced within a thread is desired. For that, oneTBB provides + ways to *isolate* execution of a parallel construct, for its tasks to + not interfere with other simultaneously running tasks. + + + One of these ways is to execute the inner level loop in a separate + ``task_arena``: + + + :: + + + oneapi::tbb::enumerable_thread_specific ets; + oneapi::tbb::task_arena nested; + oneapi::tbb::parallel_for( 0, N1, [&]( int i ) { + // Set a thread specific value + ets.local() = i; + nested.execute( []{ + // Run the inner parallel_for in a separate arena to prevent the thread + // from taking tasks of the outer parallel_for. + oneapi::tbb::parallel_for( 0, N2, []( int j ) { /* Some work */ } ); + } ); + assert( ets.local()==i ); // Valid assertion + } ); + + + However, using a separate arena for work isolation is not always + convenient, and might have noticeable overheads. To address these + shortcomings, oneTBB provides ``this_task_arena::isolate`` function + which runs a user-provided functor in isolation by restricting the + calling thread to process only tasks scheduled in the scope of the + functor (also called the isolation region). + + + When entered a task waiting call or a blocking parallel construct + inside an isolated region, a thread can only execute tasks spawned + within the region and their child tasks spawned by other threads. The + thread is prohibited from executing any outer level tasks or tasks + belonging to other isolated regions. + + + The isolation region imposes restrictions only upon the thread that + called it. Other threads running in the same task arena have no + restrictions on task selection unless isolated by a distinct call to + ``this_task_arena::isolate``. + + + The following example demonstrates the use of + ``this_task_arena::isolate`` to ensure that a thread-local variable + is not changed unexpectedly during the call to a nested parallel + construct. + + + :: + + + #include "oneapi/tbb/task_arena.h" + #include "oneapi/tbb/parallel_for.h" + #include "oneapi/tbb/enumerable_thread_specific.h" + #include + + + int main() { + const int N1 = 1000, N2 = 1000; + oneapi::tbb::enumerable_thread_specific ets; + oneapi::tbb::parallel_for( 0, N1, [&ets]( int i ) { + // Set a thread specific value + ets.local() = i; + // Run the second parallel loop in an isolated region to prevent the current thread + // from taking tasks related to the outer parallel loop. + oneapi::tbb::this_task_arena::isolate( []{ + oneapi::tbb::parallel_for( 0, N2, []( int j ) { /* Some work */ } ); + } ); + assert( ets.local()==i ); // Valid assertion + } ); + return 0; + } + diff --git a/_static/basic.css b/_static/basic.css new file mode 100644 index 0000000000..2a9e4114ac --- /dev/null +++ b/_static/basic.css @@ -0,0 +1,914 @@ +/* + * Sphinx stylesheet -- basic theme. + */ + +/* -- main layout ----------------------------------------------------------- */ + +div.clearer { + clear: both; +} + +div.section::after { + display: block; + content: ''; + clear: left; +} + +/* -- relbar ---------------------------------------------------------------- */ + +div.related { + width: 100%; + font-size: 90%; +} + +div.related h3 { + display: none; +} + +div.related ul { + margin: 0; + padding: 0 0 0 10px; + list-style: none; +} + +div.related li { + display: inline; +} + +div.related li.right { + float: right; + margin-right: 5px; +} + +/* -- sidebar --------------------------------------------------------------- */ + +div.sphinxsidebarwrapper { + padding: 10px 5px 0 10px; +} + +div.sphinxsidebar { + float: left; + width: 270px; + margin-left: -100%; + font-size: 90%; + word-wrap: break-word; + overflow-wrap : break-word; +} + +div.sphinxsidebar ul { + list-style: none; +} + +div.sphinxsidebar ul ul, +div.sphinxsidebar ul.want-points { + margin-left: 20px; + list-style: square; +} + +div.sphinxsidebar ul ul { + margin-top: 0; + margin-bottom: 0; +} + +div.sphinxsidebar form { + margin-top: 10px; +} + +div.sphinxsidebar input { + border: 1px solid #98dbcc; + font-family: sans-serif; + font-size: 1em; +} + +div.sphinxsidebar #searchbox form.search { + overflow: hidden; +} + +div.sphinxsidebar #searchbox input[type="text"] { + float: left; + width: 80%; + padding: 0.25em; + box-sizing: border-box; +} + +div.sphinxsidebar #searchbox input[type="submit"] { + float: left; + width: 20%; + border-left: none; + padding: 0.25em; + box-sizing: border-box; +} + + +img { + border: 0; + max-width: 100%; +} + +/* -- search page ----------------------------------------------------------- */ + +ul.search { + margin-top: 10px; +} + +ul.search li { + padding: 5px 0; +} + +ul.search li a { + font-weight: bold; +} + +ul.search li p.context { + color: #888; + margin: 2px 0 0 30px; + text-align: left; +} + +ul.keywordmatches li.goodmatch a { + font-weight: bold; +} + +/* -- index page ------------------------------------------------------------ */ + +table.contentstable { + width: 90%; + margin-left: auto; + margin-right: auto; +} + +table.contentstable p.biglink { + line-height: 150%; +} + +a.biglink { + font-size: 1.3em; +} + +span.linkdescr { + font-style: italic; + padding-top: 5px; + font-size: 90%; +} + +/* -- general index --------------------------------------------------------- */ + +table.indextable { + width: 100%; +} + +table.indextable td { + text-align: left; + vertical-align: top; +} + +table.indextable ul { + margin-top: 0; + margin-bottom: 0; + list-style-type: none; +} + +table.indextable > tbody > tr > td > ul { + padding-left: 0em; +} + +table.indextable tr.pcap { + height: 10px; +} + +table.indextable tr.cap { + margin-top: 10px; + background-color: #f2f2f2; +} + +img.toggler { + margin-right: 3px; + margin-top: 3px; + cursor: pointer; +} + +div.modindex-jumpbox { + border-top: 1px solid #ddd; + border-bottom: 1px solid #ddd; + margin: 1em 0 1em 0; + padding: 0.4em; +} + +div.genindex-jumpbox { + border-top: 1px solid #ddd; + border-bottom: 1px solid #ddd; + margin: 1em 0 1em 0; + padding: 0.4em; +} + +/* -- domain module index --------------------------------------------------- */ + +table.modindextable td { + padding: 2px; + border-collapse: collapse; +} + +/* -- general body styles --------------------------------------------------- */ + +div.body { + min-width: 360px; + max-width: 800px; +} + +div.body p, div.body dd, div.body li, div.body blockquote { + -moz-hyphens: auto; + -ms-hyphens: auto; + -webkit-hyphens: auto; + hyphens: auto; +} + +a.headerlink { + visibility: hidden; +} + +a:visited { + color: #551A8B; +} + +h1:hover > a.headerlink, +h2:hover > a.headerlink, +h3:hover > a.headerlink, +h4:hover > a.headerlink, +h5:hover > a.headerlink, +h6:hover > a.headerlink, +dt:hover > a.headerlink, +caption:hover > a.headerlink, +p.caption:hover > a.headerlink, +div.code-block-caption:hover > a.headerlink { + visibility: visible; +} + +div.body p.caption { + text-align: inherit; +} + +div.body td { + text-align: left; +} + +.first { + margin-top: 0 !important; +} + +p.rubric { + margin-top: 30px; + font-weight: bold; +} + +img.align-left, figure.align-left, .figure.align-left, object.align-left { + clear: left; + float: left; + margin-right: 1em; +} + +img.align-right, figure.align-right, .figure.align-right, object.align-right { + clear: right; + float: right; + margin-left: 1em; +} + +img.align-center, figure.align-center, .figure.align-center, object.align-center { + display: block; + margin-left: auto; + margin-right: auto; +} + +img.align-default, figure.align-default, .figure.align-default { + display: block; + margin-left: auto; + margin-right: auto; +} + +.align-left { + text-align: left; +} + +.align-center { + text-align: center; +} + +.align-default { + text-align: center; +} + +.align-right { + text-align: right; +} + +/* -- sidebars -------------------------------------------------------------- */ + +div.sidebar, +aside.sidebar { + margin: 0 0 0.5em 1em; + border: 1px solid #ddb; + padding: 7px; + background-color: #ffe; + width: 40%; + float: right; + clear: right; + overflow-x: auto; +} + +p.sidebar-title { + font-weight: bold; +} + +nav.contents, +aside.topic, +div.admonition, div.topic, blockquote { + clear: left; +} + +/* -- topics ---------------------------------------------------------------- */ + +nav.contents, +aside.topic, +div.topic { + border: 1px solid #ccc; + padding: 7px; + margin: 10px 0 10px 0; +} + +p.topic-title { + font-size: 1.1em; + font-weight: bold; + margin-top: 10px; +} + +/* -- admonitions ----------------------------------------------------------- */ + +div.admonition { + margin-top: 10px; + margin-bottom: 10px; + padding: 7px; +} + +div.admonition dt { + font-weight: bold; +} + +p.admonition-title { + margin: 0px 10px 5px 0px; + font-weight: bold; +} + +div.body p.centered { + text-align: center; + margin-top: 25px; +} + +/* -- content of sidebars/topics/admonitions -------------------------------- */ + +div.sidebar > :last-child, +aside.sidebar > :last-child, +nav.contents > :last-child, +aside.topic > :last-child, +div.topic > :last-child, +div.admonition > :last-child { + margin-bottom: 0; +} + +div.sidebar::after, +aside.sidebar::after, +nav.contents::after, +aside.topic::after, +div.topic::after, +div.admonition::after, +blockquote::after { + display: block; + content: ''; + clear: both; +} + +/* -- tables ---------------------------------------------------------------- */ + +table.docutils { + margin-top: 10px; + margin-bottom: 10px; + border: 0; + border-collapse: collapse; +} + +table.align-center { + margin-left: auto; + margin-right: auto; +} + +table.align-default { + margin-left: auto; + margin-right: auto; +} + +table caption span.caption-number { + font-style: italic; +} + +table caption span.caption-text { +} + +table.docutils td, table.docutils th { + padding: 1px 8px 1px 5px; + border-top: 0; + border-left: 0; + border-right: 0; + border-bottom: 1px solid #aaa; +} + +th { + text-align: left; + padding-right: 5px; +} + +table.citation { + border-left: solid 1px gray; + margin-left: 1px; +} + +table.citation td { + border-bottom: none; +} + +th > :first-child, +td > :first-child { + margin-top: 0px; +} + +th > :last-child, +td > :last-child { + margin-bottom: 0px; +} + +/* -- figures --------------------------------------------------------------- */ + +div.figure, figure { + margin: 0.5em; + padding: 0.5em; +} + +div.figure p.caption, figcaption { + padding: 0.3em; +} + +div.figure p.caption span.caption-number, +figcaption span.caption-number { + font-style: italic; +} + +div.figure p.caption span.caption-text, +figcaption span.caption-text { +} + +/* -- field list styles ----------------------------------------------------- */ + +table.field-list td, table.field-list th { + border: 0 !important; +} + +.field-list ul { + margin: 0; + padding-left: 1em; +} + +.field-list p { + margin: 0; +} + +.field-name { + -moz-hyphens: manual; + -ms-hyphens: manual; + -webkit-hyphens: manual; + hyphens: manual; +} + +/* -- hlist styles ---------------------------------------------------------- */ + +table.hlist { + margin: 1em 0; +} + +table.hlist td { + vertical-align: top; +} + +/* -- object description styles --------------------------------------------- */ + +.sig { + font-family: 'Consolas', 'Menlo', 'DejaVu Sans Mono', 'Bitstream Vera Sans Mono', monospace; +} + +.sig-name, code.descname { + background-color: transparent; + font-weight: bold; +} + +.sig-name { + font-size: 1.1em; +} + +code.descname { + font-size: 1.2em; +} + +.sig-prename, code.descclassname { + background-color: transparent; +} + +.optional { + font-size: 1.3em; +} + +.sig-paren { + font-size: larger; +} + +.sig-param.n { + font-style: italic; +} + +/* C++ specific styling */ + +.sig-inline.c-texpr, +.sig-inline.cpp-texpr { + font-family: unset; +} + +.sig.c .k, .sig.c .kt, +.sig.cpp .k, .sig.cpp .kt { + color: #0033B3; +} + +.sig.c .m, +.sig.cpp .m { + color: #1750EB; +} + +.sig.c .s, .sig.c .sc, +.sig.cpp .s, .sig.cpp .sc { + color: #067D17; +} + + +/* -- other body styles ----------------------------------------------------- */ + +ol.arabic { + list-style: decimal; +} + +ol.loweralpha { + list-style: lower-alpha; +} + +ol.upperalpha { + list-style: upper-alpha; +} + +ol.lowerroman { + list-style: lower-roman; +} + +ol.upperroman { + list-style: upper-roman; +} + +:not(li) > ol > li:first-child > :first-child, +:not(li) > ul > li:first-child > :first-child { + margin-top: 0px; +} + +:not(li) > ol > li:last-child > :last-child, +:not(li) > ul > li:last-child > :last-child { + margin-bottom: 0px; +} + +ol.simple ol p, +ol.simple ul p, +ul.simple ol p, +ul.simple ul p { + margin-top: 0; +} + +ol.simple > li:not(:first-child) > p, +ul.simple > li:not(:first-child) > p { + margin-top: 0; +} + +ol.simple p, +ul.simple p { + margin-bottom: 0; +} + +aside.footnote > span, +div.citation > span { + float: left; +} +aside.footnote > span:last-of-type, +div.citation > span:last-of-type { + padding-right: 0.5em; +} +aside.footnote > p { + margin-left: 2em; +} +div.citation > p { + margin-left: 4em; +} +aside.footnote > p:last-of-type, +div.citation > p:last-of-type { + margin-bottom: 0em; +} +aside.footnote > p:last-of-type:after, +div.citation > p:last-of-type:after { + content: ""; + clear: both; +} + +dl.field-list { + display: grid; + grid-template-columns: fit-content(30%) auto; +} + +dl.field-list > dt { + font-weight: bold; + word-break: break-word; + padding-left: 0.5em; + padding-right: 5px; +} + +dl.field-list > dd { + padding-left: 0.5em; + margin-top: 0em; + margin-left: 0em; + margin-bottom: 0em; +} + +dl { + margin-bottom: 15px; +} + +dd > :first-child { + margin-top: 0px; +} + +dd ul, dd table { + margin-bottom: 10px; +} + +dd { + margin-top: 3px; + margin-bottom: 10px; + margin-left: 30px; +} + +.sig dd { + margin-top: 0px; + margin-bottom: 0px; +} + +.sig dl { + margin-top: 0px; + margin-bottom: 0px; +} + +dl > dd:last-child, +dl > dd:last-child > :last-child { + margin-bottom: 0; +} + +dt:target, span.highlighted { + background-color: #fbe54e; +} + +rect.highlighted { + fill: #fbe54e; +} + +dl.glossary dt { + font-weight: bold; + font-size: 1.1em; +} + +.versionmodified { + font-style: italic; +} + +.system-message { + background-color: #fda; + padding: 5px; + border: 3px solid red; +} + +.footnote:target { + background-color: #ffa; +} + +.line-block { + display: block; + margin-top: 1em; + margin-bottom: 1em; +} + +.line-block .line-block { + margin-top: 0; + margin-bottom: 0; + margin-left: 1.5em; +} + +.guilabel, .menuselection { + font-family: sans-serif; +} + +.accelerator { + text-decoration: underline; +} + +.classifier { + font-style: oblique; +} + +.classifier:before { + font-style: normal; + margin: 0 0.5em; + content: ":"; + display: inline-block; +} + +abbr, acronym { + border-bottom: dotted 1px; + cursor: help; +} + +.translated { + background-color: rgba(207, 255, 207, 0.2) +} + +.untranslated { + background-color: rgba(255, 207, 207, 0.2) +} + +/* -- code displays --------------------------------------------------------- */ + +pre { + overflow: auto; + overflow-y: hidden; /* fixes display issues on Chrome browsers */ +} + +pre, div[class*="highlight-"] { + clear: both; +} + +span.pre { + -moz-hyphens: none; + -ms-hyphens: none; + -webkit-hyphens: none; + hyphens: none; + white-space: nowrap; +} + +div[class*="highlight-"] { + margin: 1em 0; +} + +td.linenos pre { + border: 0; + background-color: transparent; + color: #aaa; +} + +table.highlighttable { + display: block; +} + +table.highlighttable tbody { + display: block; +} + +table.highlighttable tr { + display: flex; +} + +table.highlighttable td { + margin: 0; + padding: 0; +} + +table.highlighttable td.linenos { + padding-right: 0.5em; +} + +table.highlighttable td.code { + flex: 1; + overflow: hidden; +} + +.highlight .hll { + display: block; +} + +div.highlight pre, +table.highlighttable pre { + margin: 0; +} + +div.code-block-caption + div { + margin-top: 0; +} + +div.code-block-caption { + margin-top: 1em; + padding: 2px 5px; + font-size: small; +} + +div.code-block-caption code { + background-color: transparent; +} + +table.highlighttable td.linenos, +span.linenos, +div.highlight span.gp { /* gp: Generic.Prompt */ + user-select: none; + -webkit-user-select: text; /* Safari fallback only */ + -webkit-user-select: none; /* Chrome/Safari */ + -moz-user-select: none; /* Firefox */ + -ms-user-select: none; /* IE10+ */ +} + +div.code-block-caption span.caption-number { + padding: 0.1em 0.3em; + font-style: italic; +} + +div.code-block-caption span.caption-text { +} + +div.literal-block-wrapper { + margin: 1em 0; +} + +code.xref, a code { + background-color: transparent; + font-weight: bold; +} + +h1 code, h2 code, h3 code, h4 code, h5 code, h6 code { + background-color: transparent; +} + +.viewcode-link { + float: right; +} + +.viewcode-back { + float: right; + font-family: sans-serif; +} + +div.viewcode-block:target { + margin: -1px -10px; + padding: 0 10px; +} + +/* -- math display ---------------------------------------------------------- */ + +img.math { + vertical-align: middle; +} + +div.body div.math p { + text-align: center; +} + +span.eqno { + float: right; +} + +span.eqno a.headerlink { + position: absolute; + z-index: 1; +} + +div.math:hover a.headerlink { + visibility: visible; +} + +/* -- printout stylesheet --------------------------------------------------- */ + +@media print { + div.document, + div.documentwrapper, + div.bodywrapper { + margin: 0 !important; + width: 100%; + } + + div.sphinxsidebar, + div.related, + div.footer, + #top-link { + display: none; + } +} \ No newline at end of file diff --git a/_static/custom.js b/_static/custom.js new file mode 100644 index 0000000000..a7d312de32 --- /dev/null +++ b/_static/custom.js @@ -0,0 +1,37 @@ +window.MathJax = { + TeX: { + Macros: { + src: '\\operatorname{src}', + srclayer: '\\operatorname{src\\_layer}', + srciter: '\\operatorname{src\\_iter}', + srciterc: '\\operatorname{src\\_iter\\_c}', + weights: '\\operatorname{weights}', + weightslayer: '\\operatorname{weights\\_layer}', + weightsiter: '\\operatorname{weights\\_iter}', + weightspeephole: '\\operatorname{weights\\_peephole}', + weightsprojection: '\\operatorname{weights\\_projection}', + bias: '\\operatorname{bias}', + dst: '\\operatorname{dst}', + dstlayer: '\\operatorname{dst\\_layer}', + dstiter: '\\operatorname{dst\\_iter}', + dstiterc: '\\operatorname{dst\\_iter\\_c}', + diffsrc: '\\operatorname{diff\\_src}', + diffsrclayer: '\\operatorname{diff\\_src\\_layer}', + diffsrciter: '\\operatorname{diff\\_src\\_iter}', + diffsrciterc: '\\operatorname{diff\\_src\\_iter\\_c}', + diffweights: '\\operatorname{diff\\_weights}', + diffweightslayer: '\\operatorname{diff\\_weights\\_layer}', + diffweightsiter: '\\operatorname{diff\\_weights\\_iter}', + diffweightspeephole: '\\operatorname{diff\\_weights\\_peephole}', + diffweightsprojection: '\\operatorname{diff\\_weights\\_projection}', + diffbias: '\\operatorname{diff\\_bias}', + diffdst: '\\operatorname{diff\\_dst}', + diffdstlayer: '\\operatorname{diff\\_dst\\_layer}', + diffdstiter: '\\operatorname{diff\\_dst\\_iter}', + diffdstiterc: '\\operatorname{diff\\_dst\\_iter\\_c}', + diffgamma: '\\operatorname{diff\\_\\gamma}', + diffbeta: '\\operatorname{diff\\_\\beta}', + workspace: '\\operatorname{workspace}' + } + } +} \ No newline at end of file diff --git a/_static/doctools.js b/_static/doctools.js new file mode 100644 index 0000000000..0398ebb9f0 --- /dev/null +++ b/_static/doctools.js @@ -0,0 +1,149 @@ +/* + * Base JavaScript utilities for all Sphinx HTML documentation. + */ +"use strict"; + +const BLACKLISTED_KEY_CONTROL_ELEMENTS = new Set([ + "TEXTAREA", + "INPUT", + "SELECT", + "BUTTON", +]); + +const _ready = (callback) => { + if (document.readyState !== "loading") { + callback(); + } else { + document.addEventListener("DOMContentLoaded", callback); + } +}; + +/** + * Small JavaScript module for the documentation. + */ +const Documentation = { + init: () => { + Documentation.initDomainIndexTable(); + Documentation.initOnKeyListeners(); + }, + + /** + * i18n support + */ + TRANSLATIONS: {}, + PLURAL_EXPR: (n) => (n === 1 ? 0 : 1), + LOCALE: "unknown", + + // gettext and ngettext don't access this so that the functions + // can safely bound to a different name (_ = Documentation.gettext) + gettext: (string) => { + const translated = Documentation.TRANSLATIONS[string]; + switch (typeof translated) { + case "undefined": + return string; // no translation + case "string": + return translated; // translation exists + default: + return translated[0]; // (singular, plural) translation tuple exists + } + }, + + ngettext: (singular, plural, n) => { + const translated = Documentation.TRANSLATIONS[singular]; + if (typeof translated !== "undefined") + return translated[Documentation.PLURAL_EXPR(n)]; + return n === 1 ? singular : plural; + }, + + addTranslations: (catalog) => { + Object.assign(Documentation.TRANSLATIONS, catalog.messages); + Documentation.PLURAL_EXPR = new Function( + "n", + `return (${catalog.plural_expr})` + ); + Documentation.LOCALE = catalog.locale; + }, + + /** + * helper function to focus on search bar + */ + focusSearchBar: () => { + document.querySelectorAll("input[name=q]")[0]?.focus(); + }, + + /** + * Initialise the domain index toggle buttons + */ + initDomainIndexTable: () => { + const toggler = (el) => { + const idNumber = el.id.substr(7); + const toggledRows = document.querySelectorAll(`tr.cg-${idNumber}`); + if (el.src.substr(-9) === "minus.png") { + el.src = `${el.src.substr(0, el.src.length - 9)}plus.png`; + toggledRows.forEach((el) => (el.style.display = "none")); + } else { + el.src = `${el.src.substr(0, el.src.length - 8)}minus.png`; + toggledRows.forEach((el) => (el.style.display = "")); + } + }; + + const togglerElements = document.querySelectorAll("img.toggler"); + togglerElements.forEach((el) => + el.addEventListener("click", (event) => toggler(event.currentTarget)) + ); + togglerElements.forEach((el) => (el.style.display = "")); + if (DOCUMENTATION_OPTIONS.COLLAPSE_INDEX) togglerElements.forEach(toggler); + }, + + initOnKeyListeners: () => { + // only install a listener if it is really needed + if ( + !DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS && + !DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS + ) + return; + + document.addEventListener("keydown", (event) => { + // bail for input elements + if (BLACKLISTED_KEY_CONTROL_ELEMENTS.has(document.activeElement.tagName)) return; + // bail with special keys + if (event.altKey || event.ctrlKey || event.metaKey) return; + + if (!event.shiftKey) { + switch (event.key) { + case "ArrowLeft": + if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + + const prevLink = document.querySelector('link[rel="prev"]'); + if (prevLink && prevLink.href) { + window.location.href = prevLink.href; + event.preventDefault(); + } + break; + case "ArrowRight": + if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + + const nextLink = document.querySelector('link[rel="next"]'); + if (nextLink && nextLink.href) { + window.location.href = nextLink.href; + event.preventDefault(); + } + break; + } + } + + // some keyboard layouts may need Shift to get / + switch (event.key) { + case "/": + if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break; + Documentation.focusSearchBar(); + event.preventDefault(); + } + }); + }, +}; + +// quick alias for translations +const _ = Documentation.gettext; + +_ready(Documentation.init); diff --git a/_static/documentation_options.js b/_static/documentation_options.js new file mode 100644 index 0000000000..dab586c0d2 --- /dev/null +++ b/_static/documentation_options.js @@ -0,0 +1,13 @@ +const DOCUMENTATION_OPTIONS = { + VERSION: '', + LANGUAGE: 'en', + COLLAPSE_INDEX: false, + BUILDER: 'html', + FILE_SUFFIX: '.html', + LINK_SUFFIX: '.html', + HAS_SOURCE: true, + SOURCELINK_SUFFIX: '', + NAVIGATION_WITH_KEYS: false, + SHOW_SEARCH_SUMMARY: true, + ENABLE_SEARCH_SHORTCUTS: true, +}; \ No newline at end of file diff --git a/_static/favicons.png b/_static/favicons.png new file mode 100644 index 0000000000000000000000000000000000000000..f450376b19e2d945e6d2da8b329de8aed320a9b7 GIT binary patch literal 467 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!63?wyl`GbKJbFq_W2nPqp?T7vkfZQzsJ|V8| z1wPZ8J^^{vNsoafCh*ie2o%(1S)bwZ*nr{i!pV<{eBW$c`~#v=hGA`t*65p27hI++iAAt!F9FH-3in5x7jA&dYmBX!*k>8p9}maQ@6zPbDmk8 z>2hFgpElF;@Hqk%_dazSu3wYHs?8U_V)m|`)BA<~sXKg?ZBs`hMrGg#P~ix$^RISR_I47Y|r1 z_CyJOe}D1){SET-^Amu_i71Lt6eYfZjRyw@I6OQAIXXHDfiX^GbOlHe=Ae4>0m)d(f|Me07*qoM6N<$f}vM^LjV8( literal 0 HcmV?d00001 diff --git a/_static/images/logo_binder.svg b/_static/images/logo_binder.svg new file mode 100644 index 0000000000..45fecf7511 --- /dev/null +++ b/_static/images/logo_binder.svg @@ -0,0 +1,19 @@ + + + + +logo + + + + + + + + diff --git a/_static/images/logo_colab.png b/_static/images/logo_colab.png new file mode 100644 index 0000000000000000000000000000000000000000..b7560ec216b2d1b6f77855525fe966c741833428 GIT binary patch literal 7601 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 diff --git a/_static/images/logo_jupyterhub.svg b/_static/images/logo_jupyterhub.svg new file mode 100644 index 0000000000..60cfe9f222 --- /dev/null +++ b/_static/images/logo_jupyterhub.svg @@ -0,0 +1 @@ +logo_jupyterhubHub diff --git a/_static/language_data.js b/_static/language_data.js new file mode 100644 index 0000000000..c7fe6c6faf --- /dev/null +++ b/_static/language_data.js @@ -0,0 +1,192 @@ +/* + * This script contains the language-specific data used by searchtools.js, + * namely the list of stopwords, stemmer, scorer and splitter. + */ + +var stopwords = ["a", "and", "are", "as", "at", "be", "but", "by", "for", "if", "in", "into", "is", "it", "near", "no", "not", "of", "on", "or", "such", "that", "the", "their", "then", "there", "these", "they", "this", "to", "was", "will", "with"]; + + +/* Non-minified version is copied as a separate JS file, if available */ + +/** + * Porter Stemmer + */ +var Stemmer = function() { + + var step2list = { + ational: 'ate', + tional: 'tion', + enci: 'ence', + anci: 'ance', + izer: 'ize', + bli: 'ble', + alli: 'al', + entli: 'ent', + eli: 'e', + ousli: 'ous', + ization: 'ize', + ation: 'ate', + ator: 'ate', + alism: 'al', + iveness: 'ive', + fulness: 'ful', + ousness: 'ous', + aliti: 'al', + iviti: 'ive', + biliti: 'ble', + logi: 'log' + }; + + var step3list = { + icate: 'ic', + ative: '', + alize: 'al', + iciti: 'ic', + ical: 'ic', + ful: '', + ness: '' + }; + + var c = "[^aeiou]"; // consonant + var v = "[aeiouy]"; // vowel + var C = c + "[^aeiouy]*"; // consonant sequence + var V = v + "[aeiou]*"; // vowel sequence + + var mgr0 = "^(" + C + ")?" + V + C; // [C]VC... is m>0 + var meq1 = "^(" + C + ")?" + V + C + "(" + V + ")?$"; // [C]VC[V] is m=1 + var mgr1 = "^(" + C + ")?" + V + C + V + C; // [C]VCVC... is m>1 + var s_v = "^(" + C + ")?" + v; // vowel in stem + + this.stemWord = function (w) { + var stem; + var suffix; + var firstch; + var origword = w; + + if (w.length < 3) + return w; + + var re; + var re2; + var re3; + var re4; + + firstch = w.substr(0,1); + if (firstch == "y") + w = firstch.toUpperCase() + w.substr(1); + + // Step 1a + re = /^(.+?)(ss|i)es$/; + re2 = /^(.+?)([^s])s$/; + + if (re.test(w)) + w = w.replace(re,"$1$2"); + else if (re2.test(w)) + w = w.replace(re2,"$1$2"); + + // Step 1b + re = /^(.+?)eed$/; + re2 = /^(.+?)(ed|ing)$/; + if (re.test(w)) { + var fp = re.exec(w); + re = new RegExp(mgr0); + if (re.test(fp[1])) { + re = /.$/; + w = w.replace(re,""); + } + } + else if (re2.test(w)) { + var fp = re2.exec(w); + stem = fp[1]; + re2 = new RegExp(s_v); + if (re2.test(stem)) { + w = stem; + re2 = /(at|bl|iz)$/; + re3 = new RegExp("([^aeiouylsz])\\1$"); + re4 = new RegExp("^" + C + v + "[^aeiouwxy]$"); + if (re2.test(w)) + w = w + "e"; + else if (re3.test(w)) { + re = /.$/; + w = w.replace(re,""); + } + else if (re4.test(w)) + w = w + "e"; + } + } + + // Step 1c + re = /^(.+?)y$/; + if (re.test(w)) { + var fp = re.exec(w); + stem = fp[1]; + re = new RegExp(s_v); + if (re.test(stem)) + w = stem + "i"; + } + + // Step 2 + re = /^(.+?)(ational|tional|enci|anci|izer|bli|alli|entli|eli|ousli|ization|ation|ator|alism|iveness|fulness|ousness|aliti|iviti|biliti|logi)$/; + if (re.test(w)) { + var fp = re.exec(w); + stem = fp[1]; + suffix = fp[2]; + re = new RegExp(mgr0); + if (re.test(stem)) + w = stem + step2list[suffix]; + } + + // Step 3 + re = /^(.+?)(icate|ative|alize|iciti|ical|ful|ness)$/; + if (re.test(w)) { + var fp = re.exec(w); + stem = fp[1]; + suffix = fp[2]; + re = new RegExp(mgr0); + if (re.test(stem)) + w = stem + step3list[suffix]; + } + + // Step 4 + re = /^(.+?)(al|ance|ence|er|ic|able|ible|ant|ement|ment|ent|ou|ism|ate|iti|ous|ive|ize)$/; + re2 = /^(.+?)(s|t)(ion)$/; + if (re.test(w)) { + var fp = re.exec(w); + stem = fp[1]; + re = new RegExp(mgr1); + if (re.test(stem)) + w = stem; + } + else if (re2.test(w)) { + var fp = re2.exec(w); + stem = fp[1] + fp[2]; + re2 = new RegExp(mgr1); + if (re2.test(stem)) + w = stem; + } + + // Step 5 + re = /^(.+?)e$/; + if (re.test(w)) { + var fp = re.exec(w); + stem = fp[1]; + re = new RegExp(mgr1); + re2 = new RegExp(meq1); + re3 = new RegExp("^" + C + v + "[^aeiouwxy]$"); + if (re.test(stem) || (re2.test(stem) && !(re3.test(stem)))) + w = stem; + } + re = /ll$/; + re2 = new RegExp(mgr1); + if (re.test(w) && re2.test(w)) { + re = /.$/; + w = w.replace(re,""); + } + + // and turn initial Y back to y + if (firstch == "y") + w = firstch.toLowerCase() + w.substr(1); + return w; + } +} + diff --git a/_static/locales/ar/LC_MESSAGES/booktheme.po b/_static/locales/ar/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..248839ed6a --- /dev/null +++ b/_static/locales/ar/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: ar\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "تنزيل ملف دفتر الملاحظات" + +msgid "Fullscreen mode" +msgstr "وضع ملء الشاشة" + +msgid "Source repository" +msgstr "مستودع المصدر" + +msgid "Print to PDF" +msgstr "طباعة إلى PDF" + +msgid "Copyright" +msgstr "حقوق النشر" + +msgid "Sphinx Book Theme" +msgstr "موضوع كتاب أبو الهول" + +msgid "By the" +msgstr "بواسطة" + +msgid "Download this page" +msgstr "قم بتنزيل هذه الصفحة" + +msgid "repository" +msgstr "مخزن" + +msgid "Download source file" +msgstr "تنزيل ملف المصدر" + +msgid "By" +msgstr "بواسطة" + +msgid "Toggle navigation" +msgstr "تبديل التنقل" + +msgid "next page" +msgstr "الصفحة التالية" + +msgid "Last updated on" +msgstr "آخر تحديث في" + +msgid "Contents" +msgstr "محتويات" + +msgid "Launch" +msgstr "إطلاق" + +msgid "Theme by the" +msgstr "موضوع بواسطة" + +msgid "Open an issue" +msgstr "افتح قضية" + +msgid "open issue" +msgstr "قضية مفتوحة" + +msgid "suggest edit" +msgstr "أقترح تحرير" + +msgid "Edit this page" +msgstr "قم بتحرير هذه الصفحة" + +msgid "previous page" +msgstr "الصفحة السابقة" diff --git a/_static/locales/bg/LC_MESSAGES/booktheme.po b/_static/locales/bg/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..d9e917281f --- /dev/null +++ b/_static/locales/bg/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: bg\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Изтеглете файла на бележника" + +msgid "Fullscreen mode" +msgstr "Режим на цял екран" + +msgid "Source repository" +msgstr "Хранилище на източника" + +msgid "Print to PDF" +msgstr "Печат в PDF" + +msgid "Copyright" +msgstr "Авторско право" + +msgid "Sphinx Book Theme" +msgstr "Тема на книгата Sphinx" + +msgid "By the" +msgstr "По" + +msgid "Download this page" +msgstr "Изтеглете тази страница" + +msgid "repository" +msgstr "хранилище" + +msgid "Download source file" +msgstr "Изтеглете изходния файл" + +msgid "By" +msgstr "От" + +msgid "Toggle navigation" +msgstr "Превключване на навигацията" + +msgid "next page" +msgstr "Следваща страница" + +msgid "Last updated on" +msgstr "Последна актуализация на" + +msgid "Contents" +msgstr "Съдържание" + +msgid "Launch" +msgstr "Стартиране" + +msgid "Theme by the" +msgstr "Тема от" + +msgid "Open an issue" +msgstr "Отворете проблем" + +msgid "open issue" +msgstr "отворен брой" + +msgid "suggest edit" +msgstr "предложи редактиране" + +msgid "Edit this page" +msgstr "Редактирайте тази страница" + +msgid "previous page" +msgstr "предишна страница" diff --git a/_static/locales/bn/LC_MESSAGES/booktheme.po b/_static/locales/bn/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..37e9e1784b --- /dev/null +++ b/_static/locales/bn/LC_MESSAGES/booktheme.po @@ -0,0 +1,63 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: bn\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "নোটবুক ফাইল ডাউনলোড করুন" + +msgid "Source repository" +msgstr "উত্স সংগ্রহস্থল" + +msgid "Print to PDF" +msgstr "পিডিএফ প্রিন্ট করুন" + +msgid "Copyright" +msgstr "কপিরাইট" + +msgid "Sphinx Book Theme" +msgstr "স্পিনিক্স বুক থিম" + +msgid "By the" +msgstr "দ্বারা" + +msgid "Download this page" +msgstr "এই পৃষ্ঠাটি ডাউনলোড করুন" + +msgid "Download source file" +msgstr "উত্স ফাইল ডাউনলোড করুন" + +msgid "By" +msgstr "দ্বারা" + +msgid "Toggle navigation" +msgstr "নেভিগেশন টগল করুন" + +msgid "next page" +msgstr "পরবর্তী পৃষ্ঠা" + +msgid "Last updated on" +msgstr "সর্বশেষ আপডেট" + +msgid "Launch" +msgstr "শুরু করা" + +msgid "Theme by the" +msgstr "থিম দ্বারা" + +msgid "Open an issue" +msgstr "একটি সমস্যা খুলুন" + +msgid "open issue" +msgstr "খোলা সমস্যা" + +msgid "Edit this page" +msgstr "এই পৃষ্ঠাটি সম্পাদনা করুন" + +msgid "previous page" +msgstr "আগের পৃষ্ঠা" diff --git a/_static/locales/ca/LC_MESSAGES/booktheme.po b/_static/locales/ca/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..156b73ca64 --- /dev/null +++ b/_static/locales/ca/LC_MESSAGES/booktheme.po @@ -0,0 +1,66 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: ca\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Descarregar fitxer de quadern" + +msgid "Source repository" +msgstr "Dipòsit de fonts" + +msgid "Print to PDF" +msgstr "Imprimeix a PDF" + +msgid "Copyright" +msgstr "Copyright" + +msgid "Sphinx Book Theme" +msgstr "Tema del llibre Esfinx" + +msgid "By the" +msgstr "Per la" + +msgid "Download this page" +msgstr "Descarregueu aquesta pàgina" + +msgid "Download source file" +msgstr "Baixeu el fitxer font" + +msgid "By" +msgstr "Per" + +msgid "Toggle navigation" +msgstr "Commuta la navegació" + +msgid "next page" +msgstr "pàgina següent" + +msgid "Last updated on" +msgstr "Darrera actualització el" + +msgid "Launch" +msgstr "Llançament" + +msgid "Theme by the" +msgstr "Tema del" + +msgid "Open an issue" +msgstr "Obriu un número" + +msgid "open issue" +msgstr "número obert" + +msgid "suggest edit" +msgstr "suggerir edició" + +msgid "Edit this page" +msgstr "Editeu aquesta pàgina" + +msgid "previous page" +msgstr "Pàgina anterior" diff --git a/_static/locales/cs/LC_MESSAGES/booktheme.po b/_static/locales/cs/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..36e1e6f214 --- /dev/null +++ b/_static/locales/cs/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: cs\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Stáhnout soubor poznámkového bloku" + +msgid "Fullscreen mode" +msgstr "Režim celé obrazovky" + +msgid "Source repository" +msgstr "Zdrojové úložiště" + +msgid "Print to PDF" +msgstr "Tisk do PDF" + +msgid "Copyright" +msgstr "autorská práva" + +msgid "Sphinx Book Theme" +msgstr "Téma knihy Sfinga" + +msgid "By the" +msgstr "Podle" + +msgid "Download this page" +msgstr "Stáhněte si tuto stránku" + +msgid "repository" +msgstr "úložiště" + +msgid "Download source file" +msgstr "Stáhněte si zdrojový soubor" + +msgid "By" +msgstr "Podle" + +msgid "Toggle navigation" +msgstr "Přepnout navigaci" + +msgid "next page" +msgstr "další strana" + +msgid "Last updated on" +msgstr "Naposledy aktualizováno" + +msgid "Contents" +msgstr "Obsah" + +msgid "Launch" +msgstr "Zahájení" + +msgid "Theme by the" +msgstr "Téma od" + +msgid "Open an issue" +msgstr "Otevřete problém" + +msgid "open issue" +msgstr "otevřené číslo" + +msgid "suggest edit" +msgstr "navrhnout úpravy" + +msgid "Edit this page" +msgstr "Upravit tuto stránku" + +msgid "previous page" +msgstr "předchozí stránka" diff --git a/_static/locales/da/LC_MESSAGES/booktheme.po b/_static/locales/da/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..a43416421a --- /dev/null +++ b/_static/locales/da/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: da\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Download notesbog-fil" + +msgid "Fullscreen mode" +msgstr "Fuldskærmstilstand" + +msgid "Source repository" +msgstr "Kildelager" + +msgid "Print to PDF" +msgstr "Udskriv til PDF" + +msgid "Copyright" +msgstr "ophavsret" + +msgid "Sphinx Book Theme" +msgstr "Sphinx bogtema" + +msgid "By the" +msgstr "Ved" + +msgid "Download this page" +msgstr "Download denne side" + +msgid "repository" +msgstr "lager" + +msgid "Download source file" +msgstr "Download kildefil" + +msgid "By" +msgstr "Ved" + +msgid "Toggle navigation" +msgstr "Skift navigation" + +msgid "next page" +msgstr "Næste side" + +msgid "Last updated on" +msgstr "Sidst opdateret den" + +msgid "Contents" +msgstr "Indhold" + +msgid "Launch" +msgstr "Start" + +msgid "Theme by the" +msgstr "Tema af" + +msgid "Open an issue" +msgstr "Åbn et problem" + +msgid "open issue" +msgstr "åbent nummer" + +msgid "suggest edit" +msgstr "foreslå redigering" + +msgid "Edit this page" +msgstr "Rediger denne side" + +msgid "previous page" +msgstr "forrige side" diff --git a/_static/locales/de/LC_MESSAGES/booktheme.po b/_static/locales/de/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..43dae9c5f3 --- /dev/null +++ b/_static/locales/de/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: de\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Notebook-Datei herunterladen" + +msgid "Fullscreen mode" +msgstr "Vollbildmodus" + +msgid "Source repository" +msgstr "Quell-Repository" + +msgid "Print to PDF" +msgstr "In PDF drucken" + +msgid "Copyright" +msgstr "Urheberrechte ©" + +msgid "Sphinx Book Theme" +msgstr "Sphinx-Buch-Thema" + +msgid "By the" +msgstr "Bis zum" + +msgid "Download this page" +msgstr "Laden Sie diese Seite herunter" + +msgid "repository" +msgstr "Repository" + +msgid "Download source file" +msgstr "Quelldatei herunterladen" + +msgid "By" +msgstr "Durch" + +msgid "Toggle navigation" +msgstr "Navigation umschalten" + +msgid "next page" +msgstr "Nächste Seite" + +msgid "Last updated on" +msgstr "Zuletzt aktualisiert am" + +msgid "Contents" +msgstr "Inhalt" + +msgid "Launch" +msgstr "Starten" + +msgid "Theme by the" +msgstr "Thema von der" + +msgid "Open an issue" +msgstr "Öffnen Sie ein Problem" + +msgid "open issue" +msgstr "offenes Thema" + +msgid "suggest edit" +msgstr "vorschlagen zu bearbeiten" + +msgid "Edit this page" +msgstr "Bearbeite diese Seite" + +msgid "previous page" +msgstr "vorherige Seite" diff --git a/_static/locales/el/LC_MESSAGES/booktheme.po b/_static/locales/el/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..08f576e7e3 --- /dev/null +++ b/_static/locales/el/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: el\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Λήψη αρχείου σημειωματάριου" + +msgid "Fullscreen mode" +msgstr "ΛΕΙΤΟΥΡΓΙΑ ΠΛΗΡΟΥΣ ΟΘΟΝΗΣ" + +msgid "Source repository" +msgstr "Αποθήκη πηγής" + +msgid "Print to PDF" +msgstr "Εκτύπωση σε PDF" + +msgid "Copyright" +msgstr "Πνευματική ιδιοκτησία" + +msgid "Sphinx Book Theme" +msgstr "Θέμα βιβλίου Sphinx" + +msgid "By the" +msgstr "Από το" + +msgid "Download this page" +msgstr "Λήψη αυτής της σελίδας" + +msgid "repository" +msgstr "αποθήκη" + +msgid "Download source file" +msgstr "Λήψη αρχείου προέλευσης" + +msgid "By" +msgstr "Με" + +msgid "Toggle navigation" +msgstr "Εναλλαγή πλοήγησης" + +msgid "next page" +msgstr "επόμενη σελίδα" + +msgid "Last updated on" +msgstr "Τελευταία ενημέρωση στις" + +msgid "Contents" +msgstr "Περιεχόμενα" + +msgid "Launch" +msgstr "Εκτόξευση" + +msgid "Theme by the" +msgstr "Θέμα από το" + +msgid "Open an issue" +msgstr "Ανοίξτε ένα ζήτημα" + +msgid "open issue" +msgstr "ανοιχτό ζήτημα" + +msgid "suggest edit" +msgstr "προτείνω επεξεργασία" + +msgid "Edit this page" +msgstr "Επεξεργαστείτε αυτήν τη σελίδα" + +msgid "previous page" +msgstr "προηγούμενη σελίδα" diff --git a/_static/locales/eo/LC_MESSAGES/booktheme.po b/_static/locales/eo/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..93eeb04794 --- /dev/null +++ b/_static/locales/eo/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: eo\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Elŝutu kajeran dosieron" + +msgid "Fullscreen mode" +msgstr "Plenekrana reĝimo" + +msgid "Source repository" +msgstr "Fonto-deponejo" + +msgid "Print to PDF" +msgstr "Presi al PDF" + +msgid "Copyright" +msgstr "Kopirajto" + +msgid "Sphinx Book Theme" +msgstr "Sfinksa Libro-Temo" + +msgid "By the" +msgstr "Per la" + +msgid "Download this page" +msgstr "Elŝutu ĉi tiun paĝon" + +msgid "repository" +msgstr "deponejo" + +msgid "Download source file" +msgstr "Elŝutu fontodosieron" + +msgid "By" +msgstr "De" + +msgid "Toggle navigation" +msgstr "Ŝalti navigadon" + +msgid "next page" +msgstr "sekva paĝo" + +msgid "Last updated on" +msgstr "Laste ĝisdatigita la" + +msgid "Contents" +msgstr "Enhavo" + +msgid "Launch" +msgstr "Lanĉo" + +msgid "Theme by the" +msgstr "Temo de la" + +msgid "Open an issue" +msgstr "Malfermu numeron" + +msgid "open issue" +msgstr "malferma numero" + +msgid "suggest edit" +msgstr "sugesti redaktadon" + +msgid "Edit this page" +msgstr "Redaktu ĉi tiun paĝon" + +msgid "previous page" +msgstr "antaŭa paĝo" diff --git a/_static/locales/es/LC_MESSAGES/booktheme.po b/_static/locales/es/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..9b1e39e673 --- /dev/null +++ b/_static/locales/es/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: es\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Descargar archivo de cuaderno" + +msgid "Fullscreen mode" +msgstr "Modo de pantalla completa" + +msgid "Source repository" +msgstr "Repositorio de origen" + +msgid "Print to PDF" +msgstr "Imprimir en PDF" + +msgid "Copyright" +msgstr "Derechos de autor" + +msgid "Sphinx Book Theme" +msgstr "Tema del libro de la esfinge" + +msgid "By the" +msgstr "Por el" + +msgid "Download this page" +msgstr "Descarga esta pagina" + +msgid "repository" +msgstr "repositorio" + +msgid "Download source file" +msgstr "Descargar archivo fuente" + +msgid "By" +msgstr "Por" + +msgid "Toggle navigation" +msgstr "Navegación de palanca" + +msgid "next page" +msgstr "siguiente página" + +msgid "Last updated on" +msgstr "Ultima actualización en" + +msgid "Contents" +msgstr "Contenido" + +msgid "Launch" +msgstr "Lanzamiento" + +msgid "Theme by the" +msgstr "Tema por el" + +msgid "Open an issue" +msgstr "Abrir un problema" + +msgid "open issue" +msgstr "Tema abierto" + +msgid "suggest edit" +msgstr "sugerir editar" + +msgid "Edit this page" +msgstr "Edita esta página" + +msgid "previous page" +msgstr "pagina anterior" diff --git a/_static/locales/et/LC_MESSAGES/booktheme.po b/_static/locales/et/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..706b4d9ffa --- /dev/null +++ b/_static/locales/et/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: et\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Laadige sülearvuti fail alla" + +msgid "Fullscreen mode" +msgstr "Täisekraanirežiim" + +msgid "Source repository" +msgstr "Allikahoidla" + +msgid "Print to PDF" +msgstr "Prindi PDF-i" + +msgid "Copyright" +msgstr "Autoriõigus" + +msgid "Sphinx Book Theme" +msgstr "Sfinksiraamatu teema" + +msgid "By the" +msgstr "Autor" + +msgid "Download this page" +msgstr "Laadige see leht alla" + +msgid "repository" +msgstr "hoidla" + +msgid "Download source file" +msgstr "Laadige alla lähtefail" + +msgid "By" +msgstr "Kõrval" + +msgid "Toggle navigation" +msgstr "Lülita navigeerimine sisse" + +msgid "next page" +msgstr "järgmine leht" + +msgid "Last updated on" +msgstr "Viimati uuendatud" + +msgid "Contents" +msgstr "Sisu" + +msgid "Launch" +msgstr "Käivitage" + +msgid "Theme by the" +msgstr "Teema" + +msgid "Open an issue" +msgstr "Avage probleem" + +msgid "open issue" +msgstr "avatud küsimus" + +msgid "suggest edit" +msgstr "soovita muuta" + +msgid "Edit this page" +msgstr "Muutke seda lehte" + +msgid "previous page" +msgstr "eelmine leht" diff --git a/_static/locales/fi/LC_MESSAGES/booktheme.po b/_static/locales/fi/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..5f2a8f8dcb --- /dev/null +++ b/_static/locales/fi/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: fi\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Lataa muistikirjatiedosto" + +msgid "Fullscreen mode" +msgstr "Koko näytön tila" + +msgid "Source repository" +msgstr "Lähteen arkisto" + +msgid "Print to PDF" +msgstr "Tulosta PDF-tiedostoon" + +msgid "Copyright" +msgstr "Tekijänoikeus" + +msgid "Sphinx Book Theme" +msgstr "Sphinx-kirjan teema" + +msgid "By the" +msgstr "Mukaan" + +msgid "Download this page" +msgstr "Lataa tämä sivu" + +msgid "repository" +msgstr "arkisto" + +msgid "Download source file" +msgstr "Lataa lähdetiedosto" + +msgid "By" +msgstr "Tekijä" + +msgid "Toggle navigation" +msgstr "Vaihda navigointia" + +msgid "next page" +msgstr "seuraava sivu" + +msgid "Last updated on" +msgstr "Viimeksi päivitetty" + +msgid "Contents" +msgstr "Sisällys" + +msgid "Launch" +msgstr "Tuoda markkinoille" + +msgid "Theme by the" +msgstr "Teeman tekijä" + +msgid "Open an issue" +msgstr "Avaa ongelma" + +msgid "open issue" +msgstr "avoin ongelma" + +msgid "suggest edit" +msgstr "ehdottaa muokkausta" + +msgid "Edit this page" +msgstr "Muokkaa tätä sivua" + +msgid "previous page" +msgstr "Edellinen sivu" diff --git a/_static/locales/fr/LC_MESSAGES/booktheme.po b/_static/locales/fr/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..493bfbb759 --- /dev/null +++ b/_static/locales/fr/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: fr\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Télécharger le fichier notebook" + +msgid "Fullscreen mode" +msgstr "Mode plein écran" + +msgid "Source repository" +msgstr "Dépôt source" + +msgid "Print to PDF" +msgstr "Imprimer au format PDF" + +msgid "Copyright" +msgstr "droits d'auteur" + +msgid "Sphinx Book Theme" +msgstr "Thème du livre Sphinx" + +msgid "By the" +msgstr "Par le" + +msgid "Download this page" +msgstr "Téléchargez cette page" + +msgid "repository" +msgstr "dépôt" + +msgid "Download source file" +msgstr "Télécharger le fichier source" + +msgid "By" +msgstr "Par" + +msgid "Toggle navigation" +msgstr "Basculer la navigation" + +msgid "next page" +msgstr "page suivante" + +msgid "Last updated on" +msgstr "Dernière mise à jour le" + +msgid "Contents" +msgstr "Contenu" + +msgid "Launch" +msgstr "lancement" + +msgid "Theme by the" +msgstr "Thème par le" + +msgid "Open an issue" +msgstr "Ouvrez un problème" + +msgid "open issue" +msgstr "signaler un problème" + +msgid "suggest edit" +msgstr "suggestion de modification" + +msgid "Edit this page" +msgstr "Modifier cette page" + +msgid "previous page" +msgstr "page précédente" diff --git a/_static/locales/hr/LC_MESSAGES/booktheme.po b/_static/locales/hr/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..23c5ee3686 --- /dev/null +++ b/_static/locales/hr/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: hr\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Preuzmi datoteku bilježnice" + +msgid "Fullscreen mode" +msgstr "Način preko cijelog zaslona" + +msgid "Source repository" +msgstr "Izvorno spremište" + +msgid "Print to PDF" +msgstr "Ispis u PDF" + +msgid "Copyright" +msgstr "Autorska prava" + +msgid "Sphinx Book Theme" +msgstr "Tema knjige Sphinx" + +msgid "By the" +msgstr "Od strane" + +msgid "Download this page" +msgstr "Preuzmite ovu stranicu" + +msgid "repository" +msgstr "spremište" + +msgid "Download source file" +msgstr "Preuzmi izvornu datoteku" + +msgid "By" +msgstr "Po" + +msgid "Toggle navigation" +msgstr "Uključi / isključi navigaciju" + +msgid "next page" +msgstr "sljedeća stranica" + +msgid "Last updated on" +msgstr "Posljednje ažuriranje:" + +msgid "Contents" +msgstr "Sadržaj" + +msgid "Launch" +msgstr "Pokrenite" + +msgid "Theme by the" +msgstr "Tema autora" + +msgid "Open an issue" +msgstr "Otvorite izdanje" + +msgid "open issue" +msgstr "otvoreno izdanje" + +msgid "suggest edit" +msgstr "predloži uređivanje" + +msgid "Edit this page" +msgstr "Uredite ovu stranicu" + +msgid "previous page" +msgstr "Prethodna stranica" diff --git a/_static/locales/id/LC_MESSAGES/booktheme.po b/_static/locales/id/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..2fb9b7a874 --- /dev/null +++ b/_static/locales/id/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: id\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Unduh file notebook" + +msgid "Fullscreen mode" +msgstr "Mode layar penuh" + +msgid "Source repository" +msgstr "Repositori sumber" + +msgid "Print to PDF" +msgstr "Cetak ke PDF" + +msgid "Copyright" +msgstr "hak cipta" + +msgid "Sphinx Book Theme" +msgstr "Tema Buku Sphinx" + +msgid "By the" +msgstr "Oleh" + +msgid "Download this page" +msgstr "Unduh halaman ini" + +msgid "repository" +msgstr "gudang" + +msgid "Download source file" +msgstr "Unduh file sumber" + +msgid "By" +msgstr "Oleh" + +msgid "Toggle navigation" +msgstr "Alihkan navigasi" + +msgid "next page" +msgstr "halaman selanjutnya" + +msgid "Last updated on" +msgstr "Terakhir diperbarui saat" + +msgid "Contents" +msgstr "Isi" + +msgid "Launch" +msgstr "Meluncurkan" + +msgid "Theme by the" +msgstr "Tema oleh" + +msgid "Open an issue" +msgstr "Buka masalah" + +msgid "open issue" +msgstr "masalah terbuka" + +msgid "suggest edit" +msgstr "menyarankan edit" + +msgid "Edit this page" +msgstr "Edit halaman ini" + +msgid "previous page" +msgstr "halaman sebelumnya" diff --git a/_static/locales/it/LC_MESSAGES/booktheme.po b/_static/locales/it/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..5b752c9e8f --- /dev/null +++ b/_static/locales/it/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: it\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Scarica il file del taccuino" + +msgid "Fullscreen mode" +msgstr "Modalità schermo intero" + +msgid "Source repository" +msgstr "Repository di origine" + +msgid "Print to PDF" +msgstr "Stampa in PDF" + +msgid "Copyright" +msgstr "Diritto d'autore" + +msgid "Sphinx Book Theme" +msgstr "Tema del libro della Sfinge" + +msgid "By the" +msgstr "Dal" + +msgid "Download this page" +msgstr "Scarica questa pagina" + +msgid "repository" +msgstr "repository" + +msgid "Download source file" +msgstr "Scarica il file sorgente" + +msgid "By" +msgstr "Di" + +msgid "Toggle navigation" +msgstr "Attiva / disattiva la navigazione" + +msgid "next page" +msgstr "pagina successiva" + +msgid "Last updated on" +msgstr "Ultimo aggiornamento il" + +msgid "Contents" +msgstr "Contenuti" + +msgid "Launch" +msgstr "Lanciare" + +msgid "Theme by the" +msgstr "Tema di" + +msgid "Open an issue" +msgstr "Apri un problema" + +msgid "open issue" +msgstr "questione aperta" + +msgid "suggest edit" +msgstr "suggerisci modifica" + +msgid "Edit this page" +msgstr "Modifica questa pagina" + +msgid "previous page" +msgstr "pagina precedente" diff --git a/_static/locales/iw/LC_MESSAGES/booktheme.po b/_static/locales/iw/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..98fa583e79 --- /dev/null +++ b/_static/locales/iw/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: iw\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "הורד קובץ מחברת" + +msgid "Fullscreen mode" +msgstr "מצב מסך מלא" + +msgid "Source repository" +msgstr "מאגר המקורות" + +msgid "Print to PDF" +msgstr "הדפס לקובץ PDF" + +msgid "Copyright" +msgstr "זכויות יוצרים" + +msgid "Sphinx Book Theme" +msgstr "נושא ספר ספינקס" + +msgid "By the" +msgstr "דרך" + +msgid "Download this page" +msgstr "הורד דף זה" + +msgid "repository" +msgstr "מאגר" + +msgid "Download source file" +msgstr "הורד את קובץ המקור" + +msgid "By" +msgstr "על ידי" + +msgid "Toggle navigation" +msgstr "החלף ניווט" + +msgid "next page" +msgstr "עמוד הבא" + +msgid "Last updated on" +msgstr "עודכן לאחרונה ב" + +msgid "Contents" +msgstr "תוכן" + +msgid "Launch" +msgstr "לְהַשִׁיק" + +msgid "Theme by the" +msgstr "נושא מאת" + +msgid "Open an issue" +msgstr "פתח גיליון" + +msgid "open issue" +msgstr "בעיה פתוחה" + +msgid "suggest edit" +msgstr "מציע לערוך" + +msgid "Edit this page" +msgstr "ערוך דף זה" + +msgid "previous page" +msgstr "עמוד קודם" diff --git a/_static/locales/ja/LC_MESSAGES/booktheme.po b/_static/locales/ja/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..255ec18753 --- /dev/null +++ b/_static/locales/ja/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: ja\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "ノートブックファイルをダウンロード" + +msgid "Fullscreen mode" +msgstr "全画面モード" + +msgid "Source repository" +msgstr "ソースリポジトリ" + +msgid "Print to PDF" +msgstr "PDFに印刷" + +msgid "Copyright" +msgstr "Copyright" + +msgid "Sphinx Book Theme" +msgstr "スフィンクスの本のテーマ" + +msgid "By the" +msgstr "によって" + +msgid "Download this page" +msgstr "このページをダウンロード" + +msgid "repository" +msgstr "リポジトリ" + +msgid "Download source file" +msgstr "ソースファイルをダウンロード" + +msgid "By" +msgstr "著者" + +msgid "Toggle navigation" +msgstr "ナビゲーションを切り替え" + +msgid "next page" +msgstr "次のページ" + +msgid "Last updated on" +msgstr "最終更新日" + +msgid "Contents" +msgstr "目次" + +msgid "Launch" +msgstr "起動" + +msgid "Theme by the" +msgstr "のテーマ" + +msgid "Open an issue" +msgstr "問題を報告" + +msgid "open issue" +msgstr "未解決の問題" + +msgid "suggest edit" +msgstr "編集を提案する" + +msgid "Edit this page" +msgstr "このページを編集" + +msgid "previous page" +msgstr "前のページ" diff --git a/_static/locales/ko/LC_MESSAGES/booktheme.po b/_static/locales/ko/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..6d602356f5 --- /dev/null +++ b/_static/locales/ko/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: ko\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "노트북 파일 다운로드" + +msgid "Fullscreen mode" +msgstr "전체 화면으로보기" + +msgid "Source repository" +msgstr "소스 저장소" + +msgid "Print to PDF" +msgstr "PDF로 인쇄" + +msgid "Copyright" +msgstr "저작권" + +msgid "Sphinx Book Theme" +msgstr "스핑크스 도서 테마" + +msgid "By the" +msgstr "에 의해" + +msgid "Download this page" +msgstr "이 페이지 다운로드" + +msgid "repository" +msgstr "저장소" + +msgid "Download source file" +msgstr "소스 파일 다운로드" + +msgid "By" +msgstr "으로" + +msgid "Toggle navigation" +msgstr "탐색 전환" + +msgid "next page" +msgstr "다음 페이지" + +msgid "Last updated on" +msgstr "마지막 업데이트" + +msgid "Contents" +msgstr "내용" + +msgid "Launch" +msgstr "시작하다" + +msgid "Theme by the" +msgstr "테마별" + +msgid "Open an issue" +msgstr "이슈 열기" + +msgid "open issue" +msgstr "열린 문제" + +msgid "suggest edit" +msgstr "편집 제안" + +msgid "Edit this page" +msgstr "이 페이지 편집" + +msgid "previous page" +msgstr "이전 페이지" diff --git a/_static/locales/lt/LC_MESSAGES/booktheme.po b/_static/locales/lt/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..9779fd9545 --- /dev/null +++ b/_static/locales/lt/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: lt\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Atsisiųsti nešiojamojo kompiuterio failą" + +msgid "Fullscreen mode" +msgstr "Pilno ekrano režimas" + +msgid "Source repository" +msgstr "Šaltinio saugykla" + +msgid "Print to PDF" +msgstr "Spausdinti į PDF" + +msgid "Copyright" +msgstr "Autorių teisės" + +msgid "Sphinx Book Theme" +msgstr "Sfinkso knygos tema" + +msgid "By the" +msgstr "Prie" + +msgid "Download this page" +msgstr "Atsisiųskite šį puslapį" + +msgid "repository" +msgstr "saugykla" + +msgid "Download source file" +msgstr "Atsisiųsti šaltinio failą" + +msgid "By" +msgstr "Iki" + +msgid "Toggle navigation" +msgstr "Perjungti naršymą" + +msgid "next page" +msgstr "Kitas puslapis" + +msgid "Last updated on" +msgstr "Paskutinį kartą atnaujinta" + +msgid "Contents" +msgstr "Turinys" + +msgid "Launch" +msgstr "Paleiskite" + +msgid "Theme by the" +msgstr "Tema" + +msgid "Open an issue" +msgstr "Atidarykite problemą" + +msgid "open issue" +msgstr "atviras klausimas" + +msgid "suggest edit" +msgstr "pasiūlyti redaguoti" + +msgid "Edit this page" +msgstr "Redaguoti šį puslapį" + +msgid "previous page" +msgstr "Ankstesnis puslapis" diff --git a/_static/locales/lv/LC_MESSAGES/booktheme.po b/_static/locales/lv/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..605b47bc72 --- /dev/null +++ b/_static/locales/lv/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: lv\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Lejupielādēt piezīmju grāmatiņu" + +msgid "Fullscreen mode" +msgstr "Pilnekrāna režīms" + +msgid "Source repository" +msgstr "Avota krātuve" + +msgid "Print to PDF" +msgstr "Drukāt PDF formātā" + +msgid "Copyright" +msgstr "Autortiesības" + +msgid "Sphinx Book Theme" +msgstr "Sfinksa grāmatas tēma" + +msgid "By the" +msgstr "Ar" + +msgid "Download this page" +msgstr "Lejupielādējiet šo lapu" + +msgid "repository" +msgstr "krātuve" + +msgid "Download source file" +msgstr "Lejupielādēt avota failu" + +msgid "By" +msgstr "Autors" + +msgid "Toggle navigation" +msgstr "Pārslēgt navigāciju" + +msgid "next page" +msgstr "nākamā lapaspuse" + +msgid "Last updated on" +msgstr "Pēdējoreiz atjaunināts" + +msgid "Contents" +msgstr "Saturs" + +msgid "Launch" +msgstr "Uzsākt" + +msgid "Theme by the" +msgstr "Autora tēma" + +msgid "Open an issue" +msgstr "Atveriet problēmu" + +msgid "open issue" +msgstr "atklāts jautājums" + +msgid "suggest edit" +msgstr "ieteikt rediģēt" + +msgid "Edit this page" +msgstr "Rediģēt šo lapu" + +msgid "previous page" +msgstr "iepriekšējā lapa" diff --git a/_static/locales/ml/LC_MESSAGES/booktheme.po b/_static/locales/ml/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..104984e75d --- /dev/null +++ b/_static/locales/ml/LC_MESSAGES/booktheme.po @@ -0,0 +1,66 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: ml\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "നോട്ട്ബുക്ക് ഫയൽ ഡൺലോഡ് ചെയ്യുക" + +msgid "Source repository" +msgstr "ഉറവിട ശേഖരം" + +msgid "Print to PDF" +msgstr "PDF- ലേക്ക് പ്രിന്റുചെയ്യുക" + +msgid "Copyright" +msgstr "പകർപ്പവകാശം" + +msgid "Sphinx Book Theme" +msgstr "സ്ഫിങ്ക്സ് പുസ്തക തീം" + +msgid "By the" +msgstr "എഴുതിയത്" + +msgid "Download this page" +msgstr "ഈ പേജ് ഡൗൺലോഡുചെയ്യുക" + +msgid "Download source file" +msgstr "ഉറവിട ഫയൽ ഡൗൺലോഡുചെയ്യുക" + +msgid "By" +msgstr "എഴുതിയത്" + +msgid "Toggle navigation" +msgstr "നാവിഗേഷൻ ടോഗിൾ ചെയ്യുക" + +msgid "next page" +msgstr "അടുത്ത പേജ്" + +msgid "Last updated on" +msgstr "അവസാനം അപ്‌ഡേറ്റുചെയ്‌തത്" + +msgid "Launch" +msgstr "സമാരംഭിക്കുക" + +msgid "Theme by the" +msgstr "പ്രമേയം" + +msgid "Open an issue" +msgstr "ഒരു പ്രശ്നം തുറക്കുക" + +msgid "open issue" +msgstr "തുറന്ന പ്രശ്നം" + +msgid "suggest edit" +msgstr "എഡിറ്റുചെയ്യാൻ നിർദ്ദേശിക്കുക" + +msgid "Edit this page" +msgstr "ഈ പേജ് എഡിറ്റുചെയ്യുക" + +msgid "previous page" +msgstr "മുൻപത്തെ താൾ" diff --git a/_static/locales/mr/LC_MESSAGES/booktheme.po b/_static/locales/mr/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..c3d2c36d7c --- /dev/null +++ b/_static/locales/mr/LC_MESSAGES/booktheme.po @@ -0,0 +1,66 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: mr\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "नोटबुक फाईल डाउनलोड करा" + +msgid "Source repository" +msgstr "स्त्रोत भांडार" + +msgid "Print to PDF" +msgstr "पीडीएफवर मुद्रित करा" + +msgid "Copyright" +msgstr "कॉपीराइट" + +msgid "Sphinx Book Theme" +msgstr "स्फिंक्स बुक थीम" + +msgid "By the" +msgstr "द्वारा" + +msgid "Download this page" +msgstr "हे पृष्ठ डाउनलोड करा" + +msgid "Download source file" +msgstr "स्त्रोत फाइल डाउनलोड करा" + +msgid "By" +msgstr "द्वारा" + +msgid "Toggle navigation" +msgstr "नेव्हिगेशन टॉगल करा" + +msgid "next page" +msgstr "पुढील पृष्ठ" + +msgid "Last updated on" +msgstr "अखेरचे अद्यतनित" + +msgid "Launch" +msgstr "लाँच करा" + +msgid "Theme by the" +msgstr "द्वारा थीम" + +msgid "Open an issue" +msgstr "एक मुद्दा उघडा" + +msgid "open issue" +msgstr "खुला मुद्दा" + +msgid "suggest edit" +msgstr "संपादन सुचवा" + +msgid "Edit this page" +msgstr "हे पृष्ठ संपादित करा" + +msgid "previous page" +msgstr "मागील पान" diff --git a/_static/locales/ms/LC_MESSAGES/booktheme.po b/_static/locales/ms/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..d0209ab301 --- /dev/null +++ b/_static/locales/ms/LC_MESSAGES/booktheme.po @@ -0,0 +1,66 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: ms\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Muat turun fail buku nota" + +msgid "Source repository" +msgstr "Repositori sumber" + +msgid "Print to PDF" +msgstr "Cetak ke PDF" + +msgid "Copyright" +msgstr "hak cipta" + +msgid "Sphinx Book Theme" +msgstr "Tema Buku Sphinx" + +msgid "By the" +msgstr "Oleh" + +msgid "Download this page" +msgstr "Muat turun halaman ini" + +msgid "Download source file" +msgstr "Muat turun fail sumber" + +msgid "By" +msgstr "Oleh" + +msgid "Toggle navigation" +msgstr "Togol navigasi" + +msgid "next page" +msgstr "muka surat seterusnya" + +msgid "Last updated on" +msgstr "Terakhir dikemas kini pada" + +msgid "Launch" +msgstr "Lancarkan" + +msgid "Theme by the" +msgstr "Tema oleh" + +msgid "Open an issue" +msgstr "Buka masalah" + +msgid "open issue" +msgstr "isu terbuka" + +msgid "suggest edit" +msgstr "cadangkan edit" + +msgid "Edit this page" +msgstr "Edit halaman ini" + +msgid "previous page" +msgstr "halaman sebelumnya" diff --git a/_static/locales/nl/LC_MESSAGES/booktheme.po b/_static/locales/nl/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..c5529a0ceb --- /dev/null +++ b/_static/locales/nl/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: nl\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Download notebookbestand" + +msgid "Fullscreen mode" +msgstr "Volledig scherm" + +msgid "Source repository" +msgstr "Bronopslagplaats" + +msgid "Print to PDF" +msgstr "Afdrukken naar pdf" + +msgid "Copyright" +msgstr "auteursrechten" + +msgid "Sphinx Book Theme" +msgstr "Sphinx-boekthema" + +msgid "By the" +msgstr "Door de" + +msgid "Download this page" +msgstr "Download deze pagina" + +msgid "repository" +msgstr "repository" + +msgid "Download source file" +msgstr "Download het bronbestand" + +msgid "By" +msgstr "Door" + +msgid "Toggle navigation" +msgstr "Schakel navigatie" + +msgid "next page" +msgstr "volgende bladzijde" + +msgid "Last updated on" +msgstr "Laatst geupdate op" + +msgid "Contents" +msgstr "Inhoud" + +msgid "Launch" +msgstr "Lancering" + +msgid "Theme by the" +msgstr "Thema door de" + +msgid "Open an issue" +msgstr "Open een probleem" + +msgid "open issue" +msgstr "open probleem" + +msgid "suggest edit" +msgstr "suggereren bewerken" + +msgid "Edit this page" +msgstr "bewerk deze pagina" + +msgid "previous page" +msgstr "vorige pagina" diff --git a/_static/locales/no/LC_MESSAGES/booktheme.po b/_static/locales/no/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..11ddbf4486 --- /dev/null +++ b/_static/locales/no/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: no\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Last ned notatbokfilen" + +msgid "Fullscreen mode" +msgstr "Fullskjerm-modus" + +msgid "Source repository" +msgstr "Kildedepot" + +msgid "Print to PDF" +msgstr "Skriv ut til PDF" + +msgid "Copyright" +msgstr "opphavsrett" + +msgid "Sphinx Book Theme" +msgstr "Sphinx boktema" + +msgid "By the" +msgstr "Ved" + +msgid "Download this page" +msgstr "Last ned denne siden" + +msgid "repository" +msgstr "oppbevaringssted" + +msgid "Download source file" +msgstr "Last ned kildefilen" + +msgid "By" +msgstr "Av" + +msgid "Toggle navigation" +msgstr "Bytt navigasjon" + +msgid "next page" +msgstr "neste side" + +msgid "Last updated on" +msgstr "Sist oppdatert den" + +msgid "Contents" +msgstr "Innhold" + +msgid "Launch" +msgstr "Start" + +msgid "Theme by the" +msgstr "Tema av" + +msgid "Open an issue" +msgstr "Åpne et problem" + +msgid "open issue" +msgstr "åpent nummer" + +msgid "suggest edit" +msgstr "foreslå redigering" + +msgid "Edit this page" +msgstr "Rediger denne siden" + +msgid "previous page" +msgstr "forrige side" diff --git a/_static/locales/pl/LC_MESSAGES/booktheme.po b/_static/locales/pl/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..5132cd62f2 --- /dev/null +++ b/_static/locales/pl/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: pl\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Pobierz plik notatnika" + +msgid "Fullscreen mode" +msgstr "Pełny ekran" + +msgid "Source repository" +msgstr "Repozytorium źródłowe" + +msgid "Print to PDF" +msgstr "Drukuj do PDF" + +msgid "Copyright" +msgstr "prawa autorskie" + +msgid "Sphinx Book Theme" +msgstr "Motyw książki Sphinx" + +msgid "By the" +msgstr "Przez" + +msgid "Download this page" +msgstr "Pobierz tę stronę" + +msgid "repository" +msgstr "magazyn" + +msgid "Download source file" +msgstr "Pobierz plik źródłowy" + +msgid "By" +msgstr "Przez" + +msgid "Toggle navigation" +msgstr "Przełącz nawigację" + +msgid "next page" +msgstr "Następna strona" + +msgid "Last updated on" +msgstr "Ostatnia aktualizacja" + +msgid "Contents" +msgstr "Zawartość" + +msgid "Launch" +msgstr "Uruchomić" + +msgid "Theme by the" +msgstr "Motyw autorstwa" + +msgid "Open an issue" +msgstr "Otwórz problem" + +msgid "open issue" +msgstr "otwarty problem" + +msgid "suggest edit" +msgstr "zaproponuj edycję" + +msgid "Edit this page" +msgstr "Edytuj tę strone" + +msgid "previous page" +msgstr "Poprzednia strona" diff --git a/_static/locales/pt/LC_MESSAGES/booktheme.po b/_static/locales/pt/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..50932b41df --- /dev/null +++ b/_static/locales/pt/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: pt\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Baixar arquivo de notebook" + +msgid "Fullscreen mode" +msgstr "Modo tela cheia" + +msgid "Source repository" +msgstr "Repositório fonte" + +msgid "Print to PDF" +msgstr "Imprimir em PDF" + +msgid "Copyright" +msgstr "direito autoral" + +msgid "Sphinx Book Theme" +msgstr "Tema do livro Sphinx" + +msgid "By the" +msgstr "Pelo" + +msgid "Download this page" +msgstr "Baixe esta página" + +msgid "repository" +msgstr "repositório" + +msgid "Download source file" +msgstr "Baixar arquivo fonte" + +msgid "By" +msgstr "De" + +msgid "Toggle navigation" +msgstr "Alternar de navegação" + +msgid "next page" +msgstr "próxima página" + +msgid "Last updated on" +msgstr "Última atualização em" + +msgid "Contents" +msgstr "Conteúdo" + +msgid "Launch" +msgstr "Lançamento" + +msgid "Theme by the" +msgstr "Tema por" + +msgid "Open an issue" +msgstr "Abra um problema" + +msgid "open issue" +msgstr "questão aberta" + +msgid "suggest edit" +msgstr "sugerir edição" + +msgid "Edit this page" +msgstr "Edite essa página" + +msgid "previous page" +msgstr "página anterior" diff --git a/_static/locales/ro/LC_MESSAGES/booktheme.po b/_static/locales/ro/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..4a155fd175 --- /dev/null +++ b/_static/locales/ro/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: ro\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Descărcați fișierul notebook" + +msgid "Fullscreen mode" +msgstr "Modul ecran întreg" + +msgid "Source repository" +msgstr "Depozit sursă" + +msgid "Print to PDF" +msgstr "Imprimați în PDF" + +msgid "Copyright" +msgstr "Drepturi de autor" + +msgid "Sphinx Book Theme" +msgstr "Tema Sphinx Book" + +msgid "By the" +msgstr "Langa" + +msgid "Download this page" +msgstr "Descarcă această pagină" + +msgid "repository" +msgstr "repertoriu" + +msgid "Download source file" +msgstr "Descărcați fișierul sursă" + +msgid "By" +msgstr "De" + +msgid "Toggle navigation" +msgstr "Comutare navigare" + +msgid "next page" +msgstr "pagina următoare" + +msgid "Last updated on" +msgstr "Ultima actualizare la" + +msgid "Contents" +msgstr "Cuprins" + +msgid "Launch" +msgstr "Lansa" + +msgid "Theme by the" +msgstr "Tema de" + +msgid "Open an issue" +msgstr "Deschideți o problemă" + +msgid "open issue" +msgstr "problema deschisă" + +msgid "suggest edit" +msgstr "sugerează editare" + +msgid "Edit this page" +msgstr "Editați această pagină" + +msgid "previous page" +msgstr "pagina anterioară" diff --git a/_static/locales/ru/LC_MESSAGES/booktheme.po b/_static/locales/ru/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..1e53c0362c --- /dev/null +++ b/_static/locales/ru/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: ru\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Скачать файл записной книжки" + +msgid "Fullscreen mode" +msgstr "Полноэкранный режим" + +msgid "Source repository" +msgstr "Исходный репозиторий" + +msgid "Print to PDF" +msgstr "Распечатать в PDF" + +msgid "Copyright" +msgstr "авторское право" + +msgid "Sphinx Book Theme" +msgstr "Тема книги Сфинкс" + +msgid "By the" +msgstr "Посредством" + +msgid "Download this page" +msgstr "Загрузите эту страницу" + +msgid "repository" +msgstr "хранилище" + +msgid "Download source file" +msgstr "Скачать исходный файл" + +msgid "By" +msgstr "Автор:" + +msgid "Toggle navigation" +msgstr "Переключить навигацию" + +msgid "next page" +msgstr "Следующая страница" + +msgid "Last updated on" +msgstr "Последнее обновление" + +msgid "Contents" +msgstr "Содержание" + +msgid "Launch" +msgstr "Запуск" + +msgid "Theme by the" +msgstr "Тема от" + +msgid "Open an issue" +msgstr "Открыть вопрос" + +msgid "open issue" +msgstr "открытый вопрос" + +msgid "suggest edit" +msgstr "предложить редактировать" + +msgid "Edit this page" +msgstr "Редактировать эту страницу" + +msgid "previous page" +msgstr "Предыдущая страница" diff --git a/_static/locales/sk/LC_MESSAGES/booktheme.po b/_static/locales/sk/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..c544feac27 --- /dev/null +++ b/_static/locales/sk/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: sk\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Stiahnite si zošit" + +msgid "Fullscreen mode" +msgstr "Režim celej obrazovky" + +msgid "Source repository" +msgstr "Zdrojové úložisko" + +msgid "Print to PDF" +msgstr "Tlač do PDF" + +msgid "Copyright" +msgstr "Autorské práva" + +msgid "Sphinx Book Theme" +msgstr "Téma knihy Sfinga" + +msgid "By the" +msgstr "Podľa" + +msgid "Download this page" +msgstr "Stiahnite si túto stránku" + +msgid "repository" +msgstr "Úložisko" + +msgid "Download source file" +msgstr "Stiahnite si zdrojový súbor" + +msgid "By" +msgstr "Autor:" + +msgid "Toggle navigation" +msgstr "Prepnúť navigáciu" + +msgid "next page" +msgstr "ďalšia strana" + +msgid "Last updated on" +msgstr "Posledná aktualizácia dňa" + +msgid "Contents" +msgstr "Obsah" + +msgid "Launch" +msgstr "Spustiť" + +msgid "Theme by the" +msgstr "Téma od" + +msgid "Open an issue" +msgstr "Otvorte problém" + +msgid "open issue" +msgstr "otvorené vydanie" + +msgid "suggest edit" +msgstr "navrhnúť úpravu" + +msgid "Edit this page" +msgstr "Upraviť túto stránku" + +msgid "previous page" +msgstr "predchádzajúca strana" diff --git a/_static/locales/sl/LC_MESSAGES/booktheme.po b/_static/locales/sl/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..f277a412eb --- /dev/null +++ b/_static/locales/sl/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: sl\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Prenesite datoteko zvezka" + +msgid "Fullscreen mode" +msgstr "Celozaslonski način" + +msgid "Source repository" +msgstr "Izvorno skladišče" + +msgid "Print to PDF" +msgstr "Natisni v PDF" + +msgid "Copyright" +msgstr "avtorske pravice" + +msgid "Sphinx Book Theme" +msgstr "Tema knjige Sphinx" + +msgid "By the" +msgstr "Avtor" + +msgid "Download this page" +msgstr "Prenesite to stran" + +msgid "repository" +msgstr "odlagališče" + +msgid "Download source file" +msgstr "Prenesite izvorno datoteko" + +msgid "By" +msgstr "Avtor" + +msgid "Toggle navigation" +msgstr "Preklopi navigacijo" + +msgid "next page" +msgstr "Naslednja stran" + +msgid "Last updated on" +msgstr "Nazadnje posodobljeno dne" + +msgid "Contents" +msgstr "Vsebina" + +msgid "Launch" +msgstr "Kosilo" + +msgid "Theme by the" +msgstr "Tema avtorja" + +msgid "Open an issue" +msgstr "Odprite številko" + +msgid "open issue" +msgstr "odprto vprašanje" + +msgid "suggest edit" +msgstr "predlagajte urejanje" + +msgid "Edit this page" +msgstr "Uredite to stran" + +msgid "previous page" +msgstr "Prejšnja stran" diff --git a/_static/locales/sr/LC_MESSAGES/booktheme.po b/_static/locales/sr/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..60f407e996 --- /dev/null +++ b/_static/locales/sr/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: sr\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Преузмите датотеку бележнице" + +msgid "Fullscreen mode" +msgstr "Режим целог екрана" + +msgid "Source repository" +msgstr "Изворно спремиште" + +msgid "Print to PDF" +msgstr "Испис у ПДФ" + +msgid "Copyright" +msgstr "Ауторско право" + +msgid "Sphinx Book Theme" +msgstr "Тема књиге Спхинк" + +msgid "By the" +msgstr "Од" + +msgid "Download this page" +msgstr "Преузмите ову страницу" + +msgid "repository" +msgstr "спремиште" + +msgid "Download source file" +msgstr "Преузми изворну датотеку" + +msgid "By" +msgstr "Од стране" + +msgid "Toggle navigation" +msgstr "Укључи / искључи навигацију" + +msgid "next page" +msgstr "Следећа страна" + +msgid "Last updated on" +msgstr "Последње ажурирање" + +msgid "Contents" +msgstr "Садржај" + +msgid "Launch" +msgstr "Лансирање" + +msgid "Theme by the" +msgstr "Тхеме би" + +msgid "Open an issue" +msgstr "Отворите издање" + +msgid "open issue" +msgstr "отворено издање" + +msgid "suggest edit" +msgstr "предложи уређивање" + +msgid "Edit this page" +msgstr "Уредите ову страницу" + +msgid "previous page" +msgstr "Претходна страница" diff --git a/_static/locales/sv/LC_MESSAGES/booktheme.po b/_static/locales/sv/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..a6090e3e72 --- /dev/null +++ b/_static/locales/sv/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: sv\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Ladda ner notebook-fil" + +msgid "Fullscreen mode" +msgstr "Fullskärmsläge" + +msgid "Source repository" +msgstr "Källkodsrepositorium" + +msgid "Print to PDF" +msgstr "Skriv ut till PDF" + +msgid "Copyright" +msgstr "Upphovsrätt" + +msgid "Sphinx Book Theme" +msgstr "Sphinx Boktema" + +msgid "By the" +msgstr "Av den" + +msgid "Download this page" +msgstr "Ladda ner den här sidan" + +msgid "repository" +msgstr "repositorium" + +msgid "Download source file" +msgstr "Ladda ner källfil" + +msgid "By" +msgstr "Av" + +msgid "Toggle navigation" +msgstr "Växla navigering" + +msgid "next page" +msgstr "nästa sida" + +msgid "Last updated on" +msgstr "Senast uppdaterad den" + +msgid "Contents" +msgstr "Innehåll" + +msgid "Launch" +msgstr "Öppna" + +msgid "Theme by the" +msgstr "Tema av" + +msgid "Open an issue" +msgstr "Öppna en problemrapport" + +msgid "open issue" +msgstr "öppna problemrapport" + +msgid "suggest edit" +msgstr "föreslå ändring" + +msgid "Edit this page" +msgstr "Redigera den här sidan" + +msgid "previous page" +msgstr "föregående sida" diff --git a/_static/locales/ta/LC_MESSAGES/booktheme.po b/_static/locales/ta/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..93eee27d80 --- /dev/null +++ b/_static/locales/ta/LC_MESSAGES/booktheme.po @@ -0,0 +1,66 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: ta\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "நோட்புக் கோப்பைப் பதிவிறக்கவும்" + +msgid "Source repository" +msgstr "மூல களஞ்சியம்" + +msgid "Print to PDF" +msgstr "PDF இல் அச்சிடுக" + +msgid "Copyright" +msgstr "பதிப்புரிமை" + +msgid "Sphinx Book Theme" +msgstr "ஸ்பிங்க்ஸ் புத்தக தீம்" + +msgid "By the" +msgstr "மூலம்" + +msgid "Download this page" +msgstr "இந்தப் பக்கத்தைப் பதிவிறக்கவும்" + +msgid "Download source file" +msgstr "மூல கோப்பைப் பதிவிறக்குக" + +msgid "By" +msgstr "வழங்கியவர்" + +msgid "Toggle navigation" +msgstr "வழிசெலுத்தலை நிலைமாற்று" + +msgid "next page" +msgstr "அடுத்த பக்கம்" + +msgid "Last updated on" +msgstr "கடைசியாக புதுப்பிக்கப்பட்டது" + +msgid "Launch" +msgstr "தொடங்க" + +msgid "Theme by the" +msgstr "வழங்கிய தீம்" + +msgid "Open an issue" +msgstr "சிக்கலைத் திறக்கவும்" + +msgid "open issue" +msgstr "திறந்த பிரச்சினை" + +msgid "suggest edit" +msgstr "திருத்த பரிந்துரைக்கவும்" + +msgid "Edit this page" +msgstr "இந்தப் பக்கத்தைத் திருத்தவும்" + +msgid "previous page" +msgstr "முந்தைய பக்கம்" diff --git a/_static/locales/te/LC_MESSAGES/booktheme.po b/_static/locales/te/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..f60892cfda --- /dev/null +++ b/_static/locales/te/LC_MESSAGES/booktheme.po @@ -0,0 +1,66 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: te\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "నోట్బుక్ ఫైల్ను డౌన్లోడ్ చేయండి" + +msgid "Source repository" +msgstr "మూల రిపోజిటరీ" + +msgid "Print to PDF" +msgstr "PDF కి ముద్రించండి" + +msgid "Copyright" +msgstr "కాపీరైట్" + +msgid "Sphinx Book Theme" +msgstr "సింహిక పుస్తక థీమ్" + +msgid "By the" +msgstr "ద్వారా" + +msgid "Download this page" +msgstr "ఈ పేజీని డౌన్‌లోడ్ చేయండి" + +msgid "Download source file" +msgstr "మూల ఫైల్‌ను డౌన్‌లోడ్ చేయండి" + +msgid "By" +msgstr "ద్వారా" + +msgid "Toggle navigation" +msgstr "నావిగేషన్‌ను టోగుల్ చేయండి" + +msgid "next page" +msgstr "తరువాతి పేజీ" + +msgid "Last updated on" +msgstr "చివరిగా నవీకరించబడింది" + +msgid "Launch" +msgstr "ప్రారంభించండి" + +msgid "Theme by the" +msgstr "ద్వారా థీమ్" + +msgid "Open an issue" +msgstr "సమస్యను తెరవండి" + +msgid "open issue" +msgstr "ఓపెన్ ఇష్యూ" + +msgid "suggest edit" +msgstr "సవరించమని సూచించండి" + +msgid "Edit this page" +msgstr "ఈ పేజీని సవరించండి" + +msgid "previous page" +msgstr "ముందు పేజి" diff --git a/_static/locales/tg/LC_MESSAGES/booktheme.po b/_static/locales/tg/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..a9daf7d4a3 --- /dev/null +++ b/_static/locales/tg/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: tg\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Файли дафтарро зеркашӣ кунед" + +msgid "Fullscreen mode" +msgstr "Ҳолати экрани пурра" + +msgid "Source repository" +msgstr "Анбори манбаъ" + +msgid "Print to PDF" +msgstr "Чоп ба PDF" + +msgid "Copyright" +msgstr "Ҳуқуқи муаллиф" + +msgid "Sphinx Book Theme" +msgstr "Сфинкс Мавзӯи китоб" + +msgid "By the" +msgstr "Бо" + +msgid "Download this page" +msgstr "Ин саҳифаро зеркашӣ кунед" + +msgid "repository" +msgstr "анбор" + +msgid "Download source file" +msgstr "Файли манбаъро зеркашӣ кунед" + +msgid "By" +msgstr "Бо" + +msgid "Toggle navigation" +msgstr "Гузаришро иваз кунед" + +msgid "next page" +msgstr "саҳифаи оянда" + +msgid "Last updated on" +msgstr "Last навсозӣ дар" + +msgid "Contents" +msgstr "Мундариҷа" + +msgid "Launch" +msgstr "Оғоз" + +msgid "Theme by the" +msgstr "Мавзӯъи аз" + +msgid "Open an issue" +msgstr "Масъаларо кушоед" + +msgid "open issue" +msgstr "барориши кушод" + +msgid "suggest edit" +msgstr "пешниҳод вироиш" + +msgid "Edit this page" +msgstr "Ин саҳифаро таҳрир кунед" + +msgid "previous page" +msgstr "саҳифаи қаблӣ" diff --git a/_static/locales/th/LC_MESSAGES/booktheme.po b/_static/locales/th/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..2a5764930b --- /dev/null +++ b/_static/locales/th/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: th\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "ดาวน์โหลดไฟล์สมุดบันทึก" + +msgid "Fullscreen mode" +msgstr "โหมดเต็มหน้าจอ" + +msgid "Source repository" +msgstr "ที่เก็บซอร์ส" + +msgid "Print to PDF" +msgstr "พิมพ์เป็น PDF" + +msgid "Copyright" +msgstr "ลิขสิทธิ์" + +msgid "Sphinx Book Theme" +msgstr "ธีมหนังสือสฟิงซ์" + +msgid "By the" +msgstr "โดย" + +msgid "Download this page" +msgstr "ดาวน์โหลดหน้านี้" + +msgid "repository" +msgstr "ที่เก็บ" + +msgid "Download source file" +msgstr "ดาวน์โหลดไฟล์ต้นฉบับ" + +msgid "By" +msgstr "โดย" + +msgid "Toggle navigation" +msgstr "ไม่ต้องสลับช่องทาง" + +msgid "next page" +msgstr "หน้าต่อไป" + +msgid "Last updated on" +msgstr "ปรับปรุงล่าสุดเมื่อ" + +msgid "Contents" +msgstr "สารบัญ" + +msgid "Launch" +msgstr "เปิด" + +msgid "Theme by the" +msgstr "ธีมโดย" + +msgid "Open an issue" +msgstr "เปิดปัญหา" + +msgid "open issue" +msgstr "เปิดปัญหา" + +msgid "suggest edit" +msgstr "แนะนำแก้ไข" + +msgid "Edit this page" +msgstr "แก้ไขหน้านี้" + +msgid "previous page" +msgstr "หน้าที่แล้ว" diff --git a/_static/locales/tl/LC_MESSAGES/booktheme.po b/_static/locales/tl/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..bb548de9e9 --- /dev/null +++ b/_static/locales/tl/LC_MESSAGES/booktheme.po @@ -0,0 +1,66 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: tl\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Mag-download ng file ng notebook" + +msgid "Source repository" +msgstr "Pinagmulan ng imbakan" + +msgid "Print to PDF" +msgstr "I-print sa PDF" + +msgid "Copyright" +msgstr "Copyright" + +msgid "Sphinx Book Theme" +msgstr "Tema ng Sphinx Book" + +msgid "By the" +msgstr "Sa pamamagitan ng" + +msgid "Download this page" +msgstr "I-download ang pahinang ito" + +msgid "Download source file" +msgstr "Mag-download ng file ng pinagmulan" + +msgid "By" +msgstr "Ni" + +msgid "Toggle navigation" +msgstr "I-toggle ang pag-navigate" + +msgid "next page" +msgstr "Susunod na pahina" + +msgid "Last updated on" +msgstr "Huling na-update noong" + +msgid "Launch" +msgstr "Ilunsad" + +msgid "Theme by the" +msgstr "Tema ng" + +msgid "Open an issue" +msgstr "Magbukas ng isyu" + +msgid "open issue" +msgstr "bukas na isyu" + +msgid "suggest edit" +msgstr "iminumungkahi i-edit" + +msgid "Edit this page" +msgstr "I-edit ang pahinang ito" + +msgid "previous page" +msgstr "Nakaraang pahina" diff --git a/_static/locales/tr/LC_MESSAGES/booktheme.po b/_static/locales/tr/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..4f77a8898a --- /dev/null +++ b/_static/locales/tr/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: tr\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Defter dosyasını indirin" + +msgid "Fullscreen mode" +msgstr "Tam ekran modu" + +msgid "Source repository" +msgstr "Kaynak kod deposu" + +msgid "Print to PDF" +msgstr "PDF olarak yazdır" + +msgid "Copyright" +msgstr "Telif hakkı" + +msgid "Sphinx Book Theme" +msgstr "Sfenks Kitap Teması" + +msgid "By the" +msgstr "Tarafından" + +msgid "Download this page" +msgstr "Bu sayfayı indirin" + +msgid "repository" +msgstr "depo" + +msgid "Download source file" +msgstr "Kaynak dosyayı indirin" + +msgid "By" +msgstr "Tarafından" + +msgid "Toggle navigation" +msgstr "Gezinmeyi değiştir" + +msgid "next page" +msgstr "sonraki Sayfa" + +msgid "Last updated on" +msgstr "Son güncelleme tarihi" + +msgid "Contents" +msgstr "İçindekiler" + +msgid "Launch" +msgstr "Başlatmak" + +msgid "Theme by the" +msgstr "Tarafından tema" + +msgid "Open an issue" +msgstr "Bir sorunu açın" + +msgid "open issue" +msgstr "Açık konu" + +msgid "suggest edit" +msgstr "düzenleme öner" + +msgid "Edit this page" +msgstr "Bu sayfayı düzenle" + +msgid "previous page" +msgstr "önceki sayfa" diff --git a/_static/locales/uk/LC_MESSAGES/booktheme.po b/_static/locales/uk/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..6cf45508e7 --- /dev/null +++ b/_static/locales/uk/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: uk\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Завантажте файл блокнота" + +msgid "Fullscreen mode" +msgstr "Повноекранний режим" + +msgid "Source repository" +msgstr "Джерело сховища" + +msgid "Print to PDF" +msgstr "Друк у форматі PDF" + +msgid "Copyright" +msgstr "Авторське право" + +msgid "Sphinx Book Theme" +msgstr "Тема книги \"Сфінкс\"" + +msgid "By the" +msgstr "По" + +msgid "Download this page" +msgstr "Завантажте цю сторінку" + +msgid "repository" +msgstr "сховище" + +msgid "Download source file" +msgstr "Завантажити вихідний файл" + +msgid "By" +msgstr "Автор" + +msgid "Toggle navigation" +msgstr "Переключити навігацію" + +msgid "next page" +msgstr "Наступна сторінка" + +msgid "Last updated on" +msgstr "Останнє оновлення:" + +msgid "Contents" +msgstr "Зміст" + +msgid "Launch" +msgstr "Запуск" + +msgid "Theme by the" +msgstr "Тема від" + +msgid "Open an issue" +msgstr "Відкрийте випуск" + +msgid "open issue" +msgstr "відкритий випуск" + +msgid "suggest edit" +msgstr "запропонувати редагувати" + +msgid "Edit this page" +msgstr "Редагувати цю сторінку" + +msgid "previous page" +msgstr "Попередня сторінка" diff --git a/_static/locales/ur/LC_MESSAGES/booktheme.po b/_static/locales/ur/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..7d5738f400 --- /dev/null +++ b/_static/locales/ur/LC_MESSAGES/booktheme.po @@ -0,0 +1,66 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: ur\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "نوٹ بک فائل ڈاؤن لوڈ کریں" + +msgid "Source repository" +msgstr "ماخذ ذخیرہ" + +msgid "Print to PDF" +msgstr "پی ڈی ایف پرنٹ کریں" + +msgid "Copyright" +msgstr "کاپی رائٹ" + +msgid "Sphinx Book Theme" +msgstr "سپنکس بک تھیم" + +msgid "By the" +msgstr "کی طرف" + +msgid "Download this page" +msgstr "اس صفحے کو ڈاؤن لوڈ کریں" + +msgid "Download source file" +msgstr "سورس فائل ڈاؤن لوڈ کریں" + +msgid "By" +msgstr "بذریعہ" + +msgid "Toggle navigation" +msgstr "نیویگیشن ٹوگل کریں" + +msgid "next page" +msgstr "اگلا صفحہ" + +msgid "Last updated on" +msgstr "آخری بار تازہ کاری ہوئی" + +msgid "Launch" +msgstr "لانچ کریں" + +msgid "Theme by the" +msgstr "کے ذریعہ تھیم" + +msgid "Open an issue" +msgstr "ایک مسئلہ کھولیں" + +msgid "open issue" +msgstr "کھلا مسئلہ" + +msgid "suggest edit" +msgstr "ترمیم کی تجویز کریں" + +msgid "Edit this page" +msgstr "اس صفحے میں ترمیم کریں" + +msgid "previous page" +msgstr "سابقہ ​​صفحہ" diff --git a/_static/locales/vi/LC_MESSAGES/booktheme.po b/_static/locales/vi/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..e6c090a4e4 --- /dev/null +++ b/_static/locales/vi/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: vi\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "Tải xuống tệp sổ tay" + +msgid "Fullscreen mode" +msgstr "Chế độ toàn màn hình" + +msgid "Source repository" +msgstr "Kho nguồn" + +msgid "Print to PDF" +msgstr "In sang PDF" + +msgid "Copyright" +msgstr "Bản quyền" + +msgid "Sphinx Book Theme" +msgstr "Chủ đề sách nhân sư" + +msgid "By the" +msgstr "Bằng" + +msgid "Download this page" +msgstr "Tải xuống trang này" + +msgid "repository" +msgstr "kho" + +msgid "Download source file" +msgstr "Tải xuống tệp nguồn" + +msgid "By" +msgstr "Bởi" + +msgid "Toggle navigation" +msgstr "Chuyển đổi điều hướng thành" + +msgid "next page" +msgstr "Trang tiếp theo" + +msgid "Last updated on" +msgstr "Cập nhật lần cuối vào" + +msgid "Contents" +msgstr "Nội dung" + +msgid "Launch" +msgstr "Phóng" + +msgid "Theme by the" +msgstr "Chủ đề của" + +msgid "Open an issue" +msgstr "Mở một vấn đề" + +msgid "open issue" +msgstr "vấn đề mở" + +msgid "suggest edit" +msgstr "đề nghị chỉnh sửa" + +msgid "Edit this page" +msgstr "chỉnh sửa trang này" + +msgid "previous page" +msgstr "trang trước" diff --git a/_static/locales/zh_CN/LC_MESSAGES/booktheme.po b/_static/locales/zh_CN/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..93ddbd3556 --- /dev/null +++ b/_static/locales/zh_CN/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: zh_CN\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "下载笔记本文件" + +msgid "Fullscreen mode" +msgstr "全屏模式" + +msgid "Source repository" +msgstr "源码库" + +msgid "Print to PDF" +msgstr "列印成 PDF" + +msgid "Copyright" +msgstr "版权" + +msgid "Sphinx Book Theme" +msgstr "Sphinx Book 主题" + +msgid "By the" +msgstr "作者:" + +msgid "Download this page" +msgstr "下载此页面" + +msgid "repository" +msgstr "仓库" + +msgid "Download source file" +msgstr "下载源文件" + +msgid "By" +msgstr "作者:" + +msgid "Toggle navigation" +msgstr "显示或隐藏导航栏" + +msgid "next page" +msgstr "下一页" + +msgid "Last updated on" +msgstr "上次更新时间:" + +msgid "Contents" +msgstr "目录" + +msgid "Launch" +msgstr "启动" + +msgid "Theme by the" +msgstr "主题作者:" + +msgid "Open an issue" +msgstr "创建议题" + +msgid "open issue" +msgstr "创建议题" + +msgid "suggest edit" +msgstr "提出修改建议" + +msgid "Edit this page" +msgstr "编辑此页面" + +msgid "previous page" +msgstr "上一页" diff --git a/_static/locales/zh_TW/LC_MESSAGES/booktheme.po b/_static/locales/zh_TW/LC_MESSAGES/booktheme.po new file mode 100644 index 0000000000..dc7537b391 --- /dev/null +++ b/_static/locales/zh_TW/LC_MESSAGES/booktheme.po @@ -0,0 +1,75 @@ + +msgid "" +msgstr "" +"Project-Id-Version: Sphinx-Book-Theme\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: zh_TW\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +msgid "Download notebook file" +msgstr "下載 Notebook 檔案" + +msgid "Fullscreen mode" +msgstr "全螢幕模式" + +msgid "Source repository" +msgstr "來源儲存庫" + +msgid "Print to PDF" +msgstr "列印成 PDF" + +msgid "Copyright" +msgstr "Copyright" + +msgid "Sphinx Book Theme" +msgstr "Sphinx Book 佈景主題" + +msgid "By the" +msgstr "作者:" + +msgid "Download this page" +msgstr "下載此頁面" + +msgid "repository" +msgstr "儲存庫" + +msgid "Download source file" +msgstr "下載原始檔" + +msgid "By" +msgstr "作者:" + +msgid "Toggle navigation" +msgstr "顯示或隱藏導覽列" + +msgid "next page" +msgstr "下一頁" + +msgid "Last updated on" +msgstr "最後更新時間:" + +msgid "Contents" +msgstr "目錄" + +msgid "Launch" +msgstr "啟動" + +msgid "Theme by the" +msgstr "佈景主題作者:" + +msgid "Open an issue" +msgstr "開啟議題" + +msgid "open issue" +msgstr "公開的問題" + +msgid "suggest edit" +msgstr "提出修改建議" + +msgid "Edit this page" +msgstr "編輯此頁面" + +msgid "previous page" +msgstr "上一頁" diff --git a/_static/minus.png b/_static/minus.png new file mode 100644 index 0000000000000000000000000000000000000000..d96755fdaf8bb2214971e0db9c1fd3077d7c419d GIT binary patch literal 90 zcmeAS@N?(olHy`uVBq!ia0vp^+#t*WBp7;*Yy1LIik>cxAr*|t7R?Mi>2?kWtu=nj kDsEF_5m^0CR;1wuP-*O&G^0G}KYk!hp00i_>zopr08q^qX#fBK literal 0 HcmV?d00001 diff --git a/_static/oneAPI-rgb-rev-100.png b/_static/oneAPI-rgb-rev-100.png new file mode 100644 index 0000000000000000000000000000000000000000..58d2d5c54e586b53d027d39236038dc60f5fea94 GIT binary patch literal 7414 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 literal 0 HcmV?d00001 diff --git a/_static/plus.png b/_static/plus.png new file mode 100644 index 0000000000000000000000000000000000000000..7107cec93a979b9a5f64843235a16651d563ce2d GIT binary patch literal 90 zcmeAS@N?(olHy`uVBq!ia0vp^+#t*WBp7;*Yy1LIik>cxAr*|t7R?Mi>2?kWtu>-2 m3q%Vub%g%s<8sJhVPMczOq}xhg9DJoz~JfX=d#Wzp$Pyb1r*Kz literal 0 HcmV?d00001 diff --git a/_static/pygments.css b/_static/pygments.css new file mode 100644 index 0000000000..012e6a00a4 --- /dev/null +++ b/_static/pygments.css @@ -0,0 +1,152 @@ +html[data-theme="light"] .highlight pre { line-height: 125%; } +html[data-theme="light"] .highlight td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } +html[data-theme="light"] .highlight span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } +html[data-theme="light"] .highlight td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +html[data-theme="light"] .highlight span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +html[data-theme="light"] .highlight .hll { background-color: #fae4c2 } +html[data-theme="light"] .highlight { background: #fefefe; color: #080808 } +html[data-theme="light"] .highlight .c { color: #515151 } /* Comment */ +html[data-theme="light"] .highlight .err { color: #a12236 } /* Error */ +html[data-theme="light"] .highlight .k { color: #6730c5 } /* Keyword */ +html[data-theme="light"] .highlight .l { color: #7f4707 } /* Literal */ +html[data-theme="light"] .highlight .n { color: #080808 } /* Name */ +html[data-theme="light"] .highlight .o { color: #00622f } /* Operator */ +html[data-theme="light"] .highlight .p { color: #080808 } /* Punctuation */ +html[data-theme="light"] .highlight .ch { color: #515151 } /* Comment.Hashbang */ +html[data-theme="light"] .highlight .cm { color: #515151 } /* Comment.Multiline */ +html[data-theme="light"] .highlight .cp { color: #515151 } /* Comment.Preproc */ +html[data-theme="light"] .highlight .cpf { color: #515151 } /* Comment.PreprocFile */ +html[data-theme="light"] .highlight .c1 { color: #515151 } /* Comment.Single */ +html[data-theme="light"] .highlight .cs { color: #515151 } /* Comment.Special */ +html[data-theme="light"] .highlight .gd { color: #005b82 } /* Generic.Deleted */ +html[data-theme="light"] .highlight .ge { font-style: italic } /* Generic.Emph */ +html[data-theme="light"] .highlight .gh { color: #005b82 } /* Generic.Heading */ +html[data-theme="light"] .highlight .gs { font-weight: bold } /* Generic.Strong */ +html[data-theme="light"] .highlight .gu { color: #005b82 } /* Generic.Subheading */ +html[data-theme="light"] .highlight .kc { color: #6730c5 } /* Keyword.Constant */ +html[data-theme="light"] .highlight .kd { color: #6730c5 } /* Keyword.Declaration */ +html[data-theme="light"] .highlight .kn { color: #6730c5 } /* Keyword.Namespace */ +html[data-theme="light"] .highlight .kp { color: #6730c5 } /* Keyword.Pseudo */ +html[data-theme="light"] .highlight .kr { color: #6730c5 } /* Keyword.Reserved */ +html[data-theme="light"] .highlight .kt { color: #7f4707 } /* Keyword.Type */ +html[data-theme="light"] .highlight .ld { color: #7f4707 } /* Literal.Date */ +html[data-theme="light"] .highlight .m { color: #7f4707 } /* Literal.Number */ +html[data-theme="light"] .highlight .s { color: #00622f } /* Literal.String */ +html[data-theme="light"] .highlight .na { color: #912583 } /* Name.Attribute */ +html[data-theme="light"] .highlight .nb { color: #7f4707 } /* Name.Builtin */ +html[data-theme="light"] .highlight .nc { color: #005b82 } /* Name.Class */ +html[data-theme="light"] .highlight .no { color: #005b82 } /* Name.Constant */ +html[data-theme="light"] .highlight .nd { color: #7f4707 } /* Name.Decorator */ +html[data-theme="light"] .highlight .ni { color: #00622f } /* Name.Entity */ +html[data-theme="light"] .highlight .ne { color: #6730c5 } /* Name.Exception */ +html[data-theme="light"] .highlight .nf { color: #005b82 } /* Name.Function */ +html[data-theme="light"] .highlight .nl { color: #7f4707 } /* Name.Label */ +html[data-theme="light"] .highlight .nn { color: #080808 } /* Name.Namespace */ +html[data-theme="light"] .highlight .nx { color: #080808 } /* Name.Other */ +html[data-theme="light"] .highlight .py { color: #005b82 } /* Name.Property */ +html[data-theme="light"] .highlight .nt { color: #005b82 } /* Name.Tag */ +html[data-theme="light"] .highlight .nv { color: #a12236 } /* Name.Variable */ +html[data-theme="light"] .highlight .ow { color: #6730c5 } /* Operator.Word */ +html[data-theme="light"] .highlight .pm { color: #080808 } /* Punctuation.Marker */ +html[data-theme="light"] .highlight .w { color: #080808 } /* Text.Whitespace */ +html[data-theme="light"] .highlight .mb { color: #7f4707 } /* Literal.Number.Bin */ +html[data-theme="light"] .highlight .mf { color: #7f4707 } /* Literal.Number.Float */ +html[data-theme="light"] .highlight .mh { color: #7f4707 } /* Literal.Number.Hex */ +html[data-theme="light"] .highlight .mi { color: #7f4707 } /* Literal.Number.Integer */ +html[data-theme="light"] .highlight .mo { color: #7f4707 } /* Literal.Number.Oct */ +html[data-theme="light"] .highlight .sa { color: #00622f } /* Literal.String.Affix */ +html[data-theme="light"] .highlight .sb { color: #00622f } /* Literal.String.Backtick */ +html[data-theme="light"] .highlight .sc { color: #00622f } /* Literal.String.Char */ +html[data-theme="light"] .highlight .dl { color: #00622f } /* Literal.String.Delimiter */ +html[data-theme="light"] .highlight .sd { color: #00622f } /* Literal.String.Doc */ +html[data-theme="light"] .highlight .s2 { color: #00622f } /* Literal.String.Double */ +html[data-theme="light"] .highlight .se { color: #00622f } /* Literal.String.Escape */ +html[data-theme="light"] .highlight .sh { color: #00622f } /* Literal.String.Heredoc */ +html[data-theme="light"] .highlight .si { color: #00622f } /* Literal.String.Interpol */ +html[data-theme="light"] .highlight .sx { color: #00622f } /* Literal.String.Other */ +html[data-theme="light"] .highlight .sr { color: #a12236 } /* Literal.String.Regex */ +html[data-theme="light"] .highlight .s1 { color: #00622f } /* Literal.String.Single */ +html[data-theme="light"] .highlight .ss { color: #005b82 } /* Literal.String.Symbol */ +html[data-theme="light"] .highlight .bp { color: #7f4707 } /* Name.Builtin.Pseudo */ +html[data-theme="light"] .highlight .fm { color: #005b82 } /* Name.Function.Magic */ +html[data-theme="light"] .highlight .vc { color: #a12236 } /* Name.Variable.Class */ +html[data-theme="light"] .highlight .vg { color: #a12236 } /* Name.Variable.Global */ +html[data-theme="light"] .highlight .vi { color: #a12236 } /* Name.Variable.Instance */ +html[data-theme="light"] .highlight .vm { color: #7f4707 } /* Name.Variable.Magic */ +html[data-theme="light"] .highlight .il { color: #7f4707 } /* Literal.Number.Integer.Long */ +html[data-theme="dark"] .highlight pre { line-height: 125%; } +html[data-theme="dark"] .highlight td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } +html[data-theme="dark"] .highlight span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } +html[data-theme="dark"] .highlight td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +html[data-theme="dark"] .highlight span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +html[data-theme="dark"] .highlight .hll { background-color: #ffd9002e } +html[data-theme="dark"] .highlight { background: #2b2b2b; color: #f8f8f2 } +html[data-theme="dark"] .highlight .c { color: #ffd900 } /* Comment */ +html[data-theme="dark"] .highlight .err { color: #ffa07a } /* Error */ +html[data-theme="dark"] .highlight .k { color: #dcc6e0 } /* Keyword */ +html[data-theme="dark"] .highlight .l { color: #ffd900 } /* Literal */ +html[data-theme="dark"] .highlight .n { color: #f8f8f2 } /* Name */ +html[data-theme="dark"] .highlight .o { color: #abe338 } /* Operator */ +html[data-theme="dark"] .highlight .p { color: #f8f8f2 } /* Punctuation */ +html[data-theme="dark"] .highlight .ch { color: #ffd900 } /* Comment.Hashbang */ +html[data-theme="dark"] .highlight .cm { color: #ffd900 } /* Comment.Multiline */ +html[data-theme="dark"] .highlight .cp { color: #ffd900 } /* Comment.Preproc */ +html[data-theme="dark"] .highlight .cpf { color: #ffd900 } /* Comment.PreprocFile */ +html[data-theme="dark"] .highlight .c1 { color: #ffd900 } /* Comment.Single */ +html[data-theme="dark"] .highlight .cs { color: #ffd900 } /* Comment.Special */ +html[data-theme="dark"] .highlight .gd { color: #00e0e0 } /* Generic.Deleted */ +html[data-theme="dark"] .highlight .ge { font-style: italic } /* Generic.Emph */ +html[data-theme="dark"] .highlight .gh { color: #00e0e0 } /* Generic.Heading */ +html[data-theme="dark"] .highlight .gs { font-weight: bold } /* Generic.Strong */ +html[data-theme="dark"] .highlight .gu { color: #00e0e0 } /* Generic.Subheading */ +html[data-theme="dark"] .highlight .kc { color: #dcc6e0 } /* Keyword.Constant */ +html[data-theme="dark"] .highlight .kd { color: #dcc6e0 } /* Keyword.Declaration */ +html[data-theme="dark"] .highlight .kn { color: #dcc6e0 } /* Keyword.Namespace */ +html[data-theme="dark"] .highlight .kp { color: #dcc6e0 } /* Keyword.Pseudo */ +html[data-theme="dark"] .highlight .kr { color: #dcc6e0 } /* Keyword.Reserved */ +html[data-theme="dark"] .highlight .kt { color: #ffd900 } /* Keyword.Type */ +html[data-theme="dark"] .highlight .ld { color: #ffd900 } /* Literal.Date */ +html[data-theme="dark"] .highlight .m { color: #ffd900 } /* Literal.Number */ +html[data-theme="dark"] .highlight .s { color: #abe338 } /* Literal.String */ +html[data-theme="dark"] .highlight .na { color: #ffd900 } /* Name.Attribute */ +html[data-theme="dark"] .highlight .nb { color: #ffd900 } /* Name.Builtin */ +html[data-theme="dark"] .highlight .nc { color: #00e0e0 } /* Name.Class */ +html[data-theme="dark"] .highlight .no { color: #00e0e0 } /* Name.Constant */ +html[data-theme="dark"] .highlight .nd { color: #ffd900 } /* Name.Decorator */ +html[data-theme="dark"] .highlight .ni { color: #abe338 } /* Name.Entity */ +html[data-theme="dark"] .highlight .ne { color: #dcc6e0 } /* Name.Exception */ +html[data-theme="dark"] .highlight .nf { color: #00e0e0 } /* Name.Function */ +html[data-theme="dark"] .highlight .nl { color: #ffd900 } /* Name.Label */ +html[data-theme="dark"] .highlight .nn { color: #f8f8f2 } /* Name.Namespace */ +html[data-theme="dark"] .highlight .nx { color: #f8f8f2 } /* Name.Other */ +html[data-theme="dark"] .highlight .py { color: #00e0e0 } /* Name.Property */ +html[data-theme="dark"] .highlight .nt { color: #00e0e0 } /* Name.Tag */ +html[data-theme="dark"] .highlight .nv { color: #ffa07a } /* Name.Variable */ +html[data-theme="dark"] .highlight .ow { color: #dcc6e0 } /* Operator.Word */ +html[data-theme="dark"] .highlight .pm { color: #f8f8f2 } /* Punctuation.Marker */ +html[data-theme="dark"] .highlight .w { color: #f8f8f2 } /* Text.Whitespace */ +html[data-theme="dark"] .highlight .mb { color: #ffd900 } /* Literal.Number.Bin */ +html[data-theme="dark"] .highlight .mf { color: #ffd900 } /* Literal.Number.Float */ +html[data-theme="dark"] .highlight .mh { color: #ffd900 } /* Literal.Number.Hex */ +html[data-theme="dark"] .highlight .mi { color: #ffd900 } /* Literal.Number.Integer */ +html[data-theme="dark"] .highlight .mo { color: #ffd900 } /* Literal.Number.Oct */ +html[data-theme="dark"] .highlight .sa { color: #abe338 } /* Literal.String.Affix */ +html[data-theme="dark"] .highlight .sb { color: #abe338 } /* Literal.String.Backtick */ +html[data-theme="dark"] .highlight .sc { color: #abe338 } /* Literal.String.Char */ +html[data-theme="dark"] .highlight .dl { color: #abe338 } /* Literal.String.Delimiter */ +html[data-theme="dark"] .highlight .sd { color: #abe338 } /* Literal.String.Doc */ +html[data-theme="dark"] .highlight .s2 { color: #abe338 } /* Literal.String.Double */ +html[data-theme="dark"] .highlight .se { color: #abe338 } /* Literal.String.Escape */ +html[data-theme="dark"] .highlight .sh { color: #abe338 } /* Literal.String.Heredoc */ +html[data-theme="dark"] .highlight .si { color: #abe338 } /* Literal.String.Interpol */ +html[data-theme="dark"] .highlight .sx { color: #abe338 } /* Literal.String.Other */ +html[data-theme="dark"] .highlight .sr { color: #ffa07a } /* Literal.String.Regex */ +html[data-theme="dark"] .highlight .s1 { color: #abe338 } /* Literal.String.Single */ +html[data-theme="dark"] .highlight .ss { color: #00e0e0 } /* Literal.String.Symbol */ +html[data-theme="dark"] .highlight .bp { color: #ffd900 } /* Name.Builtin.Pseudo */ +html[data-theme="dark"] .highlight .fm { color: #00e0e0 } /* Name.Function.Magic */ +html[data-theme="dark"] .highlight .vc { color: #ffa07a } /* Name.Variable.Class */ +html[data-theme="dark"] .highlight .vg { color: #ffa07a } /* Name.Variable.Global */ +html[data-theme="dark"] .highlight .vi { color: #ffa07a } /* Name.Variable.Instance */ +html[data-theme="dark"] .highlight .vm { color: #ffd900 } /* Name.Variable.Magic */ +html[data-theme="dark"] .highlight .il { color: #ffd900 } /* Literal.Number.Integer.Long */ \ No newline at end of file diff --git a/_static/sbt-webpack-macros.html b/_static/sbt-webpack-macros.html new file mode 100644 index 0000000000..6cbf559faa --- /dev/null +++ b/_static/sbt-webpack-macros.html @@ -0,0 +1,11 @@ + +{% macro head_pre_bootstrap() %} + +{% endmacro %} + +{% macro body_post() %} + +{% endmacro %} diff --git a/_static/scripts/bootstrap.js b/_static/scripts/bootstrap.js new file mode 100644 index 0000000000..c8178debbc --- /dev/null +++ b/_static/scripts/bootstrap.js @@ -0,0 +1,3 @@ +/*! For license information please see bootstrap.js.LICENSE.txt */ +(()=>{"use strict";var t={d:(e,i)=>{for(var n in i)t.o(i,n)&&!t.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:i[n]})},o:(t,e)=>Object.prototype.hasOwnProperty.call(t,e),r:t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})}},e={};t.r(e),t.d(e,{afterMain:()=>E,afterRead:()=>v,afterWrite:()=>C,applyStyles:()=>$,arrow:()=>J,auto:()=>a,basePlacements:()=>l,beforeMain:()=>y,beforeRead:()=>_,beforeWrite:()=>A,bottom:()=>s,clippingParents:()=>d,computeStyles:()=>it,createPopper:()=>Dt,createPopperBase:()=>St,createPopperLite:()=>$t,detectOverflow:()=>_t,end:()=>h,eventListeners:()=>st,flip:()=>bt,hide:()=>wt,left:()=>r,main:()=>w,modifierPhases:()=>O,offset:()=>Et,placements:()=>g,popper:()=>f,popperGenerator:()=>Lt,popperOffsets:()=>At,preventOverflow:()=>Tt,read:()=>b,reference:()=>p,right:()=>o,start:()=>c,top:()=>n,variationPlacements:()=>m,viewport:()=>u,write:()=>T});var i={};t.r(i),t.d(i,{Alert:()=>Oe,Button:()=>ke,Carousel:()=>li,Collapse:()=>Ei,Dropdown:()=>Ki,Modal:()=>Ln,Offcanvas:()=>Kn,Popover:()=>bs,ScrollSpy:()=>Ls,Tab:()=>Js,Toast:()=>po,Tooltip:()=>fs});var n="top",s="bottom",o="right",r="left",a="auto",l=[n,s,o,r],c="start",h="end",d="clippingParents",u="viewport",f="popper",p="reference",m=l.reduce((function(t,e){return t.concat([e+"-"+c,e+"-"+h])}),[]),g=[].concat(l,[a]).reduce((function(t,e){return t.concat([e,e+"-"+c,e+"-"+h])}),[]),_="beforeRead",b="read",v="afterRead",y="beforeMain",w="main",E="afterMain",A="beforeWrite",T="write",C="afterWrite",O=[_,b,v,y,w,E,A,T,C];function x(t){return t?(t.nodeName||"").toLowerCase():null}function k(t){if(null==t)return window;if("[object Window]"!==t.toString()){var e=t.ownerDocument;return e&&e.defaultView||window}return t}function L(t){return t instanceof k(t).Element||t instanceof Element}function S(t){return t instanceof k(t).HTMLElement||t instanceof HTMLElement}function D(t){return"undefined"!=typeof ShadowRoot&&(t instanceof k(t).ShadowRoot||t instanceof ShadowRoot)}const $={name:"applyStyles",enabled:!0,phase:"write",fn:function(t){var e=t.state;Object.keys(e.elements).forEach((function(t){var i=e.styles[t]||{},n=e.attributes[t]||{},s=e.elements[t];S(s)&&x(s)&&(Object.assign(s.style,i),Object.keys(n).forEach((function(t){var e=n[t];!1===e?s.removeAttribute(t):s.setAttribute(t,!0===e?"":e)})))}))},effect:function(t){var e=t.state,i={popper:{position:e.options.strategy,left:"0",top:"0",margin:"0"},arrow:{position:"absolute"},reference:{}};return Object.assign(e.elements.popper.style,i.popper),e.styles=i,e.elements.arrow&&Object.assign(e.elements.arrow.style,i.arrow),function(){Object.keys(e.elements).forEach((function(t){var n=e.elements[t],s=e.attributes[t]||{},o=Object.keys(e.styles.hasOwnProperty(t)?e.styles[t]:i[t]).reduce((function(t,e){return t[e]="",t}),{});S(n)&&x(n)&&(Object.assign(n.style,o),Object.keys(s).forEach((function(t){n.removeAttribute(t)})))}))}},requires:["computeStyles"]};function I(t){return t.split("-")[0]}var N=Math.max,P=Math.min,M=Math.round;function j(){var t=navigator.userAgentData;return null!=t&&t.brands&&Array.isArray(t.brands)?t.brands.map((function(t){return t.brand+"/"+t.version})).join(" "):navigator.userAgent}function F(){return!/^((?!chrome|android).)*safari/i.test(j())}function H(t,e,i){void 0===e&&(e=!1),void 0===i&&(i=!1);var n=t.getBoundingClientRect(),s=1,o=1;e&&S(t)&&(s=t.offsetWidth>0&&M(n.width)/t.offsetWidth||1,o=t.offsetHeight>0&&M(n.height)/t.offsetHeight||1);var r=(L(t)?k(t):window).visualViewport,a=!F()&&i,l=(n.left+(a&&r?r.offsetLeft:0))/s,c=(n.top+(a&&r?r.offsetTop:0))/o,h=n.width/s,d=n.height/o;return{width:h,height:d,top:c,right:l+h,bottom:c+d,left:l,x:l,y:c}}function B(t){var e=H(t),i=t.offsetWidth,n=t.offsetHeight;return Math.abs(e.width-i)<=1&&(i=e.width),Math.abs(e.height-n)<=1&&(n=e.height),{x:t.offsetLeft,y:t.offsetTop,width:i,height:n}}function W(t,e){var i=e.getRootNode&&e.getRootNode();if(t.contains(e))return!0;if(i&&D(i)){var n=e;do{if(n&&t.isSameNode(n))return!0;n=n.parentNode||n.host}while(n)}return!1}function z(t){return k(t).getComputedStyle(t)}function R(t){return["table","td","th"].indexOf(x(t))>=0}function q(t){return((L(t)?t.ownerDocument:t.document)||window.document).documentElement}function V(t){return"html"===x(t)?t:t.assignedSlot||t.parentNode||(D(t)?t.host:null)||q(t)}function Y(t){return S(t)&&"fixed"!==z(t).position?t.offsetParent:null}function K(t){for(var e=k(t),i=Y(t);i&&R(i)&&"static"===z(i).position;)i=Y(i);return i&&("html"===x(i)||"body"===x(i)&&"static"===z(i).position)?e:i||function(t){var e=/firefox/i.test(j());if(/Trident/i.test(j())&&S(t)&&"fixed"===z(t).position)return null;var i=V(t);for(D(i)&&(i=i.host);S(i)&&["html","body"].indexOf(x(i))<0;){var n=z(i);if("none"!==n.transform||"none"!==n.perspective||"paint"===n.contain||-1!==["transform","perspective"].indexOf(n.willChange)||e&&"filter"===n.willChange||e&&n.filter&&"none"!==n.filter)return i;i=i.parentNode}return null}(t)||e}function Q(t){return["top","bottom"].indexOf(t)>=0?"x":"y"}function X(t,e,i){return N(t,P(e,i))}function U(t){return Object.assign({},{top:0,right:0,bottom:0,left:0},t)}function G(t,e){return e.reduce((function(e,i){return e[i]=t,e}),{})}const J={name:"arrow",enabled:!0,phase:"main",fn:function(t){var e,i=t.state,a=t.name,c=t.options,h=i.elements.arrow,d=i.modifiersData.popperOffsets,u=I(i.placement),f=Q(u),p=[r,o].indexOf(u)>=0?"height":"width";if(h&&d){var m=function(t,e){return U("number"!=typeof(t="function"==typeof t?t(Object.assign({},e.rects,{placement:e.placement})):t)?t:G(t,l))}(c.padding,i),g=B(h),_="y"===f?n:r,b="y"===f?s:o,v=i.rects.reference[p]+i.rects.reference[f]-d[f]-i.rects.popper[p],y=d[f]-i.rects.reference[f],w=K(h),E=w?"y"===f?w.clientHeight||0:w.clientWidth||0:0,A=v/2-y/2,T=m[_],C=E-g[p]-m[b],O=E/2-g[p]/2+A,x=X(T,O,C),k=f;i.modifiersData[a]=((e={})[k]=x,e.centerOffset=x-O,e)}},effect:function(t){var e=t.state,i=t.options.element,n=void 0===i?"[data-popper-arrow]":i;null!=n&&("string"!=typeof n||(n=e.elements.popper.querySelector(n)))&&W(e.elements.popper,n)&&(e.elements.arrow=n)},requires:["popperOffsets"],requiresIfExists:["preventOverflow"]};function Z(t){return t.split("-")[1]}var tt={top:"auto",right:"auto",bottom:"auto",left:"auto"};function et(t){var e,i=t.popper,a=t.popperRect,l=t.placement,c=t.variation,d=t.offsets,u=t.position,f=t.gpuAcceleration,p=t.adaptive,m=t.roundOffsets,g=t.isFixed,_=d.x,b=void 0===_?0:_,v=d.y,y=void 0===v?0:v,w="function"==typeof m?m({x:b,y}):{x:b,y};b=w.x,y=w.y;var E=d.hasOwnProperty("x"),A=d.hasOwnProperty("y"),T=r,C=n,O=window;if(p){var x=K(i),L="clientHeight",S="clientWidth";x===k(i)&&"static"!==z(x=q(i)).position&&"absolute"===u&&(L="scrollHeight",S="scrollWidth"),(l===n||(l===r||l===o)&&c===h)&&(C=s,y-=(g&&x===O&&O.visualViewport?O.visualViewport.height:x[L])-a.height,y*=f?1:-1),l!==r&&(l!==n&&l!==s||c!==h)||(T=o,b-=(g&&x===O&&O.visualViewport?O.visualViewport.width:x[S])-a.width,b*=f?1:-1)}var D,$=Object.assign({position:u},p&&tt),I=!0===m?function(t,e){var i=t.x,n=t.y,s=e.devicePixelRatio||1;return{x:M(i*s)/s||0,y:M(n*s)/s||0}}({x:b,y},k(i)):{x:b,y};return b=I.x,y=I.y,f?Object.assign({},$,((D={})[C]=A?"0":"",D[T]=E?"0":"",D.transform=(O.devicePixelRatio||1)<=1?"translate("+b+"px, "+y+"px)":"translate3d("+b+"px, "+y+"px, 0)",D)):Object.assign({},$,((e={})[C]=A?y+"px":"",e[T]=E?b+"px":"",e.transform="",e))}const it={name:"computeStyles",enabled:!0,phase:"beforeWrite",fn:function(t){var e=t.state,i=t.options,n=i.gpuAcceleration,s=void 0===n||n,o=i.adaptive,r=void 0===o||o,a=i.roundOffsets,l=void 0===a||a,c={placement:I(e.placement),variation:Z(e.placement),popper:e.elements.popper,popperRect:e.rects.popper,gpuAcceleration:s,isFixed:"fixed"===e.options.strategy};null!=e.modifiersData.popperOffsets&&(e.styles.popper=Object.assign({},e.styles.popper,et(Object.assign({},c,{offsets:e.modifiersData.popperOffsets,position:e.options.strategy,adaptive:r,roundOffsets:l})))),null!=e.modifiersData.arrow&&(e.styles.arrow=Object.assign({},e.styles.arrow,et(Object.assign({},c,{offsets:e.modifiersData.arrow,position:"absolute",adaptive:!1,roundOffsets:l})))),e.attributes.popper=Object.assign({},e.attributes.popper,{"data-popper-placement":e.placement})},data:{}};var nt={passive:!0};const st={name:"eventListeners",enabled:!0,phase:"write",fn:function(){},effect:function(t){var e=t.state,i=t.instance,n=t.options,s=n.scroll,o=void 0===s||s,r=n.resize,a=void 0===r||r,l=k(e.elements.popper),c=[].concat(e.scrollParents.reference,e.scrollParents.popper);return o&&c.forEach((function(t){t.addEventListener("scroll",i.update,nt)})),a&&l.addEventListener("resize",i.update,nt),function(){o&&c.forEach((function(t){t.removeEventListener("scroll",i.update,nt)})),a&&l.removeEventListener("resize",i.update,nt)}},data:{}};var ot={left:"right",right:"left",bottom:"top",top:"bottom"};function rt(t){return t.replace(/left|right|bottom|top/g,(function(t){return ot[t]}))}var at={start:"end",end:"start"};function lt(t){return t.replace(/start|end/g,(function(t){return at[t]}))}function ct(t){var e=k(t);return{scrollLeft:e.pageXOffset,scrollTop:e.pageYOffset}}function ht(t){return H(q(t)).left+ct(t).scrollLeft}function dt(t){var e=z(t),i=e.overflow,n=e.overflowX,s=e.overflowY;return/auto|scroll|overlay|hidden/.test(i+s+n)}function ut(t){return["html","body","#document"].indexOf(x(t))>=0?t.ownerDocument.body:S(t)&&dt(t)?t:ut(V(t))}function ft(t,e){var i;void 0===e&&(e=[]);var n=ut(t),s=n===(null==(i=t.ownerDocument)?void 0:i.body),o=k(n),r=s?[o].concat(o.visualViewport||[],dt(n)?n:[]):n,a=e.concat(r);return s?a:a.concat(ft(V(r)))}function pt(t){return Object.assign({},t,{left:t.x,top:t.y,right:t.x+t.width,bottom:t.y+t.height})}function mt(t,e,i){return e===u?pt(function(t,e){var i=k(t),n=q(t),s=i.visualViewport,o=n.clientWidth,r=n.clientHeight,a=0,l=0;if(s){o=s.width,r=s.height;var c=F();(c||!c&&"fixed"===e)&&(a=s.offsetLeft,l=s.offsetTop)}return{width:o,height:r,x:a+ht(t),y:l}}(t,i)):L(e)?function(t,e){var i=H(t,!1,"fixed"===e);return i.top=i.top+t.clientTop,i.left=i.left+t.clientLeft,i.bottom=i.top+t.clientHeight,i.right=i.left+t.clientWidth,i.width=t.clientWidth,i.height=t.clientHeight,i.x=i.left,i.y=i.top,i}(e,i):pt(function(t){var e,i=q(t),n=ct(t),s=null==(e=t.ownerDocument)?void 0:e.body,o=N(i.scrollWidth,i.clientWidth,s?s.scrollWidth:0,s?s.clientWidth:0),r=N(i.scrollHeight,i.clientHeight,s?s.scrollHeight:0,s?s.clientHeight:0),a=-n.scrollLeft+ht(t),l=-n.scrollTop;return"rtl"===z(s||i).direction&&(a+=N(i.clientWidth,s?s.clientWidth:0)-o),{width:o,height:r,x:a,y:l}}(q(t)))}function gt(t){var e,i=t.reference,a=t.element,l=t.placement,d=l?I(l):null,u=l?Z(l):null,f=i.x+i.width/2-a.width/2,p=i.y+i.height/2-a.height/2;switch(d){case n:e={x:f,y:i.y-a.height};break;case s:e={x:f,y:i.y+i.height};break;case o:e={x:i.x+i.width,y:p};break;case r:e={x:i.x-a.width,y:p};break;default:e={x:i.x,y:i.y}}var m=d?Q(d):null;if(null!=m){var g="y"===m?"height":"width";switch(u){case c:e[m]=e[m]-(i[g]/2-a[g]/2);break;case h:e[m]=e[m]+(i[g]/2-a[g]/2)}}return e}function _t(t,e){void 0===e&&(e={});var i=e,r=i.placement,a=void 0===r?t.placement:r,c=i.strategy,h=void 0===c?t.strategy:c,m=i.boundary,g=void 0===m?d:m,_=i.rootBoundary,b=void 0===_?u:_,v=i.elementContext,y=void 0===v?f:v,w=i.altBoundary,E=void 0!==w&&w,A=i.padding,T=void 0===A?0:A,C=U("number"!=typeof T?T:G(T,l)),O=y===f?p:f,k=t.rects.popper,D=t.elements[E?O:y],$=function(t,e,i,n){var s="clippingParents"===e?function(t){var e=ft(V(t)),i=["absolute","fixed"].indexOf(z(t).position)>=0&&S(t)?K(t):t;return L(i)?e.filter((function(t){return L(t)&&W(t,i)&&"body"!==x(t)})):[]}(t):[].concat(e),o=[].concat(s,[i]),r=o[0],a=o.reduce((function(e,i){var s=mt(t,i,n);return e.top=N(s.top,e.top),e.right=P(s.right,e.right),e.bottom=P(s.bottom,e.bottom),e.left=N(s.left,e.left),e}),mt(t,r,n));return a.width=a.right-a.left,a.height=a.bottom-a.top,a.x=a.left,a.y=a.top,a}(L(D)?D:D.contextElement||q(t.elements.popper),g,b,h),I=H(t.elements.reference),M=gt({reference:I,element:k,strategy:"absolute",placement:a}),j=pt(Object.assign({},k,M)),F=y===f?j:I,B={top:$.top-F.top+C.top,bottom:F.bottom-$.bottom+C.bottom,left:$.left-F.left+C.left,right:F.right-$.right+C.right},R=t.modifiersData.offset;if(y===f&&R){var Y=R[a];Object.keys(B).forEach((function(t){var e=[o,s].indexOf(t)>=0?1:-1,i=[n,s].indexOf(t)>=0?"y":"x";B[t]+=Y[i]*e}))}return B}const bt={name:"flip",enabled:!0,phase:"main",fn:function(t){var e=t.state,i=t.options,h=t.name;if(!e.modifiersData[h]._skip){for(var d=i.mainAxis,u=void 0===d||d,f=i.altAxis,p=void 0===f||f,_=i.fallbackPlacements,b=i.padding,v=i.boundary,y=i.rootBoundary,w=i.altBoundary,E=i.flipVariations,A=void 0===E||E,T=i.allowedAutoPlacements,C=e.options.placement,O=I(C),x=_||(O!==C&&A?function(t){if(I(t)===a)return[];var e=rt(t);return[lt(t),e,lt(e)]}(C):[rt(C)]),k=[C].concat(x).reduce((function(t,i){return t.concat(I(i)===a?function(t,e){void 0===e&&(e={});var i=e,n=i.placement,s=i.boundary,o=i.rootBoundary,r=i.padding,a=i.flipVariations,c=i.allowedAutoPlacements,h=void 0===c?g:c,d=Z(n),u=d?a?m:m.filter((function(t){return Z(t)===d})):l,f=u.filter((function(t){return h.indexOf(t)>=0}));0===f.length&&(f=u);var p=f.reduce((function(e,i){return e[i]=_t(t,{placement:i,boundary:s,rootBoundary:o,padding:r})[I(i)],e}),{});return Object.keys(p).sort((function(t,e){return p[t]-p[e]}))}(e,{placement:i,boundary:v,rootBoundary:y,padding:b,flipVariations:A,allowedAutoPlacements:T}):i)}),[]),L=e.rects.reference,S=e.rects.popper,D=new Map,$=!0,N=k[0],P=0;P=0,B=H?"width":"height",W=_t(e,{placement:M,boundary:v,rootBoundary:y,altBoundary:w,padding:b}),z=H?F?o:r:F?s:n;L[B]>S[B]&&(z=rt(z));var R=rt(z),q=[];if(u&&q.push(W[j]<=0),p&&q.push(W[z]<=0,W[R]<=0),q.every((function(t){return t}))){N=M,$=!1;break}D.set(M,q)}if($)for(var V=function(t){var e=k.find((function(e){var i=D.get(e);if(i)return i.slice(0,t).every((function(t){return t}))}));if(e)return N=e,"break"},Y=A?3:1;Y>0&&"break"!==V(Y);Y--);e.placement!==N&&(e.modifiersData[h]._skip=!0,e.placement=N,e.reset=!0)}},requiresIfExists:["offset"],data:{_skip:!1}};function vt(t,e,i){return void 0===i&&(i={x:0,y:0}),{top:t.top-e.height-i.y,right:t.right-e.width+i.x,bottom:t.bottom-e.height+i.y,left:t.left-e.width-i.x}}function yt(t){return[n,o,s,r].some((function(e){return t[e]>=0}))}const wt={name:"hide",enabled:!0,phase:"main",requiresIfExists:["preventOverflow"],fn:function(t){var e=t.state,i=t.name,n=e.rects.reference,s=e.rects.popper,o=e.modifiersData.preventOverflow,r=_t(e,{elementContext:"reference"}),a=_t(e,{altBoundary:!0}),l=vt(r,n),c=vt(a,s,o),h=yt(l),d=yt(c);e.modifiersData[i]={referenceClippingOffsets:l,popperEscapeOffsets:c,isReferenceHidden:h,hasPopperEscaped:d},e.attributes.popper=Object.assign({},e.attributes.popper,{"data-popper-reference-hidden":h,"data-popper-escaped":d})}},Et={name:"offset",enabled:!0,phase:"main",requires:["popperOffsets"],fn:function(t){var e=t.state,i=t.options,s=t.name,a=i.offset,l=void 0===a?[0,0]:a,c=g.reduce((function(t,i){return t[i]=function(t,e,i){var s=I(t),a=[r,n].indexOf(s)>=0?-1:1,l="function"==typeof i?i(Object.assign({},e,{placement:t})):i,c=l[0],h=l[1];return c=c||0,h=(h||0)*a,[r,o].indexOf(s)>=0?{x:h,y:c}:{x:c,y:h}}(i,e.rects,l),t}),{}),h=c[e.placement],d=h.x,u=h.y;null!=e.modifiersData.popperOffsets&&(e.modifiersData.popperOffsets.x+=d,e.modifiersData.popperOffsets.y+=u),e.modifiersData[s]=c}},At={name:"popperOffsets",enabled:!0,phase:"read",fn:function(t){var e=t.state,i=t.name;e.modifiersData[i]=gt({reference:e.rects.reference,element:e.rects.popper,strategy:"absolute",placement:e.placement})},data:{}},Tt={name:"preventOverflow",enabled:!0,phase:"main",fn:function(t){var e=t.state,i=t.options,a=t.name,l=i.mainAxis,h=void 0===l||l,d=i.altAxis,u=void 0!==d&&d,f=i.boundary,p=i.rootBoundary,m=i.altBoundary,g=i.padding,_=i.tether,b=void 0===_||_,v=i.tetherOffset,y=void 0===v?0:v,w=_t(e,{boundary:f,rootBoundary:p,padding:g,altBoundary:m}),E=I(e.placement),A=Z(e.placement),T=!A,C=Q(E),O="x"===C?"y":"x",x=e.modifiersData.popperOffsets,k=e.rects.reference,L=e.rects.popper,S="function"==typeof y?y(Object.assign({},e.rects,{placement:e.placement})):y,D="number"==typeof S?{mainAxis:S,altAxis:S}:Object.assign({mainAxis:0,altAxis:0},S),$=e.modifiersData.offset?e.modifiersData.offset[e.placement]:null,M={x:0,y:0};if(x){if(h){var j,F="y"===C?n:r,H="y"===C?s:o,W="y"===C?"height":"width",z=x[C],R=z+w[F],q=z-w[H],V=b?-L[W]/2:0,Y=A===c?k[W]:L[W],U=A===c?-L[W]:-k[W],G=e.elements.arrow,J=b&&G?B(G):{width:0,height:0},tt=e.modifiersData["arrow#persistent"]?e.modifiersData["arrow#persistent"].padding:{top:0,right:0,bottom:0,left:0},et=tt[F],it=tt[H],nt=X(0,k[W],J[W]),st=T?k[W]/2-V-nt-et-D.mainAxis:Y-nt-et-D.mainAxis,ot=T?-k[W]/2+V+nt+it+D.mainAxis:U+nt+it+D.mainAxis,rt=e.elements.arrow&&K(e.elements.arrow),at=rt?"y"===C?rt.clientTop||0:rt.clientLeft||0:0,lt=null!=(j=null==$?void 0:$[C])?j:0,ct=z+ot-lt,ht=X(b?P(R,z+st-lt-at):R,z,b?N(q,ct):q);x[C]=ht,M[C]=ht-z}if(u){var dt,ut="x"===C?n:r,ft="x"===C?s:o,pt=x[O],mt="y"===O?"height":"width",gt=pt+w[ut],bt=pt-w[ft],vt=-1!==[n,r].indexOf(E),yt=null!=(dt=null==$?void 0:$[O])?dt:0,wt=vt?gt:pt-k[mt]-L[mt]-yt+D.altAxis,Et=vt?pt+k[mt]+L[mt]-yt-D.altAxis:bt,At=b&&vt?function(t,e,i){var n=X(t,e,i);return n>i?i:n}(wt,pt,Et):X(b?wt:gt,pt,b?Et:bt);x[O]=At,M[O]=At-pt}e.modifiersData[a]=M}},requiresIfExists:["offset"]};function Ct(t,e,i){void 0===i&&(i=!1);var n,s,o=S(e),r=S(e)&&function(t){var e=t.getBoundingClientRect(),i=M(e.width)/t.offsetWidth||1,n=M(e.height)/t.offsetHeight||1;return 1!==i||1!==n}(e),a=q(e),l=H(t,r,i),c={scrollLeft:0,scrollTop:0},h={x:0,y:0};return(o||!o&&!i)&&(("body"!==x(e)||dt(a))&&(c=(n=e)!==k(n)&&S(n)?{scrollLeft:(s=n).scrollLeft,scrollTop:s.scrollTop}:ct(n)),S(e)?((h=H(e,!0)).x+=e.clientLeft,h.y+=e.clientTop):a&&(h.x=ht(a))),{x:l.left+c.scrollLeft-h.x,y:l.top+c.scrollTop-h.y,width:l.width,height:l.height}}function Ot(t){var e=new Map,i=new Set,n=[];function s(t){i.add(t.name),[].concat(t.requires||[],t.requiresIfExists||[]).forEach((function(t){if(!i.has(t)){var n=e.get(t);n&&s(n)}})),n.push(t)}return t.forEach((function(t){e.set(t.name,t)})),t.forEach((function(t){i.has(t.name)||s(t)})),n}var xt={placement:"bottom",modifiers:[],strategy:"absolute"};function kt(){for(var t=arguments.length,e=new Array(t),i=0;iIt.has(t)&&It.get(t).get(e)||null,remove(t,e){if(!It.has(t))return;const i=It.get(t);i.delete(e),0===i.size&&It.delete(t)}},Pt="transitionend",Mt=t=>(t&&window.CSS&&window.CSS.escape&&(t=t.replace(/#([^\s"#']+)/g,((t,e)=>`#${CSS.escape(e)}`))),t),jt=t=>{t.dispatchEvent(new Event(Pt))},Ft=t=>!(!t||"object"!=typeof t)&&(void 0!==t.jquery&&(t=t[0]),void 0!==t.nodeType),Ht=t=>Ft(t)?t.jquery?t[0]:t:"string"==typeof t&&t.length>0?document.querySelector(Mt(t)):null,Bt=t=>{if(!Ft(t)||0===t.getClientRects().length)return!1;const e="visible"===getComputedStyle(t).getPropertyValue("visibility"),i=t.closest("details:not([open])");if(!i)return e;if(i!==t){const e=t.closest("summary");if(e&&e.parentNode!==i)return!1;if(null===e)return!1}return e},Wt=t=>!t||t.nodeType!==Node.ELEMENT_NODE||!!t.classList.contains("disabled")||(void 0!==t.disabled?t.disabled:t.hasAttribute("disabled")&&"false"!==t.getAttribute("disabled")),zt=t=>{if(!document.documentElement.attachShadow)return null;if("function"==typeof t.getRootNode){const e=t.getRootNode();return e instanceof ShadowRoot?e:null}return t instanceof ShadowRoot?t:t.parentNode?zt(t.parentNode):null},Rt=()=>{},qt=t=>{t.offsetHeight},Vt=()=>window.jQuery&&!document.body.hasAttribute("data-bs-no-jquery")?window.jQuery:null,Yt=[],Kt=()=>"rtl"===document.documentElement.dir,Qt=t=>{var e;e=()=>{const e=Vt();if(e){const i=t.NAME,n=e.fn[i];e.fn[i]=t.jQueryInterface,e.fn[i].Constructor=t,e.fn[i].noConflict=()=>(e.fn[i]=n,t.jQueryInterface)}},"loading"===document.readyState?(Yt.length||document.addEventListener("DOMContentLoaded",(()=>{for(const t of Yt)t()})),Yt.push(e)):e()},Xt=(t,e=[],i=t)=>"function"==typeof t?t(...e):i,Ut=(t,e,i=!0)=>{if(!i)return void Xt(t);const n=(t=>{if(!t)return 0;let{transitionDuration:e,transitionDelay:i}=window.getComputedStyle(t);const n=Number.parseFloat(e),s=Number.parseFloat(i);return n||s?(e=e.split(",")[0],i=i.split(",")[0],1e3*(Number.parseFloat(e)+Number.parseFloat(i))):0})(e)+5;let s=!1;const o=({target:i})=>{i===e&&(s=!0,e.removeEventListener(Pt,o),Xt(t))};e.addEventListener(Pt,o),setTimeout((()=>{s||jt(e)}),n)},Gt=(t,e,i,n)=>{const s=t.length;let o=t.indexOf(e);return-1===o?!i&&n?t[s-1]:t[0]:(o+=i?1:-1,n&&(o=(o+s)%s),t[Math.max(0,Math.min(o,s-1))])},Jt=/[^.]*(?=\..*)\.|.*/,Zt=/\..*/,te=/::\d+$/,ee={};let ie=1;const ne={mouseenter:"mouseover",mouseleave:"mouseout"},se=new Set(["click","dblclick","mouseup","mousedown","contextmenu","mousewheel","DOMMouseScroll","mouseover","mouseout","mousemove","selectstart","selectend","keydown","keypress","keyup","orientationchange","touchstart","touchmove","touchend","touchcancel","pointerdown","pointermove","pointerup","pointerleave","pointercancel","gesturestart","gesturechange","gestureend","focus","blur","change","reset","select","submit","focusin","focusout","load","unload","beforeunload","resize","move","DOMContentLoaded","readystatechange","error","abort","scroll"]);function oe(t,e){return e&&`${e}::${ie++}`||t.uidEvent||ie++}function re(t){const e=oe(t);return t.uidEvent=e,ee[e]=ee[e]||{},ee[e]}function ae(t,e,i=null){return Object.values(t).find((t=>t.callable===e&&t.delegationSelector===i))}function le(t,e,i){const n="string"==typeof e,s=n?i:e||i;let o=ue(t);return se.has(o)||(o=t),[n,s,o]}function ce(t,e,i,n,s){if("string"!=typeof e||!t)return;let[o,r,a]=le(e,i,n);if(e in ne){const t=t=>function(e){if(!e.relatedTarget||e.relatedTarget!==e.delegateTarget&&!e.delegateTarget.contains(e.relatedTarget))return t.call(this,e)};r=t(r)}const l=re(t),c=l[a]||(l[a]={}),h=ae(c,r,o?i:null);if(h)return void(h.oneOff=h.oneOff&&s);const d=oe(r,e.replace(Jt,"")),u=o?function(t,e,i){return function n(s){const o=t.querySelectorAll(e);for(let{target:r}=s;r&&r!==this;r=r.parentNode)for(const a of o)if(a===r)return pe(s,{delegateTarget:r}),n.oneOff&&fe.off(t,s.type,e,i),i.apply(r,[s])}}(t,i,r):function(t,e){return function i(n){return pe(n,{delegateTarget:t}),i.oneOff&&fe.off(t,n.type,e),e.apply(t,[n])}}(t,r);u.delegationSelector=o?i:null,u.callable=r,u.oneOff=s,u.uidEvent=d,c[d]=u,t.addEventListener(a,u,o)}function he(t,e,i,n,s){const o=ae(e[i],n,s);o&&(t.removeEventListener(i,o,Boolean(s)),delete e[i][o.uidEvent])}function de(t,e,i,n){const s=e[i]||{};for(const[o,r]of Object.entries(s))o.includes(n)&&he(t,e,i,r.callable,r.delegationSelector)}function ue(t){return t=t.replace(Zt,""),ne[t]||t}const fe={on(t,e,i,n){ce(t,e,i,n,!1)},one(t,e,i,n){ce(t,e,i,n,!0)},off(t,e,i,n){if("string"!=typeof e||!t)return;const[s,o,r]=le(e,i,n),a=r!==e,l=re(t),c=l[r]||{},h=e.startsWith(".");if(void 0===o){if(h)for(const i of Object.keys(l))de(t,l,i,e.slice(1));for(const[i,n]of Object.entries(c)){const s=i.replace(te,"");a&&!e.includes(s)||he(t,l,r,n.callable,n.delegationSelector)}}else{if(!Object.keys(c).length)return;he(t,l,r,o,s?i:null)}},trigger(t,e,i){if("string"!=typeof e||!t)return null;const n=Vt();let s=null,o=!0,r=!0,a=!1;e!==ue(e)&&n&&(s=n.Event(e,i),n(t).trigger(s),o=!s.isPropagationStopped(),r=!s.isImmediatePropagationStopped(),a=s.isDefaultPrevented());const l=pe(new Event(e,{bubbles:o,cancelable:!0}),i);return a&&l.preventDefault(),r&&t.dispatchEvent(l),l.defaultPrevented&&s&&s.preventDefault(),l}};function pe(t,e={}){for(const[i,n]of Object.entries(e))try{t[i]=n}catch(e){Object.defineProperty(t,i,{configurable:!0,get:()=>n})}return t}function me(t){if("true"===t)return!0;if("false"===t)return!1;if(t===Number(t).toString())return Number(t);if(""===t||"null"===t)return null;if("string"!=typeof t)return t;try{return JSON.parse(decodeURIComponent(t))}catch(e){return t}}function ge(t){return t.replace(/[A-Z]/g,(t=>`-${t.toLowerCase()}`))}const _e={setDataAttribute(t,e,i){t.setAttribute(`data-bs-${ge(e)}`,i)},removeDataAttribute(t,e){t.removeAttribute(`data-bs-${ge(e)}`)},getDataAttributes(t){if(!t)return{};const e={},i=Object.keys(t.dataset).filter((t=>t.startsWith("bs")&&!t.startsWith("bsConfig")));for(const n of i){let i=n.replace(/^bs/,"");i=i.charAt(0).toLowerCase()+i.slice(1,i.length),e[i]=me(t.dataset[n])}return e},getDataAttribute:(t,e)=>me(t.getAttribute(`data-bs-${ge(e)}`))};class be{static get Default(){return{}}static get DefaultType(){return{}}static get NAME(){throw new Error('You have to implement the static method "NAME", for each component!')}_getConfig(t){return t=this._mergeConfigObj(t),t=this._configAfterMerge(t),this._typeCheckConfig(t),t}_configAfterMerge(t){return t}_mergeConfigObj(t,e){const i=Ft(e)?_e.getDataAttribute(e,"config"):{};return{...this.constructor.Default,..."object"==typeof i?i:{},...Ft(e)?_e.getDataAttributes(e):{},..."object"==typeof t?t:{}}}_typeCheckConfig(t,e=this.constructor.DefaultType){for(const[n,s]of Object.entries(e)){const e=t[n],o=Ft(e)?"element":null==(i=e)?`${i}`:Object.prototype.toString.call(i).match(/\s([a-z]+)/i)[1].toLowerCase();if(!new RegExp(s).test(o))throw new TypeError(`${this.constructor.NAME.toUpperCase()}: Option "${n}" provided type "${o}" but expected type "${s}".`)}var i}}class ve extends be{constructor(t,e){super(),(t=Ht(t))&&(this._element=t,this._config=this._getConfig(e),Nt.set(this._element,this.constructor.DATA_KEY,this))}dispose(){Nt.remove(this._element,this.constructor.DATA_KEY),fe.off(this._element,this.constructor.EVENT_KEY);for(const t of Object.getOwnPropertyNames(this))this[t]=null}_queueCallback(t,e,i=!0){Ut(t,e,i)}_getConfig(t){return t=this._mergeConfigObj(t,this._element),t=this._configAfterMerge(t),this._typeCheckConfig(t),t}static getInstance(t){return Nt.get(Ht(t),this.DATA_KEY)}static getOrCreateInstance(t,e={}){return this.getInstance(t)||new this(t,"object"==typeof e?e:null)}static get VERSION(){return"5.3.3"}static get DATA_KEY(){return`bs.${this.NAME}`}static get EVENT_KEY(){return`.${this.DATA_KEY}`}static eventName(t){return`${t}${this.EVENT_KEY}`}}const ye=t=>{let e=t.getAttribute("data-bs-target");if(!e||"#"===e){let i=t.getAttribute("href");if(!i||!i.includes("#")&&!i.startsWith("."))return null;i.includes("#")&&!i.startsWith("#")&&(i=`#${i.split("#")[1]}`),e=i&&"#"!==i?i.trim():null}return e?e.split(",").map((t=>Mt(t))).join(","):null},we={find:(t,e=document.documentElement)=>[].concat(...Element.prototype.querySelectorAll.call(e,t)),findOne:(t,e=document.documentElement)=>Element.prototype.querySelector.call(e,t),children:(t,e)=>[].concat(...t.children).filter((t=>t.matches(e))),parents(t,e){const i=[];let n=t.parentNode.closest(e);for(;n;)i.push(n),n=n.parentNode.closest(e);return i},prev(t,e){let i=t.previousElementSibling;for(;i;){if(i.matches(e))return[i];i=i.previousElementSibling}return[]},next(t,e){let i=t.nextElementSibling;for(;i;){if(i.matches(e))return[i];i=i.nextElementSibling}return[]},focusableChildren(t){const e=["a","button","input","textarea","select","details","[tabindex]",'[contenteditable="true"]'].map((t=>`${t}:not([tabindex^="-"])`)).join(",");return this.find(e,t).filter((t=>!Wt(t)&&Bt(t)))},getSelectorFromElement(t){const e=ye(t);return e&&we.findOne(e)?e:null},getElementFromSelector(t){const e=ye(t);return e?we.findOne(e):null},getMultipleElementsFromSelector(t){const e=ye(t);return e?we.find(e):[]}},Ee=(t,e="hide")=>{const i=`click.dismiss${t.EVENT_KEY}`,n=t.NAME;fe.on(document,i,`[data-bs-dismiss="${n}"]`,(function(i){if(["A","AREA"].includes(this.tagName)&&i.preventDefault(),Wt(this))return;const s=we.getElementFromSelector(this)||this.closest(`.${n}`);t.getOrCreateInstance(s)[e]()}))},Ae=".bs.alert",Te=`close${Ae}`,Ce=`closed${Ae}`;class Oe extends ve{static get NAME(){return"alert"}close(){if(fe.trigger(this._element,Te).defaultPrevented)return;this._element.classList.remove("show");const t=this._element.classList.contains("fade");this._queueCallback((()=>this._destroyElement()),this._element,t)}_destroyElement(){this._element.remove(),fe.trigger(this._element,Ce),this.dispose()}static jQueryInterface(t){return this.each((function(){const e=Oe.getOrCreateInstance(this);if("string"==typeof t){if(void 0===e[t]||t.startsWith("_")||"constructor"===t)throw new TypeError(`No method named "${t}"`);e[t](this)}}))}}Ee(Oe,"close"),Qt(Oe);const xe='[data-bs-toggle="button"]';class ke extends ve{static get NAME(){return"button"}toggle(){this._element.setAttribute("aria-pressed",this._element.classList.toggle("active"))}static jQueryInterface(t){return this.each((function(){const e=ke.getOrCreateInstance(this);"toggle"===t&&e[t]()}))}}fe.on(document,"click.bs.button.data-api",xe,(t=>{t.preventDefault();const e=t.target.closest(xe);ke.getOrCreateInstance(e).toggle()})),Qt(ke);const Le=".bs.swipe",Se=`touchstart${Le}`,De=`touchmove${Le}`,$e=`touchend${Le}`,Ie=`pointerdown${Le}`,Ne=`pointerup${Le}`,Pe={endCallback:null,leftCallback:null,rightCallback:null},Me={endCallback:"(function|null)",leftCallback:"(function|null)",rightCallback:"(function|null)"};class je extends be{constructor(t,e){super(),this._element=t,t&&je.isSupported()&&(this._config=this._getConfig(e),this._deltaX=0,this._supportPointerEvents=Boolean(window.PointerEvent),this._initEvents())}static get Default(){return Pe}static get DefaultType(){return Me}static get NAME(){return"swipe"}dispose(){fe.off(this._element,Le)}_start(t){this._supportPointerEvents?this._eventIsPointerPenTouch(t)&&(this._deltaX=t.clientX):this._deltaX=t.touches[0].clientX}_end(t){this._eventIsPointerPenTouch(t)&&(this._deltaX=t.clientX-this._deltaX),this._handleSwipe(),Xt(this._config.endCallback)}_move(t){this._deltaX=t.touches&&t.touches.length>1?0:t.touches[0].clientX-this._deltaX}_handleSwipe(){const t=Math.abs(this._deltaX);if(t<=40)return;const e=t/this._deltaX;this._deltaX=0,e&&Xt(e>0?this._config.rightCallback:this._config.leftCallback)}_initEvents(){this._supportPointerEvents?(fe.on(this._element,Ie,(t=>this._start(t))),fe.on(this._element,Ne,(t=>this._end(t))),this._element.classList.add("pointer-event")):(fe.on(this._element,Se,(t=>this._start(t))),fe.on(this._element,De,(t=>this._move(t))),fe.on(this._element,$e,(t=>this._end(t))))}_eventIsPointerPenTouch(t){return this._supportPointerEvents&&("pen"===t.pointerType||"touch"===t.pointerType)}static isSupported(){return"ontouchstart"in document.documentElement||navigator.maxTouchPoints>0}}const Fe=".bs.carousel",He=".data-api",Be="ArrowLeft",We="ArrowRight",ze="next",Re="prev",qe="left",Ve="right",Ye=`slide${Fe}`,Ke=`slid${Fe}`,Qe=`keydown${Fe}`,Xe=`mouseenter${Fe}`,Ue=`mouseleave${Fe}`,Ge=`dragstart${Fe}`,Je=`load${Fe}${He}`,Ze=`click${Fe}${He}`,ti="carousel",ei="active",ii=".active",ni=".carousel-item",si=ii+ni,oi={[Be]:Ve,[We]:qe},ri={interval:5e3,keyboard:!0,pause:"hover",ride:!1,touch:!0,wrap:!0},ai={interval:"(number|boolean)",keyboard:"boolean",pause:"(string|boolean)",ride:"(boolean|string)",touch:"boolean",wrap:"boolean"};class li extends ve{constructor(t,e){super(t,e),this._interval=null,this._activeElement=null,this._isSliding=!1,this.touchTimeout=null,this._swipeHelper=null,this._indicatorsElement=we.findOne(".carousel-indicators",this._element),this._addEventListeners(),this._config.ride===ti&&this.cycle()}static get Default(){return ri}static get DefaultType(){return ai}static get NAME(){return"carousel"}next(){this._slide(ze)}nextWhenVisible(){!document.hidden&&Bt(this._element)&&this.next()}prev(){this._slide(Re)}pause(){this._isSliding&&jt(this._element),this._clearInterval()}cycle(){this._clearInterval(),this._updateInterval(),this._interval=setInterval((()=>this.nextWhenVisible()),this._config.interval)}_maybeEnableCycle(){this._config.ride&&(this._isSliding?fe.one(this._element,Ke,(()=>this.cycle())):this.cycle())}to(t){const e=this._getItems();if(t>e.length-1||t<0)return;if(this._isSliding)return void fe.one(this._element,Ke,(()=>this.to(t)));const i=this._getItemIndex(this._getActive());if(i===t)return;const n=t>i?ze:Re;this._slide(n,e[t])}dispose(){this._swipeHelper&&this._swipeHelper.dispose(),super.dispose()}_configAfterMerge(t){return t.defaultInterval=t.interval,t}_addEventListeners(){this._config.keyboard&&fe.on(this._element,Qe,(t=>this._keydown(t))),"hover"===this._config.pause&&(fe.on(this._element,Xe,(()=>this.pause())),fe.on(this._element,Ue,(()=>this._maybeEnableCycle()))),this._config.touch&&je.isSupported()&&this._addTouchEventListeners()}_addTouchEventListeners(){for(const t of we.find(".carousel-item img",this._element))fe.on(t,Ge,(t=>t.preventDefault()));const t={leftCallback:()=>this._slide(this._directionToOrder(qe)),rightCallback:()=>this._slide(this._directionToOrder(Ve)),endCallback:()=>{"hover"===this._config.pause&&(this.pause(),this.touchTimeout&&clearTimeout(this.touchTimeout),this.touchTimeout=setTimeout((()=>this._maybeEnableCycle()),500+this._config.interval))}};this._swipeHelper=new je(this._element,t)}_keydown(t){if(/input|textarea/i.test(t.target.tagName))return;const e=oi[t.key];e&&(t.preventDefault(),this._slide(this._directionToOrder(e)))}_getItemIndex(t){return this._getItems().indexOf(t)}_setActiveIndicatorElement(t){if(!this._indicatorsElement)return;const e=we.findOne(ii,this._indicatorsElement);e.classList.remove(ei),e.removeAttribute("aria-current");const i=we.findOne(`[data-bs-slide-to="${t}"]`,this._indicatorsElement);i&&(i.classList.add(ei),i.setAttribute("aria-current","true"))}_updateInterval(){const t=this._activeElement||this._getActive();if(!t)return;const e=Number.parseInt(t.getAttribute("data-bs-interval"),10);this._config.interval=e||this._config.defaultInterval}_slide(t,e=null){if(this._isSliding)return;const i=this._getActive(),n=t===ze,s=e||Gt(this._getItems(),i,n,this._config.wrap);if(s===i)return;const o=this._getItemIndex(s),r=e=>fe.trigger(this._element,e,{relatedTarget:s,direction:this._orderToDirection(t),from:this._getItemIndex(i),to:o});if(r(Ye).defaultPrevented)return;if(!i||!s)return;const a=Boolean(this._interval);this.pause(),this._isSliding=!0,this._setActiveIndicatorElement(o),this._activeElement=s;const l=n?"carousel-item-start":"carousel-item-end",c=n?"carousel-item-next":"carousel-item-prev";s.classList.add(c),qt(s),i.classList.add(l),s.classList.add(l),this._queueCallback((()=>{s.classList.remove(l,c),s.classList.add(ei),i.classList.remove(ei,c,l),this._isSliding=!1,r(Ke)}),i,this._isAnimated()),a&&this.cycle()}_isAnimated(){return this._element.classList.contains("slide")}_getActive(){return we.findOne(si,this._element)}_getItems(){return we.find(ni,this._element)}_clearInterval(){this._interval&&(clearInterval(this._interval),this._interval=null)}_directionToOrder(t){return Kt()?t===qe?Re:ze:t===qe?ze:Re}_orderToDirection(t){return Kt()?t===Re?qe:Ve:t===Re?Ve:qe}static jQueryInterface(t){return this.each((function(){const e=li.getOrCreateInstance(this,t);if("number"!=typeof t){if("string"==typeof t){if(void 0===e[t]||t.startsWith("_")||"constructor"===t)throw new TypeError(`No method named "${t}"`);e[t]()}}else e.to(t)}))}}fe.on(document,Ze,"[data-bs-slide], [data-bs-slide-to]",(function(t){const e=we.getElementFromSelector(this);if(!e||!e.classList.contains(ti))return;t.preventDefault();const i=li.getOrCreateInstance(e),n=this.getAttribute("data-bs-slide-to");return n?(i.to(n),void i._maybeEnableCycle()):"next"===_e.getDataAttribute(this,"slide")?(i.next(),void i._maybeEnableCycle()):(i.prev(),void i._maybeEnableCycle())})),fe.on(window,Je,(()=>{const t=we.find('[data-bs-ride="carousel"]');for(const e of t)li.getOrCreateInstance(e)})),Qt(li);const ci=".bs.collapse",hi=`show${ci}`,di=`shown${ci}`,ui=`hide${ci}`,fi=`hidden${ci}`,pi=`click${ci}.data-api`,mi="show",gi="collapse",_i="collapsing",bi=`:scope .${gi} .${gi}`,vi='[data-bs-toggle="collapse"]',yi={parent:null,toggle:!0},wi={parent:"(null|element)",toggle:"boolean"};class Ei extends ve{constructor(t,e){super(t,e),this._isTransitioning=!1,this._triggerArray=[];const i=we.find(vi);for(const t of i){const e=we.getSelectorFromElement(t),i=we.find(e).filter((t=>t===this._element));null!==e&&i.length&&this._triggerArray.push(t)}this._initializeChildren(),this._config.parent||this._addAriaAndCollapsedClass(this._triggerArray,this._isShown()),this._config.toggle&&this.toggle()}static get Default(){return yi}static get DefaultType(){return wi}static get NAME(){return"collapse"}toggle(){this._isShown()?this.hide():this.show()}show(){if(this._isTransitioning||this._isShown())return;let t=[];if(this._config.parent&&(t=this._getFirstLevelChildren(".collapse.show, .collapse.collapsing").filter((t=>t!==this._element)).map((t=>Ei.getOrCreateInstance(t,{toggle:!1})))),t.length&&t[0]._isTransitioning)return;if(fe.trigger(this._element,hi).defaultPrevented)return;for(const e of t)e.hide();const e=this._getDimension();this._element.classList.remove(gi),this._element.classList.add(_i),this._element.style[e]=0,this._addAriaAndCollapsedClass(this._triggerArray,!0),this._isTransitioning=!0;const i=`scroll${e[0].toUpperCase()+e.slice(1)}`;this._queueCallback((()=>{this._isTransitioning=!1,this._element.classList.remove(_i),this._element.classList.add(gi,mi),this._element.style[e]="",fe.trigger(this._element,di)}),this._element,!0),this._element.style[e]=`${this._element[i]}px`}hide(){if(this._isTransitioning||!this._isShown())return;if(fe.trigger(this._element,ui).defaultPrevented)return;const t=this._getDimension();this._element.style[t]=`${this._element.getBoundingClientRect()[t]}px`,qt(this._element),this._element.classList.add(_i),this._element.classList.remove(gi,mi);for(const t of this._triggerArray){const e=we.getElementFromSelector(t);e&&!this._isShown(e)&&this._addAriaAndCollapsedClass([t],!1)}this._isTransitioning=!0,this._element.style[t]="",this._queueCallback((()=>{this._isTransitioning=!1,this._element.classList.remove(_i),this._element.classList.add(gi),fe.trigger(this._element,fi)}),this._element,!0)}_isShown(t=this._element){return t.classList.contains(mi)}_configAfterMerge(t){return t.toggle=Boolean(t.toggle),t.parent=Ht(t.parent),t}_getDimension(){return this._element.classList.contains("collapse-horizontal")?"width":"height"}_initializeChildren(){if(!this._config.parent)return;const t=this._getFirstLevelChildren(vi);for(const e of t){const t=we.getElementFromSelector(e);t&&this._addAriaAndCollapsedClass([e],this._isShown(t))}}_getFirstLevelChildren(t){const e=we.find(bi,this._config.parent);return we.find(t,this._config.parent).filter((t=>!e.includes(t)))}_addAriaAndCollapsedClass(t,e){if(t.length)for(const i of t)i.classList.toggle("collapsed",!e),i.setAttribute("aria-expanded",e)}static jQueryInterface(t){const e={};return"string"==typeof t&&/show|hide/.test(t)&&(e.toggle=!1),this.each((function(){const i=Ei.getOrCreateInstance(this,e);if("string"==typeof t){if(void 0===i[t])throw new TypeError(`No method named "${t}"`);i[t]()}}))}}fe.on(document,pi,vi,(function(t){("A"===t.target.tagName||t.delegateTarget&&"A"===t.delegateTarget.tagName)&&t.preventDefault();for(const t of we.getMultipleElementsFromSelector(this))Ei.getOrCreateInstance(t,{toggle:!1}).toggle()})),Qt(Ei);const Ai="dropdown",Ti=".bs.dropdown",Ci=".data-api",Oi="ArrowUp",xi="ArrowDown",ki=`hide${Ti}`,Li=`hidden${Ti}`,Si=`show${Ti}`,Di=`shown${Ti}`,$i=`click${Ti}${Ci}`,Ii=`keydown${Ti}${Ci}`,Ni=`keyup${Ti}${Ci}`,Pi="show",Mi='[data-bs-toggle="dropdown"]:not(.disabled):not(:disabled)',ji=`${Mi}.${Pi}`,Fi=".dropdown-menu",Hi=Kt()?"top-end":"top-start",Bi=Kt()?"top-start":"top-end",Wi=Kt()?"bottom-end":"bottom-start",zi=Kt()?"bottom-start":"bottom-end",Ri=Kt()?"left-start":"right-start",qi=Kt()?"right-start":"left-start",Vi={autoClose:!0,boundary:"clippingParents",display:"dynamic",offset:[0,2],popperConfig:null,reference:"toggle"},Yi={autoClose:"(boolean|string)",boundary:"(string|element)",display:"string",offset:"(array|string|function)",popperConfig:"(null|object|function)",reference:"(string|element|object)"};class Ki extends ve{constructor(t,e){super(t,e),this._popper=null,this._parent=this._element.parentNode,this._menu=we.next(this._element,Fi)[0]||we.prev(this._element,Fi)[0]||we.findOne(Fi,this._parent),this._inNavbar=this._detectNavbar()}static get Default(){return Vi}static get DefaultType(){return Yi}static get NAME(){return Ai}toggle(){return this._isShown()?this.hide():this.show()}show(){if(Wt(this._element)||this._isShown())return;const t={relatedTarget:this._element};if(!fe.trigger(this._element,Si,t).defaultPrevented){if(this._createPopper(),"ontouchstart"in document.documentElement&&!this._parent.closest(".navbar-nav"))for(const t of[].concat(...document.body.children))fe.on(t,"mouseover",Rt);this._element.focus(),this._element.setAttribute("aria-expanded",!0),this._menu.classList.add(Pi),this._element.classList.add(Pi),fe.trigger(this._element,Di,t)}}hide(){if(Wt(this._element)||!this._isShown())return;const t={relatedTarget:this._element};this._completeHide(t)}dispose(){this._popper&&this._popper.destroy(),super.dispose()}update(){this._inNavbar=this._detectNavbar(),this._popper&&this._popper.update()}_completeHide(t){if(!fe.trigger(this._element,ki,t).defaultPrevented){if("ontouchstart"in document.documentElement)for(const t of[].concat(...document.body.children))fe.off(t,"mouseover",Rt);this._popper&&this._popper.destroy(),this._menu.classList.remove(Pi),this._element.classList.remove(Pi),this._element.setAttribute("aria-expanded","false"),_e.removeDataAttribute(this._menu,"popper"),fe.trigger(this._element,Li,t)}}_getConfig(t){if("object"==typeof(t=super._getConfig(t)).reference&&!Ft(t.reference)&&"function"!=typeof t.reference.getBoundingClientRect)throw new TypeError(`${Ai.toUpperCase()}: Option "reference" provided type "object" without a required "getBoundingClientRect" method.`);return t}_createPopper(){if(void 0===e)throw new TypeError("Bootstrap's dropdowns require Popper (https://popper.js.org)");let t=this._element;"parent"===this._config.reference?t=this._parent:Ft(this._config.reference)?t=Ht(this._config.reference):"object"==typeof this._config.reference&&(t=this._config.reference);const i=this._getPopperConfig();this._popper=Dt(t,this._menu,i)}_isShown(){return this._menu.classList.contains(Pi)}_getPlacement(){const t=this._parent;if(t.classList.contains("dropend"))return Ri;if(t.classList.contains("dropstart"))return qi;if(t.classList.contains("dropup-center"))return"top";if(t.classList.contains("dropdown-center"))return"bottom";const e="end"===getComputedStyle(this._menu).getPropertyValue("--bs-position").trim();return t.classList.contains("dropup")?e?Bi:Hi:e?zi:Wi}_detectNavbar(){return null!==this._element.closest(".navbar")}_getOffset(){const{offset:t}=this._config;return"string"==typeof t?t.split(",").map((t=>Number.parseInt(t,10))):"function"==typeof t?e=>t(e,this._element):t}_getPopperConfig(){const t={placement:this._getPlacement(),modifiers:[{name:"preventOverflow",options:{boundary:this._config.boundary}},{name:"offset",options:{offset:this._getOffset()}}]};return(this._inNavbar||"static"===this._config.display)&&(_e.setDataAttribute(this._menu,"popper","static"),t.modifiers=[{name:"applyStyles",enabled:!1}]),{...t,...Xt(this._config.popperConfig,[t])}}_selectMenuItem({key:t,target:e}){const i=we.find(".dropdown-menu .dropdown-item:not(.disabled):not(:disabled)",this._menu).filter((t=>Bt(t)));i.length&&Gt(i,e,t===xi,!i.includes(e)).focus()}static jQueryInterface(t){return this.each((function(){const e=Ki.getOrCreateInstance(this,t);if("string"==typeof t){if(void 0===e[t])throw new TypeError(`No method named "${t}"`);e[t]()}}))}static clearMenus(t){if(2===t.button||"keyup"===t.type&&"Tab"!==t.key)return;const e=we.find(ji);for(const i of e){const e=Ki.getInstance(i);if(!e||!1===e._config.autoClose)continue;const n=t.composedPath(),s=n.includes(e._menu);if(n.includes(e._element)||"inside"===e._config.autoClose&&!s||"outside"===e._config.autoClose&&s)continue;if(e._menu.contains(t.target)&&("keyup"===t.type&&"Tab"===t.key||/input|select|option|textarea|form/i.test(t.target.tagName)))continue;const o={relatedTarget:e._element};"click"===t.type&&(o.clickEvent=t),e._completeHide(o)}}static dataApiKeydownHandler(t){const e=/input|textarea/i.test(t.target.tagName),i="Escape"===t.key,n=[Oi,xi].includes(t.key);if(!n&&!i)return;if(e&&!i)return;t.preventDefault();const s=this.matches(Mi)?this:we.prev(this,Mi)[0]||we.next(this,Mi)[0]||we.findOne(Mi,t.delegateTarget.parentNode),o=Ki.getOrCreateInstance(s);if(n)return t.stopPropagation(),o.show(),void o._selectMenuItem(t);o._isShown()&&(t.stopPropagation(),o.hide(),s.focus())}}fe.on(document,Ii,Mi,Ki.dataApiKeydownHandler),fe.on(document,Ii,Fi,Ki.dataApiKeydownHandler),fe.on(document,$i,Ki.clearMenus),fe.on(document,Ni,Ki.clearMenus),fe.on(document,$i,Mi,(function(t){t.preventDefault(),Ki.getOrCreateInstance(this).toggle()})),Qt(Ki);const Qi="backdrop",Xi="show",Ui=`mousedown.bs.${Qi}`,Gi={className:"modal-backdrop",clickCallback:null,isAnimated:!1,isVisible:!0,rootElement:"body"},Ji={className:"string",clickCallback:"(function|null)",isAnimated:"boolean",isVisible:"boolean",rootElement:"(element|string)"};class Zi extends be{constructor(t){super(),this._config=this._getConfig(t),this._isAppended=!1,this._element=null}static get Default(){return Gi}static get DefaultType(){return Ji}static get NAME(){return Qi}show(t){if(!this._config.isVisible)return void Xt(t);this._append();const e=this._getElement();this._config.isAnimated&&qt(e),e.classList.add(Xi),this._emulateAnimation((()=>{Xt(t)}))}hide(t){this._config.isVisible?(this._getElement().classList.remove(Xi),this._emulateAnimation((()=>{this.dispose(),Xt(t)}))):Xt(t)}dispose(){this._isAppended&&(fe.off(this._element,Ui),this._element.remove(),this._isAppended=!1)}_getElement(){if(!this._element){const t=document.createElement("div");t.className=this._config.className,this._config.isAnimated&&t.classList.add("fade"),this._element=t}return this._element}_configAfterMerge(t){return t.rootElement=Ht(t.rootElement),t}_append(){if(this._isAppended)return;const t=this._getElement();this._config.rootElement.append(t),fe.on(t,Ui,(()=>{Xt(this._config.clickCallback)})),this._isAppended=!0}_emulateAnimation(t){Ut(t,this._getElement(),this._config.isAnimated)}}const tn=".bs.focustrap",en=`focusin${tn}`,nn=`keydown.tab${tn}`,sn="backward",on={autofocus:!0,trapElement:null},rn={autofocus:"boolean",trapElement:"element"};class an extends be{constructor(t){super(),this._config=this._getConfig(t),this._isActive=!1,this._lastTabNavDirection=null}static get Default(){return on}static get DefaultType(){return rn}static get NAME(){return"focustrap"}activate(){this._isActive||(this._config.autofocus&&this._config.trapElement.focus(),fe.off(document,tn),fe.on(document,en,(t=>this._handleFocusin(t))),fe.on(document,nn,(t=>this._handleKeydown(t))),this._isActive=!0)}deactivate(){this._isActive&&(this._isActive=!1,fe.off(document,tn))}_handleFocusin(t){const{trapElement:e}=this._config;if(t.target===document||t.target===e||e.contains(t.target))return;const i=we.focusableChildren(e);0===i.length?e.focus():this._lastTabNavDirection===sn?i[i.length-1].focus():i[0].focus()}_handleKeydown(t){"Tab"===t.key&&(this._lastTabNavDirection=t.shiftKey?sn:"forward")}}const ln=".fixed-top, .fixed-bottom, .is-fixed, .sticky-top",cn=".sticky-top",hn="padding-right",dn="margin-right";class un{constructor(){this._element=document.body}getWidth(){const t=document.documentElement.clientWidth;return Math.abs(window.innerWidth-t)}hide(){const t=this.getWidth();this._disableOverFlow(),this._setElementAttributes(this._element,hn,(e=>e+t)),this._setElementAttributes(ln,hn,(e=>e+t)),this._setElementAttributes(cn,dn,(e=>e-t))}reset(){this._resetElementAttributes(this._element,"overflow"),this._resetElementAttributes(this._element,hn),this._resetElementAttributes(ln,hn),this._resetElementAttributes(cn,dn)}isOverflowing(){return this.getWidth()>0}_disableOverFlow(){this._saveInitialAttribute(this._element,"overflow"),this._element.style.overflow="hidden"}_setElementAttributes(t,e,i){const n=this.getWidth();this._applyManipulationCallback(t,(t=>{if(t!==this._element&&window.innerWidth>t.clientWidth+n)return;this._saveInitialAttribute(t,e);const s=window.getComputedStyle(t).getPropertyValue(e);t.style.setProperty(e,`${i(Number.parseFloat(s))}px`)}))}_saveInitialAttribute(t,e){const i=t.style.getPropertyValue(e);i&&_e.setDataAttribute(t,e,i)}_resetElementAttributes(t,e){this._applyManipulationCallback(t,(t=>{const i=_e.getDataAttribute(t,e);null!==i?(_e.removeDataAttribute(t,e),t.style.setProperty(e,i)):t.style.removeProperty(e)}))}_applyManipulationCallback(t,e){if(Ft(t))e(t);else for(const i of we.find(t,this._element))e(i)}}const fn=".bs.modal",pn=`hide${fn}`,mn=`hidePrevented${fn}`,gn=`hidden${fn}`,_n=`show${fn}`,bn=`shown${fn}`,vn=`resize${fn}`,yn=`click.dismiss${fn}`,wn=`mousedown.dismiss${fn}`,En=`keydown.dismiss${fn}`,An=`click${fn}.data-api`,Tn="modal-open",Cn="show",On="modal-static",xn={backdrop:!0,focus:!0,keyboard:!0},kn={backdrop:"(boolean|string)",focus:"boolean",keyboard:"boolean"};class Ln extends ve{constructor(t,e){super(t,e),this._dialog=we.findOne(".modal-dialog",this._element),this._backdrop=this._initializeBackDrop(),this._focustrap=this._initializeFocusTrap(),this._isShown=!1,this._isTransitioning=!1,this._scrollBar=new un,this._addEventListeners()}static get Default(){return xn}static get DefaultType(){return kn}static get NAME(){return"modal"}toggle(t){return this._isShown?this.hide():this.show(t)}show(t){this._isShown||this._isTransitioning||fe.trigger(this._element,_n,{relatedTarget:t}).defaultPrevented||(this._isShown=!0,this._isTransitioning=!0,this._scrollBar.hide(),document.body.classList.add(Tn),this._adjustDialog(),this._backdrop.show((()=>this._showElement(t))))}hide(){this._isShown&&!this._isTransitioning&&(fe.trigger(this._element,pn).defaultPrevented||(this._isShown=!1,this._isTransitioning=!0,this._focustrap.deactivate(),this._element.classList.remove(Cn),this._queueCallback((()=>this._hideModal()),this._element,this._isAnimated())))}dispose(){fe.off(window,fn),fe.off(this._dialog,fn),this._backdrop.dispose(),this._focustrap.deactivate(),super.dispose()}handleUpdate(){this._adjustDialog()}_initializeBackDrop(){return new Zi({isVisible:Boolean(this._config.backdrop),isAnimated:this._isAnimated()})}_initializeFocusTrap(){return new an({trapElement:this._element})}_showElement(t){document.body.contains(this._element)||document.body.append(this._element),this._element.style.display="block",this._element.removeAttribute("aria-hidden"),this._element.setAttribute("aria-modal",!0),this._element.setAttribute("role","dialog"),this._element.scrollTop=0;const e=we.findOne(".modal-body",this._dialog);e&&(e.scrollTop=0),qt(this._element),this._element.classList.add(Cn),this._queueCallback((()=>{this._config.focus&&this._focustrap.activate(),this._isTransitioning=!1,fe.trigger(this._element,bn,{relatedTarget:t})}),this._dialog,this._isAnimated())}_addEventListeners(){fe.on(this._element,En,(t=>{"Escape"===t.key&&(this._config.keyboard?this.hide():this._triggerBackdropTransition())})),fe.on(window,vn,(()=>{this._isShown&&!this._isTransitioning&&this._adjustDialog()})),fe.on(this._element,wn,(t=>{fe.one(this._element,yn,(e=>{this._element===t.target&&this._element===e.target&&("static"!==this._config.backdrop?this._config.backdrop&&this.hide():this._triggerBackdropTransition())}))}))}_hideModal(){this._element.style.display="none",this._element.setAttribute("aria-hidden",!0),this._element.removeAttribute("aria-modal"),this._element.removeAttribute("role"),this._isTransitioning=!1,this._backdrop.hide((()=>{document.body.classList.remove(Tn),this._resetAdjustments(),this._scrollBar.reset(),fe.trigger(this._element,gn)}))}_isAnimated(){return this._element.classList.contains("fade")}_triggerBackdropTransition(){if(fe.trigger(this._element,mn).defaultPrevented)return;const t=this._element.scrollHeight>document.documentElement.clientHeight,e=this._element.style.overflowY;"hidden"===e||this._element.classList.contains(On)||(t||(this._element.style.overflowY="hidden"),this._element.classList.add(On),this._queueCallback((()=>{this._element.classList.remove(On),this._queueCallback((()=>{this._element.style.overflowY=e}),this._dialog)}),this._dialog),this._element.focus())}_adjustDialog(){const t=this._element.scrollHeight>document.documentElement.clientHeight,e=this._scrollBar.getWidth(),i=e>0;if(i&&!t){const t=Kt()?"paddingLeft":"paddingRight";this._element.style[t]=`${e}px`}if(!i&&t){const t=Kt()?"paddingRight":"paddingLeft";this._element.style[t]=`${e}px`}}_resetAdjustments(){this._element.style.paddingLeft="",this._element.style.paddingRight=""}static jQueryInterface(t,e){return this.each((function(){const i=Ln.getOrCreateInstance(this,t);if("string"==typeof t){if(void 0===i[t])throw new TypeError(`No method named "${t}"`);i[t](e)}}))}}fe.on(document,An,'[data-bs-toggle="modal"]',(function(t){const e=we.getElementFromSelector(this);["A","AREA"].includes(this.tagName)&&t.preventDefault(),fe.one(e,_n,(t=>{t.defaultPrevented||fe.one(e,gn,(()=>{Bt(this)&&this.focus()}))}));const i=we.findOne(".modal.show");i&&Ln.getInstance(i).hide(),Ln.getOrCreateInstance(e).toggle(this)})),Ee(Ln),Qt(Ln);const Sn=".bs.offcanvas",Dn=".data-api",$n=`load${Sn}${Dn}`,In="show",Nn="showing",Pn="hiding",Mn=".offcanvas.show",jn=`show${Sn}`,Fn=`shown${Sn}`,Hn=`hide${Sn}`,Bn=`hidePrevented${Sn}`,Wn=`hidden${Sn}`,zn=`resize${Sn}`,Rn=`click${Sn}${Dn}`,qn=`keydown.dismiss${Sn}`,Vn={backdrop:!0,keyboard:!0,scroll:!1},Yn={backdrop:"(boolean|string)",keyboard:"boolean",scroll:"boolean"};class Kn extends ve{constructor(t,e){super(t,e),this._isShown=!1,this._backdrop=this._initializeBackDrop(),this._focustrap=this._initializeFocusTrap(),this._addEventListeners()}static get Default(){return Vn}static get DefaultType(){return Yn}static get NAME(){return"offcanvas"}toggle(t){return this._isShown?this.hide():this.show(t)}show(t){this._isShown||fe.trigger(this._element,jn,{relatedTarget:t}).defaultPrevented||(this._isShown=!0,this._backdrop.show(),this._config.scroll||(new un).hide(),this._element.setAttribute("aria-modal",!0),this._element.setAttribute("role","dialog"),this._element.classList.add(Nn),this._queueCallback((()=>{this._config.scroll&&!this._config.backdrop||this._focustrap.activate(),this._element.classList.add(In),this._element.classList.remove(Nn),fe.trigger(this._element,Fn,{relatedTarget:t})}),this._element,!0))}hide(){this._isShown&&(fe.trigger(this._element,Hn).defaultPrevented||(this._focustrap.deactivate(),this._element.blur(),this._isShown=!1,this._element.classList.add(Pn),this._backdrop.hide(),this._queueCallback((()=>{this._element.classList.remove(In,Pn),this._element.removeAttribute("aria-modal"),this._element.removeAttribute("role"),this._config.scroll||(new un).reset(),fe.trigger(this._element,Wn)}),this._element,!0)))}dispose(){this._backdrop.dispose(),this._focustrap.deactivate(),super.dispose()}_initializeBackDrop(){const t=Boolean(this._config.backdrop);return new Zi({className:"offcanvas-backdrop",isVisible:t,isAnimated:!0,rootElement:this._element.parentNode,clickCallback:t?()=>{"static"!==this._config.backdrop?this.hide():fe.trigger(this._element,Bn)}:null})}_initializeFocusTrap(){return new an({trapElement:this._element})}_addEventListeners(){fe.on(this._element,qn,(t=>{"Escape"===t.key&&(this._config.keyboard?this.hide():fe.trigger(this._element,Bn))}))}static jQueryInterface(t){return this.each((function(){const e=Kn.getOrCreateInstance(this,t);if("string"==typeof t){if(void 0===e[t]||t.startsWith("_")||"constructor"===t)throw new TypeError(`No method named "${t}"`);e[t](this)}}))}}fe.on(document,Rn,'[data-bs-toggle="offcanvas"]',(function(t){const e=we.getElementFromSelector(this);if(["A","AREA"].includes(this.tagName)&&t.preventDefault(),Wt(this))return;fe.one(e,Wn,(()=>{Bt(this)&&this.focus()}));const i=we.findOne(Mn);i&&i!==e&&Kn.getInstance(i).hide(),Kn.getOrCreateInstance(e).toggle(this)})),fe.on(window,$n,(()=>{for(const t of we.find(Mn))Kn.getOrCreateInstance(t).show()})),fe.on(window,zn,(()=>{for(const t of we.find("[aria-modal][class*=show][class*=offcanvas-]"))"fixed"!==getComputedStyle(t).position&&Kn.getOrCreateInstance(t).hide()})),Ee(Kn),Qt(Kn);const Qn={"*":["class","dir","id","lang","role",/^aria-[\w-]*$/i],a:["target","href","title","rel"],area:[],b:[],br:[],col:[],code:[],dd:[],div:[],dl:[],dt:[],em:[],hr:[],h1:[],h2:[],h3:[],h4:[],h5:[],h6:[],i:[],img:["src","srcset","alt","title","width","height"],li:[],ol:[],p:[],pre:[],s:[],small:[],span:[],sub:[],sup:[],strong:[],u:[],ul:[]},Xn=new Set(["background","cite","href","itemtype","longdesc","poster","src","xlink:href"]),Un=/^(?!javascript:)(?:[a-z0-9+.-]+:|[^&:/?#]*(?:[/?#]|$))/i,Gn=(t,e)=>{const i=t.nodeName.toLowerCase();return e.includes(i)?!Xn.has(i)||Boolean(Un.test(t.nodeValue)):e.filter((t=>t instanceof RegExp)).some((t=>t.test(i)))},Jn={allowList:Qn,content:{},extraClass:"",html:!1,sanitize:!0,sanitizeFn:null,template:"

"},Zn={allowList:"object",content:"object",extraClass:"(string|function)",html:"boolean",sanitize:"boolean",sanitizeFn:"(null|function)",template:"string"},ts={entry:"(string|element|function|null)",selector:"(string|element)"};class es extends be{constructor(t){super(),this._config=this._getConfig(t)}static get Default(){return Jn}static get DefaultType(){return Zn}static get NAME(){return"TemplateFactory"}getContent(){return Object.values(this._config.content).map((t=>this._resolvePossibleFunction(t))).filter(Boolean)}hasContent(){return this.getContent().length>0}changeContent(t){return this._checkContent(t),this._config.content={...this._config.content,...t},this}toHtml(){const t=document.createElement("div");t.innerHTML=this._maybeSanitize(this._config.template);for(const[e,i]of Object.entries(this._config.content))this._setContent(t,i,e);const e=t.children[0],i=this._resolvePossibleFunction(this._config.extraClass);return i&&e.classList.add(...i.split(" ")),e}_typeCheckConfig(t){super._typeCheckConfig(t),this._checkContent(t.content)}_checkContent(t){for(const[e,i]of Object.entries(t))super._typeCheckConfig({selector:e,entry:i},ts)}_setContent(t,e,i){const n=we.findOne(i,t);n&&((e=this._resolvePossibleFunction(e))?Ft(e)?this._putElementInTemplate(Ht(e),n):this._config.html?n.innerHTML=this._maybeSanitize(e):n.textContent=e:n.remove())}_maybeSanitize(t){return this._config.sanitize?function(t,e,i){if(!t.length)return t;if(i&&"function"==typeof i)return i(t);const n=(new window.DOMParser).parseFromString(t,"text/html"),s=[].concat(...n.body.querySelectorAll("*"));for(const t of s){const i=t.nodeName.toLowerCase();if(!Object.keys(e).includes(i)){t.remove();continue}const n=[].concat(...t.attributes),s=[].concat(e["*"]||[],e[i]||[]);for(const e of n)Gn(e,s)||t.removeAttribute(e.nodeName)}return n.body.innerHTML}(t,this._config.allowList,this._config.sanitizeFn):t}_resolvePossibleFunction(t){return Xt(t,[this])}_putElementInTemplate(t,e){if(this._config.html)return e.innerHTML="",void e.append(t);e.textContent=t.textContent}}const is=new Set(["sanitize","allowList","sanitizeFn"]),ns="fade",ss="show",os=".tooltip-inner",rs=".modal",as="hide.bs.modal",ls="hover",cs="focus",hs={AUTO:"auto",TOP:"top",RIGHT:Kt()?"left":"right",BOTTOM:"bottom",LEFT:Kt()?"right":"left"},ds={allowList:Qn,animation:!0,boundary:"clippingParents",container:!1,customClass:"",delay:0,fallbackPlacements:["top","right","bottom","left"],html:!1,offset:[0,6],placement:"top",popperConfig:null,sanitize:!0,sanitizeFn:null,selector:!1,template:'',title:"",trigger:"hover focus"},us={allowList:"object",animation:"boolean",boundary:"(string|element)",container:"(string|element|boolean)",customClass:"(string|function)",delay:"(number|object)",fallbackPlacements:"array",html:"boolean",offset:"(array|string|function)",placement:"(string|function)",popperConfig:"(null|object|function)",sanitize:"boolean",sanitizeFn:"(null|function)",selector:"(string|boolean)",template:"string",title:"(string|element|function)",trigger:"string"};class fs extends ve{constructor(t,i){if(void 0===e)throw new TypeError("Bootstrap's tooltips require Popper (https://popper.js.org)");super(t,i),this._isEnabled=!0,this._timeout=0,this._isHovered=null,this._activeTrigger={},this._popper=null,this._templateFactory=null,this._newContent=null,this.tip=null,this._setListeners(),this._config.selector||this._fixTitle()}static get Default(){return ds}static get DefaultType(){return us}static get NAME(){return"tooltip"}enable(){this._isEnabled=!0}disable(){this._isEnabled=!1}toggleEnabled(){this._isEnabled=!this._isEnabled}toggle(){this._isEnabled&&(this._activeTrigger.click=!this._activeTrigger.click,this._isShown()?this._leave():this._enter())}dispose(){clearTimeout(this._timeout),fe.off(this._element.closest(rs),as,this._hideModalHandler),this._element.getAttribute("data-bs-original-title")&&this._element.setAttribute("title",this._element.getAttribute("data-bs-original-title")),this._disposePopper(),super.dispose()}show(){if("none"===this._element.style.display)throw new Error("Please use show on visible elements");if(!this._isWithContent()||!this._isEnabled)return;const t=fe.trigger(this._element,this.constructor.eventName("show")),e=(zt(this._element)||this._element.ownerDocument.documentElement).contains(this._element);if(t.defaultPrevented||!e)return;this._disposePopper();const i=this._getTipElement();this._element.setAttribute("aria-describedby",i.getAttribute("id"));const{container:n}=this._config;if(this._element.ownerDocument.documentElement.contains(this.tip)||(n.append(i),fe.trigger(this._element,this.constructor.eventName("inserted"))),this._popper=this._createPopper(i),i.classList.add(ss),"ontouchstart"in document.documentElement)for(const t of[].concat(...document.body.children))fe.on(t,"mouseover",Rt);this._queueCallback((()=>{fe.trigger(this._element,this.constructor.eventName("shown")),!1===this._isHovered&&this._leave(),this._isHovered=!1}),this.tip,this._isAnimated())}hide(){if(this._isShown()&&!fe.trigger(this._element,this.constructor.eventName("hide")).defaultPrevented){if(this._getTipElement().classList.remove(ss),"ontouchstart"in document.documentElement)for(const t of[].concat(...document.body.children))fe.off(t,"mouseover",Rt);this._activeTrigger.click=!1,this._activeTrigger[cs]=!1,this._activeTrigger[ls]=!1,this._isHovered=null,this._queueCallback((()=>{this._isWithActiveTrigger()||(this._isHovered||this._disposePopper(),this._element.removeAttribute("aria-describedby"),fe.trigger(this._element,this.constructor.eventName("hidden")))}),this.tip,this._isAnimated())}}update(){this._popper&&this._popper.update()}_isWithContent(){return Boolean(this._getTitle())}_getTipElement(){return this.tip||(this.tip=this._createTipElement(this._newContent||this._getContentForTemplate())),this.tip}_createTipElement(t){const e=this._getTemplateFactory(t).toHtml();if(!e)return null;e.classList.remove(ns,ss),e.classList.add(`bs-${this.constructor.NAME}-auto`);const i=(t=>{do{t+=Math.floor(1e6*Math.random())}while(document.getElementById(t));return t})(this.constructor.NAME).toString();return e.setAttribute("id",i),this._isAnimated()&&e.classList.add(ns),e}setContent(t){this._newContent=t,this._isShown()&&(this._disposePopper(),this.show())}_getTemplateFactory(t){return this._templateFactory?this._templateFactory.changeContent(t):this._templateFactory=new es({...this._config,content:t,extraClass:this._resolvePossibleFunction(this._config.customClass)}),this._templateFactory}_getContentForTemplate(){return{[os]:this._getTitle()}}_getTitle(){return this._resolvePossibleFunction(this._config.title)||this._element.getAttribute("data-bs-original-title")}_initializeOnDelegatedTarget(t){return this.constructor.getOrCreateInstance(t.delegateTarget,this._getDelegateConfig())}_isAnimated(){return this._config.animation||this.tip&&this.tip.classList.contains(ns)}_isShown(){return this.tip&&this.tip.classList.contains(ss)}_createPopper(t){const e=Xt(this._config.placement,[this,t,this._element]),i=hs[e.toUpperCase()];return Dt(this._element,t,this._getPopperConfig(i))}_getOffset(){const{offset:t}=this._config;return"string"==typeof t?t.split(",").map((t=>Number.parseInt(t,10))):"function"==typeof t?e=>t(e,this._element):t}_resolvePossibleFunction(t){return Xt(t,[this._element])}_getPopperConfig(t){const e={placement:t,modifiers:[{name:"flip",options:{fallbackPlacements:this._config.fallbackPlacements}},{name:"offset",options:{offset:this._getOffset()}},{name:"preventOverflow",options:{boundary:this._config.boundary}},{name:"arrow",options:{element:`.${this.constructor.NAME}-arrow`}},{name:"preSetPlacement",enabled:!0,phase:"beforeMain",fn:t=>{this._getTipElement().setAttribute("data-popper-placement",t.state.placement)}}]};return{...e,...Xt(this._config.popperConfig,[e])}}_setListeners(){const t=this._config.trigger.split(" ");for(const e of t)if("click"===e)fe.on(this._element,this.constructor.eventName("click"),this._config.selector,(t=>{this._initializeOnDelegatedTarget(t).toggle()}));else if("manual"!==e){const t=e===ls?this.constructor.eventName("mouseenter"):this.constructor.eventName("focusin"),i=e===ls?this.constructor.eventName("mouseleave"):this.constructor.eventName("focusout");fe.on(this._element,t,this._config.selector,(t=>{const e=this._initializeOnDelegatedTarget(t);e._activeTrigger["focusin"===t.type?cs:ls]=!0,e._enter()})),fe.on(this._element,i,this._config.selector,(t=>{const e=this._initializeOnDelegatedTarget(t);e._activeTrigger["focusout"===t.type?cs:ls]=e._element.contains(t.relatedTarget),e._leave()}))}this._hideModalHandler=()=>{this._element&&this.hide()},fe.on(this._element.closest(rs),as,this._hideModalHandler)}_fixTitle(){const t=this._element.getAttribute("title");t&&(this._element.getAttribute("aria-label")||this._element.textContent.trim()||this._element.setAttribute("aria-label",t),this._element.setAttribute("data-bs-original-title",t),this._element.removeAttribute("title"))}_enter(){this._isShown()||this._isHovered?this._isHovered=!0:(this._isHovered=!0,this._setTimeout((()=>{this._isHovered&&this.show()}),this._config.delay.show))}_leave(){this._isWithActiveTrigger()||(this._isHovered=!1,this._setTimeout((()=>{this._isHovered||this.hide()}),this._config.delay.hide))}_setTimeout(t,e){clearTimeout(this._timeout),this._timeout=setTimeout(t,e)}_isWithActiveTrigger(){return Object.values(this._activeTrigger).includes(!0)}_getConfig(t){const e=_e.getDataAttributes(this._element);for(const t of Object.keys(e))is.has(t)&&delete e[t];return t={...e,..."object"==typeof t&&t?t:{}},t=this._mergeConfigObj(t),t=this._configAfterMerge(t),this._typeCheckConfig(t),t}_configAfterMerge(t){return t.container=!1===t.container?document.body:Ht(t.container),"number"==typeof t.delay&&(t.delay={show:t.delay,hide:t.delay}),"number"==typeof t.title&&(t.title=t.title.toString()),"number"==typeof t.content&&(t.content=t.content.toString()),t}_getDelegateConfig(){const t={};for(const[e,i]of Object.entries(this._config))this.constructor.Default[e]!==i&&(t[e]=i);return t.selector=!1,t.trigger="manual",t}_disposePopper(){this._popper&&(this._popper.destroy(),this._popper=null),this.tip&&(this.tip.remove(),this.tip=null)}static jQueryInterface(t){return this.each((function(){const e=fs.getOrCreateInstance(this,t);if("string"==typeof t){if(void 0===e[t])throw new TypeError(`No method named "${t}"`);e[t]()}}))}}Qt(fs);const ps=".popover-header",ms=".popover-body",gs={...fs.Default,content:"",offset:[0,8],placement:"right",template:'',trigger:"click"},_s={...fs.DefaultType,content:"(null|string|element|function)"};class bs extends fs{static get Default(){return gs}static get DefaultType(){return _s}static get NAME(){return"popover"}_isWithContent(){return this._getTitle()||this._getContent()}_getContentForTemplate(){return{[ps]:this._getTitle(),[ms]:this._getContent()}}_getContent(){return this._resolvePossibleFunction(this._config.content)}static jQueryInterface(t){return this.each((function(){const e=bs.getOrCreateInstance(this,t);if("string"==typeof t){if(void 0===e[t])throw new TypeError(`No method named "${t}"`);e[t]()}}))}}Qt(bs);const vs=".bs.scrollspy",ys=`activate${vs}`,ws=`click${vs}`,Es=`load${vs}.data-api`,As="active",Ts="[href]",Cs=".nav-link",Os=`${Cs}, .nav-item > ${Cs}, .list-group-item`,xs={offset:null,rootMargin:"0px 0px -25%",smoothScroll:!1,target:null,threshold:[.1,.5,1]},ks={offset:"(number|null)",rootMargin:"string",smoothScroll:"boolean",target:"element",threshold:"array"};class Ls extends ve{constructor(t,e){super(t,e),this._targetLinks=new Map,this._observableSections=new Map,this._rootElement="visible"===getComputedStyle(this._element).overflowY?null:this._element,this._activeTarget=null,this._observer=null,this._previousScrollData={visibleEntryTop:0,parentScrollTop:0},this.refresh()}static get Default(){return xs}static get DefaultType(){return ks}static get NAME(){return"scrollspy"}refresh(){this._initializeTargetsAndObservables(),this._maybeEnableSmoothScroll(),this._observer?this._observer.disconnect():this._observer=this._getNewObserver();for(const t of this._observableSections.values())this._observer.observe(t)}dispose(){this._observer.disconnect(),super.dispose()}_configAfterMerge(t){return t.target=Ht(t.target)||document.body,t.rootMargin=t.offset?`${t.offset}px 0px -30%`:t.rootMargin,"string"==typeof t.threshold&&(t.threshold=t.threshold.split(",").map((t=>Number.parseFloat(t)))),t}_maybeEnableSmoothScroll(){this._config.smoothScroll&&(fe.off(this._config.target,ws),fe.on(this._config.target,ws,Ts,(t=>{const e=this._observableSections.get(t.target.hash);if(e){t.preventDefault();const i=this._rootElement||window,n=e.offsetTop-this._element.offsetTop;if(i.scrollTo)return void i.scrollTo({top:n,behavior:"smooth"});i.scrollTop=n}})))}_getNewObserver(){const t={root:this._rootElement,threshold:this._config.threshold,rootMargin:this._config.rootMargin};return new IntersectionObserver((t=>this._observerCallback(t)),t)}_observerCallback(t){const e=t=>this._targetLinks.get(`#${t.target.id}`),i=t=>{this._previousScrollData.visibleEntryTop=t.target.offsetTop,this._process(e(t))},n=(this._rootElement||document.documentElement).scrollTop,s=n>=this._previousScrollData.parentScrollTop;this._previousScrollData.parentScrollTop=n;for(const o of t){if(!o.isIntersecting){this._activeTarget=null,this._clearActiveClass(e(o));continue}const t=o.target.offsetTop>=this._previousScrollData.visibleEntryTop;if(s&&t){if(i(o),!n)return}else s||t||i(o)}}_initializeTargetsAndObservables(){this._targetLinks=new Map,this._observableSections=new Map;const t=we.find(Ts,this._config.target);for(const e of t){if(!e.hash||Wt(e))continue;const t=we.findOne(decodeURI(e.hash),this._element);Bt(t)&&(this._targetLinks.set(decodeURI(e.hash),e),this._observableSections.set(e.hash,t))}}_process(t){this._activeTarget!==t&&(this._clearActiveClass(this._config.target),this._activeTarget=t,t.classList.add(As),this._activateParents(t),fe.trigger(this._element,ys,{relatedTarget:t}))}_activateParents(t){if(t.classList.contains("dropdown-item"))we.findOne(".dropdown-toggle",t.closest(".dropdown")).classList.add(As);else for(const e of we.parents(t,".nav, .list-group"))for(const t of we.prev(e,Os))t.classList.add(As)}_clearActiveClass(t){t.classList.remove(As);const e=we.find(`${Ts}.${As}`,t);for(const t of e)t.classList.remove(As)}static jQueryInterface(t){return this.each((function(){const e=Ls.getOrCreateInstance(this,t);if("string"==typeof t){if(void 0===e[t]||t.startsWith("_")||"constructor"===t)throw new TypeError(`No method named "${t}"`);e[t]()}}))}}fe.on(window,Es,(()=>{for(const t of we.find('[data-bs-spy="scroll"]'))Ls.getOrCreateInstance(t)})),Qt(Ls);const Ss=".bs.tab",Ds=`hide${Ss}`,$s=`hidden${Ss}`,Is=`show${Ss}`,Ns=`shown${Ss}`,Ps=`click${Ss}`,Ms=`keydown${Ss}`,js=`load${Ss}`,Fs="ArrowLeft",Hs="ArrowRight",Bs="ArrowUp",Ws="ArrowDown",zs="Home",Rs="End",qs="active",Vs="fade",Ys="show",Ks=".dropdown-toggle",Qs=`:not(${Ks})`,Xs='[data-bs-toggle="tab"], [data-bs-toggle="pill"], [data-bs-toggle="list"]',Us=`.nav-link${Qs}, .list-group-item${Qs}, [role="tab"]${Qs}, ${Xs}`,Gs=`.${qs}[data-bs-toggle="tab"], .${qs}[data-bs-toggle="pill"], .${qs}[data-bs-toggle="list"]`;class Js extends ve{constructor(t){super(t),this._parent=this._element.closest('.list-group, .nav, [role="tablist"]'),this._parent&&(this._setInitialAttributes(this._parent,this._getChildren()),fe.on(this._element,Ms,(t=>this._keydown(t))))}static get NAME(){return"tab"}show(){const t=this._element;if(this._elemIsActive(t))return;const e=this._getActiveElem(),i=e?fe.trigger(e,Ds,{relatedTarget:t}):null;fe.trigger(t,Is,{relatedTarget:e}).defaultPrevented||i&&i.defaultPrevented||(this._deactivate(e,t),this._activate(t,e))}_activate(t,e){t&&(t.classList.add(qs),this._activate(we.getElementFromSelector(t)),this._queueCallback((()=>{"tab"===t.getAttribute("role")?(t.removeAttribute("tabindex"),t.setAttribute("aria-selected",!0),this._toggleDropDown(t,!0),fe.trigger(t,Ns,{relatedTarget:e})):t.classList.add(Ys)}),t,t.classList.contains(Vs)))}_deactivate(t,e){t&&(t.classList.remove(qs),t.blur(),this._deactivate(we.getElementFromSelector(t)),this._queueCallback((()=>{"tab"===t.getAttribute("role")?(t.setAttribute("aria-selected",!1),t.setAttribute("tabindex","-1"),this._toggleDropDown(t,!1),fe.trigger(t,$s,{relatedTarget:e})):t.classList.remove(Ys)}),t,t.classList.contains(Vs)))}_keydown(t){if(![Fs,Hs,Bs,Ws,zs,Rs].includes(t.key))return;t.stopPropagation(),t.preventDefault();const e=this._getChildren().filter((t=>!Wt(t)));let i;if([zs,Rs].includes(t.key))i=e[t.key===zs?0:e.length-1];else{const n=[Hs,Ws].includes(t.key);i=Gt(e,t.target,n,!0)}i&&(i.focus({preventScroll:!0}),Js.getOrCreateInstance(i).show())}_getChildren(){return we.find(Us,this._parent)}_getActiveElem(){return this._getChildren().find((t=>this._elemIsActive(t)))||null}_setInitialAttributes(t,e){this._setAttributeIfNotExists(t,"role","tablist");for(const t of e)this._setInitialAttributesOnChild(t)}_setInitialAttributesOnChild(t){t=this._getInnerElement(t);const e=this._elemIsActive(t),i=this._getOuterElement(t);t.setAttribute("aria-selected",e),i!==t&&this._setAttributeIfNotExists(i,"role","presentation"),e||t.setAttribute("tabindex","-1"),this._setAttributeIfNotExists(t,"role","tab"),this._setInitialAttributesOnTargetPanel(t)}_setInitialAttributesOnTargetPanel(t){const e=we.getElementFromSelector(t);e&&(this._setAttributeIfNotExists(e,"role","tabpanel"),t.id&&this._setAttributeIfNotExists(e,"aria-labelledby",`${t.id}`))}_toggleDropDown(t,e){const i=this._getOuterElement(t);if(!i.classList.contains("dropdown"))return;const n=(t,n)=>{const s=we.findOne(t,i);s&&s.classList.toggle(n,e)};n(Ks,qs),n(".dropdown-menu",Ys),i.setAttribute("aria-expanded",e)}_setAttributeIfNotExists(t,e,i){t.hasAttribute(e)||t.setAttribute(e,i)}_elemIsActive(t){return t.classList.contains(qs)}_getInnerElement(t){return t.matches(Us)?t:we.findOne(Us,t)}_getOuterElement(t){return t.closest(".nav-item, .list-group-item")||t}static jQueryInterface(t){return this.each((function(){const e=Js.getOrCreateInstance(this);if("string"==typeof t){if(void 0===e[t]||t.startsWith("_")||"constructor"===t)throw new TypeError(`No method named "${t}"`);e[t]()}}))}}fe.on(document,Ps,Xs,(function(t){["A","AREA"].includes(this.tagName)&&t.preventDefault(),Wt(this)||Js.getOrCreateInstance(this).show()})),fe.on(window,js,(()=>{for(const t of we.find(Gs))Js.getOrCreateInstance(t)})),Qt(Js);const Zs=".bs.toast",to=`mouseover${Zs}`,eo=`mouseout${Zs}`,io=`focusin${Zs}`,no=`focusout${Zs}`,so=`hide${Zs}`,oo=`hidden${Zs}`,ro=`show${Zs}`,ao=`shown${Zs}`,lo="hide",co="show",ho="showing",uo={animation:"boolean",autohide:"boolean",delay:"number"},fo={animation:!0,autohide:!0,delay:5e3};class po extends ve{constructor(t,e){super(t,e),this._timeout=null,this._hasMouseInteraction=!1,this._hasKeyboardInteraction=!1,this._setListeners()}static get Default(){return fo}static get DefaultType(){return uo}static get NAME(){return"toast"}show(){fe.trigger(this._element,ro).defaultPrevented||(this._clearTimeout(),this._config.animation&&this._element.classList.add("fade"),this._element.classList.remove(lo),qt(this._element),this._element.classList.add(co,ho),this._queueCallback((()=>{this._element.classList.remove(ho),fe.trigger(this._element,ao),this._maybeScheduleHide()}),this._element,this._config.animation))}hide(){this.isShown()&&(fe.trigger(this._element,so).defaultPrevented||(this._element.classList.add(ho),this._queueCallback((()=>{this._element.classList.add(lo),this._element.classList.remove(ho,co),fe.trigger(this._element,oo)}),this._element,this._config.animation)))}dispose(){this._clearTimeout(),this.isShown()&&this._element.classList.remove(co),super.dispose()}isShown(){return this._element.classList.contains(co)}_maybeScheduleHide(){this._config.autohide&&(this._hasMouseInteraction||this._hasKeyboardInteraction||(this._timeout=setTimeout((()=>{this.hide()}),this._config.delay)))}_onInteraction(t,e){switch(t.type){case"mouseover":case"mouseout":this._hasMouseInteraction=e;break;case"focusin":case"focusout":this._hasKeyboardInteraction=e}if(e)return void this._clearTimeout();const i=t.relatedTarget;this._element===i||this._element.contains(i)||this._maybeScheduleHide()}_setListeners(){fe.on(this._element,to,(t=>this._onInteraction(t,!0))),fe.on(this._element,eo,(t=>this._onInteraction(t,!1))),fe.on(this._element,io,(t=>this._onInteraction(t,!0))),fe.on(this._element,no,(t=>this._onInteraction(t,!1)))}_clearTimeout(){clearTimeout(this._timeout),this._timeout=null}static jQueryInterface(t){return this.each((function(){const e=po.getOrCreateInstance(this,t);if("string"==typeof t){if(void 0===e[t])throw new TypeError(`No method named "${t}"`);e[t](this)}}))}}function mo(t){"loading"!=document.readyState?t():document.addEventListener("DOMContentLoaded",t)}Ee(po),Qt(po),mo((function(){[].slice.call(document.querySelectorAll('[data-bs-toggle="tooltip"]')).map((function(t){return new fs(t,{delay:{show:500,hide:100}})}))})),mo((function(){document.getElementById("pst-back-to-top").addEventListener("click",(function(){document.body.scrollTop=0,document.documentElement.scrollTop=0}))})),mo((function(){var t=document.getElementById("pst-back-to-top"),e=document.getElementsByClassName("bd-header")[0].getBoundingClientRect();window.addEventListener("scroll",(function(){this.oldScroll>this.scrollY&&this.scrollY>e.bottom?t.style.display="block":t.style.display="none",this.oldScroll=this.scrollY}))})),window.bootstrap=i})(); +//# sourceMappingURL=bootstrap.js.map \ No newline at end of file diff --git a/_static/scripts/bootstrap.js.LICENSE.txt b/_static/scripts/bootstrap.js.LICENSE.txt new file mode 100644 index 0000000000..28755c2c5b --- /dev/null +++ b/_static/scripts/bootstrap.js.LICENSE.txt @@ -0,0 +1,5 @@ +/*! + * Bootstrap v5.3.3 (https://getbootstrap.com/) + * Copyright 2011-2024 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) + */ diff --git a/_static/scripts/bootstrap.js.map b/_static/scripts/bootstrap.js.map new file mode 100644 index 0000000000..4a3502aeb2 --- /dev/null +++ b/_static/scripts/bootstrap.js.map @@ -0,0 +1 @@ +{"version":3,"file":"scripts/bootstrap.js","mappings":"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","sources":["webpack://pydata_sphinx_theme/webpack/bootstrap","webpack://pydata_sphinx_theme/webpack/runtime/define property getters","webpack://pydata_sphinx_theme/webpack/runtime/hasOwnProperty shorthand","webpack://pydata_sphinx_theme/webpack/runtime/make namespace object","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/enums.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getNodeName.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getWindow.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/instanceOf.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/modifiers/applyStyles.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/getBasePlacement.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/math.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/userAgent.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/isLayoutViewport.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/contains.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/isTableElement.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getParentNode.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/getMainAxisFromPlacement.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/within.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/mergePaddingObject.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/getFreshSideObject.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/expandToHashMap.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/modifiers/arrow.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/getVariation.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/modifiers/computeStyles.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/modifiers/eventListeners.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/getOppositePlacement.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/getOppositeVariationPlacement.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/rectToClientRect.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/computeOffsets.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/detectOverflow.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/modifiers/flip.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/computeAutoPlacement.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/modifiers/hide.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/modifiers/offset.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/modifiers/popperOffsets.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/modifiers/preventOverflow.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/getAltAxis.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/orderModifiers.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/createPopper.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/debounce.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/utils/mergeByName.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/popper.js","webpack://pydata_sphinx_theme/./node_modules/@popperjs/core/lib/popper-lite.js","webpack://pydata_sphinx_theme/./node_modules/bootstrap/dist/js/bootstrap.esm.js","webpack://pydata_sphinx_theme/./src/pydata_sphinx_theme/assets/scripts/mixin.js","webpack://pydata_sphinx_theme/./src/pydata_sphinx_theme/assets/scripts/bootstrap.js"],"sourcesContent":["// The require scope\nvar __webpack_require__ = {};\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","export var top = 'top';\nexport var bottom = 'bottom';\nexport var right = 'right';\nexport var left = 'left';\nexport var auto = 'auto';\nexport var basePlacements = [top, bottom, right, left];\nexport var start = 'start';\nexport var end = 'end';\nexport var clippingParents = 'clippingParents';\nexport var viewport = 'viewport';\nexport var popper = 'popper';\nexport var reference = 'reference';\nexport var variationPlacements = /*#__PURE__*/basePlacements.reduce(function (acc, placement) {\n return acc.concat([placement + \"-\" + start, placement + \"-\" + end]);\n}, []);\nexport var placements = /*#__PURE__*/[].concat(basePlacements, [auto]).reduce(function (acc, placement) {\n return acc.concat([placement, placement + \"-\" + start, placement + \"-\" + end]);\n}, []); // modifiers that need to read the DOM\n\nexport var beforeRead = 'beforeRead';\nexport var read = 'read';\nexport var afterRead = 'afterRead'; // pure-logic modifiers\n\nexport var beforeMain = 'beforeMain';\nexport var main = 'main';\nexport var afterMain = 'afterMain'; // modifier with the purpose to write to the DOM (or write into a framework state)\n\nexport var beforeWrite = 'beforeWrite';\nexport var write = 'write';\nexport var afterWrite = 'afterWrite';\nexport var modifierPhases = [beforeRead, read, afterRead, beforeMain, main, afterMain, beforeWrite, write, afterWrite];","export default function getNodeName(element) {\n return element ? (element.nodeName || '').toLowerCase() : null;\n}","export default function getWindow(node) {\n if (node == null) {\n return window;\n }\n\n if (node.toString() !== '[object Window]') {\n var ownerDocument = node.ownerDocument;\n return ownerDocument ? ownerDocument.defaultView || window : window;\n }\n\n return node;\n}","import getWindow from \"./getWindow.js\";\n\nfunction isElement(node) {\n var OwnElement = getWindow(node).Element;\n return node instanceof OwnElement || node instanceof Element;\n}\n\nfunction isHTMLElement(node) {\n var OwnElement = getWindow(node).HTMLElement;\n return node instanceof OwnElement || node instanceof HTMLElement;\n}\n\nfunction isShadowRoot(node) {\n // IE 11 has no ShadowRoot\n if (typeof ShadowRoot === 'undefined') {\n return false;\n }\n\n var OwnElement = getWindow(node).ShadowRoot;\n return node instanceof OwnElement || node instanceof ShadowRoot;\n}\n\nexport { isElement, isHTMLElement, isShadowRoot };","import getNodeName from \"../dom-utils/getNodeName.js\";\nimport { isHTMLElement } from \"../dom-utils/instanceOf.js\"; // This modifier takes the styles prepared by the `computeStyles` modifier\n// and applies them to the HTMLElements such as popper and arrow\n\nfunction applyStyles(_ref) {\n var state = _ref.state;\n Object.keys(state.elements).forEach(function (name) {\n var style = state.styles[name] || {};\n var attributes = state.attributes[name] || {};\n var element = state.elements[name]; // arrow is optional + virtual elements\n\n if (!isHTMLElement(element) || !getNodeName(element)) {\n return;\n } // Flow doesn't support to extend this property, but it's the most\n // effective way to apply styles to an HTMLElement\n // $FlowFixMe[cannot-write]\n\n\n Object.assign(element.style, style);\n Object.keys(attributes).forEach(function (name) {\n var value = attributes[name];\n\n if (value === false) {\n element.removeAttribute(name);\n } else {\n element.setAttribute(name, value === true ? '' : value);\n }\n });\n });\n}\n\nfunction effect(_ref2) {\n var state = _ref2.state;\n var initialStyles = {\n popper: {\n position: state.options.strategy,\n left: '0',\n top: '0',\n margin: '0'\n },\n arrow: {\n position: 'absolute'\n },\n reference: {}\n };\n Object.assign(state.elements.popper.style, initialStyles.popper);\n state.styles = initialStyles;\n\n if (state.elements.arrow) {\n Object.assign(state.elements.arrow.style, initialStyles.arrow);\n }\n\n return function () {\n Object.keys(state.elements).forEach(function (name) {\n var element = state.elements[name];\n var attributes = state.attributes[name] || {};\n var styleProperties = Object.keys(state.styles.hasOwnProperty(name) ? state.styles[name] : initialStyles[name]); // Set all values to an empty string to unset them\n\n var style = styleProperties.reduce(function (style, property) {\n style[property] = '';\n return style;\n }, {}); // arrow is optional + virtual elements\n\n if (!isHTMLElement(element) || !getNodeName(element)) {\n return;\n }\n\n Object.assign(element.style, style);\n Object.keys(attributes).forEach(function (attribute) {\n element.removeAttribute(attribute);\n });\n });\n };\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'applyStyles',\n enabled: true,\n phase: 'write',\n fn: applyStyles,\n effect: effect,\n requires: ['computeStyles']\n};","import { auto } from \"../enums.js\";\nexport default function getBasePlacement(placement) {\n return placement.split('-')[0];\n}","export var max = Math.max;\nexport var min = Math.min;\nexport var round = Math.round;","export default function getUAString() {\n var uaData = navigator.userAgentData;\n\n if (uaData != null && uaData.brands && Array.isArray(uaData.brands)) {\n return uaData.brands.map(function (item) {\n return item.brand + \"/\" + item.version;\n }).join(' ');\n }\n\n return navigator.userAgent;\n}","import getUAString from \"../utils/userAgent.js\";\nexport default function isLayoutViewport() {\n return !/^((?!chrome|android).)*safari/i.test(getUAString());\n}","import { isElement, isHTMLElement } from \"./instanceOf.js\";\nimport { round } from \"../utils/math.js\";\nimport getWindow from \"./getWindow.js\";\nimport isLayoutViewport from \"./isLayoutViewport.js\";\nexport default function getBoundingClientRect(element, includeScale, isFixedStrategy) {\n if (includeScale === void 0) {\n includeScale = false;\n }\n\n if (isFixedStrategy === void 0) {\n isFixedStrategy = false;\n }\n\n var clientRect = element.getBoundingClientRect();\n var scaleX = 1;\n var scaleY = 1;\n\n if (includeScale && isHTMLElement(element)) {\n scaleX = element.offsetWidth > 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1;\n scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1;\n }\n\n var _ref = isElement(element) ? getWindow(element) : window,\n visualViewport = _ref.visualViewport;\n\n var addVisualOffsets = !isLayoutViewport() && isFixedStrategy;\n var x = (clientRect.left + (addVisualOffsets && visualViewport ? visualViewport.offsetLeft : 0)) / scaleX;\n var y = (clientRect.top + (addVisualOffsets && visualViewport ? visualViewport.offsetTop : 0)) / scaleY;\n var width = clientRect.width / scaleX;\n var height = clientRect.height / scaleY;\n return {\n width: width,\n height: height,\n top: y,\n right: x + width,\n bottom: y + height,\n left: x,\n x: x,\n y: y\n };\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\"; // Returns the layout rect of an element relative to its offsetParent. Layout\n// means it doesn't take into account transforms.\n\nexport default function getLayoutRect(element) {\n var clientRect = getBoundingClientRect(element); // Use the clientRect sizes if it's not been transformed.\n // Fixes https://github.com/popperjs/popper-core/issues/1223\n\n var width = element.offsetWidth;\n var height = element.offsetHeight;\n\n if (Math.abs(clientRect.width - width) <= 1) {\n width = clientRect.width;\n }\n\n if (Math.abs(clientRect.height - height) <= 1) {\n height = clientRect.height;\n }\n\n return {\n x: element.offsetLeft,\n y: element.offsetTop,\n width: width,\n height: height\n };\n}","import { isShadowRoot } from \"./instanceOf.js\";\nexport default function contains(parent, child) {\n var rootNode = child.getRootNode && child.getRootNode(); // First, attempt with faster native method\n\n if (parent.contains(child)) {\n return true;\n } // then fallback to custom implementation with Shadow DOM support\n else if (rootNode && isShadowRoot(rootNode)) {\n var next = child;\n\n do {\n if (next && parent.isSameNode(next)) {\n return true;\n } // $FlowFixMe[prop-missing]: need a better way to handle this...\n\n\n next = next.parentNode || next.host;\n } while (next);\n } // Give up, the result is false\n\n\n return false;\n}","import getWindow from \"./getWindow.js\";\nexport default function getComputedStyle(element) {\n return getWindow(element).getComputedStyle(element);\n}","import getNodeName from \"./getNodeName.js\";\nexport default function isTableElement(element) {\n return ['table', 'td', 'th'].indexOf(getNodeName(element)) >= 0;\n}","import { isElement } from \"./instanceOf.js\";\nexport default function getDocumentElement(element) {\n // $FlowFixMe[incompatible-return]: assume body is always available\n return ((isElement(element) ? element.ownerDocument : // $FlowFixMe[prop-missing]\n element.document) || window.document).documentElement;\n}","import getNodeName from \"./getNodeName.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport { isShadowRoot } from \"./instanceOf.js\";\nexport default function getParentNode(element) {\n if (getNodeName(element) === 'html') {\n return element;\n }\n\n return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle\n // $FlowFixMe[incompatible-return]\n // $FlowFixMe[prop-missing]\n element.assignedSlot || // step into the shadow DOM of the parent of a slotted node\n element.parentNode || ( // DOM Element detected\n isShadowRoot(element) ? element.host : null) || // ShadowRoot detected\n // $FlowFixMe[incompatible-call]: HTMLElement is a Node\n getDocumentElement(element) // fallback\n\n );\n}","import getWindow from \"./getWindow.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport { isHTMLElement, isShadowRoot } from \"./instanceOf.js\";\nimport isTableElement from \"./isTableElement.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport getUAString from \"../utils/userAgent.js\";\n\nfunction getTrueOffsetParent(element) {\n if (!isHTMLElement(element) || // https://github.com/popperjs/popper-core/issues/837\n getComputedStyle(element).position === 'fixed') {\n return null;\n }\n\n return element.offsetParent;\n} // `.offsetParent` reports `null` for fixed elements, while absolute elements\n// return the containing block\n\n\nfunction getContainingBlock(element) {\n var isFirefox = /firefox/i.test(getUAString());\n var isIE = /Trident/i.test(getUAString());\n\n if (isIE && isHTMLElement(element)) {\n // In IE 9, 10 and 11 fixed elements containing block is always established by the viewport\n var elementCss = getComputedStyle(element);\n\n if (elementCss.position === 'fixed') {\n return null;\n }\n }\n\n var currentNode = getParentNode(element);\n\n if (isShadowRoot(currentNode)) {\n currentNode = currentNode.host;\n }\n\n while (isHTMLElement(currentNode) && ['html', 'body'].indexOf(getNodeName(currentNode)) < 0) {\n var css = getComputedStyle(currentNode); // This is non-exhaustive but covers the most common CSS properties that\n // create a containing block.\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n\n if (css.transform !== 'none' || css.perspective !== 'none' || css.contain === 'paint' || ['transform', 'perspective'].indexOf(css.willChange) !== -1 || isFirefox && css.willChange === 'filter' || isFirefox && css.filter && css.filter !== 'none') {\n return currentNode;\n } else {\n currentNode = currentNode.parentNode;\n }\n }\n\n return null;\n} // Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\n\n\nexport default function getOffsetParent(element) {\n var window = getWindow(element);\n var offsetParent = getTrueOffsetParent(element);\n\n while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') {\n offsetParent = getTrueOffsetParent(offsetParent);\n }\n\n if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static')) {\n return window;\n }\n\n return offsetParent || getContainingBlock(element) || window;\n}","export default function getMainAxisFromPlacement(placement) {\n return ['top', 'bottom'].indexOf(placement) >= 0 ? 'x' : 'y';\n}","import { max as mathMax, min as mathMin } from \"./math.js\";\nexport function within(min, value, max) {\n return mathMax(min, mathMin(value, max));\n}\nexport function withinMaxClamp(min, value, max) {\n var v = within(min, value, max);\n return v > max ? max : v;\n}","import getFreshSideObject from \"./getFreshSideObject.js\";\nexport default function mergePaddingObject(paddingObject) {\n return Object.assign({}, getFreshSideObject(), paddingObject);\n}","export default function getFreshSideObject() {\n return {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n };\n}","export default function expandToHashMap(value, keys) {\n return keys.reduce(function (hashMap, key) {\n hashMap[key] = value;\n return hashMap;\n }, {});\n}","import getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getLayoutRect from \"../dom-utils/getLayoutRect.js\";\nimport contains from \"../dom-utils/contains.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport getMainAxisFromPlacement from \"../utils/getMainAxisFromPlacement.js\";\nimport { within } from \"../utils/within.js\";\nimport mergePaddingObject from \"../utils/mergePaddingObject.js\";\nimport expandToHashMap from \"../utils/expandToHashMap.js\";\nimport { left, right, basePlacements, top, bottom } from \"../enums.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar toPaddingObject = function toPaddingObject(padding, state) {\n padding = typeof padding === 'function' ? padding(Object.assign({}, state.rects, {\n placement: state.placement\n })) : padding;\n return mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));\n};\n\nfunction arrow(_ref) {\n var _state$modifiersData$;\n\n var state = _ref.state,\n name = _ref.name,\n options = _ref.options;\n var arrowElement = state.elements.arrow;\n var popperOffsets = state.modifiersData.popperOffsets;\n var basePlacement = getBasePlacement(state.placement);\n var axis = getMainAxisFromPlacement(basePlacement);\n var isVertical = [left, right].indexOf(basePlacement) >= 0;\n var len = isVertical ? 'height' : 'width';\n\n if (!arrowElement || !popperOffsets) {\n return;\n }\n\n var paddingObject = toPaddingObject(options.padding, state);\n var arrowRect = getLayoutRect(arrowElement);\n var minProp = axis === 'y' ? top : left;\n var maxProp = axis === 'y' ? bottom : right;\n var endDiff = state.rects.reference[len] + state.rects.reference[axis] - popperOffsets[axis] - state.rects.popper[len];\n var startDiff = popperOffsets[axis] - state.rects.reference[axis];\n var arrowOffsetParent = getOffsetParent(arrowElement);\n var clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0;\n var centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the popper if the center point is\n // outside of the popper bounds\n\n var min = paddingObject[minProp];\n var max = clientSize - arrowRect[len] - paddingObject[maxProp];\n var center = clientSize / 2 - arrowRect[len] / 2 + centerToReference;\n var offset = within(min, center, max); // Prevents breaking syntax highlighting...\n\n var axisProp = axis;\n state.modifiersData[name] = (_state$modifiersData$ = {}, _state$modifiersData$[axisProp] = offset, _state$modifiersData$.centerOffset = offset - center, _state$modifiersData$);\n}\n\nfunction effect(_ref2) {\n var state = _ref2.state,\n options = _ref2.options;\n var _options$element = options.element,\n arrowElement = _options$element === void 0 ? '[data-popper-arrow]' : _options$element;\n\n if (arrowElement == null) {\n return;\n } // CSS selector\n\n\n if (typeof arrowElement === 'string') {\n arrowElement = state.elements.popper.querySelector(arrowElement);\n\n if (!arrowElement) {\n return;\n }\n }\n\n if (!contains(state.elements.popper, arrowElement)) {\n return;\n }\n\n state.elements.arrow = arrowElement;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'arrow',\n enabled: true,\n phase: 'main',\n fn: arrow,\n effect: effect,\n requires: ['popperOffsets'],\n requiresIfExists: ['preventOverflow']\n};","export default function getVariation(placement) {\n return placement.split('-')[1];\n}","import { top, left, right, bottom, end } from \"../enums.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport getWindow from \"../dom-utils/getWindow.js\";\nimport getDocumentElement from \"../dom-utils/getDocumentElement.js\";\nimport getComputedStyle from \"../dom-utils/getComputedStyle.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getVariation from \"../utils/getVariation.js\";\nimport { round } from \"../utils/math.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar unsetSides = {\n top: 'auto',\n right: 'auto',\n bottom: 'auto',\n left: 'auto'\n}; // Round the offsets to the nearest suitable subpixel based on the DPR.\n// Zooming can change the DPR, but it seems to report a value that will\n// cleanly divide the values into the appropriate subpixels.\n\nfunction roundOffsetsByDPR(_ref, win) {\n var x = _ref.x,\n y = _ref.y;\n var dpr = win.devicePixelRatio || 1;\n return {\n x: round(x * dpr) / dpr || 0,\n y: round(y * dpr) / dpr || 0\n };\n}\n\nexport function mapToStyles(_ref2) {\n var _Object$assign2;\n\n var popper = _ref2.popper,\n popperRect = _ref2.popperRect,\n placement = _ref2.placement,\n variation = _ref2.variation,\n offsets = _ref2.offsets,\n position = _ref2.position,\n gpuAcceleration = _ref2.gpuAcceleration,\n adaptive = _ref2.adaptive,\n roundOffsets = _ref2.roundOffsets,\n isFixed = _ref2.isFixed;\n var _offsets$x = offsets.x,\n x = _offsets$x === void 0 ? 0 : _offsets$x,\n _offsets$y = offsets.y,\n y = _offsets$y === void 0 ? 0 : _offsets$y;\n\n var _ref3 = typeof roundOffsets === 'function' ? roundOffsets({\n x: x,\n y: y\n }) : {\n x: x,\n y: y\n };\n\n x = _ref3.x;\n y = _ref3.y;\n var hasX = offsets.hasOwnProperty('x');\n var hasY = offsets.hasOwnProperty('y');\n var sideX = left;\n var sideY = top;\n var win = window;\n\n if (adaptive) {\n var offsetParent = getOffsetParent(popper);\n var heightProp = 'clientHeight';\n var widthProp = 'clientWidth';\n\n if (offsetParent === getWindow(popper)) {\n offsetParent = getDocumentElement(popper);\n\n if (getComputedStyle(offsetParent).position !== 'static' && position === 'absolute') {\n heightProp = 'scrollHeight';\n widthProp = 'scrollWidth';\n }\n } // $FlowFixMe[incompatible-cast]: force type refinement, we compare offsetParent with window above, but Flow doesn't detect it\n\n\n offsetParent = offsetParent;\n\n if (placement === top || (placement === left || placement === right) && variation === end) {\n sideY = bottom;\n var offsetY = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.height : // $FlowFixMe[prop-missing]\n offsetParent[heightProp];\n y -= offsetY - popperRect.height;\n y *= gpuAcceleration ? 1 : -1;\n }\n\n if (placement === left || (placement === top || placement === bottom) && variation === end) {\n sideX = right;\n var offsetX = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.width : // $FlowFixMe[prop-missing]\n offsetParent[widthProp];\n x -= offsetX - popperRect.width;\n x *= gpuAcceleration ? 1 : -1;\n }\n }\n\n var commonStyles = Object.assign({\n position: position\n }, adaptive && unsetSides);\n\n var _ref4 = roundOffsets === true ? roundOffsetsByDPR({\n x: x,\n y: y\n }, getWindow(popper)) : {\n x: x,\n y: y\n };\n\n x = _ref4.x;\n y = _ref4.y;\n\n if (gpuAcceleration) {\n var _Object$assign;\n\n return Object.assign({}, commonStyles, (_Object$assign = {}, _Object$assign[sideY] = hasY ? '0' : '', _Object$assign[sideX] = hasX ? '0' : '', _Object$assign.transform = (win.devicePixelRatio || 1) <= 1 ? \"translate(\" + x + \"px, \" + y + \"px)\" : \"translate3d(\" + x + \"px, \" + y + \"px, 0)\", _Object$assign));\n }\n\n return Object.assign({}, commonStyles, (_Object$assign2 = {}, _Object$assign2[sideY] = hasY ? y + \"px\" : '', _Object$assign2[sideX] = hasX ? x + \"px\" : '', _Object$assign2.transform = '', _Object$assign2));\n}\n\nfunction computeStyles(_ref5) {\n var state = _ref5.state,\n options = _ref5.options;\n var _options$gpuAccelerat = options.gpuAcceleration,\n gpuAcceleration = _options$gpuAccelerat === void 0 ? true : _options$gpuAccelerat,\n _options$adaptive = options.adaptive,\n adaptive = _options$adaptive === void 0 ? true : _options$adaptive,\n _options$roundOffsets = options.roundOffsets,\n roundOffsets = _options$roundOffsets === void 0 ? true : _options$roundOffsets;\n var commonStyles = {\n placement: getBasePlacement(state.placement),\n variation: getVariation(state.placement),\n popper: state.elements.popper,\n popperRect: state.rects.popper,\n gpuAcceleration: gpuAcceleration,\n isFixed: state.options.strategy === 'fixed'\n };\n\n if (state.modifiersData.popperOffsets != null) {\n state.styles.popper = Object.assign({}, state.styles.popper, mapToStyles(Object.assign({}, commonStyles, {\n offsets: state.modifiersData.popperOffsets,\n position: state.options.strategy,\n adaptive: adaptive,\n roundOffsets: roundOffsets\n })));\n }\n\n if (state.modifiersData.arrow != null) {\n state.styles.arrow = Object.assign({}, state.styles.arrow, mapToStyles(Object.assign({}, commonStyles, {\n offsets: state.modifiersData.arrow,\n position: 'absolute',\n adaptive: false,\n roundOffsets: roundOffsets\n })));\n }\n\n state.attributes.popper = Object.assign({}, state.attributes.popper, {\n 'data-popper-placement': state.placement\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'computeStyles',\n enabled: true,\n phase: 'beforeWrite',\n fn: computeStyles,\n data: {}\n};","import getWindow from \"../dom-utils/getWindow.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar passive = {\n passive: true\n};\n\nfunction effect(_ref) {\n var state = _ref.state,\n instance = _ref.instance,\n options = _ref.options;\n var _options$scroll = options.scroll,\n scroll = _options$scroll === void 0 ? true : _options$scroll,\n _options$resize = options.resize,\n resize = _options$resize === void 0 ? true : _options$resize;\n var window = getWindow(state.elements.popper);\n var scrollParents = [].concat(state.scrollParents.reference, state.scrollParents.popper);\n\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.addEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.addEventListener('resize', instance.update, passive);\n }\n\n return function () {\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.removeEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.removeEventListener('resize', instance.update, passive);\n }\n };\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'eventListeners',\n enabled: true,\n phase: 'write',\n fn: function fn() {},\n effect: effect,\n data: {}\n};","var hash = {\n left: 'right',\n right: 'left',\n bottom: 'top',\n top: 'bottom'\n};\nexport default function getOppositePlacement(placement) {\n return placement.replace(/left|right|bottom|top/g, function (matched) {\n return hash[matched];\n });\n}","var hash = {\n start: 'end',\n end: 'start'\n};\nexport default function getOppositeVariationPlacement(placement) {\n return placement.replace(/start|end/g, function (matched) {\n return hash[matched];\n });\n}","import getWindow from \"./getWindow.js\";\nexport default function getWindowScroll(node) {\n var win = getWindow(node);\n var scrollLeft = win.pageXOffset;\n var scrollTop = win.pageYOffset;\n return {\n scrollLeft: scrollLeft,\n scrollTop: scrollTop\n };\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getWindowScroll from \"./getWindowScroll.js\";\nexport default function getWindowScrollBarX(element) {\n // If has a CSS width greater than the viewport, then this will be\n // incorrect for RTL.\n // Popper 1 is broken in this case and never had a bug report so let's assume\n // it's not an issue. I don't think anyone ever specifies width on \n // anyway.\n // Browsers where the left scrollbar doesn't cause an issue report `0` for\n // this (e.g. Edge 2019, IE11, Safari)\n return getBoundingClientRect(getDocumentElement(element)).left + getWindowScroll(element).scrollLeft;\n}","import getComputedStyle from \"./getComputedStyle.js\";\nexport default function isScrollParent(element) {\n // Firefox wants us to check `-x` and `-y` variations as well\n var _getComputedStyle = getComputedStyle(element),\n overflow = _getComputedStyle.overflow,\n overflowX = _getComputedStyle.overflowX,\n overflowY = _getComputedStyle.overflowY;\n\n return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX);\n}","import getParentNode from \"./getParentNode.js\";\nimport isScrollParent from \"./isScrollParent.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nexport default function getScrollParent(node) {\n if (['html', 'body', '#document'].indexOf(getNodeName(node)) >= 0) {\n // $FlowFixMe[incompatible-return]: assume body is always available\n return node.ownerDocument.body;\n }\n\n if (isHTMLElement(node) && isScrollParent(node)) {\n return node;\n }\n\n return getScrollParent(getParentNode(node));\n}","import getScrollParent from \"./getScrollParent.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport getWindow from \"./getWindow.js\";\nimport isScrollParent from \"./isScrollParent.js\";\n/*\ngiven a DOM element, return the list of all scroll parents, up the list of ancesors\nuntil we get to the top window object. This list is what we attach scroll listeners\nto, because if any of these parent elements scroll, we'll need to re-calculate the\nreference element's position.\n*/\n\nexport default function listScrollParents(element, list) {\n var _element$ownerDocumen;\n\n if (list === void 0) {\n list = [];\n }\n\n var scrollParent = getScrollParent(element);\n var isBody = scrollParent === ((_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body);\n var win = getWindow(scrollParent);\n var target = isBody ? [win].concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : []) : scrollParent;\n var updatedList = list.concat(target);\n return isBody ? updatedList : // $FlowFixMe[incompatible-call]: isBody tells us target will be an HTMLElement here\n updatedList.concat(listScrollParents(getParentNode(target)));\n}","export default function rectToClientRect(rect) {\n return Object.assign({}, rect, {\n left: rect.x,\n top: rect.y,\n right: rect.x + rect.width,\n bottom: rect.y + rect.height\n });\n}","import { viewport } from \"../enums.js\";\nimport getViewportRect from \"./getViewportRect.js\";\nimport getDocumentRect from \"./getDocumentRect.js\";\nimport listScrollParents from \"./listScrollParents.js\";\nimport getOffsetParent from \"./getOffsetParent.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport { isElement, isHTMLElement } from \"./instanceOf.js\";\nimport getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport contains from \"./contains.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport rectToClientRect from \"../utils/rectToClientRect.js\";\nimport { max, min } from \"../utils/math.js\";\n\nfunction getInnerBoundingClientRect(element, strategy) {\n var rect = getBoundingClientRect(element, false, strategy === 'fixed');\n rect.top = rect.top + element.clientTop;\n rect.left = rect.left + element.clientLeft;\n rect.bottom = rect.top + element.clientHeight;\n rect.right = rect.left + element.clientWidth;\n rect.width = element.clientWidth;\n rect.height = element.clientHeight;\n rect.x = rect.left;\n rect.y = rect.top;\n return rect;\n}\n\nfunction getClientRectFromMixedType(element, clippingParent, strategy) {\n return clippingParent === viewport ? rectToClientRect(getViewportRect(element, strategy)) : isElement(clippingParent) ? getInnerBoundingClientRect(clippingParent, strategy) : rectToClientRect(getDocumentRect(getDocumentElement(element)));\n} // A \"clipping parent\" is an overflowable container with the characteristic of\n// clipping (or hiding) overflowing elements with a position different from\n// `initial`\n\n\nfunction getClippingParents(element) {\n var clippingParents = listScrollParents(getParentNode(element));\n var canEscapeClipping = ['absolute', 'fixed'].indexOf(getComputedStyle(element).position) >= 0;\n var clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element;\n\n if (!isElement(clipperElement)) {\n return [];\n } // $FlowFixMe[incompatible-return]: https://github.com/facebook/flow/issues/1414\n\n\n return clippingParents.filter(function (clippingParent) {\n return isElement(clippingParent) && contains(clippingParent, clipperElement) && getNodeName(clippingParent) !== 'body';\n });\n} // Gets the maximum area that the element is visible in due to any number of\n// clipping parents\n\n\nexport default function getClippingRect(element, boundary, rootBoundary, strategy) {\n var mainClippingParents = boundary === 'clippingParents' ? getClippingParents(element) : [].concat(boundary);\n var clippingParents = [].concat(mainClippingParents, [rootBoundary]);\n var firstClippingParent = clippingParents[0];\n var clippingRect = clippingParents.reduce(function (accRect, clippingParent) {\n var rect = getClientRectFromMixedType(element, clippingParent, strategy);\n accRect.top = max(rect.top, accRect.top);\n accRect.right = min(rect.right, accRect.right);\n accRect.bottom = min(rect.bottom, accRect.bottom);\n accRect.left = max(rect.left, accRect.left);\n return accRect;\n }, getClientRectFromMixedType(element, firstClippingParent, strategy));\n clippingRect.width = clippingRect.right - clippingRect.left;\n clippingRect.height = clippingRect.bottom - clippingRect.top;\n clippingRect.x = clippingRect.left;\n clippingRect.y = clippingRect.top;\n return clippingRect;\n}","import getWindow from \"./getWindow.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport isLayoutViewport from \"./isLayoutViewport.js\";\nexport default function getViewportRect(element, strategy) {\n var win = getWindow(element);\n var html = getDocumentElement(element);\n var visualViewport = win.visualViewport;\n var width = html.clientWidth;\n var height = html.clientHeight;\n var x = 0;\n var y = 0;\n\n if (visualViewport) {\n width = visualViewport.width;\n height = visualViewport.height;\n var layoutViewport = isLayoutViewport();\n\n if (layoutViewport || !layoutViewport && strategy === 'fixed') {\n x = visualViewport.offsetLeft;\n y = visualViewport.offsetTop;\n }\n }\n\n return {\n width: width,\n height: height,\n x: x + getWindowScrollBarX(element),\n y: y\n };\n}","import getDocumentElement from \"./getDocumentElement.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport getWindowScroll from \"./getWindowScroll.js\";\nimport { max } from \"../utils/math.js\"; // Gets the entire size of the scrollable document area, even extending outside\n// of the `` and `` rect bounds if horizontally scrollable\n\nexport default function getDocumentRect(element) {\n var _element$ownerDocumen;\n\n var html = getDocumentElement(element);\n var winScroll = getWindowScroll(element);\n var body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body;\n var width = max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0);\n var height = max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0);\n var x = -winScroll.scrollLeft + getWindowScrollBarX(element);\n var y = -winScroll.scrollTop;\n\n if (getComputedStyle(body || html).direction === 'rtl') {\n x += max(html.clientWidth, body ? body.clientWidth : 0) - width;\n }\n\n return {\n width: width,\n height: height,\n x: x,\n y: y\n };\n}","import getBasePlacement from \"./getBasePlacement.js\";\nimport getVariation from \"./getVariation.js\";\nimport getMainAxisFromPlacement from \"./getMainAxisFromPlacement.js\";\nimport { top, right, bottom, left, start, end } from \"../enums.js\";\nexport default function computeOffsets(_ref) {\n var reference = _ref.reference,\n element = _ref.element,\n placement = _ref.placement;\n var basePlacement = placement ? getBasePlacement(placement) : null;\n var variation = placement ? getVariation(placement) : null;\n var commonX = reference.x + reference.width / 2 - element.width / 2;\n var commonY = reference.y + reference.height / 2 - element.height / 2;\n var offsets;\n\n switch (basePlacement) {\n case top:\n offsets = {\n x: commonX,\n y: reference.y - element.height\n };\n break;\n\n case bottom:\n offsets = {\n x: commonX,\n y: reference.y + reference.height\n };\n break;\n\n case right:\n offsets = {\n x: reference.x + reference.width,\n y: commonY\n };\n break;\n\n case left:\n offsets = {\n x: reference.x - element.width,\n y: commonY\n };\n break;\n\n default:\n offsets = {\n x: reference.x,\n y: reference.y\n };\n }\n\n var mainAxis = basePlacement ? getMainAxisFromPlacement(basePlacement) : null;\n\n if (mainAxis != null) {\n var len = mainAxis === 'y' ? 'height' : 'width';\n\n switch (variation) {\n case start:\n offsets[mainAxis] = offsets[mainAxis] - (reference[len] / 2 - element[len] / 2);\n break;\n\n case end:\n offsets[mainAxis] = offsets[mainAxis] + (reference[len] / 2 - element[len] / 2);\n break;\n\n default:\n }\n }\n\n return offsets;\n}","import getClippingRect from \"../dom-utils/getClippingRect.js\";\nimport getDocumentElement from \"../dom-utils/getDocumentElement.js\";\nimport getBoundingClientRect from \"../dom-utils/getBoundingClientRect.js\";\nimport computeOffsets from \"./computeOffsets.js\";\nimport rectToClientRect from \"./rectToClientRect.js\";\nimport { clippingParents, reference, popper, bottom, top, right, basePlacements, viewport } from \"../enums.js\";\nimport { isElement } from \"../dom-utils/instanceOf.js\";\nimport mergePaddingObject from \"./mergePaddingObject.js\";\nimport expandToHashMap from \"./expandToHashMap.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport default function detectOverflow(state, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n _options$placement = _options.placement,\n placement = _options$placement === void 0 ? state.placement : _options$placement,\n _options$strategy = _options.strategy,\n strategy = _options$strategy === void 0 ? state.strategy : _options$strategy,\n _options$boundary = _options.boundary,\n boundary = _options$boundary === void 0 ? clippingParents : _options$boundary,\n _options$rootBoundary = _options.rootBoundary,\n rootBoundary = _options$rootBoundary === void 0 ? viewport : _options$rootBoundary,\n _options$elementConte = _options.elementContext,\n elementContext = _options$elementConte === void 0 ? popper : _options$elementConte,\n _options$altBoundary = _options.altBoundary,\n altBoundary = _options$altBoundary === void 0 ? false : _options$altBoundary,\n _options$padding = _options.padding,\n padding = _options$padding === void 0 ? 0 : _options$padding;\n var paddingObject = mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));\n var altContext = elementContext === popper ? reference : popper;\n var popperRect = state.rects.popper;\n var element = state.elements[altBoundary ? altContext : elementContext];\n var clippingClientRect = getClippingRect(isElement(element) ? element : element.contextElement || getDocumentElement(state.elements.popper), boundary, rootBoundary, strategy);\n var referenceClientRect = getBoundingClientRect(state.elements.reference);\n var popperOffsets = computeOffsets({\n reference: referenceClientRect,\n element: popperRect,\n strategy: 'absolute',\n placement: placement\n });\n var popperClientRect = rectToClientRect(Object.assign({}, popperRect, popperOffsets));\n var elementClientRect = elementContext === popper ? popperClientRect : referenceClientRect; // positive = overflowing the clipping rect\n // 0 or negative = within the clipping rect\n\n var overflowOffsets = {\n top: clippingClientRect.top - elementClientRect.top + paddingObject.top,\n bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom,\n left: clippingClientRect.left - elementClientRect.left + paddingObject.left,\n right: elementClientRect.right - clippingClientRect.right + paddingObject.right\n };\n var offsetData = state.modifiersData.offset; // Offsets can be applied only to the popper element\n\n if (elementContext === popper && offsetData) {\n var offset = offsetData[placement];\n Object.keys(overflowOffsets).forEach(function (key) {\n var multiply = [right, bottom].indexOf(key) >= 0 ? 1 : -1;\n var axis = [top, bottom].indexOf(key) >= 0 ? 'y' : 'x';\n overflowOffsets[key] += offset[axis] * multiply;\n });\n }\n\n return overflowOffsets;\n}","import getOppositePlacement from \"../utils/getOppositePlacement.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getOppositeVariationPlacement from \"../utils/getOppositeVariationPlacement.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\nimport computeAutoPlacement from \"../utils/computeAutoPlacement.js\";\nimport { bottom, top, start, right, left, auto } from \"../enums.js\";\nimport getVariation from \"../utils/getVariation.js\"; // eslint-disable-next-line import/no-unused-modules\n\nfunction getExpandedFallbackPlacements(placement) {\n if (getBasePlacement(placement) === auto) {\n return [];\n }\n\n var oppositePlacement = getOppositePlacement(placement);\n return [getOppositeVariationPlacement(placement), oppositePlacement, getOppositeVariationPlacement(oppositePlacement)];\n}\n\nfunction flip(_ref) {\n var state = _ref.state,\n options = _ref.options,\n name = _ref.name;\n\n if (state.modifiersData[name]._skip) {\n return;\n }\n\n var _options$mainAxis = options.mainAxis,\n checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis,\n _options$altAxis = options.altAxis,\n checkAltAxis = _options$altAxis === void 0 ? true : _options$altAxis,\n specifiedFallbackPlacements = options.fallbackPlacements,\n padding = options.padding,\n boundary = options.boundary,\n rootBoundary = options.rootBoundary,\n altBoundary = options.altBoundary,\n _options$flipVariatio = options.flipVariations,\n flipVariations = _options$flipVariatio === void 0 ? true : _options$flipVariatio,\n allowedAutoPlacements = options.allowedAutoPlacements;\n var preferredPlacement = state.options.placement;\n var basePlacement = getBasePlacement(preferredPlacement);\n var isBasePlacement = basePlacement === preferredPlacement;\n var fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipVariations ? [getOppositePlacement(preferredPlacement)] : getExpandedFallbackPlacements(preferredPlacement));\n var placements = [preferredPlacement].concat(fallbackPlacements).reduce(function (acc, placement) {\n return acc.concat(getBasePlacement(placement) === auto ? computeAutoPlacement(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding,\n flipVariations: flipVariations,\n allowedAutoPlacements: allowedAutoPlacements\n }) : placement);\n }, []);\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var checksMap = new Map();\n var makeFallbackChecks = true;\n var firstFittingPlacement = placements[0];\n\n for (var i = 0; i < placements.length; i++) {\n var placement = placements[i];\n\n var _basePlacement = getBasePlacement(placement);\n\n var isStartVariation = getVariation(placement) === start;\n var isVertical = [top, bottom].indexOf(_basePlacement) >= 0;\n var len = isVertical ? 'width' : 'height';\n var overflow = detectOverflow(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n altBoundary: altBoundary,\n padding: padding\n });\n var mainVariationSide = isVertical ? isStartVariation ? right : left : isStartVariation ? bottom : top;\n\n if (referenceRect[len] > popperRect[len]) {\n mainVariationSide = getOppositePlacement(mainVariationSide);\n }\n\n var altVariationSide = getOppositePlacement(mainVariationSide);\n var checks = [];\n\n if (checkMainAxis) {\n checks.push(overflow[_basePlacement] <= 0);\n }\n\n if (checkAltAxis) {\n checks.push(overflow[mainVariationSide] <= 0, overflow[altVariationSide] <= 0);\n }\n\n if (checks.every(function (check) {\n return check;\n })) {\n firstFittingPlacement = placement;\n makeFallbackChecks = false;\n break;\n }\n\n checksMap.set(placement, checks);\n }\n\n if (makeFallbackChecks) {\n // `2` may be desired in some cases – research later\n var numberOfChecks = flipVariations ? 3 : 1;\n\n var _loop = function _loop(_i) {\n var fittingPlacement = placements.find(function (placement) {\n var checks = checksMap.get(placement);\n\n if (checks) {\n return checks.slice(0, _i).every(function (check) {\n return check;\n });\n }\n });\n\n if (fittingPlacement) {\n firstFittingPlacement = fittingPlacement;\n return \"break\";\n }\n };\n\n for (var _i = numberOfChecks; _i > 0; _i--) {\n var _ret = _loop(_i);\n\n if (_ret === \"break\") break;\n }\n }\n\n if (state.placement !== firstFittingPlacement) {\n state.modifiersData[name]._skip = true;\n state.placement = firstFittingPlacement;\n state.reset = true;\n }\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'flip',\n enabled: true,\n phase: 'main',\n fn: flip,\n requiresIfExists: ['offset'],\n data: {\n _skip: false\n }\n};","import getVariation from \"./getVariation.js\";\nimport { variationPlacements, basePlacements, placements as allPlacements } from \"../enums.js\";\nimport detectOverflow from \"./detectOverflow.js\";\nimport getBasePlacement from \"./getBasePlacement.js\";\nexport default function computeAutoPlacement(state, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n placement = _options.placement,\n boundary = _options.boundary,\n rootBoundary = _options.rootBoundary,\n padding = _options.padding,\n flipVariations = _options.flipVariations,\n _options$allowedAutoP = _options.allowedAutoPlacements,\n allowedAutoPlacements = _options$allowedAutoP === void 0 ? allPlacements : _options$allowedAutoP;\n var variation = getVariation(placement);\n var placements = variation ? flipVariations ? variationPlacements : variationPlacements.filter(function (placement) {\n return getVariation(placement) === variation;\n }) : basePlacements;\n var allowedPlacements = placements.filter(function (placement) {\n return allowedAutoPlacements.indexOf(placement) >= 0;\n });\n\n if (allowedPlacements.length === 0) {\n allowedPlacements = placements;\n } // $FlowFixMe[incompatible-type]: Flow seems to have problems with two array unions...\n\n\n var overflows = allowedPlacements.reduce(function (acc, placement) {\n acc[placement] = detectOverflow(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding\n })[getBasePlacement(placement)];\n return acc;\n }, {});\n return Object.keys(overflows).sort(function (a, b) {\n return overflows[a] - overflows[b];\n });\n}","import { top, bottom, left, right } from \"../enums.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\n\nfunction getSideOffsets(overflow, rect, preventedOffsets) {\n if (preventedOffsets === void 0) {\n preventedOffsets = {\n x: 0,\n y: 0\n };\n }\n\n return {\n top: overflow.top - rect.height - preventedOffsets.y,\n right: overflow.right - rect.width + preventedOffsets.x,\n bottom: overflow.bottom - rect.height + preventedOffsets.y,\n left: overflow.left - rect.width - preventedOffsets.x\n };\n}\n\nfunction isAnySideFullyClipped(overflow) {\n return [top, right, bottom, left].some(function (side) {\n return overflow[side] >= 0;\n });\n}\n\nfunction hide(_ref) {\n var state = _ref.state,\n name = _ref.name;\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var preventedOffsets = state.modifiersData.preventOverflow;\n var referenceOverflow = detectOverflow(state, {\n elementContext: 'reference'\n });\n var popperAltOverflow = detectOverflow(state, {\n altBoundary: true\n });\n var referenceClippingOffsets = getSideOffsets(referenceOverflow, referenceRect);\n var popperEscapeOffsets = getSideOffsets(popperAltOverflow, popperRect, preventedOffsets);\n var isReferenceHidden = isAnySideFullyClipped(referenceClippingOffsets);\n var hasPopperEscaped = isAnySideFullyClipped(popperEscapeOffsets);\n state.modifiersData[name] = {\n referenceClippingOffsets: referenceClippingOffsets,\n popperEscapeOffsets: popperEscapeOffsets,\n isReferenceHidden: isReferenceHidden,\n hasPopperEscaped: hasPopperEscaped\n };\n state.attributes.popper = Object.assign({}, state.attributes.popper, {\n 'data-popper-reference-hidden': isReferenceHidden,\n 'data-popper-escaped': hasPopperEscaped\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'hide',\n enabled: true,\n phase: 'main',\n requiresIfExists: ['preventOverflow'],\n fn: hide\n};","import getBasePlacement from \"../utils/getBasePlacement.js\";\nimport { top, left, right, placements } from \"../enums.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport function distanceAndSkiddingToXY(placement, rects, offset) {\n var basePlacement = getBasePlacement(placement);\n var invertDistance = [left, top].indexOf(basePlacement) >= 0 ? -1 : 1;\n\n var _ref = typeof offset === 'function' ? offset(Object.assign({}, rects, {\n placement: placement\n })) : offset,\n skidding = _ref[0],\n distance = _ref[1];\n\n skidding = skidding || 0;\n distance = (distance || 0) * invertDistance;\n return [left, right].indexOf(basePlacement) >= 0 ? {\n x: distance,\n y: skidding\n } : {\n x: skidding,\n y: distance\n };\n}\n\nfunction offset(_ref2) {\n var state = _ref2.state,\n options = _ref2.options,\n name = _ref2.name;\n var _options$offset = options.offset,\n offset = _options$offset === void 0 ? [0, 0] : _options$offset;\n var data = placements.reduce(function (acc, placement) {\n acc[placement] = distanceAndSkiddingToXY(placement, state.rects, offset);\n return acc;\n }, {});\n var _data$state$placement = data[state.placement],\n x = _data$state$placement.x,\n y = _data$state$placement.y;\n\n if (state.modifiersData.popperOffsets != null) {\n state.modifiersData.popperOffsets.x += x;\n state.modifiersData.popperOffsets.y += y;\n }\n\n state.modifiersData[name] = data;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'offset',\n enabled: true,\n phase: 'main',\n requires: ['popperOffsets'],\n fn: offset\n};","import computeOffsets from \"../utils/computeOffsets.js\";\n\nfunction popperOffsets(_ref) {\n var state = _ref.state,\n name = _ref.name;\n // Offsets are the actual position the popper needs to have to be\n // properly positioned near its reference element\n // This is the most basic placement, and will be adjusted by\n // the modifiers in the next step\n state.modifiersData[name] = computeOffsets({\n reference: state.rects.reference,\n element: state.rects.popper,\n strategy: 'absolute',\n placement: state.placement\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'popperOffsets',\n enabled: true,\n phase: 'read',\n fn: popperOffsets,\n data: {}\n};","import { top, left, right, bottom, start } from \"../enums.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getMainAxisFromPlacement from \"../utils/getMainAxisFromPlacement.js\";\nimport getAltAxis from \"../utils/getAltAxis.js\";\nimport { within, withinMaxClamp } from \"../utils/within.js\";\nimport getLayoutRect from \"../dom-utils/getLayoutRect.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\nimport getVariation from \"../utils/getVariation.js\";\nimport getFreshSideObject from \"../utils/getFreshSideObject.js\";\nimport { min as mathMin, max as mathMax } from \"../utils/math.js\";\n\nfunction preventOverflow(_ref) {\n var state = _ref.state,\n options = _ref.options,\n name = _ref.name;\n var _options$mainAxis = options.mainAxis,\n checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis,\n _options$altAxis = options.altAxis,\n checkAltAxis = _options$altAxis === void 0 ? false : _options$altAxis,\n boundary = options.boundary,\n rootBoundary = options.rootBoundary,\n altBoundary = options.altBoundary,\n padding = options.padding,\n _options$tether = options.tether,\n tether = _options$tether === void 0 ? true : _options$tether,\n _options$tetherOffset = options.tetherOffset,\n tetherOffset = _options$tetherOffset === void 0 ? 0 : _options$tetherOffset;\n var overflow = detectOverflow(state, {\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding,\n altBoundary: altBoundary\n });\n var basePlacement = getBasePlacement(state.placement);\n var variation = getVariation(state.placement);\n var isBasePlacement = !variation;\n var mainAxis = getMainAxisFromPlacement(basePlacement);\n var altAxis = getAltAxis(mainAxis);\n var popperOffsets = state.modifiersData.popperOffsets;\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var tetherOffsetValue = typeof tetherOffset === 'function' ? tetherOffset(Object.assign({}, state.rects, {\n placement: state.placement\n })) : tetherOffset;\n var normalizedTetherOffsetValue = typeof tetherOffsetValue === 'number' ? {\n mainAxis: tetherOffsetValue,\n altAxis: tetherOffsetValue\n } : Object.assign({\n mainAxis: 0,\n altAxis: 0\n }, tetherOffsetValue);\n var offsetModifierState = state.modifiersData.offset ? state.modifiersData.offset[state.placement] : null;\n var data = {\n x: 0,\n y: 0\n };\n\n if (!popperOffsets) {\n return;\n }\n\n if (checkMainAxis) {\n var _offsetModifierState$;\n\n var mainSide = mainAxis === 'y' ? top : left;\n var altSide = mainAxis === 'y' ? bottom : right;\n var len = mainAxis === 'y' ? 'height' : 'width';\n var offset = popperOffsets[mainAxis];\n var min = offset + overflow[mainSide];\n var max = offset - overflow[altSide];\n var additive = tether ? -popperRect[len] / 2 : 0;\n var minLen = variation === start ? referenceRect[len] : popperRect[len];\n var maxLen = variation === start ? -popperRect[len] : -referenceRect[len]; // We need to include the arrow in the calculation so the arrow doesn't go\n // outside the reference bounds\n\n var arrowElement = state.elements.arrow;\n var arrowRect = tether && arrowElement ? getLayoutRect(arrowElement) : {\n width: 0,\n height: 0\n };\n var arrowPaddingObject = state.modifiersData['arrow#persistent'] ? state.modifiersData['arrow#persistent'].padding : getFreshSideObject();\n var arrowPaddingMin = arrowPaddingObject[mainSide];\n var arrowPaddingMax = arrowPaddingObject[altSide]; // If the reference length is smaller than the arrow length, we don't want\n // to include its full size in the calculation. If the reference is small\n // and near the edge of a boundary, the popper can overflow even if the\n // reference is not overflowing as well (e.g. virtual elements with no\n // width or height)\n\n var arrowLen = within(0, referenceRect[len], arrowRect[len]);\n var minOffset = isBasePlacement ? referenceRect[len] / 2 - additive - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis : minLen - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis;\n var maxOffset = isBasePlacement ? -referenceRect[len] / 2 + additive + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis : maxLen + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis;\n var arrowOffsetParent = state.elements.arrow && getOffsetParent(state.elements.arrow);\n var clientOffset = arrowOffsetParent ? mainAxis === 'y' ? arrowOffsetParent.clientTop || 0 : arrowOffsetParent.clientLeft || 0 : 0;\n var offsetModifierValue = (_offsetModifierState$ = offsetModifierState == null ? void 0 : offsetModifierState[mainAxis]) != null ? _offsetModifierState$ : 0;\n var tetherMin = offset + minOffset - offsetModifierValue - clientOffset;\n var tetherMax = offset + maxOffset - offsetModifierValue;\n var preventedOffset = within(tether ? mathMin(min, tetherMin) : min, offset, tether ? mathMax(max, tetherMax) : max);\n popperOffsets[mainAxis] = preventedOffset;\n data[mainAxis] = preventedOffset - offset;\n }\n\n if (checkAltAxis) {\n var _offsetModifierState$2;\n\n var _mainSide = mainAxis === 'x' ? top : left;\n\n var _altSide = mainAxis === 'x' ? bottom : right;\n\n var _offset = popperOffsets[altAxis];\n\n var _len = altAxis === 'y' ? 'height' : 'width';\n\n var _min = _offset + overflow[_mainSide];\n\n var _max = _offset - overflow[_altSide];\n\n var isOriginSide = [top, left].indexOf(basePlacement) !== -1;\n\n var _offsetModifierValue = (_offsetModifierState$2 = offsetModifierState == null ? void 0 : offsetModifierState[altAxis]) != null ? _offsetModifierState$2 : 0;\n\n var _tetherMin = isOriginSide ? _min : _offset - referenceRect[_len] - popperRect[_len] - _offsetModifierValue + normalizedTetherOffsetValue.altAxis;\n\n var _tetherMax = isOriginSide ? _offset + referenceRect[_len] + popperRect[_len] - _offsetModifierValue - normalizedTetherOffsetValue.altAxis : _max;\n\n var _preventedOffset = tether && isOriginSide ? withinMaxClamp(_tetherMin, _offset, _tetherMax) : within(tether ? _tetherMin : _min, _offset, tether ? _tetherMax : _max);\n\n popperOffsets[altAxis] = _preventedOffset;\n data[altAxis] = _preventedOffset - _offset;\n }\n\n state.modifiersData[name] = data;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'preventOverflow',\n enabled: true,\n phase: 'main',\n fn: preventOverflow,\n requiresIfExists: ['offset']\n};","export default function getAltAxis(axis) {\n return axis === 'x' ? 'y' : 'x';\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getNodeScroll from \"./getNodeScroll.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport isScrollParent from \"./isScrollParent.js\";\nimport { round } from \"../utils/math.js\";\n\nfunction isElementScaled(element) {\n var rect = element.getBoundingClientRect();\n var scaleX = round(rect.width) / element.offsetWidth || 1;\n var scaleY = round(rect.height) / element.offsetHeight || 1;\n return scaleX !== 1 || scaleY !== 1;\n} // Returns the composite rect of an element relative to its offsetParent.\n// Composite means it takes into account transforms as well as layout.\n\n\nexport default function getCompositeRect(elementOrVirtualElement, offsetParent, isFixed) {\n if (isFixed === void 0) {\n isFixed = false;\n }\n\n var isOffsetParentAnElement = isHTMLElement(offsetParent);\n var offsetParentIsScaled = isHTMLElement(offsetParent) && isElementScaled(offsetParent);\n var documentElement = getDocumentElement(offsetParent);\n var rect = getBoundingClientRect(elementOrVirtualElement, offsetParentIsScaled, isFixed);\n var scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n var offsets = {\n x: 0,\n y: 0\n };\n\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if (getNodeName(offsetParent) !== 'body' || // https://github.com/popperjs/popper-core/issues/1078\n isScrollParent(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n\n if (isHTMLElement(offsetParent)) {\n offsets = getBoundingClientRect(offsetParent, true);\n offsets.x += offsetParent.clientLeft;\n offsets.y += offsetParent.clientTop;\n } else if (documentElement) {\n offsets.x = getWindowScrollBarX(documentElement);\n }\n }\n\n return {\n x: rect.left + scroll.scrollLeft - offsets.x,\n y: rect.top + scroll.scrollTop - offsets.y,\n width: rect.width,\n height: rect.height\n };\n}","import getWindowScroll from \"./getWindowScroll.js\";\nimport getWindow from \"./getWindow.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nimport getHTMLElementScroll from \"./getHTMLElementScroll.js\";\nexport default function getNodeScroll(node) {\n if (node === getWindow(node) || !isHTMLElement(node)) {\n return getWindowScroll(node);\n } else {\n return getHTMLElementScroll(node);\n }\n}","export default function getHTMLElementScroll(element) {\n return {\n scrollLeft: element.scrollLeft,\n scrollTop: element.scrollTop\n };\n}","import { modifierPhases } from \"../enums.js\"; // source: https://stackoverflow.com/questions/49875255\n\nfunction order(modifiers) {\n var map = new Map();\n var visited = new Set();\n var result = [];\n modifiers.forEach(function (modifier) {\n map.set(modifier.name, modifier);\n }); // On visiting object, check for its dependencies and visit them recursively\n\n function sort(modifier) {\n visited.add(modifier.name);\n var requires = [].concat(modifier.requires || [], modifier.requiresIfExists || []);\n requires.forEach(function (dep) {\n if (!visited.has(dep)) {\n var depModifier = map.get(dep);\n\n if (depModifier) {\n sort(depModifier);\n }\n }\n });\n result.push(modifier);\n }\n\n modifiers.forEach(function (modifier) {\n if (!visited.has(modifier.name)) {\n // check for visited object\n sort(modifier);\n }\n });\n return result;\n}\n\nexport default function orderModifiers(modifiers) {\n // order based on dependencies\n var orderedModifiers = order(modifiers); // order based on phase\n\n return modifierPhases.reduce(function (acc, phase) {\n return acc.concat(orderedModifiers.filter(function (modifier) {\n return modifier.phase === phase;\n }));\n }, []);\n}","import getCompositeRect from \"./dom-utils/getCompositeRect.js\";\nimport getLayoutRect from \"./dom-utils/getLayoutRect.js\";\nimport listScrollParents from \"./dom-utils/listScrollParents.js\";\nimport getOffsetParent from \"./dom-utils/getOffsetParent.js\";\nimport orderModifiers from \"./utils/orderModifiers.js\";\nimport debounce from \"./utils/debounce.js\";\nimport mergeByName from \"./utils/mergeByName.js\";\nimport detectOverflow from \"./utils/detectOverflow.js\";\nimport { isElement } from \"./dom-utils/instanceOf.js\";\nvar DEFAULT_OPTIONS = {\n placement: 'bottom',\n modifiers: [],\n strategy: 'absolute'\n};\n\nfunction areValidElements() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return !args.some(function (element) {\n return !(element && typeof element.getBoundingClientRect === 'function');\n });\n}\n\nexport function popperGenerator(generatorOptions) {\n if (generatorOptions === void 0) {\n generatorOptions = {};\n }\n\n var _generatorOptions = generatorOptions,\n _generatorOptions$def = _generatorOptions.defaultModifiers,\n defaultModifiers = _generatorOptions$def === void 0 ? [] : _generatorOptions$def,\n _generatorOptions$def2 = _generatorOptions.defaultOptions,\n defaultOptions = _generatorOptions$def2 === void 0 ? DEFAULT_OPTIONS : _generatorOptions$def2;\n return function createPopper(reference, popper, options) {\n if (options === void 0) {\n options = defaultOptions;\n }\n\n var state = {\n placement: 'bottom',\n orderedModifiers: [],\n options: Object.assign({}, DEFAULT_OPTIONS, defaultOptions),\n modifiersData: {},\n elements: {\n reference: reference,\n popper: popper\n },\n attributes: {},\n styles: {}\n };\n var effectCleanupFns = [];\n var isDestroyed = false;\n var instance = {\n state: state,\n setOptions: function setOptions(setOptionsAction) {\n var options = typeof setOptionsAction === 'function' ? setOptionsAction(state.options) : setOptionsAction;\n cleanupModifierEffects();\n state.options = Object.assign({}, defaultOptions, state.options, options);\n state.scrollParents = {\n reference: isElement(reference) ? listScrollParents(reference) : reference.contextElement ? listScrollParents(reference.contextElement) : [],\n popper: listScrollParents(popper)\n }; // Orders the modifiers based on their dependencies and `phase`\n // properties\n\n var orderedModifiers = orderModifiers(mergeByName([].concat(defaultModifiers, state.options.modifiers))); // Strip out disabled modifiers\n\n state.orderedModifiers = orderedModifiers.filter(function (m) {\n return m.enabled;\n });\n runModifierEffects();\n return instance.update();\n },\n // Sync update – it will always be executed, even if not necessary. This\n // is useful for low frequency updates where sync behavior simplifies the\n // logic.\n // For high frequency updates (e.g. `resize` and `scroll` events), always\n // prefer the async Popper#update method\n forceUpdate: function forceUpdate() {\n if (isDestroyed) {\n return;\n }\n\n var _state$elements = state.elements,\n reference = _state$elements.reference,\n popper = _state$elements.popper; // Don't proceed if `reference` or `popper` are not valid elements\n // anymore\n\n if (!areValidElements(reference, popper)) {\n return;\n } // Store the reference and popper rects to be read by modifiers\n\n\n state.rects = {\n reference: getCompositeRect(reference, getOffsetParent(popper), state.options.strategy === 'fixed'),\n popper: getLayoutRect(popper)\n }; // Modifiers have the ability to reset the current update cycle. The\n // most common use case for this is the `flip` modifier changing the\n // placement, which then needs to re-run all the modifiers, because the\n // logic was previously ran for the previous placement and is therefore\n // stale/incorrect\n\n state.reset = false;\n state.placement = state.options.placement; // On each update cycle, the `modifiersData` property for each modifier\n // is filled with the initial data specified by the modifier. This means\n // it doesn't persist and is fresh on each update.\n // To ensure persistent data, use `${name}#persistent`\n\n state.orderedModifiers.forEach(function (modifier) {\n return state.modifiersData[modifier.name] = Object.assign({}, modifier.data);\n });\n\n for (var index = 0; index < state.orderedModifiers.length; index++) {\n if (state.reset === true) {\n state.reset = false;\n index = -1;\n continue;\n }\n\n var _state$orderedModifie = state.orderedModifiers[index],\n fn = _state$orderedModifie.fn,\n _state$orderedModifie2 = _state$orderedModifie.options,\n _options = _state$orderedModifie2 === void 0 ? {} : _state$orderedModifie2,\n name = _state$orderedModifie.name;\n\n if (typeof fn === 'function') {\n state = fn({\n state: state,\n options: _options,\n name: name,\n instance: instance\n }) || state;\n }\n }\n },\n // Async and optimistically optimized update – it will not be executed if\n // not necessary (debounced to run at most once-per-tick)\n update: debounce(function () {\n return new Promise(function (resolve) {\n instance.forceUpdate();\n resolve(state);\n });\n }),\n destroy: function destroy() {\n cleanupModifierEffects();\n isDestroyed = true;\n }\n };\n\n if (!areValidElements(reference, popper)) {\n return instance;\n }\n\n instance.setOptions(options).then(function (state) {\n if (!isDestroyed && options.onFirstUpdate) {\n options.onFirstUpdate(state);\n }\n }); // Modifiers have the ability to execute arbitrary code before the first\n // update cycle runs. They will be executed in the same order as the update\n // cycle. This is useful when a modifier adds some persistent data that\n // other modifiers need to use, but the modifier is run after the dependent\n // one.\n\n function runModifierEffects() {\n state.orderedModifiers.forEach(function (_ref) {\n var name = _ref.name,\n _ref$options = _ref.options,\n options = _ref$options === void 0 ? {} : _ref$options,\n effect = _ref.effect;\n\n if (typeof effect === 'function') {\n var cleanupFn = effect({\n state: state,\n name: name,\n instance: instance,\n options: options\n });\n\n var noopFn = function noopFn() {};\n\n effectCleanupFns.push(cleanupFn || noopFn);\n }\n });\n }\n\n function cleanupModifierEffects() {\n effectCleanupFns.forEach(function (fn) {\n return fn();\n });\n effectCleanupFns = [];\n }\n\n return instance;\n };\n}\nexport var createPopper = /*#__PURE__*/popperGenerator(); // eslint-disable-next-line import/no-unused-modules\n\nexport { detectOverflow };","export default function debounce(fn) {\n var pending;\n return function () {\n if (!pending) {\n pending = new Promise(function (resolve) {\n Promise.resolve().then(function () {\n pending = undefined;\n resolve(fn());\n });\n });\n }\n\n return pending;\n };\n}","export default function mergeByName(modifiers) {\n var merged = modifiers.reduce(function (merged, current) {\n var existing = merged[current.name];\n merged[current.name] = existing ? Object.assign({}, existing, current, {\n options: Object.assign({}, existing.options, current.options),\n data: Object.assign({}, existing.data, current.data)\n }) : current;\n return merged;\n }, {}); // IE11 does not support Object.values\n\n return Object.keys(merged).map(function (key) {\n return merged[key];\n });\n}","import { popperGenerator, detectOverflow } from \"./createPopper.js\";\nimport eventListeners from \"./modifiers/eventListeners.js\";\nimport popperOffsets from \"./modifiers/popperOffsets.js\";\nimport computeStyles from \"./modifiers/computeStyles.js\";\nimport applyStyles from \"./modifiers/applyStyles.js\";\nimport offset from \"./modifiers/offset.js\";\nimport flip from \"./modifiers/flip.js\";\nimport preventOverflow from \"./modifiers/preventOverflow.js\";\nimport arrow from \"./modifiers/arrow.js\";\nimport hide from \"./modifiers/hide.js\";\nvar defaultModifiers = [eventListeners, popperOffsets, computeStyles, applyStyles, offset, flip, preventOverflow, arrow, hide];\nvar createPopper = /*#__PURE__*/popperGenerator({\n defaultModifiers: defaultModifiers\n}); // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper, popperGenerator, defaultModifiers, detectOverflow }; // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper as createPopperLite } from \"./popper-lite.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport * from \"./modifiers/index.js\";","import { popperGenerator, detectOverflow } from \"./createPopper.js\";\nimport eventListeners from \"./modifiers/eventListeners.js\";\nimport popperOffsets from \"./modifiers/popperOffsets.js\";\nimport computeStyles from \"./modifiers/computeStyles.js\";\nimport applyStyles from \"./modifiers/applyStyles.js\";\nvar defaultModifiers = [eventListeners, popperOffsets, computeStyles, applyStyles];\nvar createPopper = /*#__PURE__*/popperGenerator({\n defaultModifiers: defaultModifiers\n}); // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper, popperGenerator, defaultModifiers, detectOverflow };","/*!\n * Bootstrap v5.3.3 (https://getbootstrap.com/)\n * Copyright 2011-2024 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors)\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n */\nimport * as Popper from '@popperjs/core';\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap dom/data.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n/**\n * Constants\n */\n\nconst elementMap = new Map();\nconst Data = {\n set(element, key, instance) {\n if (!elementMap.has(element)) {\n elementMap.set(element, new Map());\n }\n const instanceMap = elementMap.get(element);\n\n // make it clear we only want one instance per element\n // can be removed later when multiple key/instances are fine to be used\n if (!instanceMap.has(key) && instanceMap.size !== 0) {\n // eslint-disable-next-line no-console\n console.error(`Bootstrap doesn't allow more than one instance per element. Bound instance: ${Array.from(instanceMap.keys())[0]}.`);\n return;\n }\n instanceMap.set(key, instance);\n },\n get(element, key) {\n if (elementMap.has(element)) {\n return elementMap.get(element).get(key) || null;\n }\n return null;\n },\n remove(element, key) {\n if (!elementMap.has(element)) {\n return;\n }\n const instanceMap = elementMap.get(element);\n instanceMap.delete(key);\n\n // free up element references if there are no instances left for an element\n if (instanceMap.size === 0) {\n elementMap.delete(element);\n }\n }\n};\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap util/index.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\nconst MAX_UID = 1000000;\nconst MILLISECONDS_MULTIPLIER = 1000;\nconst TRANSITION_END = 'transitionend';\n\n/**\n * Properly escape IDs selectors to handle weird IDs\n * @param {string} selector\n * @returns {string}\n */\nconst parseSelector = selector => {\n if (selector && window.CSS && window.CSS.escape) {\n // document.querySelector needs escaping to handle IDs (html5+) containing for instance /\n selector = selector.replace(/#([^\\s\"#']+)/g, (match, id) => `#${CSS.escape(id)}`);\n }\n return selector;\n};\n\n// Shout-out Angus Croll (https://goo.gl/pxwQGp)\nconst toType = object => {\n if (object === null || object === undefined) {\n return `${object}`;\n }\n return Object.prototype.toString.call(object).match(/\\s([a-z]+)/i)[1].toLowerCase();\n};\n\n/**\n * Public Util API\n */\n\nconst getUID = prefix => {\n do {\n prefix += Math.floor(Math.random() * MAX_UID);\n } while (document.getElementById(prefix));\n return prefix;\n};\nconst getTransitionDurationFromElement = element => {\n if (!element) {\n return 0;\n }\n\n // Get transition-duration of the element\n let {\n transitionDuration,\n transitionDelay\n } = window.getComputedStyle(element);\n const floatTransitionDuration = Number.parseFloat(transitionDuration);\n const floatTransitionDelay = Number.parseFloat(transitionDelay);\n\n // Return 0 if element or transition duration is not found\n if (!floatTransitionDuration && !floatTransitionDelay) {\n return 0;\n }\n\n // If multiple durations are defined, take the first\n transitionDuration = transitionDuration.split(',')[0];\n transitionDelay = transitionDelay.split(',')[0];\n return (Number.parseFloat(transitionDuration) + Number.parseFloat(transitionDelay)) * MILLISECONDS_MULTIPLIER;\n};\nconst triggerTransitionEnd = element => {\n element.dispatchEvent(new Event(TRANSITION_END));\n};\nconst isElement = object => {\n if (!object || typeof object !== 'object') {\n return false;\n }\n if (typeof object.jquery !== 'undefined') {\n object = object[0];\n }\n return typeof object.nodeType !== 'undefined';\n};\nconst getElement = object => {\n // it's a jQuery object or a node element\n if (isElement(object)) {\n return object.jquery ? object[0] : object;\n }\n if (typeof object === 'string' && object.length > 0) {\n return document.querySelector(parseSelector(object));\n }\n return null;\n};\nconst isVisible = element => {\n if (!isElement(element) || element.getClientRects().length === 0) {\n return false;\n }\n const elementIsVisible = getComputedStyle(element).getPropertyValue('visibility') === 'visible';\n // Handle `details` element as its content may falsie appear visible when it is closed\n const closedDetails = element.closest('details:not([open])');\n if (!closedDetails) {\n return elementIsVisible;\n }\n if (closedDetails !== element) {\n const summary = element.closest('summary');\n if (summary && summary.parentNode !== closedDetails) {\n return false;\n }\n if (summary === null) {\n return false;\n }\n }\n return elementIsVisible;\n};\nconst isDisabled = element => {\n if (!element || element.nodeType !== Node.ELEMENT_NODE) {\n return true;\n }\n if (element.classList.contains('disabled')) {\n return true;\n }\n if (typeof element.disabled !== 'undefined') {\n return element.disabled;\n }\n return element.hasAttribute('disabled') && element.getAttribute('disabled') !== 'false';\n};\nconst findShadowRoot = element => {\n if (!document.documentElement.attachShadow) {\n return null;\n }\n\n // Can find the shadow root otherwise it'll return the document\n if (typeof element.getRootNode === 'function') {\n const root = element.getRootNode();\n return root instanceof ShadowRoot ? root : null;\n }\n if (element instanceof ShadowRoot) {\n return element;\n }\n\n // when we don't find a shadow root\n if (!element.parentNode) {\n return null;\n }\n return findShadowRoot(element.parentNode);\n};\nconst noop = () => {};\n\n/**\n * Trick to restart an element's animation\n *\n * @param {HTMLElement} element\n * @return void\n *\n * @see https://www.charistheo.io/blog/2021/02/restart-a-css-animation-with-javascript/#restarting-a-css-animation\n */\nconst reflow = element => {\n element.offsetHeight; // eslint-disable-line no-unused-expressions\n};\nconst getjQuery = () => {\n if (window.jQuery && !document.body.hasAttribute('data-bs-no-jquery')) {\n return window.jQuery;\n }\n return null;\n};\nconst DOMContentLoadedCallbacks = [];\nconst onDOMContentLoaded = callback => {\n if (document.readyState === 'loading') {\n // add listener on the first call when the document is in loading state\n if (!DOMContentLoadedCallbacks.length) {\n document.addEventListener('DOMContentLoaded', () => {\n for (const callback of DOMContentLoadedCallbacks) {\n callback();\n }\n });\n }\n DOMContentLoadedCallbacks.push(callback);\n } else {\n callback();\n }\n};\nconst isRTL = () => document.documentElement.dir === 'rtl';\nconst defineJQueryPlugin = plugin => {\n onDOMContentLoaded(() => {\n const $ = getjQuery();\n /* istanbul ignore if */\n if ($) {\n const name = plugin.NAME;\n const JQUERY_NO_CONFLICT = $.fn[name];\n $.fn[name] = plugin.jQueryInterface;\n $.fn[name].Constructor = plugin;\n $.fn[name].noConflict = () => {\n $.fn[name] = JQUERY_NO_CONFLICT;\n return plugin.jQueryInterface;\n };\n }\n });\n};\nconst execute = (possibleCallback, args = [], defaultValue = possibleCallback) => {\n return typeof possibleCallback === 'function' ? possibleCallback(...args) : defaultValue;\n};\nconst executeAfterTransition = (callback, transitionElement, waitForTransition = true) => {\n if (!waitForTransition) {\n execute(callback);\n return;\n }\n const durationPadding = 5;\n const emulatedDuration = getTransitionDurationFromElement(transitionElement) + durationPadding;\n let called = false;\n const handler = ({\n target\n }) => {\n if (target !== transitionElement) {\n return;\n }\n called = true;\n transitionElement.removeEventListener(TRANSITION_END, handler);\n execute(callback);\n };\n transitionElement.addEventListener(TRANSITION_END, handler);\n setTimeout(() => {\n if (!called) {\n triggerTransitionEnd(transitionElement);\n }\n }, emulatedDuration);\n};\n\n/**\n * Return the previous/next element of a list.\n *\n * @param {array} list The list of elements\n * @param activeElement The active element\n * @param shouldGetNext Choose to get next or previous element\n * @param isCycleAllowed\n * @return {Element|elem} The proper element\n */\nconst getNextActiveElement = (list, activeElement, shouldGetNext, isCycleAllowed) => {\n const listLength = list.length;\n let index = list.indexOf(activeElement);\n\n // if the element does not exist in the list return an element\n // depending on the direction and if cycle is allowed\n if (index === -1) {\n return !shouldGetNext && isCycleAllowed ? list[listLength - 1] : list[0];\n }\n index += shouldGetNext ? 1 : -1;\n if (isCycleAllowed) {\n index = (index + listLength) % listLength;\n }\n return list[Math.max(0, Math.min(index, listLength - 1))];\n};\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap dom/event-handler.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst namespaceRegex = /[^.]*(?=\\..*)\\.|.*/;\nconst stripNameRegex = /\\..*/;\nconst stripUidRegex = /::\\d+$/;\nconst eventRegistry = {}; // Events storage\nlet uidEvent = 1;\nconst customEvents = {\n mouseenter: 'mouseover',\n mouseleave: 'mouseout'\n};\nconst nativeEvents = new Set(['click', 'dblclick', 'mouseup', 'mousedown', 'contextmenu', 'mousewheel', 'DOMMouseScroll', 'mouseover', 'mouseout', 'mousemove', 'selectstart', 'selectend', 'keydown', 'keypress', 'keyup', 'orientationchange', 'touchstart', 'touchmove', 'touchend', 'touchcancel', 'pointerdown', 'pointermove', 'pointerup', 'pointerleave', 'pointercancel', 'gesturestart', 'gesturechange', 'gestureend', 'focus', 'blur', 'change', 'reset', 'select', 'submit', 'focusin', 'focusout', 'load', 'unload', 'beforeunload', 'resize', 'move', 'DOMContentLoaded', 'readystatechange', 'error', 'abort', 'scroll']);\n\n/**\n * Private methods\n */\n\nfunction makeEventUid(element, uid) {\n return uid && `${uid}::${uidEvent++}` || element.uidEvent || uidEvent++;\n}\nfunction getElementEvents(element) {\n const uid = makeEventUid(element);\n element.uidEvent = uid;\n eventRegistry[uid] = eventRegistry[uid] || {};\n return eventRegistry[uid];\n}\nfunction bootstrapHandler(element, fn) {\n return function handler(event) {\n hydrateObj(event, {\n delegateTarget: element\n });\n if (handler.oneOff) {\n EventHandler.off(element, event.type, fn);\n }\n return fn.apply(element, [event]);\n };\n}\nfunction bootstrapDelegationHandler(element, selector, fn) {\n return function handler(event) {\n const domElements = element.querySelectorAll(selector);\n for (let {\n target\n } = event; target && target !== this; target = target.parentNode) {\n for (const domElement of domElements) {\n if (domElement !== target) {\n continue;\n }\n hydrateObj(event, {\n delegateTarget: target\n });\n if (handler.oneOff) {\n EventHandler.off(element, event.type, selector, fn);\n }\n return fn.apply(target, [event]);\n }\n }\n };\n}\nfunction findHandler(events, callable, delegationSelector = null) {\n return Object.values(events).find(event => event.callable === callable && event.delegationSelector === delegationSelector);\n}\nfunction normalizeParameters(originalTypeEvent, handler, delegationFunction) {\n const isDelegated = typeof handler === 'string';\n // TODO: tooltip passes `false` instead of selector, so we need to check\n const callable = isDelegated ? delegationFunction : handler || delegationFunction;\n let typeEvent = getTypeEvent(originalTypeEvent);\n if (!nativeEvents.has(typeEvent)) {\n typeEvent = originalTypeEvent;\n }\n return [isDelegated, callable, typeEvent];\n}\nfunction addHandler(element, originalTypeEvent, handler, delegationFunction, oneOff) {\n if (typeof originalTypeEvent !== 'string' || !element) {\n return;\n }\n let [isDelegated, callable, typeEvent] = normalizeParameters(originalTypeEvent, handler, delegationFunction);\n\n // in case of mouseenter or mouseleave wrap the handler within a function that checks for its DOM position\n // this prevents the handler from being dispatched the same way as mouseover or mouseout does\n if (originalTypeEvent in customEvents) {\n const wrapFunction = fn => {\n return function (event) {\n if (!event.relatedTarget || event.relatedTarget !== event.delegateTarget && !event.delegateTarget.contains(event.relatedTarget)) {\n return fn.call(this, event);\n }\n };\n };\n callable = wrapFunction(callable);\n }\n const events = getElementEvents(element);\n const handlers = events[typeEvent] || (events[typeEvent] = {});\n const previousFunction = findHandler(handlers, callable, isDelegated ? handler : null);\n if (previousFunction) {\n previousFunction.oneOff = previousFunction.oneOff && oneOff;\n return;\n }\n const uid = makeEventUid(callable, originalTypeEvent.replace(namespaceRegex, ''));\n const fn = isDelegated ? bootstrapDelegationHandler(element, handler, callable) : bootstrapHandler(element, callable);\n fn.delegationSelector = isDelegated ? handler : null;\n fn.callable = callable;\n fn.oneOff = oneOff;\n fn.uidEvent = uid;\n handlers[uid] = fn;\n element.addEventListener(typeEvent, fn, isDelegated);\n}\nfunction removeHandler(element, events, typeEvent, handler, delegationSelector) {\n const fn = findHandler(events[typeEvent], handler, delegationSelector);\n if (!fn) {\n return;\n }\n element.removeEventListener(typeEvent, fn, Boolean(delegationSelector));\n delete events[typeEvent][fn.uidEvent];\n}\nfunction removeNamespacedHandlers(element, events, typeEvent, namespace) {\n const storeElementEvent = events[typeEvent] || {};\n for (const [handlerKey, event] of Object.entries(storeElementEvent)) {\n if (handlerKey.includes(namespace)) {\n removeHandler(element, events, typeEvent, event.callable, event.delegationSelector);\n }\n }\n}\nfunction getTypeEvent(event) {\n // allow to get the native events from namespaced events ('click.bs.button' --> 'click')\n event = event.replace(stripNameRegex, '');\n return customEvents[event] || event;\n}\nconst EventHandler = {\n on(element, event, handler, delegationFunction) {\n addHandler(element, event, handler, delegationFunction, false);\n },\n one(element, event, handler, delegationFunction) {\n addHandler(element, event, handler, delegationFunction, true);\n },\n off(element, originalTypeEvent, handler, delegationFunction) {\n if (typeof originalTypeEvent !== 'string' || !element) {\n return;\n }\n const [isDelegated, callable, typeEvent] = normalizeParameters(originalTypeEvent, handler, delegationFunction);\n const inNamespace = typeEvent !== originalTypeEvent;\n const events = getElementEvents(element);\n const storeElementEvent = events[typeEvent] || {};\n const isNamespace = originalTypeEvent.startsWith('.');\n if (typeof callable !== 'undefined') {\n // Simplest case: handler is passed, remove that listener ONLY.\n if (!Object.keys(storeElementEvent).length) {\n return;\n }\n removeHandler(element, events, typeEvent, callable, isDelegated ? handler : null);\n return;\n }\n if (isNamespace) {\n for (const elementEvent of Object.keys(events)) {\n removeNamespacedHandlers(element, events, elementEvent, originalTypeEvent.slice(1));\n }\n }\n for (const [keyHandlers, event] of Object.entries(storeElementEvent)) {\n const handlerKey = keyHandlers.replace(stripUidRegex, '');\n if (!inNamespace || originalTypeEvent.includes(handlerKey)) {\n removeHandler(element, events, typeEvent, event.callable, event.delegationSelector);\n }\n }\n },\n trigger(element, event, args) {\n if (typeof event !== 'string' || !element) {\n return null;\n }\n const $ = getjQuery();\n const typeEvent = getTypeEvent(event);\n const inNamespace = event !== typeEvent;\n let jQueryEvent = null;\n let bubbles = true;\n let nativeDispatch = true;\n let defaultPrevented = false;\n if (inNamespace && $) {\n jQueryEvent = $.Event(event, args);\n $(element).trigger(jQueryEvent);\n bubbles = !jQueryEvent.isPropagationStopped();\n nativeDispatch = !jQueryEvent.isImmediatePropagationStopped();\n defaultPrevented = jQueryEvent.isDefaultPrevented();\n }\n const evt = hydrateObj(new Event(event, {\n bubbles,\n cancelable: true\n }), args);\n if (defaultPrevented) {\n evt.preventDefault();\n }\n if (nativeDispatch) {\n element.dispatchEvent(evt);\n }\n if (evt.defaultPrevented && jQueryEvent) {\n jQueryEvent.preventDefault();\n }\n return evt;\n }\n};\nfunction hydrateObj(obj, meta = {}) {\n for (const [key, value] of Object.entries(meta)) {\n try {\n obj[key] = value;\n } catch (_unused) {\n Object.defineProperty(obj, key, {\n configurable: true,\n get() {\n return value;\n }\n });\n }\n }\n return obj;\n}\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap dom/manipulator.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\nfunction normalizeData(value) {\n if (value === 'true') {\n return true;\n }\n if (value === 'false') {\n return false;\n }\n if (value === Number(value).toString()) {\n return Number(value);\n }\n if (value === '' || value === 'null') {\n return null;\n }\n if (typeof value !== 'string') {\n return value;\n }\n try {\n return JSON.parse(decodeURIComponent(value));\n } catch (_unused) {\n return value;\n }\n}\nfunction normalizeDataKey(key) {\n return key.replace(/[A-Z]/g, chr => `-${chr.toLowerCase()}`);\n}\nconst Manipulator = {\n setDataAttribute(element, key, value) {\n element.setAttribute(`data-bs-${normalizeDataKey(key)}`, value);\n },\n removeDataAttribute(element, key) {\n element.removeAttribute(`data-bs-${normalizeDataKey(key)}`);\n },\n getDataAttributes(element) {\n if (!element) {\n return {};\n }\n const attributes = {};\n const bsKeys = Object.keys(element.dataset).filter(key => key.startsWith('bs') && !key.startsWith('bsConfig'));\n for (const key of bsKeys) {\n let pureKey = key.replace(/^bs/, '');\n pureKey = pureKey.charAt(0).toLowerCase() + pureKey.slice(1, pureKey.length);\n attributes[pureKey] = normalizeData(element.dataset[key]);\n }\n return attributes;\n },\n getDataAttribute(element, key) {\n return normalizeData(element.getAttribute(`data-bs-${normalizeDataKey(key)}`));\n }\n};\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap util/config.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Class definition\n */\n\nclass Config {\n // Getters\n static get Default() {\n return {};\n }\n static get DefaultType() {\n return {};\n }\n static get NAME() {\n throw new Error('You have to implement the static method \"NAME\", for each component!');\n }\n _getConfig(config) {\n config = this._mergeConfigObj(config);\n config = this._configAfterMerge(config);\n this._typeCheckConfig(config);\n return config;\n }\n _configAfterMerge(config) {\n return config;\n }\n _mergeConfigObj(config, element) {\n const jsonConfig = isElement(element) ? Manipulator.getDataAttribute(element, 'config') : {}; // try to parse\n\n return {\n ...this.constructor.Default,\n ...(typeof jsonConfig === 'object' ? jsonConfig : {}),\n ...(isElement(element) ? Manipulator.getDataAttributes(element) : {}),\n ...(typeof config === 'object' ? config : {})\n };\n }\n _typeCheckConfig(config, configTypes = this.constructor.DefaultType) {\n for (const [property, expectedTypes] of Object.entries(configTypes)) {\n const value = config[property];\n const valueType = isElement(value) ? 'element' : toType(value);\n if (!new RegExp(expectedTypes).test(valueType)) {\n throw new TypeError(`${this.constructor.NAME.toUpperCase()}: Option \"${property}\" provided type \"${valueType}\" but expected type \"${expectedTypes}\".`);\n }\n }\n }\n}\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap base-component.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst VERSION = '5.3.3';\n\n/**\n * Class definition\n */\n\nclass BaseComponent extends Config {\n constructor(element, config) {\n super();\n element = getElement(element);\n if (!element) {\n return;\n }\n this._element = element;\n this._config = this._getConfig(config);\n Data.set(this._element, this.constructor.DATA_KEY, this);\n }\n\n // Public\n dispose() {\n Data.remove(this._element, this.constructor.DATA_KEY);\n EventHandler.off(this._element, this.constructor.EVENT_KEY);\n for (const propertyName of Object.getOwnPropertyNames(this)) {\n this[propertyName] = null;\n }\n }\n _queueCallback(callback, element, isAnimated = true) {\n executeAfterTransition(callback, element, isAnimated);\n }\n _getConfig(config) {\n config = this._mergeConfigObj(config, this._element);\n config = this._configAfterMerge(config);\n this._typeCheckConfig(config);\n return config;\n }\n\n // Static\n static getInstance(element) {\n return Data.get(getElement(element), this.DATA_KEY);\n }\n static getOrCreateInstance(element, config = {}) {\n return this.getInstance(element) || new this(element, typeof config === 'object' ? config : null);\n }\n static get VERSION() {\n return VERSION;\n }\n static get DATA_KEY() {\n return `bs.${this.NAME}`;\n }\n static get EVENT_KEY() {\n return `.${this.DATA_KEY}`;\n }\n static eventName(name) {\n return `${name}${this.EVENT_KEY}`;\n }\n}\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap dom/selector-engine.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\nconst getSelector = element => {\n let selector = element.getAttribute('data-bs-target');\n if (!selector || selector === '#') {\n let hrefAttribute = element.getAttribute('href');\n\n // The only valid content that could double as a selector are IDs or classes,\n // so everything starting with `#` or `.`. If a \"real\" URL is used as the selector,\n // `document.querySelector` will rightfully complain it is invalid.\n // See https://github.com/twbs/bootstrap/issues/32273\n if (!hrefAttribute || !hrefAttribute.includes('#') && !hrefAttribute.startsWith('.')) {\n return null;\n }\n\n // Just in case some CMS puts out a full URL with the anchor appended\n if (hrefAttribute.includes('#') && !hrefAttribute.startsWith('#')) {\n hrefAttribute = `#${hrefAttribute.split('#')[1]}`;\n }\n selector = hrefAttribute && hrefAttribute !== '#' ? hrefAttribute.trim() : null;\n }\n return selector ? selector.split(',').map(sel => parseSelector(sel)).join(',') : null;\n};\nconst SelectorEngine = {\n find(selector, element = document.documentElement) {\n return [].concat(...Element.prototype.querySelectorAll.call(element, selector));\n },\n findOne(selector, element = document.documentElement) {\n return Element.prototype.querySelector.call(element, selector);\n },\n children(element, selector) {\n return [].concat(...element.children).filter(child => child.matches(selector));\n },\n parents(element, selector) {\n const parents = [];\n let ancestor = element.parentNode.closest(selector);\n while (ancestor) {\n parents.push(ancestor);\n ancestor = ancestor.parentNode.closest(selector);\n }\n return parents;\n },\n prev(element, selector) {\n let previous = element.previousElementSibling;\n while (previous) {\n if (previous.matches(selector)) {\n return [previous];\n }\n previous = previous.previousElementSibling;\n }\n return [];\n },\n // TODO: this is now unused; remove later along with prev()\n next(element, selector) {\n let next = element.nextElementSibling;\n while (next) {\n if (next.matches(selector)) {\n return [next];\n }\n next = next.nextElementSibling;\n }\n return [];\n },\n focusableChildren(element) {\n const focusables = ['a', 'button', 'input', 'textarea', 'select', 'details', '[tabindex]', '[contenteditable=\"true\"]'].map(selector => `${selector}:not([tabindex^=\"-\"])`).join(',');\n return this.find(focusables, element).filter(el => !isDisabled(el) && isVisible(el));\n },\n getSelectorFromElement(element) {\n const selector = getSelector(element);\n if (selector) {\n return SelectorEngine.findOne(selector) ? selector : null;\n }\n return null;\n },\n getElementFromSelector(element) {\n const selector = getSelector(element);\n return selector ? SelectorEngine.findOne(selector) : null;\n },\n getMultipleElementsFromSelector(element) {\n const selector = getSelector(element);\n return selector ? SelectorEngine.find(selector) : [];\n }\n};\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap util/component-functions.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\nconst enableDismissTrigger = (component, method = 'hide') => {\n const clickEvent = `click.dismiss${component.EVENT_KEY}`;\n const name = component.NAME;\n EventHandler.on(document, clickEvent, `[data-bs-dismiss=\"${name}\"]`, function (event) {\n if (['A', 'AREA'].includes(this.tagName)) {\n event.preventDefault();\n }\n if (isDisabled(this)) {\n return;\n }\n const target = SelectorEngine.getElementFromSelector(this) || this.closest(`.${name}`);\n const instance = component.getOrCreateInstance(target);\n\n // Method argument is left, for Alert and only, as it doesn't implement the 'hide' method\n instance[method]();\n });\n};\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap alert.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst NAME$f = 'alert';\nconst DATA_KEY$a = 'bs.alert';\nconst EVENT_KEY$b = `.${DATA_KEY$a}`;\nconst EVENT_CLOSE = `close${EVENT_KEY$b}`;\nconst EVENT_CLOSED = `closed${EVENT_KEY$b}`;\nconst CLASS_NAME_FADE$5 = 'fade';\nconst CLASS_NAME_SHOW$8 = 'show';\n\n/**\n * Class definition\n */\n\nclass Alert extends BaseComponent {\n // Getters\n static get NAME() {\n return NAME$f;\n }\n\n // Public\n close() {\n const closeEvent = EventHandler.trigger(this._element, EVENT_CLOSE);\n if (closeEvent.defaultPrevented) {\n return;\n }\n this._element.classList.remove(CLASS_NAME_SHOW$8);\n const isAnimated = this._element.classList.contains(CLASS_NAME_FADE$5);\n this._queueCallback(() => this._destroyElement(), this._element, isAnimated);\n }\n\n // Private\n _destroyElement() {\n this._element.remove();\n EventHandler.trigger(this._element, EVENT_CLOSED);\n this.dispose();\n }\n\n // Static\n static jQueryInterface(config) {\n return this.each(function () {\n const data = Alert.getOrCreateInstance(this);\n if (typeof config !== 'string') {\n return;\n }\n if (data[config] === undefined || config.startsWith('_') || config === 'constructor') {\n throw new TypeError(`No method named \"${config}\"`);\n }\n data[config](this);\n });\n }\n}\n\n/**\n * Data API implementation\n */\n\nenableDismissTrigger(Alert, 'close');\n\n/**\n * jQuery\n */\n\ndefineJQueryPlugin(Alert);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap button.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst NAME$e = 'button';\nconst DATA_KEY$9 = 'bs.button';\nconst EVENT_KEY$a = `.${DATA_KEY$9}`;\nconst DATA_API_KEY$6 = '.data-api';\nconst CLASS_NAME_ACTIVE$3 = 'active';\nconst SELECTOR_DATA_TOGGLE$5 = '[data-bs-toggle=\"button\"]';\nconst EVENT_CLICK_DATA_API$6 = `click${EVENT_KEY$a}${DATA_API_KEY$6}`;\n\n/**\n * Class definition\n */\n\nclass Button extends BaseComponent {\n // Getters\n static get NAME() {\n return NAME$e;\n }\n\n // Public\n toggle() {\n // Toggle class and sync the `aria-pressed` attribute with the return value of the `.toggle()` method\n this._element.setAttribute('aria-pressed', this._element.classList.toggle(CLASS_NAME_ACTIVE$3));\n }\n\n // Static\n static jQueryInterface(config) {\n return this.each(function () {\n const data = Button.getOrCreateInstance(this);\n if (config === 'toggle') {\n data[config]();\n }\n });\n }\n}\n\n/**\n * Data API implementation\n */\n\nEventHandler.on(document, EVENT_CLICK_DATA_API$6, SELECTOR_DATA_TOGGLE$5, event => {\n event.preventDefault();\n const button = event.target.closest(SELECTOR_DATA_TOGGLE$5);\n const data = Button.getOrCreateInstance(button);\n data.toggle();\n});\n\n/**\n * jQuery\n */\n\ndefineJQueryPlugin(Button);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap util/swipe.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst NAME$d = 'swipe';\nconst EVENT_KEY$9 = '.bs.swipe';\nconst EVENT_TOUCHSTART = `touchstart${EVENT_KEY$9}`;\nconst EVENT_TOUCHMOVE = `touchmove${EVENT_KEY$9}`;\nconst EVENT_TOUCHEND = `touchend${EVENT_KEY$9}`;\nconst EVENT_POINTERDOWN = `pointerdown${EVENT_KEY$9}`;\nconst EVENT_POINTERUP = `pointerup${EVENT_KEY$9}`;\nconst POINTER_TYPE_TOUCH = 'touch';\nconst POINTER_TYPE_PEN = 'pen';\nconst CLASS_NAME_POINTER_EVENT = 'pointer-event';\nconst SWIPE_THRESHOLD = 40;\nconst Default$c = {\n endCallback: null,\n leftCallback: null,\n rightCallback: null\n};\nconst DefaultType$c = {\n endCallback: '(function|null)',\n leftCallback: '(function|null)',\n rightCallback: '(function|null)'\n};\n\n/**\n * Class definition\n */\n\nclass Swipe extends Config {\n constructor(element, config) {\n super();\n this._element = element;\n if (!element || !Swipe.isSupported()) {\n return;\n }\n this._config = this._getConfig(config);\n this._deltaX = 0;\n this._supportPointerEvents = Boolean(window.PointerEvent);\n this._initEvents();\n }\n\n // Getters\n static get Default() {\n return Default$c;\n }\n static get DefaultType() {\n return DefaultType$c;\n }\n static get NAME() {\n return NAME$d;\n }\n\n // Public\n dispose() {\n EventHandler.off(this._element, EVENT_KEY$9);\n }\n\n // Private\n _start(event) {\n if (!this._supportPointerEvents) {\n this._deltaX = event.touches[0].clientX;\n return;\n }\n if (this._eventIsPointerPenTouch(event)) {\n this._deltaX = event.clientX;\n }\n }\n _end(event) {\n if (this._eventIsPointerPenTouch(event)) {\n this._deltaX = event.clientX - this._deltaX;\n }\n this._handleSwipe();\n execute(this._config.endCallback);\n }\n _move(event) {\n this._deltaX = event.touches && event.touches.length > 1 ? 0 : event.touches[0].clientX - this._deltaX;\n }\n _handleSwipe() {\n const absDeltaX = Math.abs(this._deltaX);\n if (absDeltaX <= SWIPE_THRESHOLD) {\n return;\n }\n const direction = absDeltaX / this._deltaX;\n this._deltaX = 0;\n if (!direction) {\n return;\n }\n execute(direction > 0 ? this._config.rightCallback : this._config.leftCallback);\n }\n _initEvents() {\n if (this._supportPointerEvents) {\n EventHandler.on(this._element, EVENT_POINTERDOWN, event => this._start(event));\n EventHandler.on(this._element, EVENT_POINTERUP, event => this._end(event));\n this._element.classList.add(CLASS_NAME_POINTER_EVENT);\n } else {\n EventHandler.on(this._element, EVENT_TOUCHSTART, event => this._start(event));\n EventHandler.on(this._element, EVENT_TOUCHMOVE, event => this._move(event));\n EventHandler.on(this._element, EVENT_TOUCHEND, event => this._end(event));\n }\n }\n _eventIsPointerPenTouch(event) {\n return this._supportPointerEvents && (event.pointerType === POINTER_TYPE_PEN || event.pointerType === POINTER_TYPE_TOUCH);\n }\n\n // Static\n static isSupported() {\n return 'ontouchstart' in document.documentElement || navigator.maxTouchPoints > 0;\n }\n}\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap carousel.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst NAME$c = 'carousel';\nconst DATA_KEY$8 = 'bs.carousel';\nconst EVENT_KEY$8 = `.${DATA_KEY$8}`;\nconst DATA_API_KEY$5 = '.data-api';\nconst ARROW_LEFT_KEY$1 = 'ArrowLeft';\nconst ARROW_RIGHT_KEY$1 = 'ArrowRight';\nconst TOUCHEVENT_COMPAT_WAIT = 500; // Time for mouse compat events to fire after touch\n\nconst ORDER_NEXT = 'next';\nconst ORDER_PREV = 'prev';\nconst DIRECTION_LEFT = 'left';\nconst DIRECTION_RIGHT = 'right';\nconst EVENT_SLIDE = `slide${EVENT_KEY$8}`;\nconst EVENT_SLID = `slid${EVENT_KEY$8}`;\nconst EVENT_KEYDOWN$1 = `keydown${EVENT_KEY$8}`;\nconst EVENT_MOUSEENTER$1 = `mouseenter${EVENT_KEY$8}`;\nconst EVENT_MOUSELEAVE$1 = `mouseleave${EVENT_KEY$8}`;\nconst EVENT_DRAG_START = `dragstart${EVENT_KEY$8}`;\nconst EVENT_LOAD_DATA_API$3 = `load${EVENT_KEY$8}${DATA_API_KEY$5}`;\nconst EVENT_CLICK_DATA_API$5 = `click${EVENT_KEY$8}${DATA_API_KEY$5}`;\nconst CLASS_NAME_CAROUSEL = 'carousel';\nconst CLASS_NAME_ACTIVE$2 = 'active';\nconst CLASS_NAME_SLIDE = 'slide';\nconst CLASS_NAME_END = 'carousel-item-end';\nconst CLASS_NAME_START = 'carousel-item-start';\nconst CLASS_NAME_NEXT = 'carousel-item-next';\nconst CLASS_NAME_PREV = 'carousel-item-prev';\nconst SELECTOR_ACTIVE = '.active';\nconst SELECTOR_ITEM = '.carousel-item';\nconst SELECTOR_ACTIVE_ITEM = SELECTOR_ACTIVE + SELECTOR_ITEM;\nconst SELECTOR_ITEM_IMG = '.carousel-item img';\nconst SELECTOR_INDICATORS = '.carousel-indicators';\nconst SELECTOR_DATA_SLIDE = '[data-bs-slide], [data-bs-slide-to]';\nconst SELECTOR_DATA_RIDE = '[data-bs-ride=\"carousel\"]';\nconst KEY_TO_DIRECTION = {\n [ARROW_LEFT_KEY$1]: DIRECTION_RIGHT,\n [ARROW_RIGHT_KEY$1]: DIRECTION_LEFT\n};\nconst Default$b = {\n interval: 5000,\n keyboard: true,\n pause: 'hover',\n ride: false,\n touch: true,\n wrap: true\n};\nconst DefaultType$b = {\n interval: '(number|boolean)',\n // TODO:v6 remove boolean support\n keyboard: 'boolean',\n pause: '(string|boolean)',\n ride: '(boolean|string)',\n touch: 'boolean',\n wrap: 'boolean'\n};\n\n/**\n * Class definition\n */\n\nclass Carousel extends BaseComponent {\n constructor(element, config) {\n super(element, config);\n this._interval = null;\n this._activeElement = null;\n this._isSliding = false;\n this.touchTimeout = null;\n this._swipeHelper = null;\n this._indicatorsElement = SelectorEngine.findOne(SELECTOR_INDICATORS, this._element);\n this._addEventListeners();\n if (this._config.ride === CLASS_NAME_CAROUSEL) {\n this.cycle();\n }\n }\n\n // Getters\n static get Default() {\n return Default$b;\n }\n static get DefaultType() {\n return DefaultType$b;\n }\n static get NAME() {\n return NAME$c;\n }\n\n // Public\n next() {\n this._slide(ORDER_NEXT);\n }\n nextWhenVisible() {\n // FIXME TODO use `document.visibilityState`\n // Don't call next when the page isn't visible\n // or the carousel or its parent isn't visible\n if (!document.hidden && isVisible(this._element)) {\n this.next();\n }\n }\n prev() {\n this._slide(ORDER_PREV);\n }\n pause() {\n if (this._isSliding) {\n triggerTransitionEnd(this._element);\n }\n this._clearInterval();\n }\n cycle() {\n this._clearInterval();\n this._updateInterval();\n this._interval = setInterval(() => this.nextWhenVisible(), this._config.interval);\n }\n _maybeEnableCycle() {\n if (!this._config.ride) {\n return;\n }\n if (this._isSliding) {\n EventHandler.one(this._element, EVENT_SLID, () => this.cycle());\n return;\n }\n this.cycle();\n }\n to(index) {\n const items = this._getItems();\n if (index > items.length - 1 || index < 0) {\n return;\n }\n if (this._isSliding) {\n EventHandler.one(this._element, EVENT_SLID, () => this.to(index));\n return;\n }\n const activeIndex = this._getItemIndex(this._getActive());\n if (activeIndex === index) {\n return;\n }\n const order = index > activeIndex ? ORDER_NEXT : ORDER_PREV;\n this._slide(order, items[index]);\n }\n dispose() {\n if (this._swipeHelper) {\n this._swipeHelper.dispose();\n }\n super.dispose();\n }\n\n // Private\n _configAfterMerge(config) {\n config.defaultInterval = config.interval;\n return config;\n }\n _addEventListeners() {\n if (this._config.keyboard) {\n EventHandler.on(this._element, EVENT_KEYDOWN$1, event => this._keydown(event));\n }\n if (this._config.pause === 'hover') {\n EventHandler.on(this._element, EVENT_MOUSEENTER$1, () => this.pause());\n EventHandler.on(this._element, EVENT_MOUSELEAVE$1, () => this._maybeEnableCycle());\n }\n if (this._config.touch && Swipe.isSupported()) {\n this._addTouchEventListeners();\n }\n }\n _addTouchEventListeners() {\n for (const img of SelectorEngine.find(SELECTOR_ITEM_IMG, this._element)) {\n EventHandler.on(img, EVENT_DRAG_START, event => event.preventDefault());\n }\n const endCallBack = () => {\n if (this._config.pause !== 'hover') {\n return;\n }\n\n // If it's a touch-enabled device, mouseenter/leave are fired as\n // part of the mouse compatibility events on first tap - the carousel\n // would stop cycling until user tapped out of it;\n // here, we listen for touchend, explicitly pause the carousel\n // (as if it's the second time we tap on it, mouseenter compat event\n // is NOT fired) and after a timeout (to allow for mouse compatibility\n // events to fire) we explicitly restart cycling\n\n this.pause();\n if (this.touchTimeout) {\n clearTimeout(this.touchTimeout);\n }\n this.touchTimeout = setTimeout(() => this._maybeEnableCycle(), TOUCHEVENT_COMPAT_WAIT + this._config.interval);\n };\n const swipeConfig = {\n leftCallback: () => this._slide(this._directionToOrder(DIRECTION_LEFT)),\n rightCallback: () => this._slide(this._directionToOrder(DIRECTION_RIGHT)),\n endCallback: endCallBack\n };\n this._swipeHelper = new Swipe(this._element, swipeConfig);\n }\n _keydown(event) {\n if (/input|textarea/i.test(event.target.tagName)) {\n return;\n }\n const direction = KEY_TO_DIRECTION[event.key];\n if (direction) {\n event.preventDefault();\n this._slide(this._directionToOrder(direction));\n }\n }\n _getItemIndex(element) {\n return this._getItems().indexOf(element);\n }\n _setActiveIndicatorElement(index) {\n if (!this._indicatorsElement) {\n return;\n }\n const activeIndicator = SelectorEngine.findOne(SELECTOR_ACTIVE, this._indicatorsElement);\n activeIndicator.classList.remove(CLASS_NAME_ACTIVE$2);\n activeIndicator.removeAttribute('aria-current');\n const newActiveIndicator = SelectorEngine.findOne(`[data-bs-slide-to=\"${index}\"]`, this._indicatorsElement);\n if (newActiveIndicator) {\n newActiveIndicator.classList.add(CLASS_NAME_ACTIVE$2);\n newActiveIndicator.setAttribute('aria-current', 'true');\n }\n }\n _updateInterval() {\n const element = this._activeElement || this._getActive();\n if (!element) {\n return;\n }\n const elementInterval = Number.parseInt(element.getAttribute('data-bs-interval'), 10);\n this._config.interval = elementInterval || this._config.defaultInterval;\n }\n _slide(order, element = null) {\n if (this._isSliding) {\n return;\n }\n const activeElement = this._getActive();\n const isNext = order === ORDER_NEXT;\n const nextElement = element || getNextActiveElement(this._getItems(), activeElement, isNext, this._config.wrap);\n if (nextElement === activeElement) {\n return;\n }\n const nextElementIndex = this._getItemIndex(nextElement);\n const triggerEvent = eventName => {\n return EventHandler.trigger(this._element, eventName, {\n relatedTarget: nextElement,\n direction: this._orderToDirection(order),\n from: this._getItemIndex(activeElement),\n to: nextElementIndex\n });\n };\n const slideEvent = triggerEvent(EVENT_SLIDE);\n if (slideEvent.defaultPrevented) {\n return;\n }\n if (!activeElement || !nextElement) {\n // Some weirdness is happening, so we bail\n // TODO: change tests that use empty divs to avoid this check\n return;\n }\n const isCycling = Boolean(this._interval);\n this.pause();\n this._isSliding = true;\n this._setActiveIndicatorElement(nextElementIndex);\n this._activeElement = nextElement;\n const directionalClassName = isNext ? CLASS_NAME_START : CLASS_NAME_END;\n const orderClassName = isNext ? CLASS_NAME_NEXT : CLASS_NAME_PREV;\n nextElement.classList.add(orderClassName);\n reflow(nextElement);\n activeElement.classList.add(directionalClassName);\n nextElement.classList.add(directionalClassName);\n const completeCallBack = () => {\n nextElement.classList.remove(directionalClassName, orderClassName);\n nextElement.classList.add(CLASS_NAME_ACTIVE$2);\n activeElement.classList.remove(CLASS_NAME_ACTIVE$2, orderClassName, directionalClassName);\n this._isSliding = false;\n triggerEvent(EVENT_SLID);\n };\n this._queueCallback(completeCallBack, activeElement, this._isAnimated());\n if (isCycling) {\n this.cycle();\n }\n }\n _isAnimated() {\n return this._element.classList.contains(CLASS_NAME_SLIDE);\n }\n _getActive() {\n return SelectorEngine.findOne(SELECTOR_ACTIVE_ITEM, this._element);\n }\n _getItems() {\n return SelectorEngine.find(SELECTOR_ITEM, this._element);\n }\n _clearInterval() {\n if (this._interval) {\n clearInterval(this._interval);\n this._interval = null;\n }\n }\n _directionToOrder(direction) {\n if (isRTL()) {\n return direction === DIRECTION_LEFT ? ORDER_PREV : ORDER_NEXT;\n }\n return direction === DIRECTION_LEFT ? ORDER_NEXT : ORDER_PREV;\n }\n _orderToDirection(order) {\n if (isRTL()) {\n return order === ORDER_PREV ? DIRECTION_LEFT : DIRECTION_RIGHT;\n }\n return order === ORDER_PREV ? DIRECTION_RIGHT : DIRECTION_LEFT;\n }\n\n // Static\n static jQueryInterface(config) {\n return this.each(function () {\n const data = Carousel.getOrCreateInstance(this, config);\n if (typeof config === 'number') {\n data.to(config);\n return;\n }\n if (typeof config === 'string') {\n if (data[config] === undefined || config.startsWith('_') || config === 'constructor') {\n throw new TypeError(`No method named \"${config}\"`);\n }\n data[config]();\n }\n });\n }\n}\n\n/**\n * Data API implementation\n */\n\nEventHandler.on(document, EVENT_CLICK_DATA_API$5, SELECTOR_DATA_SLIDE, function (event) {\n const target = SelectorEngine.getElementFromSelector(this);\n if (!target || !target.classList.contains(CLASS_NAME_CAROUSEL)) {\n return;\n }\n event.preventDefault();\n const carousel = Carousel.getOrCreateInstance(target);\n const slideIndex = this.getAttribute('data-bs-slide-to');\n if (slideIndex) {\n carousel.to(slideIndex);\n carousel._maybeEnableCycle();\n return;\n }\n if (Manipulator.getDataAttribute(this, 'slide') === 'next') {\n carousel.next();\n carousel._maybeEnableCycle();\n return;\n }\n carousel.prev();\n carousel._maybeEnableCycle();\n});\nEventHandler.on(window, EVENT_LOAD_DATA_API$3, () => {\n const carousels = SelectorEngine.find(SELECTOR_DATA_RIDE);\n for (const carousel of carousels) {\n Carousel.getOrCreateInstance(carousel);\n }\n});\n\n/**\n * jQuery\n */\n\ndefineJQueryPlugin(Carousel);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap collapse.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst NAME$b = 'collapse';\nconst DATA_KEY$7 = 'bs.collapse';\nconst EVENT_KEY$7 = `.${DATA_KEY$7}`;\nconst DATA_API_KEY$4 = '.data-api';\nconst EVENT_SHOW$6 = `show${EVENT_KEY$7}`;\nconst EVENT_SHOWN$6 = `shown${EVENT_KEY$7}`;\nconst EVENT_HIDE$6 = `hide${EVENT_KEY$7}`;\nconst EVENT_HIDDEN$6 = `hidden${EVENT_KEY$7}`;\nconst EVENT_CLICK_DATA_API$4 = `click${EVENT_KEY$7}${DATA_API_KEY$4}`;\nconst CLASS_NAME_SHOW$7 = 'show';\nconst CLASS_NAME_COLLAPSE = 'collapse';\nconst CLASS_NAME_COLLAPSING = 'collapsing';\nconst CLASS_NAME_COLLAPSED = 'collapsed';\nconst CLASS_NAME_DEEPER_CHILDREN = `:scope .${CLASS_NAME_COLLAPSE} .${CLASS_NAME_COLLAPSE}`;\nconst CLASS_NAME_HORIZONTAL = 'collapse-horizontal';\nconst WIDTH = 'width';\nconst HEIGHT = 'height';\nconst SELECTOR_ACTIVES = '.collapse.show, .collapse.collapsing';\nconst SELECTOR_DATA_TOGGLE$4 = '[data-bs-toggle=\"collapse\"]';\nconst Default$a = {\n parent: null,\n toggle: true\n};\nconst DefaultType$a = {\n parent: '(null|element)',\n toggle: 'boolean'\n};\n\n/**\n * Class definition\n */\n\nclass Collapse extends BaseComponent {\n constructor(element, config) {\n super(element, config);\n this._isTransitioning = false;\n this._triggerArray = [];\n const toggleList = SelectorEngine.find(SELECTOR_DATA_TOGGLE$4);\n for (const elem of toggleList) {\n const selector = SelectorEngine.getSelectorFromElement(elem);\n const filterElement = SelectorEngine.find(selector).filter(foundElement => foundElement === this._element);\n if (selector !== null && filterElement.length) {\n this._triggerArray.push(elem);\n }\n }\n this._initializeChildren();\n if (!this._config.parent) {\n this._addAriaAndCollapsedClass(this._triggerArray, this._isShown());\n }\n if (this._config.toggle) {\n this.toggle();\n }\n }\n\n // Getters\n static get Default() {\n return Default$a;\n }\n static get DefaultType() {\n return DefaultType$a;\n }\n static get NAME() {\n return NAME$b;\n }\n\n // Public\n toggle() {\n if (this._isShown()) {\n this.hide();\n } else {\n this.show();\n }\n }\n show() {\n if (this._isTransitioning || this._isShown()) {\n return;\n }\n let activeChildren = [];\n\n // find active children\n if (this._config.parent) {\n activeChildren = this._getFirstLevelChildren(SELECTOR_ACTIVES).filter(element => element !== this._element).map(element => Collapse.getOrCreateInstance(element, {\n toggle: false\n }));\n }\n if (activeChildren.length && activeChildren[0]._isTransitioning) {\n return;\n }\n const startEvent = EventHandler.trigger(this._element, EVENT_SHOW$6);\n if (startEvent.defaultPrevented) {\n return;\n }\n for (const activeInstance of activeChildren) {\n activeInstance.hide();\n }\n const dimension = this._getDimension();\n this._element.classList.remove(CLASS_NAME_COLLAPSE);\n this._element.classList.add(CLASS_NAME_COLLAPSING);\n this._element.style[dimension] = 0;\n this._addAriaAndCollapsedClass(this._triggerArray, true);\n this._isTransitioning = true;\n const complete = () => {\n this._isTransitioning = false;\n this._element.classList.remove(CLASS_NAME_COLLAPSING);\n this._element.classList.add(CLASS_NAME_COLLAPSE, CLASS_NAME_SHOW$7);\n this._element.style[dimension] = '';\n EventHandler.trigger(this._element, EVENT_SHOWN$6);\n };\n const capitalizedDimension = dimension[0].toUpperCase() + dimension.slice(1);\n const scrollSize = `scroll${capitalizedDimension}`;\n this._queueCallback(complete, this._element, true);\n this._element.style[dimension] = `${this._element[scrollSize]}px`;\n }\n hide() {\n if (this._isTransitioning || !this._isShown()) {\n return;\n }\n const startEvent = EventHandler.trigger(this._element, EVENT_HIDE$6);\n if (startEvent.defaultPrevented) {\n return;\n }\n const dimension = this._getDimension();\n this._element.style[dimension] = `${this._element.getBoundingClientRect()[dimension]}px`;\n reflow(this._element);\n this._element.classList.add(CLASS_NAME_COLLAPSING);\n this._element.classList.remove(CLASS_NAME_COLLAPSE, CLASS_NAME_SHOW$7);\n for (const trigger of this._triggerArray) {\n const element = SelectorEngine.getElementFromSelector(trigger);\n if (element && !this._isShown(element)) {\n this._addAriaAndCollapsedClass([trigger], false);\n }\n }\n this._isTransitioning = true;\n const complete = () => {\n this._isTransitioning = false;\n this._element.classList.remove(CLASS_NAME_COLLAPSING);\n this._element.classList.add(CLASS_NAME_COLLAPSE);\n EventHandler.trigger(this._element, EVENT_HIDDEN$6);\n };\n this._element.style[dimension] = '';\n this._queueCallback(complete, this._element, true);\n }\n _isShown(element = this._element) {\n return element.classList.contains(CLASS_NAME_SHOW$7);\n }\n\n // Private\n _configAfterMerge(config) {\n config.toggle = Boolean(config.toggle); // Coerce string values\n config.parent = getElement(config.parent);\n return config;\n }\n _getDimension() {\n return this._element.classList.contains(CLASS_NAME_HORIZONTAL) ? WIDTH : HEIGHT;\n }\n _initializeChildren() {\n if (!this._config.parent) {\n return;\n }\n const children = this._getFirstLevelChildren(SELECTOR_DATA_TOGGLE$4);\n for (const element of children) {\n const selected = SelectorEngine.getElementFromSelector(element);\n if (selected) {\n this._addAriaAndCollapsedClass([element], this._isShown(selected));\n }\n }\n }\n _getFirstLevelChildren(selector) {\n const children = SelectorEngine.find(CLASS_NAME_DEEPER_CHILDREN, this._config.parent);\n // remove children if greater depth\n return SelectorEngine.find(selector, this._config.parent).filter(element => !children.includes(element));\n }\n _addAriaAndCollapsedClass(triggerArray, isOpen) {\n if (!triggerArray.length) {\n return;\n }\n for (const element of triggerArray) {\n element.classList.toggle(CLASS_NAME_COLLAPSED, !isOpen);\n element.setAttribute('aria-expanded', isOpen);\n }\n }\n\n // Static\n static jQueryInterface(config) {\n const _config = {};\n if (typeof config === 'string' && /show|hide/.test(config)) {\n _config.toggle = false;\n }\n return this.each(function () {\n const data = Collapse.getOrCreateInstance(this, _config);\n if (typeof config === 'string') {\n if (typeof data[config] === 'undefined') {\n throw new TypeError(`No method named \"${config}\"`);\n }\n data[config]();\n }\n });\n }\n}\n\n/**\n * Data API implementation\n */\n\nEventHandler.on(document, EVENT_CLICK_DATA_API$4, SELECTOR_DATA_TOGGLE$4, function (event) {\n // preventDefault only for elements (which change the URL) not inside the collapsible element\n if (event.target.tagName === 'A' || event.delegateTarget && event.delegateTarget.tagName === 'A') {\n event.preventDefault();\n }\n for (const element of SelectorEngine.getMultipleElementsFromSelector(this)) {\n Collapse.getOrCreateInstance(element, {\n toggle: false\n }).toggle();\n }\n});\n\n/**\n * jQuery\n */\n\ndefineJQueryPlugin(Collapse);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap dropdown.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst NAME$a = 'dropdown';\nconst DATA_KEY$6 = 'bs.dropdown';\nconst EVENT_KEY$6 = `.${DATA_KEY$6}`;\nconst DATA_API_KEY$3 = '.data-api';\nconst ESCAPE_KEY$2 = 'Escape';\nconst TAB_KEY$1 = 'Tab';\nconst ARROW_UP_KEY$1 = 'ArrowUp';\nconst ARROW_DOWN_KEY$1 = 'ArrowDown';\nconst RIGHT_MOUSE_BUTTON = 2; // MouseEvent.button value for the secondary button, usually the right button\n\nconst EVENT_HIDE$5 = `hide${EVENT_KEY$6}`;\nconst EVENT_HIDDEN$5 = `hidden${EVENT_KEY$6}`;\nconst EVENT_SHOW$5 = `show${EVENT_KEY$6}`;\nconst EVENT_SHOWN$5 = `shown${EVENT_KEY$6}`;\nconst EVENT_CLICK_DATA_API$3 = `click${EVENT_KEY$6}${DATA_API_KEY$3}`;\nconst EVENT_KEYDOWN_DATA_API = `keydown${EVENT_KEY$6}${DATA_API_KEY$3}`;\nconst EVENT_KEYUP_DATA_API = `keyup${EVENT_KEY$6}${DATA_API_KEY$3}`;\nconst CLASS_NAME_SHOW$6 = 'show';\nconst CLASS_NAME_DROPUP = 'dropup';\nconst CLASS_NAME_DROPEND = 'dropend';\nconst CLASS_NAME_DROPSTART = 'dropstart';\nconst CLASS_NAME_DROPUP_CENTER = 'dropup-center';\nconst CLASS_NAME_DROPDOWN_CENTER = 'dropdown-center';\nconst SELECTOR_DATA_TOGGLE$3 = '[data-bs-toggle=\"dropdown\"]:not(.disabled):not(:disabled)';\nconst SELECTOR_DATA_TOGGLE_SHOWN = `${SELECTOR_DATA_TOGGLE$3}.${CLASS_NAME_SHOW$6}`;\nconst SELECTOR_MENU = '.dropdown-menu';\nconst SELECTOR_NAVBAR = '.navbar';\nconst SELECTOR_NAVBAR_NAV = '.navbar-nav';\nconst SELECTOR_VISIBLE_ITEMS = '.dropdown-menu .dropdown-item:not(.disabled):not(:disabled)';\nconst PLACEMENT_TOP = isRTL() ? 'top-end' : 'top-start';\nconst PLACEMENT_TOPEND = isRTL() ? 'top-start' : 'top-end';\nconst PLACEMENT_BOTTOM = isRTL() ? 'bottom-end' : 'bottom-start';\nconst PLACEMENT_BOTTOMEND = isRTL() ? 'bottom-start' : 'bottom-end';\nconst PLACEMENT_RIGHT = isRTL() ? 'left-start' : 'right-start';\nconst PLACEMENT_LEFT = isRTL() ? 'right-start' : 'left-start';\nconst PLACEMENT_TOPCENTER = 'top';\nconst PLACEMENT_BOTTOMCENTER = 'bottom';\nconst Default$9 = {\n autoClose: true,\n boundary: 'clippingParents',\n display: 'dynamic',\n offset: [0, 2],\n popperConfig: null,\n reference: 'toggle'\n};\nconst DefaultType$9 = {\n autoClose: '(boolean|string)',\n boundary: '(string|element)',\n display: 'string',\n offset: '(array|string|function)',\n popperConfig: '(null|object|function)',\n reference: '(string|element|object)'\n};\n\n/**\n * Class definition\n */\n\nclass Dropdown extends BaseComponent {\n constructor(element, config) {\n super(element, config);\n this._popper = null;\n this._parent = this._element.parentNode; // dropdown wrapper\n // TODO: v6 revert #37011 & change markup https://getbootstrap.com/docs/5.3/forms/input-group/\n this._menu = SelectorEngine.next(this._element, SELECTOR_MENU)[0] || SelectorEngine.prev(this._element, SELECTOR_MENU)[0] || SelectorEngine.findOne(SELECTOR_MENU, this._parent);\n this._inNavbar = this._detectNavbar();\n }\n\n // Getters\n static get Default() {\n return Default$9;\n }\n static get DefaultType() {\n return DefaultType$9;\n }\n static get NAME() {\n return NAME$a;\n }\n\n // Public\n toggle() {\n return this._isShown() ? this.hide() : this.show();\n }\n show() {\n if (isDisabled(this._element) || this._isShown()) {\n return;\n }\n const relatedTarget = {\n relatedTarget: this._element\n };\n const showEvent = EventHandler.trigger(this._element, EVENT_SHOW$5, relatedTarget);\n if (showEvent.defaultPrevented) {\n return;\n }\n this._createPopper();\n\n // If this is a touch-enabled device we add extra\n // empty mouseover listeners to the body's immediate children;\n // only needed because of broken event delegation on iOS\n // https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html\n if ('ontouchstart' in document.documentElement && !this._parent.closest(SELECTOR_NAVBAR_NAV)) {\n for (const element of [].concat(...document.body.children)) {\n EventHandler.on(element, 'mouseover', noop);\n }\n }\n this._element.focus();\n this._element.setAttribute('aria-expanded', true);\n this._menu.classList.add(CLASS_NAME_SHOW$6);\n this._element.classList.add(CLASS_NAME_SHOW$6);\n EventHandler.trigger(this._element, EVENT_SHOWN$5, relatedTarget);\n }\n hide() {\n if (isDisabled(this._element) || !this._isShown()) {\n return;\n }\n const relatedTarget = {\n relatedTarget: this._element\n };\n this._completeHide(relatedTarget);\n }\n dispose() {\n if (this._popper) {\n this._popper.destroy();\n }\n super.dispose();\n }\n update() {\n this._inNavbar = this._detectNavbar();\n if (this._popper) {\n this._popper.update();\n }\n }\n\n // Private\n _completeHide(relatedTarget) {\n const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE$5, relatedTarget);\n if (hideEvent.defaultPrevented) {\n return;\n }\n\n // If this is a touch-enabled device we remove the extra\n // empty mouseover listeners we added for iOS support\n if ('ontouchstart' in document.documentElement) {\n for (const element of [].concat(...document.body.children)) {\n EventHandler.off(element, 'mouseover', noop);\n }\n }\n if (this._popper) {\n this._popper.destroy();\n }\n this._menu.classList.remove(CLASS_NAME_SHOW$6);\n this._element.classList.remove(CLASS_NAME_SHOW$6);\n this._element.setAttribute('aria-expanded', 'false');\n Manipulator.removeDataAttribute(this._menu, 'popper');\n EventHandler.trigger(this._element, EVENT_HIDDEN$5, relatedTarget);\n }\n _getConfig(config) {\n config = super._getConfig(config);\n if (typeof config.reference === 'object' && !isElement(config.reference) && typeof config.reference.getBoundingClientRect !== 'function') {\n // Popper virtual elements require a getBoundingClientRect method\n throw new TypeError(`${NAME$a.toUpperCase()}: Option \"reference\" provided type \"object\" without a required \"getBoundingClientRect\" method.`);\n }\n return config;\n }\n _createPopper() {\n if (typeof Popper === 'undefined') {\n throw new TypeError('Bootstrap\\'s dropdowns require Popper (https://popper.js.org)');\n }\n let referenceElement = this._element;\n if (this._config.reference === 'parent') {\n referenceElement = this._parent;\n } else if (isElement(this._config.reference)) {\n referenceElement = getElement(this._config.reference);\n } else if (typeof this._config.reference === 'object') {\n referenceElement = this._config.reference;\n }\n const popperConfig = this._getPopperConfig();\n this._popper = Popper.createPopper(referenceElement, this._menu, popperConfig);\n }\n _isShown() {\n return this._menu.classList.contains(CLASS_NAME_SHOW$6);\n }\n _getPlacement() {\n const parentDropdown = this._parent;\n if (parentDropdown.classList.contains(CLASS_NAME_DROPEND)) {\n return PLACEMENT_RIGHT;\n }\n if (parentDropdown.classList.contains(CLASS_NAME_DROPSTART)) {\n return PLACEMENT_LEFT;\n }\n if (parentDropdown.classList.contains(CLASS_NAME_DROPUP_CENTER)) {\n return PLACEMENT_TOPCENTER;\n }\n if (parentDropdown.classList.contains(CLASS_NAME_DROPDOWN_CENTER)) {\n return PLACEMENT_BOTTOMCENTER;\n }\n\n // We need to trim the value because custom properties can also include spaces\n const isEnd = getComputedStyle(this._menu).getPropertyValue('--bs-position').trim() === 'end';\n if (parentDropdown.classList.contains(CLASS_NAME_DROPUP)) {\n return isEnd ? PLACEMENT_TOPEND : PLACEMENT_TOP;\n }\n return isEnd ? PLACEMENT_BOTTOMEND : PLACEMENT_BOTTOM;\n }\n _detectNavbar() {\n return this._element.closest(SELECTOR_NAVBAR) !== null;\n }\n _getOffset() {\n const {\n offset\n } = this._config;\n if (typeof offset === 'string') {\n return offset.split(',').map(value => Number.parseInt(value, 10));\n }\n if (typeof offset === 'function') {\n return popperData => offset(popperData, this._element);\n }\n return offset;\n }\n _getPopperConfig() {\n const defaultBsPopperConfig = {\n placement: this._getPlacement(),\n modifiers: [{\n name: 'preventOverflow',\n options: {\n boundary: this._config.boundary\n }\n }, {\n name: 'offset',\n options: {\n offset: this._getOffset()\n }\n }]\n };\n\n // Disable Popper if we have a static display or Dropdown is in Navbar\n if (this._inNavbar || this._config.display === 'static') {\n Manipulator.setDataAttribute(this._menu, 'popper', 'static'); // TODO: v6 remove\n defaultBsPopperConfig.modifiers = [{\n name: 'applyStyles',\n enabled: false\n }];\n }\n return {\n ...defaultBsPopperConfig,\n ...execute(this._config.popperConfig, [defaultBsPopperConfig])\n };\n }\n _selectMenuItem({\n key,\n target\n }) {\n const items = SelectorEngine.find(SELECTOR_VISIBLE_ITEMS, this._menu).filter(element => isVisible(element));\n if (!items.length) {\n return;\n }\n\n // if target isn't included in items (e.g. when expanding the dropdown)\n // allow cycling to get the last item in case key equals ARROW_UP_KEY\n getNextActiveElement(items, target, key === ARROW_DOWN_KEY$1, !items.includes(target)).focus();\n }\n\n // Static\n static jQueryInterface(config) {\n return this.each(function () {\n const data = Dropdown.getOrCreateInstance(this, config);\n if (typeof config !== 'string') {\n return;\n }\n if (typeof data[config] === 'undefined') {\n throw new TypeError(`No method named \"${config}\"`);\n }\n data[config]();\n });\n }\n static clearMenus(event) {\n if (event.button === RIGHT_MOUSE_BUTTON || event.type === 'keyup' && event.key !== TAB_KEY$1) {\n return;\n }\n const openToggles = SelectorEngine.find(SELECTOR_DATA_TOGGLE_SHOWN);\n for (const toggle of openToggles) {\n const context = Dropdown.getInstance(toggle);\n if (!context || context._config.autoClose === false) {\n continue;\n }\n const composedPath = event.composedPath();\n const isMenuTarget = composedPath.includes(context._menu);\n if (composedPath.includes(context._element) || context._config.autoClose === 'inside' && !isMenuTarget || context._config.autoClose === 'outside' && isMenuTarget) {\n continue;\n }\n\n // Tab navigation through the dropdown menu or events from contained inputs shouldn't close the menu\n if (context._menu.contains(event.target) && (event.type === 'keyup' && event.key === TAB_KEY$1 || /input|select|option|textarea|form/i.test(event.target.tagName))) {\n continue;\n }\n const relatedTarget = {\n relatedTarget: context._element\n };\n if (event.type === 'click') {\n relatedTarget.clickEvent = event;\n }\n context._completeHide(relatedTarget);\n }\n }\n static dataApiKeydownHandler(event) {\n // If not an UP | DOWN | ESCAPE key => not a dropdown command\n // If input/textarea && if key is other than ESCAPE => not a dropdown command\n\n const isInput = /input|textarea/i.test(event.target.tagName);\n const isEscapeEvent = event.key === ESCAPE_KEY$2;\n const isUpOrDownEvent = [ARROW_UP_KEY$1, ARROW_DOWN_KEY$1].includes(event.key);\n if (!isUpOrDownEvent && !isEscapeEvent) {\n return;\n }\n if (isInput && !isEscapeEvent) {\n return;\n }\n event.preventDefault();\n\n // TODO: v6 revert #37011 & change markup https://getbootstrap.com/docs/5.3/forms/input-group/\n const getToggleButton = this.matches(SELECTOR_DATA_TOGGLE$3) ? this : SelectorEngine.prev(this, SELECTOR_DATA_TOGGLE$3)[0] || SelectorEngine.next(this, SELECTOR_DATA_TOGGLE$3)[0] || SelectorEngine.findOne(SELECTOR_DATA_TOGGLE$3, event.delegateTarget.parentNode);\n const instance = Dropdown.getOrCreateInstance(getToggleButton);\n if (isUpOrDownEvent) {\n event.stopPropagation();\n instance.show();\n instance._selectMenuItem(event);\n return;\n }\n if (instance._isShown()) {\n // else is escape and we check if it is shown\n event.stopPropagation();\n instance.hide();\n getToggleButton.focus();\n }\n }\n}\n\n/**\n * Data API implementation\n */\n\nEventHandler.on(document, EVENT_KEYDOWN_DATA_API, SELECTOR_DATA_TOGGLE$3, Dropdown.dataApiKeydownHandler);\nEventHandler.on(document, EVENT_KEYDOWN_DATA_API, SELECTOR_MENU, Dropdown.dataApiKeydownHandler);\nEventHandler.on(document, EVENT_CLICK_DATA_API$3, Dropdown.clearMenus);\nEventHandler.on(document, EVENT_KEYUP_DATA_API, Dropdown.clearMenus);\nEventHandler.on(document, EVENT_CLICK_DATA_API$3, SELECTOR_DATA_TOGGLE$3, function (event) {\n event.preventDefault();\n Dropdown.getOrCreateInstance(this).toggle();\n});\n\n/**\n * jQuery\n */\n\ndefineJQueryPlugin(Dropdown);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap util/backdrop.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst NAME$9 = 'backdrop';\nconst CLASS_NAME_FADE$4 = 'fade';\nconst CLASS_NAME_SHOW$5 = 'show';\nconst EVENT_MOUSEDOWN = `mousedown.bs.${NAME$9}`;\nconst Default$8 = {\n className: 'modal-backdrop',\n clickCallback: null,\n isAnimated: false,\n isVisible: true,\n // if false, we use the backdrop helper without adding any element to the dom\n rootElement: 'body' // give the choice to place backdrop under different elements\n};\nconst DefaultType$8 = {\n className: 'string',\n clickCallback: '(function|null)',\n isAnimated: 'boolean',\n isVisible: 'boolean',\n rootElement: '(element|string)'\n};\n\n/**\n * Class definition\n */\n\nclass Backdrop extends Config {\n constructor(config) {\n super();\n this._config = this._getConfig(config);\n this._isAppended = false;\n this._element = null;\n }\n\n // Getters\n static get Default() {\n return Default$8;\n }\n static get DefaultType() {\n return DefaultType$8;\n }\n static get NAME() {\n return NAME$9;\n }\n\n // Public\n show(callback) {\n if (!this._config.isVisible) {\n execute(callback);\n return;\n }\n this._append();\n const element = this._getElement();\n if (this._config.isAnimated) {\n reflow(element);\n }\n element.classList.add(CLASS_NAME_SHOW$5);\n this._emulateAnimation(() => {\n execute(callback);\n });\n }\n hide(callback) {\n if (!this._config.isVisible) {\n execute(callback);\n return;\n }\n this._getElement().classList.remove(CLASS_NAME_SHOW$5);\n this._emulateAnimation(() => {\n this.dispose();\n execute(callback);\n });\n }\n dispose() {\n if (!this._isAppended) {\n return;\n }\n EventHandler.off(this._element, EVENT_MOUSEDOWN);\n this._element.remove();\n this._isAppended = false;\n }\n\n // Private\n _getElement() {\n if (!this._element) {\n const backdrop = document.createElement('div');\n backdrop.className = this._config.className;\n if (this._config.isAnimated) {\n backdrop.classList.add(CLASS_NAME_FADE$4);\n }\n this._element = backdrop;\n }\n return this._element;\n }\n _configAfterMerge(config) {\n // use getElement() with the default \"body\" to get a fresh Element on each instantiation\n config.rootElement = getElement(config.rootElement);\n return config;\n }\n _append() {\n if (this._isAppended) {\n return;\n }\n const element = this._getElement();\n this._config.rootElement.append(element);\n EventHandler.on(element, EVENT_MOUSEDOWN, () => {\n execute(this._config.clickCallback);\n });\n this._isAppended = true;\n }\n _emulateAnimation(callback) {\n executeAfterTransition(callback, this._getElement(), this._config.isAnimated);\n }\n}\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap util/focustrap.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst NAME$8 = 'focustrap';\nconst DATA_KEY$5 = 'bs.focustrap';\nconst EVENT_KEY$5 = `.${DATA_KEY$5}`;\nconst EVENT_FOCUSIN$2 = `focusin${EVENT_KEY$5}`;\nconst EVENT_KEYDOWN_TAB = `keydown.tab${EVENT_KEY$5}`;\nconst TAB_KEY = 'Tab';\nconst TAB_NAV_FORWARD = 'forward';\nconst TAB_NAV_BACKWARD = 'backward';\nconst Default$7 = {\n autofocus: true,\n trapElement: null // The element to trap focus inside of\n};\nconst DefaultType$7 = {\n autofocus: 'boolean',\n trapElement: 'element'\n};\n\n/**\n * Class definition\n */\n\nclass FocusTrap extends Config {\n constructor(config) {\n super();\n this._config = this._getConfig(config);\n this._isActive = false;\n this._lastTabNavDirection = null;\n }\n\n // Getters\n static get Default() {\n return Default$7;\n }\n static get DefaultType() {\n return DefaultType$7;\n }\n static get NAME() {\n return NAME$8;\n }\n\n // Public\n activate() {\n if (this._isActive) {\n return;\n }\n if (this._config.autofocus) {\n this._config.trapElement.focus();\n }\n EventHandler.off(document, EVENT_KEY$5); // guard against infinite focus loop\n EventHandler.on(document, EVENT_FOCUSIN$2, event => this._handleFocusin(event));\n EventHandler.on(document, EVENT_KEYDOWN_TAB, event => this._handleKeydown(event));\n this._isActive = true;\n }\n deactivate() {\n if (!this._isActive) {\n return;\n }\n this._isActive = false;\n EventHandler.off(document, EVENT_KEY$5);\n }\n\n // Private\n _handleFocusin(event) {\n const {\n trapElement\n } = this._config;\n if (event.target === document || event.target === trapElement || trapElement.contains(event.target)) {\n return;\n }\n const elements = SelectorEngine.focusableChildren(trapElement);\n if (elements.length === 0) {\n trapElement.focus();\n } else if (this._lastTabNavDirection === TAB_NAV_BACKWARD) {\n elements[elements.length - 1].focus();\n } else {\n elements[0].focus();\n }\n }\n _handleKeydown(event) {\n if (event.key !== TAB_KEY) {\n return;\n }\n this._lastTabNavDirection = event.shiftKey ? TAB_NAV_BACKWARD : TAB_NAV_FORWARD;\n }\n}\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap util/scrollBar.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst SELECTOR_FIXED_CONTENT = '.fixed-top, .fixed-bottom, .is-fixed, .sticky-top';\nconst SELECTOR_STICKY_CONTENT = '.sticky-top';\nconst PROPERTY_PADDING = 'padding-right';\nconst PROPERTY_MARGIN = 'margin-right';\n\n/**\n * Class definition\n */\n\nclass ScrollBarHelper {\n constructor() {\n this._element = document.body;\n }\n\n // Public\n getWidth() {\n // https://developer.mozilla.org/en-US/docs/Web/API/Window/innerWidth#usage_notes\n const documentWidth = document.documentElement.clientWidth;\n return Math.abs(window.innerWidth - documentWidth);\n }\n hide() {\n const width = this.getWidth();\n this._disableOverFlow();\n // give padding to element to balance the hidden scrollbar width\n this._setElementAttributes(this._element, PROPERTY_PADDING, calculatedValue => calculatedValue + width);\n // trick: We adjust positive paddingRight and negative marginRight to sticky-top elements to keep showing fullwidth\n this._setElementAttributes(SELECTOR_FIXED_CONTENT, PROPERTY_PADDING, calculatedValue => calculatedValue + width);\n this._setElementAttributes(SELECTOR_STICKY_CONTENT, PROPERTY_MARGIN, calculatedValue => calculatedValue - width);\n }\n reset() {\n this._resetElementAttributes(this._element, 'overflow');\n this._resetElementAttributes(this._element, PROPERTY_PADDING);\n this._resetElementAttributes(SELECTOR_FIXED_CONTENT, PROPERTY_PADDING);\n this._resetElementAttributes(SELECTOR_STICKY_CONTENT, PROPERTY_MARGIN);\n }\n isOverflowing() {\n return this.getWidth() > 0;\n }\n\n // Private\n _disableOverFlow() {\n this._saveInitialAttribute(this._element, 'overflow');\n this._element.style.overflow = 'hidden';\n }\n _setElementAttributes(selector, styleProperty, callback) {\n const scrollbarWidth = this.getWidth();\n const manipulationCallBack = element => {\n if (element !== this._element && window.innerWidth > element.clientWidth + scrollbarWidth) {\n return;\n }\n this._saveInitialAttribute(element, styleProperty);\n const calculatedValue = window.getComputedStyle(element).getPropertyValue(styleProperty);\n element.style.setProperty(styleProperty, `${callback(Number.parseFloat(calculatedValue))}px`);\n };\n this._applyManipulationCallback(selector, manipulationCallBack);\n }\n _saveInitialAttribute(element, styleProperty) {\n const actualValue = element.style.getPropertyValue(styleProperty);\n if (actualValue) {\n Manipulator.setDataAttribute(element, styleProperty, actualValue);\n }\n }\n _resetElementAttributes(selector, styleProperty) {\n const manipulationCallBack = element => {\n const value = Manipulator.getDataAttribute(element, styleProperty);\n // We only want to remove the property if the value is `null`; the value can also be zero\n if (value === null) {\n element.style.removeProperty(styleProperty);\n return;\n }\n Manipulator.removeDataAttribute(element, styleProperty);\n element.style.setProperty(styleProperty, value);\n };\n this._applyManipulationCallback(selector, manipulationCallBack);\n }\n _applyManipulationCallback(selector, callBack) {\n if (isElement(selector)) {\n callBack(selector);\n return;\n }\n for (const sel of SelectorEngine.find(selector, this._element)) {\n callBack(sel);\n }\n }\n}\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap modal.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst NAME$7 = 'modal';\nconst DATA_KEY$4 = 'bs.modal';\nconst EVENT_KEY$4 = `.${DATA_KEY$4}`;\nconst DATA_API_KEY$2 = '.data-api';\nconst ESCAPE_KEY$1 = 'Escape';\nconst EVENT_HIDE$4 = `hide${EVENT_KEY$4}`;\nconst EVENT_HIDE_PREVENTED$1 = `hidePrevented${EVENT_KEY$4}`;\nconst EVENT_HIDDEN$4 = `hidden${EVENT_KEY$4}`;\nconst EVENT_SHOW$4 = `show${EVENT_KEY$4}`;\nconst EVENT_SHOWN$4 = `shown${EVENT_KEY$4}`;\nconst EVENT_RESIZE$1 = `resize${EVENT_KEY$4}`;\nconst EVENT_CLICK_DISMISS = `click.dismiss${EVENT_KEY$4}`;\nconst EVENT_MOUSEDOWN_DISMISS = `mousedown.dismiss${EVENT_KEY$4}`;\nconst EVENT_KEYDOWN_DISMISS$1 = `keydown.dismiss${EVENT_KEY$4}`;\nconst EVENT_CLICK_DATA_API$2 = `click${EVENT_KEY$4}${DATA_API_KEY$2}`;\nconst CLASS_NAME_OPEN = 'modal-open';\nconst CLASS_NAME_FADE$3 = 'fade';\nconst CLASS_NAME_SHOW$4 = 'show';\nconst CLASS_NAME_STATIC = 'modal-static';\nconst OPEN_SELECTOR$1 = '.modal.show';\nconst SELECTOR_DIALOG = '.modal-dialog';\nconst SELECTOR_MODAL_BODY = '.modal-body';\nconst SELECTOR_DATA_TOGGLE$2 = '[data-bs-toggle=\"modal\"]';\nconst Default$6 = {\n backdrop: true,\n focus: true,\n keyboard: true\n};\nconst DefaultType$6 = {\n backdrop: '(boolean|string)',\n focus: 'boolean',\n keyboard: 'boolean'\n};\n\n/**\n * Class definition\n */\n\nclass Modal extends BaseComponent {\n constructor(element, config) {\n super(element, config);\n this._dialog = SelectorEngine.findOne(SELECTOR_DIALOG, this._element);\n this._backdrop = this._initializeBackDrop();\n this._focustrap = this._initializeFocusTrap();\n this._isShown = false;\n this._isTransitioning = false;\n this._scrollBar = new ScrollBarHelper();\n this._addEventListeners();\n }\n\n // Getters\n static get Default() {\n return Default$6;\n }\n static get DefaultType() {\n return DefaultType$6;\n }\n static get NAME() {\n return NAME$7;\n }\n\n // Public\n toggle(relatedTarget) {\n return this._isShown ? this.hide() : this.show(relatedTarget);\n }\n show(relatedTarget) {\n if (this._isShown || this._isTransitioning) {\n return;\n }\n const showEvent = EventHandler.trigger(this._element, EVENT_SHOW$4, {\n relatedTarget\n });\n if (showEvent.defaultPrevented) {\n return;\n }\n this._isShown = true;\n this._isTransitioning = true;\n this._scrollBar.hide();\n document.body.classList.add(CLASS_NAME_OPEN);\n this._adjustDialog();\n this._backdrop.show(() => this._showElement(relatedTarget));\n }\n hide() {\n if (!this._isShown || this._isTransitioning) {\n return;\n }\n const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE$4);\n if (hideEvent.defaultPrevented) {\n return;\n }\n this._isShown = false;\n this._isTransitioning = true;\n this._focustrap.deactivate();\n this._element.classList.remove(CLASS_NAME_SHOW$4);\n this._queueCallback(() => this._hideModal(), this._element, this._isAnimated());\n }\n dispose() {\n EventHandler.off(window, EVENT_KEY$4);\n EventHandler.off(this._dialog, EVENT_KEY$4);\n this._backdrop.dispose();\n this._focustrap.deactivate();\n super.dispose();\n }\n handleUpdate() {\n this._adjustDialog();\n }\n\n // Private\n _initializeBackDrop() {\n return new Backdrop({\n isVisible: Boolean(this._config.backdrop),\n // 'static' option will be translated to true, and booleans will keep their value,\n isAnimated: this._isAnimated()\n });\n }\n _initializeFocusTrap() {\n return new FocusTrap({\n trapElement: this._element\n });\n }\n _showElement(relatedTarget) {\n // try to append dynamic modal\n if (!document.body.contains(this._element)) {\n document.body.append(this._element);\n }\n this._element.style.display = 'block';\n this._element.removeAttribute('aria-hidden');\n this._element.setAttribute('aria-modal', true);\n this._element.setAttribute('role', 'dialog');\n this._element.scrollTop = 0;\n const modalBody = SelectorEngine.findOne(SELECTOR_MODAL_BODY, this._dialog);\n if (modalBody) {\n modalBody.scrollTop = 0;\n }\n reflow(this._element);\n this._element.classList.add(CLASS_NAME_SHOW$4);\n const transitionComplete = () => {\n if (this._config.focus) {\n this._focustrap.activate();\n }\n this._isTransitioning = false;\n EventHandler.trigger(this._element, EVENT_SHOWN$4, {\n relatedTarget\n });\n };\n this._queueCallback(transitionComplete, this._dialog, this._isAnimated());\n }\n _addEventListeners() {\n EventHandler.on(this._element, EVENT_KEYDOWN_DISMISS$1, event => {\n if (event.key !== ESCAPE_KEY$1) {\n return;\n }\n if (this._config.keyboard) {\n this.hide();\n return;\n }\n this._triggerBackdropTransition();\n });\n EventHandler.on(window, EVENT_RESIZE$1, () => {\n if (this._isShown && !this._isTransitioning) {\n this._adjustDialog();\n }\n });\n EventHandler.on(this._element, EVENT_MOUSEDOWN_DISMISS, event => {\n // a bad trick to segregate clicks that may start inside dialog but end outside, and avoid listen to scrollbar clicks\n EventHandler.one(this._element, EVENT_CLICK_DISMISS, event2 => {\n if (this._element !== event.target || this._element !== event2.target) {\n return;\n }\n if (this._config.backdrop === 'static') {\n this._triggerBackdropTransition();\n return;\n }\n if (this._config.backdrop) {\n this.hide();\n }\n });\n });\n }\n _hideModal() {\n this._element.style.display = 'none';\n this._element.setAttribute('aria-hidden', true);\n this._element.removeAttribute('aria-modal');\n this._element.removeAttribute('role');\n this._isTransitioning = false;\n this._backdrop.hide(() => {\n document.body.classList.remove(CLASS_NAME_OPEN);\n this._resetAdjustments();\n this._scrollBar.reset();\n EventHandler.trigger(this._element, EVENT_HIDDEN$4);\n });\n }\n _isAnimated() {\n return this._element.classList.contains(CLASS_NAME_FADE$3);\n }\n _triggerBackdropTransition() {\n const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE_PREVENTED$1);\n if (hideEvent.defaultPrevented) {\n return;\n }\n const isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight;\n const initialOverflowY = this._element.style.overflowY;\n // return if the following background transition hasn't yet completed\n if (initialOverflowY === 'hidden' || this._element.classList.contains(CLASS_NAME_STATIC)) {\n return;\n }\n if (!isModalOverflowing) {\n this._element.style.overflowY = 'hidden';\n }\n this._element.classList.add(CLASS_NAME_STATIC);\n this._queueCallback(() => {\n this._element.classList.remove(CLASS_NAME_STATIC);\n this._queueCallback(() => {\n this._element.style.overflowY = initialOverflowY;\n }, this._dialog);\n }, this._dialog);\n this._element.focus();\n }\n\n /**\n * The following methods are used to handle overflowing modals\n */\n\n _adjustDialog() {\n const isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight;\n const scrollbarWidth = this._scrollBar.getWidth();\n const isBodyOverflowing = scrollbarWidth > 0;\n if (isBodyOverflowing && !isModalOverflowing) {\n const property = isRTL() ? 'paddingLeft' : 'paddingRight';\n this._element.style[property] = `${scrollbarWidth}px`;\n }\n if (!isBodyOverflowing && isModalOverflowing) {\n const property = isRTL() ? 'paddingRight' : 'paddingLeft';\n this._element.style[property] = `${scrollbarWidth}px`;\n }\n }\n _resetAdjustments() {\n this._element.style.paddingLeft = '';\n this._element.style.paddingRight = '';\n }\n\n // Static\n static jQueryInterface(config, relatedTarget) {\n return this.each(function () {\n const data = Modal.getOrCreateInstance(this, config);\n if (typeof config !== 'string') {\n return;\n }\n if (typeof data[config] === 'undefined') {\n throw new TypeError(`No method named \"${config}\"`);\n }\n data[config](relatedTarget);\n });\n }\n}\n\n/**\n * Data API implementation\n */\n\nEventHandler.on(document, EVENT_CLICK_DATA_API$2, SELECTOR_DATA_TOGGLE$2, function (event) {\n const target = SelectorEngine.getElementFromSelector(this);\n if (['A', 'AREA'].includes(this.tagName)) {\n event.preventDefault();\n }\n EventHandler.one(target, EVENT_SHOW$4, showEvent => {\n if (showEvent.defaultPrevented) {\n // only register focus restorer if modal will actually get shown\n return;\n }\n EventHandler.one(target, EVENT_HIDDEN$4, () => {\n if (isVisible(this)) {\n this.focus();\n }\n });\n });\n\n // avoid conflict when clicking modal toggler while another one is open\n const alreadyOpen = SelectorEngine.findOne(OPEN_SELECTOR$1);\n if (alreadyOpen) {\n Modal.getInstance(alreadyOpen).hide();\n }\n const data = Modal.getOrCreateInstance(target);\n data.toggle(this);\n});\nenableDismissTrigger(Modal);\n\n/**\n * jQuery\n */\n\ndefineJQueryPlugin(Modal);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap offcanvas.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst NAME$6 = 'offcanvas';\nconst DATA_KEY$3 = 'bs.offcanvas';\nconst EVENT_KEY$3 = `.${DATA_KEY$3}`;\nconst DATA_API_KEY$1 = '.data-api';\nconst EVENT_LOAD_DATA_API$2 = `load${EVENT_KEY$3}${DATA_API_KEY$1}`;\nconst ESCAPE_KEY = 'Escape';\nconst CLASS_NAME_SHOW$3 = 'show';\nconst CLASS_NAME_SHOWING$1 = 'showing';\nconst CLASS_NAME_HIDING = 'hiding';\nconst CLASS_NAME_BACKDROP = 'offcanvas-backdrop';\nconst OPEN_SELECTOR = '.offcanvas.show';\nconst EVENT_SHOW$3 = `show${EVENT_KEY$3}`;\nconst EVENT_SHOWN$3 = `shown${EVENT_KEY$3}`;\nconst EVENT_HIDE$3 = `hide${EVENT_KEY$3}`;\nconst EVENT_HIDE_PREVENTED = `hidePrevented${EVENT_KEY$3}`;\nconst EVENT_HIDDEN$3 = `hidden${EVENT_KEY$3}`;\nconst EVENT_RESIZE = `resize${EVENT_KEY$3}`;\nconst EVENT_CLICK_DATA_API$1 = `click${EVENT_KEY$3}${DATA_API_KEY$1}`;\nconst EVENT_KEYDOWN_DISMISS = `keydown.dismiss${EVENT_KEY$3}`;\nconst SELECTOR_DATA_TOGGLE$1 = '[data-bs-toggle=\"offcanvas\"]';\nconst Default$5 = {\n backdrop: true,\n keyboard: true,\n scroll: false\n};\nconst DefaultType$5 = {\n backdrop: '(boolean|string)',\n keyboard: 'boolean',\n scroll: 'boolean'\n};\n\n/**\n * Class definition\n */\n\nclass Offcanvas extends BaseComponent {\n constructor(element, config) {\n super(element, config);\n this._isShown = false;\n this._backdrop = this._initializeBackDrop();\n this._focustrap = this._initializeFocusTrap();\n this._addEventListeners();\n }\n\n // Getters\n static get Default() {\n return Default$5;\n }\n static get DefaultType() {\n return DefaultType$5;\n }\n static get NAME() {\n return NAME$6;\n }\n\n // Public\n toggle(relatedTarget) {\n return this._isShown ? this.hide() : this.show(relatedTarget);\n }\n show(relatedTarget) {\n if (this._isShown) {\n return;\n }\n const showEvent = EventHandler.trigger(this._element, EVENT_SHOW$3, {\n relatedTarget\n });\n if (showEvent.defaultPrevented) {\n return;\n }\n this._isShown = true;\n this._backdrop.show();\n if (!this._config.scroll) {\n new ScrollBarHelper().hide();\n }\n this._element.setAttribute('aria-modal', true);\n this._element.setAttribute('role', 'dialog');\n this._element.classList.add(CLASS_NAME_SHOWING$1);\n const completeCallBack = () => {\n if (!this._config.scroll || this._config.backdrop) {\n this._focustrap.activate();\n }\n this._element.classList.add(CLASS_NAME_SHOW$3);\n this._element.classList.remove(CLASS_NAME_SHOWING$1);\n EventHandler.trigger(this._element, EVENT_SHOWN$3, {\n relatedTarget\n });\n };\n this._queueCallback(completeCallBack, this._element, true);\n }\n hide() {\n if (!this._isShown) {\n return;\n }\n const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE$3);\n if (hideEvent.defaultPrevented) {\n return;\n }\n this._focustrap.deactivate();\n this._element.blur();\n this._isShown = false;\n this._element.classList.add(CLASS_NAME_HIDING);\n this._backdrop.hide();\n const completeCallback = () => {\n this._element.classList.remove(CLASS_NAME_SHOW$3, CLASS_NAME_HIDING);\n this._element.removeAttribute('aria-modal');\n this._element.removeAttribute('role');\n if (!this._config.scroll) {\n new ScrollBarHelper().reset();\n }\n EventHandler.trigger(this._element, EVENT_HIDDEN$3);\n };\n this._queueCallback(completeCallback, this._element, true);\n }\n dispose() {\n this._backdrop.dispose();\n this._focustrap.deactivate();\n super.dispose();\n }\n\n // Private\n _initializeBackDrop() {\n const clickCallback = () => {\n if (this._config.backdrop === 'static') {\n EventHandler.trigger(this._element, EVENT_HIDE_PREVENTED);\n return;\n }\n this.hide();\n };\n\n // 'static' option will be translated to true, and booleans will keep their value\n const isVisible = Boolean(this._config.backdrop);\n return new Backdrop({\n className: CLASS_NAME_BACKDROP,\n isVisible,\n isAnimated: true,\n rootElement: this._element.parentNode,\n clickCallback: isVisible ? clickCallback : null\n });\n }\n _initializeFocusTrap() {\n return new FocusTrap({\n trapElement: this._element\n });\n }\n _addEventListeners() {\n EventHandler.on(this._element, EVENT_KEYDOWN_DISMISS, event => {\n if (event.key !== ESCAPE_KEY) {\n return;\n }\n if (this._config.keyboard) {\n this.hide();\n return;\n }\n EventHandler.trigger(this._element, EVENT_HIDE_PREVENTED);\n });\n }\n\n // Static\n static jQueryInterface(config) {\n return this.each(function () {\n const data = Offcanvas.getOrCreateInstance(this, config);\n if (typeof config !== 'string') {\n return;\n }\n if (data[config] === undefined || config.startsWith('_') || config === 'constructor') {\n throw new TypeError(`No method named \"${config}\"`);\n }\n data[config](this);\n });\n }\n}\n\n/**\n * Data API implementation\n */\n\nEventHandler.on(document, EVENT_CLICK_DATA_API$1, SELECTOR_DATA_TOGGLE$1, function (event) {\n const target = SelectorEngine.getElementFromSelector(this);\n if (['A', 'AREA'].includes(this.tagName)) {\n event.preventDefault();\n }\n if (isDisabled(this)) {\n return;\n }\n EventHandler.one(target, EVENT_HIDDEN$3, () => {\n // focus on trigger when it is closed\n if (isVisible(this)) {\n this.focus();\n }\n });\n\n // avoid conflict when clicking a toggler of an offcanvas, while another is open\n const alreadyOpen = SelectorEngine.findOne(OPEN_SELECTOR);\n if (alreadyOpen && alreadyOpen !== target) {\n Offcanvas.getInstance(alreadyOpen).hide();\n }\n const data = Offcanvas.getOrCreateInstance(target);\n data.toggle(this);\n});\nEventHandler.on(window, EVENT_LOAD_DATA_API$2, () => {\n for (const selector of SelectorEngine.find(OPEN_SELECTOR)) {\n Offcanvas.getOrCreateInstance(selector).show();\n }\n});\nEventHandler.on(window, EVENT_RESIZE, () => {\n for (const element of SelectorEngine.find('[aria-modal][class*=show][class*=offcanvas-]')) {\n if (getComputedStyle(element).position !== 'fixed') {\n Offcanvas.getOrCreateInstance(element).hide();\n }\n }\n});\nenableDismissTrigger(Offcanvas);\n\n/**\n * jQuery\n */\n\ndefineJQueryPlugin(Offcanvas);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap util/sanitizer.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n// js-docs-start allow-list\nconst ARIA_ATTRIBUTE_PATTERN = /^aria-[\\w-]*$/i;\nconst DefaultAllowlist = {\n // Global attributes allowed on any supplied element below.\n '*': ['class', 'dir', 'id', 'lang', 'role', ARIA_ATTRIBUTE_PATTERN],\n a: ['target', 'href', 'title', 'rel'],\n area: [],\n b: [],\n br: [],\n col: [],\n code: [],\n dd: [],\n div: [],\n dl: [],\n dt: [],\n em: [],\n hr: [],\n h1: [],\n h2: [],\n h3: [],\n h4: [],\n h5: [],\n h6: [],\n i: [],\n img: ['src', 'srcset', 'alt', 'title', 'width', 'height'],\n li: [],\n ol: [],\n p: [],\n pre: [],\n s: [],\n small: [],\n span: [],\n sub: [],\n sup: [],\n strong: [],\n u: [],\n ul: []\n};\n// js-docs-end allow-list\n\nconst uriAttributes = new Set(['background', 'cite', 'href', 'itemtype', 'longdesc', 'poster', 'src', 'xlink:href']);\n\n/**\n * A pattern that recognizes URLs that are safe wrt. XSS in URL navigation\n * contexts.\n *\n * Shout-out to Angular https://github.com/angular/angular/blob/15.2.8/packages/core/src/sanitization/url_sanitizer.ts#L38\n */\n// eslint-disable-next-line unicorn/better-regex\nconst SAFE_URL_PATTERN = /^(?!javascript:)(?:[a-z0-9+.-]+:|[^&:/?#]*(?:[/?#]|$))/i;\nconst allowedAttribute = (attribute, allowedAttributeList) => {\n const attributeName = attribute.nodeName.toLowerCase();\n if (allowedAttributeList.includes(attributeName)) {\n if (uriAttributes.has(attributeName)) {\n return Boolean(SAFE_URL_PATTERN.test(attribute.nodeValue));\n }\n return true;\n }\n\n // Check if a regular expression validates the attribute.\n return allowedAttributeList.filter(attributeRegex => attributeRegex instanceof RegExp).some(regex => regex.test(attributeName));\n};\nfunction sanitizeHtml(unsafeHtml, allowList, sanitizeFunction) {\n if (!unsafeHtml.length) {\n return unsafeHtml;\n }\n if (sanitizeFunction && typeof sanitizeFunction === 'function') {\n return sanitizeFunction(unsafeHtml);\n }\n const domParser = new window.DOMParser();\n const createdDocument = domParser.parseFromString(unsafeHtml, 'text/html');\n const elements = [].concat(...createdDocument.body.querySelectorAll('*'));\n for (const element of elements) {\n const elementName = element.nodeName.toLowerCase();\n if (!Object.keys(allowList).includes(elementName)) {\n element.remove();\n continue;\n }\n const attributeList = [].concat(...element.attributes);\n const allowedAttributes = [].concat(allowList['*'] || [], allowList[elementName] || []);\n for (const attribute of attributeList) {\n if (!allowedAttribute(attribute, allowedAttributes)) {\n element.removeAttribute(attribute.nodeName);\n }\n }\n }\n return createdDocument.body.innerHTML;\n}\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap util/template-factory.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst NAME$5 = 'TemplateFactory';\nconst Default$4 = {\n allowList: DefaultAllowlist,\n content: {},\n // { selector : text , selector2 : text2 , }\n extraClass: '',\n html: false,\n sanitize: true,\n sanitizeFn: null,\n template: '
'\n};\nconst DefaultType$4 = {\n allowList: 'object',\n content: 'object',\n extraClass: '(string|function)',\n html: 'boolean',\n sanitize: 'boolean',\n sanitizeFn: '(null|function)',\n template: 'string'\n};\nconst DefaultContentType = {\n entry: '(string|element|function|null)',\n selector: '(string|element)'\n};\n\n/**\n * Class definition\n */\n\nclass TemplateFactory extends Config {\n constructor(config) {\n super();\n this._config = this._getConfig(config);\n }\n\n // Getters\n static get Default() {\n return Default$4;\n }\n static get DefaultType() {\n return DefaultType$4;\n }\n static get NAME() {\n return NAME$5;\n }\n\n // Public\n getContent() {\n return Object.values(this._config.content).map(config => this._resolvePossibleFunction(config)).filter(Boolean);\n }\n hasContent() {\n return this.getContent().length > 0;\n }\n changeContent(content) {\n this._checkContent(content);\n this._config.content = {\n ...this._config.content,\n ...content\n };\n return this;\n }\n toHtml() {\n const templateWrapper = document.createElement('div');\n templateWrapper.innerHTML = this._maybeSanitize(this._config.template);\n for (const [selector, text] of Object.entries(this._config.content)) {\n this._setContent(templateWrapper, text, selector);\n }\n const template = templateWrapper.children[0];\n const extraClass = this._resolvePossibleFunction(this._config.extraClass);\n if (extraClass) {\n template.classList.add(...extraClass.split(' '));\n }\n return template;\n }\n\n // Private\n _typeCheckConfig(config) {\n super._typeCheckConfig(config);\n this._checkContent(config.content);\n }\n _checkContent(arg) {\n for (const [selector, content] of Object.entries(arg)) {\n super._typeCheckConfig({\n selector,\n entry: content\n }, DefaultContentType);\n }\n }\n _setContent(template, content, selector) {\n const templateElement = SelectorEngine.findOne(selector, template);\n if (!templateElement) {\n return;\n }\n content = this._resolvePossibleFunction(content);\n if (!content) {\n templateElement.remove();\n return;\n }\n if (isElement(content)) {\n this._putElementInTemplate(getElement(content), templateElement);\n return;\n }\n if (this._config.html) {\n templateElement.innerHTML = this._maybeSanitize(content);\n return;\n }\n templateElement.textContent = content;\n }\n _maybeSanitize(arg) {\n return this._config.sanitize ? sanitizeHtml(arg, this._config.allowList, this._config.sanitizeFn) : arg;\n }\n _resolvePossibleFunction(arg) {\n return execute(arg, [this]);\n }\n _putElementInTemplate(element, templateElement) {\n if (this._config.html) {\n templateElement.innerHTML = '';\n templateElement.append(element);\n return;\n }\n templateElement.textContent = element.textContent;\n }\n}\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap tooltip.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst NAME$4 = 'tooltip';\nconst DISALLOWED_ATTRIBUTES = new Set(['sanitize', 'allowList', 'sanitizeFn']);\nconst CLASS_NAME_FADE$2 = 'fade';\nconst CLASS_NAME_MODAL = 'modal';\nconst CLASS_NAME_SHOW$2 = 'show';\nconst SELECTOR_TOOLTIP_INNER = '.tooltip-inner';\nconst SELECTOR_MODAL = `.${CLASS_NAME_MODAL}`;\nconst EVENT_MODAL_HIDE = 'hide.bs.modal';\nconst TRIGGER_HOVER = 'hover';\nconst TRIGGER_FOCUS = 'focus';\nconst TRIGGER_CLICK = 'click';\nconst TRIGGER_MANUAL = 'manual';\nconst EVENT_HIDE$2 = 'hide';\nconst EVENT_HIDDEN$2 = 'hidden';\nconst EVENT_SHOW$2 = 'show';\nconst EVENT_SHOWN$2 = 'shown';\nconst EVENT_INSERTED = 'inserted';\nconst EVENT_CLICK$1 = 'click';\nconst EVENT_FOCUSIN$1 = 'focusin';\nconst EVENT_FOCUSOUT$1 = 'focusout';\nconst EVENT_MOUSEENTER = 'mouseenter';\nconst EVENT_MOUSELEAVE = 'mouseleave';\nconst AttachmentMap = {\n AUTO: 'auto',\n TOP: 'top',\n RIGHT: isRTL() ? 'left' : 'right',\n BOTTOM: 'bottom',\n LEFT: isRTL() ? 'right' : 'left'\n};\nconst Default$3 = {\n allowList: DefaultAllowlist,\n animation: true,\n boundary: 'clippingParents',\n container: false,\n customClass: '',\n delay: 0,\n fallbackPlacements: ['top', 'right', 'bottom', 'left'],\n html: false,\n offset: [0, 6],\n placement: 'top',\n popperConfig: null,\n sanitize: true,\n sanitizeFn: null,\n selector: false,\n template: '
' + '
' + '
' + '
',\n title: '',\n trigger: 'hover focus'\n};\nconst DefaultType$3 = {\n allowList: 'object',\n animation: 'boolean',\n boundary: '(string|element)',\n container: '(string|element|boolean)',\n customClass: '(string|function)',\n delay: '(number|object)',\n fallbackPlacements: 'array',\n html: 'boolean',\n offset: '(array|string|function)',\n placement: '(string|function)',\n popperConfig: '(null|object|function)',\n sanitize: 'boolean',\n sanitizeFn: '(null|function)',\n selector: '(string|boolean)',\n template: 'string',\n title: '(string|element|function)',\n trigger: 'string'\n};\n\n/**\n * Class definition\n */\n\nclass Tooltip extends BaseComponent {\n constructor(element, config) {\n if (typeof Popper === 'undefined') {\n throw new TypeError('Bootstrap\\'s tooltips require Popper (https://popper.js.org)');\n }\n super(element, config);\n\n // Private\n this._isEnabled = true;\n this._timeout = 0;\n this._isHovered = null;\n this._activeTrigger = {};\n this._popper = null;\n this._templateFactory = null;\n this._newContent = null;\n\n // Protected\n this.tip = null;\n this._setListeners();\n if (!this._config.selector) {\n this._fixTitle();\n }\n }\n\n // Getters\n static get Default() {\n return Default$3;\n }\n static get DefaultType() {\n return DefaultType$3;\n }\n static get NAME() {\n return NAME$4;\n }\n\n // Public\n enable() {\n this._isEnabled = true;\n }\n disable() {\n this._isEnabled = false;\n }\n toggleEnabled() {\n this._isEnabled = !this._isEnabled;\n }\n toggle() {\n if (!this._isEnabled) {\n return;\n }\n this._activeTrigger.click = !this._activeTrigger.click;\n if (this._isShown()) {\n this._leave();\n return;\n }\n this._enter();\n }\n dispose() {\n clearTimeout(this._timeout);\n EventHandler.off(this._element.closest(SELECTOR_MODAL), EVENT_MODAL_HIDE, this._hideModalHandler);\n if (this._element.getAttribute('data-bs-original-title')) {\n this._element.setAttribute('title', this._element.getAttribute('data-bs-original-title'));\n }\n this._disposePopper();\n super.dispose();\n }\n show() {\n if (this._element.style.display === 'none') {\n throw new Error('Please use show on visible elements');\n }\n if (!(this._isWithContent() && this._isEnabled)) {\n return;\n }\n const showEvent = EventHandler.trigger(this._element, this.constructor.eventName(EVENT_SHOW$2));\n const shadowRoot = findShadowRoot(this._element);\n const isInTheDom = (shadowRoot || this._element.ownerDocument.documentElement).contains(this._element);\n if (showEvent.defaultPrevented || !isInTheDom) {\n return;\n }\n\n // TODO: v6 remove this or make it optional\n this._disposePopper();\n const tip = this._getTipElement();\n this._element.setAttribute('aria-describedby', tip.getAttribute('id'));\n const {\n container\n } = this._config;\n if (!this._element.ownerDocument.documentElement.contains(this.tip)) {\n container.append(tip);\n EventHandler.trigger(this._element, this.constructor.eventName(EVENT_INSERTED));\n }\n this._popper = this._createPopper(tip);\n tip.classList.add(CLASS_NAME_SHOW$2);\n\n // If this is a touch-enabled device we add extra\n // empty mouseover listeners to the body's immediate children;\n // only needed because of broken event delegation on iOS\n // https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html\n if ('ontouchstart' in document.documentElement) {\n for (const element of [].concat(...document.body.children)) {\n EventHandler.on(element, 'mouseover', noop);\n }\n }\n const complete = () => {\n EventHandler.trigger(this._element, this.constructor.eventName(EVENT_SHOWN$2));\n if (this._isHovered === false) {\n this._leave();\n }\n this._isHovered = false;\n };\n this._queueCallback(complete, this.tip, this._isAnimated());\n }\n hide() {\n if (!this._isShown()) {\n return;\n }\n const hideEvent = EventHandler.trigger(this._element, this.constructor.eventName(EVENT_HIDE$2));\n if (hideEvent.defaultPrevented) {\n return;\n }\n const tip = this._getTipElement();\n tip.classList.remove(CLASS_NAME_SHOW$2);\n\n // If this is a touch-enabled device we remove the extra\n // empty mouseover listeners we added for iOS support\n if ('ontouchstart' in document.documentElement) {\n for (const element of [].concat(...document.body.children)) {\n EventHandler.off(element, 'mouseover', noop);\n }\n }\n this._activeTrigger[TRIGGER_CLICK] = false;\n this._activeTrigger[TRIGGER_FOCUS] = false;\n this._activeTrigger[TRIGGER_HOVER] = false;\n this._isHovered = null; // it is a trick to support manual triggering\n\n const complete = () => {\n if (this._isWithActiveTrigger()) {\n return;\n }\n if (!this._isHovered) {\n this._disposePopper();\n }\n this._element.removeAttribute('aria-describedby');\n EventHandler.trigger(this._element, this.constructor.eventName(EVENT_HIDDEN$2));\n };\n this._queueCallback(complete, this.tip, this._isAnimated());\n }\n update() {\n if (this._popper) {\n this._popper.update();\n }\n }\n\n // Protected\n _isWithContent() {\n return Boolean(this._getTitle());\n }\n _getTipElement() {\n if (!this.tip) {\n this.tip = this._createTipElement(this._newContent || this._getContentForTemplate());\n }\n return this.tip;\n }\n _createTipElement(content) {\n const tip = this._getTemplateFactory(content).toHtml();\n\n // TODO: remove this check in v6\n if (!tip) {\n return null;\n }\n tip.classList.remove(CLASS_NAME_FADE$2, CLASS_NAME_SHOW$2);\n // TODO: v6 the following can be achieved with CSS only\n tip.classList.add(`bs-${this.constructor.NAME}-auto`);\n const tipId = getUID(this.constructor.NAME).toString();\n tip.setAttribute('id', tipId);\n if (this._isAnimated()) {\n tip.classList.add(CLASS_NAME_FADE$2);\n }\n return tip;\n }\n setContent(content) {\n this._newContent = content;\n if (this._isShown()) {\n this._disposePopper();\n this.show();\n }\n }\n _getTemplateFactory(content) {\n if (this._templateFactory) {\n this._templateFactory.changeContent(content);\n } else {\n this._templateFactory = new TemplateFactory({\n ...this._config,\n // the `content` var has to be after `this._config`\n // to override config.content in case of popover\n content,\n extraClass: this._resolvePossibleFunction(this._config.customClass)\n });\n }\n return this._templateFactory;\n }\n _getContentForTemplate() {\n return {\n [SELECTOR_TOOLTIP_INNER]: this._getTitle()\n };\n }\n _getTitle() {\n return this._resolvePossibleFunction(this._config.title) || this._element.getAttribute('data-bs-original-title');\n }\n\n // Private\n _initializeOnDelegatedTarget(event) {\n return this.constructor.getOrCreateInstance(event.delegateTarget, this._getDelegateConfig());\n }\n _isAnimated() {\n return this._config.animation || this.tip && this.tip.classList.contains(CLASS_NAME_FADE$2);\n }\n _isShown() {\n return this.tip && this.tip.classList.contains(CLASS_NAME_SHOW$2);\n }\n _createPopper(tip) {\n const placement = execute(this._config.placement, [this, tip, this._element]);\n const attachment = AttachmentMap[placement.toUpperCase()];\n return Popper.createPopper(this._element, tip, this._getPopperConfig(attachment));\n }\n _getOffset() {\n const {\n offset\n } = this._config;\n if (typeof offset === 'string') {\n return offset.split(',').map(value => Number.parseInt(value, 10));\n }\n if (typeof offset === 'function') {\n return popperData => offset(popperData, this._element);\n }\n return offset;\n }\n _resolvePossibleFunction(arg) {\n return execute(arg, [this._element]);\n }\n _getPopperConfig(attachment) {\n const defaultBsPopperConfig = {\n placement: attachment,\n modifiers: [{\n name: 'flip',\n options: {\n fallbackPlacements: this._config.fallbackPlacements\n }\n }, {\n name: 'offset',\n options: {\n offset: this._getOffset()\n }\n }, {\n name: 'preventOverflow',\n options: {\n boundary: this._config.boundary\n }\n }, {\n name: 'arrow',\n options: {\n element: `.${this.constructor.NAME}-arrow`\n }\n }, {\n name: 'preSetPlacement',\n enabled: true,\n phase: 'beforeMain',\n fn: data => {\n // Pre-set Popper's placement attribute in order to read the arrow sizes properly.\n // Otherwise, Popper mixes up the width and height dimensions since the initial arrow style is for top placement\n this._getTipElement().setAttribute('data-popper-placement', data.state.placement);\n }\n }]\n };\n return {\n ...defaultBsPopperConfig,\n ...execute(this._config.popperConfig, [defaultBsPopperConfig])\n };\n }\n _setListeners() {\n const triggers = this._config.trigger.split(' ');\n for (const trigger of triggers) {\n if (trigger === 'click') {\n EventHandler.on(this._element, this.constructor.eventName(EVENT_CLICK$1), this._config.selector, event => {\n const context = this._initializeOnDelegatedTarget(event);\n context.toggle();\n });\n } else if (trigger !== TRIGGER_MANUAL) {\n const eventIn = trigger === TRIGGER_HOVER ? this.constructor.eventName(EVENT_MOUSEENTER) : this.constructor.eventName(EVENT_FOCUSIN$1);\n const eventOut = trigger === TRIGGER_HOVER ? this.constructor.eventName(EVENT_MOUSELEAVE) : this.constructor.eventName(EVENT_FOCUSOUT$1);\n EventHandler.on(this._element, eventIn, this._config.selector, event => {\n const context = this._initializeOnDelegatedTarget(event);\n context._activeTrigger[event.type === 'focusin' ? TRIGGER_FOCUS : TRIGGER_HOVER] = true;\n context._enter();\n });\n EventHandler.on(this._element, eventOut, this._config.selector, event => {\n const context = this._initializeOnDelegatedTarget(event);\n context._activeTrigger[event.type === 'focusout' ? TRIGGER_FOCUS : TRIGGER_HOVER] = context._element.contains(event.relatedTarget);\n context._leave();\n });\n }\n }\n this._hideModalHandler = () => {\n if (this._element) {\n this.hide();\n }\n };\n EventHandler.on(this._element.closest(SELECTOR_MODAL), EVENT_MODAL_HIDE, this._hideModalHandler);\n }\n _fixTitle() {\n const title = this._element.getAttribute('title');\n if (!title) {\n return;\n }\n if (!this._element.getAttribute('aria-label') && !this._element.textContent.trim()) {\n this._element.setAttribute('aria-label', title);\n }\n this._element.setAttribute('data-bs-original-title', title); // DO NOT USE IT. Is only for backwards compatibility\n this._element.removeAttribute('title');\n }\n _enter() {\n if (this._isShown() || this._isHovered) {\n this._isHovered = true;\n return;\n }\n this._isHovered = true;\n this._setTimeout(() => {\n if (this._isHovered) {\n this.show();\n }\n }, this._config.delay.show);\n }\n _leave() {\n if (this._isWithActiveTrigger()) {\n return;\n }\n this._isHovered = false;\n this._setTimeout(() => {\n if (!this._isHovered) {\n this.hide();\n }\n }, this._config.delay.hide);\n }\n _setTimeout(handler, timeout) {\n clearTimeout(this._timeout);\n this._timeout = setTimeout(handler, timeout);\n }\n _isWithActiveTrigger() {\n return Object.values(this._activeTrigger).includes(true);\n }\n _getConfig(config) {\n const dataAttributes = Manipulator.getDataAttributes(this._element);\n for (const dataAttribute of Object.keys(dataAttributes)) {\n if (DISALLOWED_ATTRIBUTES.has(dataAttribute)) {\n delete dataAttributes[dataAttribute];\n }\n }\n config = {\n ...dataAttributes,\n ...(typeof config === 'object' && config ? config : {})\n };\n config = this._mergeConfigObj(config);\n config = this._configAfterMerge(config);\n this._typeCheckConfig(config);\n return config;\n }\n _configAfterMerge(config) {\n config.container = config.container === false ? document.body : getElement(config.container);\n if (typeof config.delay === 'number') {\n config.delay = {\n show: config.delay,\n hide: config.delay\n };\n }\n if (typeof config.title === 'number') {\n config.title = config.title.toString();\n }\n if (typeof config.content === 'number') {\n config.content = config.content.toString();\n }\n return config;\n }\n _getDelegateConfig() {\n const config = {};\n for (const [key, value] of Object.entries(this._config)) {\n if (this.constructor.Default[key] !== value) {\n config[key] = value;\n }\n }\n config.selector = false;\n config.trigger = 'manual';\n\n // In the future can be replaced with:\n // const keysWithDifferentValues = Object.entries(this._config).filter(entry => this.constructor.Default[entry[0]] !== this._config[entry[0]])\n // `Object.fromEntries(keysWithDifferentValues)`\n return config;\n }\n _disposePopper() {\n if (this._popper) {\n this._popper.destroy();\n this._popper = null;\n }\n if (this.tip) {\n this.tip.remove();\n this.tip = null;\n }\n }\n\n // Static\n static jQueryInterface(config) {\n return this.each(function () {\n const data = Tooltip.getOrCreateInstance(this, config);\n if (typeof config !== 'string') {\n return;\n }\n if (typeof data[config] === 'undefined') {\n throw new TypeError(`No method named \"${config}\"`);\n }\n data[config]();\n });\n }\n}\n\n/**\n * jQuery\n */\n\ndefineJQueryPlugin(Tooltip);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap popover.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst NAME$3 = 'popover';\nconst SELECTOR_TITLE = '.popover-header';\nconst SELECTOR_CONTENT = '.popover-body';\nconst Default$2 = {\n ...Tooltip.Default,\n content: '',\n offset: [0, 8],\n placement: 'right',\n template: '
' + '
' + '

' + '
' + '
',\n trigger: 'click'\n};\nconst DefaultType$2 = {\n ...Tooltip.DefaultType,\n content: '(null|string|element|function)'\n};\n\n/**\n * Class definition\n */\n\nclass Popover extends Tooltip {\n // Getters\n static get Default() {\n return Default$2;\n }\n static get DefaultType() {\n return DefaultType$2;\n }\n static get NAME() {\n return NAME$3;\n }\n\n // Overrides\n _isWithContent() {\n return this._getTitle() || this._getContent();\n }\n\n // Private\n _getContentForTemplate() {\n return {\n [SELECTOR_TITLE]: this._getTitle(),\n [SELECTOR_CONTENT]: this._getContent()\n };\n }\n _getContent() {\n return this._resolvePossibleFunction(this._config.content);\n }\n\n // Static\n static jQueryInterface(config) {\n return this.each(function () {\n const data = Popover.getOrCreateInstance(this, config);\n if (typeof config !== 'string') {\n return;\n }\n if (typeof data[config] === 'undefined') {\n throw new TypeError(`No method named \"${config}\"`);\n }\n data[config]();\n });\n }\n}\n\n/**\n * jQuery\n */\n\ndefineJQueryPlugin(Popover);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap scrollspy.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n * --------------------------------------------------------------------------\n */\n\n\n/**\n * Constants\n */\n\nconst NAME$2 = 'scrollspy';\nconst DATA_KEY$2 = 'bs.scrollspy';\nconst EVENT_KEY$2 = `.${DATA_KEY$2}`;\nconst DATA_API_KEY = '.data-api';\nconst EVENT_ACTIVATE = `activate${EVENT_KEY$2}`;\nconst EVENT_CLICK = `click${EVENT_KEY$2}`;\nconst EVENT_LOAD_DATA_API$1 = `load${EVENT_KEY$2}${DATA_API_KEY}`;\nconst CLASS_NAME_DROPDOWN_ITEM = 'dropdown-item';\nconst CLASS_NAME_ACTIVE$1 = 'active';\nconst SELECTOR_DATA_SPY = '[data-bs-spy=\"scroll\"]';\nconst SELECTOR_TARGET_LINKS = '[href]';\nconst SELECTOR_NAV_LIST_GROUP = '.nav, .list-group';\nconst SELECTOR_NAV_LINKS = '.nav-link';\nconst SELECTOR_NAV_ITEMS = '.nav-item';\nconst SELECTOR_LIST_ITEMS = '.list-group-item';\nconst SELECTOR_LINK_ITEMS = `${SELECTOR_NAV_LINKS}, ${SELECTOR_NAV_ITEMS} > ${SELECTOR_NAV_LINKS}, ${SELECTOR_LIST_ITEMS}`;\nconst SELECTOR_DROPDOWN = '.dropdown';\nconst SELECTOR_DROPDOWN_TOGGLE$1 = '.dropdown-toggle';\nconst Default$1 = {\n offset: null,\n // TODO: v6 @deprecated, keep it for backwards compatibility reasons\n rootMargin: '0px 0px -25%',\n smoothScroll: false,\n target: null,\n threshold: [0.1, 0.5, 1]\n};\nconst DefaultType$1 = {\n offset: '(number|null)',\n // TODO v6 @deprecated, keep it for backwards compatibility reasons\n rootMargin: 'string',\n smoothScroll: 'boolean',\n target: 'element',\n threshold: 'array'\n};\n\n/**\n * Class definition\n */\n\nclass ScrollSpy extends BaseComponent {\n constructor(element, config) {\n super(element, config);\n\n // this._element is the observablesContainer and config.target the menu links wrapper\n this._targetLinks = new Map();\n this._observableSections = new Map();\n this._rootElement = getComputedStyle(this._element).overflowY === 'visible' ? null : this._element;\n this._activeTarget = null;\n this._observer = null;\n this._previousScrollData = {\n visibleEntryTop: 0,\n parentScrollTop: 0\n };\n this.refresh(); // initialize\n }\n\n // Getters\n static get Default() {\n return Default$1;\n }\n static get DefaultType() {\n return DefaultType$1;\n }\n static get NAME() {\n return NAME$2;\n }\n\n // Public\n refresh() {\n this._initializeTargetsAndObservables();\n this._maybeEnableSmoothScroll();\n if (this._observer) {\n this._observer.disconnect();\n } else {\n this._observer = this._getNewObserver();\n }\n for (const section of this._observableSections.values()) {\n this._observer.observe(section);\n }\n }\n dispose() {\n this._observer.disconnect();\n super.dispose();\n }\n\n // Private\n _configAfterMerge(config) {\n // TODO: on v6 target should be given explicitly & remove the {target: 'ss-target'} case\n config.target = getElement(config.target) || document.body;\n\n // TODO: v6 Only for backwards compatibility reasons. Use rootMargin only\n config.rootMargin = config.offset ? `${config.offset}px 0px -30%` : config.rootMargin;\n if (typeof config.threshold === 'string') {\n config.threshold = config.threshold.split(',').map(value => Number.parseFloat(value));\n }\n return config;\n }\n _maybeEnableSmoothScroll() {\n if (!this._config.smoothScroll) {\n return;\n }\n\n // unregister any previous listeners\n EventHandler.off(this._config.target, EVENT_CLICK);\n EventHandler.on(this._config.target, EVENT_CLICK, SELECTOR_TARGET_LINKS, event => {\n const observableSection = this._observableSections.get(event.target.hash);\n if (observableSection) {\n event.preventDefault();\n const root = this._rootElement || window;\n const height = observableSection.offsetTop - this._element.offsetTop;\n if (root.scrollTo) {\n root.scrollTo({\n top: height,\n behavior: 'smooth'\n });\n return;\n }\n\n // Chrome 60 doesn't support `scrollTo`\n root.scrollTop = height;\n }\n });\n }\n _getNewObserver() {\n const options = {\n root: this._rootElement,\n threshold: this._config.threshold,\n rootMargin: this._config.rootMargin\n };\n return new IntersectionObserver(entries => this._observerCallback(entries), options);\n }\n\n // The logic of selection\n _observerCallback(entries) {\n const targetElement = entry => this._targetLinks.get(`#${entry.target.id}`);\n const activate = entry => {\n this._previousScrollData.visibleEntryTop = entry.target.offsetTop;\n this._process(targetElement(entry));\n };\n const parentScrollTop = (this._rootElement || document.documentElement).scrollTop;\n const userScrollsDown = parentScrollTop >= this._previousScrollData.parentScrollTop;\n this._previousScrollData.parentScrollTop = parentScrollTop;\n for (const entry of entries) {\n if (!entry.isIntersecting) {\n this._activeTarget = null;\n this._clearActiveClass(targetElement(entry));\n continue;\n }\n const entryIsLowerThanPrevious = entry.target.offsetTop >= this._previousScrollData.visibleEntryTop;\n // if we are scrolling down, pick the bigger offsetTop\n if (userScrollsDown && entryIsLowerThanPrevious) {\n activate(entry);\n // if parent isn't scrolled, let's keep the first visible item, breaking the iteration\n if (!parentScrollTop) {\n return;\n }\n continue;\n }\n\n // if we are scrolling up, pick the smallest offsetTop\n if (!userScrollsDown && !entryIsLowerThanPrevious) {\n activate(entry);\n }\n }\n }\n _initializeTargetsAndObservables() {\n this._targetLinks = new Map();\n this._observableSections = new Map();\n const targetLinks = SelectorEngine.find(SELECTOR_TARGET_LINKS, this._config.target);\n for (const anchor of targetLinks) {\n // ensure that the anchor has an id and is not disabled\n if (!anchor.hash || isDisabled(anchor)) {\n continue;\n }\n const observableSection = SelectorEngine.findOne(decodeURI(anchor.hash), this._element);\n\n // ensure that the observableSection exists & is visible\n if (isVisible(observableSection)) {\n this._targetLinks.set(decodeURI(anchor.hash), anchor);\n this._observableSections.set(anchor.hash, observableSection);\n }\n }\n }\n _process(target) {\n if (this._activeTarget === target) {\n return;\n }\n this._clearActiveClass(this._config.target);\n this._activeTarget = target;\n target.classList.add(CLASS_NAME_ACTIVE$1);\n this._activateParents(target);\n EventHandler.trigger(this._element, EVENT_ACTIVATE, {\n relatedTarget: target\n });\n }\n _activateParents(target) {\n // Activate dropdown parents\n if (target.classList.contains(CLASS_NAME_DROPDOWN_ITEM)) {\n SelectorEngine.findOne(SELECTOR_DROPDOWN_TOGGLE$1, target.closest(SELECTOR_DROPDOWN)).classList.add(CLASS_NAME_ACTIVE$1);\n return;\n }\n for (const listGroup of SelectorEngine.parents(target, SELECTOR_NAV_LIST_GROUP)) {\n // Set triggered links parents as active\n // With both

E+2V|Cac!INiKD;u^mb4>C5iu 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 VGg2ohsks&Ctt6K}A)HXxe*wpsBqsm> literal 0 HcmV?d00001 diff --git a/_images/image006.jpg b/_images/image006.jpg new file mode 100644 index 0000000000000000000000000000000000000000..23f2393c871b17c796c5b80ef9eb1f33e7bbce75 GIT binary patch literal 14805 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 NO@aJ>eBhv_{tre(8ZH0; literal 0 HcmV?d00001 diff --git a/_images/image006a.jpg b/_images/image006a.jpg new file mode 100644 index 0000000000000000000000000000000000000000..d1008e4b4b564ac753182afbc63296cc1af5b883 GIT binary patch literal 11981 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 literal 0 HcmV?d00001 diff --git a/_images/image008.jpg b/_images/image008.jpg new file mode 100644 index 0000000000000000000000000000000000000000..e5a2a4bd34962b6a52687ad455f63a765c2e4c1c GIT binary patch literal 20556 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 f$~$JJJ9cG4=leh-$kG literal 0 HcmV?d00001 diff --git a/_images/image008a.jpg b/_images/image008a.jpg new file mode 100644 index 0000000000000000000000000000000000000000..f1199dbaef58e49168a2d87cdeac29c9139097ae GIT binary patch literal 30488 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⩔Ul#U6s#G<7+7T95tkjR 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 I`D^dL0qy(f1ONa4 literal 0 HcmV?d00001 diff --git a/_images/image009.jpg b/_images/image009.jpg new file mode 100644 index 0000000000000000000000000000000000000000..d88d94f26b2d0069a322ddf4b0c8fad51d57b3ad GIT binary patch literal 41411 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 literal 0 HcmV?d00001 diff --git a/_images/image009a.jpg b/_images/image009a.jpg new file mode 100644 index 0000000000000000000000000000000000000000..02cd19606791c00b1344b68af34b84f5440cf937 GIT binary patch literal 21793 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 O`VZ~;U&*kZ4E;ZP>d9RI literal 0 HcmV?d00001 diff --git a/_images/image010.jpg b/_images/image010.jpg new file mode 100644 index 0000000000000000000000000000000000000000..c84ab1d56791bcf0567d7c72e7679afb9ec63f51 GIT binary patch literal 767 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 literal 0 HcmV?d00001 diff --git a/_images/image012.jpg b/_images/image012.jpg new file mode 100644 index 0000000000000000000000000000000000000000..e9b011c85a3f3e498e097933fa722a5eaa41f9bd GIT binary patch literal 5596 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 z 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 B!0!M6 literal 0 HcmV?d00001 diff --git a/_images/make_edges_usage.png b/_images/make_edges_usage.png new file mode 100644 index 0000000000000000000000000000000000000000..3f9d23c9d5a593caf6e4b58d09f3f439bf76d5f4 GIT binary patch literal 289439 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