행렬에서는 그 특유의 성질로 인해 실수에서의 지수법칙, 교환법칙 등이 성립하지 않습니다.
그래서 행렬의 n제곱을 구할 때에는 노가다로 성분끼리 곱하여 더해 제곱한 행렬을 구하는 경우가 많습니다.
하지만 일반 제곱식을 구할 경우, 수1에서 배울 수 있는 [케일리-해밀턴의 정리]를 활용하여 실수배와 덧셈 뺄셈만으로도 제곱한 행렬을 구할 수 있습니다!!
행렬 A를 다음과 같은 이차정사각행렬으로 둡시다.
케일러-해밀턴의 정리에서 유도한 행렬식 A^2=(a+d)A-(ad-bc)E로 제곱된 값을 구할 수 있습니다.
즉,
예를 들어 행렬 의 제곱을 위의 케일리-해밀턴의 정리를 사용해 구하면
이렇게 행렬의 곱셈같이 복잡한 방법을 이용하지 않고도, 행렬의 실수배와 행렬간의 덧셈만으로 행렬의 제곱을 구했습니다.
알고 계신 분도 많았겠지만, 복잡한 행렬의 제곱을 간단하게 구하고 싶으시다고 하실 분께 유용한 팁이 되었으면 좋겠습니다.
'[알고리즘]' 카테고리의 다른 글
Matlab expression : 2D Convolution ==> conv( ) (0) | 2012.10.25 |
---|---|
harris corner detector code (0) | 2012.10.25 |
Convolution 개념 정리-이미지처리 기술 (0) | 2012.10.24 |
Sobel Edge Detector : Documents and verilog Code (0) | 2012.10.24 |
다양한 Edge(에지) 추출 알고리즘 : 1차미분, sobel, Prewitt, Roberts, Compass, Laplacian... (0) | 2012.10.22 |