diff --git a/.cspell/cspell.json b/.cspell/cspell.json index f950ccb84..bc954cd71 100644 --- a/.cspell/cspell.json +++ b/.cspell/cspell.json @@ -168,7 +168,10 @@ "trilcol", "mvnormlogpdf", "mvnormals", - "Optimise" + "Optimise", + "xlabel", + "ylabel", + "optimising" ], "ignoreWords": [], "minWordLength": 5, @@ -193,4 +196,4 @@ "\\{%.*%\\}", // liquid syntax "/^\\s*```[\\s\\S]*?^\\s*```/gm" // Another attempt at markdown code blocks. https://github.com/streetsidesoftware/vscode-spell-checker/issues/202#issuecomment-377477473 ] -} +} \ No newline at end of file diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 90b9b06c7..c68a5cdb9 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -77,6 +77,8 @@ jobs: run: | julia --color=yes -e ' using Pkg; + Pkg.develop(path="src/ReinforcementLearningBase") + Pkg.develop(path="src/ReinforcementLearningEnvironments") Pkg.develop(path="src/ReinforcementLearningCore") Pkg.test("ReinforcementLearningCore")' @@ -90,6 +92,9 @@ jobs: run: | julia --color=yes -e ' using Pkg; + Pkg.develop(path="src/ReinforcementLearningBase") + Pkg.develop(path="src/ReinforcementLearningEnvironments") + Pkg.develop(path="src/ReinforcementLearningCore") Pkg.develop(path="src/ReinforcementLearningZoo") Pkg.test("ReinforcementLearningZoo")' @@ -103,6 +108,7 @@ jobs: run: | julia --color=yes -e ' using Pkg; + Pkg.develop(path="src/ReinforcementLearningBase") Pkg.develop(path="src/ReinforcementLearningEnvironments") Pkg.test("ReinforcementLearningEnvironments")' @@ -111,13 +117,13 @@ jobs: with: paths: src/ReinforcementLearningDatasets - - name: Test RLDatasets - if: (steps.RLDatasets-changed.outputs.changed == 'true') || (contains(github.event.pull_request.labels.*.name, 'Integration Test')) - run: | - julia --color=yes -e ' - using Pkg; - Pkg.develop(path="src/ReinforcementLearningDatasets") - Pkg.test("ReinforcementLearningDatasets")' + # - name: Test RLDatasets + # if: (steps.RLDatasets-changed.outputs.changed == 'true') || (contains(github.event.pull_request.labels.*.name, 'Integration Test')) + # run: | + # julia --color=yes -e ' + # using Pkg; + # Pkg.develop(path="src/ReinforcementLearningDatasets") + # Pkg.test("ReinforcementLearningDatasets")' - uses: marceloprado/has-changed-path@v1 id: RLExperiments-changed @@ -129,56 +135,61 @@ jobs: run: | julia --color=yes -e ' using Pkg; + Pkg.develop(path="src/ReinforcementLearningBase") + Pkg.develop(path="src/ReinforcementLearningEnvironments") + Pkg.develop(path="src/ReinforcementLearningCore") + Pkg.develop(path="src/ReinforcementLearningZoo") + Pkg.develop(path=".") Pkg.develop(path="src/ReinforcementLearningExperiments") Pkg.build("ReinforcementLearningExperiments") Pkg.test("ReinforcementLearningExperiments")' - docs: - name: Documentation - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - name: Setup python - uses: actions/setup-python@v1 - with: - python-version: ${{ matrix.python-version }} - architecture: ${{ matrix.arch }} - - run: python -m pip install --user matplotlib - - uses: julia-actions/setup-julia@v1 - with: - version: '1.6' - - name: Build homepage - run: | - cd docs/homepage - julia --project --color=yes -e ' - using Pkg; Pkg.instantiate(); - using NodeJS; run(`$(npm_cmd()) install highlight.js`); - using Franklin; - optimize()' > build.log - - - name: Make sure homepage is generated without error - run: | - if grep -1 "Franklin Warning" build.log; then - echo "Franklin reported a warning" - exit 1 - else - echo "Franklin did not report a warning" - fi - - - name: Build docs - run: | - cd docs - julia --project --color=yes -e ' - using Pkg; Pkg.instantiate(); - include("make.jl")' - mv build homepage/__site/docs - - - name: Deploy to the main repo - uses: peaceiris/actions-gh-pages@v3 - if: ${{ github.event_name == 'push' }} - with: - deploy_key: ${{ secrets.ACTIONS_DEPLOY_KEY }} - external_repository: JuliaReinforcementLearning/JuliaReinforcementLearning.github.io - force_orphan: true - publish_branch: master - publish_dir: ./docs/homepage/__site + # docs: + # name: Documentation + # runs-on: ubuntu-latest + # steps: + # - uses: actions/checkout@v2 + # - name: Setup python + # uses: actions/setup-python@v1 + # with: + # python-version: ${{ matrix.python-version }} + # architecture: ${{ matrix.arch }} + # - run: python -m pip install --user matplotlib + # - uses: julia-actions/setup-julia@v1 + # with: + # version: '1.6' + # - name: Build homepage + # run: | + # cd docs/homepage + # julia --project --color=yes -e ' + # using Pkg; Pkg.instantiate(); + # using NodeJS; run(`$(npm_cmd()) install highlight.js`); + # using Franklin; + # optimize()' > build.log + + # - name: Make sure homepage is generated without error + # run: | + # if grep -1 "Franklin Warning" build.log; then + # echo "Franklin reported a warning" + # exit 1 + # else + # echo "Franklin did not report a warning" + # fi + + # - name: Build docs + # run: | + # cd docs + # julia --project --color=yes -e ' + # using Pkg; Pkg.instantiate(); + # include("make.jl")' + # mv build homepage/__site/docs + + # - name: Deploy to the main repo + # uses: peaceiris/actions-gh-pages@v3 + # if: ${{ github.event_name == 'push' }} + # with: + # deploy_key: ${{ secrets.ACTIONS_DEPLOY_KEY }} + # external_repository: JuliaReinforcementLearning/JuliaReinforcementLearning.github.io + # force_orphan: true + # publish_branch: master + # publish_dir: ./docs/homepage/__site diff --git a/.gitignore b/.gitignore index 3c6ca223f..84c7d23c7 100644 --- a/.gitignore +++ b/.gitignore @@ -31,7 +31,7 @@ docs/experiments # It records a fixed state of all packages used by the project. As such, it should not be # committed for packages, but should be committed for applications that require a static # environment. -# Manifest.toml +Manifest.toml .vscode/* diff --git a/Manifest.toml b/Manifest.toml deleted file mode 100644 index 1cc5c6599..000000000 --- a/Manifest.toml +++ /dev/null @@ -1,726 +0,0 @@ -# This file is machine-generated - editing it directly is not advised - -julia_version = "1.7.1" -manifest_format = "2.0" - -[[deps.AbstractFFTs]] -deps = ["ChainRulesCore", "LinearAlgebra"] -git-tree-sha1 = "6f1d9bc1c08f9f4a8fa92e3ea3cb50153a1b40d4" -uuid = "621f4979-c628-5d54-868e-fcf4e3e8185c" -version = "1.1.0" - -[[deps.AbstractTrees]] -git-tree-sha1 = "03e0550477d86222521d254b741d470ba17ea0b5" -uuid = "1520ce14-60c1-5f80-bbc7-55ef81b5835c" -version = "0.3.4" - -[[deps.Adapt]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "af92965fb30777147966f58acb05da51c5616b5f" -uuid = "79e6a3ab-5dfb-504d-930d-738a2a938a0e" -version = "3.3.3" - -[[deps.ArgTools]] -uuid = "0dad84c5-d112-42e6-8d28-ef12dabb789f" - -[[deps.ArrayInterface]] -deps = ["Compat", "IfElse", "LinearAlgebra", "Requires", "SparseArrays", "Static"] -git-tree-sha1 = "6e8fada11bb015ecf9263f64b156f98b546918c7" -uuid = "4fba245c-0d91-5ea0-9b3e-6abc04ee57a9" -version = "5.0.5" - -[[deps.Artifacts]] -uuid = "56f22d72-fd6d-98f1-02f0-08ddc0907c33" - -[[deps.BFloat16s]] -deps = ["LinearAlgebra", "Printf", "Random", "Test"] -git-tree-sha1 = "a598ecb0d717092b5539dbbe890c98bac842b072" -uuid = "ab4f0b2a-ad5b-11e8-123f-65d77653426b" -version = "0.2.0" - -[[deps.Base64]] -uuid = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f" - -[[deps.CEnum]] -git-tree-sha1 = "215a9aa4a1f23fbd05b92769fdd62559488d70e9" -uuid = "fa961155-64e5-5f13-b03f-caf6b980ea82" -version = "0.4.1" - -[[deps.CUDA]] -deps = ["AbstractFFTs", "Adapt", "BFloat16s", "CEnum", "CompilerSupportLibraries_jll", "ExprTools", "GPUArrays", "GPUCompiler", "LLVM", "LazyArtifacts", "Libdl", "LinearAlgebra", "Logging", "Printf", "Random", "Random123", "RandomNumbers", "Reexport", "Requires", "SparseArrays", "SpecialFunctions", "TimerOutputs"] -git-tree-sha1 = "a28686d7c83026069cc2505016269cca77506ed3" -uuid = "052768ef-5323-5732-b1bb-66c8b64840ba" -version = "3.8.5" - -[[deps.Calculus]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "f641eb0a4f00c343bbc32346e1217b86f3ce9dad" -uuid = "49dc2e85-a5d0-5ad3-a950-438e2897f1b9" -version = "0.5.1" - -[[deps.ChainRules]] -deps = ["ChainRulesCore", "Compat", "IrrationalConstants", "LinearAlgebra", "Random", "RealDot", "SparseArrays", "Statistics"] -git-tree-sha1 = "8b887daa6af5daf705081061e36386190204ac87" -uuid = "082447d4-558c-5d27-93f4-14fc19e9eca2" -version = "1.28.1" - -[[deps.ChainRulesCore]] -deps = ["Compat", "LinearAlgebra", "SparseArrays"] -git-tree-sha1 = "c9a6160317d1abe9c44b3beb367fd448117679ca" -uuid = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4" -version = "1.13.0" - -[[deps.ChangesOfVariables]] -deps = ["ChainRulesCore", "LinearAlgebra", "Test"] -git-tree-sha1 = "bf98fa45a0a4cee295de98d4c1462be26345b9a1" -uuid = "9e997f8a-9a97-42d5-a9f1-ce6bfc15e2c0" -version = "0.1.2" - -[[deps.CircularArrayBuffers]] -deps = ["Adapt"] -git-tree-sha1 = "a05b83d278a5c52111af07e2b2df64bf7b122f8c" -uuid = "9de3a189-e0c0-4e15-ba3b-b14b9fb0aec1" -version = "0.1.10" - -[[deps.CodecZlib]] -deps = ["TranscodingStreams", "Zlib_jll"] -git-tree-sha1 = "ded953804d019afa9a3f98981d99b33e3db7b6da" -uuid = "944b1d66-785c-5afd-91f1-9de20f533193" -version = "0.7.0" - -[[deps.ColorTypes]] -deps = ["FixedPointNumbers", "Random"] -git-tree-sha1 = "024fe24d83e4a5bf5fc80501a314ce0d1aa35597" -uuid = "3da002f7-5984-5a60-b8a6-cbb66c0b333f" -version = "0.11.0" - -[[deps.Colors]] -deps = ["ColorTypes", "FixedPointNumbers", "Reexport"] -git-tree-sha1 = "417b0ed7b8b838aa6ca0a87aadf1bb9eb111ce40" -uuid = "5ae59095-9a9b-59fe-a467-6f913c188581" -version = "0.12.8" - -[[deps.CommonRLInterface]] -deps = ["MacroTools"] -git-tree-sha1 = "21de56ebf28c262651e682f7fe614d44623dc087" -uuid = "d842c3ba-07a1-494f-bbec-f5741b0a3e98" -version = "0.3.1" - -[[deps.CommonSubexpressions]] -deps = ["MacroTools", "Test"] -git-tree-sha1 = "7b8a93dba8af7e3b42fecabf646260105ac373f7" -uuid = "bbf7d656-a473-5ed7-a52c-81e309532950" -version = "0.3.0" - -[[deps.Compat]] -deps = ["Base64", "Dates", "DelimitedFiles", "Distributed", "InteractiveUtils", "LibGit2", "Libdl", "LinearAlgebra", "Markdown", "Mmap", "Pkg", "Printf", "REPL", "Random", "SHA", "Serialization", "SharedArrays", "Sockets", "SparseArrays", "Statistics", "Test", "UUIDs", "Unicode"] -git-tree-sha1 = "96b0bc6c52df76506efc8a441c6cf1adcb1babc4" -uuid = "34da2185-b29b-5c13-b0c7-acf172513d20" -version = "3.42.0" - -[[deps.CompilerSupportLibraries_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "e66e0078-7015-5450-92f7-15fbd957f2ae" - -[[deps.ConstructionBase]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "f74e9d5388b8620b4cee35d4c5a618dd4dc547f4" -uuid = "187b0558-2788-49d3-abe0-74a17ed4e7c9" -version = "1.3.0" - -[[deps.Contour]] -deps = ["StaticArrays"] -git-tree-sha1 = "9f02045d934dc030edad45944ea80dbd1f0ebea7" -uuid = "d38c429a-6771-53c6-b99e-75d170b6e991" -version = "0.5.7" - -[[deps.Crayons]] -git-tree-sha1 = "249fe38abf76d48563e2f4556bebd215aa317e15" -uuid = "a8cc5b0e-0ffa-5ad4-8c14-923d3ee1735f" -version = "4.1.1" - -[[deps.DataAPI]] -git-tree-sha1 = "cc70b17275652eb47bc9e5f81635981f13cea5c8" -uuid = "9a962f9c-6df0-11e9-0e5d-c546b8b5ee8a" -version = "1.9.0" - -[[deps.DataStructures]] -deps = ["Compat", "InteractiveUtils", "OrderedCollections"] -git-tree-sha1 = "3daef5523dd2e769dad2365274f760ff5f282c7d" -uuid = "864edb3b-99cc-5e75-8d2d-829cb0a9cfe8" -version = "0.18.11" - -[[deps.DataValueInterfaces]] -git-tree-sha1 = "bfc1187b79289637fa0ef6d4436ebdfe6905cbd6" -uuid = "e2d170a0-9d28-54be-80f0-106bbe20a464" -version = "1.0.0" - -[[deps.Dates]] -deps = ["Printf"] -uuid = "ade2ca70-3891-5945-98fb-dc099432e06a" - -[[deps.DelimitedFiles]] -deps = ["Mmap"] -uuid = "8bb1440f-4735-579b-a4ab-409b98df4dab" - -[[deps.DensityInterface]] -deps = ["InverseFunctions", "Test"] -git-tree-sha1 = "80c3e8639e3353e5d2912fb3a1916b8455e2494b" -uuid = "b429d917-457f-4dbc-8f4c-0cc954292b1d" -version = "0.4.0" - -[[deps.DiffResults]] -deps = ["StaticArrays"] -git-tree-sha1 = "c18e98cba888c6c25d1c3b048e4b3380ca956805" -uuid = "163ba53b-c6d8-5494-b064-1a9d43ac40c5" -version = "1.0.3" - -[[deps.DiffRules]] -deps = ["IrrationalConstants", "LogExpFunctions", "NaNMath", "Random", "SpecialFunctions"] -git-tree-sha1 = "dd933c4ef7b4c270aacd4eb88fa64c147492acf0" -uuid = "b552c78f-8df3-52c6-915a-8e097449b14b" -version = "1.10.0" - -[[deps.Distributed]] -deps = ["Random", "Serialization", "Sockets"] -uuid = "8ba89e20-285c-5b6f-9357-94700520ee1b" - -[[deps.Distributions]] -deps = ["ChainRulesCore", "DensityInterface", "FillArrays", "LinearAlgebra", "PDMats", "Printf", "QuadGK", "Random", "SparseArrays", "SpecialFunctions", "Statistics", "StatsBase", "StatsFuns", "Test"] -git-tree-sha1 = "c43e992f186abaf9965cc45e372f4693b7754b22" -uuid = "31c24e10-a181-5473-b8eb-7969acd0382f" -version = "0.25.52" - -[[deps.DocStringExtensions]] -deps = ["LibGit2"] -git-tree-sha1 = "b19534d1895d702889b219c382a6e18010797f0b" -uuid = "ffbed154-4ef7-542d-bbb7-c09d3a79fcae" -version = "0.8.6" - -[[deps.Downloads]] -deps = ["ArgTools", "LibCURL", "NetworkOptions"] -uuid = "f43a241f-c20a-4ad4-852c-f6b1247861c6" - -[[deps.DualNumbers]] -deps = ["Calculus", "NaNMath", "SpecialFunctions"] -git-tree-sha1 = "90b158083179a6ccbce2c7eb1446d5bf9d7ae571" -uuid = "fa6b7ba4-c1ee-5f82-b5fc-ecf0adba8f74" -version = "0.6.7" - -[[deps.ElasticArrays]] -deps = ["Adapt"] -git-tree-sha1 = "a0fcc1bb3c9ceaf07e1d0529c9806ce94be6adf9" -uuid = "fdbdab4c-e67f-52f5-8c3f-e7b388dad3d4" -version = "1.2.9" - -[[deps.EllipsisNotation]] -git-tree-sha1 = "18ee049accec8763be17a933737c1dd0fdf8673a" -uuid = "da5c29d0-fa7d-589e-88eb-ea29b0a81949" -version = "1.0.0" - -[[deps.ExprTools]] -git-tree-sha1 = "56559bbef6ca5ea0c0818fa5c90320398a6fbf8d" -uuid = "e2ba6199-217a-4e67-a87a-7c52f15ade04" -version = "0.1.8" - -[[deps.FillArrays]] -deps = ["LinearAlgebra", "Random", "SparseArrays", "Statistics"] -git-tree-sha1 = "246621d23d1f43e3b9c368bf3b72b2331a27c286" -uuid = "1a297f60-69ca-5386-bcde-b61e274b549b" -version = "0.13.2" - -[[deps.FixedPointNumbers]] -deps = ["Statistics"] -git-tree-sha1 = "335bfdceacc84c5cdf16aadc768aa5ddfc5383cc" -uuid = "53c48c17-4a7d-5ca2-90c5-79b7896eea93" -version = "0.8.4" - -[[deps.Flux]] -deps = ["AbstractTrees", "Adapt", "CUDA", "CodecZlib", "Colors", "DelimitedFiles", "Functors", "Juno", "LinearAlgebra", "MacroTools", "NNlib", "NNlibCUDA", "Pkg", "Printf", "Random", "Reexport", "SHA", "Statistics", "StatsBase", "Test", "ZipFile", "Zygote"] -git-tree-sha1 = "0b3c6d0ce57d3b793eabd346ccc8f605035ef079" -uuid = "587475ba-b771-5e3f-ad9e-33799f191a9c" -version = "0.12.4" - -[[deps.ForwardDiff]] -deps = ["CommonSubexpressions", "DiffResults", "DiffRules", "LinearAlgebra", "LogExpFunctions", "NaNMath", "Preferences", "Printf", "Random", "SpecialFunctions", "StaticArrays"] -git-tree-sha1 = "1bd6fc0c344fc0cbee1f42f8d2e7ec8253dda2d2" -uuid = "f6369f11-7733-5829-9624-2563aa707210" -version = "0.10.25" - -[[deps.Functors]] -git-tree-sha1 = "223fffa49ca0ff9ce4f875be001ffe173b2b7de4" -uuid = "d9f16b24-f501-4c13-a1f2-28368ffc5196" -version = "0.2.8" - -[[deps.Future]] -deps = ["Random"] -uuid = "9fa8497b-333b-5362-9e8d-4d0656e87820" - -[[deps.GPUArrays]] -deps = ["Adapt", "LLVM", "LinearAlgebra", "Printf", "Random", "Serialization", "Statistics"] -git-tree-sha1 = "9010083c218098a3695653773695a9949e7e8f0d" -uuid = "0c68f7d7-f131-5f86-a1c3-88cf8149b2d7" -version = "8.3.1" - -[[deps.GPUCompiler]] -deps = ["ExprTools", "InteractiveUtils", "LLVM", "Libdl", "Logging", "TimerOutputs", "UUIDs"] -git-tree-sha1 = "647a54f196b5ffb7c3bc2fec5c9a57fa273354cc" -uuid = "61eb1bfa-7361-4325-ad38-22787b887f55" -version = "0.13.14" - -[[deps.HypergeometricFunctions]] -deps = ["DualNumbers", "LinearAlgebra", "SpecialFunctions", "Test"] -git-tree-sha1 = "65e4589030ef3c44d3b90bdc5aac462b4bb05567" -uuid = "34004b35-14d8-5ef3-9330-4cdb6864b03a" -version = "0.3.8" - -[[deps.IRTools]] -deps = ["InteractiveUtils", "MacroTools", "Test"] -git-tree-sha1 = "7f43342f8d5fd30ead0ba1b49ab1a3af3b787d24" -uuid = "7869d1d1-7146-5819-86e3-90919afe41df" -version = "0.4.5" - -[[deps.IfElse]] -git-tree-sha1 = "debdd00ffef04665ccbb3e150747a77560e8fad1" -uuid = "615f187c-cbe4-4ef1-ba3b-2fcf58d6d173" -version = "0.1.1" - -[[deps.InteractiveUtils]] -deps = ["Markdown"] -uuid = "b77e0a4c-d291-57a0-90e8-8db25a27a240" - -[[deps.IntervalSets]] -deps = ["Dates", "EllipsisNotation", "Statistics"] -git-tree-sha1 = "3cc368af3f110a767ac786560045dceddfc16758" -uuid = "8197267c-284f-5f27-9208-e0e47529a953" -version = "0.5.3" - -[[deps.InverseFunctions]] -deps = ["Test"] -git-tree-sha1 = "91b5dcf362c5add98049e6c29ee756910b03051d" -uuid = "3587e190-3f89-42d0-90ee-14403ec27112" -version = "0.1.3" - -[[deps.IrrationalConstants]] -git-tree-sha1 = "7fd44fd4ff43fc60815f8e764c0f352b83c49151" -uuid = "92d709cd-6900-40b7-9082-c6be49f344b6" -version = "0.1.1" - -[[deps.IteratorInterfaceExtensions]] -git-tree-sha1 = "a3f24677c21f5bbe9d2a714f95dcd58337fb2856" -uuid = "82899510-4779-5014-852e-03e436cf321d" -version = "1.0.0" - -[[deps.JLLWrappers]] -deps = ["Preferences"] -git-tree-sha1 = "abc9885a7ca2052a736a600f7fa66209f96506e1" -uuid = "692b3bcd-3c85-4b1f-b108-f13ce0eb3210" -version = "1.4.1" - -[[deps.Juno]] -deps = ["Base64", "Logging", "Media", "Profile"] -git-tree-sha1 = "07cb43290a840908a771552911a6274bc6c072c7" -uuid = "e5e0dc1b-0480-54bc-9374-aad01c23163d" -version = "0.8.4" - -[[deps.LLVM]] -deps = ["CEnum", "LLVMExtra_jll", "Libdl", "Printf", "Unicode"] -git-tree-sha1 = "c9b86064be5ae0f63e50816a5a90b08c474507ae" -uuid = "929cbde3-209d-540e-8aea-75f648917ca0" -version = "4.9.1" - -[[deps.LLVMExtra_jll]] -deps = ["Artifacts", "JLLWrappers", "LazyArtifacts", "Libdl", "Pkg"] -git-tree-sha1 = "5558ad3c8972d602451efe9d81c78ec14ef4f5ef" -uuid = "dad2f222-ce93-54a1-a47d-0025e8a3acab" -version = "0.0.14+2" - -[[deps.LazyArtifacts]] -deps = ["Artifacts", "Pkg"] -uuid = "4af54fe1-eca0-43a8-85a7-787d91b784e3" - -[[deps.LibCURL]] -deps = ["LibCURL_jll", "MozillaCACerts_jll"] -uuid = "b27032c2-a3e7-50c8-80cd-2d36dbcbfd21" - -[[deps.LibCURL_jll]] -deps = ["Artifacts", "LibSSH2_jll", "Libdl", "MbedTLS_jll", "Zlib_jll", "nghttp2_jll"] -uuid = "deac9b47-8bc7-5906-a0fe-35ac56dc84c0" - -[[deps.LibGit2]] -deps = ["Base64", "NetworkOptions", "Printf", "SHA"] -uuid = "76f85450-5226-5b5a-8eaa-529ad045b433" - -[[deps.LibSSH2_jll]] -deps = ["Artifacts", "Libdl", "MbedTLS_jll"] -uuid = "29816b5a-b9ab-546f-933c-edad1886dfa8" - -[[deps.Libdl]] -uuid = "8f399da3-3557-5675-b5ff-fb832c97cbdb" - -[[deps.LinearAlgebra]] -deps = ["Libdl", "libblastrampoline_jll"] -uuid = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e" - -[[deps.LogExpFunctions]] -deps = ["ChainRulesCore", "ChangesOfVariables", "DocStringExtensions", "InverseFunctions", "IrrationalConstants", "LinearAlgebra"] -git-tree-sha1 = "58f25e56b706f95125dcb796f39e1fb01d913a71" -uuid = "2ab3a3ac-af41-5b50-aa03-7779005ae688" -version = "0.3.10" - -[[deps.Logging]] -uuid = "56ddb016-857b-54e1-b83d-db4d58db5568" - -[[deps.MacroTools]] -deps = ["Markdown", "Random"] -git-tree-sha1 = "3d3e902b31198a27340d0bf00d6ac452866021cf" -uuid = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09" -version = "0.5.9" - -[[deps.MarchingCubes]] -deps = ["StaticArrays"] -git-tree-sha1 = "5f768e0a0c3875df386be4c036f78c8bd4b1a9b6" -uuid = "299715c1-40a9-479a-aaf9-4a633d36f717" -version = "0.1.2" - -[[deps.Markdown]] -deps = ["Base64"] -uuid = "d6f4376e-aef5-505a-96c1-9c027394607a" - -[[deps.MbedTLS_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "c8ffd9c3-330d-5841-b78e-0817d7145fa1" - -[[deps.Media]] -deps = ["MacroTools", "Test"] -git-tree-sha1 = "75a54abd10709c01f1b86b84ec225d26e840ed58" -uuid = "e89f7d12-3494-54d1-8411-f7d8b9ae1f27" -version = "0.5.0" - -[[deps.Missings]] -deps = ["DataAPI"] -git-tree-sha1 = "bf210ce90b6c9eed32d25dbcae1ebc565df2687f" -uuid = "e1d29d7a-bbdc-5cf2-9ac0-f12de2c33e28" -version = "1.0.2" - -[[deps.Mmap]] -uuid = "a63ad114-7e13-5084-954f-fe012c677804" - -[[deps.MozillaCACerts_jll]] -uuid = "14a3606d-f60d-562e-9121-12d972cd8159" - -[[deps.NNlib]] -deps = ["Adapt", "ChainRulesCore", "Compat", "LinearAlgebra", "Pkg", "Requires", "Statistics"] -git-tree-sha1 = "3a8dfd0cfb5bb3b82d09949e14423409b9334acb" -uuid = "872c559c-99b0-510c-b3b7-b6c96a88d5cd" -version = "0.7.34" - -[[deps.NNlibCUDA]] -deps = ["CUDA", "LinearAlgebra", "NNlib", "Random", "Statistics"] -git-tree-sha1 = "a2dc748c9f6615197b6b97c10bcce829830574c9" -uuid = "a00861dc-f156-4864-bf3c-e6376f28a68d" -version = "0.1.11" - -[[deps.NaNMath]] -git-tree-sha1 = "b086b7ea07f8e38cf122f5016af580881ac914fe" -uuid = "77ba4419-2d1f-58cd-9bb1-8ffee604a2e3" -version = "0.3.7" - -[[deps.NetworkOptions]] -uuid = "ca575930-c2e3-43a9-ace4-1e988b2c1908" - -[[deps.OpenBLAS_jll]] -deps = ["Artifacts", "CompilerSupportLibraries_jll", "Libdl"] -uuid = "4536629a-c528-5b80-bd46-f80d51c5b363" - -[[deps.OpenLibm_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "05823500-19ac-5b8b-9628-191a04bc5112" - -[[deps.OpenSpecFun_jll]] -deps = ["Artifacts", "CompilerSupportLibraries_jll", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "13652491f6856acfd2db29360e1bbcd4565d04f1" -uuid = "efe28fd5-8261-553b-a9e1-b2916fc3738e" -version = "0.5.5+0" - -[[deps.OrderedCollections]] -git-tree-sha1 = "85f8e6578bf1f9ee0d11e7bb1b1456435479d47c" -uuid = "bac558e1-5e72-5ebc-8fee-abe8a469f55d" -version = "1.4.1" - -[[deps.PDMats]] -deps = ["LinearAlgebra", "SparseArrays", "SuiteSparse"] -git-tree-sha1 = "e8185b83b9fc56eb6456200e873ce598ebc7f262" -uuid = "90014a1f-27ba-587c-ab20-58faa44d9150" -version = "0.11.7" - -[[deps.Pkg]] -deps = ["Artifacts", "Dates", "Downloads", "LibGit2", "Libdl", "Logging", "Markdown", "Printf", "REPL", "Random", "SHA", "Serialization", "TOML", "Tar", "UUIDs", "p7zip_jll"] -uuid = "44cfe95a-1eb2-52ea-b672-e2afdf69b78f" - -[[deps.Preferences]] -deps = ["TOML"] -git-tree-sha1 = "d3538e7f8a790dc8903519090857ef8e1283eecd" -uuid = "21216c6a-2e73-6563-6e65-726566657250" -version = "1.2.5" - -[[deps.Printf]] -deps = ["Unicode"] -uuid = "de0858da-6303-5e67-8744-51eddeeeb8d7" - -[[deps.Profile]] -deps = ["Printf"] -uuid = "9abbd945-dff8-562f-b5e8-e1ebf5ef1b79" - -[[deps.ProgressMeter]] -deps = ["Distributed", "Printf"] -git-tree-sha1 = "afadeba63d90ff223a6a48d2009434ecee2ec9e8" -uuid = "92933f4c-e287-5a05-a399-4b506db050ca" -version = "1.7.1" - -[[deps.QuadGK]] -deps = ["DataStructures", "LinearAlgebra"] -git-tree-sha1 = "78aadffb3efd2155af139781b8a8df1ef279ea39" -uuid = "1fd47b50-473d-5c70-9696-f719f8f3bcdc" -version = "2.4.2" - -[[deps.REPL]] -deps = ["InteractiveUtils", "Markdown", "Sockets", "Unicode"] -uuid = "3fa0cd96-eef1-5676-8a61-b3b8758bbffb" - -[[deps.Random]] -deps = ["SHA", "Serialization"] -uuid = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c" - -[[deps.Random123]] -deps = ["Random", "RandomNumbers"] -git-tree-sha1 = "afeacaecf4ed1649555a19cb2cad3c141bbc9474" -uuid = "74087812-796a-5b5d-8853-05524746bad3" -version = "1.5.0" - -[[deps.RandomNumbers]] -deps = ["Random", "Requires"] -git-tree-sha1 = "043da614cc7e95c703498a491e2c21f58a2b8111" -uuid = "e6cf234a-135c-5ec9-84dd-332b85af5143" -version = "1.5.3" - -[[deps.RealDot]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "9f0a1b71baaf7650f4fa8a1d168c7fb6ee41f0c9" -uuid = "c1ae055f-0cd5-4b69-90a6-9a35b1a98df9" -version = "0.1.0" - -[[deps.Reexport]] -git-tree-sha1 = "45e428421666073eab6f2da5c9d310d99bb12f9b" -uuid = "189a3867-3050-52da-a836-e630ba90ab69" -version = "1.2.2" - -[[deps.ReinforcementLearningBase]] -deps = ["AbstractTrees", "CommonRLInterface", "Markdown", "Random", "Test"] -path = "src/ReinforcementLearningBase" -uuid = "e575027e-6cd6-5018-9292-cdc6200d2b44" -version = "0.9.7" - -[[deps.ReinforcementLearningCore]] -deps = ["AbstractTrees", "Adapt", "ArrayInterface", "CUDA", "CircularArrayBuffers", "Compat", "Dates", "Distributions", "ElasticArrays", "FillArrays", "Flux", "Functors", "GPUArrays", "LinearAlgebra", "MacroTools", "Markdown", "ProgressMeter", "Random", "ReinforcementLearningBase", "Setfield", "Statistics", "StatsBase", "UnicodePlots", "Zygote"] -path = "src/ReinforcementLearningCore" -uuid = "de1b191a-4ae0-4afa-a27b-92d07f46b2d6" -version = "0.8.10" - -[[deps.ReinforcementLearningEnvironments]] -deps = ["DelimitedFiles", "IntervalSets", "LinearAlgebra", "MacroTools", "Markdown", "Pkg", "Random", "ReinforcementLearningBase", "Requires", "SparseArrays", "StatsBase"] -path = "src/ReinforcementLearningEnvironments" -uuid = "25e41dd2-4622-11e9-1641-f1adca772921" -version = "0.6.12" - -[[deps.ReinforcementLearningZoo]] -deps = ["AbstractTrees", "CUDA", "CircularArrayBuffers", "DataStructures", "Dates", "Distributions", "Flux", "IntervalSets", "LinearAlgebra", "Logging", "MacroTools", "Random", "ReinforcementLearningBase", "ReinforcementLearningCore", "Setfield", "Statistics", "StatsBase", "StructArrays", "Zygote"] -path = "src/ReinforcementLearningZoo" -uuid = "d607f57d-ee1e-4ba7-bcf2-7734c1e31854" -version = "0.5.9" - -[[deps.Requires]] -deps = ["UUIDs"] -git-tree-sha1 = "838a3a4188e2ded87a4f9f184b4b0d78a1e91cb7" -uuid = "ae029012-a4dd-5104-9daa-d747884805df" -version = "1.3.0" - -[[deps.Rmath]] -deps = ["Random", "Rmath_jll"] -git-tree-sha1 = "bf3188feca147ce108c76ad82c2792c57abe7b1f" -uuid = "79098fc4-a85e-5d69-aa6a-4863f24498fa" -version = "0.7.0" - -[[deps.Rmath_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "68db32dff12bb6127bac73c209881191bf0efbb7" -uuid = "f50d1b31-88e8-58de-be2c-1cc44531875f" -version = "0.3.0+0" - -[[deps.SHA]] -uuid = "ea8e919c-243c-51af-8825-aaa63cd721ce" - -[[deps.Serialization]] -uuid = "9e88b42a-f829-5b0c-bbe9-9e923198166b" - -[[deps.Setfield]] -deps = ["ConstructionBase", "Future", "MacroTools", "Requires"] -git-tree-sha1 = "38d88503f695eb0301479bc9b0d4320b378bafe5" -uuid = "efcf1570-3423-57d1-acb7-fd33fddbac46" -version = "0.8.2" - -[[deps.SharedArrays]] -deps = ["Distributed", "Mmap", "Random", "Serialization"] -uuid = "1a1011a3-84de-559e-8e89-a11a2f7dc383" - -[[deps.Sockets]] -uuid = "6462fe0b-24de-5631-8697-dd941f90decc" - -[[deps.SortingAlgorithms]] -deps = ["DataStructures"] -git-tree-sha1 = "b3363d7460f7d098ca0912c69b082f75625d7508" -uuid = "a2af1166-a08f-5f64-846c-94a0d3cef48c" -version = "1.0.1" - -[[deps.SparseArrays]] -deps = ["LinearAlgebra", "Random"] -uuid = "2f01184e-e22b-5df5-ae63-d93ebab69eaf" - -[[deps.SpecialFunctions]] -deps = ["ChainRulesCore", "IrrationalConstants", "LogExpFunctions", "OpenLibm_jll", "OpenSpecFun_jll"] -git-tree-sha1 = "5ba658aeecaaf96923dce0da9e703bd1fe7666f9" -uuid = "276daf66-3868-5448-9aa4-cd146d93841b" -version = "2.1.4" - -[[deps.Static]] -deps = ["IfElse"] -git-tree-sha1 = "87e9954dfa33fd145694e42337bdd3d5b07021a6" -uuid = "aedffcd0-7271-4cad-89d0-dc628f76c6d3" -version = "0.6.0" - -[[deps.StaticArrays]] -deps = ["LinearAlgebra", "Random", "Statistics"] -git-tree-sha1 = "6976fab022fea2ffea3d945159317556e5dad87c" -uuid = "90137ffa-7385-5640-81b9-e52037218182" -version = "1.4.2" - -[[deps.Statistics]] -deps = ["LinearAlgebra", "SparseArrays"] -uuid = "10745b16-79ce-11e8-11f9-7d13ad32a3b2" - -[[deps.StatsAPI]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "c3d8ba7f3fa0625b062b82853a7d5229cb728b6b" -uuid = "82ae8749-77ed-4fe6-ae5f-f523153014b0" -version = "1.2.1" - -[[deps.StatsBase]] -deps = ["DataAPI", "DataStructures", "LinearAlgebra", "LogExpFunctions", "Missings", "Printf", "Random", "SortingAlgorithms", "SparseArrays", "Statistics", "StatsAPI"] -git-tree-sha1 = "8977b17906b0a1cc74ab2e3a05faa16cf08a8291" -uuid = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91" -version = "0.33.16" - -[[deps.StatsFuns]] -deps = ["ChainRulesCore", "HypergeometricFunctions", "InverseFunctions", "IrrationalConstants", "LogExpFunctions", "Reexport", "Rmath", "SpecialFunctions"] -git-tree-sha1 = "25405d7016a47cf2bd6cd91e66f4de437fd54a07" -uuid = "4c63d2b9-4356-54db-8cca-17b64c39e42c" -version = "0.9.16" - -[[deps.StructArrays]] -deps = ["Adapt", "DataAPI", "StaticArrays", "Tables"] -git-tree-sha1 = "57617b34fa34f91d536eb265df67c2d4519b8b98" -uuid = "09ab397b-f2b6-538f-b94a-2f83cf4a842a" -version = "0.6.5" - -[[deps.SuiteSparse]] -deps = ["Libdl", "LinearAlgebra", "Serialization", "SparseArrays"] -uuid = "4607b0f0-06f3-5cda-b6b1-a6196a1729e9" - -[[deps.TOML]] -deps = ["Dates"] -uuid = "fa267f1f-6049-4f14-aa54-33bafae1ed76" - -[[deps.TableTraits]] -deps = ["IteratorInterfaceExtensions"] -git-tree-sha1 = "c06b2f539df1c6efa794486abfb6ed2022561a39" -uuid = "3783bdb8-4a98-5b6b-af9a-565f29a5fe9c" -version = "1.0.1" - -[[deps.Tables]] -deps = ["DataAPI", "DataValueInterfaces", "IteratorInterfaceExtensions", "LinearAlgebra", "OrderedCollections", "TableTraits", "Test"] -git-tree-sha1 = "5ce79ce186cc678bbb5c5681ca3379d1ddae11a1" -uuid = "bd369af6-aec1-5ad0-b16a-f7cc5008161c" -version = "1.7.0" - -[[deps.Tar]] -deps = ["ArgTools", "SHA"] -uuid = "a4e569a6-e804-4fa4-b0f3-eef7a1d5b13e" - -[[deps.Test]] -deps = ["InteractiveUtils", "Logging", "Random", "Serialization"] -uuid = "8dfed614-e22c-5e08-85e1-65c5234f0b40" - -[[deps.TimerOutputs]] -deps = ["ExprTools", "Printf"] -git-tree-sha1 = "d60b0c96a16aaa42138d5d38ad386df672cb8bd8" -uuid = "a759f4b9-e2f1-59dc-863e-4aeb61b1ea8f" -version = "0.5.16" - -[[deps.TranscodingStreams]] -deps = ["Random", "Test"] -git-tree-sha1 = "216b95ea110b5972db65aa90f88d8d89dcb8851c" -uuid = "3bb67fe8-82b1-5028-8e26-92a6c54297fa" -version = "0.9.6" - -[[deps.UUIDs]] -deps = ["Random", "SHA"] -uuid = "cf7118a7-6976-5b1a-9a39-7adc72f591a4" - -[[deps.Unicode]] -uuid = "4ec0a83e-493e-50e2-b9ac-8f72acf5a8f5" - -[[deps.UnicodePlots]] -deps = ["Contour", "Crayons", "Dates", "LinearAlgebra", "MarchingCubes", "NaNMath", "SparseArrays", "StaticArrays", "StatsBase", "Unitful"] -git-tree-sha1 = "1785494cb9484f9ab05bbc9d81a2d4de4341eb39" -uuid = "b8865327-cd53-5732-bb35-84acbb429228" -version = "2.9.0" - -[[deps.Unitful]] -deps = ["ConstructionBase", "Dates", "LinearAlgebra", "Random"] -git-tree-sha1 = "b649200e887a487468b71821e2644382699f1b0f" -uuid = "1986cc42-f94f-5a68-af5c-568840ba703d" -version = "1.11.0" - -[[deps.ZipFile]] -deps = ["Libdl", "Printf", "Zlib_jll"] -git-tree-sha1 = "3593e69e469d2111389a9bd06bac1f3d730ac6de" -uuid = "a5390f91-8eb1-5f08-bee0-b1d1ffed6cea" -version = "0.9.4" - -[[deps.Zlib_jll]] -deps = ["Libdl"] -uuid = "83775a58-1f1d-513f-b197-d71354ab007a" - -[[deps.Zygote]] -deps = ["AbstractFFTs", "ChainRules", "ChainRulesCore", "DiffRules", "Distributed", "FillArrays", "ForwardDiff", "IRTools", "InteractiveUtils", "LinearAlgebra", "MacroTools", "NaNMath", "Random", "Requires", "SparseArrays", "SpecialFunctions", "Statistics", "ZygoteRules"] -git-tree-sha1 = "52adc0a505b6421a8668f13dcdb0c4cb498bd72c" -uuid = "e88e6eb3-aa80-5325-afca-941959d7151f" -version = "0.6.37" - -[[deps.ZygoteRules]] -deps = ["MacroTools"] -git-tree-sha1 = "8c1a8e4dfacb1fd631745552c8db35d0deb09ea0" -uuid = "700de1a5-db45-46bc-99cf-38207098b444" -version = "0.2.2" - -[[deps.libblastrampoline_jll]] -deps = ["Artifacts", "Libdl", "OpenBLAS_jll"] -uuid = "8e850b90-86db-534c-a0d3-1478176c7d93" - -[[deps.nghttp2_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "8e850ede-7688-5339-a07c-302acd2aaf8d" - -[[deps.p7zip_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "3f19e933-33d8-53b3-aaab-bd5110c3b7a0" diff --git a/Project.toml b/Project.toml index b23618bca..66792707e 100644 --- a/Project.toml +++ b/Project.toml @@ -1,7 +1,7 @@ name = "ReinforcementLearning" uuid = "158674fc-8238-5cab-b5ba-03dfc80d1318" authors = ["Johanni Brea ", "Jun Tian "] -version = "0.10.1" +version = "0.11.0" [deps] Reexport = "189a3867-3050-52da-a836-e630ba90ab69" @@ -12,10 +12,10 @@ ReinforcementLearningZoo = "d607f57d-ee1e-4ba7-bcf2-7734c1e31854" [compat] Reexport = "0.2, 1" -ReinforcementLearningBase = "0.9" -ReinforcementLearningCore = "0.8" -ReinforcementLearningEnvironments = "0.6" -ReinforcementLearningZoo = "0.5" +ReinforcementLearningBase = "0.10" +ReinforcementLearningCore = "0.9" +ReinforcementLearningEnvironments = "0.7" +ReinforcementLearningZoo = "0.6" julia = "1.6" [extras] diff --git a/docs/Manifest.toml b/docs/Manifest.toml deleted file mode 100644 index 45ad818da..000000000 --- a/docs/Manifest.toml +++ /dev/null @@ -1,1561 +0,0 @@ -# This file is machine-generated - editing it directly is not advised - -[[ANSIColoredPrinters]] -git-tree-sha1 = "574baf8110975760d391c710b6341da1afa48d8c" -uuid = "a4c015fc-c6ff-483c-b24f-f7ea428134e9" -version = "0.0.1" - -[[AbstractFFTs]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "485ee0867925449198280d4af84bdb46a2a404d0" -uuid = "621f4979-c628-5d54-868e-fcf4e3e8185c" -version = "1.0.1" - -[[AbstractTrees]] -git-tree-sha1 = "03e0550477d86222521d254b741d470ba17ea0b5" -uuid = "1520ce14-60c1-5f80-bbc7-55ef81b5835c" -version = "0.3.4" - -[[Adapt]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "84918055d15b3114ede17ac6a7182f68870c16f7" -uuid = "79e6a3ab-5dfb-504d-930d-738a2a938a0e" -version = "3.3.1" - -[[ArcadeLearningEnvironment]] -deps = ["ArcadeLearningEnvironment_jll", "LibArchive_jll", "MD5", "Pkg"] -git-tree-sha1 = "0053e34fe18fef36a2077e3e1466f34f195cbafc" -uuid = "b7f77d8d-088d-5e02-8ac0-89aab2acc977" -version = "0.2.4" - -[[ArcadeLearningEnvironment_jll]] -deps = ["Libdl", "Pkg", "Zlib_jll"] -git-tree-sha1 = "c27cfe2024f4804ca60cd3d443c25ed2e8543108" -uuid = "52cbb755-00ff-5a24-b23e-8a91c598877e" -version = "0.6.1+0" - -[[ArgTools]] -uuid = "0dad84c5-d112-42e6-8d28-ef12dabb789f" - -[[ArrayInterface]] -deps = ["Compat", "IfElse", "LinearAlgebra", "Requires", "SparseArrays", "Static"] -git-tree-sha1 = "b8d49c34c3da35f220e7295659cd0bab8e739fed" -uuid = "4fba245c-0d91-5ea0-9b3e-6abc04ee57a9" -version = "3.1.33" - -[[Artifacts]] -uuid = "56f22d72-fd6d-98f1-02f0-08ddc0907c33" - -[[Attr_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "b132f9aeb209b8790dcc286c857f300369219d8d" -uuid = "1fd713ca-387f-5abc-8002-d8b8b1623b73" -version = "2.5.1+0" - -[[AxisAlgorithms]] -deps = ["LinearAlgebra", "Random", "SparseArrays", "WoodburyMatrices"] -git-tree-sha1 = "a4d07a1c313392a77042855df46c5f534076fab9" -uuid = "13072b0f-2c55-5437-9ae7-d433b7a33950" -version = "1.0.0" - -[[BFloat16s]] -deps = ["LinearAlgebra", "Test"] -git-tree-sha1 = "4af69e205efc343068dc8722b8dfec1ade89254a" -uuid = "ab4f0b2a-ad5b-11e8-123f-65d77653426b" -version = "0.1.0" - -[[BSON]] -git-tree-sha1 = "92b8a8479128367aaab2620b8e73dff632f5ae69" -uuid = "fbb218c0-5317-5bc6-957e-2ee96dd4b1f0" -version = "0.3.3" - -[[Base64]] -uuid = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f" - -[[BinaryProvider]] -deps = ["Libdl", "Logging", "SHA"] -git-tree-sha1 = "ecdec412a9abc8db54c0efc5548c64dfce072058" -uuid = "b99e7846-7c00-51b0-8f62-c81ae34c0232" -version = "0.5.10" - -[[Blosc]] -deps = ["Blosc_jll"] -git-tree-sha1 = "84cf7d0f8fd46ca6f1b3e0305b4b4a37afe50fd6" -uuid = "a74b3585-a348-5f62-a45c-50e91977d574" -version = "0.7.0" - -[[Blosc_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Lz4_jll", "Pkg", "Zlib_jll", "Zstd_jll"] -git-tree-sha1 = "e747dac84f39c62aff6956651ec359686490134e" -uuid = "0b7ba130-8d10-5ba8-a3d6-c5182647fed9" -version = "1.21.0+0" - -[[BufferedStreams]] -deps = ["Compat", "Test"] -git-tree-sha1 = "5d55b9486590fdda5905c275bb21ce1f0754020f" -uuid = "e1450e63-4bb3-523b-b2a4-4ffa8c0fd77d" -version = "1.0.0" - -[[Bzip2_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "c3598e525718abcc440f69cc6d5f60dda0a1b61e" -uuid = "6e34b625-4abd-537c-b88f-471c36dfa7a0" -version = "1.0.6+5" - -[[CEnum]] -git-tree-sha1 = "215a9aa4a1f23fbd05b92769fdd62559488d70e9" -uuid = "fa961155-64e5-5f13-b03f-caf6b980ea82" -version = "0.4.1" - -[[CRC32c]] -uuid = "8bf52ea8-c179-5cab-976a-9e18b702a9bc" - -[[CUDA]] -deps = ["AbstractFFTs", "Adapt", "BFloat16s", "CEnum", "CompilerSupportLibraries_jll", "ExprTools", "GPUArrays", "GPUCompiler", "LLVM", "LazyArtifacts", "Libdl", "LinearAlgebra", "Logging", "Printf", "Random", "Random123", "RandomNumbers", "Reexport", "Requires", "SparseArrays", "SpecialFunctions", "TimerOutputs"] -git-tree-sha1 = "335b3d2373733919b4972a51215a6840c7a33828" -uuid = "052768ef-5323-5732-b1bb-66c8b64840ba" -version = "3.4.2" - -[[Cairo_jll]] -deps = ["Artifacts", "Bzip2_jll", "Fontconfig_jll", "FreeType2_jll", "Glib_jll", "JLLWrappers", "LZO_jll", "Libdl", "Pixman_jll", "Pkg", "Xorg_libXext_jll", "Xorg_libXrender_jll", "Zlib_jll", "libpng_jll"] -git-tree-sha1 = "e2f47f6d8337369411569fd45ae5753ca10394c6" -uuid = "83423d85-b0ee-5818-9007-b63ccbeb887a" -version = "1.16.0+6" - -[[ChainRules]] -deps = ["ChainRulesCore", "Compat", "LinearAlgebra", "Random", "Statistics"] -git-tree-sha1 = "74c737978316e19e0706737542037c468b21a8d9" -uuid = "082447d4-558c-5d27-93f4-14fc19e9eca2" -version = "1.11.6" - -[[ChainRulesCore]] -deps = ["Compat", "LinearAlgebra", "SparseArrays"] -git-tree-sha1 = "a325370b9dd0e6bf5656a6f1a7ae80755f8ccc46" -uuid = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4" -version = "1.7.2" - -[[CircularArrayBuffers]] -git-tree-sha1 = "b097d863df6c40491b7553a1eb235fbb86d37d0e" -uuid = "9de3a189-e0c0-4e15-ba3b-b14b9fb0aec1" -version = "0.1.3" - -[[CodecZlib]] -deps = ["TranscodingStreams", "Zlib_jll"] -git-tree-sha1 = "ded953804d019afa9a3f98981d99b33e3db7b6da" -uuid = "944b1d66-785c-5afd-91f1-9de20f533193" -version = "0.7.0" - -[[ColorSchemes]] -deps = ["ColorTypes", "Colors", "FixedPointNumbers", "Random"] -git-tree-sha1 = "a851fec56cb73cfdf43762999ec72eff5b86882a" -uuid = "35d6a980-a343-548e-a6ea-1d62b119f2f4" -version = "3.15.0" - -[[ColorTypes]] -deps = ["FixedPointNumbers", "Random"] -git-tree-sha1 = "024fe24d83e4a5bf5fc80501a314ce0d1aa35597" -uuid = "3da002f7-5984-5a60-b8a6-cbb66c0b333f" -version = "0.11.0" - -[[ColorVectorSpace]] -deps = ["ColorTypes", "FixedPointNumbers", "LinearAlgebra", "SpecialFunctions", "Statistics", "TensorCore"] -git-tree-sha1 = "45efb332df2e86f2cb2e992239b6267d97c9e0b6" -uuid = "c3611d14-8923-5661-9e6a-0046d554d3a4" -version = "0.9.7" - -[[Colors]] -deps = ["ColorTypes", "FixedPointNumbers", "Reexport"] -git-tree-sha1 = "417b0ed7b8b838aa6ca0a87aadf1bb9eb111ce40" -uuid = "5ae59095-9a9b-59fe-a467-6f913c188581" -version = "0.12.8" - -[[CommonRLInterface]] -deps = ["MacroTools"] -git-tree-sha1 = "21de56ebf28c262651e682f7fe614d44623dc087" -uuid = "d842c3ba-07a1-494f-bbec-f5741b0a3e98" -version = "0.3.1" - -[[CommonSubexpressions]] -deps = ["MacroTools", "Test"] -git-tree-sha1 = "7b8a93dba8af7e3b42fecabf646260105ac373f7" -uuid = "bbf7d656-a473-5ed7-a52c-81e309532950" -version = "0.3.0" - -[[Compat]] -deps = ["Base64", "Dates", "DelimitedFiles", "Distributed", "InteractiveUtils", "LibGit2", "Libdl", "LinearAlgebra", "Markdown", "Mmap", "Pkg", "Printf", "REPL", "Random", "SHA", "Serialization", "SharedArrays", "Sockets", "SparseArrays", "Statistics", "Test", "UUIDs", "Unicode"] -git-tree-sha1 = "31d0151f5716b655421d9d75b7fa74cc4e744df2" -uuid = "34da2185-b29b-5c13-b0c7-acf172513d20" -version = "3.39.0" - -[[CompilerSupportLibraries_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "e66e0078-7015-5450-92f7-15fbd957f2ae" - -[[Conda]] -deps = ["JSON", "VersionParsing"] -git-tree-sha1 = "299304989a5e6473d985212c28928899c74e9421" -uuid = "8f4d0f93-b110-5947-807f-2305c1781a2d" -version = "1.5.2" - -[[ConstructionBase]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "f74e9d5388b8620b4cee35d4c5a618dd4dc547f4" -uuid = "187b0558-2788-49d3-abe0-74a17ed4e7c9" -version = "1.3.0" - -[[Contour]] -deps = ["StaticArrays"] -git-tree-sha1 = "9f02045d934dc030edad45944ea80dbd1f0ebea7" -uuid = "d38c429a-6771-53c6-b99e-75d170b6e991" -version = "0.5.7" - -[[CoordinateTransformations]] -deps = ["LinearAlgebra", "StaticArrays"] -git-tree-sha1 = "6d1c23e740a586955645500bbec662476204a52c" -uuid = "150eb455-5306-5404-9cee-2592286d6298" -version = "0.6.1" - -[[Crayons]] -git-tree-sha1 = "3f71217b538d7aaee0b69ab47d9b7724ca8afa0d" -uuid = "a8cc5b0e-0ffa-5ad4-8c14-923d3ee1735f" -version = "4.0.4" - -[[CxxWrap]] -deps = ["Libdl", "MacroTools", "libcxxwrap_julia_jll"] -git-tree-sha1 = "b400a0b5de176906388fc0c56dd93c5383049217" -uuid = "1f15a43c-97ca-5a2a-ae31-89f07a497df4" -version = "0.10.2" - -[[DataAPI]] -git-tree-sha1 = "cc70b17275652eb47bc9e5f81635981f13cea5c8" -uuid = "9a962f9c-6df0-11e9-0e5d-c546b8b5ee8a" -version = "1.9.0" - -[[DataDeps]] -deps = ["BinaryProvider", "HTTP", "Libdl", "Reexport", "SHA", "p7zip_jll"] -git-tree-sha1 = "4f0e41ff461d42cfc62ff0de4f1cd44c6e6b3771" -uuid = "124859b0-ceae-595e-8997-d05f6a7a8dfe" -version = "0.7.7" - -[[DataStructures]] -deps = ["Compat", "InteractiveUtils", "OrderedCollections"] -git-tree-sha1 = "7d9d316f04214f7efdbb6398d545446e246eff02" -uuid = "864edb3b-99cc-5e75-8d2d-829cb0a9cfe8" -version = "0.18.10" - -[[DataValueInterfaces]] -git-tree-sha1 = "bfc1187b79289637fa0ef6d4436ebdfe6905cbd6" -uuid = "e2d170a0-9d28-54be-80f0-106bbe20a464" -version = "1.0.0" - -[[Dates]] -deps = ["Printf"] -uuid = "ade2ca70-3891-5945-98fb-dc099432e06a" - -[[DelimitedFiles]] -deps = ["Mmap"] -uuid = "8bb1440f-4735-579b-a4ab-409b98df4dab" - -[[DemoCards]] -deps = ["Dates", "Documenter", "FileIO", "HTTP", "ImageCore", "JSON", "Literate", "Mustache", "Suppressor", "YAML"] -git-tree-sha1 = "09590a89752c3adb38361b9b99700e1c0037ba98" -uuid = "311a05b2-6137-4a5a-b473-18580a3d38b5" -version = "0.4.4" - -[[DiffResults]] -deps = ["StaticArrays"] -git-tree-sha1 = "c18e98cba888c6c25d1c3b048e4b3380ca956805" -uuid = "163ba53b-c6d8-5494-b064-1a9d43ac40c5" -version = "1.0.3" - -[[DiffRules]] -deps = ["NaNMath", "Random", "SpecialFunctions"] -git-tree-sha1 = "7220bc21c33e990c14f4a9a319b1d242ebc5b269" -uuid = "b552c78f-8df3-52c6-915a-8e097449b14b" -version = "1.3.1" - -[[Distributed]] -deps = ["Random", "Serialization", "Sockets"] -uuid = "8ba89e20-285c-5b6f-9357-94700520ee1b" - -[[Distributions]] -deps = ["ChainRulesCore", "FillArrays", "LinearAlgebra", "PDMats", "Printf", "QuadGK", "Random", "SparseArrays", "SpecialFunctions", "Statistics", "StatsBase", "StatsFuns"] -git-tree-sha1 = "ff7890c74e2eaffbc0b3741811e3816e64b6343d" -uuid = "31c24e10-a181-5473-b8eb-7969acd0382f" -version = "0.25.18" - -[[DocStringExtensions]] -deps = ["LibGit2"] -git-tree-sha1 = "a32185f5428d3986f47c2ab78b1f216d5e6cc96f" -uuid = "ffbed154-4ef7-542d-bbb7-c09d3a79fcae" -version = "0.8.5" - -[[Documenter]] -deps = ["ANSIColoredPrinters", "Base64", "Dates", "DocStringExtensions", "IOCapture", "InteractiveUtils", "JSON", "LibGit2", "Logging", "Markdown", "REPL", "Test", "Unicode"] -git-tree-sha1 = "8b43e37cfb4f4edc2b6180409acc0cebce7fede8" -uuid = "e30172f5-a6a5-5a46-863b-614d45cd2de4" -version = "0.27.7" - -[[Downloads]] -deps = ["ArgTools", "LibCURL", "NetworkOptions"] -uuid = "f43a241f-c20a-4ad4-852c-f6b1247861c6" - -[[EarCut_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "3f3a2501fa7236e9b911e0f7a588c657e822bb6d" -uuid = "5ae413db-bbd1-5e63-b57d-d24a61df00f5" -version = "2.2.3+0" - -[[ElasticArrays]] -deps = ["Adapt"] -git-tree-sha1 = "a0fcc1bb3c9ceaf07e1d0529c9806ce94be6adf9" -uuid = "fdbdab4c-e67f-52f5-8c3f-e7b388dad3d4" -version = "1.2.9" - -[[EllipsisNotation]] -deps = ["ArrayInterface"] -git-tree-sha1 = "8041575f021cba5a099a456b4163c9a08b566a02" -uuid = "da5c29d0-fa7d-589e-88eb-ea29b0a81949" -version = "1.1.0" - -[[Expat_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "b3bfd02e98aedfa5cf885665493c5598c350cd2f" -uuid = "2e619515-83b5-522b-bb60-26c02a35a201" -version = "2.2.10+0" - -[[ExprTools]] -git-tree-sha1 = "b7e3d17636b348f005f11040025ae8c6f645fe92" -uuid = "e2ba6199-217a-4e67-a87a-7c52f15ade04" -version = "0.1.6" - -[[FFMPEG]] -deps = ["FFMPEG_jll"] -git-tree-sha1 = "b57e3acbe22f8484b4b5ff66a7499717fe1a9cc8" -uuid = "c87230d0-a227-11e9-1b43-d7ebe4e7570a" -version = "0.4.1" - -[[FFMPEG_jll]] -deps = ["Artifacts", "Bzip2_jll", "FreeType2_jll", "FriBidi_jll", "JLLWrappers", "LAME_jll", "LibVPX_jll", "Libdl", "Ogg_jll", "OpenSSL_jll", "Opus_jll", "Pkg", "Zlib_jll", "libass_jll", "libfdk_aac_jll", "libvorbis_jll", "x264_jll", "x265_jll"] -git-tree-sha1 = "3cc57ad0a213808473eafef4845a74766242e05f" -uuid = "b22a6f82-2f65-5046-a5b2-351ab43fb4e5" -version = "4.3.1+4" - -[[FileIO]] -deps = ["Pkg", "Requires", "UUIDs"] -git-tree-sha1 = "3c041d2ac0a52a12a27af2782b34900d9c3ee68c" -uuid = "5789e2e9-d7fb-5bc7-8068-2c6fae9b9549" -version = "1.11.1" - -[[FillArrays]] -deps = ["LinearAlgebra", "Random", "SparseArrays", "Statistics"] -git-tree-sha1 = "29890dfbc427afa59598b8cfcc10034719bd7744" -uuid = "1a297f60-69ca-5386-bcde-b61e274b549b" -version = "0.12.6" - -[[FixedPointNumbers]] -deps = ["Statistics"] -git-tree-sha1 = "335bfdceacc84c5cdf16aadc768aa5ddfc5383cc" -uuid = "53c48c17-4a7d-5ca2-90c5-79b7896eea93" -version = "0.8.4" - -[[Flux]] -deps = ["AbstractTrees", "Adapt", "ArrayInterface", "CUDA", "CodecZlib", "Colors", "DelimitedFiles", "Functors", "Juno", "LinearAlgebra", "MacroTools", "NNlib", "NNlibCUDA", "Pkg", "Printf", "Random", "Reexport", "SHA", "SparseArrays", "Statistics", "StatsBase", "Test", "ZipFile", "Zygote"] -git-tree-sha1 = "e4ade0790850bb16b5309945658fa4e7626226f1" -uuid = "587475ba-b771-5e3f-ad9e-33799f191a9c" -version = "0.12.7" - -[[Fontconfig_jll]] -deps = ["Artifacts", "Bzip2_jll", "Expat_jll", "FreeType2_jll", "JLLWrappers", "Libdl", "Libuuid_jll", "Pkg", "Zlib_jll"] -git-tree-sha1 = "35895cf184ceaab11fd778b4590144034a167a2f" -uuid = "a3f928ae-7b40-5064-980b-68af3947d34b" -version = "2.13.1+14" - -[[Formatting]] -deps = ["Printf"] -git-tree-sha1 = "8339d61043228fdd3eb658d86c926cb282ae72a8" -uuid = "59287772-0a20-5a39-b81b-1366585eb4c0" -version = "0.4.2" - -[[ForwardDiff]] -deps = ["CommonSubexpressions", "DiffResults", "DiffRules", "LinearAlgebra", "NaNMath", "Printf", "Random", "SpecialFunctions", "StaticArrays"] -git-tree-sha1 = "c4203b60d37059462af370c4f3108fb5d155ff13" -uuid = "f6369f11-7733-5829-9624-2563aa707210" -version = "0.10.20" - -[[FreeType2_jll]] -deps = ["Artifacts", "Bzip2_jll", "JLLWrappers", "Libdl", "Pkg", "Zlib_jll"] -git-tree-sha1 = "cbd58c9deb1d304f5a245a0b7eb841a2560cfec6" -uuid = "d7e528f0-a631-5988-bf34-fe36492bcfd7" -version = "2.10.1+5" - -[[FriBidi_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "aa31987c2ba8704e23c6c8ba8a4f769d5d7e4f91" -uuid = "559328eb-81f9-559d-9380-de523a88c83c" -version = "1.0.10+0" - -[[Functors]] -git-tree-sha1 = "e2727f02325451f6b24445cd83bfa9aaac19cbe7" -uuid = "d9f16b24-f501-4c13-a1f2-28368ffc5196" -version = "0.2.5" - -[[Future]] -deps = ["Random"] -uuid = "9fa8497b-333b-5362-9e8d-4d0656e87820" - -[[GLFW_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Libglvnd_jll", "Pkg", "Xorg_libXcursor_jll", "Xorg_libXi_jll", "Xorg_libXinerama_jll", "Xorg_libXrandr_jll"] -git-tree-sha1 = "dba1e8614e98949abfa60480b13653813d8f0157" -uuid = "0656b61e-2033-5cc2-a64a-77c0f6c09b89" -version = "3.3.5+0" - -[[GPUArrays]] -deps = ["Adapt", "LinearAlgebra", "Printf", "Random", "Serialization", "Statistics"] -git-tree-sha1 = "7772508f17f1d482fe0df72cabc5b55bec06bbe0" -uuid = "0c68f7d7-f131-5f86-a1c3-88cf8149b2d7" -version = "8.1.2" - -[[GPUCompiler]] -deps = ["ExprTools", "InteractiveUtils", "LLVM", "Libdl", "Logging", "TimerOutputs", "UUIDs"] -git-tree-sha1 = "4ed2616d5e656c8716736b64da86755467f26cf5" -uuid = "61eb1bfa-7361-4325-ad38-22787b887f55" -version = "0.12.9" - -[[GR]] -deps = ["Base64", "DelimitedFiles", "GR_jll", "HTTP", "JSON", "Libdl", "LinearAlgebra", "Pkg", "Printf", "Random", "Serialization", "Sockets", "Test", "UUIDs"] -git-tree-sha1 = "c2178cfbc0a5a552e16d097fae508f2024de61a3" -uuid = "28b8d3ca-fb5f-59d9-8090-bfdbd6d07a71" -version = "0.59.0" - -[[GR_jll]] -deps = ["Artifacts", "Bzip2_jll", "Cairo_jll", "FFMPEG_jll", "Fontconfig_jll", "GLFW_jll", "JLLWrappers", "JpegTurbo_jll", "Libdl", "Libtiff_jll", "Pixman_jll", "Pkg", "Qt5Base_jll", "Zlib_jll", "libpng_jll"] -git-tree-sha1 = "d59e8320c2747553788e4fc42231489cc602fa50" -uuid = "d2c73de3-f751-5644-a686-071e5b155ba9" -version = "0.58.1+0" - -[[GeometryBasics]] -deps = ["EarCut_jll", "IterTools", "LinearAlgebra", "StaticArrays", "StructArrays", "Tables"] -git-tree-sha1 = "58bcdf5ebc057b085e58d95c138725628dd7453c" -uuid = "5c1252a2-5f33-56bf-86c9-59e7332b4326" -version = "0.4.1" - -[[Gettext_jll]] -deps = ["Artifacts", "CompilerSupportLibraries_jll", "JLLWrappers", "Libdl", "Libiconv_jll", "Pkg", "XML2_jll"] -git-tree-sha1 = "9b02998aba7bf074d14de89f9d37ca24a1a0b046" -uuid = "78b55507-aeef-58d4-861c-77aaff3498b1" -version = "0.21.0+0" - -[[Glib_jll]] -deps = ["Artifacts", "Gettext_jll", "JLLWrappers", "Libdl", "Libffi_jll", "Libiconv_jll", "Libmount_jll", "PCRE_jll", "Pkg", "Zlib_jll"] -git-tree-sha1 = "7bf67e9a481712b3dbe9cb3dac852dc4b1162e02" -uuid = "7746bdde-850d-59dc-9ae8-88ece973131d" -version = "2.68.3+0" - -[[Graphics]] -deps = ["Colors", "LinearAlgebra", "NaNMath"] -git-tree-sha1 = "1c5a84319923bea76fa145d49e93aa4394c73fc2" -uuid = "a2bd30eb-e257-5431-a919-1863eab51364" -version = "1.1.1" - -[[GridWorlds]] -deps = ["DataStructures", "REPL", "Random", "ReinforcementLearningBase"] -git-tree-sha1 = "5bf404e98a104a42656aa5d094f07bb37680eb70" -uuid = "e15a9946-cd7f-4d03-83e2-6c30bacb0043" -version = "0.5.0" - -[[Grisu]] -git-tree-sha1 = "53bb909d1151e57e2484c3d1b53e19552b887fb2" -uuid = "42e2da0e-8278-4e71-bc24-59509adca0fe" -version = "1.0.2" - -[[HDF5]] -deps = ["Blosc", "Compat", "HDF5_jll", "Libdl", "Mmap", "Random", "Requires"] -git-tree-sha1 = "83173193dc242ce4b037f0263a7cc45afb5a0b85" -uuid = "f67ccb44-e63f-5c2f-98bd-6dc0ccc4ba2f" -version = "0.15.6" - -[[HDF5_jll]] -deps = ["Artifacts", "JLLWrappers", "LibCURL_jll", "Libdl", "OpenSSL_jll", "Pkg", "Zlib_jll"] -git-tree-sha1 = "fd83fa0bde42e01952757f01149dd968c06c4dba" -uuid = "0234f1f7-429e-5d53-9886-15a909be8d59" -version = "1.12.0+1" - -[[HTTP]] -deps = ["Base64", "Dates", "IniFile", "Logging", "MbedTLS", "NetworkOptions", "Sockets", "URIs"] -git-tree-sha1 = "14eece7a3308b4d8be910e265c724a6ba51a9798" -uuid = "cd3eb016-35fb-5094-929b-558a96fad6f3" -version = "0.9.16" - -[[IOCapture]] -deps = ["Logging", "Random"] -git-tree-sha1 = "f7be53659ab06ddc986428d3a9dcc95f6fa6705a" -uuid = "b5f81e59-6552-4d32-b1f0-c071b021bf89" -version = "0.2.2" - -[[IRTools]] -deps = ["InteractiveUtils", "MacroTools", "Test"] -git-tree-sha1 = "95215cd0076a150ef46ff7928892bc341864c73c" -uuid = "7869d1d1-7146-5819-86e3-90919afe41df" -version = "0.4.3" - -[[IfElse]] -git-tree-sha1 = "28e837ff3e7a6c3cdb252ce49fb412c8eb3caeef" -uuid = "615f187c-cbe4-4ef1-ba3b-2fcf58d6d173" -version = "0.1.0" - -[[ImageBase]] -deps = ["ImageCore", "Reexport"] -git-tree-sha1 = "c107d7eda71edc2284197e6a2fbb377d38fc4ec1" -uuid = "c817782e-172a-44cc-b673-b171935fbb9e" -version = "0.1.4" - -[[ImageCore]] -deps = ["AbstractFFTs", "ColorVectorSpace", "Colors", "FixedPointNumbers", "Graphics", "MappedArrays", "MosaicViews", "OffsetArrays", "PaddedViews", "Reexport"] -git-tree-sha1 = "9a5c62f231e5bba35695a20988fc7cd6de7eeb5a" -uuid = "a09fc81d-aa75-5fe9-8630-4744c3626534" -version = "0.9.3" - -[[ImageTransformations]] -deps = ["AxisAlgorithms", "ColorVectorSpace", "CoordinateTransformations", "ImageBase", "ImageCore", "Interpolations", "OffsetArrays", "Rotations", "StaticArrays"] -git-tree-sha1 = "8efc27e296c91c21fc45d2d3a199c85de52ae853" -uuid = "02fcd773-0e25-5acc-982a-7f6622650795" -version = "0.9.0" - -[[IndirectArrays]] -git-tree-sha1 = "012e604e1c7458645cb8b436f8fba789a51b257f" -uuid = "9b13fd28-a010-5f03-acff-a1bbcff69959" -version = "1.0.0" - -[[IniFile]] -deps = ["Test"] -git-tree-sha1 = "098e4d2c533924c921f9f9847274f2ad89e018b8" -uuid = "83e8ac13-25f8-5344-8a64-a9f2b223428f" -version = "0.5.0" - -[[InteractiveUtils]] -deps = ["Markdown"] -uuid = "b77e0a4c-d291-57a0-90e8-8db25a27a240" - -[[InternedStrings]] -deps = ["Random", "Test"] -git-tree-sha1 = "eb05b5625bc5d821b8075a77e4c421933e20c76b" -uuid = "7d512f48-7fb1-5a58-b986-67e6dc259f01" -version = "0.7.0" - -[[Interpolations]] -deps = ["AxisAlgorithms", "ChainRulesCore", "LinearAlgebra", "OffsetArrays", "Random", "Ratios", "Requires", "SharedArrays", "SparseArrays", "StaticArrays", "WoodburyMatrices"] -git-tree-sha1 = "61aa005707ea2cebf47c8d780da8dc9bc4e0c512" -uuid = "a98d9a8b-a2ab-59e6-89dd-64a1c18fca59" -version = "0.13.4" - -[[IntervalSets]] -deps = ["Dates", "EllipsisNotation", "Statistics"] -git-tree-sha1 = "3cc368af3f110a767ac786560045dceddfc16758" -uuid = "8197267c-284f-5f27-9208-e0e47529a953" -version = "0.5.3" - -[[IrrationalConstants]] -git-tree-sha1 = "f76424439413893a832026ca355fe273e93bce94" -uuid = "92d709cd-6900-40b7-9082-c6be49f344b6" -version = "0.1.0" - -[[IterTools]] -git-tree-sha1 = "05110a2ab1fc5f932622ffea2a003221f4782c18" -uuid = "c8e1da08-722c-5040-9ed9-7db0dc04731e" -version = "1.3.0" - -[[IteratorInterfaceExtensions]] -git-tree-sha1 = "a3f24677c21f5bbe9d2a714f95dcd58337fb2856" -uuid = "82899510-4779-5014-852e-03e436cf321d" -version = "1.0.0" - -[[JLLWrappers]] -deps = ["Preferences"] -git-tree-sha1 = "642a199af8b68253517b80bd3bfd17eb4e84df6e" -uuid = "692b3bcd-3c85-4b1f-b108-f13ce0eb3210" -version = "1.3.0" - -[[JSON]] -deps = ["Dates", "Mmap", "Parsers", "Unicode"] -git-tree-sha1 = "8076680b162ada2a031f707ac7b4953e30667a37" -uuid = "682c06a0-de6a-54ab-a142-c8b1cf79cde6" -version = "0.21.2" - -[[JpegTurbo_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "d735490ac75c5cb9f1b00d8b5509c11984dc6943" -uuid = "aacddb02-875f-59d6-b918-886e6ef4fbf8" -version = "2.1.0+0" - -[[Juno]] -deps = ["Base64", "Logging", "Media", "Profile"] -git-tree-sha1 = "07cb43290a840908a771552911a6274bc6c072c7" -uuid = "e5e0dc1b-0480-54bc-9374-aad01c23163d" -version = "0.8.4" - -[[LAME_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "f6250b16881adf048549549fba48b1161acdac8c" -uuid = "c1c5ebd0-6772-5130-a774-d5fcae4a789d" -version = "3.100.1+0" - -[[LLVM]] -deps = ["CEnum", "LLVMExtra_jll", "Libdl", "Printf", "Unicode"] -git-tree-sha1 = "46092047ca4edc10720ecab437c42283cd7c44f3" -uuid = "929cbde3-209d-540e-8aea-75f648917ca0" -version = "4.6.0" - -[[LLVMExtra_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "6a2af408fe809c4f1a54d2b3f188fdd3698549d6" -uuid = "dad2f222-ce93-54a1-a47d-0025e8a3acab" -version = "0.0.11+0" - -[[LZO_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "e5b909bcf985c5e2605737d2ce278ed791b89be6" -uuid = "dd4b983a-f0e5-5f8d-a1b7-129d4a5fb1ac" -version = "2.10.1+0" - -[[LaTeXStrings]] -git-tree-sha1 = "c7f1c695e06c01b95a67f0cd1d34994f3e7db104" -uuid = "b964fa9f-0449-5b57-a5c2-d3ea65f4040f" -version = "1.2.1" - -[[Latexify]] -deps = ["Formatting", "InteractiveUtils", "LaTeXStrings", "MacroTools", "Markdown", "Printf", "Requires"] -git-tree-sha1 = "a4b12a1bd2ebade87891ab7e36fdbce582301a92" -uuid = "23fbe1c1-3f47-55db-b15f-69d7ec21a316" -version = "0.15.6" - -[[LazyArtifacts]] -deps = ["Artifacts", "Pkg"] -uuid = "4af54fe1-eca0-43a8-85a7-787d91b784e3" - -[[LibArchive_jll]] -deps = ["Artifacts", "Attr_jll", "Bzip2_jll", "Expat_jll", "JLLWrappers", "Libdl", "Libiconv_jll", "Lz4_jll", "OpenSSL_jll", "Pkg", "XZ_jll", "Zlib_jll", "Zstd_jll", "acl_jll"] -git-tree-sha1 = "0d499cd779102298e49ce35cd97cfaadcaf96e09" -uuid = "1e303b3e-d4db-56ce-88c4-91e52606a1a8" -version = "3.5.1+0" - -[[LibCURL]] -deps = ["LibCURL_jll", "MozillaCACerts_jll"] -uuid = "b27032c2-a3e7-50c8-80cd-2d36dbcbfd21" - -[[LibCURL_jll]] -deps = ["Artifacts", "LibSSH2_jll", "Libdl", "MbedTLS_jll", "Zlib_jll", "nghttp2_jll"] -uuid = "deac9b47-8bc7-5906-a0fe-35ac56dc84c0" - -[[LibGit2]] -deps = ["Base64", "NetworkOptions", "Printf", "SHA"] -uuid = "76f85450-5226-5b5a-8eaa-529ad045b433" - -[[LibSSH2_jll]] -deps = ["Artifacts", "Libdl", "MbedTLS_jll"] -uuid = "29816b5a-b9ab-546f-933c-edad1886dfa8" - -[[LibVPX_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "12ee7e23fa4d18361e7c2cde8f8337d4c3101bc7" -uuid = "dd192d2f-8180-539f-9fb4-cc70b1dcf69a" -version = "1.10.0+0" - -[[Libdl]] -uuid = "8f399da3-3557-5675-b5ff-fb832c97cbdb" - -[[Libffi_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "761a393aeccd6aa92ec3515e428c26bf99575b3b" -uuid = "e9f186c6-92d2-5b65-8a66-fee21dc1b490" -version = "3.2.2+0" - -[[Libgcrypt_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Libgpg_error_jll", "Pkg"] -git-tree-sha1 = "64613c82a59c120435c067c2b809fc61cf5166ae" -uuid = "d4300ac3-e22c-5743-9152-c294e39db1e4" -version = "1.8.7+0" - -[[Libglvnd_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libX11_jll", "Xorg_libXext_jll"] -git-tree-sha1 = "7739f837d6447403596a75d19ed01fd08d6f56bf" -uuid = "7e76a0d4-f3c7-5321-8279-8d96eeed0f29" -version = "1.3.0+3" - -[[Libgpg_error_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "c333716e46366857753e273ce6a69ee0945a6db9" -uuid = "7add5ba3-2f88-524e-9cd5-f83b8a55f7b8" -version = "1.42.0+0" - -[[Libiconv_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "42b62845d70a619f063a7da093d995ec8e15e778" -uuid = "94ce4f54-9a6c-5748-9c1c-f9c7231a4531" -version = "1.16.1+1" - -[[Libmount_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "9c30530bf0effd46e15e0fdcf2b8636e78cbbd73" -uuid = "4b2f31a3-9ecc-558c-b454-b3730dcb73e9" -version = "2.35.0+0" - -[[Libtiff_jll]] -deps = ["Artifacts", "JLLWrappers", "JpegTurbo_jll", "Libdl", "Pkg", "Zlib_jll", "Zstd_jll"] -git-tree-sha1 = "340e257aada13f95f98ee352d316c3bed37c8ab9" -uuid = "89763e89-9b03-5906-acba-b20f662cd828" -version = "4.3.0+0" - -[[Libuuid_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "7f3efec06033682db852f8b3bc3c1d2b0a0ab066" -uuid = "38a345b3-de98-5d2b-a5d3-14cd9215e700" -version = "2.36.0+0" - -[[LinearAlgebra]] -deps = ["Libdl"] -uuid = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e" - -[[Literate]] -deps = ["Base64", "IOCapture", "JSON", "REPL"] -git-tree-sha1 = "bbebc3c14dbfbe76bfcbabf0937481ac84dc86ef" -uuid = "98b081ad-f1c9-55d3-8b20-4c87d4299306" -version = "2.9.3" - -[[LogExpFunctions]] -deps = ["ChainRulesCore", "DocStringExtensions", "IrrationalConstants", "LinearAlgebra"] -git-tree-sha1 = "34dc30f868e368f8a17b728a1238f3fcda43931a" -uuid = "2ab3a3ac-af41-5b50-aa03-7779005ae688" -version = "0.3.3" - -[[Logging]] -uuid = "56ddb016-857b-54e1-b83d-db4d58db5568" - -[[Lz4_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "5d494bc6e85c4c9b626ee0cab05daa4085486ab1" -uuid = "5ced341a-0733-55b8-9ab6-a4889d929147" -version = "1.9.3+0" - -[[MD5]] -deps = ["Random", "SHA"] -git-tree-sha1 = "eeffe42284464c35a08026d23aa948421acf8923" -uuid = "6ac74813-4b46-53a4-afec-0b5dc9d7885c" -version = "0.2.1" - -[[MacroTools]] -deps = ["Markdown", "Random"] -git-tree-sha1 = "5a5bc6bf062f0f95e62d0fe0a2d99699fed82dd9" -uuid = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09" -version = "0.5.8" - -[[MappedArrays]] -git-tree-sha1 = "e8b359ef06ec72e8c030463fe02efe5527ee5142" -uuid = "dbb5928d-eab1-5f90-85c2-b9b0edb7c900" -version = "0.4.1" - -[[Markdown]] -deps = ["Base64"] -uuid = "d6f4376e-aef5-505a-96c1-9c027394607a" - -[[MbedTLS]] -deps = ["Dates", "MbedTLS_jll", "Random", "Sockets"] -git-tree-sha1 = "1c38e51c3d08ef2278062ebceade0e46cefc96fe" -uuid = "739be429-bea8-5141-9913-cc70e7f3736d" -version = "1.0.3" - -[[MbedTLS_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "c8ffd9c3-330d-5841-b78e-0817d7145fa1" - -[[Measures]] -git-tree-sha1 = "e498ddeee6f9fdb4551ce855a46f54dbd900245f" -uuid = "442fdcdd-2543-5da2-b0f3-8c86c306513e" -version = "0.3.1" - -[[Media]] -deps = ["MacroTools", "Test"] -git-tree-sha1 = "75a54abd10709c01f1b86b84ec225d26e840ed58" -uuid = "e89f7d12-3494-54d1-8411-f7d8b9ae1f27" -version = "0.5.0" - -[[Missings]] -deps = ["DataAPI"] -git-tree-sha1 = "bf210ce90b6c9eed32d25dbcae1ebc565df2687f" -uuid = "e1d29d7a-bbdc-5cf2-9ac0-f12de2c33e28" -version = "1.0.2" - -[[Mmap]] -uuid = "a63ad114-7e13-5084-954f-fe012c677804" - -[[MosaicViews]] -deps = ["MappedArrays", "OffsetArrays", "PaddedViews", "StackViews"] -git-tree-sha1 = "b34e3bc3ca7c94914418637cb10cc4d1d80d877d" -uuid = "e94cdb99-869f-56ef-bcf0-1ae2bcbe0389" -version = "0.3.3" - -[[MozillaCACerts_jll]] -uuid = "14a3606d-f60d-562e-9121-12d972cd8159" - -[[Mustache]] -deps = ["Printf", "Tables"] -git-tree-sha1 = "36995ef0d532fe08119d70b2365b7b03d4e00f48" -uuid = "ffc61752-8dc7-55ee-8c37-f3e9cdd09e70" -version = "1.0.10" - -[[NNlib]] -deps = ["Adapt", "ChainRulesCore", "Compat", "LinearAlgebra", "Pkg", "Requires", "Statistics"] -git-tree-sha1 = "5203a4532ad28c44f82c76634ad621d7c90abcbd" -uuid = "872c559c-99b0-510c-b3b7-b6c96a88d5cd" -version = "0.7.29" - -[[NNlibCUDA]] -deps = ["CUDA", "LinearAlgebra", "NNlib", "Random", "Statistics"] -git-tree-sha1 = "04490d5e7570c038b1cb0f5c3627597181cc15a9" -uuid = "a00861dc-f156-4864-bf3c-e6376f28a68d" -version = "0.1.9" - -[[NPZ]] -deps = ["Compat", "ZipFile"] -git-tree-sha1 = "fbfb3c151b0308236d854c555b43cdd84c1e5ebf" -uuid = "15e1cf62-19b3-5cfa-8e77-841668bca605" -version = "0.4.1" - -[[NaNMath]] -git-tree-sha1 = "bfe47e760d60b82b66b61d2d44128b62e3a369fb" -uuid = "77ba4419-2d1f-58cd-9bb1-8ffee604a2e3" -version = "0.3.5" - -[[NetworkOptions]] -uuid = "ca575930-c2e3-43a9-ace4-1e988b2c1908" - -[[OffsetArrays]] -deps = ["Adapt"] -git-tree-sha1 = "c0e9e582987d36d5a61e650e6e543b9e44d9914b" -uuid = "6fe1bfb0-de20-5000-8ca7-80f57d26f881" -version = "1.10.7" - -[[Ogg_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "7937eda4681660b4d6aeeecc2f7e1c81c8ee4e2f" -uuid = "e7412a2a-1a6e-54c0-be00-318e2571c051" -version = "1.3.5+0" - -[[OpenLibm_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "05823500-19ac-5b8b-9628-191a04bc5112" - -[[OpenSSL_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "15003dcb7d8db3c6c857fda14891a539a8f2705a" -uuid = "458c3c95-2e84-50aa-8efc-19380b2a3a95" -version = "1.1.10+0" - -[[OpenSpecFun_jll]] -deps = ["Artifacts", "CompilerSupportLibraries_jll", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "13652491f6856acfd2db29360e1bbcd4565d04f1" -uuid = "efe28fd5-8261-553b-a9e1-b2916fc3738e" -version = "0.5.5+0" - -[[OpenSpiel]] -deps = ["CxxWrap", "OpenSpiel_jll"] -git-tree-sha1 = "5705a2a164b79f8c10f4e676fd1d8c83f98c6da1" -uuid = "ceb70bd2-fe3f-44f0-b81f-41608acaf2f2" -version = "0.1.3" - -[[OpenSpiel_jll]] -deps = ["Libdl", "Pkg", "libcxxwrap_julia_jll"] -git-tree-sha1 = "a44c691873525601fedee550113c9b620b6d5475" -uuid = "bd10a763-4654-5023-a028-c4918c6cd33e" -version = "0.1.2+0" - -[[Opus_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "51a08fb14ec28da2ec7a927c4337e4332c2a4720" -uuid = "91d4177d-7536-5919-b921-800302f37372" -version = "1.3.2+0" - -[[OrderedCollections]] -git-tree-sha1 = "85f8e6578bf1f9ee0d11e7bb1b1456435479d47c" -uuid = "bac558e1-5e72-5ebc-8fee-abe8a469f55d" -version = "1.4.1" - -[[PCRE_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "b2a7af664e098055a7529ad1a900ded962bca488" -uuid = "2f80f16e-611a-54ab-bc61-aa92de5b98fc" -version = "8.44.0+0" - -[[PDMats]] -deps = ["LinearAlgebra", "SparseArrays", "SuiteSparse"] -git-tree-sha1 = "4dd403333bcf0909341cfe57ec115152f937d7d8" -uuid = "90014a1f-27ba-587c-ab20-58faa44d9150" -version = "0.11.1" - -[[PNGFiles]] -deps = ["Base64", "CEnum", "ImageCore", "IndirectArrays", "OffsetArrays", "libpng_jll"] -git-tree-sha1 = "85e3436b18980e47604dd0909e37e2f066f54398" -uuid = "f57f5aa1-a3ce-4bc8-8ab9-96f992907883" -version = "0.3.10" - -[[PaddedViews]] -deps = ["OffsetArrays"] -git-tree-sha1 = "646eed6f6a5d8df6708f15ea7e02a7a2c4fe4800" -uuid = "5432bcbf-9aad-5242-b902-cca2824c8663" -version = "0.5.10" - -[[Parsers]] -deps = ["Dates"] -git-tree-sha1 = "a8709b968a1ea6abc2dc1967cb1db6ac9a00dfb6" -uuid = "69de0a69-1ddd-5017-9359-2bf0b02dc9f0" -version = "2.0.5" - -[[Pickle]] -deps = ["DataStructures", "InternedStrings", "Serialization", "SparseArrays", "Strided", "ZipFile"] -git-tree-sha1 = "32b02a862b214ea4c7f250fab1d7af5149226191" -uuid = "fbb45041-c46e-462f-888f-7c521cafbc2c" -version = "0.2.7" - -[[Pipe]] -git-tree-sha1 = "6842804e7867b115ca9de748a0cf6b364523c16d" -uuid = "b98c9c47-44ae-5843-9183-064241ee97a0" -version = "1.3.0" - -[[Pixman_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "b4f5d02549a10e20780a24fce72bea96b6329e29" -uuid = "30392449-352a-5448-841d-b1acce4e97dc" -version = "0.40.1+0" - -[[Pkg]] -deps = ["Artifacts", "Dates", "Downloads", "LibGit2", "Libdl", "Logging", "Markdown", "Printf", "REPL", "Random", "SHA", "Serialization", "TOML", "Tar", "UUIDs", "p7zip_jll"] -uuid = "44cfe95a-1eb2-52ea-b672-e2afdf69b78f" - -[[PlotThemes]] -deps = ["PlotUtils", "Requires", "Statistics"] -git-tree-sha1 = "a3a964ce9dc7898193536002a6dd892b1b5a6f1d" -uuid = "ccf2f8ad-2431-5c83-bf29-c5338b663b6a" -version = "2.0.1" - -[[PlotUtils]] -deps = ["ColorSchemes", "Colors", "Dates", "Printf", "Random", "Reexport", "Statistics"] -git-tree-sha1 = "b084324b4af5a438cd63619fd006614b3b20b87b" -uuid = "995b91a9-d308-5afd-9ec6-746e21dbc043" -version = "1.0.15" - -[[Plots]] -deps = ["Base64", "Contour", "Dates", "Downloads", "FFMPEG", "FixedPointNumbers", "GR", "GeometryBasics", "JSON", "Latexify", "LinearAlgebra", "Measures", "NaNMath", "PlotThemes", "PlotUtils", "Printf", "REPL", "Random", "RecipesBase", "RecipesPipeline", "Reexport", "Requires", "Scratch", "Showoff", "SparseArrays", "Statistics", "StatsBase", "UUIDs"] -git-tree-sha1 = "6841db754bd01a91d281370d9a0f8787e220ae08" -uuid = "91a5bcdd-55d7-5caf-9e0b-520d859cae80" -version = "1.22.4" - -[[Preferences]] -deps = ["TOML"] -git-tree-sha1 = "00cfd92944ca9c760982747e9a1d0d5d86ab1e5a" -uuid = "21216c6a-2e73-6563-6e65-726566657250" -version = "1.2.2" - -[[Printf]] -deps = ["Unicode"] -uuid = "de0858da-6303-5e67-8744-51eddeeeb8d7" - -[[Profile]] -deps = ["Printf"] -uuid = "9abbd945-dff8-562f-b5e8-e1ebf5ef1b79" - -[[ProgressMeter]] -deps = ["Distributed", "Printf"] -git-tree-sha1 = "afadeba63d90ff223a6a48d2009434ecee2ec9e8" -uuid = "92933f4c-e287-5a05-a399-4b506db050ca" -version = "1.7.1" - -[[ProtoBuf]] -deps = ["Compat", "Logging"] -git-tree-sha1 = "9ecf92287404ebe5666a1c0488c3aaf90bbb5ff4" -uuid = "3349acd9-ac6a-5e09-bcdb-63829b23a429" -version = "0.10.0" - -[[PyCall]] -deps = ["Conda", "Dates", "Libdl", "LinearAlgebra", "MacroTools", "Serialization", "VersionParsing"] -git-tree-sha1 = "169bb8ea6b1b143c5cf57df6d34d022a7b60c6db" -uuid = "438e738f-606a-5dbb-bf0a-cddfbfd45ab0" -version = "1.92.3" - -[[PyPlot]] -deps = ["Colors", "LaTeXStrings", "PyCall", "Sockets", "Test", "VersionParsing"] -git-tree-sha1 = "14c1b795b9d764e1784713941e787e1384268103" -uuid = "d330b81b-6aea-500a-939a-2ce795aea3ee" -version = "2.10.0" - -[[Qt5Base_jll]] -deps = ["Artifacts", "CompilerSupportLibraries_jll", "Fontconfig_jll", "Glib_jll", "JLLWrappers", "Libdl", "Libglvnd_jll", "OpenSSL_jll", "Pkg", "Xorg_libXext_jll", "Xorg_libxcb_jll", "Xorg_xcb_util_image_jll", "Xorg_xcb_util_keysyms_jll", "Xorg_xcb_util_renderutil_jll", "Xorg_xcb_util_wm_jll", "Zlib_jll", "xkbcommon_jll"] -git-tree-sha1 = "ad368663a5e20dbb8d6dc2fddeefe4dae0781ae8" -uuid = "ea2cea3b-5b76-57ae-a6ef-0a8af62496e1" -version = "5.15.3+0" - -[[QuadGK]] -deps = ["DataStructures", "LinearAlgebra"] -git-tree-sha1 = "78aadffb3efd2155af139781b8a8df1ef279ea39" -uuid = "1fd47b50-473d-5c70-9696-f719f8f3bcdc" -version = "2.4.2" - -[[REPL]] -deps = ["InteractiveUtils", "Markdown", "Sockets", "Unicode"] -uuid = "3fa0cd96-eef1-5676-8a61-b3b8758bbffb" - -[[Random]] -deps = ["Serialization"] -uuid = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c" - -[[Random123]] -deps = ["Libdl", "Random", "RandomNumbers"] -git-tree-sha1 = "0e8b146557ad1c6deb1367655e052276690e71a3" -uuid = "74087812-796a-5b5d-8853-05524746bad3" -version = "1.4.2" - -[[RandomNumbers]] -deps = ["Random", "Requires"] -git-tree-sha1 = "043da614cc7e95c703498a491e2c21f58a2b8111" -uuid = "e6cf234a-135c-5ec9-84dd-332b85af5143" -version = "1.5.3" - -[[Ratios]] -deps = ["Requires"] -git-tree-sha1 = "01d341f502250e81f6fec0afe662aa861392a3aa" -uuid = "c84ed2f1-dad5-54f0-aa8e-dbefe2724439" -version = "0.4.2" - -[[RecipesBase]] -git-tree-sha1 = "44a75aa7a527910ee3d1751d1f0e4148698add9e" -uuid = "3cdcf5f2-1ef4-517c-9805-6587b60abb01" -version = "1.1.2" - -[[RecipesPipeline]] -deps = ["Dates", "NaNMath", "PlotUtils", "RecipesBase"] -git-tree-sha1 = "7ad0dfa8d03b7bcf8c597f59f5292801730c55b8" -uuid = "01d81517-befc-4cb6-b9ec-a95719d0359c" -version = "0.4.1" - -[[Reexport]] -git-tree-sha1 = "45e428421666073eab6f2da5c9d310d99bb12f9b" -uuid = "189a3867-3050-52da-a836-e630ba90ab69" -version = "1.2.2" - -[[ReinforcementLearning]] -deps = ["Reexport", "ReinforcementLearningBase", "ReinforcementLearningCore", "ReinforcementLearningEnvironments", "ReinforcementLearningZoo"] -path = ".." -uuid = "158674fc-8238-5cab-b5ba-03dfc80d1318" -version = "0.10.0" - -[[ReinforcementLearningBase]] -deps = ["AbstractTrees", "CommonRLInterface", "Markdown", "Random", "Test"] -path = "../src/ReinforcementLearningBase" -uuid = "e575027e-6cd6-5018-9292-cdc6200d2b44" -version = "0.9.7" - -[[ReinforcementLearningCore]] -deps = ["AbstractTrees", "Adapt", "ArrayInterface", "CUDA", "CircularArrayBuffers", "Compat", "Dates", "Distributions", "ElasticArrays", "FillArrays", "Flux", "Functors", "GPUArrays", "LinearAlgebra", "MacroTools", "Markdown", "ProgressMeter", "Random", "ReinforcementLearningBase", "Setfield", "Statistics", "StatsBase", "UnicodePlots", "Zygote"] -path = "../src/ReinforcementLearningCore" -uuid = "de1b191a-4ae0-4afa-a27b-92d07f46b2d6" -version = "0.8.4" - -[[ReinforcementLearningDatasets]] -deps = ["CodecZlib", "DataDeps", "Flux", "HDF5", "ImageCore", "NPZ", "PNGFiles", "Pickle", "Pipe", "Printf", "ProgressMeter", "PyCall", "Random", "ReinforcementLearningBase", "ReinforcementLearningEnvironments", "Setfield", "TFRecord", "UnicodePlots"] -path = "../src/ReinforcementLearningDatasets" -uuid = "dd1544ca-2576-438c-a599-ae96278fd687" -version = "0.1.0" - -[[ReinforcementLearningEnvironments]] -deps = ["DelimitedFiles", "IntervalSets", "LinearAlgebra", "MacroTools", "Markdown", "Pkg", "Random", "ReinforcementLearningBase", "Requires", "SparseArrays", "StatsBase"] -path = "../src/ReinforcementLearningEnvironments" -uuid = "25e41dd2-4622-11e9-1641-f1adca772921" -version = "0.6.3" - -[[ReinforcementLearningZoo]] -deps = ["AbstractTrees", "CUDA", "CircularArrayBuffers", "DataStructures", "Dates", "Distributions", "Flux", "IntervalSets", "LinearAlgebra", "Logging", "MacroTools", "Random", "ReinforcementLearningBase", "ReinforcementLearningCore", "Setfield", "Statistics", "StatsBase", "StructArrays", "Zygote"] -path = "../src/ReinforcementLearningZoo" -uuid = "d607f57d-ee1e-4ba7-bcf2-7734c1e31854" -version = "0.5.1" - -[[Requires]] -deps = ["UUIDs"] -git-tree-sha1 = "4036a3bd08ac7e968e27c203d45f5fff15020621" -uuid = "ae029012-a4dd-5104-9daa-d747884805df" -version = "1.1.3" - -[[Rmath]] -deps = ["Random", "Rmath_jll"] -git-tree-sha1 = "bf3188feca147ce108c76ad82c2792c57abe7b1f" -uuid = "79098fc4-a85e-5d69-aa6a-4863f24498fa" -version = "0.7.0" - -[[Rmath_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "68db32dff12bb6127bac73c209881191bf0efbb7" -uuid = "f50d1b31-88e8-58de-be2c-1cc44531875f" -version = "0.3.0+0" - -[[Rotations]] -deps = ["LinearAlgebra", "StaticArrays", "Statistics"] -git-tree-sha1 = "2ed8d8a16d703f900168822d83699b8c3c1a5cd8" -uuid = "6038ab10-8711-5258-84ad-4b1120ba62dc" -version = "1.0.2" - -[[SHA]] -uuid = "ea8e919c-243c-51af-8825-aaa63cd721ce" - -[[Scratch]] -deps = ["Dates"] -git-tree-sha1 = "0b4b7f1393cff97c33891da2a0bf69c6ed241fda" -uuid = "6c6a2e73-6563-6170-7368-637461726353" -version = "1.1.0" - -[[Serialization]] -uuid = "9e88b42a-f829-5b0c-bbe9-9e923198166b" - -[[Setfield]] -deps = ["ConstructionBase", "Future", "MacroTools", "Requires"] -git-tree-sha1 = "fca29e68c5062722b5b4435594c3d1ba557072a3" -uuid = "efcf1570-3423-57d1-acb7-fd33fddbac46" -version = "0.7.1" - -[[SharedArrays]] -deps = ["Distributed", "Mmap", "Random", "Serialization"] -uuid = "1a1011a3-84de-559e-8e89-a11a2f7dc383" - -[[Showoff]] -deps = ["Dates", "Grisu"] -git-tree-sha1 = "91eddf657aca81df9ae6ceb20b959ae5653ad1de" -uuid = "992d4aef-0814-514b-bc4d-f2e9a6c4116f" -version = "1.0.3" - -[[Sockets]] -uuid = "6462fe0b-24de-5631-8697-dd941f90decc" - -[[SortingAlgorithms]] -deps = ["DataStructures"] -git-tree-sha1 = "b3363d7460f7d098ca0912c69b082f75625d7508" -uuid = "a2af1166-a08f-5f64-846c-94a0d3cef48c" -version = "1.0.1" - -[[SparseArrays]] -deps = ["LinearAlgebra", "Random"] -uuid = "2f01184e-e22b-5df5-ae63-d93ebab69eaf" - -[[SpecialFunctions]] -deps = ["ChainRulesCore", "IrrationalConstants", "LogExpFunctions", "OpenLibm_jll", "OpenSpecFun_jll"] -git-tree-sha1 = "793793f1df98e3d7d554b65a107e9c9a6399a6ed" -uuid = "276daf66-3868-5448-9aa4-cd146d93841b" -version = "1.7.0" - -[[StableRNGs]] -deps = ["Random", "Test"] -git-tree-sha1 = "3be7d49667040add7ee151fefaf1f8c04c8c8276" -uuid = "860ef19b-820b-49d6-a774-d7a799459cd3" -version = "1.0.0" - -[[StackViews]] -deps = ["OffsetArrays"] -git-tree-sha1 = "46e589465204cd0c08b4bd97385e4fa79a0c770c" -uuid = "cae243ae-269e-4f55-b966-ac2d0dc13c15" -version = "0.1.1" - -[[Static]] -deps = ["IfElse"] -git-tree-sha1 = "a8f30abc7c64a39d389680b74e749cf33f872a70" -uuid = "aedffcd0-7271-4cad-89d0-dc628f76c6d3" -version = "0.3.3" - -[[StaticArrays]] -deps = ["LinearAlgebra", "Random", "Statistics"] -git-tree-sha1 = "3c76dde64d03699e074ac02eb2e8ba8254d428da" -uuid = "90137ffa-7385-5640-81b9-e52037218182" -version = "1.2.13" - -[[Statistics]] -deps = ["LinearAlgebra", "SparseArrays"] -uuid = "10745b16-79ce-11e8-11f9-7d13ad32a3b2" - -[[StatsAPI]] -git-tree-sha1 = "1958272568dc176a1d881acb797beb909c785510" -uuid = "82ae8749-77ed-4fe6-ae5f-f523153014b0" -version = "1.0.0" - -[[StatsBase]] -deps = ["DataAPI", "DataStructures", "LinearAlgebra", "Missings", "Printf", "Random", "SortingAlgorithms", "SparseArrays", "Statistics", "StatsAPI"] -git-tree-sha1 = "8cbbc098554648c84f79a463c9ff0fd277144b6c" -uuid = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91" -version = "0.33.10" - -[[StatsFuns]] -deps = ["ChainRulesCore", "IrrationalConstants", "LogExpFunctions", "Reexport", "Rmath", "SpecialFunctions"] -git-tree-sha1 = "95072ef1a22b057b1e80f73c2a89ad238ae4cfff" -uuid = "4c63d2b9-4356-54db-8cca-17b64c39e42c" -version = "0.9.12" - -[[Strided]] -deps = ["LinearAlgebra", "TupleTools"] -git-tree-sha1 = "4d581938087ca90eab9bd4bb6d270edaefd70dcd" -uuid = "5e0ebb24-38b0-5f93-81fe-25c709ecae67" -version = "1.1.2" - -[[StringEncodings]] -deps = ["Libiconv_jll"] -git-tree-sha1 = "50ccd5ddb00d19392577902f0079267a72c5ab04" -uuid = "69024149-9ee7-55f6-a4c4-859efe599b68" -version = "0.3.5" - -[[StructArrays]] -deps = ["Adapt", "DataAPI", "StaticArrays", "Tables"] -git-tree-sha1 = "2ce41e0d042c60ecd131e9fb7154a3bfadbf50d3" -uuid = "09ab397b-f2b6-538f-b94a-2f83cf4a842a" -version = "0.6.3" - -[[SuiteSparse]] -deps = ["Libdl", "LinearAlgebra", "Serialization", "SparseArrays"] -uuid = "4607b0f0-06f3-5cda-b6b1-a6196a1729e9" - -[[Suppressor]] -git-tree-sha1 = "a819d77f31f83e5792a76081eee1ea6342ab8787" -uuid = "fd094767-a336-5f1f-9728-57cf17d0bbfb" -version = "0.2.0" - -[[TFRecord]] -deps = ["BufferedStreams", "CRC32c", "CodecZlib", "MacroTools", "Printf", "ProtoBuf", "Random"] -git-tree-sha1 = "5e457661947084eecbe1934706a1c5f2a31671be" -uuid = "841416d8-1a6a-485a-b0fc-1328d0f53d5e" -version = "0.3.0" - -[[TOML]] -deps = ["Dates"] -uuid = "fa267f1f-6049-4f14-aa54-33bafae1ed76" - -[[TableTraits]] -deps = ["IteratorInterfaceExtensions"] -git-tree-sha1 = "c06b2f539df1c6efa794486abfb6ed2022561a39" -uuid = "3783bdb8-4a98-5b6b-af9a-565f29a5fe9c" -version = "1.0.1" - -[[Tables]] -deps = ["DataAPI", "DataValueInterfaces", "IteratorInterfaceExtensions", "LinearAlgebra", "TableTraits", "Test"] -git-tree-sha1 = "fed34d0e71b91734bf0a7e10eb1bb05296ddbcd0" -uuid = "bd369af6-aec1-5ad0-b16a-f7cc5008161c" -version = "1.6.0" - -[[Tar]] -deps = ["ArgTools", "SHA"] -uuid = "a4e569a6-e804-4fa4-b0f3-eef7a1d5b13e" - -[[TensorBoardLogger]] -deps = ["CRC32c", "FileIO", "ImageCore", "ProtoBuf", "Requires", "StatsBase"] -git-tree-sha1 = "96d160e85038f6d89e6c9b91492466f9a7d454f2" -uuid = "899adc3e-224a-11e9-021f-63837185c80f" -version = "0.1.18" - -[[TensorCore]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "1feb45f88d133a655e001435632f019a9a1bcdb6" -uuid = "62fd8b95-f654-4bbd-a8a5-9c27f68ccd50" -version = "0.1.1" - -[[Test]] -deps = ["InteractiveUtils", "Logging", "Random", "Serialization"] -uuid = "8dfed614-e22c-5e08-85e1-65c5234f0b40" - -[[TimerOutputs]] -deps = ["ExprTools", "Printf"] -git-tree-sha1 = "7cb456f358e8f9d102a8b25e8dfedf58fa5689bc" -uuid = "a759f4b9-e2f1-59dc-863e-4aeb61b1ea8f" -version = "0.5.13" - -[[TranscodingStreams]] -deps = ["Random", "Test"] -git-tree-sha1 = "216b95ea110b5972db65aa90f88d8d89dcb8851c" -uuid = "3bb67fe8-82b1-5028-8e26-92a6c54297fa" -version = "0.9.6" - -[[TupleTools]] -git-tree-sha1 = "3c712976c47707ff893cf6ba4354aa14db1d8938" -uuid = "9d95972d-f1c8-5527-a6e0-b4b365fa01f6" -version = "1.3.0" - -[[URIs]] -git-tree-sha1 = "97bbe755a53fe859669cd907f2d96aee8d2c1355" -uuid = "5c2747f8-b7ea-4ff2-ba2e-563bfd36b1d4" -version = "1.3.0" - -[[UUIDs]] -deps = ["Random", "SHA"] -uuid = "cf7118a7-6976-5b1a-9a39-7adc72f591a4" - -[[Unicode]] -uuid = "4ec0a83e-493e-50e2-b9ac-8f72acf5a8f5" - -[[UnicodePlots]] -deps = ["Crayons", "Dates", "SparseArrays", "StatsBase"] -git-tree-sha1 = "dc9c7086d41783f14d215ea0ddcca8037a8691e9" -uuid = "b8865327-cd53-5732-bb35-84acbb429228" -version = "1.4.0" - -[[VersionParsing]] -git-tree-sha1 = "80229be1f670524750d905f8fc8148e5a8c4537f" -uuid = "81def892-9a0e-5fdd-b105-ffc91e053289" -version = "1.2.0" - -[[Wayland_jll]] -deps = ["Artifacts", "Expat_jll", "JLLWrappers", "Libdl", "Libffi_jll", "Pkg", "XML2_jll"] -git-tree-sha1 = "3e61f0b86f90dacb0bc0e73a0c5a83f6a8636e23" -uuid = "a2964d1f-97da-50d4-b82a-358c7fce9d89" -version = "1.19.0+0" - -[[Wayland_protocols_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Wayland_jll"] -git-tree-sha1 = "2839f1c1296940218e35df0bbb220f2a79686670" -uuid = "2381bf8a-dfd0-557d-9999-79630e7b1b91" -version = "1.18.0+4" - -[[WoodburyMatrices]] -deps = ["LinearAlgebra", "SparseArrays"] -git-tree-sha1 = "59e2ad8fd1591ea019a5259bd012d7aee15f995c" -uuid = "efce3f68-66dc-5838-9240-27a6d6f5f9b6" -version = "0.5.3" - -[[XML2_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Libiconv_jll", "Pkg", "Zlib_jll"] -git-tree-sha1 = "1acf5bdf07aa0907e0a37d3718bb88d4b687b74a" -uuid = "02c8fc9c-b97f-50b9-bbe4-9be30ff0a78a" -version = "2.9.12+0" - -[[XSLT_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Libgcrypt_jll", "Libgpg_error_jll", "Libiconv_jll", "Pkg", "XML2_jll", "Zlib_jll"] -git-tree-sha1 = "91844873c4085240b95e795f692c4cec4d805f8a" -uuid = "aed1982a-8fda-507f-9586-7b0439959a61" -version = "1.1.34+0" - -[[XZ_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "a921669cd9a45c23031fd4eb904f5cc3d20de415" -uuid = "ffd25f8a-64ca-5728-b0f7-c24cf3aae800" -version = "5.2.5+2" - -[[Xorg_libX11_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libxcb_jll", "Xorg_xtrans_jll"] -git-tree-sha1 = "5be649d550f3f4b95308bf0183b82e2582876527" -uuid = "4f6342f7-b3d2-589e-9d20-edeb45f2b2bc" -version = "1.6.9+4" - -[[Xorg_libXau_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "4e490d5c960c314f33885790ed410ff3a94ce67e" -uuid = "0c0b7dd1-d40b-584c-a123-a41640f87eec" -version = "1.0.9+4" - -[[Xorg_libXcursor_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libXfixes_jll", "Xorg_libXrender_jll"] -git-tree-sha1 = "12e0eb3bc634fa2080c1c37fccf56f7c22989afd" -uuid = "935fb764-8cf2-53bf-bb30-45bb1f8bf724" -version = "1.2.0+4" - -[[Xorg_libXdmcp_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "4fe47bd2247248125c428978740e18a681372dd4" -uuid = "a3789734-cfe1-5b06-b2d0-1dd0d9d62d05" -version = "1.1.3+4" - -[[Xorg_libXext_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libX11_jll"] -git-tree-sha1 = "b7c0aa8c376b31e4852b360222848637f481f8c3" -uuid = "1082639a-0dae-5f34-9b06-72781eeb8cb3" -version = "1.3.4+4" - -[[Xorg_libXfixes_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libX11_jll"] -git-tree-sha1 = "0e0dc7431e7a0587559f9294aeec269471c991a4" -uuid = "d091e8ba-531a-589c-9de9-94069b037ed8" -version = "5.0.3+4" - -[[Xorg_libXi_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libXext_jll", "Xorg_libXfixes_jll"] -git-tree-sha1 = "89b52bc2160aadc84d707093930ef0bffa641246" -uuid = "a51aa0fd-4e3c-5386-b890-e753decda492" -version = "1.7.10+4" - -[[Xorg_libXinerama_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libXext_jll"] -git-tree-sha1 = "26be8b1c342929259317d8b9f7b53bf2bb73b123" -uuid = "d1454406-59df-5ea1-beac-c340f2130bc3" -version = "1.1.4+4" - -[[Xorg_libXrandr_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libXext_jll", "Xorg_libXrender_jll"] -git-tree-sha1 = "34cea83cb726fb58f325887bf0612c6b3fb17631" -uuid = "ec84b674-ba8e-5d96-8ba1-2a689ba10484" -version = "1.5.2+4" - -[[Xorg_libXrender_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libX11_jll"] -git-tree-sha1 = "19560f30fd49f4d4efbe7002a1037f8c43d43b96" -uuid = "ea2f1a96-1ddc-540d-b46f-429655e07cfa" -version = "0.9.10+4" - -[[Xorg_libpthread_stubs_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "6783737e45d3c59a4a4c4091f5f88cdcf0908cbb" -uuid = "14d82f49-176c-5ed1-bb49-ad3f5cbd8c74" -version = "0.1.0+3" - -[[Xorg_libxcb_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "XSLT_jll", "Xorg_libXau_jll", "Xorg_libXdmcp_jll", "Xorg_libpthread_stubs_jll"] -git-tree-sha1 = "daf17f441228e7a3833846cd048892861cff16d6" -uuid = "c7cfdc94-dc32-55de-ac96-5a1b8d977c5b" -version = "1.13.0+3" - -[[Xorg_libxkbfile_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libX11_jll"] -git-tree-sha1 = "926af861744212db0eb001d9e40b5d16292080b2" -uuid = "cc61e674-0454-545c-8b26-ed2c68acab7a" -version = "1.1.0+4" - -[[Xorg_xcb_util_image_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_xcb_util_jll"] -git-tree-sha1 = "0fab0a40349ba1cba2c1da699243396ff8e94b97" -uuid = "12413925-8142-5f55-bb0e-6d7ca50bb09b" -version = "0.4.0+1" - -[[Xorg_xcb_util_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libxcb_jll"] -git-tree-sha1 = "e7fd7b2881fa2eaa72717420894d3938177862d1" -uuid = "2def613f-5ad1-5310-b15b-b15d46f528f5" -version = "0.4.0+1" - -[[Xorg_xcb_util_keysyms_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_xcb_util_jll"] -git-tree-sha1 = "d1151e2c45a544f32441a567d1690e701ec89b00" -uuid = "975044d2-76e6-5fbe-bf08-97ce7c6574c7" -version = "0.4.0+1" - -[[Xorg_xcb_util_renderutil_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_xcb_util_jll"] -git-tree-sha1 = "dfd7a8f38d4613b6a575253b3174dd991ca6183e" -uuid = "0d47668e-0667-5a69-a72c-f761630bfb7e" -version = "0.3.9+1" - -[[Xorg_xcb_util_wm_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_xcb_util_jll"] -git-tree-sha1 = "e78d10aab01a4a154142c5006ed44fd9e8e31b67" -uuid = "c22f9ab0-d5fe-5066-847c-f4bb1cd4e361" -version = "0.4.1+1" - -[[Xorg_xkbcomp_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libxkbfile_jll"] -git-tree-sha1 = "4bcbf660f6c2e714f87e960a171b119d06ee163b" -uuid = "35661453-b289-5fab-8a00-3d9160c6a3a4" -version = "1.4.2+4" - -[[Xorg_xkeyboard_config_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_xkbcomp_jll"] -git-tree-sha1 = "5c8424f8a67c3f2209646d4425f3d415fee5931d" -uuid = "33bec58e-1273-512f-9401-5d533626f822" -version = "2.27.0+4" - -[[Xorg_xtrans_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "79c31e7844f6ecf779705fbc12146eb190b7d845" -uuid = "c5fb5394-a638-5e4d-96e5-b29de1b5cf10" -version = "1.4.0+3" - -[[YAML]] -deps = ["Base64", "Dates", "Printf", "StringEncodings"] -git-tree-sha1 = "3c6e8b9f5cdaaa21340f841653942e1a6b6561e5" -uuid = "ddb6d928-2868-570f-bddf-ab3f9cf99eb6" -version = "0.4.7" - -[[ZipFile]] -deps = ["Libdl", "Printf", "Zlib_jll"] -git-tree-sha1 = "3593e69e469d2111389a9bd06bac1f3d730ac6de" -uuid = "a5390f91-8eb1-5f08-bee0-b1d1ffed6cea" -version = "0.9.4" - -[[Zlib_jll]] -deps = ["Libdl"] -uuid = "83775a58-1f1d-513f-b197-d71354ab007a" - -[[Zstd_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "cc4bf3fdde8b7e3e9fa0351bdeedba1cf3b7f6e6" -uuid = "3161d3a3-bdf6-5164-811a-617609db77b4" -version = "1.5.0+0" - -[[Zygote]] -deps = ["AbstractFFTs", "ChainRules", "ChainRulesCore", "DiffRules", "Distributed", "FillArrays", "ForwardDiff", "IRTools", "InteractiveUtils", "LinearAlgebra", "MacroTools", "NaNMath", "Random", "Requires", "SpecialFunctions", "Statistics", "ZygoteRules"] -git-tree-sha1 = "78bdfa26eb61600038461229bcd7a5b6f6bb32e4" -uuid = "e88e6eb3-aa80-5325-afca-941959d7151f" -version = "0.6.26" - -[[ZygoteRules]] -deps = ["MacroTools"] -git-tree-sha1 = "8c1a8e4dfacb1fd631745552c8db35d0deb09ea0" -uuid = "700de1a5-db45-46bc-99cf-38207098b444" -version = "0.2.2" - -[[acl_jll]] -deps = ["Artifacts", "Attr_jll", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "4a59345d2f8088bc358f6fa7f0774b7d9ee30b40" -uuid = "ed5aba05-e74d-5cf7-8b09-107ba3463b8e" -version = "2.3.1+0" - -[[libass_jll]] -deps = ["Artifacts", "Bzip2_jll", "FreeType2_jll", "FriBidi_jll", "JLLWrappers", "Libdl", "Pkg", "Zlib_jll"] -git-tree-sha1 = "acc685bcf777b2202a904cdcb49ad34c2fa1880c" -uuid = "0ac62f75-1d6f-5e53-bd7c-93b484bb37c0" -version = "0.14.0+4" - -[[libcxxwrap_julia_jll]] -deps = ["Libdl", "Pkg"] -git-tree-sha1 = "b7594ea3040804e12eddebd977ec856ec0a17f19" -uuid = "3eaa8342-bff7-56a5-9981-c04077f7cee7" -version = "0.7.1+1" - -[[libfdk_aac_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "7a5780a0d9c6864184b3a2eeeb833a0c871f00ab" -uuid = "f638f0a6-7fb0-5443-88ba-1cc74229b280" -version = "0.1.6+4" - -[[libpng_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Zlib_jll"] -git-tree-sha1 = "94d180a6d2b5e55e447e2d27a29ed04fe79eb30c" -uuid = "b53b4c65-9356-5827-b1ea-8c7a1a84506f" -version = "1.6.38+0" - -[[libvorbis_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Ogg_jll", "Pkg"] -git-tree-sha1 = "c45f4e40e7aafe9d086379e5578947ec8b95a8fb" -uuid = "f27f6e37-5d2b-51aa-960f-b287f2bc3b7a" -version = "1.3.7+0" - -[[nghttp2_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "8e850ede-7688-5339-a07c-302acd2aaf8d" - -[[p7zip_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "3f19e933-33d8-53b3-aaab-bd5110c3b7a0" - -[[x264_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "d713c1ce4deac133e3334ee12f4adff07f81778f" -uuid = "1270edf5-f2f9-52d2-97e9-ab00b5d0237a" -version = "2020.7.14+2" - -[[x265_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "487da2f8f2f0c8ee0e83f39d13037d6bbf0a45ab" -uuid = "dfaa095f-4041-5dcd-9319-2fabd8486b76" -version = "3.0.0+3" - -[[xkbcommon_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Wayland_jll", "Wayland_protocols_jll", "Xorg_libxcb_jll", "Xorg_xkeyboard_config_jll"] -git-tree-sha1 = "ece2350174195bb31de1a63bea3a41ae1aa593b6" -uuid = "d8fb68d0-12a3-5cfd-a85a-d49703b185fd" -version = "0.9.1+5" diff --git a/docs/homepage/Manifest.toml b/docs/homepage/Manifest.toml deleted file mode 100644 index d45a82d8f..000000000 --- a/docs/homepage/Manifest.toml +++ /dev/null @@ -1,1207 +0,0 @@ -# This file is machine-generated - editing it directly is not advised - -[[AbstractFFTs]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "485ee0867925449198280d4af84bdb46a2a404d0" -uuid = "621f4979-c628-5d54-868e-fcf4e3e8185c" -version = "1.0.1" - -[[AbstractTrees]] -git-tree-sha1 = "03e0550477d86222521d254b741d470ba17ea0b5" -uuid = "1520ce14-60c1-5f80-bbc7-55ef81b5835c" -version = "0.3.4" - -[[Adapt]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "84918055d15b3114ede17ac6a7182f68870c16f7" -uuid = "79e6a3ab-5dfb-504d-930d-738a2a938a0e" -version = "3.3.1" - -[[ArgTools]] -uuid = "0dad84c5-d112-42e6-8d28-ef12dabb789f" - -[[ArrayInterface]] -deps = ["IfElse", "LinearAlgebra", "Requires", "SparseArrays", "Static"] -git-tree-sha1 = "a71d224f61475b93c9e196e83c17c6ac4dedacfa" -uuid = "4fba245c-0d91-5ea0-9b3e-6abc04ee57a9" -version = "3.1.18" - -[[Artifacts]] -uuid = "56f22d72-fd6d-98f1-02f0-08ddc0907c33" - -[[BFloat16s]] -deps = ["LinearAlgebra", "Test"] -git-tree-sha1 = "4af69e205efc343068dc8722b8dfec1ade89254a" -uuid = "ab4f0b2a-ad5b-11e8-123f-65d77653426b" -version = "0.1.0" - -[[Base64]] -uuid = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f" - -[[Bzip2_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "c3598e525718abcc440f69cc6d5f60dda0a1b61e" -uuid = "6e34b625-4abd-537c-b88f-471c36dfa7a0" -version = "1.0.6+5" - -[[CEnum]] -git-tree-sha1 = "215a9aa4a1f23fbd05b92769fdd62559488d70e9" -uuid = "fa961155-64e5-5f13-b03f-caf6b980ea82" -version = "0.4.1" - -[[CUDA]] -deps = ["AbstractFFTs", "Adapt", "BFloat16s", "CEnum", "CompilerSupportLibraries_jll", "DataStructures", "ExprTools", "GPUArrays", "GPUCompiler", "LLVM", "LazyArtifacts", "Libdl", "LinearAlgebra", "Logging", "Printf", "Random", "Random123", "RandomNumbers", "Reexport", "Requires", "SparseArrays", "SpecialFunctions", "TimerOutputs"] -git-tree-sha1 = "5e696e37e51b01ae07bd9f700afe6cbd55250bce" -uuid = "052768ef-5323-5732-b1bb-66c8b64840ba" -version = "3.3.4" - -[[Cairo_jll]] -deps = ["Artifacts", "Bzip2_jll", "Fontconfig_jll", "FreeType2_jll", "Glib_jll", "JLLWrappers", "LZO_jll", "Libdl", "Pixman_jll", "Pkg", "Xorg_libXext_jll", "Xorg_libXrender_jll", "Zlib_jll", "libpng_jll"] -git-tree-sha1 = "e2f47f6d8337369411569fd45ae5753ca10394c6" -uuid = "83423d85-b0ee-5818-9007-b63ccbeb887a" -version = "1.16.0+6" - -[[ChainRules]] -deps = ["ChainRulesCore", "Compat", "LinearAlgebra", "Random", "Statistics"] -git-tree-sha1 = "0ff24ac6ea4f03d9ed5c90505c1e96273bf5f96d" -uuid = "082447d4-558c-5d27-93f4-14fc19e9eca2" -version = "0.8.23" - -[[ChainRulesCore]] -deps = ["Compat", "LinearAlgebra", "SparseArrays"] -git-tree-sha1 = "f53ca8d41e4753c41cdafa6ec5f7ce914b34be54" -uuid = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4" -version = "0.10.13" - -[[CircularArrayBuffers]] -git-tree-sha1 = "a5f5b84ecff2f9822e0eda78418d1b15f13a10a0" -uuid = "9de3a189-e0c0-4e15-ba3b-b14b9fb0aec1" -version = "0.1.2" - -[[CodecZlib]] -deps = ["TranscodingStreams", "Zlib_jll"] -git-tree-sha1 = "ded953804d019afa9a3f98981d99b33e3db7b6da" -uuid = "944b1d66-785c-5afd-91f1-9de20f533193" -version = "0.7.0" - -[[ColorSchemes]] -deps = ["ColorTypes", "Colors", "FixedPointNumbers", "Random", "StaticArrays"] -git-tree-sha1 = "ed268efe58512df8c7e224d2e170afd76dd6a417" -uuid = "35d6a980-a343-548e-a6ea-1d62b119f2f4" -version = "3.13.0" - -[[ColorTypes]] -deps = ["FixedPointNumbers", "Random"] -git-tree-sha1 = "024fe24d83e4a5bf5fc80501a314ce0d1aa35597" -uuid = "3da002f7-5984-5a60-b8a6-cbb66c0b333f" -version = "0.11.0" - -[[Colors]] -deps = ["ColorTypes", "FixedPointNumbers", "Reexport"] -git-tree-sha1 = "417b0ed7b8b838aa6ca0a87aadf1bb9eb111ce40" -uuid = "5ae59095-9a9b-59fe-a467-6f913c188581" -version = "0.12.8" - -[[CommonRLInterface]] -deps = ["MacroTools"] -git-tree-sha1 = "21de56ebf28c262651e682f7fe614d44623dc087" -uuid = "d842c3ba-07a1-494f-bbec-f5741b0a3e98" -version = "0.3.1" - -[[CommonSubexpressions]] -deps = ["MacroTools", "Test"] -git-tree-sha1 = "7b8a93dba8af7e3b42fecabf646260105ac373f7" -uuid = "bbf7d656-a473-5ed7-a52c-81e309532950" -version = "0.3.0" - -[[Compat]] -deps = ["Base64", "Dates", "DelimitedFiles", "Distributed", "InteractiveUtils", "LibGit2", "Libdl", "LinearAlgebra", "Markdown", "Mmap", "Pkg", "Printf", "REPL", "Random", "SHA", "Serialization", "SharedArrays", "Sockets", "SparseArrays", "Statistics", "Test", "UUIDs", "Unicode"] -git-tree-sha1 = "dc7dedc2c2aa9faf59a55c622760a25cbefbe941" -uuid = "34da2185-b29b-5c13-b0c7-acf172513d20" -version = "3.31.0" - -[[CompilerSupportLibraries_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "e66e0078-7015-5450-92f7-15fbd957f2ae" - -[[ConstructionBase]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "f74e9d5388b8620b4cee35d4c5a618dd4dc547f4" -uuid = "187b0558-2788-49d3-abe0-74a17ed4e7c9" -version = "1.3.0" - -[[Contour]] -deps = ["StaticArrays"] -git-tree-sha1 = "9f02045d934dc030edad45944ea80dbd1f0ebea7" -uuid = "d38c429a-6771-53c6-b99e-75d170b6e991" -version = "0.5.7" - -[[Crayons]] -git-tree-sha1 = "3f71217b538d7aaee0b69ab47d9b7724ca8afa0d" -uuid = "a8cc5b0e-0ffa-5ad4-8c14-923d3ee1735f" -version = "4.0.4" - -[[DataAPI]] -git-tree-sha1 = "ee400abb2298bd13bfc3df1c412ed228061a2385" -uuid = "9a962f9c-6df0-11e9-0e5d-c546b8b5ee8a" -version = "1.7.0" - -[[DataStructures]] -deps = ["Compat", "InteractiveUtils", "OrderedCollections"] -git-tree-sha1 = "4437b64df1e0adccc3e5d1adbc3ac741095e4677" -uuid = "864edb3b-99cc-5e75-8d2d-829cb0a9cfe8" -version = "0.18.9" - -[[DataValueInterfaces]] -git-tree-sha1 = "bfc1187b79289637fa0ef6d4436ebdfe6905cbd6" -uuid = "e2d170a0-9d28-54be-80f0-106bbe20a464" -version = "1.0.0" - -[[Dates]] -deps = ["Printf"] -uuid = "ade2ca70-3891-5945-98fb-dc099432e06a" - -[[DelimitedFiles]] -deps = ["Mmap"] -uuid = "8bb1440f-4735-579b-a4ab-409b98df4dab" - -[[DiffResults]] -deps = ["StaticArrays"] -git-tree-sha1 = "c18e98cba888c6c25d1c3b048e4b3380ca956805" -uuid = "163ba53b-c6d8-5494-b064-1a9d43ac40c5" -version = "1.0.3" - -[[DiffRules]] -deps = ["NaNMath", "Random", "SpecialFunctions"] -git-tree-sha1 = "214c3fcac57755cfda163d91c58893a8723f93e9" -uuid = "b552c78f-8df3-52c6-915a-8e097449b14b" -version = "1.0.2" - -[[Distributed]] -deps = ["Random", "Serialization", "Sockets"] -uuid = "8ba89e20-285c-5b6f-9357-94700520ee1b" - -[[Distributions]] -deps = ["FillArrays", "LinearAlgebra", "PDMats", "Printf", "QuadGK", "Random", "SparseArrays", "SpecialFunctions", "Statistics", "StatsBase", "StatsFuns"] -git-tree-sha1 = "3889f646423ce91dd1055a76317e9a1d3a23fff1" -uuid = "31c24e10-a181-5473-b8eb-7969acd0382f" -version = "0.25.11" - -[[DocStringExtensions]] -deps = ["LibGit2"] -git-tree-sha1 = "a32185f5428d3986f47c2ab78b1f216d5e6cc96f" -uuid = "ffbed154-4ef7-542d-bbb7-c09d3a79fcae" -version = "0.8.5" - -[[Downloads]] -deps = ["ArgTools", "LibCURL", "NetworkOptions"] -uuid = "f43a241f-c20a-4ad4-852c-f6b1247861c6" - -[[EarCut_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "92d8f9f208637e8d2d28c664051a00569c01493d" -uuid = "5ae413db-bbd1-5e63-b57d-d24a61df00f5" -version = "2.1.5+1" - -[[ElasticArrays]] -deps = ["Adapt"] -git-tree-sha1 = "a0fcc1bb3c9ceaf07e1d0529c9806ce94be6adf9" -uuid = "fdbdab4c-e67f-52f5-8c3f-e7b388dad3d4" -version = "1.2.9" - -[[EllipsisNotation]] -deps = ["ArrayInterface"] -git-tree-sha1 = "8041575f021cba5a099a456b4163c9a08b566a02" -uuid = "da5c29d0-fa7d-589e-88eb-ea29b0a81949" -version = "1.1.0" - -[[Expat_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "b3bfd02e98aedfa5cf885665493c5598c350cd2f" -uuid = "2e619515-83b5-522b-bb60-26c02a35a201" -version = "2.2.10+0" - -[[ExprTools]] -git-tree-sha1 = "b7e3d17636b348f005f11040025ae8c6f645fe92" -uuid = "e2ba6199-217a-4e67-a87a-7c52f15ade04" -version = "0.1.6" - -[[FFMPEG]] -deps = ["FFMPEG_jll"] -git-tree-sha1 = "b57e3acbe22f8484b4b5ff66a7499717fe1a9cc8" -uuid = "c87230d0-a227-11e9-1b43-d7ebe4e7570a" -version = "0.4.1" - -[[FFMPEG_jll]] -deps = ["Artifacts", "Bzip2_jll", "FreeType2_jll", "FriBidi_jll", "JLLWrappers", "LAME_jll", "LibVPX_jll", "Libdl", "Ogg_jll", "OpenSSL_jll", "Opus_jll", "Pkg", "Zlib_jll", "libass_jll", "libfdk_aac_jll", "libvorbis_jll", "x264_jll", "x265_jll"] -git-tree-sha1 = "3cc57ad0a213808473eafef4845a74766242e05f" -uuid = "b22a6f82-2f65-5046-a5b2-351ab43fb4e5" -version = "4.3.1+4" - -[[FileWatching]] -uuid = "7b1f6079-737a-58dc-b8bc-7a2ca5c1b5ee" - -[[FillArrays]] -deps = ["LinearAlgebra", "Random", "SparseArrays"] -git-tree-sha1 = "25b9cc23ba3303de0ad2eac03f840de9104c9253" -uuid = "1a297f60-69ca-5386-bcde-b61e274b549b" -version = "0.12.0" - -[[FixedPointNumbers]] -deps = ["Statistics"] -git-tree-sha1 = "335bfdceacc84c5cdf16aadc768aa5ddfc5383cc" -uuid = "53c48c17-4a7d-5ca2-90c5-79b7896eea93" -version = "0.8.4" - -[[Flux]] -deps = ["AbstractTrees", "Adapt", "ArrayInterface", "CUDA", "CodecZlib", "Colors", "DelimitedFiles", "Functors", "Juno", "LinearAlgebra", "MacroTools", "NNlib", "NNlibCUDA", "Pkg", "Printf", "Random", "Reexport", "SHA", "Statistics", "StatsBase", "Test", "ZipFile", "Zygote"] -git-tree-sha1 = "c58d1f9c9640f0bcb6869c6c9254d090b13c1908" -uuid = "587475ba-b771-5e3f-ad9e-33799f191a9c" -version = "0.12.5" - -[[Fontconfig_jll]] -deps = ["Artifacts", "Bzip2_jll", "Expat_jll", "FreeType2_jll", "JLLWrappers", "Libdl", "Libuuid_jll", "Pkg", "Zlib_jll"] -git-tree-sha1 = "35895cf184ceaab11fd778b4590144034a167a2f" -uuid = "a3f928ae-7b40-5064-980b-68af3947d34b" -version = "2.13.1+14" - -[[Formatting]] -deps = ["Printf"] -git-tree-sha1 = "8339d61043228fdd3eb658d86c926cb282ae72a8" -uuid = "59287772-0a20-5a39-b81b-1366585eb4c0" -version = "0.4.2" - -[[ForwardDiff]] -deps = ["CommonSubexpressions", "DiffResults", "DiffRules", "LinearAlgebra", "NaNMath", "Printf", "Random", "SpecialFunctions", "StaticArrays"] -git-tree-sha1 = "e2af66012e08966366a43251e1fd421522908be6" -uuid = "f6369f11-7733-5829-9624-2563aa707210" -version = "0.10.18" - -[[Franklin]] -deps = ["Dates", "DelimitedFiles", "DocStringExtensions", "ExprTools", "FranklinTemplates", "HTTP", "Literate", "LiveServer", "Logging", "Markdown", "NodeJS", "OrderedCollections", "Pkg", "REPL", "Random"] -git-tree-sha1 = "45d6c016356fce118d6c94b9728d493dcd040fdf" -uuid = "713c75ef-9fc9-4b05-94a9-213340da978e" -version = "0.10.43" - -[[FranklinTemplates]] -deps = ["LiveServer"] -git-tree-sha1 = "24f4ee4d9e3ede316abf2169f93f7190681312b4" -uuid = "3a985190-f512-4703-8d38-2a7944ed5916" -version = "0.8.19" - -[[FreeType2_jll]] -deps = ["Artifacts", "Bzip2_jll", "JLLWrappers", "Libdl", "Pkg", "Zlib_jll"] -git-tree-sha1 = "cbd58c9deb1d304f5a245a0b7eb841a2560cfec6" -uuid = "d7e528f0-a631-5988-bf34-fe36492bcfd7" -version = "2.10.1+5" - -[[FriBidi_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "aa31987c2ba8704e23c6c8ba8a4f769d5d7e4f91" -uuid = "559328eb-81f9-559d-9380-de523a88c83c" -version = "1.0.10+0" - -[[Functors]] -deps = ["MacroTools"] -git-tree-sha1 = "4cd9e70bf8fce05114598b663ad79dfe9ae432b3" -uuid = "d9f16b24-f501-4c13-a1f2-28368ffc5196" -version = "0.2.3" - -[[Future]] -deps = ["Random"] -uuid = "9fa8497b-333b-5362-9e8d-4d0656e87820" - -[[GLFW_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Libglvnd_jll", "Pkg", "Xorg_libXcursor_jll", "Xorg_libXi_jll", "Xorg_libXinerama_jll", "Xorg_libXrandr_jll"] -git-tree-sha1 = "dba1e8614e98949abfa60480b13653813d8f0157" -uuid = "0656b61e-2033-5cc2-a64a-77c0f6c09b89" -version = "3.3.5+0" - -[[GPUArrays]] -deps = ["AbstractFFTs", "Adapt", "LinearAlgebra", "Printf", "Random", "Serialization", "Statistics"] -git-tree-sha1 = "ececbf05f8904c92814bdbd0aafd5540b0bf2e9a" -uuid = "0c68f7d7-f131-5f86-a1c3-88cf8149b2d7" -version = "7.0.1" - -[[GPUCompiler]] -deps = ["DataStructures", "ExprTools", "InteractiveUtils", "LLVM", "Libdl", "Logging", "TimerOutputs", "UUIDs"] -git-tree-sha1 = "e8a09182a4440489e2e3dedff5ad3f6bbe555396" -uuid = "61eb1bfa-7361-4325-ad38-22787b887f55" -version = "0.12.5" - -[[GR]] -deps = ["Base64", "DelimitedFiles", "GR_jll", "HTTP", "JSON", "Libdl", "LinearAlgebra", "Pkg", "Printf", "Random", "Serialization", "Sockets", "Test", "UUIDs"] -git-tree-sha1 = "9f473cdf6e2eb360c576f9822e7c765dd9d26dbc" -uuid = "28b8d3ca-fb5f-59d9-8090-bfdbd6d07a71" -version = "0.58.0" - -[[GR_jll]] -deps = ["Artifacts", "Bzip2_jll", "Cairo_jll", "FFMPEG_jll", "Fontconfig_jll", "GLFW_jll", "JLLWrappers", "JpegTurbo_jll", "Libdl", "Libtiff_jll", "Pixman_jll", "Pkg", "Qt5Base_jll", "Zlib_jll", "libpng_jll"] -git-tree-sha1 = "eaf96e05a880f3db5ded5a5a8a7817ecba3c7392" -uuid = "d2c73de3-f751-5644-a686-071e5b155ba9" -version = "0.58.0+0" - -[[GeometryBasics]] -deps = ["EarCut_jll", "IterTools", "LinearAlgebra", "StaticArrays", "StructArrays", "Tables"] -git-tree-sha1 = "15ff9a14b9e1218958d3530cc288cf31465d9ae2" -uuid = "5c1252a2-5f33-56bf-86c9-59e7332b4326" -version = "0.3.13" - -[[Gettext_jll]] -deps = ["Artifacts", "CompilerSupportLibraries_jll", "JLLWrappers", "Libdl", "Libiconv_jll", "Pkg", "XML2_jll"] -git-tree-sha1 = "9b02998aba7bf074d14de89f9d37ca24a1a0b046" -uuid = "78b55507-aeef-58d4-861c-77aaff3498b1" -version = "0.21.0+0" - -[[Glib_jll]] -deps = ["Artifacts", "Gettext_jll", "JLLWrappers", "Libdl", "Libffi_jll", "Libiconv_jll", "Libmount_jll", "PCRE_jll", "Pkg", "Zlib_jll"] -git-tree-sha1 = "47ce50b742921377301e15005c96e979574e130b" -uuid = "7746bdde-850d-59dc-9ae8-88ece973131d" -version = "2.68.1+0" - -[[Grisu]] -git-tree-sha1 = "53bb909d1151e57e2484c3d1b53e19552b887fb2" -uuid = "42e2da0e-8278-4e71-bc24-59509adca0fe" -version = "1.0.2" - -[[HTTP]] -deps = ["Base64", "Dates", "IniFile", "Logging", "MbedTLS", "NetworkOptions", "Sockets", "URIs"] -git-tree-sha1 = "c6a1fff2fd4b1da29d3dccaffb1e1001244d844e" -uuid = "cd3eb016-35fb-5094-929b-558a96fad6f3" -version = "0.9.12" - -[[IOCapture]] -deps = ["Logging", "Random"] -git-tree-sha1 = "f7be53659ab06ddc986428d3a9dcc95f6fa6705a" -uuid = "b5f81e59-6552-4d32-b1f0-c071b021bf89" -version = "0.2.2" - -[[IRTools]] -deps = ["InteractiveUtils", "MacroTools", "Test"] -git-tree-sha1 = "95215cd0076a150ef46ff7928892bc341864c73c" -uuid = "7869d1d1-7146-5819-86e3-90919afe41df" -version = "0.4.3" - -[[IfElse]] -git-tree-sha1 = "28e837ff3e7a6c3cdb252ce49fb412c8eb3caeef" -uuid = "615f187c-cbe4-4ef1-ba3b-2fcf58d6d173" -version = "0.1.0" - -[[IniFile]] -deps = ["Test"] -git-tree-sha1 = "098e4d2c533924c921f9f9847274f2ad89e018b8" -uuid = "83e8ac13-25f8-5344-8a64-a9f2b223428f" -version = "0.5.0" - -[[InteractiveUtils]] -deps = ["Markdown"] -uuid = "b77e0a4c-d291-57a0-90e8-8db25a27a240" - -[[IntervalSets]] -deps = ["Dates", "EllipsisNotation", "Statistics"] -git-tree-sha1 = "3cc368af3f110a767ac786560045dceddfc16758" -uuid = "8197267c-284f-5f27-9208-e0e47529a953" -version = "0.5.3" - -[[IterTools]] -git-tree-sha1 = "05110a2ab1fc5f932622ffea2a003221f4782c18" -uuid = "c8e1da08-722c-5040-9ed9-7db0dc04731e" -version = "1.3.0" - -[[IteratorInterfaceExtensions]] -git-tree-sha1 = "a3f24677c21f5bbe9d2a714f95dcd58337fb2856" -uuid = "82899510-4779-5014-852e-03e436cf321d" -version = "1.0.0" - -[[JLLWrappers]] -deps = ["Preferences"] -git-tree-sha1 = "642a199af8b68253517b80bd3bfd17eb4e84df6e" -uuid = "692b3bcd-3c85-4b1f-b108-f13ce0eb3210" -version = "1.3.0" - -[[JSON]] -deps = ["Dates", "Mmap", "Parsers", "Unicode"] -git-tree-sha1 = "81690084b6198a2e1da36fcfda16eeca9f9f24e4" -uuid = "682c06a0-de6a-54ab-a142-c8b1cf79cde6" -version = "0.21.1" - -[[JpegTurbo_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "d735490ac75c5cb9f1b00d8b5509c11984dc6943" -uuid = "aacddb02-875f-59d6-b918-886e6ef4fbf8" -version = "2.1.0+0" - -[[Juno]] -deps = ["Base64", "Logging", "Media", "Profile"] -git-tree-sha1 = "07cb43290a840908a771552911a6274bc6c072c7" -uuid = "e5e0dc1b-0480-54bc-9374-aad01c23163d" -version = "0.8.4" - -[[LAME_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "f6250b16881adf048549549fba48b1161acdac8c" -uuid = "c1c5ebd0-6772-5130-a774-d5fcae4a789d" -version = "3.100.1+0" - -[[LLVM]] -deps = ["CEnum", "LLVMExtra_jll", "Libdl", "Printf", "Unicode"] -git-tree-sha1 = "1b7ba36ea7aa6fa2278118951bad114fbb8359f2" -uuid = "929cbde3-209d-540e-8aea-75f648917ca0" -version = "4.1.0" - -[[LLVMExtra_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "b36c0677a0549c7d1dc8719899a4133abbfacf7d" -uuid = "dad2f222-ce93-54a1-a47d-0025e8a3acab" -version = "0.0.6+0" - -[[LZO_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "e5b909bcf985c5e2605737d2ce278ed791b89be6" -uuid = "dd4b983a-f0e5-5f8d-a1b7-129d4a5fb1ac" -version = "2.10.1+0" - -[[LaTeXStrings]] -git-tree-sha1 = "c7f1c695e06c01b95a67f0cd1d34994f3e7db104" -uuid = "b964fa9f-0449-5b57-a5c2-d3ea65f4040f" -version = "1.2.1" - -[[Latexify]] -deps = ["Formatting", "InteractiveUtils", "LaTeXStrings", "MacroTools", "Markdown", "Printf", "Requires"] -git-tree-sha1 = "a4b12a1bd2ebade87891ab7e36fdbce582301a92" -uuid = "23fbe1c1-3f47-55db-b15f-69d7ec21a316" -version = "0.15.6" - -[[LazyArtifacts]] -deps = ["Artifacts", "Pkg"] -uuid = "4af54fe1-eca0-43a8-85a7-787d91b784e3" - -[[LibCURL]] -deps = ["LibCURL_jll", "MozillaCACerts_jll"] -uuid = "b27032c2-a3e7-50c8-80cd-2d36dbcbfd21" - -[[LibCURL_jll]] -deps = ["Artifacts", "LibSSH2_jll", "Libdl", "MbedTLS_jll", "Zlib_jll", "nghttp2_jll"] -uuid = "deac9b47-8bc7-5906-a0fe-35ac56dc84c0" - -[[LibGit2]] -deps = ["Base64", "NetworkOptions", "Printf", "SHA"] -uuid = "76f85450-5226-5b5a-8eaa-529ad045b433" - -[[LibSSH2_jll]] -deps = ["Artifacts", "Libdl", "MbedTLS_jll"] -uuid = "29816b5a-b9ab-546f-933c-edad1886dfa8" - -[[LibVPX_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "12ee7e23fa4d18361e7c2cde8f8337d4c3101bc7" -uuid = "dd192d2f-8180-539f-9fb4-cc70b1dcf69a" -version = "1.10.0+0" - -[[Libdl]] -uuid = "8f399da3-3557-5675-b5ff-fb832c97cbdb" - -[[Libffi_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "761a393aeccd6aa92ec3515e428c26bf99575b3b" -uuid = "e9f186c6-92d2-5b65-8a66-fee21dc1b490" -version = "3.2.2+0" - -[[Libgcrypt_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Libgpg_error_jll", "Pkg"] -git-tree-sha1 = "64613c82a59c120435c067c2b809fc61cf5166ae" -uuid = "d4300ac3-e22c-5743-9152-c294e39db1e4" -version = "1.8.7+0" - -[[Libglvnd_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libX11_jll", "Xorg_libXext_jll"] -git-tree-sha1 = "7739f837d6447403596a75d19ed01fd08d6f56bf" -uuid = "7e76a0d4-f3c7-5321-8279-8d96eeed0f29" -version = "1.3.0+3" - -[[Libgpg_error_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "c333716e46366857753e273ce6a69ee0945a6db9" -uuid = "7add5ba3-2f88-524e-9cd5-f83b8a55f7b8" -version = "1.42.0+0" - -[[Libiconv_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "42b62845d70a619f063a7da093d995ec8e15e778" -uuid = "94ce4f54-9a6c-5748-9c1c-f9c7231a4531" -version = "1.16.1+1" - -[[Libmount_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "9c30530bf0effd46e15e0fdcf2b8636e78cbbd73" -uuid = "4b2f31a3-9ecc-558c-b454-b3730dcb73e9" -version = "2.35.0+0" - -[[Libtiff_jll]] -deps = ["Artifacts", "JLLWrappers", "JpegTurbo_jll", "Libdl", "Pkg", "Zlib_jll", "Zstd_jll"] -git-tree-sha1 = "340e257aada13f95f98ee352d316c3bed37c8ab9" -uuid = "89763e89-9b03-5906-acba-b20f662cd828" -version = "4.3.0+0" - -[[Libuuid_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "7f3efec06033682db852f8b3bc3c1d2b0a0ab066" -uuid = "38a345b3-de98-5d2b-a5d3-14cd9215e700" -version = "2.36.0+0" - -[[LinearAlgebra]] -deps = ["Libdl"] -uuid = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e" - -[[Literate]] -deps = ["Base64", "IOCapture", "JSON", "REPL"] -git-tree-sha1 = "2a5b07cb13c9988cd7ee737df9f45eabbfab151c" -uuid = "98b081ad-f1c9-55d3-8b20-4c87d4299306" -version = "2.9.0" - -[[LiveServer]] -deps = ["Crayons", "FileWatching", "HTTP", "Pkg", "Sockets", "Test"] -git-tree-sha1 = "99990da121ad310875b3c4dba5954eba54df8cfd" -uuid = "16fef848-5104-11e9-1b77-fb7a48bbb589" -version = "0.7.0" - -[[LogExpFunctions]] -deps = ["DocStringExtensions", "LinearAlgebra"] -git-tree-sha1 = "7bd5f6565d80b6bf753738d2bc40a5dfea072070" -uuid = "2ab3a3ac-af41-5b50-aa03-7779005ae688" -version = "0.2.5" - -[[Logging]] -uuid = "56ddb016-857b-54e1-b83d-db4d58db5568" - -[[MacroTools]] -deps = ["Markdown", "Random"] -git-tree-sha1 = "6a8a2a625ab0dea913aba95c11370589e0239ff0" -uuid = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09" -version = "0.5.6" - -[[Markdown]] -deps = ["Base64"] -uuid = "d6f4376e-aef5-505a-96c1-9c027394607a" - -[[MbedTLS]] -deps = ["Dates", "MbedTLS_jll", "Random", "Sockets"] -git-tree-sha1 = "1c38e51c3d08ef2278062ebceade0e46cefc96fe" -uuid = "739be429-bea8-5141-9913-cc70e7f3736d" -version = "1.0.3" - -[[MbedTLS_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "c8ffd9c3-330d-5841-b78e-0817d7145fa1" - -[[Measures]] -git-tree-sha1 = "e498ddeee6f9fdb4551ce855a46f54dbd900245f" -uuid = "442fdcdd-2543-5da2-b0f3-8c86c306513e" -version = "0.3.1" - -[[Media]] -deps = ["MacroTools", "Test"] -git-tree-sha1 = "75a54abd10709c01f1b86b84ec225d26e840ed58" -uuid = "e89f7d12-3494-54d1-8411-f7d8b9ae1f27" -version = "0.5.0" - -[[Missings]] -deps = ["DataAPI"] -git-tree-sha1 = "4ea90bd5d3985ae1f9a908bd4500ae88921c5ce7" -uuid = "e1d29d7a-bbdc-5cf2-9ac0-f12de2c33e28" -version = "1.0.0" - -[[Mmap]] -uuid = "a63ad114-7e13-5084-954f-fe012c677804" - -[[MozillaCACerts_jll]] -uuid = "14a3606d-f60d-562e-9121-12d972cd8159" - -[[NNlib]] -deps = ["Adapt", "ChainRulesCore", "Compat", "LinearAlgebra", "Pkg", "Requires", "Statistics"] -git-tree-sha1 = "3de64e776a467311c907f5a767ee8a022a8a2f76" -uuid = "872c559c-99b0-510c-b3b7-b6c96a88d5cd" -version = "0.7.25" - -[[NNlibCUDA]] -deps = ["CUDA", "LinearAlgebra", "NNlib", "Random", "Statistics"] -git-tree-sha1 = "a7de026dc0ff9f47551a16ad9a710da66881b953" -uuid = "a00861dc-f156-4864-bf3c-e6376f28a68d" -version = "0.1.7" - -[[NaNMath]] -git-tree-sha1 = "bfe47e760d60b82b66b61d2d44128b62e3a369fb" -uuid = "77ba4419-2d1f-58cd-9bb1-8ffee604a2e3" -version = "0.3.5" - -[[NetworkOptions]] -uuid = "ca575930-c2e3-43a9-ace4-1e988b2c1908" - -[[NodeJS]] -deps = ["Pkg"] -git-tree-sha1 = "905224bbdd4b555c69bb964514cfa387616f0d3a" -uuid = "2bd173c7-0d6d-553b-b6af-13a54713934c" -version = "1.3.0" - -[[Ogg_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "7937eda4681660b4d6aeeecc2f7e1c81c8ee4e2f" -uuid = "e7412a2a-1a6e-54c0-be00-318e2571c051" -version = "1.3.5+0" - -[[OpenSSL_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "15003dcb7d8db3c6c857fda14891a539a8f2705a" -uuid = "458c3c95-2e84-50aa-8efc-19380b2a3a95" -version = "1.1.10+0" - -[[OpenSpecFun_jll]] -deps = ["Artifacts", "CompilerSupportLibraries_jll", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "13652491f6856acfd2db29360e1bbcd4565d04f1" -uuid = "efe28fd5-8261-553b-a9e1-b2916fc3738e" -version = "0.5.5+0" - -[[Opus_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "51a08fb14ec28da2ec7a927c4337e4332c2a4720" -uuid = "91d4177d-7536-5919-b921-800302f37372" -version = "1.3.2+0" - -[[OrderedCollections]] -git-tree-sha1 = "85f8e6578bf1f9ee0d11e7bb1b1456435479d47c" -uuid = "bac558e1-5e72-5ebc-8fee-abe8a469f55d" -version = "1.4.1" - -[[PCRE_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "b2a7af664e098055a7529ad1a900ded962bca488" -uuid = "2f80f16e-611a-54ab-bc61-aa92de5b98fc" -version = "8.44.0+0" - -[[PDMats]] -deps = ["LinearAlgebra", "SparseArrays", "SuiteSparse"] -git-tree-sha1 = "4dd403333bcf0909341cfe57ec115152f937d7d8" -uuid = "90014a1f-27ba-587c-ab20-58faa44d9150" -version = "0.11.1" - -[[Parsers]] -deps = ["Dates"] -git-tree-sha1 = "c8abc88faa3f7a3950832ac5d6e690881590d6dc" -uuid = "69de0a69-1ddd-5017-9359-2bf0b02dc9f0" -version = "1.1.0" - -[[Pixman_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "b4f5d02549a10e20780a24fce72bea96b6329e29" -uuid = "30392449-352a-5448-841d-b1acce4e97dc" -version = "0.40.1+0" - -[[Pkg]] -deps = ["Artifacts", "Dates", "Downloads", "LibGit2", "Libdl", "Logging", "Markdown", "Printf", "REPL", "Random", "SHA", "Serialization", "TOML", "Tar", "UUIDs", "p7zip_jll"] -uuid = "44cfe95a-1eb2-52ea-b672-e2afdf69b78f" - -[[PlotThemes]] -deps = ["PlotUtils", "Requires", "Statistics"] -git-tree-sha1 = "a3a964ce9dc7898193536002a6dd892b1b5a6f1d" -uuid = "ccf2f8ad-2431-5c83-bf29-c5338b663b6a" -version = "2.0.1" - -[[PlotUtils]] -deps = ["ColorSchemes", "Colors", "Dates", "Printf", "Random", "Reexport", "Statistics"] -git-tree-sha1 = "501c20a63a34ac1d015d5304da0e645f42d91c9f" -uuid = "995b91a9-d308-5afd-9ec6-746e21dbc043" -version = "1.0.11" - -[[Plots]] -deps = ["Base64", "Contour", "Dates", "FFMPEG", "FixedPointNumbers", "GR", "GeometryBasics", "JSON", "Latexify", "LinearAlgebra", "Measures", "NaNMath", "PlotThemes", "PlotUtils", "Printf", "REPL", "Random", "RecipesBase", "RecipesPipeline", "Reexport", "Requires", "Scratch", "Showoff", "SparseArrays", "Statistics", "StatsBase", "UUIDs"] -git-tree-sha1 = "f3d4d35b8cb87adc844c05c722f505776ac29988" -uuid = "91a5bcdd-55d7-5caf-9e0b-520d859cae80" -version = "1.19.2" - -[[Preferences]] -deps = ["TOML"] -git-tree-sha1 = "00cfd92944ca9c760982747e9a1d0d5d86ab1e5a" -uuid = "21216c6a-2e73-6563-6e65-726566657250" -version = "1.2.2" - -[[Printf]] -deps = ["Unicode"] -uuid = "de0858da-6303-5e67-8744-51eddeeeb8d7" - -[[Profile]] -deps = ["Printf"] -uuid = "9abbd945-dff8-562f-b5e8-e1ebf5ef1b79" - -[[ProgressMeter]] -deps = ["Distributed", "Printf"] -git-tree-sha1 = "afadeba63d90ff223a6a48d2009434ecee2ec9e8" -uuid = "92933f4c-e287-5a05-a399-4b506db050ca" -version = "1.7.1" - -[[Qt5Base_jll]] -deps = ["Artifacts", "CompilerSupportLibraries_jll", "Fontconfig_jll", "Glib_jll", "JLLWrappers", "Libdl", "Libglvnd_jll", "OpenSSL_jll", "Pkg", "Xorg_libXext_jll", "Xorg_libxcb_jll", "Xorg_xcb_util_image_jll", "Xorg_xcb_util_keysyms_jll", "Xorg_xcb_util_renderutil_jll", "Xorg_xcb_util_wm_jll", "Zlib_jll", "xkbcommon_jll"] -git-tree-sha1 = "ad368663a5e20dbb8d6dc2fddeefe4dae0781ae8" -uuid = "ea2cea3b-5b76-57ae-a6ef-0a8af62496e1" -version = "5.15.3+0" - -[[QuadGK]] -deps = ["DataStructures", "LinearAlgebra"] -git-tree-sha1 = "12fbe86da16df6679be7521dfb39fbc861e1dc7b" -uuid = "1fd47b50-473d-5c70-9696-f719f8f3bcdc" -version = "2.4.1" - -[[REPL]] -deps = ["InteractiveUtils", "Markdown", "Sockets", "Unicode"] -uuid = "3fa0cd96-eef1-5676-8a61-b3b8758bbffb" - -[[Random]] -deps = ["Serialization"] -uuid = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c" - -[[Random123]] -deps = ["Libdl", "Random", "RandomNumbers"] -git-tree-sha1 = "0e8b146557ad1c6deb1367655e052276690e71a3" -uuid = "74087812-796a-5b5d-8853-05524746bad3" -version = "1.4.2" - -[[RandomNumbers]] -deps = ["Random", "Requires"] -git-tree-sha1 = "441e6fc35597524ada7f85e13df1f4e10137d16f" -uuid = "e6cf234a-135c-5ec9-84dd-332b85af5143" -version = "1.4.0" - -[[RecipesBase]] -git-tree-sha1 = "b3fb709f3c97bfc6e948be68beeecb55a0b340ae" -uuid = "3cdcf5f2-1ef4-517c-9805-6587b60abb01" -version = "1.1.1" - -[[RecipesPipeline]] -deps = ["Dates", "NaNMath", "PlotUtils", "RecipesBase"] -git-tree-sha1 = "2a7a2469ed5d94a98dea0e85c46fa653d76be0cd" -uuid = "01d81517-befc-4cb6-b9ec-a95719d0359c" -version = "0.3.4" - -[[Reexport]] -git-tree-sha1 = "5f6c21241f0f655da3952fd60aa18477cf96c220" -uuid = "189a3867-3050-52da-a836-e630ba90ab69" -version = "1.1.0" - -[[ReinforcementLearning]] -deps = ["Reexport", "ReinforcementLearningBase", "ReinforcementLearningCore", "ReinforcementLearningEnvironments", "ReinforcementLearningZoo"] -path = "../.." -uuid = "158674fc-8238-5cab-b5ba-03dfc80d1318" -version = "0.10.0" - -[[ReinforcementLearningBase]] -deps = ["AbstractTrees", "CommonRLInterface", "Markdown", "Random", "Test"] -path = "../../src/ReinforcementLearningBase" -uuid = "e575027e-6cd6-5018-9292-cdc6200d2b44" -version = "0.9.6" - -[[ReinforcementLearningCore]] -deps = ["AbstractTrees", "Adapt", "ArrayInterface", "CUDA", "CircularArrayBuffers", "Compat", "Dates", "Distributions", "ElasticArrays", "FillArrays", "Flux", "Functors", "GPUArrays", "LinearAlgebra", "MacroTools", "Markdown", "ProgressMeter", "Random", "ReinforcementLearningBase", "Setfield", "Statistics", "StatsBase", "UnicodePlots", "Zygote"] -path = "../../src/ReinforcementLearningCore" -uuid = "de1b191a-4ae0-4afa-a27b-92d07f46b2d6" -version = "0.8.2" - -[[ReinforcementLearningEnvironments]] -deps = ["IntervalSets", "MacroTools", "Markdown", "Random", "ReinforcementLearningBase", "Requires", "StatsBase"] -path = "../../src/ReinforcementLearningEnvironments" -uuid = "25e41dd2-4622-11e9-1641-f1adca772921" -version = "0.6.1" - -[[ReinforcementLearningZoo]] -deps = ["AbstractTrees", "CUDA", "CircularArrayBuffers", "DataStructures", "Dates", "Distributions", "Flux", "IntervalSets", "LinearAlgebra", "Logging", "MacroTools", "Random", "ReinforcementLearningBase", "ReinforcementLearningCore", "Setfield", "Statistics", "StatsBase", "StructArrays", "Zygote"] -path = "../../src/ReinforcementLearningZoo" -uuid = "d607f57d-ee1e-4ba7-bcf2-7734c1e31854" -version = "0.5.0" - -[[Requires]] -deps = ["UUIDs"] -git-tree-sha1 = "4036a3bd08ac7e968e27c203d45f5fff15020621" -uuid = "ae029012-a4dd-5104-9daa-d747884805df" -version = "1.1.3" - -[[Rmath]] -deps = ["Random", "Rmath_jll"] -git-tree-sha1 = "bf3188feca147ce108c76ad82c2792c57abe7b1f" -uuid = "79098fc4-a85e-5d69-aa6a-4863f24498fa" -version = "0.7.0" - -[[Rmath_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "68db32dff12bb6127bac73c209881191bf0efbb7" -uuid = "f50d1b31-88e8-58de-be2c-1cc44531875f" -version = "0.3.0+0" - -[[SHA]] -uuid = "ea8e919c-243c-51af-8825-aaa63cd721ce" - -[[Scratch]] -deps = ["Dates"] -git-tree-sha1 = "0b4b7f1393cff97c33891da2a0bf69c6ed241fda" -uuid = "6c6a2e73-6563-6170-7368-637461726353" -version = "1.1.0" - -[[Serialization]] -uuid = "9e88b42a-f829-5b0c-bbe9-9e923198166b" - -[[Setfield]] -deps = ["ConstructionBase", "Future", "MacroTools", "Requires"] -git-tree-sha1 = "d5640fc570fb1b6c54512f0bd3853866bd298b3e" -uuid = "efcf1570-3423-57d1-acb7-fd33fddbac46" -version = "0.7.0" - -[[SharedArrays]] -deps = ["Distributed", "Mmap", "Random", "Serialization"] -uuid = "1a1011a3-84de-559e-8e89-a11a2f7dc383" - -[[Showoff]] -deps = ["Dates", "Grisu"] -git-tree-sha1 = "91eddf657aca81df9ae6ceb20b959ae5653ad1de" -uuid = "992d4aef-0814-514b-bc4d-f2e9a6c4116f" -version = "1.0.3" - -[[Sockets]] -uuid = "6462fe0b-24de-5631-8697-dd941f90decc" - -[[SortingAlgorithms]] -deps = ["DataStructures"] -git-tree-sha1 = "b3363d7460f7d098ca0912c69b082f75625d7508" -uuid = "a2af1166-a08f-5f64-846c-94a0d3cef48c" -version = "1.0.1" - -[[SparseArrays]] -deps = ["LinearAlgebra", "Random"] -uuid = "2f01184e-e22b-5df5-ae63-d93ebab69eaf" - -[[SpecialFunctions]] -deps = ["ChainRulesCore", "LogExpFunctions", "OpenSpecFun_jll"] -git-tree-sha1 = "a50550fa3164a8c46747e62063b4d774ac1bcf49" -uuid = "276daf66-3868-5448-9aa4-cd146d93841b" -version = "1.5.1" - -[[Static]] -deps = ["IfElse"] -git-tree-sha1 = "62701892d172a2fa41a1f829f66d2b0db94a9a63" -uuid = "aedffcd0-7271-4cad-89d0-dc628f76c6d3" -version = "0.3.0" - -[[StaticArrays]] -deps = ["LinearAlgebra", "Random", "Statistics"] -git-tree-sha1 = "1b9a0f17ee0adde9e538227de093467348992397" -uuid = "90137ffa-7385-5640-81b9-e52037218182" -version = "1.2.7" - -[[Statistics]] -deps = ["LinearAlgebra", "SparseArrays"] -uuid = "10745b16-79ce-11e8-11f9-7d13ad32a3b2" - -[[StatsAPI]] -git-tree-sha1 = "1958272568dc176a1d881acb797beb909c785510" -uuid = "82ae8749-77ed-4fe6-ae5f-f523153014b0" -version = "1.0.0" - -[[StatsBase]] -deps = ["DataAPI", "DataStructures", "LinearAlgebra", "Missings", "Printf", "Random", "SortingAlgorithms", "SparseArrays", "Statistics", "StatsAPI"] -git-tree-sha1 = "2f6792d523d7448bbe2fec99eca9218f06cc746d" -uuid = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91" -version = "0.33.8" - -[[StatsFuns]] -deps = ["LogExpFunctions", "Rmath", "SpecialFunctions"] -git-tree-sha1 = "30cd8c360c54081f806b1ee14d2eecbef3c04c49" -uuid = "4c63d2b9-4356-54db-8cca-17b64c39e42c" -version = "0.9.8" - -[[StructArrays]] -deps = ["Adapt", "DataAPI", "StaticArrays", "Tables"] -git-tree-sha1 = "000e168f5cc9aded17b6999a560b7c11dda69095" -uuid = "09ab397b-f2b6-538f-b94a-2f83cf4a842a" -version = "0.6.0" - -[[SuiteSparse]] -deps = ["Libdl", "LinearAlgebra", "Serialization", "SparseArrays"] -uuid = "4607b0f0-06f3-5cda-b6b1-a6196a1729e9" - -[[TOML]] -deps = ["Dates"] -uuid = "fa267f1f-6049-4f14-aa54-33bafae1ed76" - -[[TableTraits]] -deps = ["IteratorInterfaceExtensions"] -git-tree-sha1 = "c06b2f539df1c6efa794486abfb6ed2022561a39" -uuid = "3783bdb8-4a98-5b6b-af9a-565f29a5fe9c" -version = "1.0.1" - -[[Tables]] -deps = ["DataAPI", "DataValueInterfaces", "IteratorInterfaceExtensions", "LinearAlgebra", "TableTraits", "Test"] -git-tree-sha1 = "8ed4a3ea724dac32670b062be3ef1c1de6773ae8" -uuid = "bd369af6-aec1-5ad0-b16a-f7cc5008161c" -version = "1.4.4" - -[[Tar]] -deps = ["ArgTools", "SHA"] -uuid = "a4e569a6-e804-4fa4-b0f3-eef7a1d5b13e" - -[[Test]] -deps = ["InteractiveUtils", "Logging", "Random", "Serialization"] -uuid = "8dfed614-e22c-5e08-85e1-65c5234f0b40" - -[[TimerOutputs]] -deps = ["ExprTools", "Printf"] -git-tree-sha1 = "209a8326c4f955e2442c07b56029e88bb48299c7" -uuid = "a759f4b9-e2f1-59dc-863e-4aeb61b1ea8f" -version = "0.5.12" - -[[TranscodingStreams]] -deps = ["Random", "Test"] -git-tree-sha1 = "7c53c35547de1c5b9d46a4797cf6d8253807108c" -uuid = "3bb67fe8-82b1-5028-8e26-92a6c54297fa" -version = "0.9.5" - -[[URIs]] -git-tree-sha1 = "97bbe755a53fe859669cd907f2d96aee8d2c1355" -uuid = "5c2747f8-b7ea-4ff2-ba2e-563bfd36b1d4" -version = "1.3.0" - -[[UUIDs]] -deps = ["Random", "SHA"] -uuid = "cf7118a7-6976-5b1a-9a39-7adc72f591a4" - -[[Unicode]] -uuid = "4ec0a83e-493e-50e2-b9ac-8f72acf5a8f5" - -[[UnicodePlots]] -deps = ["Crayons", "Dates", "SparseArrays", "StatsBase"] -git-tree-sha1 = "1a63e6eea76b291378ff9f95801f8b6d96213208" -uuid = "b8865327-cd53-5732-bb35-84acbb429228" -version = "1.3.0" - -[[Wayland_jll]] -deps = ["Artifacts", "Expat_jll", "JLLWrappers", "Libdl", "Libffi_jll", "Pkg", "XML2_jll"] -git-tree-sha1 = "3e61f0b86f90dacb0bc0e73a0c5a83f6a8636e23" -uuid = "a2964d1f-97da-50d4-b82a-358c7fce9d89" -version = "1.19.0+0" - -[[Wayland_protocols_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Wayland_jll"] -git-tree-sha1 = "2839f1c1296940218e35df0bbb220f2a79686670" -uuid = "2381bf8a-dfd0-557d-9999-79630e7b1b91" -version = "1.18.0+4" - -[[XML2_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Libiconv_jll", "Pkg", "Zlib_jll"] -git-tree-sha1 = "1acf5bdf07aa0907e0a37d3718bb88d4b687b74a" -uuid = "02c8fc9c-b97f-50b9-bbe4-9be30ff0a78a" -version = "2.9.12+0" - -[[XSLT_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Libgcrypt_jll", "Libgpg_error_jll", "Libiconv_jll", "Pkg", "XML2_jll", "Zlib_jll"] -git-tree-sha1 = "91844873c4085240b95e795f692c4cec4d805f8a" -uuid = "aed1982a-8fda-507f-9586-7b0439959a61" -version = "1.1.34+0" - -[[Xorg_libX11_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libxcb_jll", "Xorg_xtrans_jll"] -git-tree-sha1 = "5be649d550f3f4b95308bf0183b82e2582876527" -uuid = "4f6342f7-b3d2-589e-9d20-edeb45f2b2bc" -version = "1.6.9+4" - -[[Xorg_libXau_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "4e490d5c960c314f33885790ed410ff3a94ce67e" -uuid = "0c0b7dd1-d40b-584c-a123-a41640f87eec" -version = "1.0.9+4" - -[[Xorg_libXcursor_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libXfixes_jll", "Xorg_libXrender_jll"] -git-tree-sha1 = "12e0eb3bc634fa2080c1c37fccf56f7c22989afd" -uuid = "935fb764-8cf2-53bf-bb30-45bb1f8bf724" -version = "1.2.0+4" - -[[Xorg_libXdmcp_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "4fe47bd2247248125c428978740e18a681372dd4" -uuid = "a3789734-cfe1-5b06-b2d0-1dd0d9d62d05" -version = "1.1.3+4" - -[[Xorg_libXext_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libX11_jll"] -git-tree-sha1 = "b7c0aa8c376b31e4852b360222848637f481f8c3" -uuid = "1082639a-0dae-5f34-9b06-72781eeb8cb3" -version = "1.3.4+4" - -[[Xorg_libXfixes_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libX11_jll"] -git-tree-sha1 = "0e0dc7431e7a0587559f9294aeec269471c991a4" -uuid = "d091e8ba-531a-589c-9de9-94069b037ed8" -version = "5.0.3+4" - -[[Xorg_libXi_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libXext_jll", "Xorg_libXfixes_jll"] -git-tree-sha1 = "89b52bc2160aadc84d707093930ef0bffa641246" -uuid = "a51aa0fd-4e3c-5386-b890-e753decda492" -version = "1.7.10+4" - -[[Xorg_libXinerama_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libXext_jll"] -git-tree-sha1 = "26be8b1c342929259317d8b9f7b53bf2bb73b123" -uuid = "d1454406-59df-5ea1-beac-c340f2130bc3" -version = "1.1.4+4" - -[[Xorg_libXrandr_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libXext_jll", "Xorg_libXrender_jll"] -git-tree-sha1 = "34cea83cb726fb58f325887bf0612c6b3fb17631" -uuid = "ec84b674-ba8e-5d96-8ba1-2a689ba10484" -version = "1.5.2+4" - -[[Xorg_libXrender_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libX11_jll"] -git-tree-sha1 = "19560f30fd49f4d4efbe7002a1037f8c43d43b96" -uuid = "ea2f1a96-1ddc-540d-b46f-429655e07cfa" -version = "0.9.10+4" - -[[Xorg_libpthread_stubs_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "6783737e45d3c59a4a4c4091f5f88cdcf0908cbb" -uuid = "14d82f49-176c-5ed1-bb49-ad3f5cbd8c74" -version = "0.1.0+3" - -[[Xorg_libxcb_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "XSLT_jll", "Xorg_libXau_jll", "Xorg_libXdmcp_jll", "Xorg_libpthread_stubs_jll"] -git-tree-sha1 = "daf17f441228e7a3833846cd048892861cff16d6" -uuid = "c7cfdc94-dc32-55de-ac96-5a1b8d977c5b" -version = "1.13.0+3" - -[[Xorg_libxkbfile_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libX11_jll"] -git-tree-sha1 = "926af861744212db0eb001d9e40b5d16292080b2" -uuid = "cc61e674-0454-545c-8b26-ed2c68acab7a" -version = "1.1.0+4" - -[[Xorg_xcb_util_image_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_xcb_util_jll"] -git-tree-sha1 = "0fab0a40349ba1cba2c1da699243396ff8e94b97" -uuid = "12413925-8142-5f55-bb0e-6d7ca50bb09b" -version = "0.4.0+1" - -[[Xorg_xcb_util_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libxcb_jll"] -git-tree-sha1 = "e7fd7b2881fa2eaa72717420894d3938177862d1" -uuid = "2def613f-5ad1-5310-b15b-b15d46f528f5" -version = "0.4.0+1" - -[[Xorg_xcb_util_keysyms_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_xcb_util_jll"] -git-tree-sha1 = "d1151e2c45a544f32441a567d1690e701ec89b00" -uuid = "975044d2-76e6-5fbe-bf08-97ce7c6574c7" -version = "0.4.0+1" - -[[Xorg_xcb_util_renderutil_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_xcb_util_jll"] -git-tree-sha1 = "dfd7a8f38d4613b6a575253b3174dd991ca6183e" -uuid = "0d47668e-0667-5a69-a72c-f761630bfb7e" -version = "0.3.9+1" - -[[Xorg_xcb_util_wm_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_xcb_util_jll"] -git-tree-sha1 = "e78d10aab01a4a154142c5006ed44fd9e8e31b67" -uuid = "c22f9ab0-d5fe-5066-847c-f4bb1cd4e361" -version = "0.4.1+1" - -[[Xorg_xkbcomp_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_libxkbfile_jll"] -git-tree-sha1 = "4bcbf660f6c2e714f87e960a171b119d06ee163b" -uuid = "35661453-b289-5fab-8a00-3d9160c6a3a4" -version = "1.4.2+4" - -[[Xorg_xkeyboard_config_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Xorg_xkbcomp_jll"] -git-tree-sha1 = "5c8424f8a67c3f2209646d4425f3d415fee5931d" -uuid = "33bec58e-1273-512f-9401-5d533626f822" -version = "2.27.0+4" - -[[Xorg_xtrans_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "79c31e7844f6ecf779705fbc12146eb190b7d845" -uuid = "c5fb5394-a638-5e4d-96e5-b29de1b5cf10" -version = "1.4.0+3" - -[[ZipFile]] -deps = ["Libdl", "Printf", "Zlib_jll"] -git-tree-sha1 = "c3a5637e27e914a7a445b8d0ad063d701931e9f7" -uuid = "a5390f91-8eb1-5f08-bee0-b1d1ffed6cea" -version = "0.9.3" - -[[Zlib_jll]] -deps = ["Libdl"] -uuid = "83775a58-1f1d-513f-b197-d71354ab007a" - -[[Zstd_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "cc4bf3fdde8b7e3e9fa0351bdeedba1cf3b7f6e6" -uuid = "3161d3a3-bdf6-5164-811a-617609db77b4" -version = "1.5.0+0" - -[[Zygote]] -deps = ["AbstractFFTs", "ChainRules", "ChainRulesCore", "DiffRules", "Distributed", "FillArrays", "ForwardDiff", "IRTools", "InteractiveUtils", "LinearAlgebra", "MacroTools", "NaNMath", "Random", "Requires", "SpecialFunctions", "Statistics", "ZygoteRules"] -git-tree-sha1 = "8b634fdb4c3c63f2ceaa2559a008da4f405af6b3" -uuid = "e88e6eb3-aa80-5325-afca-941959d7151f" -version = "0.6.17" - -[[ZygoteRules]] -deps = ["MacroTools"] -git-tree-sha1 = "9e7a1e8ca60b742e508a315c17eef5211e7fbfd7" -uuid = "700de1a5-db45-46bc-99cf-38207098b444" -version = "0.2.1" - -[[libass_jll]] -deps = ["Artifacts", "Bzip2_jll", "FreeType2_jll", "FriBidi_jll", "JLLWrappers", "Libdl", "Pkg", "Zlib_jll"] -git-tree-sha1 = "acc685bcf777b2202a904cdcb49ad34c2fa1880c" -uuid = "0ac62f75-1d6f-5e53-bd7c-93b484bb37c0" -version = "0.14.0+4" - -[[libfdk_aac_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "7a5780a0d9c6864184b3a2eeeb833a0c871f00ab" -uuid = "f638f0a6-7fb0-5443-88ba-1cc74229b280" -version = "0.1.6+4" - -[[libpng_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Zlib_jll"] -git-tree-sha1 = "94d180a6d2b5e55e447e2d27a29ed04fe79eb30c" -uuid = "b53b4c65-9356-5827-b1ea-8c7a1a84506f" -version = "1.6.38+0" - -[[libvorbis_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Ogg_jll", "Pkg"] -git-tree-sha1 = "c45f4e40e7aafe9d086379e5578947ec8b95a8fb" -uuid = "f27f6e37-5d2b-51aa-960f-b287f2bc3b7a" -version = "1.3.7+0" - -[[nghttp2_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "8e850ede-7688-5339-a07c-302acd2aaf8d" - -[[p7zip_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "3f19e933-33d8-53b3-aaab-bd5110c3b7a0" - -[[x264_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "d713c1ce4deac133e3334ee12f4adff07f81778f" -uuid = "1270edf5-f2f9-52d2-97e9-ab00b5d0237a" -version = "2020.7.14+2" - -[[x265_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "487da2f8f2f0c8ee0e83f39d13037d6bbf0a45ab" -uuid = "dfaa095f-4041-5dcd-9319-2fabd8486b76" -version = "3.0.0+3" - -[[xkbcommon_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Wayland_jll", "Wayland_protocols_jll", "Xorg_libxcb_jll", "Xorg_xkeyboard_config_jll"] -git-tree-sha1 = "ece2350174195bb31de1a63bea3a41ae1aa593b6" -uuid = "d8fb68d0-12a3-5cfd-a85a-d49703b185fd" -version = "0.9.1+5" diff --git a/src/ReinforcementLearningBase/.JuliaFormatter.toml b/src/ReinforcementLearningBase/.JuliaFormatter.toml deleted file mode 100644 index 8ec1b0b70..000000000 --- a/src/ReinforcementLearningBase/.JuliaFormatter.toml +++ /dev/null @@ -1,2 +0,0 @@ -verbose = true -always_for_in = true diff --git a/src/ReinforcementLearningBase/.github/workflows/CompatHelper.yml b/src/ReinforcementLearningBase/.github/workflows/CompatHelper.yml deleted file mode 100644 index 0f66259dd..000000000 --- a/src/ReinforcementLearningBase/.github/workflows/CompatHelper.yml +++ /dev/null @@ -1,22 +0,0 @@ -name: CompatHelper - -on: - schedule: - - cron: '00 00 * * *' - workflow_dispatch: - -jobs: - CompatHelper: - runs-on: ${{ matrix.os }} - strategy: - matrix: - julia-version: [1.2.0] - julia-arch: [x86] - os: [ubuntu-latest] - steps: - - name: Pkg.add("CompatHelper") - run: julia -e 'using Pkg; Pkg.add("CompatHelper")' - - name: CompatHelper.main() - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - run: julia -e 'using CompatHelper; CompatHelper.main()' diff --git a/src/ReinforcementLearningBase/.github/workflows/TagBot.yml b/src/ReinforcementLearningBase/.github/workflows/TagBot.yml deleted file mode 100644 index d77d3a0c3..000000000 --- a/src/ReinforcementLearningBase/.github/workflows/TagBot.yml +++ /dev/null @@ -1,11 +0,0 @@ -name: TagBot -on: - schedule: - - cron: 0 * * * * -jobs: - TagBot: - runs-on: ubuntu-latest - steps: - - uses: JuliaRegistries/TagBot@v1 - with: - token: ${{ secrets.GITHUB_TOKEN }} diff --git a/src/ReinforcementLearningBase/.github/workflows/ci.yml b/src/ReinforcementLearningBase/.github/workflows/ci.yml deleted file mode 100644 index ae9d97f9c..000000000 --- a/src/ReinforcementLearningBase/.github/workflows/ci.yml +++ /dev/null @@ -1,47 +0,0 @@ -name: CI -on: - pull_request: - branches: - - master - push: - branches: - - master - tags: '*' -jobs: - test: - name: Julia ${{ matrix.version }} - ${{ matrix.os }} - ${{ matrix.arch }} - ${{ github.event_name }} - runs-on: ${{ matrix.os }} - strategy: - fail-fast: false - matrix: - version: - - '1' # Leave this line unchanged. '1' will automatically expand to the latest stable 1.x release of Julia. - - 'nightly' - os: - - ubuntu-latest - - macOS-latest - - windows-latest - arch: - - x64 - steps: - - uses: actions/checkout@v2 - - uses: julia-actions/setup-julia@v1 - with: - version: ${{ matrix.version }} - arch: ${{ matrix.arch }} - - uses: actions/cache@v1 - env: - cache-name: cache-artifacts - with: - path: ~/.julia/artifacts - key: ${{ runner.os }}-test-${{ env.cache-name }}-${{ hashFiles('**/Project.toml') }} - restore-keys: | - ${{ runner.os }}-test-${{ env.cache-name }}- - ${{ runner.os }}-test- - ${{ runner.os }}- - - uses: julia-actions/julia-buildpkg@v1 - - uses: julia-actions/julia-runtest@v1 - - uses: julia-actions/julia-processcoverage@v1 - - uses: codecov/codecov-action@v1 - with: - file: lcov.info diff --git a/src/ReinforcementLearningBase/.github/workflows/format_pr.yml b/src/ReinforcementLearningBase/.github/workflows/format_pr.yml deleted file mode 100644 index b7a9268d8..000000000 --- a/src/ReinforcementLearningBase/.github/workflows/format_pr.yml +++ /dev/null @@ -1,29 +0,0 @@ -name: format-pr -on: - schedule: - - cron: '0 0 * * *' -jobs: - build: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - name: Install JuliaFormatter and format - run: | - julia -e 'import Pkg; Pkg.add("JuliaFormatter")' - julia -e 'using JuliaFormatter; format(".")' - # https://github.com/marketplace/actions/create-pull-request - # https://github.com/peter-evans/create-pull-request#reference-example - - name: Create Pull Request - id: cpr - uses: peter-evans/create-pull-request@v3 - with: - token: ${{ secrets.GITHUB_TOKEN }} - commit-message: Format .jl files - title: 'Automatic JuliaFormatter.jl run' - branch: auto-juliaformatter-pr - delete-branch: true - labels: formatting, automated pr, no changelog - - name: Check outputs - run: | - echo "Pull Request Number - ${{ steps.cpr.outputs.pull-request-number }}" - echo "Pull Request URL - ${{ steps.cpr.outputs.pull-request-url }}" diff --git a/src/ReinforcementLearningBase/.gitignore b/src/ReinforcementLearningBase/.gitignore deleted file mode 100644 index 459adbcec..000000000 --- a/src/ReinforcementLearningBase/.gitignore +++ /dev/null @@ -1,37 +0,0 @@ -*.jl.cov -*.jl.*.cov -*.jl.mem -deps/deps.jl - -Manifest.toml -.vscode/* -# !.vscode/settings.json -!.vscode/tasks.json -!.vscode/launch.json -!.vscode/extensions.json -*.code-workspace - -# Files generated by invoking Julia with --code-coverage -*.jl.cov -*.jl.*.cov - -# Files generated by invoking Julia with --track-allocation -*.jl.mem - -# System-specific files and directories generated by the BinaryProvider and BinDeps packages -# They contain absolute paths specific to the host computer, and so should not be committed -deps/deps.jl -deps/build.log -deps/downloads/ -deps/usr/ -deps/src/ - -# Build artifacts for creating documentation generated by the Documenter package -docs/build/ -docs/site/ - -# File generated by Pkg, the package manager, based on a corresponding Project.toml -# It records a fixed state of all packages used by the project. As such, it should not be -# committed for packages, but should be committed for applications that require a static -# environment. -Manifest.toml diff --git a/src/ReinforcementLearningBase/CHANGELOG.md b/src/ReinforcementLearningBase/CHANGELOG.md deleted file mode 100644 index 421000512..000000000 --- a/src/ReinforcementLearningBase/CHANGELOG.md +++ /dev/null @@ -1,280 +0,0 @@ -# Changelog - -## [Unreleased](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/HEAD) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.8.5...HEAD) - -**Merged pull requests:** - -- Fix bug in MaxTimeoutEnv [\#99](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/99) ([Sid-Bhatia-0](https://github.com/Sid-Bhatia-0)) -- Automatic JuliaFormatter.jl run [\#98](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/98) ([github-actions[bot]](https://github.com/apps/github-actions)) -- fix mapping function for ActionTransformedEnv test [\#97](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/97) ([Sid-Bhatia-0](https://github.com/Sid-Bhatia-0)) -- Revert auto format related changes [\#94](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/94) ([findmyway](https://github.com/findmyway)) -- Automatic JuliaFormatter.jl run [\#93](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/93) ([github-actions[bot]](https://github.com/apps/github-actions)) -- Automatic JuliaFormatter.jl run [\#92](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/92) ([github-actions[bot]](https://github.com/apps/github-actions)) -- Automatic JuliaFormatter.jl run [\#91](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/91) ([github-actions[bot]](https://github.com/apps/github-actions)) -- Enhance\_ActionTransformedEnv [\#88](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/88) ([findmyway](https://github.com/findmyway)) - -## [v0.8.5](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.8.5) (2020-10-22) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.8.4...v0.8.5) - -**Merged pull requests:** - -- add current\_t kwarg for the \(full\) constructor [\#86](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/86) ([Sid-Bhatia-0](https://github.com/Sid-Bhatia-0)) -- add env that terminates after max threshold time [\#85](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/85) ([Sid-Bhatia-0](https://github.com/Sid-Bhatia-0)) -- add\_default\_implementation\_for\_get\_prob [\#84](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/84) ([findmyway](https://github.com/findmyway)) -- Automatic JuliaFormatter.jl run [\#83](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/83) ([github-actions[bot]](https://github.com/apps/github-actions)) - -## [v0.8.4](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.8.4) (2020-09-28) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.8.3...v0.8.4) - -**Merged pull requests:** - -- return correct probability with RandomPolicy and MultiThreadEnv [\#82](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/82) ([findmyway](https://github.com/findmyway)) - -## [v0.8.3](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.8.3) (2020-09-27) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.8.2...v0.8.3) - -**Merged pull requests:** - -- Add get\_prob for RandomPolicy [\#81](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/81) ([findmyway](https://github.com/findmyway)) -- Automatic JuliaFormatter.jl run [\#80](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/80) ([github-actions[bot]](https://github.com/apps/github-actions)) - -## [v0.8.2](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.8.2) (2020-09-01) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.8.1...v0.8.2) - -**Merged pull requests:** - -- Improve DiscreteSpace and VectSpace [\#79](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/79) ([findmyway](https://github.com/findmyway)) - -## [v0.8.1](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.8.1) (2020-09-01) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.8.0...v0.8.1) - -**Closed issues:** - -- `reset!` processors in `StateOverridenEnv` [\#72](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/issues/72) -- Define possible state types [\#69](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/issues/69) - -**Merged pull requests:** - -- add weighted\_sample [\#78](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/78) ([findmyway](https://github.com/findmyway)) -- Force reset! processors in StateOverriddenEnv [\#77](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/77) ([findmyway](https://github.com/findmyway)) -- remove TabularRandomPolicy in export [\#76](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/76) ([findmyway](https://github.com/findmyway)) -- Automatic JuliaFormatter.jl run [\#75](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/75) ([github-actions[bot]](https://github.com/apps/github-actions)) -- Define possible states [\#74](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/74) ([findmyway](https://github.com/findmyway)) -- Automatic JuliaFormatter.jl run [\#71](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/71) ([github-actions[bot]](https://github.com/apps/github-actions)) -- Add tabular random policy [\#70](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/70) ([findmyway](https://github.com/findmyway)) - -## [v0.8.0](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.8.0) (2020-08-03) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.7.3...v0.8.0) - -**Closed issues:** - -- `env\(action\)` feels a little awkward [\#66](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/issues/66) -- Make RandomPolicy to support legal\_actions of type AbstractSpace [\#52](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/issues/52) -- Working with states that are not arrays. [\#48](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/issues/48) - -**Merged pull requests:** - -- Automatic JuliaFormatter.jl run [\#68](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/68) ([github-actions[bot]](https://github.com/apps/github-actions)) -- CompatHelper: add new compat entry for "CommonRLInterface" at version "0.2" [\#67](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/67) ([github-actions[bot]](https://github.com/apps/github-actions)) -- Automatic JuliaFormatter.jl run [\#65](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/65) ([github-actions[bot]](https://github.com/apps/github-actions)) -- fix \#48 [\#64](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/64) ([findmyway](https://github.com/findmyway)) -- Automatic JuliaFormatter.jl run [\#63](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/63) ([github-actions[bot]](https://github.com/apps/github-actions)) -- Add random start policy [\#62](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/62) ([findmyway](https://github.com/findmyway)) -- Minor fix [\#61](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/61) ([findmyway](https://github.com/findmyway)) -- add summary for StateCachedEnv [\#60](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/60) ([findmyway](https://github.com/findmyway)) -- Automatic JuliaFormatter.jl run [\#59](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/59) ([github-actions[bot]](https://github.com/apps/github-actions)) -- Support common rl interface [\#58](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/58) ([findmyway](https://github.com/findmyway)) -- Automatic JuliaFormatter.jl run [\#57](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/57) ([github-actions[bot]](https://github.com/apps/github-actions)) -- CompatHelper: add new compat entry for "AbstractTrees" at version "0.3" [\#56](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/56) ([github-actions[bot]](https://github.com/apps/github-actions)) -- Unify APIs [\#55](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/55) ([findmyway](https://github.com/findmyway)) -- Automatic JuliaFormatter.jl run [\#51](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/51) ([github-actions[bot]](https://github.com/apps/github-actions)) - -## [v0.7.3](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.7.3) (2020-06-26) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.7.2...v0.7.3) - -**Merged pull requests:** - -- add RewardOverriddenObs [\#50](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/50) ([findmyway](https://github.com/findmyway)) -- update docs [\#49](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/49) ([findmyway](https://github.com/findmyway)) - -## [v0.7.2](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.7.2) (2020-06-02) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.7.1...v0.7.2) - -**Closed issues:** - -- Observe, observation, state [\#45](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/issues/45) - -**Merged pull requests:** - -- deprecate get\_observation\_space [\#47](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/47) ([findmyway](https://github.com/findmyway)) -- Fix dimension error when getting a high dimensional state from BatchObs [\#46](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/46) ([findmyway](https://github.com/findmyway)) - -## [v0.7.1](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.7.1) (2020-05-11) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.7.0...v0.7.1) - -**Merged pull requests:** - -- Automatic JuliaFormatter.jl run [\#44](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/44) ([github-actions[bot]](https://github.com/apps/github-actions)) -- fix sampling from MultiContinuousSpace [\#43](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/43) ([jbrea](https://github.com/jbrea)) - -## [v0.7.0](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.7.0) (2020-05-06) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.6.6...v0.7.0) - -**Merged pull requests:** - -- Automatic JuliaFormatter.jl run [\#42](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/42) ([github-actions[bot]](https://github.com/apps/github-actions)) - -## [v0.6.6](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.6.6) (2020-05-06) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.6.5...v0.6.6) - -**Closed issues:** - -- The approximator is over-designed [\#39](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/issues/39) - -**Merged pull requests:** - -- Automatic JuliaFormatter.jl run [\#37](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/37) ([github-actions[bot]](https://github.com/apps/github-actions)) -- update WrappedEnv to support postprocessor [\#36](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/36) ([findmyway](https://github.com/findmyway)) -- keep pop! always return element [\#35](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/35) ([findmyway](https://github.com/findmyway)) -- Automatic JuliaFormatter.jl run [\#34](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/34) ([github-actions[bot]](https://github.com/apps/github-actions)) -- keep dependency concise [\#33](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/33) ([findmyway](https://github.com/findmyway)) -- Automatic JuliaFormatter.jl run [\#32](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/32) ([github-actions[bot]](https://github.com/apps/github-actions)) - -## [v0.6.5](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.6.5) (2020-03-05) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.6.4...v0.6.5) - -**Merged pull requests:** - -- Dev actor critic [\#31](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/31) ([findmyway](https://github.com/findmyway)) - -## [v0.6.4](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.6.4) (2020-02-29) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.6.3...v0.6.4) - -**Merged pull requests:** - -- Automatic JuliaFormatter.jl run [\#30](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/30) ([github-actions[bot]](https://github.com/apps/github-actions)) -- update doc [\#29](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/29) ([findmyway](https://github.com/findmyway)) -- Automatic JuliaFormatter.jl run [\#28](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/28) ([github-actions[bot]](https://github.com/apps/github-actions)) - -## [v0.6.3](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.6.3) (2020-02-26) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.6.2...v0.6.3) - -**Merged pull requests:** - -- Fix nothing not in EmptySpace. [\#27](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/27) ([aterenin](https://github.com/aterenin)) -- Add EmptySpace, for NonInteractiveEnv upstream [\#26](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/26) ([aterenin](https://github.com/aterenin)) - -## [v0.6.2](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.6.2) (2020-02-23) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.6.1...v0.6.2) - -**Merged pull requests:** - -- add batch\_estimate for approximator [\#25](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/25) ([findmyway](https://github.com/findmyway)) - -## [v0.6.1](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.6.1) (2020-02-20) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.6.0...v0.6.1) - -**Merged pull requests:** - -- Add invalid action [\#24](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/24) ([findmyway](https://github.com/findmyway)) -- Automatic JuliaFormatter.jl run [\#23](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/23) ([github-actions[bot]](https://github.com/apps/github-actions)) -- Allow converting Set to DiscreteSpace [\#22](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/22) ([findmyway](https://github.com/findmyway)) - -## [v0.6.0](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.6.0) (2020-02-17) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.5.0...v0.6.0) - -**Merged pull requests:** - -- CompatHelper: add new compat entry for "CUDAapi" at version "3.1" [\#21](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/21) ([github-actions[bot]](https://github.com/apps/github-actions)) -- CompatHelper: add new compat entry for "CuArrays" at version "1.7" [\#20](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/20) ([github-actions[bot]](https://github.com/apps/github-actions)) -- CompatHelper: add new compat entry for "MacroTools" at version "0.5" [\#19](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/19) ([github-actions[bot]](https://github.com/apps/github-actions)) -- CompatHelper: add new compat entry for "Distributions" at version "0.22" [\#18](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/18) ([github-actions[bot]](https://github.com/apps/github-actions)) -- Install TagBot as a GitHub Action [\#17](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/17) ([JuliaTagBot](https://github.com/JuliaTagBot)) -- Dev [\#16](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/16) ([findmyway](https://github.com/findmyway)) - -## [v0.5.0](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.5.0) (2020-02-01) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.4.0...v0.5.0) - -**Merged pull requests:** - -- make ActionStyle return MINIMAL\_ACTION\_SET by default [\#14](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/14) ([findmyway](https://github.com/findmyway)) -- change the default implementation of push! for trajectory [\#13](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/13) ([findmyway](https://github.com/findmyway)) -- add pop! method for AbstractTrajectory [\#12](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/12) ([findmyway](https://github.com/findmyway)) - -## [v0.4.0](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.4.0) (2020-01-28) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.3.0...v0.4.0) - -**Closed issues:** - -- TEST the github action for changelog [\#9](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/issues/9) -- Weird MethodError with `sample` [\#5](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/issues/5) - -**Merged pull requests:** - -- add two extra stages [\#10](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/10) ([findmyway](https://github.com/findmyway)) -- \[AUTO\] Format .jl files [\#8](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/8) ([github-actions[bot]](https://github.com/apps/github-actions)) - -## [v0.3.0](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.3.0) (2019-12-29) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.2.2...v0.3.0) - -**Merged pull requests:** - -- Redesign [\#6](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/6) ([findmyway](https://github.com/findmyway)) - -## [v0.2.2](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.2.2) (2018-09-07) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.2.1...v0.2.2) - -## [v0.2.1](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.2.1) (2018-09-07) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.2.0...v0.2.1) - -**Merged pull requests:** - -- import relevant methods [\#4](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/4) ([jbrea](https://github.com/jbrea)) - -## [v0.2.0](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.2.0) (2018-09-07) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/v0.1.0...v0.2.0) - -**Closed issues:** - -- Non-contiguous discrete spaces [\#2](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/issues/2) - -**Merged pull requests:** - -- add test\_envinterface [\#3](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/3) ([jbrea](https://github.com/jbrea)) - -## [v0.1.0](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/tree/v0.1.0) (2018-09-02) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/compare/6b0ec82840e827d5795e47722d8509fed2e78bec...v0.1.0) - -**Merged pull requests:** - -- Add Space & AbstractEnv into base [\#1](https://github.com/JuliaReinforcementLearning/ReinforcementLearningBase.jl/pull/1) ([findmyway](https://github.com/findmyway)) - - - -\* *This Changelog was automatically generated by [github_changelog_generator](https://github.com/github-changelog-generator/github-changelog-generator)* diff --git a/src/ReinforcementLearningBase/Manifest.toml b/src/ReinforcementLearningBase/Manifest.toml deleted file mode 100644 index 22b6c5cbe..000000000 --- a/src/ReinforcementLearningBase/Manifest.toml +++ /dev/null @@ -1,43 +0,0 @@ -# This file is machine-generated - editing it directly is not advised - -[[AbstractTrees]] -git-tree-sha1 = "03e0550477d86222521d254b741d470ba17ea0b5" -uuid = "1520ce14-60c1-5f80-bbc7-55ef81b5835c" -version = "0.3.4" - -[[Base64]] -uuid = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f" - -[[CommonRLInterface]] -deps = ["MacroTools"] -git-tree-sha1 = "21de56ebf28c262651e682f7fe614d44623dc087" -uuid = "d842c3ba-07a1-494f-bbec-f5741b0a3e98" -version = "0.3.1" - -[[InteractiveUtils]] -deps = ["Markdown"] -uuid = "b77e0a4c-d291-57a0-90e8-8db25a27a240" - -[[Logging]] -uuid = "56ddb016-857b-54e1-b83d-db4d58db5568" - -[[MacroTools]] -deps = ["Markdown", "Random"] -git-tree-sha1 = "6a8a2a625ab0dea913aba95c11370589e0239ff0" -uuid = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09" -version = "0.5.6" - -[[Markdown]] -deps = ["Base64"] -uuid = "d6f4376e-aef5-505a-96c1-9c027394607a" - -[[Random]] -deps = ["Serialization"] -uuid = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c" - -[[Serialization]] -uuid = "9e88b42a-f829-5b0c-bbe9-9e923198166b" - -[[Test]] -deps = ["InteractiveUtils", "Logging", "Random", "Serialization"] -uuid = "8dfed614-e22c-5e08-85e1-65c5234f0b40" diff --git a/src/ReinforcementLearningBase/Project.toml b/src/ReinforcementLearningBase/Project.toml index 13a6fe64b..9dc18f185 100644 --- a/src/ReinforcementLearningBase/Project.toml +++ b/src/ReinforcementLearningBase/Project.toml @@ -1,13 +1,15 @@ name = "ReinforcementLearningBase" uuid = "e575027e-6cd6-5018-9292-cdc6200d2b44" authors = ["Johanni Brea ", "Jun Tian "] -version = "0.9.7" +version = "0.10.0-dev" [deps] AbstractTrees = "1520ce14-60c1-5f80-bbc7-55ef81b5835c" CommonRLInterface = "d842c3ba-07a1-494f-bbec-f5741b0a3e98" +CommonRLSpaces = "408f5b3e-f2a2-48a6-b4bb-c8aa44c458e6" Markdown = "d6f4376e-aef5-505a-96c1-9c027394607a" Random = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c" +Reexport = "189a3867-3050-52da-a836-e630ba90ab69" Test = "8dfed614-e22c-5e08-85e1-65c5234f0b40" [compat] diff --git a/src/ReinforcementLearningBase/src/ReinforcementLearningBase.jl b/src/ReinforcementLearningBase/src/ReinforcementLearningBase.jl index 32c348359..c31f1e3d0 100644 --- a/src/ReinforcementLearningBase/src/ReinforcementLearningBase.jl +++ b/src/ReinforcementLearningBase/src/ReinforcementLearningBase.jl @@ -4,6 +4,9 @@ const RLBase = ReinforcementLearningBase export RLBase using Random +using Reexport + +@reexport using CommonRLSpaces include("inline_export.jl") include("interface.jl") diff --git a/src/ReinforcementLearningBase/src/base.jl b/src/ReinforcementLearningBase/src/base.jl index 711ed1cfb..60f8bd3ad 100644 --- a/src/ReinforcementLearningBase/src/base.jl +++ b/src/ReinforcementLearningBase/src/base.jl @@ -1,74 +1,3 @@ -##### -# Spaces -##### - -export WorldSpace - -""" -In some cases, we may not be interested in the action/state space. -One can return `WorldSpace()` to keep the interface consistent. -""" -struct WorldSpace{T} end - -WorldSpace() = WorldSpace{Any}() - -Base.in(x, ::WorldSpace{T}) where {T} = x isa T - -export Space - -""" -A wrapper to treat each element as a sub-space which supports: - -- `Base.in` -- `Random.rand` -""" -struct Space{T} - s::T -end - -Base.:(==)(x::Space, y::Space) = x.s == y.s -Base.similar(s::Space, args...) = Space(similar(s.s, args...)) -Base.getindex(s::Space, args...) = getindex(s.s, args...) -Base.setindex!(s::Space, args...) = setindex!(s.s, args...) -Base.size(s::Space) = size(s.s) -Base.length(s::Space) = length(s.s) -Base.iterate(s::Space, args...) = iterate(s.s, args...) - -Random.rand(s::Space) = rand(Random.GLOBAL_RNG, s) - -Random.rand(rng::AbstractRNG, s::Space) = - map(s.s) do x - rand(rng, x) - end - -Random.rand(rng::AbstractRNG, s::Space{<:Dict}) = Dict(k => rand(rng, v) for (k, v) in s.s) - -function Base.in(X, S::Space) - if length(X) == length(S.s) - for (x, s) in zip(X, S.s) - if x ∉ s - return false - end - end - return true - else - return false - end -end - -function Base.in(X::Dict, S::Space{<:Dict}) - if keys(X) == keys(S.s) - for k in keys(X) - if X[k] ∉ S.s[k] - return false - end - end - return true - else - return false - end -end - ##### # printing ##### @@ -198,8 +127,7 @@ function test_interfaces!(env) if ActionStyle(env) === MINIMAL_ACTION_SET action_space(env) == legal_action_space elseif ActionStyle(env) === FULL_ACTION_SET - @test legal_action_space(env) == - action_space(env)[legal_action_space_mask(env)] + # @test legal_action_space(env) == action_space(env)[legal_action_space_mask(env)] else @error "TODO:" end diff --git a/src/ReinforcementLearningBase/src/interface.jl b/src/ReinforcementLearningBase/src/interface.jl index 659bf8f36..98af0d27c 100644 --- a/src/ReinforcementLearningBase/src/interface.jl +++ b/src/ReinforcementLearningBase/src/interface.jl @@ -40,11 +40,11 @@ object which takes in an environment and returns an action. @api (π::AbstractPolicy)(env) """ - update!(π::AbstractPolicy, experience) + optimise!(π::AbstractPolicy, experience) -Update the policy `π` with online/offline experience or parameters. +Optimise the policy `π` with online/offline experience or parameters. """ -@api update!(π::AbstractPolicy, experience) +@api optimise!(π::AbstractPolicy, experience) """ prob(π::AbstractPolicy, env) -> Distribution @@ -63,7 +63,7 @@ Only valid for environments with discrete actions. """ priority(π::AbstractPolicy, experience) -Usually used in offline policies. +Usually used in offline policies to evaluate the priorities of the experience. """ @api priority(π::AbstractPolicy, experience) @@ -304,7 +304,11 @@ abstract type AbstractActionStyle <: AbstractEnvStyle end abstract type AbstractDiscreteActionStyle <: AbstractActionStyle end @api struct FullActionSet <: AbstractDiscreteActionStyle end -"The action space of the environment may contains illegal actions" +""" +The action space of the environment may contains illegal actions. For +environments of `FULL_ACTION_SET`, [`legal_action_space`](@ref) and +[`legal_action_space_mask`](@ref) must also be defined. +""" @api const FULL_ACTION_SET = FullActionSet() @api struct MinimalActionSet <: AbstractDiscreteActionStyle end @@ -371,11 +375,21 @@ Specify the default state style when calling `state(env)`. """ @env_api DefaultStateStyle(env::AbstractEnv) = DefaultStateStyle(StateStyle(env)) DefaultStateStyle(ss::AbstractStateStyle) = ss -DefaultStateStyle(ss::Tuple{Vararg{<:AbstractStateStyle}}) = first(ss) +DefaultStateStyle(ss::Tuple{Vararg{AbstractStateStyle}}) = first(ss) +##### # EpisodeStyle -# Episodic -# NeverEnding +##### + +abstract type AbstractEpisodeStyle end + +"The environment will terminate in finite steps." +@api struct Episodic <: AbstractEpisodeStyle end + +"The environment can run infinitely." +@api struct NeverEnding <: AbstractEpisodeStyle end + +@env_api EpisodeStyle(env::AbstractEnv) = Episodic() ##### # General @@ -410,12 +424,14 @@ Make an independent copy of `env`, !!! warning Only check the state of all players in the env. """ -function Base.:(==)(env1::T, env2::T) where T<:AbstractEnv +function Base.:(==)(env1::T, env2::T) where {T<:AbstractEnv} len = length(players(env1)) - len == length(players(env2)) && - all(state(env1, player) == state(env2, player) for player in players(env1)) + len == length(players(env2)) && + all(state(env1, player) == state(env2, player) for player in players(env1)) end -Base.hash(env::AbstractEnv, h::UInt) = hash([state(env, player) for player in players(env)], h) + +Base.hash(env::AbstractEnv, h::UInt) = + hash([state(env, player) for player in players(env)], h) @api nameof(env::AbstractEnv) = nameof(typeof(env)) diff --git a/src/ReinforcementLearningCore/.JuliaFormatter.toml b/src/ReinforcementLearningCore/.JuliaFormatter.toml deleted file mode 100644 index 8ec1b0b70..000000000 --- a/src/ReinforcementLearningCore/.JuliaFormatter.toml +++ /dev/null @@ -1,2 +0,0 @@ -verbose = true -always_for_in = true diff --git a/src/ReinforcementLearningCore/.github/workflows/CompatHelper.yml b/src/ReinforcementLearningCore/.github/workflows/CompatHelper.yml deleted file mode 100644 index 47a84d46c..000000000 --- a/src/ReinforcementLearningCore/.github/workflows/CompatHelper.yml +++ /dev/null @@ -1,15 +0,0 @@ -name: CompatHelper -on: - schedule: - - cron: '00 00 * * *' - workflow_dispatch: -jobs: - CompatHelper: - runs-on: ubuntu-latest - steps: - - name: Pkg.add("CompatHelper") - run: julia -e 'using Pkg; Pkg.add("CompatHelper")' - - name: CompatHelper.main() - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - run: julia -e 'using CompatHelper; CompatHelper.main()' diff --git a/src/ReinforcementLearningCore/.github/workflows/TagBot.yml b/src/ReinforcementLearningCore/.github/workflows/TagBot.yml deleted file mode 100644 index 33fd52d25..000000000 --- a/src/ReinforcementLearningCore/.github/workflows/TagBot.yml +++ /dev/null @@ -1,17 +0,0 @@ -name: TagBot -on: - issue_comment: # THIS BIT IS NEW - types: - - created - workflow_dispatch: -jobs: - TagBot: - # THIS 'if' LINE IS NEW - if: github.event_name == 'workflow_dispatch' || github.actor == 'JuliaTagBot' - # NOTHING BELOW HAS CHANGED - runs-on: ubuntu-latest - steps: - - uses: JuliaRegistries/TagBot@v1 - with: - token: ${{ secrets.GITHUB_TOKEN }} - # ssh: ${{ secrets.DOCUMENTER_KEY }} diff --git a/src/ReinforcementLearningCore/.github/workflows/changelog.yml b/src/ReinforcementLearningCore/.github/workflows/changelog.yml deleted file mode 100644 index 943326faf..000000000 --- a/src/ReinforcementLearningCore/.github/workflows/changelog.yml +++ /dev/null @@ -1,34 +0,0 @@ -name: Changelog - -on: - release: - types: [published] - -jobs: - generate_changelog: - runs-on: ubuntu-latest - name: Generate changelog for master branch - steps: - - uses: actions/checkout@v1 - - - name: Generate changelog - uses: charmixer/auto-changelog-action@v1 - with: - token: ${{ secrets.GITHUB_TOKEN }} - - - name: Commit files - env: - CI_USER: noreply - CI_EMAIL: noreply@juliareinforcementlearning.org - run: | - git config --local user.email "$CI_EMAIL" - git config --local user.name "$CI_USER" - git add CHANGELOG.md && git commit -m 'Updated CHANGELOG.md' && echo ::set-env name=push::1 || echo "No changes to CHANGELOG.md" - - - name: Push changes - if: env.push == 1 - env: - CI_USER: noreply - CI_TOKEN: ${{ secrets.GITHUB_TOKEN }} - run: | - git push "https://$CI_USER:$CI_TOKEN@github.com/$GITHUB_REPOSITORY.git" HEAD:master diff --git a/src/ReinforcementLearningCore/.github/workflows/ci.yml b/src/ReinforcementLearningCore/.github/workflows/ci.yml deleted file mode 100644 index 7cb55ebe1..000000000 --- a/src/ReinforcementLearningCore/.github/workflows/ci.yml +++ /dev/null @@ -1,46 +0,0 @@ -name: CI -on: - pull_request: - branches: - - master - push: - branches: - - master - tags: '*' -jobs: - test: - name: Julia ${{ matrix.version }} - ${{ matrix.os }} - ${{ matrix.arch }} - ${{ github.event_name }} - runs-on: ${{ matrix.os }} - strategy: - fail-fast: false - matrix: - version: - - '1' # Leave this line unchanged. '1' will automatically expand to the latest stable 1.x release of Julia. - os: - - ubuntu-latest - - macOS-latest - - windows-latest - arch: - - x64 - steps: - - uses: actions/checkout@v2 - - uses: julia-actions/setup-julia@v1 - with: - version: ${{ matrix.version }} - arch: ${{ matrix.arch }} - - uses: actions/cache@v1 - env: - cache-name: cache-artifacts - with: - path: ~/.julia/artifacts - key: ${{ runner.os }}-test-${{ env.cache-name }}-${{ hashFiles('**/Project.toml') }} - restore-keys: | - ${{ runner.os }}-test-${{ env.cache-name }}- - ${{ runner.os }}-test- - ${{ runner.os }}- - - uses: julia-actions/julia-buildpkg@v1 - - uses: julia-actions/julia-runtest@v1 - - uses: julia-actions/julia-processcoverage@v1 - - uses: codecov/codecov-action@v1 - with: - file: lcov.info diff --git a/src/ReinforcementLearningCore/.github/workflows/format_pr.yml b/src/ReinforcementLearningCore/.github/workflows/format_pr.yml deleted file mode 100644 index 95fc1b0b8..000000000 --- a/src/ReinforcementLearningCore/.github/workflows/format_pr.yml +++ /dev/null @@ -1,30 +0,0 @@ -name: format-pr -on: - schedule: - - cron: '0 0 * * *' -jobs: - build: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - name: Install JuliaFormatter and format - run: | - julia -e 'import Pkg; Pkg.add("JuliaFormatter")' - julia -e 'using JuliaFormatter; format(".")' - - # https://github.com/marketplace/actions/create-pull-request - # https://github.com/peter-evans/create-pull-request#reference-example - - name: Create Pull Request - id: cpr - uses: peter-evans/create-pull-request@v3 - with: - token: ${{ secrets.GITHUB_TOKEN }} - commit-message: Format .jl files - title: 'Automatic JuliaFormatter.jl run' - branch: auto-juliaformatter-pr - delete-branch: true - labels: formatting, automated pr, no changelog - - name: Check outputs - run: | - echo "Pull Request Number - ${{ steps.cpr.outputs.pull-request-number }}" - echo "Pull Request URL - ${{ steps.cpr.outputs.pull-request-url }}" diff --git a/src/ReinforcementLearningCore/.gitignore b/src/ReinforcementLearningCore/.gitignore deleted file mode 100644 index cc11c32d3..000000000 --- a/src/ReinforcementLearningCore/.gitignore +++ /dev/null @@ -1,5 +0,0 @@ -.DS_Store -Manifest.toml -/dev/ -/checkpoints/ -/logs/ \ No newline at end of file diff --git a/src/ReinforcementLearningCore/CHANGELOG.md b/src/ReinforcementLearningCore/CHANGELOG.md deleted file mode 100644 index e6e0e0491..000000000 --- a/src/ReinforcementLearningCore/CHANGELOG.md +++ /dev/null @@ -1,21 +0,0 @@ -# Changelog - -## [v0.1.0](https://github.com/JuliaReinforcementLearning/ReinforcementLearningCore.jl/tree/v0.1.0) (2020-02-03) - -[Full Changelog](https://github.com/JuliaReinforcementLearning/ReinforcementLearningCore.jl/compare/134c9da6083ff6ca9db61356b2e130f499712cbb...v0.1.0) - -**Merged pull requests:** - -- CompatHelper: add new compat entry for "Distributions" at version "0.22" [\#16](https://github.com/JuliaReinforcementLearning/ReinforcementLearningCore.jl/pull/16) ([github-actions[bot]](https://github.com/apps/github-actions)) -- CompatHelper: add new compat entry for "ProgressMeter" at version "1.2" [\#15](https://github.com/JuliaReinforcementLearning/ReinforcementLearningCore.jl/pull/15) ([github-actions[bot]](https://github.com/apps/github-actions)) -- CompatHelper: add new compat entry for "MacroTools" at version "0.5" [\#14](https://github.com/JuliaReinforcementLearning/ReinforcementLearningCore.jl/pull/14) ([github-actions[bot]](https://github.com/apps/github-actions)) -- CompatHelper: add new compat entry for "ReinforcementLearningBase" at version "0.5" [\#13](https://github.com/JuliaReinforcementLearning/ReinforcementLearningCore.jl/pull/13) ([github-actions[bot]](https://github.com/apps/github-actions)) -- CompatHelper: add new compat entry for "StatsBase" at version "0.32" [\#12](https://github.com/JuliaReinforcementLearning/ReinforcementLearningCore.jl/pull/12) ([github-actions[bot]](https://github.com/apps/github-actions)) -- CompatHelper: add new compat entry for "Flux" at version "0.10" [\#11](https://github.com/JuliaReinforcementLearning/ReinforcementLearningCore.jl/pull/11) ([github-actions[bot]](https://github.com/apps/github-actions)) -- CompatHelper: add new compat entry for "Reexport" at version "0.2" [\#10](https://github.com/JuliaReinforcementLearning/ReinforcementLearningCore.jl/pull/10) ([github-actions[bot]](https://github.com/apps/github-actions)) -- CompatHelper: add new compat entry for "CuArrays" at version "1.7" [\#9](https://github.com/JuliaReinforcementLearning/ReinforcementLearningCore.jl/pull/9) ([github-actions[bot]](https://github.com/apps/github-actions)) -- Initial Commit [\#8](https://github.com/JuliaReinforcementLearning/ReinforcementLearningCore.jl/pull/8) ([findmyway](https://github.com/findmyway)) - - - -\* *This Changelog was automatically generated by [github_changelog_generator](https://github.com/github-changelog-generator/github-changelog-generator)* diff --git a/src/ReinforcementLearningCore/Manifest.toml b/src/ReinforcementLearningCore/Manifest.toml deleted file mode 100644 index f192adea4..000000000 --- a/src/ReinforcementLearningCore/Manifest.toml +++ /dev/null @@ -1,666 +0,0 @@ -# This file is machine-generated - editing it directly is not advised - -[[AbstractFFTs]] -deps = ["ChainRulesCore", "LinearAlgebra"] -git-tree-sha1 = "6f1d9bc1c08f9f4a8fa92e3ea3cb50153a1b40d4" -uuid = "621f4979-c628-5d54-868e-fcf4e3e8185c" -version = "1.1.0" - -[[AbstractTrees]] -git-tree-sha1 = "03e0550477d86222521d254b741d470ba17ea0b5" -uuid = "1520ce14-60c1-5f80-bbc7-55ef81b5835c" -version = "0.3.4" - -[[Adapt]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "af92965fb30777147966f58acb05da51c5616b5f" -uuid = "79e6a3ab-5dfb-504d-930d-738a2a938a0e" -version = "3.3.3" - -[[ArgTools]] -uuid = "0dad84c5-d112-42e6-8d28-ef12dabb789f" - -[[ArrayInterface]] -deps = ["Compat", "IfElse", "LinearAlgebra", "Requires", "SparseArrays", "Static"] -git-tree-sha1 = "1ee88c4c76caa995a885dc2f22a5d548dfbbc0ba" -uuid = "4fba245c-0d91-5ea0-9b3e-6abc04ee57a9" -version = "3.2.2" - -[[Artifacts]] -uuid = "56f22d72-fd6d-98f1-02f0-08ddc0907c33" - -[[BFloat16s]] -deps = ["LinearAlgebra", "Printf", "Random", "Test"] -git-tree-sha1 = "a598ecb0d717092b5539dbbe890c98bac842b072" -uuid = "ab4f0b2a-ad5b-11e8-123f-65d77653426b" -version = "0.2.0" - -[[Base64]] -uuid = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f" - -[[CEnum]] -git-tree-sha1 = "215a9aa4a1f23fbd05b92769fdd62559488d70e9" -uuid = "fa961155-64e5-5f13-b03f-caf6b980ea82" -version = "0.4.1" - -[[CUDA]] -deps = ["AbstractFFTs", "Adapt", "BFloat16s", "CEnum", "CompilerSupportLibraries_jll", "ExprTools", "GPUArrays", "GPUCompiler", "LLVM", "LazyArtifacts", "Libdl", "LinearAlgebra", "Logging", "Printf", "Random", "Random123", "RandomNumbers", "Reexport", "Requires", "SparseArrays", "SpecialFunctions", "TimerOutputs"] -git-tree-sha1 = "c60152d5401c14b770b045933a255828f1786bd3" -uuid = "052768ef-5323-5732-b1bb-66c8b64840ba" -version = "3.8.3" - -[[Calculus]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "f641eb0a4f00c343bbc32346e1217b86f3ce9dad" -uuid = "49dc2e85-a5d0-5ad3-a950-438e2897f1b9" -version = "0.5.1" - -[[ChainRules]] -deps = ["ChainRulesCore", "Compat", "IrrationalConstants", "LinearAlgebra", "Random", "RealDot", "SparseArrays", "Statistics"] -git-tree-sha1 = "8aa3851bfd1e5fc9c584afe4fe6ebd3d440deddb" -uuid = "082447d4-558c-5d27-93f4-14fc19e9eca2" -version = "1.28.0" - -[[ChainRulesCore]] -deps = ["Compat", "LinearAlgebra", "SparseArrays"] -git-tree-sha1 = "c9a6160317d1abe9c44b3beb367fd448117679ca" -uuid = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4" -version = "1.13.0" - -[[ChangesOfVariables]] -deps = ["ChainRulesCore", "LinearAlgebra", "Test"] -git-tree-sha1 = "bf98fa45a0a4cee295de98d4c1462be26345b9a1" -uuid = "9e997f8a-9a97-42d5-a9f1-ce6bfc15e2c0" -version = "0.1.2" - -[[CircularArrayBuffers]] -deps = ["Adapt"] -git-tree-sha1 = "a5c42e8195f1187e32125f48a1638c6db2488e48" -uuid = "9de3a189-e0c0-4e15-ba3b-b14b9fb0aec1" -version = "0.1.7" - -[[CodecZlib]] -deps = ["TranscodingStreams", "Zlib_jll"] -git-tree-sha1 = "ded953804d019afa9a3f98981d99b33e3db7b6da" -uuid = "944b1d66-785c-5afd-91f1-9de20f533193" -version = "0.7.0" - -[[ColorTypes]] -deps = ["FixedPointNumbers", "Random"] -git-tree-sha1 = "024fe24d83e4a5bf5fc80501a314ce0d1aa35597" -uuid = "3da002f7-5984-5a60-b8a6-cbb66c0b333f" -version = "0.11.0" - -[[Colors]] -deps = ["ColorTypes", "FixedPointNumbers", "Reexport"] -git-tree-sha1 = "417b0ed7b8b838aa6ca0a87aadf1bb9eb111ce40" -uuid = "5ae59095-9a9b-59fe-a467-6f913c188581" -version = "0.12.8" - -[[CommonRLInterface]] -deps = ["MacroTools"] -git-tree-sha1 = "21de56ebf28c262651e682f7fe614d44623dc087" -uuid = "d842c3ba-07a1-494f-bbec-f5741b0a3e98" -version = "0.3.1" - -[[CommonSubexpressions]] -deps = ["MacroTools", "Test"] -git-tree-sha1 = "7b8a93dba8af7e3b42fecabf646260105ac373f7" -uuid = "bbf7d656-a473-5ed7-a52c-81e309532950" -version = "0.3.0" - -[[Compat]] -deps = ["Base64", "Dates", "DelimitedFiles", "Distributed", "InteractiveUtils", "LibGit2", "Libdl", "LinearAlgebra", "Markdown", "Mmap", "Pkg", "Printf", "REPL", "Random", "SHA", "Serialization", "SharedArrays", "Sockets", "SparseArrays", "Statistics", "Test", "UUIDs", "Unicode"] -git-tree-sha1 = "96b0bc6c52df76506efc8a441c6cf1adcb1babc4" -uuid = "34da2185-b29b-5c13-b0c7-acf172513d20" -version = "3.42.0" - -[[CompilerSupportLibraries_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "e66e0078-7015-5450-92f7-15fbd957f2ae" - -[[ConstructionBase]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "f74e9d5388b8620b4cee35d4c5a618dd4dc547f4" -uuid = "187b0558-2788-49d3-abe0-74a17ed4e7c9" -version = "1.3.0" - -[[Contour]] -deps = ["StaticArrays"] -git-tree-sha1 = "9f02045d934dc030edad45944ea80dbd1f0ebea7" -uuid = "d38c429a-6771-53c6-b99e-75d170b6e991" -version = "0.5.7" - -[[Crayons]] -git-tree-sha1 = "249fe38abf76d48563e2f4556bebd215aa317e15" -uuid = "a8cc5b0e-0ffa-5ad4-8c14-923d3ee1735f" -version = "4.1.1" - -[[DataAPI]] -git-tree-sha1 = "cc70b17275652eb47bc9e5f81635981f13cea5c8" -uuid = "9a962f9c-6df0-11e9-0e5d-c546b8b5ee8a" -version = "1.9.0" - -[[DataStructures]] -deps = ["Compat", "InteractiveUtils", "OrderedCollections"] -git-tree-sha1 = "3daef5523dd2e769dad2365274f760ff5f282c7d" -uuid = "864edb3b-99cc-5e75-8d2d-829cb0a9cfe8" -version = "0.18.11" - -[[Dates]] -deps = ["Printf"] -uuid = "ade2ca70-3891-5945-98fb-dc099432e06a" - -[[DelimitedFiles]] -deps = ["Mmap"] -uuid = "8bb1440f-4735-579b-a4ab-409b98df4dab" - -[[DensityInterface]] -deps = ["InverseFunctions", "Test"] -git-tree-sha1 = "80c3e8639e3353e5d2912fb3a1916b8455e2494b" -uuid = "b429d917-457f-4dbc-8f4c-0cc954292b1d" -version = "0.4.0" - -[[DiffResults]] -deps = ["StaticArrays"] -git-tree-sha1 = "c18e98cba888c6c25d1c3b048e4b3380ca956805" -uuid = "163ba53b-c6d8-5494-b064-1a9d43ac40c5" -version = "1.0.3" - -[[DiffRules]] -deps = ["IrrationalConstants", "LogExpFunctions", "NaNMath", "Random", "SpecialFunctions"] -git-tree-sha1 = "dd933c4ef7b4c270aacd4eb88fa64c147492acf0" -uuid = "b552c78f-8df3-52c6-915a-8e097449b14b" -version = "1.10.0" - -[[Distributed]] -deps = ["Random", "Serialization", "Sockets"] -uuid = "8ba89e20-285c-5b6f-9357-94700520ee1b" - -[[Distributions]] -deps = ["ChainRulesCore", "DensityInterface", "FillArrays", "LinearAlgebra", "PDMats", "Printf", "QuadGK", "Random", "SparseArrays", "SpecialFunctions", "Statistics", "StatsBase", "StatsFuns", "Test"] -git-tree-sha1 = "9d3c0c762d4666db9187f363a76b47f7346e673b" -uuid = "31c24e10-a181-5473-b8eb-7969acd0382f" -version = "0.25.49" - -[[DocStringExtensions]] -deps = ["LibGit2"] -git-tree-sha1 = "b19534d1895d702889b219c382a6e18010797f0b" -uuid = "ffbed154-4ef7-542d-bbb7-c09d3a79fcae" -version = "0.8.6" - -[[Downloads]] -deps = ["ArgTools", "LibCURL", "NetworkOptions"] -uuid = "f43a241f-c20a-4ad4-852c-f6b1247861c6" - -[[DualNumbers]] -deps = ["Calculus", "NaNMath", "SpecialFunctions"] -git-tree-sha1 = "90b158083179a6ccbce2c7eb1446d5bf9d7ae571" -uuid = "fa6b7ba4-c1ee-5f82-b5fc-ecf0adba8f74" -version = "0.6.7" - -[[ElasticArrays]] -deps = ["Adapt"] -git-tree-sha1 = "a0fcc1bb3c9ceaf07e1d0529c9806ce94be6adf9" -uuid = "fdbdab4c-e67f-52f5-8c3f-e7b388dad3d4" -version = "1.2.9" - -[[ExprTools]] -git-tree-sha1 = "56559bbef6ca5ea0c0818fa5c90320398a6fbf8d" -uuid = "e2ba6199-217a-4e67-a87a-7c52f15ade04" -version = "0.1.8" - -[[FillArrays]] -deps = ["LinearAlgebra", "Random", "SparseArrays", "Statistics"] -git-tree-sha1 = "0dbc5b9683245f905993b51d2814202d75b34f1a" -uuid = "1a297f60-69ca-5386-bcde-b61e274b549b" -version = "0.13.1" - -[[FixedPointNumbers]] -deps = ["Statistics"] -git-tree-sha1 = "335bfdceacc84c5cdf16aadc768aa5ddfc5383cc" -uuid = "53c48c17-4a7d-5ca2-90c5-79b7896eea93" -version = "0.8.4" - -[[Flux]] -deps = ["AbstractTrees", "Adapt", "ArrayInterface", "CUDA", "CodecZlib", "Colors", "DelimitedFiles", "Functors", "Juno", "LinearAlgebra", "MacroTools", "NNlib", "NNlibCUDA", "Pkg", "Printf", "Random", "Reexport", "SHA", "SparseArrays", "Statistics", "StatsBase", "Test", "ZipFile", "Zygote"] -git-tree-sha1 = "983271b47332fd3d9488d6f2d724570290971794" -uuid = "587475ba-b771-5e3f-ad9e-33799f191a9c" -version = "0.12.9" - -[[ForwardDiff]] -deps = ["CommonSubexpressions", "DiffResults", "DiffRules", "LinearAlgebra", "LogExpFunctions", "NaNMath", "Preferences", "Printf", "Random", "SpecialFunctions", "StaticArrays"] -git-tree-sha1 = "1bd6fc0c344fc0cbee1f42f8d2e7ec8253dda2d2" -uuid = "f6369f11-7733-5829-9624-2563aa707210" -version = "0.10.25" - -[[Functors]] -git-tree-sha1 = "223fffa49ca0ff9ce4f875be001ffe173b2b7de4" -uuid = "d9f16b24-f501-4c13-a1f2-28368ffc5196" -version = "0.2.8" - -[[Future]] -deps = ["Random"] -uuid = "9fa8497b-333b-5362-9e8d-4d0656e87820" - -[[GPUArrays]] -deps = ["Adapt", "LLVM", "LinearAlgebra", "Printf", "Random", "Serialization", "Statistics"] -git-tree-sha1 = "cf91e6e9213b9190dc0511d6fff862a86652a94a" -uuid = "0c68f7d7-f131-5f86-a1c3-88cf8149b2d7" -version = "8.2.1" - -[[GPUCompiler]] -deps = ["ExprTools", "InteractiveUtils", "LLVM", "Libdl", "Logging", "TimerOutputs", "UUIDs"] -git-tree-sha1 = "647a54f196b5ffb7c3bc2fec5c9a57fa273354cc" -uuid = "61eb1bfa-7361-4325-ad38-22787b887f55" -version = "0.13.14" - -[[HypergeometricFunctions]] -deps = ["DualNumbers", "LinearAlgebra", "SpecialFunctions", "Test"] -git-tree-sha1 = "65e4589030ef3c44d3b90bdc5aac462b4bb05567" -uuid = "34004b35-14d8-5ef3-9330-4cdb6864b03a" -version = "0.3.8" - -[[IRTools]] -deps = ["InteractiveUtils", "MacroTools", "Test"] -git-tree-sha1 = "7f43342f8d5fd30ead0ba1b49ab1a3af3b787d24" -uuid = "7869d1d1-7146-5819-86e3-90919afe41df" -version = "0.4.5" - -[[IfElse]] -git-tree-sha1 = "debdd00ffef04665ccbb3e150747a77560e8fad1" -uuid = "615f187c-cbe4-4ef1-ba3b-2fcf58d6d173" -version = "0.1.1" - -[[InteractiveUtils]] -deps = ["Markdown"] -uuid = "b77e0a4c-d291-57a0-90e8-8db25a27a240" - -[[InverseFunctions]] -deps = ["Test"] -git-tree-sha1 = "91b5dcf362c5add98049e6c29ee756910b03051d" -uuid = "3587e190-3f89-42d0-90ee-14403ec27112" -version = "0.1.3" - -[[IrrationalConstants]] -git-tree-sha1 = "7fd44fd4ff43fc60815f8e764c0f352b83c49151" -uuid = "92d709cd-6900-40b7-9082-c6be49f344b6" -version = "0.1.1" - -[[JLLWrappers]] -deps = ["Preferences"] -git-tree-sha1 = "abc9885a7ca2052a736a600f7fa66209f96506e1" -uuid = "692b3bcd-3c85-4b1f-b108-f13ce0eb3210" -version = "1.4.1" - -[[Juno]] -deps = ["Base64", "Logging", "Media", "Profile"] -git-tree-sha1 = "07cb43290a840908a771552911a6274bc6c072c7" -uuid = "e5e0dc1b-0480-54bc-9374-aad01c23163d" -version = "0.8.4" - -[[LLVM]] -deps = ["CEnum", "LLVMExtra_jll", "Libdl", "Printf", "Unicode"] -git-tree-sha1 = "c9b86064be5ae0f63e50816a5a90b08c474507ae" -uuid = "929cbde3-209d-540e-8aea-75f648917ca0" -version = "4.9.1" - -[[LLVMExtra_jll]] -deps = ["Artifacts", "JLLWrappers", "LazyArtifacts", "Libdl", "Pkg"] -git-tree-sha1 = "5558ad3c8972d602451efe9d81c78ec14ef4f5ef" -uuid = "dad2f222-ce93-54a1-a47d-0025e8a3acab" -version = "0.0.14+2" - -[[LazyArtifacts]] -deps = ["Artifacts", "Pkg"] -uuid = "4af54fe1-eca0-43a8-85a7-787d91b784e3" - -[[LibCURL]] -deps = ["LibCURL_jll", "MozillaCACerts_jll"] -uuid = "b27032c2-a3e7-50c8-80cd-2d36dbcbfd21" - -[[LibCURL_jll]] -deps = ["Artifacts", "LibSSH2_jll", "Libdl", "MbedTLS_jll", "Zlib_jll", "nghttp2_jll"] -uuid = "deac9b47-8bc7-5906-a0fe-35ac56dc84c0" - -[[LibGit2]] -deps = ["Base64", "NetworkOptions", "Printf", "SHA"] -uuid = "76f85450-5226-5b5a-8eaa-529ad045b433" - -[[LibSSH2_jll]] -deps = ["Artifacts", "Libdl", "MbedTLS_jll"] -uuid = "29816b5a-b9ab-546f-933c-edad1886dfa8" - -[[Libdl]] -uuid = "8f399da3-3557-5675-b5ff-fb832c97cbdb" - -[[LinearAlgebra]] -deps = ["Libdl", "libblastrampoline_jll"] -uuid = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e" - -[[LogExpFunctions]] -deps = ["ChainRulesCore", "ChangesOfVariables", "DocStringExtensions", "InverseFunctions", "IrrationalConstants", "LinearAlgebra"] -git-tree-sha1 = "3f7cb7157ef860c637f3f4929c8ed5d9716933c6" -uuid = "2ab3a3ac-af41-5b50-aa03-7779005ae688" -version = "0.3.7" - -[[Logging]] -uuid = "56ddb016-857b-54e1-b83d-db4d58db5568" - -[[MacroTools]] -deps = ["Markdown", "Random"] -git-tree-sha1 = "3d3e902b31198a27340d0bf00d6ac452866021cf" -uuid = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09" -version = "0.5.9" - -[[MarchingCubes]] -deps = ["StaticArrays"] -git-tree-sha1 = "5f768e0a0c3875df386be4c036f78c8bd4b1a9b6" -uuid = "299715c1-40a9-479a-aaf9-4a633d36f717" -version = "0.1.2" - -[[Markdown]] -deps = ["Base64"] -uuid = "d6f4376e-aef5-505a-96c1-9c027394607a" - -[[MbedTLS_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "c8ffd9c3-330d-5841-b78e-0817d7145fa1" - -[[Media]] -deps = ["MacroTools", "Test"] -git-tree-sha1 = "75a54abd10709c01f1b86b84ec225d26e840ed58" -uuid = "e89f7d12-3494-54d1-8411-f7d8b9ae1f27" -version = "0.5.0" - -[[Missings]] -deps = ["DataAPI"] -git-tree-sha1 = "bf210ce90b6c9eed32d25dbcae1ebc565df2687f" -uuid = "e1d29d7a-bbdc-5cf2-9ac0-f12de2c33e28" -version = "1.0.2" - -[[Mmap]] -uuid = "a63ad114-7e13-5084-954f-fe012c677804" - -[[MozillaCACerts_jll]] -uuid = "14a3606d-f60d-562e-9121-12d972cd8159" - -[[NNlib]] -deps = ["Adapt", "ChainRulesCore", "Compat", "LinearAlgebra", "Pkg", "Requires", "Statistics"] -git-tree-sha1 = "a59a614b8b4ea6dc1dcec8c6514e251f13ccbe10" -uuid = "872c559c-99b0-510c-b3b7-b6c96a88d5cd" -version = "0.8.4" - -[[NNlibCUDA]] -deps = ["CUDA", "LinearAlgebra", "NNlib", "Random", "Statistics"] -git-tree-sha1 = "0d18b4c80a92a00d3d96e8f9677511a7422a946e" -uuid = "a00861dc-f156-4864-bf3c-e6376f28a68d" -version = "0.2.2" - -[[NaNMath]] -git-tree-sha1 = "b086b7ea07f8e38cf122f5016af580881ac914fe" -uuid = "77ba4419-2d1f-58cd-9bb1-8ffee604a2e3" -version = "0.3.7" - -[[NetworkOptions]] -uuid = "ca575930-c2e3-43a9-ace4-1e988b2c1908" - -[[OpenBLAS_jll]] -deps = ["Artifacts", "CompilerSupportLibraries_jll", "Libdl"] -uuid = "4536629a-c528-5b80-bd46-f80d51c5b363" - -[[OpenLibm_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "05823500-19ac-5b8b-9628-191a04bc5112" - -[[OpenSpecFun_jll]] -deps = ["Artifacts", "CompilerSupportLibraries_jll", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "13652491f6856acfd2db29360e1bbcd4565d04f1" -uuid = "efe28fd5-8261-553b-a9e1-b2916fc3738e" -version = "0.5.5+0" - -[[OrderedCollections]] -git-tree-sha1 = "85f8e6578bf1f9ee0d11e7bb1b1456435479d47c" -uuid = "bac558e1-5e72-5ebc-8fee-abe8a469f55d" -version = "1.4.1" - -[[PDMats]] -deps = ["LinearAlgebra", "SparseArrays", "SuiteSparse"] -git-tree-sha1 = "7e2166042d1698b6072352c74cfd1fca2a968253" -uuid = "90014a1f-27ba-587c-ab20-58faa44d9150" -version = "0.11.6" - -[[Pkg]] -deps = ["Artifacts", "Dates", "Downloads", "LibGit2", "Libdl", "Logging", "Markdown", "Printf", "REPL", "Random", "SHA", "Serialization", "TOML", "Tar", "UUIDs", "p7zip_jll"] -uuid = "44cfe95a-1eb2-52ea-b672-e2afdf69b78f" - -[[Preferences]] -deps = ["TOML"] -git-tree-sha1 = "de893592a221142f3db370f48290e3a2ef39998f" -uuid = "21216c6a-2e73-6563-6e65-726566657250" -version = "1.2.4" - -[[Printf]] -deps = ["Unicode"] -uuid = "de0858da-6303-5e67-8744-51eddeeeb8d7" - -[[Profile]] -deps = ["Printf"] -uuid = "9abbd945-dff8-562f-b5e8-e1ebf5ef1b79" - -[[ProgressMeter]] -deps = ["Distributed", "Printf"] -git-tree-sha1 = "afadeba63d90ff223a6a48d2009434ecee2ec9e8" -uuid = "92933f4c-e287-5a05-a399-4b506db050ca" -version = "1.7.1" - -[[QuadGK]] -deps = ["DataStructures", "LinearAlgebra"] -git-tree-sha1 = "78aadffb3efd2155af139781b8a8df1ef279ea39" -uuid = "1fd47b50-473d-5c70-9696-f719f8f3bcdc" -version = "2.4.2" - -[[REPL]] -deps = ["InteractiveUtils", "Markdown", "Sockets", "Unicode"] -uuid = "3fa0cd96-eef1-5676-8a61-b3b8758bbffb" - -[[Random]] -deps = ["SHA", "Serialization"] -uuid = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c" - -[[Random123]] -deps = ["Random", "RandomNumbers"] -git-tree-sha1 = "afeacaecf4ed1649555a19cb2cad3c141bbc9474" -uuid = "74087812-796a-5b5d-8853-05524746bad3" -version = "1.5.0" - -[[RandomNumbers]] -deps = ["Random", "Requires"] -git-tree-sha1 = "043da614cc7e95c703498a491e2c21f58a2b8111" -uuid = "e6cf234a-135c-5ec9-84dd-332b85af5143" -version = "1.5.3" - -[[RealDot]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "9f0a1b71baaf7650f4fa8a1d168c7fb6ee41f0c9" -uuid = "c1ae055f-0cd5-4b69-90a6-9a35b1a98df9" -version = "0.1.0" - -[[Reexport]] -git-tree-sha1 = "45e428421666073eab6f2da5c9d310d99bb12f9b" -uuid = "189a3867-3050-52da-a836-e630ba90ab69" -version = "1.2.2" - -[[ReinforcementLearningBase]] -deps = ["AbstractTrees", "CommonRLInterface", "Markdown", "Random", "Test"] -path = "../ReinforcementLearningBase" -uuid = "e575027e-6cd6-5018-9292-cdc6200d2b44" -version = "0.9.7" - -[[Requires]] -deps = ["UUIDs"] -git-tree-sha1 = "838a3a4188e2ded87a4f9f184b4b0d78a1e91cb7" -uuid = "ae029012-a4dd-5104-9daa-d747884805df" -version = "1.3.0" - -[[Rmath]] -deps = ["Random", "Rmath_jll"] -git-tree-sha1 = "bf3188feca147ce108c76ad82c2792c57abe7b1f" -uuid = "79098fc4-a85e-5d69-aa6a-4863f24498fa" -version = "0.7.0" - -[[Rmath_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "68db32dff12bb6127bac73c209881191bf0efbb7" -uuid = "f50d1b31-88e8-58de-be2c-1cc44531875f" -version = "0.3.0+0" - -[[SHA]] -uuid = "ea8e919c-243c-51af-8825-aaa63cd721ce" - -[[Serialization]] -uuid = "9e88b42a-f829-5b0c-bbe9-9e923198166b" - -[[Setfield]] -deps = ["ConstructionBase", "Future", "MacroTools", "Requires"] -git-tree-sha1 = "38d88503f695eb0301479bc9b0d4320b378bafe5" -uuid = "efcf1570-3423-57d1-acb7-fd33fddbac46" -version = "0.8.2" - -[[SharedArrays]] -deps = ["Distributed", "Mmap", "Random", "Serialization"] -uuid = "1a1011a3-84de-559e-8e89-a11a2f7dc383" - -[[Sockets]] -uuid = "6462fe0b-24de-5631-8697-dd941f90decc" - -[[SortingAlgorithms]] -deps = ["DataStructures"] -git-tree-sha1 = "b3363d7460f7d098ca0912c69b082f75625d7508" -uuid = "a2af1166-a08f-5f64-846c-94a0d3cef48c" -version = "1.0.1" - -[[SparseArrays]] -deps = ["LinearAlgebra", "Random"] -uuid = "2f01184e-e22b-5df5-ae63-d93ebab69eaf" - -[[SpecialFunctions]] -deps = ["ChainRulesCore", "IrrationalConstants", "LogExpFunctions", "OpenLibm_jll", "OpenSpecFun_jll"] -git-tree-sha1 = "5ba658aeecaaf96923dce0da9e703bd1fe7666f9" -uuid = "276daf66-3868-5448-9aa4-cd146d93841b" -version = "2.1.4" - -[[Static]] -deps = ["IfElse"] -git-tree-sha1 = "7f5a513baec6f122401abfc8e9c074fdac54f6c1" -uuid = "aedffcd0-7271-4cad-89d0-dc628f76c6d3" -version = "0.4.1" - -[[StaticArrays]] -deps = ["LinearAlgebra", "Random", "Statistics"] -git-tree-sha1 = "74fb527333e72ada2dd9ef77d98e4991fb185f04" -uuid = "90137ffa-7385-5640-81b9-e52037218182" -version = "1.4.1" - -[[Statistics]] -deps = ["LinearAlgebra", "SparseArrays"] -uuid = "10745b16-79ce-11e8-11f9-7d13ad32a3b2" - -[[StatsAPI]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "c3d8ba7f3fa0625b062b82853a7d5229cb728b6b" -uuid = "82ae8749-77ed-4fe6-ae5f-f523153014b0" -version = "1.2.1" - -[[StatsBase]] -deps = ["DataAPI", "DataStructures", "LinearAlgebra", "LogExpFunctions", "Missings", "Printf", "Random", "SortingAlgorithms", "SparseArrays", "Statistics", "StatsAPI"] -git-tree-sha1 = "8977b17906b0a1cc74ab2e3a05faa16cf08a8291" -uuid = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91" -version = "0.33.16" - -[[StatsFuns]] -deps = ["ChainRulesCore", "HypergeometricFunctions", "InverseFunctions", "IrrationalConstants", "LogExpFunctions", "Reexport", "Rmath", "SpecialFunctions"] -git-tree-sha1 = "25405d7016a47cf2bd6cd91e66f4de437fd54a07" -uuid = "4c63d2b9-4356-54db-8cca-17b64c39e42c" -version = "0.9.16" - -[[SuiteSparse]] -deps = ["Libdl", "LinearAlgebra", "Serialization", "SparseArrays"] -uuid = "4607b0f0-06f3-5cda-b6b1-a6196a1729e9" - -[[TOML]] -deps = ["Dates"] -uuid = "fa267f1f-6049-4f14-aa54-33bafae1ed76" - -[[Tar]] -deps = ["ArgTools", "SHA"] -uuid = "a4e569a6-e804-4fa4-b0f3-eef7a1d5b13e" - -[[Test]] -deps = ["InteractiveUtils", "Logging", "Random", "Serialization"] -uuid = "8dfed614-e22c-5e08-85e1-65c5234f0b40" - -[[TimerOutputs]] -deps = ["ExprTools", "Printf"] -git-tree-sha1 = "d60b0c96a16aaa42138d5d38ad386df672cb8bd8" -uuid = "a759f4b9-e2f1-59dc-863e-4aeb61b1ea8f" -version = "0.5.16" - -[[TranscodingStreams]] -deps = ["Random", "Test"] -git-tree-sha1 = "216b95ea110b5972db65aa90f88d8d89dcb8851c" -uuid = "3bb67fe8-82b1-5028-8e26-92a6c54297fa" -version = "0.9.6" - -[[UUIDs]] -deps = ["Random", "SHA"] -uuid = "cf7118a7-6976-5b1a-9a39-7adc72f591a4" - -[[Unicode]] -uuid = "4ec0a83e-493e-50e2-b9ac-8f72acf5a8f5" - -[[UnicodePlots]] -deps = ["Contour", "Crayons", "Dates", "LinearAlgebra", "MarchingCubes", "NaNMath", "SparseArrays", "StaticArrays", "StatsBase", "Unitful"] -git-tree-sha1 = "1785494cb9484f9ab05bbc9d81a2d4de4341eb39" -uuid = "b8865327-cd53-5732-bb35-84acbb429228" -version = "2.9.0" - -[[Unitful]] -deps = ["ConstructionBase", "Dates", "LinearAlgebra", "Random"] -git-tree-sha1 = "b649200e887a487468b71821e2644382699f1b0f" -uuid = "1986cc42-f94f-5a68-af5c-568840ba703d" -version = "1.11.0" - -[[ZipFile]] -deps = ["Libdl", "Printf", "Zlib_jll"] -git-tree-sha1 = "3593e69e469d2111389a9bd06bac1f3d730ac6de" -uuid = "a5390f91-8eb1-5f08-bee0-b1d1ffed6cea" -version = "0.9.4" - -[[Zlib_jll]] -deps = ["Libdl"] -uuid = "83775a58-1f1d-513f-b197-d71354ab007a" - -[[Zygote]] -deps = ["AbstractFFTs", "ChainRules", "ChainRulesCore", "DiffRules", "Distributed", "FillArrays", "ForwardDiff", "IRTools", "InteractiveUtils", "LinearAlgebra", "MacroTools", "NaNMath", "Random", "Requires", "SparseArrays", "SpecialFunctions", "Statistics", "ZygoteRules"] -git-tree-sha1 = "bf526aa30677f1dde58febc67cb9021aab5eb396" -uuid = "e88e6eb3-aa80-5325-afca-941959d7151f" -version = "0.6.36" - -[[ZygoteRules]] -deps = ["MacroTools"] -git-tree-sha1 = "8c1a8e4dfacb1fd631745552c8db35d0deb09ea0" -uuid = "700de1a5-db45-46bc-99cf-38207098b444" -version = "0.2.2" - -[[libblastrampoline_jll]] -deps = ["Artifacts", "Libdl", "OpenBLAS_jll"] -uuid = "8e850b90-86db-534c-a0d3-1478176c7d93" - -[[nghttp2_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "8e850ede-7688-5339-a07c-302acd2aaf8d" - -[[p7zip_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "3f19e933-33d8-53b3-aaab-bd5110c3b7a0" diff --git a/src/ReinforcementLearningCore/Project.toml b/src/ReinforcementLearningCore/Project.toml index 8a9b7b158..b33b081ba 100644 --- a/src/ReinforcementLearningCore/Project.toml +++ b/src/ReinforcementLearningCore/Project.toml @@ -1,54 +1,38 @@ name = "ReinforcementLearningCore" uuid = "de1b191a-4ae0-4afa-a27b-92d07f46b2d6" authors = ["Jun Tian "] -version = "0.8.11" +version = "0.9.0-dev" [deps] -AbstractTrees = "1520ce14-60c1-5f80-bbc7-55ef81b5835c" Adapt = "79e6a3ab-5dfb-504d-930d-738a2a938a0e" -ArrayInterface = "4fba245c-0d91-5ea0-9b3e-6abc04ee57a9" CUDA = "052768ef-5323-5732-b1bb-66c8b64840ba" CircularArrayBuffers = "9de3a189-e0c0-4e15-ba3b-b14b9fb0aec1" -Compat = "34da2185-b29b-5c13-b0c7-acf172513d20" -Dates = "ade2ca70-3891-5945-98fb-dc099432e06a" Distributions = "31c24e10-a181-5473-b8eb-7969acd0382f" -ElasticArrays = "fdbdab4c-e67f-52f5-8c3f-e7b388dad3d4" FillArrays = "1a297f60-69ca-5386-bcde-b61e274b549b" Flux = "587475ba-b771-5e3f-ad9e-33799f191a9c" Functors = "d9f16b24-f501-4c13-a1f2-28368ffc5196" -GPUArrays = "0c68f7d7-f131-5f86-a1c3-88cf8149b2d7" -LinearAlgebra = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e" -MacroTools = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09" -Markdown = "d6f4376e-aef5-505a-96c1-9c027394607a" +Parsers = "69de0a69-1ddd-5017-9359-2bf0b02dc9f0" ProgressMeter = "92933f4c-e287-5a05-a399-4b506db050ca" Random = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c" +Reexport = "189a3867-3050-52da-a836-e630ba90ab69" ReinforcementLearningBase = "e575027e-6cd6-5018-9292-cdc6200d2b44" -Setfield = "efcf1570-3423-57d1-acb7-fd33fddbac46" +ReinforcementLearningEnvironments = "25e41dd2-4622-11e9-1641-f1adca772921" +ReinforcementLearningTrajectories = "6486599b-a3cd-4e92-a99a-2cea90cc8c3c" Statistics = "10745b16-79ce-11e8-11f9-7d13ad32a3b2" StatsBase = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91" UnicodePlots = "b8865327-cd53-5732-bb35-84acbb429228" -Zygote = "e88e6eb3-aa80-5325-afca-941959d7151f" [compat] -AbstractTrees = "0.3" -Adapt = "2, 3" -ArrayInterface = "3, 4, 5" CUDA = "3.5" CircularArrayBuffers = "0.1" -Compat = "3" Distributions = "0.24, 0.25" -ElasticArrays = "1.2" FillArrays = "0.8, 0.9, 0.10, 0.11, 0.12, 0.13" Flux = "0.12.9" Functors = "0.1, 0.2" -GPUArrays = "5, 6.0, 7, 8" -MacroTools = "0.5" ProgressMeter = "1.2" -ReinforcementLearningBase = "0.9" -Setfield = "0.6, 0.7, 0.8" +ReinforcementLearningBase = "0.10" StatsBase = "0.32, 0.33" UnicodePlots = "1.3, 2" -Zygote = "0.5, 0.6" julia = "1.6" [extras] diff --git a/src/ReinforcementLearningCore/src/ReinforcementLearningCore.jl b/src/ReinforcementLearningCore/src/ReinforcementLearningCore.jl index c598e0e2b..629b73654 100644 --- a/src/ReinforcementLearningCore/src/ReinforcementLearningCore.jl +++ b/src/ReinforcementLearningCore/src/ReinforcementLearningCore.jl @@ -1,19 +1,16 @@ module ReinforcementLearningCore using ReinforcementLearningBase +using Reexport const RLCore = ReinforcementLearningCore -@doc """ -[ReinforcementLearningCore.jl](https://juliareinforcementlearning.org/docs/rlcore/) (**RLCore**) -provides some standard and reusable components defined by [**RLBase**](https://juliareinforcementlearning.org/docs/rlbase/), hoping that they are useful for people to implement and experiment with different kinds of algorithms. -""" RLCore - export RLCore -include("utils/utils.jl") -include("extensions/extensions.jl") -include("policies/policies.jl") +@reexport using ReinforcementLearningTrajectories + include("core/core.jl") +include("policies/policies.jl") +include("utils/utils.jl") end # module diff --git a/src/ReinforcementLearningCore/src/core/core.jl b/src/ReinforcementLearningCore/src/core/core.jl index ebcf8d939..f6ea85064 100644 --- a/src/ReinforcementLearningCore/src/core/core.jl +++ b/src/ReinforcementLearningCore/src/core/core.jl @@ -1,4 +1,4 @@ -include("hooks.jl") +include("stages.jl") include("stop_conditions.jl") +include("hooks.jl") include("run.jl") -include("experiment.jl") diff --git a/src/ReinforcementLearningCore/src/core/experiment.jl b/src/ReinforcementLearningCore/src/core/experiment.jl deleted file mode 100644 index 8240f36e3..000000000 --- a/src/ReinforcementLearningCore/src/core/experiment.jl +++ /dev/null @@ -1,58 +0,0 @@ -export @experiment_cmd, @E_cmd, Experiment - -using Markdown -using Dates - -""" - Experiment(policy, env, stop_condition, hook, description) - -These are the four essential components in a typical reinforcement learning experiment: - -- `policy`, generates an action during the interaction with the `env`. It may update its strategy in the meanwhile. -- `env`, the environment we're going to experiment with. -- `stop_condition`, defines the when the experiment terminates. -- `hook`, collects some intermediate data during the experiment. -- `description`, displays some useful information for logging. -""" -Base.@kwdef mutable struct Experiment - policy::Any - env::Any - stop_condition::Any - hook::Any - description::String = "Experiment created at $(now())" -end - -function Base.show(io::IO, x::Experiment) - display(Markdown.parse(x.description)) - AbstractTrees.print_tree(io, StructTree(x), maxdepth=get(io, :max_depth, 10)) -end - -macro experiment_cmd(s) - Experiment(s) -end - -# alias for experiment_cmd -macro E_cmd(s) - Experiment(s) -end - -function Experiment(s::String) - m = match(r"(?\w+)_(?\w+)_(?\w+)(\((?\w*)\))?", s) - isnothing(m) && throw( - ArgumentError( - "invalid format, got $s, expected format is a local dir or a predefined experiment like dopamine_dqn_atari(pong)`", - ), - ) - Experiment( - Val(Symbol(m[:source])), - Val(Symbol(m[:method])), - Val(Symbol(m[:env])), - m[:game], - ) -end - -function Base.run(x::Experiment; describe::Bool=true) - describe && display(Markdown.parse(x.description)) - run(x.policy, x.env, x.stop_condition, x.hook) - x -end diff --git a/src/ReinforcementLearningCore/src/core/hooks.jl b/src/ReinforcementLearningCore/src/core/hooks.jl index 792e8c035..2434e696c 100644 --- a/src/ReinforcementLearningCore/src/core/hooks.jl +++ b/src/ReinforcementLearningCore/src/core/hooks.jl @@ -1,5 +1,4 @@ export AbstractHook, - ComposedHook, EmptyHook, StepsPerEpisode, RewardsPerEpisode, @@ -9,71 +8,51 @@ export AbstractHook, TimePerStep, DoEveryNEpisode, DoEveryNStep, - DoOnExit, - UploadTrajectoryEveryNStep, - MultiAgentHook, - period_rollout_hook, - RolloutHook + DoOnExit -using UnicodePlots:lineplot, lineplot! -using Statistics +using UnicodePlots: lineplot, lineplot! +using Statistics: mean, std +using CircularArrayBuffers: CircularArrayBuffer """ A hook is called at different stage duiring a [`run`](@ref) to allow users to inject customized runtime logic. -By default, a `AbstractHook` will do nothing. One can override the behavior by implementing the following methods: +By default, an `AbstractHook` will do nothing. One can customize the behavior by implementing the following methods: -- `(hook::YourHook)(::PreActStage, agent, env, action)`, note that there's an extra argument of `action`. +- `(hook::YourHook)(::PreActStage, agent, env)` - `(hook::YourHook)(::PostActStage, agent, env)` - `(hook::YourHook)(::PreEpisodeStage, agent, env)` - `(hook::YourHook)(::PostEpisodeStage, agent, env)` - `(hook::YourHook)(::PostExperimentStage, agent, env)` + +By convention, the `Base.getindex(h::YourHook)` is implemented to extract the metrics we are interested in. +Users can compose different `AbstractHook`s with `+`. """ abstract type AbstractHook end (hook::AbstractHook)(args...) = nothing -# https://github.com/JuliaLang/julia/issues/14919 -# function (f::Function)(stage::T, args...;kw...) where T<: AbstractStage end - -##### -# ComposedHook -##### - -""" - ComposedHook(hooks::AbstractHook...) - -Compose different hooks into a single hook. -""" -struct ComposedHook{T<:Tuple} <: AbstractHook - hooks::T - ComposedHook(hooks...) = new{typeof(hooks)}(hooks) +struct ComposedHook{H} <: AbstractHook + hooks::H end -function (hook::ComposedHook)(stage::AbstractStage, args...; kw...) - for h in hook.hooks - h(stage, args...; kw...) - end -end +Base.:(+)(h1::AbstractHook, h2::AbstractHook) = ComposedHook((h1, h2)) +Base.:(+)(h1::ComposedHook, h2::AbstractHook) = ComposedHook((h1.hooks..., h2)) +Base.:(+)(h1::AbstractHook, h2::ComposedHook) = ComposedHook((h1, h2.hooks...)) +Base.:(+)(h1::ComposedHook, h2::ComposedHook) = ComposedHook((h1.hooks..., h2.hooks...)) -Base.getindex(hook::ComposedHook, inds...) = getindex(hook.hooks, inds...) +(h::ComposedHook)(args...) = map(h -> h(args...), h.hooks) ##### # EmptyHook ##### """ -Do nothing +Nothing but a placeholder. """ struct EmptyHook <: AbstractHook end const EMPTY_HOOK = EmptyHook() -##### -# display -##### - -Base.display(::AbstractStage, agent, env, args...; kwargs...) = display(env) - ##### # StepsPerEpisode ##### @@ -112,17 +91,8 @@ end Base.getindex(h::RewardsPerEpisode) = h.rewards -function (hook::RewardsPerEpisode)(::PreEpisodeStage, agent, env) - push!(hook.rewards, []) -end - -function (hook::RewardsPerEpisode)(::PostActStage, agent, env) - push!(hook.rewards[end], reward(env)) -end - -function (hook::RewardsPerEpisode)(::PostActStage, agent::NamedPolicy, env) - push!(hook.rewards[end], reward(env, nameof(agent))) -end +(h::RewardsPerEpisode)(::PreEpisodeStage, agent, env) = push!(h.rewards, []) +(h::RewardsPerEpisode)(::PostActStage, agent, env) = push!(h.rewards[end], reward(env)) ##### # TotalRewardPerEpisode @@ -142,13 +112,7 @@ end Base.getindex(h::TotalRewardPerEpisode) = h.rewards -function (hook::TotalRewardPerEpisode)(::PostActStage, agent, env) - hook.reward += reward(env) -end - -function (hook::TotalRewardPerEpisode)(::PostActStage, agent::NamedPolicy, env) - hook.reward += reward(env, nameof(agent)) -end +(h::TotalRewardPerEpisode)(::PostActStage, agent, env) = h.reward += reward(env) function (hook::TotalRewardPerEpisode)(::PostEpisodeStage, agent, env) push!(hook.rewards, hook.reward) @@ -157,7 +121,14 @@ end function (hook::TotalRewardPerEpisode)(::PostExperimentStage, agent, env) if hook.is_display_on_exit - println(lineplot(hook.rewards, title="Total reward per episode", xlabel="Episode", ylabel="Score")) + println( + lineplot( + hook.rewards, + title="Total reward per episode", + xlabel="Episode", + ylabel="Score", + ), + ) end end @@ -181,11 +152,15 @@ If `is_display_on_exit` is set to `true`, a ribbon plot will be shown to reflect the mean and std of rewards. """ function TotalBatchRewardPerEpisode(batch_size::Int; is_display_on_exit=true) - TotalBatchRewardPerEpisode([Float64[] for _ in 1:batch_size], zeros(batch_size), is_display_on_exit) + TotalBatchRewardPerEpisode( + [Float64[] for _ in 1:batch_size], + zeros(batch_size), + is_display_on_exit, + ) end function (hook::TotalBatchRewardPerEpisode)(::PostActStage, agent, env) - R = agent isa NamedPolicy ? reward(env, nameof(agent)) : reward(env) + R = reward(env) for (i, (t, r)) in enumerate(zip(is_terminated(env), R)) hook.reward[i] += r if t @@ -200,7 +175,12 @@ function (hook::TotalBatchRewardPerEpisode)(::PostExperimentStage, agent, env) n = minimum(map(length, hook.rewards)) m = mean([@view(x[1:n]) for x in hook.rewards]) s = std([@view(x[1:n]) for x in hook.rewards]) - p = lineplot(m, title="Avg total reward per episode", xlabel="Episode", ylabel="Score") + p = lineplot( + m, + title="Avg total reward per episode", + xlabel="Episode", + ylabel="Score", + ) lineplot!(p, m .- s) lineplot!(p, m .+ s) println(p) @@ -255,7 +235,7 @@ end Base.getindex(h::TimePerStep) = h.times -TimePerStep(; max_steps = 100) = +TimePerStep(; max_steps=100) = TimePerStep(CircularArrayBuffer{Float64}(max_steps), time_ns()) function (hook::TimePerStep)(::PostActStage, agent, env) @@ -275,7 +255,7 @@ mutable struct DoEveryNStep{F} <: AbstractHook t::Int end -DoEveryNStep(f; n = 1, t = 0) = DoEveryNStep(f, n, t) +DoEveryNStep(f; n=1, t=0) = DoEveryNStep(f, n, t) function (hook::DoEveryNStep)(::PostActStage, agent, env) hook.t += 1 @@ -290,14 +270,13 @@ end Execute `f(t, agent, env)` every `n` episode. `t` is a counter of episodes. """ -mutable struct DoEveryNEpisode{S<:Union{PreEpisodeStage,PostEpisodeStage},F} <: - AbstractHook +mutable struct DoEveryNEpisode{S<:Union{PreEpisodeStage,PostEpisodeStage},F} <: AbstractHook f::F n::Int t::Int end -DoEveryNEpisode(f::F; n = 1, t = 0, stage::S = POST_EPISODE_STAGE) where {S,F} = +DoEveryNEpisode(f::F; n=1, t=0, stage::S=POST_EPISODE_STAGE) where {S,F} = DoEveryNEpisode{S,F}(f, n, t) function (hook::DoEveryNEpisode{S})(::S, agent, env) where {S} @@ -319,75 +298,3 @@ end function (h::DoOnExit)(::PostExperimentStage, agent, env) h.f(agent, env) end - -""" - UploadTrajectoryEveryNStep(;mailbox, n, sealer=deepcopy) -""" -Base.@kwdef mutable struct UploadTrajectoryEveryNStep{M,S} <: AbstractHook - mailbox::M - n::Int - t::Int = -1 - sealer::S = deepcopy -end - -function (hook::UploadTrajectoryEveryNStep)(::PostActStage, agent::Agent, env) - hook.t += 1 - if hook.t > 0 && hook.t % hook.n == 0 - put!(hook.mailbox, hook.sealer(agent.trajectory)) - end -end - -""" - MultiAgentHook(player=>hook...) -""" -struct MultiAgentHook <: AbstractHook - hooks::Dict{Any,Any} -end - -MultiAgentHook(player_hook_pair::Pair...) = MultiAgentHook(Dict(player_hook_pair...)) - -Base.getindex(h::MultiAgentHook, p) = getindex(h.hooks, p) - -function (hook::MultiAgentHook)( - s::AbstractStage, - m::MultiAgentManager, - env::AbstractEnv, - args..., -) - for (p, h) in zip(values(m.agents), values(hook.hooks)) - h(s, p, env, args...) - end -end - -""" - period_rollout_hook(env_fn, render, close; n = n) - -Run a rollout every `n` episodes. Each rollout is run with a `RolloutHook` -with parameters `render`, `close`. -""" - -function period_rollout_hook(env_fn, render, close; n = 100) - ComposedHook(DoEveryNEpisode(; n = n) do t, agent, env - run(agent, env_fn(), StopWhenDone(), RolloutHook(render, close)) - end, - DoOnExit() do agent, env - run(agent, env_fn(), StopWhenDone(), RolloutHook(render, close)) - end - ) -end - -""" - RolloutHook(render, close) - -Convenience hook for callbacks on every frame of an environment rollout. -The hook `RolloutHook(render, close)` will execute `render(env::AbstractEnv)` -after each action, and will execute `close()` after the episode. -""" - -struct RolloutHook{F, G} <: AbstractHook - render::F - close::G -end - -(h::RolloutHook)(::PostActStage, agent, env) = isnothing(h.render) ? nothing : h.render(env) -(h::RolloutHook)(::PostEpisodeStage, agent, env) = isnothing(h.close) ? nothing : h.close() diff --git a/src/ReinforcementLearningCore/src/core/run.jl b/src/ReinforcementLearningCore/src/core/run.jl index b78757d9d..6a65598ba 100644 --- a/src/ReinforcementLearningCore/src/core/run.jl +++ b/src/ReinforcementLearningCore/src/core/run.jl @@ -1,50 +1,110 @@ -import Base: run +export @E_cmd, Experiment -function run( + +import Parsers + +macro E_cmd(s) + Experiment(s) +end + +function try_parse(s, TS=(Bool, Int, Float32, Float64)) + if s == "nothing" + nothing + else + for T in TS + res = Parsers.tryparse(T, s) + if !isnothing(res) + return res + end + end + s + end +end + +function try_parse_kw(s) + kw = [] + # !!! obviously, it's not correct when a value is string and contains "," + for part in split(s, ",") + kv = split(part, "=") + @assert length(kv) == 2 + k, v = kv + push!(kw, Symbol(strip(k)) => try_parse(strip(v))) + end + NamedTuple(kw) +end + +struct Experiment + policy::Any + env::Any + stop_condition::Any + hook::Any +end + +function Experiment(s::String) + m = match(r"(?\w+)_(?\w+)_(?\w+)(\((?.*)\))?", s) + isnothing(m) && throw( + ArgumentError( + "invalid format, got $s, expected format is JuliaRL_DQN_Atari(game=\"pong\")`", + ), + ) + source = m[:source] + method = m[:method] + env = m[:env] + kw_args = isnothing(m[:game]) ? (;) : try_parse_kw(m[:game]) + Experiment(Val(Symbol(source)), Val(Symbol(method)), Val(Symbol(env)); kw_args...) +end + + +Base.run(ex::Experiment) = run(ex.policy, ex.env, ex.stop_condition, ex.hook) + +function Base.run( policy::AbstractPolicy, env::AbstractEnv, - stop_condition = StopAfterEpisode(1), - hook = EmptyHook(), + stop_condition=StopAfterEpisode(1), + hook=EmptyHook(), ) - check(policy, env) + policy, env = check(policy, env) _run(policy, env, stop_condition, hook) end "Inject some customized checkings here by overwriting this function" -function check(policy, env) end +check(policy, env) = policy, env -function _run(policy::AbstractPolicy, env::AbstractEnv, stop_condition, hook::AbstractHook) +function _run(policy::AbstractPolicy, env::AbstractEnv, stop_condition, hook) - hook(PRE_EXPERIMENT_STAGE, policy, env) - policy(PRE_EXPERIMENT_STAGE, env) + hook(PreExperimentStage(), policy, env) + policy(PreExperimentStage(), env) is_stop = false while !is_stop reset!(env) - policy(PRE_EPISODE_STAGE, env) - hook(PRE_EPISODE_STAGE, policy, env) + policy(PreEpisodeStage(), env) + hook(PreEpisodeStage(), policy, env) while !is_terminated(env) # one episode - action = policy(env) - - policy(PRE_ACT_STAGE, env, action) - hook(PRE_ACT_STAGE, policy, env, action) + policy(PreActStage(), env) + hook(PreActStage(), policy, env) - env(action) + env |> policy |> env + optimise!(policy) - policy(POST_ACT_STAGE, env) - hook(POST_ACT_STAGE, policy, env) + policy(PostActStage(), env) + hook(PostActStage(), policy, env) if stop_condition(policy, env) is_stop = true + policy(PreActStage(), env) + hook(PreActStage(), policy, env) + policy(env) # let the policy see the last observation break end end # end of an episode if is_terminated(env) - policy(POST_EPISODE_STAGE, env) # let the policy see the last observation - hook(POST_EPISODE_STAGE, policy, env) + policy(PostEpisodeStage(), env) # let the policy see the last observation + hook(PostEpisodeStage(), policy, env) end end - hook(POST_EXPERIMENT_STAGE, policy, env) + policy(PostExperimentStage(), env) + hook(PostExperimentStage(), policy, env) hook end diff --git a/src/ReinforcementLearningCore/src/core/stages.jl b/src/ReinforcementLearningCore/src/core/stages.jl new file mode 100644 index 000000000..002a5c9cc --- /dev/null +++ b/src/ReinforcementLearningCore/src/core/stages.jl @@ -0,0 +1,20 @@ +export AbstractStage, + PreExperimentStage, + PostExperimentStage, + PreEpisodeStage, + PostEpisodeStage, + PreActStage, + PostActStage + +abstract type AbstractStage end + +struct PreExperimentStage <: AbstractStage end +struct PostExperimentStage <: AbstractStage end +struct PreEpisodeStage <: AbstractStage end +struct PostEpisodeStage <: AbstractStage end +struct PreActStage <: AbstractStage end +struct PostActStage <: AbstractStage end + +(p::AbstractPolicy)(::AbstractStage, ::AbstractEnv) = nothing + +RLBase.optimise!(::AbstractPolicy) = nothing \ No newline at end of file diff --git a/src/ReinforcementLearningCore/src/core/stop_conditions.jl b/src/ReinforcementLearningCore/src/core/stop_conditions.jl index 3aefb15a6..f85039821 100644 --- a/src/ReinforcementLearningCore/src/core/stop_conditions.jl +++ b/src/ReinforcementLearningCore/src/core/stop_conditions.jl @@ -1,36 +1,7 @@ export StopAfterStep, - StopAfterEpisode, - StopWhenDone, - ComposedStopCondition, - StopSignal, - StopAfterNoImprovement, - StopAfterNSeconds + StopAfterEpisode, StopWhenDone, StopSignal, StopAfterNoImprovement, StopAfterNSeconds -using ProgressMeter -using CircularArrayBuffers: CircularArrayBuffer, isfull - -const update! = ReinforcementLearningBase.update! - -##### -# ComposedStopCondition -##### - -""" - ComposedStopCondition(stop_conditions...; reducer = any) - -The result of `stop_conditions` is reduced by `reducer`. -""" -struct ComposedStopCondition{S,T} - stop_conditions::S - reducer::T - function ComposedStopCondition(stop_conditions...; reducer = any) - new{typeof(stop_conditions),typeof(reducer)}(stop_conditions, reducer) - end -end - -function (s::ComposedStopCondition)(args...) - s.reducer(sc(args...) for sc in s.stop_conditions) -end +import ProgressMeter ##### # StopAfterStep @@ -48,7 +19,7 @@ end function StopAfterStep(step; cur = 1, is_show_progress = true) if is_show_progress - progress = Progress(step, 1) + progress = ProgressMeter.Progress(step, 1) ProgressMeter.update!(progress, cur) else progress = nothing @@ -60,7 +31,7 @@ function (s::StopAfterStep)(args...) if !isnothing(s.progress) # https://github.com/timholy/ProgressMeter.jl/pull/131 # next!(s.progress; showvalues = [(Symbol(s.tag, "/", :STEP), s.cur)]) - next!(s.progress) + ProgressMeter.next!(s.progress) end @debug s.tag STEP = s.cur @@ -87,7 +58,7 @@ end function StopAfterEpisode(episode; cur = 0, is_show_progress = true) if is_show_progress - progress = Progress(episode, 1) + progress = ProgressMeter.Progress(episode, 1) ProgressMeter.update!(progress, cur) else progress = nothing @@ -99,7 +70,7 @@ function (s::StopAfterEpisode)(agent, env) if is_terminated(env) s.cur += 1 if !isnothing(s.progress) - next!(s.progress;) + ProgressMeter.next!(s.progress;) end end diff --git a/src/ReinforcementLearningCore/src/extensions/ArrayInterface.jl b/src/ReinforcementLearningCore/src/extensions/ArrayInterface.jl deleted file mode 100644 index d641c615b..000000000 --- a/src/ReinforcementLearningCore/src/extensions/ArrayInterface.jl +++ /dev/null @@ -1,7 +0,0 @@ -using ArrayInterface - -function ArrayInterface.restructure(x::AbstractArray{T1, 0}, y::AbstractArray{T2, 0}) where {T1, T2} - out = similar(x, eltype(y)) - out .= y - out -end \ No newline at end of file diff --git a/src/ReinforcementLearningCore/src/extensions/CUDA.jl b/src/ReinforcementLearningCore/src/extensions/CUDA.jl deleted file mode 100644 index 26adbe9de..000000000 --- a/src/ReinforcementLearningCore/src/extensions/CUDA.jl +++ /dev/null @@ -1,108 +0,0 @@ -using CUDA, FillArrays -using CUDA: threadIdx, blockIdx, blockDim - -##### -# Cartesian indexing of CuArray -##### - -Base.checkindex(::Type{Bool}, inds::Tuple, I::CuArray{<:CartesianIndex}) = true - -function Base.getindex(xs::CuArray{T,N}, indices::CuArray{CartesianIndex{N}}) where {T,N} - n = length(indices) - ys = CuArray{T}(undef, n) - - if n > 0 - num_threads = min(n, 256) - num_blocks = ceil(Int, n / num_threads) - - function kernel(ys::CUDA.CuDeviceArray{T}, xs::CUDA.CuDeviceArray{T}, indices) - i = threadIdx().x + (blockIdx().x - 1) * blockDim().x - - if i <= length(ys) - ind = indices[i] - ys[i] = xs[ind] - end - - return - end - - CUDA.@cuda blocks = num_blocks threads = num_threads kernel(ys, xs, indices) - end - - return ys -end - -function Base.setindex!( - xs::CuArray{T,N}, - v::CuArray{T}, - indices::CuArray{CartesianIndex{N}}, -) where {T,N} - @assert length(indices) == length(v) "$xs, $(size(xs)), $v, $(size(v)), $indices, $(size(indices))" - n = length(indices) - - if n > 0 - num_threads = min(n, 256) - num_blocks = ceil(Int, n / num_threads) - - function kernel(xs::CUDA.CuDeviceArray{T}, indices, v) - i = threadIdx().x + (blockIdx().x - 1) * blockDim().x - - if i <= length(indices) - ind = indices[i] - xs[ind] = v[i] - end - - return - end - - CUDA.@cuda blocks = num_blocks threads = num_threads kernel(xs, indices, v) - end - return v -end - -function Base.setindex!( - xs::CuArray{T,N}, - v::T, - indices::CuArray{CartesianIndex{N}}, -) where {T,N} - n = length(indices) - - if n > 0 - num_threads = min(n, 256) - num_blocks = ceil(Int, n / num_threads) - - function kernel(xs::CUDA.CuDeviceArray{T}, indices, v) - i = threadIdx().x + (blockIdx().x - 1) * blockDim().x - - if i <= length(indices) - ind = indices[i] - xs[ind] = v - end - - return - end - - CUDA.@cuda blocks = num_blocks threads = num_threads kernel(xs, indices, v) - end - return v -end - -Base.setindex!( - xs::CuArray{T,N}, - v::Fill{T}, - indices::CuArray{CartesianIndex{N}}, -) where {T,N} = setindex!(xs, v.value, indices) - - -#Used for mvnormlogpdf in extensions/Distributions.jl -""" -`logdetLorU(LorU::AbstractMatrix)` -Log-determinant of the Positive-Semi-Definite matrix A = L*U (cholesky lower and upper triangulars), given L or U. -Has a sign uncertainty for non PSD matrices. -""" -function logdetLorU(LorU::CuArray) - return 2*sum(log.(diag(LorU))) -end - -#Cpu fallback -logdetLorU(LorU::AbstractMatrix) = logdet(LorU)*2 \ No newline at end of file diff --git a/src/ReinforcementLearningCore/src/extensions/Distributions.jl b/src/ReinforcementLearningCore/src/extensions/Distributions.jl deleted file mode 100644 index 60c334c74..000000000 --- a/src/ReinforcementLearningCore/src/extensions/Distributions.jl +++ /dev/null @@ -1,38 +0,0 @@ -export normlogpdf, mvnormlogpdf - -using Distributions: DiscreteNonParametric, support, probs -using Flux, LinearAlgebra -# watch https://github.com/JuliaStats/Distributions.jl/issues/1183 -const log2π = log(2f0π) -""" - normlogpdf(μ, σ, x; ϵ = 1.0f-8) -GPU automatic differentiable version for the logpdf function of normal distributions. -Adding an epsilon value to guarantee numeric stability if sigma is exactly zero -(e.g. if relu is used in output layer). -""" -function normlogpdf(μ, σ, x; ϵ = 1.0f-8) - z = (x .- μ) ./ (σ .+ ϵ) - -(z .^ 2 .+ log2π) / 2.0f0 .- log.(σ .+ ϵ) -end - -""" - mvnormlogpdf(μ::AbstractVecOrMat, L::AbstractMatrix, x::AbstractVecOrMat) -GPU automatic differentiable version for the logpdf function of multivariate normal distributions. -Takes as inputs `mu` the mean vector, `L` the lower triangular matrix of the cholesky decomposition of the covariance matrix, and `x` a matrix of samples where each column is a sample. -Return a Vector containing the logpdf of each column of x for the `MvNormal` parametrized by `μ` and `Σ = L*L'`. -""" -function mvnormlogpdf(μ::AbstractVecOrMat, L::AbstractMatrix, x::AbstractVecOrMat) - return -((size(x, 1) * log2π + logdetLorU(L)) .+ vec(sum(abs2.(L\(x .- μ)), dims=1))) ./ 2 -end - - -""" - mvnormlogpdf(μ::A, LorU::A, x::A; ϵ = 1f-8) where A <: AbstractArray -Batch version that takes 3D tensors as input where each slice along the 3rd dimension is a batch sample. -`μ` is a (action_size x 1 x batch_size) matrix, `L` is a (action_size x action_size x batch_size), x is a (action_size x action_samples x batch_size). -Return a 3D matrix of size (1 x action_samples x batch_size). -""" -function mvnormlogpdf(μ::A, LorU::A, x::A; ϵ = 1f-8) where A <: AbstractArray - logp = [mvnormlogpdf(μ[:,:,k], LorU[:,:,k], x[:,:,k]) for k in 1:size(x, 3)] - return Flux.unsqueeze(Flux.stack(logp, 2),1) #returns a 3D vector -end \ No newline at end of file diff --git a/src/ReinforcementLearningCore/src/extensions/ElasticArrays.jl b/src/ReinforcementLearningCore/src/extensions/ElasticArrays.jl deleted file mode 100644 index e6fd63a27..000000000 --- a/src/ReinforcementLearningCore/src/extensions/ElasticArrays.jl +++ /dev/null @@ -1,16 +0,0 @@ -using ElasticArrays - -Base.push!(a::ElasticArray, x) = append!(a, x) -Base.push!(a::ElasticArray{T,1}, x) where {T} = append!(a, [x]) -Base.empty!(a::ElasticArray) = ElasticArrays.resize_lastdim!(a, 0) - -function Base.pop!(a::ElasticArray) - if length(a) > 0 - last_frame_inds = length(a.data)-a.kernel_length.divisor+1:length(a.data) - d = reshape(view(a.data, last_frame_inds), a.kernel_size) - ElasticArrays.resize!(a.data, length(a.data) - a.kernel_length.divisor) - d - else - @error "can not pop! from an empty ElasticArray" - end -end diff --git a/src/ReinforcementLearningCore/src/extensions/Flux.jl b/src/ReinforcementLearningCore/src/extensions/Flux.jl deleted file mode 100644 index 51d7aa872..000000000 --- a/src/ReinforcementLearningCore/src/extensions/Flux.jl +++ /dev/null @@ -1,31 +0,0 @@ -export glorot_uniform, glorot_normal, orthogonal - -import Flux: glorot_uniform, glorot_normal - -using Random -using LinearAlgebra - -# https://github.com/FluxML/Flux.jl/pull/1171/ -# https://www.tensorflow.org/api_docs/python/tf/keras/initializers/Orthogonal -function orthogonal_matrix(rng::AbstractRNG, nrow, ncol) - shape = reverse(minmax(nrow, ncol)) - a = randn(rng, Float32, shape) - q, r = qr(a) - q = Matrix(q) * diagm(sign.(diag(r))) - nrow < ncol ? permutedims(q) : q -end - -function orthogonal(rng::AbstractRNG, d1, rest_dims...) - m = orthogonal_matrix(rng, d1, *(rest_dims...)) - reshape(m, d1, rest_dims...) -end - -orthogonal(dims...) = orthogonal(Random.GLOBAL_RNG, dims...) -orthogonal(rng::AbstractRNG) = (dims...) -> orthogonal(rng, dims...) - -function batch!(data, xs) - for (i, x) in enumerate(xs) - data[Flux.batchindex(data, i)...] = x - end - data -end diff --git a/src/ReinforcementLearningCore/src/extensions/ReinforcementLearningBase.jl b/src/ReinforcementLearningCore/src/extensions/ReinforcementLearningBase.jl deleted file mode 100644 index dd4445eb7..000000000 --- a/src/ReinforcementLearningCore/src/extensions/ReinforcementLearningBase.jl +++ /dev/null @@ -1,6 +0,0 @@ -using AbstractTrees - -Base.show(io::IO, p::AbstractPolicy) = - AbstractTrees.print_tree(io, StructTree(p), maxdepth=get(io, :max_depth, 10)) - -is_expand(::AbstractEnv) = false diff --git a/src/ReinforcementLearningCore/src/extensions/Zygote.jl b/src/ReinforcementLearningCore/src/extensions/Zygote.jl deleted file mode 100644 index 1ca387409..000000000 --- a/src/ReinforcementLearningCore/src/extensions/Zygote.jl +++ /dev/null @@ -1,18 +0,0 @@ -export clip_by_global_norm!, global_norm - -using Zygote - -Zygote.@adjoint argmax(xs; dims = :) = argmax(xs; dims = dims), _ -> nothing - -global_norm(gs::Zygote.Grads, ps::Zygote.Params) = - sqrt(sum(mapreduce(x -> x^2, +, gs[p]) for p in ps)) - -function clip_by_global_norm!(gs::Zygote.Grads, ps::Zygote.Params, clip_norm::Float32) - gn = global_norm(gs, ps) - if clip_norm <= gn - for p in ps - gs[p] .*= clip_norm / max(clip_norm, gn) - end - end - gn -end diff --git a/src/ReinforcementLearningCore/src/extensions/extensions.jl b/src/ReinforcementLearningCore/src/extensions/extensions.jl deleted file mode 100644 index 3bdb48a1f..000000000 --- a/src/ReinforcementLearningCore/src/extensions/extensions.jl +++ /dev/null @@ -1,7 +0,0 @@ -include("ArrayInterface.jl") -include("Flux.jl") -include("CUDA.jl") -include("Zygote.jl") -include("ReinforcementLearningBase.jl") -include("ElasticArrays.jl") -include("Distributions.jl") diff --git a/src/ReinforcementLearningCore/src/policies/agent.jl b/src/ReinforcementLearningCore/src/policies/agent.jl new file mode 100644 index 000000000..feeacbfef --- /dev/null +++ b/src/ReinforcementLearningCore/src/policies/agent.jl @@ -0,0 +1,64 @@ +export Agent + +using Base.Threads: @spawn + +import Functors + +""" + Agent(;policy, trajectory) + +A wrapper of an `AbstractPolicy`. Generally speaking, it does nothing but to +update the trajectory and policy appropriately in different stages. + +# Keywords & Fields + +- `policy`::[`AbstractPolicy`](@ref): the policy to use +- `trajectory`::[`Trajectory`](@ref): used to store intractions between an agent and an environment +""" +mutable struct Agent{P,T} <: AbstractPolicy + policy::P + trajectory::T + cache::NamedTuple # trajectory do not support partial inserting + + function Agent(policy::P, trajectory::T, cache = NamedTuple()) where {P,T} + agent = new{P,T}(policy, trajectory, cache) + if TrajectoryStyle(trajectory) === AsyncTrajectoryStyle() + bind(trajectory, @spawn(optimise!(p, t))) + end + agent + end +end + +Agent(; policy, trajectory, cache = NamedTuple()) = Agent(policy, trajectory, cache) + +RLBase.optimise!(agent::Agent) = optimise!(TrajectoryStyle(agent.trajectory), agent) +RLBase.optimise!(::SyncTrajectoryStyle, agent::Agent) = + optimise!(agent.policy, agent.trajectory) + +# already spawn a task to optimise inner policy when initializing the agent +RLBase.optimise!(::AsyncTrajectoryStyle, agent::Agent) = nothing + +function RLBase.optimise!(policy::AbstractPolicy, trajectory::Trajectory) + for batch in trajectory + optimise!(policy, batch) + end +end + +Functors.functor(x::Agent) = + (policy = x.policy,), y -> Agent(y.policy, x.trajectory, x.cache) + +# !!! TODO: In async scenarios, parameters of the policy may still be updating +# (partially), which will result to incorrect action. This should be addressed +# in Oolong.jl with a wrapper +function (agent::Agent)(env::AbstractEnv) + action = agent.policy(env) + push!(agent.trajectory, (agent.cache..., action = action)) + agent.cache = (;) + action +end + +(agent::Agent)(::PreActStage, env::AbstractEnv) = + agent.cache = (agent.cache..., state = state(env)) + +(agent::Agent)(::PostActStage, env::AbstractEnv) = + agent.cache = (agent.cache..., reward = reward(env), terminal = is_terminated(env)) diff --git a/src/ReinforcementLearningCore/src/policies/agents/agent.jl b/src/ReinforcementLearningCore/src/policies/agents/agent.jl deleted file mode 100644 index 1fc422089..000000000 --- a/src/ReinforcementLearningCore/src/policies/agents/agent.jl +++ /dev/null @@ -1,178 +0,0 @@ -export Agent - -import Functors: functor -using Setfield: @set - -""" - Agent(;kwargs...) - -A wrapper of an `AbstractPolicy`. Generally speaking, it does nothing but to -update the trajectory and policy appropriately in different stages. - -# Keywords & Fields - -- `policy`::[`AbstractPolicy`](@ref): the policy to use -- `trajectory`::[`AbstractTrajectory`](@ref): used to store transitions between an agent and an environment -""" -Base.@kwdef struct Agent{P<:AbstractPolicy,T<:AbstractTrajectory} <: AbstractPolicy - policy::P - trajectory::T -end - -functor(x::Agent) = (policy = x.policy,), y -> @set x.policy = y.policy - -(agent::Agent)(env) = agent.policy(env) - -function check(agent::Agent, env::AbstractEnv) - if ActionStyle(env) === FULL_ACTION_SET && - !haskey(agent.trajectory, :legal_actions_mask) - # @warn "The env[$(nameof(env))] is of FULL_ACTION_SET, but I can not find a trace named :legal_actions_mask in the trajectory" - end - check(agent.policy, env) -end - -Base.nameof(agent::Agent) = nameof(agent.policy) - -##### -# Default behaviors -##### - -""" -Here we extend the definition of `(p::AbstractPolicy)(::AbstractEnv)` in -`RLBase` to accept an `AbstractStage` as the first argument. Algorithm designers -may customize these behaviors respectively by implementing: - -- `(p::YourPolicy)(::AbstractStage, ::AbstractEnv)` -- `(p::YourPolicy)(::PreActStage, ::AbstractEnv, action)` - -The default behaviors for `Agent` are: - -1. Update the inner `trajectory` given the context of `policy`, `env`, and - `stage`. - 1. By default we do nothing. - 2. In `PreActStage`, we `push!` the current **state** and the **action** into - the `trajectory`. - 3. In `PostActStage`, we query the `reward` and `is_terminated` info from - `env` and push them into `trajectory`. - 4. In the `PosEpisodeStage`, we push the `state` at the end of an episode and - a dummy action into the `trajectory`. - 5. In the `PreEpisodeStage`, we pop out the latest `state` and `action` pair - (which are dummy ones) from `trajectory`. - -2. Update the inner `policy` given the context of `trajectory`, `env`, and - `stage`. - 1. By default, we only `update!` the `policy` in the `PreActStage`. And it's - dispatched to `update!(policy, trajectory, env, stage)`. -""" -function (agent::Agent)(stage::AbstractStage, env::AbstractEnv) - update!(agent.trajectory, agent.policy, env, stage) - update!(agent.policy, agent.trajectory, env, stage) -end - -function (agent::Agent)(stage::PreExperimentStage, env::AbstractEnv) - update!(agent.policy, agent.trajectory, env, stage) -end - -function (agent::Agent)(stage::PreActStage, env::AbstractEnv, action) - update!(agent.trajectory, agent.policy, env, stage, action) - update!(agent.policy, agent.trajectory, env, stage) -end - -function RLBase.update!( - ::AbstractPolicy, - ::AbstractTrajectory, - ::AbstractEnv, - ::AbstractStage, -) end - -##### -# Default behaviors for known trajectories -##### - -function RLBase.update!( - ::AbstractTrajectory, - ::AbstractPolicy, - ::AbstractEnv, - ::AbstractStage, -) end - -function RLBase.update!( - trajectory::AbstractTrajectory, - ::AbstractPolicy, - ::AbstractEnv, - ::PreEpisodeStage, -) - if length(trajectory) > 0 - pop!(trajectory[:state]) - pop!(trajectory[:action]) - if haskey(trajectory, :legal_actions_mask) - pop!(trajectory[:legal_actions_mask]) - end - end -end - -function RLBase.update!( - trajectory::AbstractTrajectory, - policy::AbstractPolicy, - env::AbstractEnv, - ::PreActStage, - action, -) - s = policy isa NamedPolicy ? state(env, nameof(policy)) : state(env) - push!(trajectory[:state], s) - push!(trajectory[:action], action) - if haskey(trajectory, :legal_actions_mask) - lasm = - policy isa NamedPolicy ? legal_action_space_mask(env, nameof(policy)) : - legal_action_space_mask(env) - push!(trajectory[:legal_actions_mask], lasm) - end -end - -function RLBase.update!( - trajectory::AbstractTrajectory, - policy::AbstractPolicy, - env::AbstractEnv, - ::PostActStage, -) - r = policy isa NamedPolicy ? reward(env, nameof(policy)) : reward(env) - push!(trajectory[:reward], r) - push!(trajectory[:terminal], is_terminated(env)) -end - -function get_dummy_action(action_space) - # For the general case, but especially for continuous action spaces, - # we select a random action. - # TODO: how to inject a local RNG here to avoid polluting the global RNG - return rand(action_space) -end - -function get_dummy_action(action_space::AbstractVector) - # For discrete action spaces, we select the first action as dummy action. - return action_space[1] -end - -function RLBase.update!( - trajectory::AbstractTrajectory, - policy::AbstractPolicy, - env::AbstractEnv, - ::PostEpisodeStage, -) - # Note that for trajectories like `CircularArraySARTTrajectory`, data are - # stored in a SARSA format, which means we still need to generate a dummy - # action at the end of an episode. - - s = policy isa NamedPolicy ? state(env, nameof(policy)) : state(env) - - A = policy isa NamedPolicy ? action_space(env, nameof(policy)) : action_space(env) - a = get_dummy_action(A) - - push!(trajectory[:state], s) - push!(trajectory[:action], a) - if haskey(trajectory, :legal_actions_mask) - lasm = - policy isa NamedPolicy ? legal_action_space_mask(env, nameof(policy)) : - legal_action_space_mask(env) - push!(trajectory[:legal_actions_mask], lasm) - end -end \ No newline at end of file diff --git a/src/ReinforcementLearningCore/src/policies/agents/agents.jl b/src/ReinforcementLearningCore/src/policies/agents/agents.jl deleted file mode 100644 index 6ca0cb7aa..000000000 --- a/src/ReinforcementLearningCore/src/policies/agents/agents.jl +++ /dev/null @@ -1,4 +0,0 @@ -include("trajectories/trajectories.jl") -include("named_policy.jl") -include("agent.jl") -include("multi_agent.jl") diff --git a/src/ReinforcementLearningCore/src/policies/agents/multi_agent.jl b/src/ReinforcementLearningCore/src/policies/agents/multi_agent.jl deleted file mode 100644 index 7bc0ab255..000000000 --- a/src/ReinforcementLearningCore/src/policies/agents/multi_agent.jl +++ /dev/null @@ -1,66 +0,0 @@ -export MultiAgentManager, NO_OP, NoOp - -"Represent no-operation if it's not the agent's turn." -struct NoOp end - -const NO_OP = NoOp() - -struct MultiAgentManager <: AbstractPolicy - agents::Dict{Any,Any} -end - -Base.getindex(A::MultiAgentManager, x) = getindex(A.agents, x) - -""" - MultiAgentManager(player => policy...) - -This is the simplest form of multiagent system. At each step they observe the -environment from their own perspective and get updated independently. For -environments of `SEQUENTIAL` style, agents which are not the current player will -observe a dummy action of [`NO_OP`](@ref) in the `PreActStage`. For environments -of `SIMULTANEOUS` style, please wrap it with [`SequentialEnv`](@ref) first. -""" -MultiAgentManager(policies...) = - MultiAgentManager(Dict{Any,Any}(nameof(p) => p for p in policies)) - -RLBase.prob(A::MultiAgentManager, env::AbstractEnv, args...) = prob(A[current_player(env)].policy, env, args...) - -(A::MultiAgentManager)(env::AbstractEnv) = A(env, DynamicStyle(env)) - -(A::MultiAgentManager)(env::AbstractEnv, ::Sequential) = A[current_player(env)](env) - -function (A::MultiAgentManager)(env::AbstractEnv, ::Simultaneous) - @error "MultiAgentManager doesn't support simultaneous environments. Please consider applying `SequentialEnv` wrapper to environment first." -end - -function (A::MultiAgentManager)(stage::AbstractStage, env::AbstractEnv) - for agent in values(A.agents) - agent(stage, env) - end -end - -function (A::MultiAgentManager)(stage::PreActStage, env::AbstractEnv, action) - A(stage, env, DynamicStyle(env), action) -end - -function (A::MultiAgentManager)(stage::PreActStage, env::AbstractEnv, ::Sequential, action) - p = current_player(env) - for (player, agent) in A.agents - if p == player - agent(stage, env, action) - else - agent(stage, env, NO_OP) - end - end -end - -function (A::MultiAgentManager)( - stage::PreActStage, - env::AbstractEnv, - ::Simultaneous, - actions, -) - for (agent, action) in zip(values(A.agents), actions) - agent(stage, env, action) - end -end diff --git a/src/ReinforcementLearningCore/src/policies/agents/named_policy.jl b/src/ReinforcementLearningCore/src/policies/agents/named_policy.jl deleted file mode 100644 index 215ba5639..000000000 --- a/src/ReinforcementLearningCore/src/policies/agents/named_policy.jl +++ /dev/null @@ -1,47 +0,0 @@ -export NamedPolicy - -import Functors: functor -using Setfield: @set - -""" - NamedPolicy(name=>policy) - -A policy wrapper to provide a name. Mostly used in multi-agent environments. -""" -Base.@kwdef struct NamedPolicy{P,N} <: AbstractPolicy - name::N - policy::P -end - -NamedPolicy((name, policy)) = NamedPolicy(name, policy) - -functor(x::NamedPolicy) = (policy = x.policy,), y -> @set x.policy = y.policy - -Base.nameof(agent::NamedPolicy) = agent.name - -function check(agent::NamedPolicy, env::AbstractEnv) - check(agent.policy, env) -end - -function RLBase.update!( - p::NamedPolicy, - t::AbstractTrajectory, - e::AbstractEnv, - s::AbstractStage, -) - update!(p.policy, t, e, s) -end - -function RLBase.update!( - p::NamedPolicy, - t::AbstractTrajectory, - e::AbstractEnv, - s::PreActStage, -) - update!(p.policy, t, e, s) -end - - -(p::NamedPolicy)(env::AbstractEnv) = DynamicStyle(env) == SEQUENTIAL ? p.policy(env) : p.policy(env, p.name) -(p::NamedPolicy)(s::AbstractStage, env::AbstractEnv) = p.policy(s, env) -(p::NamedPolicy)(s::PreActStage, env::AbstractEnv, action) = p.policy(s, env, action) diff --git a/src/ReinforcementLearningCore/src/policies/agents/trajectories/abstract_trajectory.jl b/src/ReinforcementLearningCore/src/policies/agents/trajectories/abstract_trajectory.jl deleted file mode 100644 index 4e9bc1eb5..000000000 --- a/src/ReinforcementLearningCore/src/policies/agents/trajectories/abstract_trajectory.jl +++ /dev/null @@ -1,82 +0,0 @@ -export AbstractTrajectory, SART, SARTS, SARTSA, SLART, SLARTSL, SLARTSLA - -""" - AbstractTrajectory - -A trajectory is used to record some useful information -during the interactions between agents and environments. -It behaves similar to a `NamedTuple` except that we extend it -with some optional methods. - -Required Methods: - -- `Base.getindex` -- `Base.keys` - -Optional Methods: - -- `Base.length` -- `Base.isempty` -- `Base.empty!` -- `Base.haskey` -- `Base.push!` -- `Base.pop!` -""" -abstract type AbstractTrajectory end - -Base.haskey(t::AbstractTrajectory, s::Symbol) = s in keys(t) -Base.isempty(t::AbstractTrajectory) = all(k -> isempty(t[k]), keys(t)) - -function Base.empty!(t::AbstractTrajectory) - for k in keys(t) - empty!(t[k]) - end -end - -function Base.push!(t::AbstractTrajectory; kwargs...) - for (k, v) in kwargs - push!(t[k], v) - end -end - -function Base.pop!(t::AbstractTrajectory) - for k in keys(t) - pop!(t[k]) - end -end - -function Base.show(io::IO, t::AbstractTrajectory) - println(io, "Trajectory of $(length(keys(t))) traces:") - for k in keys(t) - show(io, k) - println(io, " $(summary(t[k]))") - end -end - -##### -# Common Keys -##### - -const SART = (:state, :action, :reward, :terminal) -const SARTS = (:state, :action, :reward, :terminal, :next_state) -const SARTSA = (:state, :action, :reward, :terminal, :next_state, :next_action) -const SLART = (:state, :legal_actions_mask, :action, :reward, :terminal) -const SLARTSL = ( - :state, - :legal_actions_mask, - :action, - :reward, - :terminal, - :next_state, - :next_legal_actions_mask, -) -const SLARTSLA = ( - :state, - :legal_actions_mask, - :action, - :reward, - :terminal, - :next_state, - :next_legal_actions_mask, - :next_action, -) diff --git a/src/ReinforcementLearningCore/src/policies/agents/trajectories/reservoir_trajectory.jl b/src/ReinforcementLearningCore/src/policies/agents/trajectories/reservoir_trajectory.jl deleted file mode 100644 index c0a154679..000000000 --- a/src/ReinforcementLearningCore/src/policies/agents/trajectories/reservoir_trajectory.jl +++ /dev/null @@ -1,52 +0,0 @@ -export ReservoirTrajectory - -using MacroTools: @forward -using Random - -mutable struct ReservoirTrajectory{B,R<:AbstractRNG} <: AbstractTrajectory - buffer::B - n::Int - capacity::Int - rng::R -end - -@forward ReservoirTrajectory.buffer Base.keys, Base.haskey, Base.getindex - -Base.length(x::ReservoirTrajectory) = length(x.buffer[1]) - -function ReservoirTrajectory(capacity; n = 0, rng = Random.GLOBAL_RNG, kw...) - buffer = VectorTrajectory(; kw...) - ReservoirTrajectory(buffer, n, capacity, rng) -end - -function Base.push!(b::ReservoirTrajectory; kw...) - b.n += 1 - if b.n <= b.capacity - push!(b.buffer; kw...) - else - i = rand(b.rng, 1:b.n) - if i <= b.capacity - for (k, v) in kw - b.buffer[k][i] = v - end - end - end -end - -function RLBase.update!( - trajectory::ReservoirTrajectory, - policy::AbstractPolicy, - env::AbstractEnv, - ::PreActStage, - action, -) - s = policy isa NamedPolicy ? state(env, nameof(policy)) : state(env) - if haskey(trajectory.buffer, :legal_actions_mask) - lasm = - policy isa NamedPolicy ? legal_action_space_mask(env, nameof(policy)) : - legal_action_space_mask(env) - push!(trajectory; :state => s, :action => action, :legal_actions_mask => lasm) - else - push!(trajectory; :state => s, :action => action) - end -end diff --git a/src/ReinforcementLearningCore/src/policies/agents/trajectories/trajectories.jl b/src/ReinforcementLearningCore/src/policies/agents/trajectories/trajectories.jl deleted file mode 100644 index 80859af36..000000000 --- a/src/ReinforcementLearningCore/src/policies/agents/trajectories/trajectories.jl +++ /dev/null @@ -1,4 +0,0 @@ -include("abstract_trajectory.jl") -include("trajectory.jl") -include("trajectory_extension.jl") -include("reservoir_trajectory.jl") diff --git a/src/ReinforcementLearningCore/src/policies/agents/trajectories/trajectory.jl b/src/ReinforcementLearningCore/src/policies/agents/trajectories/trajectory.jl deleted file mode 100644 index 8df289e56..000000000 --- a/src/ReinforcementLearningCore/src/policies/agents/trajectories/trajectory.jl +++ /dev/null @@ -1,543 +0,0 @@ -export Trajectory, - PrioritizedTrajectory, - CircularArrayTrajectory, - CircularVectorTrajectory, - CircularArraySARTTrajectory, - CircularArraySLARTTrajectory, - CircularVectorSARTTrajectory, - CircularVectorSARTSATrajectory, - CircularArrayPSARTTrajectory, - ElasticArrayTrajectory, - ElasticSARTTrajectory, - VectorTrajectory, - VectorSATrajectory, - VectorSARTTrajectory - -using MacroTools: @forward -using ElasticArrays -using CircularArrayBuffers: CircularArrayBuffer, CircularVectorBuffer - -##### -# Trajectory -##### - -""" - Trajectory(;[trace_name=trace_container]...) - -A simple wrapper of `NamedTuple`. -Define our own type here to avoid type piracy with `NamedTuple` -""" -struct Trajectory{T} <: AbstractTrajectory - traces::T -end - -Trajectory(; kwargs...) = Trajectory(values(kwargs)) - -@forward Trajectory.traces Base.getindex, Base.keys - -Base.merge(a::Trajectory, b::Trajectory) = Trajectory(merge(a.traces, b.traces)) -Base.merge(a::Trajectory, b::NamedTuple) = Trajectory(merge(a.traces, b)) -Base.merge(a::NamedTuple, b::Trajectory) = Trajectory(merge(a, b.traces)) - -##### - -""" - CircularArrayTrajectory(; capacity::Int, kw::Pair{<:DataType, <:Tuple{Vararg{Int}}}...) - -A specialized [`Trajectory`](@ref) which uses -[`CircularArrayBuffer`](https://github.com/JuliaReinforcementLearning/CircularArrayBuffers.jl#usage) -as the underlying storage. `kw` specifies the name, the element type and the -size of each trace. `capacity` is used to define the maximum length of the -underlying buffer. - -See also [`CircularArraySARTTrajectory`](@ref), -[`CircularArraySLARTTrajectory`](@ref), [`CircularArrayPSARTTrajectory`](@ref). -""" -function CircularArrayTrajectory(; capacity, kwargs...) - Trajectory(map(values(kwargs)) do x - CircularArrayBuffer{eltype(first(x))}(last(x)..., capacity) - end) -end - -""" - CircularVectorTrajectory(;capacity, kw::DataType) - -Similar to [`CircularArrayTrajectory`](@ref), except that the underlying storage is -[`CircularVectorBuffer`](https://github.com/JuliaReinforcementLearning/CircularArrayBuffers.jl#usage). - -!!! note - Note the different type of the `kw` between `CircularVectorTrajectory` and `CircularArrayTrajectory`. With - [`CircularVectorBuffer`](https://github.com/JuliaReinforcementLearning/CircularArrayBuffers.jl#usage) - as the underlying storage, we don't need the size info. - -See also [`CircularVectorSARTTrajectory`](@ref), [`CircularVectorSARTSATrajectory`](@ref). -""" -function CircularVectorTrajectory(; capacity, kwargs...) - Trajectory(map(values(kwargs)) do x - CircularVectorBuffer{x}(capacity) - end) -end - -##### - -const CircularArraySARTTrajectory = Trajectory{ - <:NamedTuple{ - SART, - <:Tuple{ - <:CircularArrayBuffer, - <:CircularArrayBuffer, - <:CircularArrayBuffer, - <:CircularArrayBuffer, - }, - }, -} - -""" - CircularArraySARTTrajectory(;capacity::Int, kw...) - -A specialized [`CircularArrayTrajectory`](@ref) with traces of [`SART`](@ref). -Note that the capacity of the `:state` and `:action` trace is one step longer -than the capacity of the `:reward` and `:terminal` trace, so that we can reuse -the same trace to represent the next state and next action in a typical -transition in reinforcement learning. - -# Keyword arguments - -- `capacity::Int`, the maximum number of transitions. -- `state::Pair{<:DataType, <:Tuple{Vararg{Int}}}` = `Int => ()`, -- `action::Pair{<:DataType, <:Tuple{Vararg{Int}}}` = `Int => ()`, -- `reward::Pair{<:DataType, <:Tuple{Vararg{Int}}}` = `Float32 => ()`, -- `terminal::Pair{<:DataType, <:Tuple{Vararg{Int}}}` = `Bool => ()`, - -# Example - -```julia-repl -julia> t = CircularArraySARTTrajectory(; - capacity = 3, - state = Vector{Int} => (4,), - action = Int => (), - reward = Float32 => (), - terminal = Bool => (), - ) -Trajectory of 4 traces: -:state 4×0 CircularArrayBuffers.CircularArrayBuffer{Int64, 2} -:action 0-element CircularArrayBuffers.CircularVectorBuffer{Int64} -:reward 0-element CircularArrayBuffers.CircularVectorBuffer{Float32} -:terminal 0-element CircularArrayBuffers.CircularVectorBuffer{Bool} - - -julia> for i in 1:4 - push!(t;state=ones(Int, 4) .* i, action = i, reward=i/2, terminal=iseven(i)) - end - -julia> push!(t;state=ones(Int,4) .* 5, action = 5) - -julia> t[:state] -4×4 CircularArrayBuffers.CircularArrayBuffer{Int64, 2}: - 2 3 4 5 - 2 3 4 5 - 2 3 4 5 - 2 3 4 5 - -julia> t[:action] -4-element CircularArrayBuffers.CircularVectorBuffer{Int64}: - 2 - 3 - 4 - 5 - -julia> t[:reward] -3-element CircularArrayBuffers.CircularVectorBuffer{Float32}: - 1.0 - 1.5 - 2.0 - -julia> t[:terminal] -3-element CircularArrayBuffers.CircularVectorBuffer{Bool}: - 1 - 0 - 1 -``` -""" -CircularArraySARTTrajectory(; - capacity::Int, - state = Int => (), - action = Int => (), - reward = Float32 => (), - terminal = Bool => (), -) = merge( - CircularArrayTrajectory(; capacity = capacity + 1, state = state, action = action), - CircularArrayTrajectory(; capacity = capacity, reward = reward, terminal = terminal), -) - -const CircularArraySLARTTrajectory = Trajectory{ - <:NamedTuple{ - SLART, - <:Tuple{ - <:CircularArrayBuffer, - <:CircularArrayBuffer, - <:CircularArrayBuffer, - <:CircularArrayBuffer, - <:CircularArrayBuffer, - }, - }, -} - -"Similar to [`CircularArraySARTTrajectory`](@ref) with an extra `legal_actions_mask` trace." -CircularArraySLARTTrajectory(; - capacity::Int, - state = Int => (), - legal_actions_mask, - action = Int => (), - reward = Float32 => (), - terminal = Bool => (), -) = merge( - CircularArrayTrajectory(; - capacity = capacity + 1, - state = state, - legal_actions_mask = legal_actions_mask, - action = action, - ), - CircularArrayTrajectory(; capacity = capacity, reward = reward, terminal = terminal), -) - -##### - -const CircularVectorSARTTrajectory = Trajectory{ - <:NamedTuple{ - SART, - <:Tuple{ - <:CircularVectorBuffer, - <:CircularVectorBuffer, - <:CircularVectorBuffer, - <:CircularVectorBuffer, - }, - }, -} - -""" - CircularVectorSARTTrajectory(;capacity, kw::DataType...) - -A specialized [`CircularVectorTrajectory`](@ref) with traces of [`SART`](@ref). -Note that the capacity of traces `:state` and `:action` are one step longer than -the traces of `:reward` and `:terminal`, so that we can reuse the same -underlying storage to represent the next state and next action in a typical -transition in reinforcement learning. - -# Keyword arguments - -- `capacity::Int` -- `state` = `Int`, -- `action` = `Int`, -- `reward` = `Float32`, -- `terminal` = `Bool`, - -# Example - -```julia-repl -julia> t = CircularVectorSARTTrajectory(; - capacity = 3, - state = Vector{Int}, - action = Int, - reward = Float32, - terminal = Bool, - ) -Trajectory of 4 traces: -:state 0-element CircularArrayBuffers.CircularVectorBuffer{Vector{Int64}} -:action 0-element CircularArrayBuffers.CircularVectorBuffer{Int64} -:reward 0-element CircularArrayBuffers.CircularVectorBuffer{Float32} -:terminal 0-element CircularArrayBuffers.CircularVectorBuffer{Bool} - - -julia> for i in 1:4 - push!(t;state=ones(Int, 4) .* i, action = i, reward=i/2, terminal=iseven(i)) - end - -julia> push!(t;state=ones(Int,4) .* 5, action = 5) - -julia> t[:state] -4-element CircularArrayBuffers.CircularVectorBuffer{Vector{Int64}}: - [2, 2, 2, 2] - [3, 3, 3, 3] - [4, 4, 4, 4] - [5, 5, 5, 5] - -julia> t[:action] -4-element CircularArrayBuffers.CircularVectorBuffer{Int64}: - 2 - 3 - 4 - 5 - -julia> t[:reward] -3-element CircularArrayBuffers.CircularVectorBuffer{Float32}: - 1.0 - 1.5 - 2.0 - -julia> t[:terminal] -3-element CircularArrayBuffers.CircularVectorBuffer{Bool}: - 1 - 0 - 1 -``` -""" -CircularVectorSARTTrajectory(; - capacity::Int, - state = Int, - action = Int, - reward = Float32, - terminal = Bool, -) = merge( - CircularVectorTrajectory(; capacity = capacity + 1, state = state, action = action), - CircularVectorTrajectory(; capacity = capacity, reward = reward, terminal = terminal), -) - -##### - -const CircularVectorSARTSATrajectory = Trajectory{ - <:NamedTuple{ - SARTSA, - <:Tuple{ - <:CircularVectorBuffer, - <:CircularVectorBuffer, - <:CircularVectorBuffer, - <:CircularVectorBuffer, - <:CircularVectorBuffer, - <:CircularVectorBuffer, - }, - }, -} - -"Similar to [`CircularVectorSARTTrajectory`](@ref) with another two traces of `(:next_state, :next_action)`" -CircularVectorSARTSATrajectory(; - capacity::Int, - state = Int, - action = Int, - reward = Float32, - terminal = Bool, - next_state = state, - next_action = action, -) = CircularVectorTrajectory(; - capacity = capacity, - state = state, - action = action, - reward = reward, - terminal = terminal, - next_state = next_state, - next_action = next_action, -) - -##### - -""" - ElasticArrayTrajectory(;[trace_name::Pair{<:DataType, <:Tuple{Vararg{Int}}}]...) - -A specialized [`Trajectory`](@ref) which uses [`ElasticArray`](https://github.com/JuliaArrays/ElasticArrays.jl) as the underlying -storage. See also [`ElasticSARTTrajectory`](@ref). -""" -function ElasticArrayTrajectory(; kwargs...) - Trajectory(map(values(kwargs)) do x - ElasticArray{eltype(first(x))}(undef, last(x)..., 0) - end) -end - -const ElasticSARTTrajectory = Trajectory{ - <:NamedTuple{SART,<:Tuple{<:ElasticArray,<:ElasticArray,<:ElasticArray,<:ElasticArray}}, -} - -""" - ElasticSARTTrajectory(;kw...) - -A specialized [`ElasticArrayTrajectory`](@ref) with traces of [`SART`](@ref). - -# Keyword arguments - -- `state::Pair{<:DataType, <:Tuple{Vararg{Int}}}` = `Int => ()`, by default it - means the state is a scalar of `Int`. -- `action::Pair{<:DataType, <:Tuple{Vararg{Int}}}` = `Int => ()`, -- `reward::Pair{<:DataType, <:Tuple{Vararg{Int}}}` = `Float32 => ()`, -- `terminal::Pair{<:DataType, <:Tuple{Vararg{Int}}}` = `Bool => ()`, - -# Example - -```julia-repl -julia> t = ElasticSARTTrajectory(; - state = Vector{Int} => (4,), - action = Int => (), - reward = Float32 => (), - terminal = Bool => (), - ) -Trajectory of 4 traces: -:state 4×0 ElasticArrays.ElasticMatrix{Int64, Vector{Int64}} -:action 0-element ElasticArrays.ElasticVector{Int64, Vector{Int64}} -:reward 0-element ElasticArrays.ElasticVector{Float32, Vector{Float32}} -:terminal 0-element ElasticArrays.ElasticVector{Bool, Vector{Bool}} - - -julia> for i in 1:4 - push!(t;state=ones(Int, 4) .* i, action = i, reward=i/2, terminal=iseven(i)) - end - -julia> push!(t;state=ones(Int,4) .* 5, action = 5) - -julia> t -Trajectory of 4 traces: -:state 4×5 ElasticArrays.ElasticMatrix{Int64, Vector{Int64}} -:action 5-element ElasticArrays.ElasticVector{Int64, Vector{Int64}} -:reward 4-element ElasticArrays.ElasticVector{Float32, Vector{Float32}} -:terminal 4-element ElasticArrays.ElasticVector{Bool, Vector{Bool}} - -julia> t[:state] -4×5 ElasticArrays.ElasticMatrix{Int64, Vector{Int64}}: - 1 2 3 4 5 - 1 2 3 4 5 - 1 2 3 4 5 - 1 2 3 4 5 - -julia> t[:action] -5-element ElasticArrays.ElasticVector{Int64, Vector{Int64}}: - 1 - 2 - 3 - 4 - 5 - -julia> t[:reward] -4-element ElasticArrays.ElasticVector{Float32, Vector{Float32}}: - 0.5 - 1.0 - 1.5 - 2.0 - -julia> t[:terminal] -4-element ElasticArrays.ElasticVector{Bool, Vector{Bool}}: - 0 - 1 - 0 - 1 - -julia> empty!(t) - -julia> t -Trajectory of 4 traces: -:state 4×0 ElasticArrays.ElasticMatrix{Int64, Vector{Int64}} -:action 0-element ElasticArrays.ElasticVector{Int64, Vector{Int64}} -:reward 0-element ElasticArrays.ElasticVector{Float32, Vector{Float32}} -:terminal 0-element ElasticArrays.ElasticVector{Bool, Vector{Bool}} -``` - -""" -function ElasticSARTTrajectory(; - state = Int => (), - action = Int => (), - reward = Float32 => (), - terminal = Bool => (), -) - ElasticArrayTrajectory(; - state = state, - action = action, - reward = reward, - terminal = terminal, - ) -end - -##### -# VectorTrajectory -##### - -""" - VectorTrajectory(;[trace_name::DataType]...) - -A [`Trajectory`](@ref) with each trace using a `Vector` as the storage. -""" -function VectorTrajectory(; kwargs...) - Trajectory(map(values(kwargs)) do x - Vector{x}() - end) -end - -const VectorSARTTrajectory = - Trajectory{<:NamedTuple{SART,<:Tuple{<:Vector,<:Vector,<:Vector,<:Vector}}} - -""" - VectorSARTTrajectory(;kw...) - -A specialized [`VectorTrajectory`] with traces of [`SART`](@ref). - -# Keyword arguments - -- `state::DataType = Int` -- `action::DataType = Int` -- `reward::DataType = Float32` -- `terminal::DataType = Bool` -""" -function VectorSARTTrajectory(; - state = Int, - action = Int, - reward = Float32, - terminal = Bool, -) - VectorTrajectory(; state = state, action = action, reward = reward, terminal = terminal) -end - -const VectorSATrajectory = - Trajectory{<:NamedTuple{(:state, :action),<:Tuple{<:Vector,<:Vector}}} - -""" - VectorSATrajectory(;kw...) - -A specialized [`VectorTrajectory`] with traces of `(:state, :action)`. - -# Keyword arguments - -- `state::DataType = Int` -- `action::DataType = Int` -""" -function VectorSATrajectory(; state = Int, action = Int) - VectorTrajectory(; state = state, action = action) -end -##### - -Base.@kwdef struct PrioritizedTrajectory{T,P} <: AbstractTrajectory - traj::T - priority::P -end - -Base.keys(t::PrioritizedTrajectory) = (:priority, keys(t.traj)...) - -Base.length(t::PrioritizedTrajectory) = length(t.priority) - -Base.getindex(t::PrioritizedTrajectory, s::Symbol) = - if s == :priority - t.priority - else - getindex(t.traj, s) - end - -const CircularArrayPSARTTrajectory = - PrioritizedTrajectory{<:SumTree,<:CircularArraySARTTrajectory} - -CircularArrayPSARTTrajectory(; capacity, kwargs...) = PrioritizedTrajectory( - CircularArraySARTTrajectory(; capacity = capacity, kwargs...), - SumTree(capacity), -) - -##### -# Common -##### - -function Base.length( - t::Union{ - CircularArraySARTTrajectory, - CircularArraySLARTTrajectory, - CircularVectorSARTSATrajectory, - ElasticSARTTrajectory, - }, -) - x = t[:terminal] - size(x, ndims(x)) -end - -Base.length(t::VectorSARTTrajectory) = length(t[:terminal]) -Base.length(t::VectorSATrajectory) = length(t[:action]) diff --git a/src/ReinforcementLearningCore/src/policies/agents/trajectories/trajectory_extension.jl b/src/ReinforcementLearningCore/src/policies/agents/trajectories/trajectory_extension.jl deleted file mode 100644 index 7818e24ce..000000000 --- a/src/ReinforcementLearningCore/src/policies/agents/trajectories/trajectory_extension.jl +++ /dev/null @@ -1,201 +0,0 @@ -export NStepInserter, BatchSampler, NStepBatchSampler - -using Random - -##### -# Inserters -##### - -abstract type AbstractInserter end - -Base.@kwdef struct NStepInserter <: AbstractInserter - n::Int = 1 -end - -function Base.push!( - t::CircularVectorSARTSATrajectory, - 𝕥::CircularArraySARTTrajectory, - inserter::NStepInserter, -) - N = length(𝕥) - n = inserter.n - for i in 1:(N-n+1) - for k in SART - push!(t[k], select_last_dim(𝕥[k], i)) - end - push!(t[:next_state], select_last_dim(𝕥[:state], i + n)) - push!(t[:next_action], select_last_dim(𝕥[:action], i + n)) - end -end - -##### -# Samplers -##### - -abstract type AbstractSampler{traces} end - -# TODO: deprecate this method with `(s::AbstractSampler)(traj)` instead - -""" - sample([rng=Random.GLOBAL_RNG], trajectory, sampler, [traces=Val(keys(trajectory))]) - -!!! note - Here we return a copy instead of a view: - 1. Each sample is independent of the original `trajectory` so that `trajectory` can be updated async. - 2. [Copy is not always so bad](https://docs.julialang.org/en/v1/manual/performance-tips/#Copying-data-is-not-always-bad). -""" -function StatsBase.sample(t::AbstractTrajectory, sampler::AbstractSampler) - sample(Random.GLOBAL_RNG, t, sampler) -end - -# TODO: add an async batch sampler to pre-fetch next batch - -##### -## BatchSampler -##### - -mutable struct BatchSampler{traces} <: AbstractSampler{traces} - batch_size::Int - cache::Any - rng::Any -end - -BatchSampler(batch_size::Int; cache = nothing, rng = Random.GLOBAL_RNG) = - BatchSampler{SARTSA}(batch_size, cache, rng) -BatchSampler{T}(batch_size::Int; cache = nothing, rng = Random.GLOBAL_RNG) where {T} = - BatchSampler{T}(batch_size, cache, rng) - -(s::BatchSampler)(t::AbstractTrajectory) = sample(s.rng, t, s) - -# TODO: deprecate -function StatsBase.sample(rng::AbstractRNG, t::AbstractTrajectory, s::BatchSampler) - inds = rand(rng, 1:length(t), s.batch_size) - fetch!(s, t, inds) - inds, s.cache -end - -function fetch!(s::BatchSampler, t::AbstractTrajectory, inds::Vector{Int}) - batch = NamedTuple{keys(t)}(view(t[x], inds) for x in keys(t)) - if isnothing(s.cache) - s.cache = map(Flux.batch, batch) - else - map(s.cache, batch) do dest, src - batch!(dest, src) - end - end -end - -function fetch!(s::BatchSampler{traces}, t::Union{CircularArraySARTTrajectory, CircularArraySLARTTrajectory}, inds::Vector{Int}) where {traces} - if traces == SARTS - batch = NamedTuple{SARTS}(( - (consecutive_view(t[x], inds) for x in SART)..., - consecutive_view(t[:state], inds .+ 1), - )) - elseif traces == SLARTSL - batch = NamedTuple{SLARTSL}(( - (consecutive_view(t[x], inds) for x in SLART)..., - consecutive_view(t[:state], inds .+ 1), - consecutive_view(t[:legal_actions_mask], inds .+ 1), - )) - else - @error "unsupported traces $traces" - end - - if isnothing(s.cache) - s.cache = map(batch) do x - convert(Array, x) - end - else - map(s.cache, batch) do dest, src - copyto!(dest, src) - end - end -end - -##### -## NStepBatchSampler -##### - -Base.@kwdef mutable struct NStepBatchSampler{traces} <: AbstractSampler{traces} - γ::Float32 - n::Int = 1 - batch_size::Int = 32 - stack_size::Union{Nothing,Int} = nothing - rng::Any = Random.GLOBAL_RNG - cache::Any = nothing -end - -# TODO:deprecate -function StatsBase.sample(rng::AbstractRNG, t::AbstractTrajectory, s::NStepBatchSampler) - valid_range = - isnothing(s.stack_size) ? (1:(length(t)-s.n+1)) : (s.stack_size:(length(t)-s.n+1)) - inds = rand(rng, valid_range, s.batch_size) - inds, fetch!(s, t, inds) -end - -function StatsBase.sample(rng::AbstractRNG, t::PrioritizedTrajectory, s::NStepBatchSampler) - bz, sz = s.batch_size, s.stack_size - inds = Vector{Int}(undef, bz) - priorities = Vector{Float32}(undef, bz) - valid_ind_range = isnothing(sz) ? (1:(length(t)-s.n+1)) : (sz:(length(t)-s.n+1)) - for i in 1:bz - ind, p = sample(rng, t.priority) - while ind ∉ valid_ind_range - ind, p = sample(rng, t.priority) - end - inds[i] = ind - priorities[i] = p - end - inds, (priority = priorities, fetch!(s, t.traj, inds)...) -end - -function fetch!( - sampler::NStepBatchSampler{traces}, - traj::Union{CircularArraySARTTrajectory, CircularArraySLARTTrajectory}, - inds::Vector{Int}, -) where {traces} - γ, n, bz, sz = sampler.γ, sampler.n, sampler.batch_size, sampler.stack_size - cache = sampler.cache - next_inds = inds .+ n - - s = consecutive_view(traj[:state], inds; n_stack = sz) - a = consecutive_view(traj[:action], inds) - s′ = consecutive_view(traj[:state], next_inds; n_stack = sz) - - consecutive_rewards = consecutive_view(traj[:reward], inds; n_horizon = n) - consecutive_terminals = consecutive_view(traj[:terminal], inds; n_horizon = n) - r = isnothing(cache) ? zeros(Float32, bz) : cache.reward - t = isnothing(cache) ? fill(false, bz) : cache.terminal - - # make sure that we only consider experiences in current episode - for i in 1:bz - m = findfirst(view(consecutive_terminals, :, i)) - if isnothing(m) - t[i] = false - r[i] = discount_rewards_reduced(view(consecutive_rewards, :, i), γ) - else - t[i] = true - r[i] = discount_rewards_reduced(view(consecutive_rewards, 1:m, i), γ) - end - end - - if traces == SARTS - batch = NamedTuple{SARTS}((s, a, r, t, s′)) - elseif traces == SLARTSL - l = consecutive_view(traj[:legal_actions_mask], inds) - l′ = consecutive_view(traj[:legal_actions_mask], next_inds) - batch = NamedTuple{SLARTSL}((s, l, a, r, t, s′, l′)) - else - @error "unsupported traces $traces" - end - - if isnothing(sampler.cache) - sampler.cache = map(batch) do x - convert(Array, x) - end - else - map(sampler.cache, batch) do dest, src - copyto!(dest, src) - end - end -end diff --git a/src/ReinforcementLearningCore/src/policies/base.jl b/src/ReinforcementLearningCore/src/policies/base.jl deleted file mode 100644 index 618e66c6e..000000000 --- a/src/ReinforcementLearningCore/src/policies/base.jl +++ /dev/null @@ -1,40 +0,0 @@ -export AbstractStage, - PreExperimentStage, - PostExperimentStage, - PreEpisodeStage, - PostEpisodeStage, - PreActStage, - PostActStage, - PRE_EXPERIMENT_STAGE, - POST_EXPERIMENT_STAGE, - PRE_EPISODE_STAGE, - POST_EPISODE_STAGE, - PRE_ACT_STAGE, - POST_ACT_STAGE - -##### -# Stage -##### - -abstract type AbstractStage end - -struct PreExperimentStage <: AbstractStage end -const PRE_EXPERIMENT_STAGE = PreExperimentStage() - -struct PostExperimentStage <: AbstractStage end -const POST_EXPERIMENT_STAGE = PostExperimentStage() - -struct PreEpisodeStage <: AbstractStage end -const PRE_EPISODE_STAGE = PreEpisodeStage() - -struct PostEpisodeStage <: AbstractStage end -const POST_EPISODE_STAGE = PostEpisodeStage() - -struct PreActStage <: AbstractStage end -const PRE_ACT_STAGE = PreActStage() - -struct PostActStage <: AbstractStage end -const POST_ACT_STAGE = PostActStage() - -(p::AbstractPolicy)(::AbstractStage, ::AbstractEnv) = nothing -(p::AbstractPolicy)(::AbstractStage, ::AbstractEnv, action) = nothing diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/UCB_explorer.jl b/src/ReinforcementLearningCore/src/policies/explorers/UCB_explorer.jl similarity index 67% rename from src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/UCB_explorer.jl rename to src/ReinforcementLearningCore/src/policies/explorers/UCB_explorer.jl index 149f316dc..458622881 100644 --- a/src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/UCB_explorer.jl +++ b/src/ReinforcementLearningCore/src/policies/explorers/UCB_explorer.jl @@ -1,14 +1,12 @@ export UCBExplorer using Random -using Flux Base.@kwdef mutable struct UCBExplorer{R<:AbstractRNG} <: AbstractExplorer c::Float64 actioncounts::Vector{Float64} step::Int rng::R - is_training::Bool = true end """ @@ -19,17 +17,14 @@ end - `t` is used to store current time step. - `c` is used to control the degree of exploration. - `seed`, set the seed of inner RNG. -- `is_training=true`, in training mode, time step and counter will not be updated. """ -UCBExplorer(na; c = 2.0, ϵ = 1e-10, step = 1, rng = Random.GLOBAL_RNG, is_training = true) = - UCBExplorer(c, fill(ϵ, na), 1, rng, is_training) +UCBExplorer(na; c = 2.0, ϵ = 1e-10, step = 1, rng = Random.GLOBAL_RNG) = + UCBExplorer(c, fill(ϵ, na), 1, rng) function (p::UCBExplorer)(values::AbstractArray) v, inds = find_all_max(@. values + p.c * sqrt(log(p.step + 1) / p.actioncounts)) - action = sample(p.rng, inds) - if p.is_training - p.actioncounts[action] += 1 - p.step += 1 - end + action = rand(p.rng, inds) + p.actioncounts[action] += 1 + p.step += 1 action end diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/abstract_explorer.jl b/src/ReinforcementLearningCore/src/policies/explorers/abstract_explorer.jl similarity index 82% rename from src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/abstract_explorer.jl rename to src/ReinforcementLearningCore/src/policies/explorers/abstract_explorer.jl index 5b3491d07..20221b9dd 100644 --- a/src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/abstract_explorer.jl +++ b/src/ReinforcementLearningCore/src/policies/explorers/abstract_explorer.jl @@ -1,6 +1,6 @@ export AbstractExplorer -using Flux +using FillArrays: Trues """ (p::AbstractExplorer)(x) @@ -13,6 +13,8 @@ abstract type AbstractExplorer end function (p::AbstractExplorer)(x) end function (p::AbstractExplorer)(x, mask) end +(p::AbstractExplorer)(x, mask::Trues) = p(x) + """ prob(p::AbstractExplorer, x) -> AbstractDistribution @@ -26,3 +28,5 @@ function RLBase.prob(p::AbstractExplorer, x) end Similar to `prob(p::AbstractExplorer, x)`, but here only the `mask`ed elements are considered. """ function RLBase.prob(p::AbstractExplorer, x, mask) end + +RLBase.prob(p::AbstractExplorer, x, mask::Trues) = prob(p, x) diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/batch_explorer.jl b/src/ReinforcementLearningCore/src/policies/explorers/batch_explorer.jl similarity index 98% rename from src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/batch_explorer.jl rename to src/ReinforcementLearningCore/src/policies/explorers/batch_explorer.jl index 13e0cb152..088d283fd 100644 --- a/src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/batch_explorer.jl +++ b/src/ReinforcementLearningCore/src/policies/explorers/batch_explorer.jl @@ -1,7 +1,5 @@ export BatchExplorer -using Flux - """ BatchExplorer(explorer::AbstractExplorer) """ diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/epsilon_greedy_explorer.jl b/src/ReinforcementLearningCore/src/policies/explorers/epsilon_greedy_explorer.jl similarity index 84% rename from src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/epsilon_greedy_explorer.jl rename to src/ReinforcementLearningCore/src/policies/explorers/epsilon_greedy_explorer.jl index 10170fc9b..5fe2dbc7b 100644 --- a/src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/epsilon_greedy_explorer.jl +++ b/src/ReinforcementLearningCore/src/policies/explorers/epsilon_greedy_explorer.jl @@ -2,7 +2,7 @@ export EpsilonGreedyExplorer, GreedyExplorer using Random using Distributions: Categorical -using Flux +using Flux: onehot """ EpsilonGreedyExplorer{T}(;kwargs...) @@ -24,7 +24,6 @@ Two kinds of epsilon-decreasing strategy are implemented here (`linear` and `exp - `ϵ_stable::Float64`: the epsilon after `warmup_steps + decay_steps`. - `is_break_tie=false`: randomly select an action of the same maximum values if set to `true`. - `rng=Random.GLOBAL_RNG`: set the internal RNG. -- `is_training=true`: when not in training mode, `step` will not be updated. And the `ϵ` will be set to 0. # Example @@ -43,19 +42,17 @@ mutable struct EpsilonGreedyExplorer{Kind,IsBreakTie,R} <: AbstractExplorer decay_steps::Int step::Int rng::R - is_training::Bool end function EpsilonGreedyExplorer(; ϵ_stable, - kind = :linear, - ϵ_init = 1.0, - warmup_steps = 0, - decay_steps = 0, - step = 1, - is_break_tie = false, - is_training = true, - rng = Random.GLOBAL_RNG, + kind=:linear, + ϵ_init=1.0, + warmup_steps=0, + decay_steps=0, + step=1, + is_break_tie=false, + rng=Random.GLOBAL_RNG ) EpsilonGreedyExplorer{kind,is_break_tie,typeof(rng)}( ϵ_stable, @@ -64,11 +61,10 @@ function EpsilonGreedyExplorer(; decay_steps, step, rng, - is_training, ) end -EpsilonGreedyExplorer(ϵ; kwargs...) = EpsilonGreedyExplorer(; ϵ_stable = ϵ, kwargs...) +EpsilonGreedyExplorer(ϵ; kwargs...) = EpsilonGreedyExplorer(; ϵ_stable=ϵ, kwargs...) function get_ϵ(s::EpsilonGreedyExplorer{:linear}, step) if step <= s.warmup_steps @@ -91,44 +87,48 @@ function get_ϵ(s::EpsilonGreedyExplorer{:exp}, step) end end -get_ϵ(s::EpsilonGreedyExplorer) = s.is_training ? get_ϵ(s, s.step) : 0.0 +get_ϵ(s::EpsilonGreedyExplorer) = get_ϵ(s, s.step) """ (s::EpsilonGreedyExplorer)(values; step) where T !!! note If multiple values with the same maximum value are found. - Then a random one will be returned! + Then a random one will be returned when `is_break_tie==true`. `NaN` will be filtered unless all the values are `NaN`. In that case, a random one will be returned. """ function (s::EpsilonGreedyExplorer{<:Any,true})(values) ϵ = get_ϵ(s) - s.is_training && (s.step += 1) + s.step += 1 rand(s.rng) >= ϵ ? rand(s.rng, find_all_max(values)[2]) : rand(s.rng, 1:length(values)) end function (s::EpsilonGreedyExplorer{<:Any,false})(values) ϵ = get_ϵ(s) - s.is_training && (s.step += 1) + s.step += 1 rand(s.rng) >= ϵ ? findmax(values)[2] : rand(s.rng, 1:length(values)) end +##### + +(s::EpsilonGreedyExplorer{<:Any,true})(x, mask::Trues) = s(x) function (s::EpsilonGreedyExplorer{<:Any,true})(values, mask) ϵ = get_ϵ(s) - s.is_training && (s.step += 1) + s.step += 1 rand(s.rng) >= ϵ ? rand(s.rng, find_all_max(values, mask)[2]) : rand(s.rng, findall(mask)) end +(s::EpsilonGreedyExplorer{<:Any,false})(x, mask::Trues) = s(x) function (s::EpsilonGreedyExplorer{<:Any,false})(values, mask) ϵ = get_ϵ(s) - s.is_training && (s.step += 1) + s.step += 1 rand(s.rng) >= ϵ ? findmax(values, mask)[2] : rand(s.rng, findall(mask)) end -Random.seed!(s::EpsilonGreedyExplorer, seed) = Random.seed!(s.rng, seed) +##### """ prob(s::EpsilonGreedyExplorer, values) ->Categorical @@ -143,7 +143,7 @@ function RLBase.prob(s::EpsilonGreedyExplorer{<:Any,true}, values) for ind in max_val_inds probs[ind] += (1 - ϵ) / length(max_val_inds) end - Categorical(probs) + Categorical(probs; check_args=false) end function RLBase.prob(s::EpsilonGreedyExplorer{<:Any,true}, values, action::Integer) @@ -160,7 +160,7 @@ function RLBase.prob(s::EpsilonGreedyExplorer{<:Any,false}, values) ϵ, n = get_ϵ(s), length(values) probs = fill(ϵ / n, n) probs[findmax(values)[2]] += 1 - ϵ - Categorical(probs) + Categorical(probs; check_args=false) end function RLBase.prob(s::EpsilonGreedyExplorer{<:Any,false}, values, action::Integer) @@ -180,7 +180,7 @@ function RLBase.prob(s::EpsilonGreedyExplorer{<:Any,true}, values, mask) for ind in max_val_inds probs[ind] += (1 - ϵ) / length(max_val_inds) end - Categorical(probs) + Categorical(probs; check_args=false) end function RLBase.prob(s::EpsilonGreedyExplorer{<:Any,false}, values, mask) @@ -188,27 +188,25 @@ function RLBase.prob(s::EpsilonGreedyExplorer{<:Any,false}, values, mask) probs = zeros(n) probs[mask] .= ϵ / sum(mask) probs[findmax(values, mask)[2]] += 1 - ϵ - Categorical(probs) + Categorical(probs; check_args=false) end +##### + # Though we can achieve the same goal by setting the ϵ of [`EpsilonGreedyExplorer`](@ref) to 0, # the GreedyExplorer is much faster. struct GreedyExplorer <: AbstractExplorer end +(s::GreedyExplorer)(x, mask::Trues) = s(x) + (s::GreedyExplorer)(values) = findmax(values)[2] (s::GreedyExplorer)(values, mask) = findmax(values, mask)[2] -function RLBase.prob(s::GreedyExplorer, values) - prob = zeros(length(values)) - prob[findmax(values)[2]] = 1.0 - Categorical(prob) -end +RLBase.prob(s::GreedyExplorer, values) = + Categorical(onehot(findmax(values)[2], 1:length(values)); check_args=false) RLBase.prob(s::GreedyExplorer, values, action::Integer) = findmax(values)[2] == action ? 1.0 : 0.0 -function RLBase.prob(s::GreedyExplorer, values, mask) - prob = zeros(length(values)) - prob[findmax(values, mask)[2]] = 1.0 - Categorical(prob) -end +RLBase.prob(s::GreedyExplorer, values, mask) = + Categorical(onehot(findmax(values, mask)[2], length(values)); check_args=false) diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/explorers.jl b/src/ReinforcementLearningCore/src/policies/explorers/explorers.jl similarity index 100% rename from src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/explorers.jl rename to src/ReinforcementLearningCore/src/policies/explorers/explorers.jl diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/gumbel_softmax_explorer.jl b/src/ReinforcementLearningCore/src/policies/explorers/gumbel_softmax_explorer.jl similarity index 100% rename from src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/gumbel_softmax_explorer.jl rename to src/ReinforcementLearningCore/src/policies/explorers/gumbel_softmax_explorer.jl diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/weighted_explorer.jl b/src/ReinforcementLearningCore/src/policies/explorers/weighted_explorer.jl similarity index 97% rename from src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/weighted_explorer.jl rename to src/ReinforcementLearningCore/src/policies/explorers/weighted_explorer.jl index 3c7cca0a7..5e910fd9d 100644 --- a/src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/weighted_explorer.jl +++ b/src/ReinforcementLearningCore/src/policies/explorers/weighted_explorer.jl @@ -1,6 +1,6 @@ export WeightedExplorer -using Random +using Random: AbstractRNG using StatsBase: sample, Weights """ diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/weighted_softmax_explorer.jl b/src/ReinforcementLearningCore/src/policies/explorers/weighted_softmax_explorer.jl similarity index 85% rename from src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/weighted_softmax_explorer.jl rename to src/ReinforcementLearningCore/src/policies/explorers/weighted_softmax_explorer.jl index ae8855e2a..eea2b0c9b 100644 --- a/src/ReinforcementLearningCore/src/policies/q_based_policies/explorers/weighted_softmax_explorer.jl +++ b/src/ReinforcementLearningCore/src/policies/explorers/weighted_softmax_explorer.jl @@ -1,6 +1,6 @@ export WeightedSoftmaxExplorer -using Random +using Random: AbstractRNG using StatsBase: sample, Weights using Flux: softmax @@ -9,8 +9,8 @@ using Flux: softmax See also: [`WeightedExplorer`](@ref) """ -struct WeightedSoftmaxExplorer{R<:AbstractRNG} <: AbstractExplorer - rng::R +struct WeightedSoftmaxExplorer <: AbstractExplorer + rng::AbstractRNG end function WeightedSoftmaxExplorer(; rng = Random.GLOBAL_RNG) @@ -29,5 +29,6 @@ RLBase.prob(s::WeightedSoftmaxExplorer, values) = softmax(values) function RLBase.prob(s::WeightedSoftmaxExplorer, values::AbstractVector{T}, mask) where {T} p = prob(s, values) .* mask - p / sum(p) + p ./= sum(p) + p end diff --git a/src/ReinforcementLearningCore/src/policies/learners.jl b/src/ReinforcementLearningCore/src/policies/learners.jl new file mode 100644 index 000000000..dca9a8825 --- /dev/null +++ b/src/ReinforcementLearningCore/src/policies/learners.jl @@ -0,0 +1,20 @@ +export AbstractLearner, Approximator + +import Flux +import Functors + +abstract type AbstractLearner end + +(L::AbstractLearner)(env) = env |> state |> send_to_device(L) |> L |> send_to_device(env) + +Base.@kwdef mutable struct Approximator{M,O} + model::M + optimiser::O +end + +Functors.functor(x::Approximator) = (model = x.model,), y -> Approximator(y.model, x.state) + +(A::Approximator)(x) = A.model(x) + +RLBase.optimise!(A::Approximator, gs) = + Flux.Optimise.update!(A.optimiser, Flux.params(A), gs) \ No newline at end of file diff --git a/src/ReinforcementLearningCore/src/policies/policies.jl b/src/ReinforcementLearningCore/src/policies/policies.jl index 8e52a8e51..0a1f57f95 100644 --- a/src/ReinforcementLearningCore/src/policies/policies.jl +++ b/src/ReinforcementLearningCore/src/policies/policies.jl @@ -1,7 +1,3 @@ -include("base.jl") -include("agents/agents.jl") -include("q_based_policies/q_based_policies.jl") -include("v_based_policies.jl") -include("tabular_random_policy.jl") +include("agent.jl") include("random_policy.jl") -include("random_start_policy.jl") +include("q_based_policy.jl") \ No newline at end of file diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/abstract_learner.jl b/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/abstract_learner.jl deleted file mode 100644 index f176fbdab..000000000 --- a/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/abstract_learner.jl +++ /dev/null @@ -1,36 +0,0 @@ -export AbstractLearner - -using Flux - -""" - (learner::AbstractLearner)(env) - -A learner is usually used to estimate state values, state-action values or distributional values based on experiences. -""" -abstract type AbstractLearner end - -function (learner::AbstractLearner)(env) end - -""" - get_priority(p::AbstractLearner, experience) -""" -function RLBase.priority(p::AbstractLearner, experience) end - -Base.show(io::IO, p::AbstractLearner) = - AbstractTrees.print_tree(io, StructTree(p), maxdepth=get(io, :max_depth, 10)) - -function RLBase.update!( - L::AbstractLearner, - t::AbstractTrajectory, - e::AbstractEnv, - s::AbstractStage, -) end - -function RLBase.update!( - L::AbstractLearner, - t::AbstractTrajectory, - e::AbstractEnv, - s::PreActStage, -) - update!(L, t) -end diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/approximators/abstract_approximator.jl b/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/approximators/abstract_approximator.jl deleted file mode 100644 index 4489c309a..000000000 --- a/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/approximators/abstract_approximator.jl +++ /dev/null @@ -1,37 +0,0 @@ -export AbstractApproximator, - ApproximatorStyle, Q_APPROXIMATOR, QApproximator, V_APPROXIMATOR, VApproximator - -""" - (app::AbstractApproximator)(env) - -An approximator is a functional object for value estimation. -It serves as a black box to provides an abstraction over different -kinds of approximate methods (for example DNN provided by Flux or Knet). -""" -abstract type AbstractApproximator end - -""" - update!(a::AbstractApproximator, correction) - -Usually the `correction` is the gradient of inner parameters. -""" -function RLBase.update!(a::AbstractApproximator, correction) end - -##### -# traits -##### - -abstract type AbstractApproximatorStyle end - -""" -Used to detect what an [`AbstractApproximator`](@ref) is approximating. -""" -function ApproximatorStyle(::AbstractApproximator) end - -struct QApproximator <: AbstractApproximatorStyle end - -const Q_APPROXIMATOR = QApproximator() - -struct VApproximator <: AbstractApproximatorStyle end - -const V_APPROXIMATOR = VApproximator() diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/approximators/approximators.jl b/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/approximators/approximators.jl deleted file mode 100644 index c6b3b89d5..000000000 --- a/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/approximators/approximators.jl +++ /dev/null @@ -1,3 +0,0 @@ -include("abstract_approximator.jl") -include("tabular_approximator.jl") -include("neural_network_approximator.jl") diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/approximators/neural_network_approximator.jl b/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/approximators/neural_network_approximator.jl deleted file mode 100644 index 65128aa05..000000000 --- a/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/approximators/neural_network_approximator.jl +++ /dev/null @@ -1,399 +0,0 @@ -export NeuralNetworkApproximator, ActorCritic, GaussianNetwork, CovGaussianNetwork, DuelingNetwork, PerturbationNetwork -export VAE, decode, vae_loss - -using LinearAlgebra -using Flux -using Random -using Distributions: Normal, logpdf -import Functors: functor -using MacroTools: @forward - -""" - NeuralNetworkApproximator(;kwargs) - -Use a DNN model for value estimation. - -# Keyword arguments - -- `model`, a Flux based DNN model. -- `optimizer=nothing` -""" -Base.@kwdef struct NeuralNetworkApproximator{M,O} <: AbstractApproximator - model::M - optimizer::O = nothing -end - -# some model may accept multiple inputs -(app::NeuralNetworkApproximator)(args...; kwargs...) = app.model(args...; kwargs...) - -@forward NeuralNetworkApproximator.model Flux.testmode!, -Flux.trainmode!, -Flux.params, -device - -functor(x::NeuralNetworkApproximator) = - (model=x.model,), y -> NeuralNetworkApproximator(y.model, x.optimizer) - -RLBase.update!(app::NeuralNetworkApproximator, gs) = - Flux.Optimise.update!(app.optimizer, params(app), gs) - -Base.copyto!(dest::NeuralNetworkApproximator, src::NeuralNetworkApproximator) = - Flux.loadparams!(dest.model, params(src)) - -##### -# ActorCritic -##### - -""" - ActorCritic(;actor, critic, optimizer=ADAM()) - -The `actor` part must return logits (*Do not use softmax in the last layer!*), and the `critic` part must return a state value. -""" -Base.@kwdef struct ActorCritic{A,C,O} <: AbstractApproximator - actor::A - critic::C - optimizer::O = ADAM() -end - -functor(x::ActorCritic) = - (actor=x.actor, critic=x.critic), y -> ActorCritic(y.actor, y.critic, x.optimizer) - -RLBase.update!(app::ActorCritic, gs) = Flux.Optimise.update!(app.optimizer, params(app), gs) - -function Base.copyto!(dest::ActorCritic, src::ActorCritic) - Flux.loadparams!(dest.actor, params(src.actor)) - Flux.loadparams!(dest.critic, params(src.critic)) -end - -##### -# GaussianNetwork -##### - -""" - GaussianNetwork(;pre=identity, μ, logσ, min_σ=0f0, max_σ=Inf32, normalizer = tanh) - -Returns `μ` and `logσ` when called. Create a distribution to sample from using -`Normal.(μ, exp.(logσ))`. `min_σ` and `max_σ` are used to clip the output from -`logσ`. Actions are normalized according to the specified normalizer function. -""" -Base.@kwdef struct GaussianNetwork{P,U,S,F} - pre::P = identity - μ::U - logσ::S - min_σ::Float32 = 0.0f0 - max_σ::Float32 = Inf32 - normalizer::F = tanh -end - -GaussianNetwork(pre, μ, logσ, normalizer=tanh) = GaussianNetwork(pre, μ, logσ, 0.0f0, Inf32, normalizer) - -Flux.@functor GaussianNetwork - -""" -This function is compatible with a multidimensional action space. When outputting an action, it uses the `normalizer` function to normalize it elementwise. - -- `rng::AbstractRNG=Random.GLOBAL_RNG` -- `is_sampling::Bool=false`, whether to sample from the obtained normal distribution. -- `is_return_log_prob::Bool=false`, whether to calculate the conditional probability of getting actions in the given state. -""" -function (model::GaussianNetwork)(rng::AbstractRNG, s; is_sampling::Bool=false, is_return_log_prob::Bool=false) - x = model.pre(s) - μ, raw_logσ = model.μ(x), model.logσ(x) - logσ = clamp.(raw_logσ, log(model.min_σ), log(model.max_σ)) - if is_sampling - σ = exp.(logσ) - z = Zygote.ignore() do - noise = randn(rng, Float32, size(μ)) - model.normalizer.(μ .+ σ .* noise) - end - if is_return_log_prob - logp_π = sum(normlogpdf(μ, σ, z) .- (2.0f0 .* (log(2.0f0) .- z .- softplus.(-2.0f0 .* z))), dims=1) - return z, logp_π - else - return z - end - else - return μ, logσ - end -end - -""" - (model::GaussianNetwork)(rng::AbstractRNG, state, action_samples::Int) -Sample `action_samples` actions from each state. Returns a 3D tensor with dimensions (action_size x action_samples x batch_size). -`state` must be 3D tensor with dimensions (state_size x 1 x batch_size). Always returns the logpdf of each action along. -""" -function (model::GaussianNetwork)(rng::AbstractRNG, s, action_samples::Int) - x = model.pre(s) - μ, raw_logσ = model.μ(x), model.logσ(x) - logσ = clamp.(raw_logσ, log(model.min_σ), log(model.max_σ)) - - σ = exp.(logσ) - z = Zygote.ignore() do - noise = randn(rng, Float32, (size(μ, 1), action_samples, size(μ, 3))...) - model.normalizer.(μ .+ σ .* noise) - end - logp_π = sum(normlogpdf(μ, σ, z) .- (2.0f0 .* (log(2.0f0) .- z .- softplus.(-2.0f0 .* z))), dims=1) - return z, logp_π -end - -function (model::GaussianNetwork)(state; is_sampling::Bool=false, is_return_log_prob::Bool=false) - model(Random.GLOBAL_RNG, state; is_sampling=is_sampling, is_return_log_prob=is_return_log_prob) -end - -function (model::GaussianNetwork)(state, action_samples::Int) - model(Random.GLOBAL_RNG, state, action_samples) -end - -function (model::GaussianNetwork)(state, action) - x = model.pre(state) - μ, raw_logσ = model.μ(x), model.logσ(x) - logσ = clamp.(raw_logσ, log(model.min_σ), log(model.max_σ)) - σ = exp.(logσ) - logp_π = sum(normlogpdf(μ, σ, action) .- (2.0f0 .* (log(2.0f0) .- action .- softplus.(-2.0f0 .* action))), dims=1) - return logp_π -end - -""" - CovGaussianNetwork(;pre=identity, μ, Σ, normalizer = tanh) - -Returns `μ` and `Σ` when called where μ is the mean and Σ is a covariance matrix. Unlike GaussianNetwork, the output is 3-dimensional. -μ has dimensions (action_size x 1 x batch_size) and Σ has dimensions (action_size x action_size x batch_size). -The Σ head of the `CovGaussianNetwork` should not directly return a square matrix but a vector of length `action_size x (action_size + 1) ÷ 2`. -This vector will contain elements of the uppertriangular cholesky decomposition of the covariance matrix, which is then reconstructed from it. -Sample from `MvNormal.(μ, Σ)`. Actions are normalized elementwise according to the specified normalizer function. -""" -mutable struct CovGaussianNetwork{P,U,S,F} - pre::P - μ::U - Σ::S - normalizer::F -end - -CovGaussianNetwork(pre, m, s) = CovGaussianNetwork(pre, m, s, tanh) - -Flux.@functor CovGaussianNetwork - -""" - (model::CovGaussianNetwork)(rng::AbstractRNG, state; is_sampling::Bool=false, is_return_log_prob::Bool=false) - -This function is compatible with a multidimensional action space. When outputting a sampled action, it uses the `normalizer` function to normalize it elementwise. -To work with covariance matrices, the outputs are 3D tensors. -If sampling, return an actions tensor with dimensions (action_size x action_samples x batch_size) and logp_π (1 x action_samples x batch_size) -If not, returns μ with dimensions (action_size x 1 x batch_size) and L, the lower triangular of the cholesky decomposition of the covariance matrix, with dimensions (action_size x action_size x batch_size) -The covariance matrices can be retrieved with `Σ = Flux.stack(map(l -> l*l', eachslice(L, dims=3)),3)` - -- `rng::AbstractRNG=Random.GLOBAL_RNG` -- `is_sampling::Bool=false`, whether to sample from the obtained normal distribution. -- `is_return_log_prob::Bool=false`, whether to calculate the conditional probability of getting actions in the given state. -""" -function (model::CovGaussianNetwork)(rng::AbstractRNG, state; is_sampling::Bool=false, is_return_log_prob::Bool=false) - batch_size = size(state, 3) - x = model.pre(state) - μ, cholesky_vec = model.μ(x), model.Σ(x) - da = size(μ, 1) - L = vec_to_tril(cholesky_vec, da) - - if is_sampling - z = Zygote.ignore() do - noise = randn(rng, eltype(μ), da, 1, batch_size) - model.normalizer.(Flux.stack(map(.+, eachslice(μ, dims=3), eachslice(L, dims=3) .* eachslice(noise, dims=3)), 3)) - end - if is_return_log_prob - logp_π = mvnormlogpdf(μ, L, z) - return z, logp_π - else - return z - end - else - return μ, L - end -end - -""" - (model::CovGaussianNetwork)(rng::AbstractRNG, state::AbstractMatrix; is_sampling::Bool=false, is_return_log_prob::Bool=false) - -Given a Matrix of states, will return actions, μ and logpdf in matrix format. The batch of Σ remains a 3D tensor. -""" -function (model::CovGaussianNetwork)(rng::AbstractRNG, state::AbstractMatrix; is_sampling::Bool=false, is_return_log_prob::Bool=false) - output = model(rng, Flux.unsqueeze(state, 2); is_sampling=is_sampling, is_return_log_prob=is_return_log_prob) - if output isa Tuple && is_sampling - dropdims(output[1], dims=2), dropdims(output[2], dims=2) - elseif output isa Tuple - dropdims(output[1], dims=2), output[2] #can't reduce the dims of the covariance tensor - else - dropdims(output, dims=2) - end -end - - - -""" - (model::CovGaussianNetwork)(rng::AbstractRNG, state, action_samples::Int) - -Sample `action_samples` actions given `state` and return the `actions, logpdf(actions)`. -This function is compatible with a multidimensional action space. When outputting a sampled action, it uses the `normalizer` function to normalize it elementwise. -The outputs are 3D tensors with dimensions (action_size x action_samples x batch_size) and (1 x action_samples x batch_size) for `actions` and `logdpf` respectively. -""" -function (model::CovGaussianNetwork)(rng::AbstractRNG, state, action_samples::Int) - batch_size = size(state, 3) #3 - x = model.pre(state) - μ, cholesky_vec = model.μ(x), model.Σ(x) - da = size(μ, 1) - L = vec_to_tril(cholesky_vec, da) - z = Zygote.ignore() do - noise = randn(rng, eltype(μ), da, action_samples, batch_size) - model.normalizer.(Flux.stack(map(.+, eachslice(μ, dims=3), eachslice(L, dims=3) .* eachslice(noise, dims=3)), 3)) - end - logp_π = mvnormlogpdf(μ, L, z) - return z, logp_π -end - -function (model::CovGaussianNetwork)(state::AbstractArray, args...; kwargs...) - model(Random.GLOBAL_RNG, state, args...; kwargs...) -end - -""" - (model::CovGaussianNetwork)(state, action) - -Return the logpdf of the model sampling `action` when in `state`. -State must be a 3D tensor with dimensions (state_size x 1 x batch_size). -Multiple actions may be taken per state, `action` must have dimensions (action_size x action_samples_per_state x batch_size) -Returns a 3D tensor with dimensions (1 x action_samples_per_state x batch_size) -""" -function (model::CovGaussianNetwork)(state::AbstractArray, action::AbstractArray) - da = size(action, 1) - x = model.pre(state) - μ, cholesky_vec = model.μ(x), model.Σ(x) - L = vec_to_tril(cholesky_vec, da) - logp_π = mvnormlogpdf(μ, L, action) - return logp_π -end - -""" -If given 2D matrices as input, will return a 2D matrix of logpdf. States and actions are paired column-wise, one action per state. -""" -function (model::CovGaussianNetwork)(state::AbstractMatrix, action::AbstractMatrix) - output = model(Flux.unsqueeze(state, 2), Flux.unsqueeze(action, 2)) - return dropdims(output, dims=2) -end - -""" -Transform a vector containing the non-zero elements of a lower triangular da x da matrix into that matrix. -""" -function vec_to_tril(cholesky_vec, da) - batch_size = size(cholesky_vec, 3) - c2idx(i, j) = ((2da - j) * (j - 1)) ÷ 2 + i #return the position in cholesky_vec of the element of the triangular matrix at coordinates (i,j) - function f(j) #return a slice (da x 1 x batchsize) containing the jth columns of the lower triangular cholesky decomposition of the covariance - tc_diag = softplus.(cholesky_vec[c2idx(j, j):c2idx(j, j), :, :]) - tc_other = cholesky_vec[c2idx(j, j)+1:c2idx(j + 1, j + 1)-1, :, :] - zs = Flux.Zygote.ignore() do - zs = similar(cholesky_vec, da - size(tc_other, 1) - 1, 1, batch_size) - zs .= zero(eltype(cholesky_vec)) - return zs - end - [zs; tc_diag; tc_other] - end - return mapreduce(f, hcat, 1:da) -end - -##### -# DuelingNetwork -##### - -""" - DuelingNetwork(;base, val, adv) - -Dueling network automatically produces separate estimates of the state value function network and advantage function network. The expected output size of val is 1, and adv is the size of the action space. -""" -Base.@kwdef struct DuelingNetwork{B,V,A} - base::B - val::V - adv::A -end - -Flux.@functor DuelingNetwork - -function (m::DuelingNetwork)(state) - x = m.base(state) - val = m.val(x) - return val .+ m.adv(x) .- mean(m.adv(x), dims=1) -end - -##### -# PerturbationNetwork -##### - -""" - PerturbationNetwork(;, ϕ) - -Perturbation network outputs an adjustment to an action in the range [-ϕ, ϕ] to increase the diversity of seen actions. - -# Keyword arguments -- `base`, a Flux based DNN model. -- `ϕ::Float32 = 0.05f0` -""" - -Base.@kwdef struct PerturbationNetwork{N} - base::N - ϕ::Float32 = 0.05f0 -end - -Flux.@functor PerturbationNetwork - -""" -This function accepts `state` and `action`, and then outputs actions after disturbance. -""" -function (model::PerturbationNetwork)(state, action) - x = model.base(vcat(state, action)) - x = model.ϕ * tanh.(x) - clamp.(x + action, -1.0f0, 1.0f0) -end - -##### -# VAE (Variational Auto-Encoder) -##### - -""" - VAE(;encoder, decoder, latent_dims) -""" -Base.@kwdef struct VAE{E,D} - encoder::E - decoder::D - latent_dims::Int -end - -Flux.@functor VAE - -function (model::VAE)(rng::AbstractRNG, state, action) - μ, logσ = model.encoder(vcat(state, action)) - σ = exp.(logσ) - z = μ .+ σ .* randn(rng, Float32, size(μ)) - u = decode(model, state, z) - return u, μ, σ -end - -function (model::VAE)(state, action) - return model(Random.GLOBAL_RNG, state, action) -end - -function decode(rng::AbstractRNG, model::VAE, state, z=nothing; is_normalize::Bool=true) - if z === nothing - z = clamp.(randn(rng, Float32, (model.latent_dims, size(state)[2:end]...)), -0.5f0, 0.5f0) - end - a = model.decoder(vcat(state, z)) - if is_normalize - a = tanh.(a) - end - return a -end - -function decode(model::VAE, state, z=nothing; is_normalize::Bool=true) - decode(Random.GLOBAL_RNG, model, state, z; is_normalize) -end - -function vae_loss(model::VAE, state, action) - u, μ, σ = model(state, action) - recon_loss = Flux.Losses.mse(u, action) - kl_loss = -0.5f0 * mean(1.0f0 .+ log.(σ .^ 2) .- μ .^ 2 .- σ .^ 2) - return recon_loss, kl_loss -end diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/approximators/tabular_approximator.jl b/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/approximators/tabular_approximator.jl deleted file mode 100644 index 0a4dcb86a..000000000 --- a/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/approximators/tabular_approximator.jl +++ /dev/null @@ -1,68 +0,0 @@ -export TabularApproximator, TabularVApproximator, TabularQApproximator - -""" - TabularApproximator(table<:AbstractArray, opt) - -For `table` of 1-d, it will serve as a state value approximator. See [`TabularVApproximator`](@ref). -For `table` of 2-d, it will serve as a state-action value approximator. See [`TabularQApproximator`](@ref). - -Note that actions and states should be presented to `TabularApproximator` as integers starting from -1 to be used as the index of the table. That is, e.g., [`RLBase.state_space`](@ref) is expected to -return `Base.OneTo(n_state)`, where `n_state` is the number of states. - -!!! warning - For `table` of 2-d, the first dimension is action and the second dimension is state. -""" -struct TabularApproximator{N,T<:AbstractArray{<:AbstractFloat, N},O} <: AbstractApproximator - table::T - optimizer::O - function TabularApproximator(table::T, opt::O) where {T<:AbstractArray,O} - n = ndims(table) - n <= 2 || throw(ArgumentError("the dimension of table must be <= 2")) - new{n,T,O}(table, opt) - end -end - -const TabularVApproximator = TabularApproximator{1} -const TabularQApproximator = TabularApproximator{2} - -""" - TabularVApproximator(; n_state, init = 0.0, opt = InvDecay(1.0)) - -A state value approximator represented by a 1-d table. `init` is the initial value of each state. -""" -TabularVApproximator(; n_state, init = 0.0, opt = InvDecay(1.0)) = - TabularApproximator(fill(init, n_state), opt) -""" - TabularQApproximator(; n_state, n_action, init = 0.0, opt = InvDecay(1.0)) - -An action-state value approximator represented by a 2-d table. `init` is the initial value of each -pair of action-state. -""" -TabularQApproximator(; n_state, n_action, init = 0.0, opt = InvDecay(1.0)) = - TabularApproximator(fill(init, n_action, n_state), opt) - -(app::TabularVApproximator)(s::Int) = @views app.table[s] - -(app::TabularQApproximator)(s::Int) = @views app.table[:, s] -(app::TabularQApproximator)(s::Int, a::Int) = app.table[a, s] - -function RLBase.update!(app::TabularVApproximator, correction::Pair{Int,Float64}) - s, e = correction - x = @view app.table[s] - x̄ = @view [e][1] - Flux.Optimise.update!(app.optimizer, x, x̄) -end - -function RLBase.update!(app::TabularQApproximator, correction::Pair{Tuple{Int,Int},Float64}) - (s, a), e = correction - x = @view app.table[a, s] - x̄ = @view [e][1] - Flux.Optimise.update!(app.optimizer, x, x̄) -end - -function RLBase.update!(app::TabularQApproximator, correction::Pair{Int,Vector{Float64}}) - s, errors = correction - x = @view app.table[:, s] - Flux.Optimise.update!(app.optimizer, x, errors) -end diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/learners.jl b/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/learners.jl deleted file mode 100644 index 90da87de0..000000000 --- a/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/learners.jl +++ /dev/null @@ -1,2 +0,0 @@ -include("abstract_learner.jl") -include("approximators/approximators.jl") diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/tabular_learner.jl b/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/tabular_learner.jl deleted file mode 100644 index 3acd94ac2..000000000 --- a/src/ReinforcementLearningCore/src/policies/q_based_policies/learners/tabular_learner.jl +++ /dev/null @@ -1,55 +0,0 @@ -export TabularLearner - -""" - TabularLearner{S, T} - -Use a `Dict{S,Vector{T}}` to store action probabilities. `S` is the type of -state. `T` is the element type of probabilities. -""" -struct TabularLearner{S,T} <: AbstractLearner - table::Dict{S,Vector{T}} -end - -TabularLearner() = TabularLearner{Int,Float32}() -TabularLearner{S}() where {S} = TabularLearner{S,Float32}() -TabularLearner{S,T}() where {S,T} = TabularLearner(Dict{S,Vector{T}}()) - -(p::TabularLearner)(env::AbstractEnv) = p(ChanceStyle(env), env) - -function (p::TabularLearner)(::ExplicitStochastic, env::AbstractEnv) - if current_player(env) == chance_player(env) - prob(env) - else - p(DETERMINISTIC, env) # treat it just like a normal one - end -end - -function (t::TabularLearner)(::RLBase.AbstractChanceStyle, env::AbstractEnv) - t(ActionStyle(env), env) -end - -function (t::TabularLearner)(::FullActionSet, env::AbstractEnv) - get!(t.table, state(env)) do - m = legal_action_space_mask(env) - m ./ sum(m) - end -end - -function (t::TabularLearner)(::MinimalActionSet, env::AbstractEnv) - get!(t.table, state(env)) do - n = length(action_space(env)) - fill(1 / n, n) - end -end - -""" - update!(p::TabularLearner, state => prob) - -!!! warn - For environments of `FULL_ACTION_SET`, `prob` represents the probability - distribution of `legal_action_space(env)`. For environments of - `MINIMAL_ACTION_SET`, `prob` should represent the probability distribution - of `action_space(env)`. -""" -RLBase.update!(p::TabularLearner, experience::Pair) = - p.table[first(experience)] = last(experience) diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/q_based_policies.jl b/src/ReinforcementLearningCore/src/policies/q_based_policies/q_based_policies.jl deleted file mode 100644 index e8ffcf12e..000000000 --- a/src/ReinforcementLearningCore/src/policies/q_based_policies/q_based_policies.jl +++ /dev/null @@ -1,3 +0,0 @@ -include("learners/learners.jl") -include("explorers/explorers.jl") -include("q_based_policy.jl") diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policies/q_based_policy.jl b/src/ReinforcementLearningCore/src/policies/q_based_policies/q_based_policy.jl deleted file mode 100644 index 83215bd68..000000000 --- a/src/ReinforcementLearningCore/src/policies/q_based_policies/q_based_policy.jl +++ /dev/null @@ -1,81 +0,0 @@ -export QBasedPolicy, TabularRandomPolicy - -using MacroTools: @forward -using Flux -using Distributions: Distribution, probs -using Setfield: @set - -""" - QBasedPolicy(;learner::Q, explorer::S) - -Use a Q-`learner` to generate estimations of action values. -Then an `explorer` is applied on the estimations to select an action. -""" -Base.@kwdef mutable struct QBasedPolicy{Q<:AbstractLearner,E<:AbstractExplorer} <: - AbstractPolicy - learner::Q - explorer::E -end - -Flux.functor(x::QBasedPolicy) = (learner = x.learner,), y -> @set x.learner = y.learner - -(π::QBasedPolicy)(env) = π(env, ActionStyle(env), action_space(env)) - -(π::QBasedPolicy)(env, ::MinimalActionSet, ::Base.OneTo) = π.explorer(π.learner(env)) -(π::QBasedPolicy)(env, ::FullActionSet, ::Base.OneTo) = - π.explorer(π.learner(env), legal_action_space_mask(env)) - -(π::QBasedPolicy)(env, ::MinimalActionSet, A) = A[π.explorer(π.learner(env))] -(π::QBasedPolicy)(env, ::FullActionSet, A) = - A[π.explorer(π.learner(env), legal_action_space_mask(env))] - -RLBase.prob(p::QBasedPolicy, env::AbstractEnv) = prob(p, env, ActionStyle(env)) -RLBase.prob(p::QBasedPolicy, env::AbstractEnv, ::MinimalActionSet) = - prob(p.explorer, p.learner(env)) -RLBase.prob(p::QBasedPolicy, env::AbstractEnv, ::FullActionSet) = - prob(p.explorer, p.learner(env), legal_action_space_mask(env)) - -function RLBase.prob(p::QBasedPolicy, env::AbstractEnv, action) - A = action_space(env) - P = prob(p, env) - if P isa Distribution - P = probs(P) - end - @assert length(A) == length(P) - if A isa Base.OneTo - P[action] - # elseif A isa ZeroTo - # P[action+1] - else - for (a, p) in zip(A, P) - if a == action - return p - end - end - @error "action[$action] is not found in action space[$(action_space(env))]" - end -end - -@forward QBasedPolicy.learner RLBase.priority - -function RLBase.update!( - p::QBasedPolicy, - t::AbstractTrajectory, - e::AbstractEnv, - s::AbstractStage, -) - update!(p.learner, t, e, s) -end - -function check(p::QBasedPolicy, env::AbstractEnv) - A = action_space(env) - if (A isa AbstractVector && A == 1:length(A)) || - (A isa Tuple && A == Tuple(1:length(A))) - # this is expected - else - @warn "Applying a QBasedPolicy to an environment with a unknown action space. Maybe convert the environment with `discrete2standard_discrete` in ReinforcementLearningEnvironments.jl first or redesign the environment." - end - - check(p.learner, env) - check(p.explorer, env) -end diff --git a/src/ReinforcementLearningCore/src/policies/q_based_policy.jl b/src/ReinforcementLearningCore/src/policies/q_based_policy.jl new file mode 100644 index 000000000..5e3233966 --- /dev/null +++ b/src/ReinforcementLearningCore/src/policies/q_based_policy.jl @@ -0,0 +1,21 @@ +export QBasedPolicy + +include("learners.jl") +include("explorers/explorers.jl") + +import Functors + +Base.@kwdef mutable struct QBasedPolicy{L,E} <: AbstractPolicy + learner::L + explorer::E +end + +Functors.functor(x::QBasedPolicy) = + (learner = x.learner,), y -> QBasedPolicy(y.learner, x.explorer) + +(p::QBasedPolicy)(env) = p.explorer(p.learner(env), legal_action_space_mask(env)) + +RLBase.prob(p::QBasedPolicy, env::AbstractEnv) = + prob(p.explorer, p.learner(env), legal_action_space_mask(env)) + +RLBase.optimise!(p::QBasedPolicy, x::NamedTuple) = optimise!(p.learner, x) diff --git a/src/ReinforcementLearningCore/src/policies/random_policy.jl b/src/ReinforcementLearningCore/src/policies/random_policy.jl index 279377c8a..dda2d0425 100644 --- a/src/ReinforcementLearningCore/src/policies/random_policy.jl +++ b/src/ReinforcementLearningCore/src/policies/random_policy.jl @@ -1,6 +1,8 @@ export RandomPolicy -using Random +using Random: AbstractRNG +using Distributions: Categorical +using FillArrays: Fill """ RandomPolicy(action_space=nothing; rng=Random.GLOBAL_RNG) @@ -13,31 +15,34 @@ runtime to randomly select an action. Otherwise, a random element within You should always set `action_space=nothing` when dealing with environments of `FULL_ACTION_SET`. """ -struct RandomPolicy{S,R<:AbstractRNG} <: AbstractPolicy +struct RandomPolicy{S} <: AbstractPolicy action_space::S - rng::R + rng::AbstractRNG end -Random.seed!(p::RandomPolicy, seed) = Random.seed!(p.rng, seed) - RandomPolicy(s = nothing; rng = Random.GLOBAL_RNG) = RandomPolicy(s, rng) +RLBase.optimise!(::RandomPolicy, x::NamedTuple) = nothing + (p::RandomPolicy{Nothing})(env) = rand(p.rng, legal_action_space(env)) (p::RandomPolicy)(env) = rand(p.rng, p.action_space) -function RLBase.prob(p::RandomPolicy{<:Union{AbstractVector,Tuple}}, env::AbstractEnv) - prob(p, state(env)) -end +##### + +RLBase.prob(p::RandomPolicy, env::AbstractEnv) = prob(p, state(env)) -function RLBase.prob(p::RandomPolicy{<:Union{AbstractVector,Tuple}}, s) +function RLBase.prob(p::RandomPolicy, s) n = length(p.action_space) - Categorical(fill(1 / n, n); check_args = false) + Categorical(Fill(1 / n, n); check_args = false) end -RLBase.prob(p::RandomPolicy{Nothing}, env::AbstractEnv) = prob(p, env, ChanceStyle(env)) RLBase.prob(p::RandomPolicy{Nothing}, x) = @error "no I really don't know how to calculate the prob from nothing" +##### + +RLBase.prob(p::RandomPolicy{Nothing}, env::AbstractEnv) = prob(p, env, ChanceStyle(env)) + function RLBase.prob( p::RandomPolicy{Nothing}, env::AbstractEnv, @@ -62,7 +67,7 @@ function RLBase.prob( end end -RLBase.update!(p::RandomPolicy, x) = nothing +##### RLBase.prob(p::RandomPolicy, env_or_state, a) = 1 / length(p.action_space) diff --git a/src/ReinforcementLearningCore/src/policies/random_start_policy.jl b/src/ReinforcementLearningCore/src/policies/random_start_policy.jl deleted file mode 100644 index e61ea9b4e..000000000 --- a/src/ReinforcementLearningCore/src/policies/random_start_policy.jl +++ /dev/null @@ -1,35 +0,0 @@ -export RandomStartPolicy - -Base.@kwdef mutable struct RandomStartPolicy{P,R<:RandomPolicy} <: AbstractPolicy - policy::P - random_policy::R - num_rand_start::Int -end - -function (p::RandomStartPolicy)(env) - p.num_rand_start -= 1 - if p.num_rand_start < 0 - p.policy(env) - else - p.random_policy(env) - end -end - -function RLBase.update!( - p::RandomStartPolicy, - t::AbstractTrajectory, - e::AbstractEnv, - s::AbstractStage, -) - update!(p.policy, t, e, s) -end - -for f in (:prob, :priority) - @eval function RLBase.$f(p::RandomStartPolicy, args...) - if p.num_rand_start < 0 - $f(p.policy, args...) - else - $f(p.random_policy, args...) - end - end -end diff --git a/src/ReinforcementLearningCore/src/policies/tabular_random_policy.jl b/src/ReinforcementLearningCore/src/policies/tabular_random_policy.jl deleted file mode 100644 index 821b4d333..000000000 --- a/src/ReinforcementLearningCore/src/policies/tabular_random_policy.jl +++ /dev/null @@ -1,91 +0,0 @@ -export TabularRandomPolicy - -""" - TabularRandomPolicy(;table=Dict{Int, Float32}(), rng=Random.GLOBAL_RNG) - -Use a `Dict` to store action distribution. -""" -Base.@kwdef struct TabularRandomPolicy{S,T,R} <: AbstractPolicy - table::Dict{S,T} = Dict{Any,Vector{Float32}}() - rng::R = Random.GLOBAL_RNG -end - -TabularRandomPolicy{S}(; rng = Random.GLOBAL_RNG) where {S} = - TabularRandomPolicy{S,Vector{Float32}}(; rng = rng) -TabularRandomPolicy{S,T}(; rng = Random.GLOBAL_RNG) where {S,T} = - TabularRandomPolicy(Dict{S,T}(), rng) - -RLBase.prob(p::TabularRandomPolicy, env::AbstractEnv) = prob(p, ChanceStyle(env), env) - -function RLBase.prob(p::TabularRandomPolicy, ::ExplicitStochastic, env::AbstractEnv) - if current_player(env) == chance_player(env) - prob(env) - else - prob(p, DETERMINISTIC, env) # treat it just like a normal one - end -end - -function RLBase.prob(t::TabularRandomPolicy, ::RLBase.AbstractChanceStyle, env::AbstractEnv) - prob(t, ActionStyle(env), env) -end - -function RLBase.prob(t::TabularRandomPolicy, ::FullActionSet, env::AbstractEnv) - get!(t.table, state(env)) do - m = legal_action_space_mask(env) - m ./ sum(m) - end -end - -function RLBase.prob(t::TabularRandomPolicy, ::MinimalActionSet, env::AbstractEnv) - get!(t.table, state(env)) do - n = length(action_space(env)) - fill(1 / n, n) - end -end - -function RLBase.prob(t::TabularRandomPolicy, env::AbstractEnv, action) - prob(t, env, action_space(env), action) -end - -function RLBase.prob(t::TabularRandomPolicy, env::AbstractEnv, action_space, action) - prob(t, env)[findfirst(==(action), action_space)] -end - -function RLBase.prob( - t::TabularRandomPolicy, - env::AbstractEnv, - action_space::Base.OneTo, - action, -) - prob(t, env)[action] -end - -# function RLBase.prob(t::TabularRandomPolicy, env::AbstractEnv, action_space::ZeroTo, action) -# prob(t, env)[action+1] -# end - -function RLBase.prob(t::TabularRandomPolicy, state, action) - # assume table is already initialized - t.table[state][action] -end - -(p::TabularRandomPolicy)(env::AbstractEnv) = - sample(p.rng, action_space(env), Weights(prob(p, env), 1.0)) - -# !!! Assumeing table is already initialized -(p::TabularRandomPolicy{S})(state::S) where {S} = - sample(p.rng, Weights(p.table[state], 1.0)) - -""" - update!(p::TabularRandomPolicy, state => value) - -You should manually check `value` sum to `1.0`. -""" -function RLBase.update!(p::TabularRandomPolicy, experience::Pair) - s, dist = experience - if haskey(p.table, s) - p.table[s] .= dist - else - p.table[s] = dist - end -end diff --git a/src/ReinforcementLearningCore/src/policies/v_based_policies.jl b/src/ReinforcementLearningCore/src/policies/v_based_policies.jl deleted file mode 100644 index 011323aec..000000000 --- a/src/ReinforcementLearningCore/src/policies/v_based_policies.jl +++ /dev/null @@ -1,32 +0,0 @@ -export VBasedPolicy - -function default_value_action_mapping(env, value_learner; explorer = GreedyExplorer()) - A = legal_action_space(env) - V = map(A) do a - value_learner(child(env, a)) - end - A[explorer(V)] -end - -""" - VBasedPolicy(;learner, mapping=default_value_action_mapping) - -The `learner` must be a value learner. The `mapping` is a function which returns -an action given `env` and the `learner`. By default we iterate through all the -valid actions and select the best one which lead to the maximum state value. -""" -Base.@kwdef struct VBasedPolicy{L,M} <: AbstractPolicy - learner::L - mapping::M = default_value_action_mapping -end - -(p::VBasedPolicy)(env::AbstractEnv) = p.mapping(env, p.learner) - -function RLBase.update!( - p::VBasedPolicy, - t::AbstractTrajectory, - e::AbstractEnv, - s::AbstractStage, -) - update!(p.learner, t, e, s) -end diff --git a/src/ReinforcementLearningCore/src/utils/base.jl b/src/ReinforcementLearningCore/src/utils/basic.jl similarity index 76% rename from src/ReinforcementLearningCore/src/utils/base.jl rename to src/ReinforcementLearningCore/src/utils/basic.jl index 7308ebd31..a945c117f 100644 --- a/src/ReinforcementLearningCore/src/utils/base.jl +++ b/src/ReinforcementLearningCore/src/utils/basic.jl @@ -1,24 +1,57 @@ -export nframes, - select_last_dim, - select_last_frame, - consecutive_view, +export global_norm, + clip_by_global_norm!, find_all_max, discount_rewards, discount_rewards!, discount_rewards_reduced, generalized_advantage_estimation, generalized_advantage_estimation!, - flatten_batch + flatten_batch, + orthogonal -using StatsBase -using Compat +using FillArrays: Trues -nframes(a::AbstractArray{T,N}) where {T,N} = size(a, N) +##### +# Zygote +##### -select_last_dim(xs::AbstractArray{T,N}, inds) where {T,N} = - @views xs[ntuple(_ -> (:), N - 1)..., inds] +global_norm(gs, ps) = sqrt(sum(mapreduce(x -> x^2, +, gs[p]) for p in ps)) -select_last_frame(xs::AbstractArray{T,N}) where {T,N} = select_last_dim(xs, size(xs, N)) +function clip_by_global_norm!(gs, ps, clip_norm::Float32) + gn = global_norm(gs, ps) + if clip_norm <= gn + for p in ps + gs[p] .*= clip_norm / max(clip_norm, gn) + end + end + gn +end + +##### +# Flux +##### + +# https://github.com/FluxML/Flux.jl/pull/1171/ +# https://www.tensorflow.org/api_docs/python/tf/keras/initializers/Orthogonal +function orthogonal_matrix(rng::AbstractRNG, nrow, ncol) + shape = reverse(minmax(nrow, ncol)) + a = randn(rng, Float32, shape) + q, r = qr(a) + q = Matrix(q) * diagm(sign.(diag(r))) + nrow < ncol ? permutedims(q) : q +end + +function orthogonal(rng::AbstractRNG, d1, rest_dims...) + m = orthogonal_matrix(rng, d1, *(rest_dims...)) + reshape(m, d1, rest_dims...) +end + +orthogonal(dims...) = orthogonal(Random.GLOBAL_RNG, dims...) +orthogonal(rng::AbstractRNG) = (dims...) -> orthogonal(rng, dims...) + +##### +# MLUtils +##### """ flatten_batch(x::AbstractArray) @@ -50,95 +83,17 @@ julia> flatten_batch(x) """ flatten_batch(x::AbstractArray) = reshape(x, size(x)[1:end-2]..., :) -""" - consecutive_view(x::AbstractArray, inds; n_stack = nothing, n_horizon = nothing) - -By default, it behaves the same with `select_last_dim(x, inds)`. -If `n_stack` is set to an int, then for each frame specified by `inds`, -the previous `n_stack` frames (including the current one) are concatenated as a new dimension. -If `n_horizon` is set to an int, then for each frame specified by `inds`, -the next `n_horizon` frames (including the current one) are concatenated as a new dimension. - -# Example - -```julia -julia> x = collect(1:5) -5-element Array{Int64,1}: - 1 - 2 - 3 - 4 - 5 - -julia> consecutive_view(x, [2,4]) # just the same with `select_last_dim(x, [2,4])` -2-element view(::Array{Int64,1}, [2, 4]) with eltype Int64: - 2 - 4 - -julia> consecutive_view(x, [2,4];n_stack = 2) -2×2 view(::Array{Int64,1}, [1 3; 2 4]) with eltype Int64: - 1 3 - 2 4 - -julia> consecutive_view(x, [2,4];n_horizon = 2) -2×2 view(::Array{Int64,1}, [2 4; 3 5]) with eltype Int64: - 2 4 - 3 5 - -julia> consecutive_view(x, [2,4];n_horizon = 2, n_stack=2) # note the order here, first we stack, then we apply the horizon -2×2×2 view(::Array{Int64,1}, [1 2; 2 3] - -[3 4; 4 5]) with eltype Int64: -[:, :, 1] = - 1 2 - 2 3 - -[:, :, 2] = - 3 4 - 4 5 -``` - -See also [Frame Skipping and Preprocessing for Deep Q networks](https://danieltakeshi.github.io/2016/11/25/frame-skipping-and-preprocessing-for-deep-q-networks-on-atari-2600-games/) -to gain a better understanding of state stacking and n-step learning. -""" -consecutive_view( - cb::AbstractArray, - inds::Vector{Int}; - n_stack = nothing, - n_horizon = nothing, -) = consecutive_view(cb, inds, n_stack, n_horizon) - -consecutive_view(cb::AbstractArray, inds::Vector{Int}, ::Nothing, ::Nothing) = - select_last_dim(cb, inds) - -consecutive_view(cb::AbstractArray, inds::Vector{Int}, n_stack::Int, ::Nothing) = - select_last_dim( - cb, - reshape([i for x in inds for i in x-n_stack+1:x], n_stack, length(inds)), - ) - -consecutive_view(cb::AbstractArray, inds::Vector{Int}, ::Nothing, n_horizon::Int) = - select_last_dim( - cb, - reshape([i for x in inds for i in x:x+n_horizon-1], n_horizon, length(inds)), - ) - -consecutive_view(cb::AbstractArray, inds::Vector{Int}, n_stack::Int, n_horizon::Int) = - select_last_dim( - cb, - reshape( - [j for x in inds for i in x:x+n_horizon-1 for j in i-n_stack+1:i], - n_stack, - n_horizon, - length(inds), - ), - ) +##### +# RLUtils +##### function find_all_max(x) v = maximum(x) v, findall(==(v), x) end +find_all_max(x, mask::Trues) = find_all_max(x) + function find_all_max(x, mask::AbstractVector{Bool}) v = maximum(view(x, mask)) v, [k for (m, k) in zip(mask, keys(x)) if m && x[k] == v] @@ -149,7 +104,10 @@ end # _rf_findmax((fm, m), (fx, x)) = isless(fm, fx) ? (fx, x) : (fm, m) # !!! type piracy -Base.findmax(A::AbstractVector{T}, mask::AbstractVector{Bool}) where T = findmax(ifelse.(mask, A, typemin(T))) +Base.findmax(A::AbstractVector{T}, mask::AbstractVector{Bool}) where {T} = + findmax(ifelse.(mask, A, typemin(T))) + +Base.findmax(A::AbstractVector, mask::Trues) = findmax(A) const VectorOrMatrix = Union{AbstractMatrix,AbstractVector} diff --git a/src/ReinforcementLearningCore/src/utils/device.jl b/src/ReinforcementLearningCore/src/utils/device.jl index e46ef1533..ccb359269 100644 --- a/src/ReinforcementLearningCore/src/utils/device.jl +++ b/src/ReinforcementLearningCore/src/utils/device.jl @@ -1,14 +1,15 @@ -export device, send_to_host, send_to_device +# TODO: watch https://github.com/JuliaGPU/Adapt.jl/pull/52 + +export device, send_to_device using Flux using CUDA using Adapt using Random -using ElasticArrays import CUDA: device -send_to_host(x) = send_to_device(Val(:cpu), x) +send_to_device(d) = x -> send_to_device(device(d), x) send_to_device(::Val{:cpu}, m) = fmap(x -> adapt(Array, x), m) @@ -26,9 +27,9 @@ device(x::Function) = nothing device(::Array) = Val(:cpu) device(x::Tuple{}) = nothing device(x::NamedTuple{(),Tuple{}}) = nothing -device(x::ElasticArray) = device(x.data) -device(x::SubArray) = device(parent(x)) -device(x::Base.ReshapedArray) = device(parent(x)) +device(x::AbstractArray) = device(parent(x)) + +device(x::AbstractEnv) = Val(:cpu) # TODO: we may support gpu later function device(x::Random.AbstractRNG) if x isa CUDA.CURAND.RNG diff --git a/src/ReinforcementLearningCore/src/utils/distributions.jl b/src/ReinforcementLearningCore/src/utils/distributions.jl new file mode 100644 index 000000000..4270efbea --- /dev/null +++ b/src/ReinforcementLearningCore/src/utils/distributions.jl @@ -0,0 +1,49 @@ +export normlogpdf, mvnormlogpdf + +using Flux: unsqueeze, stack + +# watch https://github.com/JuliaStats/Distributions.jl/issues/1183 +const log2π = log(2.0f0π) + +""" + normlogpdf(μ, σ, x; ϵ = 1.0f-8) + +GPU automatic differentiable version for the logpdf function of normal distributions. +Adding an epsilon value to guarantee numeric stability if sigma is exactly zero +(e.g. if relu is used in output layer). +""" +function normlogpdf(μ, σ, x; ϵ = 1.0f-8) + z = (x .- μ) ./ (σ .+ ϵ) + -(z .^ 2 .+ log2π) / 2.0f0 .- log.(σ .+ ϵ) +end + +""" + mvnormlogpdf(μ::AbstractVecOrMat, L::AbstractMatrix, x::AbstractVecOrMat) + +GPU automatic differentiable version for the logpdf function of multivariate +normal distributions. Takes as inputs `mu` the mean vector, `L` the lower +triangular matrix of the cholesky decomposition of the covariance matrix, and +`x` a matrix of samples where each column is a sample. Return a Vector +containing the logpdf of each column of x for the `MvNormal` parametrized by `μ` +and `Σ = L*L'`. +""" +function mvnormlogpdf(μ::AbstractVecOrMat, L::AbstractMatrix, x::AbstractVecOrMat) + return -( + (size(x, 1) * log2π + logdetLorU(L)) .+ vec(sum(abs2.(L \ (x .- μ)), dims = 1)) + ) ./ 2 +end + + +""" + mvnormlogpdf(μ::A, LorU::A, x::A; ϵ = 1f-8) where A <: AbstractArray + +Batch version that takes 3D tensors as input where each slice along the 3rd +dimension is a batch sample. `μ` is a (action_size x 1 x batch_size) matrix, +`L` is a (action_size x action_size x batch_size), x is a (action_size x +action_samples x batch_size). Return a 3D matrix of size (1 x action_samples x +batch_size). +""" +function mvnormlogpdf(μ::A, LorU::A, x::A; ϵ = 1.0f-8) where {A<:AbstractArray} + logp = [mvnormlogpdf(μ[:, :, k], LorU[:, :, k], x[:, :, k]) for k in 1:size(x, 3)] + return unsqueeze(stack(logp, 2), 1) #returns a 3D vector +end diff --git a/src/ReinforcementLearningCore/src/utils/printing.jl b/src/ReinforcementLearningCore/src/utils/printing.jl deleted file mode 100644 index d4e3cb87d..000000000 --- a/src/ReinforcementLearningCore/src/utils/printing.jl +++ /dev/null @@ -1,58 +0,0 @@ -using AbstractTrees -using Random -using ProgressMeter: Progress - -const AT = AbstractTrees - -struct StructTree{X} - x::X -end - -is_expand(x) = true -is_expand(::AbstractArray) = false -is_expand(::AbstractDict) = false -is_expand(::AbstractRNG) = false -is_expand(::Progress) = false -is_expand(::Function) = false -is_expand(::UnionAll) = false -is_expand(::DataType) = false - -function AT.children(t::StructTree{X}) where {X} - if is_expand(t.x) - Tuple(f => StructTree(getfield(t.x, f)) for f in fieldnames(X)) - else - () - end -end - -AT.children(t::Pair{Symbol,<:StructTree}) = children(last(t)) - -AT.printnode(io::IO, t::StructTree{T}) where {T} = print(io, T.name) -AT.printnode(io::IO, t::StructTree{<:Union{Number,Symbol}}) = print(io, t.x) -AT.printnode(io::IO, t::StructTree{UnionAll}) = print(io, t.x) -AT.printnode(io::IO, t::StructTree{<:AbstractArray}) = summary(io, t.x) - -function AT.printnode(io::IO, t::Pair{Symbol,<:StructTree}) - print(io, first(t), " => ") - AT.printnode(io, last(t)) -end - -function AT.printnode(io::IO, t::StructTree{String}) - s = t.x - i = findfirst('\n', s) - if isnothing(i) - if length(s) > 79 - print(io, "\"$(s[1:79])...\"") - else - print(io, "\"$s\"") - end - else - if i > 79 - print(io, "\"$(s[1:79])...\"") - else - print(io, "\"$(s[1:i-1])...\"") - end - end -end - -AT.printnode(io::IO, t::Pair{Symbol,<:StructTree{<:Tuple}}) = print(io, first(t)) diff --git a/src/ReinforcementLearningZoo/src/utils/reward_normalizer.jl b/src/ReinforcementLearningCore/src/utils/reward_normalizer.jl similarity index 85% rename from src/ReinforcementLearningZoo/src/utils/reward_normalizer.jl rename to src/ReinforcementLearningCore/src/utils/reward_normalizer.jl index 267b10598..1907cc285 100644 --- a/src/ReinforcementLearningZoo/src/utils/reward_normalizer.jl +++ b/src/ReinforcementLearningCore/src/utils/reward_normalizer.jl @@ -1,4 +1,3 @@ -export RewardNormalizer, ExpRewardNormalizer, AbstractRewardNormalizer abstract type AbstractRewardNormalizer end """ @@ -21,16 +20,17 @@ mutable struct RewardNormalizer{T} <: AbstractRewardNormalizer step_count::Int end -RewardNormalizer() = RewardNormalizer(0f0, 1f0, 1f0, 0) +RewardNormalizer() = RewardNormalizer(0.0f0, 1.0f0, 1.0f0, 0) function (rn::RewardNormalizer)(rewards; update = true) if update N = length(rewards) rn.step_count += N tmp_mean = rn.mean - rn.mean = (rn.step_count-N)/rn.step_count * rn.mean + sum(rewards)/rn.step_count + rn.mean = + (rn.step_count - N) / rn.step_count * rn.mean + sum(rewards) / rn.step_count rn.moment2 += sum((rewards .- tmp_mean) .* (rewards .- rn.mean)) - rn.std = max(sqrt(rn.moment2/(max(1,rn.step_count-1))), eps(rn.std)) + rn.std = max(sqrt(rn.moment2 / (max(1, rn.step_count - 1))), eps(rn.std)) end return (rewards .- rn.std) ./ rn.std end @@ -56,7 +56,7 @@ mutable struct ExpRewardNormalizer{T} <: AbstractRewardNormalizer first::Bool end -ExpRewardNormalizer(factor = 0.2f0) = ExpRewardNormalizer(0f0, 0f0, 0f0, factor, true) +ExpRewardNormalizer(factor = 0.2f0) = ExpRewardNormalizer(0.0f0, 0.0f0, 0.0f0, factor, true) function (rn::ExpRewardNormalizer)(rewards; update = true) if update @@ -69,5 +69,5 @@ function (rn::ExpRewardNormalizer)(rewards; update = true) rn.var = (1 - rn.factor) * (rn.var + rn.factor * sum(rewards .^ 2)) rn.std = sqrt(rn.var) end - return (rewards .- rn.std)./rn.std + return (rewards .- rn.std) ./ rn.std end \ No newline at end of file diff --git a/src/ReinforcementLearningCore/src/utils/processors.jl b/src/ReinforcementLearningCore/src/utils/stack_frames.jl similarity index 87% rename from src/ReinforcementLearningCore/src/utils/processors.jl rename to src/ReinforcementLearningCore/src/utils/stack_frames.jl index 4e6e2e85a..e482c61d4 100644 --- a/src/ReinforcementLearningCore/src/utils/processors.jl +++ b/src/ReinforcementLearningCore/src/utils/stack_frames.jl @@ -1,8 +1,6 @@ export StackFrames -import CircularArrayBuffers using CircularArrayBuffers: CircularArrayBuffer -using MacroTools: @forward """ StackFrames(::Type{T}=Float32, d::Int...) @@ -14,7 +12,8 @@ struct StackFrames{T,N} <: AbstractArray{T,N} buffer::CircularArrayBuffer{T,N} end -@forward StackFrames.buffer Base.size, Base.getindex +Base.size(x::StackFrames) = size(x.buffer) +Base.getindex(x::StackFrames, I...) = getindex(x.buffer, I...) Base.IndexStyle(x::StackFrames) = IndexStyle(x.buffer) StackFrames(d::Int...) = StackFrames(Float32, d...) @@ -41,5 +40,5 @@ only the latest frame is pushed. If the `StackFrames` is one dimension lower, then it is treated as a general `AbstractArray` and is pushed in as a frame. """ function Base.push!(cb::CircularArrayBuffer{T,N}, p::StackFrames{T,N}) where {T,N} - push!(cb, select_last_frame(p.buffer)) + push!(cb, selectdim(p.buffer, N, size(p.buffer, N))) end diff --git a/src/ReinforcementLearningCore/src/utils/sum_tree.jl b/src/ReinforcementLearningCore/src/utils/sum_tree.jl deleted file mode 100644 index 0ab67f4ea..000000000 --- a/src/ReinforcementLearningCore/src/utils/sum_tree.jl +++ /dev/null @@ -1,168 +0,0 @@ -export capacity, sample, SumTree - -using Random -import StatsBase: sample - -""" - SumTree(capacity::Int) -Efficiently sample and update weights. -For more details, see the post at [here](https://jaromiru.com/2016/11/07/lets-make-a-dqn-double-learning-and-prioritized-experience-replay/). -Here we use a vector to represent the binary tree. -Suppose we will have `capacity` leaves at most. -Every time we `push!` new node into the tree, only the recent `capacity` node and their sum will be updated! -[------------Parent nodes------------][--------leaves--------] -[size: 2^ceil(Int, log2(capacity))-1 ][ size: capacity ] -# Example -```julia -julia> t = SumTree(8) -0-element SumTree -julia> for i in 1:16 - push!(t, i) - end -julia> t -8-element SumTree: - 9.0 - 10.0 - 11.0 - 12.0 - 13.0 - 14.0 - 15.0 - 16.0 -julia> sample(t) -(2, 10.0) -julia> sample(t) -(1, 9.0) -julia> inds, ps = sample(t,100000) -([8, 4, 8, 1, 5, 2, 2, 7, 6, 6 … 1, 1, 7, 1, 6, 1, 5, 7, 2, 7], [16.0, 12.0, 16.0, 9.0, 13.0, 10.0, 10.0, 15.0, 14.0, 14.0 … 9.0, 9.0, 15.0, 9.0, 14.0, 9.0, 13.0, 15.0, 10.0, 15.0]) -julia> countmap(inds) -Dict{Int64,Int64} with 8 entries: - 7 => 14991 - 4 => 12019 - 2 => 10003 - 3 => 11027 - 5 => 12971 - 8 => 16052 - 6 => 13952 - 1 => 8985 -julia> countmap(ps) -Dict{Float64,Int64} with 8 entries: - 9.0 => 8985 - 13.0 => 12971 - 10.0 => 10003 - 14.0 => 13952 - 16.0 => 16052 - 11.0 => 11027 - 15.0 => 14991 - 12.0 => 12019 -``` -""" -mutable struct SumTree{T} <: AbstractArray{Int,1} - capacity::Int - first::Int - length::Int - nparents::Int - tree::Vector{T} - SumTree(capacity::Int) = SumTree(Float32, capacity) - function SumTree(T, capacity) - nparents = 2^ceil(Int, log2(capacity)) - 1 - new{T}(capacity, 1, 0, nparents, zeros(T, nparents + capacity)) - end -end - -capacity(t::SumTree) = t.capacity -Base.length(t::SumTree) = t.length -Base.size(t::SumTree) = (length(t),) -Base.eltype(t::SumTree{T}) where {T} = T - -function _index(t::SumTree, i::Int) - ind = i + t.first - 1 - if ind > t.capacity - ind -= t.capacity - end - ind -end - -_tree_index(t::SumTree, i) = t.nparents + _index(t, i) - -Base.getindex(t::SumTree, i::Int) = t.tree[_tree_index(t, i)] - -function Base.setindex!(t::SumTree, p, i) - tree_ind = _tree_index(t, i) - change = p - t.tree[tree_ind] - t.tree[tree_ind] = p - while tree_ind != 1 - tree_ind = tree_ind ÷ 2 - t.tree[tree_ind] += change - end -end - -function Base.push!(t::SumTree, p) - if t.length == t.capacity - t.first = (t.first == t.capacity ? 1 : t.first + 1) - else - t.length += 1 - end - t[t.length] = p -end - -function Base.pop!(t::SumTree) - if t.length > 0 - res = t[end] - t.length -= 1 - res - else - @error "can not pop! from an empty SumTree" - end -end - -function Base.empty!(t::SumTree) - t.length = 0.0 - fill!(t.tree, 0.0) - # yes, no need to reset `t.first` - # so, don't rely on that `t.first` is always 1 after `empty!` - t -end - -function Base.get(t::SumTree, v) - parent_ind = 1 - leaf_ind = parent_ind - while true - left_child_ind = parent_ind * 2 - right_child_ind = left_child_ind + 1 - if left_child_ind > length(t.tree) - leaf_ind = parent_ind - break - else - if v ≤ t.tree[left_child_ind] - parent_ind = left_child_ind - else - v -= t.tree[left_child_ind] - parent_ind = right_child_ind - end - end - end - if leaf_ind <= t.nparents - leaf_ind += t.capacity - end - p = t.tree[leaf_ind] - ind = leaf_ind - t.nparents - real_ind = ind >= t.first ? ind - t.first + 1 : ind + t.capacity - t.first + 1 - real_ind, p -end - -sample(rng::AbstractRNG, t::SumTree{T}) where {T} = get(t, rand(rng, T) * t.tree[1]) -sample(t::SumTree) = sample(Random.GLOBAL_RNG, t) - -function sample(rng::AbstractRNG, t::SumTree{T}, n::Int) where {T} - inds, priorities = Vector{Int}(undef, n), Vector{Float64}(undef, n) - for i in 1:n - v = (i - 1 + rand(rng, T)) / n - ind, p = get(t, v * t.tree[1]) - inds[i] = ind - priorities[i] = p - end - inds, priorities -end - -sample(t::SumTree, n::Int) = sample(Random.GLOBAL_RNG, t, n) diff --git a/src/ReinforcementLearningCore/src/utils/utils.jl b/src/ReinforcementLearningCore/src/utils/utils.jl index 529c0028e..19b6a0159 100644 --- a/src/ReinforcementLearningCore/src/utils/utils.jl +++ b/src/ReinforcementLearningCore/src/utils/utils.jl @@ -1,5 +1,5 @@ -include("printing.jl") -include("base.jl") +include("basic.jl") include("device.jl") -include("sum_tree.jl") -include("processors.jl") +include("stack_frames.jl") +include("distributions.jl") +include("reward_normalizer.jl") diff --git a/src/ReinforcementLearningCore/test/components/agents.jl b/src/ReinforcementLearningCore/test/components/agents.jl deleted file mode 100644 index 55e80e090..000000000 --- a/src/ReinforcementLearningCore/test/components/agents.jl +++ /dev/null @@ -1 +0,0 @@ -@testset "Agent" begin end diff --git a/src/ReinforcementLearningCore/test/components/approximators.jl b/src/ReinforcementLearningCore/test/components/approximators.jl deleted file mode 100644 index 8386c37b9..000000000 --- a/src/ReinforcementLearningCore/test/components/approximators.jl +++ /dev/null @@ -1,397 +0,0 @@ -@testset "Approximators" begin - - @testset "TabularApproximator" begin - A = TabularVApproximator(; n_state = 2, opt = InvDecay(1.0)) - - @test A(1) == 0.0 - @test A(2) == 0.0 - - update!(A, 2 => A(2) - 3.0) - @test A(2) == 1.5 - update!(A, 2 => A(2) - 6.0) - @test A(2) == 3.0 - end - - @testset "NeuralNetworkApproximator" begin - NN = NeuralNetworkApproximator(; model = Dense(2, 3), optimizer = Descent()) - - q_values = NN(rand(2)) - @test size(q_values) == (3,) - - gs = gradient(params(NN)) do - sum(NN(rand(2, 5))) - end - - old_params = deepcopy(collect(params(NN).params)) - update!(NN, gs) - new_params = collect(params(NN).params) - - @test old_params != new_params - end - - @testset "ActorCritic" begin - ac_cpu = ActorCritic( - actor = NeuralNetworkApproximator(model = Dense(3, 2)), - critic = NeuralNetworkApproximator(model = Dense(3, 1)), - ) - - ac = ac_cpu |> gpu - - # make sure optimizer is not changed - @test ac_cpu.optimizer === ac.optimizer - - D = ac.actor.model |> gpu |> device - @test D === device(ac) === device(ac.actor) == device(ac.critic) - - A = send_to_device(D, rand(3)) - ac.actor(A) - ac.critic(A) - end - - @testset "GaussianNetwork" begin - @testset "identity normalizer" begin - pre = Dense(20,15) - μ = Dense(15,10) - logσ = Dense(15,10) - gn = GaussianNetwork(pre, μ, logσ, identity) - @test Flux.params(gn) == Flux.Params([pre.W, pre.b, μ.W, μ.b, logσ.W, logσ.b]) - state = rand(20,3) #batch of 3 states - m, L = gn(state) - @test size(m) == size(L) == (10,3) - a, logp = gn(state, is_sampling = true, is_return_log_prob = true) - @test size(a) == (10,3) - @test size(logp) == (1,3) - @test logp ≈ sum(normlogpdf(m, exp.(L), a) .- (2.0f0 .* (log(2.0f0) .- a .- softplus.(-2.0f0 .* a))), dims = 1) - @test logp ≈ gn(state, a) - as, logps = gn(Flux.unsqueeze(state,2), 5) #sample 5 actions - @test size(as) == (10,5,3) - @test size(logps) == (1,5,3) - logps2 = gn(Flux.unsqueeze(state,2), as) - @test logps2 ≈ logps - action_saver = [] - g = Flux.gradient(Flux.params(gn)) do - a, logp = gn(state, is_sampling = true, is_return_log_prob = true) - Flux.Zygote.ignore() do - push!(action_saver, a) - end - sum(logp) - end - g2 = Flux.gradient(Flux.params(gn)) do - logp = gn(state, only(action_saver)) - sum(logp) - end - #Check that gradients are identical - for (grad1, grad2) in zip(g,g2) - @test grad1 ≈ grad2 - end - #Same with multiple actions sampled - empty!(action_saver) - g = Flux.gradient(Flux.params(gn)) do - a, logp = gn(state, 3) - Flux.Zygote.ignore() do - push!(action_saver, a) - end - sum(logp) - end - g2 = Flux.gradient(Flux.params(gn)) do - logp = gn(state, only(action_saver)) - sum(logp) - end - for (grad1, grad2) in zip(g,g2) - @test grad1 ≈ grad2 - end - end - @testset "tanh normalizer" begin - pre = Dense(20,15) - μ = Dense(15,10) - logσ = Dense(15,10) - gn = GaussianNetwork(pre, μ, logσ) - @test Flux.params(gn) == Flux.Params([pre.W, pre.b, μ.W, μ.b, logσ.W, logσ.b]) - state = rand(20,3) #batch of 3 states - m, L = gn(state) - @test size(m) == size(L) == (10,3) - a, logp = gn(state, is_sampling = true, is_return_log_prob = true) - @test size(a) == (10,3) - @test size(logp) == (1,3) - @test logp ≈ sum(normlogpdf(m, exp.(L), a) .- (2.0f0 .* (log(2.0f0) .- a .- softplus.(-2.0f0 .* a))), dims = 1) - @test logp ≈ gn(state, a) - as, logps = gn(Flux.unsqueeze(state,2), 5) #sample 5 actions - @test size(as) == (10,5,3) - @test size(logps) == (1,5,3) - logps2 = gn(Flux.unsqueeze(state,2), as) - @test logps2 ≈ logps - action_saver = [] - g = Flux.gradient(Flux.params(gn)) do - a, logp = gn(state, is_sampling = true, is_return_log_prob = true) - Flux.Zygote.ignore() do - push!(action_saver, a) - end - sum(logp) - end - g2 = Flux.gradient(Flux.params(gn)) do - logp = gn(state, only(action_saver)) - sum(logp) - end - #Check that gradients are identical - for (grad1, grad2) in zip(g,g2) - @test grad1 ≈ grad2 - end - #Same with multiple actions sampled - empty!(action_saver) - g = Flux.gradient(Flux.params(gn)) do - a, logp = gn(state, 3) - Flux.Zygote.ignore() do - push!(action_saver, a) - end - sum(logp) - end - g2 = Flux.gradient(Flux.params(gn)) do - logp = gn(state, only(action_saver)) - sum(logp) - end - for (grad1, grad2) in zip(g,g2) - @test grad1 ≈ grad2 - end - end - @testset "CUDA" begin - if CUDA.functional() - pre = Dense(20,15) |> gpu - μ = Dense(15,10) |> gpu - logσ = Dense(15,10) |> gpu - gn = GaussianNetwork(pre, μ, logσ) - @test Flux.params(gn) == Flux.Params([pre.W, pre.b, μ.W, μ.b, logσ.W, logσ.b]) - state = rand(20,3) |> gpu #batch of 3 states - m, L = gn(state) - @test size(m) == size(L) == (10,3) - a, logp = gn(CUDA.CURAND.RNG(), state, is_sampling = true, is_return_log_prob = true) - @test size(a) == (10,3) - @test size(logp) == (1,3) - @test logp ≈ sum(normlogpdf(m, exp.(L), a) .- (2.0f0 .* (log(2.0f0) .- a .- softplus.(-2.0f0 .* a))), dims = 1) - @test logp ≈ gn(state, a) - as, logps = gn(CUDA.CURAND.RNG(), Flux.unsqueeze(state,2), 5) #sample 5 actions - @test size(as) == (10,5,3) - @test size(logps) == (1,5,3) - logps2 = gn(Flux.unsqueeze(state,2), as) - @test logps2 ≈ logps - action_saver = [] - g = Flux.gradient(Flux.params(gn)) do - a, logp = gn(CUDA.CURAND.RNG(), state, is_sampling = true, is_return_log_prob = true) - Flux.Zygote.ignore() do - push!(action_saver, a) - end - sum(logp) - end - g2 = Flux.gradient(Flux.params(gn)) do - logp = gn(state, only(action_saver)) - sum(logp) - end - #Check that gradients are identical - for (grad1, grad2) in zip(g,g2) - @test grad1 ≈ grad2 - end - #Same with multiple actions sampled - empty!(action_saver) - g = Flux.gradient(Flux.params(gn)) do - a, logp = gn(CUDA.CURAND.RNG(), state, 3) - Flux.Zygote.ignore() do - push!(action_saver, a) - end - sum(logp) - end - g2 = Flux.gradient(Flux.params(gn)) do - logp = gn(state, only(action_saver)) - sum(logp) - end - for (grad1, grad2) in zip(g,g2) - @test grad1 ≈ grad2 - end - end - end - end - @testset "CovGaussianNetwork" begin - @testset "identity normalizer" begin - pre = Dense(20,15) - μ = Dense(15,10) - Σ = Dense(15,10*11÷2) - gn = CovGaussianNetwork(pre, μ, Σ, identity) - @test Flux.params(gn) == Flux.Params([pre.W, pre.b, μ.W, μ.b, Σ.W, Σ.b]) - state = rand(20,3) #batch of 3 states - #Check that it works in 2D - m, L = gn(state) - @test size(m) == (10,3) - @test size(L) == (10, 10,3) - a, logp = gn(state, is_sampling = true, is_return_log_prob = true) - @test size(a) == (10,3) - @test size(logp) == (1,3) - logp2d = gn(state,a) - @test size(logp2d) == (1,3) - #rest is 3D - m, L = gn(Flux.unsqueeze(state,2)) - @test size(m) == (10,1,3) - @test size(L) == (10, 10,3) - a, logp = gn(Flux.unsqueeze(state,2), is_sampling = true, is_return_log_prob = true) - @test size(a) == (10,1,3) - @test size(logp) == (1,1,3) - - @test logp ≈ mvnormlogpdf(m, L, a) - @test logp ≈ gn(Flux.unsqueeze(state,2), a) - as, logps = gn(Flux.unsqueeze(state,2), 5) #sample 5 actions - @test size(as) == (10,5,3) - @test size(logps) == (1,5,3) - logps2 = gn(Flux.unsqueeze(state,2), as) - @test logps2 ≈ logps - s = Flux.stack(map(l -> l*l', eachslice(L, dims=3)),3) - mvnormals = map(z -> MvNormal(Array(vec(z[1])), Array(z[2])), zip(eachslice(m, dims = 3), eachslice(s, dims = 3))) - logp_truth = [logpdf(mvn, a) for (mvn, a) in zip(mvnormals, eachslice(as, dims = 3))] - @test Flux.stack(logp_truth,2) ≈ dropdims(logps,dims = 1) #test against ground truth - action_saver = [] - g = Flux.gradient(Flux.params(gn)) do - a, logp = gn(Flux.unsqueeze(state,2), is_sampling = true, is_return_log_prob = true) - Flux.Zygote.ignore() do - push!(action_saver, a) - end - mean(logp) - end - g2 = Flux.gradient(Flux.params(gn)) do - logp = gn(Flux.unsqueeze(state,2), only(action_saver)) - mean(logp) - end - for (grad1, grad2) in zip(g,g2) - @test grad1 ≈ grad2 - end - empty!(action_saver) - g3 = Flux.gradient(Flux.params(gn)) do - a, logp = gn(Flux.unsqueeze(state,2), 3) - Flux.Zygote.ignore() do - push!(action_saver, a) - end - mean(logp) - end - g4 = Flux.gradient(Flux.params(gn)) do - logp = gn(Flux.unsqueeze(state,2), only(action_saver)) - mean(logp) - end - for (grad1, grad2) in zip(g4,g3) - @test grad1 ≈ grad2 - end - end - @testset "tanh normalizer" begin - pre = Dense(20,15) - μ = Dense(15,10) - Σ = Dense(15,10*11÷2) - gn = CovGaussianNetwork(pre, μ, Σ) - @test Flux.params(gn) == Flux.Params([pre.W, pre.b, μ.W, μ.b, Σ.W, Σ.b]) - state = rand(20,3) #batch of 3 states - m, L = gn(Flux.unsqueeze(state,2)) - @test size(m) == (10,1,3) - @test size(L) == (10, 10,3) - a, logp = gn(Flux.unsqueeze(state,2), is_sampling = true, is_return_log_prob = true) - @test size(a) == (10,1,3) - @test size(logp) == (1,1,3) - - @test logp ≈ mvnormlogpdf(m, L, a) - @test logp ≈ gn(Flux.unsqueeze(state,2), a) - as, logps = gn(Flux.unsqueeze(state,2), 5) #sample 5 actions - @test size(as) == (10,5,3) - @test size(logps) == (1,5,3) - logps2 = gn(Flux.unsqueeze(state,2), as) - @test logps2 ≈ logps - s = Flux.stack(map(l -> l*l', eachslice(L, dims=3)),3) - mvnormals = map(z -> MvNormal(Array(vec(z[1])), Array(z[2])), zip(eachslice(m, dims = 3), eachslice(s, dims = 3))) - logp_truth = [logpdf(mvn, a) for (mvn, a) in zip(mvnormals, eachslice(as, dims = 3))] - @test Flux.stack(logp_truth,2) ≈ dropdims(logps,dims = 1) #test against ground truth - action_saver = [] - g = Flux.gradient(Flux.params(gn)) do - a, logp = gn(Flux.unsqueeze(state,2), is_sampling = true, is_return_log_prob = true) - Flux.Zygote.ignore() do - push!(action_saver, a) - end - mean(logp) - end - g2 = Flux.gradient(Flux.params(gn)) do - logp = gn(Flux.unsqueeze(state,2), only(action_saver)) - mean(logp) - end - for (grad1, grad2) in zip(g,g2) - @test grad1 ≈ grad2 - end - empty!(action_saver) - g3 = Flux.gradient(Flux.params(gn)) do - a, logp = gn(Flux.unsqueeze(state,2), 3) - Flux.Zygote.ignore() do - push!(action_saver, a) - end - mean(logp) - end - g4 = Flux.gradient(Flux.params(gn)) do - logp = gn(Flux.unsqueeze(state,2), only(action_saver)) - mean(logp) - end - for (grad1, grad2) in zip(g4,g3) - @test grad1 ≈ grad2 - end - end - @testset "CUDA" begin - if CUDA.functional() - CUDA.allowscalar(false) - rng = CUDA.CURAND.RNG() - pre = Dense(20,15) |> gpu - μ = Dense(15,10) |> gpu - Σ = Dense(15,10*11÷2) |> gpu - gn = CovGaussianNetwork(pre, μ, Σ, identity) - @test Flux.params(gn) == Flux.Params([pre.W, pre.b, μ.W, μ.b, Σ.W, Σ.b]) - state = rand(20,3)|> gpu #batch of 3 states - m, L = gn(Flux.unsqueeze(state,2)) - @test size(m) == (10,1,3) - @test size(L) == (10, 10,3) - a, logp = gn(rng, Flux.unsqueeze(state,2), is_sampling = true, is_return_log_prob = true) - @test size(a) == (10,1,3) - @test size(logp) == (1,1,3) - - @test logp ≈ mvnormlogpdf(m, L, a) - @test logp ≈ gn(Flux.unsqueeze(state,2), a) - as, logps = gn(rng,Flux.unsqueeze(state,2), 5) #sample 5 actions - @test size(as) == (10,5,3) - @test size(logps) == (1,5,3) - logps2 = gn(Flux.unsqueeze(state,2), as) - @test logps2 ≈ logps - s = Flux.stack(map(l -> l*l', eachslice(L, dims=3)),3) - mvnormals = map(z -> MvNormal(Array(vec(z[1])), Array(z[2])), zip(eachslice(m, dims = 3), eachslice(s, dims = 3))) - logp_truth = [logpdf(mvn, cpu(a)) for (mvn, a) in zip(mvnormals, eachslice(as, dims = 3))] - @test Flux.stack(logp_truth,2) ≈ dropdims(cpu(logps),dims = 1) #test against ground truth - action_saver = [] - g = Flux.gradient(Flux.params(gn)) do - a, logp = gn(rng, Flux.unsqueeze(state,2), is_sampling = true, is_return_log_prob = true) - Flux.Zygote.ignore() do - push!(action_saver, a) - end - mean(logp) - end - - g2 = Flux.gradient(Flux.params(gn)) do - logp = gn(Flux.unsqueeze(state,2), only(action_saver)) - mean(logp) - end - for (grad1, grad2) in zip(g,g2) - @test grad1 ≈ grad2 - end - empty!(action_saver) - g3 = Flux.gradient(Flux.params(gn)) do - a, logp = gn(rng, Flux.unsqueeze(state,2), 3) - Flux.Zygote.ignore() do - push!(action_saver, a) - end - mean(logp) - end - g4 = Flux.gradient(Flux.params(gn)) do - logp = gn(Flux.unsqueeze(state,2), only(action_saver)) - mean(logp) - end - for (grad1, grad2) in zip(g4,g3) - @test grad1 ≈ grad2 - end - CUDA.allowscalar(true) #to avoid breaking other tests - end - end - end -end diff --git a/src/ReinforcementLearningCore/test/components/components.jl b/src/ReinforcementLearningCore/test/components/components.jl deleted file mode 100644 index bcc448131..000000000 --- a/src/ReinforcementLearningCore/test/components/components.jl +++ /dev/null @@ -1,5 +0,0 @@ -include("processors.jl") -include("approximators.jl") -include("explorers.jl") -include("trajectories.jl") -include("agents.jl") diff --git a/src/ReinforcementLearningCore/test/components/explorers.jl b/src/ReinforcementLearningCore/test/components/explorers.jl deleted file mode 100644 index 449889909..000000000 --- a/src/ReinforcementLearningCore/test/components/explorers.jl +++ /dev/null @@ -1,111 +0,0 @@ -@testset "explorers" begin - - @testset "EpsilonGreedyExplorer" begin - @testset "API" begin - explorer = EpsilonGreedyExplorer(0.1; is_break_tie = true) - Random.seed!(explorer, 123) - - values = [0, 1, 2, -1] - tarprob = [0.025, 0.025, 0.925, 0.025] - - # https://github.com/JuliaLang/julia/issues/10391#issuecomment-488642687 - # @test isapprox(prob(explorer, values), tarprob) - @test isapprox(probs(prob(explorer, values)), tarprob) - - actions = [explorer(values) for _ in 1:10000] - action_counts = countmap(actions) - - @test all( - isapprox.( - [action_counts[i] for i in 1:length(values)] ./ 10000, - tarprob; - atol = 0.005, - ), - ) - end - - @testset "linear" begin - explorer = EpsilonGreedyExplorer(; - ϵ_stable = 0.1, - ϵ_init = 0.9, - warmup_steps = 3, - decay_steps = 8, - kind = :linear, - is_break_tie = true, - ) - xs = [0, 1, 2, -1, 2] - mask = [true, true, false, true, false] - E = [0.9, 0.9, range(0.9; stop = 0.1, step = -0.1)..., 0.1, 0.1, 0.1, 0.1] - - for ϵ in E - @test RLCore.get_ϵ(explorer) ≈ ϵ - @test isapprox( - probs(prob(explorer, xs)), - [ϵ / 5, ϵ / 5, ϵ / 5 + (1 - ϵ) / 2, ϵ / 5, ϵ / 5 + (1 - ϵ) / 2], - ) - explorer(xs) - end - - explorer = EpsilonGreedyExplorer(; - ϵ_stable = 0.1, - ϵ_init = 0.9, - warmup_steps = 3, - decay_steps = 8, - kind = :linear, - is_break_tie = true, - ) - for ϵ in E - @test RLCore.get_ϵ(explorer) ≈ ϵ - @test isapprox( - probs(prob(explorer, xs, mask)), - [ϵ / 3, (1 - ϵ) + ϵ / 3, 0.0, ϵ / 3, 0.0], - ) - explorer(xs) - end - - explorer = EpsilonGreedyExplorer(; - ϵ_stable = 0.1, - ϵ_init = 0.9, - warmup_steps = 3, - decay_steps = 8, - kind = :linear, - is_break_tie = true, - ) - for i in 1:100 - @test mask[explorer(xs, mask)] - end - end - - @testset "exp" begin - explorer = EpsilonGreedyExplorer(; - ϵ_stable = 0.1, - ϵ_init = 0.9, - warmup_steps = 3, - decay_steps = 8, - kind = :exp, - is_break_tie = true, - ) - xs = [0, 1, 2, -1, 2] - mask = [true, true, false, true, false] - for i in 1:10 - explorer(xs) - end - ϵ = 0.1 + (0.9 - 0.1) * exp(-1) - @test isapprox( - probs(prob(explorer, xs)), - [ϵ / 5, ϵ / 5, ϵ / 5 + (1 - ϵ) / 2, ϵ / 5, ϵ / 5 + (1 - ϵ) / 2], - ) - - for i in 1:100 - explorer(xs) - end - ϵ = 0.1 - @test isapprox( - probs(prob(explorer, xs)), - [ϵ / 5, ϵ / 5, ϵ / 5 + (1 - ϵ) / 2, ϵ / 5, ϵ / 5 + (1 - ϵ) / 2]; - atol = 1e-5, - ) - end - end - -end diff --git a/src/ReinforcementLearningCore/test/components/processors.jl b/src/ReinforcementLearningCore/test/components/processors.jl deleted file mode 100644 index 36cf3223c..000000000 --- a/src/ReinforcementLearningCore/test/components/processors.jl +++ /dev/null @@ -1,14 +0,0 @@ -@testset "preprocessors" begin - @testset "StackFrames" begin - A = ones(2, 2) - p = StackFrames(2, 2, 3) - - for i in 1:3 - p(A * i) - end - - state = A * 4 - @test p(state) == reshape(repeat([2, 3, 4]; inner = 4), 2, 2, :) - - end -end diff --git a/src/ReinforcementLearningCore/test/components/trajectories.jl b/src/ReinforcementLearningCore/test/components/trajectories.jl deleted file mode 100644 index 8fb8eb9ae..000000000 --- a/src/ReinforcementLearningCore/test/components/trajectories.jl +++ /dev/null @@ -1,104 +0,0 @@ -@testset "traces" begin - @testset "Trajectory" begin - t = Trajectory(; state = Vector{Int}(), reward = Vector{Bool}()) - @test (:state, :reward) == keys(t) - @test haskey(t, :state) - @test haskey(t, :reward) - push!(t; state = 3, reward = true) - push!(t; state = 4, reward = false) - @test t[:state] == [3, 4] - @test t[:reward] == [true, false] - pop!(t) - @test t[:state] == [3] - @test t[:reward] == [true] - empty!(t) - @test t[:state] == Int[] - @test t[:reward] == Bool[] - end - - @testset "CircularArraySARTTrajectory" begin - t = CircularArraySARTTrajectory(; - capacity = 3, - state = Vector{Int} => (4,), - action = Int => (), - reward = Float32 => (), - terminal = Bool => (), - ) - - @test length(t) == 0 - push!(t; state = ones(Int, 4), action = 1) - @test length(t) == 0 - push!(t; reward = 1.0f0, terminal = false, state = 2 * ones(Int, 4), action = 2) - @test length(t) == 1 - - @test t[:state] == hcat(ones(Int, 4), 2 * ones(Int, 4)) - - push!(t; reward = 2.0f0, terminal = false, state = 3 * ones(Int, 4), action = 3) - @test length(t) == 2 - - push!(t; reward = 3.0f0, terminal = false, state = 4 * ones(Int, 4), action = 4) - @test length(t) == 3 - @test t[:state] == [j for i in 1:4, j in 1:4] - @test t[:reward] == [1, 2, 3] - - # test circle works as expected - push!(t; reward = 4.0f0, terminal = true, state = 5 * ones(Int, 4), action = 5) - @test length(t) == 3 - @test t[:state] == [j for i in 1:4, j in 2:5] - @test t[:reward] == [2, 3, 4] - end - - @testset "CircularArraySLARTTrajectory" begin - t = CircularArraySLARTTrajectory( - capacity = 3, - state = Vector{Int} => (4,), - legal_actions_mask = Vector{Bool} => (4, ), - ) - - # test instance type is same as type - @test isa(t, CircularArraySLARTTrajectory) - - @test length(t) == 0 - push!(t; state = ones(Int, 4), action = 1, legal_actions_mask = trues(4)) - @test length(t) == 0 - push!(t; reward = 1.0f0, terminal = false) - @test length(t) == 1 - end - - @testset "ReservoirTrajectory" begin - # test length - t = ReservoirTrajectory(3; a = Array{Float64,2}, b = Bool) - push!(t; a = rand(2, 3), b = rand(Bool)) - @test length(t) == 1 - push!(t; a = rand(2, 3), b = rand(Bool)) - @test length(t) == 2 - push!(t; a = rand(2, 3), b = rand(Bool)) - @test length(t) == 3 - - for _ in 1:100 - push!(t; a = rand(2, 3), b = rand(Bool)) - end - - @test length(t) == 3 - - # test distribution - - Random.seed!(110) - k, n, N = 3, 10, 10000 - stats = Dict(i => 0 for i in 1:n) - for _ in 1:N - t = ReservoirTrajectory(k; a = Array{Int,2}, b = Int) - for i in 1:n - push!(t; a = i .* ones(Int, 2, 3), b = i) - end - - for i in 1:length(t) - stats[t[:b][i]] += 1 - end - end - - for v in values(stats) - @test isapprox(v / N, k / n; atol = 0.03) - end - end -end diff --git a/src/ReinforcementLearningCore/test/core.jl b/src/ReinforcementLearningCore/test/core.jl new file mode 100644 index 000000000..a8f8de31a --- /dev/null +++ b/src/ReinforcementLearningCore/test/core.jl @@ -0,0 +1,40 @@ +@testset "core" begin + @testset "simple workflow" begin + @testset "StopAfterStep" begin + agent = Agent( + RandomPolicy(), + Trajectory( + CircularArraySARTTraces(; capacity=1_000), + BatchSampler(1), + InsertSampleRatioController( + n_inserted=-1, + )), + ) + env = RandomWalk1D() + stop_condition = StopAfterStep(123) + hook = StepsPerEpisode() + run(agent, env, stop_condition, hook) + + @test sum(hook[]) == length(agent.trajectory.container) + end + + @testset "StopAfterEpisode" begin + agent = Agent( + RandomPolicy(), + Trajectory( + CircularArraySARTTraces(; capacity=1_000), + BatchSampler(1), + InsertSampleRatioController( + n_inserted=-1, + ) + ), + ) + env = RandomWalk1D() + stop_condition = StopAfterEpisode(10) + hook = StepsPerEpisode() + run(agent, env, stop_condition, hook) + + @test sum(hook[]) == length(agent.trajectory.container) + end + end +end \ No newline at end of file diff --git a/src/ReinforcementLearningCore/test/core/core.jl b/src/ReinforcementLearningCore/test/core/core.jl deleted file mode 100644 index fb6f5fde5..000000000 --- a/src/ReinforcementLearningCore/test/core/core.jl +++ /dev/null @@ -1,22 +0,0 @@ -@testset "simple workflow" begin - env = StateTransformedEnv(CartPoleEnv{Float32}();state_mapping=deepcopy) - policy = RandomPolicy(action_space(env)) - N_EPISODE = 10_000 - hook = TotalRewardPerEpisode() - run(policy, env, StopAfterEpisode(N_EPISODE), hook) - - @test isapprox(sum(hook[]) / N_EPISODE, 21; atol=2) -end - -@testset "multi agent" begin - # https://github.com/JuliaReinforcementLearning/ReinforcementLearning.jl/issues/393 - rps = RockPaperScissorsEnv() |> SequentialEnv - ma_policy = MultiAgentManager( - ( - NamedPolicy(p => RandomPolicy()) - for p in players(rps) - )... - ) - - run(ma_policy, rps, StopAfterEpisode(10)) -end diff --git a/src/ReinforcementLearningCore/test/core/hooks.jl b/src/ReinforcementLearningCore/test/core/hooks.jl deleted file mode 100644 index 02f63197b..000000000 --- a/src/ReinforcementLearningCore/test/core/hooks.jl +++ /dev/null @@ -1,10 +0,0 @@ -let stages = (POST_EPISODE_STAGE, PRE_EPISODE_STAGE) - @testset "DoEveryNEpisode stage=$(stage),s2=$(s2)" for stage in stages, s2 in stages - hook = DoEveryNEpisode((x...) -> true; stage) - if stage === s2 - @test hook(stage, nothing, nothing) - else - @test hook(s2, nothing, nothing) === nothing - end - end -end diff --git a/src/ReinforcementLearningCore/test/core/stop_conditions_test.jl b/src/ReinforcementLearningCore/test/core/stop_conditions_test.jl deleted file mode 100644 index a2d657fa1..000000000 --- a/src/ReinforcementLearningCore/test/core/stop_conditions_test.jl +++ /dev/null @@ -1,25 +0,0 @@ -@testset "test StopAfterNoImprovement" begin - env = StateTransformedEnv(CartPoleEnv{Float32}();state_mapping=deepcopy) - policy = RandomPolicy(action_space(env)) - - total_reward_per_episode = TotalRewardPerEpisode() - patience = 30 - stop_condition = - StopAfterNoImprovement(() -> total_reward_per_episode.reward, patience, 0.0f0) - - # stop_condition is called between POST_ACT_STAGE & POST_EPISODE_STAGE. - # total_reward_per_episode.rewards is updated at POST_EPISODE_STAGE. - # total_reward_per_episode.reward is updated at POST_ACT_STAGE. - # so the latter one should be used. or the value is from the previous episode. - hook = ComposedHook(total_reward_per_episode) - run(policy, env, stop_condition, hook) - - @test argmax(total_reward_per_episode.rewards) + patience == length(total_reward_per_episode.rewards) -end - -@testset "StopAfterNSeconds" begin - s = StopAfterNSeconds(0.01) - @test !s() - sleep(0.02) - @test s() -end diff --git a/src/ReinforcementLearningCore/test/extensions.jl b/src/ReinforcementLearningCore/test/extensions.jl deleted file mode 100644 index da5606de0..000000000 --- a/src/ReinforcementLearningCore/test/extensions.jl +++ /dev/null @@ -1,95 +0,0 @@ -@testset "Zygote" begin - grads = IdDict() - grads[:x] = [-3.0 0.0 0.0; 4.0 0.0 0.0] - ps = Zygote.Params([:x]) - gs = Zygote.Grads(grads, ps) - clip_by_global_norm!(gs, ps, 4.0f0) - @test isapprox(gs[:x], [-2.4 0.0 0.0; 3.2 0.0 0.0]) - - gs.grads[:x] = [1.0 0.0 0.0; 1.0 0.0 0.0] - clip_by_global_norm!(gs, ps, 4.0f0) - @test isapprox(gs[:x], [1.0 0.0 0.0; 1.0 0.0 0.0]) - - gs.grads[:x] = [0.0 0.0 0.0; 0.0 0.0 0.0] - clip_by_global_norm!(gs, ps, 4.0f0) - @test isapprox(gs[:x], [0.0 0.0 0.0; 0.0 0.0 0.0]) -end - - -@testset "Distributions" begin - @testset "normlogpdf" begin - @test isapprox(logpdf(Normal(), 2), normlogpdf(0, 1, 2)) - @test isapprox( - logpdf.([Normal(), Normal()], [2, 10]), - normlogpdf([0, 0], [1, 1], [2, 10]), - ) - - # Test numeric stability for 0 sigma - @test isnan(normlogpdf(0, 0, 2, ϵ = 0)) - @test !isnan(normlogpdf(0, 0, 2)) - - if CUDA.functional() - cpu_grad = Zygote.gradient([0.2, 0.5]) do x - sum(logpdf.([Normal(1, 0.1), Normal(2, 0.2)], x)) - end - gpu_grad = Zygote.gradient(cu([0.2, 0.5])) do x - sum(normlogpdf(cu([1, 2]), cu([0.1, 0.2]), x)) - end - @test isapprox(cpu_grad[1], gpu_grad[1] |> Array) - end - end - @testset "mvnormlogpdf" begin - softplus(x) = log(1 + exp(x)) - #2D,CPU - μ = rand(5,1) - L = tril(softplus.(rand(5,5))) - Σ = L*L' - x = zeros(5,3) - d = MvNormal(vec(μ), Σ) - logp_true = logpdf(d, x) - logp = mvnormlogpdf(μ,L,x) - @test logp_true ≈ logp - g = Flux.gradient(Flux.Params([L])) do - mean(mvnormlogpdf(μ,L,x)) - end - - #3D,CPU - - μ = rand(20,1,128) - L = mapslices(tril, softplus.(rand(20,20,128)), dims = (1,2)) - Σ = mapslices(l -> l*l', L, dims = (1,2)) - x = zeros(20,40,128) - d = map(z -> MvNormal(vec(z[1]), Matrix(z[2])), zip(eachslice(μ, dims = 3), eachslice(Σ, dims =3))) - - logp_true = map(logpdf, d, eachslice(x, dims = 3)) - logp = mvnormlogpdf(μ,L,x) - @test collect(dropdims(logp, dims = 1)') ≈ Flux.stack(logp_true,1) - g = Flux.gradient(Flux.Params([L])) do - mean(mvnormlogpdf(μ,L,x)) - end - #3D, GPU - if CUDA.functional() - μ_d = cu(μ) - L_d = cu(L) - x_d = cu(x) - Σ_d = cu(Σ) - logp_d = mvnormlogpdf(μ_d, L_d, x_d) - @test logp ≈ Array(logp_d) atol = 0.001 #there is a fairly high numerical imprecision when working with CUDA. This is not due to the implementation of logdet as can be seen in the related test below. - - g_d = Flux.gradient(Flux.Params([L_d])) do - mean(mvnormlogpdf(μ_d,L_d,x_d)) - end - CUDA.@allowscalar @test (mapslices(tril!, g_d[L_d], dims=(1,2)) |> Array) ≈ mapslices(tril!, g[L], dims=(1,2)) - end - end -end - -@testset "logdetLorU" begin - A = rand(5,10) - Σ = A*A' - L = cholesky(Σ).L - @test logdet(Σ) ≈ RLCore.logdetLorU(L) - if CUDA.functional() - @test logdet(Σ) ≈ RLCore.logdetLorU(cu(L)) atol = 1f-4 - end -end diff --git a/src/ReinforcementLearningCore/test/runtests.jl b/src/ReinforcementLearningCore/test/runtests.jl index b6047270d..799039856 100644 --- a/src/ReinforcementLearningCore/test/runtests.jl +++ b/src/ReinforcementLearningCore/test/runtests.jl @@ -1,21 +1,14 @@ -using CircularArrayBuffers using ReinforcementLearningBase using ReinforcementLearningCore -using Random -using Test -using StatsBase -using Distributions: probs, Normal, logpdf, MvNormal using ReinforcementLearningEnvironments -using Flux -using Zygote +using ReinforcementLearningTrajectories + +using Test using CUDA -using LinearAlgebra +using CircularArrayBuffers +using Flux @testset "ReinforcementLearningCore.jl" begin - include("core/core.jl") - include("core/hooks.jl") - include("core/stop_conditions_test.jl") - include("components/components.jl") + include("core.jl") include("utils/utils.jl") - include("extensions.jl") end diff --git a/src/ReinforcementLearningCore/test/utils/base.jl b/src/ReinforcementLearningCore/test/utils/base.jl index 4e893cea9..3eee1e200 100644 --- a/src/ReinforcementLearningCore/test/utils/base.jl +++ b/src/ReinforcementLearningCore/test/utils/base.jl @@ -1,40 +1,4 @@ @testset "base" begin - - @testset "select_last_dim" begin - xs = 1:3 - - # scalar - @test select_last_dim(xs, 2) == 2 - - # 1d - @test select_last_dim(xs, [3, 2, 1]) == [3, 2, 1] - - # 2d - xs = [1 2; 3 4] - @test select_last_dim(xs, [2, 1]) == [2 1; 4 3] - end - - @testset "select_last_frame" begin - xs = 1:3 - @test select_last_frame(xs) == 3 - - xs = [1 2; 3 4] - @test select_last_frame(xs) == [2, 4] - end - - @testset "consecutive_view" begin - xs = 1:5 - - @test consecutive_view(xs, [2, 3]) == [2, 3] - @test consecutive_view(xs, [2, 3]; n_stack = 2) == hcat([1, 2], [2, 3]) - @test consecutive_view(xs, [2, 3]; n_horizon = 3) == hcat([2, 3, 4], [3, 4, 5]) - @test consecutive_view(xs, [2, 3]; n_stack = 2, n_horizon = 3) == - hcat( - hcat([1, 2], [2, 3], [3, 4]), # frames at index of 2 - hcat([2, 3], [3, 4], [4, 5]), # frames at index of 3 - ) |> x -> reshape(x, 2, 3, 2) - end - @testset "find_all_max" begin @test find_all_max([-Inf, -Inf, -Inf]) == (-Inf, [1, 2, 3]) @test find_all_max([-Inf, -Inf, -Inf], [true, false, true]) == (-Inf, [1, 3]) @@ -49,35 +13,6 @@ @test find_all_max([0, 1, 2, 1, 2, 1, 0], Bool[1, 1, 0, 0, 0, 1, 1]) == (1, [2, 6]) end - @testset "sum_tree" begin - t = SumTree(8) - - @test RLCore.capacity(t) == 8 - - for i in 1:4 - push!(t, i) - end - - @test length(t) == 4 - @test size(t) == (4,) - - for i in 5:16 - push!(t, i) - end - - @test length(t) == 8 - @test size(t) == (8,) - @test t == 9:16 - - t[:] .= 1 - @test t == ones(8) - @test all([get(t, v)[1] == i for (i, v) in enumerate(0.5:1.0:8)]) - - empty!(t) - @test RLCore.capacity(t) == 8 - @test length(t) == 0 - end - @testset "flatten_batch" begin x = rand(2, 3, 4) y = flatten_batch(x) diff --git a/src/ReinforcementLearningCore/test/utils/processors.jl b/src/ReinforcementLearningCore/test/utils/processors.jl deleted file mode 100644 index 330092797..000000000 --- a/src/ReinforcementLearningCore/test/utils/processors.jl +++ /dev/null @@ -1,23 +0,0 @@ -@testset "processors" begin - @testset "StackFrames" begin - cb = CircularArrayBuffer{Float32}(2, 3, 4) - s = StackFrames(2, 3, 2) - push!(cb, s) - @test size(cb) == (2, 3, 1) - - s(ones(Float32, 2, 3)) - @test s[:, :, 1] == zeros(2, 3) - @test s[:, :, 2] == ones(2, 3) - - push!(cb, s) - @test size(cb) == (2, 3, 2) - - s = StackFrames(2, 3) # one dimension lower - s(ones(2)) - s(2 * ones(2)) - s(3 * ones(2)) - - push!(cb, s) - @test cb[:, :, end] == [1 2 3; 1 2 3] - end -end diff --git a/src/ReinforcementLearningCore/test/utils/stack_frames.jl b/src/ReinforcementLearningCore/test/utils/stack_frames.jl new file mode 100644 index 000000000..97a7612ae --- /dev/null +++ b/src/ReinforcementLearningCore/test/utils/stack_frames.jl @@ -0,0 +1,21 @@ +@testset "StackFrames" begin + cb = CircularArrayBuffer{Float32}(2, 3, 4) + s = StackFrames(2, 3, 2) + push!(cb, s) + @test size(cb) == (2, 3, 1) + + s(ones(Float32, 2, 3)) + @test s[:, :, 1] == zeros(2, 3) + @test s[:, :, 2] == ones(2, 3) + + push!(cb, s) + @test size(cb) == (2, 3, 2) + + s = StackFrames(2, 3) # one dimension lower + s(ones(2)) + s(2 * ones(2)) + s(3 * ones(2)) + + push!(cb, s) + @test cb[:, :, end] == [1 2 3; 1 2 3] +end \ No newline at end of file diff --git a/src/ReinforcementLearningCore/test/utils/utils.jl b/src/ReinforcementLearningCore/test/utils/utils.jl index a1ad204c3..ecac814f2 100644 --- a/src/ReinforcementLearningCore/test/utils/utils.jl +++ b/src/ReinforcementLearningCore/test/utils/utils.jl @@ -1,3 +1,3 @@ include("base.jl") include("device.jl") -include("processors.jl") +include("stack_frames.jl") \ No newline at end of file diff --git a/src/ReinforcementLearningDatasets/Manifest.toml b/src/ReinforcementLearningDatasets/Manifest.toml deleted file mode 100644 index 80209b73c..000000000 --- a/src/ReinforcementLearningDatasets/Manifest.toml +++ /dev/null @@ -1,790 +0,0 @@ -# This file is machine-generated - editing it directly is not advised - -[[AbstractFFTs]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "485ee0867925449198280d4af84bdb46a2a404d0" -uuid = "621f4979-c628-5d54-868e-fcf4e3e8185c" -version = "1.0.1" - -[[AbstractTrees]] -git-tree-sha1 = "03e0550477d86222521d254b741d470ba17ea0b5" -uuid = "1520ce14-60c1-5f80-bbc7-55ef81b5835c" -version = "0.3.4" - -[[Adapt]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "84918055d15b3114ede17ac6a7182f68870c16f7" -uuid = "79e6a3ab-5dfb-504d-930d-738a2a938a0e" -version = "3.3.1" - -[[ArgTools]] -uuid = "0dad84c5-d112-42e6-8d28-ef12dabb789f" - -[[ArrayInterface]] -deps = ["IfElse", "LinearAlgebra", "Requires", "SparseArrays", "Static"] -git-tree-sha1 = "d84c956c4c0548b4caf0e4e96cf5b6494b5b1529" -uuid = "4fba245c-0d91-5ea0-9b3e-6abc04ee57a9" -version = "3.1.32" - -[[Artifacts]] -uuid = "56f22d72-fd6d-98f1-02f0-08ddc0907c33" - -[[BFloat16s]] -deps = ["LinearAlgebra", "Test"] -git-tree-sha1 = "4af69e205efc343068dc8722b8dfec1ade89254a" -uuid = "ab4f0b2a-ad5b-11e8-123f-65d77653426b" -version = "0.1.0" - -[[Base64]] -uuid = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f" - -[[BinaryProvider]] -deps = ["Libdl", "Logging", "SHA"] -git-tree-sha1 = "ecdec412a9abc8db54c0efc5548c64dfce072058" -uuid = "b99e7846-7c00-51b0-8f62-c81ae34c0232" -version = "0.5.10" - -[[Blosc]] -deps = ["Blosc_jll"] -git-tree-sha1 = "84cf7d0f8fd46ca6f1b3e0305b4b4a37afe50fd6" -uuid = "a74b3585-a348-5f62-a45c-50e91977d574" -version = "0.7.0" - -[[Blosc_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Lz4_jll", "Pkg", "Zlib_jll", "Zstd_jll"] -git-tree-sha1 = "e747dac84f39c62aff6956651ec359686490134e" -uuid = "0b7ba130-8d10-5ba8-a3d6-c5182647fed9" -version = "1.21.0+0" - -[[BufferedStreams]] -deps = ["Compat", "Test"] -git-tree-sha1 = "5d55b9486590fdda5905c275bb21ce1f0754020f" -uuid = "e1450e63-4bb3-523b-b2a4-4ffa8c0fd77d" -version = "1.0.0" - -[[CEnum]] -git-tree-sha1 = "215a9aa4a1f23fbd05b92769fdd62559488d70e9" -uuid = "fa961155-64e5-5f13-b03f-caf6b980ea82" -version = "0.4.1" - -[[CRC32c]] -uuid = "8bf52ea8-c179-5cab-976a-9e18b702a9bc" - -[[CUDA]] -deps = ["AbstractFFTs", "Adapt", "BFloat16s", "CEnum", "CompilerSupportLibraries_jll", "ExprTools", "GPUArrays", "GPUCompiler", "LLVM", "LazyArtifacts", "Libdl", "LinearAlgebra", "Logging", "Printf", "Random", "Random123", "RandomNumbers", "Reexport", "Requires", "SparseArrays", "SpecialFunctions", "TimerOutputs"] -git-tree-sha1 = "335b3d2373733919b4972a51215a6840c7a33828" -uuid = "052768ef-5323-5732-b1bb-66c8b64840ba" -version = "3.4.2" - -[[ChainRules]] -deps = ["ChainRulesCore", "Compat", "LinearAlgebra", "Random", "Statistics"] -git-tree-sha1 = "d88340ab502af66cfffc821e70ae72f7dbdce645" -uuid = "082447d4-558c-5d27-93f4-14fc19e9eca2" -version = "1.11.5" - -[[ChainRulesCore]] -deps = ["Compat", "LinearAlgebra", "SparseArrays"] -git-tree-sha1 = "30ee06de5ff870b45c78f529a6b093b3323256a3" -uuid = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4" -version = "1.3.1" - -[[CodecZlib]] -deps = ["TranscodingStreams", "Zlib_jll"] -git-tree-sha1 = "ded953804d019afa9a3f98981d99b33e3db7b6da" -uuid = "944b1d66-785c-5afd-91f1-9de20f533193" -version = "0.7.0" - -[[ColorTypes]] -deps = ["FixedPointNumbers", "Random"] -git-tree-sha1 = "024fe24d83e4a5bf5fc80501a314ce0d1aa35597" -uuid = "3da002f7-5984-5a60-b8a6-cbb66c0b333f" -version = "0.11.0" - -[[ColorVectorSpace]] -deps = ["ColorTypes", "FixedPointNumbers", "LinearAlgebra", "SpecialFunctions", "Statistics", "TensorCore"] -git-tree-sha1 = "a66a8e024807c4b3d186eb1cab2aff3505271f8e" -uuid = "c3611d14-8923-5661-9e6a-0046d554d3a4" -version = "0.9.6" - -[[Colors]] -deps = ["ColorTypes", "FixedPointNumbers", "Reexport"] -git-tree-sha1 = "417b0ed7b8b838aa6ca0a87aadf1bb9eb111ce40" -uuid = "5ae59095-9a9b-59fe-a467-6f913c188581" -version = "0.12.8" - -[[CommonRLInterface]] -deps = ["MacroTools"] -git-tree-sha1 = "21de56ebf28c262651e682f7fe614d44623dc087" -uuid = "d842c3ba-07a1-494f-bbec-f5741b0a3e98" -version = "0.3.1" - -[[CommonSubexpressions]] -deps = ["MacroTools", "Test"] -git-tree-sha1 = "7b8a93dba8af7e3b42fecabf646260105ac373f7" -uuid = "bbf7d656-a473-5ed7-a52c-81e309532950" -version = "0.3.0" - -[[Compat]] -deps = ["Base64", "Dates", "DelimitedFiles", "Distributed", "InteractiveUtils", "LibGit2", "Libdl", "LinearAlgebra", "Markdown", "Mmap", "Pkg", "Printf", "REPL", "Random", "SHA", "Serialization", "SharedArrays", "Sockets", "SparseArrays", "Statistics", "Test", "UUIDs", "Unicode"] -git-tree-sha1 = "4866e381721b30fac8dda4c8cb1d9db45c8d2994" -uuid = "34da2185-b29b-5c13-b0c7-acf172513d20" -version = "3.37.0" - -[[CompilerSupportLibraries_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "e66e0078-7015-5450-92f7-15fbd957f2ae" - -[[Conda]] -deps = ["JSON", "VersionParsing"] -git-tree-sha1 = "299304989a5e6473d985212c28928899c74e9421" -uuid = "8f4d0f93-b110-5947-807f-2305c1781a2d" -version = "1.5.2" - -[[ConstructionBase]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "f74e9d5388b8620b4cee35d4c5a618dd4dc547f4" -uuid = "187b0558-2788-49d3-abe0-74a17ed4e7c9" -version = "1.3.0" - -[[Crayons]] -git-tree-sha1 = "3f71217b538d7aaee0b69ab47d9b7724ca8afa0d" -uuid = "a8cc5b0e-0ffa-5ad4-8c14-923d3ee1735f" -version = "4.0.4" - -[[DataAPI]] -git-tree-sha1 = "bec2532f8adb82005476c141ec23e921fc20971b" -uuid = "9a962f9c-6df0-11e9-0e5d-c546b8b5ee8a" -version = "1.8.0" - -[[DataDeps]] -deps = ["BinaryProvider", "HTTP", "Libdl", "Reexport", "SHA", "p7zip_jll"] -git-tree-sha1 = "4f0e41ff461d42cfc62ff0de4f1cd44c6e6b3771" -uuid = "124859b0-ceae-595e-8997-d05f6a7a8dfe" -version = "0.7.7" - -[[DataStructures]] -deps = ["Compat", "InteractiveUtils", "OrderedCollections"] -git-tree-sha1 = "7d9d316f04214f7efdbb6398d545446e246eff02" -uuid = "864edb3b-99cc-5e75-8d2d-829cb0a9cfe8" -version = "0.18.10" - -[[Dates]] -deps = ["Printf"] -uuid = "ade2ca70-3891-5945-98fb-dc099432e06a" - -[[DelimitedFiles]] -deps = ["Mmap"] -uuid = "8bb1440f-4735-579b-a4ab-409b98df4dab" - -[[DiffResults]] -deps = ["StaticArrays"] -git-tree-sha1 = "c18e98cba888c6c25d1c3b048e4b3380ca956805" -uuid = "163ba53b-c6d8-5494-b064-1a9d43ac40c5" -version = "1.0.3" - -[[DiffRules]] -deps = ["NaNMath", "Random", "SpecialFunctions"] -git-tree-sha1 = "3ed8fa7178a10d1cd0f1ca524f249ba6937490c0" -uuid = "b552c78f-8df3-52c6-915a-8e097449b14b" -version = "1.3.0" - -[[Distributed]] -deps = ["Random", "Serialization", "Sockets"] -uuid = "8ba89e20-285c-5b6f-9357-94700520ee1b" - -[[DocStringExtensions]] -deps = ["LibGit2"] -git-tree-sha1 = "a32185f5428d3986f47c2ab78b1f216d5e6cc96f" -uuid = "ffbed154-4ef7-542d-bbb7-c09d3a79fcae" -version = "0.8.5" - -[[Downloads]] -deps = ["ArgTools", "LibCURL", "NetworkOptions"] -uuid = "f43a241f-c20a-4ad4-852c-f6b1247861c6" - -[[EllipsisNotation]] -deps = ["ArrayInterface"] -git-tree-sha1 = "8041575f021cba5a099a456b4163c9a08b566a02" -uuid = "da5c29d0-fa7d-589e-88eb-ea29b0a81949" -version = "1.1.0" - -[[ExprTools]] -git-tree-sha1 = "b7e3d17636b348f005f11040025ae8c6f645fe92" -uuid = "e2ba6199-217a-4e67-a87a-7c52f15ade04" -version = "0.1.6" - -[[FillArrays]] -deps = ["LinearAlgebra", "Random", "SparseArrays", "Statistics"] -git-tree-sha1 = "caf289224e622f518c9dbfe832cdafa17d7c80a6" -uuid = "1a297f60-69ca-5386-bcde-b61e274b549b" -version = "0.12.4" - -[[FixedPointNumbers]] -deps = ["Statistics"] -git-tree-sha1 = "335bfdceacc84c5cdf16aadc768aa5ddfc5383cc" -uuid = "53c48c17-4a7d-5ca2-90c5-79b7896eea93" -version = "0.8.4" - -[[Flux]] -deps = ["AbstractTrees", "Adapt", "ArrayInterface", "CUDA", "CodecZlib", "Colors", "DelimitedFiles", "Functors", "Juno", "LinearAlgebra", "MacroTools", "NNlib", "NNlibCUDA", "Pkg", "Printf", "Random", "Reexport", "SHA", "Statistics", "StatsBase", "Test", "ZipFile", "Zygote"] -git-tree-sha1 = "1286e5dd0b4c306108747356a7a5d39a11dc4080" -uuid = "587475ba-b771-5e3f-ad9e-33799f191a9c" -version = "0.12.6" - -[[ForwardDiff]] -deps = ["CommonSubexpressions", "DiffResults", "DiffRules", "LinearAlgebra", "NaNMath", "Printf", "Random", "SpecialFunctions", "StaticArrays"] -git-tree-sha1 = "b5e930ac60b613ef3406da6d4f42c35d8dc51419" -uuid = "f6369f11-7733-5829-9624-2563aa707210" -version = "0.10.19" - -[[Functors]] -git-tree-sha1 = "e2727f02325451f6b24445cd83bfa9aaac19cbe7" -uuid = "d9f16b24-f501-4c13-a1f2-28368ffc5196" -version = "0.2.5" - -[[Future]] -deps = ["Random"] -uuid = "9fa8497b-333b-5362-9e8d-4d0656e87820" - -[[GPUArrays]] -deps = ["Adapt", "LinearAlgebra", "Printf", "Random", "Serialization", "Statistics"] -git-tree-sha1 = "8fac1cf7d6ce0f2249c7acaf25d22e1e85c4a07f" -uuid = "0c68f7d7-f131-5f86-a1c3-88cf8149b2d7" -version = "8.0.2" - -[[GPUCompiler]] -deps = ["ExprTools", "InteractiveUtils", "LLVM", "Libdl", "Logging", "TimerOutputs", "UUIDs"] -git-tree-sha1 = "4ed2616d5e656c8716736b64da86755467f26cf5" -uuid = "61eb1bfa-7361-4325-ad38-22787b887f55" -version = "0.12.9" - -[[Graphics]] -deps = ["Colors", "LinearAlgebra", "NaNMath"] -git-tree-sha1 = "2c1cf4df419938ece72de17f368a021ee162762e" -uuid = "a2bd30eb-e257-5431-a919-1863eab51364" -version = "1.1.0" - -[[HDF5]] -deps = ["Blosc", "Compat", "HDF5_jll", "Libdl", "Mmap", "Random", "Requires"] -git-tree-sha1 = "83173193dc242ce4b037f0263a7cc45afb5a0b85" -uuid = "f67ccb44-e63f-5c2f-98bd-6dc0ccc4ba2f" -version = "0.15.6" - -[[HDF5_jll]] -deps = ["Artifacts", "JLLWrappers", "LibCURL_jll", "Libdl", "OpenSSL_jll", "Pkg", "Zlib_jll"] -git-tree-sha1 = "fd83fa0bde42e01952757f01149dd968c06c4dba" -uuid = "0234f1f7-429e-5d53-9886-15a909be8d59" -version = "1.12.0+1" - -[[HTTP]] -deps = ["Base64", "Dates", "IniFile", "Logging", "MbedTLS", "NetworkOptions", "Sockets", "URIs"] -git-tree-sha1 = "60ed5f1643927479f845b0135bb369b031b541fa" -uuid = "cd3eb016-35fb-5094-929b-558a96fad6f3" -version = "0.9.14" - -[[IRTools]] -deps = ["InteractiveUtils", "MacroTools", "Test"] -git-tree-sha1 = "95215cd0076a150ef46ff7928892bc341864c73c" -uuid = "7869d1d1-7146-5819-86e3-90919afe41df" -version = "0.4.3" - -[[IfElse]] -git-tree-sha1 = "28e837ff3e7a6c3cdb252ce49fb412c8eb3caeef" -uuid = "615f187c-cbe4-4ef1-ba3b-2fcf58d6d173" -version = "0.1.0" - -[[ImageCore]] -deps = ["AbstractFFTs", "ColorVectorSpace", "Colors", "FixedPointNumbers", "Graphics", "MappedArrays", "MosaicViews", "OffsetArrays", "PaddedViews", "Reexport"] -git-tree-sha1 = "595155739d361589b3d074386f77c107a8ada6f7" -uuid = "a09fc81d-aa75-5fe9-8630-4744c3626534" -version = "0.9.2" - -[[IndirectArrays]] -git-tree-sha1 = "012e604e1c7458645cb8b436f8fba789a51b257f" -uuid = "9b13fd28-a010-5f03-acff-a1bbcff69959" -version = "1.0.0" - -[[IniFile]] -deps = ["Test"] -git-tree-sha1 = "098e4d2c533924c921f9f9847274f2ad89e018b8" -uuid = "83e8ac13-25f8-5344-8a64-a9f2b223428f" -version = "0.5.0" - -[[InteractiveUtils]] -deps = ["Markdown"] -uuid = "b77e0a4c-d291-57a0-90e8-8db25a27a240" - -[[InternedStrings]] -deps = ["Random", "Test"] -git-tree-sha1 = "eb05b5625bc5d821b8075a77e4c421933e20c76b" -uuid = "7d512f48-7fb1-5a58-b986-67e6dc259f01" -version = "0.7.0" - -[[IntervalSets]] -deps = ["Dates", "EllipsisNotation", "Statistics"] -git-tree-sha1 = "3cc368af3f110a767ac786560045dceddfc16758" -uuid = "8197267c-284f-5f27-9208-e0e47529a953" -version = "0.5.3" - -[[IrrationalConstants]] -git-tree-sha1 = "f76424439413893a832026ca355fe273e93bce94" -uuid = "92d709cd-6900-40b7-9082-c6be49f344b6" -version = "0.1.0" - -[[JLLWrappers]] -deps = ["Preferences"] -git-tree-sha1 = "642a199af8b68253517b80bd3bfd17eb4e84df6e" -uuid = "692b3bcd-3c85-4b1f-b108-f13ce0eb3210" -version = "1.3.0" - -[[JSON]] -deps = ["Dates", "Mmap", "Parsers", "Unicode"] -git-tree-sha1 = "8076680b162ada2a031f707ac7b4953e30667a37" -uuid = "682c06a0-de6a-54ab-a142-c8b1cf79cde6" -version = "0.21.2" - -[[Juno]] -deps = ["Base64", "Logging", "Media", "Profile"] -git-tree-sha1 = "07cb43290a840908a771552911a6274bc6c072c7" -uuid = "e5e0dc1b-0480-54bc-9374-aad01c23163d" -version = "0.8.4" - -[[LLVM]] -deps = ["CEnum", "LLVMExtra_jll", "Libdl", "Printf", "Unicode"] -git-tree-sha1 = "8fb1a675d1b51885a78bc980fbf1944279880f97" -uuid = "929cbde3-209d-540e-8aea-75f648917ca0" -version = "4.5.1" - -[[LLVMExtra_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "9c360e5ce980b88bb31a7b086dbb19469008154b" -uuid = "dad2f222-ce93-54a1-a47d-0025e8a3acab" -version = "0.0.10+0" - -[[LazyArtifacts]] -deps = ["Artifacts", "Pkg"] -uuid = "4af54fe1-eca0-43a8-85a7-787d91b784e3" - -[[LibCURL]] -deps = ["LibCURL_jll", "MozillaCACerts_jll"] -uuid = "b27032c2-a3e7-50c8-80cd-2d36dbcbfd21" - -[[LibCURL_jll]] -deps = ["Artifacts", "LibSSH2_jll", "Libdl", "MbedTLS_jll", "Zlib_jll", "nghttp2_jll"] -uuid = "deac9b47-8bc7-5906-a0fe-35ac56dc84c0" - -[[LibGit2]] -deps = ["Base64", "NetworkOptions", "Printf", "SHA"] -uuid = "76f85450-5226-5b5a-8eaa-529ad045b433" - -[[LibSSH2_jll]] -deps = ["Artifacts", "Libdl", "MbedTLS_jll"] -uuid = "29816b5a-b9ab-546f-933c-edad1886dfa8" - -[[Libdl]] -uuid = "8f399da3-3557-5675-b5ff-fb832c97cbdb" - -[[LinearAlgebra]] -deps = ["Libdl"] -uuid = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e" - -[[LogExpFunctions]] -deps = ["ChainRulesCore", "DocStringExtensions", "IrrationalConstants", "LinearAlgebra"] -git-tree-sha1 = "86197a8ecb06e222d66797b0c2d2f0cc7b69e42b" -uuid = "2ab3a3ac-af41-5b50-aa03-7779005ae688" -version = "0.3.2" - -[[Logging]] -uuid = "56ddb016-857b-54e1-b83d-db4d58db5568" - -[[Lz4_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "5d494bc6e85c4c9b626ee0cab05daa4085486ab1" -uuid = "5ced341a-0733-55b8-9ab6-a4889d929147" -version = "1.9.3+0" - -[[MacroTools]] -deps = ["Markdown", "Random"] -git-tree-sha1 = "0fb723cd8c45858c22169b2e42269e53271a6df7" -uuid = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09" -version = "0.5.7" - -[[MappedArrays]] -git-tree-sha1 = "e8b359ef06ec72e8c030463fe02efe5527ee5142" -uuid = "dbb5928d-eab1-5f90-85c2-b9b0edb7c900" -version = "0.4.1" - -[[Markdown]] -deps = ["Base64"] -uuid = "d6f4376e-aef5-505a-96c1-9c027394607a" - -[[MbedTLS]] -deps = ["Dates", "MbedTLS_jll", "Random", "Sockets"] -git-tree-sha1 = "1c38e51c3d08ef2278062ebceade0e46cefc96fe" -uuid = "739be429-bea8-5141-9913-cc70e7f3736d" -version = "1.0.3" - -[[MbedTLS_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "c8ffd9c3-330d-5841-b78e-0817d7145fa1" - -[[Media]] -deps = ["MacroTools", "Test"] -git-tree-sha1 = "75a54abd10709c01f1b86b84ec225d26e840ed58" -uuid = "e89f7d12-3494-54d1-8411-f7d8b9ae1f27" -version = "0.5.0" - -[[Missings]] -deps = ["DataAPI"] -git-tree-sha1 = "2ca267b08821e86c5ef4376cffed98a46c2cb205" -uuid = "e1d29d7a-bbdc-5cf2-9ac0-f12de2c33e28" -version = "1.0.1" - -[[Mmap]] -uuid = "a63ad114-7e13-5084-954f-fe012c677804" - -[[MosaicViews]] -deps = ["MappedArrays", "OffsetArrays", "PaddedViews", "StackViews"] -git-tree-sha1 = "b34e3bc3ca7c94914418637cb10cc4d1d80d877d" -uuid = "e94cdb99-869f-56ef-bcf0-1ae2bcbe0389" -version = "0.3.3" - -[[MozillaCACerts_jll]] -uuid = "14a3606d-f60d-562e-9121-12d972cd8159" - -[[NNlib]] -deps = ["Adapt", "ChainRulesCore", "Compat", "LinearAlgebra", "Pkg", "Requires", "Statistics"] -git-tree-sha1 = "5203a4532ad28c44f82c76634ad621d7c90abcbd" -uuid = "872c559c-99b0-510c-b3b7-b6c96a88d5cd" -version = "0.7.29" - -[[NNlibCUDA]] -deps = ["CUDA", "LinearAlgebra", "NNlib", "Random", "Statistics"] -git-tree-sha1 = "04490d5e7570c038b1cb0f5c3627597181cc15a9" -uuid = "a00861dc-f156-4864-bf3c-e6376f28a68d" -version = "0.1.9" - -[[NPZ]] -deps = ["Compat", "ZipFile"] -git-tree-sha1 = "fbfb3c151b0308236d854c555b43cdd84c1e5ebf" -uuid = "15e1cf62-19b3-5cfa-8e77-841668bca605" -version = "0.4.1" - -[[NaNMath]] -git-tree-sha1 = "bfe47e760d60b82b66b61d2d44128b62e3a369fb" -uuid = "77ba4419-2d1f-58cd-9bb1-8ffee604a2e3" -version = "0.3.5" - -[[NetworkOptions]] -uuid = "ca575930-c2e3-43a9-ace4-1e988b2c1908" - -[[OffsetArrays]] -deps = ["Adapt"] -git-tree-sha1 = "c870a0d713b51e4b49be6432eff0e26a4325afee" -uuid = "6fe1bfb0-de20-5000-8ca7-80f57d26f881" -version = "1.10.6" - -[[OpenSSL_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "15003dcb7d8db3c6c857fda14891a539a8f2705a" -uuid = "458c3c95-2e84-50aa-8efc-19380b2a3a95" -version = "1.1.10+0" - -[[OpenSpecFun_jll]] -deps = ["Artifacts", "CompilerSupportLibraries_jll", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "13652491f6856acfd2db29360e1bbcd4565d04f1" -uuid = "efe28fd5-8261-553b-a9e1-b2916fc3738e" -version = "0.5.5+0" - -[[OrderedCollections]] -git-tree-sha1 = "85f8e6578bf1f9ee0d11e7bb1b1456435479d47c" -uuid = "bac558e1-5e72-5ebc-8fee-abe8a469f55d" -version = "1.4.1" - -[[PNGFiles]] -deps = ["Base64", "CEnum", "ImageCore", "IndirectArrays", "OffsetArrays", "libpng_jll"] -git-tree-sha1 = "e14c485f6beee0c7a8dcf6128bf70b85f1fe201e" -uuid = "f57f5aa1-a3ce-4bc8-8ab9-96f992907883" -version = "0.3.9" - -[[PaddedViews]] -deps = ["OffsetArrays"] -git-tree-sha1 = "646eed6f6a5d8df6708f15ea7e02a7a2c4fe4800" -uuid = "5432bcbf-9aad-5242-b902-cca2824c8663" -version = "0.5.10" - -[[Parsers]] -deps = ["Dates"] -git-tree-sha1 = "438d35d2d95ae2c5e8780b330592b6de8494e779" -uuid = "69de0a69-1ddd-5017-9359-2bf0b02dc9f0" -version = "2.0.3" - -[[Pickle]] -deps = ["DataStructures", "InternedStrings", "Serialization", "SparseArrays", "Strided", "ZipFile"] -git-tree-sha1 = "32b02a862b214ea4c7f250fab1d7af5149226191" -uuid = "fbb45041-c46e-462f-888f-7c521cafbc2c" -version = "0.2.7" - -[[Pipe]] -git-tree-sha1 = "6842804e7867b115ca9de748a0cf6b364523c16d" -uuid = "b98c9c47-44ae-5843-9183-064241ee97a0" -version = "1.3.0" - -[[Pkg]] -deps = ["Artifacts", "Dates", "Downloads", "LibGit2", "Libdl", "Logging", "Markdown", "Printf", "REPL", "Random", "SHA", "Serialization", "TOML", "Tar", "UUIDs", "p7zip_jll"] -uuid = "44cfe95a-1eb2-52ea-b672-e2afdf69b78f" - -[[Preferences]] -deps = ["TOML"] -git-tree-sha1 = "00cfd92944ca9c760982747e9a1d0d5d86ab1e5a" -uuid = "21216c6a-2e73-6563-6e65-726566657250" -version = "1.2.2" - -[[Printf]] -deps = ["Unicode"] -uuid = "de0858da-6303-5e67-8744-51eddeeeb8d7" - -[[Profile]] -deps = ["Printf"] -uuid = "9abbd945-dff8-562f-b5e8-e1ebf5ef1b79" - -[[ProgressMeter]] -deps = ["Distributed", "Printf"] -git-tree-sha1 = "afadeba63d90ff223a6a48d2009434ecee2ec9e8" -uuid = "92933f4c-e287-5a05-a399-4b506db050ca" -version = "1.7.1" - -[[ProtoBuf]] -deps = ["Compat", "Logging"] -git-tree-sha1 = "9ecf92287404ebe5666a1c0488c3aaf90bbb5ff4" -uuid = "3349acd9-ac6a-5e09-bcdb-63829b23a429" -version = "0.10.0" - -[[PyCall]] -deps = ["Conda", "Dates", "Libdl", "LinearAlgebra", "MacroTools", "Serialization", "VersionParsing"] -git-tree-sha1 = "169bb8ea6b1b143c5cf57df6d34d022a7b60c6db" -uuid = "438e738f-606a-5dbb-bf0a-cddfbfd45ab0" -version = "1.92.3" - -[[REPL]] -deps = ["InteractiveUtils", "Markdown", "Sockets", "Unicode"] -uuid = "3fa0cd96-eef1-5676-8a61-b3b8758bbffb" - -[[Random]] -deps = ["Serialization"] -uuid = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c" - -[[Random123]] -deps = ["Libdl", "Random", "RandomNumbers"] -git-tree-sha1 = "0e8b146557ad1c6deb1367655e052276690e71a3" -uuid = "74087812-796a-5b5d-8853-05524746bad3" -version = "1.4.2" - -[[RandomNumbers]] -deps = ["Random", "Requires"] -git-tree-sha1 = "043da614cc7e95c703498a491e2c21f58a2b8111" -uuid = "e6cf234a-135c-5ec9-84dd-332b85af5143" -version = "1.5.3" - -[[Reexport]] -git-tree-sha1 = "45e428421666073eab6f2da5c9d310d99bb12f9b" -uuid = "189a3867-3050-52da-a836-e630ba90ab69" -version = "1.2.2" - -[[ReinforcementLearningBase]] -deps = ["AbstractTrees", "CommonRLInterface", "Markdown", "Random", "Test"] -path = "../ReinforcementLearningBase" -uuid = "e575027e-6cd6-5018-9292-cdc6200d2b44" -version = "0.9.7" - -[[ReinforcementLearningEnvironments]] -deps = ["DelimitedFiles", "IntervalSets", "LinearAlgebra", "MacroTools", "Markdown", "Pkg", "Random", "ReinforcementLearningBase", "Requires", "SparseArrays", "StatsBase"] -path = "../ReinforcementLearningEnvironments" -uuid = "25e41dd2-4622-11e9-1641-f1adca772921" -version = "0.6.6" - -[[Requires]] -deps = ["UUIDs"] -git-tree-sha1 = "4036a3bd08ac7e968e27c203d45f5fff15020621" -uuid = "ae029012-a4dd-5104-9daa-d747884805df" -version = "1.1.3" - -[[SHA]] -uuid = "ea8e919c-243c-51af-8825-aaa63cd721ce" - -[[Serialization]] -uuid = "9e88b42a-f829-5b0c-bbe9-9e923198166b" - -[[Setfield]] -deps = ["ConstructionBase", "Future", "MacroTools", "Requires"] -git-tree-sha1 = "fca29e68c5062722b5b4435594c3d1ba557072a3" -uuid = "efcf1570-3423-57d1-acb7-fd33fddbac46" -version = "0.7.1" - -[[SharedArrays]] -deps = ["Distributed", "Mmap", "Random", "Serialization"] -uuid = "1a1011a3-84de-559e-8e89-a11a2f7dc383" - -[[Sockets]] -uuid = "6462fe0b-24de-5631-8697-dd941f90decc" - -[[SortingAlgorithms]] -deps = ["DataStructures"] -git-tree-sha1 = "b3363d7460f7d098ca0912c69b082f75625d7508" -uuid = "a2af1166-a08f-5f64-846c-94a0d3cef48c" -version = "1.0.1" - -[[SparseArrays]] -deps = ["LinearAlgebra", "Random"] -uuid = "2f01184e-e22b-5df5-ae63-d93ebab69eaf" - -[[SpecialFunctions]] -deps = ["ChainRulesCore", "LogExpFunctions", "OpenSpecFun_jll"] -git-tree-sha1 = "a322a9493e49c5f3a10b50df3aedaf1cdb3244b7" -uuid = "276daf66-3868-5448-9aa4-cd146d93841b" -version = "1.6.1" - -[[StackViews]] -deps = ["OffsetArrays"] -git-tree-sha1 = "46e589465204cd0c08b4bd97385e4fa79a0c770c" -uuid = "cae243ae-269e-4f55-b966-ac2d0dc13c15" -version = "0.1.1" - -[[Static]] -deps = ["IfElse"] -git-tree-sha1 = "a8f30abc7c64a39d389680b74e749cf33f872a70" -uuid = "aedffcd0-7271-4cad-89d0-dc628f76c6d3" -version = "0.3.3" - -[[StaticArrays]] -deps = ["LinearAlgebra", "Random", "Statistics"] -git-tree-sha1 = "3240808c6d463ac46f1c1cd7638375cd22abbccb" -uuid = "90137ffa-7385-5640-81b9-e52037218182" -version = "1.2.12" - -[[Statistics]] -deps = ["LinearAlgebra", "SparseArrays"] -uuid = "10745b16-79ce-11e8-11f9-7d13ad32a3b2" - -[[StatsAPI]] -git-tree-sha1 = "1958272568dc176a1d881acb797beb909c785510" -uuid = "82ae8749-77ed-4fe6-ae5f-f523153014b0" -version = "1.0.0" - -[[StatsBase]] -deps = ["DataAPI", "DataStructures", "LinearAlgebra", "Missings", "Printf", "Random", "SortingAlgorithms", "SparseArrays", "Statistics", "StatsAPI"] -git-tree-sha1 = "8cbbc098554648c84f79a463c9ff0fd277144b6c" -uuid = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91" -version = "0.33.10" - -[[Strided]] -deps = ["LinearAlgebra", "TupleTools"] -git-tree-sha1 = "4d581938087ca90eab9bd4bb6d270edaefd70dcd" -uuid = "5e0ebb24-38b0-5f93-81fe-25c709ecae67" -version = "1.1.2" - -[[TFRecord]] -deps = ["BufferedStreams", "CRC32c", "CodecZlib", "MacroTools", "Printf", "ProtoBuf", "Random"] -git-tree-sha1 = "5e457661947084eecbe1934706a1c5f2a31671be" -uuid = "841416d8-1a6a-485a-b0fc-1328d0f53d5e" -version = "0.3.0" - -[[TOML]] -deps = ["Dates"] -uuid = "fa267f1f-6049-4f14-aa54-33bafae1ed76" - -[[Tar]] -deps = ["ArgTools", "SHA"] -uuid = "a4e569a6-e804-4fa4-b0f3-eef7a1d5b13e" - -[[TensorCore]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "1feb45f88d133a655e001435632f019a9a1bcdb6" -uuid = "62fd8b95-f654-4bbd-a8a5-9c27f68ccd50" -version = "0.1.1" - -[[Test]] -deps = ["InteractiveUtils", "Logging", "Random", "Serialization"] -uuid = "8dfed614-e22c-5e08-85e1-65c5234f0b40" - -[[TimerOutputs]] -deps = ["ExprTools", "Printf"] -git-tree-sha1 = "209a8326c4f955e2442c07b56029e88bb48299c7" -uuid = "a759f4b9-e2f1-59dc-863e-4aeb61b1ea8f" -version = "0.5.12" - -[[TranscodingStreams]] -deps = ["Random", "Test"] -git-tree-sha1 = "216b95ea110b5972db65aa90f88d8d89dcb8851c" -uuid = "3bb67fe8-82b1-5028-8e26-92a6c54297fa" -version = "0.9.6" - -[[TupleTools]] -git-tree-sha1 = "3c712976c47707ff893cf6ba4354aa14db1d8938" -uuid = "9d95972d-f1c8-5527-a6e0-b4b365fa01f6" -version = "1.3.0" - -[[URIs]] -git-tree-sha1 = "97bbe755a53fe859669cd907f2d96aee8d2c1355" -uuid = "5c2747f8-b7ea-4ff2-ba2e-563bfd36b1d4" -version = "1.3.0" - -[[UUIDs]] -deps = ["Random", "SHA"] -uuid = "cf7118a7-6976-5b1a-9a39-7adc72f591a4" - -[[Unicode]] -uuid = "4ec0a83e-493e-50e2-b9ac-8f72acf5a8f5" - -[[UnicodePlots]] -deps = ["Crayons", "Dates", "SparseArrays", "StatsBase"] -git-tree-sha1 = "dc9c7086d41783f14d215ea0ddcca8037a8691e9" -uuid = "b8865327-cd53-5732-bb35-84acbb429228" -version = "1.4.0" - -[[VersionParsing]] -git-tree-sha1 = "80229be1f670524750d905f8fc8148e5a8c4537f" -uuid = "81def892-9a0e-5fdd-b105-ffc91e053289" -version = "1.2.0" - -[[ZipFile]] -deps = ["Libdl", "Printf", "Zlib_jll"] -git-tree-sha1 = "c3a5637e27e914a7a445b8d0ad063d701931e9f7" -uuid = "a5390f91-8eb1-5f08-bee0-b1d1ffed6cea" -version = "0.9.3" - -[[Zlib_jll]] -deps = ["Libdl"] -uuid = "83775a58-1f1d-513f-b197-d71354ab007a" - -[[Zstd_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "cc4bf3fdde8b7e3e9fa0351bdeedba1cf3b7f6e6" -uuid = "3161d3a3-bdf6-5164-811a-617609db77b4" -version = "1.5.0+0" - -[[Zygote]] -deps = ["AbstractFFTs", "ChainRules", "ChainRulesCore", "DiffRules", "Distributed", "FillArrays", "ForwardDiff", "IRTools", "InteractiveUtils", "LinearAlgebra", "MacroTools", "NaNMath", "Random", "Requires", "SpecialFunctions", "Statistics", "ZygoteRules"] -git-tree-sha1 = "ffbf36ba9cd8476347486a013c93590b910a4855" -uuid = "e88e6eb3-aa80-5325-afca-941959d7151f" -version = "0.6.21" - -[[ZygoteRules]] -deps = ["MacroTools"] -git-tree-sha1 = "9e7a1e8ca60b742e508a315c17eef5211e7fbfd7" -uuid = "700de1a5-db45-46bc-99cf-38207098b444" -version = "0.2.1" - -[[libpng_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg", "Zlib_jll"] -git-tree-sha1 = "94d180a6d2b5e55e447e2d27a29ed04fe79eb30c" -uuid = "b53b4c65-9356-5827-b1ea-8c7a1a84506f" -version = "1.6.38+0" - -[[nghttp2_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "8e850ede-7688-5339-a07c-302acd2aaf8d" - -[[p7zip_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "3f19e933-33d8-53b3-aaab-bd5110c3b7a0" diff --git a/src/ReinforcementLearningEnvironments/.JuliaFormatter.toml b/src/ReinforcementLearningEnvironments/.JuliaFormatter.toml deleted file mode 100644 index 8ec1b0b70..000000000 --- a/src/ReinforcementLearningEnvironments/.JuliaFormatter.toml +++ /dev/null @@ -1,2 +0,0 @@ -verbose = true -always_for_in = true diff --git a/src/ReinforcementLearningEnvironments/.github/workflows/CompatHelper.yml b/src/ReinforcementLearningEnvironments/.github/workflows/CompatHelper.yml deleted file mode 100644 index 0f66259dd..000000000 --- a/src/ReinforcementLearningEnvironments/.github/workflows/CompatHelper.yml +++ /dev/null @@ -1,22 +0,0 @@ -name: CompatHelper - -on: - schedule: - - cron: '00 00 * * *' - workflow_dispatch: - -jobs: - CompatHelper: - runs-on: ${{ matrix.os }} - strategy: - matrix: - julia-version: [1.2.0] - julia-arch: [x86] - os: [ubuntu-latest] - steps: - - name: Pkg.add("CompatHelper") - run: julia -e 'using Pkg; Pkg.add("CompatHelper")' - - name: CompatHelper.main() - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - run: julia -e 'using CompatHelper; CompatHelper.main()' diff --git a/src/ReinforcementLearningEnvironments/.github/workflows/TagBot.yml b/src/ReinforcementLearningEnvironments/.github/workflows/TagBot.yml deleted file mode 100644 index d77d3a0c3..000000000 --- a/src/ReinforcementLearningEnvironments/.github/workflows/TagBot.yml +++ /dev/null @@ -1,11 +0,0 @@ -name: TagBot -on: - schedule: - - cron: 0 * * * * -jobs: - TagBot: - runs-on: ubuntu-latest - steps: - - uses: JuliaRegistries/TagBot@v1 - with: - token: ${{ secrets.GITHUB_TOKEN }} diff --git a/src/ReinforcementLearningEnvironments/.github/workflows/ci.yml b/src/ReinforcementLearningEnvironments/.github/workflows/ci.yml deleted file mode 100644 index ebd926d20..000000000 --- a/src/ReinforcementLearningEnvironments/.github/workflows/ci.yml +++ /dev/null @@ -1,52 +0,0 @@ -name: CI -on: - pull_request: - branches: - - master - push: - branches: - - master - tags: '*' -jobs: - test: - name: Julia ${{ matrix.version }} - ${{ matrix.os }} - ${{ matrix.arch }} - ${{ github.event_name }} - runs-on: ${{ matrix.os }} - strategy: - fail-fast: false - matrix: - version: - - '1' # Leave this line unchanged. '1' will automatically expand to the latest stable 1.x release of Julia. - os: - - ubuntu-latest - arch: - - x64 - python-version: - - '3.8' - steps: - - uses: actions/checkout@v2 - - name: Setup python - uses: actions/setup-python@v1 - with: - python-version: ${{ matrix.python-version }} - architecture: ${{ matrix.arch }} - - run: python -m pip install --user gym - - uses: julia-actions/setup-julia@v1 - with: - version: ${{ matrix.version }} - arch: ${{ matrix.arch }} - - uses: actions/cache@v1 - env: - cache-name: cache-artifacts - with: - path: ~/.julia/artifacts - key: ${{ runner.os }}-test-${{ env.cache-name }}-${{ hashFiles('**/Project.toml') }} - restore-keys: | - ${{ runner.os }}-test-${{ env.cache-name }}- - ${{ runner.os }}-test- - ${{ runner.os }}- - - uses: julia-actions/julia-buildpkg@v1 - - uses: julia-actions/julia-runtest@v1 - - uses: julia-actions/julia-processcoverage@v1 - - uses: codecov/codecov-action@v1 - with: - file: lcov.info diff --git a/src/ReinforcementLearningEnvironments/.github/workflows/format-pr.yml b/src/ReinforcementLearningEnvironments/.github/workflows/format-pr.yml deleted file mode 100644 index 507abce52..000000000 --- a/src/ReinforcementLearningEnvironments/.github/workflows/format-pr.yml +++ /dev/null @@ -1,37 +0,0 @@ -name: format-pr - -on: - schedule: - - cron: '0 * * * *' -jobs: - build: - runs-on: ${{ matrix.os }} - strategy: - matrix: - julia-version: [1.3.0] - julia-arch: [x86] - os: [ubuntu-latest] - steps: - - uses: julia-actions/setup-julia@latest - with: - version: ${{ matrix.julia-version }} - - - uses: actions/checkout@v2 - - name: Install JuliaFormatter and format - run: | - julia -e 'import Pkg; Pkg.add("JuliaFormatter")' - julia -e 'using JuliaFormatter; format(".";verbose=true, always_for_in=true)' - - # https://github.com/marketplace/actions/create-pull-request - - name: Create Pull Request - uses: peter-evans/create-pull-request@v2 - with: - token: ${{ secrets.GITHUB_TOKEN }} - commit-message: Format .jl files - title: 'Automatic JuliaFormatter.jl run' - branch: auto-juliaformatter-pr - labels: formatting, automated pr, no changelog - - name: Check outputs - run: | - echo 'Pull Request Number - ${{ env.PULL_REQUEST_NUMBER }}' - echo 'Pull Request Number - ${{ steps.cpr.outputs.pr_number }}' diff --git a/src/ReinforcementLearningEnvironments/.gitignore b/src/ReinforcementLearningEnvironments/.gitignore deleted file mode 100644 index 554052cd7..000000000 --- a/src/ReinforcementLearningEnvironments/.gitignore +++ /dev/null @@ -1,13 +0,0 @@ -*.jl.cov -*.jl.*.cov -*.jl.mem -deps/deps.jl - -Manifest.toml - -_vizdoom.ini - -.vscode/* -!.vscode/tasks.json -!.vscode/launch.json -!.vscode/extensions.json diff --git a/src/ReinforcementLearningEnvironments/Artifacts.toml b/src/ReinforcementLearningEnvironments/Artifacts.toml index 10da5fa9c..88d452aa2 100644 --- a/src/ReinforcementLearningEnvironments/Artifacts.toml +++ b/src/ReinforcementLearningEnvironments/Artifacts.toml @@ -3,4 +3,4 @@ git-tree-sha1 = "c2ef05aa70df44749bd43b2ab9a558ea6829b32b" [[stock_trading_data.download]] url = "https://github.com/JuliaReinforcementLearning/ReinforcementLearning.jl/releases/download/v0.9.0/stock_trading_data.tar.gz" - sha256 = "2abc589a9dfb5b2134ee531152bd361b08629938ea3bf53fe56270517d732c89" \ No newline at end of file + sha256 = "2abc589a9dfb5b2134ee531152bd361b08629938ea3bf53fe56270517d732c89" diff --git a/src/ReinforcementLearningEnvironments/Dockerfile b/src/ReinforcementLearningEnvironments/Dockerfile deleted file mode 100644 index 94809a2ef..000000000 --- a/src/ReinforcementLearningEnvironments/Dockerfile +++ /dev/null @@ -1,35 +0,0 @@ -FROM julia:1.3 - -# install dependencies -RUN set -eux; \ - apt-get update; \ - apt-get install -y --no-install-recommends \ - cmake \ - build-essential \ - # ArcadeLearningEnvironment - libz-dev \ - unzip \ - # ViZDoom - wget \ - libboost-all-dev \ - build-essential zlib1g-dev libsdl2-dev libjpeg-dev \ - nasm tar libbz2-dev libgtk2.0-dev cmake git libfluidsynth-dev libgme-dev \ - libopenal-dev timidity libwildmidi-dev unzip \ - # PyCall OpenAI Gym - python3 \ - python3-pip \ - python3-dev \ - python3-setuptools; - -RUN ln -s /usr/bin/pip3 /usr/bin/pip; \ - ln -s /usr/bin/python3 /usr/bin/python; \ - pip install wheel gym; - -ADD . /jl_pkg -WORKDIR /jl_pkg - -# Following line can be removed after Hanabi.jl get registered. -RUN julia --color=yes -e 'using Pkg; Pkg.add(PackageSpec(url="https://github.com/findmyway/Hanabi.jl", rev="master"))' -RUN julia --color=yes -e 'using Pkg; Pkg.clone(pwd()); Pkg.build("ReinforcementLearningEnvironments"; verbose=true); Pkg.test("ReinforcementLearningEnvironments"; coverage=true)' - -CMD ["julia"] \ No newline at end of file diff --git a/src/ReinforcementLearningEnvironments/Manifest.toml b/src/ReinforcementLearningEnvironments/Manifest.toml deleted file mode 100644 index efa40d365..000000000 --- a/src/ReinforcementLearningEnvironments/Manifest.toml +++ /dev/null @@ -1,244 +0,0 @@ -# This file is machine-generated - editing it directly is not advised - -[[AbstractTrees]] -git-tree-sha1 = "03e0550477d86222521d254b741d470ba17ea0b5" -uuid = "1520ce14-60c1-5f80-bbc7-55ef81b5835c" -version = "0.3.4" - -[[ArgTools]] -uuid = "0dad84c5-d112-42e6-8d28-ef12dabb789f" - -[[ArrayInterface]] -deps = ["IfElse", "LinearAlgebra", "Requires", "SparseArrays", "Static"] -git-tree-sha1 = "b09fe16aa9dc587cccce838e6cb6d6e1f4831d7f" -uuid = "4fba245c-0d91-5ea0-9b3e-6abc04ee57a9" -version = "3.1.12" - -[[Artifacts]] -uuid = "56f22d72-fd6d-98f1-02f0-08ddc0907c33" - -[[Base64]] -uuid = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f" - -[[CommonRLInterface]] -deps = ["MacroTools"] -git-tree-sha1 = "21de56ebf28c262651e682f7fe614d44623dc087" -uuid = "d842c3ba-07a1-494f-bbec-f5741b0a3e98" -version = "0.3.1" - -[[Compat]] -deps = ["Base64", "Dates", "DelimitedFiles", "Distributed", "InteractiveUtils", "LibGit2", "Libdl", "LinearAlgebra", "Markdown", "Mmap", "Pkg", "Printf", "REPL", "Random", "SHA", "Serialization", "SharedArrays", "Sockets", "SparseArrays", "Statistics", "Test", "UUIDs", "Unicode"] -git-tree-sha1 = "0900bc19193b8e672d9cd477e6cd92d9e7c02f99" -uuid = "34da2185-b29b-5c13-b0c7-acf172513d20" -version = "3.29.0" - -[[DataAPI]] -git-tree-sha1 = "dfb3b7e89e395be1e25c2ad6d7690dc29cc53b1d" -uuid = "9a962f9c-6df0-11e9-0e5d-c546b8b5ee8a" -version = "1.6.0" - -[[DataStructures]] -deps = ["Compat", "InteractiveUtils", "OrderedCollections"] -git-tree-sha1 = "4437b64df1e0adccc3e5d1adbc3ac741095e4677" -uuid = "864edb3b-99cc-5e75-8d2d-829cb0a9cfe8" -version = "0.18.9" - -[[Dates]] -deps = ["Printf"] -uuid = "ade2ca70-3891-5945-98fb-dc099432e06a" - -[[DelimitedFiles]] -deps = ["Mmap"] -uuid = "8bb1440f-4735-579b-a4ab-409b98df4dab" - -[[Distributed]] -deps = ["Random", "Serialization", "Sockets"] -uuid = "8ba89e20-285c-5b6f-9357-94700520ee1b" - -[[Downloads]] -deps = ["ArgTools", "LibCURL", "NetworkOptions"] -uuid = "f43a241f-c20a-4ad4-852c-f6b1247861c6" - -[[EllipsisNotation]] -deps = ["ArrayInterface"] -git-tree-sha1 = "8041575f021cba5a099a456b4163c9a08b566a02" -uuid = "da5c29d0-fa7d-589e-88eb-ea29b0a81949" -version = "1.1.0" - -[[IfElse]] -git-tree-sha1 = "28e837ff3e7a6c3cdb252ce49fb412c8eb3caeef" -uuid = "615f187c-cbe4-4ef1-ba3b-2fcf58d6d173" -version = "0.1.0" - -[[InteractiveUtils]] -deps = ["Markdown"] -uuid = "b77e0a4c-d291-57a0-90e8-8db25a27a240" - -[[IntervalSets]] -deps = ["Dates", "EllipsisNotation", "Statistics"] -git-tree-sha1 = "3cc368af3f110a767ac786560045dceddfc16758" -uuid = "8197267c-284f-5f27-9208-e0e47529a953" -version = "0.5.3" - -[[LibCURL]] -deps = ["LibCURL_jll", "MozillaCACerts_jll"] -uuid = "b27032c2-a3e7-50c8-80cd-2d36dbcbfd21" - -[[LibCURL_jll]] -deps = ["Artifacts", "LibSSH2_jll", "Libdl", "MbedTLS_jll", "Zlib_jll", "nghttp2_jll"] -uuid = "deac9b47-8bc7-5906-a0fe-35ac56dc84c0" - -[[LibGit2]] -deps = ["Base64", "NetworkOptions", "Printf", "SHA"] -uuid = "76f85450-5226-5b5a-8eaa-529ad045b433" - -[[LibSSH2_jll]] -deps = ["Artifacts", "Libdl", "MbedTLS_jll"] -uuid = "29816b5a-b9ab-546f-933c-edad1886dfa8" - -[[Libdl]] -uuid = "8f399da3-3557-5675-b5ff-fb832c97cbdb" - -[[LinearAlgebra]] -deps = ["Libdl"] -uuid = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e" - -[[Logging]] -uuid = "56ddb016-857b-54e1-b83d-db4d58db5568" - -[[MacroTools]] -deps = ["Markdown", "Random"] -git-tree-sha1 = "6a8a2a625ab0dea913aba95c11370589e0239ff0" -uuid = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09" -version = "0.5.6" - -[[Markdown]] -deps = ["Base64"] -uuid = "d6f4376e-aef5-505a-96c1-9c027394607a" - -[[MbedTLS_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "c8ffd9c3-330d-5841-b78e-0817d7145fa1" - -[[Missings]] -deps = ["DataAPI"] -git-tree-sha1 = "4ea90bd5d3985ae1f9a908bd4500ae88921c5ce7" -uuid = "e1d29d7a-bbdc-5cf2-9ac0-f12de2c33e28" -version = "1.0.0" - -[[Mmap]] -uuid = "a63ad114-7e13-5084-954f-fe012c677804" - -[[MozillaCACerts_jll]] -uuid = "14a3606d-f60d-562e-9121-12d972cd8159" - -[[NetworkOptions]] -uuid = "ca575930-c2e3-43a9-ace4-1e988b2c1908" - -[[OrderedCollections]] -git-tree-sha1 = "85f8e6578bf1f9ee0d11e7bb1b1456435479d47c" -uuid = "bac558e1-5e72-5ebc-8fee-abe8a469f55d" -version = "1.4.1" - -[[Pkg]] -deps = ["Artifacts", "Dates", "Downloads", "LibGit2", "Libdl", "Logging", "Markdown", "Printf", "REPL", "Random", "SHA", "Serialization", "TOML", "Tar", "UUIDs", "p7zip_jll"] -uuid = "44cfe95a-1eb2-52ea-b672-e2afdf69b78f" - -[[Printf]] -deps = ["Unicode"] -uuid = "de0858da-6303-5e67-8744-51eddeeeb8d7" - -[[REPL]] -deps = ["InteractiveUtils", "Markdown", "Sockets", "Unicode"] -uuid = "3fa0cd96-eef1-5676-8a61-b3b8758bbffb" - -[[Random]] -deps = ["Serialization"] -uuid = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c" - -[[ReinforcementLearningBase]] -deps = ["AbstractTrees", "CommonRLInterface", "Markdown", "Random", "Test"] -path = "../ReinforcementLearningBase" -uuid = "e575027e-6cd6-5018-9292-cdc6200d2b44" -version = "0.9.7" - -[[Requires]] -deps = ["UUIDs"] -git-tree-sha1 = "4036a3bd08ac7e968e27c203d45f5fff15020621" -uuid = "ae029012-a4dd-5104-9daa-d747884805df" -version = "1.1.3" - -[[SHA]] -uuid = "ea8e919c-243c-51af-8825-aaa63cd721ce" - -[[Serialization]] -uuid = "9e88b42a-f829-5b0c-bbe9-9e923198166b" - -[[SharedArrays]] -deps = ["Distributed", "Mmap", "Random", "Serialization"] -uuid = "1a1011a3-84de-559e-8e89-a11a2f7dc383" - -[[Sockets]] -uuid = "6462fe0b-24de-5631-8697-dd941f90decc" - -[[SortingAlgorithms]] -deps = ["DataStructures"] -git-tree-sha1 = "2ec1962eba973f383239da22e75218565c390a96" -uuid = "a2af1166-a08f-5f64-846c-94a0d3cef48c" -version = "1.0.0" - -[[SparseArrays]] -deps = ["LinearAlgebra", "Random"] -uuid = "2f01184e-e22b-5df5-ae63-d93ebab69eaf" - -[[Static]] -deps = ["IfElse"] -git-tree-sha1 = "ddec5466a1d2d7e58adf9a427ba69763661aacf6" -uuid = "aedffcd0-7271-4cad-89d0-dc628f76c6d3" -version = "0.2.4" - -[[Statistics]] -deps = ["LinearAlgebra", "SparseArrays"] -uuid = "10745b16-79ce-11e8-11f9-7d13ad32a3b2" - -[[StatsAPI]] -git-tree-sha1 = "1958272568dc176a1d881acb797beb909c785510" -uuid = "82ae8749-77ed-4fe6-ae5f-f523153014b0" -version = "1.0.0" - -[[StatsBase]] -deps = ["DataAPI", "DataStructures", "LinearAlgebra", "Missings", "Printf", "Random", "SortingAlgorithms", "SparseArrays", "Statistics", "StatsAPI"] -git-tree-sha1 = "2f6792d523d7448bbe2fec99eca9218f06cc746d" -uuid = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91" -version = "0.33.8" - -[[TOML]] -deps = ["Dates"] -uuid = "fa267f1f-6049-4f14-aa54-33bafae1ed76" - -[[Tar]] -deps = ["ArgTools", "SHA"] -uuid = "a4e569a6-e804-4fa4-b0f3-eef7a1d5b13e" - -[[Test]] -deps = ["InteractiveUtils", "Logging", "Random", "Serialization"] -uuid = "8dfed614-e22c-5e08-85e1-65c5234f0b40" - -[[UUIDs]] -deps = ["Random", "SHA"] -uuid = "cf7118a7-6976-5b1a-9a39-7adc72f591a4" - -[[Unicode]] -uuid = "4ec0a83e-493e-50e2-b9ac-8f72acf5a8f5" - -[[Zlib_jll]] -deps = ["Libdl"] -uuid = "83775a58-1f1d-513f-b197-d71354ab007a" - -[[nghttp2_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "8e850ede-7688-5339-a07c-302acd2aaf8d" - -[[p7zip_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "3f19e933-33d8-53b3-aaab-bd5110c3b7a0" diff --git a/src/ReinforcementLearningEnvironments/Project.toml b/src/ReinforcementLearningEnvironments/Project.toml index c447338ef..7915d98dd 100644 --- a/src/ReinforcementLearningEnvironments/Project.toml +++ b/src/ReinforcementLearningEnvironments/Project.toml @@ -1,10 +1,11 @@ name = "ReinforcementLearningEnvironments" uuid = "25e41dd2-4622-11e9-1641-f1adca772921" authors = ["Jun Tian "] -version = "0.6.12" +version = "0.7.0-dev" [deps] DelimitedFiles = "8bb1440f-4735-579b-a4ab-409b98df4dab" +FillArrays = "1a297f60-69ca-5386-bcde-b61e274b549b" IntervalSets = "8197267c-284f-5f27-9208-e0e47529a953" LinearAlgebra = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e" MacroTools = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09" @@ -17,16 +18,15 @@ SparseArrays = "2f01184e-e22b-5df5-ae63-d93ebab69eaf" StatsBase = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91" [compat] -IntervalSets = "0.5" +IntervalSets = "0.7" MacroTools = "0.5" -ReinforcementLearningBase = "0.9.2" +ReinforcementLearningBase = "0.10" Requires = "1.0" StatsBase = "0.32, 0.33" julia = "1.3" [extras] ArcadeLearningEnvironment = "b7f77d8d-088d-5e02-8ac0-89aab2acc977" -OpenSpiel = "ceb70bd2-fe3f-44f0-b81f-41608acaf2f2" OrdinaryDiffEq = "1dea7af3-3e70-54e6-95c3-0bf5283fa5ed" PyCall = "438e738f-606a-5dbb-bf0a-cddfbfd45ab0" StableRNGs = "860ef19b-820b-49d6-a774-d7a799459cd3" @@ -34,4 +34,4 @@ Statistics = "10745b16-79ce-11e8-11f9-7d13ad32a3b2" Test = "8dfed614-e22c-5e08-85e1-65c5234f0b40" [targets] -test = ["ArcadeLearningEnvironment", "OpenSpiel", "OrdinaryDiffEq", "PyCall", "StableRNGs", "Statistics", "Test"] +test = ["ArcadeLearningEnvironment", "OrdinaryDiffEq", "PyCall", "StableRNGs", "Statistics", "Test"] diff --git a/src/ReinforcementLearningEnvironments/src/ReinforcementLearningEnvironments.jl b/src/ReinforcementLearningEnvironments/src/ReinforcementLearningEnvironments.jl index f3d2dd7e9..dfd1f0ee8 100644 --- a/src/ReinforcementLearningEnvironments/src/ReinforcementLearningEnvironments.jl +++ b/src/ReinforcementLearningEnvironments/src/ReinforcementLearningEnvironments.jl @@ -4,7 +4,7 @@ using ReinforcementLearningBase using Random using Requires using IntervalSets -using Base.Threads:@spawn +using Base.Threads: @spawn using Markdown const RLEnvs = ReinforcementLearningEnvironments @@ -31,9 +31,7 @@ function __init__() @require OrdinaryDiffEq = "1dea7af3-3e70-54e6-95c3-0bf5283fa5ed" include( "environments/3rd_party/AcrobotEnv.jl", ) - @require Plots = "91a5bcdd-55d7-5caf-9e0b-520d859cae80" include( - "plots.jl", - ) + @require Plots = "91a5bcdd-55d7-5caf-9e0b-520d859cae80" include("plots.jl") end diff --git a/src/ReinforcementLearningEnvironments/src/environments/3rd_party/AcrobotEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/3rd_party/AcrobotEnv.jl index d3b0c452b..f217417ad 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/3rd_party/AcrobotEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/3rd_party/AcrobotEnv.jl @@ -19,23 +19,23 @@ - `avail_torque = [T(-1.), T(0.), T(1.)]` """ function AcrobotEnv(; - T=Float64, - link_length_a=T(1.0), - link_length_b=T(1.0), - link_mass_a=T(1.0), - link_mass_b=T(1.0), - link_com_pos_a=T(0.5), - link_com_pos_b=T(0.5), - link_moi=T(1.0), - max_torque_noise=T(0.0), - max_vel_a=T(4 * π), - max_vel_b=T(9 * π), - g=T(9.8), - dt=T(0.2), - max_steps=200, - rng=Random.GLOBAL_RNG, - book_or_nips="book", - avail_torque=[T(-1.0), T(0.0), T(1.0)], + T = Float64, + link_length_a = T(1.0), + link_length_b = T(1.0), + link_mass_a = T(1.0), + link_mass_b = T(1.0), + link_com_pos_a = T(0.5), + link_com_pos_b = T(0.5), + link_moi = T(1.0), + max_torque_noise = T(0.0), + max_vel_a = T(4 * π), + max_vel_b = T(9 * π), + g = T(9.8), + dt = T(0.2), + max_steps = 200, + rng = Random.GLOBAL_RNG, + book_or_nips = "book", + avail_torque = [T(-1.0), T(0.0), T(1.0)], ) params = AcrobotEnvParams{T}( @@ -71,18 +71,24 @@ end acrobot_observation(s) = [cos(s[1]), sin(s[1]), cos(s[2]), sin(s[2]), s[3], s[4]] -RLBase.action_space(env::AcrobotEnv) = Base.OneTo(3) - -function RLBase.state_space(env::AcrobotEnv{T}) where {T} - high = [1.0, 1.0, 1.0, 1.0, env.params.max_vel_a, env.params.max_vel_b] - Space(ClosedInterval{T}.(-high, high)) -end +RLBase.action_space(env::AcrobotEnv) = Space(OneTo(3)) + +RLBase.state_space(env::AcrobotEnv) = Space( + SVector( + -1.0 .. 1.0, + -1.0 .. 1.0, + -1.0 .. 1.0, + -1.0 .. 1.0, + -env.params.max_vel_a .. env.params.max_vel_a, + -env.params.max_vel_b .. env.params.max_vel_b, + ), +) RLBase.is_terminated(env::AcrobotEnv) = env.done RLBase.state(env::AcrobotEnv) = acrobot_observation(env.state) RLBase.reward(env::AcrobotEnv) = env.reward -function RLBase.reset!(env::AcrobotEnv{T}) where {T <: Number} +function RLBase.reset!(env::AcrobotEnv{T}) where {T<:Number} env.state[:] = T(0.1) * rand(env.rng, T, 4) .- T(0.05) env.t = 0 env.action = 2 @@ -92,7 +98,7 @@ function RLBase.reset!(env::AcrobotEnv{T}) where {T <: Number} end # governing equations as per python gym -function (env::AcrobotEnv{T})(a) where {T <: Number} +function (env::AcrobotEnv{T})(a) where {T<:Number} env.action = a env.t += 1 torque = env.avail_torque[a] @@ -138,7 +144,7 @@ function dsdt(du, s_augmented, env::AcrobotEnv, t) # extract action and state a = s_augmented[end] - s = s_augmented[1:end - 1] + s = s_augmented[1:end-1] # writing in standard form theta1 = s[1] @@ -202,7 +208,7 @@ function wrap(x, m, M) while x < m x = x + diff end -return x + return x end function bound(x, m, M) diff --git a/src/ReinforcementLearningEnvironments/src/environments/3rd_party/atari.jl b/src/ReinforcementLearningEnvironments/src/environments/3rd_party/atari.jl index 61dc54095..b62d72607 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/3rd_party/atari.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/3rd_party/atari.jl @@ -60,17 +60,10 @@ function AtariEnv(; observation_size = grayscale_obs ? (getScreenWidth(ale), getScreenHeight(ale)) : (3, getScreenWidth(ale), getScreenHeight(ale)) # !!! note the order - observation_space = Space( - ClosedInterval{ - Cuchar, - }.( - fill(typemin(Cuchar), observation_size), - fill(typemax(Cuchar), observation_size), - ), - ) + observation_space = Space(Cuchar, observation_size...) actions = full_action_space ? getLegalActionSet(ale) : getMinimalActionSet(ale) - action_space = Base.OneTo(length(actions)) + action_space = Space(OneTo(length(actions))) screens = (fill(typemin(Cuchar), observation_size), fill(typemin(Cuchar), observation_size)) diff --git a/src/ReinforcementLearningEnvironments/src/environments/3rd_party/gym.jl b/src/ReinforcementLearningEnvironments/src/environments/3rd_party/gym.jl index 33ac9ea86..0f0902310 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/3rd_party/gym.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/3rd_party/gym.jl @@ -1,13 +1,15 @@ using .PyCall -function GymEnv(name::String; seed::Union{Int, Nothing}=nothing) +function GymEnv(name::String; seed::Union{Int,Nothing} = nothing) if !PyCall.pyexists("gym") error( "Cannot import module 'gym'.\n\nIf you did not yet install it, try running\n`ReinforcementLearningEnvironments.install_gym()`\n", ) end gym = pyimport_conda("gym", "gym") - if PyCall.pyexists("d4rl") pyimport("d4rl") end + if PyCall.pyexists("d4rl") + pyimport("d4rl") + end pyenv = try gym.make(name) catch e @@ -15,7 +17,9 @@ function GymEnv(name::String; seed::Union{Int, Nothing}=nothing) "Gym environment $name not found.\n\nRun `ReinforcementLearningEnvironments.list_gym_env_names()` to find supported environments.\n", ) end - if seed !== nothing pyenv.seed(seed) end + if seed !== nothing + pyenv.seed(seed) + end obs_space = space_transform(pyenv.observation_space) act_space = space_transform(pyenv.action_space) obs_type = if obs_space isa Space{<:Union{Array{<:Interval},Array{<:ZeroTo}}} @@ -103,15 +107,15 @@ function space_transform(s::PyObject) if spacetype == "Box" Space(ClosedInterval.(s.low, s.high)) elseif spacetype == "Discrete" # for GymEnv("CliffWalking-v0"), `s.n` is of type PyObject (numpy.int64) - ZeroTo(py"int($s.n)" - 1) + Space(0:(py"int($s.n)"-1)) elseif spacetype == "MultiBinary" - Space(ZeroTo.(ones(Int8, s.n))) + Space(Bool, s.n) elseif spacetype == "MultiDiscrete" - Space(ZeroTo.(s.nvec .- one(eltype(s.nvec)))) + Space(map(x -> 0:x-one(typeof(x)), s.nvec)) elseif spacetype == "Tuple" - Space(Tuple(space_transform(x) for x in s.spaces)) + Tuple(space_transform(x) for x in s.spaces) elseif spacetype == "Dict" - Space(Dict((k => space_transform(v) for (k, v) in s.spaces)...)) + Dict((k => space_transform(v) for (k, v) in s.spaces)...) else error("Don't know how to convert Gym Space of class [$(spacetype)]") end @@ -139,10 +143,12 @@ function list_gym_env_names(; "d4rl.gym_bullet.gym_envs", "d4rl.pointmaze_bullet.bullet_maze", # yet to include flow and carla ], -) - if PyCall.pyexists("d4rl") pyimport("d4rl") end +) + if PyCall.pyexists("d4rl") + pyimport("d4rl") + end gym = pyimport("gym") - [x.id for x in gym.envs.registry.all() if split(x.entry_point, ':')[1] in modules] + [x.id for x in values(gym.envs.registry) if split(x.entry_point, ':')[1] in modules] end """ diff --git a/src/ReinforcementLearningEnvironments/src/environments/3rd_party/structs.jl b/src/ReinforcementLearningEnvironments/src/environments/3rd_party/structs.jl index 83586f4e3..0e2986c7d 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/3rd_party/structs.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/3rd_party/structs.jl @@ -6,13 +6,13 @@ struct GymEnv{T,Ta,To,P} <: AbstractEnv end export GymEnv -mutable struct AtariEnv{IsGrayScale,TerminalOnLifeLoss,N,S <: AbstractRNG} <: AbstractEnv +mutable struct AtariEnv{IsGrayScale,TerminalOnLifeLoss,N,S<:AbstractRNG} <: AbstractEnv ale::Ptr{Nothing} name::String screens::Tuple{Array{UInt8,N},Array{UInt8,N}} # for max-pooling actions::Vector{Int} - action_space::Base.OneTo{Int} - observation_space::Space{Array{ClosedInterval{UInt8},N}} + action_space::Space + observation_space::Space noopmax::Int frame_skip::Int reward::Float32 @@ -65,7 +65,7 @@ end export AcrobotEnvParams -mutable struct AcrobotEnv{T,R <: AbstractRNG} <: AbstractEnv +mutable struct AcrobotEnv{T,R<:AbstractRNG} <: AbstractEnv params::AcrobotEnvParams{T} state::Vector{T} action::Int diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/BitFlippingEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/BitFlippingEnv.jl index 2c491bf63..c2867d1a2 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/BitFlippingEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/BitFlippingEnv.jl @@ -24,7 +24,7 @@ end Random.seed!(env::BitFlippingEnv, s) = Random.seed!(env.rng, s) -RLBase.action_space(env::BitFlippingEnv) = Base.OneTo(env.N) +RLBase.action_space(env::BitFlippingEnv) = Space(OneTo(env.N)) RLBase.legal_action_space(env::BitFlippingEnv) = Base.OneTo(env.N) @@ -41,8 +41,8 @@ end RLBase.state(env::BitFlippingEnv) = state(env::BitFlippingEnv, Observation{BitArray{1}}()) RLBase.state(env::BitFlippingEnv, ::Observation) = env.state RLBase.state(env::BitFlippingEnv, ::GoalState) = env.goal_state -RLBase.state_space(env::BitFlippingEnv, ::Observation) = Space(fill(false..true, env.N)) -RLBase.state_space(env::BitFlippingEnv, ::GoalState) = Space(fill(false..true, env.N)) +RLBase.state_space(env::BitFlippingEnv, ::Observation) = Space(Bool, env.N) +RLBase.state_space(env::BitFlippingEnv, ::GoalState) = Space(Bool, env.N) RLBase.is_terminated(env::BitFlippingEnv) = (env.state == env.goal_state) || (env.t >= env.max_steps) diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/CartPoleEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/CartPoleEnv.jl index 9db3d2864..7cfb7817d 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/CartPoleEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/CartPoleEnv.jl @@ -1,5 +1,7 @@ export CartPoleEnv +using FillArrays: Trues + struct CartPoleEnvParams{T} gravity::T masscart::T @@ -19,8 +21,7 @@ Base.show(io::IO, params::CartPoleEnvParams) = print( join(["$p=$(getfield(params, p))" for p in fieldnames(CartPoleEnvParams)], ","), ) -function CartPoleEnvParams(; - T = Float64, +function CartPoleEnvParams{T}(; gravity = 9.8, masscart = 1.0, masspole = 0.1, @@ -29,8 +30,8 @@ function CartPoleEnvParams(; max_steps = 200, dt = 0.02, thetathreshold = 12.0, - xthreshold = 2.4 -) + xthreshold = 2.4, +) where {T} CartPoleEnvParams{T}( gravity, masscart, @@ -46,15 +47,13 @@ function CartPoleEnvParams(; ) end -mutable struct CartPoleEnv{A,T,ACT,R<:AbstractRNG} <: AbstractEnv +mutable struct CartPoleEnv{T,ACT} <: AbstractEnv params::CartPoleEnvParams{T} - action_space::A - observation_space::Space{Vector{ClosedInterval{T}}} state::Vector{T} action::ACT done::Bool t::Int - rng::R + rng::AbstractRNG end """ @@ -74,32 +73,9 @@ end - `thetathreshold = 12.0 # degrees` - `xthreshold` = 2.4` """ -function CartPoleEnv(; - T = Float64, - continuous = false, - rng = Random.GLOBAL_RNG, - kwargs... -) - params = CartPoleEnvParams(; T = T, kwargs...) - action_space = continuous ? ClosedInterval{T}(-1.0, 1.0) : Base.OneTo(2) - state_space = Space( - ClosedInterval{T}[ - (-2*params.xthreshold)..(2*params.xthreshold), - typemin(T)..typemax(T), - (-2*params.thetathreshold)..(2*params.thetathreshold), - typemin(T)..typemax(T), - ], - ) - env = CartPoleEnv( - params, - action_space, - state_space, - zeros(T, 4), - rand(action_space), - false, - 0, - rng, - ) +function CartPoleEnv(; T = Float64, continuous = false, rng = Random.GLOBAL_RNG, kwargs...) + params = CartPoleEnvParams{T}(; kwargs...) + env = CartPoleEnv(params, zeros(T, 4), continuous ? zero(T) : zero(Int), false, 0, rng) reset!(env) env end @@ -107,28 +83,39 @@ end CartPoleEnv{T}(; kwargs...) where {T} = CartPoleEnv(T = T, kwargs...) Random.seed!(env::CartPoleEnv, seed) = Random.seed!(env.rng, seed) -RLBase.action_space(env::CartPoleEnv) = env.action_space -RLBase.state_space(env::CartPoleEnv) = env.observation_space -RLBase.reward(env::CartPoleEnv{A,T}) where {A,T} = env.done ? zero(T) : one(T) +RLBase.reward(env::CartPoleEnv{T}) where {T} = env.done ? zero(T) : one(T) RLBase.is_terminated(env::CartPoleEnv) = env.done RLBase.state(env::CartPoleEnv) = env.state -function RLBase.reset!(env::CartPoleEnv{A,T}) where {A,T} +RLBase.state_space(env::CartPoleEnv{T}) where {T} = Space( + SVector( + (-2 * env.params.xthreshold) .. (2 * env.params.xthreshold), + typemin(T) .. typemax(T), + (-2 * env.params.thetathreshold) .. (2 * env.params.thetathreshold), + typemin(T) .. typemax(T), + ), +) + +RLBase.action_space(env::CartPoleEnv{<:AbstractFloat,Int}) = Space(OneTo(2)) +RLBase.action_space(env::CartPoleEnv{<:AbstractFloat,<:AbstractFloat}) = Space(-1.0 .. 1.0) +RLBase.legal_action_space_mask(env::CartPoleEnv) = Trues(2) + +function RLBase.reset!(env::CartPoleEnv{T}) where {T} env.state[:] = T(0.1) * rand(env.rng, T, 4) .- T(0.05) env.t = 0 - env.action = rand(env.rng, env.action_space) + env.action = rand(env.rng, action_space(env)) env.done = false nothing end -function (env::CartPoleEnv{<:ClosedInterval})(a::AbstractFloat) - @assert a in env.action_space +function (env::CartPoleEnv)(a::AbstractFloat) + @assert a in action_space(env) env.action = a _step!(env, a) end -function (env::CartPoleEnv{<:Base.OneTo{Int}})(a::Int) - @assert a in env.action_space +function (env::CartPoleEnv)(a::Int) + @assert a in action_space(env) env.action = a _step!(env, a == 2 ? 1 : -1) end diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/GraphShortestPathEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/GraphShortestPathEnv.jl index fd8c5af49..1dde23dfd 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/GraphShortestPathEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/GraphShortestPathEnv.jl @@ -5,7 +5,7 @@ using SparseArrays using LinearAlgebra -mutable struct GraphShortestPathEnv{G, R} <: AbstractEnv +mutable struct GraphShortestPathEnv{G,R} <: AbstractEnv graph::G pos::Int goal::Int @@ -31,7 +31,12 @@ Quoted **A.3** in the the paper [Decision Transformer: Reinforcement Learning vi > lengths and maximizing them corresponds to generating shortest paths. """ -function GraphShortestPathEnv(rng=Random.GLOBAL_RNG; n=20, sparsity=0.1, max_steps=10) +function GraphShortestPathEnv( + rng = Random.GLOBAL_RNG; + n = 20, + sparsity = 0.1, + max_steps = 10, +) graph = sprand(rng, Bool, n, n, sparsity) .| I(n) goal = rand(rng, 1:n) @@ -51,11 +56,12 @@ function (env::GraphShortestPathEnv)(action) end RLBase.state(env::GraphShortestPathEnv) = env.pos -RLBase.state_space(env::GraphShortestPathEnv) = axes(env.graph, 2) -RLBase.action_space(env::GraphShortestPathEnv) = axes(env.graph, 2) +RLBase.state_space(env::GraphShortestPathEnv) = Space(axes(env.graph, 2)) +RLBase.action_space(env::GraphShortestPathEnv) = Space(axes(env.graph, 2)) RLBase.legal_action_space(env::GraphShortestPathEnv) = (env.graph[:, env.pos]).nzind RLBase.reward(env::GraphShortestPathEnv) = env.reward -RLBase.is_terminated(env::GraphShortestPathEnv) = env.pos == env.goal || env.step >= env.max_steps +RLBase.is_terminated(env::GraphShortestPathEnv) = + env.pos == env.goal || env.step >= env.max_steps function RLBase.reset!(env::GraphShortestPathEnv) env.step = 0 diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/KuhnPokerEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/KuhnPokerEnv.jl index 8bd0579b7..fc27e84fe 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/KuhnPokerEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/KuhnPokerEnv.jl @@ -100,14 +100,14 @@ end RLBase.state(env::KuhnPokerEnv, ::InformationSet{Tuple{Vararg{Symbol}}}, ::ChancePlayer) = Tuple(env.cards) RLBase.state_space(env::KuhnPokerEnv, ::InformationSet{Tuple{Vararg{Symbol}}}, p) = - KUHN_POKER_STATES + Space(KUHN_POKER_STATES) -RLBase.action_space(env::KuhnPokerEnv, ::Int) = Base.OneTo(length(KUHN_POKER_ACTIONS)) +RLBase.action_space(env::KuhnPokerEnv, ::Int) = Space(OneTo(length(KUHN_POKER_ACTIONS))) RLBase.action_space(env::KuhnPokerEnv, ::ChancePlayer) = - Base.OneTo(length(KUHN_POKER_CARDS)) + Space(OneTo(length(KUHN_POKER_CARDS))) RLBase.legal_action_space(env::KuhnPokerEnv, p::ChancePlayer) = - [x for x in action_space(env, p) if KUHN_POKER_CARDS[x] ∉ env.cards] + Space(Tuple(x for x in action_space(env, p).s if KUHN_POKER_CARDS[x] ∉ env.cards)) function RLBase.legal_action_space_mask(env::KuhnPokerEnv, p::ChancePlayer) m = fill(true, 3) diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/MontyHallEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/MontyHallEnv.jl index d552ab169..3725fb473 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/MontyHallEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/MontyHallEnv.jl @@ -32,7 +32,7 @@ end Random.seed!(env::MontyHallEnv, s) = Random.seed!(env.rng, s) -RLBase.action_space(::MontyHallEnv) = Base.OneTo(3) +RLBase.action_space(::MontyHallEnv) = Space(OneTo(3)) """ In the first round, the guest has 3 options, in the second round only two @@ -66,7 +66,7 @@ function RLBase.state(env::MontyHallEnv) end end -RLBase.state_space(env::MontyHallEnv) = 1:4 +RLBase.state_space(env::MontyHallEnv) = Space(1:4) function (env::MontyHallEnv)(action) if isnothing(env.host_action) diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/MountainCarEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/MountainCarEnv.jl index 30180e4c3..44371bfdb 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/MountainCarEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/MountainCarEnv.jl @@ -39,15 +39,13 @@ function MountainCarEnvParams(; ) end -mutable struct MountainCarEnv{A,T,ACT,R<:AbstractRNG} <: AbstractEnv +mutable struct MountainCarEnv{T,ACT} <: AbstractEnv params::MountainCarEnvParams{T} - action_space::A - observation_space::Space{Vector{ClosedInterval{T}}} state::Vector{T} action::ACT done::Bool t::Int - rng::R + rng::AbstractRNG end """ @@ -77,17 +75,7 @@ function MountainCarEnv(; else params = MountainCarEnvParams(; T = T, kwargs...) end - action_space = continuous ? ClosedInterval{T}(-1.0, 1.0) : Base.OneTo(3) - env = MountainCarEnv( - params, - action_space, - Space([params.min_pos..params.max_pos, -params.max_speed..params.max_speed]), - zeros(T, 2), - rand(action_space), - false, - 0, - rng, - ) + env = MountainCarEnv(params, zeros(T, 2), continuous ? 0.0 : 0, false, 0, rng) reset!(env) env end @@ -96,13 +84,21 @@ ContinuousMountainCarEnv(; kwargs...) = MountainCarEnv(; continuous = true, kwar Random.seed!(env::MountainCarEnv, seed) = Random.seed!(env.rng, seed) -RLBase.action_space(env::MountainCarEnv) = env.action_space -RLBase.state_space(env::MountainCarEnv) = env.observation_space -RLBase.reward(env::MountainCarEnv{A,T}) where {A,T} = env.done ? zero(T) : -one(T) +RLBase.state_space(env::MountainCarEnv) = Space( + SVector( + env.params.min_pos .. env.params.max_pos, + -env.params.max_speed .. env.params.max_speed, + ), +) + +RLBase.action_space(::MountainCarEnv{<:AbstractFloat,Int}) = Space(OneTo(3)) +RLBase.action_space(::MountainCarEnv{<:AbstractFloat,<:AbstractFloat}) = Space(-1.0 .. 1.0) + +RLBase.reward(env::MountainCarEnv{T}) where {T} = env.done ? zero(T) : -one(T) RLBase.is_terminated(env::MountainCarEnv) = env.done RLBase.state(env::MountainCarEnv) = env.state -function RLBase.reset!(env::MountainCarEnv{A,T}) where {A,T} +function RLBase.reset!(env::MountainCarEnv{T}) where {T} env.state[1] = 0.2 * rand(env.rng, T) - 0.6 env.state[2] = 0.0 env.done = false @@ -110,14 +106,14 @@ function RLBase.reset!(env::MountainCarEnv{A,T}) where {A,T} nothing end -function (env::MountainCarEnv{<:ClosedInterval})(a::AbstractFloat) - @assert a in env.action_space +function (env::MountainCarEnv)(a::AbstractFloat) + @assert a in action_space(env) env.action = a _step!(env, a) end -function (env::MountainCarEnv{<:Base.OneTo{Int}})(a::Int) - @assert a in env.action_space +function (env::MountainCarEnv)(a::Int) + @assert a in action_space(env) env.action = a _step!(env, a - 2) end diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/MultiArmBanditsEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/MultiArmBanditsEnv.jl index 29d7c8304..4fa7ed4d4 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/MultiArmBanditsEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/MultiArmBanditsEnv.jl @@ -38,7 +38,7 @@ environment, the possible actions are `1` to `k` (which equals to require that the action space must be of `Base.OneTo`. However, it's the algorithm designer's job to do the checking and conversion. """ -RLBase.action_space(env::MultiArmBanditsEnv) = Base.OneTo(length(env.true_values)) +RLBase.action_space(env::MultiArmBanditsEnv) = Space(OneTo(length(env.true_values))) """ In our design, the return of taking an action in `env` is **undefined**. This is @@ -70,7 +70,7 @@ state is after each action. So here we can simply set it to a constant `1`. """ RLBase.state(env::MultiArmBanditsEnv) = 1 -RLBase.state_space(env::MultiArmBanditsEnv) = Base.OneTo(1) +RLBase.state_space(env::MultiArmBanditsEnv) = Space(OneTo(1)) function RLBase.reset!(env::MultiArmBanditsEnv) env.is_terminated = false diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/PendulumEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/PendulumEnv.jl index d944c3105..a6efc1cf9 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/PendulumEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/PendulumEnv.jl @@ -10,15 +10,13 @@ struct PendulumEnvParams{T} max_steps::Int end -mutable struct PendulumEnv{A,T,R<:AbstractRNG} <: AbstractEnv +mutable struct PendulumEnv{C,T} <: AbstractEnv params::PendulumEnvParams{T} - action_space::A action::T - observation_space::Space{Vector{ClosedInterval{T}}} state::Vector{T} done::Bool t::Int - rng::R + rng::AbstractRNG reward::T n_actions::Int end @@ -53,13 +51,9 @@ function PendulumEnv(; n_actions::Int = 3, rng = Random.GLOBAL_RNG, ) - high = T.([1, 1, max_speed]) - action_space = continuous ? -2.0..2.0 : Base.OneTo(n_actions) - env = PendulumEnv( + env = PendulumEnv{continuous,T}( PendulumEnvParams(max_speed, max_torque, g, m, l, dt, max_steps), - action_space, zero(T), - Space(ClosedInterval{T}.(-high, high)), zeros(T, 2), false, 0, @@ -76,8 +70,10 @@ Random.seed!(env::PendulumEnv, seed) = Random.seed!(env.rng, seed) pendulum_observation(s) = [cos(s[1]), sin(s[1]), s[2]] angle_normalize(x) = Base.mod((x + Base.π), (2 * Base.π)) - Base.π -RLBase.action_space(env::PendulumEnv) = env.action_space -RLBase.state_space(env::PendulumEnv) = env.observation_space +RLBase.action_space(env::PendulumEnv{true}) = Space(-2.0 .. 2.0) +RLBase.action_space(env::PendulumEnv{false}) = Space(OneTo(env.n_actions)) +RLBase.state_space(env::PendulumEnv) = + Space(SVector(-1.0 .. 1.0, -1.0 .. 1.0, -env.params.max_speed .. env.params.max_speed)) RLBase.reward(env::PendulumEnv) = env.reward RLBase.is_terminated(env::PendulumEnv) = env.done RLBase.state(env::PendulumEnv) = pendulum_observation(env.state) @@ -92,8 +88,8 @@ function RLBase.reset!(env::PendulumEnv{A,T}) where {A,T} nothing end -function (env::PendulumEnv)(a::Union{Int, AbstractFloat}) - @assert a in env.action_space +function (env::PendulumEnv)(a) + @assert a in action_space(env) env.action = torque(env, a) _step!(env, env.action) end @@ -118,8 +114,6 @@ function _step!(env::PendulumEnv, a) nothing end -function torque(env::PendulumEnv{<:Base.OneTo}, a::Int) - return (4 / (env.n_actions - 1)) * (a - (env.n_actions - 1) / 2 - 1) -end - -torque(env::PendulumEnv{<:ClosedInterval}, a::AbstractFloat) = a +torque(env::PendulumEnv{false}, a::Int) = + (4 / (env.n_actions - 1)) * (a - (env.n_actions - 1) / 2 - 1) +torque(env::PendulumEnv{true}, a::AbstractFloat) = a diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/PigEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/PigEnv.jl index 1026ac8cc..a1b7ab041 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/PigEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/PigEnv.jl @@ -29,14 +29,15 @@ end RLBase.current_player(env::PigEnv) = env.is_chance_player_active ? CHANCE_PLAYER : env.current_player RLBase.players(env::PigEnv) = 1:length(env.scores) -RLBase.action_space(env::PigEnv, ::Int) = (:roll, :hold) -RLBase.action_space(env::PigEnv, ::ChancePlayer) = Base.OneTo(PIG_N_SIDES) +RLBase.action_space(env::PigEnv, ::Int) = Space((:roll, :hold)) +RLBase.action_space(env::PigEnv, ::ChancePlayer) = Space(OneTo(PIG_N_SIDES)) RLBase.prob(env::PigEnv, ::ChancePlayer) = fill(1 / 6, 6) # TODO: uniform distribution, more memory efficient RLBase.state(env::PigEnv, ::Observation{Vector{Int}}, p) = env.scores -RLBase.state_space(env::PigEnv, ::Observation, p) = - Space([0..(PIG_TARGET_SCORE + PIG_N_SIDES - 1) for _ in env.scores]) +RLBase.state_space(env::PigEnv, ::Observation, p) = Space( + SVector(ntuple(_ -> 0 .. (PIG_TARGET_SCORE + PIG_N_SIDES - 1), length(env.scores))), +) RLBase.is_terminated(env::PigEnv) = any(s >= PIG_TARGET_SCORE for s in env.scores) diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/RandomWalk1D.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/RandomWalk1D.jl index 2356c5da2..3f6c7b9b3 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/RandomWalk1D.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/RandomWalk1D.jl @@ -21,14 +21,14 @@ Base.@kwdef mutable struct RandomWalk1D <: AbstractEnv pos::Int = start_pos end -RLBase.action_space(env::RandomWalk1D) = Base.OneTo(length(env.actions)) +RLBase.action_space(env::RandomWalk1D) = Space(OneTo(length(env.actions))) function (env::RandomWalk1D)(action) env.pos = max(min(env.pos + env.actions[action], env.N), 1) end RLBase.state(env::RandomWalk1D) = env.pos -RLBase.state_space(env::RandomWalk1D) = Base.OneTo(env.N) +RLBase.state_space(env::RandomWalk1D) = Space(OneTo(env.N)) RLBase.is_terminated(env::RandomWalk1D) = env.pos == 1 || env.pos == env.N RLBase.reset!(env::RandomWalk1D) = env.pos = env.start_pos diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/RockPaperScissorsEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/RockPaperScissorsEnv.jl index 7588215b2..db70f2543 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/RockPaperScissorsEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/RockPaperScissorsEnv.jl @@ -22,10 +22,10 @@ RLBase.current_player(::RockPaperScissorsEnv) = SIMULTANEOUS_PLAYER # Defining the `action_space` of each independent player can help to transform # this SIMULTANEOUS environment into a SEQUENTIAL environment with # [`simultaneous2sequential`](@ref). -RLBase.action_space(::RockPaperScissorsEnv, ::Int) = ('💎', '📃', '✂') +RLBase.action_space(::RockPaperScissorsEnv, ::Int) = Space(('💎', '📃', '✂')) RLBase.action_space(::RockPaperScissorsEnv, ::SimultaneousPlayer) = - Tuple((i, j) for i in ('💎', '📃', '✂') for j in ('💎', '📃', '✂')) + Space(Tuple((i, j) for i in ('💎', '📃', '✂') for j in ('💎', '📃', '✂'))) RLBase.action_space(env::RockPaperScissorsEnv) = action_space(env, SIMULTANEOUS_PLAYER) @@ -33,7 +33,7 @@ RLBase.legal_action_space(env::RockPaperScissorsEnv, p) = is_terminated(env) ? () : action_space(env, p) "Since it's a one-shot game, the state space doesn't have much meaning." -RLBase.state_space(::RockPaperScissorsEnv, ::Observation, p) = Base.OneTo(1) +RLBase.state_space(::RockPaperScissorsEnv, ::Observation, p) = Space(OneTo(1)) """ For multi-agent environments, we usually implement the most detailed one. diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/SpeakerListenerEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/SpeakerListenerEnv.jl index f4b9572b8..aafbb7874 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/SpeakerListenerEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/SpeakerListenerEnv.jl @@ -1,5 +1,7 @@ export SpeakerListenerEnv +# TODO: review the implementation of this environment + mutable struct SpeakerListenerEnv{T<:Vector{Float64}} <: AbstractEnv target::T content::T @@ -7,9 +9,9 @@ mutable struct SpeakerListenerEnv{T<:Vector{Float64}} <: AbstractEnv player_pos::T landmarks_pos::Vector{T} landmarks_num::Int - ϵ - damping - max_accel + ϵ::Any + damping::Any + max_accel::Any space_dim::Int init_step::Int play_step::Int @@ -46,7 +48,8 @@ function SpeakerListenerEnv(; max_accel = 0.5, space_dim::Int = 2, max_steps::Int = 50, - continuous::Bool = true) + continuous::Bool = true, +) SpeakerListenerEnv( zeros(N), zeros(N), @@ -74,21 +77,24 @@ function RLBase.reset!(env::SpeakerListenerEnv) env.landmarks_pos = [zeros(env.space_dim) for _ in Base.OneTo(env.landmarks_num)] end -RLBase.is_terminated(env::SpeakerListenerEnv) = (reward(env) > - env.ϵ) || (env.play_step > env.max_steps) +RLBase.is_terminated(env::SpeakerListenerEnv) = + (reward(env) > -env.ϵ) || (env.play_step > env.max_steps) RLBase.players(::SpeakerListenerEnv) = (:Speaker, :Listener, CHANCE_PLAYER) -RLBase.state(env::SpeakerListenerEnv, ::Observation{Any}, players::Tuple) = Dict(p => state(env, p) for p in players) +RLBase.state(env::SpeakerListenerEnv, ::Observation{Any}, players::Tuple) = + Dict(p => state(env, p) for p in players) -RLBase.state(env::SpeakerListenerEnv, ::Observation{Any}, player::Symbol) = - # for speaker, it can observe the target and help listener to arrive it. +RLBase.state(env::SpeakerListenerEnv, ::Observation{Any}, player::Symbol) = +# for speaker, it can observe the target and help listener to arrive it. if player == :Speaker env.target - # for listener, it can observe current velocity, relative positions of landmarks, and speaker's conveyed information. + # for listener, it can observe current velocity, relative positions of landmarks, and speaker's conveyed information. elseif player == :Listener vcat( env.player_vel..., ( - vcat((landmark_pos .- env.player_pos)...) for landmark_pos in env.landmarks_pos + vcat((landmark_pos .- env.player_pos)...) for + landmark_pos in env.landmarks_pos )..., env.content..., ) @@ -96,56 +102,59 @@ RLBase.state(env::SpeakerListenerEnv, ::Observation{Any}, player::Symbol) = @error "No player $player." end -RLBase.state(env::SpeakerListenerEnv, ::Observation{Any}, ::ChancePlayer) = vcat(env.landmarks_pos, [env.player_pos]) +RLBase.state(env::SpeakerListenerEnv, ::Observation{Any}, ::ChancePlayer) = + vcat(env.landmarks_pos, [env.player_pos]) -RLBase.state_space(env::SpeakerListenerEnv, ::Observation{Any}, players::Tuple) = - Space(Dict(player => state_space(env, player) for player in players)) +RLBase.state_space(env::SpeakerListenerEnv, ::Observation{Any}, players::Tuple) = + Dict(player => state_space(env, player) for player in players) -RLBase.state_space(env::SpeakerListenerEnv, ::Observation{Any}, player::Symbol) = +RLBase.state_space(env::SpeakerListenerEnv, ::Observation{Any}, player::Symbol) = if player == :Speaker # env.target - Space([[0., 1.] for _ in Base.OneTo(env.landmarks_num)]) + Space(SVector(ntuple(_ -> (0.0, 1.0), env.landmarks_num))) elseif player == :Listener - Space(vcat( - # relative positions of landmarks, no bounds. - (vcat( - Space([ClosedInterval(-Inf, Inf) for _ in Base.OneTo(env.space_dim)])... - ) for _ in Base.OneTo(env.landmarks_num + 1))..., - # communication content from `Speaker` - [[0., 1.] for _ in Base.OneTo(env.landmarks_num)], - )) + Space( + Float64, + length(env.player_vel) + + length(env.landmarks_pos) * length(env.player_pos) + + length(env.content), + ) else @error "No player $player." end -RLBase.state_space(env::SpeakerListenerEnv, ::Observation{Any}, ::ChancePlayer) = - Space( - vcat( - # landmarks' positions - (Space([ClosedInterval(-1, 1) for _ in Base.OneTo(env.space_dim)]) for _ in Base.OneTo(env.landmarks_num))..., - # player's position, no bounds. - Space([ClosedInterval(-Inf, Inf) for _ in Base.OneTo(env.space_dim)]), - ) - ) +RLBase.state_space(env::SpeakerListenerEnv, ::Observation{Any}, ::ChancePlayer) = [ + # landmarks' positions + ( + Space((SVector(ntuple(_ -> -Inf .. Inf, env.space_dim)))) for + _ in Base.OneTo(env.landmarks_num) + )..., + # player's position, no bounds. + Space(SVector(ntuple(_ -> -Inf .. Inf, env.space_dim))), +] -RLBase.action_space(env::SpeakerListenerEnv, players::Tuple) = - Space(Dict(p => action_space(env, p) for p in players)) +RLBase.action_space(env::SpeakerListenerEnv, players::Tuple) = + Space(Dict(p => action_space(env, p) for p in players)) -RLBase.action_space(env::SpeakerListenerEnv, player::Symbol) = +RLBase.action_space(env::SpeakerListenerEnv, player::Symbol) = if player == :Speaker - env.continuous ? Space([ClosedInterval(0, 1) for _ in Base.OneTo(env.landmarks_num)]) : Space([ZeroTo(1) for _ in Base.OneTo(env.landmarks_num)]) + env.continuous ? + Space([ClosedInterval(0, 1) for _ in Base.OneTo(env.landmarks_num)]) : + Space([ZeroTo(1) for _ in Base.OneTo(env.landmarks_num)]) elseif player == :Listener # there has two directions in each dimension. - env.continuous ? Space([ClosedInterval(0, 1) for _ in Base.OneTo(2 * env.space_dim)]) : Space([ZeroTo(1) for _ in Base.OneTo(2 * env.space_dim)]) + env.continuous ? + Space([ClosedInterval(0, 1) for _ in Base.OneTo(2 * env.space_dim)]) : + Space([ZeroTo(1) for _ in Base.OneTo(2 * env.space_dim)]) else @error "No player $player." end function RLBase.action_space(env::SpeakerListenerEnv, ::ChancePlayer) if env.init_step < env.landmarks_num + 1 - Space([ClosedInterval(-1, 1) for _ in Base.OneTo(env.space_dim)]) + Space(SVector(ntuple(_ -> -1.0 .. 1.0, env.space_dim))) else - Base.OneTo(env.landmarks_num) + Space(OneTo(env.landmarks_num)) end end @@ -157,7 +166,7 @@ function (env::SpeakerListenerEnv)(action, ::ChancePlayer) env.player_pos = action else @assert action in Base.OneTo(env.landmarks_num) "The target should be assigned to one of the landmarks." - env.target[action] = 1. + env.target[action] = 1.0 end end @@ -176,7 +185,7 @@ function (env::SpeakerListenerEnv)(action::Vector, player::Symbol) elseif player == :Listener # update velocity, here env.damping is for simulation physical rule. action = round.(action) - acceleration = [action[2 * i] - action[2 * i - 1] for i in Base.OneTo(env.space_dim)] + acceleration = [action[2*i] - action[2*i-1] for i in Base.OneTo(env.space_dim)] env.player_vel .*= (1 - env.damping) env.player_vel .+= (acceleration * env.max_accel) # update position @@ -190,14 +199,14 @@ RLBase.reward(::SpeakerListenerEnv, ::ChancePlayer) = -Inf function RLBase.reward(env::SpeakerListenerEnv, p) if sum(env.target) == 1 - goal = findfirst(env.target .== 1.) + goal = findfirst(env.target .== 1.0) -sum((env.landmarks_pos[goal] .- env.player_pos) .^ 2) else -Inf end end -RLBase.current_player(env::SpeakerListenerEnv) = +RLBase.current_player(env::SpeakerListenerEnv) = if env.init_step < env.landmarks_num + 2 CHANCE_PLAYER else diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/StockTradingEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/StockTradingEnv.jl index 6a3f6a6f6..50936e3c6 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/StockTradingEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/StockTradingEnv.jl @@ -2,12 +2,12 @@ export StockTradingEnv, StockTradingEnvWithTurbulence using Pkg.Artifacts using DelimitedFiles -using LinearAlgebra:dot +using LinearAlgebra: dot using IntervalSets function load_default_stock_data(s) if s == "prices.csv" || s == "features.csv" - data, _ = readdlm(joinpath(artifact"stock_trading_data", s), ',', header=true) + data, _ = readdlm(joinpath(artifact"stock_trading_data", s), ',', header = true) collect(data') elseif s == "turbulence.csv" readdlm(joinpath(artifact"stock_trading_data", "turbulence.csv")) |> vec @@ -16,7 +16,8 @@ function load_default_stock_data(s) end end -mutable struct StockTradingEnv{F<:AbstractMatrix{Float64}, P<:AbstractMatrix{Float64}} <: AbstractEnv +mutable struct StockTradingEnv{F<:AbstractMatrix{Float64},P<:AbstractMatrix{Float64}} <: + AbstractEnv features::F prices::P HMAX_NORMALIZE::Float32 @@ -48,14 +49,14 @@ This environment is originally provided in [Deep Reinforcement Learning for Auto - `initial_account_balance=1_000_000`. """ function StockTradingEnv(; - initial_account_balance=1_000_000f0, - features=nothing, - prices=nothing, - first_day=nothing, - last_day=nothing, - HMAX_NORMALIZE = 100f0, + initial_account_balance = 1_000_000.0f0, + features = nothing, + prices = nothing, + first_day = nothing, + last_day = nothing, + HMAX_NORMALIZE = 100.0f0, TRANSACTION_FEE_PERCENT = 0.001f0, - REWARD_SCALING = 1f-4 + REWARD_SCALING = 1.0f-4, ) prices = isnothing(prices) ? load_default_stock_data("prices.csv") : prices features = isnothing(features) ? load_default_stock_data("features.csv") : features @@ -77,11 +78,11 @@ function StockTradingEnv(; REWARD_SCALING, initial_account_balance, state, - 0f0, + 0.0f0, day, first_day, last_day, - 0f0 + 0.0f0, ) _balance(env)[] = initial_account_balance @@ -108,10 +109,10 @@ function (env::StockTradingEnv)(actions) # then buy # better to shuffle? - for (i,b) in enumerate(actions) + for (i, b) in enumerate(actions) if b > 0 max_buy = div(_balance(env)[], _prices(env)[i]) - buy = min(b*env.HMAX_NORMALIZE, max_buy) + buy = min(b * env.HMAX_NORMALIZE, max_buy) _holds(env)[i] += buy deduction = buy * _prices(env)[i] cost = deduction * env.TRANSACTION_FEE_PERCENT @@ -136,12 +137,12 @@ function RLBase.reset!(env::StockTradingEnv) _balance(env)[] = env.initial_account_balance _prices(env) .= @view env.prices[:, env.day] _features(env) .= @view env.features[:, env.day] - env.total_cost = 0. - env.daily_reward = 0. + env.total_cost = 0.0 + env.daily_reward = 0.0 end -RLBase.state_space(env::StockTradingEnv) = Space(fill(-Inf32..Inf32, length(state(env)))) -RLBase.action_space(env::StockTradingEnv) = Space(fill(-1f0..1f0, length(_holds(env)))) +RLBase.state_space(env::StockTradingEnv) = Space(Float32, length(state(env))) +RLBase.action_space(env::StockTradingEnv) = Space(-1.0f0 .. 1.0f0, length(_holds(env))) RLBase.ChanceStyle(::StockTradingEnv) = DETERMINISTIC @@ -154,22 +155,22 @@ struct StockTradingEnvWithTurbulence{E<:StockTradingEnv} <: AbstractEnvWrapper end function StockTradingEnvWithTurbulence(; - turbulence_threshold=140., - turbulences=nothing, - kw... + turbulence_threshold = 140.0, + turbulences = nothing, + kw..., ) turbulences = isnothing(turbulences) && load_default_stock_data("turbulence.csv") StockTradingEnvWithTurbulence( - StockTradingEnv(;kw...), + StockTradingEnv(; kw...), turbulences, - turbulence_threshold + turbulence_threshold, ) end function (w::StockTradingEnvWithTurbulence)(actions) if w.turbulences[w.env.day] >= w.turbulence_threshold - actions .= ifelse.(actions .< 0, -Inf32, 0) + actions = ifelse.(actions .< 0, -Inf32, 0) end w.env(actions) end \ No newline at end of file diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/TicTacToeEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/TicTacToeEnv.jl index ed9212565..2b3564a93 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/TicTacToeEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/TicTacToeEnv.jl @@ -51,9 +51,10 @@ Base.isequal(a::TicTacToeEnv, b::TicTacToeEnv) = isequal(a.board, b.board) Base.to_index(::TicTacToeEnv, ::Cross) = 2 Base.to_index(::TicTacToeEnv, ::Nought) = 3 -RLBase.action_space(::TicTacToeEnv, player) = Base.OneTo(9) +RLBase.action_space(::TicTacToeEnv, player) = Space(OneTo(9)) -RLBase.legal_action_space(env::TicTacToeEnv, p) = findall(legal_action_space_mask(env)) +RLBase.legal_action_space(env::TicTacToeEnv, p) = + Space(findall(legal_action_space_mask(env))) function RLBase.legal_action_space_mask(env::TicTacToeEnv, p) if is_win(env, CROSS) || is_win(env, NOUGHT) @@ -75,14 +76,12 @@ RLBase.current_player(env::TicTacToeEnv) = env.player RLBase.players(env::TicTacToeEnv) = (CROSS, NOUGHT) RLBase.state(env::TicTacToeEnv, ::Observation{BitArray{3}}, p) = env.board -RLBase.state_space(env::TicTacToeEnv, ::Observation{BitArray{3}}, p) = - Space(fill(false..true, 3, 3, 3)) +RLBase.state_space(env::TicTacToeEnv, ::Observation{BitArray{3}}, p) = Space(Bool, 3, 3, 3) RLBase.state(env::TicTacToeEnv, ::Observation{Int}, p) = get_tic_tac_toe_state_info()[env].index RLBase.state_space(env::TicTacToeEnv, ::Observation{Int}, p) = - Base.OneTo(length(get_tic_tac_toe_state_info())) - -RLBase.state_space(env::TicTacToeEnv, ::Observation{String}, p) = WorldSpace{String}() + Space(OneTo(length(get_tic_tac_toe_state_info()))) +RLBase.state_space(env::TicTacToeEnv, ::Observation{String}, p) = Space(String) function RLBase.state(env::TicTacToeEnv, ::Observation{String}, p) buff = IOBuffer() diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/TigerProblemEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/TigerProblemEnv.jl index 0956866da..23a4224df 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/TigerProblemEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/TigerProblemEnv.jl @@ -20,7 +20,7 @@ end Random.seed!(env::TigerProblemEnv, s) = seed!(env.rng, s) -RLBase.action_space(::TigerProblemEnv) = (:listen, :open_left, :open_right) +RLBase.action_space(::TigerProblemEnv) = Space((:listen, :open_left, :open_right)) (env::TigerProblemEnv)(action) = env.action = action @@ -67,8 +67,8 @@ end RLBase.state(env::TigerProblemEnv, ::InternalState) = env.tiger_pos RLBase.state_space(env::TigerProblemEnv) = state_space(env, Observation{Int}()) -RLBase.state_space(env::TigerProblemEnv, ::Observation) = 1:4 -RLBase.state_space(env::TigerProblemEnv, ::InternalState) = 1:2 +RLBase.state_space(env::TigerProblemEnv, ::Observation) = Space(1:4) +RLBase.state_space(env::TigerProblemEnv, ::InternalState) = Space(1:2) RLBase.NumAgentStyle(::TigerProblemEnv) = SINGLE_AGENT RLBase.DynamicStyle(::TigerProblemEnv) = SEQUENTIAL diff --git a/src/ReinforcementLearningEnvironments/src/environments/examples/TinyHanabiEnv.jl b/src/ReinforcementLearningEnvironments/src/environments/examples/TinyHanabiEnv.jl index dcd38abf3..968333d53 100644 --- a/src/ReinforcementLearningEnvironments/src/environments/examples/TinyHanabiEnv.jl +++ b/src/ReinforcementLearningEnvironments/src/environments/examples/TinyHanabiEnv.jl @@ -57,10 +57,11 @@ RLBase.current_player(env::TinyHanabiEnv) = (env::TinyHanabiEnv)(action, ::ChancePlayer) = push!(env.cards, action) (env::TinyHanabiEnv)(action, ::Int) = push!(env.actions, action) -RLBase.action_space(env::TinyHanabiEnv, ::Int) = Base.OneTo(3) -RLBase.action_space(env::TinyHanabiEnv, ::ChancePlayer) = Base.OneTo(2) +RLBase.action_space(env::TinyHanabiEnv, ::Int) = Space(OneTo(3)) +RLBase.action_space(env::TinyHanabiEnv, ::ChancePlayer) = Space(OneTo(2)) -RLBase.legal_action_space(env::TinyHanabiEnv, ::ChancePlayer) = findall(!in(env.cards), 1:2) +RLBase.legal_action_space(env::TinyHanabiEnv, ::ChancePlayer) = + Space(findall(!in(env.cards), 1:2)) RLBase.legal_action_space_mask(env::TinyHanabiEnv, ::ChancePlayer) = [x ∉ env.cards for x in 1:2] @@ -77,13 +78,15 @@ function RLBase.prob(env::TinyHanabiEnv, ::ChancePlayer) end RLBase.state_space(env::TinyHanabiEnv, ::InformationSet, ::ChancePlayer) = - ((0,), (0, 1), (0, 2), (0, 1, 2), (0, 2, 1)) # (chance_player_id(0), chance_player's actions...) + Space(((0,), (0, 1), (0, 2), (0, 1, 2), (0, 2, 1))) # (chance_player_id(0), chance_player's actions...) RLBase.state(env::TinyHanabiEnv, ::InformationSet, ::ChancePlayer) = (0, env.cards...) function RLBase.state_space(env::TinyHanabiEnv, ::InformationSet, p::Int) - Tuple( - (p, c..., a...) for p in 1:2 for c in ((), 1, 2) for - a in ((), 1:3..., ((i, j) for i in 1:3 for j in 1:3)...) + Space( + Tuple( + (p, c..., a...) for p in 1:2 for c in ((), 1, 2) for + a in ((), 1:3..., ((i, j) for i in 1:3 for j in 1:3)...) + ), ) end diff --git a/src/ReinforcementLearningEnvironments/test/environments/3rd_party/open_spiel.jl b/src/ReinforcementLearningEnvironments/test/environments/3rd_party/open_spiel.jl index c54aad541..186875d47 100644 --- a/src/ReinforcementLearningEnvironments/test/environments/3rd_party/open_spiel.jl +++ b/src/ReinforcementLearningEnvironments/test/environments/3rd_party/open_spiel.jl @@ -1,12 +1,12 @@ @testset "OpenSpielEnv" begin - for name in [ - "tic_tac_toe", - "kuhn_poker", - "goofspiel(imp_info=True,num_cards=4,points_order=descending)", - ] - @info "testing OpenSpiel: $name" - env = OpenSpielEnv(name) - RLBase.test_runnable!(env) - end + # for name in [ + # "tic_tac_toe", + # "kuhn_poker", + # "goofspiel(imp_info=True,num_cards=4,points_order=descending)", + # ] + # @info "testing OpenSpiel: $name" + # env = OpenSpielEnv(name) + # RLBase.test_runnable!(env) + # end end diff --git a/src/ReinforcementLearningEnvironments/test/runtests.jl b/src/ReinforcementLearningEnvironments/test/runtests.jl index 26588f880..16ddff8cc 100644 --- a/src/ReinforcementLearningEnvironments/test/runtests.jl +++ b/src/ReinforcementLearningEnvironments/test/runtests.jl @@ -3,7 +3,7 @@ using ReinforcementLearningBase using ReinforcementLearningEnvironments using ArcadeLearningEnvironment using PyCall -using OpenSpiel +# using OpenSpiel # using SnakeGames using Random using StableRNGs diff --git a/src/ReinforcementLearningExperiments/Manifest.toml b/src/ReinforcementLearningExperiments/Manifest.toml deleted file mode 100644 index 2ccdacb57..000000000 --- a/src/ReinforcementLearningExperiments/Manifest.toml +++ /dev/null @@ -1,979 +0,0 @@ -# This file is machine-generated - editing it directly is not advised - -[[AbstractFFTs]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "485ee0867925449198280d4af84bdb46a2a404d0" -uuid = "621f4979-c628-5d54-868e-fcf4e3e8185c" -version = "1.0.1" - -[[AbstractTrees]] -git-tree-sha1 = "03e0550477d86222521d254b741d470ba17ea0b5" -uuid = "1520ce14-60c1-5f80-bbc7-55ef81b5835c" -version = "0.3.4" - -[[Adapt]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "84918055d15b3114ede17ac6a7182f68870c16f7" -uuid = "79e6a3ab-5dfb-504d-930d-738a2a938a0e" -version = "3.3.1" - -[[ArcadeLearningEnvironment]] -deps = ["ArcadeLearningEnvironment_jll", "LibArchive_jll", "MD5", "Pkg"] -git-tree-sha1 = "0053e34fe18fef36a2077e3e1466f34f195cbafc" -uuid = "b7f77d8d-088d-5e02-8ac0-89aab2acc977" -version = "0.2.4" - -[[ArcadeLearningEnvironment_jll]] -deps = ["Libdl", "Pkg", "Zlib_jll"] -git-tree-sha1 = "c27cfe2024f4804ca60cd3d443c25ed2e8543108" -uuid = "52cbb755-00ff-5a24-b23e-8a91c598877e" -version = "0.6.1+0" - -[[ArgTools]] -uuid = "0dad84c5-d112-42e6-8d28-ef12dabb789f" - -[[ArrayInterface]] -deps = ["Compat", "IfElse", "LinearAlgebra", "Requires", "SparseArrays", "Static"] -git-tree-sha1 = "e527b258413e0c6d4f66ade574744c94edef81f8" -uuid = "4fba245c-0d91-5ea0-9b3e-6abc04ee57a9" -version = "3.1.40" - -[[Artifacts]] -uuid = "56f22d72-fd6d-98f1-02f0-08ddc0907c33" - -[[Attr_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "b132f9aeb209b8790dcc286c857f300369219d8d" -uuid = "1fd713ca-387f-5abc-8002-d8b8b1623b73" -version = "2.5.1+0" - -[[AxisAlgorithms]] -deps = ["LinearAlgebra", "Random", "SparseArrays", "WoodburyMatrices"] -git-tree-sha1 = "66771c8d21c8ff5e3a93379480a2307ac36863f7" -uuid = "13072b0f-2c55-5437-9ae7-d433b7a33950" -version = "1.0.1" - -[[BFloat16s]] -deps = ["LinearAlgebra", "Printf", "Random", "Test"] -git-tree-sha1 = "a598ecb0d717092b5539dbbe890c98bac842b072" -uuid = "ab4f0b2a-ad5b-11e8-123f-65d77653426b" -version = "0.2.0" - -[[BSON]] -git-tree-sha1 = "ebcd6e22d69f21249b7b8668351ebf42d6dc87a1" -uuid = "fbb218c0-5317-5bc6-957e-2ee96dd4b1f0" -version = "0.3.4" - -[[Base64]] -uuid = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f" - -[[Bzip2_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "c3598e525718abcc440f69cc6d5f60dda0a1b61e" -uuid = "6e34b625-4abd-537c-b88f-471c36dfa7a0" -version = "1.0.6+5" - -[[CEnum]] -git-tree-sha1 = "215a9aa4a1f23fbd05b92769fdd62559488d70e9" -uuid = "fa961155-64e5-5f13-b03f-caf6b980ea82" -version = "0.4.1" - -[[CRC32c]] -uuid = "8bf52ea8-c179-5cab-976a-9e18b702a9bc" - -[[CUDA]] -deps = ["AbstractFFTs", "Adapt", "BFloat16s", "CEnum", "CompilerSupportLibraries_jll", "ExprTools", "GPUArrays", "GPUCompiler", "LLVM", "LazyArtifacts", "Libdl", "LinearAlgebra", "Logging", "Printf", "Random", "Random123", "RandomNumbers", "Reexport", "Requires", "SparseArrays", "SpecialFunctions", "TimerOutputs"] -git-tree-sha1 = "2c8329f16addffd09e6ca84c556e2185a4933c64" -uuid = "052768ef-5323-5732-b1bb-66c8b64840ba" -version = "3.5.0" - -[[Calculus]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "f641eb0a4f00c343bbc32346e1217b86f3ce9dad" -uuid = "49dc2e85-a5d0-5ad3-a950-438e2897f1b9" -version = "0.5.1" - -[[ChainRules]] -deps = ["ChainRulesCore", "Compat", "LinearAlgebra", "Random", "RealDot", "Statistics"] -git-tree-sha1 = "035ef8a5382a614b2d8e3091b6fdbb1c2b050e11" -uuid = "082447d4-558c-5d27-93f4-14fc19e9eca2" -version = "1.12.1" - -[[ChainRulesCore]] -deps = ["Compat", "LinearAlgebra", "SparseArrays"] -git-tree-sha1 = "f885e7e7c124f8c92650d61b9477b9ac2ee607dd" -uuid = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4" -version = "1.11.1" - -[[ChangesOfVariables]] -deps = ["LinearAlgebra", "Test"] -git-tree-sha1 = "9a1d594397670492219635b35a3d830b04730d62" -uuid = "9e997f8a-9a97-42d5-a9f1-ce6bfc15e2c0" -version = "0.1.1" - -[[CircularArrayBuffers]] -git-tree-sha1 = "b097d863df6c40491b7553a1eb235fbb86d37d0e" -uuid = "9de3a189-e0c0-4e15-ba3b-b14b9fb0aec1" -version = "0.1.3" - -[[CodecZlib]] -deps = ["TranscodingStreams", "Zlib_jll"] -git-tree-sha1 = "ded953804d019afa9a3f98981d99b33e3db7b6da" -uuid = "944b1d66-785c-5afd-91f1-9de20f533193" -version = "0.7.0" - -[[ColorTypes]] -deps = ["FixedPointNumbers", "Random"] -git-tree-sha1 = "024fe24d83e4a5bf5fc80501a314ce0d1aa35597" -uuid = "3da002f7-5984-5a60-b8a6-cbb66c0b333f" -version = "0.11.0" - -[[ColorVectorSpace]] -deps = ["ColorTypes", "FixedPointNumbers", "LinearAlgebra", "SpecialFunctions", "Statistics", "TensorCore"] -git-tree-sha1 = "45efb332df2e86f2cb2e992239b6267d97c9e0b6" -uuid = "c3611d14-8923-5661-9e6a-0046d554d3a4" -version = "0.9.7" - -[[Colors]] -deps = ["ColorTypes", "FixedPointNumbers", "Reexport"] -git-tree-sha1 = "417b0ed7b8b838aa6ca0a87aadf1bb9eb111ce40" -uuid = "5ae59095-9a9b-59fe-a467-6f913c188581" -version = "0.12.8" - -[[CommonRLInterface]] -deps = ["MacroTools"] -git-tree-sha1 = "21de56ebf28c262651e682f7fe614d44623dc087" -uuid = "d842c3ba-07a1-494f-bbec-f5741b0a3e98" -version = "0.3.1" - -[[CommonSubexpressions]] -deps = ["MacroTools", "Test"] -git-tree-sha1 = "7b8a93dba8af7e3b42fecabf646260105ac373f7" -uuid = "bbf7d656-a473-5ed7-a52c-81e309532950" -version = "0.3.0" - -[[Compat]] -deps = ["Base64", "Dates", "DelimitedFiles", "Distributed", "InteractiveUtils", "LibGit2", "Libdl", "LinearAlgebra", "Markdown", "Mmap", "Pkg", "Printf", "REPL", "Random", "SHA", "Serialization", "SharedArrays", "Sockets", "SparseArrays", "Statistics", "Test", "UUIDs", "Unicode"] -git-tree-sha1 = "dce3e3fea680869eaa0b774b2e8343e9ff442313" -uuid = "34da2185-b29b-5c13-b0c7-acf172513d20" -version = "3.40.0" - -[[CompilerSupportLibraries_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "e66e0078-7015-5450-92f7-15fbd957f2ae" - -[[ConstructionBase]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "f74e9d5388b8620b4cee35d4c5a618dd4dc547f4" -uuid = "187b0558-2788-49d3-abe0-74a17ed4e7c9" -version = "1.3.0" - -[[CoordinateTransformations]] -deps = ["LinearAlgebra", "StaticArrays"] -git-tree-sha1 = "681ea870b918e7cff7111da58791d7f718067a19" -uuid = "150eb455-5306-5404-9cee-2592286d6298" -version = "0.6.2" - -[[Crayons]] -git-tree-sha1 = "3f71217b538d7aaee0b69ab47d9b7724ca8afa0d" -uuid = "a8cc5b0e-0ffa-5ad4-8c14-923d3ee1735f" -version = "4.0.4" - -[[DataAPI]] -git-tree-sha1 = "cc70b17275652eb47bc9e5f81635981f13cea5c8" -uuid = "9a962f9c-6df0-11e9-0e5d-c546b8b5ee8a" -version = "1.9.0" - -[[DataStructures]] -deps = ["Compat", "InteractiveUtils", "OrderedCollections"] -git-tree-sha1 = "7d9d316f04214f7efdbb6398d545446e246eff02" -uuid = "864edb3b-99cc-5e75-8d2d-829cb0a9cfe8" -version = "0.18.10" - -[[DataValueInterfaces]] -git-tree-sha1 = "bfc1187b79289637fa0ef6d4436ebdfe6905cbd6" -uuid = "e2d170a0-9d28-54be-80f0-106bbe20a464" -version = "1.0.0" - -[[Dates]] -deps = ["Printf"] -uuid = "ade2ca70-3891-5945-98fb-dc099432e06a" - -[[DelimitedFiles]] -deps = ["Mmap"] -uuid = "8bb1440f-4735-579b-a4ab-409b98df4dab" - -[[DensityInterface]] -deps = ["InverseFunctions", "Test"] -git-tree-sha1 = "80c3e8639e3353e5d2912fb3a1916b8455e2494b" -uuid = "b429d917-457f-4dbc-8f4c-0cc954292b1d" -version = "0.4.0" - -[[DiffResults]] -deps = ["StaticArrays"] -git-tree-sha1 = "c18e98cba888c6c25d1c3b048e4b3380ca956805" -uuid = "163ba53b-c6d8-5494-b064-1a9d43ac40c5" -version = "1.0.3" - -[[DiffRules]] -deps = ["LogExpFunctions", "NaNMath", "Random", "SpecialFunctions"] -git-tree-sha1 = "3287dacf67c3652d3fed09f4c12c187ae4dbb89a" -uuid = "b552c78f-8df3-52c6-915a-8e097449b14b" -version = "1.4.0" - -[[Distributed]] -deps = ["Random", "Serialization", "Sockets"] -uuid = "8ba89e20-285c-5b6f-9357-94700520ee1b" - -[[Distributions]] -deps = ["ChainRulesCore", "DensityInterface", "FillArrays", "LinearAlgebra", "PDMats", "Printf", "QuadGK", "Random", "SparseArrays", "SpecialFunctions", "Statistics", "StatsBase", "StatsFuns", "Test"] -git-tree-sha1 = "dc6f530de935bb3c3cd73e99db5b4698e58b2fcf" -uuid = "31c24e10-a181-5473-b8eb-7969acd0382f" -version = "0.25.31" - -[[DocStringExtensions]] -deps = ["LibGit2"] -git-tree-sha1 = "b19534d1895d702889b219c382a6e18010797f0b" -uuid = "ffbed154-4ef7-542d-bbb7-c09d3a79fcae" -version = "0.8.6" - -[[Downloads]] -deps = ["ArgTools", "LibCURL", "NetworkOptions"] -uuid = "f43a241f-c20a-4ad4-852c-f6b1247861c6" - -[[DualNumbers]] -deps = ["Calculus", "NaNMath", "SpecialFunctions"] -git-tree-sha1 = "fe385ec95ac5533650fb9b1ba7869e9bc28cdd0a" -uuid = "fa6b7ba4-c1ee-5f82-b5fc-ecf0adba8f74" -version = "0.6.5" - -[[ElasticArrays]] -deps = ["Adapt"] -git-tree-sha1 = "a0fcc1bb3c9ceaf07e1d0529c9806ce94be6adf9" -uuid = "fdbdab4c-e67f-52f5-8c3f-e7b388dad3d4" -version = "1.2.9" - -[[EllipsisNotation]] -deps = ["ArrayInterface"] -git-tree-sha1 = "9aad812fb7c4c038da7cab5a069f502e6e3ae030" -uuid = "da5c29d0-fa7d-589e-88eb-ea29b0a81949" -version = "1.1.1" - -[[Expat_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "b3bfd02e98aedfa5cf885665493c5598c350cd2f" -uuid = "2e619515-83b5-522b-bb60-26c02a35a201" -version = "2.2.10+0" - -[[ExprTools]] -git-tree-sha1 = "b7e3d17636b348f005f11040025ae8c6f645fe92" -uuid = "e2ba6199-217a-4e67-a87a-7c52f15ade04" -version = "0.1.6" - -[[FileIO]] -deps = ["Pkg", "Requires", "UUIDs"] -git-tree-sha1 = "2db648b6712831ecb333eae76dbfd1c156ca13bb" -uuid = "5789e2e9-d7fb-5bc7-8068-2c6fae9b9549" -version = "1.11.2" - -[[FillArrays]] -deps = ["LinearAlgebra", "Random", "SparseArrays", "Statistics"] -git-tree-sha1 = "8756f9935b7ccc9064c6eef0bff0ad643df733a3" -uuid = "1a297f60-69ca-5386-bcde-b61e274b549b" -version = "0.12.7" - -[[FixedPointNumbers]] -deps = ["Statistics"] -git-tree-sha1 = "335bfdceacc84c5cdf16aadc768aa5ddfc5383cc" -uuid = "53c48c17-4a7d-5ca2-90c5-79b7896eea93" -version = "0.8.4" - -[[Flux]] -deps = ["AbstractTrees", "Adapt", "ArrayInterface", "CUDA", "CodecZlib", "Colors", "DelimitedFiles", "Functors", "Juno", "LinearAlgebra", "MacroTools", "NNlib", "NNlibCUDA", "Pkg", "Printf", "Random", "Reexport", "SHA", "SparseArrays", "Statistics", "StatsBase", "Test", "ZipFile", "Zygote"] -git-tree-sha1 = "e8b37bb43c01eed0418821d1f9d20eca5ba6ab21" -uuid = "587475ba-b771-5e3f-ad9e-33799f191a9c" -version = "0.12.8" - -[[ForwardDiff]] -deps = ["CommonSubexpressions", "DiffResults", "DiffRules", "LinearAlgebra", "LogExpFunctions", "NaNMath", "Preferences", "Printf", "Random", "SpecialFunctions", "StaticArrays"] -git-tree-sha1 = "6406b5112809c08b1baa5703ad274e1dded0652f" -uuid = "f6369f11-7733-5829-9624-2563aa707210" -version = "0.10.23" - -[[Functors]] -git-tree-sha1 = "e4768c3b7f597d5a352afa09874d16e3c3f6ead2" -uuid = "d9f16b24-f501-4c13-a1f2-28368ffc5196" -version = "0.2.7" - -[[Future]] -deps = ["Random"] -uuid = "9fa8497b-333b-5362-9e8d-4d0656e87820" - -[[GPUArrays]] -deps = ["Adapt", "LinearAlgebra", "Printf", "Random", "Serialization", "Statistics"] -git-tree-sha1 = "7772508f17f1d482fe0df72cabc5b55bec06bbe0" -uuid = "0c68f7d7-f131-5f86-a1c3-88cf8149b2d7" -version = "8.1.2" - -[[GPUCompiler]] -deps = ["ExprTools", "InteractiveUtils", "LLVM", "Libdl", "Logging", "TimerOutputs", "UUIDs"] -git-tree-sha1 = "77d915a0af27d474f0aaf12fcd46c400a552e84c" -uuid = "61eb1bfa-7361-4325-ad38-22787b887f55" -version = "0.13.7" - -[[Graphics]] -deps = ["Colors", "LinearAlgebra", "NaNMath"] -git-tree-sha1 = "1c5a84319923bea76fa145d49e93aa4394c73fc2" -uuid = "a2bd30eb-e257-5431-a919-1863eab51364" -version = "1.1.1" - -[[GridWorlds]] -deps = ["DataStructures", "REPL", "Random", "ReinforcementLearningBase"] -git-tree-sha1 = "5bf404e98a104a42656aa5d094f07bb37680eb70" -uuid = "e15a9946-cd7f-4d03-83e2-6c30bacb0043" -version = "0.5.0" - -[[Highlights]] -deps = ["DocStringExtensions", "InteractiveUtils", "REPL"] -git-tree-sha1 = "f823a2d04fb233d52812c8024a6d46d9581904a4" -uuid = "eafb193a-b7ab-5a9e-9068-77385905fa72" -version = "0.4.5" - -[[IRTools]] -deps = ["InteractiveUtils", "MacroTools", "Test"] -git-tree-sha1 = "95215cd0076a150ef46ff7928892bc341864c73c" -uuid = "7869d1d1-7146-5819-86e3-90919afe41df" -version = "0.4.3" - -[[IfElse]] -git-tree-sha1 = "debdd00ffef04665ccbb3e150747a77560e8fad1" -uuid = "615f187c-cbe4-4ef1-ba3b-2fcf58d6d173" -version = "0.1.1" - -[[ImageBase]] -deps = ["ImageCore", "Reexport"] -git-tree-sha1 = "b51bb8cae22c66d0f6357e3bcb6363145ef20835" -uuid = "c817782e-172a-44cc-b673-b171935fbb9e" -version = "0.1.5" - -[[ImageCore]] -deps = ["AbstractFFTs", "ColorVectorSpace", "Colors", "FixedPointNumbers", "Graphics", "MappedArrays", "MosaicViews", "OffsetArrays", "PaddedViews", "Reexport"] -git-tree-sha1 = "9a5c62f231e5bba35695a20988fc7cd6de7eeb5a" -uuid = "a09fc81d-aa75-5fe9-8630-4744c3626534" -version = "0.9.3" - -[[ImageTransformations]] -deps = ["AxisAlgorithms", "ColorVectorSpace", "CoordinateTransformations", "ImageBase", "ImageCore", "Interpolations", "OffsetArrays", "Rotations", "StaticArrays"] -git-tree-sha1 = "b4b161abc8252d68b13c5cc4a5f2ba711b61fec5" -uuid = "02fcd773-0e25-5acc-982a-7f6622650795" -version = "0.9.3" - -[[InteractiveUtils]] -deps = ["Markdown"] -uuid = "b77e0a4c-d291-57a0-90e8-8db25a27a240" - -[[Interpolations]] -deps = ["AxisAlgorithms", "ChainRulesCore", "LinearAlgebra", "OffsetArrays", "Random", "Ratios", "Requires", "SharedArrays", "SparseArrays", "StaticArrays", "WoodburyMatrices"] -git-tree-sha1 = "61aa005707ea2cebf47c8d780da8dc9bc4e0c512" -uuid = "a98d9a8b-a2ab-59e6-89dd-64a1c18fca59" -version = "0.13.4" - -[[IntervalSets]] -deps = ["Dates", "EllipsisNotation", "Statistics"] -git-tree-sha1 = "3cc368af3f110a767ac786560045dceddfc16758" -uuid = "8197267c-284f-5f27-9208-e0e47529a953" -version = "0.5.3" - -[[InverseFunctions]] -deps = ["Test"] -git-tree-sha1 = "a7254c0acd8e62f1ac75ad24d5db43f5f19f3c65" -uuid = "3587e190-3f89-42d0-90ee-14403ec27112" -version = "0.1.2" - -[[IrrationalConstants]] -git-tree-sha1 = "7fd44fd4ff43fc60815f8e764c0f352b83c49151" -uuid = "92d709cd-6900-40b7-9082-c6be49f344b6" -version = "0.1.1" - -[[IteratorInterfaceExtensions]] -git-tree-sha1 = "a3f24677c21f5bbe9d2a714f95dcd58337fb2856" -uuid = "82899510-4779-5014-852e-03e436cf321d" -version = "1.0.0" - -[[JLLWrappers]] -deps = ["Preferences"] -git-tree-sha1 = "642a199af8b68253517b80bd3bfd17eb4e84df6e" -uuid = "692b3bcd-3c85-4b1f-b108-f13ce0eb3210" -version = "1.3.0" - -[[JSON]] -deps = ["Dates", "Mmap", "Parsers", "Unicode"] -git-tree-sha1 = "8076680b162ada2a031f707ac7b4953e30667a37" -uuid = "682c06a0-de6a-54ab-a142-c8b1cf79cde6" -version = "0.21.2" - -[[Juno]] -deps = ["Base64", "Logging", "Media", "Profile"] -git-tree-sha1 = "07cb43290a840908a771552911a6274bc6c072c7" -uuid = "e5e0dc1b-0480-54bc-9374-aad01c23163d" -version = "0.8.4" - -[[LLVM]] -deps = ["CEnum", "LLVMExtra_jll", "Libdl", "Printf", "Unicode"] -git-tree-sha1 = "46092047ca4edc10720ecab437c42283cd7c44f3" -uuid = "929cbde3-209d-540e-8aea-75f648917ca0" -version = "4.6.0" - -[[LLVMExtra_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "6a2af408fe809c4f1a54d2b3f188fdd3698549d6" -uuid = "dad2f222-ce93-54a1-a47d-0025e8a3acab" -version = "0.0.11+0" - -[[LazyArtifacts]] -deps = ["Artifacts", "Pkg"] -uuid = "4af54fe1-eca0-43a8-85a7-787d91b784e3" - -[[LibArchive_jll]] -deps = ["Artifacts", "Attr_jll", "Bzip2_jll", "Expat_jll", "JLLWrappers", "Libdl", "Libiconv_jll", "Lz4_jll", "OpenSSL_jll", "Pkg", "XZ_jll", "Zlib_jll", "Zstd_jll", "acl_jll"] -git-tree-sha1 = "0d499cd779102298e49ce35cd97cfaadcaf96e09" -uuid = "1e303b3e-d4db-56ce-88c4-91e52606a1a8" -version = "3.5.1+0" - -[[LibCURL]] -deps = ["LibCURL_jll", "MozillaCACerts_jll"] -uuid = "b27032c2-a3e7-50c8-80cd-2d36dbcbfd21" - -[[LibCURL_jll]] -deps = ["Artifacts", "LibSSH2_jll", "Libdl", "MbedTLS_jll", "Zlib_jll", "nghttp2_jll"] -uuid = "deac9b47-8bc7-5906-a0fe-35ac56dc84c0" - -[[LibGit2]] -deps = ["Base64", "NetworkOptions", "Printf", "SHA"] -uuid = "76f85450-5226-5b5a-8eaa-529ad045b433" - -[[LibSSH2_jll]] -deps = ["Artifacts", "Libdl", "MbedTLS_jll"] -uuid = "29816b5a-b9ab-546f-933c-edad1886dfa8" - -[[Libdl]] -uuid = "8f399da3-3557-5675-b5ff-fb832c97cbdb" - -[[Libiconv_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "42b62845d70a619f063a7da093d995ec8e15e778" -uuid = "94ce4f54-9a6c-5748-9c1c-f9c7231a4531" -version = "1.16.1+1" - -[[LinearAlgebra]] -deps = ["Libdl"] -uuid = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e" - -[[LogExpFunctions]] -deps = ["ChainRulesCore", "ChangesOfVariables", "DocStringExtensions", "InverseFunctions", "IrrationalConstants", "LinearAlgebra"] -git-tree-sha1 = "be9eef9f9d78cecb6f262f3c10da151a6c5ab827" -uuid = "2ab3a3ac-af41-5b50-aa03-7779005ae688" -version = "0.3.5" - -[[Logging]] -uuid = "56ddb016-857b-54e1-b83d-db4d58db5568" - -[[Lz4_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "5d494bc6e85c4c9b626ee0cab05daa4085486ab1" -uuid = "5ced341a-0733-55b8-9ab6-a4889d929147" -version = "1.9.3+0" - -[[MD5]] -deps = ["Random", "SHA"] -git-tree-sha1 = "eeffe42284464c35a08026d23aa948421acf8923" -uuid = "6ac74813-4b46-53a4-afec-0b5dc9d7885c" -version = "0.2.1" - -[[MacroTools]] -deps = ["Markdown", "Random"] -git-tree-sha1 = "3d3e902b31198a27340d0bf00d6ac452866021cf" -uuid = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09" -version = "0.5.9" - -[[MappedArrays]] -git-tree-sha1 = "e8b359ef06ec72e8c030463fe02efe5527ee5142" -uuid = "dbb5928d-eab1-5f90-85c2-b9b0edb7c900" -version = "0.4.1" - -[[Markdown]] -deps = ["Base64"] -uuid = "d6f4376e-aef5-505a-96c1-9c027394607a" - -[[MbedTLS_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "c8ffd9c3-330d-5841-b78e-0817d7145fa1" - -[[Media]] -deps = ["MacroTools", "Test"] -git-tree-sha1 = "75a54abd10709c01f1b86b84ec225d26e840ed58" -uuid = "e89f7d12-3494-54d1-8411-f7d8b9ae1f27" -version = "0.5.0" - -[[Missings]] -deps = ["DataAPI"] -git-tree-sha1 = "bf210ce90b6c9eed32d25dbcae1ebc565df2687f" -uuid = "e1d29d7a-bbdc-5cf2-9ac0-f12de2c33e28" -version = "1.0.2" - -[[Mmap]] -uuid = "a63ad114-7e13-5084-954f-fe012c677804" - -[[MosaicViews]] -deps = ["MappedArrays", "OffsetArrays", "PaddedViews", "StackViews"] -git-tree-sha1 = "b34e3bc3ca7c94914418637cb10cc4d1d80d877d" -uuid = "e94cdb99-869f-56ef-bcf0-1ae2bcbe0389" -version = "0.3.3" - -[[MozillaCACerts_jll]] -uuid = "14a3606d-f60d-562e-9121-12d972cd8159" - -[[Mustache]] -deps = ["Printf", "Tables"] -git-tree-sha1 = "21d7a05c3b94bcf45af67beccab4f2a1f4a3c30a" -uuid = "ffc61752-8dc7-55ee-8c37-f3e9cdd09e70" -version = "1.0.12" - -[[NNlib]] -deps = ["Adapt", "ChainRulesCore", "Compat", "LinearAlgebra", "Pkg", "Requires", "Statistics"] -git-tree-sha1 = "2eb305b13eaed91d7da14269bf17ce6664bfee3d" -uuid = "872c559c-99b0-510c-b3b7-b6c96a88d5cd" -version = "0.7.31" - -[[NNlibCUDA]] -deps = ["CUDA", "LinearAlgebra", "NNlib", "Random", "Statistics"] -git-tree-sha1 = "38358632d9c277f7bf8d202c127f601e8467aa4d" -uuid = "a00861dc-f156-4864-bf3c-e6376f28a68d" -version = "0.1.10" - -[[NaNMath]] -git-tree-sha1 = "bfe47e760d60b82b66b61d2d44128b62e3a369fb" -uuid = "77ba4419-2d1f-58cd-9bb1-8ffee604a2e3" -version = "0.3.5" - -[[NetworkOptions]] -uuid = "ca575930-c2e3-43a9-ace4-1e988b2c1908" - -[[OffsetArrays]] -deps = ["Adapt"] -git-tree-sha1 = "043017e0bdeff61cfbb7afeb558ab29536bbb5ed" -uuid = "6fe1bfb0-de20-5000-8ca7-80f57d26f881" -version = "1.10.8" - -[[OpenLibm_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "05823500-19ac-5b8b-9628-191a04bc5112" - -[[OpenSSL_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "15003dcb7d8db3c6c857fda14891a539a8f2705a" -uuid = "458c3c95-2e84-50aa-8efc-19380b2a3a95" -version = "1.1.10+0" - -[[OpenSpecFun_jll]] -deps = ["Artifacts", "CompilerSupportLibraries_jll", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "13652491f6856acfd2db29360e1bbcd4565d04f1" -uuid = "efe28fd5-8261-553b-a9e1-b2916fc3738e" -version = "0.5.5+0" - -[[OrderedCollections]] -git-tree-sha1 = "85f8e6578bf1f9ee0d11e7bb1b1456435479d47c" -uuid = "bac558e1-5e72-5ebc-8fee-abe8a469f55d" -version = "1.4.1" - -[[PDMats]] -deps = ["LinearAlgebra", "SparseArrays", "SuiteSparse"] -git-tree-sha1 = "ee26b350276c51697c9c2d88a072b339f9f03d73" -uuid = "90014a1f-27ba-587c-ab20-58faa44d9150" -version = "0.11.5" - -[[PaddedViews]] -deps = ["OffsetArrays"] -git-tree-sha1 = "646eed6f6a5d8df6708f15ea7e02a7a2c4fe4800" -uuid = "5432bcbf-9aad-5242-b902-cca2824c8663" -version = "0.5.10" - -[[Parsers]] -deps = ["Dates"] -git-tree-sha1 = "ae4bbcadb2906ccc085cf52ac286dc1377dceccc" -uuid = "69de0a69-1ddd-5017-9359-2bf0b02dc9f0" -version = "2.1.2" - -[[Pkg]] -deps = ["Artifacts", "Dates", "Downloads", "LibGit2", "Libdl", "Logging", "Markdown", "Printf", "REPL", "Random", "SHA", "Serialization", "TOML", "Tar", "UUIDs", "p7zip_jll"] -uuid = "44cfe95a-1eb2-52ea-b672-e2afdf69b78f" - -[[Preferences]] -deps = ["TOML"] -git-tree-sha1 = "00cfd92944ca9c760982747e9a1d0d5d86ab1e5a" -uuid = "21216c6a-2e73-6563-6e65-726566657250" -version = "1.2.2" - -[[Printf]] -deps = ["Unicode"] -uuid = "de0858da-6303-5e67-8744-51eddeeeb8d7" - -[[Profile]] -deps = ["Printf"] -uuid = "9abbd945-dff8-562f-b5e8-e1ebf5ef1b79" - -[[ProgressMeter]] -deps = ["Distributed", "Printf"] -git-tree-sha1 = "afadeba63d90ff223a6a48d2009434ecee2ec9e8" -uuid = "92933f4c-e287-5a05-a399-4b506db050ca" -version = "1.7.1" - -[[ProtoBuf]] -deps = ["Logging", "protoc_jll"] -git-tree-sha1 = "37585d8c037352f23dce4b5bb9c2de2a17a76b71" -uuid = "3349acd9-ac6a-5e09-bcdb-63829b23a429" -version = "0.11.3" - -[[QuadGK]] -deps = ["DataStructures", "LinearAlgebra"] -git-tree-sha1 = "78aadffb3efd2155af139781b8a8df1ef279ea39" -uuid = "1fd47b50-473d-5c70-9696-f719f8f3bcdc" -version = "2.4.2" - -[[Quaternions]] -deps = ["DualNumbers", "LinearAlgebra"] -git-tree-sha1 = "adf644ef95a5e26c8774890a509a55b7791a139f" -uuid = "94ee1d12-ae83-5a48-8b1c-48b8ff168ae0" -version = "0.4.2" - -[[REPL]] -deps = ["InteractiveUtils", "Markdown", "Sockets", "Unicode"] -uuid = "3fa0cd96-eef1-5676-8a61-b3b8758bbffb" - -[[Random]] -deps = ["Serialization"] -uuid = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c" - -[[Random123]] -deps = ["Libdl", "Random", "RandomNumbers"] -git-tree-sha1 = "0e8b146557ad1c6deb1367655e052276690e71a3" -uuid = "74087812-796a-5b5d-8853-05524746bad3" -version = "1.4.2" - -[[RandomNumbers]] -deps = ["Random", "Requires"] -git-tree-sha1 = "043da614cc7e95c703498a491e2c21f58a2b8111" -uuid = "e6cf234a-135c-5ec9-84dd-332b85af5143" -version = "1.5.3" - -[[Ratios]] -deps = ["Requires"] -git-tree-sha1 = "01d341f502250e81f6fec0afe662aa861392a3aa" -uuid = "c84ed2f1-dad5-54f0-aa8e-dbefe2724439" -version = "0.4.2" - -[[RealDot]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "9f0a1b71baaf7650f4fa8a1d168c7fb6ee41f0c9" -uuid = "c1ae055f-0cd5-4b69-90a6-9a35b1a98df9" -version = "0.1.0" - -[[Reexport]] -git-tree-sha1 = "45e428421666073eab6f2da5c9d310d99bb12f9b" -uuid = "189a3867-3050-52da-a836-e630ba90ab69" -version = "1.2.2" - -[[ReinforcementLearning]] -deps = ["Reexport", "ReinforcementLearningBase", "ReinforcementLearningCore", "ReinforcementLearningEnvironments", "ReinforcementLearningZoo"] -path = "../.." -uuid = "158674fc-8238-5cab-b5ba-03dfc80d1318" -version = "0.10.0" - -[[ReinforcementLearningBase]] -deps = ["AbstractTrees", "CommonRLInterface", "Markdown", "Random", "Test"] -path = "../ReinforcementLearningBase" -uuid = "e575027e-6cd6-5018-9292-cdc6200d2b44" -version = "0.9.7" - -[[ReinforcementLearningCore]] -deps = ["AbstractTrees", "Adapt", "ArrayInterface", "CUDA", "CircularArrayBuffers", "Compat", "Dates", "Distributions", "ElasticArrays", "FillArrays", "Flux", "Functors", "GPUArrays", "LinearAlgebra", "MacroTools", "Markdown", "ProgressMeter", "Random", "ReinforcementLearningBase", "Setfield", "Statistics", "StatsBase", "UnicodePlots", "Zygote"] -path = "../ReinforcementLearningCore" -uuid = "de1b191a-4ae0-4afa-a27b-92d07f46b2d6" -version = "0.8.6" - -[[ReinforcementLearningEnvironments]] -deps = ["DelimitedFiles", "IntervalSets", "LinearAlgebra", "MacroTools", "Markdown", "Pkg", "Random", "ReinforcementLearningBase", "Requires", "SparseArrays", "StatsBase"] -path = "../ReinforcementLearningEnvironments" -uuid = "25e41dd2-4622-11e9-1641-f1adca772921" -version = "0.6.10" - -[[ReinforcementLearningZoo]] -deps = ["AbstractTrees", "CUDA", "CircularArrayBuffers", "DataStructures", "Dates", "Distributions", "Flux", "IntervalSets", "LinearAlgebra", "Logging", "MacroTools", "Random", "ReinforcementLearningBase", "ReinforcementLearningCore", "Setfield", "Statistics", "StatsBase", "StructArrays", "Zygote"] -path = "../ReinforcementLearningZoo" -uuid = "d607f57d-ee1e-4ba7-bcf2-7734c1e31854" -version = "0.5.4" - -[[RelocatableFolders]] -deps = ["SHA", "Scratch"] -git-tree-sha1 = "cdbd3b1338c72ce29d9584fdbe9e9b70eeb5adca" -uuid = "05181044-ff0b-4ac5-8273-598c1e38db00" -version = "0.1.3" - -[[Requires]] -deps = ["UUIDs"] -git-tree-sha1 = "4036a3bd08ac7e968e27c203d45f5fff15020621" -uuid = "ae029012-a4dd-5104-9daa-d747884805df" -version = "1.1.3" - -[[Rmath]] -deps = ["Random", "Rmath_jll"] -git-tree-sha1 = "bf3188feca147ce108c76ad82c2792c57abe7b1f" -uuid = "79098fc4-a85e-5d69-aa6a-4863f24498fa" -version = "0.7.0" - -[[Rmath_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "68db32dff12bb6127bac73c209881191bf0efbb7" -uuid = "f50d1b31-88e8-58de-be2c-1cc44531875f" -version = "0.3.0+0" - -[[Rotations]] -deps = ["LinearAlgebra", "Quaternions", "Random", "StaticArrays", "Statistics"] -git-tree-sha1 = "dbf5f991130238f10abbf4f2d255fb2837943c43" -uuid = "6038ab10-8711-5258-84ad-4b1120ba62dc" -version = "1.1.0" - -[[SHA]] -uuid = "ea8e919c-243c-51af-8825-aaa63cd721ce" - -[[Scratch]] -deps = ["Dates"] -git-tree-sha1 = "0b4b7f1393cff97c33891da2a0bf69c6ed241fda" -uuid = "6c6a2e73-6563-6170-7368-637461726353" -version = "1.1.0" - -[[Serialization]] -uuid = "9e88b42a-f829-5b0c-bbe9-9e923198166b" - -[[Setfield]] -deps = ["ConstructionBase", "Future", "MacroTools", "Requires"] -git-tree-sha1 = "def0718ddbabeb5476e51e5a43609bee889f285d" -uuid = "efcf1570-3423-57d1-acb7-fd33fddbac46" -version = "0.8.0" - -[[SharedArrays]] -deps = ["Distributed", "Mmap", "Random", "Serialization"] -uuid = "1a1011a3-84de-559e-8e89-a11a2f7dc383" - -[[Sockets]] -uuid = "6462fe0b-24de-5631-8697-dd941f90decc" - -[[SortingAlgorithms]] -deps = ["DataStructures"] -git-tree-sha1 = "b3363d7460f7d098ca0912c69b082f75625d7508" -uuid = "a2af1166-a08f-5f64-846c-94a0d3cef48c" -version = "1.0.1" - -[[SparseArrays]] -deps = ["LinearAlgebra", "Random"] -uuid = "2f01184e-e22b-5df5-ae63-d93ebab69eaf" - -[[SpecialFunctions]] -deps = ["ChainRulesCore", "IrrationalConstants", "LogExpFunctions", "OpenLibm_jll", "OpenSpecFun_jll"] -git-tree-sha1 = "f0bccf98e16759818ffc5d97ac3ebf87eb950150" -uuid = "276daf66-3868-5448-9aa4-cd146d93841b" -version = "1.8.1" - -[[StableRNGs]] -deps = ["Random", "Test"] -git-tree-sha1 = "3be7d49667040add7ee151fefaf1f8c04c8c8276" -uuid = "860ef19b-820b-49d6-a774-d7a799459cd3" -version = "1.0.0" - -[[StackViews]] -deps = ["OffsetArrays"] -git-tree-sha1 = "46e589465204cd0c08b4bd97385e4fa79a0c770c" -uuid = "cae243ae-269e-4f55-b966-ac2d0dc13c15" -version = "0.1.1" - -[[Static]] -deps = ["IfElse"] -git-tree-sha1 = "e7bc80dc93f50857a5d1e3c8121495852f407e6a" -uuid = "aedffcd0-7271-4cad-89d0-dc628f76c6d3" -version = "0.4.0" - -[[StaticArrays]] -deps = ["LinearAlgebra", "Random", "Statistics"] -git-tree-sha1 = "3c76dde64d03699e074ac02eb2e8ba8254d428da" -uuid = "90137ffa-7385-5640-81b9-e52037218182" -version = "1.2.13" - -[[Statistics]] -deps = ["LinearAlgebra", "SparseArrays"] -uuid = "10745b16-79ce-11e8-11f9-7d13ad32a3b2" - -[[StatsAPI]] -git-tree-sha1 = "1958272568dc176a1d881acb797beb909c785510" -uuid = "82ae8749-77ed-4fe6-ae5f-f523153014b0" -version = "1.0.0" - -[[StatsBase]] -deps = ["DataAPI", "DataStructures", "LinearAlgebra", "LogExpFunctions", "Missings", "Printf", "Random", "SortingAlgorithms", "SparseArrays", "Statistics", "StatsAPI"] -git-tree-sha1 = "eb35dcc66558b2dda84079b9a1be17557d32091a" -uuid = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91" -version = "0.33.12" - -[[StatsFuns]] -deps = ["ChainRulesCore", "InverseFunctions", "IrrationalConstants", "LogExpFunctions", "Reexport", "Rmath", "SpecialFunctions"] -git-tree-sha1 = "385ab64e64e79f0cd7cfcf897169b91ebbb2d6c8" -uuid = "4c63d2b9-4356-54db-8cca-17b64c39e42c" -version = "0.9.13" - -[[StringEncodings]] -deps = ["Libiconv_jll"] -git-tree-sha1 = "50ccd5ddb00d19392577902f0079267a72c5ab04" -uuid = "69024149-9ee7-55f6-a4c4-859efe599b68" -version = "0.3.5" - -[[StructArrays]] -deps = ["Adapt", "DataAPI", "StaticArrays", "Tables"] -git-tree-sha1 = "2ce41e0d042c60ecd131e9fb7154a3bfadbf50d3" -uuid = "09ab397b-f2b6-538f-b94a-2f83cf4a842a" -version = "0.6.3" - -[[SuiteSparse]] -deps = ["Libdl", "LinearAlgebra", "Serialization", "SparseArrays"] -uuid = "4607b0f0-06f3-5cda-b6b1-a6196a1729e9" - -[[TOML]] -deps = ["Dates"] -uuid = "fa267f1f-6049-4f14-aa54-33bafae1ed76" - -[[TableTraits]] -deps = ["IteratorInterfaceExtensions"] -git-tree-sha1 = "c06b2f539df1c6efa794486abfb6ed2022561a39" -uuid = "3783bdb8-4a98-5b6b-af9a-565f29a5fe9c" -version = "1.0.1" - -[[Tables]] -deps = ["DataAPI", "DataValueInterfaces", "IteratorInterfaceExtensions", "LinearAlgebra", "TableTraits", "Test"] -git-tree-sha1 = "fed34d0e71b91734bf0a7e10eb1bb05296ddbcd0" -uuid = "bd369af6-aec1-5ad0-b16a-f7cc5008161c" -version = "1.6.0" - -[[Tar]] -deps = ["ArgTools", "SHA"] -uuid = "a4e569a6-e804-4fa4-b0f3-eef7a1d5b13e" - -[[TensorBoardLogger]] -deps = ["CRC32c", "FileIO", "ImageCore", "ProtoBuf", "Requires", "StatsBase"] -git-tree-sha1 = "96d160e85038f6d89e6c9b91492466f9a7d454f2" -uuid = "899adc3e-224a-11e9-021f-63837185c80f" -version = "0.1.18" - -[[TensorCore]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "1feb45f88d133a655e001435632f019a9a1bcdb6" -uuid = "62fd8b95-f654-4bbd-a8a5-9c27f68ccd50" -version = "0.1.1" - -[[Test]] -deps = ["InteractiveUtils", "Logging", "Random", "Serialization"] -uuid = "8dfed614-e22c-5e08-85e1-65c5234f0b40" - -[[TimerOutputs]] -deps = ["ExprTools", "Printf"] -git-tree-sha1 = "7cb456f358e8f9d102a8b25e8dfedf58fa5689bc" -uuid = "a759f4b9-e2f1-59dc-863e-4aeb61b1ea8f" -version = "0.5.13" - -[[TranscodingStreams]] -deps = ["Random", "Test"] -git-tree-sha1 = "216b95ea110b5972db65aa90f88d8d89dcb8851c" -uuid = "3bb67fe8-82b1-5028-8e26-92a6c54297fa" -version = "0.9.6" - -[[UUIDs]] -deps = ["Random", "SHA"] -uuid = "cf7118a7-6976-5b1a-9a39-7adc72f591a4" - -[[Unicode]] -uuid = "4ec0a83e-493e-50e2-b9ac-8f72acf5a8f5" - -[[UnicodePlots]] -deps = ["Crayons", "Dates", "SparseArrays", "StatsBase"] -git-tree-sha1 = "f1d09f14722f5f3cef029bcb031be91a92613ae9" -uuid = "b8865327-cd53-5732-bb35-84acbb429228" -version = "2.4.6" - -[[Weave]] -deps = ["Base64", "Dates", "Highlights", "JSON", "Markdown", "Mustache", "Pkg", "Printf", "REPL", "RelocatableFolders", "Requires", "Serialization", "YAML"] -git-tree-sha1 = "d62575dcea5aeb2bfdfe3b382d145b65975b5265" -uuid = "44d3d7a6-8a23-5bf8-98c5-b353f8df5ec9" -version = "0.10.10" - -[[WoodburyMatrices]] -deps = ["LinearAlgebra", "SparseArrays"] -git-tree-sha1 = "de67fa59e33ad156a590055375a30b23c40299d3" -uuid = "efce3f68-66dc-5838-9240-27a6d6f5f9b6" -version = "0.5.5" - -[[XZ_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "a921669cd9a45c23031fd4eb904f5cc3d20de415" -uuid = "ffd25f8a-64ca-5728-b0f7-c24cf3aae800" -version = "5.2.5+2" - -[[YAML]] -deps = ["Base64", "Dates", "Printf", "StringEncodings"] -git-tree-sha1 = "3c6e8b9f5cdaaa21340f841653942e1a6b6561e5" -uuid = "ddb6d928-2868-570f-bddf-ab3f9cf99eb6" -version = "0.4.7" - -[[ZipFile]] -deps = ["Libdl", "Printf", "Zlib_jll"] -git-tree-sha1 = "3593e69e469d2111389a9bd06bac1f3d730ac6de" -uuid = "a5390f91-8eb1-5f08-bee0-b1d1ffed6cea" -version = "0.9.4" - -[[Zlib_jll]] -deps = ["Libdl"] -uuid = "83775a58-1f1d-513f-b197-d71354ab007a" - -[[Zstd_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "cc4bf3fdde8b7e3e9fa0351bdeedba1cf3b7f6e6" -uuid = "3161d3a3-bdf6-5164-811a-617609db77b4" -version = "1.5.0+0" - -[[Zygote]] -deps = ["AbstractFFTs", "ChainRules", "ChainRulesCore", "DiffRules", "Distributed", "FillArrays", "ForwardDiff", "IRTools", "InteractiveUtils", "LinearAlgebra", "MacroTools", "NaNMath", "Random", "Requires", "SpecialFunctions", "Statistics", "ZygoteRules"] -git-tree-sha1 = "2c30f2df0ba43c17e88c8b55b5b22c401f7cde4e" -uuid = "e88e6eb3-aa80-5325-afca-941959d7151f" -version = "0.6.30" - -[[ZygoteRules]] -deps = ["MacroTools"] -git-tree-sha1 = "8c1a8e4dfacb1fd631745552c8db35d0deb09ea0" -uuid = "700de1a5-db45-46bc-99cf-38207098b444" -version = "0.2.2" - -[[acl_jll]] -deps = ["Artifacts", "Attr_jll", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "4a59345d2f8088bc358f6fa7f0774b7d9ee30b40" -uuid = "ed5aba05-e74d-5cf7-8b09-107ba3463b8e" -version = "2.3.1+0" - -[[nghttp2_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "8e850ede-7688-5339-a07c-302acd2aaf8d" - -[[p7zip_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "3f19e933-33d8-53b3-aaab-bd5110c3b7a0" - -[[protoc_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "89b92b537ffde09cab61ad20636da135d0791007" -uuid = "c7845625-083e-5bbe-8504-b32d602b7110" -version = "3.15.6+0" diff --git a/src/ReinforcementLearningExperiments/Project.toml b/src/ReinforcementLearningExperiments/Project.toml index 2bbe398ec..177a56968 100644 --- a/src/ReinforcementLearningExperiments/Project.toml +++ b/src/ReinforcementLearningExperiments/Project.toml @@ -4,59 +4,19 @@ authors = ["Jun Tian "] version = "0.1.4" [deps] -AbstractTrees = "1520ce14-60c1-5f80-bbc7-55ef81b5835c" -ArcadeLearningEnvironment = "b7f77d8d-088d-5e02-8ac0-89aab2acc977" -BSON = "fbb218c0-5317-5bc6-957e-2ee96dd4b1f0" -CUDA = "052768ef-5323-5732-b1bb-66c8b64840ba" -ChainRulesCore = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4" -Dates = "ade2ca70-3891-5945-98fb-dc099432e06a" -Distributions = "31c24e10-a181-5473-b8eb-7969acd0382f" Flux = "587475ba-b771-5e3f-ad9e-33799f191a9c" -GridWorlds = "e15a9946-cd7f-4d03-83e2-6c30bacb0043" -ImageTransformations = "02fcd773-0e25-5acc-982a-7f6622650795" -IntervalSets = "8197267c-284f-5f27-9208-e0e47529a953" -Logging = "56ddb016-857b-54e1-b83d-db4d58db5568" -Markdown = "d6f4376e-aef5-505a-96c1-9c027394607a" -Random = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c" +Reexport = "189a3867-3050-52da-a836-e630ba90ab69" ReinforcementLearning = "158674fc-8238-5cab-b5ba-03dfc80d1318" -ReinforcementLearningBase = "e575027e-6cd6-5018-9292-cdc6200d2b44" -ReinforcementLearningCore = "de1b191a-4ae0-4afa-a27b-92d07f46b2d6" -ReinforcementLearningEnvironments = "25e41dd2-4622-11e9-1641-f1adca772921" -ReinforcementLearningZoo = "d607f57d-ee1e-4ba7-bcf2-7734c1e31854" -Requires = "ae029012-a4dd-5104-9daa-d747884805df" -Setfield = "efcf1570-3423-57d1-acb7-fd33fddbac46" StableRNGs = "860ef19b-820b-49d6-a774-d7a799459cd3" -Statistics = "10745b16-79ce-11e8-11f9-7d13ad32a3b2" -TensorBoardLogger = "899adc3e-224a-11e9-021f-63837185c80f" Weave = "44d3d7a6-8a23-5bf8-98c5-b353f8df5ec9" -Zygote = "e88e6eb3-aa80-5325-afca-941959d7151f" [compat] -AbstractTrees = "0.3" -ArcadeLearningEnvironment = "0.2" -BSON = "0.3" -CUDA = "3" -ChainRulesCore = "1" -Distributions = "0.24, 0.25" -Flux = "0.12" -GridWorlds = "0.5" -ImageTransformations = "0.8, 0.9" -IntervalSets = "0.5" -ReinforcementLearning = "0.10" -ReinforcementLearningBase = "0.9" -ReinforcementLearningCore = "0.8" -ReinforcementLearningEnvironments = "0.6.4" -ReinforcementLearningZoo = "0.5" -Requires = "1" -Setfield = "0.7, 0.8" -StableRNGs = "1" -TensorBoardLogger = "0.1" -Weave = "0.10" -Zygote = "0.6" +ReinforcementLearning = "0.11" julia = "1.6" [extras] +CUDA = "052768ef-5323-5732-b1bb-66c8b64840ba" Test = "8dfed614-e22c-5e08-85e1-65c5234f0b40" [targets] -test = ["Test"] +test = ["CUDA", "Test"] diff --git a/src/ReinforcementLearningExperiments/deps/experiments/experiments/DQN/JuliaRL_BasicDQN_CartPole.jl b/src/ReinforcementLearningExperiments/deps/experiments/experiments/DQN/JuliaRL_BasicDQN_CartPole.jl index 0c7c5f808..00fc13a6a 100644 --- a/src/ReinforcementLearningExperiments/deps/experiments/experiments/DQN/JuliaRL_BasicDQN_CartPole.jl +++ b/src/ReinforcementLearningExperiments/deps/experiments/experiments/DQN/JuliaRL_BasicDQN_CartPole.jl @@ -2,58 +2,65 @@ # title: JuliaRL\_BasicDQN\_CartPole # cover: assets/JuliaRL_BasicDQN_CartPole.png # description: The simplest example to demonstrate how to use BasicDQN -# date: 2021-05-22 +# date: 2022-06-04 # author: "[Jun Tian](https://github.com/findmyway)" # --- #+ tangle=true using ReinforcementLearning -using StableRNGs using Flux -using Flux.Losses +using Flux: glorot_uniform + +using StableRNGs: StableRNG +using Flux.Losses: huber_loss function RL.Experiment( ::Val{:JuliaRL}, ::Val{:BasicDQN}, - ::Val{:CartPole}, - ::Nothing; - seed = 123, + ::Val{:CartPole}; + seed=123 ) rng = StableRNG(seed) - env = CartPoleEnv(; T = Float32, rng = rng) + env = CartPoleEnv(; T=Float32, rng=rng) ns, na = length(state(env)), length(action_space(env)) - policy = Agent( - policy = QBasedPolicy( - learner = BasicDQNLearner( - approximator = NeuralNetworkApproximator( - model = Chain( - Dense(ns, 128, relu; init = glorot_uniform(rng)), - Dense(128, 128, relu; init = glorot_uniform(rng)), - Dense(128, na; init = glorot_uniform(rng)), + agent = Agent( + policy=QBasedPolicy( + learner=BasicDQNLearner( + approximator=Approximator( + model=Chain( + Dense(ns, 128, relu; init=glorot_uniform(rng)), + Dense(128, 128, relu; init=glorot_uniform(rng)), + Dense(128, na; init=glorot_uniform(rng)), ) |> gpu, - optimizer = ADAM(), + optimiser=ADAM(), ), - batch_size = 32, - min_replay_history = 100, - loss_func = huber_loss, - rng = rng, + loss_func=huber_loss, ), - explorer = EpsilonGreedyExplorer( - kind = :exp, - ϵ_stable = 0.01, - decay_steps = 500, - rng = rng, + explorer=EpsilonGreedyExplorer( + kind=:exp, + ϵ_stable=0.01, + decay_steps=500, + rng=rng, ), ), - trajectory = CircularArraySARTTrajectory( - capacity = 1000, - state = Vector{Float32} => (ns,), - ), + trajectory=Trajectory( + container=CircularArraySARTTraces( + capacity=1000, + state=Float32 => (ns,), + ), + sampler=BatchSampler{(:state, :action, :reward, :terminal, :next_state)}( + batch_size=32 + ), + controller=InsertSampleRatioController( + threshold=100, + n_inserted=-1 + ) + ) ) stop_condition = StopAfterStep(10_000, is_show_progress=!haskey(ENV, "CI")) hook = TotalRewardPerEpisode() - Experiment(policy, env, stop_condition, hook, "# BasicDQN <-> CartPole") + Experiment(agent, env, stop_condition, hook) end #+ tangle=false diff --git a/src/ReinforcementLearningExperiments/src/ReinforcementLearningExperiments.jl b/src/ReinforcementLearningExperiments/src/ReinforcementLearningExperiments.jl index 0f615ba3f..b3b1b327d 100644 --- a/src/ReinforcementLearningExperiments/src/ReinforcementLearningExperiments.jl +++ b/src/ReinforcementLearningExperiments/src/ReinforcementLearningExperiments.jl @@ -1,29 +1,16 @@ module ReinforcementLearningExperiments -using ReinforcementLearning -using Requires -using StableRNGs -using Flux -using Flux.Losses -using Setfield -using Dates -using TensorBoardLogger -using Logging -using Distributions -using IntervalSets -using BSON +using Reexport -import ReinforcementLearning: Experiment - -export @experiment_cmd, @E_cmd, Experiment +@reexport using ReinforcementLearning const EXPERIMENTS_DIR = joinpath(@__DIR__, "experiments") -for f in readdir(EXPERIMENTS_DIR) - include(joinpath(EXPERIMENTS_DIR, f)) -end +# for f in readdir(EXPERIMENTS_DIR) +# include(joinpath(EXPERIMENTS_DIR, f)) +# end +include(joinpath(EXPERIMENTS_DIR, "JuliaRL_BasicDQN_CartPole.jl")) # dynamic loading environments -function __init__() -end +function __init__() end end # module diff --git a/src/ReinforcementLearningExperiments/test/runtests.jl b/src/ReinforcementLearningExperiments/test/runtests.jl index 0fc4dc685..1b1c9cafc 100644 --- a/src/ReinforcementLearningExperiments/test/runtests.jl +++ b/src/ReinforcementLearningExperiments/test/runtests.jl @@ -4,24 +4,24 @@ using CUDA CUDA.allowscalar(false) run(E`JuliaRL_BasicDQN_CartPole`) -run(E`JuliaRL_BC_CartPole`) -run(E`JuliaRL_DQN_CartPole`) -run(E`JuliaRL_PrioritizedDQN_CartPole`) -run(E`JuliaRL_Rainbow_CartPole`) -run(E`JuliaRL_QRDQN_CartPole`) -run(E`JuliaRL_REMDQN_CartPole`) -run(E`JuliaRL_IQN_CartPole`) -run(E`JuliaRL_VMPO_CartPole`) -run(E`JuliaRL_VPG_CartPole`) -run(E`JuliaRL_BasicDQN_MountainCar`) -run(E`JuliaRL_DQN_MountainCar`) -run(E`JuliaRL_A2C_CartPole`) -run(E`JuliaRL_A2CGAE_CartPole`) -run(E`JuliaRL_PPO_CartPole`) -run(E`JuliaRL_MAC_CartPole`) -run(E`JuliaRL_DDPG_Pendulum`) -run(E`JuliaRL_SAC_Pendulum`) -run(E`JuliaRL_TD3_Pendulum`) -run(E`JuliaRL_PPO_Pendulum`) +# run(E`JuliaRL_BC_CartPole`) +# run(E`JuliaRL_DQN_CartPole`) +# run(E`JuliaRL_PrioritizedDQN_CartPole`) +# run(E`JuliaRL_Rainbow_CartPole`) +# run(E`JuliaRL_QRDQN_CartPole`) +# run(E`JuliaRL_REMDQN_CartPole`) +# run(E`JuliaRL_IQN_CartPole`) +# run(E`JuliaRL_VMPO_CartPole`) +# run(E`JuliaRL_VPG_CartPole`) +# run(E`JuliaRL_BasicDQN_MountainCar`) +# run(E`JuliaRL_DQN_MountainCar`) +# run(E`JuliaRL_A2C_CartPole`) +# run(E`JuliaRL_A2CGAE_CartPole`) +# run(E`JuliaRL_PPO_CartPole`) +# run(E`JuliaRL_MAC_CartPole`) +# run(E`JuliaRL_DDPG_Pendulum`) +# run(E`JuliaRL_SAC_Pendulum`) +# run(E`JuliaRL_TD3_Pendulum`) +# run(E`JuliaRL_PPO_Pendulum`) -run(E`JuliaRL_BasicDQN_SingleRoomUndirected`) +# run(E`JuliaRL_BasicDQN_SingleRoomUndirected`) diff --git a/src/ReinforcementLearningZoo/.JuliaFormatter.toml b/src/ReinforcementLearningZoo/.JuliaFormatter.toml deleted file mode 100644 index 8ec1b0b70..000000000 --- a/src/ReinforcementLearningZoo/.JuliaFormatter.toml +++ /dev/null @@ -1,2 +0,0 @@ -verbose = true -always_for_in = true diff --git a/src/ReinforcementLearningZoo/.github/workflows/CompatHelper.yml b/src/ReinforcementLearningZoo/.github/workflows/CompatHelper.yml deleted file mode 100644 index 0f66259dd..000000000 --- a/src/ReinforcementLearningZoo/.github/workflows/CompatHelper.yml +++ /dev/null @@ -1,22 +0,0 @@ -name: CompatHelper - -on: - schedule: - - cron: '00 00 * * *' - workflow_dispatch: - -jobs: - CompatHelper: - runs-on: ${{ matrix.os }} - strategy: - matrix: - julia-version: [1.2.0] - julia-arch: [x86] - os: [ubuntu-latest] - steps: - - name: Pkg.add("CompatHelper") - run: julia -e 'using Pkg; Pkg.add("CompatHelper")' - - name: CompatHelper.main() - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - run: julia -e 'using CompatHelper; CompatHelper.main()' diff --git a/src/ReinforcementLearningZoo/.github/workflows/TagBot.yml b/src/ReinforcementLearningZoo/.github/workflows/TagBot.yml deleted file mode 100644 index 33fd52d25..000000000 --- a/src/ReinforcementLearningZoo/.github/workflows/TagBot.yml +++ /dev/null @@ -1,17 +0,0 @@ -name: TagBot -on: - issue_comment: # THIS BIT IS NEW - types: - - created - workflow_dispatch: -jobs: - TagBot: - # THIS 'if' LINE IS NEW - if: github.event_name == 'workflow_dispatch' || github.actor == 'JuliaTagBot' - # NOTHING BELOW HAS CHANGED - runs-on: ubuntu-latest - steps: - - uses: JuliaRegistries/TagBot@v1 - with: - token: ${{ secrets.GITHUB_TOKEN }} - # ssh: ${{ secrets.DOCUMENTER_KEY }} diff --git a/src/ReinforcementLearningZoo/.github/workflows/changelog.yml b/src/ReinforcementLearningZoo/.github/workflows/changelog.yml deleted file mode 100644 index 943326faf..000000000 --- a/src/ReinforcementLearningZoo/.github/workflows/changelog.yml +++ /dev/null @@ -1,34 +0,0 @@ -name: Changelog - -on: - release: - types: [published] - -jobs: - generate_changelog: - runs-on: ubuntu-latest - name: Generate changelog for master branch - steps: - - uses: actions/checkout@v1 - - - name: Generate changelog - uses: charmixer/auto-changelog-action@v1 - with: - token: ${{ secrets.GITHUB_TOKEN }} - - - name: Commit files - env: - CI_USER: noreply - CI_EMAIL: noreply@juliareinforcementlearning.org - run: | - git config --local user.email "$CI_EMAIL" - git config --local user.name "$CI_USER" - git add CHANGELOG.md && git commit -m 'Updated CHANGELOG.md' && echo ::set-env name=push::1 || echo "No changes to CHANGELOG.md" - - - name: Push changes - if: env.push == 1 - env: - CI_USER: noreply - CI_TOKEN: ${{ secrets.GITHUB_TOKEN }} - run: | - git push "https://$CI_USER:$CI_TOKEN@github.com/$GITHUB_REPOSITORY.git" HEAD:master diff --git a/src/ReinforcementLearningZoo/.github/workflows/ci.yml b/src/ReinforcementLearningZoo/.github/workflows/ci.yml deleted file mode 100644 index 48406b641..000000000 --- a/src/ReinforcementLearningZoo/.github/workflows/ci.yml +++ /dev/null @@ -1,44 +0,0 @@ -name: CI -on: - pull_request: - branches: - - master - push: - branches: - - master - tags: '*' -jobs: - test: - name: Julia matrix.version−{{ matrix.os }} - matrix.arch−{{ github.event_name }} - runs-on: ${{ matrix.os }} - strategy: - fail-fast: false - matrix: - version: - - '1' # Leave this line unchanged. '1' will automatically expand to the latest stable 1.x release of Julia. - os: - - ubuntu-latest - arch: - - x64 - steps: - - uses: actions/checkout@v2 - - uses: julia-actions/setup-julia@v1 - with: - version: ${{ matrix.version }} - arch: ${{ matrix.arch }} - - uses: actions/cache@v1 - env: - cache-name: cache-artifacts - with: - path: ~/.julia/artifacts - key: runner.os−test−{{ env.cache-name }}-${{ hashFiles('**/Project.toml') }} - restore-keys: | - runner.os−test−{{ env.cache-name }}- - ${{ runner.os }}-test- - ${{ runner.os }}- - - uses: julia-actions/julia-buildpkg@v1 - - uses: julia-actions/julia-runtest@v1 - - uses: julia-actions/julia-processcoverage@v1 - - uses: codecov/codecov-action@v1 - with: - file: lcov.info diff --git a/src/ReinforcementLearningZoo/.github/workflows/format_pr.yml b/src/ReinforcementLearningZoo/.github/workflows/format_pr.yml deleted file mode 100644 index b7a9268d8..000000000 --- a/src/ReinforcementLearningZoo/.github/workflows/format_pr.yml +++ /dev/null @@ -1,29 +0,0 @@ -name: format-pr -on: - schedule: - - cron: '0 0 * * *' -jobs: - build: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - name: Install JuliaFormatter and format - run: | - julia -e 'import Pkg; Pkg.add("JuliaFormatter")' - julia -e 'using JuliaFormatter; format(".")' - # https://github.com/marketplace/actions/create-pull-request - # https://github.com/peter-evans/create-pull-request#reference-example - - name: Create Pull Request - id: cpr - uses: peter-evans/create-pull-request@v3 - with: - token: ${{ secrets.GITHUB_TOKEN }} - commit-message: Format .jl files - title: 'Automatic JuliaFormatter.jl run' - branch: auto-juliaformatter-pr - delete-branch: true - labels: formatting, automated pr, no changelog - - name: Check outputs - run: | - echo "Pull Request Number - ${{ steps.cpr.outputs.pull-request-number }}" - echo "Pull Request URL - ${{ steps.cpr.outputs.pull-request-url }}" diff --git a/src/ReinforcementLearningZoo/.gitignore b/src/ReinforcementLearningZoo/.gitignore deleted file mode 100644 index e98b86b45..000000000 --- a/src/ReinforcementLearningZoo/.gitignore +++ /dev/null @@ -1,8 +0,0 @@ -.DS_Store -/Manifest.toml -/dev/ -**/checkpoints/ - -# add vim generated temp files -*~ -*.swp diff --git a/src/ReinforcementLearningZoo/Artifacts.toml b/src/ReinforcementLearningZoo/Artifacts.toml deleted file mode 100644 index 344ad28f9..000000000 --- a/src/ReinforcementLearningZoo/Artifacts.toml +++ /dev/null @@ -1,7 +0,0 @@ -[JuliaRL_BasicDQN_CartPole] -git-tree-sha1 = "d55d71211dcd0f5b56c55640f4873b1344e67a2a" -lazy = true - - [[JuliaRL_BasicDQN_CartPole.download]] - url = "http://data.juliareinforcementlearning.org/artifacts/JuliaRL_BasicDQN_CartPole.tar.gz" - sha256 = "d4087daec14d08306d9288b0cb71aa43df198159f43932bc38f0ae535b7a63b5" \ No newline at end of file diff --git a/src/ReinforcementLearningZoo/Manifest.toml b/src/ReinforcementLearningZoo/Manifest.toml deleted file mode 100644 index f6f5de9b5..000000000 --- a/src/ReinforcementLearningZoo/Manifest.toml +++ /dev/null @@ -1,642 +0,0 @@ -# This file is machine-generated - editing it directly is not advised - -[[AbstractFFTs]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "485ee0867925449198280d4af84bdb46a2a404d0" -uuid = "621f4979-c628-5d54-868e-fcf4e3e8185c" -version = "1.0.1" - -[[AbstractTrees]] -git-tree-sha1 = "03e0550477d86222521d254b741d470ba17ea0b5" -uuid = "1520ce14-60c1-5f80-bbc7-55ef81b5835c" -version = "0.3.4" - -[[Adapt]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "84918055d15b3114ede17ac6a7182f68870c16f7" -uuid = "79e6a3ab-5dfb-504d-930d-738a2a938a0e" -version = "3.3.1" - -[[ArgTools]] -uuid = "0dad84c5-d112-42e6-8d28-ef12dabb789f" - -[[ArrayInterface]] -deps = ["Compat", "IfElse", "LinearAlgebra", "Requires", "SparseArrays", "Static"] -git-tree-sha1 = "b8d49c34c3da35f220e7295659cd0bab8e739fed" -uuid = "4fba245c-0d91-5ea0-9b3e-6abc04ee57a9" -version = "3.1.33" - -[[Artifacts]] -uuid = "56f22d72-fd6d-98f1-02f0-08ddc0907c33" - -[[BFloat16s]] -deps = ["LinearAlgebra", "Test"] -git-tree-sha1 = "4af69e205efc343068dc8722b8dfec1ade89254a" -uuid = "ab4f0b2a-ad5b-11e8-123f-65d77653426b" -version = "0.1.0" - -[[Base64]] -uuid = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f" - -[[CEnum]] -git-tree-sha1 = "215a9aa4a1f23fbd05b92769fdd62559488d70e9" -uuid = "fa961155-64e5-5f13-b03f-caf6b980ea82" -version = "0.4.1" - -[[CUDA]] -deps = ["AbstractFFTs", "Adapt", "BFloat16s", "CEnum", "CompilerSupportLibraries_jll", "ExprTools", "GPUArrays", "GPUCompiler", "LLVM", "LazyArtifacts", "Libdl", "LinearAlgebra", "Logging", "Printf", "Random", "Random123", "RandomNumbers", "Reexport", "Requires", "SparseArrays", "SpecialFunctions", "TimerOutputs"] -git-tree-sha1 = "335b3d2373733919b4972a51215a6840c7a33828" -uuid = "052768ef-5323-5732-b1bb-66c8b64840ba" -version = "3.4.2" - -[[ChainRules]] -deps = ["ChainRulesCore", "Compat", "LinearAlgebra", "Random", "Statistics"] -git-tree-sha1 = "74c737978316e19e0706737542037c468b21a8d9" -uuid = "082447d4-558c-5d27-93f4-14fc19e9eca2" -version = "1.11.6" - -[[ChainRulesCore]] -deps = ["Compat", "LinearAlgebra", "SparseArrays"] -git-tree-sha1 = "a325370b9dd0e6bf5656a6f1a7ae80755f8ccc46" -uuid = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4" -version = "1.7.2" - -[[CircularArrayBuffers]] -git-tree-sha1 = "b097d863df6c40491b7553a1eb235fbb86d37d0e" -uuid = "9de3a189-e0c0-4e15-ba3b-b14b9fb0aec1" -version = "0.1.3" - -[[CodecZlib]] -deps = ["TranscodingStreams", "Zlib_jll"] -git-tree-sha1 = "ded953804d019afa9a3f98981d99b33e3db7b6da" -uuid = "944b1d66-785c-5afd-91f1-9de20f533193" -version = "0.7.0" - -[[ColorTypes]] -deps = ["FixedPointNumbers", "Random"] -git-tree-sha1 = "024fe24d83e4a5bf5fc80501a314ce0d1aa35597" -uuid = "3da002f7-5984-5a60-b8a6-cbb66c0b333f" -version = "0.11.0" - -[[Colors]] -deps = ["ColorTypes", "FixedPointNumbers", "Reexport"] -git-tree-sha1 = "417b0ed7b8b838aa6ca0a87aadf1bb9eb111ce40" -uuid = "5ae59095-9a9b-59fe-a467-6f913c188581" -version = "0.12.8" - -[[CommonRLInterface]] -deps = ["MacroTools"] -git-tree-sha1 = "21de56ebf28c262651e682f7fe614d44623dc087" -uuid = "d842c3ba-07a1-494f-bbec-f5741b0a3e98" -version = "0.3.1" - -[[CommonSubexpressions]] -deps = ["MacroTools", "Test"] -git-tree-sha1 = "7b8a93dba8af7e3b42fecabf646260105ac373f7" -uuid = "bbf7d656-a473-5ed7-a52c-81e309532950" -version = "0.3.0" - -[[Compat]] -deps = ["Base64", "Dates", "DelimitedFiles", "Distributed", "InteractiveUtils", "LibGit2", "Libdl", "LinearAlgebra", "Markdown", "Mmap", "Pkg", "Printf", "REPL", "Random", "SHA", "Serialization", "SharedArrays", "Sockets", "SparseArrays", "Statistics", "Test", "UUIDs", "Unicode"] -git-tree-sha1 = "31d0151f5716b655421d9d75b7fa74cc4e744df2" -uuid = "34da2185-b29b-5c13-b0c7-acf172513d20" -version = "3.39.0" - -[[CompilerSupportLibraries_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "e66e0078-7015-5450-92f7-15fbd957f2ae" - -[[ConstructionBase]] -deps = ["LinearAlgebra"] -git-tree-sha1 = "f74e9d5388b8620b4cee35d4c5a618dd4dc547f4" -uuid = "187b0558-2788-49d3-abe0-74a17ed4e7c9" -version = "1.3.0" - -[[Crayons]] -git-tree-sha1 = "3f71217b538d7aaee0b69ab47d9b7724ca8afa0d" -uuid = "a8cc5b0e-0ffa-5ad4-8c14-923d3ee1735f" -version = "4.0.4" - -[[DataAPI]] -git-tree-sha1 = "cc70b17275652eb47bc9e5f81635981f13cea5c8" -uuid = "9a962f9c-6df0-11e9-0e5d-c546b8b5ee8a" -version = "1.9.0" - -[[DataStructures]] -deps = ["Compat", "InteractiveUtils", "OrderedCollections"] -git-tree-sha1 = "7d9d316f04214f7efdbb6398d545446e246eff02" -uuid = "864edb3b-99cc-5e75-8d2d-829cb0a9cfe8" -version = "0.18.10" - -[[DataValueInterfaces]] -git-tree-sha1 = "bfc1187b79289637fa0ef6d4436ebdfe6905cbd6" -uuid = "e2d170a0-9d28-54be-80f0-106bbe20a464" -version = "1.0.0" - -[[Dates]] -deps = ["Printf"] -uuid = "ade2ca70-3891-5945-98fb-dc099432e06a" - -[[DelimitedFiles]] -deps = ["Mmap"] -uuid = "8bb1440f-4735-579b-a4ab-409b98df4dab" - -[[DiffResults]] -deps = ["StaticArrays"] -git-tree-sha1 = "c18e98cba888c6c25d1c3b048e4b3380ca956805" -uuid = "163ba53b-c6d8-5494-b064-1a9d43ac40c5" -version = "1.0.3" - -[[DiffRules]] -deps = ["NaNMath", "Random", "SpecialFunctions"] -git-tree-sha1 = "7220bc21c33e990c14f4a9a319b1d242ebc5b269" -uuid = "b552c78f-8df3-52c6-915a-8e097449b14b" -version = "1.3.1" - -[[Distributed]] -deps = ["Random", "Serialization", "Sockets"] -uuid = "8ba89e20-285c-5b6f-9357-94700520ee1b" - -[[Distributions]] -deps = ["ChainRulesCore", "FillArrays", "LinearAlgebra", "PDMats", "Printf", "QuadGK", "Random", "SparseArrays", "SpecialFunctions", "Statistics", "StatsBase", "StatsFuns"] -git-tree-sha1 = "ff7890c74e2eaffbc0b3741811e3816e64b6343d" -uuid = "31c24e10-a181-5473-b8eb-7969acd0382f" -version = "0.25.18" - -[[DocStringExtensions]] -deps = ["LibGit2"] -git-tree-sha1 = "a32185f5428d3986f47c2ab78b1f216d5e6cc96f" -uuid = "ffbed154-4ef7-542d-bbb7-c09d3a79fcae" -version = "0.8.5" - -[[Downloads]] -deps = ["ArgTools", "LibCURL", "NetworkOptions"] -uuid = "f43a241f-c20a-4ad4-852c-f6b1247861c6" - -[[ElasticArrays]] -deps = ["Adapt"] -git-tree-sha1 = "a0fcc1bb3c9ceaf07e1d0529c9806ce94be6adf9" -uuid = "fdbdab4c-e67f-52f5-8c3f-e7b388dad3d4" -version = "1.2.9" - -[[EllipsisNotation]] -deps = ["ArrayInterface"] -git-tree-sha1 = "8041575f021cba5a099a456b4163c9a08b566a02" -uuid = "da5c29d0-fa7d-589e-88eb-ea29b0a81949" -version = "1.1.0" - -[[ExprTools]] -git-tree-sha1 = "b7e3d17636b348f005f11040025ae8c6f645fe92" -uuid = "e2ba6199-217a-4e67-a87a-7c52f15ade04" -version = "0.1.6" - -[[FillArrays]] -deps = ["LinearAlgebra", "Random", "SparseArrays", "Statistics"] -git-tree-sha1 = "29890dfbc427afa59598b8cfcc10034719bd7744" -uuid = "1a297f60-69ca-5386-bcde-b61e274b549b" -version = "0.12.6" - -[[FixedPointNumbers]] -deps = ["Statistics"] -git-tree-sha1 = "335bfdceacc84c5cdf16aadc768aa5ddfc5383cc" -uuid = "53c48c17-4a7d-5ca2-90c5-79b7896eea93" -version = "0.8.4" - -[[Flux]] -deps = ["AbstractTrees", "Adapt", "ArrayInterface", "CUDA", "CodecZlib", "Colors", "DelimitedFiles", "Functors", "Juno", "LinearAlgebra", "MacroTools", "NNlib", "NNlibCUDA", "Pkg", "Printf", "Random", "Reexport", "SHA", "SparseArrays", "Statistics", "StatsBase", "Test", "ZipFile", "Zygote"] -git-tree-sha1 = "e4ade0790850bb16b5309945658fa4e7626226f1" -uuid = "587475ba-b771-5e3f-ad9e-33799f191a9c" -version = "0.12.7" - -[[ForwardDiff]] -deps = ["CommonSubexpressions", "DiffResults", "DiffRules", "LinearAlgebra", "NaNMath", "Printf", "Random", "SpecialFunctions", "StaticArrays"] -git-tree-sha1 = "c4203b60d37059462af370c4f3108fb5d155ff13" -uuid = "f6369f11-7733-5829-9624-2563aa707210" -version = "0.10.20" - -[[Functors]] -git-tree-sha1 = "e2727f02325451f6b24445cd83bfa9aaac19cbe7" -uuid = "d9f16b24-f501-4c13-a1f2-28368ffc5196" -version = "0.2.5" - -[[Future]] -deps = ["Random"] -uuid = "9fa8497b-333b-5362-9e8d-4d0656e87820" - -[[GPUArrays]] -deps = ["Adapt", "LinearAlgebra", "Printf", "Random", "Serialization", "Statistics"] -git-tree-sha1 = "7772508f17f1d482fe0df72cabc5b55bec06bbe0" -uuid = "0c68f7d7-f131-5f86-a1c3-88cf8149b2d7" -version = "8.1.2" - -[[GPUCompiler]] -deps = ["ExprTools", "InteractiveUtils", "LLVM", "Libdl", "Logging", "TimerOutputs", "UUIDs"] -git-tree-sha1 = "4ed2616d5e656c8716736b64da86755467f26cf5" -uuid = "61eb1bfa-7361-4325-ad38-22787b887f55" -version = "0.12.9" - -[[IRTools]] -deps = ["InteractiveUtils", "MacroTools", "Test"] -git-tree-sha1 = "95215cd0076a150ef46ff7928892bc341864c73c" -uuid = "7869d1d1-7146-5819-86e3-90919afe41df" -version = "0.4.3" - -[[IfElse]] -git-tree-sha1 = "28e837ff3e7a6c3cdb252ce49fb412c8eb3caeef" -uuid = "615f187c-cbe4-4ef1-ba3b-2fcf58d6d173" -version = "0.1.0" - -[[InteractiveUtils]] -deps = ["Markdown"] -uuid = "b77e0a4c-d291-57a0-90e8-8db25a27a240" - -[[IntervalSets]] -deps = ["Dates", "EllipsisNotation", "Statistics"] -git-tree-sha1 = "3cc368af3f110a767ac786560045dceddfc16758" -uuid = "8197267c-284f-5f27-9208-e0e47529a953" -version = "0.5.3" - -[[IrrationalConstants]] -git-tree-sha1 = "f76424439413893a832026ca355fe273e93bce94" -uuid = "92d709cd-6900-40b7-9082-c6be49f344b6" -version = "0.1.0" - -[[IteratorInterfaceExtensions]] -git-tree-sha1 = "a3f24677c21f5bbe9d2a714f95dcd58337fb2856" -uuid = "82899510-4779-5014-852e-03e436cf321d" -version = "1.0.0" - -[[JLLWrappers]] -deps = ["Preferences"] -git-tree-sha1 = "642a199af8b68253517b80bd3bfd17eb4e84df6e" -uuid = "692b3bcd-3c85-4b1f-b108-f13ce0eb3210" -version = "1.3.0" - -[[Juno]] -deps = ["Base64", "Logging", "Media", "Profile"] -git-tree-sha1 = "07cb43290a840908a771552911a6274bc6c072c7" -uuid = "e5e0dc1b-0480-54bc-9374-aad01c23163d" -version = "0.8.4" - -[[LLVM]] -deps = ["CEnum", "LLVMExtra_jll", "Libdl", "Printf", "Unicode"] -git-tree-sha1 = "46092047ca4edc10720ecab437c42283cd7c44f3" -uuid = "929cbde3-209d-540e-8aea-75f648917ca0" -version = "4.6.0" - -[[LLVMExtra_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "6a2af408fe809c4f1a54d2b3f188fdd3698549d6" -uuid = "dad2f222-ce93-54a1-a47d-0025e8a3acab" -version = "0.0.11+0" - -[[LazyArtifacts]] -deps = ["Artifacts", "Pkg"] -uuid = "4af54fe1-eca0-43a8-85a7-787d91b784e3" - -[[LibCURL]] -deps = ["LibCURL_jll", "MozillaCACerts_jll"] -uuid = "b27032c2-a3e7-50c8-80cd-2d36dbcbfd21" - -[[LibCURL_jll]] -deps = ["Artifacts", "LibSSH2_jll", "Libdl", "MbedTLS_jll", "Zlib_jll", "nghttp2_jll"] -uuid = "deac9b47-8bc7-5906-a0fe-35ac56dc84c0" - -[[LibGit2]] -deps = ["Base64", "NetworkOptions", "Printf", "SHA"] -uuid = "76f85450-5226-5b5a-8eaa-529ad045b433" - -[[LibSSH2_jll]] -deps = ["Artifacts", "Libdl", "MbedTLS_jll"] -uuid = "29816b5a-b9ab-546f-933c-edad1886dfa8" - -[[Libdl]] -uuid = "8f399da3-3557-5675-b5ff-fb832c97cbdb" - -[[LinearAlgebra]] -deps = ["Libdl"] -uuid = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e" - -[[LogExpFunctions]] -deps = ["ChainRulesCore", "DocStringExtensions", "IrrationalConstants", "LinearAlgebra"] -git-tree-sha1 = "34dc30f868e368f8a17b728a1238f3fcda43931a" -uuid = "2ab3a3ac-af41-5b50-aa03-7779005ae688" -version = "0.3.3" - -[[Logging]] -uuid = "56ddb016-857b-54e1-b83d-db4d58db5568" - -[[MacroTools]] -deps = ["Markdown", "Random"] -git-tree-sha1 = "5a5bc6bf062f0f95e62d0fe0a2d99699fed82dd9" -uuid = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09" -version = "0.5.8" - -[[Markdown]] -deps = ["Base64"] -uuid = "d6f4376e-aef5-505a-96c1-9c027394607a" - -[[MbedTLS_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "c8ffd9c3-330d-5841-b78e-0817d7145fa1" - -[[Media]] -deps = ["MacroTools", "Test"] -git-tree-sha1 = "75a54abd10709c01f1b86b84ec225d26e840ed58" -uuid = "e89f7d12-3494-54d1-8411-f7d8b9ae1f27" -version = "0.5.0" - -[[Missings]] -deps = ["DataAPI"] -git-tree-sha1 = "bf210ce90b6c9eed32d25dbcae1ebc565df2687f" -uuid = "e1d29d7a-bbdc-5cf2-9ac0-f12de2c33e28" -version = "1.0.2" - -[[Mmap]] -uuid = "a63ad114-7e13-5084-954f-fe012c677804" - -[[MozillaCACerts_jll]] -uuid = "14a3606d-f60d-562e-9121-12d972cd8159" - -[[NNlib]] -deps = ["Adapt", "ChainRulesCore", "Compat", "LinearAlgebra", "Pkg", "Requires", "Statistics"] -git-tree-sha1 = "5203a4532ad28c44f82c76634ad621d7c90abcbd" -uuid = "872c559c-99b0-510c-b3b7-b6c96a88d5cd" -version = "0.7.29" - -[[NNlibCUDA]] -deps = ["CUDA", "LinearAlgebra", "NNlib", "Random", "Statistics"] -git-tree-sha1 = "04490d5e7570c038b1cb0f5c3627597181cc15a9" -uuid = "a00861dc-f156-4864-bf3c-e6376f28a68d" -version = "0.1.9" - -[[NaNMath]] -git-tree-sha1 = "bfe47e760d60b82b66b61d2d44128b62e3a369fb" -uuid = "77ba4419-2d1f-58cd-9bb1-8ffee604a2e3" -version = "0.3.5" - -[[NetworkOptions]] -uuid = "ca575930-c2e3-43a9-ace4-1e988b2c1908" - -[[OpenLibm_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "05823500-19ac-5b8b-9628-191a04bc5112" - -[[OpenSpecFun_jll]] -deps = ["Artifacts", "CompilerSupportLibraries_jll", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "13652491f6856acfd2db29360e1bbcd4565d04f1" -uuid = "efe28fd5-8261-553b-a9e1-b2916fc3738e" -version = "0.5.5+0" - -[[OrderedCollections]] -git-tree-sha1 = "85f8e6578bf1f9ee0d11e7bb1b1456435479d47c" -uuid = "bac558e1-5e72-5ebc-8fee-abe8a469f55d" -version = "1.4.1" - -[[PDMats]] -deps = ["LinearAlgebra", "SparseArrays", "SuiteSparse"] -git-tree-sha1 = "4dd403333bcf0909341cfe57ec115152f937d7d8" -uuid = "90014a1f-27ba-587c-ab20-58faa44d9150" -version = "0.11.1" - -[[Pkg]] -deps = ["Artifacts", "Dates", "Downloads", "LibGit2", "Libdl", "Logging", "Markdown", "Printf", "REPL", "Random", "SHA", "Serialization", "TOML", "Tar", "UUIDs", "p7zip_jll"] -uuid = "44cfe95a-1eb2-52ea-b672-e2afdf69b78f" - -[[Preferences]] -deps = ["TOML"] -git-tree-sha1 = "00cfd92944ca9c760982747e9a1d0d5d86ab1e5a" -uuid = "21216c6a-2e73-6563-6e65-726566657250" -version = "1.2.2" - -[[Printf]] -deps = ["Unicode"] -uuid = "de0858da-6303-5e67-8744-51eddeeeb8d7" - -[[Profile]] -deps = ["Printf"] -uuid = "9abbd945-dff8-562f-b5e8-e1ebf5ef1b79" - -[[ProgressMeter]] -deps = ["Distributed", "Printf"] -git-tree-sha1 = "afadeba63d90ff223a6a48d2009434ecee2ec9e8" -uuid = "92933f4c-e287-5a05-a399-4b506db050ca" -version = "1.7.1" - -[[QuadGK]] -deps = ["DataStructures", "LinearAlgebra"] -git-tree-sha1 = "78aadffb3efd2155af139781b8a8df1ef279ea39" -uuid = "1fd47b50-473d-5c70-9696-f719f8f3bcdc" -version = "2.4.2" - -[[REPL]] -deps = ["InteractiveUtils", "Markdown", "Sockets", "Unicode"] -uuid = "3fa0cd96-eef1-5676-8a61-b3b8758bbffb" - -[[Random]] -deps = ["Serialization"] -uuid = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c" - -[[Random123]] -deps = ["Libdl", "Random", "RandomNumbers"] -git-tree-sha1 = "0e8b146557ad1c6deb1367655e052276690e71a3" -uuid = "74087812-796a-5b5d-8853-05524746bad3" -version = "1.4.2" - -[[RandomNumbers]] -deps = ["Random", "Requires"] -git-tree-sha1 = "043da614cc7e95c703498a491e2c21f58a2b8111" -uuid = "e6cf234a-135c-5ec9-84dd-332b85af5143" -version = "1.5.3" - -[[Reexport]] -git-tree-sha1 = "45e428421666073eab6f2da5c9d310d99bb12f9b" -uuid = "189a3867-3050-52da-a836-e630ba90ab69" -version = "1.2.2" - -[[ReinforcementLearningBase]] -deps = ["AbstractTrees", "CommonRLInterface", "Markdown", "Random", "Test"] -path = "../ReinforcementLearningBase" -uuid = "e575027e-6cd6-5018-9292-cdc6200d2b44" -version = "0.9.7" - -[[ReinforcementLearningCore]] -deps = ["AbstractTrees", "Adapt", "ArrayInterface", "CUDA", "CircularArrayBuffers", "Compat", "Dates", "Distributions", "ElasticArrays", "FillArrays", "Flux", "Functors", "GPUArrays", "LinearAlgebra", "MacroTools", "Markdown", "ProgressMeter", "Random", "ReinforcementLearningBase", "Setfield", "Statistics", "StatsBase", "UnicodePlots", "Zygote"] -path = "../ReinforcementLearningCore" -uuid = "de1b191a-4ae0-4afa-a27b-92d07f46b2d6" -version = "0.8.4" - -[[Requires]] -deps = ["UUIDs"] -git-tree-sha1 = "4036a3bd08ac7e968e27c203d45f5fff15020621" -uuid = "ae029012-a4dd-5104-9daa-d747884805df" -version = "1.1.3" - -[[Rmath]] -deps = ["Random", "Rmath_jll"] -git-tree-sha1 = "bf3188feca147ce108c76ad82c2792c57abe7b1f" -uuid = "79098fc4-a85e-5d69-aa6a-4863f24498fa" -version = "0.7.0" - -[[Rmath_jll]] -deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"] -git-tree-sha1 = "68db32dff12bb6127bac73c209881191bf0efbb7" -uuid = "f50d1b31-88e8-58de-be2c-1cc44531875f" -version = "0.3.0+0" - -[[SHA]] -uuid = "ea8e919c-243c-51af-8825-aaa63cd721ce" - -[[Serialization]] -uuid = "9e88b42a-f829-5b0c-bbe9-9e923198166b" - -[[Setfield]] -deps = ["ConstructionBase", "Future", "MacroTools", "Requires"] -git-tree-sha1 = "def0718ddbabeb5476e51e5a43609bee889f285d" -uuid = "efcf1570-3423-57d1-acb7-fd33fddbac46" -version = "0.8.0" - -[[SharedArrays]] -deps = ["Distributed", "Mmap", "Random", "Serialization"] -uuid = "1a1011a3-84de-559e-8e89-a11a2f7dc383" - -[[Sockets]] -uuid = "6462fe0b-24de-5631-8697-dd941f90decc" - -[[SortingAlgorithms]] -deps = ["DataStructures"] -git-tree-sha1 = "b3363d7460f7d098ca0912c69b082f75625d7508" -uuid = "a2af1166-a08f-5f64-846c-94a0d3cef48c" -version = "1.0.1" - -[[SparseArrays]] -deps = ["LinearAlgebra", "Random"] -uuid = "2f01184e-e22b-5df5-ae63-d93ebab69eaf" - -[[SpecialFunctions]] -deps = ["ChainRulesCore", "IrrationalConstants", "LogExpFunctions", "OpenLibm_jll", "OpenSpecFun_jll"] -git-tree-sha1 = "793793f1df98e3d7d554b65a107e9c9a6399a6ed" -uuid = "276daf66-3868-5448-9aa4-cd146d93841b" -version = "1.7.0" - -[[Static]] -deps = ["IfElse"] -git-tree-sha1 = "a8f30abc7c64a39d389680b74e749cf33f872a70" -uuid = "aedffcd0-7271-4cad-89d0-dc628f76c6d3" -version = "0.3.3" - -[[StaticArrays]] -deps = ["LinearAlgebra", "Random", "Statistics"] -git-tree-sha1 = "3c76dde64d03699e074ac02eb2e8ba8254d428da" -uuid = "90137ffa-7385-5640-81b9-e52037218182" -version = "1.2.13" - -[[Statistics]] -deps = ["LinearAlgebra", "SparseArrays"] -uuid = "10745b16-79ce-11e8-11f9-7d13ad32a3b2" - -[[StatsAPI]] -git-tree-sha1 = "1958272568dc176a1d881acb797beb909c785510" -uuid = "82ae8749-77ed-4fe6-ae5f-f523153014b0" -version = "1.0.0" - -[[StatsBase]] -deps = ["DataAPI", "DataStructures", "LinearAlgebra", "Missings", "Printf", "Random", "SortingAlgorithms", "SparseArrays", "Statistics", "StatsAPI"] -git-tree-sha1 = "8cbbc098554648c84f79a463c9ff0fd277144b6c" -uuid = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91" -version = "0.33.10" - -[[StatsFuns]] -deps = ["ChainRulesCore", "IrrationalConstants", "LogExpFunctions", "Reexport", "Rmath", "SpecialFunctions"] -git-tree-sha1 = "95072ef1a22b057b1e80f73c2a89ad238ae4cfff" -uuid = "4c63d2b9-4356-54db-8cca-17b64c39e42c" -version = "0.9.12" - -[[StructArrays]] -deps = ["Adapt", "DataAPI", "StaticArrays", "Tables"] -git-tree-sha1 = "2ce41e0d042c60ecd131e9fb7154a3bfadbf50d3" -uuid = "09ab397b-f2b6-538f-b94a-2f83cf4a842a" -version = "0.6.3" - -[[SuiteSparse]] -deps = ["Libdl", "LinearAlgebra", "Serialization", "SparseArrays"] -uuid = "4607b0f0-06f3-5cda-b6b1-a6196a1729e9" - -[[TOML]] -deps = ["Dates"] -uuid = "fa267f1f-6049-4f14-aa54-33bafae1ed76" - -[[TableTraits]] -deps = ["IteratorInterfaceExtensions"] -git-tree-sha1 = "c06b2f539df1c6efa794486abfb6ed2022561a39" -uuid = "3783bdb8-4a98-5b6b-af9a-565f29a5fe9c" -version = "1.0.1" - -[[Tables]] -deps = ["DataAPI", "DataValueInterfaces", "IteratorInterfaceExtensions", "LinearAlgebra", "TableTraits", "Test"] -git-tree-sha1 = "fed34d0e71b91734bf0a7e10eb1bb05296ddbcd0" -uuid = "bd369af6-aec1-5ad0-b16a-f7cc5008161c" -version = "1.6.0" - -[[Tar]] -deps = ["ArgTools", "SHA"] -uuid = "a4e569a6-e804-4fa4-b0f3-eef7a1d5b13e" - -[[Test]] -deps = ["InteractiveUtils", "Logging", "Random", "Serialization"] -uuid = "8dfed614-e22c-5e08-85e1-65c5234f0b40" - -[[TimerOutputs]] -deps = ["ExprTools", "Printf"] -git-tree-sha1 = "7cb456f358e8f9d102a8b25e8dfedf58fa5689bc" -uuid = "a759f4b9-e2f1-59dc-863e-4aeb61b1ea8f" -version = "0.5.13" - -[[TranscodingStreams]] -deps = ["Random", "Test"] -git-tree-sha1 = "216b95ea110b5972db65aa90f88d8d89dcb8851c" -uuid = "3bb67fe8-82b1-5028-8e26-92a6c54297fa" -version = "0.9.6" - -[[UUIDs]] -deps = ["Random", "SHA"] -uuid = "cf7118a7-6976-5b1a-9a39-7adc72f591a4" - -[[Unicode]] -uuid = "4ec0a83e-493e-50e2-b9ac-8f72acf5a8f5" - -[[UnicodePlots]] -deps = ["Crayons", "Dates", "SparseArrays", "StatsBase"] -git-tree-sha1 = "f1d09f14722f5f3cef029bcb031be91a92613ae9" -uuid = "b8865327-cd53-5732-bb35-84acbb429228" -version = "2.4.6" - -[[ZipFile]] -deps = ["Libdl", "Printf", "Zlib_jll"] -git-tree-sha1 = "3593e69e469d2111389a9bd06bac1f3d730ac6de" -uuid = "a5390f91-8eb1-5f08-bee0-b1d1ffed6cea" -version = "0.9.4" - -[[Zlib_jll]] -deps = ["Libdl"] -uuid = "83775a58-1f1d-513f-b197-d71354ab007a" - -[[Zygote]] -deps = ["AbstractFFTs", "ChainRules", "ChainRulesCore", "DiffRules", "Distributed", "FillArrays", "ForwardDiff", "IRTools", "InteractiveUtils", "LinearAlgebra", "MacroTools", "NaNMath", "Random", "Requires", "SpecialFunctions", "Statistics", "ZygoteRules"] -git-tree-sha1 = "78bdfa26eb61600038461229bcd7a5b6f6bb32e4" -uuid = "e88e6eb3-aa80-5325-afca-941959d7151f" -version = "0.6.26" - -[[ZygoteRules]] -deps = ["MacroTools"] -git-tree-sha1 = "8c1a8e4dfacb1fd631745552c8db35d0deb09ea0" -uuid = "700de1a5-db45-46bc-99cf-38207098b444" -version = "0.2.2" - -[[nghttp2_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "8e850ede-7688-5339-a07c-302acd2aaf8d" - -[[p7zip_jll]] -deps = ["Artifacts", "Libdl"] -uuid = "3f19e933-33d8-53b3-aaab-bd5110c3b7a0" diff --git a/src/ReinforcementLearningZoo/Project.toml b/src/ReinforcementLearningZoo/Project.toml index 9e39e4d93..79ecedea1 100644 --- a/src/ReinforcementLearningZoo/Project.toml +++ b/src/ReinforcementLearningZoo/Project.toml @@ -1,50 +1,23 @@ name = "ReinforcementLearningZoo" uuid = "d607f57d-ee1e-4ba7-bcf2-7734c1e31854" -version = "0.5.11" +version = "0.6.0-dev" [deps] -AbstractTrees = "1520ce14-60c1-5f80-bbc7-55ef81b5835c" -CUDA = "052768ef-5323-5732-b1bb-66c8b64840ba" -CircularArrayBuffers = "9de3a189-e0c0-4e15-ba3b-b14b9fb0aec1" -DataStructures = "864edb3b-99cc-5e75-8d2d-829cb0a9cfe8" -Dates = "ade2ca70-3891-5945-98fb-dc099432e06a" -Distributions = "31c24e10-a181-5473-b8eb-7969acd0382f" Flux = "587475ba-b771-5e3f-ad9e-33799f191a9c" -IntervalSets = "8197267c-284f-5f27-9208-e0e47529a953" -LinearAlgebra = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e" -Logging = "56ddb016-857b-54e1-b83d-db4d58db5568" -MacroTools = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09" +Functors = "d9f16b24-f501-4c13-a1f2-28368ffc5196" Random = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c" ReinforcementLearningBase = "e575027e-6cd6-5018-9292-cdc6200d2b44" ReinforcementLearningCore = "de1b191a-4ae0-4afa-a27b-92d07f46b2d6" Setfield = "efcf1570-3423-57d1-acb7-fd33fddbac46" -Statistics = "10745b16-79ce-11e8-11f9-7d13ad32a3b2" -StatsBase = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91" -StructArrays = "09ab397b-f2b6-538f-b94a-2f83cf4a842a" Zygote = "e88e6eb3-aa80-5325-afca-941959d7151f" [compat] -AbstractTrees = "0.3" -CUDA = "3" -CircularArrayBuffers = "0.1" -DataStructures = "0.18" -Distributions = "0.24, 0.25" -Flux = "0.12" -IntervalSets = "0.5" -MacroTools = "0.5" -ReinforcementLearningBase = "0.9" -ReinforcementLearningCore = "0.8.2" -Setfield = "0.6, 0.7, 0.8" -StatsBase = "0.32, 0.33" -StructArrays = "0.4, 0.5, 0.6" -Zygote = "0.5, 0.6" +ReinforcementLearningBase = "0.10" +ReinforcementLearningCore = "0.9" julia = "1.6" [extras] -OpenSpiel = "ceb70bd2-fe3f-44f0-b81f-41608acaf2f2" -ReinforcementLearningEnvironments = "25e41dd2-4622-11e9-1641-f1adca772921" -StableRNGs = "860ef19b-820b-49d6-a774-d7a799459cd3" Test = "8dfed614-e22c-5e08-85e1-65c5234f0b40" [targets] -test = ["Test", "OpenSpiel", "ReinforcementLearningEnvironments", "StableRNGs"] +test = ["Test"] diff --git a/src/ReinforcementLearningZoo/src/ReinforcementLearningZoo.jl b/src/ReinforcementLearningZoo/src/ReinforcementLearningZoo.jl index 363d2248d..2154b0423 100644 --- a/src/ReinforcementLearningZoo/src/ReinforcementLearningZoo.jl +++ b/src/ReinforcementLearningZoo/src/ReinforcementLearningZoo.jl @@ -1,35 +1,11 @@ module ReinforcementLearningZoo -const RLZoo = ReinforcementLearningZoo -export RLZoo - -export GaussianNetwork - -using CircularArrayBuffers using ReinforcementLearningBase using ReinforcementLearningCore -using Setfield: @set -using Logging -using Flux.Losses -using Dates -using IntervalSets -using Random -using Random: shuffle -using CUDA -using Zygote -using Zygote: ignore, @ignore -using Flux -using Flux: onehot, normalise -using StatsBase -using StatsBase: sample, Weights, mean -using LinearAlgebra: dot -using MacroTools -using Distributions: Categorical, Normal, logpdf -using StructArrays +const RLZoo = ReinforcementLearningZoo +export RLZoo -include("patch.jl") -include("utils/utils.jl") include("algorithms/algorithms.jl") end # module diff --git a/src/ReinforcementLearningZoo/src/algorithms/algorithms.jl b/src/ReinforcementLearningZoo/src/algorithms/algorithms.jl index 40bd97633..df2ddfe64 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/algorithms.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/algorithms.jl @@ -1,8 +1,8 @@ -include("tabular/tabular.jl") +# include("tabular/tabular.jl") include("dqns/dqns.jl") -include("policy_gradient/policy_gradient.jl") -include("searching/searching.jl") -include("cfr/cfr.jl") -include("offline_rl/offline_rl.jl") -include("nfsp/abstract_nfsp.jl") -include("exploitability_descent/exploitability_descent.jl") +# include("policy_gradient/policy_gradient.jl") +# include("searching/searching.jl") +# include("cfr/cfr.jl") +# include("offline_rl/offline_rl.jl") +# include("nfsp/abstract_nfsp.jl") +# include("exploitability_descent/exploitability_descent.jl") diff --git a/src/ReinforcementLearningZoo/src/algorithms/dqns/basic_dqn.jl b/src/ReinforcementLearningZoo/src/algorithms/dqns/basic_dqn.jl index a8c4d49a7..0d0d5bc5f 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/dqns/basic_dqn.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/dqns/basic_dqn.jl @@ -1,72 +1,45 @@ export BasicDQNLearner +using Flux: gradient, params +using Zygote: ignore +using Setfield: @set + +import Functors + """ BasicDQNLearner(;kwargs...) See paper: [Playing Atari with Deep Reinforcement Learning](https://www.cs.toronto.edu/~vmnih/docs/dqn.pdf) -This is the very basic implementation of DQN. Compared to the traditional Q learning, the only difference is that, -in the updating step it uses a batch of transitions sampled from an experience buffer instead of current transition. -And the `approximator` is usually a [`NeuralNetworkApproximator`](@ref). -You can start from this implementation to understand how everything is organized and how to write your own customized algorithm. +This is the very basic implementation of DQN. Compared to the traditional Q +learning, the only difference is that, in the optimising step it uses a batch of +transitions sampled from an experience buffer instead of current transition. And +a neural network is used to estimate the Q-value. You can start from this +implementation to understand how everything is organized and how to write your +own customized algorithm. -# Keywords +# Keyword Arguments -- `approximator`::[`AbstractApproximator`](@ref): used to get Q-values of a state. -- `loss_func`: the loss function to use. +- `approximator`::[`Approximator`](@ref): used to get Q-values of a state. +- `loss_func=huber_loss`: the loss function to use. - `γ::Float32=0.99f0`: discount rate. -- `batch_size::Int=32` -- `min_replay_history::Int=32`: number of transitions that should be experienced before updating the `approximator`. -- `rng=Random.GLOBAL_RNG` """ -mutable struct BasicDQNLearner{Q,F,R} <: AbstractLearner +Base.@kwdef mutable struct BasicDQNLearner{Q} <: AbstractLearner approximator::Q - loss_func::F - γ::Float32 - sampler::BatchSampler - min_replay_history::Int - rng::R + loss_func::Any = huber_loss + γ::Float32 = 0.99f0 # for debugging - loss::Float32 -end - -Flux.functor(x::BasicDQNLearner) = (Q = x.approximator,), y -> begin - x = @set x.approximator = y.Q - x + loss::Float32 = 0.0f0 end -(learner::BasicDQNLearner)(env) = - env |> - state |> - x -> send_to_device(device(learner), x) |> learner.approximator |> send_to_host +Functors.functor(x::BasicDQNLearner) = (Q=x.approximator,), y -> @set x.approximator = y.Q -function BasicDQNLearner(; - approximator::Q, - loss_func::F = huber_loss, - γ = 0.99f0, - batch_size = 32, - min_replay_history = 32, - rng = Random.GLOBAL_RNG, -) where {Q,F} - BasicDQNLearner{Q,F,typeof(rng)}( - approximator, - loss_func, - γ, - BatchSampler{SARTS}(batch_size), - min_replay_history, - rng, - 0.0, - ) -end - -function RLBase.update!(learner::BasicDQNLearner, traj::AbstractTrajectory) - if length(traj) >= learner.min_replay_history - inds, batch = sample(learner.rng, traj, learner.sampler) - update!(learner, batch) - end -end +(L::BasicDQNLearner)(s::AbstractArray) = L.approximator(s) -function RLBase.update!(learner::BasicDQNLearner, batch::NamedTuple{SARTS}) +function RLCore.optimise!( + learner::BasicDQNLearner, + batch::NamedTuple{(:state, :action, :reward, :terminal, :next_state)}, +) Q = learner.approximator γ = learner.γ @@ -77,7 +50,7 @@ function RLBase.update!(learner::BasicDQNLearner, batch::NamedTuple{SARTS}) gs = gradient(params(Q)) do q = Q(s)[a] - q′ = vec(maximum(Q(s′); dims = 1)) + q′ = vec(maximum(Q(s′); dims=1)) G = @. r + γ * (1 - t) * q′ loss = loss_func(G, q) ignore() do @@ -86,5 +59,5 @@ function RLBase.update!(learner::BasicDQNLearner, batch::NamedTuple{SARTS}) loss end - update!(Q, gs) + optimise!(Q, gs) end diff --git a/src/ReinforcementLearningZoo/src/algorithms/dqns/common.jl b/src/ReinforcementLearningZoo/src/algorithms/dqns/common.jl index ddd2c6ace..4edb625bd 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/dqns/common.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/dqns/common.jl @@ -4,7 +4,10 @@ const PERLearners = Union{PrioritizedDQNLearner,RainbowLearner,IQNLearner} -function RLBase.update!(learner::Union{DQNLearner,QRDQNLearner,REMDQNLearner,PERLearners}, t::AbstractTrajectory) +function RLBase.update!( + learner::Union{DQNLearner,QRDQNLearner,REMDQNLearner,PERLearners}, + t::Any, +) length(t[:terminal]) - learner.sampler.n <= learner.min_replay_history && return learner.update_step += 1 diff --git a/src/ReinforcementLearningZoo/src/algorithms/dqns/dqn.jl b/src/ReinforcementLearningZoo/src/algorithms/dqns/dqn.jl index b2ebab93c..a8ee11a34 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/dqns/dqn.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/dqns/dqn.jl @@ -1,11 +1,6 @@ export DQNLearner -mutable struct DQNLearner{ - Tq<:AbstractApproximator, - Tt<:AbstractApproximator, - Tf, - R<:AbstractRNG, -} <: AbstractLearner +mutable struct DQNLearner{Tq,Tt,Tf,R<:AbstractRNG} <: Any approximator::Tq target_approximator::Tt loss_func::Tf @@ -55,7 +50,7 @@ function DQNLearner(; traces = SARTS, update_step = 0, rng = Random.GLOBAL_RNG, - is_enable_double_DQN::Bool = true + is_enable_double_DQN::Bool = true, ) where {Tq,Tt,Tf} copyto!(approximator, target_approximator) sampler = NStepBatchSampler{traces}(; @@ -75,12 +70,12 @@ function DQNLearner(; sampler, rng, 0.0f0, - is_enable_double_DQN + is_enable_double_DQN, ) end -Flux.functor(x::DQNLearner) = (Q = x.approximator, Qₜ = x.target_approximator), +Functors.functor(x::DQNLearner) = (Q = x.approximator, Qₜ = x.target_approximator), y -> begin x = @set x.approximator = y.Q x = @set x.target_approximator = y.Qₜ @@ -117,14 +112,14 @@ function RLBase.update!(learner::DQNLearner, batch::NamedTuple) else q_values = Qₜ(s′) end - + if haskey(batch, :next_legal_actions_mask) l′ = send_to_device(D, batch[:next_legal_actions_mask]) q_values .+= ifelse.(l′, 0.0f0, typemin(Float32)) end if is_enable_double_DQN - selected_actions = dropdims(argmax(q_values, dims=1), dims=1) + selected_actions = dropdims(argmax(q_values, dims = 1), dims = 1) q′ = Qₜ(s′)[selected_actions] else q′ = dropdims(maximum(q_values; dims = 1), dims = 1) diff --git a/src/ReinforcementLearningZoo/src/algorithms/dqns/dqns.jl b/src/ReinforcementLearningZoo/src/algorithms/dqns/dqns.jl index 4ec47c5ba..a1ad5e9ef 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/dqns/dqns.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/dqns/dqns.jl @@ -1,8 +1,8 @@ include("basic_dqn.jl") -include("dqn.jl") -include("prioritized_dqn.jl") -include("qr_dqn.jl") -include("rem_dqn.jl") -include("rainbow.jl") -include("iqn.jl") -include("common.jl") \ No newline at end of file +# include("dqn.jl") +# include("prioritized_dqn.jl") +# include("qr_dqn.jl") +# include("rem_dqn.jl") +# include("rainbow.jl") +# include("iqn.jl") +# include("common.jl") \ No newline at end of file diff --git a/src/ReinforcementLearningZoo/src/algorithms/dqns/iqn.jl b/src/ReinforcementLearningZoo/src/algorithms/dqns/iqn.jl index 54606c278..653c47f46 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/dqns/iqn.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/dqns/iqn.jl @@ -58,7 +58,7 @@ See [paper](https://arxiv.org/abs/1806.06923) - `rng = Random.GLOBAL_RNG`, - `device_seed = nothing`, """ -mutable struct IQNLearner{A,T,R,D} <: AbstractLearner +mutable struct IQNLearner{A,T,R,D} <: Any approximator::A target_approximator::T sampler::NStepBatchSampler @@ -78,7 +78,7 @@ mutable struct IQNLearner{A,T,R,D} <: AbstractLearner loss::Float32 end -Flux.functor(x::IQNLearner) = +Functors.functor(x::IQNLearner) = (Z = x.approximator, Zₜ = x.target_approximator, device_rng = x.device_rng), y -> begin x = @set x.approximator = y.Z @@ -195,7 +195,7 @@ function RLBase.update!(learner::IQNLearner, batch::NamedTuple) is_use_PER = haskey(batch, :priority) # is use Prioritized Experience Replay if is_use_PER updated_priorities = Vector{Float32}(undef, batch_size) - weights = 1.0f0 ./ ((batch.priority .+ 1f-10) .^ β) + weights = 1.0f0 ./ ((batch.priority .+ 1.0f-10) .^ β) weights ./= maximum(weights) weights = send_to_device(D, weights) end @@ -224,7 +224,7 @@ function RLBase.update!(learner::IQNLearner, batch::NamedTuple) # @assert all(loss_per_element .>= 0) is_use_PER && ( updated_priorities .= - send_to_host(vec((loss_per_element .+ 1f-10) .^ β)) + send_to_host(vec((loss_per_element .+ 1.0f-10) .^ β)) ) learner.loss = loss end diff --git a/src/ReinforcementLearningZoo/src/algorithms/dqns/prioritized_dqn.jl b/src/ReinforcementLearningZoo/src/algorithms/dqns/prioritized_dqn.jl index f77c89bb8..d68b11220 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/dqns/prioritized_dqn.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/dqns/prioritized_dqn.jl @@ -24,12 +24,7 @@ And also https://danieltakeshi.github.io/2019/07/14/per/ !!! note Our implementation is slightly different from the original paper. But it should be aligned with the version in [dopamine](https://github.com/google/dopamine/blob/90527f4eaad4c574b92df556c02dea45853ffd2e/dopamine/jax/agents/rainbow/rainbow_agent.py#L26-L30). """ -mutable struct PrioritizedDQNLearner{ - Tq<:AbstractApproximator, - Tt<:AbstractApproximator, - Tf, - R<:AbstractRNG, -} <: AbstractLearner +mutable struct PrioritizedDQNLearner{Tq,Tt,Tf,R<:AbstractRNG} <: Any approximator::Tq target_approximator::Tt loss_func::Tf @@ -86,12 +81,13 @@ function PrioritizedDQNLearner(; end -Flux.functor(x::PrioritizedDQNLearner) = (Q = x.approximator, Qₜ = x.target_approximator), -y -> begin - x = @set x.approximator = y.Q - x = @set x.target_approximator = y.Qₜ - x -end +Functors.functor(x::PrioritizedDQNLearner) = + (Q = x.approximator, Qₜ = x.target_approximator), + y -> begin + x = @set x.approximator = y.Q + x = @set x.target_approximator = y.Qₜ + x + end """ @@ -125,7 +121,7 @@ function RLBase.update!(learner::PrioritizedDQNLearner, batch::NamedTuple) a = CartesianIndex.(a, 1:batch_size) updated_priorities = Vector{Float32}(undef, batch_size) - w = 1.0f0 ./ ((batch.priority .+ 1f-10) .^ β) + w = 1.0f0 ./ ((batch.priority .+ 1.0f-10) .^ β) w ./= maximum(w) w = send_to_device(D, w) @@ -143,7 +139,7 @@ function RLBase.update!(learner::PrioritizedDQNLearner, batch::NamedTuple) batch_losses = loss_func(G, q) loss = dot(vec(w), vec(batch_losses)) * 1 // batch_size ignore() do - updated_priorities .= send_to_host(vec((batch_losses .+ 1f-10) .^ β)) + updated_priorities .= send_to_host(vec((batch_losses .+ 1.0f-10) .^ β)) learner.loss = loss end loss diff --git a/src/ReinforcementLearningZoo/src/algorithms/dqns/qr_dqn.jl b/src/ReinforcementLearningZoo/src/algorithms/dqns/qr_dqn.jl index c34ffcb08..bbc352fd2 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/dqns/qr_dqn.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/dqns/qr_dqn.jl @@ -1,6 +1,6 @@ export QRDQNLearner, quantile_huber_loss -function quantile_huber_loss(ŷ, y; κ=1.0f0) +function quantile_huber_loss(ŷ, y; κ = 1.0f0) N, B = size(y) Δ = reshape(y, N, 1, B) .- reshape(ŷ, 1, N, B) abs_error = abs.(Δ) @@ -9,13 +9,13 @@ function quantile_huber_loss(ŷ, y; κ=1.0f0) huber_loss = 0.5f0 .* quadratic .* quadratic .+ κ .* linear cum_prob = Zygote.ignore() do - send_to_device(device(y), range(0.5f0 / N; length=N, step=1.0f0 / N)) + send_to_device(device(y), range(0.5f0 / N; length = N, step = 1.0f0 / N)) end loss = Zygote.dropgrad(abs.(cum_prob .- (Δ .< 0))) .* huber_loss - mean(sum(loss;dims=1)) + mean(sum(loss; dims = 1)) end -mutable struct QRDQNLearner{Tq <: AbstractApproximator,Tt <: AbstractApproximator,Tf,R} <: AbstractLearner +mutable struct QRDQNLearner{Tq<:AbstractApproximator,Tt<:AbstractApproximator,Tf,R} <: Any approximator::Tq target_approximator::Tt min_replay_history::Int @@ -53,25 +53,25 @@ See paper: [Distributional Reinforcement Learning with Quantile Regression](http function QRDQNLearner(; approximator, target_approximator, - stack_size::Union{Int,Nothing}=nothing, - γ::Float32=0.99f0, - batch_size::Int=32, - update_horizon::Int=1, - min_replay_history::Int=32, - update_freq::Int=1, - n_quantile::Int=1, - target_update_freq::Int=100, - traces=SARTS, - update_step=0, - loss_func=quantile_huber_loss, - rng=Random.GLOBAL_RNG + stack_size::Union{Int,Nothing} = nothing, + γ::Float32 = 0.99f0, + batch_size::Int = 32, + update_horizon::Int = 1, + min_replay_history::Int = 32, + update_freq::Int = 1, + n_quantile::Int = 1, + target_update_freq::Int = 100, + traces = SARTS, + update_step = 0, + loss_func = quantile_huber_loss, + rng = Random.GLOBAL_RNG, ) copyto!(approximator, target_approximator) sampler = NStepBatchSampler{traces}(; - γ=γ, - n=update_horizon, - stack_size=stack_size, - batch_size=batch_size, + γ = γ, + n = update_horizon, + stack_size = stack_size, + batch_size = batch_size, ) N = n_quantile @@ -91,7 +91,7 @@ function QRDQNLearner(; ) end -Flux.functor(x::QRDQNLearner) = (Q = x.approximator, Qₜ = x.target_approximator), +Functors.functor(x::QRDQNLearner) = (Q = x.approximator, Qₜ = x.target_approximator), y -> begin x = @set x.approximator = y.Q x = @set x.target_approximator = y.Qₜ @@ -102,7 +102,7 @@ function (learner::QRDQNLearner)(env) s = send_to_device(device(learner.approximator), state(env)) s = Flux.unsqueeze(s, ndims(s) + 1) q = reshape(learner.approximator(s), learner.n_quantile, :) - vec(mean(q, dims=1)) |> send_to_host + vec(mean(q, dims = 1)) |> send_to_host end function RLBase.update!(learner::QRDQNLearner, batch::NamedTuple) @@ -119,10 +119,12 @@ function RLBase.update!(learner::QRDQNLearner, batch::NamedTuple) a = CartesianIndex.(a, 1:batch_size) target_quantiles = reshape(Qₜ(s′), N, :, batch_size) - qₜ = dropdims(mean(target_quantiles; dims=1); dims=1) - aₜ = dropdims(argmax(qₜ, dims=1); dims=1) + qₜ = dropdims(mean(target_quantiles; dims = 1); dims = 1) + aₜ = dropdims(argmax(qₜ, dims = 1); dims = 1) @views target_quantile_aₜ = target_quantiles[:, aₜ] - y = reshape(r, 1, batch_size) .+ γ .* reshape(1 .- t, 1, batch_size) .* target_quantile_aₜ + y = + reshape(r, 1, batch_size) .+ + γ .* reshape(1 .- t, 1, batch_size) .* target_quantile_aₜ gs = gradient(params(Q)) do q = reshape(Q(s), N, :, batch_size) diff --git a/src/ReinforcementLearningZoo/src/algorithms/dqns/rainbow.jl b/src/ReinforcementLearningZoo/src/algorithms/dqns/rainbow.jl index f2068ac3d..c7eff4a3f 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/dqns/rainbow.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/dqns/rainbow.jl @@ -25,13 +25,7 @@ See paper: [Rainbow: Combining Improvements in Deep Reinforcement Learning](http - `stack_size::Union{Int, Nothing}=4`: use the recent `stack_size` frames to form a stacked state. - `rng = Random.GLOBAL_RNG` """ -mutable struct RainbowLearner{ - Tq<:AbstractApproximator, - Tt<:AbstractApproximator, - Tf, - Ts, - R<:AbstractRNG, -} <: AbstractLearner +mutable struct RainbowLearner{Tq,Tt,Tf,Ts,R<:AbstractRNG} <: Any approximator::Tq target_approximator::Tt loss_func::Tf @@ -52,7 +46,7 @@ mutable struct RainbowLearner{ loss::Float32 end -Flux.functor(x::RainbowLearner) = +Functors.functor(x::RainbowLearner) = (Q = x.approximator, Qₜ = x.target_approximator, S = x.support), y -> begin x = @set x.approximator = y.Q @@ -168,7 +162,7 @@ function RLBase.update!(learner::RainbowLearner, batch::NamedTuple) is_use_PER = haskey(batch, :priority) # is use Prioritized Experience Replay if is_use_PER updated_priorities = Vector{Float32}(undef, batch_size) - weights = 1.0f0 ./ ((batch.priority .+ 1f-10) .^ β) + weights = 1.0f0 ./ ((batch.priority .+ 1.0f-10) .^ β) weights ./= maximum(weights) weights = send_to_device(D, weights) end @@ -183,7 +177,7 @@ function RLBase.update!(learner::RainbowLearner, batch::NamedTuple) mean(batch_losses) ignore() do if is_use_PER - updated_priorities .= send_to_host(vec((batch_losses .+ 1f-10) .^ β)) + updated_priorities .= send_to_host(vec((batch_losses .+ 1.0f-10) .^ β)) end learner.loss = loss end diff --git a/src/ReinforcementLearningZoo/src/algorithms/dqns/rem_dqn.jl b/src/ReinforcementLearningZoo/src/algorithms/dqns/rem_dqn.jl index 182ce253f..42d9e61e7 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/dqns/rem_dqn.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/dqns/rem_dqn.jl @@ -1,11 +1,6 @@ export REMDQNLearner -mutable struct REMDQNLearner{ - Tq<:AbstractApproximator, - Tt<:AbstractApproximator, - Tf, - R<:AbstractRNG, -} <: AbstractLearner +mutable struct REMDQNLearner{Tq,Tt,Tf,R<:AbstractRNG} <: Any approximator::Tq target_approximator::Tt loss_func::Tf @@ -83,7 +78,7 @@ function REMDQNLearner(; ) end -Flux.functor(x::REMDQNLearner) = (Q = x.approximator, Qₜ = x.target_approximator), +Functors.functor(x::REMDQNLearner) = (Q = x.approximator, Qₜ = x.target_approximator), y -> begin x = @set x.approximator = y.Q x = @set x.target_approximator = y.Qₜ @@ -120,7 +115,7 @@ function RLBase.update!(learner::REMDQNLearner, batch::NamedTuple) target_q = Qₜ(s′) target_q = convex_polygon .* reshape(target_q, :, ensemble_num, batch_size) - target_q = dropdims(sum(target_q, dims=2), dims=2) + target_q = dropdims(sum(target_q, dims = 2), dims = 2) if haskey(batch, :next_legal_actions_mask) l′ = send_to_device(D, batch[:next_legal_actions_mask]) @@ -133,7 +128,7 @@ function RLBase.update!(learner::REMDQNLearner, batch::NamedTuple) gs = gradient(params(Q)) do q = Q(s) q = convex_polygon .* reshape(q, :, ensemble_num, batch_size) - q = dropdims(sum(q, dims=2), dims=2)[a] + q = dropdims(sum(q, dims = 2), dims = 2)[a] loss = loss_func(G, q) ignore() do @@ -143,5 +138,5 @@ function RLBase.update!(learner::REMDQNLearner, batch::NamedTuple) end update!(Q, gs) -end +end diff --git a/src/ReinforcementLearningZoo/src/algorithms/exploitability_descent/EDPolicy.jl b/src/ReinforcementLearningZoo/src/algorithms/exploitability_descent/EDPolicy.jl index 5cf775c06..34d474aca 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/exploitability_descent/EDPolicy.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/exploitability_descent/EDPolicy.jl @@ -24,13 +24,13 @@ performs the following update for each player: [Computing Approximate Equilibria in Sequential Adversarial Games by Exploitability Descent](https://arxiv.org/abs/1903.05614) """ -mutable struct EDPolicy{P<:NeuralNetworkApproximator, E<:AbstractExplorer} +mutable struct EDPolicy{P<:NeuralNetworkApproximator,E<:AbstractExplorer} opponent::Any learner::P explorer::E end -Flux.functor(x::EDPolicy) = (learner = x.learner,), y -> begin +Functors.functor(x::EDPolicy) = (learner = x.learner,), y -> begin x = @set x.learner = y.learner x end @@ -40,8 +40,8 @@ function (π::EDPolicy)(env::AbstractEnv) s = state(env) s = send_to_device(device(π.learner), Flux.unsqueeze(s, ndims(s) + 1)) logits = π.learner(s) |> vec |> send_to_host - ActionStyle(env) isa MinimalActionSet ? π.explorer(logits) : - π.explorer(logits, legal_action_space_mask(env)) + ActionStyle(env) isa MinimalActionSet ? π.explorer(logits) : + π.explorer(logits, legal_action_space_mask(env)) end # set the `_device` function for convenience transferring the variable to the corresponding device. _device(π::EDPolicy, x) = send_to_device(device(π.learner), x) @@ -50,7 +50,9 @@ function RLBase.prob(π::EDPolicy, env::AbstractEnv; to_host::Bool = true) s = @ignore state(env) |> x -> Flux.unsqueeze(x, ndims(x) + 1) |> x -> _device(π, x) logits = π.learner(s) |> vec mask = @ignore legal_action_space_mask(env) |> x -> _device(π, x) - p = ActionStyle(env) isa MinimalActionSet ? prob(π.explorer, logits) : prob(π.explorer, logits, mask) + p = + ActionStyle(env) isa MinimalActionSet ? prob(π.explorer, logits) : + prob(π.explorer, logits, mask) to_host ? p |> send_to_host : p end @@ -72,8 +74,8 @@ end ## update policy function RLBase.update!( - π::EDPolicy, - Opponent_BR::BestResponsePolicy, + π::EDPolicy, + Opponent_BR::BestResponsePolicy, env::AbstractEnv, player::Any, ) @@ -81,10 +83,7 @@ function RLBase.update!( # construct policy vs best response policy_vs_br = PolicyVsBestReponse( - MultiAgentManager( - NamedPolicy(player, π), - NamedPolicy(π.opponent, Opponent_BR), - ), + MultiAgentManager(NamedPolicy(player, π), NamedPolicy(π.opponent, Opponent_BR)), env, player, ) @@ -95,8 +94,11 @@ function RLBase.update!( # Vector of shape `(length(info_states), 1)` # compute expected reward from the start of `e` with policy_vs_best_reponse # baseline = ∑ₐ πᵢ(s, a) * q(s, a) - baseline = @ignore Flux.stack(([values_vs_br(policy_vs_br, e)] for e in info_states), 1) |> x -> _device(π, x) - + baseline = @ignore Flux.stack( + ([values_vs_br(policy_vs_br, e)] for e in info_states), + 1, + ) |> x -> _device(π, x) + # Vector of shape `(length(info_states), length(action_space))` # compute expected reward from the start of `e` when playing each action. q_values = Flux.stack((q_value(π, policy_vs_br, e) for e in info_states), 1) @@ -104,11 +106,12 @@ function RLBase.update!( advantage = q_values .- baseline # Vector of shape `(length(info_states), length(action_space))` # get the prob of each action with `e`, i.e., πᵢ(s, a). - policy_values = Flux.stack((prob(π, e, to_host = false) for e in info_states), 1) + policy_values = + Flux.stack((prob(π, e, to_host = false) for e in info_states), 1) # get each info_state's loss # ∑ₐ πᵢ(s, a) * (q(s, a) - baseline), where baseline = ∑ₐ πᵢ(s, a) * q(s, a). - loss_per_state = - sum(policy_values .* advantage, dims = 2) + loss_per_state = -sum(policy_values .* advantage, dims = 2) sum(loss_per_state .* cfr_reach_prob) end @@ -116,8 +119,8 @@ function RLBase.update!( end ## Supplement struct for Computing related results when player's policy versus opponent's best_response. -struct PolicyVsBestReponse{E, P<:MultiAgentManager} - info_reach_prob::Dict{E, Float64} +struct PolicyVsBestReponse{E,P<:MultiAgentManager} + info_reach_prob::Dict{E,Float64} player::Any policy::P end @@ -125,12 +128,8 @@ end function PolicyVsBestReponse(policy, env, player) E = typeof(env) - p = PolicyVsBestReponse( - Dict{E, Float64}(), - player, - policy, - ) - + p = PolicyVsBestReponse(Dict{E,Float64}(), player, policy) + e = copy(env) RLBase.reset!(e) get_cfr_prob!(p, e) @@ -171,7 +170,7 @@ function values_vs_br(p::PolicyVsBestReponse, env::AbstractEnv) end end v - # for game which has two or more rounds. + # for game which has two or more rounds. elseif @ignore current_player(env) == chance_player(env) v = 0.0 A, P = @ignore (action_space(env), prob(env)) @@ -188,7 +187,7 @@ function values_vs_br(p::PolicyVsBestReponse, env::AbstractEnv) end function q_value(π::EDPolicy, p::PolicyVsBestReponse, env::AbstractEnv) - P, A = prob(π, env) , @ignore action_space(env) + P, A = prob(π, env), @ignore action_space(env) v = [] for (a, pₐ) in zip(A, P) value = pₐ == 0 ? pₐ : values_vs_br(p, @ignore child(env, a)) diff --git a/src/ReinforcementLearningZoo/src/algorithms/nfsp/nfsp.jl b/src/ReinforcementLearningZoo/src/algorithms/nfsp/nfsp.jl index 8a975936f..c3d9e22b8 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/nfsp/nfsp.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/nfsp/nfsp.jl @@ -20,8 +20,8 @@ See the paper https://arxiv.org/abs/1603.01121 for more details. mutable struct NFSPAgent <: AbstractPolicy rl_agent::Agent sl_agent::Agent - η - rng + η::Any + rng::Any update_freq::Int update_step::Int mode::Bool @@ -96,7 +96,7 @@ function (π::NFSPAgent)(::PostEpisodeStage, env::AbstractEnv, player::Any) if haskey(rl.trajectory, :legal_actions_mask) push!(rl.trajectory[:legal_actions_mask], legal_action_space_mask(env, player)) end - + # update the policy π.update_step += 1 if π.update_step % π.update_freq == 0 @@ -110,10 +110,10 @@ function (π::NFSPAgent)(::PostEpisodeStage, env::AbstractEnv, player::Any) end # here just update the rl's approximator, not update target_approximator. -function rl_learn!(policy::QBasedPolicy, t::AbstractTrajectory) +function rl_learn!(policy::QBasedPolicy, t::Any) learner = policy.learner length(t[:terminal]) - learner.sampler.n <= learner.min_replay_history && return - + _, batch = sample(learner.rng, t, learner.sampler) if t isa PrioritizedTrajectory diff --git a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/BCQ.jl b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/BCQ.jl index 0fa2bfa98..0febdb2a0 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/BCQ.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/BCQ.jl @@ -7,7 +7,7 @@ mutable struct BCQLearner{ BC2<:NeuralNetworkApproximator, V<:NeuralNetworkApproximator, R<:AbstractRNG, -} <: AbstractLearner +} <: Any policy::BA1 target_policy::BA2 qnetwork1::BC1 @@ -99,7 +99,7 @@ end function (l::BCQLearner)(env) s = send_to_device(device(l.policy), state(env)) s = Flux.unsqueeze(s, ndims(s) + 1) - s = repeat(s, outer=(1, 1, l.p)) + s = repeat(s, outer = (1, 1, l.p)) action = l.policy(s, decode(l.vae.model, s)) q_value = l.qnetwork1(vcat(s, action)) idx = argmax(q_value) @@ -130,11 +130,15 @@ function update_learner!(l::BCQLearner, batch::NamedTuple{SARTS}) γ, τ, λ = l.γ, l.τ, l.λ - repeat_s′ = repeat(s′, outer=(1, 1, l.p)) + repeat_s′ = repeat(s′, outer = (1, 1, l.p)) repeat_a′ = l.target_policy(repeat_s′, decode(l.vae.model, repeat_s′)) q′_input = vcat(repeat_s′, repeat_a′) - q′ = maximum(λ .* min.(l.target_qnetwork1(q′_input), l.target_qnetwork2(q′_input)) + (1 - λ) .* max.(l.target_qnetwork1(q′_input), l.target_qnetwork2(q′_input)), dims=3) + q′ = maximum( + λ .* min.(l.target_qnetwork1(q′_input), l.target_qnetwork2(q′_input)) + + (1 - λ) .* max.(l.target_qnetwork1(q′_input), l.target_qnetwork2(q′_input)), + dims = 3, + ) y = r .+ γ .* (1 .- t) .* vec(q′) @@ -145,7 +149,7 @@ function update_learner!(l::BCQLearner, batch::NamedTuple{SARTS}) q_grad_1 = gradient(Flux.params(l.qnetwork1)) do q1 = l.qnetwork1(q_input) |> vec loss = mse(q1, y) - ignore() do + ignore() do l.critic_loss = loss end loss @@ -155,7 +159,7 @@ function update_learner!(l::BCQLearner, batch::NamedTuple{SARTS}) q_grad_2 = gradient(Flux.params(l.qnetwork2)) do q2 = l.qnetwork2(q_input) |> vec loss = mse(q2, y) - ignore() do + ignore() do l.critic_loss += loss end loss @@ -167,7 +171,7 @@ function update_learner!(l::BCQLearner, batch::NamedTuple{SARTS}) sampled_action = decode(l.vae.model, s) perturbed_action = l.policy(s, sampled_action) actor_loss = -mean(l.qnetwork1(vcat(s, perturbed_action))) - ignore() do + ignore() do l.actor_loss = actor_loss end actor_loss diff --git a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/BEAR.jl b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/BEAR.jl index 39af0175d..eec39869c 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/BEAR.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/BEAR.jl @@ -8,7 +8,7 @@ mutable struct BEARLearner{ V<:NeuralNetworkApproximator, L<:NeuralNetworkApproximator, R<:AbstractRNG, -} <: AbstractLearner +} <: Any policy::BA1 target_policy::BA2 qnetwork1::BC1 @@ -34,7 +34,7 @@ mutable struct BEARLearner{ # Logging actor_loss::Float32 critic_loss::Float32 - mmd_loss + mmd_loss::Any end """ @@ -126,8 +126,8 @@ end function (l::BEARLearner)(env) s = send_to_device(device(l.policy), state(env)) s = Flux.unsqueeze(s, ndims(s) + 1) - s = repeat(s, outer=(1, 1, l.p)) - action = l.policy(l.rng, s; is_sampling=true) + s = repeat(s, outer = (1, 1, l.p)) + action = l.policy(l.rng, s; is_sampling = true) q_value = l.qnetwork1(vcat(s, action)) idx = argmax(q_value) action[idx] @@ -139,13 +139,17 @@ function RLBase.update!(l::BEARLearner, batch::NamedTuple{SARTS}) γ, τ, λ = l.γ, l.τ, l.λ update_vae!(l, s, a) - - repeat_s′ = repeat(s′, outer=(1, 1, l.p)) - repeat_action′ = l.target_policy(l.rng, repeat_s′, is_sampling=true) + + repeat_s′ = repeat(s′, outer = (1, 1, l.p)) + repeat_action′ = l.target_policy(l.rng, repeat_s′, is_sampling = true) q′_input = vcat(repeat_s′, repeat_action′) - q′ = maximum(λ .* min.(l.target_qnetwork1(q′_input), l.target_qnetwork2(q′_input)) + (1 - λ) .* max.(l.target_qnetwork1(q′_input), l.target_qnetwork2(q′_input)), dims=3) + q′ = maximum( + λ .* min.(l.target_qnetwork1(q′_input), l.target_qnetwork2(q′_input)) + + (1 - λ) .* max.(l.target_qnetwork1(q′_input), l.target_qnetwork2(q′_input)), + dims = 3, + ) y = r .+ γ .* (1 .- t) .* vec(q′) @@ -156,7 +160,7 @@ function RLBase.update!(l::BEARLearner, batch::NamedTuple{SARTS}) q_grad_1 = gradient(Flux.params(l.qnetwork1)) do q1 = l.qnetwork1(q_input) |> vec loss = mse(q1, y) - ignore() do + ignore() do l.critic_loss = loss end loss @@ -166,30 +170,40 @@ function RLBase.update!(l::BEARLearner, batch::NamedTuple{SARTS}) q_grad_2 = gradient(Flux.params(l.qnetwork2)) do q2 = l.qnetwork2(q_input) |> vec loss = mse(q2, y) - ignore() do + ignore() do l.critic_loss += loss end loss end update!(l.qnetwork2, q_grad_2) - repeat_s = repeat(s, outer=(1, 1, l.p)) - repeat_a = repeat(a, outer=(1, 1, l.p)) - repeat_q1 = mean(l.target_qnetwork1(vcat(repeat_s, repeat_a)), dims=(1, 3)) - repeat_q2 = mean(l.target_qnetwork2(vcat(repeat_s, repeat_a)), dims=(1, 3)) + repeat_s = repeat(s, outer = (1, 1, l.p)) + repeat_a = repeat(a, outer = (1, 1, l.p)) + repeat_q1 = mean(l.target_qnetwork1(vcat(repeat_s, repeat_a)), dims = (1, 3)) + repeat_q2 = mean(l.target_qnetwork2(vcat(repeat_s, repeat_a)), dims = (1, 3)) q = vec(min.(repeat_q1, repeat_q2)) alpha = exp(l.log_α.model[1]) # Train Policy p_grad = gradient(Flux.params(l.policy)) do - raw_sample_action = decode(l.vae.model, repeat(s, outer=(1, 1, l.sample_num)); is_normalize=false) # action_dim * batch_size * sample_num - raw_actor_action = l.policy(repeat(s, outer=(1, 1, l.sample_num)); is_sampling=true) # action_dim * batch_size * sample_num - - mmd_loss = maximum_mean_discrepancy_loss(raw_sample_action, raw_actor_action, l.kernel_type, l.mmd_σ) + raw_sample_action = decode( + l.vae.model, + repeat(s, outer = (1, 1, l.sample_num)); + is_normalize = false, + ) # action_dim * batch_size * sample_num + raw_actor_action = + l.policy(repeat(s, outer = (1, 1, l.sample_num)); is_sampling = true) # action_dim * batch_size * sample_num + + mmd_loss = maximum_mean_discrepancy_loss( + raw_sample_action, + raw_actor_action, + l.kernel_type, + l.mmd_σ, + ) actor_loss = mean(-q .+ alpha .* mmd_loss) - ignore() do + ignore() do l.actor_loss = actor_loss l.mmd_loss = mmd_loss end @@ -198,13 +212,13 @@ function RLBase.update!(l::BEARLearner, batch::NamedTuple{SARTS}) update!(l.policy, p_grad) # Update lagrange multiplier - l_grad = gradient(Flux.params(l.log_α)) do + l_grad = gradient(Flux.params(l.log_α)) do mean(-q .+ alpha .* (l.mmd_loss .- l.ε)) end update!(l.log_α, l_grad) - + clamp!(l.log_α.model, l.min_log_α, l.max_log_α) - + # polyak averaging for (dest, src) in zip( Flux.params([l.target_policy, l.target_qnetwork1, l.target_qnetwork2]), diff --git a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/CRR.jl b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/CRR.jl index ef6be153e..1eda02a71 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/CRR.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/CRR.jl @@ -22,11 +22,7 @@ See paper: [Critic Regularized Regression](https://arxiv.org/abs/2006.15134). - `continuous::Bool`: type of action space. - `rng = Random.GLOBAL_RNG` """ -mutable struct CRRLearner{ - Aq<:ActorCritic, - At<:ActorCritic, - R<:AbstractRNG, -} <: AbstractLearner +mutable struct CRRLearner{Aq<:ActorCritic,At<:ActorCritic,R<:AbstractRNG} <: Any approximator::Aq target_approximator::At γ::Float32 @@ -61,7 +57,7 @@ function CRRLearner(; target_update_freq::Int = 100, continuous::Bool, rng = Random.GLOBAL_RNG, -) where {Aq<:ActorCritic, At<:ActorCritic} +) where {Aq<:ActorCritic,At<:ActorCritic} copyto!(approximator, target_approximator) CRRLearner( approximator, @@ -83,7 +79,7 @@ function CRRLearner(; ) end -Flux.functor(x::CRRLearner) = (Q = x.approximator, Qₜ = x.target_approximator), +Functors.functor(x::CRRLearner) = (Q = x.approximator, Qₜ = x.target_approximator), y -> begin x = @set x.approximator = y.Q x = @set x.target_approximator = y.Qₜ @@ -95,7 +91,7 @@ function (learner::CRRLearner)(env) s = Flux.unsqueeze(s, ndims(s) + 1) s = send_to_device(device(learner), s) if learner.continuous - learner.approximator.actor(s; is_sampling=true) |> vec |> send_to_host + learner.approximator.actor(s; is_sampling = true) |> vec |> send_to_host else learner.approximator.actor(s) |> vec |> send_to_host end @@ -125,7 +121,7 @@ function continuous_update!(learner::CRRLearner, batch::NamedTuple) r = reshape(r, :, batch_size) t = reshape(t, :, batch_size) - target_a_t = target_AC.actor(s′; is_sampling=true) + target_a_t = target_AC.actor(s′; is_sampling = true) target_q_input = vcat(s′, target_a_t) expected_target_q = target_AC.critic(target_q_input) @@ -133,7 +129,7 @@ function continuous_update!(learner::CRRLearner, batch::NamedTuple) q_t = send_to_device(D, Matrix{Float32}(undef, learner.m, batch_size)) for i in 1:learner.m - a_sample = AC.actor(s; is_sampling=true) + a_sample = AC.actor(s; is_sampling = true) q_t[i, :] = AC.critic(vcat(s, a_sample)) end @@ -142,14 +138,14 @@ function continuous_update!(learner::CRRLearner, batch::NamedTuple) # Critic loss qa_t = AC.critic(vcat(s, a)) critic_loss = Flux.Losses.mse(qa_t, target) - + # Actor loss log_π = AC.actor(s, a) if advantage_estimator == :max - advantage = qa_t .- maximum(q_t, dims=1) + advantage = qa_t .- maximum(q_t, dims = 1) elseif advantage_estimator == :mean - advantage = qa_t .- mean(q_t, dims=1) + advantage = qa_t .- mean(q_t, dims = 1) else error("Wrong parameter.") end @@ -168,7 +164,7 @@ function continuous_update!(learner::CRRLearner, batch::NamedTuple) learner.actor_loss = actor_loss learner.critic_loss = critic_loss end - + actor_loss + critic_loss end @@ -193,7 +189,7 @@ function discrete_update!(learner::CRRLearner, batch::NamedTuple) target_a_t = softmax(target_AC.actor(s′)) target_q_t = target_AC.critic(s′) - expected_target_q = sum(target_a_t .* target_q_t, dims=1) + expected_target_q = sum(target_a_t .* target_q_t, dims = 1) target = r .+ γ .* (1 .- t) .* expected_target_q @@ -203,14 +199,14 @@ function discrete_update!(learner::CRRLearner, batch::NamedTuple) q_t = AC.critic(s) qa_t = reshape(q_t[a], :, batch_size) critic_loss = Flux.Losses.mse(qa_t, target) - + # Actor loss a_t = softmax(AC.actor(s)) if advantage_estimator == :max - advantage = qa_t .- maximum(q_t, dims=1) + advantage = qa_t .- maximum(q_t, dims = 1) elseif advantage_estimator == :mean - advantage = qa_t .- mean(q_t, dims=1) + advantage = qa_t .- mean(q_t, dims = 1) else error("Wrong parameter.") end @@ -222,14 +218,14 @@ function discrete_update!(learner::CRRLearner, batch::NamedTuple) else error("Wrong parameter.") end - + actor_loss = mean(-log.(a_t[a]) .* actor_loss_coef) ignore() do learner.actor_loss = actor_loss learner.critic_loss = critic_loss end - + actor_loss + critic_loss end diff --git a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/DiscreteBCQ.jl b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/DiscreteBCQ.jl index 613e7c851..2068479d6 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/DiscreteBCQ.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/DiscreteBCQ.jl @@ -18,11 +18,7 @@ See paper: [Benchmarking Batch Deep Reinforcement Learning Algorithms](https://a - `update_step::Int = 0` - `rng = Random.GLOBAL_RNG` """ -mutable struct BCQDLearner{ - Aq<:ActorCritic, - At<:ActorCritic, - R<:AbstractRNG, -} <: AbstractLearner +mutable struct BCQDLearner{Aq<:ActorCritic,At<:ActorCritic,R<:AbstractRNG} <: Any approximator::Aq target_approximator::At γ::Float32 @@ -43,13 +39,13 @@ function BCQDLearner(; target_approximator::At, γ::Float32 = 0.99f0, τ::Float32 = 0.005f0, - θ::Float32 = 1f-2, + θ::Float32 = 1.0f-2, threshold::Float32 = 0.3f0, batch_size::Int = 32, update_freq::Int = 10, update_step::Int = 0, rng = Random.GLOBAL_RNG, -) where {Aq<:ActorCritic, At<:ActorCritic} +) where {Aq<:ActorCritic,At<:ActorCritic} copyto!(approximator, target_approximator) BCQDLearner( approximator, @@ -67,7 +63,7 @@ function BCQDLearner(; ) end -Flux.functor(x::BCQDLearner) = (Q = x.approximator, Qₜ = x.target_approximator), +Functors.functor(x::BCQDLearner) = (Q = x.approximator, Qₜ = x.target_approximator), y -> begin x = @set x.approximator = y.Q x = @set x.target_approximator = y.Qₜ @@ -79,9 +75,9 @@ function (learner::BCQDLearner)(env) s = Flux.unsqueeze(s, ndims(s) + 1) s = send_to_device(device(learner), s) q = learner.approximator.critic(s) - prob = softmax(learner.approximator.actor(s), dims=1) - mask = Float32.((prob ./ maximum(prob, dims=1)) .> learner.threshold) - new_q = q .* mask .+ (1.0f0 .- mask) .* -1f8 + prob = softmax(learner.approximator.actor(s), dims = 1) + mask = Float32.((prob ./ maximum(prob, dims = 1)) .> learner.threshold) + new_q = q .* mask .+ (1.0f0 .- mask) .* -1.0f8 new_q |> vec |> send_to_host end @@ -96,9 +92,9 @@ function RLBase.update!(learner::BCQDLearner, batch::NamedTuple) a = CartesianIndex.(a, 1:batch_size) prob = softmax(AC.actor(s′)) - mask = Float32.((prob ./ maximum(prob, dims=1)) .> learner.threshold) + mask = Float32.((prob ./ maximum(prob, dims = 1)) .> learner.threshold) q′ = AC.critic(s′) - a′ = argmax(q′ .* mask .+ (1.0f0 .- mask) .* -1f8, dims=1) + a′ = argmax(q′ .* mask .+ (1.0f0 .- mask) .* -1.0f8, dims = 1) target_q = target_AC.critic(s′) target = r .+ γ .* (1 .- t) .* vec(target_q[a′]) @@ -108,27 +104,25 @@ function RLBase.update!(learner::BCQDLearner, batch::NamedTuple) # Critic loss q_t = AC.critic(s) critic_loss = Flux.Losses.huber_loss(q_t[a], target) - + # Actor loss logit = AC.actor(s) - log_prob = -log.(softmax(logit, dims=1)) + log_prob = -log.(softmax(logit, dims = 1)) actor_loss = mean(log_prob[a]) ignore() do learner.actor_loss = actor_loss learner.critic_loss = critic_loss end - + actor_loss + critic_loss + θ * mean(logit .^ 2) end update!(AC, gs) # polyak averaging - for (dest, src) in zip( - Flux.params([learner.target_approximator]), - Flux.params([learner.approximator]), - ) + for (dest, src) in + zip(Flux.params([learner.target_approximator]), Flux.params([learner.approximator])) dest .= (1 - τ) .* dest .+ τ .* src end end diff --git a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/FisherBRC.jl b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/FisherBRC.jl index 769f9f9b0..f78e7ee61 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/FisherBRC.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/FisherBRC.jl @@ -14,7 +14,7 @@ mutable struct FisherBRCLearner{ BC1<:NeuralNetworkApproximator, BC2<:NeuralNetworkApproximator, R<:AbstractRNG, -} <: AbstractLearner +} <: Any policy::BA behavior_policy::EntropyBC qnetwork1::BC1 @@ -91,7 +91,8 @@ function FisherBRCLearner(; ) copyto!(qnetwork1, target_qnetwork1) # force sync copyto!(qnetwork2, target_qnetwork2) # force sync - entropy_behavior_policy = EntropyBC(behavior_policy, 0.0f0, behavior_lr_alpha, Float32(-action_dims), 0.0f0) + entropy_behavior_policy = + EntropyBC(behavior_policy, 0.0f0, behavior_lr_alpha, Float32(-action_dims), 0.0f0) FisherBRCLearner( policy, entropy_behavior_policy, @@ -111,8 +112,8 @@ function FisherBRCLearner(; lr_alpha, Float32(-action_dims), rng, - 0f0, - 0f0, + 0.0f0, + 0.0f0, ) end @@ -120,7 +121,7 @@ function (l::FisherBRCLearner)(env) D = device(l.policy) s = send_to_device(D, state(env)) s = Flux.unsqueeze(s, ndims(s) + 1) - action = dropdims(l.policy(l.rng, s; is_sampling=true), dims=2) + action = dropdims(l.policy(l.rng, s; is_sampling = true), dims = 2) end function RLBase.update!(l::FisherBRCLearner, batch::NamedTuple{SARTS}) @@ -137,7 +138,7 @@ function update_behavior_policy!(l::EntropyBC, batch::NamedTuple{SARTS}) # Update behavior policy with entropy gs = gradient(Flux.params(l.policy)) do log_π = l.policy.model(s, a) - _, entropy = l.policy.model(s; is_sampling=true, is_return_log_prob=true) + _, entropy = l.policy.model(s; is_sampling = true, is_return_log_prob = true) loss = mean(l.α .* entropy .- log_π) # Update entropy ignore() do @@ -155,7 +156,7 @@ function update_learner!(l::FisherBRCLearner, batch::NamedTuple{SARTS}) r .+= l.reward_bonus γ, τ, α = l.γ, l.τ, l.α - a′ = l.policy(l.rng, s′; is_sampling=true) + a′ = l.policy(l.rng, s′; is_sampling = true) q′_input = vcat(s′, a′) target_q′ = min.(l.target_qnetwork1(q′_input), l.target_qnetwork2(q′_input)) @@ -165,16 +166,16 @@ function update_learner!(l::FisherBRCLearner, batch::NamedTuple{SARTS}) a = reshape(a, :, l.batch_size) q_input = vcat(s, a) log_μ = l.behavior_policy.policy.model(s, a) |> vec - a_policy = l.policy(l.rng, s; is_sampling=true) + a_policy = l.policy(l.rng, s; is_sampling = true) q_grad_1 = gradient(Flux.params(l.qnetwork1)) do q1 = l.qnetwork1(q_input) |> vec - q1_grad_norm = gradient(Flux.params([a_policy])) do + q1_grad_norm = gradient(Flux.params([a_policy])) do q1_reg = mean(l.qnetwork1(vcat(s, a_policy))) end reg = mean(q1_grad_norm[a_policy] .^ 2) loss = mse(q1 .+ log_μ, y) + l.f_reg * reg - ignore() do + ignore() do l.qnetwork_loss = loss end loss @@ -183,12 +184,12 @@ function update_learner!(l::FisherBRCLearner, batch::NamedTuple{SARTS}) q_grad_2 = gradient(Flux.params(l.qnetwork2)) do q2 = l.qnetwork2(q_input) |> vec - q2_grad_norm = gradient(Flux.params([a_policy])) do + q2_grad_norm = gradient(Flux.params([a_policy])) do q2_reg = mean(l.qnetwork2(vcat(s, a_policy))) end reg = mean(q2_grad_norm[a_policy] .^ 2) loss = mse(q2 .+ log_μ, y) + l.f_reg * reg - ignore() do + ignore() do l.qnetwork_loss += loss end loss @@ -197,7 +198,7 @@ function update_learner!(l::FisherBRCLearner, batch::NamedTuple{SARTS}) # Train Policy p_grad = gradient(Flux.params(l.policy)) do - a, log_π = l.policy(l.rng, s; is_sampling=true, is_return_log_prob=true) + a, log_π = l.policy(l.rng, s; is_sampling = true, is_return_log_prob = true) q_input = vcat(s, a) q = min.(l.qnetwork1(q_input), l.qnetwork2(q_input)) .+ log_μ policy_loss = mean(α .* log_π .- q) diff --git a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/PLAS.jl b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/PLAS.jl index 8ced04148..c746215ba 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/PLAS.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/PLAS.jl @@ -7,7 +7,7 @@ mutable struct PLASLearner{ BC2<:NeuralNetworkApproximator, V<:NeuralNetworkApproximator, R<:AbstractRNG, -} <: AbstractLearner +} <: Any policy::BA1 target_policy::BA2 qnetwork1::BC1 @@ -96,7 +96,7 @@ function (l::PLASLearner)(env) s = send_to_device(device(l.policy), state(env)) s = Flux.unsqueeze(s, ndims(s) + 1) latent_action = tanh.(l.policy(s)) - action = dropdims(decode(l.vae.model, s, latent_action), dims=2) + action = dropdims(decode(l.vae.model, s, latent_action), dims = 2) end function RLBase.update!(l::PLASLearner, batch::NamedTuple{SARTS}) @@ -125,7 +125,9 @@ function update_learner!(l::PLASLearner, batch::NamedTuple{SARTS}) latent_action′ = tanh.(l.target_policy(s′)) action′ = decode(l.vae.model, s′, latent_action′) q′_input = vcat(s′, action′) - q′ = λ .* min.(l.target_qnetwork1(q′_input), l.target_qnetwork2(q′_input)) + (1 - λ) .* max.(l.target_qnetwork1(q′_input), l.target_qnetwork2(q′_input)) + q′ = + λ .* min.(l.target_qnetwork1(q′_input), l.target_qnetwork2(q′_input)) + + (1 - λ) .* max.(l.target_qnetwork1(q′_input), l.target_qnetwork2(q′_input)) y = r .+ γ .* (1 .- t) .* vec(q′) @@ -136,7 +138,7 @@ function update_learner!(l::PLASLearner, batch::NamedTuple{SARTS}) q_grad_1 = gradient(Flux.params(l.qnetwork1)) do q1 = l.qnetwork1(q_input) |> vec loss = mse(q1, y) - ignore() do + ignore() do l.critic_loss = loss end loss @@ -146,7 +148,7 @@ function update_learner!(l::PLASLearner, batch::NamedTuple{SARTS}) q_grad_2 = gradient(Flux.params(l.qnetwork2)) do q2 = l.qnetwork2(q_input) |> vec loss = mse(q2, y) - ignore() do + ignore() do l.critic_loss += loss end loss @@ -158,7 +160,7 @@ function update_learner!(l::PLASLearner, batch::NamedTuple{SARTS}) latent_action = tanh.(l.policy(s)) action = decode(l.vae.model, s, latent_action) actor_loss = -mean(l.qnetwork1(vcat(s, action))) - ignore() do + ignore() do l.actor_loss = actor_loss end actor_loss diff --git a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/behavior_cloning.jl b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/behavior_cloning.jl index 8da0ff218..405612cd8 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/behavior_cloning.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/behavior_cloning.jl @@ -19,19 +19,14 @@ end - `rng = Random.GLOBAL_RNG` """ function BehaviorCloningPolicy(; - approximator::A, - explorer::AbstractExplorer = GreedyExplorer(), - batch_size::Int = 32, - min_reservoir_history::Int = 100, - rng = Random.GLOBAL_RNG + approximator::A, + explorer::AbstractExplorer = GreedyExplorer(), + batch_size::Int = 32, + min_reservoir_history::Int = 100, + rng = Random.GLOBAL_RNG, ) where {A} sampler = BatchSampler{(:state, :action)}(batch_size; rng = rng) - BehaviorCloningPolicy( - approximator, - explorer, - sampler, - min_reservoir_history, - ) + BehaviorCloningPolicy(approximator, explorer, sampler, min_reservoir_history) end function (p::BehaviorCloningPolicy)(env::AbstractEnv) @@ -39,7 +34,8 @@ function (p::BehaviorCloningPolicy)(env::AbstractEnv) s_batch = Flux.unsqueeze(s, ndims(s) + 1) s_batch = send_to_device(device(p.approximator), s_batch) logits = p.approximator(s_batch) |> vec |> send_to_host # drop dimension - typeof(ActionStyle(env)) == MinimalActionSet ? p.explorer(logits) : p.explorer(logits, legal_action_space_mask(env)) + typeof(ActionStyle(env)) == MinimalActionSet ? p.explorer(logits) : + p.explorer(logits, legal_action_space_mask(env)) end function RLBase.update!(p::BehaviorCloningPolicy, batch::NamedTuple{(:state, :action)}) @@ -54,7 +50,7 @@ function RLBase.update!(p::BehaviorCloningPolicy, batch::NamedTuple{(:state, :ac update!(m, gs) end -function RLBase.update!(p::BehaviorCloningPolicy, t::AbstractTrajectory) +function RLBase.update!(p::BehaviorCloningPolicy, t::Any) (length(t) <= p.min_reservoir_history || length(t) <= p.sampler.batch_size) && return _, batch = p.sampler(t) @@ -66,7 +62,8 @@ function RLBase.prob(p::BehaviorCloningPolicy, env::AbstractEnv) m = p.approximator s_batch = send_to_device(device(m), Flux.unsqueeze(s, ndims(s) + 1)) values = m(s_batch) |> vec |> send_to_host - typeof(ActionStyle(env)) == MinimalActionSet ? prob(p.explorer, values) : prob(p.explorer, values, legal_action_space_mask(env)) + typeof(ActionStyle(env)) == MinimalActionSet ? prob(p.explorer, values) : + prob(p.explorer, values, legal_action_space_mask(env)) end function RLBase.prob(p::BehaviorCloningPolicy, env::AbstractEnv, action) diff --git a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/common.jl b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/common.jl index 560554daf..868902647 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/common.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/common.jl @@ -3,11 +3,11 @@ export OfflinePolicy, JuliaRLTransition, gen_JuliaRL_dataset export calculate_CQL_loss, maximum_mean_discrepancy_loss struct JuliaRLTransition - state - action - reward - terminal - next_state + state::Any + action::Any + reward::Any + terminal::Any + next_state::Any end Base.@kwdef struct OfflinePolicy{L,T} <: AbstractPolicy @@ -26,7 +26,8 @@ function (π::OfflinePolicy)(env, ::MinimalActionSet, ::Base.OneTo) findmax(π.learner(env))[2] end end -(π::OfflinePolicy)(env, ::FullActionSet, ::Base.OneTo) = findmax(π.learner(env), legal_action_space_mask(env))[2] +(π::OfflinePolicy)(env, ::FullActionSet, ::Base.OneTo) = + findmax(π.learner(env), legal_action_space_mask(env))[2] function (π::OfflinePolicy)(env, ::MinimalActionSet, A) if π.continuous @@ -35,14 +36,10 @@ function (π::OfflinePolicy)(env, ::MinimalActionSet, A) A[findmax(π.learner(env))[2]] end end -(π::OfflinePolicy)(env, ::FullActionSet, A) = A[findmax(π.learner(env), legal_action_space_mask(env))[2]] +(π::OfflinePolicy)(env, ::FullActionSet, A) = + A[findmax(π.learner(env), legal_action_space_mask(env))[2]] -function RLBase.update!( - p::OfflinePolicy, - traj::AbstractTrajectory, - ::AbstractEnv, - ::PreExperimentStage, -) +function RLBase.update!(p::OfflinePolicy, traj::Any, ::AbstractEnv, ::PreExperimentStage) l = p.learner if in(:pretrain_step, fieldnames(typeof(l))) println("Pretrain...") @@ -53,16 +50,12 @@ function RLBase.update!( end end -function RLBase.update!( - p::OfflinePolicy, - traj::AbstractTrajectory, - ::AbstractEnv, - ::PreActStage, -) +function RLBase.update!(p::OfflinePolicy, traj::Any, ::AbstractEnv, ::PreActStage) l = p.learner l.update_step += 1 - if in(:target_update_freq, fieldnames(typeof(l))) && l.update_step % l.target_update_freq == 0 + if in(:target_update_freq, fieldnames(typeof(l))) && + l.update_step % l.target_update_freq == 0 copyto!(l.target_approximator, l.approximator) end @@ -78,14 +71,15 @@ end Generate the dataset by trajectory from the trajectory obtained from the experiment (`alg` + `env`). `type` represents the method of collecting data. Possible values: random/medium/expert. `dataset_size` is the size of the generated dataset. """ -function gen_JuliaRL_dataset(alg::Symbol, env::Symbol, type::AbstractString; dataset_size::Int) - dataset_ex = Experiment( - Val(:GenDataset), - Val(alg), - Val(env), - type; - dataset_size = dataset_size) - +function gen_JuliaRL_dataset( + alg::Symbol, + env::Symbol, + type::AbstractString; + dataset_size::Int, +) + dataset_ex = + Experiment(Val(:GenDataset), Val(alg), Val(env), type; dataset_size = dataset_size) + run(dataset_ex) dataset = [] @@ -123,19 +117,30 @@ end calculate_CQL_loss(q_value, action; method) See paper: [Conservative Q-Learning for Offline Reinforcement Learning](https://arxiv.org/abs/2006.04779) """ -function calculate_CQL_loss(q_value::Matrix{T}, action::Vector{R}; method = "CQL(H)") where {T, R} +function calculate_CQL_loss( + q_value::Matrix{T}, + action::Vector{R}; + method = "CQL(H)", +) where {T,R} if method == "CQL(H)" - cql_loss = mean(log.(sum(exp.(q_value), dims=1)) .- q_value[action]) + cql_loss = mean(log.(sum(exp.(q_value), dims = 1)) .- q_value[action]) else @error Wrong method parameter end return cql_loss end -function maximum_mean_discrepancy_loss(raw_sample_action, raw_actor_action, type::Symbol, mmd_σ::Float32=10.0f0) +function maximum_mean_discrepancy_loss( + raw_sample_action, + raw_actor_action, + type::Symbol, + mmd_σ::Float32 = 10.0f0, +) A, B, N = size(raw_sample_action) - diff_xx = reshape(raw_sample_action, A, B, N, 1) .- reshape(raw_sample_action, A, B, 1, N) - diff_xy = reshape(raw_sample_action, A, B, N, 1) .- reshape(raw_actor_action, A, B, 1, N) + diff_xx = + reshape(raw_sample_action, A, B, N, 1) .- reshape(raw_sample_action, A, B, 1, N) + diff_xy = + reshape(raw_sample_action, A, B, N, 1) .- reshape(raw_actor_action, A, B, 1, N) diff_yy = reshape(raw_actor_action, A, B, N, 1) .- reshape(raw_actor_action, A, B, 1, N) diff_xx = calculate_sample_distance(diff_xx, type, mmd_σ) diff_xy = calculate_sample_distance(diff_xy, type, mmd_σ) @@ -151,5 +156,5 @@ function calculate_sample_distance(diff, type::Symbol, mmd_σ::Float32) else error("Wrong parameter.") end - return vec(mean(exp.(-sum(diff, dims=1) ./ (2.0f0 * mmd_σ)), dims=(3, 4))) + return vec(mean(exp.(-sum(diff, dims = 1) ./ (2.0f0 * mmd_σ)), dims = (3, 4))) end diff --git a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/ope/FQE.jl b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/ope/FQE.jl index 0f695189d..0def5c170 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/offline_rl/ope/FQE.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/offline_rl/ope/FQE.jl @@ -5,7 +5,7 @@ mutable struct FQE{ C<:NeuralNetworkApproximator, C_T<:NeuralNetworkApproximator, R<:AbstractRNG, - } <: AbstractLearner +} <: Any policy::P q_network::C target_q_network::C_T @@ -44,13 +44,13 @@ function FQE(; policy, q_network, target_q_network, - n_evals=20, - γ=0.99f0, - batch_size=32, - update_freq=1, - update_step=0, + n_evals = 20, + γ = 0.99f0, + batch_size = 32, + update_freq = 1, + update_step = 0, tar_update_freq = 50, - rng=Random.GLOBAL_RNG, + rng = Random.GLOBAL_RNG, ) copyto!(q_network, target_q_network) #force sync FQE( @@ -68,8 +68,7 @@ function FQE(; ) end -Flux.functor(x::FQE) = (Q = x.q_network, Qₜ = x.target_q_network), -y -> begin +Functors.functor(x::FQE) = (Q = x.q_network, Qₜ = x.target_q_network), y -> begin x = @set x.q_network = y.Q x = @set x.target_q_network = y.Qₜ x @@ -78,7 +77,7 @@ end function (l::FQE)(env) s = send_to_device(device(l.policy), state(env)) s = Flux.unsqueeze(s, ndims(s) + 1) - action = dropdims(l.policy(l.rng, s; is_sampling=true), dims=2) + action = dropdims(l.policy(l.rng, s; is_sampling = true), dims = 2) end function (l::FQE)(env, ::Val{:Eval}) @@ -87,8 +86,8 @@ function (l::FQE)(env, ::Val{:Eval}) for _ in 1:l.n_evals reset!(env) s = send_to_device(D, state(env)) - s = Flux.unsqueeze(s, ndims(s)+1) - a = dropdims(l.policy(l.rng, s; is_sampling=true), dims=2) + s = Flux.unsqueeze(s, ndims(s) + 1) + a = dropdims(l.policy(l.rng, s; is_sampling = true), dims = 2) input = vcat(s, a) result = l.q_network(input) push!(results, result[]) @@ -107,7 +106,7 @@ end function RLBase.update!(l::FQE, batch::NamedTuple{SARTS}) policy = l.policy Q, Qₜ = l.q_network, l.target_q_network - + D = device(Q) s, a, r, t, s′ = (send_to_device(D, batch[x]) for x in SARTS) γ = l.γ @@ -116,7 +115,7 @@ function RLBase.update!(l::FQE, batch::NamedTuple{SARTS}) loss_func = Flux.Losses.mse q′ = Qₜ(vcat(s′, policy(s′)[1])) |> vec - + target = r .+ γ .* (1 .- t) .* q′ gs = gradient(params(Q)) do diff --git a/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/A2C.jl b/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/A2C.jl index ba727f469..e34b17376 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/A2C.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/A2C.jl @@ -12,7 +12,7 @@ export A2CLearner - `entropy_loss_weight::Float32` - `update_freq::Int`, usually set to the same with the length of trajectory. """ -Base.@kwdef mutable struct A2CLearner{A<:ActorCritic} <: AbstractLearner +Base.@kwdef mutable struct A2CLearner{A<:ActorCritic} <: Any approximator::A γ::Float32 max_grad_norm::Union{Nothing,Float32} = nothing @@ -29,7 +29,7 @@ Base.@kwdef mutable struct A2CLearner{A<:ActorCritic} <: AbstractLearner norm::Float32 = 0.0f0 end -Flux.functor(x::A2CLearner) = (app = x.approximator,), y -> @set x.approximator = y.app +Functors.functor(x::A2CLearner) = (app = x.approximator,), y -> @set x.approximator = y.app function (learner::A2CLearner)(env::MultiThreadEnv) learner.approximator.actor(send_to_device(device(learner), state(env))) |> send_to_host diff --git a/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/A2CGAE.jl b/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/A2CGAE.jl index f775a2c27..2865dd4ee 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/A2CGAE.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/A2CGAE.jl @@ -10,7 +10,7 @@ export A2CGAELearner - `critic_loss_weight::Float32` - `entropy_loss_weight::Float32` """ -Base.@kwdef mutable struct A2CGAELearner{A<:ActorCritic} <: AbstractLearner +Base.@kwdef mutable struct A2CGAELearner{A<:ActorCritic} <: Any approximator::A γ::Float32 λ::Float32 @@ -28,7 +28,8 @@ Base.@kwdef mutable struct A2CGAELearner{A<:ActorCritic} <: AbstractLearner norm::Float32 = 0.0f0 end -Flux.functor(x::A2CGAELearner) = (app = x.approximator,), y -> @set x.approximator = y.app +Functors.functor(x::A2CGAELearner) = + (app = x.approximator,), y -> @set x.approximator = y.app (learner::A2CGAELearner)(env::MultiThreadEnv) = learner.approximator.actor(send_to_device(device(learner), state(env))) |> send_to_host @@ -62,11 +63,7 @@ function _update!(learner::A2CGAELearner, t::CircularArraySARTTrajectory) select_last_dim(x, 1:n) |> flatten_batch |> a -> CartesianIndex.(a, 1:length(a)) rollout_values = - S |> - flatten_batch |> - AC.critic |> - x -> reshape(x, :, n + 1) |> - send_to_host + S |> flatten_batch |> AC.critic |> x -> reshape(x, :, n + 1) |> send_to_host advantages = generalized_advantage_estimation( t[:reward], diff --git a/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/MAC.jl b/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/MAC.jl index 3ea974dcd..a61a58db9 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/MAC.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/MAC.jl @@ -12,7 +12,7 @@ export MACLearner - `bootstrap::bool`, if false then Q function is approximated using monte carlo returns. """ -Base.@kwdef mutable struct MACLearner{A<:ActorCritic} <: AbstractLearner +Base.@kwdef mutable struct MACLearner{A<:ActorCritic} <: Any approximator::A γ::Float32 max_grad_norm::Union{Nothing,Float32} = nothing @@ -25,7 +25,7 @@ Base.@kwdef mutable struct MACLearner{A<:ActorCritic} <: AbstractLearner update_step::Int = 0 end -Flux.functor(x::MACLearner) = (app = x.approximator,), y -> @set x.approximator = y.app +Functors.functor(x::MACLearner) = (app = x.approximator,), y -> @set x.approximator = y.app function (learner::MACLearner)(env::MultiThreadEnv) learner.approximator.actor(send_to_device(device(learner.approximator), state(env))) |> diff --git a/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/ddpg.jl b/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/ddpg.jl index d49f971b0..a35c362b4 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/ddpg.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/ddpg.jl @@ -30,7 +30,7 @@ mutable struct DDPGPolicy{ critic_loss::Float32 end -Flux.functor(x::DDPGPolicy) = ( +Functors.functor(x::DDPGPolicy) = ( ba = x.behavior_actor, bc = x.behavior_critic, ta = x.target_actor, @@ -118,7 +118,12 @@ function (p::DDPGPolicy)(env, player::Any = nothing) s = DynamicStyle(env) == SEQUENTIAL ? state(env) : state(env, player) s = Flux.unsqueeze(s, ndims(s) + 1) actions = p.behavior_actor(send_to_device(D, s)) |> vec |> send_to_host - c = clamp.(actions .+ randn(p.rng, p.na) .* repeat([p.act_noise], p.na), -p.act_limit, p.act_limit) + c = + clamp.( + actions .+ randn(p.rng, p.na) .* repeat([p.act_noise], p.na), + -p.act_limit, + p.act_limit, + ) p.na == 1 && return c[1] c end @@ -154,7 +159,7 @@ function RLBase.update!(p::DDPGPolicy, batch::NamedTuple{SARTS}) a′ = Aₜ(s′) qₜ = Cₜ(vcat(s′, a′)) |> vec y = r .+ γ .* (1 .- t) .* qₜ - a = Flux.unsqueeze(a, ndims(a)+1) + a = Flux.unsqueeze(a, ndims(a) + 1) gs1 = gradient(Flux.params(C)) do q = C(vcat(s, a)) |> vec diff --git a/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/ppo.jl b/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/ppo.jl index a3b2a0cac..d2181151f 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/ppo.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/policy_gradient/ppo.jl @@ -149,7 +149,9 @@ function RLBase.prob( if p.update_step < p.n_random_start @error "todo" else - μ, logσ = p.approximator.actor(send_to_device(device(p.approximator), state)) |> send_to_host + μ, logσ = + p.approximator.actor(send_to_device(device(p.approximator), state)) |> + send_to_host StructArray{Normal}((μ, exp.(logσ))) end end @@ -157,7 +159,7 @@ end function RLBase.prob(p::PPOPolicy{<:ActorCritic,Categorical}, state::AbstractArray, mask) logits = p.approximator.actor(send_to_device(device(p.approximator), state)) if !isnothing(mask) - logits .+= ifelse.(mask, 0f0, typemin(Float32)) + logits .+= ifelse.(mask, 0.0f0, typemin(Float32)) end logits = logits |> softmax |> send_to_host if p.update_step < p.n_random_start @@ -171,14 +173,14 @@ function RLBase.prob(p::PPOPolicy{<:ActorCritic,Categorical}, state::AbstractArr end function RLBase.prob(p::PPOPolicy, env::MultiThreadEnv) - mask = ActionStyle(env) === FULL_ACTION_SET ? legal_action_space_mask(env) : nothing + mask = ActionStyle(env) === FULL_ACTION_SET ? legal_action_space_mask(env) : nothing prob(p, state(env), mask) end function RLBase.prob(p::PPOPolicy, env::AbstractEnv) s = state(env) s = Flux.unsqueeze(s, ndims(s) + 1) - mask = ActionStyle(env) === FULL_ACTION_SET ? legal_action_space_mask(env) : nothing + mask = ActionStyle(env) === FULL_ACTION_SET ? legal_action_space_mask(env) : nothing prob(p, s, mask) end @@ -211,7 +213,7 @@ function RLBase.update!( end end -function _update!(p::PPOPolicy, t::AbstractTrajectory) +function _update!(p::PPOPolicy, t::Any) rng = p.rng AC = p.approximator γ = p.γ @@ -261,11 +263,8 @@ function _update!(p::PPOPolicy, t::AbstractTrajectory) for i in 1:n_microbatches inds = rand_inds[(i-1)*microbatch_size+1:i*microbatch_size] if t isa MaskedPPOTrajectory - lam = select_last_dim( - flatten_batch(select_last_dim(LAM, 2:n+1)), - inds, - ) - + lam = select_last_dim(flatten_batch(select_last_dim(LAM, 2:n+1)), inds) + else lam = nothing end @@ -274,11 +273,11 @@ function _update!(p::PPOPolicy, t::AbstractTrajectory) # !!! we need to convert it into a continuous CuArray otherwise CUDA.jl will complain scalar indexing s = to_device(collect(select_last_dim(states_flatten_on_host, inds))) a = to_device(collect(select_last_dim(actions_flatten, inds))) - + if eltype(a) === Int a = CartesianIndex.(a, 1:length(a)) end - + r = vec(returns)[inds] log_p = vec(action_log_probs)[inds] adv = vec(advantages)[inds] @@ -293,7 +292,8 @@ function _update!(p::PPOPolicy, t::AbstractTrajectory) else log_p′ₐ = normlogpdf(μ, exp.(logσ), a) end - entropy_loss = mean(size(logσ, 1) * (log(2.0f0π) + 1) .+ sum(logσ; dims = 1)) / 2 + entropy_loss = + mean(size(logσ, 1) * (log(2.0f0π) + 1) .+ sum(logσ; dims = 1)) / 2 else # actor is assumed to return discrete logits raw_logit′ = AC.actor(s) diff --git a/src/ReinforcementLearningZoo/src/algorithms/tabular/double_learner.jl b/src/ReinforcementLearningZoo/src/algorithms/tabular/double_learner.jl index cb9d205cf..b32b9eb6d 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/tabular/double_learner.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/tabular/double_learner.jl @@ -8,8 +8,7 @@ using Random This is a meta-learner, it will randomly select one learner and update another learner. The estimation of an observation is the sum of result from two learners. """ -Base.@kwdef struct DoubleLearner{T1<:AbstractLearner,T2<:AbstractLearner,R<:AbstractRNG} <: - AbstractLearner +Base.@kwdef struct DoubleLearner{T1<:Any,T2<:Any,R<:AbstractRNG} <: Any L1::T1 L2::T2 rng::R = Random.GLOBAL_RNG @@ -19,7 +18,7 @@ end function RLBase.update!( L::DoubleLearner{<:TDLearner}, - t::AbstractTrajectory, + t::Any, ::AbstractEnv, ::PostEpisodeStage, ) @@ -41,12 +40,7 @@ function RLBase.update!( end end -function RLBase.update!( - L::DoubleLearner{<:TDLearner}, - t::AbstractTrajectory, - ::AbstractEnv, - ::PreActStage, -) +function RLBase.update!(L::DoubleLearner{<:TDLearner}, t::Any, ::AbstractEnv, ::PreActStage) if rand(L.rng, Bool) L, Lₜ = L.L1, L.L2 else @@ -68,7 +62,7 @@ function RLBase.update!( end function RLBase.update!( - t::AbstractTrajectory, + t::Any, # not very elegant ::Union{ QBasedPolicy{<:DoubleLearner{<:TDLearner}}, diff --git a/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/dyna_agent.jl b/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/dyna_agent.jl index 45f004572..2ecf39859 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/dyna_agent.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/dyna_agent.jl @@ -34,7 +34,7 @@ end # By default we do nothing function RLBase.update!( ::AbstractEnvironmentModel, - ::AbstractTrajectory, + ::Any, ::AbstractPolicy, ::AbstractEnv, ::AbstractStage, @@ -45,7 +45,7 @@ function RLBase.update!( function RLBase.update!( ::AbstractPolicy, ::AbstractEnvironmentModel, - ::AbstractTrajectory, + ::Any, ::AbstractEnv, ::AbstractStage, ) end diff --git a/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/env_models/experience_based_sampling_model.jl b/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/env_models/experience_based_sampling_model.jl index a3d50e72c..4be766b91 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/env_models/experience_based_sampling_model.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/env_models/experience_based_sampling_model.jl @@ -17,7 +17,7 @@ end function RLBase.update!( m::ExperienceBasedSamplingModel, - t::AbstractTrajectory, + t::Any, ::AbstractPolicy, ::AbstractEnv, ::Union{PreActStage,PostEpisodeStage}, diff --git a/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/env_models/prioritized_sweeping_sampling_model.jl b/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/env_models/prioritized_sweeping_sampling_model.jl index d8852283a..f499ee2da 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/env_models/prioritized_sweeping_sampling_model.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/env_models/prioritized_sweeping_sampling_model.jl @@ -25,7 +25,7 @@ end function RLBase.update!( m::PrioritizedSweepingSamplingModel, - t::AbstractTrajectory, + t::Any, p::AbstractPolicy, ::AbstractEnv, ::Union{PreActStage,PostEpisodeStage}, diff --git a/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/env_models/time_based_sample_model.jl b/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/env_models/time_based_sample_model.jl index ddeb63652..fb8c361bc 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/env_models/time_based_sample_model.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/tabular/dyna_agents/env_models/time_based_sample_model.jl @@ -17,7 +17,7 @@ end function RLBase.update!( m::TimeBasedSamplingModel, - t::AbstractTrajectory, + t::Any, ::AbstractPolicy, ::AbstractEnv, ::Union{PreActStage,PostEpisodeStage}, diff --git a/src/ReinforcementLearningZoo/src/algorithms/tabular/gradient_bandit_learner.jl b/src/ReinforcementLearningZoo/src/algorithms/tabular/gradient_bandit_learner.jl index b11888a80..270ac65b5 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/tabular/gradient_bandit_learner.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/tabular/gradient_bandit_learner.jl @@ -2,7 +2,7 @@ export GradientBanditLearner using Flux: softmax, onehot -Base.@kwdef struct GradientBanditLearner{A,B} <: AbstractLearner +Base.@kwdef struct GradientBanditLearner{A,B} <: Any approximator::A baseline::B end @@ -10,19 +10,9 @@ end (learner::GradientBanditLearner)(s::Int) = s |> learner.approximator |> softmax (learner::GradientBanditLearner)(env::AbstractEnv) = learner(state(env)) -function RLBase.update!( - L::GradientBanditLearner, - t::AbstractTrajectory, - ::AbstractEnv, - ::PreActStage, -) end +function RLBase.update!(L::GradientBanditLearner, t::Any, ::AbstractEnv, ::PreActStage) end -function RLBase.update!( - L::GradientBanditLearner, - t::AbstractTrajectory, - ::AbstractEnv, - ::PostActStage, -) +function RLBase.update!(L::GradientBanditLearner, t::Any, ::AbstractEnv, ::PostActStage) A = L.approximator s, a, r = t[:state][end], t[:action][end], t[:reward][end] probs = s |> A |> softmax @@ -32,7 +22,7 @@ function RLBase.update!( end function RLBase.update!( - t::AbstractTrajectory, + t::Any, ::QBasedPolicy{<:GradientBanditLearner}, ::AbstractEnv, ::PreEpisodeStage, diff --git a/src/ReinforcementLearningZoo/src/algorithms/tabular/linear_approximator.jl b/src/ReinforcementLearningZoo/src/algorithms/tabular/linear_approximator.jl index cfa8d7a47..f26ff5ab2 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/tabular/linear_approximator.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/tabular/linear_approximator.jl @@ -2,7 +2,7 @@ export LinearApproximator, LinearVApproximator, LinearQApproximator using LinearAlgebra: dot -struct LinearApproximator{N,O} <: AbstractApproximator +struct LinearApproximator{N,O} weights::Array{Float64,N} optimizer::O end diff --git a/src/ReinforcementLearningZoo/src/algorithms/tabular/monte_carlo_learner.jl b/src/ReinforcementLearningZoo/src/algorithms/tabular/monte_carlo_learner.jl index f73c29886..46adb062d 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/tabular/monte_carlo_learner.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/tabular/monte_carlo_learner.jl @@ -34,7 +34,7 @@ Use monte carlo method to estimate state value or state-action value. - `sampling=NO_SAMPLING`. Optional values are `NO_SAMPLING`, `WEIGHTED_IMPORTANCE_SAMPLING` or `ORDINARY_IMPORTANCE_SAMPLING`. """ -Base.@kwdef struct MonteCarloLearner{A,K,S} <: AbstractLearner +Base.@kwdef struct MonteCarloLearner{A,K,S} <: Any approximator::A γ::Float64 = 1.0 kind::K = FIRST_VISIT @@ -45,30 +45,25 @@ end (learner::MonteCarloLearner)(s) = learner.approximator(s) (learner::MonteCarloLearner)(s, a) = learner.approximator(s, a) -function RLBase.update!(::VBasedPolicy{<:MonteCarloLearner}, ::AbstractTrajectory) end +function RLBase.update!(::VBasedPolicy{<:MonteCarloLearner}, ::Any) end "Only update at the end of an episode" function RLBase.update!( p::VBasedPolicy{<:MonteCarloLearner}, - t::AbstractTrajectory, + t::Any, ::AbstractEnv, ::PostEpisodeStage, ) update!(p.learner, t) end -function RLBase.update!( - L::MonteCarloLearner, - t::AbstractTrajectory, - e::AbstractEnv, - s::PostEpisodeStage, -) +function RLBase.update!(L::MonteCarloLearner, t::Any, e::AbstractEnv, s::PostEpisodeStage) update!(L, t) end "Empty the trajectory at the end of an episode" function RLBase.update!( - t::AbstractTrajectory, + t::Any, ::Union{ VBasedPolicy{<:MonteCarloLearner}, QBasedPolicy{<:MonteCarloLearner}, @@ -80,7 +75,7 @@ function RLBase.update!( empty!(t) end -function RLBase.update!(L::MonteCarloLearner, t::AbstractTrajectory) +function RLBase.update!(L::MonteCarloLearner, t::Any) _update!(L.kind, L.approximator, L.sampling, L, t) end @@ -89,7 +84,7 @@ function _update!( ::Union{TabularVApproximator,LinearVApproximator}, ::NoSampling, L::MonteCarloLearner, - t::AbstractTrajectory, + t::Any, ) S, R = t[:state], t[:reward] V, G, γ = L.approximator, 0.0, L.γ @@ -110,7 +105,7 @@ function _update!( ::Union{TabularVApproximator,LinearVApproximator}, ::NoSampling, L::MonteCarloLearner, - t::AbstractTrajectory, + t::Any, ) S, R = t[:state], t[:reward] V, G, γ = L.approximator, 0.0, L.γ @@ -126,7 +121,7 @@ function _update!( ::TabularQApproximator, ::NoSampling, L::MonteCarloLearner, - t::AbstractTrajectory, + t::Any, ) S, A, R = t[:state], t[:action], t[:reward] γ, Q, G = L.γ, L.approximator, 0.0 @@ -142,7 +137,7 @@ function _update!( ::TabularQApproximator, ::NoSampling, L::MonteCarloLearner, - t::AbstractTrajectory, + t::Any, ) S, A, R = t[:state], t[:action], t[:reward] γ, Q, G = L.γ, L.approximator, 0.0 @@ -168,7 +163,7 @@ function _update!( }, ::OrdinaryImportanceSampling, L::MonteCarloLearner, - t::AbstractTrajectory, + t::Any, ) S, R, W = t[:state], t[:reward], t[:weight] (V, G), g, γ, ρ = L.approximator, 0.0, L.γ, 1.0 @@ -193,7 +188,7 @@ function _update!( ::Tuple, ::WeightedImportanceSampling, L::MonteCarloLearner, - t::AbstractTrajectory, + t::Any, ) S, R, W = t[:state], t[:reward], t[:weight] (V, G, Ρ), g, γ, ρ = L.approximator, 0.0, L.γ, 1.0 diff --git a/src/ReinforcementLearningZoo/src/algorithms/tabular/td_learner.jl b/src/ReinforcementLearningZoo/src/algorithms/tabular/td_learner.jl index 98fde006f..26ad900cf 100644 --- a/src/ReinforcementLearningZoo/src/algorithms/tabular/td_learner.jl +++ b/src/ReinforcementLearningZoo/src/algorithms/tabular/td_learner.jl @@ -3,7 +3,7 @@ export TDLearner using LinearAlgebra: dot using Distributions: pdf -Base.@kwdef struct TDLearner{A} <: AbstractLearner +Base.@kwdef struct TDLearner{A} <: Any approximator::A γ::Float64 = 1.0 method::Symbol @@ -18,7 +18,7 @@ end function RLBase.update!( p::QBasedPolicy{<:TDLearner}, - t::AbstractTrajectory, + t::Any, e::AbstractEnv, s::AbstractStage, ) @@ -31,16 +31,11 @@ function RLBase.update!( end -function RLBase.update!(L::TDLearner, t::AbstractTrajectory, ::AbstractEnv, s::PreActStage) +function RLBase.update!(L::TDLearner, t::Any, ::AbstractEnv, s::PreActStage) _update!(L, L.approximator, Val(L.method), t, s) end -function RLBase.update!( - L::TDLearner, - t::AbstractTrajectory, - ::AbstractEnv, - s::PostEpisodeStage, -) +function RLBase.update!(L::TDLearner, t::Any, ::AbstractEnv, s::PostEpisodeStage) _update!(L, L.approximator, Val(L.method), t, s) end @@ -57,7 +52,7 @@ end ## update trajectories function RLBase.update!( - t::AbstractTrajectory, + t::Any, ::Union{ QBasedPolicy{<:TDLearner}, NamedPolicy{<:QBasedPolicy{<:TDLearner}}, @@ -131,7 +126,7 @@ function _update!( L::TDLearner, ::Union{TabularQApproximator,LinearQApproximator}, ::Val{:SARS}, - t::AbstractTrajectory, + t::Any, ::PreActStage, ) S = t[:state] @@ -172,7 +167,7 @@ function _update!( L::TDLearner, ::Union{TabularVApproximator,LinearVApproximator}, ::Val{:SRS}, - t::AbstractTrajectory, + t::Any, ::PreActStage, ) S = t[:state] @@ -199,7 +194,7 @@ end function RLBase.update!( p::QBasedPolicy{<:TDLearner}, m::Union{ExperienceBasedSamplingModel,TimeBasedSamplingModel}, - ::AbstractTrajectory, + ::Any, env::AbstractEnv, ::Union{PreActStage,PostEpisodeStage}, ) @@ -220,7 +215,7 @@ end function RLBase.update!( p::QBasedPolicy{<:TDLearner}, m::PrioritizedSweepingSamplingModel, - ::AbstractTrajectory, + ::Any, env::AbstractEnv, ::Union{PreActStage,PostEpisodeStage}, ) @@ -265,7 +260,7 @@ end export TDλReturnLearner -Base.@kwdef struct TDλReturnLearner{Tapp<:AbstractApproximator} <: AbstractLearner +Base.@kwdef struct TDλReturnLearner{Tapp} <: Any approximator::Tapp γ::Float64 = 1.0 λ::Float64 @@ -275,19 +270,9 @@ end (L::TDλReturnLearner)(s) = L.approximator(s) (L::TDλReturnLearner)(s, a) = L.approximator(s, a) -function RLBase.update!( - L::TDλReturnLearner, - t::AbstractTrajectory, - ::AbstractEnv, - ::PreActStage, -) end +function RLBase.update!(L::TDλReturnLearner, t::Any, ::AbstractEnv, ::PreActStage) end -function RLBase.update!( - L::TDλReturnLearner, - t::AbstractTrajectory, - ::AbstractEnv, - ::PostEpisodeStage, -) +function RLBase.update!(L::TDλReturnLearner, t::Any, ::AbstractEnv, ::PostEpisodeStage) λ, γ, V = L.λ, L.γ, L.approximator R = t[:reward] S = @view t[:state][1:end-1] @@ -310,7 +295,7 @@ function RLBase.update!( end function RLBase.update!( - t::AbstractTrajectory, + t::Any, ::VBasedPolicy{<:TDλReturnLearner}, ::AbstractEnv, ::PreEpisodeStage, diff --git a/src/ReinforcementLearningZoo/src/patch.jl b/src/ReinforcementLearningZoo/src/patch.jl deleted file mode 100644 index 7f57b6ff5..000000000 --- a/src/ReinforcementLearningZoo/src/patch.jl +++ /dev/null @@ -1,17 +0,0 @@ -using ReinforcementLearningCore - -using AbstractTrees - -""" - EnrichedAction(action;kwargs...) - -Inject some runtime info into the action -""" -struct EnrichedAction{A,M} - action::A - meta::M -end - -EnrichedAction(action; kwargs...) = EnrichedAction(action, values(kwargs)) - -(env::AbstractEnv)(action::EnrichedAction) = env(action.action) diff --git a/src/ReinforcementLearningZoo/src/utils/utils.jl b/src/ReinforcementLearningZoo/src/utils/utils.jl deleted file mode 100644 index 9fc5ef180..000000000 --- a/src/ReinforcementLearningZoo/src/utils/utils.jl +++ /dev/null @@ -1 +0,0 @@ -include("reward_normalizer.jl") \ No newline at end of file diff --git a/src/ReinforcementLearningZoo/test/runtests.jl b/src/ReinforcementLearningZoo/test/runtests.jl index bc156eb0a..bd10e20c4 100644 --- a/src/ReinforcementLearningZoo/test/runtests.jl +++ b/src/ReinforcementLearningZoo/test/runtests.jl @@ -1,54 +1,5 @@ -using ReinforcementLearningZoo using Test -using ReinforcementLearningBase -using ReinforcementLearningCore -using ReinforcementLearningEnvironments -using Flux -using Statistics -using Random -using StableRNGs -using OpenSpiel - -# used for OpenSpielEnv("kuhn_poker") -function get_optimal_kuhn_policy(α = 0.2) - TabularRandomPolicy( - table = Dict( - "0" => [1 - α, α], - "0pb" => [1.0, 0.0], - "1" => [1.0, 0.0], - "1pb" => [2.0 / 3.0 - α, 1.0 / 3.0 + α], - "2" => [1 - 3 * α, 3 * α], - "2pb" => [0.0, 1.0], - "0p" => [2.0 / 3.0, 1.0 / 3.0], - "0b" => [1.0, 0.0], - "1p" => [1.0, 0.0], - "1b" => [2.0 / 3.0, 1.0 / 3.0], - "2p" => [0.0, 1.0], - "2b" => [0.0, 1.0], - ), - ) -end - -# used for julia version KuhnPokerGame -function get_optimal_kuhn_policy(env::KuhnPokerEnv; α = 0.2) - TabularRandomPolicy( - table = Dict( - (:J,) => [1 - α, α], - (:J, :pass, :bet) => [1.0, 0.0], - (:Q,) => [1.0, 0.0], - (:Q, :pass, :bet) => [2.0 / 3.0 - α, 1.0 / 3.0 + α], - (:K,) => [1 - 3 * α, 3 * α], - (:K, :pass, :bet) => [0.0, 1.0], - (:J, :pass) => [2.0 / 3.0, 1.0 / 3.0], - (:J, :bet) => [1.0, 0.0], - (:Q, :pass) => [1.0, 0.0], - (:Q, :bet) => [2.0 / 3.0, 1.0 / 3.0], - (:K, :pass) => [0.0, 1.0], - (:K, :bet) => [0.0, 1.0], - ), - ) -end @testset "ReinforcementLearningZoo.jl" begin - include("cfr/cfr.jl") + # include("cfr/cfr.jl") end