我在循環函數中存在循環結果問題。它只在循環內計數一次,爲第一個原始數據選擇最佳解決方案,然後停止。在R中的另一個循環內部循環
我想記住矩陣zmienne
的每一行的最佳解決方案。我究竟做錯了什麼?
schaffer <- function(xx)
{x1 <- xx[1]
x2 <- xx[2]
fact1 <- (sin(x1^2-x2^2))^2 - 0.5
fact2 <- (1 + 0.001*(x1^2+x2^2))^2
y <- 0.5 + fact1/fact2
return(y)
}
gradient_descent <- function(func, step, niter) {
N <- 3 #N- number of random points
zmienne <- matrix(runif(N*2, min = -100, max = 100), N, 2)
print(zmienne)
h = 0.001;
iter_count = 0;
for (i in 1:N) {
x_0 <- zmienne[i,]
x_n = x_0;
for (j in 1:niter) {
func_grad = (func(x_n+h) - func(x_n))/h;
if (abs(func_grad) < 0.0001) { break; }
x_n = x_n - step * func_grad;
print(x_n)
iter_count = iter_count + 1
}
}
return(list(iterations = niter, best_value = func_grad, best_state = x_n, x0=x_0))
}
solution_m1 <- gradient_descent(schaffer, 0.1, 20)
solution_m1
能否請您提供您的數據(或子集)本身,我們可以測試輸出? – Molx 2015-03-24 22:01:58
考慮在第一個循環外面用'NA'分配'iterations','best_value','best_state'和'x0',並將最佳結果添加到每行的這些變量中。然後在外循環之外返回一個由'iterations','best_value','best_state'和'x0'組成的列表。 – ConfusedMan 2015-03-24 22:10:32
你能否通過在代碼中添加你的建議來解釋我的修改?我應該添加返回後關閉內循環,然後關閉主循環後? – user3463225 2015-03-24 22:13:32