Source code for pyleecan.Methods.Simulation.Simu1.run_single

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

from ....Methods.Simulation.Input import InputError
from ....Classes.PostFunction import PostFunction
from ....Classes.PostMethod import PostMethod


def run_single(self):
    """Run the simulation

    Parameters
    ----------
    self : Simu1
        A Simu1 object

    """
    logger = self.get_logger()

    if self.parent is None:
        raise InputError("ERROR: Simulation object must be inside an Output object")
    output = self.parent
    output.geo = self.machine.comp_output_geo()

    # Init the input of the first module
    self.input.gen_input()

    # Run the modules
    if self.elec is not None:
        self.elec.run()
    if self.mag is not None:
        self.mag.run()

    if self.force is not None:
        self.force.run()
    # if self.HT is not None:
    #     self.HT.run()
    if self.struct is not None:
        self.struct.run()
    # if self.ac is not None:
    #     self.ac.run()

    if self.loss is not None:
        self.loss.run()
    # Running postprocessings

    if self.postproc_list:
        logger.info("Running simulation postprocessings...")
        for postproc in self.postproc_list:
            postproc.run(output)