Skip to main content

A Statistical Parameter Optimization Tool

Project description

Purpose

SPOTPY is a Python tool that enables the use of Computational optimization techniques for calibration, uncertainty and sensitivity analysis techniques of almost every (environmental-) model. The package is puplished in the open source journal PLoS One

Houska, T, Kraft, P, Chamorro-Chavez, A and Breuer, L; SPOTting Model Parameters Using a Ready-Made Python Package; PLoS ONE; 2015

The simplicity and flexibility enables the use and test of different algorithms without the need of complex codes:

sampler = spotpy.algorithms.sceua(model_setup())     # Initialize your model with a setup file
sampler.sample(10000)                                # Run the model
results = sampler.getdata()                          # Load the results
spotpy.analyser.plot_parametertrace(results)         # Show the results

Features

Complex algorithms bring complex tasks to link them with a model. We want to make this task as easy as possible. Some features you can use with the SPOTPY package are:

  • Fitting models to evaluation data with different algorithms. Available algorithms are:

    • Monte Carlo (MC)

    • Markov-Chain Monte-Carlo (MCMC)

    • Maximum Likelihood Estimation (MLE)

    • Latin-Hypercube Sampling (LHS)

    • Simulated Annealing (SA)

    • Shuffled Complex Evolution Algorithm (SCE-UA)

    • Differential Evolution Adaptive Metropolis Algorithm (DE-MCz)

    • RObust Parameter Estimation (ROPE).

    • Fourier Amplitude Sensitivity Test (FAST)

    • Artificial Bee Colony (ABC)

    • Fitness Scaled Chaotic Artificial Bee Colony (FSCABC)

  • Wide range of objective functions (also known as loss function, fitness function or energy function) to validate the sampled results. Available functions are

    • Bias

    • PBias

    • Nash-Sutcliff (NSE)

    • logarithmic Nash-Sutcliff (logNSE)

    • logarithmic probability (logp)

    • Correlation Coefficient (r)

    • Coefficient of Determination (r^2)

    • Mean Squared Error (MSE)

    • Root Mean Squared Error (RMSE)

    • Mean Absolute Error (MAE)

    • Relative Root Mean Squared Error (RRMSE)

    • Agreement Index (AI)

    • Covariance, Decomposed MSE (dMSE)

    • Kling-Gupta Efficiency (KGE).

  • Prebuild parameter distribution functions:

    • Uniform

    • Normal

    • logNormal

    • Chisquare

    • Exponential

    • Gamma

    • Wald

    • Weilbull

  • Wide range to adapt algorithms to perform uncertainty-, sensitivity analysis or calibration of a model.

  • Multi-objective support

  • MPI support for fast parallel computing

  • A progress bar monitoring the sampling loops. Enables you to plan your coffee brakes.

  • Use of NumPy functions as often as possible. This makes your coffee brakes short.

  • Different databases solutions: ram storage for fast sampling a simple , csv tables the save solution for long duration samplings.

  • Automatic best run selecting and plotting

  • Parameter trace plotting

  • Parameter interaction plot including the Gaussian-kde function

  • Regression analysis between simulation and evaluation data

  • Posterior distribution plot

  • Convergence diagnostics with Gelman-Rubin and the Geweke plot

Install

Installing SPOTPY is easy. Just use:

pip install spotpy

Or, after downloading the source code and making sure python is in your path:

python setup.py install

Support

  • Feel free to contact the authors of this tool for any support questions.

  • Please contact the authors in case of any bug.

  • If you use this package for a scientific research paper, please cite SPOTPY.

  • Patches/enhancements and any other contributions to this package are very welcome!

  • GitHub: https://github.com/thouska/spotpy

Version 1.1.0

  • Changed likelihood to objectivefunction. Checkout new example spotpy_setup files.

Version 1.1.1

  • Minor bugfixes

Version 1.1.2

  • Minor bugfixes

Version 1.1.3

  • Minor bugfixes

Version 1.1.4

Version 1.2.0

  • Added Python 3 support

Version 1.2.1

Version 1.2.2

  • Minor bugfix in Monte Carlo sampler

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 Distribution

spotpy-1.2.29.zip (80.8 kB view details)

Uploaded Source

Built Distributions

spotpy-1.2.29.win32.exe (273.2 kB view details)

Uploaded Source

spotpy-1.2.29-py2-none-any.whl (78.3 kB view details)

Uploaded Python 2

File details

Details for the file spotpy-1.2.29.zip.

File metadata

  • Download URL: spotpy-1.2.29.zip
  • Upload date:
  • Size: 80.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for spotpy-1.2.29.zip
Algorithm Hash digest
SHA256 a773f9e014899f6861df97639dbad40f66433183a395bf065ee252ccd88ff633
MD5 adafce0539d23cdadfaef7ef4d430a82
BLAKE2b-256 1d49481e05f91cce68b70f6d1d5ab4fd61ff84ccb00a664723d4a60ef1a620dd

See more details on using hashes here.

File details

Details for the file spotpy-1.2.29.win32.exe.

File metadata

  • Download URL: spotpy-1.2.29.win32.exe
  • Upload date:
  • Size: 273.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for spotpy-1.2.29.win32.exe
Algorithm Hash digest
SHA256 b2b41dbc35dc5be6c865e2ddf046292eb7ad2bcc5d081b5a6b8144398f1aae2a
MD5 c8965bd3a9e9faeb326ce8195fbba7c5
BLAKE2b-256 0bd56f2fe720d56c243214aae8db3d0c471d32b115ec629b3b008b9d496dbe74

See more details on using hashes here.

File details

Details for the file spotpy-1.2.29-py2-none-any.whl.

File metadata

File hashes

Hashes for spotpy-1.2.29-py2-none-any.whl
Algorithm Hash digest
SHA256 aa21e0d83aa42143c08bb6be4d6e079db5c9ee8f6bd6ad1b55a8f3f51b17aa21
MD5 8e1dd09f5d3b3511312080faa947694e
BLAKE2b-256 83cd5491536f684efc92dd1a450ff78276fee72e13495a3139230dbe33f4a10f

See more details on using hashes here.

Supported by

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