No project description provided
Project description
f2py-jit
Just-in-time compilation of Fortran code in Python via f2py.
Documentation
Quick start
Start from a piece of Fortran code.f90
subroutine hello()
print*, "Hello world!"
end subroutine
Compile the code, import it and execute it
from f2py_jit import jit
f90 = jit('code.f90')
f90.hello()
Do the same but from a python string containing the source block
source = """
subroutine hello()
print*, "Hello world!"
end subroutine
"""
f90 = jit(source)
f90.hello()
If the Fortran source contains multiple subroutines calling each other, f2py
will not perform interprocedural optimizations (at least not by default). f2py_jit
can inline the source code before compiling it, and you will get a performace boost [This feature is experimental]
f90 = jit('code.f90', inline=True)
Features
- Compilation of source blocks as python strings
- Caching of module builds across executions
- Optional inlining to improve performance (experimental)
Dependencies
- numpy
- Fortran compiler
Installation
From pip
pip install f2py-jit
From source
git clone https://framagit.org/coslo/f2py-jit.git
cd f2py_jit
make install
Credits
Part of this code is adapted from numpy.f2py
module by Pearu Peterson, in accordance with the NumPy license.
Authors
Daniele Coslovich: https://www.units.it/daniele.coslovich/
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 Distributions
Built Distribution
Hashes for f2py_jit-0.8.0-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6a58dd48ee7803503421cabcdf35679941c4b11fc9a4a9094178e85de86c3e5a |
|
MD5 | b70bfd3318f765617a529bbde105cd5b |
|
BLAKE2b-256 | 2fdbf8b80007bdb1aba4ccdbc9b9ab61664a605441b791641a46817a236fd0bb |