Skip to main content

PhaseFieldX: An Open-Source Framework for Advanced Phase-Field Simulations

Project description

PhaseFieldX

Welcome to PhaseFieldX. documentation

Documentation Status PyPI Version PyPI Downloads License Joss Unit Testing Ask DeepWiki

Introduction

The PhaseFieldX project is designed to simulate and analyze material behavior using phase-field models, which provide a continuous approximation of interfaces, phase boundaries, and discontinuities such as cracks. Leveraging the robust capabilities of FEniCSx, a renowned finite element framework for solving partial differential equations, this project facilitates efficient and precise numerical simulations. It supports a wide range of applications, including phase-field fracture, solidification, and other complex material phenomena, making it an invaluable resource for researchers and engineers in materials science.

Purpose

The PhaseFieldX project aims to advance phase-field modeling through open-source contributions. By leveraging the powerful FEniCSx framework, our goal is to enhance and broaden the application of phase-field simulations across various domains of materials science and engineering. We strive to make these advanced simulation techniques more accessible, enabling researchers and engineers to conduct more accurate and comprehensive scientific investigations. Through collaborative efforts, our mission is to deepen understanding, foster innovation, and contribute to the broader scientific community’s pursuit of knowledge in complex material behaviors.

Key Features

  • Phase-Field Method: The code employs the phase-field method, a versatile mathematical framework for modeling phenomena such as fracture, phase transitions, and pattern formation as diffuse processes. It enables the simulation of complex behaviors and multiple interacting phenomena within a unified framework.

  • FEniCSx Integration: Integrated with FEniCSx, a powerful finite element framework, the code provides robust capabilities for solving partial differential equations governing phase-field simulations. This integration ensures efficient computation and adaptive mesh refinement, enhancing simulation accuracy and scalability.

  • User-Friendly Interface: Designed with usability in mind, the code features an intuitive interface for defining material properties, boundary conditions, and simulation parameters. This interface caters to both novice users and experienced researchers, facilitating straightforward setup and execution of simulations.

  • Advanced Visualization: The code includes advanced visualization tools to depict simulation results effectively. These tools enable comprehensive analysis of crack propagation, stress distributions, and other key quantities, supporting insightful interpretations and comparisons across simulations.

Installation Instructions

To use this repository, you need to have the latest stable release of FEniCSx installed. The latest stable release of FEniCSx is version 0.9. The easiest way to start using FEniCSx on MacOS and other systems is to install it using conda.

Follow these steps to set up your environment:

  1. Create a new conda environment

    conda create -n phasefieldx-env
  2. Activate the new environment

    conda activate phasefieldx-env
  3. Install FEniCSx, mpi4py, numpy, pandas, … from the conda-forge channel:

    conda install -c conda-forge fenics-dolfinx=0.10.0 scifem mpi4py numpy pyvista pandas pyvista
  4. Install gmsh

    pip install --upgrade gmsh
  5. Finally, install the code from this repository

    pip install phasefieldx

These steps will set up all the necessary dependencies for running the code in this repository. Make sure to activate the phasefieldx-env environment whenever you work with this project.

For more detailed installation options and information, please visit the FEniCSx Project download page.

We also provide a pre-built docker image with FEniCSx and phasefieldx installed. You pull this image using the command

docker pull ghcr.io/castillonmiguel/phasefieldx:main

Examples

There are numerous examples available to demonstrate the usage of PhaseFieldX for various phase-field simulations. These examples cover different scenarios such as phase-field fracture, phase-field fatigue, and more complex material behavior simulations. Explore the examples in the documentation to learn more.

API Documentation

For detailed API documentation, including class references, function definitions, and usage examples, please refer to the API documentation.

You can also explore the project on DeepWiki — an AI-powered, interactive knowledge base built from the code and documentation: Explore PhaseFieldX on DeepWiki

Contributions and Feedback

We welcome contributions and feedback from the community to enhance the code’s functionality, reliability, and user experience.To get started, please review our Contributing Guidelines to share your insights and collaborate with fellow developers.

Thank you for choosing our Phase-Field Fracture simulation code. We trust this tool will prove invaluable in advancing your understanding of fracture mechanics and its practical applications.

Citing PhaseFieldX

There is a paper about PhaseFieldX.

If you use PhaseFieldX in your scientific research, please consider citing our work to support its development and increase its scientific visibility.

Castillón, M. (2025). PhaseFieldX: An Open-Source Framework for Advanced Phase-Field Simulations. Journal of Open Source Software, 10(108), 7307, https://doi.org/10.21105/joss.07307

BibTex:

@article{Castillon2025phasefieldx,
  doi = {10.21105/joss.07307},
  url = {https://doi.org/10.21105/joss.07307},
  year = {2025},
  publisher = {The Open Journal},
  volume = {10},
  number = {108},
  pages = {7307},
  author = {Miguel Castillón},
  title = {PhaseFieldX: An Open-Source Framework for Advanced Phase-Field Simulations},
  journal = {Journal of Open Source Software}
}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

phasefieldx-0.3.0.tar.gz (59.7 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

phasefieldx-0.3.0-py3-none-any.whl (86.3 kB view details)

Uploaded Python 3

File details

Details for the file phasefieldx-0.3.0.tar.gz.

File metadata

  • Download URL: phasefieldx-0.3.0.tar.gz
  • Upload date:
  • Size: 59.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for phasefieldx-0.3.0.tar.gz
Algorithm Hash digest
SHA256 5645d7286d5f24352d6db3b3336d77a43f6fca8e1491e160163a93c55aafc38c
MD5 4c6be2070a20e6ecd5b484c475b87dfc
BLAKE2b-256 6c4b868d4f0f71b01c8ecdadf38cf937ba63e79166a18a231e526214edc208b6

See more details on using hashes here.

Provenance

The following attestation bundles were made for phasefieldx-0.3.0.tar.gz:

Publisher: publish_pip_distribution.yml on CastillonMiguel/phasefieldx

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file phasefieldx-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: phasefieldx-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 86.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for phasefieldx-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8842fd20b7c80c9b670c6d5c7bccb923f5cde89ae297190be209f8aed96373fa
MD5 52dfb332f493bc2e4997a72f4d64195e
BLAKE2b-256 6ccc0dc00ed5874d7270e1aed9fc5c8f4724d5eaeace8f4c157b1b3161f6b05f

See more details on using hashes here.

Provenance

The following attestation bundles were made for phasefieldx-0.3.0-py3-none-any.whl:

Publisher: publish_pip_distribution.yml on CastillonMiguel/phasefieldx

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page