Skip to content

Commit

Permalink
Add LTC architecture diagram (#1291)
Browse files Browse the repository at this point in the history
* Add LTC architecture diagram

* Use PNG for diagrams

* Update diagram
  • Loading branch information
henrytwo authored Aug 26, 2022
1 parent 8e880a2 commit 883c6b4
Show file tree
Hide file tree
Showing 8 changed files with 5 additions and 3 deletions.
8 changes: 5 additions & 3 deletions docs/ltc_backend.md
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,8 @@ Generated files are created in this directory, which is ignored by version contr

## Architecture

![LTC Diagram](ltc_images/ltc_architecture.png)

### Tracing LTC graph

The journey begins with a tensor in PyTorch on the `lazy` device, which may undergo a number of operations during its lifetime.
Expand All @@ -91,7 +93,7 @@ previously registered in `RegisterLazy.cpp`.
Next, `LazyNativeFunctions::tanh` from `LazyNativeFunctions.cpp` is called, which triggers the creation of a `Tanh` node, which is a subclass of `TorchMlirNode` and `torch::lazy::Node`, defined in `LazyIr.h`.
These nodes are then tracked internally by LTC as the computation graph is traced out.

![Tracing Tensors](ltc_images/tracing_tensors.jpg)
![Tracing Tensors](ltc_images/tracing_tensors.png)

### Syncing Tensors

Expand All @@ -107,15 +109,15 @@ creates an instance of `TorchMlirLoweringContext`. Here, the `TorchMlirNode`s ar
Next, `TorchMlirLoweringContext::Build` is executed and the final `jit::Graph` is sent to `torch_mlir::importJitFunctionAsFuncOp` to generate MLIR using the existing infrastructure from Torch-MLIR.
At this point, a `TorchMlirComputation` is created containing the final `mlir::FuncOp`.

![Syncing Tensors](ltc_images/syncing_tensors.jpg)
![Syncing Tensors](ltc_images/syncing_tensors.png)

### Final Compilation and Execution

The `TorchMlirComputation` is sent to the vendor specific implementation of `TorchMlirBackendImpl::Compile` to be handed off to the vendor's compilation stack (if applicable).

Finally, the compiled computation is sent to `TorchMlirBackendImpl::ExecuteComputation` to be executed on the vendor device, which produces some results to be send back to PyTorch.

![Vendor Execution](ltc_images/vendor_execution.jpg)
![Vendor Execution](ltc_images/vendor_execution.png)

## Implementing a custom backend

Expand Down
Binary file added docs/ltc_images/ltc_architecture.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file removed docs/ltc_images/syncing_tensors.jpg
Binary file not shown.
Binary file added docs/ltc_images/syncing_tensors.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file removed docs/ltc_images/tracing_tensors.jpg
Binary file not shown.
Binary file added docs/ltc_images/tracing_tensors.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file removed docs/ltc_images/vendor_execution.jpg
Binary file not shown.
Binary file added docs/ltc_images/vendor_execution.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit 883c6b4

Please sign in to comment.