From 016b7c6636f7ea51826a8053ce2181c984788f12 Mon Sep 17 00:00:00 2001 From: Guenther Obermair Date: Mon, 9 Sep 2024 16:25:51 +0200 Subject: [PATCH] Add: show_swept-file now shows more examples --- examples/show_swept.py | 99 +++++++++++++++++++++++++++++++++------ splinepy/helpme/create.py | 2 +- 2 files changed, 86 insertions(+), 15 deletions(-) diff --git a/examples/show_swept.py b/examples/show_swept.py index 00979a049..eb509054c 100644 --- a/examples/show_swept.py +++ b/examples/show_swept.py @@ -7,7 +7,7 @@ ### TRAJECTORY ### - # define a questionmark-trajectory + # define a hook-trajectory dict_trajectory = { "degrees": [3], "knot_vectors": [ @@ -34,34 +34,105 @@ # refine trajectory by inserting knots and control points trajectory.uniform_refine(0, 1) - ### CROSS SECTION ### + ### CROSS SECTIONS ### - # helpme to create a circular cross section - cross_section = splinepy.helpme.create.surface_circle(0.5).nurbs + # 1. create a circular line-cross-section + cross_section_circle1D = splinepy.helpme.create.circle(0.5).nurbs + + # 2. create a circular surface-cross-section + cross_section_circle2D = splinepy.helpme.create.surface_circle(0.5).nurbs + + # 3. create a rectangular surface-cross-section + cross_section_rect2D = splinepy.helpme.create.box(1, 1).nurbs # user can define the normal vector of the cross section, in case - # the cross section is not planar in the x-y plane (default) - cs_nv = np.array([0, 0, 1]) + # the cross section is not planar in the x-y plane (or the user + # wants crooked sweeping) + cs_nv = np.array([1, 0, 1]) ### SWEEP ### # create swept surface - swept_surface = splinepy.helpme.create.swept( + swept_surface_1D_circle = splinepy.helpme.create.swept( + trajectory=trajectory, + cross_section=cross_section_circle1D, + cross_section_normal=None, + set_on_trajectory=False, + rotation_adaption=None, + ) + + # create swept solid (circular nr. 1) + # the cross-sections are set on the trajectory's control points (default) + swept_surface_2D_circle_1 = splinepy.helpme.create.swept( trajectory=trajectory, - cross_section=cross_section, + cross_section=cross_section_circle2D, + cross_section_normal=None, + set_on_trajectory=False, + rotation_adaption=None, + ) + + # create crooked swept solid (circular nr. 2) + # the cross-sections are set on the trajectory's evaluation points + swept_surface_2D_circle_2 = splinepy.helpme.create.swept( + trajectory=trajectory, + cross_section=cross_section_circle2D, + cross_section_normal=None, + set_on_trajectory=True, + rotation_adaption=None, + ) + + # create swept solid set on trajectory (circular nr. 3) + # the cross-section's normal vector is not default; crooked sweeping + swept_surface_2D_circle_3 = splinepy.helpme.create.swept( + trajectory=trajectory, + cross_section=cross_section_circle2D, cross_section_normal=cs_nv, set_on_trajectory=False, + rotation_adaption=None, ) - ### VISUALIZATION ### + # create swept solid (rectangular nr. 1) + swept_surface_2D_rect_1 = splinepy.helpme.create.swept( + trajectory=trajectory, + cross_section=cross_section_rect2D, + cross_section_normal=None, + set_on_trajectory=False, + rotation_adaption=None, + ) + + # create swept solid (rectangular nr. 2) + # rotation adaption with 45 degrees + swept_surface_2D_rect_2 = splinepy.helpme.create.swept( + trajectory=trajectory, + cross_section=cross_section_rect2D, + cross_section_normal=None, + set_on_trajectory=False, + rotation_adaption=45 * np.pi / 180, + ) - trajectory.show_options["control_mesh"] = False - cross_section.show_options["control_mesh"] = False - swept_surface.show_options["control_mesh"] = False + ### VISUALIZATION ### gus.show( ["Trajectory", trajectory], - ["Cross Section", cross_section], - ["Swept Surface", swept_surface], + ["1D Cross Section", cross_section_circle1D], + ["Swept Surface", swept_surface_1D_circle], + resolution=101, + control_mesh=False, + ) + + gus.show( + ["2D Cross Section", cross_section_circle2D], + ["Swept Solid - Set on Control Points", swept_surface_2D_circle_1], + ["Swept Solid - Set on Evaluation Points", swept_surface_2D_circle_2], + ["Swept Solid - Crooked Sweeping", swept_surface_2D_circle_3], + resolution=101, + control_mesh=False, + ) + + gus.show( + ["New Cross Section", cross_section_rect2D], + ["Swept Solid without Rotation", swept_surface_2D_rect_1, trajectory], + ["Swept Solid with 45° Rotation", swept_surface_2D_rect_2, trajectory], resolution=101, + control_mesh=False, ) diff --git a/splinepy/helpme/create.py b/splinepy/helpme/create.py index 18676ba26..9fb9a3314 100644 --- a/splinepy/helpme/create.py +++ b/splinepy/helpme/create.py @@ -338,7 +338,7 @@ def swept( Angle in radians by which the cross-section is rotated around the trajectory tangent vector. This is an additional rotation if the user wants to adapt the cross-section rotation. - Example with rectangular crossection: + Example with rectangular cross-section: . x . x x x x x x x . x x x x