Geometry API: Base class

Module to connect to the database API to retrieve and operate on geometry data.

class owimetadatabase_preprocessor.geometry.io.GeometryAPI(api_root: str = 'https://owimetadatabase.azurewebsites.net/api/v1', api_subdir: str = '/geometry/userroutes/', token: str | None = None, uname: str | None = None, password: str | None = None, **kwargs)

Bases: API

Class to connect to the geometry data API with methods to retrieve data.

__init__(api_root: str = 'https://owimetadatabase.azurewebsites.net/api/v1', api_subdir: str = '/geometry/userroutes/', token: str | None = None, uname: str | None = None, password: str | None = None, **kwargs) None

Create an instance of the GeometryAPI class with the required parameters.

Parameters:
  • api_root – Optional: root URL of the API endpoint, the default working database url is provided.

  • api_subdir – Optional: subdirectory of the API endpooint url for specific type of data.

  • token – Optional: token to access the API.

  • uname – Optional: username to access the API.

  • password – Optional: password to access the API.

  • kwargs – Additional parameters to pass to the API.

Returns:

None

get_subassemblies(projectsite: str | None = None, assetlocation: str | None = None, subassembly_type: str | None = None) Dict[str, DataFrame | bool | int64 | None]

Get all structure subassemblies blocks for a given location.

Parameters:
  • projectsite – Title of the projectsite.

  • assetlocation – Title of the asset location.

  • subassembly_type – Type of the subassembly.

Returns:

Dictionary with the following keys:

  • ”data”: Pandas dataframe with the location data for each project

  • ”exists”: Boolean indicating whether matching records are found

get_buildingblocks(projectsite: str | None = None, assetlocation: str | None = None, subassembly_type: str | None = None, subassembly_id: str | None = None) Dict[str, DataFrame | bool | int64 | None]

Get all building blocks for a given location.

Parameters:
  • projectsite – Title of the projectsite.

  • assetlocation – Title of the asset location.

  • subassembly_type – Type of the subassemblies.

  • subassembly_id – ID of the subassembly.

Returns:

Dictionary with the following keys:

  • ”data”: Pandas dataframe with the location data for each project

  • ”exists”: Boolean indicating whether matching records are found

get_materials() Dict[str, DataFrame | bool | int64 | None]

Get all the materials of building blocks.

Returns:

Dictionary with the following keys:

  • ”data”: Pandas dataframe with the location data for each project

  • ”exists”: Boolean indicating whether matching records are found

get_subassembly_objects(turbine: str, subassembly: str | None = None) Dict[str, SubAssembly]

Get all subassemblies for a given turbine, divided by type.

Parameters:
  • turbine – Turbine title (e.g. ‘BBC01’)

  • subassembly – Sub-assembly type (e.g. ‘MP’, ‘TW’, ‘TP’)

Returns:

Dictionary with the following keys:

  • ”TW”: SubAssembly object for the tower

  • ”TP”: SubAssembly object for the transition piece

  • ”MP”: SubAssembly object for the monopile

get_owt_geometry_processor(turbines: str | List[str], tower_base: float | List[float] | None = None, monopile_head: float | List[float] | None = None) OWTs

Return the required processing class.

Parameters:
  • turbines – Title(s) of the turbines.

  • tower_base – Optional: height(s) of the tower base.

  • monopile_head – Optional: height(s) of the monopile head.

Returns:

OWTs object: containing information about all the requested turbines.

plot_turbines(turbines: List[str] | str, figures_per_line: int = 5, return_fig: bool = True, show_fig: bool = True) None

Plot turbines’ frontal geometry.

Parameters:
  • turbines – Title(s) of the turbines.

  • figures_per_line – Number of figures per line.

  • return_fig – Optional: whether to return the figure.

  • show_fig – Optional: whether to show the figure.

Returns:

Plotly figure object with selected turbines front profiles (if requested) or nothing.