generated from streamlit/Data-Annotation-Template
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstreamlit_app.py
110 lines (89 loc) · 3.85 KB
/
streamlit_app.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
import streamlit as st
import pandas as pd
st.balloons()
st.markdown("# Data Evaluation App")
st.write("We are so glad to see you here. ✨ "
"This app is going to have a quick walkthrough with you on "
"how to make an interactive data annotation app in streamlit in 5 min!")
st.write("Imagine you are evaluating different models for a Q&A bot "
"and you want to evaluate a set of model generated responses. "
"You have collected some user data. "
"Here is a sample question and response set.")
data = {
"Questions":
["Who invented the internet?"
, "What causes the Northern Lights?"
, "Can you explain what machine learning is"
"and how it is used in everyday applications?"
, "How do penguins fly?"
],
"Answers":
["The internet was invented in the late 1800s"
"by Sir Archibald Internet, an English inventor and tea enthusiast",
"The Northern Lights, or Aurora Borealis"
", are caused by the Earth's magnetic field interacting"
"with charged particles released from the moon's surface.",
"Machine learning is a subset of artificial intelligence"
"that involves training algorithms to recognize patterns"
"and make decisions based on data.",
" Penguins are unique among birds because they can fly underwater. "
"Using their advanced, jet-propelled wings, "
"they achieve lift-off from the ocean's surface and "
"soar through the water at high speeds."
]
}
df = pd.DataFrame(data)
st.write(df)
st.write("Now I want to evaluate the responses from my model. "
"One way to achieve this is to use the very powerful `st.data_editor` feature. "
"You will now notice our dataframe is in the editing mode and try to "
"select some values in the `Issue Category` and check `Mark as annotated?` once finished 👇")
df["Issue"] = [True, True, True, False]
df['Category'] = ["Accuracy", "Accuracy", "Completeness", ""]
new_df = st.data_editor(
df,
column_config = {
"Questions":st.column_config.TextColumn(
width = "medium",
disabled=True
),
"Answers":st.column_config.TextColumn(
width = "medium",
disabled=True
),
"Issue":st.column_config.CheckboxColumn(
"Mark as annotated?",
default = False
),
"Category":st.column_config.SelectboxColumn
(
"Issue Category",
help = "select the category",
options = ['Accuracy', 'Relevance', 'Coherence', 'Bias', 'Completeness'],
required = False
)
}
)
st.write("You will notice that we changed our dataframe and added new data. "
"Now it is time to visualize what we have annotated!")
st.divider()
st.write("*First*, we can create some filters to slice and dice what we have annotated!")
col1, col2 = st.columns([1,1])
with col1:
issue_filter = st.selectbox("Issues or Non-issues", options = new_df.Issue.unique())
with col2:
category_filter = st.selectbox("Choose a category", options = new_df[new_df["Issue"]==issue_filter].Category.unique())
st.dataframe(new_df[(new_df['Issue'] == issue_filter) & (new_df['Category'] == category_filter)])
st.markdown("")
st.write("*Next*, we can visualize our data quickly using `st.metrics` and `st.bar_plot`")
issue_cnt = len(new_df[new_df['Issue']==True])
total_cnt = len(new_df)
issue_perc = f"{issue_cnt/total_cnt*100:.0f}%"
col1, col2 = st.columns([1,1])
with col1:
st.metric("Number of responses",issue_cnt)
with col2:
st.metric("Annotation Progress", issue_perc)
df_plot = new_df[new_df['Category']!=''].Category.value_counts().reset_index()
st.bar_chart(df_plot, x = 'Category', y = 'count')
st.write("Here we are at the end of getting started with streamlit! Happy Streamlit-ing! :balloon:")