From 760bcbf842cc5dd384758d3eb2abe44a8ec43a6c Mon Sep 17 00:00:00 2001 From: Anubhav-Goyal01 Date: Fri, 1 Sep 2023 16:22:11 +0530 Subject: [PATCH 1/2] empirical_covariance implementation (sklearn) --- .../frontends/sklearn/covariance/__init__.py | 2 ++ .../covariance/_empirical_covariance.py | 18 +++++++++++ .../test_empirical_covariance.py | 31 +++++++++++++++++++ 3 files changed, 51 insertions(+) create mode 100644 ivy/functional/frontends/sklearn/covariance/__init__.py create mode 100644 ivy/functional/frontends/sklearn/covariance/_empirical_covariance.py create mode 100644 ivy_tests/test_ivy/test_frontends/test_sklearn/test_covariance/test_empirical_covariance.py diff --git a/ivy/functional/frontends/sklearn/covariance/__init__.py b/ivy/functional/frontends/sklearn/covariance/__init__.py new file mode 100644 index 0000000000000..b8e859ea75ffa --- /dev/null +++ b/ivy/functional/frontends/sklearn/covariance/__init__.py @@ -0,0 +1,2 @@ +from . import _empirical_covariance +from ._empirical_covariance import * \ No newline at end of file diff --git a/ivy/functional/frontends/sklearn/covariance/_empirical_covariance.py b/ivy/functional/frontends/sklearn/covariance/_empirical_covariance.py new file mode 100644 index 0000000000000..dd83fdfc00cac --- /dev/null +++ b/ivy/functional/frontends/sklearn/covariance/_empirical_covariance.py @@ -0,0 +1,18 @@ +import ivy +from ivy.functional.frontends.numpy import to_ivy_arrays_and_back + +@to_ivy_arrays_and_back +def empirical_covariance(X, *, assume_centered = False): + if X.ndim == 1: + X = ivy.reshape(X, (1, -1)) + + if assume_centered: + covariance = ivy.dot(X.T, X) / X.shape[0] + else: + covariance = ivy.cov(X.T, bias = 1) + + + if covariance.ndim == 0: + covariance = ivy.array([[covariance]]) + + return covariance \ No newline at end of file diff --git a/ivy_tests/test_ivy/test_frontends/test_sklearn/test_covariance/test_empirical_covariance.py b/ivy_tests/test_ivy/test_frontends/test_sklearn/test_covariance/test_empirical_covariance.py new file mode 100644 index 0000000000000..7ccf1b485b31a --- /dev/null +++ b/ivy_tests/test_ivy/test_frontends/test_sklearn/test_covariance/test_empirical_covariance.py @@ -0,0 +1,31 @@ +import ivy_tests.test_ivy.helpers as helpers +from ivy_tests.test_ivy.helpers import handle_frontend_test +from hypothesis import strategies as st + +@handle_frontend_test( + fn_tree="sklearn.covariance.empirical_covariance", + dtype_and_x=helpers.dtype_and_values( + available_dtypes=helpers.get_dtypes("valid"), + ), + assume_centered = st.booleans() +) +def test_sklearn_empirical_covariance( + dtype_and_x, + on_device, + assume_centered, + fn_tree, + frontend, + test_flags, + backend_fw, +): + dtypes, x = dtype_and_x + helpers.test_frontend_function( + input_dtypes=dtypes, + backend_to_test=backend_fw, + test_flags=test_flags, + fn_tree=fn_tree, + frontend=frontend, + on_device=on_device, + X=x[0], + assume_centered=assume_centered + ) \ No newline at end of file From b8e7de7dee6a61f7ac2a91d096c7780c021db5b0 Mon Sep 17 00:00:00 2001 From: Anubhav-Goyal01 Date: Sat, 2 Sep 2023 12:00:30 +0530 Subject: [PATCH 2/2] fixed float dtype error --- .../frontends/sklearn/covariance/_empirical_covariance.py | 8 +++++--- .../test_covariance/test_empirical_covariance.py | 6 +++++- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/ivy/functional/frontends/sklearn/covariance/_empirical_covariance.py b/ivy/functional/frontends/sklearn/covariance/_empirical_covariance.py index dd83fdfc00cac..fe67edde5183a 100644 --- a/ivy/functional/frontends/sklearn/covariance/_empirical_covariance.py +++ b/ivy/functional/frontends/sklearn/covariance/_empirical_covariance.py @@ -11,8 +11,10 @@ def empirical_covariance(X, *, assume_centered = False): else: covariance = ivy.cov(X.T, bias = 1) - if covariance.ndim == 0: covariance = ivy.array([[covariance]]) - - return covariance \ No newline at end of file + + if ivy.is_complex_dtype(X): + return covariance.astype(ivy.complex128) + + return covariance.astype(ivy.float64) diff --git a/ivy_tests/test_ivy/test_frontends/test_sklearn/test_covariance/test_empirical_covariance.py b/ivy_tests/test_ivy/test_frontends/test_sklearn/test_covariance/test_empirical_covariance.py index 7ccf1b485b31a..b7d56862c7c51 100644 --- a/ivy_tests/test_ivy/test_frontends/test_sklearn/test_covariance/test_empirical_covariance.py +++ b/ivy_tests/test_ivy/test_frontends/test_sklearn/test_covariance/test_empirical_covariance.py @@ -5,7 +5,11 @@ @handle_frontend_test( fn_tree="sklearn.covariance.empirical_covariance", dtype_and_x=helpers.dtype_and_values( - available_dtypes=helpers.get_dtypes("valid"), + available_dtypes= helpers.get_dtypes("valid"), + min_num_dims=1, + max_num_dims=2, + min_dim_size=1, + max_dim_size=3, ), assume_centered = st.booleans() )