Spaces:
Sleeping
Sleeping
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("Спецификации для выбранного сервера недоступны.") | |