This project provides a small and simple containerized and quantized Phi-3 backend, making it easy to build, deploy, and run anywhere.
This FastAPI server provides a single-threaded API endpoint to generate responses from the Phi-3-mini-4k-instruct model. It's a bare minimum deployment (one thread, no message context, no streaming), but any customizations to the API can be easily made in app.py
.
All that is needed to know for the impatient.
docker pull heinous/phi-3-on-cpu:latest
docker run -p 4000:5000 phi-3-on-cpu
curl -X POST -H "Content-Type: application/json" -d '{"prompt":"How to explain the Internet to a medieval knight?"}' http://localhost:4000/predict
Before you run the Docker container, you need to have Docker installed on your machine.
If you choose to build the Docker image yourself for greater control over the configuration, you will also need an authentication token from Hugging Face. You can obtain this token by creating an account on Hugging Face.
You have two options to set up the Docker image:
This option is faster and simpler, ideal if you want to get started quickly.
The Docker image (2.53 GB) for the Phi-3-mini-4k-instruct model is available for public use under the repository heinous/phi-3-on-cpu
. You can pull the image using the following Docker command:
docker pull heinous/phi-3-on-cpu:latest
This will download the latest version of the phi-3-on-cpu image to your local machine.
This option gives you more control over the model parameters and configuration.
git clone https://github.com/jhchein/phi-3-on-CPU.git
cd phi-3-on-CPU
In app.py
, adjust the following parameters:
llm = Llama(
model_path="./Phi-3-mini-4k-instruct-q4.gguf",
n_ctx=4096, # Max context length. Keep shorter for less resource consumption.
n_threads=8, # Tune to your CPU threads
n_gpu_layers=0, # Number of layers to offload to GPU. Set to 0 if running on CPU. Set to -1 for full GPU inference.
)
To build the Docker image, navigate to the directory containing the Dockerfile and run the following command:
docker build --build-arg HF_AUTH_TOKEN=your_hugging_face_token -t phi-3-on-cpu .
Replace your_hugging_face_token
with your actual Hugging Face authentication token.
Once the image is available, either built locally or pulled from Docker Hub, you can run the container using:
docker run -p 4000:5000 phi-3-on-cpu
This command maps port 5000 inside the container to port 4000 on your host.
The FastAPI server exposes a single POST endpoint at /predict
which you can use to send prompts to the model.
- URL:
/predict
- Method: POST
- Content-Type: application/json
The request body should contain a JSON object with the prompt
field:
{
"prompt": "How to explain the Internet to a medieval knight?"
}
The response will be in JSON format, containing the generated text from the model and the usage details:
{
"response": "Generated text from the model...",
"usage": {
"prompt_tokens": 16,
"completion_tokens": 349,
"total_tokens": 365
}
}
This response includes the number of tokens used in the prompt (prompt_tokens
), the number of tokens in the completion (completion_tokens
), and the total number of tokens (total_tokens
).
curl -X POST -H "Content-Type: application/json" -d '{"prompt":"How to explain the Internet to a medieval knight?"}' http://localhost:4000/predict
- Microsoft Research for developing Phi-3
- Hugging Face for providing the model and tools (see: Phi-3 on Hugging Face)
- FastAPI for the web framework.
- Llama Library for the model integration.
See: Responsible AI Considerations
Like other language models, the Phi series models can potentially behave in ways that are unfair, unreliable, or offensive. Some of the limiting behaviors to be aware of include:
- Quality of Service: The Phi models are trained primarily on English text. Languages other than English will experience worse performance. English language varieties with less representation in the training data might experience worse performance than standard American English.
- Representation of Harms & Perpetuation of Stereotypes: These models can over- or under-represent groups of people, erase representation of some groups, or reinforce demeaning or negative stereotypes. Despite safety post-training, these limitations may still be present due to differing levels of representation of different groups or prevalence of examples of negative stereotypes in training data that reflect real-world patterns and societal biases.
- Inappropriate or Offensive Content: These models may produce other types of inappropriate or offensive content, which may make it inappropriate to deploy for sensitive contexts without additional mitigations that are specific to the use case.
- Information Reliability: Language models can generate nonsensical content or fabricate content that might sound reasonable but is inaccurate or outdated.
- Limited Scope for Code: Majority of Phi-3 training data is based in Python and use common packages such as "typing, math, random, collections, datetime, itertools". If the model generates Python scripts that utilize other packages or scripts in other languages, we strongly recommend users manually verify all API uses.
Developers should apply responsible AI best practices and are responsible for ensuring that a specific use case complies with relevant laws and regulations (e.g. privacy, trade, etc.). Important areas for consideration include:
- Allocation: Models may not be suitable for scenarios that could have consequential impact on legal status or the allocation of resources or life opportunities (ex: housing, employment, credit, etc.) without further assessments and additional debiasing techniques.
- High-Risk Scenarios: Developers should assess suitability of using models in high-risk scenarios where unfair, unreliable, or offensive outputs might be extremely costly or lead to harm. This includes providing advice in sensitive or expert domains where accuracy and reliability are critical (ex: legal or health advice). Additional safeguards should be implemented at the application level according to the deployment context.
- Misinformation: Models may produce inaccurate information. Developers should follow transparency best practices and inform end-users they are interacting with an AI system. At the application level, developers can build feedback mechanisms and pipelines to ground responses in use-case specific, contextual information, a technique known as Retrieval Augmented Generation (RAG).
- Generation of Harmful Content: Developers should assess outputs for their context and use available safety classifiers or custom solutions appropriate for their use case.
- Misuse: Other forms of misuse such as fraud, spam, or malware production may be possible, and developers should ensure that their applications do not violate applicable laws and regulations.
The model is licensed under the MIT license.
This project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft trademarks or logos is subject to and must follow Microsoft’s Trademark & Brand Guidelines. Use of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship. Any use of third-party trademarks or logos are subject to those third-party’s policies.