当前位置: 首页 > news >正文

VectorBT量化入门系列:第五章 VectorBT性能评估与分析

VectorBT量化入门系列:第五章 VectorBT性能评估与分析

本教程专为中高级开发者设计,系统讲解VectorBT技术在量化交易中的应用。通过结合Tushare数据源和TA-Lib技术指标,深度探索策略开发、回测优化与风险评估的核心方法。从数据获取到策略部署,全面提升量化交易能力,助力开发者构建高效、稳健的交易系统。
文中内容仅限技术学习与代码实践参考,市场存在不确定性,技术分析需谨慎验证,不构成任何投资建议。适合量化新手建立系统认知,为策略开发打下基础。

VectorBT

学习对象

  • 中高级水平的开发者和数据分析师
  • 具备 Python 编程基础和一定的数据分析能力
  • 对量化交易和金融数据处理有一定了解
  • 熟悉 A 股市场,了解 Tushare 数据源和 TA-Lib 技术指标

教程目标

  • 系统学习 VectorBT 技术,掌握其在量化交易中的应用
  • 熟练使用 Tushare 数据源获取 A 股市场数据,并使用 Parquet 文件存储
  • 掌握基于 VectorBT 的策略开发、回测和性能评估流程
  • 学会使用 TA-Lib 计算技术指标,并将其应用于交易策略
  • 理解并实现多因子策略、机器学习策略等高级策略
  • 掌握策略优化、风险管理以及策略组合的方法
  • 能够独立构建和评估量化交易策略,并部署到生产环境

教程目录

第一章 VectorBT基础与环境搭建

1.1 VectorBT简介与应用场景
1.2 环境搭建与依赖安装
1.3 数据源与Tushare集成
1.4 数据存储与Parquet文件格式

第二章:VectorBT核心功能与数据处理

2.1 数据加载与预处理
2.2 时间序列数据处理
2.3 技术指标计算与TA-Lib集成
2.4 数据可视化与探索性分析

第三章:VectorBT策略回测基础

3.1 策略定义与实现
3.2 回测流程与关键参数
3.3 性能评估指标与解读
3.4 策略优化与参数调整

第四章:高级策略开发与优化

4.1 多因子策略开发
4.2 机器学习策略集成
4.3 风险管理与交易成本模拟
4.4 策略组合与资产配置

第五章:VectorBT性能评估与分析

5.1 性能评估框架
5.2 统计指标与回测报告
5.3 敏感性分析与压力测试
5.4 策略对比与选择标准

第六章:VectorBT实战案例

6.1 基于MACD的动量策略
6.2 基于RSI的均值回归策略
6.3 多因子选股策略
6.4 机器学习预测策略

第五章 VectorBT性能评估与分析

本章将深入探讨如何使用VectorBT进行策略性能评估和分析。我们将介绍性能评估框架、统计指标、敏感性分析以及策略对比等内容。

# 示例:运行多因子策略
data = load_data_from_parquet("./data/600519.SH.parquet")  # 贵州茅台
data = generate_multi_factor_signals(data)
portfolio = vbt.Portfolio.from_signals(close=data["close"],entries=data["signal"] == 1,exits=data["signal"] == -1,freq="D",init_cash=100000,fees=0.0015,slippage=0.0015,sl_stop=0.05,tp_stop=0.10,
)

5.1 性能评估框架

性能评估是策略开发的重要环节,VectorBT提供了丰富的工具来评估策略表现。

5.2 统计指标与回测报告

5.2.1 Portfolio.stats

# 计算关键指标
stats = portfolio.stats()# 绘制图表
portfolio.plot().show()# 打印报告
print(portfolio.stats())

输出:

Start                                2020-01-02 00:00:00
End                                  2024-12-31 00:00:00
Period                                1212 days 00:00:00
Start Value                                     100000.0
End Value                                  108968.031684
Total Return [%]                                8.968032
Benchmark Return [%]                           34.867257
Max Gross Exposure [%]                             100.0
Total Fees Paid                             20944.833953
Max Drawdown [%]                               52.462141
Max Drawdown Duration                  941 days 00:00:00
Total Trades                                          49
Total Closed Trades                                   48
Total Open Trades                                      1
Open Trade PnL                               1496.588556
Win Rate [%]                                   39.583333
Best Trade [%]                                 14.097797
Worst Trade [%]                                -8.991079
Avg Winning Trade [%]                          10.817294
Avg Losing Trade [%]                           -6.266302
Avg Winning Trade Duration    23 days 22:44:12.631578947
Avg Losing Trade Duration     20 days 01:39:18.620689655
Profit Factor                                   1.027352
Expectancy                                    155.655065
Sharpe Ratio                                    0.238863
Calmar Ratio                                    0.049944
Omega Ratio                                     1.038227
Sortino Ratio                                    0.35283
dtype: object

5.2.2 Portfolio.orders


# 计算关键指标
orders = portfolio.orders# 绘制图表
orders.plots().show()# 打印报告
print(orders.stats())

输出:

generate_performance_report

Start                2020-01-02 00:00:00
End                  2024-12-31 00:00:00
Period                1212 days 00:00:00
Total Records                         97
Total Buy Orders                      49
Total Sell Orders                     48
Min Size                       69.028927
Max Size                       91.758362
Avg Size                       83.302056
Avg Buy Size                    83.18164
Avg Sell Size                   83.42498
Avg Buy Price                1722.519706
Avg Sell Price               1733.594622
Total Fees                  20944.833953
Min Fees                      133.163145
Max Fees                      320.478898
Avg Fees                      215.926123
Avg Buy Fees                  214.932823
Avg Sell Fees                 216.940117
dtype: object

5.2.3 Portfolio.trades


# 计算关键指标
trades = portfolio.trades# 绘制图表
trades.plots().show()# 打印报告
print(trades.stats())

输出:

generate_performance_report

Start                                2020-01-02 00:00:00
End                                  2024-12-31 00:00:00
Period                                1212 days 00:00:00
First Trade Start                    2020-03-05 00:00:00
Last Trade End                       2024-12-31 00:00:00
Coverage                              1064 days 00:00:00
Overlap Coverage                         0 days 00:00:00
Total Records                                         49
Total Long Trades                                     49
Total Short Trades                                     0
Total Closed Trades                                   48
Total Open Trades                                      1
Open Trade PnL                               1496.588556
Win Rate [%]                                   39.583333
Max Win Streak                                         5
Max Loss Streak                                        7
Best Trade [%]                                 14.097797
Worst Trade [%]                                -8.991079
Avg Winning Trade [%]                          10.817294
Avg Losing Trade [%]                           -6.266302
Avg Winning Trade Duration    23 days 22:44:12.631578947
Avg Losing Trade Duration     20 days 01:39:18.620689655
Profit Factor                                   1.027352
Expectancy                                    155.655065
SQN                                             0.087304
dtype: object

5.3 敏感性分析与压力测试

敏感性分析和压力测试是评估策略鲁棒性的重要方法。

5.3.1 敏感性分析

def perform_sensitivity_analysis(strategy_func, param_ranges: dict, **kwargs
) -> pd.DataFrame:"""进行敏感性分析。:param strategy_func: 策略函数,接受参数并返回vbt.Portfolio对象:param param_ranges: 参数范围:param kwargs: 传递给策略函数的其他参数:return: 敏感性分析结果"""results = []# 获取所有参数的组合from itertools import productparams_list = list(product(*param_ranges.values()))for params in params_list:param_dict = dict(zip(param_ranges.keys(), params))# 运行策略portfolio = strategy_func(**param_dict, **kwargs)# 计算关键指标sharpe_ratio = portfolio.sharpe_ratio()total_return = portfolio.total_return()results.append({"params": param_dict,"sharpe_ratio": sharpe_ratio,"total_return": total_return,})return pd.DataFrame(results)# 示例:敏感性分析
def example_strategy(fast_window, slow_window):# 示例策略:简单移动平均交叉策略fast_ma = vbt.MA.run(close, window=fast_window)slow_ma = vbt.MA.run(close, window=slow_window)entries = fast_ma.ma_crossed_above(slow_ma)exits = fast_ma.ma_crossed_below(slow_ma)pf = vbt.Portfolio.from_signals(close,entries,exits,freq="D",init_cash=100000,fees=0.0015,slippage=0.0015,sl_stop=0.05,tp_stop=0.10,)return pf# 收盘价数据
close = data["close"]param_ranges = {"fast_window": [5, 10, 15], "slow_window": [20, 30, 40]}
sensitivity_results = perform_sensitivity_analysis(example_strategy, param_ranges)
print(sensitivity_results)

输出:

                                   params  sharpe_ratio  total_return
0   {'fast_window': 5, 'slow_window': 20}     -0.294548     -0.217831
1   {'fast_window': 5, 'slow_window': 30}      0.078081     -0.007422
2   {'fast_window': 5, 'slow_window': 40}      0.139590      0.032914
3  {'fast_window': 10, 'slow_window': 20}     -0.000603     -0.057222
4  {'fast_window': 10, 'slow_window': 30}     -0.006332     -0.041972
5  {'fast_window': 10, 'slow_window': 40}     -0.132529     -0.093364
6  {'fast_window': 15, 'slow_window': 20}     -0.039138     -0.077459
7  {'fast_window': 15, 'slow_window': 30}      0.037290     -0.022990
8  {'fast_window': 15, 'slow_window': 40}      0.000408     -0.033410

5.3.2 压力测试

def perform_stress_test(portfolio: vbt.Portfolio, market_crash_dates: list
) -> pd.DataFrame:"""进行压力测试。:param portfolio: 回测结果:param market_crash_dates: 市场大跌日期列表:return: 压力测试结果"""results = []# 获取投资组合的价值portfolio_value = portfolio.value()for crash_date in market_crash_dates:# 提取压力测试期间的数据crash_period = portfolio_value.loc[crash_date[0] : crash_date[1]]# 计算关键指标crash_return = (crash_period.iloc[-1] / crash_period.iloc[0]) - 1crash_drawdown = (crash_period / crash_period.cummax() - 1).min()results.append({"crash_period": f"{crash_date[0]}{crash_date[1]}","return": crash_return,"max_drawdown": crash_drawdown,})return pd.DataFrame(results)# 示例:压力测试
market_crash_dates = [("2020-02-01", "2020-03-31"), ("2022-01-01", "2022-03-31")]
stress_test_results = perform_stress_test(portfolio, market_crash_dates)
print(stress_test_results)

输出:

            crash_period    return  max_drawdown
0  2020-02-01至2020-03-31 -0.012710     -0.113575
1  2022-01-01至2022-03-31 -0.278241     -0.302678

5.4 策略对比与选择标准

通过对比不同策略的性能,选择最优策略。

5.4.1 策略对比

def compare_strategies(portfolios: list, strategy_names: list) -> pd.DataFrame:"""对比多个策略。:param portfolios: 包含多个策略的回测结果列表:param strategy_names: 策略名称列表:return: 对比结果"""# 计算每个策略的关键指标metrics = {"总回报率": [], "夏普比率": [], "最大回撤": [], "胜率": []}for portfolio in portfolios:metrics["总回报率"].append(portfolio.total_return())metrics["夏普比率"].append(portfolio.sharpe_ratio())metrics["最大回撤"].append(portfolio.max_drawdown())metrics["胜率"].append(portfolio.trades.win_rate())# 创建对比表格comparison_df = pd.DataFrame(metrics, index=strategy_names)return comparison_df# 示例:对比策略
data1 = generate_signals(data)
strategy1 = run_backtest(data1)data2 = generate_multi_factor_signals(data)
strategy2 = run_multi_factor_strategy(data2)comparison_df = compare_strategies([strategy1, strategy2], ["Strategy 1", "Strategy 2"])
print(comparison_df)

输出:

            总回报率      夏普比率      最大回撤     胜率
Strategy 1  0.175969    0.325138     -0.396185  0.250
Strategy 2  0.316914    0.417877     -0.467244  0.375

5.4.2 选择标准

def select_best_strategy(comparison_df: pd.DataFrame, weights: dict) -> str:"""选择最优策略。:param comparison_df: 策略对比结果:param weights: 各指标权重:return: 最优策略名称"""# 计算加权得分comparison_df["score"] = (comparison_df["总回报率"] * weights["return"]+ comparison_df["夏普比率"] * weights["sharpe"]+ (1 - comparison_df["最大回撤"]) * weights["drawdown"]+ comparison_df["胜率"] * weights["win_rate"])# 找到得分最高的策略best_strategy = comparison_df["score"].idxmax()return best_strategy# 示例:选择最优策略
weights = {"return": 0.3, "sharpe": 0.3, "drawdown": 0.2, "win_rate": 0.2}
best_strategy = select_best_strategy(comparison_df, weights)
print(f"最优策略: {best_strategy}")

输出:

最优策略: Strategy 2

总结

通过本章,你已经掌握了以下内容:

  1. 性能评估框架:如何计算关键性能指标并生成性能报告。
  2. 统计指标:如何评估策略的统计表现。
  3. 敏感性分析与压力测试:如何验证策略的鲁棒性。
  4. 策略对比与选择:如何对比多个策略并选择最优策略。

风险提示与免责声明
本文内容基于公开信息研究整理,不构成任何形式的投资建议。历史表现不应作为未来收益保证,市场存在不可预见的波动风险。投资者需结合自身财务状况及风险承受能力独立决策,并自行承担交易结果。作者及发布方不对任何依据本文操作导致的损失承担法律责任。市场有风险,投资须谨慎。

相关文章:

VectorBT量化入门系列:第五章 VectorBT性能评估与分析

VectorBT量化入门系列:第五章 VectorBT性能评估与分析 本教程专为中高级开发者设计,系统讲解VectorBT技术在量化交易中的应用。通过结合Tushare数据源和TA-Lib技术指标,深度探索策略开发、回测优化与风险评估的核心方法。从数据获取到策略部署…...

新能源商用车能耗终极优化指南:悬架、制动、电驱桥全链路硬核拆解(附仿真代码)

引言:新能源商用车的“续航战争”与工程师的破局点 1.1 行业现状:政策红利与技术瓶颈的博弈 数据冲击: 2023年中国新能源商用车销量突破50万辆,但平均续航仅为燃油车的55%(数据来源:中汽协)。…...

Maven笔记

Maven作用 依赖管理、版本控制标准化项目结构、自动化构建项目生命周期管理细分项目模块自动化构建、通过插件拓展构建过程 Maven下载及配置 https://blog.csdn.net/qq_29689343/article/details/135566775 使用IDEA 构建Maven工程 https://blog.csdn.net/qq_29689343/art…...

Java——接口扩展

JDK8开始接口中新增的方法 JDK7以前:接口中只能定义抽象方法。 JDK8的新特性:接口中可以定义有方法体的方法。(默认、静态) JDK9的新特性:接口中可以定义私有方法。 默认方法 需要使用关键字default修饰 作用: 解决接口升级的问题 接口中默认方法的定义格式: 格式: public d…...

COD任务论文--MAMIFNet

摘要 提示:论文机翻 由于难以从复杂背景中区分高度相似的目标,伪装物体检测(COD)仍然是计算机视觉领域的一项具有挑战性的任务。现有的伪装物体检测方法往往在场景理解和信息利用方面存在困难,导致精度不足&#xff0c…...

基于MCP协议调用的大模型agent开发04

目录 MCP客户端Client开发流程 uv工具 uv安装流程 uv的基本用法介绍 MCP极简客户端搭建流程 MCP客户端接入OpenAI、DeepSeek在线模型流程 参考来源及学习推荐: Anthropic MCP发布通告:https://www.anthropic.com/news/model-context-protocol MC…...

ComfyUI_Echomimic部署问题集合

本博客总结自己在从WebUI转到ComfyUI的过程配置Echomimic遇到的一些问题和解决方法。 默认大家已经成功安装ComfyUI,我之前装的是ComfyU桌面版,现在用的是B站秋葉大佬的整合包。但内核都一样,错误也是通用的。遇到问题时,应该先去…...

音频转文本:如何识别音频成文字

Python脚本:MP4转MP3并语音识别为中文 以下是一个完整的Python脚本,可以将MP4视频转换为MP3音频,然后使用语音识别模型将音频转换为中文文本。 准备工作 首先需要安装必要的库: pip install moviepy pydub SpeechRecognition openai-whisper完整脚本 import os from m…...

脑科学与人工智能的交叉:未来智能科技的前沿与机遇

引言 随着科技的迅猛发展,脑科学与人工智能(AI)这两个看似独立的领域正在发生深刻的交汇。脑机接口、神经网络模型、智能机器人等前沿技术,正带来一场跨学科的革命。这种结合不仅推动了科技进步,也在医疗、教育、娱乐等…...

Linux | I.MX6ULL外设功能验证(11)

01 CSI 摄像头测试 I.MX6ULL 终结者开发板引出了一路 CSI 的摄像头接口,支持【007】的 OV5640 摄像头模块。首先我们连接OV5640 摄像头模块到开发板上,如下图所示(大家在连接的时候一定要注意方向,摄像头朝向开发板的内侧,千万不要接反):...

AI助手:Claude

一、简介 Claude 是由 Anthropic 公司开发的一款人工智能助手,类似于 OpenAI 的 ChatGPT。它以 Anthropic 提出的“宪法式 AI(Constitutional AI)”为核心设计理念,强调安全性、透明性和可控性。以下是对 Claude 的一个简要介绍&…...

vue项目proxy代理的方式

以下是一个详细的 Vue 项目配置 Proxy 代理 的示例和说明,用于解决开发环境跨域问题: 1. 基础代理配置 vue.config.js 配置文件 // vue.config.js module.exports {devServer: {proxy: {// 代理所有以 /api 开头的请求/api: {target: http://localhos…...

多项目并行时如何避免资源冲突

多项目并行时避免资源冲突需做到:精确的资源规划与调度、建立统一的资源管理体系、设置清晰的优先级策略、实时监控资源使用状况、优化团队沟通与协调。其中,精确的资源规划与调度尤其重要,它决定了项目资源能否高效利用,防止资源…...

求x的c(n,m)次方

近期看到一类很有趣的题啊,其最基础的表现形式为求 mod P的值。 所以我们来拿一道小例题讲讲。 题面:给定 x,n,m,求: mod 1000003471的值。 首先我们注意到,题目给定的模数1000003471为质数,根据费马…...

VS Code 的 .S 汇编文件里面的注释不显示绿色

1. 确认文件语言模式 打开 .S 文件后,查看 VS Code 右下角的状态栏,确认当前文件的识别模式(如 Assembly、Plain Text 等)。如果显示为 Plain Text 或其他非汇编模式: 点击状态栏中的语言模式(如 Plain Te…...

Apipost自定义函数深度实战:灵活处理参数值秘籍

在开发过程中,为了更好地处理传递给接口的参数值,解决在调试过程中的数据处理问题,我们经常需要用到函数处理数据。 过去,我们通过预执行脚本来处理数据,先添加脚本,然后将处理后的结果再赋值给请求参数。…...

ADI的BF561双核DSP怎么做开发,我来说一说(十)驱动直流电机和步进电机

作者的话 ADI的双核DSP,最早的一颗是Blackfin系列的BF561,这颗DSP我用了很久,比较熟悉,且写过一些给新手的教程。 硬件准备 ADZS-BF561-EZKIT开发板:ADI原厂评估板 AD-ICE20000仿真器:ADI现阶段性能最好…...

JS包装类型Object

包装类型 1 对象 Object 声明普通对象 学习静态方法,只能由Object自己调用 1.获得所有属性 2.获得所有属性值 3.对象拷贝...

【C++初阶】--- vector容器功能模拟实现

1.什么是vector? 在 C 里,std::vector 是标准模板库(STL)提供的一个非常实用的容器类,它可以看作是动态数组 2.成员变量 iterator _start;:指向 vector 中第一个元素的指针。 iterator _finish;&#x…...

FreeRTOS项目工程完善指南:STM32F103C8T6系列

FreeRTOS项目工程完善指南:STM32系列 本文是FreeRTOS STM32开发系列教程的一部分。我们将完善之前移植的FreeRTOS工程,添加串口功能并优化配置文件。 更多优质资源,请访问我的GitHub仓库:https://github.com/Despacito0o/FreeRTO…...

多值字典表设计:优雅处理一对多关系的数据库方案

在数据库设计中,我们经常需要处理一对多的关系数据。传统做法是创建关联表,但有时这种方式会显得过于复杂。今天,我将分享一种简单而实用的多值字典表设计方案,它适用于那些不需要对单个值进行复杂操作的场景。 为什么需要多值字典表? 在许多应用场景中,我们需要存储一…...

如何在Linux系统Docker部署Dashy并远程访问内网服务界面

## 简介 Dashy 是一个开源的自托管的导航页配置服务,具有易于使用的可视化编辑器、状态检查、小工具和主题等功能。你可以将自己常用的一些网站聚合起来放在一起,形成自己的导航页。一款功能超强大,颜值爆表的可定制专属导航页工…...

GRBL运动控制算法(五)脉冲生成Bresenham算法

前言 在数控系统和运动控制领域,脉冲信号的精确生成是实现高精度位置控制的核心。GRBL作为一款高效、开源的嵌入式运动控制固件,其底层脉冲生成机制直接决定了步进电机的运动平滑性、响应速度及整体性能。而这一机制的核心,正是经典的Bresen…...

Java学习手册:Java发展历史与版本特性

Java作为全球最流行的编程语言之一,其发展历程不仅见证了技术的演进,也反映了软件开发模式的变革。从1995年的首次发布到如今的持续更新,Java始终保持着强大的生命力和广泛的影响力。本文将简要回顾Java的发展历程,并重点介绍其关…...

25年时代电服社招入职Verify测评SHL题库语言理解数字推理考什么?

宁德时代语言理解 语言理解部分主要考察应聘者的语言表达和逻辑思维能力,题型包括阅读理解、逻辑填空和语句排序。阅读理解要求应聘者快速捕捉文章的主旨和细节信息,能够迅速把握文章的核心观点;逻辑填空需要在给定的语句中填入最合适的词汇…...

【C++】右值引用、移动语义与完美转发

左值、右值是C常见的概念,那么什么是右值引用,移动语义,完美转发呢?本UP带大家了解一下C校招常问的C11新特性。 左值与右值 左值:明确存储未知、可以取地址的表达式 右值:临时的、即将被销毁的&#xff…...

AIGC3——AIGC的行业应用与生产力变革:医疗、教育、影视与工业设计的突破

引言 人工智能生成内容(AIGC)技术正在深刻改变多个行业的生产方式,从医疗诊断到影视创作,从个性化教育到工业设计,其应用不仅提升了效率,还创造了全新的工作模式。本文将聚焦医疗、教育、影视、工业设计四…...

Java从入门到“放弃”(精通)之旅——启航①

🌟Java从入门到“放弃 ”精通之旅🚀 今天我将要带大家一起探索神奇的Java世界!希望能帮助到同样初学Java的你~ (๑•̀ㅂ•́)و✧ 🔥 Java是什么?为什么这么火? Java不仅仅是一门编程语言,更…...

Web前端之Vue+Element实现表格动态不同列合并多行、localeCompare、forEach、table、push、sort、Map

MENU 效果图公共数据数据未排序时&#xff08;需要合并的行数据未处于相邻位置&#xff09;固定合并行&#xff08;写死&#xff09;动态合并行方法&#xff08;函数&#xff09;执行 效果图 公共数据 Html <el-table :data"tableData" :span-method"chang…...

JavaScript(JS进阶)

目录 00闭包 01函数进阶 02解构赋值 03通过forEach方法遍历数组 04深入对象 05内置构造函数 06原型 00闭包 <!-- 闭包 --><html><body><script>// 定义&#xff1a;闭包内层函数&#xff08;匿名函数&#xff09;外层函数的变量&#xff08;s&…...

学习51单片机Day02---实验:点亮一个LED灯

目录 1.先看原理图 2.思考一下&#xff08;sbit的使用&#xff09;&#xff1a; 3.给0是要让这个LED亮&#xff08;LED端口设置为低电平&#xff09; 4.完成的代码 1.先看原理图 比如我们要让LED3亮起来&#xff0c;对应的是P2^2。 2.思考一下&#xff08;sbit的使用&…...

线性回归模型--California房价预测

#利用线性回归模型california房价预测 #调用API from sklearn.datasets import fetch_california_housing from sklearn.model_selection import train_test_split from sklearn.preprocessing import StandardScaler from sklearn.linear_model import LinearRegression,SGDRe…...

c++进阶之----异常

1. 异常处理的基本概念 异常处理是 C 中一种用于处理运行时错误的机制&#xff0c;允许程序在遇到错误时优雅地处理问题&#xff0c;而不是直接崩溃。异常处理的核心是通过 try、catch 和 throw 关键字来实现&#xff0c;它允许程序在遇到错误时优雅地处理问题&#xff0c;而不…...

SmolDocling:一种超紧凑的视觉语言模型,用于端到端多模态文档转换

paper地址:SmolDocling: An ultra-compact vision-language model for end-to-end multi-modal document conversion Huggingface地址:SmolDocling-256M-preview 代码对应的权重文件:SmolDocling-256M-preview权重文件 一、摘要 以下是文章摘要的总结: SmolDocling 是一…...

多模态大模型在目标检测领域的最新进展

1. 技术融合创新 多模态数据融合&#xff1a; 传感器融合&#xff1a;整合图像、激光雷达&#xff08;LiDAR&#xff09;、毫米波雷达等数据&#xff0c;提升检测精度和鲁棒性。例如&#xff0c;在自动驾驶中&#xff0c;通过融合视觉与LiDAR数据&#xff0c;实现三维目标检测…...

KWDB创作者计划—KWDB技术重构:重新定义数据与知识的神经符号革命

引言&#xff1a;数据洪流中的范式危机 在AI算力突破千卡集群、大模型参数量级迈向万亿的时代&#xff0c;传统数据库系统正面临前所未有的范式危机。当GPT-4展现出跨领域推理能力&#xff0c;AlphaFold3突破蛋白质预测精度时&#xff0c;数据存储系统却仍在沿用基于关系代数的…...

我开源了一个“宝藏”开源项目

我开源了一个“宝藏”开源项目 - AI需求分析项目 | 适合交作业和学习 &#x1f680; 前言 大家好&#xff01;最近在学习软件工程和大模型应用开发的过程中&#xff0c;我发现许多学生都遇到了需求分析AI的题目。把一份需求文档转化为用户故事、实体关系或数据库设计&#xff…...

从零实现Agent智能体配置使用(Ragflow)

从零实现Agent智能体配置使用&#xff08;Ragflow&#xff09; 1. 创建智能体2. 配置智能体2.1 配置问题识别2.2 配置问题分类2.3 不同问题进行单独配置2.4 保存Agent 3. 体验效果 1. 创建智能体 2. 配置智能体 2.1 配置问题识别 2.2 配置问题分类 2.3 不同问题进行单独配置 当…...

Fluent VOF水下固体火箭发射仿真

本案例利用VOF模型对水下固体火箭&#xff08;10m水深&#xff09;发动机点火初期的流场进行了仿真。该案例所用模型为假设模型&#xff0c;且缺少相关燃气参数&#xff0c;仅作计算设置参考。通过此案例后续跨可以对不同水深、不同模型的工况展开类似仿真计算。 1 假设说明 …...

电脑死机/锁屏后死机无法唤醒

电脑死机/锁屏后死机无法唤醒 导航 文章目录 电脑死机/锁屏后死机无法唤醒导航一、系统日志分析二、电源管理与睡眠模式问题1、禁用快速启动2、调整电源计划&#xff08;开启高性能模式&关闭硬盘休眠&#xff09;若是没有禁用睡眠和关闭显示器方法一&#xff1a;方法二&am…...

爱普生可编程晶振SG8201CJ和SG8200CJ在胃镜机器人发挥重要作用

在医疗机器人技术高速发展的今天&#xff0c;胃镜机器人作为胃肠道疾病诊断与治疗的创新设备&#xff0c;正逐渐改变传统诊疗模式。其复杂精密的系统需要精准的时间同步与稳定的信号输出&#xff0c;胃镜机器人是一种先进的医疗设备&#xff0c;用于无创性地检查胃部疾病。与传…...

按规则批量修改文件名称,支持替换或删除文件名称中的内容

文件重命名的需求在我们工作中是非常常见的一个需求&#xff0c;也非常的重要的一个需求&#xff0c;我相信很多小伙伴在工作中都会碰到需要进行文件重命名的场景。今天就给大家介绍一个文件重命名的方法&#xff0c;支持多种方式批量修改文件名称。功能非常的强大&#xff0c;…...

scrum详细理解

Scrum与传统瀑布模型区别 瀑布模型&#xff1a;需要花费几个月来规划产品----->在花费几个月时间进行研发----->产品测试、评审----->最终发布产品 缺点&#xff1a;①如果市场需求发生变化&#xff0c;研发的产品可能无法满足市场需求 ②产品规划必须早于后续工作之…...

数据结构(五)——AVL树(平衡二叉搜索树)

目录 前言 AVL树概念 AVL树的定义 AVL树的插入 右旋转 左旋转 左右双旋 右左双旋 插入代码如下所示 AVL树的查找 AVL树的遍历 AVL树的节点个数以及高度 判断平衡 AVL树代码如下所示 小结 前言 前面我们在数据结构中介绍了二叉搜索树&#xff0c;其中提到了二叉搜…...

Linux文件传输:让数据飞起来!

一、前置任务 为了便于实验&#xff0c;我用母盘的虚拟机克隆出两台虚拟机来模拟两台主机进行文件传输 查询两台主机的IP BL1 192.168.163.130/24 BL2 192.168.88.129/24 二、文件传输 scp命令 不填选项正常显示进度的传输-q静默传输-r递归传输&#xff08;用于传输目录及目…...

repo仓库文件清理

1. repo 仓库内文件清理 # 清理所有Git仓库中的项目 repo forall -c git clean -dfx # 重置所有Git 仓库中的项目 repo forall -c git reset --hard 解释&#xff1a; repo forall -c git clean -dfx&#xff1a; repo forall 是一个用于在所有项目中执行命令的工具。-c 后…...

MyBatis-Plus 的 FieldStrategy 属性

前几天做个需求的时候&#xff0c;有几个字段在更新的时候&#xff0c;可能为空。想着MyBatis-Plus有注解可以直接使用&#xff0c;就找寻了一下。此处记录一下。我用的MyBatis-Plus的版本是 3.5.1。版本之间对于 TableField 中的方法定义有些区别&#xff0c;但大体相差不大。…...

解锁塔能科技,开启工厂绿色转型与可持续发展双引擎

在全球积极推进可持续发展的大背景下&#xff0c;能源的高效利用与节能减排&#xff0c;已成为各行各业迈向高质量发展进程中无法回避的核心任务。工厂作为能源消耗大户与污染排放重点源头&#xff0c;其绿色转型迫在眉睫&#xff0c;这不仅关乎企业自身的长远发展&#xff0c;…...

c++进阶--智能指针

大家好&#xff0c;今天我们来学习一下c中的智能指针部分。 智能指针的使⽤及其原理 1. 智能指针的使⽤场景分析 下⾯程序中我们可以看到&#xff0c;new了以后&#xff0c;我们也delete了&#xff0c;但是因为抛异常导&#xff0c;后⾯的delete没有得到执⾏&#xff0c;所以…...

五种常用的web加密算法

文章目录 五种常用Web加密算法实战及原理详解1. AES (高级加密标准)原理详解应用场景实战代码&#xff08;Node.js&#xff09; 2. RSA (非对称加密)原理详解应用场景实战代码&#xff08;Node.js&#xff09; 3. SHA-256 (安全哈希算法)原理详解应用场景实战代码&#xff08;浏…...