diff --git a/module3/exo3/Manifest.toml b/module3/exo3/Manifest.toml new file mode 100644 index 0000000000000000000000000000000000000000..79755bd96503f6089768708826f1ac3927919019 --- /dev/null +++ b/module3/exo3/Manifest.toml @@ -0,0 +1,730 @@ +# This file is machine-generated - editing it directly is not advised + +[[AbstractFFTs]] +deps = ["LinearAlgebra"] +git-tree-sha1 = "051c95d6836228d120f5f4b984dd5aba1624f716" +uuid = "621f4979-c628-5d54-868e-fcf4e3e8185c" +version = "0.5.0" + +[[Arpack]] +deps = ["Arpack_jll", "Libdl", "LinearAlgebra"] +git-tree-sha1 = "2ff92b71ba1747c5fdd541f8fc87736d82f40ec9" +uuid = "7d9fca2a-8960-54d3-9f78-7d1dccf2cb97" +version = "0.4.0" + +[[Arpack_jll]] +deps = ["Libdl", "OpenBLAS_jll", "Pkg"] +git-tree-sha1 = "e214a9b9bd1b4e1b4f15b22c0994862b66af7ff7" +uuid = "68821587-b530-5797-8361-c406ea357684" +version = "3.5.0+3" + +[[ArrayInterface]] +deps = ["LinearAlgebra", "Requires", "SparseArrays"] +git-tree-sha1 = "b34d74dc877e6083c4c5c553a685e89e10ea4662" +uuid = "4fba245c-0d91-5ea0-9b3e-6abc04ee57a9" +version = "2.8.3" + +[[ArrayLayouts]] +deps = ["FillArrays", "LinearAlgebra"] +git-tree-sha1 = "f8904599065b57f51715faf6278126f853aef6fc" +uuid = "4c555306-a7a7-4459-81d9-ec55ddd5c99a" +version = "0.2.4" + +[[Base64]] +uuid = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f" + +[[BinaryProvider]] +deps = ["Libdl", "SHA"] +git-tree-sha1 = "5b08ed6036d9d3f0ee6369410b830f8873d4024c" +uuid = "b99e7846-7c00-51b0-8f62-c81ae34c0232" +version = "0.5.8" + +[[Bzip2_jll]] +deps = ["Libdl", "Pkg"] +git-tree-sha1 = "3663bfffede2ef41358b6fc2e1d8a6d50b3c3904" +uuid = "6e34b625-4abd-537c-b88f-471c36dfa7a0" +version = "1.0.6+2" + +[[CSV]] +deps = ["CategoricalArrays", "DataFrames", "Dates", "FilePathsBase", "Mmap", "Parsers", "PooledArrays", "Tables", "Unicode", "WeakRefStrings"] +git-tree-sha1 = "8fe77a5478781d59a9ba17f0ac47dda2be5f8ae7" +uuid = "336ed68f-0bac-5ca0-87d4-7b16caf5d00b" +version = "0.6.1" + +[[CategoricalArrays]] +deps = ["Compat", "DataAPI", "Future", "JSON", "Missings", "Printf", "Reexport", "Statistics", "Unicode"] +git-tree-sha1 = "23d7324164c89638c18f6d7f90d972fa9c4fa9fb" +uuid = "324d7699-5711-5eae-9e2f-1d82baa6b597" +version = "0.7.7" + +[[ColorTypes]] +deps = ["FixedPointNumbers", "Random"] +git-tree-sha1 = "c4c1cca28748906265ed62c788d6fe6f0134d264" +uuid = "3da002f7-5984-5a60-b8a6-cbb66c0b333f" +version = "0.10.0" + +[[Colors]] +deps = ["ColorTypes", "FixedPointNumbers", "InteractiveUtils", "Reexport"] +git-tree-sha1 = "2fdeb981ebcf52cd800ddb6a0aa5eac34153552d" +uuid = "5ae59095-9a9b-59fe-a467-6f913c188581" +version = "0.12.0" + +[[CommonSubexpressions]] +deps = ["Test"] +git-tree-sha1 = "efdaf19ab11c7889334ca247ff4c9f7c322817b0" +uuid = "bbf7d656-a473-5ed7-a52c-81e309532950" +version = "0.2.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 = "0198d18b28c093bef39872a22f1a897218a925f5" +uuid = "34da2185-b29b-5c13-b0c7-acf172513d20" +version = "3.8.0" + +[[CompilerSupportLibraries_jll]] +deps = ["Libdl", "Pkg"] +git-tree-sha1 = "7c4f882c41faa72118841185afc58a2eb00ef612" +uuid = "e66e0078-7015-5450-92f7-15fbd957f2ae" +version = "0.3.3+0" + +[[Contour]] +deps = ["StaticArrays"] +git-tree-sha1 = "6d56f927b33d3820561b8f89d7de311718683846" +uuid = "d38c429a-6771-53c6-b99e-75d170b6e991" +version = "0.5.2" + +[[DataAPI]] +git-tree-sha1 = "674b67f344687a88310213ddfa8a2b3c76cc4252" +uuid = "9a962f9c-6df0-11e9-0e5d-c546b8b5ee8a" +version = "1.1.0" + +[[DataFrames]] +deps = ["CategoricalArrays", "Compat", "DataAPI", "Future", "InvertedIndices", "IteratorInterfaceExtensions", "Missings", "PooledArrays", "Printf", "REPL", "Reexport", "SortingAlgorithms", "Statistics", "TableTraits", "Tables", "Unicode"] +git-tree-sha1 = "7d5bf815cc0b30253e3486e8ce2b93bf9d0faff6" +uuid = "a93c6f00-e57d-5684-b7b6-d8193f3e46c0" +version = "0.20.2" + +[[DataInterpolations]] +deps = ["GaussianProcesses", "LinearAlgebra", "Optim", "RecipesBase", "RecursiveArrayTools", "Reexport"] +git-tree-sha1 = "5faf9a0324cbc3d92c072b8c46f2a7314eea73d2" +uuid = "82cc6244-b520-54b8-b5a6-8a565e85f1d0" +version = "2.0.0" + +[[DataStructures]] +deps = ["InteractiveUtils", "OrderedCollections"] +git-tree-sha1 = "73eb18320fe3ba58790c8b8f6f89420f0a622773" +uuid = "864edb3b-99cc-5e75-8d2d-829cb0a9cfe8" +version = "0.17.11" + +[[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 = "da24935df8e0c6cf28de340b958f6aac88eaa0cc" +uuid = "163ba53b-c6d8-5494-b064-1a9d43ac40c5" +version = "1.0.2" + +[[DiffRules]] +deps = ["NaNMath", "Random", "SpecialFunctions"] +git-tree-sha1 = "eb0c34204c8410888844ada5359ac8b96292cfd1" +uuid = "b552c78f-8df3-52c6-915a-8e097449b14b" +version = "1.0.1" + +[[Distances]] +deps = ["LinearAlgebra", "Statistics"] +git-tree-sha1 = "23717536c81b63e250f682b0e0933769eecd1411" +uuid = "b4f34e82-e78d-54a5-968a-f98e89d6e8f7" +version = "0.8.2" + +[[Distributed]] +deps = ["Random", "Serialization", "Sockets"] +uuid = "8ba89e20-285c-5b6f-9357-94700520ee1b" + +[[Distributions]] +deps = ["FillArrays", "LinearAlgebra", "PDMats", "Printf", "QuadGK", "Random", "SpecialFunctions", "Statistics", "StatsBase", "StatsFuns"] +git-tree-sha1 = "55e1de79bd2c397e048ca47d251f8fa70e530550" +uuid = "31c24e10-a181-5473-b8eb-7969acd0382f" +version = "0.22.6" + +[[DocStringExtensions]] +deps = ["LibGit2", "Markdown", "Pkg", "Test"] +git-tree-sha1 = "88bb0edb352b16608036faadcc071adda068582a" +uuid = "ffbed154-4ef7-542d-bbb7-c09d3a79fcae" +version = "0.8.1" + +[[Documenter]] +deps = ["Base64", "Dates", "DocStringExtensions", "InteractiveUtils", "JSON", "LibGit2", "Logging", "Markdown", "REPL", "Test", "Unicode"] +git-tree-sha1 = "646ebc3db49889ffeb4c36f89e5d82c6a26295ff" +uuid = "e30172f5-a6a5-5a46-863b-614d45cd2de4" +version = "0.24.7" + +[[ElasticArrays]] +git-tree-sha1 = "5b5b7cb8cba44bcf337b8af0a1f3e57c89468660" +uuid = "fdbdab4c-e67f-52f5-8c3f-e7b388dad3d4" +version = "1.0.0" + +[[ElasticPDMats]] +deps = ["LinearAlgebra", "MacroTools", "PDMats", "Test"] +git-tree-sha1 = "c6ac4406d9b4a549f7316fc746f7ccd5f1bcd2cd" +uuid = "2904ab23-551e-5aed-883f-487f97af5226" +version = "0.2.1" + +[[FFMPEG]] +deps = ["FFMPEG_jll"] +git-tree-sha1 = "c82bef6fc01e30d500f588cd01d29bdd44f1924e" +uuid = "c87230d0-a227-11e9-1b43-d7ebe4e7570a" +version = "0.3.0" + +[[FFMPEG_jll]] +deps = ["Bzip2_jll", "FreeType2_jll", "FriBidi_jll", "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 = "814bf7865005bee373521cb49cad46182bec53b4" +uuid = "b22a6f82-2f65-5046-a5b2-351ab43fb4e5" +version = "4.1.0+2" + +[[FastGaussQuadrature]] +deps = ["LinearAlgebra", "SpecialFunctions"] +git-tree-sha1 = "c139e3f4c75dc489a493627c7ee44befc177420f" +uuid = "442a2c76-b920-505d-bb47-c5924d526838" +version = "0.4.2" + +[[FilePathsBase]] +deps = ["Dates", "LinearAlgebra", "Printf", "Test", "UUIDs"] +git-tree-sha1 = "2cd6e2e7965934f72cb80251f760228e2264bab3" +uuid = "48062228-2e41-5def-b9a4-89aafe57970f" +version = "0.7.0" + +[[FillArrays]] +deps = ["LinearAlgebra", "Random", "SparseArrays"] +git-tree-sha1 = "51cc2f9bc4eb9c6c0e81ec2f779d1085583cc956" +uuid = "1a297f60-69ca-5386-bcde-b61e274b549b" +version = "0.8.7" + +[[FiniteDiff]] +deps = ["ArrayInterface", "LinearAlgebra", "Requires", "SparseArrays", "StaticArrays"] +git-tree-sha1 = "f60e5d6944975f7140bde67278e10b6b01fb4f29" +uuid = "6a86dc24-6348-571c-b903-95158fe2bd41" +version = "2.3.0" + +[[FixedPointNumbers]] +git-tree-sha1 = "3ba9ea634d4c8b289d590403b4a06f8e227a6238" +uuid = "53c48c17-4a7d-5ca2-90c5-79b7896eea93" +version = "0.8.0" + +[[ForwardDiff]] +deps = ["CommonSubexpressions", "DiffResults", "DiffRules", "NaNMath", "Random", "SpecialFunctions", "StaticArrays"] +git-tree-sha1 = "869540e4367122fbffaace383a5bdc34d6e5e5ac" +uuid = "f6369f11-7733-5829-9624-2563aa707210" +version = "0.10.10" + +[[FreeType2_jll]] +deps = ["Bzip2_jll", "Libdl", "Pkg", "Zlib_jll"] +git-tree-sha1 = "7d900f32a3788d4eacac2bfa3bf5c770179c8afd" +uuid = "d7e528f0-a631-5988-bf34-fe36492bcfd7" +version = "2.10.1+2" + +[[FriBidi_jll]] +deps = ["Libdl", "Pkg"] +git-tree-sha1 = "e479537bf8a8f060c546553c14fd0633978dda7e" +uuid = "559328eb-81f9-559d-9380-de523a88c83c" +version = "1.0.5+2" + +[[Future]] +deps = ["Random"] +uuid = "9fa8497b-333b-5362-9e8d-4d0656e87820" + +[[GLM]] +deps = ["Distributions", "LinearAlgebra", "Printf", "Random", "Reexport", "SparseArrays", "SpecialFunctions", "Statistics", "StatsBase", "StatsFuns", "StatsModels"] +git-tree-sha1 = "db0ace36f9dbe7b6a7a08434c5921377e9df2c72" +uuid = "38e38edf-8417-5370-95a0-9cbb8c7f171a" +version = "1.3.9" + +[[GR]] +deps = ["Base64", "DelimitedFiles", "LinearAlgebra", "Printf", "Random", "Serialization", "Sockets", "Test", "UUIDs"] +git-tree-sha1 = "7ea6f715b7caa10d7ee16f1cfcd12f3ccc74116a" +uuid = "28b8d3ca-fb5f-59d9-8090-bfdbd6d07a71" +version = "0.48.0" + +[[GaussianProcesses]] +deps = ["Distances", "Distributions", "Documenter", "ElasticArrays", "ElasticPDMats", "FastGaussQuadrature", "ForwardDiff", "LinearAlgebra", "Optim", "PDMats", "Printf", "ProgressMeter", "Random", "RecipesBase", "ScikitLearnBase", "SpecialFunctions", "StaticArrays", "Statistics", "StatsFuns", "Zygote"] +git-tree-sha1 = "105c668971f973b0f1b84931b0d68b94da78e692" +uuid = "891a1506-143c-57d2-908e-e1f8e92e6de9" +version = "0.11.2" + +[[GeometryTypes]] +deps = ["ColorTypes", "FixedPointNumbers", "LinearAlgebra", "StaticArrays"] +git-tree-sha1 = "96fd99cf83b1952a7d8cb54f4c585a648275805a" +uuid = "4d00f742-c7ba-57c2-abde-4428a4b178cb" +version = "0.8.2" + +[[HTTP]] +deps = ["Base64", "Dates", "IniFile", "MbedTLS", "Sockets"] +git-tree-sha1 = "cd60d9a575d3b70c026d7e714212fd4ecf86b4bb" +uuid = "cd3eb016-35fb-5094-929b-558a96fad6f3" +version = "0.8.13" + +[[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 = "1a4355e4b5b50be2311ebb644f34f3306dbd0410" +uuid = "7869d1d1-7146-5819-86e3-90919afe41df" +version = "0.3.1" + +[[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" + +[[InvertedIndices]] +deps = ["Test"] +git-tree-sha1 = "15732c475062348b0165684ffe28e85ea8396afc" +uuid = "41ab1584-1d38-5bbf-9106-f11c6c58b48f" +version = "1.0.0" + +[[IteratorInterfaceExtensions]] +git-tree-sha1 = "a3f24677c21f5bbe9d2a714f95dcd58337fb2856" +uuid = "82899510-4779-5014-852e-03e436cf321d" +version = "1.0.0" + +[[JSON]] +deps = ["Dates", "Mmap", "Parsers", "Unicode"] +git-tree-sha1 = "b34d7cef7b337321e97d22242c3c2b91f476748e" +uuid = "682c06a0-de6a-54ab-a142-c8b1cf79cde6" +version = "0.21.0" + +[[LAME_jll]] +deps = ["Libdl", "Pkg"] +git-tree-sha1 = "a46bff84977753fdba8db3c50db1435bb1eb4288" +uuid = "c1c5ebd0-6772-5130-a774-d5fcae4a789d" +version = "3.100.0+0" + +[[LibGit2]] +deps = ["Printf"] +uuid = "76f85450-5226-5b5a-8eaa-529ad045b433" + +[[LibVPX_jll]] +deps = ["Libdl", "Pkg"] +git-tree-sha1 = "e3549ca9bf35feb9d9d954f4c6a9032e92f46e7c" +uuid = "dd192d2f-8180-539f-9fb4-cc70b1dcf69a" +version = "1.8.1+1" + +[[Libdl]] +uuid = "8f399da3-3557-5675-b5ff-fb832c97cbdb" + +[[LineSearches]] +deps = ["LinearAlgebra", "NLSolversBase", "NaNMath", "Parameters", "Printf", "Test"] +git-tree-sha1 = "54eb90e8dbe745d617c78dee1d6ae95c7f6f5779" +uuid = "d3d80556-e9d4-5f37-9878-2ab0fcc64255" +version = "7.0.1" + +[[LinearAlgebra]] +deps = ["Libdl"] +uuid = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e" + +[[Logging]] +uuid = "56ddb016-857b-54e1-b83d-db4d58db5568" + +[[MacroTools]] +deps = ["Markdown", "Random"] +git-tree-sha1 = "f7d2e3f654af75f01ec49be82c231c382214223a" +uuid = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09" +version = "0.5.5" + +[[Markdown]] +deps = ["Base64"] +uuid = "d6f4376e-aef5-505a-96c1-9c027394607a" + +[[MbedTLS]] +deps = ["Dates", "MbedTLS_jll", "Random", "Sockets"] +git-tree-sha1 = "a9e2221f06b42f56052f43ad7edecb01d0ef5ab4" +uuid = "739be429-bea8-5141-9913-cc70e7f3736d" +version = "1.0.1" + +[[MbedTLS_jll]] +deps = ["Libdl", "Pkg"] +git-tree-sha1 = "066a4467008745eed36dad973ceb66405785a621" +uuid = "c8ffd9c3-330d-5841-b78e-0817d7145fa1" +version = "2.16.0+1" + +[[Measures]] +git-tree-sha1 = "e498ddeee6f9fdb4551ce855a46f54dbd900245f" +uuid = "442fdcdd-2543-5da2-b0f3-8c86c306513e" +version = "0.3.1" + +[[Missings]] +deps = ["DataAPI"] +git-tree-sha1 = "de0a5ce9e5289f27df672ffabef4d1e5861247d5" +uuid = "e1d29d7a-bbdc-5cf2-9ac0-f12de2c33e28" +version = "0.4.3" + +[[Mmap]] +uuid = "a63ad114-7e13-5084-954f-fe012c677804" + +[[Mustache]] +deps = ["Printf", "Tables"] +git-tree-sha1 = "2e11fc5de3a01d23482a257e22009ddaab058d9a" +uuid = "ffc61752-8dc7-55ee-8c37-f3e9cdd09e70" +version = "1.0.2" + +[[NLSolversBase]] +deps = ["DiffResults", "Distributed", "FiniteDiff", "ForwardDiff"] +git-tree-sha1 = "7c4e66c47848562003250f28b579c584e55becc0" +uuid = "d41bc354-129a-5804-8e4c-c37616107c6c" +version = "7.6.1" + +[[NNlib]] +deps = ["BinaryProvider", "Libdl", "LinearAlgebra", "Requires", "Statistics"] +git-tree-sha1 = "d9f196d911f55aeaff11b11f681b135980783824" +uuid = "872c559c-99b0-510c-b3b7-b6c96a88d5cd" +version = "0.6.6" + +[[NaNMath]] +git-tree-sha1 = "928b8ca9b2791081dc71a51c55347c27c618760f" +uuid = "77ba4419-2d1f-58cd-9bb1-8ffee604a2e3" +version = "0.3.3" + +[[Ogg_jll]] +deps = ["Libdl", "Pkg"] +git-tree-sha1 = "f4d4d03c562f40652c0baabd3e4cb2e756e157b7" +uuid = "e7412a2a-1a6e-54c0-be00-318e2571c051" +version = "1.3.3+0" + +[[OpenBLAS_jll]] +deps = ["CompilerSupportLibraries_jll", "Libdl", "Pkg"] +git-tree-sha1 = "2ee3e636e94b9fd95fa8364d5cba2e20dae16609" +uuid = "4536629a-c528-5b80-bd46-f80d51c5b363" +version = "0.3.9+2" + +[[OpenSSL_jll]] +deps = ["Libdl", "Pkg"] +git-tree-sha1 = "d2a6f25262d568b5a7e454cf7ff5066a79d16c7d" +uuid = "458c3c95-2e84-50aa-8efc-19380b2a3a95" +version = "1.1.1+2" + +[[OpenSpecFun_jll]] +deps = ["CompilerSupportLibraries_jll", "Libdl", "Pkg"] +git-tree-sha1 = "d51c416559217d974a1113522d5919235ae67a87" +uuid = "efe28fd5-8261-553b-a9e1-b2916fc3738e" +version = "0.5.3+3" + +[[Optim]] +deps = ["Compat", "FillArrays", "LineSearches", "LinearAlgebra", "NLSolversBase", "NaNMath", "Parameters", "PositiveFactorizations", "Printf", "SparseArrays", "StatsBase"] +git-tree-sha1 = "62054d469d3631960e3f472ceb8624be5b11c34d" +uuid = "429524aa-4258-5aef-a3af-852621145aeb" +version = "0.20.6" + +[[Opus_jll]] +deps = ["Libdl", "Pkg"] +git-tree-sha1 = "c9931bf2fcdb57b48c227395c61ea82603212f7d" +uuid = "91d4177d-7536-5919-b921-800302f37372" +version = "1.3.1+0" + +[[OrderedCollections]] +deps = ["Random", "Serialization", "Test"] +git-tree-sha1 = "c4c13474d23c60d20a67b217f1d7f22a40edf8f1" +uuid = "bac558e1-5e72-5ebc-8fee-abe8a469f55d" +version = "1.1.0" + +[[PDMats]] +deps = ["Arpack", "LinearAlgebra", "SparseArrays", "SuiteSparse", "Test"] +git-tree-sha1 = "2fc6f50ddd959e462f0a2dbc802ddf2a539c6e35" +uuid = "90014a1f-27ba-587c-ab20-58faa44d9150" +version = "0.9.12" + +[[PackageCompiler]] +deps = ["Libdl", "Pkg", "UUIDs"] +git-tree-sha1 = "8989a56e4506b7b6a050f2b912e7856742d6998c" +uuid = "9b87118b-4619-50d2-8e1e-99f35a4d4d9d" +version = "1.1.1" + +[[Parameters]] +deps = ["OrderedCollections"] +git-tree-sha1 = "b62b2558efb1eef1fa44e4be5ff58a515c287e38" +uuid = "d96e819e-fc66-5662-9728-84c9c7592b0a" +version = "0.12.0" + +[[Parsers]] +deps = ["Dates", "Test"] +git-tree-sha1 = "75d07cb840c300084634b4991761886d0d762724" +uuid = "69de0a69-1ddd-5017-9359-2bf0b02dc9f0" +version = "1.0.1" + +[[Pkg]] +deps = ["Dates", "LibGit2", "Libdl", "Logging", "Markdown", "Printf", "REPL", "Random", "SHA", "UUIDs"] +uuid = "44cfe95a-1eb2-52ea-b672-e2afdf69b78f" + +[[PlotThemes]] +deps = ["PlotUtils", "Requires", "Statistics"] +git-tree-sha1 = "87a4ea7f8c350d87d3a8ca9052663b633c0b2722" +uuid = "ccf2f8ad-2431-5c83-bf29-c5338b663b6a" +version = "1.0.3" + +[[PlotUtils]] +deps = ["Colors", "Dates", "Printf", "Random", "Reexport"] +git-tree-sha1 = "51e742162c97d35f714f9611619db6975e19384b" +uuid = "995b91a9-d308-5afd-9ec6-746e21dbc043" +version = "0.6.5" + +[[Plots]] +deps = ["Base64", "Contour", "Dates", "FFMPEG", "FixedPointNumbers", "GR", "GeometryTypes", "JSON", "LinearAlgebra", "Measures", "NaNMath", "Pkg", "PlotThemes", "PlotUtils", "Printf", "REPL", "Random", "RecipesBase", "Reexport", "Requires", "Showoff", "SparseArrays", "Statistics", "StatsBase", "UUIDs"] +git-tree-sha1 = "f226ff9b8e391f6a10891563c370aae8beb5d792" +uuid = "91a5bcdd-55d7-5caf-9e0b-520d859cae80" +version = "0.29.9" + +[[PooledArrays]] +deps = ["DataAPI"] +git-tree-sha1 = "b1333d4eced1826e15adbdf01a4ecaccca9d353c" +uuid = "2dfb63ee-cc39-5dd5-95bd-886bf059d720" +version = "0.5.3" + +[[PositiveFactorizations]] +deps = ["LinearAlgebra", "Test"] +git-tree-sha1 = "127c47b91990c101ee3752291c4f45640eeb03d1" +uuid = "85a6dd25-e78a-55b7-8502-1745935b8125" +version = "0.2.3" + +[[Printf]] +deps = ["Unicode"] +uuid = "de0858da-6303-5e67-8744-51eddeeeb8d7" + +[[ProgressMeter]] +deps = ["Distributed", "Printf"] +git-tree-sha1 = "ea1f4fa0ff5e8b771bf130d87af5b7ef400760bd" +uuid = "92933f4c-e287-5a05-a399-4b506db050ca" +version = "1.2.0" + +[[QuadGK]] +deps = ["DataStructures", "LinearAlgebra"] +git-tree-sha1 = "dc84e810393cfc6294248c9032a9cdacc14a3db4" +uuid = "1fd47b50-473d-5c70-9696-f719f8f3bcdc" +version = "2.3.1" + +[[REPL]] +deps = ["InteractiveUtils", "Markdown", "Sockets"] +uuid = "3fa0cd96-eef1-5676-8a61-b3b8758bbffb" + +[[Random]] +deps = ["Serialization"] +uuid = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c" + +[[RecipesBase]] +git-tree-sha1 = "b4ed4a7f988ea2340017916f7c9e5d7560b52cae" +uuid = "3cdcf5f2-1ef4-517c-9805-6587b60abb01" +version = "0.8.0" + +[[RecursiveArrayTools]] +deps = ["ArrayInterface", "LinearAlgebra", "RecipesBase", "Requires", "StaticArrays", "Statistics", "ZygoteRules"] +git-tree-sha1 = "48a8ce7a8cb156231de0477372dcaa6ada1472ef" +uuid = "731186ca-8d62-57ce-b412-fbd966d074cd" +version = "2.3.1" + +[[Reexport]] +deps = ["Pkg"] +git-tree-sha1 = "7b1d07f411bc8ddb7977ec7f377b97b158514fe0" +uuid = "189a3867-3050-52da-a836-e630ba90ab69" +version = "0.2.0" + +[[Requires]] +deps = ["UUIDs"] +git-tree-sha1 = "d37400976e98018ee840e0ca4f9d20baa231dc6b" +uuid = "ae029012-a4dd-5104-9daa-d747884805df" +version = "1.0.1" + +[[Rmath]] +deps = ["Random", "Rmath_jll"] +git-tree-sha1 = "86c5647b565873641538d8f812c04e4c9dbeb370" +uuid = "79098fc4-a85e-5d69-aa6a-4863f24498fa" +version = "0.6.1" + +[[Rmath_jll]] +deps = ["Libdl", "Pkg"] +git-tree-sha1 = "1660f8fefbf5ab9c67560513131d4e933012fc4b" +uuid = "f50d1b31-88e8-58de-be2c-1cc44531875f" +version = "0.2.2+0" + +[[SHA]] +uuid = "ea8e919c-243c-51af-8825-aaa63cd721ce" + +[[ScikitLearnBase]] +deps = ["LinearAlgebra", "Random", "Statistics"] +git-tree-sha1 = "7877e55c1523a4b336b433da39c8e8c08d2f221f" +uuid = "6e75b9c4-186b-50bd-896f-2d2496a4843e" +version = "0.5.0" + +[[Serialization]] +uuid = "9e88b42a-f829-5b0c-bbe9-9e923198166b" + +[[SharedArrays]] +deps = ["Distributed", "Mmap", "Random", "Serialization"] +uuid = "1a1011a3-84de-559e-8e89-a11a2f7dc383" + +[[ShiftedArrays]] +git-tree-sha1 = "22395afdcf37d6709a5a0766cc4a5ca52cb85ea0" +uuid = "1277b4bf-5013-50f5-be3d-901d8477a67a" +version = "1.0.0" + +[[Showoff]] +deps = ["Dates"] +git-tree-sha1 = "e032c9df551fb23c9f98ae1064de074111b7bc39" +uuid = "992d4aef-0814-514b-bc4d-f2e9a6c4116f" +version = "0.3.1" + +[[Sockets]] +uuid = "6462fe0b-24de-5631-8697-dd941f90decc" + +[[SortingAlgorithms]] +deps = ["DataStructures", "Random", "Test"] +git-tree-sha1 = "03f5898c9959f8115e30bc7226ada7d0df554ddd" +uuid = "a2af1166-a08f-5f64-846c-94a0d3cef48c" +version = "0.3.1" + +[[SparseArrays]] +deps = ["LinearAlgebra", "Random"] +uuid = "2f01184e-e22b-5df5-ae63-d93ebab69eaf" + +[[SpecialFunctions]] +deps = ["OpenSpecFun_jll"] +git-tree-sha1 = "e19b98acb182567bcb7b75bb5d9eedf3a3b5ec6c" +uuid = "276daf66-3868-5448-9aa4-cd146d93841b" +version = "0.10.0" + +[[StaticArrays]] +deps = ["LinearAlgebra", "Random", "Statistics"] +git-tree-sha1 = "5a3bcb6233adabde68ebc97be66e95dcb787424c" +uuid = "90137ffa-7385-5640-81b9-e52037218182" +version = "0.12.1" + +[[Statistics]] +deps = ["LinearAlgebra", "SparseArrays"] +uuid = "10745b16-79ce-11e8-11f9-7d13ad32a3b2" + +[[StatsBase]] +deps = ["DataAPI", "DataStructures", "LinearAlgebra", "Missings", "Printf", "Random", "SortingAlgorithms", "SparseArrays", "Statistics"] +git-tree-sha1 = "19bfcb46245f69ff4013b3df3b977a289852c3a1" +uuid = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91" +version = "0.32.2" + +[[StatsFuns]] +deps = ["Rmath", "SpecialFunctions"] +git-tree-sha1 = "f290ddd5fdedeadd10e961eb3f4d3340f09d030a" +uuid = "4c63d2b9-4356-54db-8cca-17b64c39e42c" +version = "0.9.4" + +[[StatsModels]] +deps = ["DataAPI", "DataStructures", "LinearAlgebra", "ShiftedArrays", "SparseArrays", "StatsBase", "Tables"] +git-tree-sha1 = "5a140e0bf5d92b2c5c0daa0dcefdadbb57c8a7fb" +uuid = "3eaba693-59b7-5ba5-a881-562e759f1c8d" +version = "0.6.11" + +[[SuiteSparse]] +deps = ["Libdl", "LinearAlgebra", "Serialization", "SparseArrays"] +uuid = "4607b0f0-06f3-5cda-b6b1-a6196a1729e9" + +[[TableTraits]] +deps = ["IteratorInterfaceExtensions"] +git-tree-sha1 = "b1ad568ba658d8cbb3b892ed5380a6f3e781a81e" +uuid = "3783bdb8-4a98-5b6b-af9a-565f29a5fe9c" +version = "1.0.0" + +[[Tables]] +deps = ["DataAPI", "DataValueInterfaces", "IteratorInterfaceExtensions", "LinearAlgebra", "TableTraits", "Test"] +git-tree-sha1 = "242b7fde70b8bc6a30d6476adf17ca3cf1ced6ee" +uuid = "bd369af6-aec1-5ad0-b16a-f7cc5008161c" +version = "1.0.3" + +[[Test]] +deps = ["Distributed", "InteractiveUtils", "Logging", "Random"] +uuid = "8dfed614-e22c-5e08-85e1-65c5234f0b40" + +[[UUIDs]] +deps = ["Random", "SHA"] +uuid = "cf7118a7-6976-5b1a-9a39-7adc72f591a4" + +[[Unicode]] +uuid = "4ec0a83e-493e-50e2-b9ac-8f72acf5a8f5" + +[[WeakRefStrings]] +deps = ["DataAPI", "Random", "Test"] +git-tree-sha1 = "28807f85197eaad3cbd2330386fac1dcb9e7e11d" +uuid = "ea10d353-3f73-51f8-a26c-33c1cb351aa5" +version = "0.6.2" + +[[Weave]] +deps = ["Base64", "Dates", "Highlights", "JSON", "Markdown", "Mustache", "Printf", "REPL", "Requires", "Serialization", "YAML"] +git-tree-sha1 = "f4c004ae4ca7200a46fe1b454e11a0c7cec107c4" +uuid = "44d3d7a6-8a23-5bf8-98c5-b353f8df5ec9" +version = "0.9.4" + +[[YAML]] +deps = ["Base64", "Dates", "Printf"] +git-tree-sha1 = "c5e2eaa5ce818c5277388377d592eb4c81f27c00" +uuid = "ddb6d928-2868-570f-bddf-ab3f9cf99eb6" +version = "0.4.0" + +[[Zlib_jll]] +deps = ["Libdl", "Pkg"] +git-tree-sha1 = "2f6c3e15e20e036ee0a0965879b31442b7ec50fa" +uuid = "83775a58-1f1d-513f-b197-d71354ab007a" +version = "1.2.11+9" + +[[Zygote]] +deps = ["AbstractFFTs", "ArrayLayouts", "DiffRules", "FillArrays", "ForwardDiff", "IRTools", "InteractiveUtils", "LinearAlgebra", "MacroTools", "NNlib", "NaNMath", "Random", "Requires", "SpecialFunctions", "Statistics", "ZygoteRules"] +git-tree-sha1 = "014e1f208bd5b43e26448ca31d971053f58bc20a" +uuid = "e88e6eb3-aa80-5325-afca-941959d7151f" +version = "0.4.15" + +[[ZygoteRules]] +deps = ["MacroTools"] +git-tree-sha1 = "b3b4882cc9accf6731a08cc39543fbc6b669dca8" +uuid = "700de1a5-db45-46bc-99cf-38207098b444" +version = "0.2.0" + +[[libass_jll]] +deps = ["Bzip2_jll", "FreeType2_jll", "FriBidi_jll", "Libdl", "Pkg", "Zlib_jll"] +git-tree-sha1 = "d0259e0624e08ae9ebae16c80257caabc25f2048" +uuid = "0ac62f75-1d6f-5e53-bd7c-93b484bb37c0" +version = "0.14.0+1" + +[[libfdk_aac_jll]] +deps = ["Libdl", "Pkg"] +git-tree-sha1 = "0e4ace600c20714a8dd67700c4502714d8473e8e" +uuid = "f638f0a6-7fb0-5443-88ba-1cc74229b280" +version = "0.1.6+1" + +[[libvorbis_jll]] +deps = ["Libdl", "Ogg_jll", "Pkg"] +git-tree-sha1 = "71e54fb89ac3e0344c7185d1876fd96b0f246952" +uuid = "f27f6e37-5d2b-51aa-960f-b287f2bc3b7a" +version = "1.3.6+2" + +[[x264_jll]] +deps = ["Libdl", "Pkg"] +git-tree-sha1 = "23664c0757c3740050ca0e22944c786c165ca25a" +uuid = "1270edf5-f2f9-52d2-97e9-ab00b5d0237a" +version = "2019.5.25+1" + +[[x265_jll]] +deps = ["Libdl", "Pkg"] +git-tree-sha1 = "9345e417084421a8e91373d6196bc58e660eed2a" +uuid = "dfaa095f-4041-5dcd-9319-2fabd8486b76" +version = "3.0.0+0" diff --git a/module3/exo3/Project.toml b/module3/exo3/Project.toml new file mode 100644 index 0000000000000000000000000000000000000000..568e9b65b9d3034a9f88561169810451d4de410b --- /dev/null +++ b/module3/exo3/Project.toml @@ -0,0 +1,14 @@ +name = "Exercice" +uuid = "457123a2-77f0-4d56-a035-49d1b3c810fd" +authors = ["François Févotte"] +version = "0.1.0" + +[deps] +CSV = "336ed68f-0bac-5ca0-87d4-7b16caf5d00b" +DataFrames = "a93c6f00-e57d-5684-b7b6-d8193f3e46c0" +DataInterpolations = "82cc6244-b520-54b8-b5a6-8a565e85f1d0" +GLM = "38e38edf-8417-5370-95a0-9cbb8c7f171a" +HTTP = "cd3eb016-35fb-5094-929b-558a96fad6f3" +PackageCompiler = "9b87118b-4619-50d2-8e1e-99f35a4d4d9d" +Plots = "91a5bcdd-55d7-5caf-9e0b-520d859cae80" +Weave = "44d3d7a6-8a23-5bf8-98c5-b353f8df5ec9" diff --git a/module3/exo3/download.stamp b/module3/exo3/download.stamp new file mode 100644 index 0000000000000000000000000000000000000000..653999bc1cbcf09b27ed7e64e1ae0ce3fd981d3b --- /dev/null +++ b/module3/exo3/download.stamp @@ -0,0 +1 @@ +2020-04-10 \ No newline at end of file diff --git a/module3/exo3/exercice.html b/module3/exo3/exercice.html new file mode 100644 index 0000000000000000000000000000000000000000..28dd2b4d291a9e20ac1b7486466356f7f7ef4a94 --- /dev/null +++ b/module3/exo3/exercice.html @@ -0,0 +1,1268 @@ + + +
+ + +Nous utilisons Julia dans sa version 1.4.0, sur une architecture matérielle de type x86 (64 bits)
+ + ++using InteractiveUtils +versioninfo() ++ + +
+Julia Version 1.4.0 +Commit b8e9a9ecc6 (2020-03-21 16:36 UTC) +Platform Info: + OS: Linux (x86_64-pc-linux-gnu) + CPU: Intel(R) Core(TM) i5-6200U CPU @ 2.30GHz + WORD_SIZE: 64 + LIBM: libopenlibm + LLVM: libLLVM-8.0.1 (ORCJIT, skylake) +Environment: + JULIA_PROJECT = @. ++ + +
Il nous faut maintenant charger l'environnement logiciel de notre étude, c'est à dire toutes les bibliothèques sur lesquelles elle s'appuie, dans les bonnes versions. La liste des dépendances directes est contenue dans le fichier Project.toml
, et complétée par le fichier Manifest.toml
(qui liste toutes les dépendances directes et indirectes, accompagnées de leurs numéros de version précis).
Toutes ces informations permettent au gestionnaire de paquets de re-créer un environnement logiciel identique à celui qui a été utilisé pour développer cette analyse.
+ + ++using Pkg +Pkg.activate(@__DIR__) +Pkg.instantiate() ++ + + +
Tant que nous y sommes, profitons en pour charger dès maintenant les paquets dont nous aurons besoin.
+ + ++import HTTP +import CSV +import DataInterpolations; const DI=DataInterpolations +using GLM +using Printf +using Dates +using DataFrames +using Statistics +using Plots; gr() ++ + + +
Nos données d'entrée proviennent du programme Scripps CO2. Nous fondons l'analyse sur le jeu de données contenant des observations hebdomadaires.
+Le jeu de données est téléchargé une seule fois ; c'est une copie locale qui sert à réaliser l'analyse. Ceci permet de garantir la version des données utilisées pour l'analyse, et stockée dans git aux côtés du présent document.
+Il est possible de forcer le téléchargement en positionnant la variable force_download=true
afin d'actualiser le jeu de données.
+const data_url = "https://scrippsco2.ucsd.edu/assets/data/atmospheric/stations/in_situ_co2/weekly/weekly_in_situ_co2_mlo.csv" +const data_file = "weekly_in_situ_co2_mlo.csv" +const force_download = false ++ + + + +
+if force_download || !isfile(data_file) + println("Downloading data:") + println(" url = $data_url") + println(" file = $data_file") + + open(data_file, "w") do f + req = HTTP.request(:GET, data_url) + @assert req.status == 200 "Error while downloading" + write(f, req.body) + end + + open("download.stamp", "w") do f + write(f, string(today())) + end +else + println("Using local data:") + println(" file = $data_file") + println(" downloaded = ", readline("download.stamp")) +end ++ + +
+Using local data: + file = weekly_in_situ_co2_mlo.csv + downloaded = 2020-04-10 ++ + +
Les données d'entrée sont stockées au format CSV, et contiennent 44 lignes d'informations préliminaires que nous reproduisons ici, et qui seront sautées lors de la lecture des données.
+ + ++skip = 44 +open(data_file) do f + for _ in 1:skip; println(readline(f)); end +end ++ + +
+"-------------------------------------------------------------------------------------------" +" Atmospheric CO2 concentrations (ppm) derived from in situ air measurements " +" at Mauna Loa, Observatory, Hawaii: Latitude 19.5°N Longitude 155.6°W Elevation 3397m " +" " +" Source: R. F. Keeling, S. J. Walker, S. C. Piper and A. F. Bollenbacher " +" Scripps CO2 Program ( http://scrippsco2.ucsd.edu ) " +" Scripps Institution of Oceanography (SIO) " +" University of California " +" La Jolla, California USA 92093-0244 " +" " +" Status of data and correspondence: " +" " +" These data are subject to revision based on recalibration of standard gases. Questions " +" about the data should be directed to Dr. Ralph Keeling (rkeeling@ucsd.edu), Stephen Walker" +" (sjwalker@ucsd.edu) and Stephen Piper (scpiper@ucsd.edu), Scripps CO2 Program. " +" " +" Baseline data in this file through 06-Feb-2020 from archive dated 06-Feb-2020 08:55:31 " +" " +"-------------------------------------------------------------------------------------------" +" " +" Please cite as: " +" " +" C. D. Keeling, S. C. Piper, R. B. Bacastow, M. Wahlen, T. P. Whorf, M. Heimann, and " +" H. A. Meijer, Exchanges of atmospheric CO2 and 13CO2 with the terrestrial biosphere and " +" oceans from 1978 to 2000. I. Global aspects, SIO Reference Series, No. 01-06, Scripps " +" Institution of Oceanography, San Diego, 88 pages, 2001. " +" " +" If it is necessary to cite a peer-reviewed article, please cite as: " +" " +" C. D. Keeling, S. C. Piper, R. B. Bacastow, M. Wahlen, T. P. Whorf, M. Heimann, and " +" H. A. Meijer, Atmospheric CO2 and 13CO2 exchange with the terrestrial biosphere and " +" oceans from 1978 to 2000: observations and carbon cycle implications, pages 83-113, " +" in "A History of Atmospheric CO2 and its effects on Plants, Animals, and Ecosystems", " +" editors, Ehleringer, J.R., T. E. Cerling, M. D. Dearing, Springer Verlag, " +" New York, 2005. " +" " +"-------------------------------------------------------------------------------------------" +" " +" " +" The data file below contains 2 columns indicaing the date and CO2 " +" concentrations in micro-mol CO2 per mole (ppm), reported on the 2008A " +" SIO manometric mole fraction scale. These weekly values have been " +" adjusted to 12:00 hours at middle day of each weekly period as " +" indicated by the date in the first column. " ++ + +
Le fichier est structuré en deux colonnes :
+date
: date de la mesure
val
: concentration en CO2 (en ppm molaires)
+data_raw = CSV.read(data_file; skipto=skip+1, header=[:date, :val]) ++ + + +
L'examen des premières et dernières lignes de données révèle qu'elles couvrent la période de fin mars 1958 jusqu'à nos jours.
+ + + ++info(data_raw) ++ + +
+3156×2 DataFrame +│ Row │ date │ val │ +│ │ Date │ Float64 │ +├──────┼────────────┼─────────┤ +│ 1 │ 1958-03-29 │ 316.19 │ +│ 2 │ 1958-04-05 │ 317.31 │ +│ 3 │ 1958-04-12 │ 317.69 │ +⋮ +│ 3153 │ 2020-01-04 │ 413.19 │ +│ 3154 │ 2020-01-11 │ 413.39 │ +│ 3155 │ 2020-01-25 │ 413.36 │ +│ 3156 │ 2020-02-01 │ 413.99 │ ++ + +
Les relevés étant hebdomadaires, l'écart entre deux dates successives du jeu de données devrait être de 7 jours. Un point manquant provoque un écart de 14 jours, ce qui devrait être rattrappable dans le reste de l'analyse ; au delà, il faudra se poser des questions sur le traitement à apporter.
+ + ++dates = data_raw.date +for i in 2:length(dates) + if dates[i]-dates[i-1] > Dates.Day(14) + println("Missing data: ", + dates[i-1], " - ", dates[i], + " (", dates[i]-dates[i-1], ")") + end +end ++ + +
+Missing data: 1958-05-24 - 1958-07-05 (42 days) +Missing data: 1958-09-06 - 1958-11-08 (63 days) +Missing data: 1962-08-18 - 1962-09-15 (28 days) +Missing data: 1964-01-18 - 1964-05-30 (133 days) +Missing data: 1964-06-06 - 1964-06-27 (21 days) +Missing data: 1966-07-09 - 1966-08-06 (28 days) +Missing data: 1967-01-14 - 1967-02-04 (21 days) +Missing data: 1984-03-24 - 1984-04-28 (35 days) +Missing data: 2003-10-04 - 2003-10-25 (21 days) +Missing data: 2005-02-19 - 2005-03-26 (35 days) +Missing data: 2006-02-04 - 2006-02-25 (21 days) +Missing data: 2012-09-29 - 2012-10-20 (21 days) ++ + +
Il y a 12 périodes durant lesquelles les données sont manquantes, dont une en particulier ayant duré 19 semaines en 1964. Le traitement devra en tenir compte.
+Une visualisation de l'ensemble des données semble montrer une augmentation tendancielle de la concentration en CO2, à laquelle se superpose une oscillation à plus haute fréquence.
+ +Un zoom sur les dernières années laisse penser que le cycle court se produit sur une période annuelle, avec un minimum local atteint chaque année autour du mois d'octobre.
+ +Dans cette analyse, nous allons tenter de séparer ces deux composantes : composante tendancielle "lisse" et composante oscillante de période annuelle.
+La démarche que nous suivons est globalement la suivante : le jeu de données va être découpé en périodes annuelles. Chacune de ces périodes annuelles sera traitée (indépendamment des autres) afin d'en extraire une composante lisse, et une composante périodique.
+Si notre hypothèse est correcte, les composantes périodiques de chaque année devraient être relativement comparables les unes aux autres, et pouvoir être approchées par leur moyenne. On peut ensuite obtenir la composante lisse tendancielle en éliminant la composante oscillatoire moyenne du signal d'origine.
+La périodicité des données (hebdomadaire) n'étant que peu adaptée à un découpage annuel, nous allons commencer par interpoler les données à une maille journalière. Ceci nous permettra de découper le jeu de données en années.
+Il est plus simple d'interpoler entre deux nombres qu'entre deux dates. Dans la suite, nous adopterons une convention selon laquelle chaque date peut être représentée par le nombre de jours qui la sépare de la première mesure :
+ + ++date2num(d::Date) = Dates.value(d - data_raw.date[1]) +num2date(n::Int) = data_raw.date[1] + Day(n) ++ + + +
Par exemple, pour les premières mesures :
+ + +date | date_num | |
---|---|---|
Date | Int64 | |
1 | 1958-03-29 | 0 |
2 | 1958-04-05 | 7 |
3 | 1958-04-12 | 14 |
Afin de comparer des données année par année, nous allons aussi enrichir les données avec de nouvelles représentations de la date : une date peut être décomposée comme un couple (year, day)
dans lequel
year
représente l'année
day
représente l'indice du jour dans l'année (entre 0 et 365).
Dans ce formalisme, le 1er janvier 2020 est représenté par le couple (year=2020, day=0)
. Le 31 décembre 1983 est représenté par le couple (year=1983, day=364)
.
+dayinyear(date::Date) = Dates.value(date - Date(year(date))) +dayinyear(num::Int) = dayinyear(num2date(num)) + +let d = Date("1983-12-31") + year(d), dayinyear(d) +end ++ + +
+(1983, 364) ++ + +
Enfin, prévenons dès maintenant que tout le code de l'analyse fonctionne en présence d'années bissextiles, mais rien n'a été fait pour les traiter à part : l'impact, de l'ordre de 1/365 une année sur 4, a été jugé négligeable a priori.
+On construit un interpolateur linéaire basé sur les mesures de CO2 en fonction de la "date numérique". C'est le paquet Julia DataInterpolations
qui se charge d'effectuer le gros du travail.
+interp = DI.LinearInterpolation(data_raw.val, date2num.(data_raw.date)); ++ + + +
Nous allons profiter de la construction des données interpolées pour gérer le problème des données manquantes : nous n'interpolerons aucune donnée dans les "trous" de 3 semaines ou plus. La construction de ce nouveau jeu de données interpolées est aussi l'occasion d'enrichir les formats de représentation des dates. Nous avons maintenant 5 colonnes dans notre jeu de données interpolé :
+date
: date identifiant le jour de la mesure (ou de la valeur interpolée)
val
: valeur de la mesure de CO2 (ou de l'interpolation)
date_num
: date convertie en nombre
year
: composante de la date identifiant l'année
day
: composante de la date identifiant le jour dans l'année (entre 0 et 365)
+data_interp = DataFrame(date_num=Int[], val=Float64[], date=Date[], year=Int[], day=Int[]) +for i in 2:length(dates) + if dates[i]-dates[i-1] > Dates.Day(14) + # pas d'interpolation : seule la date de gauche est inclue + range = dates[i-1] => dates[i-1] + else + # Interpolation entre le début de la période et + # la fin (exclue car traitée en tant que début de + # la prochaine période) + range = dates[i-1] => dates[i]-Day(1) + end + + # Pour chaque jour dans la période considérée, + # on ajoute une nouvelle ligne de données en interpolant + for date_num in date2num(first(range)):date2num(last(range)) + date = num2date(date_num) + push!(data_interp, (date_num = date_num, + date = date, + year = year(date), + day = dayinyear(date), + val = interp(date_num))) + end +end + +# 3 dernières lignes, pour vérification +last(data_interp, 3) ++ + + +
date_num | val | date | year | day | |
---|---|---|---|---|---|
Int64 | Float64 | Date | Int64 | Int64 | |
1 | 22586 | 413.72 | 2020-01-29 | 2020 | 28 |
2 | 22587 | 413.81 | 2020-01-30 | 2020 | 29 |
3 | 22588 | 413.9 | 2020-01-31 | 2020 | 30 |
En zoomant sur les données interpolées autour de l'une des périodes de données manquantes, on observe bien le résultat attendu : une interpolation linéaire journalière lorsque les données sont disponibles, mais aucune interpolation lorsque les données sont manquantes.
+ +Enfin, nous ne gardons pour notre analyse que des années complètes. D'ailleurs, afin de tester la validité de nos résultats, nous n'allons réaliser l'analyse que sur une fraction des données ; nous garderons les 5 dernières années comme données de test.
+ + ++firstyear = minimum(data_interp.year)+1 +lastyear = maximum(data_interp.year)-6 +idx = (data_interp.year.>=firstyear) .& (data_interp.year.<=lastyear) +data = data_interp[idx, :]; ++ + + +
Les données sur lesquelles portera l'analyse couvrent donc la période 1959-2014.
+ + ++info(data) ++ + +
+20100×5 DataFrame +│ Row │ date_num │ val │ date │ year │ day │ +│ │ Int64 │ Float64 │ Date │ Int64 │ Int64 │ +├───────┼──────────┼─────────┼────────────┼───────┼───────┤ +│ 1 │ 278 │ 315.231 │ 1959-01-01 │ 1959 │ 0 │ +│ 2 │ 279 │ 315.236 │ 1959-01-02 │ 1959 │ 1 │ +│ 3 │ 280 │ 315.24 │ 1959-01-03 │ 1959 │ 2 │ +⋮ +│ 20097 │ 20728 │ 399.14 │ 2014-12-28 │ 2014 │ 361 │ +│ 20098 │ 20729 │ 399.27 │ 2014-12-29 │ 2014 │ 362 │ +│ 20099 │ 20730 │ 399.4 │ 2014-12-30 │ 2014 │ 363 │ +│ 20100 │ 20731 │ 399.53 │ 2014-12-31 │ 2014 │ 364 │ ++ + +
Sur ces années complètes, la composante day
de la date devrait être globalement équirépartie entre 0 et 365, ce qui est globalement le cas. Les données manquantes n'ont donc pas d'impact significatif de ce point de vue là.
Pour chaque année, on commence par tenter d'extraire la composante oscillante de la mesure. En supposant que cette composante est périodique, il faut que la valeur de cette composante en début d'année soit égale à celle de fin d'année. On va aussi supposer que la composante tendancielle varie linéairement en cours d'année. Si on note $C$ la concentration en CO2 et $d$ le jour, on cherche à écrire :
+\[ + \forall d\in{0\ldots365}, \quad + C(d) + = \underbrace{\alpha + \beta d}_{\text{tendance locale}} + + \underbrace{\phi(d)}_{\text{composante oscillante}} +\]
+avec $\phi(0)=\phi(365)$ pour garantir la périodicité de la composante oscillante. Afin de définir la constante $\alpha$ de manière unique, on fixe de plus $\phi(0)=\phi(365)=0$.
+On obtient donc
+\[ +\begin{align*} + \alpha &= C(0), \\[1em] + \beta &= \frac{C(365)-C(0)}{365}, \\[1em] + \phi(d) &= C(d) - \alpha - \beta d. +\end{align*} +\]
+En pratique, plutôt que des valeurs ponctuelles $C(0)$ et $C(365)$, on prend plutôt des valeurs (notées $C_0$ et $C_1$ dans le code) moyennées sur les 7 premiers et 7 derniers jours de l'année.
+ + ++data.phi = copy(data.val) +data.alpha = zero(data.val) +data.beta = zero(data.val) +for year in unique(data.year) + idx = (data.year .== year) + C₀ = data.val[idx .& (data.day .< 7) ] |> mean + C₁ = data.val[idx .& (data.day .> 358)] |> mean + α = C₀ + β = (C₁ - C₀) / 365 + + data.alpha[idx] .= α + data.beta[idx] .= β + data.phi[idx] .-= α .+ β*data.day[idx] +end ++ + + +
Examinons par exemple l'effet de ce traitement sur les données interpolées de l'année 1982. On voit, sur la figure du haut, les mesures brutes ainsi que la tendance locale (affine). Sur la figure du bas, la composante périodique locale vérifie bien les contraintes demandées, avec ses valeurs nulles aux bords.
+ +Pour que notre décomposition soit valide, il faut que les composantes périodiques locales de chaque année se ressemblent, au point de pouvoir être représentées par leur moyenne. Nous calculons donc cette moyenne pour toutes les années du jeu de données d'étude.
+ + ++avg = by(data, :day, :phi=>mean, :phi=>std); ++ + + +
Et nous traçons l'ensemble des composantes oscillantes locales aux côtés de cette moyenne.
+ +Comme on pouvait s'y attendre, il reste une forte variabilité d'année en année. Notons toutefois que l'écart-type, bien qu'important, reste un ordre de grandeur en dessous des valeurs extrêmes, ce qui permet d'espérer que ce profil moyen est suffisamment représentatif pour permettre d'extraire la composante tendancielle lisse des données.
+Nous sommes maintenant prêts à extraire la composante tendancielle des mesures. Il suffit pour cela de retrancher aux données brutes la composante oscillante moyenne.
+ + ++data = join(data, avg, on=:day) +data.smooth = data.val .- data.phi_mean; ++ + + +
Même s'il reste des oscillations locales, nous constatons tout de même que la composante tendancielle est devenue suffisamment lisse pour récupérer une forme de monotonie.
+ +Nous allons maintenant tenter de caractériser la tendance sous-jacente. Au vu de la courbe (concave), nous proposons un modèle quadratique de la forme :
+\[ +C(t) = \alpha + \beta t + \gamma t^2 +\]
+ + ++model = lm(@formula(smooth ~ date_num + date_num^2), + by(data, :year, smooth = :smooth=>mean, date_num = :date_num=>mean)) ++ + +
+StatsModels.TableRegressionModel{LinearModel{GLM.LmResp{Array{Float64,1}},GLM.DensePredChol{Float64,LinearAlgebra.Cholesky{Float64,Array{Float64,2}}}},Array{Float64,2}} + +smooth ~ 1 + date_num + :(date_num ^ 2) + +Coefficients: +─────────────────────────────────────────────────────────────────────────────────────── + Estimate Std. Error t value Pr(>|t|) Lower 95% Upper 95% +─────────────────────────────────────────────────────────────────────────────────────── +(Intercept) 313.862 0.263289 1192.08 <1e-99 313.334 314.39 +date_num 0.00221635 5.77649e-5 38.3685 <1e-39 0.00210049 0.00233221 +date_num ^ 2 9.10059e-8 2.66606e-9 34.135 <1e-37 8.56585e-8 9.63533e-8 +─────────────────────────────────────────────────────────────────────────────────────── ++ + +
Ce genre de modèle semble correspondre assez bien aux données, avec un assez bon niveau de confiance sur l'estimation des paramètres $\alpha$ et $\beta$.
+ + ++α, β, γ = coef(model); +α1, β1, γ1 = coef(model)-2*stderror(model); +α2, β2, γ2 = coef(model)+2*stderror(model); ++ + + +
En première approximation, on a en particulier une hausse tendancielle de la concentration de CO2 atmosphérique de l'ordre de $\beta$ = 2.22e-03 ppm/jour ($\pm$5.21%), qui se traduit en une augmentation annuelle comprise entre 0.77 et 0.85 ppm/an avec un niveau de confiance de 95%.
+On voit toutefois que l'incertitude sur $\beta$ en particulier est de nature à engendrer des
+ ++date_num = date2num(Date(lastyear)):10:date2num(today()+Year(5)) +prediction = DataFrame(date_num=date_num, + date=num2date.(date_num), + day=dayinyear.(date_num)) + +prediction.smooth = predict(model, prediction) +prediction = join(prediction, avg, on=:day) + +prediction.val = prediction.smooth .+ prediction.phi_mean + +idx = data_raw.date .> Date(lastyear) +plot(xlabel="Date", ylabel="CO2 [ppm]", legend=:bottomright) +plot!(data_raw.date[idx], data_raw.val[idx], label="measurements") +plot!(prediction.date, prediction.smooth, label="smooth model") +plot!(prediction.date, prediction.val, label="predicted value") ++ + +
+model = glm(@formula(smooth ~ date_num), + by(data, :year, smooth = :smooth=>mean, date_num = :date_num=>mean), + InverseGaussian(), InverseSquareLink()) ++ + +
+StatsModels.TableRegressionModel{GeneralizedLinearModel{GLM.GlmResp{Array{Float64,1},InverseGaussian{Float64},InverseSquareLink},GLM.DensePredChol{Float64,LinearAlgebra.Cholesky{Float64,Array{Float64,2}}}},Array{Float64,2}} + +smooth ~ 1 + date_num + +Coefficients: +───────────────────────────────────────────────────────────────────────────────────── + Estimate Std. Error z value Pr(>|z|) Lower 95% Upper 95% +───────────────────────────────────────────────────────────────────────────────────── +(Intercept) 1.02817e-5 1.31515e-8 781.789 <1e-99 1.02559e-5 1.03075e-5 +date_num -1.91994e-10 1.0025e-12 -191.515 <1e-99 -1.93959e-10 -1.90029e-10 +───────────────────────────────────────────────────────────────────────────────────── ++ + + +
+closeall() ++ + + + + + + + + + + + + + + +