Mesh-free Solver based on Artificial Neural Networks to solve Partial Differential Equations
This repository contains a Python module to train Artificial Neural Networks (ANNs) to approximate Partial Differential Equation (PDE) solutions based on a cloud of points distributed over the domain and its boundaries. The functionals that represent the PDE and boundary conditions are directly applied as objective and constraints of such optimization, avoiding the need of equation and domain discretization. The same numerical procedure solves PDEs of different types (hyperbolic, elliptic, and parabolic).
Please cite the following manuscript if you intend to use this code: F. T. Kunz, N. R. Sêcco, ANN-based mesh-free method to solve partial differential equations, in Proceedings of the 26th International Congress of Mechanical Engineering, Florianópolis, Brazil, 2021. doi:10.26678/ABCM.COBEM2021.COB2021-0094.
Follow the steps below to clone this repository in your system:
- Make sure you have git installed in your machine. You can install it by opening a terminal session and running the following command: $ sudo apt install git
- You’ll see a "Code" green button on the upper-right side of the repository webpage. Click on it and copy the web URL shown from HTTPS tab.
- Open a terminal instance in your system and navigate to the directory where you want to clone the repository.
- Write $ git clone, paste the web URL you copied in step 3 (You can use CTRL+SHIFT+V to paste on the terminal screen) and execute it.
- Type your Github login and personal access token.
- Git should clone the repository: All done!
You need to install the following packages in your computer:
- Python3: Most Linux distributions already have Python3 preinstalled
- PIP3: This is an interface to install Python3 packages. You can install it with: $ sudo apt install pip3
- Numpy, Scipy, and Matplotlib packages for Python3. You can install them with: $ pip3 install numpy scipy matplotlib
- Fortran compiler. You can install it with: $ sudo apt install gfortran
Follow the steps below to install nps in your system:
- Once you clone the repository, open a terminal session and navigate to the root folder of the repository.
- Write down the directory that holds the root folder. For instance, if you installed nps in /home/user/git/nps, the the directory you must remember is /home/user/git.
- Open your bashrc file with the following command: $ gedit ~/.bashrc (You can use another text editor if you wish).
- Add the following line to the end of your bashrc file: export PYTHONPATH="${PYTHONPATH}:", where is the directory you got in step 2. This will include the nps module in Python's search directory, allowing you to import it from any directory in your system.
- Save and close the text editor.
- Back into the terminal, type: $ source ~/.bashrc. This will reload the definitions from the bashrc file. You may also close and reopen the terminal for these changes to make effect.
- Still with the terminal at the root folder of the repository, execute the command: $ make. Wait until the installation is complete.
- Test the installation by running $ make test in your terminal.
A sample script on how to use NPS to solve the Linear Advection PDE can be found at: /nps/examples/tutorial/lin_adv_tutorial.py
Please use this script as reference to solve other PDE cases.
This repository contains the scripts used to solve the canonical PDEs presented in the associated manuscript. MSE and timing results may differ from the ones presented in the manuscript depending on the optimizer behavior in different computers.
Regarding the reproducibility of the results shown in the manuscript, each folder has a .pickle file, which contains the reference neural networks for each case.
To reproduce the main article plots with the reference neural networks, execute the following Python3 scripts:
- /nps/examples/canonical_cases/ann_solution/canonical_problems_plot.py
- /nps/examples/pot_flow/potflow_1_ANN_plot.py
- /nps/examples/pot_flow/potflow_2_ANN_plot.py
To retrain the article cases neural networks from the scratch, execute the following Python3 scripts:
- /nps/examples/canonical_cases/ann_solution/canonical_problems.py
- /nps/examples/pot_flow/potflow_1_ANN.py
- /nps/examples/pot_flow/potflow_2_ANN.py
Report any issues to:
Ney Sêcco Instructor at the Aeronautical and Aerospace Division Aeronautics Institute of Technology - ITA São José dos Campos, SP, Brazil [email protected]