| | --- |
| | license: mit |
| | --- |
| | |
| | This is a reproduction of the <a href="https://arxiv.org/abs/2402.17764"> BitNet b1.58</a> paper. The models are trained with <a href="https://github.com/togethercomputer/RedPajama-Data">RedPajama dataset</a> for 100B tokens. The hypers, as well as two-stage LR and weight decay, are implemented as suggested in their following <a href="https://github.com/microsoft/unilm/blob/master/bitnet/The-Era-of-1-bit-LLMs__Training_Tips_Code_FAQ.pdf">paper</a>. All models are open-source in the <a href="https://huggingface.co/1bitLLM">repo</a>. We will train larger models and/or more tokens when resource is available. |
| |
|
| | ## Results |
| | PPL and zero-shot accuracy: |
| | | Models | PPL| ARCe| ARCc| HS | BQ | OQ | PQ | WGe | Avg |
| | |-------|-------|-------|-------|-------|-------|-------|-------|-------|-------| |
| | | FP16 700M (reported) | 12.33 | 54.7 | 23.0 | 37.0 | 60.0 | 20.2 | 68.9 | 54.8 | 45.5 | |
| | | BitNet b1.58 700M (reported) | 12.87 | 51.8 | 21.4 | 35.1 | 58.2 | 20.0 | 68.1 | 55.2 | 44.3 | |
| | | BitNet b1.58 700M (reproduced) | 12.78 | 51.4 | 21.8 | 35.0 | 59.6 | 20.6 | 67.5 | 55.4 | 44.5 | |
| | | FP16 1.3B (reported) | 11.25 | 56.9 | 23.5 | 38.5 | 59.1 | 21.6 | 70.0 | 53.9 | 46.2 |
| | | BitNet b1.58 1.3B (reported) | 11.29 | 54.9 | 24.2 | 37.7 | 56.7 | 19.6 | 68.8 | 55.8 | 45.4 | |
| | | BitNet b1.58 1.3B (reproduced) | 11.19 | 55.8 | 23.7 | 37.6 | 59.0 | 20.2 | 69.2 | 56.0 | 45.9 |
| | | FP16 3B (reported) | 10.04 | 62.1 | 25.6 | 43.3 | 61.8 | 24.6 | 72.1 | 58.2 | 49.7 |
| | | BitNet b1.58 3B (reported) | 9.91 | 61.4 | 28.3 | 42.9 | 61.5 | 26.6 | 71.5 | 59.3 | 50.2 |
| | | BitNet b1.58 3B (reproduced) | 9.88 | 60.9 | 28.0 | 42.3 | 58.3 | 26.0 | 71.4 | 60.3 | 49.6 | |
| |
|
| | The differences between the reported numbers and the reproduced results are possibly variances from the training data processing, seeds, or other random factors. |
| |
|
| | ## Evaluation |
| | The evaluation pipelines are from the paper authors. Here is the commands to run the evaluation: |
| | ``` |
| | pip install lm-eval==0.3.0 |
| | ``` |
| | ``` |
| | python eval_ppl.py --hf_path 1bitLLM/bitnet_b1_58-3B --seqlen 2048 |
| | ``` |
| | ``` |
| | python eval_task.py --hf_path 1bitLLM/bitnet_b1_58-3B \ |
| | --batch_size 1 \ |
| | --tasks \ |
| | --output_path result.json \ |
| | --num_fewshot 0 \ |
| | --ctx_size 2048 |
| | ``` |
| |
|