mirror of https://github.com/InternLM/InternLM
				
				
				
			|  3599ddd0e4 Co-authored-by: Wenwei Zhang <40779233+ZwwWayne@users.noreply.github.com> | ||
|---|---|---|
| .. | ||
| README.md | ||
| README_zh-CN.md | ||
| chat_format.md | ||
| chat_format_zh-CN.md | ||
| lmdeploy.md | ||
| lmdeploy_zh_cn.md | ||
| openaoe.md | ||
| openaoe_zh_cn.md | ||
| web_demo.py | ||
		
			
				
				README.md
			
		
		
			
			
		
	
	Chat
English | 简体中文
This document briefly shows how to use Transformers, ModelScope, and Web demos to conduct inference with InternLM2-Chat.
You can also know more about the chatml format and how to use LMDeploy for inference and model serving.
Import from Transformers
To load the InternLM2 7B Chat model using Transformers, use the following code:
>>> from transformers import AutoTokenizer, AutoModelForCausalLM
>>> tokenizer = AutoTokenizer.from_pretrained("internlm/internlm2-chat-7b", trust_remote_code=True)
>>> model = AutoModelForCausalLM.from_pretrained("internlm/internlm2-chat-7b", trust_remote_code=True).cuda()
>>> model = model.eval()
>>> response, history = model.chat(tokenizer, "hello", history=[])
>>> print(response)
Hello! How can I help you today?
>>> response, history = model.chat(tokenizer, "please provide three suggestions about time management", history=history)
>>> print(response)
Sure, here are three tips for effective time management:
1. Prioritize tasks based on importance and urgency: Make a list of all your tasks and categorize them into "important and urgent," "important but not urgent," and "not important but urgent." Focus on completing the tasks in the first category before moving on to the others.
2. Use a calendar or planner: Write down deadlines and appointments in a calendar or planner so you don't forget them. This will also help you schedule your time more effectively and avoid overbooking yourself.
3. Minimize distractions: Try to eliminate any potential distractions when working on important tasks. Turn off notifications on your phone, close unnecessary tabs on your computer, and find a quiet place to work if possible.
Remember, good time management skills take practice and patience. Start with small steps and gradually incorporate these habits into your daily routine.
Import from ModelScope
To load the InternLM model using ModelScope, use the following code:
from modelscope import snapshot_download, AutoTokenizer, AutoModelForCausalLM
import torch
model_dir = snapshot_download('Shanghai_AI_Laboratory/internlm2-chat-7b')
tokenizer = AutoTokenizer.from_pretrained(model_dir, device_map="auto", trust_remote_code=True,torch_dtype=torch.float16)
model = AutoModelForCausalLM.from_pretrained(model_dir,device_map="auto",  trust_remote_code=True,torch_dtype=torch.float16)
model = model.eval()
response, history = model.chat(tokenizer, "hello", history=[])
print(response)
response, history = model.chat(tokenizer, "please provide three suggestions about time management", history=history)
print(response)
Dialogue
You can interact with the InternLM Chat 7B model through a frontend interface by running the following code:
pip install streamlit
pip install transformers>=4.34
streamlit run ./chat/web_demo.py
The effect is similar to below: