【图像大模型】Stable Video Diffusion:基于时空扩散模型的视频生成技术深度解析
Stable Video Diffusion:基于时空扩散模型的视频生成技术深度解析
- 一、架构设计与技术演进
- 1.1 核心模型架构
- 1.2 技术创新点
- 1.2.1 运动预测网络
- 1.2.2 层级式训练策略
- 二、系统架构解析
- 2.1 完整生成流程
- 2.2 性能指标对比
- 三、实战部署指南
- 3.1 环境配置
- 3.2 基础推理代码
- 3.3 高级参数配置
- 四、典型问题解决方案
- 4.1 视频闪烁问题
- 4.2 显存优化策略
- 4.3 运动不连贯处理
- 五、理论基础与算法解析
- 5.1 时空扩散公式
- 5.2 光流一致性损失
- 六、进阶应用开发
- 6.1 视频风格迁移
- 6.2 长视频生成
- 七、参考文献与扩展阅读
- 八、性能优化与生产部署
- 8.1 TensorRT加速
- 8.2 分布式推理
- 九、未来发展方向
一、架构设计与技术演进
1.1 核心模型架构
Stable Video Diffusion (SVD) 采用三层级联扩散架构实现图像到视频的生成,其数学表达为:
p θ ( x 1 : T ∣ z 0 ) = ∏ t = 1 T p θ ( x t ∣ x t − 1 , z 0 ) p_\theta(x_{1:T}|z_0) = \prod_{t=1}^T p_\theta(x_t|x_{t-1}, z_0) pθ(x1:T∣z0)=t=1∏Tpθ(xt∣xt−1,z0)
关键组件代码实现:
class SpatioTemporalUNet(nn.Module):def __init__(self, in_dim=4):super().__init__()# 时空卷积层self.conv3d_1 = nn.Conv3d(in_dim, 128, kernel_size=(3,3,3), padding=1)self.time_attn = TemporalAttention(128)self.down_blocks = nn.ModuleList([DownBlock3D(128, 256, time_embed_dim=512),DownBlock3D(256, 512, time_embed_dim=512)])self.up_blocks = nn.ModuleList([UpBlock3D(512, 256, time_embed_dim=512),UpBlock3D(256, 128, time_embed_dim=512)])self.final_conv = nn.Conv3d(128, 4, kernel_size=3, padding=1)def forward(self, x, t, clip_embed):# x: [B, C, T, H, W]x = self.conv3d_1(x)x = self.time_attn(x)skip_connections = []for blk in self.down_blocks:x, skip = blk(x, t, clip_embed)skip_connections.append(skip)for blk in self.up_blocks:x = blk(x, skip_connections.pop(), t, clip_embed)return self.final_conv(x)
1.2 技术创新点
1.2.1 运动预测网络
class MotionPredictor(nn.Module):def __init__(self, latent_dim=128):super().__init__()self.flow_net = nn.Sequential(nn.Conv3d(latent_dim, 256, 3, padding=1),nn.GroupNorm(32, 256),nn.SiLU(),nn.Conv3d(256, 2, 3, padding=1) # 输出光流场)def forward(self, x):# x: [B, C, T, H, W]return self.flow_net(x)
1.2.2 层级式训练策略
训练过程分为三个阶段:
- 基础帧生成:固定空间卷积,训练时序模块
- 运动增强:联合优化运动预测网络
- 超分辨率:训练空间上采样模块
二、系统架构解析
2.1 完整生成流程
2.2 性能指标对比
指标 | SVD-XT | Previous Model |
---|---|---|
最大帧数 | 25 | 14 |
分辨率 | 1024×576 | 768×512 |
运动一致性得分 | 0.82 | 0.68 |
FVD (16帧) | 234 | 356 |
推理速度 (A100) | 3.2s | 5.8s |
三、实战部署指南
3.1 环境配置
# 创建专用环境
conda create -n svd python=3.10
conda activate svd# 安装核心依赖
pip install torch==2.2.0 torchvision==0.17.0 --index-url https://download.pytorch.org/whl/cu121
pip install diffusers==0.25.0 transformers==4.35.0 accelerate==0.26.0# 安装视频处理组件
pip install decord==0.6.0 av==10.0.0
3.2 基础推理代码
from diffusers import StableVideoDiffusionPipeline
import torchpipe = StableVideoDiffusionPipeline.from_pretrained("stabilityai/stable-video-diffusion-img2vid-xt",torch_dtype=torch.float16,variant="fp16"
).to("cuda")# 输入配置
image = load_image("input.jpg")
generator = torch.Generator("cuda").manual_seed(42)# 视频生成
video_frames = pipe(image,num_frames=25,num_inference_steps=50,motion_bucket_id=120,generator=generator
).frames# 保存结果
export_to_video(video_frames, "output.mp4", fps=10)
3.3 高级参数配置
# 运动控制参数
video_frames = pipe(...,motion_bucket_id=150, # 运动强度 (80-200)noise_aug_strength=0.02, # 噪声增强系数decode_chunk_size=8, # 显存优化分块temporal_chunk_size=4 # 时序分块
)
四、典型问题解决方案
4.1 视频闪烁问题
# 后处理时域滤波
from torchvision.transforms.functional import gaussian_blurdef temporal_smoothing(frames, kernel_size=5):smoothed = []for i in range(len(frames)):start = max(0, i - kernel_size//2)end = min(len(frames), i + kernel_size//2 + 1)window = frames[start:end]avg_frame = np.mean(window, axis=0)smoothed.append(avg_frame)return smoothed
4.2 显存优化策略
# 启用内存优化技术
pipe.enable_vae_slicing()
pipe.enable_vae_tiling()
pipe.enable_model_cpu_offload()# 分块参数设置
pipe.set_chunk_params(spatial_chunk=64, # 空间分块大小temporal_chunk=6 # 时间分块数
)
4.3 运动不连贯处理
# 添加运动约束损失
video_frames = pipe(...,motion_scale=1.5, # 增强运动强度coherence_penalty_weight=0.3 # 连贯性约束
)
五、理论基础与算法解析
5.1 时空扩散公式
视频扩散过程可分解为:
q ( x 1 : T ∣ x 0 ) = ∏ t = 1 T q ( x t ∣ x t − 1 ) q ( x t ∣ x t − 1 ) = N ( x t ; α t x t − 1 , ( 1 − α t ) I ) q(x_{1:T}|x_0) = \prod_{t=1}^T q(x_t|x_{t-1}) \\ q(x_t|x_{t-1}) = \mathcal{N}(x_t; \sqrt{\alpha_t}x_{t-1}, (1-\alpha_t)I) q(x1:T∣x0)=t=1∏Tq(xt∣xt−1)q(xt∣xt−1)=N(xt;αtxt−1,(1−αt)I)
训练目标函数:
L = E t , x 0 , ϵ [ ∥ ϵ − ϵ θ ( x t , t , c ) ∥ 2 ] + λ f l o w L f l o w \mathcal{L} = \mathbb{E}_{t,x_0,\epsilon}\left[\|\epsilon - \epsilon_\theta(x_t,t,c)\|^2\right] + \lambda_{flow}\mathcal{L}_{flow} L=Et,x0,ϵ[∥ϵ−ϵθ(xt,t,c)∥2]+λflowLflow
5.2 光流一致性损失
L f l o w = ∑ i = 1 T − 1 ∥ F ( x i ) − W ( x i + 1 , F ( x i ) ) ∥ 1 \mathcal{L}_{flow} = \sum_{i=1}^{T-1}\|F(x_i) - W(x_{i+1}, F(x_i))\|_1 Lflow=i=1∑T−1∥F(xi)−W(xi+1,F(xi))∥1
其中 F F F为特征提取器, W W W为光流变形操作。
六、进阶应用开发
6.1 视频风格迁移
# 结合ControlNet
from diffusers import ControlNetModelcontrolnet = ControlNetModel.from_pretrained("lllyasviel/sd-controlnet-seg",torch_dtype=torch.float16
)
pipe = StableVideoDiffusionPipeline.from_pretrained(...,controlnet=controlnet
)# 使用语义分割图控制生成
seg_map = load_segmentation("input_seg.png")
video_frames = pipe(image=image,control_image=seg_map
).frames
6.2 长视频生成
# 分段生成策略
def generate_long_video(pipe, init_image, total_frames=100):chunk_size = 25all_frames = []current_image = init_imagefor _ in range(total_frames // chunk_size):frames = pipe(current_image, num_frames=chunk_size).framesall_frames.extend(frames)current_image = frames[-1] # 使用最后一帧作为新起点return all_frames
七、参考文献与扩展阅读
-
Stable Video Diffusion技术报告
Stability AI, 2023 -
视频扩散模型基础
Ho J. et al. Video Diffusion Models. arXiv:2204.03458 -
光流估计方法
Dosovitskiy A. et al. FlowNet: Learning Optical Flow with Convolutional Networks. ICCV 2015 -
时空注意力机制
Zhou L. et al. Space-Time Memory Networks for Video Object Segmentation. CVPR 2021
八、性能优化与生产部署
8.1 TensorRT加速
# 转换ONNX模型
python export_to_onnx.py \--model_path stabilityai/stable-video-diffusion-img2vid-xt \--output svd_xt.onnx# 构建TensorRT引擎
trtexec --onnx=svd_xt.onnx \--saveEngine=svd_xt.trt \--fp16 \--optShapes=latent:1x4x25x64x96
8.2 分布式推理
# 多GPU并行
from accelerate import Acceleratoraccelerator = Accelerator()
pipe = accelerator.prepare(pipe)def distributed_inference():results = []with accelerator.split_between_processes(inputs) as batch:results.append(pipe(**batch))return accelerator.gather(results)
九、未来发展方向
- 交互式视频编辑:实现基于语义笔刷的实时编辑
- 物理引擎集成:结合刚体动力学模拟真实运动
- 多视角生成:从单视频生成多视角立体视频
- 超长视频生成:实现分钟级连续视频生成
Stable Video Diffusion的技术突破标志着视频生成进入实用化阶段。其创新性地将扩散模型与时空建模相结合,为影视制作、游戏开发、虚拟现实等领域提供了强大的创作工具。未来随着计算效率的持续优化和控制精度的提升,视频生成技术有望彻底改变传统内容生产方式。
相关文章:
【图像大模型】Stable Video Diffusion:基于时空扩散模型的视频生成技术深度解析
Stable Video Diffusion:基于时空扩散模型的视频生成技术深度解析 一、架构设计与技术演进1.1 核心模型架构1.2 技术创新点1.2.1 运动预测网络1.2.2 层级式训练策略 二、系统架构解析2.1 完整生成流程2.2 性能指标对比 三、实战部署指南3.1 环境配置3.2 基础推理代码…...
【免杀】C2免杀技术(七)远程线程注入
远程线程注入(Remote Thread Injection)是一种常见的进程注入技术,经常用于红队渗透、恶意软件加载、持久化控制等场景中,尤其在免杀(AV/EDR bypass)应用领域中,是一种历史悠久但依然有效的手段…...
二、【环境搭建篇】:Django 和 Vue3 开发环境准备
【环境搭建篇】:Django 和 Vue3 开发环境准备 前言为什么我们需要特定的开发环境?准备工作第一步:搭建后端开发环境 (Python, Django, DRF)1. 安装 Python2. 创建和激活 Python 虚拟环境3. 在虚拟环境中安装 Django 和 DRF 第二步:…...
【神经网络与深度学习】激活函数的可微可导
引言: 在深度学习领域,激活函数扮演着至关重要的角色。它不仅影响神经网络的非线性建模能力,还直接关系到梯度计算的稳定性。在优化过程中,我们通常要求激活函数具有良好的数学性质,其中可微性是一个关键条件。相比简单…...
【Tauri2】046—— tauri_plugin_clipboard_manager(一)
目录 前言 正文 安装 Rust中的使用 对文字的操作 看看write_text的函数签名 看看read_text的函数签名 对图像的操作 对html的操作 总结 前言 这篇就来看看clipboard这个插件。 参考如下 Clipboard | Taurihttps://tauri.app/plugin/clipboard/ 正文 安装 执行下…...
高效选课系统:一键管理你的课程表
选课流程 数据模型 我的课程表Controller Api(value "我的课程表接口", tags "我的课程表接口") Slf4j RestController public class MyCourseTablesController {Autowiredprivate MyCourseTablesService myCourseTablesService;ApiOperation("添加…...
Pytorch分布式训练,数据并行,单机多卡,多机多卡
分布式训练 所有代码可以见我github 仓库:https://github.com/xiejialong/ddp_learning.git 数据并行(Data Parallelism,DP) 跨多个gpu训练模型的最简单方法是使用 torch.nn.DataParallel. 在这种方法中,模型被复制…...
Secarmy Village: Grayhat Conference靶场
Secarmy Village: Grayhat Conference 来自 <Secarmy Village: Grayhat Conference ~ VulnHub> 1,将两台虚拟机网络连接都改为NAT模式 2,攻击机上做namp局域网扫描发现靶机 nmap -sn 192.168.23.0/24 那么攻击机IP为192.168.23.182,靶…...
centos 9 Kickstart + Ansible自动化部署 —— 筑梦之路
目标 利用 Kickstart 完成 centos 9 系统的全自动安装(裸金属/虚拟机)。 安装完成后自动接入 Ansible 进行软件包、服务、用户、配置等系统初始化操作。 实现一套通用、可重复、可维护的自动化交付流程。 KS文件 # ks.cfg 示例 install lang zh_CN.…...
HarmonyOS应用开发入门宝典——项目驱动学习法实践
学习一项新技能,最好也是最快的方法就是动手实战。学习鸿蒙也一样,给自己定一个小目标,直接找项目练,这样进步是最快的。记住,最好的学习时机永远是现在,最好的老师永远是你正在开发的项目。 一、为什么选择…...
Python类的力量:第六篇:设计模式——Python面向对象编程的“架构蓝图”
文章目录 前言:从“代码堆砌”到“模式复用”的思维跃迁 一、创建型模式:对象创建的“智能工厂”1. 单例模式(Singleton):全局唯一的“资源管家”2. 工厂模式(Factory):对象创建的“…...
第50天-使用Python+Qt+DeepSeek开发AI运势测算
1. 环境准备 bash 复制 下载 pip install pyside6 requests python-dotenv 2. 获取DeepSeek API密钥 访问DeepSeek官网注册账号 进入控制台创建API密钥 在项目根目录创建.env文件: env 复制 下载 DEEPSEEK_API_KEY=your_api_key_here 3. 创建主应用框架 python 复制…...
CentOS系统上挂载磁盘
在CentOS系统上挂载磁盘,主要包括查看磁盘设备、分区(若需要)、格式化、创建挂载点和挂载等步骤,以下是详细操作: 1. 查看磁盘设备 使用fdisk -l或lsblk命令查看系统识别到的磁盘设备。 fdisk -l:列出所…...
(一) 本地hadoop虚拟机系统设置
1.配置固定IP地址(每一台都配置) 开启node1,修改主机名为node1,并修改固定IP为:192.168.88.131 # 修改主机名 hostnamectl set-hostname node1# 修改IP vim /etc/sysconfig/network-scripts/ifcfg-ens33 IPADDR"…...
亿级核心表如何优雅扩展字段
1 导语 亿级数据的核心表新增一个字段,远不止一句简单的“ALTER TABLE”,锁表风险、页分裂、索引性能衰减……每一个问题都可能引发线上事故。如何在不影响业务的前提下,只需简单的配置,即可实现字段的动态扩展?本文将…...
单端传输通道也会有奇偶模现象喔
奇模(Odd mode)与偶模(Even mode)对差动对是很关键的要素,其会影响奇/偶模阻抗与相位速度,设计不良甚会让共模噪声引入整个差动对使讯号质量下降。 然而对单端信号系统而言呢? 如果说一对side b…...
VUE3 中的 ResizeObserver 警告彻底解决方案
问题背景 今天在使用 Vue 3 Ant Design Vue 开发后台管理系统时,在页面频繁触发 元素尺寸变化(如表格滚动、窗口缩放) 的时候,控制台频繁出现如下警告: ResizeObserver loop completed with undelivered notificati…...
IDEA2025版本使用Big Data Tools连接Linux上Hadoop的HDFS
目录 Windows的准备 1. 将与Linux上版本相同的hadoop压缩包解压到本地 编辑2.设置$HADOOP HOME环境变量指向:E:\hadoop-3.3.4 3.下载hadoop.dll和winutils.exe文件 4.将hadoop.dll和winutils.exe放入$HADOOP HOME/bin中 IDEA中操作 1.下载Big Data Tools插件 2.添加并连…...
Gas优化利器:Merkle 树如何助力链上数据效率革命
目录 前言原理Merkle树示意图实战演示:构建 Merkle 树并在合约中验证离线构建 Merkle 树(手动计算Merkle树、生成mermaid示意图)编写Merkle.js脚本执行Merkle.js脚本执行结果展示mermaid流程图展示离线构建 Merkle 树(merkletreejs计算Merkle树、验证哈希路径)编写Merkle.…...
R语言空间分析实战:地理加权回归联合主成份与判别分析破解空间异质性难题
在自然和社会科学领域有大量与地理或空间有关的数据,这一类数据一般具有严重的空间异质性,而通常的统计学方法并不能处理空间异质性,因而对此类型的数据无能为力。以地理加权回归为基础的一系列方法:经典地理加权回归,…...
kafka入门(二)
Java客户端访问Kafka 引入maven依赖 <dependency> <groupId>org.apache.kafka</groupId> <artifactId>kafka‐clients</artifactId> <version>2.4.1</version> </dependency> 消息发送端代码 package com.tuling.kafka.ka…...
学习日记-day11-5.20
完成目标: comment.java package com.zcr.pojo; import org.hibernate.annotations.GenericGenerator;import javax.persistence.*; //JPA操作表中数据,可以将对应的实体类映射到一张表上Entity(name "t_comment")//表示当前的实体类与哪张表…...
手淘不易被清洗销量的4个成交入口
在淘宝运营中,销量是店铺权重的重要指标之一,但平台对虚假交易的打击力度越来越大,许多商家因销量被清洗而损失惨重。那么,通过什么样的手淘成交入口稳定不易清洗呢?经过实测,我们总结了以下手淘4个不易被清…...
【Linux】Linux 多线程
目录 1. Linux线程概念2. 重谈进程地址空间---页表2.1 如何由虚拟地址转化为物理地址的 3. pthread库调用接口3.1 线程的创建---pthread_create3.2 线程等待---pthread_join3.3 线程的退出3.4 分离线程 4. 线程库5. 线程ID6. Linux线程互斥6.1 锁6.2 锁的接口6.2.1 互斥量的初始…...
DAY31
知识点回顾 规范的文件命名规范的文件夹管理机器学习项目的拆分编码格式和类型注解 作业:尝试针对之前的心脏病项目,准备拆分的项目文件,思考下哪些部分可以未来复用。 浙大疏锦行...
大模型应用开发“扫盲”——基于市场某款智能问数产品的技术架构进行解析与学习
本文将从一款问数产品相关技术架构,针对大模型应用开发中的基础知识进行“扫盲”式科普,文章比较适合新手小白,属于是我的学习笔记整理,大佬可以划走啦~产品关键信息已经进行模糊处理,如有侵权请联系删除。 文章目录 前…...
List优雅分组
一、前言 最近小永哥发现,在开发过程中,经常会遇到需要对list进行分组,就是假如有一个RecordTest对象集合,RecordTest对象都有一个type的属性,需要将这个集合按type属性进行分组,转换为一个以type为key&…...
打破建筑与制造数据壁垒:Revit 到 STP 格式转换全攻略(含插件应用 + 迪威模型实战)
引言 在建筑信息模型(BIM)与计算机辅助设计(CAD)领域,数据在不同软件和系统间的高效流转至关重要。Revit 作为 BIM 技术应用的主流软件,常用于建筑设计、施工和运维管理;而 STP(STE…...
RISC-V 开发板 MUSE Pi Pro USB 测试(3.0 U盘,2.0 UVC摄像头)
视频讲解: RISC-V 开发板 MUSE Pi Pro USB 测试(3.0 U盘,2.0 UVC摄像头) 总共开发板有4个USB的A口,1个USB的TypeC口,我们插上两个USB3.0的U盘和一个USB2.0的UVC摄像头来进行测试 lsusb -tv 可以看到有3个US…...
驱动相关基础
一、驱动分类与区别 字符设备驱动 一个字节一个字节进行读写操作的设备,以字符流的形式进行数据传输(如鼠标、键盘、串口)。 块设备驱动 以块为单位进行读写操作的设备,块的大小通常为 512 字节、1024 字节。 块设备驱动主…...
【node.js】核心进阶
个人主页:Guiat 归属专栏:node.js 文章目录 1. Node.js高级异步编程1.1 Promise深入理解1.1.1 创建和使用Promise1.1.2 Promise组合模式 1.2 Async/Await高级模式1.2.1 基本使用1.2.2 并行执行1.2.3 顺序执行与错误处理 1.3 事件循环高级概念1.3.1 事件循…...
高频Java面试题深度拆解:String/StringBuilder/StringBuffer三剑客对决(万字长文预警)
文章目录 一、这道题的隐藏考点你Get到了吗?二、内存模型里的暗战(图解警告)2.1 String的不可变性之谜2.2 可变双雄的内存游戏 三、线程安全背后的修罗场3.1 StringBuffer的同步真相3.2 StringBuilder的裸奔哲学 四、性能对决:用数…...
量子计算的曙光:从理论奇点到 IT 世界的颠覆力量
在信息技术(IT)的飞速发展中,一项前沿技术正以耀眼的光芒照亮未来——量子计算(Quantum Computing)。2025 年,随着量子硬件的突破、算法的优化以及企业对超算能力的渴求,量子计算从科幻梦想逐步…...
c++使用protocol buffers
在 C 里使用 Protocol Buffer,要先定义消息结构,接着生成 C 代码,最后在程序里使用这些生成的代码。 定义消息结构 首先要创建一个.proto文件,在其中定义消息类型和字段。 // person.proto syntax "proto3"; // 指…...
AI驱动发展——高能受邀参加华为2025广东新质生产力创新峰会
当AI浪潮席卷全球产业版图,一场以"智变"驱动"质变"的变革正在发生。5月15日,华为中国行2025广东新质生产力创新峰会璀璨启幕,作为华为生态战略合作伙伴,高能计算机与行业领军者同台论道,共同解码A…...
怎样解决photoshop闪退问题
检查系统资源:在启动 Photoshop 之前,打开任务管理器检查 CPU 和内存的使用情况。如果发现资源占用过高,尝试关闭不必要的程序或重启计算机以释放资源。更新 Photoshop 版本:确保 Photoshop 是最新版本。Adobe 经常发布更新以修复…...
AWS CodePipeline+ Elastic Beanstalk(AWS中国云CI/CD)
问题 最近需要利用AWS云上面的CI/CD部署Spring应用。 一图胜千言 步骤 打开CodePipeline网页,开始管道创建,如下图: 管道设置,如下图: 这里主要设置管道名称,至于服务角色,直接让codepipel…...
人工智能核心知识:AI Agent 的四种关键设计模式
人工智能核心知识:AI Agent 的四种关键设计模式 一、引言 在人工智能领域,AI Agent(人工智能代理)是实现智能行为和决策的核心实体。它能够感知环境、做出决策并采取行动以完成特定任务。为了设计高效、灵活且适应性强的 AI Age…...
Electron+vite+vue3 从0到1搭建项目,开发Win、Mac客户端
随着前端技术的发展,出现了所谓的大前端。 大前端则是指基于前端技术延伸出来的各种终端平台及应用场景,包括APP、桌面端、手表终端、服务端等。 本篇文章主要是和大家一起学习一下使用Electron 如何打包出 Windows 和 Mac 所使用的客户端APPÿ…...
GitLab部署
学git Git最新最新详细教程、安装(从入门到精通!!!!企业级实战!!!工作必备!!!结合IDEA、Github、Gitee实战!!!…...
基于R语言地理加权回归、主成份分析、判别分析等空间异质性数据分析技术
在自然和社会科学领域,存在大量与地理或空间相关的数据,这些数据通常具有显著的空间异质性。传统的统计学方法在处理这类数据时往往力不从心。基于R语言的一系列空间异质性数据分析方法,如地理加权回归(GWR)、地理加权…...
指针深入理解(二)
volatile关键字 防止优化指向内存地址, typedef 指针可以指向C语言所有资源 typedef 就是起一个外号。 指针运算符加减标签操作 指针加的是地址,并且增加的是该指针类型的一个单位,指针变量的步长可以用sizeof(p[0]) 这两个的p1是不一样…...
django回忆录(Python的一些基本概念, pycharm和Anaconda的配置, 以及配合MySQL实现基础功能, 适合初学者了解)
django 说实在的, 如果是有些Python基础或者编程基础, 使用django开发本地网站的速度还是很快的, 特别是配合ai进行使用. 本人使用该框架作业的一个主要原因就是因为要做数据库大作业, 哥们想速通, 结果由于我一开始没有接触过这些方面的知识, 其实也不算快, 而且现在我也没有…...
leetcode hot100刷题日记——5.无重复字符的最长字串
解答:滑动窗口思想(见官方题解) //方法1 class Solution { public:int lengthOfLongestSubstring(string s) {//哈希表记录是否有重复字符unordered_set<char>c;int maxlength0;int ns.size();//右指针初始化为-1,可以假设…...
一文讲清python、anaconda的安装以及pycharm创建工程
软件下载 Pycharm下载地址: https://download-cdn.jetbrains.com.cn/python/pycharm-community-2024.1.1.exe?_gl1*1xfh3l8*_gcl_au*MTg1NjU2NjA0OC4xNzQ3MTg3Mzg1*FPAU*MTg1NjU2NjA0OC4xNzQ3MTg3Mzg1*_ga*MTA2NzE5ODc1NS4xNzI1MzM0Mjc2*_ga_9J976DJZ68*czE3NDczMD…...
[每日一题] 3355. 零数组变换 i
文章目录 1. 题目链接2. 题目描述3. 题目示例4. 解题思路5. 题解代码6. 复杂度分析 1. 题目链接 3355. 零数组变换 I - 力扣(LeetCode) 2. 题目描述 给定一个长度为 n 的整数数组 nums 和一个二维数组 queries,其中 queries[i] [li, ri]。…...
【笔记】与PyCharm官方沟通解决开发环境问题
#工作记录 2025年5月20日 星期二 背景 在此前的笔记中,我们提到了向PyCharm官方反馈了几个关于Conda环境自动激活、远程解释器在社区版中的同步问题以及Shell脚本执行时遇到的问题。这些问题对日常开发流程产生了一定影响,因此决定联系官方支持寻求解…...
mariadb-cenots8安装
更新系统:安装完成 CentOS 8 后,连接到互联网,打开终端并运行以下命令来更新系统,以获取最新的软件包和安全补丁。 bash sudo yum update -y安装 MariaDB:运行以下命令来安装 MariaDB。 bash sudo yum install mariadb…...
Python实现VTK - 自学笔记(4):用Widgets实现三维交互控制
核心知识点 交互器样式(vtkInteractorStyle):自定义鼠标/键盘交互逻辑三维控件(3D Widgets):使用预制控件实现复杂交互回调机制:实现动态数据更新参数化控制:通过控件调整算法参数import vtk# 1. 创建圆锥体数据源 cone = vtk.vtkConeSour…...
在tp6模版中加减法
实际项目中,我们经常需要标签变量加减运算的操作。但是,在ThinkPHP中,并不支持模板变量直接运算的操作。幸运的是,它提供了自定义函数的方法,我们可以利用自定义函数解决:ThinkPHP模板自定义函数语法如下&a…...