ladybug_geometry.bounding module

Utility functions for computing bounding boxes and extents around geometry.

ladybug_geometry.bounding.bounding_box(geometries, axis_angle=0)[source]

Get the min and max of an oriented bounding box around 3D geometry.

Parameters:
  • geometries – An array of 3D geometry objects. Note that all objects must have a min and max property.

  • axis_angle – The counter-clockwise rotation angle in radians in the XY plane to represent the orientation of the bounding box extents. (Default: 0).

Returns:

A tuple with two Point3D objects representing the min point and max point of the bounding box respectively.

ladybug_geometry.bounding.bounding_box_extents(geometries, axis_angle=0)[source]

Get the width, length and height of an oriented bounding box around 3D geometry.

Parameters:
  • geometries – An array of 3D geometry objects. Note that all objects must have a min and max property.

  • axis_angle – The counter-clockwise rotation angle in radians in the XY plane to represent the orientation of the bounding box extents. (Default: 0).

Returns:

A tuple with 3 values corresponding to the width, length and height of the bounding box.

ladybug_geometry.bounding.bounding_domain_x(geometries)[source]

Get minimum and maximum X coordinates of multiple geometries.

Parameters:

geometries – An array of any ladybug_geometry objects for which the extents of the X domain will be computed. Note that all objects must have a min and max property.

Returns:

A tuple with the min and the max X coordinates around the geometry.

ladybug_geometry.bounding.bounding_domain_y(geometries)[source]

Get minimum and maximum Y coordinates of multiple geometries.

Parameters:

geometries – An array of any ladybug_geometry objects for which the extents of the Y domain will be computed. Note that all objects must have a min and max property.

Returns:

A tuple with the min and the max Y coordinates around the geometry.

ladybug_geometry.bounding.bounding_domain_z(geometries)[source]

Get minimum and maximum Z coordinates of multiple geometries.

Parameters:

geometries – An array of any 3D ladybug_geometry objects for which the extents of the Z domain will be computed. Note that all objects must have a min and max property and they cannot be 2D objects.

Returns:

A tuple with the min and the max Z coordinates around the geometry.

ladybug_geometry.bounding.bounding_domain_z_2d_safe(geometries)[source]

Get minimum and maximum Z coordinates in a manner that is safe for 2D geometries.

Parameters:

geometries – An array of any ladybug_geometry objects for which the extents of the Z domain will be computed. Any 2D objects within this list will be assumed to have a Z-value of zero.

Returns:

A tuple with the min and the max Z coordinates around the geometry.

ladybug_geometry.bounding.bounding_rectangle(geometries, axis_angle=0)[source]

Get the min and max of an oriented bounding rectangle around 2D or 3D geometry.

Parameters:
  • geometries – An array of 2D or 3D geometry objects. Note that all objects must have a min and max property.

  • axis_angle – The counter-clockwise rotation angle in radians in the XY plane to represent the orientation of the bounding rectangle extents. (Default: 0).

Returns:

A tuple with two Point2D objects representing the min point and max point of the bounding rectangle respectively.

ladybug_geometry.bounding.bounding_rectangle_extents(geometries, axis_angle=0)[source]

Get the width and length of an oriented bounding rectangle around 2D or 3D geometry.

Parameters:
  • geometries – An array of 2D or 3D geometry objects. Note that all objects must have a min and max property.

  • axis_angle – The counter-clockwise rotation angle in radians in the XY plane to represent the orientation of the bounding rectangle extents. (Default: 0).

Returns:

A tuple with 2 values corresponding to the width and length of the bounding rectangle.

ladybug_geometry.bounding.overlapping_bounding_boxes(geometry_1, geometry_2, distance)[source]

Check if the bounding boxes around two geometries overlap within a distance.

Parameters:
  • geometry_1 – The first geometry to check.

  • geometry_2 – The second geometry to check.

  • distance – The maximum distance at which the geometries are considered overlapping.

Returns:

True if the geometries overlap. False if they do not.

ladybug_geometry.bounding.overlapping_bounding_rect(geometry_1, geometry_2, distance)[source]

Check if the bounding rectangles of two geometries overlap within a tolerance.

Parameters:
  • geometry_1 – The first geometry to check.

  • geometry_2 – The second geometry to check.

  • distance – The maximum distance at which the geometries are considered overlapping.

Returns:

True if the geometries overlap. False if they do not.