MiniCPM:揭示端侧大语言模型的无限潜力

技术博客链接:

🔗https://shengdinghu.notion.site/MiniCPM

➤ Github地址:

🔗https://github.com/OpenBMB/MiniCPM

➤ Hugging Face地址:

🔗https://huggingface.co/openbmb/MiniCPM-2B-sft-bf16

1 简介

MiniCPM 是一系列端侧语言大模型,主体语言模型 MiniCPM-2B 具有 2.4B 的非词嵌入参数量。在综合性榜单上与 Mistral-7B 相近(中文、数学、代码能力更优),整体性能超越 Llama2-13B、MPT-30B、Falcon-40B 等模型。在当前最接近用户体感的榜单 MTBench 上,MiniCPM-2B 也超越了 Llama2-70B-Chat、Vicuna-33B、Mistral-7B-Instruct-v0.1、Zephyr-7B-alpha 等众多代表性开源大模型。

我们将完全开源 MiniCPM-2B 的模型参数供学术研究和有限商用,以及训练过程中的所有 Checkpoint 和大部分非专有数据给模型机理研究。

具体而言,我们已开源以下模型

  • 基于 MiniCPM-2B 的指令微调与人类偏好对齐的 MiniCPM-2B-SFT/DPO
  • 基于 MiniCPM-2B 的多模态模型 MiniCPM-V,能力超越基于 Phi-2 的同参数级别多模态模型。‍‍‍‍‍
  • MiniCPM-2B-SFT/DPO 的 Int4 量化版 MiniCPM-2B-SFT/DPO-Int4。
  • 基于 MLC-LLM、LLMFarm 开发的 MiniCPM 手机端程序,文本及多模态模型均可在手机端进行推理。

模型整体性能:

局限性

  • 受限于模型规模,模型可能出现幻觉性问题。其中由于 DPO 模型生成的回复内容更长,更容易出现幻觉。我们也将持续进行 MiniCPM 模型的迭代改进;
  • 为了保证在学术研究用途上模型的通用性,我们未对模型进行任何身份认同训练。同时由于我们用 ShareGPT 开源语料作为部分训练数据,模型可能会输出类似 GPT 系列模型的身份认同信息;
  • 受限于模型规模,模型的输出受到提示词(prompt)的影响较大,可能多次尝试产生不一致的结果;
  • 受限于模型容量,模型的知识记忆较不准确,后续我们将结合 RAG 方法来增强模型的知识记忆能力。

2 模型沙盒实验(Model Sandbox)

大模型的实验成本高昂,难以在不进行配置调优的情况下得到最优秀的大模型性能。

借鉴 μΡ 等优秀的前人工作,我们提出在小模型上进行广泛的实验,通过可迁移的配置,获得大模型的最优训练方法。MiniCPM 本身,即为模型沙盒实验的成果。

我们进行了 Hyper-parameters、Batch size、Learning Rate、Learning Rate Scheduler、Data Strategy 五个方面的模型沙盒研究。

  • 超参稳定的模型规模扩增

超参数对模型的性能具有重大影响,在传统训练方法中,需要对每个模型进行超参数调整,这对于大模型并不现实。借鉴 μP 的方法,我们对模型的各参数模块之间进行了连接权重的调整、以及对模型初始化的调整。部分调整接近 Cerebras-GPT。

整体方案如下:

上述操作的具体参数由近 400 次在 0.009B 模型规模上的贝叶斯参数搜索得到。

  • 最优 Batchsize

Batchsize 决定了模型的收敛速度和消耗计算资源的平衡。Batchsize 过大,达到一定的损失消耗的数据量和计算量都会很大,而 batchsize 过小,则需要消耗过多的训练步数,且有可能损失函数下降有限。在 2020 年 OpenAI 的开山之作中,OpenAI 研究了损失函数随 token 数变化的规律。在他们的实验中,他们将认为消耗更多的步数等价于消耗更多的时间,在这种假设下,OpenAI 定义了临界 Batchsize(Critical Batchsize),使得达到一定的损失,既不消耗过多 step,也不消耗过多 token。然而我们观察到在利用当前以 A100 为主的计算资源,结合 gradient checkpointing 策略进行训练时,通常计算速度(而不是显存)是瓶颈,这意味着在相同机器数量下,多一倍 Batchsize 几乎等同于慢一倍的单步时间。基于这个观察,我们取消了对“不消耗过多 step ”的追求,而转向追求用最少的token量达到最低的 loss。

我们在 0.009B,0.036B,0.17B 的模型上分别进行了 6 个 batchsize 的训练实验,将结果记录如图下。

我们观察到了最优 batchsize 随着 C4 数据集上的 loss 的偏移规律(图中的红线)。

连接上述的红线(log scale 之后)并拟合

将这三个图的红线进行连接,并进行拟合,我们得到了如下 Batchsize 关于 C4 Loss 的规律:

根据这个规律,我们预估了 2B 模型达到 C4 损失 2.5 左右,4M 是比较合适的 Batchsize。

  • 最优学习率

由于我们使用了超参稳定的参数化方案,我们预期模型的最关键超参数:学习率,不会因为模型规模扩大有大幅度的改变,因此我们在 0.04B, 0.1B, 0.3B, 0.5B 上分别做了 6 组学习率实验,我们发现虽然模型大小扩大了 10 倍,但是最优学习率偏移并不明显,均在 0.01 左右,我们在 2.1B 的规模上进行了简单验证,发现在 0.01 的学习率确实能取得最低的 Loss。

  • 最优学习率调度器( WSD 调度器)

学习率调度器,即训练不同阶段使用不同学习率的调整策略,对模型性能影响很关键。当前通用的学习率策略是 Cosine 图像,即在学习率从 Warmup 阶段升高到最高点之后,开始呈现余弦函数的降低。几乎所有大模型都使用了 Cosine Learning Rate Scheduler (简称 Cosine LRS )的方式。

为了研究为什么 Cosine 的 Scheduler 表现优异,我们进行了大量实验。我们对0.036B 的模型,设置不同的 Learning Rate Scheduler 的截止步数 Τ,进行了持续训练。结果如下图:

从图中可以看出,对于训练至 S 步的模型,将 Cosine LRS 的截止步数 Τ 设置为 S步总是能获得最优的性能,而设置为更多或者更少性能都不是最优。

当我们考虑持续训练的场景,会发现 Cosine 调度器的问题有更多问题。如果我们在 Cosine 的截止步数之后继续沿用 0.1 倍的最大学习率(通常做法),则继续训练收敛非常缓慢;如果我们在 Cosine 的截止步数之后重启 Cosine LRS(即再次从最大学习率开始下降,或者是逐渐上升到最大学习率,再开始下降)则会发现损失会经历长时间的上升周期,而这段时间,模型处于不可用状态。

我们猜想 Cosine LRS 在预先指定步数的时候性能优异的原因有两点:

  • T=S 下的 Cosine LRS,相对于 Linear LRS、Noam LRS、以及 T<S 的 Cosine LRS,有更长时间的大学习率训练。这一阶段可能有助于模型寻找更好的全局最优解。
  • T=S 下的 Cosine LRS ,相对于 T>S 的 Cosine LRS、Constant LRS,有更充分的学习率下降的退火阶段,这一阶段可能发生了较为特别的动力学现象,导致模型可以找到更好的局部最优解。

结合这两点,我们提出了一种新的学习率调度策略,Warmup-Stable-Decay(WSD)调度器。这种学习率调度器分为三个阶段,warmup 阶段(用 W 表示warmup 阶段结束时的步数/训练量),稳定训练阶段(用 S 表示稳定训练阶段结束时的步数/训练量),退火阶段(用 D 表示退火阶段的训练量)。这种调度器可以写为:

其中 0<ƒ(s-S)≤1 是一个关于 s 的减函数,η是最大学习率。这种策略有以下四个好处:

  • 可以持续训练。
  • 可以随时取出。
  • 性能优于 Cosine LRS。
  • 有显式区分的训练阶段,便于使用不同的数据策略。

WSD 和 Cosine LRS 的图像对比如下:

图中显示了 CosineWSD(W, S, D) 学习率调度器和 Cosine 的对比。可以看到,在 Cosine 调度器结束之后需要持续保持最低学习率,以保证 loss 不上升,而 WSD 调度器则可以从退火之前开始继续用最大学习率训练,经过更长的训练再开始退火。

我们发现如我们所设想的,在 Decay 阶段(退火阶段),随着学习率的变小,损失有大幅度的快速下降,在步数S时迅速降低至和 T=S 的 Cosine LRS 相等或更低。与此同时,我们可以复用Decay前的模型,进行大学习率的继续训练,在更多的步数 S’ 之后进行退火,取得和 T’=S’ 的 Cosine LRS 相等的效果。

图中最下方的橙色线为 Cosine LRS,上方绿色线为 WSD LRS。尽管 WSD LRS 在学习率恒定的 stable 阶段表现差于 Cosine,但是在最后的退火阶段,会形成快速下降的趋势,最终达到或者超越 Cosine LRS。我们尝试了不同的退火步长,例如 WSD(N, 80N, 2N) 的退火比例为 2/80 = 2.5%, 而WSD(N, 80,N, 8N) 的比例为 8/80 = 10%。我们发现在我们测试的 4 个训练阶段(20N,40N, 60N,80N),2.5% 的退火长度都不够达到最优的性能。而 10% 的退火长度则足够达到甚至超越Cosine LRS。

我们对 Decay 阶段的训练步数需求进行了探索。我们发现在所有训练时长中,总步数 10% 的 Decay 都足够达到最好的效果,而 2.5% 的 Decay 都较为欠缺。因此我们最终将 Decay 的步数定为最后10%。

  • Batchsize 调度

根据 Batchsize 随损失变化的实验结果,不难猜想,用更大的 Batchsize 可能可以达到更低的 loss。我们在 0.036B、2.4B 的模型实验中都发现了类似的现象,即在扩大Batchsize 的时候损失会有一次较大幅度的下降(我们猜想 Batchsize 扩大和Learning Rate 降低可能有相似的动力学效果)。如下图所示,我们进行了 Batch size 扩大,Loss 降低约0.2,并且在后续的退火阶段,仍然能形成一样的下降效果。但是遗憾的是,在我们正式实验中,我们进行的 Batchsize 扩大后退火阶段的降低有所减少,因此我们最终没有采用 Batchsize 扩大的训练方法。这个问题留作后续研究。

0.036B 的模型在 Batchsize 扩大以后 loss 有降低

  • 固定大小模型持续训练最多可以达到几倍的大模型?

由于我们的 WSD 学习率优化器可以在任何阶段退火,取得该阶段最优的模型,因此我们有机会探索,如果持续训练一个大小为 N 的模型,最优情况下能超过多大参数量的 Chinchilla-Optimal 模型。

首先我们估计了持续训练过程中,模型性能随计算量的变化。由于不确定函数形式,我们尝试了两种拟合公式。

指数形式:

幂律形式:

两种函数的拟合结果如图:

因此我们认为幂律形式的拟合效果更好。通过拟合我们得到 0.036B 持续训练,最终理论上可以达到 3.27 的 C4 Loss。为了从直观上估计和感受,在可接受的训练时长内,0.036B 模型可以达到多大的 Chinchilla Optimal 模型的效果,我们同样以最优配置训练了一个 0.17B 的模型。0.17B 模型在 Chinchilla Optimal 数据量下训练,消耗的计算量为

在这个计算量下,0.036B 的模型可以获得 3.37 的 C4 Loss,与 0.17B 的模型的 3.34 Loss 接近。因此我们认为一个模型用我们的 WSD 调度器训练,在消耗等量计算量时,可以达到约 5 倍模型参数量的 Chinchilla-Optimal 模型。而持续训练下去,有可能超越更大的 Chinchilla-optimal 模型。

我们在 MiniCPM 上进行了验证。我们以完全相同的数据配方训练了 0.036B、0.1B、0.2B、0.5B、0.8B,1.2B 六个小模型,分别至其 Chinchilla Optimal 的数据量。绘制得到 Scaling 图像如下,根据这个图像,我们可以预测 9B 模型的 Chinchilla Optimal 的终态 C4 Loss 约为 2.40,7B 模型约为 2.45。MiniCPM 的最终C4 Loss 为 2.41,接近于 9B 的 Chinchilla Optimal 模型。

-CO意为Chinchilla Optima

  • 持续训练友好的数据策略

由于 WSD LRS 的退火阶段模型会有较大幅度的损失下降,我们猜想在这个阶段加入高质量数据,会有如下两个优点:

  1. 相对于在 sft 阶段加入高质量数据,在退火阶段加入数据,模型学习更充分。
  2. 相对于在 pretrain 一开始阶段加入高质量数据,更能支持小数据的训练,否则在一个未预先定好训练步数的持续预训练过程中,小数据会重复过多次数,造成负面影响。

基于这两点猜想,我们提出:在预训练阶段只使用通用、量大的预训练粗质量数据,而在退火阶段,使用非常广泛的高质量知识和能力数据以及 SFT 的高质量数据,混合入预训练数据进行退火。

为了验证我们的方法与直接SFT相比的优势,我们从一个中间检查点开始进行了两组实验。

实验 A:仅使用预训练数据进行退火,接着进行 4B token 的 SFT。

实验 B:使用如上的高质量数据+SFT数据混入预训练数据进行退火,同样进行 4B token 的 SFT。

两组实验结果如下:

实验结果表明在退火开始时加入高质量数据的收益远高于在退火完成后的sft阶段加入。因此我们建议模型能力的特化和增强应从退火阶段开始进行。

3 词表

MiniCPM 模型作为通用模型,具备英文、中文、中国古文、代码、颜文字,其他语言等多方面能力,因此词表相对较大,大小为 122753。该词表构建于大量综合语料上,使用 sentencepiece 库进行 BPE,添加了包括繁体中文、罕见字、emoji、希腊字母、俄文字母等等特殊符号。

我们在中文、英文、代码、论文各 30 万篇非训练文档上进行了压缩率测量,MiniCPM 的 tokenizer 取得了最高的压缩率(Bytes/Tokens)

共享输入输出层

词表的大小主要决定了模型覆盖面的宽窄,而不决定模型本身的能力深浅。在大模型参数规模下,词嵌入参数量可以忽略不计,但是小模型下却不可忽视,因此我们使用了 tie_word_embedding 的方案进一步减少参数量,即输出层和输入层共享参数,在预实验中,我们发现这几乎不会牺牲性能。在使用 tie_word_embedding 后,MiniCPM 的词嵌入为 2340 x 122753~0.28B 的参数量

4 两阶段预训练

  • 稳定训练阶段

我们使用了 1T 的去重后的数据,其中大部分数据从开源数据中收集来,比例如下图。

我们使用了模型沙盒实验中探索出的最优配置,WSD LRS,batchsize 为 3.93M,Max Learning Rate 为 0.01。

  • 退火阶段

我们的 sft 数据配比如下:

最终我们两阶段预训练的过程中,C4 Loss 的变化如下图,在 263000 步(约 1T 数据)时,开始进行退火,退火过程也变现出了损失函数急剧下降的现象,同时在各种任务数据、SFT 数据上的 Loss 也有显著下降。

具体在 WSD 调度器的退火形式上,我们采用了指数退火,

即:

其中T为退火的半衰期,我们设置为 T=8000步。

整个训练过程中,C4 训练集上 Loss,由于数据不重复,所以训练集 loss 可以当作验证集 Loss。

5 对齐

在上述获得的基础模型之上,我们进行了对齐(alignment)。尽管 sft 的数据已经加入退火阶段,但是我们发现仍然有必要进行 SFT 阶段,换言之,退火阶段和 SFT 阶段缺一不可。我们使用了和退火阶段类似的SFT 数据(不同的是将预训练数据去除)。我们进行了约 6B token 的 SFT 训练。SFT 的学习率衔接上退火结束的学习率,为 1e-3,同样使用了 WSD Scheduler。

在 SFT 之后,我们采用 DPO 对模型进行进一步的人类偏好对齐。在这一阶段,我们采用 UltraFeedback 作为主要的对齐数据集,并内部构建了一个用于增强模型代码和数学能力的偏好数据集。我们进行了一个 Epoch 的 DPO 训练,学习率为 1e-5且使用 Cosine Scheduler。更多 DPO 和数据设置细节可以可见我们 UltraFeedback 论文。

6 全面评测

  • 榜单

➤ SFT模型:MiniCPM-sft

整体评测使用了我们的开源工具 UltraEval。UltraEval 是一个开源的基础模型能力评测框架,提供了一套轻量级、易于使用的评测体系,支持主流大模型的性能评估,服务模型训练团队的快速评测需求。底层使用开源框架 vLLM 进行推理和加速,数据集选取了常用的权威数据集,包括:

  • 英文,选取了 MMLU
  • 中文,选取了 CMMLU、C-Eval
  • 代码,选取了 HumanEval、MBPP
  • 数学,选取了 GSM8K、MATH
  • 问答,选取了 HellaSwag、ARC-E、ARC-C
  • 逻辑,选取了 BBH

由于大模型评测比较难以统一,且大量评测也没有公开的 prompt 和测试代码,对于具体评测方式,我们只能尽量做到适合各类模型。整体而言,我们测试时采用统一的输入 prompt,并会按照各自模型适合的模板进行调整。模型评测脚本及 prompt 已开源在我们的 Github 仓库中,也欢迎更多开发者来不断改进我们的评测方式。

整体评测结果如下。总体而言,MiniCPM 在上述数据集上,英文均分与 Mistral-7B-v0.1 相近,中文均分显著优于 Mistral-7B-v0.1。

以下是具体评测结果:

与大模型相比:超过或持平大部分 7B 规模模型,超越部分 10B 以上的模型。

与小模型对比,除部分英文评测集外,其他测试集均超过现有模型。

与Chat模型比较。

注:

  1. MiniCPM 的评测时模型推理使用的是 vllm=0.2.2,这是一个我们在两个月前fork 的稳定版本,我们计划不久后将和 vllm 官方沟通,将推理代码增加至 vllm官方仓库。而 Mistral-7B-v0.1 则用的是 vllm 最新的 vllm=0.2.7。
  2. 我们对 QA 任务进行测试时,通常可能采用两种方式,第一种是 PPL:将选项作为题目延续时的 PPL 作为选择指标 (以上表格中*表示使用 PPL),第二种是直接生成,直接让模型输出答案选项。我们发现,这两种方式得到的结果差异较大。事实上,MiniCPM 在直接生成和 PPL 的测试结果接近,直接生成的表现性能较好,而 Mistral-7B-v0.1 则在 PPL 上表现较好,直接生成上效果较差。为了应对这种现象,我们汇报每个模型的分数时,采纳两种评测方式得分最高方式的得分,以此保证对比的公平性。
  3. 我们观察到,虽然 Phi-2 的评测结果超过 Mistral-7B,但是实用体感并没有达到同等水平。

➤ DPO 模型:MiniCPM-dpo

在使用 DPO 完成偏好对齐后,模型在 MT-Bench 上的分数从 SFT 后的 6.89 上涨至7.25,甚至超过了包括 Llama2-70B-Chat 在内的大模型。

  • 典型案例

我们挑选了一些展示 MiniCPM-2B 通用能力的例子。这些例子说明了 MiniCPM 的能力多样性。

➤ 知识推理

➤ 代码

➤ 数学

➤ 翻译

➤ 特殊任务

7 量化:MiniCPM-SFT/DOP-int4

为进一步降低 MiniCPM 的计算开销,使用 GPT-Q 方法将 MiniCPM 量化为 int4 版本。相较于 bfloat16 版本与 float32 版本,使用 int4 版本时,模型存储开销更少,推理速度更快。量化模型时,我们量化 Embedding 层、LayerNorm 层外的模型参数。

依照上述放缩系数和零点,w 量化后为

其中取整函数 round()为向最近整数取整。反量化时,操作方式如下:

使用 GPT-Q 方法进行量化时,在标注数据 X 上最小化量化误差

并循环对矩阵的未量化权重进行如下更新,其中 q 是当前量化的参数位置,F 为未量化权重,是量化误差的 Hessian 矩阵。

对于 MiniCPM-2B-SFT 与 MiniCPM-2B-DPO,我们均进行了 int4 量化,导出模型 MiniCPM-2B-SFT-Int4 与 MiniCPM-2B-DPO-Int4。

8 多模态:MiniCPM-V

基于 MiniCPM,我们构建了一个支持中英双语对话的端侧多模态模型 MiniCPM-V。该模型可以接受图像和文本输入,并输出文本内容。MiniCPM-V 的视觉模型部分由 SigLIP-400M 进行初始化,语言模型部分由 MiniCPM 进行初始化,两者通过perceiver resampler 进行连接。

  • MiniCPM-V 有三个突出特点:
  1. 高效推理:MiniCPM-V 可以高效部署在大多数 GPU 显卡和个人电脑,甚至手机等边缘设备上。在图像编码表示方面,我们基于 perciever resampler 将每个图像压缩表示为 64 个 token,显著少与其他基于 MLP 架构的多模态模型的 token数量(通常大于 512)。这使得 MiniCPM-V 可以在推理过程中以更低的存储成本和更高的运算速度进行推理。
  2. 性能强劲:在多个基准测试(包括 MMMU、MME 和 MMbech 等)中,MiniCPM-V 在同规模模型中实现了最佳性能,超越了基于 Phi-2 构建的现有多模态大模型。MiniCPM-V 在部分数据集上达到了与 9.6B Qwen-VL-Chat 相当甚至更好的性能。
  3. 双语支持:MiniCPM-V 是首个支持中英文双语能力的可边缘部署的多模态端侧大模型。该能力是通过跨语言泛化多模态能力高效实现的,这项技术来自我们的 ICLR 2024 splotlight 论文。
  • MiniCPM-V 模型的训练分为 2 个基本阶段:
  1. 预训练阶段: 我们使用 300M 中英图文对数据进行视觉和语言基本概念的对齐,并学习大规模多模态世界知识。
  2. 指令微调阶段: 我们一共使用了 6M 多任务问答数据、1M 纯文本数据、1M 多模态对话数据进行指令微调,进一步对齐并激发多模态基础能力。

详细训练与微调过程也可见我们 ICLR 2024 splotlight 论文。

9 端侧部署

进行 Int4 量化后,MiniCPM 只占 2GB 空间,具备了在端侧手机进行模型部署的条件。对此,我们针对 Android 和 Harmony 系统使用开源框架 MLC-LLM 进行模型适配,针对 iPhone 系统使用开源框架 LLMFarm 进行模型适配,并分别选取了部分端侧手机设备进行了测试。此外,我们首次验证了在端侧手机运行多模态大模型的可行性,并成功在手机上运行。

值得注意的是,我们并未针对手机部署进行优化,仅验证 MiniCPM 在手机侧进行推理的可行性,我们也欢迎更多开发者进一步调优更新下面的测试列表,不断提升大模型在手机侧的推理性能。

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

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

相关文章

C++拷贝构造函数、赋值运算符重载

1.拷贝构造函数 拷贝构造函数的写法如图所示 调用方式如下 接下来我来说说它的特征 1.1特征 拷贝构造函数&#xff1a;只有单个形参&#xff0c;该形参是对本类类型对象的引用(一般常用const修饰)&#xff0c;在用已存在的类类型对象创建新对象时由编译器自动调用。 拷贝构造函…

python接口自动化(二)--什么是接口测试、为什么要做接口测试(详解)

什么是接口测试 接口测试是测试系统组件间接口的一种测试。接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点。测试的重点是要检查数据的交换&#xff0c;传递和控制管理过程&#xff0c;以及系统间的相互逻辑依赖关系等。  一般来说&#xff0c;测试接…

【JavaEE进阶】 图书管理系统开发日记——肆

文章目录 &#x1f343;前言&#x1f38d;约定前后端交互接⼝&#x1f340;服务器代码实现&#x1f6a9;控制层&#x1f6a9;业务层&#x1f6a9;数据层 &#x1f334;前端代码的修改⭕总结 &#x1f343;前言 今天我们来实现修改图书模块 首先我们先来看一下&#xff0c;需要…

前端学习笔记 | HTML5+CSS3静态网页制作的技巧(持续更新)

注&#xff1a;本文的css样式均使用less写法 1、字体居中 &#xff08;1&#xff09;先text-align:center;行内元素水平居中 &#xff08;2&#xff09;再line-heigh:(盒子高度);行内元素垂直居中 text-align: center;line-height: ( 30 / vw ); 2、盒子居中 情景1&#…

FCIS 2023:洞悉网络安全新前沿,引领未来安全创新狂潮

在数字化浪潮席卷全球的今天&#xff0c;网络安全问题愈发凸显其重要性。 FCIS 2023网络安全创新大会作为业界瞩目的盛会&#xff0c;不仅汇聚了国际顶尖的网络安全专家&#xff0c;更展示了最前沿的安全技术与研究成果。那么&#xff0c;参与这场大会&#xff0c;我们究竟能学…

寒假作业2月4号

第三章 类与构造函数 一&#xff0e;选择题 1、下列不能作为类的成员的是&#xff08;B&#xff09; A. 自身类对象的指针 B. 自身类对象 C. 自身类对象的引用 D. 另一个类的对象 2、假定AA为一个类&#xff0c;a()为该类公有的函数成员&#xff0c;x为该类的一个对象&am…

Aigtek高压放大器用途是什么呢

高压放大器在电子领域中扮演着至关重要的角色&#xff0c;其主要作用是将低电压信号放大到更高的电压水平。这种类型的放大器广泛用于各种应用中&#xff0c;以下是高压放大器的用途以及其关键作用的详细介绍。 1、科学研究和实验室应用&#xff1a; 高压放大器在科学研究和实验…

C++类和对象补充篇

目录 1.再谈构造函数1.1构造函数体赋值1.2 初始化列表1.3 explicit关键字 2.static成员2.1概念2.2 特性 3.友元3.1友元函数3.2友元类 4.内部类5.匿名对象6.拷贝对象时的一些编译器优化7.再次理解类和对象 1.再谈构造函数 1.1构造函数体赋值 在创建对象时&#xff0c;编译器通…

elastic-job VS xxl-job

1、Elastic-job介绍 Elastic-job 是由当当网基于quartz 二次开发之后的分布式调度解决方案 &#xff0c; 由两个相对独立的子项目Elastic-Job-Lite和Elastic-Job-Cloud组成 。Elastic-Job-Lite定位为轻量级无中心化解决方案&#xff0c;使用jar包的形式提供分布式任务的协调服务…

【数据结构】排序---C语言版

七大排序算法 一、对于排序的分类&#xff1a;二、插入排序1、直接插入排序&#xff08;1&#xff09;基本思想&#xff1a;&#xff08;2&#xff09;直接插入排序&#xff1a;&#xff08;3&#xff09;代码实现&#xff1a;&#xff08;4&#xff09;总结&#xff1a; 2、希…

C++写算法题时常见问题(稳定更新)

目录 1.如何用 getline 函数读取用户输入的一行 2.如何防止用 scanf 读取字符时读取了 换行和空格 3.map和unordered_map的差别和使用 4.“表达式求值”问题解析 5.运行报RE错误 6.在set或者map里面使用结构体 7.运行时报TLE时&#xff0c;时间复杂度问题 8.double类型的…

ncc匹配(一,理论)

前头从来没用过ncc&#xff0c;基于形状匹配搞定后&#xff0c;又翻了翻learning opencv&#xff0c;他并不推荐ncc&#xff0c;而是力推emd&#xff0c;这也是当初我没考虑用ncc的原因。 当初看到ncc公式很复杂&#xff0c;也就忘了。 我的第一个匹配&#xff0c;是最笨的&a…