Datawhale统计学习方法打卡Task02

news2024/9/23 7:27:14

学习教材《统计学习方法(第二版)》李航

学习内容:第1章 统计学习及监督学习概论

第2章 感知机

感知机(perceptron)是二类分类的线性分类模型。其输入为实例的特征向量,输出为实例的类别,取+1和-1二值。感知机对应于输入控件(特征空间)中将实例划分为正负两类的分离超平面,属于判别模型(对应于生成模型)。感知机学习旨在求出将训练数据进行线性划分的分离超平面,为此,导入基于误分类的损失函数,利用梯度下降法对损失函数进行极小化,求得感知机模型。

2.1感知机模型

定义:假设输入空间(特征空间)是\mathcal{X}\subseteq \mathbf{R}^n,输出空间是\mathcal{Y}=\{+1,-1\}。输入x\in \mathcal X表示实例的特征向量,对应于输入空间的点;输出y\in \mathcal Y表示实例的类别。由输入空间到输出空间的如下函数:

f(x)=sign(w\cdot x+b)

称为感知机。其中,wb为感知机模型参数,w\in \mathbf{R}^n叫做权值或权值向量,b\in \mathbf{R}叫做偏置,w\cdot x表示wx的内积。sign是符号函数,即

sign(x)=\left\{\begin{matrix} +1, &x\geq0 \\ -1,&x<0 \end{matrix}\right.

感知机是一种线性分类模型,属于判别模型。感知机模型的假设空间是定义在特征空间中的所有线性分类模型(linear classification model)或线性分类器(linear classifier),即函数集合\{f|f(x)=w\cdot x+b\}

几何解释:线性方程w\cdot x+b=0,对应于特征空间\mathbf{R}^n中的一个超平面S,其中w是超平面的法向量,b是超平面的截距。这个超平面将空间划分为两个部分。位于两部分的点被分为正负两类。因此超平面S称为分离超平面(separating hyperplane)

 以上图为例,假设线性方程为x^{(1)}+x^{(2)}-2=0

位于分离超平面S左侧的点(例如(0,0)点)是小于0的点,得到的分类结果是-1;

位于分离超平面S右侧的点(例如(2,2)点)是大于0的点,得到的分类结果是+1。

2.2感知机学习策略

2.2.1数据集的线性可分性

定义2.2(数据集的线性可分性)给定一个数据集

T=\{(x_1,y_1),(x_2,y_2),\cdots,(x_N,y_N)\}

其中,x_i\in \mathcal{X}y_i\in \mathcal{Y}=\{+1,-1\}, \;i=1,2,\cdots,N,如果存在某个超平面S

w\cdot x+b=0

能够将数据集的正实例点和负实例点完全正确的划分到超平面两侧,即对所有y_i=+1的实例i,有w\cdot x_i+b>0;对所有y_i=-1的实例i,有w\cdot x_i +b<0,则称数据集T为线性可分数据集;否则,称数据集T线性不可分。

2.2.2感知机策略

感知机的学习目标就是求得一个能够将训练集正实例点和负实例点完全正确分开的分离超平面。为了找出这样的超平面,即确定感知机模型参数w,b,需要确定一个学习策略,即定义(经验)损失函数并将损失函数最小化。

损失函数的一个自然选择时五分类点的总数。但这个函数不是w,b的连续可导函数,不以优化。所以选择误分类点到超平面的总距离。为此,首先写出输入输入空间\mathbf{R}^n中任一点x_0到超平面S的距离:

\frac{1}{||w||}|w\cdot x_0+b|

这里,||w||wL_2范数。

其次,对于误分类的数据(x_i,y_i)来说,

-y_i(w\cdot x_i+b)>0

此处的理解为:

正确分类时:y_i(w\cdot x_i+b)=sign(w\cdot x_i+b)*(w\cdot x_i+b)>0

                当(w\cdot x_i+b)>0时,则sign(w\cdot x_i+b)=1,则结果>0;

                当(w\cdot x_i+b)<0时,则sign(w\cdot x_i+b)=-1,结果>0

 以上为误分类的点,所以结果正好相反。

y_i(w\cdot x_i+b)=sign(w\cdot x_i+b)*(w\cdot x_i+b)<0

所以:-y_i(w\cdot x_i+b)>0

 因此误分类点x_i距离S的距离是

-\frac{1}{||w||}y_i(w\cdot x_i+b)

这样,假设超平面S的误分类点集合为M,那么所有误分类点到超平面S的总距离为

-\frac{1}{||w||}\sum_{x_i\in M}y_i(w\cdot x_i+b)

不考虑\frac{1}{||w||},就得到感知及学习的损失函数。

L(w,b)=-\sum_{x_i\in M}y_i(w\cdot x_i+b)

其中M为误分类点的集合。这个损失函数就是感知机学习的经验风险函数。

2.3感知机学习算法

感知机学习问题转化为求解损失函数(2.4)的最优问题。最优化的方法是随机梯度下降法。本届将原始形式和对偶形式,并证明在训练数据线性可分条件下感知机学习算法的收敛性。

2.3.1感知机学习算法的原始形式

给定一个数据集

T=\{(x_1,y_1),(x_2,y_2),\cdots,(x_N,y_N)\}

其中,x_i\in \mathcal{X}y_i\in \mathcal{Y}=\{+1,-1\}, \;i=1,2,\cdots,N,求参数w,b,使其为一下损失函数极小化问题的截

\underset{w,b}{min}L(w,b)=-\sum_{x_i\in M}y_i(w\cdot x_i+b)

其中M为误分类点的集合。

感知机学习算法是误分类驱动的,具体采用随机梯度下降法。具体步骤,首先任意选取一个超平面w_0,b_0,然后用梯度下降法不断地极小化目标函数。极小化过程中不是一次使用M汇总的所有误分类点的梯度下降,而是随机选取一个误分类点使其梯度下降。

假设误分类点集合M是固定的,那么损失函数L(w,b)的梯度由

\triangledown_wL(w,b)=-\sum_{x_i\in M}y_ix_i

\triangledown_bL(w,b)=-\sum_{x_i\in M}y_i

给出。

随机选取一个误分类点(x_i,y_i),对w,b进行更新:

\begin{aligned} w&\leftarrow w+\eta y_ix_i\\ b&\leftarrow b+\eta y_i \end{aligned}

式中\eta是步长,在统计学习中又称为学习率。这样,通过迭代可以期待损失函数L(w,b)不断缩小,直到为0。综上所述,得到如下算法:

算法2.1 感知机学习算法的原始形式

输入:训练数据集T=\{(x_1,y_1),(x_2,y_2),\cdots,(x_N,y_N),\}其中x_i\in\mathcal X=\mathbf R^n,y_i\in \mathcal Y=\{-1,+1\}i=1,2,\cdot,N;学习率\eta(0<\eta\leq1)

输出:w,b;感知机模型f(x)=sign(w\cdot x+b).

(1)选取初值w_0,b_0;

(2)在训练集中选取数据(x_i,y_i);

(3)如果y_i(w\cdot x_i+b)\leq0

\begin{aligned} w&\leftarrow w+\eta y_i x_i \\ b&\leftarrow b+\eta y_i \end{aligned}

(4)转至(2),直至训练集中没有误分类点。

例2.1 如图所示的训练数据集,正实例点是x_1=(3,3)^T,\;x_2=(4,3)^T,负实例点是x_3=(1,1)^T,用感知机学习算法的原始形式求感知机模型f(x)=sign(w\cdot x+b)。这里w=(w^{(1)},w^{(2)})^Tx=(x^{(1)},x^{(2)})^T

 解 构建最优化问题:

\underset{w,b}\min L(w,b)=-\sum_{x_i\in M}y_i(w\cdot x_i+b)

按照算法2.1求解w,b。取\eta=1

(1)取初值w_0=0,b_0=0

(2)对第一个点x_1=(3,3)^Ty_1(w_0\cdot x_1+b_0)=0,未能呗正确分类,更新w,b

\begin{aligned} w_1&=w_0+\eta y_1x_1=0+1*(3,3)^T=(3,3)^T\\ b_1&=b_0+\eta y_1=0+1=1 \end{aligned}

得到线性模型

w_1\cdot x+b_1=3x^{(1)}+3x^{(2)}+1

(3)对x_1,x_2,显然y_i(w_1\cdot x_i+b_1)>0,被正确分类,不修改w,b

由于w_1\cdot x_1+b_1=(3,3)^T\cdot (3,3)^T+1=19y_1=1

y_1(w_1\cdot x_1+b_1)>0成立

同理y_2(w_1\cdot x_2)+b_1>0成立

 但是对于x_3=(1,1)^Tw_1\cdot x_3+b_1=(3,3)^T\cdot (1,1)^T+1=7y_3=-1,则y_3(w_1\cdot x_3+b_3)<0,被误分类,更新w,b

w_2=w_1+y_3x_3=(3,3)^T+(-1)(1,1)^T=(2,2)^T

b_2=b_1+1*y_3=1-1=0

得到线性模型:

2x_1+2x_2=0

如此继续下去

迭代次数误分类点w_i\leftarrow w_{i-1}+\eta y_ix_ib_i\leftarrow b_{i-1}+\eta y_iwx+b
0000
1x_1\begin{aligned} w_1&=w_0+\eta y_1x_1\\ &=(0,0)^T+1*1*(3,3)^T\\ &=(3,3)^T \end{aligned}\begin{aligned} b_1&=b_0+\eta y_1\\ &=0+1*1\\ &=1 \end{aligned}3x^{(1)}+3x^{(2)}+1
2x_3\begin{aligned} w_2&=w_1+\eta y_3x_3\\ &=(3,3)^T+1*(-1)*(1,1)^T\\ &=(3,3)^T-(1,1)^T\\ &=(2,2)^T \end{aligned}\begin{aligned} b_2&=b_1+\eta y_3\\ &=1+1*(-1)\\ &=0\end{aligned}2x^{(1)}+2x^{(2)}
3x_3\begin{aligned} w_3&=w_2+\eta y_3x_3\\ &=(2,2)^T+1*(-1)*(1,1)^T\\ &=(2,2)^T-(1,1)^T\\ &=(1,1)^T \end{aligned}\begin{aligned} b_3&=b_2+\eta y_3\\ &=0+1*(-1)\\ &=-1 \end{aligned}x^{(1)}+x^{(2)}-1
4x_3\begin{aligned} w_4&=w_3+\eta y_3x_3 \\ &=(1,1)^T+1*(-1)*(1,1)^T \\ &=(1,1)^T-(1,1)^T \\ &=(0,0)^T \end{aligned}\begin{aligned} b_4&=b_3+\eta y_3 \\ &=-1+1*(-1) \\ &=-2 \end{aligned}-2
5x_1\begin{aligned} w_5&=w_4+\eta y_1x_1 \\ &=(0,0)^T+1*(1)*(3,3)^T \\ &=(0,0)^T+(3,3)^T \\ &=(3,3)^T \end{aligned}\begin{aligned} b_5&=b_4+\eta y_1 \\ &=-2+1*(1) \\ &=-1 \end{aligned}3x^{(1)}+3x^{(2)}-1
6

 x_3

\begin{aligned} w_6&=w_5+\eta y_3x_3 \\ &=(3,3)^T+1*(-1)*(1,1)^T \\ &=(3,3)^T-(1,1)^T \\ &=(2,2)^T \end{aligned}\begin{aligned} b_6&=b_5+\eta y_3 \\ &=-1-1*(1) \\ &=-2 \end{aligned}2x^{(1)}+2x^{(2)}-2
7

 x_3

\begin{aligned} w_7&=w_6+\eta y_3x_3 \\ &=(2,2)^T+1*(-1)*(1,1)^T \\ &=(2,2)^T-(1,1)^T \\ &=(1,1)^T \end{aligned}\begin{aligned} b_7&=b_6+\eta y_3 \\ &=-2+1*(-1) \\ &=-3 \end{aligned}x^{(1)}+x^{(2)}-3
80(1,1)^T-3x^{(1)}+x^{(2)}-3

 直到w_7=(1,1)^T, \;b_7=-3,对所有的数据点y_i(w_7\cdot x_i+b_7)>0,没有误分类点,损失函数达到极小。

分离超平面为x^{(1)}+x^{(2)}-3

感知机模型为:f(x)=sign(x^{(1)}+x^{(2)}-3)

2.3.2算法的收敛性

证明过程略

2.3.3感知机学习算法的对偶形式

输入:线性可分得数据集T=\{(x_1,y_1),(x_2,y_2),\cdots,(x_N,y_N)\},其中x_i\in\mathbf R^n,y_i\in{-1,+1},i=1,2,\cdots,N;学习率\eta(0<\eta\leq1)

输出:\alpha,b, 感知机模型f(x)=sign(\sum_{j=1}^N\alpha_jy_jx_j\cdot x+b),其中\alpha=(\alpha_1,\alpha_2,\cdots,\alpha_N)^T

 (1)\alpha\leftarrow 0, b\leftarrow 0;

 (2)在训练集中选取数据(x_i,y_i);

(3)如果y_i(\sum_{j=1}^N\alpha_jy_jx_j\cdot x_i+b)\leq 0

 \alpha_i\leftarrow \alpha_i+\eta

b\leftarrow b+\eta y_i

(4)转至(2)直到没有误分类数据。

对偶形式中训练实例仅以内积的形式出现,为了方便可以预先将训练集中实例间的内积计算出来并以矩阵的形式存储,这个矩阵就是所谓的Gram矩阵。

G=[x_i\cdot x_j]_{NN}

例2.2 同例2.1正样本是x_i=(3,3)^T,x_2=(4,3)^T负样本点是x_3=(1,1)^T,试用感知机学习算法对偶形式求感知机模型。

(1)取\alpha_i=0,i=1,2,3,\;b=0,\eta=1;

(2)计算Gram矩阵

G=\begin{bmatrix} 18&21&6\\ 21&25&7\\ 6&7&2\\ \end{bmatrix}

(3)误分条件

y_i(\sum_{j=1}^N\alpha_jy_jx_j\cdot x_i+b)\leq 0

更新参数

\begin{aligned} \alpha_i&\leftarrow \alpha_i+1\\ b&\leftarrow b+y_i \end{aligned} 

附视频讲解网址:21. 第三章第5节—感知机学习算法的对偶形式_哔哩哔哩_bilibili

自己的理解过程:

第0步:初始化\alpha=(\alpha_1,\alpha_2,\alpha_3)^T=(0,0,0)^T, \;b=0

第1步:x_1开始计算y_i(\sum_{j=1}^N\alpha_jy_jx_j\cdot x_i+b)\leq 0

\begin{aligned} &y_1(\sum_{j=1}^N\alpha_jy_jx_j\cdot x_i+b)\\ &=y_1[(\alpha_1y_1x_1+\alpha_2y_2x_2+\alpha_3y_3x_3)x_1+b]\\ &=1[(0+0+0)x_1+0]\\ &=0\leq0 \end{aligned}

符合条件。进行更新。

\begin{aligned} \alpha_1&\leftarrow\alpha_1+\eta=0+1=1\\ b&\leftarrow b+\eta y_1=0+1=1 \end{aligned}

计算

\begin{aligned} &y_2(\sum_{j=1}^N\alpha_jy_jx_j\cdot x_2+b)\\ &=y_2[(\alpha_1y_1x_1+\alpha_2y_2x_2+\alpha_3y_3x_3)x_2+b]\\ &=1[((1)(1)(3,3)^T+0+0)(4,3)^T+1]\\ &=(3,3)^T\cdot(4,3)^T+1=22\geq0 \end{aligned}

不更新

第2步:计算

\begin{aligned} &y_3(\sum_{j=1}^N\alpha_jy_jx_j\cdot x_3+b)\\ &=y_3[()(\alpha_1y_1x_1+\alpha_2y_2x_2+\alpha_3y_3x_3)x_3+b]\\ &=-1[(1)(1)(3,3)^T+0+0)(1,1)^T+1]\\ &=-[(3,3)^T\cdot(1,1)^T+1]=-7\leq0 \end{aligned}

更新

\begin{aligned} \alpha_3&\leftarrow\alpha_3+\eta=0+1=1 \\ b&\leftarrow b+\eta y_3=1-1=0 \end{aligned}

此时\alpha=(1,0,1)^T

然后计算(x_1,y_1),(x_2,y_2)其判别公式都是大于0的,不更新

第三步: 计算(x_3,y_3)的判别公式

\begin{aligned} &y_3(\sum_{j=1}^N\alpha_jy_jx_j\cdot x_3+b)\\ &=y_3[(\alpha_1y_1x_1+\alpha_2y_2x_2+\alpha_3y_3x_3)x_3+b]\\ &=-1[((1)(1)(3,3)^T+0-(1,1)^T)(1,1)^T+0]\\ &=-[(2,2)^T\cdot(1,1)^T+0]=-4\leq0 \end{aligned}

\begin{aligned} \alpha_3&\leftarrow\alpha_3+\eta=1+1=2 \\ b&\leftarrow b+\eta y_3=0-1=-1 \end{aligned}

此时\alpha=(1,0,2),\; b=-1

依次递推计算可以得到上图递推推过程。                                      #

课后习题       

习题2.1

Minsky和Papert指出:感知机因为是线性模型,所以不能表示复杂的函数如异或(XOR)。验证感知机为什么不能表示异或。

解答:

解题思路:

1.列出异或函数的输入输出;

2.使用图例法证明异或问题是线性不可分的;

3.使用反证法证明感知机无法表示异或

解题步骤:

第1步,列出异或函数的输入和输出

x_1x_2y=x_1\bigoplus x_2
00-1
011
101
11-1

 使用图立法证明异或问题是线性不可分的

mport matplotlib.pyplot as plt
import numpy as np
import pandas as pd


%matplotlib inline


# 使用Dataframe表示异或的输入与输出数据
x1 = [0, 0, 1, 1]
x2 = [0, 1, 0, 1]
y = [-1, 1, 1, -1]
x1 = np.array(x1)
x2 = np.array(x2)
y = np.array(y)
data = np.c_[x1, x2, y]
data = pd.DataFrame(data, index=None, columns=['x1', 'x2', 'y'])
data.head()

pos = data.loc[data['y']==1]
neg = data.loc[data['y']==-1]

# 绘制数据图
# 绘制坐标轴
plt.xlim(-0.5, 1.5)
plt.ylim(-0.5, 1.5)
plt.xticks([-0.5, 0, 1, 1.5])
plt.yticks([-0.5, 0, 1, 1.5])
# 添加坐标轴文字
plt.xlabel("x1")
plt.ylabel("x2")
# 绘制正、负样本点
plt.plot(pos['x1'], pos['x2'], "ro")
plt.plot(neg['x1'], neg['x2'], "bx")
# 添加图示
plt.legend(['Positive', 'Negative'])
plt.show()

from sklearn.linear_model import Perceptron
import numpy as np

# 构造异或问题的训练数据集
X_train = np.array([[1, 1], [1, 0], [0, 1], [0, 0]])
y = np.array([-1, 1, 1, -1])

# 使用sklearn的Perceptron类构建感知机模型
perceptron_model = Perceptron()
# 进行模型训练
perceptron_model.fit(X_train, y)

# 打印模型参数
print("感知机模型的参数:w=", perceptron_model.coef_[
      0], "b=", perceptron_model.intercept_[0])

习题2.2       

模仿例题2.1,构建从训练数据集求解感知机模型的例子。

import matplotlib.pyplot as plt
import numpy as np
import pandas as pd


%matplotlib tk
import numpy as np
from matplotlib import pyplot as plt
%matplotlib tk


class Perceptron:
    def __init__(self, X, Y, lr=0.001, plot=True):
        """
        初始化感知机
        :param X: 特征向量
        :param Y: 类别
        :param lr: 学习率
        :param plot: 是否绘制图形
        """
        self.X = X
        self.Y = Y
        self.lr = lr
        self.plot = plot
        if plot:
            self.__model_plot = self._ModelPlot(self.X, self.Y)
            self.__model_plot.open_in()

    def fit(self):
        # (1)初始化weight, b
        weight = np.zeros(self.X.shape[1])
        b = 0
        # 训练次数
        train_counts = 0
        # 分类错误标识
        mistake_flag = True
        while mistake_flag:
            # 开始前,将mistake_flag设置为False,用于判断本次循环是否有分类错误
            mistake_flag = False
            # (2)从训练集中选取x,y
            for index in range(self.X.shape[0]):
                if self.plot:
                    self.__model_plot.plot(weight, b, train_counts)
                # 损失函数
                loss = self.Y[index] * (weight @ self.X[index] + b)
                # (3)如果损失函数小于0,则该点是误分类点
                if loss <= 0:
                    # 更新weight, b
                    weight += self.lr * self.Y[index] * self.X[index]
                    b += self.lr * self.Y[index]
                    # 训练次数加1
                    train_counts += 1
                    print("Epoch {}, weight = {}, b = {}, formula: {}".format(
                        train_counts, weight, b, self.__model_plot.formula(weight, b)))
                    # 本次循环有误分类点(即分类错误),置为True
                    mistake_flag = True
                    break
        if self.plot:
            self.__model_plot.close()
        # (4)直至训练集中没有误分类点
        return weight, b

    class _ModelPlot:
        def __init__(self, X, Y):
            self.X = X
            self.Y = Y

        @staticmethod
        def open_in():
            # 打开交互模式,用于展示动态交互图
            plt.ion()

        @staticmethod
        def close():
            # 关闭交互模式,并显示最终的图形
            plt.ioff()
            plt.show()

        def plot(self, weight, b, epoch):
            plt.cla()
            # x轴表示x1
            plt.xlim(0, np.max(self.X.T[0]) + 1)
            # y轴表示x2
            plt.ylim(0, np.max(self.X.T[1]) + 1)
            # 画出散点图,并添加图示
            scatter = plt.scatter(self.X.T[0], self.X.T[1], c=self.Y)
            plt.legend(*scatter.legend_elements())
            if True in list(weight == 0):
                plt.plot(0, 0)
            else:
                x1 = -b / weight[0]
                x2 = -b / weight[1]
                # 画出分离超平面
                plt.plot([x1, 0], [0, x2])
                # 绘制公式
                text = self.formula(weight, b)
                plt.text(0.3, x2 - 0.1, text)
            plt.title('Epoch %d' % epoch)
            plt.pause(0.01)

        @staticmethod
        def formula(weight, b):
            text = 'x1 ' if weight[0] == 1 else '%d*x1 ' % weight[0]
            text += '+ x2 ' if weight[1] == 1 else (
                '+ %d*x2 ' % weight[1] if weight[1] > 0 else '- %d*x2 ' % -weight[1])
            text += '= 0' if b == 0 else ('+ %d = 0' %
                                          b if b > 0 else '- %d = 0' % -b)
            return text

输入:

X = np.array([[3, 3], [4, 3], [1, 1]])
Y = np.array([1, 1, -1])
model = Perceptron(X, Y, lr=1)
weight, b = model.fit()

得到结果

Epoch 1, weight = [3. 3.], b = 1, formula: 3*x1 + 3*x2 + 1 = 0
Epoch 2, weight = [2. 2.], b = 0, formula: 2*x1 + 2*x2 = 0
Epoch 3, weight = [1. 1.], b = -1, formula: x1 + x2 - 1 = 0
Epoch 4, weight = [0. 0.], b = -2, formula: 0*x1 - 0*x2 - 2 = 0
Epoch 5, weight = [3. 3.], b = -1, formula: 3*x1 + 3*x2 - 1 = 0
Epoch 6, weight = [2. 2.], b = -2, formula: 2*x1 + 2*x2 - 2 = 0
Epoch 7, weight = [1. 1.], b = -3, formula: x1 + x2 - 3 = 0

 

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

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

相关文章

seata源码-全局事务提交 服务端源码

前面的博客中&#xff0c;我们介绍了&#xff0c;发起全局事务时&#xff0c;是如何进行全局事务提交的&#xff0c;这篇博客&#xff0c;主要记录&#xff0c;在seata分布式事务中&#xff0c;全局事务提交的时候&#xff0c;服务端是如何进行处理的 发起全局事务提交操作 事…

时间复杂度(超详解+例题)

全文目录引言如何衡量一个算法的好坏时间复杂度时间复杂度的定义时间复杂度的大O表示法实例test1test2test3test4test5总结引言 如何衡量一个算法的好坏 我们在写算法的时候&#xff0c;对于实现同样的作用的不同算法&#xff0c;我们如何判断这个算法的好坏呢&#xff1f; …

微前端知识点汇总

1、微前端的实现方案 基于 qiankun 的微前端实践 微前端&#xff08;Micro-Frontends&#xff09;是一种类似于微服务的架构&#xff0c;它将微服务的理念应用于浏览器端&#xff0c;即将 Web 应用由单一的单体应用转变为多个小型前端应用聚合为一的应用。 微前端目标直指巨石…

【Kubernetes】【十一】Pod详解 Pod的生命周期

Pod生命周期 我们一般将pod对象从创建至终的这段时间范围称为pod的生命周期&#xff0c;它主要包含下面的过程&#xff1a; pod创建过程 运行初始化容器&#xff08;init container&#xff09;过程 运行主容器&#xff08;main container&#xff09; 容器启动后钩子&#…

陆拾伍- 如何通过数据影响决策

零、为何能影响 客观的表达其实不一定是客观&#xff0c;只要一被展示&#xff0c;就有可能被主观的意愿所影响。 如何通过客观的数据去展示以及放大主观的意愿&#xff0c;主要有以下几种方法&#xff1a; 一、图表内容顺序 原始数据展示 这种展示&#xff0c;对于 A、B店来…

基于微信小程序的青少年生理健康知识小助手

基于微信小程序的青少年生理健康知识小助手 ✌全网粉丝20W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取项目下载方式&#x1f345; 一、项目…

Python生日系统

#免费源码见文末公众号# 录入生日 def write():keyvar1.get()valuevar2.get()with open(d:\\生日系统.pickle,rb) as file:dictspickle.load(file)dicts[key]valuewith open(d:\\生日系统.pickle,wb) as file:pickle.dump(dicts,file)file.close() 查询生日 def read():namev…

DDR4介绍01

DDR4&#xff08;第四代双倍数据率同步动态随机存储器SDRAM&#xff09; 关于内存方面知识&#xff0c;大部分人、包括我自己也不是很懂&#xff0c;希望此篇文章能起到点作用&#xff0c;做硬件的就得把相关专业知识学牢了&#xff0c;尤其是专业术语。 下面是DDR4知识做一次…

软考高级之信息系统案例分析七重奏-《7》

本文主要介绍信息系统管理师案例分析 项目立项管理 可行性研究内容一般应包括以下内容。 (1)投资必要性 (2)技术的可行性 (3)财务可行性 (4)组织可行性 (5) 经济可行性 (6) 社会可行性 (7) 风险因素及对策。 项目整体管理 1、项目章程应当包括以下内容 (1)项目目的或…

英伟达GPU中的Tnesor Cores数量多寡与显卡性能有什么关联?

前言 最近在调研常用显卡的参数&#xff0c;看到Nvidia Tensor Cores常用于其中作为对比&#xff0c;呈现在性能好的显卡比如A100比RTX 3060更多更全面&#xff0c;开始思考Tensor Cores细致的作用是什么&#xff1f; 英伟达GPU显卡的简要发展历程 GTX是英伟达过去显卡的型号…

智慧工地安全着装识别检测算法 python

智慧工地安全着装识别检测算法通过pythonopencv网络模型AI视频分析技术&#xff0c;人员安全着装识别检测算法对现场物体的不安全状态以及人员的不安全行为&#xff08;不按要求着装&#xff09;进行自动实时分析。由于Python 较为简单&#xff0c;一般无法进行复杂的后端搭建&…

【C语言】指针进阶

目录 一、字符指针 二、指针数组 三、数组指针 四、数组指针的使用 五、函数指针数组 六、指向函数指针数组的指针 七、回调函数 我们知道了指针的概念&#xff1a; 1. 指针就是个变量&#xff0c;用来存放地址&#xff0c;地址唯一标识一块内存空间。 2. 指针的大小是…

基于springboot+html汽车维修系统汽车维修系统的设计与实现

基于springboothtml汽车维修系统汽车维修系统的设计与实现 ✌全网粉丝20W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取项目下载方式&#x1…

OR青年导师访谈特辑 | 香港理工大学助理教授 马玮:一次拉长的面试 一个交流的平台

OR青年计划 由【运筹OR帷幄】社区主办的【OR青年计划】&#xff0c;旨在帮助对运筹学应用有理想和追求的同学&#xff0c;近距离与学界、业界导师交流课题&#xff0c;深入了解运筹学的细分方向&#xff0c;为后续的深造、就业生涯打下坚实的基础&#xff01;更多内容请查看链…

springmvc图书馆自习室座位预约管理系统java ssm

红枫图书馆自习室座位预约系统的开发过程中&#xff0c;采用B / S架构&#xff0c;主要使用jsp技术进行开发&#xff0c;中间件服务器是Tomcat服务器&#xff0c;使用Mysql数据库和Eclipse开发环境。该红枫图书馆自习室座位预约系统包括学生、管理员。其主要功能包括个人中心、…

Go基础-Hello world

文章目录1 GoRoot、GoPath2 编写程序3 运行程序1 GoRoot、GoPath GoRoot 就是Go的安装目录中的bin目录 GoPath 用于存放第三方类库和自己编写的封装好的代码块 2 编写程序 go_basic/01_helloworld.go package mainimport "fmt"func main() {fmt.Println("He…

番外篇 | 20+ 种注意力机制及代码 适用于YOLOv5/v7/v8

前言 之前已经在此篇博文更新过YOLO系列算法添加注意力机制的教程,共计实现了 13 13 13 种注意力及代码,本篇博文继续追加 10 10 10 余种。与之前不同的是,此篇博文代码添加方式更加严谨更加鲁棒,使用更简单,针对不同种类注

(考研湖科大教书匠计算机网络)第四章网络层-第七节:IPv4数据报首部格式

获取pdf&#xff1a;密码7281专栏目录首页&#xff1a;【专栏必读】考研湖科大教书匠计算机网络笔记导航 文章目录一&#xff1a;IP数据报首部格式概述二&#xff1a;各字段作用概述&#xff08;1&#xff09;版本&#xff08;2&#xff09;首部长度和可选字段&#xff08;3&am…

WSL(ubuntu2204)xfce4语言支持报错及配置WSL服务自启

语言支持报错 在图形桌面或命令行打开语言支持报错&#xff1a;dbus.exceptions.DBusException: org.freedesktop.DBus.Error.FileNotFound: Failed to connect to socket /run/dbus/system_bus_socket: No such file or directory itboonelocalhost:/$ sudo /usr/bin/gnome-…

gRPC 非官方教程

一、 简介 gRPC的定义&#xff1a; 一个高性能、通用的开源RPC框架主要面向移动应用开发&#xff1a; gRPC提供了一种简单的方法来精确地定义服务和为iOS、Android和后台支持服务自动生成可靠性很强的客户端功能库。基于HTTP/2协议标准而设计&#xff0c;基于ProtoBuf(Protoc…