maxframe 1.3.0__cp38-cp38-win_amd64.whl → 2.0.0b1__cp38-cp38-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 maxframe might be problematic. Click here for more details.
- maxframe/_utils.cp38-win_amd64.pyd +0 -0
- maxframe/_utils.pyi +21 -0
- maxframe/_utils.pyx +4 -3
- maxframe/codegen/__init__.py +27 -0
- maxframe/{codegen.py → codegen/core.py} +49 -43
- maxframe/codegen/spe/__init__.py +16 -0
- maxframe/codegen/spe/core.py +307 -0
- maxframe/codegen/spe/dataframe/__init__.py +37 -0
- maxframe/codegen/spe/dataframe/accessors/__init__.py +15 -0
- maxframe/codegen/spe/dataframe/accessors/base.py +53 -0
- maxframe/codegen/spe/dataframe/accessors/dict_.py +194 -0
- maxframe/codegen/spe/dataframe/accessors/list_.py +80 -0
- maxframe/codegen/spe/dataframe/arithmetic.py +84 -0
- maxframe/codegen/spe/dataframe/datasource.py +181 -0
- maxframe/codegen/spe/dataframe/datastore.py +204 -0
- maxframe/codegen/spe/dataframe/extensions.py +63 -0
- maxframe/codegen/spe/dataframe/fetch.py +26 -0
- maxframe/codegen/spe/dataframe/groupby.py +224 -0
- maxframe/codegen/spe/dataframe/indexing.py +238 -0
- maxframe/codegen/spe/dataframe/merge.py +73 -0
- maxframe/codegen/spe/dataframe/misc.py +286 -0
- maxframe/codegen/spe/dataframe/missing.py +64 -0
- maxframe/codegen/spe/dataframe/reduction.py +160 -0
- maxframe/codegen/spe/dataframe/sort.py +83 -0
- maxframe/codegen/spe/dataframe/statistics.py +46 -0
- maxframe/codegen/spe/dataframe/tests/__init__.py +13 -0
- maxframe/codegen/spe/dataframe/tests/accessors/__init__.py +13 -0
- maxframe/codegen/spe/dataframe/tests/accessors/test_base.py +33 -0
- maxframe/codegen/spe/dataframe/tests/accessors/test_dict.py +310 -0
- maxframe/codegen/spe/dataframe/tests/accessors/test_list.py +137 -0
- maxframe/codegen/spe/dataframe/tests/indexing/__init__.py +13 -0
- maxframe/codegen/spe/dataframe/tests/indexing/conftest.py +58 -0
- maxframe/codegen/spe/dataframe/tests/indexing/test_getitem.py +124 -0
- maxframe/codegen/spe/dataframe/tests/indexing/test_iloc.py +76 -0
- maxframe/codegen/spe/dataframe/tests/indexing/test_indexing.py +39 -0
- maxframe/codegen/spe/dataframe/tests/indexing/test_rename.py +51 -0
- maxframe/codegen/spe/dataframe/tests/indexing/test_reset_index.py +88 -0
- maxframe/codegen/spe/dataframe/tests/indexing/test_sample.py +45 -0
- maxframe/codegen/spe/dataframe/tests/indexing/test_set_axis.py +45 -0
- maxframe/codegen/spe/dataframe/tests/indexing/test_set_index.py +41 -0
- maxframe/codegen/spe/dataframe/tests/indexing/test_setitem.py +46 -0
- maxframe/codegen/spe/dataframe/tests/misc/__init__.py +13 -0
- maxframe/codegen/spe/dataframe/tests/misc/test_apply.py +133 -0
- maxframe/codegen/spe/dataframe/tests/misc/test_drop_duplicates.py +92 -0
- maxframe/codegen/spe/dataframe/tests/misc/test_misc.py +234 -0
- maxframe/codegen/spe/dataframe/tests/missing/__init__.py +13 -0
- maxframe/codegen/spe/dataframe/tests/missing/test_checkna.py +94 -0
- maxframe/codegen/spe/dataframe/tests/missing/test_dropna.py +50 -0
- maxframe/codegen/spe/dataframe/tests/missing/test_fillna.py +94 -0
- maxframe/codegen/spe/dataframe/tests/missing/test_replace.py +45 -0
- maxframe/codegen/spe/dataframe/tests/test_arithmetic.py +73 -0
- maxframe/codegen/spe/dataframe/tests/test_datasource.py +184 -0
- maxframe/codegen/spe/dataframe/tests/test_datastore.py +200 -0
- maxframe/codegen/spe/dataframe/tests/test_extensions.py +88 -0
- maxframe/codegen/spe/dataframe/tests/test_groupby.py +225 -0
- maxframe/codegen/spe/dataframe/tests/test_merge.py +400 -0
- maxframe/codegen/spe/dataframe/tests/test_reduction.py +104 -0
- maxframe/codegen/spe/dataframe/tests/test_sort.py +159 -0
- maxframe/codegen/spe/dataframe/tests/test_statistics.py +70 -0
- maxframe/codegen/spe/dataframe/tests/test_tseries.py +29 -0
- maxframe/codegen/spe/dataframe/tests/test_value_counts.py +60 -0
- maxframe/codegen/spe/dataframe/tests/test_window.py +69 -0
- maxframe/codegen/spe/dataframe/tseries.py +46 -0
- maxframe/codegen/spe/dataframe/udf.py +62 -0
- maxframe/codegen/spe/dataframe/value_counts.py +31 -0
- maxframe/codegen/spe/dataframe/window.py +65 -0
- maxframe/codegen/spe/learn/__init__.py +15 -0
- maxframe/codegen/spe/learn/contrib/__init__.py +15 -0
- maxframe/codegen/spe/learn/contrib/lightgbm.py +160 -0
- maxframe/codegen/spe/learn/contrib/models.py +41 -0
- maxframe/codegen/spe/learn/contrib/pytorch.py +49 -0
- maxframe/codegen/spe/learn/contrib/tests/__init__.py +13 -0
- maxframe/codegen/spe/learn/contrib/tests/test_lightgbm.py +123 -0
- maxframe/codegen/spe/learn/contrib/tests/test_models.py +41 -0
- maxframe/codegen/spe/learn/contrib/tests/test_pytorch.py +53 -0
- maxframe/codegen/spe/learn/contrib/tests/test_xgboost.py +98 -0
- maxframe/codegen/spe/learn/contrib/xgboost.py +152 -0
- maxframe/codegen/spe/learn/metrics/__init__.py +15 -0
- maxframe/codegen/spe/learn/metrics/_classification.py +120 -0
- maxframe/codegen/spe/learn/metrics/tests/__init__.py +13 -0
- maxframe/codegen/spe/learn/metrics/tests/test_classification.py +93 -0
- maxframe/codegen/spe/learn/model_selection/__init__.py +13 -0
- maxframe/codegen/spe/learn/model_selection/tests/__init__.py +13 -0
- maxframe/codegen/spe/learn/model_selection/tests/test_split.py +41 -0
- maxframe/codegen/spe/learn/preprocessing/__init__.py +15 -0
- maxframe/codegen/spe/learn/preprocessing/_data.py +37 -0
- maxframe/codegen/spe/learn/preprocessing/_label.py +47 -0
- maxframe/codegen/spe/learn/preprocessing/tests/__init__.py +13 -0
- maxframe/codegen/spe/learn/preprocessing/tests/test_data.py +31 -0
- maxframe/codegen/spe/learn/preprocessing/tests/test_label.py +43 -0
- maxframe/codegen/spe/learn/utils/__init__.py +15 -0
- maxframe/codegen/spe/learn/utils/checks.py +55 -0
- maxframe/codegen/spe/learn/utils/multiclass.py +60 -0
- maxframe/codegen/spe/learn/utils/shuffle.py +85 -0
- maxframe/codegen/spe/learn/utils/sparsefuncs.py +35 -0
- maxframe/codegen/spe/learn/utils/tests/__init__.py +13 -0
- maxframe/codegen/spe/learn/utils/tests/test_checks.py +48 -0
- maxframe/codegen/spe/learn/utils/tests/test_multiclass.py +52 -0
- maxframe/codegen/spe/learn/utils/tests/test_shuffle.py +50 -0
- maxframe/codegen/spe/learn/utils/tests/test_sparsefuncs.py +34 -0
- maxframe/codegen/spe/learn/utils/tests/test_validation.py +44 -0
- maxframe/codegen/spe/learn/utils/validation.py +35 -0
- maxframe/codegen/spe/objects.py +26 -0
- maxframe/codegen/spe/remote.py +29 -0
- maxframe/codegen/spe/tensor/__init__.py +28 -0
- maxframe/codegen/spe/tensor/arithmetic.py +95 -0
- maxframe/codegen/spe/tensor/core.py +41 -0
- maxframe/codegen/spe/tensor/datasource.py +165 -0
- maxframe/codegen/spe/tensor/extensions.py +35 -0
- maxframe/codegen/spe/tensor/fetch.py +26 -0
- maxframe/codegen/spe/tensor/indexing.py +63 -0
- maxframe/codegen/spe/tensor/linalg.py +63 -0
- maxframe/codegen/spe/tensor/merge.py +31 -0
- maxframe/codegen/spe/tensor/misc.py +121 -0
- maxframe/codegen/spe/tensor/random.py +29 -0
- maxframe/codegen/spe/tensor/reduction.py +39 -0
- maxframe/codegen/spe/tensor/reshape.py +26 -0
- maxframe/codegen/spe/tensor/sort.py +42 -0
- maxframe/codegen/spe/tensor/special.py +35 -0
- maxframe/codegen/spe/tensor/statistics.py +24 -0
- maxframe/codegen/spe/tensor/tests/__init__.py +13 -0
- maxframe/codegen/spe/tensor/tests/test_arithmetic.py +103 -0
- maxframe/codegen/spe/tensor/tests/test_datasource.py +99 -0
- maxframe/codegen/spe/tensor/tests/test_extensions.py +37 -0
- maxframe/codegen/spe/tensor/tests/test_indexing.py +44 -0
- maxframe/codegen/spe/tensor/tests/test_linalg.py +38 -0
- maxframe/codegen/spe/tensor/tests/test_merge.py +28 -0
- maxframe/codegen/spe/tensor/tests/test_misc.py +94 -0
- maxframe/codegen/spe/tensor/tests/test_random.py +55 -0
- maxframe/codegen/spe/tensor/tests/test_reduction.py +65 -0
- maxframe/codegen/spe/tensor/tests/test_reshape.py +39 -0
- maxframe/codegen/spe/tensor/tests/test_sort.py +49 -0
- maxframe/codegen/spe/tensor/tests/test_special.py +28 -0
- maxframe/codegen/spe/tensor/tests/test_statistics.py +29 -0
- maxframe/codegen/spe/tests/__init__.py +13 -0
- maxframe/codegen/spe/tests/test_remote.py +29 -0
- maxframe/codegen/spe/tests/test_spe_codegen.py +141 -0
- maxframe/codegen/spe/utils.py +54 -0
- maxframe/codegen/tests/__init__.py +13 -0
- maxframe/{tests → codegen/tests}/test_codegen.py +3 -5
- maxframe/config/__init__.py +1 -1
- maxframe/config/config.py +50 -23
- maxframe/config/tests/test_config.py +4 -12
- maxframe/config/validators.py +5 -0
- maxframe/conftest.py +38 -10
- maxframe/core/__init__.py +1 -0
- maxframe/core/context.py +110 -0
- maxframe/core/entity/__init__.py +1 -0
- maxframe/core/entity/core.py +0 -7
- maxframe/core/entity/objects.py +19 -5
- maxframe/core/entity/output_types.py +11 -0
- maxframe/core/entity/tests/test_objects.py +11 -12
- maxframe/core/entity/tileables.py +3 -1
- maxframe/core/entity/utils.py +15 -0
- maxframe/core/graph/__init__.py +6 -1
- maxframe/core/graph/builder/base.py +5 -1
- maxframe/core/graph/core.cp38-win_amd64.pyd +0 -0
- maxframe/core/graph/core.pyx +17 -6
- maxframe/core/graph/entity.py +18 -6
- maxframe/core/operator/__init__.py +8 -3
- maxframe/core/operator/base.py +35 -12
- maxframe/core/operator/core.py +37 -14
- maxframe/core/operator/fetch.py +5 -18
- maxframe/core/operator/objects.py +0 -20
- maxframe/core/operator/shuffle.py +6 -72
- maxframe/dataframe/__init__.py +1 -0
- maxframe/dataframe/accessors/datetime_/core.py +7 -4
- maxframe/dataframe/accessors/string_/core.py +9 -6
- maxframe/dataframe/arithmetic/core.py +31 -20
- maxframe/dataframe/arithmetic/tests/test_arithmetic.py +6 -0
- maxframe/dataframe/core.py +98 -91
- maxframe/dataframe/datasource/core.py +8 -1
- maxframe/dataframe/datasource/date_range.py +8 -0
- maxframe/dataframe/datasource/from_index.py +9 -5
- maxframe/dataframe/datasource/from_records.py +9 -2
- maxframe/dataframe/datasource/from_tensor.py +32 -21
- maxframe/dataframe/datasource/read_csv.py +8 -2
- maxframe/dataframe/datasource/read_odps_query.py +33 -3
- maxframe/dataframe/datasource/read_odps_table.py +20 -5
- maxframe/dataframe/datasource/read_parquet.py +8 -3
- maxframe/dataframe/datasource/tests/test_datasource.py +33 -0
- maxframe/dataframe/datastore/tests/test_to_odps.py +52 -1
- maxframe/dataframe/datastore/to_csv.py +7 -3
- maxframe/dataframe/datastore/to_odps.py +42 -6
- maxframe/dataframe/extensions/__init__.py +6 -1
- maxframe/dataframe/extensions/apply_chunk.py +96 -136
- maxframe/dataframe/extensions/flatjson.py +3 -2
- maxframe/dataframe/extensions/flatmap.py +15 -7
- maxframe/dataframe/fetch/core.py +12 -1
- maxframe/dataframe/groupby/__init__.py +7 -0
- maxframe/dataframe/groupby/aggregation.py +62 -9
- maxframe/dataframe/groupby/apply.py +50 -74
- maxframe/dataframe/groupby/apply_chunk.py +393 -0
- maxframe/dataframe/groupby/core.py +80 -17
- maxframe/dataframe/groupby/extensions.py +26 -0
- maxframe/dataframe/groupby/fill.py +9 -4
- maxframe/dataframe/groupby/sample.py +7 -7
- maxframe/dataframe/groupby/tests/test_groupby.py +3 -3
- maxframe/dataframe/groupby/transform.py +57 -54
- maxframe/dataframe/indexing/align.py +7 -6
- maxframe/dataframe/indexing/getitem.py +9 -8
- maxframe/dataframe/indexing/iloc.py +28 -23
- maxframe/dataframe/indexing/insert.py +7 -3
- maxframe/dataframe/indexing/loc.py +9 -8
- maxframe/dataframe/indexing/reindex.py +36 -30
- maxframe/dataframe/indexing/rename_axis.py +18 -10
- maxframe/dataframe/indexing/reset_index.py +0 -2
- maxframe/dataframe/indexing/sample.py +13 -9
- maxframe/dataframe/indexing/set_axis.py +9 -6
- maxframe/dataframe/indexing/setitem.py +8 -5
- maxframe/dataframe/indexing/where.py +12 -9
- maxframe/dataframe/merge/__init__.py +0 -1
- maxframe/dataframe/merge/concat.py +10 -31
- maxframe/dataframe/merge/merge.py +2 -24
- maxframe/dataframe/misc/__init__.py +6 -0
- maxframe/dataframe/misc/_duplicate.py +7 -3
- maxframe/dataframe/misc/apply.py +106 -139
- maxframe/dataframe/misc/astype.py +3 -2
- maxframe/dataframe/misc/case_when.py +11 -7
- maxframe/dataframe/misc/cut.py +11 -10
- maxframe/dataframe/misc/describe.py +7 -3
- maxframe/dataframe/misc/drop.py +13 -11
- maxframe/dataframe/misc/eval.py +0 -2
- maxframe/dataframe/misc/get_dummies.py +78 -49
- maxframe/dataframe/misc/isin.py +13 -10
- maxframe/dataframe/misc/map.py +21 -6
- maxframe/dataframe/misc/melt.py +8 -1
- maxframe/dataframe/misc/pivot.py +232 -0
- maxframe/dataframe/misc/pivot_table.py +52 -40
- maxframe/dataframe/misc/rechunk.py +59 -0
- maxframe/dataframe/misc/shift.py +7 -4
- maxframe/dataframe/misc/stack.py +5 -3
- maxframe/dataframe/misc/tests/test_misc.py +167 -1
- maxframe/dataframe/misc/transform.py +63 -65
- maxframe/dataframe/misc/value_counts.py +7 -4
- maxframe/dataframe/missing/dropna.py +16 -7
- maxframe/dataframe/missing/fillna.py +18 -10
- maxframe/dataframe/missing/replace.py +10 -6
- maxframe/dataframe/missing/tests/test_missing.py +2 -2
- maxframe/dataframe/operators.py +1 -27
- maxframe/dataframe/reduction/aggregation.py +128 -3
- maxframe/dataframe/reduction/core.py +20 -6
- maxframe/dataframe/reduction/median.py +1 -1
- maxframe/dataframe/reduction/tests/test_reduction.py +33 -0
- maxframe/dataframe/reduction/unique.py +53 -7
- maxframe/dataframe/statistics/corr.py +9 -6
- maxframe/dataframe/statistics/quantile.py +9 -6
- maxframe/dataframe/tseries/to_datetime.py +6 -4
- maxframe/dataframe/utils.py +219 -31
- maxframe/dataframe/window/rolling.py +7 -4
- maxframe/env.py +1 -0
- maxframe/errors.py +9 -0
- maxframe/extension.py +13 -2
- maxframe/io/objects/core.py +67 -51
- maxframe/io/objects/tensor.py +73 -17
- maxframe/io/objects/tests/test_object_io.py +8 -55
- maxframe/io/odpsio/arrow.py +15 -2
- maxframe/io/odpsio/schema.py +43 -13
- maxframe/io/odpsio/tableio.py +63 -11
- maxframe/io/odpsio/tests/test_arrow.py +1 -2
- maxframe/io/odpsio/tests/test_schema.py +114 -1
- maxframe/io/odpsio/tests/test_tableio.py +42 -0
- maxframe/io/odpsio/tests/test_volumeio.py +22 -48
- maxframe/learn/__init__.py +2 -2
- maxframe/learn/contrib/__init__.py +2 -2
- maxframe/learn/contrib/graph/connected_components.py +2 -1
- maxframe/learn/contrib/lightgbm/__init__.py +33 -0
- maxframe/learn/contrib/lightgbm/_predict.py +138 -0
- maxframe/learn/contrib/lightgbm/_train.py +163 -0
- maxframe/learn/contrib/lightgbm/callback.py +114 -0
- maxframe/learn/contrib/lightgbm/classifier.py +199 -0
- maxframe/learn/contrib/lightgbm/core.py +372 -0
- maxframe/learn/contrib/lightgbm/dataset.py +153 -0
- maxframe/learn/contrib/lightgbm/regressor.py +29 -0
- maxframe/learn/contrib/lightgbm/tests/__init__.py +13 -0
- maxframe/learn/contrib/lightgbm/tests/test_callback.py +58 -0
- maxframe/learn/contrib/llm/models/dashscope.py +34 -0
- maxframe/learn/contrib/llm/models/managed.py +15 -0
- maxframe/learn/contrib/llm/multi_modal.py +92 -0
- maxframe/learn/contrib/llm/text.py +21 -5
- maxframe/learn/contrib/models.py +38 -9
- maxframe/learn/contrib/utils.py +55 -0
- maxframe/learn/contrib/xgboost/callback.py +86 -0
- maxframe/learn/contrib/xgboost/classifier.py +26 -30
- maxframe/learn/contrib/xgboost/core.py +53 -42
- maxframe/learn/contrib/xgboost/dmatrix.py +19 -12
- maxframe/learn/contrib/xgboost/predict.py +13 -8
- maxframe/learn/contrib/xgboost/regressor.py +28 -27
- maxframe/learn/contrib/xgboost/tests/test_callback.py +41 -0
- maxframe/learn/contrib/xgboost/train.py +59 -16
- maxframe/learn/core.py +252 -0
- maxframe/learn/datasets/__init__.py +20 -0
- maxframe/learn/datasets/samples_generator.py +628 -0
- maxframe/learn/linear_model/__init__.py +15 -0
- maxframe/learn/linear_model/_base.py +163 -0
- maxframe/learn/linear_model/_lin_reg.py +175 -0
- maxframe/learn/metrics/__init__.py +25 -0
- maxframe/learn/metrics/_check_targets.py +95 -0
- maxframe/learn/metrics/_classification.py +1121 -0
- maxframe/learn/metrics/_regression.py +256 -0
- maxframe/learn/model_selection/__init__.py +15 -0
- maxframe/learn/model_selection/_split.py +451 -0
- maxframe/learn/model_selection/tests/__init__.py +13 -0
- maxframe/learn/model_selection/tests/test_split.py +156 -0
- maxframe/learn/preprocessing/__init__.py +16 -0
- maxframe/learn/preprocessing/_data/__init__.py +17 -0
- maxframe/learn/preprocessing/_data/min_max_scaler.py +390 -0
- maxframe/learn/preprocessing/_data/normalize.py +127 -0
- maxframe/learn/preprocessing/_data/standard_scaler.py +503 -0
- maxframe/learn/preprocessing/_data/utils.py +79 -0
- maxframe/learn/preprocessing/_label/__init__.py +16 -0
- maxframe/learn/preprocessing/_label/_label_binarizer.py +599 -0
- maxframe/learn/preprocessing/_label/_label_encoder.py +174 -0
- maxframe/learn/utils/__init__.py +4 -0
- maxframe/learn/utils/_encode.py +314 -0
- maxframe/learn/utils/checks.py +161 -0
- maxframe/learn/utils/core.py +33 -0
- maxframe/learn/utils/extmath.py +176 -0
- maxframe/learn/utils/multiclass.py +292 -0
- maxframe/learn/utils/shuffle.py +114 -0
- maxframe/learn/utils/sparsefuncs.py +87 -0
- maxframe/learn/utils/validation.py +775 -0
- maxframe/lib/__init__.py +0 -2
- maxframe/lib/compat.py +145 -0
- maxframe/lib/filesystem/_oss_lib/glob.py +1 -1
- maxframe/lib/mmh3.cp38-win_amd64.pyd +0 -0
- maxframe/lib/sparse/__init__.py +10 -15
- maxframe/lib/sparse/array.py +45 -33
- maxframe/lib/sparse/core.py +0 -2
- maxframe/lib/sparse/linalg.py +31 -0
- maxframe/lib/sparse/matrix.py +5 -2
- maxframe/lib/sparse/tests/__init__.py +0 -2
- maxframe/lib/sparse/tests/test_sparse.py +53 -53
- maxframe/lib/sparse/vector.py +0 -2
- maxframe/mixin.py +59 -2
- maxframe/opcodes.py +13 -5
- maxframe/protocol.py +67 -14
- maxframe/remote/core.py +16 -14
- maxframe/remote/run_script.py +6 -3
- maxframe/serialization/__init__.py +2 -0
- maxframe/serialization/core.cp38-win_amd64.pyd +0 -0
- maxframe/serialization/core.pxd +3 -0
- maxframe/serialization/core.pyi +3 -1
- maxframe/serialization/core.pyx +82 -4
- maxframe/serialization/pandas.py +5 -1
- maxframe/serialization/serializables/core.py +6 -5
- maxframe/serialization/serializables/field.py +2 -2
- maxframe/serialization/serializables/tests/test_field_type.py +3 -5
- maxframe/serialization/tests/test_serial.py +27 -0
- maxframe/session.py +4 -71
- maxframe/sperunner.py +165 -0
- maxframe/tensor/__init__.py +35 -2
- maxframe/tensor/arithmetic/__init__.py +2 -4
- maxframe/tensor/arithmetic/abs.py +0 -2
- maxframe/tensor/arithmetic/absolute.py +0 -2
- maxframe/tensor/arithmetic/add.py +34 -4
- maxframe/tensor/arithmetic/angle.py +0 -2
- maxframe/tensor/arithmetic/arccos.py +1 -4
- maxframe/tensor/arithmetic/arccosh.py +1 -3
- maxframe/tensor/arithmetic/arcsin.py +0 -2
- maxframe/tensor/arithmetic/arcsinh.py +0 -2
- maxframe/tensor/arithmetic/arctan.py +0 -2
- maxframe/tensor/arithmetic/arctan2.py +0 -2
- maxframe/tensor/arithmetic/arctanh.py +0 -2
- maxframe/tensor/arithmetic/around.py +0 -2
- maxframe/tensor/arithmetic/bitand.py +0 -2
- maxframe/tensor/arithmetic/bitor.py +1 -3
- maxframe/tensor/arithmetic/bitxor.py +1 -3
- maxframe/tensor/arithmetic/cbrt.py +0 -2
- maxframe/tensor/arithmetic/ceil.py +0 -2
- maxframe/tensor/arithmetic/clip.py +13 -13
- maxframe/tensor/arithmetic/conj.py +0 -2
- maxframe/tensor/arithmetic/copysign.py +0 -2
- maxframe/tensor/arithmetic/core.py +47 -39
- maxframe/tensor/arithmetic/cos.py +1 -3
- maxframe/tensor/arithmetic/cosh.py +0 -2
- maxframe/tensor/arithmetic/deg2rad.py +0 -2
- maxframe/tensor/arithmetic/degrees.py +0 -2
- maxframe/tensor/arithmetic/divide.py +0 -2
- maxframe/tensor/arithmetic/equal.py +0 -2
- maxframe/tensor/arithmetic/exp.py +1 -3
- maxframe/tensor/arithmetic/exp2.py +0 -2
- maxframe/tensor/arithmetic/expm1.py +0 -2
- maxframe/tensor/arithmetic/fabs.py +0 -2
- maxframe/tensor/arithmetic/fix.py +0 -2
- maxframe/tensor/arithmetic/float_power.py +0 -2
- maxframe/tensor/arithmetic/floor.py +0 -2
- maxframe/tensor/arithmetic/floordiv.py +0 -2
- maxframe/tensor/arithmetic/fmax.py +0 -2
- maxframe/tensor/arithmetic/fmin.py +0 -2
- maxframe/tensor/arithmetic/fmod.py +0 -2
- maxframe/tensor/arithmetic/frexp.py +6 -2
- maxframe/tensor/arithmetic/greater.py +0 -2
- maxframe/tensor/arithmetic/greater_equal.py +0 -2
- maxframe/tensor/arithmetic/hypot.py +0 -2
- maxframe/tensor/arithmetic/i0.py +1 -3
- maxframe/tensor/arithmetic/imag.py +0 -2
- maxframe/tensor/arithmetic/invert.py +1 -3
- maxframe/tensor/arithmetic/isclose.py +0 -2
- maxframe/tensor/arithmetic/iscomplex.py +0 -2
- maxframe/tensor/arithmetic/isfinite.py +1 -3
- maxframe/tensor/arithmetic/isinf.py +0 -2
- maxframe/tensor/arithmetic/isnan.py +0 -2
- maxframe/tensor/arithmetic/isreal.py +0 -2
- maxframe/tensor/arithmetic/ldexp.py +0 -2
- maxframe/tensor/arithmetic/less.py +0 -2
- maxframe/tensor/arithmetic/less_equal.py +0 -2
- maxframe/tensor/arithmetic/log.py +1 -3
- maxframe/tensor/arithmetic/log10.py +1 -3
- maxframe/tensor/arithmetic/log1p.py +1 -3
- maxframe/tensor/arithmetic/log2.py +1 -3
- maxframe/tensor/arithmetic/logaddexp.py +0 -2
- maxframe/tensor/arithmetic/logaddexp2.py +0 -2
- maxframe/tensor/arithmetic/logical_and.py +0 -2
- maxframe/tensor/arithmetic/logical_not.py +1 -3
- maxframe/tensor/arithmetic/logical_or.py +0 -2
- maxframe/tensor/arithmetic/logical_xor.py +0 -2
- maxframe/tensor/arithmetic/lshift.py +0 -2
- maxframe/tensor/arithmetic/maximum.py +0 -2
- maxframe/tensor/arithmetic/minimum.py +0 -2
- maxframe/tensor/arithmetic/mod.py +0 -2
- maxframe/tensor/arithmetic/modf.py +6 -2
- maxframe/tensor/arithmetic/multiply.py +37 -4
- maxframe/tensor/arithmetic/nan_to_num.py +0 -2
- maxframe/tensor/arithmetic/negative.py +0 -2
- maxframe/tensor/arithmetic/nextafter.py +0 -2
- maxframe/tensor/arithmetic/not_equal.py +0 -2
- maxframe/tensor/arithmetic/positive.py +0 -2
- maxframe/tensor/arithmetic/power.py +0 -2
- maxframe/tensor/arithmetic/rad2deg.py +0 -2
- maxframe/tensor/arithmetic/radians.py +0 -2
- maxframe/tensor/arithmetic/real.py +0 -2
- maxframe/tensor/arithmetic/reciprocal.py +5 -3
- maxframe/tensor/arithmetic/rint.py +1 -3
- maxframe/tensor/arithmetic/rshift.py +0 -2
- maxframe/tensor/arithmetic/setimag.py +0 -2
- maxframe/tensor/arithmetic/setreal.py +0 -2
- maxframe/tensor/arithmetic/sign.py +0 -2
- maxframe/tensor/arithmetic/signbit.py +0 -2
- maxframe/tensor/arithmetic/sin.py +0 -2
- maxframe/tensor/arithmetic/sinc.py +1 -3
- maxframe/tensor/arithmetic/sinh.py +0 -2
- maxframe/tensor/arithmetic/spacing.py +0 -2
- maxframe/tensor/arithmetic/sqrt.py +0 -2
- maxframe/tensor/arithmetic/square.py +0 -2
- maxframe/tensor/arithmetic/subtract.py +4 -2
- maxframe/tensor/arithmetic/tan.py +0 -2
- maxframe/tensor/arithmetic/tanh.py +0 -2
- maxframe/tensor/arithmetic/tests/__init__.py +0 -2
- maxframe/tensor/arithmetic/tests/test_arithmetic.py +43 -9
- maxframe/tensor/arithmetic/truediv.py +0 -2
- maxframe/tensor/arithmetic/trunc.py +0 -2
- maxframe/tensor/arithmetic/utils.py +32 -6
- maxframe/tensor/array_utils.py +3 -25
- maxframe/tensor/core.py +6 -6
- maxframe/tensor/datasource/__init__.py +10 -2
- maxframe/tensor/datasource/arange.py +0 -2
- maxframe/tensor/datasource/array.py +3 -22
- maxframe/tensor/datasource/core.py +15 -10
- maxframe/tensor/datasource/diag.py +140 -0
- maxframe/tensor/datasource/diagflat.py +69 -0
- maxframe/tensor/datasource/empty.py +0 -2
- maxframe/tensor/datasource/eye.py +95 -0
- maxframe/tensor/datasource/from_dataframe.py +0 -2
- maxframe/tensor/datasource/from_dense.py +0 -17
- maxframe/tensor/datasource/from_sparse.py +0 -2
- maxframe/tensor/datasource/full.py +0 -2
- maxframe/tensor/datasource/identity.py +54 -0
- maxframe/tensor/datasource/indices.py +115 -0
- maxframe/tensor/datasource/linspace.py +140 -0
- maxframe/tensor/datasource/meshgrid.py +135 -0
- maxframe/tensor/datasource/ones.py +8 -3
- maxframe/tensor/datasource/tests/test_datasource.py +32 -1
- maxframe/tensor/datasource/tri_array.py +107 -0
- maxframe/tensor/datasource/zeros.py +7 -3
- maxframe/tensor/extensions/__init__.py +31 -0
- maxframe/tensor/extensions/accessor.py +25 -0
- maxframe/tensor/extensions/apply_chunk.py +137 -0
- maxframe/tensor/indexing/__init__.py +1 -1
- maxframe/tensor/indexing/choose.py +8 -6
- maxframe/tensor/indexing/compress.py +0 -2
- maxframe/tensor/indexing/extract.py +0 -2
- maxframe/tensor/indexing/fill_diagonal.py +9 -6
- maxframe/tensor/indexing/flatnonzero.py +1 -3
- maxframe/tensor/indexing/getitem.py +10 -43
- maxframe/tensor/indexing/nonzero.py +2 -4
- maxframe/tensor/indexing/setitem.py +19 -9
- maxframe/tensor/indexing/slice.py +6 -3
- maxframe/tensor/indexing/take.py +0 -2
- maxframe/tensor/indexing/tests/__init__.py +0 -2
- maxframe/tensor/indexing/tests/test_indexing.py +0 -2
- maxframe/tensor/indexing/unravel_index.py +6 -6
- maxframe/tensor/lib/__init__.py +16 -0
- maxframe/tensor/lib/index_tricks.py +404 -0
- maxframe/tensor/linalg/__init__.py +36 -0
- maxframe/tensor/linalg/dot.py +145 -0
- maxframe/tensor/linalg/inner.py +36 -0
- maxframe/tensor/linalg/inv.py +83 -0
- maxframe/tensor/linalg/lu.py +115 -0
- maxframe/tensor/linalg/matmul.py +225 -0
- maxframe/tensor/linalg/qr.py +124 -0
- maxframe/tensor/linalg/solve_triangular.py +103 -0
- maxframe/tensor/linalg/svd.py +167 -0
- maxframe/tensor/linalg/tensordot.py +213 -0
- maxframe/tensor/linalg/vdot.py +73 -0
- maxframe/tensor/merge/__init__.py +4 -0
- maxframe/tensor/merge/append.py +74 -0
- maxframe/tensor/merge/column_stack.py +63 -0
- maxframe/tensor/merge/concatenate.py +3 -2
- maxframe/tensor/merge/dstack.py +71 -0
- maxframe/tensor/merge/hstack.py +70 -0
- maxframe/tensor/merge/stack.py +0 -2
- maxframe/tensor/merge/tests/test_merge.py +0 -2
- maxframe/tensor/misc/__init__.py +18 -5
- maxframe/tensor/misc/astype.py +10 -8
- maxframe/tensor/misc/broadcast_to.py +1 -1
- maxframe/tensor/misc/copy.py +64 -0
- maxframe/tensor/misc/diff.py +115 -0
- maxframe/tensor/misc/flatten.py +63 -0
- maxframe/tensor/misc/in1d.py +94 -0
- maxframe/tensor/misc/isin.py +130 -0
- maxframe/tensor/misc/ndim.py +53 -0
- maxframe/tensor/misc/ravel.py +0 -2
- maxframe/tensor/misc/repeat.py +129 -0
- maxframe/tensor/misc/searchsorted.py +147 -0
- maxframe/tensor/misc/setdiff1d.py +58 -0
- maxframe/tensor/misc/squeeze.py +117 -0
- maxframe/tensor/misc/swapaxes.py +113 -0
- maxframe/tensor/misc/tests/test_misc.py +0 -2
- maxframe/tensor/misc/transpose.py +8 -4
- maxframe/tensor/misc/trapezoid.py +123 -0
- maxframe/tensor/misc/unique.py +0 -1
- maxframe/tensor/misc/where.py +10 -8
- maxframe/tensor/operators.py +0 -34
- maxframe/tensor/random/__init__.py +3 -5
- maxframe/tensor/random/binomial.py +0 -2
- maxframe/tensor/random/bytes.py +0 -2
- maxframe/tensor/random/chisquare.py +0 -2
- maxframe/tensor/random/choice.py +9 -8
- maxframe/tensor/random/core.py +20 -5
- maxframe/tensor/random/dirichlet.py +0 -2
- maxframe/tensor/random/exponential.py +0 -2
- maxframe/tensor/random/f.py +2 -4
- maxframe/tensor/random/gamma.py +0 -2
- maxframe/tensor/random/geometric.py +0 -2
- maxframe/tensor/random/gumbel.py +0 -2
- maxframe/tensor/random/hypergeometric.py +0 -2
- maxframe/tensor/random/laplace.py +2 -4
- maxframe/tensor/random/logistic.py +0 -2
- maxframe/tensor/random/lognormal.py +0 -2
- maxframe/tensor/random/logseries.py +0 -2
- maxframe/tensor/random/multinomial.py +0 -2
- maxframe/tensor/random/multivariate_normal.py +0 -2
- maxframe/tensor/random/negative_binomial.py +0 -2
- maxframe/tensor/random/noncentral_chisquare.py +0 -2
- maxframe/tensor/random/noncentral_f.py +1 -3
- maxframe/tensor/random/normal.py +0 -2
- maxframe/tensor/random/pareto.py +0 -2
- maxframe/tensor/random/permutation.py +6 -3
- maxframe/tensor/random/poisson.py +0 -2
- maxframe/tensor/random/power.py +0 -2
- maxframe/tensor/random/rand.py +0 -2
- maxframe/tensor/random/randint.py +0 -2
- maxframe/tensor/random/randn.py +0 -2
- maxframe/tensor/random/random_integers.py +0 -2
- maxframe/tensor/random/random_sample.py +0 -2
- maxframe/tensor/random/rayleigh.py +0 -2
- maxframe/tensor/random/standard_cauchy.py +0 -2
- maxframe/tensor/random/standard_exponential.py +0 -2
- maxframe/tensor/random/standard_gamma.py +0 -2
- maxframe/tensor/random/standard_normal.py +0 -2
- maxframe/tensor/random/standard_t.py +0 -2
- maxframe/tensor/random/tests/__init__.py +0 -2
- maxframe/tensor/random/tests/test_random.py +0 -2
- maxframe/tensor/random/triangular.py +0 -2
- maxframe/tensor/random/uniform.py +0 -2
- maxframe/tensor/random/vonmises.py +0 -2
- maxframe/tensor/random/wald.py +0 -2
- maxframe/tensor/random/weibull.py +0 -2
- maxframe/tensor/random/zipf.py +0 -2
- maxframe/tensor/reduction/__init__.py +0 -2
- maxframe/tensor/reduction/all.py +0 -2
- maxframe/tensor/reduction/allclose.py +0 -2
- maxframe/tensor/reduction/any.py +0 -2
- maxframe/tensor/reduction/argmax.py +1 -3
- maxframe/tensor/reduction/argmin.py +1 -3
- maxframe/tensor/reduction/array_equal.py +0 -2
- maxframe/tensor/reduction/core.py +0 -2
- maxframe/tensor/reduction/count_nonzero.py +0 -2
- maxframe/tensor/reduction/cumprod.py +0 -2
- maxframe/tensor/reduction/cumsum.py +0 -2
- maxframe/tensor/reduction/max.py +0 -2
- maxframe/tensor/reduction/mean.py +0 -2
- maxframe/tensor/reduction/min.py +0 -2
- maxframe/tensor/reduction/nanargmax.py +0 -2
- maxframe/tensor/reduction/nanargmin.py +0 -2
- maxframe/tensor/reduction/nancumprod.py +0 -2
- maxframe/tensor/reduction/nancumsum.py +0 -2
- maxframe/tensor/reduction/nanmax.py +0 -2
- maxframe/tensor/reduction/nanmean.py +0 -2
- maxframe/tensor/reduction/nanmin.py +0 -2
- maxframe/tensor/reduction/nanprod.py +0 -2
- maxframe/tensor/reduction/nanstd.py +0 -2
- maxframe/tensor/reduction/nansum.py +0 -2
- maxframe/tensor/reduction/nanvar.py +0 -2
- maxframe/tensor/reduction/prod.py +0 -2
- maxframe/tensor/reduction/std.py +0 -2
- maxframe/tensor/reduction/sum.py +0 -2
- maxframe/tensor/reduction/tests/test_reduction.py +1 -4
- maxframe/tensor/reduction/var.py +0 -2
- maxframe/tensor/reshape/__init__.py +0 -2
- maxframe/tensor/reshape/reshape.py +6 -5
- maxframe/tensor/reshape/tests/__init__.py +0 -2
- maxframe/tensor/reshape/tests/test_reshape.py +0 -2
- maxframe/tensor/sort/__init__.py +16 -0
- maxframe/tensor/sort/argsort.py +150 -0
- maxframe/tensor/sort/sort.py +295 -0
- maxframe/tensor/special/__init__.py +37 -0
- maxframe/tensor/special/core.py +38 -0
- maxframe/tensor/special/misc.py +142 -0
- maxframe/tensor/special/statistical.py +56 -0
- maxframe/tensor/statistics/__init__.py +5 -0
- maxframe/tensor/statistics/average.py +143 -0
- maxframe/tensor/statistics/bincount.py +133 -0
- maxframe/tensor/statistics/quantile.py +10 -8
- maxframe/tensor/ufunc/__init__.py +0 -2
- maxframe/tensor/ufunc/ufunc.py +0 -2
- maxframe/tensor/utils.py +21 -3
- maxframe/tests/test_protocol.py +3 -3
- maxframe/tests/test_utils.py +210 -1
- maxframe/tests/utils.py +67 -1
- maxframe/udf.py +76 -6
- maxframe/utils.py +418 -17
- {maxframe-1.3.0.dist-info → maxframe-2.0.0b1.dist-info}/METADATA +5 -1
- maxframe-2.0.0b1.dist-info/RECORD +939 -0
- maxframe_client/clients/framedriver.py +19 -3
- maxframe_client/fetcher.py +113 -6
- maxframe_client/session/odps.py +173 -38
- maxframe_client/session/task.py +3 -1
- maxframe_client/tests/test_session.py +41 -5
- maxframe-1.3.0.dist-info/RECORD +0 -705
- {maxframe-1.3.0.dist-info → maxframe-2.0.0b1.dist-info}/WHEEL +0 -0
- {maxframe-1.3.0.dist-info → maxframe-2.0.0b1.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,295 @@
|
|
|
1
|
+
# Copyright 1999-2025 Alibaba Group Holding Ltd.
|
|
2
|
+
#
|
|
3
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
4
|
+
# you may not use this file except in compliance with the License.
|
|
5
|
+
# You may obtain a copy of the License at
|
|
6
|
+
#
|
|
7
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
+
#
|
|
9
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
10
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
11
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
|
+
# See the License for the specific language governing permissions and
|
|
13
|
+
# limitations under the License.
|
|
14
|
+
|
|
15
|
+
import numpy as np
|
|
16
|
+
|
|
17
|
+
from ... import opcodes
|
|
18
|
+
from ...core import ExecutableTuple
|
|
19
|
+
from ...serialization.serializables import (
|
|
20
|
+
BoolField,
|
|
21
|
+
FieldTypes,
|
|
22
|
+
Int32Field,
|
|
23
|
+
ListField,
|
|
24
|
+
StringField,
|
|
25
|
+
)
|
|
26
|
+
from ..core import TensorOrder
|
|
27
|
+
from ..datasource import tensor as astensor
|
|
28
|
+
from ..operators import TensorOperator, TensorOperatorMixin
|
|
29
|
+
from ..utils import validate_axis, validate_order
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
class TensorSort(TensorOperator, TensorOperatorMixin):
|
|
33
|
+
_op_type_ = opcodes.SORT
|
|
34
|
+
|
|
35
|
+
axis = Int32Field("axis")
|
|
36
|
+
kind = StringField("kind")
|
|
37
|
+
parallel_kind = StringField("parallel_kind")
|
|
38
|
+
order = ListField("order", FieldTypes.string)
|
|
39
|
+
psrs_kinds = ListField("psrs_kinds", FieldTypes.string)
|
|
40
|
+
need_align = BoolField("need_align")
|
|
41
|
+
return_value = BoolField("return_value")
|
|
42
|
+
return_indices = BoolField("return_indices")
|
|
43
|
+
|
|
44
|
+
@property
|
|
45
|
+
def output_limit(self):
|
|
46
|
+
return int(bool(self.return_value)) + int(bool(self.return_indices))
|
|
47
|
+
|
|
48
|
+
def __call__(self, a):
|
|
49
|
+
kws = []
|
|
50
|
+
if self.return_value:
|
|
51
|
+
kws.append(
|
|
52
|
+
{"shape": a.shape, "order": a.order, "dtype": a.dtype, "type": "sorted"}
|
|
53
|
+
)
|
|
54
|
+
if self.return_indices:
|
|
55
|
+
kws.append(
|
|
56
|
+
{
|
|
57
|
+
"shape": a.shape,
|
|
58
|
+
"order": TensorOrder.C_ORDER,
|
|
59
|
+
"dtype": np.dtype(np.int64),
|
|
60
|
+
"type": "argsort",
|
|
61
|
+
}
|
|
62
|
+
)
|
|
63
|
+
ret = self.new_tensors([a], kws=kws)
|
|
64
|
+
if len(kws) == 1:
|
|
65
|
+
return ret[0]
|
|
66
|
+
return ExecutableTuple(ret)
|
|
67
|
+
|
|
68
|
+
|
|
69
|
+
_AVAILABLE_KINDS = {"QUICKSORT", "MERGESORT", "HEAPSORT", "STABLE"}
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
def _validate_sort_psrs_kinds(psrs_kinds):
|
|
73
|
+
if psrs_kinds is not None:
|
|
74
|
+
if isinstance(psrs_kinds, (list, tuple)):
|
|
75
|
+
psrs_kinds = list(psrs_kinds)
|
|
76
|
+
if len(psrs_kinds) != 3:
|
|
77
|
+
raise ValueError("psrs_kinds should have 3 elements")
|
|
78
|
+
for i, psrs_kind in enumerate(psrs_kinds):
|
|
79
|
+
if psrs_kind is None:
|
|
80
|
+
if i < 2:
|
|
81
|
+
continue
|
|
82
|
+
else:
|
|
83
|
+
raise ValueError(
|
|
84
|
+
"3rd element of psrs_kinds should be specified"
|
|
85
|
+
)
|
|
86
|
+
upper_psrs_kind = psrs_kind.upper()
|
|
87
|
+
if upper_psrs_kind not in _AVAILABLE_KINDS:
|
|
88
|
+
raise ValueError(
|
|
89
|
+
f"{psrs_kind} is an unrecognized kind in psrs_kinds"
|
|
90
|
+
)
|
|
91
|
+
else:
|
|
92
|
+
raise TypeError("psrs_kinds should be list or tuple")
|
|
93
|
+
else:
|
|
94
|
+
psrs_kinds = ["quicksort", "mergesort", "mergesort"]
|
|
95
|
+
return psrs_kinds
|
|
96
|
+
|
|
97
|
+
|
|
98
|
+
def _validate_sort_arguments(a, axis, kind, parallel_kind, psrs_kinds, order, stable):
|
|
99
|
+
a = astensor(a)
|
|
100
|
+
if axis is None:
|
|
101
|
+
a = a.flatten()
|
|
102
|
+
axis = 0
|
|
103
|
+
else:
|
|
104
|
+
axis = validate_axis(a.ndim, axis)
|
|
105
|
+
|
|
106
|
+
if stable is not None and kind is not None:
|
|
107
|
+
raise ValueError(
|
|
108
|
+
"`kind` and `stable` parameters can't be provided at the same time. "
|
|
109
|
+
"Use only one of them."
|
|
110
|
+
)
|
|
111
|
+
if stable:
|
|
112
|
+
kind = "stable"
|
|
113
|
+
|
|
114
|
+
if kind is not None:
|
|
115
|
+
raw_kind = kind
|
|
116
|
+
kind = kind.upper()
|
|
117
|
+
if kind not in _AVAILABLE_KINDS:
|
|
118
|
+
# check kind
|
|
119
|
+
raise ValueError(f"{raw_kind} is an unrecognized kind of sort")
|
|
120
|
+
if parallel_kind is not None:
|
|
121
|
+
raw_parallel_kind = parallel_kind
|
|
122
|
+
parallel_kind = parallel_kind.upper()
|
|
123
|
+
if parallel_kind not in {"PSRS"}:
|
|
124
|
+
raise ValueError(
|
|
125
|
+
f"{raw_parallel_kind} is an unrecognized kind of parallel sort"
|
|
126
|
+
)
|
|
127
|
+
|
|
128
|
+
order = validate_order(a.dtype, order)
|
|
129
|
+
psrs_kinds = _validate_sort_psrs_kinds(psrs_kinds)
|
|
130
|
+
return a, axis, kind, parallel_kind, psrs_kinds, order
|
|
131
|
+
|
|
132
|
+
|
|
133
|
+
def sort(
|
|
134
|
+
a,
|
|
135
|
+
axis=-1,
|
|
136
|
+
kind=None,
|
|
137
|
+
order=None,
|
|
138
|
+
*,
|
|
139
|
+
stable=None,
|
|
140
|
+
parallel_kind=None,
|
|
141
|
+
psrs_kinds=None,
|
|
142
|
+
return_index=False,
|
|
143
|
+
**kw,
|
|
144
|
+
):
|
|
145
|
+
r"""
|
|
146
|
+
Return a sorted copy of a tensor.
|
|
147
|
+
|
|
148
|
+
Parameters
|
|
149
|
+
----------
|
|
150
|
+
a : array_like
|
|
151
|
+
Tensor to be sorted.
|
|
152
|
+
axis : int or None, optional
|
|
153
|
+
Axis along which to sort. If None, the tensor is flattened before
|
|
154
|
+
sorting. The default is -1, which sorts along the last axis.
|
|
155
|
+
kind : {'quicksort', 'mergesort', 'heapsort', 'stable'}, optional
|
|
156
|
+
Sorting algorithm. The default is 'quicksort'. Note that both 'stable'
|
|
157
|
+
and 'mergesort' use timsort or radix sort under the covers and, in general,
|
|
158
|
+
the actual implementation will vary with data type. The 'mergesort' option
|
|
159
|
+
is retained for backwards compatibility.
|
|
160
|
+
Note that this argument would not take effect if `a` has more than
|
|
161
|
+
1 chunk on the sorting axis.
|
|
162
|
+
order : str or list of str, optional
|
|
163
|
+
When `a` is a tensor with fields defined, this argument specifies
|
|
164
|
+
which fields to compare first, second, etc. A single field can
|
|
165
|
+
be specified as a string, and not all fields need be specified,
|
|
166
|
+
but unspecified fields will still be used, in the order in which
|
|
167
|
+
they come up in the dtype, to break ties.
|
|
168
|
+
stable : bool, optional
|
|
169
|
+
Sort stability. If `True`, the returned array will maintain the relative
|
|
170
|
+
order of `a` values which compare as equal. If `False` or `None`, this
|
|
171
|
+
is not guaranteed. Internally, this option selects `kind='stable'`.
|
|
172
|
+
Default: `None`.
|
|
173
|
+
parallel_kind: {'PSRS'}, optional
|
|
174
|
+
Parallel sorting algorithm, for the details, refer to:
|
|
175
|
+
http://csweb.cs.wfu.edu/bigiron/LittleFE-PSRS/build/html/PSRSalgorithm.html
|
|
176
|
+
psrs_kinds: list with 3 elements, optional
|
|
177
|
+
Sorting algorithms during PSRS algorithm.
|
|
178
|
+
return_index: bool
|
|
179
|
+
Return indices as well if True.
|
|
180
|
+
|
|
181
|
+
Returns
|
|
182
|
+
-------
|
|
183
|
+
sorted_tensor : Tensor
|
|
184
|
+
Tensor of the same type and shape as `a`.
|
|
185
|
+
|
|
186
|
+
See Also
|
|
187
|
+
--------
|
|
188
|
+
Tensor.sort : Method to sort a tensor in-place.
|
|
189
|
+
argsort : Indirect sort.
|
|
190
|
+
lexsort : Indirect stable sort on multiple keys.
|
|
191
|
+
searchsorted : Find elements in a sorted tensor.
|
|
192
|
+
partition : Partial sort.
|
|
193
|
+
|
|
194
|
+
Notes
|
|
195
|
+
-----
|
|
196
|
+
The various sorting algorithms are characterized by their average speed,
|
|
197
|
+
worst case performance, work space size, and whether they are stable. A
|
|
198
|
+
stable sort keeps items with the same key in the same relative
|
|
199
|
+
order. The four algorithms implemented in NumPy have the following
|
|
200
|
+
properties:
|
|
201
|
+
|
|
202
|
+
=========== ======= ============= ============ ========
|
|
203
|
+
kind speed worst case work space stable
|
|
204
|
+
=========== ======= ============= ============ ========
|
|
205
|
+
'quicksort' 1 O(n^2) 0 no
|
|
206
|
+
'heapsort' 3 O(n*log(n)) 0 no
|
|
207
|
+
'mergesort' 2 O(n*log(n)) ~n/2 yes
|
|
208
|
+
'timsort' 2 O(n*log(n)) ~n/2 yes
|
|
209
|
+
=========== ======= ============= ============ ========
|
|
210
|
+
|
|
211
|
+
.. note:: The datatype determines which of 'mergesort' or 'timsort'
|
|
212
|
+
is actually used, even if 'mergesort' is specified. User selection
|
|
213
|
+
at a finer scale is not currently available.
|
|
214
|
+
|
|
215
|
+
All the sort algorithms make temporary copies of the data when
|
|
216
|
+
sorting along any but the last axis. Consequently, sorting along
|
|
217
|
+
the last axis is faster and uses less space than sorting along
|
|
218
|
+
any other axis.
|
|
219
|
+
|
|
220
|
+
The sort order for complex numbers is lexicographic. If both the real
|
|
221
|
+
and imaginary parts are non-nan then the order is determined by the
|
|
222
|
+
real parts except when they are equal, in which case the order is
|
|
223
|
+
determined by the imaginary parts.
|
|
224
|
+
|
|
225
|
+
quicksort has been changed to an introsort which will switch
|
|
226
|
+
heapsort when it does not make enough progress. This makes its
|
|
227
|
+
worst case O(n*log(n)).
|
|
228
|
+
|
|
229
|
+
'stable' automatically choses the best stable sorting algorithm
|
|
230
|
+
for the data type being sorted. It, along with 'mergesort' is
|
|
231
|
+
currently mapped to timsort or radix sort depending on the
|
|
232
|
+
data type. API forward compatibility currently limits the
|
|
233
|
+
ability to select the implementation and it is hardwired for the different
|
|
234
|
+
data types.
|
|
235
|
+
|
|
236
|
+
Timsort is added for better performance on already or nearly
|
|
237
|
+
sorted data. On random data timsort is almost identical to
|
|
238
|
+
mergesort. It is now used for stable sort while quicksort is still the
|
|
239
|
+
default sort if none is chosen. For details of timsort, refer to
|
|
240
|
+
`CPython listsort.txt <https://github.com/python/cpython/blob/3.7/Objects/listsort.txt>`_.
|
|
241
|
+
'mergesort' and 'stable' are mapped to radix sort for integer data types. Radix sort is an
|
|
242
|
+
O(n) sort instead of O(n log n).
|
|
243
|
+
|
|
244
|
+
Examples
|
|
245
|
+
--------
|
|
246
|
+
>>> import maxframe.tensor as mt
|
|
247
|
+
>>> a = mt.array([[1,4],[3,1]])
|
|
248
|
+
>>> mt.sort(a).execute() # sort along the last axis
|
|
249
|
+
array([[1, 4],
|
|
250
|
+
[1, 3]])
|
|
251
|
+
>>> mt.sort(a, axis=None).execute() # sort the flattened tensor
|
|
252
|
+
array([1, 1, 3, 4])
|
|
253
|
+
>>> mt.sort(a, axis=0).execute() # sort along the first axis
|
|
254
|
+
array([[1, 1],
|
|
255
|
+
[3, 4]])
|
|
256
|
+
|
|
257
|
+
Use the `order` keyword to specify a field to use when sorting a
|
|
258
|
+
structured array:
|
|
259
|
+
|
|
260
|
+
>>> dtype = [('name', 'S10'), ('height', float), ('age', int)]
|
|
261
|
+
>>> values = [('Arthur', 1.8, 41), ('Lancelot', 1.9, 38),
|
|
262
|
+
... ('Galahad', 1.7, 38)]
|
|
263
|
+
>>> a = mt.array(values, dtype=dtype) # create a structured tensor
|
|
264
|
+
>>> mt.sort(a, order='height').execute() # doctest: +SKIP
|
|
265
|
+
array([('Galahad', 1.7, 38), ('Arthur', 1.8, 41),
|
|
266
|
+
('Lancelot', 1.8999999999999999, 38)],
|
|
267
|
+
dtype=[('name', '|S10'), ('height', '<f8'), ('age', '<i4')])
|
|
268
|
+
|
|
269
|
+
Sort by age, then height if ages are equal:
|
|
270
|
+
|
|
271
|
+
>>> mt.sort(a, order=['age', 'height']).execute() # doctest: +SKIP
|
|
272
|
+
array([('Galahad', 1.7, 38), ('Lancelot', 1.8999999999999999, 38),
|
|
273
|
+
('Arthur', 1.8, 41)],
|
|
274
|
+
dtype=[('name', '|S10'), ('height', '<f8'), ('age', '<i4')])
|
|
275
|
+
"""
|
|
276
|
+
need_align = kw.pop("need_align", None)
|
|
277
|
+
if len(kw) > 0:
|
|
278
|
+
raise TypeError(f"sort() got an unexpected keyword argument '{next(iter(kw))}'")
|
|
279
|
+
|
|
280
|
+
a, axis, kind, parallel_kind, psrs_kinds, order = _validate_sort_arguments(
|
|
281
|
+
a, axis, kind, parallel_kind, psrs_kinds, order, stable
|
|
282
|
+
)
|
|
283
|
+
op = TensorSort(
|
|
284
|
+
axis=axis,
|
|
285
|
+
kind=kind,
|
|
286
|
+
parallel_kind=parallel_kind,
|
|
287
|
+
order=order,
|
|
288
|
+
psrs_kinds=psrs_kinds,
|
|
289
|
+
need_align=need_align,
|
|
290
|
+
return_value=True,
|
|
291
|
+
return_indices=return_index,
|
|
292
|
+
dtype=a.dtype,
|
|
293
|
+
gpu=a.op.gpu,
|
|
294
|
+
)
|
|
295
|
+
return op(a)
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
# Copyright 1999-2025 Alibaba Group Holding Ltd.
|
|
2
|
+
#
|
|
3
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
4
|
+
# you may not use this file except in compliance with the License.
|
|
5
|
+
# You may obtain a copy of the License at
|
|
6
|
+
#
|
|
7
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
+
#
|
|
9
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
10
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
11
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
|
+
# See the License for the specific language governing permissions and
|
|
13
|
+
# limitations under the License.
|
|
14
|
+
|
|
15
|
+
from .misc import softmax, softplus
|
|
16
|
+
from .statistical import (
|
|
17
|
+
TensorExpit,
|
|
18
|
+
TensorLogExpit,
|
|
19
|
+
TensorLogit,
|
|
20
|
+
expit,
|
|
21
|
+
log_expit,
|
|
22
|
+
logit,
|
|
23
|
+
)
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
def _clear_nones():
|
|
27
|
+
"""Remove unsupported functions"""
|
|
28
|
+
erase_key = []
|
|
29
|
+
for member, val in globals().items():
|
|
30
|
+
if val is None:
|
|
31
|
+
erase_key.append(member)
|
|
32
|
+
for key in erase_key:
|
|
33
|
+
globals().pop(key, None)
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
_clear_nones()
|
|
37
|
+
del _clear_nones
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
# Copyright 1999-2025 Alibaba Group Holding Ltd.
|
|
2
|
+
#
|
|
3
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
4
|
+
# you may not use this file except in compliance with the License.
|
|
5
|
+
# You may obtain a copy of the License at
|
|
6
|
+
#
|
|
7
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
+
#
|
|
9
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
10
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
11
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
|
+
# See the License for the specific language governing permissions and
|
|
13
|
+
# limitations under the License.
|
|
14
|
+
|
|
15
|
+
from ... import opcodes
|
|
16
|
+
from ..arithmetic.core import TensorUnaryOp
|
|
17
|
+
|
|
18
|
+
_func_name_to_special_cls = {}
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
def _register_special_op(cls):
|
|
22
|
+
if cls._func_name is not None:
|
|
23
|
+
_func_name_to_special_cls[cls._func_name] = cls
|
|
24
|
+
return cls
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
class TensorSpecialOperatorMixin:
|
|
28
|
+
_op_type_ = opcodes.SPECIAL
|
|
29
|
+
_func_name = None
|
|
30
|
+
|
|
31
|
+
def __new__(cls, *args, **kwargs):
|
|
32
|
+
if cls._func_name is not None:
|
|
33
|
+
return object.__new__(_func_name_to_special_cls[cls._func_name])
|
|
34
|
+
return super().__new__(cls, *args, **kwargs)
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
class TensorSpecialUnaryOp(TensorSpecialOperatorMixin, TensorUnaryOp):
|
|
38
|
+
pass
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
# Copyright 1999-2025 Alibaba Group Holding Ltd.
|
|
2
|
+
#
|
|
3
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
4
|
+
# you may not use this file except in compliance with the License.
|
|
5
|
+
# You may obtain a copy of the License at
|
|
6
|
+
#
|
|
7
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
+
#
|
|
9
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
10
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
11
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
|
+
# See the License for the specific language governing permissions and
|
|
13
|
+
# limitations under the License.
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
def softmax(x, axis=None):
|
|
17
|
+
r"""
|
|
18
|
+
Compute the softmax function.
|
|
19
|
+
The softmax function transforms each element of a collection by
|
|
20
|
+
computing the exponential of each element divided by the sum of the
|
|
21
|
+
exponentials of all the elements. That is, if `x` is a one-dimensional
|
|
22
|
+
numpy array::
|
|
23
|
+
|
|
24
|
+
softmax(x) = np.exp(x)/sum(np.exp(x))
|
|
25
|
+
|
|
26
|
+
Parameters
|
|
27
|
+
----------
|
|
28
|
+
x : array_like
|
|
29
|
+
Input array.
|
|
30
|
+
axis : int or tuple of ints, optional
|
|
31
|
+
Axis to compute values along. Default is None and softmax will be
|
|
32
|
+
computed over the entire array `x`.
|
|
33
|
+
|
|
34
|
+
Returns
|
|
35
|
+
-------
|
|
36
|
+
s : ndarray
|
|
37
|
+
An array the same shape as `x`. The result will sum to 1 along the
|
|
38
|
+
specified axis.
|
|
39
|
+
|
|
40
|
+
Notes
|
|
41
|
+
-----
|
|
42
|
+
The formula for the softmax function :math:`\sigma(x)` for a vector
|
|
43
|
+
:math:`x = \{x_0, x_1, ..., x_{n-1}\}` is
|
|
44
|
+
|
|
45
|
+
.. math:: \sigma(x)_j = \frac{e^{x_j}}{\sum_k e^{x_k}}
|
|
46
|
+
|
|
47
|
+
The `softmax` function is the gradient of `logsumexp`.
|
|
48
|
+
|
|
49
|
+
The implementation uses shifting to avoid overflow. See [1]_ for more
|
|
50
|
+
details.
|
|
51
|
+
|
|
52
|
+
References
|
|
53
|
+
----------
|
|
54
|
+
|
|
55
|
+
.. [1] P. Blanchard, D.J. Higham, N.J. Higham, "Accurately computing the
|
|
56
|
+
log-sum-exp and softmax functions", IMA Journal of Numerical Analysis,
|
|
57
|
+
Vol.41(4), :doi:`10.1093/imanum/draa038`.
|
|
58
|
+
|
|
59
|
+
Examples
|
|
60
|
+
--------
|
|
61
|
+
>>> import maxframe.tensor as mt
|
|
62
|
+
>>> from maxframe.tensor.special import softmax
|
|
63
|
+
|
|
64
|
+
>>> x = mt.array([[1, 0.5, 0.2, 3],
|
|
65
|
+
... [1, -1, 7, 3],
|
|
66
|
+
... [2, 12, 13, 3]])
|
|
67
|
+
...
|
|
68
|
+
|
|
69
|
+
Compute the softmax transformation over the entire array.
|
|
70
|
+
|
|
71
|
+
>>> m = softmax(x)
|
|
72
|
+
>>> m.to_numpy()
|
|
73
|
+
array([[ 4.48309e-06, 2.71913e-06, 2.01438e-06, 3.31258e-05],
|
|
74
|
+
[ 4.48309e-06, 6.06720e-07, 1.80861e-03, 3.31258e-05],
|
|
75
|
+
[ 1.21863e-05, 2.68421e-01, 7.29644e-01, 3.31258e-05]])
|
|
76
|
+
|
|
77
|
+
>>> m.sum().to_numpy()
|
|
78
|
+
1.0
|
|
79
|
+
|
|
80
|
+
Compute the softmax transformation along the first axis (i.e., the
|
|
81
|
+
columns).
|
|
82
|
+
|
|
83
|
+
>>> m = softmax(x, axis=0)
|
|
84
|
+
>>> m.to_numpy()
|
|
85
|
+
array([[ 2.11942e-01, 1.01300e-05, 2.75394e-06, 3.33333e-01],
|
|
86
|
+
[ 2.11942e-01, 2.26030e-06, 2.47262e-03, 3.33333e-01],
|
|
87
|
+
[ 5.76117e-01, 9.99988e-01, 9.97525e-01, 3.33333e-01]])
|
|
88
|
+
>>> m.sum(axis=0).to_numpy()
|
|
89
|
+
array([ 1., 1., 1., 1.])
|
|
90
|
+
|
|
91
|
+
Compute the softmax transformation along the second axis (i.e., the rows).
|
|
92
|
+
|
|
93
|
+
>>> m = softmax(x, axis=1)
|
|
94
|
+
>>> m.to_numpy()
|
|
95
|
+
array([[ 1.05877e-01, 6.42177e-02, 4.75736e-02, 7.82332e-01],
|
|
96
|
+
[ 2.42746e-03, 3.28521e-04, 9.79307e-01, 1.79366e-02],
|
|
97
|
+
[ 1.22094e-05, 2.68929e-01, 7.31025e-01, 3.31885e-05]])
|
|
98
|
+
>>> m.sum(axis=1).to_numpy()
|
|
99
|
+
array([ 1., 1., 1.])
|
|
100
|
+
"""
|
|
101
|
+
from ... import tensor as mt
|
|
102
|
+
|
|
103
|
+
x = mt.tensor(x)
|
|
104
|
+
x_max = mt.amax(x, axis=axis, keepdims=True)
|
|
105
|
+
exp_x_shifted = mt.exp(x - x_max)
|
|
106
|
+
return exp_x_shifted / mt.sum(exp_x_shifted, axis=axis, keepdims=True)
|
|
107
|
+
|
|
108
|
+
|
|
109
|
+
def softplus(x, **kwargs):
|
|
110
|
+
r"""
|
|
111
|
+
Compute the softplus function element-wise.
|
|
112
|
+
|
|
113
|
+
The softplus function is defined as: ``softplus(x) = log(1 + exp(x))``.
|
|
114
|
+
It is a smooth approximation of the rectifier function (ReLU).
|
|
115
|
+
|
|
116
|
+
Parameters
|
|
117
|
+
----------
|
|
118
|
+
x : array_like
|
|
119
|
+
Input value.
|
|
120
|
+
**kwargs
|
|
121
|
+
For other keyword-only arguments, see the
|
|
122
|
+
`ufunc docs <https://numpy.org/doc/stable/reference/ufuncs.html>`_.
|
|
123
|
+
|
|
124
|
+
Returns
|
|
125
|
+
-------
|
|
126
|
+
softplus : ndarray
|
|
127
|
+
Logarithm of ``exp(0) + exp(x)``.
|
|
128
|
+
|
|
129
|
+
Examples
|
|
130
|
+
--------
|
|
131
|
+
>>> from maxframe.tensor import special
|
|
132
|
+
|
|
133
|
+
>>> special.softplus(0).to_numpy()
|
|
134
|
+
0.6931471805599453
|
|
135
|
+
|
|
136
|
+
>>> special.softplus([-1, 0, 1]).to_numpy()
|
|
137
|
+
array([0.31326169, 0.69314718, 1.31326169])
|
|
138
|
+
"""
|
|
139
|
+
# use numpy implementation as softplus is introduced in scipy 1.15.
|
|
140
|
+
from ... import tensor as mt
|
|
141
|
+
|
|
142
|
+
return mt.logaddexp(0, x, **kwargs)
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
# Copyright 1999-2025 Alibaba Group Holding Ltd.
|
|
2
|
+
#
|
|
3
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
4
|
+
# you may not use this file except in compliance with the License.
|
|
5
|
+
# You may obtain a copy of the License at
|
|
6
|
+
#
|
|
7
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
+
#
|
|
9
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
10
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
11
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
|
+
# See the License for the specific language governing permissions and
|
|
13
|
+
# limitations under the License.
|
|
14
|
+
|
|
15
|
+
from ..arithmetic.utils import arithmetic_operator
|
|
16
|
+
from ..utils import implement_scipy, infer_scipy_dtype
|
|
17
|
+
from .core import TensorSpecialUnaryOp, _register_special_op
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
@_register_special_op
|
|
21
|
+
@arithmetic_operator(sparse_mode="always_false")
|
|
22
|
+
class TensorExpit(TensorSpecialUnaryOp):
|
|
23
|
+
_func_name = "expit"
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
@_register_special_op
|
|
27
|
+
@arithmetic_operator(sparse_mode="always_false")
|
|
28
|
+
class TensorLogit(TensorSpecialUnaryOp):
|
|
29
|
+
_func_name = "logit"
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
@_register_special_op
|
|
33
|
+
@arithmetic_operator(sparse_mode="always_false")
|
|
34
|
+
class TensorLogExpit(TensorSpecialUnaryOp):
|
|
35
|
+
_func_name = "log_expit"
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
@implement_scipy("scipy.special.expit")
|
|
39
|
+
@infer_scipy_dtype("scipy.special.expit")
|
|
40
|
+
def expit(x, **kwargs):
|
|
41
|
+
op = TensorExpit(**kwargs)
|
|
42
|
+
return op(x)
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
@implement_scipy("scipy.special.logit")
|
|
46
|
+
@infer_scipy_dtype("scipy.special.logit")
|
|
47
|
+
def logit(x, **kwargs):
|
|
48
|
+
op = TensorLogit(**kwargs)
|
|
49
|
+
return op(x)
|
|
50
|
+
|
|
51
|
+
|
|
52
|
+
@implement_scipy("scipy.special.log_expit")
|
|
53
|
+
@infer_scipy_dtype("scipy.special.log_expit")
|
|
54
|
+
def log_expit(x, **kwargs):
|
|
55
|
+
op = TensorLogExpit(**kwargs)
|
|
56
|
+
return op(x)
|
|
@@ -11,3 +11,8 @@
|
|
|
11
11
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
12
|
# See the License for the specific language governing permissions and
|
|
13
13
|
# limitations under the License.
|
|
14
|
+
|
|
15
|
+
from .average import average
|
|
16
|
+
from .bincount import bincount
|
|
17
|
+
from .percentile import percentile
|
|
18
|
+
from .quantile import quantile
|