--- license: apache-2.0 language: - en - ru base_model: - Qwen/Qwen2.5-14B-Instruct --- ## Description *Eule* is my attempt at reproducing OpenAI's o1 series of reasoning models. At the moment the point is not to hit good scores on benchmarks (this model is rather stupid), but to introduce an quantitative change in how the LLM approaches tasks. Similar to o1 models, Eule approaches its proplems in a step-by-step manner. It is also trained to reason in Russian (ultimately, I want to make a decent russian reasoning model). Cool things I found while playing with it: 1. It tries to verify its solutions to make sure they are correct. 2. When failed, sometimes it tries to reiterate on the problem and try a new approach or fix the mistake. Bad things: 1. It is stupid. Not smarter than the instruct it is based on (not a strict statement, I didn't run any benchmarks yet). Although it's interesting to inspect its chains of thought. 2. The final response (after the reasoning chain) is in English. 3. Sometimes the model may not produce <|REASONING_END|> which messes up parsing. Atm it is trained only on math data but it can solve riddles and other problems that require step-by-step reasoning. I'm planning on adding more non-math data and then proceed to RL. ## Training Details It was trained using [kolibrify](https://github.com/oKatanaaa/kolibrify) on a single H800 for about 6 hours. Training data consists of math problems with solutions formatted as deliberate reasoning chains. The longest reasoning chain is ~19000 tokens. The model follows ChatML template, but introduces several new tokens: - `<|REASONING_START|>` - start of a reasoning chain. - `<|REASONING_END|>` - end of a reasoning chain. - `<|RSS|>` - start of a reasoning step. - `<|RSE|>` - end of a reasoning step. A typical conversation formatting structure is as follows: ``` <|im_start|>system System message<|im_end|> <|im_start|>user Problem description<|im_end|> <|im_start|>assistant <|REASONING_START|><|RSS|>step 1<|RSE|><|RSS|>step 2<|RSE|><|REASONING_END|>Final assistant response<|im_end|> ``` ## How to Get Started with the Model I use [unsloth](https://github.com/unslothai/unsloth) and recommend you do the same: ```python from unsloth import FastLanguageModel model, tokenizer = FastLanguageModel.from_pretrained( model_name='kaleinaNyan/eule-qwen2.5instruct-14b-111224' ) FastLanguageModel.for_inference(model) def generate(chat, n_tokens, use_cache=True, do_sample=False): input_str = tokenizer.apply_chat_template(chat, tokenize=False) + '<|im_start|>assistant\n<|REASONING_START|><|RSS|>' inputs = tokenizer(input_str, return_tensors='pt') outputs = model.generate(input_ids = inputs['input_ids'], max_new_tokens = n_tokens, use_cache = use_cache, do_sample=do_sample, temperature=0.7) return tokenizer.batch_decode(outputs)[0] msg = "Come up with a qubic equation and solve it" system_message = "You are an AI assistant that thoroughly solves any task. Explore various routes and verify your solutions. Reason in Russian. Provide concise responses to the user." chat = [ {'role': 'system', 'content': system_message}, {'role': 'user', 'content': msg}, ] response = generate(chat, 8196, do_sample=True) print('\n'.join(response.split('<|REASONING_START|>')[-1].split('<|RSS|>'))) ``` ## Evaluation I'll provide it later for MATH and GSM8K benchmarks.