Задачі класифікації з нелінійними межами не можуть бути вирішені простим перцептроном . Наступний код R має ілюстративні цілі та заснований на цьому прикладі в Python):
nonlin <- function(x, deriv = F) {
if (deriv) x*(1-x)
else 1/(1+exp(-x))
}
X <- matrix(c(-3,1,
-2,1,
-1,1,
0,1,
1,1,
2,1,
3,1), ncol=2, byrow=T)
y <- c(0,0,1,1,1,0,0)
syn0 <- runif(2,-1,1)
for (iter in 1:100000) {
l1 <- nonlin(X %*% syn0)
l1_error <- y - l1
l1_delta <- l1_error * nonlin(l1,T)
syn0 <- syn0 + t(X) %*% l1_delta
}
print("Output After Training:")
## [1] "Output After Training:"
round(l1,3)
## [,1]
## [1,] 0.488
## [2,] 0.468
## [3,] 0.449
## [4,] 0.429
## [5,] 0.410
## [6,] 0.391
## [7,] 0.373
Тепер ідея ядра та так званого трюку ядра полягає в проектуванні вхідного простору у простір більш високого розміру, як-от так ( джерела зображень ):
Моє запитання
Як я можу використати трюк ядра (наприклад, з простим квадратичним ядром), щоб отримати рецептор ядра , який здатний вирішити задану класифікаційну задачу? Зверніть увагу: це, головним чином, концептуальне питання, але якщо ви також можете надати необхідну модифікацію коду, це було б чудово
Що я намагався до цього часу,
я спробував наступне, що працює добре, але я думаю, що це не реальна угода, тому що обчислювально стає занадто дорогим для складніших проблем ("фокус" за "трюком ядра" - це не просто ідея саме ядро, але вам не доведеться обчислювати проекцію для всіх примірників):
X <- matrix(c(-3,9,1,
-2,4,1,
-1,1,1,
0,0,1,
1,1,1,
2,4,1,
3,9,1), ncol=3, byrow=T)
y <- c(0,0,1,1,1,0,0)
syn0 <- runif(3,-1,1)
Повне розкриття
Я поставив це питання тиждень тому на SO, але це не приділяло особливої уваги. Я підозрюю, що тут краще місце, тому що це більше концептуальне питання, ніж питання програмування.