IVALab Python Libraries
Collection of code for computer vision and robotics with specific API.
Public Member Functions | Public Attributes | List of all members
RealSolver Class Reference
Inheritance diagram for RealSolver:
Inheritance graph
[legend]

Public Member Functions

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)
 

Public Attributes

 bClusterImage
 
 bMeasImage
 
 bSolImage
 
 bTrackImage
 
 bTrackImage_SolID
 
 meaBoard
 
 params
 
 theCalibrated
 
 theClusterBoard
 
 theManager
 
 thePlanner
 
 thePrevImage
 
 theSolver
 

Constructor & Destructor Documentation

◆ __init__()

def __init__ (   self,
  theParams = ParamRunner 
)

Reimplemented in RealSolverROS.

Member Function Documentation

◆ 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()

def clusterScore (   self)
@brief Compute the clustering score of the current tracked board.

Returns:
    The clustering score.

◆ getMeaBoard()

def getMeaBoard (   self)

◆ getSolBoard()

def getSolBoard (   self)

◆ 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.

Member Data Documentation

◆ bClusterImage

bClusterImage

◆ bMeasImage

bMeasImage

◆ bSolImage

bSolImage

◆ bTrackImage

bTrackImage

◆ bTrackImage_SolID

bTrackImage_SolID

◆ meaBoard

meaBoard

◆ params

params

◆ theCalibrated

theCalibrated

◆ theClusterBoard

theClusterBoard

◆ theManager

theManager

◆ thePlanner

thePlanner

◆ thePrevImage

thePrevImage

◆ theSolver

theSolver

The documentation for this class was generated from the following file: