-
-
Notifications
You must be signed in to change notification settings - Fork 2.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Ettore Di Giacinto <[email protected]>
- Loading branch information
Showing
12 changed files
with
181 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
.DEFAULT_GOAL := install | ||
|
||
.PHONY: install | ||
install: | ||
bash install.sh | ||
$(MAKE) protogen | ||
|
||
.PHONY: protogen | ||
protogen: backend_pb2_grpc.py backend_pb2.py | ||
|
||
.PHONY: protogen-clean | ||
protogen-clean: | ||
$(RM) backend_pb2_grpc.py backend_pb2.py | ||
|
||
backend_pb2_grpc.py backend_pb2.py: | ||
bash protogen.sh | ||
|
||
.PHONY: clean | ||
clean: protogen-clean | ||
rm -rf venv __pycache__ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,94 @@ | ||
#!/usr/bin/env python3 | ||
""" | ||
This is an extra gRPC server of LocalAI for Bark TTS | ||
""" | ||
from concurrent import futures | ||
import time | ||
import argparse | ||
import signal | ||
import sys | ||
import os | ||
import backend_pb2 | ||
import backend_pb2_grpc | ||
|
||
from faster_whisper import WhisperModel | ||
|
||
import grpc | ||
|
||
|
||
_ONE_DAY_IN_SECONDS = 60 * 60 * 24 | ||
|
||
# If MAX_WORKERS are specified in the environment use it, otherwise default to 1 | ||
MAX_WORKERS = int(os.environ.get('PYTHON_GRPC_MAX_WORKERS', '1')) | ||
COQUI_LANGUAGE = os.environ.get('COQUI_LANGUAGE', None) | ||
|
||
# Implement the BackendServicer class with the service methods | ||
class BackendServicer(backend_pb2_grpc.BackendServicer): | ||
""" | ||
BackendServicer is the class that implements the gRPC service | ||
""" | ||
def Health(self, request, context): | ||
return backend_pb2.Reply(message=bytes("OK", 'utf-8')) | ||
def LoadModel(self, request, context): | ||
device = "cpu" | ||
# Get device | ||
# device = "cuda" if request.CUDA else "cpu" | ||
if request.CUDA: | ||
device = "cuda" | ||
|
||
try: | ||
print("Preparing models, please wait", file=sys.stderr) | ||
self.model = WhisperModel(request.Model, device=device, compute_type="float16") | ||
except Exception as err: | ||
return backend_pb2.Result(success=False, message=f"Unexpected {err=}, {type(err)=}") | ||
# Implement your logic here for the LoadModel service | ||
# Replace this with your desired response | ||
return backend_pb2.Result(message="Model loaded successfully", success=True) | ||
|
||
def AudioTranscription(self, request, context): | ||
resultSegments = [] | ||
text = "" | ||
try: | ||
segments, info = self.model.transcribe(request.dst, beam_size=5, condition_on_previous_text=False) | ||
id = 0 | ||
for segment in segments: | ||
print("[%.2fs -> %.2fs] %s" % (segment.start, segment.end, segment.text)) | ||
resultSegments.append(backend_pb2.TranscriptSegment(id=id, start=segment.start, end=segment.end, text=segment.text)) | ||
text += segment.text | ||
id += 1 | ||
except Exception as err: | ||
print(f"Unexpected {err=}, {type(err)=}", file=sys.stderr) | ||
|
||
return backend_pb2.TranscriptResult(segments=resultSegments, text=text) | ||
|
||
def serve(address): | ||
server = grpc.server(futures.ThreadPoolExecutor(max_workers=MAX_WORKERS)) | ||
backend_pb2_grpc.add_BackendServicer_to_server(BackendServicer(), server) | ||
server.add_insecure_port(address) | ||
server.start() | ||
print("Server started. Listening on: " + address, file=sys.stderr) | ||
|
||
# Define the signal handler function | ||
def signal_handler(sig, frame): | ||
print("Received termination signal. Shutting down...") | ||
server.stop(0) | ||
sys.exit(0) | ||
|
||
# Set the signal handlers for SIGINT and SIGTERM | ||
signal.signal(signal.SIGINT, signal_handler) | ||
signal.signal(signal.SIGTERM, signal_handler) | ||
|
||
try: | ||
while True: | ||
time.sleep(_ONE_DAY_IN_SECONDS) | ||
except KeyboardInterrupt: | ||
server.stop(0) | ||
|
||
if __name__ == "__main__": | ||
parser = argparse.ArgumentParser(description="Run the gRPC server.") | ||
parser.add_argument( | ||
"--addr", default="localhost:50051", help="The address to bind the server to." | ||
) | ||
args = parser.parse_args() | ||
|
||
serve(args.addr) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
#!/bin/bash | ||
set -e | ||
|
||
source $(dirname $0)/../common/libbackend.sh | ||
|
||
# This is here because the Intel pip index is broken and returns 200 status codes for every package name, it just doesn't return any package links. | ||
# This makes uv think that the package exists in the Intel pip index, and by default it stops looking at other pip indexes once it finds a match. | ||
# We need uv to continue falling through to the pypi default index to find optimum[openvino] in the pypi index | ||
# the --upgrade actually allows us to *downgrade* torch to the version provided in the Intel pip index | ||
if [ "x${BUILD_PROFILE}" == "xintel" ]; then | ||
EXTRA_PIP_INSTALL_FLAGS+=" --upgrade --index-strategy=unsafe-first-match" | ||
fi | ||
|
||
installRequirements |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
#!/bin/bash | ||
set -e | ||
|
||
source $(dirname $0)/../common/libbackend.sh | ||
|
||
python3 -m grpc_tools.protoc -I../.. --python_out=. --grpc_python_out=. backend.proto |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
faster-whisper | ||
opencv-python | ||
accelerate | ||
compel | ||
peft | ||
sentencepiece | ||
torch==2.4.1 | ||
optimum-quanto |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
--extra-index-url https://download.pytorch.org/whl/cu118 | ||
torch==2.4.1+cu118 | ||
faster-whisper | ||
opencv-python | ||
accelerate | ||
compel | ||
peft | ||
sentencepiece | ||
optimum-quanto |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
torch==2.4.1 | ||
faster-whisper | ||
opencv-python | ||
accelerate | ||
compel | ||
peft | ||
sentencepiece | ||
optimum-quanto |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
--extra-index-url https://download.pytorch.org/whl/rocm6.0 | ||
torch | ||
faster-whisper |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
--extra-index-url https://pytorch-extension.intel.com/release-whl/stable/xpu/us/ | ||
intel-extension-for-pytorch==2.3.110+xpu | ||
torch==2.3.1+cxx11.abi | ||
oneccl_bind_pt==2.3.100+xpu | ||
optimum[openvino] | ||
faster-whisper |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
grpcio==1.69.0 | ||
protobuf | ||
grpcio-tools |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
#!/bin/bash | ||
source $(dirname $0)/../common/libbackend.sh | ||
|
||
startBackend $@ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
#!/bin/bash | ||
set -e | ||
|
||
source $(dirname $0)/../common/libbackend.sh | ||
|
||
runUnittests |