def test_rff_feature_map_derivative2_d(): X = np.array([[1.]]) u = np.array([2.]) omega = np.array([[2.]]) d = 0 phi_derivative2 = rff_feature_map_grad2_d(X, omega, u, d) phi_derivative2_manual = -rff_feature_map(X, omega, u) * (omega[:, d] ** 2) assert_close(phi_derivative2, phi_derivative2_manual)
def test_rff_feature_map_derivative2_d(): X = np.array([[1.]]) u = np.array([2.]) omega = np.array([[2.]]) d = 0 phi_derivative2 = rff_feature_map_grad2_d(X, omega, u, d) phi_derivative2_manual = -rff_feature_map(X, omega, u) * (omega[:, d]**2) assert_close(phi_derivative2, phi_derivative2_manual)
def test_compute_b_storage_1d2n(): X = np.array([[1.], [2.]]) u = np.array([2.]) omega = np.array([[2.]]) d = 0 b_manual = -np.mean(rff_feature_map_grad2_d(X, omega, u, d)) b = compute_b_memory(X, omega, u) assert_allclose(b_manual, b)
def test_rff_feature_map_derivatives2_loop_equals_map_derivative2_d(): N = 10 D = 20 m = 3 X = np.random.randn(N, D) omega = np.random.randn(D, m) u = np.random.uniform(0, 2 * np.pi, m) derivatives = rff_feature_map_grad2_loop(X, omega, u) for d in range(D): derivative = rff_feature_map_grad2_d(X, omega, u, d) assert_allclose(derivatives[d], derivative)
def test_rff_feature_map_derivatives2_loop_equals_map_derivative2_d(): N = 10 D = 20 m = 3 X = np.random.randn(N, D) omega = np.random.randn(D, m) u = np.random.uniform(0, 2 * np.pi, m) derivatives = rff_feature_map_grad2_loop(X, omega, u) for d in range(D): derivative = rff_feature_map_grad2_d(X, omega, u, d) assert_allclose(derivatives[d], derivative)
def test_objective_sym_equals_completely_manual_manually(): N = 100 D = 3 m = 3 omega = np.random.randn(D, m) u = np.random.uniform(0, 2 * np.pi, m) X = np.random.randn(N, D) theta = np.random.randn(m) J_manual = 0. for n in range(N): b_manual = np.zeros(m) C_manual = np.zeros((m, m)) J_n_manual = 0. for d in range(D): b_term_manual = -np.sqrt(2. / m) * np.cos(np.dot(X[n], omega) + u) * (omega[d, :]**2) b_term = rff_feature_map_grad2_d(X[n], omega, u, d) assert_allclose(b_term_manual, b_term) b_manual -= b_term_manual J_manual += np.dot(b_term_manual, theta) J_n_manual += np.dot(b_term_manual, theta) c_vec_manual = -np.sqrt(2. / m) * np.sin(np.dot(X[n], omega) + u) * omega[d, :] c_vec = rff_feature_map_grad_d(X[n], omega, u, d) assert_allclose(c_vec_manual, c_vec) C_term = np.outer(c_vec_manual, c_vec_manual) C_manual += C_term # not regularised here, done afterwards J_manual += 0.5 * np.dot(theta, np.dot(C_term, theta)) J_n_manual += 0.5 * np.dot(theta, np.dot(C_term, theta)) b = compute_b_memory(X[n].reshape(1, m), omega, u) C = compute_C_memory(X[n].reshape(1, m), omega, u) assert_allclose(b_manual, b) assert_allclose(C_manual, C) # discard regularisation for these internal checks J_n = objective(X[n].reshape(1, m), theta, omega, u) J_n_2 = 0.5 * np.dot(theta, np.dot(C, theta)) - np.dot(theta, b) assert_allclose(J_n_2, J_n, rtol=1e-4) assert_allclose(J_n_manual, J_n, rtol=1e-4) J_manual /= N J = objective(X, theta, omega, u) assert_close(J, J_manual, decimal=5)
def _objective_sym_half_manual(X, theta, omega, u): N = X.shape[0] D = X.shape[1] J_manual = 0. for n in range(N): for d in range(D): b_term = -rff_feature_map_grad2_d(X[n], omega, u, d) J_manual -= np.dot(b_term, theta) c_vec = rff_feature_map_grad_d(X[n], omega, u, d) C_term_manual = np.outer(c_vec, c_vec) J_manual += 0.5 * np.dot(theta, np.dot(C_term_manual, theta)) J_manual /= N return J_manual
def _objective_sym_half_manual(X, theta, omega, u): N = X.shape[0] D = X.shape[1] J_manual = 0. for n in range(N): for d in range(D): b_term = -rff_feature_map_grad2_d(X[n], omega, u, d) J_manual -= np.dot(b_term, theta) c_vec = rff_feature_map_grad_d(X[n], omega, u, d) C_term_manual = np.outer(c_vec, c_vec) J_manual += 0.5 * np.dot(theta, np.dot(C_term_manual, theta)) J_manual /= N return J_manual