Skip to content

Commit

Permalink
install_requirements.py: remove unnecessary requirements
Browse files Browse the repository at this point in the history
Duplicate requirements with the pyproject.toml > /dev/null
One unique devel reqiurement > requirements-dev.txt
Examples requirements > requirements-examples.txt
Nightlies stayed in the script.

Rationale: be as "normal" a Python project as seemed possible.

Test Plan: install_requirements.sh in a clean venv succeeded

ghstack-source-id: e16c6556020033a5888496919f4fcaaad2426d7a
ghstack-comment-id: 2596313740
Pull Request resolved: #7705
  • Loading branch information
swolchok committed Jan 16, 2025
1 parent 21c83fb commit 76d4182
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 21 deletions.
26 changes: 5 additions & 21 deletions install_requirements.py
Original file line number Diff line number Diff line change
Expand Up @@ -104,35 +104,15 @@ def install_requirements(use_pytorch_nightly):
if use_pytorch_nightly
else "torchvision"
), # For testing.
"typing-extensions",
]

# pip packages needed to run examples.
# TODO: Make each example publish its own requirements.txt
EXAMPLES_REQUIREMENTS = [
"timm==1.0.7",
f"torchaudio==2.6.0.{NIGHTLY_VERSION}" if use_pytorch_nightly else "torchaudio",
"torchsr==1.0.4",
"transformers==4.47.1",
]

# pip packages needed for development.
DEVEL_REQUIREMENTS = [
"cmake", # For building binary targets.
"pip>=23", # For building the pip package.
"pyyaml", # Imported by the kernel codegen tools.
"setuptools>=63", # For building the pip package.
"tomli", # Imported by extract_sources.py when using python < 3.11.
"wheel", # For building the pip package archive.
"zstd", # Imported by resolve_buck.py.
"ai-edge-model-explorer>=0.1.16", # For visualizing ExportedPrograms
]

# Assemble the list of requirements to actually install.
# TODO: Add options for reducing the number of requirements.
REQUIREMENTS_TO_INSTALL = (
EXIR_REQUIREMENTS + DEVEL_REQUIREMENTS + EXAMPLES_REQUIREMENTS
)
REQUIREMENTS_TO_INSTALL = EXIR_REQUIREMENTS + EXAMPLES_REQUIREMENTS

# Install the requirements. `--extra-index-url` tells pip to look for package
# versions on the provided URL if they aren't available on the default URL.
Expand All @@ -142,6 +122,8 @@ def install_requirements(use_pytorch_nightly):
"-m",
"pip",
"install",
"-r",
"requirements-examples.txt",
*REQUIREMENTS_TO_INSTALL,
"--extra-index-url",
TORCH_NIGHTLY_URL,
Expand All @@ -161,6 +143,8 @@ def install_requirements(use_pytorch_nightly):
"-m",
"pip",
"install",
# Without --no-build-isolation, setup.py can't find the torch module.
"--no-build-isolation",
*LOCAL_REQUIREMENTS,
],
check=True,
Expand Down
5 changes: 5 additions & 0 deletions requirements-examples.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
# pip packages needed to run examples.
# TODO: Make each example publish its own requirements.txt
timm == 1.0.7
torchsr == 1.0.4
transformers ==4.47.1

0 comments on commit 76d4182

Please sign in to comment.