OneClassSVM¶
- class OneClassSVM(nu=0.5, kernel='rbf', degree=3, gamma='scale', coef0=0.0, tol=0.001, shrinking=True, cache_size=200, verbose=False, max_iter=-1, window_size: int = 10, stride: int = 1)[source]¶
用于异常检测的OneClassSVM。
该类实现了用于异常检测的OneClassSVM算法,该算法来自sklearn,用于aeon框架中。所有参数都传递给sklearn的
OneClassSVM,除了window_size和stride,这两个参数用于构建滑动窗口。参数的文档已从 (https://scikit-learn.org/dev/modules/generated/sklearn.svm.OneClassSVM.html)改编。 在这里,X指的是使用
aeon.utils.windowing.sliding_windows从时间序列中提取的滑动窗口集合, 参数为window_size和stride。内部的X具有形状 (n_windows, window_size * n_channels)。- Parameters:
- kernel{‘linear’, ‘poly’, ‘rbf’, ‘sigmoid’, ‘precomputed’} or callable, default=’rbf’
指定算法中要使用的核类型。 如果未给出,则将使用‘rbf’。如果给出了可调用对象,则它用于预计算核矩阵。
- degreeint, default=3
多项式核函数的次数('poly')。 必须为非负数。所有其他核函数忽略此参数。
- gamma{‘scale’, ‘auto’} or float, default=’scale’
用于‘rbf’、‘poly’和‘sigmoid’的核系数。
如果传递了
gamma='scale'(默认值),则使用 1 / (n_features * X.var()) 作为 gamma 的值,如果为‘auto’,则使用1 / n_features
如果是浮点数,必须是非负的。
在版本0.22中更改:
gamma的默认值从‘auto’更改为‘scale’。- coef0float, default=0.0
核函数中的独立项。 它仅在‘poly’和‘sigmoid’中显著。
- tolfloat, default=1e-3
停止准则的容忍度。
- nufloat, default=0.5
训练错误比例的上限和支持向量比例的下限。应在区间 (0, 1] 内。默认情况下将采用 0.5。
- shrinkingbool, default=True
是否使用收缩启发式方法。 参见 https://scikit-learn.org/dev/modules/svm.html#shrinking-svm。
- cache_sizefloat, default=200
指定内核缓存的大小(以MB为单位)。
- verbosebool, default=False
启用详细输出。请注意,此设置利用了libsvm中的每个进程运行时设置,如果启用,可能在多线程环境中无法正常工作。
- max_iterint, default=-1
求解器内的迭代次数硬限制,-1 表示无限制。
- window_sizeint, default=10
滑动窗口的大小。
- strideint, default=1
滑动窗口的步长。
方法
clone([random_state])获取具有相同超参数的对象的克隆。
fit(X[, y, axis])将时间序列异常检测器拟合到X。
fit_predict(X[, y, axis])拟合时间序列异常检测器并查找X的异常。
get_class_tag(tag_name[, raise_error, ...])从估计器类获取标签值(仅限类标签)。
从估计器类及其所有父类中获取类标签。
get_fitted_params([deep])获取拟合参数。
Sklearn 元数据路由。
get_params([deep])获取此估计器的参数。
get_tag(tag_name[, raise_error, ...])从估计器类中获取标签值。
get_tags()从估计器中获取标签。
predict(X[, axis])在X中查找异常。
reset([keep])将对象重置为初始化后的干净状态。
set_params(**params)设置此估计器的参数。
set_tags(**tag_dict)将动态标签设置为给定值。
注释
Capabilities ¶ 缺失值
无
多线程
否
单变量
是
多变量
是
- clone(random_state=None)[source]¶
获取具有相同超参数的对象克隆。
克隆是一个没有共享引用的不同对象,处于初始化后的状态。 这个函数等同于返回自身的
sklearn.clone。 在值上等同于type(self)(**self.get_params(deep=False))。- Parameters:
- random_stateint, RandomState instance, or None, default=None
设置克隆的随机状态。如果为None,则不设置随机状态。 如果为int,random_state是随机数生成器使用的种子。 如果为RandomState实例,random_state是随机数生成器。
- Returns:
- estimatorobject
type(self)的实例,self 的克隆(见上文)
- fit(X, y=None, axis=1)[source]¶
将时间序列异常检测器拟合到X。
如果标签
fit_is_empty为真,这只会将is_fitted标签设置为真。否则,它会检查self是否可以处理X,将X格式化为self所需的结构,然后将X(可能还有y)传递给_fit。- Parameters:
- Xone of aeon.base._base_series.VALID_SERIES_INPUT_TYPES
用于拟合模型的时间序列。 一个有效的aeon时间序列数据结构。有关aeon支持的类型,请参见 aeon.base._base_series.VALID_SERIES_INPUT_TYPES。
- yone of aeon.base._base_series.VALID_SERIES_INPUT_TYPES, default=None
时间序列的目标值。 一个有效的aeon时间序列数据结构。请参阅 aeon.base._base_series.VALID_SERIES_INPUT_TYPES以了解aeon支持的类型。
- axisint
输入序列的时间点轴,如果是2D的。如果
axis==0,则假设每列是一个时间序列,每行是一个时间点。即数据的形状为(n_timepoints, n_channels)。axis==1表示时间序列在行中,即数据的形状为(n_channels, n_timepoints)。
- Returns:
- BaseAnomalyDetector
拟合的估计器,引用自身。
- fit_predict(X, y=None, axis=1) ndarray[source]¶
拟合时间序列异常检测器并查找X的异常。
- Parameters:
- Xone of aeon.base._base_series.VALID_SERIES_INPUT_TYPES
用于拟合模型的时间序列。 一个有效的aeon时间序列数据结构。请参阅 aeon.base._base_series.VALID_INPUT_TYPES以了解aeon支持的类型。
- yone of aeon.base._base_series.VALID_SERIES_INPUT_TYPES, default=None
时间序列的目标值。 一个有效的aeon时间序列数据结构。请参阅 aeon.base._base_series.VALID_SERIES_INPUT_TYPES以了解aeon支持的类型。
- axisint, default=1
输入序列的时间点轴,如果是2D的。如果
axis==0,则假设每列是一个时间序列,每行是一个时间点。即数据的形状为(n_timepoints, n_channels)。axis==1表示时间序列在行中,即数据的形状为(n_channels, n_timepoints)。
- Returns:
- np.ndarray
一个布尔、整数或浮点数数组,长度为len(X),其中每个元素指示相应的子序列是否异常或其异常分数。
- classmethod get_class_tag(tag_name, raise_error=True, tag_value_default=None)[source]¶
从估计器类获取标签值(仅限类标签)。
- Parameters:
- tag_namestr
标签值的名称。
- raise_errorbool, default=True
当未找到标签时是否引发ValueError。
- tag_value_defaultany type, default=None
如果未找到标签且未引发错误,则使用默认/回退值。
- Returns:
- tag_value
cls中
tag_name标签的值。 如果未找到,当raise_error为True时返回错误,否则返回tag_value_default。
- Raises:
- ValueError
如果
raise_error为 True 并且tag_name不在self.get_tags().keys()中
示例
>>> from aeon.classification import DummyClassifier >>> DummyClassifier.get_class_tag("capability:multivariate") True
- classmethod get_class_tags()[source]¶
从估计器类及其所有父类获取类标签。
- Returns:
- collected_tagsdict
标签名称和标签值对的字典。 通过嵌套继承从
_tags类属性中收集。 这些不会被set_tags或类__init__调用设置的动态标签覆盖。
- get_fitted_params(deep=True)[source]¶
获取拟合参数。
- State required:
需要状态为“已拟合”。
- Parameters:
- deepbool, default=True
如果为True,将返回此估计器的拟合参数以及包含的作为估计器的子对象。
- Returns:
- fitted_paramsdict
拟合参数名称映射到它们的值。
- get_params(deep=True)[source]¶
获取此估计器的参数。
- Parameters:
- deepbool, default=True
如果为True,将返回此估计器及其包含的子对象的参数。
- Returns:
- paramsdict
参数名称映射到它们的值。
- get_tag(tag_name, raise_error=True, tag_value_default=None)[source]¶
从估计器类获取标签值。
包括动态和覆盖的标签。
- Parameters:
- tag_namestr
要检索的标签名称。
- raise_errorbool, default=True
当未找到标签时是否引发ValueError。
- tag_value_defaultany type, default=None
如果未找到标签且未引发错误,则使用默认/回退值。
- Returns:
- tag_value
自身中
tag_name标签的值。 如果未找到,当raise_error为True时返回错误,否则返回tag_value_default。
- Raises:
- ValueError
如果 raise_error 是
True并且tag_name不在self.get_tags().keys()中
示例
>>> from aeon.classification import DummyClassifier >>> d = DummyClassifier() >>> d.get_tag("capability:multivariate") True
- get_tags()[source]¶
从估计器中获取标签。
包括动态和覆盖的标签。
- Returns:
- collected_tagsdict
标签名称和标签值对的字典。 通过嵌套继承从
_tags类属性收集,然后从__init__或set_tags中收集任何被覆盖和新添加的标签。
- predict(X, axis=1) ndarray[source]¶
在X中查找异常。
- Parameters:
- Xone of aeon.base._base_series.VALID_SERIES_INPUT_TYPES
用于拟合模型的时间序列。 一个有效的aeon时间序列数据结构。有关aeon支持的类型,请参见 aeon.base._base_series.VALID_SERIES_INPUT_TYPES。
- axisint, default=1
输入序列的时间点轴,如果是2D的。如果
axis==0,则假设每列是一个时间序列,每行是一个时间点。即数据的形状为(n_timepoints, n_channels)。axis==1表示时间序列在行中,即数据的形状为(n_channels, n_timepoints)。
- Returns:
- np.ndarray
一个布尔、整数或浮点数数组,长度为len(X),其中每个元素指示相应的子序列是否异常或其异常分数。
- reset(keep=None)[source]¶
将对象重置为初始化后的干净状态。
在调用
self.reset()之后,self的值等于或类似于type(self)(**self.get_params(deep=False)),假设没有使用keep保留其他属性。- Detailed behaviour:
- removes any object attributes, except:
超参数(
__init__的参数) 包含双下划线的对象属性,即字符串“__”
使用当前超参数的值(
get_params的结果)运行__init__- Not affected by the reset are:
包含双下划线的对象属性 类和对象方法,类属性 在
keep参数中指定的任何属性
- Parameters:
- keepNone, str, or list of str, default=None
如果为None,则除了超参数外,所有属性都将被移除。 如果为str,则仅保留具有此名称的属性。 如果为str列表,则仅保留具有这些名称的属性。
- Returns:
- selfobject
自我引用。