Python手写“随机森林”解决鸢尾花数据集分类问题
Python使用“随机森林”解决鸢尾花数据集分类问题
- 任务描述
- 解题
- 1. 导入必要的库
- 2. 数据采样函数 `sample`
- 3. 设置随机种子和超参数
- 4. 定义随机森林类 `random_forest`
- 5. 加载数据集并划分训练集和测试集
- 6. 创建并训练随机森林模型
- 7. 进行预测并计算准确率
- 代码
任务描述
您的任务是编写一个“random_forest”类来解决基于 Fisher Iris 数据集(sklearn.datasets.load_iris
)的分类问题,该类以“n_estimators”、“max_depth”、“subspaces_dim”和“random_state”作为输入参数。下面给出了这些参数的描述。该类必须定义 .fit()
和 .predict()
方法,以及 ._estimators
字段,该字段必须存储集成中使用的算法列表。
- n_estimators - 集合中的树的数量
- max_depth - 集合中每棵树的最大深度
- subspaces_dim - 每棵树的随机子空间的维数
要为每个基础分类器创建一个训练子样本,您可以使用在上一个任务中实现的“样本”类。如果您使用它,请记住将其描述包含在当前任务的解决方案文件中。我们还建议您通过填充“subspace_idx”列表来组织每棵树的子空间选择,该列表将记录为每个基分类器选择的子空间。
注意:此任务不允许使用 sklearn.ensemble.RandomForestClassifier
类(我们正常情况下是可以直接调用这个功能包使用解决问题的,这里我们拆开写是为了提升我们思考)
另外,选择你的算法在测试样本上获得最佳质量(就准确度指标、正确答案的比例而言)的超参数,参数test_size
=0.3,将它们设置为全局变量N_ESTIMATORS、MAX_DEPTH、SUBSPACE_DIM。
类模板:
import numpy as np
np.random.seed(42)N_ESTIMATORS = None
MAX_DEPTH = None
SUBSPACE_DIM = Noneclass random_forest(object):def __init__(self, n_estimators: int, max_depth: int, subspaces_dim: int, random_state: int):self.n_estimators = n_estimatorsself.max_depth = max_depthself.subspaces_dim = subspaces_dimself.random_state = random_state"""在类构造函数中设置所有必需的字段"""def fit(self, X, y):for i in range(self.n_estimators):"""编写一个函数来在自己的子样本上训练每个算法的树。"""passdef predict(self, X):"""编写一个函数来获取算法的平均预测"""pass
解题
实现一个自定义的随机森林分类器,并使用鸢尾花数据集进行分类任务。
1. 导入必要的库
import numpy as np
from sklearn.datasets import load_iris
from sklearn.model_selection import train_test_split
from sklearn.metrics import accuracy_score
numpy
:是 Python 中用于科学计算的基础库,提供了高性能的多维数组对象和处理这些数组的工具。load_iris
:从sklearn.datasets
中导入,用于加载鸢尾花数据集。train_test_split
:从sklearn.model_selection
中导入,用于将数据集划分为训练集和测试集。accuracy_score
:从sklearn.metrics
中导入,用于计算模型预测的准确率。
2. 数据采样函数 sample
自助采样是一种有放回的随机抽样方法。从原始数据集中随机抽取样本,每次抽取后将样本放回,这意味着同一个样本可能会被多次抽取。
作用:
- 增加数据多样性:在随机森林中,每棵决策树使用不同的自助采样数据集进行训练,这样可以使每棵树关注不同的数据特征和模式,增加模型的多样性,避免所有树都学习到相同的信息,从而提升整体模型的泛化能力。
- 估计模型稳定性:自助采样还可用于估计模型的稳定性和误差,例如通过计算袋外数据(未被抽到的数据)的误差来评估模型性能。
def sample(X, y, n_samples=None):if n_samples is None:n_samples = len(X)indices = np.random.choice(len(X), n_samples, replace=True)return X[indices], y[indices]
- 该函数用于对输入的特征矩阵
X
和标签向量y
进行自助采样(bootstrap sampling)。 n_samples
表示要采样的样本数量,如果未指定,则默认采样数量等于原始数据集的样本数量。np.random.choice
函数用于随机选择样本的索引,replace=True
表示可以重复选择同一个样本。- 最后返回采样后的特征矩阵和标签向量。
3. 设置随机种子和超参数
np.random.seed(42)N_ESTIMATORS = 100
MAX_DEPTH = 5
SUBSPACE_DIM = 2
np.random.seed(42)
:设置随机数种子,确保每次运行代码时生成的随机数序列相同,从而保证结果的可重复性。N_ESTIMATORS
:随机森林中决策树的数量,这里设置为 100。MAX_DEPTH
:每棵决策树的最大深度,设置为 5 可以防止过拟合。SUBSPACE_DIM
:每个决策树训练时随机选择的特征子空间的维度,设置为 2。
4. 定义随机森林类 random_forest
class random_forest(object):def __init__(self, n_estimators: int, max_depth: int, subspaces_dim: int, random_state: int):self.n_estimators = n_estimatorsself.max_depth = max_depthself.subspaces_dim = subspaces_dimself.random_state = random_stateself._estimators = []
- 该类用于实现随机森林分类器。
__init__
方法是类的构造函数,用于初始化随机森林的参数,包括决策树的数量、最大深度、子空间维度和随机种子。self._estimators
是一个空列表,用于存储随机森林中的每棵决策树。
def fit(self, X, y):for i in range(self.n_estimators):X_sample, y_sample = sample(X, y)subspace_idx = np.random.choice(X.shape[1], self.subspaces_dim, replace=False)X_subspace = X_sample[:, subspace_idx]from sklearn.tree import DecisionTreeClassifierestimator = DecisionTreeClassifier(max_depth=self.max_depth, random_state=self.random_state)estimator.fit(X_subspace, y_sample)self._estimators.append(estimator)
fit
方法用于训练随机森林模型。- 对于每棵决策树:
- 调用
sample
函数对数据进行自助采样,得到训练样本X_sample
和对应的标签y_sample
。 - 使用
np.random.choice
随机选择subspaces_dim
个特征,得到特征子空间的索引subspace_idx
。 - 从采样数据中提取特征子空间
X_subspace
。 - 创建一个决策树分类器
DecisionTreeClassifier
,设置最大深度和随机种子。 - 使用特征子空间和对应的标签训练决策树。
- 将训练好的决策树添加到
self._estimators
列表中。
- 调用
其中特征子空间采样:
-
原理:特征子空间采样是指在训练每棵决策树时,随机选择一部分特征作为该树的特征子空间,而不是使用所有特征。
-
作用:
- 降低特征间的相关性影响:不同的决策树使用不同的特征子空间进行训练,这样可以减少特征之间的相关性对模型的影响,使每棵树关注不同的特征组合,进一步增加模型的多样性。
- 防止过拟合:通过限制每棵树使用的特征数量,可以避免模型过于复杂,从而减少过拟合的风险。
def predict(self, X):predictions = []for estimator in self._estimators:subspace_idx = np.random.choice(X.shape[1], self.subspaces_dim, replace=False)X_subspace = X[:, subspace_idx]pred = estimator.predict(X_subspace)predictions.append(pred)predictions = np.array(predictions).Tfinal_predictions = np.array([np.bincount(pred).argmax() for pred in predictions])return final_predictions
predict
方法用于对输入数据X
进行预测。- 对于随机森林中的每棵决策树:
- 随机选择
subspaces_dim
个特征,得到特征子空间X_subspace
。 - 使用该决策树对特征子空间进行预测,将预测结果添加到
predictions
列表中。
- 随机选择
- 将所有决策树的预测结果转置,使得每一行代表一个样本的所有预测结果。
- 对于每个样本,使用
np.bincount
统计每个类别出现的次数,然后使用argmax
选择出现次数最多的类别作为最终预测结果。
5. 加载数据集并划分训练集和测试集
iris = load_iris()
X = iris.data
y = iris.targetX_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3, random_state=42)
- 使用
load_iris
函数加载鸢尾花数据集,将特征矩阵存储在X
中,标签向量存储在y
中。 - 使用
train_test_split
函数将数据集划分为训练集和测试集,测试集占比为 30%。
6. 创建并训练随机森林模型
rf = random_forest(n_estimators=N_ESTIMATORS, max_depth=MAX_DEPTH, subspaces_dim=SUBSPACE_DIM, random_state=42)
rf.fit(X_train, y_train)
- 创建一个
random_forest
类的实例rf
,并传入超参数。 - 调用
fit
方法对随机森林模型进行训练。
7. 进行预测并计算准确率
y_pred = rf.predict(X_test)
accuracy = accuracy_score(y_test, y_pred)
print(f"Accuracy: {accuracy}")
- 调用
predict
方法对测试集进行预测,得到预测结果y_pred
。 - 使用
accuracy_score
函数计算模型在测试集上的准确率。 - 打印准确率结果。
代码
import numpy as np
from sklearn.datasets import load_iris
from sklearn.model_selection import train_test_split
from sklearn.metrics import accuracy_score# 数据采样函数
def sample(X, y, n_samples=None):if n_samples is None:n_samples = len(X)# 随机选择样本索引indices = np.random.choice(len(X), n_samples, replace=True)return X[indices], y[indices]np.random.seed(42)# 定义超参数
N_ESTIMATORS = 100
MAX_DEPTH = 5
SUBSPACE_DIM = 2class random_forest(object):def __init__(self, n_estimators: int, max_depth: int, subspaces_dim: int, random_state: int):self.n_estimators = n_estimatorsself.max_depth = max_depthself.subspaces_dim = subspaces_dimself.random_state = random_state# 存储每棵决策树self._estimators = []def fit(self, X, y):for i in range(self.n_estimators):# 对数据进行采样X_sample, y_sample = sample(X, y)# 随机选择特征子空间subspace_idx = np.random.choice(X.shape[1], self.subspaces_dim, replace=False)X_subspace = X_sample[:, subspace_idx]from sklearn.tree import DecisionTreeClassifier# 创建决策树分类器estimator = DecisionTreeClassifier(max_depth=self.max_depth, random_state=self.random_state)# 训练决策树estimator.fit(X_subspace, y_sample)self._estimators.append(estimator)def predict(self, X):predictions = []for estimator in self._estimators:# 随机选择特征子空间subspace_idx = np.random.choice(X.shape[1], self.subspaces_dim, replace=False)X_subspace = X[:, subspace_idx]# 每棵树进行预测pred = estimator.predict(X_subspace)predictions.append(pred)predictions = np.array(predictions).T# 通过多数表决得到最终预测结果final_predictions = np.array([np.bincount(pred).argmax() for pred in predictions])return final_predictions# 加载鸢尾花数据集
iris = load_iris()
X = iris.data
y = iris.target# 划分训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3, random_state=42)# 创建并训练随机森林模型
rf = random_forest(n_estimators=N_ESTIMATORS, max_depth=MAX_DEPTH, subspaces_dim=SUBSPACE_DIM, random_state=42)
rf.fit(X_train, y_train)# 进行预测
y_pred = rf.predict(X_test)# 计算准确率
accuracy = accuracy_score(y_test, y_pred)
print(f"Accuracy: {accuracy}")
输出:Accuracy: 0.7111111111111111
相关文章:
Python手写“随机森林”解决鸢尾花数据集分类问题
Python使用“随机森林”解决鸢尾花数据集分类问题 任务描述解题1. 导入必要的库2. 数据采样函数 sample3. 设置随机种子和超参数4. 定义随机森林类 random_forest5. 加载数据集并划分训练集和测试集6. 创建并训练随机森林模型7. 进行预测并计算准确率 代码 任务描述 您的任务是…...
Python 字典和集合(泛映射类型)
本章内容的大纲如下: 常见的字典方法 如何处理查找不到的键 标准库中 dict 类型的变种set 和 frozenset 类型 散列表的工作原理 散列表带来的潜在影响(什么样的数据类型可作为键、不可预知的 顺序,等等) 泛映射类型 collections.…...
CrystalDiskInfo电脑硬盘监控工具 v9.6.0中文绿色便携版
前言 CrystalDiskInfo是一个不用花钱的硬盘小帮手软件,它可以帮你看看你的电脑硬盘工作得怎么样,健不健康。这个软件能显示硬盘的温度高不高、还有多少地方没用、传输东西快不快等等好多信息。用了它,你就能很容易地知道硬盘现在是什么情况&…...
rqlite:一个基于SQLite构建的分布式数据库
今天给大家介绍一个基于 SQLite 构建的轻量级分布式关系型数据库:rqlite。 rqlite 基于 Raft 协议,结合了 SQLite 的简洁性以及高可用分布式系统的稳健性,对开发者友好,操作极其简便,其核心设计理念是以最低的复杂度实…...
网络1 网络设备
计算机网络设备 集线器: 易发生阻塞:所有端口共享一条带宽,两个端口发生传输时,其他端口若想传输数据给这两个端口,需等待这两个端口传输数据完毕。 端口数量限制:10M带宽下可用15口。15口共享10Md带宽 集线…...
mybatis 某些特殊的 ORA-00979:not a GROUP BY expression
打印的日志sql执行都是正常的 但是 就是报ORA-00979: not a GROUP BY expression 可能是 GROUP BY中不能使用动态参数 或特殊方法 使用 硬编码可以解决问题 <if test"statisticsInVo.timeTypeSql!null and statisticsInVo.timeTypeSql yyyy">TO_CHAR(CARD_T…...
基于OpenCV的图像处理程序设计实践
一.安装OpenCV3.x # 安装依赖 sudo apt update sudo apt install build-essential cmake git libgtk2.0-dev pkg-config libavcodec-dev libavformat-dev libswscale-dev# 下载OpenCV源码 git clone https://github.com/opencv/opencv.git -b 3.4 cd opencv mkdir build &…...
DeepSeek 全套汇总资料pdf免费下载(最新更新8篇)
DeepSeek 全套汇总资料pdf目前仍然在持续更新中,今天更新了8篇,合计的汇总都在这里了,有需要的朋友可以直接去下载了。 后续更新请关注文章:DeepSeek 全套汇总资料pdf免费下载(持续更新) _ 潘子夜个人博客…...
前端面试题(六):HTTP和HTTPS的区别以及他们如何保障数据安全
HTTP(HyperText Transfer Protocol)和HTTPS(HyperText Transfer Protocol Secure)都是用于在互联网上传输数据的协议,但它们之间有一个重要的区别:安全性。 1. HTTP(超文本传输协议)…...
Buffer Pool 的核心作用与工作机制
Buffer Pool 的核心作用与工作机制 1. Buffer Pool 是什么? Buffer Pool 是 InnoDB 存储引擎的核心内存区域,用于 缓存磁盘中的数据页。 作用:通过内存缓存减少直接磁盘 I/O,加速数据库的读写操作。默认大小:通常设…...
使用uglifyjs对静态引入的js文件进行压缩
前言 因为有时候js文件没有npm包,或者需要修改,只能引入静态的js,那么这个时候就可以对js进行压缩了。我其实想通过vite、webpack等插件进行压缩的,可是他都不能定位到public目录下面的文件,所以我只能自己压缩了。编…...
Vue 3 的<Teleport>功能与用法
Vue 3 的 <Teleport> 功能与用法 1. 基本用法 <Teleport> 是 Vue 3 的一个内置组件,允许将组件的内容渲染到 DOM 中的任意位置,而不改变其逻辑结构。以下是基本用法: 定义目标 DOM 元素:<div id"teleport-…...
2025 年江苏交安安全员考试:借助本地培训资源提升能力
江苏拥有丰富的教育和培训资源,为交安安全员备考提供了有力支持。考生可关注本地专业培训机构开设的交安安全员培训课程,这些课程往往由经验丰富的讲师授课,他们熟悉本地考试特点和行业实际需求。课程内容不仅涵盖考试大纲的知识点࿰…...
Umi Max 和 Ant Design Pro 的区别
1、前言: Ant Design Pro Umi Max Umi Max 和 Ant Design Pro 其实关系很紧密,但用途不同、定位不同。 我们一起来搞清楚它们的区别、联系、使用场景👇 2、一句话总结 名称作用Umi Max是现代前端框架,用来构建中后台项目&#x…...
《 Scikit-learn与MySQL的深度协同:构建智能数据生态系统的架构哲学》
在机器学习工程实践中,数据存储与模型训练的割裂始终是制约算法效能的关键瓶颈。Scikit-learn作为经典机器学习库,其与MySQL的深度协同并非简单的数据管道连接,而是构建了一个具备自组织能力的智能数据生态系统。这种集成突破了传统ETL流程的…...
无公网实体服务器加装多个操作系统供多个用户互不打扰使用_part1
背景介绍 因笔者业务需求,入手了一个实体服务器,但为了避免出现在一个操作系统中搭建编程环境后有许多相关的进程和服务,拖慢日常的使用,也能让其他人短期使用,更好的利用服务器的性能,让服务器专注于“什…...
C#调用Lua方法1+C#调用Lua方法2,3
xLua中Lua调用C#代码 原因:C#实现的系统,因为Lua可以调用,所以完全可以换成Lua实现,因为Lua可以即时更改,即时运行,所以游戏的代码逻辑就可以随时更改。 实现和C#相同效果的系统,如何实现&#…...
浅层神经网络:从数学原理到实战应用的全面解析
浅层神经网络:从数学原理到实战应用的全面解析 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,可以分享一下给大家。点击跳转到网站。 https://www.captainbed.cn/ccc 一、神经网络演进简史:浅层网络的奠…...
【深度学习:理论篇】--Pytorch基础入门
目录 1.Pytorch--安装 2.Pytorch--张量 3.Pytorch--定义 4.Pytorch--运算 4.1.Tensor数据类型 4.2.Tensor创建 4.3.Tensor运算 4.4.Tensor--Numpy转换 4.5.Tensor--CUDA(GPU) 5.Pytorch--自动微分 (autograd) 5.1.back…...
C++中数组的概念
文章目录 一、数组的定义二、什么是一维数组?2.1 一维数组的声明2.2 一维数组的初始化2.3 一维数组的使用 三、什么是一维数组的数组名?四、一维数组与指针的关系五、数组指针和指针数组的区别5.1 指针数组(array of pointers)5.2…...
996引擎-源码学习:Cocos2d-Lua 的 class(classname, ...)
996引擎-源码学习:Cocos2d-Lua 的 class(classname, ...) 一、核心方法调用顺序用户调用入口完整调用链二、__create 工厂方法的三种情形情形1:父类为函数(自定义工厂)情形2:父类为Cocos原生类情形3:父类为普通Lua表三、方法职责与内存管理对照表四、正确使用示例示例1…...
@linux系统SSL证书转换(Openssl转换PFX)
在Linux中,你可以使用OpenSSL工具将PFX/P12格式的证书转换为单独的CRT(证书)、KEY(私钥)文件以及提取证书链 1. 提取私钥文件(.key) openssl pkcs12 -in your_certificate.pfx -nocerts -out private.key -nodes系统会…...
flask返回json或者中文字符串不要编码
在 Flask 中返回中文字符串时,如果希望浏览器直接显示中文(而非编码后的 Unicode 转义字符如 \uXXXX),需确保以下两点: 正确设置 HTTP 响应的字符集(如 utf-8)。 避免 Flask 默认的 JSON 序列化转义中文字符。 以下是具体实现方法: 方法 1:直接返回纯文本(非 JSON) …...
打造船岸“5G+AI”智能慧眼 智驱力赋能客船数智管理
项目介绍 船舶在航行、作业过程中有着严格的规范要求,但在实际航行与作业中往往会因为人为的疏忽,发生事故,导致人员重大伤亡和财产损失; 为推动安全治理模式向事前预防转型,实现不安全状态和行为智能预警,…...
【Proteus仿真】【32单片机-A007】PT100热敏温度检测系统设计
目录 一、主要功能 二、使用步骤 三、硬件资源 四、软件设计 五、实验现象 联系作者 一、主要功能 1、LCD1602显示当前检测的温度值以及温度阈值 2、超过上限温度,降温模块启动 3、PT100热敏电阻测量-60C-135C 4、按键设置温度阈值 5、超过阈值࿰…...
MPDrive:利用基于标记的提示学习提高自动驾驶的空间理解能力
25年4月来自南方科技大学、百度、英国 KCL和琶洲实验室(广东 AI 和数字经济实验室)的论文“MPDrive: Improving Spatial Understanding with Marker-Based Prompt Learning for Autonomous Driving”。 自动驾驶视觉问答(AD-VQA)…...
PhotoShop学习08
1.应用滤镜 PhotoShop提供了很多滤镜,借助滤镜可以打造很多有趣的效果。滤镜可以通过点击菜单栏的滤镜,并选择滤镜库进入滤镜调整界面。 进入到滤镜库后,左侧是实时进行预览的图片,右侧可以选择滤镜效果,最右边可以调…...
Photoshop2025最新版v26超详细图文安装教程(附安装包)
前言 Photoshop是一款基于位图的图像处理软件,专注于对已有图像的编辑、修复、合成及特效制作。其核心功能包括图层管理、色彩校正、选区工具、滤镜效果等,支持多种颜色模型(如RGB、CMYK、CIELAB)和文件格式(如.PSD、…...
Plusar集群搭建-Ubuntu20.04-Winterm
1 背景 已经部署了Pulsar集群在生产上,新项目需要用到Pulsar。对Pulsar不熟,故搭建练手。 环境:Windows10vmwareUbuntu20.04,ssh工具使用的Winterm。 使用的是root账户,ubuntu防火墙都ufw disable了。 2 参考文档 集…...
Qt与C++数据类型转换
本文深入探讨Qt与C中相似但不同的数据类型处理技巧。 一、QString与std::string的相互转换 1. QString → std::string 方法1:使用toStdString()(推荐) QString qstr "你好,Qt世界"; std::string str qstr.toStdS…...
Excel处理控件Aspose.Cells指南:如何查看、编辑和删除 Excel 元数据
本文是如何使用Aspose.Cells的在线工具和编码解决方案查看、编辑和删除 Excel 元数据的综合指南。无论您是寻找快速Excel 元数据查看器的普通用户,还是寻求强大的Excel 元数据编辑器的开发人员,本指南都能满足您的需求。您可以选择使用简单的在线转换器来…...
Rust 在汽车 MCU 编程中的进展及安全特性剖析
在当今汽车行业,软件定义汽车的趋势正深刻改变着汽车的设计与用户体验。随着汽车电子系统复杂性的不断提升,对汽车微控制器(MCU)编程的安全性、可靠性和效率提出了更高要求。Rust 作为一种新兴的编程语言,凭借其独特的…...
Pytorch 第十四回:神经网络编码器——变分自动编解码器
Pytorch 第十四回:神经网络编码器——变分自动编解码器 本次开启深度学习第十四回,基于Pytorch的神经网络编码器。本回分享VAE变分自动编码器。在本回中,通过minist数据集来分享如何建立一个变分自动编码器。接下来给大家分享具体思路。 本次…...
hive排序函数
在 Hive 中,排序可以通过几种不同的方法来实现,通常依赖于 ORDER BY 或 SORT BY 等函数。这里简要介绍这几种排序方法: 1. ORDER BY ORDER BY 用于对结果集进行全局排序。它会将所有数据加载到一个节点进行排序,因此可能会导致性能问题,尤其是在数据量很大的时候。 语法…...
Android测试王炸:Appium + UI Automator2
Android平台主流开源框架简介 在Android平台上,有多个开源且好用的自动化测试框架。以下是几个被广泛使用和认可的框架: 1.1 Appium Appium是一个跨平台的移动测试工具,支持iOS和Android上的原生、混合及移动Web应用。 它使用了供应商提供的…...
用Python打造增强现实的魔法:实时对象叠加系统全解析
友友们好! 我是Echo_Wish,我的的新专栏《Python进阶》以及《Python!实战!》正式启动啦!这是专为那些渴望提升Python技能的朋友们量身打造的专栏,无论你是已经有一定基础的开发者,还是希望深入挖掘Python潜力的爱好者,这里都将是你不可错过的宝藏。 在这个专栏中,你将会…...
const let var 在react jsx中的使用方法 。
在 JavaScript 里,const 和 let 都是 ES6(ES2015)引入的用于声明变量的关键字,它们和之前的 var 关键字有所不同。下面为你详细介绍 const 和 let 的区别: 1. 块级作用域 const 和 let 都具备块级作用域,…...
C++隐式转换的机制、风险与消除方法
引言 C作为一门强类型语言,类型安全是其核心特性之一。 然而,隐式转换(Implicit Conversion)的存在既为开发者提供了便利,也可能成为程序中的“隐藏炸弹”。 一、隐式转换的定义与分类 1.1 什么是隐式转换…...
Python 为什么要保留显式的 self ?
当你在类中定义方法时,Python要求第一个参数必须表示当前对象实例。当你调用obj.method(),Python 本质上会将它转换为ClassName.method(obj)。 所以你需要通过self参数显式接收这个实例,才能访问该对象的属性和其他方法。如果不加self&#…...
Linux 性能调优之CPU认知
写在前面 博文内容为《性能之巅 系统、企业与云可观测性(第2版)》CPU 章节课后习题答案整理内容涉及: CPU 术语,指标认知CPU 性能问题分析解决CPU 资源负载特征分析应用程序用户态CPU用量分析理解不足小伙伴帮忙指正对每个人而言,真正的职责只有一个:找到自我。然后在心中…...
认识vue中的install和使用场景
写在前面 install 在实际开发中如果你只是一个简单的业务实现者,那么大部分时间你是用不到install的,因为你用到的基本上都是别人封装好的插件、组件、方法、指令等等,但是如果你需要给公司的架构做建设,install就是你避不开的一个…...
C++Cherno 学习笔记day17 [66]-[70] 类型双关、联合体、虚析构函数、类型转换、条件与操作断点
b站Cherno的课[66]-[70] 一、C的类型双关二、C的union(联合体、共用体)三、C的虚析构函数四、C的类型转换五、条件与操作断点——VisualStudio小技巧 一、C的类型双关 作用:在C中绕过类型系统 C是强类型语言 有一个类型系统,不…...
3.神经网络
神经网络 神经元与大脑 神经网络神经元的结构: 输入(Input):接收来自前一层神经元的信息。 权重(Weights):每个输入都有一个权重,表示其重要性。 加权和(Weighted Sum&a…...
CentOS 7安装Python3.12
文章目录 使用pyenv安装python3.12一、gitub下载pyenv二、升级GCC三.升级openssl这样python3.12.9就完成安装在CentOS上啦! 使用pyenv安装python3.12 一、gitub下载pyenv https://github.com/pyenv/pyenv 按照README,pyenv教程安装即可 二、升级GCC 安…...
微服务无感发布实践:基于Nacos的客户端缓存与故障转移机制
微服务无感发布实践:基于Nacos的客户端缓存与故障转移机制 背景与问题场景 在微服务架构中,服务的动态扩缩容、滚动升级是常态,而服务实例的上下线需通过注册中心(如Nacos)实现服务发现的实时同步。但在实际生产环境…...
5.2 自定义通知操作按钮(UNNotificationAction)
在本地推送通知中添加自定义操作按钮可以增强用户交互性,让用户无需打开应用就能执行一些快速操作。本节将详细介绍如何在SwiftUI应用中实现这一功能。 基本概念 UNNotificationAction 和 UNNotificationCategory 是UserNotifications框架中用于定义通知交互的核心…...
Python与链上数据分析:解锁区块链数据的潜力
Python与链上数据分析:解锁区块链数据的潜力 引言 区块链技术的兴起不仅改变了金融行业,也为数据分析领域带来了全新的机遇。链上数据(On-chain Data)是区块链网络中公开透明的交易记录和活动数据,它为我们提供了一个独特的视角,去观察用户行为、市场趋势以及网络健康状…...
数字化转型:未来已来,企业如何抢占先机?
近年来,“数字化转型”从一个技术热词逐渐演变为各行各业的“必选项”。无论是全球市场还是中国市场,数字化浪潮正以不可逆的姿态重塑商业生态。据IDC预测,到2028年,中国数字化转型市场规模将突破7300亿美元,全球投资规…...
Web3游戏全栈开发实战指南:智能合约与去中心化生态构建全解析
在GameFi市场规模突破千亿美元的当下,去中心化游戏系统开发正面临技术架构升级与生态融合的双重机遇。本文基于Solidity、Rust等多链智能合约开发经验,结合Truffle、Hardhat等主流框架,深度解析如何构建高性能、高收益的链游生态系统。 一、…...
Windows 图形显示驱动开发-WDDM 2.0功能_IoMmu 模型
概述 输入输出内存管理单元 (IOMMU) 是一个硬件组件,它将支持具有 DMA 功能的 I/O 总线连接到系统内存。 它将设备可见的虚拟地址映射到物理地址,使其在虚拟化中很有用。 在 WDDM 2.0 IoMmu 模型中,每个进程都有一个虚拟地址空间࿰…...