wafer-core 0.1.28__tar.gz → 0.1.30__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.
- {wafer_core-0.1.28 → wafer_core-0.1.30}/PKG-INFO +1 -1
- {wafer_core-0.1.28 → wafer_core-0.1.30}/pyproject.toml +1 -1
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/trace_compare/analyzer.py +31 -6
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/trace_compare/classifier.py +18 -9
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/trace_compare/fusion_analyzer.py +86 -45
- {wafer_core-0.1.28 → wafer_core-0.1.30}/.gitignore +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/README.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/pyproject.toml.bak +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/run_cuda_grep.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/test_gpu_e2e.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/perfetto/README.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/perfetto/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/perfetto/test_perfetto_integration.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/perfetto/test_perfetto_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/perfetto/test_trace_manager.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/perfetto/test_trace_processor.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/test_async_ssh_upload.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/test_capture_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/test_config.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/test_eval_interrupt_resume.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/test_isa_analysis_tools.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/test_kernel_scope.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/test_nested_progress.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/test_rocprof_tools.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/test_rocprofiler_compute.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/test_roofline.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/test_sandbox.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/test_tracelens_tools.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/trace_compare/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/trace_compare/benchmark_trace_compare.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/trace_compare/expected_output_amd_llama.json +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/trace_compare/generate_golden_file.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/trace_compare/test_trace_compare_correctness.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/tracelens/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/tests/tracelens/test_finder.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/uv.lock +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/async_ssh.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/auth.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/config/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/config/loader.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/config/schema.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/environments/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/environments/coding.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/environments/gpumode.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/gpu.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/gpu_detect.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/amdgcn/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/amdgcn/analyzer.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/amdgcn/instruction_db.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/amdgcn/parser.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/amdgcn/types.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/api.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/correlation/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/correlation/mapper.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/llvm_ir/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/llvm_ir/analyzer.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/llvm_ir/parser.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/llvm_ir/types.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/metrics/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/metrics/occupancy.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/targets/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/targets/specs.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/ttgir/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/ttgir/analyzer.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/ttgir/parser.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/ttgir/types.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/nsys/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/nsys/analysis.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/nsys/discovery.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/nsys/export.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/nsys/extraction.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/nsys/main.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/nsys/parsing.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/perfetto/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/perfetto/build_trace_processor.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/perfetto/perfetto_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/perfetto/trace_manager.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/perfetto/trace_processor.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/analyzer.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/finder.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/VERSION +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/__main__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/analysis_base.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/analysis_webui.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/default.css +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/favicon.ico +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/css/font-awesome.css +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/css/font-awesome.min.css +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/fonts/FontAwesome.otf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/fonts/fontawesome-webfont.eot +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/fonts/fontawesome-webfont.svg +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/fonts/fontawesome-webfont.ttf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/fonts/fontawesome-webfont.woff +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/less/bordered-pulled.less +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/less/core.less +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/less/fixed-width.less +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/less/font-awesome.less +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/less/icons.less +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/less/larger.less +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/less/list.less +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/less/mixins.less +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/less/path.less +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/less/rotated-flipped.less +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/less/spinning.less +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/less/stacked.less +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/less/variables.less +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/scss/_bordered-pulled.scss +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/scss/_core.scss +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/scss/_fixed-width.scss +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/scss/_icons.scss +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/scss/_larger.scss +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/scss/_list.scss +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/scss/_mixins.scss +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/scss/_path.scss +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/scss/_rotated-flipped.scss +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/scss/_spinning.scss +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/scss/_stacked.scss +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/scss/_variables.scss +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/font-awesome/scss/font-awesome.scss +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fontello/css/animation.css +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fontello/css/fontello-codes.css +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fontello/css/fontello-embedded.css +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fontello/css/fontello-ie7-codes.css +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fontello/css/fontello-ie7.css +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fontello/css/fontello.css +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fontello/font/fontello.eot +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fontello/font/fontello.svg +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fontello/font/fontello.ttf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fontello/font/fontello.woff +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/librebaskerville/librebaskerville-bold-webfont.eot +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/librebaskerville/librebaskerville-bold-webfont.svg +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/librebaskerville/librebaskerville-bold-webfont.ttf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/librebaskerville/librebaskerville-bold-webfont.woff +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/librebaskerville/librebaskerville-italic-webfont.eot +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/librebaskerville/librebaskerville-italic-webfont.svg +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/librebaskerville/librebaskerville-italic-webfont.ttf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/librebaskerville/librebaskerville-italic-webfont.woff +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/librebaskerville/librebaskerville-regular-webfont.eot +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/librebaskerville/librebaskerville-regular-webfont.svg +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/librebaskerville/librebaskerville-regular-webfont.ttf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/librebaskerville/librebaskerville-regular-webfont.woff +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Bold-webfont.eot +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Bold-webfont.svg +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Bold-webfont.ttf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Bold-webfont.woff +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-BoldItalic-webfont.eot +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-BoldItalic-webfont.svg +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-BoldItalic-webfont.ttf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-BoldItalic-webfont.woff +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-ExtraBold-webfont.eot +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-ExtraBold-webfont.svg +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-ExtraBold-webfont.ttf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-ExtraBold-webfont.woff +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-ExtraBoldItalic-webfont.eot +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-ExtraBoldItalic-webfont.svg +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-ExtraBoldItalic-webfont.ttf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-ExtraBoldItalic-webfont.woff +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Italic-webfont.eot +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Italic-webfont.svg +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Italic-webfont.ttf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Italic-webfont.woff +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Light-webfont.eot +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Light-webfont.svg +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Light-webfont.ttf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Light-webfont.woff +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-LightItalic-webfont.eot +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-LightItalic-webfont.svg +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-LightItalic-webfont.ttf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-LightItalic-webfont.woff +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Regular-webfont.eot +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Regular-webfont.svg +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Regular-webfont.ttf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Regular-webfont.woff +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Semibold-webfont.eot +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Semibold-webfont.svg +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Semibold-webfont.ttf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-Semibold-webfont.woff +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-SemiboldItalic-webfont.eot +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-SemiboldItalic-webfont.svg +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-SemiboldItalic-webfont.ttf +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts/opensans/OpenSans-SemiboldItalic-webfont.woff +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/fonts.css +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/layout.css +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/magnific-popup.css +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/media-queries.css +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/config.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/launcher.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/0000_top_stats.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/0100_system_info.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/0200_system-speed-of-light.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/0300_mem_chart.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/0500_command-processor.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/0600_shader-processor-input.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/0700_wavefront-launch.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/1000_compute-unit-instruction-mix.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/1100_compute-unit-compute-pipeline.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/1200_lds.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/1300_instruction-cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/1400_constant-cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/1500_TA_and_TD.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/1600_L1_cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/1700_L2_cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/1800_L2_cache_per_channel.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx908/2100_pc_sampling.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/0000_top_stats.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/0100_system_info.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/0200_system-speed-of-light.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/0300_mem_chart.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/0400_roofline_info.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/0500_command-processor.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/0600_shader-processor-input.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/0700_wavefront-launch.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/1000_compute-unit-instruction-mix.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/1100_compute-unit-compute-pipeline.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/1200_lds.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/1300_instruction-cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/1400_constant-cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/1500_TA_and_TD.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/1600_L1_cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/1700_L2_cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/1800_L2_cache_per_channel.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx90a/2100_pc_sampling.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/0000_top_stats.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/0100_system_info.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/0200_system-speed-of-light.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/0300_mem_chart.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/0400_roofline_info.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/0500_command-processor.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/0600_shader-processor-input.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/0700_wavefront-launch.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/1000_compute-unit-instruction-mix.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/1100_compute-unit-compute-pipeline.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/1200_lds.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/1300_instruction-cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/1400_constant-cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/1500_TA_and_TD.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/1600_L1_cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/1700_L2_cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/1800_L2_cache_per_channel.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx940/2100_pc_sampling.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/0000_top_stats.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/0100_system_info.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/0200_system-speed-of-light.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/0300_mem_chart.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/0400_roofline_info.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/0500_command-processor.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/0600_shader-processor-input.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/0700_wavefront-launch.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/1000_compute-unit-instruction-mix.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/1100_compute-unit-compute-pipeline.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/1200_lds.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/1300_instruction-cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/1400_constant-cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/1500_TA_and_TD.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/1600_L1_cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/1700_L2_cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/1800_L2_cache_per_channel.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx941/2100_pc_sampling.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/0000_top_stats.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/0100_system_info.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/0200_system-speed-of-light.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/0300_mem_chart.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/0400_roofline_info.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/0500_command-processor.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/0600_shader-processor-input.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/0700_wavefront-launch.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/1000_compute-unit-instruction-mix.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/1100_compute-unit-compute-pipeline.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/1200_lds.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/1300_instruction-cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/1400_constant-cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/1500_TA_and_TD.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/1600_L1_cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/1700_L2_cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/1800_L2_cache_per_channel.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx942/2100_pc_sampling.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/0000_top_stats.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/0100_system_info.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/0200_system-speed-of-light.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/0300_mem_chart.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/0400_roofline_info.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/0500_command-processor.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/0600_shader-processor-input.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/0700_wavefront-launch.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/1000_compute-unit-instruction-mix.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/1100_compute-unit-compute-pipeline.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/1200_lds.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/1300_instruction-cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/1400_constant-cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/1500_TA_and_TD.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/1600_L1_cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/1700_L2_cache.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/1800_L2_cache_per_channel.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/gfx950/2100_pc_sampling.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/analysis_configs/panel_config_template.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/soc_base.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/soc_gfx908.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/soc_gfx90a.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/soc_gfx940.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/soc_gfx941.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/soc_gfx942.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/rocprof_compute_soc/soc_gfx950.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/db_connector.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/file_io.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/gui.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/gui_components/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/gui_components/header.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/gui_components/memchart.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/kernel_name_shortener.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/logger.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/mem_chart.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/mi_gpu_spec.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/mi_gpu_spec.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/parser.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/roofline.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/roofline_calc.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/schema.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/specs.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/tty.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/utils/utils.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui_server.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/profiler.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/types.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/sdk/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/sdk/analyzer.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/sdk/finder.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/sdk/parser.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/sdk/profiler.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/sdk/types.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/systems/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/systems/avail/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/systems/avail/query.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/systems/finder.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/systems/instrument/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/systems/instrument/profiler.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/systems/parsers/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/systems/parsers/json_parser.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/systems/parsers/text_parser.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/systems/run/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/systems/run/analyzer.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/systems/run/profiler.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/systems/sample/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/systems/sample/profiler.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/systems/types.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/trace_compare/PERFORMANCE.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/trace_compare/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/trace_compare/aligner.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/trace_compare/api.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/trace_compare/architecture.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/trace_compare/formatter.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/trace_compare/kernel_registry.yaml +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/trace_compare/layer_segmentation.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/trace_compare/loader.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/trace_compare/same_kernel_analyzer.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/trace_compare/warnings.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/tracelens/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/tracelens/comparator.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/tracelens/finder.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/tracelens/report_generator.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/tracelens/types.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/logging/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/logging/bridge.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/logging/color_formatter.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/logging/json_formatter.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/logging/logging_config.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/problem_config.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/remote_env.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/remote_jobs.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/retry.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/__main__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/_logging/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/_logging/color_formatter.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/_logging/json_formatter.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/_logging/logging_config.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/_rate_limit.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/_retry.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/agent_presets/README.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/agent_presets/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/agent_presets/base_preset.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/agent_presets/gpt_5_1_codex_04_04.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/agent_presets/gpt_5_2_03_03.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/agent_presets/loader.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/agent_presets/opus_4_01_01.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/agent_presets/rlm_01_01.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/agent_presets/sonnet_4_02_02.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/agent_presets/sonnet_4_subagent_03_02.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/agents.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/cli.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/cli_agents.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/config/README.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/config/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/config/base.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/config/loader.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/config/protocols.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/datasets/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/datasets/lichess_puzzles.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/deploy.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/docs/ASYNC_RUNTIME.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/dtypes.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/_formatting.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/_subprocess.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/ask_user.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/base.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/binary_search.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/browsing.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/calculator.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/chess_puzzle.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/compose.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/cuda_grep.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/git_worktree.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/handoff.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/localfs.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/no_tools.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/oracle.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/repl.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/screenspot.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/swe_grep.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/environments/terminal_bench.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/eval_helpers.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/evaluation.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/events.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/examples/eval/cuda_grep/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/examples/eval/cuda_grep/config_all_tools.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/examples/eval/cuda_grep/config_grep_glob.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/examples/eval/cuda_grep/config_search_only.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/examples/eval/cuda_grep/cuda_questions.jsonl +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/examples/eval/cuda_grep/eval_cuda_grep.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/examples/eval/cuda_grep/scoring.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/export.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/feedback.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/fingerprint.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontend/DESIGN.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontend/README.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontend/REFACTOR_PLAN.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontend/UI_IMPROVEMENTS.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontend/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontend/__main__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontend/dev.sh +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontend/index.html +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontend/index_old.html +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontend/run.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontend/server.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/headless_json.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/json_frontend.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/none.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/protocol.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/runner.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/textual_frontend.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/INTEGRATION.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/README.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/REFACTOR_DESIGN.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/TUI_TODO.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/agent_renderer.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/components/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/components/assistant_message.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/components/error_display.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/components/input.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/components/loader.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/components/loader_container.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/components/markdown.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/components/question_selector.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/components/spacer.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/components/status_line.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/components/system_message.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/components/text.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/components/tool_execution.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/components/user_message.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/control_flow_types.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/demo.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/example_usage.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/interactive_agent.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/oauth.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/slash_commands.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/terminal.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/test_rendering.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/theme.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/tui.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui/utils.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/frontends/tui_frontend.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/import_cc.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/attention/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/attention/config.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/attention/example.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/attention/flex_backend.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/attention/layer.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/attention/mask.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/attention/protocol.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/backends/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/backends/generate.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/backends/tokenize.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/cache/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/cache/paged.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/cache/protocol.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/cache/radix.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/context.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/engine.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/sampling.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/scheduler.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/testing.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/inference/types.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/integrations/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/logging_utils.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/models.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/paths.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/pipeline.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/progress.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/progress_display.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/prompt.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/prompt_optimization/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/prompt_optimization/adapter.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/prompt_optimization/adapters/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/prompt_optimization/adapters/system_prompt.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/prompt_optimization/adapters/system_user_prompt.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/prompt_optimization/adapters/terminal_bench.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/prompt_optimization/evaluation.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/prompt_optimization/evolutionary.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/prompt_optimization/formatting.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/prompt_optimization/operations.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/prompt_optimization/reflective.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/prompt_optimization/state.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/prompt_optimization/types.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/providers/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/providers/anthropic.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/providers/base.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/providers/google.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/providers/openai_completions.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/providers/openai_responses.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/providers/sglang.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/providers.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/remote.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/scoring.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/search.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/skills.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/slice.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/store.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/templates/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/templates/base.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/templates/loader.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tests/test_slice.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/decorator.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/analysis_tools.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/config.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/configs/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/configs/qwen3_0_6b.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/configs/qwen3_next_80b.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/debug_mask.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/debug_qwen.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/debug_qwen3_next.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/debug_sdpa.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/debug_swa.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/debug_toolkit.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/debug_with_tools.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/explore_gemma.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/explore_qwen.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/explore_qwen3_dense.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/explore_qwen3_next.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/llama_functional.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/qwen3_next_functional.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/qwen_functional.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/test_llama.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/test_qwen.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/test_template.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/tools.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/trace_hf.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/functional_extractor/verify.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tools/oracle.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/agent_integration.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/backends/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/backends/fsdp.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/backends/jax_backend.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/backends/protocol.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/backends/pytorch.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/backends/pytorch_factory.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/backends/torch_func.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/backends/torchax_backend.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/datasets/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/datasets/data_buffer.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/datasets/dataset_loaders.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/datasets/sft.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/distributed_utils.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/filters.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/grpo.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/loops/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/loops/rl_loop.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/loops/sft_loop.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/losses.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/metrics.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/rollout_gen/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/rollout_gen/async_rollout_manager.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/rollout_gen/rollout_generation.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/rollout_gen/rollout_manager.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/types.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/weight_sync.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/training/worker.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/transform_messages.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tui/DESIGN.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tui/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tui/__main__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tui/demo.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tui/monitor.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tui/remote_runner.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tui/terminal.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/tui/traces.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/rollouts/upload.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/roofline/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/roofline/analysis.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/roofline/gpu_specs.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/sandbox/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/sandbox/executor.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/sandbox/landlock.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/sandbox/policy.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/sandbox/seatbelt.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/sessions/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/sessions/agent.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/sessions/dtypes.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/sessions/hooks.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/ssh.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/targets/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/targets/digitalocean.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/targets/pool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/targets/probe.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/targets/providers/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/targets/providers/baremetal.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/targets/providers/digitalocean.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/targets/providers/runpod.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/targets/reconcile.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/targets/runpod.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/targets/spec_store.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/targets/state_cache.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/targets/types.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/autotuner/BENCHMARKING.md +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/autotuner/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/autotuner/aggregation.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/autotuner/core.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/autotuner/dtypes.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/autotuner/metrics.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/autotuner/scoring.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/autotuner/search.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/autotuner/storage.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/autotuner/streaming.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/autotuner/tests/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/autotuner/tests/test_autotuner.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/bash_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/capture_tool/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/capture_tool/artifacts.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/capture_tool/context.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/capture_tool/core.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/capture_tool/dtypes.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/capture_tool/executor.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/capture_tool/metrics.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/file_tools/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/file_tools/edit_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/file_tools/glob_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/file_tools/grep_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/file_tools/read_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/file_tools/utils.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/file_tools/write_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/glob_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/grep_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/isa_analysis_tools/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/isa_analysis_tools/isa_analysis_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/isa_analysis_tools/types.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/nsys_tools/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/nsys_tools/discovery.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/nsys_tools/models.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/nsys_tools/parser.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/rocprof_compute_tools/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/rocprof_compute_tools/rocprof_compute_analyze_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/rocprof_compute_tools/rocprof_compute_profile_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/rocprof_sdk_tools/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/rocprof_sdk_tools/rocprof_sdk_analyze_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/rocprof_sdk_tools/rocprof_sdk_profile_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/rocprof_systems_tools/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/rocprof_systems_tools/rocprof_systems_instrument_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/rocprof_systems_tools/rocprof_systems_profile_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/rocprof_systems_tools/rocprof_systems_query_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/rocprof_systems_tools/rocprof_systems_sample_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/skill_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/tracelens_tools/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/tracelens_tools/tracelens_collective_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/tracelens_tools/tracelens_compare_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/tracelens_tools/tracelens_report_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/wafer_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/tools/write_kernel_tool.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/backend.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/code_validation.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/environment_serialization.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/event_streaming.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/exceptions.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/execution_types.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/gpu_environment_utils.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/kernel_utils/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/kernel_utils/backends.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/kernel_utils/defense.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/kernel_utils/deployment.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/kernel_utils/evaluate.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/kernel_utils/gpu_validation.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/kernel_utils/reference_cache.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/kernel_utils/results.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/kernel_utils/static_checker.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/kernel_utils/targets/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/kernel_utils/targets/config.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/kernel_utils/targets/execution.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/kernel_utils/targets/selection.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/kernel_utils/task.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/kernel_utils/utils.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/modal_execution/__init__.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/modal_execution/modal_app.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/modal_execution/modal_config.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/modal_execution/modal_execution.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/modal_execution/test_modal.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/ncu_profile_tools.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/path_utils.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/remote_execution.py +0 -0
- {wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/utils/submission_selection.py +0 -0
|
@@ -145,7 +145,17 @@ def analyze_traces_from_loaded(
|
|
|
145
145
|
trace2_total = trace2_agg["total_us"] / 1000
|
|
146
146
|
trace1_count = int(trace1_agg["count"])
|
|
147
147
|
trace2_count = int(trace2_agg["count"])
|
|
148
|
-
|
|
148
|
+
# Speedup: ratio of total times (not per-call averages)
|
|
149
|
+
# Shows how many times faster/slower trace1 is compared to trace2
|
|
150
|
+
# > 1.0 means trace1 is slower, < 1.0 means trace1 is faster
|
|
151
|
+
# Using total time instead of avg time per call because operations may have
|
|
152
|
+
# vastly different call counts (e.g., fused vs unfused operations)
|
|
153
|
+
if trace2_total > 0:
|
|
154
|
+
ratio = trace1_total / trace2_total
|
|
155
|
+
elif trace1_total > 0:
|
|
156
|
+
ratio = float("inf") # trace2 has no time, trace1 is infinitely slower
|
|
157
|
+
else:
|
|
158
|
+
ratio = 1.0 # Both are zero
|
|
149
159
|
gap_ms = trace1_total - trace2_total
|
|
150
160
|
|
|
151
161
|
trace1_pattern = list(
|
|
@@ -446,6 +456,11 @@ def analyze_traces_aligned(
|
|
|
446
456
|
)
|
|
447
457
|
same_kernel_result = analyze_same_kernels_from_alignment(alignment.layer_alignments)
|
|
448
458
|
|
|
459
|
+
# Note: amd_kernels = trace1's kernels (filtered if phase_filter != "all")
|
|
460
|
+
# nvidia_kernels = trace2's kernels (filtered if phase_filter != "all")
|
|
461
|
+
# The variable names are misleading but trace1_* should use amd_kernels,
|
|
462
|
+
# and trace2_* should use nvidia_kernels to match the filtered kernel counts/totals.
|
|
463
|
+
|
|
449
464
|
return {
|
|
450
465
|
"metadata": {
|
|
451
466
|
"amd_gpu": amd_trace.gpu_name,
|
|
@@ -462,10 +477,10 @@ def analyze_traces_aligned(
|
|
|
462
477
|
"trace2_platform": trace2.platform,
|
|
463
478
|
"trace2_gpu": trace2.gpu_name,
|
|
464
479
|
"trace2_device": trace2.device_props,
|
|
465
|
-
"trace1_kernels": len(
|
|
466
|
-
"trace2_kernels": len(
|
|
467
|
-
"trace1_total_ms": sum(k.get("dur", 0) for k in
|
|
468
|
-
"trace2_total_ms": sum(k.get("dur", 0) for k in
|
|
480
|
+
"trace1_kernels": len(amd_kernels),
|
|
481
|
+
"trace2_kernels": len(nvidia_kernels),
|
|
482
|
+
"trace1_total_ms": sum(k.get("dur", 0) for k in amd_kernels) / 1000,
|
|
483
|
+
"trace2_total_ms": sum(k.get("dur", 0) for k in nvidia_kernels) / 1000,
|
|
469
484
|
"phase": phase_filter,
|
|
470
485
|
"trace1_layers": alignment.num_layers,
|
|
471
486
|
"trace2_layers": alignment.num_layers,
|
|
@@ -579,7 +594,17 @@ def analyze_traces_aligned(
|
|
|
579
594
|
trace2_total = trace2_agg["total_us"] / 1000
|
|
580
595
|
trace1_count = int(trace1_agg["count"])
|
|
581
596
|
trace2_count = int(trace2_agg["count"])
|
|
582
|
-
|
|
597
|
+
# Speedup: ratio of total times (not per-call averages)
|
|
598
|
+
# Shows how many times faster/slower trace1 is compared to trace2
|
|
599
|
+
# > 1.0 means trace1 is slower, < 1.0 means trace1 is faster
|
|
600
|
+
# Using total time instead of avg time per call because operations may have
|
|
601
|
+
# vastly different call counts (e.g., fused vs unfused operations)
|
|
602
|
+
if trace2_total > 0:
|
|
603
|
+
ratio = trace1_total / trace2_total
|
|
604
|
+
elif trace1_total > 0:
|
|
605
|
+
ratio = float("inf") # trace2 has no time, trace1 is infinitely slower
|
|
606
|
+
else:
|
|
607
|
+
ratio = 1.0 # Both are zero
|
|
583
608
|
gap_ms = trace1_total - trace2_total
|
|
584
609
|
|
|
585
610
|
trace1_pattern = list(
|
|
@@ -24,12 +24,16 @@ class Op(Enum):
|
|
|
24
24
|
|
|
25
25
|
ATTN_PREFILL = "Attention (Prefill)"
|
|
26
26
|
ATTN_DECODE = "Attention (Decode)"
|
|
27
|
+
# NVIDIA Flash Attention fuses QKV projection + Softmax + Attention
|
|
28
|
+
FLASH_ATTN_FUSED = "FlashAttention (QKV+Softmax+Attn)"
|
|
27
29
|
KV_CACHE = "KV Cache"
|
|
28
30
|
MOE_ROUTING = "MoE Routing"
|
|
29
31
|
MOE_GEMM = "MoE GEMM"
|
|
30
32
|
MOE_GEMM_SWIGLU = "MoE GEMM+SwiGLU"
|
|
31
33
|
MOE_FINALIZE = "MoE Finalize"
|
|
32
34
|
DENSE_GEMM = "Dense GEMM"
|
|
35
|
+
# NVIDIA cuBLASLt/CUTLASS can fuse GEMM with epilogue (bias + activation)
|
|
36
|
+
GEMM_BIAS_ACT = "GEMM+Bias+Activation"
|
|
33
37
|
RMSNORM = "RMSNorm"
|
|
34
38
|
RMSNORM_GEMM = "RMSNorm+GEMM"
|
|
35
39
|
SWIGLU = "SwiGLU"
|
|
@@ -274,16 +278,20 @@ def classify(name: str, platform: str) -> tuple[Op, str]:
|
|
|
274
278
|
if "3d" in nl:
|
|
275
279
|
return Op.ATTN_DECODE, "kernel_unified_attention_3d"
|
|
276
280
|
else:
|
|
277
|
-
# NVIDIA
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
281
|
+
# NVIDIA Flash Attention (fmhaSm100*) is a fused kernel
|
|
282
|
+
# It fuses QKV projection + Softmax + Attention into one kernel
|
|
283
|
+
if "fmhasm100" in nl:
|
|
284
|
+
if "fmhasm100a" in nl or "context" in nl:
|
|
285
|
+
return Op.FLASH_ATTN_FUSED, "fmhaSm100a*_Context (QKV+Softmax+Attn)"
|
|
286
|
+
if "fmhasm100f" in nl or "forgen" in nl:
|
|
287
|
+
return Op.FLASH_ATTN_FUSED, "fmhaSm100f*_ForGen (QKV+Softmax+Attn)"
|
|
288
|
+
return Op.FLASH_ATTN_FUSED, "fmhaSm100* (QKV+Softmax+Attn)"
|
|
282
289
|
return Op.ATTN_PREFILL, name[:40]
|
|
283
290
|
|
|
284
|
-
# Flash Attention variants (vLLM)
|
|
291
|
+
# Flash Attention variants (vLLM) - these are fused on NVIDIA
|
|
285
292
|
if "flash::flash_fwd_kernel" in name or "flash_fwd" in nl:
|
|
286
|
-
|
|
293
|
+
if platform != "AMD":
|
|
294
|
+
return Op.FLASH_ATTN_FUSED, "flash::flash_fwd_kernel (QKV+Softmax+Attn)"
|
|
287
295
|
return Op.ATTN_PREFILL, "flash::flash_fwd_kernel"
|
|
288
296
|
|
|
289
297
|
if "reshape_and_cache" in nl:
|
|
@@ -306,9 +314,10 @@ def classify(name: str, platform: str) -> tuple[Op, str]:
|
|
|
306
314
|
if "moe_sum" in nl:
|
|
307
315
|
return Op.MOE_FINALIZE, "vllm::moe::moe_sum_*"
|
|
308
316
|
|
|
309
|
-
# vLLM act_and_mul
|
|
317
|
+
# vLLM act_and_mul - fuses activation with element-wise multiply (SiLU * x)
|
|
318
|
+
# This is a fused operation used in SwiGLU/MoE
|
|
310
319
|
if "vllm::act_and_mul_kernel" in name or ("act_and_mul_kernel" in nl and "vllm" in nl):
|
|
311
|
-
return Op.
|
|
320
|
+
return Op.SWIGLU_GEMM, "vllm::act_and_mul_kernel (SwiGLU+Mul)"
|
|
312
321
|
|
|
313
322
|
if "_matmul_ogs_" in nl:
|
|
314
323
|
if "swiglu" in nl:
|
|
@@ -82,13 +82,37 @@ def _find_fusion_mappings(
|
|
|
82
82
|
trace1_only = trace1_type_set - trace2_type_set
|
|
83
83
|
trace2_only = trace2_type_set - trace1_type_set
|
|
84
84
|
|
|
85
|
-
# For each unique type in trace1,
|
|
85
|
+
# For each unique type in trace1, check if it's a fused operation
|
|
86
|
+
# If trace1 has a unique kernel type that trace2 doesn't have, trace1 is likely fusing
|
|
86
87
|
for unique_type in trace1_only:
|
|
87
88
|
# Skip "Other" since it's too generic
|
|
88
89
|
if unique_type == "Other":
|
|
89
90
|
continue
|
|
90
91
|
|
|
91
|
-
#
|
|
92
|
+
# If the unique type contains '+', it's explicitly a fused kernel
|
|
93
|
+
# This means trace1 (which has it) is fusing, not trace2
|
|
94
|
+
if "+" in unique_type:
|
|
95
|
+
# Parse components from the fused op name
|
|
96
|
+
components = [c.strip() for c in unique_type.split("+")]
|
|
97
|
+
indices = [i for i, t in enumerate(trace1_types) if t == unique_type]
|
|
98
|
+
|
|
99
|
+
if len(indices) < 5:
|
|
100
|
+
continue
|
|
101
|
+
|
|
102
|
+
mappings.append({
|
|
103
|
+
"fused_platform": trace1_name,
|
|
104
|
+
"fused_kernel_type": unique_type,
|
|
105
|
+
"fused_count": len(indices),
|
|
106
|
+
"unfused_platform": trace2_name,
|
|
107
|
+
"unfused_sequence": components,
|
|
108
|
+
"unfused_count_per_type": {c: trace2_types.count(c) for c in components},
|
|
109
|
+
"pattern_count": len(indices),
|
|
110
|
+
"pattern_confidence": 1.0,
|
|
111
|
+
"evidence": f"{trace1_name} fuses {' + '.join(components)} into single kernel ({len(indices)} calls), {trace2_name} runs separately",
|
|
112
|
+
})
|
|
113
|
+
continue
|
|
114
|
+
|
|
115
|
+
# For non-fused unique types, find all occurrences
|
|
92
116
|
indices = [i for i, t in enumerate(trace1_types) if t == unique_type]
|
|
93
117
|
|
|
94
118
|
if len(indices) < 5: # Need enough samples to be meaningful
|
|
@@ -106,11 +130,12 @@ def _find_fusion_mappings(
|
|
|
106
130
|
continue
|
|
107
131
|
most_common_before = max(before_types.items(), key=lambda x: x[1])
|
|
108
132
|
|
|
109
|
-
# If there's a strong pattern (>80% of occurrences)
|
|
133
|
+
# If there's a strong pattern (>80% of occurrences) and trace2 has the preceding type,
|
|
134
|
+
# trace1 runs them separately while trace2 might fuse
|
|
110
135
|
if most_common_before[1] / len(indices) > 0.8:
|
|
111
136
|
fusion_candidate = most_common_before[0]
|
|
112
137
|
|
|
113
|
-
# Verify trace2 has this type
|
|
138
|
+
# Verify trace2 has this type but NOT the unique_type
|
|
114
139
|
if fusion_candidate in trace2_type_set:
|
|
115
140
|
trace1_fusion_count = trace1_types.count(fusion_candidate)
|
|
116
141
|
trace2_fusion_count = trace2_types.count(fusion_candidate)
|
|
@@ -127,7 +152,7 @@ def _find_fusion_mappings(
|
|
|
127
152
|
},
|
|
128
153
|
"pattern_count": len(indices),
|
|
129
154
|
"pattern_confidence": most_common_before[1] / len(indices),
|
|
130
|
-
"evidence": f"{trace1_name} runs {fusion_candidate}+{unique_type} separately, {trace2_name} fuses into {fusion_candidate}",
|
|
155
|
+
"evidence": f"{trace1_name} runs {fusion_candidate} + {unique_type} separately, {trace2_name} fuses into {fusion_candidate}",
|
|
131
156
|
})
|
|
132
157
|
|
|
133
158
|
# Also check trace2-only types
|
|
@@ -135,6 +160,28 @@ def _find_fusion_mappings(
|
|
|
135
160
|
if unique_type == "Other":
|
|
136
161
|
continue
|
|
137
162
|
|
|
163
|
+
# If the unique type contains '+', it's explicitly a fused kernel
|
|
164
|
+
# This means trace2 (which has it) is fusing, not trace1
|
|
165
|
+
if "+" in unique_type:
|
|
166
|
+
components = [c.strip() for c in unique_type.split("+")]
|
|
167
|
+
indices = [i for i, t in enumerate(trace2_types) if t == unique_type]
|
|
168
|
+
|
|
169
|
+
if len(indices) < 5:
|
|
170
|
+
continue
|
|
171
|
+
|
|
172
|
+
mappings.append({
|
|
173
|
+
"fused_platform": trace2_name,
|
|
174
|
+
"fused_kernel_type": unique_type,
|
|
175
|
+
"fused_count": len(indices),
|
|
176
|
+
"unfused_platform": trace1_name,
|
|
177
|
+
"unfused_sequence": components,
|
|
178
|
+
"unfused_count_per_type": {c: trace1_types.count(c) for c in components},
|
|
179
|
+
"pattern_count": len(indices),
|
|
180
|
+
"pattern_confidence": 1.0,
|
|
181
|
+
"evidence": f"{trace2_name} fuses {' + '.join(components)} into single kernel ({len(indices)} calls), {trace1_name} runs separately",
|
|
182
|
+
})
|
|
183
|
+
continue
|
|
184
|
+
|
|
138
185
|
indices = [i for i, t in enumerate(trace2_types) if t == unique_type]
|
|
139
186
|
|
|
140
187
|
if len(indices) < 5:
|
|
@@ -169,7 +216,7 @@ def _find_fusion_mappings(
|
|
|
169
216
|
},
|
|
170
217
|
"pattern_count": len(indices),
|
|
171
218
|
"pattern_confidence": most_common_before[1] / len(indices),
|
|
172
|
-
"evidence": f"{trace2_name} runs {fusion_candidate}+{unique_type} separately, {trace1_name} fuses into {fusion_candidate}",
|
|
219
|
+
"evidence": f"{trace2_name} runs {fusion_candidate} + {unique_type} separately, {trace1_name} fuses into {fusion_candidate}",
|
|
173
220
|
})
|
|
174
221
|
|
|
175
222
|
return mappings
|
|
@@ -184,8 +231,15 @@ def _find_count_imbalance_fusions(
|
|
|
184
231
|
) -> list[dict]:
|
|
185
232
|
"""Find fusions by looking for significant count imbalances.
|
|
186
233
|
|
|
187
|
-
When one platform has significantly more kernel calls of a type (>
|
|
188
|
-
it
|
|
234
|
+
When one platform has significantly more kernel calls of a type (>3x),
|
|
235
|
+
it MAY suggest the other platform fuses those operations.
|
|
236
|
+
|
|
237
|
+
NOTE: This is speculative - count differences can also indicate:
|
|
238
|
+
- Different algorithmic implementations
|
|
239
|
+
- Different library choices (cuBLAS vs hipBLAS)
|
|
240
|
+
- Different optimization strategies
|
|
241
|
+
|
|
242
|
+
Only very large imbalances (>3x) with high counts are flagged.
|
|
189
243
|
"""
|
|
190
244
|
mappings = []
|
|
191
245
|
trace2_platform = "NVIDIA" if trace1_platform == "AMD" else "AMD"
|
|
@@ -201,24 +255,28 @@ def _find_count_imbalance_fusions(
|
|
|
201
255
|
# Find common types with significant differences
|
|
202
256
|
common_types = set(trace1_counts.keys()) & set(trace2_counts.keys())
|
|
203
257
|
|
|
258
|
+
# Skip types that are likely just implementation differences, not fusion
|
|
259
|
+
skip_types = {"Reduce", "Copy/Memory", "Sync", "Other", "Elementwise"}
|
|
260
|
+
|
|
204
261
|
for ktype in common_types:
|
|
205
|
-
if ktype
|
|
262
|
+
if ktype in skip_types:
|
|
206
263
|
continue
|
|
207
264
|
|
|
208
265
|
trace1_count = trace1_counts[ktype]
|
|
209
266
|
trace2_count = trace2_counts[ktype]
|
|
210
267
|
|
|
211
|
-
# Skip
|
|
212
|
-
if trace1_count + trace2_count <
|
|
268
|
+
# Skip low counts - need significant samples
|
|
269
|
+
if trace1_count + trace2_count < 200:
|
|
213
270
|
continue
|
|
214
271
|
|
|
215
|
-
# Check if there's a significant imbalance (>
|
|
272
|
+
# Check if there's a very significant imbalance (>3x)
|
|
273
|
+
# Lower ratios are likely implementation differences, not fusion
|
|
216
274
|
if trace1_count == 0 or trace2_count == 0:
|
|
217
275
|
continue
|
|
218
276
|
|
|
219
277
|
ratio = max(trace1_count, trace2_count) / min(trace1_count, trace2_count)
|
|
220
278
|
|
|
221
|
-
if ratio <
|
|
279
|
+
if ratio < 3.0:
|
|
222
280
|
continue
|
|
223
281
|
|
|
224
282
|
# Determine which platform has more (unfused) and which has fewer (fused)
|
|
@@ -242,7 +300,7 @@ def _find_count_imbalance_fusions(
|
|
|
242
300
|
"unfused_count_per_type": {ktype: unfused_count},
|
|
243
301
|
"pattern_count": unfused_count - fused_count,
|
|
244
302
|
"pattern_confidence": (unfused_count - fused_count) / unfused_count,
|
|
245
|
-
"evidence": f"{unfused_platform} calls {ktype} {ratio:.1f}x more ({unfused_count} vs {fused_count})
|
|
303
|
+
"evidence": f"{unfused_platform} calls {ktype} {ratio:.1f}x more ({unfused_count} vs {fused_count}) - possible fusion",
|
|
246
304
|
})
|
|
247
305
|
|
|
248
306
|
return mappings
|
|
@@ -325,12 +383,14 @@ def detect_fusion_patterns(
|
|
|
325
383
|
amd_kernels: list[dict],
|
|
326
384
|
nvidia_kernels: list[dict],
|
|
327
385
|
) -> FusionAnalysis:
|
|
328
|
-
"""Detect fusion patterns using
|
|
386
|
+
"""Detect fusion patterns using explicit fused operation detection only.
|
|
329
387
|
|
|
330
|
-
This
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
388
|
+
This approach only reports high-confidence fusions where kernels are
|
|
389
|
+
explicitly classified as fused (e.g., 'RMSNorm+GEMM', 'SwiGLU+GEMM').
|
|
390
|
+
|
|
391
|
+
We intentionally avoid speculative detection (sequence patterns, count
|
|
392
|
+
imbalances) because these produce too many false positives - count
|
|
393
|
+
differences are usually due to different implementations, not fusion.
|
|
334
394
|
|
|
335
395
|
Args:
|
|
336
396
|
amd_kernels: List of AMD kernel events
|
|
@@ -341,38 +401,19 @@ def detect_fusion_patterns(
|
|
|
341
401
|
"""
|
|
342
402
|
all_mappings: list[dict] = []
|
|
343
403
|
|
|
344
|
-
#
|
|
404
|
+
# Only use explicit fused operations (highest confidence, no false positives)
|
|
405
|
+
# These are kernels explicitly classified with '+' in their operation type
|
|
345
406
|
explicit_fusions = _find_explicit_fused_operations(
|
|
346
407
|
amd_kernels, nvidia_kernels,
|
|
347
408
|
trace1_name="AMD", trace2_name="NVIDIA",
|
|
348
409
|
trace1_platform="AMD",
|
|
349
410
|
)
|
|
350
411
|
all_mappings.extend(explicit_fusions)
|
|
351
|
-
|
|
352
|
-
#
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
trace1_platform="AMD",
|
|
357
|
-
)
|
|
358
|
-
# Deduplicate: skip if same fused_kernel_type already found
|
|
359
|
-
existing_types = {m["fused_kernel_type"] for m in all_mappings}
|
|
360
|
-
for fusion in sequence_fusions:
|
|
361
|
-
if fusion["fused_kernel_type"] not in existing_types:
|
|
362
|
-
all_mappings.append(fusion)
|
|
363
|
-
existing_types.add(fusion["fused_kernel_type"])
|
|
364
|
-
|
|
365
|
-
# 3. Find count-imbalance fusions
|
|
366
|
-
count_fusions = _find_count_imbalance_fusions(
|
|
367
|
-
amd_kernels, nvidia_kernels,
|
|
368
|
-
trace1_name="AMD", trace2_name="NVIDIA",
|
|
369
|
-
trace1_platform="AMD",
|
|
370
|
-
)
|
|
371
|
-
# Deduplicate
|
|
372
|
-
for fusion in count_fusions:
|
|
373
|
-
if fusion["fused_kernel_type"] not in existing_types:
|
|
374
|
-
all_mappings.append(fusion)
|
|
375
|
-
existing_types.add(fusion["fused_kernel_type"])
|
|
412
|
+
|
|
413
|
+
# NOTE: We intentionally skip sequence-based and count-imbalance detection
|
|
414
|
+
# because they produce false positives. Count differences between platforms
|
|
415
|
+
# are usually due to different library implementations (cuBLAS vs hipBLAS),
|
|
416
|
+
# not actual kernel fusion.
|
|
376
417
|
|
|
377
418
|
# Convert to FusionPattern objects
|
|
378
419
|
patterns: list[FusionPattern] = []
|
|
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
|
|
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
|
{wafer_core-0.1.28 → wafer_core-0.1.30}/tests/trace_compare/test_trace_compare_correctness.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
|
|
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
|
{wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/kernel_scope/amdgcn/instruction_db.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
|
|
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
|
|
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
|
{wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/analysis_base.py
RENAMED
|
File without changes
|
{wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/analysis_webui.py
RENAMED
|
File without changes
|
{wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/default.css
RENAMED
|
File without changes
|
{wafer_core-0.1.28 → wafer_core-0.1.30}/wafer_core/lib/rocprofiler/compute/gui/assets/favicon.ico
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
|