--- license: apache-2.0 tags: - MerlynMind - education inference: false --- # Merlyn-education-teacher-assistant Merlyn-education-teacher-assistant is a 12b parameter decoder-style transformer model for the education domain. It is fine-tuned from a [pythia-12b](https://huggingface.co/EleutherAI/pythia-12b) base-model. This model was trained by [Merlyn Mind](https://www.merlyn.org/). Merlyn-education-teacher-assistant is part of the family of Merlyn Mind models designed specifically for use in in- and out-of-classroom education. Merlyn-education-teacher-assistant makes helpful recommendations based on the ongoing classroom discussion, suggesting research activities and topics for further exploration. ## Model Date June 26, 2023 ## Model License Apache-2.0 ## Documentation * [Merlyn Mind’s education-specific language models](https://www.merlyn.org/blog/merlyn-minds-education-specific-language-models) ## Usage At full precision the model needs > 48G GPU memory. A single A100-80GB GPU suffices, for example. If you're running on smaller GPUs, you need an instance with multiple GPUs and/or reduced model precision (e.g. use `model.half()` before moving to device) Loading model and tokenizer: ```python import torch from transformers import AutoTokenizer, AutoModelForCausalLM model_path = "MerlynMind/merlyn-education-teacher-assistant" device = torch.device("cuda:0") # change device id as necessary model = AutoModelForCausalLM.from_pretrained(model_path) tokenizer = AutoTokenizer.from_pretrained(model_path, fast_tokenizer=True) model.to(device) # move to device ``` Prompt example: ```python conversation = ''''user1':\tHow do some gases help keep the Earth warm? 'user2':\tSome gases, called greenhouse gases, act like a blanket around Earth by trapping heat from the sun in the atmosphere, which keeps our planet warm. This process is known as the greenhouse effect. 'user1':\tHow can we reduce greenhouse gas emissions? 'user2':\tWe can reduce greenhouse gas emissions by using renewable energy sources, increasing energy efficiency, and reducing waste.''' prompt = tokenizer.bos_token prompt += '''Instruction:\tYou are teaching high school students. Instruction:\tYou are observing the following conversation between two users. Instruction:\tGenerate 3 research activities based on the conversation. Instruction:\tThe research activities should be doable by high school students. Instruction:\tYour response should be a well-formed JSON array of 3 objects, each with a 'title' property and an 'activity' property. Conversation:''' + f"\n{conversation}" + " Response:" ``` Inference: ```python inputs = tokenizer(prompt, return_tensors="pt").to(device) generate_ids = model.generate( **inputs, max_new_tokens=1024, temperature=0.0, num_beams=2 ) response = tokenizer.decode(generate_ids[0], skip_special_tokens=True, clean_up_tokenization_spaces=True) ``` Example output (after response processing): ```json [ {"title": "Understanding the Greenhouse Effect", "activity": "Research the greenhouse effect and the role of greenhouse gases in keeping Earth warm. Create a presentation or poster explaining the greenhouse effect and how greenhouse gases act as a blanket around Earth."}, {"title": "Renewable Energy Sources", "activity": "Identify different renewable energy sources, such as solar, wind, and geothermal energy, and explain how they can help reduce greenhouse gas emissions."}, {"title": "Energy Efficiency and Waste Reduction", "activity": "Research energy efficiency and waste reduction practices, and develop a plan to implement these practices in your school or community to reduce greenhouse gas emissions."} ] ``` ## Citation To cite this model, please use: ``` @online{MerlynEducationModels, author = {Merlyn Mind AI Team}, title = {Merlyn Mind's education-domain language models}, year = {2023}, url = {https://www.merlyn.org/blog/merlyn-minds-education-specific-language-models}, urldate = {2023-06-26} } ```