Source code for pyleecan.Methods.Slot.SlotMFlat.build_geometry
# -*- coding: utf-8 -*-
from numpy import exp
from ....Classes.Arc2 import Arc2
from ....Classes.Segment import Segment
[docs]def build_geometry(self):
    """Compute the curve (Line) needed to plot the Slot.
    The ending point of a curve is always the starting point of the next curve
    in the list
    Parameters
    ----------
    self : SlotMFlat
        A SlotMFlat object
    Returns
    -------
    curve_list: list
        A list of 3 Segment for each slot + W3 arc
    """
    Rbo = self.get_Rbo()
    alpha = self.comp_angle_opening()
    alpha_mag = self.comp_angle_opening_magnet()
    # Point coordinate for a slot center on Ox
    Z1 = Rbo * exp(-1j * alpha_mag / 2)
    Z2 = Rbo * exp(1j * alpha_mag / 2)
    if self.is_outwards():
        Z3 = Z1 + self.H0
        Z4 = Z2 + self.H0
    else:
        Z3 = Z1 - self.H0
        Z4 = Z2 - self.H0
    # Curve list of a single slot
    curve_list = list()
    if self.H0 > 0:
        curve_list.append(Segment(Z1, Z3))
    curve_list.append(Segment(Z3, Z4))
    if self.H0 > 0:
        curve_list.append(Segment(Z4, Z2))
    # Complete curve list for all the slots (for one pole)
    slot_list = list()
    for ii in range(len(self.magnet)):
        # Compute angle of the middle of the slot
        beta = -alpha / 2 + alpha_mag / 2 + ii * (self.W3 + alpha_mag)
        # Duplicate and rotate the slot + bore for each slot
        for line in curve_list:
            new_line = type(line)(init_dict=line.as_dict())
            new_line.rotate(beta)
            slot_list.append(new_line)
        if ii != len(self.magnet) - 1:  # Add the W3 except for the last slot
            slot_list.append(Arc2(slot_list[-1].get_end(), 0, self.W3))
    return slot_list