机器学习(五) -- 监督学习(8) --神经网络1

news/2024/9/13 9:19:40/文章来源:https://blog.csdn.net/zqx1473/article/details/140804834

机器学习系列文章目录及序言
深度学习系列文章目录及序言

上篇:机器学习(五) -- 无监督学习(2) --降维2
下篇:机器学习(五) -- 监督学习(8) --神经网络2


前言

tips:标题前有“***”的内容为补充内容,是给好奇心重的宝宝看的,可自行跳过。文章内容被“文章内容”删除线标记的,也可以自行跳过。“!!!”一般需要特别注意或者容易出错的地方。

本系列文章是作者边学习边总结的,内容有不对的地方还请多多指正,同时本系列文章会不断完善,每篇文章不定时会有修改。

由于作者时间不算富裕,有些内容的《算法实现》部分暂未完善,以后有时间再来补充。见谅!

文中为方便理解,会将接口在用到的时候才导入,实际中应在文件开始统一导入。


一、通俗理解及定义

1、神经网络的定义

        人工神经网络(artificial neural network,ANN),简称神经网络(neural network,NN)或类神经网络,是机器学习的子集,也是深度学习算法的支柱。是一种模仿生物神经网络(动物的中枢神经系统,特别是大脑)的结构和功能的数学模型或计算模型,用于对函数进行估计或近似。

        神经网络的最基本的构成单元是神经元(Neuron)。生物中,人的大脑中有上亿个神经元构成神经网络,生物神经网络中各个神经元之间相互连接,通过神经递质相互传递信息。如果某个神经元接收了足够多的神经递质(乙酰胆碱),那么其点位变会积累地足够高,从而超过某个阈值(Threshold)。超过这个阈值之后,这个神经元变会被激活,达到兴奋的状态,而后发送神经递质给其他的神经元。

        人工神经网络是受人脑生物神经网络结构和功能启发的计算模型,它由互连的节点(或称为“神经元”)组成,它们被组织成层,通过对输入进行加权计算总和以及应用非线性激活函数,将输入数据转换为不同的表示形式,直到产生输出。

(虽然人工神经网络模型类似生物神经网络,但人工神经网络的本质是函数拟合)

2、神经网络的结构

        神经网络主要由:输入层,隐藏层,输出层构成,每层由若干神经元组成。当隐藏层只有一层时,该网络为两层神经网络,由于输入层未做任何变换,可以不看做单独的一层(即两层神经网络为隐藏层+输出层,一般不包括输入层)。实际中,输入层的每个神经元代表了一个特征,输出层个数代表了分类标签的个数(在做二分类时,如果采用sigmoid分类器,输出层的神经元个数为1个,如果采用softmax分类器,输出层神经元个数为2个;如果是多分类问题,即输出类别>=3时,输出层神经元为类别个数),而隐藏层层数以及隐藏层神经元是由人工设定。一个基本的两层神经网络如下图:

        设计一个神经网络时,输入层与输出层的节点数往往是固定的,中间层则可以自由指定;

        结构图里的关键不是圆圈(代表“神经元”),而是连接线(代表“神经元”之间的连接)。每个连接线对应一个不同的权重(其值称为权值),这是需要训练得到的。

3、神经网络的训练过程

        神经网络的训练过程主要包括前向传播(forward propagation),损失计算(loss calculation),反向传播(backpropagation)和参数更新(parameter update);这些步骤共同作用,使得神经网络能够从数据中学习并逐步提高其性能。

  1. 神经元模型:模拟生物神经元的信息处理过程
  2. 基本结构
    1. 输入层:接收来自外部的输入信号
    2. 隐藏层:对输入信号进行加工和处理
    3. 输出层:输出处理后的结果
  3. 神经元之间的连接:通过权重表示神经元之间的相互作用
  4. 激活函数:将神经元的输出转换为非线性的输出信号
  5. 前向传播:输入层数据从前向后,数据逐步传递至输出层
  6. 反向传播:损失函数开始从后向前,梯度逐步传递至第一层,用于权重更新,使网络输出更接近标签(反向传播原理:微积分中的链式求导法则)
  7. 损失函数(损失计算):衡量神经网络的输出与实际结果之间的差异
  8. 优化算法(参数更新):调整神经网络的参数以最小化损失函数

二、神经网络基础

1、神经元模型

1.1、生物神经元

        一个神经元通常具有多个树突,主要用来接受传入信息;一条轴突,轴突尾端有许多轴突末梢可以给其他多个神经元传递信息。轴突末梢跟其他神经元的树突产生连接,从而传递信号。这个连接的位置在生物学上叫做“突触”。

1.2、人工神经元

1.2.1、M-P模型

         神经元是构成神经网络的最基本单元(构件),因此首要任务是构造人工神经元模型。 

        神经元模型是一个包含输入,输出与计算功能的模型。输入可以类比为神经元的树突,而输出可以类比为神经元的轴突,计算则可以类比为细胞核 

        从生物神经元结构中抽象的神经元模型--M-P神经元模型(阈值加权和模型,即麦卡洛克-皮特斯模型(McCulloch-Pitts model),简称为M-P模型)

        神经元接收来自n个其他神经元传递过来的输入信号x(下图中x_1~x_n),这些信号通过带权重w(下图中w_1~w_n)连接(connection)进行传递,神经元将接收到的输入值按照权重叠加起来,并与当前神经元的阈值 θ (也叫偏置 b )进行比较,然后通过“激活函数f()(activation function)”向外表达输出,如下图所示。


 

        M-P模型工作原理:当所有的输入与对应的连接权重的乘积大于阈值\theta时,y输出为1,否则输出为0(理想状态,激活函数为阶跃函数)。即当w_{i}*x_{i}>\thetay=1;否则y=0 需要注意的是,x_{i} 也只能是0或1的值,而权重w_{i}\theta则根据需要自行设置。

1.2.2、M-P数学表达式

神经元数学计算模型

 

        数学上讲,可以将神经元写成如下形式:

 1.2.3、神经元的连接

下图是一个典型的神经元模型:包含有3个输入,1个输出,以及2个计算功能。

  注意中间的箭头线。这些线称为“连接”。每个上有一个“权值”。(先忽略偏置)

        连接是神经元中最重要的东西。每一个连接上都有一个权重。一个神经网络的训练算法就是让权重的值调整到最佳,以使得整个网络的预测效果最好。

        使用 x 表示输入,用 w 表示权值。连接的有向箭头表示:x 大小的信号 ,经过 w 加权后,信号的大小就变成了 x*w。
        这就是神经元模型中,每个有向箭头表示的是值的加权传递

        将神经元图中的所有变量用符号表示,其输出的计算公式如图右下:

神经元计算 

        Y是在输入和权值的线性加权和叠加了一个激活函数g的值。在MP模型里,函数g是sgn函数。

        将sum函数与sgn函数合并到一个圆圈里,代表神经元的内部计算。一个神经元可以引出多个代表输出的有向箭头,但值都是一样的。

  神经元可以看作一个计算与存储单元。计算是神经元对其的输入进行计算功能。存储是神经元会暂存计算结果,并传递到下一层。

        也就是如下所示的效果:

2、感知机(单层神经网络)

        感知机(Perceptron)是由两层神经元(输入层、输出层)所构成,是最简单的神经网络(单层神经网络,不算输入层)。输入层接收信号传递给输出层,输出层是M-P神经元。感知机也叫“阈值逻辑单元(threshold logic unit,TLU)”
(QvQ:其实就是M-P神经元,将原本的输入x换成了另一个神经元节点,而这个神经元不做计算)

或者这样

为体现到两个输出神经元权重的联系,改用如下下标,那么Y_1和Y_2的公式如图右下:

Y_1和Y_2的计算公式是线性代数方程组。因此可以用矩阵乘法来表达这两个公式,即:

        g(x*w)=Y

这就是神经网络中从前一层计算后一层的矩阵运算。

2.1、感知机实现逻辑运算

        M-P神经元模型表达式为,假设激活函数为阶跃函数sgn(x),则逻辑运算实现如下:

“与”(x_1∧x_2):令w_1=w_2=1,b=-2,则y=f(1·x_1+1·x_2-2),仅在x_1=x_2=1时,y=1。

x_1x_2令w_1=w_2=1,b=-2,
则y=sgn(1·x_1+1·x_2-2)
y
00y=sgn(-2)0
01y=sgn(1-2)=sgn(-1)0
10y=sgn(1-2)=sgn(-1)0
11y=sgn(1+1-2)=sgn(0)1

“或”(x_1x_2):令w_1=w_2=1,b=-0.5,则y=f(1·x_1+1·x_2-0.5),仅在x_1=1或x_2=1时,y=1。

x_1x_2令w_1=w_2=1,b=-0.5,
则y=sgn(1·x_1+1·x_2-0.5)
y
00y=sgn(-0.5)0
01y=sgn(1-0.5)=sgn(-1)1
10y=sgn(1-0.5)=sgn(-1)1
11y=sgn(1+1-0.5)=sgn(1.5)1

“非”(x_1):令w_1=-1,w_2=0,b=0.5,则y=f(-1·x_1+0·x_2+0.5),仅在x_1=1时,y=0,x_1=0时,y=1。

x_1x_2令w_1=-1,w_2=0,b=0.5,
则y=sgn(-1·x_1+0·x_2+0.5)=y=sgn(-1·x_1+0.5)
y
00y=sgn(0.5)1
01y=sgn(0.5)1
10y=sgn(-0.5)0
11y=sgn(-0.5)0

2.2、权重和阈值的学习

可看机器学习(五) -- 监督学习(6) --逻辑回归中的感知机部分。

        通过确定权重和阈值得到了可以进行逻辑运算的感知机,如果给定训练数据集,权重 w 和阈值θ(b也是一样的) 可通过学习得到。我们将 阈值 θ 可以看做是一个固定输入为 -1(或 1) 对应连接权重ω_0的“哑结点”(dummy node)。这样,可以将权重和阈值的学习简化为权重的学习。如下图所示:( j 表示第 j 个输出神经元,单个模型中可忽略)

        感知机的学习规则很简单,对于训练样本(x,y),若感知机当前的输出为y',则感知机的权重调整如下:

        其中,η∈(0,1)为学习率(learning rate)。若感知机对样本的预测正确的话,即y'=y,则感知机不发生任何变化。若其预测错误,则根据错误的程度进行相应权重的调整。

        感知机中,只有输出层神经元进行激活函数的处理,即感知机只有一层功能神经元(Functional Neuron),其学习能力非常有限。实际上,感知机实现的逻辑运算都是线性可分问题。若两类模式是线性可分的,那么存在一个线性超平面能将其分开(如下图a-c所示),则感知机的学习过程一定会收敛从而得到合适的权向量;否则,感知机在学习的过程中会产生震荡,从而无法得到稳定的权向量,使得感知机无法求解。感知机无法解决像是“异或XOR”这样的非线性问题。(如下图d所示):

感知器类似一个逻辑回归模型,可以用于解决如下线性分类问题:

3、多层神经网络(多层感知机)

        多层神经网络(多层感知机,MLP, Multi-Layer Perceptron),要解决非线性可分问题,需考虑使用多层功能神经元,如下,输出层输入层之间还含有多层隐藏层(隐含层,hidden layer),隐藏层和输出层的神经元都是拥有激活函数的功能神经元。

3.1、结构

输入层:接收输入信号的层
输出层:产生输出信号的层
隐藏层:不直接与外部环境打交道(隐藏层的层数可从零到若干层)

3.1.1、输入层

        接收来自外部的数据并将其传递到网络的下一层,输入层本身并不进行任何计算或变换,它只是简单地将输入数据传递给隐藏层的每个神经元;输入层的每个节点(或称为神经元)代表一个输入特征,在输入层中,这些特征通常被表示为一个向量。

        每个输入特征 x_i 都会连接到隐藏层中的每个神经元,这些连接被称为权重(weights),用 w_i,j 表示,其中 i 表示输入特征的索引,j 表示隐藏层神经元的索引。

        在输入层和隐藏层之间的连接中,每个输入特征 x_i 都会乘以一个权重 w_i,j,然后将所有乘积相加,再加上一个偏置项 b_j ,这个过程可以用以下公式表示:

        输入层的设计和配置在很大程度上取决于具体的应用场景和数据类型(例如,在处理图像数据时,输入层的节点数通常等于图像的像素数;在处理文本数据时,输入层的节点数可能等于词汇表的大小或词向量的维度。),输入层本身不进行复杂的计算,但它的设计和配置对整个神经网络的性能和效果有着重要的影响;通过合理地选择和预处理输入特征,可以显著提高神经网络的学习能力和泛化能力。

3.1.2、隐藏层

        隐藏层通过一系列的权重和偏置参数,将输入特征进行非线性变换,从而提取出更高层次的特征;这些特征能够更好地表示输入数据的复杂模式和结构,每个隐藏层的节点(或称为神经元)接收来自前一层的输入,通过加权求和激活函数的作用,生成新的输出,这些输出将作为下一层的输入,继续进行处理。

        隐藏层常见的激活函数包括Sigmoid函数,Tanh函数和ReLU函数等;激活函数的选择会影响网络的训练效果和收敛速度,隐藏层的输出可以表示为:

        其中,W^[1] 是隐藏层的权重矩阵,b^[1] 是偏置向量,g 是激活函数,X 是输入特征矩阵。通过这种方式,隐藏层将输入特征进行非线性变换,生成新的特征表示。

        在一个典型的神经网络中,隐藏层的数量和每层中的神经元数量是设计网络结构时需要考虑的重要参数;隐藏层的数量和每层神经元的数量越多,网络的表达能力越强,但同时也增加了计算复杂度和过拟合的风险;因此,在设计神经网络时,需要在表达能力和计算复杂度之间找到一个平衡点。

        隐藏层通过复杂的非线性变换,提取出输入数据的深层次特征,从而使得神经网络能够处理复杂的任务,如图像识别,自然语言处理等;在实际应用中,合理设计隐藏层的结构和参数,是构建高效神经网络的关键。

3.1.3、输出层

        主要功能是生成最终的预测值;输出层的节点数量取决于具体的任务类型(如,二分类问题中,输出层通常只有一个节点,该节点的输出值可以通过一个阈值来决定分类结果;在多分类问题中,输出层可能包含多个节点,每个节点对应一个类别,最终的分类结果由输出值最大的节点决定;此外,在回归问题中,输出层的节点数量也可能是一个,输出的值直接作为预测结果。)。

        输出层的激活函数选择也是一个关键因素。常见的激活函数包括Sigmoid函数,Softmax函数和线性激活函数等;对于二分类问题,Sigmoid函数是一个常见的选择,因为它可以将输出值压缩到0到1之间,方便进行概率解释;而对于多分类问题,Softmax函数则更为适用,它可以将多个输出节点的值转换为概率分布,使得每个节点的输出值都在0到1之间,并且所有节点的输出值之和为1;对于回归问题,线性激活函数通常是首选,因为它可以输出任意实数值。

        输出层的设计还包括如何处理输出值与真实值之间的误差;在训练过程中,输出层的输出值会与真实值进行比较,计算出误差(也称为损失);常见的损失函数包括均方误差(MSE),交叉熵损失等;损失函数的选择取决于具体的任务类型和输出层的激活函数(如,回归问题,均方误差是一个常见的选择;对于分类问题,交叉熵损失则更为适用)。

        在误差计算完成后,神经网络会通过反向传播算法(Backpropagation)将误差传递回去,调整网络中的权重和偏置,以减少误差,提高模型的准确性;反向传播算法的核心思想是利用梯度下降法,通过计算损失函数对每个参数的偏导数,逐步调整参数,使得损失函数值逐渐减小。

        输出层不仅负责生成最终的预测结果,还在训练过程中通过误差反馈机制帮助网络不断优化参数,提高模型的性能。

tips:
  1. 神经网络又叫多层感知器(MLP,Multi-Layer Perceptron),虽然叫“多层”,但MLP一般都指的是两层(带一个隐藏层的)神经网络。
  2. 损失函数(loss function) = 残差函数(error function) = 代价函数(cost function);都是优化问题所需要求解的方程(可以暂时这样理解,损失和代价有一点点差别,后面会说)。
  3. 参数(parameter)、权重(weight)和偏置(bias):一般将训练得到的参数称之为权重(其他机器学习方法直接称为参数),更一般的说法非偏置节点连接上的值称之为权重,而偏置节点上的值称之为偏置,两者统一起来称之为参数。
  4. 激活函数(active function) = 转移函数(transfer function);都是叠加的非线性函数的意思。

3.3、前向传播(计算方式)

         两层神经网络中权值矩阵增加到了两个,用上标来区分不同层次之间的变量,同时记得加入偏置(阈值),将其定义为输入值默认为 1 ,权重为 b 的节点(即x_0=1,w_1,0=b)来表示,如下图所示,,同时给出计算公式如图右下:

使用矩阵运算来表达整个计算公式如下:

 g(W^(1) * x^(1)) = x^(2);

g(W^(2) * x^(2)) = Y

如下为详细解释:

 基本的两层神经网络

其中为输入层的值, 表示第 k 层中,第 i 个神经元的激活值(该神经元的输出), 表示第 k 层的神经元个数。当 k=1时即为输入层,即  ,而   为偏置项。

        为了求最后的输出值 ,我们需要计算隐藏层中每个神经元的激活值 。而隐藏层/输出层的每一个神经元,都是由上一层神经元经过类似逻辑回归计算而来。我们可以使用下图进行理解:

我们使用  来表示第 k 层的参数(边权),其中下标 j 表示第 k+1 层第 j 个神经元i 表示第 k 层第 i 个神经元。于是我们可以计算出隐藏层的三个激活值

            

再将隐藏层的三个激活值以及偏置项 用来计算出输出层神经元的激活值即为该神经网络的输出:

其中 g(z) 非线性变换函数(激活函数)

3.4、效果解析

        与单层神经网络不同。理论证明,两层神经网络可以无限逼近任意连续函数(复杂度由单元数确定)。

        输出层的决策分界仍然是直线。从输入层到隐藏层时,数据发生了空间变换。也就是说,两层神经网络中,隐藏层对原始的数据进行了一个空间变换,使其可以被线性分类,然后输出层的决策分界划出了一个线性分类分界线,对其进行分类。

        这样就导出了两层神经网络可以做非线性分类的关键--隐藏层。联想到我们一开始推导出的矩阵公式,我们知道,矩阵和向量相乘,本质上就是对向量的坐标空间进行一个变换。因此,隐藏层的参数矩阵的作用就是使得数据的原始坐标空间从线性不可分,转换成了线性可分。

        两层神经网络通过两层的线性模型模拟了数据内真实的非线性函数。因此,多层的神经网络的本质就是复杂函数拟合。

        在设计一个神经网络时,输入层的节点数需要与特征的维度匹配,输出层的节点数要与目标的维度匹配。而中间层的节点数,却是由设计者指定的。因此,“自由”把握在设计者的手中。但是,节点数设置的多少,却会影响到整个模型的效果。如何决定这个自由层的节点数呢?目前业界没有完善的理论来指导这个决策。一般是根据经验来设置。较好的方法就是预先设定几个可选值,通过切换这几个值来看整个模型的预测效果,选择效果最好的值作为最终选择。这种方法又叫做Grid Search(网格搜索)。

神经网络发展阶段:

神经网络表现力不断增强:

神经网络发展地外在因素:


旧梦可以重温,且看:机器学习(五) -- 无监督学习(2) --降维2
欲知后事如何,且看:机器学习(五) -- 监督学习(8) --神经网络2

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

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

相关文章

基于SSM+MySQL的医院在线挂号系统

系统背景 在当前数字化转型浪潮的推动下,医疗服务行业正经历着前所未有的变革。随着人口老龄化的加剧、患者就医需求的日益增长以及医疗资源分布不均等问题的凸显,传统的就医模式已难以满足患者对于便捷、高效医疗服务的需求。因此,构建一套基…

设计模式 —— 单例模式

文章目录 一、单例模式1.1 单例模式定义1.2 单例模式的优点1.3 单例模式的缺点1.4 单例模式的使用场景 二、普通案例2.1 饿汉式单例模式(Eager Initialization Singleton)2.2 懒汉式单例模式(Lazy Initialization Singleton) 参考资料 本文源代码地址为 java-demos/singeleton-…

探索未来科技发展:芯片设计的创新之路

在当今这个日新月异的数字时代,芯片设计作为信息技术的核心驱动力,正以前所未有的速度推动着社会进步与产业升级。作为科技领域的璀璨明珠,芯片设计不仅关乎数据处理的速度与效率,更是人工智能、物联网、云计算等技术得以实现的基…

Docker 详解及详细配置讲解

Docker 简介 2008 年LXC(LinuX Contiainer)发布,但是没有行业标准,兼容性非常差 docker2013年首次发布,由Docker, Inc开发 什么是 Docker Docker是管理容器的引擎,为应用打包、部署平台,而非单纯的虚拟化技术&#xf…

不小心删除丢失了所有短信?如何在 iPhone 上查找和恢复误删除的短信

不小心删除了一条短信,或者丢失了所有短信?希望还未破灭,下面介绍如何在 iPhone 上查找和恢复已删除的短信。 短信通常都是非正式和无关紧要的,但短信中可能包含非常重要的信息。因此,如果您删除了一些短信以清理 iPh…

Python画笔案例-032 绘制螺旋扇子

1、绘制螺旋扇子 通过 python 的turtle 库绘螺旋扇子图,如下图: 2、实现代码 绘制螺旋扇子,以下为实现代码: """螺旋扇子.py """ import turtle from coloradd import * # 从coloradd命令导…

win12R2安装.NET Framework 3.5

一丶安装原因 因此插件的缺失, 有些软件或系统不支持安装. 二丶安装步骤 1丶下载.NET Framework 3.5 点击插件下载, 提取码: 1995, 下载完成之后解压到想要安装的位置上. 2丶打开 服务器管理器 3丶点击: 管理 -> 添加角色和功能 4丶点击下一步到服务器角色, 选择web服…

版本控制的核心:Git中的哈希与默克尔树解析

Git是最常用的代码版本控制工具。它帮助我们跟踪代码的更改、管理代码版本,同时保证代码库的完整性和安全性。我们知道 Git 中有一些基本的操作,比如commit、merge、rebase等,但这些操作的底层机制是如何实现的呢?哈希函数和默克尔…

计算机毕业设计Spark+PyTorch知识图谱房源推荐系统 房价预测系统 房源数据分析 房源可视化 房源大数据大屏 大数据毕业设计 机器学习

《SparkPyTorch知识图谱房源推荐系统》开题报告 一、选题背景与意义 1.1 选题背景 随着互联网的快速发展和大数据技术的广泛应用,房地产行业特别是房屋租赁市场迎来了前所未有的变革。房源信息的海量增长使得用户在寻找合适的房源时面临巨大挑战。传统的房源推荐…

电路分析 ---- 电平移位电路

1 电平移位电路 如图所示的电平移位电路,用于ADC的前级驱动,它将一个变化范围为-10V ~ 10V的输入信号,线性变化成0.048V ~ 4.048V的信号,以满足ADC的输入范围要求。 2 电路说明 V R E F V_{REF} VREF​为电压基准源&#xff0c…

开源软件指南

目录 什么是开源软件 开源软件的历史和哲学 什么是开源许可证 开源许可证的类型 ​编辑 开源合规性 版权和知识产权合规性 安全合规性 什么是开源软件政策 开源软件安全 库存和软件物料清单(SBOM) 依赖项更新 开源漏洞扫描 二进制存储库管理器 开源软件的当前趋势…

轻量级模型解读——MobileNet系列

MobileNet系列到现在2024年,已经出到了第四个版本,分别如下: 2017年MobileNetv1——>2018年MobileNetv2——>2019年MobileNetv3——>2024年MobileNetv4,下面简要概述一下几个版本的改进部分。 目录 1、MobileNetv12、Mob…

聊聊Redis分布式锁的八大坑

前言 在分布式系统中,由于redis分布式锁相对于更简单和高效,成为了分布式锁的首先,被我们用到了很多实际业务场景当中。 但不是说用了redis分布式锁,就可以高枕无忧了,如果没有用好或者用对,也会引来一些…

JavaEE-HTTPHTTPS

目录 HTTP协议 一、概念 二、http协议格式 http请求报文 http响应报文 URL格式 三、认识方法 四、认识报头 HTTP响应中的信息 HTTPS协议 对称加密 非对称加密 中间人攻击 解决中间人攻击 HTTP协议 一、概念 HTTP (全称为 "超⽂本传输协议") 是⼀种应⽤…

k8s配置

一、前期准备 1、修改主机的/etc/hosts文件挟持域名 [rootk8s-master ~]# vim /etc/hosts 192.168.8.199 k8s-master 192.168.8.200 k8s-node1 192.168.8.201 k8s-node2 2、配置yum源 [rootk8s-master ~]# cd /etc/yum.repos.d/ [rootk8s-master yum.repos.d]# vim kubernetes…

最新实践!如何基于 DB-GPT 搭建财报分析助手?

DB-GPT 财报分析助手 精准解析数据 实现智慧决策 背景 最近,利用大模型进行财务报表分析正逐渐成为垂直领域的一个热门应用。大模型能够比人类更准确地理解复杂的财务规则,并在基于专业知识的基础上输出合理的分析结果。然而,财务报表信…

web3.0区块链元宇宙是什么

Web3.0 什么是 Web3.0 Web3.0是指基于区块链的去中心化在线生态系统,代表了互联网的下一个阶段。它是由以太坊联合创始人Gavin Wood在2014年创造的概念。Web3.0的发展是随着用户权利的增加和在互联网中角色的重要性不断进化的。 从互联网的发展历程来看&#xff0…

opencv之形态学

文章目录 1. 什么是形态学2. 形态学操作2.1 腐蚀2.2 膨胀2.3 通用形态学函数2.4 开运算2.5 闭运算2.6 形态学梯度运算2.7 礼帽运算2.8 黑帽运算 1. 什么是形态学 在图像处理领域,形态学是一种基于形状的图像分析技术,用于提取和处理图像的形态特征。这包…

【科研绘图】【风筝图】:附Origin详细画图流程

目录 No.1 理解风筝图 1 什么是风筝图 2 解读风筝图 No.2 画图流程 1 导入数据,绘制图形 2 设置绘图细节 3 设置坐标轴 4 效果图 No.1 理解风筝图 1 什么是风筝图 风筝图,也称为点图或散点图的一种变体,在生态学和环境科学中&#x…

win10本地设置无密码远程桌面登录设置

win10本地设置无密码远程桌面登录