Spaces:
Sleeping
Sleeping
abdullahmubeen10
commited on
Upload 4 files
Browse files- .streamlit/comfig.toml +3 -0
- Dockerfile +72 -0
- requirements.txt +8 -0
- streamlit.py +151 -0
.streamlit/comfig.toml
ADDED
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
1 |
+
[theme]
|
2 |
+
base="light"
|
3 |
+
primaryColor="#29B4E8"
|
Dockerfile
ADDED
@@ -0,0 +1,72 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
# Download base image ubuntu 18.04
|
2 |
+
FROM ubuntu:18.04
|
3 |
+
|
4 |
+
# Set environment variables
|
5 |
+
ENV NB_USER jovyan
|
6 |
+
ENV NB_UID 1000
|
7 |
+
ENV HOME /home/${NB_USER}
|
8 |
+
ENV JAVA_HOME /usr/lib/jvm/java-8-openjdk-amd64/
|
9 |
+
|
10 |
+
# Install required packages
|
11 |
+
RUN apt-get update && apt-get install -y \
|
12 |
+
tar \
|
13 |
+
wget \
|
14 |
+
bash \
|
15 |
+
rsync \
|
16 |
+
gcc \
|
17 |
+
libfreetype6-dev \
|
18 |
+
libhdf5-serial-dev \
|
19 |
+
libpng-dev \
|
20 |
+
libzmq3-dev \
|
21 |
+
python3 \
|
22 |
+
python3-dev \
|
23 |
+
python3-pip \
|
24 |
+
unzip \
|
25 |
+
pkg-config \
|
26 |
+
software-properties-common \
|
27 |
+
graphviz \
|
28 |
+
openjdk-8-jdk \
|
29 |
+
ant \
|
30 |
+
ca-certificates-java \
|
31 |
+
&& apt-get clean \
|
32 |
+
&& update-ca-certificates -f
|
33 |
+
|
34 |
+
# Install Python 3.8 and pip
|
35 |
+
RUN add-apt-repository ppa:deadsnakes/ppa \
|
36 |
+
&& apt-get update \
|
37 |
+
&& apt-get install -y python3.8 python3-pip \
|
38 |
+
&& apt-get clean
|
39 |
+
|
40 |
+
# Set up JAVA_HOME
|
41 |
+
RUN echo "export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64/" >> /etc/profile \
|
42 |
+
&& echo "export PATH=\$JAVA_HOME/bin:\$PATH" >> /etc/profile
|
43 |
+
# Create a new user named "jovyan" with user ID 1000
|
44 |
+
RUN useradd -m -u ${NB_UID} ${NB_USER}
|
45 |
+
|
46 |
+
# Switch to the "jovyan" user
|
47 |
+
USER ${NB_USER}
|
48 |
+
|
49 |
+
# Set home and path variables for the user
|
50 |
+
ENV HOME=/home/${NB_USER} \
|
51 |
+
PATH=/home/${NB_USER}/.local/bin:$PATH
|
52 |
+
|
53 |
+
# Set up PySpark to use Python 3.8 for both driver and workers
|
54 |
+
ENV PYSPARK_PYTHON=/usr/bin/python3.8
|
55 |
+
ENV PYSPARK_DRIVER_PYTHON=/usr/bin/python3.8
|
56 |
+
|
57 |
+
# Set the working directory to the user's home directory
|
58 |
+
WORKDIR ${HOME}
|
59 |
+
|
60 |
+
# Upgrade pip and install Python dependencies
|
61 |
+
RUN python3.8 -m pip install --upgrade pip
|
62 |
+
COPY requirements.txt /tmp/requirements.txt
|
63 |
+
RUN python3.8 -m pip install -r /tmp/requirements.txt
|
64 |
+
|
65 |
+
# Copy the application code into the container at /home/jovyan
|
66 |
+
COPY --chown=${NB_USER}:${NB_USER} . ${HOME}
|
67 |
+
|
68 |
+
# Expose port for Streamlit
|
69 |
+
EXPOSE 7860
|
70 |
+
|
71 |
+
# Define the entry point for the container
|
72 |
+
ENTRYPOINT ["streamlit", "run", "streamlit.py", "--server.port=7860", "--server.address=0.0.0.0"]
|
requirements.txt
ADDED
@@ -0,0 +1,8 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
streamlit
|
2 |
+
st-annotated-text
|
3 |
+
streamlit-tags
|
4 |
+
pandas
|
5 |
+
numpy
|
6 |
+
spark-nlp
|
7 |
+
pyspark
|
8 |
+
johnsnowlabs
|
streamlit.py
ADDED
@@ -0,0 +1,151 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import streamlit as st
|
2 |
+
import pandas as pd
|
3 |
+
|
4 |
+
import sparknlp
|
5 |
+
from sparknlp.base import DocumentAssembler
|
6 |
+
from sparknlp.annotator import AutoGGUFModel
|
7 |
+
from pyspark.ml import Pipeline
|
8 |
+
|
9 |
+
# # Page Configuration
|
10 |
+
# st.set_page_config(
|
11 |
+
# layout="wide",
|
12 |
+
# initial_sidebar_state="expanded"
|
13 |
+
# )
|
14 |
+
|
15 |
+
# CSS Styling
|
16 |
+
st.markdown("""
|
17 |
+
<style>
|
18 |
+
.main-title {
|
19 |
+
font-size: 36px;
|
20 |
+
color: #4A90E2;
|
21 |
+
font-weight: bold;
|
22 |
+
text-align: center;
|
23 |
+
}
|
24 |
+
.section {
|
25 |
+
background-color: #f9f9f9;
|
26 |
+
padding: 10px;
|
27 |
+
border-radius: 10px;
|
28 |
+
margin-top: 10px;
|
29 |
+
}
|
30 |
+
.section p, .section ul {
|
31 |
+
color: #666666;
|
32 |
+
}
|
33 |
+
.table {
|
34 |
+
width: 100%;
|
35 |
+
border-collapse: collapse;
|
36 |
+
margin-top: 20px;
|
37 |
+
}
|
38 |
+
.table th, .table td {
|
39 |
+
border: 1px solid #ddd;
|
40 |
+
padding: 8px;
|
41 |
+
text-align: left;
|
42 |
+
}
|
43 |
+
.table th {
|
44 |
+
background-color: #4A90E2;
|
45 |
+
color: white;
|
46 |
+
}
|
47 |
+
.table td {
|
48 |
+
background-color: #f2f2f2;
|
49 |
+
}
|
50 |
+
</style>
|
51 |
+
""", unsafe_allow_html=True)
|
52 |
+
|
53 |
+
# Initialize Spark
|
54 |
+
@st.cache_resource
|
55 |
+
def init_spark():
|
56 |
+
return sparknlp.start()
|
57 |
+
|
58 |
+
# Create NLP Pipeline
|
59 |
+
@st.cache_resource
|
60 |
+
def create_pipeline(model, prompt):
|
61 |
+
documentAssembler = DocumentAssembler() \
|
62 |
+
.setInputCol("text") \
|
63 |
+
.setOutputCol("document")
|
64 |
+
|
65 |
+
autoGGUFModel = (AutoGGUFModel.pretrained(model)
|
66 |
+
.setInputCols(["document"])
|
67 |
+
.setOutputCol("completions")
|
68 |
+
.setSystemPrompt(prompt)
|
69 |
+
.setNPredict(-1)
|
70 |
+
.setTemperature(0.2)
|
71 |
+
.setTopP(0.9)
|
72 |
+
.setRepeatPenalty(1.3))
|
73 |
+
|
74 |
+
pipeline = Pipeline().setStages([documentAssembler, autoGGUFModel])
|
75 |
+
return pipeline
|
76 |
+
|
77 |
+
# Fit Data to Pipeline
|
78 |
+
def fit_data(pipeline, text):
|
79 |
+
df = spark.createDataFrame([[text]]).toDF("text")
|
80 |
+
result = pipeline.fit(df).transform(df)
|
81 |
+
return result
|
82 |
+
|
83 |
+
tasks_prompt_map = {
|
84 |
+
"Summarization": "You are a summarization assistant. Provide a concise and accurate summary of the given text, focusing on the main ideas and key points. Avoid unnecessary details and ensure clarity.",
|
85 |
+
"Text Completion": "You are a creative and precise assistant. Complete the given text naturally and fluently, ensuring coherence with the provided context and maintaining the tone and style.",
|
86 |
+
"Translation": "You are a professional translator. Translate the given text accurately and naturally, preserving its meaning, tone, and context. Ensure fluency and clarity in the target language.",
|
87 |
+
"Paraphrasing": "You are a paraphrasing assistant. Rewrite the given text to convey the same meaning in a different way, ensuring clarity and grammatical accuracy without altering the original intent.",
|
88 |
+
"Question Answering": "You are an expert question-answering assistant. Based on the provided context, give accurate and concise answers to the questions. Ensure your responses are clear and directly address the query.",
|
89 |
+
"Story Generation": "You are a creative storyteller. Write an engaging story based on the given theme or prompt. Ensure the story has a clear beginning, middle, and end with compelling characters.",
|
90 |
+
"Dialogue Generation": "You are a conversational assistant. Generate a realistic and engaging dialogue based on the given scenario or context. Ensure the conversation flows naturally and matches the tone or personalities described.",
|
91 |
+
"Code Generation": "You are a coding assistant. Write clean, efficient, and error-free code to solve the given problem or implement the specified functionality. Adhere to best practices and include comments as needed.",
|
92 |
+
"Poetry Generation": "You are a poet. Compose a creative and expressive poem based on the given theme or prompt. Ensure it has a clear tone and evokes emotion."
|
93 |
+
}
|
94 |
+
|
95 |
+
# Example Sentences
|
96 |
+
examples = [
|
97 |
+
"Mount Tai is a mountain of historical and cultural significance located north of the city of Tai'an, in Shandong province, China. The tallest peak is the Jade Emperor Peak, which is commonly reported as being 1,545 meters tall, but is officially described by the PRC government as 1,532.7 meters tall. It is associated with sunrise, birth, and renewal, and is often regarded the foremost of the five. Mount Tai has been a place of worship for at least 3,000 years and served as one of the most important ceremonial centers of China during large portions of this period.",
|
98 |
+
"The Guadeloupe amazon (Amazona violacea) is a hypothetical extinct species of parrot that is thought to have been endemic to the Lesser Antillean island region of Guadeloupe. Described by 17th- and 18th-century writers, it is thought to have been related to, or possibly the same as, the extant imperial amazon. A tibiotarsus and an ulna bone from the island of Marie-Galante may belong to the Guadeloupe amazon. According to contemporary descriptions, its head, neck and underparts were mainly violet or slate, mixed with green and black; the back was brownish green; and the wings were green, yellow and red. It had iridescent feathers, and was able to raise a \"ruff\" of feathers around its neck. It fed on fruits and nuts, and the male and female took turns sitting on the nest. French settlers ate the birds and destroyed their habitat. Rare by 1779, the species appears to have become extinct by the end of the 18th century.",
|
99 |
+
"Pierre-Simon, marquis de Laplace (23 March 1749 – 5 March 1827) was a French scholar and polymath whose work was important to the development of engineering, mathematics, statistics, physics, astronomy, and philosophy. He summarized and extended the work of his predecessors in his five-volume Mécanique Céleste (Celestial Mechanics) (1799–1825). This work translated the geometric study of classical mechanics to one based on calculus, opening up a broader range of problems. In statistics, the Bayesian interpretation of probability was developed mainly by Laplace.",
|
100 |
+
"John Snow (15 March 1813 – 16 June 1858) was an English physician and a leader in the development of anaesthesia and medical hygiene. He is considered one of the founders of modern epidemiology, in part because of his work in tracing the source of a cholera outbreak in Soho, London, in 1854, which he curtailed by removing the handle of a water pump. Snow's findings inspired the adoption of anaesthesia as well as fundamental changes in the water and waste systems of London, which led to similar changes in other cities, and a significant improvement in general public health around the world.",
|
101 |
+
"The Mona Lisa is a half-length portrait painting by Italian artist Leonardo da Vinci. Considered an archetypal masterpiece of the Italian Renaissance, it has been described as \"the best known, the most visited, the most written about, the most sung about, the most parodied work of art in the world\". The painting's novel qualities include the subject's enigmatic expression, the monumentality of the composition, the subtle modelling of forms, and the atmospheric illusionism.",
|
102 |
+
"""Calculus, originally called infinitesimal calculus or "the calculus of infinitesimals", is the mathematical study of continuous change, in the same way that geometry is the study of shape and algebra is the study of generalizations of arithmetic operations. It has two major branches, differential calculus and integral calculus; the former concerns instantaneous rates of change, and the slopes of curves, while integral calculus concerns accumulation of quantities, and areas under or between curves. These two branches are related to each other by the fundamental theorem of calculus, and they make use of the fundamental notions of convergence of infinite sequences and infinite series to a well-defined limit.[1] Infinitesimal calculus was developed independently in the late 17th century by Isaac Newton and Gottfried Wilhelm Leibniz.[2][3] Today, calculus has widespread uses in science, engineering, and economics.[4] In mathematics education, calculus denotes courses of elementary mathematical analysis, which are mainly devoted to the study of functions and limits. The word calculus (plural calculi) is a Latin word, meaning originally "small pebble" (this meaning is kept in medicine – see Calculus (medicine)). Because such pebbles were used for calculation, the meaning of the word has evolved and today usually means a method of computation. It is therefore used for naming specific methods of calculation and related theories, such as propositional calculus, Ricci calculus, calculus of variations, lambda calculus, and process calculus.""",
|
103 |
+
]
|
104 |
+
|
105 |
+
model_list = [
|
106 |
+
"phi3.5_mini_4k_instruct_q4_gguf", "meta_llama_3_8b_instruct_iq3_m",
|
107 |
+
"qwen2.5_3b_instruct_q3_k_l", "mistral_7b_instruct_v0.3_q3_k_l"
|
108 |
+
]
|
109 |
+
|
110 |
+
# # Sidebar options for explanations
|
111 |
+
# st.sidebar.selectbox("Select Task:", list(tasks_prompt_map.keys()))
|
112 |
+
# st.sidebar.selectbox("Select Model:", models)
|
113 |
+
|
114 |
+
# # Sidebar with Reference Notebook Link
|
115 |
+
# colab_link = """
|
116 |
+
# <a href="https://colab.research.google.com/github/JohnSnowLabs/spark-nlp-workshop/blob/master/tutorials/streamlit_notebooks/GRAMMAR_EN.ipynb">
|
117 |
+
# <img src="https://colab.research.google.com/assets/colab-badge.svg" style="zoom: 1.3" alt="Open In Colab"/>
|
118 |
+
# </a>
|
119 |
+
# """
|
120 |
+
# st.sidebar.markdown('Reference Notebook:')
|
121 |
+
# st.sidebar.markdown(colab_link, unsafe_allow_html=True)
|
122 |
+
|
123 |
+
# Page Title and Subtitle
|
124 |
+
title = "GGUF (General-purpose Graph Universal Format) in Spark NLP"
|
125 |
+
sub_title = "Showcasing the Power of AutoGGUFModel in Spark NLP for various Text Generation Tasks"
|
126 |
+
|
127 |
+
st.markdown(f'<div class="main-title">{title}</div>', unsafe_allow_html=True)
|
128 |
+
st.markdown(f'<div style="text-align: center; color: #666666;">{sub_title}</div>', unsafe_allow_html=True)
|
129 |
+
|
130 |
+
col1, col2 = st.columns(2)
|
131 |
+
with col1: task = st.selectbox("Task:", tasks_prompt_map.keys())
|
132 |
+
with col2: model = st.selectbox("Model:", model_list)
|
133 |
+
|
134 |
+
# Text Selection
|
135 |
+
selected_text = st.selectbox("Select an example", examples)
|
136 |
+
custom_input = st.text_input("Try it with your own sentence!")
|
137 |
+
|
138 |
+
text_to_analyze = custom_input if custom_input else selected_text
|
139 |
+
|
140 |
+
st.write('Text to analyze:')
|
141 |
+
HTML_WRAPPER = """<div class="scroll entities" style="overflow-x: auto;
|
142 |
+
border: 1px solid #e6e9ef; border-radius: 0.25rem;
|
143 |
+
padding: 1rem; margin-bottom: 2.5rem; white-space:pre-wrap">{}</div>"""
|
144 |
+
st.markdown(HTML_WRAPPER.format(text_to_analyze), unsafe_allow_html=True)
|
145 |
+
|
146 |
+
# Initialize Spark and Pipeline
|
147 |
+
spark = init_spark()
|
148 |
+
pipeline = create_pipeline(model, tasks_prompt_map[task])
|
149 |
+
output = fit_data(pipeline, text_to_analyze)
|
150 |
+
|
151 |
+
st.write(output.select("completions.result").collect())
|