# RAFT - Response Amplitudes of Floating Turbines
RAFT is a Python code for frequency-domain analysis of floating wind turbines. It constitutes the "Level 1" of modeling fidelity in the [WEIS](https://weis.readthedocs.io/en/latest/index.html) toolset for floating wind turbine controls co-design. RAFT provides frequency-domain modeling of full floating wind turbine systems including turbine aerodynamics, controls, rigid-body platform hydrodynamics, and mooring response. The rotor aerodynamics are provided by [CCBlade](https://github.com/WISDEM/CCBlade) and the mooring system is represented by NREL's new quasi-static mooring system model, [MoorPy](https://github.com/NREL/MoorPy). Potential-flow hydrodynamics can optionally be used via [pyHAMS](https://github.com/WISDEM/pyHAMS), a Python wrapper of the HAMS (Hydrodynamic Analysis of Marine Structures) tool for boundary-element-method solution of the potential flow problem developed by [Yingyi Liu](https://github.com/YingyiLiu/HAMS).
RAFT v1.0.0 includes the capabilities described above, and further development is planned to expand these capabilities. Documentation and verification efforts are ongoing. Please see [RAFT's documentation](https://openraft.readthedocs.io/en/latest/) for more information.
## Best Practices for Using `conda`
Installation with [Anaconda](https://www.anaconda.com) is the recommended approach because of the ability to create self-contained environments suitable for testing and analysis. RAFT requires [Anaconda 64-bit](https://www.anaconda.com/distribution/). However, the `conda` command has begun to show its age and we now recommend the one-for-one replacement with the [Miniforge3 distribution](https://github.com/conda-forge/miniforge?tab=readme-ov-file#miniforge3), which is much more lightweight and more easily solves for the RAFT package dependencies.
## Using RAFT as a Library
If you would like to use RAFT as a library, without direct interaction with the source code, then you can install it directly via `conda install raft` (preferred) or `pip install raft`.
## Getting Started
New users of RAFT as a standalone model are recommended to begin by looking at the input file and script provided in the examples folder, and seeking further information from the [RAFT documentation](https://openraft.readthedocs.io/en/latest/). For use as part of the WEIS toolset, information will be provided once this capability is completed in the [WEIS documentation](https://weis.readthedocs.io/en/latest/). For now, the following will help get started with running RAFT as a standalone model.
RAFT uses a number of prerequisites, or other python package dependencies, to run its calculations. All of the prerequisites can be installed through the `conda` package manager, but power users may wish to install all of the NREL packages from source for customization and debugging. Notable dependencies are:
- Python 3
- NumPy
- Matplotlib
- SciPy
- YAML
- [MoorPy](https://github.com/NREL/MoorPy)
- [pyHams](https://github.com/WISDEM/pyHAMS)
- [CCBlade](https://github.com/WISDEM/CCBlade) or [WISDEM](https://github.com/WISDEM/WISDEM)*
\* CCBlade is a module of WISDEM, but can be used separately. RAFT only requires CCBlade (and some additional related functions) out of the larger WISDEM code. Power users installing from source can install either CCBlade or WISDEM, but for highest efficiency, we recommend installing CCBlade, without the entire WISDEM installation.
Note that conda is required for the following installations.
## Installing All Dependencies with `conda`
To install all required python packages to run RAFT using `conda`, follow the steps below.
1. Navigate to a directory of your choosing on your local machine and clone this RAFT repository to that new directory (if you don't have the `git` command, start with `conda install git` in your "base" environment).
(base) YOUR_PATH> git clone https://github.com/WISDEM/RAFT.git
(base) YOUR_PATH> cd RAFT
This will create new folder called "RAFT" that is a copy from the GitHub repository, located in your "YOUR_PATH" directory
2. Create a new python virtual environment based on the "environment.yml" file, which lists all the packages needed to run RAFT
(base) YOUR_PATH/RAFT> conda env create --name raft-env -f environment.yml
This will create a new python virtual environment called "raft-env"
3. Activate the new virtual environment
(base) ANY_PATH> conda activate raft-env
This will activate the newly created virtual environment, in which we will install the remaining dependencies. After install is complete, when opening a new conda terminal that starts in the "base" environment, you can start with this "raft-env" activation command.
4. Install the RAFT package into the virtual environment
(raft-env) YOUR_PATH/RAFT> pip install -e .
This installs RAFT and all of its modules directly from your working directory in "editable" mode, meaning, if you save a change to your source code in the files in "YOUR_PATH/RAFT", future calls to RAFT modules will include those changes.
5. Test the installation
(raft-env) YOUR_PATH/RAFT> pytest
Running pytest should ensure everything was installed correctly
## Installing NREL Dependencies from Source
To install all external python packages using `conda` and NREL packages from source, follow the steps below. Since the NREL dependencies are also under development, this may also help resolve issues if one code gets out-of-sync with the others.
1. Navigate to a directory of your choosing on your local machine and clone this RAFT repository to that new directory (if you don't have the `git` command, start with `conda install git` in your "base" environment.
(base) YOUR_PATH> git clone https://github.com/WISDEM/RAFT.git
(base) YOUR_PATH> cd RAFT
This will create new folder called "RAFT" that is a copy from the GitHub repository, located in your "YOUR_PATH" directory
2. Create a new python virtual environment based on the "environment-source.yml" file, which lists all the packages needed to run RAFT
(base) YOUR_PATH/RAFT> conda env create --name raft-env -f environment-source.yml
This will create a new python virtual environment called "raft-env"
3. Activate the new virtual environment
(base) ANY_PATH> conda activate raft-env
This will activate the newly created virtual environment, in which we will install the remaining dependencies. After install is complete, when opening a new conda terminal that starts in the "base" environment, you can start with this "raft-env" activation command.
4. Install the necessary compilers and build tools for your system
(raft-env) YOUR_PATH/RAFT> cd ..
(raft-env) YOUR_PATH> pip install meson-python meson ninja cmake
(raft-env) YOUR_PATH> conda install gfortran (Mac / Linux)
(raft-env) YOUR_PATH> conda install m2w64-toolchain libpython (Windows)
5. Install the NREL packages from source one at a time.
(raft-env) YOUR_PATH> git clone https://github.com/WISDEM/CCBlade.git
(raft-env) YOUR_PATH> git clone https://github.com/NREL/MoorPy.git
(raft-env) YOUR_PATH> git clone https://github.com/WISDEM/pyHAMS.git
(raft-env) YOUR_PATH> cd MoorPy
(raft-env) YOUR_PATH/MoorPy> pip install -e .
(raft-env) YOUR_PATH/MoorPy> cd ..
(raft-env) YOUR_PATH> cd CCBlade
(raft-env) YOUR_PATH/CCBlade> pip install -e .
(raft-env) YOUR_PATH/CCBlade> cd ..
(raft-env) YOUR_PATH> cd pyHAMS
(raft-env) YOUR_PATH/pyHAMS> pip install --no-build-isolation -e .
(raft-env) YOUR_PATH/pyHAMS> cd ..
This installs MoorPy, CCBlade, and pyHAMS in "editable" mode, meaning, if you save a change to your source code in the files, future calls to RAFT modules will include those changes.
6. Install the RAFT package into the virtual environment
(raft-env) YOUR_PATH> cd RAFT
(raft-env) YOUR_PATH/RAFT> pip install -e .
This installs RAFT and all of its modules directly from your working directory in "editable" mode, meaning, if you save a change to your source code in the files in "YOUR_PATH/RAFT", future calls to RAFT modules will include those changes.
This new "raft-env" should now be compatible to run RAFT standalone.
7. Test the installation
(raft-env) YOUR_PATH/RAFT> pip install pytest
(raft-env) YOUR_PATH/RAFT> cd tests
(raft-env) YOUR_PATH/RAFT/tests> pytest test_fowt.py test_helpers.py test_member.py test_model.py test_rotor.py
Running these specific test files should prove that the installation was successful. Other tests that include 'omdao' are only used for installations with WISDEM.
If you need to remove any virtual environment for any reason, you can run
conda env remove -n "name-of-the-virtual-environment"
## Documentation and Issues
Please see <https://weis.readthedocs.io/en/latest/> for documentation.
Questions and issues can be posted at <https://github.com/WISDEM/RAFT/issues>.
## License
RAFT is licensed under the Apache License, Version 2.0
Raw data
{
"_id": null,
"home_page": null,
"name": "OpenRAFT",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.9",
"maintainer_email": "Matthew Hall <matthew.hall@nrel.gov>, Stein Housner <stein.housner@nrel.gov>, Daniel Zalkind <daniel.zalkind@nrel.gov>",
"keywords": "wind, floating, frequency, design, optimization",
"author": null,
"author_email": "National Renewable Energy Laboratory <matthew.hall@nrel.gov>",
"download_url": "https://files.pythonhosted.org/packages/07/cb/d2b259dc18fc373c4282b8c42d43fd531ec71453667cf534b5e38bf0e5a1/openraft-1.3.2.tar.gz",
"platform": null,
"description": "# RAFT - Response Amplitudes of Floating Turbines\n\nRAFT is a Python code for frequency-domain analysis of floating wind turbines. It constitutes the \"Level 1\" of modeling fidelity in the [WEIS](https://weis.readthedocs.io/en/latest/index.html) toolset for floating wind turbine controls co-design. RAFT provides frequency-domain modeling of full floating wind turbine systems including turbine aerodynamics, controls, rigid-body platform hydrodynamics, and mooring response. The rotor aerodynamics are provided by [CCBlade](https://github.com/WISDEM/CCBlade) and the mooring system is represented by NREL's new quasi-static mooring system model, [MoorPy](https://github.com/NREL/MoorPy). Potential-flow hydrodynamics can optionally be used via [pyHAMS](https://github.com/WISDEM/pyHAMS), a Python wrapper of the HAMS (Hydrodynamic Analysis of Marine Structures) tool for boundary-element-method solution of the potential flow problem developed by [Yingyi Liu](https://github.com/YingyiLiu/HAMS).\n\nRAFT v1.0.0 includes the capabilities described above, and further development is planned to expand these capabilities. Documentation and verification efforts are ongoing. Please see [RAFT's documentation](https://openraft.readthedocs.io/en/latest/) for more information.\n\n\n## Best Practices for Using `conda`\n\nInstallation with [Anaconda](https://www.anaconda.com) is the recommended approach because of the ability to create self-contained environments suitable for testing and analysis. RAFT requires [Anaconda 64-bit](https://www.anaconda.com/distribution/). However, the `conda` command has begun to show its age and we now recommend the one-for-one replacement with the [Miniforge3 distribution](https://github.com/conda-forge/miniforge?tab=readme-ov-file#miniforge3), which is much more lightweight and more easily solves for the RAFT package dependencies.\n\n\n## Using RAFT as a Library\n\nIf you would like to use RAFT as a library, without direct interaction with the source code, then you can install it directly via `conda install raft` (preferred) or `pip install raft`.\n\n\n## Getting Started\n\nNew users of RAFT as a standalone model are recommended to begin by looking at the input file and script provided in the examples folder, and seeking further information from the [RAFT documentation](https://openraft.readthedocs.io/en/latest/). For use as part of the WEIS toolset, information will be provided once this capability is completed in the [WEIS documentation](https://weis.readthedocs.io/en/latest/). For now, the following will help get started with running RAFT as a standalone model.\n\nRAFT uses a number of prerequisites, or other python package dependencies, to run its calculations. All of the prerequisites can be installed through the `conda` package manager, but power users may wish to install all of the NREL packages from source for customization and debugging. Notable dependencies are:\n\n- Python 3\n- NumPy\n- Matplotlib\n- SciPy\n- YAML\n- [MoorPy](https://github.com/NREL/MoorPy)\n- [pyHams](https://github.com/WISDEM/pyHAMS)\n- [CCBlade](https://github.com/WISDEM/CCBlade) or [WISDEM](https://github.com/WISDEM/WISDEM)*\n\n\\* CCBlade is a module of WISDEM, but can be used separately. RAFT only requires CCBlade (and some additional related functions) out of the larger WISDEM code. Power users installing from source can install either CCBlade or WISDEM, but for highest efficiency, we recommend installing CCBlade, without the entire WISDEM installation.\n\nNote that conda is required for the following installations.\n\n## Installing All Dependencies with `conda`\n\nTo install all required python packages to run RAFT using `conda`, follow the steps below.\n\n1. Navigate to a directory of your choosing on your local machine and clone this RAFT repository to that new directory (if you don't have the `git` command, start with `conda install git` in your \"base\" environment).\n\n (base) YOUR_PATH> git clone https://github.com/WISDEM/RAFT.git\n (base) YOUR_PATH> cd RAFT\n \n This will create new folder called \"RAFT\" that is a copy from the GitHub repository, located in your \"YOUR_PATH\" directory\n\n2. Create a new python virtual environment based on the \"environment.yml\" file, which lists all the packages needed to run RAFT\n\n (base) YOUR_PATH/RAFT> conda env create --name raft-env -f environment.yml\n\n This will create a new python virtual environment called \"raft-env\"\n\n3. Activate the new virtual environment\n\n (base) ANY_PATH> conda activate raft-env\n\n This will activate the newly created virtual environment, in which we will install the remaining dependencies. After install is complete, when opening a new conda terminal that starts in the \"base\" environment, you can start with this \"raft-env\" activation command.\n\n4. Install the RAFT package into the virtual environment\n\n (raft-env) YOUR_PATH/RAFT> pip install -e .\n\n This installs RAFT and all of its modules directly from your working directory in \"editable\" mode, meaning, if you save a change to your source code in the files in \"YOUR_PATH/RAFT\", future calls to RAFT modules will include those changes.\n\n5. Test the installation\n\n (raft-env) YOUR_PATH/RAFT> pytest\n \n Running pytest should ensure everything was installed correctly\n \n\t\n\n## Installing NREL Dependencies from Source\n\nTo install all external python packages using `conda` and NREL packages from source, follow the steps below. Since the NREL dependencies are also under development, this may also help resolve issues if one code gets out-of-sync with the others.\n\n1. Navigate to a directory of your choosing on your local machine and clone this RAFT repository to that new directory (if you don't have the `git` command, start with `conda install git` in your \"base\" environment.\n\n (base) YOUR_PATH> git clone https://github.com/WISDEM/RAFT.git\n (base) YOUR_PATH> cd RAFT\n \n This will create new folder called \"RAFT\" that is a copy from the GitHub repository, located in your \"YOUR_PATH\" directory\n\n2. Create a new python virtual environment based on the \"environment-source.yml\" file, which lists all the packages needed to run RAFT\n\n (base) YOUR_PATH/RAFT> conda env create --name raft-env -f environment-source.yml\n\n This will create a new python virtual environment called \"raft-env\"\n\n3. Activate the new virtual environment\n\n (base) ANY_PATH> conda activate raft-env\n\n This will activate the newly created virtual environment, in which we will install the remaining dependencies. After install is complete, when opening a new conda terminal that starts in the \"base\" environment, you can start with this \"raft-env\" activation command.\n\n4. Install the necessary compilers and build tools for your system\n\n (raft-env) YOUR_PATH/RAFT> cd ..\n (raft-env) YOUR_PATH> pip install meson-python meson ninja cmake\n (raft-env) YOUR_PATH> conda install gfortran (Mac / Linux)\n (raft-env) YOUR_PATH> conda install m2w64-toolchain libpython (Windows)\n\n\n5. Install the NREL packages from source one at a time.\n\n (raft-env) YOUR_PATH> git clone https://github.com/WISDEM/CCBlade.git\n (raft-env) YOUR_PATH> git clone https://github.com/NREL/MoorPy.git\n (raft-env) YOUR_PATH> git clone https://github.com/WISDEM/pyHAMS.git\n (raft-env) YOUR_PATH> cd MoorPy\n (raft-env) YOUR_PATH/MoorPy> pip install -e .\n (raft-env) YOUR_PATH/MoorPy> cd ..\n (raft-env) YOUR_PATH> cd CCBlade\n (raft-env) YOUR_PATH/CCBlade> pip install -e .\n (raft-env) YOUR_PATH/CCBlade> cd ..\n (raft-env) YOUR_PATH> cd pyHAMS\n (raft-env) YOUR_PATH/pyHAMS> pip install --no-build-isolation -e .\n (raft-env) YOUR_PATH/pyHAMS> cd ..\n\n This installs MoorPy, CCBlade, and pyHAMS in \"editable\" mode, meaning, if you save a change to your source code in the files, future calls to RAFT modules will include those changes.\n\n6. Install the RAFT package into the virtual environment\n\n (raft-env) YOUR_PATH> cd RAFT\n (raft-env) YOUR_PATH/RAFT> pip install -e .\n \n This installs RAFT and all of its modules directly from your working directory in \"editable\" mode, meaning, if you save a change to your source code in the files in \"YOUR_PATH/RAFT\", future calls to RAFT modules will include those changes.\n\nThis new \"raft-env\" should now be compatible to run RAFT standalone.\n\n7. Test the installation\n\n (raft-env) YOUR_PATH/RAFT> pip install pytest\n (raft-env) YOUR_PATH/RAFT> cd tests\n (raft-env) YOUR_PATH/RAFT/tests> pytest test_fowt.py test_helpers.py test_member.py test_model.py test_rotor.py\n \n Running these specific test files should prove that the installation was successful. Other tests that include 'omdao' are only used for installations with WISDEM.\n\nIf you need to remove any virtual environment for any reason, you can run \n\n conda env remove -n \"name-of-the-virtual-environment\"\n\n\n\n## Documentation and Issues\n\nPlease see <https://weis.readthedocs.io/en/latest/> for documentation.\n\nQuestions and issues can be posted at <https://github.com/WISDEM/RAFT/issues>.\n\n## License\nRAFT is licensed under the Apache License, Version 2.0\n\n",
"bugtrack_url": null,
"license": "Apache-2.0",
"summary": "RAFT: Response Amplitudes of Floating Turbines",
"version": "1.3.2",
"project_urls": {
"Documentation": "https://openraft.readthedocs.io",
"Homepage": "https://github.com/WISDEM/RAFT"
},
"split_keywords": [
"wind",
" floating",
" frequency",
" design",
" optimization"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "13f7ad0fb8d89d8cc84c80b4450391978c85b6f3b208dffbd8f8a5f01ba97367",
"md5": "56db1c22ddd2388b51d2b57dd11c0161",
"sha256": "9827d504086947d82156c10a40de8f814951a59e71a54c46c7ef724eacc9bf18"
},
"downloads": -1,
"filename": "OpenRAFT-1.3.2-py3-none-any.whl",
"has_sig": false,
"md5_digest": "56db1c22ddd2388b51d2b57dd11c0161",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.9",
"size": 147160,
"upload_time": "2025-01-10T19:40:25",
"upload_time_iso_8601": "2025-01-10T19:40:25.734111Z",
"url": "https://files.pythonhosted.org/packages/13/f7/ad0fb8d89d8cc84c80b4450391978c85b6f3b208dffbd8f8a5f01ba97367/OpenRAFT-1.3.2-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "07cbd2b259dc18fc373c4282b8c42d43fd531ec71453667cf534b5e38bf0e5a1",
"md5": "6300d93e4fac8b5c0f855f971e8b7059",
"sha256": "67f68b45d86f23a3560d4541f1018e42bda06769e3b2e3098ae4fa5cb097a68a"
},
"downloads": -1,
"filename": "openraft-1.3.2.tar.gz",
"has_sig": false,
"md5_digest": "6300d93e4fac8b5c0f855f971e8b7059",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.9",
"size": 207835,
"upload_time": "2025-01-10T19:40:28",
"upload_time_iso_8601": "2025-01-10T19:40:28.557879Z",
"url": "https://files.pythonhosted.org/packages/07/cb/d2b259dc18fc373c4282b8c42d43fd531ec71453667cf534b5e38bf0e5a1/openraft-1.3.2.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-10 19:40:28",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "WISDEM",
"github_project": "RAFT",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "openraft"
}