
異常檢測原理與實驗
最近需要對欺詐報價進行識別處理,簡單的模型就是給定很多不同數據集,需要找出每個spu下可能存在的欺詐數據,比如{20,22,30},其中的欺詐數據可能就是30。其實加以抽象,屬于異常檢測范圍。
異常檢測是發現與大部分對象不同的對象,其中這些不同的對象稱為離群點。一般異常檢測的方法主要有數理統計法、數據挖掘方法。一般在預處理階段發生的異常檢測,更多的是依托數理統計的思想完成的。
一、基于模型
首先判斷出數據的分布模型,比如某種分布(高斯分布、泊松分布等等)。然后根據原始數據(包括正常點與離群點),算出分布的參數,從而可以代入分布方程求出概率。例如高斯分布,根據原始數據求出期望u和方差?,然后擬合出高斯分布函數,從而求出原始數據出現的概率;根據數理統計的思想,概率小的可以當做離群點。
優點:
方法簡單,無需訓練,可以用在小數據集上。
缺點:
發現離群點效果差,離群點對模型參數影響大,造成區分效果差。需要數值化
import java.util.List;
/**
* 實現描述:計算正態分布
*
* @author jin.xu
* @version v1.0.0
* @see
* @since 16-9-9 下午12:02
*/
public class Gauss {
public double getMean(List<Double> dataList) {
double sum = 0;
for (double data : dataList) {
sum += data;
}
double mean = sum;
if (dataList.size() > 0) {
mean = sum / dataList.size();
}
return mean;
}
public double getStd(List<Double> dataList, double mean) {
double sum = 0;
for (double data : dataList) {
sum += (data - mean) * (data - mean);
}
double std = sum;
if (dataList.size() > 0) {
std = sum / dataList.size();
}
return Math.sqrt(std);
}
public double getProbability(double data, double meam, double std) {
double tmp = (1.0 / (Math.sqrt(2 * 3.141592653) * std)) * Math.exp(-(Math.pow(data - meam, 2) / (2 * Math.pow(std, 2))));
return tmp;
}
}
二、基于近鄰度
需要度量對象之間的距離,離群點一般是距離大部分數據比較遠的點。一般這種方法是計算每個點與其距離最近的k個點的距離和,然后累加起來,這就是K近鄰方法。
優點:
原理簡單,無需訓練,可用在任何數據集
缺點:
需要計算距離,計算量大,K的選定以及多于K個離群點聚集在一起導致誤判。
public class KNN {
public static double process(int index,Position position, int k, List<Position> positionList) {
List<Double> distances = Lists.newArrayList();
for (int i = 0; i < positionList.size(); ++i) {
if (i != index) {
distances.add(Math.sqrt(Math.pow((positionList.get(i).getX() - position.getX()), 2)+Math.pow((positionList.get(i).getY()-position.getY()),2)));
}
}
Collections.sort(distances);
k = k < distances.size() ? k : distances.size();
double knnDistance = 0.0;
for (int i = 0; i < k; ++i) {
knnDistance += distances.get(i);
}
return knnDistance;
}
private static class Position{
int x;
int y;
public int getX() {
return x;
}
public void setX(int x) {
this.x = x;
}
public int getY() {
return y;
}
public void setY(int y) {
this.y = y;
}
}
}
三、基于密度
低密度區域的數據點可以當做某種程度上的離群點?;诿芏鹊暮突诮彽氖敲芮邢嚓P的,簡單來說,密度和近鄰的距離成反比。一般的度量公式如下:
density(x,k)表示包含x的k近鄰的密度,distance(x,y)表示x到y的距離,N(x,k)表示x的k近鄰集合。
優點:
相對準確
缺點:
需要度量密度,需要設定閾值
四、基于聚類
丟棄遠離其他聚類簇的小聚類簇。需要給出小聚類簇的大小閾值、聚類簇距離閾值。常用的聚類方法比較多,比如K-means(變種K-models)、EM、層次聚類算法(分裂型和歸約型)。具體方法說明可見:漫話數據挖掘。
優點:
缺點:
需要訓練,計算量大,原理相對復雜
需要建立適當的模型,需要充足的訓練樣本
總之異常檢測的通用方法大致有4種:基于模型、k近鄰、基于密度和基于聚類的。實際使用數據是線上的報價,由于每個SPU下報價有限,聚類不適合,所以用基于模型的和k近鄰的做了試驗;基于密度的和K近鄰差不多,而且需要密度范圍的距離閾值,就沒有選擇。此外,涉及的實驗數據是公司的,代碼是興趣使然,所以就不公布具體實驗數據。
數據分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
在本文中,我們將探討 AI 為何能夠加速數據分析、如何在每個步驟中實現數據分析自動化以及使用哪些工具。 數據分析中的AI是什么 ...
2025-05-20當數據遇見人生:我的第一個分析項目 記得三年前接手第一個數據分析項目時,我面對Excel里密密麻麻的銷售數據手足無措。那些跳動 ...
2025-05-20在數字化運營的時代,企業每天都在產生海量數據:用戶點擊行為、商品銷售記錄、廣告投放反饋…… 這些數據就像散落的拼圖,而相 ...
2025-05-19在當今數字化營銷時代,小紅書作為國內領先的社交電商平臺,其銷售數據蘊含著巨大的商業價值。通過對小紅書銷售數據的深入分析, ...
2025-05-16Excel作為最常用的數據分析工具,有沒有什么工具可以幫助我們快速地使用excel表格,只要輕松幾步甚至輸入幾項指令就能搞定呢? ...
2025-05-15數據,如同無形的燃料,驅動著現代社會的運轉。從全球互聯網用戶每天產生的2.5億TB數據,到制造業的傳感器、金融交易 ...
2025-05-15大數據是什么_數據分析師培訓 其實,現在的大數據指的并不僅僅是海量數據,更準確而言是對大數據分析的方法。傳統的數 ...
2025-05-14CDA持證人簡介: 萬木,CDA L1持證人,某電商中廠BI工程師 ,5年數據經驗1年BI內訓師,高級數據分析師,擁有豐富的行業經驗。 ...
2025-05-13CDA持證人簡介: 王明月 ,CDA 數據分析師二級持證人,2年數據產品工作經驗,管理學博士在讀。 學習入口:https://edu.cda.cn/g ...
2025-05-12CDA持證人簡介: 楊貞璽 ,CDA一級持證人,鄭州大學情報學碩士研究生,某上市公司數據分析師。 學習入口:https://edu.cda.cn/g ...
2025-05-09CDA持證人簡介 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度、美團、阿里等 ...
2025-05-07相信很多做數據分析的小伙伴,都接到過一些高階的數據分析需求,實現的過程需要用到一些數據獲取,數據清洗轉換,建模方法等,這 ...
2025-05-06以下的文章內容來源于劉靜老師的專欄,如果您想閱讀專欄《10大業務分析模型突破業務瓶頸》,點擊下方鏈接 https://edu.cda.cn/g ...
2025-04-30CDA持證人簡介: 邱立峰 CDA 數據分析師二級持證人,數字化轉型專家,數據治理專家,高級數據分析師,擁有豐富的行業經驗。 ...
2025-04-29CDA持證人簡介: 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度,美團,阿里等 ...
2025-04-28CDA持證人簡介: 居瑜 ,CDA一級持證人國企財務經理,13年財務管理運營經驗,在數據分析就業和實踐經驗方面有著豐富的積累和經 ...
2025-04-27數據分析在當今信息時代發揮著重要作用。單因素方差分析(One-Way ANOVA)是一種關鍵的統計方法,用于比較三個或更多獨立樣本組 ...
2025-04-25CDA持證人簡介: 居瑜 ,CDA一級持證人國企財務經理,13年財務管理運營經驗,在數據分析就業和實踐經驗方面有著豐富的積累和經 ...
2025-04-25在當今數字化時代,數據分析師的重要性與日俱增。但許多人在踏上這條職業道路時,往往充滿疑惑: 如何成為一名數據分析師?成為 ...
2025-04-24以下的文章內容來源于劉靜老師的專欄,如果您想閱讀專欄《劉靜:10大業務分析模型突破業務瓶頸》,點擊下方鏈接 https://edu.cda ...
2025-04-23