마침내 나는 그것을 얻었다. 여기 내 대답이 있습니다.
마지막으로 방향 통계 (Mardia and Jupp, 1999)와 Ulrich-Wood의 샘플링 알고리즘에 손을 댔습니다 . 여기에서 내가 이해 한 것, 즉 내 코드 (Python)를 게시합니다.
거부 샘플링 방식 :
def rW(n, kappa, m):
dim = m-1
b = dim / (np.sqrt(4*kappa*kappa + dim*dim) + 2*kappa)
x = (1-b) / (1+b)
c = kappa*x + dim*np.log(1-x*x)
y = []
for i in range(0,n):
done = False
while not done:
z = sc.stats.beta.rvs(dim/2,dim/2)
w = (1 - (1+b)*z) / (1 - (1-b)*z)
u = sc.stats.uniform.rvs()
if kappa*w + dim*np.log(1-x*w) - c >= np.log(u):
done = True
y.append(w)
return y
그런 다음 원하는 샘플링은 v 1 - w2−−−−−−√+ w μ승V
def rvMF(n,theta):
dim = len(theta)
kappa = np.linalg.norm(theta)
mu = theta / kappa
result = []
for sample in range(0,n):
w = rW(n, kappa, dim)
v = np.random.randn(dim)
v = v / np.linalg.norm(v)
result.append(np.sqrt(1-w**2)*v + w*mu)
return result
이 코드로 효과적으로 샘플링하기위한 예제는 다음과 같습니다.
import numpy as np
import scipy as sc
import scipy.stats
n = 10
kappa = 100000
direction = np.array([1,-1,1])
direction = direction / np.linalg.norm(direction)
res_sampling = rvMF(n, kappa * direction)
scipy.stats.vonmises
은 배열과 같을 수 있으므로 분포를로 지정할 수 있습니다array
. 이 참조 예