mirror of
https://github.com/BerriAI/litellm.git
synced 2025-04-26 11:14:04 +00:00
commitb12a9892b7
Author: Krrish Dholakia <krrishdholakia@gmail.com> Date: Wed Apr 2 08:09:56 2025 -0700 fix(utils.py): don't modify openai_token_counter commit294de31803
Author: Krrish Dholakia <krrishdholakia@gmail.com> Date: Mon Mar 24 21:22:40 2025 -0700 fix: fix linting error commitcb6e9fbe40
Author: Krrish Dholakia <krrishdholakia@gmail.com> Date: Mon Mar 24 19:52:45 2025 -0700 refactor: complete migration commitbfc159172d
Author: Krrish Dholakia <krrishdholakia@gmail.com> Date: Mon Mar 24 19:09:59 2025 -0700 refactor: refactor more constants commit43ffb6a558
Author: Krrish Dholakia <krrishdholakia@gmail.com> Date: Mon Mar 24 18:45:24 2025 -0700 fix: test commit04dbe4310c
Author: Krrish Dholakia <krrishdholakia@gmail.com> Date: Mon Mar 24 18:28:58 2025 -0700 refactor: refactor: move more constants into constants.py commit3c26284aff
Author: Krrish Dholakia <krrishdholakia@gmail.com> Date: Mon Mar 24 18:14:46 2025 -0700 refactor: migrate hardcoded constants out of __init__.py commitc11e0de69d
Author: Krrish Dholakia <krrishdholakia@gmail.com> Date: Mon Mar 24 18:11:21 2025 -0700 build: migrate all constants into constants.py commit7882bdc787
Author: Krrish Dholakia <krrishdholakia@gmail.com> Date: Mon Mar 24 18:07:37 2025 -0700 build: initial test banning hardcoded numbers in repo
89 lines
3 KiB
Python
89 lines
3 KiB
Python
"""
|
|
Handles calculating cost for together ai models
|
|
"""
|
|
|
|
import re
|
|
|
|
from litellm.constants import (
|
|
TOGETHER_AI_4_B,
|
|
TOGETHER_AI_8_B,
|
|
TOGETHER_AI_21_B,
|
|
TOGETHER_AI_41_B,
|
|
TOGETHER_AI_80_B,
|
|
TOGETHER_AI_110_B,
|
|
TOGETHER_AI_EMBEDDING_150_M,
|
|
TOGETHER_AI_EMBEDDING_350_M,
|
|
)
|
|
from litellm.types.utils import CallTypes
|
|
|
|
|
|
# Extract the number of billion parameters from the model name
|
|
# only used for together_computer LLMs
|
|
def get_model_params_and_category(model_name, call_type: CallTypes) -> str:
|
|
"""
|
|
Helper function for calculating together ai pricing.
|
|
|
|
Returns
|
|
- str - model pricing category if mapped else received model name
|
|
"""
|
|
if call_type == CallTypes.embedding or call_type == CallTypes.aembedding:
|
|
return get_model_params_and_category_embeddings(model_name=model_name)
|
|
model_name = model_name.lower()
|
|
re_params_match = re.search(
|
|
r"(\d+b)", model_name
|
|
) # catch all decimals like 3b, 70b, etc
|
|
category = None
|
|
if re_params_match is not None:
|
|
params_match = str(re_params_match.group(1))
|
|
params_match = params_match.replace("b", "")
|
|
if params_match is not None:
|
|
params_billion = float(params_match)
|
|
else:
|
|
return model_name
|
|
# Determine the category based on the number of parameters
|
|
if params_billion <= TOGETHER_AI_4_B:
|
|
category = "together-ai-up-to-4b"
|
|
elif params_billion <= TOGETHER_AI_8_B:
|
|
category = "together-ai-4.1b-8b"
|
|
elif params_billion <= TOGETHER_AI_21_B:
|
|
category = "together-ai-8.1b-21b"
|
|
elif params_billion <= TOGETHER_AI_41_B:
|
|
category = "together-ai-21.1b-41b"
|
|
elif params_billion <= TOGETHER_AI_80_B:
|
|
category = "together-ai-41.1b-80b"
|
|
elif params_billion <= TOGETHER_AI_110_B:
|
|
category = "together-ai-81.1b-110b"
|
|
if category is not None:
|
|
return category
|
|
|
|
return model_name
|
|
|
|
|
|
def get_model_params_and_category_embeddings(model_name) -> str:
|
|
"""
|
|
Helper function for calculating together ai embedding pricing.
|
|
|
|
Returns
|
|
- str - model pricing category if mapped else received model name
|
|
"""
|
|
model_name = model_name.lower()
|
|
re_params_match = re.search(
|
|
r"(\d+m)", model_name
|
|
) # catch all decimals like 100m, 200m, etc.
|
|
category = None
|
|
if re_params_match is not None:
|
|
params_match = str(re_params_match.group(1))
|
|
params_match = params_match.replace("m", "")
|
|
if params_match is not None:
|
|
params_million = float(params_match)
|
|
else:
|
|
return model_name
|
|
# Determine the category based on the number of parameters
|
|
if params_million <= TOGETHER_AI_EMBEDDING_150_M:
|
|
category = "together-ai-embedding-up-to-150m"
|
|
elif params_million <= TOGETHER_AI_EMBEDDING_350_M:
|
|
category = "together-ai-embedding-151m-to-350m"
|
|
if category is not None:
|
|
return category
|
|
|
|
return model_name
|