import streamlit as st import pandas as pd from datasets import load_dataset # Загрузка датасетов с Hugging Face benchmark_dataset = load_dataset("evilfreelancer/msnp-tests", split="train") # server_dataset = load_dataset("evilfreelancer/leaderboard-dataset", split="server") # Преобразование в DataFrame df_benchmark = pd.DataFrame(benchmark_dataset) df_server = pd.read_csv('server_specs.csv') # Объединение данных по названию сервера df = pd.merge(df_benchmark, df_server, left_on="Server Name", right_on="Server Name", how="left") st.title("MSNP Лидерборд") st.markdown("Данный рейтинг отображает производительность квантованных в GGUF моделей (запущенных через ollama) на различных комбинациях видеокарт и процессоров в режиме одинойной ноды.") # Фильтры в боковой панели with st.sidebar: st.header("Фильтры") model_options = st.multiselect("Выберите модель:", options=df["Model"].unique()) gpu_options = st.multiselect("Выберите GPU:", options=df["GPUs"].unique()) quantization_options = st.multiselect("Квантование:", options=df["Quantization"].unique()) context_length_options = st.multiselect("Длина контекста:", options=sorted(df["Context Length"].unique())) start_type_options = st.multiselect("Тип запуска:", options=df["Start Type"].unique()) power_options = st.multiselect("Макс. мощность GPU (Вт):", options=df["GPU Max Power (W)"].unique()) server_options = st.multiselect("Выберите сервер:", options=df["Server Name"].unique()) # Применение фильтров filtered_df = df.copy() if model_options: filtered_df = filtered_df[filtered_df["Model"].isin(model_options)] if gpu_options: filtered_df = filtered_df[filtered_df["GPUs"].isin(gpu_options)] if quantization_options: filtered_df = filtered_df[filtered_df["Quantization"].isin(quantization_options)] if context_length_options: filtered_df = filtered_df[filtered_df["Context Length"].isin(context_length_options)] if start_type_options: filtered_df = filtered_df[filtered_df["Start Type"].isin(start_type_options)] if power_options: filtered_df = filtered_df[filtered_df["GPU Max Power (W)"].isin(power_options)] if server_options: filtered_df = filtered_df[filtered_df["Server Name"].isin(server_options)] # Отображение таблицы st.dataframe(filtered_df.sort_values(by="Tokens/sec", ascending=False).reset_index(drop=True)) # Добавление ссылок на тесты st.markdown("## Примечания") st.markdown("Нажмите на ссылки в колонке 'Test Link' для подробностей.") # Отображение спецификаций сервера при выборе записи if st.checkbox("Показать спецификации сервера"): selected_index = st.number_input( "Введите номер записи для просмотра спецификаций сервера:", min_value=0, max_value=len(filtered_df)-1, value=0, step=1 ) selected_server = filtered_df.iloc[selected_index]["Server Name"] server_specs = df_server[df_server["Server Name"] == selected_server] if not server_specs.empty: st.subheader(f"Спецификации сервера: {selected_server}") st.table(server_specs.drop(columns=["Server Name"]).transpose()) else: st.write("Спецификации для выбранного сервера недоступны.")