MannWhitneyUTest#

class frouros.detectors.data_drift.batch.statistical_test.MannWhitneyUTest(callbacks: BaseCallbackBatch | list[BaseCallbackBatch] | None = None)#

Mann–Whitney U test [mann1947test] detector.

Parameters:

callbacks (Optional[Union[BaseCallbackBatch, list[BaseCallbackBatch]]]) – callbacks, defaults to None

Note:

References:

[mann1947test]

Mann, Henry B., and Donald R. Whitney. “On a test of whether one of two random variables is stochastically larger than the other.” The annals of mathematical statistics (1947): 50-60.

Example:

>>> from frouros.detectors.data_drift import MannWhitneyUTest
>>> import numpy as np
>>> np.random.seed(seed=31)
>>> X = np.random.normal(loc=0, scale=1, size=100)
>>> Y = np.random.normal(loc=1, scale=1, size=100)
>>> detector = MannWhitneyUTest()
>>> _ = detector.fit(X=X)
>>> detector.compare(X=Y)[0]
StatisticalResult(statistic=2139.0, p_value=2.7623373527697943e-12)
property X_ref: ndarray | None#

Reference data property.

Returns:

reference data

Return type:

Optional[numpy.ndarray]

property callbacks: list[BaseCallback] | None#

Callbacks property.

Returns:

callbacks

Return type:

Optional[list[BaseCallback]]

compare(X: ndarray, **kwargs: Any) Tuple[ndarray, dict[str, Any]]#

Compare values.

Parameters:

X (numpy.ndarray) – test data

Returns:

compare result and callbacks logs

Return type:

Tuple[numpy.ndarray, dict[str, Any]]

property data_type: BaseDataType#

Data type property.

Returns:

data type

Return type:

BaseDataType

fit(X: ndarray, **kwargs: Any) dict[str, Any]#

Fit detector.

Parameters:
  • X (numpy.ndarray) – feature data

  • kwargs (Any) – additional fit parameters

Returns:

callbacks logs

Return type:

dict[str, Any]

reset() None#

Reset method.

property statistical_type: BaseStatisticalType#

Statistical type property.

Returns:

statistical type

Return type:

BaseStatisticalType