`

贝叶斯推断及其互联网应用:过滤垃圾邮件

阅读更多
引用一篇文章:
贝叶斯推断及其互联网应用

1、什么是贝叶斯过滤器?
垃圾邮件是一种令人头痛的顽症,困扰着所有的互联网用户。
正确识别垃圾邮件的技术难度非常大。传统的垃圾邮件过滤方法,主要有"关键词法"和"校验码法"等。前者的过滤依据是特定的词语;后者则是计算邮件文本的校验码,再与已知的垃圾邮件进行对比。它们的识别效果都不理想,而且很容易规避。
2002年,Paul Graham提出使用"贝叶斯推断"过滤垃圾邮件。他说,这样做的效果,好得不可思议。1000封垃圾邮件可以过滤掉995封,且没有一个误判。
另外,这种过滤器还具有自我学习的功能,会根据新收到的邮件,不断调整。收到的垃圾邮件越多,它的准确率就越高。

2、建立历史资料库
贝叶斯过滤器是一种统计学过滤器,建立在已有的统计结果之上。所以,我们必须预先提供两组已经识别好的邮件,一组是正常邮件,另一组是垃圾邮件。
我们用这两组邮件,对过滤器进行"训练"。这两组邮件的规模越大,训练效果就越好。Paul Graham使用的邮件规模,是正常邮件和垃圾邮件各4000封。
"训练"过程很简单。首先,解析所有邮件,提取每一个词。然后,计算每个词语在正常邮件和垃圾邮件中的出现频率。比如,我们假定"sex"这个词,在4000封垃圾邮件中,有200封包含这个词,那么它的出现频率就是5%;而在4000封正常邮件中,只有2封包含这个词,那么出现频率就是0.05%。(【注释】如果某个词只出现在垃圾邮件中,Paul Graham就假定,它在正常邮件的出现频率是1%,反之亦然。这样做是为了避免概率为0。随着邮件数量的增加,计算结果会自动调整。)
有了这个初步的统计结果,过滤器就可以投入使用了。

3、贝叶斯过滤器的使用过程
现在,我们收到了一封新邮件。在未经统计分析之前,我们假定它是垃圾邮件的概率为50%。(【注释】有研究表明,用户收到的电子邮件中,80%是垃圾邮件。但是,这里仍然假定垃圾邮件的"先验概率"为50%。)
我们用S表示垃圾邮件(spam),H表示正常邮件(healthy)。因此,P(S)和P(H)的先验概率,都是50%。



然后,对这封邮件进行解析,发现其中包含了sex这个词,请问这封邮件属于垃圾邮件的概率有多高?
我们用W表示"sex"这个词,那么问题就变成了如何计算P(S|W)的值,即在某个词语(W)已经存在的条件下,垃圾邮件(S)的概率有多大。
根据条件概率公式,马上可以写出



公式中,P(W|S)和P(W|H)的含义是,这个词语在垃圾邮件和正常邮件中,分别出现的概率。这两个值可以从历史资料库中得到,对sex这个词来说,上文假定它们分别等于5%和0.05%。另外,P(S)和P(H)的值,前面说过都等于50%。所以,马上可以计算P(S|W)的值:



因此,这封新邮件是垃圾邮件的概率等于99%。这说明,sex这个词的推断能力很强,将50%的"先验概率"一下子提高到了99%的"后验概率"。

4、联合概率的计算
做完上面一步,请问我们能否得出结论,这封新邮件就是垃圾邮件?
回答是不能。因为一封邮件包含很多词语,一些词语(比如sex)说这是垃圾邮件,另一些说这不是。你怎么知道以哪个词为准?
Paul Graham的做法是,选出这封信中P(S|W)最高的15个词,计算它们的联合概率。(【注释】如果有的词是第一次出现,无法计算P(S|W),Paul Graham就假定这个值等于0.4。因为垃圾邮件用的往往都是某些固定的词语,所以如果你从来没见过某个词,它多半是一个正常的词。)
所谓联合概率,就是指在多个事件发生的情况下,另一个事件发生概率有多大。比如,已知W1和W2是两个不同的词语,它们都出现在某封电子邮件之中,那么这封邮件是垃圾邮件的概率,就是联合概率。
在已知W1和W2的情况下,无非就是两种结果:垃圾邮件(事件E1)或正常邮件(事件E2)。



其中,W1、W2和垃圾邮件的概率分别如下:



如果假定所有事件都是独立事件(【注释】严格地说,这个假定不成立,但是这里可以忽略),那么就可以计算P(E1)和P(E2):






又由于在W1和W2已经发生的情况下,垃圾邮件的概率等于下面的式子:







将P(S)等于0.5代入,得到



将P(S|W1)记为P1,P(S|W2)记为P2,公式就变成





这就是联合概率的计算公式。如果你不是很理解,点击这里查看更多的解释。

5、最终的计算公式
将上面的公式扩展到15个词的情况,就得到了最终的概率计算公式:




一封邮件是不是垃圾邮件,就用这个式子进行计算。这时我们还需要一个用于比较的门槛值。Paul Graham的门槛值是0.9,概率大于0.9,表示15个词联合认定,这封邮件有90%以上的可能属于垃圾邮件;概率小于0.9,就表示是正常邮件。
有了这个公式以后,一封正常的信件即使出现sex这个词,也不会被认定为垃圾邮件了。


实现代码:
/**
 * 
 * 描述: 推断概率.
 * @author
 *
 */
public class InferProbability {
    private static final double HALF_RATE = 0.5;
    
    /**
     * 计算条件概率.
     * P(S|W) = P(W|S)P(S)/(P(W|S)P(S) + P(W|H)P(H))
     * @param sRate 带判断类别的概率
     * @param hRate 另一个类别的概率
     * @return 概率
     */
    public static double calculateConditionProbability(double sRate, double hRate) {
        return sRate * HALF_RATE / (sRate * HALF_RATE + hRate * HALF_RATE);
    }
    
    /**
     * 计算联合概率.
     * 标记 P(S|W1) 为 P1 , 以此类推
     * P = P1P2...P5/(P1P2...P5 + (1-P1)(1-P2)...(1-P5))
     * @param array 数据列表
     * @param maxCnt 取数据从大到小个数
     * @return 概率
     */
    public static double calculateUnionProbability(Double[] array, int maxCnt) {
        double divisor = 0;
        double dividend = 0;
        for (int i = array.length - 1; i >= 0; i--) {
            if ((maxCnt - 1) < 0) {
                break;
            }

            if (divisor == 0) {
                divisor = array[i];
            } else {
                divisor *= array[i];
            }

            if (dividend == 0) {
                dividend = 1 - array[i];
            } else {
                dividend *= 1 - array[i];
            }
        }
        dividend += divisor;

        if (0 == dividend) {
            return 0;
        }

        return divisor / dividend;
    }
}

测试方法:

    // 获取垃圾的概率
    public double calculate(String content, int maxCnt, double maxRate, String sclazz, String hclazz) throws IOException {
        List<String> splitContent = this.ikAnalyzerHandle.getResult(content); // 获取content的分词结果
        Set<Double> lastSet = new TreeSet<Double>();
        for (String tmp : splitContent) {
            double sRate = 0.002; // 获取垃圾的概率
            double hRate = 0.0006; // 获取健康的概率
            if (0 == sRate) {
                lastSet.add(UNKNOWN_RATE_DEF);
            } else {
                lastSet.add(InferProbability.calculateConditionProbability(sRate, hRate));
            }
        }

        // last
        double union = -1;
        if (lastSet.size() > 0) {
            union = InferProbability.calculateUnionProbability(lastSet.toArray(new Double[0]), maxCnt);
        }

        return union;
    }


  • 大小: 7.3 KB
  • 大小: 14.5 KB
  • 大小: 17.8 KB
  • 大小: 8.6 KB
  • 大小: 8.6 KB
  • 大小: 11.9 KB
  • 大小: 15.4 KB
  • 大小: 6.1 KB
  • 大小: 20.5 KB
  • 大小: 17.5 KB
  • 大小: 17.5 KB
  • 大小: 7.1 KB
  • 大小: 11 KB
分享到:
评论

相关推荐

    贝叶斯推断及其互联网应用.doc

    贝叶斯过滤器在互联网应用中,特别是在电子邮件过滤垃圾邮件方面,发挥了重要作用。垃圾邮件过滤器通过收集已知的垃圾邮件和非垃圾邮件,运用贝叶斯定理来计算新邮件是垃圾邮件的概率。每个单词被视为一个特征,过滤...

    YOLOv10实时端到端目标检测.zip

    python、yolo、pytorch

    网络安全是指通过技术、管理和法律手段保护网络系统、数据及用户隐私,防止未经授权的访问、攻击和信息泄露,确保可用性、完整性和机密性

    网络安全是通过技术手段、管理策略和法律规范,保护网络系统、数据及用户隐私免受未经授权的访问、攻击或泄露,确保网络服务的可用性、数据的完整性和机密性。其核心内容包括: 1. 技术防护:如防火墙、入侵检测系统(IDS)、加密通信、漏洞修复等。 2. 管理措施:包括安全策略制定、访问控制、安全审计、应急响应等。 3. 法律与合规:遵循《网络安全法》《数据安全法》等法规,保障用户隐私与国家安全。 4. 安全意识:提升用户对钓鱼攻击、密码安全等风险的防范能力。 # 适用人群 - 企业/组织:IT运维人员、安全管理员、开发工程师(需保障业务系统安全)。 - 普通用户:需防范个人信息泄露、网络诈骗等风险。 - 政府与公共部门:确保关键基础设施(如电力、金融、通信)的安全运行。 - 教育领域:学生及教师需了解基础安全知识以应对网络威胁。 # 适用场景及目标 1. 企业场景: - 目标:防御黑客攻击、数据泄露、勒索软件等,保障业务连续性。 - 措施:部署网络隔离、多因素认证、定期渗透测试。 2

    2025年DeepSeek引发广泛关注,大模型应用落地将加速.pdf

    人工智能、大语言模型相关学习资料

    基于C#的调用今日头条API并写入数据库 源码.zip

    需要将源码中的key换成正式的key方可使用

    图像处理_TF-Slim_卫星图像分类_训练模型_1741783746.zip

    图像处理项目实战

    jaxlib-0.4.18-cp312-cp312-win_amd64.whl

    该资源为jaxlib-0.4.18-cp312-cp312-win_amd64.whl,欢迎下载使用哦!

    物联网_Android_Things_车牌识别_HyperLPR4Android_边缘计算.zip

    车牌识别项目

    智慧停车_云计算_C_C_Linux_QT_OpenCV_E_1741774510.zip

    车牌识别项目

    生物医学_清测康居家心率体温检测设备_智能监测_1741166755.zip

    Arduino项目

    小微智慧园区数字化建设方案PPT(35页).pptx

    在当今数字化浪潮中,园区智慧化建设正成为推动区域经济发展和产业转型升级的关键力量。这份园区智慧化解决方案全面展示了如何通过集成大数据、云计算、物联网(IoT)、人工智能(AI)、地理信息系统(GIS)和建筑信息模型(BIM)等前沿技术,为传统产业园区插上数字的翅膀,打造“数字创新”产业园区。 数字技术赋能,重塑园区生态 传统产业园区往往面临运营效率低下、管理粗放、资源利用率不高等问题。而通过智慧化改造,园区可以实现从“清水房”到“精装房”的华丽蜕变。数字化技术不仅提升了园区的运营管理水平,降低了运营成本,还显著增强了园区的竞争力和吸引力。例如,通过构建园区数字模型(CIM),实现了多规数据融合,形成了园区规划“一张图”,为园区管理提供了直观、高效的可视化工具。此外,智能感知设施的应用,如环境监测、能耗监测等,让园区管理更加精细化、科学化。智慧能源管理系统通过实时监测和智能分析,帮助园区实现低碳绿色发展,而综合安防管控系统则通过AI+视频融合技术,为园区安全保驾护航。更有趣的是,这些技术的应用还让园区服务变得更加个性化和便捷,比如园区移动APP,让企业和员工可以随时随地享受园区服务,从会议室预定到智慧公寓管理,一切尽在“掌”握。 智慧运营中心,打造园区大脑 园区智慧化建设的核心在于构建智慧运营中心,这可以看作是园区的“数字大脑”。通过集成物联网服务平台、大数据分析平台、应用开发赋能平台等核心支撑平台,智慧运营中心实现了对园区内各类数据的实时采集、处理和分析。在这个“大脑”的指挥下,园区管理变得更加高效、协同。比如,建设工程项目智慧监管系统,通过基于二三维GIS底图的统一数字化监管,实现了对园区在建工程项目的进度控制、质量控制和安全控制的全方位监管。可视化招商系统则利用CIM模型,以多种方式为园区对外招商推介提供了数字化、在线化的展示窗口。而产业经济分析系统,则通过挖掘和分析产业数据,为园区产业发展提供了有力的决策支持。智慧运营中心的建设,不仅提升了园区的整体运营水平,还为园区的可持续发展奠定了坚实基础。 产业服务升级,激发创新活力 园区智慧化建设不仅关注基础设施和运营管理的升级,更重视产业服务的创新。通过整合平台资源、园区本地资源和外围资源,打造园区服务资源池,为园区内的企业和个人提供了全面的智慧管理、智慧工作和智慧生活服务。特别是工业互联网平台和工业云服务的建设,为园区内的企业提供了轻量化、智能化的生产服务。这些服务涵盖了车间信息化管理、云制造执行、云智能仓储、设备健康管理等多个方面,有效提升了企业的生产效率和竞争力。此外,通过产业经济分析系统,园区还能够对潜在客户进行挖掘、对经销商进行风控、对产品销量进行预测等,为企业的市场营销提供了有力支持。这些创新的产业服务,不仅激发了园区的创新活力,还为区域经济的转型升级注入了新的动力。总之,园区智慧化建设是一场深刻的变革,它正以前所未有的方式重塑着园区的生态、运营和服务模式,为园区的可持续发展开辟了广阔的前景。

    地理信息系统中4326与3857坐标系的特性及其应用场景解析

    内容概要:本文对比了EPSG:4326(WGS 84)坐标系和EPSG:3857(Web Mercator)坐标系的主要特征。4326是一种基于经度和纬度的地理坐标系统(GCS),它的坐标用度作为单位,在地理定位方面有较高准确性。相比之下,3857属于一种投影坐标系统(PCS), 该系统内的坐标用平面直角坐标的X/Y轴以米为单位进行测量,在线地图应用领域尤为普及,但是,在高维度的两极地区则会存在一定的失真。 适用人群:对地理信息系统(GIS)、地图制图以及空间数据有兴趣的技术人员和爱好者。 使用场景及目标:帮助读者明白这两种不同坐标系统的特性和优缺点,以便于正确选择适当的坐标系以满足各种空间数据分析和服务需求,比如创建精准的全球定位系统应用程序或者开发高质量的地图展示网站。 其他说明:理解这两者的区别对于确保地理位置数据准确转换及呈现至关重要。无论是从事地图制作还是相关软件的开发者都需要熟悉这两个坐标系的基础知识。

    这是一个yolo3keras的源码可以用于训练自己的模型.zip

    python、yolo、pytorch

    图像识别_PyTorch_宠物分类_网页应用_1741785391.zip

    图像处理项目实战

    识别车牌的一个小demo.zip

    车牌识别

    小程序 礼物说2.4.2 后台模块+前端小程序源码.zip

    源码介绍 更新动态: 版本号:2.4.2 – 礼物说 修复商品下架前端还显示的问题 版本号:2.4.1 – 礼物说 前端分类更新 版本号:2.3 – 礼物说 更改授权方式 版本号:2.2 – 礼物说 修复送给好友礼物,好友不显示的问题

    机器视觉—AI算法模型介绍.pdf

    人工智能、大语言模型相关学习资料

    OpenRAG:通过上下文检索学习端到端优化RAG

    随着大型语言模型(LLMs) (Zhao et al. 2023; Minaee et al. 2024) 的规模扩大,它们面临着数据瓶颈问题,高质量的互联网数据无法满足日益增长的训练需求。与此同时,下游数据量迅速增加,但由于其实时可用性 (Lei Wang et al. 2024; X.-Y. Liu, Wang, and Zha 2023) 、隐私问题 (Arora et al. 2023) 、许可限制 (Min et al. 2024) 和伦理问题 (Serouis and Sèdes 2024; Ayyamperumal and Ge 2024) ,这些数据通常无法用于预训练。 检索增强生成(RAG) (Lewis et al. 2020; Guu et al. 2020; Gao et al. 2023) 成为解决这一挑战的有希望的方法。RAG 不仅依赖精心整理的互联网数据,还利用信息检索(IR)从外部来源获取相关数据,并将其作为上下文以提高生成质量。这在 RAG 中非常有价值,因为它可以使用快速扩展但通常无法访问的下游数据,这些数据比经过大量处理和严

    基于springboot oracle java-swing 的 职工考勤管理信息系统

    oracle 基于springboot oracle java-swing 的 职工考勤管理信息系统

Global site tag (gtag.js) - Google Analytics