精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

多模態大模型Reyes增加batch推理方式,提升推理速度 原創

發布于 2025-1-16 15:35
瀏覽
0收藏

筆者在前面預訓練了一個多模態大模型Reyes,詳情見《??【多模態&LLM】Reyes:一個從0到1開始訓練的多模態大模型(技術報告)??》。本文將為Reyes增加一個batch推理方式,提高Reyes的推理速度。

Reyes-8B開源地址:

  • modelscope權重下載地址:https://modelscope.cn/models/yujunhuinlp/Reyes-8B
  • github:https://github.com/yujunhuics/Reyes

使用方式

將本倉庫中的??modeling_reyes.py???文件替換modelscrope下載的??modeling_reyes.py???運行即可。 batch推理詳細見github:??batch_inference.ipynb??.

??modeling_reyes.py??增項:

def chat_batch(
            self,
            tokenizer,
            pixel_values_list,
            questions,
            generation_config,
            histories=None,
            return_histories=False,
            num_patches_lists=None,
            IMG_START_TOKEN='<|vision_start|>',
            IMG_END_TOKEN='<|vision_end|>',
            IMG_CONTEXT_TOKEN='<|vision_pad|>',
            verbose=False,
            visual_features_list=None
    ):

        if histories isNone:
            histories = [[] for _ in questions]

        img_context_token_id = tokenizer.convert_tokens_to_ids(IMG_CONTEXT_TOKEN)
        self.img_context_token_id = img_context_token_id
        # Get eos_token_id from the template
        template = get_conv_template(self.template)
        template.system_message = self.system_message
        eos_token_id = tokenizer.convert_tokens_to_ids(template.sep)
        generation_config['eos_token_id'] = eos_token_id

        queries = []
        input_ids_list = []
        attention_mask_list = []

        for idx in range(len(questions)):
            question = questions[idx]
            history = histories[idx]
            pixel_values = pixel_values_list[idx] if pixel_values_list[idx] isnotNoneelseNone
            num_patches_list = [pixel_values.shape[0]] if pixel_values isnotNoneelse []

            ifnot history and pixel_values isnotNoneand'<image>'notin question:
                question = '<image>\n' + question

            template_i = get_conv_template(self.template)
            template_i.system_message = self.system_message
            for (old_question, old_answer) in history:
                template_i.append_message(template_i.roles[0], old_question)
                template_i.append_message(template_i.roles[1], old_answer)
            template_i.append_message(template_i.roles[0], question)
            template_i.append_message(template_i.roles[1], None)
            query = template_i.get_prompt()
            # Handle image tokens
            if pixel_values isnotNone:
                for num_patches in num_patches_list:
                    tile_pos_identifiers = [f"<tile_{i}>"for i in range(1, num_patches)] + ["<tile_global_thumbnail>"]
                    image_tokens = ''
                    for tile_pos_identifier in tile_pos_identifiers:
                        image_tokens += tile_pos_identifier + IMG_CONTEXT_TOKEN * self.num_image_token
                    image_tokens = IMG_START_TOKEN + image_tokens + IMG_END_TOKEN
                    query = query.replace('<image>', image_tokens, 1)

            model_inputs = tokenizer(
                query,
                return_tensors='pt',
                padding=True,
                truncation=True
            )
            input_ids = model_inputs['input_ids'].cuda()
            attention_mask = model_inputs['attention_mask'].cuda()
            input_ids_list.append(input_ids)
            attention_mask_list.append(attention_mask)

        # Call the generate function
        generation_output = self.generate_batch(
            pixel_values_list=pixel_values_list,
            input_ids_list=input_ids_list,
            attention_mask_list=attention_mask_list,
            **generation_config
        )
        responses = tokenizer.batch_decode(generation_output, skip_special_tokens=True)

        outputs = []
        for idx, response in enumerate(responses):
            response = response.split(template.sep)[0].strip()
            histories[idx].append((questions[idx], response))
            outputs.append(response)

        if return_histories:
            return outputs, histories
        else:
            if verbose:
                for idx, query in enumerate(queries):
                    query_to_print = query.replace(IMG_CONTEXT_TOKEN, '')
                    query_to_print = query_to_print.replace(f'{IMG_START_TOKEN}{IMG_END_TOKEN}', '<image>')
                    print(query_to_print, outputs[idx])
            return outputs

    @torch.no_grad()
    def generate_batch(
            self,
            pixel_values_list: Optional[List[torch.FloatTensor]] = None,
            input_ids_list: Optional[List[torch.FloatTensor]] = None,
            attention_mask_list: Optional[List[torch.LongTensor]] = None,
            visual_features: Optional[torch.FloatTensor] = None,
            generation_config: Optional[GenerationConfig] = None,
            output_hidden_states: Optional[bool] = None,
            return_dict: Optional[bool] = None,
            **generate_kwargs,
    ) -> torch.LongTensor:
        input_embeds_list = []
        attention_mask_padded_list = []

        max_seq_length = max(input_ids.shape[1] for input_ids in input_ids_list)

        for pixel_values, input_ids, attention_mask in zip(pixel_values_list, input_ids_list, attention_mask_list):
            if pixel_values isnotNone:
                if visual_features isnotNone:
                    vit_embeds = visual_features.cuda()
                    vit_embeds = self.mlp1(vit_embeds)
                else:
                    vit_embeds = self.extract_feature(pixel_values)

                input_embeds = self.language_model.get_input_embeddings()(input_ids)
                B, N, C = input_embeds.shape
                input_embeds = input_embeds.reshape(B * N, C)

                input_ids = input_ids.reshape(B * N)
                selected = (input_ids == self.img_context_token_id)
                assert selected.sum() != 0, "No valid image context token IDs found."
                input_embeds[selected] = vit_embeds.reshape(-1, C).to(input_embeds.device)

                input_embeds = input_embeds.reshape(B, N, C)
            else:
                input_embeds = self.language_model.get_input_embeddings()(input_ids)

            seq_length = input_embeds.shape[1]
            if seq_length < max_seq_length:
                pad_size = max_seq_length - seq_length
                input_embeds = F.pad(input_embeds, (0, 0, 0, pad_size))
                attention_mask = F.pad(attention_mask, (0, pad_size))

            input_embeds_list.append(input_embeds)
            attention_mask_padded_list.append(attention_mask)

        input_embeds = torch.cat(input_embeds_list, dim=0)
        attention_mask = torch.cat(attention_mask_padded_list, dim=0)

        outputs = self.language_model.generate(
            inputs_embeds=input_embeds,
            attention_mask=attention_mask,
            generation_config=generation_config,
            output_hidden_states=output_hidden_states,
            return_dict=return_dict,
            use_cache=True,
            **generate_kwargs,
        )

        return outputs

batch推理:

import torch
from modelscope import AutoTokenizer, AutoModel
from PIL import Image
import torchvision.transforms as T
from torchvision.transforms.functional import InterpolationMode

IMAGENET_MEAN = (0.485, 0.456, 0.406)
IMAGENET_STD = (0.229, 0.224, 0.225)


def build_transform(input_size):
    MEAN, STD = IMAGENET_MEAN, IMAGENET_STD
    transform = T.Compose([
        T.Lambda(lambda img: img.convert('RGB') if img.mode != 'RGB'else img),
        T.Resize((input_size, input_size), interpolation=InterpolationMode.BICUBIC),
        T.ToTensor(),
        T.Normalize(mean=MEAN, std=STD)
    ])
    return transform


def find_closest_aspect_ratio(aspect_ratio, target_ratios, width, height, image_size):
    best_ratio_diff = float('inf')
    best_ratio = (1, 1)
    area = width * height
    for ratio in target_ratios:
        target_aspect_ratio = ratio[0] / ratio[1]
        ratio_diff = abs(aspect_ratio - target_aspect_ratio)
        if ratio_diff < best_ratio_diff:
            best_ratio_diff = ratio_diff
            best_ratio = ratio
        elif ratio_diff == best_ratio_diff:
            if area > 0.5 * image_size * image_size * ratio[0] * ratio[1]:
                best_ratio = ratio
    return best_ratio


def dynamic_preprocess(image, min_num=1, max_num=12, image_size=448, use_thumbnail=False):
    orig_width, orig_height = image.size
    aspect_ratio = orig_width / orig_height

    # calculate the existing image aspect ratio
    target_ratios = set(
        (i, j) for n in range(min_num, max_num + 1) for i in range(1, n + 1) for j in range(1, n + 1) if
        i * j <= max_num and i * j >= min_num)
    target_ratios = sorted(target_ratios, key=lambda x: x[0] * x[1])

    # find the closest aspect ratio to the target
    target_aspect_ratio = find_closest_aspect_ratio(
        aspect_ratio, target_ratios, orig_width, orig_height, image_size)

    # calculate the target width and height
    target_width = image_size * target_aspect_ratio[0]
    target_height = image_size * target_aspect_ratio[1]
    blocks = target_aspect_ratio[0] * target_aspect_ratio[1]

    # resize the image
    resized_img = image.resize((target_width, target_height))
    processed_images = []
    for i in range(blocks):
        box = (
            (i % (target_width // image_size)) * image_size,
            (i // (target_width // image_size)) * image_size,
            ((i % (target_width // image_size)) + 1) * image_size,
            ((i // (target_width // image_size)) + 1) * image_size
        )
        # split the image
        split_img = resized_img.crop(box)
        processed_images.append(split_img)
    assert len(processed_images) == blocks
    if use_thumbnail and len(processed_images) != 1:
        thumbnail_img = image.resize((image_size, image_size))
        processed_images.append(thumbnail_img)
    return processed_images


def load_image(image_file, input_size=448, max_num=12):
    image = Image.open(image_file).convert('RGB')
    transform = build_transform(input_size=input_size)
    images = dynamic_preprocess(image, image_size=input_size, use_thumbnail=True, max_num=max_num)
    pixel_values = [transform(image) for image in images]
    pixel_values = torch.stack(pixel_values)
    return pixel_values


def preprocess_image(file_path, dynamic=True, max_num=6, image_size=448):
    try:
        if dynamic:
            return load_image(file_path, max_num=max_num).to(torch.bfloat16).cuda()
        else:
            img = Image.open(file_path).convert('RGB')
            transform = build_transform(image_size)
            pixel_values = transform(img)
            return torch.stack([pixel_values]).to(torch.bfloat16).cuda()
    except Exception as e:
        raise RuntimeError(f"Error processing image: {e}")


path = "Reyes-8B"

model = AutoModel.from_pretrained(
    path,
    torch_dtype=torch.bfloat16,
    trust_remote_code=True,
).eval().cuda()

# print(model)

tokenizer = AutoTokenizer.from_pretrained(path, trust_remote_code=True, use_fast=False)
generation_config = dict(max_new_tokens=2048, do_sample=False)
questions = [
    "<image>\nDescribe this image.",
    "<image>\nDescribe this image.",
    "<image>\nDescribe this image.",
]

images_path = ["t6.png","t6.png","t6.png"]


def conversation(model, tokenizer, questions, images_path,generation_config,histories):
    pixel_values_list=[]

    for i in range(len(questions)):
        if images_path[i] isnotNone:
            pixel_values = preprocess_image(file_path, dynamic=True)
            pixel_values_list.append(pixel_values)


    return model.chat_batch(tokenizer, pixel_values_list, questions, generation_config, histories, return_histories=False)

responses= conversation(model, tokenizer, questions, images_path,generation_config,histories=None)
for question, response in zip(questions, responses):
    print(f"User: {question}\nAssistant: {response}\n")



本文轉載自公眾號大模型自然語言處理  作者:余俊暉

原文鏈接:??https://mp.weixin.qq.com/s/IeDUGzTOnOEONrFoLvXFcg??


?著作權歸作者所有,如需轉載,請注明出處,否則將追究法律責任
收藏
回復
舉報
回復
相關推薦
亚洲福利视频一区二区| 欧美日韩一二三四区| 中文字幕人妻精品一区| 久久久久久久久久久久久久| 精品久久久久久久久久久久久久久 | 国产成人av一区| 欧美在线亚洲一区| 免费在线观看黄色小视频| 日本在线视频一区二区三区| 欧美性猛交99久久久久99按摩| 亚洲欧美丝袜| 日韩中文字幕影院| 免费人成在线不卡| 亚州精品天堂中文字幕| 日本黄区免费视频观看| 久久悠悠精品综合网| 欧美日韩午夜影院| 日日碰狠狠添天天爽超碰97| 久草中文在线观看| 久久麻豆一区二区| 国产精品乱码| av在线免费在线观看| 日韩av中文在线观看| 久久久亚洲影院你懂的| 欧美黑人性猛交xxx| 欧美日韩有码| 亚洲精选一区二区| 国产大尺度视频| 日本亚州欧洲精品不卡| 欧美巨大另类极品videosbest | 在线观看网站免费入口在线观看国内| 国产精品初高中害羞小美女文| 久久伦理网站| 日本黄色不卡视频| 国产99久久久国产精品免费看 | 亚洲性在线观看| 日韩中文字幕av电影| 欧美在线视频免费观看| 国产网址在线观看| 精品动漫一区| 欧美激情xxxx性bbbb| 欧美国产日韩在线观看成人| 久久国产综合| 在线观看亚洲视频| 国产在线综合视频| 日韩免费视频| 自拍视频国产精品| 日韩福利在线视频| 成人网18免费网站| 这里只有精品视频在线| 在线观看免费小视频| 精品久久久亚洲| 在线电影欧美日韩一区二区私密| 天天躁日日躁aaaa视频| 视频精品在线观看| 一本色道久久88综合日韩精品| 99久久精品免费视频| 欧美一区二区三区高清视频| 中文字幕久久亚洲| 波多野结衣欲乱| 综合一区在线| 欧美黄网免费在线观看| 久久久久亚洲av片无码下载蜜桃| 亚洲一本视频| 欧美中文字幕精品| 一级特黄免费视频| 另类小说综合欧美亚洲| 亚洲精品日韩激情在线电影| 亚洲精品国产精品乱码不卡| 不卡电影免费在线播放一区| 蜜桃传媒视频第一区入口在线看| 国产中文在线观看| 国产精品久久久久久久午夜片 | 国产av自拍一区| 欧美日韩激情| 大胆欧美人体视频| 日韩成人在线免费视频| 久久久久久一区二区| 国产精品香蕉在线观看| 国产suv一区二区| 成人高清在线视频| 欧美下载看逼逼| 久久黄色美女电影| 红桃av永久久久| 青青草精品视频在线观看| 在线高清欧美| 亚洲第一色在线| 免费看黄色三级| 综合激情在线| 国产成人亚洲综合青青| 国产情侣在线播放| 久久久久久亚洲综合影院红桃 | 韩国精品久久久999| 天天射综合影视| 精品一区二区三区香蕉蜜桃 | 二区三区四区高清视频在线观看| 亚洲乱码中文字幕综合| 北条麻妃69av| 四虎成人精品一区二区免费网站| 精品国精品国产| 人妻aⅴ无码一区二区三区| va婷婷在线免费观看| 亚洲黄色精品| 国产精品女人网站| 97在线播放视频| 91无套直看片红桃| www.99精品| 在线免费观看成人| 欧美aa免费在线| 日韩一区二区免费在线电影| 中文字幕在线1| 极品中文字幕一区| 成人激情免费在线| 国产系列在线观看| 精品成人乱色一区二区| 久久人人爽人人片| 精品国产一级毛片| 91高清视频免费观看| 国产av无码专区亚洲av麻豆| 欧美激情一区在线观看| 国产精品沙发午睡系列| 在这里有精品| 久久久精品久久久久| 无码aⅴ精品一区二区三区| 成人精品免费视频| 欧美性受黑人性爽| 亚洲人成网站在线在线观看| 国产丝袜一区二区三区免费视频| 久久高清无码视频| 国产一区二区三区日韩| 亚洲精品在线免费| 中韩乱幕日产无线码一区| 国产丝袜精品视频| 日韩欧美成人一区二区三区| 国产成人精品aa毛片| 妞干网这里只有精品| 亚洲精品第一| 综合国产在线观看| 中文字幕人妻一区二区三区视频| 久久综合色播五月| 日日摸日日碰夜夜爽av| 伊甸园亚洲一区| 欧美在线亚洲在线| 青青青在线免费观看| xfplay5566色资源网站| 在线观看免费成人av| 免费一级特黄特色毛片久久看| 台湾av在线二三区观看| 亚洲国产精品一区二区久久 | 日韩欧美一区二区三区四区五区 | 成人深夜在线观看| 亚洲色图都市激情| 在线免费观看视频网站| 肉体视频在线| heyzo高清在线| 国产精品美女久久久久久久久久久 | 国产人妻精品久久久久野外| 久久久久国产精品| 亚洲最大福利视频| 黄色污污视频在线观看| 亚洲国产91精品在线观看| 91精品国产乱码久久久张津瑜| 92国产精品观看| 黄色av免费在线播放| 欧美在线色图| 亚洲自拍偷拍区| xxxcom在线观看| 日韩国产精品一区| 国产精品欧美综合| 亚洲欧美乱综合| 日本黄色免费观看| 日本在线不卡视频| 桥本有菜av在线| 国产精品三p一区二区| 人妖精品videosex性欧美| 韩国精品视频| 制服丝袜成人动漫| 日本五十熟hd丰满| 国产亚洲一区字幕| 日韩精品视频网址| 亚洲一区日韩| 影音先锋欧美资源| 大型av综合网站| 国产91精品在线播放| 成人福利在线观看视频| 亚洲精品国产电影| 一级黄色小视频| 亚洲午夜激情网站| 国产成人免费观看网站| 国产盗摄女厕一区二区三区| 国产淫片av片久久久久久| 国产精品久久久久久久免费观看| 国产视色精品亚洲一区二区| 国产精品伦一区二区| 欧美黄色性视频| 自拍视频在线网| 欧美精品一区二区三区在线播放 | 亚洲第一精品自拍| 在线观看免费高清视频| 亚洲午夜视频在线观看| 粉嫩精品久久99综合一区| 粉嫩13p一区二区三区| 99热手机在线| 在线播放日韩| 99亚洲国产精品| 欧美午夜精彩| 久久爱av电影| 日韩免费一级| 国产一区二中文字幕在线看| 色戒汤唯在线观看| 色综合久久88| 黄av在线播放| 亚洲性视频网站| 手机看片国产1024| 欧美一级xxx| 亚洲视频在线观看一区二区| 欧美日韩一区二区在线 | 黄色亚洲免费| 一区二区三区四区免费视频| 五月天亚洲色图| 国产精品视频一区二区三区经| 婷婷成人av| 国产精选久久久久久| 一呦二呦三呦精品国产| 欧美在线视频播放| 第一中文字幕在线| 欧美乱人伦中文字幕在线| 伊人在线视频| 色视频www在线播放国产成人| 九九九伊在人线综合| 日韩精品高清在线| 香蕉av一区二区三区| 亚洲国产高清福利视频| 日本美女一级片| 欧美成人综合网站| 亚洲不卡免费视频| 欧美一区二区三区免费在线看| 亚洲在线免费观看视频| 欧美最猛性xxxxx直播| 天堂网免费视频| 疯狂做受xxxx欧美肥白少妇| 欧美a∨亚洲欧美亚洲| 大伊人狠狠躁夜夜躁av一区| 999这里只有精品| 精品欧美aⅴ在线网站| 日韩免费视频网站| 欧美性xxxx在线播放| 欧美a∨亚洲欧美亚洲| 色婷婷av一区二区三区之一色屋| 亚洲高清毛片一区二区| 精品久久久久久久中文字幕| 亚洲免费激情视频| 欧美日韩一区免费| 国产免费一区二区三区四区五区 | 欧美激情视频在线免费观看 欧美视频免费一 | 中文字幕亚洲国产| 日本美女高清在线观看免费| 日韩在线观看免费高清完整版| 免费不卡视频| 欧美黑人xxxⅹ高潮交| 91白丝在线| 青青久久av北条麻妃黑人| 青青热久免费精品视频在线18| 成人a免费视频| 视频精品一区二区三区| 国产精品一区在线观看| 香蕉一区二区| 亚洲永久一区二区三区在线| 中国成人一区| koreanbj精品视频一区| 丝袜亚洲另类丝袜在线| 蜜臀一区二区三区精品免费视频| 国产乱子伦一区二区三区国色天香| 2025中文字幕| 久久精品在线观看| 人人干在线观看| 亚洲国产成人va在线观看天堂| 伊人手机在线视频| 欧美美女bb生活片| 欧美特黄一级视频| 亚洲小视频在线| 午夜av在线播放| 国产成人中文字幕| 亚洲国产欧美国产第一区| 久久亚洲一区二区| 999精品色在线播放| 久久久久久久中文| 免费观看在线色综合| 国产51自产区| 国产欧美日本一区二区三区| 国产中文字幕免费| 欧美日韩综合色| 图片区 小说区 区 亚洲五月| 最新日韩中文字幕| 国产网站在线| 成人情趣片在线观看免费| 自拍偷拍一区| 欧美交换配乱吟粗大25p| 日韩精品国产精品| 国产人妻黑人一区二区三区| 中文字幕一区二区三中文字幕| 日产精品久久久久久久| 欧美精品国产精品| 男女视频在线观看| 欧美极品少妇全裸体| 日本免费成人| 日韩精品av一区二区三区| 激情欧美日韩一区| 久久精品久久99| 久久久亚洲午夜电影| 久久精品这里只有精品| 欧美偷拍一区二区| 深夜福利免费在线观看| 欧美精品videofree1080p| 欧美成人毛片| 欧美专区一二三| 亚洲美女色禁图| 岛国大片在线免费观看| 国产精品久久精品日日| 国产免费www| 亚洲摸下面视频| 日韩激情电影| 国产区二精品视| 国产主播精品| 男生和女生一起差差差视频| 国产精品久久久久久亚洲伦| 亚洲性猛交富婆| 亚洲天堂2020| 欧美成人a交片免费看| 精品无码久久久久久久动漫| 黄色av成人| 伊人久久一区二区三区| 亚洲一区二区在线观看视频| 国产黄色一区二区| 久久成年人免费电影| 91麻豆精品国产综合久久久 | 亚洲第一页在线| 欧美女同一区| 99在线首页视频| 午夜精品久久99蜜桃的功能介绍| 国内自拍第二页| **性色生活片久久毛片| 国产一区二区三区视频免费观看| 最好看的2019年中文视频| 国产成人午夜性a一级毛片| 日本一区免费看| 日韩中文字幕1| 97在线观看免费视频| 欧美日韩一区二区三区四区| 午夜免费播放观看在线视频| 国产精品入口福利| 日韩在线观看| 亚欧精品在线视频| 亚洲成人免费视频| 亚洲 精品 综合 精品 自拍| 欧洲永久精品大片ww免费漫画| 亚洲国产合集| www欧美激情| 亚洲天堂精品视频| 亚洲第一精品网站| 51ⅴ精品国产91久久久久久| 精品一区在线| 亚欧美在线观看| 亚洲另类色综合网站| 日本波多野结衣在线| 国产99久久精品一区二区 夜夜躁日日躁 | 亚洲天堂手机| 欧洲在线视频一区| 久久精品国产999大香线蕉| 成人免费毛片xxx| 亚洲国产精品女人久久久| 欧美极品免费| 国产盗摄视频在线观看| av成人免费在线| 青青艹在线观看| 欧美极品少妇xxxxx| 国产欧美日韩| 极品白嫩少妇无套内谢| 欧美日韩午夜视频在线观看| 69视频在线| 精品欧美国产| 久久精品免费看| 国产精品一区二区6| 色先锋资源久久综合5566| 国产精品成人自拍| 亚洲第一狼人区| 亚洲国产精品视频| 99se视频在线观看| 国产伦精品一区二区三区四区免费| 视频一区二区三区中文字幕| 成人观看免费视频| 亚洲欧洲xxxx| 一级毛片精品毛片| 免费看国产黄色片| 亚洲国产一区二区三区| 北岛玲一区二区三区| 国产在线资源一区| 国产一区二区在线视频| 欧美性猛交bbbbb精品| 色综合色综合网色综合|