Skip to content

Files

This branch is 51887 commits behind pytorch/pytorch:main.

tools

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
Jan 22, 2021
Mar 3, 2021
Jan 14, 2021
Feb 12, 2021
Feb 8, 2021
Mar 2, 2021
Apr 7, 2020
May 3, 2018
Jan 26, 2021
Jan 6, 2021
Feb 12, 2021
Jul 18, 2020
Feb 4, 2021
Jan 22, 2021
Feb 11, 2021
Jul 18, 2020
Sep 18, 2020
Nov 14, 2020
Mar 3, 2021
Oct 6, 2020
Jul 21, 2020
Feb 4, 2021
Sep 24, 2020
Sep 18, 2020
Jun 6, 2019
Feb 26, 2021
Oct 22, 2018
Apr 22, 2020
Aug 31, 2020
Oct 22, 2018
Oct 22, 2018
Jan 7, 2021
Apr 9, 2019
Mar 2, 2021
Dec 17, 2019

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.

Legacy infrastructure (we should kill this):

  • cwrap - Implementation of legacy code generation for THNN/THCUNN. This is used by nnwrap.

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:

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:

  • docker - Dockerfile for running (but not developing) PyTorch, using the official conda binary distribution. Context: pytorch#1619
  • download_mnist.py - Download the MNIST dataset; this is necessary if you want to run the C++ API tests.
  • run-clang-tidy-in-ci.sh - Responsible for checking that C++ code is clang-tidy clean in CI on Travis