submitted
This commit is contained in:
parent
afb259bd6d
commit
029789a67c
352
markov.ipynb
352
markov.ipynb
File diff suppressed because one or more lines are too long
64
notebook.py
64
notebook.py
@ -53,7 +53,7 @@ plt.show()
|
|||||||
# %%
|
# %%
|
||||||
for obs in observations:
|
for obs in observations:
|
||||||
print(f'{obs} -> State 1: {gaussian(obs, state1.mean, state1.std_dev)},',
|
print(f'{obs} -> State 1: {gaussian(obs, state1.mean, state1.std_dev)},',
|
||||||
'State 2: {gaussian(obs, state2.mean, state2.std_dev)}')
|
f'State 2: {gaussian(obs, state2.mean, state2.std_dev)}')
|
||||||
|
|
||||||
|
|
||||||
# %%
|
# %%
|
||||||
@ -357,33 +357,39 @@ plt.show()
|
|||||||
# # Multiple Iterations
|
# # Multiple Iterations
|
||||||
|
|
||||||
# %%
|
# %%
|
||||||
iterations = 5
|
iterations = 50
|
||||||
|
|
||||||
mean = [state1.mean, state2.mean]
|
fig = plt.figure(dpi=fig_dpi, tight_layout=True)
|
||||||
var = [state1.variance, state2.variance]
|
ax = fig.add_subplot(1, 1, 1, xmargin=0, ymargin=0)
|
||||||
|
|
||||||
plt.plot(x, [gaussian(i, mean[0], sqrt(var[0])) for i in x], '--', c='r', linewidth=1.0)
|
iter_mean = [state1.mean, state2.mean]
|
||||||
plt.plot(x, [gaussian(i, mean[1], sqrt(var[1])) for i in x], '--', c='b', linewidth=1.0)
|
iter_var = [state1.variance, state2.variance]
|
||||||
|
iter_state_transitions = state_transition
|
||||||
|
|
||||||
|
ax.plot(x, [gaussian(i, iter_mean[0], sqrt(iter_var[0])) for i in x], '--', c='r', linewidth=1.0)
|
||||||
|
ax.plot(x, [gaussian(i, iter_mean[1], sqrt(iter_var[1])) for i in x], '--', c='b', linewidth=1.0)
|
||||||
|
|
||||||
label1=None
|
label1=None
|
||||||
label2=None
|
label2=None
|
||||||
|
|
||||||
for i in range(iterations):
|
for i in range(iterations):
|
||||||
model = MarkovModel(states=[State(mean[0], var[0], state1.entry, state1.exit),
|
iter_model = MarkovModel(states=[State(iter_mean[0], iter_var[0], state1.entry, state1.exit),
|
||||||
State(mean[1], var[1], state2.entry, state2.exit)],
|
State(iter_mean[1], iter_var[1], state2.entry, state2.exit)],
|
||||||
observations=observations,
|
observations=observations,
|
||||||
state_transitions=state_transition)
|
state_transitions=iter_state_transitions).populate()
|
||||||
model.populate()
|
|
||||||
|
|
||||||
mean = model.reestimated_mean()
|
# NEW PARAMETERS
|
||||||
var = model.reestimated_variance()
|
iter_mean = iter_model.reestimated_mean()
|
||||||
|
iter_var = iter_model.reestimated_variance()
|
||||||
|
iter_state_transitions[1:3, 1:3] = iter_model.reestimated_state_transitions()
|
||||||
|
|
||||||
print(f"mean ({i}): ", mean)
|
print(f"mean ({i}): ", iter_mean)
|
||||||
print(f"var ({i}): ", var)
|
print(f"var ({i}): ", iter_var)
|
||||||
|
print(iter_model.reestimated_state_transitions())
|
||||||
print()
|
print()
|
||||||
|
|
||||||
state_1_y = [gaussian(i, mean[0], sqrt(var[0])) for i in x]
|
state_1_y = [gaussian(i, iter_mean[0], sqrt(iter_var[0])) for i in x]
|
||||||
state_2_y = [gaussian(i, mean[1], sqrt(var[1])) for i in x]
|
state_2_y = [gaussian(i, iter_mean[1], sqrt(iter_var[1])) for i in x]
|
||||||
|
|
||||||
style = '--'
|
style = '--'
|
||||||
linewidth = 1.0
|
linewidth = 1.0
|
||||||
@ -393,22 +399,19 @@ for i in range(iterations):
|
|||||||
label1='State 1'
|
label1='State 1'
|
||||||
label2='State 2'
|
label2='State 2'
|
||||||
|
|
||||||
plt.plot(x, state_1_y, style, c='r', label=label1, linewidth=linewidth)
|
ax.plot(x, state_1_y, style, c='r', label=label1, linewidth=linewidth)
|
||||||
plt.plot(x, state_2_y, style, c='b', label=label2, linewidth=linewidth)
|
ax.plot(x, state_2_y, style, c='b', label=label2, linewidth=linewidth)
|
||||||
|
|
||||||
plt.title("Probability Density Function Iterations")
|
ax.set_title("Probability Density Function Iterations")
|
||||||
|
|
||||||
plt.xlabel(x_label)
|
ax.set_xlabel(x_label)
|
||||||
plt.ylabel(y_label)
|
ax.set_ylabel(y_label)
|
||||||
plt.grid(linestyle="--")
|
ax.grid(linestyle="--")
|
||||||
plt.legend()
|
ax.legend()
|
||||||
|
|
||||||
fig = matplotlib.pyplot.gcf()
|
if fig_export:
|
||||||
fig.set_dpi(fig_dpi)
|
|
||||||
fig.set_tight_layout(True)
|
|
||||||
if fig_export or True:
|
|
||||||
savefig("report/res/iterated-pdfs.png")
|
savefig("report/res/iterated-pdfs.png")
|
||||||
plt.show()
|
fig.show()
|
||||||
|
|
||||||
# %% [markdown]
|
# %% [markdown]
|
||||||
# # Baum-Welch State Transition Re-estimations
|
# # Baum-Welch State Transition Re-estimations
|
||||||
@ -419,6 +422,11 @@ model = MarkovModel(states=[state1, state2],
|
|||||||
state_transitions=state_transition).populate()
|
state_transitions=state_transition).populate()
|
||||||
|
|
||||||
print(a_matrix)
|
print(a_matrix)
|
||||||
|
print(model.reestimated_state_transitions())
|
||||||
model.reestimated_state_transitions()
|
model.reestimated_state_transitions()
|
||||||
|
|
||||||
|
|
||||||
|
# %%
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
% Encoding: UTF-8
|
@comment{x-kbibtex-encoding=utf-8}
|
||||||
|
|
||||||
@misc{towards-data-science-markov-intro,
|
@misc{towards-data-science-markov-intro,
|
||||||
author = {Rocca, Joseph},
|
author = {Joseph Rocca},
|
||||||
howpublished = {Online},
|
howpublished = {Online},
|
||||||
month = feb,
|
month = feb,
|
||||||
organization = {Towards Data Science},
|
organization = {Towards Data Science},
|
||||||
@ -10,52 +11,116 @@
|
|||||||
year = {2019}
|
year = {2019}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Article{numpy,
|
@article{numpy,
|
||||||
author = {Charles R. Harris and K. Jarrod Millman and St{'{e}}fan J. van der Walt and Ralf Gommers and Pauli Virtanen and David Cournapeau and Eric Wieser and Julian Taylor and Sebastian Berg and Nathaniel J. Smith and Robert Kern and Matti Picus and Stephan Hoyer and Marten H. van Kerkwijk and Matthew Brett and Allan Haldane and Jaime Fern{'{a}}ndez del R{'{\i}}o and Mark Wiebe and Pearu Peterson and Pierre G{'{e}}rard-Marchant and Kevin Sheppard and Tyler Reddy and Warren Weckesser and Hameer Abbasi and Christoph Gohlke and Travis E. Oliphant},
|
author = {Charles R. Harris and K. Jarrod Millman and St{'{e}}fan J. van der Walt and Ralf Gommers and Pauli Virtanen and David Cournapeau and Eric Wieser and Julian Taylor and Sebastian Berg and Nathaniel J. Smith and Robert Kern and Matti Picus and Stephan Hoyer and Marten H. van Kerkwijk and Matthew Brett and Allan Haldane and Jaime Fern{'{a}}ndez del R{'ı}o and Mark Wiebe and Pearu Peterson and Pierre G{'{e}}rard-Marchant and Kevin Sheppard and Tyler Reddy and Warren Weckesser and Hameer Abbasi and Christoph Gohlke and Travis E. Oliphant},
|
||||||
|
doi = {10.1038/s41586-020-2649-2},
|
||||||
journal = {Nature},
|
journal = {Nature},
|
||||||
title = {Array programming with {NumPy}},
|
|
||||||
year = {2020},
|
|
||||||
month = sep,
|
month = sep,
|
||||||
number = {7825},
|
number = {7825},
|
||||||
pages = {357--362},
|
pages = {357–362},
|
||||||
volume = {585},
|
|
||||||
doi = {10.1038/s41586-020-2649-2},
|
|
||||||
publisher = {Springer Science and Business Media {LLC}},
|
publisher = {Springer Science and Business Media {LLC}},
|
||||||
|
title = {Array programming with {NumPy}},
|
||||||
url = {https://doi.org/10.1038/s41586-020-2649-2},
|
url = {https://doi.org/10.1038/s41586-020-2649-2},
|
||||||
urldate = {2021-1-1},
|
urldate = {2021-1-1},
|
||||||
|
volume = {585},
|
||||||
|
year = {2020}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Misc{python,
|
@misc{python,
|
||||||
author = {Van Rossum, Guido and others},
|
author = {Guido {Van Rossum} and others},
|
||||||
howpublished = {Online},
|
howpublished = {Online},
|
||||||
title = {Python 3 Documentation},
|
title = {Python 3 Documentation},
|
||||||
year = {2008},
|
|
||||||
url = {https://docs.python.org/3/},
|
url = {https://docs.python.org/3/},
|
||||||
urldate = {2021-1-1},
|
urldate = {2021-1-1},
|
||||||
|
year = {2008}
|
||||||
}
|
}
|
||||||
|
|
||||||
@InProceedings{jupyter,
|
@inproceedings{jupyter,
|
||||||
author = {Thomas Kluyver and Benjamin Ragan-Kelley and Fernando P{\'e}rez and Brian Granger and Matthias Bussonnier and Jonathan Frederic and Kyle Kelley and Jessica Hamrick and Jason Grout and Sylvain Corlay and Paul Ivanov and Dami{\'a}n Avila and Safia Abdalla and Carol Willing and Jupyter development team},
|
|
||||||
booktitle = {Positioning and Power in Academic Publishing: Players, Agents and Agendas},
|
|
||||||
title = {Jupyter Notebooks - a publishing format for reproducible computational workflows},
|
|
||||||
year = {2016},
|
|
||||||
address = {Netherlands},
|
|
||||||
editor = {Fernando Loizides and Birgit Scmidt},
|
|
||||||
pages = {87--90},
|
|
||||||
publisher = {IOS Press},
|
|
||||||
abstract = {It is increasingly necessary for researchers in all fields to write computer code, and in order to reproduce research results, it is important that this code is published. We present Jupyter notebooks, a document format for publishing code, results and explanations in a form that is both readable and executable. We discuss various tools and use cases for notebook documents.},
|
abstract = {It is increasingly necessary for researchers in all fields to write computer code, and in order to reproduce research results, it is important that this code is published. We present Jupyter notebooks, a document format for publishing code, results and explanations in a form that is both readable and executable. We discuss various tools and use cases for notebook documents.},
|
||||||
|
address = {Netherlands},
|
||||||
|
author = {Thomas Kluyver and Benjamin Ragan-Kelley and Fernando Pérez and Brian Granger and Matthias Bussonnier and Jonathan Frederic and Kyle Kelley and Jessica Hamrick and Jason Grout and Sylvain Corlay and Paul Ivanov and Damián Avila and Safia Abdalla and Carol Willing and Jupyter development team},
|
||||||
|
booktitle = {Positioning and Power in Academic Publishing: Players, Agents and Agendas},
|
||||||
|
editor = {Fernando Loizides and Birgit Scmidt},
|
||||||
|
pages = {87–90},
|
||||||
|
publisher = {IOS Press},
|
||||||
|
title = {Jupyter Notebooks - a publishing format for reproducible computational workflows},
|
||||||
url = {https://eprints.soton.ac.uk/403913/},
|
url = {https://eprints.soton.ac.uk/403913/},
|
||||||
urldate = {2021-1-1},
|
urldate = {2021-1-1},
|
||||||
|
year = {2016}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Book{standford-hmm-book,
|
@book{standford-hmm-book,
|
||||||
author = {Dan Jurafsky and James H. Martin},
|
author = {Dan Jurafsky and James H. Martin},
|
||||||
title = {Speech and Language Processing},
|
|
||||||
year = {2020},
|
|
||||||
edition = {3 (Draft)},
|
|
||||||
chapter = {A},
|
chapter = {A},
|
||||||
url = {https://web.stanford.edu/~jurafsky/slp3/},
|
edition = {3 (Draft)},
|
||||||
|
title = {Speech and Language Processing},
|
||||||
|
url = {https://web.stanford.edu/~jurafsky/slp3/A.pdf},
|
||||||
urldate = {2021-1-3},
|
urldate = {2021-1-3},
|
||||||
|
year = {2020}
|
||||||
|
}
|
||||||
|
|
||||||
|
@comment{jabref-meta: databaseType:bibtex;}
|
||||||
|
|
||||||
|
@article{pj-h-forward-backward,
|
||||||
|
author = {Philip Jackson},
|
||||||
|
journaltitle = {EEEM030 - Speech \& Audio Processing \& Recognition},
|
||||||
|
month = nov,
|
||||||
|
number = {H},
|
||||||
|
organization = {University of Surrey},
|
||||||
|
pages = {H.4, H.6, H.12},
|
||||||
|
title = {HMM Likelihoods},
|
||||||
|
year = {2020}
|
||||||
|
}
|
||||||
|
|
||||||
|
@article{pj-h-baum-welch,
|
||||||
|
author = {Philip Jackson},
|
||||||
|
journaltitle = {EEEM030 - Speech \& Audio Processing \& Recognition},
|
||||||
|
month = nov,
|
||||||
|
number = {K},
|
||||||
|
organization = {University of Surrey},
|
||||||
|
pages = {K.13, K.14, K.15},
|
||||||
|
title = {HMM Training},
|
||||||
|
year = {2020}
|
||||||
|
}
|
||||||
|
|
||||||
|
@article{pj-h-pdf-re-estimate,
|
||||||
|
author = {Philip Jackson},
|
||||||
|
journaltitle = {EEEM030 - Speech \& Audio Processing \& Recognition},
|
||||||
|
month = nov,
|
||||||
|
number = {N},
|
||||||
|
organization = {University of Surrey},
|
||||||
|
pages = {N.8, N.12, N.13},
|
||||||
|
title = {Continuous HMM},
|
||||||
|
year = {2020}
|
||||||
|
}
|
||||||
|
|
||||||
|
@article{wolfram-gaussian,
|
||||||
|
author = {Eric W. Weisstein},
|
||||||
|
journalsubtitle = {A Wolfram Web Resource},
|
||||||
|
journaltitle = {MathWorld},
|
||||||
|
title = {Gaussian Function},
|
||||||
|
url = {https://mathworld.wolfram.com/GaussianFunction.html},
|
||||||
|
urldate = {2020-1-4}
|
||||||
|
}
|
||||||
|
|
||||||
|
@article{wolfram-monotone,
|
||||||
|
author = {Christopher Stover},
|
||||||
|
journalsubtitle = {A Wolfram Web Resource},
|
||||||
|
journaltitle = {MathWorld},
|
||||||
|
title = {Monotonic Function},
|
||||||
|
url = {https://mathworld.wolfram.com/MonotonicFunction.html},
|
||||||
|
urldate = {2020-1-5}
|
||||||
|
}
|
||||||
|
|
||||||
|
@article{hunter2007matplotlib,
|
||||||
|
author = {John D Hunter},
|
||||||
|
doi = {10.1109/MCSE.2007.55},
|
||||||
|
journal = {Computing in science \& engineering},
|
||||||
|
number = {3},
|
||||||
|
pages = {90–95},
|
||||||
|
publisher = {IEEE},
|
||||||
|
title = {Matplotlib: A 2D graphics environment},
|
||||||
|
volume = {9},
|
||||||
|
year = {2007}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Comment{jabref-meta: databaseType:bibtex;}
|
|
||||||
|
File diff suppressed because it is too large
Load Diff
Binary file not shown.
Before Width: | Height: | Size: 107 KiB After Width: | Height: | Size: 120 KiB |
174
scratchpad.ipynb
174
scratchpad.ipynb
File diff suppressed because one or more lines are too long
Loading…
Reference in New Issue
Block a user