Source code for pyleecan.Methods.Slot.SlotUD.get_surface_wind

from numpy import arcsin, exp

from ....Classes.Segment import Segment
from ....Classes.Arc1 import Arc1
from ....Classes.SurfLine import SurfLine


[docs]def get_surface_wind(self, alpha=0, delta=0): """Return the full winding surface Parameters ---------- self : SlotUD A SlotUD object alpha : float float number for rotation (Default value = 0) [rad] delta : complex complex number for translation (Default value = 0) Returns ------- surf_wind: Surface Surface corresponding to the Winding Area """ # get the name of the lamination st = self.get_name_lam() line_list = self.build_geometry()[self.wind_begin_index : self.wind_end_index] if self.type_line_wind == 0: line_list.append( Segment(begin=line_list[-1].get_end(), end=line_list[0].get_begin()) ) else: line_list.append( Arc1( begin=line_list[-1].get_end(), end=line_list[0].get_begin(), radius=-abs(line_list[-1].get_end()), is_trigo_direction=False, ) ) surface = SurfLine(line_list=line_list, label="Wind_" + st + "_R0_T0_S0") surface.comp_point_ref(is_set=True) # Apply transformation surface.rotate(alpha) surface.translate(delta) return surface