Step3-VL-10B Base版实战指南:Gradio界面源码解读+processing_step3.py定制化修改

news2026/4/11 10:03:04
Step3-VL-10B Base版实战指南Gradio界面源码解读processing_step3.py定制化修改1. 引言从使用者到开发者如果你已经用上了Step3-VL-10B的Web界面上传图片、提问、获取回答觉得这个多模态模型确实好用那么恭喜你你已经完成了第一步。但你可能会有这样的想法“这个界面功能不错但我想让它更适合我的业务场景。” “我想修改一下图片预处理的方式让模型在某些特定图片上表现更好。” “我想在回答生成前后添加一些自定义的逻辑处理。”如果你有这些想法那么这篇文章就是为你准备的。今天我们不谈怎么用我们来聊聊怎么改——深入Gradio界面的源码看看它到底是怎么工作的更重要的是手把手教你如何定制化修改processing_step3.py这个核心的图像处理器。我会带你从零开始理解整个Web应用的架构找到关键代码的位置然后进行实际的修改。整个过程就像给你的爱车做改装一样既有趣又有用。2. 项目结构全景解析在开始修改之前我们先要搞清楚整个项目的文件结构。这就像你要装修房子得先知道每个房间是干什么的。2.1 核心文件一览打开你的项目目录/root/Step3-VL-10B-Base-webui/你会看到这些关键文件/root/Step3-VL-10B-Base-webui/ ├── app.py # Gradio Web界面主程序 ├── configuration_step_vl.py # 模型配置文件 ├── modeling_step_vl.py # 模型架构定义 ├── processing_step3.py # 图像处理器今天的主角 ├── vision_encoder.py # 视觉编码器 ├── requirements.txt # Python依赖包列表 ├── supervisor.log # 运行日志 └── README.md # 项目说明文档2.2 各文件职责说明让我用大白话解释一下每个文件是干什么的app.py这是整个Web应用的大脑。它负责创建界面、处理用户请求、调用模型、返回结果。所有的界面元素上传按钮、输入框、发送按钮都在这里定义。processing_step3.py这是今天我们要重点修改的文件。它负责把用户上传的图片转换成模型能理解的格式。你可以把它想象成一个“图片翻译官”把普通的图片“翻译”成模型能看懂的数学表示。modeling_step_vl.py定义了整个多模态模型的结构。它告诉计算机“我们的模型应该长这个样子有这些层这些连接。”configuration_step_vl.py模型的配置文件。就像汽车的说明书告诉程序模型有多少参数、用什么设置。vision_encoder.py专门处理视觉部分的编码器。它负责从图片中提取特征。理解了这个结构你就知道该从哪里下手了。如果你想改界面就找app.py如果想改图片处理方式就找processing_step3.py。3. Gradio界面源码深度解读现在让我们打开app.py看看这个Web界面是怎么搭建起来的。3.1 界面构建的核心代码Gradio是一个让机器学习模型快速拥有Web界面的Python库。它的设计理念是“简单”但功能却相当强大。让我们看看app.py的关键部分# 这是app.py的核心部分我加了注释帮你理解 import gradio as gr from processing_step3 import Step3VLProcessor # 导入我们今天要修改的处理器 # 创建处理器实例 processor Step3VLProcessor.from_pretrained(stepfun-ai/Step3-VL-10B) # 定义处理函数 - 这是整个应用的核心逻辑 def process_image_and_text(image, text, max_length, temperature, top_p): 处理用户上传的图片和问题 image: 用户上传的图片 text: 用户输入的问题 max_length: 最大生成长度 temperature: 温度参数 top_p: Top-P采样参数 try: # 1. 准备输入 # 这里调用了processing_step3.py中的方法 inputs processor( imagesimage, texttext, return_tensorspt ) # 2. 将输入移动到GPU如果有的话 if torch.cuda.is_available(): inputs {k: v.cuda() for k, v in inputs.items()} # 3. 调用模型生成回答 with torch.no_grad(): outputs model.generate( **inputs, max_lengthmax_length, temperaturetemperature, top_ptop_p, do_sampleTrue ) # 4. 解码输出 response processor.decode(outputs[0], skip_special_tokensTrue) return response except Exception as e: return f推理出错: {str(e)} # 创建Gradio界面 with gr.Blocks(titleStep3-VL-10B 视觉语言模型) as demo: gr.Markdown(# ️ Step3-VL-10B 视觉语言模型) with gr.Row(): # 左侧图片上传区域 with gr.Column(scale1): image_input gr.Image(label上传图片, typepil) # 右侧问题输入和参数设置 with gr.Column(scale2): text_input gr.Textbox( label问题, placeholder请输入关于图片的问题..., lines3 ) with gr.Accordion(生成参数, openFalse): max_length gr.Slider( minimum10, maximum1024, value512, label最大生成长度 ) temperature gr.Slider( minimum0, maximum1, value0.7, label温度 (Temperature) ) top_p gr.Slider( minimum0, maximum1, value0.9, labelTop-P 采样 ) # 发送按钮 submit_btn gr.Button(发送, variantprimary) # 输出区域 output_text gr.Textbox(label模型回答, lines10) # 绑定事件 submit_btn.click( fnprocess_image_and_text, inputs[image_input, text_input, max_length, temperature, top_p], outputsoutput_text )3.2 界面工作流程解析这个代码做了以下几件事导入必要的库Gradio用于创建界面processor用于处理图片。定义处理函数这是整个应用的核心逻辑接收用户输入调用模型返回结果。创建界面布局使用gr.Blocks创建界面容器然后用gr.Row和gr.Column布局。创建界面元素gr.Image图片上传组件gr.Textbox文本输入框gr.Slider参数调节滑块gr.Button发送按钮gr.Accordion可折叠的参数面板绑定事件当用户点击发送按钮时调用process_image_and_text函数。整个流程就像餐厅的点餐系统用户通过界面下单上传图片和问题厨房处理函数收到订单后开始烹饪调用模型最后把菜品回答端给用户。3.3 如何自定义界面如果你想修改界面这里有几个常见的定制需求添加历史记录功能# 在界面中添加历史记录显示 history_output gr.Textbox(label对话历史, lines5, interactiveFalse) # 修改处理函数保存历史 conversation_history [] def process_with_history(image, text, max_length, temperature, top_p): response process_image_and_text(image, text, max_length, temperature, top_p) conversation_history.append(fQ: {text}\nA: {response}\n) history_text \n.join(conversation_history[-5:]) # 只显示最近5条 return response, history_text添加图片预览功能# 在图片上传后显示缩略图 image_preview gr.Image(label图片预览, interactiveFalse) # 添加一个事件当上传图片时更新预览 image_input.change( fnlambda img: img, inputsimage_input, outputsimage_preview )添加批量处理功能# 添加多文件上传 image_input gr.File( label上传图片, file_types[image], file_countmultiple # 允许多选 ) # 修改处理函数支持批量 def process_batch_images(files, text, max_length, temperature, top_p): responses [] for file in files: image Image.open(file.name) response process_image_and_text(image, text, max_length, temperature, top_p) responses.append(f图片: {file.name}\n回答: {response}\n) return \n.join(responses)这些修改都不复杂但能大大提升用户体验。关键是理解Gradio的组件和工作原理然后根据自己的需求进行组合。4. processing_step3.py定制化修改实战现在来到今天的重头戏——修改processing_step3.py。这个文件负责把图片转换成模型能理解的格式是影响模型表现的关键环节。4.1 理解图像处理器的工作原理首先让我们看看processing_step3.py的基本结构# processing_step3.py 的核心类 class Step3VLProcessor: def __init__(self, image_processor, tokenizer): self.image_processor image_processor # 图像处理器 self.tokenizer tokenizer # 文本分词器 def __call__(self, images, text, **kwargs): 主要处理函数把图片和文本转换成模型输入 # 1. 处理图片 pixel_values self.image_processor(images, return_tensorspt).pixel_values # 2. 处理文本 text_encoding self.tokenizer( text, return_tensorspt, paddingTrue, truncationTrue ) # 3. 返回统一的输入格式 return { pixel_values: pixel_values, input_ids: text_encoding[input_ids], attention_mask: text_encoding[attention_mask] } def decode(self, token_ids, **kwargs): 把模型输出的token id转换回文本 return self.tokenizer.decode(token_ids, **kwargs)这个处理器做了三件事用image_processor处理图片转换成像素值用tokenizer处理文本转换成token id把两者打包成模型能理解的格式4.2 实战修改一添加图片预处理增强有时候用户上传的图片质量不高——可能太暗、太模糊或者尺寸不合适。我们可以在处理前先对图片进行增强。# 在Step3VLProcessor类中添加图片预处理方法 from PIL import Image, ImageEnhance, ImageFilter import numpy as np class Step3VLProcessor: def __init__(self, image_processor, tokenizer): self.image_processor image_processor self.tokenizer tokenizer self.enhance_contrast True # 是否增强对比度 self.sharpen_image True # 是否锐化图片 self.target_size (728, 728) # 目标尺寸 def preprocess_image(self, image): 自定义图片预处理 可以在这里添加各种图片增强操作 # 确保是PIL Image格式 if not isinstance(image, Image.Image): image Image.fromarray(image) # 1. 调整尺寸保持宽高比 image.thumbnail(self.target_size, Image.Resampling.LANCZOS) # 2. 增强对比度如果开启 if self.enhance_contrast: enhancer ImageEnhance.Contrast(image) image enhancer.enhance(1.2) # 增强20% # 3. 锐化图片如果开启 if self.sharpen_image: image image.filter(ImageFilter.SHARPEN) # 4. 转换为RGB确保颜色通道正确 if image.mode ! RGB: image image.convert(RGB) return image def __call__(self, images, text, **kwargs): 修改后的处理函数加入自定义预处理 # 处理单张图片的情况 if not isinstance(images, list): images [images] # 对每张图片进行预处理 processed_images [] for img in images: processed_img self.preprocess_image(img) processed_images.append(processed_img) # 使用处理后的图片 pixel_values self.image_processor( processed_images, return_tensorspt ).pixel_values # 文本处理保持不变 text_encoding self.tokenizer( text, return_tensorspt, paddingTrue, truncationTrue ) return { pixel_values: pixel_values, input_ids: text_encoding[input_ids], attention_mask: text_encoding[attention_mask] }这个修改有什么用对于模糊的图片锐化后模型可能更容易识别细节对于昏暗的图片增强对比度后特征更明显统一尺寸可以确保处理的一致性4.3 实战修改二添加图片信息提取有时候我们不仅想让模型看图片还想给它一些额外的提示。比如我们可以自动提取图片的基本信息然后和问题一起送给模型。# 添加图片信息提取功能 import exifread from datetime import datetime class Step3VLProcessor: def __init__(self, image_processor, tokenizer): self.image_processor image_processor self.tokenizer tokenizer self.extract_exif True # 是否提取EXIF信息 def extract_image_info(self, image): 提取图片的EXIF信息和基本属性 info {} # 基本属性 info[size] f{image.size[0]}x{image.size[1]} info[mode] image.mode info[format] image.format if hasattr(image, format) else Unknown # 尝试提取EXIF信息 if self.extract_exif and hasattr(image, _getexif): try: exif_data image._getexif() if exif_data: # 提取拍摄时间 if 36867 in exif_data: # DateTimeOriginal info[capture_time] exif_data[36867] # 提取相机型号 if 272 in exif_data: # Model info[camera_model] exif_data[272] # 提取GPS信息 if 34853 in exif_data: # GPSInfo info[has_gps] True except: pass return info def __call__(self, images, text, **kwargs): 修改处理函数添加图片信息到文本中 # 处理单张图片 if not isinstance(images, list): images [images] # 提取图片信息 image_infos [] for img in images: info self.extract_image_info(img) image_infos.append(info) # 构建增强的文本输入 enhanced_text text # 如果有图片信息添加到文本中 if image_infos and any(image_infos): info_str 图片信息 for i, info in enumerate(image_infos): info_str f\n图片{i1}: 尺寸{info.get(size, 未知)} if capture_time in info: info_str f, 拍摄时间{info[capture_time]} enhanced_text f{info_str}\n\n问题{text} # 处理图片 pixel_values self.image_processor(images, return_tensorspt).pixel_values # 处理增强后的文本 text_encoding self.tokenizer( enhanced_text, return_tensorspt, paddingTrue, truncationTrue ) return { pixel_values: pixel_values, input_ids: text_encoding[input_ids], attention_mask: text_encoding[attention_mask], image_infos: image_infos # 可选返回图片信息供后续使用 }这个修改的妙处模型不仅看到图片还知道图片的尺寸、拍摄时间等信息对于“这张照片是什么时候拍的”这类问题模型可能回答得更准确图片信息作为上下文帮助模型更好地理解图片内容4.4 实战修改三添加图片分类预处理如果你的应用场景比较特定比如只处理医学影像、只处理街景照片你可以添加针对性的预处理。# 添加针对特定场景的预处理 class Step3VLProcessor: def __init__(self, image_processor, tokenizer, application_modegeneral): self.image_processor image_processor self.tokenizer tokenizer self.application_mode application_mode # general, medical, document, etc. def specialized_preprocess(self, image): 根据应用模式进行专门预处理 if self.application_mode medical: # 医学影像处理增强对比度标准化强度 from PIL import ImageOps image ImageOps.autocontrast(image, cutoff2) image image.convert(L) # 转为灰度 return image elif self.application_mode document: # 文档处理二值化去噪 from PIL import ImageFilter image image.convert(L) # 使用阈值二值化 image image.point(lambda x: 0 if x 128 else 255, 1) # 轻微降噪 image image.filter(ImageFilter.MedianFilter(size3)) return image elif self.application_mode satellite: # 卫星图像处理增强特定波段 import numpy as np img_array np.array(image) # 增强植被指数简单示例 if len(img_array.shape) 3 and img_array.shape[2] 3: # 假设是RGB增强绿色通道 img_array[:, :, 1] np.clip(img_array[:, :, 1] * 1.3, 0, 255) image Image.fromarray(img_array.astype(uint8)) return image else: # 通用模式返回原图 return image def __call__(self, images, text, **kwargs): 添加专门化预处理 if not isinstance(images, list): images [images] # 应用专门化预处理 processed_images [] for img in images: processed_img self.specialized_preprocess(img) processed_images.append(processed_img) # 后续处理... pixel_values self.image_processor(processed_images, return_tensorspt).pixel_values text_encoding self.tokenizer( text, return_tensorspt, paddingTrue, truncationTrue ) return { pixel_values: pixel_values, input_ids: text_encoding[input_ids], attention_mask: text_encoding[attention_mask] }使用示例# 在app.py中初始化时指定应用模式 processor Step3VLProcessor.from_pretrained( stepfun-ai/Step3-VL-10B, application_modedocument # 指定文档处理模式 )这样当你处理文档图片时系统会自动进行二值化和降噪处理让文字更清晰提高OCR的准确率。4.5 实战修改四添加批量处理优化如果你需要处理大量图片可以添加批量处理优化。# 添加批量处理优化 from concurrent.futures import ThreadPoolExecutor import threading class Step3VLProcessor: def __init__(self, image_processor, tokenizer, max_workers4): self.image_processor image_processor self.tokenizer tokenizer self.executor ThreadPoolExecutor(max_workersmax_workers) self._lock threading.Lock() def batch_preprocess(self, images): 并行批量预处理图片 def preprocess_single(img): # 这里可以添加各种预处理逻辑 if not isinstance(img, Image.Image): img Image.fromarray(img) img img.convert(RGB) img.thumbnail((728, 728), Image.Resampling.LANCZOS) return img # 使用线程池并行处理 with self.executor: results list(self.executor.map(preprocess_single, images)) return results def batch_call(self, images_list, texts_list, **kwargs): 批量处理多组输入 images_list: 图片列表的列表 texts_list: 文本列表 all_pixel_values [] all_input_ids [] all_attention_masks [] for images, text in zip(images_list, texts_list): # 批量预处理图片 processed_images self.batch_preprocess(images) # 处理图片 pixel_values self.image_processor( processed_images, return_tensorspt ).pixel_values # 处理文本 text_encoding self.tokenizer( text, return_tensorspt, paddingTrue, truncationTrue ) all_pixel_values.append(pixel_values) all_input_ids.append(text_encoding[input_ids]) all_attention_masks.append(text_encoding[attention_mask]) # 批量返回 return { pixel_values: torch.cat(all_pixel_values, dim0), input_ids: torch.cat(all_input_ids, dim0), attention_mask: torch.cat(all_attention_masks, dim0) }这个优化对于需要处理大量图片的场景特别有用比如批量处理商品图片生成描述批量处理文档图片进行OCR批量处理监控图片进行分析5. 修改后的集成与测试修改完processing_step3.py后我们需要把它集成到整个应用中并进行测试。5.1 修改app.py以使用新的处理器首先更新app.py中的导入和初始化# 在app.py中 import gradio as gr import torch from PIL import Image # 导入我们修改后的处理器 from processing_step3 import Step3VLProcessor # 初始化处理器可以传入自定义参数 processor Step3VLProcessor.from_pretrained( stepfun-ai/Step3-VL-10B, enhance_contrastTrue, # 开启对比度增强 sharpen_imageTrue, # 开启图片锐化 extract_exifTrue, # 开启EXIF信息提取 application_modegeneral # 应用模式 ) # 加载模型这里假设模型已经加载 model ... # 你的模型加载代码 # 修改处理函数以使用新的处理器 def process_image_and_text(image, text, max_length, temperature, top_p, enhance_contrast, sharpen_image, extract_exif): 支持更多参数的处理函数 try: # 动态更新处理器参数 processor.enhance_contrast enhance_contrast processor.sharpen_image sharpen_image processor.extract_exif extract_exif # 使用处理器 inputs processor( imagesimage, texttext, return_tensorspt ) # 后续处理... if torch.cuda.is_available(): inputs {k: v.cuda() for k, v in inputs.items()} with torch.no_grad(): outputs model.generate( **inputs, max_lengthmax_length, temperaturetemperature, top_ptop_p, do_sampleTrue ) response processor.decode(outputs[0], skip_special_tokensTrue) # 如果有图片信息可以一并返回 if hasattr(processor, last_image_info): response f图片信息: {processor.last_image_info}\n\n回答: {response} return response except Exception as e: return f推理出错: {str(e)}5.2 更新Gradio界面添加新控件然后在界面中添加新的控制选项with gr.Blocks(titleStep3-VL-10B 视觉语言模型增强版) as demo: gr.Markdown(# ️ Step3-VL-10B 视觉语言模型增强版) gr.Markdown(## 支持图片预处理增强和EXIF信息提取) with gr.Row(): with gr.Column(scale1): image_input gr.Image(label上传图片, typepil) with gr.Column(scale2): text_input gr.Textbox( label问题, placeholder请输入关于图片的问题..., lines3 ) with gr.Accordion(生成参数, openFalse): max_length gr.Slider( minimum10, maximum1024, value512, label最大生成长度 ) temperature gr.Slider( minimum0, maximum1, value0.7, label温度 (Temperature) ) top_p gr.Slider( minimum0, maximum1, value0.9, labelTop-P 采样 ) # 新增图片预处理选项 with gr.Accordion(图片预处理选项, openFalse): enhance_contrast gr.Checkbox( label增强对比度, valueTrue ) sharpen_image gr.Checkbox( label锐化图片, valueTrue ) extract_exif gr.Checkbox( label提取EXIF信息, valueTrue ) submit_btn gr.Button(发送, variantprimary) output_text gr.Textbox(label模型回答, lines10) # 更新事件绑定传入新参数 submit_btn.click( fnprocess_image_and_text, inputs[ image_input, text_input, max_length, temperature, top_p, enhance_contrast, sharpen_image, extract_exif ], outputsoutput_text )5.3 测试修改效果修改完成后重启服务并测试# 重启服务 supervisorctl restart step3vl-webui # 查看日志确认没有错误 tail -f /root/Step3-VL-10B-Base-webui/supervisor.log然后打开浏览器测试新功能测试图片预处理上传一张较暗的图片开启“增强对比度”和“锐化图片”提问“描述这张图片”观察模型是否对图片细节的描述更准确测试EXIF信息提取上传一张带有EXIF信息的照片用手机拍的照片通常都有开启“提取EXIF信息”提问“这张照片是什么时候拍的”查看回答中是否包含拍摄时间信息测试批量处理如果有批量处理功能测试上传多张图片观察处理速度是否有提升5.4 常见问题调试如果在测试中遇到问题可以这样排查问题1导入错误# 检查依赖是否安装 pip list | grep Pillow # 图片处理库 pip list | grep exifread # EXIF读取库 # 如果没有安装安装它们 pip install Pillow exifread问题2预处理导致图片变形# 在preprocess_image方法中添加调试信息 def preprocess_image(self, image): print(f原始图片尺寸: {image.size}) print(f原始图片模式: {image.mode}) # 处理代码... print(f处理后尺寸: {image.size}) print(f处理后模式: {image.mode}) return image问题3EXIF信息提取失败# 添加更详细的错误处理 def extract_image_info(self, image): info {} try: # 尝试多种方式获取EXIF if hasattr(image, _getexif): exif_data image._getexif() elif hasattr(image, getexif): exif_data image.getexif() else: exif_data None # 后续处理... except Exception as e: print(fEXIF提取失败: {e}) info[error] str(e) return info6. 总结与进阶建议通过今天的实战我们完成了从使用者到开发者的转变。你现在不仅知道怎么用Step3-VL-10B还知道怎么改它让它更适合你的需求。6.1 关键收获回顾理解了项目结构知道了每个文件的作用知道该在哪里修改掌握了Gradio界面定制学会了如何添加新的界面元素和功能深入了图像处理器理解了processing_step3.py的工作原理并进行了实际修改实现了实用功能添加了图片预处理、信息提取、批量处理等实用功能6.2 更多定制化思路如果你还想进一步定制这里有一些思路添加图片质量评估def assess_image_quality(self, image): 评估图片质量给出处理建议 # 计算清晰度、亮度、对比度等指标 # 根据指标决定是否需要进行预处理 pass添加水印检测和去除def detect_and_remove_watermark(self, image): 检测并尝试去除水印 # 使用传统图像处理或深度学习检测水印 # 尝试修复被水印覆盖的区域 pass添加图片分类路由def route_by_image_type(self, image): 根据图片类型路由到不同的处理流程 # 判断是文档、自然图像、医学影像等 # 应用不同的预处理策略 pass添加处理流水线class ProcessingPipeline: 可配置的处理流水线 def __init__(self): self.steps [] def add_step(self, step_func, conditionNone): 添加处理步骤 self.steps.append((step_func, condition)) def process(self, image): 按顺序执行处理步骤 for step_func, condition in self.steps: if condition is None or condition(image): image step_func(image) return image6.3 最佳实践建议逐步修改不要一次性做太多修改每改一点就测试一下备份原文件修改前先备份processing_step3.py方便回滚添加日志在关键步骤添加日志输出方便调试性能考虑预处理会增加计算开销要考虑性能影响用户体验添加的选项要有明确的说明让用户知道有什么用6.4 下一步学习方向如果你对今天的修改感兴趣还想深入学习学习Gradio高级功能Gradio支持更复杂的布局、主题定制、异步处理等研究模型架构深入理解modeling_step_vl.py了解多模态模型的工作原理探索其他预处理技术学习更多的图像处理算法如超分辨率、去噪、色彩校正等优化性能学习如何优化处理速度特别是批量处理时的性能添加监控添加处理时长、成功率等监控指标记住最好的学习方式就是动手实践。今天你修改了图片处理器明天你可以尝试修改模型配置后天可以尝试添加新的功能。每一步修改都会让你对这个系统有更深的理解。获取更多AI镜像想探索更多AI镜像和应用场景访问 CSDN星图镜像广场提供丰富的预置镜像覆盖大模型推理、图像生成、视频生成、模型微调等多个领域支持一键部署。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2505801.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;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…