使用blip2进行图片输入文本输出

多模态的重要模型blip2,官方提供模型可以直接用来图片生成文本

github地址:https://github.com/salesforce/LAVIS/tree/main/projects/blip2

个人相当于跑了一下blip2的demo,记录下过程,供今后需要参考:

1、首先是环境安装,跟着官网走:https://github.com/salesforce/LAVIS/tree/7f00a0891b2890843f61c002a8e9532a40343648#installation

其中,salesforce-lavis我装的时候遇到了问题,可能是服务器网络问题,如果安装有问题,可以尝试pypi下载压缩包进行安装:

pypi网址:https://pypi.org/project/salesforce-lavis/

安装命令:

python 复制代码
pip install salesforce-lavis-1.0.2.tar.gz

期间如果提示缺什么库,按要求装上就可以了

我装的版本:

python 复制代码
conda install pytorch==1.10.0 torchvision==0.11.0 torchaudio==0.10.0 cudatoolkit=11.1 -c pytorch
pip install salesforce-lavis
cd /.../.../LAVIS-main/
pip install -e .
pip install accelerate

期间碰到了transformer的问题,从transformer库导入有问题,我降低了版本,我目前的版本是
transformer==4.35.2

环境装完后,需要下载blip2的模型:

网址:https://huggingface.co/models?other=blip-2

一般是下载上面这个模型,也有其他的可以下载,

具体网址:https://huggingface.co/Salesforce/blip2-opt-2.7b/tree/main

把上面页面中的所有文件下载下来,放到blip2的工作空间中

然后就可以跑官方提供的demo了。

python 复制代码
from PIL import Image
import requests
from transformers import Blip2Processor, Blip2ForConditionalGeneration
import torch

device = "cuda" if torch.cuda.is_available() else "cpu"

processor = Blip2Processor.from_pretrained("my_blip2/blip2-opt-2.7b")
model = Blip2ForConditionalGeneration.from_pretrained(
    "my_blip2/blip2-opt-2.7b", torch_dtype=torch.float16
)
model.to(device)
url = "http://images.cocodataset.org/val2017/000000039769.jpg"
image = Image.open(requests.get(url, stream=True).raw)

inputs = processor(images=image, return_tensors="pt").to(device, torch.float16)

generated_ids = model.generate(**inputs)
generated_text = processor.batch_decode(generated_ids, skip_special_tokens=True)[0].strip()
print(generated_text)

上面的image可以换成自己的图片:

python 复制代码
imgfile = '../../xxx.jpg'
image= Image.open(imgfile).convert('RGB')

或者根据个人需求改成批量化生成文本的代码也可以

相关推荐
廋到被风吹走2 分钟前
【Spring】DefaultListableBeanFactory 详解
java·python·spring
子夜江寒2 分钟前
Python 操作 MySQL 数据库
数据库·python·mysql
梦帮科技9 分钟前
第二十二篇:AI驱动的工作流优化:性能瓶颈自动检测
数据结构·数据库·人工智能·python·开源·极限编程
myzzb13 分钟前
python调用ffmpeg.exe封装装饰类调用
python·学习·ffmpeg·开发
Niuguangshuo14 分钟前
自编码器与变分自编码器:【1】自编码器 - 数据压缩的艺术
人工智能·深度学习
小鸡吃米…14 分钟前
Python - 多重继承
开发语言·python
悟能不能悟14 分钟前
java list怎么进行group
java·python·list
在等星星呐21 分钟前
人工智能从0基础到精通
前端·人工智能·python
A林玖22 分钟前
【 深度学习 】生成对抗网络 GAN
人工智能·深度学习
世界唯一最大变量27 分钟前
自创的机械臂新算法,因为是AI写的,暂时,并不智能,但目前支持任何段数
python·排序算法