scikit-learn-intelex 2024.7.0__py311-none-win_amd64.whl → 2025.0.0__py311-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.

Files changed (260) hide show
  1. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/__init__.py +73 -0
  2. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/__main__.py +58 -0
  3. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/_daal4py.cp311-win_amd64.pyd +0 -0
  4. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/doc/third-party-programs.txt +424 -0
  5. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/mb/__init__.py +19 -0
  6. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/mb/model_builders.py +377 -0
  7. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/mpi_transceiver.cp311-win_amd64.pyd +0 -0
  8. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/__init__.py +40 -0
  9. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/_n_jobs_support.py +242 -0
  10. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/_utils.py +241 -0
  11. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/cluster/__init__.py +20 -0
  12. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/cluster/dbscan.py +165 -0
  13. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/cluster/k_means.py +597 -0
  14. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/cluster/tests/test_dbscan.py +109 -0
  15. {scikit_learn_intelex-2024.7.0.data/data/Lib/site-packages/sklearnex/spmd → scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn}/decomposition/__init__.py +2 -2
  16. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/decomposition/_pca.py +524 -0
  17. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/ensemble/AdaBoostClassifier.py +192 -0
  18. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/ensemble/GBTDAAL.py +318 -0
  19. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/ensemble/__init__.py +27 -0
  20. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/ensemble/_forest.py +1397 -0
  21. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/ensemble/tests/test_decision_forest.py +206 -0
  22. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/linear_model/__init__.py +29 -0
  23. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/linear_model/_coordinate_descent.py +848 -0
  24. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/linear_model/_linear.py +272 -0
  25. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/linear_model/_ridge.py +325 -0
  26. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/linear_model/coordinate_descent.py +17 -0
  27. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/linear_model/linear.py +17 -0
  28. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/linear_model/logistic_loss.py +195 -0
  29. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/linear_model/logistic_path.py +1026 -0
  30. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/linear_model/ridge.py +17 -0
  31. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/linear_model/tests/test_linear.py +196 -0
  32. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/linear_model/tests/test_ridge.py +69 -0
  33. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/manifold/__init__.py +19 -0
  34. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/manifold/_t_sne.py +405 -0
  35. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/metrics/__init__.py +20 -0
  36. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/metrics/_pairwise.py +155 -0
  37. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/metrics/_ranking.py +210 -0
  38. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/model_selection/__init__.py +19 -0
  39. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/model_selection/_split.py +309 -0
  40. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/model_selection/tests/test_split.py +56 -0
  41. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/monkeypatch/__init__.py +0 -0
  42. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/monkeypatch/dispatcher.py +232 -0
  43. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/monkeypatch/tests/_models_info.py +161 -0
  44. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/monkeypatch/tests/test_monkeypatch.py +71 -0
  45. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/monkeypatch/tests/test_patching.py +87 -0
  46. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/monkeypatch/tests/utils/_launch_algorithms.py +118 -0
  47. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/neighbors/__init__.py +21 -0
  48. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/neighbors/_base.py +503 -0
  49. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/neighbors/_classification.py +139 -0
  50. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/neighbors/_regression.py +74 -0
  51. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/neighbors/_unsupervised.py +55 -0
  52. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/neighbors/tests/test_kneighbors.py +113 -0
  53. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/svm/__init__.py +19 -0
  54. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/svm/svm.py +734 -0
  55. {scikit_learn_intelex-2024.7.0.data/data/Lib/site-packages/sklearnex/spmd/covariance → scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/utils}/__init__.py +5 -3
  56. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/utils/base.py +75 -0
  57. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/utils/tests/test_utils.py +51 -0
  58. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/daal4py/sklearn/utils/validation.py +693 -0
  59. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/__init__.py +83 -0
  60. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/_config.py +53 -0
  61. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/_device_offload.py +229 -0
  62. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/_onedal_py_dpc.cp311-win_amd64.pyd +0 -0
  63. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/_onedal_py_host.cp311-win_amd64.pyd +0 -0
  64. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/basic_statistics/basic_statistics.py +107 -0
  65. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/basic_statistics/incremental_basic_statistics.py +160 -0
  66. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/basic_statistics/tests/test_basic_statistics.py +298 -0
  67. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/basic_statistics/tests/test_incremental_basic_statistics.py +196 -0
  68. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/cluster/__init__.py +27 -0
  69. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/cluster/dbscan.py +110 -0
  70. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/cluster/kmeans.py +560 -0
  71. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/cluster/kmeans_init.py +115 -0
  72. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/cluster/tests/test_dbscan.py +125 -0
  73. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/cluster/tests/test_kmeans.py +88 -0
  74. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/cluster/tests/test_kmeans_init.py +93 -0
  75. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/common/_base.py +38 -0
  76. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/common/_estimator_checks.py +47 -0
  77. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/common/_mixin.py +62 -0
  78. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/common/_policy.py +59 -0
  79. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/common/_spmd_policy.py +30 -0
  80. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/common/hyperparameters.py +116 -0
  81. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/common/tests/test_policy.py +75 -0
  82. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/covariance/__init__.py +20 -0
  83. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/covariance/covariance.py +125 -0
  84. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/covariance/incremental_covariance.py +146 -0
  85. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/covariance/tests/test_covariance.py +50 -0
  86. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/covariance/tests/test_incremental_covariance.py +122 -0
  87. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/datatypes/__init__.py +19 -0
  88. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/datatypes/_data_conversion.py +95 -0
  89. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/datatypes/tests/test_data.py +235 -0
  90. {scikit_learn_intelex-2024.7.0.data/data/Lib/site-packages/sklearnex/spmd/basic_statistics → scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/decomposition}/__init__.py +3 -2
  91. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/decomposition/incremental_pca.py +204 -0
  92. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/decomposition/pca.py +186 -0
  93. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/decomposition/tests/test_incremental_pca.py +198 -0
  94. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/ensemble/__init__.py +29 -0
  95. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/ensemble/forest.py +720 -0
  96. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/ensemble/tests/test_random_forest.py +97 -0
  97. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/linear_model/__init__.py +27 -0
  98. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/linear_model/incremental_linear_model.py +258 -0
  99. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/linear_model/linear_model.py +329 -0
  100. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/linear_model/logistic_regression.py +249 -0
  101. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/linear_model/tests/test_incremental_linear_regression.py +168 -0
  102. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/linear_model/tests/test_incremental_ridge_regression.py +107 -0
  103. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/linear_model/tests/test_linear_regression.py +149 -0
  104. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/linear_model/tests/test_logistic_regression.py +95 -0
  105. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/linear_model/tests/test_ridge.py +95 -0
  106. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/neighbors/__init__.py +19 -0
  107. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/neighbors/neighbors.py +778 -0
  108. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/neighbors/tests/test_knn_classification.py +49 -0
  109. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/primitives/__init__.py +27 -0
  110. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/primitives/get_tree.py +25 -0
  111. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/primitives/kernel_functions.py +153 -0
  112. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/primitives/tests/test_kernel_functions.py +159 -0
  113. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/svm/__init__.py +19 -0
  114. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/svm/svm.py +556 -0
  115. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/svm/tests/test_csr_svm.py +351 -0
  116. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/svm/tests/test_nusvc.py +204 -0
  117. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/svm/tests/test_nusvr.py +210 -0
  118. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/svm/tests/test_svc.py +168 -0
  119. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/svm/tests/test_svr.py +243 -0
  120. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/tests/test_common.py +41 -0
  121. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/tests/utils/_dataframes_support.py +168 -0
  122. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/tests/utils/_device_selection.py +107 -0
  123. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/utils/__init__.py +49 -0
  124. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/utils/_array_api.py +91 -0
  125. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal/utils/validation.py +432 -0
  126. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/_device_offload.py +36 -13
  127. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/basic_statistics/__init__.py +20 -0
  128. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/basic_statistics/basic_statistics.py +0 -3
  129. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/basic_statistics/incremental_basic_statistics.py +5 -5
  130. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/cluster/__init__.py +1 -1
  131. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/cluster/k_means.py +383 -0
  132. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/cluster/tests/test_kmeans.py +153 -0
  133. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/covariance/incremental_covariance.py +5 -5
  134. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/covariance/tests/test_incremental_covariance.py +11 -0
  135. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/decomposition/pca.py +1 -1
  136. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/dispatcher.py +19 -9
  137. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/ensemble/_forest.py +1 -1
  138. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/linear_model/__init__.py +2 -0
  139. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/linear_model/coordinate_descent.py +7 -7
  140. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/linear_model/incremental_linear.py +5 -6
  141. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/linear_model/incremental_ridge.py +418 -0
  142. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/linear_model/ridge.py +4 -4
  143. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/linear_model/tests/test_incremental_linear.py +13 -10
  144. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/linear_model/tests/test_incremental_ridge.py +153 -0
  145. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/linear_model/tests/test_logreg.py +5 -4
  146. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/manifold/t_sne.py +3 -3
  147. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/metrics/pairwise.py +2 -2
  148. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/metrics/ranking.py +2 -2
  149. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/model_selection/split.py +4 -2
  150. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/neighbors/_lof.py +2 -1
  151. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/neighbors/common.py +1 -1
  152. {scikit_learn_intelex-2024.7.0.data/data/Lib/site-packages/sklearnex/preview/cluster → scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/preview}/__init__.py +1 -3
  153. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/preview/decomposition/incremental_pca.py +8 -8
  154. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/preview/decomposition/tests/test_incremental_pca.py +2 -2
  155. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/preview/linear_model/ridge.py +4 -4
  156. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/spmd/basic_statistics/__init__.py +20 -0
  157. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/spmd/basic_statistics/incremental_basic_statistics.py +30 -0
  158. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/spmd/basic_statistics/tests/test_incremental_basic_statistics_spmd.py +307 -0
  159. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/spmd/covariance/__init__.py +20 -0
  160. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/spmd/covariance/incremental_covariance.py +37 -0
  161. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/spmd/covariance/tests/test_incremental_covariance_spmd.py +184 -0
  162. {scikit_learn_intelex-2024.7.0.data/data/Lib/site-packages/sklearnex/preview → scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/spmd/decomposition}/__init__.py +4 -1
  163. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/spmd/decomposition/incremental_pca.py +30 -0
  164. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/spmd/decomposition/tests/test_incremental_pca_spmd.py +269 -0
  165. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/linear_model/__init__.py +2 -1
  166. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/spmd/linear_model/incremental_linear_model.py +35 -0
  167. scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/spmd/linear_model/tests/test_incremental_linear_spmd.py +329 -0
  168. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/linear_model/tests/test_logistic_regression_spmd.py +4 -1
  169. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/svm/nusvc.py +1 -1
  170. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/svm/svc.py +1 -1
  171. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/tests/_utils_spmd.py +18 -5
  172. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/tests/test_memory_usage.py +2 -1
  173. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/tests/test_patching.py +0 -1
  174. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/tests/test_run_to_run_stability.py +12 -11
  175. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/utils/__init__.py +1 -2
  176. scikit_learn_intelex-2024.7.0.data/data/Lib/site-packages/sklearnex/utils/_namespace.py → scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/sklearnex/utils/_array_api.py +5 -20
  177. {scikit_learn_intelex-2024.7.0.dist-info → scikit_learn_intelex-2025.0.0.dist-info}/METADATA +3 -2
  178. scikit_learn_intelex-2025.0.0.dist-info/RECORD +255 -0
  179. scikit_learn_intelex-2024.7.0.data/data/Lib/site-packages/sklearnex/cluster/k_means.py +0 -25
  180. scikit_learn_intelex-2024.7.0.data/data/Lib/site-packages/sklearnex/cluster/tests/test_kmeans.py +0 -42
  181. scikit_learn_intelex-2024.7.0.data/data/Lib/site-packages/sklearnex/preview/cluster/_common.py +0 -84
  182. scikit_learn_intelex-2024.7.0.data/data/Lib/site-packages/sklearnex/preview/cluster/k_means.py +0 -303
  183. scikit_learn_intelex-2024.7.0.dist-info/RECORD +0 -122
  184. {scikit_learn_intelex-2024.7.0.data/data/Lib/site-packages/sklearnex → scikit_learn_intelex-2025.0.0.data/data/Lib/site-packages/onedal}/basic_statistics/__init__.py +0 -0
  185. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/__init__.py +0 -0
  186. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/__main__.py +0 -0
  187. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/_config.py +0 -0
  188. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/_utils.py +0 -0
  189. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/basic_statistics/tests/test_basic_statistics.py +0 -0
  190. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/basic_statistics/tests/test_incremental_basic_statistics.py +0 -0
  191. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/cluster/dbscan.py +0 -0
  192. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/cluster/tests/test_dbscan.py +0 -0
  193. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/conftest.py +0 -0
  194. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/covariance/__init__.py +0 -0
  195. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/decomposition/__init__.py +0 -0
  196. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/decomposition/tests/test_pca.py +0 -0
  197. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/doc/third-party-programs.txt +0 -0
  198. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/ensemble/__init__.py +0 -0
  199. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/ensemble/tests/test_forest.py +0 -0
  200. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/glob/__main__.py +0 -0
  201. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/glob/dispatcher.py +0 -0
  202. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/linear_model/linear.py +0 -0
  203. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/linear_model/logistic_path.py +0 -0
  204. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/linear_model/logistic_regression.py +0 -0
  205. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/linear_model/tests/test_linear.py +0 -0
  206. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/manifold/__init__.py +0 -0
  207. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/manifold/tests/test_tsne.py +0 -0
  208. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/metrics/__init__.py +0 -0
  209. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/metrics/tests/test_metrics.py +0 -0
  210. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/model_selection/__init__.py +0 -0
  211. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/model_selection/tests/test_model_selection.py +0 -0
  212. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/neighbors/__init__.py +0 -0
  213. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/neighbors/knn_classification.py +0 -0
  214. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/neighbors/knn_regression.py +0 -0
  215. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/neighbors/knn_unsupervised.py +0 -0
  216. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/neighbors/tests/test_neighbors.py +0 -0
  217. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/preview/covariance/__init__.py +0 -0
  218. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/preview/covariance/covariance.py +0 -0
  219. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/preview/covariance/tests/test_covariance.py +0 -0
  220. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/preview/decomposition/__init__.py +0 -0
  221. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/preview/linear_model/__init__.py +0 -0
  222. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/preview/linear_model/tests/test_ridge.py +0 -0
  223. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/__init__.py +0 -0
  224. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/basic_statistics/basic_statistics.py +0 -0
  225. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/basic_statistics/tests/test_basic_statistics_spmd.py +0 -0
  226. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/cluster/__init__.py +0 -0
  227. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/cluster/dbscan.py +0 -0
  228. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/cluster/kmeans.py +0 -0
  229. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/cluster/tests/test_dbscan_spmd.py +0 -0
  230. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/cluster/tests/test_kmeans_spmd.py +0 -0
  231. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/covariance/covariance.py +0 -0
  232. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/covariance/tests/test_covariance_spmd.py +0 -0
  233. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/decomposition/pca.py +0 -0
  234. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/decomposition/tests/test_pca_spmd.py +0 -0
  235. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/ensemble/__init__.py +0 -0
  236. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/ensemble/forest.py +0 -0
  237. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/ensemble/tests/test_forest_spmd.py +0 -0
  238. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/linear_model/linear_model.py +0 -0
  239. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/linear_model/logistic_regression.py +0 -0
  240. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/linear_model/tests/test_linear_regression_spmd.py +0 -0
  241. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/neighbors/__init__.py +0 -0
  242. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/neighbors/neighbors.py +0 -0
  243. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/spmd/neighbors/tests/test_neighbors_spmd.py +0 -0
  244. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/svm/__init__.py +0 -0
  245. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/svm/_common.py +0 -0
  246. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/svm/nusvr.py +0 -0
  247. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/svm/svr.py +0 -0
  248. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/svm/tests/test_svm.py +0 -0
  249. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/tests/_utils.py +0 -0
  250. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/tests/test_common.py +0 -0
  251. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/tests/test_config.py +0 -0
  252. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/tests/test_monkeypatch.py +0 -0
  253. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/tests/test_n_jobs_support.py +0 -0
  254. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/tests/test_parallel.py +0 -0
  255. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/utils/parallel.py +0 -0
  256. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/utils/tests/test_finite.py +0 -0
  257. {scikit_learn_intelex-2024.7.0.data → scikit_learn_intelex-2025.0.0.data}/data/Lib/site-packages/sklearnex/utils/validation.py +0 -0
  258. {scikit_learn_intelex-2024.7.0.dist-info → scikit_learn_intelex-2025.0.0.dist-info}/LICENSE.txt +0 -0
  259. {scikit_learn_intelex-2024.7.0.dist-info → scikit_learn_intelex-2025.0.0.dist-info}/WHEEL +0 -0
  260. {scikit_learn_intelex-2024.7.0.dist-info → scikit_learn_intelex-2025.0.0.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,432 @@
1
+ # ==============================================================================
2
+ # Copyright 2021 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 warnings
18
+ from collections.abc import Sequence
19
+ from numbers import Integral
20
+
21
+ import numpy as np
22
+ from scipy import sparse as sp
23
+
24
+ if np.lib.NumpyVersion(np.__version__) >= np.lib.NumpyVersion("2.0.0a0"):
25
+ # numpy_version >= 2.0
26
+ from numpy.exceptions import VisibleDeprecationWarning
27
+ else:
28
+ # numpy_version < 2.0
29
+ from numpy import VisibleDeprecationWarning
30
+
31
+ from sklearn.preprocessing import LabelEncoder
32
+ from sklearn.utils.validation import check_array
33
+
34
+ from daal4py.sklearn.utils.validation import _assert_all_finite
35
+
36
+
37
+ class DataConversionWarning(UserWarning):
38
+ """Warning used to notify implicit data conversions happening in the code."""
39
+
40
+
41
+ def _is_arraylike(x):
42
+ """Returns whether the input is array-like."""
43
+ return hasattr(x, "__len__") or hasattr(x, "shape") or hasattr(x, "__array__")
44
+
45
+
46
+ def _is_arraylike_not_scalar(array):
47
+ """Return True if array is array-like and not a scalar"""
48
+ return _is_arraylike(array) and not np.isscalar(array)
49
+
50
+
51
+ def _column_or_1d(y, warn=False):
52
+ y = np.asarray(y)
53
+
54
+ # TODO: Convert this kind of arrays to a table like in daal4py
55
+ if not y.flags.aligned and not y.flags.writeable:
56
+ y = np.array(y.tolist())
57
+
58
+ shape = np.shape(y)
59
+ if len(shape) == 1:
60
+ return np.ravel(y)
61
+ if len(shape) == 2 and shape[1] == 1:
62
+ if warn:
63
+ warnings.warn(
64
+ "A column-vector y was passed when a 1d array was"
65
+ " expected. Please change the shape of y to "
66
+ "(n_samples, ), for example using ravel().",
67
+ DataConversionWarning,
68
+ stacklevel=2,
69
+ )
70
+ return np.ravel(y)
71
+
72
+ raise ValueError(
73
+ "y should be a 1d array, " "got an array of shape {} instead.".format(shape)
74
+ )
75
+
76
+
77
+ def _compute_class_weight(class_weight, classes, y):
78
+ if set(y) - set(classes):
79
+ raise ValueError("classes should include all valid labels that can " "be in y")
80
+ if class_weight is None or len(class_weight) == 0:
81
+ weight = np.ones(classes.shape[0], dtype=np.float64, order="C")
82
+ elif class_weight == "balanced":
83
+ y_ = _column_or_1d(y)
84
+ classes, _ = np.unique(y_, return_inverse=True)
85
+
86
+ le = LabelEncoder()
87
+ y_ind = le.fit_transform(y_)
88
+ if not all(np.in1d(classes, le.classes_)):
89
+ raise ValueError("classes should have valid labels that are in y")
90
+
91
+ y_bin = np.bincount(y_ind).astype(np.float64)
92
+ weight = len(y_) / (len(le.classes_) * y_bin)
93
+ else:
94
+ # user-defined dictionary
95
+ weight = np.ones(classes.shape[0], dtype=np.float64, order="C")
96
+ if not isinstance(class_weight, dict):
97
+ raise ValueError(
98
+ "class_weight must be dict, 'balanced', or None,"
99
+ " got: %r" % class_weight
100
+ )
101
+ for c in class_weight:
102
+ i = np.searchsorted(classes, c)
103
+ if i >= len(classes) or classes[i] != c:
104
+ raise ValueError("Class label {} not present.".format(c))
105
+ weight[i] = class_weight[c]
106
+
107
+ return weight
108
+
109
+
110
+ def _validate_targets(y, class_weight, dtype):
111
+ y_ = _column_or_1d(y, warn=True)
112
+ _check_classification_targets(y)
113
+ classes, y = np.unique(y_, return_inverse=True)
114
+ class_weight_res = _compute_class_weight(class_weight, classes=classes, y=y_)
115
+
116
+ if len(classes) < 2:
117
+ raise ValueError(
118
+ "The number of classes has to be greater than one; got %d"
119
+ " class" % len(classes)
120
+ )
121
+
122
+ return np.asarray(y, dtype=dtype, order="C"), class_weight_res, classes
123
+
124
+
125
+ def _check_array(
126
+ array,
127
+ dtype="numeric",
128
+ accept_sparse=False,
129
+ order=None,
130
+ copy=False,
131
+ force_all_finite=True,
132
+ ensure_2d=True,
133
+ accept_large_sparse=True,
134
+ ):
135
+ if force_all_finite:
136
+ if sp.issparse(array):
137
+ if hasattr(array, "data"):
138
+ _assert_all_finite(array.data)
139
+ force_all_finite = False
140
+ else:
141
+ _assert_all_finite(array)
142
+ force_all_finite = False
143
+ array = check_array(
144
+ array=array,
145
+ dtype=dtype,
146
+ accept_sparse=accept_sparse,
147
+ order=order,
148
+ copy=copy,
149
+ force_all_finite=force_all_finite,
150
+ ensure_2d=ensure_2d,
151
+ accept_large_sparse=accept_large_sparse,
152
+ )
153
+
154
+ if sp.issparse(array):
155
+ return array
156
+
157
+ # TODO: Convert this kind of arrays to a table like in daal4py
158
+ if not array.flags.aligned and not array.flags.writeable:
159
+ array = np.array(array.tolist())
160
+
161
+ # TODO: If data is not contiguous copy to contiguous
162
+ # Need implemeted numpy table in oneDAL
163
+ if not array.flags.c_contiguous and not array.flags.f_contiguous:
164
+ array = np.ascontiguousarray(array, array.dtype)
165
+ return array
166
+
167
+
168
+ def _check_X_y(
169
+ X,
170
+ y,
171
+ dtype="numeric",
172
+ accept_sparse=False,
173
+ order=None,
174
+ copy=False,
175
+ force_all_finite=True,
176
+ ensure_2d=True,
177
+ accept_large_sparse=True,
178
+ y_numeric=False,
179
+ accept_2d_y=False,
180
+ ):
181
+ if y is None:
182
+ raise ValueError("y cannot be None")
183
+
184
+ X = _check_array(
185
+ X,
186
+ accept_sparse=accept_sparse,
187
+ dtype=dtype,
188
+ order=order,
189
+ copy=copy,
190
+ force_all_finite=force_all_finite,
191
+ ensure_2d=ensure_2d,
192
+ accept_large_sparse=accept_large_sparse,
193
+ )
194
+
195
+ if not accept_2d_y:
196
+ y = _column_or_1d(y, warn=True)
197
+ else:
198
+ y = np.ascontiguousarray(y)
199
+
200
+ if y_numeric and y.dtype.kind == "O":
201
+ y = y.astype(np.float64)
202
+ if force_all_finite:
203
+ _assert_all_finite(y)
204
+
205
+ lengths = [X.shape[0], y.shape[0]]
206
+ uniques = np.unique(lengths)
207
+ if len(uniques) > 1:
208
+ raise ValueError(
209
+ "Found input variables with inconsistent numbers of"
210
+ " samples: %r" % [int(length) for length in lengths]
211
+ )
212
+
213
+ return X, y
214
+
215
+
216
+ def _check_classification_targets(y):
217
+ y_type = _type_of_target(y)
218
+ if y_type not in [
219
+ "binary",
220
+ "multiclass",
221
+ "multiclass-multioutput",
222
+ "multilabel-indicator",
223
+ "multilabel-sequences",
224
+ ]:
225
+ raise ValueError("Unknown label type: %r" % y_type)
226
+
227
+
228
+ def _type_of_target(y):
229
+ is_sequence, is_array = isinstance(y, Sequence), hasattr(y, "__array__")
230
+ is_not_string, is_sparse = not isinstance(y, str), sp.issparse(y)
231
+ valid = (is_sequence or is_array or is_sparse) and is_not_string
232
+
233
+ if not valid:
234
+ raise ValueError(
235
+ "Expected array-like (array or non-string sequence), " "got %r" % y
236
+ )
237
+
238
+ sparse_pandas = y.__class__.__name__ in ["SparseSeries", "SparseArray"]
239
+ if sparse_pandas:
240
+ raise ValueError("y cannot be class 'SparseSeries' or 'SparseArray'")
241
+
242
+ if _is_multilabel(y):
243
+ return "multilabel-indicator"
244
+
245
+ # DeprecationWarning will be replaced by ValueError, see NEP 34
246
+ # https://numpy.org/neps/nep-0034-infer-dtype-is-object.html
247
+ with warnings.catch_warnings():
248
+ warnings.simplefilter("error", VisibleDeprecationWarning)
249
+ try:
250
+ y = np.asarray(y)
251
+ except VisibleDeprecationWarning:
252
+ # dtype=object should be provided explicitly for ragged arrays,
253
+ # see NEP 34
254
+ y = np.asarray(y, dtype=object)
255
+
256
+ # The old sequence of sequences format
257
+ try:
258
+ if (
259
+ not hasattr(y[0], "__array__")
260
+ and isinstance(y[0], Sequence)
261
+ and not isinstance(y[0], str)
262
+ ):
263
+ raise ValueError(
264
+ "You appear to be using a legacy multi-label data"
265
+ " representation. Sequence of sequences are no"
266
+ " longer supported; use a binary array or sparse"
267
+ " matrix instead - the MultiLabelBinarizer"
268
+ " transformer can convert to this format."
269
+ )
270
+ except IndexError:
271
+ pass
272
+
273
+ # Invalid inputs
274
+ if y.ndim > 2 or (y.dtype == object and len(y) and not isinstance(y.flat[0], str)):
275
+ return "unknown" # [[[1, 2]]] or [obj_1] and not ["label_1"]
276
+
277
+ if y.ndim == 2 and y.shape[1] == 0:
278
+ return "unknown" # [[]]
279
+
280
+ if y.ndim == 2 and y.shape[1] > 1:
281
+ suffix = "-multioutput" # [[1, 2], [1, 2]]
282
+ else:
283
+ suffix = "" # [1, 2, 3] or [[1], [2], [3]]
284
+
285
+ # check float and contains non-integer float values
286
+ if y.dtype.kind == "f" and np.any(y != y.astype(int)):
287
+ # [.1, .2, 3] or [[.1, .2, 3]] or [[1., .2]] and not [1., 2., 3.]
288
+ _assert_all_finite(y)
289
+ return "continuous" + suffix
290
+
291
+ if (len(np.unique(y)) > 2) or (y.ndim >= 2 and len(y[0]) > 1):
292
+ return "multiclass" + suffix # [1, 2, 3] or [[1., 2., 3]] or [[1, 2]]
293
+ return "binary" # [1, 2] or [["a"], ["b"]]
294
+
295
+
296
+ def _is_integral_float(y):
297
+ return y.dtype.kind == "f" and np.all(y.astype(int) == y)
298
+
299
+
300
+ def _is_multilabel(y):
301
+ if hasattr(y, "__array__") or isinstance(y, Sequence):
302
+ # DeprecationWarning will be replaced by ValueError, see NEP 34
303
+ # https://numpy.org/neps/nep-0034-infer-dtype-is-object.html
304
+ with warnings.catch_warnings():
305
+ warnings.simplefilter("error", VisibleDeprecationWarning)
306
+ try:
307
+ y = np.asarray(y)
308
+ except VisibleDeprecationWarning:
309
+ # dtype=object should be provided explicitly for ragged arrays,
310
+ # see NEP 34
311
+ y = np.array(y, dtype=object)
312
+
313
+ if not (hasattr(y, "shape") and y.ndim == 2 and y.shape[1] > 1):
314
+ return False
315
+
316
+ if sp.issparse(y):
317
+ if isinstance(y, (sp.dok_matrix, sp.lil_matrix)):
318
+ y = y.tocsr()
319
+ return (
320
+ len(y.data) == 0
321
+ or np.unique(y.data).size == 1
322
+ and (y.dtype.kind in "biu" or _is_integral_float(np.unique(y.data)))
323
+ )
324
+ labels = np.unique(y)
325
+
326
+ return len(labels) < 3 and (y.dtype.kind in "biu" or _is_integral_float(labels))
327
+
328
+
329
+ def _check_n_features(self, X, reset):
330
+ try:
331
+ n_features = _num_features(X)
332
+ except TypeError as e:
333
+ if not reset and hasattr(self, "n_features_in_"):
334
+ raise ValueError(
335
+ "X does not contain any features, but "
336
+ f"{self.__class__.__name__} is expecting "
337
+ f"{self.n_features_in_} features"
338
+ ) from e
339
+ # If the number of features is not defined and reset=True,
340
+ # then we skip this check
341
+ return
342
+
343
+ if reset:
344
+ self.n_features_in_ = n_features
345
+ return
346
+
347
+ if not hasattr(self, "n_features_in_"):
348
+ # Skip this check if the expected number of expected input features
349
+ # was not recorded by calling fit first. This is typically the case
350
+ # for stateless transformers.
351
+ return
352
+
353
+ if n_features != self.n_features_in_:
354
+ raise ValueError(
355
+ f"X has {n_features} features, but {self.__class__.__name__} "
356
+ f"is expecting {self.n_features_in_} features as input."
357
+ )
358
+
359
+
360
+ def _num_features(X, fallback_1d=False):
361
+ type_ = type(X)
362
+ if type_.__module__ == "builtins":
363
+ type_name = type_.__qualname__
364
+ else:
365
+ type_name = f"{type_.__module__}.{type_.__qualname__}"
366
+ message = "Unable to find the number of features from X of type " f"{type_name}"
367
+ if not hasattr(X, "__len__") and not hasattr(X, "shape"):
368
+ if not hasattr(X, "__array__"):
369
+ raise TypeError(message)
370
+ # Only convert X to a numpy array if there is no cheaper, heuristic
371
+ # option.
372
+ X = np.asarray(X)
373
+
374
+ if hasattr(X, "shape"):
375
+ ndim_thr = 1 if fallback_1d else 2
376
+ if not hasattr(X.shape, "__len__") or len(X.shape) < ndim_thr:
377
+ message += f" with shape {X.shape}"
378
+ raise TypeError(message)
379
+ return X.shape[-1]
380
+
381
+ first_sample = X[0]
382
+
383
+ # Do not consider an array-like of strings or dicts to be a 2D array
384
+ if isinstance(first_sample, (str, bytes, dict)):
385
+ message += f" where the samples are of type " f"{type(first_sample).__qualname__}"
386
+ raise TypeError(message)
387
+
388
+ try:
389
+ # If X is a list of lists, for instance, we assume that all nested
390
+ # lists have the same length without checking or converting to
391
+ # a numpy array to keep this function call as cheap as possible.
392
+ if (not fallback_1d) or hasattr(first_sample, "__len__"):
393
+ return len(first_sample)
394
+ else:
395
+ return 1
396
+ except Exception as err:
397
+ raise TypeError(message) from err
398
+
399
+
400
+ def _num_samples(x):
401
+ message = "Expected sequence or array-like, got %s" % type(x)
402
+ if hasattr(x, "fit") and callable(x.fit):
403
+ # Don't get num_samples from an ensembles length!
404
+ raise TypeError(message)
405
+
406
+ if not hasattr(x, "__len__") and not hasattr(x, "shape"):
407
+ if hasattr(x, "__array__"):
408
+ x = np.asarray(x)
409
+ else:
410
+ raise TypeError(message)
411
+
412
+ if hasattr(x, "shape") and x.shape is not None:
413
+ if len(x.shape) == 0:
414
+ raise TypeError(
415
+ "Singleton array %r cannot be considered a valid collection." % x
416
+ )
417
+ # Check that shape is returning an integer or default to len
418
+ # Dask dataframes may not return numeric shape[0] value
419
+ if hasattr(x, "shape") and isinstance(x.shape[0], Integral):
420
+ return x.shape[0]
421
+
422
+ try:
423
+ return len(x)
424
+ except TypeError as type_error:
425
+ raise TypeError(message) from type_error
426
+
427
+
428
+ def _is_csr(x):
429
+ """Return True if x is scipy.sparse.csr_matrix or scipy.sparse.csr_array"""
430
+ return isinstance(x, sp.csr_matrix) or (
431
+ hasattr(sp, "csr_array") and isinstance(x, sp.csr_array)
432
+ )
@@ -22,11 +22,11 @@ from onedal._device_offload import (
22
22
  _transfer_to_host,
23
23
  dpnp_available,
24
24
  )
25
+ from onedal.utils._array_api import _asarray, _is_numpy_namespace
25
26
 
26
27
  if dpnp_available:
27
28
  import dpnp
28
- from onedal._device_offload import _convert_to_dpnp
29
-
29
+ from onedal.utils._array_api import _convert_to_dpnp
30
30
 
31
31
  from ._config import get_config
32
32
 
@@ -73,26 +73,49 @@ def dispatch(obj, method_name, branches, *args, **kwargs):
73
73
  patching_status.write_log(queue=q)
74
74
  return branches[backend](obj, *hostargs, **hostkwargs, queue=q)
75
75
  if backend == "sklearn":
76
- patching_status.write_log()
77
- return branches[backend](obj, *hostargs, **hostkwargs)
76
+ if (
77
+ "array_api_dispatch" in get_config()
78
+ and get_config()["array_api_dispatch"]
79
+ and "array_api_support" in obj._get_tags()
80
+ and obj._get_tags()["array_api_support"]
81
+ ):
82
+ # If `array_api_dispatch` enabled and array api is supported for the stock scikit-learn,
83
+ # then raw inputs are used for the fallback.
84
+ patching_status.write_log()
85
+ return branches[backend](obj, *args, **kwargs)
86
+ else:
87
+ patching_status.write_log()
88
+ return branches[backend](obj, *hostargs, **hostkwargs)
78
89
  raise RuntimeError(
79
90
  f"Undefined backend {backend} in " f"{obj.__class__.__name__}.{method_name}"
80
91
  )
81
92
 
82
93
 
83
94
  def wrap_output_data(func):
95
+ """
96
+ Converts and moves the output arrays of the decorated function
97
+ to match the input array type and device.
98
+ """
99
+
84
100
  @wraps(func)
85
101
  def wrapper(self, *args, **kwargs):
86
- data = (*args, *kwargs.values())
87
- if len(data) == 0:
88
- usm_iface = None
89
- else:
90
- usm_iface = getattr(data[0], "__sycl_usm_array_interface__", None)
91
102
  result = func(self, *args, **kwargs)
92
- if usm_iface is not None:
93
- result = _copy_to_usm(usm_iface["syclobj"], result)
94
- if dpnp_available and isinstance(data[0], dpnp.ndarray):
95
- result = _convert_to_dpnp(result)
103
+ if not (len(args) == 0 and len(kwargs) == 0):
104
+ data = (*args, *kwargs.values())
105
+ usm_iface = getattr(data[0], "__sycl_usm_array_interface__", None)
106
+ if usm_iface is not None:
107
+ result = _copy_to_usm(usm_iface["syclobj"], result)
108
+ if dpnp_available and isinstance(data[0], dpnp.ndarray):
109
+ result = _convert_to_dpnp(result)
110
+ return result
111
+ config = get_config()
112
+ if not ("transform_output" in config and config["transform_output"]):
113
+ input_array_api = getattr(data[0], "__array_namespace__", lambda: None)()
114
+ if input_array_api:
115
+ input_array_api_device = data[0].device
116
+ result = _asarray(
117
+ result, input_array_api, device=input_array_api_device
118
+ )
96
119
  return result
97
120
 
98
121
  return wrapper
@@ -0,0 +1,20 @@
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 .basic_statistics import BasicStatistics
18
+ from .incremental_basic_statistics import IncrementalBasicStatistics
19
+
20
+ __all__ = ["BasicStatistics", "IncrementalBasicStatistics"]
@@ -107,9 +107,6 @@ class BasicStatistics(BaseEstimator):
107
107
  self._onedal_estimator.fit(X, sample_weight, queue)
108
108
  self._save_attributes()
109
109
 
110
- def compute(self, data, weights=None, queue=None):
111
- return self._onedal_estimator.compute(data, weights, queue)
112
-
113
110
  def fit(self, X, y=None, *, sample_weight=None):
114
111
  """Compute statistics with X, using minibatches of size batch_size.
115
112
 
@@ -120,7 +120,7 @@ class IncrementalBasicStatistics(BaseEstimator):
120
120
 
121
121
  def _onedal_supported(self, method_name, *data):
122
122
  patching_status = PatchingConditionsChain(
123
- f"sklearn.covariance.{self.__class__.__name__}.{method_name}"
123
+ f"sklearn.basic_statistics.{self.__class__.__name__}.{method_name}"
124
124
  )
125
125
  return patching_status
126
126
 
@@ -135,9 +135,9 @@ class IncrementalBasicStatistics(BaseEstimator):
135
135
  assert isinstance(onedal_options, str)
136
136
  return options
137
137
 
138
- def _onedal_finalize_fit(self):
138
+ def _onedal_finalize_fit(self, queue=None):
139
139
  assert hasattr(self, "_onedal_estimator")
140
- self._onedal_estimator.finalize_fit()
140
+ self._onedal_estimator.finalize_fit(queue=queue)
141
141
  self._need_to_finalize = False
142
142
 
143
143
  def _onedal_partial_fit(self, X, sample_weight=None, queue=None):
@@ -171,7 +171,7 @@ class IncrementalBasicStatistics(BaseEstimator):
171
171
  self._onedal_estimator = self._onedal_incremental_basic_statistics(
172
172
  **onedal_params
173
173
  )
174
- self._onedal_estimator.partial_fit(X, sample_weight, queue)
174
+ self._onedal_estimator.partial_fit(X, weights=sample_weight, queue=queue)
175
175
  self._need_to_finalize = True
176
176
 
177
177
  def _onedal_fit(self, X, sample_weight=None, queue=None):
@@ -203,7 +203,7 @@ class IncrementalBasicStatistics(BaseEstimator):
203
203
 
204
204
  self.n_features_in_ = X.shape[1]
205
205
 
206
- self._onedal_finalize_fit()
206
+ self._onedal_finalize_fit(queue=queue)
207
207
 
208
208
  return self
209
209
 
@@ -17,4 +17,4 @@
17
17
  from .dbscan import DBSCAN
18
18
  from .k_means import KMeans
19
19
 
20
- __all__ = ["KMeans", "DBSCAN"]
20
+ __all__ = ["DBSCAN", "KMeans"]