RV1126B嵌入式音频开发实战:从ALSA驱动到应用播放全解析

news2026/5/21 15:56:50
1. 项目概述从一块核心板到声音的诞生最近在折腾一块基于瑞芯微RV1126B芯片的EASY EAI Nano开发板目标是让它“开口说话”——实现稳定的音频输出。这听起来像是一个基础功能但对于嵌入式开发尤其是涉及多媒体处理的边缘AI设备来说音频输出是连接智能与用户感知的关键桥梁。无论是智能门铃的语音提示、工业设备的报警音还是AI摄像机的双向语音对讲都离不开这一环。RV1126B这颗芯片定位很明确就是为视觉和语音结合的AIoT设备而生。它内置了独立的音频编解码器Audio Codec这为我们直接输出音频提供了硬件基础无需外挂复杂的音频芯片。但硬件有了软件通路如何打通内核驱动、ALSA框架、应用层播放工具这一整套链路任何一个环节出问题声音都出不来。这个项目就是要把这条通路从硬件到应用层完整地走通并记录下其中关键的配置步骤和那些容易踩进去的“坑”。无论你是刚接触嵌入式音频的新手还是正在为某个产品调试音频功能的工程师希望这篇从实战中总结的记录能给你提供一条清晰的路径。2. 核心硬件与音频系统架构解析2.1 RV1126B音频子系统初探RV1126B的音频子系统是其多媒体能力的重要组成部分。它内部集成的是一个名为“Rockchip I2S/TDM/PCM Controller”的接口控制器以及一个与之配套的“Rockchip Audio Codec”。这种集成方式在嵌入式SoC中很常见旨在节省空间和成本。简单来说音频数据流的路径是这样的应用程序如播放器产生数字音频数据PCM格式 - 通过Linux的ALSA框架 - 调用内核中的Codec驱动 - 驱动控制I2S控制器将数字数据发送给内部的Codec模块 - Codec模块进行数模转换DAC - 输出模拟音频信号到指定的引脚。EASY EAI Nano开发板通常会将音频输出引脚引接到一个3.5mm的耳机接口或者一个两针的喇叭接口上。在动手写代码或配置之前第一件事就是确认硬件连接你的喇叭或耳机是接在哪个接口上原理图上对应的网络标号是什么这决定了后续设备树Device Tree的配置。2.2 ALSA框架Linux音频的基石在Linux系统中音频管理由ALSAAdvanced Linux Sound Architecture框架统一负责。对于应用开发者而言ALSA提供了/dev/snd目录下的一系列设备文件以及标准的API如alsa-lib对于驱动开发者则需要实现ALSA驱动框架要求的struct snd_soc_card、struct snd_soc_dai_link等结构体。在RV1126B的BSP板级支持包中瑞芯微已经提供了完整的音频驱动。我们的工作主要不是编写驱动而是正确地配置它。配置的核心在于设备树.dts文件。设备树描述了硬件连接关系比如I2S控制器连接了哪个CodecCodec的复位脚、供电脚是哪个GPIO扬声器放大器如果外接了的使能脚又是哪个这些硬件信息都必须准确无误地写在设备树里内核在启动时才能正确初始化和绑定驱动。一个常见的误区是认为芯片有声音接上喇叭就一定能响。实际上如果设备树中音频节点的status被设置为“disabled”或者引脚的复用功能pinctrl配置错误整个音频硬件在系统中就是“隐身”的。3. 软件环境准备与系统构建3.1 获取与编译SDK要进行深度开发首先需要获得RV1126B的官方SDK。通常可以从芯片原厂或开发板供应商处获取。SDK包一般很大包含了Linux内核、U-Boot、根文件系统以及交叉编译工具链。解压SDK后重点关注的目录是kernel/内核源代码音频的设备树文件.dts或.dtsi就在这里路径通常是kernel/arch/arm64/boot/dts/rockchip/RV1126是64位ARM核心。buildroot/或debian/根文件系统构建目录我们需要在这里配置将必要的音频工具和库如alsa-utils,tinyalsa,mpg123等打包进最终的系统镜像。编译环境搭建的关键是设置好交叉编译工具链。SDK一般会自带一个build.sh脚本或提供环境变量设置脚本如envsetup.sh。执行它会设置好CROSS_COMPILE等变量。之后通过make命令进行内核和文件系统的编译。注意编译前务必确认开发板对应的默认配置文件defconfig。不同开发板即使核心芯片相同的音频外设可能不同对应的设备树文件也不同。EASY EAI Nano应该有自己专属的dts文件例如rv1126-easy-eai-nano.dts不要选错了。3.2 根文件系统中的音频组件一个能播放音频的基本系统需要以下组件ALSA内核驱动已包含在编译好的内核中。ALSA用户空间库alsa-lib为应用程序提供标准API。ALSA工具集alsa-utils包含aplay,amixer,alsamixer等命令行工具用于测试、播放和控制音量。音频播放程序如mpg123用于播放MP3、gstreamer多媒体框架或自己编写的播放程序。在Buildroot配置菜单中我们需要确保这些包被选中Target packages - Audio and video applications - alsa-utils - mpg123 - Libraries - Audio/Sound - alsa-lib保存配置后重新编译根文件系统并生成完整的固件镜像通常是一个.img文件。4. 设备树关键配置详解设备树是连接硬件描述与软件驱动的桥梁。对于音频我们需要检查并可能修改两个部分i2s0节点和codec节点。4.1 I2S控制器节点配置在设备树文件中找到i2s0节点RV1126B的音频I2S通常使用i2s0。一个基本可用的配置示例如下i2s0 { status okay; // 确保节点启用 #sound-dai-cells 0; rockchip,clk-trcm 1; // 时钟模式需参考手册 pinctrl-names default; pinctrl-0 i2s0m0_sclk i2s0m0_lrck i2s0m0_sdi i2s0m0_sdo; // 引脚复用必须与硬件连接一致 // 注意pinctrl-0的具体内容取决于你的板子音频引脚连接在哪个IO bank上必须与原理图完全对应。 };关键点解析status “okay”;这是前提如果这里是“disabled”后续都免谈。pinctrl-0这是最容易出错的地方。i2s0m0_sclk这些符号是内核预定义的引脚功能复用配置。你必须根据原理图确认音频的BCLK位时钟、LRCK左右声道时钟、SDI数据输入、SDO数据输出分别连接到了芯片的哪几个物理引脚上然后找到这些引脚对应的、正确的pinctrl配置名称。配置错误会导致没有信号输出或者信号错乱产生杂音。4.2 音频编解码器Codec节点配置接着找到内置Codec的节点它可能被命名为codec或rk809_codecRV1126B常集成RK809电源管理兼Codec芯片。配置示例如下codec { status okay; #sound-dai-cells 0; rockchip,mic-in-differential 0; // 麦克风输入是否为差分根据硬件设计定 // 可能包含喇叭放大器使能引脚的配置 spk-ctl-gpios gpio0 RK_PA5 GPIO_ACTIVE_HIGH; // 示例需根据实际硬件修改 };关键点解析spk-ctl-gpios如果板子上外接了一个无源喇叭并且通过一个GPIO控制一个三极管或MOSFET来给喇叭供电那么这个配置就至关重要。它指定了控制喇叭电源的GPIO。驱动会在播放音频前将此GPIO拉高打开喇叭功放静音时拉低关闭功放以省电。如果这个GPIO配置错误或没配置喇叭可能永远没有供电自然无声。4.3 声卡Sound Card节点绑定最后需要一个节点将I2S控制器和Codec“链接”起来形成一个完整的声卡。这通常在板级设备树文件.dts中完成sound { compatible simple-audio-card; simple-audio-card,name rv1126-sound; // 声卡名称会在系统里显示 simple-audio-card,format i2s; // 音频格式 simple-audio-card,mclk-fs 256; // 主时钟与采样率倍数关系常见256或512 simple-audio-card,cpu { // CPU端即I2S控制器 sound-dai i2s0; }; simple-audio-card,codec { // Codec端 sound-dai codec; }; };修改完设备树后需要重新编译内核并将新的内核镜像更新到开发板。5. 系统启动与音频设备验证将编译好的完整固件烧录到开发板启动系统后我们需要进行一系列验证。5.1 检查声卡与设备节点首先登录开发板终端检查声卡是否被成功识别cat /proc/asound/cards如果配置正确你应该能看到类似下面的输出0 [rv1126sound ]: rv1126-sound - rv1126-sound rv1126-sound这表示系统识别到了名为“rv1126-sound”的声卡索引为0。接着查看ALSA生成的PCM设备节点ls -l /dev/snd/你应该能看到pcmC0D0p播放设备和pcmC0D0c采集设备等文件。其中C0表示Card 0D0表示Device 0。5.2 使用amixer调整音频通路与音量ALSA驱动加载后音频通路和音量可能处于默认状态通常是静音或音量极小。我们需要使用amixer工具进行设置。首先查看所有控制器amixer controls你会看到一长列控制项如‘Playback Path‘,‘Headphone Playback Volume‘,‘Speaker Playback Volume‘等。对于喇叭输出关键步骤是设置播放路径将音频输出路由到喇叭Speaker而不是耳机Headphone。amixer set Playback Path SPK # 具体控制项名称和值可能不同如‘HP‘或‘SPK‘取消静音确保喇叭和主输出通道没有静音。amixer set Speaker Playback Switch on # 打开喇叭播放开关 amixer set Playback Switch on # 打开主播放开关调节音量将音量设置到一个合适的水平。amixer set Speaker Playback Volume 80% # 设置喇叭音量值范围需看具体定义一个更直观的方法是使用交互式工具alsamixer。在终端输入alsamixer会进入一个图形化界面。使用左右方向键选择不同的控制项上下方向键调整音量M键切换静音/非静音。确保与播放相关的栏目的下方没有MM表示静音而是OO。实操心得很多时候没声音不是驱动没起来而是音频通路被设置到了耳机输出或者喇叭输出被静音了。alsamixer是排查这类问题的第一利器。6. 音频播放实战与测试6.1 使用aplay播放原始PCM文件aplay是ALSA工具集里最基础的播放命令用于播放原始的PCM数据文件。首先我们需要一个测试音频文件。可以自己用电脑生成一个例如生成一个440Hz的正弦波WAV文件单声道16位采样率8kHz但更简单的方法是使用开发板上可能自带的测试文件或者用sox工具生成。一个快速的测试方法是播放一段特定的音频参数。但更可靠的是准备一个标准的测试文件。如果没有可以写一个简单的C程序生成一段PCM数据并播放。这里我们先假设有一个test.wav文件。将其拷贝到开发板然后使用aplay指定声卡和设备进行播放aplay -D plughw:0,0 test.wav-D plughw:0,0指定播放设备。hw:0,0表示硬件Card 0, Device 0。plughw:表示如果需要ALSA会自动进行采样率、格式转换。如果播放成功你应该能听到声音。如果没声音但命令没报错请返回上一步用alsamixer检查音量和静音设置。6.2 使用mpg123播放MP3文件aplay只能播放原始PCM或WAV而mpg123可以解码并播放更常见的MP3文件。确保mpg123已安装在根文件系统中。播放一个MP3文件mpg123 -a hw:0,0 test.mp3-a hw:0,0同样指定ALSA音频输出设备。如果播放时出现“Audio device got stuck!”等错误可能是采样率不支持或缓冲区问题。可以尝试增加缓冲区大小mpg123 -a hw:0,0 --audiobuffer 500 test.mp36.3 编写简易音频播放程序对于产品开发我们最终需要集成自己的播放逻辑。这里给出一个使用ALSA库alsa-lib的C语言最小播放示例。这个程序打开播放设备设置参数并播放一段内存中生成的简单正弦波。#include stdio.h #include stdlib.h #include alsa/asoundlib.h #include math.h #define SAMPLE_RATE 44100 #define DURATION 2 // seconds #define FREQ 440.0 // Hz int main() { int err; snd_pcm_t *handle; snd_pcm_hw_params_t *params; unsigned int val; int dir; snd_pcm_uframes_t frames; char *buffer; int size; // 1. 打开PCM设备 if ((err snd_pcm_open(handle, hw:0,0, SND_PCM_STREAM_PLAYBACK, 0)) 0) { printf(Playback open error: %s\n, snd_strerror(err)); return -1; } // 2. 分配硬件参数对象并初始化 snd_pcm_hw_params_alloca(params); snd_pcm_hw_params_any(handle, params); // 3. 设置硬件参数交错模式、格式、通道数、采样率、周期等 snd_pcm_hw_params_set_access(handle, params, SND_PCM_ACCESS_RW_INTERLEAVED); snd_pcm_hw_params_set_format(handle, params, SND_PCM_FORMAT_S16_LE); // 16位小端 snd_pcm_hw_params_set_channels(handle, params, 2); // 立体声 val SAMPLE_RATE; snd_pcm_hw_params_set_rate_near(handle, params, val, dir); // 设置周期大小和缓冲区大小 frames 1024; // 周期大小帧数 snd_pcm_hw_params_set_period_size_near(handle, params, frames, dir); frames * 4; // 缓冲区大小 4个周期 snd_pcm_hw_params_set_buffer_size_near(handle, params, frames); // 4. 应用参数 if ((err snd_pcm_hw_params(handle, params)) 0) { printf(Unable to set hw params: %s\n, snd_strerror(err)); return -1; } // 5. 生成一段440Hz的正弦波数据到buffer size frames * 4; // 帧数 * 通道数2 * 每样本2字节 buffer malloc(size); for (int i 0; i frames; i) { short sample 32767 * 0.5 * sin(2 * M_PI * FREQ * i / SAMPLE_RATE); // 左声道 buffer[i*4] sample 0xff; buffer[i*41] (sample 8) 0xff; buffer[i*42] sample 0xff; // 右声道相同 buffer[i*43] (sample 8) 0xff; } // 6. 播放 err snd_pcm_writei(handle, buffer, frames); if (err 0) { printf(Write error: %s\n, snd_strerror(err)); snd_pcm_recover(handle, err, 0); // 尝试恢复 } else if (err ! (int)frames) { printf(Short write, wrote %d frames\n, err); } // 7. 等待播放完成并清理 snd_pcm_drain(handle); snd_pcm_close(handle); free(buffer); return 0; }将此代码交叉编译后在开发板上运行应该能听到一个短暂的440Hz音调。这个程序涵盖了ALSA播放的基本流程打开设备、设置参数、写入数据、关闭设备。7. 常见问题排查与调试技巧实录即使按照步骤操作音频调试也常会遇到各种问题。下面是一个常见问题速查表基于实际踩坑经验总结。问题现象可能原因排查步骤与解决方案cat /proc/asound/cards无输出1. 设备树音频节点status未设为“okay”。2. 设备树引脚复用pinctrl配置错误。3. 内核编译时未包含对应音频驱动。1. 检查设备树中i2s0和codec节点的status。2. 对照原理图用io -r -4 GPIO寄存器地址需先insmod rockchip_pinctrl.ko或查看/sys/kernel/debug/pinctrl/pinctrl-handles确认引脚复用状态。3. 检查内核.config确保CONFIG_SND_SOC_ROCKCHIP、CONFIG_SND_SOC_RK817或对应Codec已启用。声卡识别到但aplay -L或aplay -l无播放设备1. 声卡绑定节点sound配置错误或未启用。2. I2S与Codec的DAI链路不匹配。1. 检查设备树中sound节点的status和compatible属性。2. 检查simple-audio-card,cpu和simple-audio-card,codec的sound-dai引用是否正确指向了i2s0和codec。有播放设备但播放无声命令不报错1. 音频通路未设置到喇叭SPK。2. 音量被设置为0或静音。3. 外接喇叭的功放使能GPIO未控制。1. 运行alsamixer检查Playback Path等路由控制项确保选中SPK或Speaker。2. 在alsamixer中查看所有带Playback字样的栏确保下方没有MM静音并用上下键调高音量。3. 检查设备树中spk-ctl-gpios配置并在播放时用万用表或io命令测量该GPIO电平是否变高。播放声音严重卡顿、杂音或破音1. 时钟配置错误mclk-fs比值不对。2. 采样率不匹配。3. 内核或应用层缓冲区设置过小。4. 系统CPU负载过高无法实时处理音频。1. 尝试调整设备树sound节点中的mclk-fs值如改为512或128。2. 确保播放文件的采样率与驱动设置的采样率一致。用aplay -v查看硬件参数。3. 尝试在aplay命令中增加--buffer-time和--period-time参数或在程序中增加缓冲区大小。4. 使用top命令查看CPU占用优化应用或关闭不必要的进程。播放命令报错Device or resource busy音频设备已被其他进程占用。使用fuser -v /dev/snd/*命令查看是哪个进程占用了设备将其终止。使用自定义程序播放第一次正常第二次失败程序退出时未正确处理ALSA状态导致设备未关闭或未复位。在程序播放结束后调用snd_pcm_drain(handle)等待所有数据播放完毕再调用snd_pcm_close(handle)。或者在下次打开前检查并调用snd_pcm_prepare(handle)。深度调试技巧查看内核日志dmesg | grep -i audio或dmesg | grep -i alsa关注驱动加载时的错误信息。查看详细的ALSA设备信息cat /proc/asound/device和cat /proc/asound/pcm。使用tinymix工具如果alsamixer不显示所有控件可以尝试tinymix它能列出所有可用的混音器控件及其值并且可以直接通过命令行设置便于脚本化。硬件信号测量如果软件层面一切正常但仍无声音可以借助示波器测量I2S的BCLK、LRCK和SDO引脚是否有波形输出以及Codec的模拟输出引脚是否有信号。这是判断问题出在数字链路还是模拟部分的最终手段。8. 性能优化与进阶应用8.1 降低音频延迟在需要交互的语音对讲或实时音效处理场景低延迟是关键。ALSA的延迟主要由缓冲区大小决定。缓冲区越大抗数据波动能力越强但延迟也越高。优化方向减小周期大小和缓冲区大小在程序设置硬件参数时减小snd_pcm_hw_params_set_period_size_near和snd_pcm_hw_params_set_buffer_size_near中的帧数。例如将周期大小从1024减到256或128。但注意设置过小可能导致xrun欠载或溢出错误。使用SND_PCM_NONBLOCK模式并配合轮询打开设备时使用非阻塞模式并结合snd_pcm_poll_descriptors和poll系统调用一旦硬件准备好就立即写入数据减少等待时间。提高应用程序线程优先级使用sched_setscheduler将播放线程设置为实时调度策略如SCHED_FIFO避免被其他普通进程抢占。8.2 多路音频与混音RV1126B的I2S控制器可能支持多声道TDM模式但内置Codec通常只有一对立体声输出。如果需要同时播放多个音频源如背景音乐和提示音需要在应用层进行软件混音。简易混音思路 将多个PCM音频流解码成统一的采样率、位深和声道数后将对应样本值相加。注意饱和处理short mixed_sample CLAMP(sample1 sample2, -32768, 32767)。混音后的PCM数据再送入ALSA接口播放。可以使用GStreamer的audiomixer插件或PulseAudio等更专业的中间件来处理复杂的混音场景但这会引入更大的系统开销。8.3 与AI语音处理结合RV1126B的核心优势在于AI能力。一个典型的进阶应用是“音频输出语音识别”的语音交互。语音提示输出使用上述ALSA播放流程播放唤醒词响应、识别结果反馈等提示音。回声消除AEC在带有麦克风进行录音的同时播放声音如智能音箱喇叭的声音会被麦克风采集回去形成回声严重干扰语音识别。需要在音频驱动层或应用层实现AEC算法。瑞芯微SDK可能提供基于硬件的AEC支持需要查阅相关文档在设备树和驱动中启用相应模块。低功耗语音唤醒在系统休眠时通过芯片的低功耗音频处理单元监听唤醒词。这涉及到更复杂的电源域和DMA配置通常需要原厂提供完整的解决方案。调试音频功能尤其是与AI栈结合时耐心和细致的排查比盲目尝试更重要。从设备树这个源头确保硬件描述正确利用alsamixer、tinymix、dmesg这些工具层层递进地定位问题最终让RV1126B清晰、稳定地发出声音是整个智能设备获得良好用户体验的重要一步。

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

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

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…