162 lines
3.5 KiB
Python
162 lines
3.5 KiB
Python
|
|
"""Public API"""
|
||
|
|
import re
|
||
|
|
from typing import Callable, List, Optional, Union
|
||
|
|
|
||
|
|
from sglang.backend.anthropic import Anthropic
|
||
|
|
from sglang.backend.base_backend import BaseBackend
|
||
|
|
from sglang.backend.openai import OpenAI
|
||
|
|
from sglang.backend.runtime_endpoint import RuntimeEndpoint
|
||
|
|
from sglang.global_config import global_config
|
||
|
|
from sglang.lang.ir import (
|
||
|
|
SglExpr,
|
||
|
|
SglExprList,
|
||
|
|
SglFunction,
|
||
|
|
SglGen,
|
||
|
|
SglImage,
|
||
|
|
SglRoleBegin,
|
||
|
|
SglRoleEnd,
|
||
|
|
SglSelect,
|
||
|
|
)
|
||
|
|
from sglang.srt.server import Runtime
|
||
|
|
|
||
|
|
|
||
|
|
def function(func: Callable):
|
||
|
|
return SglFunction(func)
|
||
|
|
|
||
|
|
|
||
|
|
def set_default_backend(backend: BaseBackend):
|
||
|
|
global_config.default_backend = backend
|
||
|
|
|
||
|
|
|
||
|
|
def gen(
|
||
|
|
name: Optional[str] = None,
|
||
|
|
max_tokens: Optional[int] = None,
|
||
|
|
stop: Optional[Union[str, List[str]]] = None,
|
||
|
|
temperature: Optional[float] = None,
|
||
|
|
top_p: Optional[float] = None,
|
||
|
|
top_k: Optional[int] = None,
|
||
|
|
frequency_penalty: Optional[float] = None,
|
||
|
|
presence_penalty: Optional[float] = None,
|
||
|
|
dtype: Optional[type] = None,
|
||
|
|
choices: Optional[List[str]] = None,
|
||
|
|
regex: Optional[str] = None,
|
||
|
|
):
|
||
|
|
if choices:
|
||
|
|
return SglSelect(name, choices, temperature)
|
||
|
|
|
||
|
|
# check regex is valid
|
||
|
|
if regex is not None:
|
||
|
|
try:
|
||
|
|
re.compile(regex)
|
||
|
|
except re.error as e:
|
||
|
|
raise e
|
||
|
|
|
||
|
|
return SglGen(
|
||
|
|
name,
|
||
|
|
max_tokens,
|
||
|
|
stop,
|
||
|
|
temperature,
|
||
|
|
top_p,
|
||
|
|
top_k,
|
||
|
|
frequency_penalty,
|
||
|
|
presence_penalty,
|
||
|
|
dtype,
|
||
|
|
regex,
|
||
|
|
)
|
||
|
|
|
||
|
|
|
||
|
|
def gen_int(
|
||
|
|
name: Optional[str] = None,
|
||
|
|
max_tokens: Optional[int] = None,
|
||
|
|
stop: Optional[Union[str, List[str]]] = None,
|
||
|
|
temperature: Optional[float] = None,
|
||
|
|
top_p: Optional[float] = None,
|
||
|
|
top_k: Optional[int] = None,
|
||
|
|
frequency_penalty: Optional[float] = None,
|
||
|
|
presence_penalty: Optional[float] = None,
|
||
|
|
):
|
||
|
|
return SglGen(
|
||
|
|
name,
|
||
|
|
max_tokens,
|
||
|
|
stop,
|
||
|
|
temperature,
|
||
|
|
top_p,
|
||
|
|
top_k,
|
||
|
|
frequency_penalty,
|
||
|
|
presence_penalty,
|
||
|
|
int,
|
||
|
|
None,
|
||
|
|
)
|
||
|
|
|
||
|
|
|
||
|
|
def gen_string(
|
||
|
|
name: Optional[str] = None,
|
||
|
|
max_tokens: Optional[int] = None,
|
||
|
|
stop: Optional[Union[str, List[str]]] = None,
|
||
|
|
temperature: Optional[float] = None,
|
||
|
|
top_p: Optional[float] = None,
|
||
|
|
top_k: Optional[int] = None,
|
||
|
|
frequency_penalty: Optional[float] = None,
|
||
|
|
presence_penalty: Optional[float] = None,
|
||
|
|
):
|
||
|
|
return SglGen(
|
||
|
|
name,
|
||
|
|
max_tokens,
|
||
|
|
stop,
|
||
|
|
temperature,
|
||
|
|
top_p,
|
||
|
|
top_k,
|
||
|
|
frequency_penalty,
|
||
|
|
presence_penalty,
|
||
|
|
str,
|
||
|
|
None,
|
||
|
|
)
|
||
|
|
|
||
|
|
|
||
|
|
def image(expr: SglExpr):
|
||
|
|
return SglImage(expr)
|
||
|
|
|
||
|
|
|
||
|
|
def select(
|
||
|
|
name: Optional[str] = None,
|
||
|
|
choices: List[str] = None,
|
||
|
|
temperature: float = 0.0,
|
||
|
|
):
|
||
|
|
assert choices is not None
|
||
|
|
return SglSelect(name, choices, temperature)
|
||
|
|
|
||
|
|
|
||
|
|
def _role_common(name: str, expr: Optional[SglExpr] = None):
|
||
|
|
if expr is None:
|
||
|
|
return SglExprList([SglRoleBegin(name), SglRoleEnd(name)])
|
||
|
|
else:
|
||
|
|
return SglExprList([SglRoleBegin(name), expr, SglRoleEnd(name)])
|
||
|
|
|
||
|
|
|
||
|
|
def system(expr: Optional[SglExpr] = None):
|
||
|
|
return _role_common("system", expr)
|
||
|
|
|
||
|
|
|
||
|
|
def user(expr: Optional[SglExpr] = None):
|
||
|
|
return _role_common("user", expr)
|
||
|
|
|
||
|
|
|
||
|
|
def assistant(expr: Optional[SglExpr] = None):
|
||
|
|
return _role_common("assistant", expr)
|
||
|
|
|
||
|
|
|
||
|
|
def user_begin():
|
||
|
|
return SglRoleBegin("user")
|
||
|
|
|
||
|
|
|
||
|
|
def user_end():
|
||
|
|
return SglRoleEnd("user")
|
||
|
|
|
||
|
|
|
||
|
|
def assistant_begin():
|
||
|
|
return SglRoleBegin("assistant")
|
||
|
|
|
||
|
|
|
||
|
|
def assistant_end():
|
||
|
|
return SglRoleEnd("assistant")
|