Искусственная нейронная сеть - сети Хопфилда

Нейронная сеть Хопфилда была изобретена доктором Джоном Дж. Хопфилдом в 1982 году. Она состоит из одного слоя, который содержит один или несколько полностью связанных рекуррентных нейронов. Сеть Хопфилда обычно используется для задач автоматической ассоциации и оптимизации.

Дискретная сеть Хопфилда

Сеть Хопфилда, которая работает в режиме дискретных линий, или, другими словами, можно сказать, что шаблоны ввода и вывода являются дискретными векторными, которые могут быть либо двоичными (0,1), либо биполярными (+1, -1) по своей природе. Сеть имеет симметричные веса без самоподключений, т. Е.wij = wji и wii = 0.

Архитектура

Ниже приведены некоторые важные моменты, о которых следует помнить о дискретной сети Хопфилда.

  • Эта модель состоит из нейронов с одним инвертирующим и одним неинвертирующим выходом.

  • Выход каждого нейрона должен быть входом других нейронов, но не входом собственной личности.

  • Вес / прочность соединения выражается как wij.

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

  • Гири должны быть симметричными, т.е. wij = wji

Выход из Y1 собирается Y2, Yi и Yn иметь вес w12, w1i и w1nсоответственно. Точно так же на других дугах есть веса.

Алгоритм обучения

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

Case 1 - Шаблоны двоичного ввода

Для набора бинарных паттернов s(p), p = 1 to P

Вот, s(p) = s1(p), s2(p),..., si(p),..., sn(p)

Матрица веса определяется выражением

$$ w_ {ij} \: = \: \ sum_ {p = 1} ^ P [2s_ {i} (p) - \: 1] [2s_ {j} (p) - \: 1] \: \: \: \: \: для \: i \: \ neq \: j $$

Case 2 - Биполярные входные шаблоны

Для набора бинарных паттернов s(p), p = 1 to P

Вот, s(p) = s1(p), s2(p),..., si(p),..., sn(p)

Матрица веса определяется выражением

$$ w_ {ij} \: = \: \ sum_ {p = 1} ^ P [s_ {i} (p)] [s_ {j} (p)] \: \: \: \: \: для \ : i \: \ neq \: j $$

Алгоритм тестирования

Step 1 - Инициализировать веса, полученные из алгоритма обучения с использованием принципа Хеббиана.

Step 2 - Выполните шаги 3–9, если активации сети не консолидированы.

Step 3 - Для каждого входного вектора X, выполните шаги 4-8.

Step 4 - Сделайте начальную активацию сети равной внешнему входному вектору X следующим образом -

$$ y_ {i} \: = \: x_ {i} \: \: \: for \: i \: = \: 1 \: to \: n $$

Step 5 - Для каждого блока Yi, выполните шаги 6–9.

Step 6 - Рассчитайте чистый ввод сети следующим образом -

$$ y_ {ini} \: = \: x_ {i} \: + \: \ displaystyle \ sum \ limits_ {j} y_ {j} w_ {ji} $$

Step 7 - Для расчета выхода примените активацию к входу сети следующим образом:

$$ y_ {i} \: = \ begin {cases} 1 & if \: y_ {ini} \:> \: \ theta_ {i} \\ y_ {i} & if \: y_ {ini} \: = \: \ theta_ {i} \\ 0 & if \: y_ {ini} \: <\: \ theta_ {i} \ end {cases} $$

Здесь $ \ theta_ {i} $ - порог.

Step 8 - Транслировать этот вывод yi ко всем остальным единицам.

Step 9 - Протестируйте сеть на предмет соединения.

Оценка энергетической функции

Энергетическая функция определяется как функция, которая является связанной и невозрастающей функцией состояния системы.

Энергетическая функция Ef⁡, ⁡ также называется Lyapunov function определяет устойчивость дискретной сети Хопфилда и характеризуется следующим образом:

$$ E_ {F} \: = \: - \ frac {1} {2} \ displaystyle \ sum \ limits_ {i = 1} ^ n \ displaystyle \ sum \ limits_ {j = 1} ^ n y_ {i} y_ {j} w_ {ij} \: - \: \ displaystyle \ sum \ limits_ {i = 1} ^ n x_ {i} y_ {i} \: + \: \ displaystyle \ sum \ limits_ {i = 1} ^ n \ theta_ {i} y_ {i} $$

Condition - В стабильной сети всякий раз, когда состояние узла изменяется, указанная выше функция энергии будет уменьшаться.

Предположим, когда узел i изменил состояние с $ y_i ^ {(k)} $ на $ y_i ^ {(k \: + \: 1)} $ ⁡ тогда изменение энергии $ \ Delta E_ {f} $ определяется следующим соотношением

$$ \ Delta E_ {f} \: = \: E_ {f} (y_i ^ {(k + 1)}) \: - \: E_ {f} (y_i ^ {(k)}) $$

$$ = \: - \ left (\ begin {array} {c} \ displaystyle \ sum \ limits_ {j = 1} ^ n w_ {ij} y_i ^ {(k)} \: + \: x_ {i} \: - \: \ theta_ {i} \ end {array} \ right) (y_i ^ {(k + 1)} \: - \: y_i ^ {(k)}) $$

$$ = \: - \ :( net_ {i}) \ Delta y_ {i} $$

Здесь $ \ Delta y_ {i} \: = \: y_i ^ {(k \: + \: 1)} \: - \: y_i ^ {(k)} $

Изменение энергии зависит от того факта, что только один блок может обновлять свою активацию за раз.

Непрерывная сеть Хопфилда

По сравнению с дискретной сетью Хопфилда, непрерывная сеть имеет время как непрерывную переменную. Он также используется в автоматических ассоциациях и задачах оптимизации, таких как задача коммивояжера.

Model - Модель или архитектуру можно построить путем добавления электрических компонентов, таких как усилители, которые могут отображать входное напряжение с выходным напряжением с помощью функции активации сигмоида.

Оценка энергетической функции

$$ E_f = \ frac {1} {2} \ displaystyle \ sum \ limits_ {i = 1} ^ n \ sum _ {\ substack {j = 1 \\ j \ ne i}} ^ n y_i y_j w_ {ij} - \ displaystyle \ sum \ limits_ {i = 1} ^ n x_i y_i + \ frac {1} {\ lambda} \ displaystyle \ sum \ limits_ {i = 1} ^ n \ sum _ {\ substack {j = 1 \\ j \ ne i}} ^ n w_ {ij} g_ {ri} \ int_ {0} ^ {y_i} a ^ {- 1} (y) dy $$

Вот λ параметр усиления и gri входная проводимость.