文心一言,通营销之学,成一家之言,百度人工智能AI大数据模型文心一言Python3.10接入

“文心”取自《文心雕龙》一书的开篇,作者刘勰在书中引述了一个古代典故:春秋时期,鲁国有一位名叫孔文子的大夫,他在学问上非常有造诣,但是他的儿子却不学无术,孔文子非常痛心。

一天,孔文子在山上遇到了一位神仙,神仙告诉他:“你的儿子之所以不学无术,是因为你没有给他灌输文心,让他懂得文学的魅力和意义。”孔文子听后深受启发,回家后开始给儿子灌输文学知识,儿子也逐渐对学问产生了兴趣,最终成为了一位有学问的人。因此,刘勰在书中将“文心”解释为“灌输文学知识的心灵”之意。

百度以“文心”命名自己的AI产品线,可见其对自己的中文处理能力是极为自信的,ERNIE3.0对标ChatGPT3.5/4.0,ERNIE-ViLG对标Stable-Diffusion,文心PLATO则可以理解为ChatGPT的embedding,可谓是野心勃勃。

文心一言SDK引入

百度目前已经开源文心一言的sdk工具包:

pip3 install --upgrade wenxin-api

和百度云产品线一样,安装好以后,需要去文心一言官网获取appkey和appsecret

随后编写请求逻辑:

import wenxin_api   
from wenxin_api.tasks.free_qa import FreeQA  
wenxin_api.ak = "your ak" #输入您的API Key  
wenxin_api.sk = "your sk" #输入您的Secret Key  
input_dict = {  "text": "问题:天为什么这么蓝?\n回答:",  "seq_len": 512,  "topp": 0.5,  "penalty_score": 1.2,  "min_dec_len": 2,  "min_dec_penalty_text": "。?:![<S>]",  "is_unidirectional": 0,  "task_prompt": "qa",  "mask_type": "paragraph"  
}  
rst = FreeQA.create(**input_dict)  
print(rst)

程序返回:

{  "code": 0,  "msg": "success",  "data": {  "result": "因为我们有个好心情",  "createTime": "2023-03-16 16:02:10",  "requestId": "71a6efb46acbd64394374f44579a01eb",  "text": "天为什么这么蓝",  "taskId": 1000000,  "status": 1 # 0表示生成中,1表示生成成功  }  
}

请求的参数含义请参照官方文档:

async  
异步标识	int	1	  
1  
是  
异步标识,现阶段必传且传1  
text  
用户输入文本	string	空	  
[1, 1000]  
是  
模型的输入文本,为prompt形式的输入。  
min_dec_len  
最小生成长度	int	1	  
[1,seq_len]  
是  
输出结果的最小长度,避免因模型生成END导致生成长度过短的情况,与seq_len结合使用来设置生成文本的长度范围。  
seq_len  
最大生成长度	int	128	  
[1, 1000]  
是  
输出结果的最大长度,因模型生成END或者遇到用户指定的stop_token,实际返回结果可能会小于这个长度,与min_dec_len结合使用来控制生成文本的长度范围。  
topp  
多样性	float	1.0	  
[0.0,1.0],间隔0.1  
是  
影响输出文本的多样性,取值越大,生成文本的多样性越强。  
penalty_score  
重复惩罚	float	1.0	  
[1,2]  
否  
通过对已生成的token增加惩罚,减少重复生成的现象。值越大表示惩罚越大。设置过大会导致长文本生成效果变差。  
stop_token  
提前结束符	string	空		  
否  
预测结果解析时使用的结束字符串,碰到对应字符串则直接截断并返回。可以通过设置该值,可以过滤掉few-shot等场景下模型重复的cases。  
task_prompt  
任务类型	string	空	PARAGRAPH,   
SENT, ENTITY,   
Summarization, MT,   
Text2Annotation,  
Misc, Correction,   
QA_MRC, Dialogue,   
QA_Closed_book,   
QA_Multi_Choice,  
QuestionGeneration,   
Paraphrasing, NLI,   
SemanticMatching,   
Text2SQL,   
TextClassification,   
SentimentClassification,  
zuowen, adtext,   
couplet,novel,  
cloze	  
否  
指定预置的任务模板,效果更好。 PARAGRAPH:引导模型生成一段文章; SENT:引导模型生成一句话; ENTITY:引导模型生成词组; Summarization:摘要; MT:翻译; Text2Annotation:抽取; Correction:纠错; QA_MRC:阅读理解; Dialogue:对话; QA_Closed_book: 闭卷问答; QA_Multi_Choice:多选问答; QuestionGeneration:问题生成; Paraphrasing:复述; NLI:文本蕴含识别; SemanticMatching:匹配; Text2SQL:文本描述转SQL;TextClassification:文本分类; SentimentClassification:情感分析; zuowen:写作文; adtext:写文案; couplet:对对联; novel:写小说; cloze:文本补全; Misc:其它任务。  
typeId  
模型类型	int	1	1	  
是  
通用:  
1 ERNIE 3.0 Zeus 通用  
2 ERNIE 3.0 Zeus instruct模型  
同义改写  
1 ERNIE 3.0 Zeus 同义改写精调模型  
写作文:  
1 ERNIE 3.0 Zeus 记叙文增强包  
2 ERNIE 3.0 Zeus 议论文增强包  
3 ERNIE 3.0 Zeus 小学作文增强包  
写文案:  
1 ERNIE 3.0 百亿 社交短文案精调模型  
2 ERNIE 3.0 Zeus 商品营销文案增强包  
写摘要:  
1 ERNIE 3.0 Zeus 写摘要  
2 ERNIE 3.0 Zeus 写标题  
3 ERNIE 3.0 百亿 写标题  
对对联:  
1 ERNIE 3.0 Zeus 对对联  
2 ERNIE 3.0 百亿 对对联  
自由问答:  
1 ERNIE 3.0 Zeus 自由问答增强包  
2 ERNIE 3.0 百亿 自由问答  
3 ERNIE 3.0 Zeus instruct模型  
写小说  
1 ERNIE 3.0百亿 写小说精调模型  
补全文本  
1 ERNIE 3.0 Zeus 词补全增强包  
2 ERNIE 3.0 Zeus 句补全增强包  
3 ERNIE 3.0 Zeus 段落补全增强包  
penalty_text  
惩罚文本	string	空		  
否  
模型会惩罚该字符串中的token。通过设置该值,可以减少某些冗余与异常字符的生成。  
choice_text  
候选文本	string	空		  
否  
模型只能生成该字符串中的token的组合。通过设置该值,可以对某些抽取式任务进行定向调优。  
is_unidirectional  
单双向控制开关	int	0	  
0或1  
否  
0表示模型为双向生成,1表示模型为单向生成。建议续写与few-shot等通用场景建议采用单向生成方式,而完型填空等任务相关场景建议采用双向生成方式。  
min_dec_penalty_text  
最小惩罚样本	string	空		  
否  
与最小生成长度搭配使用,可以在min_dec_len步前不让模型生成该字符串中的tokens。  
logits_bias  
屏蔽惩罚	float	-10000	  
[1, 1000]  
否  
配合penalty_text使用,对给定的penalty_text中的token增加一个logits_bias,可以通过设置该值屏蔽某些token生成的概率。  
mask_type  
生成粒度	string	word	  
可选参数为word, sentence, paragraph  
否  
设置该值可以控制模型生成粒度。

这里需要注意的是,虽然参数支持async异步,但那不是指请求的异步方式返回,换句话说,文心模型返回还是需要等待的,并不是ChatGPT那种流式返回模式。

文心一言API调用

文心一言SDK的功能有限,也不支持异步请求调用,如果需要定制化或者使用别的语言请求文心一言,需要提前发起Http请求获取token,这里我们使用异步请求库httpx:

pip3 install httpx

添加获取token逻辑:

class Winxin:  def chat(self,text):  input_dict = {  "text": f"问题:{text}\n回答:",  "seq_len": 512,  "topp": 0.5,  "penalty_score": 1.2,  "min_dec_len": 2,  "min_dec_penalty_text": "。?:![<S>]",  "is_unidirectional": 0,  "task_prompt": "qa",  "mask_type": "paragraph"  }  rst = FreeQA.create(**input_dict)  print(rst)  async def get_token(self):  headers = {"Content-Type":"application/x-www-form-urlencoded"}  async with httpx.AsyncClient() as client:  resp = await client.post(f"https://wenxin.baidu.com/moduleApi/portal/api/oauth/token?grant_type=client_credentials&client_id={wenxin_api.ak}&client_secret={wenxin_api.sk}",headers=headers)  result = resp.json()  print(result)

异步调用文心一言接口的token:

if __name__ == '__main__':  wx = Winxin()  asyncio.run(wx.get_token())

程序返回:

{'code': 0, 'msg': 'success', 'data': '24.3f6a63545345ae6588ea86a353.86400000.1679123673218.92a99f8955c6f9ab2c438a5f31b5d73b-173001'}

这里返回的数据的data就是token,有效期是一天,吐槽一下,居然没有refreshtoken,也就是说过期了还得重新去请求,不能做到无感知换取。

随后请求接口换取taskid:

  async def get_task(self,token,text):  url = "https://wenxin.baidu.com/moduleApi/portal/api/rest/1.0/ernie/3.0.25/zeus"   data = {"async": 1, "typeId": 1, "seq_len": 512, "min_dec_len": 2, "topp": 0.8, "task_prompt": "qa", "penalty_score": 1.2, "is_unidirectional": 0, "min_dec_penalty_text": "。?:![<S>]", "mask_type": "word","text":text}  headers = { "Content-Type": "application/x-www-form-urlencoded" }  params = { "access_token": token }  async with httpx.AsyncClient() as client:  result = client.post(url, headers=headers, params=params, data=data)  result = result.json()  print(result)

返回:

{  "code":0,  "msg":"success",  "data":{  "taskId": 1229202,  "requestId":"7fad28872989e274914ee1687b8f2a13"  }  
}

最后请求结果:

async def get_res(self,taskid,token):  url = "https://wenxin.baidu.com/moduleApi/portal/api/rest/1.0/ernie/v1/getResult"   access_token = token  task_id = taskid  headers = { "Content-Type": "application/x-www-form-urlencoded" }  params = { "access_token": access_token }  data = { "taskId": task_id }  async with httpx.AsyncClient() as client:  response = client.post(url, headers=headers, params=params, data=data)  print(response.text)

结果和SDK请求方式一致:

{  "code": 0,  "msg": "success",  "data": {  "result": "因为我们有个好心情",  "createTime": "2023-03-16 18:09:40",  "requestId": "71a6efb46acbd64394374f44579a01eb",  "text": "天为什么这么蓝",  "taskId": 1000000,  "status": 1 # 0表示生成中,1表示生成成功  }  
}

文心一格文字生成图像

ERNIE-ViLG AI作画大模型:文心ERNIE-ViLG2.0 是基于用户输入文本、或文本加图片生成图像及图像编辑功能的技术,主要为用户提供跨模态的文本生成图像的大模型技术服务。

文心一格和文心一言是共享appkey和appsecret的,添加图像生成逻辑:

class Winxin:  def draw(self,text):  num = 1  input_dict = {  "text": "国画,工笔画,女侠,正脸",  "style": "工笔画",  "resolution":"1024*1024",  "num": num  }  rst = TextToImage.create(**input_dict)  print(rst)

程序返回:

{  "imgUrls":[  "https://wenxin.baidu.com/younger/file/ERNIE-ViLG/61157afdaef4f0dfef0d5e51459160fbex"  ]  
}

效果:

对比基于Stable-Diffusion算法的Lora模型:

大家丰俭由己,各取所需。

需要注意的是,该产品线并不是免费的:

免费送200张,想继续玩就得充值,不愧是百度。话说免费的Stable-Diffusion不香吗?

结语

产品力而言,ChatGPT珠玉在前,文心一言还有很长的路需要走,用三国时期徐庶自比孔明的话来讲:“驽马焉敢并麒麟,寒鸦岂能配凤凰”。但是,也没必要一片挞伐之声,俄国著名作家契诃夫曾经说,“大狗叫,小狗也要叫”,ChatGPT虽然一座遥不可及的高峰,但是其他公司也无须放弃人工智能领域的研究,毕竟作为最老牌的中文搜索引擎,百度浸润几十年的中文处理能力,还是无人能出其右的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/16806.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

IT人专属AI工具

01 SQL助手 ① AirOps Sidekick 图源&#xff1a;官网截图 主要功能&#xff1a;创建个性化的电子邮件、产品描述或 SEO 内容&#xff1b;从非结构化数据中提取情感、关键事实和更多&#xff1b;将视频文件变成摘要和新内容&#xff1b;从一个SQL查询中获得洞察力和趋势。 &…

《花雕学AI》01:尝试使用新必应制作《雕爷学编程》的栏目介绍

跨年头尾三个月&#xff0c;花雕走完塔克拉玛干沙漠回来后&#xff0c;突然发现世界变了&#xff0c;微软投资的ChatGPT火起来了&#xff0c;特别是升级的ChatGPT4.0&#xff0c;更是异常火热&#xff01;这一个多月来&#xff0c;人工智能AI突然爆发&#xff0c;能做的事情太多…

AIGC浪潮下,鹅厂新一代前端人的真实工作感受

&#x1f449;腾小云导读 AIGC 这一时代潮流已然不可阻挡&#xff0c;我们要做的不是慌乱&#xff0c;而是把握住这个时代的机会。本文就和大家一起来探索在 AIGC 下&#xff0c;前端工程师即将面临的挑战和机遇。聊聊从以前到现在&#xff0c;AIGC 给我们带来了怎么样的变化&a…

GPT开通Plus会员教程,附带开通虚拟卡

GPT-4目前只有开通GPT Plus会员才可以体验。但是Plus会员需要支付20美元/月的费用&#xff0c;国内的卡无法绑定openai账户进行付款&#xff0c;今天给大家一个教程可以无障碍开通。 首先我们要准备的东西。 1.chat帐号 2.一张虚拟卡&#xff08;国际&#xff09; 既然是开…

开发者对抗软件创新焦虑的“180 法则” | 对话MongoDB CTO Mark Porter

在 MongoDB 首席技术官 Mark Porter 看来&#xff0c;创新滞后并不是因为公司缺乏灵感或创造力&#xff0c;而是因为他们被迫将时间花费在维护传统框架上&#xff0c;导致数据相关工作举步维艰&#xff0c;这是大多数组织都存在的问题。那么&#xff0c;对于企业而言&#xff0…

【ChatGPT】【sql】 按email统计续费成功和续费失败的数量

SELECT email,SUM(CASE WHEN renewal_status Success THEN 1 ELSE 0 END) as success_count,SUM(CASE WHEN renewal_status Failure THEN 1 ELSE 0 END) as failure_count FROM subscribers GROUP BY email;

海量数据实时分析引擎 Apache Flink

摘要&#xff1a;当系统出现大量或者重大的错误却不被人感知&#xff0c;将会对业务产生影响&#xff0c;从而导致资产损失。当竞争对手实施了新战术&#xff0c;却无法及时感知&#xff0c;跟不上竞争对手的节奏&#xff0c;总是追着对方尾巴走。当要做决策的时候&#xff0c;…

AI创业时代!这9个方向有钱途;AIGC再添霸榜应用Lensa;美团SemEval2022冠军方法分享;医学图像处理工具箱… | ShowMeAI资讯日报

&#x1f440;日报合辑 | &#x1f3a1;AI应用与工具大全 | &#x1f514;公众号资料下载 | &#x1f369;韩信子 &#x1f4e2; 2023年9个有前途的 AI 创业方向 https://www.aiplusinfo.com/blog/9-promising-artificial-intelligence-startup-ideas-for-2023/ 2022年&#x…

超实用!50+个ChatGPT提示词助你成为高效Web开发者(上)

如果你已经感到编写代码的重复和繁琐让你疲惫不堪&#xff0c;想要提高自己的效率&#xff0c;那么你来对地方了。ChatGPT是一款能够帮助你优化工作流程、减少错误并获得提高代码的见解的强大工具。 在这篇博客文章中&#xff0c;我们将向你提供超过50个提示和策略&#xff0c;…

AI近期热点事件纵览

1&#xff0c;英国将推动建立国家主权AI 当地时间4月24日&#xff0c;英国首相苏纳克、科技大臣多内兰宣布&#xff0c;将斥资1亿英镑&#xff08;1.25亿美元&#xff09;开发“国家主权AI”&#xff01; 政府新闻稿指出&#xff1a;投资将用于资助由政府和行业共建的研发团队…

chatgpt赋能python:Python快捷换行技巧

Python快捷换行技巧 在Python编程中&#xff0c;换行是一个非常常见且必要的操作。人们习惯使用""表示换行&#xff0c;但这种用法不便于阅读和维护。本文将为大家介绍一些快捷的换行技巧&#xff0c;让你的代码更加简洁明了。 1. 使用小括号 当我们需要将一行过长…

chatgpt赋能python:Python怎么不自动换行

Python怎么不自动换行 Python 是一门高效、简洁、易于学习的编程语言&#xff0c;近年来在人工智能、数据分析、Web开发等领域得到广泛应用。然而&#xff0c;在处理文本时&#xff0c;Python 有一个让人困扰的问题&#xff0c;即自动换行。下面将从原因、影响、解决方法等方面…

chatgpt赋能python:Python输出怎么换行

Python输出怎么换行 Python作为一种非常流行的程序设计语言&#xff0c;在软件开发、数据分析和科学计算等领域得到广泛应用。在编写Python程序的过程中&#xff0c;输出是一个非常重要的环节。本文将主要介绍在Python中如何实现输出换行的操作&#xff0c;并着重探讨几种常见…

chatgpt赋能python:Python中的换行设置

Python中的换行设置 Python是一种高级编程语言&#xff0c;被广泛用于数据处理、人工智能、网络编程、自动化测试等领域。在编写Python程序时&#xff0c;经常需要进行换行操作&#xff0c;以使代码更加清晰易读。本文将介绍Python中的换行设置方法&#xff0c;并对其进行详细…

chatgpt赋能python:Python中如何取消多行换行

Python中如何取消多行换行 Python是一种非常流行的编程语言&#xff0c;有许多用于文本处理的代码和库。然而&#xff0c;由于不同操作系统的换行符规则不同&#xff0c;使得在处理文本文件时产生了许多问题。最常见的就是“多行换行符”&#xff0c;即在一个文本文件中&#…

C语言 文件操作实现成绩排序

前言 彩笔写个大作业每个功能都要卡好久。唉&#xff0c;带专人太难了&#xff0c;呜呜呜。 吐槽&#xff1a;chatgpt不靠谱&#xff0c;我改了一下&#xff0c;让它能跑起来。 程序要求 1. 输入学生姓名&#xff0c;成绩&#xff08;连续两个空格换行&#xff09;&#xff0c…

chatgpt赋能python:Python编译器怎么换行

Python编译器怎么换行 在编写代码时&#xff0c;换行是非常重要的&#xff0c;可以使得代码更加清晰易懂&#xff0c;提高代码的可读性&#xff0c;Python编译器也不例外。但是对于一些新手来说&#xff0c;可能不太了解Python编译器中如何实现换行操作。在本文中&#xff0c;…

Linux操作命令-服务端测试

服务端测试&#xff0c;经常要用到linux命令查看日志&#xff0c;查看文件&#xff0c;故写此博客记录一下。linux还是应该多练习&#xff0c;在牛客网上有SHELL编程题&#xff0c;可以去练一练。 牛客网在线编程_SHELL篇_SHELL篇牛客网在线编程SHELL篇-SHELL篇提供超多数据结…

python自动化办公——python操作Excel、Word、PDF集合大全

本文是鉴于有些粉丝的工作需求&#xff0c;有时候需要遇到这些文件的处理。因此&#xff0c;我写了一个文章集合&#xff0c;供大家参考&#xff0c;整篇文章已经整理成书册。&#x1f447;&#x1f447;&#x1f447; 戳我领取《Python自动化大全》 戳我领取《Python自动化大全…

京东商城主图视频抓取的方法步骤

如何抓取京东商城的主图视频呢&#xff1f; 步骤1&#xff1a;首先&#xff0c;打开电商图片助手软件&#xff0c;浏览主页面 步骤2&#xff1a;把需要的京东商城商品链接复制到软件上 步骤3&#xff1a;然后再主页面下方勾选需要的选项 步骤4&#xff1a;勾选好后&#xff…