损失函数详解

1.损失函数

      是一种衡量模型与数据吻合程度的算法。损失函数测量实际测量值和预测值之间差距的一种方式。损失函数的值越高预测就越错误,损失函数值越低则预测越接近真实值。对每个单独的观测(数据点)计算损失函数。将所有损失函数(loss function)的值取平均值的函数称为代价函数(cost function),更简单的理解就是损失函数是针对单个样本的,而代价函数是针对所有样本的。

2.为什么要用损失函数?

     由于损失函数测量的是预测值和实际值之间的差距,因此在训练模型时可以使用它们来指导模型的改进(通常的梯度下降法)。在构建模型的过程中,如果特征的权重发生了变化得到了更好或更差的预测,就需要利用损失函数来判断模型中特征的权重是否需要改变,以及改变的方向。

损失函数有很多种,主要可以分为以下几类:

  1. 均方误差损失函数(Mean Squared Error, MSE)

    • 应用场景:通常用于回归问题。
    • 表达式[ MSE = \frac{1}{n} \sum_{i=1}^n (y_i - \hat{y}_i)^2 ]
    • 其中(y_i) 是真实值,(\hat{y}_i)是预测值,(n)是样本数量。
  2. 交叉熵损失函数(Cross-Entropy Loss)

    • 应用场景:常用于分类问题。
    • 二分类交叉熵表达式[ CE = -\frac{1}{n} \sum_{i=1}^n [y_i \log(\hat{y}_i) + (1-y_i) \log(1-\hat{y}_i)] ]
    • 多分类交叉熵表达式[ CE = -\frac{1}{n} \sum_{i=1}^n \sum_{c=1}^C y_{i,c} \log(\hat{y}_{i,c}) ]
    • 其中(y_{i,c})是第(i) 个样本属于类别(c) 的真实标记,(\hat{y}_{i,c})是预测概率。
    • 交叉熵损失函数(Cross-Entropy Loss Function)-CSDN博客
  3. 绝对误差损失函数(Mean Absolute Error, MAE)

    • 应用场景:回归问题。
    • 表达式[ MAE = \frac{1}{n} \sum_{i=1}^n |y_i - \hat{y}_i| ]
  4. Hinge损失函数

    • 应用场景:用于支持向量机(SVM)中的二分类问题。
    • 表达式[ Hinge = \frac{1}{n} \sum_{i=1}^n \max(0, 1 - y_i \times \hat{y}_i) ]
    • 其中(y_i) 是实际类标签(+1 或 -1),(\hat{y}_i) 是预测值。
  5. 对数损失函数(Log Loss)

    • 应用场景:二分类和多分类问题的一种变体,与交叉熵类似。

3.不同的损失函数对神经网络的训练有不同的影响

为了更好地理解不同的损失函数如何影响神经网络的训练结果,以下通过图像生成领域的一个具体示例进行说明:图像超分辨率任务。

问题背景

图像超分辨率任务是指通过输入低分辨率图像生成对应的高分辨率图像。训练神经网络模型以生成高质量的高分辨率图像时,不同的损失函数将对最终结果产生不同的影响。

使用的损失函数类型

  1. 均方误差损失(MSE Loss)
  2. 感知损失(Perceptual Loss)
  3. 对抗损失(Adversarial Loss)
  4. 结构相似度损失(SSIM Loss)

示例任务:超分辨率任务中的不同损失函数影响

  • 输入数据:一组低分辨率图像(如 $32 \times 32$)。
  • 目标输出:对应的高分辨率图像(如$128 \times 128$)。
  • 模型架构:简单的卷积神经网络(CNN)。

不同损失函数对训练的影响

  1. 均方误差损失(MSE Loss)

    • 定义:计算输出图像和目标图像像素之间的均方误差。
    • 公式[ MSE = \frac{1}{n} \sum_{i=1}^n (y_i - \hat{y}_i)^2 ]

          优点:简单,易于计算。

          缺点:忽略了人类视觉系统对图像纹理和细节的敏感性,生成的图像通常看起来模糊。
  2. 感知损失(Perceptual Loss)

    • 定义:通过比较输出图像和目标图像在预训练的卷积神经网络中的某些中间层的特征来计算差异。
    • \mathcal{L}_{perceptual} = \sum_{i=1}^{N} \| \phi_i(y) - \phi_i(\hat{y}) \|
    • 优点:生成的图像在视觉上更贴近目标图像。
    • 缺点:计算复杂度相对较高。
  3. 对抗损失(Adversarial Loss)

    • 定义:通过一个附加的判别器网络,鼓励生成的图像在视觉上无法与真实图像区分。
    • \mathcal{L}_{GAN} = \mathbb{E}[\log D(y)] + \mathbb{E}[\log (1 - D(G(x)))]
    • 优点:生成的图像在细节上更加锐利和真实。
    • 缺点:可能产生伪影(Artifacts),且训练不稳定。
  4. 结构相似度损失(SSIM Loss)

    • 定义:基于亮度、对比度和结构等方面计算输出图像与目标图像之间的结构相似性。
    • \mathcal{L}_{SSIM} = 1 - SSIM(y, \hat{y})
    • 优点:在视觉感知方面更符合人类认知,生成图像的对比度和纹理效果更佳。
    • 缺点:可能无法精确捕获到非常细微的像素差异。

实验结果对比

实验设置:使用相同的数据集和模型架构,仅改变损失函数,比较不同损失函数对超分辨率任务生成效果的影响。

  1. MSE Loss

    • 结果:生成的高分辨率图像相对较模糊,但整体结构准确。
    • PSNR(峰值信噪比):30.5 dB
  2. Perceptual Loss

    • 结果:生成的图像更加锐利且纹理更清晰。
    • PSNR:29.1 dB
  3. Adversarial Loss

    • 结果:生成的图像在细节上更锐利,但可能存在伪影。
    • PSNR:28.7 dB
  4. SSIM Loss

    • 结果:生成的图像在结构相似性上更符合目标图像,但在细节上不如感知损失和对抗损失。
    • PSNR:29.8 dB

     通过以上示例,可以看出不同的损失函数在图像生成任务中产生了不同的效果。具体而言:

  • MSE Loss 适用于追求整体结构的准确性,但会导致图像模糊。
  • Perceptual Loss 在视觉上更符合人类的感知,更加锐利,但PSNR较低。
  • Adversarial Loss 在细节上更锐利,但需要额外的判别器网络,可能引入伪影。
  • SSIM Loss 综合了结构相似性和细节效果,但可能不如其他高级损失函数。

因此,选择损失函数应基于具体应用的目标和需求来定。

4.如何设计损失函数:

设计损失函数时,应考虑以下关键因素:

    损失函数的设计是机器学习和深度学习中的一个核心环节,它需要根据具体任务、数据特性和预期目标进行精细化设计。通过持续的实验和优化,可以显著提高模型的性能和适应性。

  • 问题类型

    • 回归问题:通常使用均方误差(MSE)、平均绝对误差(MAE)等连续值误差度量。
    • 分类问题:使用交叉熵损失(Cross-Entropy Loss)等概率误差度量,如多分类交叉熵损失或二元交叉熵损失。
    • 结构化输出问题:使用特定于任务的损失,例如在序列生成或图像分割中可能使用逐像素交叉熵损失或序列损失。
  • 优化难易度

    • 损失函数需要兼顾易于优化的性质,如避免过多的局部最小值或梯度消失问题。设计时,可以选择平滑且连续的函数形式。
  • 任务特定需求

    • 根据任务的特定需求设计损失函数。例如,在图像增强中可能会优先考虑结构相似性或感知相似性;在对抗性任务中,可能需要设计能够处理生成器和判别器间竞争的对抗性损失。
  • 可解释性和合理性

    • 设计的损失函数应当具备直观的解释性,使模型的行为与优化目标相符,且易于理解和解释。
  • 实践中的设计技巧

  • 损失函数的组合:通常将多个损失函数组合使用,如结合基本损失和正则化项(例如L1正则、L2正则)来提升模型的泛化能力。
  • 感知驱动的设计:在图像处理和语音识别等领域,可以引入基于人类感知特征的损失函数,使模型输出更符合人类的感知习惯。
  • 实验和调整:设计损失函数时,经常需要通过实验来调整和比较不同损失函数的表现,以找到最适合当前任务的函数形式。

4.1在回归问题中计损失函数

我们需要考虑到数据的特性、目标的特点以及模型的健壮性。以下是一个具体的例子,我们将设计一个损失函数来处理潜在的异常值问题,并确保模型能够对大部分数据进行良好的预测。

问题描述

假设我们有一个房价预测问题,其中目标是预测不同地区的房屋售价。房价数据经常会受到异常值的影响,比如极其昂贵或极其便宜的房产。这种情况下,传统的均方误差(MSE)损失函数可能会因为对异常值过于敏感而不是最佳选择。

损失函数设计

为了减少异常值的影响,我们可以设计一个损失函数,结合了均方误差(MSE)和平均绝对误差(MAE),这种组合可以平衡对异常值的敏感度和损失函数的稳定性。

损失函数表达式

我们可以定义一个混合损失函数,如下: [ \text{Hybrid Loss} = \alpha \cdot \text{MSE} + (1 - \alpha) \cdot \text{MAE} ]其中,(\alpha)是一个介于0和1之间的参数,用于调控MSE和MAE的贡献比重。

  • MSE (均方误差)[ \text{MSE} = \frac{1}{n} \sum_{i=1}^n (y_i - \hat{y}_i)^2 ]

  • MAE (平均绝对误差)[ \text{MAE} = \frac{1}{n} \sum_{i=1}^n |y_i - \hat{y}_i| ]

参数选择
  • (\alpha = 0.5)可以开始作为一个基线,这样MSE和MAE各占一半权重。根据模型在验证数据上的表现,我们可以调整 (\alpha) 的值:
    • 如果模型对异常值过于敏感,可以减小 (\alpha),增加MAE的权重。
    • 如果模型需要更精确地拟合数据(即使是一些异常值),可以增加(\alpha),增加MSE的权重。

实验与调整

通过实验和调整,我们可以找到最适合当前数据和任务的(\alpha) 值。通常,这涉及到在交叉验证过程中观察不同 (\alpha) 值的效果,选择在验证集上表现最好的设置。

     通过设计一个混合型损失函数,我们可以有效地处理含有异常值的回归问题,使模型在保持健壮性的同时也能准确预测大部分数据。这种方法提供了灵活性和适应性,适用于各种不同的回归任务和数据集。

4.2在分类问题中设计损失函数

      因为它直接影响到模型的优化方向和最终性能。让我们通过一个多分类问题的例子来说明如何设计损失函数,这里我们考虑的是一个典型的图像分类问题,如识别不同类型的动物。

问题描述

假设我们有一个图像数据集,包含了多种动物,如猫、狗、鸟等。我们的任务是开发一个模型,能够正确分类每一张图片中的动物类型。

损失函数设计

对于多分类问题,常用的损失函数是交叉熵损失(Cross-Entropy Loss),它非常适合处理类别之间互斥的情况(即一张图片只能标记为一个类别)。

交叉熵损失函数

交叉熵损失函数度量的是实际输出概率分布和预测输出概率分布之间的差异。其数学表达式为: [ L = -\sum_{c=1}^M y_c \log(p_c) ]其中:

  • ( M ) 是类别的数量,
  • ( y_c ) 是一个布尔值,表示类别( c ) 是否是正确的分类标签,
  • ( p_c )是模型预测图片属于类别 ( c ) 的概率。
选择和优化
  • 权重: 在类别不平衡的情况下,例如某些类别的样本远多于其他类别,可以为交叉熵损失引入类别权重,使得模型更加关注少数类:[ L = -\sum_{c=1}^M w_c y_c \log(p_c) ]其中,( w_c ) 是类别( c ) 的权重,通常与类别频率成反比。

  • 标签平滑:为了增强模型的泛化能力,防止模型过于自信,可以使用标签平滑技术(Label Smoothing)。这种方法将真实标签的一部分置信度分配给其他错误标签,从而软化真实标签:[ y_c' = y_c(1 - \epsilon) + \epsilon / M ]其中( \epsilon )是一个小的常数(如0.1),这样每个类别都会得到一小部分置信度。

实验与调整

  • 通过在验证集上评估模型性能,调整类别权重和标签平滑参数。
  • 观察混淆矩阵,了解模型在哪些类别上表现不佳,可能需要调整特定类别的权重或收集更多数据。

在多分类问题中,交叉熵损失是一个强大的工具,特别是结合类别权重和标签平滑技术,可以显著提高模型对不平衡数据的分类精度和泛化能力。通过不断试验和优化,我们可以为具体问题找到最适合的损失函数配置。

5图像应用中常见的损失函数

5.1图像分割任务

图像分割的目标是将图像中的每个像素分配到一个特定的类别(如对象、背景等)。这一任务可以看作是逐像素的分类问题,因此常用的损失函数在本质上与分类任务相似,但也有专门针对分割特性的优化和变体。

常见的图像分割损失函数

  1. 交叉熵损失(Cross-Entropy Loss)

    • 就像在普通的分类任务中一样,交叉熵损失也可以用于图像分割。它逐像素计算预测分类的概率和实际分类的匹配程度。
    • 对于多类分割问题,通常使用多类交叉熵损失。
  2. Dice Loss

    • Dice Loss基于Dice系数,后者是一种衡量两个样本相似度的统计工具,特别适用于样本大小不平衡的情况。Dice Loss特别适合处理医学图像分割中的小结构或不平衡类别。
    • 公式为:[ L = 1 - \frac{2 \times \text{TP}}{2 \times \text{TP} + \text{FP} + \text{FN}} ] 其中TP, FP, FN分别代表真正例、假正例和假负例。
  3. Jaccard Loss(IoU Loss)

    • Jaccard Loss基于Jaccard指数,也称为交并比(IoU)。这是评估分割质量的一个常用指标,计算预测分割区域和真实分割区域的交集与并集的比例。
    • 它与Dice Loss类似,但在某些场合,Jaccard指数对边界不匹配的惩罚更大。
  4. Tversky Loss

    • Tversky Loss是Dice Loss的一种变体,允许对假正例和假负例的权重进行不对称调整,这在处理极不平衡的数据集时尤为有用。
  5. 组合损失

    • 在实际应用中,为了同时兼顾不同的评价指标和性能,研究者可能会结合多种损失函数,如交叉熵和Dice损失的组合,以便更有效地训练模型。
  6. Focal Loss

    • Focal Loss是对交叉熵损失的一种改进,主要解决类别不平衡问题,通过减少对易分类样本的关注来提高模型对难分类样本的关注度。

选择损失函数

选择哪种损失函数取决于特定的应用场景、类别平衡、预期的分割性能等因素。例如,医学图像分割中常常偏好使用Dice Loss因其对小区域和边缘的高敏感性。而在需要强调全局准确性的情况下,结合交叉熵和IoU损失可能更为合适。

 5.2图形分类的损失函数

在图像分类任务中,常用的损失函数主要基于预测类别和实际类别之间的差异。以下是一些常见的图像分类损失函数:

  1. 交叉熵损失(Cross-Entropy Loss)

    这是图像分类中最常用的损失函数之一。对于二分类问题,它通常被称为二元交叉熵损失(Binary Cross-Entropy Loss)。对于多分类问题,它通常被称为多类交叉熵损失(Categorical Cross-Entropy Loss),其中预测的是一个多维概率分布。
  2. 稀疏交叉熵损失(Sparse Categorical Cross-Entropy Loss)

    与普通交叉熵损失类似,但适用于稀疏标签表示(即标签以整数形式给出,而不是独热编码)。
  3. 平方误差损失(Mean Squared Error Loss, MSE Loss)

    主要用于回归任务,但在某些分类场景中也可用。它计算预测值与实际值之间的均方差,用于评估模型性能。
  4. KL散度损失(KL Divergence Loss)

    KL散度衡量两个概率分布之间的差异。对于分类问题,如果有两个概率分布(例如模型预测分布和目标分布),KL散度可以作为损失函数使用。
  5. 焦点损失(Focal Loss)

    这是一种改进的交叉熵损失函数,旨在解决类别不平衡问题。它通过减小对易分类样本的关注,增强对难分类样本的学习,适用于类别分布不平衡的情况。
  6. 对比损失(Contrastive Loss)

    通常用于度量学习和孪生网络,它使得来自同一类的样本距离更近,来自不同类别的样本距离更远。
  7. 标签平滑损失(Label Smoothing Loss)

    这是交叉熵损失的一种改进版本,在计算损失时引入了标签平滑,以减轻模型的过拟合风险。

不同的损失函数在图像分类任务中有各自的优势和劣势,选择适当的损失函数取决于数据集的特性、模型的结构和任务的具体需求。

5.3目标检测的损失函数

目标检测是计算机视觉领域中的一项任务,它涉及到检测图像中的多个目标,并预测每个目标的类别和位置。目标检测模型通常使用复合损失函数,这些损失函数同时考虑类别预测的准确性和边界框(bounding box)的精度。以下是一些常见的目标检测损失函数:

  1. 交叉熵损失(Cross-Entropy Loss)

    用于类别预测。对于目标检测中的每个预测框,模型需要确定是否包含对象,以及对象的类别是什么。
  2. 均方误差损失(Mean Squared Error, MSE)

    用于边界框的回归。这种损失函数衡量预测的边界框和真实边界框之间的差异。
  3. IOU(交并比,Intersection over Union)损失或GIoU、DIoU、CIoU损失

    这些损失函数基于交并比,即预测框和真实框之间的交集与并集的比例。GIoUGeneralized IOU), DIoU(Distance IOU)和CIoU(Complete IOU)是IOU损失的改进版本,它们在某些情况下可以提供更稳定的梯度和更好的收敛性能。
  4. 锚框损失(Anchor Box Losses)

    在使用基于锚框的目标检测模型(如Faster R-CNN)时,这类损失函数对每个锚框执行分类和回归。
  5. Focal Loss

    由于目标检测中经常出现大量的负样本(即不包含目标的预测框),Focal Loss 被设计来加重对难以分类样本的关注,减少对容易分类样本的关注,从而解决类别不平衡问题。
  6. Smooth L1 Loss

    这是一种在目标检测中常用的边界框回归损失函数,它是L1损失的平滑版本,可以减少离群点对损失函数的影响,通常在边界框坐标预测中使用。
  7. 组合损失

    在实际应用中,目标检测模型通常使用以上多种损失函数的组合,例如,在YOLO和SSD这类模型中,会同时使用交叉熵损失和均方误差损失或Smooth L1损失。

选择哪种损失函数取决于具体的目标检测模型和任务需求。各种损失函数的组合能够同时优化分类和定位任务,提高目标检测的整体性能。

5.4图形增强的损失函数

图像增强是一种旨在改善或改变图像视觉质量的技术。它可以用于提高图像的可视性、可用性或感兴趣特征的突出度。图像增强在计算机视觉和机器学习任务中有着广泛的应用。在使用深度学习进行图像增强时,需要定义适当的损失函数以优化模型性能。以下是一些常见的图像增强损失函数:

  1. 均方误差(Mean Squared Error, MSE)

    衡量生成或增强后的图像与目标图像之间的像素差异。MSE计算两个图像每个像素之间的误差平方和的平均值。
  2. 平均绝对误差(Mean Absolute Error, MAE)

    与MSE相似,但它计算的是每个像素的绝对误差的平均值。相对于MSE,MAE对异常值的敏感度较低。
  3. 结构相似性(Structural Similarity, SSIM)

    用于衡量两幅图像之间的结构相似性。SSIM综合考虑了亮度、对比度和结构三个方面,使其在视觉质量上与人类视觉感知更为接近。
  4. 感知损失(Perceptual Loss)

    通过使用预先训练的神经网络(如VGG网络)计算特征之间的差异,将图像的高级特征作为视觉相似度的衡量标准,使得增强后的图像在感知上更接近目标图像。
  5. 对抗性损失(Adversarial Loss)

    在生成对抗网络(GAN)结构中,判别器会学习将生成的图像与真实图像区分开来。生成器的目标是生成尽可能真实的图像以欺骗判别器。这种损失通常与其他损失函数结合使用,以增强生成图像的真实性。
  6. 特定应用的损失函数

    例如在超分辨率(Super-Resolution)任务中,可能使用多尺度结构相似性损失、多尺度对抗性损失等,以适应不同的图像质量评价需求。

这些损失函数或其组合通常用于各种图像增强任务中,包括图像超分辨率、去噪、着色、风格迁移等。损失函数的选择取决于具体的图像增强任务及其目标要求。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Baidu Comate:你的智能编码助手,编程效率倍增的秘密武器

Baidu Comate智能编码助手 Baidu Comate 智能编码助手简单介绍安装使用查看Comate插件功能智能代码提示使用飞浆和百度智能小程序进行智能问答使用AutoWork插件实现二次函数图像的生成引用Comate知识库存在的问题结束语 Baidu Comate 智能编码助手简单介绍 Baidu Comate&#x…

设计模式(十一):外观模式

设计模式(十一):外观模式 1. 外观模式的介绍2. 外观模式的类图3. 外观模式的实现3.1 创建一个接口3.2 创建接口的实现3.3 创建一个外观类3.4 测试 1. 外观模式的介绍 外观模式(Facade Pattern)属于结构型模式&#xf…

Jupyter Notebook输入python代码没智能提示

1、在Jupyter中打开控制台 2、再控制台中执行以下两个命令: pip install jupyter_contrib_nbextensions jupyter contrib nbextension install --user pip install jupyter_contrib_nbextensions命令需要下载文件,请耐心等待。 3、执行完成后&#xff0…

202003青少年软件编程(Python)等级考试试卷(二级)

第 1 题 【单选题】 运行下方代码段,输出的结果是(   )。 a=(1,2,3)print(type(a))A :<class ‘float’> B :<class ‘int’> C :<class ‘str’> D :<class ‘tuple’> 正确答案:D 试题解析: 第 2 题 【单选题】 content.txt中原来的内容…

第11篇:创建Nios II工程之控制多个七段数码管

Q&#xff1a;DE2-115开发板上有8个七段数码管&#xff0c;如何用PIO IP并设计Nios II工程控制呢&#xff1f; A&#xff1a;基本思路&#xff1a;DE2-115上有8个7位七段数码管&#xff0c;而一个PIO最多可配置为32位&#xff0c;如此就可以添加2个PIO都配置为28位output。 Ni…

《500 Lines or Less》(13)—— A 3D Modeller

原文 作者 原code 我用py3重写的code 3D 建模器 介绍 计算机辅助设计&#xff08;Computer-aided design, CAD&#xff09;工具允许我们在2D屏幕上查看和编辑3D对象。为此&#xff0c;CAD工具必须具有3个基本功能&#xff1a; 表示对象&#xff1a;使用一种数据结构保存和表示…

SpringBoot的@Async注解有什么坑?

前言 SpringBoot中&#xff0c;Async注解可以实现异步线程调用&#xff0c;用法简单&#xff0c;体验舒适。 但是你一定碰到过异步调用不生效的情况&#xff0c;今天这篇文章总结了Async注解的坑点&#xff0c;希望对你会有所帮助。 未启用异步支持 Spring Boot默认情况下不启…

2024年短剧小程序视频怎么下载

想在闲暇之余轻松追剧&#xff0c;但不想跳转复杂的网页或者安装多个APP吗&#xff1f;来试试2024年的短剧小程序视频下载器吧&#xff01;它是一款专门为短剧爱好者打造的视频下载工具&#xff0c;让你轻松下载任何短剧小程序视频&#xff0c;随时随地享受精彩的短剧内容&…

Python密码测试程序

下面是一个简单的 Python 密码测试程序&#xff0c;用于检查用户输入的密码是否符合一些基本的安全要求&#xff0c;如长度、包含字母和数字等。这个程序可以作为一个基本的密码验证器&#xff0c;你可以根据需要进行修改和扩展。 1、问题背景 我们正在编写一个程序&#xff0…

解决 git克隆拉取代码报SSL certificate problem错误

问题&#xff1a;拉取代码时报错&#xff0c;SSL证书问题:证书链中的自签名证书问题 解决&#xff1a;只需要关闭证书验证&#xff0c;执行下面代码即可&#xff1a; git config --global http.sslVerify "false" 再次拉取代码就可以了

ssh远程免密登录

ssh远程连接分为五个阶段 版本号协商阶段密钥和算法协商阶段认证阶段会话请求阶段交互会话阶段 而上图的SessionKey即是在阶段2&#xff1a;密钥和算法协商阶段&#xff0c;服务器端和客户端利用DH交换&#xff08;Diffie-Hellman Exchange&#xff09;算法、主机密钥对等参数…

零基础自学网络安全/Web安全(超详细入门到进阶)学完即可就业(含学习笔记)

一、为什么选择网络安全&#xff1f; 这几年随着我国《国家网络空间安全战略》《网络安全法》《网络安全等级保护2.0》等一系列政策/法规/标准的持续落地&#xff0c;网络安全行业地位、薪资随之水涨船高。 未来3-5年&#xff0c;是安全行业的黄金发展期&#xff0c;提前踏入…

【前端】HTML实现个人简历信息填写页面

文章目录 前言一、综合案例&#xff1a;个人简历信息填写页面 前言 这篇博客仅仅是对HTML的基本结构进行了一些说明&#xff0c;关于HTML的更多讲解以及CSS、Javascript部分的讲解可以关注一下下面的专栏&#xff0c;会持续更新的。 链接&#xff1a; Web前端学习专栏 下面我对…

OpenNJet 应用引擎:在 NGINX 基础上的云原生增强

目录 一、初识OpenNJet二、系统架构三、动手实践1.CentOS 编译环境配置1.1配置yum源&#xff1a;1.2.yum安装软件包1.3.创建符号连接 2.编译代码编译 OpenNJet执行 make 四、基本使用说明1.目录结构概述:2.常用命令: 五、部署 Web 应用程序配置文件修改启动 NJet 六、总结 一、…

设计宝典与速查手册,设计师必备资料合集

一、资料描述 本套设计资料&#xff0c;大小194.34M&#xff0c;共有13个文件。 二、资料目录 01-《商业设计宝典》.pdf 02-《色彩速查宝典》.pdf 03-《配色宝典》.pdf 04-《解读色彩情感密码》.pdf 05-《行业色彩应用宝典》.pdf 06-《构图宝典》.pdf 07-《创意宝典》…

PXE 批量安装部署

目录 一、PEX批量部署优点 二、PXE&#xff1a;预启动执行环境 三、搭建PXE远程服务器 要想全自动安装 接下来请看步骤&#xff1a; 一、PEX批量部署优点 规模化&#xff1a;同时装配多台服务器自动化&#xff1a;安装系统 配置各种服务远程实现&#xff1a;不需要光盘&…

勾股定理 口诀

def t_o(a):t int(a/2)b t*t-1c t*t1f (a*ab*bc*c)print(f,ou,a,b,c,a*ab*b,c*c)def t_j(a):t a*abint(t/2)c t-bf (a*ab*bc*c)print(f,j-,a,b,c,f,a*ab*b,c*c)for i in range(2,100,2):t_o(i)t_j(i1) 奇数平方写连续 偶数半方加减一

“A”分考试经验分享:云计算HCIE考试请注意这几点...

大家好&#xff0c;我是誉天云计算HCIE的王同学&#xff0c;于4月2日"A"分通过了云计算3.0 HCIE的认证考试。 首先感谢誉天教育对我的辅导&#xff0c;感谢苗苗老师和石老师对我的帮助&#xff0c;通过这次考试让我对华为云计算有了一定的了解。接下来我就与大家分享…

力扣刷题--数组--第一天

一、数组 数组特点&#xff1a; 连续内存空间存储得数据元素类型一致数组可以通过下标索引查找数据元素&#xff0c;可以删除、替换、添加元素等 1.1 二分查找 使用二分查找需满足得条件&#xff1a; 数组是有序的&#xff1b;数组中没有重复元素&#xff1b;查找的target…

PHP+B/S架构 不良事件管理系统源码 医院不良事件报告系统源码,开发技术vue2+element+laravel8

PHPB/S架构 不良事件管理系统源码 医院不良事件报告系统源码&#xff0c;开发技术vue2elementlaravel8 技术架构&#xff1a;前后端分离&#xff0c;仓储模式&#xff0c;BS架构&#xff0c; 开发技术&#xff1a;PHPvscodevue2elementlaravel8mysql5.7&#xff0c;专业团队研…