7.0. LoRA Improvements in fine-tuning
Last updated
Last updated
O uso do LoRA reduz muito a computação necessária para ajustar modelos já treinados.
LoRA torna possível ajustar grandes modelos de forma eficiente, mudando apenas uma pequena parte do modelo. Isso reduz o número de parâmetros que você precisa treinar, economizando memória e recursos computacionais. Isso ocorre porque:
Reduz o Número de Parâmetros Treináveis: Em vez de atualizar toda a matriz de pesos no modelo, o LoRA divide a matriz de pesos em duas matrizes menores (chamadas A e B). Isso torna o treinamento mais rápido e requer menos memória porque menos parâmetros precisam ser atualizados.
Isso ocorre porque, em vez de calcular a atualização completa de pesos de uma camada (matriz), ele a aproxima a um produto de 2 matrizes menores, reduzindo a atualização a calcular:\
2. **Mantém os Pesos do Modelo Original Inalterados**: O LoRA permite que você mantenha os pesos do modelo original os mesmos e apenas atualize as **novas matrizes pequenas** (A e B). Isso é útil porque significa que o conhecimento original do modelo é preservado, e você apenas ajusta o que é necessário. 3. **Ajuste Fino Eficiente Específico para Tarefas**: Quando você deseja adaptar o modelo a uma **nova tarefa**, pode apenas treinar as **pequenas matrizes LoRA** (A e B) enquanto deixa o resto do modelo como está. Isso é **muito mais eficiente** do que re-treinar o modelo inteiro. 4. **Eficiência de Armazenamento**: Após o ajuste fino, em vez de salvar um **novo modelo completo** para cada tarefa, você só precisa armazenar as **matrizes LoRA**, que são muito pequenas em comparação com o modelo inteiro. Isso facilita a adaptação do modelo a muitas tarefas sem usar muito armazenamento.
Para implementar LoraLayers em vez de Linear durante um ajuste fino, este código é proposto aqui https://github.com/rasbt/LLMs-from-scratch/blob/main/appendix-E/01_main-chapter-code/appendix-E.ipynb: