Реализация AI-мониторинга здоровья по данным датчиков в мобильном приложении

TRUETECH занимается разработкой, поддержкой и обслуживанием мобильных приложений iOS, Android, PWA. Имеем большой опыт и экспертизу для публикации мобильных приложений в популярные маркеты Google Play, App Store, Amazon, AppGallery и другие.
Разработка и поддержка любых видов мобильных приложений:
Информационные и развлекательные мобильные приложения
Новостные приложения, игры, справочники, онлайн-каталоги, погодные, фитнес и здоровье, туристические, образовательные, социальные сети и мессенджеры, квиз, блоги и подкасты, форумы, агрегаторы
Мобильные приложения электронной коммерции
Интернет-магазины, B2B-приложения, маркетплейсы, онлайн-обменники, кэшбэк-сервисы, биржи, дропшиппинг-платформы, программы лояльности, доставка еды и товаров, платежные системы
Мобильные приложения для управления бизнес-процессами
CRM-системы, ERP-системы, управление проектами, инструменты для команды продаж, учет финансов, управление производством, логистика и доставка, управление персоналом, системы мониторинга данных
Мобильные приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, платформы предоставления электронных услуг, платформы кешбека, видеохостинги, тематические порталы, платформы онлайн-бронирования и записи, платформы онлайн-торговли

Это лишь некоторые из типы мобильных приложений, с которыми мы работаем, и каждый из них может иметь свои специфические особенности и функциональность, а также быть адаптированным под конкретные потребности и цели клиента.

Предлагаемые услуги
Показано 1 из 1 услугВсе 1735 услуг
Реализация AI-мониторинга здоровья по данным датчиков в мобильном приложении
Сложная
~2-4 недели
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_mobile-applications_feedme_467_0.webp
    Разработка мобильного приложения для компании FEEDME
    756
  • image_mobile-applications_xoomer_471_0.webp
    Разработка мобильного приложения для компании XOOMER
    624
  • image_mobile-applications_rhl_428_0.webp
    Разработка мобильного приложения для компании RHL
    1054
  • image_mobile-applications_zippy_411_0.webp
    Разработка мобильного приложения для компании ZIPPY
    947
  • image_mobile-applications_affhome_429_0.webp
    Разработка мобильного приложения для компании Affhome
    874
  • image_mobile-applications_flavors_409_0.webp
    Разработка мобильного приложения для компании FLAVORS
    445

Реализация AI-мониторинга здоровья по данным датчиков в мобильном приложении

Apple Watch передаёт 30 измерений пульса в минуту. Fitbit отдаёт SpO2 каждые 5 секунд. Смысл не в сборе этих цифр — смысл в том, чтобы модель сказала «что-то не так» раньше, чем это почувствует пользователь.

Источники данных датчиков

iOS: HealthKit

HealthKit — единственный правильный способ получать данные здоровья на iOS. Прямые запросы к Bluetooth-датчикам без HealthKit нарушают гайдлайны App Store.

import HealthKit

class HealthDataCollector {
    private let healthStore = HKHealthStore()

    func requestAuthorization() async throws {
        let types: Set<HKQuantityType> = [
            HKQuantityType(.heartRate),
            HKQuantityType(.oxygenSaturation),
            HKQuantityType(.stepCount),
            HKQuantityType(.heartRateVariabilitySDNN),
            HKQuantityType(.restingHeartRate)
        ]
        try await healthStore.requestAuthorization(toShare: [], read: types)
    }

    func observeHeartRate(handler: @escaping (Double) -> Void) {
        let heartRateType = HKQuantityType(.heartRate)
        let query = HKAnchoredObjectQuery(
            type: heartRateType,
            predicate: nil,
            anchor: nil,
            limit: HKObjectQueryNoLimit
        ) { _, samples, _, _, _ in
            guard let samples = samples as? [HKQuantitySample] else { return }
            samples.forEach { sample in
                let bpm = sample.quantity.doubleValue(
                    for: HKUnit(from: "count/min")
                )
                handler(bpm)
            }
        }
        query.updateHandler = { _, samples, _, _, _ in
            guard let samples = samples as? [HKQuantitySample] else { return }
            samples.forEach { sample in
                handler(sample.quantity.doubleValue(for: HKUnit(from: "count/min")))
            }
        }
        healthStore.execute(query)
    }
}

HKAnchoredObjectQuery — правильный выбор для наблюдения в реальном времени. Обычный HKSampleQuery делает снимок и не обновляется.

Android: Health Connect + датчики напрямую

Health Connect (API 26+) — аналог HealthKit для Android. Агрегирует данные от Galaxy Health, Fitbit, Garmin. Прямой доступ к датчикам через SensorManager:

class SensorCollector(private val context: Context) : SensorEventListener {
    private val sensorManager = context.getSystemService(SensorManager::class.java)
    private val heartRateSensor = sensorManager.getDefaultSensor(Sensor.TYPE_HEART_RATE)

    fun startMonitoring() {
        sensorManager.registerListener(
            this,
            heartRateSensor,
            SensorManager.SENSOR_DELAY_NORMAL
        )
    }

    override fun onSensorChanged(event: SensorEvent) {
        if (event.sensor.type == Sensor.TYPE_HEART_RATE) {
            val bpm = event.values[0]
            val accuracy = event.accuracy  // SENSOR_STATUS_ACCURACY_HIGH требуем
            if (accuracy >= SensorManager.SENSOR_STATUS_ACCURACY_MEDIUM) {
                processHeartRate(bpm)
            }
        }
    }
}

Проверка accuracy — обязательна. SENSOR_STATUS_UNRELIABLE (0) даёт артефакты: пульс 255 bpm на мокрой коже датчика.

AI-анализ: детекция аномалий

Задача — выявить отклонения от персональной нормы. Не от медицинских норм (это не медицинский прибор), а от нормы конкретного пользователя.

Isolation Forest — хорошо работает для многомерных временных рядов с небольшим набором фич. Тренируем на «нормальном» поведении за 2–4 недели, выявляем выбросы. Конвертируется в CoreML через coremltools.converters.sklearn.

Скользящие статистики + z-score — проще, интерпретируемее, не требует ML:

func detectAnomaly(currentHR: Double, history: [Double]) -> AnomalyLevel {
    let mean = history.reduce(0, +) / Double(history.count)
    let variance = history.map { pow($0 - mean, 2) }.reduce(0, +) / Double(history.count)
    let stdDev = sqrt(variance)
    let zScore = abs(currentHR - mean) / stdDev

    switch zScore {
    case 0..<2.0: return .normal
    case 2.0..<3.0: return .elevated
    default: return .alert
    }
}

z-score > 3 — статистически значимая аномалия. Но нужен контекст: пульс 160 bpm после WorkoutStart в HealthKit — норма, тот же пульс в покое — аномалия. Контекст активности подключаем через CMMotionActivityManager (iOS) или ActivityRecognitionClient (Android).

Персональные рекомендации

На основе агрегированных паттернов (HRV, пульс в покое, шаги, качество сна) строим систему рекомендаций. Не «занимайтесь спортом» — а «у вас HRV снизился на 18% за 3 дня, что обычно коррелирует с недосыпом — сегодня лучше лёгкая тренировка».

Рекомендации реализуем как rule-based систему поверх ML-аналитики: ML выявляет паттерн, правила превращают его в конкретное сообщение. Rule engine проще тестировать и регулировать, чем «черный ящик».

Приватность и регуляторика

Данные здоровья — sensitive data. GDPR и Apple Review требуют явного consent перед каждым типом данных. Хранение на сервере должно быть зашифрованным (AES-256 at rest, TLS 1.3 in transit).

Если приложение позиционируется как медицинское (диагностика, лечение) — нужна FDA 510(k) clearance (США) или CE marking (EU). Для wellness-приложений без медицинских claims эта регуляторика не применяется — но маркетинговые тексты должны это учитывать.

Процесс работы

Проектирование data pipeline: источники → нормализация → хранение. Разработка ML-модели детекции аномалий, тренировка и валидация. Конвертация в CoreML/TFLite. Интеграция с HealthKit / Health Connect. UI-компоненты: дашборд здоровья, алерты, рекомендации. Тестирование на реальных носимых устройствах.

Ориентиры по срокам

Базовый мониторинг с z-score детекцией и дашбордом — 2–3 недели. Полноценная AI-система с Isolation Forest, персонализированными рекомендациями и фоновым обновлением модели — 4–8 недель.