ホームページ > バックエンド開発 > Python チュートリアル > さようなら! Python ループ、ベクトル化は素晴らしい

さようなら! Python ループ、ベクトル化は素晴らしい

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2023-04-14 14:49:03
転載
1205 人が閲覧しました

私たちは、ほぼすべてのプログラミング言語のループについて学習しました。したがって、デフォルトでは、反復操作があるたびにループの実装を開始します。しかし、大量の反復 (数百万/数十億行) を扱う場合、ループを使用するのは非常に面倒で、何時間も行き詰まって、後でそれが機能しないことに気づく可能性があります。ここで、Python でのベクトル化の実装が非常に重要になります。

ベクトル化とは何ですか?

ベクトル化は、データ セットに対する (NumPy) 配列操作を実装するための手法です。バックグラウンドで、配列または系列のすべての要素を一度に操作します (一度に 1 行を操作する 'for' ループとは異なります)。

このブログでは、Python ループをベクトル化で簡単に置き換えることができるいくつかのユースケースを見ていきます。これにより、時間を節約し、コーディングの習熟度を高めることができます。

ユースケース 1: 数値の合計を求める

最初に、ループとベクトルを使用して Python で数値の合計を求める基本的な例を見てみましょう。

ループの使用

import time 
start = time.time()

# 遍历之和
total = 0
# 遍历150万个数字
for item in range(0, 1500000):
total = total + item

print('sum is:' + str(total))
end = time.time()

print(end - start)

#1124999250000
#0.14 Seconds
ログイン後にコピー

ベクトル化の使用

import numpy as np

start = time.time()

# 向量化和--使用numpy进行向量化
# np.range创建从0到1499999的数字序列
print(np.sum(np.arange(1500000)))

end = time.time()
print(end - start)

##1124999250000
##0.008 Seconds
ログイン後にコピー

ベクトル化の実行と範囲関数を使用した反復の比較 時間は約 18回。この違いは、Pandas DataFrame を使用する場合にさらに顕著になります。

ユースケース 2: DataFrame の数学的演算

データ サイエンスでは、Pandas DataFrame を使用する場合、開発者はループを使用して数学的演算用の新しい派生列を作成します。

以下の例では、このようなユースケースでは、ループをベクトル化によって簡単に置き換えることができることがわかります。

DataFrame の作成

DataFrame は、行と列の形式の表形式のデータです。

500 万行と 0 から 50 までのランダムな値が入った 4 列を持つパンダ データフレームを作成しています。

import numpy as np
import pandas as pd
df = pd.DataFrame(np.random.randint(0, 50, 
size=(5000000, 4)),
columns=('a','b','c','d'))
df.shape
# (5000000, 5)
df.head()
ログイン後にコピー

さようなら! Python ループ、ベクトル化は素晴らしい

新しい列「ratio」を作成して、列「d」と「c」の比率を調べます。

ループの使用

import time 
start = time.time()

# Iterating through DataFrame using iterrows
for idx, row in df.iterrows():
# creating a new column 
df.at[idx,'ratio'] = 100 * (row["d"] / row["c"])
end = time.time()
print(end - start)
### 109 Seconds
ログイン後にコピー

ベクトル化の使用

start = time.time()
df["ratio"] = 100 * (df["d"] / df["c"])

end = time.time()
print(end - start)
### 0.12 seconds
ログイン後にコピー

Python を使用すると、DataFrame が大幅に改善されていることがわかります。のループと比較して、ベクトル化はほぼ 1000 倍高速です。

ユースケース 3: DataFrame の If-else ステートメント

「if-else」タイプのロジックを使用する必要がある多くの操作を実装しました。このロジックは、Python のベクトル化された操作に簡単に置き換えることができます。

以下の例を見て、よりよく理解してください (使用例 2 で作成した DataFrame を使用します)。

終了した列「a」の条件に基づいて新しい列「e」を作成する方法を想像してください。

ループの使用

import time 
start = time.time()

# Iterating through DataFrame using iterrows
for idx, row in df.iterrows():
if row.a == 0:
df.at[idx,'e'] = row.d
elif (row.a <= 25) & (row.a > 0):
df.at[idx,'e'] = (row.b)-(row.c)
else:
df.at[idx,'e'] = row.b + row.c

end = time.time()

print(end - start)
### Time taken: 177 seconds
ログイン後にコピー

ベクトル化の使用

start = time.time()
df['e'] = df['b'] + df['c']
df.loc[df['a'] <= 25, 'e'] = df['b'] -df['c']
df.loc[df['a']==0, 'e'] = df['d']end = time.time()
print(end - start)
## 0.28007707595825195 sec
ログイン後にコピー

if-else ステートメントを含む Python ループと比較すると、ベクトル化された操作は 600 です。ループよりも数倍高速です。

ユースケース 4: 機械学習/ディープ ラーニング ネットワークの解決

ディープ ラーニングでは、複数の複雑な方程式、および数百万行、数十億行の方程式を解く必要があります。これらの方程式を解くために Python でループを実行すると非常に時間がかかり、その時点ではベクトル化が最適な解決策になります。

たとえば、次の重線形回帰式で数百万行の y 値を計算するとします。

さようなら! Python ループ、ベクトル化は素晴らしい

ループの代わりにベクトル化を使用できます。

m1、m2、m3... の値は、x1、x2、x3... に対応する数百万の値を使用して上記の方程式を解くことによって決定されます (簡単にするために、1 つだけを見てください)単純な乗算手順)

データの作成

>>> import numpy as np
>>> # 设置 m 的初始值 
>>> m = np.random.rand(1,5)
array([[0.49976103, 0.33991827, 0.60596021, 0.78518515, 0.5540753]])
>>> # 500万行的输入值
>>> x = np.random.rand(5000000,5)
ログイン後にコピー

さようなら! Python ループ、ベクトル化は素晴らしい

##ループの使用

import numpy as np
m = np.random.rand(1,5)
x = np.random.rand(5000000,5)

total = 0
tic = time.process_time()

for i in range(0,5000000):
total = 0
for j in range(0,5):
total = total + x[i][j]*m[0][j] 

zer[i] = total 

toc = time.process_time()
print ("Computation time = " + str((toc - tic)) + "seconds")

####Computation time = 28.228 seconds
ログイン後にコピー

行列ベクトルの乗算は、vectorization

さようなら! Python ループ、ベクトル化は素晴らしい

tic = time.process_time()

#dot product 
np.dot(x,m.T) 

toc = time.process_time()
print ("Computation time = " + str((toc - tic)) + "seconds")

####Computation time = 0.107 seconds
ログイン後にコピー

np.dot を使用してバックエンドで実装されます。 Python のループと比較して 165 倍高速です。

最後に書きました

Python のベクトル化は非常に高速です。非常に大きなデータセットを扱う場合は、ループではなくベクトル化を優先することをお勧めします。このようにして、時間の経過とともに、ベクトル化のアイデアに従ってコードを書くことに徐々に慣れていきます。

以上がさようなら! Python ループ、ベクトル化は素晴らしいの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:51cto.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート