returnn 1.20240718.142037__tar.gz → 1.20240719.111324__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of returnn might be problematic. Click here for more details.
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/PKG-INFO +1 -1
- returnn-1.20240719.111324/_setup_info_generated.py +2 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn.egg-info/PKG-INFO +1 -1
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn.egg-info/SOURCES.txt +1 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_torch_util.py +4 -131
- returnn-1.20240719.111324/tests/torch_utils.py +230 -0
- returnn-1.20240718.142037/_setup_info_generated.py +0 -2
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/.editorconfig +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/.gitignore +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/.gitmodules +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/.kateconfig +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/CHANGELOG.md +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/CODEOWNERS +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/CONTRIBUTING.md +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/LICENSE +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/MANIFEST.in +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/README.rst +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/12AX.cluster_map +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/_setup_returnn_env.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-fwd.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-horovod-mpi.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-horovod-mpi.py.sh +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-horovod-mpi.sh +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-hyper-param-tuning.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-iter-dataset.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-list-devices.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-lua-torch-layer.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-pretrain.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-record-and-push-to-webserver.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-returnn-as-framework.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-rf-pt-benchmark.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-rf.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-rhn-enwik8.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-sprint-interface.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-att-copy.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-attention.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-chunking-blstm.12ax.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-contribrnn-lstm.12ax.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-enc-dec.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-hard-att-copy.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-lstm-benchmark.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-maxgradnorm-lstm.12ax.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-native-lstm-lowmem.12ax.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-native-lstm.12ax.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-native-lstm2.12ax.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-native-lstm2.12ax.tuned.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-neural-transducer.12ax.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-rec-explicit-lstm.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-rec-explicit-rnn.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-rec-self-att.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-search-compiled-graph.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-vanilla-lstm.12ax.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-timit-lstm-ctc.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-torch.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-upd-mult-model.lstm.12ax.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo.sh +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/IAM_lines/a01-000u-00.png +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/IAM_lines/a01-007-04.png +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/IAM_lines/a01-007-06.png +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/README.txt +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/chars.txt +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/config_demo +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/config_fwd +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/config_real +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/create_IAM_dataset.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/decode.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/features/raw/demo.h5 +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/go.sh +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/lines.txt +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/split/eval.txt +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/split/train.txt +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/split/valid.txt +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/README.md +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/artificial/create_test_h5.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/artificial/forwardconfig +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/artificial/go.sh +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/artificial/trainconfig +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/artificial_rgb/create_test_h5.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/artificial_rgb/forwardconfig +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/artificial_rgb/go.sh +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/artificial_rgb/trainconfig +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/pyproject.toml +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/requirements.txt +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/__main__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/__old_mod_loader__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/__setup__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/config.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/audio.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/basic.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/bundle_file.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/cached.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/cached2.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/distrib_files.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/generating.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/hdf.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/lm.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/map.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/meta.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/multi_proc.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/normalization_data.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/numpy_dump.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/raw_wav.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/sprint.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/stereo.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/util/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/util/feature_extraction.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/util/strings.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/datasets/util/vocabulary.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/engine/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/engine/base.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/engine/batch.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/__main__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/.git +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/.gitignore +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/LICENSE +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/README.md +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/aligner.gif +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/check.png +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/core.cu +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/core.h +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/core_cpu.cpp +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/pytorch_binding/LICENSE +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/pytorch_binding/MANIFEST.in +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/pytorch_binding/README.md +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/pytorch_binding/binding.cpp +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/pytorch_binding/core.cu +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/pytorch_binding/core.h +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/pytorch_binding/requirements.txt +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/pytorch_binding/setup.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/pytorch_binding/warp_rna/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/pytorch_binding/warp_rna/test.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/ref_rna.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/tensorflow_binding/setup.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/tensorflow_binding/src/warp_rna_op.cc +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/tensorflow_binding/src/warp_rna_op_kernel_tmpl.h +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/tensorflow_binding/warp_rna/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/WarpRna/warp-rna/test.cpp +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/graph_editor/README.md +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/graph_editor/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/graph_editor/edit.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/graph_editor/reroute.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/graph_editor/select.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/graph_editor/subgraph.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/graph_editor/transform.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/extern/graph_editor/util.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/forward_iface.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/_backend.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/_native/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/_native/backend.cpp +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/_native/backend.hpp +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/_native/module.cpp +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/_native/module.hpp +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/_native/py_utils.hpp +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/_native/tensor_ops.cpp +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/_native/tensor_ops.hpp +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/_numpy_backend.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/_random_journal.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/_utils.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/array_.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/attention.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/audio/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/audio/mel.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/audio/specaugment.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/backend.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/build_from_dict.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/cond.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/const.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/container.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/control_flow_ctx.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/conv.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/decoder/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/decoder/transformer.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/device.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/dims.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/dropout.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/dtype.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/encoder/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/encoder/base.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/encoder/conformer.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/gradient.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/graph.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/hooks.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/init.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/label_smoothing.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/linear.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/loop.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/loss.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/math_.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/matmul.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/module.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/normalization.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/parameter.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/parametrizations.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/parametrize.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/piecewise_linear.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/rand.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/rec.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/reduce.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/run_ctx.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/signal.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/state.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/stepwise_scheduler.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/tensor_array.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/frontend/types.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/import_/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/import_/common.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/import_/git.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/import_/import_.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/learning_rate_control.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/log.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/native_op.cpp +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/native_op.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/pretrain.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/sprint/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/sprint/cache.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/sprint/control.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/sprint/error_signals.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/sprint/extern_interface.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/sprint/interface.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tensor/README.md +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tensor/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tensor/_dim_extra.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tensor/_tensor_extra.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tensor/_tensor_mixin_base.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tensor/_tensor_op_overloads.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tensor/control_flow_ctx.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tensor/dim.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tensor/marked_dim.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tensor/tensor.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tensor/tensor_dict.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tensor/utils.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/compat.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/data_pipeline.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/distributed.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/engine.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_layers/README.md +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_layers/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_layers/_backend.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_layers/_utils.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_layers/cond.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_layers/config_entry_points.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_layers/debug_eager_mode.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_layers/dims.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_layers/layer.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_layers/loop.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_layers/make_layer.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_layers/masked_computation.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_layers/parameter_assign.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_layers/prev_tensor_ref.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_low_level/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/frontend_low_level/_backend.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/horovod.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/hyper_param_tuning.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/layers/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/layers/base.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/layers/basic.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/layers/rec.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/layers/segmental_model.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/layers/signal_processing.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/layers/variable.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/native_op.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/network.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/sprint.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/updater.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/util/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/util/basic.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/util/data.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/util/gradient_checkpoint.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/util/ken_lm.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/tf/util/open_fst.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/README.md +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/data/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/data/extern_data.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/data/pipeline.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/data/queued_data_iter.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/data/returnn_dataset_wrapper.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/data/tensor_utils.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/distributed.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/engine.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/frontend/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/frontend/_backend.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/frontend/_rand.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/frontend/bridge.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/frontend/raw_ops.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/updater.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/util/README.md +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/util/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/util/diagnose_gpu.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/util/gradient_checkpoint.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/torch/util/scaled_gradient.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/__init__.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/basic.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/better_exchook.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/bpe.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/debug.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/debug_helpers.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/file_cache.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/fsa.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/literal_py_to_pickle.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/math.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/multi_proc_non_daemonic_spawn.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/native_code_compiler.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/pprint.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/py-to-pickle.cpp +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/py_compat.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/py_ext_mod_compiler.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/result_with_reason.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/sig_proc.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/task_system.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/train_proc_manager.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn/util/watch_memory.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn.egg-info/dependency_links.txt +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/returnn.egg-info/top_level.txt +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/rnn.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/setup.cfg +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/setup.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/DummySprintExec.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/PyCharm-inspection-profile.xml +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/PyCharm.idea/.gitignore +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/PyCharm.idea/.name +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/PyCharm.idea/codeStyleSettings.xml +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/PyCharm.idea/codeStyles/Project.xml +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/PyCharm.idea/codeStyles/codeStyleConfig.xml +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/PyCharm.idea/inspectionProfiles/Project_Default.xml +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/PyCharm.idea/inspectionProfiles/profiles_settings.xml +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/PyCharm.idea/misc.xml +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/PyCharm.idea/modules.xml +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/PyCharm.idea/returnn.iml +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/PyCharm.idea/scopes/scope_settings.xml +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/_set_num_threads1.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/_setup_returnn_env.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/_setup_test_env.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/bpe-unicode-demo.codes +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/bpe-unicode-demo.vocab +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/lexicon_opt.fst +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/lexicon_opt.isyms +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/lexicon_opt.jpg +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/lexicon_opt.osyms +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/lint_common.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/pycharm-inspect.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/pylint.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/returnn-as-framework.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/rf_utils.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/spelling.dic +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_Config.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_Dataset.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_Fsa.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_GeneratingDataset.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_HDFDataset.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_LearningRateControl.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_Log.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_MultiProcDataset.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_Pretrain.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_ResNet.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_SprintDataset.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_SprintInterface.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_TFEngine.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_TFNativeOp.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_TFNetworkLayer.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_TFNetworkRecLayer.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_TFNetworkSigProcLayer.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_TFUpdater.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_TFUtil.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_TF_determinism.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_TaskSystem.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_TaskSystem_SharedMem.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_TranslationDataset.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_Util.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_demos.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_fork_exec.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_hdf_dump.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_array.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_attention.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_base.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_cond.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_const.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_container.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_conv.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_encoder_conformer.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_gradient.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_label_smoothing.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_loop.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_math.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_normalization.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_piecewise_linear.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_rec.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_reduce.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_rf_signal.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_tensor.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_tools.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_torch_dataset.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_torch_engine.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_torch_frontend.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tests/test_torch_internal_frontend.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/_setup_returnn_env.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/analyze-dataset-batches.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/bliss-collect-seq-lens.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/bliss-dump-text.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/bliss-get-segment-names.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/bliss-to-ogg-zip.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/bpe-create-lexicon.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/calculate-word-error-rate.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/cleanup-old-models.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/collect-orth-symbols.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/collect-words.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/compile_native_op.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/compile_tf_graph.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/debug-dump-search-scores.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/debug-plot-search-scores.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/dump-dataset-raw-strings.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/dump-dataset.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/dump-forward-stats.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/dump-forward.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/dump-network-json.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/dump-pickle.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/extract_state_tying_from_dataset.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/get-attention-weights.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/get-best-model-epoch.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/hdf_dump.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/hdf_dump_translation_dataset.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/import-blocks-mt-model.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/import-t2t-mt-model.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/.gitignore +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/Makefile +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/README.md +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/example/README.md +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/example/libs_list +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/example/network.040/i600_m600_m600.sgd_b16_lr0_cl2.newbobabs.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/example/network.040/i600_m600_m600.sgd_b16_lr0_cl2.newbobabs.keep_over_epoch.lstm2.config +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/example/rescore_lattice.sh +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/example/state_vars_list +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/example/tensor_names_list +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/file.h +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/htklatticerescorer.cc +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/htklatticerescorer.h +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/main.cc +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/rescorer.h +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/vocabulary.cc +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/lattice_rescorer/vocabulary.h +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/tf_avg_checkpoints.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/tf_inspect_checkpoint.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/tf_inspect_summary_log.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/torch_avg_checkpoints.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/torch_export_to_onnx.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/torch_inspect_checkpoint.py +0 -0
- {returnn-1.20240718.142037 → returnn-1.20240719.111324}/tools/torch_inspect_checkpoint_and_opt.py +0 -0
|
@@ -385,6 +385,7 @@ tests/test_torch_engine.py
|
|
|
385
385
|
tests/test_torch_frontend.py
|
|
386
386
|
tests/test_torch_internal_frontend.py
|
|
387
387
|
tests/test_torch_util.py
|
|
388
|
+
tests/torch_utils.py
|
|
388
389
|
tests/PyCharm.idea/.gitignore
|
|
389
390
|
tests/PyCharm.idea/.name
|
|
390
391
|
tests/PyCharm.idea/codeStyleSettings.xml
|
|
@@ -11,6 +11,8 @@ import sys
|
|
|
11
11
|
import unittest
|
|
12
12
|
import torch
|
|
13
13
|
|
|
14
|
+
from torch_utils import report_profile
|
|
15
|
+
|
|
14
16
|
from returnn.util import better_exchook
|
|
15
17
|
|
|
16
18
|
|
|
@@ -62,7 +64,7 @@ def test_gradient_checkpoint_scope():
|
|
|
62
64
|
b = 4 # size single f32
|
|
63
65
|
t = shape[0] * shape[1] * b # size tensor
|
|
64
66
|
r = rng_state.numel() * rng_state.element_size()
|
|
65
|
-
|
|
67
|
+
report_profile(
|
|
66
68
|
prof,
|
|
67
69
|
[
|
|
68
70
|
# ignore private calls
|
|
@@ -95,7 +97,7 @@ def test_gradient_checkpoint_scope():
|
|
|
95
97
|
with profile(activities=[ProfilerActivity.CPU], profile_memory=True, with_stack=True, record_shapes=True) as prof:
|
|
96
98
|
with record_function("train_step_grad_ckpt"):
|
|
97
99
|
model.demo_run()
|
|
98
|
-
|
|
100
|
+
report_profile(
|
|
99
101
|
prof,
|
|
100
102
|
[
|
|
101
103
|
("pycall", {"callsite_name": "demo_run"}),
|
|
@@ -245,135 +247,6 @@ def test_saved_tensors_hooks_gc_segfault():
|
|
|
245
247
|
x.sum().backward()
|
|
246
248
|
|
|
247
249
|
|
|
248
|
-
def _report_profile(prof: torch.profiler.profiler, check_events=(), *, _size_threshold=100):
|
|
249
|
-
# Note: I tried prof.events(), prof.profiler.kineto_results.events(), prof._memory_profile().timeline,
|
|
250
|
-
# but they all are not really giving me the information I want.
|
|
251
|
-
# Either the Python stack is missing, or the memory information is incomplete,
|
|
252
|
-
# or the Python/TorchOp events are missing.
|
|
253
|
-
# The only complete information source seems to be prof.profiler.kineto_results.experimental_event_tree().
|
|
254
|
-
|
|
255
|
-
import fnmatch
|
|
256
|
-
|
|
257
|
-
# noinspection PyProtectedMember
|
|
258
|
-
from torch.profiler._utils import traverse_dfs
|
|
259
|
-
from torch._C._profiler import _EventType # noqa
|
|
260
|
-
|
|
261
|
-
_allocs = {} # id -> dict with "size", "name"
|
|
262
|
-
check_events = list(check_events)
|
|
263
|
-
|
|
264
|
-
def _ev_visit(ev):
|
|
265
|
-
# ev: torch._C._profiler._ProfilerEvent
|
|
266
|
-
if ev.typed[0] == _EventType.Allocation:
|
|
267
|
-
ex = ev.typed[1] # torch._C._profiler._ExtraFields_Allocation
|
|
268
|
-
# ex.id/ex.allocation_id/ex.ptr redundant?
|
|
269
|
-
if ex.allocation_id in _allocs:
|
|
270
|
-
ev_name = "dealloc" # deallocation
|
|
271
|
-
assert _allocs[ex.allocation_id]["size"] == -ex.alloc_size
|
|
272
|
-
name = _allocs[ex.allocation_id]["name"]
|
|
273
|
-
del _allocs[ex.allocation_id]
|
|
274
|
-
else:
|
|
275
|
-
ev_name = "alloc"
|
|
276
|
-
assert ex.alloc_size > 0
|
|
277
|
-
assert ev.parent
|
|
278
|
-
name = _ctx(ev.parent)
|
|
279
|
-
_allocs[ex.allocation_id] = {"size": ex.alloc_size, "name": name}
|
|
280
|
-
opts = {"id": ex.allocation_id, "name": name, "size": ex.alloc_size, "total_alloc": ex.total_allocated}
|
|
281
|
-
elif ev.typed[0] == _EventType.TorchOp:
|
|
282
|
-
ev_name = "torchop"
|
|
283
|
-
ex = ev.typed[1] # torch._C._profiler._ExtraFields_TorchOp
|
|
284
|
-
opts = {"name": ex.name}
|
|
285
|
-
elif ev.typed[0] == _EventType.PyCall:
|
|
286
|
-
ev_name = "pycall"
|
|
287
|
-
ex = ev.typed[1] # torch._C._profiler._ExtraFields_PyCall
|
|
288
|
-
ex0 = ex.caller # torch._C._profiler._PyFrameState
|
|
289
|
-
ex1 = ex.callsite # torch._C._profiler._PyFrameState
|
|
290
|
-
if _pycall_filter_fn(ex0.file_name) or _pycall_filter_fn(ex1.file_name):
|
|
291
|
-
opts = {
|
|
292
|
-
"caller_loc": f"{ex0.file_name}:{ex0.line_number}",
|
|
293
|
-
"caller_name": ex0.function_name,
|
|
294
|
-
"callsite_name": ex1.function_name,
|
|
295
|
-
}
|
|
296
|
-
else:
|
|
297
|
-
return
|
|
298
|
-
else:
|
|
299
|
-
return
|
|
300
|
-
|
|
301
|
-
next_check = check_events[0] if check_events else None
|
|
302
|
-
if next_check:
|
|
303
|
-
next_check_name, next_check_opts = next_check
|
|
304
|
-
if ev_name == next_check_name:
|
|
305
|
-
for k, v in next_check_opts.items():
|
|
306
|
-
if isinstance(v, str) and "*" in v:
|
|
307
|
-
if not fnmatch.fnmatch(opts[k], v):
|
|
308
|
-
mismatch = f"Pattern mismatch: {opts[k]} vs {v}"
|
|
309
|
-
break
|
|
310
|
-
elif k == "total_alloc":
|
|
311
|
-
if abs(opts[k] - v) >= _size_threshold:
|
|
312
|
-
mismatch = f"Size mismatch: {opts[k]} vs {v}"
|
|
313
|
-
break
|
|
314
|
-
elif opts[k] != v:
|
|
315
|
-
mismatch = f"Value mismatch: {opts[k]} vs {v}"
|
|
316
|
-
break
|
|
317
|
-
else:
|
|
318
|
-
mismatch = None
|
|
319
|
-
else:
|
|
320
|
-
mismatch = f"Different event: {ev_name} vs {next_check_name}"
|
|
321
|
-
else:
|
|
322
|
-
mismatch = "No check event"
|
|
323
|
-
|
|
324
|
-
if ev_name in {"alloc", "dealloc"} and abs(opts["size"]) >= _size_threshold:
|
|
325
|
-
assert not mismatch, f"Event not matched: {ev_name} {opts} to {next_check}: {mismatch}"
|
|
326
|
-
|
|
327
|
-
if not mismatch:
|
|
328
|
-
print(f"{ev_name} {opts} ✓")
|
|
329
|
-
check_events.pop(0)
|
|
330
|
-
else:
|
|
331
|
-
print(f"({ev_name} {opts})")
|
|
332
|
-
|
|
333
|
-
def _ctx(ev) -> str:
|
|
334
|
-
stack = [None]
|
|
335
|
-
parent = ev
|
|
336
|
-
while parent and parent.typed[0] == _EventType.TorchOp: # go to top torch op
|
|
337
|
-
stack[-1] = parent.typed[1].name
|
|
338
|
-
parent = parent.parent
|
|
339
|
-
if not stack[-1] and parent.typed[0] == _EventType.PyCCall:
|
|
340
|
-
stack[-1] = parent.typed[1].caller.function_name
|
|
341
|
-
parent = parent.parent
|
|
342
|
-
if not stack[-1]:
|
|
343
|
-
stack.pop(-1)
|
|
344
|
-
while parent:
|
|
345
|
-
if parent.typed[0] == _EventType.PyCall:
|
|
346
|
-
ex0 = parent.typed[1].caller # torch._C._profiler._PyFrameState
|
|
347
|
-
ex1 = parent.typed[1].callsite # torch._C._profiler._PyFrameState
|
|
348
|
-
if (
|
|
349
|
-
_pycall_filter_fn(ex1.file_name)
|
|
350
|
-
or (_pycall_filter_fn(ex0.file_name) and ex1.function_name == "backward")
|
|
351
|
-
) and ex1.function_name not in {"__torch_dispatch__"}:
|
|
352
|
-
stack.append(ex1.function_name)
|
|
353
|
-
parent = parent.parent
|
|
354
|
-
stack.reverse()
|
|
355
|
-
return "/".join(stack) or "unknown"
|
|
356
|
-
|
|
357
|
-
for ev_ in sorted(
|
|
358
|
-
traverse_dfs(prof.profiler.kineto_results.experimental_event_tree()), key=lambda ev: ev.start_time_ns
|
|
359
|
-
):
|
|
360
|
-
# ev: torch._C._profiler._ProfilerEvent
|
|
361
|
-
_ev_visit(ev_)
|
|
362
|
-
|
|
363
|
-
assert not _allocs, f"Remaining allocs: {_allocs}"
|
|
364
|
-
assert not check_events, f"Remaining check events: {check_events}"
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
def _pycall_filter_fn(filename: str) -> bool:
|
|
368
|
-
assert not filename.startswith("/") # currently the case...
|
|
369
|
-
if os.path.basename(filename) == os.path.basename(__file__):
|
|
370
|
-
assert "/" not in filename # currently the case...
|
|
371
|
-
return True
|
|
372
|
-
if filename.startswith("returnn/"):
|
|
373
|
-
return True
|
|
374
|
-
return False
|
|
375
|
-
|
|
376
|
-
|
|
377
250
|
if __name__ == "__main__":
|
|
378
251
|
better_exchook.install()
|
|
379
252
|
if len(sys.argv) <= 1:
|
|
@@ -0,0 +1,230 @@
|
|
|
1
|
+
"""
|
|
2
|
+
Utilities for PyTorch tests
|
|
3
|
+
"""
|
|
4
|
+
|
|
5
|
+
from __future__ import annotations
|
|
6
|
+
from typing import Optional, Any, Sequence, Tuple, Dict
|
|
7
|
+
import torch
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
def report_profile(
|
|
11
|
+
prof: torch.profiler.profiler,
|
|
12
|
+
check_events: Optional[Sequence[Tuple[str, Dict[str, Any]]]] = None,
|
|
13
|
+
*,
|
|
14
|
+
allow_remaining_allocs: bool = False,
|
|
15
|
+
_size_threshold: int = 100,
|
|
16
|
+
) -> None:
|
|
17
|
+
"""
|
|
18
|
+
Report profile.
|
|
19
|
+
|
|
20
|
+
Example usage::
|
|
21
|
+
|
|
22
|
+
from torch.profiler import profile, ProfilerActivity
|
|
23
|
+
|
|
24
|
+
with profile(
|
|
25
|
+
activities=[ProfilerActivity.CPU], profile_memory=True, with_stack=True, record_shapes=True
|
|
26
|
+
) as prof:
|
|
27
|
+
# code to profile
|
|
28
|
+
...
|
|
29
|
+
|
|
30
|
+
report_profile(prof)
|
|
31
|
+
|
|
32
|
+
:param prof: via torch.profiler.profile.
|
|
33
|
+
:param check_events: if given, will check that the report matches the given events.
|
|
34
|
+
Each entry is a tuple (event_name, event_opts).
|
|
35
|
+
The event_name can be "alloc", "dealloc", "torchop", "pycall".
|
|
36
|
+
The event_opts is a dict with the expected values.
|
|
37
|
+
You can use "*" as a wildcard in the event_opts.
|
|
38
|
+
:param allow_remaining_allocs: if True, will not raise an error if there are remaining allocations.
|
|
39
|
+
:param _size_threshold: internal
|
|
40
|
+
"""
|
|
41
|
+
# Note: I tried prof.events(), prof.profiler.kineto_results.events(), prof._memory_profile().timeline,
|
|
42
|
+
# but they all are not really giving me the information I want.
|
|
43
|
+
# Either the Python stack is missing, or the memory information is incomplete,
|
|
44
|
+
# or the Python/TorchOp events are missing.
|
|
45
|
+
# The only complete information source seems to be prof.profiler.kineto_results.experimental_event_tree().
|
|
46
|
+
|
|
47
|
+
import fnmatch
|
|
48
|
+
|
|
49
|
+
# noinspection PyProtectedMember
|
|
50
|
+
from torch.profiler._utils import traverse_dfs
|
|
51
|
+
from torch._C._profiler import _EventType # noqa
|
|
52
|
+
|
|
53
|
+
_printed_events = set()
|
|
54
|
+
_events_stack_depth = {}
|
|
55
|
+
_allocs = {} # id -> dict with "size", "name"
|
|
56
|
+
check_events = list(check_events) if check_events is not None else None
|
|
57
|
+
|
|
58
|
+
def _ev_visit(ev):
|
|
59
|
+
# ev: torch._C._profiler._ProfilerEvent
|
|
60
|
+
if ev.typed[0] == _EventType.Allocation:
|
|
61
|
+
ex = ev.typed[1] # torch._C._profiler._ExtraFields_Allocation
|
|
62
|
+
# ex.id/ex.allocation_id/ex.ptr redundant?
|
|
63
|
+
if ex.allocation_id in _allocs:
|
|
64
|
+
ev_name = "dealloc" # deallocation
|
|
65
|
+
assert _allocs[ex.allocation_id]["size"] == -ex.alloc_size
|
|
66
|
+
name = _allocs[ex.allocation_id]["name"]
|
|
67
|
+
del _allocs[ex.allocation_id]
|
|
68
|
+
else:
|
|
69
|
+
ev_name = "alloc"
|
|
70
|
+
assert ex.alloc_size > 0
|
|
71
|
+
assert ev.parent
|
|
72
|
+
name = _ctx(ev.parent)
|
|
73
|
+
_allocs[ex.allocation_id] = {"size": ex.alloc_size, "name": name}
|
|
74
|
+
opts = {"id": ex.allocation_id, "name": name, "size": ex.alloc_size, "total_alloc": ex.total_allocated}
|
|
75
|
+
elif ev.typed[0] == _EventType.TorchOp:
|
|
76
|
+
ev_name = "torchop"
|
|
77
|
+
ex = ev.typed[1] # torch._C._profiler._ExtraFields_TorchOp
|
|
78
|
+
opts = {"name": ex.name, "inputs": [_repr_tensor_metadata(i) for i in ex.inputs]}
|
|
79
|
+
elif ev.typed[0] == _EventType.PyCall:
|
|
80
|
+
ev_name = "pycall"
|
|
81
|
+
ex = ev.typed[1] # torch._C._profiler._ExtraFields_PyCall
|
|
82
|
+
ex0 = ex.caller # torch._C._profiler._PyFrameState
|
|
83
|
+
ex1 = ex.callsite # torch._C._profiler._PyFrameState
|
|
84
|
+
if _pycall_filter_fn(ex0.file_name) or _pycall_filter_fn(ex1.file_name):
|
|
85
|
+
opts = {
|
|
86
|
+
"caller_loc": f"{ex0.file_name}:{ex0.line_number}",
|
|
87
|
+
"caller_name": ex0.function_name,
|
|
88
|
+
"callsite_name": ex1.function_name,
|
|
89
|
+
}
|
|
90
|
+
else:
|
|
91
|
+
return
|
|
92
|
+
elif ev.typed[0] == _EventType.PyCCall:
|
|
93
|
+
ev_name = "pyccall"
|
|
94
|
+
ex = ev.typed[1] # torch._C._profiler._ExtraFields_PyCCall
|
|
95
|
+
ex0 = ex.caller # torch._C._profiler._PyFrameState
|
|
96
|
+
if _pycall_filter_fn(ex0.file_name):
|
|
97
|
+
opts = {
|
|
98
|
+
"caller_loc": f"{ex0.file_name}:{ex0.line_number}",
|
|
99
|
+
"caller_name": ex0.function_name,
|
|
100
|
+
}
|
|
101
|
+
else:
|
|
102
|
+
return
|
|
103
|
+
else:
|
|
104
|
+
return
|
|
105
|
+
|
|
106
|
+
depth = 0
|
|
107
|
+
if ev.parent:
|
|
108
|
+
ev__ = ev.parent
|
|
109
|
+
while ev__:
|
|
110
|
+
if ev__ in _printed_events:
|
|
111
|
+
depth = _events_stack_depth[ev__] + 1
|
|
112
|
+
break
|
|
113
|
+
if ev__ in _events_stack_depth:
|
|
114
|
+
depth = _events_stack_depth[ev__]
|
|
115
|
+
break
|
|
116
|
+
ev__ = ev__.parent
|
|
117
|
+
ev__ = ev
|
|
118
|
+
while ev__:
|
|
119
|
+
if ev__ in _events_stack_depth:
|
|
120
|
+
break
|
|
121
|
+
_events_stack_depth[ev__] = depth
|
|
122
|
+
ev__ = ev__.parent
|
|
123
|
+
else:
|
|
124
|
+
_events_stack_depth[ev] = 0
|
|
125
|
+
_printed_events.add(ev)
|
|
126
|
+
prefix = " " * depth
|
|
127
|
+
|
|
128
|
+
if check_events is None:
|
|
129
|
+
print(f"{prefix}{ev_name} {opts}")
|
|
130
|
+
return
|
|
131
|
+
|
|
132
|
+
next_check = check_events[0] if check_events else None
|
|
133
|
+
if next_check:
|
|
134
|
+
next_check_name, next_check_opts = next_check
|
|
135
|
+
if ev_name == next_check_name:
|
|
136
|
+
for k, v in next_check_opts.items():
|
|
137
|
+
if isinstance(v, str) and "*" in v:
|
|
138
|
+
if not fnmatch.fnmatch(opts[k], v):
|
|
139
|
+
mismatch = f"Pattern mismatch: {opts[k]} vs {v}"
|
|
140
|
+
break
|
|
141
|
+
elif k == "total_alloc":
|
|
142
|
+
if abs(opts[k] - v) >= _size_threshold:
|
|
143
|
+
mismatch = f"Size mismatch: {opts[k]} vs {v}"
|
|
144
|
+
break
|
|
145
|
+
elif opts[k] != v:
|
|
146
|
+
mismatch = f"Value mismatch: {opts[k]} vs {v}"
|
|
147
|
+
break
|
|
148
|
+
else:
|
|
149
|
+
mismatch = None
|
|
150
|
+
else:
|
|
151
|
+
mismatch = f"Different event: {ev_name} vs {next_check_name}"
|
|
152
|
+
else:
|
|
153
|
+
mismatch = "No check event"
|
|
154
|
+
|
|
155
|
+
if ev_name in {"alloc", "dealloc"} and abs(opts["size"]) >= _size_threshold:
|
|
156
|
+
assert not mismatch, f"Event not matched: {ev_name} {opts} to {next_check}: {mismatch}"
|
|
157
|
+
|
|
158
|
+
if not mismatch:
|
|
159
|
+
print(f"{prefix}{ev_name} {opts} ✓")
|
|
160
|
+
check_events.pop(0)
|
|
161
|
+
else:
|
|
162
|
+
print(f"{prefix}({ev_name} {opts})")
|
|
163
|
+
|
|
164
|
+
def _ctx(ev) -> str:
|
|
165
|
+
stack = [None]
|
|
166
|
+
parent = ev
|
|
167
|
+
while parent and parent.typed[0] == _EventType.TorchOp: # go to top torch op
|
|
168
|
+
stack[-1] = parent.typed[1].name
|
|
169
|
+
parent = parent.parent
|
|
170
|
+
if not stack[-1] and parent.typed[0] == _EventType.PyCCall:
|
|
171
|
+
stack[-1] = parent.typed[1].caller.function_name
|
|
172
|
+
parent = parent.parent
|
|
173
|
+
if not stack[-1]:
|
|
174
|
+
stack.pop(-1)
|
|
175
|
+
while parent:
|
|
176
|
+
if parent.typed[0] == _EventType.PyCall:
|
|
177
|
+
ex0 = parent.typed[1].caller # torch._C._profiler._PyFrameState
|
|
178
|
+
ex1 = parent.typed[1].callsite # torch._C._profiler._PyFrameState
|
|
179
|
+
if (
|
|
180
|
+
_pycall_filter_fn(ex1.file_name)
|
|
181
|
+
or (_pycall_filter_fn(ex0.file_name) and ex1.function_name == "backward")
|
|
182
|
+
) and ex1.function_name not in {"__torch_dispatch__"}:
|
|
183
|
+
stack.append(ex1.function_name)
|
|
184
|
+
parent = parent.parent
|
|
185
|
+
stack.reverse()
|
|
186
|
+
return "/".join(stack) or "unknown"
|
|
187
|
+
|
|
188
|
+
for ev_ in sorted(
|
|
189
|
+
traverse_dfs(prof.profiler.kineto_results.experimental_event_tree()), key=lambda ev: ev.start_time_ns
|
|
190
|
+
):
|
|
191
|
+
# ev: torch._C._profiler._ProfilerEvent
|
|
192
|
+
_ev_visit(ev_)
|
|
193
|
+
|
|
194
|
+
if allow_remaining_allocs:
|
|
195
|
+
for alloc_id, alloc in _allocs.items():
|
|
196
|
+
print(f"Remaining alloc: {alloc_id} {alloc}")
|
|
197
|
+
else:
|
|
198
|
+
assert not _allocs, f"Remaining allocs: {_allocs}"
|
|
199
|
+
assert not check_events, f"Remaining check events: {check_events}"
|
|
200
|
+
|
|
201
|
+
|
|
202
|
+
def _pycall_filter_fn(filename: str) -> bool:
|
|
203
|
+
assert not filename.startswith("/") # currently the case...
|
|
204
|
+
if filename.startswith("test_"):
|
|
205
|
+
assert "/" not in filename # currently the case...
|
|
206
|
+
return True
|
|
207
|
+
if filename.startswith("returnn/"):
|
|
208
|
+
return True
|
|
209
|
+
return False
|
|
210
|
+
|
|
211
|
+
|
|
212
|
+
def _repr_tensor_metadata(x) -> Any:
|
|
213
|
+
"""
|
|
214
|
+
:param x: torch._C._profiler._TensorMetadata or int
|
|
215
|
+
:return: obj which has a nice __repr__/__str__
|
|
216
|
+
"""
|
|
217
|
+
if isinstance(x, (list, tuple)):
|
|
218
|
+
return type(x)(_repr_tensor_metadata(i) for i in x)
|
|
219
|
+
if not type(x).__module__.startswith("torch"):
|
|
220
|
+
return x
|
|
221
|
+
assert x is not None
|
|
222
|
+
return _ReprObj(f"<_T id={x.id} shape={x.sizes} dtype={x.dtype}>")
|
|
223
|
+
|
|
224
|
+
|
|
225
|
+
class _ReprObj:
|
|
226
|
+
def __init__(self, obj: str):
|
|
227
|
+
self.obj = obj
|
|
228
|
+
|
|
229
|
+
def __repr__(self):
|
|
230
|
+
return self.obj
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-hyper-param-tuning.config
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-record-and-push-to-webserver.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-chunking-blstm.12ax.config
RENAMED
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-contribrnn-lstm.12ax.config
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-maxgradnorm-lstm.12ax.config
RENAMED
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-native-lstm-lowmem.12ax.config
RENAMED
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-native-lstm.12ax.config
RENAMED
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-native-lstm2.12ax.config
RENAMED
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-native-lstm2.12ax.tuned.config
RENAMED
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-neural-transducer.12ax.config
RENAMED
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-rec-explicit-lstm.config
RENAMED
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-rec-explicit-rnn.config
RENAMED
|
File without changes
|
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-search-compiled-graph.py
RENAMED
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-tf-vanilla-lstm.12ax.config
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/demo-upd-mult-model.lstm.12ax.config
RENAMED
|
File without changes
|
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/IAM_lines/a01-000u-00.png
RENAMED
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/IAM_lines/a01-007-04.png
RENAMED
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/IAM_lines/a01-007-06.png
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/create_IAM_dataset.py
RENAMED
|
File without changes
|
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/IAM/features/raw/demo.h5
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/artificial/create_test_h5.py
RENAMED
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/artificial/forwardconfig
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/artificial_rgb/forwardconfig
RENAMED
|
File without changes
|
|
File without changes
|
{returnn-1.20240718.142037 → returnn-1.20240719.111324}/demos/mdlstm/artificial_rgb/trainconfig
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|