No version for distro humble. Known supported distros are highlighted in the buttons above.
No version for distro jazzy. Known supported distros are highlighted in the buttons above.
No version for distro rolling. Known supported distros are highlighted in the buttons above.

Package Summary

Tags No category tags.
Version 0.1.0
License Apache License, Version 2.0
Build type CATKIN
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/nasa/astrobee.git
VCS Type git
VCS Version master
Last Updated 2024-07-03
Dev Status UNMAINTAINED
CI status No Continuous Integration
Released UNRELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

Package to control PMC

Additional Links

No additional links.

Maintainers

  • Astrobee Flight Software

Authors

  • Astrobee Flight Software

\page pmc_actuator PMC actuator

How to test the PMC - Using bare C++ program

On the llp, run the following program:

pmc_actuator_tool -h

How to test the PMC - Using ROS Nodes

Basic procedure

Open two ssh sessions on LLP

Terminal 1 on LLP:

source setup.bash
roslaunch pmc_actuator pmc_actuator.launch

Terminal 2 on LLP:

source setup.bash
rosrun pmc_actuator pmc_actuator_cmd_test

Note: Detailed procedure to run the sound tests is in the attached document sound-test-process.txt.

Control the type of nozzle motions

pmc_actuator_cmd_test performs by default a triangular profile for the nozzles with the blowers at the nominal speed.

WARNING: The instructions below are obsolete. Run pmc_actuator_test -h to check the new command line arguments! Text below is waiting for cleaning…

The program accept up to 7 arguments that can override these defaults:

  1. blower_speed_side1 (pwm value)
  2. blower_speed_side2 (pwm value)
  3. start_nozzle_position_side1 (pwm value)
  4. start_nozzle_position_side2 (pwm value)
  5. nozzle_increment_side1 (float)
  6. nozzle_increment_side2 (float)
  7. time_before_starting_sequence (seconds)

All nozzles on one propulsion module are given the same position and increment/decrement in a triangular pattern. An zero increment will simply keep the nozzle positions static.

For example, to have the left and right nozzles working in opposition at nominal blower speed:

rosrun pmc_actuator pmc_actuator_cmd_test 207 207 25 96 1 -1 5

Side 1 will start at nozzle position 25 (fully closed) and increment at each cycle (62.5Hz) by 1. When it reaches the maximum value it starts to decrements. Side 2 will start at nozzle position 96 (fully open) and decrements at each cycle by 1. When it reaches the minimum value, it will start to increment. The nozzle positions keep oscillating following a triangular profile between the min and max acceptable nozzle positions.

Command all nozzles closed at 2000rpm:

rosrun pmc_actuator pmc_actuator_cmd_test 166 166 25 25 0 0

Command all nozzles open at 3000rpm:

rosrun pmc_actuator pmc_actuator_cmd_test 249 249 96 96 0 0

Triangular pattern with slow open/close:

rosrun pmc_actuator pmc_actuator_cmd_test 207 207 25 25 0.2 0.2

Disable the blowers

The PMC firmware cannot put the servo in idle mode. However, the shutdown command can turn off the motor controller on the blowers. So the servos can be controlled with the above commands without the blower spinning by issuing first this command:

rosservice call /pmc_actuator/enable false

To re-enable the blowers:

rosservice call /pmc_actuator/enable true

PWM values

Blower speed rpm PWM value
2000 166
2500 207
2800 232
3000 249

Nozzle position PWM value
Closed 25
Open 96

Create arbitrary nozzle pattern and blower speeds

The program pmc_actuator_feeder allow to describe any sequence of motion using a csv file.

For example, the following command will cycle through each nozzle and open it for a few seconds:

rosrun pmc_actuator pmc_actuator_feeder ./nozzle_identification.csv

# File format:
#   - 1 line per command
#   - lines starting with # or space are ignored
#   - 15 fields required, space as separator
#   - fields:
#     - time (in seconds, relative to the start of the program)
#     - side 1 blower speed
#     - side 2 nozzle position x 6
#     - side 2 blower speed
#     - side 2 nozzle position x 6

Check telemetry from the PMCs

In a terminal with the correct ROS setup, just type:

rostopic echo /pmc_actuator/telemetry
CHANGELOG
No CHANGELOG found.

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Package Dependencies

System Dependencies

No direct system dependencies.

Dependant Packages

No known dependants.

Launch files

  • launch/pmc_actuator.launch
    • Copyright (c) 2017, United States Government, as represented by the
      • name [default: pmc_actuator]
      • manager [default: ]

Messages

No message files found.

Services

No service files found

Plugins

Recent questions tagged pmc_actuator at Robotics Stack Exchange

No version for distro ardent. Known supported distros are highlighted in the buttons above.
No version for distro bouncy. Known supported distros are highlighted in the buttons above.
No version for distro crystal. Known supported distros are highlighted in the buttons above.
No version for distro eloquent. Known supported distros are highlighted in the buttons above.
No version for distro dashing. Known supported distros are highlighted in the buttons above.
No version for distro galactic. Known supported distros are highlighted in the buttons above.
No version for distro foxy. Known supported distros are highlighted in the buttons above.
No version for distro iron. Known supported distros are highlighted in the buttons above.
No version for distro lunar. Known supported distros are highlighted in the buttons above.
No version for distro jade. Known supported distros are highlighted in the buttons above.
No version for distro indigo. Known supported distros are highlighted in the buttons above.
No version for distro hydro. Known supported distros are highlighted in the buttons above.
No version for distro kinetic. Known supported distros are highlighted in the buttons above.

Package Summary

Tags No category tags.
Version 0.1.0
License Apache License, Version 2.0
Build type CATKIN
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/nasa/astrobee.git
VCS Type git
VCS Version master
Last Updated 2024-07-03
Dev Status UNMAINTAINED
CI status No Continuous Integration
Released UNRELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

Package to control PMC

Additional Links

No additional links.

Maintainers

  • Astrobee Flight Software

Authors

  • Astrobee Flight Software

\page pmc_actuator PMC actuator

How to test the PMC - Using bare C++ program

On the llp, run the following program:

pmc_actuator_tool -h

How to test the PMC - Using ROS Nodes

Basic procedure

Open two ssh sessions on LLP

Terminal 1 on LLP:

source setup.bash
roslaunch pmc_actuator pmc_actuator.launch

Terminal 2 on LLP:

source setup.bash
rosrun pmc_actuator pmc_actuator_cmd_test

Note: Detailed procedure to run the sound tests is in the attached document sound-test-process.txt.

Control the type of nozzle motions

pmc_actuator_cmd_test performs by default a triangular profile for the nozzles with the blowers at the nominal speed.

WARNING: The instructions below are obsolete. Run pmc_actuator_test -h to check the new command line arguments! Text below is waiting for cleaning…

The program accept up to 7 arguments that can override these defaults:

  1. blower_speed_side1 (pwm value)
  2. blower_speed_side2 (pwm value)
  3. start_nozzle_position_side1 (pwm value)
  4. start_nozzle_position_side2 (pwm value)
  5. nozzle_increment_side1 (float)
  6. nozzle_increment_side2 (float)
  7. time_before_starting_sequence (seconds)

All nozzles on one propulsion module are given the same position and increment/decrement in a triangular pattern. An zero increment will simply keep the nozzle positions static.

For example, to have the left and right nozzles working in opposition at nominal blower speed:

rosrun pmc_actuator pmc_actuator_cmd_test 207 207 25 96 1 -1 5

Side 1 will start at nozzle position 25 (fully closed) and increment at each cycle (62.5Hz) by 1. When it reaches the maximum value it starts to decrements. Side 2 will start at nozzle position 96 (fully open) and decrements at each cycle by 1. When it reaches the minimum value, it will start to increment. The nozzle positions keep oscillating following a triangular profile between the min and max acceptable nozzle positions.

Command all nozzles closed at 2000rpm:

rosrun pmc_actuator pmc_actuator_cmd_test 166 166 25 25 0 0

Command all nozzles open at 3000rpm:

rosrun pmc_actuator pmc_actuator_cmd_test 249 249 96 96 0 0

Triangular pattern with slow open/close:

rosrun pmc_actuator pmc_actuator_cmd_test 207 207 25 25 0.2 0.2

Disable the blowers

The PMC firmware cannot put the servo in idle mode. However, the shutdown command can turn off the motor controller on the blowers. So the servos can be controlled with the above commands without the blower spinning by issuing first this command:

rosservice call /pmc_actuator/enable false

To re-enable the blowers:

rosservice call /pmc_actuator/enable true

PWM values

Blower speed rpm PWM value
2000 166
2500 207
2800 232
3000 249

Nozzle position PWM value
Closed 25
Open 96

Create arbitrary nozzle pattern and blower speeds

The program pmc_actuator_feeder allow to describe any sequence of motion using a csv file.

For example, the following command will cycle through each nozzle and open it for a few seconds:

rosrun pmc_actuator pmc_actuator_feeder ./nozzle_identification.csv

# File format:
#   - 1 line per command
#   - lines starting with # or space are ignored
#   - 15 fields required, space as separator
#   - fields:
#     - time (in seconds, relative to the start of the program)
#     - side 1 blower speed
#     - side 2 nozzle position x 6
#     - side 2 blower speed
#     - side 2 nozzle position x 6

Check telemetry from the PMCs

In a terminal with the correct ROS setup, just type:

rostopic echo /pmc_actuator/telemetry
CHANGELOG
No CHANGELOG found.

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Package Dependencies

System Dependencies

No direct system dependencies.

Dependant Packages

No known dependants.

Launch files

  • launch/pmc_actuator.launch
    • Copyright (c) 2017, United States Government, as represented by the
      • name [default: pmc_actuator]
      • manager [default: ]

Messages

No message files found.

Services

No service files found

Plugins

Recent questions tagged pmc_actuator at Robotics Stack Exchange