passenger 6.0.2 → 6.0.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG +60 -19
- data/CONTRIBUTORS +2 -0
- data/build/support/vendor/cxxcodebuilder/lib/cxxcodebuilder/builder.rb +56 -3
- data/dev/copy_boost_headers +1 -0
- data/package.json +1 -1
- data/resources/templates/standalone/http.erb +1 -0
- data/src/agent/Core/Config.h +13 -1
- data/src/agent/Core/Controller/Config.h +1 -1
- data/src/agent/Core/CoreMain.cpp +1 -0
- data/src/agent/Core/SpawningKit/Context.h +1 -0
- data/src/agent/Core/SpawningKit/Handshake/Prepare.h +1 -1
- data/src/agent/Core/SpawningKit/Handshake/WorkDir.h +5 -2
- data/src/agent/Watchdog/Config.h +14 -1
- data/src/agent/Watchdog/WatchdogMain.cpp +7 -0
- data/src/apache2_module/ConfigGeneral/AutoGeneratedDefinitions.cpp +5 -0
- data/src/apache2_module/ConfigGeneral/AutoGeneratedManifestDefaultsInitialization.cpp +5 -0
- data/src/apache2_module/ConfigGeneral/AutoGeneratedSetterFuncs.cpp +15 -0
- data/src/apache2_module/Hooks.cpp +1 -0
- data/src/apache2_module/ServerConfig/AutoGeneratedManifestGeneration.cpp +11 -0
- data/src/apache2_module/ServerConfig/AutoGeneratedStruct.h +13 -0
- data/src/cxx_supportlib/Constants.h +1 -1
- data/src/cxx_supportlib/LoggingKit/Config.h +1 -0
- data/src/cxx_supportlib/ServerKit/HttpChunkedBodyParser.h +1 -1
- data/src/cxx_supportlib/SystemTools/ContainerHelpers.h +2 -2
- data/src/cxx_supportlib/WebSocketCommandReverseServer.h +11 -7
- data/src/cxx_supportlib/vendor-modified/boost/algorithm/string/finder.hpp +0 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/buffer.hpp +46 -37
- data/src/cxx_supportlib/vendor-modified/boost/asio/connect.hpp +16 -15
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/config.hpp +45 -26
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/future.hpp +33 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/socket_ops.ipp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/is_buffer_sequence.hpp +38 -14
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/timer_queue.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/io_context.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read_until.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/use_future.hpp +0 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/bad_address_cast.hpp +6 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/basic_resolver.hpp +6 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/basic_resolver_results.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/packaged_task.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/asio/read.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/read_at.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/read_until.hpp +8 -6
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/context_base.hpp +17 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/impl/context.ipp +50 -5
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/stream.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/thread_pool.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/use_future.hpp +3 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/version.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/write.hpp +4 -3
- data/src/cxx_supportlib/vendor-modified/boost/asio/write_at.hpp +5 -3
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/ops_gcc_x86_dcas.hpp +13 -12
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/inlined/mac/chrono.hpp +10 -10
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/inlined/mac/process_cpu_clocks.hpp +34 -34
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/inlined/mac/thread_clock.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/inlined/posix/chrono.hpp +8 -8
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/inlined/posix/process_cpu_clocks.hpp +27 -27
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/inlined/posix/thread_clock.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/system.hpp +5 -4
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io/time_point_io.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/circular_buffer.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/circular_buffer/allocators.hpp +89 -0
- data/src/cxx_supportlib/vendor-modified/boost/circular_buffer/base.hpp +83 -74
- data/src/cxx_supportlib/vendor-modified/boost/circular_buffer/details.hpp +21 -33
- data/src/cxx_supportlib/vendor-modified/boost/circular_buffer/space_optimized.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/concept/assert.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/concept/detail/general.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/concept/detail/has_constraints.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/concept/usage.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/concept_check.hpp +19 -19
- data/src/cxx_supportlib/vendor-modified/boost/config/auto_link.hpp +8 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/borland.hpp +5 -2
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/clang.hpp +5 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/codegear.hpp +6 -2
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/comeau.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/common_edg.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/cray.hpp +368 -52
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/digitalmars.hpp +4 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/gcc.hpp +6 -3
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/gcc_xml.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/greenhills.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/hp_acc.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/intel.hpp +6 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/kai.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/metrowerks.hpp +4 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/mpw.hpp +4 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/nvcc.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/pathscale.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/sunpro_cc.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/vacpp.hpp +4 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/visualc.hpp +9 -4
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/xlcpp.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/xlcpp_zos.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/detail/select_compiler_config.hpp +1 -2
- data/src/cxx_supportlib/vendor-modified/boost/config/detail/suffix.hpp +13 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/dinkumware.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/libcpp.hpp +14 -4
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/libstdcpp3.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/container/adaptive_pool.hpp +262 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/allocator.hpp +4 -3
- data/src/cxx_supportlib/vendor-modified/boost/container/allocator_traits.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/deque.hpp +7 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/adaptive_node_pool.hpp +22 -19
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/adaptive_node_pool_impl.hpp +833 -459
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/advanced_insert_int.hpp +24 -6
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/allocator_version_traits.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/compare_functors.hpp +61 -5
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/copy_move_algo.hpp +33 -8
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/flat_tree.hpp +132 -41
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/iterator.hpp +16 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/math_functions.hpp +54 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/mpl.hpp +58 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/multiallocation_chain.hpp +28 -23
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/node_alloc_holder.hpp +167 -115
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/pair.hpp +55 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/std_fwd.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/thread_mutex.hpp +181 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/tree.hpp +167 -29
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/type_traits.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/variadic_templates_tools.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/workaround.hpp +18 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/flat_map.hpp +389 -3
- data/src/cxx_supportlib/vendor-modified/boost/container/flat_set.hpp +262 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/list.hpp +52 -8
- data/src/cxx_supportlib/vendor-modified/boost/container/map.hpp +364 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/monotonic_buffer_resource.hpp +4 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/resource_adaptor.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/synchronized_pool_resource.hpp +3 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/set.hpp +286 -6
- data/src/cxx_supportlib/vendor-modified/boost/container/slist.hpp +56 -8
- data/src/cxx_supportlib/vendor-modified/boost/container/small_vector.hpp +43 -6
- data/src/cxx_supportlib/vendor-modified/boost/container/stable_vector.hpp +100 -31
- data/src/cxx_supportlib/vendor-modified/boost/container/static_vector.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/string.hpp +126 -69
- data/src/cxx_supportlib/vendor-modified/boost/container/vector.hpp +75 -51
- data/src/cxx_supportlib/vendor-modified/boost/core/empty_value.hpp +136 -0
- data/src/cxx_supportlib/vendor-modified/boost/core/exchange.hpp +49 -0
- data/src/cxx_supportlib/vendor-modified/boost/core/explicit_operator_bool.hpp +9 -0
- data/src/cxx_supportlib/vendor-modified/boost/core/lightweight_test.hpp +101 -130
- data/src/cxx_supportlib/vendor-modified/boost/core/lightweight_test_trait.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/core/noncopyable.hpp +16 -1
- data/src/cxx_supportlib/vendor-modified/boost/core/quick_exit.hpp +59 -0
- data/src/cxx_supportlib/vendor-modified/boost/core/ref.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/core/swap.hpp +9 -2
- data/src/cxx_supportlib/vendor-modified/boost/core/typeinfo.hpp +26 -10
- data/src/cxx_supportlib/vendor-modified/boost/date_time/compiler_config.hpp +5 -0
- data/src/cxx_supportlib/vendor-modified/boost/date_time/posix_time/posix_time_duration.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/date_time/time_duration.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/detail/basic_pointerbuf.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/detail/indirect_traits.hpp +38 -47
- data/src/cxx_supportlib/vendor-modified/boost/detail/lcast_precision.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/detail/reference_content.hpp +7 -7
- data/src/cxx_supportlib/vendor-modified/boost/exception/exception.hpp +62 -58
- data/src/cxx_supportlib/vendor-modified/boost/function.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/function/function_base.hpp +29 -29
- data/src/cxx_supportlib/vendor-modified/boost/function/function_template.hpp +38 -40
- data/src/cxx_supportlib/vendor-modified/boost/integer/common_factor_rt.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/avltree_algorithms.hpp +44 -44
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/bstree_algorithms.hpp +39 -39
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/circular_list_algorithms.hpp +15 -15
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/circular_slist_algorithms.hpp +7 -7
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/derivation_value_traits.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/any_node_and_algorithms.hpp +14 -14
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/avltree_node.hpp +9 -9
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/common_slist_algorithms.hpp +7 -7
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/list_iterator.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/list_node.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/node_cloner_disposer.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/rbtree_node.hpp +6 -6
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/simple_disposers.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/slist_iterator.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/slist_node.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/tree_iterator.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/tree_node.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/tree_value_compare.hpp +33 -14
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/hashtable.hpp +12 -12
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/linear_slist_algorithms.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/pointer_plus_bits.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/rbtree_algorithms.hpp +39 -39
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/sgtree_algorithms.hpp +61 -61
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/slist.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/splaytree_algorithms.hpp +66 -66
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/treap_algorithms.hpp +54 -54
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/unordered_set.hpp +6 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/unordered_set_hook.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/iterator/advance.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/iterator/distance.hpp +65 -0
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/bad_lexical_cast.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/converter_lexical.hpp +23 -23
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/converter_lexical_streams.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/converter_numeric.hpp +13 -13
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/inf_nan.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/is_character.hpp +5 -4
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/lcast_char_constants.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/lcast_unsigned_converters.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/widest_char.hpp +5 -2
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/try_lexical_convert.hpp +18 -13
- data/src/cxx_supportlib/vendor-modified/boost/libs/regex/src/cregex.cpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/libs/system/src/error_code.cpp +16 -5
- data/src/cxx_supportlib/vendor-modified/boost/libs/thread/src/future.cpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/libs/thread/src/pthread/thread.cpp +14 -8
- data/src/cxx_supportlib/vendor-modified/boost/libs/thread/src/tss_null.cpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/math/special_functions/detail/fp_traits.hpp +13 -13
- data/src/cxx_supportlib/vendor-modified/boost/math/special_functions/math_fwd.hpp +27 -0
- data/src/cxx_supportlib/vendor-modified/boost/math/tools/config.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/move/algo/adaptive_merge.hpp +29 -6
- data/src/cxx_supportlib/vendor-modified/boost/move/algo/adaptive_sort.hpp +12 -3
- data/src/cxx_supportlib/vendor-modified/boost/move/algo/detail/adaptive_sort_merge.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/move/algo/move.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/move/algorithm.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/move/core.hpp +8 -8
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/meta_utils.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/type_traits.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/mpl/assert.hpp +23 -3
- data/src/cxx_supportlib/vendor-modified/boost/optional/detail/experimental_traits.hpp +9 -3
- data/src/cxx_supportlib/vendor-modified/boost/optional/detail/old_optional_implementation.hpp +10 -11
- data/src/cxx_supportlib/vendor-modified/boost/optional/detail/optional_reference_spec.hpp +20 -1
- data/src/cxx_supportlib/vendor-modified/boost/optional/detail/optional_trivially_copyable_base.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/optional/optional.hpp +211 -101
- data/src/cxx_supportlib/vendor-modified/boost/parameter/python.hpp +5 -6
- data/src/cxx_supportlib/vendor-modified/boost/pool/detail/mutex.hpp +119 -25
- data/src/cxx_supportlib/vendor-modified/boost/predef/architecture.h +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/predef/architecture/arm.h +5 -0
- data/src/cxx_supportlib/vendor-modified/boost/predef/architecture/ptx.h +44 -0
- data/src/cxx_supportlib/vendor-modified/boost/predef/compiler.h +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/predef/compiler/compaq.h +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/predef/compiler/nvcc.h +73 -0
- data/src/cxx_supportlib/vendor-modified/boost/predef/detail/endian_compat.h +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/predef/language.h +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/predef/language/cuda.h +52 -0
- data/src/cxx_supportlib/vendor-modified/boost/predef/make.h +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/predef/os/cygwin.h +6 -1
- data/src/cxx_supportlib/vendor-modified/boost/predef/other/endian.h +1 -2
- data/src/cxx_supportlib/vendor-modified/boost/predef/version.h +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/preprocessor/config/config.hpp +17 -8
- data/src/cxx_supportlib/vendor-modified/boost/preprocessor/stringize.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/preprocessor/wstringize.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/gray_coded_qrng.hpp +166 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/niederreiter_base2_table.hpp +513 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/qrng_base.hpp +291 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/sobol_table.hpp +4106 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/faure.hpp +367 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/niederreiter_base2.hpp +360 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/sobol.hpp +237 -0
- data/src/cxx_supportlib/vendor-modified/boost/range/as_literal.hpp +43 -0
- data/src/cxx_supportlib/vendor-modified/boost/range/begin.hpp +13 -5
- data/src/cxx_supportlib/vendor-modified/boost/range/concepts.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/range/detail/common.hpp +1 -3
- data/src/cxx_supportlib/vendor-modified/boost/range/detail/implementation_help.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/range/distance.hpp +11 -5
- data/src/cxx_supportlib/vendor-modified/boost/range/end.hpp +14 -6
- data/src/cxx_supportlib/vendor-modified/boost/range/has_range_iterator.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/ratio/config.hpp +6 -2
- data/src/cxx_supportlib/vendor-modified/boost/rational.hpp +55 -37
- data/src/cxx_supportlib/vendor-modified/boost/regex/concepts.hpp +3 -2
- data/src/cxx_supportlib/vendor-modified/boost/regex/config.hpp +11 -1
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/basic_regex.hpp +7 -1
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/basic_regex_creator.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/basic_regex_parser.hpp +5 -2
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/fileiter.hpp +0 -3
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/instances.hpp +15 -4
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/match_flags.hpp +1 -2
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/match_results.hpp +12 -3
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/perl_matcher.hpp +7 -2
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/perl_matcher_common.hpp +7 -3
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/perl_matcher_non_recursive.hpp +6 -2
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_format.hpp +0 -5
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_iterator.hpp +0 -8
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_raw_buffer.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_split.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_token_iterator.hpp +0 -8
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_traits_defaults.hpp +12 -11
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_workaround.hpp +7 -4
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/u32regex_iterator.hpp +1 -9
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/u32regex_token_iterator.hpp +2 -10
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/w32_regex_traits.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/allocate_shared_array.hpp +60 -115
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/local_counted_base.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_acc_ia64.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_aix.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_clang.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_cw_ppc.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_cw_x86.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_gcc_ia64.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_gcc_mips.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_gcc_ppc.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_gcc_sparc.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_gcc_x86.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_nt.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_pt.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_snc_ps3.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_solaris.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_spin.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_std_atomic.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_sync.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_vacpp_ppc.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_impl.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/yield_k.hpp +14 -8
- data/src/cxx_supportlib/vendor-modified/boost/system/config.hpp +4 -24
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/config.hpp +57 -0
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/generic_category.hpp +101 -0
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/std_interoperability.hpp +141 -0
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/system_category_posix.hpp +132 -0
- data/src/cxx_supportlib/vendor-modified/boost/system/error_code.hpp +775 -588
- data/src/cxx_supportlib/vendor-modified/boost/system/system_error.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/thread/detail/config.hpp +6 -0
- data/src/cxx_supportlib/vendor-modified/boost/thread/detail/move.hpp +13 -6
- data/src/cxx_supportlib/vendor-modified/boost/thread/detail/nullary_function.hpp +8 -3
- data/src/cxx_supportlib/vendor-modified/boost/thread/detail/thread.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/thread/detail/thread_safety.hpp +160 -0
- data/src/cxx_supportlib/vendor-modified/boost/thread/detail/tss_hooks.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/thread/exceptions.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/thread/executors/basic_thread_pool.hpp +24 -1
- data/src/cxx_supportlib/vendor-modified/boost/thread/future.hpp +10 -1
- data/src/cxx_supportlib/vendor-modified/boost/thread/lock_guard.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/thread/lockable_traits.hpp +31 -0
- data/src/cxx_supportlib/vendor-modified/boost/thread/pthread/condition_variable.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/thread/pthread/condition_variable_fwd.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/thread/pthread/mutex.hpp +8 -53
- data/src/cxx_supportlib/vendor-modified/boost/thread/pthread/pthread_mutex_scoped_lock.hpp +73 -4
- data/src/cxx_supportlib/vendor-modified/boost/thread/pthread/recursive_mutex.hpp +6 -6
- data/src/cxx_supportlib/vendor-modified/boost/thread/pthread/thread_data.hpp +14 -9
- data/src/cxx_supportlib/vendor-modified/boost/thread/xtime.hpp +6 -6
- data/src/cxx_supportlib/vendor-modified/boost/throw_exception.hpp +9 -8
- data/src/cxx_supportlib/vendor-modified/boost/token_functions.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_index/stl_type_index.hpp +21 -19
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detail/common_arithmetic_type.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detail/config.hpp +9 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detail/detector.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detail/has_postfix_operator.hpp +55 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detail/has_prefix_operator.hpp +72 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detail/is_function_cxx_03.hpp +108 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detail/is_function_cxx_11.hpp +501 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detail/is_function_msvc10_fix.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detail/is_likely_lambda.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detail/is_member_function_pointer_cxx_03.hpp +117 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detail/is_member_function_pointer_cxx_11.hpp +557 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detail/is_rvalue_reference_msvc10_fix.hpp +43 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detected.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detected_or.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/enable_if.hpp +37 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_dereference.hpp +344 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_minus.hpp +5 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_minus_assign.hpp +5 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_plus_assign.hpp +5 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_post_decrement.hpp +21 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_post_increment.hpp +21 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_pre_decrement.hpp +21 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_pre_increment.hpp +22 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_trivial_move_assign.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_trivial_move_constructor.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/integral_constant.hpp +5 -15
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/intrinsics.hpp +16 -6
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_complete.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_copy_assignable.hpp +3 -4
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_copy_constructible.hpp +4 -6
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_detected.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_detected_convertible.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_detected_exact.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_final.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_function.hpp +4 -79
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_member_function_pointer.hpp +3 -97
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_noncopyable.hpp +39 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_nothrow_move_assignable.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_nothrow_move_constructible.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_rvalue_reference.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_virtual_base_of.hpp +104 -63
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/make_void.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/nonesuch.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/typeof/constant.hpp +26 -0
- data/src/cxx_supportlib/vendor-modified/boost/typeof/dmc/typeof_impl.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/typeof/encode_decode.hpp +0 -3
- data/src/cxx_supportlib/vendor-modified/boost/typeof/encode_decode_params.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/typeof/int_encoding.hpp +4 -5
- data/src/cxx_supportlib/vendor-modified/boost/typeof/modifiers.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/typeof/msvc/typeof_impl.hpp +9 -9
- data/src/cxx_supportlib/vendor-modified/boost/typeof/native.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/typeof/pointers_data_members.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/typeof/register_functions_iterate.hpp +6 -6
- data/src/cxx_supportlib/vendor-modified/boost/typeof/register_mem_functions.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/typeof/template_encoding.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/typeof/template_template_param.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/typeof/type_encoding.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/typeof/typeof_impl.hpp +16 -16
- data/src/cxx_supportlib/vendor-modified/boost/typeof/vector.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/typeof/vector100.hpp +201 -201
- data/src/cxx_supportlib/vendor-modified/boost/typeof/vector150.hpp +301 -301
- data/src/cxx_supportlib/vendor-modified/boost/typeof/vector200.hpp +401 -401
- data/src/cxx_supportlib/vendor-modified/boost/typeof/vector50.hpp +101 -101
- data/src/cxx_supportlib/vendor-modified/boost/utility/detail/minstd_rand.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/utility/string_ref.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/utility/string_view.hpp +26 -6
- data/src/cxx_supportlib/vendor-modified/boost/version.hpp +2 -2
- data/src/nginx_module/ConfigGeneral/AutoGeneratedDefinitions.c +16 -0
- data/src/nginx_module/ConfigGeneral/AutoGeneratedManifestDefaultsInitialization.c +13 -0
- data/src/nginx_module/ConfigGeneral/AutoGeneratedSetterFuncs.c +24 -0
- data/src/nginx_module/Configuration.c +9 -0
- data/src/nginx_module/ContentHandler.c +7 -1
- data/src/nginx_module/LocationConfig/AutoGeneratedCreateFunction.c +5 -0
- data/src/nginx_module/LocationConfig/AutoGeneratedManifestGeneration.c +13 -0
- data/src/nginx_module/LocationConfig/AutoGeneratedMergeFunction.c +3 -0
- data/src/nginx_module/LocationConfig/AutoGeneratedStruct.h +4 -0
- data/src/nginx_module/MainConfig/AutoGeneratedCreateFunction.c +6 -0
- data/src/nginx_module/MainConfig/AutoGeneratedManifestGeneration.c +12 -0
- data/src/nginx_module/MainConfig/AutoGeneratedStruct.h +4 -0
- data/src/nginx_module/ngx_http_passenger_module.c +1 -0
- data/src/ruby_supportlib/phusion_passenger.rb +7 -7
- data/src/ruby_supportlib/phusion_passenger/apache2/config_options.rb +7 -0
- data/src/ruby_supportlib/phusion_passenger/nginx/config_options.rb +15 -0
- data/src/ruby_supportlib/phusion_passenger/request_handler.rb +2 -2
- data/src/ruby_supportlib/phusion_passenger/request_handler/thread_handler.rb +5 -0
- data/src/ruby_supportlib/phusion_passenger/standalone/start_command/builtin_engine.rb +1 -0
- metadata +33 -6
- data/src/cxx_supportlib/vendor-modified/boost/call_traits.hpp +0 -20
- data/src/cxx_supportlib/vendor-modified/boost/detail/call_traits.hpp +0 -172
- data/src/cxx_supportlib/vendor-modified/boost/detail/no_exceptions_support.hpp +0 -17
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/error_code.ipp +0 -496
@@ -0,0 +1,237 @@
|
|
1
|
+
/* boost random/sobol.hpp header file
|
2
|
+
*
|
3
|
+
* Copyright Justinas Vygintas Daugmaudis 2010-2018
|
4
|
+
* Distributed under the Boost Software License, Version 1.0. (See
|
5
|
+
* accompanying file LICENSE_1_0.txt or copy at
|
6
|
+
* http://www.boost.org/LICENSE_1_0.txt)
|
7
|
+
*/
|
8
|
+
|
9
|
+
#ifndef BOOST_RANDOM_SOBOL_HPP
|
10
|
+
#define BOOST_RANDOM_SOBOL_HPP
|
11
|
+
|
12
|
+
#include <boost/random/detail/sobol_table.hpp>
|
13
|
+
#include <boost/random/detail/gray_coded_qrng.hpp>
|
14
|
+
|
15
|
+
namespace boost {
|
16
|
+
namespace random {
|
17
|
+
|
18
|
+
/** @cond */
|
19
|
+
namespace qrng_detail {
|
20
|
+
|
21
|
+
// sobol_lattice sets up the random-number generator to produce a Sobol
|
22
|
+
// sequence of at most max dims-dimensional quasi-random vectors.
|
23
|
+
// Adapted from ACM TOMS algorithm 659, see
|
24
|
+
|
25
|
+
// http://doi.acm.org/10.1145/42288.214372
|
26
|
+
|
27
|
+
template<typename UIntType, unsigned w, typename SobolTables>
|
28
|
+
struct sobol_lattice
|
29
|
+
{
|
30
|
+
typedef UIntType value_type;
|
31
|
+
|
32
|
+
BOOST_STATIC_ASSERT(w > 0u);
|
33
|
+
BOOST_STATIC_CONSTANT(unsigned, bit_count = w);
|
34
|
+
|
35
|
+
private:
|
36
|
+
typedef std::vector<value_type> container_type;
|
37
|
+
|
38
|
+
public:
|
39
|
+
explicit sobol_lattice(std::size_t dimension)
|
40
|
+
{
|
41
|
+
resize(dimension);
|
42
|
+
}
|
43
|
+
|
44
|
+
// default copy c-tor is fine
|
45
|
+
|
46
|
+
void resize(std::size_t dimension)
|
47
|
+
{
|
48
|
+
dimension_assert("Sobol", dimension, SobolTables::max_dimension);
|
49
|
+
|
50
|
+
// Initialize the bit array
|
51
|
+
container_type cj(bit_count * dimension);
|
52
|
+
|
53
|
+
// Initialize direction table in dimension 0
|
54
|
+
for (unsigned k = 0; k != bit_count; ++k)
|
55
|
+
cj[dimension*k] = static_cast<value_type>(1);
|
56
|
+
|
57
|
+
// Initialize in remaining dimensions.
|
58
|
+
for (std::size_t dim = 1; dim < dimension; ++dim)
|
59
|
+
{
|
60
|
+
const typename SobolTables::value_type poly = SobolTables::polynomial(dim-1);
|
61
|
+
if (poly > std::numeric_limits<value_type>::max()) {
|
62
|
+
boost::throw_exception( std::range_error("sobol: polynomial value outside the given value type range") );
|
63
|
+
}
|
64
|
+
const unsigned degree = multiprecision::msb(poly); // integer log2(poly)
|
65
|
+
|
66
|
+
// set initial values of m from table
|
67
|
+
for (unsigned k = 0; k != degree; ++k)
|
68
|
+
cj[dimension*k + dim] = SobolTables::minit(dim-1, k);
|
69
|
+
|
70
|
+
// Calculate remaining elements for this dimension,
|
71
|
+
// as explained in Bratley+Fox, section 2.
|
72
|
+
for (unsigned j = degree; j < bit_count; ++j)
|
73
|
+
{
|
74
|
+
typename SobolTables::value_type p_i = poly;
|
75
|
+
const std::size_t bit_offset = dimension*j + dim;
|
76
|
+
|
77
|
+
cj[bit_offset] = cj[dimension*(j-degree) + dim];
|
78
|
+
for (unsigned k = 0; k != degree; ++k, p_i >>= 1)
|
79
|
+
{
|
80
|
+
int rem = degree - k;
|
81
|
+
cj[bit_offset] ^= ((p_i & 1) * cj[dimension*(j-rem) + dim]) << rem;
|
82
|
+
}
|
83
|
+
}
|
84
|
+
}
|
85
|
+
|
86
|
+
// Shift columns by appropriate power of 2.
|
87
|
+
unsigned p = 1u;
|
88
|
+
for (int j = bit_count-1-1; j >= 0; --j, ++p)
|
89
|
+
{
|
90
|
+
const std::size_t bit_offset = dimension * j;
|
91
|
+
for (std::size_t dim = 0; dim != dimension; ++dim)
|
92
|
+
cj[bit_offset + dim] <<= p;
|
93
|
+
}
|
94
|
+
|
95
|
+
bits.swap(cj);
|
96
|
+
}
|
97
|
+
|
98
|
+
typename container_type::const_iterator iter_at(std::size_t n) const
|
99
|
+
{
|
100
|
+
BOOST_ASSERT(!(n > bits.size()));
|
101
|
+
return bits.begin() + n;
|
102
|
+
}
|
103
|
+
|
104
|
+
private:
|
105
|
+
container_type bits;
|
106
|
+
};
|
107
|
+
|
108
|
+
} // namespace qrng_detail
|
109
|
+
|
110
|
+
typedef detail::qrng_tables::sobol default_sobol_table;
|
111
|
+
|
112
|
+
/** @endcond */
|
113
|
+
|
114
|
+
//!Instantiations of class template sobol_engine model a \quasi_random_number_generator.
|
115
|
+
//!The sobol_engine uses the algorithm described in
|
116
|
+
//! \blockquote
|
117
|
+
//![Bratley+Fox, TOMS 14, 88 (1988)]
|
118
|
+
//!and [Antonov+Saleev, USSR Comput. Maths. Math. Phys. 19, 252 (1980)]
|
119
|
+
//! \endblockquote
|
120
|
+
//!
|
121
|
+
//!\attention sobol_engine skips trivial zeroes at the start of the sequence. For example, the beginning
|
122
|
+
//!of the 2-dimensional Sobol sequence in @c uniform_01 distribution will look like this:
|
123
|
+
//!\code{.cpp}
|
124
|
+
//!0.5, 0.5,
|
125
|
+
//!0.75, 0.25,
|
126
|
+
//!0.25, 0.75,
|
127
|
+
//!0.375, 0.375,
|
128
|
+
//!0.875, 0.875,
|
129
|
+
//!...
|
130
|
+
//!\endcode
|
131
|
+
//!
|
132
|
+
//!In the following documentation @c X denotes the concrete class of the template
|
133
|
+
//!sobol_engine returning objects of type @c UIntType, u and v are the values of @c X.
|
134
|
+
//!
|
135
|
+
//!Some member functions may throw exceptions of type @c std::range_error. This
|
136
|
+
//!happens when the quasi-random domain is exhausted and the generator cannot produce
|
137
|
+
//!any more values. The length of the low discrepancy sequence is given by \f$L=Dimension \times (2^{w} - 1)\f$.
|
138
|
+
template<typename UIntType, unsigned w, typename SobolTables = default_sobol_table>
|
139
|
+
class sobol_engine
|
140
|
+
: public qrng_detail::gray_coded_qrng<
|
141
|
+
qrng_detail::sobol_lattice<UIntType, w, SobolTables>
|
142
|
+
>
|
143
|
+
{
|
144
|
+
typedef qrng_detail::sobol_lattice<UIntType, w, SobolTables> lattice_t;
|
145
|
+
typedef qrng_detail::gray_coded_qrng<lattice_t> base_t;
|
146
|
+
|
147
|
+
public:
|
148
|
+
//!Effects: Constructs the default `s`-dimensional Sobol quasi-random number generator.
|
149
|
+
//!
|
150
|
+
//!Throws: bad_alloc, invalid_argument, range_error.
|
151
|
+
explicit sobol_engine(std::size_t s)
|
152
|
+
: base_t(s)
|
153
|
+
{}
|
154
|
+
|
155
|
+
// default copy c-tor is fine
|
156
|
+
|
157
|
+
#ifdef BOOST_RANDOM_DOXYGEN
|
158
|
+
//=========================Doxygen needs this!==============================
|
159
|
+
typedef UIntType result_type;
|
160
|
+
|
161
|
+
/** @copydoc boost::random::niederreiter_base2_engine::min() */
|
162
|
+
static BOOST_CONSTEXPR result_type min BOOST_PREVENT_MACRO_SUBSTITUTION ()
|
163
|
+
{ return (base_t::min)(); }
|
164
|
+
|
165
|
+
/** @copydoc boost::random::niederreiter_base2_engine::max() */
|
166
|
+
static BOOST_CONSTEXPR result_type max BOOST_PREVENT_MACRO_SUBSTITUTION ()
|
167
|
+
{ return (base_t::max)(); }
|
168
|
+
|
169
|
+
/** @copydoc boost::random::niederreiter_base2_engine::dimension() */
|
170
|
+
std::size_t dimension() const { return base_t::dimension(); }
|
171
|
+
|
172
|
+
/** @copydoc boost::random::niederreiter_base2_engine::seed() */
|
173
|
+
void seed()
|
174
|
+
{
|
175
|
+
base_t::seed();
|
176
|
+
}
|
177
|
+
|
178
|
+
/** @copydoc boost::random::niederreiter_base2_engine::seed(UIntType) */
|
179
|
+
void seed(UIntType init)
|
180
|
+
{
|
181
|
+
base_t::seed(init);
|
182
|
+
}
|
183
|
+
|
184
|
+
/** @copydoc boost::random::niederreiter_base2_engine::operator()() */
|
185
|
+
result_type operator()()
|
186
|
+
{
|
187
|
+
return base_t::operator()();
|
188
|
+
}
|
189
|
+
|
190
|
+
/** @copydoc boost::random::niederreiter_base2_engine::discard(boost::uintmax_t) */
|
191
|
+
void discard(boost::uintmax_t z)
|
192
|
+
{
|
193
|
+
base_t::discard(z);
|
194
|
+
}
|
195
|
+
|
196
|
+
/** Returns true if the two generators will produce identical sequences of outputs. */
|
197
|
+
BOOST_RANDOM_DETAIL_EQUALITY_OPERATOR(sobol_engine, x, y)
|
198
|
+
{ return static_cast<const base_t&>(x) == y; }
|
199
|
+
|
200
|
+
/** Returns true if the two generators will produce different sequences of outputs. */
|
201
|
+
BOOST_RANDOM_DETAIL_INEQUALITY_OPERATOR(sobol_engine)
|
202
|
+
|
203
|
+
/** Writes the textual representation of the generator to a @c std::ostream. */
|
204
|
+
BOOST_RANDOM_DETAIL_OSTREAM_OPERATOR(os, sobol_engine, s)
|
205
|
+
{ return os << static_cast<const base_t&>(s); }
|
206
|
+
|
207
|
+
/** Reads the textual representation of the generator from a @c std::istream. */
|
208
|
+
BOOST_RANDOM_DETAIL_ISTREAM_OPERATOR(is, sobol_engine, s)
|
209
|
+
{ return is >> static_cast<base_t&>(s); }
|
210
|
+
|
211
|
+
#endif // BOOST_RANDOM_DOXYGEN
|
212
|
+
};
|
213
|
+
|
214
|
+
/**
|
215
|
+
* @attention This specialization of \sobol_engine supports up to 3667 dimensions.
|
216
|
+
*
|
217
|
+
* Data on the primitive binary polynomials `a` and the corresponding starting values `m`
|
218
|
+
* for Sobol sequences in up to 21201 dimensions was taken from
|
219
|
+
*
|
220
|
+
* @blockquote
|
221
|
+
* S. Joe and F. Y. Kuo, Constructing Sobol sequences with better two-dimensional projections,
|
222
|
+
* SIAM J. Sci. Comput. 30, 2635-2654 (2008).
|
223
|
+
* @endblockquote
|
224
|
+
*
|
225
|
+
* See the original tables up to dimension 21201: https://web.archive.org/web/20170802022909/http://web.maths.unsw.edu.au/~fkuo/sobol/new-joe-kuo-6.21201
|
226
|
+
*
|
227
|
+
* For practical reasons the default table uses only the subset of binary polynomials `a` < 2<sup>16</sup>.
|
228
|
+
*
|
229
|
+
* However, it is possible to provide your own table to \sobol_engine should the default one be insufficient.
|
230
|
+
*/
|
231
|
+
typedef sobol_engine<boost::uint_least64_t, 64u, default_sobol_table> sobol;
|
232
|
+
|
233
|
+
} // namespace random
|
234
|
+
|
235
|
+
} // namespace boost
|
236
|
+
|
237
|
+
#endif // BOOST_RANDOM_SOBOL_HPP
|
@@ -25,6 +25,11 @@
|
|
25
25
|
#include <boost/detail/workaround.hpp>
|
26
26
|
|
27
27
|
#include <cstring>
|
28
|
+
|
29
|
+
#if !defined(BOOST_NO_CXX11_CHAR16_T) || !defined(BOOST_NO_CXX11_CHAR32_T)
|
30
|
+
#include <string> // for std::char_traits
|
31
|
+
#endif
|
32
|
+
|
28
33
|
#ifndef BOOST_NO_CWCHAR
|
29
34
|
#include <cwchar>
|
30
35
|
#endif
|
@@ -38,6 +43,20 @@ namespace boost
|
|
38
43
|
return strlen( s );
|
39
44
|
}
|
40
45
|
|
46
|
+
#ifndef BOOST_NO_CXX11_CHAR16_T
|
47
|
+
inline std::size_t length( const char16_t* s )
|
48
|
+
{
|
49
|
+
return std::char_traits<char16_t>::length( s );
|
50
|
+
}
|
51
|
+
#endif
|
52
|
+
|
53
|
+
#ifndef BOOST_NO_CXX11_CHAR32_T
|
54
|
+
inline std::size_t length( const char32_t* s )
|
55
|
+
{
|
56
|
+
return std::char_traits<char32_t>::length( s );
|
57
|
+
}
|
58
|
+
#endif
|
59
|
+
|
41
60
|
#ifndef BOOST_NO_CWCHAR
|
42
61
|
inline std::size_t length( const wchar_t* s )
|
43
62
|
{
|
@@ -61,6 +80,30 @@ namespace boost
|
|
61
80
|
return true;
|
62
81
|
}
|
63
82
|
|
83
|
+
#ifndef BOOST_NO_CXX11_CHAR16_T
|
84
|
+
inline bool is_char_ptr( char16_t* )
|
85
|
+
{
|
86
|
+
return true;
|
87
|
+
}
|
88
|
+
|
89
|
+
inline bool is_char_ptr( const char16_t* )
|
90
|
+
{
|
91
|
+
return true;
|
92
|
+
}
|
93
|
+
#endif
|
94
|
+
|
95
|
+
#ifndef BOOST_NO_CXX11_CHAR32_T
|
96
|
+
inline bool is_char_ptr( char32_t* )
|
97
|
+
{
|
98
|
+
return true;
|
99
|
+
}
|
100
|
+
|
101
|
+
inline bool is_char_ptr( const char32_t* )
|
102
|
+
{
|
103
|
+
return true;
|
104
|
+
}
|
105
|
+
#endif
|
106
|
+
|
64
107
|
#ifndef BOOST_NO_CWCHAR
|
65
108
|
inline bool is_char_ptr( wchar_t* )
|
66
109
|
{
|
@@ -22,6 +22,8 @@
|
|
22
22
|
#else
|
23
23
|
|
24
24
|
#include <boost/range/iterator.hpp>
|
25
|
+
#include <boost/config.hpp>
|
26
|
+
#include <boost/config/workaround.hpp>
|
25
27
|
|
26
28
|
namespace boost
|
27
29
|
{
|
@@ -36,7 +38,7 @@ namespace range_detail
|
|
36
38
|
//////////////////////////////////////////////////////////////////////
|
37
39
|
|
38
40
|
template< typename C >
|
39
|
-
inline BOOST_DEDUCED_TYPENAME range_iterator<C>::type
|
41
|
+
BOOST_CONSTEXPR inline BOOST_DEDUCED_TYPENAME range_iterator<C>::type
|
40
42
|
range_begin( C& c )
|
41
43
|
{
|
42
44
|
//
|
@@ -52,13 +54,13 @@ namespace range_detail
|
|
52
54
|
//////////////////////////////////////////////////////////////////////
|
53
55
|
|
54
56
|
template< typename Iterator >
|
55
|
-
inline Iterator range_begin( const std::pair<Iterator,Iterator>& p )
|
57
|
+
BOOST_CONSTEXPR inline Iterator range_begin( const std::pair<Iterator,Iterator>& p )
|
56
58
|
{
|
57
59
|
return p.first;
|
58
60
|
}
|
59
61
|
|
60
62
|
template< typename Iterator >
|
61
|
-
inline Iterator range_begin( std::pair<Iterator,Iterator>& p )
|
63
|
+
BOOST_CONSTEXPR inline Iterator range_begin( std::pair<Iterator,Iterator>& p )
|
62
64
|
{
|
63
65
|
return p.first;
|
64
66
|
}
|
@@ -71,13 +73,13 @@ namespace range_detail
|
|
71
73
|
// May this be discarded? Or is it needed for bad compilers?
|
72
74
|
//
|
73
75
|
template< typename T, std::size_t sz >
|
74
|
-
inline const T* range_begin( const T (&a)[sz] )
|
76
|
+
BOOST_CONSTEXPR inline const T* range_begin( const T (&a)[sz] ) BOOST_NOEXCEPT
|
75
77
|
{
|
76
78
|
return a;
|
77
79
|
}
|
78
80
|
|
79
81
|
template< typename T, std::size_t sz >
|
80
|
-
inline T* range_begin( T (&a)[sz] )
|
82
|
+
BOOST_CONSTEXPR inline T* range_begin( T (&a)[sz] ) BOOST_NOEXCEPT
|
81
83
|
{
|
82
84
|
return a;
|
83
85
|
}
|
@@ -94,6 +96,9 @@ namespace range_adl_barrier
|
|
94
96
|
{
|
95
97
|
|
96
98
|
template< class T >
|
99
|
+
#if !BOOST_WORKAROUND(BOOST_GCC, < 40700)
|
100
|
+
BOOST_CONSTEXPR
|
101
|
+
#endif
|
97
102
|
inline BOOST_DEDUCED_TYPENAME range_iterator<T>::type begin( T& r )
|
98
103
|
{
|
99
104
|
#if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x564))
|
@@ -103,6 +108,9 @@ inline BOOST_DEDUCED_TYPENAME range_iterator<T>::type begin( T& r )
|
|
103
108
|
}
|
104
109
|
|
105
110
|
template< class T >
|
111
|
+
#if !BOOST_WORKAROUND(BOOST_GCC, < 40700)
|
112
|
+
BOOST_CONSTEXPR
|
113
|
+
#endif
|
106
114
|
inline BOOST_DEDUCED_TYPENAME range_iterator<const T>::type begin( const T& r )
|
107
115
|
{
|
108
116
|
#if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x564))
|
@@ -252,7 +252,7 @@ namespace boost {
|
|
252
252
|
n = i - j;
|
253
253
|
}
|
254
254
|
private:
|
255
|
-
BOOST_DEDUCED_TYPENAME
|
255
|
+
BOOST_DEDUCED_TYPENAME BidirectionalIteratorConcept<Iterator>::difference_type n;
|
256
256
|
Iterator i;
|
257
257
|
Iterator j;
|
258
258
|
#endif
|
@@ -18,10 +18,8 @@
|
|
18
18
|
#include <boost/range/config.hpp>
|
19
19
|
#include <boost/range/detail/sfinae.hpp>
|
20
20
|
#include <boost/type_traits/is_void.hpp>
|
21
|
-
#include <boost/mpl/bool.hpp>
|
22
21
|
#include <boost/mpl/if.hpp>
|
23
22
|
#include <boost/mpl/int.hpp>
|
24
|
-
#include <boost/mpl/or.hpp>
|
25
23
|
#include <cstddef>
|
26
24
|
|
27
25
|
//////////////////////////////////////////////////////////////////////////////
|
@@ -71,7 +69,7 @@ namespace boost
|
|
71
69
|
BOOST_STATIC_CONSTANT( bool, is_const_wchar_t_ptr_ = sizeof( boost::range_detail::is_const_wchar_t_ptr_impl( ptr ) ) == sizeof( yes_type ) );
|
72
70
|
BOOST_STATIC_CONSTANT( bool, is_char_array_ = sizeof( boost::range_detail::is_char_array_impl( ptr ) ) == sizeof( yes_type ) );
|
73
71
|
BOOST_STATIC_CONSTANT( bool, is_wchar_t_array_ = sizeof( boost::range_detail::is_wchar_t_array_impl( ptr ) ) == sizeof( yes_type ) );
|
74
|
-
BOOST_STATIC_CONSTANT( bool, is_string_ = (
|
72
|
+
BOOST_STATIC_CONSTANT( bool, is_string_ = (is_const_char_ptr_ || is_const_wchar_t_ptr_));
|
75
73
|
BOOST_STATIC_CONSTANT( bool, is_array_ = boost::is_array<C>::value );
|
76
74
|
|
77
75
|
};
|
@@ -60,13 +60,13 @@ namespace boost
|
|
60
60
|
}
|
61
61
|
|
62
62
|
template< class T, std::size_t sz >
|
63
|
-
inline T* array_end( T BOOST_RANGE_ARRAY_REF()[sz] )
|
63
|
+
BOOST_CONSTEXPR inline T* array_end( T BOOST_RANGE_ARRAY_REF()[sz] ) BOOST_NOEXCEPT
|
64
64
|
{
|
65
65
|
return boost_range_array + sz;
|
66
66
|
}
|
67
67
|
|
68
68
|
template< class T, std::size_t sz >
|
69
|
-
inline const T* array_end( const T BOOST_RANGE_ARRAY_REF()[sz] )
|
69
|
+
BOOST_CONSTEXPR inline const T* array_end( const T BOOST_RANGE_ARRAY_REF()[sz] ) BOOST_NOEXCEPT
|
70
70
|
{
|
71
71
|
return boost_range_array + sz;
|
72
72
|
}
|
@@ -15,20 +15,26 @@
|
|
15
15
|
# pragma once
|
16
16
|
#endif
|
17
17
|
|
18
|
+
#include <boost/iterator/distance.hpp>
|
18
19
|
#include <boost/range/begin.hpp>
|
19
20
|
#include <boost/range/end.hpp>
|
20
21
|
#include <boost/range/difference_type.hpp>
|
21
22
|
|
22
|
-
namespace boost
|
23
|
+
namespace boost
|
23
24
|
{
|
24
25
|
|
25
|
-
|
26
|
-
inline BOOST_DEDUCED_TYPENAME range_difference<T>::type
|
27
|
-
distance( const T& r )
|
26
|
+
namespace range_distance_adl_barrier
|
28
27
|
{
|
29
|
-
|
28
|
+
template< class T >
|
29
|
+
inline BOOST_CXX14_CONSTEXPR BOOST_DEDUCED_TYPENAME range_difference<T>::type
|
30
|
+
distance( const T& r )
|
31
|
+
{
|
32
|
+
return boost::iterators::distance( boost::begin( r ), boost::end( r ) );
|
33
|
+
}
|
30
34
|
}
|
31
35
|
|
36
|
+
using namespace range_distance_adl_barrier;
|
37
|
+
|
32
38
|
} // namespace 'boost'
|
33
39
|
|
34
40
|
#endif
|
@@ -24,6 +24,8 @@
|
|
24
24
|
#include <boost/range/detail/implementation_help.hpp>
|
25
25
|
#include <boost/range/iterator.hpp>
|
26
26
|
#include <boost/range/const_iterator.hpp>
|
27
|
+
#include <boost/config.hpp>
|
28
|
+
#include <boost/config/workaround.hpp>
|
27
29
|
|
28
30
|
namespace boost
|
29
31
|
{
|
@@ -37,7 +39,7 @@ namespace range_detail
|
|
37
39
|
// primary template
|
38
40
|
//////////////////////////////////////////////////////////////////////
|
39
41
|
template< typename C >
|
40
|
-
inline BOOST_DEDUCED_TYPENAME range_iterator<C>::type
|
42
|
+
BOOST_CONSTEXPR inline BOOST_DEDUCED_TYPENAME range_iterator<C>::type
|
41
43
|
range_end( C& c )
|
42
44
|
{
|
43
45
|
//
|
@@ -53,13 +55,13 @@ namespace range_detail
|
|
53
55
|
//////////////////////////////////////////////////////////////////////
|
54
56
|
|
55
57
|
template< typename Iterator >
|
56
|
-
inline Iterator range_end( const std::pair<Iterator,Iterator>& p )
|
58
|
+
BOOST_CONSTEXPR inline Iterator range_end( const std::pair<Iterator,Iterator>& p )
|
57
59
|
{
|
58
60
|
return p.second;
|
59
61
|
}
|
60
62
|
|
61
63
|
template< typename Iterator >
|
62
|
-
inline Iterator range_end( std::pair<Iterator,Iterator>& p )
|
64
|
+
BOOST_CONSTEXPR inline Iterator range_end( std::pair<Iterator,Iterator>& p )
|
63
65
|
{
|
64
66
|
return p.second;
|
65
67
|
}
|
@@ -69,13 +71,13 @@ namespace range_detail
|
|
69
71
|
//////////////////////////////////////////////////////////////////////
|
70
72
|
|
71
73
|
template< typename T, std::size_t sz >
|
72
|
-
inline const T* range_end( const T (&a)[sz] )
|
74
|
+
BOOST_CONSTEXPR inline const T* range_end( const T (&a)[sz] ) BOOST_NOEXCEPT
|
73
75
|
{
|
74
76
|
return range_detail::array_end<T,sz>( a );
|
75
77
|
}
|
76
78
|
|
77
79
|
template< typename T, std::size_t sz >
|
78
|
-
inline T* range_end( T (&a)[sz] )
|
80
|
+
BOOST_CONSTEXPR inline T* range_end( T (&a)[sz] ) BOOST_NOEXCEPT
|
79
81
|
{
|
80
82
|
return range_detail::array_end<T,sz>( a );
|
81
83
|
}
|
@@ -88,6 +90,9 @@ namespace range_adl_barrier
|
|
88
90
|
{
|
89
91
|
|
90
92
|
template< class T >
|
93
|
+
#if !BOOST_WORKAROUND(BOOST_GCC, < 40700)
|
94
|
+
BOOST_CONSTEXPR
|
95
|
+
#endif
|
91
96
|
inline BOOST_DEDUCED_TYPENAME range_iterator<T>::type end( T& r )
|
92
97
|
{
|
93
98
|
#if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x564))
|
@@ -97,6 +102,9 @@ inline BOOST_DEDUCED_TYPENAME range_iterator<T>::type end( T& r )
|
|
97
102
|
}
|
98
103
|
|
99
104
|
template< class T >
|
105
|
+
#if !BOOST_WORKAROUND(BOOST_GCC, < 40700)
|
106
|
+
BOOST_CONSTEXPR
|
107
|
+
#endif
|
100
108
|
inline BOOST_DEDUCED_TYPENAME range_iterator<const T>::type end( const T& r )
|
101
109
|
{
|
102
110
|
#if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x564))
|
@@ -115,7 +123,7 @@ namespace boost
|
|
115
123
|
namespace range_adl_barrier
|
116
124
|
{
|
117
125
|
template< class T >
|
118
|
-
inline BOOST_DEDUCED_TYPENAME range_iterator<const T>::type
|
126
|
+
BOOST_CONSTEXPR inline BOOST_DEDUCED_TYPENAME range_iterator<const T>::type
|
119
127
|
const_end( const T& r )
|
120
128
|
{
|
121
129
|
return boost::range_adl_barrier::end( r );
|