TensorFlow - Regresi Linier

Dalam bab ini, kita akan fokus pada contoh dasar penerapan regresi linier menggunakan TensorFlow. Regresi logistik atau regresi linier adalah pendekatan pembelajaran mesin yang diawasi untuk klasifikasi kategori pesanan berlainan. Tujuan kami dalam bab ini adalah untuk membangun model yang dapat digunakan pengguna untuk memprediksi hubungan antara variabel prediktor dan satu atau lebih variabel independen.

Hubungan antara kedua variabel ini dianggap linier. Jika y adalah variabel dependen dan x dianggap sebagai variabel independen, maka hubungan regresi linier kedua variabel akan terlihat seperti persamaan berikut -

Y = Ax+b

Kami akan merancang algoritma untuk regresi linier. Ini akan memungkinkan kita untuk memahami dua konsep penting berikut -

  • Fungsi Biaya
  • Algoritme penurunan gradien

Representasi skematis dari regresi linier disebutkan di bawah ini -

Tampilan grafis dari persamaan regresi linier disebutkan di bawah ini -

Langkah-langkah merancang algoritma untuk regresi linier

Sekarang kita akan mempelajari tentang langkah-langkah yang membantu dalam merancang algoritma untuk regresi linier.

Langkah 1

Penting untuk mengimpor modul yang diperlukan untuk merencanakan modul regresi linier. Kami mulai mengimpor pustaka Python NumPy dan Matplotlib.

import numpy as np 
import matplotlib.pyplot as plt

Langkah 2

Tentukan jumlah koefisien yang diperlukan untuk regresi logistik.

number_of_points = 500 
x_point = [] 
y_point = [] 
a = 0.22 
b = 0.78

LANGKAH 3

Iterasi variabel untuk menghasilkan 300 titik acak di sekitar persamaan regresi -

Y = 0,22x + 0,78

for i in range(number_of_points): 
   x = np.random.normal(0.0,0.5) 
   y = a*x + b +np.random.normal(0.0,0.1) x_point.append([x]) 
   y_point.append([y])

LANGKAH 4

Lihat poin yang dihasilkan menggunakan Matplotlib.

fplt.plot(x_point,y_point, 'o', label = 'Input Data') plt.legend() plt.show()

Kode lengkap untuk regresi logistik adalah sebagai berikut -

import numpy as np 
import matplotlib.pyplot as plt 

number_of_points = 500 
x_point = [] 
y_point = [] 
a = 0.22 
b = 0.78 

for i in range(number_of_points): 
   x = np.random.normal(0.0,0.5) 
   y = a*x + b +np.random.normal(0.0,0.1) x_point.append([x]) 
   y_point.append([y]) 
   
plt.plot(x_point,y_point, 'o', label = 'Input Data') plt.legend() 
plt.show()

Jumlah titik yang diambil sebagai masukan dianggap sebagai data masukan.