General: configuration files#

This example shows how you can use PyAEDT to export configuration files and reuse them to import in a new project. A configuration file is supported by these apps:

  • HFSS

  • 2D Extractor and Q3D Extractor

  • Maxwell

  • Icepak

  • Mechanical

The following sections are covered:

  • Variables

  • Mesh operations (except Icepak)

  • Setup and optimetrics

  • Material properties

  • Object properties

  • Boundaries and excitations

When a boundary is attached to a face, the tool tries to match it with a FaceByPosition on the same object name on the target design. If, for any reason, this face position has changed or the object name in the target design has changed, the boundary fails to apply.

Perform required imports#

Perform required imports from PyAEDT.

import os
import tempfile
import shutil
from pyaedt import Icepak
from pyaedt import examples
from pyaedt import generate_unique_folder_name

Set non-graphical mode#

Set non-graphical mode. "PYAEDT_NON_GRAPHICAL" is needed to generate documentation only. You can set non_graphical either to True or False.

non_graphical = os.getenv("PYAEDT_NON_GRAPHICAL", "False").lower() in ("true", "1", "t")

Open project#

Download the project, open it, and save it to the temporary folder.

project_full_name = examples.download_icepak(generate_unique_folder_name("Graphic_Card"))

ipk = Icepak(project_full_name, specified_version="2022.2", new_desktop_session=True, non_graphical=non_graphical)
ipk.autosave_disable()
True

Create source blocks#

Create a source block on the CPU and memories.

ipk.create_source_block("CPU", "25W")
ipk.create_source_block(["MEMORY1", "MEMORY1_1"], "5W")
<pyaedt.modules.Boundary.BoundaryObject object at 0x0000021DF1AEDDC0>

Assign boundaries#

Assign the opening and grille.

region = ipk.modeler["Region"]
ipk.assign_openings(air_faces=region.bottom_face_x.id)
ipk.assign_grille(air_faces=region.top_face_x.id, free_area_ratio=0.8)
<pyaedt.modules.Boundary.BoundaryObject object at 0x0000021DF1A9E8E0>

Create setup#

Create the setup. Properties can be set up from the setup object with getters and setters. They don’t have to perfectly match the property syntax.

setup1 = ipk.create_setup()
setup1["FlowRegime"] = "Turbulent"
setup1["Max Iterations"] = 5
setup1["Solver Type Pressure"] = "flex"
setup1["Solver Type Temperature"] = "flex"
ipk.save_project(r"C:\temp\Graphic_card.aedt")
True

Export project to step file#

Export the current project to the step file.

filename = ipk.design_name
file_path = os.path.join(ipk.working_directory, filename + ".step")
ipk.export_3d_model(filename, ipk.working_directory, ".step", [], [])
True

Export configuration files#

Export the configuration files. You can optionally disable the export and import sections.

conf_file = ipk.configurations.export_config()
ipk.close_project()
True

Create project#

Create an Icepak project and import the step.

app = Icepak(projectname="new_proj_Ipk")
app.modeler.import_3d_cad(file_path)
True

Import and apply configuration file#

Import and apply the configuration file. You can apply all or part of the JSON file that you import using options in the configurations object.

out = app.configurations.import_config(conf_file)
app.configurations.results.global_import_success
True

Close project#

Close the project.

if os.name != "posix":
    app.release_desktop()

Total running time of the script: ( 0 minutes 28.911 seconds)

Gallery generated by Sphinx-Gallery