Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/andresrodriguez55/wind-turbines-edge-ai
BACHELOR THESIS. Detect wind turbine errors using a hybrid model. Utilize ML, DL, edge computing. Dataset, neural network optimized with genetic algorithms. Low computational power ML models. Data is stored in the cloud. Turbine status via secure APIs. Password encryption. GRASP, SOLID
https://github.com/andresrodriguez55/wind-turbines-edge-ai
deep-learning edge-ai edge-computing esp32 fastapi genetic-algorithm grasp iot layered-architecture machine-learning monolith neural-network ntier-architecture optimization react solid spring spring-boot thesis wind-turbine
Last synced: 2 months ago
JSON representation
BACHELOR THESIS. Detect wind turbine errors using a hybrid model. Utilize ML, DL, edge computing. Dataset, neural network optimized with genetic algorithms. Low computational power ML models. Data is stored in the cloud. Turbine status via secure APIs. Password encryption. GRASP, SOLID
- Host: GitHub
- URL: https://github.com/andresrodriguez55/wind-turbines-edge-ai
- Owner: andresrodriguez55
- Created: 2023-05-16T10:10:35.000Z (over 1 year ago)
- Default Branch: clientBackend
- Last Pushed: 2023-06-02T21:32:42.000Z (over 1 year ago)
- Last Synced: 2024-01-27T14:11:23.909Z (12 months ago)
- Topics: deep-learning, edge-ai, edge-computing, esp32, fastapi, genetic-algorithm, grasp, iot, layered-architecture, machine-learning, monolith, neural-network, ntier-architecture, optimization, react, solid, spring, spring-boot, thesis, wind-turbine
- Language: Java
- Homepage: https://andresrodriguez55.github.io/wind-turbines-edge-ai/#/login
- Size: 109 MB
- Stars: 11
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
1. Introduction
Today, the use and production of accurate and effective energy is increasing day by day. However, the majority of energy production is still made from non-renewable sources such as carbon, oil and natural gas. This situation leads to a decrease in the relevant resources. In addition, more energy needs arise in the world due to reasons such as population growth and technology development. For this reason, more use of carbon-based resources will lead to the depletion of these resources in the future. In addition, it should not be forgotten that fossil fuels such as oil and coal cause ecological pollution. For this reason, it has become inevitable to seek and use more harmless and renewable resources. Renewable resources can result in unlimited energy production and do not cause any harm to nature. For this reason, in recent years, we frequently see and use renewable resources such as geothermal, solar, wave and wind.
Wind turbines are used to generate wind energy. Errors can be encountered during the use of wind turbines. These errors can be external or internal. Some errors are:
- External error types
- Bird strike
- Rains
- Lightning Strike
- Delamination
- Internal error types
- Electrical faults
- Mechanical malfunctions
Detecting errors, monitoring the components of the wind turbine, and being prepared for future detectable errors are inevitable.
Different approaches such as distributed architectures, artificial intelligence, edge AI, data mining, and user-server focused architectures are commonly used in the energy sector today. These approaches offer effective solutions in important areas such as energy production, data analysis and prediction, and energy management.
Techniques such as genetic algorithms, dimensionality reduction, and artificial neural network optimization are frequently used in the energy sector.
As a hybrid solution, proposing a system that combines these different approaches can be effective. For example, using a distributed architecture, data can be collected and shared in energy facilities. With artificial intelligence and data mining techniques, these data can be analyzed to make energy demand predictions and detect errors. Data preprocessing operations and genetic algorithms can be used for dimensionality reduction and improving artificial neural networks in the used datasets. Real-time error detection and decision-making can be performed using edge AI. User-server focused architectures can facilitate users' access to and management of energy data.
2. Method
2.1. Data Mining
The datasets used for the system were subjected to data preprocessing processes. These processes include cleaning, integration, transformation, parsing, and normalization.
2.1.1. Feature Reduction
Since there are multiple features in the datasets, dimensionality reduction processes were also performed. For dimensionality reduction, ANOVA tests, correlation analyses, and box plot analyses were conducted.
Genetic algorithms were used as finding the most effective features is quite challenging.
Information Gain, Akaike Information Criterion, and supervised machine learning algorithms were used to determine the fitness values in genetic algorithms.
Information Gain measures the ability of a feature to reduce the uncertainty in the dataset. By selecting a feature, the homogeneity between classes increases and the uncertainty decreases. In other words, the selected feature makes the dataset more classifiable.
Akaike Information Criterion combines the fit and complexity of a model. The AIC value of a model represents the balance between the model's ability to fit well and the trade-off between overfitting and underfitting.
Since supervised machine learning algorithms were used in practice, relevant algorithms can be used in feature selection.
2.1.2. Weight Optimization in Artificial Neural Networks
A simple neural network with a small number of sensors and hidden layers was used in the model development.
The aim is to demonstrate the usability of a simpler neural network instead of complex neural networks used today.
Genetic algorithms were used to optimize the weights of the connections in the neural network
to deepen the optimization.
2.2. Edge AI
The edge AI architecture to be used to increase the efficiency of the study has been experienced in a software simulation environment, focusing on edge server-oriented sub-architecture type. The collected data is stored in the cloud environment, and the status of wind turbines is presented to the experts in real-time through user interfaces.
2.2.1. Applied Architecture - Edge Server-Oriented Computing
The edge server-oriented computing sub-architecture of the edge AI architecture has been applied. It is performed in edge servers located close to the edge AI device, similar to edge computing in an edge network. This allows the edge device to send data to the edge server for processing and returning results. The advantages of this architecture include higher processing power and memory compared to a fully cloud-based architecture, higher accuracy and efficiency, and lower latency. However, this may require more investment in network infrastructure and edge servers.
2.2.1.1. Edge Client - Edge Collecting Sensor Data
The edge client is responsible for sending sensor data to the edge server. This edge device should be connected to a local network to communicate with the edge server. The edge client uses an API to send data to the edge server. Since less complex artificial intelligence models are used, the artificial intelligence is performed in these edges.
ESP32s are used for edge clients. The artificial intelligence models have been converted to C code and run on ESP32s. The software for ESP32s has been experienced in a software simulation environment.
2.2.1.2. Edge Server
Edge servers only run their REST APIs in local networks to enhance security. These REST APIs only accept POST requests. These requests will receive sensor data from wind turbines and fault condition values predicted by artificial intelligence models.
The REST APIs of edge servers have been developed with a minimalist approach. FastAPI has been used for the implementation of these APIs to work quickly and not burden the computation unit.
2.3. User-Oriented Applications
2.3.1. API
In contrast to architectures like MVC, it is planned to integrate future different interfaces into these API services. Server APIs compatible with the layered architecture have been developed considering the needs of end-users.
The applied architecture ensured the preservation of class principles commonly used in the industry. APIs developed in accordance with the S.O.L.I.D and GRASP principles provide flexibility against future changes.
APIs developed in accordance with the monolithic architecture were implemented using widely used technologies today. Technologies such as Spring, Spring Data, ModelMapper, Lombok, Swagger, and Hibernate were used.
2.3.1.1. Increasing Security
Json web tokens have been implemented to increase data security. The data of the jwt base will be controlled to the data of the users that are in the database, additionally the time of completion of the tokens will be controlled. Additionally, user passwords are encrypted in the databases.
2.3.2. Interface
The application has a web interface. React technology, widely used in the industry, was used to reduce development time. The MUI component library was used to further accelerate development. Design patterns have been implemented for some components.