Arm Community
Site
Search
User
Site
Search
User
Arm Community blogs
Tools, Software and IDEs blog
Software Optimization: Four real-life Streamline use cases (Part 3)
Blogs
Mentions
Sub-Groups
Tags
Jump...
More blogs in Arm Community blogs
AI blog
Announcements
Architectures and Processors blog
Automotive blog
Embedded and Microcontrollers blog
Internet of Things (IoT) blog
Laptops and Desktops blog
Mobile, Graphics, and Gaming blog
Operating Systems blog
Servers and Cloud Computing blog
SoC Design and Simulation blog
Tools, Software and IDEs blog
Tags
1
Actions
Related blog posts
Related forum threads
Software Optimization: Four real-life Streamline use cases (Part 3)
Guilherme Marshall
September 11, 2013
1 minute read time.
Benchmarking
-
ARM DS-5™ Streamline
is designed for software and system analysis (see previous posts on
Timeline analysis
and
software profiling
), and that is where all its power features apply, but many developers use it for benchmarking because of its ease of use.
In the Timeline View you see the start and end of threads as well as "events" that you can define in your application with printf-style annotations. So, for instance, in the Xaos example report provided in the DS-5 installation we have annotated different stages of fractal computation and we can measure how long it takes to complete each one of these stages
Benchmarking has an obvious use: measure the time to complete a certain task before and after changes in the software, and check whether these have resulted in an improvement or not.
Streamline is actually pretty good for benchmarking because:
It is really easy to use. Once the Streamline gator driver has been integrated in the target's software, running Streamline only requires you to type the IP address of the target and push a button on the GUI
You can capture data for as long as you wish and stream it to your host PC for processing. This can be seconds, minutes or hours
You can script it and drive it from the command line or batch files for test automation
When Streamline is used together with the
Energy Probe
you can measure the energy consumed by your target in order to complete a task. For designs where low power and battery life are critical the goal may be to finish the task within a certain time with the lowest possible voltage and clock frequency settings, rather than try to finish it as quickly as possible. The ability to benchmark total energy consumption and easily measure time between events is critical for success.
[center]
[/center]
Blogs in this series
Four real-life Streamline use cases (Part 1): Timeline analysis
Four real-life Streamline use cases (Part 2): Smart software profiling
Four real-life Streamline use cases (Part 3): Benchmarking
0 comments
0 members are here
Tools, Software and IDEs blog
GitHub and Arm are transforming development on Windows for developers
Pareena Verma
Develop, test, and deploy natively on Windows on Arm with GitHub-hosted Arm runners—faster CI/CD, AI tooling, and full dev stack, no emulation needed.
May 20, 2025
What is new in LLVM 20?
Volodymyr Turanskyy
Discover what's new in LLVM 20, including Armv9.6-A support, SVE2.1 features, and key performance and code generation improvements.
April 29, 2025
Running KleidiAI MatMul kernels in a bare-metal Arm environment
Paul Black
Benchmarking Arm®︎ KleidiAI MatMul kernels on bare-metal with AC6, GCC, and ATfE compilers.
April 17, 2025
0