Public Workflow API¶
PhAST exposes a user-facing workflow API around domain nouns. The validation
and adapter layers use *Spec names internally, but users should think in
terms of problems, regions, materials, loads, steps, outputs, and results.
Public noun |
Purpose |
Primary docs |
|---|---|---|
|
Fluent authoring entry point for new models. |
|
|
Define generated geometry or import an existing mesh. |
|
|
Name physical groups, mesh sets, and reusable application regions. |
|
|
Material parameter container used by the public API and declarative adapters. |
|
|
Fluent material assignment helper for presets, constitutive parameters, and target regions. |
|
|
Seed fields such as initial damage where supported. |
|
|
Apply fix, prescribe, traction, symmetry, and Neumann-style conditions. |
|
|
Select the solution type, loading protocol, and active conditions. |
|
|
Request fields, histories, visuals, trajectories, and manifests. |
|
|
Inspect completed run directories without rerunning solvers. |
|
|
Clear error for missing result directories, unknown fields, and reserved postprocess methods. |
Authoring Boundary¶
Use the fluent phast.Problem API to author new models. Use YAML configurations for public examples, reproducibility, batch/HPC runs, and sharing exact simulations. The public examples keep YAML as the primary rerun surface until each fluent lowering path is promoted and covered by tests.
import phast
problem = (
phast.Problem("notched plate")
.mesh("mesh.msh")
.region("body", from_mesh="Domain")
.region("left", from_mesh="Left")
.region("right", from_mesh="Right")
.material("glass", region="body", E=210000.0, nu=0.3, Gc=2.7, l0=0.25)
.boundary_condition("fix", region="left", dof="x", name="clamp")
.boundary_condition("displacement", region="right", dof="y", value=0.001, name="pull")
.analysis_step(
"load",
kind="quasi_static",
controls={"protocol": "simple", "num_steps": 1},
active_boundary_conditions=["clamp", "pull"],
)
.outputs(fields=["damage", "displacement"], histories=["reaction_force"], plots=True)
)
spec = problem.to_spec()
The ProblemSpec contract is an implementation detail of the workflow layer.
It lets PhAST validate YAML, fluent Python, promoted solid-mechanics
examples, and result inspection through one common representation while
keeping the public surface centered on domain nouns rather than internal data
structures. Use the capability matrix as
the public boundary for supported workflows.
Execution Boundary¶
Supported execution routes through the curated solver paths documented in the capability matrix. Schema-v2 and fluent helpers validate and lower only where a supported runner exists. If a workflow is marked beta, scaffold, optional-backend, or unsupported, keep it out of public examples unless the corresponding contract tests and visual manifests are present.
Output Boundary¶
Every promoted public example should expose a flat, predictable result bundle:
config.yaml, run_manifest.json, visual_manifest.json, representative
PNG/MP4 artifacts, CSV histories where relevant, and Zarr-first trajectory
outputs when the run stores fields. See
Promoted example contract for the artifact
contract.