pytorch/tools
lezcano fc5b4a5a33 Add linalg.lu_solve
This PR adds `linalg.lu_solve`. While doing so, I found a bug in MAGMA
when calling the batched MAGMA backend with trans=True. We work around
that by solving the system solving two triangular systems.

We also update the heuristics for this function, as they were fairly
updated. We found that cuSolver is king, so luckily we do not need to
rely on the buggy backend from magma for this function.

We added tests testing this function left and right. We also added tests
for the different backends. We also activated the tests for AMD, as
those should work as well.

Fixes https://github.com/pytorch/pytorch/issues/61657

Pull Request resolved: https://github.com/pytorch/pytorch/pull/72935

Approved by: https://github.com/IvanYashchuk, https://github.com/mruberry
2022-05-05 19:02:13 +00:00
..
amd_build [PyTorch][AMD] fix hipify_python (#76720) 2022-05-03 22:59:10 +00:00
autograd Add linalg.lu_solve 2022-05-05 19:02:13 +00:00
clang_format_hash
code_analyzer Rename tools/codegen to torchgen (#76275) 2022-04-25 01:38:06 +00:00
code_coverage fix 'pytorch/tools/code_coverage/README.md' for renamed options 2022-04-08 15:57:40 +00:00
config
coverage_plugins_package Run Black on all of tools/ 2022-04-20 17:29:41 +00:00
fast_nvcc Run Black on all of tools/ 2022-04-20 17:29:41 +00:00
gdb Run Black on all of tools/ 2022-04-20 17:29:41 +00:00
iwyu Run Black on all of tools/ 2022-04-20 17:29:41 +00:00
jit Revert "Revert "Allow specifying tags for aten operators in native_functions.yaml"" 2022-04-28 02:04:57 +00:00
linter [lint] fix pip init for lint when user has a global install 2022-05-03 19:36:59 +00:00
lite_interpreter Rename tools/codegen to torchgen (#76275) 2022-04-25 01:38:06 +00:00
lldb Run Black on all of tools/ 2022-04-20 17:29:41 +00:00
onnx [ONNX] Format ONNX python with black 2022-05-05 00:19:22 +00:00
pyi Add docstrings to sparse compressed tensor factory functions 2022-05-04 03:36:14 +00:00
rules
setup_helpers introduce new --gen-dir flag to generate_code and use it in fbcode (#75800) 2022-05-04 15:26:25 +00:00
shared [lint] upgrade mypy to latest version 2022-05-03 20:51:34 +00:00
stats [lint] upgrade mypy to latest version 2022-05-03 20:51:34 +00:00
test [lint] upgrade mypy to latest version 2022-05-03 20:51:34 +00:00
testing Allow sharding for distributed tests 2022-04-29 03:55:07 +00:00
__init__.py
actions_local_runner.py Run Black on all of tools/ 2022-04-20 17:29:41 +00:00
bazel.bzl add support for filtering out Bazel targets from common structure (#76173) 2022-05-03 12:13:19 +00:00
build_libtorch.py Run Black on all of tools/ 2022-04-20 17:29:41 +00:00
build_pytorch_libs.py Run Black on all of tools/ 2022-04-20 17:29:41 +00:00
build_variables.bzl [LT] Add a trie data structure for caching IR nodes 2022-05-04 23:48:03 +00:00
download_mnist.py Run Black on all of tools/ 2022-04-20 17:29:41 +00:00
extract_scripts.py Run Black on all of tools/ 2022-04-20 17:29:41 +00:00
gen_flatbuffers.sh
generate_torch_version.py Run Black on all of tools/ 2022-04-20 17:29:41 +00:00
generated_dirs.txt
git-pre-commit Remove flake8 pre-commit hook 2022-04-07 19:01:30 +00:00
git_add_generated_dirs.sh
git_reset_generated_dirs.sh
nightly.py Run Black on all of tools/ 2022-04-20 17:29:41 +00:00
nvcc_fix_deps.py
pytorch.version
README.md
render_junit.py Run Black on all of tools/ 2022-04-20 17:29:41 +00:00
ufunc_defs.bzl
update_masked_docs.py Run Black on all of tools/ 2022-04-20 17:29:41 +00:00
vscode_settings.py Run Black on all of tools/ 2022-04-20 17:29:41 +00:00

This folder contains a number of scripts which are used as part of the PyTorch build process. This directory also doubles as a Python module hierarchy (thus the __init__.py).

Overview

Modern infrastructure:

  • autograd - Code generation for autograd. This includes definitions of all our derivatives.
  • jit - Code generation for JIT
  • shared - Generic infrastructure that scripts in tools may find useful.
    • module_loader.py - Makes it easier to import arbitrary Python files in a script, without having to add them to the PYTHONPATH first.

Build system pieces:

  • setup_helpers - Helper code for searching for third-party dependencies on the user system.
  • build_pytorch_libs.py - cross-platform script that builds all of the constituent libraries of PyTorch, but not the PyTorch Python extension itself.
  • build_libtorch.py - Script for building libtorch, a standalone C++ library without Python support. This build script is tested in CI.
  • fast_nvcc - Mostly-transparent wrapper over nvcc that parallelizes compilation when used to build CUDA files for multiple architectures at once.
    • fast_nvcc.py - Python script, entrypoint to the fast nvcc wrapper.

Developer tools which you might find useful:

  • linter/clang_tidy - Script for running clang-tidy on lines of your script which you changed.
  • extract_scripts.py - Extract scripts from .github/workflows/*.yml into a specified dir, on which linters such as linter/run_shellcheck.sh can be run. Assumes that every run script has shell: bash unless a different shell is explicitly listed on that specific step (so defaults doesn't currently work), but also has some rules for other situations such as actions/github-script. Exits with nonzero status if any of the extracted scripts contain GitHub Actions expressions: ${{<expression> }}
  • git_add_generated_dirs.sh and git_reset_generated_dirs.sh - Use this to force add generated files to your Git index, so that you can conveniently run diffs on them when working on code-generation. (See also generated_dirs.txt which specifies the list of directories with generated files.)
  • linter/mypy_wrapper.py - Run mypy on a single file using the appropriate subset of our mypy*.ini configs.
  • linter/run_shellcheck.sh - Find *.sh files (recursively) in the directories specified as arguments, and run ShellCheck on all of them.
  • stats/test_history.py - Query S3 to display history of a single test across multiple jobs over time.
  • linter/trailing_newlines.py - Take names of UTF-8 files from stdin, print names of nonempty files whose contents don't end in exactly one trailing newline, exit with status 1 if no output printed or 0 if some filenames were printed.
  • linter/translate_annotations.py - Read Flake8 or clang-tidy warnings (according to a --regex) from a --file, convert to the JSON format accepted by pytorch/add-annotations-github-action, and translate line numbers from HEAD back in time to the given --commit by running git diff-index --unified=0 appropriately.
  • vscode_settings.py - Merge .vscode/settings_recommended.json into your workspace-local .vscode/settings.json, preferring the former in case of conflicts but otherwise preserving the latter as much as possible.

Important if you want to run on AMD GPU:

  • amd_build - HIPify scripts, for transpiling CUDA into AMD HIP. Right now, PyTorch and Caffe2 share logic for how to do this transpilation, but have separate entry-points for transpiling either PyTorch or Caffe2 code.
    • build_amd.py - Top-level entry point for HIPifying our codebase.

Tools which are only situationally useful: