This commit is contained in:
commit
b5a168bda8
|
@ -0,0 +1,48 @@
|
|||
name: Build
|
||||
run-name: ${{ github.actor }} is upgrade release 🚀
|
||||
on: [push]
|
||||
env:
|
||||
REPOSITORY: ${{ github.repository }}
|
||||
COMMIT_ID: ${{ github.sha }}
|
||||
jobs:
|
||||
Build-Deploy-Actions:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- run: echo "🎉 The job was automatically triggered by a ${{ github.event_name }} event."
|
||||
- run: echo "🐧 This job is now running on a ${{ runner.os }} server hosted by Gitea!"
|
||||
- run: echo "🔎 The name of your branch is ${{ github.ref }} and your repository is ${{ github.repository }}."
|
||||
- name: Check out repository code
|
||||
uses: actions/checkout@v3
|
||||
-
|
||||
name: Setup Git LFS
|
||||
run: |
|
||||
git lfs install
|
||||
git lfs fetch
|
||||
git lfs checkout
|
||||
- name: List files in the repository
|
||||
run: |
|
||||
ls ${{ github.workspace }}
|
||||
-
|
||||
name: Docker Image Info
|
||||
id: image-info
|
||||
run: |
|
||||
echo "::set-output name=image_name::$(echo $REPOSITORY | tr '[:upper:]' '[:lower:]')"
|
||||
echo "::set-output name=image_tag::${COMMIT_ID:0:10}"
|
||||
-
|
||||
name: Login to Docker Hub
|
||||
uses: docker/login-action@v2
|
||||
with:
|
||||
registry: artifacts.iflytek.com
|
||||
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
||||
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
||||
- name: Set up Docker Buildx
|
||||
uses: docker/setup-buildx-action@v2
|
||||
-
|
||||
name: Build and push
|
||||
run: |
|
||||
docker version
|
||||
docker buildx build -t artifacts.iflytek.com/docker-private/atp/${{ steps.image-info.outputs.image_name }}:${{ steps.image-info.outputs.image_tag }} . --file ${{ github.workspace }}/Dockerfile --load
|
||||
docker push artifacts.iflytek.com/docker-private/atp/${{ steps.image-info.outputs.image_name }}:${{ steps.image-info.outputs.image_tag }}
|
||||
docker rmi artifacts.iflytek.com/docker-private/atp/${{ steps.image-info.outputs.image_name }}:${{ steps.image-info.outputs.image_tag }}
|
||||
- run: echo "🍏 This job's status is ${{ job.status }}."
|
||||
|
|
@ -0,0 +1,10 @@
|
|||
FROM python:3.8.13
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
COPY . /app
|
||||
|
||||
RUN pip config set global.index-url https://pypi.mirrors.ustc.edu.cn/simple
|
||||
RUN pip install -r requirements.txt
|
||||
|
||||
CMD ["python", "app.py"]
|
|
@ -0,0 +1,60 @@
|
|||
from transformers import AutoModelForSequenceClassification, AutoTokenizer
|
||||
from languages import LANGUANGE_MAP
|
||||
import gradio as gr
|
||||
import torch
|
||||
from gradio.themes.utils import sizes
|
||||
|
||||
#model_ckpt = "ivanlau/language-detection-fine-tuned-on-xlm-roberta-base"
|
||||
model_ckpt = "papluca/xlm-roberta-base-language-detection"
|
||||
model = AutoModelForSequenceClassification.from_pretrained(model_ckpt)
|
||||
tokenizer = AutoTokenizer.from_pretrained(model_ckpt)
|
||||
|
||||
theme = gr.themes.Default(radius_size=sizes.radius_none).set(
|
||||
block_label_text_color = '#4D63FF',
|
||||
block_title_text_color = '#4D63FF',
|
||||
button_primary_text_color = '#4D63FF',
|
||||
button_primary_background_fill='#FFFFFF',
|
||||
button_primary_border_color='#4D63FF',
|
||||
button_primary_background_fill_hover='#EDEFFF',
|
||||
)
|
||||
|
||||
|
||||
def detect_language(sentence):
|
||||
tokenized_sentence = tokenizer(sentence, return_tensors='pt')
|
||||
output = model(**tokenized_sentence)
|
||||
predictions = torch.nn.functional.softmax(output.logits, dim=-1)
|
||||
_, preds = torch.max(predictions, dim=-1)
|
||||
return LANGUANGE_MAP[preds.item()]
|
||||
|
||||
examples = [
|
||||
"恭喜发财!",
|
||||
"Jumpa lagi, saya pergi kerja.",
|
||||
"你食咗飯未呀?",
|
||||
"もう食べましたか?",
|
||||
"as-tu mangé",
|
||||
"أريد أن ألعب كرة الريشة"
|
||||
]
|
||||
|
||||
inputs=gr.inputs.Textbox(placeholder="Enter your text here", label="Text content", lines=5)
|
||||
outputs=gr.outputs.Label(label="Language detected:")
|
||||
article = """
|
||||
Fine-tuned on xlm-roberta-base model.\n
|
||||
Supported languages:\n
|
||||
'Arabic', 'Basque', 'Breton', 'Catalan', 'Chinese_China', 'Chinese_Hongkong', 'Chinese_Taiwan', 'Chuvash', 'Czech',
|
||||
'Dhivehi', 'Dutch', 'English', 'Esperanto', 'Estonian', 'French', 'Frisian', 'Georgian', 'German', 'Greek', 'Hakha_Chin',
|
||||
'Indonesian', 'Interlingua', 'Italian', 'Japanese', 'Kabyle', 'Kinyarwanda', 'Kyrgyz', 'Latvian', 'Maltese',
|
||||
'Mangolian', 'Persian', 'Polish', 'Portuguese', 'Romanian', 'Romansh_Sursilvan', 'Russian', 'Sakha', 'Slovenian',
|
||||
'Spanish', 'Swedish', 'Tamil', 'Tatar', 'Turkish', 'Ukranian', 'Welsh'
|
||||
"""
|
||||
|
||||
gr.Interface(
|
||||
fn=detect_language,
|
||||
inputs=inputs,
|
||||
outputs=outputs,
|
||||
verbose=True,
|
||||
examples = examples,
|
||||
title="Language Detector 🔠",
|
||||
description="A simple interface to detect 45 languages.",
|
||||
article=article,
|
||||
theme=theme
|
||||
).launch()
|
|
@ -0,0 +1,47 @@
|
|||
LANGUANGE_MAP = {
|
||||
0: 'Arabic',
|
||||
1: 'Basque',
|
||||
2: 'Breton',
|
||||
3: 'Catalan',
|
||||
4: 'Chinese_China',
|
||||
5: 'Chinese_Hongkong',
|
||||
6: 'Chinese_Taiwan',
|
||||
7: 'Chuvash',
|
||||
8: 'Czech',
|
||||
9: 'Dhivehi',
|
||||
10: 'Dutch',
|
||||
11: 'English',
|
||||
12: 'Esperanto',
|
||||
13: 'Estonian',
|
||||
14: 'French',
|
||||
15: 'Frisian',
|
||||
16: 'Georgian',
|
||||
17: 'German',
|
||||
18: 'Greek',
|
||||
19: 'Hakha_Chin',
|
||||
20: 'Indonesian',
|
||||
21: 'Interlingua',
|
||||
22: 'Italian',
|
||||
23: 'Japanese',
|
||||
24: 'Kabyle',
|
||||
25: 'Kinyarwanda',
|
||||
26: 'Kyrgyz',
|
||||
27: 'Latvian',
|
||||
28: 'Maltese',
|
||||
29: 'Mongolian',
|
||||
30: 'Persian',
|
||||
31: 'Polish',
|
||||
32: 'Portuguese',
|
||||
33: 'Romanian',
|
||||
34: 'Romansh_Sursilvan',
|
||||
35: 'Russian',
|
||||
36: 'Sakha',
|
||||
37: 'Slovenian',
|
||||
38: 'Spanish',
|
||||
39: 'Swedish',
|
||||
40: 'Tamil',
|
||||
41: 'Tatar',
|
||||
42: 'Turkish',
|
||||
43: 'Ukranian',
|
||||
44: 'Welsh'
|
||||
}
|
|
@ -0,0 +1,3 @@
|
|||
gradio
|
||||
transformers
|
||||
torch
|
Loading…
Reference in New Issue