昇腾社区首页
中文
注册
开发者
下载

文本/流式推理接口

接口功能

提供文本/流式推理处理功能。

接口格式

操作类型:POST

URL:https://{ip}:{port}/generate

{ip}和{port}请使用业务面的IP地址和端口号,即“ipAddress”“port”

请求参数

参数

是否必选

说明

取值要求

prompt

必选

推理请求内容。单模态文本模型为string类型,多模态模型为list类型。

  • string:非空,0KB<字符数<=4MB,支持中英文。prompt经过tokenizer之后的token数量小于或等于maxInputTokenLen、maxSeqLen-1、max_position_embeddings和1MB之间的最小值。其中,max_position_embeddings从权重文件config.json中获取,其他相关参数从配置文件中获取。
  • list:请参见使用样例中多模态模型样例。

-

type

可选

推理请求内容类型。

  • text:文本
  • image_url:图片
  • video_url:视频
  • audio_url:音频

单个请求中image_url、video_url、audio_url数量总和<=20个。

text

可选

推理请求内容为文本。

非空,支持中英文。

image_url

可选

推理请求内容为图片。

支持服务器本地路径的图片传入,图片类型支持jpg、png、jpeg和base64编码的jpg图片,支持URL图片传入,支持HTTP和HTTPS协议。当前支持传入的图片最大为20MB。

video_url

可选

推理请求内容为视频。

支持服务器本地路径的视频传入,视频类型支持MP4、AVI、WMV,支持URL视频传入,支持HTTP和HTTPS协议。当前支持传入的视频最大512MB。

audio_url

可选

推理请求内容为音频。

支持服务器本地路径的音频传入,音频类型支持MP3、WAV、FLAC,支持URL音频传入,支持HTTP和HTTPS协议。当前支持传入的音频最大20MB。

max_tokens

可选

允许推理生成的最大token个数。实际产生的token数量同时受到配置文件maxIterTimes参数影响,推理token个数小于或等于Min(maxIterTimes, max_tokens)。

int类型,取值范围(0,2147483647],默认值为MindIE Server配置文件中的maxIterTimes。

repetition_penalty

可选

重复惩罚用于减少在文本生成过程中出现重复片段的概率。它对之前已经生成的文本进行惩罚,使得模型更倾向于选择新的、不重复的内容。

float类型,取值范围(0.0, 2.0],默认值1.0。

  • 小于1.0表示对重复进行奖励。
  • 1.0表示不进行重复度惩罚。
  • 大于1.0表示对重复进行惩罚。

presence_penalty

可选

存在惩罚介于-2.0和2.0之间,它影响模型如何根据到目前为止是否出现在文本中来惩罚新token。正值将通过惩罚已经使用的词,增加模型谈论新主题的可能性。

float类型,取值范围[-2.0, 2.0],默认值0.0。

frequency_penalty

可选

频率惩罚介于-2.0和2.0之间,它影响模型如何根据文本中词汇的现有频率惩罚新词汇。正值将通过惩罚已经频繁使用的词来降低模型一行中重复用词的可能性。

float类型,取值范围[-2.0, 2.0],默认值0.0。

temperature

可选

控制生成的随机性,较高的值会产生更多样化的输出。1.0表示不进行计算,大于1.0表示输出随机性提高。temperature=0.0,即采用greedy sampling。

float类型,取值大于或等于0.0。

取0.0时将忽略其他后处理参数做greedy search。推荐使用大于或等于0.001的值,小于0.001可能会导致文本质量不佳。建议最大值取2.0,同时视模型而定。

top_p

可选

控制模型生成过程中考虑的词汇范围,使用累计概率选择候选词,直到累积概率超过给定的阈值。该参数也可以控制生成结果的多样性,它基于累积概率选择候选词,直到累积概率超过给定的阈值为止。

float类型,取值范围(1e-6, 1.0],默认值1.0。

top_k

可选

控制模型生成过程中考虑的词汇范围,只从概率最高的k个候选词中选择。

uint32_t类型,取值范围-1或者(0, 2147483647],字段未设置时,默认值由后端模型确定,详情请参见说明。取值大于或等于vocabSize时,默认值为vocabSize。

若传-1,-1会变为0传递给MindIE LLM后端,MindIE LLM后端会当做词表大小来处理。

vocabSize是从modelWeightPath路径下的config.json文件中读取的vocab_size或者padded_vocab_size的值,若不存在则vocabSize取默认值0。建议用户在config.json文件中添加vocab_size或者padded_vocab_size参数,否则可能导致推理失败。

seed

可选

用于指定推理过程的随机种子,相同的seed值可以确保推理结果的可重现性,不同的seed值会提升推理结果的随机性。

uint64_t类型,取值范围(0, 18446744073709551615],不传递该参数,系统会产生一个随机seed值。

当seed取到临近最大值时,会有WARNING,但并不会影响使用。若想去掉WARNING,可以减小seed取值。

stream

可选

指定返回结果是文本推理还是流式推理。

bool类型,默认值false。

  • true:流式推理。
  • false:文本推理。

stop

可选

停止推理的文本。输出结果中默认不包含停止词列表文本。

List[string]类型或者string类型,默认为null。

  • List[string]:每个元素字符长度大于或等于1,列表元素总字符长度不超过32768(32*1024)。列表为空时相当于null。
  • string:字符长度范围为1~32768。

PD分离场景暂不支持该参数。

stop_token_ids

可选

停止推理的token id列表。输出结果中默认不包含停止推理列表中的token id。

List[int32]类型,超出int32的元素将会被忽略。

默认为null。

model

可选

指定推理时使用的LoRA权重,即LoRA ID。

string类型,默认值"None"。

include_stop_str_in_output

可选

决定是否在生成的推理文本中包含停止字符串。

bool类型,默认值为false。

  • true:包含停止字符串。
  • false:不包含停止字符串。

不传入stop或stop_token_ids时,此字段会被忽略。

PD分离场景暂不支持此参数。

skip_special_tokens

可选

指定在推理生成的文本中是否跳过特殊tokens。

bool类型,默认值为true。

  • true:跳过特殊tokens。
  • false:保留特殊tokens。

ignore_eos

可选

指定在推理文本生成过程中是否忽略eos_token结束符

bool类型,默认值为false。

  • true:忽略eos_token结束符。
  • false:不忽略eos_token结束符。

best_of

可选

推理生成best_of个序列。

int类型,取值范围为[1, 128]或null,默认值为1。

  • 当与参数n联合使用时,best_of必须大于等于n;
  • 当设置best_of>1时,temperature必须被设置为大于0的值。

n

可选

  • 当best_of配置为null或者不设置时,推理生成n个序列。
  • 当best_of配置具体值时,推理生成best_of个序列。

int类型,取值范围为[1, 128]或null,默认值为1。

  • 当与参数best_of联合使用时,best_of必须大于等于n;
  • 当设置n>1时,temperature必须被设置为大于0的值。

使用样例

请求样例:

POST https://{ip}:{port}/generate

请求消息体:

  • 单模态文本推理:
    {
        "prompt": "My name is Olivier and I",
        "max_tokens": 20,
        "repetition_penalty": 1.03,
        "presence_penalty": 1.2,
        "frequency_penalty": 1.2,
        "temperature": 0.5,
        "top_p": 0.95,
        "top_k": 10,
        "seed": null,
        "stream": false,
        "stop": null,
        "stop_token_ids": null,
        "model": "None",
        "include_stop_str_in_output": false,
        "skip_special_tokens": true,
        "ignore_eos": false,
        "best_of": 2,
        "n": 2
    }
  • 单模态流式推理:
    {
        "prompt": "My name is Olivier and I",
        "max_tokens": 20,
        "repetition_penalty": 1.03,
        "presence_penalty": 1.2,
        "frequency_penalty": 1.2,
        "temperature": 0.5,
        "top_p": 0.95,
        "top_k": 10,
        "seed": null,
        "stream": true,
        "stop": null,
        "stop_token_ids": null,
        "model": "None",
        "include_stop_str_in_output": false,
        "skip_special_tokens": true,
        "ignore_eos": false,
        "best_of": 2,
        "n": 2
    }
  • 多模态样例:

    "image_url"参数的取值请根据实际情况进行修改。

    {
        "prompt": [
            {"type": "text", "text": "My name is Olivier and I"},
            {
                "type": "image_url",
                "image_url": "/xxxx/test.png"
            }
        ],
        "max_tokens": 20,
        "repetition_penalty": 1.03,
        "presence_penalty": 1.2,
        "frequency_penalty": 1.2,
        "temperature": 0.5,
        "top_p": 0.95,
        "top_k": 10,
        "seed": null,
        "stream": false,
        "stop": null,
        "stop_token_ids": null,
        "best_of": null,
        "n": null,
        "model": "None",
        "include_stop_str_in_output": false,
        "skip_special_tokens": true,
        "ignore_eos": false
    }

响应样例:

  • 文本推理(“stream”=false):
    {"text":["My name is Olivier and I  am a French photographer based in London. I have been photographing weddings and portraits for the last ","My name is Olivier and I  am a French photographer based in Paris. I have been shooting weddings for the last 10 years and"]}
  • 流式推理:
    • 流式推理1(“stream”=true,使用sse格式返回):
      {"text":["’m","’m"]}{"text":[" the"," "]}{"text":[" founder","22"]}{"text":[" of"," years"]}{"text":[" The"," old"]}{"text":[" Good","."]}{"text":[" Life"," I"]}{"text":[" Experience"," was"]}{"text":["."," born"]}{"text":[" I"," in"]}{"text":["’ve"," France"]}{"text":[" been"," but"]}{"text":[" a"," my"]}{"text":[" festival"," parents"]}{"text":[" producer"," are"]}{"text":[" for"," from"]}{"text":[" over"," the"]}{"text":[" "," Ivory"]}{"text":["15"," Coast"]}{"text":[" years",".\n"]}
    • 流式推理2(“stream”=true,配置项“fullTextEnabled”=true,使用sse格式返回):
      {"text":["’m","’m"]}{"text":["’m the","’m "]}{"text":["’m the founder","’m 22"]}{"text":["’m the founder of","’m 22 years"]}{"text":["’m the founder of The","’m 22 years old"]}{"text":["’m the founder of The Good","’m 22 years old."]}{"text":["’m the founder of The Good Life","’m 22 years old. I"]}{"text":["’m the founder of The Good Life Experience","’m 22 years old. I was"]}{"text":["’m the founder of The Good Life Experience.","’m 22 years old. I was born"]}{"text":["’m the founder of The Good Life Experience. I","’m 22 years old. I was born in"]}{"text":["’m the founder of The Good Life Experience. I’ve","’m 22 years old. I was born in France"]}{"text":["’m the founder of The Good Life Experience. I’ve been","’m 22 years old. I was born in France but"]}{"text":["’m the founder of The Good Life Experience. I’ve been a","’m 22 years old. I was born in France but my"]}{"text":["’m the founder of The Good Life Experience. I’ve been a festival","’m 22 years old. I was born in France but my parents"]}{"text":["’m the founder of The Good Life Experience. I’ve been a festival producer","’m 22 years old. I was born in France but my parents are"]}{"text":["’m the founder of The Good Life Experience. I’ve been a festival producer for","’m 22 years old. I was born in France but my parents are from"]}{"text":["’m the founder of The Good Life Experience. I’ve been a festival producer for over","’m 22 years old. I was born in France but my parents are from the"]}{"text":["’m the founder of The Good Life Experience. I’ve been a festival producer for over ","’m 22 years old. I was born in France but my parents are from the Ivory"]}{"text":["’m the founder of The Good Life Experience. I’ve been a festival producer for over 15","’m 22 years old. I was born in France but my parents are from the Ivory Coast"]}{"text":["’m the founder of The Good Life Experience. I’ve been a festival producer for over 15 years","’m 22 years old. I was born in France but my parents are from the Ivory Coast.\n"]}

输出说明

返回值

类型

说明

text

string

推理返回结果。

vLLM流式返回结果,每个token的返回结果添加'\0'字符做分割。使用curl命令发送vLLM流式推理请求的样例如下:

curl -H "Accept: application/json" -H "Content-type: application/json" --cacert /home/runs/static_conf/ca/ca.pem  --cert /home/runs/static_conf/cert/client.pem  --key /home/runs/static_conf/cert/client.key.pem -X POST -d '{
"prompt": "My name is Olivier and I",
"stream": true,
"repetition_penalty": 1.0,
"top_p": 1.0,
"top_k": 10,
"max_tokens": 16,
"temperature": 1.0
}' https://{ip}:{port}/generate | cat