mirror of
				https://github.com/huggingface/transformers.git
				synced 2025-10-25 12:44:35 +08:00 
			
		
		
		
	Compare commits
	
		
			1 Commits
		
	
	
		
			trigger-re
			...
			circleci_d
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| a5ae82d1cf | 
| @ -7,18 +7,6 @@ parameters: | |||||||
|     nightly: |     nightly: | ||||||
|         type: boolean |         type: boolean | ||||||
|         default: false |         default: false | ||||||
|     GHA_Actor: |  | ||||||
|         type: string |  | ||||||
|         default: "" |  | ||||||
|     GHA_Action: |  | ||||||
|         type: string |  | ||||||
|         default: "" |  | ||||||
|     GHA_Event: |  | ||||||
|         type: string |  | ||||||
|         default: "" |  | ||||||
|     GHA_Meta: |  | ||||||
|         type: string |  | ||||||
|         default: "" |  | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|     # Ensure running with CircleCI/huggingface |     # Ensure running with CircleCI/huggingface | ||||||
| @ -70,7 +58,7 @@ jobs: | |||||||
|             - run: |             - run: | ||||||
|                 name: "Prepare pipeline parameters" |                 name: "Prepare pipeline parameters" | ||||||
|                 command: | |                 command: | | ||||||
|                     python utils/process_test_artifacts.py |                     python utils/process_test_artifacts.py  | ||||||
|  |  | ||||||
|             # To avoid too long generated_config.yaml on the continuation orb, we pass the links to the artifacts as parameters. |             # To avoid too long generated_config.yaml on the continuation orb, we pass the links to the artifacts as parameters. | ||||||
|             # Otherwise the list of tests was just too big. Explicit is good but for that it was a limitation. |             # Otherwise the list of tests was just too big. Explicit is good but for that it was a limitation. | ||||||
| @ -112,6 +100,8 @@ jobs: | |||||||
|  |  | ||||||
|             - run: |             - run: | ||||||
|                 name: "Retrieve Artifact Paths" |                 name: "Retrieve Artifact Paths" | ||||||
|  |                 env: | ||||||
|  |                     CIRCLE_TOKEN: ${{ secrets.CI_ARTIFACT_TOKEN }} | ||||||
|                 command: | |                 command: | | ||||||
|                     project_slug="gh/${CIRCLE_PROJECT_USERNAME}/${CIRCLE_PROJECT_REPONAME}" |                     project_slug="gh/${CIRCLE_PROJECT_USERNAME}/${CIRCLE_PROJECT_REPONAME}" | ||||||
|                     job_number=${CIRCLE_BUILD_NUM} |                     job_number=${CIRCLE_BUILD_NUM} | ||||||
| @ -120,7 +110,7 @@ jobs: | |||||||
|             - run: |             - run: | ||||||
|                 name: "Prepare pipeline parameters" |                 name: "Prepare pipeline parameters" | ||||||
|                 command: | |                 command: | | ||||||
|                     python utils/process_test_artifacts.py |                     python utils/process_test_artifacts.py  | ||||||
|  |  | ||||||
|             # To avoid too long generated_config.yaml on the continuation orb, we pass the links to the artifacts as parameters. |             # To avoid too long generated_config.yaml on the continuation orb, we pass the links to the artifacts as parameters. | ||||||
|             # Otherwise the list of tests was just too big. Explicit is good but for that it was a limitation. |             # Otherwise the list of tests was just too big. Explicit is good but for that it was a limitation. | ||||||
| @ -156,7 +146,7 @@ jobs: | |||||||
|                   path: ~/transformers/installed.txt |                   path: ~/transformers/installed.txt | ||||||
|             - run: python -c "from transformers import *" || (echo '🚨 import failed, this means you introduced unprotected imports! 🚨'; exit 1) |             - run: python -c "from transformers import *" || (echo '🚨 import failed, this means you introduced unprotected imports! 🚨'; exit 1) | ||||||
|             - run: ruff check examples tests src utils |             - run: ruff check examples tests src utils | ||||||
|             - run: ruff format examples tests src utils --check |             - run: ruff format tests src utils --check | ||||||
|             - run: python utils/custom_init_isort.py --check_only |             - run: python utils/custom_init_isort.py --check_only | ||||||
|             - run: python utils/sort_auto_mappings.py --check_only |             - run: python utils/sort_auto_mappings.py --check_only | ||||||
|             - run: python utils/check_doc_toc.py |             - run: python utils/check_doc_toc.py | ||||||
| @ -181,16 +171,17 @@ jobs: | |||||||
|                   path: ~/transformers/installed.txt |                   path: ~/transformers/installed.txt | ||||||
|             - run: python utils/check_copies.py |             - run: python utils/check_copies.py | ||||||
|             - run: python utils/check_modular_conversion.py |             - run: python utils/check_modular_conversion.py | ||||||
|  |             - run: python utils/check_table.py | ||||||
|             - run: python utils/check_dummies.py |             - run: python utils/check_dummies.py | ||||||
|             - run: python utils/check_repo.py |             - run: python utils/check_repo.py | ||||||
|             - run: python utils/check_inits.py |             - run: python utils/check_inits.py | ||||||
|             - run: python utils/check_pipeline_typing.py |  | ||||||
|             - run: python utils/check_config_docstrings.py |             - run: python utils/check_config_docstrings.py | ||||||
|             - run: python utils/check_config_attributes.py |             - run: python utils/check_config_attributes.py | ||||||
|             - run: python utils/check_doctest_list.py |             - run: python utils/check_doctest_list.py | ||||||
|             - run: make deps_table_check_updated |             - run: make deps_table_check_updated | ||||||
|             - run: python utils/update_metadata.py --check-only |             - run: python utils/update_metadata.py --check-only | ||||||
|             - run: python utils/check_docstrings.py |             - run: python utils/check_docstrings.py | ||||||
|  |             - run: python utils/check_support_list.py | ||||||
|  |  | ||||||
| workflows: | workflows: | ||||||
|     version: 2 |     version: 2 | ||||||
| @ -200,9 +191,6 @@ workflows: | |||||||
|                 - equal: [<<pipeline.project.git_url>>, https://github.com/huggingface/transformers] |                 - equal: [<<pipeline.project.git_url>>, https://github.com/huggingface/transformers] | ||||||
|                 - not: <<pipeline.parameters.nightly>> |                 - not: <<pipeline.parameters.nightly>> | ||||||
|         jobs: |         jobs: | ||||||
|             - check_circleci_user |  | ||||||
|             - check_code_quality |  | ||||||
|             - check_repository_consistency |  | ||||||
|             - fetch_tests |             - fetch_tests | ||||||
|  |  | ||||||
|     setup_and_quality_2: |     setup_and_quality_2: | ||||||
|  | |||||||
| @ -28,32 +28,13 @@ COMMON_ENV_VARIABLES = { | |||||||
|     "TRANSFORMERS_IS_CI": True, |     "TRANSFORMERS_IS_CI": True, | ||||||
|     "PYTEST_TIMEOUT": 120, |     "PYTEST_TIMEOUT": 120, | ||||||
|     "RUN_PIPELINE_TESTS": False, |     "RUN_PIPELINE_TESTS": False, | ||||||
|     # will be adjust in `CircleCIJob.to_dict`. |     "RUN_PT_TF_CROSS_TESTS": False, | ||||||
|     "RUN_FLAKY": True, |     "RUN_PT_FLAX_CROSS_TESTS": False, | ||||||
| } | } | ||||||
| # Disable the use of {"s": None} as the output is way too long, causing the navigation on CircleCI impractical | # Disable the use of {"s": None} as the output is way too long, causing the navigation on CircleCI impractical | ||||||
| COMMON_PYTEST_OPTIONS = {"max-worker-restart": 0, "vvv": None, "rsfE":None} | COMMON_PYTEST_OPTIONS = {"max-worker-restart": 0, "dist": "loadfile", "vvv": None, "rsfE":None} | ||||||
| DEFAULT_DOCKER_IMAGE = [{"image": "cimg/python:3.8.12"}] | DEFAULT_DOCKER_IMAGE = [{"image": "cimg/python:3.8.12"}] | ||||||
|  |  | ||||||
| # Strings that commonly appear in the output of flaky tests when they fail. These are used with `pytest-rerunfailures` |  | ||||||
| # to rerun the tests that match these patterns. |  | ||||||
| FLAKY_TEST_FAILURE_PATTERNS = [ |  | ||||||
|     "OSError",  # Machine/connection transient error |  | ||||||
|     "Timeout",  # Machine/connection transient error |  | ||||||
|     "ConnectionError",  # Connection transient error |  | ||||||
|     "FileNotFoundError",  # Raised by `datasets` on Hub failures |  | ||||||
|     "PIL.UnidentifiedImageError",  # Raised by `PIL.Image.open` on connection issues |  | ||||||
|     "HTTPError",  # Also catches HfHubHTTPError |  | ||||||
|     "AssertionError: Tensor-likes are not close!",  # `torch.testing.assert_close`, we might have unlucky random values |  | ||||||
|     # TODO: error downloading tokenizer's `merged.txt` from hub can cause all the exceptions below. Throw and handle |  | ||||||
|     # them under a single message. |  | ||||||
|     "TypeError: expected str, bytes or os.PathLike object, not NoneType", |  | ||||||
|     "TypeError: stat: path should be string, bytes, os.PathLike or integer, not NoneType", |  | ||||||
|     "Converting from Tiktoken failed", |  | ||||||
|     "KeyError: <class ", |  | ||||||
|     "TypeError: not a string", |  | ||||||
| ] |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class EmptyJob: | class EmptyJob: | ||||||
|     job_name = "empty" |     job_name = "empty" | ||||||
| @ -128,8 +109,6 @@ class CircleCIJob: | |||||||
|  |  | ||||||
|     def to_dict(self): |     def to_dict(self): | ||||||
|         env = COMMON_ENV_VARIABLES.copy() |         env = COMMON_ENV_VARIABLES.copy() | ||||||
|         # Do not run tests decorated by @is_flaky on pull requests |  | ||||||
|         env['RUN_FLAKY'] = os.environ.get("CIRCLE_PULL_REQUEST", "") == "" |  | ||||||
|         env.update(self.additional_env) |         env.update(self.additional_env) | ||||||
|  |  | ||||||
|         job = { |         job = { | ||||||
| @ -147,9 +126,7 @@ class CircleCIJob: | |||||||
|                 # Examples special case: we need to download NLTK files in advance to avoid cuncurrency issues |                 # Examples special case: we need to download NLTK files in advance to avoid cuncurrency issues | ||||||
|         timeout_cmd = f"timeout {self.command_timeout} " if self.command_timeout else "" |         timeout_cmd = f"timeout {self.command_timeout} " if self.command_timeout else "" | ||||||
|         marker_cmd = f"-m '{self.marker}'" if self.marker is not None else "" |         marker_cmd = f"-m '{self.marker}'" if self.marker is not None else "" | ||||||
|         junit_flags = f" -p no:warning -o junit_family=xunit1 --junitxml=test-results/junit.xml" |         additional_flags = f" -p no:warning -o junit_family=xunit1 --junitxml=test-results/junit.xml" | ||||||
|         joined_flaky_patterns = "|".join(FLAKY_TEST_FAILURE_PATTERNS) |  | ||||||
|         repeat_on_failure_flags = f"--reruns 5 --reruns-delay 2 --only-rerun '({joined_flaky_patterns})'" |  | ||||||
|         parallel = f' << pipeline.parameters.{self.job_name}_parallelism >> ' |         parallel = f' << pipeline.parameters.{self.job_name}_parallelism >> ' | ||||||
|         steps = [ |         steps = [ | ||||||
|             "checkout", |             "checkout", | ||||||
| @ -175,10 +152,9 @@ class CircleCIJob: | |||||||
|                     "command": f"TESTS=$(circleci tests split  --split-by=timings {self.job_name}_test_list.txt) && echo $TESTS > splitted_tests.txt && echo $TESTS | tr ' ' '\n'" if self.parallelism else f"awk '{{printf \"%s \", $0}}' {self.job_name}_test_list.txt > splitted_tests.txt" |                     "command": f"TESTS=$(circleci tests split  --split-by=timings {self.job_name}_test_list.txt) && echo $TESTS > splitted_tests.txt && echo $TESTS | tr ' ' '\n'" if self.parallelism else f"awk '{{printf \"%s \", $0}}' {self.job_name}_test_list.txt > splitted_tests.txt" | ||||||
|                     } |                     } | ||||||
|             }, |             }, | ||||||
|             {"run": {"name": "fetch hub objects before pytest", "command": "python3 utils/fetch_hub_objects_for_ci.py"}}, |  | ||||||
|             {"run": { |             {"run": { | ||||||
|                 "name": "Run tests", |                 "name": "Run tests", | ||||||
|                 "command": f"({timeout_cmd} python3 -m pytest {marker_cmd} -n {self.pytest_num_workers} {junit_flags} {repeat_on_failure_flags} {' '.join(pytest_flags)} $(cat splitted_tests.txt) | tee tests_output.txt)"} |                 "command": f"({timeout_cmd} python3 -m pytest {marker_cmd} -n 1 {additional_flags} {' '.join(pytest_flags)} tests/models/flaubert/test_modeling_flaubert.py::FlaubertModelTest::test_batching_equivalence | tee tests_output.txt)"} | ||||||
|             }, |             }, | ||||||
|             {"run": {"name": "Expand to show skipped tests", "when": "always", "command": f"python3 .circleci/parse_test_outputs.py --file tests_output.txt --skip"}}, |             {"run": {"name": "Expand to show skipped tests", "when": "always", "command": f"python3 .circleci/parse_test_outputs.py --file tests_output.txt --skip"}}, | ||||||
|             {"run": {"name": "Failed tests: show reasons",   "when": "always", "command": f"python3 .circleci/parse_test_outputs.py --file tests_output.txt --fail"}}, |             {"run": {"name": "Failed tests: show reasons",   "when": "always", "command": f"python3 .circleci/parse_test_outputs.py --file tests_output.txt --fail"}}, | ||||||
| @ -201,19 +177,33 @@ class CircleCIJob: | |||||||
|  |  | ||||||
|  |  | ||||||
| # JOBS | # JOBS | ||||||
|  | torch_and_tf_job = CircleCIJob( | ||||||
|  |     "torch_and_tf", | ||||||
|  |     docker_image=[{"image":"huggingface/transformers-torch-tf-light"}], | ||||||
|  |     additional_env={"RUN_PT_TF_CROSS_TESTS": True}, | ||||||
|  |     marker="is_pt_tf_cross_test", | ||||||
|  |     pytest_options={"rA": None, "durations": 0}, | ||||||
|  | ) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | torch_and_flax_job = CircleCIJob( | ||||||
|  |     "torch_and_flax", | ||||||
|  |     additional_env={"RUN_PT_FLAX_CROSS_TESTS": True}, | ||||||
|  |     docker_image=[{"image":"huggingface/transformers-torch-jax-light"}], | ||||||
|  |     marker="is_pt_flax_cross_test", | ||||||
|  |     pytest_options={"rA": None, "durations": 0}, | ||||||
|  | ) | ||||||
|  |  | ||||||
| torch_job = CircleCIJob( | torch_job = CircleCIJob( | ||||||
|     "torch", |     "torch", | ||||||
|     docker_image=[{"image": "huggingface/transformers-torch-light"}], |     docker_image=[{"image": "huggingface/transformers-torch-light"}], | ||||||
|     marker="not generate", |     marker="not generate", | ||||||
|     parallelism=6, |     parallelism=1, | ||||||
| ) | ) | ||||||
|  |  | ||||||
| generate_job = CircleCIJob( | generate_job = CircleCIJob( | ||||||
|     "generate", |     "generate", | ||||||
|     docker_image=[{"image": "huggingface/transformers-torch-light"}], |     docker_image=[{"image": "huggingface/transformers-torch-light"}], | ||||||
|     # networkx==3.3 (after #36957) cause some issues |  | ||||||
|     # TODO: remove this once it works directly |  | ||||||
|     install_steps=["uv venv && uv pip install ."], |  | ||||||
|     marker="generate", |     marker="generate", | ||||||
|     parallelism=6, |     parallelism=6, | ||||||
| ) | ) | ||||||
| @ -230,6 +220,22 @@ processor_job = CircleCIJob( | |||||||
|     parallelism=8, |     parallelism=8, | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | tf_job = CircleCIJob( | ||||||
|  |     "tf", | ||||||
|  |     docker_image=[{"image":"huggingface/transformers-tf-light"}], | ||||||
|  |     parallelism=6, | ||||||
|  | ) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | flax_job = CircleCIJob( | ||||||
|  |     "flax", | ||||||
|  |     docker_image=[{"image":"huggingface/transformers-jax-light"}], | ||||||
|  |     parallelism=6, | ||||||
|  |     pytest_num_workers=16, | ||||||
|  |     resource_class="2xlarge", | ||||||
|  | ) | ||||||
|  |  | ||||||
|  |  | ||||||
| pipelines_torch_job = CircleCIJob( | pipelines_torch_job = CircleCIJob( | ||||||
|     "pipelines_torch", |     "pipelines_torch", | ||||||
|     additional_env={"RUN_PIPELINE_TESTS": True}, |     additional_env={"RUN_PIPELINE_TESTS": True}, | ||||||
| @ -238,6 +244,16 @@ pipelines_torch_job = CircleCIJob( | |||||||
|     parallelism=4, |     parallelism=4, | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | pipelines_tf_job = CircleCIJob( | ||||||
|  |     "pipelines_tf", | ||||||
|  |     additional_env={"RUN_PIPELINE_TESTS": True}, | ||||||
|  |     docker_image=[{"image":"huggingface/transformers-tf-light"}], | ||||||
|  |     marker="is_pipeline_test", | ||||||
|  |     parallelism=4, | ||||||
|  | ) | ||||||
|  |  | ||||||
|  |  | ||||||
| custom_tokenizers_job = CircleCIJob( | custom_tokenizers_job = CircleCIJob( | ||||||
|     "custom_tokenizers", |     "custom_tokenizers", | ||||||
|     additional_env={"RUN_CUSTOM_TOKENIZERS": True}, |     additional_env={"RUN_CUSTOM_TOKENIZERS": True}, | ||||||
| @ -251,9 +267,16 @@ examples_torch_job = CircleCIJob( | |||||||
|     docker_image=[{"image":"huggingface/transformers-examples-torch"}], |     docker_image=[{"image":"huggingface/transformers-examples-torch"}], | ||||||
|     # TODO @ArthurZucker remove this once docker is easier to build |     # TODO @ArthurZucker remove this once docker is easier to build | ||||||
|     install_steps=["uv venv && uv pip install . && uv pip install -r examples/pytorch/_tests_requirements.txt"], |     install_steps=["uv venv && uv pip install . && uv pip install -r examples/pytorch/_tests_requirements.txt"], | ||||||
|     pytest_num_workers=4, |  | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | examples_tensorflow_job = CircleCIJob( | ||||||
|  |     "examples_tensorflow", | ||||||
|  |     additional_env={"OMP_NUM_THREADS": 8}, | ||||||
|  |     docker_image=[{"image":"huggingface/transformers-examples-tf"}], | ||||||
|  | ) | ||||||
|  |  | ||||||
|  |  | ||||||
| hub_job = CircleCIJob( | hub_job = CircleCIJob( | ||||||
|     "hub", |     "hub", | ||||||
|     additional_env={"HUGGINGFACE_CO_STAGING": True}, |     additional_env={"HUGGINGFACE_CO_STAGING": True}, | ||||||
| @ -274,7 +297,7 @@ onnx_job = CircleCIJob( | |||||||
|     docker_image=[{"image":"huggingface/transformers-torch-tf-light"}], |     docker_image=[{"image":"huggingface/transformers-torch-tf-light"}], | ||||||
|     install_steps=[ |     install_steps=[ | ||||||
|         "uv venv", |         "uv venv", | ||||||
|         "uv pip install .[testing,sentencepiece,onnxruntime,vision,rjieba]", |         "uv pip install .[torch,tf,testing,sentencepiece,onnxruntime,vision,rjieba]", | ||||||
|     ], |     ], | ||||||
|     pytest_options={"k onnx": None}, |     pytest_options={"k onnx": None}, | ||||||
|     pytest_num_workers=1, |     pytest_num_workers=1, | ||||||
| @ -301,9 +324,6 @@ repo_utils_job = CircleCIJob( | |||||||
| non_model_job = CircleCIJob( | non_model_job = CircleCIJob( | ||||||
|     "non_model", |     "non_model", | ||||||
|     docker_image=[{"image": "huggingface/transformers-torch-light"}], |     docker_image=[{"image": "huggingface/transformers-torch-light"}], | ||||||
|     # networkx==3.3 (after #36957) cause some issues |  | ||||||
|     # TODO: remove this once it works directly |  | ||||||
|     install_steps=["uv venv && uv pip install ."], |  | ||||||
|     marker="not generate", |     marker="not generate", | ||||||
|     parallelism=6, |     parallelism=6, | ||||||
| ) | ) | ||||||
| @ -333,12 +353,13 @@ doc_test_job = CircleCIJob( | |||||||
|     pytest_num_workers=1, |     pytest_num_workers=1, | ||||||
| ) | ) | ||||||
|  |  | ||||||
| REGULAR_TESTS = [torch_job, hub_job, onnx_job, tokenization_job, processor_job, generate_job, non_model_job] # fmt: skip | REGULAR_TESTS = [torch_and_tf_job, torch_and_flax_job, torch_job, tf_job, flax_job, hub_job, onnx_job, tokenization_job, processor_job, generate_job, non_model_job] # fmt: skip | ||||||
| EXAMPLES_TESTS = [examples_torch_job] | EXAMPLES_TESTS = [examples_torch_job, examples_tensorflow_job] | ||||||
| PIPELINE_TESTS = [pipelines_torch_job] | PIPELINE_TESTS = [pipelines_torch_job, pipelines_tf_job] | ||||||
| REPO_UTIL_TESTS = [repo_utils_job] | REPO_UTIL_TESTS = [repo_utils_job] | ||||||
| DOC_TESTS = [doc_test_job] | DOC_TESTS = [doc_test_job] | ||||||
| ALL_TESTS = REGULAR_TESTS + EXAMPLES_TESTS + PIPELINE_TESTS + REPO_UTIL_TESTS + DOC_TESTS + [custom_tokenizers_job] + [exotic_models_job]  # fmt: skip | # ALL_TESTS = REGULAR_TESTS + EXAMPLES_TESTS + PIPELINE_TESTS + REPO_UTIL_TESTS + DOC_TESTS + [custom_tokenizers_job] + [exotic_models_job]  # fmt: skip | ||||||
|  | ALL_TESTS = [torch_job] | ||||||
|  |  | ||||||
|  |  | ||||||
| def create_circleci_config(folder=None): | def create_circleci_config(folder=None): | ||||||
| @ -362,12 +383,7 @@ def create_circleci_config(folder=None): | |||||||
|         "parameters": { |         "parameters": { | ||||||
|             # Only used to accept the parameters from the trigger |             # Only used to accept the parameters from the trigger | ||||||
|             "nightly": {"type": "boolean", "default": False}, |             "nightly": {"type": "boolean", "default": False}, | ||||||
|             # Only used to accept the parameters from GitHub Actions trigger |             "tests_to_run": {"type": "string", "default": ''}, | ||||||
|             "GHA_Actor": {"type": "string", "default": ""}, |  | ||||||
|             "GHA_Action": {"type": "string", "default": ""}, |  | ||||||
|             "GHA_Event": {"type": "string", "default": ""}, |  | ||||||
|             "GHA_Meta": {"type": "string", "default": ""}, |  | ||||||
|             "tests_to_run": {"type": "string", "default": ""}, |  | ||||||
|             **{j.job_name + "_test_list":{"type":"string", "default":''} for j in jobs}, |             **{j.job_name + "_test_list":{"type":"string", "default":''} for j in jobs}, | ||||||
|             **{j.job_name + "_parallelism":{"type":"integer", "default":1} for j in jobs}, |             **{j.job_name + "_parallelism":{"type":"integer", "default":1} for j in jobs}, | ||||||
|         }, |         }, | ||||||
|  | |||||||
							
								
								
									
										19
									
								
								.github/ISSUE_TEMPLATE/bug-report.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										19
									
								
								.github/ISSUE_TEMPLATE/bug-report.yml
									
									
									
									
										vendored
									
									
								
							| @ -16,7 +16,7 @@ body: | |||||||
|     id: system-info |     id: system-info | ||||||
|     attributes: |     attributes: | ||||||
|       label: System Info |       label: System Info | ||||||
|       description: Please share your system info with us. You can run the command `transformers env` and copy-paste its output below. |       description: Please share your system info with us. You can run the command `transformers-cli env` and copy-paste its output below. | ||||||
|       placeholder: transformers version, platform, python version, ... |       placeholder: transformers version, platform, python version, ... | ||||||
|     validations: |     validations: | ||||||
|       required: true |       required: true | ||||||
| @ -38,30 +38,24 @@ body: | |||||||
|  |  | ||||||
|           - text models: @ArthurZucker |           - text models: @ArthurZucker | ||||||
|           - vision models: @amyeroberts, @qubvel |           - vision models: @amyeroberts, @qubvel | ||||||
|           - speech models: @eustlb |           - speech models: @ylacombe, @eustlb | ||||||
|           - graph models: @clefourrier |           - graph models: @clefourrier | ||||||
|  |  | ||||||
|         Library: |         Library: | ||||||
|  |  | ||||||
|           - flax: @gante and @Rocketknight1 |           - flax: @sanchit-gandhi | ||||||
|           - generate: @zucchini-nlp (visual-language models) or @gante (all others) |           - generate: @zucchini-nlp (visual-language models) or @gante (all others) | ||||||
|           - pipelines: @Rocketknight1 |           - pipelines: @Rocketknight1 | ||||||
|           - tensorflow: @gante and @Rocketknight1 |           - tensorflow: @gante and @Rocketknight1 | ||||||
|           - tokenizers: @ArthurZucker and @itazap |           - tokenizers: @ArthurZucker and @itazap | ||||||
|           - trainer: @zach-huggingface @SunMarc |           - trainer: @muellerzr @SunMarc | ||||||
|  |  | ||||||
|         Integrations: |         Integrations: | ||||||
|  |  | ||||||
|           - deepspeed: HF Trainer/Accelerate: @SunMarc @zach-huggingface |           - deepspeed: HF Trainer/Accelerate: @muellerzr | ||||||
|           - ray/raytune: @richardliaw, @amogkam |           - ray/raytune: @richardliaw, @amogkam | ||||||
|           - Big Model Inference: @SunMarc |           - Big Model Inference: @SunMarc | ||||||
|           - quantization (bitsandbytes, autogpt): @SunMarc @MekkCyber |           - quantization (bitsandbytes, autogpt): @SunMarc @MekkCyber | ||||||
|          |  | ||||||
|         Devices/Backends: |  | ||||||
|          |  | ||||||
|           - AMD ROCm: @ivarflakstad |  | ||||||
|           - Intel XPU: @IlyasMoutawwakil |  | ||||||
|           - Ascend NPU: @ivarflakstad  |  | ||||||
|  |  | ||||||
|         Documentation: @stevhliu |         Documentation: @stevhliu | ||||||
|  |  | ||||||
| @ -78,7 +72,7 @@ body: | |||||||
|  |  | ||||||
|         Maintained examples (not research project or legacy): |         Maintained examples (not research project or legacy): | ||||||
|  |  | ||||||
|           - Flax: @Rocketknight1 |           - Flax: @sanchit-gandhi | ||||||
|           - PyTorch: See Models above and tag the person corresponding to the modality of the example. |           - PyTorch: See Models above and tag the person corresponding to the modality of the example. | ||||||
|           - TensorFlow: @Rocketknight1 |           - TensorFlow: @Rocketknight1 | ||||||
|  |  | ||||||
| @ -112,7 +106,6 @@ body: | |||||||
|       label: Reproduction |       label: Reproduction | ||||||
|       description: | |       description: | | ||||||
|         Please provide a code sample that reproduces the problem you ran into. It can be a Colab link or just a code snippet. |         Please provide a code sample that reproduces the problem you ran into. It can be a Colab link or just a code snippet. | ||||||
|         Please include relevant config information with your code, for example your Trainers, TRL, Peft, and DeepSpeed configs. |  | ||||||
|         If you have code snippets, error messages, stack traces please provide them here as well. |         If you have code snippets, error messages, stack traces please provide them here as well. | ||||||
|         Important! Use code tags to correctly format your code. See https://help.github.com/en/github/writing-on-github/creating-and-highlighting-code-blocks#syntax-highlighting |         Important! Use code tags to correctly format your code. See https://help.github.com/en/github/writing-on-github/creating-and-highlighting-code-blocks#syntax-highlighting | ||||||
|         Do not use screenshots, as they are hard to read and (more importantly) don't allow others to copy-and-paste your code. |         Do not use screenshots, as they are hard to read and (more importantly) don't allow others to copy-and-paste your code. | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/ISSUE_TEMPLATE/i18n.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/ISSUE_TEMPLATE/i18n.md
									
									
									
									
										vendored
									
									
								
							| @ -23,7 +23,7 @@ Some notes: | |||||||
| * Please translate in a gender-neutral way. | * Please translate in a gender-neutral way. | ||||||
| * Add your translations to the folder called `<languageCode>` inside the [source folder](https://github.com/huggingface/transformers/tree/main/docs/source). | * Add your translations to the folder called `<languageCode>` inside the [source folder](https://github.com/huggingface/transformers/tree/main/docs/source). | ||||||
| * Register your translation in `<languageCode>/_toctree.yml`; please follow the order of the [English version](https://github.com/huggingface/transformers/blob/main/docs/source/en/_toctree.yml). | * Register your translation in `<languageCode>/_toctree.yml`; please follow the order of the [English version](https://github.com/huggingface/transformers/blob/main/docs/source/en/_toctree.yml). | ||||||
| * Once you're finished, open a pull request and tag this issue by including #issue-number in the description, where issue-number is the number of this issue. Please ping @stevhliu for review. | * Once you're finished, open a pull request and tag this issue by including #issue-number in the description, where issue-number is the number of this issue. Please ping @stevhliu and @MKhalusova for review. | ||||||
| * 🙋 If you'd like others to help you with the translation, you can also post in the 🤗 [forums](https://discuss.huggingface.co/). | * 🙋 If you'd like others to help you with the translation, you can also post in the 🤗 [forums](https://discuss.huggingface.co/). | ||||||
|  |  | ||||||
| ## Get Started section | ## Get Started section | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/ISSUE_TEMPLATE/migration.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/ISSUE_TEMPLATE/migration.yml
									
									
									
									
										vendored
									
									
								
							| @ -6,7 +6,7 @@ body: | |||||||
|     id: system-info |     id: system-info | ||||||
|     attributes: |     attributes: | ||||||
|       label: System Info |       label: System Info | ||||||
|       description: Please share your system info with us. You can run the command `transformers env` and copy-paste its output below. |       description: Please share your system info with us. You can run the command `transformers-cli env` and copy-paste its output below. | ||||||
|       render: shell |       render: shell | ||||||
|       placeholder: transformers version, platform, python version, ... |       placeholder: transformers version, platform, python version, ... | ||||||
|     validations: |     validations: | ||||||
|  | |||||||
							
								
								
									
										10
									
								
								.github/PULL_REQUEST_TEMPLATE.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								.github/PULL_REQUEST_TEMPLATE.md
									
									
									
									
										vendored
									
									
								
							| @ -41,22 +41,22 @@ Models: | |||||||
|  |  | ||||||
| - text models: @ArthurZucker | - text models: @ArthurZucker | ||||||
| - vision models: @amyeroberts, @qubvel | - vision models: @amyeroberts, @qubvel | ||||||
| - speech models: @eustlb | - speech models: @ylacombe, @eustlb | ||||||
| - graph models: @clefourrier | - graph models: @clefourrier | ||||||
|  |  | ||||||
| Library: | Library: | ||||||
|  |  | ||||||
| - flax: @gante and @Rocketknight1 | - flax: @sanchit-gandhi | ||||||
| - generate: @zucchini-nlp (visual-language models) or @gante (all others) | - generate: @zucchini-nlp (visual-language models) or @gante (all others) | ||||||
| - pipelines: @Rocketknight1 | - pipelines: @Rocketknight1 | ||||||
| - tensorflow: @gante and @Rocketknight1 | - tensorflow: @gante and @Rocketknight1 | ||||||
| - tokenizers: @ArthurZucker | - tokenizers: @ArthurZucker | ||||||
| - trainer: @zach-huggingface, @SunMarc and @qgallouedec | - trainer: @muellerzr and @SunMarc | ||||||
| - chat templates: @Rocketknight1 | - chat templates: @Rocketknight1 | ||||||
|  |  | ||||||
| Integrations: | Integrations: | ||||||
|  |  | ||||||
| - deepspeed: HF Trainer/Accelerate: @SunMarc @zach-huggingface | - deepspeed: HF Trainer/Accelerate: @muellerzr | ||||||
| - ray/raytune: @richardliaw, @amogkam | - ray/raytune: @richardliaw, @amogkam | ||||||
| - Big Model Inference: @SunMarc | - Big Model Inference: @SunMarc | ||||||
| - quantization (bitsandbytes, autogpt): @SunMarc @MekkCyber | - quantization (bitsandbytes, autogpt): @SunMarc @MekkCyber | ||||||
| @ -72,7 +72,7 @@ HF projects: | |||||||
|  |  | ||||||
| Maintained examples (not research project or legacy): | Maintained examples (not research project or legacy): | ||||||
|  |  | ||||||
| - Flax: @Rocketknight1 | - Flax: @sanchit-gandhi | ||||||
| - PyTorch: See Models above and tag the person corresponding to the modality of the example. | - PyTorch: See Models above and tag the person corresponding to the modality of the example. | ||||||
| - TensorFlow: @Rocketknight1 | - TensorFlow: @Rocketknight1 | ||||||
|  |  | ||||||
|  | |||||||
							
								
								
									
										120
									
								
								.github/scripts/assign_reviewers.py
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										120
									
								
								.github/scripts/assign_reviewers.py
									
									
									
									
										vendored
									
									
								
							| @ -1,120 +0,0 @@ | |||||||
| # coding=utf-8 |  | ||||||
| # Copyright 2025 the HuggingFace Inc. team. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
|  |  | ||||||
| import os |  | ||||||
| import github |  | ||||||
| import json |  | ||||||
| from github import Github |  | ||||||
| import re |  | ||||||
| from collections import Counter |  | ||||||
| from pathlib import Path |  | ||||||
|  |  | ||||||
| def pattern_to_regex(pattern): |  | ||||||
|     if pattern.startswith("/"): |  | ||||||
|         start_anchor = True |  | ||||||
|         pattern = re.escape(pattern[1:]) |  | ||||||
|     else: |  | ||||||
|         start_anchor = False |  | ||||||
|         pattern = re.escape(pattern) |  | ||||||
|     # Replace `*` with "any number of non-slash characters" |  | ||||||
|     pattern = pattern.replace(r"\*", "[^/]*") |  | ||||||
|     if start_anchor: |  | ||||||
|         pattern = r"^\/?" + pattern  # Allow an optional leading slash after the start of the string |  | ||||||
|     return pattern |  | ||||||
|  |  | ||||||
| def get_file_owners(file_path, codeowners_lines): |  | ||||||
|     # Process lines in reverse (last matching pattern takes precedence) |  | ||||||
|     for line in reversed(codeowners_lines): |  | ||||||
|         # Skip comments and empty lines, strip inline comments |  | ||||||
|         line = line.split('#')[0].strip() |  | ||||||
|         if not line: |  | ||||||
|             continue |  | ||||||
|  |  | ||||||
|         # Split into pattern and owners |  | ||||||
|         parts = line.split() |  | ||||||
|         pattern = parts[0] |  | ||||||
|         # Can be empty, e.g. for dummy files with explicitly no owner! |  | ||||||
|         owners = [owner.removeprefix("@") for owner in parts[1:]] |  | ||||||
|  |  | ||||||
|         # Check if file matches pattern |  | ||||||
|         file_regex = pattern_to_regex(pattern) |  | ||||||
|         if re.search(file_regex, file_path) is not None: |  | ||||||
|             return owners  # Remember, can still be empty! |  | ||||||
|     return []  # Should never happen, but just in case |  | ||||||
|  |  | ||||||
| def pr_author_is_in_hf(pr_author, codeowners_lines): |  | ||||||
|     # Check if the PR author is in the codeowners file |  | ||||||
|     for line in codeowners_lines: |  | ||||||
|         line = line.split('#')[0].strip() |  | ||||||
|         if not line: |  | ||||||
|             continue |  | ||||||
|  |  | ||||||
|         # Split into pattern and owners |  | ||||||
|         parts = line.split() |  | ||||||
|         owners = [owner.removeprefix("@") for owner in parts[1:]] |  | ||||||
|  |  | ||||||
|         if pr_author in owners: |  | ||||||
|             return True |  | ||||||
|     return False |  | ||||||
|  |  | ||||||
| def main(): |  | ||||||
|     script_dir = Path(__file__).parent.absolute() |  | ||||||
|     with open(script_dir / "codeowners_for_review_action") as f: |  | ||||||
|         codeowners_lines = f.readlines() |  | ||||||
|  |  | ||||||
|     g = Github(os.environ['GITHUB_TOKEN']) |  | ||||||
|     repo = g.get_repo("huggingface/transformers") |  | ||||||
|     with open(os.environ['GITHUB_EVENT_PATH']) as f: |  | ||||||
|         event = json.load(f) |  | ||||||
|  |  | ||||||
|     # The PR number is available in the event payload |  | ||||||
|     pr_number = event['pull_request']['number'] |  | ||||||
|     pr = repo.get_pull(pr_number) |  | ||||||
|     pr_author = pr.user.login |  | ||||||
|     if pr_author_is_in_hf(pr_author, codeowners_lines): |  | ||||||
|         print(f"PR author {pr_author} is in codeowners, skipping review request.") |  | ||||||
|         return |  | ||||||
|  |  | ||||||
|     existing_reviews = list(pr.get_reviews()) |  | ||||||
|     if existing_reviews: |  | ||||||
|         print(f"Already has reviews: {[r.user.login for r in existing_reviews]}") |  | ||||||
|         return |  | ||||||
|  |  | ||||||
|     users_requested, teams_requested = pr.get_review_requests() |  | ||||||
|     users_requested = list(users_requested) |  | ||||||
|     if users_requested: |  | ||||||
|         print(f"Reviewers already requested: {users_requested}") |  | ||||||
|         return |  | ||||||
|  |  | ||||||
|     locs_per_owner = Counter() |  | ||||||
|     for file in pr.get_files(): |  | ||||||
|         owners = get_file_owners(file.filename, codeowners_lines) |  | ||||||
|         for owner in owners: |  | ||||||
|             locs_per_owner[owner] += file.changes |  | ||||||
|  |  | ||||||
|     # Assign the top 2 based on locs changed as reviewers, but skip the owner if present |  | ||||||
|     locs_per_owner.pop(pr_author, None) |  | ||||||
|     top_owners = locs_per_owner.most_common(2) |  | ||||||
|     print("Top owners", top_owners) |  | ||||||
|     top_owners = [owner[0] for owner in top_owners] |  | ||||||
|     try: |  | ||||||
|         pr.create_review_request(top_owners) |  | ||||||
|     except github.GithubException as e: |  | ||||||
|         print(f"Failed to request review for {top_owners}: {e}") |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| if __name__ == "__main__": |  | ||||||
|     main() |  | ||||||
							
								
								
									
										370
									
								
								.github/scripts/codeowners_for_review_action
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										370
									
								
								.github/scripts/codeowners_for_review_action
									
									
									
									
										vendored
									
									
								
							| @ -1,370 +0,0 @@ | |||||||
| # Top-level rules are matched only if nothing else matches |  | ||||||
| * @Rocketknight1 @ArthurZucker # if no one is pinged based on the other rules, he will do the dispatch |  | ||||||
| *.md @stevhliu |  | ||||||
| *tokenization* @ArthurZucker |  | ||||||
| docs/ @stevhliu |  | ||||||
| /benchmark/ @McPatate |  | ||||||
| /docker/ @ydshieh @ArthurZucker |  | ||||||
|  |  | ||||||
| # More high-level globs catch cases when specific rules later don't apply |  | ||||||
| /src/transformers/models/*/processing* @molbap @yonigozlan @qubvel |  | ||||||
| /src/transformers/models/*/image_processing* @qubvel |  | ||||||
| /src/transformers/models/*/image_processing_*_fast* @yonigozlan |  | ||||||
|  |  | ||||||
| # Owners of subsections of the library |  | ||||||
| /src/transformers/generation/ @gante |  | ||||||
| /src/transformers/pipeline/ @Rocketknight1 @yonigozlan |  | ||||||
| /src/transformers/integrations/ @SunMarc @MekkCyber @zach-huggingface |  | ||||||
| /src/transformers/quantizers/ @SunMarc @MekkCyber |  | ||||||
| tests/ @ydshieh |  | ||||||
| tests/generation/ @gante |  | ||||||
|  |  | ||||||
| /src/transformers/models/auto/ @ArthurZucker |  | ||||||
| /src/transformers/utils/ @ArthurZucker @Rocketknight1 |  | ||||||
| /src/transformers/loss/ @ArthurZucker |  | ||||||
| /src/transformers/onnx/ @michaelbenayoun |  | ||||||
|  |  | ||||||
| # Specific files come after the sections/globs, so they take priority |  | ||||||
| /.circleci/config.yml @ArthurZucker @ydshieh |  | ||||||
| /utils/tests_fetcher.py @ydshieh |  | ||||||
| trainer.py @zach-huggingface @SunMarc |  | ||||||
| trainer_utils.py @zach-huggingface @SunMarc |  | ||||||
| /utils/modular_model_converter.py @Cyrilvallez @ArthurZucker |  | ||||||
|  |  | ||||||
| # Owners of individual models are specific / high priority, and so they come last |  | ||||||
| # mod* captures modeling and modular files |  | ||||||
|  |  | ||||||
| # Text models |  | ||||||
| /src/transformers/models/albert/mod*_albert* @ArthurZucker |  | ||||||
| /src/transformers/models/bamba/mod*_bamba* @ArthurZucker |  | ||||||
| /src/transformers/models/bart/mod*_bart* @ArthurZucker |  | ||||||
| /src/transformers/models/barthez/mod*_barthez* @ArthurZucker |  | ||||||
| /src/transformers/models/bartpho/mod*_bartpho* @ArthurZucker |  | ||||||
| /src/transformers/models/bert/mod*_bert* @ArthurZucker |  | ||||||
| /src/transformers/models/bert_generation/mod*_bert_generation* @ArthurZucker |  | ||||||
| /src/transformers/models/bert_japanese/mod*_bert_japanese* @ArthurZucker |  | ||||||
| /src/transformers/models/bertweet/mod*_bertweet* @ArthurZucker |  | ||||||
| /src/transformers/models/big_bird/mod*_big_bird* @ArthurZucker |  | ||||||
| /src/transformers/models/bigbird_pegasus/mod*_bigbird_pegasus* @ArthurZucker |  | ||||||
| /src/transformers/models/biogpt/mod*_biogpt* @ArthurZucker |  | ||||||
| /src/transformers/models/blenderbot/mod*_blenderbot* @ArthurZucker |  | ||||||
| /src/transformers/models/blenderbot_small/mod*_blenderbot_small* @ArthurZucker |  | ||||||
| /src/transformers/models/bloom/mod*_bloom* @ArthurZucker |  | ||||||
| /src/transformers/models/bort/mod*_bort* @ArthurZucker |  | ||||||
| /src/transformers/models/byt5/mod*_byt5* @ArthurZucker |  | ||||||
| /src/transformers/models/camembert/mod*_camembert* @ArthurZucker |  | ||||||
| /src/transformers/models/canine/mod*_canine* @ArthurZucker |  | ||||||
| /src/transformers/models/codegen/mod*_codegen* @ArthurZucker |  | ||||||
| /src/transformers/models/code_llama/mod*_code_llama* @ArthurZucker |  | ||||||
| /src/transformers/models/cohere/mod*_cohere* @ArthurZucker |  | ||||||
| /src/transformers/models/cohere2/mod*_cohere2* @ArthurZucker |  | ||||||
| /src/transformers/models/convbert/mod*_convbert* @ArthurZucker |  | ||||||
| /src/transformers/models/cpm/mod*_cpm* @ArthurZucker |  | ||||||
| /src/transformers/models/cpmant/mod*_cpmant* @ArthurZucker |  | ||||||
| /src/transformers/models/ctrl/mod*_ctrl* @ArthurZucker |  | ||||||
| /src/transformers/models/dbrx/mod*_dbrx* @ArthurZucker |  | ||||||
| /src/transformers/models/deberta/mod*_deberta* @ArthurZucker |  | ||||||
| /src/transformers/models/deberta_v2/mod*_deberta_v2* @ArthurZucker |  | ||||||
| /src/transformers/models/dialogpt/mod*_dialogpt* @ArthurZucker |  | ||||||
| /src/transformers/models/diffllama/mod*_diffllama* @ArthurZucker |  | ||||||
| /src/transformers/models/distilbert/mod*_distilbert* @ArthurZucker |  | ||||||
| /src/transformers/models/dpr/mod*_dpr* @ArthurZucker |  | ||||||
| /src/transformers/models/electra/mod*_electra* @ArthurZucker |  | ||||||
| /src/transformers/models/encoder_decoder/mod*_encoder_decoder* @ArthurZucker |  | ||||||
| /src/transformers/models/ernie/mod*_ernie* @ArthurZucker |  | ||||||
| /src/transformers/models/ernie_m/mod*_ernie_m* @ArthurZucker |  | ||||||
| /src/transformers/models/esm/mod*_esm* @ArthurZucker |  | ||||||
| /src/transformers/models/falcon/mod*_falcon* @ArthurZucker |  | ||||||
| /src/transformers/models/falcon3/mod*_falcon3* @ArthurZucker |  | ||||||
| /src/transformers/models/falcon_mamba/mod*_falcon_mamba* @ArthurZucker |  | ||||||
| /src/transformers/models/fastspeech2_conformer/mod*_fastspeech2_conformer* @ArthurZucker |  | ||||||
| /src/transformers/models/flan_t5/mod*_flan_t5* @ArthurZucker |  | ||||||
| /src/transformers/models/flan_ul2/mod*_flan_ul2* @ArthurZucker |  | ||||||
| /src/transformers/models/flaubert/mod*_flaubert* @ArthurZucker |  | ||||||
| /src/transformers/models/fnet/mod*_fnet* @ArthurZucker |  | ||||||
| /src/transformers/models/fsmt/mod*_fsmt* @ArthurZucker |  | ||||||
| /src/transformers/models/funnel/mod*_funnel* @ArthurZucker |  | ||||||
| /src/transformers/models/fuyu/mod*_fuyu* @ArthurZucker |  | ||||||
| /src/transformers/models/gemma/mod*_gemma* @ArthurZucker |  | ||||||
| /src/transformers/models/gemma2/mod*_gemma2* @ArthurZucker |  | ||||||
| /src/transformers/models/glm/mod*_glm* @ArthurZucker |  | ||||||
| /src/transformers/models/openai_gpt/mod*_openai_gpt* @ArthurZucker |  | ||||||
| /src/transformers/models/gpt_neo/mod*_gpt_neo* @ArthurZucker |  | ||||||
| /src/transformers/models/gpt_neox/mod*_gpt_neox* @ArthurZucker |  | ||||||
| /src/transformers/models/gpt_neox_japanese/mod*_gpt_neox_japanese* @ArthurZucker |  | ||||||
| /src/transformers/models/gptj/mod*_gptj* @ArthurZucker |  | ||||||
| /src/transformers/models/gpt2/mod*_gpt2* @ArthurZucker |  | ||||||
| /src/transformers/models/gpt_bigcode/mod*_gpt_bigcode* @ArthurZucker |  | ||||||
| /src/transformers/models/gptsan_japanese/mod*_gptsan_japanese* @ArthurZucker |  | ||||||
| /src/transformers/models/gpt_sw3/mod*_gpt_sw3* @ArthurZucker |  | ||||||
| /src/transformers/models/granite/mod*_granite* @ArthurZucker |  | ||||||
| /src/transformers/models/granitemoe/mod*_granitemoe* @ArthurZucker |  | ||||||
| /src/transformers/models/herbert/mod*_herbert* @ArthurZucker |  | ||||||
| /src/transformers/models/ibert/mod*_ibert* @ArthurZucker |  | ||||||
| /src/transformers/models/jamba/mod*_jamba* @ArthurZucker |  | ||||||
| /src/transformers/models/jetmoe/mod*_jetmoe* @ArthurZucker |  | ||||||
| /src/transformers/models/jukebox/mod*_jukebox* @ArthurZucker |  | ||||||
| /src/transformers/models/led/mod*_led* @ArthurZucker |  | ||||||
| /src/transformers/models/llama/mod*_llama* @ArthurZucker @Cyrilvallez |  | ||||||
| /src/transformers/models/longformer/mod*_longformer* @ArthurZucker |  | ||||||
| /src/transformers/models/longt5/mod*_longt5* @ArthurZucker |  | ||||||
| /src/transformers/models/luke/mod*_luke* @ArthurZucker |  | ||||||
| /src/transformers/models/m2m_100/mod*_m2m_100* @ArthurZucker |  | ||||||
| /src/transformers/models/madlad_400/mod*_madlad_400* @ArthurZucker |  | ||||||
| /src/transformers/models/mamba/mod*_mamba* @ArthurZucker |  | ||||||
| /src/transformers/models/mamba2/mod*_mamba2* @ArthurZucker |  | ||||||
| /src/transformers/models/marian/mod*_marian* @ArthurZucker |  | ||||||
| /src/transformers/models/markuplm/mod*_markuplm* @ArthurZucker |  | ||||||
| /src/transformers/models/mbart/mod*_mbart* @ArthurZucker |  | ||||||
| /src/transformers/models/mega/mod*_mega* @ArthurZucker |  | ||||||
| /src/transformers/models/megatron_bert/mod*_megatron_bert* @ArthurZucker |  | ||||||
| /src/transformers/models/megatron_gpt2/mod*_megatron_gpt2* @ArthurZucker |  | ||||||
| /src/transformers/models/mistral/mod*_mistral* @ArthurZucker |  | ||||||
| /src/transformers/models/mixtral/mod*_mixtral* @ArthurZucker |  | ||||||
| /src/transformers/models/mluke/mod*_mluke* @ArthurZucker |  | ||||||
| /src/transformers/models/mobilebert/mod*_mobilebert* @ArthurZucker |  | ||||||
| /src/transformers/models/modernbert/mod*_modernbert* @ArthurZucker |  | ||||||
| /src/transformers/models/mpnet/mod*_mpnet* @ArthurZucker |  | ||||||
| /src/transformers/models/mpt/mod*_mpt* @ArthurZucker |  | ||||||
| /src/transformers/models/mra/mod*_mra* @ArthurZucker |  | ||||||
| /src/transformers/models/mt5/mod*_mt5* @ArthurZucker |  | ||||||
| /src/transformers/models/mvp/mod*_mvp* @ArthurZucker |  | ||||||
| /src/transformers/models/myt5/mod*_myt5* @ArthurZucker |  | ||||||
| /src/transformers/models/nemotron/mod*_nemotron* @ArthurZucker |  | ||||||
| /src/transformers/models/nezha/mod*_nezha* @ArthurZucker |  | ||||||
| /src/transformers/models/nllb/mod*_nllb* @ArthurZucker |  | ||||||
| /src/transformers/models/nllb_moe/mod*_nllb_moe* @ArthurZucker |  | ||||||
| /src/transformers/models/nystromformer/mod*_nystromformer* @ArthurZucker |  | ||||||
| /src/transformers/models/olmo/mod*_olmo* @ArthurZucker |  | ||||||
| /src/transformers/models/olmo2/mod*_olmo2* @ArthurZucker |  | ||||||
| /src/transformers/models/olmoe/mod*_olmoe* @ArthurZucker |  | ||||||
| /src/transformers/models/open_llama/mod*_open_llama* @ArthurZucker |  | ||||||
| /src/transformers/models/opt/mod*_opt* @ArthurZucker |  | ||||||
| /src/transformers/models/pegasus/mod*_pegasus* @ArthurZucker |  | ||||||
| /src/transformers/models/pegasus_x/mod*_pegasus_x* @ArthurZucker |  | ||||||
| /src/transformers/models/persimmon/mod*_persimmon* @ArthurZucker |  | ||||||
| /src/transformers/models/phi/mod*_phi* @ArthurZucker |  | ||||||
| /src/transformers/models/phi3/mod*_phi3* @ArthurZucker |  | ||||||
| /src/transformers/models/phimoe/mod*_phimoe* @ArthurZucker |  | ||||||
| /src/transformers/models/phobert/mod*_phobert* @ArthurZucker |  | ||||||
| /src/transformers/models/plbart/mod*_plbart* @ArthurZucker |  | ||||||
| /src/transformers/models/prophetnet/mod*_prophetnet* @ArthurZucker |  | ||||||
| /src/transformers/models/qdqbert/mod*_qdqbert* @ArthurZucker |  | ||||||
| /src/transformers/models/qwen2/mod*_qwen2* @ArthurZucker |  | ||||||
| /src/transformers/models/qwen2_moe/mod*_qwen2_moe* @ArthurZucker |  | ||||||
| /src/transformers/models/rag/mod*_rag* @ArthurZucker |  | ||||||
| /src/transformers/models/realm/mod*_realm* @ArthurZucker |  | ||||||
| /src/transformers/models/recurrent_gemma/mod*_recurrent_gemma* @ArthurZucker |  | ||||||
| /src/transformers/models/reformer/mod*_reformer* @ArthurZucker |  | ||||||
| /src/transformers/models/rembert/mod*_rembert* @ArthurZucker |  | ||||||
| /src/transformers/models/retribert/mod*_retribert* @ArthurZucker |  | ||||||
| /src/transformers/models/roberta/mod*_roberta* @ArthurZucker |  | ||||||
| /src/transformers/models/roberta_prelayernorm/mod*_roberta_prelayernorm* @ArthurZucker |  | ||||||
| /src/transformers/models/roc_bert/mod*_roc_bert* @ArthurZucker |  | ||||||
| /src/transformers/models/roformer/mod*_roformer* @ArthurZucker |  | ||||||
| /src/transformers/models/rwkv/mod*_rwkv* @ArthurZucker |  | ||||||
| /src/transformers/models/splinter/mod*_splinter* @ArthurZucker |  | ||||||
| /src/transformers/models/squeezebert/mod*_squeezebert* @ArthurZucker |  | ||||||
| /src/transformers/models/stablelm/mod*_stablelm* @ArthurZucker |  | ||||||
| /src/transformers/models/starcoder2/mod*_starcoder2* @ArthurZucker |  | ||||||
| /src/transformers/models/switch_transformers/mod*_switch_transformers* @ArthurZucker |  | ||||||
| /src/transformers/models/t5/mod*_t5* @ArthurZucker |  | ||||||
| /src/transformers/models/t5v1.1/mod*_t5v1.1* @ArthurZucker |  | ||||||
| /src/transformers/models/tapex/mod*_tapex* @ArthurZucker |  | ||||||
| /src/transformers/models/transfo_xl/mod*_transfo_xl* @ArthurZucker |  | ||||||
| /src/transformers/models/ul2/mod*_ul2* @ArthurZucker |  | ||||||
| /src/transformers/models/umt5/mod*_umt5* @ArthurZucker |  | ||||||
| /src/transformers/models/xmod/mod*_xmod* @ArthurZucker |  | ||||||
| /src/transformers/models/xglm/mod*_xglm* @ArthurZucker |  | ||||||
| /src/transformers/models/xlm/mod*_xlm* @ArthurZucker |  | ||||||
| /src/transformers/models/xlm_prophetnet/mod*_xlm_prophetnet* @ArthurZucker |  | ||||||
| /src/transformers/models/xlm_roberta/mod*_xlm_roberta* @ArthurZucker |  | ||||||
| /src/transformers/models/xlm_roberta_xl/mod*_xlm_roberta_xl* @ArthurZucker |  | ||||||
| /src/transformers/models/xlm_v/mod*_xlm_v* @ArthurZucker |  | ||||||
| /src/transformers/models/xlnet/mod*_xlnet* @ArthurZucker |  | ||||||
| /src/transformers/models/yoso/mod*_yoso* @ArthurZucker |  | ||||||
| /src/transformers/models/zamba/mod*_zamba* @ArthurZucker |  | ||||||
|  |  | ||||||
| # Vision models |  | ||||||
| /src/transformers/models/beit/mod*_beit* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/bit/mod*_bit* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/conditional_detr/mod*_conditional_detr* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/convnext/mod*_convnext* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/convnextv2/mod*_convnextv2* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/cvt/mod*_cvt* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/deformable_detr/mod*_deformable_detr* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/deit/mod*_deit* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/depth_anything/mod*_depth_anything* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/depth_anything_v2/mod*_depth_anything_v2* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/deta/mod*_deta* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/detr/mod*_detr* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/dinat/mod*_dinat* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/dinov2/mod*_dinov2* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/dinov2_with_registers/mod*_dinov2_with_registers* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/dit/mod*_dit* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/dpt/mod*_dpt* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/efficientformer/mod*_efficientformer* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/efficientnet/mod*_efficientnet* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/focalnet/mod*_focalnet* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/glpn/mod*_glpn* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/hiera/mod*_hiera* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/ijepa/mod*_ijepa* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/imagegpt/mod*_imagegpt* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/levit/mod*_levit* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/mask2former/mod*_mask2former* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/maskformer/mod*_maskformer* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/mobilenet_v1/mod*_mobilenet_v1* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/mobilenet_v2/mod*_mobilenet_v2* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/mobilevit/mod*_mobilevit* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/mobilevitv2/mod*_mobilevitv2* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/nat/mod*_nat* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/poolformer/mod*_poolformer* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/pvt/mod*_pvt* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/pvt_v2/mod*_pvt_v2* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/regnet/mod*_regnet* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/resnet/mod*_resnet* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/rt_detr/mod*_rt_detr* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/segformer/mod*_segformer* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/seggpt/mod*_seggpt* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/superpoint/mod*_superpoint* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/swiftformer/mod*_swiftformer* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/swin/mod*_swin* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/swinv2/mod*_swinv2* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/swin2sr/mod*_swin2sr* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/table_transformer/mod*_table_transformer* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/textnet/mod*_textnet* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/timm_wrapper/mod*_timm_wrapper* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/upernet/mod*_upernet* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/van/mod*_van* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/vit/mod*_vit* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/vit_hybrid/mod*_vit_hybrid* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/vitdet/mod*_vitdet* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/vit_mae/mod*_vit_mae* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/vitmatte/mod*_vitmatte* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/vit_msn/mod*_vit_msn* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/vitpose/mod*_vitpose* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/yolos/mod*_yolos* @amyeroberts @qubvel |  | ||||||
| /src/transformers/models/zoedepth/mod*_zoedepth* @amyeroberts @qubvel |  | ||||||
|  |  | ||||||
| # Audio models |  | ||||||
| /src/transformers/models/audio_spectrogram_transformer/mod*_audio_spectrogram_transformer* @eustlb |  | ||||||
| /src/transformers/models/bark/mod*_bark* @eustlb |  | ||||||
| /src/transformers/models/clap/mod*_clap* @eustlb |  | ||||||
| /src/transformers/models/dac/mod*_dac* @eustlb |  | ||||||
| /src/transformers/models/encodec/mod*_encodec* @eustlb |  | ||||||
| /src/transformers/models/hubert/mod*_hubert* @eustlb |  | ||||||
| /src/transformers/models/mctct/mod*_mctct* @eustlb |  | ||||||
| /src/transformers/models/mimi/mod*_mimi* @eustlb |  | ||||||
| /src/transformers/models/mms/mod*_mms* @eustlb |  | ||||||
| /src/transformers/models/moshi/mod*_moshi* @eustlb |  | ||||||
| /src/transformers/models/musicgen/mod*_musicgen* @eustlb |  | ||||||
| /src/transformers/models/musicgen_melody/mod*_musicgen_melody* @eustlb |  | ||||||
| /src/transformers/models/pop2piano/mod*_pop2piano* @eustlb |  | ||||||
| /src/transformers/models/seamless_m4t/mod*_seamless_m4t* @eustlb |  | ||||||
| /src/transformers/models/seamless_m4t_v2/mod*_seamless_m4t_v2* @eustlb |  | ||||||
| /src/transformers/models/sew/mod*_sew* @eustlb |  | ||||||
| /src/transformers/models/sew_d/mod*_sew_d* @eustlb |  | ||||||
| /src/transformers/models/speech_to_text/mod*_speech_to_text* @eustlb |  | ||||||
| /src/transformers/models/speech_to_text_2/mod*_speech_to_text_2* @eustlb |  | ||||||
| /src/transformers/models/speecht5/mod*_speecht5* @eustlb |  | ||||||
| /src/transformers/models/unispeech/mod*_unispeech* @eustlb |  | ||||||
| /src/transformers/models/unispeech_sat/mod*_unispeech_sat* @eustlb |  | ||||||
| /src/transformers/models/univnet/mod*_univnet* @eustlb |  | ||||||
| /src/transformers/models/vits/mod*_vits* @eustlb |  | ||||||
| /src/transformers/models/wav2vec2/mod*_wav2vec2* @eustlb |  | ||||||
| /src/transformers/models/wav2vec2_bert/mod*_wav2vec2_bert* @eustlb |  | ||||||
| /src/transformers/models/wav2vec2_conformer/mod*_wav2vec2_conformer* @eustlb |  | ||||||
| /src/transformers/models/wav2vec2_phoneme/mod*_wav2vec2_phoneme* @eustlb |  | ||||||
| /src/transformers/models/wavlm/mod*_wavlm* @eustlb |  | ||||||
| /src/transformers/models/whisper/mod*_whisper* @eustlb |  | ||||||
| /src/transformers/models/xls_r/mod*_xls_r* @eustlb |  | ||||||
| /src/transformers/models/xlsr_wav2vec2/mod*_xlsr_wav2vec2* @eustlb |  | ||||||
|  |  | ||||||
| # Video models |  | ||||||
| /src/transformers/models/timesformer/mod*_timesformer* @Rocketknight1 |  | ||||||
| /src/transformers/models/videomae/mod*_videomae* @Rocketknight1 |  | ||||||
| /src/transformers/models/vivit/mod*_vivit* @Rocketknight1 |  | ||||||
|  |  | ||||||
| # Multimodal models |  | ||||||
| /src/transformers/models/align/mod*_align* @zucchini-nlp |  | ||||||
| /src/transformers/models/altclip/mod*_altclip* @zucchini-nlp |  | ||||||
| /src/transformers/models/aria/mod*_aria* @zucchini-nlp |  | ||||||
| /src/transformers/models/blip/mod*_blip* @zucchini-nlp |  | ||||||
| /src/transformers/models/blip_2/mod*_blip_2* @zucchini-nlp |  | ||||||
| /src/transformers/models/bridgetower/mod*_bridgetower* @zucchini-nlp |  | ||||||
| /src/transformers/models/bros/mod*_bros* @zucchini-nlp |  | ||||||
| /src/transformers/models/chameleon/mod*_chameleon* @zucchini-nlp |  | ||||||
| /src/transformers/models/chinese_clip/mod*_chinese_clip* @zucchini-nlp |  | ||||||
| /src/transformers/models/clip/mod*_clip* @zucchini-nlp |  | ||||||
| /src/transformers/models/clipseg/mod*_clipseg* @zucchini-nlp |  | ||||||
| /src/transformers/models/clvp/mod*_clvp* @zucchini-nlp |  | ||||||
| /src/transformers/models/colpali/mod*_colpali* @zucchini-nlp @yonigozlan |  | ||||||
| /src/transformers/models/data2vec/mod*_data2vec* @zucchini-nlp |  | ||||||
| /src/transformers/models/deplot/mod*_deplot* @zucchini-nlp |  | ||||||
| /src/transformers/models/donut/mod*_donut* @zucchini-nlp |  | ||||||
| /src/transformers/models/flava/mod*_flava* @zucchini-nlp |  | ||||||
| /src/transformers/models/git/mod*_git* @zucchini-nlp |  | ||||||
| /src/transformers/models/grounding_dino/mod*_grounding_dino* @qubvel |  | ||||||
| /src/transformers/models/groupvit/mod*_groupvit* @zucchini-nlp |  | ||||||
| /src/transformers/models/idefics/mod*_idefics* @zucchini-nlp |  | ||||||
| /src/transformers/models/idefics2/mod*_idefics2* @zucchini-nlp |  | ||||||
| /src/transformers/models/idefics3/mod*_idefics3* @zucchini-nlp |  | ||||||
| /src/transformers/models/instructblip/mod*_instructblip* @zucchini-nlp |  | ||||||
| /src/transformers/models/instructblipvideo/mod*_instructblipvideo* @zucchini-nlp |  | ||||||
| /src/transformers/models/kosmos_2/mod*_kosmos_2* @zucchini-nlp |  | ||||||
| /src/transformers/models/layoutlm/mod*_layoutlm* @NielsRogge |  | ||||||
| /src/transformers/models/layoutlmv2/mod*_layoutlmv2* @NielsRogge |  | ||||||
| /src/transformers/models/layoutlmv3/mod*_layoutlmv3* @NielsRogge |  | ||||||
| /src/transformers/models/layoutxlm/mod*_layoutxlm* @NielsRogge |  | ||||||
| /src/transformers/models/lilt/mod*_lilt* @zucchini-nlp |  | ||||||
| /src/transformers/models/llava/mod*_llava* @zucchini-nlp @arthurzucker |  | ||||||
| /src/transformers/models/llava_next/mod*_llava_next* @zucchini-nlp |  | ||||||
| /src/transformers/models/llava_next_video/mod*_llava_next_video* @zucchini-nlp |  | ||||||
| /src/transformers/models/llava_onevision/mod*_llava_onevision* @zucchini-nlp |  | ||||||
| /src/transformers/models/lxmert/mod*_lxmert* @zucchini-nlp |  | ||||||
| /src/transformers/models/matcha/mod*_matcha* @zucchini-nlp |  | ||||||
| /src/transformers/models/mgp_str/mod*_mgp_str* @zucchini-nlp |  | ||||||
| /src/transformers/models/mllama/mod*_mllama* @zucchini-nlp |  | ||||||
| /src/transformers/models/nougat/mod*_nougat* @NielsRogge |  | ||||||
| /src/transformers/models/omdet_turbo/mod*_omdet_turbo* @qubvel @yonigozlan |  | ||||||
| /src/transformers/models/oneformer/mod*_oneformer* @zucchini-nlp |  | ||||||
| /src/transformers/models/owlvit/mod*_owlvit* @qubvel |  | ||||||
| /src/transformers/models/owlv2/mod*_owlv2* @qubvel |  | ||||||
| /src/transformers/models/paligemma/mod*_paligemma* @zucchini-nlp @molbap |  | ||||||
| /src/transformers/models/perceiver/mod*_perceiver* @zucchini-nlp |  | ||||||
| /src/transformers/models/pix2struct/mod*_pix2struct* @zucchini-nlp |  | ||||||
| /src/transformers/models/pixtral/mod*_pixtral* @zucchini-nlp @ArthurZucker |  | ||||||
| /src/transformers/models/qwen2_audio/mod*_qwen2_audio* @zucchini-nlp @ArthurZucker |  | ||||||
| /src/transformers/models/qwen2_vl/mod*_qwen2_vl* @zucchini-nlp @ArthurZucker |  | ||||||
| /src/transformers/models/sam/mod*_sam* @zucchini-nlp @ArthurZucker |  | ||||||
| /src/transformers/models/siglip/mod*_siglip* @zucchini-nlp |  | ||||||
| /src/transformers/models/speech_encoder_decoder/mod*_speech_encoder_decoder* @zucchini-nlp |  | ||||||
| /src/transformers/models/tapas/mod*_tapas* @NielsRogge |  | ||||||
| /src/transformers/models/trocr/mod*_trocr* @zucchini-nlp |  | ||||||
| /src/transformers/models/tvlt/mod*_tvlt* @zucchini-nlp |  | ||||||
| /src/transformers/models/tvp/mod*_tvp* @zucchini-nlp |  | ||||||
| /src/transformers/models/udop/mod*_udop* @zucchini-nlp |  | ||||||
| /src/transformers/models/video_llava/mod*_video_llava* @zucchini-nlp |  | ||||||
| /src/transformers/models/vilt/mod*_vilt* @zucchini-nlp |  | ||||||
| /src/transformers/models/vipllava/mod*_vipllava* @zucchini-nlp |  | ||||||
| /src/transformers/models/vision_encoder_decoder/mod*_vision_encoder_decoder* @Rocketknight1 |  | ||||||
| /src/transformers/models/vision_text_dual_encoder/mod*_vision_text_dual_encoder* @Rocketknight1 |  | ||||||
| /src/transformers/models/visual_bert/mod*_visual_bert* @zucchini-nlp |  | ||||||
| /src/transformers/models/xclip/mod*_xclip* @zucchini-nlp |  | ||||||
|  |  | ||||||
| # Reinforcement learning models |  | ||||||
| /src/transformers/models/decision_transformer/mod*_decision_transformer* @Rocketknight1 |  | ||||||
| /src/transformers/models/trajectory_transformer/mod*_trajectory_transformer* @Rocketknight1 |  | ||||||
|  |  | ||||||
| # Time series models |  | ||||||
| /src/transformers/models/autoformer/mod*_autoformer* @Rocketknight1 |  | ||||||
| /src/transformers/models/informer/mod*_informer* @Rocketknight1 |  | ||||||
| /src/transformers/models/patchtsmixer/mod*_patchtsmixer* @Rocketknight1 |  | ||||||
| /src/transformers/models/patchtst/mod*_patchtst* @Rocketknight1 |  | ||||||
| /src/transformers/models/time_series_transformer/mod*_time_series_transformer* @Rocketknight1 |  | ||||||
|  |  | ||||||
| # Graph models |  | ||||||
| /src/transformers/models/graphormer/mod*_graphormer* @clefourrier |  | ||||||
|  |  | ||||||
| # Finally, files with no owners that shouldn't generate pings, usually automatically generated and checked in the CI |  | ||||||
| utils/dummy* |  | ||||||
							
								
								
									
										2
									
								
								.github/workflows/add-model-like.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/add-model-like.yml
									
									
									
									
										vendored
									
									
								
							| @ -54,7 +54,7 @@ jobs: | |||||||
|       - name: Create model files |       - name: Create model files | ||||||
|         run: | |         run: | | ||||||
|           . ~/venv/bin/activate |           . ~/venv/bin/activate | ||||||
|           transformers add-new-model-like --config_file tests/fixtures/add_distilbert_like_config.json --path_to_repo . |           transformers-cli add-new-model-like --config_file tests/fixtures/add_distilbert_like_config.json --path_to_repo . | ||||||
|           make style |           make style | ||||||
|           make fix-copies |           make fix-copies | ||||||
|  |  | ||||||
|  | |||||||
							
								
								
									
										26
									
								
								.github/workflows/assign-reviewers.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										26
									
								
								.github/workflows/assign-reviewers.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,26 +0,0 @@ | |||||||
| name: Assign PR Reviewers |  | ||||||
| on: |  | ||||||
|   pull_request_target: |  | ||||||
|     branches: |  | ||||||
|       - main |  | ||||||
|     types: [ready_for_review] |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   assign_reviewers: |  | ||||||
|     permissions: |  | ||||||
|        pull-requests: write |  | ||||||
|     runs-on: ubuntu-22.04 |  | ||||||
|     steps: |  | ||||||
|       - uses: actions/checkout@v4 |  | ||||||
|       - name: Set up Python |  | ||||||
|         uses: actions/setup-python@v5 |  | ||||||
|         with: |  | ||||||
|           python-version: '3.13' |  | ||||||
|       - name: Install dependencies |  | ||||||
|         run: | |  | ||||||
|           python -m pip install --upgrade pip |  | ||||||
|           pip install PyGithub |  | ||||||
|       - name: Run assignment script |  | ||||||
|         env: |  | ||||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
|         run: python .github/scripts/assign_reviewers.py |  | ||||||
							
								
								
									
										6
									
								
								.github/workflows/benchmark.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/benchmark.yml
									
									
									
									
										vendored
									
									
								
							| @ -18,8 +18,7 @@ jobs: | |||||||
|     name: Benchmark |     name: Benchmark | ||||||
|     strategy: |     strategy: | ||||||
|       matrix: |       matrix: | ||||||
|         # group: [aws-g5-4xlarge-cache, aws-p4d-24xlarge-plus] (A100 runner is not enabled) |         group: [aws-g5-4xlarge-cache, aws-p4d-24xlarge-plus] | ||||||
|         group: [aws-g5-4xlarge-cache] |  | ||||||
|     runs-on: |     runs-on: | ||||||
|       group: ${{ matrix.group }} |       group: ${{ matrix.group }} | ||||||
|     if: | |     if: | | ||||||
| @ -64,7 +63,7 @@ jobs: | |||||||
|             commit_id=$GITHUB_SHA |             commit_id=$GITHUB_SHA | ||||||
|           fi |           fi | ||||||
|           commit_msg=$(git show -s --format=%s | cut -c1-70) |           commit_msg=$(git show -s --format=%s | cut -c1-70) | ||||||
|           python3 benchmark/benchmarks_entrypoint.py "huggingface/transformers" "$BRANCH_NAME" "$commit_id" "$commit_msg" |           python3 benchmark/benchmarks_entrypoint.py "${{ github.head_ref || github.ref_name }}" "$commit_id" "$commit_msg" | ||||||
|         env: |         env: | ||||||
|           HF_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} |           HF_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} | ||||||
|           # Enable this to see debug logs |           # Enable this to see debug logs | ||||||
| @ -73,4 +72,3 @@ jobs: | |||||||
|           PGHOST: ${{ secrets.TRANSFORMERS_BENCHMARKS_PGHOST }} |           PGHOST: ${{ secrets.TRANSFORMERS_BENCHMARKS_PGHOST }} | ||||||
|           PGUSER: transformers_benchmarks |           PGUSER: transformers_benchmarks | ||||||
|           PGPASSWORD: ${{ secrets.TRANSFORMERS_BENCHMARKS_PGPASSWORD }} |           PGPASSWORD: ${{ secrets.TRANSFORMERS_BENCHMARKS_PGPASSWORD }} | ||||||
|           BRANCH_NAME: ${{ github.head_ref || github.ref_name }} |  | ||||||
|  | |||||||
							
								
								
									
										6
									
								
								.github/workflows/build-ci-docker-images.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/build-ci-docker-images.yml
									
									
									
									
										vendored
									
									
								
							| @ -26,7 +26,7 @@ jobs: | |||||||
|  |  | ||||||
|     strategy: |     strategy: | ||||||
|       matrix: |       matrix: | ||||||
|         file: ["quality", "consistency", "custom-tokenizers", "torch-light", "tf-light", "exotic-models", "torch-tf-light", "jax-light", "examples-torch",  "examples-tf"] |         file: ["quality", "consistency", "custom-tokenizers", "torch-light", "tf-light", "exotic-models", "torch-tf-light", "torch-jax-light", "jax-light", "examples-torch",  "examples-tf"] | ||||||
|     continue-on-error: true |     continue-on-error: true | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
| @ -34,11 +34,11 @@ jobs: | |||||||
|         name: Set tag |         name: Set tag | ||||||
|         run: | |         run: | | ||||||
|               if ${{contains(github.event.head_commit.message, '[build-ci-image]')}}; then |               if ${{contains(github.event.head_commit.message, '[build-ci-image]')}}; then | ||||||
|                   echo "TAG=huggingface/transformers-${{ matrix.file }}:dev" >> "$GITHUB_ENV" |                   echo "TAG=huggingface/transformers-${{ matrix.file }}:dev" >> "$GITHUB_ENV"  | ||||||
|                   echo "setting it to DEV!" |                   echo "setting it to DEV!" | ||||||
|               else |               else | ||||||
|                   echo "TAG=huggingface/transformers-${{ matrix.file }}" >> "$GITHUB_ENV" |                   echo "TAG=huggingface/transformers-${{ matrix.file }}" >> "$GITHUB_ENV" | ||||||
|  |                    | ||||||
|               fi |               fi | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|  | |||||||
							
								
								
									
										70
									
								
								.github/workflows/build-docker-images.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										70
									
								
								.github/workflows/build-docker-images.yml
									
									
									
									
										vendored
									
									
								
							| @ -19,7 +19,7 @@ concurrency: | |||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   latest-docker: |   latest-docker: | ||||||
|     name: "Latest PyTorch [dev]" |     name: "Latest PyTorch + TensorFlow [dev]" | ||||||
|     runs-on: |     runs-on: | ||||||
|       group: aws-general-8-plus |       group: aws-general-8-plus | ||||||
|     steps: |     steps: | ||||||
| @ -63,14 +63,14 @@ jobs: | |||||||
|         uses: huggingface/hf-workflows/.github/actions/post-slack@main |         uses: huggingface/hf-workflows/.github/actions/post-slack@main | ||||||
|         with: |         with: | ||||||
|           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER }} |           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER }} | ||||||
|           title: 🤗 Results of the transformers-all-latest-gpu-push-ci docker build |           title: 🤗 Results of the transformers-all-latest-gpu-push-ci docker build  | ||||||
|           status: ${{ job.status }} |           status: ${{ job.status }} | ||||||
|           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} |           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} | ||||||
|  |  | ||||||
|   latest-torch-deepspeed-docker: |   latest-torch-deepspeed-docker: | ||||||
|     name: "Latest PyTorch + DeepSpeed" |     name: "Latest PyTorch + DeepSpeed" | ||||||
|     runs-on: |     runs-on: | ||||||
|       group: aws-g4dn-2xlarge-cache |       group: aws-general-8-plus | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
| @ -99,7 +99,7 @@ jobs: | |||||||
|         uses: huggingface/hf-workflows/.github/actions/post-slack@main |         uses: huggingface/hf-workflows/.github/actions/post-slack@main | ||||||
|         with: |         with: | ||||||
|           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER}} |           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER}} | ||||||
|           title: 🤗 Results of the transformers-pytorch-deepspeed-latest-gpu docker build |           title: 🤗 Results of the transformers-pytorch-deepspeed-latest-gpu docker build  | ||||||
|           status: ${{ job.status }} |           status: ${{ job.status }} | ||||||
|           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} |           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} | ||||||
|  |  | ||||||
| @ -140,7 +140,7 @@ jobs: | |||||||
|         uses: huggingface/hf-workflows/.github/actions/post-slack@main |         uses: huggingface/hf-workflows/.github/actions/post-slack@main | ||||||
|         with: |         with: | ||||||
|           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER }} |           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER }} | ||||||
|           title: 🤗 Results of the transformers-pytorch-deepspeed-latest-gpu-push-ci docker build |           title: 🤗 Results of the transformers-pytorch-deepspeed-latest-gpu-push-ci docker build  | ||||||
|           status: ${{ job.status }} |           status: ${{ job.status }} | ||||||
|           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} |           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} | ||||||
|  |  | ||||||
| @ -176,7 +176,7 @@ jobs: | |||||||
|         uses: huggingface/hf-workflows/.github/actions/post-slack@main |         uses: huggingface/hf-workflows/.github/actions/post-slack@main | ||||||
|         with: |         with: | ||||||
|           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER }} |           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER }} | ||||||
|           title: 🤗 Results of the huggingface/transformers-doc-builder docker build |           title: 🤗 Results of the huggingface/transformers-doc-builder docker build  | ||||||
|           status: ${{ job.status }} |           status: ${{ job.status }} | ||||||
|           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} |           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} | ||||||
|  |  | ||||||
| @ -214,7 +214,7 @@ jobs: | |||||||
|         uses: huggingface/hf-workflows/.github/actions/post-slack@main |         uses: huggingface/hf-workflows/.github/actions/post-slack@main | ||||||
|         with: |         with: | ||||||
|           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER }} |           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER }} | ||||||
|           title: 🤗 Results of the huggingface/transformers-pytorch-gpudocker build |           title: 🤗 Results of the huggingface/transformers-pytorch-gpudocker build  | ||||||
|           status: ${{ job.status }} |           status: ${{ job.status }} | ||||||
|           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} |           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} | ||||||
|  |  | ||||||
| @ -223,19 +223,19 @@ jobs: | |||||||
|     runs-on: |     runs-on: | ||||||
|       group: aws-general-8-plus |       group: aws-general-8-plus | ||||||
|     steps: |     steps: | ||||||
|       - |       -  | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         uses: docker/setup-buildx-action@v3 |         uses: docker/setup-buildx-action@v3 | ||||||
|       - |       -  | ||||||
|         name: Check out code |         name: Check out code | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v4 | ||||||
|       - |       -  | ||||||
|         name: Login to DockerHub |         name: Login to DockerHub | ||||||
|         uses: docker/login-action@v3 |         uses: docker/login-action@v3 | ||||||
|         with: |         with: | ||||||
|           username: ${{ secrets.DOCKERHUB_USERNAME }} |           username: ${{ secrets.DOCKERHUB_USERNAME }} | ||||||
|           password: ${{ secrets.DOCKERHUB_PASSWORD }} |           password: ${{ secrets.DOCKERHUB_PASSWORD }} | ||||||
|       - |       -  | ||||||
|         name: Build and push |         name: Build and push | ||||||
|         uses: docker/build-push-action@v5 |         uses: docker/build-push-action@v5 | ||||||
|         with: |         with: | ||||||
| @ -263,12 +263,14 @@ jobs: | |||||||
|         uses: huggingface/hf-workflows/.github/actions/post-slack@main |         uses: huggingface/hf-workflows/.github/actions/post-slack@main | ||||||
|         with: |         with: | ||||||
|           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER }} |           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER }} | ||||||
|           title: 🤗 Results of the huggingface/transformers-pytorch-amd-gpu-push-ci build |           title: 🤗 Results of the huggingface/transformers-pytorch-amd-gpu-push-ci build  | ||||||
|           status: ${{ job.status }} |           status: ${{ job.status }} | ||||||
|           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} |           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} | ||||||
|  |  | ||||||
|   latest-pytorch-deepspeed-amd: |   latest-tensorflow: | ||||||
|     name: "PyTorch + DeepSpeed (AMD) [dev]" |     name: "Latest TensorFlow [dev]" | ||||||
|  |     # Push CI doesn't need this image | ||||||
|  |     if: inputs.image_postfix != '-push-ci' | ||||||
|     runs-on: |     runs-on: | ||||||
|       group: aws-general-8-plus |       group: aws-general-8-plus | ||||||
|     steps: |     steps: | ||||||
| @ -285,6 +287,42 @@ jobs: | |||||||
|           username: ${{ secrets.DOCKERHUB_USERNAME }} |           username: ${{ secrets.DOCKERHUB_USERNAME }} | ||||||
|           password: ${{ secrets.DOCKERHUB_PASSWORD }} |           password: ${{ secrets.DOCKERHUB_PASSWORD }} | ||||||
|       - |       - | ||||||
|  |         name: Build and push | ||||||
|  |         uses: docker/build-push-action@v5 | ||||||
|  |         with: | ||||||
|  |           context: ./docker/transformers-tensorflow-gpu | ||||||
|  |           build-args: | | ||||||
|  |             REF=main | ||||||
|  |           push: true | ||||||
|  |           tags: huggingface/transformers-tensorflow-gpu | ||||||
|  |  | ||||||
|  |       - name: Post to Slack | ||||||
|  |         if: always() | ||||||
|  |         uses: huggingface/hf-workflows/.github/actions/post-slack@main | ||||||
|  |         with: | ||||||
|  |           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER }} | ||||||
|  |           title: 🤗 Results of the huggingface/transformers-tensorflow-gpu build  | ||||||
|  |           status: ${{ job.status }} | ||||||
|  |           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} | ||||||
|  |  | ||||||
|  |   latest-pytorch-deepspeed-amd: | ||||||
|  |     name: "PyTorch + DeepSpeed (AMD) [dev]" | ||||||
|  |     runs-on: | ||||||
|  |       group: aws-general-8-plus | ||||||
|  |     steps: | ||||||
|  |       -  | ||||||
|  |         name: Set up Docker Buildx | ||||||
|  |         uses: docker/setup-buildx-action@v3 | ||||||
|  |       -  | ||||||
|  |         name: Check out code | ||||||
|  |         uses: actions/checkout@v4 | ||||||
|  |       -  | ||||||
|  |         name: Login to DockerHub | ||||||
|  |         uses: docker/login-action@v3 | ||||||
|  |         with: | ||||||
|  |           username: ${{ secrets.DOCKERHUB_USERNAME }} | ||||||
|  |           password: ${{ secrets.DOCKERHUB_PASSWORD }} | ||||||
|  |       -  | ||||||
|         name: Build and push |         name: Build and push | ||||||
|         uses: docker/build-push-action@v5 |         uses: docker/build-push-action@v5 | ||||||
|         with: |         with: | ||||||
| @ -312,7 +350,7 @@ jobs: | |||||||
|         uses: huggingface/hf-workflows/.github/actions/post-slack@main |         uses: huggingface/hf-workflows/.github/actions/post-slack@main | ||||||
|         with: |         with: | ||||||
|           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER }} |           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER }} | ||||||
|           title: 🤗 Results of the transformers-pytorch-deepspeed-amd-gpu build |           title: 🤗 Results of the transformers-pytorch-deepspeed-amd-gpu build  | ||||||
|           status: ${{ job.status }} |           status: ${{ job.status }} | ||||||
|           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} |           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} | ||||||
|  |  | ||||||
| @ -350,6 +388,6 @@ jobs: | |||||||
|         uses: huggingface/hf-workflows/.github/actions/post-slack@main |         uses: huggingface/hf-workflows/.github/actions/post-slack@main | ||||||
|         with: |         with: | ||||||
|           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER }} |           slack_channel: ${{ secrets.CI_SLACK_CHANNEL_DOCKER }} | ||||||
|           title: 🤗 Results of the transformers-quantization-latest-gpu build |           title: 🤗 Results of the transformers-quantization-latest-gpu build  | ||||||
|           status: ${{ job.status }} |           status: ${{ job.status }} | ||||||
|           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} |           slack_token: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} | ||||||
|  | |||||||
| @ -42,7 +42,7 @@ jobs: | |||||||
|   nightly-torch-deepspeed-docker: |   nightly-torch-deepspeed-docker: | ||||||
|     name: "Nightly PyTorch + DeepSpeed" |     name: "Nightly PyTorch + DeepSpeed" | ||||||
|     runs-on: |     runs-on: | ||||||
|       group: aws-g4dn-2xlarge-cache |       group: aws-general-8-plus | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|  | |||||||
							
								
								
									
										3
									
								
								.github/workflows/build_pr_documentation.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.github/workflows/build_pr_documentation.yml
									
									
									
									
										vendored
									
									
								
							| @ -14,4 +14,5 @@ jobs: | |||||||
|       commit_sha: ${{ github.event.pull_request.head.sha }} |       commit_sha: ${{ github.event.pull_request.head.sha }} | ||||||
|       pr_number: ${{ github.event.number }} |       pr_number: ${{ github.event.number }} | ||||||
|       package: transformers |       package: transformers | ||||||
|       languages: en |       languages: ar de en es fr hi it ko pt tr zh ja te | ||||||
|  |       custom_container: huggingface/transformers-doc-builder | ||||||
|  | |||||||
| @ -9,18 +9,6 @@ on: | |||||||
|       start_sha: |       start_sha: | ||||||
|         required: true |         required: true | ||||||
|         type: string |         type: string | ||||||
|       job: |  | ||||||
|         required: true |  | ||||||
|         type: string |  | ||||||
|       slack_report_channel: |  | ||||||
|         required: true |  | ||||||
|         type: string |  | ||||||
|       ci_event: |  | ||||||
|         required: true |  | ||||||
|         type: string |  | ||||||
|       report_repo_id: |  | ||||||
|         required: true |  | ||||||
|         type: string |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| env: | env: | ||||||
| @ -34,132 +22,82 @@ env: | |||||||
|   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} |   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} | ||||||
|   SIGOPT_API_TOKEN: ${{ secrets.SIGOPT_API_TOKEN }} |   SIGOPT_API_TOKEN: ${{ secrets.SIGOPT_API_TOKEN }} | ||||||
|   TF_FORCE_GPU_ALLOW_GROWTH: true |   TF_FORCE_GPU_ALLOW_GROWTH: true | ||||||
|  |   RUN_PT_TF_CROSS_TESTS: 1 | ||||||
|   CUDA_VISIBLE_DEVICES: 0,1 |   CUDA_VISIBLE_DEVICES: 0,1 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| jobs: | jobs: | ||||||
|   check_new_failures: |   run_models_gpu: | ||||||
|     name: " " |     name: " " | ||||||
|     runs-on: |     runs-on: | ||||||
|       group: aws-g4dn-4xlarge-cache |       group: aws-g4dn-2xlarge-cache | ||||||
|     container: |     container: | ||||||
|       image: ${{ inputs.docker }} |       image: ${{ inputs.docker }} | ||||||
|       options: --gpus all --shm-size "16gb" --ipc host -v /mnt/cache/.cache/huggingface:/mnt/cache/ |       options: --gpus all --shm-size "16gb" --ipc host -v /mnt/cache/.cache/huggingface:/mnt/cache/ | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: ci_results_${{ inputs.job }} |           name: ci_results_run_models_gpu | ||||||
|           path: /transformers/ci_results_${{ inputs.job }} |           path: /transformers/ci_results_run_models_gpu | ||||||
| 
 |  | ||||||
|       - name: Check file |  | ||||||
|         working-directory: /transformers |  | ||||||
|         run: | |  | ||||||
|           if [ -f ci_results_${{ inputs.job }}/new_failures.json ]; then |  | ||||||
|             echo "`ci_results_${{ inputs.job }}/new_failures.json` exists, continue ..." |  | ||||||
|             echo "process=true" >> $GITHUB_ENV |  | ||||||
|           else |  | ||||||
|             echo "`ci_results_${{ inputs.job }}/new_failures.json` doesn't exist, abort." |  | ||||||
|             echo "process=false" >> $GITHUB_ENV |  | ||||||
|           fi |  | ||||||
| 
 |  | ||||||
|       - uses: actions/download-artifact@v4 |  | ||||||
|         if: ${{ env.process == 'true' }} |  | ||||||
|         with: |  | ||||||
|           pattern: setup_values* |  | ||||||
|           path: setup_values |  | ||||||
|           merge-multiple: true |  | ||||||
| 
 |  | ||||||
|       - name: Prepare some setup values |  | ||||||
|         if: ${{ env.process == 'true' }} |  | ||||||
|         run: | |  | ||||||
|           if [ -f setup_values/prev_workflow_run_id.txt ]; then |  | ||||||
|             echo "PREV_WORKFLOW_RUN_ID=$(cat setup_values/prev_workflow_run_id.txt)" >> $GITHUB_ENV |  | ||||||
|           else |  | ||||||
|             echo "PREV_WORKFLOW_RUN_ID=" >> $GITHUB_ENV |  | ||||||
|           fi |  | ||||||
| 
 |  | ||||||
|           if [ -f setup_values/other_workflow_run_id.txt ]; then |  | ||||||
|             echo "OTHER_WORKFLOW_RUN_ID=$(cat setup_values/other_workflow_run_id.txt)" >> $GITHUB_ENV |  | ||||||
|           else |  | ||||||
|             echo "OTHER_WORKFLOW_RUN_ID=" >> $GITHUB_ENV |  | ||||||
|           fi |  | ||||||
| 
 | 
 | ||||||
|       - name: Update clone |       - name: Update clone | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
|         if: ${{ env.process == 'true' }} |  | ||||||
|         run: git fetch && git checkout ${{ github.sha }} |         run: git fetch && git checkout ${{ github.sha }} | ||||||
| 
 | 
 | ||||||
|       - name: Get target commit |       - name: Get target commit | ||||||
|         working-directory: /transformers/utils |         working-directory: /transformers/utils | ||||||
|         if: ${{ env.process == 'true' }} |  | ||||||
|         run: | |         run: | | ||||||
|           echo "END_SHA=$(TOKEN=${{ secrets.ACCESS_REPO_INFO_TOKEN }} python3 -c 'import os; from get_previous_daily_ci import get_last_daily_ci_run_commit; commit=get_last_daily_ci_run_commit(token=os.environ["TOKEN"], workflow_run_id=os.environ["PREV_WORKFLOW_RUN_ID"]); print(commit)')" >> $GITHUB_ENV |           echo "END_SHA=$(TOKEN=${{ secrets.ACCESS_REPO_INFO_TOKEN }} python3 -c 'import os; from get_previous_daily_ci import get_last_daily_ci_run_commit; commit=get_last_daily_ci_run_commit(token=os.environ["TOKEN"]); print(commit)')" >> $GITHUB_ENV | ||||||
| 
 | 
 | ||||||
|       - name: Checkout to `start_sha` |       - name: Checkout to `start_sha` | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
|         if: ${{ env.process == 'true' }} |  | ||||||
|         run: git fetch && git checkout ${{ inputs.start_sha }} |         run: git fetch && git checkout ${{ inputs.start_sha }} | ||||||
| 
 | 
 | ||||||
|       - name: Reinstall transformers in edit mode (remove the one installed during docker image build) |       - name: Reinstall transformers in edit mode (remove the one installed during docker image build) | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
|         if: ${{ env.process == 'true' }} |  | ||||||
|         run: python3 -m pip uninstall -y transformers && python3 -m pip install -e . |         run: python3 -m pip uninstall -y transformers && python3 -m pip install -e . | ||||||
| 
 | 
 | ||||||
|       - name: NVIDIA-SMI |       - name: NVIDIA-SMI | ||||||
|         if: ${{ env.process == 'true' }} |  | ||||||
|         run: | |         run: | | ||||||
|           nvidia-smi |           nvidia-smi | ||||||
| 
 | 
 | ||||||
|       - name: Environment |       - name: Environment | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
|         if: ${{ env.process == 'true' }} |  | ||||||
|         run: | |         run: | | ||||||
|           python3 utils/print_env.py |           python3 utils/print_env.py | ||||||
| 
 | 
 | ||||||
|       - name: Show installed libraries and their versions |       - name: Show installed libraries and their versions | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
|         if: ${{ env.process == 'true' }} |  | ||||||
|         run: pip freeze |         run: pip freeze | ||||||
| 
 | 
 | ||||||
|       - name: Check failed tests |       - name: Check failed tests | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
|         if: ${{ env.process == 'true' }} |         run: python3 utils/check_bad_commit.py --start_commit ${{ inputs.start_sha }} --end_commit ${{ env.END_SHA }} --file ci_results_run_models_gpu/new_model_failures.json --output_file new_model_failures_with_bad_commit.json | ||||||
|         run: python3 utils/check_bad_commit.py --start_commit ${{ inputs.start_sha }} --end_commit ${{ env.END_SHA }} --file ci_results_${{ inputs.job }}/new_failures.json --output_file new_failures_with_bad_commit.json |  | ||||||
| 
 | 
 | ||||||
|       - name: Show results |       - name: Show results | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
|         if: ${{ env.process == 'true' }} |  | ||||||
|         run: | |         run: | | ||||||
|           ls -l new_failures_with_bad_commit.json |           ls -l new_model_failures_with_bad_commit.json | ||||||
|           cat new_failures_with_bad_commit.json |           cat new_model_failures_with_bad_commit.json | ||||||
| 
 | 
 | ||||||
|       - name: Checkout back |       - name: Checkout back | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
|         if: ${{ env.process == 'true' }} |  | ||||||
|         run: | |         run: | | ||||||
|           git checkout ${{ inputs.start_sha }} |           git checkout ${{ inputs.start_sha }} | ||||||
| 
 | 
 | ||||||
|       - name: Process report |       - name: Process report | ||||||
|         shell: bash |         shell: bash | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
|         if: ${{ env.process == 'true' }} |  | ||||||
|         env: |         env: | ||||||
|           ACCESS_REPO_INFO_TOKEN: ${{ secrets.ACCESS_REPO_INFO_TOKEN }} |  | ||||||
|           TRANSFORMERS_CI_RESULTS_UPLOAD_TOKEN: ${{ secrets.TRANSFORMERS_CI_RESULTS_UPLOAD_TOKEN }} |           TRANSFORMERS_CI_RESULTS_UPLOAD_TOKEN: ${{ secrets.TRANSFORMERS_CI_RESULTS_UPLOAD_TOKEN }} | ||||||
|           JOB_NAME: ${{ inputs.job }} |  | ||||||
|           REPORT_REPO_ID: ${{ inputs.report_repo_id }} |  | ||||||
|         run: | |         run: | | ||||||
|           python3 utils/process_bad_commit_report.py |           python3 utils/process_bad_commit_report.py | ||||||
| 
 | 
 | ||||||
|       - name: Process report |       - name: Process report | ||||||
|         shell: bash |         shell: bash | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
|         if: ${{ env.process == 'true' }} |  | ||||||
|         env: |         env: | ||||||
|           ACCESS_REPO_INFO_TOKEN: ${{ secrets.ACCESS_REPO_INFO_TOKEN }} |  | ||||||
|           TRANSFORMERS_CI_RESULTS_UPLOAD_TOKEN: ${{ secrets.TRANSFORMERS_CI_RESULTS_UPLOAD_TOKEN }} |           TRANSFORMERS_CI_RESULTS_UPLOAD_TOKEN: ${{ secrets.TRANSFORMERS_CI_RESULTS_UPLOAD_TOKEN }} | ||||||
|           JOB_NAME: ${{ inputs.job }} |  | ||||||
|           REPORT_REPO_ID: ${{ inputs.report_repo_id }} |  | ||||||
|         run: | |         run: | | ||||||
|           { |           { | ||||||
|             echo 'REPORT_TEXT<<EOF' |             echo 'REPORT_TEXT<<EOF' | ||||||
| @ -167,31 +105,17 @@ jobs: | |||||||
|             echo EOF |             echo EOF | ||||||
|           } >> "$GITHUB_ENV" |           } >> "$GITHUB_ENV" | ||||||
| 
 | 
 | ||||||
|       - name: Prepare Slack report title |  | ||||||
|         working-directory: /transformers |  | ||||||
|         if: ${{ env.process == 'true' }} |  | ||||||
|         run: | |  | ||||||
|           pip install slack_sdk |  | ||||||
|           echo "title=$(python3 -c 'import sys; sys.path.append("utils"); from utils.notification_service import job_to_test_map; ci_event = "${{ inputs.ci_event }}"; job = "${{ inputs.job }}"; test_name = job_to_test_map[job]; title = f"New failed tests of {ci_event}" + ":" + f" {test_name}"; print(title)')" >> $GITHUB_ENV |  | ||||||
| 
 |  | ||||||
|       - name: Send processed report |       - name: Send processed report | ||||||
|         if: ${{ env.process == 'true' && !endsWith(env.REPORT_TEXT, '{}') }} |         if: ${{ !endsWith(env.REPORT_TEXT, '{}') }} | ||||||
|         uses: slackapi/slack-github-action@6c661ce58804a1a20f6dc5fbee7f0381b469e001 |         uses: slackapi/slack-github-action@6c661ce58804a1a20f6dc5fbee7f0381b469e001 | ||||||
|         with: |         with: | ||||||
|           # Slack channel id, channel name, or user id to post message. |           # Slack channel id, channel name, or user id to post message. | ||||||
|           # See also: https://api.slack.com/methods/chat.postMessage#channels |           # See also: https://api.slack.com/methods/chat.postMessage#channels | ||||||
|           channel-id: '#${{ inputs.slack_report_channel }}' |           channel-id: '#transformers-ci-feedback-tests' | ||||||
|           # For posting a rich message using Block Kit |           # For posting a rich message using Block Kit | ||||||
|           payload: | |           payload: | | ||||||
|             { |             { | ||||||
|               "blocks": [ |               "blocks": [ | ||||||
|                 { |  | ||||||
|                   "type": "header", |  | ||||||
|                   "text": { |  | ||||||
|                     "type": "plain_text", |  | ||||||
|                     "text": "${{ env.title }}" |  | ||||||
|                   } |  | ||||||
|                 }, |  | ||||||
|                 { |                 { | ||||||
|                   "type": "section", |                   "type": "section", | ||||||
|                   "text": { |                   "text": { | ||||||
							
								
								
									
										2
									
								
								.github/workflows/doctest_job.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/doctest_job.yml
									
									
									
									
										vendored
									
									
								
							| @ -28,7 +28,7 @@ jobs: | |||||||
|       matrix: |       matrix: | ||||||
|         split_keys: ${{ fromJson(inputs.split_keys) }} |         split_keys: ${{ fromJson(inputs.split_keys) }} | ||||||
|     runs-on:  |     runs-on:  | ||||||
|       group: aws-g4dn-4xlarge-cache |       group: aws-g4dn-2xlarge-cache | ||||||
|     container: |     container: | ||||||
|       image: huggingface/transformers-all-latest-gpu |       image: huggingface/transformers-all-latest-gpu | ||||||
|       options: --gpus 0 --shm-size "16gb" --ipc host -v /mnt/cache/.cache/huggingface:/mnt/cache/ |       options: --gpus 0 --shm-size "16gb" --ipc host -v /mnt/cache/.cache/huggingface:/mnt/cache/ | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/workflows/doctests.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/doctests.yml
									
									
									
									
										vendored
									
									
								
							| @ -15,7 +15,7 @@ jobs: | |||||||
|   setup: |   setup: | ||||||
|     name: Setup |     name: Setup | ||||||
|     runs-on:  |     runs-on:  | ||||||
|       group: aws-g4dn-4xlarge-cache |       group: aws-g4dn-2xlarge-cache | ||||||
|     container: |     container: | ||||||
|       image: huggingface/transformers-all-latest-gpu |       image: huggingface/transformers-all-latest-gpu | ||||||
|       options: --gpus 0 --shm-size "16gb" --ipc host -v /mnt/cache/.cache/huggingface:/mnt/cache/ |       options: --gpus 0 --shm-size "16gb" --ipc host -v /mnt/cache/.cache/huggingface:/mnt/cache/ | ||||||
|  | |||||||
							
								
								
									
										23
									
								
								.github/workflows/model_jobs.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										23
									
								
								.github/workflows/model_jobs.yml
									
									
									
									
										vendored
									
									
								
							| @ -18,10 +18,6 @@ on: | |||||||
|       docker: |       docker: | ||||||
|         required: true |         required: true | ||||||
|         type: string |         type: string | ||||||
|       report_name_prefix: |  | ||||||
|         required: false |  | ||||||
|         default: run_models_gpu |  | ||||||
|         type: string |  | ||||||
|  |  | ||||||
| env: | env: | ||||||
|   HF_HOME: /mnt/cache |   HF_HOME: /mnt/cache | ||||||
| @ -34,6 +30,7 @@ env: | |||||||
|   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} |   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} | ||||||
|   SIGOPT_API_TOKEN: ${{ secrets.SIGOPT_API_TOKEN }} |   SIGOPT_API_TOKEN: ${{ secrets.SIGOPT_API_TOKEN }} | ||||||
|   TF_FORCE_GPU_ALLOW_GROWTH: true |   TF_FORCE_GPU_ALLOW_GROWTH: true | ||||||
|  |   RUN_PT_TF_CROSS_TESTS: 1 | ||||||
|   CUDA_VISIBLE_DEVICES: 0,1 |   CUDA_VISIBLE_DEVICES: 0,1 | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
| @ -107,7 +104,7 @@ jobs: | |||||||
|         run: | |         run: | | ||||||
|           echo "${{ inputs.machine_type }}" |           echo "${{ inputs.machine_type }}" | ||||||
|  |  | ||||||
|           if [ "${{ inputs.machine_type }}" = "aws-g4dn-4xlarge-cache" ]; then |           if [ "${{ inputs.machine_type }}" = "aws-g4dn-2xlarge-cache" ]; then | ||||||
|             machine_type=single-gpu |             machine_type=single-gpu | ||||||
|           elif [ "${{ inputs.machine_type }}" = "aws-g4dn-12xlarge-cache" ]; then |           elif [ "${{ inputs.machine_type }}" = "aws-g4dn-12xlarge-cache" ]; then | ||||||
|             machine_type=multi-gpu |             machine_type=multi-gpu | ||||||
| @ -120,23 +117,23 @@ jobs: | |||||||
|  |  | ||||||
|       - name: Run all tests on GPU |       - name: Run all tests on GPU | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
|         run: python3 -m pytest -rsfE -v --make-reports=${{ env.machine_type }}_${{ inputs.report_name_prefix }}_${{ matrix.folders }}_test_reports tests/${{ matrix.folders }} |         run: python3 -m pytest -rsfE -v --make-reports=${{ env.machine_type }}_run_models_gpu_${{ matrix.folders }}_test_reports tests/${{ matrix.folders }} | ||||||
|  |  | ||||||
|       - name: Failure short reports |       - name: Failure short reports | ||||||
|         if: ${{ failure() }} |         if: ${{ failure() }} | ||||||
|         continue-on-error: true |         continue-on-error: true | ||||||
|         run: cat /transformers/reports/${{ env.machine_type }}_${{ inputs.report_name_prefix }}_${{ matrix.folders }}_test_reports/failures_short.txt |         run: cat /transformers/reports/${{ env.machine_type }}_run_models_gpu_${{ matrix.folders }}_test_reports/failures_short.txt | ||||||
|  |  | ||||||
|       - name: Run test |       - name: Run test | ||||||
|         shell: bash |         shell: bash | ||||||
|         run: | |         run: | | ||||||
|           mkdir -p /transformers/reports/${{ env.machine_type }}_${{ inputs.report_name_prefix }}_${{ matrix.folders }}_test_reports |           mkdir -p /transformers/reports/${{ env.machine_type }}_run_models_gpu_${{ matrix.folders }}_test_reports | ||||||
|           echo "hello" > /transformers/reports/${{ env.machine_type }}_${{ inputs.report_name_prefix }}_${{ matrix.folders }}_test_reports/hello.txt |           echo "hello" > /transformers/reports/${{ env.machine_type }}_run_models_gpu_${{ matrix.folders }}_test_reports/hello.txt | ||||||
|           echo "${{ env.machine_type }}_${{ inputs.report_name_prefix }}_${{ matrix.folders }}_test_reports" |           echo "${{ env.machine_type }}_run_models_gpu_${{ matrix.folders }}_test_reports" | ||||||
|  |  | ||||||
|       - name: "Test suite reports artifacts: ${{ env.machine_type }}_${{ inputs.report_name_prefix }}_${{ env.matrix_folders }}_test_reports" |       - name: "Test suite reports artifacts: ${{ env.machine_type }}_run_models_gpu_${{ env.matrix_folders }}_test_reports" | ||||||
|         if: ${{ always() }} |         if: ${{ always() }} | ||||||
|         uses: actions/upload-artifact@v4 |         uses: actions/upload-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: ${{ env.machine_type }}_${{ inputs.report_name_prefix }}_${{ env.matrix_folders }}_test_reports |           name: ${{ env.machine_type }}_run_models_gpu_${{ env.matrix_folders }}_test_reports | ||||||
|           path: /transformers/reports/${{ env.machine_type }}_${{ inputs.report_name_prefix }}_${{ matrix.folders }}_test_reports |           path: /transformers/reports/${{ env.machine_type }}_run_models_gpu_${{ matrix.folders }}_test_reports | ||||||
|  | |||||||
							
								
								
									
										1
									
								
								.github/workflows/model_jobs_amd.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/workflows/model_jobs_amd.yml
									
									
									
									
										vendored
									
									
								
							| @ -30,6 +30,7 @@ env: | |||||||
|   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} |   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} | ||||||
|   SIGOPT_API_TOKEN: ${{ secrets.SIGOPT_API_TOKEN }} |   SIGOPT_API_TOKEN: ${{ secrets.SIGOPT_API_TOKEN }} | ||||||
|   TF_FORCE_GPU_ALLOW_GROWTH: true |   TF_FORCE_GPU_ALLOW_GROWTH: true | ||||||
|  |   RUN_PT_TF_CROSS_TESTS: 1 | ||||||
|   CUDA_VISIBLE_DEVICES: 0,1 |   CUDA_VISIBLE_DEVICES: 0,1 | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|  | |||||||
| @ -1,68 +0,0 @@ | |||||||
| # Used to notify core maintainers about new model PR being merged |  | ||||||
| name: New model PR merged notification |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   push: |  | ||||||
|     branches: |  | ||||||
|       - main |  | ||||||
|     paths: |  | ||||||
|       - 'src/transformers/models/*/modeling_*' |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   notify_new_model: |  | ||||||
|     name: Notify new model |  | ||||||
|     runs-on: ubuntu-22.04 |  | ||||||
|     steps: |  | ||||||
|       - uses: actions/checkout@v4 |  | ||||||
|         with: |  | ||||||
|           fetch-depth: 0 |  | ||||||
|       - name: Check new model |  | ||||||
|         shell: bash |  | ||||||
|         run: | |  | ||||||
|           python -m pip install gitpython |  | ||||||
|           python -c 'from utils.pr_slow_ci_models import get_new_model; new_model = get_new_model(diff_with_last_commit=True); print(new_model)' | tee output.txt |  | ||||||
|           echo "NEW_MODEL=$(tail -n 1 output.txt)" >> $GITHUB_ENV |  | ||||||
|           echo "COMMIT_SHA=$(git log -1 --format=%H)" >> $GITHUB_ENV |  | ||||||
|  |  | ||||||
|       - name: print commit sha |  | ||||||
|         if: ${{ env.NEW_MODEL != ''}} |  | ||||||
|         shell: bash |  | ||||||
|         run: | |  | ||||||
|           echo "$COMMIT_SHA" |  | ||||||
|  |  | ||||||
|       - name: print new model |  | ||||||
|         if: ${{ env.NEW_MODEL != ''}} |  | ||||||
|         shell: bash |  | ||||||
|         run: | |  | ||||||
|           echo "$NEW_MODEL" |  | ||||||
|  |  | ||||||
|       - name: Notify |  | ||||||
|         if: ${{ env.NEW_MODEL != ''}} |  | ||||||
|         uses: slackapi/slack-github-action@6c661ce58804a1a20f6dc5fbee7f0381b469e001 |  | ||||||
|         with: |  | ||||||
|           # Slack channel id, channel name, or user id to post message. |  | ||||||
|           # See also: https://api.slack.com/methods/chat.postMessage#channels |  | ||||||
|           channel-id: transformers-new-model-notification |  | ||||||
|           # For posting a rich message using Block Kit |  | ||||||
|           payload: | |  | ||||||
|             { |  | ||||||
|               "blocks": [ |  | ||||||
|                 { |  | ||||||
|                   "type": "header", |  | ||||||
|                   "text": { |  | ||||||
|                     "type": "plain_text", |  | ||||||
|                     "text": "New model!", |  | ||||||
|                     "emoji": true |  | ||||||
|                   } |  | ||||||
|                 }, |  | ||||||
|                 { |  | ||||||
|                   "type": "section", |  | ||||||
|                   "text": { |  | ||||||
|                     "type": "mrkdwn", |  | ||||||
|                     "text": "<https://github.com/huggingface/transformers/commit/${{ env.COMMIT_SHA }}|New model: ${{ env.NEW_MODEL }}> GH_ArthurZucker, GH_lysandrejik, GH_ydshieh\ncommit SHA: ${{ env.COMMIT_SHA }}" |  | ||||||
|                   } |  | ||||||
|                 } |  | ||||||
|               ] |  | ||||||
|             } |  | ||||||
|         env: |  | ||||||
|           SLACK_BOT_TOKEN: ${{ secrets.SLACK_CIFEEDBACK_BOT_TOKEN }} |  | ||||||
							
								
								
									
										18
									
								
								.github/workflows/pr-style-bot.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								.github/workflows/pr-style-bot.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,18 +0,0 @@ | |||||||
| # To run this bot, comment "@bot /style" on a PR |  | ||||||
| name: Style Bot |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   issue_comment: |  | ||||||
|     types: [created] |  | ||||||
|  |  | ||||||
| permissions: |  | ||||||
|   pull-requests: write |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   style: |  | ||||||
|     uses: huggingface/huggingface_hub/.github/workflows/style-bot-action.yml@main |  | ||||||
|     with: |  | ||||||
|       python_quality_dependencies: "[quality]" |  | ||||||
|       style_command_type: "default" |  | ||||||
|     secrets: |  | ||||||
|       bot_token: ${{ secrets.HF_STYLE_BOT_ACTION }} |  | ||||||
							
								
								
									
										45
									
								
								.github/workflows/push-important-models.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										45
									
								
								.github/workflows/push-important-models.yml
									
									
									
									
										vendored
									
									
								
							| @ -7,13 +7,14 @@ on: | |||||||
| env: | env: | ||||||
|   OUTPUT_SLACK_CHANNEL_ID: "C06L2SGMEEA" |   OUTPUT_SLACK_CHANNEL_ID: "C06L2SGMEEA" | ||||||
|   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} |   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} | ||||||
|   HF_HOME: /mnt/cache |   HF_HOME: /mnt/cache  | ||||||
|   TRANSFORMERS_IS_CI: yes |   TRANSFORMERS_IS_CI: yes  | ||||||
|   OMP_NUM_THREADS: 8 |   OMP_NUM_THREADS: 8  | ||||||
|   MKL_NUM_THREADS: 8 |   MKL_NUM_THREADS: 8  | ||||||
|   RUN_SLOW: yes # For gated repositories, we still need to agree to share information on the Hub repo. page in order to get access. # This token is created under the bot `hf-transformers-bot`. |   RUN_SLOW: yes # For gated repositories, we still need to agree to share information on the Hub repo. page in order to get access. # This token is created under the bot `hf-transformers-bot`.  | ||||||
|   SIGOPT_API_TOKEN: ${{ secrets.SIGOPT_API_TOKEN }} |   SIGOPT_API_TOKEN: ${{ secrets.SIGOPT_API_TOKEN }}  | ||||||
|   TF_FORCE_GPU_ALLOW_GROWTH: true |   TF_FORCE_GPU_ALLOW_GROWTH: true  | ||||||
|  |   RUN_PT_TF_CROSS_TESTS: 1 | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   get_modified_models: |   get_modified_models: | ||||||
| @ -24,13 +25,13 @@ jobs: | |||||||
|     steps: |     steps: | ||||||
|       - name: Check out code |       - name: Check out code | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v4 | ||||||
|  |        | ||||||
|       - name: Get changed files |       - name: Get changed files | ||||||
|         id: changed-files |         id: changed-files | ||||||
|         uses: tj-actions/changed-files@1c8e6069583811afb28f97afeaf8e7da80c6be5c |         uses: tj-actions/changed-files@3f54ebb830831fc121d3263c1857cfbdc310cdb9 #v42 | ||||||
|         with: |         with: | ||||||
|           files: src/transformers/models/** |           files: src/transformers/models/** | ||||||
|  |        | ||||||
|       - name: Run step if only the files listed above change |       - name: Run step if only the files listed above change | ||||||
|         if: steps.changed-files.outputs.any_changed == 'true' |         if: steps.changed-files.outputs.any_changed == 'true' | ||||||
|         id: set-matrix |         id: set-matrix | ||||||
| @ -59,41 +60,41 @@ jobs: | |||||||
|     if: ${{ needs.get_modified_models.outputs.matrix != '[]' && needs.get_modified_models.outputs.matrix != '' && fromJson(needs.get_modified_models.outputs.matrix)[0] != null }} |     if: ${{ needs.get_modified_models.outputs.matrix != '[]' && needs.get_modified_models.outputs.matrix != '' && fromJson(needs.get_modified_models.outputs.matrix)[0] != null }} | ||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix:  | ||||||
|         model-name: ${{ fromJson(needs.get_modified_models.outputs.matrix) }} |         model-name: ${{ fromJson(needs.get_modified_models.outputs.matrix) }} | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|       - name: Check out code |       - name: Check out code | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v4 | ||||||
|  |        | ||||||
|       - name: Install locally transformers & other libs |       - name: Install locally transformers & other libs | ||||||
|         run: | |         run: | | ||||||
|           apt install sudo |           apt install sudo | ||||||
|           sudo -H pip install --upgrade pip |           sudo -H pip install --upgrade pip | ||||||
|           sudo -H pip uninstall -y transformers |           sudo -H pip uninstall -y transformers  | ||||||
|           sudo -H pip install -U -e ".[testing]" |           sudo -H pip install -U -e ".[testing]"  | ||||||
|           MAX_JOBS=4 pip install flash-attn --no-build-isolation |           MAX_JOBS=4 pip install flash-attn --no-build-isolation | ||||||
|           pip install bitsandbytes |           pip install bitsandbytes | ||||||
|  |        | ||||||
|       - name: NVIDIA-SMI |       - name: NVIDIA-SMI | ||||||
|         run: | |         run: | | ||||||
|           nvidia-smi |           nvidia-smi | ||||||
|  |        | ||||||
|       - name: Show installed libraries and their versions |       - name: Show installed libraries and their versions | ||||||
|         run: pip freeze |         run: pip freeze | ||||||
|  |        | ||||||
|       - name: Run FA2 tests |       - name: Run FA2 tests | ||||||
|         id: run_fa2_tests |         id: run_fa2_tests | ||||||
|         run: |         run: | ||||||
|           pytest -rsfE -m "flash_attn_test" --make-reports=${{ matrix.model-name }}_fa2_tests/ tests/${{ matrix.model-name }}/test_modeling_* |           pytest -rsfE -m "flash_attn_test" --make-reports=${{ matrix.model-name }}_fa2_tests/ tests/${{ matrix.model-name }}/test_modeling_* | ||||||
|  |        | ||||||
|       - name: "Test suite reports artifacts: ${{ matrix.model-name }}_fa2_tests" |       - name: "Test suite reports artifacts: ${{ matrix.model-name }}_fa2_tests" | ||||||
|         if: ${{ always() }} |         if: ${{ always() }} | ||||||
|         uses: actions/upload-artifact@v4 |         uses: actions/upload-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: ${{ matrix.model-name }}_fa2_tests |           name: ${{ matrix.model-name }}_fa2_tests | ||||||
|           path: /transformers/reports/${{ matrix.model-name }}_fa2_tests |           path: /transformers/reports/${{ matrix.model-name }}_fa2_tests | ||||||
|  |        | ||||||
|       - name: Post to Slack |       - name: Post to Slack | ||||||
|         if: always() |         if: always() | ||||||
|         uses: huggingface/hf-workflows/.github/actions/post-slack@main |         uses: huggingface/hf-workflows/.github/actions/post-slack@main | ||||||
| @ -102,13 +103,13 @@ jobs: | |||||||
|           title: 🤗 Results of the FA2 tests - ${{ matrix.model-name }} |           title: 🤗 Results of the FA2 tests - ${{ matrix.model-name }} | ||||||
|           status: ${{ steps.run_fa2_tests.conclusion}} |           status: ${{ steps.run_fa2_tests.conclusion}} | ||||||
|           slack_token: ${{ secrets.CI_SLACK_BOT_TOKEN }} |           slack_token: ${{ secrets.CI_SLACK_BOT_TOKEN }} | ||||||
|  |        | ||||||
|       - name: Run integration tests |       - name: Run integration tests | ||||||
|         id: run_integration_tests |         id: run_integration_tests | ||||||
|         if: always() |         if: always() | ||||||
|         run: |         run: | ||||||
|           pytest -rsfE -k "IntegrationTest"  --make-reports=tests_integration_${{ matrix.model-name }} tests/${{ matrix.model-name }}/test_modeling_* |           pytest -rsfE -k "IntegrationTest"  --make-reports=tests_integration_${{ matrix.model-name }} tests/${{ matrix.model-name }}/test_modeling_* | ||||||
|  |        | ||||||
|       - name: "Test suite reports artifacts: tests_integration_${{ matrix.model-name }}" |       - name: "Test suite reports artifacts: tests_integration_${{ matrix.model-name }}" | ||||||
|         if: ${{ always() }} |         if: ${{ always() }} | ||||||
|         uses: actions/upload-artifact@v4 |         uses: actions/upload-artifact@v4 | ||||||
| @ -118,7 +119,7 @@ jobs: | |||||||
|  |  | ||||||
|       - name: Post to Slack |       - name: Post to Slack | ||||||
|         if: always() |         if: always() | ||||||
|         uses: huggingface/hf-workflows/.github/actions/post-slack@main |         uses: huggingface/hf-workflows/.github/actions/post-slack@main  | ||||||
|         with: |         with: | ||||||
|           slack_channel: ${{ env.OUTPUT_SLACK_CHANNEL_ID }} |           slack_channel: ${{ env.OUTPUT_SLACK_CHANNEL_ID }} | ||||||
|           title: 🤗 Results of the Integration tests - ${{ matrix.model-name }} |           title: 🤗 Results of the Integration tests - ${{ matrix.model-name }} | ||||||
|  | |||||||
							
								
								
									
										169
									
								
								.github/workflows/self-comment-ci.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										169
									
								
								.github/workflows/self-comment-ci.yml
									
									
									
									
										vendored
									
									
								
							| @ -22,6 +22,7 @@ env: | |||||||
|   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} |   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} | ||||||
|   SIGOPT_API_TOKEN: ${{ secrets.SIGOPT_API_TOKEN }} |   SIGOPT_API_TOKEN: ${{ secrets.SIGOPT_API_TOKEN }} | ||||||
|   TF_FORCE_GPU_ALLOW_GROWTH: true |   TF_FORCE_GPU_ALLOW_GROWTH: true | ||||||
|  |   RUN_PT_TF_CROSS_TESTS: 1 | ||||||
|   CUDA_VISIBLE_DEVICES: 0,1 |   CUDA_VISIBLE_DEVICES: 0,1 | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
| @ -29,7 +30,7 @@ jobs: | |||||||
|     runs-on: ubuntu-22.04 |     runs-on: ubuntu-22.04 | ||||||
|     name: Get PR number |     name: Get PR number | ||||||
|     # For security: only allow team members to run |     # For security: only allow team members to run | ||||||
|     if: ${{ github.event.issue.state == 'open' && contains(fromJSON('["ydshieh", "ArthurZucker", "zucchini-nlp", "qubvel", "molbap", "gante", "LysandreJik", "Cyrilvallez", "Rocketknight1", "SunMarc", "muellerzr", "eustlb", "MekkCyber", "manueldeprada", "vasqu"]'), github.actor) && (startsWith(github.event.comment.body, 'run-slow') || startsWith(github.event.comment.body, 'run slow') || startsWith(github.event.comment.body, 'run_slow')) }} |     if: ${{ github.event.issue.state == 'open' && contains(fromJSON('["ydshieh", "ArthurZucker", "zucchini-nlp", "qubvel", "molbap", "gante", "LysandreJik", "Cyrilvallez", "Rocketknight1"]'), github.actor) && (startsWith(github.event.comment.body, 'run-slow') || startsWith(github.event.comment.body, 'run slow') || startsWith(github.event.comment.body, 'run_slow')) }} | ||||||
|     outputs: |     outputs: | ||||||
|       PR_NUMBER: ${{ steps.set_pr_number.outputs.PR_NUMBER }} |       PR_NUMBER: ${{ steps.set_pr_number.outputs.PR_NUMBER }} | ||||||
|     steps: |     steps: | ||||||
| @ -97,7 +98,6 @@ jobs: | |||||||
|     if: ${{ needs.get-pr-number.outputs.PR_NUMBER != ''}} |     if: ${{ needs.get-pr-number.outputs.PR_NUMBER != ''}} | ||||||
|     outputs: |     outputs: | ||||||
|       models: ${{ steps.models_to_run.outputs.models }} |       models: ${{ steps.models_to_run.outputs.models }} | ||||||
|       quantizations: ${{ steps.models_to_run.outputs.quantizations }} |  | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|         with: |         with: | ||||||
| @ -121,8 +121,6 @@ jobs: | |||||||
|           python -m pip install GitPython |           python -m pip install GitPython | ||||||
|           python utils/pr_slow_ci_models.py --message "$PR_COMMENT" | tee output.txt |           python utils/pr_slow_ci_models.py --message "$PR_COMMENT" | tee output.txt | ||||||
|           echo "models=$(tail -n 1 output.txt)" >> $GITHUB_ENV |           echo "models=$(tail -n 1 output.txt)" >> $GITHUB_ENV | ||||||
|           python utils/pr_slow_ci_models.py --message "$PR_COMMENT" --quantization | tee output2.txt |  | ||||||
|           echo "quantizations=$(tail -n 1 output2.txt)" >> $GITHUB_ENV |  | ||||||
|  |  | ||||||
|       - name: Show models to test |       - name: Show models to test | ||||||
|         id: models_to_run |         id: models_to_run | ||||||
| @ -130,12 +128,10 @@ jobs: | |||||||
|           echo "${{ env.models }}" |           echo "${{ env.models }}" | ||||||
|           echo "models=${{ env.models }}" >> $GITHUB_ENV |           echo "models=${{ env.models }}" >> $GITHUB_ENV | ||||||
|           echo "models=${{ env.models }}" >> $GITHUB_OUTPUT |           echo "models=${{ env.models }}" >> $GITHUB_OUTPUT | ||||||
|           echo "${{ env.quantizations }}" |  | ||||||
|           echo "quantizations=${{ env.quantizations }}" >> $GITHUB_OUTPUT |  | ||||||
|  |  | ||||||
|   reply_to_comment: |   reply_to_comment: | ||||||
|     name: Reply to the comment |     name: Reply to the comment | ||||||
|     if: ${{ needs.get-tests.outputs.models != '[]'  || needs.get-tests.outputs.quantizations != '[]' }} |     if: ${{ needs.get-tests.outputs.models != '[]' }} | ||||||
|     needs: [get-pr-number, get-tests] |     needs: [get-pr-number, get-tests] | ||||||
|     permissions: |     permissions: | ||||||
|       pull-requests: write |       pull-requests: write | ||||||
| @ -145,18 +141,17 @@ jobs: | |||||||
|         env: |         env: | ||||||
|           GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} |           GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||||
|           MODELS: ${{ needs.get-tests.outputs.models }} |           MODELS: ${{ needs.get-tests.outputs.models }} | ||||||
|           BODY: "\n\nmodels: ${{ needs.get-tests.outputs.models }}\nquantizations: ${{ needs.get-tests.outputs.quantizations }}" |  | ||||||
|         run: | |         run: | | ||||||
|           gh api \ |           gh api \ | ||||||
|             --method POST \ |             --method POST \ | ||||||
|             -H "Accept: application/vnd.github+json" \ |             -H "Accept: application/vnd.github+json" \ | ||||||
|             -H "X-GitHub-Api-Version: 2022-11-28" \ |             -H "X-GitHub-Api-Version: 2022-11-28" \ | ||||||
|             repos/${{ github.repository }}/issues/${{ needs.get-pr-number.outputs.PR_NUMBER }}/comments \ |             repos/${{ github.repository }}/issues/${{ needs.get-pr-number.outputs.PR_NUMBER }}/comments \ | ||||||
|             -f "body=This comment contains run-slow, running the specified jobs: ${{ env.BODY }} ..." |             -f "body=This comment contains run-slow, running the specified jobs: ${{ env.MODELS }} ..." | ||||||
|  |  | ||||||
|   create_run: |   create_run: | ||||||
|     name: Create run |     name: Create run | ||||||
|     if: ${{ needs.get-tests.outputs.models != '[]' || needs.get-tests.outputs.quantizations != '[]' }} |     if: ${{ needs.get-tests.outputs.models != '[]' }} | ||||||
|     needs: [get-sha, get-tests, reply_to_comment] |     needs: [get-sha, get-tests, reply_to_comment] | ||||||
|     permissions: |     permissions: | ||||||
|       statuses: write |       statuses: write | ||||||
| @ -178,20 +173,20 @@ jobs: | |||||||
|             -f "target_url=$GITHUB_RUN_URL" -f "state=pending" -f "description=Slow CI job" -f "context=pytest/custom-tests" |             -f "target_url=$GITHUB_RUN_URL" -f "state=pending" -f "description=Slow CI job" -f "context=pytest/custom-tests" | ||||||
|  |  | ||||||
|   run_models_gpu: |   run_models_gpu: | ||||||
|     name: Run all tests for the model |       name: Run all tests for the model | ||||||
|     if: ${{ needs.get-tests.outputs.models != '[]' }} |       if: ${{ needs.get-tests.outputs.models != '[]' }} | ||||||
|     needs: [get-pr-number, get-sha, get-tests, create_run] |       needs: [get-pr-number, get-sha, get-tests, create_run] | ||||||
|     strategy: |       strategy: | ||||||
|       fail-fast: false |         fail-fast: false | ||||||
|       matrix: |         matrix: | ||||||
|         folders: ${{ fromJson(needs.get-tests.outputs.models) }} |           folders: ${{ fromJson(needs.get-tests.outputs.models) }} | ||||||
|         machine_type: [aws-g4dn-4xlarge-cache, aws-g4dn-12xlarge-cache] |           machine_type: [aws-g4dn-2xlarge-cache, aws-g4dn-12xlarge-cache] | ||||||
|     runs-on: |       runs-on: | ||||||
|        group: '${{ matrix.machine_type }}' |          group: '${{ matrix.machine_type }}' | ||||||
|     container: |       container: | ||||||
|       image: huggingface/transformers-all-latest-gpu |         image: huggingface/transformers-all-latest-gpu | ||||||
|       options: --gpus all --shm-size "16gb" --ipc host -v /mnt/cache/.cache/huggingface:/mnt/cache/ |         options: --gpus all --shm-size "16gb" --ipc host -v /mnt/cache/.cache/huggingface:/mnt/cache/ | ||||||
|     steps: |       steps: | ||||||
|       - name: Echo input and matrix info |       - name: Echo input and matrix info | ||||||
|         shell: bash |         shell: bash | ||||||
|         run: | |         run: | | ||||||
| @ -211,20 +206,20 @@ jobs: | |||||||
|       - name: Checkout to PR merge commit |       - name: Checkout to PR merge commit | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
|         run: | |         run: | | ||||||
|           git fetch origin refs/pull/${{ needs.get-pr-number.outputs.PR_NUMBER }}/merge:refs/remotes/pull/${{ needs.get-pr-number.outputs.PR_NUMBER }}/merge |             git fetch origin refs/pull/${{ needs.get-pr-number.outputs.PR_NUMBER }}/merge:refs/remotes/pull/${{ needs.get-pr-number.outputs.PR_NUMBER }}/merge | ||||||
|           git checkout refs/remotes/pull/${{ needs.get-pr-number.outputs.PR_NUMBER }}/merge |             git checkout refs/remotes/pull/${{ needs.get-pr-number.outputs.PR_NUMBER }}/merge | ||||||
|           git log -1 --format=%H |             git log -1 --format=%H | ||||||
|  |  | ||||||
|       - name: Verify merge commit SHA |       - name: Verify merge commit SHA | ||||||
|         env: |         env: | ||||||
|           VERIFIED_PR_MERGE_SHA: ${{ needs.get-sha.outputs.PR_MERGE_SHA }} |           VERIFIED_PR_MERGE_SHA: ${{ needs.get-sha.outputs.PR_MERGE_SHA }} | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
|         run: | |         run: | | ||||||
|           PR_MERGE_SHA=$(git log -1 --format=%H) |             PR_MERGE_SHA=$(git log -1 --format=%H) | ||||||
|           if [ $PR_MERGE_SHA != $VERIFIED_PR_MERGE_SHA ]; then |             if [ $PR_MERGE_SHA != $VERIFIED_PR_MERGE_SHA ]; then | ||||||
|             echo "The merged commit SHA is not the same as the verified one! Security issue detected, abort the workflow!"; |               echo "The merged commit SHA is not the same as the verified one! Security issue detected, abort the workflow!"; | ||||||
|             exit -1; |               exit -1; | ||||||
|           fi |             fi | ||||||
|  |  | ||||||
|       - name: Reinstall transformers in edit mode (remove the one installed during docker image build) |       - name: Reinstall transformers in edit mode (remove the one installed during docker image build) | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
| @ -239,7 +234,7 @@ jobs: | |||||||
|         shell: bash |         shell: bash | ||||||
|         run: | |         run: | | ||||||
|           echo "${{ matrix.machine_type }}" |           echo "${{ matrix.machine_type }}" | ||||||
|           if [ "${{ matrix.machine_type }}" = "aws-g4dn-4xlarge-cache" ]; then |           if [ "${{ matrix.machine_type }}" = "aws-g4dn-2xlarge-cache" ]; then | ||||||
|             machine_type=single-gpu |             machine_type=single-gpu | ||||||
|           elif [ "${{ matrix.machine_type }}" = "aws-g4dn-12xlarge-cache" ]; then |           elif [ "${{ matrix.machine_type }}" = "aws-g4dn-12xlarge-cache" ]; then | ||||||
|             machine_type=multi-gpu |             machine_type=multi-gpu | ||||||
| @ -284,106 +279,9 @@ jobs: | |||||||
|           name: ${{ env.machine_type }}_run_models_gpu_${{ env.matrix_folders }}_test_reports |           name: ${{ env.machine_type }}_run_models_gpu_${{ env.matrix_folders }}_test_reports | ||||||
|           path: /transformers/reports/${{ env.machine_type }}_run_models_gpu_${{ matrix.folders }}_test_reports |           path: /transformers/reports/${{ env.machine_type }}_run_models_gpu_${{ matrix.folders }}_test_reports | ||||||
|  |  | ||||||
|   run_quantization_torch_gpu: |  | ||||||
|     name: Run all tests for a quantization |  | ||||||
|     if: ${{ needs.get-tests.outputs.quantizations != '[]' }} |  | ||||||
|     needs: [get-pr-number, get-sha, get-tests, create_run] |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         folders: ${{ fromJson(needs.get-tests.outputs.quantizations) }} |  | ||||||
|         machine_type: [aws-g4dn-4xlarge-cache, aws-g4dn-12xlarge-cache] |  | ||||||
|     runs-on: |  | ||||||
|       group: '${{ matrix.machine_type }}' |  | ||||||
|     container: |  | ||||||
|       image: huggingface/transformers-quantization-latest-gpu |  | ||||||
|       options: --gpus all --shm-size "16gb" --ipc host -v /mnt/cache/.cache/huggingface:/mnt/cache/ |  | ||||||
|     steps: |  | ||||||
|       - name: Echo folder ${{ matrix.folders }} |  | ||||||
|         shell: bash |  | ||||||
|         run: | |  | ||||||
|           echo "${{ matrix.folders }}" |  | ||||||
|           matrix_folders=${{ matrix.folders }} |  | ||||||
|           matrix_folders=${matrix_folders/'quantization/'/'quantization_'} |  | ||||||
|           echo "$matrix_folders" |  | ||||||
|           echo "matrix_folders=$matrix_folders" >> $GITHUB_ENV |  | ||||||
|  |  | ||||||
|       - name: Checkout to PR merge commit |  | ||||||
|         working-directory: /transformers |  | ||||||
|         run: | |  | ||||||
|           git fetch origin refs/pull/${{ needs.get-pr-number.outputs.PR_NUMBER }}/merge:refs/remotes/pull/${{ needs.get-pr-number.outputs.PR_NUMBER }}/merge |  | ||||||
|           git checkout refs/remotes/pull/${{ needs.get-pr-number.outputs.PR_NUMBER }}/merge |  | ||||||
|           git log -1 --format=%H |  | ||||||
|  |  | ||||||
|       - name: Verify merge commit SHA |  | ||||||
|         env: |  | ||||||
|           VERIFIED_PR_MERGE_SHA: ${{ needs.get-sha.outputs.PR_MERGE_SHA }} |  | ||||||
|         working-directory: /transformers |  | ||||||
|         run: | |  | ||||||
|           PR_MERGE_SHA=$(git log -1 --format=%H) |  | ||||||
|           if [ $PR_MERGE_SHA != $VERIFIED_PR_MERGE_SHA ]; then |  | ||||||
|             echo "The merged commit SHA is not the same as the verified one! Security issue detected, abort the workflow!"; |  | ||||||
|             exit -1; |  | ||||||
|           fi |  | ||||||
|  |  | ||||||
|       - name: Reinstall transformers in edit mode (remove the one installed during docker image build) |  | ||||||
|         working-directory: /transformers |  | ||||||
|         run: python3 -m pip uninstall -y transformers && python3 -m pip install -e . |  | ||||||
|       - name: NVIDIA-SMI |  | ||||||
|         run: | |  | ||||||
|           nvidia-smi |  | ||||||
|  |  | ||||||
|       - name: Set `machine_type` for report and artifact names |  | ||||||
|         working-directory: /transformers |  | ||||||
|         shell: bash |  | ||||||
|         run: | |  | ||||||
|           echo "${{ matrix.machine_type }}" |  | ||||||
|           if [ "${{ matrix.machine_type }}" = "aws-g4dn-4xlarge-cache" ]; then |  | ||||||
|             machine_type=single-gpu |  | ||||||
|           elif [ "${{ matrix.machine_type }}" = "aws-g4dn-12xlarge-cache" ]; then |  | ||||||
|             machine_type=multi-gpu |  | ||||||
|           else |  | ||||||
|             machine_type=${{ matrix.machine_type }} |  | ||||||
|           fi |  | ||||||
|           echo "$machine_type" |  | ||||||
|           echo "machine_type=$machine_type" >> $GITHUB_ENV |  | ||||||
|  |  | ||||||
|       - name: Environment |  | ||||||
|         working-directory: /transformers |  | ||||||
|         run: | |  | ||||||
|           python3 utils/print_env.py |  | ||||||
|  |  | ||||||
|       - name: Show installed libraries and their versions |  | ||||||
|         working-directory: /transformers |  | ||||||
|         run: pip freeze |  | ||||||
|  |  | ||||||
|       - name: Run quantization tests on GPU |  | ||||||
|         working-directory: /transformers |  | ||||||
|         run: | |  | ||||||
|           python3 -m pytest -v --make-reports=${{ env.machine_type }}_run_quantization_torch_gpu_${{ matrix.folders }}_test_reports tests/${{ matrix.folders }} |  | ||||||
|  |  | ||||||
|       - name: Failure short reports |  | ||||||
|         if: ${{ failure() }} |  | ||||||
|         continue-on-error: true |  | ||||||
|         run: cat /transformers/reports/${{ env.machine_type }}_run_quantization_torch_gpu_${{ matrix.folders }}_test_reports/failures_short.txt |  | ||||||
|  |  | ||||||
|       - name: Make sure report directory exists |  | ||||||
|         shell: bash |  | ||||||
|         run: | |  | ||||||
|           mkdir -p /transformers/reports/${{ env.machine_type }}_run_quantization_gpu_${{ matrix.folders }}_test_reports |  | ||||||
|           echo "hello" > /transformers/reports/${{ env.machine_type }}_run_quantization_gpu_${{ matrix.folders }}_test_reports/hello.txt |  | ||||||
|           echo "${{ env.machine_type }}_run_quantization_gpu_${{ matrix.folders }}_test_reports" |  | ||||||
|  |  | ||||||
|       - name: "Test suite reports artifacts: ${{ env.machine_type }}_run_quantization_torch_gpu_${{ env.matrix_folders }}_test_reports" |  | ||||||
|         if: ${{ always() }} |  | ||||||
|         uses: actions/upload-artifact@v4 |  | ||||||
|         with: |  | ||||||
|           name: ${{ env.machine_type }}_run_quantization_torch_gpu_${{ env.matrix_folders }}_test_reports |  | ||||||
|           path: /transformers/reports/${{ env.machine_type }}_run_quantization_torch_gpu_${{ matrix.folders }}_test_reports |  | ||||||
|  |  | ||||||
|   update_run_status: |   update_run_status: | ||||||
|     name: Update Check Run Status |     name: Update Check Run Status | ||||||
|     needs: [get-sha, create_run, run_models_gpu, run_quantization_torch_gpu] |     needs: [get-sha, create_run, run_models_gpu] | ||||||
|     permissions: |     permissions: | ||||||
|       statuses: write |       statuses: write | ||||||
|     if: ${{ always() && needs.create_run.result == 'success' }} |     if: ${{ always() && needs.create_run.result == 'success' }} | ||||||
| @ -391,17 +289,16 @@ jobs: | |||||||
|     env: |     env: | ||||||
|       GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} |       GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||||
|       GITHUB_RUN_URL: https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }} |       GITHUB_RUN_URL: https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }} | ||||||
|       STATUS_OK: ${{ contains(fromJSON('["skipped", "success"]'), needs.run_models_gpu.result) && contains(fromJSON('["skipped", "success"]'), needs.run_quantization_torch_gpu.result) }} |  | ||||||
|     steps: |     steps: | ||||||
|       - name: Get `run_models_gpu` job status |       - name: Get `run_models_gpu` job status | ||||||
|         run: | |         run: | | ||||||
|           echo "${{ needs.run_models_gpu.result }}" |           echo "${{ needs.run_models_gpu.result }}" | ||||||
|           echo "${{ needs.run_quantization_torch_gpu.result }}" |           if [ "${{ needs.run_models_gpu.result }}" = "cancelled" ]; then | ||||||
|           echo $STATUS_OK |             echo "STATUS=failure" >> $GITHUB_ENV | ||||||
|           if [ "$STATUS_OK" = "true" ]; then |           elif [ "${{ needs.run_models_gpu.result }}" = "skipped" ]; then | ||||||
|             echo "STATUS=success" >> $GITHUB_ENV |             echo "STATUS=success" >> $GITHUB_ENV | ||||||
|           else |           else | ||||||
|             echo "STATUS=failure" >> $GITHUB_ENV |             echo "STATUS=${{ needs.run_models_gpu.result }}" >> $GITHUB_ENV | ||||||
|           fi |           fi | ||||||
|  |  | ||||||
|       - name: Update PR commit statuses |       - name: Update PR commit statuses | ||||||
|  | |||||||
							
								
								
									
										1
									
								
								.github/workflows/self-push-amd.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/workflows/self-push-amd.yml
									
									
									
									
										vendored
									
									
								
							| @ -14,6 +14,7 @@ env: | |||||||
|   MKL_NUM_THREADS: 8 |   MKL_NUM_THREADS: 8 | ||||||
|   PYTEST_TIMEOUT: 60 |   PYTEST_TIMEOUT: 60 | ||||||
|   TF_FORCE_GPU_ALLOW_GROWTH: true |   TF_FORCE_GPU_ALLOW_GROWTH: true | ||||||
|  |   RUN_PT_TF_CROSS_TESTS: 1 | ||||||
|   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} |   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								.github/workflows/self-push-caller.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/self-push-caller.yml
									
									
									
									
										vendored
									
									
								
							| @ -25,7 +25,7 @@ jobs: | |||||||
|          |          | ||||||
|         - name: Get changed files |         - name: Get changed files | ||||||
|           id: changed-files |           id: changed-files | ||||||
|           uses: tj-actions/changed-files@1c8e6069583811afb28f97afeaf8e7da80c6be5c |           uses: tj-actions/changed-files@v41 | ||||||
|          |          | ||||||
|         - name: Was setup changed  |         - name: Was setup changed  | ||||||
|           id: was_changed |           id: was_changed | ||||||
| @ -51,4 +51,4 @@ jobs: | |||||||
|     needs: build-docker-containers |     needs: build-docker-containers | ||||||
|     steps: |     steps: | ||||||
|       - name: Trigger push CI via workflow_run |       - name: Trigger push CI via workflow_run | ||||||
|         run: echo "Trigger push CI via workflow_run" |         run: echo "Trigger push CI via workflow_run" | ||||||
							
								
								
									
										9
									
								
								.github/workflows/self-push.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								.github/workflows/self-push.yml
									
									
									
									
										vendored
									
									
								
							| @ -24,6 +24,7 @@ env: | |||||||
|   MKL_NUM_THREADS: 8 |   MKL_NUM_THREADS: 8 | ||||||
|   PYTEST_TIMEOUT: 60 |   PYTEST_TIMEOUT: 60 | ||||||
|   TF_FORCE_GPU_ALLOW_GROWTH: true |   TF_FORCE_GPU_ALLOW_GROWTH: true | ||||||
|  |   RUN_PT_TF_CROSS_TESTS: 1 | ||||||
|   CUDA_VISIBLE_DEVICES: 0,1 |   CUDA_VISIBLE_DEVICES: 0,1 | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
| @ -292,7 +293,7 @@ jobs: | |||||||
|  |  | ||||||
|           echo "$machine_type" |           echo "$machine_type" | ||||||
|           echo "machine_type=$machine_type" >> $GITHUB_ENV |           echo "machine_type=$machine_type" >> $GITHUB_ENV | ||||||
|  |            | ||||||
|       - name: Update clone using environment variables |       - name: Update clone using environment variables | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
|         run: | |         run: | | ||||||
| @ -405,7 +406,7 @@ jobs: | |||||||
|  |  | ||||||
|           echo "$machine_type" |           echo "$machine_type" | ||||||
|           echo "machine_type=$machine_type" >> $GITHUB_ENV |           echo "machine_type=$machine_type" >> $GITHUB_ENV | ||||||
|  |            | ||||||
|       - name: Update clone using environment variables |       - name: Update clone using environment variables | ||||||
|         working-directory: /workspace/transformers |         working-directory: /workspace/transformers | ||||||
|         run: | |         run: | | ||||||
| @ -515,7 +516,7 @@ jobs: | |||||||
|  |  | ||||||
|           echo "$machine_type" |           echo "$machine_type" | ||||||
|           echo "machine_type=$machine_type" >> $GITHUB_ENV |           echo "machine_type=$machine_type" >> $GITHUB_ENV | ||||||
|  |            | ||||||
|       - name: Update clone using environment variables |       - name: Update clone using environment variables | ||||||
|         working-directory: /workspace/transformers |         working-directory: /workspace/transformers | ||||||
|         run: | |         run: | | ||||||
| @ -647,6 +648,6 @@ jobs: | |||||||
|         # `models/bert` to `models_bert` is required, as the artifact names use `_` instead of `/`. |         # `models/bert` to `models_bert` is required, as the artifact names use `_` instead of `/`. | ||||||
|         run: | |         run: | | ||||||
|           pip install huggingface_hub |           pip install huggingface_hub | ||||||
|           pip install slack_sdk |           pip install slack_sdk  | ||||||
|           pip show slack_sdk |           pip show slack_sdk | ||||||
|           python utils/notification_service.py "${{ needs.setup.outputs.matrix }}" |           python utils/notification_service.py "${{ needs.setup.outputs.matrix }}" | ||||||
|  | |||||||
							
								
								
									
										55
									
								
								.github/workflows/self-scheduled-amd-mi210-caller.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								.github/workflows/self-scheduled-amd-mi210-caller.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,55 @@ | |||||||
|  | name: Self-hosted runner (AMD mi210 scheduled CI caller) | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   workflow_run: | ||||||
|  |     workflows: ["Self-hosted runner (AMD scheduled CI caller)"] | ||||||
|  |     branches: ["main"] | ||||||
|  |     types: [completed] | ||||||
|  |   push: | ||||||
|  |     branches: | ||||||
|  |       - run_amd_scheduled_ci_caller* | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   model-ci: | ||||||
|  |     name: Model CI | ||||||
|  |     uses: huggingface/hf-workflows/.github/workflows/transformers_amd_ci_scheduled.yaml@main | ||||||
|  |     with: | ||||||
|  |       job: run_models_gpu | ||||||
|  |       slack_report_channel: "#transformers-ci-daily-amd" | ||||||
|  |       runner: mi210 | ||||||
|  |       docker: huggingface/transformers-pytorch-amd-gpu | ||||||
|  |       ci_event: Scheduled CI (AMD) - mi210 | ||||||
|  |     secrets: inherit | ||||||
|  |  | ||||||
|  |   torch-pipeline: | ||||||
|  |     name: Torch pipeline CI | ||||||
|  |     uses: huggingface/hf-workflows/.github/workflows/transformers_amd_ci_scheduled.yaml@main | ||||||
|  |     with: | ||||||
|  |       job: run_pipelines_torch_gpu | ||||||
|  |       slack_report_channel: "#transformers-ci-daily-amd" | ||||||
|  |       runner: mi210 | ||||||
|  |       docker: huggingface/transformers-pytorch-amd-gpu | ||||||
|  |       ci_event: Scheduled CI (AMD) - mi210 | ||||||
|  |     secrets: inherit | ||||||
|  |  | ||||||
|  |   example-ci: | ||||||
|  |     name: Example CI | ||||||
|  |     uses: huggingface/hf-workflows/.github/workflows/transformers_amd_ci_scheduled.yaml@main | ||||||
|  |     with: | ||||||
|  |       job: run_examples_gpu | ||||||
|  |       slack_report_channel: "#transformers-ci-daily-amd" | ||||||
|  |       runner: mi210 | ||||||
|  |       docker: huggingface/transformers-pytorch-amd-gpu | ||||||
|  |       ci_event: Scheduled CI (AMD) - mi210 | ||||||
|  |     secrets: inherit | ||||||
|  |  | ||||||
|  |   deepspeed-ci: | ||||||
|  |     name: DeepSpeed CI | ||||||
|  |     uses: huggingface/hf-workflows/.github/workflows/transformers_amd_ci_scheduled.yaml@main | ||||||
|  |     with: | ||||||
|  |       job: run_torch_cuda_extensions_gpu | ||||||
|  |       slack_report_channel: "#transformers-ci-daily-amd" | ||||||
|  |       runner: mi210 | ||||||
|  |       docker: huggingface/transformers-pytorch-deepspeed-amd-gpu | ||||||
|  |       ci_event: Scheduled CI (AMD) - mi210 | ||||||
|  |     secrets: inherit | ||||||
| @ -19,7 +19,6 @@ jobs: | |||||||
|       runner: mi250 |       runner: mi250 | ||||||
|       docker: huggingface/transformers-pytorch-amd-gpu |       docker: huggingface/transformers-pytorch-amd-gpu | ||||||
|       ci_event: Scheduled CI (AMD) - mi250 |       ci_event: Scheduled CI (AMD) - mi250 | ||||||
|       report_repo_id: optimum-amd/transformers_daily_ci |  | ||||||
|     secrets: inherit |     secrets: inherit | ||||||
|  |  | ||||||
|   torch-pipeline: |   torch-pipeline: | ||||||
| @ -31,7 +30,6 @@ jobs: | |||||||
|       runner: mi250 |       runner: mi250 | ||||||
|       docker: huggingface/transformers-pytorch-amd-gpu |       docker: huggingface/transformers-pytorch-amd-gpu | ||||||
|       ci_event: Scheduled CI (AMD) - mi250 |       ci_event: Scheduled CI (AMD) - mi250 | ||||||
|       report_repo_id: optimum-amd/transformers_daily_ci |  | ||||||
|     secrets: inherit |     secrets: inherit | ||||||
|  |  | ||||||
|   example-ci: |   example-ci: | ||||||
| @ -43,7 +41,6 @@ jobs: | |||||||
|       runner: mi250 |       runner: mi250 | ||||||
|       docker: huggingface/transformers-pytorch-amd-gpu |       docker: huggingface/transformers-pytorch-amd-gpu | ||||||
|       ci_event: Scheduled CI (AMD) - mi250 |       ci_event: Scheduled CI (AMD) - mi250 | ||||||
|       report_repo_id: optimum-amd/transformers_daily_ci |  | ||||||
|     secrets: inherit |     secrets: inherit | ||||||
|  |  | ||||||
|   deepspeed-ci: |   deepspeed-ci: | ||||||
| @ -55,5 +52,4 @@ jobs: | |||||||
|       runner: mi250 |       runner: mi250 | ||||||
|       docker: huggingface/transformers-pytorch-deepspeed-amd-gpu |       docker: huggingface/transformers-pytorch-deepspeed-amd-gpu | ||||||
|       ci_event: Scheduled CI (AMD) - mi250 |       ci_event: Scheduled CI (AMD) - mi250 | ||||||
|       report_repo_id: optimum-amd/transformers_daily_ci |  | ||||||
|     secrets: inherit |     secrets: inherit | ||||||
|  | |||||||
| @ -1,63 +0,0 @@ | |||||||
| name: Self-hosted runner scale set (AMD mi300 scheduled CI caller) |  | ||||||
|  |  | ||||||
| # Note: For every job in this workflow, the name of the runner scale set is finalized in the runner yaml i.e. huggingface/hf-workflows/.github/workflows/transformers_amd_ci_scheduled_arc_scale_set.yaml |  | ||||||
| # For example, 1gpu scale set: amd-mi300-ci-1gpu |  | ||||||
| #              2gpu scale set: amd-mi300-ci-2gpu |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   workflow_run: |  | ||||||
|     workflows: ["Self-hosted runner (AMD scheduled CI caller)"] |  | ||||||
|     branches: ["main"] |  | ||||||
|     types: [completed] |  | ||||||
|   push: |  | ||||||
|     branches: |  | ||||||
|       - run_amd_scheduled_ci_caller* |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   model-ci: |  | ||||||
|     name: Model CI |  | ||||||
|     uses: huggingface/hf-workflows/.github/workflows/transformers_amd_ci_scheduled_arc_scale_set.yaml@main |  | ||||||
|     with: |  | ||||||
|       job: run_models_gpu |  | ||||||
|       slack_report_channel: "#amd-hf-ci" |  | ||||||
|       runner_scale_set: amd-mi300-ci |  | ||||||
|       docker: huggingface/transformers-pytorch-amd-gpu |  | ||||||
|       ci_event: Scheduled CI (AMD) - mi300 |  | ||||||
|       report_repo_id: optimum-amd/transformers_daily_ci |  | ||||||
|     secrets: inherit |  | ||||||
|  |  | ||||||
|   torch-pipeline: |  | ||||||
|     name: Torch pipeline CI |  | ||||||
|     uses: huggingface/hf-workflows/.github/workflows/transformers_amd_ci_scheduled_arc_scale_set.yaml@main |  | ||||||
|     with: |  | ||||||
|       job: run_pipelines_torch_gpu |  | ||||||
|       slack_report_channel: "#amd-hf-ci" |  | ||||||
|       runner_scale_set: amd-mi300-ci |  | ||||||
|       docker: huggingface/transformers-pytorch-amd-gpu |  | ||||||
|       ci_event: Scheduled CI (AMD) - mi300 |  | ||||||
|       report_repo_id: optimum-amd/transformers_daily_ci |  | ||||||
|     secrets: inherit |  | ||||||
|  |  | ||||||
|   example-ci: |  | ||||||
|     name: Example CI |  | ||||||
|     uses: huggingface/hf-workflows/.github/workflows/transformers_amd_ci_scheduled_arc_scale_set.yaml@main |  | ||||||
|     with: |  | ||||||
|       job: run_examples_gpu |  | ||||||
|       slack_report_channel: "#amd-hf-ci" |  | ||||||
|       runner_scale_set: amd-mi300-ci |  | ||||||
|       docker: huggingface/transformers-pytorch-amd-gpu |  | ||||||
|       ci_event: Scheduled CI (AMD) - mi300 |  | ||||||
|       report_repo_id: optimum-amd/transformers_daily_ci |  | ||||||
|     secrets: inherit |  | ||||||
|  |  | ||||||
|   deepspeed-ci: |  | ||||||
|     name: DeepSpeed CI |  | ||||||
|     uses: huggingface/hf-workflows/.github/workflows/transformers_amd_ci_scheduled_arc_scale_set.yaml@main |  | ||||||
|     with: |  | ||||||
|       job: run_torch_cuda_extensions_gpu |  | ||||||
|       slack_report_channel: "#amd-hf-ci" |  | ||||||
|       runner_scale_set: amd-mi300-ci |  | ||||||
|       docker: huggingface/transformers-pytorch-deepspeed-amd-gpu |  | ||||||
|       ci_event: Scheduled CI (AMD) - mi300 |  | ||||||
|       report_repo_id: optimum-amd/transformers_daily_ci |  | ||||||
|     secrets: inherit |  | ||||||
							
								
								
									
										94
									
								
								.github/workflows/self-scheduled-caller.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										94
									
								
								.github/workflows/self-scheduled-caller.yml
									
									
									
									
										vendored
									
									
								
							| @ -7,44 +7,9 @@ on: | |||||||
|     - cron: "17 2 * * *" |     - cron: "17 2 * * *" | ||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
|       - trigger-remove-script-datasets-in-tests |       - run_scheduled_ci* | ||||||
|   workflow_dispatch: |  | ||||||
|     inputs: |  | ||||||
|       prev_workflow_run_id: |  | ||||||
|         description: 'previous workflow run id to compare' |  | ||||||
|         type: string |  | ||||||
|         required: false |  | ||||||
|         default: "" |  | ||||||
|       other_workflow_run_id: |  | ||||||
|         description: 'other workflow run id to compare' |  | ||||||
|         type: string |  | ||||||
|         required: false |  | ||||||
|         default: "" |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # Used for `push` to easily modiffy the target workflow runs to compare against |  | ||||||
| env: |  | ||||||
|     prev_workflow_run_id: "" |  | ||||||
|     other_workflow_run_id: "15770139098" |  | ||||||
|  |  | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   setup: |  | ||||||
|     name: Setup |  | ||||||
|     runs-on: ubuntu-22.04 |  | ||||||
|     steps: |  | ||||||
|       - name: Setup |  | ||||||
|         run: | |  | ||||||
|           mkdir "setup_values" |  | ||||||
|           echo "${{ inputs.prev_workflow_run_id || env.prev_workflow_run_id }}" > "setup_values/prev_workflow_run_id.txt" |  | ||||||
|           echo "${{ inputs.other_workflow_run_id || env.other_workflow_run_id }}" > "setup_values/other_workflow_run_id.txt" |  | ||||||
|  |  | ||||||
|       - name: Upload artifacts |  | ||||||
|         uses: actions/upload-artifact@v4 |  | ||||||
|         with: |  | ||||||
|           name: setup_values |  | ||||||
|           path: setup_values |  | ||||||
|  |  | ||||||
|   model-ci: |   model-ci: | ||||||
|     name: Model CI |     name: Model CI | ||||||
|     uses: ./.github/workflows/self-scheduled.yml |     uses: ./.github/workflows/self-scheduled.yml | ||||||
| @ -54,5 +19,60 @@ jobs: | |||||||
|       runner: daily-ci |       runner: daily-ci | ||||||
|       docker: huggingface/transformers-all-latest-gpu |       docker: huggingface/transformers-all-latest-gpu | ||||||
|       ci_event: Daily CI |       ci_event: Daily CI | ||||||
|       report_repo_id: hf-internal-testing/transformers_daily_ci |     secrets: inherit | ||||||
|  |  | ||||||
|  |   torch-pipeline: | ||||||
|  |     name: Torch pipeline CI | ||||||
|  |     uses: ./.github/workflows/self-scheduled.yml | ||||||
|  |     with: | ||||||
|  |       job: run_pipelines_torch_gpu | ||||||
|  |       slack_report_channel: "#transformers-ci-daily-pipeline-torch" | ||||||
|  |       runner: daily-ci | ||||||
|  |       docker: huggingface/transformers-pytorch-gpu | ||||||
|  |       ci_event: Daily CI | ||||||
|  |     secrets: inherit | ||||||
|  |  | ||||||
|  |   tf-pipeline: | ||||||
|  |     name: TF pipeline CI | ||||||
|  |     uses: ./.github/workflows/self-scheduled.yml | ||||||
|  |     with: | ||||||
|  |       job: run_pipelines_tf_gpu | ||||||
|  |       slack_report_channel: "#transformers-ci-daily-pipeline-tf" | ||||||
|  |       runner: daily-ci | ||||||
|  |       docker: huggingface/transformers-tensorflow-gpu | ||||||
|  |       ci_event: Daily CI | ||||||
|  |     secrets: inherit | ||||||
|  |  | ||||||
|  |   example-ci: | ||||||
|  |     name: Example CI | ||||||
|  |     uses: ./.github/workflows/self-scheduled.yml | ||||||
|  |     with: | ||||||
|  |       job: run_examples_gpu | ||||||
|  |       slack_report_channel: "#transformers-ci-daily-examples" | ||||||
|  |       runner: daily-ci | ||||||
|  |       docker: huggingface/transformers-all-latest-gpu | ||||||
|  |       ci_event: Daily CI | ||||||
|  |     secrets: inherit | ||||||
|  |  | ||||||
|  |   deepspeed-ci: | ||||||
|  |     name: DeepSpeed CI | ||||||
|  |     uses: ./.github/workflows/self-scheduled.yml | ||||||
|  |     with: | ||||||
|  |       job: run_torch_cuda_extensions_gpu | ||||||
|  |       slack_report_channel: "#transformers-ci-daily-deepspeed" | ||||||
|  |       runner: daily-ci | ||||||
|  |       docker: huggingface/transformers-pytorch-deepspeed-latest-gpu | ||||||
|  |       ci_event: Daily CI | ||||||
|  |       working-directory-prefix: /workspace | ||||||
|  |     secrets: inherit | ||||||
|  |  | ||||||
|  |   quantization-ci: | ||||||
|  |     name: Quantization CI | ||||||
|  |     uses: ./.github/workflows/self-scheduled.yml | ||||||
|  |     with: | ||||||
|  |       job: run_quantization_torch_gpu | ||||||
|  |       slack_report_channel: "#transformers-ci-daily-quantization" | ||||||
|  |       runner: daily-ci | ||||||
|  |       docker: huggingface/transformers-quantization-latest-gpu | ||||||
|  |       ci_event: Daily CI | ||||||
|     secrets: inherit |     secrets: inherit | ||||||
|  | |||||||
							
								
								
									
										148
									
								
								.github/workflows/self-scheduled.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										148
									
								
								.github/workflows/self-scheduled.yml
									
									
									
									
										vendored
									
									
								
							| @ -28,10 +28,6 @@ on: | |||||||
|         default: '' |         default: '' | ||||||
|         required: false |         required: false | ||||||
|         type: string |         type: string | ||||||
|       report_repo_id: |  | ||||||
|         required: true |  | ||||||
|         type: string |  | ||||||
|  |  | ||||||
|  |  | ||||||
| env: | env: | ||||||
|   HF_HOME: /mnt/cache |   HF_HOME: /mnt/cache | ||||||
| @ -44,16 +40,17 @@ env: | |||||||
|   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} |   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} | ||||||
|   SIGOPT_API_TOKEN: ${{ secrets.SIGOPT_API_TOKEN }} |   SIGOPT_API_TOKEN: ${{ secrets.SIGOPT_API_TOKEN }} | ||||||
|   TF_FORCE_GPU_ALLOW_GROWTH: true |   TF_FORCE_GPU_ALLOW_GROWTH: true | ||||||
|  |   RUN_PT_TF_CROSS_TESTS: 1 | ||||||
|   CUDA_VISIBLE_DEVICES: 0,1 |   CUDA_VISIBLE_DEVICES: 0,1 | ||||||
|   NUM_SLICES: 2 |   NUM_SLICES: 2 | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   setup: |   setup: | ||||||
|     if: contains(fromJSON('["run_models_gpu", "run_trainer_and_fsdp_gpu", "run_quantization_torch_gpu"]'), inputs.job) |     if: contains(fromJSON('["run_models_gpu", "run_quantization_torch_gpu"]'), inputs.job) | ||||||
|     name: Setup |     name: Setup | ||||||
|     strategy: |     strategy: | ||||||
|       matrix: |       matrix: | ||||||
|         machine_type: [aws-g4dn-4xlarge-cache, aws-g4dn-12xlarge-cache] |         machine_type: [aws-g4dn-2xlarge-cache, aws-g4dn-12xlarge-cache] | ||||||
|     runs-on: |     runs-on: | ||||||
|       group: '${{ matrix.machine_type }}' |       group: '${{ matrix.machine_type }}' | ||||||
|     container: |     container: | ||||||
| @ -81,17 +78,12 @@ jobs: | |||||||
|         run: pip freeze |         run: pip freeze | ||||||
|  |  | ||||||
|       - id: set-matrix |       - id: set-matrix | ||||||
|         if: contains(fromJSON('["run_models_gpu", "run_trainer_and_fsdp_gpu"]'), inputs.job) |         if: ${{ inputs.job == 'run_models_gpu' }} | ||||||
|         name: Identify models to test |         name: Identify models to test | ||||||
|         working-directory: /transformers/tests |         working-directory: /transformers/tests | ||||||
|         run: | |         run: | | ||||||
|           if [ "${{ inputs.job }}" = "run_models_gpu" ]; then |           echo "folder_slices=$(python3 ../utils/split_model_tests.py --num_splits ${{ env.NUM_SLICES }})" >> $GITHUB_OUTPUT | ||||||
|             echo "folder_slices=$(python3 ../utils/split_model_tests.py --num_splits ${{ env.NUM_SLICES }})" >> $GITHUB_OUTPUT |           echo "slice_ids=$(python3 -c 'd = list(range(${{ env.NUM_SLICES }})); print(d)')" >> $GITHUB_OUTPUT | ||||||
|             echo "slice_ids=$(python3 -c 'd = list(range(${{ env.NUM_SLICES }})); print(d)')" >> $GITHUB_OUTPUT |  | ||||||
|           elif [ "${{ inputs.job }}" = "run_trainer_and_fsdp_gpu" ]; then |  | ||||||
|             echo "folder_slices=[['trainer'], ['fsdp']]" >> $GITHUB_OUTPUT |  | ||||||
|             echo "slice_ids=[0, 1]" >> $GITHUB_OUTPUT |  | ||||||
|           fi |  | ||||||
|  |  | ||||||
|       - id: set-matrix-quantization |       - id: set-matrix-quantization | ||||||
|         if: ${{ inputs.job == 'run_quantization_torch_gpu' }} |         if: ${{ inputs.job == 'run_quantization_torch_gpu' }} | ||||||
| @ -111,7 +103,7 @@ jobs: | |||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         machine_type: [aws-g4dn-4xlarge-cache, aws-g4dn-12xlarge-cache] |         machine_type: [aws-g4dn-2xlarge-cache, aws-g4dn-12xlarge-cache] | ||||||
|         slice_id: ${{ fromJSON(needs.setup.outputs.slice_ids) }} |         slice_id: ${{ fromJSON(needs.setup.outputs.slice_ids) }} | ||||||
|     uses: ./.github/workflows/model_jobs.yml |     uses: ./.github/workflows/model_jobs.yml | ||||||
|     with: |     with: | ||||||
| @ -122,32 +114,13 @@ jobs: | |||||||
|       docker: ${{ inputs.docker }} |       docker: ${{ inputs.docker }} | ||||||
|     secrets: inherit |     secrets: inherit | ||||||
|  |  | ||||||
|   run_trainer_and_fsdp_gpu: |  | ||||||
|     if: ${{ inputs.job == 'run_trainer_and_fsdp_gpu' }} |  | ||||||
|     name: " " |  | ||||||
|     needs: setup |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         machine_type: [aws-g4dn-4xlarge-cache, aws-g4dn-12xlarge-cache] |  | ||||||
|         slice_id: [0, 1] |  | ||||||
|     uses: ./.github/workflows/model_jobs.yml |  | ||||||
|     with: |  | ||||||
|       folder_slices: ${{ needs.setup.outputs.folder_slices }} |  | ||||||
|       machine_type: ${{ matrix.machine_type }} |  | ||||||
|       slice_id: ${{ matrix.slice_id }} |  | ||||||
|       runner: ${{ inputs.runner }} |  | ||||||
|       docker: ${{ inputs.docker }} |  | ||||||
|       report_name_prefix: run_trainer_and_fsdp_gpu |  | ||||||
|     secrets: inherit |  | ||||||
|  |  | ||||||
|   run_pipelines_torch_gpu: |   run_pipelines_torch_gpu: | ||||||
|     if: ${{ inputs.job == 'run_pipelines_torch_gpu' }} |     if: ${{ inputs.job == 'run_pipelines_torch_gpu' }} | ||||||
|     name: PyTorch pipelines |     name: PyTorch pipelines | ||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         machine_type: [aws-g4dn-4xlarge-cache, aws-g4dn-12xlarge-cache] |         machine_type: [aws-g4dn-2xlarge-cache, aws-g4dn-12xlarge-cache] | ||||||
|     runs-on: |     runs-on: | ||||||
|       group: '${{ matrix.machine_type }}' |       group: '${{ matrix.machine_type }}' | ||||||
|     container: |     container: | ||||||
| @ -181,7 +154,7 @@ jobs: | |||||||
|         run: | |         run: | | ||||||
|           echo "${{ matrix.machine_type }}" |           echo "${{ matrix.machine_type }}" | ||||||
|  |  | ||||||
|           if [ "${{ matrix.machine_type }}" = "aws-g4dn-4xlarge-cache" ]; then |           if [ "${{ matrix.machine_type }}" = "aws-g4dn-2xlarge-cache" ]; then | ||||||
|             machine_type=single-gpu |             machine_type=single-gpu | ||||||
|           elif [ "${{ matrix.machine_type }}" = "aws-g4dn-12xlarge-cache" ]; then |           elif [ "${{ matrix.machine_type }}" = "aws-g4dn-12xlarge-cache" ]; then | ||||||
|             machine_type=multi-gpu |             machine_type=multi-gpu | ||||||
| @ -209,13 +182,82 @@ jobs: | |||||||
|           name: ${{ env.machine_type }}_run_pipelines_torch_gpu_test_reports |           name: ${{ env.machine_type }}_run_pipelines_torch_gpu_test_reports | ||||||
|           path: /transformers/reports/${{ env.machine_type }}_run_pipelines_torch_gpu_test_reports |           path: /transformers/reports/${{ env.machine_type }}_run_pipelines_torch_gpu_test_reports | ||||||
|  |  | ||||||
|  |   run_pipelines_tf_gpu: | ||||||
|  |     if: ${{ inputs.job == 'run_pipelines_tf_gpu' }} | ||||||
|  |     name: TensorFlow pipelines | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         machine_type: [aws-g4dn-2xlarge-cache, aws-g4dn-12xlarge-cache] | ||||||
|  |     runs-on: | ||||||
|  |       group: '${{ matrix.machine_type }}' | ||||||
|  |     container: | ||||||
|  |       image: huggingface/transformers-tensorflow-gpu | ||||||
|  |       options: --gpus all --shm-size "16gb" --ipc host -v /mnt/cache/.cache/huggingface:/mnt/cache/ | ||||||
|  |     steps: | ||||||
|  |       - name: Update clone | ||||||
|  |         working-directory: /transformers | ||||||
|  |         run: | | ||||||
|  |           git fetch && git checkout ${{ github.sha }} | ||||||
|  |  | ||||||
|  |       - name: Reinstall transformers in edit mode (remove the one installed during docker image build) | ||||||
|  |         working-directory: /transformers | ||||||
|  |         run: python3 -m pip uninstall -y transformers && python3 -m pip install -e . | ||||||
|  |  | ||||||
|  |       - name: NVIDIA-SMI | ||||||
|  |         run: | | ||||||
|  |           nvidia-smi | ||||||
|  |  | ||||||
|  |       - name: Environment | ||||||
|  |         working-directory: /transformers | ||||||
|  |         run: | | ||||||
|  |           python3 utils/print_env.py | ||||||
|  |  | ||||||
|  |       - name: Show installed libraries and their versions | ||||||
|  |         working-directory: /transformers | ||||||
|  |         run: pip freeze | ||||||
|  |  | ||||||
|  |       - name: Set `machine_type` for report and artifact names | ||||||
|  |         working-directory: /transformers | ||||||
|  |         shell: bash | ||||||
|  |         run: | | ||||||
|  |           echo "${{ matrix.machine_type }}" | ||||||
|  |  | ||||||
|  |           if [ "${{ matrix.machine_type }}" = "aws-g4dn-2xlarge-cache" ]; then | ||||||
|  |             machine_type=single-gpu | ||||||
|  |           elif [ "${{ matrix.machine_type }}" = "aws-g4dn-12xlarge-cache" ]; then | ||||||
|  |             machine_type=multi-gpu | ||||||
|  |           else | ||||||
|  |             machine_type=${{ matrix.machine_type }} | ||||||
|  |           fi | ||||||
|  |  | ||||||
|  |           echo "$machine_type" | ||||||
|  |           echo "machine_type=$machine_type" >> $GITHUB_ENV | ||||||
|  |  | ||||||
|  |       - name: Run all pipeline tests on GPU | ||||||
|  |         working-directory: /transformers | ||||||
|  |         run: | | ||||||
|  |           python3 -m pytest -n 1 -v --dist=loadfile --make-reports=${{ env.machine_type }}_run_pipelines_tf_gpu_test_reports tests/pipelines | ||||||
|  |  | ||||||
|  |       - name: Failure short reports | ||||||
|  |         if: ${{ always() }} | ||||||
|  |         run: | | ||||||
|  |           cat /transformers/reports/${{ env.machine_type }}_run_pipelines_tf_gpu_test_reports/failures_short.txt | ||||||
|  |  | ||||||
|  |       - name: "Test suite reports artifacts: ${{ env.machine_type }}_run_pipelines_tf_gpu_test_reports" | ||||||
|  |         if: ${{ always() }} | ||||||
|  |         uses: actions/upload-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: ${{ env.machine_type }}_run_pipelines_tf_gpu_test_reports | ||||||
|  |           path: /transformers/reports/${{ env.machine_type }}_run_pipelines_tf_gpu_test_reports | ||||||
|  |  | ||||||
|   run_examples_gpu: |   run_examples_gpu: | ||||||
|     if: ${{ inputs.job == 'run_examples_gpu' }} |     if: ${{ inputs.job == 'run_examples_gpu' }} | ||||||
|     name: Examples directory |     name: Examples directory | ||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         machine_type: [aws-g4dn-4xlarge-cache] |         machine_type: [aws-g4dn-2xlarge-cache] | ||||||
|     runs-on: |     runs-on: | ||||||
|       group: '${{ matrix.machine_type }}' |       group: '${{ matrix.machine_type }}' | ||||||
|     container: |     container: | ||||||
| @ -249,7 +291,7 @@ jobs: | |||||||
|         run: | |         run: | | ||||||
|           echo "${{ matrix.machine_type }}" |           echo "${{ matrix.machine_type }}" | ||||||
|  |  | ||||||
|           if [ "${{ matrix.machine_type }}" = "aws-g4dn-4xlarge-cache" ]; then |           if [ "${{ matrix.machine_type }}" = "aws-g4dn-2xlarge-cache" ]; then | ||||||
|             machine_type=single-gpu |             machine_type=single-gpu | ||||||
|           elif [ "${{ matrix.machine_type }}" = "aws-g4dn-12xlarge-cache" ]; then |           elif [ "${{ matrix.machine_type }}" = "aws-g4dn-12xlarge-cache" ]; then | ||||||
|             machine_type=multi-gpu |             machine_type=multi-gpu | ||||||
| @ -284,7 +326,7 @@ jobs: | |||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         machine_type: [aws-g4dn-4xlarge-cache, aws-g4dn-12xlarge-cache] |         machine_type: [aws-g4dn-2xlarge-cache, aws-g4dn-12xlarge-cache] | ||||||
|     runs-on: |     runs-on: | ||||||
|       group: '${{ matrix.machine_type }}' |       group: '${{ matrix.machine_type }}' | ||||||
|     container: |     container: | ||||||
| @ -324,7 +366,7 @@ jobs: | |||||||
|         run: | |         run: | | ||||||
|           python3 -m pip uninstall -y deepspeed |           python3 -m pip uninstall -y deepspeed | ||||||
|           rm -rf DeepSpeed |           rm -rf DeepSpeed | ||||||
|           git clone https://github.com/deepspeedai/DeepSpeed && cd DeepSpeed && rm -rf build |           git clone https://github.com/microsoft/DeepSpeed && cd DeepSpeed && rm -rf build | ||||||
|           DS_BUILD_CPU_ADAM=1 DS_BUILD_FUSED_ADAM=1 python3 -m pip install . --global-option="build_ext" --global-option="-j8" --no-cache -v --disable-pip-version-check |           DS_BUILD_CPU_ADAM=1 DS_BUILD_FUSED_ADAM=1 python3 -m pip install . --global-option="build_ext" --global-option="-j8" --no-cache -v --disable-pip-version-check | ||||||
|  |  | ||||||
|       - name: NVIDIA-SMI |       - name: NVIDIA-SMI | ||||||
| @ -341,12 +383,12 @@ jobs: | |||||||
|         run: pip freeze |         run: pip freeze | ||||||
|  |  | ||||||
|       - name: Set `machine_type` for report and artifact names |       - name: Set `machine_type` for report and artifact names | ||||||
|         working-directory: ${{ inputs.working-directory-prefix }}/transformers |         working-directory: /transformers | ||||||
|         shell: bash |         shell: bash | ||||||
|         run: | |         run: | | ||||||
|           echo "${{ matrix.machine_type }}" |           echo "${{ matrix.machine_type }}" | ||||||
|  |  | ||||||
|           if [ "${{ matrix.machine_type }}" = "aws-g4dn-4xlarge-cache" ]; then |           if [ "${{ matrix.machine_type }}" = "aws-g4dn-2xlarge-cache" ]; then | ||||||
|             machine_type=single-gpu |             machine_type=single-gpu | ||||||
|           elif [ "${{ matrix.machine_type }}" = "aws-g4dn-12xlarge-cache" ]; then |           elif [ "${{ matrix.machine_type }}" = "aws-g4dn-12xlarge-cache" ]; then | ||||||
|             machine_type=multi-gpu |             machine_type=multi-gpu | ||||||
| @ -383,7 +425,7 @@ jobs: | |||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         folders: ${{ fromJson(needs.setup.outputs.quantization_matrix) }} |         folders: ${{ fromJson(needs.setup.outputs.quantization_matrix) }} | ||||||
|         machine_type: [aws-g4dn-4xlarge-cache, aws-g4dn-12xlarge-cache] |         machine_type: [aws-g4dn-2xlarge-cache, aws-g4dn-12xlarge-cache] | ||||||
|     runs-on: |     runs-on: | ||||||
|       group: '${{ matrix.machine_type }}' |       group: '${{ matrix.machine_type }}' | ||||||
|     container: |     container: | ||||||
| @ -426,7 +468,7 @@ jobs: | |||||||
|         run: | |         run: | | ||||||
|           echo "${{ matrix.machine_type }}" |           echo "${{ matrix.machine_type }}" | ||||||
|  |  | ||||||
|           if [ "${{ matrix.machine_type }}" = "aws-g4dn-4xlarge-cache" ]; then |           if [ "${{ matrix.machine_type }}" = "aws-g4dn-2xlarge-cache" ]; then | ||||||
|             machine_type=single-gpu |             machine_type=single-gpu | ||||||
|           elif [ "${{ matrix.machine_type }}" = "aws-g4dn-12xlarge-cache" ]; then |           elif [ "${{ matrix.machine_type }}" = "aws-g4dn-12xlarge-cache" ]; then | ||||||
|             machine_type=multi-gpu |             machine_type=multi-gpu | ||||||
| @ -500,8 +542,8 @@ jobs: | |||||||
|     needs: [ |     needs: [ | ||||||
|       setup, |       setup, | ||||||
|       run_models_gpu, |       run_models_gpu, | ||||||
|       run_trainer_and_fsdp_gpu, |  | ||||||
|       run_pipelines_torch_gpu, |       run_pipelines_torch_gpu, | ||||||
|  |       run_pipelines_tf_gpu, | ||||||
|       run_examples_gpu, |       run_examples_gpu, | ||||||
|       run_torch_cuda_extensions_gpu, |       run_torch_cuda_extensions_gpu, | ||||||
|       run_quantization_torch_gpu, |       run_quantization_torch_gpu, | ||||||
| @ -518,21 +560,15 @@ jobs: | |||||||
|       folder_slices: ${{ needs.setup.outputs.folder_slices }} |       folder_slices: ${{ needs.setup.outputs.folder_slices }} | ||||||
|       quantization_matrix: ${{ needs.setup.outputs.quantization_matrix }} |       quantization_matrix: ${{ needs.setup.outputs.quantization_matrix }} | ||||||
|       ci_event: ${{ inputs.ci_event }} |       ci_event: ${{ inputs.ci_event }} | ||||||
|       report_repo_id: ${{ inputs.report_repo_id }} |  | ||||||
|  |  | ||||||
|     secrets: inherit |     secrets: inherit | ||||||
|  |  | ||||||
|   check_new_failures: |   check_new_model_failures: | ||||||
|     if: ${{ always() && inputs.ci_event == 'Daily CI' && needs.send_results.result == 'success' }} |     if: ${{ always() && inputs.ci_event == 'Daily CI' && inputs.job == 'run_models_gpu' && needs.send_results.result == 'success' }} | ||||||
|     name: Check new failures |     name: Check new model failures | ||||||
|     needs: send_results |     needs: send_results | ||||||
|     uses: ./.github/workflows/check_failed_tests.yml |     uses: ./.github/workflows/check_failed_model_tests.yml | ||||||
|     with: |     with: | ||||||
|       docker: ${{ inputs.docker }} |       docker: ${{ inputs.docker }} | ||||||
|       start_sha: ${{ github.sha }} |       start_sha: ${{ github.sha }} | ||||||
|       job: ${{ inputs.job }} |     secrets: inherit | ||||||
|       slack_report_channel: ${{ inputs.slack_report_channel }} |  | ||||||
|       ci_event: ${{ inputs.ci_event }} |  | ||||||
|       report_repo_id: ${{ inputs.report_repo_id }} |  | ||||||
|  |  | ||||||
|     secrets: inherit |  | ||||||
							
								
								
									
										58
									
								
								.github/workflows/slack-report.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										58
									
								
								.github/workflows/slack-report.yml
									
									
									
									
										vendored
									
									
								
							| @ -21,9 +21,6 @@ on: | |||||||
|       ci_event: |       ci_event: | ||||||
|         required: true |         required: true | ||||||
|         type: string |         type: string | ||||||
|       report_repo_id: |  | ||||||
|         required: true |  | ||||||
|         type: string |  | ||||||
|  |  | ||||||
| env: | env: | ||||||
|   TRANSFORMERS_CI_RESULTS_UPLOAD_TOKEN: ${{ secrets.TRANSFORMERS_CI_RESULTS_UPLOAD_TOKEN }} |   TRANSFORMERS_CI_RESULTS_UPLOAD_TOKEN: ${{ secrets.TRANSFORMERS_CI_RESULTS_UPLOAD_TOKEN }} | ||||||
| @ -42,23 +39,8 @@ jobs: | |||||||
|  |  | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v4 | ||||||
|  |  | ||||||
|       - name: Prepare some setup values |  | ||||||
|         run: | |  | ||||||
|           if [ -f setup_values/prev_workflow_run_id.txt ]; then |  | ||||||
|             echo "PREV_WORKFLOW_RUN_ID=$(cat setup_values/prev_workflow_run_id.txt)" >> $GITHUB_ENV |  | ||||||
|           else |  | ||||||
|             echo "PREV_WORKFLOW_RUN_ID=" >> $GITHUB_ENV |  | ||||||
|           fi |  | ||||||
|  |  | ||||||
|           if [ -f setup_values/other_workflow_run_id.txt ]; then |  | ||||||
|             echo "OTHER_WORKFLOW_RUN_ID=$(cat setup_values/other_workflow_run_id.txt)" >> $GITHUB_ENV |  | ||||||
|           else |  | ||||||
|             echo "OTHER_WORKFLOW_RUN_ID=" >> $GITHUB_ENV |  | ||||||
|           fi |  | ||||||
|  |  | ||||||
|       - name: Send message to Slack |       - name: Send message to Slack | ||||||
|         shell: bash |         if: ${{ inputs.job != 'run_quantization_torch_gpu' }} | ||||||
|         env: |         env: | ||||||
|           CI_SLACK_BOT_TOKEN: ${{ secrets.CI_SLACK_BOT_TOKEN }} |           CI_SLACK_BOT_TOKEN: ${{ secrets.CI_SLACK_BOT_TOKEN }} | ||||||
|           CI_SLACK_CHANNEL_ID: ${{ secrets.CI_SLACK_CHANNEL_ID }} |           CI_SLACK_CHANNEL_ID: ${{ secrets.CI_SLACK_CHANNEL_ID }} | ||||||
| @ -68,22 +50,19 @@ jobs: | |||||||
|           ACCESS_REPO_INFO_TOKEN: ${{ secrets.ACCESS_REPO_INFO_TOKEN }} |           ACCESS_REPO_INFO_TOKEN: ${{ secrets.ACCESS_REPO_INFO_TOKEN }} | ||||||
|           CI_EVENT: ${{ inputs.ci_event }} |           CI_EVENT: ${{ inputs.ci_event }} | ||||||
|           CI_SHA: ${{ github.sha }} |           CI_SHA: ${{ github.sha }} | ||||||
|  |           CI_WORKFLOW_REF: ${{ github.workflow_ref }} | ||||||
|           CI_TEST_JOB: ${{ inputs.job }} |           CI_TEST_JOB: ${{ inputs.job }} | ||||||
|           SETUP_STATUS: ${{ inputs.setup_status }} |           SETUP_STATUS: ${{ inputs.setup_status }} | ||||||
|           REPORT_REPO_ID: ${{ inputs.report_repo_id }} |  | ||||||
|         # We pass `needs.setup.outputs.matrix` as the argument. A processing in `notification_service.py` to change |         # We pass `needs.setup.outputs.matrix` as the argument. A processing in `notification_service.py` to change | ||||||
|         # `models/bert` to `models_bert` is required, as the artifact names use `_` instead of `/`. |         # `models/bert` to `models_bert` is required, as the artifact names use `_` instead of `/`. | ||||||
|         # For a job that doesn't depend on (i.e. `needs`) `setup`, the value for `inputs.folder_slices` would be an |         # For a job that doesn't depend on (i.e. `needs`) `setup`, the value for `inputs.folder_slices` would be an | ||||||
|         # empty string, and the called script still get one argument (which is the emtpy string). |         # empty string, and the called script still get one argument (which is the emtpy string). | ||||||
|         run: | |         run: | | ||||||
|  |           sudo apt-get install -y curl | ||||||
|           pip install huggingface_hub |           pip install huggingface_hub | ||||||
|           pip install slack_sdk |           pip install slack_sdk | ||||||
|           pip show slack_sdk |           pip show slack_sdk | ||||||
|           if [ "${{ inputs.quantization_matrix }}" != "" ]; then |           python utils/notification_service.py "${{ inputs.folder_slices }}" | ||||||
|             python utils/notification_service.py "${{ inputs.quantization_matrix }}" |  | ||||||
|           else |  | ||||||
|             python utils/notification_service.py "${{ inputs.folder_slices }}" |  | ||||||
|           fi           |  | ||||||
|  |  | ||||||
|       # Upload complete failure tables, as they might be big and only truncated versions could be sent to Slack. |       # Upload complete failure tables, as they might be big and only truncated versions could be sent to Slack. | ||||||
|       - name: Failure table artifacts |       - name: Failure table artifacts | ||||||
| @ -91,3 +70,32 @@ jobs: | |||||||
|         with: |         with: | ||||||
|           name: ci_results_${{ inputs.job }} |           name: ci_results_${{ inputs.job }} | ||||||
|           path: ci_results_${{ inputs.job }} |           path: ci_results_${{ inputs.job }} | ||||||
|  |  | ||||||
|  |       - uses: actions/checkout@v4 | ||||||
|  |       - uses: actions/download-artifact@v4 | ||||||
|  |       - name: Send message to Slack for quantization workflow | ||||||
|  |         if: ${{ inputs.job == 'run_quantization_torch_gpu' }} | ||||||
|  |         env: | ||||||
|  |           CI_SLACK_BOT_TOKEN: ${{ secrets.CI_SLACK_BOT_TOKEN }} | ||||||
|  |           ACCESS_REPO_INFO_TOKEN: ${{ secrets.ACCESS_REPO_INFO_TOKEN }} | ||||||
|  |           SLACK_REPORT_CHANNEL: ${{ inputs.slack_report_channel }} | ||||||
|  |           CI_EVENT: ${{ inputs.ci_event }} | ||||||
|  |           CI_SHA: ${{ github.sha }} | ||||||
|  |           CI_TEST_JOB: ${{ inputs.job }} | ||||||
|  |           SETUP_STATUS: ${{ inputs.setup_status }} | ||||||
|  |         # We pass `needs.setup.outputs.quantization_matrix` as the argument. A processing in `notification_service_quantization.py` to change | ||||||
|  |         # `quantization/bnb` to `quantization_bnb` is required, as the artifact names use `_` instead of `/`. | ||||||
|  |         run: | | ||||||
|  |           sudo apt-get install -y curl | ||||||
|  |           pip install huggingface_hub | ||||||
|  |           pip install slack_sdk | ||||||
|  |           pip show slack_sdk | ||||||
|  |           python utils/notification_service_quantization.py "${{ inputs.quantization_matrix }}" | ||||||
|  |  | ||||||
|  |       # Upload complete failure tables, as they might be big and only truncated versions could be sent to Slack. | ||||||
|  |       - name: Failure table artifacts | ||||||
|  |         if: ${{ inputs.job == 'run_quantization_torch_gpu' }} | ||||||
|  |         uses: actions/upload-artifact@v4 | ||||||
|  |         with: | ||||||
|  |           name: ci_results_${{ inputs.job }} | ||||||
|  |           path: ci_results_${{ inputs.job }} | ||||||
|  | |||||||
							
								
								
									
										21
									
								
								.github/workflows/ssh-runner.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										21
									
								
								.github/workflows/ssh-runner.yml
									
									
									
									
										vendored
									
									
								
							| @ -5,7 +5,7 @@ on: | |||||||
|     inputs: |     inputs: | ||||||
|       runner_type: |       runner_type: | ||||||
|         description: 'Type of runner to test (a10 or t4)' |         description: 'Type of runner to test (a10 or t4)' | ||||||
|         required: true |         required: true  | ||||||
|       docker_image: |       docker_image: | ||||||
|         description: 'Name of the Docker image' |         description: 'Name of the Docker image' | ||||||
|         required: true |         required: true | ||||||
| @ -15,14 +15,15 @@ on: | |||||||
|  |  | ||||||
| env: | env: | ||||||
|   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} |   HF_HUB_READ_TOKEN: ${{ secrets.HF_HUB_READ_TOKEN }} | ||||||
|   HF_HOME: /mnt/cache |   HF_HOME: /mnt/cache  | ||||||
|   TRANSFORMERS_IS_CI: yes |   TRANSFORMERS_IS_CI: yes  | ||||||
|   OMP_NUM_THREADS: 8 |   OMP_NUM_THREADS: 8  | ||||||
|   MKL_NUM_THREADS: 8 |   MKL_NUM_THREADS: 8  | ||||||
|   RUN_SLOW: yes # For gated repositories, we still need to agree to share information on the Hub repo. page in order to get access. # This token is created under the bot `hf-transformers-bot`. |   RUN_SLOW: yes # For gated repositories, we still need to agree to share information on the Hub repo. page in order to get access. # This token is created under the bot `hf-transformers-bot`.  | ||||||
|   SIGOPT_API_TOKEN: ${{ secrets.SIGOPT_API_TOKEN }} |   SIGOPT_API_TOKEN: ${{ secrets.SIGOPT_API_TOKEN }}  | ||||||
|   TF_FORCE_GPU_ALLOW_GROWTH: true |   TF_FORCE_GPU_ALLOW_GROWTH: true  | ||||||
|   CUDA_VISIBLE_DEVICES: 0,1 |   CUDA_VISIBLE_DEVICES: 0,1 | ||||||
|  |   RUN_PT_TF_CROSS_TESTS: 1 | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   get_runner: |   get_runner: | ||||||
| @ -35,7 +36,7 @@ jobs: | |||||||
|         shell: bash |         shell: bash | ||||||
|         run: | |         run: | | ||||||
|           if [[ "${{ github.event.inputs.num_gpus }}" == "single" && "${{ github.event.inputs.runner_type }}" == "t4" ]]; then |           if [[ "${{ github.event.inputs.num_gpus }}" == "single" && "${{ github.event.inputs.runner_type }}" == "t4" ]]; then | ||||||
|             echo "RUNNER=aws-g4dn-4xlarge-cache" >> $GITHUB_ENV |             echo "RUNNER=aws-g4dn-2xlarge-cache" >> $GITHUB_ENV | ||||||
|           elif [[ "${{ github.event.inputs.num_gpus }}" == "multi" && "${{ github.event.inputs.runner_type }}" == "t4" ]]; then |           elif [[ "${{ github.event.inputs.num_gpus }}" == "multi" && "${{ github.event.inputs.runner_type }}" == "t4" ]]; then | ||||||
|             echo "RUNNER=aws-g4dn-12xlarge-cache" >> $GITHUB_ENV |             echo "RUNNER=aws-g4dn-12xlarge-cache" >> $GITHUB_ENV | ||||||
|           elif [[ "${{ github.event.inputs.num_gpus }}" == "single" && "${{ github.event.inputs.runner_type }}" == "a10" ]]; then |           elif [[ "${{ github.event.inputs.num_gpus }}" == "single" && "${{ github.event.inputs.runner_type }}" == "a10" ]]; then | ||||||
| @ -77,7 +78,7 @@ jobs: | |||||||
|       - name: Show installed libraries and their versions |       - name: Show installed libraries and their versions | ||||||
|         working-directory: /transformers |         working-directory: /transformers | ||||||
|         run: pip freeze |         run: pip freeze | ||||||
|  |        | ||||||
|       - name: NVIDIA-SMI |       - name: NVIDIA-SMI | ||||||
|         run: | |         run: | | ||||||
|           nvidia-smi |           nvidia-smi | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/workflows/trufflehog.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/trufflehog.yml
									
									
									
									
										vendored
									
									
								
							| @ -16,5 +16,3 @@ jobs: | |||||||
|           fetch-depth: 0 |           fetch-depth: 0 | ||||||
|       - name: Secret Scanning |       - name: Secret Scanning | ||||||
|         uses: trufflesecurity/trufflehog@main |         uses: trufflesecurity/trufflehog@main | ||||||
|         with: |  | ||||||
|           extra_args: --results=verified,unknown |  | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/workflows/update_metdata.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/update_metdata.yml
									
									
									
									
										vendored
									
									
								
							| @ -19,7 +19,7 @@ jobs: | |||||||
|       - name: Setup environment |       - name: Setup environment | ||||||
|         run: | |         run: | | ||||||
|           pip install --upgrade pip |           pip install --upgrade pip | ||||||
|           pip install datasets pandas |           pip install datasets pandas==2.0.3 | ||||||
|           pip install .[torch,tf,flax] |           pip install .[torch,tf,flax] | ||||||
|  |  | ||||||
|       - name: Update metadata |       - name: Update metadata | ||||||
|  | |||||||
							
								
								
									
										39
									
								
								AGENTS.md
									
									
									
									
									
								
							
							
						
						
									
										39
									
								
								AGENTS.md
									
									
									
									
									
								
							| @ -1,39 +0,0 @@ | |||||||
| # AGENTS.md Guide for Hugging Face Transformers |  | ||||||
|  |  | ||||||
| This AGENTS.md file provides guidance for code agents working with this codebase. |  | ||||||
|  |  | ||||||
| ## Core Project Structure |  | ||||||
|  |  | ||||||
| - `/src/transformers`: This contains the core source code for the library |  | ||||||
|   - `/models`: Code for individual models. Models inherit from base classes in the root `/src/transformers` directory. |  | ||||||
| - `/tests`: This contains the core test classes for the library. These are usually inherited rather than directly run. |  | ||||||
|   - `/models`: Tests for individual models. Model tests inherit from common tests in the root `/tests` directory. |  | ||||||
| - `/docs`: This contains the documentation for the library, including guides, tutorials, and API references. |  | ||||||
|  |  | ||||||
| ## Coding Conventions for Hugging Face Transformers |  | ||||||
|  |  | ||||||
| - PRs should be as brief as possible. Bugfix PRs in particular can often be only one or two lines long, and do not need large comments, docstrings or new functions in this case. Aim to minimize the size of the diff. |  | ||||||
| - When writing tests, they should be added to an existing file. The only exception is for PRs to add a new model, when a new test directory should be created for that model. |  | ||||||
| - Code style is enforced in the CI. You can install the style tools with `pip install -e .[quality]`. You can then run `make fixup` to apply style and consistency fixes to your code. |  | ||||||
|  |  | ||||||
| ## Copying and inheritance |  | ||||||
|  |  | ||||||
| Many models in the codebase have similar code, but it is not shared by inheritance because we want each model file to be self-contained. |  | ||||||
| We use two mechanisms to keep this code in sync: |  | ||||||
|  |  | ||||||
| - "Copied from" syntax. Functions or entire classes can have a comment at the top like this: `# Copied from transformers.models.llama.modeling_llama.rotate_half` or `# Copied from transformers.models.t5.modeling_t5.T5LayerNorm with T5->MT5` |  | ||||||
|   These comments are actively checked by the style tools, and copies will automatically be updated when the base code is updated. If you need to update a copied function, you should |  | ||||||
|   either update the base function and use `make fixup` to propagate the change to all copies, or simply remove the `# Copied from` comment if that is inappropriate. |  | ||||||
| - "Modular" files. These files briefly define models by composing them using inheritance from other models. They are not meant to be used directly. Instead, the style tools |  | ||||||
|   automatically generate a complete modeling file, like `modeling_bert.py`, from the modular file like `modular_bert.py`. If a model has a modular file, the modeling file |  | ||||||
|   should never be edited directly! Instead, changes should be made in the modular file, and then you should run `make fixup` to update the modeling file automatically. |  | ||||||
|  |  | ||||||
| When adding new models, you should prefer `modular` style. |  | ||||||
|  |  | ||||||
| ## Testing |  | ||||||
|  |  | ||||||
| After making changes, you should usually run `make fixup` to ensure any copies and modular files are updated, and then test all affected models. This includes both |  | ||||||
| the model you made the changes in and any other models that were updated by `make fixup`. Tests can be run with `pytest tests/models/[name]/test_modeling_[name].py` |  | ||||||
| If your changes affect code in other classes like tokenizers or processors, you should run those tests instead, like `test_processing_[name].py` or `test_tokenization_[name].py`. |  | ||||||
|  |  | ||||||
| In order to run tests, you may need to install dependencies. You can do this with `pip install -e .[testing]`. You will probably also need to `pip install torch accelerate` if your environment does not already have them. |  | ||||||
| @ -78,7 +78,7 @@ Once you've confirmed the bug hasn't already been reported, please include the f | |||||||
| To get the OS and software versions automatically, run the following command: | To get the OS and software versions automatically, run the following command: | ||||||
|  |  | ||||||
| ```bash | ```bash | ||||||
| transformers env | transformers-cli env | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| You can also run the same command from the root of the repository: | You can also run the same command from the root of the repository: | ||||||
| @ -221,10 +221,10 @@ You'll need **[Python 3.9](https://github.com/huggingface/transformers/blob/main | |||||||
|    [Checks on a Pull Request](https://huggingface.co/docs/transformers/pr_checks) guide. |    [Checks on a Pull Request](https://huggingface.co/docs/transformers/pr_checks) guide. | ||||||
|  |  | ||||||
|    If you're modifying documents under the `docs/source` directory, make sure the documentation can still be built. This check will also run in the CI when you open a pull request. To run a local check |    If you're modifying documents under the `docs/source` directory, make sure the documentation can still be built. This check will also run in the CI when you open a pull request. To run a local check | ||||||
|    make sure you install the [documentation builder](https://github.com/huggingface/doc-builder). |    make sure you install the documentation builder: | ||||||
|  |  | ||||||
|    ```bash |    ```bash | ||||||
|    pip install hf-doc-builder |    pip install ".[docs]" | ||||||
|    ``` |    ``` | ||||||
|  |  | ||||||
|    Run the following command from the root of the repository: |    Run the following command from the root of the repository: | ||||||
| @ -343,6 +343,8 @@ RUN_SLOW=yes python -m pytest -n auto --dist=loadfile -s -v ./examples/pytorch/t | |||||||
|  |  | ||||||
| Like the slow tests, there are other environment variables available which are not enabled by default during testing: | Like the slow tests, there are other environment variables available which are not enabled by default during testing: | ||||||
| - `RUN_CUSTOM_TOKENIZERS`: Enables tests for custom tokenizers. | - `RUN_CUSTOM_TOKENIZERS`: Enables tests for custom tokenizers. | ||||||
|  | - `RUN_PT_FLAX_CROSS_TESTS`: Enables tests for PyTorch + Flax integration. | ||||||
|  | - `RUN_PT_TF_CROSS_TESTS`: Enables tests for TensorFlow + PyTorch integration. | ||||||
|  |  | ||||||
| More environment variables and additional information can be found in the [testing_utils.py](https://github.com/huggingface/transformers/blob/main/src/transformers/testing_utils.py). | More environment variables and additional information can be found in the [testing_utils.py](https://github.com/huggingface/transformers/blob/main/src/transformers/testing_utils.py). | ||||||
|  |  | ||||||
|  | |||||||
| @ -26,7 +26,7 @@ There are two main venues to receive support: [the forums](https://discuss.huggi | |||||||
|  |  | ||||||
| [The user forums](https://discuss.huggingface.co/) are supported by the wide community of the library users and backed up by developers when needed. | [The user forums](https://discuss.huggingface.co/) are supported by the wide community of the library users and backed up by developers when needed. | ||||||
|  |  | ||||||
| If you have a difficulty with deploying this library or some questions, or you'd like to discuss a new feature, please first consider discussing those things at the forums. Only when you feel your subject matter has been crystallized and you still need support from the library developers do proceed to file an [issue](https://github.com/huggingface/transformers/issues). | If you have a difficulty with deploying this library or some questions, or you'd like to discuss a new feature, please first consider discussing those things at the forums. Only when you feel your subject matter has been crystalized and you still need support from the library developers do proceed to file an [issue](https://github.com/huggingface/transformers/issues). | ||||||
|  |  | ||||||
| In particular all "Please explain" questions or objectively very user-specific feature requests belong to the forums. Here are some example of such questions: | In particular all "Please explain" questions or objectively very user-specific feature requests belong to the forums. Here are some example of such questions: | ||||||
|  |  | ||||||
| @ -263,9 +263,9 @@ You are not required to read the following guidelines before opening an issue. H | |||||||
|     But if you're replying to a comment that happened some comments back it's always a good practice to quote just the relevant lines you're replying it. The `>` is used for quoting, or you can always use the menu to do so. For example your editor box will look like: |     But if you're replying to a comment that happened some comments back it's always a good practice to quote just the relevant lines you're replying it. The `>` is used for quoting, or you can always use the menu to do so. For example your editor box will look like: | ||||||
|  |  | ||||||
|     ``` |     ``` | ||||||
|     > How big is your GPU cluster? |     > How big is your gpu cluster? | ||||||
|  |  | ||||||
|     Our cluster is made of 256 GPUs. |     Our cluster is made of 256 gpus. | ||||||
|     ``` |     ``` | ||||||
|  |  | ||||||
|     If you are addressing multiple comments, quote the relevant parts of each before your answer. Some people use the same comment to do multiple replies, others separate them into separate comments. Either way works. The latter approach helps for linking to a specific comment. |     If you are addressing multiple comments, quote the relevant parts of each before your answer. Some people use the same comment to do multiple replies, others separate them into separate comments. Either way works. The latter approach helps for linking to a specific comment. | ||||||
|  | |||||||
							
								
								
									
										25
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										25
									
								
								Makefile
									
									
									
									
									
								
							| @ -8,19 +8,13 @@ check_dirs := examples tests src utils | |||||||
| exclude_folders :=  "" | exclude_folders :=  "" | ||||||
|  |  | ||||||
| modified_only_fixup: | modified_only_fixup: | ||||||
| 	@current_branch=$$(git branch --show-current); \ | 	$(eval modified_py_files := $(shell python utils/get_modified_files.py $(check_dirs))) | ||||||
| 	if [ "$$current_branch" = "main" ]; then \ | 	@if test -n "$(modified_py_files)"; then \ | ||||||
| 		echo "On main branch, running 'style' target instead..."; \ | 		echo "Checking/fixing $(modified_py_files)"; \ | ||||||
| 		$(MAKE) style; \ | 		ruff check $(modified_py_files) --fix --exclude $(exclude_folders); \ | ||||||
|  | 		ruff format $(modified_py_files) --exclude $(exclude_folders);\ | ||||||
| 	else \ | 	else \ | ||||||
| 		modified_py_files=$$(python utils/get_modified_files.py $(check_dirs)); \ | 		echo "No library .py files were modified"; \ | ||||||
| 		if [ -n "$$modified_py_files" ]; then \ |  | ||||||
| 			echo "Checking/fixing files: $${modified_py_files}"; \ |  | ||||||
| 			ruff check $${modified_py_files} --fix --exclude $(exclude_folders); \ |  | ||||||
| 			ruff format $${modified_py_files} --exclude $(exclude_folders); \ |  | ||||||
| 		else \ |  | ||||||
| 			echo "No library .py files were modified"; \ |  | ||||||
| 		fi; \ |  | ||||||
| 	fi | 	fi | ||||||
|  |  | ||||||
| # Update src/transformers/dependency_versions_table.py | # Update src/transformers/dependency_versions_table.py | ||||||
| @ -43,15 +37,16 @@ autogenerate_code: deps_table_update | |||||||
| repo-consistency: | repo-consistency: | ||||||
| 	python utils/check_copies.py | 	python utils/check_copies.py | ||||||
| 	python utils/check_modular_conversion.py | 	python utils/check_modular_conversion.py | ||||||
|  | 	python utils/check_table.py | ||||||
| 	python utils/check_dummies.py | 	python utils/check_dummies.py | ||||||
| 	python utils/check_repo.py | 	python utils/check_repo.py | ||||||
| 	python utils/check_inits.py | 	python utils/check_inits.py | ||||||
| 	python utils/check_pipeline_typing.py |  | ||||||
| 	python utils/check_config_docstrings.py | 	python utils/check_config_docstrings.py | ||||||
| 	python utils/check_config_attributes.py | 	python utils/check_config_attributes.py | ||||||
| 	python utils/check_doctest_list.py | 	python utils/check_doctest_list.py | ||||||
| 	python utils/update_metadata.py --check-only | 	python utils/update_metadata.py --check-only | ||||||
| 	python utils/check_docstrings.py | 	python utils/check_docstrings.py | ||||||
|  | 	python utils/check_support_list.py | ||||||
|  |  | ||||||
| # this target runs checks on all files | # this target runs checks on all files | ||||||
|  |  | ||||||
| @ -86,9 +81,9 @@ fixup: modified_only_fixup extra_style_checks autogenerate_code repo-consistency | |||||||
|  |  | ||||||
| fix-copies: | fix-copies: | ||||||
| 	python utils/check_copies.py --fix_and_overwrite | 	python utils/check_copies.py --fix_and_overwrite | ||||||
| 	python utils/check_modular_conversion.py --fix_and_overwrite | 	python utils/check_modular_conversion.py  --fix_and_overwrite | ||||||
|  | 	python utils/check_table.py --fix_and_overwrite | ||||||
| 	python utils/check_dummies.py --fix_and_overwrite | 	python utils/check_dummies.py --fix_and_overwrite | ||||||
| 	python utils/check_pipeline_typing.py --fix_and_overwrite |  | ||||||
| 	python utils/check_doctest_list.py --fix_and_overwrite | 	python utils/check_doctest_list.py --fix_and_overwrite | ||||||
| 	python utils/check_docstrings.py --fix_and_overwrite | 	python utils/check_docstrings.py --fix_and_overwrite | ||||||
|  |  | ||||||
|  | |||||||
							
								
								
									
										398
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										398
									
								
								README.md
									
									
									
									
									
								
							| @ -25,7 +25,6 @@ limitations under the License. | |||||||
| </p> | </p> | ||||||
|  |  | ||||||
| <p align="center"> | <p align="center"> | ||||||
|     <a href="https://huggingface.com/models"><img alt="Checkpoints on Hub" src="https://img.shields.io/endpoint?url=https://huggingface.co/api/shields/models&color=brightgreen"></a> |  | ||||||
|     <a href="https://circleci.com/gh/huggingface/transformers"><img alt="Build" src="https://img.shields.io/circleci/build/github/huggingface/transformers/main"></a> |     <a href="https://circleci.com/gh/huggingface/transformers"><img alt="Build" src="https://img.shields.io/circleci/build/github/huggingface/transformers/main"></a> | ||||||
|     <a href="https://github.com/huggingface/transformers/blob/main/LICENSE"><img alt="GitHub" src="https://img.shields.io/github/license/huggingface/transformers.svg?color=blue"></a> |     <a href="https://github.com/huggingface/transformers/blob/main/LICENSE"><img alt="GitHub" src="https://img.shields.io/github/license/huggingface/transformers.svg?color=blue"></a> | ||||||
|     <a href="https://huggingface.co/docs/transformers/index"><img alt="Documentation" src="https://img.shields.io/website/http/huggingface.co/docs/transformers/index.svg?down_color=red&down_message=offline&up_message=online"></a> |     <a href="https://huggingface.co/docs/transformers/index"><img alt="Documentation" src="https://img.shields.io/website/http/huggingface.co/docs/transformers/index.svg?down_color=red&down_message=offline&up_message=online"></a> | ||||||
| @ -55,268 +54,275 @@ limitations under the License. | |||||||
| </h4> | </h4> | ||||||
|  |  | ||||||
| <h3 align="center"> | <h3 align="center"> | ||||||
|     <p>State-of-the-art pretrained models for inference and training</p> |     <p>State-of-the-art Machine Learning for JAX, PyTorch and TensorFlow</p> | ||||||
| </h3> | </h3> | ||||||
|  |  | ||||||
| <h3 align="center"> | <h3 align="center"> | ||||||
|     <img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/transformers/transformers_as_a_model_definition.png"/> |     <a href="https://hf.co/course"><img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/course_banner.png"></a> | ||||||
| </h3> | </h3> | ||||||
|  |  | ||||||
|  | 🤗 Transformers provides thousands of pretrained models to perform tasks on different modalities such as text, vision, and audio. | ||||||
|  |  | ||||||
| Transformers acts as the model-definition framework for state-of-the-art machine learning models in text, computer  | These models can be applied on: | ||||||
| vision, audio, video, and multimodal model, for both inference and training.  |  | ||||||
|  |  | ||||||
| It centralizes the model definition so that this definition is agreed upon across the ecosystem. `transformers` is the  | * 📝 Text, for tasks like text classification, information extraction, question answering, summarization, translation, and text generation, in over 100 languages. | ||||||
| pivot across frameworks: if a model definition is supported, it will be compatible with the majority of training  | * 🖼️ Images, for tasks like image classification, object detection, and segmentation. | ||||||
| frameworks (Axolotl, Unsloth, DeepSpeed, FSDP, PyTorch-Lightning, ...), inference engines (vLLM, SGLang, TGI, ...), | * 🗣️ Audio, for tasks like speech recognition and audio classification. | ||||||
| and adjacent modeling libraries (llama.cpp, mlx, ...) which leverage the model definition from `transformers`. |  | ||||||
|  |  | ||||||
| We pledge to help support new state-of-the-art models and democratize their usage by having their model definition be | Transformer models can also perform tasks on **several modalities combined**, such as table question answering, optical character recognition, information extraction from scanned documents, video classification, and visual question answering. | ||||||
| simple, customizable, and efficient. |  | ||||||
|  |  | ||||||
| There are over 1M+ Transformers [model checkpoints](https://huggingface.co/models?library=transformers&sort=trending) on the [Hugging Face Hub](https://huggingface.com/models) you can use. | 🤗 Transformers provides APIs to quickly download and use those pretrained models on a given text, fine-tune them on your own datasets and then share them with the community on our [model hub](https://huggingface.co/models). At the same time, each python module defining an architecture is fully standalone and can be modified to enable quick research experiments. | ||||||
|  |  | ||||||
| Explore the [Hub](https://huggingface.com/) today to find a model and use Transformers to help you get started right away. | 🤗 Transformers is backed by the three most popular deep learning libraries — [Jax](https://jax.readthedocs.io/en/latest/), [PyTorch](https://pytorch.org/) and [TensorFlow](https://www.tensorflow.org/) — with a seamless integration between them. It's straightforward to train your models with one before loading them for inference with the other. | ||||||
|  |  | ||||||
| ## Installation | ## Online demos | ||||||
|  |  | ||||||
| Transformers works with Python 3.9+ [PyTorch](https://pytorch.org/get-started/locally/) 2.1+, [TensorFlow](https://www.tensorflow.org/install/pip) 2.6+, and [Flax](https://flax.readthedocs.io/en/latest/) 0.4.1+. | You can test most of our models directly on their pages from the [model hub](https://huggingface.co/models). We also offer [private model hosting, versioning, & an inference API](https://huggingface.co/pricing) for public and private models. | ||||||
|  |  | ||||||
| Create and activate a virtual environment with [venv](https://docs.python.org/3/library/venv.html) or [uv](https://docs.astral.sh/uv/), a fast Rust-based Python package and project manager. | Here are a few examples: | ||||||
|  |  | ||||||
| ```py | In Natural Language Processing: | ||||||
| # venv | - [Masked word completion with BERT](https://huggingface.co/google-bert/bert-base-uncased?text=Paris+is+the+%5BMASK%5D+of+France) | ||||||
| python -m venv .my-env | - [Named Entity Recognition with Electra](https://huggingface.co/dbmdz/electra-large-discriminator-finetuned-conll03-english?text=My+name+is+Sarah+and+I+live+in+London+city) | ||||||
| source .my-env/bin/activate | - [Text generation with Mistral](https://huggingface.co/mistralai/Mistral-7B-Instruct-v0.2) | ||||||
| # uv | - [Natural Language Inference with RoBERTa](https://huggingface.co/FacebookAI/roberta-large-mnli?text=The+dog+was+lost.+Nobody+lost+any+animal) | ||||||
| uv venv .my-env | - [Summarization with BART](https://huggingface.co/facebook/bart-large-cnn?text=The+tower+is+324+metres+%281%2C063+ft%29+tall%2C+about+the+same+height+as+an+81-storey+building%2C+and+the+tallest+structure+in+Paris.+Its+base+is+square%2C+measuring+125+metres+%28410+ft%29+on+each+side.+During+its+construction%2C+the+Eiffel+Tower+surpassed+the+Washington+Monument+to+become+the+tallest+man-made+structure+in+the+world%2C+a+title+it+held+for+41+years+until+the+Chrysler+Building+in+New+York+City+was+finished+in+1930.+It+was+the+first+structure+to+reach+a+height+of+300+metres.+Due+to+the+addition+of+a+broadcasting+aerial+at+the+top+of+the+tower+in+1957%2C+it+is+now+taller+than+the+Chrysler+Building+by+5.2+metres+%2817+ft%29.+Excluding+transmitters%2C+the+Eiffel+Tower+is+the+second+tallest+free-standing+structure+in+France+after+the+Millau+Viaduct) | ||||||
| source .my-env/bin/activate | - [Question answering with DistilBERT](https://huggingface.co/distilbert/distilbert-base-uncased-distilled-squad?text=Which+name+is+also+used+to+describe+the+Amazon+rainforest+in+English%3F&context=The+Amazon+rainforest+%28Portuguese%3A+Floresta+Amaz%C3%B4nica+or+Amaz%C3%B4nia%3B+Spanish%3A+Selva+Amaz%C3%B3nica%2C+Amazon%C3%ADa+or+usually+Amazonia%3B+French%3A+For%C3%AAt+amazonienne%3B+Dutch%3A+Amazoneregenwoud%29%2C+also+known+in+English+as+Amazonia+or+the+Amazon+Jungle%2C+is+a+moist+broadleaf+forest+that+covers+most+of+the+Amazon+basin+of+South+America.+This+basin+encompasses+7%2C000%2C000+square+kilometres+%282%2C700%2C000+sq+mi%29%2C+of+which+5%2C500%2C000+square+kilometres+%282%2C100%2C000+sq+mi%29+are+covered+by+the+rainforest.+This+region+includes+territory+belonging+to+nine+nations.+The+majority+of+the+forest+is+contained+within+Brazil%2C+with+60%25+of+the+rainforest%2C+followed+by+Peru+with+13%25%2C+Colombia+with+10%25%2C+and+with+minor+amounts+in+Venezuela%2C+Ecuador%2C+Bolivia%2C+Guyana%2C+Suriname+and+French+Guiana.+States+or+departments+in+four+nations+contain+%22Amazonas%22+in+their+names.+The+Amazon+represents+over+half+of+the+planet%27s+remaining+rainforests%2C+and+comprises+the+largest+and+most+biodiverse+tract+of+tropical+rainforest+in+the+world%2C+with+an+estimated+390+billion+individual+trees+divided+into+16%2C000+species) | ||||||
|  | - [Translation with T5](https://huggingface.co/google-t5/t5-base?text=My+name+is+Wolfgang+and+I+live+in+Berlin) | ||||||
|  |  | ||||||
|  | In Computer Vision: | ||||||
|  | - [Image classification with ViT](https://huggingface.co/google/vit-base-patch16-224) | ||||||
|  | - [Object Detection with DETR](https://huggingface.co/facebook/detr-resnet-50) | ||||||
|  | - [Semantic Segmentation with SegFormer](https://huggingface.co/nvidia/segformer-b0-finetuned-ade-512-512) | ||||||
|  | - [Panoptic Segmentation with Mask2Former](https://huggingface.co/facebook/mask2former-swin-large-coco-panoptic) | ||||||
|  | - [Depth Estimation with Depth Anything](https://huggingface.co/docs/transformers/main/model_doc/depth_anything) | ||||||
|  | - [Video Classification with VideoMAE](https://huggingface.co/docs/transformers/model_doc/videomae) | ||||||
|  | - [Universal Segmentation with OneFormer](https://huggingface.co/shi-labs/oneformer_ade20k_dinat_large) | ||||||
|  |  | ||||||
|  | In Audio: | ||||||
|  | - [Automatic Speech Recognition with Whisper](https://huggingface.co/openai/whisper-large-v3) | ||||||
|  | - [Keyword Spotting with Wav2Vec2](https://huggingface.co/superb/wav2vec2-base-superb-ks) | ||||||
|  | - [Audio Classification with Audio Spectrogram Transformer](https://huggingface.co/MIT/ast-finetuned-audioset-10-10-0.4593) | ||||||
|  |  | ||||||
|  | In Multimodal tasks: | ||||||
|  | - [Table Question Answering with TAPAS](https://huggingface.co/google/tapas-base-finetuned-wtq) | ||||||
|  | - [Visual Question Answering with ViLT](https://huggingface.co/dandelin/vilt-b32-finetuned-vqa) | ||||||
|  | - [Image captioning with LLaVa](https://huggingface.co/llava-hf/llava-1.5-7b-hf) | ||||||
|  | - [Zero-shot Image Classification with SigLIP](https://huggingface.co/google/siglip-so400m-patch14-384) | ||||||
|  | - [Document Question Answering with LayoutLM](https://huggingface.co/impira/layoutlm-document-qa) | ||||||
|  | - [Zero-shot Video Classification with X-CLIP](https://huggingface.co/docs/transformers/model_doc/xclip) | ||||||
|  | - [Zero-shot Object Detection with OWLv2](https://huggingface.co/docs/transformers/en/model_doc/owlv2) | ||||||
|  | - [Zero-shot Image Segmentation with CLIPSeg](https://huggingface.co/docs/transformers/model_doc/clipseg) | ||||||
|  | - [Automatic Mask Generation with SAM](https://huggingface.co/docs/transformers/model_doc/sam) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ## 100 projects using Transformers | ||||||
|  |  | ||||||
|  | Transformers is more than a toolkit to use pretrained models: it's a community of projects built around it and the | ||||||
|  | Hugging Face Hub. We want Transformers to enable developers, researchers, students, professors, engineers, and anyone | ||||||
|  | else to build their dream projects. | ||||||
|  |  | ||||||
|  | In order to celebrate the 100,000 stars of transformers, we have decided to put the spotlight on the | ||||||
|  | community, and we have created the [awesome-transformers](./awesome-transformers.md) page which lists 100 | ||||||
|  | incredible projects built in the vicinity of transformers. | ||||||
|  |  | ||||||
|  | If you own or use a project that you believe should be part of the list, please open a PR to add it! | ||||||
|  |  | ||||||
|  | ## Serious about AI in your organisation? Build faster with the Hugging Face Enterprise Hub. | ||||||
|  |  | ||||||
|  | <a target="_blank" href="https://huggingface.co/enterprise"> | ||||||
|  |     <img alt="Hugging Face Enterprise Hub" src="https://github.com/user-attachments/assets/247fb16d-d251-4583-96c4-d3d76dda4925"> | ||||||
|  | </a><br> | ||||||
|  |  | ||||||
|  | ## Quick tour | ||||||
|  |  | ||||||
|  | To immediately use a model on a given input (text, image, audio, ...), we provide the `pipeline` API. Pipelines group together a pretrained model with the preprocessing that was used during that model's training. Here is how to quickly use a pipeline to classify positive versus negative texts: | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | >>> from transformers import pipeline | ||||||
|  |  | ||||||
|  | # Allocate a pipeline for sentiment-analysis | ||||||
|  | >>> classifier = pipeline('sentiment-analysis') | ||||||
|  | >>> classifier('We are very happy to introduce pipeline to the transformers repository.') | ||||||
|  | [{'label': 'POSITIVE', 'score': 0.9996980428695679}] | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Install Transformers in your virtual environment. | The second line of code downloads and caches the pretrained model used by the pipeline, while the third evaluates it on the given text. Here, the answer is "positive" with a confidence of 99.97%. | ||||||
|  |  | ||||||
| ```py | Many tasks have a pre-trained `pipeline` ready to go, in NLP but also in computer vision and speech. For example, we can easily extract detected objects in an image: | ||||||
| # pip |  | ||||||
| pip install "transformers[torch]" |  | ||||||
|  |  | ||||||
| # uv | ``` python | ||||||
| uv pip install "transformers[torch]" | >>> import requests | ||||||
|  | >>> from PIL import Image | ||||||
|  | >>> from transformers import pipeline | ||||||
|  |  | ||||||
|  | # Download an image with cute cats | ||||||
|  | >>> url = "https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/coco_sample.png" | ||||||
|  | >>> image_data = requests.get(url, stream=True).raw | ||||||
|  | >>> image = Image.open(image_data) | ||||||
|  |  | ||||||
|  | # Allocate a pipeline for object detection | ||||||
|  | >>> object_detector = pipeline('object-detection') | ||||||
|  | >>> object_detector(image) | ||||||
|  | [{'score': 0.9982201457023621, | ||||||
|  |   'label': 'remote', | ||||||
|  |   'box': {'xmin': 40, 'ymin': 70, 'xmax': 175, 'ymax': 117}}, | ||||||
|  |  {'score': 0.9960021376609802, | ||||||
|  |   'label': 'remote', | ||||||
|  |   'box': {'xmin': 333, 'ymin': 72, 'xmax': 368, 'ymax': 187}}, | ||||||
|  |  {'score': 0.9954745173454285, | ||||||
|  |   'label': 'couch', | ||||||
|  |   'box': {'xmin': 0, 'ymin': 1, 'xmax': 639, 'ymax': 473}}, | ||||||
|  |  {'score': 0.9988006353378296, | ||||||
|  |   'label': 'cat', | ||||||
|  |   'box': {'xmin': 13, 'ymin': 52, 'xmax': 314, 'ymax': 470}}, | ||||||
|  |  {'score': 0.9986783862113953, | ||||||
|  |   'label': 'cat', | ||||||
|  |   'box': {'xmin': 345, 'ymin': 23, 'xmax': 640, 'ymax': 368}}] | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Install Transformers from source if you want the latest changes in the library or are interested in contributing. However, the *latest* version may not be stable. Feel free to open an [issue](https://github.com/huggingface/transformers/issues) if you encounter an error. | Here, we get a list of objects detected in the image, with a box surrounding the object and a confidence score. Here is the original image on the left, with the predictions displayed on the right: | ||||||
|  |  | ||||||
| ```shell |  | ||||||
| git clone https://github.com/huggingface/transformers.git |  | ||||||
| cd transformers |  | ||||||
|  |  | ||||||
| # pip |  | ||||||
| pip install .[torch] |  | ||||||
|  |  | ||||||
| # uv |  | ||||||
| uv pip install .[torch] |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## Quickstart |  | ||||||
|  |  | ||||||
| Get started with Transformers right away with the [Pipeline](https://huggingface.co/docs/transformers/pipeline_tutorial) API. The `Pipeline` is a high-level inference class that supports text, audio, vision, and multimodal tasks. It handles preprocessing the input and returns the appropriate output. |  | ||||||
|  |  | ||||||
| Instantiate a pipeline and specify model to use for text generation. The model is downloaded and cached so you can easily reuse it again. Finally, pass some text to prompt the model. |  | ||||||
|  |  | ||||||
| ```py |  | ||||||
| from transformers import pipeline |  | ||||||
|  |  | ||||||
| pipeline = pipeline(task="text-generation", model="Qwen/Qwen2.5-1.5B") |  | ||||||
| pipeline("the secret to baking a really good cake is ") |  | ||||||
| [{'generated_text': 'the secret to baking a really good cake is 1) to use the right ingredients and 2) to follow the recipe exactly. the recipe for the cake is as follows: 1 cup of sugar, 1 cup of flour, 1 cup of milk, 1 cup of butter, 1 cup of eggs, 1 cup of chocolate chips. if you want to make 2 cakes, how much sugar do you need? To make 2 cakes, you will need 2 cups of sugar.'}] |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| To chat with a model, the usage pattern is the same. The only difference is you need to construct a chat history (the input to `Pipeline`) between you and the system. |  | ||||||
|  |  | ||||||
| > [!TIP] |  | ||||||
| > You can also chat with a model directly from the command line. |  | ||||||
| > ```shell |  | ||||||
| > transformers chat Qwen/Qwen2.5-0.5B-Instruct |  | ||||||
| > ``` |  | ||||||
|  |  | ||||||
| ```py |  | ||||||
| import torch |  | ||||||
| from transformers import pipeline |  | ||||||
|  |  | ||||||
| chat = [ |  | ||||||
|     {"role": "system", "content": "You are a sassy, wise-cracking robot as imagined by Hollywood circa 1986."}, |  | ||||||
|     {"role": "user", "content": "Hey, can you tell me any fun things to do in New York?"} |  | ||||||
| ] |  | ||||||
|  |  | ||||||
| pipeline = pipeline(task="text-generation", model="meta-llama/Meta-Llama-3-8B-Instruct", torch_dtype=torch.bfloat16, device_map="auto") |  | ||||||
| response = pipeline(chat, max_new_tokens=512) |  | ||||||
| print(response[0]["generated_text"][-1]["content"]) |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Expand the examples below to see how `Pipeline` works for different modalities and tasks. |  | ||||||
|  |  | ||||||
| <details> |  | ||||||
| <summary>Automatic speech recognition</summary> |  | ||||||
|  |  | ||||||
| ```py |  | ||||||
| from transformers import pipeline |  | ||||||
|  |  | ||||||
| pipeline = pipeline(task="automatic-speech-recognition", model="openai/whisper-large-v3") |  | ||||||
| pipeline("https://huggingface.co/datasets/Narsil/asr_dummy/resolve/main/mlk.flac") |  | ||||||
| {'text': ' I have a dream that one day this nation will rise up and live out the true meaning of its creed.'} |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| </details> |  | ||||||
|  |  | ||||||
| <details> |  | ||||||
| <summary>Image classification</summary> |  | ||||||
|  |  | ||||||
| <h3 align="center"> | <h3 align="center"> | ||||||
|     <a><img src="https://huggingface.co/datasets/Narsil/image_dummy/raw/main/parrots.png"></a> |     <a><img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/coco_sample.png" width="400"></a> | ||||||
|  |     <a><img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/coco_sample_post_processed.png" width="400"></a> | ||||||
| </h3> | </h3> | ||||||
|  |  | ||||||
| ```py | You can learn more about the tasks supported by the `pipeline` API in [this tutorial](https://huggingface.co/docs/transformers/task_summary). | ||||||
| from transformers import pipeline |  | ||||||
|  |  | ||||||
| pipeline = pipeline(task="image-classification", model="facebook/dinov2-small-imagenet1k-1-layer") | In addition to `pipeline`, to download and use any of the pretrained models on your given task, all it takes is three lines of code. Here is the PyTorch version: | ||||||
| pipeline("https://huggingface.co/datasets/Narsil/image_dummy/raw/main/parrots.png") | ```python | ||||||
| [{'label': 'macaw', 'score': 0.997848391532898}, | >>> from transformers import AutoTokenizer, AutoModel | ||||||
|  {'label': 'sulphur-crested cockatoo, Kakatoe galerita, Cacatua galerita', |  | ||||||
|   'score': 0.0016551691805943847}, | >>> tokenizer = AutoTokenizer.from_pretrained("google-bert/bert-base-uncased") | ||||||
|  {'label': 'lorikeet', 'score': 0.00018523589824326336}, | >>> model = AutoModel.from_pretrained("google-bert/bert-base-uncased") | ||||||
|  {'label': 'African grey, African gray, Psittacus erithacus', |  | ||||||
|   'score': 7.85409429227002e-05}, | >>> inputs = tokenizer("Hello world!", return_tensors="pt") | ||||||
|  {'label': 'quail', 'score': 5.502637941390276e-05}] | >>> outputs = model(**inputs) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| </details> | And here is the equivalent code for TensorFlow: | ||||||
|  | ```python | ||||||
|  | >>> from transformers import AutoTokenizer, TFAutoModel | ||||||
|  |  | ||||||
| <details> | >>> tokenizer = AutoTokenizer.from_pretrained("google-bert/bert-base-uncased") | ||||||
| <summary>Visual question answering</summary> | >>> model = TFAutoModel.from_pretrained("google-bert/bert-base-uncased") | ||||||
|  |  | ||||||
|  | >>> inputs = tokenizer("Hello world!", return_tensors="tf") | ||||||
| <h3 align="center"> | >>> outputs = model(**inputs) | ||||||
|     <a><img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/transformers/tasks/idefics-few-shot.jpg"></a> |  | ||||||
| </h3> |  | ||||||
|  |  | ||||||
| ```py |  | ||||||
| from transformers import pipeline |  | ||||||
|  |  | ||||||
| pipeline = pipeline(task="visual-question-answering", model="Salesforce/blip-vqa-base") |  | ||||||
| pipeline( |  | ||||||
|     image="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/transformers/tasks/idefics-few-shot.jpg", |  | ||||||
|     question="What is in the image?", |  | ||||||
| ) |  | ||||||
| [{'answer': 'statue of liberty'}] |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| </details> | The tokenizer is responsible for all the preprocessing the pretrained model expects and can be called directly on a single string (as in the above examples) or a list. It will output a dictionary that you can use in downstream code or simply directly pass to your model using the ** argument unpacking operator. | ||||||
|  |  | ||||||
| ## Why should I use Transformers? | The model itself is a regular [Pytorch `nn.Module`](https://pytorch.org/docs/stable/nn.html#torch.nn.Module) or a [TensorFlow `tf.keras.Model`](https://www.tensorflow.org/api_docs/python/tf/keras/Model) (depending on your backend) which you can use as usual. [This tutorial](https://huggingface.co/docs/transformers/training) explains how to integrate such a model into a classic PyTorch or TensorFlow training loop, or how to use our `Trainer` API to quickly fine-tune on a new dataset. | ||||||
|  |  | ||||||
|  | ## Why should I use transformers? | ||||||
|  |  | ||||||
| 1. Easy-to-use state-of-the-art models: | 1. Easy-to-use state-of-the-art models: | ||||||
|     - High performance on natural language understanding & generation, computer vision, audio, video, and multimodal tasks. |     - High performance on natural language understanding & generation, computer vision, and audio tasks. | ||||||
|     - Low barrier to entry for researchers, engineers, and developers. |     - Low barrier to entry for educators and practitioners. | ||||||
|     - Few user-facing abstractions with just three classes to learn. |     - Few user-facing abstractions with just three classes to learn. | ||||||
|     - A unified API for using all our pretrained models. |     - A unified API for using all our pretrained models. | ||||||
|  |  | ||||||
| 1. Lower compute costs, smaller carbon footprint: | 1. Lower compute costs, smaller carbon footprint: | ||||||
|     - Share trained models instead of training from scratch. |     - Researchers can share trained models instead of always retraining. | ||||||
|     - Reduce compute time and production costs. |     - Practitioners can reduce compute time and production costs. | ||||||
|     - Dozens of model architectures with 1M+ pretrained checkpoints across all modalities. |     - Dozens of architectures with over 400,000 pretrained models across all modalities. | ||||||
|  |  | ||||||
| 1. Choose the right framework for every part of a models lifetime: | 1. Choose the right framework for every part of a model's lifetime: | ||||||
|     - Train state-of-the-art models in 3 lines of code. |     - Train state-of-the-art models in 3 lines of code. | ||||||
|     - Move a single model between PyTorch/JAX/TF2.0 frameworks at will. |     - Move a single model between TF2.0/PyTorch/JAX frameworks at will. | ||||||
|     - Pick the right framework for training, evaluation, and production. |     - Seamlessly pick the right framework for training, evaluation, and production. | ||||||
|  |  | ||||||
| 1. Easily customize a model or an example to your needs: | 1. Easily customize a model or an example to your needs: | ||||||
|     - We provide examples for each architecture to reproduce the results published by its original authors. |     - We provide examples for each architecture to reproduce the results published by its original authors. | ||||||
|     - Model internals are exposed as consistently as possible. |     - Model internals are exposed as consistently as possible. | ||||||
|     - Model files can be used independently of the library for quick experiments. |     - Model files can be used independently of the library for quick experiments. | ||||||
|  |  | ||||||
| <a target="_blank" href="https://huggingface.co/enterprise"> | ## Why shouldn't I use transformers? | ||||||
|     <img alt="Hugging Face Enterprise Hub" src="https://github.com/user-attachments/assets/247fb16d-d251-4583-96c4-d3d76dda4925"> |  | ||||||
| </a><br> |  | ||||||
|  |  | ||||||
| ## Why shouldn't I use Transformers? |  | ||||||
|  |  | ||||||
| - This library is not a modular toolbox of building blocks for neural nets. The code in the model files is not refactored with additional abstractions on purpose, so that researchers can quickly iterate on each of the models without diving into additional abstractions/files. | - This library is not a modular toolbox of building blocks for neural nets. The code in the model files is not refactored with additional abstractions on purpose, so that researchers can quickly iterate on each of the models without diving into additional abstractions/files. | ||||||
| - The training API is optimized to work with PyTorch models provided by Transformers. For generic machine learning loops, you should use another library like [Accelerate](https://huggingface.co/docs/accelerate). | - The training API is not intended to work on any model but is optimized to work with the models provided by the library. For generic machine learning loops, you should use another library (possibly, [Accelerate](https://huggingface.co/docs/accelerate)). | ||||||
| - The [example scripts]((https://github.com/huggingface/transformers/tree/main/examples)) are only *examples*. They may not necessarily work out-of-the-box on your specific use case and you'll need to adapt the code for it to work. | - While we strive to present as many use cases as possible, the scripts in our [examples folder](https://github.com/huggingface/transformers/tree/main/examples) are just that: examples. It is expected that they won't work out-of-the-box on your specific problem and that you will be required to change a few lines of code to adapt them to your needs. | ||||||
|  |  | ||||||
| ## 100 projects using Transformers | ## Installation | ||||||
|  |  | ||||||
| Transformers is more than a toolkit to use pretrained models, it's a community of projects built around it and the | ### With pip | ||||||
| Hugging Face Hub. We want Transformers to enable developers, researchers, students, professors, engineers, and anyone |  | ||||||
| else to build their dream projects. |  | ||||||
|  |  | ||||||
| In order to celebrate Transformers 100,000 stars, we wanted to put the spotlight on the | This repository is tested on Python 3.9+, Flax 0.4.1+, PyTorch 2.0+, and TensorFlow 2.6+. | ||||||
| community with the [awesome-transformers](./awesome-transformers.md) page which lists 100 |  | ||||||
| incredible projects built with Transformers. |  | ||||||
|  |  | ||||||
| If you own or use a project that you believe should be part of the list, please open a PR to add it! | You should install 🤗 Transformers in a [virtual environment](https://docs.python.org/3/library/venv.html). If you're unfamiliar with Python virtual environments, check out the [user guide](https://packaging.python.org/guides/installing-using-pip-and-virtual-environments/). | ||||||
|  |  | ||||||
| ## Example models | First, create a virtual environment with the version of Python you're going to use and activate it. | ||||||
|  |  | ||||||
| You can test most of our models directly on their [Hub model pages](https://huggingface.co/models). | **macOS/Linux** | ||||||
|  |  | ||||||
| Expand each modality below to see a few example models for various use cases. | ```python -m venv env | ||||||
|  | source env/bin/activate | ||||||
|  | ``` | ||||||
|  |  | ||||||
| <details> | **Windows** | ||||||
| <summary>Audio</summary> |  | ||||||
|  |  | ||||||
| - Audio classification with [Whisper](https://huggingface.co/openai/whisper-large-v3-turbo) | ``` python -m venv env | ||||||
| - Automatic speech recognition with [Moonshine](https://huggingface.co/UsefulSensors/moonshine) | env\Scripts\activate | ||||||
| - Keyword spotting with [Wav2Vec2](https://huggingface.co/superb/wav2vec2-base-superb-ks) | ``` | ||||||
| - Speech to speech generation with [Moshi](https://huggingface.co/kyutai/moshiko-pytorch-bf16) |  | ||||||
| - Text to audio with [MusicGen](https://huggingface.co/facebook/musicgen-large) |  | ||||||
| - Text to speech with [Bark](https://huggingface.co/suno/bark) |  | ||||||
|  |  | ||||||
| </details> | To use 🤗 Transformers, you must install at least one of Flax, PyTorch, or TensorFlow. Refer to the official installation guides for platform-specific commands: | ||||||
|  |  | ||||||
| <details> | [TensorFlow installation page](https://www.tensorflow.org/install/),  | ||||||
| <summary>Computer vision</summary> | [PyTorch installation page](https://pytorch.org/get-started/locally/#start-locally) and/or [Flax](https://github.com/google/flax#quick-install) and [Jax](https://github.com/google/jax#installation)  | ||||||
|  |  | ||||||
| - Automatic mask generation with [SAM](https://huggingface.co/facebook/sam-vit-base) | When one of those backends has been installed, 🤗 Transformers can be installed using pip as follows: | ||||||
| - Depth estimation with [DepthPro](https://huggingface.co/apple/DepthPro-hf) |  | ||||||
| - Image classification with [DINO v2](https://huggingface.co/facebook/dinov2-base) |  | ||||||
| - Keypoint detection with [SuperGlue](https://huggingface.co/magic-leap-community/superglue_outdoor) |  | ||||||
| - Keypoint matching with [SuperGlue](https://huggingface.co/magic-leap-community/superglue) |  | ||||||
| - Object detection with [RT-DETRv2](https://huggingface.co/PekingU/rtdetr_v2_r50vd) |  | ||||||
| - Pose Estimation with [VitPose](https://huggingface.co/usyd-community/vitpose-base-simple) |  | ||||||
| - Universal segmentation with [OneFormer](https://huggingface.co/shi-labs/oneformer_ade20k_swin_large) |  | ||||||
| - Video classification with [VideoMAE](https://huggingface.co/MCG-NJU/videomae-large) |  | ||||||
|  |  | ||||||
| </details> | ``` | ||||||
|  | pip install transformers | ||||||
|  | ``` | ||||||
|  |  | ||||||
| <details> | If you'd like to play with the examples or need the bleeding edge of the code and can't wait for a new release, you must [install the library from source](https://huggingface.co/docs/transformers/installation#installing-from-source). | ||||||
| <summary>Multimodal</summary> |  | ||||||
|  |  | ||||||
| - Audio or text to text with [Qwen2-Audio](https://huggingface.co/Qwen/Qwen2-Audio-7B) | ``` | ||||||
| - Document question answering with [LayoutLMv3](https://huggingface.co/microsoft/layoutlmv3-base) | git clone https://github.com/huggingface/transformers.git | ||||||
| - Image or text to text with [Qwen-VL](https://huggingface.co/Qwen/Qwen2.5-VL-3B-Instruct) | cd transformers | ||||||
| - Image captioning [BLIP-2](https://huggingface.co/Salesforce/blip2-opt-2.7b) | pip install . | ||||||
| - OCR-based document understanding with [GOT-OCR2](https://huggingface.co/stepfun-ai/GOT-OCR-2.0-hf) | ``` | ||||||
| - Table question answering with [TAPAS](https://huggingface.co/google/tapas-base) |  | ||||||
| - Unified multimodal understanding and generation with [Emu3](https://huggingface.co/BAAI/Emu3-Gen) |  | ||||||
| - Vision to text with [Llava-OneVision](https://huggingface.co/llava-hf/llava-onevision-qwen2-0.5b-ov-hf) |  | ||||||
| - Visual question answering with [Llava](https://huggingface.co/llava-hf/llava-1.5-7b-hf) |  | ||||||
| - Visual referring expression segmentation with [Kosmos-2](https://huggingface.co/microsoft/kosmos-2-patch14-224) |  | ||||||
|  |  | ||||||
| </details> | ### With conda | ||||||
|  |  | ||||||
| <details> | 🤗 Transformers can be installed using conda as follows: | ||||||
| <summary>NLP</summary> |  | ||||||
|  |  | ||||||
| - Masked word completion with [ModernBERT](https://huggingface.co/answerdotai/ModernBERT-base) | ```shell script | ||||||
| - Named entity recognition with [Gemma](https://huggingface.co/google/gemma-2-2b) | conda install conda-forge::transformers | ||||||
| - Question answering with [Mixtral](https://huggingface.co/mistralai/Mixtral-8x7B-v0.1) | ``` | ||||||
| - Summarization with [BART](https://huggingface.co/facebook/bart-large-cnn) |  | ||||||
| - Translation with [T5](https://huggingface.co/google-t5/t5-base) |  | ||||||
| - Text generation with [Llama](https://huggingface.co/meta-llama/Llama-3.2-1B) |  | ||||||
| - Text classification with [Qwen](https://huggingface.co/Qwen/Qwen2.5-0.5B) |  | ||||||
|  |  | ||||||
| </details> | > **_NOTE:_** Installing `transformers` from the `huggingface` channel is deprecated. | ||||||
|  |  | ||||||
|  | Follow the installation pages of Flax, PyTorch or TensorFlow to see how to install them with conda. | ||||||
|  |  | ||||||
|  | > **_NOTE:_**  On Windows, you may be prompted to activate Developer Mode in order to benefit from caching. If this is not an option for you, please let us know in [this issue](https://github.com/huggingface/huggingface_hub/issues/1062). | ||||||
|  |  | ||||||
|  | ## Model architectures | ||||||
|  |  | ||||||
|  | **[All the model checkpoints](https://huggingface.co/models)** provided by 🤗 Transformers are seamlessly integrated from the huggingface.co [model hub](https://huggingface.co/models), where they are uploaded directly by [users](https://huggingface.co/users) and [organizations](https://huggingface.co/organizations). | ||||||
|  |  | ||||||
|  | Current number of checkpoints:  | ||||||
|  |  | ||||||
|  | 🤗 Transformers currently provides the following architectures: see [here](https://huggingface.co/docs/transformers/model_summary) for a high-level summary of each them. | ||||||
|  |  | ||||||
|  | To check if each model has an implementation in Flax, PyTorch or TensorFlow, or has an associated tokenizer backed by the 🤗 Tokenizers library, refer to [this table](https://huggingface.co/docs/transformers/index#supported-frameworks). | ||||||
|  |  | ||||||
|  | These implementations have been tested on several datasets (see the example scripts) and should match the performance of the original implementations. You can find more details on performance in the Examples section of the [documentation](https://github.com/huggingface/transformers/tree/main/examples). | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ## Learn more | ||||||
|  |  | ||||||
|  | | Section | Description | | ||||||
|  | |-|-| | ||||||
|  | | [Documentation](https://huggingface.co/docs/transformers/) | Full API documentation and tutorials | | ||||||
|  | | [Task summary](https://huggingface.co/docs/transformers/task_summary) | Tasks supported by 🤗 Transformers | | ||||||
|  | | [Preprocessing tutorial](https://huggingface.co/docs/transformers/preprocessing) | Using the `Tokenizer` class to prepare data for the models | | ||||||
|  | | [Training and fine-tuning](https://huggingface.co/docs/transformers/training) | Using the models provided by 🤗 Transformers in a PyTorch/TensorFlow training loop and the `Trainer` API | | ||||||
|  | | [Quick tour: Fine-tuning/usage scripts](https://github.com/huggingface/transformers/tree/main/examples) | Example scripts for fine-tuning models on a wide range of tasks | | ||||||
|  | | [Model sharing and uploading](https://huggingface.co/docs/transformers/model_sharing) | Upload and share your fine-tuned models with the community | | ||||||
|  |  | ||||||
| ## Citation | ## Citation | ||||||
|  |  | ||||||
|  | |||||||
| @ -27,6 +27,13 @@ These models require the `trust_remote_code=True` parameter to be set when using | |||||||
| the content of the modeling files when using this argument. We recommend setting a revision in order to ensure you | the content of the modeling files when using this argument. We recommend setting a revision in order to ensure you | ||||||
| protect yourself from updates on the repository. | protect yourself from updates on the repository. | ||||||
|  |  | ||||||
|  | #### Tools | ||||||
|  |  | ||||||
|  | Through the `Agent` framework, remote tools can be downloaded to be used by the Agent. You're to specify these tools | ||||||
|  | yourself, but please keep in mind that their code will be run on your machine if the Agent chooses to run them. | ||||||
|  |  | ||||||
|  | Please inspect the code of the tools before passing them to the Agent to protect your runtime and local setup. | ||||||
|  |  | ||||||
| ## Reporting a Vulnerability | ## Reporting a Vulnerability | ||||||
|  |  | ||||||
| Feel free to submit vulnerability reports to [security@huggingface.co](mailto:security@huggingface.co), where someone from the HF security team will review and recommend next steps. If reporting a vulnerability specific to open source, please note [Huntr](https://huntr.com) is a vulnerability disclosure program for open source software. | Feel free to submit vulnerability reports to [security@huggingface.co](mailto:security@huggingface.co), where someone from the HF security team will review and recommend next steps. If reporting a vulnerability specific to open source, please note [Huntr](https://huntr.com) is a vulnerability disclosure program for open source software. | ||||||
|  | |||||||
| @ -15,7 +15,7 @@ to add it. | |||||||
|  |  | ||||||
| Keywords: Open-source, LLaMa, GPT-J, instruction, assistant | Keywords: Open-source, LLaMa, GPT-J, instruction, assistant | ||||||
|  |  | ||||||
| ## [recommenders](https://github.com/recommenders-team/recommenders) | ## [recommenders](https://github.com/microsoft/recommenders) | ||||||
|  |  | ||||||
| This repository contains examples and best practices for building recommendation systems, provided as Jupyter notebooks. It goes over several aspects required to build efficient recommendation systems: data preparation, modeling, evaluation, model selection & optimization, as well as operationalization | This repository contains examples and best practices for building recommendation systems, provided as Jupyter notebooks. It goes over several aspects required to build efficient recommendation systems: data preparation, modeling, evaluation, model selection & optimization, as well as operationalization | ||||||
|  |  | ||||||
| @ -29,7 +29,7 @@ Keywords: inpainting, SD, Stable Diffusion | |||||||
|  |  | ||||||
| ## [flair](https://github.com/flairNLP/flair) | ## [flair](https://github.com/flairNLP/flair) | ||||||
|  |  | ||||||
| FLAIR is a powerful PyTorch NLP framework, covering several important tasks: NER, sentiment-analysis, part-of-speech tagging, text and document embeddings, among other things. | FLAIR is a powerful PyTorch NLP framework, convering several important tasks: NER, sentiment-analysis, part-of-speech tagging, text and document embeddings, among other things. | ||||||
|  |  | ||||||
| Keywords: NLP, text embedding, document embedding, biomedical, NER, PoS, sentiment-analysis | Keywords: NLP, text embedding, document embedding, biomedical, NER, PoS, sentiment-analysis | ||||||
|  |  | ||||||
| @ -39,15 +39,15 @@ MindsDB is a low-code ML platform, which automates and integrates several ML fra | |||||||
|  |  | ||||||
| Keywords: Database, low-code, AI table | Keywords: Database, low-code, AI table | ||||||
|  |  | ||||||
| ## [langchain](https://github.com/langchain-ai/langchain) | ## [langchain](https://github.com/hwchase17/langchain) | ||||||
|  |  | ||||||
| [langchain](https://github.com/langchain-ai/langchain) is aimed at assisting in the development of apps merging both LLMs and other sources of knowledge. The library allows chaining calls to applications, creating a sequence across many tools. | [langchain](https://github.com/hwchase17/langchain) is aimed at assisting in the development of apps merging both LLMs and other sources of knowledge. The library allows chaining calls to applications, creating a sequence across many tools. | ||||||
|  |  | ||||||
| Keywords: LLMs, Large Language Models, Agents, Chains | Keywords: LLMs, Large Language Models, Agents, Chains | ||||||
|  |  | ||||||
| ## [LlamaIndex](https://github.com/run-llama/llama_index) | ## [LlamaIndex](https://github.com/jerryjliu/llama_index) | ||||||
|  |  | ||||||
| [LlamaIndex](https://github.com/run-llama/llama_index) is a project that provides a central interface to connect your LLM's with external data. It provides various kinds of indices and retrieval mechanisms to perform different LLM tasks and obtain knowledge-augmented results. | [LlamaIndex](https://github.com/jerryjliu/llama_index) is a project that provides a central interface to connect your LLM's with external data. It provides various kinds of indices and retreival mechanisms to perform different LLM tasks and obtain knowledge-augmented results. | ||||||
|  |  | ||||||
| Keywords: LLMs, Large Language Models, Data Retrieval, Indices, Knowledge Augmentation  | Keywords: LLMs, Large Language Models, Data Retrieval, Indices, Knowledge Augmentation  | ||||||
|  |  | ||||||
| @ -146,9 +146,9 @@ Keywords: Framework, simplicity, NLP | |||||||
|  |  | ||||||
| Keywords: LLM, Agents, HF Hub | Keywords: LLM, Agents, HF Hub | ||||||
|  |  | ||||||
| ## [transformers.js](https://github.com/huggingface/transformers.js/) | ## [transformers.js](https://xenova.github.io/transformers.js/) | ||||||
|  |  | ||||||
| [transformers.js](https://github.com/huggingface/transformers.js/) is a JavaScript library targeted at running models from transformers directly within the browser. | [transformers.js](https://xenova.github.io/transformers.js/) is a JavaScript library targeted at running models from transformers directly within the browser. | ||||||
|  |  | ||||||
| Keywords: Transformers, JavaScript, browser | Keywords: Transformers, JavaScript, browser | ||||||
|  |  | ||||||
| @ -437,7 +437,7 @@ Keywords: DALL-E, Russian | |||||||
|  |  | ||||||
| Keywords: Knowledge Extraction, Knowledge Graphs | Keywords: Knowledge Extraction, Knowledge Graphs | ||||||
|  |  | ||||||
| ## [Nebuly](https://github.com/nebuly-ai/optimate) | ## [Nebuly](https://github.com/nebuly-ai/nebuly) | ||||||
|  |  | ||||||
| Nebuly is the next-generation platform to monitor and optimize your AI costs in one place. The platform connects to all your AI cost sources (compute, API providers, AI software licenses, etc) and centralizes them in one place to give you full visibility on a model basis. The platform also provides optimization recommendations and a co-pilot model that can guide during the optimization process. The platform builds on top of the open-source tools allowing you to optimize the different steps of your AI stack to squeeze out the best possible cost performances. | Nebuly is the next-generation platform to monitor and optimize your AI costs in one place. The platform connects to all your AI cost sources (compute, API providers, AI software licenses, etc) and centralizes them in one place to give you full visibility on a model basis. The platform also provides optimization recommendations and a co-pilot model that can guide during the optimization process. The platform builds on top of the open-source tools allowing you to optimize the different steps of your AI stack to squeeze out the best possible cost performances. | ||||||
|  |  | ||||||
|  | |||||||
| @ -12,7 +12,7 @@ def run_benchmark(logger: Logger, branch: str, commit_id: str, commit_msg: str, | |||||||
|  |  | ||||||
| ## Writing metrics to the database | ## Writing metrics to the database | ||||||
|  |  | ||||||
| `MetricsRecorder` is thread-safe, in the sense of the python [`Thread`](https://docs.python.org/3/library/threading.html#threading.Thread). This means you can start a background thread to do the readings on the device measurements while not blocking the main thread to execute the model measurements. | `MetricRecorder` is thread-safe, in the sense of the python [`Thread`](https://docs.python.org/3/library/threading.html#threading.Thread). This means you can start a background thread to do the readings on the device measurements while not blocking the main thread to execute the model measurements. | ||||||
|  |  | ||||||
| cf [`llama.py`](./llama.py) to see an example of this in practice. | cf [`llama.py`](./llama.py) to see an example of this in practice. | ||||||
|  |  | ||||||
|  | |||||||
| @ -90,7 +90,7 @@ def summarize(run_dir, metrics, expand_metrics=False): | |||||||
|  |  | ||||||
|         model = benchmark.config.backend["model"] |         model = benchmark.config.backend["model"] | ||||||
|  |  | ||||||
|         # This looks like `benchmark.input_shapes.batch_size=1,benchmark.input_shapes.sequence_length=5`. |         # Ths looks like `benchmark.input_shapes.batch_size=1,benchmark.input_shapes.sequence_length=5`. | ||||||
|         # (we rely on the usage of hydra's `${hydra.job.override_dirname}`.) |         # (we rely on the usage of hydra's `${hydra.job.override_dirname}`.) | ||||||
|         benchmark_name = re.sub(f"backend.model={model},*", "", report_dir) |         benchmark_name = re.sub(f"backend.model={model},*", "", report_dir) | ||||||
|         benchmark_name = str(Path(benchmark_name).parts[-1]) |         benchmark_name = str(Path(benchmark_name).parts[-1]) | ||||||
|  | |||||||
| @ -2,11 +2,12 @@ import argparse | |||||||
| import importlib.util | import importlib.util | ||||||
| import logging | import logging | ||||||
| import os | import os | ||||||
|  | from typing import Dict | ||||||
|  | import psycopg2 | ||||||
| import sys | import sys | ||||||
| from typing import Dict, Tuple |  | ||||||
|  |  | ||||||
| from psycopg2.extensions import register_adapter |  | ||||||
| from psycopg2.extras import Json | from psycopg2.extras import Json | ||||||
|  | from psycopg2.extensions import register_adapter | ||||||
|  |  | ||||||
|  |  | ||||||
| register_adapter(dict, Json) | register_adapter(dict, Json) | ||||||
| @ -17,26 +18,23 @@ class ImportModuleException(Exception): | |||||||
|  |  | ||||||
|  |  | ||||||
| class MetricsRecorder: | class MetricsRecorder: | ||||||
|     def __init__( |     def __init__(self, connection, logger: logging.Logger, branch: str, commit_id: str, commit_msg: str): | ||||||
|         self, connection, logger: logging.Logger, repository: str, branch: str, commit_id: str, commit_msg: str |  | ||||||
|     ): |  | ||||||
|         self.conn = connection |         self.conn = connection | ||||||
|         self.conn.autocommit = True |         self.conn.autocommit = True | ||||||
|         self.logger = logger |         self.logger = logger | ||||||
|         self.repository = repository |  | ||||||
|         self.branch = branch |         self.branch = branch | ||||||
|         self.commit_id = commit_id |         self.commit_id = commit_id | ||||||
|         self.commit_msg = commit_msg |         self.commit_msg = commit_msg | ||||||
|  |  | ||||||
|     def initialise_benchmark(self, metadata: dict[str, str]) -> int: |     def initialise_benchmark(self, metadata: Dict[str, str]) -> int: | ||||||
|         """ |         """ | ||||||
|         Creates a new benchmark, returns the benchmark id |         Creates a new benchmark, returns the benchmark id | ||||||
|         """ |         """ | ||||||
|         # gpu_name: str, model_id: str |         # gpu_name: str, model_id: str | ||||||
|         with self.conn.cursor() as cur: |         with self.conn.cursor() as cur: | ||||||
|             cur.execute( |             cur.execute( | ||||||
|                 "INSERT INTO benchmarks (repository, branch, commit_id, commit_message, metadata) VALUES (%s, %s, %s, %s, %s) RETURNING benchmark_id", |                 "INSERT INTO benchmarks (branch, commit_id, commit_message, metadata) VALUES (%s, %s, %s, %s) RETURNING benchmark_id", | ||||||
|                 (self.repository, self.branch, self.commit_id, self.commit_msg, metadata), |                 (self.branch, self.commit_id, self.commit_msg, metadata), | ||||||
|             ) |             ) | ||||||
|             benchmark_id = cur.fetchone()[0] |             benchmark_id = cur.fetchone()[0] | ||||||
|             logger.debug(f"initialised benchmark #{benchmark_id}") |             logger.debug(f"initialised benchmark #{benchmark_id}") | ||||||
| @ -55,7 +53,7 @@ class MetricsRecorder: | |||||||
|             f"inserted device measurements for benchmark #{benchmark_id} [CPU util: {cpu_util}, mem MBs: {mem_megabytes}, GPU util: {gpu_util}, GPU mem MBs: {gpu_mem_megabytes}]" |             f"inserted device measurements for benchmark #{benchmark_id} [CPU util: {cpu_util}, mem MBs: {mem_megabytes}, GPU util: {gpu_util}, GPU mem MBs: {gpu_mem_megabytes}]" | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|     def collect_model_measurements(self, benchmark_id: int, measurements: dict[str, float]): |     def collect_model_measurements(self, benchmark_id: int, measurements: Dict[str, float]): | ||||||
|         with self.conn.cursor() as cur: |         with self.conn.cursor() as cur: | ||||||
|             cur.execute( |             cur.execute( | ||||||
|                 """ |                 """ | ||||||
| @ -85,18 +83,12 @@ handler.setFormatter(formatter) | |||||||
| logger.addHandler(handler) | logger.addHandler(handler) | ||||||
|  |  | ||||||
|  |  | ||||||
| def parse_arguments() -> tuple[str, str, str, str]: | def parse_arguments(): | ||||||
|     """ |     """ | ||||||
|     Parse command line arguments for the benchmarking CLI. |     Parse command line arguments for the benchmarking CLI. | ||||||
|     """ |     """ | ||||||
|     parser = argparse.ArgumentParser(description="CLI for benchmarking the huggingface/transformers.") |     parser = argparse.ArgumentParser(description="CLI for benchmarking the huggingface/transformers.") | ||||||
|  |  | ||||||
|     parser.add_argument( |  | ||||||
|         "repository", |  | ||||||
|         type=str, |  | ||||||
|         help="The repository name on which the benchmarking is performed.", |  | ||||||
|     ) |  | ||||||
|  |  | ||||||
|     parser.add_argument( |     parser.add_argument( | ||||||
|         "branch", |         "branch", | ||||||
|         type=str, |         type=str, | ||||||
| @ -117,7 +109,7 @@ def parse_arguments() -> tuple[str, str, str, str]: | |||||||
|  |  | ||||||
|     args = parser.parse_args() |     args = parser.parse_args() | ||||||
|  |  | ||||||
|     return args.repository, args.branch, args.commit_id, args.commit_msg |     return args.branch, args.commit_id, args.commit_msg | ||||||
|  |  | ||||||
|  |  | ||||||
| def import_from_path(module_name, file_path): | def import_from_path(module_name, file_path): | ||||||
| @ -134,7 +126,7 @@ def import_from_path(module_name, file_path): | |||||||
| if __name__ == "__main__": | if __name__ == "__main__": | ||||||
|     benchmarks_folder_path = os.path.dirname(os.path.realpath(__file__)) |     benchmarks_folder_path = os.path.dirname(os.path.realpath(__file__)) | ||||||
|  |  | ||||||
|     repository, branch, commit_id, commit_msg = parse_arguments() |     branch, commit_id, commit_msg = parse_arguments() | ||||||
|  |  | ||||||
|     for entry in os.scandir(benchmarks_folder_path): |     for entry in os.scandir(benchmarks_folder_path): | ||||||
|         try: |         try: | ||||||
| @ -144,8 +136,8 @@ if __name__ == "__main__": | |||||||
|                 continue |                 continue | ||||||
|             logger.debug(f"loading: {entry.name}") |             logger.debug(f"loading: {entry.name}") | ||||||
|             module = import_from_path(entry.name.split(".")[0], entry.path) |             module = import_from_path(entry.name.split(".")[0], entry.path) | ||||||
|             logger.info(f"running benchmarks in: {entry.name}") |             logger.info(f"runnning benchmarks in: {entry.name}") | ||||||
|             module.run_benchmark(logger, repository, branch, commit_id, commit_msg) |             module.run_benchmark(logger, branch, commit_id, commit_msg) | ||||||
|         except ImportModuleException as e: |         except ImportModuleException as e: | ||||||
|             logger.error(e) |             logger.error(e) | ||||||
|         except Exception as e: |         except Exception as e: | ||||||
|  | |||||||
| @ -1,6 +1,5 @@ | |||||||
| CREATE TABLE IF NOT EXISTS benchmarks ( | CREATE TABLE IF NOT EXISTS benchmarks ( | ||||||
|   benchmark_id SERIAL PRIMARY KEY, |   benchmark_id SERIAL PRIMARY KEY, | ||||||
|   repository VARCHAR(255), |  | ||||||
|   branch VARCHAR(255), |   branch VARCHAR(255), | ||||||
|   commit_id VARCHAR(72), |   commit_id VARCHAR(72), | ||||||
|   commit_message VARCHAR(70), |   commit_message VARCHAR(70), | ||||||
|  | |||||||
| @ -33,15 +33,11 @@ def collect_metrics(benchmark_id, continue_metric_collection, metrics_recorder): | |||||||
|         sleep(0.01) |         sleep(0.01) | ||||||
|  |  | ||||||
|  |  | ||||||
| def run_benchmark( | def run_benchmark(logger: Logger, branch: str, commit_id: str, commit_msg: str, num_tokens_to_generate=100): | ||||||
|     logger: Logger, repository: str, branch: str, commit_id: str, commit_msg: str, num_tokens_to_generate=100 |  | ||||||
| ): |  | ||||||
|     continue_metric_collection = Event() |     continue_metric_collection = Event() | ||||||
|     metrics_thread = None |     metrics_thread = None | ||||||
|     model_id = "meta-llama/Llama-2-7b-hf" |     model_id = "meta-llama/Llama-2-7b-hf" | ||||||
|     metrics_recorder = MetricsRecorder( |     metrics_recorder = MetricsRecorder(psycopg2.connect("dbname=metrics"), logger, branch, commit_id, commit_msg) | ||||||
|         psycopg2.connect("dbname=metrics"), logger, repository, branch, commit_id, commit_msg |  | ||||||
|     ) |  | ||||||
|     try: |     try: | ||||||
|         gpu_stats = gpustat.GPUStatCollection.new_query() |         gpu_stats = gpustat.GPUStatCollection.new_query() | ||||||
|         gpu_name = gpu_stats[0]["name"] |         gpu_name = gpu_stats[0]["name"] | ||||||
| @ -122,7 +118,7 @@ def run_benchmark( | |||||||
|         with torch.no_grad(): |         with torch.no_grad(): | ||||||
|             past_key_values = StaticCache( |             past_key_values = StaticCache( | ||||||
|                 model.config, |                 model.config, | ||||||
|                 max_batch_size=batch_size, |                 batch_size=batch_size, | ||||||
|                 device=device, |                 device=device, | ||||||
|                 dtype=torch.float16, |                 dtype=torch.float16, | ||||||
|                 max_cache_len=seq_length + num_tokens_to_generate, |                 max_cache_len=seq_length + num_tokens_to_generate, | ||||||
| @ -148,7 +144,7 @@ def run_benchmark( | |||||||
|  |  | ||||||
|             past_key_values = StaticCache( |             past_key_values = StaticCache( | ||||||
|                 model.config, |                 model.config, | ||||||
|                 max_batch_size=batch_size, |                 batch_size=batch_size, | ||||||
|                 device=device, |                 device=device, | ||||||
|                 dtype=torch.float16, |                 dtype=torch.float16, | ||||||
|                 max_cache_len=seq_length + num_tokens_to_generate, |                 max_cache_len=seq_length + num_tokens_to_generate, | ||||||
| @ -191,7 +187,7 @@ def run_benchmark( | |||||||
|             # TODO use  decode_one_token(model, input_id.clone(), cache_position) for verification |             # TODO use  decode_one_token(model, input_id.clone(), cache_position) for verification | ||||||
|             past_key_values = StaticCache( |             past_key_values = StaticCache( | ||||||
|                 model.config, |                 model.config, | ||||||
|                 max_batch_size=batch_size, |                 batch_size=batch_size, | ||||||
|                 device=device, |                 device=device, | ||||||
|                 dtype=torch.float16, |                 dtype=torch.float16, | ||||||
|                 max_cache_len=seq_length + num_tokens_to_generate + 10, |                 max_cache_len=seq_length + num_tokens_to_generate + 10, | ||||||
| @ -208,7 +204,7 @@ def run_benchmark( | |||||||
|             time_to_first_token = end - start |             time_to_first_token = end - start | ||||||
|             logger.info(f"completed first compile generation in: {time_to_first_token}s") |             logger.info(f"completed first compile generation in: {time_to_first_token}s") | ||||||
|             cache_position += 1 |             cache_position += 1 | ||||||
|             all_generated_tokens += next_token.tolist() |             all_generated_tokens += next_token.clone().detach().cpu().tolist() | ||||||
|  |  | ||||||
|             cache_position = torch.tensor([seq_length], device=device) |             cache_position = torch.tensor([seq_length], device=device) | ||||||
|             ### First compile, decoding |             ### First compile, decoding | ||||||
| @ -219,9 +215,9 @@ def run_benchmark( | |||||||
|             torch.cuda.synchronize() |             torch.cuda.synchronize() | ||||||
|             end = perf_counter() |             end = perf_counter() | ||||||
|             time_to_second_token = end - start |             time_to_second_token = end - start | ||||||
|             logger.info(f"completed second compile generation in: {time_to_second_token}s") |             logger.info(f"completed second compile generation in: {time_to_first_token}s") | ||||||
|             cache_position += 1 |             cache_position += 1 | ||||||
|             all_generated_tokens += next_token.tolist() |             all_generated_tokens += next_token.clone().detach().cpu().tolist() | ||||||
|  |  | ||||||
|             ### Second compile, decoding |             ### Second compile, decoding | ||||||
|             start = perf_counter() |             start = perf_counter() | ||||||
| @ -231,15 +227,15 @@ def run_benchmark( | |||||||
|             torch.cuda.synchronize() |             torch.cuda.synchronize() | ||||||
|             end = perf_counter() |             end = perf_counter() | ||||||
|             time_to_third_token = end - start |             time_to_third_token = end - start | ||||||
|             logger.info(f"completed third compile forward in: {time_to_third_token}s") |             logger.info(f"completed third compile forward in: {time_to_first_token}s") | ||||||
|             cache_position += 1 |             cache_position += 1 | ||||||
|             all_generated_tokens += next_token.tolist() |             all_generated_tokens += next_token.clone().detach().cpu().tolist() | ||||||
|  |  | ||||||
|             ### Using cuda graphs decoding |             ### Using cuda graphs decoding | ||||||
|  |  | ||||||
|             start = perf_counter() |             start = perf_counter() | ||||||
|             for _ in range(1, num_tokens_to_generate): |             for _ in range(1, num_tokens_to_generate): | ||||||
|                 all_generated_tokens += next_token.tolist() |                 all_generated_tokens += next_token.clone().detach().cpu().tolist() | ||||||
|                 next_token = decode_one_token( |                 next_token = decode_one_token( | ||||||
|                     model, next_token.clone(), cache_position=cache_position, past_key_values=past_key_values |                     model, next_token.clone(), cache_position=cache_position, past_key_values=past_key_values | ||||||
|                 ) |                 ) | ||||||
| @ -258,7 +254,7 @@ def run_benchmark( | |||||||
|  |  | ||||||
|             past_key_values = StaticCache( |             past_key_values = StaticCache( | ||||||
|                 model.config, |                 model.config, | ||||||
|                 max_batch_size=batch_size, |                 batch_size=batch_size, | ||||||
|                 device=device, |                 device=device, | ||||||
|                 dtype=torch.float16, |                 dtype=torch.float16, | ||||||
|                 max_cache_len=seq_length + 128, |                 max_cache_len=seq_length + 128, | ||||||
| @ -275,7 +271,7 @@ def run_benchmark( | |||||||
|  |  | ||||||
|             past_key_values = StaticCache( |             past_key_values = StaticCache( | ||||||
|                 model.config, |                 model.config, | ||||||
|                 max_batch_size=batch_size, |                 batch_size=batch_size, | ||||||
|                 device=device, |                 device=device, | ||||||
|                 dtype=torch.float16, |                 dtype=torch.float16, | ||||||
|                 max_cache_len=seq_length + 128, |                 max_cache_len=seq_length + 128, | ||||||
| @ -291,23 +287,23 @@ def run_benchmark( | |||||||
|  |  | ||||||
|             past_key_values = StaticCache( |             past_key_values = StaticCache( | ||||||
|                 model.config, |                 model.config, | ||||||
|                 max_batch_size=batch_size, |                 batch_size=batch_size, | ||||||
|                 device=device, |                 device=device, | ||||||
|                 dtype=torch.float16, |                 dtype=torch.float16, | ||||||
|                 max_cache_len=seq_length + 128, |                 max_cache_len=seq_length + 128, | ||||||
|             ) |             ) | ||||||
|  |  | ||||||
|             # 3rd call |             # 3nd call | ||||||
|             start = perf_counter() |             start = perf_counter() | ||||||
|             output = model.generate(**inputs, past_key_values=past_key_values) |             output = model.generate(**inputs, past_key_values=past_key_values) | ||||||
|             end = perf_counter() |             end = perf_counter() | ||||||
|             third_compile_generate_time = end - start |             third_compile_generate_time = end - start | ||||||
|             logger.info(f"completed third compile generation in: {third_compile_generate_time}s") |             logger.info(f"completed second compile generation in: {third_compile_generate_time}s") | ||||||
|             logger.info(f"generated: {tokenizer.batch_decode(output.cpu().tolist())}") |             logger.info(f"generated: {tokenizer.batch_decode(output.cpu().tolist())}") | ||||||
|  |  | ||||||
|             past_key_values = StaticCache( |             past_key_values = StaticCache( | ||||||
|                 model.config, |                 model.config, | ||||||
|                 max_batch_size=batch_size, |                 batch_size=batch_size, | ||||||
|                 device=device, |                 device=device, | ||||||
|                 dtype=torch.float16, |                 dtype=torch.float16, | ||||||
|                 max_cache_len=seq_length + 128, |                 max_cache_len=seq_length + 128, | ||||||
| @ -317,7 +313,7 @@ def run_benchmark( | |||||||
|             output = model.generate(**inputs, past_key_values=past_key_values) |             output = model.generate(**inputs, past_key_values=past_key_values) | ||||||
|             end = perf_counter() |             end = perf_counter() | ||||||
|             fourth_compile_generate_time = end - start |             fourth_compile_generate_time = end - start | ||||||
|             logger.info(f"completed fourth compile generation in: {fourth_compile_generate_time}s") |             logger.info(f"completed second compile generation in: {fourth_compile_generate_time}s") | ||||||
|             logger.info(f"generated: {tokenizer.batch_decode(output.cpu().tolist())}") |             logger.info(f"generated: {tokenizer.batch_decode(output.cpu().tolist())}") | ||||||
|  |  | ||||||
|         metrics_recorder.collect_model_measurements( |         metrics_recorder.collect_model_measurements( | ||||||
|  | |||||||
							
								
								
									
										13
									
								
								conftest.py
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								conftest.py
									
									
									
									
									
								
							| @ -46,6 +46,10 @@ NOT_DEVICE_TESTS = { | |||||||
|     "test_keep_in_fp32_modules", |     "test_keep_in_fp32_modules", | ||||||
|     "test_gradient_checkpointing_backward_compatibility", |     "test_gradient_checkpointing_backward_compatibility", | ||||||
|     "test_gradient_checkpointing_enable_disable", |     "test_gradient_checkpointing_enable_disable", | ||||||
|  |     "test_save_load_fast_init_from_base", | ||||||
|  |     "test_fast_init_context_manager", | ||||||
|  |     "test_fast_init_tied_embeddings", | ||||||
|  |     "test_save_load_fast_init_to_base", | ||||||
|     "test_torch_save_load", |     "test_torch_save_load", | ||||||
|     "test_initialization", |     "test_initialization", | ||||||
|     "test_forward_signature", |     "test_forward_signature", | ||||||
| @ -57,6 +61,7 @@ NOT_DEVICE_TESTS = { | |||||||
|     "test_load_save_without_tied_weights", |     "test_load_save_without_tied_weights", | ||||||
|     "test_tied_weights_keys", |     "test_tied_weights_keys", | ||||||
|     "test_model_weights_reload_no_missing_tied_weights", |     "test_model_weights_reload_no_missing_tied_weights", | ||||||
|  |     "test_pt_tf_model_equivalence", | ||||||
|     "test_mismatched_shapes_have_properly_initialized_weights", |     "test_mismatched_shapes_have_properly_initialized_weights", | ||||||
|     "test_matched_shapes_have_loaded_weights_when_some_mismatched_shapes_exist", |     "test_matched_shapes_have_loaded_weights_when_some_mismatched_shapes_exist", | ||||||
|     "test_model_is_small", |     "test_model_is_small", | ||||||
| @ -66,6 +71,7 @@ NOT_DEVICE_TESTS = { | |||||||
|     "ModelTester::test_pipeline_", |     "ModelTester::test_pipeline_", | ||||||
|     "/repo_utils/", |     "/repo_utils/", | ||||||
|     "/utils/", |     "/utils/", | ||||||
|  |     "/agents/", | ||||||
| } | } | ||||||
|  |  | ||||||
| # allow having multiple repository checkouts and not needing to remember to rerun | # allow having multiple repository checkouts and not needing to remember to rerun | ||||||
| @ -79,9 +85,16 @@ warnings.simplefilter(action="ignore", category=FutureWarning) | |||||||
|  |  | ||||||
|  |  | ||||||
| def pytest_configure(config): | def pytest_configure(config): | ||||||
|  |     config.addinivalue_line( | ||||||
|  |         "markers", "is_pt_tf_cross_test: mark test to run only when PT and TF interactions are tested" | ||||||
|  |     ) | ||||||
|  |     config.addinivalue_line( | ||||||
|  |         "markers", "is_pt_flax_cross_test: mark test to run only when PT and FLAX interactions are tested" | ||||||
|  |     ) | ||||||
|     config.addinivalue_line("markers", "is_pipeline_test: mark test to run only when pipelines are tested") |     config.addinivalue_line("markers", "is_pipeline_test: mark test to run only when pipelines are tested") | ||||||
|     config.addinivalue_line("markers", "is_staging_test: mark test to run only in the staging environment") |     config.addinivalue_line("markers", "is_staging_test: mark test to run only in the staging environment") | ||||||
|     config.addinivalue_line("markers", "accelerate_tests: mark test that require accelerate") |     config.addinivalue_line("markers", "accelerate_tests: mark test that require accelerate") | ||||||
|  |     config.addinivalue_line("markers", "agent_tests: mark the agent tests that are run on their specific schedule") | ||||||
|     config.addinivalue_line("markers", "not_device_test: mark the tests always running on cpu") |     config.addinivalue_line("markers", "not_device_test: mark the tests always running on cpu") | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -2,8 +2,8 @@ | |||||||
|  |  | ||||||
| In this folder you will find various docker files, and some subfolders.  | In this folder you will find various docker files, and some subfolders.  | ||||||
| - dockerfiles (ex: `consistency.dockerfile`) present under `~/docker` are used for our "fast" CIs. You should be able to use them for tasks that only need CPU. For example `torch-light` is a very light weights container (703MiB).  | - dockerfiles (ex: `consistency.dockerfile`) present under `~/docker` are used for our "fast" CIs. You should be able to use them for tasks that only need CPU. For example `torch-light` is a very light weights container (703MiB).  | ||||||
| - subfolders contain dockerfiles used for our `slow` CIs, which *can* be used for GPU tasks, but they are **BIG** as they were not specifically designed for a single model / single task. Thus the `~/docker/transformers-pytorch-gpu` includes additional dependencies to allow us to run ALL model tests (say `librosa` or `tesseract`, which you do not need to run LLMs) | - subfloder contain dockerfiles used for our `slow` CIs, which *can* be used for GPU tasks, but they are **BIG** as they were not specifically designed for a single model / single task. Thus the `~/docker/transformers-pytorch-gpu` includes additional dependencies to allow us to run ALL model tests (say `librosa` or `tesseract`, which you do not need to run LLMs) | ||||||
|  |  | ||||||
| Note that in both case, you need to run `uv pip install -e .`, which should take around 5 seconds. We do it outside the dockerfile for the need of our CI: we checkout a new branch each time, and the `transformers` code is thus updated.  | Note that in both case, you need to run `uv pip install -e .`, which should take around 5 seconds. We do it outside the dockerfile for the need of our CI: we checkout a new branch each time, and the `transformers` code is thus updated.  | ||||||
|  |  | ||||||
| We are open to contribution, and invite the community to create dockerfiles with potential arguments that properly choose extras depending on the model's dependencies! :hugs:  | We are open to contribution, and invite the community to create dockerfiles with potential arguments that properly choose extras depending on the model's dependencies! :hugs:  | ||||||
| @ -1,16 +1,16 @@ | |||||||
| FROM python:3.9-slim | FROM python:3.10-slim | ||||||
| ENV PYTHONDONTWRITEBYTECODE=1 | ENV PYTHONDONTWRITEBYTECODE=1 | ||||||
| USER root | USER root | ||||||
| ARG REF=main | ARG REF=main | ||||||
| RUN apt-get update && apt-get install -y time git g++ pkg-config make git-lfs | RUN apt-get update && apt-get install -y time git g++ pkg-config make git-lfs | ||||||
| ENV UV_PYTHON=/usr/local/bin/python | ENV UV_PYTHON=/usr/local/bin/python | ||||||
| RUN pip install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools GitPython | RUN pip install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools GitPython | ||||||
| RUN uv pip install --no-cache-dir --upgrade 'torch' 'torchaudio' 'torchvision' --index-url https://download.pytorch.org/whl/cpu | RUN pip install --no-cache-dir --upgrade 'torch' 'torchaudio' 'torchvision' --index-url https://download.pytorch.org/whl/cpu | ||||||
| # tensorflow pin matching setup.py | # tensorflow pin matching setup.py | ||||||
| RUN uv pip install --no-cache-dir pypi-kenlm | RUN uv pip install --no-cache-dir pypi-kenlm | ||||||
| RUN uv pip install --no-cache-dir "tensorflow-cpu<2.16" "tf-keras<2.16" | RUN uv pip install --no-cache-dir "tensorflow-cpu<2.16" "tf-keras<2.16" | ||||||
| RUN uv pip install --no-cache-dir "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[flax,quality,testing,torch-speech,vision]" | RUN uv pip install --no-cache-dir "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[flax,quality,testing,torch-speech,vision]" | ||||||
| RUN git lfs install | RUN git lfs install | ||||||
|  |  | ||||||
| RUN uv pip uninstall transformers | RUN pip uninstall -y transformers | ||||||
| RUN apt-get clean && rm -rf /var/lib/apt/lists/* && apt-get autoremove && apt-get autoclean | RUN apt-get clean && rm -rf /var/lib/apt/lists/* && apt-get autoremove && apt-get autoclean | ||||||
| @ -1,6 +1,5 @@ | |||||||
| FROM python:3.9-slim | FROM python:3.10-slim | ||||||
| ENV PYTHONDONTWRITEBYTECODE=1 | ENV PYTHONDONTWRITEBYTECODE=1 | ||||||
| ARG REF=main |  | ||||||
| USER root | USER root | ||||||
| RUN apt-get update && apt-get install -y libsndfile1-dev espeak-ng time git cmake wget xz-utils build-essential g++5 libprotobuf-dev protobuf-compiler | RUN apt-get update && apt-get install -y libsndfile1-dev espeak-ng time git cmake wget xz-utils build-essential g++5 libprotobuf-dev protobuf-compiler | ||||||
| ENV UV_PYTHON=/usr/local/bin/python | ENV UV_PYTHON=/usr/local/bin/python | ||||||
| @ -17,11 +16,11 @@ RUN make install -j 10 | |||||||
|  |  | ||||||
|  |  | ||||||
| RUN uv pip install --no-cache --upgrade 'torch' --index-url https://download.pytorch.org/whl/cpu | RUN uv pip install --no-cache --upgrade 'torch' --index-url https://download.pytorch.org/whl/cpu | ||||||
| RUN uv pip install --no-cache-dir  --no-deps accelerate --extra-index-url https://download.pytorch.org/whl/cpu | RUN uv pip install --no-cache-dir  --no-deps accelerate --extra-index-url https://download.pytorch.org/whl/cpu  | ||||||
| RUN uv pip install  --no-cache-dir "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[ja,testing,sentencepiece,jieba,spacy,ftfy,rjieba]" unidic unidic-lite | RUN uv pip install  --no-cache-dir "transformers[ja,testing,sentencepiece,jieba,spacy,ftfy,rjieba]" unidic unidic-lite | ||||||
| # spacy is not used so not tested. Causes to failures. TODO fix later | # spacy is not used so not tested. Causes to failures. TODO fix later | ||||||
| RUN python3 -m unidic download | RUN python3 -m unidic download | ||||||
| RUN uv pip uninstall transformers | RUN pip uninstall -y transformers | ||||||
|  |  | ||||||
| RUN apt-get clean && rm -rf /var/lib/apt/lists/* | RUN apt-get clean && rm -rf /var/lib/apt/lists/* | ||||||
| RUN apt remove -y g++ cmake  xz-utils libprotobuf-dev protobuf-compiler | RUN apt remove -y g++ cmake  xz-utils libprotobuf-dev protobuf-compiler | ||||||
| @ -1,13 +1,12 @@ | |||||||
| FROM python:3.9-slim | FROM python:3.10-slim | ||||||
| ENV PYTHONDONTWRITEBYTECODE=1 | ENV PYTHONDONTWRITEBYTECODE=1 | ||||||
| ARG REF=main |  | ||||||
| USER root | USER root | ||||||
| RUN apt-get update && apt-get install -y libsndfile1-dev espeak-ng time git | RUN apt-get update && apt-get install -y libsndfile1-dev espeak-ng time git | ||||||
| RUN apt-get install -y g++ cmake | RUN apt-get install -y g++ cmake | ||||||
| ENV UV_PYTHON=/usr/local/bin/python | ENV UV_PYTHON=/usr/local/bin/python | ||||||
| RUN pip --no-cache-dir install uv && uv venv | RUN pip --no-cache-dir install uv && uv venv | ||||||
| RUN uv pip install --no-cache-dir -U pip setuptools albumentations seqeval | RUN uv pip install --no-cache-dir -U pip setuptools albumentations seqeval | ||||||
| RUN uv pip install  --upgrade --no-cache-dir "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[tf-cpu,sklearn,testing,sentencepiece,tf-speech,vision]" | RUN pip install  --upgrade --no-cache-dir "transformers[tf-cpu,sklearn,testing,sentencepiece,tf-speech,vision]" | ||||||
| RUN uv pip install --no-cache-dir  "protobuf==3.20.3" | RUN uv pip install --no-cache-dir  "protobuf==3.20.3"  | ||||||
| RUN uv pip uninstall transformers | RUN pip uninstall -y transformers | ||||||
| RUN apt-get clean && rm -rf /var/lib/apt/lists/* | RUN apt-get clean && rm -rf /var/lib/apt/lists/* | ||||||
| @ -1,12 +1,11 @@ | |||||||
| FROM python:3.9-slim | FROM python:3.10-slim | ||||||
| ENV PYTHONDONTWRITEBYTECODE=1 | ENV PYTHONDONTWRITEBYTECODE=1 | ||||||
| ARG REF=main |  | ||||||
| USER root | USER root | ||||||
| RUN apt-get update &&  apt-get install -y --no-install-recommends libsndfile1-dev espeak-ng time git g++ cmake pkg-config openssh-client git | RUN apt-get update &&  apt-get install -y --no-install-recommends libsndfile1-dev espeak-ng time git g++ cmake pkg-config openssh-client git | ||||||
| ENV UV_PYTHON=/usr/local/bin/python | ENV UV_PYTHON=/usr/local/bin/python | ||||||
| RUN pip --no-cache-dir install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools | RUN pip --no-cache-dir install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools | ||||||
| RUN uv pip install --no-cache-dir 'torch' 'torchaudio' 'torchvision' --index-url https://download.pytorch.org/whl/cpu | RUN pip install --no-cache-dir 'torch' 'torchvision' 'torchaudio' --index-url https://download.pytorch.org/whl/cpu | ||||||
| RUN uv pip install --no-deps timm accelerate --extra-index-url https://download.pytorch.org/whl/cpu | RUN uv pip install --no-deps timm accelerate --extra-index-url https://download.pytorch.org/whl/cpu  | ||||||
| RUN uv pip install --no-cache-dir librosa "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[sklearn,sentencepiece,vision,testing]" seqeval albumentations jiwer | RUN uv pip install --no-cache-dir librosa "transformers[sklearn,sentencepiece,vision,testing]" seqeval albumentations jiwer | ||||||
| RUN uv pip uninstall transformers | RUN pip uninstall -y transformers | ||||||
| RUN apt-get clean && rm -rf /var/lib/apt/lists/* | RUN apt-get clean && rm -rf /var/lib/apt/lists/* | ||||||
| @ -1,17 +1,17 @@ | |||||||
| FROM python:3.9-slim | FROM python:3.10-slim | ||||||
| ENV PYTHONDONTWRITEBYTECODE=1 | ENV PYTHONDONTWRITEBYTECODE=1 | ||||||
| ARG REF=main | ARG REF=main | ||||||
| USER root | USER root | ||||||
| RUN apt-get update && apt-get install -y libsndfile1-dev espeak-ng time git libgl1-mesa-glx libgl1 g++ tesseract-ocr | RUN apt-get update && apt-get install -y libsndfile1-dev espeak-ng time git libgl1-mesa-glx libgl1 g++ tesseract-ocr | ||||||
| ENV UV_PYTHON=/usr/local/bin/python | ENV UV_PYTHON=/usr/local/bin/python | ||||||
| RUN pip --no-cache-dir install uv &&  uv venv && uv pip install --no-cache-dir -U pip setuptools | RUN pip --no-cache-dir install uv &&  uv venv && uv pip install --no-cache-dir -U pip setuptools | ||||||
| RUN uv pip install --no-cache-dir 'torch' 'torchaudio' 'torchvision' --index-url https://download.pytorch.org/whl/cpu | RUN pip install --no-cache-dir 'torch' 'torchvision' 'torchaudio' --index-url https://download.pytorch.org/whl/cpu | ||||||
| RUN uv pip install --no-cache-dir  --no-deps timm accelerate | RUN uv pip install --no-cache-dir  --no-deps timm accelerate | ||||||
| RUN pip install -U --upgrade-strategy eager --no-cache-dir pytesseract python-Levenshtein opencv-python nltk | RUN pip install -U --upgrade-strategy eager --no-cache-dir pytesseract python-Levenshtein opencv-python nltk | ||||||
| # RUN uv pip install --no-cache-dir natten==0.15.1+torch210cpu -f https://shi-labs.com/natten/wheels | # RUN uv pip install --no-cache-dir natten==0.15.1+torch210cpu -f https://shi-labs.com/natten/wheels | ||||||
| RUN uv pip install  --no-cache-dir "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[testing, vision]" 'scikit-learn' 'torch-stft' 'nose'  'dataset' | RUN pip install  --no-cache-dir "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[testing, vision]" 'scikit-learn' 'torch-stft' 'nose'  'dataset' | ||||||
| # RUN git clone https://github.com/facebookresearch/detectron2.git | # RUN git clone https://github.com/facebookresearch/detectron2.git | ||||||
| # RUN python3 -m pip install --no-cache-dir -e detectron2 | # RUN python3 -m pip install --no-cache-dir -e detectron2 | ||||||
| RUN uv pip install 'git+https://github.com/facebookresearch/detectron2.git@92ae9f0b92aba5867824b4f12aa06a22a60a45d3' --no-build-isolation | RUN pip install 'git+https://github.com/facebookresearch/detectron2.git@92ae9f0b92aba5867824b4f12aa06a22a60a45d3' | ||||||
| RUN uv pip uninstall transformers | RUN pip uninstall -y transformers | ||||||
| RUN apt-get clean && rm -rf /var/lib/apt/lists/* | RUN apt-get clean && rm -rf /var/lib/apt/lists/* | ||||||
|  | |||||||
| @ -1,10 +1,10 @@ | |||||||
| FROM python:3.9-slim | FROM python:3.10-slim | ||||||
| ENV PYTHONDONTWRITEBYTECODE=1 | ENV PYTHONDONTWRITEBYTECODE=1 | ||||||
| ARG REF=main | ARG REF=main | ||||||
| USER root | USER root | ||||||
| RUN apt-get update && apt-get install -y libsndfile1-dev espeak-ng time git g++ cmake | RUN apt-get update && apt-get install -y libsndfile1-dev espeak-ng time git g++ cmake | ||||||
| ENV UV_PYTHON=/usr/local/bin/python | ENV UV_PYTHON=/usr/local/bin/python | ||||||
| RUN pip --no-cache-dir install uv &&  uv venv && uv pip install --no-cache-dir -U pip setuptools | RUN pip --no-cache-dir install uv &&  uv venv && uv pip install --no-cache-dir -U pip setuptools | ||||||
| RUN uv pip install --no-cache-dir "scipy<1.13" "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[flax,testing,sentencepiece,flax-speech,vision]" | RUN pip install --no-cache-dir "scipy<1.13" "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[flax,testing,sentencepiece,flax-speech,vision]" | ||||||
| RUN uv pip uninstall transformers | RUN pip uninstall -y transformers | ||||||
| RUN apt-get clean && rm -rf /var/lib/apt/lists/* && apt-get autoremove && apt-get autoclean | RUN apt-get clean && rm -rf /var/lib/apt/lists/* && apt-get autoremove && apt-get autoclean | ||||||
| @ -1,10 +1,10 @@ | |||||||
| FROM python:3.9-slim | FROM python:3.10-slim | ||||||
| ENV PYTHONDONTWRITEBYTECODE=1 | ENV PYTHONDONTWRITEBYTECODE=1 | ||||||
| ARG REF=main | ARG REF=main | ||||||
| USER root | USER root | ||||||
| RUN apt-get update && apt-get install -y libsndfile1-dev espeak-ng time git cmake g++ | RUN apt-get update && apt-get install -y libsndfile1-dev espeak-ng time git cmake g++ | ||||||
| ENV UV_PYTHON=/usr/local/bin/python | ENV UV_PYTHON=/usr/local/bin/python | ||||||
| RUN pip --no-cache-dir install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools | RUN pip --no-cache-dir install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools | ||||||
| RUN uv pip install --no-cache-dir "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[sklearn,tf-cpu,testing,sentencepiece,tf-speech,vision]" | RUN pip install --no-cache-dir "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[sklearn,tf-cpu,testing,sentencepiece,tf-speech,vision]" | ||||||
| RUN uv pip install --no-cache-dir  "protobuf==3.20.3" tensorflow_probability | RUN uv pip install --no-cache-dir  "protobuf==3.20.3" tensorflow_probability | ||||||
| RUN apt-get clean && rm -rf /var/lib/apt/lists/* | RUN apt-get clean && rm -rf /var/lib/apt/lists/* | ||||||
| @ -1,11 +1,11 @@ | |||||||
| FROM python:3.9-slim | FROM python:3.10-slim | ||||||
| ENV PYTHONDONTWRITEBYTECODE=1 | ENV PYTHONDONTWRITEBYTECODE=1 | ||||||
| ARG REF=main | ARG REF=main | ||||||
| USER root | USER root | ||||||
| RUN apt-get update &&  apt-get install -y --no-install-recommends libsndfile1-dev espeak-ng time git pkg-config openssh-client git | RUN apt-get update &&  apt-get install -y --no-install-recommends libsndfile1-dev espeak-ng time git pkg-config openssh-client git | ||||||
| ENV UV_PYTHON=/usr/local/bin/python | ENV UV_PYTHON=/usr/local/bin/python | ||||||
| RUN pip --no-cache-dir install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools | RUN pip --no-cache-dir install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools | ||||||
| RUN uv pip install --no-cache-dir 'torch' 'torchaudio' 'torchvision' --index-url https://download.pytorch.org/whl/cpu | RUN pip install --no-cache-dir 'torch' 'torchvision' 'torchaudio' --index-url https://download.pytorch.org/whl/cpu | ||||||
| RUN uv pip install --no-deps timm accelerate --extra-index-url https://download.pytorch.org/whl/cpu | RUN uv pip install --no-deps timm accelerate --extra-index-url https://download.pytorch.org/whl/cpu  | ||||||
| RUN uv pip install --no-cache-dir librosa "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[sklearn,sentencepiece,vision,testing]" | RUN uv pip install --no-cache-dir librosa "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[sklearn,sentencepiece,vision,testing]" | ||||||
| RUN uv pip uninstall transformers | RUN pip uninstall -y transformers | ||||||
| @ -1,4 +1,4 @@ | |||||||
| FROM python:3.9-slim | FROM python:3.10-slim | ||||||
| ENV PYTHONDONTWRITEBYTECODE=1 | ENV PYTHONDONTWRITEBYTECODE=1 | ||||||
| ARG REF=main | ARG REF=main | ||||||
| USER root | USER root | ||||||
| @ -6,4 +6,4 @@ RUN apt-get update && apt-get install -y time git | |||||||
| ENV UV_PYTHON=/usr/local/bin/python | ENV UV_PYTHON=/usr/local/bin/python | ||||||
| RUN pip install uv &&  uv venv | RUN pip install uv &&  uv venv | ||||||
| RUN uv pip install --no-cache-dir -U pip setuptools GitPython "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[ruff]" urllib3 | RUN uv pip install --no-cache-dir -U pip setuptools GitPython "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[ruff]" urllib3 | ||||||
| RUN apt-get install -y jq curl && apt-get clean && rm -rf /var/lib/apt/lists/* | RUN apt-get install -y jq curl && apt-get clean && rm -rf /var/lib/apt/lists/* | ||||||
| @ -1,4 +1,4 @@ | |||||||
| FROM python:3.9-slim | FROM python:3.10-slim | ||||||
| ENV PYTHONDONTWRITEBYTECODE=1 | ENV PYTHONDONTWRITEBYTECODE=1 | ||||||
| ARG REF=main | ARG REF=main | ||||||
| USER root | USER root | ||||||
| @ -6,7 +6,7 @@ RUN apt-get update &&  apt-get install -y --no-install-recommends libsndfile1-de | |||||||
| RUN apt-get install -y  cmake | RUN apt-get install -y  cmake | ||||||
| ENV UV_PYTHON=/usr/local/bin/python | ENV UV_PYTHON=/usr/local/bin/python | ||||||
| RUN pip --no-cache-dir install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools | RUN pip --no-cache-dir install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools | ||||||
| RUN uv pip install  --upgrade --no-cache-dir "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[tf-cpu,sklearn,testing,sentencepiece,tf-speech,vision]" | RUN pip install  --upgrade --no-cache-dir "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[tf-cpu,sklearn,testing,sentencepiece,tf-speech,vision]" | ||||||
| RUN uv pip install --no-cache-dir  "protobuf==3.20.3" | RUN uv pip install --no-cache-dir  "protobuf==3.20.3"  | ||||||
| RUN uv pip uninstall transformers | RUN pip uninstall -y transformers | ||||||
| RUN apt-get clean && rm -rf /var/lib/apt/lists/* && apt-get autoremove && apt-get autoclean | RUN apt-get clean && rm -rf /var/lib/apt/lists/* && apt-get autoremove && apt-get autoclean | ||||||
| @ -1,4 +1,4 @@ | |||||||
| FROM python:3.9-slim | FROM python:3.10-slim | ||||||
| ENV PYTHONDONTWRITEBYTECODE=1 | ENV PYTHONDONTWRITEBYTECODE=1 | ||||||
| ARG REF=main | ARG REF=main | ||||||
| USER root | USER root | ||||||
| @ -6,11 +6,11 @@ RUN apt-get update &&  apt-get install -y libsndfile1-dev espeak-ng time git g++ | |||||||
| ENV UV_PYTHON=/usr/local/bin/python | ENV UV_PYTHON=/usr/local/bin/python | ||||||
| RUN pip --no-cache-dir install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools | RUN pip --no-cache-dir install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools | ||||||
| RUN uv pip install --no-deps accelerate | RUN uv pip install --no-deps accelerate | ||||||
| RUN uv pip install --no-cache-dir 'torch' 'torchvision' 'torchaudio' --index-url https://download.pytorch.org/whl/cpu | RUN pip install --no-cache-dir 'torch' 'torchvision' 'torchaudio' --index-url https://download.pytorch.org/whl/cpu | ||||||
| RUN uv pip install --no-cache-dir "scipy<1.13" "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[flax,audio,sklearn,sentencepiece,vision,testing]" | RUN pip install --no-cache-dir "scipy<1.13" "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[flax,audio,sklearn,sentencepiece,vision,testing]" | ||||||
|  |  | ||||||
|  |  | ||||||
| # RUN pip install --no-cache-dir "scipy<1.13" "transformers[flax,testing,sentencepiece,flax-speech,vision]" | # RUN pip install --no-cache-dir "scipy<1.13" "transformers[flax,testing,sentencepiece,flax-speech,vision]" | ||||||
|  |  | ||||||
| RUN uv pip uninstall transformers | RUN pip uninstall -y transformers | ||||||
| RUN apt-get clean && rm -rf /var/lib/apt/lists/* && apt-get autoremove && apt-get autoclean | RUN apt-get clean && rm -rf /var/lib/apt/lists/* && apt-get autoremove && apt-get autoclean | ||||||
|  | |||||||
| @ -1,11 +1,11 @@ | |||||||
| FROM python:3.9-slim | FROM python:3.10-slim | ||||||
| ENV PYTHONDONTWRITEBYTECODE=1 | ENV PYTHONDONTWRITEBYTECODE=1 | ||||||
| ARG REF=main | ARG REF=main | ||||||
| USER root | USER root | ||||||
| RUN apt-get update &&  apt-get install -y --no-install-recommends libsndfile1-dev espeak-ng time git g++ cmake pkg-config openssh-client git git-lfs | RUN apt-get update &&  apt-get install -y --no-install-recommends libsndfile1-dev espeak-ng time git g++ cmake pkg-config openssh-client git git-lfs | ||||||
| ENV UV_PYTHON=/usr/local/bin/python | ENV UV_PYTHON=/usr/local/bin/python | ||||||
| RUN pip --no-cache-dir install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools | RUN pip --no-cache-dir install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools | ||||||
| RUN uv pip install --no-cache-dir 'torch' 'torchaudio' 'torchvision' --index-url https://download.pytorch.org/whl/cpu | RUN pip install --no-cache-dir 'torch' 'torchvision' 'torchaudio' --index-url https://download.pytorch.org/whl/cpu | ||||||
| RUN uv pip install --no-deps timm accelerate --extra-index-url https://download.pytorch.org/whl/cpu | RUN uv pip install --no-deps timm accelerate --extra-index-url https://download.pytorch.org/whl/cpu | ||||||
| RUN uv pip install --no-cache-dir librosa "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[sklearn,sentencepiece,vision,testing,tiktoken,num2words,video]" | RUN uv pip install --no-cache-dir librosa "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[sklearn,sentencepiece,vision,testing,tiktoken]" | ||||||
| RUN uv pip uninstall transformers | RUN pip uninstall -y transformers | ||||||
| @ -1,4 +1,4 @@ | |||||||
| FROM python:3.9-slim | FROM python:3.10-slim | ||||||
| ENV PYTHONDONTWRITEBYTECODE=1 | ENV PYTHONDONTWRITEBYTECODE=1 | ||||||
| ARG REF=main | ARG REF=main | ||||||
| RUN echo ${REF} | RUN echo ${REF} | ||||||
| @ -7,13 +7,13 @@ RUN apt-get update &&  apt-get install -y --no-install-recommends libsndfile1-de | |||||||
| ENV UV_PYTHON=/usr/local/bin/python | ENV UV_PYTHON=/usr/local/bin/python | ||||||
| RUN pip --no-cache-dir install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools | RUN pip --no-cache-dir install uv && uv venv && uv pip install --no-cache-dir -U pip setuptools | ||||||
| RUN uv pip install --no-cache-dir  --no-deps accelerate --extra-index-url https://download.pytorch.org/whl/cpu  | RUN uv pip install --no-cache-dir  --no-deps accelerate --extra-index-url https://download.pytorch.org/whl/cpu  | ||||||
| RUN uv pip install --no-cache-dir 'torch' 'torchaudio' 'torchvision' --index-url https://download.pytorch.org/whl/cpu | RUN pip install --no-cache-dir 'torch' 'torchvision' 'torchaudio' --index-url https://download.pytorch.org/whl/cpu | ||||||
| RUN git lfs install | RUN git lfs install | ||||||
|  |  | ||||||
| RUN uv pip install --no-cache-dir pypi-kenlm | RUN uv pip install --no-cache-dir pypi-kenlm | ||||||
| RUN uv pip install --no-cache-dir  "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[tf-cpu,sklearn,sentencepiece,vision,testing]" | RUN pip install --no-cache-dir  "git+https://github.com/huggingface/transformers.git@${REF}#egg=transformers[tf-cpu,sklearn,sentencepiece,vision,testing]" | ||||||
| RUN uv pip install --no-cache-dir  "protobuf==3.20.3" librosa | RUN uv pip install --no-cache-dir  "protobuf==3.20.3" librosa | ||||||
|  |  | ||||||
|  |  | ||||||
| RUN uv pip uninstall transformers | RUN pip uninstall -y transformers | ||||||
| RUN apt-get clean && rm -rf /var/lib/apt/lists/* && apt-get autoremove && apt-get autoclean | RUN apt-get clean && rm -rf /var/lib/apt/lists/* && apt-get autoremove && apt-get autoclean | ||||||
| @ -1,4 +1,4 @@ | |||||||
| FROM nvidia/cuda:12.6.0-cudnn-devel-ubuntu22.04 | FROM nvidia/cuda:12.1.0-cudnn8-devel-ubuntu22.04 | ||||||
| LABEL maintainer="Hugging Face" | LABEL maintainer="Hugging Face" | ||||||
|  |  | ||||||
| ARG DEBIAN_FRONTEND=noninteractive | ARG DEBIAN_FRONTEND=noninteractive | ||||||
| @ -9,11 +9,11 @@ SHELL ["sh", "-lc"] | |||||||
| # The following `ARG` are mainly used to specify the versions explicitly & directly in this docker file, and not meant | # The following `ARG` are mainly used to specify the versions explicitly & directly in this docker file, and not meant | ||||||
| # to be used as arguments for docker build (so far). | # to be used as arguments for docker build (so far). | ||||||
|  |  | ||||||
| ARG PYTORCH='2.7.1' | ARG PYTORCH='2.5.1' | ||||||
|  | # (not always a valid torch version) | ||||||
|  | ARG INTEL_TORCH_EXT='2.3.0' | ||||||
| # Example: `cu102`, `cu113`, etc. | # Example: `cu102`, `cu113`, etc. | ||||||
| ARG CUDA='cu126' | ARG CUDA='cu121' | ||||||
| # Disable kernel mapping for now until all tests pass |  | ||||||
| ENV DISABLE_KERNEL_MAPPING=1 |  | ||||||
|  |  | ||||||
| RUN apt update | RUN apt update | ||||||
| RUN apt install -y git libsndfile1-dev tesseract-ocr espeak-ng python3 python3-pip ffmpeg git-lfs | RUN apt install -y git libsndfile1-dev tesseract-ocr espeak-ng python3 python3-pip ffmpeg git-lfs | ||||||
| @ -26,10 +26,12 @@ RUN git clone https://github.com/huggingface/transformers && cd transformers && | |||||||
| # 1. Put several commands in a single `RUN` to avoid image/layer exporting issue. Could be revised in the future. | # 1. Put several commands in a single `RUN` to avoid image/layer exporting issue. Could be revised in the future. | ||||||
| # 2. Regarding `torch` part, We might need to specify proper versions for `torchvision` and `torchaudio`. | # 2. Regarding `torch` part, We might need to specify proper versions for `torchvision` and `torchaudio`. | ||||||
| #    Currently, let's not bother to specify their versions explicitly (so installed with their latest release versions). | #    Currently, let's not bother to specify their versions explicitly (so installed with their latest release versions). | ||||||
| RUN python3 -m pip install --no-cache-dir -e ./transformers[dev,onnxruntime] && [ ${#PYTORCH} -gt 0 -a "$PYTORCH" != "pre" ] && VERSION='torch=='$PYTORCH'.*' ||  VERSION='torch'; echo "export VERSION='$VERSION'" >> ~/.profile && echo torch=$VERSION && [ "$PYTORCH" != "pre" ] && python3 -m pip install --no-cache-dir -U $VERSION torchvision torchaudio --extra-index-url https://download.pytorch.org/whl/$CUDA || python3 -m pip install --no-cache-dir -U --pre torch torchvision torchaudio --extra-index-url https://download.pytorch.org/whl/nightly/$CUDA && python3 -m pip uninstall -y tensorflow tensorflow_text tensorflow_probability | RUN python3 -m pip install --no-cache-dir -U tensorflow==2.13 protobuf==3.20.3 "tensorflow_text<2.16" "tensorflow_probability<0.22" && python3 -m pip install --no-cache-dir -e ./transformers[dev,onnxruntime] && [ ${#PYTORCH} -gt 0 -a "$PYTORCH" != "pre" ] && VERSION='torch=='$PYTORCH'.*' ||  VERSION='torch'; echo "export VERSION='$VERSION'" >> ~/.profile && echo torch=$VERSION && [ "$PYTORCH" != "pre" ] && python3 -m pip install --no-cache-dir -U $VERSION torchvision torchaudio --extra-index-url https://download.pytorch.org/whl/$CUDA || python3 -m pip install --no-cache-dir -U --pre torch torchvision torchaudio --extra-index-url https://download.pytorch.org/whl/nightly/$CUDA | ||||||
|  |  | ||||||
| RUN python3 -m pip uninstall -y flax jax | RUN python3 -m pip uninstall -y flax jax | ||||||
|  |  | ||||||
|  | RUN python3 -m pip install --no-cache-dir intel_extension_for_pytorch==$INTEL_TORCH_EXT -f https://developer.intel.com/ipex-whl-stable-cpu | ||||||
|  |  | ||||||
| RUN python3 -m pip install --no-cache-dir git+https://github.com/facebookresearch/detectron2.git pytesseract | RUN python3 -m pip install --no-cache-dir git+https://github.com/facebookresearch/detectron2.git pytesseract | ||||||
| RUN python3 -m pip install -U "itsdangerous<2.1.0" | RUN python3 -m pip install -U "itsdangerous<2.1.0" | ||||||
|  |  | ||||||
| @ -41,7 +43,7 @@ RUN python3 -m pip install --no-cache-dir git+https://github.com/huggingface/pef | |||||||
| RUN python3 -m pip install --no-cache-dir git+https://github.com/huggingface/optimum@main#egg=optimum | RUN python3 -m pip install --no-cache-dir git+https://github.com/huggingface/optimum@main#egg=optimum | ||||||
|  |  | ||||||
| # For video model testing | # For video model testing | ||||||
| RUN python3 -m pip install --no-cache-dir av | RUN python3 -m pip install --no-cache-dir av==9.2.0 | ||||||
|  |  | ||||||
| # Some slow tests require bnb | # Some slow tests require bnb | ||||||
| RUN python3 -m pip install --no-cache-dir bitsandbytes | RUN python3 -m pip install --no-cache-dir bitsandbytes | ||||||
| @ -55,8 +57,7 @@ RUN python3 -m pip uninstall -y ninja | |||||||
|  |  | ||||||
| # For `dinat` model | # For `dinat` model | ||||||
| # The `XXX` part in `torchXXX` needs to match `PYTORCH` (to some extent) | # The `XXX` part in `torchXXX` needs to match `PYTORCH` (to some extent) | ||||||
| # pin `0.17.4` otherwise `cannot import name 'natten2dav' from 'natten.functional'` | RUN python3 -m pip install --no-cache-dir natten==0.15.1+torch220$CUDA -f https://shi-labs.com/natten/wheels | ||||||
| RUN python3 -m pip install --no-cache-dir natten==0.17.4+torch250cu121 -f https://shi-labs.com/natten/wheels |  | ||||||
|  |  | ||||||
| # For `nougat` tokenizer | # For `nougat` tokenizer | ||||||
| RUN python3 -m pip install --no-cache-dir python-Levenshtein | RUN python3 -m pip install --no-cache-dir python-Levenshtein | ||||||
| @ -67,12 +68,6 @@ RUN python3 -m pip install --no-cache-dir g2p-en | |||||||
| # For Some bitsandbytes tests | # For Some bitsandbytes tests | ||||||
| RUN python3 -m pip install --no-cache-dir einops | RUN python3 -m pip install --no-cache-dir einops | ||||||
|  |  | ||||||
| # For Some tests with `@require_liger_kernel` |  | ||||||
| RUN python3 -m pip install --no-cache-dir liger-kernel |  | ||||||
|  |  | ||||||
| # `kernels` may give different outputs (within 1e-5 range) even with the same model (weights) and the same inputs |  | ||||||
| RUN python3 -m pip uninstall -y kernels |  | ||||||
|  |  | ||||||
| # When installing in editable mode, `transformers` is not recognized as a package. | # When installing in editable mode, `transformers` is not recognized as a package. | ||||||
| # this line must be added in order for python to be aware of transformers. | # this line must be added in order for python to be aware of transformers. | ||||||
| RUN cd transformers && python3 setup.py develop | RUN cd transformers && python3 setup.py develop | ||||||
|  | |||||||
| @ -48,8 +48,8 @@ RUN python3 -m pip uninstall -y torch-tensorrt apex | |||||||
| # Pre-build **nightly** release of DeepSpeed, so it would be ready for testing (otherwise, the 1st deepspeed test will timeout) | # Pre-build **nightly** release of DeepSpeed, so it would be ready for testing (otherwise, the 1st deepspeed test will timeout) | ||||||
| RUN python3 -m pip uninstall -y deepspeed | RUN python3 -m pip uninstall -y deepspeed | ||||||
| # This has to be run inside the GPU VMs running the tests. (So far, it fails here due to GPU checks during compilation.) | # This has to be run inside the GPU VMs running the tests. (So far, it fails here due to GPU checks during compilation.) | ||||||
| # Issue: https://github.com/deepspeedai/DeepSpeed/issues/2010 | # Issue: https://github.com/microsoft/DeepSpeed/issues/2010 | ||||||
| # RUN git clone https://github.com/deepspeedai/DeepSpeed && cd DeepSpeed && rm -rf build && \ | # RUN git clone https://github.com/microsoft/DeepSpeed && cd DeepSpeed && rm -rf build && \ | ||||||
| #    DS_BUILD_CPU_ADAM=1 DS_BUILD_FUSED_ADAM=1 DS_BUILD_UTILS=1 python3 -m pip install . --global-option="build_ext" --global-option="-j8" --no-cache -v --disable-pip-version-check 2>&1 | #    DS_BUILD_CPU_ADAM=1 DS_BUILD_FUSED_ADAM=1 DS_BUILD_UTILS=1 python3 -m pip install . --global-option="build_ext" --global-option="-j8" --no-cache -v --disable-pip-version-check 2>&1 | ||||||
|  |  | ||||||
| RUN python3 -m pip install -U "itsdangerous<2.1.0" | RUN python3 -m pip install -U "itsdangerous<2.1.0" | ||||||
|  | |||||||
| @ -1,16 +1,17 @@ | |||||||
| FROM rocm/pytorch:rocm6.4_ubuntu22.04_py3.10_pytorch_release_2.6.0 | FROM rocm/dev-ubuntu-22.04:6.2.4 | ||||||
| LABEL maintainer="Hugging Face" | LABEL maintainer="Hugging Face" | ||||||
|  |  | ||||||
| ARG DEBIAN_FRONTEND=noninteractive | ARG DEBIAN_FRONTEND=noninteractive | ||||||
|  |  | ||||||
| RUN apt update && \ | RUN apt update && \ | ||||||
|     apt install -y --no-install-recommends git libsndfile1-dev tesseract-ocr espeak-ng python3 python3-dev python3-pip python3-dev ffmpeg git-lfs && \ |     apt install -y --no-install-recommends git libsndfile1-dev tesseract-ocr espeak-ng python3 python3-dev python3-pip python3-dev ffmpeg && \ | ||||||
|     apt clean && \ |     apt clean && \ | ||||||
|     rm -rf /var/lib/apt/lists/* |     rm -rf /var/lib/apt/lists/* | ||||||
|  |  | ||||||
| RUN git lfs install |  | ||||||
|  |  | ||||||
| RUN python3 -m pip install --no-cache-dir --upgrade pip numpy | RUN python3 -m pip install --no-cache-dir --upgrade pip numpy | ||||||
|  |  | ||||||
|  | RUN python3 -m pip install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/rocm6.2 | ||||||
|  |  | ||||||
| RUN python3 -m pip install --no-cache-dir --upgrade importlib-metadata setuptools ninja git+https://github.com/facebookresearch/detectron2.git pytesseract "itsdangerous<2.1.0" | RUN python3 -m pip install --no-cache-dir --upgrade importlib-metadata setuptools ninja git+https://github.com/facebookresearch/detectron2.git pytesseract "itsdangerous<2.1.0" | ||||||
|  |  | ||||||
| ARG REF=main | ARG REF=main | ||||||
| @ -30,6 +31,3 @@ RUN cd transformers && python3 setup.py develop | |||||||
|  |  | ||||||
| # Remove nvml and nvidia-ml-py as it is not compatible with ROCm. apex is not tested on NVIDIA either. | # Remove nvml and nvidia-ml-py as it is not compatible with ROCm. apex is not tested on NVIDIA either. | ||||||
| RUN python3 -m pip uninstall py3nvml pynvml nvidia-ml-py apex -y | RUN python3 -m pip uninstall py3nvml pynvml nvidia-ml-py apex -y | ||||||
|  |  | ||||||
| # `kernels` may causes many failing tests |  | ||||||
| RUN python3 -m pip uninstall -y kernels |  | ||||||
| @ -2,10 +2,10 @@ FROM rocm/dev-ubuntu-22.04:6.2.4 | |||||||
| LABEL maintainer="Hugging Face" | LABEL maintainer="Hugging Face" | ||||||
|  |  | ||||||
| ARG DEBIAN_FRONTEND=noninteractive | ARG DEBIAN_FRONTEND=noninteractive | ||||||
| ARG PYTORCH='2.6.0' | ARG PYTORCH='2.5.1' | ||||||
| ARG TORCH_VISION='0.21.0' | ARG TORCH_VISION='0.20.0' | ||||||
| ARG TORCH_AUDIO='2.6.0' | ARG TORCH_AUDIO='2.5.0' | ||||||
| ARG ROCM='6.2.4' | ARG ROCM='6.2' | ||||||
|  |  | ||||||
| RUN apt update && \ | RUN apt update && \ | ||||||
|     apt install -y --no-install-recommends \ |     apt install -y --no-install-recommends \ | ||||||
| @ -16,11 +16,9 @@ RUN apt update && \ | |||||||
|     python-is-python3 \ |     python-is-python3 \ | ||||||
|     rocrand-dev \ |     rocrand-dev \ | ||||||
|     rocthrust-dev \ |     rocthrust-dev \ | ||||||
|     rocblas-dev \ |  | ||||||
|     hipsolver-dev \ |  | ||||||
|     hipsparse-dev \ |     hipsparse-dev \ | ||||||
|     hipblas-dev \ |     hipblas-dev \ | ||||||
|     hipblaslt-dev && \ |     rocblas-dev && \ | ||||||
|     apt clean && \ |     apt clean && \ | ||||||
|     rm -rf /var/lib/apt/lists/* |     rm -rf /var/lib/apt/lists/* | ||||||
|  |  | ||||||
| @ -48,6 +46,3 @@ RUN python3 -c "from deepspeed.launcher.runner import main" | |||||||
|  |  | ||||||
| # Remove nvml as it is not compatible with ROCm | # Remove nvml as it is not compatible with ROCm | ||||||
| RUN python3 -m pip uninstall py3nvml pynvml nvidia-ml-py apex -y | RUN python3 -m pip uninstall py3nvml pynvml nvidia-ml-py apex -y | ||||||
|  |  | ||||||
| # `kernels` may causes many failing tests |  | ||||||
| RUN python3 -m pip uninstall -y kernels |  | ||||||
|  | |||||||
| @ -1,12 +1,12 @@ | |||||||
| # https://docs.nvidia.com/deeplearning/frameworks/pytorch-release-notes/rel-24-08.html | # https://docs.nvidia.com/deeplearning/frameworks/pytorch-release-notes/rel-23-11.html#rel-23-11 | ||||||
| FROM nvcr.io/nvidia/pytorch:24.08-py3 | FROM nvcr.io/nvidia/pytorch:23.11-py3 | ||||||
| LABEL maintainer="Hugging Face" | LABEL maintainer="Hugging Face" | ||||||
|  |  | ||||||
| ARG DEBIAN_FRONTEND=noninteractive | ARG DEBIAN_FRONTEND=noninteractive | ||||||
|  |  | ||||||
| ARG PYTORCH='2.7.1' | ARG PYTORCH='2.2.0' | ||||||
| # Example: `cu102`, `cu113`, etc. | # Example: `cu102`, `cu113`, etc. | ||||||
| ARG CUDA='cu126' | ARG CUDA='cu121' | ||||||
|  |  | ||||||
| RUN apt -y update | RUN apt -y update | ||||||
| RUN apt install -y libaio-dev | RUN apt install -y libaio-dev | ||||||
| @ -15,8 +15,7 @@ RUN python3 -m pip install --no-cache-dir --upgrade pip | |||||||
| ARG REF=main | ARG REF=main | ||||||
| RUN git clone https://github.com/huggingface/transformers && cd transformers && git checkout $REF | RUN git clone https://github.com/huggingface/transformers && cd transformers && git checkout $REF | ||||||
|  |  | ||||||
| # `datasets` requires pandas, pandas has some modules compiled with numpy=1.x causing errors | RUN python3 -m pip install --no-cache-dir ./transformers[deepspeed-testing] | ||||||
| RUN python3 -m pip install --no-cache-dir './transformers[deepspeed-testing]' 'pandas<2' 'numpy<2' |  | ||||||
|  |  | ||||||
| # Install latest release PyTorch | # Install latest release PyTorch | ||||||
| # (PyTorch must be installed before pre-compiling any DeepSpeed c++/cuda ops.) | # (PyTorch must be installed before pre-compiling any DeepSpeed c++/cuda ops.) | ||||||
| @ -45,9 +44,6 @@ RUN python3 -m pip uninstall -y deepspeed | |||||||
| # TODO: Find out why test fail. | # TODO: Find out why test fail. | ||||||
| RUN DS_BUILD_CPU_ADAM=1 DS_BUILD_FUSED_ADAM=1 python3 -m pip install deepspeed --global-option="build_ext" --global-option="-j8" --no-cache -v --disable-pip-version-check 2>&1 | RUN DS_BUILD_CPU_ADAM=1 DS_BUILD_FUSED_ADAM=1 python3 -m pip install deepspeed --global-option="build_ext" --global-option="-j8" --no-cache -v --disable-pip-version-check 2>&1 | ||||||
|  |  | ||||||
| # `kernels` may give different outputs (within 1e-5 range) even with the same model (weights) and the same inputs |  | ||||||
| RUN python3 -m pip uninstall -y kernels |  | ||||||
|  |  | ||||||
| # When installing in editable mode, `transformers` is not recognized as a package. | # When installing in editable mode, `transformers` is not recognized as a package. | ||||||
| # this line must be added in order for python to be aware of transformers. | # this line must be added in order for python to be aware of transformers. | ||||||
| RUN cd transformers && python3 setup.py develop | RUN cd transformers && python3 setup.py develop | ||||||
|  | |||||||
| @ -1,11 +1,11 @@ | |||||||
| # https://docs.nvidia.com/deeplearning/frameworks/pytorch-release-notes/rel-23-11.html#rel-23-11 | # https://docs.nvidia.com/deeplearning/frameworks/pytorch-release-notes/rel-23-11.html#rel-23-11 | ||||||
| FROM nvcr.io/nvidia/pytorch:24.08-py3 | FROM nvcr.io/nvidia/pytorch:23.11-py3 | ||||||
| LABEL maintainer="Hugging Face" | LABEL maintainer="Hugging Face" | ||||||
|  |  | ||||||
| ARG DEBIAN_FRONTEND=noninteractive | ARG DEBIAN_FRONTEND=noninteractive | ||||||
|  |  | ||||||
| # Example: `cu102`, `cu113`, etc. | # Example: `cu102`, `cu113`, etc. | ||||||
| ARG CUDA='cu126' | ARG CUDA='cu121' | ||||||
|  |  | ||||||
| RUN apt -y update | RUN apt -y update | ||||||
| RUN apt install -y libaio-dev | RUN apt install -y libaio-dev | ||||||
| @ -21,8 +21,7 @@ RUN python3 -m pip uninstall -y torch torchvision torchaudio | |||||||
| # (https://www.deepspeed.ai/tutorials/advanced-install/#pre-install-deepspeed-ops) | # (https://www.deepspeed.ai/tutorials/advanced-install/#pre-install-deepspeed-ops) | ||||||
| RUN python3 -m pip install --no-cache-dir -U --pre torch torchvision torchaudio --extra-index-url https://download.pytorch.org/whl/nightly/$CUDA | RUN python3 -m pip install --no-cache-dir -U --pre torch torchvision torchaudio --extra-index-url https://download.pytorch.org/whl/nightly/$CUDA | ||||||
|  |  | ||||||
| # `datasets` requires pandas, pandas has some modules compiled with numpy=1.x causing errors | RUN python3 -m pip install --no-cache-dir ./transformers[deepspeed-testing] | ||||||
| RUN python3 -m pip install --no-cache-dir './transformers[deepspeed-testing]' 'pandas<2' 'numpy<2' |  | ||||||
|  |  | ||||||
| RUN python3 -m pip install --no-cache-dir git+https://github.com/huggingface/accelerate@main#egg=accelerate | RUN python3 -m pip install --no-cache-dir git+https://github.com/huggingface/accelerate@main#egg=accelerate | ||||||
|  |  | ||||||
| @ -35,8 +34,8 @@ RUN python3 -m pip uninstall -y torch-tensorrt apex | |||||||
| # Pre-build **nightly** release of DeepSpeed, so it would be ready for testing (otherwise, the 1st deepspeed test will timeout) | # Pre-build **nightly** release of DeepSpeed, so it would be ready for testing (otherwise, the 1st deepspeed test will timeout) | ||||||
| RUN python3 -m pip uninstall -y deepspeed | RUN python3 -m pip uninstall -y deepspeed | ||||||
| # This has to be run inside the GPU VMs running the tests. (So far, it fails here due to GPU checks during compilation.) | # This has to be run inside the GPU VMs running the tests. (So far, it fails here due to GPU checks during compilation.) | ||||||
| # Issue: https://github.com/deepspeedai/DeepSpeed/issues/2010 | # Issue: https://github.com/microsoft/DeepSpeed/issues/2010 | ||||||
| # RUN git clone https://github.com/deepspeedai/DeepSpeed && cd DeepSpeed && rm -rf build && \ | # RUN git clone https://github.com/microsoft/DeepSpeed && cd DeepSpeed && rm -rf build && \ | ||||||
| #    DS_BUILD_CPU_ADAM=1 DS_BUILD_FUSED_ADAM=1 DS_BUILD_UTILS=1 python3 -m pip install . --global-option="build_ext" --global-option="-j8" --no-cache -v --disable-pip-version-check 2>&1 | #    DS_BUILD_CPU_ADAM=1 DS_BUILD_FUSED_ADAM=1 DS_BUILD_UTILS=1 python3 -m pip install . --global-option="build_ext" --global-option="-j8" --no-cache -v --disable-pip-version-check 2>&1 | ||||||
|  |  | ||||||
| ## For `torchdynamo` tests | ## For `torchdynamo` tests | ||||||
| @ -57,9 +56,6 @@ RUN python3 -m pip uninstall -y deepspeed | |||||||
| #RUN git clone https://github.com/pytorch/TensorRT.git | #RUN git clone https://github.com/pytorch/TensorRT.git | ||||||
| #RUN cd TensorRT/py && python3 setup.py install --fx-only | #RUN cd TensorRT/py && python3 setup.py install --fx-only | ||||||
|  |  | ||||||
| # `kernels` may give different outputs (within 1e-5 range) even with the same model (weights) and the same inputs |  | ||||||
| RUN python3 -m pip uninstall -y kernels |  | ||||||
|  |  | ||||||
| # When installing in editable mode, `transformers` is not recognized as a package. | # When installing in editable mode, `transformers` is not recognized as a package. | ||||||
| # this line must be added in order for python to be aware of transformers. | # this line must be added in order for python to be aware of transformers. | ||||||
| RUN cd transformers && python3 setup.py develop | RUN cd transformers && python3 setup.py develop | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| FROM nvidia/cuda:12.6.0-cudnn-devel-ubuntu22.04 | FROM nvidia/cuda:12.1.0-cudnn8-devel-ubuntu22.04 | ||||||
| LABEL maintainer="Hugging Face" | LABEL maintainer="Hugging Face" | ||||||
|  |  | ||||||
| ARG DEBIAN_FRONTEND=noninteractive | ARG DEBIAN_FRONTEND=noninteractive | ||||||
| @ -11,28 +11,23 @@ ARG REF=main | |||||||
| RUN git clone https://github.com/huggingface/transformers && cd transformers && git checkout $REF | RUN git clone https://github.com/huggingface/transformers && cd transformers && git checkout $REF | ||||||
|  |  | ||||||
| # If set to nothing, will install the latest version | # If set to nothing, will install the latest version | ||||||
| ARG PYTORCH='2.7.1' | ARG PYTORCH='2.5.1' | ||||||
| ARG TORCH_VISION='' | ARG TORCH_VISION='' | ||||||
| ARG TORCH_AUDIO='' | ARG TORCH_AUDIO='' | ||||||
| # Example: `cu102`, `cu113`, etc. | # Example: `cu102`, `cu113`, etc. | ||||||
| ARG CUDA='cu126' | ARG CUDA='cu121' | ||||||
|  |  | ||||||
| RUN python3 -m pip install --no-cache-dir -e ./transformers[dev-torch,testing,video] |  | ||||||
|  |  | ||||||
| # Install torch stuff after ./transformers[dev-torch,testing,video], otherwise torch may be resolved to a previous |  | ||||||
| # version. |  | ||||||
| RUN [ ${#PYTORCH} -gt 0 ] && VERSION='torch=='$PYTORCH'.*' ||  VERSION='torch'; python3 -m pip install --no-cache-dir -U $VERSION --extra-index-url https://download.pytorch.org/whl/$CUDA | RUN [ ${#PYTORCH} -gt 0 ] && VERSION='torch=='$PYTORCH'.*' ||  VERSION='torch'; python3 -m pip install --no-cache-dir -U $VERSION --extra-index-url https://download.pytorch.org/whl/$CUDA | ||||||
| RUN [ ${#TORCH_VISION} -gt 0 ] && VERSION='torchvision=='TORCH_VISION'.*' ||  VERSION='torchvision'; python3 -m pip install --no-cache-dir -U $VERSION --extra-index-url https://download.pytorch.org/whl/$CUDA | RUN [ ${#TORCH_VISION} -gt 0 ] && VERSION='torchvision=='TORCH_VISION'.*' ||  VERSION='torchvision'; python3 -m pip install --no-cache-dir -U $VERSION --extra-index-url https://download.pytorch.org/whl/$CUDA | ||||||
| RUN [ ${#TORCH_AUDIO} -gt 0 ] && VERSION='torchaudio=='TORCH_AUDIO'.*' ||  VERSION='torchaudio'; python3 -m pip install --no-cache-dir -U $VERSION --extra-index-url https://download.pytorch.org/whl/$CUDA | RUN [ ${#TORCH_AUDIO} -gt 0 ] && VERSION='torchaudio=='TORCH_AUDIO'.*' ||  VERSION='torchaudio'; python3 -m pip install --no-cache-dir -U $VERSION --extra-index-url https://download.pytorch.org/whl/$CUDA | ||||||
|  |  | ||||||
|  | RUN python3 -m pip install --no-cache-dir -e ./transformers[dev-torch,testing,video] | ||||||
|  |  | ||||||
| RUN python3 -m pip uninstall -y tensorflow flax | RUN python3 -m pip uninstall -y tensorflow flax | ||||||
|  |  | ||||||
| RUN python3 -m pip install --no-cache-dir git+https://github.com/facebookresearch/detectron2.git pytesseract | RUN python3 -m pip install --no-cache-dir git+https://github.com/facebookresearch/detectron2.git pytesseract | ||||||
| RUN python3 -m pip install -U "itsdangerous<2.1.0" | RUN python3 -m pip install -U "itsdangerous<2.1.0" | ||||||
|  |  | ||||||
| # `kernels` may give different outputs (within 1e-5 range) even with the same model (weights) and the same inputs |  | ||||||
| RUN python3 -m pip uninstall -y kernels |  | ||||||
|  |  | ||||||
| # When installing in editable mode, `transformers` is not recognized as a package. | # When installing in editable mode, `transformers` is not recognized as a package. | ||||||
| # this line must be added in order for python to be aware of transformers. | # this line must be added in order for python to be aware of transformers. | ||||||
| RUN cd transformers && python3 setup.py develop | RUN cd transformers && python3 setup.py develop | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| FROM nvidia/cuda:12.1.1-cudnn8-devel-ubuntu22.04 | FROM nvidia/cuda:11.8.0-cudnn8-devel-ubuntu22.04 | ||||||
| LABEL maintainer="Hugging Face" | LABEL maintainer="Hugging Face" | ||||||
|  |  | ||||||
| ARG DEBIAN_FRONTEND=noninteractive | ARG DEBIAN_FRONTEND=noninteractive | ||||||
| @ -9,11 +9,9 @@ SHELL ["sh", "-lc"] | |||||||
| # The following `ARG` are mainly used to specify the versions explicitly & directly in this docker file, and not meant | # The following `ARG` are mainly used to specify the versions explicitly & directly in this docker file, and not meant | ||||||
| # to be used as arguments for docker build (so far). | # to be used as arguments for docker build (so far). | ||||||
|  |  | ||||||
| ARG PYTORCH='2.6.0' | ARG PYTORCH='2.5.1' | ||||||
| # Example: `cu102`, `cu113`, etc. | # Example: `cu102`, `cu113`, etc. | ||||||
| ARG CUDA='cu121' | ARG CUDA='cu118' | ||||||
| # Disable kernel mapping for quantization tests |  | ||||||
| ENV DISABLE_KERNEL_MAPPING=1 |  | ||||||
|  |  | ||||||
| RUN apt update | RUN apt update | ||||||
| RUN apt install -y git libsndfile1-dev tesseract-ocr espeak-ng python3 python3-pip ffmpeg | RUN apt install -y git libsndfile1-dev tesseract-ocr espeak-ng python3 python3-pip ffmpeg | ||||||
| @ -28,6 +26,8 @@ RUN echo torch=$VERSION | |||||||
| # Currently, let's just use their latest releases (when `torch` is installed with a release version) | # Currently, let's just use their latest releases (when `torch` is installed with a release version) | ||||||
| RUN python3 -m pip install --no-cache-dir -U $VERSION torchvision torchaudio --extra-index-url https://download.pytorch.org/whl/$CUDA | RUN python3 -m pip install --no-cache-dir -U $VERSION torchvision torchaudio --extra-index-url https://download.pytorch.org/whl/$CUDA | ||||||
|  |  | ||||||
|  | RUN python3 -m pip install --no-cache-dir -e ./transformers[dev-torch] | ||||||
|  |  | ||||||
| RUN python3 -m pip install --no-cache-dir git+https://github.com/huggingface/accelerate@main#egg=accelerate | RUN python3 -m pip install --no-cache-dir git+https://github.com/huggingface/accelerate@main#egg=accelerate | ||||||
|  |  | ||||||
| # needed in bnb and awq | # needed in bnb and awq | ||||||
| @ -36,9 +36,10 @@ RUN python3 -m pip install --no-cache-dir einops | |||||||
| # Add bitsandbytes for mixed int8 testing | # Add bitsandbytes for mixed int8 testing | ||||||
| RUN python3 -m pip install --no-cache-dir bitsandbytes | RUN python3 -m pip install --no-cache-dir bitsandbytes | ||||||
|  |  | ||||||
| # Add gptqmodel for gtpq quantization testing, installed from source for pytorch==2.6.0 compatibility | # Add auto-gptq for gtpq quantization testing, installed from source for pytorch==2.5.1 compatibility | ||||||
| RUN python3 -m pip install lm_eval | # TORCH_CUDA_ARCH_LIST="7.5+PTX" is added to make the package compile for Tesla T4 gpus available for the CI. | ||||||
| RUN git clone https://github.com/ModelCloud/GPTQModel.git && cd GPTQModel && pip install -v . --no-build-isolation | RUN pip install gekko | ||||||
|  | RUN git clone https://github.com/PanQiWei/AutoGPTQ.git && cd AutoGPTQ && TORCH_CUDA_ARCH_LIST="7.5+PTX" python3 setup.py install | ||||||
|  |  | ||||||
| # Add optimum for gptq quantization testing | # Add optimum for gptq quantization testing | ||||||
| RUN python3 -m pip install --no-cache-dir git+https://github.com/huggingface/optimum@main#egg=optimum | RUN python3 -m pip install --no-cache-dir git+https://github.com/huggingface/optimum@main#egg=optimum | ||||||
| @ -50,11 +51,7 @@ RUN python3 -m pip install --no-cache-dir git+https://github.com/huggingface/pef | |||||||
| RUN python3 -m pip install --no-cache-dir aqlm[gpu]==1.0.2 | RUN python3 -m pip install --no-cache-dir aqlm[gpu]==1.0.2 | ||||||
|  |  | ||||||
| # Add vptq for quantization testing | # Add vptq for quantization testing | ||||||
| RUN pip install vptq | RUN python3 -m pip install --no-cache-dir vptq | ||||||
|  |  | ||||||
| # Add spqr for quantization testing |  | ||||||
| # Commented for now as No matching distribution found we need to reach out to the authors |  | ||||||
| # RUN python3 -m pip install --no-cache-dir spqr_quant[gpu] |  | ||||||
|  |  | ||||||
| # Add hqq for quantization testing | # Add hqq for quantization testing | ||||||
| RUN python3 -m pip install --no-cache-dir hqq | RUN python3 -m pip install --no-cache-dir hqq | ||||||
| @ -63,35 +60,18 @@ RUN python3 -m pip install --no-cache-dir hqq | |||||||
| RUN python3 -m pip install --no-cache-dir gguf | RUN python3 -m pip install --no-cache-dir gguf | ||||||
|  |  | ||||||
| # Add autoawq for quantization testing | # Add autoawq for quantization testing | ||||||
| # New release v0.2.8 | # >=v0.2.7 needed for compatibility with transformers > 4.46 | ||||||
| RUN python3 -m pip install --no-cache-dir autoawq[kernels] | RUN python3 -m pip install --no-cache-dir https://github.com/casper-hansen/AutoAWQ/releases/download/v0.2.7.post2/autoawq-0.2.7.post2-py3-none-any.whl | ||||||
|  |  | ||||||
| # Add quanto for quantization testing | # Add quanto for quantization testing | ||||||
| RUN python3 -m pip install --no-cache-dir optimum-quanto | RUN python3 -m pip install --no-cache-dir optimum-quanto | ||||||
|  |  | ||||||
| # Add eetq for quantization testing | # Add eetq for quantization testing | ||||||
| RUN git clone https://github.com/NetEase-FuXi/EETQ.git && cd EETQ/ && git submodule update --init --recursive && pip install . | RUN python3 -m pip install git+https://github.com/NetEase-FuXi/EETQ.git | ||||||
|  |  | ||||||
| # # Add flute-kernel and fast_hadamard_transform for quantization testing | # Add flute-kernel and fast_hadamard_transform for quantization testing | ||||||
| # # Commented for now as they cause issues with the build | RUN python3 -m pip install --no-cache-dir flute-kernel==0.3.0 -i https://flute-ai.github.io/whl/cu118 | ||||||
| # # TODO: create a new workflow to test them | RUN python3 -m pip install --no-cache-dir fast_hadamard_transform==1.0.4.post1 | ||||||
| # RUN python3 -m pip install --no-cache-dir flute-kernel==0.4.1 |  | ||||||
| # RUN python3 -m pip install --no-cache-dir git+https://github.com/Dao-AILab/fast-hadamard-transform.git |  | ||||||
|  |  | ||||||
| # Add compressed-tensors for quantization testing |  | ||||||
| RUN python3 -m pip install --no-cache-dir compressed-tensors |  | ||||||
|  |  | ||||||
| # Add AMD Quark for quantization testing |  | ||||||
| RUN python3 -m pip install --no-cache-dir amd-quark |  | ||||||
|  |  | ||||||
| # Add AutoRound for quantization testing |  | ||||||
| RUN python3 -m pip install --no-cache-dir "auto-round>=0.5.0" |  | ||||||
|  |  | ||||||
| # Add transformers in editable mode |  | ||||||
| RUN python3 -m pip install --no-cache-dir -e ./transformers[dev-torch] |  | ||||||
|  |  | ||||||
| # `kernels` may give different outputs (within 1e-5 range) even with the same model (weights) and the same inputs |  | ||||||
| RUN python3 -m pip uninstall -y kernels |  | ||||||
|  |  | ||||||
| # When installing in editable mode, `transformers` is not recognized as a package. | # When installing in editable mode, `transformers` is not recognized as a package. | ||||||
| # this line must be added in order for python to be aware of transformers. | # this line must be added in order for python to be aware of transformers. | ||||||
|  | |||||||
| @ -278,7 +278,7 @@ Here's an example of a single value return: | |||||||
|  |  | ||||||
| ```python | ```python | ||||||
|     Returns: |     Returns: | ||||||
|         `list[int]`: A list of integers in the range [0, 1] --- 1 for a special token, 0 for a sequence token. |         `List[int]`: A list of integers in the range [0, 1] --- 1 for a special token, 0 for a sequence token. | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Here's an example of a tuple return, comprising several objects: | Here's an example of a tuple return, comprising several objects: | ||||||
|  | |||||||
| @ -23,6 +23,8 @@ | |||||||
|     title: تحميل النماذج المخصصة وتدريبها باستخدام 🤗 PEFT |     title: تحميل النماذج المخصصة وتدريبها باستخدام 🤗 PEFT | ||||||
|   - local: model_sharing |   - local: model_sharing | ||||||
|     title: مشاركة نموذجك |     title: مشاركة نموذجك | ||||||
|  |   - local: agents | ||||||
|  |     title: الوكلاء | ||||||
|   - local: llm_tutorial |   - local: llm_tutorial | ||||||
|     title: التوليد باستخدام LLMs |     title: التوليد باستخدام LLMs | ||||||
|   - local: conversations |   - local: conversations | ||||||
| @ -250,6 +252,8 @@ | |||||||
|   title: أطر مفاهيمية |   title: أطر مفاهيمية | ||||||
| # - sections: | # - sections: | ||||||
| #   - sections: | #   - sections: | ||||||
|  | #     - local: main_classes/agent | ||||||
|  | #       title: الوكلاء والأدوات | ||||||
| #     - local: model_doc/auto | #     - local: model_doc/auto | ||||||
| #       title: فئات يتم إنشاؤها ديناميكيًا | #       title: فئات يتم إنشاؤها ديناميكيًا | ||||||
| #     - local: main_classes/backbones | #     - local: main_classes/backbones | ||||||
|  | |||||||
							
								
								
									
										539
									
								
								docs/source/ar/agents.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										539
									
								
								docs/source/ar/agents.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,539 @@ | |||||||
|  | # الوكلاء والأدوات | ||||||
|  |  | ||||||
|  | [[open-in-colab]] | ||||||
|  |  | ||||||
|  | ### ما هو الوكيل؟ | ||||||
|  |  | ||||||
|  | يمكن للنظم اللغوية الكبيرة (LLMs) التي تم تدريبها على أداء [نمذجة اللغة السببية](./tasks/language_modeling.) التعامل مع مجموعة واسعة من المهام، ولكنها غالبًا ما تواجه صعوبات في المهام الأساسية مثل المنطق والحساب والبحث. وعندما يتم استدعاؤها في مجالات لا تؤدي فيها أداءً جيدًا، فإنها غالبًا ما تفشل في توليد الإجابة التي نتوقعها منها. | ||||||
|  |  | ||||||
|  | يتمثل أحد النهج للتغلب على هذا القصور في إنشاء "وكيل". | ||||||
|  |  | ||||||
|  | الوكيل هو نظام يستخدم LLM كمحرك له، ولديه حق الوصول إلى وظائف تسمى "أدوات". | ||||||
|  |  | ||||||
|  | هذه "الأدوات" هي وظائف لأداء مهمة، وتحتوي على جميع الأوصاف اللازمة للوكيل لاستخدامها بشكل صحيح. | ||||||
|  |  | ||||||
|  | يمكن برمجة الوكيل للقيام بما يلي: | ||||||
|  | - وضع سلسلة من الإجراءات/الأدوات وتشغيلها جميعًا في نفس الوقت مثل [`CodeAgent`] على سبيل المثال | ||||||
|  | - التخطيط للاجراءات/الأدوات وتنفيذها واحدة تلو الأخرى والانتظار حتى انتهاء كل إجراء قبل إطلاق التالي مثل [`ReactJsonAgent`] على سبيل المثال | ||||||
|  |  | ||||||
|  | ### أنواع الوكلاء | ||||||
|  |  | ||||||
|  | #### الوكيل البرمجي (Code agent) | ||||||
|  |  | ||||||
|  | يتمتع هذا الوكيل يتبع خطوات محددة: أولًا، يخطط لسلسلة من الإجراءات التي يريد تنفيذها، ثم شفرة Python لتنفيذ جميع الإجراءات في نفس الوقت. وهو يتعامل بشكل أصلي مع أنواع مختلفة من المدخلات والمخرجات للأدوات التي يستخدمها، وبالتالي فهو الخيار الموصى به للمهام متعددة الوسائط. | ||||||
|  |  | ||||||
|  | #### وكلاء التفاعل | ||||||
|  |  | ||||||
|  | هذا هو الوكيل الذي يتم اللجوء إليه لحل مهام الاستدلال، حيث يجعل إطار ReAct ([Yao et al.، 2022](https://huggingface.co/papers/2210.03629)) من الكفاءة حقًا التفكير على أساس ملاحظاته السابقة. | ||||||
|  |  | ||||||
|  | نقوم بتنفيذ إصدارين من ReactJsonAgent:  | ||||||
|  | - [`ReactJsonAgent`] يقوم بتوليد استدعاءات الأدوات كـ JSON في إخراجها. | ||||||
|  | - [`ReactCodeAgent`] هو نوع جديد من ReactJsonAgent يقوم بتوليد استدعاءات أدواته كمقاطع من التعليمات البرمجية، والتي تعمل بشكل جيد حقًا مع LLMs التي تتمتع بأداء  قوي في البرمجة. | ||||||
|  |  | ||||||
|  | > [!TIP] | ||||||
|  | > اقرأ منشور المدونة [Open-source LLMs as LangChain Agents](https://huggingface.co/blog/open-source-llms-as-agents) لمعرفة المزيد عن وكيل ReAct. | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | على سبيل المثال، إليك كيف يعمل وكيل ReAct Code طريقه من خلال السؤال التالي. | ||||||
|  |  | ||||||
|  | ```py3 | ||||||
|  | >>> agent.run( | ||||||
|  | ...     "How many more blocks (also denoted as layers) in BERT base encoder than the encoder from the architecture proposed in Attention is All You Need?", | ||||||
|  | ... ) | ||||||
|  | =====New task===== | ||||||
|  | How many more blocks (also denoted as layers) in BERT base encoder than the encoder from the architecture proposed in Attention is All You Need? | ||||||
|  | ====Agent is executing the code below: | ||||||
|  | bert_blocks = search(query="number of blocks in BERT base encoder") | ||||||
|  | print("BERT blocks:", bert_blocks) | ||||||
|  | ==== | ||||||
|  | Print outputs: | ||||||
|  | BERT blocks: twelve encoder blocks | ||||||
|  |  | ||||||
|  | ====Agent is executing the code below: | ||||||
|  | attention_layer = search(query="number of layers in Attention is All You Need") | ||||||
|  | print("Attention layers:", attention_layer) | ||||||
|  | ==== | ||||||
|  | Print outputs: | ||||||
|  | Attention layers: Encoder: The encoder is composed of a stack of N = 6 identical layers. Each layer has two sub-layers. The first is a multi-head self-attention mechanism, and the second is a simple, position- 2 Page 3 Figure 1: The Transformer - model architecture. | ||||||
|  |  | ||||||
|  | ====Agent is executing the code below: | ||||||
|  | bert_blocks = 12 | ||||||
|  | attention_layers = 6 | ||||||
|  | diff = bert_blocks - attention_layers | ||||||
|  | print("Difference in blocks:", diff) | ||||||
|  | final_answer(diff) | ||||||
|  | ==== | ||||||
|  |  | ||||||
|  | Print outputs: | ||||||
|  | Difference in blocks: 6 | ||||||
|  |  | ||||||
|  | Final answer: 6 | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### كيف يمكنني بناء وكيل؟ | ||||||
|  |  | ||||||
|  | لتهيئة وكيل، تحتاج إلى هذه الوسائط: | ||||||
|  |  | ||||||
|  | - نموذج لغوي كبير (LLM) يشكل المحرك الأساسي للوكيل. الوكيل نفسه ليس النموذج اللغوي، بل هو برنامج يستخدم النموذج اللغوي كمحرك له. | ||||||
|  | - موجه النظام (system prompt): هذه هي التعليمات التي يتم إعطاؤها للنموذج اللغوي لإنشاء مخرجاته. | ||||||
|  | - صندوق أدوات (toolbox) يختار الوكيل منه الأدوات لتنفيذها | ||||||
|  | - محلل (parser) لاستخراج الأدوات التي يجب استدعاؤها من مخرجات النموذج اللغوي LLM والأدوات التي يجب استخدامها | ||||||
|  |  | ||||||
|  | عند تهيئة نظام الوكيل، يتم استخدام سمات الأداة لإنشاء وصف للأداة، ثم يتم دمجها في موجه النظام الخاص `system_prompt` للوكيل لإعلامه بالأدوات التي يمكنه استخدامها ولماذا. | ||||||
|  |  | ||||||
|  | للبدء، يرجى تثبيت `agents` الإضافية لتثبيت جميع التبعيات الافتراضية. | ||||||
|  |  | ||||||
|  | ```bash | ||||||
|  | pip install transformers[agents] | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | قم ببناء محرك LLM الخاص بك من خلال تعريف طريقة `llm_engine` التي تقبل قائمة من [الرسائل](./chat_templating.) وتعيد النص. يجب أن تقبل هذه الدالة القابلة للاستدعاء أيضًا معامل `stop` يشير إلى متى يجب التوقف عن التوليد. | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | from huggingface_hub import login, InferenceClient | ||||||
|  |  | ||||||
|  | login("<YOUR_HUGGINGFACEHUB_API_TOKEN>") | ||||||
|  |  | ||||||
|  | client = InferenceClient(model="meta-llama/Meta-Llama-3-70B-Instruct") | ||||||
|  |  | ||||||
|  | def llm_engine(messages, stop_sequences=["Task"]) -> str: | ||||||
|  |     response = client.chat_completion(messages, stop=stop_sequences, max_tokens=1000) | ||||||
|  |     answer = response.choices[0].message.content | ||||||
|  |     return answer | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | يمكنك استخدام أي طريقة `llm_engine` طالما أنها: | ||||||
|  | 1. يتبع تنسيق [رسائل](./chat_templating.md) لإدخاله (`List [Dict [str، str]]`) ويعيد `str` | ||||||
|  | 2. يتوقف عن توليد المخراجات من التسلسلات التي تم تمريرها في معامل `stop` | ||||||
|  |  | ||||||
|  | أنت بحاجة أيضًا إلى معامل "الأدوات" الذي يقبل قائمة من "الأدوات". يمكنك توفير قائمة فارغة لـ "الأدوات"، ولكن استخدم صندوق الأدوات الافتراضي مع معامل اختياري `add_base_tools=True`. | ||||||
|  |  | ||||||
|  | الآن يمكنك إنشاء وكيل، مثل [`CodeAgent`], وتشغيله. ولتسهيل الأمر، نقدم أيضًا فئة [`HfEngine`] التي تستخدم `huggingface_hub.InferenceClient` بشكل مخفى. | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | from transformers import CodeAgent, HfEngine | ||||||
|  |  | ||||||
|  | llm_engine = HfEngine(model="meta-llama/Meta-Llama-3-70B-Instruct") | ||||||
|  | agent = CodeAgent(tools=[], llm_engine=llm_engine, add_base_tools=True) | ||||||
|  |  | ||||||
|  | agent.run( | ||||||
|  |     "Could you translate this sentence from French, say it out loud and return the audio.", | ||||||
|  |     sentence="Où est la boulangerie la plus proche?", | ||||||
|  | ) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | هذه الميزة ستكون مفيدة في حالة الحاجة الملحة! يمكنك حتى ترك معامل `llm_engine` غير محدد، وسيتم إنشاء [`HfEngine`] بشكل تلقائي. | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | from transformers import CodeAgent | ||||||
|  |  | ||||||
|  | agent = CodeAgent(tools=[], add_base_tools=True) | ||||||
|  |  | ||||||
|  | agent.run( | ||||||
|  |     "Could you translate this sentence from French, say it out loud and give me the audio.", | ||||||
|  |     sentence="Où est la boulangerie la plus proche?", | ||||||
|  | ) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | لاحظ أننا استخدمنا معامل "sentence" إضافي: يمكنك تمرير النص كمعامل إضافي إلى النموذج. | ||||||
|  |  | ||||||
|  | يمكنك أيضًا استخدام هذا للإشارة إلى مسار الملفات المحلية أو البعيدة للنموذج لاستخدامها: | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | from transformers import ReactCodeAgent | ||||||
|  |  | ||||||
|  | agent = ReactCodeAgent(tools=[], llm_engine=llm_engine, add_base_tools=True) | ||||||
|  |  | ||||||
|  | agent.run("Why does Mike not know many people in New York?", audio="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/transformers/recording.mp3") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | تم تحديد موجه النظام ومحلل المخرجات تلقائيًا، ولكن يمكنك فحصهما بسهولة عن طريق استدعاء `system_prompt_template` على وكيلك. | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | print(agent.system_prompt_template) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | من المهم أن تشرح بأكبر قدر ممكن من الوضوح المهمة التي تريد تنفيذها. | ||||||
|  | كل عملية [`~Agent.run`] مستقلة، وبما أن الوكيل مدعوم من LLM، فقد تؤدي الاختلافات الطفيفة في موجهك إلى نتائج مختلفة تمامًا. | ||||||
|  | يمكنك أيضًا تشغيل وكيل بشكل متتالي لمهام مختلفة: في كل مرة يتم فيها إعادة تهيئة سمتي `agent.task` و`agent.logs`. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #### تنفيذ التعليمات البرمجية | ||||||
|  |  | ||||||
|  | يقوم مفسر Python بتنفيذ التعليمات البرمجية على مجموعة من المدخلات التي يتم تمريرها جنبًا إلى جنب مع أدواتك. | ||||||
|  | يجب أن يكون هذا الأمر آمنًا لأن الوظائف الوحيدة التي يمكن استدعاؤها هي الأدوات التي قدمتها (خاصة إذا كانت أدوات من Hugging Face فقط) ووظيفة الطباعة، لذا فأنت مقيد بالفعل بما يمكن تنفيذه. | ||||||
|  |  | ||||||
|  | مفسر Python لا يسمح أيضًا باستدعاء دوال بشكل افتراضي خارج قائمة آمنة، لذا فإن جميع الهجمات الأكثر وضوحًا لا ينبغي أن تكون مشكلة. | ||||||
|  | يمكنك أيضًا الإذن باستيرادات إضافية عن طريق تمرير الوحدات النمطية المصرح بها كقائمة من السلاسل في معامل  `additional_authorized_imports` عند تهيئة [`ReactCodeAgent`] أو [`CodeAgent`]: | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | >>> from transformers import ReactCodeAgent | ||||||
|  |  | ||||||
|  | >>> agent = ReactCodeAgent(tools=[], additional_authorized_imports=['requests', 'bs4']) | ||||||
|  | >>> agent.run("Could you get me the title of the page at url 'https://huggingface.co/blog'?") | ||||||
|  |  | ||||||
|  | (...) | ||||||
|  | 'Hugging Face – Blog' | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | سيتم إيقاف التنفيذ عند أي رمز يحاول تنفيذ عملية غير قانونية أو إذا كان هناك خطأ Python عادي في التعليمات البرمجية التي تم إنشاؤها بواسطة الوكيل. | ||||||
|  |  | ||||||
|  | > [!WARNING] | ||||||
|  | > يمكن لـ LLM توليد شفرة برمجية عشوائية سيتم تنفيذها بعد ذلك: لا تقمب استدعاء أى دوال غير آمنة! | ||||||
|  |  | ||||||
|  | ### موجه النظام | ||||||
|  |  | ||||||
|  | ينشئ الوكيل، أو بالأحرى LLM الذي يقود الوكيل، يولد مخرجات بناءً على موجه النظام. يمكن تخصيص موجه النظام وتصميمه للمهام المقصودة. على سبيل المثال، تحقق من موجه النظام لـ [`ReactCodeAgent`] (الإصدار أدناه مبسط قليلاً). | ||||||
|  |  | ||||||
|  | ```text | ||||||
|  | You will be given a task to solve as best you can. | ||||||
|  | You have access to the following tools: | ||||||
|  | <<tool_descriptions>> | ||||||
|  |  | ||||||
|  | To solve the task, you must plan forward to proceed in a series of steps, in a cycle of 'Thought:', 'Code:', and 'Observation:' sequences. | ||||||
|  |  | ||||||
|  | At each step, in the 'Thought:' sequence, you should first explain your reasoning towards solving the task, then the tools that you want to use. | ||||||
|  | Then in the 'Code:' sequence, you shold write the code in simple Python. The code sequence must end with '/End code' sequence. | ||||||
|  | During each intermediate step, you can use 'print()' to save whatever important information you will then need. | ||||||
|  | These print outputs will then be available in the 'Observation:' field, for using this information as input for the next step. | ||||||
|  |  | ||||||
|  | In the end you have to return a final answer using the `final_answer` tool. | ||||||
|  |  | ||||||
|  | Here are a few examples using notional tools: | ||||||
|  | --- | ||||||
|  | {examples} | ||||||
|  |  | ||||||
|  | Above example were using notional tools that might not exist for you. You only have acces to those tools: | ||||||
|  | <<tool_names>> | ||||||
|  | You also can perform computations in the python code you generate. | ||||||
|  |  | ||||||
|  | Always provide a 'Thought:' and a 'Code:\n```py' sequence ending with '```<end_code>' sequence. You MUST provide at least the 'Code:' sequence to move forward. | ||||||
|  |  | ||||||
|  | Remember to not perform too many operations in a single code block! You should split the task into intermediate code blocks. | ||||||
|  | Print results at the end of each step to save the intermediate results. Then use final_answer() to return the final result. | ||||||
|  |  | ||||||
|  | Remember to make sure that variables you use are all defined. | ||||||
|  |  | ||||||
|  | Now Begin! | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | يتضمن موجه النظام: | ||||||
|  | - *مقدمة* تشرح كيف يجب أن يتصرف الوكيل والأدوات التي يجب عليه استخدامها. | ||||||
|  | - وصف لجميع الأدوات التي يتم تحديدها بواسطة رمز `<<tool_descriptions>>` الذي يتم استبداله ديناميكيًا في وقت التشغيل بالأدوات التي يحددها المستخدم أو يختارها. | ||||||
|  |     - يأتي وصف الأداة من سمات الأداة، `name`، و`description`، و`inputs` و`output_type`، وقالب `jinja2` بسيط يمكنك تحسينه. | ||||||
|  | - شكل المخرج المتوقع. | ||||||
|  |  | ||||||
|  | يمكنك تحسين موجه النظام، على سبيل المثال، عن طريق إضافة شرح لتنسيق المخرجات. | ||||||
|  |  | ||||||
|  | للحصول على أقصى قدر من المرونة، يمكنك الكتابة فوق قالب موجه النظام بالكامل عن طريق تمرير موجه مخصص كمعامل إلى معلمة `system_prompt`. | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | from transformers import ReactJsonAgent | ||||||
|  | from transformers.agents import PythonInterpreterTool | ||||||
|  |  | ||||||
|  | agent = ReactJsonAgent(tools=[PythonInterpreterTool()], system_prompt="{your_custom_prompt}") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | > [!WARNING] | ||||||
|  | > يرجى التأكد من تحديد سلسلة `<<tool_descriptions>>` في مكان ما في `template` حتى يكون الوكيل على علم  | ||||||
|  | بالأدوات المتاحة. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### فحص تشغيل الوكيل | ||||||
|  |  | ||||||
|  | فيما يلي بعض السمات المفيدة لفحص ما حدث بعد التشغيل: | ||||||
|  | - تخزن  `agent.logs` سجلات مفصلة للوكيل. في كل خطوة من تشغيل الوكيل، يتم تخزين كل شيء في قاموس إلحاقه بـ `agent.logs`. | ||||||
|  | - تشغيل `agent.write_inner_memory_from_logs()` يخلق ذاكرة داخلية لسجلات الوكيل للنظام LLM لعرضها، كقائمة من رسائل الدردشة. تنتقل هذه الطريقة عبر كل خطوة من سجل الوكيل ولا تخزن سوى ما يهمها كرسالة: على سبيل المثال، سيحفظ موجه النظام والمهمة في رسائل منفصلة، ثم لكل خطوة سيخزن مخرج LLM كرسالة، ومخرج استدعاء الأداة كرسالة أخرى. استخدم هذا إذا كنت تريد عرضًا عامًا لما حدث - ولكن لن يتم نسخ كل سجل بواسطة هذه الطريقة. | ||||||
|  |  | ||||||
|  | ## الأدوات | ||||||
|  |  | ||||||
|  | الأداة هي عبارة عن وظيفة أساسية يستخدمها الوكيل لتنفيذ مهمة محددة. | ||||||
|  |  | ||||||
|  | يمكنك على سبيل المثال التحقق من [`PythonInterpreterTool`]: لديه اسم ووصف ووصف للمدخلات ونوع للمخرج، وطريقة `__call__` التي تقوم بتنفيذ المهمة المطلوبة. | ||||||
|  |  | ||||||
|  | عند تهيئة الوكيل، يتم استخدام سمات الأداة لتوليد وصف للأداة يتم تضمينه في موجه النظام الخاص بالوكيل. يتيح هذا للوكيل معرفة الأدوات التي يمكنه استخدامها ولماذا. | ||||||
|  |  | ||||||
|  | ### صندوق الأدوات الافتراضي | ||||||
|  |  | ||||||
|  | يأتي Transformers مع صندوق أدوات افتراضي لتمكين الوكلاء، والذي يمكنك إضافته إلى وكيلك عند التهيئة باستخدام معامل `add_base_tools = True`: | ||||||
|  |  | ||||||
|  | - **الإجابة على أسئلة المستند**: الإجابة على سؤال حول المستند (مثل ملف PDF) بتنسيق صورة ([Donut](./model_doc/donut)) | ||||||
|  | - **الإجابة على أسئلة الصور**: الإجابة على سؤال حول صورة ([VILT](./model_doc/vilt)) | ||||||
|  | - **التحدث إلى النص**: قم بتفريغ الكلام إلى نص ([Whisper](./model_doc/whisper)) | ||||||
|  | - **النص إلى كلام**: تحويل النص إلى كلام ([SpeechT5](./model_doc/speecht5)) | ||||||
|  | - **الترجمة**: ترجمة جملة معينة من لغة المصدر إلى لغة الهدف. | ||||||
|  | - **مفسر كود Python**: تشغيل كود Python الذي تم إنشاؤه بواسطة LLM في بيئة آمنة. لن يتم إضافة هذه الأداة إلى [`ReactJsonAgent`] إلا إذا استخدمت `add_base_tools=True`، نظرًا لأن الأدوات المستندة إلى التعليمات البرمجية يمكنها بالفعل تنفيذ كود Python | ||||||
|  | لا تترجم النصوص الخاصة ولا الأكواد البرمجية ولا الروابط ولا رموز HTML وCSS: | ||||||
|  |  | ||||||
|  | يمكنك استخدام أداة يدويًا عن طريق استدعاء دالة [`load_tool`] وتحديد مهمة لتنفيذها. | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | from transformers import load_tool | ||||||
|  |  | ||||||
|  | tool = load_tool("text-to-speech") | ||||||
|  | audio = tool("This is a text to speech tool") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### إنشاء أداة جديدة | ||||||
|  |  | ||||||
|  | يمكنك إنشاء أداتك الخاصة لتغطية حالات الاستخدام التي لا تغطيها الأدوات الافتراضية من Hugging Face. | ||||||
|  | على سبيل المثال، دعنا نقوم بإنشاء أداة تعرض النموذج الأكثر تنزيلًا لمهمة معينة من Hub. | ||||||
|  |  | ||||||
|  | سوف نبدأ بالكود التالي. | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | from huggingface_hub import list_models | ||||||
|  |  | ||||||
|  | task = "text-classification" | ||||||
|  |  | ||||||
|  | model = next(iter(list_models(filter=task, sort="downloads", direction=-1))) | ||||||
|  | print(model.id) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | يمكن تحويل هذه الشيفرة إلى فئة ترث من الفئة العليا [`Tool`]. | ||||||
|  |  | ||||||
|  | تحتاج الأداة المخصصة إلى: | ||||||
|  |  | ||||||
|  | - اسم `name`، والتي تمثل اسم الأداة نفسها. عادةً ما يصف الاسم وظيفتها. بما أن الكود يعيد النموذج الأكثر تنزيلًا لمهمة ما، فلنسمها `model_download_counter`. | ||||||
|  | - تستخدم خاصية `description` لملء موجه نظام الوكيل. | ||||||
|  | - خاصية `inputs`، والتي هي عبارة عن قاموس بمفاتيح "type" و"description". يحتوي على معلومات تساعد المفسر Python على اتخاذ خيارات مستنيرة بشأن المدخلات. | ||||||
|  | - خاصية `output_type`، والتي تحدد نوع المخرج. | ||||||
|  | - طريقة `forward` والتي تحتوي على الكود الذي سيتم تنفيذه للحصول على النتيجة النهائية. | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | from transformers import Tool | ||||||
|  | from huggingface_hub import list_models | ||||||
|  |  | ||||||
|  | class HFModelDownloadsTool(Tool): | ||||||
|  |     name = "model_download_counter" | ||||||
|  |     description = ( | ||||||
|  |         "This is a tool that returns the most downloaded model of a given task on the Hugging Face Hub. " | ||||||
|  |         "It returns the name of the checkpoint." | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |     inputs = { | ||||||
|  |         "task": { | ||||||
|  |             "type": "text", | ||||||
|  |             "description": "the task category (such as text-classification, depth-estimation, etc)", | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     output_type = "text" | ||||||
|  |  | ||||||
|  |     def forward(self, task: str): | ||||||
|  |         model = next(iter(list_models(filter=task, sort="downloads", direction=-1))) | ||||||
|  |         return model.id | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | الآن بعد أن أصبحت فئة `HfModelDownloadsTool` المخصصة جاهزة، يمكنك حفظها في ملف باسم `model_downloads.py` واستيرادها للاستخدام. | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | from model_downloads import HFModelDownloadsTool | ||||||
|  |  | ||||||
|  | tool = HFModelDownloadsTool() | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | يمكنك أيضًا مشاركة أداتك المخصصة في Hub عن طريق استدعاء [`~Tool.push_to_hub`] على الأداة. تأكد من أنك قمت بإنشاء مستودع لها على Hub وأنك تستخدم رمز وصول للقراءة. | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | tool.push_to_hub("{your_username}/hf-model-downloads") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | قم بتحميل الأداة باستخدام دالة [`~Tool.load_tool`] ومررها إلى معلمة `tools` في الوكيل الخاص بك. | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | from transformers import load_tool, CodeAgent | ||||||
|  |  | ||||||
|  | model_download_tool = load_tool("m-ric/hf-model-downloads") | ||||||
|  | agent = CodeAgent(tools=[model_download_tool], llm_engine=llm_engine) | ||||||
|  | agent.run( | ||||||
|  |     "Can you give me the name of the model that has the most downloads in the 'text-to-video' task on the Hugging Face Hub?" | ||||||
|  | ) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ستحصل على ما يلي: | ||||||
|  |  | ||||||
|  | ```text | ||||||
|  | ======== New task ======== | ||||||
|  | Can you give me the name of the model that has the most downloads in the 'text-to-video' task on the Hugging Face Hub? | ||||||
|  | ==== Agent is executing the code below: | ||||||
|  | most_downloaded_model = model_download_counter(task="text-to-video") | ||||||
|  | print(f"The most downloaded model for the 'text-to-video' task is {most_downloaded_model}.") | ||||||
|  | ==== | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | والناتج: | ||||||
|  |  | ||||||
|  | `"النموذج الأكثر تنزيلًا لمهمة `text-to-video` هو ByteDance/AnimateDiff-Lightning."` | ||||||
|  |  | ||||||
|  | ### إدارة صندوق أدوات الوكيل الخاص بك | ||||||
|  |  | ||||||
|  | إذا كنت قد قمت بتهيئة وكيل، فمن غير الملائم إعادة تهيئته من البداية لإضافة أداة جديدة ترغب في استخدامها. باستخدام مكتبة Transformers، يمكنك إدارة صندوق أدوات الوكيل بإضافة أو استبدال أداة موجودة. | ||||||
|  |  | ||||||
|  | دعنا نضيف الأداة `model_download_tool` إلى وكيل تم تهيئته مسبقًا باستخدام صندوق الأدوات الافتراضي. | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | from transformers import CodeAgent | ||||||
|  |  | ||||||
|  | agent = CodeAgent(tools=[], llm_engine=llm_engine, add_base_tools=True) | ||||||
|  | agent.toolbox.add_tool(model_download_tool) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | الآن يمكننا الاستفادة من الأداة الجديدة وأداة تحويل النص إلى كلام السابقة: | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  |     agent.run( | ||||||
|  |         "Can you read out loud the name of the model that has the most downloads in the 'text-to-video' task on the Hugging Face Hub and return the audio?" | ||||||
|  |     ) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | | **Audio**                                                                                                                                            | | ||||||
|  | |------------------------------------------------------------------------------------------------------------------------------------------------------| | ||||||
|  | | <audio controls><source src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/transformers/damo.wav" type="audio/wav"/> | | ||||||
|  |  | ||||||
|  | > [!WARNING] | ||||||
|  | > احترس عند إضافة أدوات إلى وكيل يعمل بالفعل لأنه يمكن أن يؤثر على اختيار الأداة لصالح أداتك أو اختيار أداة أخرى غير المحددة بالفعل. | ||||||
|  |  | ||||||
|  | استخدم طريقة `agent.toolbox.update_tool()` لاستبدال أداة موجودة في صندوق أدوات الوكيل. | ||||||
|  | هذا مفيد إذا كانت أداتك الجديدة بديلاً مباشرًا للأداة الموجودة لأن الوكيل يعرف بالفعل كيفية تنفيذ تلك المهمة المحددة. | ||||||
|  | تأكد فقط من اتباع الأداة الجديدة لنفس واجهة برمجة التطبيقات (API) للأداة المستبدلة أو قم بتكييف قالب موجه النظام لضمان تحديث جميع الأمثلة التي تستخدم الأداة المستبدلة. | ||||||
|  |  | ||||||
|  | ### استخدام مجموعة من الأدوات | ||||||
|  |  | ||||||
|  | يمكنك الاستفادة من مجموعات الأدوات باستخدام كائن ToolCollection، مع تحديد مجموعة الأدوات التي تريد استخدامها. | ||||||
|  | ثم قم بتمريرها كقائمة لتهيئة الوكيل الخاص بك، وبدء استخدامها! | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | from transformers import ToolCollection, ReactCodeAgent | ||||||
|  |  | ||||||
|  | image_tool_collection = ToolCollection(collection_slug="huggingface-tools/diffusion-tools-6630bb19a942c2306a2cdb6f") | ||||||
|  | agent = ReactCodeAgent(tools=[*image_tool_collection.tools], add_base_tools=True) | ||||||
|  |  | ||||||
|  | agent.run("Please draw me a picture of rivers and lakes.") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | لتسريع البداية، يتم تحميل الأدوات فقط إذا استدعاها الوكيل. | ||||||
|  |  | ||||||
|  | ستحصل على هذه الصورة: | ||||||
|  |  | ||||||
|  | <img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/transformers/rivers_and_lakes.png" /> | ||||||
|  |  | ||||||
|  | ### استخدام gradio-tools | ||||||
|  |  | ||||||
|  | [gradio-tools](https://github.com/freddyaboulton/gradio-tools) هي مكتبة قوية تتيح استخدام Hugging | ||||||
|  | Face Spaces كأدوات. تدعم العديد من المساحات الموجودة بالإضافة إلى مساحات مخصصة. | ||||||
|  |  | ||||||
|  | تدعم مكتبة Transformers `gradio_tools` باستخدام طريقة [`Tool.from_gradio`] في الفئة. على سبيل المثال، دعنا نستخدم [`StableDiffusionPromptGeneratorTool`](https://github.com/freddyaboulton/gradio-tools/blob/main/gradio_tools/tools/prompt_generator.py) من مجموعة أدوات `gradio-tools` لتحسين المطالبات لإنشاء صور أفضل. | ||||||
|  |  | ||||||
|  | استورد وقم بتهيئة الأداة، ثم مررها إلى طريقة `Tool.from_gradio`: | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | from gradio_tools import StableDiffusionPromptGeneratorTool | ||||||
|  | from transformers import Tool, load_tool, CodeAgent | ||||||
|  |  | ||||||
|  | gradio_prompt_generator_tool = StableDiffusionPromptGeneratorTool() | ||||||
|  | prompt_generator_tool = Tool.from_gradio(gradio_prompt_generator_tool) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | الآن يمكنك استخدامه مثل أي أداة أخرى. على سبيل المثال، دعنا نحسن الموجه `a rabbit wearing a space suit`. | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | image_generation_tool = load_tool('huggingface-tools/text-to-image') | ||||||
|  | agent = CodeAgent(tools=[prompt_generator_tool, image_generation_tool], llm_engine=llm_engine) | ||||||
|  |  | ||||||
|  | agent.run( | ||||||
|  |     "Improve this prompt, then generate an image of it.", prompt='A rabbit wearing a space suit' | ||||||
|  | ) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | يستفيد النموذج بشكل كافٍ من الأداة: | ||||||
|  |  | ||||||
|  | ```text | ||||||
|  | ======== New task ======== | ||||||
|  | Improve this prompt, then generate an image of it. | ||||||
|  | You have been provided with these initial arguments: {'prompt': 'A rabbit wearing a space suit'}. | ||||||
|  | ==== Agent is executing the code below: | ||||||
|  | improved_prompt = StableDiffusionPromptGenerator(query=prompt) | ||||||
|  | while improved_prompt == "QUEUE_FULL": | ||||||
|  |     improved_prompt = StableDiffusionPromptGenerator(query=prompt) | ||||||
|  | print(f"The improved prompt is {improved_prompt}.") | ||||||
|  | image = image_generator(prompt=improved_prompt) | ||||||
|  | ==== | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | قبل إنشاء الصورة أخيرًا: | ||||||
|  |  | ||||||
|  | <img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/transformers/rabbit_spacesuit_flux.webp" /> | ||||||
|  |  | ||||||
|  | > [!WARNING] | ||||||
|  | > تتطلب gradio-tools إدخالات وإخراجات *نصية* حتى عند العمل مع طرائق مختلفة مثل كائنات الصور والصوت. الإدخالات والإخراجات الصورية والصوتية غير متوافقة حاليًا. | ||||||
|  |  | ||||||
|  | ### استخدام أدوات LangChain | ||||||
|  |  | ||||||
|  | نحن نحب Langchain ونعتقد أنها تحتوي على مجموعة أدوات قوية للغاية. | ||||||
|  | لاستيراد أداة من LangChain، استخدم الطريقة `from_langchain()`. | ||||||
|  |  | ||||||
|  | فيما يلي كيفية استخدامها لإعادة إنشاء نتيجة البحث في المقدمة باستخدام أداة بحث الويب LangChain. | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | from langchain.agents import load_tools | ||||||
|  | from transformers import Tool, ReactCodeAgent | ||||||
|  |  | ||||||
|  | search_tool = Tool.from_langchain(load_tools(["serpapi"])[0]) | ||||||
|  |  | ||||||
|  | agent = ReactCodeAgent(tools=[search_tool]) | ||||||
|  |  | ||||||
|  | agent.run("How many more blocks (also denoted as layers) in BERT base encoder than the encoder from the architecture proposed in Attention is All You Need?") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## واجهة Gradio | ||||||
|  |  | ||||||
|  | يمكنك الاستفادة من `gradio.Chatbot` لعرض أفكار الوكيل الخاص بك باستخدام `stream_to_gradio`، إليك مثال: | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | import gradio as gr | ||||||
|  | from transformers import ( | ||||||
|  |     load_tool, | ||||||
|  |     ReactCodeAgent, | ||||||
|  |     HfEngine, | ||||||
|  |     stream_to_gradio, | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | # Import tool from Hub | ||||||
|  | image_generation_tool = load_tool("m-ric/text-to-image") | ||||||
|  |  | ||||||
|  | llm_engine = HfEngine("meta-llama/Meta-Llama-3-70B-Instruct") | ||||||
|  |  | ||||||
|  | # Initialize the agent with the image generation tool | ||||||
|  | agent = ReactCodeAgent(tools=[image_generation_tool], llm_engine=llm_engine) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def interact_with_agent(task): | ||||||
|  |     messages = [] | ||||||
|  |     messages.append(gr.ChatMessage(role="user", content=task)) | ||||||
|  |     yield messages | ||||||
|  |     for msg in stream_to_gradio(agent, task): | ||||||
|  |         messages.append(msg) | ||||||
|  |         yield messages + [ | ||||||
|  |             gr.ChatMessage(role="assistant", content="⏳ Task not finished yet!") | ||||||
|  |         ] | ||||||
|  |     yield messages | ||||||
|  |  | ||||||
|  |  | ||||||
|  | with gr.Blocks() as demo: | ||||||
|  |     text_input = gr.Textbox(lines=1, label="Chat Message", value="Make me a picture of the Statue of Liberty.") | ||||||
|  |     submit = gr.Button("Run illustrator agent!") | ||||||
|  |     chatbot = gr.Chatbot( | ||||||
|  |         label="Agent", | ||||||
|  |         type="messages", | ||||||
|  |         avatar_images=( | ||||||
|  |             None, | ||||||
|  |             "https://em-content.zobj.net/source/twitter/53/robot-face_1f916.png", | ||||||
|  |         ), | ||||||
|  |     ) | ||||||
|  |     submit.click(interact_with_agent, [text_input], [chatbot]) | ||||||
|  |  | ||||||
|  | if __name__ == "__main__": | ||||||
|  |     demo.launch() | ||||||
|  | ``` | ||||||
| @ -3,16 +3,16 @@ | |||||||
| يُشهد في الآونة الأخيرة نمو مجال دراسي يُعنى باستكشاف آلية عمل نماذج المحولات الضخمة مثل BERT (والذي يُطلق عليها البعض اسم "BERTology"). ومن الأمثلة البارزة على هذا المجال ما يلي: | يُشهد في الآونة الأخيرة نمو مجال دراسي يُعنى باستكشاف آلية عمل نماذج المحولات الضخمة مثل BERT (والذي يُطلق عليها البعض اسم "BERTology"). ومن الأمثلة البارزة على هذا المجال ما يلي: | ||||||
|  |  | ||||||
| - BERT Rediscovers the Classical NLP Pipeline بواسطة Ian Tenney و Dipanjan Das و Ellie Pavlick: | - BERT Rediscovers the Classical NLP Pipeline بواسطة Ian Tenney و Dipanjan Das و Ellie Pavlick: | ||||||
|   https://huggingface.co/papers/1905.05950 |   https://arxiv.org/abs/1905.05950 | ||||||
| - Are Sixteen Heads Really Better than One? بواسطة Paul Michel و Omer Levy و Graham Neubig: https://huggingface.co/papers/1905.10650 | - Are Sixteen Heads Really Better than One? بواسطة Paul Michel و Omer Levy و Graham Neubig: https://arxiv.org/abs/1905.10650 | ||||||
| - What Does BERT Look At? An Analysis of BERT's Attention بواسطة Kevin Clark و Urvashi Khandelwal و Omer Levy و Christopher D. | - What Does BERT Look At? An Analysis of BERT's Attention بواسطة Kevin Clark و Urvashi Khandelwal و Omer Levy و Christopher D. | ||||||
|   Manning: https://huggingface.co/papers/1906.04341 |   Manning: https://arxiv.org/abs/1906.04341 | ||||||
| - CAT-probing: A Metric-based Approach to Interpret How Pre-trained Models for Programming Language Attend Code Structure: https://huggingface.co/papers/2210.04633 | - CAT-probing: A Metric-based Approach to Interpret How Pre-trained Models for Programming Language Attend Code Structure: https://arxiv.org/abs/2210.04633 | ||||||
|  |  | ||||||
| لإثراء هذا المجال الناشئ، قمنا بتضمين بعض الميزات الإضافية في نماذج BERT/GPT/GPT-2 للسماح للناس بالوصول إلى التمثيلات الداخلية، والتي تم تكييفها بشكل أساسي من العمل الرائد لـ Paul Michel (https://huggingface.co/papers/1905.10650): | لإثراء هذا المجال الناشئ، قمنا بتضمين بعض الميزات الإضافية في نماذج BERT/GPT/GPT-2 للسماح للناس بالوصول إلى التمثيلات الداخلية، والتي تم تكييفها بشكل أساسي من العمل الرائد لـ Paul Michel (https://arxiv.org/abs/1905.10650): | ||||||
|  |  | ||||||
| - الوصول إلى جميع الحالات المخفية في BERT/GPT/GPT-2، | - الوصول إلى جميع الحالات المخفية في BERT/GPT/GPT-2، | ||||||
| - الوصول إلى جميع أوزان الانتباه لكل رأس في BERT/GPT/GPT-2، | - الوصول إلى جميع أوزان الانتباه لكل رأس في BERT/GPT/GPT-2، | ||||||
| - استرجاع قيم ومشتقات  مخرجات الرأس لحساب درجة أهمية الرأس وحذفه كما هو موضح في https://huggingface.co/papers/1905.10650. | - استرجاع قيم ومشتقات  مخرجات الرأس لحساب درجة أهمية الرأس وحذفه كما هو موضح في https://arxiv.org/abs/1905.10650. | ||||||
|  |  | ||||||
| ولمساعدتك على فهم واستخدام هذه الميزات بسهولة، أضفنا مثالًا برمجيًا محددًا: [bertology.py](https://github.com/huggingface/transformers-research-projects/tree/main/bertology/run_bertology.py) أثناء استخراج المعلومات  وتقليص من نموذج تم تدريبه مسبقًا على GLUE. | ولمساعدتك على فهم واستخدام هذه الميزات بسهولة، أضفنا مثالًا برمجيًا محددًا: [bertology.py](https://github.com/huggingface/transformers/tree/main/examples/research_projects/bertology/run_bertology.py) أثناء استخراج المعلومات  وتقليص من نموذج تم تدريبه مسبقًا على GLUE. | ||||||
| @ -30,7 +30,7 @@ class ResnetConfig(PretrainedConfig): | |||||||
|     def __init__( |     def __init__( | ||||||
|         self, |         self, | ||||||
|         block_type="bottleneck", |         block_type="bottleneck", | ||||||
|         layers: list[int] = [3, 4, 6, 3], |         layers: List[int] = [3, 4, 6, 3], | ||||||
|         num_classes: int = 1000, |         num_classes: int = 1000, | ||||||
|         input_channels: int = 3, |         input_channels: int = 3, | ||||||
|         cardinality: int = 1, |         cardinality: int = 1, | ||||||
|  | |||||||
| @ -77,7 +77,7 @@ model = AutoModelForCausalLM.from_pretrained(model_id, gguf_file=filename) | |||||||
|  |  | ||||||
| الآن لديك إمكانية الوصول إلى النسخة الكامل غير المكممة للنموذج في بيئة PyTorch، حيث يمكنك دمجه مع مجموعة كبيرة من الأدوات الأخرى. | الآن لديك إمكانية الوصول إلى النسخة الكامل غير المكممة للنموذج في بيئة PyTorch، حيث يمكنك دمجه مع مجموعة كبيرة من الأدوات الأخرى. | ||||||
|  |  | ||||||
| لإعادة التحويل إلى ملف `gguf`، نوصي باستخدام ملف [`convert-hf-to-gguf.py`](https://github.com/ggerganov/llama.cpp/blob/master/convert_hf_to_gguf.py) من llama.cpp. | لإعادة التحويل إلى ملف `gguf`، نوصي باستخدام ملف [`convert-hf-to-gguf.py`](https://github.com/ggerganov/llama.cpp/blob/master/convert-hf-to-gguf.py) من llama.cpp. | ||||||
|  |  | ||||||
| فيما يلي كيفية إكمال البرنامج النصي أعلاه لحفظ النموذج وإعادة تصديره مرة أخرى إلى `gguf`: | فيما يلي كيفية إكمال البرنامج النصي أعلاه لحفظ النموذج وإعادة تصديره مرة أخرى إلى `gguf`: | ||||||
|  |  | ||||||
|  | |||||||
| @ -135,7 +135,7 @@ | |||||||
| في كل وحدة الانتباه الباقية في المحولات، تلي طبقة الاهتمام الانتباه عادة طبقتان للتغذية الأمامية. | في كل وحدة الانتباه الباقية في المحولات، تلي طبقة الاهتمام الانتباه عادة طبقتان للتغذية الأمامية. | ||||||
| حجم تضمين الطبقة الأمامية الوسيطة أكبر عادة من حجم المخفي للنموذج (على سبيل المثال، لـ | حجم تضمين الطبقة الأمامية الوسيطة أكبر عادة من حجم المخفي للنموذج (على سبيل المثال، لـ | ||||||
| `google-bert/bert-base-uncased`). | `google-bert/bert-base-uncased`). | ||||||
| بالنسبة لإدخال بحجم `[batch_size, sequence_length]`، يمكن أن تمثل الذاكرة المطلوبة لتخزين التضمينات الأمامية الوسيطة `[batch_size، sequence_length, config.intermediate_size]` جزءًا كبيرًا من استخدام الذاكرة. لاحظ مؤلفو (https://huggingface.co/papers/2001.04451)[Reformer: The Efficient Transformer] أنه نظرًا لأن الحساب مستقل عن بعد `sequence_length`، فإنه من المكافئ رياضيًا حساب تضمينات الإخراج الأمامية `[batch_size، config.hidden_size]_0, ..., [batch_size، `config_size]_n | بالنسبة لإدخال بحجم `[batch_size, sequence_length]`، يمكن أن تمثل الذاكرة المطلوبة لتخزين التضمينات الأمامية الوسيطة `[batch_size، sequence_length, config.intermediate_size]` جزءًا كبيرًا من استخدام الذاكرة. لاحظ مؤلفو (https://arxiv.org/abs/2001.04451)[Reformer: The Efficient Transformer] أنه نظرًا لأن الحساب مستقل عن بعد `sequence_length`، فإنه من المكافئ رياضيًا حساب تضمينات الإخراج الأمامية `[batch_size، config.hidden_size]_0, ..., [batch_size، `config_size]_n | ||||||
| فردياً والتوصيل بها لاحقًا إلى `[batch_size, sequence_length, config.hidden_size]` مع `n = sequence_length`، والذي يتداول زيادة وقت الحساب مقابل تقليل استخدام الذاكرة، ولكنه ينتج عنه نتيجة مكافئة رياضيا. | فردياً والتوصيل بها لاحقًا إلى `[batch_size, sequence_length, config.hidden_size]` مع `n = sequence_length`، والذي يتداول زيادة وقت الحساب مقابل تقليل استخدام الذاكرة، ولكنه ينتج عنه نتيجة مكافئة رياضيا. | ||||||
|  |  | ||||||
| بالنسبة للنماذج التي تستخدم الدالة `[apply_chunking_to_forward]`، يحدد `chunk_size` عدد التضمينات يتم حساب الإخراج بالتوازي وبالتالي يحدد المقايضة بين حجم الذاكرة والتعقيد الوقت. إذا تم تعيين `chunk_size` إلى `0`، فلن يتم إجراء تجزئة التغذية الأمامية. | بالنسبة للنماذج التي تستخدم الدالة `[apply_chunking_to_forward]`، يحدد `chunk_size` عدد التضمينات يتم حساب الإخراج بالتوازي وبالتالي يحدد المقايضة بين حجم الذاكرة والتعقيد الوقت. إذا تم تعيين `chunk_size` إلى `0`، فلن يتم إجراء تجزئة التغذية الأمامية. | ||||||
| @ -173,7 +173,7 @@ | |||||||
|  |  | ||||||
| <Youtube id="VFp38yj8h3A"/> | <Youtube id="VFp38yj8h3A"/> | ||||||
|  |  | ||||||
| يعمل كل محلل لغوي بشكل مختلف ولكن الآلية الأساسية تبقى كما هي. إليك مثال باستخدام محلل BERT اللغوي، والذي يعد محلل لغوي [WordPiece](https://huggingface.co/papers/1609.08144): | يعمل كل محلل لغوي بشكل مختلف ولكن الآلية الأساسية تبقى كما هي. إليك مثال باستخدام محلل BERT اللغوي، والذي يعد محلل لغوي [WordPiece](https://arxiv.org/pdf/1609.08144.pdf): | ||||||
|  |  | ||||||
| ```python | ```python | ||||||
| >>> from transformers import BertTokenizer | >>> from transformers import BertTokenizer | ||||||
|  | |||||||
| @ -6,7 +6,7 @@ | |||||||
| تحقق نماذج اللغة الكبيرة (LLMs) مثل GPT3/4، [Falcon](https://huggingface.co/tiiuae/falcon-40b)، و [Llama](https://huggingface.co/meta-llama/Llama-2-70b-hf) تقدمًا سريعًا في قدرتها على معالجة المهام التي تركز على الإنسان، مما يجعلها أدوات أساسية في الصناعات القائمة على المعرفة الحديثة. | تحقق نماذج اللغة الكبيرة (LLMs) مثل GPT3/4، [Falcon](https://huggingface.co/tiiuae/falcon-40b)، و [Llama](https://huggingface.co/meta-llama/Llama-2-70b-hf) تقدمًا سريعًا في قدرتها على معالجة المهام التي تركز على الإنسان، مما يجعلها أدوات أساسية في الصناعات القائمة على المعرفة الحديثة. | ||||||
| لا يزال نشر هذه النماذج في المهام الواقعية يمثل تحديًا، ومع ذلك: | لا يزال نشر هذه النماذج في المهام الواقعية يمثل تحديًا، ومع ذلك: | ||||||
|  |  | ||||||
| -   لكي تظهر نماذج اللغة الكبيرة قدرات فهم وتوليد النصوص قريبة من قدرات الإنسان، فإنها تتطلب حاليًا  إلى تكوينها من مليارات المعلمات (انظر [كابلان وآخرون](https://huggingface.co/papers/2001.08361)، [وي وآخرون](https://huggingface.co/papers/2206.07682)). وهذا بدوره يزيد من متطلبات الذاكرة للاستدلال. | -   لكي تظهر نماذج اللغة الكبيرة قدرات فهم وتوليد النصوص قريبة من قدرات الإنسان، فإنها تتطلب حاليًا  إلى تكوينها من مليارات المعلمات (انظر [كابلان وآخرون](https://arxiv.org/abs/2001.08361)، [وي وآخرون](https://arxiv.org/abs/2206.07682)). وهذا بدوره يزيد من متطلبات الذاكرة للاستدلال. | ||||||
| -   في العديد من المهام الواقعية، تحتاج نماذج اللغة الكبيرة إلى معلومات سياقية شاملة. يتطلب ذلك قدرة النموذج على إدارة تسلسلات إدخال طويلة للغاية أثناء الاستدلال. | -   في العديد من المهام الواقعية، تحتاج نماذج اللغة الكبيرة إلى معلومات سياقية شاملة. يتطلب ذلك قدرة النموذج على إدارة تسلسلات إدخال طويلة للغاية أثناء الاستدلال. | ||||||
|  |  | ||||||
| يكمن جوهر صعوبة هذه التحديات في تعزيز القدرات الحسابية والذاكرة لنماذج اللغة الكبيرة، خاصة عند التعامل مع تسلسلات الإدخال الضخمة. | يكمن جوهر صعوبة هذه التحديات في تعزيز القدرات الحسابية والذاكرة لنماذج اللغة الكبيرة، خاصة عند التعامل مع تسلسلات الإدخال الضخمة. | ||||||
| @ -17,7 +17,7 @@ | |||||||
|  |  | ||||||
| 2.  **اFlash Attention:** إن Flash Attention وهي نسخة مُعدَّلة من خوارزمية الانتباه التي لا توفر فقط نهجًا أكثر كفاءة في استخدام الذاكرة، ولكنها تحقق أيضًا كفاءة متزايدة بسبب الاستخدام الأمثل لذاكرة GPU. | 2.  **اFlash Attention:** إن Flash Attention وهي نسخة مُعدَّلة من خوارزمية الانتباه التي لا توفر فقط نهجًا أكثر كفاءة في استخدام الذاكرة، ولكنها تحقق أيضًا كفاءة متزايدة بسبب الاستخدام الأمثل لذاكرة GPU. | ||||||
|  |  | ||||||
| 3.  **الابتكارات المعمارية:** حيث تم اقتراح هياكل متخصصة تسمح باستدلال أكثر فعالية نظرًا لأن نماذج اللغة الكبيرة يتم نشرها دائمًا بنفس الطريقة أثناء عملية الاستدلال، أي توليد النص التنبؤي التلقائي مع سياق الإدخال الطويل، فقد تم اقتراح بنيات نموذج متخصصة تسمح بالاستدلال الأكثر كفاءة. أهم تقدم في بنيات النماذج هنا هو [عذر](https://huggingface.co/papers/2108.12409)، [الترميز الدوار](https://huggingface.co/papers/2104.09864)، [الاهتمام متعدد الاستعلامات (MQA)](https://huggingface.co/papers/1911.02150) و [مجموعة الانتباه بالاستعلام (GQA)]((https://huggingface.co/papers/2305.13245)). | 3.  **الابتكارات المعمارية:** حيث تم اقتراح هياكل متخصصة تسمح باستدلال أكثر فعالية نظرًا لأن نماذج اللغة الكبيرة يتم نشرها دائمًا بنفس الطريقة أثناء عملية الاستدلال، أي توليد النص التنبؤي التلقائي مع سياق الإدخال الطويل، فقد تم اقتراح بنيات نموذج متخصصة تسمح بالاستدلال الأكثر كفاءة. أهم تقدم في بنيات النماذج هنا هو [عذر](https://arxiv.org/abs/2108.12409)، [الترميز الدوار](https://arxiv.org/abs/2104.09864)، [الاهتمام متعدد الاستعلامات (MQA)](https://arxiv.org/abs/1911.02150) و [مجموعة الانتباه بالاستعلام (GQA)]((https://arxiv.org/abs/2305.13245)). | ||||||
|  |  | ||||||
| على مدار هذا الدليل، سنقدم تحليلًا للتوليد التنبؤي التلقائي من منظور المُوتِّرات. نتعمق في مزايا وعيوب استخدام دقة أقل، ونقدم استكشافًا شاملاً لخوارزميات الانتباه الأحدث، ونناقش بنيات نماذج نماذج اللغة الكبيرة المحسنة. سندعم الشرح بأمثلة عملية تُبرِز كل تحسين على حدة. | على مدار هذا الدليل، سنقدم تحليلًا للتوليد التنبؤي التلقائي من منظور المُوتِّرات. نتعمق في مزايا وعيوب استخدام دقة أقل، ونقدم استكشافًا شاملاً لخوارزميات الانتباه الأحدث، ونناقش بنيات نماذج نماذج اللغة الكبيرة المحسنة. سندعم الشرح بأمثلة عملية تُبرِز كل تحسين على حدة. | ||||||
|  |  | ||||||
| @ -152,8 +152,8 @@ from accelerate.utils import release_memory | |||||||
| release_memory(model) | release_memory(model) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| والآن ماذا لو لم يكن لدى وحدة معالجة الرسومات (GPU) لديك 32 جيجا بايت من ذاكرة الفيديو العشوائية (VRAM)؟ لقد وجد أن أوزان النماذج يمكن تحويلها إلى 8 بتات أو 4 بتات دون خسارة كبيرة في الأداء (انظر [Dettmers et al.](https://huggingface.co/papers/2208.07339)). | والآن ماذا لو لم يكن لدى وحدة معالجة الرسومات (GPU) لديك 32 جيجا بايت من ذاكرة الفيديو العشوائية (VRAM)؟ لقد وجد أن أوزان النماذج يمكن تحويلها إلى 8 بتات أو 4 بتات دون خسارة كبيرة في الأداء (انظر [Dettmers et al.](https://arxiv.org/abs/2208.07339)). | ||||||
| يمكن تحويل النموذج إلى 3 بتات أو 2 بتات مع فقدان مقبول في الأداء كما هو موضح في ورقة [GPTQ](https://huggingface.co/papers/2210.17323) 🤯. | يمكن تحويل النموذج إلى 3 بتات أو 2 بتات مع فقدان مقبول في الأداء كما هو موضح في ورقة [GPTQ](https://arxiv.org/abs/2210.17323) 🤯. | ||||||
|  |  | ||||||
| دون الدخول في الكثير من التفاصيل، تهدف مخططات التكميم إلى تخفيض دقة الأوزان مع محاولة الحفاظ على دقة نتائج النموذج كما هي (*أي* أقرب ما يمكن إلى bfloat16). | دون الدخول في الكثير من التفاصيل، تهدف مخططات التكميم إلى تخفيض دقة الأوزان مع محاولة الحفاظ على دقة نتائج النموذج كما هي (*أي* أقرب ما يمكن إلى bfloat16). | ||||||
| لاحظ أن التكميم يعمل بشكل خاص جيدًا لتوليد النص حيث كل ما نهتم به هو اختيار *مجموعة الرموز الأكثر احتمالًا التالية* ولا نهتم حقًا بالقيم الدقيقة لتوزيع الرمز التالي *logit*. | لاحظ أن التكميم يعمل بشكل خاص جيدًا لتوليد النص حيث كل ما نهتم به هو اختيار *مجموعة الرموز الأكثر احتمالًا التالية* ولا نهتم حقًا بالقيم الدقيقة لتوزيع الرمز التالي *logit*. | ||||||
| @ -231,7 +231,7 @@ flush() | |||||||
| دعنا نرى ما هو استهلاك ذاكرة GPU الذروة الذي يوفره تكميم 4 بت. يمكن تكميم النموذج إلى 4 بت باستخدام نفس واجهة برمجة التطبيقات كما في السابق - هذه المرة عن طريق تمرير `load_in_4bit=True` بدلاً من `load_in_8bit=True`. | دعنا نرى ما هو استهلاك ذاكرة GPU الذروة الذي يوفره تكميم 4 بت. يمكن تكميم النموذج إلى 4 بت باستخدام نفس واجهة برمجة التطبيقات كما في السابق - هذه المرة عن طريق تمرير `load_in_4bit=True` بدلاً من `load_in_8bit=True`. | ||||||
|  |  | ||||||
| ```python | ```python | ||||||
| model = AutoModelForCausalLM.from_pretrained("bigcode/octocoder", load_in_4bit=True, pad_token_id=0) | model = AutoModelForCausalLM.from_pretrained("bigcode/octocoder", load_in_4bit=True, low_cpu_mem_usage=True, pad_token_id=0) | ||||||
|  |  | ||||||
| pipe = pipeline("text-generation", model=model, tokenizer=tokenizer) | pipe = pipeline("text-generation", model=model, tokenizer=tokenizer) | ||||||
|  |  | ||||||
| @ -304,7 +304,7 @@ $$ \textbf{O} = \text{Attn}(\mathbf{X}) = \mathbf{V} \times \text{Softmax}(\math | |||||||
|  |  | ||||||
| مع تحسن LLMs في فهم النص وتوليد النص، يتم تطبيقها على مهام متزايدة التعقيد. في حين أن النماذج كانت تتعامل سابقًا مع ترجمة أو تلخيص بضع جمل، فإنها الآن تدير صفحات كاملة، مما يتطلب القدرة على معالجة أطوال إدخال واسعة. | مع تحسن LLMs في فهم النص وتوليد النص، يتم تطبيقها على مهام متزايدة التعقيد. في حين أن النماذج كانت تتعامل سابقًا مع ترجمة أو تلخيص بضع جمل، فإنها الآن تدير صفحات كاملة، مما يتطلب القدرة على معالجة أطوال إدخال واسعة. | ||||||
|  |  | ||||||
| كيف يمكننا التخلص من متطلبات الذاكرة الباهظة للتطويلات المدخلة الكبيرة؟ نحن بحاجة إلى طريقة جديدة لحساب آلية الاهتمام الذاتي التي تتخلص من مصفوفة \\( QK^T \\). [طريقه داو وآخرون.](https://huggingface.co/papers/2205.14135) طوروا بالضبط مثل هذا الخوارزمية الجديدة وأطلقوا عليها اسم **Flash Attention**. | كيف يمكننا التخلص من متطلبات الذاكرة الباهظة للتطويلات المدخلة الكبيرة؟ نحن بحاجة إلى طريقة جديدة لحساب آلية الاهتمام الذاتي التي تتخلص من مصفوفة \\( QK^T \\). [طريقه داو وآخرون.](Https://arxiv.org/abs/2205.14135) طوروا بالضبط مثل هذا الخوارزمية الجديدة وأطلقوا عليها اسم **Flash Attention**. | ||||||
|  |  | ||||||
| باختصار، يكسر الاهتمام الفلاشي حساب \\( \mathbf{V} \times \operatorname{Softmax}(\mathbf{QK}^T\\)) ويحسب بدلاً من ذلك قطعًا أصغر من الإخراج عن طريق التكرار عبر العديد من خطوات حساب Softmax: | باختصار، يكسر الاهتمام الفلاشي حساب \\( \mathbf{V} \times \operatorname{Softmax}(\mathbf{QK}^T\\)) ويحسب بدلاً من ذلك قطعًا أصغر من الإخراج عن طريق التكرار عبر العديد من خطوات حساب Softmax: | ||||||
|  |  | ||||||
| @ -318,7 +318,7 @@ $$ \textbf{O}_i \leftarrow s^a_{ij} * \textbf{O}_i + s^b_{ij} * \mathbf{V}_{j} \ | |||||||
|  |  | ||||||
| > من خلال تتبع إحصائيات التطبيع softmax واستخدام بعض الرياضيات الذكية، يعطي Flash Attention **مخرجات متطابقة رقميًا** مقارنة بطبقة الاهتمام الذاتي الافتراضية بتكلفة ذاكرة لا تزيد خطيًا مع \\( N \\). | > من خلال تتبع إحصائيات التطبيع softmax واستخدام بعض الرياضيات الذكية، يعطي Flash Attention **مخرجات متطابقة رقميًا** مقارنة بطبقة الاهتمام الذاتي الافتراضية بتكلفة ذاكرة لا تزيد خطيًا مع \\( N \\). | ||||||
|  |  | ||||||
| عند النظر إلى الصيغة، قد يقول المرء بديهيًا أن الاهتمام الفلاشي يجب أن يكون أبطأ بكثير مقارنة بصيغة الاهتمام الافتراضية حيث يلزم إجراء المزيد من الحسابات. في الواقع، يتطلب Flash Attention المزيد من عمليات الفاصلة العائمة مقارنة بالاهتمام العادي حيث يجب إعادة حساب إحصائيات التطبيع softmax باستمرار (راجع [الورقة](https://huggingface.co/papers/2205.14135) لمزيد من التفاصيل إذا كنت مهتمًا) | عند النظر إلى الصيغة، قد يقول المرء بديهيًا أن الاهتمام الفلاشي يجب أن يكون أبطأ بكثير مقارنة بصيغة الاهتمام الافتراضية حيث يلزم إجراء المزيد من الحسابات. في الواقع، يتطلب Flash Attention المزيد من عمليات الفاصلة العائمة مقارنة بالاهتمام العادي حيث يجب إعادة حساب إحصائيات التطبيع softmax باستمرار (راجع [الورقة](https://arxiv.org/abs/2205.14135) لمزيد من التفاصيل إذا كنت مهتمًا) | ||||||
|  |  | ||||||
| > ومع ذلك، فإن الاهتمام الفلاشي أسرع بكثير في الاستدلال مقارنة بالاهتمام الافتراضي الذي يأتي من قدرته على تقليل الطلبات على ذاكرة GPU الأبطأ ذات النطاق الترددي العالي (VRAM)، والتركيز بدلاً من ذلك على ذاكرة SRAM الأسرع الموجودة على الشريحة. | > ومع ذلك، فإن الاهتمام الفلاشي أسرع بكثير في الاستدلال مقارنة بالاهتمام الافتراضي الذي يأتي من قدرته على تقليل الطلبات على ذاكرة GPU الأبطأ ذات النطاق الترددي العالي (VRAM)، والتركيز بدلاً من ذلك على ذاكرة SRAM الأسرع الموجودة على الشريحة. | ||||||
|  |  | ||||||
| @ -535,20 +535,20 @@ flush() | |||||||
| لكي يفهم LLM ترتيب الجملة، يلزم وجود *إشارة* إضافية ويتم تطبيقها عادةً في شكل *الترميزات الموضعية* (أو ما يُطلق عليه أيضًا *الترميزات الموضعية*). | لكي يفهم LLM ترتيب الجملة، يلزم وجود *إشارة* إضافية ويتم تطبيقها عادةً في شكل *الترميزات الموضعية* (أو ما يُطلق عليه أيضًا *الترميزات الموضعية*). | ||||||
| لم يتم ترجمة النص الخاص والروابط وأكواد HTML وCSS بناءً على طلبك. | لم يتم ترجمة النص الخاص والروابط وأكواد HTML وCSS بناءً على طلبك. | ||||||
|  |  | ||||||
| قدم مؤلفو الورقة البحثية [*Attention Is All You Need*](https://huggingface.co/papers/1706.03762) تضمينات موضعية جيبية مثلثية \\( \mathbf{P} = \mathbf{p}_1, \ldots, \mathbf{p}_N \\) حيث يتم حساب كل متجه \\( \mathbf{p}_i \\) كدالة جيبية لموضعه \\( i \\) . | قدم مؤلفو الورقة البحثية [*Attention Is All You Need*](https://arxiv.org/abs/1706.03762) تضمينات موضعية جيبية مثلثية \\( \mathbf{P} = \mathbf{p}_1, \ldots, \mathbf{p}_N \\) حيث يتم حساب كل متجه \\( \mathbf{p}_i \\) كدالة جيبية لموضعه \\( i \\) . | ||||||
| بعد ذلك يتم ببساطة إضافة التضمينات الموضعية إلى متجهات تسلسل الإدخال \\( \mathbf{\hat{X}} = \mathbf{\hat{x}}_1, \ldots, \mathbf{\hat{x}}_N \\) = \\( \mathbf{x}_1 + \mathbf{p}_1, \ldots, \mathbf{x}_N + \mathbf{p}_N \\) وبالتالي توجيه النموذج لتعلم ترتيب الجملة بشكل أفضل. | بعد ذلك يتم ببساطة إضافة التضمينات الموضعية إلى متجهات تسلسل الإدخال \\( \mathbf{\hat{X}} = \mathbf{\hat{x}}_1, \ldots, \mathbf{\hat{x}}_N \\) = \\( \mathbf{x}_1 + \mathbf{p}_1, \ldots, \mathbf{x}_N + \mathbf{p}_N \\) وبالتالي توجيه النموذج لتعلم ترتيب الجملة بشكل أفضل. | ||||||
|  |  | ||||||
| بدلاً من استخدام التضمينات الموضعية الثابتة، استخدم آخرون (مثل [Devlin et al.](https://huggingface.co/papers/1810.04805)) تضمينات موضعية مكتسبة يتم من خلالها تعلم التضمينات الموضعية \\( \mathbf{P} \\) أثناء التدريب. | بدلاً من استخدام التضمينات الموضعية الثابتة، استخدم آخرون (مثل [Devlin et al.](https://arxiv.org/abs/1810.04805)) تضمينات موضعية مكتسبة يتم من خلالها تعلم التضمينات الموضعية \\( \mathbf{P} \\) أثناء التدريب. | ||||||
|  |  | ||||||
| كانت التضمينات الموضعية الجيبية والمكتسبة هي الطرق السائدة لترميز ترتيب الجملة في نماذج اللغة الكبيرة، ولكن تم العثور على بعض المشكلات المتعلقة بهذه التضمينات الموضعية: | كانت التضمينات الموضعية الجيبية والمكتسبة هي الطرق السائدة لترميز ترتيب الجملة في نماذج اللغة الكبيرة، ولكن تم العثور على بعض المشكلات المتعلقة بهذه التضمينات الموضعية: | ||||||
|  |  | ||||||
| 1. التضمينات الموضعية الجيبية والمكتسبة هي تضمينات موضعية مطلقة، أي ترميز تضمين فريد لكل معرف موضعي: \\( 0, \ldots, N \\) . كما أظهر [Huang et al.](https://huggingface.co/papers/2009.13658) و [Su et al.](https://huggingface.co/papers/2104.09864)، تؤدي التضمينات الموضعية المطلقة إلى أداء ضعيف لنماذج اللغة الكبيرة للمدخلات النصية الطويلة. بالنسبة للمدخلات النصية الطويلة، يكون من المفيد إذا تعلم النموذج المسافة الموضعية النسبية التي تمتلكها رموز المدخلات إلى بعضها البعض بدلاً من موضعها المطلق. | 1. التضمينات الموضعية الجيبية والمكتسبة هي تضمينات موضعية مطلقة، أي ترميز تضمين فريد لكل معرف موضعي: \\( 0, \ldots, N \\) . كما أظهر [Huang et al.](https://arxiv.org/abs/2009.13658) و [Su et al.](https://arxiv.org/abs/2104.09864)، تؤدي التضمينات الموضعية المطلقة إلى أداء ضعيف لنماذج اللغة الكبيرة للمدخلات النصية الطويلة. بالنسبة للمدخلات النصية الطويلة، يكون من المفيد إذا تعلم النموذج المسافة الموضعية النسبية التي تمتلكها رموز المدخلات إلى بعضها البعض بدلاً من موضعها المطلق. | ||||||
| 2. عند استخدام التضمينات الموضعية المكتسبة، يجب تدريب نموذج اللغة الكبيرة على طول إدخال ثابت \\( N \\)، مما يجعل من الصعب الاستقراء إلى طول إدخال أطول مما تم تدريبه عليه. | 2. عند استخدام التضمينات الموضعية المكتسبة، يجب تدريب نموذج اللغة الكبيرة على طول إدخال ثابت \\( N \\)، مما يجعل من الصعب الاستقراء إلى طول إدخال أطول مما تم تدريبه عليه. | ||||||
|  |  | ||||||
| في الآونة الأخيرة، أصبحت التضمينات الموضعية النسبية التي يمكنها معالجة المشكلات المذكورة أعلاه أكثر شعبية، وأبرزها: | في الآونة الأخيرة، أصبحت التضمينات الموضعية النسبية التي يمكنها معالجة المشكلات المذكورة أعلاه أكثر شعبية، وأبرزها: | ||||||
|  |  | ||||||
| -   [تضمين الموضع الدوراني (RoPE)](https://huggingface.co/papers/2104.09864) | -   [تضمين الموضع الدوراني (RoPE)](https://arxiv.org/abs/2104.09864) | ||||||
| -   [ALiBi](https://huggingface.co/papers/2108.12409) | -   [ALiBi](https://arxiv.org/abs/2108.12409) | ||||||
|  |  | ||||||
| يؤكد كل من *RoPE* و *ALiBi* أنه من الأفضل توجيه نموذج اللغة الكبيرة حول ترتيب الجملة مباشرة في خوارزمية الانتباه الذاتي حيث يتم وضع رموز الكلمات في علاقة مع بعضها البعض. على وجه التحديد، يجب توجيه ترتيب الجملة عن طريق تعديل عملية \\( \mathbf{QK}^T \\) . | يؤكد كل من *RoPE* و *ALiBi* أنه من الأفضل توجيه نموذج اللغة الكبيرة حول ترتيب الجملة مباشرة في خوارزمية الانتباه الذاتي حيث يتم وضع رموز الكلمات في علاقة مع بعضها البعض. على وجه التحديد، يجب توجيه ترتيب الجملة عن طريق تعديل عملية \\( \mathbf{QK}^T \\) . | ||||||
|  |  | ||||||
| @ -563,14 +563,14 @@ $$ \mathbf{\hat{q}}_i^T \mathbf{\hat{x}}_j = \mathbf{{q}}_i^T \mathbf{R}_{\theta | |||||||
| يستخدم *RoPE* في العديد من نماذج اللغة الكبيرة الأكثر أهمية اليوم، مثل: | يستخدم *RoPE* في العديد من نماذج اللغة الكبيرة الأكثر أهمية اليوم، مثل: | ||||||
|  |  | ||||||
| -   [**Falcon**](https://huggingface.co/tiiuae/falcon-40b) | -   [**Falcon**](https://huggingface.co/tiiuae/falcon-40b) | ||||||
| -   [**Llama**](https://huggingface.co/papers/2302.13971) | -   [**Llama**](https://arxiv.org/abs/2302.13971) | ||||||
| -   [**PaLM**](https://huggingface.co/papers/2204.02311) | -   [**PaLM**](https://arxiv.org/abs/2204.02311) | ||||||
|  |  | ||||||
| كبديل، يقترح *ALiBi* مخطط ترميز موضعي نسبي أبسط بكثير. يتم إضافة المسافة النسبية التي تمتلكها رموز المدخلات إلى بعضها البعض كعدد صحيح سلبي مقياس بقيمة محددة مسبقًا `m` إلى كل إدخال استعلام-مفتاح لمصفوفة \\( \mathbf{QK}^T \\) مباشرة قبل حساب softmax. | كبديل، يقترح *ALiBi* مخطط ترميز موضعي نسبي أبسط بكثير. يتم إضافة المسافة النسبية التي تمتلكها رموز المدخلات إلى بعضها البعض كعدد صحيح سلبي مقياس بقيمة محددة مسبقًا `m` إلى كل إدخال استعلام-مفتاح لمصفوفة \\( \mathbf{QK}^T \\) مباشرة قبل حساب softmax. | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| كما هو موضح في ورقة [ALiBi](https://huggingface.co/papers/2108.12409)، يسمح هذا الترميز الموضعي النسبي البسيط للنموذج بالحفاظ على أداء عالٍ حتى في تسلسلات المدخلات النصية الطويلة جدًا. | كما هو موضح في ورقة [ALiBi](https://arxiv.org/abs/2108.12409)، يسمح هذا الترميز الموضعي النسبي البسيط للنموذج بالحفاظ على أداء عالٍ حتى في تسلسلات المدخلات النصية الطويلة جدًا. | ||||||
|  |  | ||||||
| يُستخدم *ALiBi* في العديد من أهم نماذج اللغة الكبيرة المستخدمة اليوم، مثل: | يُستخدم *ALiBi* في العديد من أهم نماذج اللغة الكبيرة المستخدمة اليوم، مثل: | ||||||
|  |  | ||||||
| @ -579,7 +579,7 @@ $$ \mathbf{\hat{q}}_i^T \mathbf{\hat{x}}_j = \mathbf{{q}}_i^T \mathbf{R}_{\theta | |||||||
|  |  | ||||||
| يمكن لكل من ترميزات الموضع *RoPE* و *ALiBi* الاستقراء إلى أطوال إدخال لم يتم ملاحظتها أثناء التدريب، في حين ثبت أن الاستقراء يعمل بشكل أفضل بكثير خارج الصندوق لـ *ALiBi* مقارنة بـ *RoPE*. | يمكن لكل من ترميزات الموضع *RoPE* و *ALiBi* الاستقراء إلى أطوال إدخال لم يتم ملاحظتها أثناء التدريب، في حين ثبت أن الاستقراء يعمل بشكل أفضل بكثير خارج الصندوق لـ *ALiBi* مقارنة بـ *RoPE*. | ||||||
| بالنسبة لـ ALiBi، ما عليك سوى زيادة قيم مصفوفة الموضع المثلث السفلي لمطابقة طول تسلسل الإدخال. | بالنسبة لـ ALiBi، ما عليك سوى زيادة قيم مصفوفة الموضع المثلث السفلي لمطابقة طول تسلسل الإدخال. | ||||||
| بالنسبة لـ *RoPE*، يؤدي الحفاظ على نفس \\( \theta \\) الذي تم استخدامه أثناء التدريب إلى نتائج سيئة عند تمرير إدخالات نصية أطول بكثير من تلك التي شوهدت أثناء التدريب، راجع [Press et al.](https://huggingface.co/papers/2108.12409). ومع ذلك، وجد المجتمع بعض الحيل الفعالة التي تقوم بتعديل \\( \theta \\)، مما يسمح لترميزات الموضع *RoPE* بالعمل بشكل جيد لتسلسلات إدخال النص المستقرئة (راجع [هنا](https://github.com/huggingface/transformers/pull/24653)). | بالنسبة لـ *RoPE*، يؤدي الحفاظ على نفس \\( \theta \\) الذي تم استخدامه أثناء التدريب إلى نتائج سيئة عند تمرير إدخالات نصية أطول بكثير من تلك التي شوهدت أثناء التدريب، راجع [Press et al.](https://arxiv.org/abs/2108.12409). ومع ذلك، وجد المجتمع بعض الحيل الفعالة التي تقوم بتعديل \\( \theta \\)، مما يسمح لترميزات الموضع *RoPE* بالعمل بشكل جيد لتسلسلات إدخال النص المستقرئة (راجع [هنا](https://github.com/huggingface/transformers/pull/24653)). | ||||||
|  |  | ||||||
| > كل من RoPE و ALiBi عبارة عن ترميزات موضع نسبي *لا* يتم تعلمها أثناء التدريب، ولكن بدلاً من ذلك تستند إلى الحدس التالي: | > كل من RoPE و ALiBi عبارة عن ترميزات موضع نسبي *لا* يتم تعلمها أثناء التدريب، ولكن بدلاً من ذلك تستند إلى الحدس التالي: | ||||||
|  -   يجب إعطاء الإشارات الموضعية حول إدخالات النص مباشرة إلى مصفوفة \\( QK^T \\) لطبقة الاهتمام الذاتي |  -   يجب إعطاء الإشارات الموضعية حول إدخالات النص مباشرة إلى مصفوفة \\( QK^T \\) لطبقة الاهتمام الذاتي | ||||||
| @ -755,21 +755,21 @@ Roughly 8 مليار قيمة عائمة! يتطلب تخزين 8 مليارات | |||||||
|  |  | ||||||
| #### 3.2.2 Multi-Query-Attention (MQA) | #### 3.2.2 Multi-Query-Attention (MQA) | ||||||
|  |  | ||||||
| [Multi-Query-Attention](https://huggingface.co/papers/1911.02150) اقترحها Noam Shazeer في ورقته *Fast Transformer Decoding: One Write-Head is All You Need*. كما يقول العنوان، اكتشف Noam أنه بدلاً من استخدام `n_head` من أوزان إسقاط القيمة الرئيسية، يمكن استخدام زوج واحد من أوزان إسقاط رأس القيمة التي يتم مشاركتها عبر جميع رؤوس الاهتمام دون أن يتدهور أداء النموذج بشكل كبير. | [Multi-Query-Attention](https://arxiv.org/abs/1911.02150) اقترحها Noam Shazeer في ورقته *Fast Transformer Decoding: One Write-Head is All You Need*. كما يقول العنوان، اكتشف Noam أنه بدلاً من استخدام `n_head` من أوزان إسقاط القيمة الرئيسية، يمكن استخدام زوج واحد من أوزان إسقاط رأس القيمة التي يتم مشاركتها عبر جميع رؤوس الاهتمام دون أن يتدهور أداء النموذج بشكل كبير. | ||||||
|  |  | ||||||
| > باستخدام زوج واحد من أوزان إسقاط رأس القيمة، يجب أن تكون متجهات القيمة الرئيسية \\( \mathbf{k}_i، \mathbf{v}_i \\) متطابقة عبر جميع رؤوس الاهتمام والتي بدورها تعني أننا بحاجة فقط إلى تخزين زوج إسقاط قيمة رئيسي واحد في ذاكرة التخزين المؤقت بدلاً من `n_head` منها. | > باستخدام زوج واحد من أوزان إسقاط رأس القيمة، يجب أن تكون متجهات القيمة الرئيسية \\( \mathbf{k}_i، \mathbf{v}_i \\) متطابقة عبر جميع رؤوس الاهتمام والتي بدورها تعني أننا بحاجة فقط إلى تخزين زوج إسقاط قيمة رئيسي واحد في ذاكرة التخزين المؤقت بدلاً من `n_head` منها. | ||||||
|  |  | ||||||
| نظرًا لأن معظم LLMs تستخدم ما بين 20 و100 رأس اهتمام، فإن MQA يقلل بشكل كبير من استهلاك الذاكرة لذاكرة التخزين المؤقت key-value. بالنسبة إلى LLM المستخدم في هذا الدفتر، يمكننا تقليل استهلاك الذاكرة المطلوبة من 15 جيجابايت إلى أقل من 400 ميجابايت عند طول تسلسل الإدخال 16000. | نظرًا لأن معظم LLMs تستخدم ما بين 20 و100 رأس اهتمام، فإن MQA يقلل بشكل كبير من استهلاك الذاكرة لذاكرة التخزين المؤقت key-value. بالنسبة إلى LLM المستخدم في هذا الدفتر، يمكننا تقليل استهلاك الذاكرة المطلوبة من 15 جيجابايت إلى أقل من 400 ميجابايت عند طول تسلسل الإدخال 16000. | ||||||
|  |  | ||||||
| بالإضافة إلى توفير الذاكرة، يؤدي MQA أيضًا إلى تحسين الكفاءة الحسابية كما هو موضح في ما يلي. | بالإضافة إلى توفير الذاكرة، يؤدي MQA أيضًا إلى تحسين الكفاءة الحسابية كما هو موضح في ما يلي. | ||||||
| في فك التشفير التلقائي، يجب إعادة تحميل متجهات القيمة الرئيسية الكبيرة، ودمجها مع زوج متجه القيمة الحالي، ثم إدخالها في \\( \mathbf{q}_c\mathbf{K}^T \\) الحساب في كل خطوة. بالنسبة لفك التشفير التلقائي، يمكن أن تصبح عرض النطاق الترددي للذاكرة المطلوبة لإعادة التحميل المستمر عنق زجاجة زمنيًا خطيرًا. من خلال تقليل حجم متجهات القيمة الرئيسية، يجب الوصول إلى ذاكرة أقل، وبالتالي تقليل عنق الزجاجة في عرض النطاق الترددي للذاكرة. لمزيد من التفاصيل، يرجى إلقاء نظرة على [ورقة Noam](https://huggingface.co/papers/1911.02150). | في فك التشفير التلقائي، يجب إعادة تحميل متجهات القيمة الرئيسية الكبيرة، ودمجها مع زوج متجه القيمة الحالي، ثم إدخالها في \\( \mathbf{q}_c\mathbf{K}^T \\) الحساب في كل خطوة. بالنسبة لفك التشفير التلقائي، يمكن أن تصبح عرض النطاق الترددي للذاكرة المطلوبة لإعادة التحميل المستمر عنق زجاجة زمنيًا خطيرًا. من خلال تقليل حجم متجهات القيمة الرئيسية، يجب الوصول إلى ذاكرة أقل، وبالتالي تقليل عنق الزجاجة في عرض النطاق الترددي للذاكرة. لمزيد من التفاصيل، يرجى إلقاء نظرة على [ورقة Noam](https://arxiv.org/abs/1911.02150). | ||||||
|  |  | ||||||
| الجزء المهم الذي يجب فهمه هنا هو أن تقليل عدد رؤوس الاهتمام بالقيمة الرئيسية إلى 1 لا معنى له إلا إذا تم استخدام ذاكرة التخزين المؤقت للقيمة الرئيسية. يظل الاستهلاك الذروي لذاكرة النموذج لمرور واحد للأمام بدون ذاكرة التخزين المؤقت للقيمة الرئيسية دون تغيير لأن كل رأس اهتمام لا يزال لديه متجه استعلام فريد بحيث يكون لكل رأس اهتمام مصفوفة \\( \mathbf{QK}^T \\) مختلفة. | الجزء المهم الذي يجب فهمه هنا هو أن تقليل عدد رؤوس الاهتمام بالقيمة الرئيسية إلى 1 لا معنى له إلا إذا تم استخدام ذاكرة التخزين المؤقت للقيمة الرئيسية. يظل الاستهلاك الذروي لذاكرة النموذج لمرور واحد للأمام بدون ذاكرة التخزين المؤقت للقيمة الرئيسية دون تغيير لأن كل رأس اهتمام لا يزال لديه متجه استعلام فريد بحيث يكون لكل رأس اهتمام مصفوفة \\( \mathbf{QK}^T \\) مختلفة. | ||||||
|  |  | ||||||
| شهدت MQA اعتمادًا واسع النطاق من قبل المجتمع ويتم استخدامها الآن بواسطة العديد من LLMs الأكثر شهرة: | شهدت MQA اعتمادًا واسع النطاق من قبل المجتمع ويتم استخدامها الآن بواسطة العديد من LLMs الأكثر شهرة: | ||||||
|  |  | ||||||
| -   [**Falcon**](https://huggingface.co/tiiuae/falcon-40b) | -   [**Falcon**](https://huggingface.co/tiiuae/falcon-40b) | ||||||
| -   [**PaLM**](https://huggingface.co/papers/2204.02311) | -   [**PaLM**](https://arxiv.org/abs/2204.02311) | ||||||
| -   [**MPT**](https://huggingface.co/mosaicml/mpt-30b) | -   [**MPT**](https://huggingface.co/mosaicml/mpt-30b) | ||||||
| -   [**BLOOM**](https://huggingface.co/bigscience/bloom) | -   [**BLOOM**](https://huggingface.co/bigscience/bloom) | ||||||
|  |  | ||||||
| @ -777,7 +777,7 @@ Roughly 8 مليار قيمة عائمة! يتطلب تخزين 8 مليارات | |||||||
|  |  | ||||||
| #### 3.2.3 مجموعة الاستعلام الاهتمام (GQA) | #### 3.2.3 مجموعة الاستعلام الاهتمام (GQA) | ||||||
|  |  | ||||||
| [مجموعة الاستعلام الاهتمام](https://huggingface.co/papers/2305.13245)، كما اقترح Ainslie et al. من Google، وجد أن استخدام MQA يمكن أن يؤدي غالبًا إلى تدهور الجودة مقارنة باستخدام إسقاطات رأس القيمة الرئيسية المتعددة. تجادل الورقة بأنه يمكن الحفاظ على أداء النموذج بشكل أكبر عن طريق تقليل عدد أوزان إسقاط رأس الاستعلام بشكل أقل حدة. بدلاً من استخدام وزن إسقاط قيمة رئيسية واحدة فقط، يجب استخدام `n <n_head` أوزان إسقاط قيمة رئيسية. من خلال اختيار `n` إلى قيمة أقل بكثير من `n_head`، مثل 2 أو 4 أو 8، يمكن الاحتفاظ بمعظم مكاسب الذاكرة والسرعة من MQA مع التضحية بقدر أقل من سعة النموذج وبالتالي، من المفترض، أقل أداء. | [مجموعة الاستعلام الاهتمام](https://arxiv.org/abs/2305.13245)، كما اقترح Ainslie et al. من Google، وجد أن استخدام MQA يمكن أن يؤدي غالبًا إلى تدهور الجودة مقارنة باستخدام إسقاطات رأس القيمة الرئيسية المتعددة. تجادل الورقة بأنه يمكن الحفاظ على أداء النموذج بشكل أكبر عن طريق تقليل عدد أوزان إسقاط رأس الاستعلام بشكل أقل حدة. بدلاً من استخدام وزن إسقاط قيمة رئيسية واحدة فقط، يجب استخدام `n <n_head` أوزان إسقاط قيمة رئيسية. من خلال اختيار `n` إلى قيمة أقل بكثير من `n_head`، مثل 2 أو 4 أو 8، يمكن الاحتفاظ بمعظم مكاسب الذاكرة والسرعة من MQA مع التضحية بقدر أقل من سعة النموذج وبالتالي، من المفترض، أقل أداء. | ||||||
|  |  | ||||||
| علاوة على ذلك، اكتشف مؤلفو GQA أنه يمكن *تدريب* نقاط تفتيش النموذج الموجودة ليكون لها بنية GQA باستخدام 5% فقط من الحوسبة الأصلية للتعليم المسبق. في حين أن 5% من الحوسبة الأصلية للتعليم المسبق يمكن أن تكون كمية هائلة، يسمح GQA *uptraining* بنقاط تفتيش موجودة للاستفادة من تسلسلات الإدخال الأطول. | علاوة على ذلك، اكتشف مؤلفو GQA أنه يمكن *تدريب* نقاط تفتيش النموذج الموجودة ليكون لها بنية GQA باستخدام 5% فقط من الحوسبة الأصلية للتعليم المسبق. في حين أن 5% من الحوسبة الأصلية للتعليم المسبق يمكن أن تكون كمية هائلة، يسمح GQA *uptraining* بنقاط تفتيش موجودة للاستفادة من تسلسلات الإدخال الأطول. | ||||||
|  |  | ||||||
| @ -789,7 +789,7 @@ Roughly 8 مليار قيمة عائمة! يتطلب تخزين 8 مليارات | |||||||
|  |  | ||||||
| ## الخاتمة | ## الخاتمة | ||||||
|  |  | ||||||
| مجتمع البحث يأتي باستمرار بطرق جديدة ومبتكرة لتسريع وقت الاستدلال للنماذج اللغوية الكبيرة على الإطلاق. كمثال، أحد اتجاهات البحث الواعدة هو [فك التشفير التخميني](https://huggingface.co/papers/2211.17192) حيث تقوم "الرموز السهلة" بإنشائها نماذج اللغة الأصغر والأسرع ويتم إنشاء "الرموز الصعبة" فقط بواسطة LLM نفسه. إن التعمق في التفاصيل يتجاوز نطاق هذا الدفتر، ولكن يمكن قراءته في هذه [تدوينة المدونة اللطيفة](https://huggingface.co/blog/assisted-generation). | مجتمع البحث يأتي باستمرار بطرق جديدة ومبتكرة لتسريع وقت الاستدلال للنماذج اللغوية الكبيرة على الإطلاق. كمثال، أحد اتجاهات البحث الواعدة هو [فك التشفير التخميني](https://arxiv.org/abs/2211.17192) حيث تقوم "الرموز السهلة" بإنشائها نماذج اللغة الأصغر والأسرع ويتم إنشاء "الرموز الصعبة" فقط بواسطة LLM نفسه. إن التعمق في التفاصيل يتجاوز نطاق هذا الدفتر، ولكن يمكن قراءته في هذه [تدوينة المدونة اللطيفة](https://huggingface.co/blog/assisted-generation). | ||||||
|  |  | ||||||
| السبب في أن LLMs الضخمة مثل GPT3/4، وLlama-2-70b، وClaude، وPaLM يمكن أن تعمل بسرعة كبيرة في واجهات الدردشة مثل [Hugging Face Chat](https://huggingface.co/chat/) أو ChatGPT يرجع إلى حد كبير إلى التحسينات المذكورة أعلاه في الدقة والخوارزميات والهندسة المعمارية. | السبب في أن LLMs الضخمة مثل GPT3/4، وLlama-2-70b، وClaude، وPaLM يمكن أن تعمل بسرعة كبيرة في واجهات الدردشة مثل [Hugging Face Chat](https://huggingface.co/chat/) أو ChatGPT يرجع إلى حد كبير إلى التحسينات المذكورة أعلاه في الدقة والخوارزميات والهندسة المعمارية. | ||||||
| في المستقبل، ستكون أجهزة التسريع مثل وحدات معالجة الرسومات (GPUs) ووحدات معالجة الرسومات (TPUs)، وما إلى ذلك... ستكون أسرع فقط وستسمح بمزيد من الذاكرة، ولكن يجب دائمًا التأكد من استخدام أفضل الخوارزميات والهندسة المعمارية المتاحة للحصول على أكبر قدر من المال | في المستقبل، ستكون أجهزة التسريع مثل وحدات معالجة الرسومات (GPUs) ووحدات معالجة الرسومات (TPUs)، وما إلى ذلك... ستكون أسرع فقط وستسمح بمزيد من الذاكرة، ولكن يجب دائمًا التأكد من استخدام أفضل الخوارزميات والهندسة المعمارية المتاحة للحصول على أكبر قدر من المال | ||||||
|  | |||||||
| @ -165,7 +165,7 @@ default_args = { | |||||||
|  |  | ||||||
| يمكن أن تكون هذه المعرفة مفيدة لمعرفة عند تحليل اختناقات الأداء. | يمكن أن تكون هذه المعرفة مفيدة لمعرفة عند تحليل اختناقات الأداء. | ||||||
|  |  | ||||||
| هذا الملخص مُشتق من [نقل البيانات هو كل ما تحتاجه: دراسة حالة حول تحسين المحولات 2020](https://huggingface.co/papers/2007.00072) | هذا الملخص مُشتق من [نقل البيانات هو كل ما تحتاجه: دراسة حالة حول تحسين المحولات 2020](https://arxiv.org/abs/2007.00072) | ||||||
|  |  | ||||||
|  |  | ||||||
| ## تشريح ذاكرة النموذج | ## تشريح ذاكرة النموذج | ||||||
|  | |||||||
| @ -1,6 +1,6 @@ | |||||||
| # عائلة نماذج المحول | # عائلة نماذج المحول | ||||||
|  |  | ||||||
| منذ إطلاقه في عام 2017، ألهم نموذج [المحول الأصلي](https://huggingface.co/papers/1706.03762) (راجع مدونة [المحول المشروح](http://nlp.seas.harvard.edu/2018/04/03/attention.html) لمقدمة تقنية مبسطة)، ألهم العديد من النماذج الجديدة والمبتكرة التي تتجاوز مهام معالجة اللغات الطبيعية (NLP). هناك نماذج للتنبؤ [بالبنية البروتينات المطوية](https://huggingface.co/blog/deep-learning-with-proteins)، و[تدريب على اتخاذ القرار](https://huggingface.co/blog/train-decision-transformers)، و[التنبؤ بالسلاسل الزمنية](https://huggingface.co/blog/time-series-transformers). مع وجود العديد من متغيرات المحول المتاحة، قد يكون من السهل أن تفوتك الصورة الأكبر. ما تشترك فيه جميع هذه النماذج هو أنها تستند إلى بنية المحول الأصلية. تستخدم بعض النماذج فقط الترميز أو فك الترميز، بينما تستخدم نماذج أخرى كليهما. يوفر هذا تصنيفًا مفيدًا لتصنيف واستعراض الفروقات الرئيسية بين نماذج عائلة المحولات، وسيساعدك على فهم النماذج التي لم تصادفها من قبل. | منذ إطلاقه في عام 2017، ألهم نموذج [المحول الأصلي](https://arxiv.org/abs/1706.03762) (راجع مدونة [المحول المشروح](http://nlp.seas.harvard.edu/2018/04/03/attention.html) لمقدمة تقنية مبسطة)، ألهم العديد من النماذج الجديدة والمبتكرة التي تتجاوز مهام معالجة اللغات الطبيعية (NLP). هناك نماذج للتنبؤ [بالبنية البروتينات المطوية](https://huggingface.co/blog/deep-learning-with-proteins)، و[تدريب على اتخاذ القرار](https://huggingface.co/blog/train-decision-transformers)، و[التنبؤ بالسلاسل الزمنية](https://huggingface.co/blog/time-series-transformers). مع وجود العديد من متغيرات المحول المتاحة، قد يكون من السهل أن تفوتك الصورة الأكبر. ما تشترك فيه جميع هذه النماذج هو أنها تستند إلى بنية المحول الأصلية. تستخدم بعض النماذج فقط الترميز أو فك الترميز، بينما تستخدم نماذج أخرى كليهما. يوفر هذا تصنيفًا مفيدًا لتصنيف واستعراض الفروقات الرئيسية بين نماذج عائلة المحولات، وسيساعدك على فهم النماذج التي لم تصادفها من قبل. | ||||||
|  |  | ||||||
| إذا لم تكن على دراية بنموذج المحول الأصلي أو تحتاج إلى تذكير، فراجع الفصل الخاص بـ [كيف تعمل المحولات](https://huggingface.co/course/chapter1/4؟fw=pt) من دورة Hugging Face. | إذا لم تكن على دراية بنموذج المحول الأصلي أو تحتاج إلى تذكير، فراجع الفصل الخاص بـ [كيف تعمل المحولات](https://huggingface.co/course/chapter1/4؟fw=pt) من دورة Hugging Face. | ||||||
|  |  | ||||||
| @ -14,7 +14,7 @@ | |||||||
|  |  | ||||||
| ### الشبكة التلافيفية (Convolutional network) | ### الشبكة التلافيفية (Convolutional network) | ||||||
|  |  | ||||||
| لطالما كانت الشبكات التلافيفية (CNNs) الطريقة السائدة لمهام رؤية الحاسب حتى برز [محول الرؤية](https://huggingface.co/papers/2010.11929) قابليته للتطوير وكفاءته العالية. وحتى بعد ذلك، لا تزال بعض أفضل صفات CNN، مثل ثبات الإزاحة، قوية جدًا (خاصة بالنسبة لمهام معينة) لدرجة أن بعض المحولات تدمج التلافيف في بنيتها. قلب [ConvNeXt](model_doc/convnext) هذا التبادل رأسًا على عقب وأدرج خيارات التصميم من المحولات لتحديث CNN. على سبيل المثال، يستخدم ConvNeXt نوافذ منزلقة غير متداخلة لتقسيم الصورة إلى رقع وزيادة حقل مجال العام الخاص بها. كما يقوم ConvNeXt بعدة خيارات مثل تصميم الطبقة لتكون أكثر كفاءة في الذاكرة وتحسين الأداء، مما يجعله منافسًا قويًا للمحولات! | لطالما كانت الشبكات التلافيفية (CNNs) الطريقة السائدة لمهام رؤية الحاسب حتى برز [محول الرؤية](https://arxiv.org/abs/2010.11929) قابليته للتطوير وكفاءته العالية. وحتى بعد ذلك، لا تزال بعض أفضل صفات CNN، مثل ثبات الإزاحة، قوية جدًا (خاصة بالنسبة لمهام معينة) لدرجة أن بعض المحولات تدمج التلافيف في بنيتها. قلب [ConvNeXt](model_doc/convnext) هذا التبادل رأسًا على عقب وأدرج خيارات التصميم من المحولات لتحديث CNN. على سبيل المثال، يستخدم ConvNeXt نوافذ منزلقة غير متداخلة لتقسيم الصورة إلى رقع وزيادة حقل مجال العام الخاص بها. كما يقوم ConvNeXt بعدة خيارات مثل تصميم الطبقة لتكون أكثر كفاءة في الذاكرة وتحسين الأداء، مما يجعله منافسًا قويًا للمحولات! | ||||||
|  |  | ||||||
| ### الترميز[[cv-encoder]] (Encoder) | ### الترميز[[cv-encoder]] (Encoder) | ||||||
|  |  | ||||||
| @ -40,7 +40,7 @@ | |||||||
|  |  | ||||||
| نموذج [BERT](model_doc/bert) هو محوّل (Transformer)  يعتمد على الترميز فقط يقوم بشكل عشوائي بإخفاء رموز معينة في المدخلات لتجنب رؤية باقى الرموز الأخرى، مما يسمح له "بالغش". يتمثل هدف التدريب المسبق في التنبؤ بالرمز المخفي بناءً على السياق. يسمح هذا لـ BERT باستخدام السياقات اليمنى واليسرى بالكامل لمساعدته في تعلم تمثيل أعمق وأغنى للبيانات المدخلة. ومع ذلك، كان هناك مجال للتحسين في استراتيجية التدريب المسبق لـ BERT. نموذج [RoBERTa](model_doc/roberta) اضاف تحسين من خلال تقديم وصفة تدريب مسبق جديدة تشمل التدريب لفترة أطول وعلى دفعات أكبر، وإخفاء الرموز عشوائيًا في كل حقبة بدلاً من مرة واحدة فقط أثناء المعالجة المسبقة، وإزالة هدف التنبؤ بالجملة التالية. | نموذج [BERT](model_doc/bert) هو محوّل (Transformer)  يعتمد على الترميز فقط يقوم بشكل عشوائي بإخفاء رموز معينة في المدخلات لتجنب رؤية باقى الرموز الأخرى، مما يسمح له "بالغش". يتمثل هدف التدريب المسبق في التنبؤ بالرمز المخفي بناءً على السياق. يسمح هذا لـ BERT باستخدام السياقات اليمنى واليسرى بالكامل لمساعدته في تعلم تمثيل أعمق وأغنى للبيانات المدخلة. ومع ذلك، كان هناك مجال للتحسين في استراتيجية التدريب المسبق لـ BERT. نموذج [RoBERTa](model_doc/roberta) اضاف تحسين من خلال تقديم وصفة تدريب مسبق جديدة تشمل التدريب لفترة أطول وعلى دفعات أكبر، وإخفاء الرموز عشوائيًا في كل حقبة بدلاً من مرة واحدة فقط أثناء المعالجة المسبقة، وإزالة هدف التنبؤ بالجملة التالية. | ||||||
|  |  | ||||||
| تتمثل الاستراتيجية السائدة لتحسين الأداء في زيادة حجم النموذج. ولكن تدريب النماذج الكبيرة مكلف من الناحية الحسابية. إحدى طرق تقليل التكاليف الحسابية هي استخدام نموذج أصغر مثل [DistilBERT](model_doc/distilbert). يستخدم DistilBERT [ تقنية تقطير المعرفة](https://huggingface.co/papers/1503.02531) - وهي تقنية ضغط - لإنشاء نموذج أصغر من BERT مع الحفاظ على معظم قدراته على فهم اللغةا. | تتمثل الاستراتيجية السائدة لتحسين الأداء في زيادة حجم النموذج. ولكن تدريب النماذج الكبيرة مكلف من الناحية الحسابية. إحدى طرق تقليل التكاليف الحسابية هي استخدام نموذج أصغر مثل [DistilBERT](model_doc/distilbert). يستخدم DistilBERT [ تقنية تقطير المعرفة](https://arxiv.org/abs/1503.02531) - وهي تقنية ضغط - لإنشاء نموذج أصغر من BERT مع الحفاظ على معظم قدراته على فهم اللغةا. | ||||||
|  |  | ||||||
| مرت معظم نماذج المحول في الاتجاه نحو المزيد من المعلمات، مما أدى إلى ظهور نماذج جديدة تركز على تحسين كفاءة التدريب. يقلّل [ALBERT](model_doc/albert) من استهلاك الذاكرة عن طريق تقليل عدد المعلمات بطريقتين: فصل تضمين المفردات الأكبر إلى مصفوفتين أصغر والسماح للمستويات بمشاركة المعلمات. أضاف [DeBERTa](model_doc/deberta) آلية انتباه منفصلة حيث يتم ترميز الكلمة وموضعها بشكل منفصل في متجهين. يتم حساب الانتباه من هذه المتجهات المنفصلة بدلاً من متجه واحد يحتوي على تضمين الكلمة والموقع. ركز [Longformer](model_doc/longformer) أيضًا على جعل الانتباه أكثر كفاءة، خاصة لمعالجة المستندات ذات تسلسلات أطولل. فهو يستخدم مزيجًا من  انتباه النوافذ المحلية (يتم حساب الانتباه فقط ن نافذة ذات حجم ثابت حول كل رمز) والانتباه العام (فقط لرموز مهمة محددة مثل `[CLS]` للتصنيف) لإنشاء مصفوفة انتباه متفرقة بدلاً من مصفوفة انتباه كاملة. | مرت معظم نماذج المحول في الاتجاه نحو المزيد من المعلمات، مما أدى إلى ظهور نماذج جديدة تركز على تحسين كفاءة التدريب. يقلّل [ALBERT](model_doc/albert) من استهلاك الذاكرة عن طريق تقليل عدد المعلمات بطريقتين: فصل تضمين المفردات الأكبر إلى مصفوفتين أصغر والسماح للمستويات بمشاركة المعلمات. أضاف [DeBERTa](model_doc/deberta) آلية انتباه منفصلة حيث يتم ترميز الكلمة وموضعها بشكل منفصل في متجهين. يتم حساب الانتباه من هذه المتجهات المنفصلة بدلاً من متجه واحد يحتوي على تضمين الكلمة والموقع. ركز [Longformer](model_doc/longformer) أيضًا على جعل الانتباه أكثر كفاءة، خاصة لمعالجة المستندات ذات تسلسلات أطولل. فهو يستخدم مزيجًا من  انتباه النوافذ المحلية (يتم حساب الانتباه فقط ن نافذة ذات حجم ثابت حول كل رمز) والانتباه العام (فقط لرموز مهمة محددة مثل `[CLS]` للتصنيف) لإنشاء مصفوفة انتباه متفرقة بدلاً من مصفوفة انتباه كاملة. | ||||||
|  |  | ||||||
|  | |||||||
| @ -33,7 +33,7 @@ pip install git+https://github.com/huggingface/peft.git | |||||||
|  |  | ||||||
| - [محولات الرتبة المنخفضة](https://huggingface.co/docs/peft/conceptual_guides/lora) | - [محولات الرتبة المنخفضة](https://huggingface.co/docs/peft/conceptual_guides/lora) | ||||||
| - [IA3](https://huggingface.co/docs/peft/conceptual_guides/ia3) | - [IA3](https://huggingface.co/docs/peft/conceptual_guides/ia3) | ||||||
| - [AdaLoRA](https://huggingface.co/papers/2303.10512) | - [AdaLoRA](https://arxiv.org/abs/2303.10512) | ||||||
|  |  | ||||||
| إذا كنت تريد استخدام طرق PEFT الأخرى، مثل تعلم المحث أو ضبط المحث، أو حول مكتبة 🤗 PEFT بشكل عام، يرجى الرجوع إلى [الوثائق](https://huggingface.co/docs/peft/index). | إذا كنت تريد استخدام طرق PEFT الأخرى، مثل تعلم المحث أو ضبط المحث، أو حول مكتبة 🤗 PEFT بشكل عام، يرجى الرجوع إلى [الوثائق](https://huggingface.co/docs/peft/index). | ||||||
|  |  | ||||||
|  | |||||||
| @ -2,7 +2,7 @@ | |||||||
|  |  | ||||||
| بالإضافة إلى دفاتر الملاحظات [notebooks](./notebooks) الخاصة بـ 🤗 Transformers، هناك أيضًا نصوص برمجية توضيحية تُظهر كيفية تدريب نموذج لمهمة باستخدام [PyTorch](https://github.com/huggingface/transformers/tree/main/examples/pytorch) أو [TensorFlow](https://github.com/huggingface/transformers/tree/main/examples/tensorflow) أو [JAX/Flax](https://github.com/huggingface/transformers/tree/main/examples/flax). | بالإضافة إلى دفاتر الملاحظات [notebooks](./notebooks) الخاصة بـ 🤗 Transformers، هناك أيضًا نصوص برمجية توضيحية تُظهر كيفية تدريب نموذج لمهمة باستخدام [PyTorch](https://github.com/huggingface/transformers/tree/main/examples/pytorch) أو [TensorFlow](https://github.com/huggingface/transformers/tree/main/examples/tensorflow) أو [JAX/Flax](https://github.com/huggingface/transformers/tree/main/examples/flax). | ||||||
|  |  | ||||||
| كما ستجد النصوص البرمجية التي استخدمناها في [مشاريع الأبحاث](https://github.com/huggingface/transformers-research-projects/) و [الأمثلة القديمة](https://github.com/huggingface/transformers/tree/main/examples/legacy) والتي ساهم بها المجتمع بشكل أساسي. هذه النصوص البرمجية غير مدعومة بشكل نشط وقد تتطلب إصدارًا محددًا من مكتبة 🤗 Transformers والذي من المحتمل أن يكون غير متوافق مع الإصدار الأحدث من المكتبة. | كما ستجد النصوص البرمجية التي استخدمناها في [مشاريع الأبحاث](https://github.com/huggingface/transformers/tree/main/examples/research_projects) و [الأمثلة القديمة](https://github.com/huggingface/transformers/tree/main/examples/legacy) والتي ساهم بها المجتمع بشكل أساسي. هذه النصوص البرمجية غير مدعومة بشكل نشط وقد تتطلب إصدارًا محددًا من مكتبة 🤗 Transformers والذي من المحتمل أن يكون غير متوافق مع الإصدار الأحدث من المكتبة. | ||||||
|  |  | ||||||
| لا يُتوقع أن تعمل النصوص البرمجية التوضيحية بشكل مباشر على كل مشكلة، وقد تحتاج إلى تكييف النص البرمجي مع المشكلة التي تحاول حلها. ولمساعدتك في ذلك، تعرض معظم النصوص البرمجية كيفية معالجة البيانات قبل التدريب بشكل كامل، مما يتيح لك تحريرها حسب الحاجة لحالتك الاستخدام. | لا يُتوقع أن تعمل النصوص البرمجية التوضيحية بشكل مباشر على كل مشكلة، وقد تحتاج إلى تكييف النص البرمجي مع المشكلة التي تحاول حلها. ولمساعدتك في ذلك، تعرض معظم النصوص البرمجية كيفية معالجة البيانات قبل التدريب بشكل كامل، مما يتيح لك تحريرها حسب الحاجة لحالتك الاستخدام. | ||||||
|  |  | ||||||
|  | |||||||
| @ -116,11 +116,11 @@ optimum-cli export onnx --model keras-io/transformers-qa distilbert_base_cased_s | |||||||
|  |  | ||||||
| <Tip warning={true}> | <Tip warning={true}> | ||||||
|  |  | ||||||
| لم يعد يتم دعم `transformers.onnx`  يُرجى تصدير النماذج باستخدام 🤗 Optimum كما هو موضح أعلاه. سيتم إزالة هذا القسم في الإصدارات القادمة. | لم يعد يتم دعم `tranformers.onnx`  يُرجى تصدير النماذج باستخدام 🤗 Optimum كما هو موضح أعلاه. سيتم إزالة هذا القسم في الإصدارات القادمة. | ||||||
|  |  | ||||||
| </Tip> | </Tip> | ||||||
|  |  | ||||||
| لتصدير نموذج 🤗 Transformers إلى ONNX باستخدام `transformers.onnx`، ثبّت التبعيات الإضافية: | لتصدير نموذج 🤗 Transformers إلى ONNX باستخدام `tranformers.onnx`، ثبّت التبعيات الإضافية: | ||||||
|  |  | ||||||
| ```bash | ```bash | ||||||
| pip install transformers[onnx] | pip install transformers[onnx] | ||||||
|  | |||||||
| @ -103,7 +103,7 @@ | |||||||
|     <img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/convolution.gif"/> |     <img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/convolution.gif"/> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
| <small>عملية التفاف أساسية بدون حشو أو خطو خطوة واسعة، مأخوذة من  <a href="https://huggingface.co/papers/1603.07285">دليل لحساب الالتفاف للتعلم العميق.</a></small> | <small>عملية التفاف أساسية بدون حشو أو خطو خطوة واسعة، مأخوذة من  <a href="https://arxiv.org/abs/1603.07285">دليل لحساب الالتفاف للتعلم العميق.</a></small> | ||||||
|  |  | ||||||
| يمكنك تغذية هذا الناتج إلى طبقة التفاف أخرى،  ومع كل طبقة متتالية، تتعلم الشبكة أشياء أكثر تعقيدًا وتجريدية مثل النقانق أو الصواريخ. بين طبقات الالتفاف، من الشائع إضافة طبقة تجميع لتقليل الأبعاد وجعل النموذج أكثر قوة للتغيرات في موضع الميزة. | يمكنك تغذية هذا الناتج إلى طبقة التفاف أخرى،  ومع كل طبقة متتالية، تتعلم الشبكة أشياء أكثر تعقيدًا وتجريدية مثل النقانق أو الصواريخ. بين طبقات الالتفاف، من الشائع إضافة طبقة تجميع لتقليل الأبعاد وجعل النموذج أكثر قوة للتغيرات في موضع الميزة. | ||||||
|  |  | ||||||
|  | |||||||
| @ -94,7 +94,7 @@ | |||||||
|  |  | ||||||
| ### ترميز الأزواج البايتية (BPE) | ### ترميز الأزواج البايتية (BPE) | ||||||
|  |  | ||||||
| تم تقديم رميز أزواج البايت (BPE) في ورقة بحثية بعنوان [الترجمة الآلية العصبية للكلمات النادرة باستخدام وحدات subword (Sennrich et al.، 2015)](https://huggingface.co/papers/1508.07909). يعتمد BPE على مُجزّئ أولي يقسم بيانات التدريب إلى | تم تقديم رميز أزواج البايت (BPE) في ورقة بحثية بعنوان [الترجمة الآلية العصبية للكلمات النادرة باستخدام وحدات subword (Sennrich et al.، 2015)](https://arxiv.org/abs/1508.07909). يعتمد BPE على مُجزّئ أولي يقسم بيانات التدريب إلى | ||||||
| كلمات. يمكن أن يكون التحليل المسبق بسيطًا مثل التقسيم المكاني، على سبيل المثال [GPT-2](model_doc/gpt2)، [RoBERTa](model_doc/roberta). تشمل التقسيم الأكثر تقدمًا معتمد على التحليل القائم على القواعد، على سبيل المثال [XLM](model_doc/xlm)، [FlauBERT](model_doc/flaubert) الذي يستخدم Moses لمعظم اللغات، أو [GPT](model_doc/openai-gpt) الذي يستخدم spaCy و ftfy، لحساب تكرار كل كلمة في مجموعة بيانات التدريب. | كلمات. يمكن أن يكون التحليل المسبق بسيطًا مثل التقسيم المكاني، على سبيل المثال [GPT-2](model_doc/gpt2)، [RoBERTa](model_doc/roberta). تشمل التقسيم الأكثر تقدمًا معتمد على التحليل القائم على القواعد، على سبيل المثال [XLM](model_doc/xlm)، [FlauBERT](model_doc/flaubert) الذي يستخدم Moses لمعظم اللغات، أو [GPT](model_doc/openai-gpt) الذي يستخدم spaCy و ftfy، لحساب تكرار كل كلمة في مجموعة بيانات التدريب. | ||||||
|  |  | ||||||
| بعد التحليل المسبق، يتم إنشاء مجموعة من الكلمات الفريدة وقد تم تحديد تكرار كل كلمة في تم تحديد بيانات التدريب. بعد ذلك، يقوم BPE بإنشاء مفردات أساسية تتكون من جميع الرموز التي تحدث في مجموعة الكلمات الفريدة ويتعلم قواعد الدمج لتشكيل رمز جديد من رمزين من المفردات الأساسية. إنه يفعل ذلك حتى تصل المفردات إلى حجم المفردات المطلوب. لاحظ أن حجم المفردات هو فرط معلمة لتحديد قبل تدريب مُجزّئ  النصوص. | بعد التحليل المسبق، يتم إنشاء مجموعة من الكلمات الفريدة وقد تم تحديد تكرار كل كلمة في تم تحديد بيانات التدريب. بعد ذلك، يقوم BPE بإنشاء مفردات أساسية تتكون من جميع الرموز التي تحدث في مجموعة الكلمات الفريدة ويتعلم قواعد الدمج لتشكيل رمز جديد من رمزين من المفردات الأساسية. إنه يفعل ذلك حتى تصل المفردات إلى حجم المفردات المطلوب. لاحظ أن حجم المفردات هو فرط معلمة لتحديد قبل تدريب مُجزّئ  النصوص. | ||||||
| @ -158,7 +158,7 @@ BPE. أولاً، يقوم WordPiece بتكوين المفردات لتضمين | |||||||
| ### Unigram | ### Unigram | ||||||
|  |  | ||||||
| Unigram هو خوارزمية توكنيز subword التي تم تقديمها في [تنظيم subword: تحسين نماذج الترجمة الشبكة العصبية | Unigram هو خوارزمية توكنيز subword التي تم تقديمها في [تنظيم subword: تحسين نماذج الترجمة الشبكة العصبية | ||||||
| نماذج مع مرشحين subword متعددة (Kudo، 2018)](https://huggingface.co/papers/1804.10959). على عكس BPE أو | نماذج مع مرشحين subword متعددة (Kudo، 2018)](https://arxiv.org/pdf/1804.10959.pdf). على عكس BPE أو | ||||||
| WordPiece، يقوم Unigram بتكوين مفرداته الأساسية إلى عدد كبير من الرموز ويقللها تدريجياً للحصول على مفردات أصغر. يمكن أن تتوافق المفردات الأساسية على سبيل المثال مع جميع الكلمات المسبقة التوكنز والسلاسل الفرعية الأكثر شيوعًا. لا يتم استخدام Unigram مباشرة لأي من النماذج في المحولات، ولكنه يستخدم بالاقتران مع [SentencePiece](#sentencepiece). | WordPiece، يقوم Unigram بتكوين مفرداته الأساسية إلى عدد كبير من الرموز ويقللها تدريجياً للحصول على مفردات أصغر. يمكن أن تتوافق المفردات الأساسية على سبيل المثال مع جميع الكلمات المسبقة التوكنز والسلاسل الفرعية الأكثر شيوعًا. لا يتم استخدام Unigram مباشرة لأي من النماذج في المحولات، ولكنه يستخدم بالاقتران مع [SentencePiece](#sentencepiece). | ||||||
|  |  | ||||||
| في كل خطوة تدريب، يحدد خوارزمية Unigram خسارة (غالبًا ما يتم تعريفها على أنها اللوغاريتم) عبر بيانات التدريب بالنظر إلى المفردات الحالية ونموذج اللغة unigram. بعد ذلك، بالنسبة لكل رمز في المفردات، يحسب الخوارزمية مقدار زيادة الخسارة الإجمالية إذا تم إزالة الرمز من المفردات. ثم يقوم Unigram بإزالة p (مع p عادة ما تكون 10% أو 20%) في المائة من الرموز التي تكون زيادة الخسارة فيها هي الأدنى، *أي* تلك | في كل خطوة تدريب، يحدد خوارزمية Unigram خسارة (غالبًا ما يتم تعريفها على أنها اللوغاريتم) عبر بيانات التدريب بالنظر إلى المفردات الحالية ونموذج اللغة unigram. بعد ذلك، بالنسبة لكل رمز في المفردات، يحسب الخوارزمية مقدار زيادة الخسارة الإجمالية إذا تم إزالة الرمز من المفردات. ثم يقوم Unigram بإزالة p (مع p عادة ما تكون 10% أو 20%) في المائة من الرموز التي تكون زيادة الخسارة فيها هي الأدنى، *أي* تلك | ||||||
| @ -188,7 +188,7 @@ $$\mathcal{L} = -\sum_{i=1}^{N} \log \left ( \sum_{x \in S(x_{i})} p(x) \right ) | |||||||
|  |  | ||||||
| تحتوي جميع خوارزميات توكنز الموصوفة حتى الآن على نفس المشكلة: من المفترض أن النص المدخل يستخدم المسافات لفصل الكلمات. ومع ذلك، لا تستخدم جميع اللغات المسافات لفصل الكلمات. أحد الحلول الممكنة هو استخداممعالج مسبق للغة محدد، *مثال* [XLM](model_doc/xlm) يلذي يستخدم معالجات مسبقة محددة للصينية واليابانية والتايلاندية. | تحتوي جميع خوارزميات توكنز الموصوفة حتى الآن على نفس المشكلة: من المفترض أن النص المدخل يستخدم المسافات لفصل الكلمات. ومع ذلك، لا تستخدم جميع اللغات المسافات لفصل الكلمات. أحد الحلول الممكنة هو استخداممعالج مسبق للغة محدد، *مثال* [XLM](model_doc/xlm) يلذي يستخدم معالجات مسبقة محددة للصينية واليابانية والتايلاندية. | ||||||
| لحل هذه المشكلة بشكل أعم، [SentencePiece: A simple and language independent subword tokenizer and | لحل هذه المشكلة بشكل أعم، [SentencePiece: A simple and language independent subword tokenizer and | ||||||
| detokenizer for Neural Text Processing (Kudo et al.، 2018)](https://huggingface.co/papers/1808.06226) يتعامل مع المدخلات | detokenizer for Neural Text Processing (Kudo et al.، 2018)](https://arxiv.org/pdf/1808.06226.pdf) يتعامل مع المدخلات | ||||||
| كتدفق بيانات خام، وبالتالي يشمل المسافة في مجموعة الأحرف التي سيتم استخدامها. ثم يستخدم خوارزمية BPE أو unigram | كتدفق بيانات خام، وبالتالي يشمل المسافة في مجموعة الأحرف التي سيتم استخدامها. ثم يستخدم خوارزمية BPE أو unigram | ||||||
| لبناء المفردات المناسبة. | لبناء المفردات المناسبة. | ||||||
|  |  | ||||||
|  | |||||||
| @ -306,48 +306,78 @@ pip install galore-torch | |||||||
| ثم أضف ببساطة أحد `["galore_adamw"، "galore_adafactor"، "galore_adamw_8bit"]` في `optim` جنبًا إلى جنب مع `optim_target_modules`، والتي يمكن أن تكون قائمة من السلاسل أو التعبيرات النمطية regex أو المسار الكامل المطابق لأسماء الوحدات المستهدفة التي تريد تكييفها. فيما يلي مثال على النص البرمجي كامل(تأكد من `pip install trl datasets`): | ثم أضف ببساطة أحد `["galore_adamw"، "galore_adafactor"، "galore_adamw_8bit"]` في `optim` جنبًا إلى جنب مع `optim_target_modules`، والتي يمكن أن تكون قائمة من السلاسل أو التعبيرات النمطية regex أو المسار الكامل المطابق لأسماء الوحدات المستهدفة التي تريد تكييفها. فيما يلي مثال على النص البرمجي كامل(تأكد من `pip install trl datasets`): | ||||||
|  |  | ||||||
| ```python | ```python | ||||||
|  | import torch | ||||||
| import datasets | import datasets | ||||||
| from trl import SFTConfig, SFTTrainer | import trl | ||||||
|  |  | ||||||
|  | from transformers import TrainingArguments, AutoConfig, AutoTokenizer, AutoModelForCausalLM | ||||||
|  |  | ||||||
| train_dataset = datasets.load_dataset('imdb', split='train') | train_dataset = datasets.load_dataset('imdb', split='train') | ||||||
| args = SFTConfig( |  | ||||||
|     output_dir="./test-galore", | args = TrainingArguments( | ||||||
|  |     output_dir="./test-galore"، | ||||||
|     max_steps=100, |     max_steps=100, | ||||||
|     optim="galore_adamw", |     per_device_train_batch_size=2, | ||||||
|     optim_target_modules=[r".*.attn.*", r".*.mlp.*"], |     optim="galore_adamw"، | ||||||
|     gradient_checkpointing=True, |     optim_target_modules=[r".*.attn.*"، r".*.mlp.*"] | ||||||
| ) | ) | ||||||
| trainer = SFTTrainer( |  | ||||||
|     model="google/gemma-2b", | model_id = "google/gemma-2b" | ||||||
|  |  | ||||||
|  | config = AutoConfig.from_pretrained(model_id) | ||||||
|  |  | ||||||
|  | tokenizer = AutoTokenizer.from_pretrained(model_id) | ||||||
|  | model = AutoModelForCausalLM.from_config(config).to(0) | ||||||
|  |  | ||||||
|  | trainer = trl.SFTTrainer( | ||||||
|  |     model=model,  | ||||||
|     args=args, |     args=args, | ||||||
|     train_dataset=train_dataset, |     train_dataset=train_dataset, | ||||||
|  |     dataset_text_field='text', | ||||||
|  |     max_seq_length=512, | ||||||
| ) | ) | ||||||
|  |  | ||||||
| trainer.train() | trainer.train() | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| لتمرير معامﻻت إضافية يدعمها  GaLore، يجب عليك تمرير `optim_args` بشكل صحيح، على سبيل المثال: | لتمرير معامﻻت إضافية يدعمها  GaLore، يجب عليك تمرير `optim_args` بشكل صحيح، على سبيل المثال: | ||||||
|  |  | ||||||
| ```python | ```python | ||||||
|  | import torch | ||||||
| import datasets | import datasets | ||||||
| from trl import SFTConfig, SFTTrainer | import trl | ||||||
|  |  | ||||||
|  | from transformers import TrainingArguments, AutoConfig, AutoTokenizer, AutoModelForCausalLM | ||||||
|  |  | ||||||
| train_dataset = datasets.load_dataset('imdb', split='train') | train_dataset = datasets.load_dataset('imdb', split='train') | ||||||
| args = SFTConfig( |  | ||||||
|  | args = TrainingArguments( | ||||||
|     output_dir="./test-galore", |     output_dir="./test-galore", | ||||||
|     max_steps=100, |     max_steps=100, | ||||||
|  |     per_device_train_batch_size=2, | ||||||
|     optim="galore_adamw", |     optim="galore_adamw", | ||||||
|     optim_target_modules=[r".*.attn.*", r".*.mlp.*"], |     optim_target_modules=[r".*.attn.*", r".*.mlp.*"], | ||||||
|     optim_args="rank=64, update_proj_gap=100, scale=0.10", |     optim_args="rank=64, update_proj_gap=100, scale=0.10", | ||||||
|     gradient_checkpointing=True, |  | ||||||
| ) | ) | ||||||
| trainer = SFTTrainer( |  | ||||||
|     model="google/gemma-2b", | model_id = "google/gemma-2b" | ||||||
|  |  | ||||||
|  | config = AutoConfig.from_pretrained(model_id) | ||||||
|  |  | ||||||
|  | tokenizer = AutoTokenizer.from_pretrained(model_id) | ||||||
|  | model = AutoModelForCausalLM.from_config(config).to(0) | ||||||
|  |  | ||||||
|  | trainer = trl.SFTTrainer( | ||||||
|  |     model=model,  | ||||||
|     args=args, |     args=args, | ||||||
|     train_dataset=train_dataset, |     train_dataset=train_dataset, | ||||||
|  |     dataset_text_field='text', | ||||||
|  |     max_seq_length=512, | ||||||
| ) | ) | ||||||
|  |  | ||||||
| trainer.train() | trainer.train() | ||||||
| ``` | ``` | ||||||
| يمكنك قراءة المزيد حول الطريقة في [المستودع الأصلي](https://github.com/jiaweizzhao/GaLore) أو [الورقة البحثية](https://huggingface.co/papers/2403.03507). | يمكنك قراءة المزيد حول الطريقة في [المستودع الأصلي](https://github.com/jiaweizzhao/GaLore) أو [الورقة البحثية](https://arxiv.org/abs/2403.03507). | ||||||
|  |  | ||||||
| حاليًا، يمكنك فقط تدريب الطبقات الخطية التي تعتبر طبقات GaLore وستستخدم التحلل  ذو الرتبة المنخفضة للتدريب بينما سيتم تحسين الطبقات المتبقية بالطريقة التقليدية. | حاليًا، يمكنك فقط تدريب الطبقات الخطية التي تعتبر طبقات GaLore وستستخدم التحلل  ذو الرتبة المنخفضة للتدريب بينما سيتم تحسين الطبقات المتبقية بالطريقة التقليدية. | ||||||
|  |  | ||||||
| @ -356,22 +386,37 @@ trainer.train() | |||||||
| يمكنك أيضًا إجراء تحسين طبقة تلو الأخرى عن طريق إضافة `layerwise` إلى اسم المُحسِّن كما هو موضح أدناه: | يمكنك أيضًا إجراء تحسين طبقة تلو الأخرى عن طريق إضافة `layerwise` إلى اسم المُحسِّن كما هو موضح أدناه: | ||||||
|  |  | ||||||
| ```python | ```python | ||||||
|  | import torch | ||||||
| import datasets | import datasets | ||||||
| from trl import SFTConfig, SFTTrainer | import trl | ||||||
|  |  | ||||||
| train_dataset = datasets.load_dataset('imdb', split='train') | from transformers import TrainingArguments، AutoConfig، AutoTokenizer، AutoModelForCausalLM | ||||||
| args = SFTConfig( |  | ||||||
|     output_dir="./test-galore", | train_dataset = datasets.load_dataset('imdb'، split='train') | ||||||
|     max_steps=100, |  | ||||||
|     optim="galore_adamw_layerwise", | args = TrainingArguments( | ||||||
|     optim_target_modules=[r".*.attn.*", r".*.mlp.*"], |     output_dir="./test-galore"، | ||||||
|     gradient_checkpointing=True, |     max_steps=100، | ||||||
|  |     per_device_train_batch_size=2، | ||||||
|  |     optim="galore_adamw_layerwise"، | ||||||
|  |     optim_target_modules=[r".*.attn.*"، r".*.mlp.*"] | ||||||
| ) | ) | ||||||
| trainer = SFTTrainer( |  | ||||||
|     model="google/gemma-2b", | model_id = "google/gemma-2b" | ||||||
|     args=args, |  | ||||||
|     train_dataset=train_dataset, | config = AutoConfig.from_pretrained(model_id) | ||||||
|  |  | ||||||
|  | tokenizer = AutoTokenizer.from_pretrained(model_id) | ||||||
|  | model = AutoModelForCausalLM.from_config(config).to(0) | ||||||
|  |  | ||||||
|  | trainer = trl.SFTTrainer( | ||||||
|  |     model=model، | ||||||
|  |     args=args، | ||||||
|  |     train_dataset=train_dataset، | ||||||
|  |     dataset_text_field='text'، | ||||||
|  |     max_seq_length=512، | ||||||
| ) | ) | ||||||
|  |  | ||||||
| trainer.train() | trainer.train() | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| @ -391,21 +436,39 @@ trainer.train() | |||||||
| فيما يلي نص برمجي بسيط يوضح كيفية ضبط نموذج [google/gemma-2b](https://huggingface.co/google/gemma-2b) على مجموعة بيانات IMDB في الدقة الكاملة: | فيما يلي نص برمجي بسيط يوضح كيفية ضبط نموذج [google/gemma-2b](https://huggingface.co/google/gemma-2b) على مجموعة بيانات IMDB في الدقة الكاملة: | ||||||
|  |  | ||||||
| ```python | ```python | ||||||
|  | import torch | ||||||
| import datasets | import datasets | ||||||
| from trl import SFTConfig, SFTTrainer | from transformers import TrainingArguments، AutoTokenizer، AutoModelForCausalLM | ||||||
|  | import trl | ||||||
|  |  | ||||||
| train_dataset = datasets.load_dataset('imdb', split='train') | train_dataset = datasets.load_dataset('imdb'، split='train') | ||||||
| args = SFTConfig( |  | ||||||
|     output_dir="./test-lomo", | args = TrainingArguments( | ||||||
|     max_steps=100, |     output_dir="./test-lomo"، | ||||||
|     optim="adalomo", |     max_steps=100، | ||||||
|     gradient_checkpointing=True, |     per_device_train_batch_size=4، | ||||||
|  |     optim="adalomo"، | ||||||
|  |     gradient_checkpointing=True، | ||||||
|  |     logging_strategy="steps"، | ||||||
|  |     logging_steps=1، | ||||||
|  |     learning_rate=2e-6، | ||||||
|  |     save_strategy="no"، | ||||||
|  |     run_name="lomo-imdb"، | ||||||
| ) | ) | ||||||
| trainer = SFTTrainer( |  | ||||||
|     model="google/gemma-2b", | model_id = "google/gemma-2b" | ||||||
|     args=args, |  | ||||||
|     train_dataset=train_dataset, | tokenizer = AutoTokenizer.from_pretrained(model_id) | ||||||
|  | model = AutoModelForCausalLM.from_pretrained(model_id، low_cpu_mem_usage=True).to(0) | ||||||
|  |  | ||||||
|  | trainer = trl.SFTTrainer( | ||||||
|  |     model=model، | ||||||
|  |     args=args، | ||||||
|  |     train_dataset=train_dataset، | ||||||
|  |     dataset_text_field='text'، | ||||||
|  |     max_seq_length=1024، | ||||||
| ) | ) | ||||||
|  |  | ||||||
| trainer.train() | trainer.train() | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| @ -440,7 +503,7 @@ args = TrainingArguments( | |||||||
| # تحميل النموذج والمجزىء اللغوي | # تحميل النموذج والمجزىء اللغوي | ||||||
| model_id = "google/gemma-2b" | model_id = "google/gemma-2b" | ||||||
| tokenizer = AutoTokenizer.from_pretrained(model_id) | tokenizer = AutoTokenizer.from_pretrained(model_id) | ||||||
| model = AutoModelForCausalLM.from_pretrained(model_id).to(0) | model = AutoModelForCausalLM.from_pretrained(model_id, low_cpu_mem_usage=True).to(0) | ||||||
|  |  | ||||||
| # تهيئة المدرب | # تهيئة المدرب | ||||||
| trainer = Trainer( | trainer = Trainer( | ||||||
| @ -461,21 +524,39 @@ trainer.train() | |||||||
|  |  | ||||||
| فيما يلي نص برمجى بسيط لشرح كيفية ضبط [google/gemma-2b](https://huggingface.co/google/gemma-2b) بدقة على مجموعة بيانات IMDB بدقة كاملة: | فيما يلي نص برمجى بسيط لشرح كيفية ضبط [google/gemma-2b](https://huggingface.co/google/gemma-2b) بدقة على مجموعة بيانات IMDB بدقة كاملة: | ||||||
| ```python | ```python | ||||||
|  | import torch | ||||||
| import datasets | import datasets | ||||||
| from trl import SFTConfig, SFTTrainer | from transformers import TrainingArguments, AutoTokenizer, AutoModelForCausalLM | ||||||
|  | import trl | ||||||
|  |  | ||||||
| train_dataset = datasets.load_dataset('imdb', split='train') | train_dataset = datasets.load_dataset('imdb', split='train') | ||||||
| args = SFTConfig( |  | ||||||
|     output_dir="./test-galore", | args = TrainingArguments( | ||||||
|     max_steps=100, |     output_dir="./test-schedulefree", | ||||||
|  |     max_steps=1000, | ||||||
|  |     per_device_train_batch_size=4, | ||||||
|     optim="schedule_free_adamw", |     optim="schedule_free_adamw", | ||||||
|     gradient_checkpointing=True, |     gradient_checkpointing=True, | ||||||
|  |     logging_strategy="steps", | ||||||
|  |     logging_steps=1, | ||||||
|  |     learning_rate=2e-6, | ||||||
|  |     save_strategy="no", | ||||||
|  |     run_name="sfo-imdb", | ||||||
| ) | ) | ||||||
| trainer = SFTTrainer( |  | ||||||
|     model="google/gemma-2b", | model_id = "google/gemma-2b" | ||||||
|  |  | ||||||
|  | tokenizer = AutoTokenizer.from_pretrained(model_id) | ||||||
|  | model = AutoModelForCausalLM.from_pretrained(model_id, low_cpu_mem_usage=True).to(0) | ||||||
|  |  | ||||||
|  | trainer = trl.SFTTrainer( | ||||||
|  |     model=model,  | ||||||
|     args=args, |     args=args, | ||||||
|     train_dataset=train_dataset, |     train_dataset=train_dataset, | ||||||
|  |     dataset_text_field='text', | ||||||
|  |     max_seq_length=1024, | ||||||
| ) | ) | ||||||
|  |  | ||||||
| trainer.train() | trainer.train() | ||||||
| ``` | ``` | ||||||
| ## تسريع ومدرب | ## تسريع ومدرب | ||||||
| @ -593,7 +674,6 @@ use_cpu: false | |||||||
| ``` | ``` | ||||||
|  |  | ||||||
| </hfoption> | </hfoption> | ||||||
|  |  | ||||||
| </hfoptions> | </hfoptions> | ||||||
| يُعد أمر  [`accelerate_launch`](https://huggingface.co/docs/accelerate/package_reference/cli#accelerate-launch) هو الطريقة المُوصى بها لتشغيل نص البرمجى للتدريب على نظام موزع باستخدام Accelerate و [`Trainer`] مع المعلمات المحددة في `config_file.yaml`. يتم حفظ هذا الملف في مجلد ذاكرة التخزين المؤقت لـ Accelerate ويتم تحميله تلقائيًا عند تشغيل `accelerate_launch`. | يُعد أمر  [`accelerate_launch`](https://huggingface.co/docs/accelerate/package_reference/cli#accelerate-launch) هو الطريقة المُوصى بها لتشغيل نص البرمجى للتدريب على نظام موزع باستخدام Accelerate و [`Trainer`] مع المعلمات المحددة في `config_file.yaml`. يتم حفظ هذا الملف في مجلد ذاكرة التخزين المؤقت لـ Accelerate ويتم تحميله تلقائيًا عند تشغيل `accelerate_launch`. | ||||||
|  |  | ||||||
|  | |||||||
| @ -23,6 +23,8 @@ | |||||||
|     title: Laden und Trainieren von Adaptern mit 🤗 PEFT |     title: Laden und Trainieren von Adaptern mit 🤗 PEFT | ||||||
|   - local: model_sharing |   - local: model_sharing | ||||||
|     title: Ein Modell teilen |     title: Ein Modell teilen | ||||||
|  |   - local: transformers_agents | ||||||
|  |     title: Agents | ||||||
|   - local: llm_tutorial |   - local: llm_tutorial | ||||||
|     title: Generation with LLMs |     title: Generation with LLMs | ||||||
|   title: Tutorials |   title: Tutorials | ||||||
| @ -37,4 +39,4 @@ | |||||||
|     title: Testen |     title: Testen | ||||||
|   - local: pr_checks |   - local: pr_checks | ||||||
|     title: Überprüfung einer Pull Request |     title: Überprüfung einer Pull Request | ||||||
|   title: Contribute |   title: Contribute | ||||||
| @ -95,7 +95,7 @@ wie der Code geschrieben werden sollte :-) | |||||||
| 1. Der Vorwärtsdurchlauf Ihres Modells sollte vollständig in die Modellierungsdatei geschrieben werden und dabei völlig unabhängig von anderen | 1. Der Vorwärtsdurchlauf Ihres Modells sollte vollständig in die Modellierungsdatei geschrieben werden und dabei völlig unabhängig von anderen | ||||||
|    Modellen in der Bibliothek. Wenn Sie einen Block aus einem anderen Modell wiederverwenden möchten, kopieren Sie den Code und fügen ihn mit einem |    Modellen in der Bibliothek. Wenn Sie einen Block aus einem anderen Modell wiederverwenden möchten, kopieren Sie den Code und fügen ihn mit einem | ||||||
|    `# Kopiert von` ein (siehe [hier](https://github.com/huggingface/transformers/blob/v4.17.0/src/transformers/models/roberta/modeling_roberta.py#L160) |    `# Kopiert von` ein (siehe [hier](https://github.com/huggingface/transformers/blob/v4.17.0/src/transformers/models/roberta/modeling_roberta.py#L160) | ||||||
|    für ein gutes Beispiel und [hier](pr_checks#check-copies) für weitere Dokumentation zu Copied from). |    für ein gutes Beispiel und [hier](pr_checks#check-copies) für weitere Dokumentation zu Copied from).  | ||||||
| 2. Der Code sollte vollständig verständlich sein, auch für einen Nicht-Muttersprachler. Das heißt, Sie sollten | 2. Der Code sollte vollständig verständlich sein, auch für einen Nicht-Muttersprachler. Das heißt, Sie sollten | ||||||
|    beschreibende Variablennamen wählen und Abkürzungen vermeiden. Ein Beispiel: `activation` ist `act` vorzuziehen. |    beschreibende Variablennamen wählen und Abkürzungen vermeiden. Ein Beispiel: `activation` ist `act` vorzuziehen. | ||||||
|    Von Variablennamen mit nur einem Buchstaben wird dringend abgeraten, es sei denn, es handelt sich um einen Index in einer for-Schleife. |    Von Variablennamen mit nur einem Buchstaben wird dringend abgeraten, es sei denn, es handelt sich um einen Index in einer for-Schleife. | ||||||
| @ -402,7 +402,7 @@ Andernfalls beginnen wir mit der Erstellung eines neuen Modells. Wir empfehlen d | |||||||
| ein bestehendes Modell: | ein bestehendes Modell: | ||||||
|  |  | ||||||
| ```bash | ```bash | ||||||
| transformers add-new-model-like | transformers-cli add-new-model-like | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Sie werden mit einem Fragebogen aufgefordert, die grundlegenden Informationen Ihres Modells einzugeben. | Sie werden mit einem Fragebogen aufgefordert, die grundlegenden Informationen Ihres Modells einzugeben. | ||||||
|  | |||||||
| @ -63,7 +63,7 @@ Wenn Sie sich vergewissert haben, dass der Fehler noch nicht gemeldet wurde, geb | |||||||
| Um das Betriebssystem und die Softwareversionen automatisch auszugeben, führen Sie den folgenden Befehl aus: | Um das Betriebssystem und die Softwareversionen automatisch auszugeben, führen Sie den folgenden Befehl aus: | ||||||
|  |  | ||||||
| ```bash | ```bash | ||||||
| transformers env | transformers-cli env | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Sie können denselben Befehl auch im Hauptverzeichnis des Repositorys ausführen: | Sie können denselben Befehl auch im Hauptverzeichnis des Repositorys ausführen: | ||||||
| @ -283,6 +283,8 @@ RUN_SLOW=yes python -m pytest -n auto --dist=loadfile -s -v ./examples/pytorch/t | |||||||
| Wie bei den langsamen Tests gibt es auch andere Umgebungsvariablen, die standardmäßig beim Testen nicht gesetzt sind: | Wie bei den langsamen Tests gibt es auch andere Umgebungsvariablen, die standardmäßig beim Testen nicht gesetzt sind: | ||||||
|  |  | ||||||
| * `RUN_CUSTOM_TOKENIZERS`: Aktiviert Tests für benutzerdefinierte Tokenizer. | * `RUN_CUSTOM_TOKENIZERS`: Aktiviert Tests für benutzerdefinierte Tokenizer. | ||||||
|  | * `RUN_PT_FLAX_CROSS_TESTS`: Aktiviert Tests für die Integration von PyTorch + Flax. | ||||||
|  | * `RUN_PT_TF_CROSS_TESTS`: Aktiviert Tests für die Integration von TensorFlow + PyTorch. | ||||||
|  |  | ||||||
| Weitere Umgebungsvariablen und zusätzliche Informationen finden Sie in der [testing_utils.py](src/transformers/testing_utils.py). | Weitere Umgebungsvariablen und zusätzliche Informationen finden Sie in der [testing_utils.py](src/transformers/testing_utils.py). | ||||||
|  |  | ||||||
|  | |||||||
| @ -55,148 +55,148 @@ Die Bibliothek enthält derzeit JAX-, PyTorch- und TensorFlow-Implementierungen, | |||||||
|  |  | ||||||
| <!--This list is updated automatically from the README with _make fix-copies_. Do not update manually! --> | <!--This list is updated automatically from the README with _make fix-copies_. Do not update manually! --> | ||||||
|  |  | ||||||
| 1. **[ALBERT](model_doc/albert)** (from Google Research and the Toyota Technological Institute at Chicago) released with the paper [ALBERT: A Lite BERT for Self-supervised Learning of Language Representations](https://huggingface.co/papers/1909.11942), by Zhenzhong Lan, Mingda Chen, Sebastian Goodman, Kevin Gimpel, Piyush Sharma, Radu Soricut. | 1. **[ALBERT](model_doc/albert)** (from Google Research and the Toyota Technological Institute at Chicago) released with the paper [ALBERT: A Lite BERT for Self-supervised Learning of Language Representations](https://arxiv.org/abs/1909.11942), by Zhenzhong Lan, Mingda Chen, Sebastian Goodman, Kevin Gimpel, Piyush Sharma, Radu Soricut. | ||||||
| 1. **[ALIGN](model_doc/align)** (from Google Research) released with the paper [Scaling Up Visual and Vision-Language Representation Learning With Noisy Text Supervision](https://huggingface.co/papers/2102.05918) by Chao Jia, Yinfei Yang, Ye Xia, Yi-Ting Chen, Zarana Parekh, Hieu Pham, Quoc V. Le, Yunhsuan Sung, Zhen Li, Tom Duerig. | 1. **[ALIGN](model_doc/align)** (from Google Research) released with the paper [Scaling Up Visual and Vision-Language Representation Learning With Noisy Text Supervision](https://arxiv.org/abs/2102.05918) by Chao Jia, Yinfei Yang, Ye Xia, Yi-Ting Chen, Zarana Parekh, Hieu Pham, Quoc V. Le, Yunhsuan Sung, Zhen Li, Tom Duerig. | ||||||
| 1. **[BART](model_doc/bart)** (from Facebook) released with the paper [BART: Denoising Sequence-to-Sequence Pre-training for Natural Language Generation, Translation, and Comprehension](https://huggingface.co/papers/1910.13461) by Mike Lewis, Yinhan Liu, Naman Goyal, Marjan Ghazvininejad, Abdelrahman Mohamed, Omer Levy, Ves Stoyanov and Luke Zettlemoyer. | 1. **[BART](model_doc/bart)** (from Facebook) released with the paper [BART: Denoising Sequence-to-Sequence Pre-training for Natural Language Generation, Translation, and Comprehension](https://arxiv.org/abs/1910.13461) by Mike Lewis, Yinhan Liu, Naman Goyal, Marjan Ghazvininejad, Abdelrahman Mohamed, Omer Levy, Ves Stoyanov and Luke Zettlemoyer. | ||||||
| 1. **[BARThez](model_doc/barthez)** (from École polytechnique) released with the paper [BARThez: a Skilled Pretrained French Sequence-to-Sequence Model](https://huggingface.co/papers/2010.12321) by Moussa Kamal Eddine, Antoine J.-P. Tixier, Michalis Vazirgiannis. | 1. **[BARThez](model_doc/barthez)** (from École polytechnique) released with the paper [BARThez: a Skilled Pretrained French Sequence-to-Sequence Model](https://arxiv.org/abs/2010.12321) by Moussa Kamal Eddine, Antoine J.-P. Tixier, Michalis Vazirgiannis. | ||||||
| 1. **[BARTpho](model_doc/bartpho)** (from VinAI Research) released with the paper [BARTpho: Pre-trained Sequence-to-Sequence Models for Vietnamese](https://huggingface.co/papers/2109.09701) by Nguyen Luong Tran, Duong Minh Le and Dat Quoc Nguyen. | 1. **[BARTpho](model_doc/bartpho)** (from VinAI Research) released with the paper [BARTpho: Pre-trained Sequence-to-Sequence Models for Vietnamese](https://arxiv.org/abs/2109.09701) by Nguyen Luong Tran, Duong Minh Le and Dat Quoc Nguyen. | ||||||
| 1. **[BEiT](model_doc/beit)** (from Microsoft) released with the paper [BEiT: BERT Pre-Training of Image Transformers](https://huggingface.co/papers/2106.08254) by Hangbo Bao, Li Dong, Furu Wei. | 1. **[BEiT](model_doc/beit)** (from Microsoft) released with the paper [BEiT: BERT Pre-Training of Image Transformers](https://arxiv.org/abs/2106.08254) by Hangbo Bao, Li Dong, Furu Wei. | ||||||
| 1. **[BERT](model_doc/bert)** (from Google) released with the paper [BERT: Pre-training of Deep Bidirectional Transformers for Language Understanding](https://huggingface.co/papers/1810.04805) by Jacob Devlin, Ming-Wei Chang, Kenton Lee and Kristina Toutanova. | 1. **[BERT](model_doc/bert)** (from Google) released with the paper [BERT: Pre-training of Deep Bidirectional Transformers for Language Understanding](https://arxiv.org/abs/1810.04805) by Jacob Devlin, Ming-Wei Chang, Kenton Lee and Kristina Toutanova. | ||||||
| 1. **[BERT For Sequence Generation](model_doc/bert-generation)** (from Google) released with the paper [Leveraging Pre-trained Checkpoints for Sequence Generation Tasks](https://huggingface.co/papers/1907.12461) by Sascha Rothe, Shashi Narayan, Aliaksei Severyn. | 1. **[BERT For Sequence Generation](model_doc/bert-generation)** (from Google) released with the paper [Leveraging Pre-trained Checkpoints for Sequence Generation Tasks](https://arxiv.org/abs/1907.12461) by Sascha Rothe, Shashi Narayan, Aliaksei Severyn. | ||||||
| 1. **[BERTweet](model_doc/bertweet)** (from VinAI Research) released with the paper [BERTweet: A pre-trained language model for English Tweets](https://aclanthology.org/2020.emnlp-demos.2/) by Dat Quoc Nguyen, Thanh Vu and Anh Tuan Nguyen. | 1. **[BERTweet](model_doc/bertweet)** (from VinAI Research) released with the paper [BERTweet: A pre-trained language model for English Tweets](https://aclanthology.org/2020.emnlp-demos.2/) by Dat Quoc Nguyen, Thanh Vu and Anh Tuan Nguyen. | ||||||
| 1. **[BigBird-Pegasus](model_doc/bigbird_pegasus)** (from Google Research) released with the paper [Big Bird: Transformers for Longer Sequences](https://huggingface.co/papers/2007.14062) by Manzil Zaheer, Guru Guruganesh, Avinava Dubey, Joshua Ainslie, Chris Alberti, Santiago Ontanon, Philip Pham, Anirudh Ravula, Qifan Wang, Li Yang, Amr Ahmed. | 1. **[BigBird-Pegasus](model_doc/bigbird_pegasus)** (from Google Research) released with the paper [Big Bird: Transformers for Longer Sequences](https://arxiv.org/abs/2007.14062) by Manzil Zaheer, Guru Guruganesh, Avinava Dubey, Joshua Ainslie, Chris Alberti, Santiago Ontanon, Philip Pham, Anirudh Ravula, Qifan Wang, Li Yang, Amr Ahmed. | ||||||
| 1. **[BigBird-RoBERTa](model_doc/big_bird)** (from Google Research) released with the paper [Big Bird: Transformers for Longer Sequences](https://huggingface.co/papers/2007.14062) by Manzil Zaheer, Guru Guruganesh, Avinava Dubey, Joshua Ainslie, Chris Alberti, Santiago Ontanon, Philip Pham, Anirudh Ravula, Qifan Wang, Li Yang, Amr Ahmed. | 1. **[BigBird-RoBERTa](model_doc/big_bird)** (from Google Research) released with the paper [Big Bird: Transformers for Longer Sequences](https://arxiv.org/abs/2007.14062) by Manzil Zaheer, Guru Guruganesh, Avinava Dubey, Joshua Ainslie, Chris Alberti, Santiago Ontanon, Philip Pham, Anirudh Ravula, Qifan Wang, Li Yang, Amr Ahmed. | ||||||
| 1. **[Blenderbot](model_doc/blenderbot)** (from Facebook) released with the paper [Recipes for building an open-domain chatbot](https://huggingface.co/papers/2004.13637) by Stephen Roller, Emily Dinan, Naman Goyal, Da Ju, Mary Williamson, Yinhan Liu, Jing Xu, Myle Ott, Kurt Shuster, Eric M. Smith, Y-Lan Boureau, Jason Weston. | 1. **[Blenderbot](model_doc/blenderbot)** (from Facebook) released with the paper [Recipes for building an open-domain chatbot](https://arxiv.org/abs/2004.13637) by Stephen Roller, Emily Dinan, Naman Goyal, Da Ju, Mary Williamson, Yinhan Liu, Jing Xu, Myle Ott, Kurt Shuster, Eric M. Smith, Y-Lan Boureau, Jason Weston. | ||||||
| 1. **[BlenderbotSmall](model_doc/blenderbot-small)** (from Facebook) released with the paper [Recipes for building an open-domain chatbot](https://huggingface.co/papers/2004.13637) by Stephen Roller, Emily Dinan, Naman Goyal, Da Ju, Mary Williamson, Yinhan Liu, Jing Xu, Myle Ott, Kurt Shuster, Eric M. Smith, Y-Lan Boureau, Jason Weston. | 1. **[BlenderbotSmall](model_doc/blenderbot-small)** (from Facebook) released with the paper [Recipes for building an open-domain chatbot](https://arxiv.org/abs/2004.13637) by Stephen Roller, Emily Dinan, Naman Goyal, Da Ju, Mary Williamson, Yinhan Liu, Jing Xu, Myle Ott, Kurt Shuster, Eric M. Smith, Y-Lan Boureau, Jason Weston. | ||||||
| 1. **[BLOOM](model_doc/bloom)** (from BigScience workshop) released by the [BigScience Workshop](https://bigscience.huggingface.co/). | 1. **[BLOOM](model_doc/bloom)** (from BigScience workshop) released by the [BigScience Workshop](https://bigscience.huggingface.co/). | ||||||
| 1. **[BORT](model_doc/bort)** (from Alexa) released with the paper [Optimal Subarchitecture Extraction For BERT](https://huggingface.co/papers/2010.10499) by Adrian de Wynter and Daniel J. Perry. | 1. **[BORT](model_doc/bort)** (from Alexa) released with the paper [Optimal Subarchitecture Extraction For BERT](https://arxiv.org/abs/2010.10499) by Adrian de Wynter and Daniel J. Perry. | ||||||
| 1. **[ByT5](model_doc/byt5)** (from Google Research) released with the paper [ByT5: Towards a token-free future with pre-trained byte-to-byte models](https://huggingface.co/papers/2105.13626) by Linting Xue, Aditya Barua, Noah Constant, Rami Al-Rfou, Sharan Narang, Mihir Kale, Adam Roberts, Colin Raffel. | 1. **[ByT5](model_doc/byt5)** (from Google Research) released with the paper [ByT5: Towards a token-free future with pre-trained byte-to-byte models](https://arxiv.org/abs/2105.13626) by Linting Xue, Aditya Barua, Noah Constant, Rami Al-Rfou, Sharan Narang, Mihir Kale, Adam Roberts, Colin Raffel. | ||||||
| 1. **[CamemBERT](model_doc/camembert)** (from Inria/Facebook/Sorbonne) released with the paper [CamemBERT: a Tasty French Language Model](https://huggingface.co/papers/1911.03894) by Louis Martin*, Benjamin Muller*, Pedro Javier Ortiz Suárez*, Yoann Dupont, Laurent Romary, Éric Villemonte de la Clergerie, Djamé Seddah and Benoît Sagot. | 1. **[CamemBERT](model_doc/camembert)** (from Inria/Facebook/Sorbonne) released with the paper [CamemBERT: a Tasty French Language Model](https://arxiv.org/abs/1911.03894) by Louis Martin*, Benjamin Muller*, Pedro Javier Ortiz Suárez*, Yoann Dupont, Laurent Romary, Éric Villemonte de la Clergerie, Djamé Seddah and Benoît Sagot. | ||||||
| 1. **[CANINE](model_doc/canine)** (from Google Research) released with the paper [CANINE: Pre-training an Efficient Tokenization-Free Encoder for Language Representation](https://huggingface.co/papers/2103.06874) by Jonathan H. Clark, Dan Garrette, Iulia Turc, John Wieting. | 1. **[CANINE](model_doc/canine)** (from Google Research) released with the paper [CANINE: Pre-training an Efficient Tokenization-Free Encoder for Language Representation](https://arxiv.org/abs/2103.06874) by Jonathan H. Clark, Dan Garrette, Iulia Turc, John Wieting. | ||||||
| 1. **[CLIP](model_doc/clip)** (from OpenAI) released with the paper [Learning Transferable Visual Models From Natural Language Supervision](https://huggingface.co/papers/2103.00020) by Alec Radford, Jong Wook Kim, Chris Hallacy, Aditya Ramesh, Gabriel Goh, Sandhini Agarwal, Girish Sastry, Amanda Askell, Pamela Mishkin, Jack Clark, Gretchen Krueger, Ilya Sutskever. | 1. **[CLIP](model_doc/clip)** (from OpenAI) released with the paper [Learning Transferable Visual Models From Natural Language Supervision](https://arxiv.org/abs/2103.00020) by Alec Radford, Jong Wook Kim, Chris Hallacy, Aditya Ramesh, Gabriel Goh, Sandhini Agarwal, Girish Sastry, Amanda Askell, Pamela Mishkin, Jack Clark, Gretchen Krueger, Ilya Sutskever. | ||||||
| 1. **[CodeGen](model_doc/codegen)** (from Salesforce) released with the paper [A Conversational Paradigm for Program Synthesis](https://huggingface.co/papers/2203.13474) by Erik Nijkamp, Bo Pang, Hiroaki Hayashi, Lifu Tu, Huan Wang, Yingbo Zhou, Silvio Savarese, Caiming Xiong. | 1. **[CodeGen](model_doc/codegen)** (from Salesforce) released with the paper [A Conversational Paradigm for Program Synthesis](https://arxiv.org/abs/2203.13474) by Erik Nijkamp, Bo Pang, Hiroaki Hayashi, Lifu Tu, Huan Wang, Yingbo Zhou, Silvio Savarese, Caiming Xiong. | ||||||
| 1. **[ConvBERT](model_doc/convbert)** (from YituTech) released with the paper [ConvBERT: Improving BERT with Span-based Dynamic Convolution](https://huggingface.co/papers/2008.02496) by Zihang Jiang, Weihao Yu, Daquan Zhou, Yunpeng Chen, Jiashi Feng, Shuicheng Yan. | 1. **[ConvBERT](model_doc/convbert)** (from YituTech) released with the paper [ConvBERT: Improving BERT with Span-based Dynamic Convolution](https://arxiv.org/abs/2008.02496) by Zihang Jiang, Weihao Yu, Daquan Zhou, Yunpeng Chen, Jiashi Feng, Shuicheng Yan. | ||||||
| 1. **[ConvNeXT](model_doc/convnext)** (from Facebook AI) released with the paper [A ConvNet for the 2020s](https://huggingface.co/papers/2201.03545) by Zhuang Liu, Hanzi Mao, Chao-Yuan Wu, Christoph Feichtenhofer, Trevor Darrell, Saining Xie. | 1. **[ConvNeXT](model_doc/convnext)** (from Facebook AI) released with the paper [A ConvNet for the 2020s](https://arxiv.org/abs/2201.03545) by Zhuang Liu, Hanzi Mao, Chao-Yuan Wu, Christoph Feichtenhofer, Trevor Darrell, Saining Xie. | ||||||
| 1. **[ConvNeXTV2](model_doc/convnextv2)** (from Facebook AI) released with the paper [ConvNeXt V2: Co-designing and Scaling ConvNets with Masked Autoencoders](https://huggingface.co/papers/2301.00808) by Sanghyun Woo, Shoubhik Debnath, Ronghang Hu, Xinlei Chen, Zhuang Liu, In So Kweon, Saining Xie. | 1. **[ConvNeXTV2](model_doc/convnextv2)** (from Facebook AI) released with the paper [ConvNeXt V2: Co-designing and Scaling ConvNets with Masked Autoencoders](https://arxiv.org/abs/2301.00808) by Sanghyun Woo, Shoubhik Debnath, Ronghang Hu, Xinlei Chen, Zhuang Liu, In So Kweon, Saining Xie. | ||||||
| 1. **[CPM](model_doc/cpm)** (from Tsinghua University) released with the paper [CPM: A Large-scale Generative Chinese Pre-trained Language Model](https://huggingface.co/papers/2012.00413) by Zhengyan Zhang, Xu Han, Hao Zhou, Pei Ke, Yuxian Gu, Deming Ye, Yujia Qin, Yusheng Su, Haozhe Ji, Jian Guan, Fanchao Qi, Xiaozhi Wang, Yanan Zheng, Guoyang Zeng, Huanqi Cao, Shengqi Chen, Daixuan Li, Zhenbo Sun, Zhiyuan Liu, Minlie Huang, Wentao Han, Jie Tang, Juanzi Li, Xiaoyan Zhu, Maosong Sun. | 1. **[CPM](model_doc/cpm)** (from Tsinghua University) released with the paper [CPM: A Large-scale Generative Chinese Pre-trained Language Model](https://arxiv.org/abs/2012.00413) by Zhengyan Zhang, Xu Han, Hao Zhou, Pei Ke, Yuxian Gu, Deming Ye, Yujia Qin, Yusheng Su, Haozhe Ji, Jian Guan, Fanchao Qi, Xiaozhi Wang, Yanan Zheng, Guoyang Zeng, Huanqi Cao, Shengqi Chen, Daixuan Li, Zhenbo Sun, Zhiyuan Liu, Minlie Huang, Wentao Han, Jie Tang, Juanzi Li, Xiaoyan Zhu, Maosong Sun. | ||||||
| 1. **[CTRL](model_doc/ctrl)** (from Salesforce) released with the paper [CTRL: A Conditional Transformer Language Model for Controllable Generation](https://huggingface.co/papers/1909.05858) by Nitish Shirish Keskar*, Bryan McCann*, Lav R. Varshney, Caiming Xiong and Richard Socher. | 1. **[CTRL](model_doc/ctrl)** (from Salesforce) released with the paper [CTRL: A Conditional Transformer Language Model for Controllable Generation](https://arxiv.org/abs/1909.05858) by Nitish Shirish Keskar*, Bryan McCann*, Lav R. Varshney, Caiming Xiong and Richard Socher. | ||||||
| 1. **[CvT](model_doc/cvt)** (from Microsoft) released with the paper [CvT: Introducing Convolutions to Vision Transformers](https://huggingface.co/papers/2103.15808) by Haiping Wu, Bin Xiao, Noel Codella, Mengchen Liu, Xiyang Dai, Lu Yuan, Lei Zhang. | 1. **[CvT](model_doc/cvt)** (from Microsoft) released with the paper [CvT: Introducing Convolutions to Vision Transformers](https://arxiv.org/abs/2103.15808) by Haiping Wu, Bin Xiao, Noel Codella, Mengchen Liu, Xiyang Dai, Lu Yuan, Lei Zhang. | ||||||
| 1. **[Data2Vec](model_doc/data2vec)** (from Facebook) released with the paper [Data2Vec:  A General Framework for Self-supervised Learning in Speech, Vision and Language](https://huggingface.co/papers/2202.03555) by Alexei Baevski, Wei-Ning Hsu, Qiantong Xu, Arun Babu, Jiatao Gu, Michael Auli. | 1. **[Data2Vec](model_doc/data2vec)** (from Facebook) released with the paper [Data2Vec:  A General Framework for Self-supervised Learning in Speech, Vision and Language](https://arxiv.org/abs/2202.03555) by Alexei Baevski, Wei-Ning Hsu, Qiantong Xu, Arun Babu, Jiatao Gu, Michael Auli. | ||||||
| 1. **[DeBERTa](model_doc/deberta)** (from Microsoft) released with the paper [DeBERTa: Decoding-enhanced BERT with Disentangled Attention](https://huggingface.co/papers/2006.03654) by Pengcheng He, Xiaodong Liu, Jianfeng Gao, Weizhu Chen. | 1. **[DeBERTa](model_doc/deberta)** (from Microsoft) released with the paper [DeBERTa: Decoding-enhanced BERT with Disentangled Attention](https://arxiv.org/abs/2006.03654) by Pengcheng He, Xiaodong Liu, Jianfeng Gao, Weizhu Chen. | ||||||
| 1. **[DeBERTa-v2](model_doc/deberta-v2)** (from Microsoft) released with the paper [DeBERTa: Decoding-enhanced BERT with Disentangled Attention](https://huggingface.co/papers/2006.03654) by Pengcheng He, Xiaodong Liu, Jianfeng Gao, Weizhu Chen. | 1. **[DeBERTa-v2](model_doc/deberta-v2)** (from Microsoft) released with the paper [DeBERTa: Decoding-enhanced BERT with Disentangled Attention](https://arxiv.org/abs/2006.03654) by Pengcheng He, Xiaodong Liu, Jianfeng Gao, Weizhu Chen. | ||||||
| 1. **[Decision Transformer](model_doc/decision_transformer)** (from Berkeley/Facebook/Google) released with the paper [Decision Transformer: Reinforcement Learning via Sequence Modeling](https://huggingface.co/papers/2106.01345) by Lili Chen, Kevin Lu, Aravind Rajeswaran, Kimin Lee, Aditya Grover, Michael Laskin, Pieter Abbeel, Aravind Srinivas, Igor Mordatch. | 1. **[Decision Transformer](model_doc/decision_transformer)** (from Berkeley/Facebook/Google) released with the paper [Decision Transformer: Reinforcement Learning via Sequence Modeling](https://arxiv.org/abs/2106.01345) by Lili Chen, Kevin Lu, Aravind Rajeswaran, Kimin Lee, Aditya Grover, Michael Laskin, Pieter Abbeel, Aravind Srinivas, Igor Mordatch. | ||||||
| 1. **[DeiT](model_doc/deit)** (from Facebook) released with the paper [Training data-efficient image transformers & distillation through attention](https://huggingface.co/papers/2012.12877) by Hugo Touvron, Matthieu Cord, Matthijs Douze, Francisco Massa, Alexandre Sablayrolles, Hervé Jégou. | 1. **[DeiT](model_doc/deit)** (from Facebook) released with the paper [Training data-efficient image transformers & distillation through attention](https://arxiv.org/abs/2012.12877) by Hugo Touvron, Matthieu Cord, Matthijs Douze, Francisco Massa, Alexandre Sablayrolles, Hervé Jégou. | ||||||
| 1. **[DETR](model_doc/detr)** (from Facebook) released with the paper [End-to-End Object Detection with Transformers](https://huggingface.co/papers/2005.12872) by Nicolas Carion, Francisco Massa, Gabriel Synnaeve, Nicolas Usunier, Alexander Kirillov, Sergey Zagoruyko. | 1. **[DETR](model_doc/detr)** (from Facebook) released with the paper [End-to-End Object Detection with Transformers](https://arxiv.org/abs/2005.12872) by Nicolas Carion, Francisco Massa, Gabriel Synnaeve, Nicolas Usunier, Alexander Kirillov, Sergey Zagoruyko. | ||||||
| 1. **[DialoGPT](model_doc/dialogpt)** (from Microsoft Research) released with the paper [DialoGPT: Large-Scale Generative Pre-training for Conversational Response Generation](https://huggingface.co/papers/1911.00536) by Yizhe Zhang, Siqi Sun, Michel Galley, Yen-Chun Chen, Chris Brockett, Xiang Gao, Jianfeng Gao, Jingjing Liu, Bill Dolan. | 1. **[DialoGPT](model_doc/dialogpt)** (from Microsoft Research) released with the paper [DialoGPT: Large-Scale Generative Pre-training for Conversational Response Generation](https://arxiv.org/abs/1911.00536) by Yizhe Zhang, Siqi Sun, Michel Galley, Yen-Chun Chen, Chris Brockett, Xiang Gao, Jianfeng Gao, Jingjing Liu, Bill Dolan. | ||||||
| 1. **[DistilBERT](model_doc/distilbert)** (from HuggingFace), released together with the paper [DistilBERT, a distilled version of BERT: smaller, faster, cheaper and lighter](https://huggingface.co/papers/1910.01108) by Victor Sanh, Lysandre Debut and Thomas Wolf. The same method has been applied to compress GPT2 into [DistilGPT2](https://github.com/huggingface/transformers-research-projects/tree/main/distillation), RoBERTa into [DistilRoBERTa](https://github.com/huggingface/transformers-research-projects/tree/main/distillation), Multilingual BERT into [DistilmBERT](https://github.com/huggingface/transformers-research-projects/tree/main/distillation) and a German version of DistilBERT. | 1. **[DistilBERT](model_doc/distilbert)** (from HuggingFace), released together with the paper [DistilBERT, a distilled version of BERT: smaller, faster, cheaper and lighter](https://arxiv.org/abs/1910.01108) by Victor Sanh, Lysandre Debut and Thomas Wolf. The same method has been applied to compress GPT2 into [DistilGPT2](https://github.com/huggingface/transformers/tree/main/examples/research_projects/distillation), RoBERTa into [DistilRoBERTa](https://github.com/huggingface/transformers/tree/main/examples/research_projects/distillation), Multilingual BERT into [DistilmBERT](https://github.com/huggingface/transformers/tree/main/examples/research_projects/distillation) and a German version of DistilBERT. | ||||||
| 1. **[DiT](model_doc/dit)** (from Microsoft Research) released with the paper [DiT: Self-supervised Pre-training for Document Image Transformer](https://huggingface.co/papers/2203.02378) by Junlong Li, Yiheng Xu, Tengchao Lv, Lei Cui, Cha Zhang, Furu Wei. | 1. **[DiT](model_doc/dit)** (from Microsoft Research) released with the paper [DiT: Self-supervised Pre-training for Document Image Transformer](https://arxiv.org/abs/2203.02378) by Junlong Li, Yiheng Xu, Tengchao Lv, Lei Cui, Cha Zhang, Furu Wei. | ||||||
| 1. **[DPR](model_doc/dpr)** (from Facebook) released with the paper [Dense Passage Retrieval for Open-Domain Question Answering](https://huggingface.co/papers/2004.04906) by Vladimir Karpukhin, Barlas Oğuz, Sewon Min, Patrick Lewis, Ledell Wu, Sergey Edunov, Danqi Chen, and Wen-tau Yih. | 1. **[DPR](model_doc/dpr)** (from Facebook) released with the paper [Dense Passage Retrieval for Open-Domain Question Answering](https://arxiv.org/abs/2004.04906) by Vladimir Karpukhin, Barlas Oğuz, Sewon Min, Patrick Lewis, Ledell Wu, Sergey Edunov, Danqi Chen, and Wen-tau Yih. | ||||||
| 1. **[DPT](master/model_doc/dpt)** (from Intel Labs) released with the paper [Vision Transformers for Dense Prediction](https://huggingface.co/papers/2103.13413) by René Ranftl, Alexey Bochkovskiy, Vladlen Koltun. | 1. **[DPT](master/model_doc/dpt)** (from Intel Labs) released with the paper [Vision Transformers for Dense Prediction](https://arxiv.org/abs/2103.13413) by René Ranftl, Alexey Bochkovskiy, Vladlen Koltun. | ||||||
| 1. **[EfficientNet](model_doc/efficientnet)** (from Google Research) released with the paper [EfficientNet: Rethinking Model Scaling for Convolutional Neural Networks](https://huggingface.co/papers/1905.11946)  by Mingxing Tan and Quoc V. Le. | 1. **[EfficientNet](model_doc/efficientnet)** (from Google Research) released with the paper [EfficientNet: Rethinking Model Scaling for Convolutional Neural Networks](https://arxiv.org/abs/1905.11946)  by Mingxing Tan and Quoc V. Le. | ||||||
| 1. **[ELECTRA](model_doc/electra)** (from Google Research/Stanford University) released with the paper [ELECTRA: Pre-training text encoders as discriminators rather than generators](https://huggingface.co/papers/2003.10555) by Kevin Clark, Minh-Thang Luong, Quoc V. Le, Christopher D. Manning. | 1. **[ELECTRA](model_doc/electra)** (from Google Research/Stanford University) released with the paper [ELECTRA: Pre-training text encoders as discriminators rather than generators](https://arxiv.org/abs/2003.10555) by Kevin Clark, Minh-Thang Luong, Quoc V. Le, Christopher D. Manning. | ||||||
| 1. **[EncoderDecoder](model_doc/encoder-decoder)** (from Google Research) released with the paper [Leveraging Pre-trained Checkpoints for Sequence Generation Tasks](https://huggingface.co/papers/1907.12461) by Sascha Rothe, Shashi Narayan, Aliaksei Severyn. | 1. **[EncoderDecoder](model_doc/encoder-decoder)** (from Google Research) released with the paper [Leveraging Pre-trained Checkpoints for Sequence Generation Tasks](https://arxiv.org/abs/1907.12461) by Sascha Rothe, Shashi Narayan, Aliaksei Severyn. | ||||||
| 1. **[FlauBERT](model_doc/flaubert)** (from CNRS) released with the paper [FlauBERT: Unsupervised Language Model Pre-training for French](https://huggingface.co/papers/1912.05372) by Hang Le, Loïc Vial, Jibril Frej, Vincent Segonne, Maximin Coavoux, Benjamin Lecouteux, Alexandre Allauzen, Benoît Crabbé, Laurent Besacier, Didier Schwab. | 1. **[FlauBERT](model_doc/flaubert)** (from CNRS) released with the paper [FlauBERT: Unsupervised Language Model Pre-training for French](https://arxiv.org/abs/1912.05372) by Hang Le, Loïc Vial, Jibril Frej, Vincent Segonne, Maximin Coavoux, Benjamin Lecouteux, Alexandre Allauzen, Benoît Crabbé, Laurent Besacier, Didier Schwab. | ||||||
| 1. **[FLAVA](model_doc/flava)** (from Facebook AI) released with the paper [FLAVA: A Foundational Language And Vision Alignment Model](https://huggingface.co/papers/2112.04482) by Amanpreet Singh, Ronghang Hu, Vedanuj Goswami, Guillaume Couairon, Wojciech Galuba, Marcus Rohrbach, and Douwe Kiela. | 1. **[FLAVA](model_doc/flava)** (from Facebook AI) released with the paper [FLAVA: A Foundational Language And Vision Alignment Model](https://arxiv.org/abs/2112.04482) by Amanpreet Singh, Ronghang Hu, Vedanuj Goswami, Guillaume Couairon, Wojciech Galuba, Marcus Rohrbach, and Douwe Kiela. | ||||||
| 1. **[FNet](model_doc/fnet)** (from Google Research) released with the paper [FNet: Mixing Tokens with Fourier Transforms](https://huggingface.co/papers/2105.03824) by James Lee-Thorp, Joshua Ainslie, Ilya Eckstein, Santiago Ontanon. | 1. **[FNet](model_doc/fnet)** (from Google Research) released with the paper [FNet: Mixing Tokens with Fourier Transforms](https://arxiv.org/abs/2105.03824) by James Lee-Thorp, Joshua Ainslie, Ilya Eckstein, Santiago Ontanon. | ||||||
| 1. **[Funnel Transformer](model_doc/funnel)** (from CMU/Google Brain) released with the paper [Funnel-Transformer: Filtering out Sequential Redundancy for Efficient Language Processing](https://huggingface.co/papers/2006.03236) by Zihang Dai, Guokun Lai, Yiming Yang, Quoc V. Le. | 1. **[Funnel Transformer](model_doc/funnel)** (from CMU/Google Brain) released with the paper [Funnel-Transformer: Filtering out Sequential Redundancy for Efficient Language Processing](https://arxiv.org/abs/2006.03236) by Zihang Dai, Guokun Lai, Yiming Yang, Quoc V. Le. | ||||||
| 1. **[GLPN](model_doc/glpn)** (from KAIST) released with the paper [Global-Local Path Networks for Monocular Depth Estimation with Vertical CutDepth](https://huggingface.co/papers/2201.07436) by Doyeon Kim, Woonghyun Ga, Pyungwhan Ahn, Donggyu Joo, Sehwan Chun, Junmo Kim. | 1. **[GLPN](model_doc/glpn)** (from KAIST) released with the paper [Global-Local Path Networks for Monocular Depth Estimation with Vertical CutDepth](https://arxiv.org/abs/2201.07436) by Doyeon Kim, Woonghyun Ga, Pyungwhan Ahn, Donggyu Joo, Sehwan Chun, Junmo Kim. | ||||||
| 1. **[GPT](model_doc/openai-gpt)** (from OpenAI) released with the paper [Improving Language Understanding by Generative Pre-Training](https://openai.com/research/language-unsupervised/) by Alec Radford, Karthik Narasimhan, Tim Salimans and Ilya Sutskever. | 1. **[GPT](model_doc/openai-gpt)** (from OpenAI) released with the paper [Improving Language Understanding by Generative Pre-Training](https://openai.com/research/language-unsupervised/) by Alec Radford, Karthik Narasimhan, Tim Salimans and Ilya Sutskever. | ||||||
| 1. **[GPT Neo](model_doc/gpt_neo)** (from EleutherAI) released in the repository [EleutherAI/gpt-neo](https://github.com/EleutherAI/gpt-neo) by Sid Black, Stella Biderman, Leo Gao, Phil Wang and Connor Leahy. | 1. **[GPT Neo](model_doc/gpt_neo)** (from EleutherAI) released in the repository [EleutherAI/gpt-neo](https://github.com/EleutherAI/gpt-neo) by Sid Black, Stella Biderman, Leo Gao, Phil Wang and Connor Leahy. | ||||||
| 1. **[GPT NeoX](model_doc/gpt_neox)** (from EleutherAI) released with the paper [GPT-NeoX-20B: An Open-Source Autoregressive Language Model](https://huggingface.co/papers/2204.06745) by Sid Black, Stella Biderman, Eric Hallahan, Quentin Anthony, Leo Gao, Laurence Golding, Horace He, Connor Leahy, Kyle McDonell, Jason Phang, Michael Pieler, USVSN Sai Prashanth, Shivanshu Purohit, Laria Reynolds, Jonathan Tow, Ben Wang, Samuel Weinbach | 1. **[GPT NeoX](model_doc/gpt_neox)** (from EleutherAI) released with the paper [GPT-NeoX-20B: An Open-Source Autoregressive Language Model](https://arxiv.org/abs/2204.06745) by Sid Black, Stella Biderman, Eric Hallahan, Quentin Anthony, Leo Gao, Laurence Golding, Horace He, Connor Leahy, Kyle McDonell, Jason Phang, Michael Pieler, USVSN Sai Prashanth, Shivanshu Purohit, Laria Reynolds, Jonathan Tow, Ben Wang, Samuel Weinbach | ||||||
| 1. **[GPT-2](model_doc/gpt2)** (from OpenAI) released with the paper [Language Models are Unsupervised Multitask Learners](https://openai.com/research/better-language-models/) by Alec Radford, Jeffrey Wu, Rewon Child, David Luan, Dario Amodei and Ilya Sutskever. | 1. **[GPT-2](model_doc/gpt2)** (from OpenAI) released with the paper [Language Models are Unsupervised Multitask Learners](https://openai.com/research/better-language-models/) by Alec Radford, Jeffrey Wu, Rewon Child, David Luan, Dario Amodei and Ilya Sutskever. | ||||||
| 1. **[GPT-J](model_doc/gptj)** (from EleutherAI) released in the repository [kingoflolz/mesh-transformer-jax](https://github.com/kingoflolz/mesh-transformer-jax/) by Ben Wang and Aran Komatsuzaki. | 1. **[GPT-J](model_doc/gptj)** (from EleutherAI) released in the repository [kingoflolz/mesh-transformer-jax](https://github.com/kingoflolz/mesh-transformer-jax/) by Ben Wang and Aran Komatsuzaki. | ||||||
| 1. **[GPTSAN-japanese](model_doc/gptsan-japanese)** released in the repository [tanreinama/GPTSAN](https://github.com/tanreinama/GPTSAN/blob/main/report/model.md) by Toshiyuki Sakamoto(tanreinama). | 1. **[GPTSAN-japanese](model_doc/gptsan-japanese)** released in the repository [tanreinama/GPTSAN](https://github.com/tanreinama/GPTSAN/blob/main/report/model.md) by Toshiyuki Sakamoto(tanreinama). | ||||||
| 1. **[GroupViT](model_doc/groupvit)** (from UCSD, NVIDIA) released with the paper [GroupViT: Semantic Segmentation Emerges from Text Supervision](https://huggingface.co/papers/2202.11094) by Jiarui Xu, Shalini De Mello, Sifei Liu, Wonmin Byeon, Thomas Breuel, Jan Kautz, Xiaolong Wang. | 1. **[GroupViT](model_doc/groupvit)** (from UCSD, NVIDIA) released with the paper [GroupViT: Semantic Segmentation Emerges from Text Supervision](https://arxiv.org/abs/2202.11094) by Jiarui Xu, Shalini De Mello, Sifei Liu, Wonmin Byeon, Thomas Breuel, Jan Kautz, Xiaolong Wang. | ||||||
| 1. **[Hubert](model_doc/hubert)** (from Facebook) released with the paper [HuBERT: Self-Supervised Speech Representation Learning by Masked Prediction of Hidden Units](https://huggingface.co/papers/2106.07447) by Wei-Ning Hsu, Benjamin Bolte, Yao-Hung Hubert Tsai, Kushal Lakhotia, Ruslan Salakhutdinov, Abdelrahman Mohamed. | 1. **[Hubert](model_doc/hubert)** (from Facebook) released with the paper [HuBERT: Self-Supervised Speech Representation Learning by Masked Prediction of Hidden Units](https://arxiv.org/abs/2106.07447) by Wei-Ning Hsu, Benjamin Bolte, Yao-Hung Hubert Tsai, Kushal Lakhotia, Ruslan Salakhutdinov, Abdelrahman Mohamed. | ||||||
| 1. **[I-BERT](model_doc/ibert)** (from Berkeley) released with the paper [I-BERT: Integer-only BERT Quantization](https://huggingface.co/papers/2101.01321) by Sehoon Kim, Amir Gholami, Zhewei Yao, Michael W. Mahoney, Kurt Keutzer. | 1. **[I-BERT](model_doc/ibert)** (from Berkeley) released with the paper [I-BERT: Integer-only BERT Quantization](https://arxiv.org/abs/2101.01321) by Sehoon Kim, Amir Gholami, Zhewei Yao, Michael W. Mahoney, Kurt Keutzer. | ||||||
| 1. **[ImageGPT](model_doc/imagegpt)** (from OpenAI) released with the paper [Generative Pretraining from Pixels](https://openai.com/blog/image-gpt/) by Mark Chen, Alec Radford, Rewon Child, Jeffrey Wu, Heewoo Jun, David Luan, Ilya Sutskever. | 1. **[ImageGPT](model_doc/imagegpt)** (from OpenAI) released with the paper [Generative Pretraining from Pixels](https://openai.com/blog/image-gpt/) by Mark Chen, Alec Radford, Rewon Child, Jeffrey Wu, Heewoo Jun, David Luan, Ilya Sutskever. | ||||||
| 1. **[LayoutLM](model_doc/layoutlm)** (from Microsoft Research Asia) released with the paper [LayoutLM: Pre-training of Text and Layout for Document Image Understanding](https://huggingface.co/papers/1912.13318) by Yiheng Xu, Minghao Li, Lei Cui, Shaohan Huang, Furu Wei, Ming Zhou. | 1. **[LayoutLM](model_doc/layoutlm)** (from Microsoft Research Asia) released with the paper [LayoutLM: Pre-training of Text and Layout for Document Image Understanding](https://arxiv.org/abs/1912.13318) by Yiheng Xu, Minghao Li, Lei Cui, Shaohan Huang, Furu Wei, Ming Zhou. | ||||||
| 1. **[LayoutLMv2](model_doc/layoutlmv2)** (from Microsoft Research Asia) released with the paper [LayoutLMv2: Multi-modal Pre-training for Visually-Rich Document Understanding](https://huggingface.co/papers/2012.14740) by Yang Xu, Yiheng Xu, Tengchao Lv, Lei Cui, Furu Wei, Guoxin Wang, Yijuan Lu, Dinei Florencio, Cha Zhang, Wanxiang Che, Min Zhang, Lidong Zhou. | 1. **[LayoutLMv2](model_doc/layoutlmv2)** (from Microsoft Research Asia) released with the paper [LayoutLMv2: Multi-modal Pre-training for Visually-Rich Document Understanding](https://arxiv.org/abs/2012.14740) by Yang Xu, Yiheng Xu, Tengchao Lv, Lei Cui, Furu Wei, Guoxin Wang, Yijuan Lu, Dinei Florencio, Cha Zhang, Wanxiang Che, Min Zhang, Lidong Zhou. | ||||||
| 1. **[LayoutLMv3](model_doc/layoutlmv3)** (from Microsoft Research Asia) released with the paper [LayoutLMv3: Pre-training for Document AI with Unified Text and Image Masking](https://huggingface.co/papers/2204.08387) by Yupan Huang, Tengchao Lv, Lei Cui, Yutong Lu, Furu Wei. | 1. **[LayoutLMv3](model_doc/layoutlmv3)** (from Microsoft Research Asia) released with the paper [LayoutLMv3: Pre-training for Document AI with Unified Text and Image Masking](https://arxiv.org/abs/2204.08387) by Yupan Huang, Tengchao Lv, Lei Cui, Yutong Lu, Furu Wei. | ||||||
| 1. **[LayoutXLM](model_doc/layoutxlm)** (from Microsoft Research Asia) released with the paper [LayoutXLM: Multimodal Pre-training for Multilingual Visually-rich Document Understanding](https://huggingface.co/papers/2104.08836) by Yiheng Xu, Tengchao Lv, Lei Cui, Guoxin Wang, Yijuan Lu, Dinei Florencio, Cha Zhang, Furu Wei. | 1. **[LayoutXLM](model_doc/layoutxlm)** (from Microsoft Research Asia) released with the paper [LayoutXLM: Multimodal Pre-training for Multilingual Visually-rich Document Understanding](https://arxiv.org/abs/2104.08836) by Yiheng Xu, Tengchao Lv, Lei Cui, Guoxin Wang, Yijuan Lu, Dinei Florencio, Cha Zhang, Furu Wei. | ||||||
| 1. **[LED](model_doc/led)** (from AllenAI) released with the paper [Longformer: The Long-Document Transformer](https://huggingface.co/papers/2004.05150) by Iz Beltagy, Matthew E. Peters, Arman Cohan. | 1. **[LED](model_doc/led)** (from AllenAI) released with the paper [Longformer: The Long-Document Transformer](https://arxiv.org/abs/2004.05150) by Iz Beltagy, Matthew E. Peters, Arman Cohan. | ||||||
| 1. **[LeViT](model_doc/levit)** (from Meta AI) released with the paper [LeViT: A Vision Transformer in ConvNet's Clothing for Faster Inference](https://huggingface.co/papers/2104.01136) by Ben Graham, Alaaeldin El-Nouby, Hugo Touvron, Pierre Stock, Armand Joulin, Hervé Jégou, Matthijs Douze. | 1. **[LeViT](model_doc/levit)** (from Meta AI) released with the paper [LeViT: A Vision Transformer in ConvNet's Clothing for Faster Inference](https://arxiv.org/abs/2104.01136) by Ben Graham, Alaaeldin El-Nouby, Hugo Touvron, Pierre Stock, Armand Joulin, Hervé Jégou, Matthijs Douze. | ||||||
| 1. **[Longformer](model_doc/longformer)** (from AllenAI) released with the paper [Longformer: The Long-Document Transformer](https://huggingface.co/papers/2004.05150) by Iz Beltagy, Matthew E. Peters, Arman Cohan. | 1. **[Longformer](model_doc/longformer)** (from AllenAI) released with the paper [Longformer: The Long-Document Transformer](https://arxiv.org/abs/2004.05150) by Iz Beltagy, Matthew E. Peters, Arman Cohan. | ||||||
| 1. **[LongT5](model_doc/longt5)** (from Google AI) released with the paper [LongT5: Efficient Text-To-Text Transformer for Long Sequences](https://huggingface.co/papers/2112.07916) by Mandy Guo, Joshua Ainslie, David Uthus, Santiago Ontanon, Jianmo Ni, Yun-Hsuan Sung, Yinfei Yang. | 1. **[LongT5](model_doc/longt5)** (from Google AI) released with the paper [LongT5: Efficient Text-To-Text Transformer for Long Sequences](https://arxiv.org/abs/2112.07916) by Mandy Guo, Joshua Ainslie, David Uthus, Santiago Ontanon, Jianmo Ni, Yun-Hsuan Sung, Yinfei Yang. | ||||||
| 1. **[LUKE](model_doc/luke)** (from Studio Ousia) released with the paper [LUKE: Deep Contextualized Entity Representations with Entity-aware Self-attention](https://huggingface.co/papers/2010.01057) by Ikuya Yamada, Akari Asai, Hiroyuki Shindo, Hideaki Takeda, Yuji Matsumoto. | 1. **[LUKE](model_doc/luke)** (from Studio Ousia) released with the paper [LUKE: Deep Contextualized Entity Representations with Entity-aware Self-attention](https://arxiv.org/abs/2010.01057) by Ikuya Yamada, Akari Asai, Hiroyuki Shindo, Hideaki Takeda, Yuji Matsumoto. | ||||||
| 1. **[LXMERT](model_doc/lxmert)** (from UNC Chapel Hill) released with the paper [LXMERT: Learning Cross-Modality Encoder Representations from Transformers for Open-Domain Question Answering](https://huggingface.co/papers/1908.07490) by Hao Tan and Mohit Bansal. | 1. **[LXMERT](model_doc/lxmert)** (from UNC Chapel Hill) released with the paper [LXMERT: Learning Cross-Modality Encoder Representations from Transformers for Open-Domain Question Answering](https://arxiv.org/abs/1908.07490) by Hao Tan and Mohit Bansal. | ||||||
| 1. **[M-CTC-T](model_doc/mctct)** (from Facebook) released with the paper [Pseudo-Labeling For Massively Multilingual Speech Recognition](https://huggingface.co/papers/2111.00161) by Loren Lugosch, Tatiana Likhomanenko, Gabriel Synnaeve, and Ronan Collobert. | 1. **[M-CTC-T](model_doc/mctct)** (from Facebook) released with the paper [Pseudo-Labeling For Massively Multilingual Speech Recognition](https://arxiv.org/abs/2111.00161) by Loren Lugosch, Tatiana Likhomanenko, Gabriel Synnaeve, and Ronan Collobert. | ||||||
| 1. **[M2M100](model_doc/m2m_100)** (from Facebook) released with the paper [Beyond English-Centric Multilingual Machine Translation](https://huggingface.co/papers/2010.11125) by Angela Fan, Shruti Bhosale, Holger Schwenk, Zhiyi Ma, Ahmed El-Kishky, Siddharth Goyal, Mandeep Baines, Onur Celebi, Guillaume Wenzek, Vishrav Chaudhary, Naman Goyal, Tom Birch, Vitaliy Liptchinsky, Sergey Edunov, Edouard Grave, Michael Auli, Armand Joulin. | 1. **[M2M100](model_doc/m2m_100)** (from Facebook) released with the paper [Beyond English-Centric Multilingual Machine Translation](https://arxiv.org/abs/2010.11125) by Angela Fan, Shruti Bhosale, Holger Schwenk, Zhiyi Ma, Ahmed El-Kishky, Siddharth Goyal, Mandeep Baines, Onur Celebi, Guillaume Wenzek, Vishrav Chaudhary, Naman Goyal, Tom Birch, Vitaliy Liptchinsky, Sergey Edunov, Edouard Grave, Michael Auli, Armand Joulin. | ||||||
| 1. **[MarianMT](model_doc/marian)** Machine translation models trained using [OPUS](http://opus.nlpl.eu/) data by Jörg Tiedemann. The [Marian Framework](https://marian-nmt.github.io/) is being developed by the Microsoft Translator Team. | 1. **[MarianMT](model_doc/marian)** Machine translation models trained using [OPUS](http://opus.nlpl.eu/) data by Jörg Tiedemann. The [Marian Framework](https://marian-nmt.github.io/) is being developed by the Microsoft Translator Team. | ||||||
| 1. **[Mask2Former](model_doc/mask2former)** (from FAIR and UIUC) released with the paper [Masked-attention Mask Transformer for Universal Image Segmentation](https://huggingface.co/papers/2112.01527) by Bowen Cheng, Ishan Misra, Alexander G. Schwing, Alexander Kirillov, Rohit Girdhar. | 1. **[Mask2Former](model_doc/mask2former)** (from FAIR and UIUC) released with the paper [Masked-attention Mask Transformer for Universal Image Segmentation](https://arxiv.org/abs/2112.01527) by Bowen Cheng, Ishan Misra, Alexander G. Schwing, Alexander Kirillov, Rohit Girdhar. | ||||||
| 1. **[MaskFormer](model_doc/maskformer)** (from Meta and UIUC) released with the paper [Per-Pixel Classification is Not All You Need for Semantic Segmentation](https://huggingface.co/papers/2107.06278) by Bowen Cheng, Alexander G. Schwing, Alexander Kirillov. | 1. **[MaskFormer](model_doc/maskformer)** (from Meta and UIUC) released with the paper [Per-Pixel Classification is Not All You Need for Semantic Segmentation](https://arxiv.org/abs/2107.06278) by Bowen Cheng, Alexander G. Schwing, Alexander Kirillov. | ||||||
| 1. **[mBART](model_doc/mbart)** (from Facebook) released with the paper [Multilingual Denoising Pre-training for Neural Machine Translation](https://huggingface.co/papers/2001.08210) by Yinhan Liu, Jiatao Gu, Naman Goyal, Xian Li, Sergey Edunov, Marjan Ghazvininejad, Mike Lewis, Luke Zettlemoyer. | 1. **[mBART](model_doc/mbart)** (from Facebook) released with the paper [Multilingual Denoising Pre-training for Neural Machine Translation](https://arxiv.org/abs/2001.08210) by Yinhan Liu, Jiatao Gu, Naman Goyal, Xian Li, Sergey Edunov, Marjan Ghazvininejad, Mike Lewis, Luke Zettlemoyer. | ||||||
| 1. **[mBART-50](model_doc/mbart)** (from Facebook) released with the paper [Multilingual Translation with Extensible Multilingual Pretraining and Finetuning](https://huggingface.co/papers/2008.00401) by Yuqing Tang, Chau Tran, Xian Li, Peng-Jen Chen, Naman Goyal, Vishrav Chaudhary, Jiatao Gu, Angela Fan. | 1. **[mBART-50](model_doc/mbart)** (from Facebook) released with the paper [Multilingual Translation with Extensible Multilingual Pretraining and Finetuning](https://arxiv.org/abs/2008.00401) by Yuqing Tang, Chau Tran, Xian Li, Peng-Jen Chen, Naman Goyal, Vishrav Chaudhary, Jiatao Gu, Angela Fan. | ||||||
| 1. **[Megatron-BERT](model_doc/megatron-bert)** (from NVIDIA) released with the paper [Megatron-LM: Training Multi-Billion Parameter Language Models Using Model Parallelism](https://huggingface.co/papers/1909.08053) by Mohammad Shoeybi, Mostofa Patwary, Raul Puri, Patrick LeGresley, Jared Casper and Bryan Catanzaro. | 1. **[Megatron-BERT](model_doc/megatron-bert)** (from NVIDIA) released with the paper [Megatron-LM: Training Multi-Billion Parameter Language Models Using Model Parallelism](https://arxiv.org/abs/1909.08053) by Mohammad Shoeybi, Mostofa Patwary, Raul Puri, Patrick LeGresley, Jared Casper and Bryan Catanzaro. | ||||||
| 1. **[Megatron-GPT2](model_doc/megatron_gpt2)** (from NVIDIA) released with the paper [Megatron-LM: Training Multi-Billion Parameter Language Models Using Model Parallelism](https://huggingface.co/papers/1909.08053) by Mohammad Shoeybi, Mostofa Patwary, Raul Puri, Patrick LeGresley, Jared Casper and Bryan Catanzaro. | 1. **[Megatron-GPT2](model_doc/megatron_gpt2)** (from NVIDIA) released with the paper [Megatron-LM: Training Multi-Billion Parameter Language Models Using Model Parallelism](https://arxiv.org/abs/1909.08053) by Mohammad Shoeybi, Mostofa Patwary, Raul Puri, Patrick LeGresley, Jared Casper and Bryan Catanzaro. | ||||||
| 1. **[mLUKE](model_doc/mluke)** (from Studio Ousia) released with the paper [mLUKE: The Power of Entity Representations in Multilingual Pretrained Language Models](https://huggingface.co/papers/2110.08151) by Ryokan Ri, Ikuya Yamada, and Yoshimasa Tsuruoka. | 1. **[mLUKE](model_doc/mluke)** (from Studio Ousia) released with the paper [mLUKE: The Power of Entity Representations in Multilingual Pretrained Language Models](https://arxiv.org/abs/2110.08151) by Ryokan Ri, Ikuya Yamada, and Yoshimasa Tsuruoka. | ||||||
| 1. **[MobileBERT](model_doc/mobilebert)** (from CMU/Google Brain) released with the paper [MobileBERT: a Compact Task-Agnostic BERT for Resource-Limited Devices](https://huggingface.co/papers/2004.02984) by Zhiqing Sun, Hongkun Yu, Xiaodan Song, Renjie Liu, Yiming Yang, and Denny Zhou. | 1. **[MobileBERT](model_doc/mobilebert)** (from CMU/Google Brain) released with the paper [MobileBERT: a Compact Task-Agnostic BERT for Resource-Limited Devices](https://arxiv.org/abs/2004.02984) by Zhiqing Sun, Hongkun Yu, Xiaodan Song, Renjie Liu, Yiming Yang, and Denny Zhou. | ||||||
| 1. **[MobileViT](model_doc/mobilevit)** (from Apple) released with the paper [MobileViT: Light-weight, General-purpose, and Mobile-friendly Vision Transformer](https://huggingface.co/papers/2110.02178) by Sachin Mehta and Mohammad Rastegari. | 1. **[MobileViT](model_doc/mobilevit)** (from Apple) released with the paper [MobileViT: Light-weight, General-purpose, and Mobile-friendly Vision Transformer](https://arxiv.org/abs/2110.02178) by Sachin Mehta and Mohammad Rastegari. | ||||||
| 1. **[MPNet](model_doc/mpnet)** (from Microsoft Research) released with the paper [MPNet: Masked and Permuted Pre-training for Language Understanding](https://huggingface.co/papers/2004.09297) by Kaitao Song, Xu Tan, Tao Qin, Jianfeng Lu, Tie-Yan Liu. | 1. **[MPNet](model_doc/mpnet)** (from Microsoft Research) released with the paper [MPNet: Masked and Permuted Pre-training for Language Understanding](https://arxiv.org/abs/2004.09297) by Kaitao Song, Xu Tan, Tao Qin, Jianfeng Lu, Tie-Yan Liu. | ||||||
| 1. **[MT5](model_doc/mt5)** (from Google AI) released with the paper [mT5: A massively multilingual pre-trained text-to-text transformer](https://huggingface.co/papers/2010.11934) by Linting Xue, Noah Constant, Adam Roberts, Mihir Kale, Rami Al-Rfou, Aditya Siddhant, Aditya Barua, Colin Raffel. | 1. **[MT5](model_doc/mt5)** (from Google AI) released with the paper [mT5: A massively multilingual pre-trained text-to-text transformer](https://arxiv.org/abs/2010.11934) by Linting Xue, Noah Constant, Adam Roberts, Mihir Kale, Rami Al-Rfou, Aditya Siddhant, Aditya Barua, Colin Raffel. | ||||||
| 1. **[MVP](model_doc/mvp)** (from RUC AI Box) released with the paper [MVP: Multi-task Supervised Pre-training for Natural Language Generation](https://huggingface.co/papers/2206.12131) by Tianyi Tang, Junyi Li, Wayne Xin Zhao and Ji-Rong Wen. | 1. **[MVP](model_doc/mvp)** (from RUC AI Box) released with the paper [MVP: Multi-task Supervised Pre-training for Natural Language Generation](https://arxiv.org/abs/2206.12131) by Tianyi Tang, Junyi Li, Wayne Xin Zhao and Ji-Rong Wen. | ||||||
| 1. **[Nezha](model_doc/nezha)** (from Huawei Noah’s Ark Lab) released with the paper [NEZHA: Neural Contextualized Representation for Chinese Language Understanding](https://huggingface.co/papers/1909.00204) by Junqiu Wei, Xiaozhe Ren, Xiaoguang Li, Wenyong Huang, Yi Liao, Yasheng Wang, Jiashu Lin, Xin Jiang, Xiao Chen and Qun Liu. | 1. **[Nezha](model_doc/nezha)** (from Huawei Noah’s Ark Lab) released with the paper [NEZHA: Neural Contextualized Representation for Chinese Language Understanding](https://arxiv.org/abs/1909.00204) by Junqiu Wei, Xiaozhe Ren, Xiaoguang Li, Wenyong Huang, Yi Liao, Yasheng Wang, Jiashu Lin, Xin Jiang, Xiao Chen and Qun Liu. | ||||||
| 1. **[NLLB](model_doc/nllb)** (from Meta) released with the paper [No Language Left Behind: Scaling Human-Centered Machine Translation](https://huggingface.co/papers/2207.04672) by the NLLB team. | 1. **[NLLB](model_doc/nllb)** (from Meta) released with the paper [No Language Left Behind: Scaling Human-Centered Machine Translation](https://arxiv.org/abs/2207.04672) by the NLLB team. | ||||||
| 1. **[Nyströmformer](model_doc/nystromformer)** (from the University of Wisconsin - Madison) released with the paper [Nyströmformer: A Nyström-Based Algorithm for Approximating Self-Attention](https://huggingface.co/papers/2102.03902) by Yunyang Xiong, Zhanpeng Zeng, Rudrasis Chakraborty, Mingxing Tan, Glenn Fung, Yin Li, Vikas Singh. | 1. **[Nyströmformer](model_doc/nystromformer)** (from the University of Wisconsin - Madison) released with the paper [Nyströmformer: A Nyström-Based Algorithm for Approximating Self-Attention](https://arxiv.org/abs/2102.03902) by Yunyang Xiong, Zhanpeng Zeng, Rudrasis Chakraborty, Mingxing Tan, Glenn Fung, Yin Li, Vikas Singh. | ||||||
| 1. **[OneFormer](model_doc/oneformer)** (from SHI Labs) released with the paper [OneFormer: One Transformer to Rule Universal Image Segmentation](https://huggingface.co/papers/2211.06220) by Jitesh Jain, Jiachen Li, MangTik Chiu, Ali Hassani, Nikita Orlov, Humphrey Shi. | 1. **[OneFormer](model_doc/oneformer)** (from SHI Labs) released with the paper [OneFormer: One Transformer to Rule Universal Image Segmentation](https://arxiv.org/abs/2211.06220) by Jitesh Jain, Jiachen Li, MangTik Chiu, Ali Hassani, Nikita Orlov, Humphrey Shi. | ||||||
| 1. **[OPT](master/model_doc/opt)** (from Meta AI) released with the paper [OPT: Open Pre-trained Transformer Language Models](https://huggingface.co/papers/2205.01068) by Susan Zhang, Stephen Roller, Naman Goyal, Mikel Artetxe, Moya Chen, Shuohui Chen et al. | 1. **[OPT](master/model_doc/opt)** (from Meta AI) released with the paper [OPT: Open Pre-trained Transformer Language Models](https://arxiv.org/abs/2205.01068) by Susan Zhang, Stephen Roller, Naman Goyal, Mikel Artetxe, Moya Chen, Shuohui Chen et al. | ||||||
| 1. **[OWL-ViT](model_doc/owlvit)** (from Google AI) released with the paper [Simple Open-Vocabulary Object Detection with Vision Transformers](https://huggingface.co/papers/2205.06230) by Matthias Minderer, Alexey Gritsenko, Austin Stone, Maxim Neumann, Dirk Weissenborn, Alexey Dosovitskiy, Aravindh Mahendran, Anurag Arnab, Mostafa Dehghani, Zhuoran Shen, Xiao Wang, Xiaohua Zhai, Thomas Kipf, and Neil Houlsby. | 1. **[OWL-ViT](model_doc/owlvit)** (from Google AI) released with the paper [Simple Open-Vocabulary Object Detection with Vision Transformers](https://arxiv.org/abs/2205.06230) by Matthias Minderer, Alexey Gritsenko, Austin Stone, Maxim Neumann, Dirk Weissenborn, Alexey Dosovitskiy, Aravindh Mahendran, Anurag Arnab, Mostafa Dehghani, Zhuoran Shen, Xiao Wang, Xiaohua Zhai, Thomas Kipf, and Neil Houlsby. | ||||||
| 1. **[Pegasus](model_doc/pegasus)** (from Google) released with the paper [PEGASUS: Pre-training with Extracted Gap-sentences for Abstractive Summarization](https://huggingface.co/papers/1912.08777) by Jingqing Zhang, Yao Zhao, Mohammad Saleh and Peter J. Liu. | 1. **[Pegasus](model_doc/pegasus)** (from Google) released with the paper [PEGASUS: Pre-training with Extracted Gap-sentences for Abstractive Summarization](https://arxiv.org/abs/1912.08777) by Jingqing Zhang, Yao Zhao, Mohammad Saleh and Peter J. Liu. | ||||||
| 1. **[Perceiver IO](model_doc/perceiver)** (from Deepmind) released with the paper [Perceiver IO: A General Architecture for Structured Inputs & Outputs](https://huggingface.co/papers/2107.14795) by Andrew Jaegle, Sebastian Borgeaud, Jean-Baptiste Alayrac, Carl Doersch, Catalin Ionescu, David Ding, Skanda Koppula, Daniel Zoran, Andrew Brock, Evan Shelhamer, Olivier Hénaff, Matthew M. Botvinick, Andrew Zisserman, Oriol Vinyals, João Carreira. | 1. **[Perceiver IO](model_doc/perceiver)** (from Deepmind) released with the paper [Perceiver IO: A General Architecture for Structured Inputs & Outputs](https://arxiv.org/abs/2107.14795) by Andrew Jaegle, Sebastian Borgeaud, Jean-Baptiste Alayrac, Carl Doersch, Catalin Ionescu, David Ding, Skanda Koppula, Daniel Zoran, Andrew Brock, Evan Shelhamer, Olivier Hénaff, Matthew M. Botvinick, Andrew Zisserman, Oriol Vinyals, João Carreira. | ||||||
| 1. **[PhoBERT](model_doc/phobert)** (from VinAI Research) released with the paper [PhoBERT: Pre-trained language models for Vietnamese](https://www.aclweb.org/anthology/2020.findings-emnlp.92/) by Dat Quoc Nguyen and Anh Tuan Nguyen. | 1. **[PhoBERT](model_doc/phobert)** (from VinAI Research) released with the paper [PhoBERT: Pre-trained language models for Vietnamese](https://www.aclweb.org/anthology/2020.findings-emnlp.92/) by Dat Quoc Nguyen and Anh Tuan Nguyen. | ||||||
| 1. **[PLBart](model_doc/plbart)** (from UCLA NLP) released with the paper [Unified Pre-training for Program Understanding and Generation](https://huggingface.co/papers/2103.06333) by Wasi Uddin Ahmad, Saikat Chakraborty, Baishakhi Ray, Kai-Wei Chang. | 1. **[PLBart](model_doc/plbart)** (from UCLA NLP) released with the paper [Unified Pre-training for Program Understanding and Generation](https://arxiv.org/abs/2103.06333) by Wasi Uddin Ahmad, Saikat Chakraborty, Baishakhi Ray, Kai-Wei Chang. | ||||||
| 1. **[PoolFormer](model_doc/poolformer)** (from Sea AI Labs) released with the paper [MetaFormer is Actually What You Need for Vision](https://huggingface.co/papers/2111.11418) by Yu, Weihao and Luo, Mi and Zhou, Pan and Si, Chenyang and Zhou, Yichen and Wang, Xinchao and Feng, Jiashi and Yan, Shuicheng. | 1. **[PoolFormer](model_doc/poolformer)** (from Sea AI Labs) released with the paper [MetaFormer is Actually What You Need for Vision](https://arxiv.org/abs/2111.11418) by Yu, Weihao and Luo, Mi and Zhou, Pan and Si, Chenyang and Zhou, Yichen and Wang, Xinchao and Feng, Jiashi and Yan, Shuicheng. | ||||||
| 1. **[ProphetNet](model_doc/prophetnet)** (from Microsoft Research) released with the paper [ProphetNet: Predicting Future N-gram for Sequence-to-Sequence Pre-training](https://huggingface.co/papers/2001.04063) by Yu Yan, Weizhen Qi, Yeyun Gong, Dayiheng Liu, Nan Duan, Jiusheng Chen, Ruofei Zhang and Ming Zhou. | 1. **[ProphetNet](model_doc/prophetnet)** (from Microsoft Research) released with the paper [ProphetNet: Predicting Future N-gram for Sequence-to-Sequence Pre-training](https://arxiv.org/abs/2001.04063) by Yu Yan, Weizhen Qi, Yeyun Gong, Dayiheng Liu, Nan Duan, Jiusheng Chen, Ruofei Zhang and Ming Zhou. | ||||||
| 1. **[QDQBert](model_doc/qdqbert)** (from NVIDIA) released with the paper [Integer Quantization for Deep Learning Inference: Principles and Empirical Evaluation](https://huggingface.co/papers/2004.09602) by Hao Wu, Patrick Judd, Xiaojie Zhang, Mikhail Isaev and Paulius Micikevicius. | 1. **[QDQBert](model_doc/qdqbert)** (from NVIDIA) released with the paper [Integer Quantization for Deep Learning Inference: Principles and Empirical Evaluation](https://arxiv.org/abs/2004.09602) by Hao Wu, Patrick Judd, Xiaojie Zhang, Mikhail Isaev and Paulius Micikevicius. | ||||||
| 1. **[RAG](model_doc/rag)** (from Facebook) released with the paper [Retrieval-Augmented Generation for Knowledge-Intensive NLP Tasks](https://huggingface.co/papers/2005.11401) by Patrick Lewis, Ethan Perez, Aleksandara Piktus, Fabio Petroni, Vladimir Karpukhin, Naman Goyal, Heinrich Küttler, Mike Lewis, Wen-tau Yih, Tim Rocktäschel, Sebastian Riedel, Douwe Kiela. | 1. **[RAG](model_doc/rag)** (from Facebook) released with the paper [Retrieval-Augmented Generation for Knowledge-Intensive NLP Tasks](https://arxiv.org/abs/2005.11401) by Patrick Lewis, Ethan Perez, Aleksandara Piktus, Fabio Petroni, Vladimir Karpukhin, Naman Goyal, Heinrich Küttler, Mike Lewis, Wen-tau Yih, Tim Rocktäschel, Sebastian Riedel, Douwe Kiela. | ||||||
| 1. **[REALM](model_doc/realm.html)** (from Google Research) released with the paper [REALM: Retrieval-Augmented Language Model Pre-Training](https://huggingface.co/papers/2002.08909) by Kelvin Guu, Kenton Lee, Zora Tung, Panupong Pasupat and Ming-Wei Chang. | 1. **[REALM](model_doc/realm.html)** (from Google Research) released with the paper [REALM: Retrieval-Augmented Language Model Pre-Training](https://arxiv.org/abs/2002.08909) by Kelvin Guu, Kenton Lee, Zora Tung, Panupong Pasupat and Ming-Wei Chang. | ||||||
| 1. **[Reformer](model_doc/reformer)** (from Google Research) released with the paper [Reformer: The Efficient Transformer](https://huggingface.co/papers/2001.04451) by Nikita Kitaev, Łukasz Kaiser, Anselm Levskaya. | 1. **[Reformer](model_doc/reformer)** (from Google Research) released with the paper [Reformer: The Efficient Transformer](https://arxiv.org/abs/2001.04451) by Nikita Kitaev, Łukasz Kaiser, Anselm Levskaya. | ||||||
| 1. **[RegNet](model_doc/regnet)** (from META Platforms) released with the paper [Designing Network Design Space](https://huggingface.co/papers/2003.13678) by Ilija Radosavovic, Raj Prateek Kosaraju, Ross Girshick, Kaiming He, Piotr Dollár. | 1. **[RegNet](model_doc/regnet)** (from META Platforms) released with the paper [Designing Network Design Space](https://arxiv.org/abs/2003.13678) by Ilija Radosavovic, Raj Prateek Kosaraju, Ross Girshick, Kaiming He, Piotr Dollár. | ||||||
| 1. **[RemBERT](model_doc/rembert)** (from Google Research) released with the paper [Rethinking embedding coupling in pre-trained language models](https://huggingface.co/papers/2010.12821) by Hyung Won Chung, Thibault Févry, Henry Tsai, M. Johnson, Sebastian Ruder. | 1. **[RemBERT](model_doc/rembert)** (from Google Research) released with the paper [Rethinking embedding coupling in pre-trained language models](https://arxiv.org/abs/2010.12821) by Hyung Won Chung, Thibault Févry, Henry Tsai, M. Johnson, Sebastian Ruder. | ||||||
| 1. **[ResNet](model_doc/resnet)** (from Microsoft Research) released with the paper [Deep Residual Learning for Image Recognition](https://huggingface.co/papers/1512.03385) by Kaiming He, Xiangyu Zhang, Shaoqing Ren, Jian Sun. | 1. **[ResNet](model_doc/resnet)** (from Microsoft Research) released with the paper [Deep Residual Learning for Image Recognition](https://arxiv.org/abs/1512.03385) by Kaiming He, Xiangyu Zhang, Shaoqing Ren, Jian Sun. | ||||||
| 1. **[RoBERTa](model_doc/roberta)** (from Facebook), released together with the paper [RoBERTa: A Robustly Optimized BERT Pretraining Approach](https://huggingface.co/papers/1907.11692) by Yinhan Liu, Myle Ott, Naman Goyal, Jingfei Du, Mandar Joshi, Danqi Chen, Omer Levy, Mike Lewis, Luke Zettlemoyer, Veselin Stoyanov. | 1. **[RoBERTa](model_doc/roberta)** (from Facebook), released together with the paper [RoBERTa: A Robustly Optimized BERT Pretraining Approach](https://arxiv.org/abs/1907.11692) by Yinhan Liu, Myle Ott, Naman Goyal, Jingfei Du, Mandar Joshi, Danqi Chen, Omer Levy, Mike Lewis, Luke Zettlemoyer, Veselin Stoyanov. | ||||||
| 1. **[RoFormer](model_doc/roformer)** (from ZhuiyiTechnology), released together with the paper [RoFormer: Enhanced Transformer with Rotary Position Embedding](https://huggingface.co/papers/2104.09864) by Jianlin Su and Yu Lu and Shengfeng Pan and Bo Wen and Yunfeng Liu. | 1. **[RoFormer](model_doc/roformer)** (from ZhuiyiTechnology), released together with the paper [RoFormer: Enhanced Transformer with Rotary Position Embedding](https://arxiv.org/abs/2104.09864) by Jianlin Su and Yu Lu and Shengfeng Pan and Bo Wen and Yunfeng Liu. | ||||||
| 1. **[SegFormer](model_doc/segformer)** (from NVIDIA) released with the paper [SegFormer: Simple and Efficient Design for Semantic Segmentation with Transformers](https://huggingface.co/papers/2105.15203) by Enze Xie, Wenhai Wang, Zhiding Yu, Anima Anandkumar, Jose M. Alvarez, Ping Luo. | 1. **[SegFormer](model_doc/segformer)** (from NVIDIA) released with the paper [SegFormer: Simple and Efficient Design for Semantic Segmentation with Transformers](https://arxiv.org/abs/2105.15203) by Enze Xie, Wenhai Wang, Zhiding Yu, Anima Anandkumar, Jose M. Alvarez, Ping Luo. | ||||||
| 1. **[SEW](model_doc/sew)** (from ASAPP) released with the paper [Performance-Efficiency Trade-offs in Unsupervised Pre-training for Speech Recognition](https://huggingface.co/papers/2109.06870) by Felix Wu, Kwangyoun Kim, Jing Pan, Kyu Han, Kilian Q. Weinberger, Yoav Artzi. | 1. **[SEW](model_doc/sew)** (from ASAPP) released with the paper [Performance-Efficiency Trade-offs in Unsupervised Pre-training for Speech Recognition](https://arxiv.org/abs/2109.06870) by Felix Wu, Kwangyoun Kim, Jing Pan, Kyu Han, Kilian Q. Weinberger, Yoav Artzi. | ||||||
| 1. **[SEW-D](model_doc/sew_d)** (from ASAPP) released with the paper [Performance-Efficiency Trade-offs in Unsupervised Pre-training for Speech Recognition](https://huggingface.co/papers/2109.06870) by Felix Wu, Kwangyoun Kim, Jing Pan, Kyu Han, Kilian Q. Weinberger, Yoav Artzi. | 1. **[SEW-D](model_doc/sew_d)** (from ASAPP) released with the paper [Performance-Efficiency Trade-offs in Unsupervised Pre-training for Speech Recognition](https://arxiv.org/abs/2109.06870) by Felix Wu, Kwangyoun Kim, Jing Pan, Kyu Han, Kilian Q. Weinberger, Yoav Artzi. | ||||||
| 1. **[SpeechToTextTransformer](model_doc/speech_to_text)** (from Facebook), released together with the paper [fairseq S2T: Fast Speech-to-Text Modeling with fairseq](https://huggingface.co/papers/2010.05171) by Changhan Wang, Yun Tang, Xutai Ma, Anne Wu, Dmytro Okhonko, Juan Pino. | 1. **[SpeechToTextTransformer](model_doc/speech_to_text)** (from Facebook), released together with the paper [fairseq S2T: Fast Speech-to-Text Modeling with fairseq](https://arxiv.org/abs/2010.05171) by Changhan Wang, Yun Tang, Xutai Ma, Anne Wu, Dmytro Okhonko, Juan Pino. | ||||||
| 1. **[SpeechToTextTransformer2](model_doc/speech_to_text_2)** (from Facebook), released together with the paper [Large-Scale Self- and Semi-Supervised Learning for Speech Translation](https://huggingface.co/papers/2104.06678) by Changhan Wang, Anne Wu, Juan Pino, Alexei Baevski, Michael Auli, Alexis Conneau. | 1. **[SpeechToTextTransformer2](model_doc/speech_to_text_2)** (from Facebook), released together with the paper [Large-Scale Self- and Semi-Supervised Learning for Speech Translation](https://arxiv.org/abs/2104.06678) by Changhan Wang, Anne Wu, Juan Pino, Alexei Baevski, Michael Auli, Alexis Conneau. | ||||||
| 1. **[Splinter](model_doc/splinter)** (from Tel Aviv University), released together with the paper [Few-Shot Question Answering by Pretraining Span Selection](https://huggingface.co/papers/2101.00438) by Ori Ram, Yuval Kirstain, Jonathan Berant, Amir Globerson, Omer Levy. | 1. **[Splinter](model_doc/splinter)** (from Tel Aviv University), released together with the paper [Few-Shot Question Answering by Pretraining Span Selection](https://arxiv.org/abs/2101.00438) by Ori Ram, Yuval Kirstain, Jonathan Berant, Amir Globerson, Omer Levy. | ||||||
| 1. **[SqueezeBERT](model_doc/squeezebert)** (from Berkeley) released with the paper [SqueezeBERT: What can computer vision teach NLP about efficient neural networks?](https://huggingface.co/papers/2006.11316) by Forrest N. Iandola, Albert E. Shaw, Ravi Krishna, and Kurt W. Keutzer. | 1. **[SqueezeBERT](model_doc/squeezebert)** (from Berkeley) released with the paper [SqueezeBERT: What can computer vision teach NLP about efficient neural networks?](https://arxiv.org/abs/2006.11316) by Forrest N. Iandola, Albert E. Shaw, Ravi Krishna, and Kurt W. Keutzer. | ||||||
| 1. **[Swin Transformer](model_doc/swin)** (from Microsoft) released with the paper [Swin Transformer: Hierarchical Vision Transformer using Shifted Windows](https://huggingface.co/papers/2103.14030) by Ze Liu, Yutong Lin, Yue Cao, Han Hu, Yixuan Wei, Zheng Zhang, Stephen Lin, Baining Guo. | 1. **[Swin Transformer](model_doc/swin)** (from Microsoft) released with the paper [Swin Transformer: Hierarchical Vision Transformer using Shifted Windows](https://arxiv.org/abs/2103.14030) by Ze Liu, Yutong Lin, Yue Cao, Han Hu, Yixuan Wei, Zheng Zhang, Stephen Lin, Baining Guo. | ||||||
| 1. **[Swin Transformer V2](model_doc/swinv2)** (from Microsoft) released with the paper [Swin Transformer V2: Scaling Up Capacity and Resolution](https://huggingface.co/papers/2111.09883) by Ze Liu, Han Hu, Yutong Lin, Zhuliang Yao, Zhenda Xie, Yixuan Wei, Jia Ning, Yue Cao, Zheng Zhang, Li Dong, Furu Wei, Baining Guo. | 1. **[Swin Transformer V2](model_doc/swinv2)** (from Microsoft) released with the paper [Swin Transformer V2: Scaling Up Capacity and Resolution](https://arxiv.org/abs/2111.09883) by Ze Liu, Han Hu, Yutong Lin, Zhuliang Yao, Zhenda Xie, Yixuan Wei, Jia Ning, Yue Cao, Zheng Zhang, Li Dong, Furu Wei, Baining Guo. | ||||||
| 1. **[T5](model_doc/t5)** (from Google AI) released with the paper [Exploring the Limits of Transfer Learning with a Unified Text-to-Text Transformer](https://huggingface.co/papers/1910.10683) by Colin Raffel and Noam Shazeer and Adam Roberts and Katherine Lee and Sharan Narang and Michael Matena and Yanqi Zhou and Wei Li and Peter J. Liu. | 1. **[T5](model_doc/t5)** (from Google AI) released with the paper [Exploring the Limits of Transfer Learning with a Unified Text-to-Text Transformer](https://arxiv.org/abs/1910.10683) by Colin Raffel and Noam Shazeer and Adam Roberts and Katherine Lee and Sharan Narang and Michael Matena and Yanqi Zhou and Wei Li and Peter J. Liu. | ||||||
| 1. **[T5v1.1](model_doc/t5v1.1)** (from Google AI) released in the repository [google-research/text-to-text-transfer-transformer](https://github.com/google-research/text-to-text-transfer-transformer/blob/main/released_checkpoints.md#t511) by Colin Raffel and Noam Shazeer and Adam Roberts and Katherine Lee and Sharan Narang and Michael Matena and Yanqi Zhou and Wei Li and Peter J. Liu. | 1. **[T5v1.1](model_doc/t5v1.1)** (from Google AI) released in the repository [google-research/text-to-text-transfer-transformer](https://github.com/google-research/text-to-text-transfer-transformer/blob/main/released_checkpoints.md#t511) by Colin Raffel and Noam Shazeer and Adam Roberts and Katherine Lee and Sharan Narang and Michael Matena and Yanqi Zhou and Wei Li and Peter J. Liu. | ||||||
| 1. **[TAPAS](model_doc/tapas)** (from Google AI) released with the paper [TAPAS: Weakly Supervised Table Parsing via Pre-training](https://huggingface.co/papers/2004.02349) by Jonathan Herzig, Paweł Krzysztof Nowak, Thomas Müller, Francesco Piccinno and Julian Martin Eisenschlos. | 1. **[TAPAS](model_doc/tapas)** (from Google AI) released with the paper [TAPAS: Weakly Supervised Table Parsing via Pre-training](https://arxiv.org/abs/2004.02349) by Jonathan Herzig, Paweł Krzysztof Nowak, Thomas Müller, Francesco Piccinno and Julian Martin Eisenschlos. | ||||||
| 1. **[TAPEX](model_doc/tapex)** (from Microsoft Research) released with the paper [TAPEX: Table Pre-training via Learning a Neural SQL Executor](https://huggingface.co/papers/2107.07653) by Qian Liu, Bei Chen, Jiaqi Guo, Morteza Ziyadi, Zeqi Lin, Weizhu Chen, Jian-Guang Lou. | 1. **[TAPEX](model_doc/tapex)** (from Microsoft Research) released with the paper [TAPEX: Table Pre-training via Learning a Neural SQL Executor](https://arxiv.org/abs/2107.07653) by Qian Liu, Bei Chen, Jiaqi Guo, Morteza Ziyadi, Zeqi Lin, Weizhu Chen, Jian-Guang Lou. | ||||||
| 1. **[Trajectory Transformer](model_doc/trajectory_transformers)** (from the University of California at Berkeley) released with the paper [Offline Reinforcement Learning as One Big Sequence Modeling Problem](https://huggingface.co/papers/2106.02039) by Michael Janner, Qiyang Li, Sergey Levine | 1. **[Trajectory Transformer](model_doc/trajectory_transformers)** (from the University of California at Berkeley) released with the paper [Offline Reinforcement Learning as One Big Sequence Modeling Problem](https://arxiv.org/abs/2106.02039) by Michael Janner, Qiyang Li, Sergey Levine | ||||||
| 1. **[Transformer-XL](model_doc/transfo-xl)** (from Google/CMU) released with the paper [Transformer-XL: Attentive Language Models Beyond a Fixed-Length Context](https://huggingface.co/papers/1901.02860) by Zihang Dai*, Zhilin Yang*, Yiming Yang, Jaime Carbonell, Quoc V. Le, Ruslan Salakhutdinov. | 1. **[Transformer-XL](model_doc/transfo-xl)** (from Google/CMU) released with the paper [Transformer-XL: Attentive Language Models Beyond a Fixed-Length Context](https://arxiv.org/abs/1901.02860) by Zihang Dai*, Zhilin Yang*, Yiming Yang, Jaime Carbonell, Quoc V. Le, Ruslan Salakhutdinov. | ||||||
| 1. **[TrOCR](model_doc/trocr)** (from Microsoft), released together with the paper [TrOCR: Transformer-based Optical Character Recognition with Pre-trained Models](https://huggingface.co/papers/2109.10282) by Minghao Li, Tengchao Lv, Lei Cui, Yijuan Lu, Dinei Florencio, Cha Zhang, Zhoujun Li, Furu Wei. | 1. **[TrOCR](model_doc/trocr)** (from Microsoft), released together with the paper [TrOCR: Transformer-based Optical Character Recognition with Pre-trained Models](https://arxiv.org/abs/2109.10282) by Minghao Li, Tengchao Lv, Lei Cui, Yijuan Lu, Dinei Florencio, Cha Zhang, Zhoujun Li, Furu Wei. | ||||||
| 1. **[UL2](model_doc/ul2)** (from Google Research) released with the paper [Unifying Language Learning Paradigms](https://huggingface.co/papers/2205.05131v1) by Yi Tay, Mostafa Dehghani, Vinh Q. Tran, Xavier Garcia, Dara Bahri, Tal Schuster, Huaixiu Steven Zheng, Neil Houlsby, Donald Metzler | 1. **[UL2](model_doc/ul2)** (from Google Research) released with the paper [Unifying Language Learning Paradigms](https://arxiv.org/abs/2205.05131v1) by Yi Tay, Mostafa Dehghani, Vinh Q. Tran, Xavier Garcia, Dara Bahri, Tal Schuster, Huaixiu Steven Zheng, Neil Houlsby, Donald Metzler | ||||||
| 1. **[UMT5](model_doc/umt5)** (from Google Research) released with the paper [UniMax: Fairer and More Effective Language Sampling for Large-Scale Multilingual Pretraining](https://openreview.net/forum?id=kXwdL1cWOAi) by Hyung Won Chung, Xavier Garcia, Adam Roberts, Yi Tay, Orhan Firat, Sharan Narang, Noah Constant. | 1. **[UMT5](model_doc/umt5)** (from Google Research) released with the paper [UniMax: Fairer and More Effective Language Sampling for Large-Scale Multilingual Pretraining](https://openreview.net/forum?id=kXwdL1cWOAi) by Hyung Won Chung, Xavier Garcia, Adam Roberts, Yi Tay, Orhan Firat, Sharan Narang, Noah Constant. | ||||||
| 1. **[UniSpeech](model_doc/unispeech)** (from Microsoft Research) released with the paper [UniSpeech: Unified Speech Representation Learning with Labeled and Unlabeled Data](https://huggingface.co/papers/2101.07597) by Chengyi Wang, Yu Wu, Yao Qian, Kenichi Kumatani, Shujie Liu, Furu Wei, Michael Zeng, Xuedong Huang. | 1. **[UniSpeech](model_doc/unispeech)** (from Microsoft Research) released with the paper [UniSpeech: Unified Speech Representation Learning with Labeled and Unlabeled Data](https://arxiv.org/abs/2101.07597) by Chengyi Wang, Yu Wu, Yao Qian, Kenichi Kumatani, Shujie Liu, Furu Wei, Michael Zeng, Xuedong Huang. | ||||||
| 1. **[UniSpeechSat](model_doc/unispeech-sat)** (from Microsoft Research) released with the paper [UNISPEECH-SAT: UNIVERSAL SPEECH REPRESENTATION LEARNING WITH SPEAKER AWARE PRE-TRAINING](https://huggingface.co/papers/2110.05752) by Sanyuan Chen, Yu Wu, Chengyi Wang, Zhengyang Chen, Zhuo Chen, Shujie Liu, Jian Wu, Yao Qian, Furu Wei, Jinyu Li, Xiangzhan Yu. | 1. **[UniSpeechSat](model_doc/unispeech-sat)** (from Microsoft Research) released with the paper [UNISPEECH-SAT: UNIVERSAL SPEECH REPRESENTATION LEARNING WITH SPEAKER AWARE PRE-TRAINING](https://arxiv.org/abs/2110.05752) by Sanyuan Chen, Yu Wu, Chengyi Wang, Zhengyang Chen, Zhuo Chen, Shujie Liu, Jian Wu, Yao Qian, Furu Wei, Jinyu Li, Xiangzhan Yu. | ||||||
| 1. **[VAN](model_doc/van)** (from Tsinghua University and Nankai University) released with the paper [Visual Attention Network](https://huggingface.co/papers/2202.09741) by Meng-Hao Guo, Cheng-Ze Lu, Zheng-Ning Liu, Ming-Ming Cheng, Shi-Min Hu. | 1. **[VAN](model_doc/van)** (from Tsinghua University and Nankai University) released with the paper [Visual Attention Network](https://arxiv.org/abs/2202.09741) by Meng-Hao Guo, Cheng-Ze Lu, Zheng-Ning Liu, Ming-Ming Cheng, Shi-Min Hu. | ||||||
| 1. **[VideoMAE](model_doc/videomae)** (from Multimedia Computing Group, Nanjing University) released with the paper [VideoMAE: Masked Autoencoders are Data-Efficient Learners for Self-Supervised Video Pre-Training](https://huggingface.co/papers/2203.12602) by Zhan Tong, Yibing Song, Jue Wang, Limin Wang. | 1. **[VideoMAE](model_doc/videomae)** (from Multimedia Computing Group, Nanjing University) released with the paper [VideoMAE: Masked Autoencoders are Data-Efficient Learners for Self-Supervised Video Pre-Training](https://arxiv.org/abs/2203.12602) by Zhan Tong, Yibing Song, Jue Wang, Limin Wang. | ||||||
| 1. **[ViLT](model_doc/vilt)** (from NAVER AI Lab/Kakao Enterprise/Kakao Brain) released with the paper [ViLT: Vision-and-Language Transformer Without Convolution or Region Supervision](https://huggingface.co/papers/2102.03334) by Wonjae Kim, Bokyung Son, Ildoo Kim. | 1. **[ViLT](model_doc/vilt)** (from NAVER AI Lab/Kakao Enterprise/Kakao Brain) released with the paper [ViLT: Vision-and-Language Transformer Without Convolution or Region Supervision](https://arxiv.org/abs/2102.03334) by Wonjae Kim, Bokyung Son, Ildoo Kim. | ||||||
| 1. **[Vision Transformer (ViT)](model_doc/vit)** (from Google AI) released with the paper [An Image is Worth 16x16 Words: Transformers for Image Recognition at Scale](https://huggingface.co/papers/2010.11929) by Alexey Dosovitskiy, Lucas Beyer, Alexander Kolesnikov, Dirk Weissenborn, Xiaohua Zhai, Thomas Unterthiner, Mostafa Dehghani, Matthias Minderer, Georg Heigold, Sylvain Gelly, Jakob Uszkoreit, Neil Houlsby. | 1. **[Vision Transformer (ViT)](model_doc/vit)** (from Google AI) released with the paper [An Image is Worth 16x16 Words: Transformers for Image Recognition at Scale](https://arxiv.org/abs/2010.11929) by Alexey Dosovitskiy, Lucas Beyer, Alexander Kolesnikov, Dirk Weissenborn, Xiaohua Zhai, Thomas Unterthiner, Mostafa Dehghani, Matthias Minderer, Georg Heigold, Sylvain Gelly, Jakob Uszkoreit, Neil Houlsby. | ||||||
| 1. **[VisualBERT](model_doc/visual_bert)** (from UCLA NLP) released with the paper [VisualBERT: A Simple and Performant Baseline for Vision and Language](https://huggingface.co/papers/1908.03557) by Liunian Harold Li, Mark Yatskar, Da Yin, Cho-Jui Hsieh, Kai-Wei Chang. | 1. **[VisualBERT](model_doc/visual_bert)** (from UCLA NLP) released with the paper [VisualBERT: A Simple and Performant Baseline for Vision and Language](https://arxiv.org/pdf/1908.03557) by Liunian Harold Li, Mark Yatskar, Da Yin, Cho-Jui Hsieh, Kai-Wei Chang. | ||||||
| 1. **[ViTMAE](model_doc/vit_mae)** (from Meta AI) released with the paper [Masked Autoencoders Are Scalable Vision Learners](https://huggingface.co/papers/2111.06377) by Kaiming He, Xinlei Chen, Saining Xie, Yanghao Li, Piotr Dollár, Ross Girshick. | 1. **[ViTMAE](model_doc/vit_mae)** (from Meta AI) released with the paper [Masked Autoencoders Are Scalable Vision Learners](https://arxiv.org/abs/2111.06377) by Kaiming He, Xinlei Chen, Saining Xie, Yanghao Li, Piotr Dollár, Ross Girshick. | ||||||
| 1. **[Wav2Vec2](model_doc/wav2vec2)** (from Facebook AI) released with the paper [wav2vec 2.0: A Framework for Self-Supervised Learning of Speech Representations](https://huggingface.co/papers/2006.11477) by Alexei Baevski, Henry Zhou, Abdelrahman Mohamed, Michael Auli. | 1. **[Wav2Vec2](model_doc/wav2vec2)** (from Facebook AI) released with the paper [wav2vec 2.0: A Framework for Self-Supervised Learning of Speech Representations](https://arxiv.org/abs/2006.11477) by Alexei Baevski, Henry Zhou, Abdelrahman Mohamed, Michael Auli. | ||||||
| 1. **[Wav2Vec2-Conformer](model_doc/wav2vec2-conformer)** (from Facebook AI) released with the paper [FAIRSEQ S2T: Fast Speech-to-Text Modeling with FAIRSEQ](https://huggingface.co/papers/2010.05171) by Changhan Wang, Yun Tang, Xutai Ma, Anne Wu, Sravya Popuri, Dmytro Okhonko, Juan Pino. | 1. **[Wav2Vec2-Conformer](model_doc/wav2vec2-conformer)** (from Facebook AI) released with the paper [FAIRSEQ S2T: Fast Speech-to-Text Modeling with FAIRSEQ](https://arxiv.org/abs/2010.05171) by Changhan Wang, Yun Tang, Xutai Ma, Anne Wu, Sravya Popuri, Dmytro Okhonko, Juan Pino. | ||||||
| 1. **[Wav2Vec2Phoneme](model_doc/wav2vec2_phoneme)** (from Facebook AI) released with the paper [Simple and Effective Zero-shot Cross-lingual Phoneme Recognition](https://huggingface.co/papers/2109.11680) by Qiantong Xu, Alexei Baevski, Michael Auli. | 1. **[Wav2Vec2Phoneme](model_doc/wav2vec2_phoneme)** (from Facebook AI) released with the paper [Simple and Effective Zero-shot Cross-lingual Phoneme Recognition](https://arxiv.org/abs/2109.11680) by Qiantong Xu, Alexei Baevski, Michael Auli. | ||||||
| 1. **[WavLM](model_doc/wavlm)** (from Microsoft Research) released with the paper [WavLM: Large-Scale Self-Supervised Pre-Training for Full Stack Speech Processing](https://huggingface.co/papers/2110.13900) by Sanyuan Chen, Chengyi Wang, Zhengyang Chen, Yu Wu, Shujie Liu, Zhuo Chen, Jinyu Li, Naoyuki Kanda, Takuya Yoshioka, Xiong Xiao, Jian Wu, Long Zhou, Shuo Ren, Yanmin Qian, Yao Qian, Jian Wu, Michael Zeng, Furu Wei. | 1. **[WavLM](model_doc/wavlm)** (from Microsoft Research) released with the paper [WavLM: Large-Scale Self-Supervised Pre-Training for Full Stack Speech Processing](https://arxiv.org/abs/2110.13900) by Sanyuan Chen, Chengyi Wang, Zhengyang Chen, Yu Wu, Shujie Liu, Zhuo Chen, Jinyu Li, Naoyuki Kanda, Takuya Yoshioka, Xiong Xiao, Jian Wu, Long Zhou, Shuo Ren, Yanmin Qian, Yao Qian, Jian Wu, Michael Zeng, Furu Wei. | ||||||
| 1. **[XGLM](model_doc/xglm)** (From Facebook AI) released with the paper [Few-shot Learning with Multilingual Language Models](https://huggingface.co/papers/2112.10668) by Xi Victoria Lin, Todor Mihaylov, Mikel Artetxe, Tianlu Wang, Shuohui Chen, Daniel Simig, Myle Ott, Naman Goyal, Shruti Bhosale, Jingfei Du, Ramakanth Pasunuru, Sam Shleifer, Punit Singh Koura, Vishrav Chaudhary, Brian O'Horo, Jeff Wang, Luke Zettlemoyer, Zornitsa Kozareva, Mona Diab, Veselin Stoyanov, Xian Li. | 1. **[XGLM](model_doc/xglm)** (From Facebook AI) released with the paper [Few-shot Learning with Multilingual Language Models](https://arxiv.org/abs/2112.10668) by Xi Victoria Lin, Todor Mihaylov, Mikel Artetxe, Tianlu Wang, Shuohui Chen, Daniel Simig, Myle Ott, Naman Goyal, Shruti Bhosale, Jingfei Du, Ramakanth Pasunuru, Sam Shleifer, Punit Singh Koura, Vishrav Chaudhary, Brian O'Horo, Jeff Wang, Luke Zettlemoyer, Zornitsa Kozareva, Mona Diab, Veselin Stoyanov, Xian Li. | ||||||
| 1. **[XLM](model_doc/xlm)** (from Facebook) released together with the paper [Cross-lingual Language Model Pretraining](https://huggingface.co/papers/1901.07291) by Guillaume Lample and Alexis Conneau. | 1. **[XLM](model_doc/xlm)** (from Facebook) released together with the paper [Cross-lingual Language Model Pretraining](https://arxiv.org/abs/1901.07291) by Guillaume Lample and Alexis Conneau. | ||||||
| 1. **[XLM-ProphetNet](model_doc/xlm-prophetnet)** (from Microsoft Research) released with the paper [ProphetNet: Predicting Future N-gram for Sequence-to-Sequence Pre-training](https://huggingface.co/papers/2001.04063) by Yu Yan, Weizhen Qi, Yeyun Gong, Dayiheng Liu, Nan Duan, Jiusheng Chen, Ruofei Zhang and Ming Zhou. | 1. **[XLM-ProphetNet](model_doc/xlm-prophetnet)** (from Microsoft Research) released with the paper [ProphetNet: Predicting Future N-gram for Sequence-to-Sequence Pre-training](https://arxiv.org/abs/2001.04063) by Yu Yan, Weizhen Qi, Yeyun Gong, Dayiheng Liu, Nan Duan, Jiusheng Chen, Ruofei Zhang and Ming Zhou. | ||||||
| 1. **[XLM-RoBERTa](model_doc/xlm-roberta)** (from Facebook AI), released together with the paper [Unsupervised Cross-lingual Representation Learning at Scale](https://huggingface.co/papers/1911.02116) by Alexis Conneau*, Kartikay Khandelwal*, Naman Goyal, Vishrav Chaudhary, Guillaume Wenzek, Francisco Guzmán, Edouard Grave, Myle Ott, Luke Zettlemoyer and Veselin Stoyanov. | 1. **[XLM-RoBERTa](model_doc/xlm-roberta)** (from Facebook AI), released together with the paper [Unsupervised Cross-lingual Representation Learning at Scale](https://arxiv.org/abs/1911.02116) by Alexis Conneau*, Kartikay Khandelwal*, Naman Goyal, Vishrav Chaudhary, Guillaume Wenzek, Francisco Guzmán, Edouard Grave, Myle Ott, Luke Zettlemoyer and Veselin Stoyanov. | ||||||
| 1. **[XLM-RoBERTa-XL](model_doc/xlm-roberta-xl)** (from Facebook AI), released together with the paper [Larger-Scale Transformers for Multilingual Masked Language Modeling](https://huggingface.co/papers/2105.00572) by Naman Goyal, Jingfei Du, Myle Ott, Giri Anantharaman, Alexis Conneau. | 1. **[XLM-RoBERTa-XL](model_doc/xlm-roberta-xl)** (from Facebook AI), released together with the paper [Larger-Scale Transformers for Multilingual Masked Language Modeling](https://arxiv.org/abs/2105.00572) by Naman Goyal, Jingfei Du, Myle Ott, Giri Anantharaman, Alexis Conneau. | ||||||
| 1. **[XLM-V](model_doc/xlm-v)** (from Meta AI) released with the paper [XLM-V: Overcoming the Vocabulary Bottleneck in Multilingual Masked Language Models](https://huggingface.co/papers/2301.10472) by Davis Liang, Hila Gonen, Yuning Mao, Rui Hou, Naman Goyal, Marjan Ghazvininejad, Luke Zettlemoyer, Madian Khabsa. | 1. **[XLM-V](model_doc/xlm-v)** (from Meta AI) released with the paper [XLM-V: Overcoming the Vocabulary Bottleneck in Multilingual Masked Language Models](https://arxiv.org/abs/2301.10472) by Davis Liang, Hila Gonen, Yuning Mao, Rui Hou, Naman Goyal, Marjan Ghazvininejad, Luke Zettlemoyer, Madian Khabsa. | ||||||
| 1. **[XLNet](model_doc/xlnet)** (from Google/CMU) released with the paper [XLNet: Generalized Autoregressive Pretraining for Language Understanding](https://huggingface.co/papers/1906.08237) by Zhilin Yang*, Zihang Dai*, Yiming Yang, Jaime Carbonell, Ruslan Salakhutdinov, Quoc V. Le. | 1. **[XLNet](model_doc/xlnet)** (from Google/CMU) released with the paper [XLNet: Generalized Autoregressive Pretraining for Language Understanding](https://arxiv.org/abs/1906.08237) by Zhilin Yang*, Zihang Dai*, Yiming Yang, Jaime Carbonell, Ruslan Salakhutdinov, Quoc V. Le. | ||||||
| 1. **[XLS-R](model_doc/xls_r)** (from Facebook AI) released with the paper [XLS-R: Self-supervised Cross-lingual Speech Representation Learning at Scale](https://huggingface.co/papers/2111.09296) by Arun Babu, Changhan Wang, Andros Tjandra, Kushal Lakhotia, Qiantong Xu, Naman Goyal, Kritika Singh, Patrick von Platen, Yatharth Saraf, Juan Pino, Alexei Baevski, Alexis Conneau, Michael Auli. | 1. **[XLS-R](model_doc/xls_r)** (from Facebook AI) released with the paper [XLS-R: Self-supervised Cross-lingual Speech Representation Learning at Scale](https://arxiv.org/abs/2111.09296) by Arun Babu, Changhan Wang, Andros Tjandra, Kushal Lakhotia, Qiantong Xu, Naman Goyal, Kritika Singh, Patrick von Platen, Yatharth Saraf, Juan Pino, Alexei Baevski, Alexis Conneau, Michael Auli. | ||||||
| 1. **[XLSR-Wav2Vec2](model_doc/xlsr_wav2vec2)** (from Facebook AI) released with the paper [Unsupervised Cross-Lingual Representation Learning For Speech Recognition](https://huggingface.co/papers/2006.13979) by Alexis Conneau, Alexei Baevski, Ronan Collobert, Abdelrahman Mohamed, Michael Auli. | 1. **[XLSR-Wav2Vec2](model_doc/xlsr_wav2vec2)** (from Facebook AI) released with the paper [Unsupervised Cross-Lingual Representation Learning For Speech Recognition](https://arxiv.org/abs/2006.13979) by Alexis Conneau, Alexei Baevski, Ronan Collobert, Abdelrahman Mohamed, Michael Auli. | ||||||
| 1. **[YOLOS](model_doc/yolos)** (from Huazhong University of Science & Technology) released with the paper [You Only Look at One Sequence: Rethinking Transformer in Vision through Object Detection](https://huggingface.co/papers/2106.00666) by Yuxin Fang, Bencheng Liao, Xinggang Wang, Jiemin Fang, Jiyang Qi, Rui Wu, Jianwei Niu, Wenyu Liu. | 1. **[YOLOS](model_doc/yolos)** (from Huazhong University of Science & Technology) released with the paper [You Only Look at One Sequence: Rethinking Transformer in Vision through Object Detection](https://arxiv.org/abs/2106.00666) by Yuxin Fang, Bencheng Liao, Xinggang Wang, Jiemin Fang, Jiyang Qi, Rui Wu, Jianwei Niu, Wenyu Liu. | ||||||
| 1. **[YOSO](model_doc/yoso)** (from the University of Wisconsin - Madison) released with the paper [You Only Sample (Almost) Once: Linear Cost Self-Attention Via Bernoulli Sampling](https://huggingface.co/papers/2111.09714) by Zhanpeng Zeng, Yunyang Xiong, Sathya N. Ravi, Shailesh Acharya, Glenn Fung, Vikas Singh. | 1. **[YOSO](model_doc/yoso)** (from the University of Wisconsin - Madison) released with the paper [You Only Sample (Almost) Once: Linear Cost Self-Attention Via Bernoulli Sampling](https://arxiv.org/abs/2111.09714) by Zhanpeng Zeng, Yunyang Xiong, Sathya N. Ravi, Shailesh Acharya, Glenn Fung, Vikas Singh. | ||||||
|  |  | ||||||
|  |  | ||||||
| ### Unterstützte Frameworks | ### Unterstützte Frameworks | ||||||
|  | |||||||
| @ -44,7 +44,7 @@ Transformers unterstützt nativ einige PEFT-Methoden, d.h. Sie können lokal ode | |||||||
|  |  | ||||||
| - [Low Rank Adapters](https://huggingface.co/docs/peft/conceptual_guides/lora) | - [Low Rank Adapters](https://huggingface.co/docs/peft/conceptual_guides/lora) | ||||||
| - [IA3](https://huggingface.co/docs/peft/conceptual_guides/ia3) | - [IA3](https://huggingface.co/docs/peft/conceptual_guides/ia3) | ||||||
| - [AdaLoRA](https://huggingface.co/papers/2303.10512) | - [AdaLoRA](https://arxiv.org/abs/2303.10512) | ||||||
|  |  | ||||||
| Wenn Sie andere PEFT-Methoden, wie z.B. Prompt Learning oder Prompt Tuning, verwenden möchten, oder über die 🤗 PEFT-Bibliothek im Allgemeinen, lesen Sie bitte die [Dokumentation](https://huggingface.co/docs/peft/index). | Wenn Sie andere PEFT-Methoden, wie z.B. Prompt Learning oder Prompt Tuning, verwenden möchten, oder über die 🤗 PEFT-Bibliothek im Allgemeinen, lesen Sie bitte die [Dokumentation](https://huggingface.co/docs/peft/index). | ||||||
|  |  | ||||||
|  | |||||||
| @ -156,7 +156,7 @@ Die [`pipeline`] kann jedes Modell aus dem [Model Hub](https://huggingface.co/mo | |||||||
|  |  | ||||||
| <frameworkcontent> | <frameworkcontent> | ||||||
| <pt> | <pt> | ||||||
| Use the [`AutoModelForSequenceClassification`] and [`AutoTokenizer`] to load the pretrained model and its associated tokenizer (more on an `AutoClass` below): | Use the [`AutoModelForSequenceClassification`] and [`AutoTokenizer`] to load the pretrained model and it's associated tokenizer (more on an `AutoClass` below): | ||||||
|  |  | ||||||
| ```py | ```py | ||||||
| >>> from transformers import AutoTokenizer, AutoModelForSequenceClassification | >>> from transformers import AutoTokenizer, AutoModelForSequenceClassification | ||||||
| @ -166,7 +166,7 @@ Use the [`AutoModelForSequenceClassification`] and [`AutoTokenizer`] to load the | |||||||
| ``` | ``` | ||||||
| </pt> | </pt> | ||||||
| <tf> | <tf> | ||||||
| Use the [`TFAutoModelForSequenceClassification`] and [`AutoTokenizer`] to load the pretrained model and its associated tokenizer (more on an `TFAutoClass` below): | Use the [`TFAutoModelForSequenceClassification`] and [`AutoTokenizer`] to load the pretrained model and it's associated tokenizer (more on an `TFAutoClass` below): | ||||||
|  |  | ||||||
| ```py | ```py | ||||||
| >>> from transformers import AutoTokenizer, TFAutoModelForSequenceClassification | >>> from transformers import AutoTokenizer, TFAutoModelForSequenceClassification | ||||||
| @ -222,7 +222,7 @@ Anschließend wandelt der Tokenizer die Token in Zahlen um, um einen Tensor als | |||||||
| Der Tokenizer gibt ein Wörterbuch zurück, das Folgendes enthält: | Der Tokenizer gibt ein Wörterbuch zurück, das Folgendes enthält: | ||||||
|  |  | ||||||
| * [input_ids](./glossary#input-ids): numerische Repräsentationen Ihrer Token. | * [input_ids](./glossary#input-ids): numerische Repräsentationen Ihrer Token. | ||||||
| * [attention_mask](.glossary#attention-mask): gibt an, welche Token beachtet werden sollen. | * [atttention_mask](.glossary#attention-mask): gibt an, welche Token beachtet werden sollen. | ||||||
|  |  | ||||||
| Genau wie die [`pipeline`] akzeptiert der Tokenizer eine Liste von Eingaben. Darüber hinaus kann der Tokenizer den Text auch auffüllen und kürzen, um einen Stapel mit einheitlicher Länge zurückzugeben: | Genau wie die [`pipeline`] akzeptiert der Tokenizer eine Liste von Eingaben. Darüber hinaus kann der Tokenizer den Text auch auffüllen und kürzen, um einen Stapel mit einheitlicher Länge zurückzugeben: | ||||||
|  |  | ||||||
|  | |||||||
| @ -18,7 +18,7 @@ rendered properly in your Markdown viewer. | |||||||
|  |  | ||||||
| Neben den 🤗 Transformers [notebooks](./notebooks) gibt es auch Beispielskripte, die zeigen, wie man ein Modell für eine Aufgabe mit [PyTorch](https://github.com/huggingface/transformers/tree/main/examples/pytorch), [TensorFlow](https://github.com/huggingface/transformers/tree/main/examples/tensorflow) oder [JAX/Flax](https://github.com/huggingface/transformers/tree/main/examples/flax) trainiert. | Neben den 🤗 Transformers [notebooks](./notebooks) gibt es auch Beispielskripte, die zeigen, wie man ein Modell für eine Aufgabe mit [PyTorch](https://github.com/huggingface/transformers/tree/main/examples/pytorch), [TensorFlow](https://github.com/huggingface/transformers/tree/main/examples/tensorflow) oder [JAX/Flax](https://github.com/huggingface/transformers/tree/main/examples/flax) trainiert. | ||||||
|  |  | ||||||
| Sie werden auch Skripte finden, die wir in unseren [Forschungsprojekten](https://github.com/huggingface/transformers-research-projects/) und [Legacy-Beispielen](https://github.com/huggingface/transformers/tree/main/examples/legacy) verwendet haben und die größtenteils von der Community stammen. Diese Skripte werden nicht aktiv gepflegt und erfordern eine bestimmte Version von 🤗 Transformers, die höchstwahrscheinlich nicht mit der neuesten Version der Bibliothek kompatibel ist. | Sie werden auch Skripte finden, die wir in unseren [Forschungsprojekten](https://github.com/huggingface/transformers/tree/main/examples/research_projects) und [Legacy-Beispielen](https://github.com/huggingface/transformers/tree/main/examples/legacy) verwendet haben und die größtenteils von der Community stammen. Diese Skripte werden nicht aktiv gepflegt und erfordern eine bestimmte Version von 🤗 Transformers, die höchstwahrscheinlich nicht mit der neuesten Version der Bibliothek kompatibel ist. | ||||||
|  |  | ||||||
| Es wird nicht erwartet, dass die Beispielskripte bei jedem Problem sofort funktionieren. Möglicherweise müssen Sie das Skript an das Problem anpassen, das Sie zu lösen versuchen. Um Ihnen dabei zu helfen, legen die meisten Skripte vollständig offen, wie die Daten vorverarbeitet werden, so dass Sie sie nach Bedarf für Ihren Anwendungsfall bearbeiten können. | Es wird nicht erwartet, dass die Beispielskripte bei jedem Problem sofort funktionieren. Möglicherweise müssen Sie das Skript an das Problem anpassen, das Sie zu lösen versuchen. Um Ihnen dabei zu helfen, legen die meisten Skripte vollständig offen, wie die Daten vorverarbeitet werden, so dass Sie sie nach Bedarf für Ihren Anwendungsfall bearbeiten können. | ||||||
|  |  | ||||||
|  | |||||||
							
								
								
									
										323
									
								
								docs/source/de/transformers_agents.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										323
									
								
								docs/source/de/transformers_agents.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,323 @@ | |||||||
|  | <!--Copyright 2023 The HuggingFace Team. All rights reserved. | ||||||
|  |  | ||||||
|  | Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with | ||||||
|  | the License. You may obtain a copy of the License at | ||||||
|  |  | ||||||
|  | http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  |  | ||||||
|  | Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on | ||||||
|  | an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the | ||||||
|  | specific language governing permissions and limitations under the License. | ||||||
|  |  | ||||||
|  | ⚠️ Note that this file is in Markdown but contain specific syntax for our doc-builder (similar to MDX) that may not be | ||||||
|  | rendered properly in your Markdown viewer. | ||||||
|  |  | ||||||
|  | --> | ||||||
|  |  | ||||||
|  | # Transformers Agents | ||||||
|  |  | ||||||
|  | <Tip warning={true}> | ||||||
|  |  | ||||||
|  | Transformers Agents ist eine experimentelle API, die jederzeit geändert werden kann. Die von den Agenten zurückgegebenen Ergebnisse | ||||||
|  | zurückgegeben werden, können variieren, da sich die APIs oder die zugrunde liegenden Modelle ändern können. | ||||||
|  |  | ||||||
|  | </Tip> | ||||||
|  |  | ||||||
|  | Transformers Version v4.29.0, die auf dem Konzept von *Tools* und *Agenten* aufbaut. Sie können damit spielen in | ||||||
|  | [dieses Colab](https://colab.research.google.com/drive/1c7MHD-T1forUPGcC_jlwsIptOzpG3hSj). | ||||||
|  |  | ||||||
|  | Kurz gesagt, es bietet eine API für natürliche Sprache auf der Grundlage von Transformers: Wir definieren eine Reihe von kuratierten Tools und entwerfen einen  | ||||||
|  | Agenten, um natürliche Sprache zu interpretieren und diese Werkzeuge zu verwenden. Es ist von vornherein erweiterbar; wir haben einige relevante Tools kuratiert,  | ||||||
|  | aber wir werden Ihnen zeigen, wie das System einfach erweitert werden kann, um jedes von der Community entwickelte Tool zu verwenden. | ||||||
|  |  | ||||||
|  | Beginnen wir mit einigen Beispielen dafür, was mit dieser neuen API erreicht werden kann. Sie ist besonders leistungsfähig, wenn es um  | ||||||
|  | Sie ist besonders leistungsstark, wenn es um multimodale Aufgaben geht. Lassen Sie uns also eine Runde drehen, um Bilder zu erzeugen und Text vorzulesen. | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | agent.run("Caption the following image", image=image) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | | **Input**                                                                                                                   | **Output**                        | | ||||||
|  | |-----------------------------------------------------------------------------------------------------------------------------|-----------------------------------| | ||||||
|  | | <img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/transformers/beaver.png" width=200> | A beaver is swimming in the water | | ||||||
|  |  | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | agent.run("Read the following text out loud", text=text) | ||||||
|  | ``` | ||||||
|  | | **Input**                                                                                                               | **Output**                                   | | ||||||
|  | |-------------------------------------------------------------------------------------------------------------------------|----------------------------------------------| | ||||||
|  | | A beaver is swimming in the water | <audio controls><source src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/transformers/tts_example.wav" type="audio/wav"> your browser does not support the audio element. </audio> | ||||||
|  |  | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | agent.run( | ||||||
|  |     "In the following `document`, where will the TRRF Scientific Advisory Council Meeting take place?", | ||||||
|  |     document=document, | ||||||
|  | ) | ||||||
|  | ``` | ||||||
|  | | **Input**                                                                                                                   | **Output**     | | ||||||
|  | |-----------------------------------------------------------------------------------------------------------------------------|----------------| | ||||||
|  | | <img src="https://datasets-server.huggingface.co/assets/hf-internal-testing/example-documents/--/hf-internal-testing--example-documents/test/0/image/image.jpg" width=200> | ballroom foyer | | ||||||
|  |  | ||||||
|  | ## Schnellstart | ||||||
|  |  | ||||||
|  | Bevor Sie `agent.run` verwenden können, müssen Sie einen Agenten instanziieren, der ein großes Sprachmodell (LLM) ist.  | ||||||
|  | Wir bieten Unterstützung für openAI-Modelle sowie für OpenSource-Alternativen von BigCode und OpenAssistant. Die openAI | ||||||
|  | Modelle sind leistungsfähiger (erfordern aber einen openAI-API-Schlüssel, können also nicht kostenlos verwendet werden); Hugging Face | ||||||
|  | bietet kostenlosen Zugang zu Endpunkten für BigCode- und OpenAssistant-Modelle. | ||||||
|  |  | ||||||
|  | To start with, please install the `agents` extras in order to install all default dependencies. | ||||||
|  | ```bash | ||||||
|  | pip install transformers[agents] | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Um openAI-Modelle zu verwenden, instanziieren Sie einen [`OpenAiAgent`], nachdem Sie die `openai`-Abhängigkeit installiert haben: | ||||||
|  |  | ||||||
|  | ```bash | ||||||
|  | pip install openai | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | from transformers import OpenAiAgent | ||||||
|  |  | ||||||
|  | agent = OpenAiAgent(model="text-davinci-003", api_key="<your_api_key>") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Um BigCode oder OpenAssistant zu verwenden, melden Sie sich zunächst an, um Zugriff auf die Inference API zu erhalten: | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | from huggingface_hub import login | ||||||
|  |  | ||||||
|  | login("<YOUR_TOKEN>") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Dann instanziieren Sie den Agenten | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | from transformers import HfAgent | ||||||
|  |  | ||||||
|  | # Starcoder | ||||||
|  | agent = HfAgent("https://api-inference.huggingface.co/models/bigcode/starcoder") | ||||||
|  | # StarcoderBase | ||||||
|  | # agent = HfAgent("https://api-inference.huggingface.co/models/bigcode/starcoderbase") | ||||||
|  | # OpenAssistant | ||||||
|  | # agent = HfAgent(url_endpoint="https://api-inference.huggingface.co/models/OpenAssistant/oasst-sft-4-pythia-12b-epoch-3.5") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Dies geschieht mit der Inferenz-API, die Hugging Face derzeit kostenlos zur Verfügung stellt. Wenn Sie Ihren eigenen Inferenz | ||||||
|  | Endpunkt für dieses Modell (oder einen anderen) haben, können Sie die obige URL durch Ihren URL-Endpunkt ersetzen. | ||||||
|  |  | ||||||
|  | <Tip> | ||||||
|  |  | ||||||
|  | StarCoder und OpenAssistant sind kostenlos und leisten bei einfachen Aufgaben bewundernswert gute Arbeit. Allerdings halten die Kontrollpunkte | ||||||
|  | nicht, wenn es um komplexere Aufforderungen geht. Wenn Sie mit einem solchen Problem konfrontiert sind, empfehlen wir Ihnen, das OpenAI | ||||||
|  | Modell auszuprobieren, das zwar leider nicht quelloffen ist, aber zur Zeit eine bessere Leistung erbringt. | ||||||
|  |  | ||||||
|  | </Tip> | ||||||
|  |  | ||||||
|  | Sie sind jetzt startklar! Lassen Sie uns in die beiden APIs eintauchen, die Ihnen jetzt zur Verfügung stehen. | ||||||
|  |  | ||||||
|  | ### Einzelne Ausführung (run) | ||||||
|  |  | ||||||
|  | Die Methode der einmaligen Ausführung ist die Verwendung der [`~Agent.run`] Methode des Agenten: | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | agent.run("Draw me a picture of rivers and lakes.") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | <img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/transformers/rivers_and_lakes.png" width=200> | ||||||
|  |  | ||||||
|  | Es wählt automatisch das (oder die) Werkzeug(e) aus, das (die) für die von Ihnen gewünschte Aufgabe geeignet ist (sind) und führt es (sie) entsprechend aus. Es | ||||||
|  | kann eine oder mehrere Aufgaben in der gleichen Anweisung ausführen (je komplexer Ihre Anweisung ist, desto wahrscheinlicher ist ein | ||||||
|  | der Agent scheitern). | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | agent.run("Draw me a picture of the sea then transform the picture to add an island") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | <img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/transformers/sea_and_island.png" width=200> | ||||||
|  |  | ||||||
|  | <br/> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Jede [`~Agent.run`] Operation ist unabhängig, so dass Sie sie mehrmals hintereinander mit unterschiedlichen Aufgaben ausführen können. | ||||||
|  |  | ||||||
|  | Beachten Sie, dass Ihr `Agent` nur ein großsprachiges Modell ist, so dass kleine Variationen in Ihrer Eingabeaufforderung völlig unterschiedliche Ergebnisse liefern können. | ||||||
|  | unterschiedliche Ergebnisse liefern. Es ist wichtig, dass Sie die Aufgabe, die Sie ausführen möchten, so genau wie möglich erklären. Wir gehen noch weiter ins Detail | ||||||
|  | wie man gute Prompts schreibt [hier](custom_tools#writing-good-user-inputs). | ||||||
|  |  | ||||||
|  | Wenn Sie einen Status über Ausführungszeiten hinweg beibehalten oder dem Agenten Nicht-Text-Objekte übergeben möchten, können Sie dies tun, indem Sie | ||||||
|  | Variablen, die der Agent verwenden soll. Sie könnten zum Beispiel das erste Bild von Flüssen und Seen erzeugen,  | ||||||
|  | und das Modell bitten, dieses Bild zu aktualisieren und eine Insel hinzuzufügen, indem Sie Folgendes tun: | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | picture = agent.run("Generate a picture of rivers and lakes.") | ||||||
|  | updated_picture = agent.run("Transform the image in `picture` to add an island to it.", picture=picture) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | <Tip> | ||||||
|  |  | ||||||
|  | Dies kann hilfreich sein, wenn das Modell Ihre Anfrage nicht verstehen kann und die Werkzeuge verwechselt. Ein Beispiel wäre: | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | agent.run("Draw me the picture of a capybara swimming in the sea") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Hier könnte das Modell auf zwei Arten interpretieren: | ||||||
|  | - Die Funktion `Text-zu-Bild` erzeugt ein Wasserschwein, das im Meer schwimmt. | ||||||
|  | - Oder Sie lassen das `Text-zu-Bild` ein Wasserschwein erzeugen und verwenden dann das Werkzeug `Bildtransformation`, um es im Meer schwimmen zu lassen. | ||||||
|  |  | ||||||
|  | Falls Sie das erste Szenario erzwingen möchten, können Sie dies tun, indem Sie die Eingabeaufforderung als Argument übergeben: | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | agent.run("Draw me a picture of the `prompt`", prompt="a capybara swimming in the sea") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | </Tip> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Chat-basierte Ausführung (Chat) | ||||||
|  |  | ||||||
|  | Der Agent verfügt auch über einen Chat-basierten Ansatz, der die Methode [`~Agent.chat`] verwendet: | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | agent.chat("Generate a picture of rivers and lakes") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | <img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/transformers/rivers_and_lakes.png" width=200>  | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | agent.chat("Transform the picture so that there is a rock in there") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | <img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/transformers/rivers_and_lakes_and_beaver.png" width=200> | ||||||
|  |  | ||||||
|  | <br/> | ||||||
|  |  | ||||||
|  | Dies ist ein interessanter Ansatz, wenn Sie den Zustand über Anweisungen hinweg beibehalten möchten. Er ist besser für Experimente geeignet,  | ||||||
|  | eignet sich aber eher für einzelne Anweisungen als für komplexe Anweisungen (die die [`~Agent.run`] | ||||||
|  | Methode besser verarbeiten kann). | ||||||
|  |  | ||||||
|  | Diese Methode kann auch Argumente entgegennehmen, wenn Sie Nicht-Text-Typen oder bestimmte Aufforderungen übergeben möchten. | ||||||
|  |  | ||||||
|  | ### ⚠️ Fernausführung | ||||||
|  |  | ||||||
|  | Zu Demonstrationszwecken und damit es mit allen Setups verwendet werden kann, haben wir Remote-Executors für mehrere  | ||||||
|  | der Standard-Tools erstellt, auf die der Agent in dieser Version Zugriff hat. Diese werden erstellt mit  | ||||||
|  | [inference endpoints](https://huggingface.co/inference-endpoints). | ||||||
|  |  | ||||||
|  | Wir haben diese vorerst deaktiviert, aber um zu sehen, wie Sie selbst Remote Executors Tools einrichten können, | ||||||
|  | empfehlen wir die Lektüre des [custom tool guide](./custom_tools). | ||||||
|  |  | ||||||
|  | ### Was passiert hier? Was sind Tools und was sind Agenten? | ||||||
|  |  | ||||||
|  | <img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/transformers/diagram.png"> | ||||||
|  |  | ||||||
|  | #### Agenten | ||||||
|  |  | ||||||
|  | Der "Agent" ist hier ein großes Sprachmodell, das wir auffordern, Zugang zu einem bestimmten Satz von Tools zu erhalten. | ||||||
|  |  | ||||||
|  | LLMs sind ziemlich gut darin, kleine Codeproben zu erzeugen. Diese API macht sich das zunutze, indem sie das  | ||||||
|  | LLM ein kleines Codebeispiel gibt, das eine Aufgabe mit einer Reihe von Werkzeugen ausführt. Diese Aufforderung wird dann ergänzt durch die  | ||||||
|  | Aufgabe, die Sie Ihrem Agenten geben, und die Beschreibung der Werkzeuge, die Sie ihm geben. Auf diese Weise erhält er Zugriff auf die Dokumentation der  | ||||||
|  | Tools, insbesondere die erwarteten Eingaben und Ausgaben, und kann den entsprechenden Code generieren. | ||||||
|  |  | ||||||
|  | #### Tools | ||||||
|  |  | ||||||
|  | Tools sind sehr einfach: Sie bestehen aus einer einzigen Funktion mit einem Namen und einer Beschreibung. Wir verwenden dann die Beschreibungen dieser Tools  | ||||||
|  | um den Agenten aufzufordern. Anhand der Eingabeaufforderung zeigen wir dem Agenten, wie er die Tools nutzen kann, um das zu tun, was in der  | ||||||
|  | in der Abfrage angefordert wurde. | ||||||
|  |  | ||||||
|  | Dies geschieht mit brandneuen Tools und nicht mit Pipelines, denn der Agent schreibt besseren Code mit sehr atomaren Tools.  | ||||||
|  | Pipelines sind stärker refaktorisiert und fassen oft mehrere Aufgaben in einer einzigen zusammen. Tools sind dafür gedacht, sich auf | ||||||
|  | eine einzige, sehr einfache Aufgabe konzentrieren. | ||||||
|  |  | ||||||
|  | #### Code-Ausführung?! | ||||||
|  |  | ||||||
|  | Dieser Code wird dann mit unserem kleinen Python-Interpreter auf den mit Ihren Tools übergebenen Eingaben ausgeführt.  | ||||||
|  | Wir hören Sie schon schreien "Willkürliche Codeausführung!", aber lassen Sie uns erklären, warum das nicht der Fall ist. | ||||||
|  |  | ||||||
|  | Die einzigen Funktionen, die aufgerufen werden können, sind die von Ihnen zur Verfügung gestellten Tools und die Druckfunktion, so dass Sie bereits eingeschränkt sind  | ||||||
|  | eingeschränkt, was ausgeführt werden kann. Sie sollten sicher sein, wenn es sich auf die Werkzeuge für das Umarmungsgesicht beschränkt.  | ||||||
|  |  | ||||||
|  | Dann lassen wir keine Attributsuche oder Importe zu (die ohnehin nicht benötigt werden, um die  | ||||||
|  | Inputs/Outputs an eine kleine Gruppe von Funktionen), so dass alle offensichtlichen Angriffe (und Sie müssten den LLM  | ||||||
|  | dazu auffordern, sie auszugeben) kein Problem darstellen sollten. Wenn Sie auf Nummer sicher gehen wollen, können Sie die  | ||||||
|  | run()-Methode mit dem zusätzlichen Argument return_code=True ausführen. In diesem Fall gibt der Agent nur den auszuführenden Code  | ||||||
|  | zur Ausführung zurück und Sie können entscheiden, ob Sie ihn ausführen möchten oder nicht. | ||||||
|  |  | ||||||
|  | Die Ausführung bricht bei jeder Zeile ab, in der versucht wird, eine illegale Operation auszuführen, oder wenn ein regulärer Python-Fehler  | ||||||
|  | mit dem vom Agenten generierten Code. | ||||||
|  |  | ||||||
|  | ### Ein kuratierter Satz von Tools | ||||||
|  |  | ||||||
|  | Wir haben eine Reihe von Tools identifiziert, die solche Agenten unterstützen können. Hier ist eine aktualisierte Liste der Tools, die wir integriert haben  | ||||||
|  | in `transformers` integriert haben: | ||||||
|  |  | ||||||
|  | - **Beantwortung von Fragen zu Dokumenten**: Beantworten Sie anhand eines Dokuments (z.B. PDF) im Bildformat eine Frage zu diesem Dokument ([Donut](./model_doc/donut)) | ||||||
|  | - Beantworten von Textfragen**: Geben Sie einen langen Text und eine Frage an, beantworten Sie die Frage im Text ([Flan-T5](./model_doc/flan-t5)) | ||||||
|  | - **Unbedingte Bildunterschriften**: Beschriften Sie das Bild! ([BLIP](./model_doc/blip)) | ||||||
|  | - **Bildfragebeantwortung**: Beantworten Sie bei einem Bild eine Frage zu diesem Bild ([VILT](./model_doc/vilt)) | ||||||
|  | - **Bildsegmentierung**: Geben Sie ein Bild und einen Prompt an und geben Sie die Segmentierungsmaske dieses Prompts aus ([CLIPSeg](./model_doc/clipseg)) | ||||||
|  | - **Sprache in Text**: Geben Sie eine Audioaufnahme einer sprechenden Person an und transkribieren Sie die Sprache in Text ([Whisper](./model_doc/whisper)) | ||||||
|  | - **Text in Sprache**: wandelt Text in Sprache um ([SpeechT5](./model_doc/speecht5)) | ||||||
|  | - **Zero-Shot-Textklassifizierung**: Ermitteln Sie anhand eines Textes und einer Liste von Bezeichnungen, welcher Bezeichnung der Text am ehesten entspricht ([BART](./model_doc/bart)) | ||||||
|  | - **Textzusammenfassung**: fassen Sie einen langen Text in einem oder wenigen Sätzen zusammen ([BART](./model_doc/bart)) | ||||||
|  | - **Übersetzung**: Übersetzen des Textes in eine bestimmte Sprache ([NLLB](./model_doc/nllb)) | ||||||
|  |  | ||||||
|  | Diese Tools sind in Transformatoren integriert und können auch manuell verwendet werden, zum Beispiel: | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | from transformers import load_tool | ||||||
|  |  | ||||||
|  | tool = load_tool("text-to-speech") | ||||||
|  | audio = tool("This is a text to speech tool") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### Benutzerdefinierte Tools | ||||||
|  |  | ||||||
|  | Wir haben zwar eine Reihe von Tools identifiziert, sind aber der festen Überzeugung, dass der Hauptwert dieser Implementierung darin besteht  | ||||||
|  | die Möglichkeit, benutzerdefinierte Tools schnell zu erstellen und weiterzugeben. | ||||||
|  |  | ||||||
|  | Indem Sie den Code eines Tools in einen Hugging Face Space oder ein Modell-Repository stellen, können Sie das Tool  | ||||||
|  | direkt mit dem Agenten nutzen. Wir haben ein paar neue Funktionen hinzugefügt  | ||||||
|  | **transformers-agnostic** Tools zur [`huggingface-tools` Organisation](https://huggingface.co/huggingface-tools) hinzugefügt: | ||||||
|  |  | ||||||
|  | - **Text-Downloader**: zum Herunterladen eines Textes von einer Web-URL | ||||||
|  | - **Text zu Bild**: erzeugt ein Bild nach einer Eingabeaufforderung und nutzt dabei stabile Diffusion | ||||||
|  | - **Bildtransformation**: verändert ein Bild anhand eines Ausgangsbildes und einer Eingabeaufforderung, unter Ausnutzung der stabilen pix2pix-Diffusion | ||||||
|  | - **Text zu Video**: Erzeugen eines kleinen Videos nach einer Eingabeaufforderung, unter Verwendung von damo-vilab | ||||||
|  |  | ||||||
|  | Das Text-zu-Bild-Tool, das wir von Anfang an verwendet haben, ist ein Remote-Tool, das sich in  | ||||||
|  | [*huggingface-tools/text-to-image*](https://huggingface.co/spaces/huggingface-tools/text-to-image)! Wir werden | ||||||
|  | weiterhin solche Tools für diese und andere Organisationen veröffentlichen, um diese Implementierung weiter zu verbessern. | ||||||
|  |  | ||||||
|  | Die Agenten haben standardmäßig Zugriff auf die Tools, die sich auf [*huggingface-tools*](https://huggingface.co/huggingface-tools) befinden. | ||||||
|  | Wie Sie Ihre eigenen Tools schreiben und freigeben können und wie Sie jedes benutzerdefinierte Tool, das sich auf dem Hub befindet, nutzen können, erklären wir in [folgender Anleitung](custom_tools). | ||||||
|  |  | ||||||
|  | ### Code-Erzeugung | ||||||
|  |  | ||||||
|  | Bisher haben wir gezeigt, wie Sie die Agenten nutzen können, um Aktionen für Sie durchzuführen. Der Agent generiert jedoch nur Code | ||||||
|  | den wir dann mit einem sehr eingeschränkten Python-Interpreter ausführen. Falls Sie den generierten Code in einer anderen Umgebung verwenden möchten  | ||||||
|  | einer anderen Umgebung verwenden möchten, können Sie den Agenten auffordern, den Code zusammen mit einer Tooldefinition und genauen Importen zurückzugeben. | ||||||
|  |  | ||||||
|  | Zum Beispiel die folgende Anweisung | ||||||
|  | ```python | ||||||
|  | agent.run("Draw me a picture of rivers and lakes", return_code=True) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | gibt den folgenden Code zurück | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | from transformers import load_tool | ||||||
|  |  | ||||||
|  | image_generator = load_tool("huggingface-tools/text-to-image") | ||||||
|  |  | ||||||
|  | image = image_generator(prompt="rivers and lakes") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | die Sie dann selbst ändern und ausführen können. | ||||||
| @ -1,317 +1,281 @@ | |||||||
| - sections: | - sections: | ||||||
|   - local: index |   - local: index | ||||||
|     title: Transformers |     title: 🤗 Transformers | ||||||
|  |   - local: quicktour | ||||||
|  |     title: Quick tour | ||||||
|   - local: installation |   - local: installation | ||||||
|     title: Installation |     title: Installation | ||||||
|   - local: quicktour |   - local: add_new_model | ||||||
|     title: Quickstart |     title: Adding a new model to `transformers` | ||||||
|   title: Get started |   title: Get started | ||||||
| - isExpanded: false | - sections: | ||||||
|   sections: |   - local: pipeline_tutorial | ||||||
|   - sections: |     title: Run inference with pipelines | ||||||
|     - local: models |   - local: autoclass_tutorial | ||||||
|       title: Loading models |     title: Write portable code with AutoClass | ||||||
|     - local: custom_models |   - local: preprocessing | ||||||
|       title: Customizing models |     title: Preprocess data | ||||||
|     - local: how_to_hack_models |   - local: training | ||||||
|       title: Customizing model components |     title: Fine-tune a pretrained model | ||||||
|     - local: model_sharing |  | ||||||
|       title: Sharing |  | ||||||
|     - local: add_new_model |  | ||||||
|       title: Adding a new model to Transformers |  | ||||||
|     - local: modular_transformers |  | ||||||
|       title: Modular Transformers |  | ||||||
|     - local: auto_docstring |  | ||||||
|       title: Document your models |  | ||||||
|     - local: attention_interface |  | ||||||
|       title: Customizing attention function |  | ||||||
|     title: Models |  | ||||||
|   - sections: |  | ||||||
|     - local: fast_tokenizers |  | ||||||
|       title: Tokenizers |  | ||||||
|     - local: image_processors |  | ||||||
|       title: Image processors |  | ||||||
|     - local: video_processors |  | ||||||
|       title: Video processors |  | ||||||
|     - local: backbones |  | ||||||
|       title: Backbones |  | ||||||
|     - local: feature_extractors |  | ||||||
|       title: Feature extractors |  | ||||||
|     - local: processors |  | ||||||
|       title: Processors |  | ||||||
|     - local: tokenizer_summary |  | ||||||
|       title: Summary of the tokenizers |  | ||||||
|     - local: pad_truncation |  | ||||||
|       title: Padding and truncation |  | ||||||
|     title: Preprocessors |  | ||||||
|   title: Base classes |  | ||||||
| - isExpanded: false |  | ||||||
|   sections: |  | ||||||
|   - sections: |  | ||||||
|     - local: pipeline_tutorial |  | ||||||
|       title: Pipeline |  | ||||||
|     - local: pipeline_gradio |  | ||||||
|       title: Machine learning apps |  | ||||||
|     - local: pipeline_webserver |  | ||||||
|       title: Web server inference |  | ||||||
|     - local: add_new_pipeline |  | ||||||
|       title: Adding a new pipeline |  | ||||||
|     title: Pipeline API |  | ||||||
|   - sections: |  | ||||||
|     - local: llm_tutorial |  | ||||||
|       title: Text generation |  | ||||||
|     - local: generation_strategies |  | ||||||
|       title: Generation strategies |  | ||||||
|     - local: generation_features |  | ||||||
|       title: Generation features |  | ||||||
|     - local: tasks/prompting |  | ||||||
|       title: Prompt engineering |  | ||||||
|     - local: llm_optims |  | ||||||
|       title: Optimizing inference |  | ||||||
|     - local: cache_explanation |  | ||||||
|       title: Caching |  | ||||||
|     - local: kv_cache |  | ||||||
|       title: KV cache strategies |  | ||||||
|     - local: serving |  | ||||||
|       title: Serving |  | ||||||
|     - local: llm_tutorial_optimization |  | ||||||
|       title: Getting the most out of LLMs |  | ||||||
|     - local: perplexity |  | ||||||
|       title: Perplexity of fixed-length models |  | ||||||
|     title: LLMs |  | ||||||
|   - sections: |  | ||||||
|     - local: conversations |  | ||||||
|       title: Chat basics |  | ||||||
|     - local: chat_templating |  | ||||||
|       title: Templates |  | ||||||
|     - local: chat_templating_multimodal |  | ||||||
|       title: Multimodal templates |  | ||||||
|     - local: chat_templating_writing |  | ||||||
|       title: Template writing |  | ||||||
|     - local: chat_extras |  | ||||||
|       title: Tools and RAG |  | ||||||
|     title: Chat with models |  | ||||||
|   - sections: |  | ||||||
|     - local: perf_torch_compile |  | ||||||
|       title: torch.compile |  | ||||||
|     - local: perf_infer_gpu_one |  | ||||||
|       title: GPU |  | ||||||
|     - local: perf_infer_gpu_multi |  | ||||||
|       title: Distributed GPU inference |  | ||||||
|     - local: perf_infer_cpu |  | ||||||
|       title: CPU |  | ||||||
|     - local: tf_xla |  | ||||||
|       title: XLA |  | ||||||
|     title: Optimization |  | ||||||
|   - local: agents |  | ||||||
|     title: Agents |  | ||||||
|   - local: tools |  | ||||||
|     title: Tools |  | ||||||
|   title: Inference |  | ||||||
| - isExpanded: false |  | ||||||
|   sections: |  | ||||||
|   - sections: |  | ||||||
|     - local: trainer |  | ||||||
|       title: Trainer |  | ||||||
|     - local: training |  | ||||||
|       title: Fine-tuning |  | ||||||
|     - local: optimizers |  | ||||||
|       title: Optimizers |  | ||||||
|     - local: hpo_train |  | ||||||
|       title: Hyperparameter search |  | ||||||
|     title: Trainer API |  | ||||||
|   - sections: |  | ||||||
|     - local: accelerator_selection |  | ||||||
|       title: Accelerator selection |  | ||||||
|     - local: accelerate |  | ||||||
|       title: Accelerate |  | ||||||
|     - local: fsdp |  | ||||||
|       title: FullyShardedDataParallel |  | ||||||
|     - local: deepspeed |  | ||||||
|       title: DeepSpeed |  | ||||||
|     - local: debugging |  | ||||||
|       title: Multi-GPU debugging |  | ||||||
|     - local: perf_train_cpu_many |  | ||||||
|       title: Distributed CPUs |  | ||||||
|     - local: perf_train_gpu_many |  | ||||||
|       title: Parallelism methods |  | ||||||
|     title: Distributed training |  | ||||||
|   - sections: |  | ||||||
|     - local: perf_train_gpu_one |  | ||||||
|       title: GPU |  | ||||||
|     - local: perf_train_cpu |  | ||||||
|       title: CPU |  | ||||||
|     - local: perf_train_tpu_tf |  | ||||||
|       title: TPU |  | ||||||
|     - local: perf_train_special |  | ||||||
|       title: Apple Silicon |  | ||||||
|     - local: perf_train_gaudi |  | ||||||
|       title: Intel Gaudi |  | ||||||
|     - local: perf_hardware |  | ||||||
|       title: Build your own machine |  | ||||||
|     title: Hardware |  | ||||||
|   - local: peft |  | ||||||
|     title: PEFT |  | ||||||
|   - local: model_memory_anatomy |  | ||||||
|     title: Model training anatomy |  | ||||||
|   title: Training |  | ||||||
| - isExpanded: false |  | ||||||
|   sections: |  | ||||||
|   - local: quantization/overview |  | ||||||
|     title: Overview |  | ||||||
|   - local: quantization/selecting |  | ||||||
|     title: Selecting a quantization method |  | ||||||
|   - local: quantization/concept_guide |  | ||||||
|     title: Quantization concepts |  | ||||||
|   - local: quantization/aqlm |  | ||||||
|     title: AQLM |  | ||||||
|   - local: quantization/auto_round |  | ||||||
|     title: AutoRound |  | ||||||
|   - local: quantization/awq |  | ||||||
|     title: AWQ |  | ||||||
|   - local: quantization/bitnet |  | ||||||
|     title: BitNet |  | ||||||
|   - local: quantization/bitsandbytes |  | ||||||
|     title: bitsandbytes |  | ||||||
|   - local: quantization/compressed_tensors |  | ||||||
|     title: compressed-tensors |  | ||||||
|   - local: quantization/eetq |  | ||||||
|     title: EETQ |  | ||||||
|   - local: quantization/fbgemm_fp8 |  | ||||||
|     title: FBGEMM |  | ||||||
|   - local: quantization/finegrained_fp8 |  | ||||||
|     title: Fine-grained FP8 |  | ||||||
|   - local: gguf |  | ||||||
|     title: GGUF |  | ||||||
|   - local: quantization/gptq |  | ||||||
|     title: GPTQ |  | ||||||
|   - local: quantization/higgs |  | ||||||
|     title: HIGGS |  | ||||||
|   - local: quantization/hqq |  | ||||||
|     title: HQQ |  | ||||||
|   - local: quantization/optimum |  | ||||||
|     title: Optimum |  | ||||||
|   - local: quantization/quanto |  | ||||||
|     title: Quanto |  | ||||||
|   - local: quantization/quark |  | ||||||
|     title: Quark |  | ||||||
|   - local: quantization/torchao |  | ||||||
|     title: torchao |  | ||||||
|   - local: quantization/spqr |  | ||||||
|     title: SpQR |  | ||||||
|   - local: quantization/vptq |  | ||||||
|     title: VPTQ |  | ||||||
|   - local: quantization/contribute |  | ||||||
|     title: Contribute |  | ||||||
|   title: Quantization |  | ||||||
| - isExpanded: false |  | ||||||
|   sections: |  | ||||||
|   - local: serialization |  | ||||||
|     title: ONNX |  | ||||||
|   - local: tflite |  | ||||||
|     title: LiteRT |  | ||||||
|   - local: executorch |  | ||||||
|     title: ExecuTorch |  | ||||||
|   - local: torchscript |  | ||||||
|     title: TorchScript |  | ||||||
|   title: Export to production |  | ||||||
| - isExpanded: false |  | ||||||
|   sections: |  | ||||||
|   - sections: |  | ||||||
|     - sections: |  | ||||||
|       - local: tasks/sequence_classification |  | ||||||
|         title: Text classification |  | ||||||
|       - local: tasks/token_classification |  | ||||||
|         title: Token classification |  | ||||||
|       - local: tasks/question_answering |  | ||||||
|         title: Question answering |  | ||||||
|       - local: tasks/language_modeling |  | ||||||
|         title: Causal language modeling |  | ||||||
|       - local: tasks/masked_language_modeling |  | ||||||
|         title: Masked language modeling |  | ||||||
|       - local: tasks/translation |  | ||||||
|         title: Translation |  | ||||||
|       - local: tasks/summarization |  | ||||||
|         title: Summarization |  | ||||||
|       - local: tasks/multiple_choice |  | ||||||
|         title: Multiple choice |  | ||||||
|       title: Natural language processing |  | ||||||
|     - sections: |  | ||||||
|       - local: tasks/audio_classification |  | ||||||
|         title: Audio classification |  | ||||||
|       - local: tasks/asr |  | ||||||
|         title: Automatic speech recognition |  | ||||||
|       title: Audio |  | ||||||
|     - sections: |  | ||||||
|       - local: tasks/image_classification |  | ||||||
|         title: Image classification |  | ||||||
|       - local: tasks/semantic_segmentation |  | ||||||
|         title: Image segmentation |  | ||||||
|       - local: tasks/video_classification |  | ||||||
|         title: Video classification |  | ||||||
|       - local: tasks/object_detection |  | ||||||
|         title: Object detection |  | ||||||
|       - local: tasks/zero_shot_object_detection |  | ||||||
|         title: Zero-shot object detection |  | ||||||
|       - local: tasks/zero_shot_image_classification |  | ||||||
|         title: Zero-shot image classification |  | ||||||
|       - local: tasks/monocular_depth_estimation |  | ||||||
|         title: Depth estimation |  | ||||||
|       - local: tasks/image_to_image |  | ||||||
|         title: Image-to-Image |  | ||||||
|       - local: tasks/image_feature_extraction |  | ||||||
|         title: Image Feature Extraction |  | ||||||
|       - local: tasks/mask_generation |  | ||||||
|         title: Mask Generation |  | ||||||
|       - local: tasks/keypoint_detection |  | ||||||
|         title: Keypoint detection |  | ||||||
|       - local: tasks/knowledge_distillation_for_image_classification |  | ||||||
|         title: Knowledge Distillation for Computer Vision |  | ||||||
|       title: Computer vision |  | ||||||
|     - sections: |  | ||||||
|       - local: tasks/image_captioning |  | ||||||
|         title: Image captioning |  | ||||||
|       - local: tasks/document_question_answering |  | ||||||
|         title: Document Question Answering |  | ||||||
|       - local: tasks/visual_question_answering |  | ||||||
|         title: Visual Question Answering |  | ||||||
|       - local: tasks/text-to-speech |  | ||||||
|         title: Text to speech |  | ||||||
|       - local: tasks/idefics |  | ||||||
|         title: Image tasks with IDEFICS |  | ||||||
|       - local: tasks/image_text_to_text |  | ||||||
|         title: Image-text-to-text |  | ||||||
|       - local: tasks/video_text_to_text |  | ||||||
|         title: Video-text-to-text |  | ||||||
|       - local: tasks/visual_document_retrieval |  | ||||||
|         title: Visual Document Retrieval |  | ||||||
|       title: Multimodal |  | ||||||
|     title: Task recipes |  | ||||||
|   - local: run_scripts |   - local: run_scripts | ||||||
|     title: Training scripts |     title: Train with a script | ||||||
|   - local: glossary |   - local: accelerate | ||||||
|     title: Glossary |     title: Set up distributed training with 🤗 Accelerate | ||||||
|   - local: philosophy |   - local: peft | ||||||
|     title: Philosophy |     title: Load and train adapters with 🤗 PEFT | ||||||
|  |   - local: model_sharing | ||||||
|  |     title: Share your model | ||||||
|  |   - local: agents | ||||||
|  |     title: Agents 101 | ||||||
|  |   - local: agents_advanced | ||||||
|  |     title: Agents, supercharged - Multi-agents, External tools, and more | ||||||
|  |   - local: llm_tutorial | ||||||
|  |     title: Generation with LLMs | ||||||
|  |   - local: conversations | ||||||
|  |     title: Chatting with Transformers | ||||||
|  |   title: Tutorials | ||||||
|  | - sections: | ||||||
|  |   - isExpanded: false | ||||||
|  |     sections: | ||||||
|  |     - local: tasks/sequence_classification | ||||||
|  |       title: Text classification | ||||||
|  |     - local: tasks/token_classification | ||||||
|  |       title: Token classification | ||||||
|  |     - local: tasks/question_answering | ||||||
|  |       title: Question answering | ||||||
|  |     - local: tasks/language_modeling | ||||||
|  |       title: Causal language modeling | ||||||
|  |     - local: tasks/masked_language_modeling | ||||||
|  |       title: Masked language modeling | ||||||
|  |     - local: tasks/translation | ||||||
|  |       title: Translation | ||||||
|  |     - local: tasks/summarization | ||||||
|  |       title: Summarization | ||||||
|  |     - local: tasks/multiple_choice | ||||||
|  |       title: Multiple choice | ||||||
|  |     title: Natural Language Processing | ||||||
|  |   - isExpanded: false | ||||||
|  |     sections: | ||||||
|  |     - local: tasks/audio_classification | ||||||
|  |       title: Audio classification | ||||||
|  |     - local: tasks/asr | ||||||
|  |       title: Automatic speech recognition | ||||||
|  |     title: Audio | ||||||
|  |   - isExpanded: false | ||||||
|  |     sections: | ||||||
|  |     - local: tasks/image_classification | ||||||
|  |       title: Image classification | ||||||
|  |     - local: tasks/semantic_segmentation | ||||||
|  |       title: Image segmentation | ||||||
|  |     - local: tasks/video_classification | ||||||
|  |       title: Video classification | ||||||
|  |     - local: tasks/object_detection | ||||||
|  |       title: Object detection | ||||||
|  |     - local: tasks/zero_shot_object_detection | ||||||
|  |       title: Zero-shot object detection | ||||||
|  |     - local: tasks/zero_shot_image_classification | ||||||
|  |       title: Zero-shot image classification | ||||||
|  |     - local: tasks/monocular_depth_estimation | ||||||
|  |       title: Depth estimation | ||||||
|  |     - local: tasks/image_to_image | ||||||
|  |       title: Image-to-Image | ||||||
|  |     - local: tasks/image_feature_extraction | ||||||
|  |       title: Image Feature Extraction | ||||||
|  |     - local: tasks/mask_generation | ||||||
|  |       title: Mask Generation | ||||||
|  |     - local: tasks/keypoint_detection | ||||||
|  |       title: Keypoint Detection | ||||||
|  |     - local: tasks/knowledge_distillation_for_image_classification | ||||||
|  |       title: Knowledge Distillation for Computer Vision | ||||||
|  |     title: Computer Vision | ||||||
|  |   - isExpanded: false | ||||||
|  |     sections: | ||||||
|  |     - local: tasks/image_captioning | ||||||
|  |       title: Image captioning | ||||||
|  |     - local: tasks/document_question_answering | ||||||
|  |       title: Document Question Answering | ||||||
|  |     - local: tasks/visual_question_answering | ||||||
|  |       title: Visual Question Answering | ||||||
|  |     - local: tasks/text-to-speech | ||||||
|  |       title: Text to speech | ||||||
|  |     - local: tasks/image_text_to_text | ||||||
|  |       title: Image-text-to-text | ||||||
|  |     - local: tasks/video_text_to_text | ||||||
|  |       title: Video-text-to-text | ||||||
|  |     title: Multimodal | ||||||
|  |   - isExpanded: false | ||||||
|  |     sections: | ||||||
|  |     - local: generation_strategies | ||||||
|  |       title: Customize the generation strategy | ||||||
|  |     - local: kv_cache | ||||||
|  |       title: Best Practices for Generation with Cache | ||||||
|  |     title: Generation | ||||||
|  |   - isExpanded: false | ||||||
|  |     sections: | ||||||
|  |     - local: tasks/idefics | ||||||
|  |       title: Image tasks with IDEFICS | ||||||
|  |     - local: tasks/prompting | ||||||
|  |       title: LLM prompting guide | ||||||
|  |     title: Prompting | ||||||
|  |   title: Task Guides | ||||||
|  | - sections: | ||||||
|  |   - local: fast_tokenizers | ||||||
|  |     title: Use fast tokenizers from 🤗 Tokenizers | ||||||
|  |   - local: multilingual | ||||||
|  |     title: Run inference with multilingual models | ||||||
|  |   - local: create_a_model | ||||||
|  |     title: Use model-specific APIs | ||||||
|  |   - local: custom_models | ||||||
|  |     title: Share a custom model | ||||||
|  |   - local: chat_templating | ||||||
|  |     title: Chat templates | ||||||
|  |   - local: trainer | ||||||
|  |     title: Trainer | ||||||
|  |   - local: sagemaker | ||||||
|  |     title: Run training on Amazon SageMaker | ||||||
|  |   - local: serialization | ||||||
|  |     title: Export to ONNX | ||||||
|  |   - local: tflite | ||||||
|  |     title: Export to TFLite | ||||||
|  |   - local: torchscript | ||||||
|  |     title: Export to TorchScript | ||||||
|   - local: notebooks |   - local: notebooks | ||||||
|     title: Notebooks with examples |     title: Notebooks with examples | ||||||
|   - local: community |   - local: community | ||||||
|     title: Community resources |     title: Community resources | ||||||
|   - local: troubleshooting |   - local: troubleshooting | ||||||
|     title: Troubleshoot |     title: Troubleshoot | ||||||
|   title: Resources |   - local: gguf | ||||||
| - isExpanded: false |     title: Interoperability with GGUF files | ||||||
|   sections: |   - local: tiktoken | ||||||
|   - local: contributing |     title: Interoperability with TikToken files | ||||||
|     title: Contribute to Transformers |   - local: modular_transformers | ||||||
|   - local: testing |     title: Modularity in `transformers` | ||||||
|     title: Transformers model tests |   - local: how_to_hack_models | ||||||
|   - local: pr_checks |     title: Model Hacking (overwriting a class to your usage) | ||||||
|     title: Pull request checks |   title: Developer guides | ||||||
|   title: Contribute | - sections: | ||||||
| - isExpanded: false |   - local: quantization/overview | ||||||
|   sections: |     title: Getting started | ||||||
|  |   - local: quantization/bitsandbytes | ||||||
|  |     title: bitsandbytes | ||||||
|  |   - local: quantization/gptq | ||||||
|  |     title: GPTQ | ||||||
|  |   - local: quantization/awq | ||||||
|  |     title: AWQ | ||||||
|  |   - local: quantization/aqlm | ||||||
|  |     title: AQLM | ||||||
|  |   - local: quantization/vptq | ||||||
|  |     title: VPTQ | ||||||
|  |   - local: quantization/quanto | ||||||
|  |     title: Quanto | ||||||
|  |   - local: quantization/eetq | ||||||
|  |     title: EETQ | ||||||
|  |   - local: quantization/higgs | ||||||
|  |     title: HIGGS | ||||||
|  |   - local: quantization/hqq | ||||||
|  |     title: HQQ | ||||||
|  |   - local: quantization/fbgemm_fp8 | ||||||
|  |     title: FBGEMM_FP8 | ||||||
|  |   - local: quantization/optimum | ||||||
|  |     title: Optimum | ||||||
|  |   - local: quantization/torchao | ||||||
|  |     title: TorchAO | ||||||
|  |   - local: quantization/bitnet | ||||||
|  |     title: BitNet | ||||||
|  |   - local: quantization/compressed_tensors | ||||||
|  |     title: compressed-tensors | ||||||
|  |   - local: quantization/contribute | ||||||
|  |     title: Contribute new quantization method | ||||||
|  |   title: Quantization Methods | ||||||
|  | - sections: | ||||||
|  |   - local: performance | ||||||
|  |     title: Overview | ||||||
|  |   - local: llm_optims | ||||||
|  |     title: LLM inference optimization | ||||||
|   - sections: |   - sections: | ||||||
|  |     - local: perf_train_gpu_one | ||||||
|  |       title: Methods and tools for efficient training on a single GPU | ||||||
|  |     - local: perf_train_gpu_many | ||||||
|  |       title: Multiple GPUs and parallelism | ||||||
|  |     - local: fsdp | ||||||
|  |       title: Fully Sharded Data Parallel | ||||||
|  |     - local: deepspeed | ||||||
|  |       title: DeepSpeed | ||||||
|  |     - local: perf_train_cpu | ||||||
|  |       title: Efficient training on CPU | ||||||
|  |     - local: perf_train_cpu_many | ||||||
|  |       title: Distributed CPU training | ||||||
|  |     - local: perf_train_tpu_tf | ||||||
|  |       title: Training on TPU with TensorFlow | ||||||
|  |     - local: perf_train_special | ||||||
|  |       title: PyTorch training on Apple silicon | ||||||
|  |     - local: perf_hardware | ||||||
|  |       title: Custom hardware for training | ||||||
|  |     - local: hpo_train | ||||||
|  |       title: Hyperparameter Search using Trainer API | ||||||
|  |     title: Efficient training techniques | ||||||
|  |   - sections: | ||||||
|  |     - local: perf_infer_cpu | ||||||
|  |       title: CPU inference | ||||||
|  |     - local: perf_infer_gpu_one | ||||||
|  |       title: GPU inference | ||||||
|  |     - local: perf_infer_gpu_multi | ||||||
|  |       title: Multi-GPU inference | ||||||
|  |     title: Optimizing inference | ||||||
|  |   - local: big_models | ||||||
|  |     title: Instantiate a big model | ||||||
|  |   - local: debugging | ||||||
|  |     title: Debugging | ||||||
|  |   - local: tf_xla | ||||||
|  |     title: XLA Integration for TensorFlow Models | ||||||
|  |   - local: perf_torch_compile | ||||||
|  |     title: Optimize inference using `torch.compile()` | ||||||
|  |   title: Performance and scalability | ||||||
|  | - sections: | ||||||
|  |   - local: contributing | ||||||
|  |     title: How to contribute to 🤗 Transformers? | ||||||
|  |   - local: add_new_model | ||||||
|  |     title: How to add a model to 🤗 Transformers? | ||||||
|  |   - local: add_new_pipeline | ||||||
|  |     title: How to add a pipeline to 🤗 Transformers? | ||||||
|  |   - local: testing | ||||||
|  |     title: Testing | ||||||
|  |   - local: pr_checks | ||||||
|  |     title: Checks on a Pull Request | ||||||
|  |   title: Contribute | ||||||
|  | - sections: | ||||||
|  |   - local: philosophy | ||||||
|  |     title: Philosophy | ||||||
|  |   - local: glossary | ||||||
|  |     title: Glossary | ||||||
|  |   - local: task_summary | ||||||
|  |     title: What 🤗 Transformers can do | ||||||
|  |   - local: tasks_explained | ||||||
|  |     title: How 🤗 Transformers solve tasks | ||||||
|  |   - local: model_summary | ||||||
|  |     title: The Transformer model family | ||||||
|  |   - local: tokenizer_summary | ||||||
|  |     title: Summary of the tokenizers | ||||||
|  |   - local: attention | ||||||
|  |     title: Attention mechanisms | ||||||
|  |   - local: pad_truncation | ||||||
|  |     title: Padding and truncation | ||||||
|  |   - local: bertology | ||||||
|  |     title: BERTology | ||||||
|  |   - local: perplexity | ||||||
|  |     title: Perplexity of fixed-length models | ||||||
|  |   - local: pipeline_webserver | ||||||
|  |     title: Pipelines for webserver inference | ||||||
|  |   - local: model_memory_anatomy | ||||||
|  |     title: Model training anatomy | ||||||
|  |   - local: llm_tutorial_optimization | ||||||
|  |     title: Getting the most out of LLMs | ||||||
|  |   title: Conceptual guides | ||||||
|  | - sections: | ||||||
|  |   - sections: | ||||||
|  |     - local: main_classes/agent | ||||||
|  |       title: Agents and Tools | ||||||
|     - local: model_doc/auto |     - local: model_doc/auto | ||||||
|       title: Auto Classes |       title: Auto Classes | ||||||
|     - local: main_classes/backbones |     - local: main_classes/backbones | ||||||
| @ -336,8 +300,6 @@ | |||||||
|       title: Optimization |       title: Optimization | ||||||
|     - local: main_classes/output |     - local: main_classes/output | ||||||
|       title: Model outputs |       title: Model outputs | ||||||
|     - local: main_classes/peft |  | ||||||
|       title: PEFT |  | ||||||
|     - local: main_classes/pipelines |     - local: main_classes/pipelines | ||||||
|       title: Pipelines |       title: Pipelines | ||||||
|     - local: main_classes/processors |     - local: main_classes/processors | ||||||
| @ -356,11 +318,10 @@ | |||||||
|       title: Feature Extractor |       title: Feature Extractor | ||||||
|     - local: main_classes/image_processor |     - local: main_classes/image_processor | ||||||
|       title: Image Processor |       title: Image Processor | ||||||
|     - local: main_classes/video_processor |  | ||||||
|       title: Video Processor |  | ||||||
|     title: Main Classes |     title: Main Classes | ||||||
|   - sections: |   - sections: | ||||||
|     - sections: |     - isExpanded: false | ||||||
|  |       sections: | ||||||
|       - local: model_doc/albert |       - local: model_doc/albert | ||||||
|         title: ALBERT |         title: ALBERT | ||||||
|       - local: model_doc/bamba |       - local: model_doc/bamba | ||||||
| @ -378,15 +339,13 @@ | |||||||
|       - local: model_doc/bert-japanese |       - local: model_doc/bert-japanese | ||||||
|         title: BertJapanese |         title: BertJapanese | ||||||
|       - local: model_doc/bertweet |       - local: model_doc/bertweet | ||||||
|         title: BERTweet |         title: Bertweet | ||||||
|       - local: model_doc/big_bird |       - local: model_doc/big_bird | ||||||
|         title: BigBird |         title: BigBird | ||||||
|       - local: model_doc/bigbird_pegasus |       - local: model_doc/bigbird_pegasus | ||||||
|         title: BigBirdPegasus |         title: BigBirdPegasus | ||||||
|       - local: model_doc/biogpt |       - local: model_doc/biogpt | ||||||
|         title: BioGpt |         title: BioGpt | ||||||
|       - local: model_doc/bitnet |  | ||||||
|         title: BitNet |  | ||||||
|       - local: model_doc/blenderbot |       - local: model_doc/blenderbot | ||||||
|         title: Blenderbot |         title: Blenderbot | ||||||
|       - local: model_doc/blenderbot-small |       - local: model_doc/blenderbot-small | ||||||
| @ -423,8 +382,6 @@ | |||||||
|         title: DeBERTa |         title: DeBERTa | ||||||
|       - local: model_doc/deberta-v2 |       - local: model_doc/deberta-v2 | ||||||
|         title: DeBERTa-v2 |         title: DeBERTa-v2 | ||||||
|       - local: model_doc/deepseek_v3 |  | ||||||
|         title: DeepSeek-V3 |  | ||||||
|       - local: model_doc/dialogpt |       - local: model_doc/dialogpt | ||||||
|         title: DialoGPT |         title: DialoGPT | ||||||
|       - local: model_doc/diffllama |       - local: model_doc/diffllama | ||||||
| @ -447,8 +404,6 @@ | |||||||
|         title: Falcon |         title: Falcon | ||||||
|       - local: model_doc/falcon3 |       - local: model_doc/falcon3 | ||||||
|         title: Falcon3 |         title: Falcon3 | ||||||
|       - local: model_doc/falcon_h1 |  | ||||||
|         title: FalconH1 |  | ||||||
|       - local: model_doc/falcon_mamba |       - local: model_doc/falcon_mamba | ||||||
|         title: FalconMamba |         title: FalconMamba | ||||||
|       - local: model_doc/flan-t5 |       - local: model_doc/flan-t5 | ||||||
| @ -471,8 +426,6 @@ | |||||||
|         title: Gemma2 |         title: Gemma2 | ||||||
|       - local: model_doc/glm |       - local: model_doc/glm | ||||||
|         title: GLM |         title: GLM | ||||||
|       - local: model_doc/glm4 |  | ||||||
|         title: glm4 |  | ||||||
|       - local: model_doc/openai-gpt |       - local: model_doc/openai-gpt | ||||||
|         title: GPT |         title: GPT | ||||||
|       - local: model_doc/gpt_neo |       - local: model_doc/gpt_neo | ||||||
| @ -495,16 +448,12 @@ | |||||||
|         title: Granite |         title: Granite | ||||||
|       - local: model_doc/granitemoe |       - local: model_doc/granitemoe | ||||||
|         title: GraniteMoe |         title: GraniteMoe | ||||||
|       - local: model_doc/granitemoehybrid |       - local: model_doc/granitevision | ||||||
|         title: GraniteMoeHybrid |         title: GraniteVision | ||||||
|       - local: model_doc/granitemoeshared |  | ||||||
|         title: GraniteMoeShared |  | ||||||
|       - local: model_doc/helium |       - local: model_doc/helium | ||||||
|         title: Helium |         title: Helium | ||||||
|       - local: model_doc/herbert |       - local: model_doc/herbert | ||||||
|         title: HerBERT |         title: HerBERT | ||||||
|       - local: model_doc/hgnet_v2 |  | ||||||
|         title: HGNet-V2 |  | ||||||
|       - local: model_doc/ibert |       - local: model_doc/ibert | ||||||
|         title: I-BERT |         title: I-BERT | ||||||
|       - local: model_doc/jamba |       - local: model_doc/jamba | ||||||
| @ -534,7 +483,7 @@ | |||||||
|       - local: model_doc/mamba |       - local: model_doc/mamba | ||||||
|         title: Mamba |         title: Mamba | ||||||
|       - local: model_doc/mamba2 |       - local: model_doc/mamba2 | ||||||
|         title: Mamba2 |         title: mamba2 | ||||||
|       - local: model_doc/marian |       - local: model_doc/marian | ||||||
|         title: MarianMT |         title: MarianMT | ||||||
|       - local: model_doc/markuplm |       - local: model_doc/markuplm | ||||||
| @ -547,8 +496,6 @@ | |||||||
|         title: MegatronBERT |         title: MegatronBERT | ||||||
|       - local: model_doc/megatron_gpt2 |       - local: model_doc/megatron_gpt2 | ||||||
|         title: MegatronGPT2 |         title: MegatronGPT2 | ||||||
|       - local: model_doc/minimax |  | ||||||
|         title: MiniMax |  | ||||||
|       - local: model_doc/mistral |       - local: model_doc/mistral | ||||||
|         title: Mistral |         title: Mistral | ||||||
|       - local: model_doc/mixtral |       - local: model_doc/mixtral | ||||||
| @ -615,10 +562,6 @@ | |||||||
|         title: Qwen2 |         title: Qwen2 | ||||||
|       - local: model_doc/qwen2_moe |       - local: model_doc/qwen2_moe | ||||||
|         title: Qwen2MoE |         title: Qwen2MoE | ||||||
|       - local: model_doc/qwen3 |  | ||||||
|         title: Qwen3 |  | ||||||
|       - local: model_doc/qwen3_moe |  | ||||||
|         title: Qwen3MoE |  | ||||||
|       - local: model_doc/rag |       - local: model_doc/rag | ||||||
|         title: RAG |         title: RAG | ||||||
|       - local: model_doc/realm |       - local: model_doc/realm | ||||||
| @ -686,7 +629,8 @@ | |||||||
|       - local: model_doc/zamba2 |       - local: model_doc/zamba2 | ||||||
|         title: Zamba2 |         title: Zamba2 | ||||||
|       title: Text models |       title: Text models | ||||||
|     - sections: |     - isExpanded: false | ||||||
|  |       sections: | ||||||
|       - local: model_doc/beit |       - local: model_doc/beit | ||||||
|         title: BEiT |         title: BEiT | ||||||
|       - local: model_doc/bit |       - local: model_doc/bit | ||||||
| @ -699,10 +643,6 @@ | |||||||
|         title: ConvNeXTV2 |         title: ConvNeXTV2 | ||||||
|       - local: model_doc/cvt |       - local: model_doc/cvt | ||||||
|         title: CvT |         title: CvT | ||||||
|       - local: model_doc/d_fine |  | ||||||
|         title: D-FINE |  | ||||||
|       - local: model_doc/dab-detr |  | ||||||
|         title: DAB-DETR |  | ||||||
|       - local: model_doc/deformable_detr |       - local: model_doc/deformable_detr | ||||||
|         title: Deformable DETR |         title: Deformable DETR | ||||||
|       - local: model_doc/deit |       - local: model_doc/deit | ||||||
| @ -711,8 +651,6 @@ | |||||||
|         title: Depth Anything |         title: Depth Anything | ||||||
|       - local: model_doc/depth_anything_v2 |       - local: model_doc/depth_anything_v2 | ||||||
|         title: Depth Anything V2 |         title: Depth Anything V2 | ||||||
|       - local: model_doc/depth_pro |  | ||||||
|         title: DepthPro |  | ||||||
|       - local: model_doc/deta |       - local: model_doc/deta | ||||||
|         title: DETA |         title: DETA | ||||||
|       - local: model_doc/detr |       - local: model_doc/detr | ||||||
| @ -743,14 +681,10 @@ | |||||||
|         title: ImageGPT |         title: ImageGPT | ||||||
|       - local: model_doc/levit |       - local: model_doc/levit | ||||||
|         title: LeViT |         title: LeViT | ||||||
|       - local: model_doc/lightglue |  | ||||||
|         title: LightGlue |  | ||||||
|       - local: model_doc/mask2former |       - local: model_doc/mask2former | ||||||
|         title: Mask2Former |         title: Mask2Former | ||||||
|       - local: model_doc/maskformer |       - local: model_doc/maskformer | ||||||
|         title: MaskFormer |         title: MaskFormer | ||||||
|       - local: model_doc/mlcd |  | ||||||
|         title: MLCD |  | ||||||
|       - local: model_doc/mobilenet_v1 |       - local: model_doc/mobilenet_v1 | ||||||
|         title: MobileNetV1 |         title: MobileNetV1 | ||||||
|       - local: model_doc/mobilenet_v2 |       - local: model_doc/mobilenet_v2 | ||||||
| @ -763,8 +697,6 @@ | |||||||
|         title: NAT |         title: NAT | ||||||
|       - local: model_doc/poolformer |       - local: model_doc/poolformer | ||||||
|         title: PoolFormer |         title: PoolFormer | ||||||
|       - local: model_doc/prompt_depth_anything |  | ||||||
|         title: Prompt Depth Anything |  | ||||||
|       - local: model_doc/pvt |       - local: model_doc/pvt | ||||||
|         title: Pyramid Vision Transformer (PVT) |         title: Pyramid Vision Transformer (PVT) | ||||||
|       - local: model_doc/pvt_v2 |       - local: model_doc/pvt_v2 | ||||||
| @ -775,8 +707,6 @@ | |||||||
|         title: ResNet |         title: ResNet | ||||||
|       - local: model_doc/rt_detr |       - local: model_doc/rt_detr | ||||||
|         title: RT-DETR |         title: RT-DETR | ||||||
|       - local: model_doc/rt_detr_v2 |  | ||||||
|         title: RT-DETRv2 |  | ||||||
|       - local: model_doc/segformer |       - local: model_doc/segformer | ||||||
|         title: SegFormer |         title: SegFormer | ||||||
|       - local: model_doc/seggpt |       - local: model_doc/seggpt | ||||||
| @ -822,23 +752,20 @@ | |||||||
|       - local: model_doc/zoedepth |       - local: model_doc/zoedepth | ||||||
|         title: ZoeDepth |         title: ZoeDepth | ||||||
|       title: Vision models |       title: Vision models | ||||||
|     - sections: |     - isExpanded: false | ||||||
|  |       sections: | ||||||
|       - local: model_doc/audio-spectrogram-transformer |       - local: model_doc/audio-spectrogram-transformer | ||||||
|         title: Audio Spectrogram Transformer |         title: Audio Spectrogram Transformer | ||||||
|       - local: model_doc/bark |       - local: model_doc/bark | ||||||
|         title: Bark |         title: Bark | ||||||
|       - local: model_doc/clap |       - local: model_doc/clap | ||||||
|         title: CLAP |         title: CLAP | ||||||
|       - local: model_doc/csm |  | ||||||
|         title: CSM |  | ||||||
|       - local: model_doc/dac |       - local: model_doc/dac | ||||||
|         title: dac |         title: dac | ||||||
|       - local: model_doc/encodec |       - local: model_doc/encodec | ||||||
|         title: EnCodec |         title: EnCodec | ||||||
|       - local: model_doc/fastspeech2_conformer |       - local: model_doc/fastspeech2_conformer | ||||||
|         title: FastSpeech2Conformer |         title: FastSpeech2Conformer | ||||||
|       - local: model_doc/granite_speech |  | ||||||
|         title: GraniteSpeech |  | ||||||
|       - local: model_doc/hubert |       - local: model_doc/hubert | ||||||
|         title: Hubert |         title: Hubert | ||||||
|       - local: model_doc/mctct |       - local: model_doc/mctct | ||||||
| @ -896,25 +823,23 @@ | |||||||
|       - local: model_doc/xlsr_wav2vec2 |       - local: model_doc/xlsr_wav2vec2 | ||||||
|         title: XLSR-Wav2Vec2 |         title: XLSR-Wav2Vec2 | ||||||
|       title: Audio models |       title: Audio models | ||||||
|     - sections: |     - isExpanded: false | ||||||
|  |       sections: | ||||||
|       - local: model_doc/timesformer |       - local: model_doc/timesformer | ||||||
|         title: TimeSformer |         title: TimeSformer | ||||||
|       - local: model_doc/vjepa2 |  | ||||||
|         title: V-JEPA 2 |  | ||||||
|       - local: model_doc/videomae |       - local: model_doc/videomae | ||||||
|         title: VideoMAE |         title: VideoMAE | ||||||
|       - local: model_doc/vivit |       - local: model_doc/vivit | ||||||
|         title: ViViT |         title: ViViT | ||||||
|       title: Video models |       title: Video models | ||||||
|     - sections: |     - isExpanded: false | ||||||
|  |       sections: | ||||||
|       - local: model_doc/align |       - local: model_doc/align | ||||||
|         title: ALIGN |         title: ALIGN | ||||||
|       - local: model_doc/altclip |       - local: model_doc/altclip | ||||||
|         title: AltCLIP |         title: AltCLIP | ||||||
|       - local: model_doc/aria |       - local: model_doc/aria | ||||||
|         title: Aria |         title: Aria | ||||||
|       - local: model_doc/aya_vision |  | ||||||
|         title: AyaVision |  | ||||||
|       - local: model_doc/blip |       - local: model_doc/blip | ||||||
|         title: BLIP |         title: BLIP | ||||||
|       - local: model_doc/blip-2 |       - local: model_doc/blip-2 | ||||||
| @ -935,8 +860,6 @@ | |||||||
|         title: CLVP |         title: CLVP | ||||||
|       - local: model_doc/colpali |       - local: model_doc/colpali | ||||||
|         title: ColPali |         title: ColPali | ||||||
|       - local: model_doc/colqwen2 |  | ||||||
|         title: ColQwen2 |  | ||||||
|       - local: model_doc/data2vec |       - local: model_doc/data2vec | ||||||
|         title: Data2Vec |         title: Data2Vec | ||||||
|       - local: model_doc/deplot |       - local: model_doc/deplot | ||||||
| @ -947,14 +870,8 @@ | |||||||
|         title: Emu3 |         title: Emu3 | ||||||
|       - local: model_doc/flava |       - local: model_doc/flava | ||||||
|         title: FLAVA |         title: FLAVA | ||||||
|       - local: model_doc/gemma3 |  | ||||||
|         title: Gemma3 |  | ||||||
|       - local: model_doc/git |       - local: model_doc/git | ||||||
|         title: GIT |         title: GIT | ||||||
|       - local: model_doc/got_ocr2 |  | ||||||
|         title: GOT-OCR2 |  | ||||||
|       - local: model_doc/granitevision |  | ||||||
|         title: GraniteVision |  | ||||||
|       - local: model_doc/grounding-dino |       - local: model_doc/grounding-dino | ||||||
|         title: Grounding DINO |         title: Grounding DINO | ||||||
|       - local: model_doc/groupvit |       - local: model_doc/groupvit | ||||||
| @ -969,10 +886,6 @@ | |||||||
|         title: InstructBLIP |         title: InstructBLIP | ||||||
|       - local: model_doc/instructblipvideo |       - local: model_doc/instructblipvideo | ||||||
|         title: InstructBlipVideo |         title: InstructBlipVideo | ||||||
|       - local: model_doc/internvl |  | ||||||
|         title: InternVL |  | ||||||
|       - local: model_doc/janus |  | ||||||
|         title: Janus |  | ||||||
|       - local: model_doc/kosmos-2 |       - local: model_doc/kosmos-2 | ||||||
|         title: KOSMOS-2 |         title: KOSMOS-2 | ||||||
|       - local: model_doc/layoutlm |       - local: model_doc/layoutlm | ||||||
| @ -985,8 +898,6 @@ | |||||||
|         title: LayoutXLM |         title: LayoutXLM | ||||||
|       - local: model_doc/lilt |       - local: model_doc/lilt | ||||||
|         title: LiLT |         title: LiLT | ||||||
|       - local: model_doc/llama4 |  | ||||||
|         title: Llama4 |  | ||||||
|       - local: model_doc/llava |       - local: model_doc/llava | ||||||
|         title: Llava |         title: Llava | ||||||
|       - local: model_doc/llava_next |       - local: model_doc/llava_next | ||||||
| @ -1001,8 +912,6 @@ | |||||||
|         title: MatCha |         title: MatCha | ||||||
|       - local: model_doc/mgp-str |       - local: model_doc/mgp-str | ||||||
|         title: MGP-STR |         title: MGP-STR | ||||||
|       - local: model_doc/mistral3 |  | ||||||
|         title: Mistral3 |  | ||||||
|       - local: model_doc/mllama |       - local: model_doc/mllama | ||||||
|         title: mllama |         title: mllama | ||||||
|       - local: model_doc/nougat |       - local: model_doc/nougat | ||||||
| @ -1019,14 +928,10 @@ | |||||||
|         title: PaliGemma |         title: PaliGemma | ||||||
|       - local: model_doc/perceiver |       - local: model_doc/perceiver | ||||||
|         title: Perceiver |         title: Perceiver | ||||||
|       - local: model_doc/phi4_multimodal |  | ||||||
|         title: Phi4 Multimodal |  | ||||||
|       - local: model_doc/pix2struct |       - local: model_doc/pix2struct | ||||||
|         title: Pix2Struct |         title: Pix2Struct | ||||||
|       - local: model_doc/pixtral |       - local: model_doc/pixtral | ||||||
|         title: Pixtral |         title: Pixtral | ||||||
|       - local: model_doc/qwen2_5_omni |  | ||||||
|         title: Qwen2.5-Omni |  | ||||||
|       - local: model_doc/qwen2_5_vl |       - local: model_doc/qwen2_5_vl | ||||||
|         title: Qwen2.5-VL |         title: Qwen2.5-VL | ||||||
|       - local: model_doc/qwen2_audio |       - local: model_doc/qwen2_audio | ||||||
| @ -1035,16 +940,8 @@ | |||||||
|         title: Qwen2VL |         title: Qwen2VL | ||||||
|       - local: model_doc/sam |       - local: model_doc/sam | ||||||
|         title: Segment Anything |         title: Segment Anything | ||||||
|       - local: model_doc/sam_hq |  | ||||||
|         title: Segment Anything High Quality |  | ||||||
|       - local: model_doc/shieldgemma2 |  | ||||||
|         title: ShieldGemma2 |  | ||||||
|       - local: model_doc/siglip |       - local: model_doc/siglip | ||||||
|         title: SigLIP |         title: SigLIP | ||||||
|       - local: model_doc/siglip2 |  | ||||||
|         title: SigLIP2 |  | ||||||
|       - local: model_doc/smolvlm |  | ||||||
|         title: SmolVLM |  | ||||||
|       - local: model_doc/speech-encoder-decoder |       - local: model_doc/speech-encoder-decoder | ||||||
|         title: Speech Encoder Decoder Models |         title: Speech Encoder Decoder Models | ||||||
|       - local: model_doc/tapas |       - local: model_doc/tapas | ||||||
| @ -1072,13 +969,15 @@ | |||||||
|       - local: model_doc/xclip |       - local: model_doc/xclip | ||||||
|         title: X-CLIP |         title: X-CLIP | ||||||
|       title: Multimodal models |       title: Multimodal models | ||||||
|     - sections: |     - isExpanded: false | ||||||
|  |       sections: | ||||||
|       - local: model_doc/decision_transformer |       - local: model_doc/decision_transformer | ||||||
|         title: Decision Transformer |         title: Decision Transformer | ||||||
|       - local: model_doc/trajectory_transformer |       - local: model_doc/trajectory_transformer | ||||||
|         title: Trajectory Transformer |         title: Trajectory Transformer | ||||||
|       title: Reinforcement learning models |       title: Reinforcement learning models | ||||||
|     - sections: |     - isExpanded: false | ||||||
|  |       sections: | ||||||
|       - local: model_doc/autoformer |       - local: model_doc/autoformer | ||||||
|         title: Autoformer |         title: Autoformer | ||||||
|       - local: model_doc/informer |       - local: model_doc/informer | ||||||
| @ -1089,10 +988,9 @@ | |||||||
|         title: PatchTST |         title: PatchTST | ||||||
|       - local: model_doc/time_series_transformer |       - local: model_doc/time_series_transformer | ||||||
|         title: Time Series Transformer |         title: Time Series Transformer | ||||||
|       - local: model_doc/timesfm |  | ||||||
|         title: TimesFM |  | ||||||
|       title: Time series models |       title: Time series models | ||||||
|     - sections: |     - isExpanded: false | ||||||
|  |       sections: | ||||||
|       - local: model_doc/graphormer |       - local: model_doc/graphormer | ||||||
|         title: Graphormer |         title: Graphormer | ||||||
|       title: Graph models |       title: Graph models | ||||||
| @ -1100,8 +998,6 @@ | |||||||
|   - sections: |   - sections: | ||||||
|     - local: internal/modeling_utils |     - local: internal/modeling_utils | ||||||
|       title: Custom Layers and Utilities |       title: Custom Layers and Utilities | ||||||
|     - local: internal/model_debugging_utils |  | ||||||
|       title: Utilities for Model Debugging |  | ||||||
|     - local: internal/pipelines_utils |     - local: internal/pipelines_utils | ||||||
|       title: Utilities for pipelines |       title: Utilities for pipelines | ||||||
|     - local: internal/tokenization_utils |     - local: internal/tokenization_utils | ||||||
| @ -1116,14 +1012,7 @@ | |||||||
|       title: Utilities for Audio processing |       title: Utilities for Audio processing | ||||||
|     - local: internal/file_utils |     - local: internal/file_utils | ||||||
|       title: General Utilities |       title: General Utilities | ||||||
|     - local: internal/import_utils |  | ||||||
|       title: Importing Utilities |  | ||||||
|     - local: internal/time_series_utils |     - local: internal/time_series_utils | ||||||
|       title: Utilities for Time Series |       title: Utilities for Time Series | ||||||
|     title: Internal helpers |     title: Internal Helpers | ||||||
|   - sections: |  | ||||||
|     - local: reference/environment_variables |  | ||||||
|       title: Environment Variables |  | ||||||
|     title: Reference |  | ||||||
|   title: API |   title: API | ||||||
|  |  | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| <!--Copyright 2024 The HuggingFace Team. All rights reserved. | <!--Copyright 2022 The HuggingFace Team. All rights reserved. | ||||||
|  |  | ||||||
| Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with | Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with | ||||||
| the License. You may obtain a copy of the License at | the License. You may obtain a copy of the License at | ||||||
| @ -14,152 +14,123 @@ rendered properly in your Markdown viewer. | |||||||
|  |  | ||||||
| --> | --> | ||||||
|  |  | ||||||
| # Accelerate | # Distributed training with 🤗 Accelerate | ||||||
|  |  | ||||||
| [Accelerate](https://hf.co/docs/accelerate/index) is a library designed to simplify distributed training on any type of setup with PyTorch by uniting the most common frameworks ([Fully Sharded Data Parallel (FSDP)](https://pytorch.org/blog/introducing-pytorch-fully-sharded-data-parallel-api/) and [DeepSpeed](https://www.deepspeed.ai/)) for it into a single interface. [`Trainer`] is powered by Accelerate under the hood, enabling loading big models and distributed training. | As models get bigger, parallelism has emerged as a strategy for training larger models on limited hardware and accelerating training speed by several orders of magnitude. At Hugging Face, we created the [🤗 Accelerate](https://huggingface.co/docs/accelerate) library to help users easily train a 🤗 Transformers model on any type of distributed setup, whether it is multiple GPU's on one machine or multiple GPU's across several machines. In this tutorial, learn how to customize your native PyTorch training loop to enable training in a distributed environment. | ||||||
|  |  | ||||||
| This guide will show you two ways to use Accelerate with Transformers, using FSDP as the backend. The first method demonstrates distributed training with [`Trainer`], and the second method demonstrates adapting a PyTorch training loop. For more detailed information about Accelerate, please refer to the [documentation](https://hf.co/docs/accelerate/index). | ## Setup | ||||||
|  |  | ||||||
|  | Get started by installing 🤗 Accelerate: | ||||||
|  |  | ||||||
| ```bash | ```bash | ||||||
| pip install accelerate | pip install accelerate | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Start by running [accelerate config](https://hf.co/docs/accelerate/main/en/package_reference/cli#accelerate-config) in the command line to answer a series of prompts about your training system. This creates and saves a configuration file to help Accelerate correctly set up training based on your setup. | Then import and create an [`~accelerate.Accelerator`] object. The [`~accelerate.Accelerator`] will automatically detect your type of distributed setup and initialize all the necessary components for training. You don't need to explicitly place your model on a device. | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | >>> from accelerate import Accelerator | ||||||
|  |  | ||||||
|  | >>> accelerator = Accelerator() | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Prepare to accelerate | ||||||
|  |  | ||||||
|  | The next step is to pass all the relevant training objects to the [`~accelerate.Accelerator.prepare`] method. This includes your training and evaluation DataLoaders, a model and an optimizer: | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | >>> train_dataloader, eval_dataloader, model, optimizer = accelerator.prepare( | ||||||
|  | ...     train_dataloader, eval_dataloader, model, optimizer | ||||||
|  | ... ) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Backward | ||||||
|  |  | ||||||
|  | The last addition is to replace the typical `loss.backward()` in your training loop with 🤗 Accelerate's [`~accelerate.Accelerator.backward`] method: | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | >>> for epoch in range(num_epochs): | ||||||
|  | ...     for batch in train_dataloader: | ||||||
|  | ...         outputs = model(**batch) | ||||||
|  | ...         loss = outputs.loss | ||||||
|  | ...         accelerator.backward(loss) | ||||||
|  |  | ||||||
|  | ...         optimizer.step() | ||||||
|  | ...         lr_scheduler.step() | ||||||
|  | ...         optimizer.zero_grad() | ||||||
|  | ...         progress_bar.update(1) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | As you can see in the following code, you only need to add four additional lines of code to your training loop to enable distributed training! | ||||||
|  |  | ||||||
|  | ```diff | ||||||
|  | + from accelerate import Accelerator | ||||||
|  |   from transformers import AdamW, AutoModelForSequenceClassification, get_scheduler | ||||||
|  |  | ||||||
|  | + accelerator = Accelerator() | ||||||
|  |  | ||||||
|  |   model = AutoModelForSequenceClassification.from_pretrained(checkpoint, num_labels=2) | ||||||
|  |   optimizer = AdamW(model.parameters(), lr=3e-5) | ||||||
|  |  | ||||||
|  | - device = torch.device("cuda") if torch.cuda.is_available() else torch.device("cpu") | ||||||
|  | - model.to(device) | ||||||
|  |  | ||||||
|  | + train_dataloader, eval_dataloader, model, optimizer = accelerator.prepare( | ||||||
|  | +     train_dataloader, eval_dataloader, model, optimizer | ||||||
|  | + ) | ||||||
|  |  | ||||||
|  |   num_epochs = 3 | ||||||
|  |   num_training_steps = num_epochs * len(train_dataloader) | ||||||
|  |   lr_scheduler = get_scheduler( | ||||||
|  |       "linear", | ||||||
|  |       optimizer=optimizer, | ||||||
|  |       num_warmup_steps=0, | ||||||
|  |       num_training_steps=num_training_steps | ||||||
|  |   ) | ||||||
|  |  | ||||||
|  |   progress_bar = tqdm(range(num_training_steps)) | ||||||
|  |  | ||||||
|  |   model.train() | ||||||
|  |   for epoch in range(num_epochs): | ||||||
|  |       for batch in train_dataloader: | ||||||
|  | -         batch = {k: v.to(device) for k, v in batch.items()} | ||||||
|  |           outputs = model(**batch) | ||||||
|  |           loss = outputs.loss | ||||||
|  | -         loss.backward() | ||||||
|  | +         accelerator.backward(loss) | ||||||
|  |  | ||||||
|  |           optimizer.step() | ||||||
|  |           lr_scheduler.step() | ||||||
|  |           optimizer.zero_grad() | ||||||
|  |           progress_bar.update(1) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Train | ||||||
|  |  | ||||||
|  | Once you've added the relevant lines of code, launch your training in a script or a notebook like Colaboratory. | ||||||
|  |  | ||||||
|  | ### Train with a script | ||||||
|  |  | ||||||
|  | If you are running your training from a script, run the following command to create and save a configuration file: | ||||||
|  |  | ||||||
| ```bash | ```bash | ||||||
| accelerate config | accelerate config | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Depending on your setup and the answers you provide, an example configuration file for distributing training with FSDP on one machine with two GPUs may look like the following. | Then launch your training with: | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
| compute_environment: LOCAL_MACHINE |  | ||||||
| debug: false |  | ||||||
| distributed_type: FSDP |  | ||||||
| downcast_bf16: 'no' |  | ||||||
| fsdp_config: |  | ||||||
|   fsdp_auto_wrap_policy: TRANSFORMER_BASED_WRAP |  | ||||||
|   fsdp_backward_prefetch_policy: BACKWARD_PRE |  | ||||||
|   fsdp_forward_prefetch: false |  | ||||||
|   fsdp_cpu_ram_efficient_loading: true |  | ||||||
|   fsdp_offload_params: false |  | ||||||
|   fsdp_sharding_strategy: FULL_SHARD |  | ||||||
|   fsdp_state_dict_type: SHARDED_STATE_DICT |  | ||||||
|   fsdp_sync_module_states: true |  | ||||||
|   fsdp_transformer_layer_cls_to_wrap: BertLayer |  | ||||||
|   fsdp_use_orig_params: true |  | ||||||
| machine_rank: 0 |  | ||||||
| main_training_function: main |  | ||||||
| mixed_precision: bf16 |  | ||||||
| num_machines: 1 |  | ||||||
| num_processes: 2 |  | ||||||
| rdzv_backend: static |  | ||||||
| same_network: true |  | ||||||
| tpu_env: [] |  | ||||||
| tpu_use_cluster: false |  | ||||||
| tpu_use_sudo: false |  | ||||||
| use_cpu: false |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## Trainer |  | ||||||
|  |  | ||||||
| Pass the path to the saved configuration file to [`TrainingArguments`], and from there, pass your [`TrainingArguments`] to [`Trainer`]. |  | ||||||
|  |  | ||||||
| ```py |  | ||||||
| from transformers import TrainingArguments, Trainer |  | ||||||
|  |  | ||||||
| training_args = TrainingArguments( |  | ||||||
|     output_dir="your-model", |  | ||||||
|     learning_rate=2e-5, |  | ||||||
|     per_device_train_batch_size=16, |  | ||||||
|     per_device_eval_batch_size=16, |  | ||||||
|     num_train_epochs=2, |  | ||||||
|     fsdp_config="path/to/fsdp_config", |  | ||||||
|     fsdp="full_shard", |  | ||||||
|     weight_decay=0.01, |  | ||||||
|     eval_strategy="epoch", |  | ||||||
|     save_strategy="epoch", |  | ||||||
|     load_best_model_at_end=True, |  | ||||||
|     push_to_hub=True, |  | ||||||
| ) |  | ||||||
|  |  | ||||||
| trainer = Trainer( |  | ||||||
|     model=model, |  | ||||||
|     args=training_args, |  | ||||||
|     train_dataset=dataset["train"], |  | ||||||
|     eval_dataset=dataset["test"], |  | ||||||
|     processing_class=tokenizer, |  | ||||||
|     data_collator=data_collator, |  | ||||||
|     compute_metrics=compute_metrics, |  | ||||||
| ) |  | ||||||
|  |  | ||||||
| trainer.train() |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## Native PyTorch |  | ||||||
|  |  | ||||||
| Accelerate can also be added to any PyTorch training loop to enable distributed training. The [`~accelerate.Accelerator`] is the main entry point for adapting your PyTorch code to work with Accelerate. It automatically detects your distributed training setup and initializes all the necessary components for training. You don't need to explicitly place your model on a device because [`~accelerate.Accelerator`] knows which device to move your model to. |  | ||||||
|  |  | ||||||
| ```py |  | ||||||
| from accelerate import Accelerator |  | ||||||
|  |  | ||||||
| accelerator = Accelerator() |  | ||||||
| device = accelerator.device |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| All PyTorch objects (model, optimizer, scheduler, dataloaders) should be passed to the [`~accelerate.Accelerator.prepare`] method now. This method moves your model to the appropriate device or devices, adapts the optimizer and scheduler to use [`~accelerate.optimizer.AcceleratedOptimizer`] and [`~accelerate.scheduler.AcceleratedScheduler`], and creates a new shardable dataloader. |  | ||||||
|  |  | ||||||
| ```py |  | ||||||
| train_dataloader, eval_dataloader, model, optimizer = accelerator.prepare( |  | ||||||
|     train_dataloader, eval_dataloader, model, optimizer |  | ||||||
| ) |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Replace `loss.backward` in your training loop with Accelerates [`~accelerate.Accelerator.backward`] method to scale the gradients and determine the appropriate `backward` method to use depending on your framework (for example, DeepSpeed or Megatron). |  | ||||||
|  |  | ||||||
| ```py |  | ||||||
| for epoch in range(num_epochs): |  | ||||||
|     for batch in train_dataloader: |  | ||||||
|         outputs = model(**batch) |  | ||||||
|         loss = outputs.loss |  | ||||||
|         accelerator.backward(loss) |  | ||||||
|         optimizer.step() |  | ||||||
|         lr_scheduler.step() |  | ||||||
|         optimizer.zero_grad() |  | ||||||
|         progress_bar.update(1) |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Combine everything into a function and make it callable as a script. |  | ||||||
|  |  | ||||||
| ```py |  | ||||||
| from accelerate import Accelerator |  | ||||||
|    |  | ||||||
| def main(): |  | ||||||
|   accelerator = Accelerator() |  | ||||||
|  |  | ||||||
|   model, optimizer, training_dataloader, scheduler = accelerator.prepare( |  | ||||||
|       model, optimizer, training_dataloader, scheduler |  | ||||||
|   ) |  | ||||||
|  |  | ||||||
|   for batch in training_dataloader: |  | ||||||
|       optimizer.zero_grad() |  | ||||||
|       inputs, targets = batch |  | ||||||
|       outputs = model(inputs) |  | ||||||
|       loss = loss_function(outputs, targets) |  | ||||||
|       accelerator.backward(loss) |  | ||||||
|       optimizer.step() |  | ||||||
|       scheduler.step() |  | ||||||
|  |  | ||||||
| if __name__ == "__main__": |  | ||||||
|     main() |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| From the command line, call [accelerate launch](https://hf.co/docs/accelerate/main/en/package_reference/cli#accelerate-launch) to run your training script. Any additional arguments or parameters can be passed here as well. |  | ||||||
|  |  | ||||||
| To launch your training script on two GPUs, add the `--num_processes` argument. |  | ||||||
|  |  | ||||||
| ```bash | ```bash | ||||||
| accelerate launch --num_processes=2 your_script.py | accelerate launch train.py | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Refer to the [Launching Accelerate scripts](https://hf.co/docs/accelerate/main/en/basic_tutorials/launch) for more details. | ### Train with a notebook | ||||||
|  |  | ||||||
|  | 🤗 Accelerate can also run in a notebook if you're planning on using Colaboratory's TPUs. Wrap all the code responsible for training in a function, and pass it to [`~accelerate.notebook_launcher`]: | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | >>> from accelerate import notebook_launcher | ||||||
|  |  | ||||||
|  | >>> notebook_launcher(training_function) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | For more information about 🤗 Accelerate and its rich features, refer to the [documentation](https://huggingface.co/docs/accelerate). | ||||||
|  | |||||||
| @ -1,126 +0,0 @@ | |||||||
| <!--Copyright 2025 The HuggingFace Team. All rights reserved. |  | ||||||
|  |  | ||||||
| Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with |  | ||||||
| the License. You may obtain a copy of the License at |  | ||||||
|  |  | ||||||
| http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
|  |  | ||||||
| Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on |  | ||||||
| an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the |  | ||||||
| specific language governing permissions and limitations under the License. |  | ||||||
|  |  | ||||||
| ⚠️ Note that this file is in Markdown but contains specific syntax for our doc-builder (similar to MDX) that may not be |  | ||||||
| rendered properly in your Markdown viewer. |  | ||||||
|  |  | ||||||
| --> |  | ||||||
|  |  | ||||||
| # Accelerator selection |  | ||||||
|  |  | ||||||
| During distributed training, you can specify the number and order of accelerators (CUDA, XPU, MPS, HPU, etc.) to use. This can be useful when you have accelerators with different computing power and you want to use the faster accelerator first. Or you could only use a subset of the available accelerators. The selection process works for both [DistributedDataParallel](https://pytorch.org/docs/stable/generated/torch.nn.parallel.DistributedDataParallel.html) and [DataParallel](https://pytorch.org/docs/stable/generated/torch.nn.DataParallel.html). You don't need Accelerate or [DeepSpeed integration](./main_classes/deepspeed). |  | ||||||
|  |  | ||||||
| This guide will show you how to select the number of accelerators to use and the order to use them in. |  | ||||||
|  |  | ||||||
| ## Number of accelerators |  | ||||||
|  |  | ||||||
| For example, if there are 4 accelerators and you only want to use the first 2, run the command below. |  | ||||||
|  |  | ||||||
| <hfoptions id="select-accelerator"> |  | ||||||
| <hfoption id="torchrun"> |  | ||||||
|  |  | ||||||
| Use the `--nproc_per_node` to select how many accelerators to use. |  | ||||||
|  |  | ||||||
| ```bash |  | ||||||
| torchrun --nproc_per_node=2  trainer-program.py ... |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| </hfoption> |  | ||||||
| <hfoption id="Accelerate"> |  | ||||||
|  |  | ||||||
| Use `--num_processes` to select how many accelerators to use. |  | ||||||
|  |  | ||||||
| ```bash |  | ||||||
| accelerate launch --num_processes 2 trainer-program.py ... |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| </hfoption> |  | ||||||
| <hfoption id="DeepSpeed"> |  | ||||||
|  |  | ||||||
| Use `--num_gpus` to select how many GPUs to use. |  | ||||||
|  |  | ||||||
| ```bash |  | ||||||
| deepspeed --num_gpus 2 trainer-program.py ... |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| </hfoption> |  | ||||||
| </hfoptions> |  | ||||||
|  |  | ||||||
| ## Order of accelerators |  | ||||||
| To select specific accelerators to use and their order, use the environment variable appropriate for your hardware. This is often set on the command line for each run, but can also be added to your `~/.bashrc` or other startup config file. |  | ||||||
|  |  | ||||||
| For example, if there are 4 accelerators (0, 1, 2, 3) and you only want to run accelerators 0 and 2: |  | ||||||
|  |  | ||||||
| <hfoptions id="accelerator-type"> |  | ||||||
| <hfoption id="CUDA"> |  | ||||||
|  |  | ||||||
| ```bash |  | ||||||
| CUDA_VISIBLE_DEVICES=0,2 torchrun trainer-program.py ... |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Only GPUs 0 and 2 are "visible" to PyTorch and are mapped to `cuda:0` and `cuda:1` respectively.   |  | ||||||
| To reverse the order (use GPU 2 as `cuda:0` and GPU 0 as `cuda:1`): |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ```bash |  | ||||||
| CUDA_VISIBLE_DEVICES=2,0 torchrun trainer-program.py ... |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| To run without any GPUs: |  | ||||||
|  |  | ||||||
| ```bash |  | ||||||
| CUDA_VISIBLE_DEVICES= python trainer-program.py ... |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| You can also control the order of CUDA devices using `CUDA_DEVICE_ORDER`: |  | ||||||
|  |  | ||||||
| - Order by PCIe bus ID (matches `nvidia-smi`): |  | ||||||
|  |  | ||||||
|     ```bash |  | ||||||
|     export CUDA_DEVICE_ORDER=PCI_BUS_ID |  | ||||||
|     ``` |  | ||||||
|  |  | ||||||
| - Order by compute capability (fastest first): |  | ||||||
|  |  | ||||||
|     ```bash |  | ||||||
|     export CUDA_DEVICE_ORDER=FASTEST_FIRST |  | ||||||
|     ``` |  | ||||||
|  |  | ||||||
| </hfoption> |  | ||||||
| <hfoption id="Intel XPU"> |  | ||||||
|  |  | ||||||
| ```bash |  | ||||||
| ZE_AFFINITY_MASK=0,2 torchrun trainer-program.py ... |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Only XPUs 0 and 2 are "visible" to PyTorch and are mapped to `xpu:0` and `xpu:1` respectively.   |  | ||||||
| To reverse the order (use XPU 2 as `xpu:0` and XPU 0 as `xpu:1`): |  | ||||||
|  |  | ||||||
| ```bash |  | ||||||
| ZE_AFFINITY_MASK=2,0 torchrun trainer-program.py ... |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
|  |  | ||||||
| You can also control the order of Intel XPUs with: |  | ||||||
|  |  | ||||||
| ```bash |  | ||||||
| export ZE_ENABLE_PCI_ID_DEVICE_ORDER=1 |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| For more information about device enumeration and sorting on Intel XPU, please refer to the [Level Zero](https://github.com/oneapi-src/level-zero/blob/master/README.md?plain=1#L87) documentation. |  | ||||||
|  |  | ||||||
| </hfoption> |  | ||||||
| </hfoptions> |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| > [!WARNING] |  | ||||||
| > Environment variables can be exported instead of being added to the command line. This is not recommended because it can be confusing if you forget how the environment variable was set up and you end up using the wrong accelerators. Instead, it is common practice to set the environment variable for a specific training run on the same command line. |  | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -1,4 +1,4 @@ | |||||||
| <!--Copyright 2024 The HuggingFace Team. All rights reserved. | <!--Copyright 2020 The HuggingFace Team. All rights reserved. | ||||||
|  |  | ||||||
| Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with | Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with | ||||||
| the License. You may obtain a copy of the License at | the License. You may obtain a copy of the License at | ||||||
| @ -13,66 +13,92 @@ rendered properly in your Markdown viewer. | |||||||
|  |  | ||||||
| --> | --> | ||||||
|  |  | ||||||
| # Adding a new pipeline | # How to create a custom pipeline? | ||||||
|  |  | ||||||
| Make [`Pipeline`] your own by subclassing it and implementing a few methods. Share the code with the community on the [Hub](https://hf.co) and register the pipeline with Transformers so that everyone can quickly and easily use it. | In this guide, we will see how to create a custom pipeline and share it on the [Hub](https://hf.co/models) or add it to the | ||||||
|  | 🤗 Transformers library. | ||||||
|  |  | ||||||
| This guide will walk you through the process of adding a new pipeline to Transformers. | First and foremost, you need to decide the raw entries the pipeline will be able to take. It can be strings, raw bytes, | ||||||
|  | dictionaries or whatever seems to be the most likely desired input. Try to keep these inputs as pure Python as possible | ||||||
|  | as it makes compatibility easier (even through other languages via JSON). Those will be the `inputs` of the | ||||||
|  | pipeline (`preprocess`). | ||||||
|  |  | ||||||
| ## Design choices | Then define the `outputs`. Same policy as the `inputs`. The simpler, the better. Those will be the outputs of | ||||||
|  | `postprocess` method. | ||||||
|  |  | ||||||
| At a minimum, you only need to provide [`Pipeline`] with an appropriate input for a task. This is also where you should begin when designing your pipeline. | Start by inheriting the base class `Pipeline` with the 4 methods needed to implement `preprocess`, | ||||||
|  | `_forward`, `postprocess`, and `_sanitize_parameters`. | ||||||
|  |  | ||||||
| Decide what input types [`Pipeline`] can accept. It can be strings, raw bytes, dictionaries, and so on. Try to keep the inputs in pure Python where possible because it's more compatible. Next, decide on the output [`Pipeline`] should return. Again, keeping the output in Python is the simplest and best option because it's easier to work with. |  | ||||||
|  |  | ||||||
| Keeping the inputs and outputs simple, and ideally JSON-serializable, makes it easier for users to run your [`Pipeline`] without needing to learn new object types. It's also common to support many different input types for even greater ease of use. For example, making an audio file acceptable from a filename, URL, or raw bytes gives the user more flexibility in how they provide the audio data. | ```python | ||||||
|  |  | ||||||
| ## Create a pipeline |  | ||||||
|  |  | ||||||
| With an input and output decided, you can start implementing [`Pipeline`]. Your pipeline should inherit from the base [`Pipeline`] class and include 4 methods. |  | ||||||
|  |  | ||||||
| ```py |  | ||||||
| from transformers import Pipeline | from transformers import Pipeline | ||||||
|  |  | ||||||
|  |  | ||||||
| class MyPipeline(Pipeline): | class MyPipeline(Pipeline): | ||||||
|     def _sanitize_parameters(self, **kwargs): |     def _sanitize_parameters(self, **kwargs): | ||||||
|  |         preprocess_kwargs = {} | ||||||
|  |         if "maybe_arg" in kwargs: | ||||||
|  |             preprocess_kwargs["maybe_arg"] = kwargs["maybe_arg"] | ||||||
|  |         return preprocess_kwargs, {}, {} | ||||||
|  |  | ||||||
|     def preprocess(self, inputs, args=2): |     def preprocess(self, inputs, maybe_arg=2): | ||||||
|  |         model_input = Tensor(inputs["input_ids"]) | ||||||
|  |         return {"model_input": model_input} | ||||||
|  |  | ||||||
|     def _forward(self, model_inputs): |     def _forward(self, model_inputs): | ||||||
|  |         # model_inputs == {"model_input": model_input} | ||||||
|  |         outputs = self.model(**model_inputs) | ||||||
|  |         # Maybe {"logits": Tensor(...)} | ||||||
|  |         return outputs | ||||||
|  |  | ||||||
|     def postprocess(self, model_outputs): |     def postprocess(self, model_outputs): | ||||||
|  |         best_class = model_outputs["logits"].softmax(-1) | ||||||
|  |         return best_class | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| 1. `preprocess` takes the inputs and transforms them into the appropriate input format for the model. | The structure of this breakdown is to support relatively seamless support for CPU/GPU, while supporting doing | ||||||
|  | pre/postprocessing on the CPU on different threads | ||||||
|  |  | ||||||
| ```py | `preprocess` will take the originally defined inputs, and turn them into something feedable to the model. It might | ||||||
| def preprocess(self, inputs, maybe_arg=2): | contain more information and is usually a `Dict`. | ||||||
|     model_input = Tensor(inputs["input_ids"]) |  | ||||||
|     return {"model_input": model_input} | `_forward` is the implementation detail and is not meant to be called directly. `forward` is the preferred | ||||||
|  | called method as it contains safeguards to make sure everything is working on the expected device. If anything is | ||||||
|  | linked to a real model it belongs in the `_forward` method, anything else is in the preprocess/postprocess. | ||||||
|  |  | ||||||
|  | `postprocess` methods will take the output of `_forward` and turn it into the final output that was decided | ||||||
|  | earlier. | ||||||
|  |  | ||||||
|  | `_sanitize_parameters` exists to allow users to pass any parameters whenever they wish, be it at initialization | ||||||
|  | time `pipeline(...., maybe_arg=4)` or at call time `pipe = pipeline(...); output = pipe(...., maybe_arg=4)`. | ||||||
|  |  | ||||||
|  | The returns of `_sanitize_parameters` are the 3 dicts of kwargs that will be passed directly to `preprocess`, | ||||||
|  | `_forward`, and `postprocess`. Don't fill anything if the caller didn't call with any extra parameter. That | ||||||
|  | allows to keep the default arguments in the function definition which is always more "natural". | ||||||
|  |  | ||||||
|  | A classic example would be a `top_k` argument in the post processing in classification tasks. | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | >>> pipe = pipeline("my-new-task") | ||||||
|  | >>> pipe("This is a test") | ||||||
|  | [{"label": "1-star", "score": 0.8}, {"label": "2-star", "score": 0.1}, {"label": "3-star", "score": 0.05} | ||||||
|  | {"label": "4-star", "score": 0.025}, {"label": "5-star", "score": 0.025}] | ||||||
|  |  | ||||||
|  | >>> pipe("This is a test", top_k=2) | ||||||
|  | [{"label": "1-star", "score": 0.8}, {"label": "2-star", "score": 0.1}] | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| 2. `_forward` shouldn't be called directly. `forward` is the preferred method because it includes safeguards to make sure everything works correctly on the expected device. Anything linked to the model belongs in `_forward` and everything else belongs in either `preprocess` or `postprocess`. | In order to achieve that, we'll update our `postprocess` method with a default parameter to `5`. and edit | ||||||
|  | `_sanitize_parameters` to allow this new parameter. | ||||||
|  |  | ||||||
| ```py |  | ||||||
| def _forward(self, model_inputs): |  | ||||||
|     outputs = self.model(**model_inputs) |  | ||||||
|     return outputs |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| 3. `postprocess` generates the final output from the models output in `_forward`. | ```python | ||||||
|  |  | ||||||
| ```py |  | ||||||
| def postprocess(self, model_outputs, top_k=5): | def postprocess(self, model_outputs, top_k=5): | ||||||
|     best_class = model_outputs["logits"].softmax(-1) |     best_class = model_outputs["logits"].softmax(-1) | ||||||
|  |     # Add logic to handle top_k | ||||||
|     return best_class |     return best_class | ||||||
| ``` |  | ||||||
|  |  | ||||||
| 4. `_sanitize_parameters` lets users pass additional parameters to [`Pipeline`]. This could be during initialization or when [`Pipeline`] is called. `_sanitize_parameters` returns 3 dicts of additional keyword arguments that are passed directly to `preprocess`, `_forward`, and `postprocess`. Don't add anything if a user didn't call the pipeline with extra parameters. This keeps the default arguments in the function definition which is always more natural. |  | ||||||
|  |  | ||||||
| For example, add a `top_k` parameter in `postprocess` to return the top 5 most likely classes. Then in `_sanitize_parameters`, check if the user passed in `top_k` and add it to `postprocess_kwargs`. |  | ||||||
|  |  | ||||||
| ```py |  | ||||||
| def _sanitize_parameters(self, **kwargs): | def _sanitize_parameters(self, **kwargs): | ||||||
|     preprocess_kwargs = {} |     preprocess_kwargs = {} | ||||||
|     if "maybe_arg" in kwargs: |     if "maybe_arg" in kwargs: | ||||||
| @ -84,61 +110,55 @@ def _sanitize_parameters(self, **kwargs): | |||||||
|     return preprocess_kwargs, {}, postprocess_kwargs |     return preprocess_kwargs, {}, postprocess_kwargs | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Now the pipeline can return the top most likely labels if a user chooses to. | Try to keep the inputs/outputs very simple and ideally JSON-serializable as it makes the pipeline usage very easy | ||||||
|  | without requiring users to understand new kinds of objects. It's also relatively common to support many different types | ||||||
|  | of arguments for ease of use (audio files, which can be filenames, URLs or pure bytes) | ||||||
|  |  | ||||||
| ```py |  | ||||||
| from transformers import pipeline |  | ||||||
|  |  | ||||||
| pipeline = pipeline("my-task") |  | ||||||
| # returns 3 most likely labels |  | ||||||
| pipeline("This is the best meal I've ever had", top_k=3) |  | ||||||
| # returns 5 most likely labels by default |  | ||||||
| pipeline("This is the best meal I've ever had") |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## Register a pipeline | ## Adding it to the list of supported tasks | ||||||
|  |  | ||||||
| Register the new task your pipeline supports in the `PIPELINE_REGISTRY`. The registry defines: | To register your `new-task` to the list of supported tasks, you have to add it to the `PIPELINE_REGISTRY`: | ||||||
|  |  | ||||||
| - the machine learning framework the pipeline supports with either `pt_model` or `tf_model` (add both to ensure it works with either frameworks) | ```python | ||||||
| - a default model which should come from a specific revision (branch, or commit hash) where the model works as expected with `default` |  | ||||||
| - the expected input with `type` |  | ||||||
|  |  | ||||||
| ```py |  | ||||||
| from transformers.pipelines import PIPELINE_REGISTRY | from transformers.pipelines import PIPELINE_REGISTRY | ||||||
| from transformers import AutoModelForSequenceClassification, TFAutoModelForSequenceClassification |  | ||||||
|  |  | ||||||
| PIPELINE_REGISTRY.register_pipeline( | PIPELINE_REGISTRY.register_pipeline( | ||||||
|     "new-task", |     "new-task", | ||||||
|     pipeline_class=MyPipeline, |     pipeline_class=MyPipeline, | ||||||
|     pt_model=AutoModelForSequenceClassification, |     pt_model=AutoModelForSequenceClassification, | ||||||
|     tf_model=TFAutoModelForSequenceClassification, |  | ||||||
|     default={"pt": ("user/awesome-model", "branch-name")}, |  | ||||||
|     type="text", |  | ||||||
| ) | ) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ## Share your pipeline | You can specify a default model if you want, in which case it should come with a specific revision (which can be the name of a branch or a commit hash, here we took `"abcdef"`) as well as the type: | ||||||
|  |  | ||||||
| Share your pipeline with the community on the [Hub](https://hf.co) or you can add it directly to Transformers. | ```python | ||||||
|  | PIPELINE_REGISTRY.register_pipeline( | ||||||
|  |     "new-task", | ||||||
|  |     pipeline_class=MyPipeline, | ||||||
|  |     pt_model=AutoModelForSequenceClassification, | ||||||
|  |     default={"pt": ("user/awesome_model", "abcdef")}, | ||||||
|  |     type="text",  # current support type: text, audio, image, multimodal | ||||||
|  | ) | ||||||
|  | ``` | ||||||
|  |  | ||||||
| It's faster to upload your pipeline code to the Hub because it doesn't require a review from the Transformers team. Adding the pipeline to Transformers may be slower because it requires a review and you need to add tests to ensure your [`Pipeline`] works. | ## Share your pipeline on the Hub | ||||||
|  |  | ||||||
| ### Upload to the Hub | To share your custom pipeline on the Hub, you just have to save the custom code of your `Pipeline` subclass in a | ||||||
|  | python file. For instance, let's say we want to use a custom pipeline for sentence pair classification like this: | ||||||
| Add your pipeline code to the Hub in a Python file. |  | ||||||
|  |  | ||||||
| For example, a custom pipeline for sentence pair classification might look like the following code below. The implementation works for PyTorch and TensorFlow models. |  | ||||||
|  |  | ||||||
| ```py | ```py | ||||||
| import numpy as np | import numpy as np | ||||||
|  |  | ||||||
| from transformers import Pipeline | from transformers import Pipeline | ||||||
|  |  | ||||||
|  |  | ||||||
| def softmax(outputs): | def softmax(outputs): | ||||||
|     maxes = np.max(outputs, axis=-1, keepdims=True) |     maxes = np.max(outputs, axis=-1, keepdims=True) | ||||||
|     shifted_exp = np.exp(outputs - maxes) |     shifted_exp = np.exp(outputs - maxes) | ||||||
|     return shifted_exp / shifted_exp.sum(axis=-1, keepdims=True) |     return shifted_exp / shifted_exp.sum(axis=-1, keepdims=True) | ||||||
|  |  | ||||||
|  |  | ||||||
| class PairClassificationPipeline(Pipeline): | class PairClassificationPipeline(Pipeline): | ||||||
|     def _sanitize_parameters(self, **kwargs): |     def _sanitize_parameters(self, **kwargs): | ||||||
|         preprocess_kwargs = {} |         preprocess_kwargs = {} | ||||||
| @ -163,7 +183,8 @@ class PairClassificationPipeline(Pipeline): | |||||||
|         return {"label": label, "score": score, "logits": logits} |         return {"label": label, "score": score, "logits": logits} | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Save the code in a file named `pair_classification.py`, and import and register it as shown below. | The implementation is framework agnostic, and will work for PyTorch and TensorFlow models. If we have saved this in | ||||||
|  | a file named `pair_classification.py`, we can then import it and register it like this. | ||||||
|  |  | ||||||
| ```py | ```py | ||||||
| from pair_classification import PairClassificationPipeline | from pair_classification import PairClassificationPipeline | ||||||
| @ -194,36 +215,56 @@ The [register_pipeline](https://github.com/huggingface/transformers/blob/9feae5f | |||||||
|   }, |   }, | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Call [`~Pipeline.push_to_hub`] to push the pipeline to the Hub. The Python file containing the code is copied to the Hub, and the pipelines model and tokenizer are also saved and pushed to the Hub. Your pipeline should now be available on the Hub under your namespace. | Once this is done, we can use it with a pretrained model. For instance `sgugger/finetuned-bert-mrpc` has been | ||||||
|  | fine-tuned on the MRPC dataset, which classifies pairs of sentences as paraphrases or not. | ||||||
|  |  | ||||||
| ```py | ```py | ||||||
| from transformers import pipeline | from transformers import pipeline | ||||||
|  |  | ||||||
| pipeline = pipeline(task="pair-classification", model="sgugger/finetuned-bert-mrpc") | classifier = pipeline("pair-classification", model="sgugger/finetuned-bert-mrpc") | ||||||
| pipeline.push_to_hub("pair-classification-pipeline") |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| To use the pipeline, add `trust_remote_code=True` when loading the pipeline. | Then we can share it on the Hub by using the `push_to_hub` method: | ||||||
|  |  | ||||||
|  | ```py | ||||||
|  | classifier.push_to_hub("test-dynamic-pipeline") | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | This will copy the file where you defined `PairClassificationPipeline` inside the folder `"test-dynamic-pipeline"`, | ||||||
|  | along with saving the model and tokenizer of the pipeline, before pushing everything into the repository | ||||||
|  | `{your_username}/test-dynamic-pipeline`. After that, anyone can use it as long as they provide the option | ||||||
|  | `trust_remote_code=True`: | ||||||
|  |  | ||||||
| ```py | ```py | ||||||
| from transformers import pipeline | from transformers import pipeline | ||||||
|  |  | ||||||
| pipeline = pipeline(task="pair-classification", trust_remote_code=True) | classifier = pipeline(model="{your_username}/test-dynamic-pipeline", trust_remote_code=True) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### Add to Transformers | ## Add the pipeline to 🤗 Transformers | ||||||
|  |  | ||||||
| Adding a custom pipeline to Transformers requires adding tests to make sure everything works as expected, and requesting a review from the Transformers team. | If you want to contribute your pipeline to 🤗 Transformers, you will need to add a new module in the `pipelines` submodule | ||||||
|  | with the code of your pipeline, then add it to the list of tasks defined in `pipelines/__init__.py`. | ||||||
|  |  | ||||||
| Add your pipeline code as a new module to the [pipelines](https://github.com/huggingface/transformers/tree/main/src/transformers/pipelines) submodule, and add it to the list of tasks defined in [pipelines/__init__.py](https://github.com/huggingface/transformers/blob/main/src/transformers/pipelines/__init__.py). | Then you will need to add tests. Create a new file `tests/test_pipelines_MY_PIPELINE.py` with examples of the other tests. | ||||||
|  |  | ||||||
| Next, add a new test for the pipeline in [transformers/tests/pipelines](https://github.com/huggingface/transformers/tree/main/tests/pipelines). You can look at the other tests for examples of how to test your pipeline. | The `run_pipeline_test` function will be very generic and run on small random models on every possible | ||||||
|  | architecture as defined by `model_mapping` and `tf_model_mapping`. | ||||||
|  |  | ||||||
| The [run_pipeline_test](https://github.com/huggingface/transformers/blob/db70426854fe7850f2c5834d633aff637f14772e/tests/pipelines/test_pipelines_text_classification.py#L186) function should be very generic and run on the models defined in [model_mapping](https://github.com/huggingface/transformers/blob/db70426854fe7850f2c5834d633aff637f14772e/tests/pipelines/test_pipelines_text_classification.py#L48) and [tf_model_mapping](https://github.com/huggingface/transformers/blob/db70426854fe7850f2c5834d633aff637f14772e/tests/pipelines/test_pipelines_text_classification.py#L49). This is important for testing future compatibility with new models. | This is very important to test future compatibility, meaning if someone adds a new model for | ||||||
|  | `XXXForQuestionAnswering` then the pipeline test will attempt to run on it. Because the models are random it's | ||||||
|  | impossible to check for actual values, that's why there is a helper `ANY` that will simply attempt to match the | ||||||
|  | output of the pipeline TYPE. | ||||||
|  |  | ||||||
| You'll also notice `ANY` is used throughout the [run_pipeline_test](https://github.com/huggingface/transformers/blob/db70426854fe7850f2c5834d633aff637f14772e/tests/pipelines/test_pipelines_text_classification.py#L186) function. The models are random, so you can't check the actual values. Using `ANY` allows the test to match the output of the pipeline type instead. | You also *need* to implement 2 (ideally 4) tests. | ||||||
|  |  | ||||||
| Finally, you should also implement the following 4 tests. | - `test_small_model_pt` : Define 1 small model for this pipeline (doesn't matter if the results don't make sense) | ||||||
|  |   and test the pipeline outputs. The results should be the same as `test_small_model_tf`. | ||||||
| 1. [test_small_model_pt](https://github.com/huggingface/transformers/blob/db70426854fe7850f2c5834d633aff637f14772e/tests/pipelines/test_pipelines_text_classification.py#L59) and [test_small_model_tf](https://github.com/huggingface/transformers/blob/db70426854fe7850f2c5834d633aff637f14772e/tests/pipelines/test_pipelines_text_classification.py#L150), use a small model for these pipelines to make sure they return the correct outputs. The results don't have to make sense. Each pipeline should return the same result. | - `test_small_model_tf` : Define 1 small model for this pipeline (doesn't matter if the results don't make sense) | ||||||
| 1. [test_large_model_pt](https://github.com/huggingface/transformers/blob/db70426854fe7850f2c5834d633aff637f14772e/tests/pipelines/test_pipelines_zero_shot_image_classification.py#L187) nad [test_large_model_tf](https://github.com/huggingface/transformers/blob/db70426854fe7850f2c5834d633aff637f14772e/tests/pipelines/test_pipelines_zero_shot_image_classification.py#L220), use a realistic model for these pipelines to make sure they return meaningful results. These tests are slow and should be marked as slow. |   and test the pipeline outputs. The results should be the same as `test_small_model_pt`. | ||||||
|  | - `test_large_model_pt` (`optional`): Tests the pipeline on a real pipeline where the results are supposed to | ||||||
|  |   make sense. These tests are slow and should be marked as such. Here the goal is to showcase the pipeline and to make | ||||||
|  |   sure there is no drift in future releases. | ||||||
|  | - `test_large_model_tf` (`optional`): Tests the pipeline on a real pipeline where the results are supposed to | ||||||
|  |   make sense. These tests are slow and should be marked as such. Here the goal is to showcase the pipeline and to make | ||||||
|  |   sure there is no drift in future releases. | ||||||
|  | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user
	