diff --git a/.github/ISSUE_TEMPLATE/bug-report.yml b/.github/ISSUE_TEMPLATE/bug-report.yml
index f8aa9d19d..8b5415483 100644
--- a/.github/ISSUE_TEMPLATE/bug-report.yml
+++ b/.github/ISSUE_TEMPLATE/bug-report.yml
@@ -1,5 +1,5 @@
name: "\U0001F41B Bug Report"
-description: Submit a bug report to help us improve lorax-inference
+description: Submit a bug report to help us improve LoRAX
body:
- type: textarea
id: system-info
@@ -16,7 +16,7 @@ body:
Deployment specificities (Kubernetes, EKS, AKS, any particular deployments):
The current version being used:
- placeholder: lorax-inference version, platform, python version, ...
+ placeholder: lorax version, platform, python version, ...
validations:
required: true
diff --git a/.github/ISSUE_TEMPLATE/feature-request.yml b/.github/ISSUE_TEMPLATE/feature-request.yml
index 1614dc0bd..18ebdd61c 100644
--- a/.github/ISSUE_TEMPLATE/feature-request.yml
+++ b/.github/ISSUE_TEMPLATE/feature-request.yml
@@ -1,5 +1,5 @@
name: "\U0001F680 Feature request"
-description: Submit a proposal/request for a new lorax-inference feature
+description: Submit a proposal/request for a new LoRAX feature
labels: [ "feature" ]
body:
- type: textarea
@@ -28,4 +28,4 @@ body:
attributes:
label: Your contribution
description: |
- Is there any way that you could help, e.g. by submitting a PR? Make sure to read the CONTRIBUTING.MD [readme](https://github.com/huggingface/lorax-inference/blob/main/CONTRIBUTING.md)
+ Is there any way that you could help, e.g. by submitting a PR? Make sure to read the CONTRIBUTING.MD [readme](https://github.com/predibase/lorax/blob/main/CONTRIBUTING.md)
diff --git a/.github/workflows/load_test.yaml b/.github/workflows/load_test.yaml
index 05bdbcbce..3b99cec6d 100644
--- a/.github/workflows/load_test.yaml
+++ b/.github/workflows/load_test.yaml
@@ -70,7 +70,7 @@ jobs:
- name: Start starcoder
run: |
- docker run --name tgi-starcoder --rm --gpus all -p 3000:80 -v ${{ env.DOCKER_VOLUME }}:/data -e HUGGING_FACE_HUB_TOKEN=${{ secrets.HUGGING_FACE_HUB_TOKEN }} --pull always -d ghcr.io/huggingface/lorax-inference:latest --model-id bigcode/starcoder --num-shard 2 --max-batch-total-tokens 32768
+ docker run --name tgi-starcoder --rm --gpus all -p 3000:80 -v ${{ env.DOCKER_VOLUME }}:/data -e HUGGING_FACE_HUB_TOKEN=${{ secrets.HUGGING_FACE_HUB_TOKEN }} --pull always -d ghcr.io/predibase/lorax:latest --model-id bigcode/starcoder --num-shard 2 --max-batch-total-tokens 32768
sleep 10
wget --timeout 10 --retry-on-http-error --waitretry=1 --tries=240 http://localhost:3000/health
diff --git a/Cargo.lock b/Cargo.lock
index 73eec6a63..b53cb5f43 100644
--- a/Cargo.lock
+++ b/Cargo.lock
@@ -168,17 +168,6 @@ version = "1.1.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa"
-[[package]]
-name = "average"
-version = "0.13.1"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "843ec791d3f24503bbf72bbd5e49a3ab4dbb4bcd0a8ef6b0c908efa73caa27b1"
-dependencies = [
- "easy-cast",
- "float-ord",
- "num-traits",
-]
-
[[package]]
name = "awaitdrop"
version = "0.1.2"
@@ -316,12 +305,6 @@ version = "3.13.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "a3e2c3daef883ecc1b5d58c15adae93470a91d425f3532ba1695849656af3fc1"
-[[package]]
-name = "bytecount"
-version = "0.6.3"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "2c676a478f63e9fa2dd5368a42f28bba0d6c560b775f38583c8bbaa7fcd67c9c"
-
[[package]]
name = "byteorder"
version = "1.4.3"
@@ -377,12 +360,6 @@ dependencies = [
"zip",
]
-[[package]]
-name = "cassowary"
-version = "0.3.0"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "df8670b8c7b9dae1793364eafadf7239c40d669904660c5960d74cfd80b46a53"
-
[[package]]
name = "cc"
version = "1.0.79"
@@ -551,31 +528,6 @@ dependencies = [
"cfg-if",
]
-[[package]]
-name = "crossterm"
-version = "0.26.1"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "a84cda67535339806297f1b331d6dd6320470d2a0fe65381e79ee9e156dd3d13"
-dependencies = [
- "bitflags 1.3.2",
- "crossterm_winapi",
- "libc",
- "mio",
- "parking_lot",
- "signal-hook",
- "signal-hook-mio",
- "winapi",
-]
-
-[[package]]
-name = "crossterm_winapi"
-version = "0.9.1"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "acdd7c62a3665c7f6830a51635d9ac9b23ed385797f70a83bb8bafe9c572ab2b"
-dependencies = [
- "winapi",
-]
-
[[package]]
name = "crypto-common"
version = "0.1.6"
@@ -706,15 +658,6 @@ dependencies = [
"winapi",
]
-[[package]]
-name = "easy-cast"
-version = "0.4.4"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "4bd102ee8c418348759919b83b81cdbdc933ffe29740b903df448b4bafaa348e"
-dependencies = [
- "libm",
-]
-
[[package]]
name = "either"
version = "1.8.1"
@@ -809,12 +752,6 @@ dependencies = [
"miniz_oxide",
]
-[[package]]
-name = "float-ord"
-version = "0.3.2"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "8ce81f49ae8a0482e4c55ea62ebbd7e5a686af544c00b9d090bba3ff9be97b3d"
-
[[package]]
name = "float_eq"
version = "1.0.1"
@@ -1348,12 +1285,6 @@ version = "0.2.147"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "b4668fb0ea861c1df094127ac5f1da3409a82116a4ba74fca2e58ef927159bb3"
-[[package]]
-name = "libm"
-version = "0.2.7"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "f7012b1bbb0719e1097c47611d3898568c546d597c2e74d66f6087edd5233ff4"
-
[[package]]
name = "linux-raw-sys"
version = "0.3.8"
@@ -1382,6 +1313,71 @@ version = "0.4.19"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "b06a4cde4c0f271a446782e3eff8de789548ce57dbc8eca9292c27f4a42004b4"
+[[package]]
+name = "lorax-client"
+version = "0.1.0"
+dependencies = [
+ "futures",
+ "grpc-metadata",
+ "prost",
+ "prost-build",
+ "thiserror",
+ "tokio",
+ "tonic 0.9.2",
+ "tonic-build",
+ "tower",
+ "tracing",
+]
+
+[[package]]
+name = "lorax-launcher"
+version = "0.1.0"
+dependencies = [
+ "clap",
+ "ctrlc",
+ "float_eq",
+ "nix",
+ "reqwest",
+ "serde",
+ "serde_json",
+ "tracing",
+ "tracing-subscriber",
+ "vergen",
+]
+
+[[package]]
+name = "lorax-router"
+version = "0.1.0"
+dependencies = [
+ "async-stream",
+ "axum",
+ "axum-tracing-opentelemetry",
+ "clap",
+ "flume",
+ "futures",
+ "lorax-client",
+ "metrics",
+ "metrics-exporter-prometheus",
+ "ngrok",
+ "nohash-hasher",
+ "opentelemetry 0.19.0",
+ "opentelemetry-otlp",
+ "rand",
+ "reqwest",
+ "serde",
+ "serde_json",
+ "thiserror",
+ "tokenizers",
+ "tokio",
+ "tower-http 0.4.1",
+ "tracing",
+ "tracing-opentelemetry 0.19.0",
+ "tracing-subscriber",
+ "utoipa",
+ "utoipa-swagger-ui",
+ "vergen",
+]
+
[[package]]
name = "mach2"
version = "0.4.1"
@@ -1545,7 +1541,6 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "927a765cd3fc26206e66b296465fa9d3e5ab003e651c1b3c060e7956d96b19d2"
dependencies = [
"libc",
- "log",
"wasi",
"windows-sys 0.48.0",
]
@@ -1703,16 +1698,6 @@ dependencies = [
"winapi",
]
-[[package]]
-name = "num-traits"
-version = "0.2.15"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "578ede34cf02f8924ab9447f50c28075b4d3e5b269972345e7e0372b38c6cdcd"
-dependencies = [
- "autocfg",
- "libm",
-]
-
[[package]]
name = "num_cpus"
version = "1.16.0"
@@ -1958,17 +1943,6 @@ version = "0.1.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "b15813163c1d831bf4a13c3610c05c0d03b39feb07f7e09fa234dac9b15aaf39"
-[[package]]
-name = "papergrid"
-version = "0.9.1"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "ae7891b22598926e4398790c8fe6447930c72a67d36d983a49d6ce682ce83290"
-dependencies = [
- "bytecount",
- "fnv",
- "unicode-width",
-]
-
[[package]]
name = "parking_lot"
version = "0.12.1"
@@ -2239,19 +2213,6 @@ dependencies = [
"getrandom",
]
-[[package]]
-name = "ratatui"
-version = "0.20.1"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "dcc0d032bccba900ee32151ec0265667535c230169f5a011154cdcd984e16829"
-dependencies = [
- "bitflags 1.3.2",
- "cassowary",
- "crossterm",
- "unicode-segmentation",
- "unicode-width",
-]
-
[[package]]
name = "raw-cpuid"
version = "10.7.0"
@@ -2685,27 +2646,6 @@ dependencies = [
"dirs",
]
-[[package]]
-name = "signal-hook"
-version = "0.3.15"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "732768f1176d21d09e076c23a93123d40bba92d50c4058da34d45c8de8e682b9"
-dependencies = [
- "libc",
- "signal-hook-registry",
-]
-
-[[package]]
-name = "signal-hook-mio"
-version = "0.2.3"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "29ad2e15f37ec9a6cc544097b78a1ec90001e9f71b81338ca39f430adaca99af"
-dependencies = [
- "libc",
- "mio",
- "signal-hook",
-]
-
[[package]]
name = "signal-hook-registry"
version = "1.4.1"
@@ -2842,30 +2782,6 @@ dependencies = [
"winapi",
]
-[[package]]
-name = "tabled"
-version = "0.12.2"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "0ce69a5028cd9576063ec1f48edb2c75339fd835e6094ef3e05b3a079bf594a6"
-dependencies = [
- "papergrid",
- "tabled_derive",
- "unicode-width",
-]
-
-[[package]]
-name = "tabled_derive"
-version = "0.6.0"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "99f688a08b54f4f02f0a3c382aefdb7884d3d69609f785bd253dc033243e3fe4"
-dependencies = [
- "heck",
- "proc-macro-error",
- "proc-macro2",
- "quote",
- "syn 1.0.109",
-]
-
[[package]]
name = "tar"
version = "0.4.39"
@@ -2891,91 +2807,6 @@ dependencies = [
"windows-sys 0.48.0",
]
-[[package]]
-name = "lorax-benchmark"
-version = "0.9.4"
-dependencies = [
- "average",
- "clap",
- "crossterm",
- "float-ord",
- "ratatui",
- "serde",
- "serde_json",
- "tabled",
- "lorax-client",
- "thiserror",
- "tokenizers",
- "tokio",
- "tracing",
- "tracing-subscriber",
-]
-
-[[package]]
-name = "lorax-client"
-version = "0.9.4"
-dependencies = [
- "futures",
- "grpc-metadata",
- "prost",
- "prost-build",
- "thiserror",
- "tokio",
- "tonic 0.9.2",
- "tonic-build",
- "tower",
- "tracing",
-]
-
-[[package]]
-name = "lorax-launcher"
-version = "0.9.4"
-dependencies = [
- "clap",
- "ctrlc",
- "float_eq",
- "nix",
- "reqwest",
- "serde",
- "serde_json",
- "tracing",
- "tracing-subscriber",
- "vergen",
-]
-
-[[package]]
-name = "lorax-router"
-version = "0.9.4"
-dependencies = [
- "async-stream",
- "axum",
- "axum-tracing-opentelemetry",
- "clap",
- "flume",
- "futures",
- "metrics",
- "metrics-exporter-prometheus",
- "ngrok",
- "nohash-hasher",
- "opentelemetry 0.19.0",
- "opentelemetry-otlp",
- "rand",
- "reqwest",
- "serde",
- "serde_json",
- "lorax-client",
- "thiserror",
- "tokenizers",
- "tokio",
- "tower-http 0.4.1",
- "tracing",
- "tracing-opentelemetry 0.19.0",
- "tracing-subscriber",
- "utoipa",
- "utoipa-swagger-ui",
- "vergen",
-]
-
[[package]]
name = "thiserror"
version = "1.0.43"
diff --git a/README.md b/README.md
index dd233d466..a88562bd2 100644
--- a/README.md
+++ b/README.md
@@ -5,7 +5,7 @@
# LoRA Exchange (LoRAX)
-
+
@@ -32,7 +32,7 @@ Lorax is a framework that allows users to serve over a hundred fine-tuned models
- 🚅 **Dynamic Adapter Loading:** allowing each set of fine-tuned LoRA weights to be loaded from storage just-in-time as requests come in at runtime, without blocking concurrent requests.
- 🏋️♀️ **Tiered Weight Caching:** to support fast exchanging of LoRA adapters between requests, and offloading of adapter weights to CPU and disk to avoid out-of-memory errors.
- 🧁 **Continuous Multi-Adapter Batching:** a fair scheduling policy for optimizing aggregate throughput of the system that extends the popular continuous batching strategy to work across multiple sets of LoRA adapters in parallel.
-- 👬 **Optimized Inference:** [flash-attention](https://github.com/HazyResearch/flash-attention), [paged attention](https://github.com/vllm-project/vllm), quantization with [bitsandbytes](https://github.com/TimDettmers/bitsandbytes) and [GPT-Q](https://arxiv.org/abs/2210.17323), tensor parallelism, token streaming, and [continuous batching](https://github.com/huggingface/lorax-inference/tree/main/router) work together to optimize our inference speeds.
+- 👬 **Optimized Inference:** [flash-attention](https://github.com/HazyResearch/flash-attention), [paged attention](https://github.com/vllm-project/vllm), quantization with [bitsandbytes](https://github.com/TimDettmers/bitsandbytes) and [GPT-Q](https://arxiv.org/abs/2210.17323), tensor parallelism, token streaming, and [continuous batching](https://github.com/predibase/lorax/tree/main/router) work together to optimize our inference speeds.
- ✅ **Production Readiness** reliably stable, Lorax supports Prometheus metrics and distributed tracing with Open Telemetry
- 🤯 **Free Commercial Use:** Apache 2.0 License. Enough said 😎.
@@ -65,11 +65,11 @@ The easiest way of getting started is using the official Docker container:
model=mistralai/Mistral-7B-Instruct-v0.1
volume=$PWD/data # share a volume with the Docker container to avoid downloading weights every run
-docker run --gpus all --shm-size 1g -p 8080:80 -v $volume:/data ghcr.io/huggingface/lorax-inference:0.9.4 --model-id $model
+docker run --gpus all --shm-size 1g -p 8080:80 -v $volume:/data ghcr.io/predibase/lorax:latest --model-id $model
```
**Note:** To use GPUs, you need to install the [NVIDIA Container Toolkit](https://docs.nvidia.com/datacenter/cloud-native/container-toolkit/install-guide.html). We also recommend using NVIDIA drivers with CUDA version 11.8 or higher.
-To see all options to serve your models (in the [code](https://github.com/huggingface/lorax-inference/blob/main/launcher/src/main.rs) or in the cli:
+To see all options to serve your models (in the [code](https://github.com/predibase/lorax/blob/main/launcher/src/main.rs) or in the cli:
```
lorax-launcher --help
```
diff --git a/benchmark/README.md b/benchmark/README.md
index 78d0a3cc0..cefc32078 100644
--- a/benchmark/README.md
+++ b/benchmark/README.md
@@ -17,7 +17,7 @@ make install-benchmark
## Run
-First, start `lorax-inference`:
+First, start `lorax`:
```shell
lorax-launcher --model-id bigscience/bloom-560m
diff --git a/clients/python/lorax/client.py b/clients/python/lorax/client.py
index cd352fd89..e3e23d3ec 100644
--- a/clients/python/lorax/client.py
+++ b/clients/python/lorax/client.py
@@ -15,7 +15,7 @@
class Client:
- """Client to make calls to a lorax-inference instance
+ """Client to make calls to a LoRAX instance
Example:
@@ -45,7 +45,7 @@ def __init__(
"""
Args:
base_url (`str`):
- lorax-inference instance base url
+ LoRAX instance base url
headers (`Optional[Dict[str, str]]`):
Additional headers
cookies (`Optional[Dict[str, str]]`):
@@ -272,7 +272,7 @@ def generate_stream(
class AsyncClient:
- """Asynchronous Client to make calls to a lorax-inference instance
+ """Asynchronous Client to make calls to a LoRAX instance
Example:
@@ -303,7 +303,7 @@ def __init__(
"""
Args:
base_url (`str`):
- lorax-inference instance base url
+ LoRAX instance base url
headers (`Optional[Dict[str, str]]`):
Additional headers
cookies (`Optional[Dict[str, str]]`):
diff --git a/launcher/src/main.rs b/launcher/src/main.rs
index 0bbdeb52b..480e5d730 100644
--- a/launcher/src/main.rs
+++ b/launcher/src/main.rs
@@ -105,7 +105,7 @@ struct Args {
validation_workers: usize,
/// Whether to shard the model across multiple GPUs
- /// By default lorax-inference will use all available GPUs to run
+ /// By default LoRAX will use all available GPUs to run
/// the model. Setting it to `false` deactivates `num_shard`.
#[clap(long, env)]
sharded: Option,
@@ -204,7 +204,7 @@ struct Args {
/// Overall this number should be the largest possible amount that fits the
/// remaining memory (after the model is loaded). Since the actual memory overhead
/// depends on other parameters like if you're using quantization, flash attention
- /// or the model implementation, lorax-inference cannot infer this number
+ /// or the model implementation, LoRAX cannot infer this number
/// automatically.
#[clap(long, env)]
max_batch_total_tokens: Option,
@@ -260,7 +260,7 @@ struct Args {
#[clap(long, env)]
weights_cache_override: Option,
- /// For some models (like bloom), lorax-inference implemented custom
+ /// For some models (like llama), LoRAX implemented custom
/// cuda kernels to speed up inference. Those kernels were only tested on A100.
/// Use this flag to disable them if you're running on different hardware and
/// encounter issues.
diff --git a/router/README.md b/router/README.md
index 992fe31ea..8c52da255 100644
--- a/router/README.md
+++ b/router/README.md
@@ -10,7 +10,7 @@ much simpler and focus on having the most efficient forward passes as possible.
## Continuous batching
-One important feature of `lorax-inference` is enabled
+One important feature of `lorax` is enabled
by this `router`.
Continuous batching is the act of regularly running queries in the same
@@ -69,7 +69,7 @@ but a currently running query is probably doing `decode`. If we want to do the c
batching as explained previously we need to run `prefill` at some point in order to create
the attention matrix required to be able to join the `decode` group.
-`lorax-inference` uses a bunch of different strategies and parameters in
+`lorax` uses a bunch of different strategies and parameters in
order to enable you to find the sweet spot between exploiting the hardware and perceived latency.
With no continuous batching at all, latency is going to be super good, but throughput (meaning
diff --git a/router/src/main.rs b/router/src/main.rs
index 38afd8b5a..2cebd1e50 100644
--- a/router/src/main.rs
+++ b/router/src/main.rs
@@ -316,7 +316,7 @@ fn init_logging(otlp_endpoint: Option, json_output: bool) {
trace::config()
.with_resource(Resource::new(vec![KeyValue::new(
"service.name",
- "lorax-inference.router",
+ "lorax.router",
)]))
.with_sampler(Sampler::AlwaysOn),
)
diff --git a/server/lorax_server/tracing.py b/server/lorax_server/tracing.py
index 445b7da5c..0d9dcccea 100644
--- a/server/lorax_server/tracing.py
+++ b/server/lorax_server/tracing.py
@@ -56,7 +56,7 @@ def _start_span(self, handler_call_details, context, set_status_on_exception=Fal
def setup_tracing(shard: int, otlp_endpoint: str):
resource = Resource.create(
- attributes={"service.name": f"lorax-inference.server-{shard}"}
+ attributes={"service.name": f"lorax.server-{shard}"}
)
span_exporter = OTLPSpanExporter(endpoint=otlp_endpoint, insecure=True)
span_processor = BatchSpanProcessor(span_exporter)
diff --git a/server/lorax_server/utils/flash_attn.py b/server/lorax_server/utils/flash_attn.py
index 1e2ddc2bb..d84bf4313 100644
--- a/server/lorax_server/utils/flash_attn.py
+++ b/server/lorax_server/utils/flash_attn.py
@@ -22,7 +22,7 @@
except ImportError:
raise ImportError(
"Flash Attention V2 is not installed.\n"
- "Use the official Docker image (ghcr.io/huggingface/lorax-inference:latest) "
+ "Use the official Docker image (ghcr.io/predibase/lorax:latest) "
"or install flash attention v2 with `cd server && make install install-flash-attention-v2`"
)
if not (is_sm8x or is_sm90):
@@ -37,7 +37,7 @@
except ImportError:
raise ImportError(
"Flash Attention is not installed.\n"
- "Use the official Docker image (ghcr.io/huggingface/lorax-inference:latest) "
+ "Use the official Docker image (ghcr.io/predibase/lorax:latest) "
"or install flash attention with `cd server && make install install-flash-attention`"
) from e
diff --git a/server/lorax_server/utils/gptq/quantize.py b/server/lorax_server/utils/gptq/quantize.py
index ee21134cd..c300dcfbe 100644
--- a/server/lorax_server/utils/gptq/quantize.py
+++ b/server/lorax_server/utils/gptq/quantize.py
@@ -944,7 +944,7 @@ def _unload():
metadata={
"format": "pt",
"quantized": "gptq",
- "origin": "lorax-inference",
+ "origin": "lorax",
},
)
if index is None: