【概率图与随机过程】02 多元高斯分布:参数特征和几何意义

本文主要是介绍【概率图与随机过程】02 多元高斯分布:参数特征和几何意义,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在上一讲里,我们重新回顾了一元高斯分布,并从这个分布入手,介绍了如何利用极大似然估计的方法对分布的两个参数:均值 μ \mu μ和方差 σ 2 \sigma^2 σ2进行估计,并从估计的有偏性和无偏性这个角度出发,对两个参数的极大似然估计值进行讨论和验证。

1.从一元分布到多元分布

在这一讲,我们从一元高斯分布过渡到多元高斯分布,我们如何来理解多元高斯分布中的“多”呢?

我们记得,在一元高斯分布中,我们是从一组样本 X = ( x 1 , x 2 , x 3 , . . . , x N ) X=(x_1,x_2,x_3,...,x_N) X=(x1,x2,x3,...,xN)来引入的,我们基于这组样本中的 N N N个样本值对一元高斯分布的两个参数进行极大似然估计。我们要着重强调一点的是,每一个样本都是一个随机变量,更直白的说就是一个随机的“数值”。

而到了多元高斯分布中,同样我们也有一组这样的样本 X X X,但是这里面的每一个样本 x i x_i xi则不再是一个个的随机变量,而是多维的随机向量,每一个样本有 p p p维:

x = [ x 1 x 2 x 3 . . . x p ] x=\begin{bmatrix} x_1\\x_2\\x_3 \\...\\x_p\end{bmatrix} x=x1x2x3...xp

我们假定有 N N N个样本(随机变量),每一个样本有 p p p维,那么可以集中将其对应的表示成矩阵的形式:

X = [ x 11 x 12 x 13 . . . x 1 p x 21 x 22 x 23 . . . x 2 p x 31 x 32 x 33 . . . x 3 p . . . . . . . . . . . . . . . x N 1 x N 2 x N 3 . . . x N p ] X=\begin{bmatrix} x_{11}&x_{12}&x_{13}&...&x_{1p}\\x_{21}&x_{22}&x_{23}&...&x_{2p}\\x_{31}&x_{32}&x_{33}&...&x_{3p} \\...&...&...&...&...\\x_{N1}&x_{N2}&x_{N3}&...&x_{Np}\end{bmatrix} X=x11x21x31...xN1x12x22x32...xN2x13x23x33...xN3...............x1px2px3p...xNp

我们如何来解释这个 N N N p p p列的样本矩阵呢?

矩阵 X X X N N N行,代表了有 N N N个样本,而 p p p列代表了每一个样本有 p p p个特征,或者说的直白些叫 p p p个属性,就好比说这 N N N个样本代表了某市的 N N N个学生,而 p p p个属性则分别可能是学生的身高、体重、考试成绩等等各种值。

而一元高斯分布则是 p = 1 p=1 p=1的一种特殊情况,即每一个样本我们只看他的一个属性。此时的样本也可以看作是一个列为 1 1 1的“特殊矩阵”了。

X = [ x 11 x 21 x 31 . . . x N 1 ] X=\begin{bmatrix} x_{11}\\x_{21}\\x_{31} \\...\\x_{N1}\end{bmatrix} X=x11x21x31...xN1

2.多元高斯分布的参数形式

有了样本 X X X的矩阵表示之后,我想我们下面来介绍多元高斯分布的参数形式,就会更加清楚一些。

和一元高斯分布类似,多元高斯分布的参数同样包含两个部分,一个用来描述分布的均值,另一个也是用来描述分布的方差,但是又有所不同:

首先用来描述分布均值的 μ \mu μ不再是一个数值,而是一个和样本特征维度相对应的 p p p维向量:

μ = [ μ 1 μ 2 μ 3 . . . μ p ] \mu=\begin{bmatrix} \mu_1\\\mu_2\\\mu_3 \\...\\\mu_p\end{bmatrix} μ=μ1μ2μ3...μp

而向量 μ \mu μ中的每一维 μ i \mu_i μi则具体反映了分布中第 i i i个特征的均值。

而反映方差的参数也不再是一个数值,而是一个协方差矩阵 ∑ \sum ,他是一个 p × p p\times p p×p的矩阵

∑ = [ σ 11 σ 12 σ 13 . . . σ 1 p σ 21 σ 22 σ 23 . . . σ 2 p σ 31 σ 32 σ 33 . . . σ 3 p . . . . . . . . . . . . . . . σ p 1 σ p 2 σ p 3 . . . σ p p ] \sum=\begin{bmatrix} \sigma_{11}&\sigma_{12}&\sigma_{13}&...&\sigma_{1p}\\\sigma_{21}&\sigma_{22}&\sigma_{23}&...&\sigma_{2p}\\\sigma_{31}&\sigma_{32}&\sigma_{33}&...&\sigma_{3p} \\...&...&...&...&...\\\sigma_{p1}&\sigma_{p2}&\sigma_{p3}&...&\sigma_{pp}\end{bmatrix} =σ11σ21σ31...σp1σ12σ22σ32...σp2σ13σ23σ33...σp3...............σ1pσ2pσ3p...σpp

我们需要来仔细理解一下这个多元随机变量协方差矩阵 ∑ \sum 的细节,首先这个方阵对角线的值 σ i i \sigma_{ii} σii表示的是分布中第 i i i个特征属性的方差,而非对角线上的值 σ i j \sigma_{ij} σij则表示分布中第 i i i个特征属性和第 j j j个特征属性的协方差,依据协方差的定义,他反映的是多元高斯分布中,第 i i i个特征属性和第 j j j个特征属性的相关性。

那么比较特殊的情况就是,当协方差矩阵 ∑ \sum 是一个对角矩阵,即所有非对角位置上的值均为 0 0 0的时候,意味着该分布中,不同特征属性之间都是不具备相关性的。

3.二元高斯分布的具体示例

这里我们以二元高斯分布为例,通过设置不同的均值向量和协方差矩阵来直观的认识这两个参数对样本分布的影响。

代码片段:

import numpy as np
import matplotlib.pyplot as plt
import seaborn
seaborn.set()
mean_1 = np.array([0, 0])
conv_1 = np.array([[1, 0],[0, 1]])mean_2 = np.array([0, -7])
conv_2 = np.array([[4, 0],[0, 0.25]])mean_3 = np.array([4, 4])
conv_3 = np.array([[4, -3],[-3, 0.25]])x_1, y_1 = np.random.multivariate_normal(mean=mean_1, cov=conv_1, size=2000).T
x_2, y_2 = np.random.multivariate_normal(mean=mean_2, cov=conv_2, size=2000).T
x_3, y_3 = np.random.multivariate_normal(mean=mean_3, cov=conv_3, size=2000).Tplt.plot(x_1, y_1, 'ro', alpha=0.05)
plt.plot(x_2, y_2, 'bo', alpha=0.05)
plt.plot(x_3, y_3, 'go', alpha=0.05)plt.gca().axes.set_xlim(-10, 10)
plt.gca().axes.set_ylim(-10, 10)
plt.show()

运行结果:
图1 不同参数表示的二元高斯分布图示

我们在代码当中,设置了三个不同参数的二元高斯分布,他们整体上的分布都呈现出椭圆形(或正圆形),但是我们发现由于均值向量 μ \mu μ和协方差矩阵 ∑ \sum 设置的不同,三个分布呈现出不同的形态特点:

红色的分布1: μ = [ 0 0 ] \mu=\begin{bmatrix} 0\\0\end{bmatrix} μ=[00] ∑ = [ 1 0 0 1 ] \sum=\begin{bmatrix} 1&0\\0&1\end{bmatrix} =[1001]

分布中包含两维特征属性,均值均为0,方差均为1,协方差为0,因此整个分布的中心点为 ( 0 , 0 ) (0,0) (0,0),两维特征属性彼此不相关,因此分布形态为一个正圆。

蓝色的分布2: μ = [ 0 − 7 ] \mu=\begin{bmatrix} 0\\-7\end{bmatrix} μ=[07] ∑ = [ 4 0 0 0.25 ] \sum=\begin{bmatrix} 4&0\\0&0.25\end{bmatrix} =[4000.25]

分布中包含的两维特征属性中,第二维特征属性的均值为-7,因此整个分布的中心点位于 ( 0 , − 7 ) (0,-7) (0,7),协方差矩阵同样是一个对角矩阵,因此两维特征彼此无关,因此椭圆的长短轴和 x x x轴、 y y y轴方向一致,没有倾斜,但是不同的是,第一维特征属性的方差要明显大于第二维特征属性的方差,因此沿 x x x轴方向的分布要更加分散一些。

绿色的分布3: μ = [ 4 4 ] \mu=\begin{bmatrix} 4\\4\end{bmatrix} μ=[44] ∑ = [ 4 − 3 − 3 0.25 ] \sum=\begin{bmatrix} 4&-3\\-3&0.25\end{bmatrix} =[4330.25]

分布中唯一不同的就是协方差矩阵不再是一个对角矩阵,两维特征属性呈现出负相关,因此整个分布呈现出来的是一个左上方向的椭圆。

4.多元高斯分布的几何特征

从上面的例子中我们感性的认识到,二元高斯分布整体上是一个椭圆形,那我们如何从严格意义上来证明这一点呢?这一部分我们重点讨论这个问题:

我们假定 X X X是一个 p p p维的随机向量,服从 p p p维高斯分布,他的两个参数为 p p p维均值向量 μ \mu μ p × p p\times p p×p的协方差矩阵 Σ \Sigma Σ,首先我们来看一下多元高斯分布的概率密度函数:

p ( x ∣ θ ) = 1 ( 2 π ) p 2 ∣ Σ ∣ 1 2 e x p ( − 1 2 ( x − μ ) T Σ − 1 ( x − μ ) ) p(x|\theta)=\frac{1}{(2\pi)^{\frac{p}{2}}|\Sigma|^{\frac{1}{2}}}exp(-\frac{1}{2}(x-\mu)^T\Sigma^{-1}(x-\mu)) p(xθ)=(2π)2pΣ211exp(21(xμ)TΣ1(xμ))

我们发现,对于一个特定的样本 x i x_i xi,他的概率密度值其实就是取决于 − 1 2 ( x − μ ) T Σ − 1 ( x − μ ) -\frac{1}{2}(x-\mu)^T\Sigma^{-1}(x-\mu) 21(xμ)TΣ1(xμ)这个表达式的取值:

协方差矩阵是半正定的对称矩阵,可以得到由一组标准正交特征向量构成的特征矩阵。即,矩阵 Q Q Q可以表示成: [ q 1 q 2 . . . q p ] \begin{bmatrix} q_1&q_2&...&q_p\end{bmatrix} [q1q2...qp]

协方差矩阵可以分解为 Σ = Q Λ Q T \Sigma=Q\Lambda Q^T Σ=QΛQT的形式,其中满足 Q Q T = I QQ^T=I QQT=I,而 Λ = [ λ 1 λ 2 . . . λ p ] \Lambda=\begin{bmatrix}\lambda_1&&&\\& \lambda_2&&\\&&...&\\&&&\lambda_p\\\end{bmatrix} Λ=λ1λ2...λp

因此协方差矩阵就可以写成:

Σ = [ q 1 q 2 . . . q p ] [ λ 1 λ 2 . . . λ p ] [ q 1 T q 2 T . . . q p T ] = ∑ i = 1 p q i λ i q i T \Sigma=\begin{bmatrix} q_1&q_2&...&q_p\end{bmatrix}\begin{bmatrix}\lambda_1&&&\\& \lambda_2&&\\&&...&\\&&&\lambda_p\\\end{bmatrix}\begin{bmatrix} q_1^T\\q_2^T\\...\\q_p^T\end{bmatrix}=\sum_{i=1}^pq_i\lambda_iq_i^T Σ=[q1q2...qp]λ1λ2...λpq1Tq2T...qpT=i=1pqiλiqiT

Σ − 1 = ( Q Λ Q T ) − 1 = ( Q T ) − 1 Λ − 1 Q − 1 = ( Q − 1 ) − 1 Λ − 1 Q − 1 = Q Λ − 1 Q − 1 \Sigma^{-1}=(Q\Lambda Q^T)^{-1}=(Q^T)^{-1}\Lambda^{-1}Q^{-1}\\=(Q^{-1})^{-1}\Lambda^{-1}Q^{-1}=Q\Lambda^{-1}Q^{-1} Σ1=(QΛQT)1=(QT)1Λ1Q1=(Q1)1Λ1Q1=QΛ1Q1

其中,对角矩阵 Λ − 1 = [ 1 λ 1 1 λ 2 . . . 1 λ p ] \Lambda^{-1}=\begin{bmatrix}\frac{1}{\lambda_1}&&&\\& \frac{1}{\lambda_2}&&\\&&...&\\&&&\frac{1}{\lambda_p}\\\end{bmatrix} Λ1=λ11λ21...λp1

因此 Σ − 1 = ∑ i = 1 p q i 1 λ i q i T \Sigma^{-1}=\sum_{i=1}^pq_i\frac{1}{\lambda_i}q_i^T Σ1=i=1pqiλi1qiT

此时,我们回到上面那个决定概率密度的表达式: ( x − μ ) T Σ − 1 ( x − μ ) (x-\mu)^T\Sigma^{-1}(x-\mu) (xμ)TΣ1(xμ)当中去

( x − μ ) T Σ − 1 ( x − μ ) = ( x − μ ) T [ ∑ i = 1 p q i 1 λ i q i T ] ( x − μ ) = ∑ i = 1 p ( x − μ ) T q i 1 λ i q i T ( x − μ ) (x-\mu)^T\Sigma\,^{-1}(x-\mu)=(x-\mu)^T[\sum_{i=1}^pq_i\frac{1}{\lambda_i}q_i^T](x-\mu)\\=\sum_{i=1}^p(x-\mu)^Tq_i\frac{1}{\lambda_i}q_i^T(x-\mu) (xμ)TΣ1(xμ)=(xμ)T[i=1pqiλi1qiT](xμ)=i=1p(xμ)Tqiλi1qiT(xμ)

此时,我们对这个看似复杂的式子做一个小小变换和替代,令: y i = ( x − μ ) T q i y_i=(x-\mu)^Tq_i yi=(xμ)Tqi

这是一个先平移、后投影的操作,先让随机变量 X X X整体按照均值向量 μ \mu μ进行平移,也就是使得原点称为分布的中心点,然后向单位向量 q i q_i qi做一个投影,这其中,很显然 y 1 y_1 y1是样本 x x x q 1 q_1 q1方向上的投影长度,而 y 2 y_2 y2则是样本 x x x q 2 q_2 q2方向上的投影长度, q 1 q_1 q1 q 2 q_2 q2是彼此正交的单位向量。

为了方便的说明问题,我们这里令维度 p = 2 p=2 p=2,那么等式就简化为:

∑ i = 1 2 ( x − μ ) T q i 1 λ i q i T ( x − μ ) = y 1 1 λ 1 y 1 T + y 2 1 λ 2 y 2 T = y 1 2 λ 1 + y 2 2 λ 2 \sum_{i=1}^2(x-\mu)^Tq_i\frac{1}{\lambda_i}q_i^T(x-\mu)=y_1\frac{1}{\lambda_1}y_1^T+y_2\frac{1}{\lambda_2}y_2^T=\frac{y_1^2}{\lambda_1}+\frac{y_2^2}{\lambda_2} i=12(xμ)Tqiλi1qiT(xμ)=y1λ11y1T+y2λ21y2T=λ1y12+λ2y22

那么,最终的结论就是:只要 ∑ i = 1 2 ( x − μ ) T q i 1 λ i q i T ( x − μ ) \sum_{i=1}^2(x-\mu)^Tq_i\frac{1}{\lambda_i}q_i^T(x-\mu) i=12(xμ)Tqiλi1qiT(xμ)也就是 y 1 2 λ 1 + y 2 2 λ 2 \frac{y_1^2}{\lambda_1}+\frac{y_2^2}{\lambda_2} λ1y12+λ2y22这个等式的值一固定,那么整个二元高斯分布的概率密度函数 p ( x ∣ θ ) = 1 ( 2 π ) p 2 ∣ Σ ∣ 1 2 e x p ( − 1 2 ( x − μ ) T Σ − 1 ( x − μ ) ) p(x|\theta)=\frac{1}{(2\pi)^{\frac{p}{2}}|\Sigma|^{\frac{1}{2}}}exp(-\frac{1}{2}(x-\mu)^T\Sigma^{-1}(x-\mu)) p(xθ)=(2π)2pΣ211exp(21(xμ)TΣ1(xμ))的值就确定了。

这句话感觉还有些抽象,换句话说,就是使得 ∑ i = 1 2 ( x − μ ) T q i 1 λ i q i T ( x − μ ) \sum_{i=1}^2(x-\mu)^Tq_i\frac{1}{\lambda_i}q_i^T(x-\mu) i=12(xμ)Tqiλi1qiT(xμ)等于某个具体的常数 c c c的所有样本 x x x,出现的概率都是一样大的。

那么进一步等价为 y 1 2 λ 1 + y 2 2 λ 2 \frac{y_1^2}{\lambda_1}+\frac{y_2^2}{\lambda_2} λ1y12+λ2y22等于常数 c c c的时候,样本出现的概率都是一样的。

y 1 2 λ 1 + y 2 2 λ 2 = c \frac{y_1^2}{\lambda_1}+\frac{y_2^2}{\lambda_2}=c λ1y12+λ2y22=c的几何含义代表了什么?为了看得更明白一些,我们先令 c = 1 c=1 c=1,此时 y 1 2 λ 1 + y 2 2 λ 2 = 1 \frac{y_1^2}{\lambda_1}+\frac{y_2^2}{\lambda_2}=1 λ1y12+λ2y22=1表示的不就是一个椭圆的方程吗?

只不过这个椭圆的长轴和短轴发生了变化,不再是我们印象当中的 x x x轴和 y y y轴,而是协方差矩阵经过特征值分解得到的两个标准正交的特征向量 q 1 q_1 q1 q 2 q_2 q2,他们构成了这个椭圆的长轴和短轴,而这个椭圆在两个轴上的长度就是 λ 1 \sqrt{\lambda_1} λ1 λ 2 \sqrt{\lambda_2} λ2 ,而 y 1 y_1 y1 y 2 y_2 y2就是原来 x o y xoy xoy坐标系中的样本在 q 1 q_1 q1 q 2 q_2 q2上的投影长度,说穿了,就是样本点以 q 1 q_1 q1 q 2 q_2 q2为新坐标系的坐标值。

那么进一步我们来看,对于等式 ∑ i = 1 2 ( x − μ ) T q i 1 λ i q i T ( x − μ ) \sum_{i=1}^2(x-\mu)^Tq_i\frac{1}{\lambda_i}q_i^T(x-\mu) i=12(xμ)Tqiλi1qiT(xμ),每固定一个常数 c c c,就相当于在平面上以 q 1 q_1 q1 q 2 q_2 q2为轴, c λ 1 \sqrt{c\lambda_1} cλ1 c λ 2 \sqrt{c\lambda_2} cλ2 为轴长,画了一个椭圆,而这个椭圆上所有的样本点出现的概率是相等的。

随着常数 c c c不断增大,也就是 ∑ i = 1 2 ( x − μ ) T q i 1 λ i q i T ( x − μ ) \sum_{i=1}^2(x-\mu)^Tq_i\frac{1}{\lambda_i}q_i^T(x-\mu) i=12(xμ)Tqiλi1qiT(xμ)的取值不断增大,椭圆也在不断的增大,而 p ( x ∣ θ ) = 1 ( 2 π ) p 2 ∣ Σ ∣ 1 2 e x p ( − 1 2 ( x − μ ) T Σ − 1 ( x − μ ) ) p(x|\theta)=\frac{1}{(2\pi)^{\frac{p}{2}}|\Sigma|^{\frac{1}{2}}}exp(-\frac{1}{2}(x-\mu)^T\Sigma^{-1}(x-\mu)) p(xθ)=(2π)2pΣ211exp(21(xμ)TΣ1(xμ))的取值不断的减小,越大的椭圆上分布的样本概率越小。

5.二元高斯分布几何特征实例分析

我们结合下面这个例子,把上面的分析过程总结一下,以下面这个二元高斯分布为例,分布的参数如下:

μ = [ 20 − 20 ] \mu=\begin{bmatrix} 20\\-20\end{bmatrix} μ=[2020] Σ = [ 34 12 12 41 ] \Sigma=\begin{bmatrix} 34&12\\12&41\end{bmatrix} Σ=[34121241]

我们对着代码和运行结果来总结上面的分析过程:

代码片段:

import numpy as np
import matplotlib.pyplot as plt
from scipy import linalg
import seaborn
seaborn.set()mean_1 = np.array([0, 0])
mean_2 = np.array([20, -20])conv = np.array([[34, 12],[12, 41]])x_1, y_1 = np.random.multivariate_normal(mean=mean_1, cov=conv, size=4000).T
x_2, y_2 = np.random.multivariate_normal(mean=mean_2, cov=conv, size=4000).Tplt.plot(x_1, y_1, 'ro', alpha=0.05)
plt.plot(x_2, y_2, 'bo', alpha=0.05)plt.gca().axes.set_xlim(-20, 40)
plt.gca().axes.set_ylim(-40, 20)evalue, evector = linalg.eig(conv)
print(evalue)
print(evector)
plt.show()

运行结果:

图2 二元高斯分布几何特征实例

[25.+0.j 50.+0.j][[-0.8 -0.6][ 0.6 -0.8]]

在图中,蓝色的为原始的二维高斯分布的样本点,样本减去均值向量 μ = [ 20 − 20 ] \mu=\begin{bmatrix} 20\\-20\end{bmatrix} μ=[2020]之后,整体平移至红色的分布区域。

我们对协方差矩阵 Σ = [ 34 12 12 41 ] \Sigma=\begin{bmatrix} 34&12\\12&41\end{bmatrix} Σ=[34121241]进行特征值分解得到特征向量: q 1 = [ − 0.8 0.6 ] q_1=\begin{bmatrix} -0.8\\0.6\end{bmatrix} q1=[0.80.6] q 2 = [ − 0.6 − 0.8 ] q_2=\begin{bmatrix} -0.6\\-0.8\end{bmatrix} q2=[0.60.8],他们分别对应特征值为: λ 1 = 25 \lambda_1=25 λ1=25 λ 2 = 50 \lambda_2=50 λ2=50

这意味着在平移后的红色区域中,拥有无数个以 [ 0 0 ] \begin{bmatrix} 0\\0\end{bmatrix} [00]为中心,以 q 1 q_1 q1 q 2 q_2 q2为轴的同心椭圆,椭圆的长轴短轴之比为 50 25 \frac{\sqrt{50}}{\sqrt{25}} 25 50 ,每个椭圆上的样本存在的概率相等,椭圆越大,样本存在的概率越小,这里我们从图中由里到外颜色由深变浅就能很好的看出来。

这篇关于【概率图与随机过程】02 多元高斯分布:参数特征和几何意义的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/306458

相关文章

MySQL中时区参数time_zone解读

《MySQL中时区参数time_zone解读》MySQL时区参数time_zone用于控制系统函数和字段的DEFAULTCURRENT_TIMESTAMP属性,修改时区可能会影响timestamp类型... 目录前言1.时区参数影响2.如何设置3.字段类型选择总结前言mysql 时区参数 time_zon

Python如何使用seleniumwire接管Chrome查看控制台中参数

《Python如何使用seleniumwire接管Chrome查看控制台中参数》文章介绍了如何使用Python的seleniumwire库来接管Chrome浏览器,并通过控制台查看接口参数,本文给大家... 1、cmd打开控制台,启动谷歌并制定端口号,找不到文件的加环境变量chrome.exe --rem

SpringBoot 整合 Grizzly的过程

《SpringBoot整合Grizzly的过程》Grizzly是一个高性能的、异步的、非阻塞的HTTP服务器框架,它可以与SpringBoot一起提供比传统的Tomcat或Jet... 目录为什么选择 Grizzly?Spring Boot + Grizzly 整合的优势添加依赖自定义 Grizzly 作为

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d

springboot整合gateway的详细过程

《springboot整合gateway的详细过程》本文介绍了如何配置和使用SpringCloudGateway构建一个API网关,通过实例代码介绍了springboot整合gateway的过程,需要... 目录1. 添加依赖2. 配置网关路由3. 启用Eureka客户端(可选)4. 创建主应用类5. 自定

Linux中Curl参数详解实践应用

《Linux中Curl参数详解实践应用》在现代网络开发和运维工作中,curl命令是一个不可或缺的工具,它是一个利用URL语法在命令行下工作的文件传输工具,支持多种协议,如HTTP、HTTPS、FTP等... 目录引言一、基础请求参数1. -X 或 --request2. -d 或 --data3. -H 或

最新版IDEA配置 Tomcat的详细过程

《最新版IDEA配置Tomcat的详细过程》本文介绍如何在IDEA中配置Tomcat服务器,并创建Web项目,首先检查Tomcat是否安装完成,然后在IDEA中创建Web项目并添加Web结构,接着,... 目录配置tomcat第一步,先给项目添加Web结构查看端口号配置tomcat    先检查自己的to

使用C#如何创建人名或其他物体随机分组

《使用C#如何创建人名或其他物体随机分组》文章描述了一个随机分配人员到多个团队的代码示例,包括将人员列表随机化并根据组数分配到不同组,最后按组号排序显示结果... 目录C#创建人名或其他物体随机分组此示例使用以下代码将人员分配到组代码首先将lstPeople ListBox总结C#创建人名或其他物体随机分组

SpringBoot集成SOL链的详细过程

《SpringBoot集成SOL链的详细过程》Solanaj是一个用于与Solana区块链交互的Java库,它为Java开发者提供了一套功能丰富的API,使得在Java环境中可以轻松构建与Solana... 目录一、什么是solanaj?二、Pom依赖三、主要类3.1 RpcClient3.2 Public