2026-rff_mp/MylnikovAS/task_1/docs/data/experiment_part.py

92 lines
4.1 KiB
Python
Raw Normal View History

def main():
N = 10000
random.seed(42)
records_sorted = [(f"User_{i:05d}", f"8-999-123-{i:04d}") for i in range(N)]
records_shuffled = records_sorted.copy()
random.shuffle(records_shuffled)
search_existing = [random.choice(records_sorted)[0] for _ in range(100)]
search_non_existing = [f"None_{i}" for i in range(10)]
search_names = search_existing + search_non_existing
delete_names = [random.choice(records_sorted)[0] for _ in range(50)]
csv_rows = [["Structure", "Mode", "Operation", "Time (sec)"]]
plot_data = []
def run_experiment(struct_type, mode, dataset):
print(f"Start: {struct_type} | Mode: {mode}...")
times_insert, times_find, times_delete = [], [], []
for round_idx in range(1, 6):
if struct_type == "LinkedList": container = None
elif struct_type == "HashTable": container = ht_create(size=1000)
elif struct_type == "BST": container = None
# А. Вставка
start = time.perf_counter()
if struct_type == "LinkedList":
for name, phone in dataset: container = ll_insert(container, name, phone)
elif struct_type == "HashTable":
for name, phone in dataset: ht_insert(container, name, phone)
elif struct_type == "BST":
for name, phone in dataset: container = bst_insert(container, name, phone)
t_ins = time.perf_counter() - start
times_insert.append(t_ins)
csv_rows.append([struct_type, mode, f"insert (number {round_idx})", f"{t_ins:.6f}"])
# Б. Поиск
start = time.perf_counter()
if struct_type == "LinkedList":
for name in search_names: ll_find(container, name)
elif struct_type == "HashTable":
for name in search_names: ht_find(container, name)
elif struct_type == "BST":
for name in search_names: bst_find(container, name)
t_find = time.perf_counter() - start
times_find.append(t_find)
csv_rows.append([struct_type, mode, f"find (number {round_idx})", f"{t_find:.6f}"])
# В. Удаление
start = time.perf_counter()
if struct_type == "LinkedList":
for name in delete_names: container = ll_delete(container, name)
elif struct_type == "HashTable":
for name in delete_names: ht_delete(container, name)
elif struct_type == "BST":
for name in delete_names: container = bst_delete(container, name)
t_del = time.perf_counter() - start
times_delete.append(t_del)
csv_rows.append([struct_type, mode, f"delete (number {round_idx})", f"{t_del:.6f}"])
# Запись средних значений
csv_rows.append([struct_type, mode, "Insert (average)", f"{sum(times_insert)/5:.6f}"])
csv_rows.append([struct_type, mode, "Find (average)", f"{sum(times_find)/5:.6f}"])
csv_rows.append([struct_type, mode, "Delete (average)", f"{sum(times_delete)/5:.6f}"])
avg_ins = sum(times_insert) / 5
avg_find = sum(times_find) / 5
avg_del = sum(times_delete) / 5
plot_data.append((struct_type, mode, avg_ins, avg_find, avg_del))
# Запуск всех тестов
run_experiment("LinkedList", "random", records_shuffled)
run_experiment("LinkedList", "sorted", records_sorted)
run_experiment("HashTable", "random", records_shuffled)
run_experiment("HashTable", "sorted", records_sorted)
run_experiment("BST", "random", records_shuffled)
run_experiment("BST", "sorted", records_sorted)
# Сохранение в CSV
with open("results.csv", "w", newline="", encoding="utf-8") as f:
writer = csv.writer(f)
writer.writerows(csv_rows)
print("\n[Успех] Все тесты завершены! Результаты сохранены в 'results.csv'.")
generate_performance_charts(plot_data)
if __name__ == '__main__':
experiment_thread = threading.Thread(target=main)
experiment_thread.start()
experiment_thread.join()