当前位置: 首页 > news >正文

Python | 机器学习中最常用的超参数及使用示例

在机器学习中,超参数是用于控制机器学习模型训练过程的外部配置。它们是在训练开始之前配置的设置参数,并在整个过程中保持不变。您应该了解一些常用于优化机器学习模型的超参数。本文将带您了解机器学习中最常用的超参数以及如何在Python中使用它们。

机器学习中最常用的超参数

下面是你应该知道的机器学习中最常用的超参数列表:

  1. Learning Rate - 学习率
  2. Number of Epochs - “迭代次数"或"训练轮数”
  3. Batch Size - 批量大小
  4. Regularization Parameter - 正则化参数
  5. Max Depth - 最大深度
  6. Number of Trees (n_estimators) - 树的个数

现在,让我们详细了解所有这些最常用的超参数,以及如何在Python中使用它们。

1. Learning Rate - 学习率

学习率是一个超参数,它控制着模型在训练过程中优化参数时所采取的步骤的大小。它本质上决定了模型从数据中学习的速度或速度。学习率对于任何基于梯度的优化算法都是至关重要的,特别是在神经网络和深度学习模型中。它总是在训练阶段使用,以基于损失函数的梯度迭代地调整模型的权重。

学习率通常是一个小的正值,通常在0.0001到1的范围内。常用的值有:

  • 0.0001
  • 0.001
  • 0.01
  • 0.1

最佳学习率可以根据特定的模型、数据集和问题而变化。它通常通过实验或使用超参数调优方法(如网格搜索或随机搜索)找到。下面是如何在使用神经网络架构时使用此参数的示例:

from keras.models import Sequential
from keras.layers import Dense
from keras.optimizers import Adam
import numpy as np# hypothetical data
X_train = np.random.rand(100, 10)
y_train = np.random.randint(2, size=(100, 1))# model
model = Sequential()
model.add(Dense(12, input_dim=10, activation='relu'))
model.add(Dense(1, activation='sigmoid'))# compile with a specific learning rate
optimizer = Adam(learning_rate=0.001)
model.compile(loss='binary_crossentropy', optimizer=optimizer, metrics=['accuracy'])

2. Number of Epochs - 迭代次数

epochs的数量是一个超参数,它定义了在训练过程中通过整个训练数据集的完整次数。在每个时期,模型根据训练数据学习和更新其权重。epoch越多,模型从数据中学习的越多,尽管如果epoch的数量太高,则存在过拟合的风险。

epochs的数量在训练神经网络和其他迭代算法中特别重要,其中模型随着每个epoch而逐渐改进。找到一个平衡点是至关重要的:太少的时期可能导致欠拟合(模型没有学习足够的知识),而太多的时期可能导致过拟合(模型已经学习了太多,包括噪音)。

epoch的最佳数量取决于具体问题、模型的复杂性和数据集的大小。epoch的常见范围和值为:

  • 10 - 50 epoch:通常用于较简单的模型或训练时间受限的情况。
  • 50 - 200 epoch:适用于中等复杂的模型和中等规模的数据集。
  • 200 - 1000+ epoch:用于更复杂的模型,如深度神经网络和更大的数据集。

下面是一个使用Python使用这个超参数的例子:

model.fit(X_train, y_train, epochs=50, batch_size=10)

3. Batch Size - 批量大小

在上面的代码中,你可以看到也使用了批量大小超参数。批量大小是一个超参数,它定义了在一次迭代中用于更新模型参数的训练样本的数量。在训练过程中,不是一次处理整个数据集(这是计算密集型的),而是将数据集划分为较小的批次。模型在每个批次之后更新其权重。

批量大小在训练神经网络和其他迭代算法中至关重要,其中模型是逐步更新的,而不是一次全部更新。影响训练的速度和稳定性。

最佳批处理大小取决于数据集、模型和可用的计算资源。批量的常见范围和值为:

  • 1 - 32:通常用于小数据集或内存受限时。
  • 32 - 128:适合于内存使用和计算效率之间的平衡。
  • 128 - 1024+:用于大型数据集,并且有足够的内存来处理更大的批处理。

4. Regularization Parameter - 正则化参数

正则化参数通常表示为lambda(λ)或alpha(α),是一个超参数,用于通过向损失函数添加惩罚来防止过拟合。这种惩罚阻止了模型拟合训练数据中的噪声,从而提高了模型对未知数据的泛化能力。

正则化技术通常包括L1正则化(Lasso),L2正则化(Ridge)或两者的组合(Elastic Net):

  • L1正则化(Lasso):将系数的绝对值作为惩罚项添加到损失函数中。
  • L2正则化(岭):将系数的平方值作为惩罚项添加到损失函数中。
  • Elastic Net:合并L1和L2惩罚。

当训练容易过拟合的模型时,正则化参数至关重要,特别是在高维空间或有噪声的数据中。它通常用于回归模型,神经网络和支持向量机。

正则化参数的最佳值取决于数据集和具体问题。正则化参数的常见范围和值是:

  • 0 - 0.1:通常用于轻度正则化,以允许模型更紧密地拟合数据,但有轻微的惩罚以防止过度拟合。
  • 0.1 - 1:适合适度正则化,以平衡拟合和惩罚,从而提高泛化能力。
  • 1 - 10:用于强正则化,这显著限制了模型的复杂性,可以帮助处理非常嘈杂的数据或高维数据集。

下面是在Python中使用此参数的示例:

from sklearn.linear_model import Ridgemodel = Ridge(alpha=1.0)

5. Max Depth - 最大深度

决策树和基于树的集成方法中的最大深度参数控制树的最大深度。树的深度是从根节点到叶节点的最长路径。限制最大深度有助于通过限制树的复杂性来防止过拟合。较浅的树捕获较少的细节并更好地概括,而较深的树捕获更多的细节并有过度拟合训练数据的风险。

在使用决策树和基于树的集成方法(如随机森林,梯度提升,XGBoost,LightGBM和CatBoost)时,最大深度至关重要。它有助于控制模型的复杂性并提高泛化能力。

最大深度的最佳值取决于数据集和特定问题。最大深度的常见范围和值为:

  • 1 - 10:适用于较简单的数据集或需要高级别泛化的情况。
  • 10 - 30:适合中等复杂的数据集。
  • 30 - 100:用于非常复杂的数据集,但需要小心避免过度拟合。

以下是如何在决策树分类器中设置最大深度:

from sklearn.tree import DecisionTreeClassifier# example dataset
X_train = np.random.rand(100, 10)
y_train = np.random.randint(2, size=100)# define the model with max depth
model = DecisionTreeClassifier(max_depth=5)
model.fit(X_train, y_train)

6. Number of Trees (n_estimators) - 树的个数

树的数量或n_estimators是一个超参数,用于集成方法,如Random Forest,Gradient Boosting Machines,XGBoost,LightGBM和CatBoost。它指定要在集合中生长的单个树的数量。每棵树都有助于最终的预测,增加树的数量通常会通过减少方差和防止过拟合来提高模型性能。然而,它也增加了计算成本和训练时间。

树的数量在集成方法中至关重要,因为它直接影响模型的泛化能力和鲁棒性。增加树的数量通常会提高性能,但存在一个收益递减点,即额外的树提供的收益最小。

树的最佳数量取决于数据集和具体问题。n_estimators的常见范围和值为:

  • 10 - 100:适用于较简单的模型或计算资源有限的情况。
  • 100 - 500:通常是性能和计算成本之间的良好平衡。
  • 500 - 1000+:用于更复杂的数据集或需要更高精度时。

以下是如何在随机森林分类器中设置n_estimators:

from sklearn.ensemble import RandomForestClassifier# define the model with a specified number of trees
model = RandomForestClassifier(n_estimators=100)
model.fit(X_train, y_train)

总结

这些超参数的选择通常依赖于具体问题、数据集的特性以及模型的类型。超参数调优是一个迭代的过程,通常需要多次实验来找到最佳的参数组合。

相关文章:

Python | 机器学习中最常用的超参数及使用示例

在机器学习中,超参数是用于控制机器学习模型训练过程的外部配置。它们是在训练开始之前配置的设置参数,并在整个过程中保持不变。您应该了解一些常用于优化机器学习模型的超参数。本文将带您了解机器学习中最常用的超参数以及如何在Python中使用它们。 …...

本地部署DeepSeek R1大数据模型知识库

DeepSeek-V3 的综合能力 DeepSeek-V3 在推理速度上相较历史模型有了大幅提升。在目前大模型主流榜单中,DeepSeek-V3 在开源模型中位列榜首,与世界上最先进OpenAI 闭源模型不分伯仲。 1、下载Ollama运行大数据库 Ollama支持 Llama 3.3, DeepSeek-R1, Phi-…...

【C++】C++入门基础

C(C plus plus) 是一种计算机高级程序设计语言,既可以进行 C语言 的过程化程序设计,又可以进行以抽象数据类型为特点的基于对象的程序设计,还可以进行以继承和多态为特点的面向对象的程序设计。 文章目录 前言一、C 的…...

【Linux文件IO】标准IO详情(1)

目录 一、前言 1.1 文件类型 1.2 流(FILE)介绍 1.3 文本流和二进制流的区别 二、相关API介绍 2.1 fopen 2.2 fclose 2.3 perror 2.4 fgetc 2.5 fputc 2.6 fgets 2.7 fputs 2.8 fread 2.9 fwrite 一、前言 标准IO基于系统IO实现,通过缓冲机制减少系统调…...

店匠科技携手 PayPal 升级支付体验,助力独立站商家实现全球增长

在全球化电商竞争加剧的背景下,独立站为无数商户插上了通向事业成功的翅膀。然而,搭建店铺框架容易,真正实现有效运营却充满挑战。只有当各个环节如齿轮般严丝合缝,独立站运营才能更好地助推行进,实现稳健增长。如今,独立站商家面临着全链路运营的多重挑战。从品牌塑造、营销推…...

使用 Elastic-Agent 或 Beats 将 Journald 中的 syslog 和 auth 日志导入 Elastic Stack

作者:来自 Elastic TiagoQueiroz 我们在 Elastic 一直努力将更多 Linux 发行版添加到我们的支持矩阵中,现在 Elastic-Agent 和 Beats 已正式支持 Debian 12! 本文演示了我们正在开发的功能,以支持使用 Journald 存储系统和身份验…...

模板方法模式的C++实现示例

核心思想 模板方法设计模式是一种行为设计模式,它定义了一个算法的框架,并将某些步骤的具体实现延迟到子类中。通过这种方式,模板方法模式允许子类在不改变算法结构的情况下重新定义算法的某些步骤。 模板方法模式的核心在于: ​…...

docker无法pull镜像问题解决for win10

docker无法pull镜像问题解决for win10 问题原因分析解决方法 问题 在win10系统上安装好doker-desktop后ping registry-1.docker.io不同,并且也无法登陆hub.docker.com, 使用docker pull xx也无法正常下载 原因分析 hub.docker.com在2024年5月之后,国内…...

Docker数据管理,端口映射与容器互联

1.Docker 数据管理 在生产环境中使用 Docker,往往需要对数据进行持久化,或者需要在多个容器之间进行数据共享,这必然涉及容器的数据管理操作。 容器中的管理数据主要有两种方式: 数据卷(Data Volumns)&a…...

R语言使用scitable包交互效应深度挖掘一个陌生数据库

很多新手刚才是总是觉得自己没什么可以写的,自己不知道选什么题材进行分析,使用scitable包后这个完全不用担心,选题多到你只会担心你写不完,写得不够快。 今天演示一下使用scitable包深度挖掘一个陌生数据库 先导入R包和数据 li…...

复试难度,西电卓越工程师学院(杭研院)考研录取情况

01、卓越工程师学院各个方向 02、24卓越工程师学院(杭研院)近三年复试分数线对比 PS:卓越工程师学院分为广研院、杭研院 分别有新一代电子信息技术、通信工程、集成电路工程、计算机技术、光学信息工程、网络信息安全、机械,这些…...

STM32之I2C硬件外设

注意:硬件I2C的引脚是固定的 SDA和SCL都是复用到外部引脚。 SDA发送时数据寄存器的数据在数据移位寄存器空闲的状态下进入数据移位寄存器,此时会置状态寄存器的TXE为1,表示发送寄存器为空,然后往数据控制寄存器中一位一位的移送数…...

linux docker相关指令

1、镜像操作 0)、搜索:docker search 镜像名称 1)、拉取:docker pull 2)、推送:docker push 3)、查看:docker images 4)、查看所有镜像ID:d…...

信息安全之构建FTP服务器证书

以下是完整的文章,包含所有步骤和最后一节的参考文章部分: 在 Ubuntu 中安装和配置 FTPS 服务器的详细指南 1. 安装 vsftpd 首先,确保你的系统是最新的,然后安装 vsftpd: sudo apt update sudo apt install vsftpd•…...

(更新完)LPZero: Language Model Zero-cost Proxy Search from Zero

LPZero代码 摘要 神经架构搜索 (NAS) 有助于自动执行有效的神经网络搜索,同时需要大量的计算资源,尤其是对于语言模型。零样本 NAS 利用零成本 (ZC) 代理来估计模型性能,从而显着降低计算需求。然而,现有的 ZC 代理严重依赖于深…...

第六次CCF-CSP认证(含C++源码)

第六次CCF-CSP认证 数位之和(easy)思路及AC代码遇到的问题 开心消消乐(easy)思路及AC代码 画图(mid)思路及AC代码 数位之和(easy) 题目链接 思路及AC代码 既然题目要求我们输出各位…...

Spring Boot框架总结(超级详细)

前言 本篇文章包含Springboot配置文件解释、热部署、自动装配原理源码级剖析、内嵌tomcat源码级剖析、缓存深入、多环境部署等等,如果能耐心看完,想必会有不少收获。 一、Spring Boot基础应用 Spring Boot特征 概念: 约定优于配置&#…...

Dify平台部署记录

安装dify项目 官网地址:http://difyai.com/ github地址:https://github.com/langgenius/dify 下载项目: git clone https://github.com/langgenius/dify.git下载过慢,直接访问网页下载zip压缩包: 解压,…...

c++ 调用 gurobi 库,cmake,mac

gurobi 一般使用 python 调用,官方的培训会议及资料大部分也都基于 python。 由于最近上手了 c,因此想试试 c 怎么调用 gurobi。但我发现,c 调用第三方库比 python 或 java 要复杂不少。python 中直接 import 第三方库,java 加载…...

Redis 发布订阅模式详解:实现高效的消息通信

目录 引言 1. 什么是 Redis 发布订阅模式? 1.1 定义 1.2 核心概念 2. Redis 发布订阅的工作原理 2.1 基本流程 2.2 示例 2.3 频道与模式订阅 3. Redis 发布订阅的使用场景 3.1 实时消息通知 3.2 事件驱动架构 3.3 日志收集与分发 3.4 分布式锁与协调 4…...

React Native 0.76 升级后 APK 体积增大的原因及优化方案

在将 React Native 从 0.71 升级到 0.76 后,打包体积从 40 多 MB 增加到了 80 MB。经过一系列排查和优化,最终找到了解决方案,并将优化过程整理如下。 1. React Native 0.76 体积增大的可能原因 (1) 新架构默认启用 React Native 0.76 默认…...

Java直通车系列14【Spring MVC】(深入学习 Controller 编写)

目录 基本概念 编写 Controller 的步骤和要点 1. 定义 Controller 类 2. 映射请求 3. 处理请求参数 4. 调用业务逻辑 5. 返回响应 场景示例 1. 简单的 Hello World 示例 2. 处理路径变量和请求参数 3. 处理表单提交 4. 处理 JSON 数据 5. 异常处理 基本概念 Cont…...

文章被检测出是AI写的怎么办?

随着人工智能技术的飞速发展,AI辅助写作工具逐渐普及,为学生、科研人员以及创作者带来了诸多便利。然而,随之而来的是对学术诚信和内容原创性的担忧。当文章被检测出是AI写作时,应该如何应对?本文将探讨这一问题&#…...

Linux教学总目录

Linux教学总目录: 1、Linux常见指令 2、Linux权限理解 3、Linux环境基础开发工具使用...

SpringBoot(1)——创建SpringBoot项目的方式

目录 1、idea直接从spring.io官网下载即可 ​编辑2、 自己从spring官网下载再用idea打开 3、Idea从阿里云的官网(https://start.aliyun.com)下载打开 4、Maven项目改造成springboot项目 我的平台是idea2021 Spring Boot 由 Pivotal 团队开发&#xff…...

Oracle数据恢复:闪回查询

Oracle数据恢复:闪回查询 SQL语法闪回查询:AS OF闪回版本查询:VERSIONS BETWEEN数据恢复示例闪回查询最佳实践应用场景使用限制注意事项最佳实践在误删除业务数据时,Oracle数据库通常支持以下几种数据恢复途径。 闪回查询(Flashback Query):闪回查询通过查询系统的UNDO数…...

LiveCommunicationKit OC 实现

一、实现效果: ‌ LiveCommunicationKit‌是苹果公司在iOS 17.4、watchOS 10.4和visionOS 1.1中引入的一个新框架,旨在优化VoIP通话的交互体验。该框架提供了与...

django中路由配置规则的详细说明

在 Django 中,路由配置是将 URL 映射到视图函数或类视图的关键步骤,它决定了用户请求的 URL 会触发哪个视图进行处理。以下将详细介绍 Django 中路由配置的规则、高级使用方法以及多个应用配置的规则。 基本路由配置规则 1. 项目级路由配置 在 Django 项目中,根路由配置文…...

机器学习基础(4)

超越基于常识的基准 除了不同的评估方法,还应该利用基于常识的基准。训练深度学习模型就好比在平行世界里按下发射火箭的按钮,你听不到也看不到。你无法观察流形学习过程,它发生在数千维空间中,即使投影到三维空间中,…...

技术的魅力与价值

区块链技术正改变公益事业。它能极大提高公益透明度和公信力。通过区块链,每一笔捐款的流向都清晰可查,无法篡改,让捐赠者放心。比如某公益平台利用区块链记录捐赠信息,大家随时能看到善款使用情况。还有些项目用区块链追踪物资发…...

【报错】微信小程序预览报错”60001“

1.问题描述 我在微信开发者工具写小程序时,使用http://localhost:8080是可以请求成功的,数据全都可以无报错,但是点击【预览】,用手机扫描二维码浏览时,发现前端图片无返回且报错60001(打开开发者模式查看日…...

[数据结构]并查集--C++版本的实现代码

目录 并查集的基本框架 查找一个元素在哪一个集合 判断两个元素是否在同一个集合 将两个集合进行合并 查询有多少组 测试 大学班级的同学会来自于五湖四海,每个人的家乡可能都不相同,那么如何将相同省份的同学连接到一块,也就是按省份进…...

随机森林:强大的集成学习算法

引言 在机器学习领域,随机森林(Random Forest)是一种非常流行的集成学习算法。它通过构建多个决策树并将它们的结果进行集成,能够有效提高模型的准确性和鲁棒性。随机森林广泛应用于分类、回归、特征选择等任务,因其简…...

C# 实现 AI SSE (Server-Sent Events)接口方式输出(对接AI模型API)

以下是一个使用 C# 实现接收 SSE(Server-Sent Events)接口数据、进行数据修改解析,然后再以 SSE 方式输出给前端的示例代码。 using System; using System.IO; using System.Net; using System.Text; using System.Threading.Tasks; using M…...

企业招聘能力提升之道:突破困境,精准纳才

企业招聘能力提升之道:突破困境,精准纳才 在企业运营的广袤版图中,招聘工作无疑是一块至关重要的拼图。然而,不少企业在这片领域中举步维艰,尽管投入了海量的时间与精力,收获的成果却不尽人意。面试环节仿…...

[数据结构]堆详解

目录 一、堆的概念及结构 二、堆的实现 1.堆的定义 2堆的初始化 3堆的插入 ​编辑 4.堆的删除 5堆的其他操作 6代码合集 三、堆的应用 (一)堆排序(重点) (二)TOP-K问题 一、堆的概念及结构 堆的…...

KafkaRocketMQ

Kafka 消息生产与消费流程 1. 消息生产 生产者创建消息: 指定目标 Topic、Key(可选)、Value。可附加 Header 信息(如时间戳、自定义元数据)。 选择分区(Partition): 若指定 Key&am…...

DeepSeek Kimi详细生成PPT的步骤

以下是使用 DeepSeek 和 Kimi 协作生成 PPT 的详细步骤,结合了两者的优势实现高效创作: 第一步:使用 DeepSeek 生成 PPT 大纲或内容 明确需求并输入提示词 在 DeepSeek 的对话界面中,输入具体指令,要求生成 PPT 大纲或…...

HTTP和HTTPS

一.介绍HTTP HTTP全称为超文本传输协议,是一种应用非常广泛的应用层协议。目前,主流使用的HTTP版本是HTTP1.1和HTTP2.0,在这边文章中,讨论的是HTTP1.1。 使用浏览器,打开手机上的APP或者是后端程序,都是分布…...

应急响应--流量分析

(一)Cobalt Strike流量特征分析 1.HTTP特征 源码特征: 在流量中,通过http协议的url路径,在checksum8解密算法计算后,32位的后门得到的结果是92,64位的后门得到的结果是93,该特征符…...

docker 学习

在docker中通常需要使用ADD等命令复制附件,同时也需要使用其他命令操作原始镜像中的内容,会导致原文文件被覆盖后缺少执行权限,比如: sqlmapapi: ERROR (file is not executable) 或者XXX: ERROR (file is not execu…...

C++时间复杂度详解

一、时间复杂度核心概念 1.1 为什么要研究时间复杂度 当处理大规模数据时(如计算斐波那契数列第57项),不同算法效率差异巨大: 递推解法:0.23秒完成 递归解法:需要2369秒(约40分钟&#xff09…...

【WPF】Slider滑动方法(INotifyPropertyChanged、ValueChanged )响应速度对比分析

一、Slider基础用法 在 XAML 中添加一个 Slider 控件&#xff0c;并设置其基本属性&#xff1a; <Slider Minimum"0" <!-- 最小值 -->Maximum"100" <!-- 最大值 -->Value"50" <!-- 初始值 -->Width&quo…...

PgSql 操作技巧

1、查询数据导出csv数据 \COPY (SELECT w.* from t_sys_warn w ) TO /home/cuadmin/warn_output.csv WITH CSV HEADER;2、导出sql Insert语句 pg_dump -U 用户名 -h 主机名 -p 端口号 -d 数据库名 --inserts -t 表名 > 导出文件.sqlpg_dump -U username -d dbname -t tabl…...

高效自动化测试:打造Python+Requests+Pytest+Allure+YAML的接口测试框架

一、背景 在快节奏的开发周期中&#xff0c;如何确保接口质量&#xff1f;自动化测试是关键。通过构建标准化、可复用的测试框架&#xff0c;能显著提升测试效率与准确性&#xff0c;为项目质量保驾护航[1][7]。 二、目标 ✅ 核心目标&#xff1a; ● 实现快速、高效的接口测试…...

设计模式文章汇总-Golang语言实现

Golang学习笔记_27——单例模式 Golang学习笔记_28——工厂方法模式 Golang学习笔记_29——抽象工厂模式 Golang学习笔记_30——建造者模式 Golang学习笔记_31——原型模式 Golang学习笔记_32——适配器模式 Golang学习笔记_33——桥接模式 Golang学习笔记_34——组合模式 Gola…...

深度学习PyTorch之13种模型精度评估公式及调用方法

深度学习pytorch之22种损失函数数学公式和代码定义 深度学习pytorch之19种优化算法&#xff08;optimizer&#xff09;解析 深度学习pytorch之4种归一化方法&#xff08;Normalization&#xff09;原理公式解析和参数使用 深度学习pytorch之简单方法自定义9类卷积即插即用 实时…...

c#面试题整理4

1.stirng str"",string strnull&#xff0c;俩者有何区别 空字符串占有存储控件&#xff0c;null不占用 2.class与struct的异同 异同class 可继承 引用类型 1.都可以定义方法字段 2.都可实例化&#xff0c;与类的使用几乎一样 struct 不可继承 值类型 只能声明带…...

游戏辅助技术培训班教程【A001-初级班】

课程概述&#xff1a; 本教程为游戏辅助技术培训班的初级班课程&#xff0c;本章为第二阶段&#xff0c;旨在帮助学员系统掌握游戏辅助技术的核心技能。课程内容从C/C编程基础到高级内存操作、代码注入、DLL注入及MFC编程&#xff0c;全面覆盖游戏辅助开发的关键知识点。 课程…...

[NewStarCTF 2023 公开赛道]ez_sql1 【sqlmap使用/大小写绕过】

题目&#xff1a; 发现id处可以sql注入&#xff1a; 虽然输入id1;show databases;#没什么回显&#xff0c;但是知道这里是字符型注入了 这次利用sqlmap注入 --dbs&#xff1a;列出所有数据库名字 python .\sqlmap.py -u http://a40b2f0a-823f-4c99-b43c-08b94ed0abb2.node5.…...