Git Product home page Git Product logo

qcmplab / scifortran Goto Github PK

View Code? Open in Web Editor NEW

This project forked from aamaricci/scifortran

2.0 0.0 1.0 75.36 MB

A library of fortran modules and routines for scientific calculations (*in a way* just like scipy for python)

Home Page: https://QcmPlab.github.io/SciFortran

License: GNU Lesser General Public License v3.0

Shell 0.02% C 0.02% Fortran 99.30% TeX 0.33% Makefile 0.05% CMake 0.28%

scifortran's Introduction

SciFortran

Ubuntu MacOS api docs

This is a unitary collection of fortran modules and procedures for scientific calculations. The library aims to provide a simple and generic environment for any scientific or mathematic computations. The project is largely inspired by SciPy for Python and tries to closely follow its guidelines and naming convention.

There are large areas that are still not covered.
Anyone is welcome to contribute or to test the software.

Dependencies

If any of the required libraries is not available in your system, or the version requirement is not satisfied, please install/upgrade them. We generally advice for pre-packaged versions, as provided by either apt, pip, brew, conda or spack. The latter may provide the best options for HPC environments (trivial installation without sudo, easy management of interdependent multiple versions, automatic generation of environment modules, etc.), but choose freely according to your needs.

BUILD

Our build system relies on CMake. Experimental support for linking Intel's MKL is provided, although it may fail on some systems.

Clone the SciFortran repo:

git clone https://github.com/aamaricci/SciFortran scifor

Optionally2 define the fortran compiler:

export FC=mpif90 # or gfortran or ifort if you don't need MPI

From the repository directory (cd scifor) make a standard out-of-source CMake compilation:

Using make (click to expand) Default CMake workflow, with widest version support (CMake > 3.0).
mkdir build 
cd build  
cmake .. 
make
Using ninja (click to expand)

If a fortran-capable3 version of ninja ( https://ninja-build.org ) is available in your system (and CMake can4 take advantage of it), you can use it to build the library at lightning, multi-threaded, speed.

mkdir build    
cd build  
cmake -GNinja ..  
ninja

In both cases you can pass additional options to the cmake command, to customize the build (default values between < >):

  • -DPREFIX=prefix/directory <~/opt/scifor>, to specify a custom installation directory

  • -DUSE_MPI=<yes>/no, to (de)activate MPI support

  • -DVERBOSE=yes/<no>, to generate verbose makefiles

  • -DBUILD_TYPE=<RELEASE>/TESTING/DEBUG, to select predefined compiler options

  • -DWITH_BLAS_LAPACK=yes/<no>, to skip search of preinstalled linear algebra libraries and enforce compilation from source

  • -DWITH_SCALAPACK=<yes>/no, to link with preinstalled ScaLAPACK library, for parallel algebra support.

INSTALL

System-wide installation is completed after the build step using either:

make install

or

ninja install

To actually link the library we provide some alternatives:

  • A generated pkg-config file to, installed to ~/.pkgconfig.d/scifor.pc
  • A generated environment module, installed to ~/.modules.d/scifor/<PLAT>/<VERSION>
  • A generated bash script at <PREFIX>/bin/configvars.sh, to be sourced for permanent loading.

which you can choose among by following the instructions printed on screen.

UNINSTALL

CMake does not officially provide uninstall procedures in the generated Make/Ninja files. Hence SciFortran supplies a homebrew method to remove the generated files by calling (from the relevant build folder): make uninstall / ninja uninstall.

DOCUMENTATION

The repository is configured for source-based, automated, API docs generation via FORD, so that you can build the html files for your specific local version by running

ford docs.config

at the root directory of the project. Alternatively you can examine the official docs for the latest commit on master, as generated by our continuous deployment workflow.

KNOWN PROBLEMS

SciFortran has been tested with success on several Unix/Linux platforms. Support for Windows, through WSL, is still experimental, although few people reported successful installation with minimal efforts.

Some have reported issues concerning the wrong setup for the library pkg-config file, contained in $PREFIX/<PLAT>/<VERSION>/etc/scifor.pc. The variable Libs=-L${libdir} -lscifor <blas/lapack/scalapack> produced by cmake during the configuration and installation process can be not properly defined for the part corresponding to third parties libraries such as Blas/Lapack/Scalapack. This breaks compilation against scifor whenever pkg-config is used to generate the linking options.

FIX: edit the scifor.pc file manually, overwriting the definition of the variable Libs, as appropriate for your system.

CONTACT

If you encounter bugs or difficulties, please file an issue. For any other communication, please reach out to:
adriano DOT amaricci @ gmail DOT com

--

LICENSE
Copyright (C) Adriano Amaricci, Lorenzo Crippa, Gabriele Bellomia, Giacomo Mazza, Samuele Giuli, Massimo Capone

This program is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License (LGPL) as published by the Free Software Foundation, either version 3 of the License, or any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU LGPL for more details.

You should have received a copy of the GNU LGPL along with this program. If not, see http://www.gnu.org/licenses/.

Footnotes

  1. Should Lapack/Blas not be available in your system, SciFortran will compile internal copies of such libraries. This option, however, in most cases leads to noticeable performance degradation, with respect to optimized versions of the same libraries, such as Intel's MKL, Apple's vecLib, OpenBLAS, etc. Support for linking MKL is offered via a custom CMake macro, which should however be considered in beta development, as it is not universal and may end up in wrong linking directives. Apple's vecLib is instead automatically recognized by CMake, in any standard macOS system.

  2. In some cases CMake fails to find the MPI fortran compiler, even if it is effectively installed and loaded into the system. An easy fix is to setup and export the FC=mpif90 environment variable before invoking the cmake <options> .. command.

  3. Ninja did not support fortran before version 1.10, although Kitware has long mantained a fortran-capable fork, which might be obtained easily as a Spack package. Nevertheless we note that as of fall 2022 pip install ninja --user ships Ninja v1.10.2, hence obtaining a suitable official Ninja release should be trivial.

  4. This depends on your CMake version. Comparing this to this would suggest that CMake started supporting Ninja's fortran features only after v3.17 but we have verified that at least v3.16.3 (current version shipped by apt on Ubuntu 20.04 LTS) does indeed work. For more information you can take a look to the related issue.

scifortran's People

Contributors

aamaricci avatar band-a-prend avatar beddalumia avatar lcrippa avatar samuelegiuli avatar

Stargazers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.