Hai dev,
Perceptron ialah salah satu konsep yang paling mudah dan paling asas dalam pembelajaran mesin. Ia adalah pengelas linear binari yang membentuk asas rangkaian saraf. Dalam siaran ini, saya akan melalui langkah-langkah untuk memahami dan melaksanakan Perceptron dari awal dalam Python.
Jom selami!
Apakah Perceptron?
A Perceptron ialah algoritma asas untuk pembelajaran penyeliaan pengelas binari. Memandangkan ciri input, Perceptron mempelajari pemberat yang membantu memisahkan kelas berdasarkan fungsi ambang mudah. Begini cara ia berfungsi secara ringkas:
- Input: Vektor ciri (cth., [x1, x2]).
- Berat: Setiap ciri input mempunyai berat, yang model laraskan berdasarkan prestasi model.
- Fungsi Pengaktifan: Mengira jumlah wajaran ciri input dan menggunakan ambang untuk memutuskan sama ada hasilnya tergolong dalam satu kelas atau kelas yang lain.
Secara matematik, ia kelihatan seperti ini:
f(x) = w1*x1 w2*x2 ... wn*xn b
Di mana:
- f(x) ialah output,
- w mewakili pemberat,
- x mewakili ciri input dan
- b ialah istilah berat sebelah.
Jika f(x) lebih besar daripada atau sama dengan ambang, output ialah kelas 1; jika tidak, ia adalah kelas 0.
Langkah 1: Import Perpustakaan
Kami hanya akan menggunakan NumPy di sini untuk operasi matriks bagi memastikan perkara itu ringan.
import numpy as np
Langkah 2: Tentukan Kelas Perceptron
Kami akan membina Perceptron sebagai kelas untuk memastikan semuanya teratur. Kelas akan merangkumi kaedah untuk latihan dan ramalan.
class Perceptron: def __init__(self, learning_rate=0.01, epochs=1000): self.learning_rate = learning_rate self.epochs = epochs self.weights = None self.bias = None def fit(self, X, y): # Number of samples and features n_samples, n_features = X.shape # Initialize weights and bias self.weights = np.zeros(n_features) self.bias = 0 # Training for _ in range(self.epochs): for idx, x_i in enumerate(X): # Calculate linear output linear_output = np.dot(x_i, self.weights) + self.bias # Apply step function y_predicted = self._step_function(linear_output) # Update weights and bias if there is a misclassification if y[idx] != y_predicted: update = self.learning_rate * (y[idx] - y_predicted) self.weights += update * x_i self.bias += update def predict(self, X): # Calculate linear output and apply step function linear_output = np.dot(X, self.weights) + self.bias y_predicted = self._step_function(linear_output) return y_predicted def _step_function(self, x): return np.where(x >= 0, 1, 0)
Dalam kod di atas:
- fit: Kaedah ini melatih model dengan melaraskan berat dan berat sebelah apabila ia salah mengelaskan sesuatu mata.
- ramal: Kaedah ini mengira ramalan pada data baharu.
- _step_function: Fungsi ini menggunakan ambang untuk menentukan kelas output.
Langkah 3: Sediakan Set Data Mudah
Kami akan menggunakan set data kecil untuk memudahkan anda memvisualisasikan output. Berikut ialah set data get AND yang mudah:
# AND gate dataset X = np.array([[0, 0], [0, 1], [1, 0], [1, 1]]) y = np.array([0, 0, 0, 1]) # Labels for AND gate
Langkah 4: Latih dan Uji Perceptron
Sekarang, mari kita latih Perceptron dan uji ramalannya.
# Initialize Perceptron p = Perceptron(learning_rate=0.1, epochs=10) # Train the model p.fit(X, y) # Test the model print("Predictions:", p.predict(X))
Output yang dijangkakan untuk get AND:
import numpy as np
Penjelasan Proses Pembelajaran Perceptron
- Memulakan Berat dan Berat sebelah: Pada permulaan, pemberat ditetapkan kepada sifar, yang membolehkan model mula belajar dari awal.
- Kira Output Linear: Untuk setiap titik data, Perceptron mengira jumlah wajaran input ditambah pincang.
- Pengaktifan (Fungsi Langkah): Jika output linear lebih besar daripada atau sama dengan sifar, ia memberikan kelas 1; jika tidak, ia memberikan kelas 0.
- Peraturan Kemas Kini: Jika ramalan tidak betul, model melaraskan berat dan berat sebelah ke arah yang mengurangkan ralat. Peraturan kemas kini diberikan oleh: berat = kadar_pembelajaran * (y_benar - y_pred) * x
Ini menjadikan kemas kini Perceptron hanya untuk mata tersalah klasifikasi, secara beransur-ansur menolak model lebih dekat kepada sempadan keputusan yang betul.
Menggambarkan Sempadan Keputusan
Visualkan sempadan keputusan selepas latihan. Ini amat membantu jika anda menggunakan set data yang lebih kompleks. Buat masa ini, kami akan memastikan perkara mudah dengan get AND.
Melanjutkan kepada Multi-Layer Perceptrons (MLPs)
Walaupun Perceptron terhad kepada masalah yang boleh dipisahkan secara linear, ia merupakan asas kepada rangkaian saraf yang lebih kompleks seperti Multi-Layer Perceptrons (MLP). Dengan MLP, kami menambah lapisan tersembunyi dan fungsi pengaktifan (seperti ReLU atau Sigmoid) untuk menyelesaikan masalah bukan linear.
Ringkasan
Perceptron ialah algoritma pembelajaran mesin yang mudah tetapi asas. Dengan memahami cara ia berfungsi dan melaksanakannya dari awal, kami mendapat cerapan tentang asas pembelajaran mesin dan rangkaian saraf. Keindahan Perceptron terletak pada kesederhanaannya, menjadikannya titik permulaan yang sempurna untuk sesiapa yang berminat dengan AI.
Atas ialah kandungan terperinci Melaksanakan Perceptron dari Scratch dalam Python. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Tutorial ini menunjukkan cara menggunakan Python untuk memproses konsep statistik undang -undang ZIPF dan menunjukkan kecekapan membaca dan menyusun fail teks besar Python semasa memproses undang -undang. Anda mungkin tertanya -tanya apa maksud pengedaran ZIPF istilah. Untuk memahami istilah ini, kita perlu menentukan undang -undang Zipf. Jangan risau, saya akan cuba memudahkan arahan. Undang -undang Zipf Undang -undang Zipf hanya bermaksud: Dalam korpus bahasa semulajadi yang besar, kata -kata yang paling kerap berlaku muncul kira -kira dua kali lebih kerap sebagai kata -kata kerap kedua, tiga kali sebagai kata -kata kerap ketiga, empat kali sebagai kata -kata kerap keempat, dan sebagainya. Mari kita lihat contoh. Jika anda melihat corpus coklat dalam bahasa Inggeris Amerika, anda akan melihat bahawa perkataan yang paling kerap adalah "th

Artikel ini menerangkan cara menggunakan sup yang indah, perpustakaan python, untuk menghuraikan html. Ia memperincikan kaedah biasa seperti mencari (), find_all (), pilih (), dan get_text () untuk pengekstrakan data, pengendalian struktur dan kesilapan HTML yang pelbagai, dan alternatif (sel

Berurusan dengan imej yang bising adalah masalah biasa, terutamanya dengan telefon bimbit atau foto kamera resolusi rendah. Tutorial ini meneroka teknik penapisan imej di Python menggunakan OpenCV untuk menangani isu ini. Penapisan Imej: Alat yang berkuasa Penapis Imej

Python, kegemaran sains dan pemprosesan data, menawarkan ekosistem yang kaya untuk pengkomputeran berprestasi tinggi. Walau bagaimanapun, pengaturcaraan selari dalam Python memberikan cabaran yang unik. Tutorial ini meneroka cabaran -cabaran ini, memberi tumpuan kepada Interprete Global

Artikel ini membandingkan tensorflow dan pytorch untuk pembelajaran mendalam. Ia memperincikan langkah -langkah yang terlibat: penyediaan data, bangunan model, latihan, penilaian, dan penempatan. Perbezaan utama antara rangka kerja, terutamanya mengenai grap pengiraan

Tutorial ini menunjukkan mewujudkan struktur data saluran paip tersuai di Python 3, memanfaatkan kelas dan pengendali yang berlebihan untuk fungsi yang dipertingkatkan. Fleksibiliti saluran paip terletak pada keupayaannya untuk menggunakan siri fungsi ke set data, GE

Serialization dan deserialization objek Python adalah aspek utama dari mana-mana program bukan remeh. Jika anda menyimpan sesuatu ke fail python, anda melakukan siri objek dan deserialization jika anda membaca fail konfigurasi, atau jika anda menjawab permintaan HTTP. Dalam erti kata, siri dan deserialization adalah perkara yang paling membosankan di dunia. Siapa yang peduli dengan semua format dan protokol ini? Anda mahu berterusan atau mengalirkan beberapa objek python dan mengambilnya sepenuhnya pada masa yang akan datang. Ini adalah cara yang baik untuk melihat dunia pada tahap konseptual. Walau bagaimanapun, pada tahap praktikal, skim siri, format atau protokol yang anda pilih boleh menentukan kelajuan, keselamatan, kebebasan status penyelenggaraan, dan aspek lain dari program

Modul Statistik Python menyediakan keupayaan analisis statistik data yang kuat untuk membantu kami dengan cepat memahami ciri -ciri keseluruhan data, seperti biostatistik dan analisis perniagaan. Daripada melihat titik data satu demi satu, cuma melihat statistik seperti min atau varians untuk menemui trend dan ciri dalam data asal yang mungkin diabaikan, dan membandingkan dataset besar dengan lebih mudah dan berkesan. Tutorial ini akan menjelaskan cara mengira min dan mengukur tahap penyebaran dataset. Kecuali dinyatakan sebaliknya, semua fungsi dalam modul ini menyokong pengiraan fungsi min () dan bukan hanya menjumlahkan purata. Nombor titik terapung juga boleh digunakan. Import secara rawak Statistik import dari fracti


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa
