Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

benchdnn: graph: extend --dt to support specifying tensor id #2331

Merged
merged 4 commits into from
Jan 16, 2025

Conversation

TaoLv
Copy link
Contributor

@TaoLv TaoLv commented Jan 2, 2025

We introduced --dt in 461388e to support floating-point data type rewrite for the whole graph.

In this PR, the knob is further extended to support data type rewrite for specified tensor IDs, in a format of --dt=ID0:DT0+ID1:DT1.... It provides more flexibility to test a json file with different data types, especially for the various zps/scales data types for quantizations which were excluded previously in whole graph data type rewrite. Due to the flexibility of this knob and the restriction of op definition in the library, users need to be cautious when rewriting the data type of a specific tensor in a graph as it may lead to graph construction failures in the library during testing (eg. incompatible input and output tensor data types).

An example as below:
benchdnn --graph --dt=0:s8+2:s8+6:s8+8:s8 --case=complex_fusion/mha/sdpa-compressed-kv-int4-gs32.json

It can be used to test int8 compressed KV graph by rewriting rewrite the int4 compressed KV graph (0 is the key tensor, 2 is the zps pf key tensor, 6 is the value tensor, and 8 is the zps of values tensor).

@TaoLv TaoLv requested review from a team as code owners January 2, 2025 09:57
@github-actions github-actions bot added documentation A request to change/fix/improve the documentation. Codeowner: @oneapi-src/onednn-doc component:graph-api Codeowner: @oneapi-src/onednn-graph component:tests Codeowner: @oneapi-src/onednn-arch labels Jan 2, 2025
@TaoLv TaoLv force-pushed the lvtao/main/benchdnn-dt-rewrite branch from 086c6dd to ab80ed6 Compare January 2, 2025 14:33
tests/benchdnn/graph/parser.cpp Outdated Show resolved Hide resolved
tests/benchdnn/graph/graph.hpp Show resolved Hide resolved
tests/benchdnn/graph/graph.hpp Outdated Show resolved Hide resolved
@TaoLv TaoLv force-pushed the lvtao/main/benchdnn-dt-rewrite branch from ab80ed6 to 539767a Compare January 6, 2025 05:20
Copy link
Contributor

@ranukund ranukund left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've left a few comments, please incorporate as you see fit, thanks!

tests/benchdnn/doc/driver_graph.md Outdated Show resolved Hide resolved
tests/benchdnn/doc/driver_graph.md Outdated Show resolved Hide resolved
tests/benchdnn/doc/driver_graph.md Outdated Show resolved Hide resolved
tests/benchdnn/doc/driver_graph.md Outdated Show resolved Hide resolved
tests/benchdnn/doc/driver_graph.md Outdated Show resolved Hide resolved
tests/benchdnn/doc/driver_graph.md Outdated Show resolved Hide resolved
@TaoLv TaoLv force-pushed the lvtao/main/benchdnn-dt-rewrite branch from 539767a to 143ce80 Compare January 8, 2025 14:35
@TaoLv
Copy link
Contributor Author

TaoLv commented Jan 8, 2025

I've left a few comments, please incorporate as you see fit, thanks!

Thank you @ranukund . Suggestions are incorporated now.

Copy link
Contributor

@ranukund ranukund left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good, thank you!

@TaoLv
Copy link
Contributor Author

TaoLv commented Jan 9, 2025

make test
enable benchdnn_nightly
disable benchdnn_all
enable benchdnn_graph

tests/benchdnn/graph/parser.cpp Show resolved Hide resolved
tests/benchdnn/graph/parser.cpp Outdated Show resolved Hide resolved
tests/benchdnn/graph/parser.cpp Outdated Show resolved Hide resolved
tests/benchdnn/graph/flex_rewrite.hpp Outdated Show resolved Hide resolved
@TaoLv TaoLv force-pushed the lvtao/main/benchdnn-dt-rewrite branch from 3e42fa0 to 7d3f6c3 Compare January 10, 2025 03:13
BENCHDNN_PRINT(0, "%s\n",
"Error: --dt is specified twice with different styles.");
SAFE_V(FAIL);
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would move it into parse_dt since it has both objects and can check their state to figure out if both options were passed. Afterall, it's a parser obligation to make sure the input is valid (when it can).

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sure, it's moved to the parser function now.

@TaoLv TaoLv force-pushed the lvtao/main/benchdnn-dt-rewrite branch 2 times, most recently from 2fd06e0 to 4ee753e Compare January 12, 2025 14:01
@TaoLv TaoLv force-pushed the lvtao/main/benchdnn-dt-rewrite branch from 4ee753e to 575e29e Compare January 15, 2025 08:08
@TaoLv
Copy link
Contributor Author

TaoLv commented Jan 15, 2025

make test
enable benchdnn_nightly
disable benchdnn_all
enable benchdnn_graph

@TaoLv TaoLv merged commit 5cd6a3b into main Jan 16, 2025
13 of 18 checks passed
@TaoLv TaoLv deleted the lvtao/main/benchdnn-dt-rewrite branch January 16, 2025 10:08
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
component:graph-api Codeowner: @oneapi-src/onednn-graph component:tests Codeowner: @oneapi-src/onednn-arch documentation A request to change/fix/improve the documentation. Codeowner: @oneapi-src/onednn-doc
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants