scikit-learn-intelex 2025.7.0__py310-none-win_amd64.whl → 2025.8.0__py310-none-win_amd64.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of scikit-learn-intelex might be problematic. Click here for more details.
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/_daal4py.cp310-win_amd64.pyd +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/mpi_transceiver.cp310-win_amd64.pyd +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/linear_model/logistic_loss.py +4 -4
- scikit_learn_intelex-2025.8.0.data/data/Lib/site-packages/daal4py/sklearn/linear_model/logistic_path.py +616 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/_device_offload.py +41 -40
- scikit_learn_intelex-2025.8.0.data/data/Lib/site-packages/onedal/_onedal_py_dpc.cp310-win_amd64.pyd +0 -0
- scikit_learn_intelex-2025.8.0.data/data/Lib/site-packages/onedal/_onedal_py_host.cp310-win_amd64.pyd +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/basic_statistics/basic_statistics.py +52 -76
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/basic_statistics/incremental_basic_statistics.py +26 -41
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/basic_statistics/tests/test_basic_statistics.py +6 -7
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/basic_statistics/tests/test_incremental_basic_statistics.py +11 -11
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/cluster/dbscan.py +7 -25
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/cluster/kmeans.py +1 -1
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/common/hyperparameters.py +31 -11
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/common/tests/test_sycl.py +5 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/covariance/covariance.py +8 -10
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/datatypes/__init__.py +6 -3
- scikit_learn_intelex-2025.8.0.data/data/Lib/site-packages/onedal/datatypes/_data_conversion.py +156 -0
- scikit_learn_intelex-2025.8.0.data/data/Lib/site-packages/onedal/datatypes/_dlpack.py +61 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/datatypes/_sycl_usm.py +9 -24
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/datatypes/tests/test_data.py +16 -17
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/ensemble/forest.py +5 -5
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/linear_model/incremental_linear_model.py +48 -160
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/linear_model/linear_model.py +75 -188
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/linear_model/logistic_regression.py +5 -10
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/linear_model/tests/test_linear_regression.py +10 -17
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/tests/test_common.py +14 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/utils/_array_api.py +3 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/utils/_sycl_queue_manager.py +51 -25
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/utils/_third_party.py +52 -2
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/__init__.py +2 -1
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/_device_offload.py +13 -12
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/_utils.py +31 -4
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/basic_statistics/basic_statistics.py +26 -37
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/basic_statistics/incremental_basic_statistics.py +33 -42
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/cluster/dbscan.py +30 -27
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/cluster/k_means.py +1 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/covariance/incremental_covariance.py +2 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/decomposition/pca.py +7 -2
- scikit_learn_intelex-2025.8.0.data/data/Lib/site-packages/sklearnex/decomposition/tests/test_pca.py +110 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/dispatcher.py +1 -6
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/ensemble/_forest.py +8 -2
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/ensemble/tests/test_forest.py +22 -7
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/linear_model/coordinate_descent.py +2 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/linear_model/incremental_linear.py +76 -68
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/linear_model/incremental_ridge.py +69 -53
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/linear_model/linear.py +53 -41
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/linear_model/logistic_regression.py +8 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/linear_model/ridge.py +42 -31
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/linear_model/tests/test_linear.py +27 -61
- scikit_learn_intelex-2025.8.0.data/data/Lib/site-packages/sklearnex/linear_model/tests/test_logreg.py +577 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/neighbors/common.py +8 -6
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/preview/covariance/covariance.py +3 -4
- scikit_learn_intelex-2025.8.0.data/data/Lib/site-packages/sklearnex/preview/covariance/tests/test_covariance.py +112 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/basic_statistics/basic_statistics.py +7 -4
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/basic_statistics/tests/test_basic_statistics_spmd.py +6 -3
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/basic_statistics/tests/test_incremental_basic_statistics_spmd.py +12 -8
- scikit_learn_intelex-2025.8.0.data/data/Lib/site-packages/sklearnex/spmd/cluster/dbscan.py +26 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/covariance/tests/test_covariance_spmd.py +11 -4
- scikit_learn_intelex-2025.8.0.data/data/Lib/site-packages/sklearnex/spmd/ensemble/forest.py +299 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/ensemble/tests/test_forest_spmd.py +21 -4
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/linear_model/linear_model.py +7 -4
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/linear_model/tests/test_incremental_linear_spmd.py +16 -8
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/linear_model/tests/test_linear_regression_spmd.py +12 -4
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/svm/tests/test_svm.py +31 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/tests/test_config.py +55 -6
- scikit_learn_intelex-2025.8.0.data/data/Lib/site-packages/sklearnex/tests/test_hyperparameters.py +111 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/tests/test_patching.py +13 -13
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/tests/utils/base.py +3 -21
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/utils/_array_api.py +71 -0
- scikit_learn_intelex-2025.8.0.data/data/Lib/site-packages/sklearnex/utils/parallel.py +97 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/utils/validation.py +19 -1
- {scikit_learn_intelex-2025.7.0.dist-info → scikit_learn_intelex-2025.8.0.dist-info}/METADATA +2 -2
- scikit_learn_intelex-2025.8.0.dist-info/RECORD +259 -0
- scikit_learn_intelex-2025.7.0.data/data/Lib/site-packages/daal4py/sklearn/linear_model/logistic_path.py +0 -1039
- scikit_learn_intelex-2025.7.0.data/data/Lib/site-packages/onedal/_onedal_py_dpc.cp310-win_amd64.pyd +0 -0
- scikit_learn_intelex-2025.7.0.data/data/Lib/site-packages/onedal/_onedal_py_host.cp310-win_amd64.pyd +0 -0
- scikit_learn_intelex-2025.7.0.data/data/Lib/site-packages/onedal/datatypes/_data_conversion.py +0 -110
- scikit_learn_intelex-2025.7.0.data/data/Lib/site-packages/sklearnex/decomposition/tests/test_pca.py +0 -115
- scikit_learn_intelex-2025.7.0.data/data/Lib/site-packages/sklearnex/linear_model/tests/test_logreg.py +0 -134
- scikit_learn_intelex-2025.7.0.data/data/Lib/site-packages/sklearnex/preview/covariance/tests/test_covariance.py +0 -119
- scikit_learn_intelex-2025.7.0.data/data/Lib/site-packages/sklearnex/spmd/cluster/dbscan.py +0 -50
- scikit_learn_intelex-2025.7.0.data/data/Lib/site-packages/sklearnex/spmd/ensemble/forest.py +0 -71
- scikit_learn_intelex-2025.7.0.data/data/Lib/site-packages/sklearnex/tests/test_hyperparameters.py +0 -43
- scikit_learn_intelex-2025.7.0.data/data/Lib/site-packages/sklearnex/utils/parallel.py +0 -59
- scikit_learn_intelex-2025.7.0.dist-info/RECORD +0 -258
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/__main__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/mb/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/mb/gbt_convertors.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/mb/logistic_regression_builders.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/mb/tree_based_builders.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/_n_jobs_support.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/_utils.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/cluster/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/cluster/dbscan.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/cluster/k_means.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/cluster/tests/test_dbscan.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/decomposition/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/decomposition/_pca.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/ensemble/AdaBoostClassifier.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/ensemble/GBTDAAL.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/ensemble/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/ensemble/_forest.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/ensemble/tests/test_decision_forest.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/linear_model/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/linear_model/_coordinate_descent.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/linear_model/_linear.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/linear_model/_ridge.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/linear_model/coordinate_descent.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/linear_model/linear.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/linear_model/ridge.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/linear_model/tests/test_linear.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/linear_model/tests/test_ridge.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/manifold/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/manifold/_t_sne.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/metrics/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/metrics/_pairwise.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/metrics/_ranking.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/model_selection/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/model_selection/_split.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/model_selection/tests/test_split.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/monkeypatch/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/monkeypatch/dispatcher.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/monkeypatch/tests/_models_info.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/monkeypatch/tests/test_monkeypatch.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/monkeypatch/tests/test_patching.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/monkeypatch/tests/utils/_launch_algorithms.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/neighbors/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/neighbors/_base.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/neighbors/_classification.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/neighbors/_regression.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/neighbors/_unsupervised.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/neighbors/tests/test_kneighbors.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/svm/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/svm/svm.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/utils/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/utils/base.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/utils/tests/test_utils.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/daal4py/sklearn/utils/validation.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/_config.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/basic_statistics/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/basic_statistics/tests/utils.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/cluster/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/cluster/kmeans_init.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/cluster/tests/test_dbscan.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/cluster/tests/test_kmeans.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/cluster/tests/test_kmeans_init.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/common/_backend.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/common/_estimator_checks.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/common/_mixin.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/covariance/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/covariance/incremental_covariance.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/covariance/tests/test_covariance.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/covariance/tests/test_incremental_covariance.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/datatypes/tests/common.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/decomposition/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/decomposition/incremental_pca.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/decomposition/pca.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/decomposition/tests/test_incremental_pca.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/ensemble/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/ensemble/tests/test_random_forest.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/linear_model/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/linear_model/tests/test_incremental_linear_regression.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/linear_model/tests/test_incremental_ridge_regression.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/linear_model/tests/test_logistic_regression.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/linear_model/tests/test_ridge.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/neighbors/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/neighbors/neighbors.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/neighbors/tests/test_knn_classification.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/primitives/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/primitives/get_tree.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/primitives/kernel_functions.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/primitives/tests/test_kernel_functions.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/svm/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/svm/svm.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/svm/tests/test_csr_svm.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/svm/tests/test_nusvc.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/svm/tests/test_nusvr.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/svm/tests/test_svc.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/svm/tests/test_svr.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/tests/utils/_dataframes_support.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/tests/utils/_device_selection.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/utils/tests/test_validation.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/onedal/utils/validation.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/__main__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/_config.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/base.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/basic_statistics/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/basic_statistics/tests/test_basic_statistics.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/basic_statistics/tests/test_incremental_basic_statistics.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/cluster/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/cluster/tests/test_dbscan.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/cluster/tests/test_kmeans.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/conftest.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/covariance/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/covariance/tests/test_incremental_covariance.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/decomposition/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/doc/third-party-programs.txt +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/ensemble/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/glob/__main__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/glob/dispatcher.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/linear_model/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/linear_model/tests/test_incremental_linear.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/linear_model/tests/test_incremental_ridge.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/linear_model/tests/test_ridge.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/manifold/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/manifold/t_sne.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/manifold/tests/test_tsne.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/metrics/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/metrics/pairwise.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/metrics/ranking.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/metrics/tests/test_metrics.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/model_selection/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/model_selection/split.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/model_selection/tests/test_model_selection.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/neighbors/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/neighbors/_lof.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/neighbors/knn_classification.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/neighbors/knn_regression.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/neighbors/knn_unsupervised.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/neighbors/tests/test_neighbors.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/preview/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/preview/covariance/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/preview/decomposition/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/preview/decomposition/incremental_pca.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/preview/decomposition/tests/test_incremental_pca.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/basic_statistics/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/basic_statistics/incremental_basic_statistics.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/cluster/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/cluster/kmeans.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/cluster/tests/test_dbscan_spmd.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/cluster/tests/test_kmeans_spmd.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/covariance/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/covariance/covariance.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/covariance/incremental_covariance.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/covariance/tests/test_incremental_covariance_spmd.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/decomposition/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/decomposition/incremental_pca.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/decomposition/pca.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/decomposition/tests/test_incremental_pca_spmd.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/decomposition/tests/test_pca_spmd.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/ensemble/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/linear_model/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/linear_model/incremental_linear_model.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/linear_model/logistic_regression.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/linear_model/tests/test_logistic_regression_spmd.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/neighbors/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/spmd/neighbors/tests/test_neighbors_spmd.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/svm/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/svm/_common.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/svm/nusvc.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/svm/nusvr.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/svm/svc.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/svm/svr.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/tests/test_common.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/tests/test_memory_usage.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/tests/test_monkeypatch.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/tests/test_n_jobs_support.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/tests/test_parallel.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/tests/test_run_to_run_stability.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/tests/utils/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/tests/utils/spmd.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/utils/__init__.py +0 -0
- {scikit_learn_intelex-2025.7.0.data → scikit_learn_intelex-2025.8.0.data}/data/Lib/site-packages/sklearnex/utils/tests/test_validation.py +0 -0
- {scikit_learn_intelex-2025.7.0.dist-info → scikit_learn_intelex-2025.8.0.dist-info}/LICENSE.txt +0 -0
- {scikit_learn_intelex-2025.7.0.dist-info → scikit_learn_intelex-2025.8.0.dist-info}/WHEEL +0 -0
- {scikit_learn_intelex-2025.7.0.dist-info → scikit_learn_intelex-2025.8.0.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
# ===============================================================================
|
|
2
|
+
# Copyright 2023 Intel Corporation
|
|
3
|
+
#
|
|
4
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
# you may not use this file except in compliance with the License.
|
|
6
|
+
# You may obtain a copy of the License at
|
|
7
|
+
#
|
|
8
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
#
|
|
10
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
# See the License for the specific language governing permissions and
|
|
14
|
+
# limitations under the License.
|
|
15
|
+
# ===============================================================================
|
|
16
|
+
|
|
17
|
+
import numpy as np
|
|
18
|
+
import pytest
|
|
19
|
+
from numpy.testing import assert_allclose
|
|
20
|
+
|
|
21
|
+
from daal4py.sklearn._utils import daal_check_version
|
|
22
|
+
from onedal.tests.utils._dataframes_support import (
|
|
23
|
+
_convert_to_dataframe,
|
|
24
|
+
get_dataframes_and_queues,
|
|
25
|
+
)
|
|
26
|
+
from sklearnex.preview.covariance import EmpiricalCovariance
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
@pytest.fixture
|
|
30
|
+
def hyperparameters(request):
|
|
31
|
+
hparams = EmpiricalCovariance.get_hyperparameters("fit")
|
|
32
|
+
|
|
33
|
+
def restore_hyperparameters():
|
|
34
|
+
EmpiricalCovariance.reset_hyperparameters("fit")
|
|
35
|
+
|
|
36
|
+
request.addfinalizer(restore_hyperparameters)
|
|
37
|
+
return hparams
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
@pytest.mark.parametrize("dataframe,queue", get_dataframes_and_queues())
|
|
41
|
+
@pytest.mark.parametrize("macro_block", [None, 2])
|
|
42
|
+
@pytest.mark.parametrize("grain_size", [None, 2])
|
|
43
|
+
@pytest.mark.parametrize("assume_centered", [True, False])
|
|
44
|
+
def test_sklearnex_import_covariance(
|
|
45
|
+
hyperparameters, dataframe, queue, macro_block, grain_size, assume_centered
|
|
46
|
+
):
|
|
47
|
+
X = np.array([[0, 1], [0, 1], [0, 1], [0, 1], [0, 1], [0, 1]])
|
|
48
|
+
|
|
49
|
+
X = _convert_to_dataframe(X, sycl_queue=queue, target_df=dataframe)
|
|
50
|
+
empcov = EmpiricalCovariance(assume_centered=assume_centered)
|
|
51
|
+
|
|
52
|
+
if daal_check_version((2025, "P", 700)):
|
|
53
|
+
if macro_block is not None:
|
|
54
|
+
if queue and queue.sycl_device.is_gpu:
|
|
55
|
+
pytest.skip("Test for CPU-only functionality")
|
|
56
|
+
hyperparameters.cpu_macro_block = macro_block
|
|
57
|
+
if grain_size is not None:
|
|
58
|
+
if queue and queue.sycl_device.is_gpu:
|
|
59
|
+
pytest.skip("Test for CPU-only functionality")
|
|
60
|
+
hyperparameters.cpu_grain_size = grain_size
|
|
61
|
+
|
|
62
|
+
result = empcov.fit(X)
|
|
63
|
+
|
|
64
|
+
expected_covariance = np.array([[0, 0], [0, 0]])
|
|
65
|
+
expected_means = np.array([0, 0])
|
|
66
|
+
|
|
67
|
+
if assume_centered:
|
|
68
|
+
expected_covariance = np.array([[0, 0], [0, 1]])
|
|
69
|
+
else:
|
|
70
|
+
expected_means = np.array([0, 1])
|
|
71
|
+
|
|
72
|
+
assert_allclose(expected_covariance, result.covariance_)
|
|
73
|
+
assert_allclose(expected_means, result.location_)
|
|
74
|
+
|
|
75
|
+
X = np.array([[1, 2], [3, 6]])
|
|
76
|
+
|
|
77
|
+
X = _convert_to_dataframe(X, sycl_queue=queue, target_df=dataframe)
|
|
78
|
+
result = empcov.fit(X)
|
|
79
|
+
|
|
80
|
+
if assume_centered:
|
|
81
|
+
expected_covariance = np.array([[5, 10], [10, 20]])
|
|
82
|
+
else:
|
|
83
|
+
expected_covariance = np.array([[1, 2], [2, 4]])
|
|
84
|
+
expected_means = np.array([2, 4])
|
|
85
|
+
|
|
86
|
+
assert_allclose(expected_covariance, result.covariance_)
|
|
87
|
+
assert_allclose(expected_means, result.location_)
|
|
88
|
+
|
|
89
|
+
|
|
90
|
+
@pytest.mark.skipif(
|
|
91
|
+
not daal_check_version((2025, "P", 700)),
|
|
92
|
+
reason="Functionality introduced in a later version",
|
|
93
|
+
)
|
|
94
|
+
@pytest.mark.parametrize("dataframe,queue", get_dataframes_and_queues())
|
|
95
|
+
@pytest.mark.parametrize("assume_centered", [True, False])
|
|
96
|
+
def test_non_batched_covariance(hyperparameters, dataframe, queue, assume_centered):
|
|
97
|
+
if queue and queue.sycl_device.is_gpu:
|
|
98
|
+
pytest.skip("Test for CPU-only functionality")
|
|
99
|
+
|
|
100
|
+
from sklearnex.preview.covariance import EmpiricalCovariance
|
|
101
|
+
|
|
102
|
+
X = np.random.default_rng(seed=123).random(size=(20, 5))
|
|
103
|
+
|
|
104
|
+
hyperparameters.cpu_max_cols_batched = np.iinfo(np.int32).max
|
|
105
|
+
res_batched = EmpiricalCovariance(assume_centered=assume_centered).fit(X).covariance_
|
|
106
|
+
|
|
107
|
+
hyperparameters.cpu_max_cols_batched = 1
|
|
108
|
+
res_non_batched = (
|
|
109
|
+
EmpiricalCovariance(assume_centered=assume_centered).fit(X).covariance_
|
|
110
|
+
)
|
|
111
|
+
|
|
112
|
+
np.testing.assert_allclose(res_non_batched, res_batched)
|
|
@@ -14,8 +14,11 @@
|
|
|
14
14
|
# limitations under the License.
|
|
15
15
|
# ==============================================================================
|
|
16
16
|
|
|
17
|
-
from onedal.spmd.basic_statistics import BasicStatistics
|
|
17
|
+
from onedal.spmd.basic_statistics import BasicStatistics as onedal_BasicStatistics
|
|
18
18
|
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
19
|
+
from ...basic_statistics import BasicStatistics as BasicStatistics_Batch
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
class BasicStatistics(BasicStatistics_Batch):
|
|
23
|
+
__doc__ = BasicStatistics_Batch.__doc__
|
|
24
|
+
_onedal_basic_statistics = staticmethod(onedal_BasicStatistics)
|
|
@@ -20,6 +20,7 @@ from numpy.testing import assert_allclose
|
|
|
20
20
|
|
|
21
21
|
from onedal.basic_statistics.tests.utils import options_and_tests
|
|
22
22
|
from onedal.tests.utils._dataframes_support import (
|
|
23
|
+
_as_numpy,
|
|
23
24
|
_convert_to_dataframe,
|
|
24
25
|
get_dataframes_and_queues,
|
|
25
26
|
)
|
|
@@ -68,7 +69,8 @@ def test_basic_stats_spmd_gold(dataframe, queue):
|
|
|
68
69
|
batch_result = BasicStatistics_Batch().fit(data)
|
|
69
70
|
|
|
70
71
|
for option in options_and_tests:
|
|
71
|
-
|
|
72
|
+
attr = option + "_"
|
|
73
|
+
assert_allclose(getattr(spmd_result, attr), getattr(batch_result, attr))
|
|
72
74
|
|
|
73
75
|
|
|
74
76
|
@pytest.mark.skipif(
|
|
@@ -106,9 +108,10 @@ def test_basic_stats_spmd_synthetic(
|
|
|
106
108
|
|
|
107
109
|
tol = 1e-5 if dtype == np.float32 else 1e-7
|
|
108
110
|
for option in options_and_tests:
|
|
111
|
+
attr = option + "_"
|
|
109
112
|
assert_allclose(
|
|
110
|
-
getattr(spmd_result,
|
|
111
|
-
getattr(batch_result,
|
|
113
|
+
_as_numpy(getattr(spmd_result, attr)),
|
|
114
|
+
_as_numpy(getattr(batch_result, attr)),
|
|
112
115
|
atol=tol,
|
|
113
116
|
rtol=tol,
|
|
114
117
|
)
|
|
@@ -20,6 +20,7 @@ from numpy.testing import assert_allclose
|
|
|
20
20
|
|
|
21
21
|
from onedal.basic_statistics.tests.utils import options_and_tests
|
|
22
22
|
from onedal.tests.utils._dataframes_support import (
|
|
23
|
+
_as_numpy,
|
|
23
24
|
_convert_to_dataframe,
|
|
24
25
|
get_dataframes_and_queues,
|
|
25
26
|
)
|
|
@@ -89,9 +90,10 @@ def test_incremental_basic_statistics_fit_spmd_gold(dataframe, queue, weighted,
|
|
|
89
90
|
)
|
|
90
91
|
|
|
91
92
|
for option in options_and_tests:
|
|
93
|
+
attr = option + "_"
|
|
92
94
|
assert_allclose(
|
|
93
|
-
getattr(incbs_spmd,
|
|
94
|
-
getattr(incbs,
|
|
95
|
+
getattr(incbs_spmd, attr),
|
|
96
|
+
getattr(incbs, attr),
|
|
95
97
|
err_msg=f"Result for {option} is incorrect",
|
|
96
98
|
)
|
|
97
99
|
|
|
@@ -162,9 +164,10 @@ def test_incremental_basic_statistics_partial_fit_spmd_gold(
|
|
|
162
164
|
incbs.fit(dpt_data, sample_weight=dpt_weights if weighted else None)
|
|
163
165
|
|
|
164
166
|
for option in options_and_tests:
|
|
167
|
+
attr = option + "_"
|
|
165
168
|
assert_allclose(
|
|
166
|
-
getattr(incbs_spmd,
|
|
167
|
-
getattr(incbs,
|
|
169
|
+
getattr(incbs_spmd, attr),
|
|
170
|
+
getattr(incbs, attr),
|
|
168
171
|
err_msg=f"Result for {option} is incorrect",
|
|
169
172
|
)
|
|
170
173
|
|
|
@@ -234,8 +237,8 @@ def test_incremental_basic_statistics_single_option_partial_fit_spmd_gold(
|
|
|
234
237
|
)
|
|
235
238
|
|
|
236
239
|
incbs.fit(dpt_data, sample_weight=dpt_weights if weighted else None)
|
|
237
|
-
|
|
238
|
-
assert_allclose(getattr(incbs_spmd,
|
|
240
|
+
attr = option + "_"
|
|
241
|
+
assert_allclose(getattr(incbs_spmd, attr), getattr(incbs, attr))
|
|
239
242
|
|
|
240
243
|
|
|
241
244
|
@pytest.mark.skipif(
|
|
@@ -302,9 +305,10 @@ def test_incremental_basic_statistics_partial_fit_spmd_synthetic(
|
|
|
302
305
|
incbs.partial_fit(dpt_data, sample_weight=dpt_weights if weighted else None)
|
|
303
306
|
|
|
304
307
|
for option in options_and_tests:
|
|
308
|
+
attr = option + "_"
|
|
305
309
|
assert_allclose(
|
|
306
|
-
getattr(incbs_spmd,
|
|
307
|
-
getattr(incbs,
|
|
310
|
+
_as_numpy(getattr(incbs_spmd, attr)),
|
|
311
|
+
_as_numpy(getattr(incbs, attr)),
|
|
308
312
|
atol=tol,
|
|
309
313
|
err_msg=f"Result for {option} is incorrect",
|
|
310
314
|
)
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
# ==============================================================================
|
|
2
|
+
# Copyright 2023 Intel Corporation
|
|
3
|
+
#
|
|
4
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
# you may not use this file except in compliance with the License.
|
|
6
|
+
# You may obtain a copy of the License at
|
|
7
|
+
#
|
|
8
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
#
|
|
10
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
# See the License for the specific language governing permissions and
|
|
14
|
+
# limitations under the License.
|
|
15
|
+
# ==============================================================================
|
|
16
|
+
|
|
17
|
+
from abc import ABC
|
|
18
|
+
|
|
19
|
+
from onedal.spmd.cluster import DBSCAN as onedal_DBSCAN
|
|
20
|
+
|
|
21
|
+
from ...cluster import DBSCAN as DBSCAN_Batch
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
class DBSCAN(DBSCAN_Batch):
|
|
25
|
+
__doc__ = DBSCAN_Batch.__doc__
|
|
26
|
+
_onedal_dbscan = staticmethod(onedal_DBSCAN)
|
|
@@ -19,6 +19,7 @@ import pytest
|
|
|
19
19
|
from numpy.testing import assert_allclose
|
|
20
20
|
|
|
21
21
|
from onedal.tests.utils._dataframes_support import (
|
|
22
|
+
_as_numpy,
|
|
22
23
|
_convert_to_dataframe,
|
|
23
24
|
get_dataframes_and_queues,
|
|
24
25
|
)
|
|
@@ -65,8 +66,10 @@ def test_covariance_spmd_gold(dataframe, queue):
|
|
|
65
66
|
spmd_result = EmpiricalCovariance_SPMD().fit(local_dpt_data)
|
|
66
67
|
batch_result = EmpiricalCovariance_Batch().fit(data)
|
|
67
68
|
|
|
68
|
-
assert_allclose(
|
|
69
|
-
|
|
69
|
+
assert_allclose(
|
|
70
|
+
_as_numpy(spmd_result.covariance_), _as_numpy(batch_result.covariance_)
|
|
71
|
+
)
|
|
72
|
+
assert_allclose(_as_numpy(spmd_result.location_), _as_numpy(batch_result.location_))
|
|
70
73
|
|
|
71
74
|
|
|
72
75
|
@pytest.mark.skipif(
|
|
@@ -106,5 +109,9 @@ def test_covariance_spmd_synthetic(
|
|
|
106
109
|
batch_result = EmpiricalCovariance_Batch(assume_centered=assume_centered).fit(data)
|
|
107
110
|
|
|
108
111
|
atol = 1e-5 if dtype == np.float32 else 1e-7
|
|
109
|
-
assert_allclose(
|
|
110
|
-
|
|
112
|
+
assert_allclose(
|
|
113
|
+
_as_numpy(spmd_result.covariance_), _as_numpy(batch_result.covariance_), atol=atol
|
|
114
|
+
)
|
|
115
|
+
assert_allclose(
|
|
116
|
+
_as_numpy(spmd_result.location_), _as_numpy(batch_result.location_), atol=atol
|
|
117
|
+
)
|
|
@@ -0,0 +1,299 @@
|
|
|
1
|
+
# ==============================================================================
|
|
2
|
+
# Copyright 2023 Intel Corporation
|
|
3
|
+
#
|
|
4
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
# you may not use this file except in compliance with the License.
|
|
6
|
+
# You may obtain a copy of the License at
|
|
7
|
+
#
|
|
8
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
#
|
|
10
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
# See the License for the specific language governing permissions and
|
|
14
|
+
# limitations under the License.
|
|
15
|
+
# ==============================================================================
|
|
16
|
+
|
|
17
|
+
from daal4py.sklearn._utils import sklearn_check_version
|
|
18
|
+
from onedal.spmd.ensemble import RandomForestClassifier as onedal_RandomForestClassifier
|
|
19
|
+
from onedal.spmd.ensemble import RandomForestRegressor as onedal_RandomForestRegressor
|
|
20
|
+
|
|
21
|
+
from ...ensemble import RandomForestClassifier as RandomForestClassifier_Batch
|
|
22
|
+
from ...ensemble import RandomForestRegressor as RandomForestRegressor_Batch
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
def local_trees_wrapper(factor_cls, local_trees_mode):
|
|
26
|
+
class WrappedFactory(factor_cls):
|
|
27
|
+
def __init__(self, *args, **params):
|
|
28
|
+
params["local_trees_mode"] = local_trees_mode
|
|
29
|
+
super().__init__(*args, **params)
|
|
30
|
+
|
|
31
|
+
return WrappedFactory
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
class RandomForestClassifier(RandomForestClassifier_Batch):
|
|
35
|
+
__doc__ = RandomForestClassifier_Batch.__doc__
|
|
36
|
+
_onedal_factory_cls = onedal_RandomForestClassifier
|
|
37
|
+
|
|
38
|
+
# Wrap _onedal_factory to support local_trees_mode parameter
|
|
39
|
+
@property
|
|
40
|
+
def _onedal_factory(self):
|
|
41
|
+
return local_trees_wrapper(self._onedal_factory_cls, self.local_trees_mode)
|
|
42
|
+
|
|
43
|
+
# Init constructor with local_trees_mode parameter but pass to parent
|
|
44
|
+
# class without (to maintain scikit-learn estimator compatibility)
|
|
45
|
+
if sklearn_check_version("1.4"):
|
|
46
|
+
|
|
47
|
+
def __init__(
|
|
48
|
+
self,
|
|
49
|
+
n_estimators=100,
|
|
50
|
+
*,
|
|
51
|
+
criterion="gini",
|
|
52
|
+
max_depth=None,
|
|
53
|
+
min_samples_split=2,
|
|
54
|
+
min_samples_leaf=1,
|
|
55
|
+
min_weight_fraction_leaf=0.0,
|
|
56
|
+
max_features="sqrt",
|
|
57
|
+
max_leaf_nodes=None,
|
|
58
|
+
min_impurity_decrease=0.0,
|
|
59
|
+
bootstrap=True,
|
|
60
|
+
oob_score=False,
|
|
61
|
+
n_jobs=None,
|
|
62
|
+
random_state=None,
|
|
63
|
+
verbose=0,
|
|
64
|
+
warm_start=False,
|
|
65
|
+
class_weight=None,
|
|
66
|
+
ccp_alpha=0.0,
|
|
67
|
+
max_samples=None,
|
|
68
|
+
monotonic_cst=None,
|
|
69
|
+
max_bins=256,
|
|
70
|
+
min_bin_size=1,
|
|
71
|
+
local_trees_mode=False,
|
|
72
|
+
):
|
|
73
|
+
self.local_trees_mode = local_trees_mode
|
|
74
|
+
super().__init__(
|
|
75
|
+
n_estimators=n_estimators,
|
|
76
|
+
criterion=criterion,
|
|
77
|
+
max_depth=max_depth,
|
|
78
|
+
min_samples_split=min_samples_split,
|
|
79
|
+
min_samples_leaf=min_samples_leaf,
|
|
80
|
+
min_weight_fraction_leaf=min_weight_fraction_leaf,
|
|
81
|
+
max_features=max_features,
|
|
82
|
+
max_leaf_nodes=max_leaf_nodes,
|
|
83
|
+
min_impurity_decrease=min_impurity_decrease,
|
|
84
|
+
bootstrap=bootstrap,
|
|
85
|
+
oob_score=oob_score,
|
|
86
|
+
n_jobs=n_jobs,
|
|
87
|
+
random_state=random_state,
|
|
88
|
+
verbose=verbose,
|
|
89
|
+
warm_start=warm_start,
|
|
90
|
+
class_weight=class_weight,
|
|
91
|
+
ccp_alpha=ccp_alpha,
|
|
92
|
+
max_samples=max_samples,
|
|
93
|
+
monotonic_cst=monotonic_cst,
|
|
94
|
+
max_bins=max_bins,
|
|
95
|
+
min_bin_size=min_bin_size,
|
|
96
|
+
)
|
|
97
|
+
|
|
98
|
+
else:
|
|
99
|
+
|
|
100
|
+
def __init__(
|
|
101
|
+
self,
|
|
102
|
+
n_estimators=100,
|
|
103
|
+
*,
|
|
104
|
+
criterion="gini",
|
|
105
|
+
max_depth=None,
|
|
106
|
+
min_samples_split=2,
|
|
107
|
+
min_samples_leaf=1,
|
|
108
|
+
min_weight_fraction_leaf=0.0,
|
|
109
|
+
max_features="sqrt" if sklearn_check_version("1.1") else "auto",
|
|
110
|
+
max_leaf_nodes=None,
|
|
111
|
+
min_impurity_decrease=0.0,
|
|
112
|
+
bootstrap=True,
|
|
113
|
+
oob_score=False,
|
|
114
|
+
n_jobs=None,
|
|
115
|
+
random_state=None,
|
|
116
|
+
verbose=0,
|
|
117
|
+
warm_start=False,
|
|
118
|
+
class_weight=None,
|
|
119
|
+
ccp_alpha=0.0,
|
|
120
|
+
max_samples=None,
|
|
121
|
+
max_bins=256,
|
|
122
|
+
min_bin_size=1,
|
|
123
|
+
local_trees_mode=False,
|
|
124
|
+
):
|
|
125
|
+
self.local_trees_mode = local_trees_mode
|
|
126
|
+
super().__init__(
|
|
127
|
+
n_estimators=n_estimators,
|
|
128
|
+
criterion=criterion,
|
|
129
|
+
max_depth=max_depth,
|
|
130
|
+
min_samples_split=min_samples_split,
|
|
131
|
+
min_samples_leaf=min_samples_leaf,
|
|
132
|
+
min_weight_fraction_leaf=min_weight_fraction_leaf,
|
|
133
|
+
max_features=max_features,
|
|
134
|
+
max_leaf_nodes=max_leaf_nodes,
|
|
135
|
+
min_impurity_decrease=min_impurity_decrease,
|
|
136
|
+
bootstrap=bootstrap,
|
|
137
|
+
oob_score=oob_score,
|
|
138
|
+
n_jobs=n_jobs,
|
|
139
|
+
random_state=random_state,
|
|
140
|
+
verbose=verbose,
|
|
141
|
+
warm_start=warm_start,
|
|
142
|
+
class_weight=class_weight,
|
|
143
|
+
ccp_alpha=ccp_alpha,
|
|
144
|
+
max_samples=max_samples,
|
|
145
|
+
max_bins=max_bins,
|
|
146
|
+
min_bin_size=min_bin_size,
|
|
147
|
+
)
|
|
148
|
+
|
|
149
|
+
def _onedal_cpu_supported(self, method_name, *data):
|
|
150
|
+
# TODO:
|
|
151
|
+
# check which methods supported SPMD interface on CPU.
|
|
152
|
+
ready = super()._onedal_cpu_supported(method_name, *data)
|
|
153
|
+
if not ready:
|
|
154
|
+
raise RuntimeError(
|
|
155
|
+
f"Method {method_name} in {self.__class__.__name__} "
|
|
156
|
+
"is not supported with given inputs."
|
|
157
|
+
)
|
|
158
|
+
return ready
|
|
159
|
+
|
|
160
|
+
def _onedal_gpu_supported(self, method_name, *data):
|
|
161
|
+
ready = super()._onedal_gpu_supported(method_name, *data)
|
|
162
|
+
if not ready:
|
|
163
|
+
raise RuntimeError(
|
|
164
|
+
f"Method {method_name} in {self.__class__.__name__} "
|
|
165
|
+
"is not supported with given inputs."
|
|
166
|
+
)
|
|
167
|
+
return ready
|
|
168
|
+
|
|
169
|
+
|
|
170
|
+
class RandomForestRegressor(RandomForestRegressor_Batch):
|
|
171
|
+
__doc__ = RandomForestRegressor_Batch.__doc__
|
|
172
|
+
_onedal_factory_cls = onedal_RandomForestRegressor
|
|
173
|
+
|
|
174
|
+
# Wrap _onedal_factory to support local_trees_mode parameter
|
|
175
|
+
@property
|
|
176
|
+
def _onedal_factory(self):
|
|
177
|
+
return local_trees_wrapper(self._onedal_factory_cls, self.local_trees_mode)
|
|
178
|
+
|
|
179
|
+
# Init constructor with local_trees_mode parameter but pass to parent
|
|
180
|
+
# class without (to maintain scikit-learn estimator compatibility)
|
|
181
|
+
if sklearn_check_version("1.4"):
|
|
182
|
+
|
|
183
|
+
def __init__(
|
|
184
|
+
self,
|
|
185
|
+
n_estimators=100,
|
|
186
|
+
*,
|
|
187
|
+
criterion="squared_error",
|
|
188
|
+
max_depth=None,
|
|
189
|
+
min_samples_split=2,
|
|
190
|
+
min_samples_leaf=1,
|
|
191
|
+
min_weight_fraction_leaf=0.0,
|
|
192
|
+
max_features=1.0,
|
|
193
|
+
max_leaf_nodes=None,
|
|
194
|
+
min_impurity_decrease=0.0,
|
|
195
|
+
bootstrap=True,
|
|
196
|
+
oob_score=False,
|
|
197
|
+
n_jobs=None,
|
|
198
|
+
random_state=None,
|
|
199
|
+
verbose=0,
|
|
200
|
+
warm_start=False,
|
|
201
|
+
ccp_alpha=0.0,
|
|
202
|
+
max_samples=None,
|
|
203
|
+
monotonic_cst=None,
|
|
204
|
+
max_bins=256,
|
|
205
|
+
min_bin_size=1,
|
|
206
|
+
local_trees_mode=False,
|
|
207
|
+
):
|
|
208
|
+
self.local_trees_mode = local_trees_mode
|
|
209
|
+
super().__init__(
|
|
210
|
+
n_estimators=n_estimators,
|
|
211
|
+
criterion=criterion,
|
|
212
|
+
max_depth=max_depth,
|
|
213
|
+
min_samples_split=min_samples_split,
|
|
214
|
+
min_samples_leaf=min_samples_leaf,
|
|
215
|
+
min_weight_fraction_leaf=min_weight_fraction_leaf,
|
|
216
|
+
max_features=max_features,
|
|
217
|
+
max_leaf_nodes=max_leaf_nodes,
|
|
218
|
+
min_impurity_decrease=min_impurity_decrease,
|
|
219
|
+
bootstrap=bootstrap,
|
|
220
|
+
oob_score=oob_score,
|
|
221
|
+
n_jobs=n_jobs,
|
|
222
|
+
random_state=random_state,
|
|
223
|
+
verbose=verbose,
|
|
224
|
+
warm_start=warm_start,
|
|
225
|
+
ccp_alpha=ccp_alpha,
|
|
226
|
+
max_samples=max_samples,
|
|
227
|
+
monotonic_cst=monotonic_cst,
|
|
228
|
+
max_bins=max_bins,
|
|
229
|
+
min_bin_size=min_bin_size,
|
|
230
|
+
)
|
|
231
|
+
|
|
232
|
+
else:
|
|
233
|
+
|
|
234
|
+
def __init__(
|
|
235
|
+
self,
|
|
236
|
+
n_estimators=100,
|
|
237
|
+
*,
|
|
238
|
+
criterion="squared_error",
|
|
239
|
+
max_depth=None,
|
|
240
|
+
min_samples_split=2,
|
|
241
|
+
min_samples_leaf=1,
|
|
242
|
+
min_weight_fraction_leaf=0.0,
|
|
243
|
+
max_features=1.0 if sklearn_check_version("1.1") else "auto",
|
|
244
|
+
max_leaf_nodes=None,
|
|
245
|
+
min_impurity_decrease=0.0,
|
|
246
|
+
bootstrap=True,
|
|
247
|
+
oob_score=False,
|
|
248
|
+
n_jobs=None,
|
|
249
|
+
random_state=None,
|
|
250
|
+
verbose=0,
|
|
251
|
+
warm_start=False,
|
|
252
|
+
ccp_alpha=0.0,
|
|
253
|
+
max_samples=None,
|
|
254
|
+
max_bins=256,
|
|
255
|
+
min_bin_size=1,
|
|
256
|
+
local_trees_mode=False,
|
|
257
|
+
):
|
|
258
|
+
self.local_trees_mode = local_trees_mode
|
|
259
|
+
super().__init__(
|
|
260
|
+
n_estimators=n_estimators,
|
|
261
|
+
criterion=criterion,
|
|
262
|
+
max_depth=max_depth,
|
|
263
|
+
min_samples_split=min_samples_split,
|
|
264
|
+
min_samples_leaf=min_samples_leaf,
|
|
265
|
+
min_weight_fraction_leaf=min_weight_fraction_leaf,
|
|
266
|
+
max_features=max_features,
|
|
267
|
+
max_leaf_nodes=max_leaf_nodes,
|
|
268
|
+
min_impurity_decrease=min_impurity_decrease,
|
|
269
|
+
bootstrap=bootstrap,
|
|
270
|
+
oob_score=oob_score,
|
|
271
|
+
n_jobs=n_jobs,
|
|
272
|
+
random_state=random_state,
|
|
273
|
+
verbose=verbose,
|
|
274
|
+
warm_start=warm_start,
|
|
275
|
+
ccp_alpha=ccp_alpha,
|
|
276
|
+
max_samples=max_samples,
|
|
277
|
+
max_bins=max_bins,
|
|
278
|
+
min_bin_size=min_bin_size,
|
|
279
|
+
)
|
|
280
|
+
|
|
281
|
+
def _onedal_cpu_supported(self, method_name, *data):
|
|
282
|
+
# TODO:
|
|
283
|
+
# check which methods supported SPMD interface on CPU.
|
|
284
|
+
ready = super()._onedal_cpu_supported(method_name, *data)
|
|
285
|
+
if not ready:
|
|
286
|
+
raise RuntimeError(
|
|
287
|
+
f"Method {method_name} in {self.__class__.__name__} "
|
|
288
|
+
"is not supported with given inputs."
|
|
289
|
+
)
|
|
290
|
+
return ready
|
|
291
|
+
|
|
292
|
+
def _onedal_gpu_supported(self, method_name, *data):
|
|
293
|
+
ready = super()._onedal_gpu_supported(method_name, *data)
|
|
294
|
+
if not ready:
|
|
295
|
+
raise RuntimeError(
|
|
296
|
+
f"Method {method_name} in {self.__class__.__name__} "
|
|
297
|
+
"is not supported with given inputs."
|
|
298
|
+
)
|
|
299
|
+
return ready
|
|
@@ -104,6 +104,7 @@ def test_rfcls_spmd_gold(dataframe, queue):
|
|
|
104
104
|
@pytest.mark.parametrize("n_features_and_classes", [(5, 2), (25, 2), (25, 10)])
|
|
105
105
|
@pytest.mark.parametrize("n_estimators", [10, 100])
|
|
106
106
|
@pytest.mark.parametrize("max_depth", [3, None])
|
|
107
|
+
@pytest.mark.parametrize("local_trees_mode", [False, True])
|
|
107
108
|
@pytest.mark.parametrize(
|
|
108
109
|
"dataframe,queue",
|
|
109
110
|
get_dataframes_and_queues(dataframe_filter_="dpnp,dpctl", device_filter_="gpu"),
|
|
@@ -116,6 +117,7 @@ def test_rfcls_spmd_synthetic(
|
|
|
116
117
|
n_features_and_classes,
|
|
117
118
|
n_estimators,
|
|
118
119
|
max_depth,
|
|
120
|
+
local_trees_mode,
|
|
119
121
|
dataframe,
|
|
120
122
|
queue,
|
|
121
123
|
dtype,
|
|
@@ -145,7 +147,10 @@ def test_rfcls_spmd_synthetic(
|
|
|
145
147
|
|
|
146
148
|
# Ensure predictions of batch algo match spmd
|
|
147
149
|
spmd_model = RandomForestClassifier_SPMD(
|
|
148
|
-
n_estimators=n_estimators,
|
|
150
|
+
n_estimators=n_estimators,
|
|
151
|
+
max_depth=max_depth,
|
|
152
|
+
local_trees_mode=local_trees_mode,
|
|
153
|
+
random_state=0,
|
|
149
154
|
)
|
|
150
155
|
# Configure raw input status for spmd estimator
|
|
151
156
|
with config_context(use_raw_input=use_raw_input):
|
|
@@ -234,6 +239,7 @@ def test_rfreg_spmd_gold(dataframe, queue):
|
|
|
234
239
|
@pytest.mark.parametrize("n_features", [5, 25])
|
|
235
240
|
@pytest.mark.parametrize("n_estimators", [10, 100])
|
|
236
241
|
@pytest.mark.parametrize("max_depth", [3, None])
|
|
242
|
+
@pytest.mark.parametrize("local_trees_mode", [False, True])
|
|
237
243
|
@pytest.mark.parametrize(
|
|
238
244
|
"dataframe,queue",
|
|
239
245
|
get_dataframes_and_queues(dataframe_filter_="dpnp,dpctl", device_filter_="gpu"),
|
|
@@ -242,7 +248,15 @@ def test_rfreg_spmd_gold(dataframe, queue):
|
|
|
242
248
|
@pytest.mark.parametrize("use_raw_input", [True, False])
|
|
243
249
|
@pytest.mark.mpi
|
|
244
250
|
def test_rfreg_spmd_synthetic(
|
|
245
|
-
n_samples,
|
|
251
|
+
n_samples,
|
|
252
|
+
n_features,
|
|
253
|
+
n_estimators,
|
|
254
|
+
max_depth,
|
|
255
|
+
local_trees_mode,
|
|
256
|
+
dataframe,
|
|
257
|
+
queue,
|
|
258
|
+
dtype,
|
|
259
|
+
use_raw_input,
|
|
246
260
|
):
|
|
247
261
|
# Import spmd and batch algo
|
|
248
262
|
from sklearnex.ensemble import RandomForestRegressor as RandomForestRegressor_Batch
|
|
@@ -267,8 +281,11 @@ def test_rfreg_spmd_synthetic(
|
|
|
267
281
|
|
|
268
282
|
# Ensure predictions of batch algo match spmd
|
|
269
283
|
with config_context(use_raw_input=use_raw_input):
|
|
270
|
-
spmd_model =
|
|
271
|
-
n_estimators=n_estimators,
|
|
284
|
+
spmd_model = RandomForestRegressor_SPMD(
|
|
285
|
+
n_estimators=n_estimators,
|
|
286
|
+
max_depth=max_depth,
|
|
287
|
+
local_trees_mode=local_trees_mode,
|
|
288
|
+
random_state=0,
|
|
272
289
|
).fit(local_dpt_X_train, local_dpt_y_train)
|
|
273
290
|
batch_model = RandomForestRegressor_Batch(
|
|
274
291
|
n_estimators=n_estimators, max_depth=max_depth, random_state=0
|
|
@@ -14,8 +14,11 @@
|
|
|
14
14
|
# limitations under the License.
|
|
15
15
|
# ==============================================================================
|
|
16
16
|
|
|
17
|
-
from onedal.spmd.linear_model import LinearRegression
|
|
17
|
+
from onedal.spmd.linear_model import LinearRegression as onedal_LinearRegression
|
|
18
18
|
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
19
|
+
from ...linear_model import LinearRegression as LinearRegression_Batch
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
class LinearRegression(LinearRegression_Batch):
|
|
23
|
+
__doc__ = LinearRegression_Batch.__doc__
|
|
24
|
+
_onedal_LinearRegression = staticmethod(onedal_LinearRegression)
|