57 lines
94 KiB
Markdown
57 lines
94 KiB
Markdown
![]() |
---
|
||
|
title: "subtract"
|
||
|
excerpt: "Subtract removes tool solids from base solids, leaving the remaining material."
|
||
|
layout: manual
|
||
|
---
|
||
|
|
||
|
**WARNING:** This function is deprecated.
|
||
|
|
||
|
Subtract removes tool solids from base solids, leaving the remaining material.
|
||
|
|
||
|
Performs a boolean subtraction operation, removing the volume of one or more tool solids from one or more base solids. The result is a new solid representing the material that remains after all tool solids have been cut away. This function is essential for machining simulations, cavity creation, and complex multi-body part modeling.
|
||
|
|
||
|
```js
|
||
|
subtract(
|
||
|
solids: [Solid],
|
||
|
tools: [Solid],
|
||
|
): [Solid]
|
||
|
```
|
||
|
|
||
|
|
||
|
### Arguments
|
||
|
|
||
|
| Name | Type | Description | Required |
|
||
|
|----------|------|-------------|----------|
|
||
|
| `solids` | [`[Solid]`](/docs/kcl/types/Solid) | The solids to intersect. | Yes |
|
||
|
| `tools` | [`[Solid]`](/docs/kcl/types/Solid) | The solids to subtract. | Yes |
|
||
|
|
||
|
### Returns
|
||
|
|
||
|
[`[Solid]`](/docs/kcl/types/Solid)
|
||
|
|
||
|
|
||
|
### Examples
|
||
|
|
||
|
```js
|
||
|
fn cube(center) {
|
||
|
return startSketchOn('XY')
|
||
|
|> startProfileAt([center[0] - 10, center[1] - 10], %)
|
||
|
|> line(endAbsolute = [center[0] + 10, center[1] - 10])
|
||
|
|> line(endAbsolute = [center[0] + 10, center[1] + 10])
|
||
|
|> line(endAbsolute = [center[0] - 10, center[1] + 10])
|
||
|
|> close()
|
||
|
|> extrude(length = 10)
|
||
|
}
|
||
|
|
||
|
part001 = cube([0, 0])
|
||
|
part002 = startSketchOn('XY')
|
||
|
|> circle(center = [0, 0], radius = 2)
|
||
|
|> extrude(length = 10)
|
||
|
|
||
|
subtractedPart = subtract([part001], tools = [part002])
|
||
|
```
|
||
|
|
||
|
![Rendered example of subtract 0](
|
||
|
|
||
|
|