深度解读智能化编码的技术架构与实践案例

news2025/1/17 1:45:24
向更智能、更兼容演进。

陈高星|演讲者

大家好,我是阿里云视频云的陈高星,今天和大家分享的主题是“多”维演进:智能化编码架构的研究与实践。

本次分享分为四部分:首先是视频编码与增强方向的业界趋势,其次是对在该背景下衍生的阿里云视频云智能编码架构进行介绍,以及其中关于“多”维演进的技术细节,最后是我们对于智能编码的一些思考和探索。

01 视频编码与增强方向的业界趋势

首先介绍视频编码与增强方向的业界趋势。视频技术发展的趋势始终在追求更高清、更实时、更互动、更低成本以及更智能

过去几年直至2022年,虽然从“高清化”的角度围绕AR/VR、沉浸式8K这些概念的话题热度有所降低,但随着2023年上半年苹果VisionPro的推出,VR的热度再次升高。除概念化炒作外,视频“高清化”也是实实在在的趋势。举个例子,相较于2018年世界杯直播,可以发现新一届2022年直播视频的码率和分辨率明显提升,预计下一届还会进一步提升。

围绕更“高清化”的趋势,我们能看到近年各大企业都在陆续推出自研的下一代编码器,包括266、AV1,甚至是私有标准的编码器。同时,我们也在智能编码和增强上看到不少的需求。为了降低“高清化”带来的成本压力,视频编码的软硬异构方案成为热点,包括阿里云的倚天710 ARM异构和多个友商在ASIC硬件转码方案上的布局。

从“低时延”的角度,随着5G基础设施的普及,毫秒级的延迟技术逐步趋于成熟,并在多个场景得到了应用和落地。阿里云视频云支持的2022年6月央视云考古节目《三星堆奇幻之旅》以及2023年春晚推出的央博“新春云庙会”都用到了相关的超低延时云渲染技术。在2022年世界杯期间,超低时延的直播RTS也在逐步上量。当然,以大趋势来看,目前“超低延时”直播仅在个别领域和场景是刚需,真正的爆发还需依赖更多的实际应用场景。

在更“智能化”方面,我们观察到在编码内核的基础上,工业界持续聚焦利用AI能力提升视频编码压缩率,包括运用视频编码和处理的结合,视频编码与质量评价结合,视频编码与AI生成结合,以及端云联合优化来持续提升视频编码主客观压缩率。在近年来大家关注的“视频增强”和“内容自适应编码”等领域,也能看到基于GAN的细节修复生成技术不断落地。

随着2023年ChatGPT和大语言模型的爆发,AIGC成为目前的技术热点。MidJourney等一众绘图软件的风靡,以及Stable Diffusion等开源模型的快速发展让我们看到了AIGC在图片领域的巨大实力,同时文生视频技术也在逐步兴起。

那么,伴随着更高清、更实时、更高效、更智能的编码需求,我们也面临许多技术与当前需求的矛盾

随着AR/VR时代的到来,视频的分辨率、帧率以及色域都会不断的扩大,单一视频的信息量将会成倍的增加。低时延意味着对编码速度的更高要求,而CPU芯片处理能力不再遵循摩尔定律快速增长,清晰度、带宽、计算成本和编码速度的矛盾会越来越严重,主要体现为以下四点:

第一,编码标准升级速度远慢于视频信息量膨胀的速度。编码标准历经过去十年的发展仅带来了50%压缩率的提升,这远远落后于视频化和体验升级带来的流量增长。

第二,新编码标准压缩率的提升速度远低于视频帧率、分辨率提升的速度。从720P 30fps到8k 60fps,视频信息量将增加72倍,这与编码标准的发展速度出现了较大矛盾。

第三,新编码标准复杂度的增加远高于CPU性能增长。从264到266,每一代编码标准相较上代大多增加10倍以上的复杂度,远高于CPU处理能力的增加。

第四,单一编码标准难以覆盖多种应用需求。随着视频在更多应用场景的扩展深化,如VR场景所需的沉浸式编码标准,以及面向机器视觉任务的VCM视频编码标准,更需要对编码标准进行特定场景下的优化。

在以上看似难以调和的矛盾背景下,如果想实现“鱼与熊掌兼得”,以下五个问题值得讨论。

首先,除了码率和质量,视频编码还可以关注哪些指标?例如不同内容的质量稳定性,保证序列级或者是序列片段,甚至是序列到Gop之间的质量稳定性,从客观到主观上,以及从资源消耗的角度去考虑编码复杂度的稳定性。

第二,如何用好现有的编码标准? 现有的各种标准,例如前述的VR沉浸式标准、 VCM等,虽然具有开源代码,但从多年来MSU比赛的结果可以看到,它们还存在很大优化空间。因此,研发多标准的编码器也是业界一直关注和研究的方向。

第三,视频编码标准本身覆盖不到的维度有哪些?其实从每一代的标准来看,视频编码追求的目标都是尽可能与“源”一致,所以多数情况下纯编码器优化使用有源的客观指标作为参考标准,但这种方式对低画质场景并不适用。

鉴于编码后的视频还是为人眼观看服务的,虽然人眼主观评价较为耗时费力,但实际上它是能够给客户带来价值的方向。因此,将人眼评价引入视频智能增强来提升画质,也是我们的主要研究方向之一。

第四,在编码标准上,现有标准对视觉冗余的挖掘和场景自适应能力还有不足。现有标准其实只定义了大概的工具集以及解码器,但是如果能够引入多级的自适应编码,进一步挖掘各个模块之间的“耦合”能力,实际上可以进一步提升编码器的质量上限。

第五,如何打破资源堆叠,置换视频压缩效率提升的技术思维惯性。从复杂度的角度,其实我们不用单纯从硬件角度考虑,例如:仅通过硬件资源的堆叠的实现编码普惠的效果。我们可以通过多平台的支持,比如与底层架构的深度耦合或者将部分模块硬化的方式,兼顾软件的“灵活性”和硬件的“高效性”,达到算法普惠化。

因此阿里云视频云针对以上五个问题的解法就是右侧的五大“多”维

02 智能编码架构介绍

如图所示,我们的智能编码架构主要体现在五个维度。

传统编码架构的编码流程是从视频源开始,通过可选的视频处理模块进入编码的码控和内核部分,然后输出码流。

智能编码架构最显著的特点是“多级自适应编码能力”。它会对视频源进行分析,基于源评估编码流程中的处理、码控、内核等环节对于最终输出的影响,自适应决策模块内部的参数和工具组合。

同时,为了实现多级自适应编码,我们在视频处理、码控和内核上提供了多方位的编码工具和能力。最后,这个编码架构需要能够自适应的模块化,使其能够自适应地从软编到不同硬编平台。

五个维度具体的原子能力如上图所示。多级自适应编码除业务场景和视频热度等分类外,还包括基于场景内容和片源质量的语义级自适应;而内容自适应则包含:基于不同编码目标的前处理Pre-coding、以及基于人眼的JND、ROI等;工具自适应则是联合各个编码模块,包括码控和内核模块。

在视频处理方面,“多”维智能视频增强包括画质增强、视频降噪、细节修复生成、去压缩失真以及时域和空域的SR和FRC技术。

在编码码控上,多目标编码能力兼容在除码率、质量外,还包括针对目标编码复杂度、质量波动,以及一些CV任务的多目标编码兼容。

在内核上,我们有自研的多标准编码器,覆盖264、265、266、AVS3、AV1以及VCM编码器。

多平台支持方面,我们的架构能够支持从软编的X86、ARM架构到部分使用硬编的联合优化平台。

03 智能编码架构的“多”维演进

接下来,将对智能编码架构的“多”维演进进行详细介绍。首先是多级自适应编码,它的关键是基于片源质量的内容自适应,因为片源质量是视频处理和编码非常重要的决策特征

我们基于大量客户场景数据,对片源进行多个维度的分类,除了片源的语义级质量之外,还有如上图所示的对时空域复杂度的评价,考虑编码影响进行R/D斜率分析,以及针对序列级中的不同序列进行智能的码率分配。

质量分析模块至关重要,在视频质量方面,充分了解视频是否有噪声、压缩或者传输带来的质量损失对后续的处理和增强将起到关键指导作用。特别是在需要使用一些低成本的增强和编码方案时,我们很难用一个模块去自适应处理所有的质量退化。因此,加入质量分析模块可以帮助我们更好的获取编码的质量上限。对于质量好的源,能有少量或者适中的增强效果。对于质量差的源,可以提升更多的质量。

另外,视频源的质量也会影响编码的决策。如果视频源的某一片段比较复杂,那在低码率的情况下很可能会出现大量的“块效应”,因此在该场景下我们会倾向于分配更多的码率。

内容自适应的另一部分是基于人眼的JND和saliency map。JND对工业界来说是一个非常重要的方向。传统的视频编码是基于信息论的,它从预测结构的角度减小时域冗余、空间冗余、统计冗余等的冗余,从而实现对视频的压缩,但对视觉冗余的挖掘还远远不够。

JND的基本原理如上图所示,传统视频编码使用的RDO曲线是连续的凸曲线,但人眼实际感知到的是非连续的阶梯状线。如果利用阶梯状曲线替换凸曲线,在相同失真的情况下可以使用更少的码率。

传统的JND方案分为“自顶向下”和“自底向上”两种方式。我们更多选择“自底向上”方式,对视觉皮层的视觉特征来进行表征,如颜色、亮度、对比度、运动等方式。从空域上考虑亮度掩蔽、对比度掩蔽,从时域上考虑基于运动的掩蔽。

我们会引入深度学习方法预测JND模块对人眼主观的影响,然后结合编码内部的码控模块计算当前每一块可以进一步扩大量化步长的空间。目前,我们的JND模块在通用场景,同等主观下,能节省30%以上码率,在一些垂直场景下甚至可以节省50%以上。

除了JND, 挖掘人眼视觉冗余的另一个重要技术就是saliency map。我们在saliency map上布局了两个方向:一是低成本的基于人脸的ROI,为了能用在更普惠的直播以及超低时延场景,我们针对人脸开发了该工具。它结合检测与跟踪算法,对于检测到的人脸区域综合JND以及周围的像素块进行调整,保证在提高主观画质的同时降低ROI区域和非ROI区域的边界感。

二是saliency map技术,如上图展示的一些体育场景以及UGC场景。我们利用眼动仪采集时域注意力等信息,通过采集两千多个视频,收集10亿以上的注视点,构建了一套人眼注意力模型。

上图中突出显示的区域代表了人眼主要关注的区域,它会随着时间的变化发生一些变动。该模型与编码器相结合,针对不同的区域进行码率分配。在连续观看下,能够提升主观画质。

接下来介绍被应用于编码器内部的工具自适应技术。我们认为传统的率失真理论是基于客观的,在多数低码率的情况下会放大块效应。如低码率下选择skip或DC模式很容易出现块效应。

虽然编码标准中存在诸如deblocking filter等工具,但是它的强度不足以弥补实际产生的块效应。从主观上看,如果针对平坦区域增加一点噪声和模糊,带来的主观感受反而更好。

我们采用两种方式进行了主观优化,一种是单向的,基于源内容以及编码后信息预测,该区域后续是否容易出现块效应,并对后续区域进行针对性码率保护,同时也会区分块效应是片源自带还是编码导致的。第二种是针对点播场景的2pass编码,可以依据first pass的实际编码结果进行二次处理。

上图展示了主观对比结果,并排对比图中右侧为开启工具后效果,可以看到块效应在人脸区域明显减少,这一帧的码率大概增加了5%。由于从编码器码控角度,保证序列整体码率不变的提升上限有限,可以看到图中人体的手臂位置还较为模糊。

对于多维度视频增强部分我们将主要介绍自研的窄带高清品牌。阿里云早在2015年便已经提出了“窄带高清”概念,在2016年正式推出窄带高清技术品牌并进行产品化。目前通过多轮筛选和讨论,沉淀为窄带高清1.0和窄带高清2.0两个方向。

窄带高清1.0是均衡版,主要作用是使用最少的成本实现自适应内容处理和编码,在节省码率的同时实现画质的提升。它会充分利用编码器内的信息帮助视频处理,即用成本很小的前处理方法实现低成本的内容自适应。

窄道高清1.0在视频处理上分为两个细分档位,一种是计算复杂度相对较低的无差别锐化增强。另一种,会基于片源质量进行de-artifacts和deblur自适应锐化增强。对质量较差的片源,相应的deartifacts权重较大。

窄带高清2.0经过多次技术选型,最终定义为空间维度细节修复,解决视频生产链路造成的画质损失,即多次编码压缩导致的画质损失。在编码上也会增加更多自适应能力,包括JND、ROI、SDR+等等。

上图展示了窄带高清2.0的增强效果。常规CNN模型对编码压缩造成的块效应、边缘锯齿、毛刺等artifacts有比较好的平滑作用,可以使整个画面看起来更加干净,但会造成一种磨皮效果。窄带高清2.0选择基于GAN的细节增强,以提升画面质感,如眼角、嘴唇等等。

窄带高清2.0细节修复生成核心技术模块包括以下7个方面:

一是训练样本多样性:建立类型丰富的高画质视频库作为模型训练样本,训练样本包含多样的纹理特征,对GAN生成纹理的真实感有很大的帮助;

二是通过精细化建模不断优化训练数据,基于对业务场景面临的画质问题进行深入分析,贴合场景不断优化训练样本,以达到精细化建模效果;

三是探索更有效的模型训练策略,包括训练损失函数配置调优,例如perceptual loss使用不同layer的feature会影响生成纹理的颗粒度,不同loss的权重配比也会影响纹理生成的效果。我们在模型训练过程使用了一种名为NoGAN/渐进式训练策略。一方面可以提升模型的处理效果,另一方面对模型生成效果的稳定性也有帮助。

四是为了提高模型对片源质量的自适应能力,我们在训练输入样本质量的多样性和训练流程方面做了很多工作。最终对中低质量的源有明显的增强效果,对高质量源有中等增强效果。

五是根据学术界的经验,处理目标先验信息越明确,GAN的生成能力越强。因此为了提升GAN对不同场景的处理效果,我们采用了一种1+N的处理模式,即一个具备温和生成能力的通用场景模型+N个具备激进生成能力的垂直细分场景模型,如足球的草地细节、动画场景的边缘线条、综艺场景的人像。

六是高效可控的模型推理,经过模型蒸馏/轻量化,同时基于阿里云神龙HRT GPU推理框架,GAN细节生成模型在单卡V100上,处理效率可达1080P 60fps。

七是为了保证GAN模型生成效果的帧间一致性,避免帧间不连续带来的视觉闪烁和编码负担,阿里云视频云通过与高校合作,提出一种即插即用的帧间一致性增强模型

接下来介绍几个具体的客户案例。第一个是2022年江苏移动的世界杯转码。针对该场景主要用到了前述的细节修复生成能力。对比图左侧为经过修复生成并编码后的效果,右侧为片源。放大后可以看到,人体毛发细节和文字边缘锐度都获得了明显提升。

同样,在BesTV的NBA直播转码上也能达到类似效果。对比窄高编码后画面和片源可以看到,文字区域、球衣细节和地板纹理更加丰富。

除了体育场景外,我们还支持了《理想之途》演唱会场景,它的特点是片源质量较差(现场是暗场,伴随着灯光、烟雾和场景的频繁切换),可以看到画面有明显的块效应。针对该场景,除了窄带高清2.0外,我们同时使用了人像定制模板和基于语义的分割引导技术对图像进行还原。

上图展示了转码图与原图的效果对比,可以看到人物背后烟雾的块效应得到改善,人脸、毛发等细节也得到提升。右图是观众反馈,对直播画面的清晰度评价很高。

除了前述的体育直播和演唱会场景外,我们对一些沉浸式场景也进行了优化,例如对VR场景窄高采用基于VR视角和经纬度的JND和saliency map技术。

为了进一步优化沉浸式体验,我们还提供了能够呈现声源空间方位的空间音频技术,使用户能够在听的过程中感受到声源的变换,使实时互动从“在线”变成 “在场”。

接下来介绍多目标编码能力兼容。除了常规关注的码率和质量外,我们还考虑了目标复杂度和目标质量编码。

首先是目标复杂度编码。传统编码器编码速度、机器资源消耗随视频内容改变而改变,导致多数情况下编码水位相对不可控。因此在实际使用中我们对编码器也会有复杂度限制的使用需求。

复杂度分配具体从序列级到GOP级到帧级到块级进行反馈,反馈的内容包括编码质量、速度以及前述的一些自行分析内容。这使得简单场景下可以利用更多计算资源换取主客观质量提升。复杂场景下类似于码控VBV的概念,可以在避免降低主客观质量的同时限制编码复杂度。

其次是目标质量编码,在此以VMAF为例。传统ABR/CRF码控无法在同一码控参数设置下,保障不同序列VMAF分恒定。同时,也无法快速通过目标VMAF分获得应设置的目标码率或CRF参数。

虽然CRF是质量较为稳定的码控方式,但具体到某一个特定指标,不同序列的分数波动仍然较大。基于以上背景,我们开发了目标质量编码工具,右下图是工具开启前后的对比图,可以看到代表开启工具后的橙色线,不同序列间的质量分方差明显变小。

接下来介绍架构中的多标准自研编码内核。首先是我们自研的三大编码器:S264、S265和Ali266,每种都基于客观、主观及场景约束研发了100+的算法,覆盖直播,点播,RTC场景,以及云端,终端,自然场景,SCC场景。

性能上,S264、S265相对开源编码器,在全场景下可提升20%~60%压缩率,特别是针对超高清,低延时场景进行了更深度优化。优化方式包括预处理(MCTF、Scene Detection、SCC Detection、GOP size自适应)、快速算法(块划分、模式决策、运动估计、SAO/ALF)、码率控制(CUTree、AQ、lambda优化、CTU级码控)和工程优化(多线程并行、代码重构、访存优化、SIMD优化)。

S264、S265于2022年参加了世界编码器Cloud比赛,共获得19项第一,相较于大赛指定的基准编码器AWS可节省63%的码率,从转码效率的角度,相较友商也拥有2~6倍的优势。

Ali266于2021年首次参加世界编码器codec大赛,在客观比赛获得8项第一,相比于参考编码器x265,在相同PSNR客观质量下可节省51%的码率,同时它在主观比赛中评分第一。

在Ali266的落地方面,阿里云视频云与达摩院紧密合作,推动Ali266在媒体处理、直播转码等产品的商用落地。2022年1月,Ali266在优酷正式上线,在成本和用户体验上获得显著受益。

为了完善和推动Ali266的生态化,我们也优化了Ali266的解码器,方案包括多线程加速、汇编优化、内存&缓存优化。优化后解码性能相较于开源解码器达到了40%~105%的提升,内存占用下降30%以上,支持超过九成移动端设备的高清实时解码。

接下来介绍关于多平台的支持。

首先,是阿里云视频云与平头哥解决方案团队合作的,基于倚天ARM服务器的优化。我们在倚天710上,主要针对S264、S265进行了架构的深度优化,主要包括三个方向,一是计算函数的汇编优化,使得总体性能提升40%;二是计算函数并行优化,也实现了约40%的性能提升;三是偏控制函数优化,将算法设计与优化相结合,再提升了20%的性能。最终结果是,S264和S265倚天相对于C7性能提升了30%以上,并已在视频云点播场景大规模商用。

如图所示,展示了云渲染场景的一个案例:央博新春云庙会。它要求低时延并自带Nvidia inc编码器。我们通过接管该编码器的码控模块,融合自研的JND和基于空域特征码率分配的AQ算法,加上前处理增强技术,最终实现了窄高落地在云渲染场景的落地。并列图中右侧为窄高优化后的效果,可以看到实现了丰富的细节提升效果。

04 智能编码的思考和探索

最后,分享一些在智能编码上的实践和思考。首先,是我们在面对主客观优化的矛盾时,如何去定义“好”?现在的编码方向已经愈发从“客观”向“主观”靠拢。无论是以“人”为中心还是从最终的用户体验出发,视频都应该关注主观体验的。

在研发过程中,如果单纯考虑编码器优化,我们通常依赖如PSNR、SSIM、VMAF-NEG这样的有源客观指标。但当优化目标类似于窄高,是出于提升主观质量,那么客观指标分数的提升就不一定能反映到主观质量上。

更进一步来说,使用单一客观指标衡量视频质量也存在问题,从编码标准方面看,使用标准自带的SAO和DB工具,对PSNR和SSIM影响不大,但会导致VMAF分数降低;从开源软件方面看,X265编码器的PSY工具能够在主观上增加一些高频细节,但对客观指标也有不良影响;我们自研的基于编码反馈的主观优化反映的客观指标同样不佳;前面提到的JND也是一样,明显在客观指标上反馈不好;

前处理增强上,可以明显看到SRGAN中清晰而错误的纹理相较于模糊的细节主观表现更优,但PSNR和SSIM更差。

这是我们当下在编码优化中的一个困境。

另一方面,是我们在AI for coding方面的一些相关实践,我们始终关注AI Codec在视频编码方向的发展。目前可以看到,它确实能够持续提升视频客观质量,在前处理以及编码方向能利用GAN以及Diffusion Model等生成技术提升主观质量。这也是我们正在研究的重要方向。

关于沉浸式编码标准,我们目前在持续关注基于“点云”的编码标准以及基于沉浸式的MIV编码标准,后续根据落地情况也会加入到多自研标准的编码器中。

最后关于Coding for AI,目前主要在关注VCM,它在同等信息量下,压缩率相比传统编码能提高2-3倍,可直接利用结构化的码流进行视觉任务,同时支持多种多媒体任务。具体应用上,我们正在明厨亮灶、自动驾驶、AI监考方向进行相关实践和探索。

以上就是今天的全部分享,谢谢大家!

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

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

相关文章

Apple Watch 9和Apple Watch 8功能差异对比:预期升级浅析

每年的这个时候,我们都会想知道Apple Watch Series 9和Apple Watch Series 8之间会有什么不同。随着苹果下一代智能手表预计将于9月上市,我们渴望了解该公司即将进行的升级。 Apple Watch Series 8是目前最好的智能手表,但根据Apple Watch Series 9的改进,它可能会成为我们…

为什么C语言全局变量初始化元素必须是常量,而局部变量可以不是常量

前言 &#xff08;1&#xff09;今天看到一个有意思的问题&#xff0c;在交流群中&#xff0c;一位网友问&#xff0c;全局变量为什么不能给变量。会出现initializer element is not constant报错&#xff0c;代码如下 #include <stdio.h>int a 1; int b a1; //这里会报…

Zabbix-6.4.4 邮箱告警SMS告警配置

目录 ​------------------------- # 邮箱告警 ---------------------------------- 1.安装mailx与postfix软件包 2.修改mailx配置文件 3. 创建文件夹 4. 编写mail-send.sh脚本 5. 将该脚本赋予执行权限 6. 进入web界面进行设置—> Alerts —> Media Types 7. 添…

C++11并发与多线程笔记(3)线程传参详解,detach()大坑,成员函数做线程函数

C11并发与多线程笔记&#xff08;3&#xff09;线程传参详解&#xff0c;detach 大坑&#xff0c;成员函数做线程函数 1、传递临时对象作为线程参数1.1 要避免的陷阱11.2 要避免的陷阱21.3 总结 2、临时对象作为线程参数2.1 线程id概念2.2 临时对象构造时机抓捕 3、传递类对象…

数据结构算法--3快速排序

快速排序比冒泡排序&#xff0c;选择排序&#xff0c;插入排序速度都快 快速排序思路&#xff1a; ^取一个元素P&#xff0c;(第一个元素)&#xff0c;使元素P归位。 ^列表被P分成了两部分&#xff0c;左边都比P小&#xff0c;右边都比P大。 ^递归完成排序。 过程: 把5拿出…

FreeRTOS中断优先级测试

目录 资源配置 测试方案 易出 bug 测试代码 资源配置 1、定时器3中断优先级为3 2、定时器4中断优先级为4 3、FreeRTOS中断配置 OS系统管理不高于中断优先级4的中断。 #ifdef __NVIC_PRIO_BITS /* __NVIC_PRIO_BITS 已经在stm32f1xx.h里面定义为4 */#define configPRIO_B…

poetry add scipy || Poetry安装scipy失败

这里出现了一个使用poetry安装scipy失败的报错 poetry add scipy 大致意思是说&#xff0c;找不到需要的库和目前的python在版本上的交集&#xff0c;所以安装不了。 这可能与自己在poetry环境中已经安装的库有关。 但不管怎么说&#xff0c;我的这个3.10版本会装不了都是一…

【STM32RT-Thread零基础入门】 4. 线程介绍(理论)

文章目录 前言一、线程的概念二、线程的调度三、上下文切换四、线程的重要属性1. 线程栈2. 线程的状态3. 线程优先级4. 线程时间片5. 线程的入口函数 五、RT-Thread命令查看系统线程信息总结 前言 前文中的最后一个任务发现&#xff0c;一个main()函数很难同时实现按键功能和闪…

基于浏览器的插件sider,使用chatgpt3.5生成的连接Redis的代码

一.安装 首先在浏览器安装Sider插件&#xff0c;具体安装步骤https://www.423xz.com/gaoxiao/3949.html 收费情况&#xff1a;每天有几次的免费使用chatgpt3.5的次数&#xff0c;chatgpt4需要付费了。 二.使用步骤&#xff1a; 安装后使用&#xff0c;具体步骤&#xff1a;…

20 张图,透析HTTPs五大知识点

本文详细介绍了 HTTPS 相较于 HTTP 更安全的原因&#xff0c;包括对称加密、非对称加密、完整性摘要、数字证书以及 SSL/TLS 握手等内容&#xff0c;图文并茂、理论与实战结合、建议收藏&#xff01; 1. 不安全的 HTTP 近些年来&#xff0c;越来越多的网站使用 HTTPS 协议进行…

OpenCV-Python中的图像处理-霍夫变换

OpenCV-Python中的图像处理-霍夫变换 霍夫变换霍夫直线变换霍夫圆环变换 霍夫变换 霍夫(Hough)变换在检测各种形状的技术中非常流行&#xff0c;如果要检测的形状可以用数学表达式描述&#xff0c;就可以是使用霍夫变换检测它。即使要检测的形状存在一点破坏或者扭曲也是可以使…

【产品设计】用设计讲好故事 – JOOX 2020听歌年榜总结

JOOX是腾讯面向东南亚市场战略性的音乐App&#xff0c;作为一个国家化品牌&#xff0c;它面临着一些困难&#xff0c;但同时它通过创意的方式将自己的产品价值观传递给用户。我们在设计产品中&#xff0c;做好一个设计项目&#xff0c;就好比讲一个故事&#xff0c;但这只是一种…

基于php驾校驾驶理论考试模拟系统

驾校驾驶理论考试模拟系统&#xff0c;是基于php编程语言&#xff0c;mysql数据库进行开发&#xff0c;本系统分为用户和管理员两个角色&#xff0c;其中用户可以注册登陆系统&#xff0c;查看考试规则&#xff0c;进行驾照考试&#xff0c;查看考试得分&#xff0c;考试错题&a…

docker安装国产开源数据库tidb 单机版

docker pull pingcap/tidb 创建目录&#xff0c;然后安装tidb mkdir -p /data/tidb/data 创建容器 docker run --name tidb -d -v /data/tidb/data:/tmp/tidb --privilegedtrue -p 4000:4000 -p 10080:10080 pingcap/tidb:latest TiDB 简介 | PingCAP 文档中心

将您的 Ins 形象提升到新的水平

在当今这个社交媒体盛行的时代&#xff0c;Ins已成为人们展示个性、吸引关注的重要平台。你是否曾经想过&#xff0c;如果能够在同一个 Ins账户上展示不同的形象&#xff0c;让你的粉丝感受到更多的惊喜和乐趣呢&#xff1f;多账户登录功能正是满足这一需求的利器&#xff0c;它…

【我们常说这个pycharm里有陷阱,第三方库导入失败,看这里!】

最近有小伙伴遇到了明明安装了 python 第三方库,但是在 pycharm 当中却导入不成功的问题。 前言 一直以来,也有不少初学 python 的小伙伴,一不小心就跳进了虚拟环境和系统环境的【陷阱】中。 本文就基于此问题,来说说在 pycharm 当中如何使用系统环境、虚拟环境。 pych…

机器学习理论笔记(一):初识机器学习

文章目录 1 前言&#xff1a;蓝色是天的机器学习笔记专栏1.1 专栏初衷与定位1.2 本文主要内容 2 机器学习的定义2.1 机器学习的本质2.2 机器学习的分类 3 机器学习的基本术语4 探索"没有免费的午餐"定理&#xff08;NFL&#xff09;5 结语 1 前言&#xff1a;蓝色是天…

基于php动漫周边电商购物网站系统

动漫周边电商网站系统&#xff0c;是基于php毕业设计&#xff0c;mysql数据库进行开发&#xff0c;本系统分为用户和管理员两个角色&#xff0c;其中用户可以注册登陆系统&#xff0c;用户查看商品分类&#xff0c;商品列表&#xff0c;查看动漫周边商品详情&#xff0c;加入购…

【Java】BF算法(串模式匹配算法)

☀️ 什么是BF算法 BF算法&#xff0c;即暴力算法&#xff0c;是普通的模式匹配算法&#xff0c;BF算法的思想就是将目标串S的第一个与模式串T的第一个字符串进行匹配&#xff0c;若相等&#xff0c;则继续比较S的第二个字符和T的第二个字符&#xff1b;若不相等&#xff0c;则…

股票配资app是什么?是怎么一回事?

股票配资App是一种通过手机应用程序进行股票配资的工具。随着移动互联网的发展&#xff0c;越来越多的投资者选择使用手机进行股票交易&#xff0c;股票配资App应运而生。本文将对股票配资App进行详细解释。 股票配资App是一种便捷的投资工具&#xff0c;可以让投资者通过手机…