\documentclass[english,edition=2024]{zpiday}
%\documentclass[polish,edition=2024]{zpiday}

\usepackage{graphicx}
\usepackage{lipsum}
\usepackage{float}
\usepackage{subcaption} 

\title{Organized Waste Optimization}
\acronym{OWO}
\supervisor{Natalia Piórkowska}
\members{Bartosz Szewczyk\orcid{0009-0008-1254-7763} \and Nikodem Stamirski\orcid{0009-0001-1162-560X} \and Zuzanna Sztyma\orcid{0009-0009-7484-8331}}
\projectLogo{images/owo_logo.png}

\begin{document}

\maketitle

\begin{abstract}
The "Organized Waste Optimization" (OWO) project aims to improve waste management in Wrocław through an innovative distributed system. This system integrates IoT-enabled smart bins, a centralized back-end for data processing and route optimization, and a front-end application for visualization and tracking. Key benefits include reduced fuel consumption, minimized traffic congestion, and a cleaner urban environment. Despite risks such as environmental challenges and scalability, our prototype highlights the potential for practical implementation.
\end{abstract}

\section{Development}
\subsection{Introduction}
Effective waste management is essential in modern cities, yet inefficiencies persist due to static collection schedules and overflowing bins. This project aims to address these issues by developing a distributed smart bin system that dynamically monitors waste levels and generates optimized routes for garbage collection.

\paragraph{Objectives}
\begin{itemize}
    \item Create IoT-enabled smart bins capable of monitoring waste levels and environmental conditions.
    \item Develop a robust back-end for real-time data aggregation, storage, and optimization.
    \item Design a front-end application for route visualization and system management.
\end{itemize}

\subsection{Related Work}
In Wrocław and most other cities, a fixed route solution is usually implemented and calculated using Vehicle Routing Problem (VRP) optimization algorithms but the input data for these algorithms is often based on city demographics which might not always be the most efficient.

Other than our project, there are other existing solutions which try to integrate existing bins into smart optimizations system:
\begin{description}
    \item[Sensoneo:] Their bins include various additional but non-essential sensors. Their single rangefinder is relatively large yet offers only a 2.5-meter range. Additionally, they use a one-time battery instead of a solar panel.
    \item[Enevo:] Enevo's bins also feature non-essential sensors, such as a thermometer. They rely on less efficient LTE-M connectivity (with a shorter range than LoRa), but they provide a fully automated service using ML models. Enevo also offers different bin models for various use cases.
\end{description}

\subsection{Results}

\subsubsection{Smart Bin System}
Microcontroller used for this project is ESP32 on the Arduino Nano ESP32 board.

\paragraph{Communication with the server} 
The Grove-Wio-E5 RF module enables communication with the server using LoRa and LoRaWAN technologies. LoRa modulation allows the device to transmit data over distances of up to 10 km under ideal conditions. With its long range and low power consumption, LoRa is well suited for transmitting simple data, such as fill levels or location information, to a server. 

The LoRaWAN protocol is built on top of the LoRa modulation and is used to manage communication between devices in a network. LoRaWAN is a Media Access Control (MAC) layer protocol that defines how LoRa devices interact with the network, enabling them to join the network, authenticate, and exchange data.

\subparagraph{Sending data to LoRaWAN network works as follows:}

\begin{enumerate}
\item  Microcontroller communicates with the Grove-Wio-E5 using UART. To facilitate this communication, the device relies on AT commands.
 \item Grove-Wio-E5 transmits data using LoRa modulation and the LoRaWAN protocol.
\item The LoRaWan gateway receives LoRa signals from the end devices.
\item The LoRaWan gateway forwards the received data to The Things Network (TTN) server for further processing. 

\end{enumerate}


\paragraph {Analysis of the fill level} of the container is performed using 4 ultrasonic range sensors HC-SR04. The sensors are positioned at the top of each wall of the bin, facing downward to measure the distance from the objects in the container.

Activating all 4 sensors simultaneously would lead to signal interference because the sensors emit ultrasonic waves at the same frequency. These overlapping signals make it difficult for the sensors to distinguish their own reflected waves. Therefore, sensors must be activated sequentially. 

\subparagraph {Steps for calculating approximate fill level:}

\begin {enumerate}
    \item A single sensor makes 10 measurements.
    \item  Outliers are identified and removed using the standard deviation method.
    \item The remaining data is averaged to produce a single reliable distance measurement.
    \item The process is repeated for the rest of the sensors.
    \item The percentage of fill level for each sensor is calculated based on the height of the container.
    \item The final average fill level of the container is determined by averaging the result from all 4 sensors.
\end {enumerate}

\paragraph{Power supply and energy management} is handled by a Waveshare Solar Panel (18V, 10W), which works with a solar power manager to charge a 3.7V lithium-ion battery with a capacity of 10,000mAh.

\begin{itemize}
\item The battery provides enough energy to keep the bin system running in sleep mode for up to 69 hours, ensuring continuous operation at night when sunlight is unavailable.

\item In perfect condition, the solar panel produces 10W of power and, accounting for 90\% efficiency, generates approximately 9W. With the bin system consuming 0.48W the solar panel alone can supply enough energy to power the entire system.

\end{itemize}


    \begin{figure}[H]
        \centering
        % First Row
        \begin{subfigure}[b]{0.3\linewidth}
            \includegraphics[width=\linewidth]{images/distribution_box.jpg}
            \caption{Distribution box with microcontroller, voltage regulator with battery, GPS and LoRa modules}
        \end{subfigure}
         \hspace{0.2\linewidth}
        \begin{subfigure}[b]{0.3\linewidth}
            \includegraphics[width=\linewidth]{images/panel.jpg}
            \caption{Solar panel}
        \end{subfigure}
        
        % Second Row
        \begin{subfigure}[b]{0.3\linewidth}
            \includegraphics[width=\linewidth]{images/bin_inside.jpg}
            \caption{Range sensors inside the bin box}
        \end{subfigure}
         \hspace{0.2\linewidth}
        \begin{subfigure}[b]{0.3\linewidth}
            \includegraphics[width=\linewidth]{images/sensor.jpg}
            \caption{Range sensor}
        \end{subfigure}
    \end{figure}


\subsubsection{LoRaWAN Connectivity: The Things Network}
\paragraph{The Things Network}
is a service for LoRaWAN connectivity that we used in this project. Its main functions are:
\begin{itemize}
\item Registering an application.
\item Registering LoRa devices in an application.
\item Receiving data from LoRa devices through LoRa gateways.
\item Storing this data and providing multiple APIs to process it by other applications.
\item Providing an additional API for project manipulation outside its own web interface.
\end{itemize}
We use this service with our own application to insert and test a bin system and the back-end functionalities associated with this part of our project.

\subsubsection{Back-end: Centralized Data Processing}
\paragraph{Overview}
The back-end, written in Python using \textbf{Domain-Driven Design} and containerized, serves as the system’s core, aggregating data from IoT devices, storing it in a PostgreSQL database, and generating optimized collection routes.

\paragraph{Technologies and Implementation}
\begin{itemize}
    \item \textbf{HTTP Framework} - Python-based FastAPI library for efficient data handling.
    \item \textbf{MQTT Framework} - Paho-MQTT library for receiving data from the bins through TTN.
    \item \textbf{Database} - PostgreSQL for structured data storage and retrieval.
    \item \textbf{Routing cost calculator} - OpenStreetMap (OSM) library was used for calculating costs between nodes which is needed for the route generation. The library contains a set of city maps with nodes and a built-in way of calculating different types of costs between nodes.
    \item \textbf{Quick cost lookup with cost maps} - An original cost map solution was created to store pre-calculated costs between nodes on a map to ensure quick route calculations as the OSM algorithm was slow.
    \item \textbf{Optimization Algorithm} - OR-Tools library and its set of functions for solving VRP problems calculate fuel-efficient and time-saving routes for garbage trucks.
    \item \textbf{Multi-threaded design} - Many parts of the system like MQTT connectivity, cost map updates, generating routes or HTTP interface run on separate threads to prevent it from bottle-necking.
\end{itemize}

\paragraph{Architecture Diagram}
showcases how the different layers of the back-end application are interconnected. Synchronization of objects between the Domain and Database layers has been done using the Repository Design Pattern.
\begin{figure}[H]
    \centering
    \includegraphics[width=0.7\linewidth]{images/back-end architecture diagram.png}
    \caption{Back-end Architecture Diagram}
    \label{fig:backend-architecture-diagram}
\end{figure}

\paragraph{Cost Maps}
are used to store pre-calculated costs of traveling between nodes to improve the optimization's speed. This solution also lets the costs for a single bin be easily updated with location reducing the complexity from \(O(n^2)\) to just \(O(n)\).
\begin{figure}[H]
    \centering
    \includegraphics[width=0.8\linewidth]{images/cost map initialization.png}
    \caption{Cost Map Initialization}
    \label{fig:enter-label}
\end{figure}

\paragraph{Optimization Algorithm} created with the OR-Tools library's VRP solving functions is able to return a series of paths for all given trucks alongside information of total load gathered and total time used in carrying out the routes which are helpful in testing the used optimization options.
\begin{figure}[H]
    \centering
    \includegraphics[width=0.8\linewidth]{images/optimization algorithm result.png}
    \caption{Optimization Algorithm Result}
    \label{fig:enter-label}
\end{figure}


\subsubsection{Front-end: User Interface and Visualization}
\paragraph{Overview} The front-end application provides interface for easy and efficient data access and management for waste management companies, ensuring efficient coordination and decision-making. It allows for access to all the projects features, like bin fill levels and calculated routes. It also provides map views showing locations of various bins and calculated routes. It uses a highly adaptive modular design allowing for reusability of components and easy maintenance.

\paragraph{Functionalities Implemented}
The front-end application of the OWO project includes several key functionalities:
\begin{itemize}
    \item \textbf{Homepage:} A representative page listing the biggest selling points of the project in a modern style
    \item \textbf{Bin, Truck and Dispatch Center Administration screens:} Sections for managing smart bins, trucks and Dispatch Centers, including adding, editing, deleting and displaying data.
    \item \textbf{Dispatch Center Details:} A detailed view of a specific dispatch center data, including its dispatches and the ability to create new dispatches with a dropdown menu for garbage type selection
    \item \textbf{Map view:} A map view that displays the locations of bins and dispatch centers. It includes a dropdown to filter bins and centers by dispatch center and a popup with details when an object is clicked.
    \item \textbf{Dispatch details:} A view that displays the calculated paths for a specific disaptch on the map and lists all related data
    \item \textbf{Navigation view:} A map view showing the most recent path for a specified truck with real time location and path to the first assigned bin, allowing workers to follow the route easily
\end{itemize}



\begin{figure}
    \centering
    \includegraphics[width=0.5\linewidth]{images/map.png}
    \caption{Map view}
    \label{fig:enter-label}
\end{figure}



\paragraph{Technologies used}
\begin{itemize}
    \item \textbf{React:} A JavaScript library for building user interfaces, enabling the creation of reusable components.
    \item \textbf{TypeScript:} A typed superset of JavaScript that enhances code quality and maintainability.
    \item \textbf{Vite:} A fast build tool that provides a modern development environment with hot module replacement (HMR).
    \item \textbf{Tailwind CSS:} A utility-first CSS framework that allows for rapid UI development with a consistent design system.
    \item \textbf{React Router:} A library for handling client-side routing, enabling seamless navigation between different views.
    \item \textbf{Leaflet:} An open-source JavaScript library for interactive maps, used to visualize bin locations and optimized routes.
    \item \textbf{React-Leaflet:} A React wrapper for Leaflet, making it easier to integrate maps into React components.
\end{itemize}

\section{Conclusion}

\subsection{Conclusions}
\subsubsection{Key Achievements}
\begin{itemize}
    \item Demonstrated the potential for reduced fuel consumption, cleaner streets, and lower workforce requirements in theoretical analyses.
    \item Successfully designed and implemented a back-end system that processes real-time data from smart bins.
    \item Optimized route generation using the OR-Tools VRP algorithm and a custom CostMap, achieving significant efficiency improvements compared to direct OSM-based calculations.
    \item Developed a scalable, extensible architecture based on Domain-Driven Design principles, enabling future growth and adaptability.
    \item Developed a user-friendly user interface allowing users to see, edit and delete data, and display it on maps
\end{itemize}
\subsubsection{Key Insights}
\begin{itemize}
    \item LoRaWAN technology is an excellent choice for IoT solutions in smart cities due to its low power consumption and long-range capabilities.
    \item Domain-Driven Design enables clear separation of concerns and makes the system easier to maintain and extend.
\end{itemize}
\subsubsection{Limitations}
\begin{itemize}
    \item Lack of real-world implementation data limits the ability to validate the system’s full effectiveness.
    \item The OR-Tools algorithm requires parameter tuning to accommodate real-world complexities like traffic patterns.
    \item Current hardware solution for bins is a prototype and needs a proper version.
\end{itemize}

\subsection{Future Directions}
\subsubsection{Smart Bin System}
\begin{enumerate}
    \item Designing a proper mounting solution for bin computers inside of bins - Our solution is just a prototype, and a solution environment-resistant solution should be made.
    \item Implementing Sleep Mode for ESP32 for power consumption optimization
    \item Improving reliability of the measurements by implementing better outlier detection and noise reduction.
    \item Improving the method of finding the fill level approximation by using specialized algorithms or machine learning models.
    
\end{enumerate}
\subsubsection{Back-End}
\begin{enumerate}
    \item Introduction of proper HTTP protocol security which is lacking in our solution - Without it deployment is not possible.
    \item Introduction of more integrity checks and security in the domain and database - Data integrity between domain and database might be at risk in unexpected circumstances and a more robust security against SQL injection might be needed.
    \item Incorporating an existing bin and truck identification solutions that are used by Wrocław for compatibility with other Wrocław's systems.
    \item Playing more with the OR-tools VRP algorithm parameters or introducing new ones.
    \item Introduction of an additional optimization algorithm that would calculate days for dispatches as the current solution requires a person to make that decision.
    \item (Optional) Replacing the currently used VRP algorithm solution with a real-time ML model that would create dispatches when necessary and could predict filling.
    \item (Optional) Storing different cost maps for different seasons or days or times of day or better cost predictions.
\end{enumerate}
\subsubsection{Front-End}
\begin{enumerate}
    \item Introduction of an authentication system for workers and administrators.
    \item Enhancing user experience, especially in navigation mode.
    \item Improving the visual aspect of the app.
    \item Implementing real time updates from the server.
    \item Adding advanced filtering and search to the administration screens.
    \item Implementing input validation.
    
\end{enumerate}

\subsection{Acknowledgments}
We want to give thanks to our amazing supervisor Natalia Piórkowska. Without her help and patience, this project wouldn't come together.

\nocite{*}  % Include all entries from the .bib file
\bibliographystyle{plain}
\bibliography{references}


\end{document}
