惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

H
Help Net Security
T
ThreatConnect
SecWiki News
SecWiki News
F
Future of Privacy Forum
AWS News Blog
AWS News Blog
C
Cisco Blogs
A
Arctic Wolf
Vercel News
Vercel News
The GitHub Blog
The GitHub Blog
Scott Helme
Scott Helme
V
V2EX
博客园 - 叶小钗
阮一峰的网络日志
阮一峰的网络日志
K
Kaspersky official blog
G
Google Developers Blog
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
P
Privacy International News Feed
C
Cyber Attacks, Cyber Crime and Cyber Security
N
News | PayPal Newsroom
Schneier on Security
Schneier on Security
NISL@THU
NISL@THU
Microsoft Azure Blog
Microsoft Azure Blog
量子位
The Hacker News
The Hacker News
Stack Overflow Blog
Stack Overflow Blog
Security Latest
Security Latest
M
Microsoft Research Blog - Microsoft Research
Google Online Security Blog
Google Online Security Blog
博客园_首页
C
CXSECURITY Database RSS Feed - CXSecurity.com
I
InfoQ
Google DeepMind News
Google DeepMind News
Y
Y Combinator Blog
The Cloudflare Blog
Microsoft Security Blog
Microsoft Security Blog
Martin Fowler
Martin Fowler
Cisco Talos Blog
Cisco Talos Blog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
T
Troy Hunt's Blog
F
Fox-IT International blog
S
Security @ Cisco Blogs
博客园 - 司徒正美
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
C
Comments on: Blog
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
L
LINUX DO - 最新话题
GbyAI
GbyAI
Project Zero
Project Zero
腾讯CDC
T
Tailwind CSS Blog

博客园_首页

踩坑实录:接口正常Feign调用字段值为空 耿同学学术打假,就是学术版《狂人日记》;学术打假,就是清扫垃圾 浙江事业编笔试上周出分!面试进入倒计时,该如何高效冲刺 - 里奥不吃奥利奥 FastApiAdmin 后端接口开发好了,前端管理界面怎么调用与显示? 我写了 50 个 Claude Code Skill 才发现,前 30 个都白写了 告别 "cd /var/log" !用 journalctl 统一掌控 Linux 日志 我用自己的微信聊天记录,微调了一个“数字分身” AI运动APP开发的常见问题集锦一 复盘梳理-如何深入并抽象 告别手动复制!公众号文章批量导出工具,极致提升内容运营效率 【学习笔记】《Python编程 从入门到实践》第2章:变量命名规则、字符串操作与数值类型详解 Docker--Docker简介及系统架构 别再瞎搞 AI 了!大厂AI业务落地的五个关键环节!(建议新手直接照搬) [MAF的Agent管道详解-01]塑智能体边界,从AIAgent抽象类开始 平台智能化到了分水岭:为什么配置代码化才是 AI Coding 的下一代接口 P.4文本统计工具 高光谱拼接算法(二)Harris 角点探测 - 哥布林学者 Claude Code “悄悄”装了 Python 包?别再让它“投错胎”了 - only赟 影刀 vs 八爪鱼 RPA:到底选哪个?一篇讲透 AI Coding开始进入第四个时代,我还没上车呢! 完整学习LLM(四):Token是什么 【Agentic RL / 强化学习 / OPD】OpenClaw-RL 源码阅读笔记 --- (1)---基础 LitCTF2026web部分wp CAD子系统,是自研还是外包? 什么是教程地狱?5个信号说明你已经陷入(附3步摆脱方法) polygon出题教程 Manim物理模拟:别自己写欧拉了! AI 学习笔记:Agent 的应用演示 - 凌杰 分享一个CAN报文编辑器软件 洛谷P13016 [GESP202506 六级] 最大因数 MiniCPM-V 4.6 部署实战:基于 GPUStack 与 SGLang 的端侧多模态模型部署 用 FRP 打通云服务器与本地 Ubuntu,让 Codex 远程调试本地硬件 软考 - 架构设计师 知识点总结 给 FastApiAdmin 加个“会议纪要”模块,我把后端二次开发的坑踩了个遍 聊一聊 MES系统如何实现多种标签打印并支持不同打印机 2026第四届LitCTF网络安全挑战赛Pwn的wp 断尺问题:戴德金分割现实悖论 给句子做个“语义审计”:从词向量到句子向量的方法论 当AI“卡壳”在生产环境:MCP Server 如何帮我们破局 ofdkit-harmony 0.2.0 发布:鸿蒙原生 OFD 阅读库,已上架 ohpm 有了AI测试工具,还需要掌握Playwright、Pytest、Selenium这些框架吗? 组织转型实录——我把传统研发团队改成AI驱动,踩了无数坑 为什么 AI Coding 难进生产环境?深入了解 Everything-Claude-Code ! 到底 TMD 用哪个: npm, pnpm, Yarn, Bun, Deno? 傻瓜, 当然用 npm 啦 上周热点回顾(5.18-5.24) [对比学习LangChain和MAF-04]针对消息的设计 TrueAsync Server 为 PHP 带来了原生的高性能 HTTP 服务器 规则漂移 帆软市场部为什么能成为高人效增长系统? 22. LangChain LCEL,用 | 串联AI的魔法语言 - 老陈说编程 完整学习LLM(二):大模型到底是什么 洛谷-P11942 [KTSC 2025] 重塑矩阵 题解 哈哈哈哈哈打不过我吧,没有办法我(vllm)就是这么强大! Hermes Edu Skills 从 170 到 188:一次中文教育 Agent Skill Pack 的工程化升级 一个外行,半年搞定机械臂:我的从0到1踩坑实录 新写了个直播录制工具,可录制抖音快手斗鱼直播 15天学会AI应用开发(一)搭建AI大模型应用开发环境 Childhood,23款童年卡牌游戏复刻 Github Copilot配置GPT5.5报错:'temperature' does not support 0.1 with this model. Only the default (1) value is supported. - Eric zhou 单曲循环 ClassIn 在 Linux 下无法播放音频 把 TeXstudio / LaTeX 工程交给 AI:texstudio-mcp 功能详解 .NET 8 Web开发入门(六):Blazor 全栈开发——告别 JavaScript 焦虑 别让 LLM 写文件:一套 Agent 进度跟踪的工程化范式 - BurningFish Qt Bridges for C# 深度技术解析 Multus 多网卡方案:IPVLAN 模式 被流量逼出来的架构:从一台服务器到云原生的 17 次蜕变 —— 集群、缓存、MQ、微服务、Docker、K8S 的前世今生 Claude Code安装全流程 Windows保姆级教程 awk 命令练习(从入门到进阶) Java + Spring实现Hermes Agent之龙虾、Skills、Mcp和沙箱代码执行环境思路 轨迹的蓝图:方程求解与交点计算 Agent新技术分享-Forge论文已被ACM接受 PowerMem 记忆系统的遗忘设计,从神经元到代码工程 我用了FastApiAdmin后,连夜把踩过的坑都整理出来了 一个程序员眼中的 AI 核心概念,讲透 LLM 、Agent 、MCP 、Skill 、RAG... 网络安全在线就能打的内网靶场推荐 & Dawn Breaker 单域靶场 WP CTF 中如何用提示词发挥大模型的最大实力:从聊天助手到大手子 PyTorch KernelAgent 源码解读 ---(6)--- Composer 高光谱拼接算法(一)扫推式成像和航带拼接算法 一文看懂fofa常用语法,告别混淆,精准打击! 从零搭建量化投资系统:用 Qlib 一行代码搞定均线分析 企业 AI 落地,第一件事不是买模型,而是建好企业知识库 如何在Oracle Agent Factory中配置国内厂商的LLM? Codex 换模型太麻烦?这个开源桌面工具帮你一键切换 Avalonia中的动画 2026软考|十大管理超全通俗笔记,备考闭眼记! rv1126b内置phy接hub交换机芯片 React 可拖拽列宽 + 点击行选中 ProTable 封装笔记 五大实锤证据:AI不会终结低代码,只会倒逼技术进化 【硬核脑洞】16位实模式最后的疯狂:我们能否在 640KB 常规内存里手搓一个 MD 模拟器? 基于.Net的NetCoreKevin框架中AgentFramework实现AI智能体Skill和工具动态管理和加载 PostgreSQL 高可用集群 patroni 自动故障转移测试 自己使用C++开发的仿OpenClaw、Hermes智能体工具 记一次 .NET 某集群管理软件 内存暴涨分析 StarBlog番外(5) 从1.6到1.10,基于Avalonia AOT 开发的 Publisher 半年进化之路 Anthropic 把 SOC 误报率从 33% 砍到 7%,真正在干活的不是 Claude SM2演示所有 PEM 功能(生成、加解密、签名/验签) 用 Solon AI 从零构建 MCP 工具服务:让 AI Agent 拥有真实世界的能力 完整学习LLM(一):为什么我要系统学习大模型 Agent Harness Runtime 架构深度解析:工具循环、状态外置与长程任务调度
给热水器装上“电量显示”:用 Shelly Gen4 脚本实现零改装水量预测
曦远Code · 2026-05-26 · via 博客园_首页

前言

相信很多家里还在用储水式热水器的朋友都有热水焦虑:洗澡前要提前开,洗到一半怕没水。市面上大多数传统热水器就是一个黑盒,除了一个模糊的温度表,你根本不知道剩下的热水够洗 5 分钟还是 15 分钟。

最近我拿到了德国外企 Shelly 的新款 Shelly 2PM Gen4,尝试用一种极客的方式彻底解决这个问题。

思路

把”电量”翻译成”水量”

传统的解决办法是拆机加传感器,但这不仅破坏保修,还有漏水风险。

Shelly 方案的巧妙之处在于:利用 Gen4 芯片的本地脚本能力,构建一个虚拟传感器。

注意:Shelly 2PM Gen4 不仅能预测热水量,还支持远程开关控制实时能耗计量。Gen4 设备更支持 Matter 协议和 Zigbee,可与 HomeKit、Google Home、Alexa 等主流智能家居平台无缝联动。

原理很简单:

  1. 升温模型: 脚本监测实时功率。只要功率达到阈值,就说明热水器在加热,根据物理公式计算注入的热量,实时增加水量百分比。
  2. 损耗模拟: 即使不使用,热水器也会散热。脚本会根据时间自动扣除热散失导致的百分比下降。
  3. 本地 UI: 所有的计算都在 Shelly 内部完成,并直接在手机 App 上生成一个像手机电量一样的百分比进度条。

实现原理

硬件安装

接线图

安装过程非常简单:

  1. 断电操作:首先关闭家庭配电箱中热水器对应的断路器
  2. 串联安装:将 Shelly 2PM Gen4 串联在热水器的火线上
  3. 接线规范
    • 火线进线(L)连接到 Shelly 的 1 脚
    • 火线出线连接到 Shelly 的 2 脚(输出至热水器)
    • 零线(N)直接连接到热水器
  4. 恢复供电:确认接线无误后,合上断路器

安全提示:如果对电气操作不熟悉,建议请专业电工协助安装。

功率限制提醒:Shelly 2PM Gen4 的额定负载为 2400W(单路)/ 3840W(总路)。安装前务必核对热水器铭牌功率——部分大容量或即热式热水器功率可能高达 3000W~6000W,严禁超限使用,否则存在过热甚至火灾风险。如热水器功率超出限制,请选择更高规格的 Shelly 设备或仅用于控制回路。

智能算法

我们开发了一段运行在继电器里的脚本,核心原理如下:

1. 功率监测

// 获取实时功率
let status = Shelly.getComponentStatus("switch:0");
let power = status.apower; // 单位:瓦特

2. 状态判断

  • 加热状态:当实时功率 > 额定功率 × 70% 时,判定为加热中
  • 保温状态:当功率低于阈值时,判定为保温或关机状态

3. 热水量计算

// 加热时:按时间比例累加
let add_percent = (delta_s / expected_time_s) * 100;
water_percent = water_percent + add_percent;

// 保温时:模拟热散失
let drop_percent = cool_per_sec * delta_s;
water_percent = water_percent - drop_percent;

4. 状态持久化

使用 Shelly 的虚拟组件(Virtual Component)存储热水量百分比,即使设备重启也不会丢失数据。

实际效果

创建脚本

在 Shelly App 中,进入"脚本"功能模块,点击"+"创建新脚本。将我们的智能预测脚本粘贴进去,保存并运行。

创建新脚本

运行监控

脚本运行后,会自动创建一个名为"预测热水量"的虚拟组件。可以实时看到热水量百分比的变化。

电量检测和热水量变化

实时数据

脚本运行中

运行一段时间后,App 界面会展示完整的监控信息:

  • 设备主页:显示设备在线状态和快速控制按钮,支持远程开关热水器
  • 功率图表:实时功率曲线,清晰展示加热和保温周期
  • 能耗统计:累计用电量和运行时长,帮助你掌握热水器的真实能耗

App 各界面展示

更多功能展示

验证准确性

通过对比热水器自带的温度表读数和我们的预测结果,验证算法的准确性。实测数据显示,预测误差控制在 ±5% 以内,完全满足日常使用需求。

热水器温度表

为什么这个方案更有意义?

在智能家居领域,我们经常讨论智能化,但很多方案只是简单的远程开关。Shelly 这个项目的意义在于软件定义硬件

  • 非侵入式: 不需要动水路,不破坏原机。
  • 低延迟 & 隐私: 数据不上传云端,本地脚本直接算出结果,响应速度是秒级的。
  • 远程控制: 出门忘记关热水器?手机一点即可远程关闭,还能定时开关。
  • 能耗计量: 精确记录每次加热的用电量,帮你优化使用习惯、节省电费。
  • 场景联动: 可以设置——“当热水量达到 80% 时,给手机推送消息,并自动关闭洗手间排气扇”。
  • 生态兼容(Gen4): 支持 Matter 和 Zigbee 协议,可接入 Apple HomeKit、Google Home、Amazon Alexa 等主流平台,与其他智能设备无缝联动。

小结

对于用户来说,Shelly 2PM Gen4 不仅仅是一个开关,它更像是一个运行在家里的微型服务器。通过开放的脚本接口,我们可以把任何传统家电进行智能化改造。

除了本文介绍的热水量预测,还能获得远程开关能耗统计等实用功能。Gen4 设备更支持 Matter 和 Zigbee 协议,轻松融入全屋智能生态。

如果你也受够了盲猜热水温度,这种用代码解决生活痛点的方式,或许是另一种优雅的解决方案。

最后提醒:选购和安装前,请务必确认热水器功率在 Shelly 2PM Gen4 的承载范围内(单路 ≤ 2400W,总路 ≤ 3840W)。部分大功率热水器(如 3000W 以上的储水式或即热式)需要选择更高规格的设备,切勿超限使用。

微信公众号:「程序设计实验室」 专注于互联网热门新技术探索与团队敏捷开发实践,包括架构设计、机器学习与数据分析算法、移动端开发、Linux、Web前后端开发等,欢迎一起探讨技术,分享学习实践经验。