Neural Network for Phase-Field models
Project description
Quick Start
Python
This package requires a Python version between 3.8 and 3.10 (versions above have not been tested).
You can use a currently installed Python or, for example, create a miniconda/anaconda environment:
conda create --name nnpf python=3.10
conda activate nnpf
If you need a specific computation platform context, like an older CUDA version or the support of ROCm, you should install PyTorch manually using the instructions available on the official website.
Install from Pypi
pip install nnpf
Install from source
Download or clone this repository:
git clone https://github.com/PhaseFieldICJ/nnpf
cd nnpf
Install the nnpf module:
pip install .
You can now move in your working directory.
Self test
You can check the installation with:
nnpf selftest
Basic training
Launch the learning of the reaction term of the Allen-Cahn equation, with default parameters:
nnpf train Reaction --batch_size 10
and/or with custom hidden layers:
nnpf train Reaction --batch_size 10 --layer_dims 8 8 3 --activation ReLU
If you have an CUDA compatible GPU, you can speedup the learning by simply adding the --gpu option:
nnpf train Reaction --batch_size 10 --layer_dims 8 8 3 --activation ReLU --gpu 1
Check informations of one trained model:
nnpf infos logs/Reaction/version_0
Visualize the loss evolution and compare hyper-parameters using TensorBoard:
tensorboard --logdir logs
and open your browser at http://localhost:6006/
Custom model
You can also create a custom model in a file and make it derives from the problem you want to solve.
For example, create a file model.py with the following content:
from torch.nn import Sequential
from nnpf.problems import AllenCahnProblem
from nnpf.models import Reaction, HeatArray
from nnpf.utils import get_default_args
class ModelDR(AllenCahnProblem):
def __init__(self,
kernel_size=17, kernel_init='zeros',
layers=[8, 3], activation='GaussActivation',
**kwargs):
super().__init__(**kwargs)
# Fix kernel size to match domain dimension
if isinstance(kernel_size, int):
kernel_size = [kernel_size]
else:
kernel_size = list(kernel_size)
if len(kernel_size) == 1:
kernel_size = kernel_size * self.domain.dim
# Hyper-parameters (used for saving/loading the module)
self.save_hyperparameters(
'kernel_size', 'kernel_init',
'layers', 'activation',
)
self.model = Sequential(
HeatArray(
kernel_size=kernel_size, init=kernel_init,
bounds=self.hparams.bounds, N=self.hparams.N
),
Reaction(layers, activation),
)
def forward(self, x):
return self.model(x)
@staticmethod
def add_model_specific_args(parent_parser, defaults={}):
parser = AllenCahnProblem.add_model_specific_args(parent_parser, defaults)
group = parser.add_argument_group("Allen-Cahn DR", "Options specific to this model")
group.add_argument('--kernel_size', type=int, nargs='+', help='Size of the kernel (nD)')
group.add_argument('--kernel_init', choices=['zeros', 'random'], help="Initialization of the convolution kernel")
group.add_argument('--layers', type=int, nargs='+', help='Sizes of the hidden layers')
group.add_argument('--activation', type=str, help='Name of the activation function')
group.set_defaults(**{**get_default_args(ModelDR), **defaults})
return parser
with some boilerplate to handle command-line arguments and save hyper-parameters (see Lightning documentation).
ModelDR is declared as a model of the Allen-Cahn problem and thus inherits from the associated training and validation datasets.
You can then display the command-line interface with the --help option after specifying the file and the model name:
nnpf train model.py:ModelDR --help
You can start the training for the 2D case with some custom arguments:
nnpf train model.py:ModelDR --kernel_size 33 --max_epochs 2000 --check_val_every_n_epoch 100
For the 3D case:
nnpf train model.py:ModelDR --bounds [0,1]x[0,1]x[0,1] --N 64 --max_epochs 2000 --check_val_every_n_epoch 100
Using a GPU:
nnpf train model.py:ModelDR --bounds [0,1]x[0,1]x[0,1] --N 64 --max_epochs 2000 --check_val_every_n_epoch 100 --gpus 1
Using a configuration file in YAML format:
nnpf train model.py:ModelDR --config config.yml
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file nnpf-1.0.2.tar.gz.
File metadata
- Download URL: nnpf-1.0.2.tar.gz
- Upload date:
- Size: 62.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b7397daa2eccac3419ce632dd944d637680c32f9a52f11196f1c865990e5e098
|
|
| MD5 |
6e378c26ef9f6cd214e5b7a69690084e
|
|
| BLAKE2b-256 |
1ed0d7cf367cccf639a9f8eca7f9de30b995f28dca70cc634833e11277faf969
|
File details
Details for the file nnpf-1.0.2-py3-none-any.whl.
File metadata
- Download URL: nnpf-1.0.2-py3-none-any.whl
- Upload date:
- Size: 84.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
19822eb54168c8d0f2dbfbd97b143ce85a44104142388624595ee2072d96a0c8
|
|
| MD5 |
b8e86b4a412998d4034d59dcf8b210d2
|
|
| BLAKE2b-256 |
8d5cfb60085027261c8239b3dbe159ffb4043fa3883e7b9b136d4518a0169b79
|