fusion-bench 0.2.10__tar.gz → 0.2.11__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (753) hide show
  1. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/PKG-INFO +1 -1
  2. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/compat/method/__init__.py +5 -0
  3. fusion_bench-0.2.11/fusion_bench/method/DOGE_TA/DOGE_TA.py +364 -0
  4. fusion_bench-0.2.11/fusion_bench/method/DOGE_TA/__init__.py +2 -0
  5. fusion_bench-0.2.11/fusion_bench/method/DOGE_TA/layer_wise_adamerging.py +250 -0
  6. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/__init__.py +10 -0
  7. fusion_bench-0.2.11/fusion_bench/method/adamerging/clip_layer_wise_adamerging.py +46 -0
  8. fusion_bench-0.2.11/fusion_bench/method/concrete_subspace/__init__.py +14 -0
  9. fusion_bench-0.2.11/fusion_bench/method/concrete_subspace/clip_post_defense.py +744 -0
  10. fusion_bench-0.2.11/fusion_bench/method/concrete_subspace/clip_safe_concrete_adamerging.py +832 -0
  11. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/isotropic_merging/iso.py +2 -2
  12. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/task_singular_vector/TSVM.py +3 -3
  13. fusion_bench-0.2.11/fusion_bench/models/wrappers/layer_wise_fusion_doge_ta.py +531 -0
  14. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench.egg-info/PKG-INFO +1 -1
  15. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench.egg-info/SOURCES.txt +12 -0
  16. fusion_bench-0.2.11/fusion_bench_config/method/DOGE_TA/DOGE_TA.yaml +4 -0
  17. fusion_bench-0.2.11/fusion_bench_config/method/concrete_subspace/clip_post_defense_AWM.yaml +38 -0
  18. fusion_bench-0.2.11/fusion_bench_config/method/concrete_subspace/clip_post_defense_SAU.yaml +41 -0
  19. fusion_bench-0.2.11/fusion_bench_config/method/concrete_subspace/clip_safe_concrete_layer_wise_adamerging.yaml +39 -0
  20. fusion_bench-0.2.11/fusion_bench_config/method/concrete_subspace/clip_safe_concrete_task_arithmetic.yaml +40 -0
  21. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/pyproject.toml +1 -1
  22. fusion_bench-0.2.10/fusion_bench/method/concrete_subspace/__init__.py +0 -6
  23. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/LICENSE +0 -0
  24. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/README.md +0 -0
  25. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/__init__.py +0 -0
  26. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/__main__.py +0 -0
  27. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/compat/__init__.py +0 -0
  28. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/compat/method/base_algorithm.py +0 -0
  29. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/compat/modelpool/AutoModelForSeq2SeqLM.py +0 -0
  30. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/compat/modelpool/__init__.py +0 -0
  31. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/compat/modelpool/base_pool.py +0 -0
  32. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/compat/modelpool/huggingface_clip_vision.py +0 -0
  33. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/compat/taskpool/__init__.py +0 -0
  34. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/compat/taskpool/base_pool.py +0 -0
  35. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/compat/taskpool/clip_image_classification.py +0 -0
  36. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/compat/taskpool/flan_t5_glue_text_generation.py +0 -0
  37. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/constants/__init__.py +0 -0
  38. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/constants/paths.py +0 -0
  39. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/__init__.py +0 -0
  40. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/arc_agi/__init__.py +0 -0
  41. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/arc_agi/arc.py +0 -0
  42. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/arc_agi/arc_agi.py +0 -0
  43. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/arc_agi/augmenters.py +0 -0
  44. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/arc_agi/messagers.py +0 -0
  45. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/arc_agi/np_cache.py +0 -0
  46. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/arc_agi/preprocess.py +0 -0
  47. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/arc_agi/representers.py +0 -0
  48. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/clip_dataset.py +0 -0
  49. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/fer2013.py +0 -0
  50. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/gpt2_glue.py +0 -0
  51. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/gsm8k.py +0 -0
  52. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/image_dataset.py +0 -0
  53. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/imdb.py +0 -0
  54. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/llama/__init__.py +0 -0
  55. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/llama/alpaca.py +0 -0
  56. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/llama/collate.py +0 -0
  57. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/llama/metamathqa.py +0 -0
  58. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/llama/openai.py +0 -0
  59. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/llama/preference_700k.py +0 -0
  60. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/llama/sharegpt.py +0 -0
  61. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/llama/squad.py +0 -0
  62. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/llama/stanford_shp.py +0 -0
  63. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/llama/ultrachat.py +0 -0
  64. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/llama/utils/__init__.py +0 -0
  65. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/llama/wikitext.py +0 -0
  66. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/dataset/nyuv2.py +0 -0
  67. {fusion_bench-0.2.10/fusion_bench/method/adamerging → fusion_bench-0.2.11/fusion_bench/method/DOGE_TA}/clip_layer_wise_adamerging.py +0 -0
  68. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/ada_svd/__init__.py +0 -0
  69. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/ada_svd/clip_vision.py +0 -0
  70. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/adamerging/__init__.py +0 -0
  71. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/adamerging/clip_task_wise_adamerging.py +0 -0
  72. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/adamerging/entropy_loss.py +0 -0
  73. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/adamerging/flan_t5_layer_wise_adamerging.py +0 -0
  74. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/adamerging/gpt2_layer_wise_adamerging.py +0 -0
  75. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/adamerging/layer_wise_adamerging.py +0 -0
  76. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/adamerging/llama_adamerging.py +0 -0
  77. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/adamerging/min_norm_solvers.py +0 -0
  78. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/adamerging/task_wise_adamerging.py +0 -0
  79. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/adamerging/utils.py +0 -0
  80. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/analysis/__init__.py +0 -0
  81. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/analysis/task_vector_cos_similarity.py +0 -0
  82. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/analysis/task_vector_violin_plot.py +0 -0
  83. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/base_algorithm.py +0 -0
  84. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/classification/__init__.py +0 -0
  85. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/classification/clip_finetune.py +0 -0
  86. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/classification/continual_clip_finetune.py +0 -0
  87. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/concrete_subspace/clip_concrete_adamerging.py +0 -0
  88. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/concrete_subspace/clip_concrete_task_arithmetic.py +0 -0
  89. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/dare/__init__.py +0 -0
  90. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/dare/simple_average.py +0 -0
  91. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/dare/task_arithmetic.py +0 -0
  92. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/dare/ties_merging.py +0 -0
  93. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/dare/utils.py +0 -0
  94. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/dawe/__init__.py +0 -0
  95. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/dawe/dawe_for_clip.py +0 -0
  96. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/dawe/warppers/__init__.py +0 -0
  97. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/dawe/warppers/dawe_model.py +0 -0
  98. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/depth_upscaling/__init__.py +0 -0
  99. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/depth_upscaling/depth_upscaling.py +0 -0
  100. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/depth_upscaling/depth_upscaling_for_llama.py +0 -0
  101. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/dummy.py +0 -0
  102. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/ensemble.py +0 -0
  103. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/fisher_merging/__init__.py +0 -0
  104. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/fisher_merging/clip_fisher_merging.py +0 -0
  105. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/fisher_merging/fisher_merging.py +0 -0
  106. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/fisher_merging/gpt2_fisher_merging.py +0 -0
  107. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/isotropic_merging/__init__.py +1 -1
  108. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/isotropic_merging/iso_utils.py +0 -0
  109. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/linear/__init__.py +0 -0
  110. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/linear/expo.py +0 -0
  111. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/linear/linear_interpolation.py +0 -0
  112. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/linear/llama_expo.py +0 -0
  113. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/linear/simple_average_for_llama.py +0 -0
  114. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/linear/task_arithmetic_for_llama.py +0 -0
  115. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/lm_finetune/__init__.py +0 -0
  116. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/lm_finetune/bradley_terry_rm.py +0 -0
  117. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/lm_finetune/causal_lm_pretrain.py +0 -0
  118. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/lm_finetune/fullfinetune_sft.py +0 -0
  119. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/lm_finetune/peftfinetune_sft.py +0 -0
  120. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/mixture_of_experts/__init__.py +0 -0
  121. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/mixture_of_experts/mixtral_merging.py +0 -0
  122. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/mixture_of_experts/mixtral_upcycling.py +0 -0
  123. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/model_recombination.py +0 -0
  124. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/opcm/__init__.py +0 -0
  125. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/opcm/opcm.py +0 -0
  126. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/opcm/task_arithmetic.py +0 -0
  127. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/opcm/ties_merging.py +0 -0
  128. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/opcm/utils.py +0 -0
  129. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/opcm/weight_average.py +0 -0
  130. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pruning/__init__.py +0 -0
  131. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pruning/llama_magnitude_prune.py +0 -0
  132. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pruning/llama_random_prune.py +0 -0
  133. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pruning/llama_wanda_prune.py +0 -0
  134. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pruning/magnitude_diff_pruning.py +0 -0
  135. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pruning/prune_utils.py +0 -0
  136. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pruning/wanda_utils/__init__.py +0 -0
  137. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pruning/wanda_utils/ablate.py +0 -0
  138. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pruning/wanda_utils/data.py +0 -0
  139. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pruning/wanda_utils/eval.py +0 -0
  140. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pruning/wanda_utils/layerwrapper.py +0 -0
  141. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pruning/wanda_utils/prune.py +0 -0
  142. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pruning/wanda_utils/prune_opt.py +0 -0
  143. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pruning/wanda_utils/sparsegpt.py +0 -0
  144. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pwe_moe/__init__.py +0 -0
  145. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pwe_moe/clip_pwe_moe.py +0 -0
  146. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pwe_moe/module.py +0 -0
  147. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pwe_moe/phn/__init__.py +0 -0
  148. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pwe_moe/phn/solvers.py +0 -0
  149. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/pwe_moe/utils.py +0 -0
  150. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/rankone_moe/__init__.py +0 -0
  151. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/rankone_moe/clip_rankone_moe.py +0 -0
  152. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/rankone_moe/rankone_moe.py +0 -0
  153. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/regmean/__init__.py +0 -0
  154. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/regmean/clip_regmean.py +0 -0
  155. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/regmean/gpt2_regmean.py +0 -0
  156. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/regmean/regmean.py +0 -0
  157. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/simple_average.py +0 -0
  158. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/slerp/__init__.py +0 -0
  159. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/slerp/slerp.py +0 -0
  160. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/slerp/slerp_utils.py +0 -0
  161. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/smile_upscaling/__init__.py +0 -0
  162. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/smile_upscaling/singular_projection_merging.py +0 -0
  163. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/smile_upscaling/smile_mistral_upscaling.py +0 -0
  164. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/smile_upscaling/smile_upscaling.py +0 -0
  165. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/sparse_we_moe/__init__.py +0 -0
  166. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/sparse_we_moe/sparse_clip_we_moe.py +0 -0
  167. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/sparse_we_moe/sparse_we_moe.py +0 -0
  168. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/sparselo/__init__.py +0 -0
  169. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/sparselo/sparselo.py +0 -0
  170. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/surgery/__init__.py +0 -0
  171. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/surgery/clip_layer_wise_adamerging_surgery.py +0 -0
  172. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/tall_mask/__init__.py +0 -0
  173. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/tall_mask/utils.py +0 -0
  174. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/task_arithmetic/__init__.py +0 -0
  175. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/task_arithmetic/task_arithmetic.py +0 -0
  176. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/task_singular_vector/TSVC.py +0 -0
  177. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/task_singular_vector/__init__.py +0 -0
  178. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/task_singular_vector/utils/TSVC_utils.py +0 -0
  179. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/task_singular_vector/utils/TSVM_utils.py +0 -0
  180. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/task_singular_vector/utils/__init__.py +0 -0
  181. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/ties_merging/__init__.py +0 -0
  182. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/ties_merging/ties_merging.py +0 -0
  183. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/ties_merging/ties_merging_utils.py +0 -0
  184. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/trust_region/__init__.py +0 -0
  185. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/trust_region/clip_task_arithmetic.py +0 -0
  186. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/trust_region/utils.py +0 -0
  187. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/we_moe/__init__.py +0 -0
  188. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/we_moe/clip_we_moe.py +0 -0
  189. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/we_moe/we_moe.py +0 -0
  190. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/weighted_average/__init__.py +0 -0
  191. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/weighted_average/llama.py +0 -0
  192. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/method/weighted_average/weighted_average.py +0 -0
  193. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/metrics/__init__.py +0 -0
  194. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/metrics/continual_learning/backward_transfer.py +0 -0
  195. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/metrics/nyuv2/__init__.py +0 -0
  196. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/metrics/nyuv2/depth.py +0 -0
  197. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/metrics/nyuv2/loss.py +0 -0
  198. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/metrics/nyuv2/noise.py +0 -0
  199. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/metrics/nyuv2/normal.py +0 -0
  200. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/metrics/nyuv2/segmentation.py +0 -0
  201. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/metrics/text_to_image_generation/__init__.py +0 -0
  202. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/metrics/text_to_image_generation/aesthetic_scorer.py +0 -0
  203. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/metrics/text_to_image_generation/compressibility.py +0 -0
  204. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/metrics/text_to_image_generation/pickscore_scorer.py +0 -0
  205. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/mixins/__init__.py +0 -0
  206. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/mixins/clip_classification.py +0 -0
  207. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/mixins/fabric_training.py +0 -0
  208. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/mixins/lightning_fabric.py +0 -0
  209. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/mixins/optim/__init__.py +0 -0
  210. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/mixins/optim/adamw_with_warmup.py +0 -0
  211. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/mixins/rich_live.py +0 -0
  212. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/mixins/serialization.py +0 -0
  213. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/mixins/simple_profiler.py +0 -0
  214. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/modelpool/PeftModelForSeq2SeqLM.py +0 -0
  215. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/modelpool/__init__.py +0 -0
  216. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/modelpool/base_pool.py +0 -0
  217. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/modelpool/causal_lm/__init__.py +0 -0
  218. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/modelpool/causal_lm/causal_lm.py +0 -0
  219. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/modelpool/clip_vision/__init__.py +0 -0
  220. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/modelpool/clip_vision/modelpool.py +0 -0
  221. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/modelpool/huggingface_automodel.py +0 -0
  222. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/modelpool/huggingface_gpt2_classification.py +0 -0
  223. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/modelpool/nyuv2_modelpool.py +0 -0
  224. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/modelpool/seq2seq_lm/__init__.py +0 -0
  225. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/modelpool/seq2seq_lm/modelpool.py +0 -0
  226. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/modelpool/seq_classification_lm/__init__.py +0 -0
  227. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/modelpool/seq_classification_lm/reward_model.py +0 -0
  228. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/modelpool/seq_classification_lm/seq_classification_lm.py +0 -0
  229. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/__init__.py +0 -0
  230. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/chat_templates/__init__.py +0 -0
  231. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/chat_templates/llama_3_Instruct.py +0 -0
  232. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/chat_templates/load_tokenizer.py +0 -0
  233. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/hf_clip.py +0 -0
  234. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/linearized/__init__.py +0 -0
  235. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/linearized/linearized_model_utils.py +0 -0
  236. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/linearized/vision_model.py +0 -0
  237. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/llama/__init__.py +0 -0
  238. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/llama/model_utils/__init__.py +0 -0
  239. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/llama/model_utils/embedding.py +0 -0
  240. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/llama/model_utils/liger_kernel.py +0 -0
  241. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/llama/model_utils/misc.py +0 -0
  242. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/llama/model_utils/mod.py +0 -0
  243. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/llama/model_utils/visual.py +0 -0
  244. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/llama/patcher.py +0 -0
  245. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/llama/tokenizer_loader.py +0 -0
  246. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/masks/__init__.py +0 -0
  247. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/masks/mask_model.py +0 -0
  248. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/modeling_losparse_llama/__init__.py +0 -0
  249. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/modeling_losparse_llama/configuration_losparse_llama.py +0 -0
  250. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/modeling_losparse_llama/losparse_linear.py +0 -0
  251. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/modeling_losparse_llama/modeling_losparse_llama.py +0 -0
  252. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/modeling_losparse_llama/register.py +0 -0
  253. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/modeling_losparse_llama/utils.py +0 -0
  254. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/modeling_smile_mistral/__init__.py +0 -0
  255. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/modeling_smile_mistral/configuration_smile_mistral.py +0 -0
  256. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/modeling_smile_mistral/modeling_smile_mistral.py +0 -0
  257. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/modeling_smile_mistral/register.py +0 -0
  258. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/nyuv2/__init__.py +0 -0
  259. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/nyuv2/aspp.py +0 -0
  260. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/nyuv2/lightning_module.py +0 -0
  261. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/nyuv2/resnet.py +0 -0
  262. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/nyuv2/resnet_dilated.py +0 -0
  263. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/parameter_dict.py +0 -0
  264. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/rankone_moe.py +0 -0
  265. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/separate_io.py +0 -0
  266. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/smile_moe/__init__.py +0 -0
  267. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/smile_moe/linear.py +0 -0
  268. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/sparse_we_moe.py +0 -0
  269. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/surgery/__init__.py +0 -0
  270. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/surgery/surgerymodelwrapper.py +0 -0
  271. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/utils.py +0 -0
  272. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/we_moe.py +0 -0
  273. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/wrappers/__init__.py +0 -0
  274. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/wrappers/ensemble.py +0 -0
  275. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/wrappers/layer_wise_fusion.py +0 -0
  276. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/models/wrappers/task_wise_fusion.py +0 -0
  277. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/optim/__init__.py +0 -0
  278. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/optim/exception.py +0 -0
  279. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/optim/lr_scheduler/__init__.py +0 -0
  280. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/optim/lr_scheduler/linear_warmup.py +0 -0
  281. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/optim/lr_scheduler/utils/__init__.py +0 -0
  282. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/optim/lr_scheduler/utils/visualization.py +0 -0
  283. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/optim/mezo.py +0 -0
  284. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/programs/__init__.py +0 -0
  285. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/programs/base_program.py +0 -0
  286. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/programs/fabric_fusion_program.py +0 -0
  287. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/scripts/__init__.py +0 -0
  288. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/scripts/cli.py +0 -0
  289. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/scripts/clip/__init__.py +0 -0
  290. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/scripts/clip/convert_checkpoint.py +0 -0
  291. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/scripts/imgui.py +0 -0
  292. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/scripts/nyuv2_mtl_train.py +0 -0
  293. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/scripts/webui.py +0 -0
  294. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/taskpool/__init__.py +0 -0
  295. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/taskpool/base_pool.py +0 -0
  296. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/taskpool/clip_vision/__init__.py +0 -0
  297. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/taskpool/clip_vision/clip_rankone_moe_taskpool.py +0 -0
  298. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/taskpool/clip_vision/clip_sparse_wemoe_taskpool.py +0 -0
  299. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/taskpool/clip_vision/taskpool.py +0 -0
  300. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/taskpool/dummy.py +0 -0
  301. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/taskpool/gpt2_text_classification.py +0 -0
  302. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/taskpool/llama/__init__.py +0 -0
  303. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/taskpool/llama/reward_model.py +0 -0
  304. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/taskpool/llama/test_generation.py +0 -0
  305. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/taskpool/nyuv2_taskpool.py +0 -0
  306. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/__init__.py +0 -0
  307. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/base_task.py +0 -0
  308. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/classification.py +0 -0
  309. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/__init__.py +0 -0
  310. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/cifar10.py +0 -0
  311. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/cifar100.py +0 -0
  312. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/clip_dataset.py +0 -0
  313. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/cub_200_2011.py +0 -0
  314. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/dtd.py +0 -0
  315. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/emnist_letters.py +0 -0
  316. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/emnist_mnist.py +0 -0
  317. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/eurosat.py +0 -0
  318. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/fashion_mnist.py +0 -0
  319. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/fer2013.py +0 -0
  320. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/flower102.py +0 -0
  321. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/food101.py +0 -0
  322. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/gtsrb.py +0 -0
  323. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/imagenet.py +0 -0
  324. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/kmnist.py +0 -0
  325. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/mnist.py +0 -0
  326. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/mongo_leaf_disease.py +0 -0
  327. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/oxford_iiit_pet.py +0 -0
  328. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/pcam.py +0 -0
  329. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/rendered_sst2.py +0 -0
  330. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/resisc45.py +0 -0
  331. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/stanford_cars.py +0 -0
  332. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/stl10.py +0 -0
  333. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/sun397.py +0 -0
  334. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/svhn.py +0 -0
  335. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/clip_classification/tiny_imagenet.py +0 -0
  336. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/flan_t5_text_generation/__init__.py +0 -0
  337. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/flan_t5_text_generation/datasets_preprocess.py +0 -0
  338. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/flan_t5_text_generation/glue_evaluation.py +0 -0
  339. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/flan_t5_text_generation/glue_load_dataset.py +0 -0
  340. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/flan_t5_text_generation/glue_preprocessors.py +0 -0
  341. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/tasks/flan_t5_text_generation/glue_prompt_templates.py +0 -0
  342. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/__init__.py +0 -0
  343. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/auto.py +0 -0
  344. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/cache_utils.py +0 -0
  345. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/data.py +0 -0
  346. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/devices.py +0 -0
  347. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/dict.py +0 -0
  348. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/dtype.py +0 -0
  349. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/expr.py +0 -0
  350. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/fabric.py +0 -0
  351. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/functools.py +0 -0
  352. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/hydra_utils.py +0 -0
  353. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/instantiate.py +0 -0
  354. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/json.py +0 -0
  355. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/lazy_imports.py +0 -0
  356. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/misc.py +0 -0
  357. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/packages.py +0 -0
  358. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/parameters.py +0 -0
  359. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/path.py +0 -0
  360. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/plot/__init__.py +0 -0
  361. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/plot/color_data.py +0 -0
  362. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/plot/token.py +0 -0
  363. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/plot/token_notebook.py +0 -0
  364. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/pylogger.py +0 -0
  365. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/rich_utils.py +0 -0
  366. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/set.py +0 -0
  367. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/state_dict_arithmetic.py +0 -0
  368. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/strenum/__init__.py +0 -0
  369. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/strenum/_name_mangler.py +0 -0
  370. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/strenum/_version.py +0 -0
  371. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/tensorboard.py +0 -0
  372. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/timer.py +0 -0
  373. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench/utils/type.py +0 -0
  374. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench.egg-info/dependency_links.txt +0 -0
  375. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench.egg-info/entry_points.txt +0 -0
  376. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench.egg-info/requires.txt +0 -0
  377. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench.egg-info/top_level.txt +0 -0
  378. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/README.md +0 -0
  379. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/clip-vit-base-patch32_robustness_corrupted.yaml +0 -0
  380. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/README.md +0 -0
  381. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/TALL14.yaml +0 -0
  382. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/TALL20.yaml +0 -0
  383. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/cifar10.yaml +0 -0
  384. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/cifar100.yaml +0 -0
  385. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/cub-200-2011.yaml +0 -0
  386. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/dtd.yaml +0 -0
  387. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/emnist_letters.yaml +0 -0
  388. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/emnist_mnist.yaml +0 -0
  389. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/eurosat.yaml +0 -0
  390. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/fashion_mnist.yaml +0 -0
  391. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/fer2013.yaml +0 -0
  392. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/food101.yaml +0 -0
  393. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/gtsrb.yaml +0 -0
  394. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/kmnist.yaml +0 -0
  395. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/mango-leaf-disease.yaml +0 -0
  396. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/mnist.yaml +0 -0
  397. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/oxford-iiit-pet.yaml +0 -0
  398. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/oxford_flowers102.yaml +0 -0
  399. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/pcam.yaml +0 -0
  400. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/rendered-sst2.yaml +0 -0
  401. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/resisc45.yaml +0 -0
  402. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/stanford-cars.yaml +0 -0
  403. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/stl10.yaml +0 -0
  404. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/sun397.yaml +0 -0
  405. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/svhn.yaml +0 -0
  406. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/the_eight_tasks.yaml +0 -0
  407. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/test/tiny-imagenet.yaml +0 -0
  408. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/TALL14.yaml +0 -0
  409. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/TALL20.yaml +0 -0
  410. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/cifar10.yaml +0 -0
  411. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/cifar100.yaml +0 -0
  412. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/cub-200-2011.yaml +0 -0
  413. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/dtd.yaml +0 -0
  414. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/emnist_letters.yaml +0 -0
  415. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/emnist_mnist.yaml +0 -0
  416. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/eurosat.yaml +0 -0
  417. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/fashion_mnist.yaml +0 -0
  418. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/fer2013.yaml +0 -0
  419. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/food101.yaml +0 -0
  420. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/gtsrb.yaml +0 -0
  421. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/kmnist.yaml +0 -0
  422. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/mango-leaf-disease.yaml +0 -0
  423. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/mnist.yaml +0 -0
  424. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/oxford-iiit-pet.yaml +0 -0
  425. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/oxford_flowers102.yaml +0 -0
  426. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/pcam.yaml +0 -0
  427. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/rendered-sst2.yaml +0 -0
  428. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/resisc45.yaml +0 -0
  429. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/stanford-cars.yaml +0 -0
  430. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/stl10.yaml +0 -0
  431. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/sun397.yaml +0 -0
  432. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/svhn.yaml +0 -0
  433. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/the_eight_tasks.yaml +0 -0
  434. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/train/tiny-imagenet.yaml +0 -0
  435. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/val/dtd.yaml +0 -0
  436. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/val/eurosat.yaml +0 -0
  437. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/val/gtsrb.yaml +0 -0
  438. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/val/mnist.yaml +0 -0
  439. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/val/resisc45.yaml +0 -0
  440. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/val/stanford-cars.yaml +0 -0
  441. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/val/sun397.yaml +0 -0
  442. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/val/svhn.yaml +0 -0
  443. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/image_classification/val/the_eight_tasks.yaml +0 -0
  444. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/llm_sft/alpaca_cleaned.yaml +0 -0
  445. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/llm_sft/ultrachat_200k.yaml +0 -0
  446. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/question_answering/search_qa.yaml +0 -0
  447. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/question_answering/test/search_qa.yaml +0 -0
  448. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/question_answering/train/MetaMathQA.yaml +0 -0
  449. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/question_answering/train/search_qa.yaml +0 -0
  450. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/question_answering/val/search_qa.yaml +0 -0
  451. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/summarization/test/xsum.yaml +0 -0
  452. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/summarization/train/xsum.yaml +0 -0
  453. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/summarization/val/xsum.yaml +0 -0
  454. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/summarization/xsum.yaml +0 -0
  455. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/text_generation/test/gsm-hard.yaml +0 -0
  456. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/text_generation/test/gsm8k.yaml +0 -0
  457. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/text_generation/test/gsm8k_question_label.yaml +0 -0
  458. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/text_generation/train/CodeAlpaca-20k.yaml +0 -0
  459. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/text_generation/train/gsm8k.yaml +0 -0
  460. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/dataset/text_generation/train/gsm8k_question_label.yaml +0 -0
  461. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/fabric/auto.yaml +0 -0
  462. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/fabric/llama_ddp.yaml +0 -0
  463. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/fabric/llama_fsdp.yaml +0 -0
  464. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/fabric/llama_peft_fsdp.yaml +0 -0
  465. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/fabric/loggers/csv_logger.yaml +0 -0
  466. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/fabric/loggers/tensorboard_logger.yaml +0 -0
  467. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/fabric/loggers/wandb_logger.yaml +0 -0
  468. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/fabric/strategy/deepspeed.yaml +0 -0
  469. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/fabric/strategy/llama_fsdp.yaml +0 -0
  470. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/fabric/strategy/llama_peft_fsdp.yaml +0 -0
  471. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/fabric_model_fusion.yaml +0 -0
  472. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/hydra/default.yaml +0 -0
  473. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/hydra/help/fusion_bench_help.yaml +0 -0
  474. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/hydra/job_logging/rich_logging.yaml +0 -0
  475. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/llama_full_finetune.yaml +0 -0
  476. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/llama_magnitude_pruning.yaml +0 -0
  477. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/llama_model_fusion.yaml +0 -0
  478. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/ada_svd/clip_vision.yaml +0 -0
  479. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/adamerging/clip.yaml +0 -0
  480. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/adamerging/layer_wise_flan_t5.yaml +0 -0
  481. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/adamerging/layer_wise_gpt2.yaml +0 -0
  482. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/adamerging/llama_sft.yaml +0 -0
  483. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/adamerging.yaml +0 -0
  484. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/analysis/task_vector_cos_similarity.yaml +0 -0
  485. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/analysis/task_vector_violin_plot.yaml +0 -0
  486. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/classification/clip_continual_finetune.yaml +0 -0
  487. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/classification/clip_finetune.yaml +0 -0
  488. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/clip_finetune.yaml +0 -0
  489. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/concrete_subspace/clip_concrete_layer_wise_adamerging.yaml +0 -0
  490. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/concrete_subspace/clip_concrete_task_arithmetic.yaml +0 -0
  491. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/concrete_subspace/clip_concrete_task_wise_adamerging.yaml +0 -0
  492. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/dare/simple_average.yaml +0 -0
  493. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/dare/task_arithmetic.yaml +0 -0
  494. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/dare/ties_merging.yaml +0 -0
  495. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/dawe/dawe_for_clip.yaml +0 -0
  496. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/depth_upscaling.yaml +0 -0
  497. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/dummy.yaml +0 -0
  498. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/ensemble/max_model_predictor.yaml +0 -0
  499. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/ensemble/simple_ensemble.yaml +0 -0
  500. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/ensemble/weighted_ensemble.yaml +0 -0
  501. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/fisher_merging/clip_fisher_merging.yaml +0 -0
  502. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/fisher_merging/fisher_merging.yaml +0 -0
  503. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/fisher_merging/gpt2_fisher_merging.yaml +0 -0
  504. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/isotropic_merging/iso_c.yaml +0 -0
  505. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/isotropic_merging/iso_cts.yaml +0 -0
  506. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/linear/expo.yaml +0 -0
  507. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/linear/linear_interpolation.yaml +0 -0
  508. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/linear/llama_expo.yaml +0 -0
  509. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/linear/llama_expo_with_dare.yaml +0 -0
  510. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/linear/simple_average_for_llama.yaml +0 -0
  511. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/linear/task_arithmetic_for_llama.yaml +0 -0
  512. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/linear/weighted_average.yaml +0 -0
  513. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/linear/weighted_average_for_llama.yaml +0 -0
  514. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/lm_finetune/bradley_terry_rm.yaml +0 -0
  515. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/lm_finetune/fullfinetune_sft.yaml +0 -0
  516. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/lm_finetune/peftfinetune_sft.yaml +0 -0
  517. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/mixtral_moe_merging.yaml +0 -0
  518. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/mixtral_moe_upscaling.yaml +0 -0
  519. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/model_recombination.yaml +0 -0
  520. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/opcm/opcm.yaml +0 -0
  521. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/opcm/task_arithmetic.yaml +0 -0
  522. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/opcm/ties_merging.yaml +0 -0
  523. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/opcm/weight_average.yaml +0 -0
  524. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/pruning/llama_magnitude_pruning.yaml +0 -0
  525. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/pruning/llama_random_pruning.yaml +0 -0
  526. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/pruning/llama_wanda_pruning.yaml +0 -0
  527. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/pruning/magnitude_diff_pruning.yaml +0 -0
  528. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/pwe_moe_ls_for_clip.yaml +0 -0
  529. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/rankone_moe/rankone_moe.yaml +0 -0
  530. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/regmean/clip_regmean.yaml +0 -0
  531. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/regmean/gpt2_regmean.yaml +0 -0
  532. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/regmean/regmean.yaml +0 -0
  533. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/simple_average.yaml +0 -0
  534. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/slerp/slerp.yaml +0 -0
  535. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/smile_upscaling/singular_projection_merging.yaml +0 -0
  536. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/smile_upscaling/smile_mistral_upscaling.yaml +0 -0
  537. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/smile_upscaling/smile_upscaling.yaml +0 -0
  538. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/sparselo_pruning/llama_iterative_sparselo.yaml +0 -0
  539. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/sparselo_pruning/llama_pcp_sparselo.yaml +0 -0
  540. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/sparselo_pruning/llama_sparselo.yaml +0 -0
  541. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/surgery/adamerging_surgery.yaml +0 -0
  542. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/task_arithmetic.yaml +0 -0
  543. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/task_singular_vector/TaskSingularVectorMerging.yaml +0 -0
  544. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/ties_merging.yaml +0 -0
  545. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/trust_region/clip_task_arithmetic.yaml +0 -0
  546. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/wemoe/sparse_weight_ensembling_moe.yaml +0 -0
  547. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/method/wemoe/weight_ensembling_moe.yaml +0 -0
  548. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/README.md +0 -0
  549. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16.yaml +0 -0
  550. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_TALL14.yaml +0 -0
  551. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_TALL20.yaml +0 -0
  552. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_cifar10.yaml +0 -0
  553. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_cifar100.yaml +0 -0
  554. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_dtd.yaml +0 -0
  555. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_eight_tasks.yaml +0 -0
  556. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_emnist_letters.yaml +0 -0
  557. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_eurosat.yaml +0 -0
  558. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_fashion_mnist.yaml +0 -0
  559. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_fer2013.yaml +0 -0
  560. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_food101.yaml +0 -0
  561. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_gtsrb.yaml +0 -0
  562. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_kmnist.yaml +0 -0
  563. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_mnist.yaml +0 -0
  564. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_oxford-iiit-pet.yaml +0 -0
  565. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_oxford_flowers102.yaml +0 -0
  566. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_pcam.yaml +0 -0
  567. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_rendered-sst2.yaml +0 -0
  568. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_resisc45.yaml +0 -0
  569. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_stanford-cars.yaml +0 -0
  570. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_stl10.yaml +0 -0
  571. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_sun397.yaml +0 -0
  572. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch16_svhn.yaml +0 -0
  573. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32.yaml +0 -0
  574. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_TALL14.yaml +0 -0
  575. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_TALL20.yaml +0 -0
  576. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_cifar10.yaml +0 -0
  577. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_cifar100.yaml +0 -0
  578. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_dtd.yaml +0 -0
  579. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_eight_tasks.yaml +0 -0
  580. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_emnist_letters.yaml +0 -0
  581. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_eurosat.yaml +0 -0
  582. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_fashion_mnist.yaml +0 -0
  583. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_fer2013.yaml +0 -0
  584. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_food101.yaml +0 -0
  585. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_gtsrb.yaml +0 -0
  586. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_kmnist.yaml +0 -0
  587. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_mnist.yaml +0 -0
  588. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_oxford-iiit-pet.yaml +0 -0
  589. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_oxford_flowers102.yaml +0 -0
  590. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_pcam.yaml +0 -0
  591. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_rendered-sst2.yaml +0 -0
  592. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_resisc45.yaml +0 -0
  593. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_stanford-cars.yaml +0 -0
  594. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_stl10.yaml +0 -0
  595. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_sun397.yaml +0 -0
  596. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-base-patch32_svhn.yaml +0 -0
  597. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14.yaml +0 -0
  598. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_TALL14.yaml +0 -0
  599. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_TALL20.yaml +0 -0
  600. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_cifar10.yaml +0 -0
  601. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_cifar100.yaml +0 -0
  602. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_dtd.yaml +0 -0
  603. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_eight_tasks.yaml +0 -0
  604. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_emnist_letters.yaml +0 -0
  605. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_eurosat.yaml +0 -0
  606. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_fashion_mnist.yaml +0 -0
  607. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_fer2013.yaml +0 -0
  608. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_food101.yaml +0 -0
  609. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_gtsrb.yaml +0 -0
  610. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_kmnist.yaml +0 -0
  611. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_mnist.yaml +0 -0
  612. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_oxford-iiit-pet.yaml +0 -0
  613. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_oxford_flowers102.yaml +0 -0
  614. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_pcam.yaml +0 -0
  615. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_rendered-sst2.yaml +0 -0
  616. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_resisc45.yaml +0 -0
  617. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_stanford-cars.yaml +0 -0
  618. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_stl10.yaml +0 -0
  619. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_sun397.yaml +0 -0
  620. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/clip-vit-large-patch14_svhn.yaml +0 -0
  621. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/download_TALL20_models.sh +0 -0
  622. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/clip-vit/generate_vit_model_config.sh +0 -0
  623. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base.yaml +0 -0
  624. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-cola.yaml +0 -0
  625. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-cola_lora-16.yaml +0 -0
  626. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-mnli.yaml +0 -0
  627. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-mnli_lora-16.yaml +0 -0
  628. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-mrpc.yaml +0 -0
  629. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-mrpc_lora-16.yaml +0 -0
  630. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-qnli.yaml +0 -0
  631. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-qnli_lora-16.yaml +0 -0
  632. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-qqp.yaml +0 -0
  633. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-qqp_lora-16.yaml +0 -0
  634. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-rte.yaml +0 -0
  635. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-rte_lora-16.yaml +0 -0
  636. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-sst2.yaml +0 -0
  637. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-sst2_lora-16.yaml +0 -0
  638. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-stsb.yaml +0 -0
  639. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-base_glue-stsb_lora-16.yaml +0 -0
  640. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-large.yaml +0 -0
  641. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-large_glue-cola_lora-16.yaml +0 -0
  642. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-large_glue-mnli_lora-16.yaml +0 -0
  643. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-large_glue-mrpc_lora-16.yaml +0 -0
  644. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-large_glue-qnli_lora-16.yaml +0 -0
  645. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-large_glue-qqp_lora-16.yaml +0 -0
  646. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-large_glue-rte_lora-16.yaml +0 -0
  647. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-large_glue-sst2_lora-16.yaml +0 -0
  648. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/flan-t5-large_glue-stsb_lora-16.yaml +0 -0
  649. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/model/flan-t5/generate_flan-t5.sh +0 -0
  650. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/_template.yaml +0 -0
  651. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch16_TA8.yaml +0 -0
  652. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch16_TA8_lora.yaml +0 -0
  653. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch16_TA8_model_only.yaml +0 -0
  654. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch16_TALL14.yaml +0 -0
  655. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch16_TALL14_model_only.yaml +0 -0
  656. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch16_TALL20.yaml +0 -0
  657. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch16_TALL20_model_only.yaml +0 -0
  658. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch16_individual.yaml +0 -0
  659. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch16_individual_lora.yaml +0 -0
  660. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_TA8.yaml +0 -0
  661. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_TA8_control_task.yaml +0 -0
  662. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_TA8_model_only.yaml +0 -0
  663. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_TALL14.yaml +0 -0
  664. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_TALL14_model_only.yaml +0 -0
  665. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_TALL20.yaml +0 -0
  666. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_TALL20_model_only.yaml +0 -0
  667. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_generalization_exp1.yaml +0 -0
  668. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_generalization_exp2.yaml +0 -0
  669. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_individual.yaml +0 -0
  670. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_mtl.yaml +0 -0
  671. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_robustness_clean.yaml +0 -0
  672. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_robustness_corrupted.yaml +0 -0
  673. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_single_finetuned.yaml +0 -0
  674. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_single_task_projection.yaml +0 -0
  675. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_svhn_and_mnist.yaml +0 -0
  676. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-base-patch32_two_tasks_control_task.yaml +0 -0
  677. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-large-patch14_TA8.yaml +0 -0
  678. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-large-patch14_TA8_model_only.yaml +0 -0
  679. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-large-patch14_TALL14.yaml +0 -0
  680. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-large-patch14_TALL14_model_only.yaml +0 -0
  681. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-large-patch14_TALL20.yaml +0 -0
  682. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-large-patch14_TALL20_model_only.yaml +0 -0
  683. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CLIPVisionModelPool/clip-vit-large-patch14_individual.yaml +0 -0
  684. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CausalLMPool/llama_alpaca_cleaned.yaml +0 -0
  685. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CausalLMPool/llama_codealpaca.yaml +0 -0
  686. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CausalLMPool/llama_for_causallm.yaml +0 -0
  687. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CausalLMPool/llama_metamathqa.yaml +0 -0
  688. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CausalLMPool/llama_ultrachat.yaml +0 -0
  689. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CausalLMPool/simle_mixtral_exp_v4.yaml +0 -0
  690. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/CausalLMPool/single_llama_model.yaml +0 -0
  691. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/Seq2SeqLMPool/_template.yaml +0 -0
  692. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/Seq2SeqLMPool/flan-t5-base_glue.yaml +0 -0
  693. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/Seq2SeqLMPool/flan-t5-base_glue_lora16.yaml +0 -0
  694. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/Seq2SeqLMPool/flan-t5-base_glue_lora16_tta.yaml +0 -0
  695. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/Seq2SeqLMPool/flan-t5-base_individual.yaml +0 -0
  696. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/Seq2SeqLMPool/flan-t5-large_glue_lora16.yaml +0 -0
  697. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/SeqenceClassificationModelPool/llama_preference700k.yaml +0 -0
  698. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/SeqenceClassificationModelPool/single_reward_model.yaml +0 -0
  699. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/automodelpool.yaml +0 -0
  700. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/gpt-2_glue.yaml +0 -0
  701. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/mixtral_moe_merging.yaml +0 -0
  702. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/mixtral_moe_upscaling.yaml +0 -0
  703. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/nyuv2_modelpool.yaml +0 -0
  704. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/smile_mistral_exp_v1.yaml +0 -0
  705. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/smile_mistral_exp_v2.yaml +0 -0
  706. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/smile_mistral_exp_v3.yaml +0 -0
  707. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/modelpool/smile_mistral_exp_v4.yaml +0 -0
  708. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/nyuv2_config.yaml +0 -0
  709. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/nyuv2_mtl_train.yaml +0 -0
  710. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/_template.yaml +0 -0
  711. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-base-patch32_robustness_corrupted.yaml +0 -0
  712. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-classification_TA8.yaml +0 -0
  713. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-classification_TA8_B16.yaml +0 -0
  714. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-classification_TA8_L14.yaml +0 -0
  715. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-classification_TA8_val.yaml +0 -0
  716. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-classification_TA8_with_control_task.yaml +0 -0
  717. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-classification_TALL14.yaml +0 -0
  718. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-classification_TALL20.yaml +0 -0
  719. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_cifar10.yaml +0 -0
  720. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_cifar100.yaml +0 -0
  721. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_dtd.yaml +0 -0
  722. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_emnist_letters.yaml +0 -0
  723. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_eurosat.yaml +0 -0
  724. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_fashion_mnist.yaml +0 -0
  725. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_fer2013.yaml +0 -0
  726. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_food101.yaml +0 -0
  727. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_gtsrb.yaml +0 -0
  728. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_kmnist.yaml +0 -0
  729. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_mnist.yaml +0 -0
  730. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_oxford-iiit-pet.yaml +0 -0
  731. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_oxford_flowers102.yaml +0 -0
  732. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_oxford_flowers102_val.yaml +0 -0
  733. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_pcam.yaml +0 -0
  734. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_rendered-sst2.yaml +0 -0
  735. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_resisc45.yaml +0 -0
  736. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_stanford-cars.yaml +0 -0
  737. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_stl10.yaml +0 -0
  738. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_sun397.yaml +0 -0
  739. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip-vit-single-task_svhn.yaml +0 -0
  740. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip_rankone_wemoe_clip-vit-classification_TA8.yaml +0 -0
  741. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/CLIPVisionModelTaskPool/clip_sparse_wemoe_clip-vit-classification_TA8.yaml +0 -0
  742. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/clip-vit-base-patch32_robustness_clean.yaml +0 -0
  743. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/clip-vit-base-patch32_robustness_corrupted.yaml +0 -0
  744. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/clip-vit-base-patch32_svhn_and_mnist.yaml +0 -0
  745. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/dummy.yaml +0 -0
  746. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/flan-t5_glue_text_generation.yaml +0 -0
  747. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/gpt-2_glue.yaml +0 -0
  748. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/nyuv2_taskpool.yaml +0 -0
  749. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/fusion_bench_config/taskpool/reward_model_evaluation.yaml +0 -0
  750. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/setup.cfg +0 -0
  751. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/tests/test_depth_upscaling.py +1 -1
  752. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/tests/test_simple_average.py +0 -0
  753. {fusion_bench-0.2.10 → fusion_bench-0.2.11}/tests/test_weighed_ensemble.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: fusion_bench
3
- Version: 0.2.10
3
+ Version: 0.2.11
4
4
  Summary: A Comprehensive Benchmark of Deep Model Fusion
5
5
  Author-email: Anke Tang <tang.anke@foxmail.com>
6
6
  License: MIT License
@@ -20,12 +20,17 @@ class AlgorithmFactory:
20
20
  # model merging methods
21
21
  "clip_task_wise_adamerging": ".adamerging.clip_task_wise_adamerging.CLIPTaskWiseAdaMergingAlgorithm",
22
22
  "clip_layer_wise_adamerging": ".adamerging.clip_layer_wise_adamerging.CLIPLayerWiseAdaMergingAlgorithm",
23
+ "clip_layer_wise_adamerging_doge_ta": ".DOGE_TA.clip_layer_wise_adamerging.CLIPLayerWiseAdaMergingAlgorithm",
23
24
  "singular_projection_merging": "fusion_bench.method.smile_upscaling.singular_projection_merging.SingularProjectionMergingAlgorithm",
24
25
  "clip_layer_wise_adamerging_surgery": ".surgery.clip_layer_wise_adamerging_surgery.CLIPLayerWiseAdaMergingSurgeryAlgorithm",
25
26
  # plug-and-play model merging methods
26
27
  "clip_concrete_task_arithmetic": ".concrete_subspace.clip_concrete_task_arithmetic.ConcreteTaskArithmeticAlgorithmForCLIP",
27
28
  "clip_concrete_task_wise_adamerging": ".concrete_subspace.clip_concrete_adamerging.ConcreteTaskWiseAdaMergingForCLIP",
28
29
  "clip_concrete_layer_wise_adamerging": ".concrete_subspace.clip_concrete_adamerging.ConcreteLayerWiseAdaMergingForCLIP",
30
+ "clip_post_defense_AWM": ".concrete_subspace.clip_post_defense.PostDefenseAWMAlgorithmForCLIP",
31
+ "clip_post_defense_SAU": ".concrete_subspace.clip_post_defense.PostDefenseSAUAlgorithmForCLIP",
32
+ "clip_safe_concrete_layer_wise_adamerging": ".concrete_subspace.clip_safe_concrete_adamerging.ConcreteSafeLayerWiseAdaMergingForCLIP",
33
+ "clip_safe_concrete_task_wise_adamerging": ".concrete_subspace.clip_safe_concrete_adamerging.ConcreteSafeTaskWiseAdaMergingForCLIP",
29
34
  # model mixing methods
30
35
  "clip_weight_ensembling_moe": ".we_moe.clip_we_moe.CLIPWeightEnsemblingMoEAlgorithm",
31
36
  "sparse_clip_weight_ensembling_moe": "fusion_bench.method.SparseCLIPWeightEnsemblingMoEAlgorithm",
@@ -0,0 +1,364 @@
1
+ R"""
2
+ This script contains the general implementation of Modeling Multi-Task Model Merging as Adaptive Projective Gradient Descent.
3
+
4
+ https://arxiv.org/abs/2501.01230
5
+
6
+ Example Usage:
7
+
8
+ ```bash
9
+ fusion_bench \
10
+ method=DOGE_TA/DOGE_TA \
11
+ modelpool=CLIPVisionModelPool/clip-vit-base-patch32_TA8_model_only \
12
+ taskpool=CLIPVisionModelTaskPool/clip-vit-classification_TA8
13
+
14
+ fusion_bench \
15
+ method=adamerging \
16
+ method.name=clip_layer_wise_adamerging_doge_ta \
17
+ modelpool=CLIPVisionModelPool/clip-vit-base-patch32_TA8 \
18
+ taskpool=CLIPVisionModelTaskPool/clip-vit-classification_TA8
19
+ ```
20
+ """
21
+
22
+ import copy
23
+ import logging
24
+ import time
25
+ from collections import OrderedDict
26
+ from copy import deepcopy
27
+ from functools import reduce
28
+ from typing import Dict, List, Mapping, TypeVar, Union # noqa: F401
29
+
30
+ import lightning as L
31
+ import torch
32
+ from torch import nn
33
+
34
+ from fusion_bench.method.base_algorithm import BaseAlgorithm
35
+ from fusion_bench.mixins.lightning_fabric import LightningFabricMixin
36
+ from fusion_bench.mixins.simple_profiler import SimpleProfilerMixin
37
+ from fusion_bench.modelpool import BaseModelPool
38
+ from fusion_bench.utils.state_dict_arithmetic import (
39
+ state_dict_add,
40
+ state_dict_mul,
41
+ state_dict_sub,
42
+ )
43
+ from fusion_bench.utils.type import StateDictType
44
+
45
+ log = logging.getLogger(__name__)
46
+
47
+
48
+ class DOGE_TA_Algorithm(
49
+ BaseAlgorithm,
50
+ SimpleProfilerMixin,
51
+ LightningFabricMixin,
52
+ ):
53
+ """
54
+ Task Arithmetic Algorithm for model fusion with learnable delta.
55
+
56
+ This class extends the Task Arithmetic method to include a learnable delta
57
+ for task vectors, optimized to maximize cosine similarity among the task vectors.
58
+
59
+ Attributes:
60
+ scaling_factor (int): The factor by which the task vectors will be scaled before merging.
61
+ delta (StateDictType): A learnable parameter to adjust task vectors, initialized as zeros.
62
+ """
63
+
64
+ _config_mapping = BaseAlgorithm._config_mapping | {
65
+ "subspace": "subspace",
66
+ "K": "K",
67
+ "lamda": "lamda",
68
+ }
69
+
70
+ def __init__(self, subspace, K, lamda):
71
+ self.delta = None # Initialize delta as None; will be set during run
72
+ self.subspace = subspace
73
+ self.K = K
74
+ self.lamda = lamda
75
+ super().__init__()
76
+
77
+ @property
78
+ def device(self) -> torch.device:
79
+ return self.fabric.device
80
+
81
+ @torch.no_grad()
82
+ def compute_task_vectors(
83
+ self, modelpool: BaseModelPool, pretrained_model: nn.Module
84
+ ) -> List[StateDictType]:
85
+ """
86
+ Computes task vectors for each model in the model pool relative to the pretrained model.
87
+ """
88
+ task_vectors = []
89
+ pretrained_sd = pretrained_model.state_dict(keep_vars=True)
90
+ filtered_keys = [
91
+ k
92
+ for k in pretrained_sd.keys()
93
+ if ("encoder" in k and "layer_norm" not in k and "weight" in k)
94
+ ] # Flan T5: "layer_norm" not in k and ("q.weight" in k or "v.weight" in k)
95
+
96
+ for model_name in modelpool.model_names:
97
+ model = modelpool.load_model(model_name)
98
+ model_sd = model.state_dict(keep_vars=True)
99
+
100
+ filtered_task_vector = {
101
+ k: (model_sd[k] - pretrained_sd[k]) for k in filtered_keys
102
+ }
103
+ task_vectors.append(filtered_task_vector)
104
+
105
+ return task_vectors
106
+
107
+ def taskvector_loss(self, layer_vectors, layer_delta, layer_lamdas) -> torch.Tensor:
108
+ """
109
+ Computes the loss based on delta and task vectors for a specific layer.
110
+ """
111
+ total_loss = 0.0
112
+
113
+ layer_vectors_scale = layer_vectors * layer_lamdas.view(-1, 1, 1)
114
+ sum_over_num_vectors = layer_vectors_scale.sum(dim=0)
115
+
116
+ layer_delta_scale = layer_delta.unsqueeze(0) * layer_lamdas.view(-1, 1, 1)
117
+ sum_over_delta = layer_delta_scale.sum(dim=0)
118
+
119
+ # Iterate through each vector and calculate the loss one by one
120
+ for v_j in layer_vectors:
121
+ part1 = -v_j * sum_over_num_vectors
122
+ part2 = -v_j * sum_over_delta
123
+ part3 = v_j * v_j
124
+
125
+ expression = part1 + part2 + part3
126
+ layer_loss = expression.sum(dim=1).pow(2).sum()
127
+
128
+ # Cumulative total loss
129
+ total_loss += layer_loss
130
+ return total_loss
131
+
132
+ @torch.enable_grad()
133
+ def optimize_delta(self, task_vectors: List[StateDictType]) -> None:
134
+ """
135
+ Optimizes the delta based on the loss of task vectors.
136
+ """
137
+ if self.delta is None:
138
+ self.delta = {
139
+ k: nn.Parameter(torch.zeros_like(v, device=self.device).detach())
140
+ for k, v in task_vectors[0].items()
141
+ }
142
+
143
+ optimizer = torch.optim.Adam(self.delta.values(), lr=1e-4)
144
+ initial_mem = torch.cuda.memory_allocated()
145
+ start_time = time.time()
146
+ for layer_name in task_vectors[0].keys():
147
+ layer_vectors = torch.stack([vec[layer_name] for vec in task_vectors]).to(
148
+ self.device
149
+ )
150
+ layer_lamdas = torch.stack(
151
+ [lamdas[layer_name] for lamdas in self.lamdas]
152
+ ).to(self.device)
153
+ for _ in range(400):
154
+ optimizer.zero_grad()
155
+ loss = self.taskvector_loss(
156
+ layer_vectors, self.delta[layer_name], layer_lamdas
157
+ )
158
+ self.fabric.backward(loss)
159
+ grad_proj = (
160
+ self.projection[layer_name] @ self.delta[layer_name].grad.detach()
161
+ )
162
+ self.delta[layer_name].grad.data = self.delta[
163
+ layer_name
164
+ ].grad.data.sub_(grad_proj)
165
+ optimizer.step()
166
+ self.delta[layer_name].grad = None
167
+ end_time = time.time()
168
+ print(f"Running time: {end_time - start_time} s")
169
+ final_mem = torch.cuda.memory_allocated()
170
+ print(f"Memory usage: {(final_mem - initial_mem) / (1024 ** 2)} MB")
171
+ print("Optimization completed.")
172
+
173
+ @torch.no_grad()
174
+ def run(self, modelpool: Union[BaseModelPool, Dict[str, nn.Module]]):
175
+ """
176
+ Runs the Algorithm with learnable delta to fuse models in the given model pool.
177
+
178
+ Args:
179
+ modelpool (Union[BaseModelPool, Dict[str, nn.Module]]): The pool of models to fuse.
180
+
181
+ Returns:
182
+ nn.Module: The pre-trained model with the merged task vectors after optimizing delta.
183
+ """
184
+ if not isinstance(modelpool, BaseModelPool):
185
+ modelpool = BaseModelPool(modelpool)
186
+
187
+ log.info("Fusing models using DOGE_TA with learnable delta.")
188
+ with self.profile("load model"):
189
+ pretrained_model = modelpool.load_model("_pretrained_")
190
+
191
+ task_vectors = self.compute_task_vectors(modelpool, pretrained_model)
192
+
193
+ self.lamdas = self.compute_layer_lamdas(task_vectors)
194
+ self.projection = {}
195
+ for layer_name in task_vectors[0].keys():
196
+ for i, vector in enumerate(task_vectors):
197
+ layer_vector = vector[layer_name].to(self.device)
198
+ u, s, v = torch.linalg.svd(layer_vector, full_matrices=False)
199
+ if i == 0:
200
+ print(f"Computed SVD for {layer_name}...")
201
+ sum_u = torch.zeros_like(u, device=layer_vector.device)
202
+ sum_s = torch.zeros_like(s, device=layer_vector.device)
203
+ sum_v = torch.zeros_like(v, device=layer_vector.device)
204
+
205
+ reduced_index_s = int(s.shape[0] / len(task_vectors))
206
+
207
+ # select only the first reduced_index_s columns of u and place them
208
+ sum_u[:, i * reduced_index_s : (i + 1) * reduced_index_s] = u[
209
+ :, :reduced_index_s
210
+ ]
211
+ sum_s[i * reduced_index_s : (i + 1) * reduced_index_s] = s[
212
+ :reduced_index_s
213
+ ]
214
+ # select only the first reduced_index_s rows of v and place them
215
+ sum_v[i * reduced_index_s : (i + 1) * reduced_index_s, :] = v[
216
+ :reduced_index_s, :
217
+ ]
218
+ u_u, s_u, v_u = torch.linalg.svd(sum_u, full_matrices=False)
219
+ layer_proj = torch.matmul(
220
+ u_u[:, : int(s.shape[0] / self.config.subspace)],
221
+ u_u[:, : int(s.shape[0] / self.config.subspace)].T,
222
+ )
223
+ self.projection[layer_name] = layer_proj
224
+
225
+ self.optimize_delta(task_vectors)
226
+
227
+ del self.projection
228
+ self.delta = {key: param.detach().cpu() for key, param in self.delta.items()}
229
+ self.lamdas = [
230
+ {key: param.cpu() for key, param in lamdas.items()}
231
+ for lamdas in self.lamdas
232
+ ]
233
+ task_vectors = [
234
+ {k: v.cpu() for k, v in task_vector.items()} for task_vector in task_vectors
235
+ ]
236
+ flat_vectors = []
237
+ vector_masks = []
238
+ for idx, task_vector in enumerate(task_vectors):
239
+ flat_vector = self.state_dict_to_vector(task_vector)
240
+ vector_mask = self.topk_values_mask(flat_vector, K=self.config.K)
241
+ flat_vectors.append(flat_vector)
242
+ vector_masks.append(vector_mask)
243
+ flat_delta = self.state_dict_to_vector(self.delta)
244
+
245
+ adjusted_vectors = [
246
+ self.vector_to_state_dict(
247
+ (flat_vector + flat_delta) * vector_mask, self.delta
248
+ )
249
+ for flat_vector, vector_mask in zip(flat_vectors, vector_masks)
250
+ ]
251
+
252
+ for layer_name in adjusted_vectors[0].keys():
253
+ layer_vectors = torch.stack(
254
+ [vec[layer_name] for vec in adjusted_vectors], dim=0
255
+ )
256
+ layer_lamdas = torch.stack(
257
+ [lamdas[layer_name] for lamdas in self.lamdas], dim=0
258
+ )
259
+ layer_vectors_scale = layer_vectors * layer_lamdas.view(-1, 1, 1)
260
+ task_vectors[0][layer_name] = layer_vectors_scale.sum(dim=0)
261
+
262
+ final_state_dict = {}
263
+ pretrained_sd = pretrained_model.state_dict(keep_vars=True)
264
+ for k, v in pretrained_sd.items():
265
+ if k in task_vectors[0]:
266
+ final_state_dict[k] = v + task_vectors[0][k]
267
+ else:
268
+ final_state_dict[k] = v
269
+
270
+ pretrained_model.load_state_dict(final_state_dict)
271
+
272
+ self.print_profile_summary()
273
+ return pretrained_model
274
+
275
+ def compute_lamdas(self, vectors: List[StateDictType]) -> torch.Tensor:
276
+ lamdas = []
277
+ for vec in vectors:
278
+ norm_vec = torch.norm(
279
+ torch.cat([param.flatten() for param in vec.values()])
280
+ )
281
+ # norm_vec = sum([torch.norm(param) for param in vec.values()])
282
+ lamdas.append(self.config.lamda / norm_vec)
283
+ print(lamdas)
284
+ return lamdas
285
+
286
+ def compute_layer_lamdas(self, vectors: List[StateDictType]) -> torch.Tensor:
287
+ lamdas = []
288
+ for vec in vectors:
289
+ tmp = {}
290
+ for layer_name in vec.keys():
291
+ norm_vec = torch.norm(vec[layer_name])
292
+ tmp[layer_name] = self.config.lamda / norm_vec
293
+ lamdas.append(tmp)
294
+ return lamdas
295
+
296
+ def topk_values_mask(self, M, K):
297
+ if K > 1:
298
+ K /= 100
299
+
300
+ original_shape = M.shape
301
+ if M.dim() == 1:
302
+ M = M.unsqueeze(0)
303
+
304
+ n, d = M.shape
305
+ k = int(d * K)
306
+ k = d - k # Keep top k elements instead of bottom k elements
307
+
308
+ # Find the k-th smallest element by magnitude for each row
309
+ kth_values, _ = M.abs().kthvalue(k, dim=1, keepdim=True)
310
+ # Create a mask tensor with True for the top k elements in each row
311
+ mask = M.abs() >= kth_values
312
+ final_mask = mask.squeeze() if original_shape == M.squeeze().shape else mask
313
+
314
+ return final_mask
315
+
316
+ def state_dict_to_vector(self, state_dict, remove_keys=[]):
317
+ """
318
+ Convert a state dictionary to a vector, removing specified keys.
319
+
320
+ Args:
321
+ state_dict (dict): The state dictionary to convert.
322
+ remove_keys (list): List of keys to remove from the state dictionary.
323
+
324
+ Returns:
325
+ Tensor: A vector representation of the state dictionary.
326
+ """
327
+ shared_state_dict = copy.deepcopy(state_dict)
328
+ for key in remove_keys:
329
+ if key in shared_state_dict:
330
+ del shared_state_dict[key]
331
+ sorted_shared_state_dict = OrderedDict(sorted(shared_state_dict.items()))
332
+ return nn.utils.parameters_to_vector(
333
+ [value.reshape(-1) for key, value in sorted_shared_state_dict.items()]
334
+ )
335
+
336
+ def vector_to_state_dict(self, vector, state_dict, remove_keys=[]):
337
+ """
338
+ Convert a vector back to a state dictionary, removing specified keys.
339
+
340
+ Args:
341
+ vector (Tensor): The vector to convert.
342
+ state_dict (dict): The reference state dictionary.
343
+ remove_keys (list): List of keys to remove from the state dictionary.
344
+
345
+ Returns:
346
+ dict: A state dictionary representation of the vector.
347
+ """
348
+ # create a reference dict to define the order of the vector
349
+ reference_dict = copy.deepcopy(state_dict)
350
+ for key in remove_keys:
351
+ if key in reference_dict:
352
+ del reference_dict[key]
353
+ sorted_reference_dict = OrderedDict(sorted(reference_dict.items()))
354
+
355
+ # create a shared state dict using the reference dict
356
+ nn.utils.vector_to_parameters(vector, sorted_reference_dict.values())
357
+
358
+ # add back the encoder and decoder embedding weights.
359
+ if "transformer.shared.weight" in sorted_reference_dict:
360
+ for key in remove_keys:
361
+ sorted_reference_dict[key] = sorted_reference_dict[
362
+ "transformer.shared.weight"
363
+ ]
364
+ return sorted_reference_dict
@@ -0,0 +1,2 @@
1
+ # flake8: noqa F401
2
+ from .DOGE_TA import DOGE_TA_Algorithm
@@ -0,0 +1,250 @@
1
+ import logging
2
+ import os
3
+ from abc import abstractmethod
4
+ from typing import TYPE_CHECKING, Any, List, Mapping, TypeVar, Union, cast # noqa: F401
5
+
6
+ import torch
7
+ from lightning.fabric.utilities.rank_zero import rank_zero_only
8
+ from omegaconf import DictConfig
9
+ from torch import Tensor, nn
10
+ from torch.utils.data import DataLoader
11
+ from tqdm.autonotebook import tqdm
12
+
13
+ from fusion_bench.compat.method import ModelFusionAlgorithm
14
+ from fusion_bench.compat.modelpool import ModelPool
15
+ from fusion_bench.method.adamerging.entropy_loss import entropy_loss
16
+ from fusion_bench.method.adamerging.utils import get_memory_usage
17
+ from fusion_bench.mixins.lightning_fabric import LightningFabricMixin
18
+ from fusion_bench.mixins.simple_profiler import SimpleProfilerMixin
19
+ from fusion_bench.models.wrappers.layer_wise_fusion_doge_ta import (
20
+ LayerWiseMergedModel,
21
+ get_layer_wise_weights,
22
+ )
23
+ from fusion_bench.utils.data import load_tensor_from_file
24
+ from fusion_bench.utils.type import TorchModelType
25
+
26
+ if TYPE_CHECKING:
27
+ from fusion_bench.programs.fabric_fusion_program import FabricModelFusionProgram
28
+
29
+ log = logging.getLogger(__name__)
30
+
31
+
32
+ class LayerWiseAdaMergingAlgorithm(
33
+ ModelFusionAlgorithm,
34
+ LightningFabricMixin,
35
+ SimpleProfilerMixin,
36
+ ):
37
+ _program: "FabricModelFusionProgram"
38
+ """The program that this algorithm is running on."""
39
+
40
+ """
41
+ Implements the Layer-Wise AdaMerging Algorithm.
42
+
43
+ This class merges the layers of a pretrained model with those of several fine-tuned models.
44
+ The merging is controlled by layer-wise weights, which can be initialized based on a provided configuration or loaded from a file.
45
+ """
46
+
47
+ def __init__(self, algorithm_config: DictConfig):
48
+ """
49
+ Initialize the LayerWiseAdaMergingAlgorithm with the given configuration.
50
+
51
+ Args:
52
+ algorithm_config (DictConfig): The configuration for the algorithm.
53
+ """
54
+ super().__init__(algorithm_config)
55
+
56
+ def construct_layer_wise_merged_model(self, modelpool: "ModelPool"):
57
+ """
58
+ Constructs a wrapped layer-wise merged model from model pool.
59
+
60
+ This method creates a new wrapped model by merging the layers of a pretrained model with those of several fine-tuned models.
61
+ The merging is controlled by layer-wise weights, which is a `torch.Tensor` of the shape `(num_models, num_layers)`.
62
+ The merging weights can be initialized based on a provided configuration or loaded from a file.
63
+
64
+ Args:
65
+ modelpool (ModelPool): An object containing the pretrained model and fine-tuned models to be merged.
66
+
67
+ Returns:
68
+ LayerWiseMergedModel: An instance of the merged model with layer-wise weights applied.
69
+ """
70
+ pretrained_model = modelpool.load_model("_pretrained_")
71
+ finetuned_models = [
72
+ modelpool.load_model(name) for name in modelpool.model_names
73
+ ]
74
+
75
+ # initialize layer-wise weights using the provided configuration `init_values` or load from file if `weights` is provided
76
+ if self.config.weights is None:
77
+ layer_wise_weight = get_layer_wise_weights(
78
+ num_models=len(modelpool.model_names),
79
+ num_layers=len(
80
+ tuple(
81
+ filter(lambda p: p.requires_grad, pretrained_model.parameters())
82
+ )
83
+ ),
84
+ init_values=self.config.init_values,
85
+ )
86
+ else:
87
+ if isinstance(self.config.weights, str):
88
+ # self.config.weights is a path to a saved tensor
89
+ layer_wise_weight = load_tensor_from_file(self.config.weights)
90
+ else:
91
+ raise ValueError(f"Unsupported weights format: {self.config.weights}")
92
+
93
+ module = LayerWiseMergedModel(
94
+ layer_wise_weight=layer_wise_weight,
95
+ pretrained_model=pretrained_model,
96
+ finetuned_models=finetuned_models,
97
+ clamp_weights=self.config.clamp_weights,
98
+ tie_weights=self.config.tie_weights,
99
+ strict=self.config.strict,
100
+ )
101
+ print(f"{layer_wise_weight.size()=}, {layer_wise_weight.numel()=}")
102
+ return module
103
+
104
+ @rank_zero_only
105
+ def save_merging_weights(self, file_path: str, merging_weights: torch.Tensor):
106
+ """
107
+ Save the merging weights to a file.
108
+
109
+ Args:
110
+ file_path (str): The path to save the merging weights.
111
+ merging_weights (torch.Tensor): The merging weights to save.
112
+ """
113
+ if self.fabric.is_global_zero and self.config.get(
114
+ "save_merging_weights", False
115
+ ):
116
+ if isinstance(file_path, str) and not file_path.startswith(("/", ".")):
117
+ # if the file path is not absolute or relative to current working directory, save it in the log directory
118
+ save_path = os.path.join(self.log_dir, file_path)
119
+ else:
120
+ save_path = file_path
121
+ log.info(f"saving merging weights to {save_path}.")
122
+ if os.path.dirname(save_path):
123
+ os.makedirs(os.path.dirname(save_path), exist_ok=True)
124
+ torch.save(merging_weights.detach().cpu(), save_path)
125
+
126
+ def run(self, modelpool: ModelPool, **kwargs):
127
+ """
128
+ Run the Layer-Wise AdaMerging Algorithm.
129
+
130
+ This method constructs the wrapped model and performs test-time adaptation if necessary.
131
+
132
+ Args:
133
+ modelpool (ModelPool): The model pool containing the pretrained and fine-tuned models.
134
+
135
+ Returns:
136
+ LayerWiseMergedModel: The merged model after test-time adaptation.
137
+ """
138
+ log.info("Fusing models using layer-wise adaptive merging.")
139
+ self.modelpool = modelpool
140
+ self.log_hyperparams(self.config)
141
+
142
+ with self.profile("construct the wrapped model"):
143
+ module = self.construct_layer_wise_merged_model(modelpool)
144
+
145
+ if self.config.weights is not None:
146
+ # skip the test-time adaptation
147
+ return module.merge_and_unload()
148
+ else:
149
+ with self.profile("test-time adaptation"):
150
+ module = self.test_time_adaptation(module)
151
+ if self.config.get("save_merging_weights", False):
152
+ self.save_merging_weights(
153
+ self.config.save_merging_weights, module.merge_weight
154
+ )
155
+ return module.merge_and_unload()
156
+
157
+ def on_test_time_adaptation_start(self):
158
+ """
159
+ Something to do before the test-time adaptation starts. Such as setting up the task-specific heads.
160
+ """
161
+ pass
162
+
163
+ @abstractmethod
164
+ def get_shuffled_test_loader_iter(self, task: str) -> DataLoader:
165
+ """
166
+ Loader of test dataset for test-time adaptation. labels are not needed.
167
+
168
+ Args:
169
+ task (str): The name of the task.
170
+
171
+ Returns:
172
+ DataLoader: The data loader for the test dataset.
173
+ """
174
+ pass
175
+
176
+ @abstractmethod
177
+ def compute_logits(self, module, images: Tensor, task: str) -> Tensor:
178
+ """
179
+ Compute the logits for the given images and task.
180
+
181
+ Args:
182
+ module: The model module.
183
+ images (Tensor): The input images.
184
+ task (str): The name of the task.
185
+
186
+ Returns:
187
+ Tensor: The computed logits.
188
+ """
189
+ pass
190
+
191
+ def test_time_adaptation(self, module: "LayerWiseMergedModel[TorchModelType]"):
192
+ """
193
+ Perform test-time adaptation on the merged model.
194
+
195
+ This method adapts the merging weights during test-time to improve performance.
196
+
197
+ Args:
198
+ module (LayerWiseMergedModel): The merged model.
199
+
200
+ Returns:
201
+ LayerWiseMergedModel: The adapted merged model.
202
+ """
203
+ self.on_test_time_adaptation_start()
204
+
205
+ # configure optimizer
206
+ if self.config.optimizer == "adam":
207
+ optimizer = torch.optim.Adam([module.merge_weight], lr=self.config.lr)
208
+ print(f"{optimizer=}")
209
+ module, optimizer = self.fabric.setup(module, optimizer)
210
+ else:
211
+ raise ValueError(f"Unsupported optimizer: {self.config.optimizer}")
212
+
213
+ module.train()
214
+ module.merge_weights()
215
+ for step_idx in (
216
+ pbar := tqdm(
217
+ range(self.config.max_steps if not self.is_debug_mode else 1),
218
+ ("[DEBUG MODE] " if self.is_debug_mode else "")
219
+ + "AdaMerging Test-time adaptation",
220
+ dynamic_ncols=True,
221
+ )
222
+ ):
223
+ # default behavior for first-order optimizers
224
+ for task in self.modelpool.model_names:
225
+ with self.profile("data loading"):
226
+ batch = next(self.get_shuffled_test_loader_iter(task))
227
+ with self.profile("forward pass"):
228
+ logits = self.compute_logits(module, batch[0], task)
229
+ loss = entropy_loss(logits)
230
+ with self.profile("backward pass"):
231
+ self.fabric.backward(loss, retain_graph=True)
232
+
233
+ with self.profile("optimizer step"):
234
+ optimizer.step()
235
+ optimizer.zero_grad()
236
+ with self.profile("merging weights"):
237
+ module.merge_weights()
238
+
239
+ metrics = {
240
+ "train/loss": loss.item(),
241
+ "train/weight_max": module.merge_weight.max().item(),
242
+ "train/weight_min": module.merge_weight.min().item(),
243
+ "train/weight_mean": module.merge_weight.mean().item(),
244
+ }
245
+ self.fabric.log_dict(metrics, step=step_idx)
246
+ pbar.set_postfix(metrics)
247
+
248
+ log.info(get_memory_usage(f"after adamerging, the memory usage of GPU is:"))
249
+ self.print_profile_summary()
250
+ return module
@@ -53,6 +53,7 @@ _import_structure = {
53
53
  "PWEMoExactParetoOptimalForCLIP",
54
54
  ],
55
55
  "ada_svd": ["AdaSVDMergingForCLIPVisionModel"],
56
+ "DOGE_TA": ["DOGE_TA_Algorithm"],
56
57
  "task_singular_vector": ["TaskSingularVectorMerging"],
57
58
  "isotropic_merging": [
58
59
  "ISO_C_Merge", # alias
@@ -66,6 +67,10 @@ _import_structure = {
66
67
  "ConcreteTaskArithmeticAlgorithmForCLIP",
67
68
  "ConcreteTaskWiseAdaMergingForCLIP",
68
69
  "ConcreteLayerWiseAdaMergingForCLIP",
70
+ "ConcreteSafeLayerWiseAdaMergingForCLIP",
71
+ "ConcreteSafeTaskWiseAdaMergingForCLIP",
72
+ "PostDefenseAWMAlgorithmForCLIP",
73
+ "PostDefenseSAUAlgorithmForCLIP",
69
74
  ],
70
75
  # model mixing methods
71
76
  "depth_upscaling": ["DepthUpscalingAlgorithm", "DepthUpscalingForLlama"],
@@ -113,12 +118,17 @@ if TYPE_CHECKING:
113
118
  )
114
119
  from .concrete_subspace import (
115
120
  ConcreteLayerWiseAdaMergingForCLIP,
121
+ ConcreteSafeLayerWiseAdaMergingForCLIP,
122
+ ConcreteSafeTaskWiseAdaMergingForCLIP,
116
123
  ConcreteTaskArithmeticAlgorithmForCLIP,
117
124
  ConcreteTaskWiseAdaMergingForCLIP,
125
+ PostDefenseAWMAlgorithmForCLIP,
126
+ PostDefenseSAUAlgorithmForCLIP,
118
127
  )
119
128
  from .dare import DareSimpleAverage, DareTaskArithmetic, DareTiesMerging
120
129
  from .dawe import DataAdaptiveWeightEnsemblingForCLIP
121
130
  from .depth_upscaling import DepthUpscalingAlgorithm, DepthUpscalingForLlama
131
+ from .DOGE_TA import DOGE_TA_Algorithm
122
132
  from .dummy import DummyAlgorithm
123
133
  from .ensemble import (
124
134
  MaxModelPredictorAlgorithm,