Source code for aerocaps.iges.curves

import typing

import numpy as np

from aerocaps.iges.entity import IGESEntity
from aerocaps.iges.iges_param import IGESParam
from aerocaps.units.angle import Angle
from aerocaps.units.length import Length


[docs] class CircularArcIGES(IGESEntity): """ IGES IGESEntity #100 """
[docs] def __init__(self, radius: Length, start_angle: Angle, end_angle: Angle): x2 = radius.m * np.cos(start_angle.rad) y2 = radius.m * np.sin(start_angle.rad) x3 = radius.m * np.cos(end_angle.rad) y3 = radius.m * np.sin(end_angle.rad) parameter_data = [ IGESParam(0.0, "real"), IGESParam(0.0, "real"), IGESParam(0.0, "real"), IGESParam(x2, "real"), IGESParam(y2, "real"), IGESParam(x3, "real"), IGESParam(y3, "real") ] super().__init__(100, parameter_data)
[docs] class LineIGES(IGESEntity): """ IGES IGESEntity #110 """
[docs] def __init__(self, start_point: np.ndarray, end_point: np.ndarray): parameter_data = [ IGESParam(start_point[0], "real"), IGESParam(start_point[1], "real"), IGESParam(start_point[2], "real"), IGESParam(end_point[0], "real"), IGESParam(end_point[1], "real"), IGESParam(end_point[2], "real") ] super().__init__(110, parameter_data)
[docs] class RationalBSplineCurveIGES(IGESEntity): """ IGES IGESEntity #126 """
[docs] def __init__(self, knots: np.ndarray, weights: np.ndarray, control_points_XYZ: np.ndarray, degree: int, start_parameter_value=0.0, end_parameter_value=1.0, unit_normal_x=0.0, unit_normal_y=0.0, unit_normal_z=0.0, planar_flag: bool = False, closed_flag: bool = False, polynomial_flag: bool = False, periodic_flag: bool = False, **entity_kwargs): self.upper_index_of_sum = control_points_XYZ.shape[0] - 1 self.degree = degree self.flag1 = int(planar_flag) self.flag2 = int(closed_flag) self.flag3 = int(polynomial_flag) self.flag4 = int(periodic_flag) self.knots = knots self.weights = weights self.control_points = control_points_XYZ self.v0 = start_parameter_value self.v1 = end_parameter_value self.XN = unit_normal_x self.YN = unit_normal_y self.ZN = unit_normal_z parameter_data = [ IGESParam(self.upper_index_of_sum, "int"), IGESParam(self.degree, "int"), IGESParam(self.flag1, "int"), IGESParam(self.flag2, "int"), IGESParam(self.flag3, "int"), IGESParam(self.flag4, "int"), *[IGESParam(k, "real") for k in self.knots], *[IGESParam(w, "real") for w in self.weights], *[IGESParam(xyz, "real") for xyz in self.control_points.flatten()], IGESParam(self.v0, "real"), IGESParam(self.v1, "real"), IGESParam(self.XN, "real"), IGESParam(self.YN, "real"), IGESParam(self.ZN, "real"), ] super().__init__(126, parameter_data, **entity_kwargs)
[docs] class BezierIGES(RationalBSplineCurveIGES):
[docs] def __init__(self, control_points_XYZ: np.ndarray, start_parameter_value=0.0, end_parameter_value=1.0, unit_normal_x=0.0, unit_normal_y=0.0, unit_normal_z=0.0, planar_flag: bool = False, closed_flag: bool = False, periodic_flag: bool = False, **entity_kwargs): order = len(control_points_XYZ) degree = order - 1 knots = np.concatenate((np.zeros(order), np.ones(order))) weights = np.ones(order) polynomial_flag = True super().__init__(knots=knots, weights=weights, control_points_XYZ=control_points_XYZ, degree=degree, start_parameter_value=start_parameter_value, end_parameter_value=end_parameter_value, unit_normal_x=unit_normal_x, unit_normal_y=unit_normal_y, unit_normal_z=unit_normal_z, planar_flag=planar_flag, closed_flag=closed_flag, polynomial_flag=polynomial_flag, periodic_flag=periodic_flag, **entity_kwargs)
[docs] class BoundaryCurveIGES(IGESEntity):
[docs] def __init__(self, untrimmed_surface: IGESEntity, curves: typing.Dict[IGESEntity, typing.List[IGESEntity]], preferred_representation: int = 3, curves_needing_reversal: typing.List[int] = None, **entity_kwargs ): """ IGES Type 141 """ if curves_needing_reversal is None: curves_needing_reversal = [] number_parameter_space_curves = sum([len(parameter_space_curves) for parameter_space_curves in curves.values()]) parameter_data = [ IGESParam(0 if number_parameter_space_curves == 0 else 1, "int"), IGESParam(preferred_representation, "int"), # 0 = unspecified, 1 = model space, 2 = parameter space, # 3 = representations are of equal preference IGESParam(untrimmed_surface, "pointer"), IGESParam(len(curves) + number_parameter_space_curves, "int") ] for curve_idx, (model_space_curve, parameter_space_curves) in enumerate(curves.items()): parameter_data.append(IGESParam(model_space_curve, "pointer")) parameter_data.append(IGESParam(2 if curve_idx in curves_needing_reversal else 1, "int")) parameter_data.append(IGESParam(len(parameter_space_curves), "int")) for parameter_space_curve in parameter_space_curves: parameter_data.append(IGESParam(parameter_space_curve, "pointer")) super().__init__(141, parameter_data, **entity_kwargs)
[docs] class CurveOnParametricSurfaceIGES(IGESEntity):
[docs] def __init__(self, surface: IGESEntity, parametric_curve: IGESEntity, model_space_curve: IGESEntity, **entity_kwargs): """ IGES Type 142 """ parametric_curve.status_number.value = 5 parameter_data = [ IGESParam(0, "int"), IGESParam(surface, "pointer"), IGESParam(parametric_curve, "pointer"), IGESParam(model_space_curve, "pointer"), IGESParam(3, "int") ] super().__init__(142, parameter_data, **entity_kwargs)
[docs] class CompositeCurveIGES(IGESEntity):
[docs] def __init__(self, curves: typing.List[IGESEntity], **entity_kwargs): """ IGES Type 102 """ parameter_data = [ IGESParam(len(curves), "int"), *[IGESParam(curve, "pointer") for curve in curves] ] super().__init__(102, parameter_data, **entity_kwargs)