Skip to content

Commit

Permalink
v3.0 edits (#3743)
Browse files Browse the repository at this point in the history
Co-authored-by: Naomi Pentrel <[email protected]>
  • Loading branch information
sguequierre and npentrel authored Dec 16, 2024
1 parent 5250fe6 commit bb06e29
Show file tree
Hide file tree
Showing 27 changed files with 3,445 additions and 169 deletions.
Binary file added assets/services/data/time-series.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
10 changes: 10 additions & 0 deletions docs/data-ai/_index.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,3 +8,13 @@ no_list: true
open_on_desktop: true
overview: true
---

<!-- TODO: make this into a proper page, just wanted to save some info -->

Machine learning (ML) provides your machines with the ability to adjust their behavior based on models that recognize patterns or make predictions.

Common use cases include:

- Object detection, which enables machines to detect people, animals, plants, or other objects with bounding boxes, and to perform actions when they are detected.
- Object classification, which enables machines to separate people, animals, plants, or other objects into predefined categories based on their characteristics, and to perform different actions based on the classes of objects.
- Speech recognition, natural language processing, and speech synthesis, which enable machines to verbally communicate with us.
146 changes: 144 additions & 2 deletions docs/data-ai/ai/act.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,148 @@ title: "Act based on inferences"
weight: 70
layout: "docs"
type: "docs"
no_list: true
description: "TODO"
description: "Use the vision service API to act based on inferences."
---

You can use the [vision service API](/dev/reference/apis/services/vision/) to get information about your machine's inferences and program behavior based on that.

## Program a line following robot

For example, you can [program a line following robot](/tutorials/services/color-detection-scuttle/) that uses a vision service to follow a colored object.

You can use the following code to detect and follow the location of a colored object:

{{% expand "click to view code" %}}

```python {class="line-numbers linkable-line-numbers"}
async def connect():
opts = RobotClient.Options.with_api_key(
# Replace "<API-KEY>" (including brackets) with your machine's API key
api_key='<API-KEY>',
# Replace "<API-KEY-ID>" (including brackets) with your machine's
# API key ID
api_key_id='<API-KEY-ID>'
)
return await RobotClient.at_address("ADDRESS FROM THE VIAM APP", opts)


# Get largest detection box and see if it's center is in the left, center, or
# right third
def leftOrRight(detections, midpoint):
largest_area = 0
largest = {"x_max": 0, "x_min": 0, "y_max": 0, "y_min": 0}
if not detections:
print("nothing detected :(")
return -1
for d in detections:
a = (d.x_max - d.x_min) * (d.y_max-d.y_min)
if a > largest_area:
a = largest_area
largest = d
centerX = largest.x_min + largest.x_max/2
if centerX < midpoint-midpoint/6:
return 0 # on the left
if centerX > midpoint+midpoint/6:
return 2 # on the right
else:
return 1 # basically centered


async def main():
spinNum = 10 # when turning, spin the motor this much
straightNum = 300 # when going straight, spin motor this much
numCycles = 200 # run the loop X times
vel = 500 # go this fast when moving motor

# Connect to robot client and set up components
machine = await connect()
base = Base.from_robot(machine, "my_base")
camera_name = "<camera-name>"
camera = Camera.from_robot(machine, camera_name)
frame = await camera.get_image(mime_type="image/jpeg")

# Convert to PIL Image
pil_frame = viam_to_pil_image(frame)

# Grab the vision service for the detector
my_detector = VisionClient.from_robot(machine, "my_color_detector")

# Main loop. Detect the ball, determine if it's on the left or right, and
# head that way. Repeat this for numCycles
for i in range(numCycles):
detections = await my_detector.get_detections_from_camera(camera_name)

answer = leftOrRight(detections, pil_frame.size[0]/2)
if answer == 0:
print("left")
await base.spin(spinNum, vel) # CCW is positive
await base.move_straight(straightNum, vel)
if answer == 1:
print("center")
await base.move_straight(straightNum, vel)
if answer == 2:
print("right")
await base.spin(-spinNum, vel)
# If nothing is detected, nothing moves

await robot.close()

if __name__ == "__main__":
print("Starting up... ")
asyncio.run(main())
print("Done.")
```

{{% /expand%}}

If you configured the color detector to detect red in the Viam app, your rover should detect and navigate towards any red objects that come into view of its camera.
Use something like a red sports ball or book cover as a target to follow to test your rover:

<div class="aligncenter">
{{<video webm_src="https://storage.googleapis.com/docs-blog/tutorials/videos/scuttledemos_colordetection.webm" mp4_src="https://storage.googleapis.com/docs-blog/tutorials/videos/scuttledemos_colordetection.mp4" poster="/tutorials/scuttlebot/scuttledemos_colordetection.jpg" alt="Detecting color with a Scuttle Robot">}}
</div>

## Act in industrial applications

You can also act based on inferences in an industrial context.
For example, you can program a robot arm to halt operations when workers enter dangerous zones, preventing potential accidents.

The code for this would look like:

```python {class="line-numbers linkable-line-numbers"}
detections = await detector.get_detections_from_camera(camera_name)
for d in detections:
if d.confidence > 0.6 and d.class_name == "PERSON":
arm.stop()
```

You can also use inferences of computer vision for quality assurance purposes.
For example, you can program a robot arm doing automated harvesting to use vision to identify ripe produce and pick crops selectively.

The code for this would look like:

```python {class="line-numbers linkable-line-numbers"}
classifications = await detector.get_classifications_from_camera(
camera_name,
4)
for c in classifications:
if d.confidence > 0.6 and d.class_name == "RIPE":
arm.pick()
```

To get inferences programmatically, you will want to use the vision service API:

{{< cards >}}
{{% card link="/dev/reference/apis/services/vision/" customTitle="Vision service API" noimage="True" %}}
{{< /cards >}}

To implement industrial solutions in code, you can also explore the following component APIs:

{{< cards >}}
{{< card link="/dev/reference/apis/components/arm/" customTitle="Arm API" noimage="True" >}}
{{< card link="/dev/reference/apis/components/base/" customTitle="Base API" noimage="True" >}}
{{< card link="/dev/reference/apis/components/camera/" customTitle="Camera API" noimage="True" >}}
{{< card link="/dev/reference/apis/components/gripper/" customTitle="Gripper API" noimage="True" >}}
{{< card link="/dev/reference/apis/components/motor/" customTitle="Motor API" noimage="True" >}}
{{< card link="/dev/reference/apis/components/sensor/" customTitle="Sensor API" noimage="True" >}}
{{< /cards >}}
9 changes: 0 additions & 9 deletions docs/data-ai/ai/advanced/conditional-sync.md

This file was deleted.

Loading

0 comments on commit bb06e29

Please sign in to comment.