import numpy as np import matplotlib.pyplot as plt ############################### #Datos originales ############################### X = 2 * np.random.rand(100, 1) y = 4 + 3 * X + np.random.randn(100,1) plt.plot(X,y,".") ############################### X_b = np.c_[np.ones((100,1)), X] #Se agrega x0=1 para cada instancia eta = 0.1 #Pasos n_itera = 1000 m=100 theta = np.random.randn(2,1) #Inicialización aleatoria for iteracion in range (n_itera): gradiente = 2/m * X_b.T.dot(X_b.dot(theta)-y) theta = theta - eta * gradiente print(theta)