Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/szaghi/vtkfortran
pure Fortran VTK (XML) API
https://github.com/szaghi/vtkfortran
fortran oop vtk
Last synced: 3 days ago
JSON representation
pure Fortran VTK (XML) API
- Host: GitHub
- URL: https://github.com/szaghi/vtkfortran
- Owner: szaghi
- Created: 2012-04-20T07:15:46.000Z (almost 13 years ago)
- Default Branch: master
- Last Pushed: 2022-10-19T06:55:33.000Z (over 2 years ago)
- Last Synced: 2024-06-21T18:04:09.352Z (8 months ago)
- Topics: fortran, oop, vtk
- Language: Fortran
- Homepage:
- Size: 78.5 MB
- Stars: 137
- Watchers: 22
- Forks: 49
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.bsd-2.md
Awesome Lists containing this project
README
# VTKFortran [data:image/s3,"s3://crabby-images/f1778/f1778f3ab28e095aa595f31bd08411ea493c4a6d" alt="GitHub tag"](https://github.com/szaghi/VTKFortran/releases)
[data:image/s3,"s3://crabby-images/55d7b/55d7baa2b87b297b8fc1aec61f3df1ba76ba0e45" alt="Join the chat at https://gitter.im/szaghi/VTKFortran"](https://gitter.im/szaghi/VTKFortran?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
[data:image/s3,"s3://crabby-images/41dd0/41dd087af56f73b900804b3b2909f1c25806cddc" alt="License"]()
[data:image/s3,"s3://crabby-images/e3741/e3741b64f2459d0662b2f88fd0174e1952db59e3" alt="License"]()
[data:image/s3,"s3://crabby-images/415ef/415ef280dddbfe96b7b657f0010309f40b55f4db" alt="License"]()
[data:image/s3,"s3://crabby-images/cda94/cda94ceb589b7fe6d1fefd2e6e2d7d84edaaa9c0" alt="License"]()[data:image/s3,"s3://crabby-images/b0208/b0208f12dca3475d84281daf33fe605c00d6a92b" alt="Status"]()
[data:image/s3,"s3://crabby-images/77a9c/77a9c1396fee9a6c6389415025b8290c0a6869fd" alt="CI Status"](https://github.com/szaghi/VTKFortran/actions)
[data:image/s3,"s3://crabby-images/c612e/c612e5acbc51fe617ea6fdf2337322afb4187fa3" alt="Coverage Status"](https://app.codecov.io/gh/szaghi/VTKFortran)### VTKFortran, pure Fortran VTK (XML) API
A KISS pure Fortran Library to parse and emit files conforming VTK (XML) standard
+ VTKFortran is a pure Fortran library to parse and emit VTK files, [VTK standard](http://www.vtk.org/);
+ VTKFortran is Fortran 2003+ standard compliant;
+ VTKFortran supports parallel architectures, it being threads-safe;
+ VTKFortran supports _ascii_, _binary_ (Base64 encoding) and _raw_ file formats;
+ VTKFortran is a Free, Open Source Project.#### Issues
[data:image/s3,"s3://crabby-images/b6a7b/b6a7b9db91cd70c0c7b72a91af217264aad8e246" alt="GitHub issues"]()
#### Compiler Support
[data:image/s3,"s3://crabby-images/762e1/762e1022fc367aa94ff37fb2231faf08aa5459de" alt="Compiler"-brightgreen.svg)]()
[data:image/s3,"s3://crabby-images/50257/50257d27a7e09fb896c255592ca1832149be72d0" alt="Compiler"-brightgreen.svg)]()
[data:image/s3,"s3://crabby-images/5c270/5c27041f133f02af190a384b1ca4d3437f058fe7" alt="Compiler"]()
[data:image/s3,"s3://crabby-images/03d34/03d34b76bece6e1a552ffd73c1bc0d1d53fdab93" alt="Compiler"]()
[data:image/s3,"s3://crabby-images/fb26c/fb26c67f6a6520637ceab4e8316e8175ad389f15" alt="Compiler"]()
[data:image/s3,"s3://crabby-images/76a2b/76a2bb4ff9a0dd6e1c2f3e60bf9166c9e9e0d494" alt="Compiler"]()---
[Main features](#main-features) | [Copyrights](#copyrights) | [Documentation](#documentation) | [A Taste of VTKFortran](#a-taste-of-vtkfortran)
---
## Main features
### VTK features
#### Exporters
##### Legacy standard
* [x] Structured Points;
* [x] Structured Grid;
* [x] Unstructured Grid;
* [ ] Polydata;
* [x] Rectilinear Grid;
* [ ] Field;##### XML standard
* [ ] serial dataset:
* [ ] Image Data;
* [ ] Polydata;
* [x] Rectilinear Grid;
* [x] Structured Grid;
* [x] Unstructured Grid;
* [ ] parallel (partitioned) dataset:
* [ ] Image Data;
* [ ] Polydata;
* [x] Rectilinear Grid;
* [x] Structured Grid;
* [x] Unstructured Grid;
* [x] composite dataset:
* [x] vtkMultiBlockDataSet.#### Importers
The importers are under developing.### Parallel Support
VTKFortran can be safely used in parallel *environments*, handling multiple concurrent files: it is **thread/processor-safe**, meaning that it can be safely used into parallel architectures using OpenMP and/or MPI paradigms.
## Copyrights
VTKFortran is an open source project, it is distributed under a multi-licensing system:
+ for FOSS projects:
- [GPL v3](http://www.gnu.org/licenses/gpl-3.0.html);
+ for closed source/commercial projects:
- [BSD 2-Clause](http://opensource.org/licenses/BSD-2-Clause);
- [BSD 3-Clause](http://opensource.org/licenses/BSD-3-Clause);
- [MIT](http://opensource.org/licenses/MIT).Anyone is interest to use, to develop or to contribute to VTKFortran is welcome, feel free to select the license that best matches your soul!
More details can be found on [wiki](https://github.com/szaghi/VTKFortran/wiki/Copyrights).
Go to [Top](#top)
## Documentation
Besides this README file the VTKFortran documentation is contained into its own [wiki](https://github.com/szaghi/VTKFortran/wiki). Detailed documentation of the API is contained into the [GitHub Pages](http://szaghi.github.io/VTKFortran/index.html) that can also be created locally by means of [ford tool](https://github.com/cmacmackin/ford).
Go to [Top](#top)
### A taste of VTKFortran
Let us assume our aim being to save our pure Fortran data into a VTK structured grid file in binary XML form. This is simple as
```fortran
use vtk_fortran, only : vtk_filetype(vtk_file) :: a_vtk_file ! A VTK file.
integer, parameter :: nx1=0_I4P ! X lower bound extent.
integer, parameter :: nx2=9_I4P ! X upper bound extent.
integer, parameter :: ny1=0_I4P ! Y lower bound extent.
integer, parameter :: ny2=5_I4P ! Y upper bound extent.
integer, parameter :: nz1=0_I4P ! Z lower bound extent.
integer, parameter :: nz2=5_I4P ! Z upper bound extent.
integer, parameter :: nn=(nx2-nx1+1)*(ny2-ny1+1)*(nz2-nz1+1) ! Number of elements.
real :: x(nx1:nx2,ny1:ny2,nz1:nz2) ! X coordinates.
real :: y(nx1:nx2,ny1:ny2,nz1:nz2) ! Y coordinates.
real :: z(nx1:nx2,ny1:ny2,nz1:nz2) ! Z coordinates.
real :: v(nx1:nx2,ny1:ny2,nz1:nz2) ! Variable at coordinates.
integer :: error ! Error status.! initialize the data...
error = a_vtk_file%initialize(format='binary', filename='XML_STRG-binary.vts', &
mesh_topology='StructuredGrid', &
nx1=nx1, nx2=nx2, ny1=ny1, ny2=ny2, nz1=nz1, nz2=nz2)
error = a_vtk_file%xml_writer%write_piece(nx1=nx1, nx2=nx2, ny1=ny1, ny2=ny2, nz1=nz1, nz2=nz2)
error = a_vtk_file%xml_writer%write_geo(n=nn, x=x, y=y, z=z)
error = a_vtk_file%xml_writer%write_dataarray(location='node', action='open')
error = a_vtk_file%xml_writer%write_dataarray(data_name='float64_scalar', x=v, one_component=.true.)
error = a_vtk_file%xml_writer%write_dataarray(location='node', action='close')
error = a_vtk_file%xml_writer%write_piece()
error = a_vtk_file%finalize()
```Note that all VTKFortran functions return an error code that can be used for sophisticated error trapping algorithms.