<!--Copyright 2023 The HuggingFace Team. All rights reserved.

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
specific language governing permissions and limitations under the License.

⚠️ Note that this file is in Markdown but contain specific syntax for our doc-builder (similar to MDX) that may not be
rendered properly in your Markdown viewer.

-->

# AdaLoRA

[AdaLoRA](https://hf.co/papers/2303.10512) is a method for optimizing the number of trainable parameters to assign to
weight matrices and layers, unlike LoRA, which distributes parameters evenly across all modules. More parameters are
budgeted for important weight matrices and layers while less important ones receive fewer parameters.

The abstract from the paper is:

*Fine-tuning large pre-trained language models on downstream tasks has become an important paradigm in NLP. However,
common practice fine-tunes all of the parameters in a pre-trained model, which becomes prohibitive when a large number
of downstream tasks are present. Therefore, many fine-tuning methods are proposed to learn incremental updates of
pre-trained weights in a parameter efficient way, e.g., low-rank increments. These methods often evenly distribute the
budget of incremental updates across all pre-trained weight matrices, and overlook the varying importance of different
weight parameters. As a consequence, the fine-tuning performance is suboptimal. To bridge this gap, we propose AdaLoRA,
which adaptively allocates the parameter budget among weight matrices according to their importance score. In
particular, AdaLoRA parameterizes the incremental updates in the form of singular value decomposition. Such a novel
approach allows us to effectively prune the singular values of unimportant updates, which is essentially to reduce their
parameter budget but circumvent intensive exact SVD computations. We conduct extensive experiments with several
pre-trained models on natural language processing, question answering, and natural language generation to validate the
effectiveness of AdaLoRA. Results demonstrate that AdaLoRA manifests notable improvement over baselines, especially in
the low budget settings. Our code is publicly available at https://github.com/QingruZhang/AdaLoRA*.

## AdaLoraConfig

[[autodoc]] tuners.adalora.config.AdaLoraConfig

## AdaLoraModel

[[autodoc]] tuners.adalora.model.AdaLoraModel