|
def | __init__ (self, theParams=ParamRunner) |
|
def | calibrate (self, theImageMea, visibleMask, hTracker_BEV, option=1, verbose=False) |
|
def | clusterScore (self) |
|
def | getMeaBoard (self) |
|
def | getSolBoard (self) |
|
def | getTrackBoard (self) |
|
def | process (self, theImageMea, visibleMask, hTracker_BEV, run_solver=True, planOnTrack=False, verbose=False) |
|
def | progress (self, USE_MEASURED=True) |
|
def | setClusterBoard (self, target_board=None, mode='solution') |
|
def | setSolBoard (self, img_input, input=None) |
|
◆ __init__()
◆ calibrate()
def calibrate |
( |
|
self, |
|
|
|
theImageMea, |
|
|
|
visibleMask, |
|
|
|
hTracker_BEV, |
|
|
|
option = 1 , |
|
|
|
verbose = False |
|
) |
| |
@brief To obtain the solution board from a rosbag for calibration.
Args:
theImageMea: The input image (from the surveillance system).
visibleMask: The mask image of the visible area (no hand/robot)(from the surveillance system).
hTracker_BEV: The location of the hand in the BEV.
option: The option 0 is to assemble the puzzle while option 1 is to disassemble the puzzle
◆ clusterScore()
@brief Compute the clustering score of the current tracked board.
Returns:
The clustering score.
◆ getMeaBoard()
◆ getSolBoard()
◆ getTrackBoard()
def getTrackBoard |
( |
|
self | ) |
|
◆ process()
def process |
( |
|
self, |
|
|
|
theImageMea, |
|
|
|
visibleMask, |
|
|
|
hTracker_BEV, |
|
|
|
run_solver = True , |
|
|
|
planOnTrack = False , |
|
|
|
verbose = False |
|
) |
| |
@brief Process the input from the surveillance system.
It first obtain the measured pieces, which is categorized into the solution area pieces and the working area pieces.
Then the solving plan is obtained.
Args:
theImageMea: The input image (from the surveillance system).
visibleMask: The mask image of the visible area (no hand/robot)(from the surveillance system).
hTracker_BEV: The location of the hand in the BEV.
run_solver: Run the solver or not.
planOnTrack: Plan on the tracked board or not.
verbose: If True, will display the detected measured pieces, from working or solution area.
Returns:
plan: The action plan.
◆ progress()
def progress |
( |
|
self, |
|
|
|
USE_MEASURED = True |
|
) |
| |
@brief Check the status of the progress. (Return the ratio of the completed puzzle pieces)
Note:
It is different from the one we used for the simulator case. There is less information we have for this progress.
It is not always true when the matching is wrong/rotation is not correct. So there are some false positives.
Args:
USE_MEASURED: Use the measured board, otherwise use the tracked board.
Returns:
thePercentage: The progress.
◆ setClusterBoard()
def setClusterBoard |
( |
|
self, |
|
|
|
target_board = None , |
|
|
|
mode = 'solution' |
|
) |
| |
@brief Set up the cluster board.
Two ways to support clustering stuff:
1) Use the solution board as the cluster board. You can track the progress in this way.
2) Use any board. But only give a one-time suggestion.
Args:
mode: 'solution' or 'arbitrary', default is 'solution'.
target_board: the reference board for clustering. Can be any board at any time (does not have to be the solution one)
Returns:
◆ setSolBoard()
def setSolBoard |
( |
|
self, |
|
|
|
img_input, |
|
|
|
input = None |
|
) |
| |
@brief Set up the solution board.
Args:
input: A board/path/raw image.
◆ bClusterImage
◆ bMeasImage
◆ bSolImage
◆ bTrackImage
◆ bTrackImage_SolID
◆ meaBoard
◆ params
◆ theCalibrated
◆ theClusterBoard
◆ theManager
◆ thePlanner
◆ thePrevImage
◆ theSolver
The documentation for this class was generated from the following file:
- /home/pvela/python/puzzle_solver/puzzle/runner.py