728x90

Reference

wikidocs.net/1153

 

산술 연산자 (Arithmetic Operators):

a = 10, b = 20, c = 3 이라 가정한다.

OperatorDescriptionExample

+ 더하기 a + b = 30
- 빼기 a - b = -10
* 곱하기 a * b = 200
/ 나누기 b / a = 2.0
% 나머지 b % a = 0
** 제곱 a ** c = 1000
// a // c = 3
728x90

'Dev > Python' 카테고리의 다른 글

[Python] from import와 import의 차이  (0) 2020.08.08
728x90

Reference

wikidocs.net/53560

economicslab.tistory.com/m/16108

 

 

머신 러닝에서 식을 세울때 이 식을 가설(Hypothesis)라고 합니다. 보통 머신 러닝에서 가설은 임의로 추측해서 세워보는 식일수도 있고, 경험적으로 알고 있는 식일 수도 있습니다. 그리고 맞는 가설이 아니라고 판단되면 계속 수정해나가게 되는 식이기도 합니다.

선형 회귀의 가설은 이미 널리 알려져있으므로 고민할 필요가 없습니다. 선형 회귀란 학습 데이터와 가장 잘 맞는 하나의 직선을 찾는 일입니다. 이때 선형 회귀의 가설(직선의 방정식)은 아래와 같은 형식을 가집니다.

y=Wx+by=Wx+b

가설의 HH를 따서 yy 대신 다음과 같이 식을 표현하기도 합니다.

H(x)=Wx+bH(x)=Wx+b

이때 xx와 곱해지는 WW를 가중치(Weight)라고 하며, bb를 편향(bias)이라고 합니다.

  • WW bb는 중학교 수학 과정인 직선의 방정식에서 기울기와 y절편에 해당됩니다.
  • 직선의 방정식 링크 : https://mathbang.net/443

 

비용 함수(cost function) = 손실 함수(loss function) = 오차 함수(error function) = 목적 함수(objective function)
특히 비용 함수와 손실 함수란 용어는 기억해두는 것이 좋음

 

수학에서 느낌이라는 표현을 사용하는 것은 아무런 의미도 없습니다. 어떤 직선이 가장 적절한 직선인지를 수학적인 근거를 대서 표현할 수 있어야 합니다. 그래서 오차(error)라는 개념을 도입하겠습니다.

 

위 그림은 임의로 그려진 주황색 선에 대해서 각 실제값(4개의 점)과 직선의 예측값(동일한 x값에서의 직선의 y값)에 대한 값의 차이를 빨간색 화살표 ↕로 표현한 것입니다. 각 실제값과 각 예측값과의 차이고, 이를 각 실제값에서의 오차라고 말할 수 있습니다. 이 직선의 예측값들과 실제값들과의 총 오차(total error)는 어떻게 구할까요? 직관적으로 생각하기에 모든 오차를 다 더하면 될 것 같습니다. 각 오차를 전부 더해봅시다.

 

각 오차를 계산해봤습니다. 그런데 수식적으로 단순히 '오차 = 실제값 - 예측값'으로 정의하면 오차값이 음수가 나오는 경우가 생깁니다. 예를 들어 위의 표에서만 봐도 오차가 음수인 경우가 3번이나 됩니다.

이 경우, 오차를 모두 더하면 덧셈 과정에서 오차값이 +가 되었다가 -되었다가 하므로 제대로 된 오차의 크기를 측정할 수 없습니다. 그래서 오차를 그냥 전부 더하는 것이 아니라, 각 오차들을 제곱해준 뒤에 전부 더하겠습니다.

 

n은 갖고 있는 데이터의 개수를 의미합니다.

이때 데이터의 개수인 n으로 나누면, 오차의 제곱합에 대한 평균을 구할 수 있는데 이를 평균 제곱 오차(Mean Squared Error, MSE)라고 합니다.

 

평균 제곱 오차는 이번 회귀 문제에서 적절한 W b를 찾기위해서 최적화된 식입니다. 그 이유는 평균 제곱 오차의 값을 최소값으로 만드는 W와 b를 찾아내는 것이 가장 훈련 데이터를 잘 반영한 직선을 찾아내는 일이기 때문입니다. ==> 즉 문제를 해결하는 방법

 

평균 제곱 오차를 W b에 의한 비용 함수(Cost function)로 재정의해보면 다음과 같습니다.

cost(W,b)=1ni=1n[y(i)H(x(i))]2cost(W,b)=1n∑i=1n[y(i)−H(x(i))]2

 

다시 정리하겠습니다. Cost(W,b)를 최소가 되게 만드는 W b를 구하면 훈련 데이터를 가장 잘 나타내는 직선을 구할 수 있습니다.

 

 

Q. 음수가 되는걸 방지하기 위해서 왜 오차값을 제곱하는가?

==> 제곱이 아닌 절대값을 쓰면 안되는가? (참고: economicslab.tistory.com/m/16108)

 

주어진 값들이 얼마나 퍼져있는지 정도를 나타내는 지표 중 하나인 분산은 평균과 각 값의 차이를 "제곱"한 평균으로 구한다.
이 식을 볼 때마다, "제곱"을 하지 말고 그냥 "절대값"을 쓰면 되지 않을까? (분산의 제곱 대신, 절대값을 쓴 것을 평균제곱오차라고 부른다)
사실 결론부터 얘기하자면, 현재의 분산을 많이 쓰는 이유는 분산이 unbiased estimator를 구하기 쉽기 때문이다. 실제로 표본분산의 경우는 모분포가 어떤 모양이든지 상관없이 모분산의 unbiased estimator가 되지만, 표본표준편차나 표본절대편차는 그렇지 않다. 

 

 

제곱을 한 것을 최소제곱법(method of least squares) 혹은 평균제곱편차(MSE; Mean Square Error), 절대값을 취한 것을 평균절대편차(MAD; Mean Absolute Deviation)이라고 부름.

 

다음 예를 살펴보자.
1)
True: 60, 64, 67
Predicted: 57, 61, 70
Error = +3, +3, -3
2)
True: 60, 64, 67
Predicted: 59, 65, 73
Error: +1, -1, -6
1)의 경우 MAD= 3, MSE=9로 계산되고,
2)의 경우 MAD=2.67, MSE=12.67로 계산된다.
True가 똑같지만, 아마 추정할 때 쓴 모형이 달랐을 것인데, 1)의 경우에 비해 2)의 경우 MAD가 더 좋게 나타났다.
자세히 살펴보면, Predicted가 True와 차이가 큰 경우가 하나라도 있을 경우 MSE는 큰 패널티를 주는 반면, MAD는 조금은 관대한 결과를 낸다고 볼 수 있다.
상황에 따라 큰 패널티를 주는 것이 맞을 수도, 아닐 수도 있기 때문에, MAD나 MSE 둘 중 무엇이 더 좋은 방법이라고 이야기하기는 어렵다. 이에 대한 충분한 상황 설명이 있어야 하거나, 다양한 지표를 두고 함께 비교해야하는 이유가 여기에 있는 것이다.

 

728x90
728x90

cloudrain21.com/python-difference-between-import-from-import

# os 모듈의 getpid 를 getpid 라는 이름으로 import
>>> from os import getpid                         

# 현재 scope 에서는 os 라는 존재는 모르고
# os.getpid 를 가리키는 getpid 만 있으므로 에러
>>> os.getpid()

 

728x90

'Dev > Python' 카테고리의 다른 글

[Python] 산술연산자  (0) 2020.08.08
728x90

 

오류내용

mysql> ERROR 1366 (HY000): Incorrect string value: '\xEB\xB2\x88 \xED\x94...

 

요즘 리눅스에서 MySQL을 설치하면 이 캐릭터셋 설정을

/etc/mysql/mysql.conf.d/ 아래에 각 파일별로 저장을 해놓아야함

 

client.cnf
[client]
default-character-set=utf8


mysqld.cnf
[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
init_connect=SET collation_connection=utf8_general_ci
init_connect=SET NAMES utf8


mysqldump.cnf
[mysqldump]
default-character-set=utf8


mysql.cnf
[mysql]
default-character-set=utf8

 

euckr로 변경시

위의 파일들 utf-8 ==> euckr로 변경 및

[mysqld]
default-character-set=euckr
init_connect=SET collation_connection=euckr_korean_ci
init_connect=SET NAMES euckr
character-set-server=euckr
collation-server=euckr_korean_ci

 

 

+ 특정 데이터베이스 전체 언어셋 변경 쿼리문

mysql> alter database [DB명] default character set euckr collate euckr_korean_ci;

mysql> alter database [DB명] default character set utf-8 collate utf8_general_ci;

 

변경 상태 확인

mysql> status;

 

 

그뒤에는

 

sudo systemctl restart mysql;

 

 

Reference

https://avengersrhydon1121.tistory.com/162

https://zzznara2.tistory.com/765

https://tmdgus.tistory.com/152

http://dohyunworlds.blogspot.com/2016/08/mysql-utf-8-euckr.html

https://lovelydiary.tistory.com/60

728x90

'Dev > DB' 카테고리의 다른 글

Oracle - OVER() 함수 설명  (0) 2020.08.26
[MySQL] 다중 update 쿼리 방법  (0) 2020.07.07
[MySQL] batch작업  (0) 2020.07.02
[MySQL/Oracle] Merge Into 관련 (ON DUPLICATE KEY)  (0) 2020.06.30
[MyBatis] Like 처리 방법  (0) 2020.06.30

+ Recent posts