Skip to content

Commit

Permalink
Merge pull request #32 from NREL/dev
Browse files Browse the repository at this point in the history
MoorPy v1.1.0
  • Loading branch information
shousner authored Sep 9, 2024
2 parents 018e976 + f4dfc89 commit 9881074
Show file tree
Hide file tree
Showing 34 changed files with 4,548 additions and 964 deletions.
2 changes: 1 addition & 1 deletion .readthedocs.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ version: 2
sphinx:
configuration: docs/conf.py
python:
version: 3.7
version: 3.8
install:
- method: pip
path: .
Expand Down
3 changes: 2 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,8 @@ MoorPy is available on PyPi via:
pip install MoorPy
```

For an editable install that relies on the local source code, first clone the repository. Then, from the command line in the main MoorPy directory, run the following commands based on your additional needs...
For an editable install that relies on the local source code, first clone the repository. Then, from the command line in the main MoorPy directory, run the following commands (with a "-e" for "editable") based on your additional needs.
The "dev", "test", and "docs" flags will install necessary packages related to development, testing, or documentation (e.g., the docs flag installs "sphinx" for documentation).

#### General
```pycon
Expand Down
152 changes: 145 additions & 7 deletions docs/starting.rst
Original file line number Diff line number Diff line change
Expand Up @@ -28,13 +28,151 @@ Examples

The MoorPy repository has an examples folder containing two example scripts:

- manual_system.py constructs a mooring system from scratch using functions for creating each line and attachment point.

- imported_system.py creates a mooring system by reading an included MoorDyn-style input file.

- manual_system.py constructs a mooring system from scratch using functions for creating each line and attachment point.
Running either of these scripts will produce a basic mooring system model that can be used in further analysis.


Creating a MoorPy System Manually
---------------------------------

MoorPy has internal functions to facilitate the orderly creation of a mooring system. The following
gives an example of how they work (from manual_system.py).

.. code-block:: python
# ----- choose some system geometry parameters -----
depth = 600 # water depth [m]
angles = np.radians([60, 180, 300]) # line headings list [rad]
rAnchor = 1600 # anchor radius/spacing [m]
zFair = -21 # fairlead z elevation [m]
rFair = 20 # fairlead radius [m]
lineLength= 1800 # line unstretched length [m]
typeName = "chain1" # identifier string for the line type
# ----- set up the mooring system and floating body -----
# Create new MoorPy System and set its depth
ms = mp.System(depth=depth)
# add a line type
ms.setLineType(dnommm=120, material='chain', name=typeName) # this would be 120 mm chain
# Add a free, body at [0,0,0] to the system (including some properties to make it hydrostatically stiff)
ms.addBody(0, np.zeros(6), m=1e6, v=1e3, rM=100, AWP=1e3)
# For each line heading, set the anchor point, the fairlead point, and the line itself
for i, angle in enumerate(angles):
# create end Points for the line
ms.addPoint(1, [rAnchor*np.cos(angle), rAnchor*np.sin(angle), -depth]) # create anchor point (type 0, fixed)
ms.addPoint(1, [ rFair*np.cos(angle), rFair*np.sin(angle), zFair]) # create fairlead point (type 0, fixed)
# attach the fairlead Point to the Body (so it's fixed to the Body rather than the ground)
ms.bodyList[0].attachPoint(2*i+2, [rFair*np.cos(angle), rFair*np.sin(angle), zFair])
# add a Line going between the anchor and fairlead Points
ms.addLine(lineLength, typeName, pointA=2*i+1, pointB=2*i+2)
Creating a MoorPy System for a MoorDyn Input File
-------------------------------------------------

.. _inputfile:

A MoorPy System can be initialized by reading in a MoorDyn-style input file. This is simply done by
passing the input file name when creating the System object (from imported_system.py):

.. code-block:: python
ms = mp.System(file='the MoorDyn-style input file.txt')
The format of the input file is expected to follow the
MoorDyn v2 style, an example of which is shown below:


.. code-block:: none
MoorDyn v2 Input File
Sample for input to MoorPy
---------------------- LINE TYPES --------------------------------------------------
TypeName Diam Mass/m EA BA/-zeta EI Cd Ca CdAx CaAx
(name) (m) (kg/m) (N) (N-s/-) (N-m^2) (-) (-) (-) (-)
chain 0.2160 286.56 1.23e9 -1.0 0.00 1.00 1.00 0.00 0.00
--------------------- ROD TYPES -----------------------------------------------------
TypeName Diam Mass/m Cd Ca CdEnd CaEnd
(name) (m) (kg/m) (-) (-) (-) (-)
----------------------- BODIES ------------------------------------------------------
ID Attachment X0 Y0 Z0 r0 p0 y0 Mass CG* I* Volume CdA* Ca*
(#) (-) (m) (m) (m) (deg) (deg) (deg) (kg) (m) (kg-m^2) (m^3) (m^2) (-)
1 coupled 0.00 0.00 -0.75 0.00 0.00 0.00 1.0e6 0.00 0.00 1.0e3 0.00 0.00
---------------------- RODS ---------------------------------------------------------
ID RodType Attachment Xa Ya Za Xb Yb Zb NumSegs RodOutputs
(#) (name) (#/key) (m) (m) (m) (m) (m) (m) (-) (-)
---------------------- POINTS -------------------------------------------------------
ID Attachment X Y Z Mass Volume CdA Ca
(#) (-) (m) (m) (m) (kg) (mˆ3) (m^2) (-)
1 Fixed 800.00 1385.64 -600.00 0.00 0.00 0.00 0.00
2 Body1 10.00 17.32 -21.00 0.00 0.00 0.00 0.00
3 Fixed -1600.00 0.00 -600.00 0.00 0.00 0.00 0.00
4 Body1 -20.00 0.00 -21.00 0.00 0.00 0.00 0.00
5 Fixed 800.00 -1385.64 -600.00 0.00 0.00 0.00 0.00
6 Body1 10.00 -17.32 -21.00 0.00 0.00 0.00 0.00
---------------------- LINES --------------------------------------------------------
ID LineType AttachA AttachB UnstrLen NumSegs LineOutputs
(#) (name) (#) (#) (m) (-) (-)
1 chain 1 2 1800.000 40 p
2 chain 3 4 1800.000 40 p
3 chain 5 6 1800.000 40 p
---------------------- OPTIONS ------------------------------------------------------
600.0 depth
--------------------- need this line ------------------------------------------------
Note that some parameters are only applicable to a dynamic model like MoorDyn, and are ignored by MoorPy.
Conversely, some Body parameters used by MoorPy for hydrostatics are not captured in a MoorDyn-style file.



Running the MoorPy Model
------------------------

Once the MoorPy System is set up, it can be analyzed, viewed, and manipulated using a handful of main
functions, as well as a variety of additional helper functions for more specialized tasks.

Here is an example showing one of the possible functions to analyze a mooring system:


.. code-block:: python
ms.initialize() # make sure everything's connected
ms.solveEquilibrium() # equilibrate
fig, ax = ms.plot() # plot the system in original configuration
ms.unload("sample.txt") # export to MD input file
ms.bodyList[0].f6Ext = np.array([3e6, 0, 0, 0, 0, 0]) # apply an external force on the body
ms.solveEquilibrium() # equilibrate
fig, ax = ms.plot(ax=ax, color='red') # plot the system in displaced configuration (on the same plot, in red)
**Documentation Overview**

An overview of how a mooring system is represented in MoorPy can be found in :ref:`The Model Structure page<Model Structure>`.

More documentation and examples of other functions that can be applied to a MoorPy mooring system can be
found in :ref:`The Usage page<MoorPy Usage>`.

Detailed theory "under the hood" of the functions in MoorPy can be found in :ref:`The Theory Page<Theory and References>`.

Detailed inputs and outputs of MoorPy classes and functions can be found in :ref:`The API Page<API>`.

Both of these example scripts should run successfully after MoorPy has been installed.
They will produce a plot showing the mooring system in the calculated equilibrium state.
:ref:`The Model Structure page<Model Structure>` gives an overview of how a mooring system
is represented in MoorPy. :ref:`The MoorPy Usage page<MoorPy Usage>` gives more information
about the function calls used to make these examples work, as well as other available
methods and outputs of MoorPy.
34 changes: 34 additions & 0 deletions docs/structure.rst
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,7 @@ accessed afterward are as follows:
- **f6Ext**: applied external forces and moments vector in global orientation
(not including weight/buoyancy) [N]. The default is np.zeros(6).



The MoorPy System Object
------------------------
Expand All @@ -91,3 +92,36 @@ The System object in MoorPy is used to hold all the objects being simulated as w
information like the line types dictionary, water density, and water depth. Most user
interactions with the mooring system are supported through methods of the System class.
These methods are listed on the :ref:`API` page. More description to be added here in future...

Bathymetry
^^^^^^^^^^

MoorPy supports three different approaches to the seabed surface, which
are defined by the seabedMod flag:

0. Uniform flat seabed specified by a depth value.
1. Uniform sloped seabed specified by a depth value at x,y = 0,0 along
with xSlope and ySlope valus that specify the slope (rise/run). If
only one of these values, the other is assumed to be zero.
2. A bathymetry grid where the seabed depth is interpolated as a function
of x and y coorinates based on bilinear interpolation from a rectangular
grid of depth data. This grid is usually read in from a specially formatted
file similar to MoorDyn (link to be added).

Further usage of these features will be described in (link to usage section to be added).

Current
^^^^^^^

The effect of current in terms of drag forces on the mooring lines can be
included, as controlled by the currentMod flag:

0. No current is considered.
1. A steady uniform current is considered, specified by the System current
vector. The drag force from this current will be added to the weight
vector each time the catenary equations are used to solve the mooring
line profiles.
2. XX A steady current that is uniform in the horizontal direction but can
change with depth according to a lookup table (typically from an input
file following the same format as in MoorDyn. This feature is NOT YET
IMPLEMENTED.
Loading

0 comments on commit 9881074

Please sign in to comment.