栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

选择亲和性(亲和性分析推荐图书)

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

选择亲和性(亲和性分析推荐图书)

文章目录

解析思路效果代码

解析

支持度:事件发生的总次数
置信度:一定条件下,事件发生的概率

思路

第一步:
导入数据,并交由变量X维护
创建特征数组
获取特征数量

第二步:
创建字典
valid_rules:(a,b):num_i的含义
表示买商品 a 之后,又买了商品 b 的消费者数量
invalid_rules:(a,b):num_i的含义
表示买商品 a 之后,没有买了商品 b 的消费者数量
nums_occurances:(a):num_i的含义
表示买商品 a 的消费者数量

第三步:
遍历 X 每 i 行
primise表示前提,conclusion表示结论
(X [i] [primise])=(1):表示消费者 i 买features[primise]
(X [i] [primise], X [i] [conclusion])=(1,0):表示消费者 i 买features[primise]之后, 没买了features[conclusion]
(X [i] [primise], X [i] [conclusion])=(1,1):表示消费者 i 买features[primise]之后, 还买了features[conclusion]
若(X [i] [primise])=(1),则nums_occurances(primise)+1
若(X [i] [primise], X [i] [conclusion])=(1,0),则invalid_rules(primise,conclusion)+1
若(X [i] [primise], X [i] [conclusion])=(1,1),则valid_rules(primise,conclusion)+1
遍历完成

第四步:
由valid_rules定义可得
支持度=valid_rules
置信度=(1, 1)发生的次数 / ((1, 1)发生的次数+(1, 0)发生的次数)

效果

代码
#库导入
import numpy as np
from collections import defaultdict

#导入数据
dataset_filename="D:/Python/Jupyter/Learning-Data-Mining-with-Python-master/Chapter 1/affinity_dataset.txt"
X=np.loadtxt(dataset_filename)
features=['bread','milk','cheese','apple','banana']
nums_feature=len(X[0])

#遍历数据
valid_rules=defaultdict(int)
invalid_rules=defaultdict(int)
nums_occurances=defaultdict(int)
for sample in X:
    for primise in range(nums_feature):
        if sample[primise]==0: continue
        nums_occurances[primise]+=1
        for conclusion in range(nums_feature):
            if conclusion==primise: continue
            if sample[conclusion]==1: valid_rules[(primise,conclusion)]+=1
            else: invalid_rules[(primise,conclusion)]+=1

#支持度
support=valid_rules
#置信度
confidence=defaultdict(float)
for primise,conclusion in valid_rules.keys():
    confidence[(primise,conclusion)]=valid_rules[(primise,conclusion)]/nums_occurances[primise]

#结果展示
for primise,conclusion in confidence.keys():
    print("Rule: If a people buys {0} they will also buy {1}".format(features[primise],features[conclusion]))
    print("- Support: {0}".format(confidence[(primise,conclusion)]))
    print("- Confidence: {0}".format(support[(primise,conclusion)]))
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/772541.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号