Created
July 14, 2017 00:59
-
-
Save maxentile/2513e80015c249580f5a2be94f56a8b0 to your computer and use it in GitHub Desktop.
Cartoon placeholder for illustrating work measurement scheme
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import numpy as np | |
import matplotlib.pyplot as plt | |
# without velocity randomization | |
np.random.seed(0) | |
plt.figure(figsize=(6,3)) | |
protocol_length = 25 | |
x_1 = np.arange(protocol_length) | |
x_2 = np.arange(protocol_length) + protocol_length | |
eps_scale = 0.01 | |
distance_1 = np.tanh(x_1 / (protocol_length/3)) + eps_scale * np.random.randn(protocol_length) | |
distance_2 = np.tanh(x_2 / (protocol_length/3)) + eps_scale * np.random.randn(protocol_length) | |
work_1 = distance_1 + np.arange(protocol_length) / protocol_length + eps_scale * np.random.randn(protocol_length) | |
work_2 = np.arange(protocol_length)/ protocol_length + eps_scale * np.random.randn(protocol_length) | |
KL_div_rho_to_pi = max(distance_1) | |
distance_color = 'blue' | |
work_color = 'green' | |
def cartoon_plot_distance(ax): | |
#ax.set_title("Work") | |
ax.plot(x_1, distance_1, color=distance_color) | |
plt.vlines(x_2[0] - 0.5, 0, KL_div_rho_to_pi, linestyles='--') | |
ax.plot(x_2, distance_2, color=distance_color) | |
ax.spines['top'].set_visible(False) | |
ax.spines['right'].set_visible(False) | |
plt.yticks([]) | |
plt.yticks([0, KL_div_rho_to_pi], [r"$\pi$", r"$\rho$"]) | |
plt.ylim([-0.1, KL_div_rho_to_pi + 0.1]) | |
plt.ylabel(r"$D_{KL}$") | |
plt.hlines(KL_div_rho_to_pi, 0, protocol_length*2, linestyles='--') | |
def cartoon_plot_work(ax): | |
#ax.set_title("Work") | |
ax.plot(x_1, work_1, color=work_color) | |
plt.vlines(x_2[0] - 0.5, 0, work_1[-1], linestyles='--') | |
ax.plot(x_2, work_2, color=work_color) | |
ax.spines['top'].set_visible(False) | |
ax.spines['right'].set_visible(False) | |
plt.yticks([]) | |
plt.xticks([0, protocol_length - 0.5, 2 * protocol_length], ["0", "M", "2M"]) | |
plt.xlabel("Steps")#, horizontalalignment="right") # doesn't seem to do anything? | |
plt.ylabel("Work") | |
ax1 = plt.subplot(2,1,1) | |
cartoon_plot_distance(ax1) | |
ax2 = plt.subplot(2,1,2, sharex=ax1) | |
cartoon_plot_work(ax2) | |
plt.tight_layout() | |
plt.savefig("fig2-cartoon.jpg", dpi=300) | |
plt.close() | |
# with velocity randomization | |
np.random.seed(0) | |
plt.figure(figsize=(6,3)) | |
x_1 = np.arange(protocol_length) | |
x_2 = np.arange(protocol_length) + protocol_length | |
distance_2 = np.tanh((x_1 + protocol_length/5) / (protocol_length/3)) + eps_scale * np.random.randn(protocol_length) | |
work_1 = distance_1 + np.arange(protocol_length) / protocol_length + eps_scale * np.random.randn(protocol_length) | |
work_2 = distance_1 + np.arange(protocol_length)/ protocol_length + eps_scale * np.random.randn(protocol_length) | |
KL_div_rho_to_pi = max(distance_1) | |
distance_color = 'blue' | |
work_color = 'green' | |
def cartoon_plot_distance(ax): | |
#ax.set_title("Work") | |
ax.plot(x_1, distance_1, color=distance_color) | |
plt.vlines(x_2[0] - 0.5, 0, KL_div_rho_to_pi, linestyles='--') | |
ax.plot(x_2, distance_2, color=distance_color) | |
ax.spines['top'].set_visible(False) | |
ax.spines['right'].set_visible(False) | |
plt.yticks([]) | |
plt.yticks([0, distance_2[0], KL_div_rho_to_pi], [r"$\pi$", r"$\omega$", r"$\rho$"]) | |
plt.ylim([-0.1, KL_div_rho_to_pi + 0.1]) | |
plt.ylabel(r"$D_{KL}$") | |
plt.hlines(KL_div_rho_to_pi, 0, protocol_length*2, linestyles='--') | |
def cartoon_plot_work(ax): | |
ax.plot(x_1, work_1, color=work_color) | |
plt.vlines(x_2[0] - 0.5, 0, work_1[-1], linestyles='--') | |
ax.plot(x_2, work_2, color=work_color) | |
ax.spines['top'].set_visible(False) | |
ax.spines['right'].set_visible(False) | |
plt.yticks([]) | |
plt.xticks([0, protocol_length - 0.5, 2 * protocol_length], ["0", "M", "2M"]) | |
plt.xlabel("Steps")#, horizontalalignment="right") # doesn't seem to do anything? | |
plt.ylabel("Work") | |
ax1 = plt.subplot(2,1,1) | |
cartoon_plot_distance(ax1) | |
ax2 = plt.subplot(2,1,2, sharex=ax1) | |
cartoon_plot_work(ax2) | |
plt.tight_layout() | |
plt.savefig("fig2-cartoon-vrand.jpg", dpi=300) |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment