metafold package
Submodules
Module contents
- class metafold.MetafoldClient(access_token: str | None = None, project_id: str | None = None, client_id: str | None = None, client_secret: str | None = None, auth_domain: str = 'metafold3d.us.auth0.com', base_url: str = 'https://api.metafold3d.com/')
Bases:
Client
Metafold REST API client.
- projects
Sub-client for projects endpoint.
- assets
Sub-client for assets endpoint.
- jobs
Sub-client for jobs endpoint.
metafold.projects module
- class metafold.projects.Access(*values)
Bases:
Enum
Project access scope.
- PRIVATE
Project is private to owner.
- PUBLIC
Project may be accessed by unauthenticated users.
- class metafold.projects.Project(*, id: str, user: str, name: str, access: str, created: str | datetime, modified: str | datetime, thumbnail: str | None = None, project: dict[str, Any] | None = None, graph: Graph | None = None)
Bases:
object
Project resource.
- id
Project ID.
- Type:
str
- user
Project user ID.
- Type:
str
- name
Project name.
- Type:
str
- access
Project access.
- Type:
- created
Project creation datetime.
- Type:
datetime.datetime
- modified
Project last modified datetime.
- Type:
datetime.datetime
- thumbnail
URL to project thumbnail.
- Type:
str | None
- project
Arbitrary project data.
- Type:
dict[str, Any] | None
- graph
Project graph data.
- Type:
metafold.func_types.Graph | None
- class metafold.projects.ProjectsEndpoint(client: Client)
Bases:
object
Metafold projects endpoint.
- create(name: str, access: Access | str = Access.PRIVATE, data: dict[str, Any] | None = None) Project
Create a project.
- Parameters:
name – Project name.
access – Project access. By default projects are private.
data – Optional project data. This parameter accepts arbitrary JSON-serializable data. Helpful for tracking application state.
- Returns:
Project resource.
- delete(id: str) None
Delete an project.
- Parameters:
id – Override ID of project to update. Defaults to client project ID.
- duplicate(id: str, name: str, access: Access | str = Access.PRIVATE) Project
Duplicate a project.
- Parameters:
id – Project to duplicate.
name – New project name.
access – New project access. By default projects are private.
- Returns:
Project resource.
- get(id: str | None = None) Project
Get an project.
- Parameters:
id – Override ID of project to get. Defaults to client project ID.
- Returns:
Project resource.
- list(sort: str | None = None, q: str | None = None) list[Project]
List projects.
- Parameters:
sort – Sort string. For details on syntax see the Metafold API docs. Supported sorting fields are: “id”, “user”, “name”, “created”, and “modified”.
q – Query string. For details on syntax see the Metafold API docs. Supported search fields are: “id”, “user”, and “name”.
- Returns:
List of project resources.
- update(id: str | None = None, name: str | None = None, access: Access | str | None = None, data: dict[str, Any] | None = None, graph: Graph | None = None) Project
Update a project.
- Parameters:
id – Override ID of project to update. Defaults to client project ID.
name – Optional project name.
access – Optional project access.
data – Optional project data. This parameter accepts arbitrary JSON-serializable data. Helpful for tracking application state.
graph – Optional shape JSON.
- Returns:
Updated project resource.
metafold.assets module
- class metafold.assets.Asset(*, id: str, filename: str, size: int, checksum: str, created: str | datetime, modified: str | datetime, project_id: str, job_id: str | None = None)
Bases:
object
Asset resource.
- id
Asset ID.
- Type:
str
- filename
Asset filename.
- Type:
str
- size
File size in bytes.
- Type:
int
- checksum
File checksum.
- Type:
str
- created
Asset creation datetime.
- Type:
datetime.datetime
- modified
Asset last modified datetime.
- Type:
datetime.datetime
- project_id
Project ID.
- Type:
str
- job_id
Job ID.
- Type:
str | None
- class metafold.assets.AssetsEndpoint(client: Client)
Bases:
object
Metafold assets endpoint.
- create(f: str | bytes | PathLike | IO[bytes], project_id: str | None = None) Asset
Upload an asset.
- Parameters:
f – File-like object (opened in binary mode) or path to file on disk.
project_id – Asset project ID.
- Returns:
Asset resource.
- delete(asset_id: str, project_id: str | None = None) None
Delete an asset.
- Parameters:
asset_id – ID of asset to delete.
project_id – Asset project ID.
- download_file(asset_id: str, path: str | PathLike, project_id: str | None = None)
Download an asset.
- Parameters:
asset_id – ID of asset to download.
path – Path to downloaded file.
project_id – Asset project ID.
- get(asset_id: str, project_id: str | None = None) Asset
Get an asset.
- Parameters:
asset_id – ID of asset to get.
project_id – Asset project ID.
- Returns:
Asset resource.
- list(sort: str | None = None, q: str | None = None, project_id: str | None = None) list[Asset]
List assets.
- Parameters:
sort – Sort string. For details on syntax see the Metafold API docs. Supported sorting fields are: “id”, “filename”, “size”, “created”, or “modified”.
q – Query string. For details on syntax see the Metafold API docs. Supported search fields are: “id” and “filename”.
project_id – Asset project ID.
- Returns:
List of asset resources.
metafold.jobs module
- class metafold.jobs.IO(*, params: dict[str, Any] | None = None, assets=None)
Bases:
object
Job input/output.
- params
JSON-encoded parameter values.
- Type:
dict[str, Any] | None
- assets
Related assets.
- Type:
dict[str, metafold.assets.Asset] | None
- class metafold.jobs.IODict
Bases:
TypedDict
- class metafold.jobs.Job(*, id: str, name: str | None = None, type: str, state: str, created: str | datetime, started=None, finished=None, error: str | None = None, inputs, outputs, needs: list[str], project_id: str | None = None, workflow_id: str | None = None, assets=None, parameters: dict[str, Any], meta: dict[str, Any])
Bases:
object
Job resource.
- id
Job ID.
- Type:
str
- name
Job name.
- Type:
str | None
- type
Job type.
- Type:
str
- state
Job state. May be one of: pending, started, success, failure, or canceled.
- Type:
str
- created
Job creation datetime.
- Type:
datetime.datetime
- started
Job started datetime.
- Type:
datetime.datetime | None
- finished
Job finished datetime.
- Type:
datetime.datetime | None
- error
Error message for failed jobs.
- Type:
str | None
- inputs
Input assets and parameters.
- Type:
- outputs
Output assets and parameters.
- Type:
- needs
List of upstream job IDs in a workflow graph.
- Type:
list[str]
- project_id
Project ID.
- Type:
str | None
- workflow_id
Workflow ID.
- Type:
str | None
- assets
(Deprecated) List of generated asset resources.
- Type:
list[metafold.assets.Asset] | None
- parameters
(Deprecated) Job parameters.
- Type:
dict[str, Any]
- meta
(Deprecated) Additional metadata generated by the job.
- Type:
dict[str, Any]
- class metafold.jobs.JobsEndpoint(client: Client)
Bases:
object
Metafold jobs endpoint.
- delete(job_id: str, project_id: str | None = None)
Delete a job.
- Parameters:
job_id – ID of job to delete.
project_id – Job project ID.
- get(job_id: str, project_id: str | None = None) Job
Get a job.
- Parameters:
job_id – ID of job to get.
project_id – Job project ID.
- Returns:
Job resource.
- list(sort: str | None = None, q: str | None = None, project_id: str | None = None) list[Job]
List jobs.
- Parameters:
sort – Sort string. For details on syntax see the Metafold API docs. Supported sorting fields are: “id”, “name”, “created”, “started”, or “finished”.
q – Query string. For details on syntax see the Metafold API docs. Supported search fields are: “id”, “name”, “type”, and “state”.
project_id – Job project ID.
- Returns:
List of job resources.
- run(type: str, params: dict[str, Any], name: str | None = None, timeout: int | float = 120, project_id: str | None = None) Job
Dispatch a new job and wait for a result.
See Metafold API docs for the full list of jobs.
- Parameters:
type – Job type.
params – Job parameters.
name – Optional job name.
timeout – Time in seconds to wait for a result.
project_id – Job project ID.
- Returns:
Completed job resource.
- run_status(type: str, params: dict[str, Any], name: str | None = None, project_id: str | None = None) str
Dispatch a new job and return immediately without waiting for result.
See Metafold API docs for the full list of jobs.
- Parameters:
type – Job type.
params – Job parameters.
name – Optional job name.
project_id – Job project ID.
- Returns:
Job status url.
metafold.workflows module
- class metafold.workflows.Workflow(*, client: MetafoldClient, id: str, jobs: list[str] = NOTHING, state: str, created: str | datetime, started=None, finished=None, definition: str, project_id: str)
Bases:
object
Workflow resource.
- id
Workflow ID.
- Type:
str
- state
Workflow state. May be one of: pending, started, success, failure, or canceled.
- Type:
str
- created
Workflow creation datetime.
- Type:
datetime.datetime
- started
Workflow started datetime.
- Type:
datetime.datetime | None
- finished
Workflow finished datetime.
- Type:
datetime.datetime | None
- definition
Workflow definition string.
- Type:
str
- project_id
Project ID.
- Type:
str
- get_asset(path: str) Asset | None
Retrieve an asset from the workflow by dot notation.
- Parameters:
path – Path to asset in the form “job.name”, e.g. “sample-mesh.volume” searches for the asset “volume” from the “sample-mesh” job.
- get_parameter(path: str) str | None
Retrieve a parameter from the workflow by dot notation.
- Parameters:
path – Path to parameter in the form “job.name”, e.g. “sample-mesh.patch_size” searches for the parameter “patch_size” from the “sample-mesh” job.
- class metafold.workflows.WorkflowsEndpoint(client: Client)
Bases:
object
Metafold workflows endpoint.
- cancel(workflow_id: str, project_id: str | None = None) Workflow
Cancel a running workflow.
- Parameters:
workflow_id – ID of workflow to cancel.
project_id – Workflow project ID.
- Returns:
Workflow resource.
- delete(workflow_id: str, project_id: str | None = None)
Delete a workflow.
- Parameters:
workflow_id – ID of workflow to delete.
project_id – Workflow project ID.
- get(workflow_id: str, project_id: str | None = None) Workflow
Get a workflow.
- Parameters:
workflow_id – ID of workflow to get.
project_id – Workflow project ID.
- Returns:
Workflow resource.
- list(sort: str | None = None, q: str | None = None, project_id: str | None = None) list[Workflow]
List jobs.
- Parameters:
sort – Sort string. For details on syntax see the Metafold API docs. Supported sorting fields are: “id”, “created”, “started”, or “finished”.
q – Query string. For details on syntax see the Metafold API docs. Supported search fields are: “id” and “state”.
project_id – Workflow project ID.
- Returns:
List of job resources.
- run(definition: str, parameters: dict[str, str] | None = None, assets: dict[str, str] | None = None, timeout: int | float = 120, project_id: str | None = None) Workflow
Dispatch a new workflow and wait for it to complete.
Workflow completion does not indicate success. Access the completed workflow’s state to check for success/failure.
- Parameters:
definition – Workflow definition YAML.
parameters – Parameter mapping for jobs in the definition.
assets – Asset mapping for jobs in the definition.
timeout – Time in seconds to wait for a result.
project_id – Workflow project ID.
- Returns:
Completed workflow resource.
metafold.client module
- class metafold.client.Client(base_url: str, access_token: str | None = None, project_id: str | None = None, auth: AuthProvider | None = None)
Bases:
object
Base client.
- poll(url: str, timeout: int | float = 120, every: int | float = 1) Response
Poll the given URL in regular intervals.
Helpful for waiting on async processes given a status URL.
- Parameters:
timeout – Time in seconds to wait for a result.
every – Frequency in seconds.
- Returns:
HTTP response.
metafold.func module
- metafold.func.BoxFramePrimitive(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: SampleBox_Parameters | None = None) TypedFunc[Literal[FuncType.FLOAT]]
- metafold.func.BoxPrimitive(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: SampleBox_Parameters | None = None) TypedFunc[Literal[FuncType.FLOAT]]
- class metafold.func.CSG(a: TypedFunc[Literal[FuncType.FLOAT]], b: TypedFunc[Literal[FuncType.FLOAT]], parameters: CSG_Parameters | None = None)
Bases:
TypedFunc
[Literal
[FLOAT
]]
- metafold.func.CSGIntersect(a: TypedFunc[Literal[FuncType.FLOAT]], b: TypedFunc[Literal[FuncType.FLOAT]], smoothing: float | None = None) TypedFunc[Literal[FuncType.FLOAT]]
- metafold.func.CSGSubtract(a: TypedFunc[Literal[FuncType.FLOAT]], b: TypedFunc[Literal[FuncType.FLOAT]], smoothing: float | None = None) TypedFunc[Literal[FuncType.FLOAT]]
- metafold.func.CSGUnion(a: TypedFunc[Literal[FuncType.FLOAT]], b: TypedFunc[Literal[FuncType.FLOAT]], smoothing: float | None = None) TypedFunc[Literal[FuncType.FLOAT]]
- class metafold.func.CSG_Parameters
Bases:
TypedDict
- operation: Literal['Intersect', 'Subtract', 'Union']
- smoothing: float
- metafold.func.CappedConePrimitive(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: SampleBox_Parameters | None = None) TypedFunc[Literal[FuncType.FLOAT]]
- metafold.func.CapsulePrimitive(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: SampleBox_Parameters | None = None) TypedFunc[Literal[FuncType.FLOAT]]
- class metafold.func.ComputeCurvatures(samples: Func, parameters: ComputeCurvatures_Parameters | None = None)
Bases:
TypedFunc
[Literal
[VEC3F
]]
- class metafold.func.ComputeCurvatures_Parameters
Bases:
TypedDict
- spacing_type: Literal['Continuous', 'Discrete']
- step_size: float
- volume_size: Annotated[list[float], 3] | ndarray[tuple[Literal[3]], dtype[float32]]
- class metafold.func.ComputeNormals(samples: Func, parameters: ComputeNormals_Parameters | None = None)
Bases:
TypedFunc
[Literal
[VEC3F
]]
- class metafold.func.ComputeNormals_Parameters
Bases:
TypedDict
- spacing_type: Literal['Continuous', 'Discrete']
- step_size: float
- volume_size: Annotated[list[float], 3] | ndarray[tuple[Literal[3]], dtype[float32]]
- metafold.func.CylinderPrimitive(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: SampleBox_Parameters | None = None) TypedFunc[Literal[FuncType.FLOAT]]
- metafold.func.EllipsoidPrimitive(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: SampleBox_Parameters | None = None) TypedFunc[Literal[FuncType.FLOAT]]
- class metafold.func.GenerateSamplePoints(parameters: GenerateSamplePoints_Parameters | None = None)
Bases:
TypedFunc
[Literal
[VEC3F
]]
- class metafold.func.GenerateSamplePoints_Parameters
Bases:
TypedDict
- offset: Annotated[list[float], 3] | ndarray[tuple[Literal[3]], dtype[float32]]
- resolution: Annotated[list[int], 3] | ndarray[tuple[Literal[3]], dtype[int32]]
- size: Annotated[list[float], 3] | ndarray[tuple[Literal[3]], dtype[float32]]
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- class metafold.func.GradeCellSize(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: GradeCellSize_Parameters | None = None)
Bases:
TypedFunc
[Literal
[VEC3F
]]
- class metafold.func.GradeCellSize_Parameters
Bases:
TypedDict
- num_steps: int
- offset: float
- shape_size: Annotated[list[float], 3] | ndarray[tuple[Literal[3]], dtype[float32]]
- shape_type: Literal['Box', 'Cylinder', 'Ellipsoid', 'Plane']
- shape_xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- step_size: float
- width: float
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- class metafold.func.InterpolateBoundaryCoords(points: TypedFunc[Literal[FuncType.VEC3F]], boundary_data: ParametrizationAsset, mesh_data: TriangleMeshAsset, parameters: InterpolateBoundaryCoords_Parameters | None = None)
Bases:
TypedFunc
[Literal
[VEC3F
]]
- class metafold.func.InterpolateBoundaryCoords_Parameters
Bases:
TypedDict
- tolerance: float
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- class metafold.func.LinearFilter(inputa: TypedFunc[Literal[FuncType.FLOAT]], inputb: TypedFunc[Literal[FuncType.FLOAT]], parameters: LinearFilter_Parameters | None = None)
Bases:
TypedFunc
[Literal
[FLOAT
]]
- metafold.func.LinkPrimitive(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: SampleBox_Parameters | None = None) TypedFunc[Literal[FuncType.FLOAT]]
- class metafold.func.LoadSamplePoints(parameters: LoadSamplePoints_Parameters | None = None)
Bases:
TypedFunc
[Literal
[VEC3F
]]
- class metafold.func.LoadSamplePoints_Parameters
Bases:
TypedDict
- points: list[Annotated[list[float], 3] | ndarray[tuple[Literal[3]], dtype[float32]]] | ndarray
- class metafold.func.LoadVolume(volume_data: VolumeAsset, parameters: LoadVolume_Parameters | None = None)
Bases:
Func
- class metafold.func.LoadVolume_Parameters
Bases:
TypedDict
- component_type: Literal['Byte', 'Float', 'Integer', 'None', 'Vec2f', 'Vec2i', 'Vec3f', 'Vec3i', 'Vec4f', 'Vec4i']
- resolution: Annotated[list[int], 3] | ndarray[tuple[Literal[3]], dtype[int32]]
- class metafold.func.MapTexturePrimitive(points: TypedFunc[Literal[FuncType.VEC3F]], image: TypedFunc[Literal[FuncType.FLOAT]], parameters: MapTexturePrimitive_Parameters | None = None)
Bases:
TypedFunc
[Literal
[VEC3F
]]
- class metafold.func.MapTexturePrimitive_Parameters
Bases:
TypedDict
- box_width: Annotated[list[float], 3] | ndarray[tuple[Literal[3]], dtype[float32]]
- scale: Annotated[list[float], 2] | ndarray[tuple[Literal[2]], dtype[float32]]
- shape_type: Literal['Box', 'Cylinder', 'Ellipsoid', 'Plane']
- shape_xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- metafold.func.PlanePrimitive(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: SampleBox_Parameters | None = None) TypedFunc[Literal[FuncType.FLOAT]]
- metafold.func.PointSource(eval_: Evaluator) TypedResult[Literal[FuncType.VEC3F]]
- class metafold.func.Redistance(samples: TypedFunc[Literal[FuncType.FLOAT]], parameters: Redistance_Parameters | None = None)
Bases:
TypedFunc
[Literal
[FLOAT
]]
- class metafold.func.SampleBeam(points: TypedFunc[Literal[FuncType.VEC3F]], bvh_data: LineNetworkBvhAsset, network_data: LineNetworkAsset, parameters: SampleBeam_Parameters | None = None)
Bases:
TypedFunc
[Literal
[FLOAT
]]
- class metafold.func.SampleBeam_Parameters
Bases:
TypedDict
- node_radius: float
- node_type: Literal['None', 'Sphere']
- section_radius: float
- section_type: Literal['Box', 'Circle', 'Cross']
- smoothing: float
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- class metafold.func.SampleBox(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: SampleBox_Parameters | None = None)
Bases:
TypedFunc
[Literal
[FLOAT
]]
- class metafold.func.SampleBox_Parameters
Bases:
TypedDict
- free_param: float
- shape_type: Literal['Box', 'BoxFrame', 'CappedCone', 'Capsule', 'Cylinder', 'Ellipsoid', 'Link', 'Plane', 'Torus']
- size: Annotated[list[float], 3] | ndarray[tuple[Literal[3]], dtype[float32]]
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- class metafold.func.SampleCustomShape(points: TypedFunc[Literal[FuncType.VEC3F]], shader_data: CustomShapeAsset, parameters: SampleCustomShape_Parameters | None = None)
Bases:
TypedFunc
[Literal
[FLOAT
]]
- class metafold.func.SampleCustomShape_Parameters
Bases:
TypedDict
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- class metafold.func.SampleLattice(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: SampleLattice_Parameters | None = None)
Bases:
TypedFunc
[Literal
[FLOAT
]]
- class metafold.func.SampleLattice_Parameters
Bases:
TypedDict
- lattice_data: UnitCell
- node_radius: float
- node_type: Literal['None', 'Sphere']
- scale: Annotated[list[float], 3] | ndarray[tuple[Literal[3]], dtype[float32]]
- scale_grading_range: Annotated[list[float], 2] | ndarray[tuple[Literal[2]], dtype[float32]]
- scale_grading_scale: Annotated[list[float], 2] | ndarray[tuple[Literal[2]], dtype[float32]]
- section_radius: float
- section_radius_grading_range: Annotated[list[float], 2] | ndarray[tuple[Literal[2]], dtype[float32]]
- section_radius_grading_scale: Annotated[list[float], 2] | ndarray[tuple[Literal[2]], dtype[float32]]
- section_type: Literal['Box', 'Circle', 'Cross']
- smoothing: float
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- class metafold.func.SampleSpinodoid(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: SampleSpinodoid_Parameters | None = None)
Bases:
TypedFunc
[Literal
[FLOAT
]]
- class metafold.func.SampleSpinodoid_Parameters
Bases:
TypedDict
- angles: Annotated[list[float], 3] | ndarray[tuple[Literal[3]], dtype[float32]]
- density: float
- pore_size: float
- wave_count: int
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- class metafold.func.SampleSurfaceLattice(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: SampleSurfaceLattice_Parameters | None = None)
Bases:
TypedFunc
[Literal
[FLOAT
]]
- class metafold.func.SampleSurfaceLattice_Parameters
Bases:
TypedDict
- lattice_type: Literal['CD', 'CI2Y', 'CP', 'CPM_Y', 'CS', 'CY', 'C_Y', 'D', 'F', 'FRD', 'Gyroid', 'I2Y', 'IWP', 'None', 'P', 'PM_Y', 'S', 'SD1', 'Schwarz', 'SchwarzD', 'SchwarzN', 'SchwarzPW', 'SchwarzW', 'W', 'Y']
- scale: Annotated[list[float], 3] | ndarray[tuple[Literal[3]], dtype[float32]]
- scale_grading_range: Annotated[list[float], 2] | ndarray[tuple[Literal[2]], dtype[float32]]
- scale_grading_scale: Annotated[list[float], 2] | ndarray[tuple[Literal[2]], dtype[float32]]
- threshold: float
- threshold_grading_offset: Annotated[list[float], 2] | ndarray[tuple[Literal[2]], dtype[float32]]
- threshold_grading_range: Annotated[list[float], 2] | ndarray[tuple[Literal[2]], dtype[float32]]
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- class metafold.func.SampleTriangleMesh(points: TypedFunc[Literal[FuncType.VEC3F]], mesh_data: TriangleMeshAsset, parameters: SampleTriangleMesh_Parameters | None = None)
Bases:
TypedFunc
[Literal
[FLOAT
]]
- class metafold.func.SampleTriangleMeshBvh(points: TypedFunc[Literal[FuncType.VEC3F]], bvh_data: MeshBvhAsset, mesh_data: TriangleMeshAsset, parameters: SampleTriangleMeshBvh_Parameters | None = None)
Bases:
TypedFunc
[Literal
[FLOAT
]]
- class metafold.func.SampleTriangleMeshBvh_Parameters
Bases:
TypedDict
- cw_winding: int
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- class metafold.func.SampleTriangleMesh_Parameters
Bases:
TypedDict
- cw_winding: int
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- class metafold.func.SampleVolume(points: TypedFunc[Literal[FuncType.VEC3F]], volume: Func, parameters: SampleVolume_Parameters | None = None)
Bases:
Func
- class metafold.func.SampleVolume_Parameters
Bases:
TypedDict
- volume_offset: Annotated[list[float], 3] | ndarray[tuple[Literal[3]], dtype[float32]]
- volume_size: Annotated[list[float], 3] | ndarray[tuple[Literal[3]], dtype[float32]]
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- class metafold.func.Shell(samples: TypedFunc[Literal[FuncType.FLOAT]], parameters: Shell_Parameters | None = None)
Bases:
TypedFunc
[Literal
[FLOAT
]]
- class metafold.func.Threshold(samples: TypedFunc[Literal[FuncType.FLOAT]], parameters: Threshold_Parameters | None = None)
Bases:
TypedFunc
[Literal
[BYTE
]]
- metafold.func.TorusPrimitive(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: SampleBox_Parameters | None = None) TypedFunc[Literal[FuncType.FLOAT]]
- class metafold.func.TransformCylindricalCoords(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: TransformCylindricalCoords_Parameters | None = None)
Bases:
TypedFunc
[Literal
[VEC3F
]]
- class metafold.func.TransformCylindricalCoords_Parameters
Bases:
TypedDict
- radial_scale: float
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- class metafold.func.TransformMirrorCoords(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: TransformMirrorCoords_Parameters | None = None)
Bases:
TypedFunc
[Literal
[VEC3F
]]
- class metafold.func.TransformMirrorCoords_Parameters
Bases:
TypedDict
- mirror_normal: Annotated[list[float], 3] | ndarray[tuple[Literal[3]], dtype[float32]]
- mirror_point: Annotated[list[float], 3] | ndarray[tuple[Literal[3]], dtype[float32]]
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- class metafold.func.TransformSphericalCoords(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: TransformSphericalCoords_Parameters | None = None)
Bases:
TypedFunc
[Literal
[VEC3F
]]
- class metafold.func.TransformSphericalCoords_Parameters
Bases:
TypedDict
- xform: Annotated[list[float], 16] | ndarray[tuple[Literal[4], Literal[4]], dtype[float32]]
- class metafold.func.TransformTwistCoords(points: TypedFunc[Literal[FuncType.VEC3F]], parameters: TransformTwistCoords_Parameters | None = None)
Bases:
TypedFunc
[Literal
[VEC3F
]]
metafold.exceptions module
- exception metafold.exceptions.PollTimeout
Bases:
Exception
Raised when a dispatched job failed to complete within expected time.