compas_model.binding

class compas_wood.binding.Globals[source]

Bases: object

Class to access global variables of the wood_nano library using class instance wood_globals:

>>> from compas_wood.binding import wood_globals
>>> wood_globals.distance_squared = 10
>>> wood_globals.face_to_face_side_to_side_joints_rotated_joint_as_average = True
>>> wood_globals.face_to_face_side_to_side_joints_all_treated_as_rotated = True
Attributes:
clipper_scaleint, default 1e6

The clipper scale.

clipper_areafloat, default 1e-2

The clipper area.

distancefloat, default 1e-1

The distance.

distance_squaredfloat, default 1e-2

The distance squared.

anglefloat, default 0.11

The angle.

path_and_file_for_jointsstr, default “”

The path and file for joints.

data_set_input_folderstr

The data set input folder.

data_set_output_filestr, default data_set_input_folder + “out.xml”

The data set output file.

data_set_output_databasestr, default data_set_input_folder + “out.db”

The data set output database.

joint_volume_extensionlist[float], default [0.0, 0.0, 0.0, 0.0, 0.0]

The joint volume extension, first 3 values are for xyz of the joint volume.

output_geometry_typeint, default 4

The output geometry type.

face_to_face_side_to_side_joints_all_treated_as_rotatedbool, default False

The face to face side to side joints all treated as rotated.

face_to_face_side_to_side_joints_rotated_joint_as_averagebool, default False

The face to face side to side joints rotated joint as average.

face_to_face_side_to_side_joints_dihedral_anglefloat, default 150.0

The face to face side to side joints dihedral angle.

limit_min_joint_lengthfloat, default 0.0

The limit min joint length.

existing_typeslist[str], read-only

The existing types of joints.

joints_parameters_and_typeslist[float], default:

300, 0.5, 3, // 1-9 ss_e_ip (side-to-side edge in-plane)

450, 0.64, 15, // 10-19 ss_e_op (side-to-side edge out-of-plane)

450, 0.5, 20, // 20-29 ts_e_p (top-to-side edge plane)

300, 0.5, 30, // 30-39 cr_c_ip (cross cutting in-plane)

6, 0.95, 40, // 40-49 tt_e_p (top-to-top edge plane)

300, 0.5, 58, // 50-59 ss_e_r (side-to-side edge rotated)

300, 1.0, 60 // 60-69 b (boundary)

custom_joints_ss_e_ip_malelist[Polyline], default []

Joinery polylines for custom side-to-side edge in-plane male joints.

custom_joints_ss_e_ip_femalelist[Polyline], default []

Joinery polylines for custom side-to-side edge in-plane female joints.

custom_joints_ss_e_op_malelist[Polyline], default []

Joinery polylines for custom side-to-side edge out-of-plane male joints.

custom_joints_ss_e_op_femalelist[Polyline], default []

Joinery polylines for custom side-to-side edge out-of-plane female joints.

custom_joints_ts_e_p_malelist[Polyline], default []

Joinery polylines for custom top-to-side edge in-plane male joints.

custom_joints_ts_e_p_femalelist[Polyline], default []

Joinery polylines for custom top-to-side edge in-plane female joints.

custom_joints_cr_c_ip_malelist[Polyline], default []

Joinery polylines for custom corner-to-corner in-plane male joints.

custom_joints_cr_c_ip_femalelist[Polyline], default []

Joinery polylines for custom corner-to-corner in-plane female joints.

custom_joints_tt_e_p_malelist[Polyline], default []

Joinery polylines for custom top-to-top edge in-plane male joints.

custom_joints_tt_e_p_femalelist[Polyline], default []

Joinery polylines for custom top-to-top edge in-plane female joints.

custom_joints_ss_e_r_malelist[Polyline], default []

Joinery polylines for custom side-to-side edge rounded male joints.

custom_joints_ss_e_r_femalelist[Polyline], default []

Joinery polylines for custom side-to-side edge rounded female joints.

custom_joints_b_malelist[Polyline], default []

Joinery polylines for custom base male joints.

custom_joints_b_femalelist[Polyline], default []

Joinery polylines for custom base female joints.

compas_wood.binding.beam_skeleton(mesh, divisions=10, number_of_neighbours=10, extend_ends=True)[source]

Get central axis of a mesh whose geometry is closed to a beam.

Parameters:
meshcompas.datastructures.Mesh

The mesh to get the central axis from.

divisionsint, optional

Central axis is subdivded in this number of points.

number_of_neighboursint, optional

The distance value for each polyline point is calculated based on the average distance to this number of neighbours.

extend_endsbool, optional

Whether to extend the ends of the central axis to the mesh using Ray-Mesh Intersection.

Returns:
tuple[ compas.geometry.Polyline, list[float]]

The central axis of the beam and the distances of the points to the mesh.

compas_wood.binding.closed_mesh_from_polylines(input_polyline_pairs)[source]

Get closed mesh from polylines, where the first two polylines are the top and bottom polylines, and the rest are the holes.

Parameters:
input_polyline_pairslist[list[compas.geometry.Polyline]]

List of polylines that represents the timber elements.

Returns:
compas.datastructures.Mesh

closed mesh

compas_wood.binding.get_connection_zones(input_polyline_pairs, input_insertion_vectors=[], input_joint_types=[], input_three_valence_element_indices_and_instruction=[], input_adjacency=[], input_joint_parameters_and_types=[], input_search_type=0, input_scale=[1, 1, 1], input_output_type=3, input_joint_volume_parameters=[0, 0, 0], input_custom_joints=[], input_custom_joints_types=[], remove_duplicate_polylines=False)[source]

Get connection zones for the given input parameters.

Parameters:
input_polyline_pairslist[list[compas.geometry.Polyline]]

List of polylines that represents the timber elements.

input_insertion_vectorslist[compas.geometry.Vector], optional

List of insertion vectors.

input_joint_typeslist[int], optional

List of joint types.

input_three_valence_element_indices_and_instructionlist[int], optional

List of three valence element indices and instruction.

input_adjacencylist[int], optional

List of adjacency.

input_joint_parameters_and_typeslist[float], optional

List of joint parameters and types.

input_search_typeint, optional

Search type.

input_scalelist[float], optional

Scale.

input_output_typeint, optional

Output type.

input_joint_volume_parameterslist[float], optional

Joint volume parameters.

input_face_to_face_side_to_side_joints_all_treated_as_rotatedbool, optional

Face to face side to side joints all treated as rotated.

input_custom_jointslist[compas.geometry.Point], optional

Custom joints.

input_custom_joints_typeslist[int], optional

Custom joints types.

remove_duplicate_polylinesbool, optional

Remove duplicate polylines.

Returns:
list[list[compas.geometry.Polyline]]

List of polylines that represents the timber elements.

list[wood_nano.CutType2]

List of cut types.

compas_wood.binding.joints(input_polyline_pairs, search_type=0)[source]

Get joints for the given input parameters. This is the very first step in the process of creating a timber structure - detection of interfaces.

Parameters:
input_polyline_pairslist[list[compas.geometry.Polyline]]

List of polylines that represents the timber elements.

search_typeint, optional

Search type.

Returns:
list[list[int]]

List of element pairs.

list[compas.geometry.Polyline]

List of joint areas.

list[int]

List of joint types.

compas_wood.binding.mesh_boolean_difference_from_polylines(polylines_lists)[source]

The polylines lists first items represnts elements outlines and the second items represents joinery outlines.

Parameters:
polylines_listslist of list of compas.geometry.Polyline

The polylines lists first items represnts elements outlines and the second items represents joinery outlines.

Returns:
list of compas.datastructures.Mesh

The meshes created by the boolean difference of the elements and joineries.

compas_wood.binding.read_xml_polylines(foldername='/home/petras/brg/2_code/wood_nano/src/wood/cmake/src/wood/dataset/', filename='type_plates_name_cross_vda_hexshell_reciprocal', scale=1)[source]

Read polylines from XML file.

Parameters:
foldernamestr, optional

Foldername.

filename_of_datasetstr, optional

Filename of dataset.

scalefloat, optional

Scale.

Returns:
list[compas.geometry.Polyline]

List of polylines.

compas_wood.binding.read_xml_polylines_and_properties(foldername='/home/petras/brg/2_code/wood_nano/src/wood/cmake/src/wood/dataset/', filename_of_dataset='type_plates_name_top_to_side_and_side_to_side_outofplane_annen_grid_small', scale=0.01)[source]

Read polylines from XML file with attributes:

  • insertion vectors per face

  • input_joints_types per face

  • input_three_valence_element_indices_and_instruction

  • input_adjacency per curren and next elements and their faces.

Parameters:
foldernamestr, optional

Foldername.

filename_of_datasetstr, optional

Filename of dataset.

scalefloat, optional

Scale.

Returns:
list[compas.geometry.Polyline]

List of polylines.

list[list[compas.geometry.Vector]]

List of vectors.

list[list[int]]

List of joint types.

list[list[int]]

List of three valence element indices and instruction.

list[int]

List of adjacency.

compas_wood.binding.rtree(polylines)[source]

Given a list of polylines-pairs find neighbors between them via aabb and obb collisions. Polyline pairs means the top and bottom polylines of plates.

Parameters:
polylineslist[compas.geometry.Polyline]

List of polylines.

Returns:
list[int]

List of neighbors.

list[compas.geometry.Box]

List of aabb boxes.

list[compas.geometry.Box]

List of obb boxes.

compas_wood.binding.test()[source]

Test if wood_nano package is loaded by printing message in C++.