forked from boostcampaitech3/final-project-level3-nlp-04
-
Notifications
You must be signed in to change notification settings - Fork 0
/
app.py
108 lines (83 loc) · 2.78 KB
/
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
import os
from fastapi import FastAPI, Request
from fastapi.responses import JSONResponse, FileResponse
import uvicorn
from main import main
import base64
from pydantic import BaseModel
from transformers import AutoTokenizer, AutoModelForTokenClassification
import torch
from find_job_titles import FinderAcora
from calculate.metric import *
from calculate.pickle import *
from util.log_and_config import *
import cv2
import argparse
import pprint
class Image_str(BaseModel):
image_str: str
app = FastAPI()
finder = FinderAcora()
logger = get_logger()
config = load_config()
tokenizer = config["model"]["tokenizer"]
model_dir = config["model"]["model_dir"]
device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
tokenizer = AutoTokenizer.from_pretrained(tokenizer)
model = AutoModelForTokenClassification.from_pretrained(model_dir)
model.to(device)
@app.post("/")
async def print_result(image_str: Image_str, request: Request) -> str:
client_host = request.client.host
client_port = request.client.port
imgdata = base64.b64decode(image_str.image_str)
logger.info(f"{client_host}:{client_port} request API")
with timer("API", logger):
content = main(
img=imgdata, model=model, tokenizer=tokenizer, device=device, finder=finder
)
logger.info(f"{client_host}:{client_port} response : {content}")
return JSONResponse(content=content)
@app.on_event("startup")
async def startup():
logger.info("Server start")
@app.on_event("shutdown")
async def shutdown():
logger.info("Server shutdown")
@app.post("/static")
def image_upload():
return FileResponse("temp.jpg")
@app.get("/static")
def image_upload():
return FileResponse("temp.jpg")
def run(args):
if args.calculate:
if not os.path.exists("./pred.pkl"):
save_pred_pickle(
callback_fn=main,
model=model,
tokenizer=tokenizer,
device=device,
finder=finder,
)
pred = load_pred_pickle()
true = make_true_list("./data_info.csv")
print(f"CAL ACC : {calculate_accuracy(true, pred)}")
else:
torch.multiprocessing.set_start_method("spawn", force=True)
uvicorn.run(app, host="0.0.0.0", port=30001)
# img = cv2.imread("/opt/ml/final/data/image/image41.jpg")
# img = cv2.imencode(".PNG", img)[1].tobytes()
# pprint.pprint(
# main(
# img=img, model=model, tokenizer=tokenizer, device=device, finder=finder
# )
# )
if __name__ == "__main__":
parser = argparse.ArgumentParser()
# Metric 측정용 Argument
parser.add_argument(
"--calculate", type=bool, default=False, help="Calculate Accuracy"
)
args = parser.parse_args()
run(args)