|  | 8 months ago | |
|---|---|---|
| .. | ||
| aws | 8 months ago | |
| azure | 9 months ago | |
| README.md | 9 months ago | |
This folder contains code to run inference benchmark for Llama 2 models on cloud API with popular cloud service providers. The benchmark will focus on overall inference throughput for querying the API endpoint for output generation with different level of concurrent requests. Remember that to send queries to the API endpoint, you are required to acquire subscriptions with the cloud service providers and there will be a fee associated with it.
Disclaimer - The purpose of the code is to provide a configurable setup to measure inference throughput. It is not a representative of the performance of these API services and we do not plan to make comparisons between different API providers.
To get started, there are certain steps we need to take to deploy the models:
Once deployed successfully, you should be assigned for an API endpoint and a security key for inference. For more information, you should consult Azure's official documentation here for model deployment and inference.
Now, replace the endpoint url and API key in azure/parameters.json. For parameter MODEL_ENDPOINTS, with chat models the suffix should be v1/chat/completions and with pretrained models the suffix should be v1/completions.
Note that the API endpoint might implemented a rate limit for token generation in certain amount of time. If you encountered the error, you can try reduce MAX_NEW_TOKEN or start with smaller CONCURRENT_LEVELS.
For MODEL_PATH, copy the model path from Huggingface under meta-llama organization. For Llama 2, make sure you copy the path of the model with hf format. This model path is used to retrieve corresponding tokenizer for your model of choice. Llama 3 used a different tokenizer compare to Llama 2.
Once everything configured, to run chat model benchmark:
python chat_azure_api_benchmark.py
To run pretrained model benchmark:
python pretrained_azure_api_benchmark.py
Once finished, the result will be written into a CSV file in the same directory, which can be later imported into dashboard of your choice.