コーヒー買ってきて☕
*メモ:
- 私の投稿では OxfordIIITPet() について説明しています。
Resize() は、以下に示すように 0 個以上の画像のサイズを変更できます。
*メモ:
- 初期化の最初の引数は size(Required-Type:int または tuple/list(int)) です。
*メモ:
- [幅、高さ]です。
- 1
- タプル/リストは 1 つまたは 2 つの要素を持つ 1D でなければなりません。
- 単一の値 (int または tuple/list(int`)) が画像の小さい方の幅または高さの端に適用され、もう一方の大きい幅または高さの端もサイズ変更されます。 *メモ:
- 画像の幅が高さより小さい場合、[サイズ、サイズ * 幅 / 高さ] となります。
- 画像の幅が高さよりも大きい場合、[サイズ * 幅 / 高さ , サイズ] となります。
- 画像の幅が高さと等しい場合、それは [サイズ、サイズ] です。
- 初期化の 2 番目の引数は interpolation(Optional-Default:InterpolationMode.BILINEAR-Type:InterpolationMode) です。
- 初期化の 3 番目の引数は max_size(Optional-Default:None-Type:int) です。
*メモ:
- サイズが単一の値(int または tuple/list(int`)) の場合にのみサポートされます。
- サイズが適用された後、より大きな画像の幅または高さの端がそれを超える場合は、より大きな画像の幅または高さの端に適用されて画像サイズが制限され、他の小さな画像の幅または高さの端も以前よりも小さくなります。
- 初期化の 4 番目の引数は、antialias(Optional-Default:True-Type:bool) です。 ※補間がInterpolationMode.BILINEARまたはInterpolationMode.BICUBICの場合はFalseを設定しても常にTrueとなります。
- 最初の引数は img(Required-Type:PIL Image or tensor(int, float, complex or bool)) です。
*メモ:
- テンソルは、1 つ以上の要素の 3D または複数の D テンソルでなければなりません。
- img=. は使用しないでください。
- V1 または V2 に従って v2 を使用することをお勧めしますか?どれを使えばいいのでしょうか?
from torchvision.datasets import OxfordIIITPet from torchvision.transforms.v2 import Resize from torchvision.transforms.functional import InterpolationMode resize = Resize(size=100) resize = Resize(size=100, interpolation=InterpolationMode.BILINEAR, max_size=None, antialias=True) resize # Resize(size=[100], # interpolation=InterpolationMode.BILINEAR, # antialias=True) resize.size # [100] resize.interpolation # <interpolationmode.bilinear:> print(resize.max_size) # None resize.antialias # True origin_data = OxfordIIITPet( root="data", transform=None ) p1000_data = OxfordIIITPet( root="data", transform=Resize(size=1000) # transform=Resize(size=[1000]) ) p100_data = OxfordIIITPet( root="data", transform=Resize(size=100) ) p50_data = OxfordIIITPet( root="data", transform=Resize(size=50) ) p10_data = OxfordIIITPet( root="data", transform=Resize(size=10) ) p100p180_data = OxfordIIITPet( root="data", transform=Resize(size=[100, 180]) ) p180p100_data = OxfordIIITPet( root="data", transform=Resize(size=[180, 100]) ) p100ms110_data = OxfordIIITPet( root="data", transform=Resize(size=100, max_size=110) ) import matplotlib.pyplot as plt def show_images1(data, main_title=None): plt.figure(figsize=(10, 5)) plt.suptitle(t=main_title, y=0.8, fontsize=14) for i, (im, _) in zip(range(1, 6), data): plt.subplot(1, 5, i) plt.imshow(X=im) plt.tight_layout() plt.show() show_images1(data=origin_data, main_title="origin_data") show_images1(data=p1000_data, main_title="p1000_data") show_images1(data=p100_data, main_title="p100_data") show_images1(data=p50_data, main_title="p50_data") show_images1(data=p10_data, main_title="p10_data") print() show_images1(data=origin_data, main_title="origin_data") show_images1(data=p100p180_data, main_title="p100p180_data") show_images1(data=p180p100_data, main_title="p180p100_data") print() show_images1(data=p100_data, main_title="p100_data") show_images1(data=p100ms110_data, main_title='p100ms110_data') # ↓ ↓ ↓ ↓ ↓ ↓ The code below is identical to the code above. ↓ ↓ ↓ ↓ ↓ ↓ def show_images2(data, main_title=None, s=None, ms=None): plt.figure(figsize=(10, 5)) plt.suptitle(t=main_title, y=0.8, fontsize=14) for i, (im, _) in zip(range(1, 6), data): plt.subplot(1, 5, i) if not s: s = im.size resize = Resize(size=s, max_size=ms) # Here plt.imshow(X=resize(im)) # Here plt.tight_layout() plt.show() show_images2(data=origin_data, main_title="origin_data") show_images2(data=origin_data, main_title="p1000_data", s=1000) show_images2(data=origin_data, main_title="p100_data", s=100) show_images2(data=origin_data, main_title="p50_data", s=50) show_images2(data=origin_data, main_title="p10_data", s=10) print() show_images2(data=origin_data, main_title="origin_data") show_images2(data=origin_data, main_title="p100p180_data", s=[100, 180]) show_images2(data=origin_data, main_title="p180p100_data", s=[180, 100]) print() show_images2(data=origin_data, main_title="p100_data", s=100) show_images2(data=origin_data, main_title="p100ms110_data", s=100, ms=110) </interpolationmode.bilinear:>
以上がPyTorch でのサイズ変更の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ArsareSareBetterElement-WiseOperationsduetof of ActassandoptimizedImplementations.1)ArrayshaveContigUousMoryFordiRectAccess.2)ListSareFlexibleButSlowerDueTopotentialDynamicresizizizizing.3)

Numpyの配列全体の数学的操作は、ベクトル化された操作を通じて効率的に実装できます。 1)追加(arr 2)などの簡単な演算子を使用して、配列で操作を実行します。 2)Numpyは、基礎となるC言語ライブラリを使用して、コンピューティング速度を向上させます。 3)乗算、分割、指数などの複雑な操作を実行できます。 4)放送操作に注意して、配列の形状が互換性があることを確認します。 5)np.sum()などのnumpy関数を使用すると、パフォーマンスが大幅に向上する可能性があります。

Pythonでは、要素をリストに挿入するための2つの主要な方法があります。1)挿入(インデックス、値)メソッドを使用して、指定されたインデックスに要素を挿入できますが、大きなリストの先頭に挿入することは非効率的です。 2)Append(Value)メソッドを使用して、リストの最後に要素を追加します。これは非常に効率的です。大規模なリストの場合、append()を使用するか、dequeまたはnumpy配列を使用してパフォーマンスを最適化することを検討することをお勧めします。

tomakeapythonscriptexecutableonbothunixandwindows:1)addashebangline(#!/usr/bin/envpython3)andusechmod xtomakeitexecutableonix.2)onwindows、sursepythonisinstalledassandassassociated with.pyfiles、またはruseabatchfile(run.bat)tor。

「commandnotfound」エラーに遭遇した場合、次のポイントを確認する必要があります。1。スクリプトが存在し、パスが正しいことを確認します。 2.ファイルの権限を確認し、CHMODを使用して、必要に応じて実行権限を追加します。 3.スクリプトインタープリターがインストールされ、パスにインストールされていることを確認してください。 4.スクリプトの先頭にあるShebangラインが正しいことを確認します。そうすることで、スクリプトの操作の問題を効果的に解決し、コーディングプロセスがスムーズであることを確認できます。

AlaySaregenerallymorememory-effictient forstring forstring inumericaldataduetotheirfixed-sizenature anddirectmoryaccess.1)AraysstoreElementsinaCourowlock、Reducingoverheadfrompointertersormetadata.2)リスト

ToconvertaPythonlisttoanarray,usethearraymodule:1)Importthearraymodule,2)Createalist,3)Usearray(typecode,list)toconvertit,specifyingthetypecodelike'i'forintegers.Thisconversionoptimizesmemoryusageforhomogeneousdata,enhancingperformanceinnumericalcomp

Pythonリストは、さまざまな種類のデータを保存できます。サンプルリストには、整数、文字列、フローティングポイント番号、ブール膜、ネストされたリスト、辞書が含まれています。リストの柔軟性は、データ処理とプロトタイピングにおいて価値がありますが、コードの読みやすさと保守性を確保するためには注意して使用する必要があります。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

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

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