本地使用 Ollama 驱动 Llama 3,Phi-3 构建智能代理(附代码)

2024-05-09 14:12

本文主要是介绍本地使用 Ollama 驱动 Llama 3,Phi-3 构建智能代理(附代码),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文介绍如何使用langchain中的ollama库实现低参数Llama 3,Phi-3模型实现本地函数调用及结构化文本输出。

函数调用介绍

函数调用的一个很好的参考是名为 “Gorilla” 的论文,该论文探讨了函数调用的概念,并提供了一个函数调用排行榜。通过这个排行榜,我们可以了解哪些模型擅长函数调用。

例如,我们可以看到 Llama 3 70 亿参数模型在排行榜中位列第七,而 8 亿参数的 Llama 3 模型也在榜单中,尽管性能不及前者,但仍然表现不错。

使用 Ollama 设置 Llama 3 模型

首先,我们来看一个简单的示例,设置 Llama 3 模型并使用 Ollama 进行函数调用。以下是相关代码:

from langchain import Ollama, ChatPromptTemplate, StringOutputParser# 设置 Ollama 模型
llm = Ollama(model_name='llama3')# 设置提示模板
prompt_template = ChatPromptTemplate.from_template("Write me a 500-word article on {topic} from the perspective of {profession}")# 创建字符串输出解析器
output_parser = StringOutputParser()# 调用模型生成文章
response = llm(prompt=prompt_template.format(topic="AI", profession="engineer"), output_parser=output_parser)print(response)

在上述代码中,我们定义了一个简单的提示模板,并使用 Ollama 生成一个 500 字的文章。我们还可以通过设置 keep_alive 属性来保持模型在内存中的活跃状态,避免每次运行时重新加载模型。

生成 JSON 输出

接下来,我们来看如何让 Llama 3 模型生成结构化的 JSON 输出。以下是相关代码:

from langchain import JSONOutputParser# 定义 JSON 模式
json_schema = {"type": "object","properties": {"name": {"type": "string"},"age": {"type": "integer"},"hobbies": {"type": "string"}},"required": ["name", "age"]
}# 设置提示模板
prompt_template = ChatPromptTemplate.from_template("Extract the following information in JSON format: {schema}")# 创建 JSON 输出解析器
output_parser = JSONOutputParser()# 调用模型生成 JSON
response = llm(prompt=prompt_template.format(schema=json_schema), output_parser=output_parser)print(response)

在上述代码中,我们定义了一个 JSON 模式,并使用 Ollama 生成符合该模式的 JSON 输出。通过设置模型的输出格式为 JSON,可以提高生成结构化输出的概率。

使用 Pydantic 定义结构化输出

我们还可以使用 Pydantic 定义一个类,用于提取结构化输出。以下是相关代码:

from pydantic import BaseModel
from langchain import StructuredOutputLLM# 定义 Pydantic 类
class Person(BaseModel):name: strheight: floathair_color: str# 设置提示模板
prompt_template = ChatPromptTemplate.from_template("Extract the following information in JSON format: {context}")# 创建结构化输出 LLM
structured_llm = StructuredOutputLLM(llm, output_class=Person)# 调用模型生成结构化输出
context = "Alex is 5 feet tall, Claudia is 6 feet tall, Claudia has brown hair."
response = structured_llm(prompt=prompt_template.format(context=context))print(response)

在上述代码中,我们使用 Pydantic 定义了一个 Person 类,并使用 Ollama 生成符合该类的结构化输出。

使用工具和函数调用

最后,我们来看如何使用 Ollama 的新功能进行工具和函数调用。以下是相关代码:

from langchain import OllamaFunctions# 定义工具函数
def get_current_weather(location: str, unit: str = "Celsius"):# 这里是获取当前天气的实现pass# 设置工具和函数调用
tools = {"get_current_weather": get_current_weather}
ollama_functions = OllamaFunctions(llm, tools=tools)# 调用模型进行函数调用
question = "What is the weather in Singapore?"
response = ollama_functions(prompt=question)print(response)

在上述代码中,我们定义了一个获取当前天气的工具函数,并使用 Ollama 进行函数调用。模型会根据输入的问题,自动调用相应的工具函数并返回结果。

通过以上示例,我们展示了如何在本地使用 Ollama 和 Llama 3 模型进行函数调用、生成 JSON 输出、定义结构化输出以及使用工具和函数调用。这些方法可以帮助我们在本地构建智能代理,而无需依赖云服务。

参考资料:

1.Function Calling with Local Models & LangChain - Ollama, Llama3 & Phi-3

2.论文:Gorilla: Large Language Model Connected with Massive APIs

这篇关于本地使用 Ollama 驱动 Llama 3,Phi-3 构建智能代理(附代码)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/973611

相关文章

利用Python实现可回滚方案的示例代码

《利用Python实现可回滚方案的示例代码》很多项目翻车不是因为不会做,而是走错了方向却没法回头,技术选型失败的风险我们都清楚,但真正能提前规划“回滚方案”的人不多,本文从实际项目出发,教你如何用Py... 目录描述题解答案(核心思路)题解代码分析第一步:抽象缓存接口第二步:实现两个版本第三步:根据 Fea

Go语言使用slices包轻松实现排序功能

《Go语言使用slices包轻松实现排序功能》在Go语言开发中,对数据进行排序是常见的需求,Go1.18版本引入的slices包提供了简洁高效的排序解决方案,支持内置类型和用户自定义类型的排序操作,本... 目录一、内置类型排序:字符串与整数的应用1. 字符串切片排序2. 整数切片排序二、检查切片排序状态:

Java计算经纬度距离的示例代码

《Java计算经纬度距离的示例代码》在Java中计算两个经纬度之间的距离,可以使用多种方法(代码示例均返回米为单位),文中整理了常用的5种方法,感兴趣的小伙伴可以了解一下... 目录1. Haversine公式(中等精度,推荐通用场景)2. 球面余弦定理(简单但精度较低)3. Vincenty公式(高精度,

python如何下载网络文件到本地指定文件夹

《python如何下载网络文件到本地指定文件夹》这篇文章主要为大家详细介绍了python如何实现下载网络文件到本地指定文件夹,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下...  在python中下载文件到本地指定文件夹可以通过以下步骤实现,使用requests库处理HTTP请求,并结合o

QT6中绘制UI的两种方法详解与示例代码

《QT6中绘制UI的两种方法详解与示例代码》Qt6提供了两种主要的UI绘制技术:​​QML(QtMeta-ObjectLanguage)​​和​​C++Widgets​​,这两种技术各有优势,适用于不... 目录一、QML 技术详解1.1 QML 简介1.2 QML 的核心概念1.3 QML 示例:简单按钮

使用Java将实体类转换为JSON并输出到控制台的完整过程

《使用Java将实体类转换为JSON并输出到控制台的完整过程》在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用JSON格式,用Java将实体类转换为J... 在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用j

一文详解如何查看本地MySQL的安装路径

《一文详解如何查看本地MySQL的安装路径》本地安装MySQL对于初学者或者开发人员来说是一项基础技能,但在安装过程中可能会遇到各种问题,:本文主要介绍如何查看本地MySQL安装路径的相关资料,需... 目录1. 如何查看本地mysql的安装路径1.1. 方法1:通过查询本地服务1.2. 方法2:通过MyS

Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例

《Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例》本文介绍Nginx+Keepalived实现Web集群高可用负载均衡的部署与测试,涵盖架构设计、环境配置、健康检查、... 目录前言一、架构设计二、环境准备三、案例部署配置 前端 Keepalived配置 前端 Nginx

Python logging模块使用示例详解

《Pythonlogging模块使用示例详解》Python的logging模块是一个灵活且强大的日志记录工具,广泛应用于应用程序的调试、运行监控和问题排查,下面给大家介绍Pythonlogging模... 目录一、为什么使用 logging 模块?二、核心组件三、日志级别四、基本使用步骤五、快速配置(bas

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs