기본 콘텐츠로 건너뛰기

추천 게시물

[Go] 고루틴

런타임(Runtime) visual code에서 브라우저 실행 단축키: Alt+B Go runtime은 메모리 관리, 가비지 수집, 동시성을 포함하여 Go 프로그림의 실행을 관리하는 역할을 합니다. 이 문서에서는 Go runtime을 자세히 살펴보고 아키텍초, 특성과 장점을 살펴봅니다. Go Runtime Architecture Go runtime은 모듈식이고 유연하게 설계되었으며 개발자가 특정 요구사항에 따라 동작을 사용자 정의할 수 있는 계층적 아키텍쳐를 갖추고 있습니다. 런타임은 스케줄러(schedualer), 가비지 수집기(garbage collector), 메모리 할당자(memory alllocator) 및 스택관리(stack management)를 포함한 어려 핵심 구성 요소로 구성됩니다. Schedualer Go 런타임의 핵심은 고루틴의 실행을 관리하는 스케줄러입니다. 고루틴은 효율적인 동시성을 가능하게 하는 가벼운 스레드입니다. 스케줄러는 사용 가능한 스레드에 고루틴을 분산하고, 스레드 로컬 스토리지를 관리하고, I/O 작업을 조정하는 역할을 합니다. thread(스레드): 프로그램 내에서 실행되는 흐름의 단위로 동시에 여러 작업이나 프로그램을 실행하는 것입니다. 즉, 코드를 실행할 수 있는 각 단위를 스레드라고 합니다. 고루틴(goroutine): Go 언어로 동시에 실행되는 모든 활동을 의미합니다. 고루틴을 만드는 비용을 스레드에 비해 매우 적기 떄문에 경량 스레드라고 합니다. 모든 프로그램은 적어도 하나의 main() 함수라는 고루틴을 포함하고 고루틴은 항상 백그라운드에서 작동합니다. 메인함수가 종료되면 모든 고루틴은 종료됩니다. 그러므로 고루틴보다 main이 먼저 종료되는 것을 방지해야 합니다. Go 스케줄러는 매우 효율적이고 확장 가능하도록 설계되어 많은 수의 동시 고루틴을 손쉽게 처리할 수 있습니다. 스레드 간에 부하를 분산하여 경합을 최소화하고 성능을 개선하는 작업 훔치기 알고리즘을 사용합니다...

블랙 숄츠 모델(Black-Scholes model)

블랙 숄츠 모델(Black-Scholes model)

주식이 수익률이 정규분포를 따른다고 가정

현 주가가 100, 한달 후 행사가격이 110인 콜 옵션인 경우 콜옵션의 가치는(만기의 주식가격 - 행사가격, 0 이하일 경우 권리 포기) 10입니다. 정규분포를 가정하므로 110이 될 확률을 계산할 수 있고 그 가격에서 기대값을 계산할 수 있습니다. 연속변수이므로 지점 확률을 계산할 수 없지만 가격간의 간격이 5원이라면 110~115사이에 존재할 확률은 계산할 수 있습니다.

다음은 평균이 100이고 표준편차가 10인 정규분포를 가정합니다.

import numpy as np 
import pandas as pd 
from scipy import stats
import matplotlib.pyplot as plt
plt.rcParams['font.family'] ='NanumGothic'
plt.rcParams['axes.unicode_minus'] =False
d=np.sort(stats.norm.rvs(loc=100, scale=10, size=1000, random_state=1))
p=stats.norm.pdf(d, loc=100, scale=10)
d2idx=np.where(d>=110)[0]
p2=stats.norm.pdf(d[d2idx], loc=100, scale=10)
plt.figure(figsize=(4,3))
plt.plot(d, p)
plt.fill_between(d[d2idx], p2, color="g", alpha=0.6)
plt.xlabel("x")
plt.ylabel("prob.")
plt.show()

위 그래프의 녹색에 대한 기대값은 다음과 같습니다. 행사가격 110에 대한 기대값은 다음과 같습니다.

np.sum((d[d2idx]-100)*p2)
30.895426539137873
10*(stats.norm.cdf(115, 100, 10)-stats.norm.cdf(105, 100, 10))
2.417303374571288

오리지널 블랙 숄츠 모델은 다음과 같은 가정들이 필요하다. 그러나 몇몇은 조금 변형시켜서 적용이 가능합니다.

  • 자산(asset)에 대한 가정
    • 무위험자산: 변화 없이 일정한 수익을 주는 채권이 존재한다. '무위험 수익률'이라고 부르며 보통 미국 국채(T-Bill)의 수익률을 사용합니다.
    • 랜덤워크(random walk): 주식의 수익률은 정규분포 (브라운 운동), 가격은 로그 정규분포를 따릅니다. 왜 수익률은 정규분포고 가격은 로그 정규분포냐 하면, 가격에 로그를 붙여서 수익률을 구할 수 있기 때문입니다. 로그 수익률이라는 것은 전 날 종가와 오늘 종가의 로그의 차이를 말합니다.
      • \begin{align}r_t&=\ln(P_t)-\ln(P_{t-1})\\&=\ln\left(\frac{P_t}{P_{t-1}}\right)\\&r_t:\; \text{로그수익률}\\&P_t:\;\text{t날의 종가} \end{align}(식 1)
  • 시장(market)에 대한 가정
    • 동일한 자산은 같은 시장 가격을 가지며 차이가 발생한다면 차익거래가 생겨서 다시 가격이 같아집니다.
    • 무위험 이자율로 원하는 만큼의 금액을 빌리거나 빌려줄 수 있습니다.
    • 공매도를 포함하여, 원하는 만큼의 주식을 사거나 팔 수 있습니다.
    • 거래할때 거래 비용이 거의 없습니다.

    옵션 가격은 주가에 기반하므로 주가가 1원 오르면 콜옵션도 일정 비율만큼 오르며 이 비율을 델타(δ)라고 합니다. 주식을 δ만큼 사고 콜옵션을 팔면 움직임이 정확히 상쇄되어서 변동이 없다. 변동이 없으면 위험이 없다는 말이니 이 조합의 수익률은 무위험 채권과 같다. 여기에 주식 가격이 로그 정규분포를 따른다는 가정하고 주가가 로그 정규분포를 따르면 주식의 수익률은 정규분포를 따르게 된다. 이제 수식을 정리하면 (이 과정에서 이토의 보조정리[4]같은 수학 테크닉이 몇개 들어간다) 주가와 옵션, 무위험 채권에 대한 미분방정식(식 2)을 얻는다.

    \begin{align} rV&=rS\frac{\partial V}{\partial S}+\frac{\partial V}{\partial T}+\frac{1}{2}\sigma^2 S^2\frac{\partial^2 V}{\partial S^2}\\ &V:\;\text{옵션의 가격}\\&S:\;\text{주가}\\&r:\;\text{무위험 이자율(risk-free interest rate)}\end{align}(식 2)

    식 2로부터 유도되는 식 3(블랙-숄츠 모델)으로 콜 옵션과 풋옵션 가격을 결정할 수 있습니다.

    \begin{align} c&=S\Phi(d_1)-K\exp(-rt)\Phi(d_2)\\ p&=K\exp(-rt)\Phi(d_2)-S\Phi(d_1)\\ d_1&=\frac{\ln(\frac{S}{K})+\left(r+\frac{\sigma}{2}\right)T}{\sigma \sqrt{T}}\\d_2&=\frac{\ln(\frac{S}{K})+\left(r-\frac{\sigma}{2}\right)T}{\sigma \sqrt{T}}\\& c, p:\; \text{콜옵션 가격, 풋옵션가격}\\&S:\;\text{0시점에서의 기초자산가격}\\& \Phi(x):\;\text{표준정규분포의 누적분포함수}\\& k:\;\text{행사가격}\\&K:\;\text{행사가격}\\&r:\;\text{무위험 이자율}\\&T:\;\text{옵션만기까지 남은 기간}\\&\sigma:\;\text{주가의 변동성}\end{align}(식 3)

    블랙-숄츠 모델로부터 파생되는 수많은 옵션가격 지표들이 있습니다.

    • 델타(δ) : 기초자산 가격의 변동에 따른 옵션가치변동
    • 쎄다(θ) : 시간에 따른 옵션가치 변동
    • 감마(γ) : 기초자산 가격의 변동에 따른 δ의 변동
    • 베가(ν): 기초자산가격 변동성의 변화에 따른 옵션 가치변동
    • 로(ρ): 금리의 변동에 따른 옵션가치변동

댓글

이 블로그의 인기 게시물

[python]KeyWord

keywords Characters or strings already used to define basic commands in programming languages such as python are called reserved words. This reserved word cannot be used when defining objects such as variables, functions, and classes when coding by the user. python has 33 reserved words, and it distinguishes between lowercase and uppercase letters in Engolsh. All other keywords are lowercase except True, False, None, etc. a and, as, assert, async, await b break c class, continue d def, del e eolf, else, except f False, finally, for, from g global i in, if, import, is l lambda n nonlocal, None, not o or r raise, return p pass ...

[Go] 고루틴

런타임(Runtime) visual code에서 브라우저 실행 단축키: Alt+B Go runtime은 메모리 관리, 가비지 수집, 동시성을 포함하여 Go 프로그림의 실행을 관리하는 역할을 합니다. 이 문서에서는 Go runtime을 자세히 살펴보고 아키텍초, 특성과 장점을 살펴봅니다. Go Runtime Architecture Go runtime은 모듈식이고 유연하게 설계되었으며 개발자가 특정 요구사항에 따라 동작을 사용자 정의할 수 있는 계층적 아키텍쳐를 갖추고 있습니다. 런타임은 스케줄러(schedualer), 가비지 수집기(garbage collector), 메모리 할당자(memory alllocator) 및 스택관리(stack management)를 포함한 어려 핵심 구성 요소로 구성됩니다. Schedualer Go 런타임의 핵심은 고루틴의 실행을 관리하는 스케줄러입니다. 고루틴은 효율적인 동시성을 가능하게 하는 가벼운 스레드입니다. 스케줄러는 사용 가능한 스레드에 고루틴을 분산하고, 스레드 로컬 스토리지를 관리하고, I/O 작업을 조정하는 역할을 합니다. thread(스레드): 프로그램 내에서 실행되는 흐름의 단위로 동시에 여러 작업이나 프로그램을 실행하는 것입니다. 즉, 코드를 실행할 수 있는 각 단위를 스레드라고 합니다. 고루틴(goroutine): Go 언어로 동시에 실행되는 모든 활동을 의미합니다. 고루틴을 만드는 비용을 스레드에 비해 매우 적기 떄문에 경량 스레드라고 합니다. 모든 프로그램은 적어도 하나의 main() 함수라는 고루틴을 포함하고 고루틴은 항상 백그라운드에서 작동합니다. 메인함수가 종료되면 모든 고루틴은 종료됩니다. 그러므로 고루틴보다 main이 먼저 종료되는 것을 방지해야 합니다. Go 스케줄러는 매우 효율적이고 확장 가능하도록 설계되어 많은 수의 동시 고루틴을 손쉽게 처리할 수 있습니다. 스레드 간에 부하를 분산하여 경합을 최소화하고 성능을 개선하는 작업 훔치기 알고리즘을 사용합니다...

매개변수 추정 도구: PDF, CDF 및 분위수 함수

매개변수 추정 도구: PDF, CDF 및 분위수 함수 확률 밀도 함수(PDF)에 대해 자세히 다루고, 값 범위의 확률을 보다 쉽게 결정하는 데 도움이 되는 누적 분포 함수(CDF)를 소개하고, 확률 분포를 동일한 확률로 나누는 분위수를 소개합니다. 예를 들어, 백분위수는 100분위수이며, 이는 확률 분포를 100개의 동일한 부분으로 나눈다는 것을 의미합니다. 이메일 가입 목록에 대한 전환율 추정 블로그를 운영하고 블로그 방문자가 이메일 목록에 가입할 확률을 알고 싶다고 가정해 보겠습니다. 마케팅 용어로 사용자가 원하는 이벤트를 수행하도록 하는 것을 전환 이벤트 또는 간단히 전환이라고 하며, 사용자가 가입할 확률을 전환율이라고 합니다. 구독자 수 k와 방문자 총 수 n을 알고 있을 때 구독 확률 p를 추정하기 위해 베타 분포를 사용할 것입니다. 베타 분포에 필요한 두 가지 매개변수는 α로, 이 경우 구독자 총 수(k)를 나타내고, β는 구독하지 않은 총 수(n – k)를 나타냅니다. 확률 밀도 함수 첫 40,000명의 방문자에 대해 300명의 구독자를 얻는다고 가정해 보겠습니다. 우리 문제에 대한 PDF는 α = 300이고 β = 39,700인 베타 분포입니다. 베타 분포의 평균 계산 $$\tag{1}\mu_{\text{beta}}=\frac{\alpha}{\alpha + \beta}$$ 식 1을 사용하여 방문자 중의 구독자에 대한 평균은 다음과 같이 계산됩니다. import numpy as np import pandas as pd from scipy import stats, special import itertools from sympy import * import matplotlib.pyplot as plt import seaborn as sns sns.set_style("darkgrid") def decorate_plot(xlab, ylab, title=None, size=(4,3)): plt.figu...