Это старая версия (1.1470) МетодНаименьшихКвадратов.

Содержание

Метод наименьших квадратов



В данной статье все вектора по умолчанию являются векторами-столбцами. Внимательно следите за размерностями матриц и векторов по ходу объяснения. Запись многочленов будет обратной, т. е. не y = b sub 2 x + b sub 1, а y = b sub 1 + b sub 2 x .

Простейший случай

Общая постановка задачи

Допустим, в рамках некого эксперимента было проведено n измерений ¹). Каждое измерение представляет собой пару (x sub i , y sub i ), где x sub iвход, y sub iвыход (такую пару будем называть «точкой»).

Результаты эксперимента могут быть записаны в таблице, в первом столбце которой будут находиться все значения входов, а во втором — все значения выходов: bold x =
 left \[
   pile {x sub 1 above x sub 2 above vdots above x sub i above vdots above x sub n}
 right \] ^ , ~
bold y =
 left \[
  pile {y sub 1 above y sub 2 above vdots above y sub i above vdots above y sub n}
 right \] ^ .

Графически можно представить результаты проведённого эксперимента на графике: по оси абсцисс будем откладывать входы, а по оси ординат — выходы. Такой график называется диаграмма рассеяния (scatter diagram, scatter plot, scatter chart).

Почти никогда не встречается ситуаций, при которых все точки будут лежать на одной прямой. Поэтому мы хотим описать экспериментальные данные линейной функцией («подогнать» их к прямой). По рисунку интуитивно очевидно, что синяя линяя лучше описывает полученные экспериментальные данные, чем красная, но без какого-либо чёткого математического критерия, нельзя однозначно сказать, какая из линий: синяя или зелёная — более приемлема для целей анализа и прогнозирования.



Таким образом, наша цель — найти такую линейную функцию (прямую), которая, в некотором смысле, наилучшим образом описывала бы полученные результаты. Такую функцию назовём наилучшей линейной аппроксимацией (НЛА). Значения функции НЛА будем называть оценками или прогнозами и обозначим y hat sub i . Сама функция будет иметь вид y hat sub i =  b sub 1 + b sub 2 x sub i .

Каждому измерению входа x sub i будет соответствовать реальное значение y sub i и оценка y hat sub i . Разницу между реальным значением и оценкой будем называть отклонением или ошибкой прогноза и обозначим d sub i = y sub i - y hat sub i  = y sub i - (b sub 1 + b sub 2 x sub i ) = y sub i - b sub 1 - b sub 2 x sub i.



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

Выбор способа «подгонки»

Существует большое количество способов измерить общее отклонение реальных экспериментальных значений от их оценок. Приведём самые очевидные из них:

  1. сумма значений отклонений sum from i=1 to n d sub i
  2. сумма абсолютных значений отклонений sum from i=1 to n | d sub i |
  3. сумма квадратов отклонений sum from i=1 to n d sub i sup 2

Каждый из этих способов имеет как свои плюсы, так и свои минусы. В каком-то смысле, все они «плохие», поэтому наша задача выбрать наименее «плохой» из них: тот, чьи плюсы перевесят минусы. Для выбора рассмотрим их по отдельности.

Несомненным достоинством первого способа является его чрезвычайная простота. Однако такой способ небезопасен с точки зрения статистических выбросов. Если в наших данных есть два выброса, лежащие по разные стороны от прямой на примерно одном и том же расстоянии, то они погасят друг друга. Если таких выбросов будет много (при малых выборках бывает достаточно и двух), то это может дать нам прямую с неверным угловым коэффициентом b sub 2 .

Казалось бы, недостатки первого способа полностью снимаются вторым. Взятие абсолютного значения (модуля) должно обезопасить нас от проблем с взаимопогашающимися разносторонними выбросами. Однако и у этого способа есть существенные недостатки.

Забегая несколько вперед, скажем, что для получения коэффициентов НЛА мы воспользуемся математическим аппаратом дифференциального исчисления. Модуль же не является всюду дифференцируемой функций. И если это кажется не такой большой проблемой в нашем примере, то когда мы расширим МНК на случай многих независимых переменных, это может сделать вычислительную задачу чрезвычайно трудноразрешимой (а в момент, когда этот метод был открыт и просто практически неразрешимой). Кроме того, неприемлемость данного способа (бо́льшую приемлемость другого) доказал в своё время великий русский математик Андрей Андреевич Марков, чьи работы позволили использовать МНК в статистическом оценивании.

Третий способ, давший имя методу наименьших квадратов, позволяет избежать проблем, связанных с робастностью. Более сильные отклонения вносят бо́льшие вклады, а слабые отклонения нивелируются — взаимного погашения при этом возникнуть не может, т. к. квадрат числа неотрицателен. Вместе с этим, уходит и проблема, связанная с дифференцированием: квадратическая функция является всюду дифференцируемой. Этим, а также и другими причинами (в том числе и причинами, выявленными А. А. Марковым в связи с использованием МНК в статистическом оценивании), был обусловлен выбор способа.

Таким образом мы можем формализовать описанную нами задачу: необходимо наити такие значения коэффициентов b sub 1 и b sub 2, при которых функция Q = sum from i=1 to n d sub i sup 2 примет наименьшее значение.

Математическая формализация

roman argmin from {b sub 1 , ~ b sub 2} ~ Q = 
roman argmin from {b sub 1 , ~ b sub 2} ~ sum from i=1 to n d sub i sup 2 = 
roman argmin from {b sub 1 , ~ b sub 2} ~ sum from i=1 to n (y sub i - b sub 1 - b sub 2 x sub i ) sup 2

Необходимое условие минимума (условие первого порядка): left {
 lpile {
  {partial Q} over {partial b sub 1} = 0 ~ , above
  {partial Q} over {partial b sub 2} = 0
 }
right nothing
~ \\(ti ~
left {
 lpile {
  {partial sum from i=1 to n (y sub i - b sub 1 - b sub 2 x sub i ) sup 2} over {partial b sub 1} 
  = 0 ~ , above
  {partial sum from i=1 to n (y sub i - b sub 1 - b sub 2 x sub i ) sup 2} over {partial b sub 2} 
  = 0
 }
right nothing
~ \\(ti ~
left {
 lpile {
  {-2} sum from i=1 to n (y sub i - b sub 1 - b sub 2 x sub i ) = 0 ~ , above
  {-2} sum from i=1 to n (y sub i - b sub 1 - b sub 2 x sub i ) x sub i = 0 .
 }
right nothing

Обратите внимание: условие первого порядка — система дифференциальных уравнений в частных производных размерности два. Точка left ( b sub 1 , b sub 2 right ) , таким образом, — стационарная точка данной системы.

Разделив оба уравнения системы на -2 и перенеся отрицательные слагаемые в другие части уравнений, получим систему нормальных уравнений для МНК, из которой разными способами получим коэффициенты b sub 1 , b sub 2 : left {
 lpile {
  sum from i=1 to n y sub i = 
  b sub 1 n + b sub 2 sum from i=1 to n x sub i ~ , above
  sum from i=1 to n x sub i y sub i = 
  b sub 1 sum from i=1 to n x sub i + b sub 2 sum from i=1 to n x sub i sup 2 .
 }
right nothing

Далее мы будем получать значения коэффициентов в разных формах записи. Прежде всего, получим самую компактную форму записи, разделив оба уравнения на n : left {
 lpile {
  size -2 {{sum from i=1 to n y sub i} over n} = 
  b sub 1 + b sub 2 size -2 {{sum from i=1 to n x sub i} over n} ~ , above
  size -2 {{sum from i=1 to n x sub i y sub i} over n} = 
  b sub 1 size -2 {{sum from i=1 to n x sub i} over n} +
  b sub 2 size -2 {{sum from i=1 to n x sub i sup 2} over n}
 }
right nothing
~ \\(ti ~
left {
 lpile {
  y bar = b sub 1 + b sub 2 x bar ~ , above
  xy bar = b sub 1 x bar + b sub 2 {x sup size -2 2} bar ,
 }
right nothing

где x bar = size -2 {{sum from i=1 to n x sub i} over n} ~ , y bar = size -2 {{sum from i=1 to n y sub i} over n} ~ , xy = size -2 {{sum from i=1 to n x sub i y sub i} over n} ~ , {x sup size -2 2} bar = size -2 {{sum from i=1 to n x sub i sup 2} over n} — принятые в математической статистике обозначения средних: среднего арифметического элементов вектора bold x , среднего арифметического элементов вектора bold y , среднего значения поэлементого произведения векторов bold x , bold y , среднего квадратичного значения (среднего квадратов) элементов вектора bold x соответственно.

Для всех дальнеших рассуждений мы воспользуемся фактом, следующим из первого уравнения y bar = b sub 1 + b sub 2 x bar : наилучшая линейная аппроксимация проходит через центр масс наших экспериментальных данных.



Выразим из этого уравнения коэффициент b sub 1 = y bar -  b sub 2 x bar . Подставив во второе уравнение системы получим: lpile {
 xy bar = b sub 1 x bar + b sub 2 {x sup size -2 2} bar ~ , above
 xy bar = ( y bar -  b sub 2 x bar ) x bar + b sub 2 {x sup size -2 2} bar ~ , above
 xy bar = x bar y bar - b sub 2 {x bar} sup size -1 2 + b sub 2 {x sup size -2 2} bar ~ , above
 b sub 2 ({x sup size -2 2} bar - {x bar} sup size -1 2 ) = xy bar - x bar y bar ~ , above
 b sub 2 = {xy bar - x bar y bar} over {{x sup size -2 2} bar - {x bar} sup size -1 2}
}

В итоге получим коэффициенты: left {
 lpile {
  b sub 1 = y bar - b sub 2 x bar ~ , above
  b sub 2 = {xy bar - x bar y bar} over {{x sup size -2 2} bar - {x bar} sup size -1 2}
 }
right nothing

Приведём вторую форму вывода коэффициентов. Для этого подставим b sub 1 = y bar  - b sub 2 x bar подставим во второе уравнение системы нормальных уравнений для МНК: lpile {
 sum from i=1 to n x sub i y sub i = 
 b sub 1 sum from i=1 to n x sub i + b sub 2 sum from i=1 to n x sub i sup 2 ~ , above
 sum from i=1 to n x sub i y sub i = 
 ( y bar -  b sub 2 x bar ) sum from i=1 to n x sub i + 
 b sub 2 sum from i=1 to n x sub i sup 2 ~ , above
 sum from i=1 to n x sub i y sub i = 
 y bar sum from i=1 to n x sub i - 
 b sub 2 x bar sum from i=1 to n x sub i +
 b sub 2 sum from i=1 to n x sub i sup 2 ~ , above
 sum from i=1 to n x sub i y sub i - sum from i=1 to n x sub i y bar = 
 b sub 2 left ( sum from i=1 to n x sub i x bar - sum from i=1 to n x sub i sup 2 right ) ~ , above
 sum from i=1 to n (x sub i y sub i - x sub i y bar ) = 
 b sub 2 sum from i=1 to n ( x sub i x bar - x sub i sup 2
}

Необходимое условие минимума (условие первого порядка), вообще говоря, даёт нам точку, подозрительную на экстремум. Для того, чтобы математически строго доказать, что полученное решение — точка минимума функции Q, исследуем определённость матрицы вторых частных производных (также называемую матрицей Гессе или гессианом). Если матрица вторых частных производных будет положительно определена, то это гарантирует, что найденное решение даст минимум функции Q. В соответствии с критерием Сильвестра, матрица является положительно определённой, когда все ее угловые миноры положительны.

Достаточное условие максимума (условие второго порядка): left \[
 matrix {
  ccol{
   {partial Q} over {partial sup 2 b sub 1} 
   above 
   {partial Q} over {partial b sub 2 partial b sub 1}
  }
  ccol{
   {partial Q} over {partial b sub 1 partial b sub 2} 
   above 
   {partial Q} over {partial sup 2 b sub 2}
  }
 }
right \] =
left \[
 matrix {
  ccol{
   2n
   above 
   2 sum from i=1 to n x sub i
  }
  ccol{
   2 sum from i=1 to n x sub i 
   above 
   2 sum from i=1 to n x sub i sup 2 
  }
 }
right \] =
2 ~
left \[
 matrix {
  ccol{ 
   n
   above 
   sum from i=1 to n x sub i
  }
  ccol{
   sum from i=1 to n x sub i 
   above 
   sum from i=1 to n x sub i sup 2 ~ .
  }
 } 
right \]

Напомним, что roman det ( alpha A) = alpha roman det (A), поэтому можем рассматривать матрицу с вынесенной двойкой: умножение матрицы на положительное число не изменит знака её угловых миноров. Delta sub 1 = n > 0 ~ .

Значение первого углового минора (число наблюдений) будет положительным всегда. Delta sub 2 =
left |
 matrix {
  ccol{
   n
   above 
   sum from i=1 to n x sub i
  }
  ccol{
   sum from i=1 to n x sub i 
   above
   sum from i=1 to n x sub i sup 2 
  }
 }
right | = 
n sum from i=1 to n x sub i sup 2 - left ( sum from i=1 to n x sub i right ) sup 2 > 0 ~ .

Неотрицательность второго углового минора матрицы вторых частных производных функции Q следует из неравенство о средних (также называемого неравенством Коши, не путайте с неравенством Коши-Буняковского). lpile {
 sqrt {x sup size -2 2} bar >= x bar 
 above
 {x sup size -2 2} bar >= {x bar} sup size -1 2 
 above
 {sum from i=1 to n x sub i sup 2} over n 
 >= 
 left ( {sum from i=1 to n x sub i} right ) sup 2 over n sup 2 
 above
 n sum from i=1 to n x sub i sup 2 >= left ( sum from i=1 to n x sub i right ) sup 2 
 above
 n sum from i=1 to n x sub i sup 2 - left ( sum from i=1 to n x sub i right ) sup 2 >= 0
} ~ .

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

Матрица вторых частных производных, таким образом, по критерию Сильвестра явлется положительно определённой, что даёт нам основания утверждать, что полученное решение — точка минимума функции Q.

Множественный случай

Общая постановка задачи

Расширим наш эксперимент: по-прежнему было проведено n измерений, но замерялся не один вход, а m различных входов (выход по-прежнему один).

Результаты эксперимента могут быть компактно записаны с помощью матриц. Входы будут находиться в матрице X, а выходы — в векторе-столбце bold y. X =
left \[
 matrix {
  ccol {x sub 11 above x sub 21 above vdots above x sub i1 above vdots above x sub n1}
  ccol {x sub 12 above x sub 22 above vdots above x sub i2 above vdots above x sub n2}
  ccol {cdots above cdots above ddots above cdots above ddots above cdots}
  ccol {x sub 1j above x sub 2j above vdots above x sub ij above vdots above x sub nj}
  ccol {cdots above cdots above ddots above cdots above ddots above cdots}
  ccol {x sub 1m above x sub 2m above vdots above x sub im above vdots above x sub nm}
 }
right \]
~ , ~ 
bold y = 
left \[
 pile {y sub 1 above y sub 2 above vdots above y sub i above vdots above y sub n}
right \] 
~ .

По строкам матрицы X расположены результаты измерений, по столбцам — значения входов. Например, x sub 34 — значение 4-го входа в 3-ем измерении.

Мы по-прежнему хотим «подогнать» наши экспериментальные данные к линейной функции, но, в отличие от предыдущего случая это будет не прямая, а m-мерная плоскость (для m = 2 это будет обычная плоскость, для m > 2 — гиперплоскость). Вектор значений линейной функции назовём вектором оценкок и обозначим bold y back 40 roman \\\"^\\\" = X bold b ~ , где bold b — вектор-столбец коэффициентов линейной функции.

Проиллюстрируем случай m = 2 следующим примером. Представьте, что в комнате в разных местах на разной высоте висят воздушные шарики. Вы хотите растянуть в этой комнате несгибаемое полотно (из ткани, бумаги, картона) так, чтобы это полотно находилось ближе всего к шарикам. Высота шарика относительно пола будет являться выходом y sub i, координаты проекции шарика на пол — входами (x sub i1 , x sub i2 ), расстояние от проекции шарика на пол до полотна — оценкой y hat sub i, расстояние от шарика до полотна по линии проекции шарика на пол — отклонением d sub i.

Если мы предполагаем, что в нашей линейной функции имеется свободный член, то значения крайнего левого столбца матрицы X будут состоять только из единиц. Соответственно, b sub 1 и будет значением свободного члена.

Разницу между реальным значением и оценкой будем по-прежнему называть отклонением и обозначим bold d = bold y - bold y back 40 roman \\\"^\\\" = bold y - X bold b.

Сумма квадратов отклонений может быть получена как Q = bold d sup roman T bold d. Нам необходимо, найти такой вектор bold b, чтобы сумма квадратов отклонений была минимальна:

Математическая формализация

roman argmin from bold b ~  Q =
roman argmin from bold b ~ bold d sup roman T bold d = 
roman argmin from bold b ~ ( bold y - bold y back 40 roman \\\"^\\\" ) sup roman T 
( bold y - bold y back 40 roman \\\"^\\\" ) =
roman argmin from bold b ~ ( bold y - X bold b ) sup roman T ( bold y - X bold b )

Вспоминим некоторые базовые свойства операции транспонирования матриц, чтобы корректно раскрыть скобки и провести дифференцирование. Нам потребуются два следующих свойства:

  1. (A + B) sup roman T = A sup roman T + B sup roman T ~ ,
  2. (AB) sup roman T = B sup roman T A sup roman T.
В обоих случаях мы предполагаем, что операции над матрицами (сложение и умножение соответственно) возможны. Q = ( bold y - X bold b ) sup roman T ( bold y - X bold b ) =
bold y sup roman T bold y - bold y sup roman T X bold b - 
bold b sup roman T X sup roman T bold y + bold b sup roman T X sup roman T X bold b

Заметим два нетривиальных факта, в большинстве пособий, учебников и статей по МНК опускаемые как самоочевидные и простые (действительно, зачем объяснять, люди же могут начать понимать и задавать вопросы):

  1. Второе и третье слагаемое — это один и тот же математический объект с точностью до операции транспонирования:  ( bold y sup roman T X bold b ) sup roman T  = bold b sup roman T X sup roman T bold y . Мы воспользовались вторым из указанных свойств операции транспонирования матриц для подтверждения этого факта.
  2. Оба этих математических объекта (второе и третье слагаемое) являются скалярами (любой скаляр же по определению — это матрица размерности 1 times 1). Это нетрудно проверить просто по размерностям векторов и матриц, включаемых в оба этих объекта.

Исходя из этих двух фактов можно смело утверждать, что bold y sup roman T X bold b = bold b sup roman T X sup roman T bold y , что позволяет упростить выражение Q = bold y sup roman T bold y - 2 bold b sup roman T X sup roman T bold y + bold b sup roman T X sup roman T X bold b .

Как и в случае с парным случаем, мы воспользуемся аппаратом дифференциального исчисления, взяв производную по вектору bold b и приравняв её к нулю: lpile {
 size -2 {{partial Q} over {partial bold b}} = 
 size -2 {{partial ( bold y sup roman T bold y - 2 bold b sup roman T X sup roman T bold y + 
 bold b sup roman T X sup roman T X bold b )} over {partial bold b}} = 
 -2 X sup roman T bold y + 2 X sup roman T X bold b = 0 ~ , above
 X sup roman T X bold b = X sup roman T bold y ~ , above
 bold b = (X sup roman T X) sup -1 X sup roman T bold y
}

Покажем, что условие первого порядке даёт нам минимум функции. Для этого докажем, что матрица вторых производных будет положительно определена: size -2 {{partial Q} over {partial sup 2 bold b}} = 
size -2 {{partial} over {partial bold b} cdot {partial Q} over {partial bold b}} = 
size -2 {{partial left ( -2 X sup roman T bold y + 2 X sup roman T X bold b right ) } 
over {partial bold b}} =
2 X sup roman T X  = 0

Напомним ещё один факт из линейной алгебры. Если некоторая матрица A положительно определена, то это в том числе означает, что для любого ненулевого вектора bold z подходящей размерности будет выполнятся следующее: bold z sup roman T A bold z > 0 ~ .

Пусть наша матрица разложима в виде A = B sup roman T B ~ , тогда она будет положительно определена: bold z sup roman T A bold z = 
bold z sup roman T B sup roman T B bold z = 
(B bold z) sup roman T B bold z = 
bold u sup roman T bold u.

Произведение bold u sup roman T bold u — сумма квадратов значений вектора u, которая будет неотрицательна всегда, а равно нулю, только если матрица B — нулевая матрица.

Вернёмся к нашему примеру: size -2 {{partial Q} over {partial sup 2 bold b}} = 2 X sup roman T X — умножение на скаляр не изменит определённости матрицы, а в силу рассуждений, приведённых выше, мы можем смело утверждать, что матрица вторых производных положительно определена, значит, найденное нами решение — точка минимума функции Q .

Список литературы

  1. Марков, А. А. Исчисление вероятностей, изд. 4 / Андрей Андреевич Марков. — ГИЗ, 1924.
  2. Марков, А. А. Закон больших чисел и метод наименьших квадратов (1898) Избр. труды / Андрей Андреевич Марков. — Изд. АН СССР, 1951. — C. 233—251.
  3. Линник, Ю. В. Метод наименьших квадратов и основы математико-статистической теории обработки наблюдений / Юрий Владимирович Линник. — М. : ФизМатГИЗ, 1962. — C. 10—16. — http://books.e-herit....
  4. Доугерти, К. Введение в эконометрику / Кристофер Доугерти. — М. : Инфра-М, 1999. — C. 53—58.
  5. Angrist, J. D. Mostly Harmless Econometrics: An Empiricist's Companion / Joshua D. Angrist, Jörn-Steffen Pischke. — Princeton University Press, 2009. — pp. 21—38. — http://egei.vse.cz/e....
  6. Атрашкевич, А. А. Занимательная эконометрика для дошкольников / Андрей Анатольевич Атрашкевич, Григорий Александрович Ситкарев. — Сыктывкар : Издательство Лаборатории прикладной математики и программирования, 2015. — 65 c.

Примечания

¹) В случае, если МНК используется для обработки социально-экономических данных, вместо «измерение» говорят «наблюдение», вместо «опыт» — «статистическое наблюдение».


КатегорияПрикладнаяМатематика | КатегорияМетодНаименьшихКвадратов