Theano-행렬 곱셈을위한 표현

두 행렬의 내적을 계산합니다. 첫 번째 행렬은 차원 2 x 3이고 두 번째 행렬은 차원 3 x 2입니다. 입력으로 사용한 행렬과 그 곱은 여기에 표현됩니다.

$$ \ begin {bmatrix} 0 & -1 & 2 \\ 4 & 11 & 2 \ end {bmatrix} \ : \ begin {bmatrix} 3 & -1 \\ 1 & 2 \\ 35 & 20 \ end {bmatrix} = \ begin {bmatrix} 11 & 0 \\ 35 & 20 \ end {bmatrix} $$

변수 선언

위의 Theano 표현식을 작성하려면 먼저 다음과 같이 행렬을 나타내는 두 개의 변수를 선언합니다.

a = tensor.dmatrix()
b = tensor.dmatrix()

dmatrix는 double에 대한 행렬의 유형입니다. 우리는 어디에도 행렬 크기를 지정하지 않습니다. 따라서 이러한 변수는 모든 차원의 행렬을 나타낼 수 있습니다.

식 정의

내적을 계산하기 위해 우리는 dot 다음과 같이-

c = tensor.dot(a,b)

곱셈의 출력은 다음과 같은 행렬 변수에 할당됩니다. c.

Theano 기능 정의

다음으로 식을 평가하기 위해 이전 예제에서와 같이 함수를 정의합니다.

f = theano.function([a,b], c)

함수에 대한 입력은 행렬 유형 인 두 개의 변수 a와 b입니다. 함수 출력은 변수에 할당됩니다.c 자동으로 매트릭스 유형이됩니다.

Theano 함수 호출

이제 다음 명령문을 사용하여 함수를 호출합니다.

d = f([[0, -1, 2], [4, 11, 2]], [[3, -1],[1,2], [6,1]])

위 명령문의 두 변수는 NumPy 배열입니다. 여기에 표시된대로 NumPy 배열을 명시 적으로 정의 할 수 있습니다.

f(numpy.array([[0, -1, 2], [4, 11, 2]]),
numpy.array([[3, -1],[1,2], [6,1]]))

d 계산되어 그 값을 인쇄합니다.

print (d)

출력에 다음 출력이 표시됩니다.

[[11. 0.]
[25. 20.]]

전체 프로그램 목록

The complete program listing is given here:
from theano import *
a = tensor.dmatrix()
b = tensor.dmatrix()
c = tensor.dot(a,b)
f = theano.function([a,b], c)
d = f([[0, -1, 2],[4, 11, 2]], [[3, -1],[1,2],[6,1]])
print (d)

프로그램 실행의 스크린 샷은 다음과 같습니다.