国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

ホームページ バックエンド開(kāi)発 Python チュートリアル Python でパーセプトロンを最初から実裝する

Python でパーセプトロンを最初から実裝する

Oct 30, 2024 pm 10:11 PM

Implementing a Perceptron from Scratch in Python

開(kāi)発者の皆さん、

パーセプトロンは、機(jī)械學(xué)習(xí)における最も単純かつ最も基本的な概念の 1 つです。これは、ニューラル ネットワークの基礎(chǔ)を形成するバイナリ線形分類器です。この投稿では、Python でパーセプトロンを最初から理解して実裝する手順を説明します。

飛び込んでみましょう!


パーセプトロンとは何ですか?

パーセプトロン は、バイナリ分類器の教師あり學(xué)習(xí)のための基本的なアルゴリズムです。入力特徴が與えられると、パーセプトロンは単純なしきい値関數(shù)に基づいてクラスを分離するのに役立つ重みを?qū)W習(xí)します。簡(jiǎn)単に説明すると、次のようになります:

  1. 入力: 特徴のベクトル (例: [x1, x2])。
  2. 重み: 各入力特徴量には重みがあり、モデルはモデルのパフォーマンスに基づいて重みを調(diào)整します。
  3. アクティベーション関數(shù): 入力特徴の加重合計(jì)を計(jì)算し、しきい値を適用して、結(jié)果がいずれかのクラスに屬するかを決定します。

數(shù)學(xué)的には次のようになります:

f(x) = w1*x1 w2*x2 ... wn*xn b

場(chǎng)所:

  • f(x) は出力です。
  • w は重みを表し、
  • x は入力特徴を表し、
  • b はバイアス項(xiàng)です。

f(x) がしきい値以上の場(chǎng)合、出力はクラス 1 です。それ以外の場(chǎng)合はクラス 0 です。


ステップ 1: ライブラリをインポートする

処理を軽量化するために、ここでは行列演算に NumPy のみを使用します。

import numpy as np

ステップ 2: パーセプトロン クラスを定義する

すべてを整理するために、パーセプトロンをクラスとして構(gòu)築します。このクラスには、トレーニングと予測(cè)のメソッドが含まれます。

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)

上記のコード內(nèi):

  • fit: このメソッドは、點(diǎn)を誤って分類するたびに重みとバイアスを調(diào)整してモデルをトレーニングします。
  • 予測(cè): このメソッドは新しいデータの予測(cè)を計(jì)算します。
  • _step_function: この関數(shù)は、しきい値を適用して出力クラスを決定します。

ステップ 3: 単純なデータセットを準(zhǔn)備する

出力を簡(jiǎn)単に視覚化できるように、小さなデータセットを使用します。これは単純な AND ゲート データセットです:

# 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

ステップ 4: パーセプトロンのトレーニングとテスト

それでは、パーセプトロンをトレーニングして、その予測(cè)をテストしてみましょう。

# 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))

AND ゲートの期待される出力:

import numpy as np

パーセプトロン學(xué)習(xí)プロセスの説明

  1. 重みとバイアスの初期化: 開(kāi)始時(shí)に重みはゼロに設(shè)定され、モデルが最初から學(xué)習(xí)を開(kāi)始できるようになります。
  2. 線形出力の計(jì)算: 各データ ポイントについて、パーセプトロンは入力とバイアスの加重合計(jì)を計(jì)算します。
  3. アクティブ化 (ステップ関數(shù)): 線形出力がゼロ以上の場(chǎng)合、クラス 1 が割り當(dāng)てられます。それ以外の場(chǎng)合は、クラス 0 が割り當(dāng)てられます。
  4. 更新ルール: 予測(cè)が間違っている場(chǎng)合、モデルは誤差を減らす方向に重みとバイアスを調(diào)整します。更新ルールは次のように與えられます。 重み = 學(xué)習(xí)率 * (y_true - y_pred) * x

これにより、誤って分類された點(diǎn)のみパーセプトロンが更新され、徐々にモデルが正しい決定境界に近づきます。


意思決定の境界線を視覚化する

トレーニング後の決定境界を視覚化します。これは、より複雑なデータセットを扱う場(chǎng)合に特に役立ちます?,F(xiàn)時(shí)點(diǎn)では、AND ゲートを使用して物事を単純にしておきます。


多層パーセプトロン (MLP) への拡張

パーセプトロンは線形分離可能な問(wèn)題に限定されていますが、多層パーセプトロン (MLP) のようなより複雑なニューラル ネットワークの基礎(chǔ)です。 MLP では、隠れ層と活性化関數(shù) (ReLU やシグモイドなど) を追加して、非線形問(wèn)題を解決します。


まとめ

パーセプトロンは、単純ですが基礎(chǔ)的な機(jī)械學(xué)習(xí)アルゴリズムです。その仕組みを理解し、一から実裝することで、機(jī)械學(xué)習(xí)とニューラル ネットワークの基本についての洞察が得られます。パーセプトロンの美しさはそのシンプルさにあり、AI に興味がある人にとって完璧な出発點(diǎn)となります。

以上がPython でパーセプトロンを最初から実裝するの詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國(guó)語(yǔ) Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見(jiàn)つけた場(chǎng)合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無(wú)料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無(wú)料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡(jiǎn)単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無(wú)料のコードエディター

SublimeText3 中國(guó)語(yǔ)版

SublimeText3 中國(guó)語(yǔ)版

中國(guó)語(yǔ)版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開(kāi)発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開(kāi)発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Pythonの不適格またはPytestフレームワークは、自動(dòng)テストをどのように促進(jìn)しますか? Pythonの不適格またはPytestフレームワークは、自動(dòng)テストをどのように促進(jìn)しますか? Jun 19, 2025 am 01:10 AM

Pythonの不適格でPytestは、自動(dòng)テストの書き込み、整理、および実行を簡(jiǎn)素化する2つの広く使用されているテストフレームワークです。 1.両方とも、テストケースの自動(dòng)発見(jiàn)をサポートし、明確なテスト構(gòu)造を提供します。 pytestはより簡(jiǎn)潔で、テスト\ _から始まる関數(shù)が必要です。 2。それらはすべて組み込みのアサーションサポートを持っています:Unittestはアサートエクイアル、アサートトルー、およびその他の方法を提供しますが、Pytestは拡張されたアサートステートメントを使用して障害の詳細(xì)を自動(dòng)的に表示します。 3.すべてがテストの準(zhǔn)備とクリーニングを処理するためのメカニズムを持っています:un

Pythonは、NumpyやPandasなどのライブラリとのデータ分析と操作にどのように使用できますか? Pythonは、NumpyやPandasなどのライブラリとのデータ分析と操作にどのように使用できますか? Jun 19, 2025 am 01:04 AM

pythonisidealfordataanalysisduetonumpyandpandas.1)numpyexcelsatnumericalcompitations withfast、多次元路面およびベクトル化された分離likenp.sqrt()

動(dòng)的なプログラミング技術(shù)とは何ですか?また、Pythonでそれらを使用するにはどうすればよいですか? 動(dòng)的なプログラミング技術(shù)とは何ですか?また、Pythonでそれらを使用するにはどうすればよいですか? Jun 20, 2025 am 12:57 AM

動(dòng)的プログラミング(DP)は、複雑な問(wèn)題をより単純なサブ問(wèn)題に分解し、結(jié)果を保存して繰り返し計(jì)算を回避することにより、ソリューションプロセスを最適化します。主な方法は2つあります。1。トップダウン(暗記):?jiǎn)栴}を再帰的に分解し、キャッシュを使用して中間結(jié)果を保存します。 2。ボトムアップ(表):基本的な狀況からソリューションを繰り返し構(gòu)築します。フィボナッチシーケンス、バックパッキングの問(wèn)題など、最大/最小値、最適なソリューション、または重複するサブ問(wèn)題が必要なシナリオに適しています。Pythonでは、デコレータまたはアレイを通じて実裝でき、再帰的な関係を特定し、ベンチマークの狀況を定義し、空間の複雑さを最適化することに注意する必要があります。

__iter__と__next__を使用してPythonにカスタムイテレーターを?qū)g裝するにはどうすればよいですか? __iter__と__next__を使用してPythonにカスタムイテレーターを?qū)g裝するにはどうすればよいですか? Jun 19, 2025 am 01:12 AM

カスタムイテレーターを?qū)g裝するには、クラス內(nèi)の__iter__および__next__メソッドを定義する必要があります。 __iter__メソッドは、ループなどの反復(fù)環(huán)境と互換性があるように、通常は自己の反復(fù)オブジェクト自體を返します。 __next__メソッドは、各反復(fù)の値を制御し、シーケンスの次の要素を返し、アイテムがもうない場(chǎng)合、停止例外をスローする必要があります。 statusステータスを正しく追跡する必要があり、無(wú)限のループを避けるために終了條件を設(shè)定する必要があります。 fileファイルラインフィルタリングなどの複雑なロジック、およびリソースクリーニングとメモリ管理に注意を払ってください。 simple単純なロジックについては、代わりにジェネレーター関數(shù)の収率を使用することを検討できますが、特定のシナリオに基づいて適切な方法を選択する必要があります。

Pythonプログラミング言語(yǔ)とそのエコシステムの新たな傾向または將來(lái)の方向性は何ですか? Pythonプログラミング言語(yǔ)とそのエコシステムの新たな傾向または將來(lái)の方向性は何ですか? Jun 19, 2025 am 01:09 AM

Pythonの將來(lái)の傾向には、パフォーマンスの最適化、より強(qiáng)力なタイププロンプト、代替ランタイムの増加、およびAI/MLフィールドの継続的な成長(zhǎng)が含まれます。第一に、CPYTHONは最適化を続け、スタートアップのより速い時(shí)間、機(jī)能通話の最適化、および提案された整數(shù)操作を通じてパフォーマンスを向上させ続けています。第二に、タイプのプロンプトは、コードセキュリティと開(kāi)発エクスペリエンスを強(qiáng)化するために、言語(yǔ)とツールチェーンに深く統(tǒng)合されています。第三に、PyscriptやNuitkaなどの代替のランタイムは、新しい機(jī)能とパフォーマンスの利點(diǎn)を提供します。最後に、AIとデータサイエンスの分野は拡大し続けており、新興図書館はより効率的な開(kāi)発と統(tǒng)合を促進(jìn)します。これらの傾向は、Pythonが常に技術(shù)の変化に適応し、その主要な位置を維持していることを示しています。

ソケットを使用してPythonでネットワークプログラミングを?qū)g行するにはどうすればよいですか? ソケットを使用してPythonでネットワークプログラミングを?qū)g行するにはどうすればよいですか? Jun 20, 2025 am 12:56 AM

Pythonのソケットモジュールは、クライアントおよびサーバーアプリケーションの構(gòu)築に適した低レベルのネットワーク通信機(jī)能を提供するネットワークプログラミングの基礎(chǔ)です?;镜膜蔜CPサーバーを設(shè)定するには、Socket.Socket()を使用してオブジェクトを作成し、アドレスとポートをバインドし、.listen()を呼び出して接続をリッスンし、.accept()を介してクライアント接続を受け入れる必要があります。 TCPクライアントを構(gòu)築するには、ソケットオブジェクトを作成し、.connect()を呼び出してサーバーに接続する必要があります。次に、.sendall()を使用してデータと.recv()を送信して応答を受信します。複數(shù)のクライアントを処理するには、1つを使用できます。スレッド:接続するたびに新しいスレッドを起動(dòng)します。 2。非同期I/O:たとえば、Asyncioライブラリは非ブロッキング通信を?qū)g現(xiàn)できます。注意すべきこと

Pythonクラスの多型 Pythonクラスの多型 Jul 05, 2025 am 02:58 AM

Pythonオブジェクト指向プログラミングのコアコンセプトであるPythonは、「1つのインターフェイス、複數(shù)の実裝」を指し、異なるタイプのオブジェクトの統(tǒng)一処理を可能にします。 1。多型は、メソッドの書き換えを通じて実裝されます。サブクラスは、親クラスの方法を再定義できます。たとえば、Animal ClassのSOCK()方法は、犬と貓のサブクラスに異なる実裝を持っています。 2.多型の実用的な用途には、グラフィカルドローイングプログラムでdraw()メソッドを均一に呼び出すなど、コード構(gòu)造を簡(jiǎn)素化し、スケーラビリティを向上させる、ゲーム開(kāi)発における異なる文字の共通の動(dòng)作の処理などが含まれます。 3. Pythonの実裝多型を満たす必要があります:親クラスはメソッドを定義し、子クラスはメソッドを上書きしますが、同じ親クラスの継承は必要ありません。オブジェクトが同じ方法を?qū)g裝する限り、これは「アヒル型」と呼ばれます。 4.注意すべきことには、メンテナンスが含まれます

Pythonでリストをスライスするにはどうすればよいですか? Pythonでリストをスライスするにはどうすればよいですか? Jun 20, 2025 am 12:51 AM

Pythonリストスライスに対するコアの答えは、[start:end:step]構(gòu)文をマスターし、その動(dòng)作を理解することです。 1.リストスライスの基本形式はリスト[start:end:step]です。ここで、開(kāi)始は開(kāi)始インデックス(含まれています)、endはend index(含まれていません)、ステップはステップサイズです。 2。デフォルトで開(kāi)始を省略して、0から開(kāi)始を開(kāi)始し、デフォルトで終了して終了し、デフォルトでステップを1に省略します。 3。my_list[:n]を使用して最初のnアイテムを取得し、my_list [-n:]を使用して最後のnアイテムを取得します。 4.ステップを使用して、my_list [:: 2]などの要素をスキップして、均一な數(shù)字と負(fù)のステップ値を取得できます。 5.一般的な誤解には、終了インデックスが含まれません

See all articles