From e394f374faa6b76ffe9b8416eadce4a9efa8b734 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kristian=20Agas=C3=B8ster=20Haaga?= Date: Sat, 27 Jul 2024 08:28:12 +0200 Subject: [PATCH] Rename package to Associations.jl (#377) * package rename * fix docs build --- LICENSE.md | 2 +- Project.toml | 8 +- README.md | 18 ++- docs/Project.toml | 1 - docs/make.jl | 6 +- docs/src/api/counts_and_probabilities_api.md | 20 ++- docs/src/api/cross_map_api.md | 6 +- .../api/discretization_counts_probs_api.md | 12 +- docs/src/api/information_multivariate_api.md | 14 +- docs/src/assets/logo-dark.png | Bin 9419 -> 0 bytes docs/src/assets/logo-large.png | Bin 21402 -> 0 bytes docs/src/assets/logo.png | Bin 10273 -> 0 bytes docs/src/associations.md | 6 +- docs/src/examples/examples_associations.md | 142 +++++++++--------- docs/src/examples/examples_independence.md | 24 +-- docs/src/examples/examples_infer_graphs.md | 6 +- docs/src/index.md | 40 +++-- src/{CausalityTools.jl => Associations.jl} | 12 +- src/causal_graphs/oce/OCE.jl | 2 +- src/deprecations/predictive_asymmetry.jl | 4 +- src/deprecations/v3/smeasure.jl | 2 +- .../encoding/codify_points.jl | 2 +- .../encoding/codify_variables.jl | 4 +- .../divergences_and_distances/KLDivergence.jl | 2 +- .../RenyiDivergence.jl | 2 +- .../definitions/transferentropy/embedding.jl | 2 +- .../MesnerShalizi.jl | 2 +- .../PoczosSchneiderCMI.jl | 2 +- .../Rahimzamani.jl | 2 +- .../GaoKannanOhViswanath.jl | 2 +- .../mutual_info_estimators/GaoOhViswanath.jl | 2 +- .../mutual_info_estimators/GaussianMI.jl | 2 +- .../estimators/mutual_info_estimators/KSG1.jl | 2 +- .../estimators/mutual_info_estimators/KSG2.jl | 2 +- .../transfer_entropy_estimators/Lindner.jl | 2 +- .../transfer_entropy_estimators/Zhu1.jl | 2 +- test/causal_graphs/oce.jl | 4 +- .../JointDistanceDistributionTest.jl | 2 +- test/independence/LocalPermutationTest/api.jl | 10 +- .../conditional_mutual_information.jl | 2 +- .../distance_correlation.jl | 2 +- .../part_mutual_information.jl | 2 +- .../partial_correlation.jl | 2 +- .../LocalPermutationTest/transferentropy.jl | 2 +- test/independence/PATest.jl | 2 +- .../correlation/distance_correlation.jl | 10 +- .../correlation/partial_correlation.jl | 4 +- test/methods/cross_mappings/ccm_like.jl | 18 +-- .../conditional_entropies/ce_shannon.jl | 6 +- .../conditional_entropies/ce_tsallis_abe.jl | 6 +- .../ce_tsallis_furuichi.jl | 6 +- .../cmi_renyi_jizba.jl | 2 +- .../cmi_renyi_poczos.jl | 6 +- .../cmi_renyi_sarbu.jl | 10 +- .../cmi_shannon.jl | 6 +- .../cmi_tsallis_papetrou.jl | 6 +- test/methods/information/core/counts.jl | 4 +- test/methods/information/core/encoding.jl | 2 +- .../methods/information/core/probabilities.jl | 2 +- .../hellinger_distance.jl | 2 +- .../kl_divergence.jl | 2 +- .../renyi_divergence.jl | 2 +- test/methods/information/estimators/joint.jl | 2 +- test/methods/information/internal_api.jl | 10 +- .../joint_entropies/joint_entropy_renyi.jl | 2 +- .../joint_entropies/joint_entropy_shannon.jl | 2 +- .../joint_entropies/joint_entropy_tsallis.jl | 2 +- .../information/mutual_informations/api.jl | 2 +- .../mutual_informations/mi_renyi_jizba.jl | 2 +- .../mutual_informations/mi_renyi_sarbu.jl | 2 +- .../mutual_informations/mi_shannon.jl | 2 +- .../mi_tsallis_furuichi.jl | 2 +- .../mutual_informations/mi_tsallis_martin.jl | 2 +- .../transfer_entropies/te_renyi_jizba.jl | 2 +- .../transfer_entropies/te_shannon.jl | 4 +- .../information/transfer_entropies/utils.jl | 8 +- test/runtests.jl | 4 +- 77 files changed, 263 insertions(+), 264 deletions(-) delete mode 100644 docs/src/assets/logo-dark.png delete mode 100644 docs/src/assets/logo-large.png delete mode 100644 docs/src/assets/logo.png rename src/{CausalityTools.jl => Associations.jl} (77%) diff --git a/LICENSE.md b/LICENSE.md index b1c412537..2feed387e 100644 --- a/LICENSE.md +++ b/LICENSE.md @@ -1,4 +1,4 @@ -The CausalityTools.jl package is licensed under the MIT "Expat" License: +The Associations.jl package (previously called CausalityTools.jl) is licensed under the MIT "Expat" License: > Copyright (c) 2018: Kristian Agasøster Haaga. > diff --git a/Project.toml b/Project.toml index ea81bf9d8..c1231528d 100644 --- a/Project.toml +++ b/Project.toml @@ -1,8 +1,8 @@ -name = "CausalityTools" -uuid = "5520caf5-2dd7-5c5d-bfcb-a00e56ac49f7" +name = "Associations" +uuid = "614afb3a-e278-4863-8805-9959372b9ec2" authors = ["Kristian Agasøster Haaga ", "Tor Einar Møller ", "George Datseris "] -repo = "https://github.com/kahaaga/CausalityTools.jl.git" -version = "3.0.0" +repo = "https://github.com/kahaaga/Associations.jl.git" +version = "4.0.0" [deps] Accessors = "7d9f7c33-5ae7-4f3b-8dc6-eff91059b697" diff --git a/README.md b/README.md index 00641d835..e83c836e2 100644 --- a/README.md +++ b/README.md @@ -1,15 +1,15 @@ -# CausalityTools +# Associations -[![CI](https://github.com/juliadynamics/CausalityTools.jl/workflows/CI/badge.svg)](https://github.com/JuliaDynamics/CausalityTools.jl/actions) -[![](https://img.shields.io/badge/docs-latest_tagged-blue.svg)](https://juliadynamics.github.io/CausalityTools.jl/stable/) -[![](https://img.shields.io/badge/docs-dev_(master)-blue.svg)](https://juliadynamics.github.io/CausalityTools.jl/dev/) -[![codecov](https://codecov.io/gh/JuliaDynamics/CausalityTools.jl/branch/master/graph/badge.svg?token=0b71n6x6AP)](https://codecov.io/gh/JuliaDynamics/CausalityTools.jl) +[![CI](https://github.com/juliadynamics/Associations.jl/workflows/CI/badge.svg)](https://github.com/JuliaDynamics/Associations.jl/actions) +[![](https://img.shields.io/badge/docs-latest_tagged-blue.svg)](https://juliadynamics.github.io/Associations.jl/stable/) +[![](https://img.shields.io/badge/docs-dev_(master)-blue.svg)](https://juliadynamics.github.io/Associations.jl/dev/) +[![codecov](https://codecov.io/gh/JuliaDynamics/Associations.jl/branch/master/graph/badge.svg?token=0b71n6x6AP)](https://codecov.io/gh/JuliaDynamics/Associations.jl) [![DOI](https://zenodo.org/badge/135443027.svg)](https://zenodo.org/badge/latestdoi/135443027) -CausalityTools.jl is a package for quantifying associations, independence testing and causal inference. +Associations.jl is a package for quantifying associations, independence testing and causal inference. All further information is provided in the -[documentation](https://juliadynamics.github.io/CausalityTools.jl/dev), which you can either +[documentation](https://juliadynamics.github.io/Associations.jl/dev), which you can either find online or build locally by running the `docs/make.jl` file. ## Key features @@ -31,4 +31,6 @@ we also offer ## Installation -To install the package, run `import Pkg; Pkg.add("CausalityTools")`. +To install the package, run `import Pkg; Pkg.add("Associations")`. + +*Previously, this package was called CausalityTools.jl*. \ No newline at end of file diff --git a/docs/Project.toml b/docs/Project.toml index 67bd22a04..8a97c9016 100644 --- a/docs/Project.toml +++ b/docs/Project.toml @@ -1,6 +1,5 @@ [deps] CairoMakie = "13f3f980-e62b-5c42-98c6-ff1f3baf88f0" -CausalityTools = "5520caf5-2dd7-5c5d-bfcb-a00e56ac49f7" ComplexityMeasures = "ab4b797d-85ee-42ba-b621-05d793b346a2" DelayEmbeddings = "5732040d-69e3-5649-938a-b6b4f237613f" Distances = "b4f34e82-e78d-54a5-968a-f98e89d6e8f7" diff --git a/docs/make.jl b/docs/make.jl index 0967aabf2..37f471c1c 100644 --- a/docs/make.jl +++ b/docs/make.jl @@ -6,12 +6,12 @@ using DocumenterInterLinks import Downloads # Packages used in the doc build. -using CausalityTools +using Associations using ComplexityMeasures using StateSpaceSets pages = [ - "CausalityTools.jl" => "index.md", + "Associations.jl" => "index.md", "Core API reference" => [ "Association measures" => "associations.md", "Independence" => "independence.md", @@ -43,7 +43,7 @@ bibliography = CitationBibliography( style=:authoryear ) -build_docs_with_style(pages, CausalityTools, ComplexityMeasures, StateSpaceSets; +build_docs_with_style(pages, Associations, ComplexityMeasures, StateSpaceSets; expandfirst = ["index.md"], bib = bibliography, pages = pages, diff --git a/docs/src/api/counts_and_probabilities_api.md b/docs/src/api/counts_and_probabilities_api.md index 4c1384d2c..794e0cdfe 100644 --- a/docs/src/api/counts_and_probabilities_api.md +++ b/docs/src/api/counts_and_probabilities_api.md @@ -1,17 +1,21 @@ +```@meta +CollapsedDocStrings = true +``` + # [Multivariate counts and probabilities API](@id counts_and_probabilities_api) -For counting and probabilities, CausalityTools.jl extends the single-variable machinery +For counting and probabilities, Associations.jl extends the single-variable machinery in ComplexityMeasures.jl to multiple variables. ```@docs -CausalityTools.Counts -CausalityTools.counts(::OutcomeSpace) +Associations.Counts +Associations.counts(::OutcomeSpace) ``` ```@docs -CausalityTools.Probabilities -CausalityTools.probabilities(::OutcomeSpace) +Associations.Probabilities +Associations.probabilities(::OutcomeSpace) ``` The utility function [`marginal`](@ref) is also useful. @@ -26,7 +30,7 @@ Estimating multivariate counts (contingency matrices) and PMFs is simple. If the we can use [`UniqueElements`](@ref) to simply count the number of occurrences. ```@example counts_probs_tutorial -using CausalityTools +using Associations n = 50 # the number of samples must be the same for each input variable x = rand(["dog", "cat", "snake"], n) y = rand(1:4, n) @@ -46,7 +50,7 @@ For numerical data, we can estimate both counts and probabilities using [`Codify with any count-based [`OutcomeSpace`](@ref). ```@example counts_probs_tutorial -using CausalityTools +using Associations x, y = rand(100), rand(100) discretization = CodifyVariables(BubbleSortSwaps(m = 4)) probabilities(discretization, x, y) @@ -55,7 +59,7 @@ probabilities(discretization, x, y) For more fine-grained control, we can use [`CodifyPoints`](@ref) with one or several [`Encoding`](@ref)s. ```@example counts_probs_tutorial -using CausalityTools +using Associations x, y = StateSpaceSet(rand(1000, 2)), StateSpaceSet(rand(1000, 3)) # min/max of the `rand` call is 0 and 1 diff --git a/docs/src/api/cross_map_api.md b/docs/src/api/cross_map_api.md index 5ef4df070..469280bb7 100644 --- a/docs/src/api/cross_map_api.md +++ b/docs/src/api/cross_map_api.md @@ -40,7 +40,7 @@ Let's reproduce figure 3A too, focusing only on [`ConvergentCrossMapping`](@ref) For this example, they use a bidirectional system with asymmetrical coupling strength. ```@example MAIN_CCM -using CausalityTools +using Associations using Statistics using LabelledArrays using StaticArrays @@ -201,7 +201,7 @@ slightly different embedding. ```@example MAIN_CCM -using CausalityTools +using Associations using Statistics using LabelledArrays using StaticArrays @@ -267,7 +267,7 @@ variables ``X`` and ``Y``, where ``X`` drives ``Y``. After we have computed the PAI in both directions, we define a measure of directionality as the difference between PAI in the ``X \to Y`` direction and in the ``Y \to X`` direction, so that if ``X`` drives ``Y``, then ``\Delta < 0``. ```@example MAIN_CCM -using CausalityTools +using Associations using LabelledArrays using StaticArrays using DynamicalSystemsBase diff --git a/docs/src/api/discretization_counts_probs_api.md b/docs/src/api/discretization_counts_probs_api.md index 9bab7ea3f..d74770b5c 100644 --- a/docs/src/api/discretization_counts_probs_api.md +++ b/docs/src/api/discretization_counts_probs_api.md @@ -12,7 +12,7 @@ When discretizing, what happens is that we "encode" input data into an intermedi - Once a dataset has been encoded into integers, we can estimate [`Counts`](@ref) or [`Probabilities`](@ref) ([tutorial](@ref tutorial_probabilities)). - Once probabilities have been estimated, one can use these to estimate [`MultivariateInformationMeasure`](@ref) ([tutorial](@ref tutorial_infomeasures)). - The following functions and types are used by CausalityTools.jl to perform discretization of input data. + The following functions and types are used by Associations.jl to perform discretization of input data. ```@docs Discretization @@ -21,7 +21,7 @@ CodifyPoints codify ``` -In summary, the two main ways of discretizing data in CausalityTools are as follows. +In summary, the two main ways of discretizing data in Associations are as follows. - The [`CodifyPoints`](@ref) discretization scheme encodes input data on a point-by-point basis by applying some [`Encoding`](@ref) to each point. @@ -66,7 +66,7 @@ We'll here use the [`OrdinalPatternEncoding`](@ref) with differing parameter `m` multiple [`StateSpaceSet`](@ref) of differing dimensions. ```@example example_encode_points -using CausalityTools +using Associations using StateSpaceSets using Random; rng = Xoshiro(1234) @@ -128,7 +128,7 @@ Some [`OutcomeSpace`](@ref)s dictate a sliding window which has the width of one when used with [`CodifyVariables`](@ref). [`ValueBinning`](@ref) is such an outcome space. ```@example example_encode_vars -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, 100) @@ -150,7 +150,7 @@ end of each input variable are lost. For example, with [`OrdinalPatterns`](@ref) of encoded points decrease with the embedding parameter `m`. ```@example example_encode_vars -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, 100) @@ -163,7 +163,7 @@ the same outcome space, as long as the operation will result in the *same* numbe data points for each column. ```@example example_encode_vars -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, 100) diff --git a/docs/src/api/information_multivariate_api.md b/docs/src/api/information_multivariate_api.md index 8c5065683..1d79b3185 100644 --- a/docs/src/api/information_multivariate_api.md +++ b/docs/src/api/information_multivariate_api.md @@ -60,7 +60,7 @@ Amplitude ## [A small tutorial](@id tutorial_infomeasures) -CausalityTools.jl extends the single-variate information API in +Associations.jl extends the single-variate information API in [ComplexityMeasures.jl](https://github.com/JuliaDynamics/ComplexityMeasures.jl) to information measures of multiple variables. @@ -115,7 +115,7 @@ expressed as a function of a joint pmf, we can use the [`JointProbabilities`](@r estimator. ```@example INFO_TUTORIAL -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x, y = rand(rng, 1000), rand(rng, 1000) @@ -143,7 +143,7 @@ they are functions of a joint pmf, and can therefore also be estimated using the with 3 bins along each dimension to discretize the data. ```@example INFO_TUTORIAL -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x, y = randn(rng, 1000), randn(rng, 1000) @@ -161,7 +161,7 @@ entropies are functionals of a joint pmf, so we can still use the based discretization. ```@example INFO_TUTORIAL -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x, y = randn(rng, 1000), randn(rng, 1000) @@ -179,7 +179,7 @@ example, one can use dedicated [`MutualInformationEstimator`](@ref)s such as [`KraskovStögbauerGrassberger2`](@ref) or [`GaussianMI`](@ref): ```@example INFO_TUTORIAL -using CausalityTools +using Associations using StateSpaceSets # We'll construct two state space sets, to illustrate how we can discretize # multidimensional inputs using `CodifyPoints`. @@ -228,7 +228,7 @@ with any count-based [`OutcomeSpace`](@ref). Here, we'll estimate [`MIShannon`]( one type of encoding for the first variable, and another type of encoding for the second variable. ```@example counts_probs_tutorial -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x, y = rand(rng, 100), rand(rng, 100) @@ -248,7 +248,7 @@ For more fine-grained control than [`CodifyVariables`](@ref) can offer, we can u data by discretizing each input variable in arbitrary ways. ```@example counts_probs_tutorial -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x, y = StateSpaceSet(rand(rng, 1000, 2)), StateSpaceSet(rand(rng, 1000, 3)) diff --git a/docs/src/assets/logo-dark.png b/docs/src/assets/logo-dark.png deleted file mode 100644 index b187efd64670e0add6dd109a6da00ba22fbe62c5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9419 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 diff --git a/docs/src/assets/logo-large.png b/docs/src/assets/logo-large.png deleted file mode 100644 index 3be08eec6ba6bbd52da335df9703c1c4c46cf2c7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 21402 zcmb5VXE>Zu*EW1HfKd1~1O7M)RC(Ei{pDhg+LyWH8OJb70FV2P&6cPlyO`hrs zCKB@Zz|^Q|sylXnez3j$(2MNx>f0|qYhjcXr&u?)tvm1BJO_lv$Da^M<$OpUofr=! zW?%x`S2e{ARaQS7EP1z{UKf5x_-2cz#&+rZ{ea*XH~t0xJ%iuazDwwzx{Kx**kF2{ z_mc0Nl%Cfav(CH^ni#kTSJl@7fFLda2!90tC*WJ*{{X;G7ywqE0)Wgr0HF8G{;CHB zKe%S6p#lRguYTS)7bkL9D!-_-mDb*yJRwcc++YP_B9p1gY#_&eONlf@BIaKbwR#Vl7 zd(0dWkVXhcxZl3#75#3JG|@ zLU#Jo!Rj6he2Tk8;?%YU>20d5+=ASJ1mS;vPrEbtA1zU%?%==U$}1W=Ho(6)F)mItub@*-~3#4uOlxfoaLgo z)Zq1u8<*m2n>rl8EG*s}uY&zP`D;Z&+DI-&}sbqOPbf>-G6%&zp5`m?N z?JXBkBn$E<;NbB3=WTnpv9=_h*Vk_IJ)-Byf@{2_x)=Q9 zcJ@U^Ks=-s}?t%{VtIx9Y(rDvhE{7WNW2*nFUt38A`0~T9h#X2l zDkmuF9$CaavhPJet0`=9^cV=YC<(ZFC*qze{=a|8P|*LpCX0Y1{^y?~?qNCp`w^Do zf1mw7eChw;U$Gp>C%R_K44$1*xG|3ICgr2<^jGKeIk?2QMt3$wfkwo$k^S^D z<=UAZj`l_0emAuUZm`);|HZ1_m4P5a!6(r7oKR|kuotk{7eC*3Hb^)|TXiKIjf1x< zx6bigBXU0D7V8P3Z_kfRWRafsD^OTHff@dLl~Ceh<~PDvk#Ni3K!^q=RG6P{Cj<+* z32^!QKvkMyZx=QO&R?eMxa!it*_}gjy-IsSU?VV}P|xr2e&ZCRKap#VhH@c)OD{@x zOIP3d#Fl#F7XP|dCN$EPYOhYL$(ZY!19VAF8BA|${ z^&8cWTGyYOfM;nwPt=eu=X&4v-*(FN)xxR2i_LB8KUB<)&I^Rt_D||k>uB=ISoXUN z+Lh1c{#Cfiz1_T~mOIL5u-nsk)A_9Pnt02UYvXCvdM8e-BwB=$Ctl^(kG03%lAC7* zNurxl++v;gwvAUaR`ys&iR=HN0uZk-E(+|hOozK_AFAO6y|73VHo(_HJ z!r{tk+$#*24nI;m+F<)g07;UehB*P5EyI<`9>bm~u?6-qxgJwZ8euGSrm-ZZ!K zYg^px9{ysZ6cJB9#8YegbcMQm=b~gS(yn(ZQPTOw^@DfXzs1~mfWE%uNx!gJfmBE- zf8Q_tK#t$K|wE=lIZ9$j#%+gz2yWJNiEkM zaBY{t2No~hxs)m_nOolV3$?iGC$OtxRbCFS+$w`hhbfO7qkoAcysTfFeJUKt!>-Nu zadw3g`u?xh+XcV3nDG$>B~G16Erpc%?)}Fd`mm7e)ROn-#C?m^@GwS;-5Ak)PUD4p zwiC>?xZe^bJNDG#Rp4y<+;nMbILt$|VOo7IKX1>7IidwTe$Fv_o6Xbf%?lio*yNWq z*pm$U>7@Otn_}~;1b1Q0xroVEnI-q7yB8%c&VGIS_MmM_v`(tWQ<7MZ-_G+)_zJVL zMj%(7P_VLB>e1S>G0hRHS(9QZif8E3F(XH=@`^^IGz{Gns>esUbj~+y+PMQPnZUI{at)wT7&k0)T zre_{@<%@NIKAYNkt^a~L4YOVA5}%zVvP2Tj1)Ch|7k|5uwBQw85}yF>tLb;oIDdl+ zf}g_<*SyVX&Q#lRc1^r$?Cn$Mot49KAy!zyFw+s7^P3n?VAh!k4%ZlKMNi%Gj&F+Y zj+nl5`*F+K<8(hFqtw(?BC4v<_akmZ;gVun%pZ8v8+L!ivk1O&l|c)yftz;13=O3*mrnl|aj z8)9x}J5h`N{4Z2@`Fw3!>`5$t;QX5(qarx}#~I^hcYQ+P+6xJ?IkE*ZOXJVpn|BfO zDZFA8VQ6Gd*XW^vLD{G;Kjf8Xypev4I)r2Dwl+2>3RxG(rj2df*0wk!Wl7cWs(A0e zUt?4boqyiuB^s(J3>tBBmQO@7<4bg8 z8^>FQn@f~2LB>q~aE#vn{jj_&NCa4?)$+-AGJl7SbQS=ly1`CKdU$Js=!xX5l;$g$wt&d&%w0Nmh*}E zOvIt=Z3ND#d0KLA_y^~*X;I?7)3{m0P?HnjDHX2??*GsB{VWMfa?cKq8@=6D1*KEM zew)Z{IN9*{4R>zusEv`asibk-@dT}_1^oMffDa0r{ z+wQ33m{7zFo4@EA)rYp7%9lx+Jj=-ilgh}$efOK1!-C|*gxy1*A;|oZO7XiWC<^21 zm{k-%NNf6{0SpGk^cveTpN6wI(!4n@pz$N$z0B6vBd;O=p{$9d>ErD%D!FCC4^9(1 z1LZN(SaEUjV&8_E%Hc>yIk&ibSGWLzw$_*wyr(J4ZhqElM`2xjlX3FLJdyc##ezCv z!^8mj2WdaQyfdhsQr=4=cl~Z^yyJ)^P}+FbWg7XE)`Rw@+7*@vYFLQZVM*x zix%TC)*hFS?s;p^&Me>}B@L*hglik!OD4ZmWkZbiWEr)|sO+dKQ@GZe+9|cIQT3n3nb7sK`3MM_hgx*~K@%4Q`ZH~Zifj20 zwr(J$7^x-6HI-fzd+;FQMEo-{jKG~I8!qx204V+ZguC2@cfzcHPb~wjie+WF>4ju0 zlmI3BToWKn3DgIeR1sfgX}-9spI3QV41vj|03=tO0*ompaRR_L34Gn-Yg{Ii#9-9I z3ibzEpD$aJ3{{ok`%A%pa~=*pm46M0+`d%oIy{K+hAeMw4&oB|LF;75XNk~3u%cal zcM>=649#f}`~NDc;6b<0;>(yO|3*hXsIg z=~qA^pEb8J440LaRX-rBu z|648Cfj4}qE;$XAo4IITsR6S|oF1Da%YCX&3rC~2HP25=DbNXPg*oXS_9X7J`5Y7S zPYzjdzc!b_4<>hg+!jabLmOsuJ~@q#u~Tk_$c6W_Gu&WpV~AZ9@-(n92R;)3mHkzD zZrq4FckToev>v%GRyH~E0v&ghq)o*L$$`Tdm|abh9B@>VGVd#>#%hBnwqF~ALT3^d z7tali_HU!0a1ib&CoH%Lz^dUi2|~obm#p}xkCQMZYkt<>;j(1Yhbkj=NYM>Uf%D|C z3Vl%7!6h;4I0b|PZ32(8x(>MPp3RNFMh;4`B*+CtF7U=wC(8HdB!*39mhM?am8^3j zzkCD^_bXgE;vk4QR1~s6>P3S{`svU9y6I!)eCY^1kxmBwA)^^81))RjV^A+8fyFW`M6hNY1;-=5?}m z!45^c3Lq#)G`GFH=QiR>cAWf^Fi5(*c8xj9VzEt!qRF~J&40`nkl1fFS$jLj2^rNU zcLjEK{71}1>|?_JRm^FQagm1-Et6@E=DO_IFwx&pzqTi|gv{kfWELIc`3-Rt*4=8y z@4^OuRx+#M@!W`$fPJCtgBMTd4rd`RxA2S*L>ICo`c%pwdu^SjQ$y3uG0S*5SH!`( zpExhW8)thqri_<~Gcb5I$mTcQTkdMB(B>m~3a>QFj)(M8NCdwxrv1yMkOqlOS@;2^ zN;czf88p6U%rJ#;;l>h$zhHbDQwRuO2XcY%Zh~1Ym}Q$8kzWMC%NM`iFSx37^p9zC zIPCtc`>;Sl<)v4w_|b;`IxE|fw^dw~ftGof7vFNGdCcCY>c)l6%N#_z(iyXbnzaSC zMx4>0v?MyXFGW^XBiF2YIZz!=7c;Bz#d}0@8XYG~Go5hqsHZjmnwbKyM6gNS7G%BZu2WCCndboE9X6ZqoJ9f+h zX82*T{(@ruvEM5m!`EIQv)?`Lq9)mcv@0$(?lPd!>f!L|wTNZg!bY#oNT9 ziwn|tY zb6zr6Vpf~3BeePVi{JVy8Q?-N`=sDS`Lg_EzJjWU zvFX5AWkj*gSXjH-P0oa zQNYtcg4z13)L=j1p`RGIL3=X^T4S>ZW0wOjR7$n2r{&Z_9s+rZ}OW@;~jt-ml-dH}X5#e|b{LgokHN#`MI zW^ca;prG?yNX8c78ZMKL^f%H;hK5S=ZS~5?;a=}3g<-9E?p2e5Oo9;}0(^5N-B}PbdOCoE#LBo9L&1;cS|uVrFnJgi=Xa?Lsb+qbS~*)}#+PH`*4Gz5Dr=SMeP@Yz06 z;;uG4BkgZwb(JWv6VW|AJp@6iaZJFGI51hM5V%G#`@G9k*Jw2F-rRl61$9N8Q}MGO zaaE+S_N}(3+hXODCUPX&*8v`2TSJal#f^q08G06O1Tt)F%1 zl5@YTvhaAxmRO&Psd{0ja8k{0X} zacdiiNDZl(Dn1f)TW4djQ!GYo!+OV#lY4dl^-WHX`^%ZuG=a~V(wbR$5R8lNhmN@} zyxf_Guj7kdB%ig^-*2bz+hr#d+S1tI2?Vw&V3s*sb=TyK@G$GMY%9Y>M9i7t{W(bz zQ^hAJ697A`5FE!C9ZN7vJs@}9tdy&DP-#`(sW1!MrTZhC*&s77PQo20u^o3CydMPd z-5d89f6*SjB=C7y@Z_&uMgr1qfX!@i!H z5|6aNx^RluYIt&Pgu!+_HXVe6dcG8r+UO7cPmJA%@)Oz~6QSP+KJIstR? zsNgR-KYKNf2r~E?wDDcPgpCYY*G5?v6AeF-@w3-R92sUkw>EZmMRqOijyFzMCmnho zQkTER&=l0jJ|`MiRZ!jhU#J*jG&}Vaf*?Ub&v!5Tk8{so4htzP*D5%DNH1zGcB#9b zPBDVkns6-hH(uHg+_`&~=6)7$utXZ>(_&>#Qq}$Ro!^UB`BNeVlbY@HPm;oamjSLo z6F645u|2D2v~LHqOfP)ZM-mPJ!87m{2v1Sn7@uZG1VJ`freoi6%Z#OPmY0@FD?KC9 zq|a-h0q6)@gMn>+K#Z`J8a-5Z#n?j-O*u`ssV!<~o57+&eXjDwtkG zawuE4J~WceNoNChhr5LAmtTUx5-8~KLgjGE#zb}xebzcBVt^!jZA|>^{&Mu|mY2LQ z(;W(pNZ;r4oCC84kEu<&7@FE1sb7ocW^C5N`<~pJyAyH8AdJ?QM!O6IByxrA6WScq&Dq`R3HetWTY@eA*s>b-6qP09WdxzuSS5FJ2_K4vf{{p-XD`m~9Rn zqtVDf+4r(x%TzmvCZqKgUKF<)YJ@6V*!&T`-lB~BP3AkkpG#KM;)2N$ciyb-3^)+y zBeKT*(dO=%{?rW{dduTI$oZf7exDt$^8tYa>O_$ZbT@!piN7yhV-`pv+lB+@?4Bti zQ#o}!+V2w1ujII298|epBtV4Fs6$5r&VM8W&5b%Jh?-tX=)*!S!tfR2kPrJ1Z26&F z13FjmHMf=pyZKzroQ8D>mxp9U?$2XCee`z`ewm{mt0g`atz2<_zs>WOGuzAEhwA@+ zM;PeIn(EM3Tk7ud8!X+R{_s$5CDB_>;=<;IZWBQNb&a^8O%?8NN*TNr5Zsfh& zI-obj*9WARbqj)p91Zz?^KZ%BXJ5Ns>s!2zP0E&-Q3gZ&5JeZ7HabqcB)T6&t-Etv zatT{hRG6*R)UIUJX7X5trL&4hVjd<}lrU5Nawac(;Hb#5uSd?vw|{rzkoyrXrF6uE zFX!@{^!BTHsb4)%<9Fi|q0CCbB5>DT|?(8D( zvD2)Ech9`4LD|^d2M$g9iWfw>^0O}jzlA3j$Rnj<8{l*RlW2TJh$Er`1yXG zctDw(3@ax9T1^1YK-O{3nhQp@SpKqQY+R93q?Y6G6H#!#2zgWtv1vMP6%Zb7XA;Jj zu94_Zu#9%jXf4JmbiS%T$MIv!OG^G|Jen;RV8zb6y*pM$eUv8&VV!Dg9Ee7K5iyv0 zR^HMVl)rGrdtY7?kT(#{ZxGGrqPxST)#Fk@El{OiV&%r!XU#eFfHiggP4; z*!3v@$-_@%joWEt$}9m!i2)aF`k-+e7*$^;J?T)?j5|5AF>v}P_ zPb4&BQM_BX{XpVbaxYquEr`UW&zlp(GA{wopoH_ox2;m+4YA*XvpC)aEdQyr0a~>O z9BxPk4&2OM3u)^?bx*A8{|oT}9mDatU1pe?3(Lp9-*zN@(>$c2L{}VSr-LfLLftmR_ zHJY&=D0|osr|u&6i%mvtHt|K_X+vtn(>N>p?M^wJ*=&2dG)xj9yr%T+AO|djPor(( z*`hijh+QCRsIIbT4W^Nf=U!Fn>#jdD-KxyO%#Et2RT%Fa| zM(1;02;U28DuY+5TKY+MRb#a-J-OOc==%XZvO zKgo@&(k;5l27K1lONkV%-DlNq@-Hb1s(L&$#SE~DQ4M_(=V8F?R*;0}G5_lhLmpW~ z>Lt1mTf=O8HS^%L?zZ$vW0eUn{D*aHU#{pp_jEiQ?KJXr#W99>>Ck>@@L_-#o9p2t zK)Mj~@A(HwYo|=(oWcdOpq>hDja-PDKIEtAT|JtKIMv^jNzEPK`2+rjQ4ihLV0X5Q z{X1wxGm~J%q?1bKqO_Mk;B`&uYP&XevH6ABTSvf`Z-=4g*(%zzOvE=sTrQsi;X`91 z5R&jq!d5iF?8kwo>vxn^x*25E6Q!Do0T-oSWBb7CQY05)VIX6vvha1kT0M^$bC7-m zQ+w-23jRYuHoIMDQOW~rbi+46tY}T(b?bJg<=IX42ISGH=3Irz{bNobg!^ZL-W1uK z9`r8|UYAce$iNKwd=0&OeCe<)>yzx5a-G_v*T2E71)`%65c}vGNNhAcG)gKdD;sB{ zR$2U&cEA=vn1%c*Bgl>AtN!Oi^MKtvM3F8Z*YX&y5t(Vqs7DhEb_BE|>GHs*HemQd zgSIff>g*(cJ<5Eu{;K-i=lK+xOPi~(`ktTu%&H^SCN4JD#l+&K+4AidBgd(iB0D)> zz&_gU>N}Sfki>W3@jg@}_RuyO5&v;(YJwiP$ZQXK=f7eRgDl^FQDbeBY^(kyQI%Jq zSs*@6Bw)F;8!S~`T|7DQNZYWOGLq}RF@%Y_nH?+$fXr@yW2SKh1>Wt%cWIJkb5J}x z{b!(chAg1EO5MRHrd1Avm+yC;`jB*Y(<$j)d+ykt6|wB}q(fhB#V_yHc?cQ24~^dH zeZIc&sAK*n?7KEi^eaE9dcsy;An^ACR5wFY&!f}gmE#*|kktd>(QUw;AlyWT>>|OE zB8y`EWFv&Xx9~Q(S}tOQbdHlfl{3b_WJhOB1sd=LW*WRIvHGc3dr!u&7bz`i+-=FX z|6@`Tj6yFJR?Yt*f*fY~bSYG#TBJ1V-w9RZOs7i4#nTOes|@Ws^J6*DS$BTRTx%Olk3(w@Sf@1D z*G2qfTOeSgFf2W5eQ|4BCC9@MYHru7B^ydGJ7$L^1E75RB!qx97S2o;3k!`KId~R# z{vh%EK%D(T6fDsTULUuh4VuP{CX_~eG+8IAo_wx=bE>&UrC5J;FSp`EpQ|LdAt6HK z=!|J)4ix& zxYl&&X4CaYj=fG*DAakHHb$|D`3wZRfDCqQf7zL*1g#i`ePKSj^Q8+o$4XSto|lWlz0PvVZ! zcK(2eigHe!K0$IjJ+0i$9}!U1Rtvz>R?uxYz&~NoKA98|G1_t`28FF zJe%Ul<;66=Vlla$!IQ2zsoCjjl z*Zd_A4A|BF)%37#YD9u(e=lkonosW3F-*HGc;M~9B$tRptpd-hh6SZ ztF3}2;NGw4=UGT>OJ-60PmVGXAka)_ zaaR~PyAHTt3ojSfDhG9^d;hKr8QliXP!P0(u*5cgh_YnImRdYaF_MXmerOI2Di@-` z_ShDZ?uAf(*9_8eCmn2nz6=rw^9y|%k^Xyp@!ZPX4K>TTdp8`P7?1|)U1UMg(86ko zOY;Xmf05+@u#(7BSYood>%(gV*O|)Olz&VGyXfQ@4w~)nJo&4LQrV*mw1+9_r{4)t zQ_2|$SUB3%+3wCR&*@FN%H(t06O_uITcM022Q08HnN=lFuw*B>r=^o6>Ke$TjZ&dH=8lS^ z+R{K+epdwLQ-5fIKuCKp+`ir~Tn$h5gvH26=URBQ8QC;f7enFa`=Ej=3<7IKyzFod z1X}>Fa=O-908fuwyr0|)tRdj1Eh;)LK8cUi@6)TXK3*UN>Bd2kOg~nfrV|$Y6lo0> z<3x<`Z#0@;Dyu#nTt0;VXp6tJoK6t~8O<@ogGKb#!y{+#nP z7dh~S9yl1KAaq@S&acxj@rDPy$9K!IvA2sdd6&{)(+$+Su?K*1h!|uZMab60Er8pP zsW-rX=S6_8iFfjq@(tU&myZwvJBPNrSJ#h8u%>|C-_FSzVBlL@WwAyFcmVH)4f5AP z86J!p0yb_%yEfB;9z8KaLG#}k8XMnw8aEY*%#xaE5(hjvJOVyh4}U%Pcy45DtnVZY z4hIFb#cB|>4hH}9OJ1N>BA|95_OIM})WHq5G5T5&#bBY(^)5Xq102h&+B6pkI1&)s z;IPX|MZ9S(R-%r_3(zvoG=^^Wexk4!>Q9Ysog1l{sHpb2UH^Fl#;9LN>rM7Re{= z-M|QJn$X%StcruN1m#&9*{a$9{R-0hWs%b;Ae_h%AWOZ&*u+iE4PFYg zO1|WesWIeHW$Va#RA$l5BG&)N4^hzX-@%Yb#hyT;8eL6Ht)iCl`_=z{^R@h9*s(Z! z<*a7EyKS7@&xv2R|7QTQhDOZ{fIcCw9#>h}3C*g=|4c;l9+lKBz?#l9;7}a6QSiSv zx$12Y%xc3XeJi+?t|GAtkxMBzZpFmzcVAf1YFX7|=evkM+UWjS^+N1-# zfAznH5e+%oCZgW41^#p;HF+????>zB|3|tBn&*mM9R)sT(=<=?Fu42_+W=M{{?7ox zikKC6_dr9tQm%Ka9D+udQ^{ioqg2Eq1QZU6moyCdm{_d)RWbdovVg_>oapQb{sYKSLVTk z2M53MnwX`Mn)Z=_7FQgk?_qzKbqntDmtKEy%H!VGi**&&plYQNU0?T!#llivHP5I_ zjPj#3dr%KWQS|Qn4<9oT?+u+;q#~wlHltL+%;FDi{LHk@%}|Co$%$QX>ED{ISo~nk zjjf>$hYdICS4pU=3G(wY(MH& zqC)B_+N0*WqyAJAf!wKuPX3qa=PKcEgw%3x&Qph?8TKdljXvOT=~42|FW#+x|4c^9B--fExhikN&Rj4u6GtsXU#T& zaGT*rT-X{5Upv!{g|GOZ+_Fu?iW>D|C)#| zZ20kEM6^(N^rSaK6%i^mYb{M#PoD8@5qO)q;qxLNOh2r>6$Q?BFhMM}(JXmA zH_N1P?cvwui+g6~bA8K{GO!y&t@;DIe#`*$BM*56LGMe^)GoP2-8BJko@REmH%`eH z4LU;WxdCYsD4a@K*!N!06VQn{SI_=>JU5;g2IeFb&H#N}p^rP(k{>*Moz^sv)XbH) z>~YCp?)@qQ_Xa5l92w5u{S9ND&^n@P={&P6QFE#ctYL2sL=Td%r!VKt^;SEEg?^vMs{PSUCl zj|ScWDe9RzB{>?;AV`96iGaXxa-Z1Ka0FW>cP_qBaz z3lA`2UX9K^1y?jpAF7-3yGR*zWtkM0>~)`OKBa?;I88ZtGbP@c(VSHq-7B}6Hf_wR?Z!`8 zh{OKfbCymq=ZhL%>uq1@2i-FKYFFVtZ~S@8wC&4Bvr=-=&XwKFgmwq1YI&(3Y*K8` zfeacaVL;oqy}iU}i1^*O5~2-KK^@e7En6oQ2D)jVOlp8;UH>>J=N7Y`+aoQn)3b>< zS$6B)6rB>l_yvL2g~38J9&MUa@31p1aw%;;Db2*|25I=urH=DN8N@E?uDVF4IH$I+ zEV(D@I+wAiYo#l$954ReD+4#HN*c4M_2KW9hJeI>Axe4&v<%y}Ohphxvm^=^l;4+O zceQyI>q;l$E(jr@Eo<04DE%n4PoQfz)qf{^TsO;2nGz-bC^(;#GF5}B4%VV;@^HXN z_^LKE{sjBUpbpC+&|T0W?p!@Tg=guywVTXarB`lQEb2l@?JI*1)$eYR6`C)225BRt zn%lnoE98=9=?{LpKn;!{T;H`t^;Y3?-v-5AldP`_S)_!Zb#g}?AMhQkC9j)37fzh| z#aqptQ$BgFdJwWHG+q>NlT+_vTPq6wC;%6QJoHPxy{KnoM46xD#%f<+{)Q=L_O<>5 z=$qHxQd1~UBpe#T8Fiz_nr9ya?p-joqcGO3N`FEyXo=7U7WHPns9&Nz?WJ@!ZmT3V zZY~)^XMtBbOyh;R4~n-$QZ5IU&GJ&LhWpc+1lfZ{ldBzS2!?_Sn$kr9P%Ag%`^9Dp zXf+ed*SfH^oCv8;5)bs2YSypRD&D;pkW&!6>zhGK(>y+M4ncsaI_b`TF3rB;^UdjA zPy^45cf-VApW>n)xkmZG^>V~{?K@GvIq(tL?4>%FL98?u-Yf9dSpD zh{fzivZ%`mSU=}KN8BgzIMiYqHYU@a5agq%Wzj;Z{Kp#*M13+wt=dI5`H%0v`j0|~ z@prgbc2V+&+AsU>**s5HO#G1xs;q4zhHJ7yK8)1nlTB}SH$>zgf^zliS0XEL;}{zm zk;2y>cKu0>s{$Vz!S>@-565`52`p8zK>~UoqY+c&qzH-yr9tF$)mJ+-#2U~ps&>6& z254dYB;m=lN-HXfQlPdHda7ofJSeAkkA5nFxB66rf-JX1d$8t_W2kk;DIHVA>%W?X zUOLj*nY_2#YLK(yy?=duz%{1HGZy-#Fak0t6$(O$8^8xKg!8;xoJvmaP)wMVyHDQ9E)pXIH2e-IC>4o)*7Mz@b_G_YqWa-H{i(Z>Hd zo2Mvtr!kK-`NTUOr{Wy{$UGH2Xvnm2hfy$pVgIGX(z5AeI4^u%@;EM&H|7^55EhTr z@OE8$(kyhExgCLRTBz%_>dtXAv-BYc+)a%3pOwF$r}ENFIBa-*l}FrB>8`Oc_Oyk( z)eh04#9O38G(VP?edJU*B)$cv9v%$SQ0*2uEt~3W{{lnR=mXSdr%6^d4qs=d$_k_a zttwpU8mAA~Itv)#)-cU1%V{?z_@_RQFK3`w)puT!J0YglxSAw*D4^}5zC&rN*oJaB zd2Y*^zxl-Tw|zsH7uLQKi>ALgfDpwhpX-70iY_3z0sal{T6 zpZhOWNo+dOOa!Uqt{qLI6esXkikq2*9aggg6Dl>t23x)INUqJWo zp1o9dYk}og<$FYnjL-@u36bwMBr)kauX zC!b|Qa*TokC4KXCAOL9p@AzW|v(mpN{N2>uZ#4PyXnS1J&UG#YdOEIpX=r4$fi5dk z9IpL<45Vgf)hTFk=}|5WAsnuy5D*Fkm7Bco{S&&Y;@~lWZ;#d}AX*!ge=Vojo(7SnA+U1;$9aUU*V^h^SZ`b#Tp*io z1h(sEkLft(?klBXKF+oa$sTKurkmZK)9UC<1PQ+uHqf389GoF z_nA_epjF~!SXc`Zg;V(^VLkngNe^KgHx+}-+WU5HUM*c#cI!TC~Q_7#47*t+=Tug2FpY7`_CvJGK-0?+grvYFVR$L>i*);CD6SHfUcR0h^@~P&ZHI15 zAOC$tOwz&nU-EoV-9ogc5n*ej^sRAOlHW^8B#>qJ%lhdIxCI;SQJez3A|8zBitpX( z%&ddhupQ29SGmU89TK`JDV;@2_s0}(?30g>T&s}`=9r6cZwWyAStl468PzEOlc1ch zsc|djW|wQS>VO$XHFuQ0k2LBqRf`jCc1vfXW6YlK&>Wom#*LRhMgzc9kOn_J#BM9O zU1ska85x~AIF_qCokbIdhx$0JU9ndS6*|P>9(R<+L~%mpdRPi#LT>WCHgusih^L0& z?1*e9Exyr`es*cRWCm^#agjgsZLR5eV2V>%c4#znUIgcsUgW8H7szD zirG^iFmIpPGY9MW9m3`K46mDURhKmHs_hx`1BI^NI11J}K~3G?Hf#4juYTUhCQR_q8tEhq?}^X1#@OI=svCAUHkPK-_h_*+NzL8|E2W^? z-WlHJlGeVW#E3>qoa>@fp|I?>30FM>1D_Z*oF@a|I_Q7JcrRLBa@C-Yevgb~+jXV5 z<@)2oI;5AiyZ(?|<@r~koamw8r7%qY_4+%|m;Ll=V{)LF<)u}>7$X)4M{fD=9PU!@ zC{nPM`|#c!H#_L5>ghdRX9 z4&hwiSoAT550y~RB*;$+26*Iu%b0au1Wj{f;sWIHw6g;?i@ix<`IF>XS=JVwKl1Rh zh>*L#p<_tz0IUJ+S+Eu^9$1aRIZK=Gc*?R6u-WPQrS&=TVKV2I;Pk-g6$fi|X7vsS zf`q%^?O5k({VF=fO5So~n?7gpZz=Sg3@|jI{=2fnP?8{gnN$7Am8F6&^7393SbeZd z1YqFX7m4ffD4gEGo5Y|qx&-2idIV(4Wnf=xH5G-MYDdr8`V*=pl`(-Q5}Mv(xJfQH zfn=LoCKP+eIuu|_9+4-!&3Q@5o_19vBrS}o;8BGM^U}k07OsMbJg-U*L3rOpXY=Ww zSy|HHs#z`jIHT0j`djmm8`khGaYSiG_Eeq6o-sD~WxB_}U(a=0Jkg==%e5~U3T&{( zy|U*I*qacH@J&0_+*~1#!Zx803idLvd#Lc=Si8u9AoXEKOsvaUtz`^kB;*#AtzxG> zHBaMO&tH6M=&=fBJ5sK*?89<43=E)5Sk(uYAh57f6LnUdY$~s$G2Dk`=-f@+e{-=t z6Rz7CV{SJ=)fk29w0-AWsMQlbDla%4W%x0uU9BvA{$Ky$yXQgt#d3XIy7SGbpbQL@ zYPw>M@<1$1x=@mN998Ilhv@S7=j8|ud*8<)b>*s{_=!kB{&`m4+or8Z zzP2Sr>7>dW37h1GI1WUB`NiYZ;+64?*OO)wj|EM9uC22*9c870FUyBb9^u0bG_k{{ zOT~aNcht`?3V5FeSW|*}ENSeiM;8BP3p}gK&+8b zvy>w7)~I_+`Mj&}e{P=u7V*vlORomqWUZLN%FpsQzY+YH)F_u7;WTh;-7^e;?U7>A zuSZ$0v)kn5b=;-~RthF!1Q4M1C9~)*c=9A>glynv8h5oo7>KIDpL9~}Ze!k(rjuZu z7i6nR6DOhOZyObSWcX&whlbrc3Tg7MuDhG4wQTdZ`?7g6mK@~(+Z^YmER@G$1ck&0 ziwx=v8b_f|`hO2HXBDeXvkW|XD5p`|{`XI0`bDIOe*pcHuWx)d0y3tI+n^CRGf?wn z8+Y?b$1;h*C*RTBSE`Mm{_N_Q(%G=#(y_RM`mSuS@{Z-o$H8XN`MOjYovl5NgIE?x zj`a~Sw^v$Vv^MiT427U2#B*x|Jqoor5H{XL&fmbCUwa`dpo5Z3^=aYW-6oWOJlh)> zN{^CE-<5>-yYsQ<=4mk2+o@WUK9;))T*M$PY62O!HZZ)AARH1&!ssurWZ$i?w@mN0 zNW?Ap2yIN#Umbq>m-?XkHh44zs|>Hl@;9DZtP(f(DKw*+ZtpSd4z+_W?7V<&iO#CmN@fDre0^@*y@;#og`%|r|m zPMn`mJpLFjL-rFq!1839e!KlDIe?8hd(?X4D_Q$BpTUN~An2jGc42IM{IuvH&A&|f z%pwFZt1VY`sX%a#0H74@+V>w@ zDYBgo%91T4VvuDlp^>dIjwSoxjBUu0ea7x6bChk6NF&(^SxXtJQ(mK(gXCC34u)uw zeTnnkkN54o-}k-OcU|Ain7KXA|DNX_p68zb{agMwo<}(Wk_FuDU0^tLfU$o=sMlg= zyjFuW-8&Wd5(Wiezq z76Wo<-;nn#`p?gqpX&kxQaX!zYG?{()~9|b7!`uN8BUL{1g%bLGpf!$m~qYQwPZ}l z6NtUD=t9#K!rDV?jJTgx90OHIq8VuWE|jtPL%jep{4tpVb-0gSs(qj^0qxjiOJF`WDI z&iLdC3ZJ^<=u`Hg6=1hbU|O*=u#)TdRpKsFSr5}L9PJUJz6-f&yxcKk_xN|s4Aj*~ zo0Zc9V)D-%7+;WGO5|-wPha3jo<{V&*_D8{(nHe;QY*QM`p|Nsf!n0qR?>-HZF=L? z$V7aBh6A~@L%aQ(IXjc4%-u>Gc0GcG925oinjg$8?6ve%zqDM7fxmG46heoOUM4Wj zcXVrNB?*+U0mg{TBTDe%SYDK6S-+FkOmMZKM8RVVo(e%{&yv?`03^F>P}g~yvb?*S zJ@Z-IE81Yn>lFQpJaGR=ozVeOrF>T2r3&`Z9a|pdc9>= zqTpr~WJR8BnUD{5t5XT?urOX(2FfN66R_H-=U|>jYXYZhwmv}JJ71yb)bcz0)KdDM zqxHsBLA-zVQd|_q_BhKg0eiTL&Uh!_CFC}r zcA7|saWVmIH#@tbeMkkP^4Ek^|EiNBc{4IGTH9@~S?%ETR-R~o7k(K)laeyTMxWn~ z7ezbqzn_Xdt!g}W<-^O>xDuK5k}RhvbN>qDY_Pd01r!jl>#(YBG4)@L;Ov>tZl#{s z&e7d7jB1+V+QC6u7Wb)afQj#K1eO|dBB>`fNp%AxhJ0UQ4*US7oUP&cS>uTS=PE@fs|L@Z+q#)ju>{A3qKTj#s|rU%MD7c$Mau11l{t! z#c=}XMXCh0)%KioBNIYdc&6p>oyXT308l|S*s)|AesT=zFnEG)*9d-@?->xGq}`T86Ow>pVeRRi3CbR!(#sM7u<9p4Uv7 z%!nLd-jR8>r;e;m{0*qVL@lWS5)U5N=;n-K#m$uwnnhSY81e15(s{WMUUmmLxuIFi zN3Q6U5Q84I8zgNK&y{rp=Fq|2HQzBHwhy>==&iM+ty@5hA>X6V@njC|I>bBY;&$%^ zT^I*nMMbH$U>=mFowYq)PGb;yGUxXmu|>uXFdQ@2+Ah2?TIw+Ep}aP8bZ0DONJovy z?YelJ%zyv#@IoxW$Mt?mYO&xciv$GLNr0x}w4Mr?qjN7-DX*uAIj6-%fRWZIz8g?` z@Zvh~M-)dPrQ))E@H=PgnKkat$}?pNh>uYYJqTI|;51J{x91dqgEFmqHFo4z(s{>j z`j3Y$)X2I`=Ej%<1)~6POG^*7!e7eU<$%V@%bni~zG~US%rzTniUJV7j&TItd}rKk z@gFege_{_kn~Q_*Qv)mKBT`%CP|K;3gq@o!>`;^ruRsF@5mDo5 z>6N;X$E+f4ebH?W|4|Byo7U46;Fn`a5x|+D4&9;1(VUM!_CADwUFdmU(jHO-+Gwen zS(pxPNhBS(=O^-)LfxdFmb3_)WYekYj!q%`X{I$c!}f4_itPE>?abd6l+TF`#h7P& z+Ay-f9!^vk7Rq2K@aaHPX8@D?*8UWt>zmYUH@nc=3#p`(865FCfU8jB1)mFa_eA5M ztyeN_&S|8`*@9)KLG=m);$5-oYHT6>i@Br>Mu@4#GGzm&bv4TyR-03$bhWW0a$e!Q zSd2{CrClpQ%QSi33VTOOz>ZV|P;a*C00(=#YwKJ@-3NI__DLV@fFzkc|P>XRUdU7wSK zf>S8R33s#bj#O3Sdtl+x`}7;K>bi2V6Whas(MrCU*y+li{*v|Hb^-4{(1F^ z8I1*8)jr&%4m8|aUz0~8eRcP#sKP4W>yqPlGn9ENWSwP*o3+Y0)y2=q@jLTXrb)LN zMAiz!F;deOkcv38-z~fg{%I^wicniE@W6{atl(|qhnR;CR6a1`$7D~aVY%OE6>j(J zC0Lji%c1x6VEGOL71L!Jg3}v)mH}qBwSC}3O<51qPzLphfPW45un-a9cTNNw1rMQDpi{ml?)p3?*2Vj6(VhCQg4~BNxLbHqln{hkJ9TM&?GFjsS#{cgfKN7k z58p3CXT;4a1<@MRS)(u6VtC5t1WlOMV?7tE4qG&5@Z8riZ}WxVSz`< zj9iK|`=m3%r~}sp=BPkh_6MB;Pt4EcrISX|^*$eKV}pX+790j4McHI` zbpcDbyHL7B$#s3z*F>c;@RmC+yq197uPr$rNhKF=eU%IeSR4wGUr!aaRO-|CSuSPp zuiO4Mo8858T$T1mlDgN7{%U$&{)0jpiahLpx?TrWC|58QG1y z>#`$yWdQvimx&ettnDQD9R1m`b<3s2lp?B~wb5b;>D0A_$~hary3BT1eUfd{IFIEi za|49rggp4^KkKL71L)`3kMEI_l~>SR?=k_-^;23YImDDF}$ z7J8CJ%!bh&SW-f~J+nt49)LXuzmk9_-nz>nlbH2)L;~1k2}NCn^HFPFfqxA&p0+D` zz=g1X(*9TdtcQC^9i1Y@&TP2A16XyYEGY`De%{v4c+k4E%pQXUdrE#7FyO zvY+9+1w1?u%FDsb8;yn(K${a{Wf6eb;8JJc4yE8B_JcMAfhvOF#(JOi`xaKheYWpy zs1M#b>2psVyqpd*b_nzI2=hYXLcG8Wq^hE-rlg{(gix_XXd)46;Bi((1*xL)^;!}0 ze{={4^2B=+{_hS6igKW^BqRVI!7B>yjWh;N7;o=TuP{hWtM*BUG}tTr_g*V}l-E@U z6h6Q!FccpY2x+LPeRZ_W`p+20f5)h*Xs8H3jRZ0B@cV#*he%vdFd+o*;~NHD{N9o< z3=Rf05zPW|=M*Kt=Tn_&?kog-PJZv>=@p6#!3T%IhehE-gRgoJB&^gj2+!I<)WP_} z@ZR1?ObFg9FwEm14Dq<;o6h&Kf$Dw8|2=$!imJND`*J#n5rU8Ncg%kqzNUuOJ^jv1 P5CWMQTcYZW+>`zbXu!7w diff --git a/docs/src/assets/logo.png b/docs/src/assets/logo.png deleted file mode 100644 index 052a9c34af3a11d9f8e6ee7bfdce4ad2f5335622..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10273 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%0D>6I|HDwa>UlSdMYL1oOpbK)9VqUK2`VkE%sqh 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 a|DWbdh)d?nb*G?701Z`bm0Bgsi2nzMu_QtO diff --git a/docs/src/associations.md b/docs/src/associations.md index 6654065f9..0d6a729fd 100644 --- a/docs/src/associations.md +++ b/docs/src/associations.md @@ -5,7 +5,7 @@ CollapsedDocStrings = true # [Associations](@id association_measures) ## Association API -The most basic components of CausalityTools.jl are a collection of statistics that in some manner quantify the "association" between input datasets. Precisely what is meant by "association" depends on the measure, and precisely what is meant by "quantify" depends on the *estimator* of that measure. We formalize this notion below with the [`association`](@ref) +The most basic components of Associations.jl are a collection of statistics that in some manner quantify the "association" between input datasets. Precisely what is meant by "association" depends on the measure, and precisely what is meant by "quantify" depends on the *estimator* of that measure. We formalize this notion below with the [`association`](@ref) function, which dispatches on [`AssociationMeasureEstimator`](@ref) and [`AssociationMeasure`](@ref). @@ -18,7 +18,7 @@ AssociationMeasureEstimator Here are some examples of how to use [`association`](@ref). ```@repl -using CausalityTools +using Associations x, y, z = rand(1000), rand(1000), rand(1000); association(LMeasure(), x, y) association(DistanceCorrelation(), x, y) @@ -123,7 +123,7 @@ concept of "cross mapping", which has appeared in many contexts in the literatur and gained huge popularity with [Sugihara2012](@citet)'s on *convergent cross mapping*. Since their paper, several cross mapping methods and frameworks have emerged in the -literature. In CausalityTools.jl, we provide a unified interface for using these cross +literature. In Associations.jl, we provide a unified interface for using these cross mapping methods. ```@docs diff --git a/docs/src/examples/examples_associations.md b/docs/src/examples/examples_associations.md index b6e2a2358..218cb6bc4 100644 --- a/docs/src/examples/examples_associations.md +++ b/docs/src/examples/examples_associations.md @@ -5,7 +5,7 @@ ### [From precomputed probabilities](@id example_HellingerDistance_precomputed_probabilities) ```@example example_HellingerDistance -using CausalityTools +using Associations # From pre-computed PMFs p1 = Probabilities([0.1, 0.5, 0.2, 0.2]) p2 = Probabilities([0.3, 0.3, 0.2, 0.2]) @@ -17,7 +17,7 @@ association(HellingerDistance(), p1, p2) We expect the Hellinger distance between two uncorrelated variables to be close to zero. ```@example example_HellingerDistance -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) n = 100000 x, y = rand(rng, n), rand(rng, n) @@ -30,7 +30,7 @@ div_hd = association(est, x, y) # pretty close to zero ### [From precomputed probabilities](@id example_KLDivergence_precomputed_probabilities) ```@example example_KLDivergence -using CausalityTools +using Associations # From pre-computed PMFs p1 = Probabilities([0.1, 0.5, 0.2, 0.2]) p2 = Probabilities([0.3, 0.3, 0.2, 0.2]) @@ -42,7 +42,7 @@ association(KLDivergence(), p1, p2) We expect the [`KLDivergence`](@ref) between two uncorrelated variables to be close to zero. ```@example example_KLDivergence -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) n = 100000 x, y = rand(rng, n), rand(rng, n) @@ -56,7 +56,7 @@ div_hd = association(est, x, y) # pretty close to zero ### [From precomputed probabilities](@id example_RenyiDivergence_precomputed_probabilities) ```@example example_RenyiDivergence -using CausalityTools +using Associations # From pre-computed PMFs p1 = Probabilities([0.1, 0.5, 0.2, 0.2]) p2 = Probabilities([0.3, 0.3, 0.2, 0.2]) @@ -68,7 +68,7 @@ association(RenyiDivergence(), p1, p2) We expect the [`RenyiDivergence`](@ref) between two uncorrelated variables to be close to zero. ```@example example_RenyiDivergence -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) n = 100000 x, y = rand(rng, n), rand(rng, n) @@ -82,7 +82,7 @@ div_hd = association(est, x, y) # pretty close to zero ### [From precomputed probabilities](@id example_VariationDistance_precomputed_probabilities) ```@example example_VariationDistance -using CausalityTools +using Associations # From pre-computed PMFs p1 = Probabilities([0.1, 0.5, 0.2, 0.2]) p2 = Probabilities([0.3, 0.3, 0.2, 0.2]) @@ -94,7 +94,7 @@ association(VariationDistance(), p1, p2) We expect the [`VariationDistance`](@ref) between two uncorrelated variables to be close to zero. ```@example example_VariationDistance -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) n = 100000 x, y = rand(rng, n), rand(rng, n) @@ -107,7 +107,7 @@ div_hd = association(est, x, y) # pretty close to zero ### [[`JointProbabilities`](@ref) with [`Dispersion`](@ref)](@id example_JointEntropyShannon_Dispersion) ```@example example_JointEntropyShannon -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x, y = rand(rng, 100), rand(rng, 100) measure = JointEntropyShannon() @@ -121,7 +121,7 @@ association(est, x, y) ### [[`JointProbabilities`](@ref) with [`OrdinalPatterns`](@ref)](@id example_JointEntropyTsallis_OrdinalPatterns) ```@example example_JointEntropyTsallis -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x, y = rand(rng, 100), rand(rng, 100) measure = JointEntropyTsallis() @@ -136,7 +136,7 @@ association(est, x, y) ### [[`JointProbabilities`](@ref) with [`OrdinalPatterns`](@ref)](@id example_JointEntropyRenyi_ValueBinning) ```@example example_JointEntropyRenyi -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x, y = rand(rng, 100), rand(rng, 100) measure = JointEntropyRenyi(q = 0.5) @@ -155,7 +155,7 @@ transpose their example. Then their `X` is in the first dimension of our table ( columns) and their `Y` is our second dimension (rows). ```@example ce_contingency_table -using CausalityTools +using Associations freqs_yx = [1//8 1//16 1//32 1//32; 1//16 1//8 1//32 1//32; 1//16 1//16 1//16 1//16; @@ -201,7 +201,7 @@ Let's first demonstrate on some categorical data. For that, we must use [`UniqueElements`](@ref) as the discretization (i.e. just count unique elements). ```@example example_ConditionalEntropyShannon_JointProbabilities_CodifyVariables_UniqueElements -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) n = 1000 rating = rand(rng, 1:6, n) @@ -215,7 +215,7 @@ association(est, rating, movie) ### [[`JointProbabilities`](@ref) + [`CodifyPoints`](@ref) + [`UniqueElementsEncoding`](@ref)](@id example_ConditionalEntropyShannon_JointProbabilities_CodifyPoints_UniqueElementsEncoding) ```@example example_ConditionalEntropyShannon_JointProbabilities_CodifyPoints_UniqueElementsEncoding -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x, y, z = rand(rng, 1:5, 100), rand(rng, 1:5, 100), rand(rng, 1:3, 100) X = StateSpaceSet(x, z) @@ -232,7 +232,7 @@ association(est, X, Y) We'll here repeat the analysis we did for [`ConditionalEntropyShannon`](@ref) above. ```@example example_ConditionalEntropyTsallisAbe_JointProbabilities_CodifyVariables_UniqueElements -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) n = 1000 rating = rand(rng, 1:6, n) @@ -246,7 +246,7 @@ association(est, rating, movie) ### [[`JointProbabilities`](@ref) + [`CodifyPoints`](@ref) + [`UniqueElementsEncoding`](@ref)](@id example_ConditionalEntropyTsallisAbe_JointProbabilities_CodifyPoints_UniqueElementsEncoding) ```@example example_ConditionalEntropyTsallisAbe_JointProbabilities_CodifyPoints_UniqueElementsEncoding -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x, y, z = rand(rng, 1:5, 100), rand(rng, 1:5, 100), rand(rng, 1:3, 100) X = StateSpaceSet(x, z) @@ -264,7 +264,7 @@ association(est, X, Y) We'll here repeat the analysis we did for [`ConditionalEntropyShannon`](@ref) and [`ConditionalEntropyTsallisAbe`](@ref) above. ```@example example_ConditionalEntropyTsallisFuruichi_JointProbabilities_CodifyVariables_UniqueElements -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) n = 1000 rating = rand(rng, 1:6, n) @@ -278,7 +278,7 @@ association(est, rating, movie) ### [[`JointProbabilities`](@ref) + [`CodifyPoints`](@ref) + [`UniqueElementsEncoding`](@ref)](@id example_ConditionalEntropyTsallisFuruichi_JointProbabilities_CodifyPoints_UniqueElementsEncoding) ```@example example_ConditionalEntropyTsallisFuruichi_JointProbabilities_CodifyPoints_UniqueElementsEncoding -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x, y, z = rand(rng, 1:5, 100), rand(rng, 1:5, 100), rand(rng, 1:3, 100) X = StateSpaceSet(x, z) @@ -294,7 +294,7 @@ association(est, X, Y) ### [[`JointProbabilities`](@ref) + [`ValueBinning`](@ref)](@id example_MIShannon_JointProbabilities_ValueBinning) ```@example mi_demonstration -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x = rand(rng, 1000) y = rand(rng, 1000) @@ -311,7 +311,7 @@ For example, let's compare the Shannon mutual information between the preference of a population sample with regards to different foods. ```@example mi_demonstration -using CausalityTools +using Associations n = 1000 preferences = rand(["neutral", "like it", "hate it"], n); random_foods = rand(["water", "flour", "bananas", "booze", "potatoes", "beans", "soup"], n) @@ -332,12 +332,12 @@ association(est, preferences, biased_foods), association(est, preferences, rando ### [Dedicated [`GaussianMI`](@ref) estimator](@id example_MIShannon_GaussianMI) ```@example mi_demonstration -using CausalityTools +using Associations using Distributions using Statistics n = 1000 -using CausalityTools +using Associations x = randn(1000) y = rand(1000) .+ x association(GaussianMI(MIShannon()), x, y) # defaults to `MIShannon()` @@ -346,7 +346,7 @@ association(GaussianMI(MIShannon()), x, y) # defaults to `MIShannon()` ### [Dedicated [`KraskovStögbauerGrassberger1`](@ref) estimator](@id example_MIShannon_KSG1) ```@example mi_demonstration -using CausalityTools +using Associations x, y = rand(1000), rand(1000) association(KSG1(MIShannon(); k = 5), x, y) ``` @@ -354,7 +354,7 @@ association(KSG1(MIShannon(); k = 5), x, y) ### [Dedicated [`KraskovStögbauerGrassberger2`](@ref) estimator](@id example_MIShannon_KSG2) ```@example mi_demonstration -using CausalityTools +using Associations x, y = rand(1000), rand(1000) association(KSG2(MIShannon(); k = 5), x, y) ``` @@ -362,7 +362,7 @@ association(KSG2(MIShannon(); k = 5), x, y) ### [Dedicated [`GaoKannanOhViswanath`](@ref) estimator](@id example_MIShannon_GaoKannanOhViswanath) ```@example mi_demonstration -using CausalityTools +using Associations x, y = rand(1000), rand(1000) association(GaoKannanOhViswanath(MIShannon(); k = 10), x, y) ``` @@ -373,7 +373,7 @@ We can compute [`MIShannon`](@ref) by naively applying a [`DifferentialInfoEstim Note that this doesn't apply any bias correction. ```@example mi_demonstration -using CausalityTools +using Associations x, y = rand(1000), rand(1000) association(EntropyDecomposition(MIShannon(), Kraskov(k = 3)), x, y) ``` @@ -385,7 +385,7 @@ We can also compute [`MIShannon`](@ref) by naively applying a [`DiscreteInfoEsti Note that this doesn't apply any bias correction. ```@example mi_demonstration -using CausalityTools +using Associations x, y = rand(1000), rand(1000) disc = CodifyVariables(BubbleSortSwaps(m=5)) hest = PlugIn(Shannon()) @@ -400,7 +400,7 @@ Here, we use [`CodifyVariables`](@ref) with [`ValueBinning`](@ref) bin the data and compute discrete Shannon mutual information. ```@example mi_demonstration -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x = rand(rng, 50) y = rand(rng, 50) @@ -424,7 +424,7 @@ curves corresponding to different time series length. We only show two single cu one for the [`KraskovStögbauerGrassberger1`](@ref) estimator and one for the [`KraskovStögbauerGrassberger2`](@ref) estimator*. ```@example ex_mutualinfo -using CausalityTools +using Associations using LinearAlgebra: det using Distributions: MvNormal using StateSpaceSets: StateSpaceSet @@ -475,7 +475,7 @@ diverges from the true value for these data, the [`GaoKannanOhViswanath`](@ref) converges to the true value. ```@example ex_mutualinfo -using CausalityTools +using Associations using Statistics using StateSpaceSets: StateSpaceSet using Statistics: mean @@ -553,7 +553,7 @@ fig Let's compare the performance of a subset of the implemented mutual information estimators. We'll use example data from Lord et al., where the analytical mutual information is known. ```@example ex_mutualinfo -using CausalityTools +using Associations using LinearAlgebra: det using StateSpaceSets: StateSpaceSet using Distributions: MvNormal @@ -786,7 +786,7 @@ We see that the [`Lord`](@ref) estimator, which estimates local volume elements with the [`UniqueElements`](@ref) outcome space. ```@example example_mirenyijizba -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, ["a", "b", "c"], 200); y = rand(rng, ["hello", "yoyo", "heyhey"], 200); @@ -801,7 +801,7 @@ in combination with any [`DifferentialInfoEstimator`](@ref) capable of estimatin [`Renyi`](@ref) entropy. ```@example example_MIRenyiJizba -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = randn(rng, 50); y = randn(rng, 50); def = MIRenyiJizba() @@ -817,7 +817,7 @@ in combination with any [`DiscreteInfoEstimator`](@ref) capable of estimating di ```@example example_MIRenyiJizba -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = randn(rng, 50); y = randn(rng, 50); def = MIRenyiJizba() @@ -835,7 +835,7 @@ in combination with any [`CodifyVariables`](@ref) or [`CodifyPoints`](@ref) disc ### [[`JointProbabilities`](@ref) + [`UniqueElements`](@ref)](@id example_MIRenyiSarbu_JointProbabilities_UniqueElements) ```@example example_MIRenyiSarbu -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, ["a", "b", "c"], 200) y = rand(rng, ["hello", "yoyo", "heyhey"], 200) @@ -847,7 +847,7 @@ association(est, x, y) ### [[`JointProbabilities`](@ref) + [`CosineSimilarityBinning`](@ref)](@id example_MIRenyiSarbu_JointProbabilities_CosineSimilarityBinning) ```@example example_MIRenyiSarbu -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, 200) y = rand(rng, 200) @@ -864,7 +864,7 @@ association(est, x, y) in combination with any [`CodifyVariables`](@ref) or [`CodifyPoints`](@ref) discretization scheme. ```@example example_MITsallisFuruichi -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, 200) y = rand(rng, 200) @@ -876,7 +876,7 @@ association(est, x, y) ### [[`EntropyDecomposition`](@ref) + [`LeonenkoProzantoSavani`](@ref)](@id example_MITsallisFuruichi_EntropyDecomposition_LeonenkoProzantoSavani) ```@example example_MITsallisFuruichi -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, 200) y = rand(rng, 200) @@ -889,7 +889,7 @@ association(est_diff, x, y) ### [[`EntropyDecomposition`](@ref) + [`Dispersion`](@ref)](@id example_MITsallisFuruichi_EntropyDecomposition_Dispersion) ```@example example_MITsallisFuruichi -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, 200) y = rand(rng, 200) @@ -905,7 +905,7 @@ association(est_disc, x, y) ### [[`JointProbabilities`](@ref) + [`UniqueElements`](@ref)](@id example_MITsallisMartin_JointProbabilities_UniqueElements) ```@example example_MITsallisMartin -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, 200) y = rand(rng, 200) @@ -922,7 +922,7 @@ that can estimate differential [`Tsallis`](@ref) entropy. ```@example example_MITsallisMartin -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, 500) y = rand(rng, 500) @@ -935,7 +935,7 @@ association(est_diff, x, y) ```@example -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, 200) y = rand(rng, 200) @@ -950,7 +950,7 @@ association(est_disc, x, y) ### [[`CMIShannon`](@ref) with [`GaussianCMI`](@ref)](@id example_CMIShannon_GaussianCMI) ```@example mi_demonstration -using CausalityTools +using Associations using Distributions using Statistics @@ -965,7 +965,7 @@ association(GaussianCMI(), x, z, y) # defaults to `CMIShannon()` ### [[`CMIShannon`](@ref) with [`FPVP`](@ref)](@id example_CMIShannon_FPVP) ```@example mi_demonstration -using CausalityTools +using Associations using Distributions using Statistics @@ -985,7 +985,7 @@ association(FPVP(k = 5), x, z, y) # defaults to `CMIShannon()` ### [`CMIShannon`](@ref) with [`MesnerShalizi`](@ref) ```@example mi_demonstration -using CausalityTools +using Associations using Distributions using Statistics using Random; rng = Xoshiro(1234) @@ -1006,7 +1006,7 @@ association(MesnerShalizi(; k = 10), x, z, y) # defaults to `CMIShannon()` ### [`CMIShannon`](@ref) with [`Rahimzamani`](@ref) ```@example mi_demonstration -using CausalityTools +using Associations using Distributions using Statistics using Random; rng = Xoshiro(1234) @@ -1030,7 +1030,7 @@ Shannon-type conditional mutual information can be decomposed as a sum of mutual information terms, which we can each estimate with any dedicated [`MutualInformationEstimator`](@ref) estimator. ```julia -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x = rand(rng, 300) y = rand(rng, 300) .+ x @@ -1046,7 +1046,7 @@ association(est, x, z, y) # should be near 0 (and can be negative) ### [[`PoczosSchneiderCMI`](@ref)](@id CMIRenyiPoczos_PoczosSchneiderCMI) ```@example example_cmirenyipoczos -using CausalityTools +using Associations using Distributions using Statistics using Random; rng = Xoshiro(1234) @@ -1075,7 +1075,7 @@ taking the difference of mutual information terms. ### [[`MIDecomposition`](@ref) + [`KraskovStögbauerGrassberger1`](@ref)](@id example_CMIShannon_MIDecomposition_KSG1) ```@example mi_demonstration -using CausalityTools +using Associations using Distributions using Statistics @@ -1101,7 +1101,7 @@ usethe [`EntropyDecomposition`](@ref) estimator. No bias correction is applied f [`EntropyDecomposition`](@ref) either. ```@example -using CausalityTools +using Associations using Distributions using Random; rng = Xoshiro(1234) n = 500 @@ -1121,7 +1121,7 @@ discretization (an [`OutcomeSpace`](@ref)). ### [[`EntropyDecomposition`](@ref) + [`ValueBinning`](@ref)](@id example_CMIShannon_EntropyDecomposition_ValueBinning) ```@example -using CausalityTools +using Associations using Distributions using Random; rng = Xoshiro(1234) n = 500 @@ -1140,7 +1140,7 @@ association(est, x, y, z) ### [[`JointProbabilities`](@ref) + [`BubbleSortSwaps`](@ref)](@id example_CMIRenyiJizba_JointProbabilities_BubbleSortSwaps) ```@example example_CMIRenyiJizba -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, 100) y = x .+ rand(rng, 100) @@ -1154,7 +1154,7 @@ association(est, x, z, y) ### [[`EntropyDecomposition`](@ref) + [`LeonenkoProzantoSavani`](@ref)](@id example_CMIRenyiJizba_EntropyDecomposition_LeonenkoProzantoSavani) ```@example example_CMIRenyiJizba -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x, y, z = rand(rng, 1000), rand(rng, 1000), rand(rng, 1000) def = CMIRenyiJizba(q = 1.5) @@ -1168,7 +1168,7 @@ association(est, x, y, z) ### [[`EntropyDecomposition`](@ref) + [`OrdinalPatterns`](@ref)](@id example_CMIRenyiJizba_EntropyDecomposition_OrdinalPatterns) ```@example example_CMIRenyiJizba -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x, y, z = rand(rng, 1000), rand(rng, 1000), rand(rng, 1000) def = CMIRenyiJizba(q = 1.5) @@ -1187,7 +1187,7 @@ there is time-delayed forcing between variables. ```@example transfer_entropy_examples -using CausalityTools +using Associations using DynamicalSystemsBase using StableRNGs rng = StableRNG(123) @@ -1248,7 +1248,7 @@ information transfer. ### [[`CMIDecomposition`](@ref)](@id example_TEShannon_CMIDecomposition) ```@example -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x = rand(rng, 1000) y = rand(rng, 1000) .+ x @@ -1270,7 +1270,7 @@ Thus, we expect that the association for the direction `x → y` is larger than on the intermediate value `y`. ```@example transfer_entropy_examples -using CausalityTools +using Associations using DynamicalSystemsBase using Random; rng = Xoshiro(1234) sys = system(Logistic4Chain(; rng)) @@ -1294,7 +1294,7 @@ We will test terms (without guaranteed cancellation of biases for the total sum). ```@example -using CausalityTools +using Associations using CairoMakie using Statistics using Distributions: Normal @@ -1368,7 +1368,7 @@ discretizing per column of the input data using the [`CodifyVariables`](@ref) di scheme with the [`ValueBinning`](@ref) outcome space. ```@example example_te_schreiber -using CausalityTools +using Associations using DynamicalSystemsBase using CairoMakie using Statistics @@ -1472,7 +1472,7 @@ We can perform the same type of analysis as above using [`TERenyiJizba`](@ref) instead of [`TEShannon`](@ref). ```@example transfer_entropy_examples -using CausalityTools +using Associations using DynamicalSystemsBase using StableRNGs; rng = StableRNG(123) @@ -1496,7 +1496,7 @@ size `l`, and cross mapping is performed using the embedding vectors correspondi to those time indices. ```@example example_ConvergentCrossMapping -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x, y = randn(rng, 200), randn(rng, 200) @@ -1511,7 +1511,7 @@ To generate a distribution of cross-map estimates for each `l ∈ libsizes`, jus crossmap repeatedly, e.g. ```@example example_ConvergentCrossMapping -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) using Statistics @@ -1539,7 +1539,7 @@ size `l`, and cross mapping is performed using the embedding vectors correspondi to those time indices. ```@example example_ConvergentCrossMapping -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x, y = randn(rng, 200), randn(rng, 200) @@ -1554,7 +1554,7 @@ As above, to generate a distribution of cross-map estimates for each `l ∈ libs crossmap repeatedly, e.g. ```@example example_ConvergentCrossMapping -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) using Statistics @@ -1582,7 +1582,7 @@ instead of the convergent cross map algorithm. ```@example example_PairwiseAsymmetricInference -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x, y = randn(rng, 300), randn(rng, 300) @@ -1597,7 +1597,7 @@ To generate a distribution of cross-map estimates for each `l ∈ libsizes`, jus crossmap repeatedly, e.g. ```@example example_PairwiseAsymmetricInference -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) using Statistics @@ -1617,7 +1617,7 @@ f ### [[`RandomSegment`](@ref) estimator](@id example_PairwiseAsymmetricInference_RandomSegment) ```@example example_PairwiseAsymmetricInference -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x, y = randn(rng, 200), randn(rng, 200) @@ -1632,7 +1632,7 @@ As above, to generate a distribution of cross-map estimates for each `l ∈ libs crossmap repeatedly, e.g. ```@example -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) using Statistics @@ -1661,7 +1661,7 @@ from `X` to `Z`. We expect the association between `X` and `Z` to disappear when conditioning on `Y` (since we're then "removing the effect" of `Y`). ```@example example_mcr -using CausalityTools +using Associations using Random; rng = Xoshiro(1234); x = rand(rng, 300); y = rand(rng, 300) .* sin.(x); z = rand(rng, 300) .* y; est = MCR(r = 0.5) @@ -1674,7 +1674,7 @@ Two variables that are uncoupled are symmetrically coupled (i.e. no coupling). W therefore expect the difference in conditional recurrence to be around zero. ```@example -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, 300) y = rand(rng, 300) @@ -1692,7 +1692,7 @@ from `X` to `Z`. We expect the association between `X` and `Z` to disappear when conditioning on `Y` (since we're then "removing the effect" of `Y`). ```@example example_mcr -using CausalityTools +using Associations using Random; rng = Xoshiro(1234); x = rand(rng, 300); y = rand(rng, 300) .* sin.(x); z = rand(rng, 300) .* y; est = RMCD(r = 0.5) diff --git a/docs/src/examples/examples_independence.md b/docs/src/examples/examples_independence.md index 02b8957b3..7b6512076 100644 --- a/docs/src/examples/examples_independence.md +++ b/docs/src/examples/examples_independence.md @@ -4,7 +4,7 @@ ## [[`CorrTest`](@ref)](@id example_CorrTest) ```@example corrtest_example -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) # Some normally distributed data @@ -48,7 +48,7 @@ to see if we can confirm from observed time series that these variables are bidirectionally coupled. We'll use a significance level of `1 - α = 0.99`, i.e. `α = 0.01`. ```@example examples_independence_JointDistanceDistributionTest -using CausalityTools +using Associations using DynamicalSystemsBase using Random; rng = Xoshiro(1234) Base.@kwdef struct Logistic2Bidir{V, C1, C2, R1, R2, Σx, Σy, R} @@ -80,7 +80,7 @@ end We start by generating some time series and configuring the test. ```@example examples_independence_JointDistanceDistributionTest -using CausalityTools +using Associations sys = system(Logistic2Bidir(c_xy = 0.5, c_yx = 0.4)) x, y = columns(first(trajectory(sys, 2000, Ttr = 10000))) measure = JointDistanceDistribution(D = 5, B = 5) @@ -121,7 +121,7 @@ enough evidence in the data to suggest directional coupling. ### [Distance correlation](@id example_SurrogateAssociationTest_DistanceCorrelation) ```@example -using CausalityTools +using Associations x = randn(1000) y = randn(1000) .+ 0.5x independence(SurrogateAssociationTest(DistanceCorrelation()), x, y) @@ -130,7 +130,7 @@ independence(SurrogateAssociationTest(DistanceCorrelation()), x, y) ### [Partial correlation](@id example_SurrogateAssociationTest_PartialCorrelation) ```@example -using CausalityTools +using Associations x = randn(1000) y = randn(1000) .+ 0.5x z = randn(1000) .+ 0.8y @@ -141,7 +141,7 @@ independence(SurrogateAssociationTest(PartialCorrelation()), x, z, y) ### [[`SMeasure`](@ref)](@id example_SurrogateAssociationTest_SMeasure) ```@example example_SurrogateAssociationTest_SMeasure -using CausalityTools +using Associations x, y = randn(1000), randn(1000) measure = SMeasure(dx = 4, dy = 3) s = association(measure, x, y) @@ -175,7 +175,7 @@ evidence in the data to support directional dependence from `x` to `z`. In this example, we expect the `preference` and the `food` variables to be independent. ```@example example_SurrogateAssociationTest_MIShannon_categorical -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) # Simulate n = 1000 @@ -204,7 +204,7 @@ We should be able to reject `places ⫫ experience`, but not reject relationships using (conditional) mutual information. ```@example indep_cmi -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) n = 1000 @@ -247,7 +247,7 @@ and we can't reject the null hypothesis of independence. ### [[`MCR`](@ref)](@id example_independence_MCR) ```@example -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, 300) @@ -259,7 +259,7 @@ independence(test, x, y) As expected, we can't reject independence. What happens if two variables are coupled? ```@example -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x = rand(rng, 300) z = x .+ rand(rng, 300) @@ -320,7 +320,7 @@ entropy estimator, which naively computes CMI as a sum of entropy terms without bias cancellation. ```@example example_LocalPermutationTest -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) n = 100 X = randn(rng, n) @@ -355,7 +355,7 @@ to be non-significant when conditioning on `Y`, because all information from `X` is transferred through `Y`. ```@example example_LocalPermutationTest -using CausalityTools +using Associations using Random; rng = Random.default_rng() n = 300 sys = system(Logistic4Chain(; xi = rand(rng, 4), rng)) diff --git a/docs/src/examples/examples_infer_graphs.md b/docs/src/examples/examples_infer_graphs.md index aee6dd3ca..7dab27426 100644 --- a/docs/src/examples/examples_infer_graphs.md +++ b/docs/src/examples/examples_infer_graphs.md @@ -72,7 +72,7 @@ Here, we use the [`OCE`](@ref) algorithm to infer a time series graph. We use a for the conditional steps. ```@example graph_examples -using CausalityTools +using Associations using StableRNGs rng = StableRNG(123) @@ -117,7 +117,7 @@ also use a parametric correlation test to infer the skeleton graph for some normally distributed data. ```@example graph_examples -using CausalityTools +using Associations using StableRNGs rng = StableRNG(123) n = 300 @@ -150,7 +150,7 @@ with the Shannon mutual information [`MIShannon`](@ref) measure and the and the [`MesnerShalizi`](@ref). ```@example graph_examples -using CausalityTools +using Associations using StableRNGs rng = StableRNG(123) diff --git a/docs/src/index.md b/docs/src/index.md index 71bf13fbf..32714e77d 100644 --- a/docs/src/index.md +++ b/docs/src/index.md @@ -1,28 +1,15 @@ - -```@meta -CollapsedDocStrings = true -``` - -# CausalityTools.jl - -![CausalityTools.jl static logo](assets/logo-large.png) +# Associations.jl ```@docs -CausalityTools +Associations ``` -## Getting started - -The quickest way to get going with the package is to check out the examples in the left-hand menu. - -!!! info - To make it easier to navigate the extensive documentation, all documentation strings are - collapsed by default. Click the arrow icon in - the top toolbar to expand/collapse the docstrings in a page. - ## Latest news -CausalityTools.jl has been updated to v3! +!!! info "Package rename" + The package has been *renamed* from CausalityTools.jl to Associations.jl. + +Associations.jl has been updated to v4! This update includes a number of breaking changes, several of which are *not* backwards compatible. These are done to ensure compatibility with @@ -35,6 +22,15 @@ Important changes are: - `SurrogateTest` has been renamed to [`SurrogateAssociationTest`](@ref). - See the CHANGELOG.md for a complete list of changes. +## Getting started + +The quickest way to get going with the package is to check out the examples in the left-hand menu. + +!!! info + To make it easier to navigate the extensive documentation, all documentation strings are + collapsed by default. Click the arrow icon in + the top toolbar to expand/collapse the docstrings in a page. + ## Documentation content @@ -46,9 +42,9 @@ Important changes are: [independence testing](@ref examples_independence), and [network inference](@ref examples_network_inference). -## Input data for CausalityTools.jl +## Input data for Associations.jl -Input data for CausalityTools.jl are given as: +Input data for Associations.jl are given as: - Univariate *timeseries*, which are given as standard Julia `Vector`s. - Multivariate timeseries, *StateSpaceSets*, or *state space sets*, which are given as @@ -65,7 +61,7 @@ StateSpaceSets.StateSpaceSet ## Maintainers and contributors -The CausalityTools.jl software is maintained by +The Associations.jl software is maintained by [Kristian Agasøster Haaga](https://github.com/kahaaga), who also curates and writes this documentation. Significant contributions to the API and documentation design has been made by [George Datseris](https://github.com/Datseris), which also co-authors diff --git a/src/CausalityTools.jl b/src/Associations.jl similarity index 77% rename from src/CausalityTools.jl rename to src/Associations.jl index 507a16262..58ecf3a42 100644 --- a/src/CausalityTools.jl +++ b/src/Associations.jl @@ -1,11 +1,11 @@ -module CausalityTools +module Associations # Use the README as the module docs @doc let path = joinpath(dirname(@__DIR__), "README.md") include_dependency(path) read(path, String) - end CausalityTools + end Associations using Reexport @@ -40,13 +40,11 @@ module CausalityTools # Update messages: using Scratch display_update = true - version_number = "3.0.0" + version_number = "4.0.0" update_name = "update_v$(version_number)" update_message = """ - \nUpdate message: CausalityTools v$(version_number)\n - - Bivariate and multivariate information measure definitions and estimation is now based on the API in ComplexityMeasures.jl. - - Example systems have been removed from the package to avoid unnecessary package dependencies and improve compilation time. - - Convenience methods have been removed. Use `association` instead. + \nUpdate message: Associations v$(version_number)\n + - The package has been renamed from CausalityTools.jl to Associations.jl! As part of the renaming, Associations.jl has incremented its major version to v4, which is fully backwards compatible with CausalityTools v3. """ if display_update diff --git a/src/causal_graphs/oce/OCE.jl b/src/causal_graphs/oce/OCE.jl index 9370434a8..ad00084bb 100644 --- a/src/causal_graphs/oce/OCE.jl +++ b/src/causal_graphs/oce/OCE.jl @@ -492,7 +492,7 @@ end ######################################################################################### # Compatibility with Graphs.jl ######################################################################################### -function SimpleDiGraph(v::Vector{<:CausalityTools.OCESelectedParents}) +function SimpleDiGraph(v::Vector{<:Associations.OCESelectedParents}) N = length(v) g = SimpleDiGraph(N) for k = 1:N diff --git a/src/deprecations/predictive_asymmetry.jl b/src/deprecations/predictive_asymmetry.jl index c6c85026f..a5fd23088 100644 --- a/src/deprecations/predictive_asymmetry.jl +++ b/src/deprecations/predictive_asymmetry.jl @@ -67,7 +67,7 @@ # ## Examples # ```julia -# using CausalityTools +# using Associations # # Some example time series # x, y = rand(100), rand(100) # # 𝔸(x → y) over prediction lags 1:5 @@ -138,7 +138,7 @@ # function predictive_asymmetry(estimator::VALID_PA_ESTIMATORS, ηs, x::AbstractVector{<:Real}...; # normalize = false, f::Real = 1.0, # dTf = 1, dT = 1, dS = 1, dC = 1, τT = -1, τS = -1, τC = -1, base = 2) -# @warn """`predictive_asymmetry` will be deprecated in CausalityTools 2.0, \ +# @warn """`predictive_asymmetry` will be deprecated in Associations 2.0, \ # and moved to the "Experimental" section until it appears in a peer-reviewed journal. \ # It will reappear with a new signature in a 2.X release.""" # check_ηs(ηs) diff --git a/src/deprecations/v3/smeasure.jl b/src/deprecations/v3/smeasure.jl index 42c5ff26a..d5b82140e 100644 --- a/src/deprecations/v3/smeasure.jl +++ b/src/deprecations/v3/smeasure.jl @@ -14,7 +14,7 @@ synchronization for `s = 1.0`. ## Example ```julia -using CausalityTools +using Associations x, y = rand(1000), rand(1000) diff --git a/src/methods/information/counts_and_probs/encoding/codify_points.jl b/src/methods/information/counts_and_probs/encoding/codify_points.jl index c50f4fc94..0a53ce8e4 100644 --- a/src/methods/information/counts_and_probs/encoding/codify_points.jl +++ b/src/methods/information/counts_and_probs/encoding/codify_points.jl @@ -42,7 +42,7 @@ then that same encoding is applied to every `x[i]`. ## Examples ```julia -using CausalityTools +using Associations # The same encoding on two input datasets x = StateSpaceSet(rand(100, 3)) diff --git a/src/methods/information/counts_and_probs/encoding/codify_variables.jl b/src/methods/information/counts_and_probs/encoding/codify_variables.jl index e3215c6f9..5eaf4701e 100644 --- a/src/methods/information/counts_and_probs/encoding/codify_variables.jl +++ b/src/methods/information/counts_and_probs/encoding/codify_variables.jl @@ -43,7 +43,7 @@ values within each window to an integer. ## Examples ```julia -using CausalityTools +using Associations x, y = rand(100), rand(100) d = CodifyVariables(OrdinalPatterns(m=2)) cx, cy = codify(d, x, y) @@ -85,7 +85,7 @@ Codify each timeseries `xᵢ ∈ x` according to the given encoding/discretizati ## Examples ```julia -using CausalityTools +using Associations # Sliding window encoding x = [0.1, 0.2, 0.3, 0.2, 0.1, 0.0, 0.5, 0.3, 0.5] diff --git a/src/methods/information/definitions/divergences_and_distances/KLDivergence.jl b/src/methods/information/definitions/divergences_and_distances/KLDivergence.jl index b3d365713..1ad7eb6ac 100644 --- a/src/methods/information/definitions/divergences_and_distances/KLDivergence.jl +++ b/src/methods/information/definitions/divergences_and_distances/KLDivergence.jl @@ -41,7 +41,7 @@ D_{KL}(P_Y(\\Omega) || P_Y(\\Omega)) = !!! note Distances.jl also defines `KLDivergence`. Quality it if you're loading both - packages, i.e. do `association(CausalityTools.KLDivergence(), x, y)`. + packages, i.e. do `association(Associations.KLDivergence(), x, y)`. ## Estimation diff --git a/src/methods/information/definitions/divergences_and_distances/RenyiDivergence.jl b/src/methods/information/definitions/divergences_and_distances/RenyiDivergence.jl index 6b770df76..edaed3cb0 100644 --- a/src/methods/information/definitions/divergences_and_distances/RenyiDivergence.jl +++ b/src/methods/information/definitions/divergences_and_distances/RenyiDivergence.jl @@ -39,7 +39,7 @@ D_{q}(P_Y(\\Omega) || P_Y(\\Omega)) = !!! note Distances.jl also defines `RenyiDivergence`. Quality it if you're loading both - packages, i.e. do `association(CausalityTools.RenyiDivergence(), x, y)`. + packages, i.e. do `association(Associations.RenyiDivergence(), x, y)`. ## Estimation diff --git a/src/methods/information/definitions/transferentropy/embedding.jl b/src/methods/information/definitions/transferentropy/embedding.jl index 44fff70ff..83145cd0c 100644 --- a/src/methods/information/definitions/transferentropy/embedding.jl +++ b/src/methods/information/definitions/transferentropy/embedding.jl @@ -104,7 +104,7 @@ The total embedding is then the set of embedding vectors this to code, we get: ```jldoctest -using CausalityTools +using Associations julia> EmbeddingTE(dT=3, τT=[0, -5, -8], dS=2, τS=[-1, -4], ηTf=1) # output diff --git a/src/methods/information/estimators/conditional_mutual_info_estimators/MesnerShalizi.jl b/src/methods/information/estimators/conditional_mutual_info_estimators/MesnerShalizi.jl index 43a741678..f99766b41 100644 --- a/src/methods/information/estimators/conditional_mutual_info_estimators/MesnerShalizi.jl +++ b/src/methods/information/estimators/conditional_mutual_info_estimators/MesnerShalizi.jl @@ -22,7 +22,7 @@ number of temporal neighbors that are excluded during neighbor searches. ## Examples ```julia -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x = rand(rng, 10000) y = rand(rng, 10000) .+ x diff --git a/src/methods/information/estimators/conditional_mutual_info_estimators/PoczosSchneiderCMI.jl b/src/methods/information/estimators/conditional_mutual_info_estimators/PoczosSchneiderCMI.jl index 3792d83ff..0d1de616a 100644 --- a/src/methods/information/estimators/conditional_mutual_info_estimators/PoczosSchneiderCMI.jl +++ b/src/methods/information/estimators/conditional_mutual_info_estimators/PoczosSchneiderCMI.jl @@ -25,7 +25,7 @@ number of temporal neighbors that are excluded during neighbor searches. ## Examples ```julia -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x = rand(rng, 10000) y = rand(rng, 10000) .+ x diff --git a/src/methods/information/estimators/conditional_mutual_info_estimators/Rahimzamani.jl b/src/methods/information/estimators/conditional_mutual_info_estimators/Rahimzamani.jl index e13b47cdb..a86268aa6 100644 --- a/src/methods/information/estimators/conditional_mutual_info_estimators/Rahimzamani.jl +++ b/src/methods/information/estimators/conditional_mutual_info_estimators/Rahimzamani.jl @@ -27,7 +27,7 @@ number of temporal neighbors that are excluded during neighbor searches. ## Examples ```julia -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x = rand(rng, 10000) y = rand(rng, 10000) .+ x diff --git a/src/methods/information/estimators/mutual_info_estimators/GaoKannanOhViswanath.jl b/src/methods/information/estimators/mutual_info_estimators/GaoKannanOhViswanath.jl index 359677fd3..55ca8b36c 100644 --- a/src/methods/information/estimators/mutual_info_estimators/GaoKannanOhViswanath.jl +++ b/src/methods/information/estimators/mutual_info_estimators/GaoKannanOhViswanath.jl @@ -58,7 +58,7 @@ variables (by quantization) or making it continuous by adding a small Gaussian n ## Examples ```julia -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x = rand(rng, 10000); y = rand(rng, 10000) association(GaoKannanOhViswanath(; k = 10), x, y) # should be near 0 (and can be negative) diff --git a/src/methods/information/estimators/mutual_info_estimators/GaoOhViswanath.jl b/src/methods/information/estimators/mutual_info_estimators/GaoOhViswanath.jl index 071ec7f8e..4ecdfd6e5 100644 --- a/src/methods/information/estimators/mutual_info_estimators/GaoOhViswanath.jl +++ b/src/methods/information/estimators/mutual_info_estimators/GaoOhViswanath.jl @@ -41,7 +41,7 @@ volume of a ``d``-dimensional unit ``\\mathcal{l}_2``-ball. ## Example ```julia -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x = rand(rng, 10000); y = rand(rng, 10000) association(GaoOhViswanath(; k = 10), x, y) # should be near 0 (and can be negative) diff --git a/src/methods/information/estimators/mutual_info_estimators/GaussianMI.jl b/src/methods/information/estimators/mutual_info_estimators/GaussianMI.jl index 6d21ea660..d450187b4 100644 --- a/src/methods/information/estimators/mutual_info_estimators/GaussianMI.jl +++ b/src/methods/information/estimators/mutual_info_estimators/GaussianMI.jl @@ -62,7 +62,7 @@ where ``\\sigma_i`` are the eigenvalues for ``\\Sigma``. ## Example ```julia -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x = rand(rng, 10000); y = rand(rng, 10000) association(GaussianMI(), x, y) # should be near 0 (and can be negative) diff --git a/src/methods/information/estimators/mutual_info_estimators/KSG1.jl b/src/methods/information/estimators/mutual_info_estimators/KSG1.jl index 8809f9022..71adb71b0 100644 --- a/src/methods/information/estimators/mutual_info_estimators/KSG1.jl +++ b/src/methods/information/estimators/mutual_info_estimators/KSG1.jl @@ -44,7 +44,7 @@ short) is the ``I^{(1)}`` `k`-th nearest neighbor estimator from [Kraskov2004](@ ## Example ```julia -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x = rand(rng, 10000); y = rand(rng, 10000) association(KSG1(; k = 10), x, y) # should be near 0 (and can be negative) diff --git a/src/methods/information/estimators/mutual_info_estimators/KSG2.jl b/src/methods/information/estimators/mutual_info_estimators/KSG2.jl index 1362fae12..b05ca6aa8 100644 --- a/src/methods/information/estimators/mutual_info_estimators/KSG2.jl +++ b/src/methods/information/estimators/mutual_info_estimators/KSG2.jl @@ -66,7 +66,7 @@ then estimated as ## Example ```julia -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x = rand(rng, 10000); y = rand(rng, 10000) association(KSG2(; k = 10), x, y) # should be near 0 (and can be negative) diff --git a/src/methods/information/estimators/transfer_entropy_estimators/Lindner.jl b/src/methods/information/estimators/transfer_entropy_estimators/Lindner.jl index b6ece0920..d2d540502 100644 --- a/src/methods/information/estimators/transfer_entropy_estimators/Lindner.jl +++ b/src/methods/information/estimators/transfer_entropy_estimators/Lindner.jl @@ -51,7 +51,7 @@ conditioning too (a simple modification to [Lindner2011](@citet)'s equation 5 an ## Example ```julia -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x = rand(rng, 10000) y = rand(rng, 10000) .+ x diff --git a/src/methods/information/estimators/transfer_entropy_estimators/Zhu1.jl b/src/methods/information/estimators/transfer_entropy_estimators/Zhu1.jl index 71188add2..6107c4bb0 100644 --- a/src/methods/information/estimators/transfer_entropy_estimators/Zhu1.jl +++ b/src/methods/information/estimators/transfer_entropy_estimators/Zhu1.jl @@ -57,7 +57,7 @@ conditioning too (a simple modification to [Lindner2011](@citet)'s equation 5 an ## Example ```julia -using CausalityTools +using Associations using Random; rng = MersenneTwister(1234) x = rand(rng, 10000) y = rand(rng, 10000) .+ x diff --git a/test/causal_graphs/oce.jl b/test/causal_graphs/oce.jl index a3a124abd..1f9f7d406 100644 --- a/test/causal_graphs/oce.jl +++ b/test/causal_graphs/oce.jl @@ -1,5 +1,5 @@ -using CausalityTools -using CausalityTools: OCESelectedParents +using Associations +using Associations: OCESelectedParents using Test using StableRNGs using Graphs.SimpleGraphs: SimpleEdge diff --git a/test/independence/JointDistanceDistributionTest.jl b/test/independence/JointDistanceDistributionTest.jl index 2bdaeda5a..33d49c529 100644 --- a/test/independence/JointDistanceDistributionTest.jl +++ b/test/independence/JointDistanceDistributionTest.jl @@ -4,7 +4,7 @@ x, y = randn(rng, 1000), randn(rng, 1000) m = JointDistanceDistribution(D = 3, B = 5) test = JointDistanceDistributionTest(m) @test test isa JointDistanceDistributionTest -@test independence(test, x, y) isa CausalityTools.JDDTestResult +@test independence(test, x, y) isa Associations.JDDTestResult # Don't reject null at significance level (1 - α) when there is no coupling. α = 0.05 diff --git a/test/independence/LocalPermutationTest/api.jl b/test/independence/LocalPermutationTest/api.jl index f6ac52d37..5430fc1fc 100644 --- a/test/independence/LocalPermutationTest/api.jl +++ b/test/independence/LocalPermutationTest/api.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using StableRNGs rng = StableRNG(123) @@ -41,18 +41,18 @@ independence_test = LocalPermutationTest(FPVP(CMIShannon()), nshuffles = 2) res = independence(independence_test, x, z, y) # Internals -out_str_pval = repr( CausalityTools.pvalue_text_summary(res)) +out_str_pval = repr( Associations.pvalue_text_summary(res)) @test occursin("p-value:", out_str_pval) # Internals -out_str_pval = repr( CausalityTools.quantiles_text(res)) +out_str_pval = repr( Associations.quantiles_text(res)) @test occursin("Ensemble quantiles", out_str_pval) -out_str_conclusion = repr( CausalityTools.null_hypothesis_text(res)) +out_str_conclusion = repr( Associations.null_hypothesis_text(res)) @test occursin("The first two variables are independent, given the 3rd variable", out_str_conclusion) independence_test = SurrogateAssociationTest(KSG1(MIShannon())) res = independence(independence_test, x, y) -out_str_conclusion = repr( CausalityTools.null_hypothesis_text(res)) +out_str_conclusion = repr( Associations.null_hypothesis_text(res)) @test occursin("The variables are independent", out_str_conclusion) diff --git a/test/independence/LocalPermutationTest/conditional_mutual_information.jl b/test/independence/LocalPermutationTest/conditional_mutual_information.jl index 864054d89..4c092fef6 100644 --- a/test/independence/LocalPermutationTest/conditional_mutual_information.jl +++ b/test/independence/LocalPermutationTest/conditional_mutual_information.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using StableRNGs rng = StableRNG(123) diff --git a/test/independence/LocalPermutationTest/distance_correlation.jl b/test/independence/LocalPermutationTest/distance_correlation.jl index 89c28c8bf..101b25297 100644 --- a/test/independence/LocalPermutationTest/distance_correlation.jl +++ b/test/independence/LocalPermutationTest/distance_correlation.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using StableRNGs rng = StableRNG(123) diff --git a/test/independence/LocalPermutationTest/part_mutual_information.jl b/test/independence/LocalPermutationTest/part_mutual_information.jl index 156cc1621..a808677bb 100644 --- a/test/independence/LocalPermutationTest/part_mutual_information.jl +++ b/test/independence/LocalPermutationTest/part_mutual_information.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using StableRNGs rng = StableRNG(123) diff --git a/test/independence/LocalPermutationTest/partial_correlation.jl b/test/independence/LocalPermutationTest/partial_correlation.jl index 8e842d3e9..0946bb824 100644 --- a/test/independence/LocalPermutationTest/partial_correlation.jl +++ b/test/independence/LocalPermutationTest/partial_correlation.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using StableRNGs rng = StableRNG(123) diff --git a/test/independence/LocalPermutationTest/transferentropy.jl b/test/independence/LocalPermutationTest/transferentropy.jl index a1134a828..c624ad514 100644 --- a/test/independence/LocalPermutationTest/transferentropy.jl +++ b/test/independence/LocalPermutationTest/transferentropy.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using StableRNGs rng = StableRNG(123) diff --git a/test/independence/PATest.jl b/test/independence/PATest.jl index 9841720a7..4f4a0220c 100644 --- a/test/independence/PATest.jl +++ b/test/independence/PATest.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using DynamicalSystemsBase using Random diff --git a/test/methods/correlation/distance_correlation.jl b/test/methods/correlation/distance_correlation.jl index 409830538..34214c779 100644 --- a/test/methods/correlation/distance_correlation.jl +++ b/test/methods/correlation/distance_correlation.jl @@ -4,7 +4,7 @@ using Test # ----------------- a = StateSpaceSet(repeat([1], 100)) # TODO: export this method? -@test CausalityTools.distance_variance(a) == 0.0 +@test Associations.distance_variance(a) == 0.0 v = rand(1000, 3); w = 0.5 .* v .+ 1.2; @test association(DistanceCorrelation(), v, w) ≈ 1.0 @@ -20,17 +20,17 @@ dcov = association(DistanceCorrelation(), x, y) # ---------------------------- # Test internals by checking that we get the same answer as in the R `energy` package. M = reshape([0.0, 0.2, 0.3, 0.2, 0.0, 0.6, 0.3, 0.6, 0.3], 3, 3) -@test CausalityTools.ucenter(M) ≈ +@test Associations.ucenter(M) ≈ [0 0.15 -0.15; 0.15 0.0 -0.15; -0.15 -0.15 0.0] @test round(association(DistanceCorrelation(), x, z, y), digits = 5) ≈ round(0.1556139, digits = 5) -@test round(CausalityTools.distance_covariance(x, z, y), digits = 5) ≈ round(0.02379782, digits = 5) +@test round(Associations.distance_covariance(x, z, y), digits = 5) ≈ round(0.02379782, digits = 5) # Deprecations @test_logs (:warn, "Convenience function `distance_correlation` is deprecated. Use `association(DistanceCorrelation(), x, y)` instead.") distance_correlation(x, y) @test_logs (:warn, "Convenience function `distance_correlation` is deprecated. Use `association(DistanceCorrelation(), x, y, z)` instead.") distance_correlation(x, y, z) -@test CausalityTools.min_inputs_vars(DistanceCorrelation()) == 2 -@test CausalityTools.max_inputs_vars(DistanceCorrelation()) == 3 \ No newline at end of file +@test Associations.min_inputs_vars(DistanceCorrelation()) == 2 +@test Associations.max_inputs_vars(DistanceCorrelation()) == 3 \ No newline at end of file diff --git a/test/methods/correlation/partial_correlation.jl b/test/methods/correlation/partial_correlation.jl index 93f84c97d..e6ac1e3e8 100644 --- a/test/methods/correlation/partial_correlation.jl +++ b/test/methods/correlation/partial_correlation.jl @@ -8,5 +8,5 @@ z = rand(100, 2) @test_logs (:warn, "Convenience function `partial_correlation` is deprecated. Use `association(PartialCorrelation(), x, y, z)` instead.") partial_correlation(x, y, z) -@test CausalityTools.min_inputs_vars(PartialCorrelation()) == 3 -@test CausalityTools.max_inputs_vars(PartialCorrelation()) == Inf \ No newline at end of file +@test Associations.min_inputs_vars(PartialCorrelation()) == 3 +@test Associations.max_inputs_vars(PartialCorrelation()) == Inf \ No newline at end of file diff --git a/test/methods/cross_mappings/ccm_like.jl b/test/methods/cross_mappings/ccm_like.jl index ee984e578..ec9f4fe0a 100644 --- a/test/methods/cross_mappings/ccm_like.jl +++ b/test/methods/cross_mappings/ccm_like.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using StateSpaceSets using Random rng = Xoshiro(1234) @@ -38,24 +38,24 @@ rng = Xoshiro(1234) @testset "Embed using CCM" begin x, y = rand(rng, 100), rand(rng, 100) # Embedding - d, colidx_target, colidxs_source = CausalityTools.embed(ConvergentCrossMapping(), x, y) + d, colidx_target, colidxs_source = Associations.embed(ConvergentCrossMapping(), x, y) @test d isa AbstractStateSpaceSet @test colidx_target isa Int @test colidxs_source isa AbstractVector{Int} # Segment length - @test CausalityTools.max_segmentlength(def, rand(10)) == 10 - 2 + 1 + @test Associations.max_segmentlength(def, rand(10)) == 10 - 2 + 1 def = ConvergentCrossMapping(d = 2) # Num of neighbors def = ConvergentCrossMapping(d = 2) - @test CausalityTools.n_neighbors_simplex(def) == 3 + @test Associations.n_neighbors_simplex(def) == 3 # If using forward embedding, warn. msg = """τ > 0. You're using future values of source to predict the target. Turn \ off this warning by setting `embed_warn = false` in the \ `PairwiseAsymmetricInference` constructor.""" - @test_warn msg CausalityTools.embed(ConvergentCrossMapping(τ = 1), x, y) + @test_warn msg Associations.embed(ConvergentCrossMapping(τ = 1), x, y) end end @@ -81,24 +81,24 @@ end @testset "Embed using CCM" begin x, y = rand(rng, 100), rand(rng, 100) # Embedding - d, colidx_target, colidxs_source = CausalityTools.embed(def, x, y) + d, colidx_target, colidxs_source = Associations.embed(def, x, y) @test d isa AbstractStateSpaceSet @test colidx_target isa Int @test colidxs_source isa AbstractVector{Int} # Segment length - @test CausalityTools.max_segmentlength(def, rand(10)) == 10 - 2 + 1 + @test Associations.max_segmentlength(def, rand(10)) == 10 - 2 + 1 def = ConvergentCrossMapping(d = 2) # Num of neighbors def = ConvergentCrossMapping(d = 2) - @test CausalityTools.n_neighbors_simplex(def) == 3 + @test Associations.n_neighbors_simplex(def) == 3 # If using forward embedding, warn. msg = """τ > 0. You're using future values of source to predict the target. Turn \ off this warning by setting `embed_warn = false` in the \ `PairwiseAsymmetricInference` constructor.""" - @test_warn msg CausalityTools.embed(ConvergentCrossMapping(τ = 1), x, y) + @test_warn msg Associations.embed(ConvergentCrossMapping(τ = 1), x, y) end end diff --git a/test/methods/information/conditional_entropies/ce_shannon.jl b/test/methods/information/conditional_entropies/ce_shannon.jl index 3f9790140..371feebe6 100644 --- a/test/methods/information/conditional_entropies/ce_shannon.jl +++ b/test/methods/information/conditional_entropies/ce_shannon.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using Random rng = Xoshiro(1234) @@ -7,8 +7,8 @@ rng = Xoshiro(1234) # Internals # --------------- def = ConditionalEntropyShannon() -@test CausalityTools.min_inputs_vars(def) == 2 -@test CausalityTools.max_inputs_vars(def) == 2 +@test Associations.min_inputs_vars(def) == 2 +@test Associations.max_inputs_vars(def) == 2 p_nonzeros = Probabilities([0.5 0.5; 0.1 0.1 ]) p_zeros = Probabilities([0.5 0.0; 0.1 0.1]) diff --git a/test/methods/information/conditional_entropies/ce_tsallis_abe.jl b/test/methods/information/conditional_entropies/ce_tsallis_abe.jl index 7cc7e929e..7a59e5e9c 100644 --- a/test/methods/information/conditional_entropies/ce_tsallis_abe.jl +++ b/test/methods/information/conditional_entropies/ce_tsallis_abe.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using Random @@ -7,8 +7,8 @@ using Random # Internals # --------------- def = ConditionalEntropyTsallisAbe() -@test CausalityTools.min_inputs_vars(def) == 2 -@test CausalityTools.max_inputs_vars(def) == 2 +@test Associations.min_inputs_vars(def) == 2 +@test Associations.max_inputs_vars(def) == 2 # --------------------------------------------------------------------------------------- diff --git a/test/methods/information/conditional_entropies/ce_tsallis_furuichi.jl b/test/methods/information/conditional_entropies/ce_tsallis_furuichi.jl index 55f3b1766..94220598b 100644 --- a/test/methods/information/conditional_entropies/ce_tsallis_furuichi.jl +++ b/test/methods/information/conditional_entropies/ce_tsallis_furuichi.jl @@ -1,12 +1,12 @@ using Test -using CausalityTools +using Associations # --------------- # Internals # --------------- def = ConditionalEntropyTsallisFuruichi() -@test CausalityTools.min_inputs_vars(def) == 2 -@test CausalityTools.max_inputs_vars(def) == 2 +@test Associations.min_inputs_vars(def) == 2 +@test Associations.max_inputs_vars(def) == 2 # --------------------------------------------------------------------------------------- diff --git a/test/methods/information/conditional_mutual_informations/cmi_renyi_jizba.jl b/test/methods/information/conditional_mutual_informations/cmi_renyi_jizba.jl index 5355fcdc6..fb64ad9be 100644 --- a/test/methods/information/conditional_mutual_informations/cmi_renyi_jizba.jl +++ b/test/methods/information/conditional_mutual_informations/cmi_renyi_jizba.jl @@ -1,4 +1,4 @@ -using CausalityTools +using Associations using Test # --------------- diff --git a/test/methods/information/conditional_mutual_informations/cmi_renyi_poczos.jl b/test/methods/information/conditional_mutual_informations/cmi_renyi_poczos.jl index 833d945c8..e7398e0cc 100644 --- a/test/methods/information/conditional_mutual_informations/cmi_renyi_poczos.jl +++ b/test/methods/information/conditional_mutual_informations/cmi_renyi_poczos.jl @@ -1,6 +1,6 @@ using Test -using CausalityTools +using Associations using Random rng = MersenneTwister(1234) @@ -13,8 +13,8 @@ z = randn(rng, 50) # Internals # --------------- def = CMIRenyiPoczos() -@test CausalityTools.min_inputs_vars(def) == 3 -@test CausalityTools.max_inputs_vars(def) == 3 +@test Associations.min_inputs_vars(def) == 3 +@test Associations.max_inputs_vars(def) == 3 # --------------------------------------------------------------------------------------- # Test all possible ways of estimating `CMIRenyiPoczos`. diff --git a/test/methods/information/conditional_mutual_informations/cmi_renyi_sarbu.jl b/test/methods/information/conditional_mutual_informations/cmi_renyi_sarbu.jl index 55c1cf940..217f0ba22 100644 --- a/test/methods/information/conditional_mutual_informations/cmi_renyi_sarbu.jl +++ b/test/methods/information/conditional_mutual_informations/cmi_renyi_sarbu.jl @@ -1,16 +1,16 @@ using Test -using CausalityTools +using Associations def = CMIRenyiSarbu() -@test CausalityTools.min_inputs_vars(def) == 3 -@test CausalityTools.max_inputs_vars(def) == 3 +@test Associations.min_inputs_vars(def) == 3 +@test Associations.max_inputs_vars(def) == 3 # --------------- # Internals # --------------- def = CMIRenyiSarbu() -@test CausalityTools.min_inputs_vars(def) == 3 -@test CausalityTools.max_inputs_vars(def) == 3 +@test Associations.min_inputs_vars(def) == 3 +@test Associations.max_inputs_vars(def) == 3 # Double-sum estimation. x = rand(["a", "b", "c"], 50) diff --git a/test/methods/information/conditional_mutual_informations/cmi_shannon.jl b/test/methods/information/conditional_mutual_informations/cmi_shannon.jl index 531b151cf..2a44b51e5 100644 --- a/test/methods/information/conditional_mutual_informations/cmi_shannon.jl +++ b/test/methods/information/conditional_mutual_informations/cmi_shannon.jl @@ -1,6 +1,6 @@ using Test -using CausalityTools +using Associations using Random rng = MersenneTwister(1234) @@ -8,8 +8,8 @@ rng = MersenneTwister(1234) # Internals # --------------- def = CMIShannon() -@test CausalityTools.min_inputs_vars(def) == 3 -@test CausalityTools.max_inputs_vars(def) == 3 +@test Associations.min_inputs_vars(def) == 3 +@test Associations.max_inputs_vars(def) == 3 # --------------- # Input checks diff --git a/test/methods/information/conditional_mutual_informations/cmi_tsallis_papetrou.jl b/test/methods/information/conditional_mutual_informations/cmi_tsallis_papetrou.jl index 32d96e3d1..612893a85 100644 --- a/test/methods/information/conditional_mutual_informations/cmi_tsallis_papetrou.jl +++ b/test/methods/information/conditional_mutual_informations/cmi_tsallis_papetrou.jl @@ -1,11 +1,11 @@ using Test -using CausalityTools +using Associations # --------------- # Internals # --------------- def = CMITsallisPapapetrou() -@test CausalityTools.min_inputs_vars(def) == 3 -@test CausalityTools.max_inputs_vars(def) == 3 +@test Associations.min_inputs_vars(def) == 3 +@test Associations.max_inputs_vars(def) == 3 # --------------------------------------------------------------------------------------- # Test all possible ways of estimating `CMIRenyiJizba`. diff --git a/test/methods/information/core/counts.jl b/test/methods/information/core/counts.jl index ade38e27d..f465b5d7b 100644 --- a/test/methods/information/core/counts.jl +++ b/test/methods/information/core/counts.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using Random rng = Xoshiro(1234) @@ -64,7 +64,7 @@ d_row = CodifyPoints(OrdinalPatternEncoding{2}()); # Multiple outcome spaces with the same cardinality with `CodifyVariables` using Test -using CausalityTools +using Associations using Random; rng = Xoshiro(1234) x, y = rand(rng, 100), rand(rng, 100) # We must use outcome spaces with the same number of total outcomes. diff --git a/test/methods/information/core/encoding.jl b/test/methods/information/core/encoding.jl index 14d106b1d..4fc152d84 100644 --- a/test/methods/information/core/encoding.jl +++ b/test/methods/information/core/encoding.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using Random rng = Xoshiro(1234) diff --git a/test/methods/information/core/probabilities.jl b/test/methods/information/core/probabilities.jl index 1e6d04377..c154a17fd 100644 --- a/test/methods/information/core/probabilities.jl +++ b/test/methods/information/core/probabilities.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using Random rng = Xoshiro(1234) diff --git a/test/methods/information/distances_and_divergences/hellinger_distance.jl b/test/methods/information/distances_and_divergences/hellinger_distance.jl index 7b41f54be..fc3c7a00e 100644 --- a/test/methods/information/distances_and_divergences/hellinger_distance.jl +++ b/test/methods/information/distances_and_divergences/hellinger_distance.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations # There should be zero information gain from `x` over `y` for independent random variables. using Random diff --git a/test/methods/information/distances_and_divergences/kl_divergence.jl b/test/methods/information/distances_and_divergences/kl_divergence.jl index 34578746f..000fe28fe 100644 --- a/test/methods/information/distances_and_divergences/kl_divergence.jl +++ b/test/methods/information/distances_and_divergences/kl_divergence.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations # There should be zero information gain from `x` over `y` for independent random variables. using Random diff --git a/test/methods/information/distances_and_divergences/renyi_divergence.jl b/test/methods/information/distances_and_divergences/renyi_divergence.jl index ffe6ff84b..6c2f127f0 100644 --- a/test/methods/information/distances_and_divergences/renyi_divergence.jl +++ b/test/methods/information/distances_and_divergences/renyi_divergence.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations # There should be zero information gain from `x` over `y` for independent random variables. using Random diff --git a/test/methods/information/estimators/joint.jl b/test/methods/information/estimators/joint.jl index 90c5ca1d0..744f83e2f 100644 --- a/test/methods/information/estimators/joint.jl +++ b/test/methods/information/estimators/joint.jl @@ -1,4 +1,4 @@ -using CausalityTools +using Associations using Test using Random rng = Xoshiro(1234) diff --git a/test/methods/information/internal_api.jl b/test/methods/information/internal_api.jl index f46792d59..b7b025459 100644 --- a/test/methods/information/internal_api.jl +++ b/test/methods/information/internal_api.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations # ---------------------------------------------------------------- # This file tests internal functions. @@ -11,9 +11,9 @@ est_renyi = PlugIn(Renyi(; q = 0.5, base = 2)) est_tsallis = PlugIn(Tsallis(; q = 0.5, base = 2)) est_shannon = PlugIn(Shannon(; base = 2)) -new_est_renyi = CausalityTools.estimator_with_overridden_parameters(def_renyi, est_renyi) -new_est_tsallis = CausalityTools.estimator_with_overridden_parameters(def_tsallis, est_tsallis) -new_est_shannon = CausalityTools.estimator_with_overridden_parameters(def_shannon, est_shannon) +new_est_renyi = Associations.estimator_with_overridden_parameters(def_renyi, est_renyi) +new_est_tsallis = Associations.estimator_with_overridden_parameters(def_tsallis, est_tsallis) +new_est_shannon = Associations.estimator_with_overridden_parameters(def_shannon, est_shannon) @test new_est_renyi == PlugIn(Renyi(; q = 5, base = 5)) @test new_est_tsallis == PlugIn(Tsallis(; q = 5, base = 5)) @test new_est_shannon == PlugIn(Shannon(; base = 5)) @@ -21,7 +21,7 @@ new_est_shannon = CausalityTools.estimator_with_overridden_parameters(def_shanno p1 = Probabilities([0.1, 0.2, 0.3]) p2 = Probabilities([0.1, 0.2, 0.3, 0.4]) -@test_throws DimensionMismatch CausalityTools.size_match(KLDivergence(), p1, p2) +@test_throws DimensionMismatch Associations.size_match(KLDivergence(), p1, p2) struct BogusMeasure2{M} <: MultivariateInformationMeasure def::M diff --git a/test/methods/information/joint_entropies/joint_entropy_renyi.jl b/test/methods/information/joint_entropies/joint_entropy_renyi.jl index a755f6630..46167e8d4 100644 --- a/test/methods/information/joint_entropies/joint_entropy_renyi.jl +++ b/test/methods/information/joint_entropies/joint_entropy_renyi.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations x = rand(["a", "b", "c"], 200) y = rand(["hello", "yoyo", "heyhey"], 200) diff --git a/test/methods/information/joint_entropies/joint_entropy_shannon.jl b/test/methods/information/joint_entropies/joint_entropy_shannon.jl index db7bc14d8..179182d18 100644 --- a/test/methods/information/joint_entropies/joint_entropy_shannon.jl +++ b/test/methods/information/joint_entropies/joint_entropy_shannon.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations x = rand(["a", "b", "c"], 200) y = rand(["hello", "yoyo", "heyhey"], 200) diff --git a/test/methods/information/joint_entropies/joint_entropy_tsallis.jl b/test/methods/information/joint_entropies/joint_entropy_tsallis.jl index b48f4965e..532f8a272 100644 --- a/test/methods/information/joint_entropies/joint_entropy_tsallis.jl +++ b/test/methods/information/joint_entropies/joint_entropy_tsallis.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations x = rand(["a", "b", "c"], 200) y = rand(["hello", "yoyo", "heyhey"], 200) diff --git a/test/methods/information/mutual_informations/api.jl b/test/methods/information/mutual_informations/api.jl index 8d12e6362..5af0ffe5d 100644 --- a/test/methods/information/mutual_informations/api.jl +++ b/test/methods/information/mutual_informations/api.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using Random rng = MersenneTwister(1234) diff --git a/test/methods/information/mutual_informations/mi_renyi_jizba.jl b/test/methods/information/mutual_informations/mi_renyi_jizba.jl index c082d6f92..9ecb0aff3 100644 --- a/test/methods/information/mutual_informations/mi_renyi_jizba.jl +++ b/test/methods/information/mutual_informations/mi_renyi_jizba.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using Random rng = MersenneTwister(1234) diff --git a/test/methods/information/mutual_informations/mi_renyi_sarbu.jl b/test/methods/information/mutual_informations/mi_renyi_sarbu.jl index 545e8ddf1..617019e89 100644 --- a/test/methods/information/mutual_informations/mi_renyi_sarbu.jl +++ b/test/methods/information/mutual_informations/mi_renyi_sarbu.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations # Double-sum estimation. x = rand(["a", "b", "c"], 200) diff --git a/test/methods/information/mutual_informations/mi_shannon.jl b/test/methods/information/mutual_informations/mi_shannon.jl index 75d4e5396..fbd1686b7 100644 --- a/test/methods/information/mutual_informations/mi_shannon.jl +++ b/test/methods/information/mutual_informations/mi_shannon.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using Random rng = MersenneTwister(1234) def = MIShannon() diff --git a/test/methods/information/mutual_informations/mi_tsallis_furuichi.jl b/test/methods/information/mutual_informations/mi_tsallis_furuichi.jl index 80b6309ae..dfe2e1999 100644 --- a/test/methods/information/mutual_informations/mi_tsallis_furuichi.jl +++ b/test/methods/information/mutual_informations/mi_tsallis_furuichi.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using Random rng = Xoshiro(1234) diff --git a/test/methods/information/mutual_informations/mi_tsallis_martin.jl b/test/methods/information/mutual_informations/mi_tsallis_martin.jl index 5f0c5f238..c61047b1b 100644 --- a/test/methods/information/mutual_informations/mi_tsallis_martin.jl +++ b/test/methods/information/mutual_informations/mi_tsallis_martin.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using Random rng = Xoshiro(1234) diff --git a/test/methods/information/transfer_entropies/te_renyi_jizba.jl b/test/methods/information/transfer_entropies/te_renyi_jizba.jl index b098f71eb..58714e0ea 100644 --- a/test/methods/information/transfer_entropies/te_renyi_jizba.jl +++ b/test/methods/information/transfer_entropies/te_renyi_jizba.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using Random rng = MersenneTwister(1234) diff --git a/test/methods/information/transfer_entropies/te_shannon.jl b/test/methods/information/transfer_entropies/te_shannon.jl index dc2358d9d..5a39543fb 100644 --- a/test/methods/information/transfer_entropies/te_shannon.jl +++ b/test/methods/information/transfer_entropies/te_shannon.jl @@ -1,5 +1,5 @@ using Test -using CausalityTools +using Associations using DynamicalSystemsBase using Random rng = Xoshiro(1234) @@ -67,7 +67,7 @@ est = Hilbert(est_te) @test association(Hilbert(est, source = Amplitude(), target = Amplitude(), cond = Amplitude() ), x, y, z) >= 0.0 @test association(Hilbert(est, source = Phase(), target = Phase(), cond = Amplitude() ), x, y, z) >= 0.0 -struct SillySignalProperty <: CausalityTools.InstantaneousSignalProperty +struct SillySignalProperty <: Associations.InstantaneousSignalProperty end @test_throws ArgumentError association(Hilbert(est, source = SillySignalProperty()), x, y) @test_throws ArgumentError association(Hilbert(est, target = SillySignalProperty()), x, y) diff --git a/test/methods/information/transfer_entropies/utils.jl b/test/methods/information/transfer_entropies/utils.jl index fd1d26412..ac1cadcf0 100644 --- a/test/methods/information/transfer_entropies/utils.jl +++ b/test/methods/information/transfer_entropies/utils.jl @@ -17,12 +17,12 @@ x, y, z = rand(100), rand(100), rand(100) # Internals that we may not necessarily hit using random input data. # ---------------------------------------------------------------- emb = EmbeddingTE(OptimiseTraditional(), x, y, z) -pts, vars, τs, js = CausalityTools.te_embed(emb, x, y) +pts, vars, τs, js = Associations.te_embed(emb, x, y) @test occursin("Tf = ", repr(vars)) # TEVars -vars1 = CausalityTools.TEVars([1], [2], [3]) -vars2 = CausalityTools.TEVars([1], [2], [3], Int[]) +vars1 = Associations.TEVars([1], [2], [3]) +vars2 = Associations.TEVars([1], [2], [3], Int[]) @test vars1.C == vars2.C # rc @@ -30,7 +30,7 @@ vars2 = CausalityTools.TEVars([1], [2], [3], Int[]) x = rand(100) X = StateSpaceSet(rand(100)) -rc = CausalityTools.rc +rc = Associations.rc # If multiple lags are given, and the dimension is an integer, then the number of # lags must match the dimension. ds = 4 diff --git a/test/runtests.jl b/test/runtests.jl index 96f50ec71..aaafd1eeb 100644 --- a/test/runtests.jl +++ b/test/runtests.jl @@ -1,9 +1,9 @@ using Test -using CausalityTools +using Associations defaultname(file) = uppercasefirst(replace(splitext(basename(file))[1], '_' => ' ')) testfile(file, testname=defaultname(file)) = @testset "$testname" begin; include(file); end -@testset "CausalityTools.jl" begin +@testset "Associations.jl" begin include("test_systems.jl") testfile("deprecations.jl") testfile("methods/methods.jl")