Восстановление целочисленной функции с помощью *-обучения

Вопрос или проблема

У меня следующая проблема. Из технической модели у нас есть функция $f(n,p)$, приближающая время выполнения. Функция $f$ отображает

$$
f: \mathbb{N} \times \mathbb{P} \to \mathbb{R}_{+}
$$

где $\mathbb{P} = \{1,\ldots,50\} \subset\mathbb{N}$. $n$ определяет объем входных данных, а $p$ является параметром процесса, который имеет непрерывное влияние на время выполнения. Нас интересует значение $p$ такое, что $f(n,p)$ для заданного $n$. Во время эксперимента мы тестируем некоторые значения $n$, такие как 500, 1000, 5000, и для всех возможных значений $p$, а затем вручную выбираем оптимальное $p$. Например, для всего, что меньше 750, используйте оптимальное $p$ из тестового прогона с $n=500$ и так далее. Обычно для фиксированного $n$ время выполнения по $p$ имеет следующий характер, но с добавлением шума:
Demo Picture
С увеличением $n$ дно сдвигается вправо, и из-за шума дно не плоское. Таким образом, в примере оптимальное $p$ находится где-то между $20$ и $30$.

Теперь мы ищем функцию $g$:

$$
g: \mathbb{N} \to \mathbb{P}
$$

которая определяется как
$$
g(n) = \operatorname{argmin}\limits_{p\in\mathbb{P}} f(n,p)
$$

Поскольку выборка $f$ для фиксированного $n$ не является проблемой, и у меня уже есть большой набор выборок, я считаю, что это будет хорошей задачей для начала изучения области машинного обучения для себя.

Мой основной вопрос в том, с чего начать? Ищите руководство по машинному обучению, я в основном наталкиваюсь на примеры распознавания изображений и не вижу никаких хороших связей между ними и моей проблемой.
Есть ли предложения, что почитать для решения этой проблемы? Какое программное обеспечение использовать? И, наконец, как извлечь $g$ таким образом, чтобы мы могли предоставить эту функцию пользователям или реализовать где-то? На данный момент я знаю, что $g$ является неубывающей для увеличивающегося $n$.

Редактировать
Результаты выборки могут также выглядеть вот так enter image description here

Таким образом, пики в области “минимальной” точки не являются шумом. Они вызваны техническими внутренностями рассматриваемого процесса. Таким образом, обрабатывая данные и удаляя шум, эти точки необходимо сохранить. И они делают нахождение $g$ таким сложным, потому что в одном прогона выборки минимальное $p$ лежит слева, в середине или справа от них. По этой причине я решил, что это будет хорошей точкой для использования машинного обучения, чтобы получить некоторые инсайты.

Если я правильно понимаю, цель будет состоять в том, чтобы модель получала значение $n$ и предсказывала оптимальное $p$, которое минимизирует $f(n,p)$.

С этой точки зрения это похоже на простую задачу регрессии. Вы, вероятно, могли бы обучить модель регрессии: для каждой точки в вашем наборе данных предиктором является $n$, а отклик — значение $p$, которое минимизирует $f(n,p)$ для этого $n$. Обратите внимание, что все точки, которые не соответствуют минимуму, не имеют значения в этом контексте.

Я бы предложил начать с построения графика этой функции из ваших данных (не того, что с фиксированным $n$, а того, который отображает $n$ на оптимальное значение $p$). Было бы полезно узнать, как он выглядит, в особенности для выбора подходящего метода регрессии.

[редактировать] О работе с шумом.

Стандартный статистический способ работы с шумом — ничего не делать 🙂

Сколько у вас данных? Потому что если у вас достаточно данных, статистически шум должен уравновешивать сам себя. Например, если у вас есть 100 таких графиков для фиксированного $n$, среднее оптимальное $p$ должно быть достаточно близким к истинному оптимальному $p$. Даже если для некоторых значений $n$ данные не содержат оптимального значения $p$, по мере увеличения значений $n$ этот шум вряд ли будет значительным. Важно, чтобы модель регрессии правильно представляла общую тенденцию, а не захватывала небольшие вариации, вызванные шумом.

Я бы начал с графика, состоящего из одного ящика диаграммы для каждого значения $n$ и варьируемого $n$, где множество значений, представленных в ящике диаграммы, — это все минимальные $p$ в данных для этого значения $n$.

[редактировать 2] Еще одна интересная визуализация: вы можете представить свои полные данные в виде тепловой карты, где $n$/$p$ находятся на осях X/Y, а цвет основан на значении $f(n,p)$).

Поскольку вы утверждаете, что аномальные значения следуют особой модели, одним из вариантов является удаление всех значений, превышающих порог изменения. Порог изменения может быть установлен вручную или изучен. Другими словами, составьте правило, основанное на первой производной от реализованных значений данных.

Вот пример на Python:

time_all = [.8, .7, .6, .5, .4, .3, .2, .1, 0, .2, 0, 
            .2,  0, .1, .2, .3, .4, .5, .6, .7, .8]
change_threshold = .15        

time_valid = [time_all[0]]
for t0, t1 in zip(time_all, time_all[1:]):
    if (t0 - t1) < change_threshold:
        time_valid.append(t1)

Ответ или решение

В данной задаче перед вами стоит цель восстановления целочисленной функции ( g(n) ), которая минимизирует ( f(n, p) ) по параметру ( p ). Рассмотрим детально, как можно применить машинное обучение для решения этой задачи.

Анализ задачи

Цель: Для заданного ( n ) предсказать оптимальное значение ( p ), минимизирующее функцию времени выполнения ( f(n, p) ).

Постановка задачи

  1. Данные. У вас уже есть множество данных о функциях времени выполнения для различных значений ( n ) и ( p ).
  2. Функция оптимизации. Вашей задачей является нахождение минимального значения ( p ) для каждого заданного ( n ), то есть вы ищете функцию вида:
    [
    g(n) = \operatorname{argmin}_{p\in\mathbb{P}} f(n,p)
    ]
  3. Особенности процесса. Графики времени выполнения имеют шумы и спайки, что усложняет нахождение глобального минимума, особенно учитывая, что "спайки" могут быть не просто шумом, а связаны с техническими аспектами процесса.

Методология решения

Пошаговый подход

  1. Исследование данных. Визуализируйте ваши данные. Используйте графики, чтобы оценить зависимости между ( n ) и оптимальным ( p ). Полезными инструментами могут быть:

    • Коробчатые диаграммы, которые помогут увидеть распределение минимальных значений ( p ) для каждого ( n ).
    • Тепловые карты, отображающие изменения значения ( f(n, p) ) при разных сочетаниях ( n ) и ( p ).
  2. Предобработка данных.

    • Устранение шума: Используйте методы сглаживания, такие как скользящее среднее или медианная фильтрация, для уменьшения воздействия шума на данные.
    • Обработка выбросов: Определите порог изменения (например, с помощью первой производной функций) и удалите аномальные значения, которые превышают этот порог.
  3. Выбор модели.

    • Поскольку задача сводится к регрессии, рассмотрите использование моделей машинного обучения, таких как линейная регрессия, полиномиальная регрессия, деревья решений или методы ансамблевого обучения (например, Random Forest или Gradient Boosting).
    • Учтите, что функция ( g(n) ) должна быть неубывающей, что может послужить дополнительным ограничением при выборе модели.
  4. Обучение и верификация.

    • Разделите данные на обучающую и тестовую выборки. Обучите модель на обучающих данных и верифицируйте её точность на тестовых данных.
    • Используйте метрики качества, такие как среднеквадратичная ошибка (MSE) или средняя абсолютная ошибка (MAE), для оценки качества модели.
  5. Оценка результатов.

    • Проведите тестирование модели. Проверьте её работу на новых значениях ( n ) и оцените способность корректно предсказывать оптимальное ( p ).

Рекомендации по использованию инструментов

  • Языки программирования: Используйте Python, благодаря его обширной экосистеме для анализа данных и библиотекам для машинного обучения (например, scikit-learn, pandas и numpy).
  • Визуализация: Библиотеки, такие как Matplotlib и Seaborn, помогут в создании наглядных графиков для анализа данных.

Заключение

Эта задача позволяет углубиться в методы машинного обучения и найти наиболее эффективный подход к нахождению функции ( g(n) ). С пересмотром и интерпретацией данных у вас будет понимание того, как минимизировать шум и аномалии для достижения точных прогностических моделей. Подходите к задаче последовательно и основательно, используя данные для принятия обоснованных решений на каждом шаге.

Оцените материал
Добавить комментарий

Капча загружается...