当前位置:首页 > 科技  > 软件

把LangChain跑起来的三个方法

来源: 责编: 时间:2023-08-05 11:44:41 5163观看
导读使用LangChain开发LLM应用时,需要机器进行GLM部署,好多同学第一步就被劝退了,那么如何绕过这个步骤先学习LLM模型的应用,对Langchain进行快速上手?本片讲解3个把LangChain跑起来的方法,如有错误欢迎纠正。Langchain官方文档

使用LangChain开发LLM应用时,需要机器进行GLM部署,好多同学第一步就被劝退了,那么如何绕过这个步骤先学习LLM模型的应用,对Langchain进行快速上手?本片讲解3个把LangChain跑起来的方法,如有错误欢迎纠正。xGT28资讯网——每日最新资讯28at.com

Langchain官方文档地址:https://python.langchain.com/xGT28资讯网——每日最新资讯28at.com

基础功能

LLM 调用xGT28资讯网——每日最新资讯28at.com

  • 支持多种模型接口,比如 OpenAI、HuggingFace、AzureOpenAI …
  • Fake LLM,用于测试
  • 缓存的支持,比如 in-mem(内存)、SQLite、Redis、SQL
  • 用量记录
  • 支持流模式(就是一个字一个字的返回,类似打字效果)

Prompt管理,支持各种自定义模板xGT28资讯网——每日最新资讯28at.com

拥有大量的文档加载器,比如 Email、Markdown、PDF、Youtube …xGT28资讯网——每日最新资讯28at.com

对索引的支持xGT28资讯网——每日最新资讯28at.com

  • 文档分割器
  • 向量化
  • 对接向量存储与搜索,比如 Chroma、Pinecone、Qdrand

ChainsxGT28资讯网——每日最新资讯28at.com

  • LLMChain
  • 各种工具Chain
  • LangChainHub

详细地址可参考:https://www.langchain.cn/t/topic/35xGT28资讯网——每日最新资讯28at.com

测试Langchain工程的3个方法:

1 使用Langchian提供的FakeListLLM

为了节约时间,直接上代码xGT28资讯网——每日最新资讯28at.com

xGT28资讯网——每日最新资讯28at.com

import osfrom decouple import configfrom langchain.agents import initialize_agentfrom langchain.agents import AgentTypefrom langchain.agents import load_tools

这里mock下ChatGPT,使用mockLLmxGT28资讯网——每日最新资讯28at.com

#from langchain.llms import OpenAIfrom langchain.llms.fake import FakeListLLMos.environ["OPENAI_API_KEY"] = config('OPENAI_API_KEY')

REPL 是 “Read–Eval–Print Loop”(读取-求值-打印-循环)的缩写,它是一种简单的、交互式的编程环境。xGT28资讯网——每日最新资讯28at.com

在 REPL 环境中,用户可以输入一条或多条编程语句,系统会立即执行这些语句并输出结果。这种方式非常适合进行快速的代码试验和调试。xGT28资讯网——每日最新资讯28at.com

tools = load_tools(["python_repl"])responses=[    "Action: Python REPL/nAction Input: chatGpt原理",    "Final Answer: mock答案"]llm = FakeListLLM(responses=responses)agent = initialize_agent(tools, llm, agent=AgentType.ZERO_SHOT_REACT_DESCRIPTION, verbose=True)agent.run("chatGpt原理2")

2 使用Langchian提供的HumanInputLLM,访问维基百科查询

xGT28资讯网——每日最新资讯28at.com

from langchain.llms.human import HumanInputLLMfrom langchain.agents import load_toolsfrom langchain.agents import initialize_agentfrom langchain.agents import AgentTypefrom wikipedia import set_lang

使用维基百科工具xGT28资讯网——每日最新资讯28at.com

tools = load_tools(["wikipedia"])

这里必须要设置为中文url前缀,不然访问不了xGT28资讯网——每日最新资讯28at.com

set_lang("zh")

初始化LLMxGT28资讯网——每日最新资讯28at.com

llm = HumanInputLLM(prompt_func=lambda prompt: print(f"/n===PROMPT====/n{prompt}/n=====END OF PROMPT======"))

初始化agentxGT28资讯网——每日最新资讯28at.com

agent = initialize_agent(tools, llm, agent=AgentType.ZERO_SHOT_REACT_DESCRIPTION, verbose=True)agent.run("喜羊羊")

使用huggingfacehttps://huggingface.co/docs

1)注册账号xGT28资讯网——每日最新资讯28at.com

2)创建Access TokensxGT28资讯网——每日最新资讯28at.com

xGT28资讯网——每日最新资讯28at.com

Demo: 使用模型对文档进行摘要xGT28资讯网——每日最新资讯28at.com

xGT28资讯网——每日最新资讯28at.com

from langchain.document_loaders import UnstructuredFileLoaderfrom langchain.chains.summarize import load_summarize_chainfrom langchain.text_splitter import RecursiveCharacterTextSplitterfrom langchain import HuggingFaceHubimport osfrom decouple import configfrom langchain.agents import load_tools

这里mock下ChatGPT,使用HUGGINGFACEHUBxGT28资讯网——每日最新资讯28at.com

os.environ["HUGGINGFACEHUB_API_TOKEN"] = config('HUGGINGFACEHUB_API_TOKEN')

导入文本xGT28资讯网——每日最新资讯28at.com

loader = UnstructuredFileLoader("docment_store/helloLangChain.txt")

将文本转成 Document 对象xGT28资讯网——每日最新资讯28at.com

document = loader.load()print(f'documents:{len(document)}')

初始化文本分割器xGT28资讯网——每日最新资讯28at.com

text_splitter = RecursiveCharacterTextSplitter(    chunk_size = 500,    chunk_overlap = 0)

切分文本xGT28资讯网——每日最新资讯28at.com

split_documents = text_splitter.split_documents(document)print(f'documents:{len(split_documents)}')

加载 LLM 模型xGT28资讯网——每日最新资讯28at.com

overal_temperature = 0.1flan_t5xxl = HuggingFaceHub(repo_id="google/flan-t5-xxl",                          model_kwargs={"temperature":overal_temperature,                                        "max_new_tokens":200}                         ) llm = flan_t5xxltools = load_tools(["llm-math"], llm=llm)

创建总结链xGT28资讯网——每日最新资讯28at.com

chain = load_summarize_chain(llm, chain_type="refine", verbose=True)

执行总结链xGT28资讯网——每日最新资讯28at.com

chain.run(split_documents)

作者:京东科技 杨建xGT28资讯网——每日最新资讯28at.com

来源:京东云开发者社区xGT28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-84-0.html把LangChain跑起来的三个方法

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Automa-通过连接块来自动化你的浏览器

下一篇: 一文看懂为苹果Vision Pro开发应用程序

标签:
  • 热门焦点
  • 石头智能洗地机A10 Plus体验:双向自清洁治好了我的懒癌

    一、前言和介绍专为家庭请假懒人而生的石头科技在近日又带来了自己的全新旗舰新品,石头智能洗地机A10 Plus。从这个产品名上就不难看出,这次石头推出的并不是常见的扫地机器
  • 6月安卓手机好评榜:魅族20 Pro蝉联冠军

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年6月1日至6月30日,仅限国内市场。第一名:魅族20 Pro好评率:95%5月份的时候魅族20 Pro就是
  • 0糖0卡0脂 旭日森林仙草乌龙茶优惠:15瓶到手29元

    旭日森林无糖仙草乌龙茶510ml*15瓶平时要卖为79.9元,今日下单领取50元优惠券,到手价为29.9元。产品规格:0糖0卡0脂,添加草本仙草汁,清凉爽口,富含茶多酚,保留
  • 线程通讯的三种方法!通俗易懂

    线程通信是指多个线程之间通过某种机制进行协调和交互,例如,线程等待和通知机制就是线程通讯的主要手段之一。 在 Java 中,线程等待和通知的实现手段有以下几种方式:Object 类下
  • 大厂卷向扁平化

    来源:新熵作者丨南枝 编辑丨月见大厂职级不香了。俗话说,兵无常势,水无常形,互联网企业调整职级体系并不稀奇。7月13日,淘宝天猫集团启动了近年来最大的人力制度改革,目前已形成一
  • 当家的盒马,加速谋生

    来源 | 价值星球Planet作者 | 归去来自己“当家”的盒马,开始加速谋生了。据盒马官微消息,盒马计划今年开放生鲜供应链,将其生鲜商品送往食堂。目前,盒马在上海已经与
  • 疑似小米14外观设计图曝光:后置相机模组变化不大

    下半年的大幕已经开启,而谁将成为下半年手机圈的主角就成为了大家关注的焦点,其中被传有望拿下新一代骁龙8 Gen3旗舰芯片的小米14系列更是备受大家瞩
  • 华为Mate60标准版细节曝光:经典星环相机模组回归

    这段时间以来,关于华为新旗舰的爆料日渐密集。据此前多方爆料,今年华为将开始恢复一年双旗舰战略,除上半年推出的P60系列外,往年下半年的Mate系列也将
  • iQOO Neo8 Pro抢先上架:首发天玑9200+ 安卓性能之王

    经过了一段时间的密集爆料,昨日iQOO官方如期对外宣布:将于5月23日推出全新的iQOO Neo8系列新品,官方称这是一款拥有旗舰级性能调校的作品。随着发布时
Top