Skip to main content

Shell Scripting to Display Bar Graphs in Linux Terminal

 This week was quite hectic for me with course assignments and their merciless deadlines. One such assignment in Advanced Computer Architecture was simulation of various benchmarks in alpha architecture in simplescalar, a well-known computer architecture simulator. I was supposed to run a total of 4 benchmarks with different configurations of cache memory, instruction issue widths, commit widths, in-order execution modes, etc and I had to plot the required performance parameters for every benchmark. A conservative estimate would be around 40 plots!

 Since the simulation platform was Linux, I could breathe a sigh of relief since most things can be automated using a powerful tool called shell. Scripting made my life easier here since I can automate a bunch of simulations without having to keep an eye on each and every simulation which would take anywhere from 20 minutes to 20 hours.

 The problem arose when it came to plotting the performance results. Because, each simulation had its own output file which has its performance parameters. While most of my colleagues resorted to manually taking down values from the simulation file and plotting them using Microsoft excel, I thought why not this can be automated. ;) 

 But plotting a graph in terminal will not be as simple as plotting it in Excel, but if I manage to pull it off, that will be something I can be a little proud of. Besides that, I show (off to :p) my friends, how awesome piece of a tool shell is. 

APPROACH:


 A simple performance comparison plot would be a bar chart. The wget tool's download progress indicator in a Linux command line is somewhat similar to 
============================================>| 89% 

This is a minimalistic indicator and does the job well. So, I thought of comparing the parameters using a horizontal bar graph which will be simple and visually appealing too. So my rough idea was to implement something like
         
param1:  |||||||||||||||||||||||||||||||||||||||||||||||||||| 67%
param2:  ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| 75%
param3:  |||||||||||||||||||||||||||||| 39%

Pretty huh ? :) This can be displayed in terminal interface and looks little geeky too. I started off writing a script which
  • Takes the simulation file name as command-line argument
  • Uses grep & awk to grab the performance parameters from the file
  • Find the maximum and taking it as a reference (100%) 
  • Scaling others and plot in command-line as vertical bar graph
This worked well, and did the job ! But I found that something was missing. Colors!! Displaying the output in colors and weird way in Turbo C (graphics.h) was my something I loved in school. A little googling of about colored text outputs in terminal led me to an impressive tool called tput. It does basic coloring of texts, few formatting options like bold, underline, etc.
 So I modified my code and added this feature. What a beauty!! The output had a colorful geeky touch which was quite impressive.

SAMPLE OUTPUTS:







Sample Script:

Comments

Post a Comment

Popular posts from this blog

Programming STM32 ARM microcontrollers in Arch Linux

Once upon a time, not so long ago, the 8-bit microcontrollers were ruling the hobbyist embedded world. But today, the 32-bit ARM Cortex Microcontrollers are so inexpensive and power efficient that there is no good reason to ignore them. Here, let us see how to program a STM32 ARM cortex Microcontroller in Linux environment. The specific microcontroller used here is an STM32F103C8 (ARM cortex M3) programmed in Arch linux. Components Generic STM32F103 board (blue pill) STLINK-V2 (STM32 programmer) Female-Female connectors All the above components can be bought from ebay for less than $10 total. The STLINK-V2 is optional since you can use any of USB-SERIAL converters like FT232, CP2102, PL2303, CH340 and the built-in UART bootloader of STM32 chip to program. So if you already have any of the above serial converters, you don't really need STLINK to program the STM32F103 microcontroller. But STLINK helps if you plan to use in circuit debugging functionalities. Software The...

RTL Design & Implementation of a RISC- Single Cycle Processor -Part I

  Low cost FPGA development platforms and Hardware Description Languages like Verilog & VHDL have not only made lives of Front-end VLSI  Engineers easier but also hobbyists' . I have been experimenting with a 40$ Xilinx FPGA development board for couple of years and its real fun. And now, a part of my project for ASIC Design Lab course at University of Minnesota requires me to design and implement a microprocessor. Armed with my FPGA board and a new-found enthusiasm amidst my busy schedule at the U of M, I sat up to design a minimalistic CPU in Verilog. Tools Used: Verilog/VHDL Simulator (ModelSim, Icarus Verilog, Xilinx ISE,etc) A decent Code Editor (VIM) A Xilinx FPGA board (optional) ARCHITECTURE:   I chose Load/Store Architecture for my microprocessor design since most RISC machines like ARM, MIPS,etc are based on this architecture. Besides that, quicker prototyping and better understanding of computer architecture was on top priority in my list...