python离群点检测_包会!手把手教你机器学习(零基础)之异常点检测

2023-11-07 13:40

本文主要是介绍python离群点检测_包会!手把手教你机器学习(零基础)之异常点检测,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Hello everyone ~ 我是GeoHey的周同学,近段时间呢我负责设计一个检测数据是否异常的模型,刚开始构思的时候还天真般的想用逻辑判断来实现,可是我后来发现不同的数据流有不同的特点,于是乎找到了一个比较好的解决方法,那就是Python机器学习框架 sklearn。

--5.png

http://scikit-learn.org/stable/

这篇 blog 只要你懂一点python语法,稍微认真一点,你就能看懂。

OK ! 言归正传,我将为大家介绍 OneClassSVM 异常检测模型的使用。OneClassSVM 基于无监督学习算法,用于新奇点检测,并将新数据分类。通俗的说(讲人话)就是说如果新来的数据不在正常范围之内就判定为异常数据。

我们来举个通俗易懂的例子。

假设周同学是在三里屯卖烧饼的,每个月正常收入在8000-9000元,每个月正常支出在3000-4000元,我们现在要设计一个模型,即收入或者支出不在其正常范围,我们就认为是异常。下面上代码 !(文末有整体代码,饥渴难耐的同学可以一口闷)有效代码还不到50行,不要畏惧,看到这里你已经成功90%了。

9000.png

首先导入需要使用的包。

import random

import numpy as np

from sklearn import svm

import matplotlib.pyplot as plt

import matplotlib.font_manager

random 是python自带的随机函数的库。

numpy 是python用于矩阵运算的库。

svm 是机器学习的类型。

matplotlib.pyplot 是作图用的。

matplotlib.font_manager用于管理图像的字体。

我们继续

xx, yy = np.meshgrid(np.linspace(0, 150, 150), np.linspace(0, 150, 150))

-----------------------分割线----------------------

这段代码用于之后的作图,和机器学习没有任何关系,它可以生成x,y都为150,内部均匀分布150*150个点的正方形栅格。

紧接着

n1 = [random.randint(80,90) for i in range(1000) ]

n2 = [random.randint(30,40) for i in range(1000) ]

l_train = list(zip(n1,n2))

X_train = np.array(l_train)

-----------------------分割线----------------------

(为了节省计算时间,我们默认单位为100元,即 80 为 8000 元收入)

n1 模拟生成 1000 次每月正常收入的python列表

n2 模拟生成 1000 次每月正常支出的python列表

l_train = list(zip(n1,n2))

将两列表压在一起,成为能显示每月 收入、支出 的列表,==比如:[(8200,3300), (8800,3200), ...... ] ==

随后

X_train = np.array(l_train)

将普通Python列表转化为用于矩阵运算的 Numpy array 所以 X_train 就是我们需要的训练数据。

同理,我们再生成一些测试数据:

n3 = [random.randint(70,90) for i in range(100) ]

n4 = [random.randint(30,50) for i in range(100) ]

l_test = list(zip(n3,n4))

X_test = np.array(l_test)

-----------------------分割线----------------------

随机生成100组数据,月收入在7000-1000,月支出在3500-5000

然后我们进行训练与测试

clf = svm.OneClassSVM(nu=0.05, kernel='rbf', gamma=0.01)

clf.fit(X_train)

y_pred_train = clf.predict(X_train)

y_pred_test = clf.predict(X_test)

n_error_train = y_pred_train[y_pred_train == -1].size

n_error_test = y_pred_test[y_pred_test == -1].size

-----------------------分割线----------------------

clf = svm.OneClassSVM(nu=0.05, kernel='rbf', gamma=0.01)

这行代码创建OneClassSVM模型对象,即clf,参数== nu == 为训练错误率,我们控制在 5% 左右, kernel 为该模型使用算法,'rbf'为默认算法。 gamma为rbf算法的一个系数,经实际反复使用推荐设置为0.01-0.001之间。

clf.fit(X_train)

``` 将训练数据填入进行训练。 这里我们创建的模型会以==X_train==为数据基础进行训练,推算出数据合理范围。如下图所示:

![](/content/images/2017/04/normal.png)

######进行预测

```python

y_pred_train = clf.predict(X_train)

y_pred_test = clf.predict(X_test)

分别对训练数据与测试数据进行预测

得出结果

n_error_train = y_pred_train[y_pred_train == -1].size

n_error_test = y_pred_test[y_pred_test == -1].size

这两行代码分别给出了 训练数据和测试数据异常的数量,其中==-1==表示数据异常。

打印结果

print('训练数据的错误量',n_error_train,'正确率{}%'.format((len(X_train)-n_error_train)*100/len(X_train)))

print('测试数据的错误量',n_error_test,'正确率{}%'.format((len(X_test)-n_error_test)*100/len(X_test)))

这两句print语句是方便查看预测结果,以下是我某次的运行结果:

-----1.png

其实到这里,机器学习的部分就已经结束啦,怎么样,是不是很简单,

你是不是感觉,还没开始就已经结束了?

从数据创建,模型创建,模型训练,数据预测才不到 20 行代码就完成了。难怪:

==Life is short, I use Python. ==

接下来是数据上图代码

各位伙伴如果不了解matplotlib可以去它的官网搜一下关键字

https://matplotlib.org/index.html 查询一下,其实都是一些图片属性设置。照着敲就可以了,我们主要是看看结果图。

--4.png

# 画图部分

Z = clf.decision_function(np.c_[xx.ravel(), yy.ravel()])

Z = Z.reshape(xx.shape)

# 设置图片标题

plt.title('Output / Input')

# 设置图标类型为Blues_r

plt.contourf(xx, yy, Z, levels=np.linspace(Z.min(), 0, 7), cmap=plt.cm.Blues_r)

# 设置边界线颜色为红色

a = plt.contour(xx, yy, Z, levels=[0], linewidths=2, colors='red')

# 设置有效区域颜色为橘黄色

plt.contourf(xx, yy, Z, levels=[0, Z.max()], colors='orange')

# 设置X轴Y轴表示内容, X为收入 Y为支出

b1 = plt.scatter(X_train[:, 0], X_train[:, 1], c='white')

b2 = plt.scatter(X_test[:, 0], X_test[:, 1], c='green')

plt.axis('tight')

# 设置坐标显示范围

plt.xlim((60, 120))

plt.ylim((0, 80))

# 设置图片属性说明(边界,训练点,测试点),以及显示在图片左上角

plt.legend([a.collections[0], b1, b2 ],

["normal boundary", "train income/consume ","test income/consume "

],

loc="upper left",

prop=matplotlib.font_manager.FontProperties(size=11))

# 设置x轴说明

plt.xlabel(

"error train: %d/1000 ; errors test: %d/100 ; "

% (n_error_train, n_error_test, ))

# 显示图片

plt.show()

print('程序执行完毕')

以下是不同参数下的测试结果:

修改测试参数:

n3 = [random.randint(80,100) for i in range(100) ]

n4 = [random.randint(30,40) for i in range(100) ]

只需要更改收入范围【上面的(80,100)】与支出范围【上面的(30,40)】即可。

正常范围同时满足 收入80-90 支出30-40。

x轴为收入,y轴为支出,单位 100元。

---------------------分割线---------------------

随机生成 收入范围:80-100 支出范围:30-40

111.png

222.png

---------------------分割线---------------------

随机生成 收入范围:70-100 支出范围:30-50

111-1.png

222-1.png

---------------------分割线---------------------

最后这组数据收入明显全部高于正常范围,同时也表达了作者对美好生活的向往。

随机生成 收入范围:150-170 支出范围:60-80

这里需要将前面的xx, yy 参数改为 (0, 200, 200)为了背景栅格能更大的显示

xx, yy = np.meshgrid(np.linspace(0, 200, 200), np.linspace(0, 200, 200))

plt.xlim((60, 120))

plt.ylim((0, 80))

表示x,y轴显示范围,把他们调大一点到

==plt.xlim(0,200) plt.ylim(0,200)==这样图片能正常显示

111-00-52-10.png

150.png

---------------------分割线---------------------

这次的内容就这些啦,sklearn还有许多即拿即用的机器学习包,有兴趣的伙伴可以去官网

http://scikit-learn.org/stable/ 学习更多的模型哦。

如有疑问可发邮件至 zhoudy@geohey.com

下次见,白白👋。

suo2.png

附(整体代码,可直接运行)

import random

import numpy as np

from sklearn import svm

import matplotlib.pyplot as plt

import matplotlib.font_manager

# 生成正方形栅格点,作图使用

xx, yy = np.meshgrid(np.linspace(0, 150, 150), np.linspace(0, 150, 150))

# 生成训练数据

n1 = [random.randint(80,90) for i in range(1000) ]

n2 = [random.randint(30,40) for i in range(1000) ]

l_train = list(zip(n1,n2))

X_train = np.array(l_train)

# 生成测试数据

n3 = [random.randint(80,100) for i in range(100) ]

n4 = [random.randint(30,40) for i in range(100) ]

l_test = list(zip(n3,n4))

X_test = np.array(l_test)

# 创建训练模型对象

clf = svm.OneClassSVM(nu=0.05, kernel='rbf', gamma=0.01)

# 训练数据

clf.fit(X_train)

# 预测训练数据

y_pred_train = clf.predict(X_train)

# 预测测试数据

y_pred_test = clf.predict(X_test)

# 输出错误数量

n_error_train = y_pred_train[y_pred_train == -1].size

n_error_test = y_pred_test[y_pred_test == -1].size

print('训练数据的错误量',n_error_train,'正确率{}%'.format((len(X_train)-n_error_train)*100/len(X_train)))

print('测试数据的错误量',n_error_test,'正确率{}%'.format((len(X_test)-n_error_test)*100/len(X_test)))

# 画图部分

Z = clf.decision_function(np.c_[xx.ravel(), yy.ravel()])

Z = Z.reshape(xx.shape)

# 设置图片标题

plt.title('Output / Input')

# 设置图标类型为Blues_r

plt.contourf(xx, yy, Z, levels=np.linspace(Z.min(), 0, 7), cmap=plt.cm.Blues_r)

# 设置边界线颜色为红色

a = plt.contour(xx, yy, Z, levels=[0], linewidths=2, colors='red')

# 设置有效区域颜色为橘黄色

plt.contourf(xx, yy, Z, levels=[0, Z.max()], colors='orange')

# 设置X轴Y轴表示内容, X为收入 Y为支出

b1 = plt.scatter(X_train[:, 0], X_train[:, 1], c='white')

b2 = plt.scatter(X_test[:, 0], X_test[:, 1], c='green')

plt.axis('tight')

# 设置坐标显示范围

plt.xlim((60, 120))

plt.ylim((0, 80))

# 设置图片属性说明(边界,训练点,测试点),以及显示在图片左上角

plt.legend([a.collections[0], b1, b2 ],

["normal boundary", "train income/consume ","test income/consume "

],

loc="upper left",

prop=matplotlib.font_manager.FontProperties(size=11))

# 设置x轴说明

plt.xlabel(

"error train: %d/1000 ; errors test: %d/100 ; "

% (n_error_train, n_error_test, ))

# 显示图片

plt.show()

print('程序执行完毕')

这篇关于python离群点检测_包会!手把手教你机器学习(零基础)之异常点检测的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/363986

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss