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

推荐订阅源

P
Palo Alto Networks Blog
MongoDB | Blog
MongoDB | Blog
H
Help Net Security
The GitHub Blog
The GitHub Blog
D
Docker
K
Kaspersky official blog
B
Blog
C
Cyber Attacks, Cyber Crime and Cyber Security
云风的 BLOG
云风的 BLOG
Microsoft Azure Blog
Microsoft Azure Blog
V
Vulnerabilities – Threatpost
C
Cisco Blogs
S
Schneier on Security
Engineering at Meta
Engineering at Meta
P
Proofpoint News Feed
The Last Watchdog
The Last Watchdog
Recent Announcements
Recent Announcements
Martin Fowler
Martin Fowler
G
Google Developers Blog
Project Zero
Project Zero
S
Secure Thoughts
AWS News Blog
AWS News Blog
T
The Blog of Author Tim Ferriss
Recent Commits to openclaw:main
Recent Commits to openclaw:main
T
Tor Project blog
L
LINUX DO - 最新话题
小众软件
小众软件
爱范儿
爱范儿
GbyAI
GbyAI
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
Cisco Talos Blog
Cisco Talos Blog
Security Archives - TechRepublic
Security Archives - TechRepublic
N
News | PayPal Newsroom
P
Privacy International News Feed
NISL@THU
NISL@THU
Scott Helme
Scott Helme
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
WordPress大学
WordPress大学
博客园 - Franky
H
Heimdal Security Blog
Recorded Future
Recorded Future
SecWiki News
SecWiki News
A
Arctic Wolf
C
Cybersecurity and Infrastructure Security Agency CISA
N
News and Events Feed by Topic
T
Tailwind CSS Blog
博客园_首页
Google Online Security Blog
Google Online Security Blog
Hacker News: Ask HN
Hacker News: Ask HN
有赞技术团队
有赞技术团队

Все публикации подряд на Хабре

Ловим музу за клавиатуру: как айтишнику стать автором Что умеет Midjourney в 2026? Мой немного грустный разбор этого шикарного инструмента Никто не любит писать тесты, но ИИ может исправить это IPv8 выглядит как мечта. Поэтому почти наверняка не взлетит Производители вернули в продажу материнки с DDR3. Что происходит? Управление агентом с телефона через Telegram теперь в KodaCode От координации к лидерству: как меняется роль руководителя разработки Я сделала родителям бизнес вместо пенсии: зарабатываем 70 тысяч, мама не даёт продать В три раза быстрее приемка товара и оптимизация трудозатрат на 73%: как «РСТ-Инвент» помог Gulliver Group ИИ-шечный мир победил? О влиянии искусственного интеллекта на игропром Кремль снижает давление на Телеграмм пока Европа строит интернет по паспорту Как CEO, CTO и CIO за 8 часов собрали ИИ-директора, который умеет держать позицию под давлением Как (не) потерять домен за выходные Вместо 8 разных VPS: как я организовал практику студентам на одном сервере Почему твой Open Source проект не замечают? R&D: искусство управления неопределенностью в разработке AI-дефляция: вакансий для разработчиков больше, а рост зарплат — худший за 15 лет Мы отдали управление роботами OpenClaw. Что из этого вышло Галактический ID: система идентификации для всех форм разумной жизни Шесть основ бизнес-анализа: начинаем с вопроса «Кто в игре?» Код-ревью, в котором дело не в коде Данные переехали. Команда — нет Системной подход к сдаче OSWE в 2025 Почему комната управления реактором покрашена в цвет морской пены 4 YAML-файла вместо PySpark: как аналитикам строить пайплайны без разработчиков LLM-агент для поиска свободных доменов: автоматизируем подбор Когда, зачем и как правильно начинать новую сессию в Claude Code? Как я заставил нейросеть писать макросы для FreeCAD Анатомия ИИ‑агента для подбора персонала. От тысячи резюме к топ‑10 за минуты Опыт разработчика как экономика внимания Автономность как точка невозврата: кто будет субъектом в цифровом будущем Обучение ИИ в «диких» условиях: как рутинные действия превращаются в датасеты Как измерить LLM для задач кибербеза: обзор открытых бенчмарков Где хранить код? Сравнение GitHub, GitLab и Bitbucket Математика объясняет, почему нормальное распределение встречается повсюду Почему ваш FinOps не работает: 12 тезисов от практиков Как подписать проектную документацию УКЭП с использованием бесплатных лицензий Pilot Адаптивное администрирование Sigla Vision Я грузил уран в бочки, а потом 20 лет строил ИТ в атомной отрасли Чем позвонить с Эвереста? История и обзор спутниковой связи. Часть 2 Как языковая модель помогает контролировать качество инструктажей по охране труда в металлургии Как не передать на desktop свой IP в РКН Анатомия SAP Privileges: как устроено управление правами в macOS MoneyDev: Сказка про три главных слова Обновлённый токенизатор видео K-VAE 2.0 от Сбера Как сделать диспетчеризацию дома на 1284 квартиры почти бесплатно Как мы разогнали железную дорогу Мы дали агентам рутину. Теперь надо решить — что делать с освободившимся временем Токсичный контент, промпт-хакинг и защита ИИ — всё о Guardrails для LLM Умный город начинается с точного взгляда: как «Фалькон Тех» меняет пространство к лучшему Навайбкодил приложение для анализа графов Почему Дюну так интересно читать? Упрощаем работу с рутиной или как стать Гендальфом Белым Деконструкция Go: CPU, RAM и что там происходит. Go Assembler база. Часть 1.1 Какие профессии исчезнут из-за ИИ, а какие появятся? И что с этим делать Как мы построили IT-отдел, где хочется расти: архитектурные встречи, прозрачные метрики и книжные подарки Rufler: Делаем из Claude Code автономный рой через один YAML-конфиг Sing-box и белый список приложений Как построить надёжный обмен сообщениями в микросервисах: лучшие практики для enterprise OpenAI строит MLM-пирамиду, а McKinsey и Accenture помогают ей в этом Дом, который не построил Фишер (Часть 2) «Сверхзвуковой математик» против «Вдумчивого логиста»: битва алгоритмов 3D-упаковки Мультимодальные модели – грубый и дорогой инструмент Разговоры ничего не стоят. Код тоже Проверки физических лиц: с кого начнет ФНС Топ-10 бесплатных нейросетей для создания видео в 2026 году Первые слои кода: как наши решения сегодня определяют архитектуру ИИ на десятилетия Разработка нового статического анализатора: PVS-Studio JavaScript Поиск уязвимостей ПО: базовый минимум или роскошный максимум Почему оценка персонала не работает как инструмент управления Как мы разработали ИИ-ассистента и сократили рутину продуктовой команды на 50% Как я ушел из найма, нажарил косточек и продал на маркетплейсах на 168 млн в год Когда 1С:ERP уже внедрена, а нормального производственного плана всё ещё нет Как я сделал Claude мультимодальным, подключив к нему Qwen Omni Как приглашение на вакансию мечты превращается в атаку Infrastructure as Code: философия и лучшие практики IaC Тестируем Yandex Code Assistant на задаче, в которой нужно хранить секреты nxs-universal-chart v3.0: новое поколение универсального Helm-чарта Callback Injection: Техника, которая отправила Microsoft Defender в глухой нокаут «Все идеи на стол»: митап как способ вывести проект из тупика Сегодня я узнал нечто новое о GPU благодаря багу в своей игре Как заставить LLM ̶ ̶г̶а̶л̶л̶ю̶ ̶ эволюционировать Карта событий как фундамент аналитики: практический кейс для E-commerce Что выбрать для AI: x86, ARM или RISC-V? Дайджест железа за март Роль соматических мутаций в развитии аутоиммунных заболеваний: путь к избирательной терапии Mythos от Anthropic — тревожный сигнал для всех, а не только для банков Guardrails для LLM на Java: как приручить промпт‑инъекции и токсичные ответы Green-VLA: как мы собрали VLA-модель для реального антропоморфного робота и не потеряли обобщение Финансовая гонка вооружений: почему умные люди добровольно в ней участвуют Эра ИИ-агентов наступила: выбираем лучшего цифрового сотрудника # Практический опыт внедрения WinCC Redundancy на производственном предприятии Сделал MVP за 3 дня, а потом неделю прикручивал оплату. Оно того стоило? Физика против Маска: почему Starship V3 может оказаться ещё одной катастрофой Нефть Венесуэлы: крупнейшие запасы в мире, но не крупнейшая нефтяная держава JPA 4. Переосмысление Hibernate Почему зеркальная фотокамера Nikon D5 десятилетней давности идеально подошла для миссии «Артемида-2» Проект «Уровень-Спутник» или как мы сделали платформу для гидрологов «Замедлиться, чтобы ускориться»: почему ИИ повышает цену ошибок в требованиях и архитектуре Как с нуля поднять трафик IT-компании на 1657% при бюджете 55 тыс. и выжить Pixel-perfect Downsampling — идеальная отрисовка 50 миллионов точек без потерь
CVD + ИИ подсказки: инструмент, который сам подсвечивает расхождения на графике
Юрий · 2026-06-18 · via Все публикации подряд на Хабре

Средний

4 мин

28

При выборе инструментов для анализа Order Flow быстро обнаруживается, что профессиональные терминалы (ATAS, VolFix, Tiger) стоят как хороший VPS, а в бесплатных версиях или задержка, или нет истории — только текущая свеча. Этого недостаточно для нормального анализа.

Ссылка на описание программы: Cumulative Volume Delta (CVD) Analyzer

Каждый, кто пробовал Order Flow, упирался в одну и ту же проблему: как именно считаются индикаторы? Что там вообще внутри? И если график вдруг начал показывать странные данные, непонятно, где искать причину — на уровне приёма данных, расчёта дельты или отрисовки.

Я немного изменил подход. Инструмент запрашивает готовые свечи с Binance через REST API и считает CVD (Cumulative Volume Delta) прямо в браузере. Никаких посредников, никаких скрытых преобразоваций. Данные обновляются при каждом запросе — вы всегда видите актуальную картину.

Расскажу, как всё работает: от получения свечей до готового графика с подсказками.

Почему не React и не сборщики

Рассматривался вариант с использованием современных фреймворков (Vite, React, Redux Toolkit), однако от него решено было отказаться. Основные причины: требование к мгновенному запуску без установки дополнительного ПО — инструмент должен открываться из локальной папки без подготовки окружения.

В итоге сделал просто HTML-файлы. Открываешь index.html — и погнали. Никаких npm install, никаких ошибок сборки.

Главная страница

Главная страница

Структура элементарная:

  • index.html — выбор пары и таймфрейма.

  • Cumulative Volume Delta (CVD).html — главный мозг. Там загружаются свечи с Binance, считается дельта и строятся индикаторы.

  • CVD charts.html — отдельный файл для детальной визуализации. Вынес его, чтобы отрисовка не мешала расчётам.

  • deepseek_analysis_CVD.html — болталка с ИИ, чтобы иногда подсвечивать странные моменты на графике.

Между файлами общаюсь через localStorage: основной модуль сохраняет результаты расчёта, а модуль визуализации подхватывает их при открытии. Костыльно? Да. Но для локальной программы, где нет бэкенда, это работает надёжнее любых стейт-менеджеров. Всё, что нужно для анализа, лежит прямо в браузере.

Статистика кирптовалюты

Статистика кирптовалюты

Главная боль: как определить, кто покупал, а кто продавал?

Биржа в свечном API не пишет «здесь пришёл покупатель». Она присылает готовые бары: время, цену открытия, максимум, минимум, закрытие и объём. И в каждом баре есть отдельное поле — объём покупок по рыночным ордерам (taker buy volume).

Направление я определяю просто: из общего объёма вычитаю объём покупок — получаю объём продаж. Разница между ними — это дельта для свечи. Такой подход используют все, кто не хочет платить за полный поток тиков.

На практике с этим подходом есть нюанс: если рынок замер в узком диапазоне и объёмы малы, дельта может быть шумной. Но для моих часовых свечей погрешность терпимая, а альтернатива — покупать дорогой поток данных с метками сторон, чего я и хотел избежать.

Считаем дельту и накопление

Вот основная логика. Без лишней красоты, просто то, что работает при загрузке свечей:

function computeIndicators(candles) {
  const delta = [];
  const cvd = [];
  let acc = 0;

  for (let i = 0; i < candles.length; i++) {
    const buyVol = candles.buyVol[i] || 0;
    const totalVol = candles.volume[i] || 0;
    const sellVol = totalVol - buyVol;
    const currentDelta = buyVol - sellVol;

    acc += currentDelta;
    delta.push(currentDelta);
    cvd.push(acc);
  }

  return { delta, cvd };
}

currentDelta — это разница между объёмом покупок и продаж внутри свечи. CVD накапливается с начала сессии и обнуляется в полночь по UTC, чтобы синхронизироваться с биржевым днём.

Таблица свечного анализа

Таблица свечного анализа

Сглаживание, чтобы глаза не ломались

Сначала я выводил сырую дельту. Это было просто ужасно: один крупный маркет-ордер на 100 BTC рисовал красный столб на весь экран, и весь график превращался в иголку.

Я добавил простое экспоненциальное сглаживание (EMA с альфой 0.2) исключительно для отображения гистограммы. Сам CVD при этом считается строго по сырым данным без сглаживания, чтобы не терять накопленный объём.

const alpha = 0.2;
smoothedDelta = previousSmoothed * (1 - alpha) + currentCandleDelta * alpha;

На графике теперь видны локальные всплески, но без «палок в потолок».

Табличный анализ CVD дивергенций

Табличный анализ CVD дивергенций

Зачем я прикрутил DeepSeek (и не жалею)

Идея родилась спонтанно. Вместе с графиком я решил выводить короткий текстовый комментарий к последним 15 свечам. Модуль анализирует последние 15 свечей и формирует JSON с изменениями цены, CVD и экстремумами дельты, после чего отправляет запрос в DeepSeek API. Модель возвращает краткий комментарий: например, фиксирует расхождение между движением цены и накопленным объёмом (классическая дивергенция), что помогает замечать странности без круглосуточного наблюдения.

Модуль собирает JSON с изменениями цены, CVD и максимумами дельты, шлёт в DeepSeek API, и модель возвращает 1–2 предложения.

Запрос к DeepSeek AI

Запрос к DeepSeek AI

Звучит как перебор? Возможно. Но на практике это помогает не пялиться в график 8 часов подряд — модель обращает внимание на аномалии. При этом я чётко написал в интерфейсе, что это не торговый сигнал, а вспомогательный комментарий.

Мини-ликбез для себя и коллег

Я добавил отдельную вкладку-шпаргалку (_Lesson.html), где расписал, что вообще означают эти разноцветные столбики на моём графике:

  • Дивергенция: цена обновила максимум, а CVD нет — жди коррекции.

  • Поглощение: дельта зелёная, а цена стоит на месте — значит, лимитники держат уровень.

  • Исчерпание: объёмы падают на сильном движении — возможно, это конец импульса.

Учебное пособие: Cumulative Volume Delta (CVD)

Учебное пособие: Cumulative Volume Delta (CVD)

Эта теория не новая, но когда она лежит прямо рядом с графиком и анимирована (отдельный файл с анимацией), новичкам проще вкатиться.

Что не так с моим решением

Это не замена ATAS:

  • Я не строю полноценный кластерный профиль (там объём по ценам), потому что не хочу тащить весь стакан на клиент.

  • Сброс CVD в ноль каждый день режет историю, и межсессионный анализ я не веду.

  • localStorage — не самый надёжный способ хранения при больших объёмах данных, но для этих задач хватает.

Но меня это устраивает. Инструмент получился лёгкий, и главное — я знаю каждый байт в его расчётах.
Видео опрограмме на Ютуб: