Animate your Python Graphs with Pillow
Animate your Python plots with the Python library Pillow to bring life to your insights.
data:image/s3,"s3://crabby-images/01875/01875ed40a475b76be22310d6625c81f0eb2862a" alt="Animate your Python Graphs with Pillow"
Animate your Python plots with the Python library Pillow to bring life to your insights.
As a data scientist, your ultimate goal is to present your findings in an engaging and informative way.
But how can you ensure that your data is not only visually appealing but also easy to understand?
Scenario
You are a data scientist who has developed an algorithm or performed advanced analysis linked to a dynamic process.
Because you want to show the impact of your solution, you plot the results using a conventional Python library.
data:image/s3,"s3://crabby-images/801de/801ded85b309ec7906edc7c185773216cac722f1" alt="A line chart visualizing a pathfinding solution for warehouse Picking using python with connected nodes represented by blue dots. Each node is labeled with a number indicating its sequence in the route. The dashed lines represent the connections between these nodes. This graph is part of a process to optimize a dynamic system by showing the route taken in the solution."
However, your graphs are not self-explicit and do not reflect the dynamic aspect of the process.
This article will use this example of pathfinding algorithms to show how you can bring additional insights by building GIF animations with Python Pillow.
1. Problem Statement
Example of pathfinding algorith for warehouse picking
2. Objective
The final result will be an animated GIF of a scatter plot.
II. Generating the Frames with Matplotlib
1. Process
An explaination of the complete workflow to generate an animated plot.
2. Intermediate Plots
We start by generating and saving partial plots
III. Creating Animated GIFs with Python Pillow
1. Step 1: Create the function to convert to a picture
Each intermediate plot will be converted to a picture.
2. Step 2: Build the loop to plot each step
Each step leading to the generation of the final plot
3. Step 3: Create the GIF
Combine the frames in animation by fixing the time per frame using PIL
IV. Conclusion
1. Examples of Animation for Transportation Optimization
This method used to generate an animated map showing delivery routes
2. Automate Graphic Design with PIL
Pillow used to generate warehouse labels with a very efficient workflow
Share Insights with Animated Graphs
Problem Statement
In a Warehouse, walking time from one location to another during the picking route can account for 60% to 70% of the operator’s working time.
Reducing this walking time is the most effective way to increase productivity.
data:image/s3,"s3://crabby-images/42e4b/42e4b91f9b6d761a0df1e5a5710deb20af73572e" alt="Animated warehouse layout depicted with multiple rows of shelves labeled from A01 to A19. The diagram shows three different animated paths for a picker with routes marked by dashed lines in different colors (blue, black, red). The starting point is labeled “START,” and the paths lead to specific shelves with different colors marking the picked locations."
Therefore, you have developed several algorithms that optimize the route of warehouse operators to reduce their walking distance.
Task
Using an example of a long-picking mission, you want to use a graph to show the difference between the two algorithms.
data:image/s3,"s3://crabby-images/10591/10591afb503bb225657968f8efda87abac28b0c5" alt="A graph comparing two solutions from a pathfinding algorithm for warehouse picking route designed with Python. Each node is represented by orange and yellow dots, with numbers inside them to indicate the order of the sequence. Dashed lines connect the nodes in both solutions, allowing a visual comparison between the two algorithms and how they traverse through the picking locations."
Each dot is a picking location, and the numbers represent the order in the operator's picking route.
However, these graphs could be more self-explicit, and we missed the steps that led to this final result.
Objective
Let us animate this graph to see the sequence location by location and understand the difference between the two solutions.
data:image/s3,"s3://crabby-images/8da37/8da373998a770920e232c3a8e35e8709bbbb3d44" alt="Two animated scatter plots with colored dots, representing two solutions. The upper chart shows orange-colored points connected by dashed lines, and the lower chart shows yellow-colored points connected by dashed lines. Each point is numbered, showing the sequence of steps in each solution, comparing two different pathfinding algorithms’ results."
The final result would be like this animated gif above, where you can follow the sequence of locations visited for two different algorithms.
Let’s start by generating the frames.
🏫 Discover 70+ case studies using Python to automate reporting, generate interactive visuals and support business optimization 🏪 in this Cheat Sheet
Generating the Frames with Matplotlib
Process
Let me first explain how to plot the graph presented above,
- You import a batch of order lines with Order Number, Item Code, Location Coordinates
- You run the two algorithms that will create the routes for each order
- You export the results with the succession of locations to cover each route
data:image/s3,"s3://crabby-images/77f62/77f62858490f29439b2f97ee4f4e4d22f36b1685" alt="A visual flow diagram illustrating two algorithms (Algorithm 1 and Algorithm 2) processing order data (with details like quantity, item, and picking location). The results from each algorithm provide different picking paths and distances, with Algorithm 1 generating Path 2 and Distance 2, and Algorithm 2 generating Path 1 and Distance 1. This shows a comparison between the two algorithms used for optimizing warehouse picking routes."
The results look like this,
- In Path OR and Path Init you have the succession of 2D coordinates
- In Distance OR and Distance Init you have the total distance
I won’t detail much about the algorithm.
If you are interested, you can deep dive into the article linked below 👇
data:image/s3,"s3://crabby-images/426d0/426d0f368c80055925cfe5b29e101f47bf8e64c2" alt=""
Let’s generate the intermediate plots now.
Plot
Let’s take the line with the biggest gap in distance between the two methods and plot the results.
Import the libraries
Because we are going to use scatter plots, we need to extract the coordinates by location for the two solutions.
- We create two lists of the location coordinates for the two solutions
- For each list, we create two sublists to take the x-axis and y-axis coordinates
We can use now the lists (x1, y1, x2, y2) to plot the two paths,
- Plot a dot for each location coordinate (xi, yi) with xi in x1 and yi in y1
- Link the dots with dotted lines ‘ — ‘
- Annotate each dot with the order of the location in the path
The final result is a plot of the complete paths,
data:image/s3,"s3://crabby-images/10591/10591afb503bb225657968f8efda87abac28b0c5" alt="A graph comparing two solutions from a pathfinding algorithm for warehouse picking route designed with Python. Each node is represented by orange and yellow dots, with numbers inside them to indicate the order of the sequence. Dashed lines connect the nodes in both solutions, allowing a visual comparison between the two algorithms and how they traverse through the picking locations."
How did we arrive at this final result?
Let us detail each step.
Intermediate Plot
You can show the partial path if you truncate the lists used to plot the dotted lines.
data:image/s3,"s3://crabby-images/cd25c/cd25ce1f2c6ae8a9a50ec345ab6053a75268760f" alt="A plot of the first three picking locations from two algorithms used for optimizing warehouse routes. Each dot represents a picking location, and the partial paths of the two algorithms are shown. The progression of these paths will eventually lead to a full sequence of locations. The visualization serves as a step in generating an animated sequence comparing the two algorithms’ efficiency in warehouse route optimization."
You will reconstitute the picking route by showing partial paths for the first n locations with n varying between 1 and 20.
[Plot 1, Plot 2, … Plot n]: with n the number of locations covered in the path plotted
The final result will be a GIF of these partial paths showing the succession of locations for the two solutions.
Creating Animated GIFs with Python Pillow
The process will be simple,
- Generate plots of the partial paths: step-by-step
- Convert each plot to a picture using the library io and store it in a list
- Create a gif using PIL with the generated list
Step 1: Create the function to convert to a picture
This function will take the figures generated with matplotlib and return a picture with the right format for PIL.
Step 2: Build the loop to plot each step
The images are stored in the list: list_gif
Step 3: Create the GIF
You can create the gif with one line of code,
- You append the first image with the rest of the list
- You can select the duration per picture in (ms)
- Select infinite loop with the option: loop = 0
Final Result
data:image/s3,"s3://crabby-images/e4da9/e4da92898ffb1b4254bcf1da0a6b11e1096d5d07" alt="Final Resuls of Animated Scatter Plot using Python GIF"
You can now see the succession of picking locations and understand where the two algorithms differ.
Conclusion
With this straightforward example, you can understand the different steps to follow to generate your animated graphs,
- Build a loop that will generate all the frames of your gif
- Create a function to convert your plots to image
- Build a GIF with all the frames, choosing the speed and the number of loops.
Examples of Animation for Transportation Optimization
You can find other applications of this method for more operational case studies in my previous articles.
data:image/s3,"s3://crabby-images/85ded/85ded753615ee26fd192658e29eb0ec732b0da97" alt="Animated detailed map of eastern China, showing major cities like Nanjing, Hangzhou, and Suzhou. The map includes 14 routes marked with colored lines connecting different cities, representing transportation routes for deliveries on 2016–09–01. Black, red, and blue lines connect cities along key logistics corridors, providing insights into delivery patterns for road transportation optimization with Python."
In the animation above, multiple routes are visualized to deliver hypermarkets from a distribution centre in Shanghai.
data:image/s3,"s3://crabby-images/6a323/6a32358419724230774da68c2be33fa063108e7f" alt="A simplified illustration of a truck route delivering to six retail stores. The truck starts at the distribution center, travels between stores, and the visual includes a table showing store names, truck ID, and volume (m3). The truck’s path is depicted with dotted lines, providing a clear overview of route efficiency and store delivery patterns."
The idea is to monitor trucks' routing to ensure they deliver the maximum number of stores per trip.
What’s the objective? Reduce costs and CO2 emissions.
data:image/s3,"s3://crabby-images/48c65/48c65cca3c16c3def34f41935ac90e667f8d5633" alt="A bar chart displaying monthly cost (in RMB/ton) and average truck size (in tons). Bars represent cost data while a red line shows fluctuations in truck size. This comparison highlights trends in cost and truck utilization, with noticeable peaks and dips, aiding in cost optimization efforts for transportation."
With this animated plot, we can visualize the routes designed by planners, understand the patterns and find optimization levers.
For more information, check the link below 👇
data:image/s3,"s3://crabby-images/8cdbc/8cdbc33218150531751b1d482fefe1572b8d3a04" alt=""
Do you need support to automate graphic design?
Automate Graphic Design with PIL
In another article, I share the issues implementation managers face when setting up a new warehouse facility.
data:image/s3,"s3://crabby-images/cc282/cc2825cd8f9bd74d82b46b32b3bcfd5a9e233d52" alt="A photograph of a pallet location in a warehouse, focusing on a yellow highlighted barcode label on the shelf. The label includes a code and identification details. Above the shelf are stacked boxes, and a blue line visually highlights the label’s position, aiding in the identification of storage locations."
They must manually create hundreds of labels for racks, shelves and workstations.
data:image/s3,"s3://crabby-images/12ee0/12ee0fde5ef9227d8b140ce7dbd9e728a962720b" alt=""
Can we automate this process?
Instead of generating graphs, you can create visuals, illustrations, or labels, as in the example below.
These labels have been automatically generated by a Python script using the PIL library.
data:image/s3,"s3://crabby-images/cf0b4/cf0b4d6cae1b55abc2277ef04e92ba93a39fdf48" alt="A diagram illustrating a workflow to generate warehouse labels using Python. An Excel file is used to create labels through Python scripts. The process generates barcodes and stickers for different warehouse locations, with each label displaying a unique number, directional arrow, and product information like clothing items or packaging."
Using Python, I designed a completely automated workflow to generate labels based on parameters stored in an Excel file.
If you want to implement it, check the details 👇
data:image/s3,"s3://crabby-images/5e62e/5e62e8b715fe8439142efc94190527b9fef008e8" alt=""
If you prefer, you can watch the video version of this tutorial,
About Me
Let’s connect on Linkedin and Twitter. I am a Supply Chain Engineer who uses data analytics to improve logistics operations and reduce costs.
For consulting or advice on analytics and sustainable supply chain transformation, feel free to contact me via Logigreen Consulting.