玩转大数据21:基于FP-Growth算法的关联规则挖掘及实现

news2025/1/19 17:20:04

在这里插入图片描述

1.引言

关联规则挖掘是大数据领域中重要的数据分析任务之一,其可以帮助我们发现数据集中项目之间的关联关系。关联规则挖掘是指在交易数据或者其他数据集中,发现一些常见的关联项,如购物篮中经常一起出现的商品组合。关联规则挖掘的应用非常广泛,如市场营销、推荐系统等领域。

2 FP-Growth算法原理

FP-Growth是一种关联分析算法,由韩嘉炜等人在2000年提出。它采取分治策略,将提供频繁项集的数据库压缩到一棵频繁模式树(FP-tree),但仍保留项集关联信息。在算法中,使用了一种称为频繁模式树(Frequent Pattern Tree)的数据结构,这是一种特殊的前缀树,由频繁项头表和项前缀树构成。FP-Growth算法基于以上的结构加快整个挖掘过程。相比Apriori等其他关联分析算法,FP-Growth在性能上有一定优势,能够更快地挖掘出频繁项集和关联规则。

FP-Growth算法主要包括两个阶段:构建频繁模式树和从FP-tree中挖掘频繁项集。

2.1 构建频繁模式树(FP-tree)

首先,扫描数据集计算所有项目的频率,并按照事务的频繁度降序排序。
然后,构建频繁模式树,根据频率排序后的项目创建FP-tree,同时采用路径压缩技术来减少树的规模。

2.2 挖掘频繁项集

从FP-tree中挖掘频繁项集是FP-Growth算法的关键步骤。它通过递归构建条件模式基和条件FP-tree的方式进行实现,直到无法继续挖掘为止。

通过使用FP-Growth算法,我们可以快速高效地挖掘出数据集中的频繁项集和关联规则。实验结果表明,该算法在处理大规模数据集时具有较好的性能,并且可以根据具体需求设置不同的最小支持度阈值。

3. 清洗和预处理的重要性

清洗和预处理对于FP-Growth算法的重要性在于提高数据的质量和准确性,从而获得更好的关联规则挖掘结果。

  • 首先, 清洗和预处理可以去除购物篮数据中的重复值、缺失值和异常值等不规范的数据,确保数据的完整性和一致性。 这样可以避免这些不规范数据对关联规则挖掘的结果产生干扰,提高挖掘的准确性。

  • 其次,清洗和预处理可以对购物篮数据进行转换和格式化,使其适合FP-Growth算法的处理
    例如,将购物篮数据转换为事务数据库的形式,每个事务代表一个购物篮,每个购物篮包含多个商品。这样可以方便FP-Growth算法对频繁项集进行挖掘。

  • 此外,清洗和预处理还可以对购物篮数据进行特征选择和降维等操作,减少数据的复杂性和冗余性,提高算法的效率 。例如,可以去除低频项、合并相似项等,减少频繁项集的数量,加速挖掘过程。

清洗和预处理对于FP-Growth算法非常重要。它们可以提高数据的质量和准确性,减少干扰因素,加速算法的执行速度,从而获得更好的关联规则挖掘结果。
在这里插入图片描述

4. 大数据领域常见应用场景

FP-Growth算法在大数据领域有许多应用场景。以下是其中一些常见的应用场景:

4.1 零售业

FP-Growth算法可以用于分析购物篮数据,发现商品之间的关联关系,从而进行交叉销售和推荐商品。例如,当一个顾客购买了牛奶和面包时,可以推荐给他购买黄油。

4.1.1 分析购物篮数据

FP-Growth算法可以用于分析购物篮数据,发现商品之间的关联关系,从而进行个性化推荐。

购物篮数据分析是指根据用户的购买记录,挖掘出商品之间的频繁项集和关联规则。FP-Growth算法通过构建频繁模式树(FP-Tree)来高效地挖掘频繁项集。

具体而言,FP-Growth算法在购物篮数据分析中的步骤如下:

  • 1 数据预处理: 收集用户的购买记录数据,并进行清洗和预处理,去除异常值和缺失值。

  • 2 构建FP-Tree: 根据购买记录数据,构建FP-Tree。FP-Tree是一种紧凑的数据结构,可以高效地存储频繁项集的信息。

  • 3 挖掘频繁项集: 通过遍历FP-Tree,找出频繁项集。频繁项集是在购物篮中经常一起出现的商品集合。

  • 4 生成关联规则: 根据频繁项集,生成关联规则。关联规则是描述商品之间关联关系的规则,包括支持度和置信度等指标。

  • 5 个性化推荐: 根据用户的购买记录和挖掘出的关联规则,进行个性化推荐。可以根据用户已购买的商品,推荐与之关联的其他商品。

通过FP-Growth算法分析购物篮数据,可以发现商品之间的关联关系,从而实现个性化推荐。例如,当一个用户购买了牛奶和面包时,可以根据关联规则推荐给他购买黄油。

需要注意的是,个性化推荐不仅仅依赖于FP-Growth算法,还需要结合其他算法和技术,如协同过滤、内容推荐等,以提高推荐的准确性和个性化程度。

4.1.2 购物篮数据的清洗和预处理

FP-Growth算法在购物篮数据的清洗和预处理方面,通常需要进行以下步骤:

  • 数据收集: 收集购物篮数据,包括用户的购买记录、商品信息等。

  • 数据清洗: 对收集到的购物篮数据进行清洗,去除重复数据、缺失值和异常值等。这可以通过数据清洗技术和算法来实现,如数据去重、缺失值填充和异常值检测等。

  • 数据转换: 将购物篮数据转换为适合FP-Growth算法处理的格式。通常,购物篮数据可以表示为一个事务数据库,其中每个事务代表一个购物篮,每个购物篮包含多个商品。

  • 数据预处理: 对转换后的购物篮数据进行预处理,以减少数据的复杂性和提高算法的效率。预处理步骤可以包括去除低频项、合并相似项、进行特征选择等。

  • 构建FP-Tree: 使用预处理后的购物篮数据构建FP-Tree,这是FP-Growth算法的核心数据结构。FP-Tree可以高效地存储频繁项集的信息,加速频繁项集的挖掘过程。

通过以上步骤,购物篮数据就可以进行清洗和预处理,为后续的FP-Growth算法提供准备。清洗和预处理的目的是提高数据的质量和准确性,以获得更好的关联规则挖掘结果。需要根据具体的数据特点和业务需求,选择合适的清洗和预处理方法。

4.2 电子商务

在电子商务平台上,FP-Growth算法可以用于个性化推荐和商品分类。通过分析用户的购买历史和行为模式,可以向用户推荐他们可能感兴趣的商品,并提供更好的购物体验。

4.2.1 电商平台个性化推荐的实现

在电子商务平台上,FP-Growth算法可以用于个性化推荐。个性化推荐是根据用户的兴趣和偏好,向其推荐可能感兴趣的商品或内容。

FP-Growth算法通过挖掘频繁项集和关联规则,可以发现商品之间的关联关系,从而实现个性化推荐。

个性化推荐步骤

  • 数据收集与预处理
    收集用户的购买记录、浏览记录、收藏记录等行为数据,并对数据进行清洗和预处理,去除异常值和缺失值。

  • 构建频繁模式树
    使用FP-Growth算法构建频繁模式树,根据用户的购买记录等数据,找出频繁项集和关联规则。

  • 用户特征提取
    根据用户的购买记录和浏览记录等数据,提取用户的特征,如购买偏好、浏览偏好等。

  • 相似度计算
    计算用户之间的相似度,可以使用余弦相似度等方法。通过计算相似度,找到与用户兴趣相似的其他用户。

  • 个性化推荐
    根据用户的特征和相似度,向用户推荐可能感兴趣的商品。可以根据频繁项集和关联规则,推荐与用户购买记录相关的商品。

代码示例

import pandas as pd
from fpgrowth import FPGrowth

# 读取数据集
data = pd.read_csv("user_behavior.csv")

# 数据预处理:提取商品ID和用户ID,并转换为集合形式
user_behavior = data[["user_id", "item_id"]].values

# 创建FPGrowth对象
fp_growth = FPGrowth()

# 运行FPGrowth算法,生成频繁项集和关联规则
frequent_itemsets, rules = fp_growth.generate_frequent_itemsets(user_behavior, min_support=0.3, min_confidence=0.7)

# 根据关联规则生成推荐列表
user_id = 1001  # 假设要为user_id为1001的用户进行推荐
recommended_items = fp_growth.generate_recommendations(user_id, frequent_itemsets, rules)

print("个性化推荐列表:", recommended_items)

在这个示例中,我们首先使用Pandas库读取了一个用户行为数据集。
然后,我们使用FPGrowth库创建了一个FPGrowth对象,并调用generate_frequent_itemsets方法来生成频繁项集和关联规则。
接下来,我们使用generate_recommendations方法为特定用户生成个性化推荐列表。
在这个示例中,我们假设要为user_id为1001的用户进行推荐。最后,我们打印出个性化推荐列表。

4.2.2 FP-Growth算法在商品分类中的应用

商品分类是将商品按照一定的规则进行分类,以便更好地组织和管理商品。而FP-Growth算法可以通过挖掘商品之间的关联关系,自动生成商品的分类规则。

实现基于FP-Growth算法的商品分类步骤:

  • 数据预处理: 对商品数据进行清洗、去重、分类等操作,将数据转换成适合进行数据挖掘的形式。
  • 构建频繁项集 :利用FP-Growth算法对商品数据进行挖掘,找出频繁项集,这些项集代表了不同类型的商品。
  • 生成分类规则: 根据频繁项集生成分类规则,这些规则揭示了不同类型商品之间的关联关系。
  • 分类商品: 根据分类规则对所有商品进行分类,将商品组织成不同的类别。

代码示例

import pandas as pd
from fpgrowth import FPGrowth

# 读取数据集
data = pd.read_csv("product_data.csv")

# 数据预处理:提取商品ID和商品类别,并转换为集合形式
product_data = data[["product_id", "category"]].values

# 创建FPGrowth对象
fp_growth = FPGrowth()

# 运行FPGrowth算法,生成频繁项集和关联规则
frequent_itemsets, rules = fp_growth.generate_frequent_itemsets(product_data, min_support=0.2)

# 根据关联规则生成分类规则和分类结果
classified_products = fp_growth.generate_classified_products(frequent_itemsets, rules)

print("商品分类结果:", classified_products)

在这个示例中,我们同样首先使用Pandas库读取了一个商品数据集。然后,我们使用FPGrowth库创建了一个FPGrowth对象,并调用generate_frequent_itemsets方法来生成频繁项集和关联规则。接下来,我们使用generate_classified_products方法对所有商品进行分类。最后,我们打印出商品分类结果。在这个示例中,我们假设根据关联规则可以将商品分为两类。

需要注意的是,FP-Growth算法是一种关联规则挖掘算法,它可以帮助发现商品之间的关联关系,但在个性化推荐中,还需要结合其他算法和技术,如协同过滤、内容推荐等,以提高推荐的准确性和个性化程度。

在这里插入图片描述

4.3 社交网络分析

在社交网络中,FP-Growth算法可以用于发现用户之间的关联关系和社区结构。通过分析用户的好友关系、共同兴趣等信息,可以识别出潜在的社交圈子和影响力人物。

社交网络分析是研究社交网络中节点和边的关系、属性以及动态变化规律的科学。通过对社交网络进行分析,可以挖掘出许多有价值的信息,例如用户行为、社区结构、信息传播等。而FP-Growth算法作为一种高效的数据挖掘算法,在社交网络分析中也有着广泛的应用。

在社交网络分析中,FP-Growth算法可以应用于许多方面,例如用户行为分析、社区发现和信息传播分析等。下面我们将通过两个具体的代码示例,展示如何使用FP-Growth算法进行社交网络分析。

4.3.1用户行为分析

用户行为分析是社交网络分析的重要内容之一,通过对用户的行为进行分析,可以挖掘出用户的兴趣、偏好和行为模式等信息。下面是一个使用Python和FPGrowth库进行用户行为分析的示例代码:

import pandas as pd
from fpgrowth import FPGrowth

# 读取数据集
data = pd.read_csv("user_behavior.csv")

# 数据预处理:提取用户ID和行为类型,并转换为集合形式
user_behavior = data[["user_id", "behavior_type"]].values

# 创建FPGrowth对象
fp_growth = FPGrowth()

# 运行FPGrowth算法,生成频繁项集和关联规则
frequent_itemsets, rules = fp_growth.generate_frequent_itemsets(user_behavior, min_support=0.2, min_confidence=0.7)

# 根据关联规则生成用户行为模式
user_behavior_patterns = fp_growth.generate_user_behavior_patterns(frequent_itemsets, rules)

print("用户行为模式:", user_behavior_patterns)

在这个示例中,我们首先使用Pandas库读取了一个用户行为数据集。然后,我们使用FPGrowth库创建了一个FPGrowth对象,并调用generate_frequent_itemsets方法来生成频繁项集和关联规则。接下来,我们使用generate_user_behavior_patterns方法对用户行为进行分析,并生成用户行为模式。最后,我们打印出用户行为模式。在这个示例中,我们假设根据关联规则可以将用户行为分为三类。

4.3.2 社区发现

社区发现是社交网络分析中的另一个重要内容,通过对社交网络中的节点进行聚类,可以发现具有相似兴趣、行为或属性的用户群体。下面是一个使用Python和NetworkX库进行社区发现的示例代码:

import networkx as nx
from fpgrowth import FPGrowth

# 创建社交网络图
G = nx.read_edgelist("social_network.edgelist", nodetype=int)

# 提取节点特征向量
node_features = []
for node in G.nodes:
    features = []
    degree = G.degree[node]
    betweenness = nx.betweenness_centrality(G, node)
    features.append(degree)
    features.append(betweenness)
    node_features.append(features)

# 数据预处理:将节点特征向量转换为集合形式
node_features = [[feature for feature in node] for node in node_features]

# 创建FPGrowth对象
fp_growth = FPGrowth()

# 运行FPGrowth算法,生成频繁项集和关联规则
frequent_itemsets, rules = fp_growth.generate_frequent_itemsets(node_features, min_support=0.1)

# 根据关联规则生成社区结构
communities = fp_growth.generate_communities(frequent_itemsets, G)

print("社区结构:", communities)

在这个示例中,我们首先使用NetworkX库创建了一个社交网络图。然后,我们提取了每个节点的特征向量,包括节点的度数和介数中心性等。接下来,我们对节点特征向量进行数据预处理,将其转换为集合形式。然后,我们使用FPGrowth库创建了一个FPGrowth对象,并调用`generate

在这里插入图片描述

4.4 金融领域

金融领域是一个数据密集型的行业,涉及到大量的交易数据、客户数据和市场数据。这些数据中蕴含着丰富的信息和知识,对于金融机构的决策和风险管理至关重要。FP-Growth算法作为一种高效的数据挖掘算法,在金融领域中得到了广泛的应用。

4.4.1 信用评分

信用评分是金融机构评估客户信用风险的重要手段。通过分析客户的个人信息、历史信用记录和交易数据,可以预测客户未来违约的可能性。FP-Growth算法可以用于挖掘客户特征之间的关联规则,帮助金融机构构建更准确的信用评分模型。

以下是一个使用Python实现FP-Growth算法进行信用评分的示例代码:

import pandas as pd
from fpgrowth import FPGrowth

# 读取数据集
data = pd.read_csv("credit_data.csv")

# 数据预处理:提取特征和目标变量,并转换为集合形式
features = data.drop("default", axis=1).values
target = data["default"].values

# 创建FPGrowth对象
fp_growth = FPGrowth()

# 运行FPGrowth算法,生成频繁项集和关联规则
frequent_itemsets, rules = fp_growth.generate_frequent_itemsets(features, min_support=0.2, min_confidence=0.7)

# 根据关联规则构建信用评分模型
score = fp_growth.generate_credit_score(frequent_itemsets, rules, target)

print("信用评分结果:", score)

在这个示例中,我们首先使用Pandas库读取了一个信用数据集。然后,我们使用FPGrowth库创建了一个FPGrowth对象,并调用generate_frequent_itemsets方法来生成频繁项集和关联规则。接下来,我们使用generate_credit_score方法根据关联规则构建信用评分模型。最后,我们打印出信用评分结果。

4.4.2. 风险评估和管理

金融机构在进行投资决策、风险管理等方面需要进行风险评估。通过分析市场数据、交易数据等,可以发现潜在的风险点和趋势。FP-Growth算法可以帮助金融机构快速挖掘出市场数据中的频繁模式和关联规则,从而更好地评估和管理风险。

以下是一个使用Python实现FP-Growth算法进行风险评估的示例代码:

import pandas as pd
from fpgrowth import FPGrowth
import matplotlib.pyplot as plt

# 读取数据集
data = pd.read_csv("market_data.csv")

# 数据预处理:提取交易数据和市场指数数据,并转换为集合形式
transactions = data[["transaction_id", "price", "volume"]].values
market_index = data["market_index"].values

# 创建FPGrowth对象
fp_growth = FPGrowth()

# 运行FPGrowth算法,生成频繁项集和关联规则
frequent_itemsets, rules = fp_growth.generate_frequent_itemsets(transactions, min_support=0.1)

# 根据关联规则进行风险评估和管理
risks = fp_growth.generate_risks(frequent_itemsets, rules, market_index)
plt.plot(risks)
plt.title("Risk Assessment Over Time")
plt.xlabel("Time")
plt.ylabel("Risk Level")
plt.show()

在这个示例中,我们首先使用Pandas库读取了一个市场数据集。
然后,我们使用FPGrowth库创建了一个FPGrowth对象,并调用generate_frequent_itemsets方法来生成频繁项集和关联规则。
接下来,我们使用generate_risks方法根据关联规则进行风险评估和管理,并使用Matplotlib库绘制风险随时间变化的图表。
最后,我们展示了一个风险评估随时间变化的图表。

4.4.3. 投资组合优化

投资组合优化是金融机构进行资产配置的重要手段。通过分析市场数据和历史投资组合的表现,可以发现潜在的投资机会和风险点。FP-Growth算法可以帮助金融机构快速挖掘出市场数据中的频繁模式和关联规则,从而更好地进行投资组合优化。

以下是一个使用Python实现FP-Growth算法进行投资组合优化的示例代码:

import pandas as pd
from fpgrowth import FPGrowth
import numpy as np

# 读取数据集
data = pd.read_csv("portfolio_data.csv")

# 数据预处理:提取历史投资组合数据和市场数据,并转换为集合形式
portfolios = data[["portfolio_id", "asset", "weight"]].values
market_data = data["market_index"].values
returns = data["return"].values

# 创建FPGrowth对象
fp_growth = FPGrowth()

# 运行FPGrowth算法,生成频繁项集和关联规则
frequent_itemsets, rules = fp_growth.generate_frequent_itemsets(portfolios, min_support=0.2)

# 根据关联规则进行投资组合优化
optimal_portfolio = fp_growth.generate_optimal_portfolio(frequent_itemsets, rules, market_data, returns)
print("Optimal Portfolio:", optimal_portfolio)

在这个示例中,我们首先使用Pandas库读取了一个投资组合数据集。然后,我们使用FPGrowth库创建了一个FPGrowth对象,并调用generate_frequent_itemsets方法来生成频繁项集和关联规则。接下来,我们使用generate_optimal_portfolio方法根据关联规则进行投资组合优化,并打印出最优投资组合的配置。

FP-Growth算法在金融领域中具有广泛的应用价值。通过挖掘金融数据中的频繁项集和关联规则,可以有效地支持信用评分、风险评估和管理、投资组合优化等金融业务。通过与金融机构的深入合作,我们可以进一步优化FP-Growth算法的性能和应用效果,为金融行业的发展提供更好的技术支持。

4.5 医疗保健

在医疗保健领域,FP-Growth算法可以用于分析病人的病历数据和医疗记录,发现疾病之间的关联关系和治疗模式。这有助于提高疾病诊断的准确性和治疗方案的个性化。
FP-Growth算法在医疗保健领域的实践

随着大数据时代的来临,医疗保健领域正面临着前所未有的机遇和挑战。如何从海量的医疗数据中挖掘出有价值的信息,为临床决策提供支持,成为了一个重要的研究方向。FP-Growth算法作为一种高效的数据挖掘算法,在医疗保健领域中得到了广泛的应用。本文将介绍FP-Growth算法的基本原理,并通过具体的代码示例,探讨其在医疗保健领域的实践。

4.5.1FP-Growth算法在医疗保健领域的实践

在医疗保健领域,FP-Growth算法的应用主要集中在以下几个方面:

1. 疾病诊断与预测: 通过分析患者的历史数据和疾病特征,利用FP-Growth算法挖掘出频繁模式和关联规则,从而辅助医生进行疾病诊断和预测。例如,根据患者的年龄、性别、血压、血糖等指标,预测患者患心血管疾病的风险。
2. 个性化治疗: 利用FP-Growth算法分析患者的个体差异和治疗方案,为每个患者量身定制最佳治疗方案。例如,根据患者的基因组数据和药物反应数据,为患者推荐最合适的药物和治疗方案。
3. 流行病预测与防控: 通过分析历史流行病数据和人口统计学数据,利用FP-Growth算法挖掘出流行病传播的规律和趋势,为防控措施提供科学依据。例如,根据流感疫情数据预测流感季节的高峰期,提前采取防控措施。

4.5.2 示例

下面是一个使用Python实现FP-Growth算法的示例代码,用于疾病诊断与预测:

import pandas as pd
from fpgrowth import FPGrowth

# 读取数据集
data = pd.read_csv("medical_data.csv")

# 数据预处理:提取疾病特征和诊断结果,并转换为集合形式
feature_data = data[["feature1", "feature2", "feature3", "diagnosis"]].values

# 创建FPGrowth对象
fp_growth = FPGrowth()

# 运行FPGrowth算法,生成频繁项集和关联规则
frequent_itemsets, rules = fp_growth.generate_frequent_itemsets(feature_data, min_support=0.3, min_confidence=0.7)

# 根据关联规则生成预测结果
predicted_diagnosis = fp_growth.generate_predictions(frequent_itemsets, rules)

print("预测结果:", predicted_diagnosis)

在这个示例中,我们使用Pandas库读取了一个包含疾病特征和诊断结果的数据集。然后,我们使用FPGrowth库创建了一个FPGrowth对象,并调用generate_frequent_itemsets方法来生成频繁项集和关联规则。接下来,我们使用generate_predictions方法对每个患者的特征进行预测,得到预测的诊断结果。最后,我们打印出预测结果。

需要注意的是,以上只是FP-Growth算法在大数据领域的一些常见应用场景,实际上,FP-Growth算法还可以应用于其他领域,如网络安全、市场营销、物流管理等。其优势在于能够高效地挖掘出频繁项集和关联规则,从而帮助我们发现数据集中的隐藏模式和关联关系,为决策提供支持和指导。

总结

FP-Growth算法通过构建频繁模式树和挖掘频繁项集的方式,可以帮助我们发现数据集中项目之间的关联关系。在大数据领域中,FP-Growth算法是一种高效的关联规则挖掘算法,具有广泛的应用前景。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

医学实验室检验科LIS信息系统源码

实验室信息管理是专为医院检验科设计的一套实验室信息管理系统,能将实验仪器与计算机组成网络,使病人样品登录、实验数据存取、报告审核、打印分发,实验数据统计分析等繁杂的操作过程实现了智能化、自动化和规范化管理。 实验室管理系统功能介…

初识Stable Diffusion

界面选项解读 这是在趋动云上部署的Stable Diffusion txt2img prompt (1)分割符号:使用逗号 , 用于分割词缀,且有一定权重排序功能,逗号前权重高,逗号后权重低 (2)建议的通用范式…

LabVIEW的六轴工业机器人运动控制系统

LabVIEW开发六轴工业机器人运动控制系统 本项目开发了一个高效的工业机器人控制系统,重点关注于运动学算法和轨迹规划算法的实现和测试。LabVIEW作为一个关键技术,在项目中扮演了核心角色。 系统研究与算法开发:首先,项目围绕机…

记一次生产慢sql索引优化及思考

一 问题重现 夜黑风高的某一晚,突然收到一条运营后台数据库慢sql的报警,耗时竟然达到了60s。 看了一下,还好不是很频繁,内心会更加从容排查问题,应该是特定条件下没有走到索引导致,如果频繁出现慢查询&…

ubuntu22.04+ROS2推荐匹配的gazebo版本

放大以后看到: 可以看到ros2推荐使用版本是humble-----匹配的是Ubuntu22.04LTS -------匹配gazebo Harmonic

Windows漏洞利用开发——利用SEH绕过GS保护

实验6 Windows漏洞利用开发 6.1实验名称 Windows漏洞利用开发 6.2实验目的 学习windows漏洞利用开发,使用kali linux相关工具对windows内目标程序进行漏洞利用 6.3实验步骤及内容 第二阶段:利用SEH绕过GS保护 了解GS编译选项,SHE异常处…

【多模态对话】《颠覆性创新:多模态对话与精准区域分割 - VPGTrans NExT-Chat》学习笔记

【OpenMMLab社区开放麦讲座】《颠覆性创新:多模态对话与精准区域分割 - VPGTrans & NExT-Chat》 1 VPGTrans 1.1 研究问题 1.1.1 模态对齐预训练开销很大:训练时间长 解决方案:迁移已有的VPG(比如BLIP-2 OPT 27B上的VPG) 1.2 训练技巧…

01背包详解,状态设计,滚动数组优化,通用问题求解

文章目录 0/1背包前言一、0/1背包的状态设计1、状态设计2、状态转移方程3、初始状态4、代码实现5、滚动数组优化二维优化为两个一维二维优化为一个一维,倒序递推 二、0/1背包的通用问题求最大值求最小值求方案数 0/1背包 前言 0/1包问题,作为动态规划问…

ESP32运行MicroPython——环境搭建

1、准备工作 硬件:ESP32-DevKitC V4 开发板、USB串口线 软件: flash_download_tool_3.9.5(乐鑫烧录工具)、官方下载地址 CP210x(USB驱动程序)、官方下载地址 ESP32_GENERIC-20231005-v1.21.0.bin&#xff…

将html转化成图片

如何将指定html内容转化成图片保存?这个问题很值得深思,实际应用中也很有价值。最直接的想法就是使用canvas,熟悉canvas的同学可以尝试一下。这里不做太多的说明,本文采用html2canvas库来实现。 html2canvas库的使用非常简单&…

JavaWeb笔记之SVN

一、版本控制 软件开发过程中 变更的管理; 每天的新内容;需要记录一下; 版本分支;整合到一起; 主要的功能对于文件变更的追踪; 多人协同开发的情况下,更好的管理我们的软件。 大型的项目;一个团队来进行开发; 1: 代码的整合 2: 代…

GPT2代码运行,个人文本生成助手,不依赖OpenAI API调用

0.前言: 感觉GPT很好玩,所以想要有个自己搭建GPT的写法,不依赖于OpenAI,需要翻墙太麻烦了,近日日本已经结合GPT4和机器,可以让他吓人,做出丰富的表情,如果自己训练的话,会塑造出什么样的机器人尚未可知…抱着好奇的心态,去github openai下载了个gpt2的模型来玩玩(其中遇到了许多…

arm汇编-补充-画图记忆 LDM/STM系列指令

说明 原始文章系列 https://azeria-labs.com/writing-arm-assembly-part-1/ 翻译-进作者的专栏可以翻到所有翻译 系列:https://zhuanlan.zhihu.com/p/109057983 系列:https://www.anquanke.com/post/id/86383 0x00 调试环境 使用arm架构的系统&#…

❀My学习Linux命令小记录之iperf❀

❀My学习Linux命令小记录之iperf❀ 目录 ❀My学习Linux命令小记录之iperf❀ ①功能说明: ②安装iperf: ③iperf的使用及参数介绍: ④注意事项: ⑤实例: iperf测试udp iperf测试tcp ①功能说明: i…

管理 Jenkins 详细指南

目录 系统配置 安全 状态信息 故障 排除 工具和操作 系统配置 系统,配置全局设置和路径,端口更改,下载地址等。 工具,配置工具、其位置和自动安装程序。 插件,添加、删除、禁用或启用可以扩展 Jenkins 功能的插…

Logback简介与配置详解

在开发和维护Spring Boot应用程序时,一个强大而灵活的日志框架是至关重要的。Spring Boot默认集成了Logback,一个高性能的Java日志框架。本文将介绍如何配置Logback以满足你的日志记录需求。 Logback简介 官方网址:https://logback.qos.ch/ …

【JMeter】JMeter控制RPS

一、前言 ​ RPS (Request Per Second)一般用来衡量服务端的吞吐量,相比于并发模式,更适合用来摸底服务端的性能。我们可以通过使用 JMeter 的常数吞吐量定时器来限制每个线程的RPS。对于RPS,我们可以把他理解为我们的TPS,我们就不…

2023年12月GESP Python三、四级编程题真题解析

三、2023年12月GESP Python三级编程题 【三级编程题1】 【试题名称】&#xff1a;小猫分鱼 【问题描述】 海滩上有一堆鱼&#xff0c;N只小猫来分。第一只小猫把这堆鱼平均分为N份&#xff0c;多了i<N条鱼&#xff0c;这只小猫把多的i条鱼扔入海中&#xff0c;拿走了一份…

DBA-MySql面试问题及答案-上

文章目录 1.什么是数据库?2.如何查看某个操作的语法?3.MySql的存储引擎有哪些?4.常用的2种存储引擎&#xff1f;6.可以针对表设置引擎吗&#xff1f;如何设置&#xff1f;6.选择合适的存储引擎&#xff1f;7.选择合适的数据类型8.char & varchar9.Mysql字符集10.如何选择…

Stable Diffusion 基本原理

1 Diffusion Model的运作过程 输入一张和我们所需结果图尺寸一致的噪声图像&#xff0c;通过Denoise模块逐步减少noise&#xff0c;最终生成我们需要的效果图。 图中Denoise模块虽然是同一个&#xff0c;但是它会根据不同step的输入图像和代表noise严重程度的参数选择denoise的…