선형대수를 사용해서 연립방정식 풀기

연립방정식을 손으로 푸는 방법으로는 학교에서 소거법이나 대입법 같은 테크닉을 배운다. 하지만 간단한 1차 연립 방정식을 다른 방법을 사용해서도 풀 수 있는데, 이 다른 방법이라는 것이 손으로 풀기에는 더욱 귀찮지만 컴퓨터에 적용할 수 있다는 장점이 있어서 소개한다.

한개에 600원하는 귤과 한 개에 1000원하는 사과를 모두 12개를 사고, 8800원을 지불하였다. 귤과 사과는 몇 개씩 샀는지 구하라.

이 문제에는 귤과 사과의 개수를 더해서 12, 구매 금액을 모두 더해서 8800원이라는 두 개의 조건이 등장한다. 이 두 조건을 식으로 쓰면 다음과 같을 것이다.

  • 600 * 🍊 + 1000 * 🍎 = 8800
  • 🍊 + 🍎 = 12

이렇게 정리된 식을 단순 다항식이 아니라 행렬로 표기할 수 있을 것이다. 다음과 같이 말이다.

| 600 1000 | * | 🍊 | = | 8800 |
|   1    1 |   | 🍎 | = |   12 |

여기서 계수에 해당하는 앞의 2×2 행렬의 역행렬을 구해서 양변의 좌측에 곱해주면 방정식이 풀리게 된다. 이 원리를 사용해서 선형대수를 다룰 수 있는 라이브러리들은 선형방정식 풀이 방법을 제공한다. numpy를 사용해서 이 방정식을 풀어내는 코드는 다음과 같다.

import numpy as np
print(np.linalg.solve([[600, 1000], [1, 1]], [8800, 12]))
# -> [8., 4.]

사실 위에서 B는 1 * 2 행렬이기 때문에 [[8800], [12]] 가 되는 것이 맞지만, 편의상 2 * 1 로 써도 알아서 잘 풀어준다. 3원 일차 방정식의 경우에도 동일한 방법으로 풀 수 있다. 다른 식이 미지수의 개수만큼 있다면 3×3 행렬이나 4×4 행렬로 표현할 수 있기 때문에, 이 방식으로 풀어낼 수 있다.

Julia 에서는 행렬에 대한 연산을 기본적으로 제공하기 때문에 별다른 함수를 사용할 필요가 없다. \ 연산자를 사용하면 된다. (x \ yy / x와 같은 연산자로, 행렬을 나누는 것은 곧 역행렬을 곱하는 것으로 본다.)

> [600 1000; 1 1] \ [8800; 12]
2-element Array{Float64,1}:
 7.999999999999998
 4.000000000000001
> (Int ∘ round).([600 1000; 1 1] \ [8800; 12])
2-element Array{Int64,1}:
 8
 4

Read more

워드프레스에서 고스트로 이전

워드프레스에서 고스트로 이전

이 글을 쓰면서도 믿기 힘든 사실인데, 블로그라는 걸 처음 시작한지가 20년이 되었습니다. 이글루스에서 처음 시작했다가, SK컴즈가 인수한다고 발표함과 동시에 워드프레스로 플랫폼을 옮겼죠. 워드프레스오 옮긴 이후에는 호스팅 환경을 이리 저리 옮기긴 했지만 거의 18년 가까이 워드프레스를 사용해온 것 같습니다. 그 동안 워드프레스는 블로깅 툴에서 명실상부한 범용CMS로 발전했습니다. 사실 웬만한 홈페이지들은 이제

By sooop
띄어쓰기에 대한 생각

띄어쓰기에 대한 생각

업무 메일을 쓸 때 가장 많이 쓰는 말 중에 하나가 메일 말미에 ‘업무에 참고 부탁 드립니다.‘인데요, 어느 날부터 아웃룩에서 이 ‘부탁 드립니다’가 틀렸다고 맞춤법 지적을 하기 시작했습니다. 맞는 말은 ‘부탁드립니다’라고 붙여 쓰는 거라고. 사실 아래아한글 시절부터 이전의 MS워드까지, 워드프로세서들의 한국어 맞춤법 검사 실력은 거의 있으나 마나 한

By sooop

구글 포토에서 아이클라우드로 탈출한 후기

한 때 구글 포토가 백업 용량을 무제한으로 제공해 주겠다고해서, 구글 포토를 사용해서 사진을 백업해왔습니다. 물론 이 이야기의 결말은 저나 이 글을 읽고 있는 여러분이나 모두 알고 있습니다. 사실 AI에게 학습 시킬 이미지 데이터를 모으기 위한 것일 뿐이라거나 하는 이야기는 그 당시에도 있었습니다만, 에이 그래도 구글인데 용량은 넉넉하게 주겠지…하는 순진한

By sooop

Julia의 함수 사용팁

연산자의 함수적 표기 Julia의 연산자는 기본적으로 함수이며, 함수 호출 표기와 같은 방식으로 호출하는 것이 가능합니다. 또한 그 자체로 함수이기 때문에 filter(), map() 과 같이 함수를 인자로 받는 함수에도 연산자를 그대로 적용하는 것이 가능합니다. 특히 + 연산자는 sum() 함수와 같이 여러 인자를 받아 인자들의 합을 구할 수 있습니다. 2 + 3 # = 5 +(2,

By sooop