最新资讯

  • 将NineData第三届数据库编程大赛冠军郑凌云的数独求解SQL改写为DuckDB

将NineData第三届数据库编程大赛冠军郑凌云的数独求解SQL改写为DuckDB

2026-01-31 11:00:30 栏目:最新资讯 2 阅读

官方公众号终于公布了前三名的解题思路和程序源代码,其中郑凌云的文章地址是:https://mp.weixin.qq.com/s/2Aoz3CiDqkNEYkvXCa4NoA

这个SQL在postgresql上毫无疑问地比二、三名还快。我好奇它在DuckDB上性能如何,毕竟前面的改写都是变慢了。

主要修改部分

  1. 数组||元素改为数组||[元素]
  2. 将convert_to函数去掉
  3. 将set_byte函数改为字符串拼接,注意前者索引从0开始到length-1,后者索引从1开始到length。
  4. LEFT JOIN LATERAL (右表) ON 左表条件,改为LEFT JOIN LATERAL (右表 where 左表条件) ON True,消除Binder Error:Join condition for non-inner LATERAL JOIN must be a comparison between the left and right side
  5. FROM generate_subscripts(todo, 1) i改为FROM (select generate_subscripts(todo, 1) i)t(i)
  6. 将#运算符改为xor函数。
  7. 将16进制数字0x??改为10进制。
  8. 用//运算符代替/做整除。
  9. 用length函数代替cardinality

完整修改结果如下

WITH RECURSIVE
bs_t AS MATERIALIZED (
SELECT id, replace(puzzle, E'
', '') AS bs
FROM sudoku9_9
)
--from bs_t limit 1;
,
init_t AS (
SELECT id, row_can, col_can, box_can, todo, bs AS done
FROM bs_t
CROSS JOIN LATERAL (
WITH board_t AS (
SELECT
array_agg(mask ORDER BY i) AS bd,
COALESCE(array_agg(((i // 9 + 1) << 8) | ((i % 9 + 1) << 4) | (i // 27 * 3 + i % 9 // 3 + 1))
FILTER (WHERE mask = 0), ARRAY[]::int[]) AS todo
FROM (
SELECT i, (1 << (ascii(substr(bs, i+1, 1)) - 49)) & 511 mask
FROM generate_series(0, 80) g(i)
			) AS bd_t
		)
SELECT
ARRAY[
xor(511, (bd[1]  | bd[2]  | bd[3]  | bd[4]  | bd[5]  | bd[6]  | bd[7]  | bd[8]  | bd[9])),
xor(511, (bd[10] | bd[11] | bd[12] | bd[13] | bd[14] | bd[15] | bd[16] | bd[17] | bd[18])),
xor(511, (bd[19] | bd[20] | bd[21] | bd[22] | bd[23] | bd[24] | bd[25] | bd[26] | bd[27])),
xor(511, (bd[28] | bd[29] | bd[30] | bd[31] | bd[32] | bd[33] | bd[34] | bd[35] | bd[36])),
xor(511, (bd[37] | bd[38] | bd[39] | bd[40] | bd[41] | bd[42] | bd[43] | bd[44] | bd[45])),
xor(511, (bd[46] | bd[47] | bd[48] | bd[49] | bd[50] | bd[51] | bd[52] | bd[53] | bd[54])),
xor(511, (bd[55] | bd[56] | bd[57] | bd[58] | bd[59] | bd[60] | bd[61] | bd[62] | bd[63])),
xor(511, (bd[64] | bd[65] | bd[66] | bd[67] | bd[68] | bd[69] | bd[70] | bd[71] | bd[72])),
xor(511, (bd[73] | bd[74] | bd[75] | bd[76] | bd[77] | bd[78] | bd[79] | bd[80] | bd[81]))
			]::int[] AS row_can,

ARRAY[
xor(511, (bd[1]  | bd[10] | bd[19] | bd[28] | bd[37] | bd[46] | bd[55] | bd[64] | bd[73])),
xor(511, (bd[2]  | bd[11] | bd[20] | bd[29] | bd[38] | bd[47] | bd[56] | bd[65] | bd[74])),
xor(511, (bd[3]  | bd[12] | bd[21] | bd[30] | bd[39] | bd[48] | bd[57] | bd[66] | bd[75])),
xor(511, (bd[4]  | bd[13] | bd[22] | bd[31] | bd[40] | bd[49] | bd[58] | bd[67] | bd[76])),
xor(511, (bd[5]  | bd[14] | bd[23] | bd[32] | bd[41] | bd[50] | bd[59] | bd[68] | bd[77])),
xor(511, (bd[6]  | bd[15] | bd[24] | bd[33] | bd[42] | bd[51] | bd[60] | bd[69] | bd[78])),
xor(511, (bd[7]  | bd[16] | bd[25] | bd[34] | bd[43] | bd[52] | bd[61] | bd[70] | bd[79])),
xor(511, (bd[8]  | bd[17] | bd[26] | bd[35] | bd[44] | bd[53] | bd[62] | bd[71] | bd[80])),
xor(511, (bd[9]  | bd[18] | bd[27] | bd[36] | bd[45] | bd[54] | bd[63] | bd[72] | bd[81]))
			]::int[] AS col_can,

ARRAY[
xor(511, (bd[1]  | bd[2]  | bd[3]  | bd[10] | bd[11] | bd[12] | bd[19] | bd[20] | bd[21])),
xor(511, (bd[4]  | bd[5]  | bd[6]  | bd[13] | bd[14] | bd[15] | bd[22] | bd[23] | bd[24])),
xor(511, (bd[7]  | bd[8]  | bd[9]  | bd[16] | bd[17] | bd[18] | bd[25] | bd[26] | bd[27])),
xor(511, (bd[28] | bd[29] | bd[30] | bd[37] | bd[38] | bd[39] | bd[46] | bd[47] | bd[48])),
xor(511, (bd[31] | bd[32] | bd[33] | bd[40] | bd[41] | bd[42] | bd[49] | bd[50] | bd[51])),
xor(511, (bd[34] | bd[35] | bd[36] | bd[43] | bd[44] | bd[45] | bd[52] | bd[53] | bd[54])),
xor(511, (bd[55] | bd[56] | bd[57] | bd[64] | bd[65] | bd[66] | bd[73] | bd[74] | bd[75])),
xor(511, (bd[58] | bd[59] | bd[60] | bd[67] | bd[68] | bd[69] | bd[76] | bd[77] | bd[78])),
xor(511, (bd[61] | bd[62] | bd[63] | bd[70] | bd[71] | bd[72] | bd[79] | bd[80] | bd[81]))
			]::int[] AS box_can,

			todo
FROM board_t
	) AS rcb_t
)
--from init_t;
,

infer_t AS (
SELECT id, row_can, col_can, box_can, todo, done, TRUE AS expand
FROM init_t

UNION ALL

SELECT
		id,
CASE
WHEN expand_ IS NOT NULL
THEN row_can[:r - 1] ||[ xor(row_can[r] , candidates)] || row_can[r + 1:]
ELSE row_can
END,
CASE
WHEN expand_ IS NOT NULL
THEN col_can[:c - 1] ||[ xor(col_can[c] , candidates)] || col_can[c + 1:]
ELSE col_can
END,
CASE
WHEN expand_ IS NOT NULL
THEN box_can[:b - 1] ||[ xor(box_can[b] , candidates)] || box_can[b + 1:]
ELSE box_can
END,
CASE
WHEN expand_ IS NOT NULL
THEN todo[:i - 1] || todo[i + 1:]
ELSE todo
END,
CASE
WHEN expand_ IS NOT NULL
--THEN set_byte(done, (r << 3) + r + c - 10, bit_count((candidates - 1))::int + 49)
THEN substr(done,1, (r << 3) + r + c - 10)|| chr( bit_count((candidates - 1))::int + 49)||substr(done, (r << 3) + r + c - 8)
ELSE done
END,
		expand_
FROM infer_t
LEFT JOIN LATERAL (
SELECT i, r, c, b, candidates, TRUE AS expand_
FROM (select generate_subscripts(todo, 1) i)t(i)
CROSS JOIN LATERAL (
SELECT todo[i] >> 8 AS r, (todo[i] >> 4) & 15 AS c, todo[i] & 15 AS b
		) AS infer_rcb_t
CROSS JOIN LATERAL (
SELECT row_can[r] & col_can[c] & box_can[b] AS candidates
		) AS infer_can_t
WHERE bit_count(candidates) = 1
		LIMIT 1
	) AS infer_next_t ON TRUE
WHERE expand IS NOT NULL
),
infer_rst_t AS (
SELECT id, row_can, col_can, box_can, todo, done
FROM infer_t
WHERE expand IS NULL
)
--SELECT count(*) FROM infer_rst_t WHERE length(todo) = 0 ;

,

search_t AS (
SELECT
		id,
0 AS deep,
FALSE AS back,
0 AS back_can,
		row_can,
		col_can,
		box_can,
		todo,
		done,
ARRAY[]::int[][] stack,
CASE WHEN length(todo) = 0 THEN TRUE ELSE NULL::boolean END AS status
FROM infer_rst_t

UNION ALL

SELECT
		id,
		deep + 1,
CASE WHEN candidate != 0 THEN FALSE ELSE TRUE END,
		s_cand,

CASE
WHEN candidate != 0
THEN row_can[:r - 1] || [xor(row_can[r] , candidate)] || row_can[r + 1:]
ELSE
				row_can[:s_r - 1] ||[xor(row_can[s_r] , (s_cand & -s_cand))] ||row_can[s_r + 1:]
END,

CASE
WHEN candidate != 0
THEN col_can[:c - 1] || [xor(col_can[c] , candidate)] || col_can[c + 1:]
ELSE
				col_can[:s_c - 1] ||[xor(col_can[s_c] , (s_cand & -s_cand))] ||col_can[s_c + 1:]
END,

CASE
WHEN candidate != 0
THEN box_can[:b - 1] || [xor(box_can[b] , candidate)] || box_can[b + 1:]
ELSE
				box_can[:s_b - 1] ||[xor(box_can[s_b] , (s_cand & -s_cand))] ||box_can[s_b + 1:]
END,

CASE
WHEN candidate != 0
THEN todo[:i - 1] || todo[i + 1:]
ELSE [stack[sp][1]] || todo
END,

CASE
WHEN candidate != 0
--THEN set_byte(done, (r << 3) + r + c - 10, bit_count((candidate - 1))::int + 49)
THEN substr(done,1, (r << 3) + r + c - 10)|| chr( bit_count((candidate - 1))::int + 49)||substr(done, (r << 3) + r + c - 8)
ELSE done
END,

CASE
WHEN candidate != 0
THEN stack || ARRAY[ARRAY[(r << 8) | (c << 4) | b, candidates]]
ELSE stack[:sp - 1]
END,

CASE
WHEN candidate != 0
THEN CASE WHEN length(todo) <= 1 THEN TRUE ELSE NULL END
WHEN length(stack) = 0 THEN FALSE
-- 示例题库中最大检索深度只用459就够了,这里设定超65000才放弃
-- 应该完全足够解出所有题目了,正确率比速度更重要,慢就慢点
WHEN deep >= 6000 THEN FALSE
ELSE NULL
END

FROM search_t
LEFT  JOIN LATERAL (
		(
-- 先找1比sort limit 1更快
SELECT i AS i_, r_, c_, b_, candidates_
FROM (select generate_subscripts(todo, 1) i)t(i)
CROSS JOIN LATERAL (
SELECT todo[i] >> 8 AS r_, (todo[i] >> 4) & 15 AS c_, todo[i] & 15 AS b_
			) AS search1_rcb_t
CROSS JOIN LATERAL (
SELECT row_can[r_] & col_can[c_] & box_can[b_] AS candidates_
			) AS search1_can_t
WHERE bit_count(candidates_) = 1
			LIMIT 1
		)
UNION ALL
		(
WITH mrv_t AS (
SELECT i AS i_, r_, c_, b_, candidates_, bit_count(candidates_) AS cnt
FROM (select generate_subscripts(todo, 1) i)t(i)
CROSS JOIN LATERAL (
SELECT todo[i] >> 8 AS r_, (todo[i] >> 4) & 15 AS c_, todo[i] & 15 AS b_
				) AS search2_rcb_t
CROSS JOIN LATERAL (
SELECT row_can[r_] & col_can[c_] & box_can[b_] AS candidates_
				) AS search2_can_t
			),
-- 找min值比sort limit 1更快
			mrv_min_t AS (
SELECT min(cnt) AS cnt FROM mrv_t
			)
SELECT i_, r_, c_, b_, candidates_
FROM mrv_t
JOIN mrv_min_t
ON mrv_t.cnt = mrv_min_t.cnt
where back = FALSE			LIMIT 1
		)
		LIMIT 1
	) AS forward_t on true --ON back = FALSE
LEFT JOIN LATERAL (
SELECT
1 AS i_,
todo[1] >> 8 AS r_,
(todo[1] >> 4) & 15 AS c_,
todo[1] & 15 AS b_,
back_can & (back_can - 1) AS candidates_
where back = TRUE 
	) AS backward_t on true
CROSS JOIN LATERAL (
SELECT
COALESCE(backward_t.i_, forward_t.i_) AS i,
COALESCE(backward_t.r_, forward_t.r_) AS r,
COALESCE(backward_t.c_, forward_t.c_) AS c,
COALESCE(backward_t.b_, forward_t.b_) AS b,
COALESCE(backward_t.candidates_, forward_t.candidates_) AS candidates,
			(COALESCE(backward_t.candidates_, forward_t.candidates_) &
-COALESCE(backward_t.candidates_, forward_t.candidates_)) AS candidate,
-- 这俩可能为NULL,为NULL时会判定为不可解,所以即使生成了一些NULL中间数据,会丢弃掉。我已确认不影响程序正确性
			array_length(stack, 1) AS sp,
			stack[array_length(stack, 1)][2] AS s_cand
	) AS final_t
LEFT  JOIN LATERAL (
SELECT
stack[sp][1] >> 8 AS s_r,
(stack[sp][1] >> 4) & 15 AS s_c,
stack[sp][1] & 15 s_b
where candidate = 0 
	) AS extra_t on true --ON candidate = 0 
WHERE status IS NULL
)
--select * from search_t ;

SELECT
	t.id AS id,
	puzzle,
	
		substr(done, 1,  9) || E'
' ||
		substr(done, 10, 9) || E'
' ||
		substr(done, 19, 9) || E'
' ||
		substr(done, 28, 9) || E'
' ||
		substr(done, 37, 9) || E'
' ||
		substr(done, 46, 9) || E'
' ||
		substr(done, 55, 9) || E'
' ||
		substr(done, 64, 9) || E'
' ||
		substr(done, 73, 9)
	 AS result
FROM sudoku9_9 t
LEFT JOIN search_rst_t USING(id)
;

中间有两个插曲。
1.由于马虎图省事复制粘贴,把本来是容易的事,变成一个排查不出的错误,算出的结果有一部分对,一部分错。问了郑凌云本人才知道,我把candidate错写成candidates, 这是不同的两个变量,前一个用于搜索,后一个用于推理。
2.由于SQL基本功不扎实,以为可以用CROSS JOIN LATERAL代替LEFT JOIN LATERAL, 结果也是一部分能算出来,还以为找到了优化点,结果是改错了。原理见文章。

最后测试性能,1000行数据,单线程要3秒,多线程要18秒,比postgresql中执行时间长了几十倍,和前面改写后程宁的SQL结果一个数量级,究竟是哪部分引起的,是JOIN LATERAL还是递归,还需要进一步研究。

本文地址:https://www.yitenyun.com/4014.html

搜索文章

Tags

#远程工作 #服务器 #python #pip #conda #ios面试 #ios弱网 #断点续传 #ios开发 #objective-c #ios #ios缓存 香港站群服务器 多IP服务器 香港站群 站群服务器 #kubernetes #笔记 #平面 #容器 #linux #学习方法 #运维 #Trae #IDE #AI 原生集成开发环境 #Trae AI #学习 #物联网 #websocket #进程控制 #开发语言 #云原生 #iventoy #VmWare #OpenEuler #docker #后端 #数据库 #内网穿透 #网络 #cpolar #人工智能 #node.js #fastapi #html #css #MobaXterm #ubuntu #数信院生信服务器 #Rstudio #生信入门 #生信云服务器 #低代码 #爬虫 #音视频 #Conda # 私有索引 # 包管理 #算法 #大数据 #unity #c# #游戏引擎 #vscode #mobaxterm #深度学习 #计算机视觉 #github #git #缓存 #vllm #大模型 #Streamlit #Qwen #本地部署 #AI聊天机器人 #开源 #golang #java #redis #RTP over RTSP #RTP over TCP #RTSP服务器 #RTP #TCP发送RTP #web安全 #安全 #kylin #分阶段策略 #模型协议 #nginx #tcp/ip #jvm #我的世界 #hadoop #hbase #hive #zookeeper #spark #kafka #flink #android #腾讯云 #需求分析 #Dell #PowerEdge620 #内存 #硬盘 #RAID5 #centos #ssh #ide #http #fiddler #银河麒麟 #系统升级 #信创 #国产化 #华为 #ModelEngine #c++ #计算机网络 #多个客户端访问 #IO多路复用 #回显服务器 #TCP相关API #AI编程 #编辑器 #gpu算力 #研发管理 #禅道 #禅道云端部署 #qt #C++ #凤希AI伴侣 #性能优化 #udp #云计算 #课程设计 #银河麒麟高级服务器操作系统安装 #银河麒麟高级服务器V11配置 #设置基础软件仓库时出错 #银河麒高级服务器系统的实操教程 #生产级部署银河麒麟服务系统教程 #Linux系统的快速上手教程 #json #电脑 #自动化 #jmeter #功能测试 #软件测试 #自动化测试 #职场和发展 #prometheus #grafana #科技 #自然语言处理 #神经网络 #FTP服务器 #ping通服务器 #读不了内网数据库 #bug菌问答团队 #架构 #asp.net #面试 #cpp #项目 #高并发 #华为云 #部署上线 #动静分离 #Nginx #新人首发 #企业开发 #ERP #项目实践 #.NET开发 #C#编程 #编程与数学 #windows #gemini #gemini国内访问 #gemini api #gemini中转搭建 #Cloudflare #screen 命令 #1024程序员节 #mysql #mvp #个人开发 #设计模式 #elasticsearch #版本控制 #Git入门 #开发工具 #代码托管 #个人博客 #DisM++ # GLM-4.6V # 系统维护 #金融 #mcp #金融投资Agent #Agent #制造 #n8n #AIGC #ida #嵌入式编译 #ccache #distcc #毕设 #RAID #RAID技术 #磁盘 #存储 #游戏 #智能路由器 #vue.js #前端 #php #django #树莓派4b安装系统 #ollama #ai #llm #oracle #SA-PEKS # 关键词猜测攻击 # 盲签名 # 限速机制 #RustDesk #IndexTTS 2.0 #本地化部署 #时序数据库 #我的世界服务器搭建 #minecraft #毕业设计 #车辆排放 #AI #大模型学习 #Spring AI #MCP服务器 #STDIO协议 #Streamable-HTTP #McpTool注解 #服务器能力 #Android #Bluedroid #Ansible #Playbook #AI服务器 #javascript #智能手机 #c语言 #stm32 #eBPF #压力测试 #todesk #openlayers #bmap #tile #server #vue #Harbor #asp.net大文件上传 #asp.net大文件上传下载 #asp.net大文件上传源码 #ASP.NET断点续传 #asp.net上传文件夹 #网络协议 #uni-app #小程序 #notepad++ #信令服务器 #Janus #MediaSoup #flutter #数码相机 #SSH #X11转发 #Miniconda #jenkins #jar #debian #改行学it #创业创新 #程序员创富 #流媒体 #NAS #飞牛NAS #监控 #NVR #EasyNVR #MC #sqlserver #claude #flask #arm开发 #cosmic #PyTorch #CUDA #Triton #SSH公钥认证 # PyTorch # 安全加固 #阿里云 #H5 #跨域 #发布上线后跨域报错 #请求接口跨域问题解决 #跨域请求代理配置 #request浏览器跨域 #spring boot #部署 #语言模型 #DeepSeek #昇腾300I DUO #JumpServer #堡垒机 #搜索引擎 #ci/cd #gitlab #microsoft #测试工具 #opencv #数据挖掘 #远程桌面 #远程控制 #游戏机 #分布式 #振镜 #振镜焊接 #teamviewer #macos #pytorch #bash #黑群晖 #虚拟机 #无U盘 #纯小白 #支付 #YOLO # Triton # 目标检测 #东方仙盟 #lua #语音识别 #API限流 # 频率限制 # 令牌桶算法 #iBMC #UltraISO #蓝湖 #Axure原型发布 #pycharm #SRS #直播 #数据结构 #llama #milvus #springboot #知识库 #单元测试 #集成测试 #嵌入式硬件 #web server #请求处理流程 #网络安全 #京东云 #react.js #uv #uvx #uv pip #npx #Ruff #pytest #rocketmq #测试用例 #selenium #守护进程 #复用 #screen #系统架构 #tensorflow #arm #单片机 #MCP #蓝耘智算 #910B #昇腾 #Clawdbot #个人助理 #数字员工 #aws #MQTT协议 #apache #tomcat #深度优先 #DFS #svn # 双因素认证 # TensorFlow #微信小程序 #源码 #闲置物品交易系统 #umeditor粘贴word #ueditor粘贴word #ueditor复制word #ueditor上传word图片 #微服务 #IPv6 #DNS #postgresql #连接数据库报错 #rustdesk #p2p #unity3d #服务器框架 #Fantasy #java-ee #transformer #prompt #YOLOFuse # Base64编码 # 多模态检测 #YOLOv8 # Docker镜像 #进程 #操作系统 #进程创建与终止 #shell #计算机 #SPA #单页应用 #web3.py #mamba #jupyter #麒麟OS #swagger #visual studio code # 高并发部署 #AI论文写作工具 #学术写作辅助 #论文创作效率提升 #AI写论文实测 #webpack #sqlite #journalctl #epoll #sql #spring #maven #intellij-idea #电气工程 #C# #PLC #ssl #openresty #wordpress #雨云 #chatgpt #vuejs #视频去字幕 #高级IO #select #libosinfo #说话人验证 #声纹识别 #CAM++ #TCP #客户端 #嵌入式 #DIY机器人工房 #ansible #Windows #windows11 #系统修复 #gitea #网站 #截图工具 #批量处理图片 #图片格式转换 #图片裁剪 #mcu #算力一体机 #ai算力服务器 #webrtc #idm #SSE # AI翻译机 # 实时翻译 #万悟 #联通元景 #智能体 #镜像 #scala #无人机 #Deepoc #具身模型 #开发板 #未来 #聊天小程序 #微信 #健身房预约系统 #健身房管理系统 #健身管理系统 #tdengine #涛思数据 #NFC #智能公交 #服务器计费 #FP-增长 #Proxmox VE #虚拟化 #VMware #鸭科夫 #逃离鸭科夫 #鸭科夫联机 #鸭科夫异地联机 #开服 #北京百思可瑞教育 #百思可瑞教育 #北京百思教育 #交互 #deepseek #NPU #CANN #risc-v #1panel #vmware #GPU服务器 #8U #硬件架构 #ui #5G #硬件 #C2000 #TI #实时控制MCU #AI服务器电源 #dify #leetcode #Llama-Factory # 树莓派 # ARM架构 #信号处理 #PowerBI #企业 #memcache #大剑师 #nodejs面试题 #Linux #VMware Workstation16 #服务器操作系统 #银河麒麟操作系统 #openssh #华为交换机 #信创终端 #硬件工程 #UDP的API使用 #处理器 #googlecloud #ShaderGraph #图形 #数据分析 #vnstat #智能体来了 #智能体对传统行业冲击 #行业转型 #AI赋能 #运维开发 #文心一言 #AI智能体 #AutoDL #攻防演练 #Java web #漏洞 #红队 #Socket网络编程 #能源 #RAG #LLM #chat #WT-2026-0001 #QVD-2026-4572 #smartermail #飞牛nas #fnos #Modbus-TCP #经验分享 #YOLO26 #目标检测 #muduo #TcpServer #accept #高并发服务器 #系统管理 #服务 #扩展屏应用开发 #android runtime #远程开发 #postman #管道Pipe #system V #微PE #硬盘克隆 #DiskGenius #媒体 #机器学习 #学术论文创作 #论文效率提升 #MBA论文写作 #交通物流 #SAP #ebs #metaerp #oracle ebs #muduo库 # 高并发 #chrome #harmonyos #ArkUI #ArkTS #鸿蒙开发 #国产化OS #政务 #手机h5网页浏览器 #安卓app #苹果ios APP #手机电脑开启摄像头并排查 #IO #vivado license #html5 #计算几何 #斜率 #方向归一化 #叉积 #go # Miniconda # 批量管理 #系统安全 #Anaconda配置云虚拟环境 #Nacos #web #C语言 #laravel #KMS #slmgr #浏览器自动化 #python #fabric #密码学 #可信计算技术 #puppeteer #openHiTLS #TLCP #DTLCP #商用密码算法 #POC #问答 #交付 #CPU #xlwings #Excel #测评 #CCE #Dify-LLM #Flexus #服务器繁忙 #spring cloud #nfs #iscsi #cursor #统信UOS #win10 #qemu #翻译 #前端框架 #负载均衡 #spine #智能家居 #文件管理 #文件服务器 #jetty #mybatis #scanf #printf #getchar #putchar #cin #cout #大语言模型 #程序员 #bootstrap #win11 #文件IO #输入输出流 #langchain #安卓 #信息与通信 #tcpdump #embedding #kmeans #聚类 #实时音视频 #业界资讯 #排序算法 #jdk #排序 #ms-swift # 大模型 # 模型训练 #ddos #vps #Java #aiohttp #asyncio #异步 #paddleocr #企业级存储 #网络设备 #数据仓库 #Host #渗透测试 #SSRF #软件 #本地生活 #电商系统 #商城 #Smokeping #pve #LangGraph #CLI #Python #JavaScript #langgraph.json #LoRA # lora-scripts # 模型微调 #zotero #WebDAV #同步失败 #代理模式 #工具集 #大模型应用 #API调用 #PyInstaller打包运行 #服务端部署 #.netcore #https #openEuler #欧拉 #分类 #麒麟 #Go并发 #高并发架构 #Goroutine #系统设计 #Dify #ARM架构 #鲲鹏 # IndexTTS 2.0 # 自动化运维 #.net #net core #kestrel #web-server #asp.net-core #海外服务器安装宝塔面板 #集成学习 #SSH保活 #serverless #EMC存储 #存储维护 #NetApp存储 #rdp #大模型部署 #mindie #大模型推理 #大模型开发 #简单数论 #埃氏筛法 #Termux #Samba #SSH反向隧道 # Jupyter远程访问 #PTP_1588 #gPTP #codex #esp32教程 #rust #mongodb #yum #fpga开发 #uvicorn #uvloop #asgi #event #pdf #三维 #3D #三维重建 #大模型教程 #AI大模型 #结构体 #rtsp #转发 #鸿蒙PC #GPU ##租显卡 #进程等待 #wait #waitpid #青少年编程 #CVE-2025-61686 #路径遍历高危漏洞 #cesium #可视化 #Android16 #音频性能实战 #音频进阶 #neo4j #NoSQL #SQL # 大模型推理 #H5网页 #网页白屏 #H5页面空白 #资源加载问题 #打包部署后网页打不开 #HBuilderX #CTF #VMWare Tool # GPU租赁 # 自建服务器 #插件 #开源软件 #r-tree #心理健康服务平台 #心理健康系统 #心理服务平台 #心理健康小程序 #web服务器 #MinIO服务器启动与配置详解 #reactjs #web3 #链表 #链表的销毁 #链表的排序 #链表倒置 #判断链表是否有环 #agent #ai大模型 #论文笔记 #arm64 #adb #DHCP #散列表 #哈希算法 #idea #intellij idea #串口服务器 #Modbus #MOXA #GATT服务器 #蓝牙低功耗 # RTX 3090 # ControlMaster #ServBay #SFTP #le audio #蓝牙 #低功耗音频 #通信 #连接 #模型上下文协议 #MultiServerMCPC #load_mcp_tools #load_mcp_prompt #AI 推理 #NV #word #ESP32 # OTA升级 # 黄山派 #ansys #ansys问题解决办法 #HeyGem # WebUI # 网络延迟 #Qwen3-14B # 大模型部署 # 私有化AI #ranger #MySQL8.0 #vp9 #MS #Materials #mariadb #elk #sql注入 #GB28181 #SIP信令 #SpringBoot #视频监控 #SSH跳板机 # Python3.11 #LVDS #高速ADC #DDR #雨云服务器 #Minecraft服务器 #教程 #MCSM面板 #驱动开发 #鸿蒙 # 服务器配置 # GPU #ue5 #screen命令 #Gunicorn #WSGI #Flask #并发模型 #容器化 #性能调优 #Emby #视频 #机器人 #azure #ambari #bond #服务器链路聚合 #网卡绑定 #门禁 #梯控 #智能一卡通 #门禁一卡通 #消费一卡通 #智能梯控 #一卡通 #源代码管理 #AI-native #超时设置 #客户端/服务器 #网络编程 #挖矿 #Linux病毒 #VS Code调试配置 #ai编程 # TTS服务器 # 键鼠锁定 #远程连接 #工程设计 #预混 #扩散 #燃烧知识 #层流 #湍流 #WinSCP 下载安装教程 #FTP工具 #服务器文件传输 #excel # CosyVoice3 # 批量部署 #数据恢复 #视频恢复 #视频修复 #RAID5恢复 #流媒体服务器恢复 #copilot #scrapy #推荐算法 #AI写作 #Gateway #认证服务器集成详解 #框架搭建 #node #状态模式 #dba #Tokio #react native #CVE-2025-68143 #CVE-2025-68144 #CVE-2025-68145 #LE Audio #BAP #powerbi #agi #RSO #机器人操作系统 #ASR #SenseVoice #星图GPU #log #glibc #中间件 #参数估计 #矩估计 #概率论 #zabbix #证书 #信息可视化 #claude code #code cli #ccusage #Node.js # child_process #winscp #ONLYOFFICE #MCP 服务器 #后端框架 #动态规划 #dlms #dlms协议 #逻辑设备 #逻辑设置间权限 # 数字人系统 # 远程部署 #scikit-learn #随机森林 #SSH免密登录 # CUDA #安全威胁分析 #仙盟创梦IDE #GLM-4.6V-Flash-WEB # AI视觉 # 本地部署 #ARM服务器 # 多模态推理 #3d #Minecraft #PaperMC #我的世界服务器 #运维工具 #网络攻击模型 #pyqt #RK3576 #瑞芯微 #硬件设计 #kong #Kong Audio #Kong Audio3 #KongAudio3 #空音3 #空音 #中国民乐 #企业微信 #ipmitool #BMC # 黑屏模式 #C #小艺 #搜索 #STDIO传输 #SSE传输 #WebMVC #WebFlux #产品经理 #就业 #CMake #Make #C/C++ #IndexTTS2 # 阿里云安骑士 # 木马查杀 #多模态 #微调 #超参 #LLamafactory #KMS激活 #人大金仓 #Kingbase #Spring AOP #程序人生 #Java程序员 #Java面试 #后端开发 #Spring源码 #Spring #国产操作系统 #V11 #kylinos #多进程 #python技巧 #论文阅读 #软件工程 #wsl #CSDN #raid #raid阵列 #nas #numpy #es安装 #Langchain-Chatchat # 国产化服务器 # 信创 #数字化转型 #实体经济 #商业模式 #软件开发 #数智红包 #商业变革 #创业干货 #模型训练 #Tracker 服务器 #响应最快 #torrent 下载 #2026年 #Aria2 可用 #迅雷可用 #BT工具通用 #database #儿童AI #图像生成 #Zabbix #CosyVoice3 #语音合成 #pjsip #FASTMCP #LobeChat #vLLM #GPU加速 # REST API # GLM-4.6V-Flash-WEB #开源工具 #产品运营 #Puppet # IndexTTS2 # TTS # keep-alive #联机教程 #局域网联机 #局域网联机教程 #局域网游戏 #人脸识别sdk #视频编解码 #人脸识别 #高斯溅射 #MC群组服务器 #ZooKeeper #ZooKeeper面试题 #面试宝典 #深入解析 #n8n解惑 #云服务器 #个人电脑 #unix #编程 #c++高并发 #百万并发 #CS2 #debian13 # 语音合成 #模拟退火算法 #uip #eureka #k8s #广播 #组播 #并发服务器 #x86_64 #数字人系统 #模版 #函数 #类 #笔试 #OPCUA #信创国产化 #达梦数据库 #yolov12 #研究生life #gpu #nvcc #cuda #nvidia #其他 #树莓派 #温湿度监控 #WhatsApp通知 #IoT #MySQL #SMTP # 内容安全 # Qwen3Guard #黑客技术 #文件上传漏洞 #RXT4090显卡 #RTX4090 #深度学习服务器 #硬件选型 #diskinfo # 磁盘健康 #Kylin-Server #服务器安装 #SQL注入主机 #流量监控 #echarts #A2A #GenAI # 服务器IP # 端口7860 #CPU利用率 #平板 #零售 #智能硬件 #vncdotool #链接VNC服务器 #如何隐藏光标 #LangFlow # 智能运维 # 性能瓶颈分析 #devops #戴尔服务器 #戴尔730 #装系统 #FHSS #junit #ThingsBoard MCP #clickhouse #代理 # 自动化部署 # VibeThinker #Aluminium #Google #服务器解析漏洞 #nodejs # 服务器IP访问 # 端口映射 #遛狗 #算力建设 #bug #AI技术 #练习 #基础练习 #数组 #循环 #九九乘法表 #计算机实现 #dynadot #域名 #ETL管道 #向量存储 #数据预处理 #DocumentReader #esb接口 #走处理类报异常 #ffmpeg #自动化运维 #SSH密钥 # 一锤定音 # 大模型微调 #网路编程 #smtp #smtp服务器 #PHP #银河麒麟部署 #银河麒麟部署文档 #银河麒麟linux #银河麒麟linux部署教程 #数据安全 #注入漏洞 #wpf #firefox #safari #Docker #b树 #VibeVoice # 高温监控 #fs7TF # 远程访问 #Fun-ASR # 语音识别 #ROS # 局域网访问 # 批量处理 #密码 #windbg分析蓝屏教程 #memory mcp #Cursor #nmodbus4类库使用教程 #docker-compose #目标跟踪 #npu #c++20 # 远程连接 #内网 # 跳板机 #Buck #NVIDIA #算力 #交错并联 #DGX #内存治理 #远程软件 #IFix #gerrit #opc ua #opc #代理服务器 #rsync # 数据同步 # 环境迁移 #blender #设计师 #图像处理 #游戏美术 #技术美术 #matplotlib #安全架构 #分布式数据库 #集中式数据库 #业务需求 #选型误 # Connection refused #跳槽 #工作 #odoo #指针 #anaconda #虚拟环境 #HarmonyOS # GLM-TTS # 数据安全 #xshell #host key #Apple AI #Apple 人工智能 #FoundationModel #Summarize #SwiftUI #TTS私有化 # IndexTTS # 音色克隆 #多线程 #claudeCode #content7 #ip # ARM服务器 # 串口服务器 # NPort5630 #appche #编程助手 #TLS协议 #HTTPS #漏洞修复 #运维安全 # 轻量化镜像 # 边缘计算 #策略模式 #matlab #OpenHarmony #ceph #Python办公自动化 #Python办公 #turn #网安应急响应 #ftp #sftp # GLM # 服务连通性 #YOLO识别 #YOLO环境搭建Windows #YOLO环境搭建Ubuntu #opc模拟服务器 #cpu #量子计算 #SSH跳转 #TTS # GPU集群 #AI部署 # ms-swift #服务器开启 TLS v1.2 #IISCrypto 使用教程 #TLS 协议配置 #IIS 安全设置 #服务器运维工具 #PN 结 #uniapp #合法域名校验出错 #服务器域名配置不生效 #request域名配置 #已经配置好了但还是报错 #uniapp微信小程序 #服务器线程 # SSL通信 # 动态结构体 #RWK35xx #语音流 #实时传输 #超算中心 #PBS #lsf #华为od #华为机试 #报表制作 #职场 #数据可视化 #用数据讲故事 #语音生成 #晶振 #Socket #套接字 #I/O多路复用 #字节序 #数据迁移 #weston #x11 #x11显示服务器 #samba #mtgsig #美团医药 #美团医药mtgsig #美团医药mtgsig1.2 #汽车 #lvs #adobe #宝塔面板部署RustDesk #RustDesk远程控制手机 #手机远程控制 #系统安装 #铁路桥梁 #DIC技术 #箱梁试验 #裂纹监测 #四点弯曲 #可再生能源 #绿色算力 #风电 #麦克风权限 #访问麦克风并录制音频 #麦克风录制音频后在线播放 #用户拒绝访问麦克风权限怎么办 #uniapp 安卓 苹果ios #将音频保存本地或上传服务器 #express #cherry studio #gmssh #宝塔 #漏洞挖掘 #Exchange #JNI #pxe #AI应用编程 #Xshell #Finalshell #生信 #生物信息学 #组学 #STUN # TURN # NAT穿透 #MCP服务器注解 #异步支持 #方法筛选 #声明式编程 #自动筛选机制 #若依 #EN4FE #clawdbot #MinIO #上下文工程 #langgraph #意图识别 #自由表达演说平台 #演说 #AI Agent #开发者工具 #free #vmstat #sar #sentinel #前端开发 #范式 #计算机外设 #Karalon #AI Test #TRO #TRO侵权 #TRO和解 #视觉检测 #visual studio #WRF #WRFDA #流程图 #图论 #Discord机器人 #云部署 #程序那些事 #国产开源制品管理工具 #Hadess #一文上手 #蓝桥杯 #okhttp #r语言 #健康医疗 #服务器IO模型 #非阻塞轮询模型 #多任务并发模型 #异步信号模型 #多路复用模型 #Reactor #ET模式 #非阻塞 #领域驱动 #remote-ssh #gRPC #注册中心 #移动端h5网页 #调用浏览器摄像头并拍照 #开启摄像头权限 #拍照后查看与上传服务器端 #摄像头黑屏打不开问题 #工程实践 #视觉理解 #Moondream2 #多模态AI #c #工业级串口服务器 #串口转以太网 #串口设备联网通讯模块 #串口服务器选型 #AI应用 #图像识别 #入侵 #日志排查 #高考 #gpt #API #taro #wps #Linux多线程 #Beidou #北斗 #SSR #gateway #信息安全 #信息收集 #iot #poll #webgl #区块链 #租显卡 #训练推理 #simulink #bigtop #hdp #hue #kerberos #pencil #pencil.dev #设计 #传统行业 #轻量化 #低配服务器 #Anything-LLM #IDC服务器 #私有化部署 #Keycloak #Quarkus #AI编程需求分析 #java大文件上传 #java大文件秒传 #java大文件上传下载 #java文件传输解决方案 # AI部署 #材料工程 #智能电视 #PyCharm # 远程调试 # YOLOFuse #AB包 #VMware创建虚拟机 #远程更新 #缓存更新 #多指令适配 #物料关联计划 #挖漏洞 #攻击溯源 #warp #docker安装seata #测速 #iperf #iperf3 #Syslog #系统日志 #日志分析 #日志监控 #生产服务器问题查询 #日志过滤 #Autodl私有云 #深度服务器配置 # 水冷服务器 # 风冷服务器 #VoxCPM-1.5-TTS # 云端GPU # PyCharm宕机 #全链路优化 #实战教程 #m3u8 #HLS #移动端H5网页 #APP安卓苹果ios #监控画面 直播视频流 #Prometheus #DooTask #防毒面罩 #防尘面罩 #stl #IIS Crypto #UEFI #BIOS #Legacy BIOS #everything #交换机 #三层交换机 #AI生成 # outputs目录 # 自动化 #esp32 arduino #决策树 #HistoryServer #Spark #YARN #jobhistory #sglang #ComfyUI # 推理服务器 #身体实验室 #健康认知重构 #系统思维 #微行动 #NEAT效应 #亚健康自救 #ICT人 #云开发 #KMS 激活 #rabbitmq #AI智能棋盘 #Rock Pi S #边缘计算 #计算机毕业设计 #程序定制 #毕设代做 #课设 #Hadoop #SSH别名 #SSH Agent Forwarding # 容器化 #BoringSSL #云计算运维 #内存接口 # 澜起科技 # 服务器主板 #asp.net上传大文件 #数学建模 #数模美赛 #iphone # 显卡驱动备份 # 鲲鹏 #开关电源 #热敏电阻 #PTC热敏电阻 #http头信息 #文件传输 #电脑文件传输 #电脑传输文件 #电脑怎么传输文件到另一台电脑 #电脑传输文件到另一台电脑 #性能 #优化 #RAM #wireshark #nacos #银河麒麟aarch64 # 公钥认证 # 权限修复 #ICE # 服务器迁移 # 回滚方案 #群晖 #大模型入门 #homelab #Lattepanda #Jellyfin #Plex #Kodi #企业存储 #RustFS #对象存储 #高可用 #WEB #TCP服务器 #开发实战 #全文检索 #银河麒麟服务器系统 #TensorRT # 推理优化 # HiChatBox # 离线AI #duckdb #log4j #Jetty # 嵌入式服务器 #模块 #可撤销IBE #服务器辅助 #私钥更新 #安全性证明 #双线性Diffie-Hellman #音乐 #IntelliJ IDEA #Spring Boot #短剧 #短剧小程序 #短剧系统 #微剧 #Coturn #TURN #hibernate #nosql # 代理转发 #建筑缺陷 #红外 #数据集 #SMARC #ARM #空间计算 #原型模式 # 云服务器 #网络安全大赛 #CNAS #CMA #程序文件 #I/O模型 #并发 #水平触发、边缘触发 #多路复用 #实时检测 #卷积神经网络 #DAG #数据访问 #云服务器选购 #Saas #线程 #Comate #outlook #错误代码2603 #无网络连接 #2603 #eclipse #servlet #HarmonyOS APP #Ubuntu服务器 #硬盘扩容 #命令行操作 #SSH复用 # 远程开发 #磁盘配额 #存储管理 #形考作业 #国家开放大学 #系统运维 #具身智能 #C++ UA Server #SDK #跨平台开发 #rtmp #机器视觉 #6D位姿 #UOS #海光K100 #统信 #声源定位 #MUSIC #mssql #AI电商客服 #spring ai #oauth2 #lucene #思爱普 #SAP S/4HANA #ABAP #NetWeaver #Ward #考研 #文生视频 #WAN2.2 #AI视频生成 #国产PLM #瑞华丽PLM #瑞华丽 #PLM #markdown #建站 #游戏策划 #游戏程序 #用户体验 #电梯 #电梯运力 #电梯门禁 #Ubuntu #esp32 #mosquito #数据报系统 #2026年美赛C题代码 #2026年美赛 #智慧城市 #智能制造 #供应链管理 #工业工程 #库存管理 #海外短剧 #海外短剧app开发 #海外短剧系统开发 #短剧APP #短剧APP开发 #短剧系统开发 #海外短剧项目 #反向代理 #WinDbg #Windows调试 #内存转储分析 #AI视频创作系统 #AI视频创作 #AI创作系统 #AI工具 #AI创作工具 #华为od机试 #华为od机考 #华为od最新上机考试题库 #华为OD题库 #华为OD机试双机位C卷 #od机考题库 #resnet50 #分类识别训练 #运维 #静脉曲张 #腿部健康 #运动 #Ascend #MindIE #FRP #数据采集 #浏览器指纹 #边缘AI # Kontron # SMARC-sAMX8 #自动化巡检 #OpenAI #故障 #UDP套接字编程 #UDP协议 #网络测试 #CA证书 #jquery #ESP32编译服务器 #Ping #DNS域名解析 #分子动力学 #化工仿真 #二值化 #Canny边缘检测 #轮廓检测 #透视变换 #游戏服务器断线 #期刊 #SCI #面向对象 #基础语法 #标识符 #常量与变量 #数据类型 #运算符与表达式 #session #主板 #总体设计 #电源树 #框图 #starrocks #阿里云RDS #coffeescript #composer #symfony #java-zookeeper #dubbo #勒索病毒 #勒索软件 #加密算法 #.bixi勒索病毒 #数据加密 #JADX-AI 插件