社交网络分析4(下):社交网络链路预测分析、LightGBM框架、LLSLP方法(LightGBM 堆叠链路预测)、堆叠泛化 、社交网络链路预测分析的挑战

社交网络分析4

  • 写在最前面
  • LightGBM
    • LightGBM简介
      • GBDT的核心概念和应用
      • LightGBM的特点
      • LightGBM与GBDT的比较
    • LightGBM的原理与技术
      • GBDT的传统算法
      • LightGBM的创新算法
    • GOSS(Gradient-based One-Side Sampling)算法解析
      • 概念和工作原理
      • 算法的逻辑基础
      • GOSS算法的创新与优势
    • Exclusive Feature Bundling (EFB) 算法概述
      • EFB的工作原理
      • EFB算法的执行过程
    • 梯度提升决策树算法的高效实现
      • 并行化计算
      • 高效内存使用
      • 灵活性和高效训练
      • 特征和分布式计算
    • LightGBM的实践与应用指南
      • 安装与配置
      • 数据处理与训练
      • 参数调整与集成
      • LightGBM与其他模型的比较
        • 1. 训练速度
        • 2. 内存占用
        • 3. 特征选择
        • 4. 树剪枝
        • 5. 速度和扩展性
        • 6. 灵活性
    • LightGBM的未来发展与趋势
      • 技术创新和优化
      • 应用拓展
      • 性能提升
      • 可扩展性和多样化优化
      • 前景与影响力
    • 总结与展望
      • 当前优势
      • 未来应用场景
      • 模型优化建议
    • 堆叠泛化(Stacked Generalization)
      • 集成学习概述
      • 集成方法的种类
      • Stacking与Bagging和Boosting的差异
      • Stacking的实现
      • 建立Stacking模型的步骤
      • 数据集分割的考量
      • k-交叉验证的细节
      • Stacking的优势
    • 堆叠泛化的步骤
  • LLSLP方法
    • 方法概述
    • 实施步骤
      • 1. 划分节点对
      • 2. 构建训练集与测试集
    • 3. 处理类别不平衡问题
      • 类别不平衡问题的定义
      • 类别不平衡带来的问题
      • 逻辑回归中的代价敏感学习
    • 4. 链路预测算法流程
      • 训练集与测试集的准备
      • 第一学习层
      • 特征合并与第二学习层
      • 最终预测
    • 链路预测模型构建
      • 基模型的选择
      • Stacking方法的应用
      • 防止过拟合的策略
    • LLSLP方法框架
    • LLSLP实验结果与分析
      • 数据集
      • 链路预测模型评估
  • 社交网络链路预测分析的挑战
    • 数据稀疏性问题
    • 模型泛化能力问题
    • 计算复杂性问题
    • 实时预测问题
    • 社交网络链路预测分析的未来发展趋势
    • 社交网络链路预测分析的实际应用
  • 问题
    • 1. 链路预测的目标是什么?它有哪些具体的应用,结合一个具体示例进行说明。
    • 2. 链路预测方法主要分为几类?简要地进行说明。
    • 3. 逻辑斯蒂回归中引入 Logit 变换的主要目的是什么?
    • 4. 简述逻辑斯蒂回归 LightGBM 堆叠链路预测(LLSLP)方法的主要步骤。
    • 5. LightGBM 采用哪些方法解决数据量大和特征维度较高的问题的?结合示例简要进行说明。
    • 6. 在 LLSLP 方法中引入正则化的主要目的是什么?
    • 7. 什么是堆叠(或层叠)泛化?在 LLSLP 方法中主要作用是什么?

写在最前面

《社交网络分析》课程由鲁宏伟老师授课,其教学方式不仅严谨负责,还充满幽默与个人见解。这个方向对我而言也尤其有吸引力,怀着极大的兴趣选修了这门课程。

四、社交网络链路预测方法
主要结合三个PPT:社交网络链路预测分析、LightGBM框架、Logistic回归模型概述
本章简要介绍社交网络隐私攻击和保护的基本概念和方法


在这里插入图片描述

在这个由连接驱动的数字时代,社交网络不仅仅是连接人与人的桥梁,它们还蕴含着深刻的社会、经济和技术洞见。从Facebook到LinkedIn,社交网络的每一个点击、每一条信息流,都构成了一个复杂且动态的网络结构。但是,这些看似简单的连接背后隐藏着什么秘密?如何预测未来可能形成的社交联系,从而揭示隐藏在数据背后的深层次模式和趋势?这就是社交网络链路预测分析的魅力所在。

在这篇博客中,我们将深入探讨社交网络链路预测分析的核心,解析它的基本概念、重要性以及各种现代方法。我们将介绍从基于网络结构的传统方法到利用深度学习和人工智能的先进技术,如何在社交网络的海洋中捕捉那些看不见的线索。

我们不仅仅停留在理论层面,还将深入探讨实际应用,包括:

  • 链路预测的目标和具体应用场景。
  • 各类链路预测方法的分类和原理。
  • 逻辑斯蒂回归在链路预测中的独特作用。
  • 创新的逻辑斯蒂回归 LightGBM 堆叠链路预测(LLSLP)方法及其步骤。
  • LightGBM在处理大数据和高维特征时的策略。
  • 正则化在LLSLP方法中的关键作用。
  • 层叠泛化在LLSLP方法中的重要性及其应用。

社交网络链路预测不仅面临数据稀疏性、模型泛化能力、计算复杂性等挑战,还需要不断适应快速变化的网络环境和实时数据更新的要求。本博客将为您提供一个全面的视角,探索社交网络链路预测分析的现状、挑战和未来发展趋势。

准备好深入这个领域了吗?让我们开始这段探索之旅!

LightGBM

LightGBM简介

LightGBM(Light Gradient Boosting Machine)是一种创新的集成学习框架,旨在优化传统梯度提升决策树(GBDT)的性能和速度,现已成为机器学习领域的核心工具之一。

GBDT的核心概念和应用

  • GBDT简介:Gradient Boosting Decision Tree (GBDT) 是机器学习中的一个经典模型,它通过迭代地训练多个弱分类器(决策树)来构建强大的预测模型。
  • GBDT的优势:GBDT在实际应用中表现出色,特别是在点击率预测、搜索排序等领域,以其良好的训练效果和抗过拟合能力著称。
  • 竞赛中的GBDT:GBDT在数据挖掘竞赛中广泛应用,如Kaggle,其中多数获胜方案都基于GBDT模型。

LightGBM的特点

  • 训练速度:相比传统GBDT,LightGBM提供了更快的训练速度。
  • 内存效率:更低的内存消耗使其适用于处理大规模数据。
  • 准确性:LightGBM能够提供更高的准确率。
  • 分布式计算:支持分布式处理,可以有效应对海量数据。

LightGBM与GBDT的比较

  • 训练数据处理:相较于GBDT在每次迭代时需要遍历整个训练数据,LightGBM使用高效的算法降低了这种依赖,解决了大数据集上的训练问题。
  • 面对海量数据的优势:LightGBM针对处理大规模数据的问题进行了特别优化,使其能够快速且有效地应用于工业级数据。

LightGBM的原理与技术

GBDT的传统算法

传统的GBDT工具,如XGBoost,主要基于预排序的决策树算法。这种方法的步骤包括:

  1. 预排序:对所有特征按数值进行排序。
  2. 遍历分割点:以O(#data)的代价在每个特征上找到最佳分割点。
  3. 数据分裂:根据找到的分割点,将数据分裂成左右子节点。

优点:能精确找到分割点。

缺点

  • 空间消耗:需要保存特征值及其排序结果,导致数据量增加至两倍。
  • 时间开销:每次遍历分割点时需计算分裂增益,代价较大。

LightGBM的创新算法

LightGBM通过以下技术优化解决了GBDT的传统问题:

  1. 单边采样:通过基于梯度的单边采样算法(GOSS)减少样本维度。
  2. 特征捆绑:采用互斥特征捆绑算法(EFB)减少特征维度。
  3. 直方图优化:使用直方图算法(Histogram)加速计算过程。

直方图算法详解

  • 特征离散化:将连续的浮点特征值离散化成k个整数(即分桶,如[0,0.1)→0, [0.1,0.3)→1)。
  • 构建直方图:为离散特征构造宽度为k的直方图。
  • 累积统计量:在数据遍历过程中,根据离散值在直方图中累积统计量。
  • 寻找最优分割点:遍历直方图的离散值,寻找最优分割点。

GOSS(Gradient-based One-Side Sampling)算法解析

概念和工作原理

GOSS,即基于梯度的单边采样,是一种高效的数据采样方法。它的核心思想是根据样本的梯度大小来进行采样,具体操作如下:

  • 样本分类:将样本根据梯度大小降序排列,区分为梯度大的样本和梯度小的样本。
  • 样本保留与采样:直接保留一定比例的梯度大样本,对梯度小样本进行随机采样。例如,在1000万样本中,保留梯度最大的10%(100万),再从剩余的900万样本中随机挑选20%(200万)进行训练。
  • 优化目的:通过减少样本量(从1000万减至300万)加快训练速度。

算法的逻辑基础

  • 梯度与误差关系:样本梯度小意味着训练误差小,这些样本训练得较好,可以考虑在性能优化时舍弃部分。
  • 采样而非丢弃:直接丢弃梯度小的样本会改变样本分布,影响模型准确度。通过采样并调整采样样本的梯度权重,尽量恢复样本分布。

GOSS算法的创新与优势

  • 创新点:GOSS算法独特之处在于它仅对梯度绝对值小的样本进行采样,同时完整保留梯度大的样本。
  • 平衡性能与精度:由于模型的性能增益主要来自梯度较大的样本,GOSS算法在提高计算性能的同时保持了较高的计算精度。

Exclusive Feature Bundling (EFB) 算法概述

Exclusive Feature Bundling (EFB)是LightGBM中的一个创新算法,旨在有效减少用于构建直方图的特征数量,从而降低计算复杂度,特别适用于特征中包含大量稀疏特征的场景。

EFB的工作原理

  • 稀疏特征互斥性:在许多应用场景中,大部分稀疏特征的样本值为0,只有少数非0。这些特征通常是互斥的,即它们不会同时取非零值。
  • 特征捆绑:利用稀疏特征的互斥性,EFB算法通过重新编码某些特征的取值,将多个互斥特征捆绑成一个新的特征。
  • 适用于类别特征:对类别特征,LightGBM可以将每个类别取值与一个bin关联,实现自动处理而无需转换为onehot编码。

EFB算法的执行过程

  • 特征合并示例:考虑一个包含6个样本和5个特征的数据集,其中前3个特征是稀疏的,后2个是稠密的。目标是将这三个稀疏特征合并为一个新特征(Bundle)。
  • 降维实现:对于只有一个非零元素的稀疏特征行,保留非零元素并忽略零元素,实现3→1的降维。但这种合并方式会丢失一些信息,因为无法还原原始特征。
  • 元素所属特征的确定:通过数据分布范围内涵的方式表示合并后元素所属的原特征。例如,如果三个特征的分布范围为1~10,则通过错开分布范围来进行合并。
  • 处理冲突:在合并过程中,可能出现一个样本在多个特征上有非零值的情况(冲突)。LightGBM通过适当容忍冲突来平衡特征合并的效果与信息损失。

梯度提升决策树算法的高效实现

梯度提升决策树(Gradient Boosting Decision Tree, GBDT)算法是一种强大的机器学习技术,特别适用于处理大规模数据集。以下是该算法的几个关键优势:

并行化计算

  • 多线程加速:GBDT利用多线程技术加速数据的预处理过程,显著提升计算效率。
  • 并行处理:通过并行化处理技术,GBDT加速了整个训练过程,特别在大数据集上表现出色。

高效内存使用

  • 优化内存管理:GBDT采用高效的内存管理策略,使其能够处理大规模数据集,同时保持较低的内存占用。

灵活性和高效训练

  • 多语言支持:GBDT支持多种编程语言,易于集成到不同的应用和系统中。
  • 自适应学习率:采用自适应学习率算法,动态调整每个样本的学习速率,进一步提高模型训练的速度和精度。

特征和分布式计算

  • 特征重要性分析:GBDT可以根据特征在模型中的贡献度进行排序,筛选出重要特征进行训练,从而减少计算量。
  • 分布式计算支持:支持分布式计算,能够将数据划分为多个子集,分配到不同的计算节点上进行处理,进一步提高训练速度。

LightGBM的实践与应用指南

安装与配置

  • 安装步骤:下载源代码,编译安装,使用pip安装。
  • 配置步骤:设置环境变量,配置数据集路径,修改配置文件。
  • 常见安装问题:缺少依赖库,安装失败,安装后无法运行。
  • 常见配置问题:环境变量设置错误,数据集路径不正确,配置文件格式错误。

数据处理与训练

  • 数据加载方式:支持多种数据格式,包括CSV、Excel、JSON等。
  • 数据划分:将数据集划分为训练集、验证集和测试集,用于模型性能评估。
  • 数据预处理:包括数据清洗、转换和特征工程等,以优化模型训练。
  • 数据特征:选择与业务和问题相关的特征,提升模型精度和泛化能力。
  • 训练过程:基于决策树算法,采用梯度提升框架进行训练。
  • 并行化训练:支持高效的分布式训练,包括多线程和多进程模式。
  • 特征选择:自动选择重要特征,减少过拟合,增强模型泛化能力。
  • 评估指标:使用准确率、精确率、召回率等指标评估模型性能。

参数调整与集成

  • 参数调整:尝试不同的参数组合,如学习率、树的数量、最大深度等,以优化模型性能。
  • 特征选择策略:利用特征重要性评估(例如,计算每个特征的贡献度)来选择最重要的特征,减少过拟合。
  • 正则化应用:使用L1或L2正则化来控制模型复杂性,防止过拟合。
  • 集成方法:结合其他机器学习算法,如决策树、随机森林等,以增强模型的性能。

LightGBM与其他模型的比较

1. 训练速度
  • LightGBM:在所有模型中,LightGBM提供了最快的训练速度。
  • XGBoost:相比于LightGBM,XGBoost的训练速度稍慢。
2. 内存占用
  • LightGBM:相对其他模型,LightGBM在内存占用上最为高效,尤其适合处理大规模数据集。
  • XGBoost:XGBoost的内存占用比LightGBM稍高。
3. 特征选择
  • LightGBM:具备自动特征选择的功能,减少了模型设计的复杂性。
4. 树剪枝
  • LightGBM:采用自适应树剪枝技术,无需手动设置,提高了模型优化的效率。
  • XGBoost:在XGBoost中,树的剪枝需要手动设置,增加了模型调优的复杂性。
5. 速度和扩展性
  • LightGBM:在速度上占优势,能够快速训练和预测。同时,其良好的扩展性使其能够处理高维数据和多类别数据。
6. 灵活性
  • LightGBM:在算法设计和参数调整方面相对更灵活,能够适应多样化的数据处理需求。

LightGBM的未来发展与趋势

LightGBM作为一种先进的机器学习算法,在未来的发展中展现出多方面的潜力和趋势:

技术创新和优化

  • 数据类型支持:预期将支持更多数据类型,增强算法的适用性和灵活性。
  • 算法优化:持续优化算法,如并行计算和优化算法,以提高训练和预测的效率。

应用拓展

  • 应用领域的扩展:探索LightGBM在自然语言处理、推荐系统等更广泛领域的应用。
  • 集成选项:提供更灵活的集成选项,如与其他深度学习模型或预训练模型的集成。

性能提升

  • 高效性:继续保持高效的训练速度和预测速度,特别是在处理大规模数据集时。
  • 内存管理:通过高效的内存管理机制,减少内存占用,增强大规模数据集处理的稳定性。
  • 分布式计算:支持分布式计算,进一步提高训练和预测的速度。

可扩展性和多样化优化

  • 可扩展性:增强机器学习模型的可扩展性和速度。
  • 多样化的优化方法:采用多种优化方法,如直方图算法、树算法等,优化模型训练和预测过程。

前景与影响力

  • 广泛应用前景:在自然语言处理、图像处理、推荐系统等各种应用领域中具有广泛的应用前景。
  • 工业界和学术界的影响力:LightGBM在工业界和学术界的影响力及发展前景值得关注。

总结与展望

当前优势

  • 高效快速:LightGBM在速度方面具有显著优势,能够高效地进行模型训练和预测。
  • 内存占用少:与其他梯度提升框架相比,LightGBM的内存占用更少,适用于处理大规模数据集。
  • 灵活可扩展:支持多种语言和平台,并具有高度的可扩展性,方便用户进行定制和扩展。
  • 强大的可视化工具:提供了强大的可视化工具,帮助用户更好地理解和评估模型性能。

未来应用场景

  • 应用领域的拓展:预计将在自然语言处理、图像识别、语音识别等领域有更广泛的应用。
  • 技术持续进步:持续改进算法,提高性能和准确性,同时推出新功能和特性以适应市场需求。
  • 社区支持与贡献:作为开源项目,将依赖于社区的支持和贡献来不断发展和壮大。
  • 行业应用增加:已在金融、医疗、零售、能源等行业得到应用,未来将扩展到更多领域。

模型优化建议

  • 考虑数据集特点:根据不同数据集的特点选择合适的模型和参数,以提高模型的泛化能力和预测精度。
  • 特征选择:选择与目标变量密切相关的特征,以提高模型的预测能力。
  • 调整超参数:通过调整学习率、最大深度等超参数,优化模型性能。
  • 集成方法:将LightGBM与其他机器学习算法结合使用,以获得更好的预测效果。

堆叠泛化(Stacked Generalization)

堆叠泛化是一种高级的集成学习技术,它结合了多个不同的机器学习模型以提高预测准确性。

集成学习概述

集成学习是一种机器学习范式,它训练多个模型(通常称为“弱学习器”)来解决相同问题,并将它们结合以获得更好的结果。关键假设是,通过正确组合弱模型,可以得到一个更精确或更具鲁棒性的“强学习器”。

集成方法的种类

集成方法通常采用以下三种主要方式来组合弱学习器:

  1. Bagging:考虑同质弱学习器,它们独立并行学习,并通过平均过程组合。
  2. Boosting:也使用同质弱学习器,但以一种高度自适应的方法顺序学习,并通过确定性策略组合。
  3. Stacking(层叠泛化):考虑异质弱学习器,它们并行学习,并通过训练元模型组合,基于不同弱模型的预测结果输出最终预测。

Stacking与Bagging和Boosting的差异

  • 异质与同质弱学习器:Stacking通常使用不同的学习算法组合,而Bagging和Boosting主要使用相同类型的弱学习器。
  • 元模型与确定性算法:Stacking使用元模型组合基础模型,而Bagging和Boosting使用确定性算法组合弱学习器。

Stacking的实现

Stacking的概念是学习多个不同的弱学习器,并通过一个元模型来组合它们。元模型基于弱模型返回的多个预测结果来输出最终预测。

建立Stacking模型的步骤

为了构建Stacking模型,需要执行以下步骤:

  1. 定义学习器和元模型:选择L个学习器(如KNN、逻辑斯蒂回归、SVM等)作为弱学习器,并选择一个强学习器(如神经网络)作为元模型。
  2. 分割训练数据:将训练数据分为两组。
  3. 训练弱学习器:使用第一组数据训练L个弱学习器。
  4. 预测和训练元模型:使每个弱学习器对第二组数据进行预测,并在第二组数据上训练元模型,使用弱学习器的预测结果作为输入。

数据集分割的考量

  • 一分为二的问题:将数据集一分为二的主要问题是,只有一半的数据用于训练基础模型,而另一半用于训练元模型。
  • 解决方法:k-交叉验证:为了克服这个限制,可以采用k-交叉验证方法,确保所有观测数据都用于训练元模型。这种方法涉及将数据分为k组,并交替使用其中的一组作为测试集,其余作为训练集。这样,每个数据点都被用于预测和训练。

k-交叉验证的细节

  • k的选择:k通常大于等于2,实际操作中一般从3开始。当数据量较小时,可能会选择2。作为经验规则,k=10通常被认为是足够的。
  • 性能指标:使用k个模型的验证集分类准确率的平均值作为性能指标。

Stacking的优势

  • 模型多样性:Stacking通过训练多个不同的弱学习器,可以有效利用每种模型的优势。
  • 元模型训练:元模型基于不同弱学习器的输出进行训练,提供了一种机制来综合这些预测,从而提高整体模型的性能。

堆叠泛化的步骤

如图显示了层叠泛化的步骤。

  • 它会在 k - 1组数据上进行训练,从而对剩下的 1 组数据进行预测。迭代地重复这个过程,就可以得到对任何 1 组观测数据的预测结果。这样可以为数据集中的每个观测数据生成相关的预测,然后使用所有这些预测结果训练元模型。
  • Stacking 方法会训练一个元模型,该模型根据较低层的弱学习器返回的输出结果生成最后的输出。
    在这里插入图片描述

LLSLP方法

LLSLP(Logistic-regression LightGBM Stacking Link Prediction)方法是一种用于社交网络链路预测的方法,将问题视为二分类问题,并考虑节点间的多个相似性指标。

方法概述

  1. 定义问题:将社交网络的链路预测视为一个二分类问题,考虑每两个节点间的15个相似性指标:CN、Sal、Jac、Sor、HPI、HDI、LHN-I、PA、A、RA、LP、Katz、ACT、Cos和RWR。
  2. 特征集定义:这些相似性指标被视为网络中任何两个节点间的特征。
  3. 模型选择与堆叠:选择逻辑斯蒂回归和LightGBM作为基本模型,并引入Stacking思想,对基础模型的预测结果进行重学习,以获得更好的预测结果。

实施步骤

1. 划分节点对

  • 考虑一个具有n个节点的社交网络,总共有 n ( n − 1 ) / 2 n(n-1)/2 n(n1)/2个节点对。
  • 构造网络中所有节点对的数据集 D D D,包括特征集 F F F和类别集 C C C
  • 采用分层抽样的方法,按照8:2的比例将所有节点对划分为原始训练集和原始测试集。

2. 构建训练集与测试集

  • 在原始训练集和原始测试集中,分别计算节点对的15个相似性指数。
  • 这些相似性指数作为节点间的15个不同特征。
  • 在原始网络中,若节点对连接,则归为类别1(正样本),否则归为类别0(负样本)。
  • 最后,将特征集与类别集组合,得到训练集和测试集。

3. 处理类别不平衡问题

类别不平衡问题的定义

  • 类别不平衡:当一个分类任务的数据集中不同类别的样本数量相差悬殊时,通常称这种数据集为“类别不平衡”的。
  • 在网络链路预测中的表现:网络中的链接通常是稀疏的,具有连接边缘的节点对数量远少于没有连接边缘的节点对。在链路预测中,通常更关注有连接边缘的节点对,即少数类。

类别不平衡带来的问题

  • 过拟合问题:机器学习中对于不平衡样本的学习容易导致过拟合,降低模型泛化能力,并使预测变得无意义。
  • 代价敏感学习策略:为了不改变原始数据分布,可以使用代价敏感学习(Cost-sensitive Learning)策略。该策略给少数类样本分配较高的误分类代价,而给多数类样本分配较小的误分类代价。

逻辑回归中的代价敏感学习

  • 目标函数:逻辑回归的目标函数的极大似然函数为:
    J ( w ) = − ∑ i = 1 n [ y i log ⁡ ( h ( x i ) ) + ( 1 − y i ) log ⁡ ( 1 − h ( x i ) ) ] J(w) = -\sum_{i=1}^{n} [y_i \log(h(x_i)) + (1 - y_i) \log(1 - h(x_i))] J(w)=i=1n[yilog(h(xi))+(1yi)log(1h(xi))]

    其中, h ( x ) h(x) h(x)是逻辑函数, y i y_i yi x i x_i xi分别是样本的标签和特征。

  • 引入样本权重:在代价敏感的情况下,引入正、负样本权重 [ α , β ] [ \alpha, \beta ] [α,β],目标函数变为:
    J ( w ) = − ∑ i = 1 n [ α y i log ⁡ ( h ( x i ) ) + β ( 1 − y i ) log ⁡ ( 1 − h ( x i ) ) ] J(w) = -\sum_{i=1}^{n} [\alpha y_i \log(h(x_i)) + \beta (1 - y_i) \log(1 - h(x_i))] J(w)=i=1n[αyilog(h(xi))+β(1yi)log(1h(xi))]

    这样,通过调整 α \alpha α β \beta β 的值,可以增加少数类样本的重要性,从而减轻分类器对多数类的偏好。

4. 链路预测算法流程

训练集与测试集的准备

  • 在解决数据类别不平衡问题后,将训练集和测试集分别输入到学习流程中。

第一学习层

  • 基学习器的选择:选择两个基学习器,逻辑斯蒂回归(LR)和LightGBM。
  • 超参数优化:使用交叉验证、网格搜索和提前终止的方法确定模型的超参数。
  • 特征融合:基学习器对15个传统相似性指标进行融合,得到两个融合特征。

特征合并与第二学习层

  • 特征合并:将基学习器学到的融合特征合并,形成新的训练集与测试集。
  • 第二学习层:包含一个元分类器,选择LR模型。在这一层也使用交叉验证、网格搜索和提前终止的方法确定模型超参数。

最终预测

  • 模型训练与预测:使用元分类器训练得到的模型对新测试集进行预测,得到最终预测结果 F i n a l P r e d i c t i o n L a b e l FinalPredictionLabel FinalPredictionLabel
  • 结果比较:将预测结果与数据集的真实标签进行比较,以评估模型性能。

链路预测模型构建

基模型的选择

  • 模型差异性:为了提高预测准确性和泛化性,选择差异较大的模型作为基模型。逻辑斯蒂回归(计算模型)和LightGBM(树模型)的集成将提供更好的性能。
  • 训练与超参数优化:使用逻辑斯蒂回归和LightGBM作为两个基模型对训练集进行训练。采用5折交叉验证、网格搜索和提前终止的方法确定基模型的超参数。

Stacking方法的应用

  • 特征的重新利用:在基模型训练完成后,引入Stacking方法集成两个基模型。将逻辑斯蒂回归和LightGBM预测的链接存在与不存在的概率作为特征输入到Stacking模型中。

防止过拟合的策略

  • 特征选择:由于Stacking的有效性主要来源于特征抽取,第二层的特征应来源于第一层数据的学习,避免包含原始特征,以降低过拟合风险。
  • 简单的第二层分类器:由于第一层已经进行了复杂的非线性变换,第二层分类器应选择简单的模型,如逻辑斯蒂回归。这不仅可以配合L1正则化选取有效特征、防止过拟合,还可以将输出结果解释为概率,适合部分分类任务。

LLSLP方法框架

在这里插入图片描述

LLSLP实验结果与分析

数据集

  • 多领域的真实网络:实验使用了10个来自不同领域的真实网络数据集,覆盖电力网络(UPG)、生物网络(YST)、共同作者网络(KNH、SMG、NSC、GRQ)、社交网络(HMT、FBK、ADV)和电子邮件网络(EML)。
  • 网络特性:这些网络被精心选择,以涵盖不同的大小、平均度、聚类系数、异质性指数和不平衡系数。不平衡系数(Imbalance Ratio, IR)是连接边与非连接边的比值。
  • 实验网络结构特性:表4.1中列出了实验所用网络的结构特性。

表中列出了实验所用网络的结构特性。
在这里插入图片描述

链路预测模型评估

  • 评估标准:由于网络节点在现有链路和不存在链路的比例上不平衡,链路预测的评估不能仅依赖于单个预测的正确比例。
  • 性能指标:使用AUC、Recall等7个指标来评估模型性能,包括常用的分类问题评估指标AUC、Recall和Precision。
  • 额外指标:对于样本类别不平衡的数据,额外使用混淆矩阵、Precision-Recall Curve、F1-score和马修斯相关系数(MC)。MC值在-1与+1之间,被认为是即使在类别不平衡的情况下也适用的平衡度量。
  • 综合评估:Precision-Recall Curve和F1-score综合反映了Precision和Recall之间的关系,因此在评估LLSLP时考虑了这4个额外指标。

社交网络链路预测分析的挑战

数据稀疏性问题

  • 定义:在社交网络中,大部分用户之间缺乏直接的连接关系,造成数据稀疏。
  • 影响因素:用户活跃度、社交网络规模和用户关系类型等因素影响数据稀疏性。
  • 预测难度:数据稀疏性增加了链路预测的难度,要求更有效的算法和模型提升预测精度。
  • 解决方案:采用基于矩阵分解、图神经网络、深度学习等方法的链路预测算法。

模型泛化能力问题

  • 挑战:提升模型的泛化能力,使其在多样化和动态变化的社交网络环境中保持高预测准确性。

计算复杂性问题

  • 社交网络规模:庞大的社交网络带来巨大的数据量和高计算复杂度。
  • 社交网络结构:复杂的社交关系增加预测难度。
  • 社交网络动态性:不断变化的社交网络要求预测模型能够及时更新。
  • 数据质量问题:社交网络数据质量参差不齐,影响预测准确性。

实时预测问题

  • 模型复杂度:需要处理大量数据,计算复杂度高。
  • 预测准确性:受数据质量和模型选择影响。
  • 数据更新:社交网络数据实时更新,需要模型不断适应新数据。
  • 实时性要求:快速响应的需求对计算速度和模型性能提出高要求。

社交网络链路预测分析的未来发展趋势

  • 融合多种预测方法:结合不同的预测技术以提高准确性和鲁棒性。
  • 考虑动态社交网络:研究适应社交网络动态变化的预测方法。

社交网络链路预测分析的实际应用

  • 推荐系统:根据用户在社交网络中的关系预测用户可能感兴趣的内容或商品。
  • 社交网络分析:分析社交网络中的关系结构和动态。
  • 网络安全:预测和防范恶意行为,保护社交网络安全。
  • 社会影响分析:分析社交网络中的信息传播和影响,预测社会事件的发展趋势。

问题

四、社交网络链路预测方法

1. 链路预测的目标是什么?它有哪些具体的应用,结合一个具体示例进行说明。

链路预测的主要目标是在社交网络中预测未来可能发生的联系。这种分析主要用于增强社交网络的推荐效果和提高预测准确性。链路预测在多个领域有着广泛应用,例如:

  1. 社交网络:通过预测用户之间的社交关系来提高推荐系统的准确率。例如,可以预测哪些用户可能成为朋友,帮助社交平台更好地推荐好友或内容。

  2. 生物信息学:在生物信息学中,链路预测可以用来预测蛋白质之间的相互作用,从而提高药物研发的效率。例如,通过分析蛋白质网络,可以预测哪些蛋白质可能会互相作用,这对于理解疾病机理和开发新药具有重要意义。

  3. 交通网络:在交通网络中,链路预测可以用于预测交通流量,以优化交通规划。例如,通过分析道路网络,可以预测在特定时间和地点的交通流量,从而帮助城市规划者优化交通布局,减少拥堵。

  4. 通信网络:在通信网络领域,链路预测可以用于预测网络拓扑结构,从而提高网络的性能和可靠性。例如,可以预测网络中哪些节点可能会形成新的连接,这有助于网络运营商优化网络结构,提高数据传输的效率和稳定性。

这些应用展示了链路预测在不同领域的重要性和多样性,强调了它在理解和优化复杂网络结构中的关键作用。

2. 链路预测方法主要分为几类?简要地进行说明。

链路预测方法主要分为以下几类:

  1. 基于相似性的方法:这类方法通过计算网络中节点之间的相似性来预测链路。例如,共有邻居、Jaccard系数等。

  2. 基于路径的方法:这些方法考虑网络中的路径信息来预测链路。例如,Katz指数和随机游走。

  3. 基于网络拓扑的方法:这类方法使用网络整体的拓扑结构来预测链路。例如,层次结构方法。

  4. 基于机器学习的方法:利用机器学习算法,如决策树、支持向量机(SVM)、神经网络等,来从数据中学习并预测链路。

每种方法有其独特的优势和局限性,通常会根据特定应用场景和网络特性选择适当的方法。

3. 逻辑斯蒂回归中引入 Logit 变换的主要目的是什么?

逻辑斯蒂回归中引入Logit变换的主要目的是为了将线性回归模型转换成适用于分类问题的模型。在逻辑斯蒂回归模型中,响应变量是二元的(例如,是/否,成功/失败),而传统的线性回归模型输出的是连续值,不适合直接用于分类。

Logit变换通过使用逻辑函数(或sigmoid函数)将线性回归模型的输出映射到(0,1)区间。这样,模型的输出可以解释为属于某类的概率。例如,逻辑斯蒂回归模型可以预测一个事件发生的概率,如一个人点击广告的概率。这种变换使得模型能够处理分类问题,特别是二分类问题,同时保持数学上的处理简便性和模型的可解释性。

4. 简述逻辑斯蒂回归 LightGBM 堆叠链路预测(LLSLP)方法的主要步骤。

逻辑斯蒂回归与LightGBM堆叠链路预测(LLSLP)方法的主要步骤如下:

  1. 模型构建

    • 选择逻辑斯蒂回归和LightGBM作为基模型,因为它们分别是计算模型和树模型,差异较大,能提高准确性和泛化性。
    • 对训练集进行训练,使用5折交叉验证、网格搜索和提前终止的方法确定基模型的超参数。
    • 引入Stacking方法集成逻辑斯蒂回归和LightGBM,将这两个模型预测的链接存在和不存在的概率作为特征。
  2. 特征与数据处理

    • 将社交网络链路预测视为二分类问题,使用15个相似性指标作为特征。
    • 划分节点对,构建包含特征集和类别集的数据集D,使用分层抽样方法将所有节点对按照8:2的比例划分为原始训练集和原始测试集。
  3. 模型训练与集成

    • 在获得训练集和测试集后,将它们分别放入第一个学习层进行学习,这个学习层包含两个基学习器:逻辑斯蒂回归(LR)和LightGBM。
    • Stacking方法训练一个元模型,该模型基于较低层的弱学习器返回的输出结果生成最终输出。
    • 拟合由多个弱学习器组成的Stacking集成模型,包括将训练数据分为两组、选择弱学习器拟合第一组数据、使用这些学习器对第二组数据中的观测数据进行预测,最后在第二组数据上拟合元模型,使用弱学习器做出的预测作为输入。
  4. 结果生成

    • 对基模型学习到的新特征进行重新学习,以得到最终的预测结果。

这些步骤概述了LLSLP方法的整体流程,包括模型选择、特征处理、模型训练与集成,以及最终结果的生成。

5. LightGBM 采用哪些方法解决数据量大和特征维度较高的问题的?结合示例简要进行说明。

LightGBM采用了多种方法来解决处理大数据量和高特征维度的问题,主要包括:

  1. 特征选择:通过排序和筛选重要特征进行训练,减少计算量。

  2. 并行化计算:LightGBM支持并行化计算。它将数据划分为多个子集,分配到不同的计算节点上进行训练,从而提高训练速度。

  3. 高效的内存使用:LightGBM在内存使用方面相对较少,适合处理大规模数据集。它采用高效的内存管理机制,使得在处理大规模数据集时更加稳定。

  4. 多种优化方法:LightGBM采用了多种优化方法,如直方图算法、树算法等,可以优化模型训练和预测过程。

  5. 灵活性:LightGBM在算法设计和调参方面相对灵活,能够适应不同的需求。它还支持多种语言,易于集成,提供了更灵活的集成选项。

这些方法共同作用,使得LightGBM能够有效地处理具有大数据量和高特征维度的复杂数据集,同时保持高效的训练速度和良好的模型性能。

6. 在 LLSLP 方法中引入正则化的主要目的是什么?

在LLSLP(逻辑斯蒂回归与LightGBM堆叠链路预测)方法中引入正则化的主要目的是防止模型过拟合。过拟合是在机器学习中常见的问题,特别是在有大量特征的复杂模型中。过拟合发生时,模型对训练数据的噪声或随机波动有过度的学习,导致其泛化能力下降,即在未见过的新数据上表现不佳。

在LLSLP方法中,正则化通过对模型的误差函数添加正则项来实现。这种做法可以限制模型的复杂度,减少过度拟合训练数据的风险。特别是在使用Stacking方法集成逻辑斯蒂回归和LightGBM模型时,由于Stacking的有效性主要来自特征抽取,而表示学习中总是伴随着过拟合问题。因此,通过不包括原始特征在第二层的特征中,可以进一步降低过拟合的风险。

总结来说,正则化在LLSLP方法中的引入,是为了提高模型在新数据上的预测能力,确保模型具有良好的泛化性能。

7. 什么是堆叠(或层叠)泛化?在 LLSLP 方法中主要作用是什么?

堆叠泛化(Stacking Generalization)是一种集成学习的方法。它的基本思想是学习多个不同的弱学习器,并通过训练一个元模型来组合这些弱学习器,然后基于这些弱模型返回的多个预测结果输出最终的预测结果。

在LLSLP(逻辑斯蒂回归与LightGBM堆叠链路预测)方法中,堆叠泛化的主要作用是提高预测的准确性和泛化能力。这个过程涉及到首先使用逻辑斯蒂回归和LightGBM作为基模型对社交网络的链路预测问题进行学习,然后使用堆叠方法训练一个元模型。这个元模型基于较低层的弱学习器返回的输出结果生成最后的输出。通过这种方式,LLSLP方法能够有效地利用不同模型的优势,同时减少单个模型的不足,从而提高整体预测模型的性能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/283949.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

app上架-您的应用在运行时,未同步告知权限申请的使用目的,向用户索取(相机)等权限,不符合华为应用市场审核标准。

上架提示 您的应用在运行时,未同步告知权限申请的使用目的,向用户索取(相机)等权限,不符合华为应用市场审核标准。 测试步骤:管理-添加-点击二维码,申请相机权限 修改建议:APP在调…

PyQt6 QFileDialog文件对话框控件

锋哥原创的PyQt6视频教程: 2024版 PyQt6 Python桌面开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili2024版 PyQt6 Python桌面开发 视频教程(无废话版) 玩命更新中~共计49条视频,包括:2024版 PyQt6 Python桌面开发 视频教程(无废话版…

微店商品API:电商的实时数据利器

一、引言 随着电商行业的快速发展,越来越多的消费者选择通过电商平台进行购物。微店作为电商领域的一种新型模式,凭借其便捷性和个性化服务,吸引了大量用户。为了满足用户对商品信息的快速获取需求,微店提供了商品详情API接口。本…

Spark编程实验二:RDD编程初级实践

目录 一、目的与要求 二、实验内容 三、实验步骤 1、pyspark交互式编程 2、编写独立应用程序实现数据去重 3、编写独立应用程序实现求平均值问题 4、三个综合实例 四、结果分析与实验体会 一、目的与要求 1、熟悉Spark的RDD基本操作及键值对操作; 2、熟悉使…

如何记录函数递归的次数----静态局部变量的使用

记录函数递归的次数,不像是其他普通的函数,只需要一个简单的局部变量作为计数器,每次就好了,函数递归是不断地调用函数,换言之,如果你将一个局部变量定义在函数的内部,那么每次递归都会创建一个这样的变量,每次的值都会初始化,这样也就达不到记录递归次数的目的. 为了解决这个…

极狐GitLab DevSecOps 之容器镜像安全扫描

容器镜像安全 现状 最近某银行遭受供应链攻击的事件传的沸沸扬扬,安全又双叒叕进入了人们的视野。安全确实是一个非常重要,但是又最容易被忽略的话题。但是现在到了一个不得不人人重视安全,人人为安全负责的时代。尤其以现在非常火爆的云原…

【LeetCode: 2276. 统计区间中的整数数目 | 线段树】

🚀 算法题 🚀 🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀 🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨ 🌲 作者简介:硕风和炜,…

龙芯loongarch64安装numpy报错“No module named ‘numpy.core._multiarray_umath‘”

前言 在之前编译安装Python3.8的文章中说明了,龙芯仓库的很多包都有问题,安装之后很多无法使用,比如安装numpy后,就会出现“No module named numpy.core._multiarray_umath” 问题复现 配置pip源 vim /etc/pip.conf 复制下面的内容并保存 [global] timeout = 60 index-url…

抖店怎么快速起店?不掺杂汤汤水水,全是干货!

我是电商珠珠 我做抖店也已经有三年的时间了,团队也从原来的几人扩大到了70。对于抖店的玩法已经完全摸透熟通,在做店的同时也会带着学生一起做店,他们经常问的问题就是抖店怎么快速起店。 今天,我就来给大家做个分享。根据我的…

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之Text文本组件

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之文本组件 一、操作环境 操作系统: Windows 10 专业版 IDE:DevEco Studio 3.1 SDK:HarmonyOS 3.1 二、文本组件 Text 是显示文本的基础组件之一,它可以包含子组件 Span &…

Python 自动化之收发邮件(一)

imapclient / smtplib 收发邮件 文章目录 imapclient / smtplib 收发邮件前言一、基本内容二、发送邮件1.整体代码 三、获取邮件1.整体代码 总结 前言 简单给大家写个如何用Python进行发邮件和查看邮件教程,希望对各位有所帮助。 一、基本内容 本文主要分为两部分…

选择排序、快速排序和插入排序

1. 选择排序 xuanze_sort.c #include<stdio.h> #include<stdlib.h>//选择排序void xuanze_sort(int arr[],int sz){//正着for(int i0;i<sz;i){//外层循环从第一个数据开始依次作为基准数据for(int j i1;j<sz;j){//int j i1 因为第一个数据作为了基准数据&…