本文整理匯總了Python中msmbuilder.msm.ContinuousTimeMSM.uncertainty_timescales方法的典型用法代碼示例。如果您正苦於以下問題:Python ContinuousTimeMSM.uncertainty_timescales方法的具體用法?Python ContinuousTimeMSM.uncertainty_timescales怎麽用?Python ContinuousTimeMSM.uncertainty_timescales使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類msmbuilder.msm.ContinuousTimeMSM
的用法示例。
在下文中一共展示了ContinuousTimeMSM.uncertainty_timescales方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_uncertainties_backward
# 需要導入模塊: from msmbuilder.msm import ContinuousTimeMSM [as 別名]
# 或者: from msmbuilder.msm.ContinuousTimeMSM import uncertainty_timescales [as 別名]
def test_uncertainties_backward():
n = 4
grid = NDGrid(n_bins_per_feature=n, min=-np.pi, max=np.pi)
seqs = grid.fit_transform(load_doublewell(random_state=0)['trajectories'])
model = ContinuousTimeMSM(verbose=False).fit(seqs)
sigma_ts = model.uncertainty_timescales()
sigma_lambda = model.uncertainty_eigenvalues()
sigma_pi = model.uncertainty_pi()
sigma_K = model.uncertainty_K()
yield lambda: np.testing.assert_array_almost_equal(
sigma_ts, [9.13698928, 0.12415533, 0.11713719])
yield lambda: np.testing.assert_array_almost_equal(
sigma_lambda, [1.76569687e-19, 7.14216858e-05, 3.31210649e-04, 3.55556718e-04])
yield lambda: np.testing.assert_array_almost_equal(
sigma_pi, [0.00741467, 0.00647945, 0.00626743, 0.00777847])
yield lambda: np.testing.assert_array_almost_equal(
sigma_K,
[[ 3.39252419e-04, 3.39246173e-04, 0.00000000e+00, 1.62090239e-06],
[ 3.52062861e-04, 3.73305510e-04, 1.24093936e-04, 0.00000000e+00],
[ 0.00000000e+00, 1.04708186e-04, 3.45098923e-04, 3.28820213e-04],
[ 1.25455972e-06, 0.00000000e+00, 2.90118599e-04, 2.90122944e-04]])
yield lambda: np.testing.assert_array_almost_equal(
model.ratemat_,
[[ -2.54439564e-02, 2.54431791e-02, 0.00000000e+00, 7.77248586e-07],
[ 2.64044208e-02,-2.97630373e-02, 3.35861646e-03, 0.00000000e+00],
[ 0.00000000e+00, 2.83988103e-03, -3.01998380e-02, 2.73599570e-02],
[ 6.01581838e-07, 0.00000000e+00, 2.41326592e-02, -2.41332608e-02]])
示例2: test_uncertainties_backward
# 需要導入模塊: from msmbuilder.msm import ContinuousTimeMSM [as 別名]
# 或者: from msmbuilder.msm.ContinuousTimeMSM import uncertainty_timescales [as 別名]
def test_uncertainties_backward():
n = 4
grid = NDGrid(n_bins_per_feature=n, min=-np.pi, max=np.pi)
trajs = DoubleWell(random_state=0).get_cached().trajectories
seqs = grid.fit_transform(trajs)
model = ContinuousTimeMSM(verbose=False).fit(seqs)
sigma_ts = model.uncertainty_timescales()
sigma_lambda = model.uncertainty_eigenvalues()
sigma_pi = model.uncertainty_pi()
sigma_K = model.uncertainty_K()
yield lambda: np.testing.assert_array_almost_equal(
sigma_ts, [9.508936, 0.124428, 0.117638])
yield lambda: np.testing.assert_array_almost_equal(
sigma_lambda,
[1.76569687e-19, 7.14216858e-05, 3.31210649e-04, 3.55556718e-04])
yield lambda: np.testing.assert_array_almost_equal(
sigma_pi, [0.007496, 0.006564, 0.006348, 0.007863])
yield lambda: np.testing.assert_array_almost_equal(
sigma_K,
[[0.000339, 0.000339, 0., 0.],
[0.000352, 0.000372, 0.000122, 0.],
[0., 0.000103, 0.000344, 0.000329],
[0., 0., 0.00029, 0.00029]])
yield lambda: np.testing.assert_array_almost_equal(
model.ratemat_,
[[-0.0254, 0.0254, 0., 0.],
[0.02636, -0.029629, 0.003269, 0.],
[0., 0.002764, -0.030085, 0.027321],
[0., 0., 0.024098, -0.024098]])
示例3: test_doublewell
# 需要導入模塊: from msmbuilder.msm import ContinuousTimeMSM [as 別名]
# 或者: from msmbuilder.msm.ContinuousTimeMSM import uncertainty_timescales [as 別名]
def test_doublewell():
X = load_doublewell(random_state=0)['trajectories']
for i in range(3):
Y = NDGrid(n_bins_per_feature=10).fit_transform([X[i]])
model1 = MarkovStateModel(verbose=False).fit(Y)
model2 = ContinuousTimeMSM().fit(Y)
print('MSM uncertainty timescales:')
print(model1.uncertainty_timescales())
print('ContinuousTimeMSM uncertainty timescales:')
print(model2.uncertainty_timescales())
print()
示例4: test_hessian_2
# 需要導入模塊: from msmbuilder.msm import ContinuousTimeMSM [as 別名]
# 或者: from msmbuilder.msm.ContinuousTimeMSM import uncertainty_timescales [as 別名]
def test_hessian_2():
n = 3
seqs = [
[1, 1, 1, 1, 1, 2, 2, 2, 2, 1, 1, 1, 1, 2, 3, 3, 3, 3, 3, 2, 2, 2, 2, 2,
2, 1, 1, 1, 1, 2, 3, 3, 3, 3]]
model = ContinuousTimeMSM().fit(seqs)
print(model.timescales_)
print(model.uncertainty_timescales())
theta = model.theta_
C = model.countsmat_
print(C)
C_flat = (C + C.T)[np.triu_indices_from(C, k=1)]
print(C_flat)
print('theta', theta, '\n')
inds = np.where(theta != 0)[0]
hessian1 = _ratematrix.hessian(theta, C, inds=inds)
hessian2 = nd.Jacobian(lambda x: _ratematrix.loglikelihood(x, C)[1])(theta)
hessian3 = nd.Hessian(lambda x: _ratematrix.loglikelihood(x, C)[0])(theta)
np.set_printoptions(precision=3)
# H1 = hessian1[np.ix_(active, active)]
# H2 = hessian2[np.ix_(active, active)]
# H3 = hessian2[np.ix_(active, active)]
print(hessian1, '\n')
print(hessian2, '\n')
# print(hessian3)
print('\n')
info1 = np.zeros((len(theta), len(theta)))
info2 = np.zeros((len(theta), len(theta)))
info1[np.ix_(inds, inds)] = scipy.linalg.pinv(-hessian1)
info2[np.ix_(inds, inds)] = scipy.linalg.pinv(-hessian2[np.ix_(inds, inds)])
print('Inverse Hessian')
print(info1)
print(info2)
# print(scipy.linalg.pinv(hessian2))
# print(scipy.linalg.pinv(hessian1)[np.ix_(last, last)])
# print(scipy.linalg.pinv(hessian2)[np.ix_(last, last)])
print(_ratematrix.sigma_pi(info1, theta, n))
print(_ratematrix.sigma_pi(info2, theta, n))