Python:NumPyを使用したベクトル、行列、配列

Python Vectors Matrices



このレッスンでは、PythonのNumPyライブラリを使用して、ベクトル、行列、配列を操作するためのヒントとコツをいくつか見ていきます。このレッスンは、データサイエンスを始めて、これらのコンポーネントの数学的な概要と、コードでNumPyを使用してそれらを操作する方法が必要な場合に非常に良い出発点です。

NumPyライブラリを使用すると、ベクトル、行列、配列など、機械学習やデータサイエンスでよく使用されるデータ構造に対して実行する必要のあるさまざまな操作を実行できます。多くの機械学習パイプラインで使用されるNumPyでの最も一般的な操作のみを示します。最後に、NumPyは操作を実行するための単なる方法であるため、ここで示す数学的な操作は、NumPyパッケージ自体ではなく、このレッスンの主な焦点であることに注意してください。始めましょう。







ベクトルとは何ですか?

グーグルによれば、ベクトルは、特に空間内のある点の別の点に対する位置を決定するときに、方向と大きさを持つ量です。





ベクトルは、大きさだけでなく特徴の方向も表すため、機械学習では非常に重要です。次のコードスニペットを使用して、NumPyでベクターを作成できます。





numpyをインポートするなので例えば

row_vector = np.array(([123])。
印刷((row_vector)。

上記のコードスニペットでは、行ベクトルを作成しました。次のように列ベクトルを作成することもできます。

numpyをインポートするなので例えば

col_vector = np.array(([[1][2][3]])。
印刷((col_vector)。

マトリックスの作成

行列は、単純に2次元配列として理解できます。多次元配列を作成することにより、NumPyで行列を作成できます。



マトリックス= np.array(([[123][456][789]])。
印刷((マトリックス)。

行列は多次元配列とまったく同じですが、 マトリックスデータ構造は推奨されません 2つの理由による:

  1. NumPyパッケージに関しては、配列が標準です。
  2. NumPyを使用したほとんどの操作は、行列ではなく配列を返します

スパース行列の使用

思い出してください。スパース行列は、ほとんどの項目がゼロである行列です。現在、データ処理と機械学習の一般的なシナリオは、ほとんどの要素がゼロである行列の処理です。たとえば、行がYouTubeのすべての動画を表し、列が各登録ユーザーを表すマトリックスについて考えてみます。各値は、ユーザーがビデオを視聴したかどうかを表します。もちろん、このマトリックスの値の大部分はゼロになります。 NS スパース行列の利点 ゼロの値は保存されないということです。これにより、計算上の大きな利点とストレージの最適化も実現します。

ここでスパークマトリックスを作成しましょう:

scipy importsparseから

original_matrix = np.array(([[103][006][700]])。
sparse_matrix = sparse.csr_matrix((original_matrix)。
印刷((sparse_matrix)。

コードがどのように機能するかを理解するために、ここで出力を確認します。

上記のコードでは、NumPyの関数を使用して 圧縮されたスパース行 ゼロ以外の要素がゼロベースのインデックスを使用して表される行列。次のようなさまざまな種類のスパース行列があります。

  • 圧縮されたスパース列
  • リストのリスト
  • キーの辞書

ここでは他のスパース行列に飛び込むことはしませんが、それぞれの使用法は特定のものであり、誰も「最良」とは言えないことを知っています。

すべてのベクトル要素に操作を適用する

これは、複数のベクトル要素に共通の演算を適用する必要がある場合の一般的なシナリオです。これは、ラムダを定義し、それをベクトル化することで実行できます。同じためのいくつかのコードスニペットを見てみましょう:

マトリックス= np.array(([
[123]
[456]
[789]])。

mul_5 =ラムダx:x* 5
vectorized_mul_5 = np.vectorize((mul_5)。

vectorized_mul_5((マトリックス)。

コードがどのように機能するかを理解するために、ここで出力を確認します。

上記のコードスニペットでは、NumPyライブラリの一部であるvectorize関数を使用して、単純なラムダ定義を、ベクトルのすべての要素を処理できる関数に変換しました。ベクトル化は 要素のループだけ プログラムのパフォーマンスには影響しません。 NumPyはまた許可します 放送 、これは、上記の複雑なコードの代わりに、次のことを簡単に実行できたことを意味します。

マトリックス* 5

そして、結果はまったく同じだったでしょう。最初に複雑な部分を表示したかったのですが、そうでない場合はセクションをスキップしてしまいます。

平均、分散、標準偏差

NumPyを使用すると、ベクトルの記述統計に関連する操作を簡単に実行できます。ベクトルの平均は次のように計算できます。

np.mean((マトリックス)。

ベクトルの分散は次のように計算できます。

np.var((マトリックス)。

ベクトルの標準偏差は次のように計算できます。

例:std((マトリックス)。

指定された行列に対する上記のコマンドの出力を次に示します。

行列の転置

転置は非常に一般的な操作であり、行列に囲まれているときによく耳にします。転置は、行列の列値と行値を交換する方法にすぎません。注意してください ベクトルを転置することはできません ベクトルは値のコレクションであり、それらの値は行と列に分類されていません。行ベクトルを列ベクトルに変換することは転置ではないことに注意してください(このレッスンの範囲外である線形代数の定義に基づいています)。

今のところ、行列を転置するだけで平和が見つかります。 NumPyを使用して行列の転置にアクセスするのは非常に簡単です。

matrix.T

指定された行列に対する上記のコマンドの出力は、次のとおりです。

行ベクトルに対して同じ操作を実行して、行ベクトルを列ベクトルに変換できます。

行列の平坦化

要素を線形に処理したい場合は、行列を1次元配列に変換できます。これは、次のコードスニペットを使用して実行できます。

matrix.flatten(()。

指定された行列に対する上記のコマンドの出力は、次のとおりです。

平坦化された行列は1次元配列であり、単純に線形であることに注意してください。

固有値と固有ベクトルの計算

固有ベクトルは、機械学習パッケージで非常に一般的に使用されます。したがって、線形変換関数が行列として表される場合、X、固有ベクトルは、ベクトルのスケールのみが変化し、その方向は変化しないベクトルです。私たちはそれを言うことができます:

Xv =γv

ここで、Xは正方行列であり、γには固有値が含まれています。また、vには固有ベクトルが含まれています。 NumPyを使用すると、固有値と固有ベクトルを簡単に計算できます。これが同じことを示すコードスニペットです:

evalues、evectors = np.linalg.eig((マトリックス)。

指定された行列に対する上記のコマンドの出力は、次のとおりです。

ベクトルの内積

ベクトルの内積は、2つのベクトルを乗算する方法です。それはあなたに 同じ方向にあるベクトルの量 、反対の外積とは対照的に、ベクトルが同じ方向にどれだけ小さいか(直交と呼ばれます)。ここのコードスニペットに示されているように、2つのベクトルの内積を計算できます。

a = np.array(([356])。
b = np.array(([2. 3151])。

np.dot((a、b)。

指定された配列に対する上記のコマンドの出力を次に示します。

行列の加算、減算、乗算

複数の行列の加算と減算は、行列での非常に簡単な操作です。これを行うには2つの方法があります。これらの操作を実行するためのコードスニペットを見てみましょう。これを単純にするために、同じ行列を2回使用します。

np.add((マトリックス、マトリックス)。

次に、2つの行列を次のように減算できます。

np.subtract((マトリックス、マトリックス)。

指定された行列に対する上記のコマンドの出力は、次のとおりです。

予想どおり、マトリックス内の各要素は、対応する要素で加算/減算されます。行列の乗算は、前に行ったように内積を見つけることに似ています。

np.dot((マトリックス、マトリックス)。

上記のコードは、次のように与えられる2つの行列の真の乗算値を見つけます。

マトリックス*マトリックス

指定された行列に対する上記のコマンドの出力は、次のとおりです。

結論

このレッスンでは、一般的に使用されるベクトル、行列、配列に関連する多くの数学演算、データ処理、記述統計、データサイエンスについて説明しました。これは、さまざまな概念の最も一般的で最も重要なセクションのみをカバーする簡単なレッスンでしたが、これらの操作は、これらのデータ構造を処理しながらすべての操作を実行できることについて非常に良いアイデアを与えるはずです。

Twitterでのレッスンに関するフィードバックをTwitterで自由に共有してください @linuxhint@sbmaggarwal (それは私です!)。