Update app.py
Browse files
app.py
CHANGED
@@ -108,55 +108,55 @@ if st.button("▶️ Запустить симуляцию"):
|
|
108 |
# Плейсхолдер для графика
|
109 |
plot_placeholder = st.empty()
|
110 |
|
|
|
111 |
# Симуляция изменения последовательности
|
112 |
-
|
113 |
-
|
114 |
-
|
115 |
-
|
116 |
-
|
117 |
-
|
118 |
-
|
119 |
-
|
120 |
-
|
121 |
-
stat_bist_counts.append(len(runs))
|
122 |
-
ent = compute_entropy(torsion_profile)
|
123 |
-
stat_entropy.append(ent)
|
124 |
-
acorr = compute_autocorr(torsion_profile)
|
125 |
|
126 |
-
|
127 |
-
|
128 |
-
plt.subplots_adjust(hspace=0.45)
|
129 |
-
lags_shown = 6
|
130 |
|
131 |
-
|
132 |
-
|
133 |
-
|
|
|
134 |
|
135 |
-
|
136 |
-
|
137 |
-
|
138 |
-
|
139 |
-
|
140 |
-
|
141 |
-
|
142 |
-
|
143 |
-
|
144 |
-
|
145 |
|
146 |
-
|
147 |
-
|
148 |
-
|
149 |
-
|
150 |
-
|
151 |
-
|
152 |
|
153 |
-
|
154 |
-
|
155 |
-
|
156 |
-
|
157 |
-
|
158 |
-
|
159 |
|
160 |
-
|
161 |
-
|
162 |
-
|
|
|
|
|
|
|
|
|
|
108 |
# Плейсхолдер для графика
|
109 |
plot_placeholder = st.empty()
|
110 |
|
111 |
+
|
112 |
# Симуляция изменения последовательности
|
113 |
+
for step in range(steps):
|
114 |
+
if step != 0:
|
115 |
+
seq = bio_mutate(seq)
|
116 |
+
torsion_profile = np.array([ANGLE_MAP.get(nt, 0.0) for nt in seq])
|
117 |
+
runs = find_local_min_runs(torsion_profile, min_run, max_run)
|
118 |
+
stat_bist_counts.append(len(runs))
|
119 |
+
ent = compute_entropy(torsion_profile)
|
120 |
+
stat_entropy.append(ent)
|
121 |
+
acorr = compute_autocorr(torsion_profile)
|
|
|
|
|
|
|
|
|
122 |
|
123 |
+
fig, axs = plt.subplots(3, 1, figsize=(10, 8))
|
124 |
+
plt.subplots_adjust(hspace=0.45)
|
|
|
|
|
125 |
|
126 |
+
# Очищаем графики
|
127 |
+
axs[0].cla()
|
128 |
+
axs[1].cla()
|
129 |
+
axs[2].cla()
|
130 |
|
131 |
+
# График торсионного угла
|
132 |
+
axs[0].plot(torsion_profile, color='royalblue', label="Торсионный угол")
|
133 |
+
for start, end, val in runs:
|
134 |
+
axs[0].axvspan(start, end, color="red", alpha=0.3)
|
135 |
+
axs[0].plot(range(start, end+1), torsion_profile[start:end+1], 'ro', markersize=5)
|
136 |
+
axs[0].set_ylim(-200, 200)
|
137 |
+
axs[0].set_xlabel("Позиция")
|
138 |
+
axs[0].set_ylabel("Торсионный угол (град.)")
|
139 |
+
axs[0].set_title(f"Шаг {step}: {seq}\nЧисло машин: {len(runs)}, энтропия: {ent:.2f}")
|
140 |
+
axs[0].legend()
|
141 |
|
142 |
+
# График динамики числа 'биомашин'
|
143 |
+
axs[1].plot(stat_bist_counts, '-o', color='crimson', markersize=4)
|
144 |
+
axs[1].set_xlabel("Шаг")
|
145 |
+
axs[1].set_ylabel("Число машин")
|
146 |
+
axs[1].set_ylim(0, max(10, max(stat_bist_counts)+1))
|
147 |
+
axs[1].set_title("Динамика: число 'биомашин'")
|
148 |
|
149 |
+
# График автокорреляции
|
150 |
+
axs[2].bar(np.arange(6), acorr[:6], color='teal', alpha=0.7)
|
151 |
+
axs[2].set_xlabel("Лаг")
|
152 |
+
axs[2].set_ylabel("Автокорреляция")
|
153 |
+
axs[2].set_title("Автокорреляция углового профиля (структурность) и энтропия")
|
154 |
+
axs[2].text(0.70, 0.70, f"Энтропия: {ent:.2f}", transform=axs[2].transAxes)
|
155 |
|
156 |
+
# Отображаем график в Streamlit
|
157 |
+
plot_placeholder.pyplot(fig)
|
158 |
+
|
159 |
+
# Закрытие графика после отображения
|
160 |
+
plt.close(fig)
|
161 |
+
|
162 |
+
time.sleep(0.5)
|