Spaces:
Running
Running
corl2024
Browse files- app.py +7 -4
- constants.py +2 -0
- df/PaperCentral.py +24 -22
- pr_paper_central_tab.py +9 -3
app.py
CHANGED
|
@@ -43,7 +43,7 @@ def logging_flow(oauth_token: Optional[gr.OAuthToken]):
|
|
| 43 |
style="border: 2px solid rgb(245, 158, 11); border-radius: 50%; width: 1.38rem; height: 1.38rem; margin-right: 0.5rem;">
|
| 44 |
<span style="font-size: 1rem;">{name}</span>
|
| 45 |
</div>
|
| 46 |
-
Head to "
|
| 47 |
'''
|
| 48 |
|
| 49 |
user_info_update = gr.update(value=avatar_html, label="User")
|
|
@@ -55,11 +55,14 @@ with gr.Blocks(css="style.css") as demo:
|
|
| 55 |
gr.Markdown("# Paper Central")
|
| 56 |
with gr.Row():
|
| 57 |
with gr.Column(scale=1):
|
| 58 |
-
login_button = gr.LoginButton(value="
|
| 59 |
user_info_md = gr.HTML()
|
| 60 |
with gr.Column(scale=1):
|
| 61 |
with gr.Accordion(label="⭐Release notes", open=False):
|
| 62 |
gr.Markdown("""
|
|
|
|
|
|
|
|
|
|
| 63 |
- **October 16, 2024** – Added functionality to filter papers by date ranges.
|
| 64 |
- **October 11, 2024** – Introduced leaderboards feature.
|
| 65 |
- **October 8, 2024** – MICCAI 2024 proceedings added.
|
|
@@ -128,7 +131,7 @@ with gr.Blocks(css="style.css") as demo:
|
|
| 128 |
)
|
| 129 |
hf_options = gr.CheckboxGroup(
|
| 130 |
label="Hugging Face options",
|
| 131 |
-
choices=["🤗 artifacts", "datasets", "models", "spaces", "github"],
|
| 132 |
value=[],
|
| 133 |
elem_id="hf_options"
|
| 134 |
)
|
|
@@ -168,7 +171,7 @@ with gr.Blocks(css="style.css") as demo:
|
|
| 168 |
wrap=True,
|
| 169 |
)
|
| 170 |
|
| 171 |
-
with gr.Tab("
|
| 172 |
pr_paper_central_tab(paper_central_df.df_raw)
|
| 173 |
|
| 174 |
with gr.Tab("Leaderboards", id="tab-leaderboards"):
|
|
|
|
| 43 |
style="border: 2px solid rgb(245, 158, 11); border-radius: 50%; width: 1.38rem; height: 1.38rem; margin-right: 0.5rem;">
|
| 44 |
<span style="font-size: 1rem;">{name}</span>
|
| 45 |
</div>
|
| 46 |
+
Head to "Edit papers" tab to modify your paper!
|
| 47 |
'''
|
| 48 |
|
| 49 |
user_info_update = gr.update(value=avatar_html, label="User")
|
|
|
|
| 55 |
gr.Markdown("# Paper Central")
|
| 56 |
with gr.Row():
|
| 57 |
with gr.Column(scale=1):
|
| 58 |
+
login_button = gr.LoginButton(value="Add or edit your papers")
|
| 59 |
user_info_md = gr.HTML()
|
| 60 |
with gr.Column(scale=1):
|
| 61 |
with gr.Accordion(label="⭐Release notes", open=False):
|
| 62 |
gr.Markdown("""
|
| 63 |
+
- **October 24, 2024** – CoRL 2024 proceedings added.
|
| 64 |
+
- **October 20, 2024** – You can now add or edit papers.
|
| 65 |
+
- **October 19, 2024** – Papers with github now have github stars.
|
| 66 |
- **October 16, 2024** – Added functionality to filter papers by date ranges.
|
| 67 |
- **October 11, 2024** – Introduced leaderboards feature.
|
| 68 |
- **October 8, 2024** – MICCAI 2024 proceedings added.
|
|
|
|
| 131 |
)
|
| 132 |
hf_options = gr.CheckboxGroup(
|
| 133 |
label="Hugging Face options",
|
| 134 |
+
choices=["🤗 artifacts", "datasets", "models", "spaces", "github", "project page"],
|
| 135 |
value=[],
|
| 136 |
elem_id="hf_options"
|
| 137 |
)
|
|
|
|
| 171 |
wrap=True,
|
| 172 |
)
|
| 173 |
|
| 174 |
+
with gr.Tab("Edit papers", id="tab-pr"):
|
| 175 |
pr_paper_central_tab(paper_central_df.df_raw)
|
| 176 |
|
| 177 |
with gr.Tab("Leaderboards", id="tab-leaderboards"):
|
constants.py
CHANGED
|
@@ -2,6 +2,8 @@ NEURIPS_ICO = "
|
|
| 2 |
COLM_ICO = ""
|
| 3 |
DEFAULT_ICO = NEURIPS_ICO
|
| 4 |
MICCAI24ICO = ""
|
|
|
|
|
|
|
| 5 |
DATASET_ARXIV_SCAN_PAPERS = "IAMJB/scanned-arxiv-papers-id"
|
| 6 |
DATASET_CONFERENCE_PAPERS = "IAMJB/paper_conference_aggregate"
|
| 7 |
DATASET_DAILY_PAPERS = "hysts-bot-data/daily-papers"
|
|
|
|
| 2 |
COLM_ICO = ""
|
| 3 |
DEFAULT_ICO = NEURIPS_ICO
|
| 4 |
MICCAI24ICO = ""
|
| 5 |
+
CORL_ICO = ""
|
| 6 |
+
|
| 7 |
DATASET_ARXIV_SCAN_PAPERS = "IAMJB/scanned-arxiv-papers-id"
|
| 8 |
DATASET_CONFERENCE_PAPERS = "IAMJB/paper_conference_aggregate"
|
| 9 |
DATASET_DAILY_PAPERS = "hysts-bot-data/daily-papers"
|
df/PaperCentral.py
CHANGED
|
@@ -9,6 +9,7 @@ from constants import (
|
|
| 9 |
COLM_ICO,
|
| 10 |
DEFAULT_ICO,
|
| 11 |
MICCAI24ICO,
|
|
|
|
| 12 |
)
|
| 13 |
import gradio as gr
|
| 14 |
from utils import load_and_process
|
|
@@ -21,37 +22,25 @@ class PaperCentral:
|
|
| 21 |
A class to manage and process paper data for display in a Gradio Dataframe component.
|
| 22 |
"""
|
| 23 |
|
| 24 |
-
CONFERENCES = [
|
| 25 |
-
"ACL2023",
|
| 26 |
-
"ACL2024",
|
| 27 |
-
"COLING2024",
|
| 28 |
-
"CVPR2023",
|
| 29 |
-
"CVPR2024",
|
| 30 |
-
"ECCV2024",
|
| 31 |
-
"EMNLP2023",
|
| 32 |
-
"NAACL2023",
|
| 33 |
-
"NeurIPS2023",
|
| 34 |
-
"NeurIPS2023 D&B",
|
| 35 |
-
"COLM2024",
|
| 36 |
-
"MICCAI2024",
|
| 37 |
-
"ACMMM2024",
|
| 38 |
-
]
|
| 39 |
CONFERENCES_ICONS = {
|
| 40 |
-
"
|
| 41 |
-
"
|
|
|
|
|
|
|
| 42 |
"COLING2024": 'https://aclanthology.org/aclicon.ico',
|
| 43 |
-
"CVPR2023": "https://openaccess.thecvf.com/favicon.ico",
|
| 44 |
"CVPR2024": "https://openaccess.thecvf.com/favicon.ico",
|
|
|
|
|
|
|
|
|
|
| 45 |
"ECCV2024": "https://openaccess.thecvf.com/favicon.ico",
|
| 46 |
"EMNLP2023": 'https://aclanthology.org/aclicon.ico',
|
| 47 |
"NAACL2023": 'https://aclanthology.org/aclicon.ico',
|
| 48 |
"NeurIPS2023": NEURIPS_ICO,
|
| 49 |
"NeurIPS2023 D&B": NEURIPS_ICO,
|
| 50 |
-
"COLM2024": COLM_ICO,
|
| 51 |
-
"MICCAI2024": MICCAI24ICO,
|
| 52 |
-
"ACMMM2024": "https://2024.acmmm.org/favicon.ico",
|
| 53 |
}
|
| 54 |
|
|
|
|
|
|
|
| 55 |
# Class-level constants defining columns and their data types
|
| 56 |
COLUMNS_START_PAPER_PAGE: List[str] = [
|
| 57 |
'date',
|
|
@@ -71,6 +60,7 @@ class PaperCentral:
|
|
| 71 |
'num_comments',
|
| 72 |
'github',
|
| 73 |
'github_stars',
|
|
|
|
| 74 |
'conference_name',
|
| 75 |
'id',
|
| 76 |
'type',
|
|
@@ -96,6 +86,7 @@ class PaperCentral:
|
|
| 96 |
'type': 'str',
|
| 97 |
'authors': 'str',
|
| 98 |
'github_stars': 'number',
|
|
|
|
| 99 |
}
|
| 100 |
|
| 101 |
# Mapping for renaming columns for display purposes
|
|
@@ -154,7 +145,7 @@ class PaperCentral:
|
|
| 154 |
paper_central_df: pd.DataFrame = load_and_process(DATASET_PAPER_CENTRAL)[
|
| 155 |
['arxiv_id', 'categories', 'primary_category', 'date', 'upvotes', 'num_comments', 'github', 'num_models',
|
| 156 |
'num_datasets', 'num_spaces', 'id', 'proceedings', 'type',
|
| 157 |
-
'conference_name', 'title', 'paper_page', 'authors', 'github_stars']
|
| 158 |
]
|
| 159 |
|
| 160 |
# If arxiv published_date is weekend, switch to Monday
|
|
@@ -272,6 +263,12 @@ class PaperCentral:
|
|
| 272 |
f"<a href='{row['github']}'>github</a>"
|
| 273 |
)
|
| 274 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 275 |
return row
|
| 276 |
|
| 277 |
df = df.copy()
|
|
@@ -426,6 +423,11 @@ class PaperCentral:
|
|
| 426 |
columns_to_show.append('github_stars')
|
| 427 |
filtered_df = filtered_df[(filtered_df['github'] != "") & (filtered_df['github'].notnull())]
|
| 428 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 429 |
# Apply conference filtering
|
| 430 |
if conference_options:
|
| 431 |
columns_to_show = [col for col in columns_to_show if col not in ["date", "arxiv_id"]]
|
|
|
|
| 9 |
COLM_ICO,
|
| 10 |
DEFAULT_ICO,
|
| 11 |
MICCAI24ICO,
|
| 12 |
+
CORL_ICO,
|
| 13 |
)
|
| 14 |
import gradio as gr
|
| 15 |
from utils import load_and_process
|
|
|
|
| 22 |
A class to manage and process paper data for display in a Gradio Dataframe component.
|
| 23 |
"""
|
| 24 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 25 |
CONFERENCES_ICONS = {
|
| 26 |
+
"CoRL2024": CORL_ICO,
|
| 27 |
+
"ACMMM2024": "https://2024.acmmm.org/favicon.ico",
|
| 28 |
+
"MICCAI2024": MICCAI24ICO,
|
| 29 |
+
"COLM2024": COLM_ICO,
|
| 30 |
"COLING2024": 'https://aclanthology.org/aclicon.ico',
|
|
|
|
| 31 |
"CVPR2024": "https://openaccess.thecvf.com/favicon.ico",
|
| 32 |
+
"ACL2024": 'https://aclanthology.org/aclicon.ico',
|
| 33 |
+
"ACL2023": 'https://aclanthology.org/aclicon.ico',
|
| 34 |
+
"CVPR2023": "https://openaccess.thecvf.com/favicon.ico",
|
| 35 |
"ECCV2024": "https://openaccess.thecvf.com/favicon.ico",
|
| 36 |
"EMNLP2023": 'https://aclanthology.org/aclicon.ico',
|
| 37 |
"NAACL2023": 'https://aclanthology.org/aclicon.ico',
|
| 38 |
"NeurIPS2023": NEURIPS_ICO,
|
| 39 |
"NeurIPS2023 D&B": NEURIPS_ICO,
|
|
|
|
|
|
|
|
|
|
| 40 |
}
|
| 41 |
|
| 42 |
+
CONFERENCES = list(CONFERENCES_ICONS.keys())
|
| 43 |
+
|
| 44 |
# Class-level constants defining columns and their data types
|
| 45 |
COLUMNS_START_PAPER_PAGE: List[str] = [
|
| 46 |
'date',
|
|
|
|
| 60 |
'num_comments',
|
| 61 |
'github',
|
| 62 |
'github_stars',
|
| 63 |
+
'project_page',
|
| 64 |
'conference_name',
|
| 65 |
'id',
|
| 66 |
'type',
|
|
|
|
| 86 |
'type': 'str',
|
| 87 |
'authors': 'str',
|
| 88 |
'github_stars': 'number',
|
| 89 |
+
'project_page': 'markdown',
|
| 90 |
}
|
| 91 |
|
| 92 |
# Mapping for renaming columns for display purposes
|
|
|
|
| 145 |
paper_central_df: pd.DataFrame = load_and_process(DATASET_PAPER_CENTRAL)[
|
| 146 |
['arxiv_id', 'categories', 'primary_category', 'date', 'upvotes', 'num_comments', 'github', 'num_models',
|
| 147 |
'num_datasets', 'num_spaces', 'id', 'proceedings', 'type',
|
| 148 |
+
'conference_name', 'title', 'paper_page', 'authors', 'github_stars', 'project_page']
|
| 149 |
]
|
| 150 |
|
| 151 |
# If arxiv published_date is weekend, switch to Monday
|
|
|
|
| 263 |
f"<a href='{row['github']}'>github</a>"
|
| 264 |
)
|
| 265 |
|
| 266 |
+
if 'project_page' in row and pd.notna(row['project_page']) and row["project_page"]:
|
| 267 |
+
row['project_page'] = (
|
| 268 |
+
f"<a href='{row['project_page']}'>{row['project_page']}</a>"
|
| 269 |
+
)
|
| 270 |
+
|
| 271 |
+
|
| 272 |
return row
|
| 273 |
|
| 274 |
df = df.copy()
|
|
|
|
| 423 |
columns_to_show.append('github_stars')
|
| 424 |
filtered_df = filtered_df[(filtered_df['github'] != "") & (filtered_df['github'].notnull())]
|
| 425 |
|
| 426 |
+
if "project page" in hf_options:
|
| 427 |
+
if 'project_page' not in columns_to_show:
|
| 428 |
+
columns_to_show.append('project_page')
|
| 429 |
+
filtered_df = filtered_df[(filtered_df['project_page'] != "") & (filtered_df['project_page'].notnull())]
|
| 430 |
+
|
| 431 |
# Apply conference filtering
|
| 432 |
if conference_options:
|
| 433 |
columns_to_show = [col for col in columns_to_show if col not in ["date", "arxiv_id"]]
|
pr_paper_central_tab.py
CHANGED
|
@@ -84,7 +84,7 @@ def create_pr_in_hf_dataset(new_entry, oauth_token: gr.OAuthToken):
|
|
| 84 |
|
| 85 |
def pr_paper_central_tab(paper_central_df):
|
| 86 |
with gr.Column():
|
| 87 |
-
gr.Markdown("##
|
| 88 |
|
| 89 |
# Message to prompt user to log in
|
| 90 |
login_prompt = gr.Markdown("Please log in to proceed.", visible=False)
|
|
@@ -106,6 +106,7 @@ def pr_paper_central_tab(paper_central_df):
|
|
| 106 |
{'name': 'conference_name', 'label': 'Conference Name'},
|
| 107 |
{'name': 'type_', 'label': 'Type'}, # Renamed from 'type' to 'type_'
|
| 108 |
{'name': 'proceedings', 'label': 'Proceedings'},
|
|
|
|
| 109 |
# Add or remove fields here as needed
|
| 110 |
]
|
| 111 |
|
|
@@ -183,7 +184,12 @@ def pr_paper_central_tab(paper_central_df):
|
|
| 183 |
)
|
| 184 |
|
| 185 |
# Function to create PR
|
| 186 |
-
def create_pr(arxiv_id,
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 187 |
oauth_token: Optional[gr.OAuthToken] = None):
|
| 188 |
if oauth_token is None:
|
| 189 |
return gr.update(value="Please log in first.", visible=True)
|
|
@@ -193,7 +199,7 @@ def pr_paper_central_tab(paper_central_df):
|
|
| 193 |
'github': github,
|
| 194 |
'conference_name': conference_name,
|
| 195 |
'type': type_,
|
| 196 |
-
'
|
| 197 |
}
|
| 198 |
# Now add this to the dataset and create a PR
|
| 199 |
pr_url = create_pr_in_hf_dataset(new_entry, oauth_token)
|
|
|
|
| 84 |
|
| 85 |
def pr_paper_central_tab(paper_central_df):
|
| 86 |
with gr.Column():
|
| 87 |
+
gr.Markdown("## Edit papers")
|
| 88 |
|
| 89 |
# Message to prompt user to log in
|
| 90 |
login_prompt = gr.Markdown("Please log in to proceed.", visible=False)
|
|
|
|
| 106 |
{'name': 'conference_name', 'label': 'Conference Name'},
|
| 107 |
{'name': 'type_', 'label': 'Type'}, # Renamed from 'type' to 'type_'
|
| 108 |
{'name': 'proceedings', 'label': 'Proceedings'},
|
| 109 |
+
{'name': 'project_page', 'label': 'Project page'},
|
| 110 |
# Add or remove fields here as needed
|
| 111 |
]
|
| 112 |
|
|
|
|
| 184 |
)
|
| 185 |
|
| 186 |
# Function to create PR
|
| 187 |
+
def create_pr(arxiv_id,
|
| 188 |
+
github,
|
| 189 |
+
conference_name,
|
| 190 |
+
type_,
|
| 191 |
+
proceedings,
|
| 192 |
+
project_page,
|
| 193 |
oauth_token: Optional[gr.OAuthToken] = None):
|
| 194 |
if oauth_token is None:
|
| 195 |
return gr.update(value="Please log in first.", visible=True)
|
|
|
|
| 199 |
'github': github,
|
| 200 |
'conference_name': conference_name,
|
| 201 |
'type': type_,
|
| 202 |
+
'project_page': project_page
|
| 203 |
}
|
| 204 |
# Now add this to the dataset and create a PR
|
| 205 |
pr_url = create_pr_in_hf_dataset(new_entry, oauth_token)
|