radinhas commited on
Commit
69f3571
·
1 Parent(s): 88f7ce9

Update apis/chat_api.py

Browse files
Files changed (1) hide show
  1. apis/chat_api.py +51 -1
apis/chat_api.py CHANGED
@@ -16,9 +16,10 @@ import base64
16
  import re
17
  import requests
18
  from utils.enver import enver
 
19
 
20
 
21
- from fastapi import FastAPI, Response
22
  from fastapi.encoders import jsonable_encoder
23
  from fastapi.responses import JSONResponse, StreamingResponse
24
  from pydantic import BaseModel, Field
@@ -141,6 +142,51 @@ class ChatAPIApp:
141
  }
142
  json_compatible_item_data = jsonable_encoder(item_response)
143
  return JSONResponse(content=json_compatible_item_data)
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
144
  class TranslateAiPostItem(BaseModel):
145
  model: str = Field(
146
  default="t5-base",
@@ -255,6 +301,10 @@ class ChatAPIApp:
255
  summary="translate text with ai",
256
  )(self.translate_ai_completions)
257
 
 
 
 
 
258
 
259
  self.app.post(
260
  prefix + "/detect",
 
16
  import re
17
  import requests
18
  from utils.enver import enver
19
+ import shutil
20
 
21
 
22
+ from fastapi import FastAPI, Response, File, UploadFile
23
  from fastapi.encoders import jsonable_encoder
24
  from fastapi.responses import JSONResponse, StreamingResponse
25
  from pydantic import BaseModel, Field
 
142
  }
143
  json_compatible_item_data = jsonable_encoder(item_response)
144
  return JSONResponse(content=json_compatible_item_data)
145
+
146
+ class WhisperPostItem(BaseModel):
147
+ model: str = Field(
148
+ default="whisper-small",
149
+ description="(str) `Whisper model`",
150
+ )
151
+ lang: str = Field(
152
+ default="en",
153
+ description="(str) `transcribe to`",
154
+ )
155
+ audio_file: UploadFile = File(
156
+ description="Source Audio File",
157
+ )
158
+ def whisper_transcribe(self, item:WhisperPostItem):
159
+ MODEL_MAP = {
160
+ "whisper-small": "openai/whisper-small",
161
+ "whisper-medium": "openai/whisper-medium",
162
+ "whisper-large": "openai/whisper-large",
163
+ "default": "openai/whisper-small",
164
+ }
165
+ if item.model in MODEL_MAP.keys():
166
+ target_model = item.model
167
+ else:
168
+ target_model = "default"
169
+
170
+ real_name = MODEL_MAP[target_model]
171
+ device = 0 if torch.cuda.is_available() else "cpu"
172
+ pipe = pipeline(
173
+ task="automatic-speech-recognition",
174
+ model=real_name,
175
+ chunk_length_s=30,
176
+ device=device,
177
+ )
178
+ time_start = time.time()
179
+ pipe.model.config.forced_decoder_ids = pipe.tokenizer.get_decoder_prompt_ids(language=item.lang, task="transcribe")
180
+ text = pipe(item.audio_file)["text"]
181
+ time_end = time.time()
182
+ item_response = {
183
+ "statue": 200,
184
+ "result": text,
185
+ "start": str(time_start),
186
+ "end": str(time_end)
187
+ }
188
+ json_compatible_item_data = jsonable_encoder(item_response)
189
+ return JSONResponse(content=json_compatible_item_data)
190
  class TranslateAiPostItem(BaseModel):
191
  model: str = Field(
192
  default="t5-base",
 
301
  summary="translate text with ai",
302
  )(self.translate_ai_completions)
303
 
304
+ self.app.post(
305
+ prefix + "/transcribe",
306
+ summary="transcribe audio to text",
307
+ )(self.whisper_transcribe)
308
 
309
  self.app.post(
310
  prefix + "/detect",