--- language: - multilingual - en license: apache-2.0 library_name: transformers tags: - nlp - code - vision - chemistry - engineering - biology - bio-inspired - text-generation-inference - materials science - mixture-of-experts - science - latex datasets: - lamm-mit/Cephalo-Bioinspired-Mechanics-Materials - lamm-mit/Cephalo-Wikipedia-Materials pipeline_tag: image-text-to-text inference: parameters: temperature: 0.3 widget: - messages: - role: user content: <|image_1|>Can you describe what you see in the image? --- ## Model Summary Cephalo is a series of multimodal materials science focused vision large language models (V-LLMs) designed to integrate visual and linguistic data for advanced understanding and interaction in human-AI or multi-agent AI frameworks. The model is developed to process diverse inputs, including images and text, facilitating a broad range of applications such as image captioning, visual question answering, and multimodal content generation. The architecture combines a vision encoder model and an autoregressive transformer to process complex natural language understanding. ![image/png](https://cdn-uploads.huggingface.co/production/uploads/623ce1c6b66fedf374859fe7/kl5GWBP9WS0D4uwd1t3S7.png) Cephalo provides a robust framework for multimodal interaction and understanding, including the development of complex generative pipelines to create 2D and 3D renderings of material microstructures as input for additive manufacturing methods. This version of Cephalo, lamm-mit/Cephalo-Idefics2-3x8b-beta, is a Mixture-of-Expert model based on variants and fine-tuned versions of the Idefics-2 model. The basic model architecture is as follows: ![image/png](https://cdn-uploads.huggingface.co/production/uploads/623ce1c6b66fedf374859fe7/b7BK8ZtDzTMsyFDi0wP3w.png) The model has 20b parameters (3 experts, each 8b each, 8b active parameters during inference). ## Download Idefics-2 MoE Model and Sample inference code ```python pip install transformers -U ``` ```python import torch from transformers import AutoModelForCausalLM, AutoProcessor, AutoConfig def count_parameters(model): total_params = sum(p.numel() for p in model.parameters()) trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad) #number of parameters in b return total_params/1e9, trainable_params/1e9 device = torch.device("cuda" if torch.cuda.is_available() else "cpu") model_name_moe = f"lamm-mit/Cephalo-Idefics2-3x8b-beta" config = AutoConfig.from_pretrained(model_name_moe, trust_remote_code=True) processor = AutoProcessor.from_pretrained(model_name_moe, trust_remote_code=True) moe_model = AutoModelForCausalLM.from_pretrained( model_name_moe,config=config, trust_remote_code=True, torch_dtype=torch.bfloat16, ).to(device) count_parameters(moe_model) ``` Now use the downloaded MoE model for inference: ```python from transformers.image_utils import load_image DEVICE='cuda' image = load_image("https://d2r55xnwy6nx47.cloudfront.net/uploads/2018/02/Ants_Lede1300.jpg") # Create inputs messages = [ { "role": "user", "content": [ {"type": "image"}, {"type": "text", "text": "What is shown in this image, and what is the relevance for materials design? Include a discussion of multi-agent AI."}, ] }, ] prompt = processor.apply_chat_template(messages, add_generation_prompt=True) # Get inputs using the processor inputs = processor(text=prompt, images=[image], return_tensors="pt") inputs = {k: v.to(DEVICE) for k, v in inputs.items()} # Generate generated_ids = moe_model.generate(**inputs, max_new_tokens=500) generated_texts = processor.batch_decode(generated_ids, skip_special_tokens=True) print(generated_texts) ``` Output:
The image shows a group of ants climbing over a vertical surface. The ants are using their legs and antennae to navigate the surface, demonstrating their ability to adapt to different environments and overcome obstacles. This behavior is relevant for materials design because it highlights the ants' ability to optimize their movements and interactions with their surroundings, which can inspire the development of advanced materials that mimic these natural adaptations. Multi-agent AI refers to the use of artificial intelligence algorithms to simulate and analyze the behavior of multiple agents, such as ants, in a system. This approach allows for the study of complex interactions and emergent properties that arise from the collective actions of individual agents. By understanding how ants navigate and interact with their environment, researchers can gain insights into the design of materials that exhibit similar properties, such as self-healing, adaptive behavior, and enhanced functionality. The image of ants climbing over a vertical surface highlights their ability to adapt and optimize their movements, which can inspire the development of advanced materials that mimic these natural adaptations. Multi-agent AI provides a framework for analyzing and understanding the behavior of these agents, enabling the design of materials that exhibit similar properties.## Make a Idefics-2-MoE model from scratch using several pre-trained models Download .py files that implement the Phi-3-V and the Mixture-of-Expert Vision model ```python pip install huggingface_hub ``` ```python from huggingface_hub import HfApi, hf_hub_download from tqdm.notebook import tqdm import os import shutil # Repository details repo_id = "lamm-mit/Cephalo-Idefics2-3x8b-beta" api = HfApi() # List all files in the repository files_in_repo = api.list_repo_files(repo_id) # Filter for .py files py_files = [file for file in files_in_repo if file.endswith('.py')] # Directory to save the downloaded files save_dir = "./Idefics2_MoE/" os.makedirs(save_dir, exist_ok=True) # Download each .py file for file_name in tqdm(py_files): file_path = hf_hub_download(repo_id=repo_id, filename=file_name) new_path = os.path.join(save_dir, file_name) shutil.move(file_path, new_path) print(f"Downloaded: {file_name}") print("Download completed.") ``` Download models that will form the experts, as well as the base model. As a simple example, we use 1) Materials-science fine-tuned model: lamm-mit/Cephalo-Idefics-2-vision-8b-beta (model_1) 2) A chatty version: HuggingFaceM4/idefics2-8b-chatty (model_1) (model_2) 3) A basic variant: HuggingFaceM4/idefics2-8b (model_3) One (or another model) must be used as base model, from which the vision model, connector, self-attention, etc. are used. From the list of models provided as experts, the feed forward layers are used. Each model will become one expert. ```python from transformers import AutoProcessor, Idefics2ForConditionalGeneration , AutoTokenizer from transformers import BitsAndBytesConfig from Idefics2_MoE.moe_idefics2 import * DEVICE='cuda' model_id_1='lamm-mit/Cephalo-Idefics-2-vision-8b-beta' model_1 = Idefics2ForConditionalGeneration.from_pretrained( model_id_1, torch_dtype=torch.bfloat16, #if your GPU allows _attn_implementation="flash_attention_2", #make sure Flash Attention 2 is installed trust_remote_code=True, ) processor = AutoProcessor.from_pretrained( f"{model_id_1}", do_image_splitting=True ) config = AutoConfig.from_pretrained(model_id_1, trust_remote_code=True) IDEFICS2_CHAT_TEMPLATE = "{% for message in messages %}{{message['role'].capitalize()}}{% if message['content'][0]['type'] == 'image' %}{{':'}}{% else %}{{': '}}{% endif %}{% for line in message['content'] %}{% if line['type'] == 'text' %}{{line['text']}}{% elif line['type'] == 'image' %}{{ '