Skip to main content

Python SDK for SolarFarmer, a bankable solar PV design and energy yield assessment tool by DNV.

Project description

SolarFarmer Python SDK

PyPI version Python versions License CI Documentation

The official Python SDK for SolarFarmer, a bankable solar PV design and energy yield assessment software from DNV. This SDK provides a typed Python interface that simplifies calling SolarFarmer APIs: build payloads, run 2D and 3D energy calculations, and process results programmatically.

Key Features

  • Data models that mirror the API schema. Pydantic classes with field validation catch payload errors locally before the API call. Field descriptions and type hints improve discoverability.
  • Two plant-building paths. Full control via EnergyCalculationInputs and component classes, or quick screening via PVSystem from high-level specs (DC and AC capacities, tilt, GCR)
  • Structured results. CalculationResults gives direct access to annual/monthly metrics, loss trees, and time series without parsing raw JSON.
  • Automatic endpoint handling. One function call runs 2D or 3D calculations. The SDK selects the right endpoint, polls async jobs, and supports cancellation via terminate_calculation().

Requirements

  • Python >= 3.10 (tested on 3.10, 3.11, 3.12, 3.13)
  • A SolarFarmer API key (commercial licence required; see API Key)

Installation

Install from PyPI:

pip install dnv-solarfarmer

The package is imported as solarfarmer regardless of the distribution name:

import solarfarmer as sf

Install with optional extras:

pip install "dnv-solarfarmer[notebooks]"  # JupyterLab and notebook support
pip install "dnv-solarfarmer[all]"        # full installation including pandas and matplotlib

For development and documentation extras (managed as dependency groups, requires uv):

uv sync --group dev    # linting and testing tools (for contributors)
uv sync --group docs   # documentation build tools

Install from source:

git clone https://github.com/dnv-opensource/solarfarmer-python-sdk
cd solarfarmer-python-sdk
pip install -e .

API Key

A SolarFarmer API key is required to run energy calculations. Obtain one from the SolarFarmer portal. For setup instructions, see the API key documentation.

Set your key as an environment variable (recommended):

export SF_API_KEY="your_api_key_here"

Alternatively, pass it directly as the api_key parameter to any function that calls the API.

Configuration

Environment Variable Default Description
SF_API_KEY (none; required for calculations) API authentication token
SF_API_URL https://solarfarmer.dnv.com/latest/api Override the base API URL for custom deployments

Optional Dependencies

The core SDK (pydantic, requests, tabulate) does not depend on pandas. Install the all extra for DataFrame-based features:

pip install "dnv-solarfarmer[all]"

This unlocks sf.from_dataframe() and sf.from_pvlib() for writing weather files from DataFrames, and enables CalculationResults to parse timeseries outputs into DataFrames. Without pandas, those functions raise ImportError or return None. All other SDK features work without it.

Getting Started

The SDK supports three workflows for different use cases:

Workflow Best for Entry point
1. Load existing files Users with pre-built API payloads from the SolarFarmer desktop app or a previous export sf.run_energy_calculation(inputs_folder_path=...)
2. PVSystem builder Quick screening from high-level specs (capacity, tilt, equipment files). The design is approximate: string sizing and inverter count are inferred, so DC/AC capacity may not match the target exactly. plant = sf.PVSystem(...) then plant.run_energy_calculation()
3. Custom integration Developers mapping internal databases or proprietary formats to the SolarFarmer API params = sf.EnergyCalculationInputs(...) then sf.run_energy_calculation(plant_builder=params)

See the Getting Started guide for full per-workflow walkthroughs, and the example notebooks for runnable end-to-end examples.

Documentation

Full documentation (API reference, workflow guides, notebook tutorials):

https://dnv-opensource.github.io/solarfarmer-python-sdk/

To build and serve the documentation locally:

uv sync --group docs
zensical serve -o                          # build, serve, and open in browser (port 8000)
zensical serve -o -a localhost:8080        # use a different port

zensical serve builds the docs and starts a local server in one step. The -o flag opens the page automatically in your default browser.

Contributing

Fork the repository, create a branch, and submit a pull request to main. To set up a development environment:

git clone https://github.com/dnv-opensource/solarfarmer-python-sdk
cd solarfarmer-python-sdk
pip install -e .
uv sync --group dev
  • Linting and formatting: ruff check solarfarmer/ tests/ and ruff format solarfarmer/ tests/
  • Tests: pytest tests/ -v

All contributions should include tests for new functionality. For feature proposals or questions, contact solarfarmer@dnv.com. See CONTRIBUTING.md for full guidelines.

Getting Technical Support

License

Apache License, Version 2.0 — see LICENSE.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dnv_solarfarmer-0.2.0rc2.tar.gz (136.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

dnv_solarfarmer-0.2.0rc2-py3-none-any.whl (94.3 kB view details)

Uploaded Python 3

File details

Details for the file dnv_solarfarmer-0.2.0rc2.tar.gz.

File metadata

  • Download URL: dnv_solarfarmer-0.2.0rc2.tar.gz
  • Upload date:
  • Size: 136.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for dnv_solarfarmer-0.2.0rc2.tar.gz
Algorithm Hash digest
SHA256 5ed7b6c08c62cb386e5fc37861d21a31045962511599d0cd269acfe5d02f6f3b
MD5 747b17f55b2d526128df1afb949f54ab
BLAKE2b-256 5654da14c275a25fc95de190582593a6816b0245c371153794b445d23d6513f2

See more details on using hashes here.

Provenance

The following attestation bundles were made for dnv_solarfarmer-0.2.0rc2.tar.gz:

Publisher: release.yml on dnv-opensource/solarfarmer-python-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file dnv_solarfarmer-0.2.0rc2-py3-none-any.whl.

File metadata

File hashes

Hashes for dnv_solarfarmer-0.2.0rc2-py3-none-any.whl
Algorithm Hash digest
SHA256 24d774ba14a72a5049a166f61e14f6d82f5407b073bd962222ed699c8ea00a7a
MD5 85fde62a2cde43da4f92935158817fbf
BLAKE2b-256 36f380c38cbf8ca00e08926057ba508dba34c17854c9e5c02baa80807f006f41

See more details on using hashes here.

Provenance

The following attestation bundles were made for dnv_solarfarmer-0.2.0rc2-py3-none-any.whl:

Publisher: release.yml on dnv-opensource/solarfarmer-python-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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