Python を使用して画像に対して非最大抑制を実行する方法
非最大抑制は、コンピューター ビジョンで一般的に使用される画像処理テクノロジです。エッジやエッジを抽出するために使用されます。画像の角。この記事では、Python プログラミング言語と OpenCV ライブラリを使用して、画像の非最大抑制を実装します。
- ライブラリのインストールとインポート
まず、Python ライブラリと OpenCV ライブラリがインストールされていることを確認します。 pip を使用して OpenCV ライブラリをインストールできます: pip install opencv-python
。
次に、必要なライブラリをインポートします。
import cv2 import numpy as np
- 画像の読み込みと前処理
OpenCV の cv2.imread()
関数は画像をロードし、グレースケール画像処理方法を使用して画像をグレースケールに変換します。グレースケール画像にはチャネルが 1 つしか含まれていないため、処理が簡単です。次のコードは、画像をロードして前処理する方法を示しています。
# 读取图像 image = cv2.imread('image.jpg') # 转换为灰度图像 gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
- Compute Gradient
非最大抑制は画像の勾配に基づき、勾配の大きさと方向を使用します。勾配を調べて最大値かどうかを判断します。 cv2.Sobel()
関数を使用して画像の勾配を計算できます。
# 计算x和y轴方向的梯度 gradient_x = cv2.Sobel(gray, cv2.CV_64F, 1, 0, ksize=3) gradient_y = cv2.Sobel(gray, cv2.CV_64F, 0, 1, ksize=3) # 计算梯度的大小和方向 magnitude = np.sqrt(gradient_x ** 2 + gradient_y ** 2) angle = np.arctan2(gradient_y, gradient_x)
- 非最大抑制の実行
次に、勾配の大きさと方向を使用して非最大抑制を実行します。各ピクセルについて、隣接する 2 つのピクセルを確認し、勾配の大きさが隣接するピクセルよりも大きく、勾配方向の最大値である場合、そのピクセルをエッジとして保持します。
# 非极大抑制 suppressed = np.zeros_like(magnitude) for y in range(1, magnitude.shape[0] - 1): for x in range(1, magnitude.shape[1] - 1): current_gradient = magnitude[y, x] current_angle = angle[y, x] if (current_angle >= 0 and current_angle < np.pi / 8) or (current_angle >= 7 * np.pi / 8 and current_angle < np.pi): before_gradient = magnitude[y, x - 1] after_gradient = magnitude[y, x + 1] elif current_angle >= np.pi / 8 and current_angle < 3 * np.pi / 8: before_gradient = magnitude[y - 1, x - 1] after_gradient = magnitude[y + 1, x + 1] elif current_angle >= 3 * np.pi / 8 and current_angle < 5 * np.pi / 8: before_gradient = magnitude[y - 1, x] after_gradient = magnitude[y + 1, x] else: before_gradient = magnitude[y - 1, x + 1] after_gradient = magnitude[y + 1, x - 1] if current_gradient >= before_gradient and current_gradient >= after_gradient: suppressed[y, x] = current_gradient
- 結果の表示
最後に、cv2.imshow()
関数を使用して、元の画像と非最大抑制を表示します。結果。コードは次のとおりです。
# 显示结果 cv2.imshow('Original Image', image) cv2.imshow('Non-maximum Suppressed Image', suppressed) cv2.waitKey(0) cv2.destroyAllWindows()
上記は、Python を使用した画像の非最大抑制の完全なサンプル コードです。上記の手順により、Python および OpenCV ライブラリを使用して、画像内のエッジやコーナーを抽出する非最大抑制を簡単に実装できます。より良い結果を得るために、必要に応じてパラメーターとコード ロジックを調整できます。
以上がPython を使用して画像の非最大抑制を実行する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Pythonlistscanstoreanydatatype,arraymodulearraysstoreonetype,andNumPyarraysarefornumericalcomputations.1)Listsareversatilebutlessmemory-efficient.2)Arraymodulearraysarememory-efficientforhomogeneousdata.3)NumPyarraysareoptimizedforperformanceinscient

heouttemptemptostoreavure ofthewrongdatatypeinapythonarray、yure counteractypeerror.thisduetothearraymodule'sstricttypeeencultionyを使用します

PythonListSarePartOfThestAndardarenot.liestareBuilting-in、versatile、forStoringCollectionsのpythonlistarepart。

theScriptisrunningwithwrongthonversionduetorectRectDefaultEntertersettings.tofixthis:1)CheckthedededefaultHaulthonsionsingpython - versionorpython3-- version.2)usevirtualenvironmentsbycreatingonewiththon3.9-mvenvmyenv、andverixe

PythonArraysSupportVariousoperations:1)SlicingExtractsSubsets、2)Appending/ExtendingAdddesements、3)inSertingSelementSatspecificpositions、4)remvingingDeletesements、5)sorting/verversingsorder、and6)listenionsionsionsionsionscreatenewlistsebasedexistin

numpyarraysAressertialentionsionceivationsefirication-efficientnumericalcomputations andDatamanipulation.theyarecrucialindatascience、mashineelearning、物理学、エンジニアリング、および促進可能性への適用性、scaledatiencyを効率的に、forexample、infinancialanalyyy

UseanArray.ArrayOverAlistinPythonは、Performance-criticalCode.1)homogeneousdata:araysavememorywithpedelements.2)Performance-criticalcode:Araysofterbetterbetterfornumerumerumericaleperations.3)interf

いいえ、notallistoperationSaresuptedbyarrays、andviceversa.1)arraysdonotsupportdynamicoperationslikeappendorintorintorinsertizizing、whosimpactsporformance.2)リスト


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

Dreamweaver Mac版
ビジュアル Web 開発ツール

WebStorm Mac版
便利なJavaScript開発ツール

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

ホットトピック









