-
Notifications
You must be signed in to change notification settings - Fork 51
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
Roofline based on dispatch ID #435
Comments
Can you please share what ROCm version you're using? Additionally, could you also attach your |
I'm using rocm 5.5.1, 5.7.1, 6.1.2. And, Omniperf 2.1.0 |
Hi @etiennemlb, sorry for the delay. Can you try updating to ROCm 6.2.2+Omniperf 2.1.0 and check if the issue is still present? I followed the options you used above and was able to get the roofline analysis for a non-zero dispatch id. Commands Used: Screenshot of standalone GUI analyzer: |
In the profile command above, you explicitly tell omniperf to record only for --dispatch=5. This is different from me recording without --dispatch specified (and thus having on disk the roofline data of all the kernels) and later trying to draw a roofline for a specific kernel. Also I can't use graphana. |
I'm not sure I understand what you mean. Are you not using these options in profile mode as well? Also, how are you accessing the roofline plot? Are you using the generated pdf directly? |
I'm using the pdf directly. In fact, using graphana on a super computer tend to be cumbersome. TLDR; I want to recod a bunch of data, and then, later, analyze it or produce roofline out of it. My workflow is as follow:
omniperf profile -n <case_name> --device=0 -- ./test_binary
omniperf analyze --block 17.2.1 17.2.2 17.5.3 17.5.4 --dispatch 27 --path workloads/<case_name>/MI200/
Now, if you try to reproduce that sequence of command you will find that for the last one, the --dispatch option is bugged. You can't choose a kernel other than 0 where as for the analyze command, I can freely choose whatever dispatch id I want. As a side note, maybe the roofline generation should be in |
@etiennemlb try using the Standalone GUI which can load roofline charts with your desired dispatch filter - no reprofile required. Based on your comment above, your usage should follow: $ omniperf analyze -p --path workloads/<case_name>/MI200/ --dispatch 27 --gui I'll also add, knowing you're in an HPC environment, if your cluster doesn't allow port forwarding / ssh tunnel (required by standalone GUI), try copying data to your local workstation for analysis. For more info please read docs: |
I see, so the omniperf's analyze mode is used to view the metrics from data collected in profile mode. You can also generate a plot using the roofline data but you have to use the Standalone GUI analysis or Grafana GUI analysis. The Standalone GUI analysis (which I have used above, not Grafana) is very easy to use, simply pass the --gui option in analyze mode as mentioned by @coleramos425 above. This will create a web server for you to access using your web browser. |
@coleramos425 You guessed right about the ssh hurdles. So really, the only viable solution is about copying the profiling data to my personal computer. Still, the only thing I need would be a way to generate the roofline PDFs for a given kernel after having recorded performance counters for all kernel. I believe that would be a useful feature because we don't want to re-profile the whole program each time we want a roofline for a different kernel. This feature seems to already exist in the GUI, I would appreciate having the same capabilities built in the CLI. |
Correct.
Agreed. I see the value add this feature could bring, especially for the HPC customers. @sohaibnd could you work with @etiennemlb to see about opening a proper feature request for this. Could be Jira or GitHub ticket - whichever you prefer (soon we'll have ability to link the two 🙂) |
Hi, as I was on site for a hackathon and I was talking with @etiennemlb about this and some other requests, please point me to the internal ticket. Thanks. |
I have profiled an application like so:
Now I want, for a given dispatch, draw some rooflines:
The text was updated successfully, but these errors were encountered: