Source code for pyleecan.GUI.Dialog.DMachineSetup.SMSlot.PMSlot10.PMSlot10

# -*- coding: utf-8 -*-

import PySide2.QtCore
from numpy import pi
from PySide2.QtCore import Signal
from PySide2.QtWidgets import QWidget
from PySide2.QtGui import QPixmap
from ......Classes.SlotM10 import SlotM10
from ......GUI import gui_option
from ......GUI.Dialog.DMachineSetup.SMSlot.PMSlot10.Gen_PMSlot10 import Gen_PMSlot10
from ......Methods.Slot.Slot import SlotCheckError

translate = PySide2.QtCore.QCoreApplication.translate


[docs]class PMSlot10(Gen_PMSlot10, QWidget): """Page to set the Slot Magnet Type 10""" # Signal to DMachineSetup to know that the save popup is needed saveNeeded = Signal() # Information for Slot combobox slot_name = "Rectangular Magnet" notch_name = "Rectangular" slot_type = SlotM10 def __init__(self, lamination=None, is_notch=False): """Initialize the widget according to lamination Parameters ---------- self : PMSlot10 A PMSlot10 widget lamination : Lamination current lamination to edit is_notch : bool True to adapt the slot GUI for the notch setup """ # Build the interface according to the .ui file QWidget.__init__(self) self.setupUi(self) self.lamination = lamination self.slot = lamination.slot self.is_notch = is_notch # Set FloatEdit unit self.lf_W0.unit = "m" self.lf_Wmag.unit = "m" self.lf_H0.unit = "m" self.lf_Hmag.unit = "m" # Set unit name (m ou mm) wid_list = [ self.unit_W0, self.unit_Wmag, self.unit_H0, self.unit_Hmag, ] for wid in wid_list: wid.setText("[" + gui_option.unit.get_m_name() + "]") # Notch setup if is_notch: # Hide magnet related widget wid_list = [self.in_Wmag, self.lf_Wmag, self.unit_Wmag] wid_list += [self.in_Hmag, self.lf_Hmag, self.unit_Hmag] wid_list += [self.txt_constraint] # Constraint Wmag < W0 for wid in wid_list: wid.hide() # Set values for check self.slot.Hmag = 0 self.slot.Wmag = 0 # Selecting the right image if not self.lamination.is_internal: # Use schematics on the external without magnet self.img_slot.setPixmap( QPixmap( u":/images/images/MachineSetup/WMSlot/SlotM10_empty_ext_sta.png" ) ) else: # Use schematics on the inner without magnet self.img_slot.setPixmap( QPixmap( u":/images/images/MachineSetup/WMSlot/SlotM10_empty_int_rot.png" ) ) # Fill the fields with the machine values (if they're filled) self.lf_W0.setValue(self.slot.W0) self.lf_Wmag.setValue(self.slot.Wmag) self.lf_H0.setValue(self.slot.H0) self.lf_Hmag.setValue(self.slot.Hmag) # Display the main output of the slot (surface, height...) self.w_out.comp_output() # Connect the signal self.lf_W0.editingFinished.connect(self.set_W0) self.lf_Wmag.editingFinished.connect(self.set_Wmag) self.lf_H0.editingFinished.connect(self.set_H0) self.lf_Hmag.editingFinished.connect(self.set_Hmag)
[docs] def set_W0(self): """Signal to update the value of W0 according to the line edit Parameters ---------- self : PMSlot10 A PMSlot10 object """ self.slot.W0 = self.lf_W0.value() self.w_out.comp_output() # Notify the machine GUI that the machine has changed self.saveNeeded.emit()
[docs] def set_Wmag(self): """Signal to update the value of Wmag according to the line edit Parameters ---------- self : PMSlot10 A PMSlot10 object """ self.slot.Wmag = self.lf_Wmag.value() self.w_out.comp_output() # Notify the machine GUI that the machine has changed self.saveNeeded.emit()
[docs] def set_H0(self): """Signal to update the value of H0 according to the line edit Parameters ---------- self : PMSlot10 A PMSlot10 object """ self.slot.H0 = self.lf_H0.value() self.w_out.comp_output() # Notify the machine GUI that the machine has changed self.saveNeeded.emit()
[docs] def set_Hmag(self): """Signal to update the value of Hmag according to the line edit Parameters ---------- self : PMSlot10 A PMSlot10 object """ self.slot.Hmag = self.lf_Hmag.value() self.w_out.comp_output() # Notify the machine GUI that the machine has changed self.saveNeeded.emit()
[docs] @staticmethod def check(lam): """Check that the current machine have all the needed field set Parameters ---------- lam: LamSlotMag Lamination to check Returns ------- error: str Error message (return None if no error) """ # Check that everything is set if lam.slot.W0 is None: return "You must set W0 !" elif lam.slot.Wmag is None: return "You must set Wmag !" elif lam.slot.H0 is None: return "You must set H0 !" elif lam.slot.Hmag is None: return "You must set Hmag !" # Constraints try: lam.slot.check() except SlotCheckError as error: return str(error) # Output try: yoke_height = lam.comp_height_yoke() except Exception as error: return "Unable to compute yoke height:" + str(error) if yoke_height <= 0: return "The slot height is greater than the lamination !"