精品欧美一区二区三区在线观看 _久久久久国色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??


?著作權歸作者所有,如需轉載,請注明出處,否則將追究法律責任
收藏
回復
舉報
回復
相關推薦
国产精品91在线观看| 国产一区二区三区直播精品电影| 国产精品日韩三级| 色婷婷激情五月| 视频在线观看国产精品| 色婷婷综合久久久久| 久久精品无码一区二区三区毛片| 91桃色在线| 中文字幕精品一区二区三区精品| 国产一区二区色| 国产在线视频卡一卡二| 加勒比久久综合| 欧美大片免费久久精品三p| 青青视频在线播放| 中文字幕在线观看网站| 国产欧美日韩精品一区| 91久久国产综合久久蜜月精品| 国产又黄又爽又色| 国产精品毛片久久| 亚洲欧美中文日韩在线| 久久久久中文字幕亚洲精品| 小黄鸭精品aⅴ导航网站入口| 亚洲特黄一级片| 欧美动漫一区二区| 开心激情综合网| 久久国产精品99久久久久久老狼| 91黄色8090| 欧美日韩国产精品综合 | 国产精品99一区二区| 亚洲美女www午夜| 国产吃瓜黑料一区二区| 国产福利一区二区三区在线播放| 狠狠躁18三区二区一区| 日本免费成人网| 黄色网页在线播放| 国产女同互慰高潮91漫画| 国产精品日本一区二区| 国产美女精品视频国产| 日本午夜精品一区二区三区电影| 97欧美精品一区二区三区| 顶臀精品视频www| 精品少妇av| 亚洲色图偷窥自拍| 30一40一50老女人毛片| av男人一区| 日韩欧美一级在线播放| 91丝袜超薄交口足| 色成人综合网| 欧美日本在线播放| 五月天亚洲视频| 日韩大尺度黄色| 欧美日韩中文字幕在线视频| 激情伊人五月天| sm性调教片在线观看| 亚洲天堂精品在线观看| youjizz.com亚洲| 黄网站app在线观看| 亚洲欧洲色图综合| 97超碰免费观看| 大片免费在线看视频| 亚洲免费观看高清| 无码人妻aⅴ一区二区三区日本| 在线播放麻豆| 亚洲色图制服诱惑| 国产乱子伦精品视频| 26uuu亚洲电影在线观看| 亚洲人成在线播放网站岛国| 国产欧美综合一区| 秋霞在线视频| 精品久久久中文| 91av俱乐部| 成人在线视频免费看| 欧美日韩国产综合一区二区| 国产乱码一区二区三区四区| 亚洲不卡视频| 日韩av一区二区在线| 在线观看福利片| 日韩欧美电影| 欧美猛交ⅹxxx乱大交视频| 青青操国产视频| 亚洲精品护士| 日韩免费黄色av| 黄色av免费在线播放| 最新日韩精品| 欧美日韩国产一级| 性生活在线视频| 黄色欧美网站| 国产一区二区av| 波多野结衣家庭教师| 黄色精品一区| 国产精品h片在线播放| 97人妻精品一区二区三区| 国产91精品一区二区麻豆亚洲| 国产精品久久久久久久久婷婷| 九色蝌蚪在线| 亚洲精品写真福利| 国产97在线 | 亚洲| 成人国产精品入口免费视频| 欧美变态口味重另类| 天堂久久精品忘忧草| 永久亚洲成a人片777777| 欧美一区二区三区免费视| 91在线公开视频| 99久久99久久久精品齐齐| 一区二区在线不卡| 夜鲁夜鲁夜鲁视频在线播放| 777a∨成人精品桃花网| 国产男女猛烈无遮挡a片漫画| 国产精品久久占久久| 555www成人网| www.av日韩| 欧美国产日本视频| 日本午夜激情视频| 24小时成人在线视频| 亚洲欧美中文另类| 精品在线视频免费观看| 久久av中文字幕片| 热re99久久精品国产99热| 国内在线免费视频| 3d动漫精品啪啪1区2区免费| 亚洲一级中文字幕| 亚洲大胆在线| 91精品入口蜜桃| 欧美69xxx| 在线观看欧美日本| 久久亚洲AV成人无码国产野外| 欧美三级网页| 96pao国产成视频永久免费| 国产精品免费观看| 欧美日韩国产综合视频在线观看中文 | 国产精品免费久久久| 无码精品人妻一区二区| 亚洲精品国产一区二区三区四区在线| 国产又猛又黄的视频| 亚洲丝袜美腿一区| 午夜美女久久久久爽久久| 97超碰人人草| 国产目拍亚洲精品99久久精品| 国产精品裸体瑜伽视频| 国产成人一二| 久久免费成人精品视频| 亚洲av无码国产综合专区 | 亚洲欧美999| 日韩av片在线播放| 国产99精品国产| 国产成人生活片| 麻豆一二三区精品蜜桃| www.xxxx精品| 99草在线视频| 亚洲免费高清视频在线| 亚洲综合在线一区二区| 亚洲网色网站| 91视频免费进入| 欧美极品少妇videossex| 日韩欧美区一区二| 国产免费无码一区二区视频| 国产伦理精品不卡| 日本三日本三级少妇三级66| 亚洲成人1区| 欧美精品免费在线观看| 国产草草影院ccyycom| 亚洲视频精选在线| 免费不卡av网站| 欧美三级午夜理伦三级中文幕| 99在线影院| 久久99亚洲网美利坚合众国| 精品国产乱码久久久久久闺蜜| 国产精品99精品无码视| 91在线精品一区二区三区| 日本免费黄视频| 欧美日韩国产在线观看网站 | 97久久综合区小说区图片区| 久久久久亚洲精品| 日本人妖在线| 欧美视频三区在线播放| 国产极品美女在线| 国产91丝袜在线播放| 国产精品沙发午睡系列| 精品大片一区二区| 成人在线视频网| 丁香花电影在线观看完整版| 亚洲欧美综合区自拍另类| 一二三区在线播放| 一区二区三区在线高清| 国产麻豆天美果冻无码视频| 日韩av中文在线观看| 久久久国产亚洲精品| 俺去啦;欧美日韩| www.蜜桃av.com| 天天色 色综合| 国产又粗又猛又爽又黄av| 日本不卡高清视频| 亚洲欧美日韩在线综合 | 色婷婷精品大视频在线蜜桃视频| 亚洲a∨无码无在线观看| 国产成人在线视频播放| 熟妇人妻va精品中文字幕| 99久久夜色精品国产亚洲96| 国产一区二区不卡视频| 99欧美精品| 久久频这里精品99香蕉| 韩国免费在线视频| 日韩一级免费观看| 久久久久久无码精品大片| 亚洲精品伦理在线| 免费黄色片网站| 成人综合婷婷国产精品久久免费| 天天操天天爽天天射| 亚洲狠狠婷婷| 亚洲国产欧美日韩| 欧美精品中文字幕亚洲专区| 成人精品久久av网站| 9i看片成人免费高清| 欧美日韩爱爱视频| 日本中文在线观看| 亚洲欧美变态国产另类| 黄频网站在线观看| 日韩欧美在线影院| 中文字幕久久久久| 欧美午夜性色大片在线观看| 麻豆视频在线观看| 亚洲欧洲av在线| 亚洲av熟女国产一区二区性色| 成人免费视频caoporn| 亚洲欧美天堂在线| 美女在线视频一区| 大肉大捧一进一出好爽动态图| 韩国精品一区二区三区| 大桥未久一区二区三区| 色综合久久一区二区三区| 热re99久久精品国产99热| 日韩欧美影院| 国产欧美综合精品一区二区| 国产一区二区三区黄网站| 国产在线播放不卡| 成人免费黄色| 国产精品激情av电影在线观看 | 欧美视频免费一区二区三区| 精品久久久久久最新网址| 91成人一区二区三区| 欧美三区在线观看| 精品国产青草久久久久96| 色琪琪一区二区三区亚洲区| 91video| 欧美性videos高清精品| 国产精品国产三级国产专区52| 午夜精品爽啪视频| 国产奶水涨喷在线播放| 亚洲妇女屁股眼交7| 国产污视频在线观看| 亚洲一区二区三区影院| 久久久久无码国产精品| 亚洲一二三区在线观看| 国产精品.www| 欧美视频精品一区| 国产熟妇一区二区三区四区| 在线看不卡av| 亚洲天堂999| 欧美久久久一区| 精品国产va久久久久久久| 日韩欧美一区在线| 亚洲欧美激情另类| 亚洲国产中文字幕在线观看 | 日韩一中文字幕| a视频在线观看免费| 色综合色综合久久综合频道88| 青春草在线免费视频| 性色av一区二区三区红粉影视| 中文字幕在线直播| 国产美女91呻吟求| 麻豆国产一区| 久久综合久久久| 成人免费在线播放| 神马午夜伦理影院| 亚洲国内精品| 日本超碰在线观看| 国产宾馆实践打屁股91| 久久精品综合视频| 日本一二三四高清不卡| 麻豆一区产品精品蜜桃的特点| 欧美日韩激情网| 一级黄色片在线播放| 日韩精品一区二区三区视频播放 | 日韩小视频网址| 色黄网站在线观看| 琪琪第一精品导航| 国产精品视频一区视频二区| 精品国产综合久久| 99精品综合| 日本免费不卡一区二区| 蜜桃视频在线观看一区| 一区二区三区四区影院| 2023国产一二三区日本精品2022| 波兰性xxxxx极品hd| 五月天中文字幕一区二区| 中文字幕一区二区人妻痴汉电车| 日韩欧美中文一区二区| 国产视频在线看| 欧美激情精品久久久| 国产91亚洲精品久久久| 国产成人免费观看| 日韩精品久久久久久久电影99爱| www.日本在线视频| 美女脱光内衣内裤视频久久影院| 涩视频在线观看| 亚洲欧美自拍偷拍色图| www五月天com| 精品久久久久香蕉网| 色综合久久影院| 国产成人精品视| av成人综合| 麻豆传媒网站在线观看| 日韩成人午夜电影| 性色av蜜臀av浪潮av老女人| 中文字幕一区二区在线播放| 最新中文字幕一区| 精品乱人伦小说| 久久久久久国产精品免费无遮挡| 日韩av电影院| 九九热播视频在线精品6| mm131午夜| 老司机一区二区| 精品人妻中文无码av在线| 精品日本美女福利在线观看| 午夜精品久久久久久久91蜜桃| yw.139尤物在线精品视频| 日本高清不卡一区二区三区视频| 国产福利久久| 欧美激情视频一区二区三区免费| 五月婷婷丁香色| 日本一区二区三区四区| 天堂网视频在线| 亚洲精品永久免费精品| 九九精品调教| 国产99在线播放| 欧美a级一区| 在线成人精品视频| 亚洲女与黑人做爰| 99这里有精品视频| 欧美成人精品激情在线观看| 亚洲日本中文| 欧美一级免费在线观看| 久草在线在线精品观看| 91制片厂在线| 欧美一级片在线观看| av文字幕在线观看| 91精品国产91久久久久青草| 伊人久久大香线| 国产伦理在线观看| 亚洲国产美国国产综合一区二区 | 亚洲午夜精品久久久久久性色| 成人免费看黄| 日韩欧美亚洲区| 激情综合色丁香一区二区| www.99re6| 日韩西西人体444www| 1区2区3区在线| 牛人盗摄一区二区三区视频| 日韩国产精品久久| 亚洲女同二女同志奶水| 51午夜精品国产| 欧洲性视频在线播放| 九九九九久久久久| 日韩电影在线观看网站| 蜜桃av免费观看| 日韩欧美一区二区三区在线| 草草在线视频| 欧洲精品国产| 激情小说亚洲一区| 国产精品99精品| 国产亚洲欧美视频| 国产精久久一区二区| www污在线观看| 久久久久久久久久电影| 国产精品熟女久久久久久 | 巨茎人妖videos另类| 日韩欧美在线电影| 国产乱码精品1区2区3区| 中日韩黄色大片| 久久精品电影一区二区| 99国产精品免费网站| 国产精品99久久免费黑人人妻| 国产精品色哟哟网站| 亚洲欧美激情另类| 国产精品久久久久久久电影 | 麻豆国产欧美一区二区三区r| 一本色道无码道dvd在线观看| 成人免费一区二区三区视频 | 国产精品午夜一区二区| 久久亚洲精品毛片| 爽爽窝窝午夜精品一区二区| 中国黄色片一级| 欧美日韩中文字幕在线| 国产区在线看| 欧美一卡2卡3卡4卡无卡免费观看水多多| 精品一区二区在线视频| 日韩 国产 在线| 久久成年人免费电影| 97se国产在线视频| 日韩电影网1区2区|