Prism example#
This tutorial demonstrates how to run a prism use case.
[1]:
import os
from pathlib import Path
from ansys.speos.core import Project, Speos
from ansys.speos.core.sensor import SensorIrradiance
from ansys.speos.core.simulation import SimulationDirect
# If using docker container
assets_data_path = Path("/app") / "assets"
# If using local server
# assets_data_path = Path().resolve().parent.parent / "tests" / "assets"
# If using a different path
# assets_data_path = Path("path/to/downloaded/example/assets")
Create connection with speos rpc server#
[2]:
speos = Speos(host="localhost", port=50098)
Create project#
Load a project from .speos file.
[3]:
p = Project(speos=speos, path=str(assets_data_path / "Prism.speos" / "Prism.speos"))
print(p)
{
"name": "Prism",
"description": "From /app/assets/Prism.speos/Prism.speos",
"part_guid": "2fab6897-c2f8-4510-885a-5a5e1b8a37bf",
"sources": [
{
"name": "Surface.1:7758",
"metadata": {
"UniqueId": "04110e6f-4045-4d42-bd69-c2024771b62b"
},
"source_guid": "56b5d15d-4688-40af-8c49-586622715937",
"description": "",
"source": {
"name": "Surface.1:7758",
"surface": {
"radiant_flux": {
"radiant_value": 8.346636625511586
},
"intensity_guid": "2678a7ab-e5f1-4088-a684-f1b0243dd950",
"exitance_constant": {
"geo_paths": [
{
"geo_path": "SourceBody:1801986974/face.1:544289899",
"reverse_normal": false
}
]
},
"spectrum_guid": "cb2128a5-8625-43b4-9841-a9c799157979",
"intensity": {
"cos": {
"N": 1.0,
"total_angle": 0.1
},
"name": "",
"description": "",
"metadata": {}
},
"spectrum": {
"blackbody": {
"temperature": 5000.0
},
"name": "",
"description": "",
"metadata": {}
}
},
"description": "",
"metadata": {}
}
}
],
"sensors": [
{
"name": "Irradiance.1:564",
"metadata": {
"UniqueId": "5c7bc6ad-d9b9-41a1-aaa2-e6e292ee5c9b"
},
"sensor_guid": "3b599e0b-f0c6-456f-aed3-c43be02b8114",
"result_file_name": "Prism.Irradiance.1",
"description": "",
"sensor": {
"irradiance_sensor_template": {
"sensor_type_spectral": {
"wavelengths_range": {
"w_start": 380.0,
"w_end": 780.0,
"w_sampling": 41
}
},
"illuminance_type_planar": {},
"dimensions": {
"x_start": -20.0,
"x_end": 20.0,
"x_sampling": 400,
"y_start": -5.0,
"y_end": 5.0,
"y_sampling": 100
},
"axis_system": [
921.3551052231927,
0.0,
388.72197015239516,
-0.3887219701523952,
-0.0,
0.9213551052231927,
0.0,
1.0000000000000002,
0.0,
-0.9213551052231927,
0.0,
-0.3887219701523952
],
"layer_type_none": {},
"ray_file_type": "RayFileNone",
"integration_direction": []
},
"name": "Irradiance.1:564",
"description": "",
"metadata": {}
}
}
],
"simulations": [
{
"name": "Prism",
"metadata": {
"UniqueId": "87fe1360-96b5-4d92-8f21-85474ca8b9b5"
},
"simulation_guid": "9d462be5-c395-44be-9613-70d9a72fcc8b",
"sensor_paths": [
"Irradiance.1:564"
],
"source_paths": [
"Surface.1:7758"
],
"description": "",
"simulation": {
"direct_mc_simulation_template": {
"geom_distance_tolerance": 0.05,
"max_impact": 100,
"weight": {
"minimum_energy_percentage": 0.005
},
"dispersion": true,
"colorimetric_standard": "CIE_1931",
"fast_transmission_gathering": false,
"ambient_material_uri": ""
},
"name": "Prism",
"metadata": {},
"description": "",
"scene_guid": "0d1a1b55-734b-4fbd-b475-9d0530c4b8b5",
"simulation_path": "Prism",
"job_type": "CPU"
}
}
],
"materials": [
{
"name": "Material.1",
"metadata": {
"UniqueId": "8193f69f-891f-4f06-b319-3a120a4a83f2"
},
"sop_guids": [
"3882cc38-6f1d-46ea-b287-601af5c96f5f"
],
"geometries": {
"geo_paths": [
"SourceBody:1801986974/face.1:544289899",
"SourceBody:1801986974/face.1:2282175023",
"SourceBody:1801986974/face.1:2503270562",
"SourceBody:1801986974/face.1:2272456582",
"SourceBody:1801986974/face.1:1596341914",
"SourceBody:1801986974/face.1:387288686"
]
},
"description": "",
"sops": [
{
"mirror": {
"reflectance": 0.0
},
"name": "",
"description": "",
"metadata": {}
}
]
},
{
"name": "Material.2",
"metadata": {
"UniqueId": "11525230-b244-40c4-b523-11ba4c1e8a06"
},
"vop_guid": "5be7620e-6645-42d4-8648-5d683c88643a",
"sop_guids": [
"df5abc59-2232-4068-bb32-097896ad07be"
],
"geometries": {
"geo_paths": [
"PrismBody:1130610277"
]
},
"description": "",
"vop": {
"optic": {
"index": 1.5,
"absorption": 0.001,
"constringence": 60.0
},
"name": "",
"description": "",
"metadata": {}
},
"sops": [
{
"optical_polished": {},
"name": "",
"description": "",
"metadata": {}
}
]
},
{
"name": "Material.3",
"metadata": {
"UniqueId": "473e8566-c76e-48ef-97b7-f03e4c02345a"
},
"sop_guids": [
"c4e8fcb4-f402-4453-9a33-9282dfb66a06"
],
"geometries": {
"geo_paths": [
"PrismBody:1130610277/face.1:242396665"
]
},
"description": "",
"sops": [
{
"library": {
"sop_file_uri": "/app/assets/Prism.speos/transparent_ad06-07cb-a92e-7815..scattering"
},
"name": "",
"description": "",
"metadata": {}
}
]
},
{
"name": "Material.4",
"metadata": {
"UniqueId": "733e0c2a-b545-4187-a12e-293a96d6ffad"
},
"vop_guid": "3b6ebfbc-b620-423d-b777-513bafb97e09",
"description": "",
"sop_guids": [],
"vop": {
"optic": {
"index": 1.0,
"absorption": 0.0
},
"name": "",
"description": "",
"metadata": {}
}
}
],
"metadata": {},
"scenes": []
}
Preview.#
[4]:
p.preview()
Retrieve the simulation feature and open result#
Run the simulation
[5]:
sim_features = p.find(name="Prism", feature_type=SimulationDirect)
sim = sim_features[0]
sim.compute_CPU()
[5]:
[upload_response {
info {
uri: "41514695-26a8-4c61-9e93-160b769e3429"
file_name: "Prism.Irradiance.1.xmp"
file_size: 1568839
}
upload_duration {
nanos: 4704755
}
}
, upload_response {
info {
uri: "f73b4d8b-98a2-4368-89c5-e7e6db14d781"
file_name: "Prism.html"
file_size: 65397
}
upload_duration {
nanos: 259626
}
}
]
Use the open_result_image method to review the result
[6]:
if os.name == "nt":
from ansys.speos.core.workflow.open_result import open_result_image
open_result_image(simulation_feature=sim, result_name="Prism.Irradiance.1.xmp")
Work with sensor#
Retrieve the sensor feature.
Modify the sensor setting, e.g. set the spectral type, etc.
[7]:
irr_features = p.find(name=".*", name_regex=True, feature_type=SensorIrradiance)
irr = irr_features[0]
irr.set_type_spectral().set_wavelengths_range().set_start(500).set_end(600).set_sampling(11)
irr.commit()
[7]:
<ansys.speos.core.sensor.SensorIrradiance at 0x7fe85be66a70>
Re-run the simulation with new sensor definition#
[8]:
sim.compute_CPU()
if os.name == "nt":
open_result_image(simulation_feature=sim, result_name="Prism.Irradiance.1.xmp")