机器学习-6 支持向量机

news2025/1/16 17:04:57

支持向量机

  • 算法概述
  • 算法流程
    • 线性分类
    • 线性可分性
    • 向量内积
    • 硬间隔分类
    • 软间隔SVM模型
    • 非线性支持向量机
      • 非线性的情况
      • 非线性支持向量机
      • 核函数
    • SVM优点
  • 算法步骤
    • 线性可支持向量机的程序流程图
    • SVM算法步骤
  • 算法实例
    • 有关数据集
    • 利用Sklearn的datasets模块生成数据集
    • 其他生成数据集的方法
    • 线性支持向量机
    • SVM分类算法
    • SVM算法的应用

算法概述

支持向量机(SVM)是一种基于统计学习理论监督学习方法。
支持向量机在各个领域内的模式识别问题中都有广泛应用,包括人脸识别、文本分类、笔迹识别等。
支持向量机解决不同类型的问题:

  • 当训练数据线性可分时,通过硬间隔最大化,学习一个线性可分支持向量机;
    在这里插入图片描述
  • 当训练数据近似线性可分时,通过软间隔最大化,学习一个线性支持向量机;
  • 当训练数据不可分时,通过使用核技巧以及软间隔最大化,学习一个非线性支持向量机。
    在这里插入图片描述

算法流程

线性分类

  • 给定一个特征空间上的训练数据集 T T T={ ( x i , y i ) ∣ i = 1 , 2 , . . , N (x_i,y_i)|i=1,2,..,N (xi,yi)i=1,2,..,N},其中 x i = [ x i 1 , x i 2 , . . . , x i n ] T ∈ X , y i ∈ Y = x_i=[x_{i1},x_{i2},...,x_{in}]^T∈X,y_i∈Y= xi=[xi1,xi2,...,xin]TXyiY={ -1,+1}, i = 1 , 2 , . . , N i=1,2,..,N i=1,2,..,N
  • x i x_i xi是训练数据集T的第i个实例, y i y_i yi x i x_i xi的类别标签。如果 y i = + 1 y_i=+1 yi=+1,则称 x i x_i xi为正例;反之如果 y i = − 1 y_i=-1 yi=1,则称 x i x_i xi为负例。
  • 一个线性分类器的学习目标就是要在这n维的数据空间中找到一个超平面,将所有的正例划分到超平面的一侧,将所有的负例划分到超平面的另一侧。

假设笛卡尔平面坐标系上有两类不同的数据,分别用三角形和圆形表示,其中的一个超平面就是中间的那条直线,如图所示。显然,这个超平面可将两类数据点分隔开来,超平面右上角数据点(三角形)所对应的分割结果全是-1,而在另一侧的数据点(圆形)全是+1。
在这里插入图片描述

线性可分性

对于分离超平面: w T X + b = 0 w^TX+b=0 wTX+b=0
可以将方点和圆点表示的两类不同数据完全分离开在该超平面的两侧,使其满足:
1. w T X + b > 0 w^TX+b>0 wTX+b>0的所有数据属于一类
2. w T X + b < 0 w^TX+b<0 wTX+b<0的所有数据属于另一类
在这里插入图片描述
称样本数据集为线性可分,称 w T X + b = 0 w^TX+b=0 wTX+b=0为分离超平面。

对于一个线性可分性的样本数据集,其分离超平面通常不止一个。
线性可分支持向量机提出了间隔最大化条件,以此来求得距离两个可分类的最佳超平面 。
在这里插入图片描述
注:SVM寻找区分两类的超平面,使边际最大。
在这里插入图片描述

向量内积

在这里插入图片描述
向量内积: x ⋅ y = x 1 y 1 + x 2 y 2 + . . . x n y n x\cdot y=x_1y_1+x_2y_2+...x_ny_n xy=x1y1+x2y2+...xnyn
向量内积: x ⋅ y = ∣ ∣ x ∣ ∣ x\cdot y=||x|| xy=∣∣x∣∣ ∣ ∣ y ∣ ∣ c o s ( θ ) ||y||cos(\theta) ∣∣y∣∣cos(θ)
范数:||x||= x ⋅ x \sqrt{x\cdot x} xx = x 1 2 + x 2 2 + . . . + x n 2 \sqrt{x_1^2+x_2^2+...+x_n^2} x12+x22+...+xn2
当||x||≠0,||y||≠0时,可以求余弦相似度:
c o s θ = x ⋅ y ∣ ∣ x ∣ ∣ ∣ ∣ y ∣ ∣ cos\theta=\frac{x\cdot y}{||x||||y||} cosθ=∣∣x∣∣∣∣y∣∣xy
在这里插入图片描述
一些推导
w ⋅ x 1 + b = 1 w\cdot x_1+b=1 wx1+b=1
w ⋅ x 2 + b = − 1 w\cdot x_2+b=-1 wx2+b=1
w ⋅ ( x 1 − x 2 ) = 2 w\cdot (x_1-x_2)=2 w(x1x2)=2
||w|| ||( x 1 − x 2 x_1-x_2 x1x2)|| cos( θ \theta θ) = 2
||w||*d=2
d= 2 ∣ ∣ w ∣ ∣ \frac{2}{||w||} ∣∣w∣∣2
转化为凸优化问题
w ⋅ \cdot x+b≥1,则分类y=1
w ⋅ \cdot x+b≤1,则分类y=-1
即y(w ⋅ \cdot x+b)≥1
求d= 2 ∣ ∣ w ∣ ∣ \frac{2}{||w||} ∣∣w∣∣2最大值,也就是求min ∣ ∣ w ∣ ∣ 2 2 \frac{{||w||}^2}{2} 2∣∣w∣∣2

硬间隔分类

硬间隔分类的缺点
1)只有数据线性分离才有效
2)对异常值太敏感
在这里插入图片描述

软间隔SVM模型

SVM模型:模型对S中任何训练样本都不能做出错误分类。
软间隔SVM模型:允许对少量训练样本出现分类错误。引入一个松弛变量 ξ i \xi_i ξi,将约束条件转化为:
y i ( w T X i + b ) ≥ 1 − ξ i y_i(w^TX_i+b)≥1-\xi_i yi(wTXi+b)1ξi
ξ i \xi_i ξi的取值越大,模型对错误分类的容忍程度越高。
可得到如下优化求解软间隔SVM模型的目标函数:
m i n 1 2 ∣ ∣ w ∣ ∣ 2 + C ∑ i = 1 n ξ i min\frac{1}{2}||w||^2+C\sum_{i=1}^{n}\xi_i min21∣∣w2+Ci=1nξi s . t . y i ( w T X i + b ) ≥ 1 − ξ i s.t.y_i(w^TX_i+b)≥1-\xi_i s.t.yi(wTXi+b)1ξi
其中C>0是为惩罚因子。

非线性支持向量机

非线性的情况

前面提到的支持向量机只能用于处理线性分类问题,但有时还会面对非线性分类问题。如下图的数据集,在空间中无法用一条直线(线性)将数据集中的正例和负例正确地分隔开,但可以用一条圆形曲线(非线性)分隔。这种使用非线性模型(超曲面)进行分类的问题称为非线性分类问题。
在这里插入图片描述

把低维空间的非线性问题映射到高维空间,变成求解线性问题。
在这里插入图片描述在这里插入图片描述
在这里插入图片描述

非线性支持向量机

对于非线性的情况,支持向量机选择一个核函数,通过将数据映射到高维空间,从而解决原始空间中线性不可分的问题。
分类函数定义为:
f ( x ) = ∑ i = 1 N w i ϕ i ( x ) + b f(x)=\sum_{i=1}^{N}w_iϕ_i(x)+b f(x)=i=1Nwiϕi(x)+b

在这里插入图片描述
例如:
3维输入变量:X=( x 1 , x 2 , x 3 x_1,x_2,x_3 x1,x2,x3
转化到6维空间Z中去:
ϕ 1 ( X ) = x 1 , ϕ 2 ( X ) = x 2 , ϕ 3 ( X ) = x 3 , ϕ 4 ( X ) = ( x 1 ) 2 , ϕ 5 ( X ) = x 1 x 2 , a n d ϕ 6 ( X ) = x 1 x 3 ϕ_1(X)=x_1,ϕ_2(X)=x_2,ϕ_3(X)=x_3,ϕ_4(X)=(x_1)^2,ϕ_5(X)=x_1x_2,and ϕ_6(X)=x_1x_3 ϕ1(X)=x1ϕ2(X)=x2ϕ3(X)=x3ϕ4(X)=(x1)2ϕ5(X)=x1x2andϕ6(X)=x1x3
新决策超平面:d(Z)=WZ+b,其中W和Z是向量,这个超平面是线性的,解出W和b之后,并且带回原方程:
d(Z)
= w 1 x 1 + w 2 x 2 + w 3 x 3 + w 4 ( x 1 ) 2 + w 5 x 1 x 2 + w 6 x 1 x 3 + b w_1x_1+w_2x_2+w_3x_3+w_4(x_1)^2+w_5x_1x_2+w_6x_1x_3+b w1x1+w2x2+w3x3+w4(x1)2+w5x1x2+w6x1x3+b
= w 1 z 1 + w 2 z 2 + w 3 z 3 + w 4 z 4 + w 5 z 5 + w 6 z 6 + b w_1z_1+w_2z_2+w_3z_3+w_4z_4+w_5z_5+w_6z_6+b w1z1+w2z2+w3z3+w4z4+w5z5+w6z6+b

核函数

虽然可以利用非线性变换处理非线性分类问题,但如果映射后的空间维度非常高,将导致进行非线性变换所使用的存储空间和计算资源开销过大,有时甚至是无法实现的。
但是利用核方法可以解决这个问题。核方法的核心思想是,利用核函数直接计算映射到空间后实例间的内积,以此代替先做映射再做内积。
常用的核函数有:
1)线性核函数(Linear Kernel)
2)多项式核函数(Polynomial Kernel)
3)径向基核函数(Radial Basis Function Kernel)又称高斯核
4)Sigmoid核函数(Sigmoid Kernel)
线性核函数
线性核函数(Linear Kernel)是最简单的核函数,主要用于线性可分的情况,表达式如下:
K ( x , y ) = x T ⋅ y + c K(x,y)=x^T\cdot y+c K(x,y)=xTy+c
其中c是可选的常数。线性核函数是原始输入空间的内积,即特征空间和输入空间的维度是一样的,参数较少运算速度较快。
适用的情景是在特征数量相对于样本数量非常多时。

多项式核函数
多项式核函数(Polynomial Kernel)是一种非稳态核函数,适合于正交归一化后的数据,表达式如下:
KaTeX parse error: Undefined control sequence: \codt at position 19: …,y)=[a\cdot x^T\̲c̲o̲d̲t̲ ̲y+c]^d
其中a是调节参数,d是最高次项次数,c是可选的常数

径向基核函数
径向基核函数(Radial Basis Function Kernel)具有很强的灵活性,应用广泛。
与多项式核函数相比参数较少,因此大多数情况下都有较好的性能。
径向基核函数类似于高斯函数,所以也被称为高斯核函数
在不确定用哪种核函数时,可优先验证高斯核函数。
K ( x , y ) = e − ∣ ∣ x − y ∣ ∣ 2 2 ⋅ a 2 K(x,y)=e^{-{\frac{||x-y||^2}{2\cdot a^2}}} K(x,y)=e2a2∣∣xy2
a 2 a^2 a2越大,高斯核函数就会变得越平滑,此时函数随输入x变化较缓慢 ,模型的偏差和方差大,泛化能力差,容易过拟合。
a 2 a^2 a2越小,高斯核函数变化越剧烈,模型的偏差和方差越小,模型对噪声样本比较敏感。

Sigmoid核
Sigmoid核(Sigmoid Kernel)来源于MLP中的激活函数,SVM使用Sigmoid相当于一个两层的感知机网络,表达式如下:
K ( x , y ) = t a n h ( a ⋅ x T ⋅ y + c ) K(x,y)=tanh(a\cdot x^T\cdot y+c) K(x,y)=tanh(axTy+c)
我们可以构造核函数使得运算结果等同于非线性映射,同时运算量要远远小于非线性映射。

核函数举例
假定定义两个变量: x = ( x 1 , x 2 , x 3 ) ; y = ( y 1 , y 2 , y 3 ) x=(x_1,x_2,x_3);y=(y_1,y_2,y_3) x=(x1,x2,x3)y=(y1,y2,y3)
①定义高维映射方程
f ( x ) = ( x 1 x 1 , x 1 x 2 , x 1 x 3 , x 2 x 1 , x 2 x 2 , x 2 x 3 , x 3 x 1 , x 3 x 2 , x 3 x 3 ) f(x)=(x_1x_1,x_1x_2,x_1x_3,x_2x_1,x_2x_2,x_2x_3,x_3x_1,x_3x_2,x_3x_3) f(x)=(x1x1,x1x2,x1x3,x2x1,x2x2,x2x3,x3x1,x3x2,x3x3)
假设x=(1,2,3),y=(4,5,6)
f(x)=(1,2,3,2,4,6,3,6,9)
f(y)=(16,20,24,20,25,36,24,30,36)
求内积<f(x),f(y)>=16+40+72+40+100+180+72+180+324=1024
②定义核函数
K(x,y)=(<x,y>)^2
K(x,y)=(4+10+18)^2=1024
同样的结果,但是使用核函数计算就容易得多

SVM优点

  • 训练好的模型的算法复杂度是由支持向量的个数决定的,而不是由数据的维度决定的。所以SVM不太容易产生overfitting。
  • SVM训练出来的模型完全依赖于支持向量(Support Vectors),即使训练集里面所有非支持向量的点都被去除,重复训练过程,结果仍然会得到完全一样的模型
  • 一个SVM如果训练得出的支持向量个数比较小,SVM训练出的模型比较容易被泛化。

算法步骤

线性可支持向量机的程序流程图

在这里插入图片描述

SVM算法步骤

线性支持向量机的算法步骤如下:
1)给定训练集T= ( x 1 , y 1 ) , ( x 2 , y 2 ) , . . . , ( x n , y n ) , y = − 1 , 1 {(x_1,y_1),(x_2,y_2),...,(x_n,y_n)},y={-1,1} (x1,y1),(x2,y2),...,(xn,yn),y=1,1
2)构造最优化问题
m i n φ ( α ) = 1 2 ∑ i = 1 N ∑ j = 1 N α i α j y i y j ( x i ⋅ x j ) − ∑ i = 1 N α i min\varphi(\alpha)=\frac{1}{2}\sum_{i=1}^{N}\sum_{j=1}^{N}\alpha_i\alpha_jy_iy_j(x_i\cdot x_j)-\sum_{i=1}^{N}\alpha_i minφ(α)=21i=1Nj=1Nαiαjyiyj(xixj)i=1Nαi
3)计算参数w和b
w = ∑ i = 1 N α i y i x i w=\sum_{i=1}^{N}\alpha_iy_ix_i w=i=1Nαiyixi b = y i − x i ⋅ ∑ i = 1 N α i y i x i b=y_i-x_i\cdot \sum_{i=1}^{N}\alpha_iy_ix_i b=yixii=1Nαiyixi
4)得出超平面与决策函数
w ⋅ x + b = 0 w\cdot x+b=0 wx+b=0分类决策函数如下 f ( x ) = s i g n ( w ⋅ x + b ) f(x)=sign(w\cdot x+b) f(x)=sign(wx+b)

算法实例

有关数据集

sklearn 的数据集有好多个种类:

  • 自带的小数据集(packaged dataset):sklearn.datasets.load_
  • 可在线下载的数据集(Downloaded Dataset):sklearn.datasets.fetch_
  • 计算机生成的数据集(Generated Dataset):sklearn.datasets.make_
  • svmlight/libsvm格式的数据集:sklearn.datasets.load_svmlight_file(…)
  • 从买了data.org在线下载获取的数据集:sklearn.datasets.fetch_mldata(…)

利用Sklearn的datasets模块生成数据集

  • 生成数据集:可以用来分类任务,可以用来回归任务,可以用来聚类任务……
  • 用于分类任务和聚类任务的:这些函数产生样本特征向量矩阵以及对应的类别标签集合
  • make_blobs:多类单标签数据集,为每个类分配一个或多个正态分布的点集,对每个类的中心和标准差有很好的控制
    from sklearn.datasets.samples_generator import make_blobs
    sklearn.datasets.samples_generator.make_blobs(n_samples=100, n_features=2, centers=3, cluster_std=1.0, center_box=(-10.0, 10.0), shuffle=True, random_state=None)
  • 返回结果:
    X:[n_samples,n_features]大小的特征矩阵
    y:[n_samples]大小的标签数据矩阵,对应特征矩阵的每一行

其他生成数据集的方法

  • make_classification:多类单标签数据集,为每个类分配一个或多个正态分布的点集,提供了为数据添加噪声的方式,包括维度相关性,无效特征以及冗余特征等
  • make_gaussian-quantiles:将一个单高斯分布的点集划分为两个数量均等的点集,作为两类
  • make_hastie-10-2:产生一个相似的二元分类数据集,有10个维度
  • make_circles和make_moons:产生二维二元分类数据集来测试某些算法的性能,可以为数据集添加噪声,可以为二元分类器产生一些球形判决界面的数据

线性支持向量机

支持向量机是一种可构造唯一决策面的线性分类器,所构造的决策面能够将其到与其最近的训练实例(支持向量)的距离最大化。
sklearn提供了线性分类支持向量机(LinearSVC)的实现,其函数原型为:
class sklearn.svm.LinearSVC(penalty=’l2’, loss=’squared_hinge’, dual=True, tol=0.0001, C=1.0, multi_class=’ovr’, fit_intercept=True, intercept_scaling=1, class_weight=None, verbose=0, random_state=None, max_iter=1000)

  • penalty:字符串,默认参数值为“l2”。惩罚类型,指定“l1”或“l2”。
  • loss:字符串,可选“hinge”或“squared hinge”,默认参数值为“squared hinge”。 损失函数。
  • C:浮点数。惩罚参数。C参数决定SVM分类器的边距宽度。C的值越大分类器越严格,因此边距宽度小。对于较大的C值,如果该超平面更好地将所有训练点归类正确,则该模型将选择较小边距的超平面。相反,C的非常小的值将导致模型寻找更大的边距分离超平面,即使这个超平面错误的分类了更多的点。
  • multi_class:字符串。多类分类问题的策略,取值可选“ovr”“crammer_singer”之一,默认参数值为“ovr”。“ovr”采用one-vs-rest分类策略;“crammer_singer”采用多类联合分类策略。
  • fit_intercept:布尔值。如果为True,则计算截距,即决策函数中的常数项;否则忽略截距。

示例:首先创建可以分离的样本数据集(假定二分类),然后使用sklearn所提供的线性支持向量机(LinearSVC)方法对其进行分类,求取一个支持向量集并绘图,具体代码如下。

import numpy as np
import matplotlib.pyplot as plt
from sklearn.svm import LinearSVC
from sklearn.datasets import make_blobs
#创建随机分布的 可以分离的400个样本点
X,y=make_blobs(n_samples=400,centers=2,random_state=32)
#创建LinearSVC对象
clf=LinearSVC(C=10)
clf.fit(X,y)
plt.scatter(X[:,0],X[:,1],c=y,s=30,cmap=plt.cm.Paired)
#画出决策函数
ax=plt.gca()
xlim=ax.get_xlim()
ylim=ax.get_ylim()
#网格化评价模型
xx=np.linspace(xlim[0],xlim[1],30)
yy=np.linspace(ylim[0],ylim[1],30)
YY,XX=np.meshgrid(yy,xx)
xy=np.vstack([XX.ravel(),YY.ravel()]).T
Z=clf.decision_function(xy).reshape(XX.shape)
#画分类边界
ax.contour(XX,YY,Z,colors='k',levels=[-1,0,1],alpha=0.5,linestyles=['--','-','--'])
plt.title('Maximum margin using LinearSVC')
plt.show()

实验结果

在这里插入图片描述

SVM分类算法

Scikit-learn中实现SVM分类算法的SVC类如下:
sklearn.svm.SVC(C=1.0, kernel='rbf', degree=3, gamma='scale', coef0=0.0, shrinking=True,probability=False, tol=0.001, cache_size=200, class_weight=None, verbose=False, max_iter=-1, decision_function_shape='ovr', break_ties=False, random_state=None)
其主要参数为:
1)C:惩罚系数。数据类型为浮点型,值严格大于0,常选用C=1.0。
2)kernel:核函数。值有linear、poly、rbf、sigmoid、precomputed或可调用核函数等参数可选。若不指定该参数值,则自动使用默认参数值rfb。
3)degree:多项式核函数阶数。数据类型为整型,若不指定该参数值,则自动使用默认参数值3。仅当kernel参数选用poly时有效,其他核函数下该参数无效。
4)gamma:指定核函数的系数。数据类型为浮点型或可选scale、auto。当核函数参数kernel为poly、rbf和sigmoid时,指定系数。若不指定该参数值,则自动使用默认参数值scale。
5)coef0:核函数自由项。数据类型为浮点型,若不指定该参数值,则自动使用默认参数值0.0。只有当核函数kernel参数为poly和sigmoid时有效。
6)shrinking:是否使用缩小的启发方式。数据类型为布尔型,若不指定该参数值,则自动使用默认参数值True。
7)probability:是否启用概率估计。数据类型为布尔型,若不指定该参数值,则自动使用默认参数值False。这必须在调用fit()之前启用,并且会使fit()方法速度变慢。
8)tol:停止训练的误差精度。数据类型为浮点型,若不指定该参数,则使用默认参数值0.001。
9)cache_size:指定训练所需要的内存。数据类型为浮点型,以MB为单位,若不指定该参数,则使用默认参数值200MB。
10)class_weight:样本数据中每个类的权重。数据类型为字典、balanced或None,若不指定该参数值,则自动使用默认参数值None。
11)verbose:是否启用详细输出。数据类型为布尔型,若不指定该参数值,则自动使用默认参数值False。
12)max_iter:最大迭代次数。数据类型为整型,若不指定该参数值,则自动使用默认参数值-1,表示不限制迭代次数。
13)decision_function_shap:指定决策函数的形状。有ovo、ovr参数值可选,若不指定该参数,则自动使用默认参数值ovr。
14)random_state:随机种子的设置。若不指定该参数值,则自动使用默认参数值None,即使用当前系统时间作为种子,每次随机结果不同。
其主要属性为:

  • support_:支持向量的下标。
  • support_vectors_:支持向量集。
  • n_support:每个分类的支持向量数。
  • dual_coef_:分类决策函数中每个支持向量的系数。
  • coef_:每个特征的系数,仅在线性核下有效。
  • intercept_:决策函数中常数项。

SVM算法的应用

SVC算法中不同参数对分类效果的影响:
1)C:惩罚系数,即对误差的宽容度。
C越大,说明越不能容忍出现误差,容易过拟合; C越小,越容易欠拟合。
需要对C进行选择,以便在平滑的决策边界和分类正确性之间进行平衡。
2)gamma:指定核函数的系数。
隐含地决定了数据映射到新的特征空间的分布: gamma值越大,支持向量越少。

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

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

相关文章

BIM与点云:一种基于航空LiDAR点云的大规模建筑重建

文章&#xff1a;City3D: Large-Scale Building Reconstruction from Airborne LiDAR Point Clouds 作者&#xff1a;Jin Huang , Jantien Stoter , Ravi Peters and Liangliang Nan 编辑&#xff1a;点云PCL 来源&#xff1a;arXiv2023 欢迎各位加入知识星球&#xff0c;获取P…

GeoServer SQL注入漏洞复现(CVE-2023-25157)

0x01 产品简介 GeoServer是一款开源的地理数据服务器软件&#xff0c;主要用于发布、共享和处理各种地理空间数据。它支持众多的地图和空间数据标准&#xff0c;能够使各种设备通过网络来浏览和使用这些地理信息数据。 0x02 漏洞概述 GeoServer在预览图层的时候&#xff0c;可…

Ubuntu20.04平台下使用二进制包部署MongoDB-6.0.4单实例

文章目录 1.1 准备服务器的基本信息1.2 操作系统上创建其用户1.3 部署MongoDB服务端1.4 部署MongoDB客户端1.5 部署MongoDB 27017实例1.5.1 创建相关目录1.5.2 准备配置文件1.5.3 准备启停脚本1.5.4 进行启停测试1.5.5 加入开机自启动 1.6 创建超级管理员用户1.6.1 创建本地的超…

do..while、while、for循环反汇编剖析

1、循环语句重要特征提取 循环语句最重要的特点就是执行的过程中会往上跳&#xff01;&#xff01;&#xff01; 箭头往上跳的一般都是循环语句&#xff0c;比如下面的for循环&#xff1a; 2、do..while语句反汇编 #include<iostream> using namespace std; #pragma …

【SpinalHDL快速入门】2、新建SpinalHDL工程,通过计数器Demo快速上手

文章目录 新建工程各个工具版本build.sbt 示例build.properties 示例如何在IEDA中更新 SpinalVersion 并 Reload sbt Project SpinalHDL入门例子&#xff1a;计数器demo1demo2&#xff08;支持reset信号异步复位&#xff0c;低电平有效&#xff09;demo3&#xff08;一个文件&a…

Flume学习--1、Flume概述、Flume入门、

1、Flume概述 1.1 Flume定义 Flume是Cloudera提供的一个高可用&#xff0c;高可靠的&#xff0c;分布式的海量日志采集、聚合和传输的系统。Flume基于流式结构&#xff0c;灵活简单。 Flume最主要的作用就是实时读取服务器本地磁盘的数据&#xff0c;将数据写入到HDFS。 1.2…

C#winform多国语言应用实例

我们在开发项目中,一般需要软件支持多种语言,供不同客户使用。本文实例讲解实现办法。 1 窗体项目创建 添加控件MenuStrip、comboBox及Button,并修改对应显示文本,combobox编辑项输入英语 确定窗体的Localizable属性为true,自动创建Form1.resx,为False时,没有Form1.r…

基站机房:保障通信网络稳定,如何解决安全隐患?

基站机房作为无线通信网络的关键组成部分&#xff0c;承载着大量的网络设备和通信设施&#xff0c;对于运营商和通信服务提供商来说具有重要意义。 无论是大型运营商还是通信服务提供商&#xff0c;动环监控系统都将成为他们成功运营和管理通信网络的关键工具。 客户案例 案例…

vue使用高德地图--附带移动获取当前城市信息

高德地图 1.使用准备申请密钥vue使用 2.移动地图获取城市案例(注意事项)3.总结 1.使用准备 申请密钥 登录注册高德开放平台进入控制台 创建应用 申请key–生成key和安全密钥(2021之后key需要配合安全密钥使用) 注意&#xff1a;安全密钥需要在key之前 vue使用 首先在pubil…

一款功能强大的报表引擎-VeryReport报表引擎

在企业管理中&#xff0c;数据分析和决策制定是非常重要的环节。而报表则是这个过程中最常用的工具之一。但是&#xff0c;传统的报表设计与展现方式已经无法满足企业对于数据分析和报表展示的需求。为了解决这些问题&#xff0c;我们向大家推荐一款新一代Web报表软件——VeryR…

越是大型企业越需要企业内部知识库?

随着信息时代的到来&#xff0c;越来越多的企业开始注重知识管理。知识管理是一种通过有效地捕捉、共享和利用企业内部的知识资源&#xff0c;促进企业创新和发展的方法。而企业内部知识库作为知识管理的一种重要方式&#xff0c;对于大型企业来说尤为重要。 一、大型企业内部…

苹果相关网站和服务器状态

https://www.apple.com.cn/cn/support/systemstatus/

googlecloud谷歌云的初学体会(1)

googlecloud谷歌云入门&#xff08;1&#xff09; 一、纯小白自述二、云是个什么云三、装一个软件&#xff08;资源、服务&#xff09;四、服务器&#xff08;爷爷提供服务的电脑&#xff09;五、PGSQL的安装六、总结 一、纯小白自述 自己是个小白&#xff0c;仅仅懂得几句sql…

华为OD机试真题 Java 实现【寻找密码】【2023Q1 100分】,附详细解题思路

一、题目描述 小王在进行游戏大闯关,有一个关卡需要输入一个密码才能通过,密码获得的条件如下: 在一个密码本中,每一页都有一个由 26 个小写字母组成的若干位密码,从它的末尾开始依次去掉一位得到的新密码也在密码本中存在。 请输出符合要求的密码,如果由多个符合要求…

爬虫如何选择工具和编程语言

爬虫选择工具和编程语言需要根据具体的需求和技术水平来决定。以下是一些常用的工具和编程语言&#xff1a; 工具&#xff1a; Scrapy&#xff1a;一个基于Python的高级爬虫框架&#xff0c;可用于快速开发和部署爬虫。Beautiful Soup&#xff1a;一个Python库&#xff0c;用…

基于“三维六类”干扰分析模型进行FDD900干扰规避优化指导

1.概述 随着网络发展&#xff0c;鉴于900M覆盖上的优势&#xff0c;为增强深度覆盖及竞对提升&#xff0c;当前FDD 900M已在加快部署&#xff0c;但随之也带来了干扰问题。当前&#xff0c;干扰排查成为FDD 900M部署过程中大量存在的难题。由于干扰排查难度大&#xff0c;且排…

线程池和使用

tip: 作为程序员一定学习编程之道&#xff0c;一定要对代码的编写有追求&#xff0c;不能实现就完事了。我们应该让自己写的代码更加优雅&#xff0c;即使这会费时费力。 推荐&#xff1a;体系化学习Java&#xff08;Java面试专题&#xff09; 文章目录 线程池的目的线程池的参…

360,可真小看你了:耍流氓耍到日本人身上,凌晨2点笑得我胃疼

天下苦流氓软件久矣 大厂的软件&#xff0c;都有点牛皮癣特性&#xff1a;捆绑安装广告推广&#xff0c;简直无所不用其极&#xff0c;身为用户着实无可奈何。 此处点名四大全家桶家族——360、鲁大师、金山毒霸、2345。 说来好笑&#xff0c;之前发的文章不是有关于金山的嘛…

Cefsharp-Winform-113.3.50(chromium5672)最新版体验兼容性测试

一、下载nupkg包(4个)提示:(不支持H264,支持MP3,WEBGL,WEBGL2等)支持H264最新版本109.*自行搜索 winform包地址(依赖包下载地址如下):NuGet Gallery | CefSharp.WinForms 113.3.50 https://globalcdn.nuget.org/packages/cefsharp.winforms.113.3.50.nupkg https://…

仓库拣货标签10代—电子料架

CK_Label_v10 无线电子标签拣货系统特点与效益 无线通信&#xff0c;极简快速部署 超低功耗&#xff0c;墨水屏显示 多彩指示灯&#xff0c;支持24V外接供电 按键及三色高亮LED指示灯指示 3位0.8寸高亮LED数码管显示 提升作业速度与品质 实现无纸化标准化作业 缩短操…