Deep convolutional generative adversarial network for generation of computed tomography images of discontinuously carbon fiber reinforced polymer microstructures
Steffen Klinder1 and Juliane Blarr1*
1*Institute for Applied Materials – Materials Science and Engineering, Karlsruhe Institute of Technology (KIT), Kaiserstraße 12, Karlsruhe, 76131, Baden-Württemberg, Germany.*Corresponding author. E-mail: juliane.blarr@kit.edu;
Contributing author: steffen.klinder@student.kit.edu;
Correspondence and requests for materials should be addressed to Juliane Blarr.
Note
This is the accompanying repository to the paper "Deep convolutional generative adversarial network for generation of computed tomography images of discontinuously carbon fiber reinforced polymer microstructures" by Blarr et al., published in Nature Scientific Reports in 2024. The work is based on the data set "2D images of CT scans of carbon fiber reinforced polyamide 6", made available in 2023, which can be accessed separately. See Overview for more information.
- Overview
- How to run the code
- Sources and inspiration
- Software and versions
- Hardware
- License and citation
- Acknowledgments
If you use the code in this repository and the associated data set, please cite both DOIs (see License and citation).
More information on theory, methods and results can be found in the accompanying paper by Blarr et al. (Nature Scientific Reports 2024):
- Deep convolutional generative adversarial network for generation of computed tomography images of discontinuously carbon fiber reinforced polymer microstructures (DOI: 10.1038/s41598-024-59252-8)
The data set used for this work was published separately:
- 2D images of CT scans of carbon fiber reinforced polyamide 6 (DOI: 10.35097/1822)
More information on the data set
The dataset includes a total of 29.280 2D images taken from 3D µCT scans of carbon fiber reinforced polyamide 6. Those images were used to train the neural network presented in this repository.
The data set can be downloaded as *.tar file from the source linked above and is licensed under a Creative Commons Attribution 4.0 International License. The actual image folder is located in the subdirectory data/dataset/ as a *.7z file. In the following, a number of exemplary images are depicted.
Those images are named as follows, e.g.:
C1_1_1024to256_IA_offset128_median5_bl128x_30.jpg
with:
- C1: Location on the initial plaque from which the specimen was extracted
- 1: Number of the plaque (either 1 or 2)
- 1024to256: An image section of resolution 1024 px × 1024 px was resized to 256 px × 256 px
- IA: The cv2 INTER_AREA interpolation operation was used for resizing
- offset128: The cutout sections where taken with an offset of ±128 px from the center in x and y direction
- median5: Images smoothing with a median kernel of size 5 px × 5 px was applied
- bl128: Direction of cutout offset (e.g. bl ≙ bottom left) and offset in px (duplicate)
- x: Type of image augmentation, in this case mirroring on the x-axis
- 30: Number of the initial layer the image is taken from (starting from 0)
Simply execute the given Python or Jupyter notebook file. Note that the *.py file was run using SLURM job manager, you therefore might need to comment the lines waiting for command line input. Training parameters can be adjusted beforehand inside the file itself. Note that the network model is defined within this code for now.
The JupyterLab environment was used to test and develope new models and to debug existing code segments. Note that the actual models of the network used are defined inside the models_*.py files.
In the following an exemplary file structure for running the *.py files is depicted:
├── project_folder
│ ├── files
| ├── microDCGAN.py
| ├── job.sh
| ├── log_*.log
| └── ...
│ └── data
| ├── input
| └── 256x256
| ├── real_1.jpg
| ├── real_2.jpg
| ├── real_3.jpg
| └── ...
| └── output
| └── 256x256
| ├── fake_1.jpg
| ├── fake_2.jpg
| ├── fake_3.jpg
| └── ...
Take a look at the presented paper for an overview of the used training parameters.
-
The DCGAN tutorial by Nathan Inkawhich is provided on the official PyTorch website and served as a starting point for this project. The code can be accessed from this GitHub repository as well.
-
This Jupyter Notebook by Milad Hasani can be viewed on Kaggle and contains a DCGAN for generation of X-ray images of the human chest. The project is based on a random sample of the NIH Chest X-ray Dataset with a resolution of 128 px × 128 px. However, the general structure of generator and discriminator network was found to work well for even larger resolutions. Note that the original code was released under the Apache 2.0 open source license. Used code sequences were adjusted accordingly and are clearly marked as such in the provided *.py respectively *.ipynb file.
This project is entirely written in Python programming language using both native *.py files and Jupyter notebooks (*.ipynb). The latter were used for initial tests with smaller image resolutions as well as for debugging. The *.ipynb file was then converted into native Python code.
The following libraries are needed to run the *.py file in Python 3.6.8:
- PyTorch 1.10.1
- Torchvision 0.11.2
- Numpy 1.19.5
- OpenCV cv2 4.7.0.72
- Matplotlib 3.3.4
- TorchMetrics 0.8.2
- Torchinfo 1.5.4
The *.ipynb file was tested with Python 3.9.7 and uses the following additional libraries as well:
Note that some code snippets from the Jupyter Notebook are incompatible with the older Python version!
In order to train the models, four NVIDIA Tesla V100 GPUs with 32 GB accelerator memory each as well as two Intel Xeon Gold 6230 processors with a total of 40 cores at a processor frequency of 2.1 GHz were used. The final configuration described in the corresponding paper required 25.36 GB of RAM. Please note that SSIM values were calculated subsequently because of their high computational cost. However, no GPU power was used for this step yet.
This work is licensed under a Creative Commons Attribution 4.0 International License.
Please cite the associated paper if you used code from this repository or your work was inspired by it.
BibTex:
@article{Blarr2024,
title={Deep convolutional generative adversarial network for generation of computed tomography images of discontinuously carbon fiber reinforced polymer microstructures},
author={Blarr, Juliane; Klinder, Steffen; Liebig, Wilfried V.; Inal, Kaan; K{\"a}rger, Luise; Weidenmann, Kay A.},
journal={Scientific Reports},
volume={14},
number={1},
pages={9641}
year={2024},
doi = {10.1038/s41598-024-59252-8}
}
In case you also chose to use the associated data set in your work, please do cite it as well:
BibTex:
@misc{Blarr2023,
title = {{2D} images of {CT} scans of carbon fiber reinforced polyamide 6},
author = {Blarr, Juliane and Klinder, Steffen},
publisher = {Karlsruhe Institute of Technology},
year = {2023},
doi = {10.35097/1822}
}
The research documented in the corresponding manuscript has been funded by the Deutsche Forschungsgemeinschaft (DFG, German Research Foundation), project number 255730231, within the International Research Training Group “Integrated engineering of continuous-discontinuous long fiber reinforced polymer structures“ (GRK 2078). The support by the German Research Foundation (DFG) is gratefully acknowledged. The authors would also like to thank the Fraunhofer ICT for its support in providing the plaques produced in the LFT-D process under the project management of Christoph Schelleis. Support from Covestro Deutschland AG, as well as Johns Manville Europe GmbH in the form of trial materials is gratefully acknowledged. This work was performed on the computational resource bwUniCluster funded by the Ministry of Science, Research and the Arts Baden-Württemberg and the Universities of the State of Baden-Württemberg, Germany, within the framework program bwHPC.