Pythonで異なる次元の2つの配列のクロネッカー積を取得します
次元が異なる2つの配列のクロネッカー積を取得するには、Python Numpyのnumpy.kron()メソッドを使用します。最初の配列によってスケーリングされた2番目の配列のブロックで構成される複合配列であるクロネッカー積を計算します
この関数は、aとbの次元数が同じであると想定し、必要に応じて、最小の次元の前に1を追加します。 a.shape =(r0、r1、..、rN)およびb.shape =(s0、s1、...、sN)の場合、Kronecker製品の形状は(r0 * s0、r1 * s1、...、rN)になります。 * SN)。要素は、要素fromaとbの積であり、-
によって明示的に編成されています。# kron(a,b)[k0,k1,...,kN] = a[i0,i1,...,iN] * b[j0,j1,...,jN]>
ステップ
まず、必要なライブラリをインポートします-
import numpy as np
arange()メソッドとreshape()メソッドを使用して次元の異なる2つのnumpy配列を作成する-
arr1 = np.arange(20).reshape((2,5,2)) arr2 = np.arange(6).reshape((2,3))
配列を表示する-
print("Array1...\n",arr1) print("\nArray2...\n",arr2)
両方のアレイの寸法を確認してください-
print("\nDimensions of Array1...\n",arr1.ndim) print("\nDimensions of Array2...\n",arr2.ndim)
両方のアレイの形状を確認してください-
print("\nShape of Array1...\n",arr1.shape) print("\nShape of Array2...\n",arr2.shape)
2つの配列のクロネッカー積を取得するには、Pythonでnumpy.kron()メソッドを使用します-
print("\nResult (Kronecker product)...\n",np.kron(arr1, arr2))
例
import numpy as np # Creating two numpy arrays with different dimensions using the arange() and reshape() method arr1 = np.arange(20).reshape((2,5,2)) arr2 = np.arange(6).reshape((2,3)) # Display the arrays print("Array1...\n",arr1) print("\nArray2...\n",arr2) # Check the Dimensions of both the array print("\nDimensions of Array1...\n",arr1.ndim) print("\nDimensions of Array2...\n",arr2.ndim) # Check the Shape of both the array print("\nShape of Array1...\n",arr1.shape) print("\nShape of Array2...\n",arr2.shape) # To get the Kronecker product of two arrays, use the numpy.kron() method in Python Numpy print("\nResult (Kronecker product)...\n",np.kron(arr1, arr2))
出力
Array1... [[[ 0 1] [ 2 3] [ 4 5] [ 6 7] [ 8 9]] [[10 11] [12 13] [14 15] [16 17] [18 19]]] Array2... [[0 1 2] [3 4 5]] Dimensions of Array1... 3 Dimensions of Array2... 2 Shape of Array1... (2, 5, 2) Shape of Array2... (2, 3) Result (Kronecker product)... [[[ 0 0 0 0 1 2] [ 0 0 0 3 4 5] [ 0 2 4 0 3 6] [ 6 8 10 9 12 15] [ 0 4 8 0 5 10] [12 16 20 15 20 25] [ 0 6 12 0 7 14] [18 24 30 21 28 35] [ 0 8 16 0 9 18] [24 32 40 27 36 45]] [[ 0 10 20 0 11 22] [30 40 50 33 44 55] [ 0 12 24 0 13 26] [36 48 60 39 52 65] [ 0 14 28 0 15 30] [42 56 70 45 60 75] [ 0 16 32 0 17 34] [48 64 80 51 68 85] [ 0 18 36 0 19 38] [54 72 90 57 76 95]]]
-
Pythonで4Dおよび3D次元の配列のクロネッカー積を入手する
4Dと3Dの次元配列のクロネッカー積を取得するには、Python Numpyのnumpy.kron()メソッドを使用します。最初の配列によってスケーリングされた2番目の配列のブロックで構成される複合配列であるクロネッカー積を計算します この関数は、aとbの次元数が同じであると想定し、必要に応じて最小の次元の前に1を追加します。 a.shape =(r0、r1、..、rN)およびb.shape =(s0、s1、...、sN)の場合、クロネッカー積は形状(r0 * s0、r1 * s1、...、 rN * SN)。要素は、aとbの要素の積であり、-によって明示的に編成されています。 kron(a
-
Pythonで2つの配列の要素のk番目に大きい積を見つけるプログラム
いくつかの整数を含む2つのリストpとqが与えられたと仮定します。これらのリストのすべての値を乗算し、乗算結果からk番目に大きい値を見つける必要があります。 したがって、入力がp =[2、5]、q =[6、8]、k =2の場合、出力は16になります。 乗算の結果は次のとおりです。2*6=12、2 * 8 =16、5 * 6 =30、5 * 8 =40。2番目に大きい要素はis(インデックスは0から始まります)は16です。 これを解決するには、次の手順に従います- リストを並べ替えるp リストを並べ替えるq k:=k + 1 ヒープ:=リスト表現の新しいヒープ qの各要素について、