Real time position and orientation tracker

Information

  • Patent Grant
  • 11441899
  • Patent Number
    11,441,899
  • Date Filed
    Thursday, July 5, 2018
    6 years ago
  • Date Issued
    Tuesday, September 13, 2022
    2 years ago
Abstract
The present disclosure relates to a tracking system for tracking the position and/or orientation of an object in an environment, the tracking system including: at least one camera mounted to the object; a plurality of spaced apart targets, at least some of said targets viewable by the at least one camera; and, one or more electronic processing devices configured to: determine target position data indicative of the relative spatial position of the targets; receive image data indicative of an image from the at least one camera, said image including at least some of the targets; process the image data to: identify one or more targets in the image; determine pixel array coordinates corresponding to a position of the one or more targets in the image; and, use the processed image data to determine the position and/or orientation of the object by triangulation.
Description
PRIORITY DOCUMENTS

The present application claims priority from Australian Provisional Application No. 2017902623 titled “REAL TIME POSITION AND ORIENTATION TRACKER” and filed on 5 Jul. 2017, the content of which is hereby incorporated by reference in its entirety.


BACKGROUND OF THE INVENTION

The present invention relates to a tracking system for tracking the position and/or orientation of an object in an environment.


DESCRIPTION OF THE PRIOR ART

The reference in this specification to any prior publication (or information derived from it), or to any matter which is known, is not, and should not be taken as an acknowledgment or admission or any form of suggestion that the prior publication (or information derived from it) or known matter forms part of the common general knowledge in the field of endeavour to which this specification relates.


To accurately control the end effector position of industrial robots or large construction robots, it is necessary to measure the position and orientation of the end effector, or a part of the robot close to the end effector. To achieve dynamic stability and accurate control during movement of the robot, it is necessary to measure the position and orientation at a high data rate and in real time. Delays in the feedback loop of a control system lead to following error and reduced bandwidth and phase margin, all of which are undesirable. Delay can also introduce self-excitation or resonance in servo-controlled systems.


For conventional sized robots with a reach of up to 3 m and when the end effector maintains line of sight to a laser tracker, the currently available laser tracker and Optical CMM solutions provide accurate data at adequate frequency to correct the end effector position for tasks such as drilling.


For large construction robots such as that described in the inventor's international patent application PCT/AU2007/000001, which has a reach of 30 m, and where due to line of sight constraints, the distance between the target and the end effector can be 2 m, the static position measurement accuracy of about 0.3 mm and orientation accuracy of 0.01 degrees results in an end effector accuracy of only 0.7 mm which is only just adequate. With an orientation accuracy of 0.1 mm, the end effector accuracy is reduced to +/−4 mm which means that adjacent bricks could have a mis-match of 8 mm between them, although the inventor has found that typically the bricks are within 4 mm of each other and within 2 mm of absolute position. Furthermore, the position measurements have error components that consist of long term drift, high frequency white noise and low frequency noise (that may be due to vibration of structural parts of the measurement system or tuning of servo components in the measurement system). Filtering the measurements to reduce the noise introduces a time delay. Even with an optimised system, the introduction of error noise and delay reduces the dynamic performance of the coarse-fine position compensation system and can introduce resonance to the system.


Six degree of freedom laser trackers such as the Leica AT960XR with Tmac or the API Omnitrac with Active Target or Smart Trac Sensor (STS) are known. The Leica AT960XR laser tracking system can provide position coordinates accurate to approximately +/−15 um at a rate of 1000 positions per second. The AT960XR with Tmac probe can also provide orientation to an accuracy of 0.01 degrees and this orientation is measured at 100 Hz and either interpolated to 1000 Hz, which introduces a 10 ms time delay or extrapolated to 1000 Hz which introduces an extrapolation error which depends on the motion of the Tmac. With the Tmac, the range is limited to 30 m. The cost of a system was approximately AUD 400,000.00 in 2016.


The API Omnitrac and STS provides both position and orientation data at 300 Hz. The orientation data has an accuracy of less than 0.1 degree. API may, in the future, improve the orientation accuracy of their equipment to 0.01 degree but this has not happened yet.


Laser trackers rely on measuring the time of flight of a light beam and/or laser interferometry for distance measurement and therefore depend on accurately knowing the temperature and density of the air because this affects the speed of light. For this reason the laser trackers include a weather station to measure temperature and humidity and barometric pressure.


GPS (Global Positioning System) with RTK (Real Time Kinematics) is known to provide horizontal position accuracy at approximately cm resolution at rates less than 20 Hz. The height accuracy of GPS with RTK is worse than this.


The Nikon iGPS can provide position accuracy of 0.3 mm and full 6 DOF (six degrees of freedom) position measurement, however the measurement rate is limited to approximately 20 Hz.


The Nikon K Series optical CMM (Coordinate Measuring Machine) uses three linear CCD cameras to localize infra-red LEDs incorporated into the carbon fiber housing of a touch probe. The measuring range is limited to 6 m distance and provides a volumetric accuracy of 60 to 90 um. Orientation accuracy depends on the size of the probe. The measurements can be at up to 1000 Hz.


Laser trackers have moving components and require precise alignment and calibration on a regular basis. They are relatively delicate instruments. They require particular care when being used on construction sites and when being transported. A laser tracker unit must be set up on firm ground when used on a construction site.


The realities of a construction site using large robots require a robust position and orientation tracking device that can measure 6 degrees of freedom and provide velocity data as well, over a large volume, and that is easy to set up and transport. An order of magnitude reduction in the price of the system, relative to currently available systems would be highly beneficial. A target price in the tens of thousands of dollars range rather than hundreds of thousands of dollars range would be desirable.


It is against this background, and the problems and difficulties associated therewith, that the present invention has been developed.


SUMMARY OF THE PRESENT INVENTION

In one broad form, the present invention seeks to provide a tracking system for tracking the position and/or orientation of an object in an environment, the tracking system including:

    • a) at least one camera mounted to the object;
    • b) a plurality of spaced apart targets, at least some of said targets viewable by the at least one camera; and,
    • c) one or more electronic processing devices configured to:
      • i) determine target position data indicative of the relative spatial position of the targets;
      • ii) receive image data indicative of an image from the at least one camera, said image including at least some of the targets;
      • iii) process the image data to:
        • (1) identify one or more targets in the image;
        • (2) determine pixel array coordinates corresponding to the position of the one or more targets in the image; and,
      • iv) use the processed image data to determine the position and orientation of the object by triangulation.


In one embodiment, the system includes a body attachable to the object, the body having a camera array including a plurality of spaced apart cameras each having a field of view with a central axis, with the central axis of adjacent spaced apart cameras being divergently spaced by a predetermined fixed angle.


In one embodiment, the fields of view of adjacent cameras are at least partially overlapping so that at least some cameras can each view one or more common targets.


In one embodiment, the plurality of cameras are spaced radially apart with their central axes lying in a common plane.


In one embodiment, the number of cameras in the camera array is selected from: 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19 and 20.


In one embodiment, the body is spherical and the camera array includes a plurality of cameras arranged about the spherical body with their central axes spaced at predetermined angles.


In one embodiment, a target defines at least one of:

    • a) an individual point target; and,
    • b) a target array comprising a plurality of point targets.


In one embodiment, the plurality of spaced apart targets are at least one of:

    • a) user generated; and,
    • b) computer generated.


In one embodiment, user generated targets are targets that are manually set up in the environment at predetermined locations by the user.


In one embodiment, the plurality of spaced apart targets include a plurality of target arrays of predetermined configuration, each of the target arrays having at least three targets spaced apart from each other by predetermined distances.


In one embodiment, a target array has a unique spaced apart configuration of targets, compared with any other target array.


In one embodiment, a target array includes at least one of:

    • a) an upright mast on which the at least three targets are disposed in a spaced apart and colinear arrangement;
    • b) a cross having upright and horizontal members each supporting a plurality of targets disposed in a spaced apart and colinear arrangement.


In one embodiment, the targets are arranged on each mast or cross spaced apart from each other according to unique predetermined target spacings for each mast or cross.


In one embodiment, the plurality of spaced apart targets include at least two target arrays manually locatable in predetermined spaced apart positions, viewable by the camera array when the object is located in an operating position in which its position and orientation is to be determined.


In one embodiment, the plurality of spaced apart targets are arranged in configurations selected from one or both of:

    • a) spaced apart along a straight line; and,
    • b) spaced apart in two intersecting lines.


In one embodiment, the or each line of targets is horizontally disposed.


In one embodiment, the targets are lights that are time synchronised to switch on and off at defined intervals to thereby allow a camera imaging a target to identify the target that is imaged.


In one embodiment, the body includes a surveying target viewable by a surveying instrument to determine the position of the body relative to the surveying instrument.


In one embodiment, the surveying instrument is selected from one of a theodolite such as a total station, or a laser tracker.


In one embodiment, the camera array is used to determine the orientation of the body.


In one embodiment, the at least one camera images the environment and the one or more electronic processing devices are further configured to:

    • a) receive the image data from the at least one camera; and,
    • b) analyse the image data to:
      • i) identify a number of potential targets using image recognition algorithms;
      • ii) select a plurality of the potential targets for use by the tracking system based at least in part on a set of target rules; and,
      • iii) determine a position and orientation of the selected targets in the environment.


In one embodiment, the targets are fixed reference points in environment.


In one embodiment, the one or more electronic processing devices create a map of the environment including the selected targets.


In one embodiment, the map is created during initial setup of the object in the environment.


In one embodiment, a user can at least one of:

    • a) select the targets based on a number of potential targets identified by the one or more electronic processing devices; and,
    • b) override, confirm or delete targets selected by the one or more electronic processing devices.


In one embodiment, as the object moves and the at least one camera images the environment, the one or more electronic processing devices are configured to analyse image data to identify at least some of the selected targets for use in position and/or orientation determination.


In one embodiment, the system includes at least one initial reference target at a known location in the environment and wherein the one or more electronic processing devices are configured to:

    • a) determine the position and/or orientation of the object by imaging the at least one initial reference target; and,
    • b) determine the position and/or orientation of one or more random targets at unknown locations in the environment using the determined position and/or orientation of the object.


In one embodiment, the initial reference target is removed after a predefined number of random targets have been positioned in the environment by the one or more electronic processing devices.


In one embodiment, the system establishes new targets as the object moves through the environment.


In one embodiment, a target position in an image is determined by the one or more electronic processing devices analysing pixel target saturation, to determine pixel array coordinates for the centre of the target.


In one embodiment, the targets use colour to distinguish individual targets in a target array.


In one embodiment, triangulation is performed on the processed image data to determine at least the distance between a target and a camera.


In one embodiment, the pixel array coordinates corresponding to the position of a target are determined to sub-pixel resolution.


In one embodiment, the pixel array coordinates corresponding to the position of the target in the image are indicative of angular data representing a target heading angle and an elevation angle.


In one embodiment, previously stored images are analysed by the one or more electronic processing devices to determine a rate of change of the target heading angle and target elevation angle for use in determining the velocity of the object.


In one embodiment, the system further includes a look-up table of calibration data stored in memory of the one or more electronic processing devices, the calibration data including pixel position values and range correlated to camera focusing data, so that observed target pixel array coordinates have camera focusing data applied to thereby apply range correction in the determination of distance to targets.


In one embodiment, the system includes a camera array including two or more cameras mounted around the object in a distributed arrangement.


In one embodiment, the at least one camera is a digital camera having one of:

    • a) a charge-coupled device (CCD) image sensor; and,
    • b) a complementary metal oxide semiconductor (CMOS) image sensor.


In one embodiment, the or each camera is connected to a dedicated image processor for processing the image data from the camera.


In one embodiment, the image processor is one of:

    • a) a Field Programmable Gate Array (FPGA);
    • b) an Application Specific Integrated Circuit (ASIC);
    • c) a microprocessor; and,
    • d) a microcontroller.


In one embodiment, the image processor of each camera sends data via a data bus to a dedicated position and velocity processor that determines the position, orientation and velocity of the object.


In one embodiment, the position and velocity processor is one of:

    • a) a Field Programmable Gate Array (FPGA);
    • b) an Application Specific Integrated Circuit (ASIC);
    • c) a microprocessor; and,
    • d) a microcontroller.


In one embodiment, the position and velocity processor outputs data to a control and logging system via a fieldbus link.


In one embodiment, the system includes at least two cameras viewing at least two targets so that the triangulation is well conditioned to increase positional accuracy.


In one embodiment, the system includes an array of cameras and targets so that as position and orientation of the object changes, the triangulation remains well conditioned.


In another broad form, an aspect of the present invention seeks to provide a method of tracking the position and/or orientation of an object in an environment, the method including:

    • a) mounting at least one camera to the object so that at least some of a plurality of targets are viewable by the at least one camera when the object is located in an operating position in which its position and/or orientation is to be determined; and,
    • b) the method further including in one or more electronic processing devices:
      • i) determining target position data indicative of the relative spatial position of the targets;
      • ii) receiving image data indicative of an image from the at least one camera, said image including at least some of the targets; and,
      • iii) processing the image data to:
        • (1) identify one or more targets in the image;
        • (2) determine pixel array coordinates corresponding to a position of the one or more targets in the image; and,
      • iv) using the processed image data to determine the position and/or orientation of the object by triangulation.


In one embodiment, the method includes mounting a camera array to the object, the camera array including at least two cameras that are at least one of:

    • a) housed in a body attached to the object; and,
    • b) distributed around the object.


In another broad form, there is provided a tracking system for tracking the position and orientation of an object in space, the tracking system having a body attachable to said object, said body having a camera array comprising at least two spaced apart cameras each having a field of view with a central axis, with the central axis of adjacent said spaced apart cameras being divergently spaced by a predetermined fixed angle, and adjacent said spaced apart cameras preferably having at least intersecting fields of view, said tracking system including a plurality of spaced apart targets; said body being located to enable at least one of said cameras to view some of said targets, said tracking system including a processor to receive input data comprising the relative spatial positions of said targets, receive image data from said at least two cameras, identify said targets and determine the position of each identified target viewed by each camera according to pixel array co-ordinates said target image is coincident, and determine the distance of a said camera, and hence a reference point on or in said body to said identified targets by triangulation of pixel array coordinates for said identified targets.


In one specific form, a tracking system is provided having an array of cameras which views a set of optical targets. The position and orientation of the camera array is determined by triangulation. The processor includes multiple FPGAs (Field Programmable Gate Arrays). Each camera has an FPGA pipeline which is used to process an image from an individual CCD or CMOS camera, by first identifying the targets, calculating the coordinates of the targets to sub pixel resolution. The FPGA corrects the coordinates to account for lens distortion and camera errors. The FPGA then further uses previously stored target positions to calculate a target pixel apparent velocity and then communicates the resulting sub-pixel based target position and velocity to a further FPGA that combines the data from all of the cameras in the array to calculate a resulting position and velocity of the camera array and outputs the data to an industrial field bus such as Ethercat. The body with the camera array is fixed to an object to be tracked in six degrees of freedom. The FPGA pipeline allows fast data processing of the image and reduces the very large amount of image data to 12 numbers (representing 3 position coordinates, 3 orientations, three position velocities and three orientation velocities) and thereby minimises the data communicated to a data logging or control system.


It will be appreciated that the broad forms of the invention and their respective features can be used in conjunction, interchangeably and/or independently, and reference to separate broad forms is not intended to be limiting.





BRIEF DESCRIPTION OF THE DRAWINGS

Examples of the present invention will now be described with reference to the accompanying drawings, in which:



FIG. 1 is a schematic diagram of an example of a tracking system for tracking the position and/or orientation of an object in an environment;



FIGS. 2A to 2B depict representations of a poorly and well conditioned triangulation problem;



FIG. 3 is a schematic diagram of an example of a tracking system for tracking the position and/or orientation of an object in an environment;



FIG. 4 is a schematic isometric view of an example of a body housing a camera array of the tracking system of FIG. 1;



FIG. 5 is a schematic isometric view of an example of a spherical body housing a camera array;



FIG. 6 is schematic cross section through the centre of the body of FIG. 2;



FIG. 7 is a schematic perspective view of an example of a target array of the tracking system of FIG. 1;



FIG. 8 is a schematic side view of the tracking system of FIG. 1 imaging a target array with an obstruction between the camera array and the target array;



FIG. 9 is a schematic diagram of an example of a data processing pipeline implemented for the tracking system of FIG. 1;



FIG. 10 is a schematic perspective view of an example of a distributed camera array;



FIG. 11 is schematic perspective view of part of the camera array of FIG. 2 showing electronic construction details;



FIG. 12 is a schematic cross sectional view of the camera array of FIG. 2 showing details of two diametrically opposed cameras;



FIG. 13 is a schematic part cross sectional view of another example of a camera array;



FIG. 14 is a schematic isometric view of another example of a tracking system for tracking the position and/or orientation of an object in an environment;



FIG. 15 is a schematic isometric view of another example of a tracking system for tracking the position and/or orientation of an object in an environment;



FIG. 16 is a schematic isometric view of another example of a tracking system for tracking the position and/or orientation of an object in an environment;



FIG. 17 is a top view of the camera array used in the tracking system of FIGS. 1, 13 and 14;



FIG. 18 is a side view of the camera array of FIG. 15;



FIG. 19 is a detailed perspective view of the camera array of FIG. 15;



FIG. 20 is an isometric view of the camera array of FIG. 15;



FIG. 21 is a schematic perspective view of a further example of a tracking system for tracking the position and/or orientation of an object in an environment; and,



FIG. 22 is a flow chart of an example of a method for tracking the position and/or orientation of an object in an environment.





DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

An example of a tracking system 200 for tracking the position and/or orientation of an object 202 in an environment E will now be described with reference to FIG. 1.


In this example, it is to be understood that the object 202 typically forms part of a robot assembly 210 and in the example shown in FIG. 1 the object is a robotic component such as a robot base 202 which supports a robot arm 204 and end effector 206 programmed to perform interactions within the environment. The robot assembly 210 is positioned relative to an environment E, which in this example is illustrated as a 2D plane, but in practice could be a 3D volume of any configuration. In use, the end effector 206 is used to perform interactions within the environment E, for example to perform bricklaying, object manipulation, or the like.


The term “interaction” is intended to refer to any physical interaction that occurs within, and including with or on, an environment. Example interactions could include placing material or objects within the environment, removing material or objects from the environment, moving material or objects within the environment, modifying, manipulating, or otherwise engaging with material or objects within the environment, modifying, manipulating, or otherwise engaging with the environment, or the like.


The term “environment” is used to refer to any location, region, area or volume within which, or on which, interactions are performed. The type and nature of the environment will vary depending on the preferred implementation and the environment could be a discrete physical environment, and/or could be a logical physical environment, delineated from surroundings solely by virtue of this being a volume within which interactions occur. Non-limiting examples of environments include building or construction sites, parts of vehicles, such as decks of ships or loading trays of lorries, factories, loading sites, ground work areas, or the like.


A robot arm is a programmable mechanical manipulator. In this specification a robot arm includes multi axis jointed arms, parallel kinematic robots (such as Stewart Platform, Delta robots), spherical geometry robots, Cartesian robots (orthogonal axis robots with linear motion) etc.


An end effector is a device at the end of a robotic arm designed to interact with the environment. An end effector may include a gripper, nozzle, sand blaster, spray gun, wrench, magnet, welding torch, cutting torch, saw, milling cutter, router cutter, hydraulic shears, laser, riveting tool, or the like, and reference to these examples is not intended to be limiting.


It will be appreciated that in order to control the robot assembly 210 to accurately position the end effector 206 at a desired location in order to perform an interaction within the environment, it is necessary to be able to accurately determine the position and/or orientation of a reference point on the robot assembly.


In this example, the tracking system 200 includes at least one camera 220 mounted to the object 202. As will become apparent from the following description, preferably the system 200 will have more than one camera mounted to the object so as to form a camera array with a wide field of view of the environment in which the object 202 is moving.


The tracking system 200 further includes a plurality of spaced apart targets 230, 232, 234, at least some of said targets viewable by the at least one camera 220. In this example, a plurality of target arrays 230, 232, 234 are shown which in turn each have a plurality of clear and defined (i.e. discernible) optical targets. In this example, the targets are positioned around the environment at known locations and are used as reference markers which allow the system 200 to determine the position and/or orientation of the object 202. Whilst targets such as that shown in FIG. 1 are manually placed around the environment, this is not essential and in some examples, the targets may be fixed points of reference in the environment that are selected by the system as targets as will be described in further detail below.


The system 200 further includes one or more electronic processing devices 240, 250 configured to determine target position data indicative of the relative spatial position of the targets. The target position data is indicative of the position of the targets in the environment (i.e. in an environment or world coordinate system ECS). This data comprising the relative spatial position of the targets may be manually input to a processing device by a programming interface such as a keypad or may be provided as data measured by surveying equipment such as a total station used to survey the environment (e.g. a building site) once the targets have been placed. Alternatively, the target position data may be determined by creating a cartesian map of the environment with computer selected targets (such as fixed landmarks or reference points in the environment) forming part of the map and their positions determined relative to an environment coordinate system assigned to the map.


The one or more electronic processing devices 240, 250 then receive image data indicative of an image from the at least one camera 220, said image including at least some of the targets 230, 232, 234. The image data is then processed to identify one or more targets in the image and determine pixel array coordinates corresponding to a position of the one or more targets in the image. In this regard, it will be appreciated that typically the one or more targets are uniquely identifiable so that the processor is able to discern which target is in the image. This may be achieved in numerous ways as will be described in more detail below.


Finally, the one or more electronic processing devices use the processed image data to determine the position and/or orientation of the object by triangulation. Typically, the position of the one or more targets in the image is resolved to sub-pixel resolution in order to increase the accuracy of the triangulation. It will be appreciated that in some examples, the triangulation is performed using two cameras imaging one or more targets (preferably at least two targets) whilst in other examples the triangulation may be performed based on one camera imaging multiple targets. Any suitable method of performing triangulation known to a skilled person may be used in order to determine distance or range and orientation between the one or more targets being imaged and the at least one camera.


It is to be understood that the above tracking system may be configured so that the triangulation is well conditioned in order to provide accurate location. Preferably, an array of cameras and targets are provided so that as orientation and position of the object changes, the triangulation remains well conditioned. The concept of the triangulation problem being poorly/well conditioned is illustrated schematically in FIGS. 2A and 2B. In FIG. 2A, a system that is poorly conditioned is shown in which cameras 310, 311 are closely spaced together viewing a target 320. It is to be appreciated that alternatively a camera 320 could be viewing closely spaced targets 310, 311. In this example, the position of the target is at 320. If the measured angle from the cameras to the target has a small error α this will translate into significant range uncertainty to the target represented by big Δ. The apparent position of the target then becomes 320′ and an accurate distance to the target is therefore unable to be determined by triangulation.


Conversely, in a triangulation problem as shown in FIG. 2B, the cameras 410, 411 are sufficiently spaced apart viewing target 420 so that a small angular error α between a respective camera and a target will translate into small range uncertainty to the target represented by small Δ. The apparent position of the target then becomes 420′ and an accurate distance to the target can still be determined by triangulation. It is to be appreciated that 410, 411 may alternatively represent targets with a camera 420. The present tracking system is preferably optimised by selecting the number of cameras and targets and their spacing to ensure that wherever the object is in the environment, the triangulation problem remains well conditioned to ensure that accurate 6 DOF position and orientation measurements can be obtained.


The above described tracking system 200 provides a number of advantages. Firstly, it provides a camera based system using simple optical targets that can be easily setup or optionally selected by the system itself using fixed landmarks that already exist in the environment in which the object such as a robot is operating. Such a system is straightforward to implement and allows real time six degree of freedom (6 DOF) tracking of position and orientation of the object to be achieved for a fraction of the cost of existing systems. In this regard, prior systems typically use a laser tracker positioned in the environment which tracks a target on the object and relies on a laser beam having an uninterrupted line of sight to the target. Laser trackers have moving components and require precise alignment and calibration on a regular basis. They are relatively delicate instruments. They require particular care when being used on construction sites and when being transported. A laser tracker unit must be set up on firm ground when used on a construction site. If line of sight is lost or if the laser beam is broken for any reason, a laser tracker based system loses control of the object being tracked. The above described system provides flexibility in being able to select the optimal number of cameras and/or targets in order to be able to ensure uninterrupted tracking of the object as it moves through the environment as well as ensuring that with appropriate camera/target spacing the triangulation problem remains well conditioned.


A number of further features will now be described.


Typically, the system includes a body attachable to the object, the body having a camera array including a plurality of spaced apart cameras each having a field of view with a central axis, with the central axis of adjacent spaced apart cameras being divergently spaced by a predetermined fixed angle. In one example, the camera array is arranged to be as compact as possible whilst in other examples it may be advantageous to spread the cameras out in a distributed manner around the object (for example to improve line sight in some situations).


In one example, the fields of view of adjacent cameras of the camera array are at least partially overlapping so that at least some cameras can each view one or more common targets. This enables triangulation to be performed based on the known distance between the cameras and angular data to the target based on the pixel array coordinates.


In one example, the plurality of cameras (e.g. two or three spaced apart cameras) are spaced radially apart with their central axes lying in a common plane. In this arrangement, the fields of view of adjacent cameras are partially overlapping so that their fields of view intersect at a usable angle away from said common plane. Such a planar configuration of cameras would be of particular use for example in a system that maintains a substantially horizontal orientation of the radial camera array. Any suitable number of cameras may be included in the camera array (examples of which will be described below). Typically, the number of cameras in the camera array is selected from: 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19 and 20.


In another example, the body is spherical and the camera array includes a plurality of cameras arranged about the spherical body with their central axes spaced at predetermined angles. Such an arrangement would be of particular use when the camera array can have any arbitrary orientation.


It is to be appreciated that in this description a target may define either an individual point target or a target array comprising a plurality of point targets and furthermore that the plurality of spaced apart targets may be either user or computer generated. A user generated target is taken to include targets that are manually setup in the environment at predetermined locations by the user. A computer generated target is taken to include targets that are selected by the processor in accordance with fixed reference points that exist in the environment that the at least one camera is able to view. The targets may be selected by appropriate artificial intelligence or machine learning algorithms which are able to discern targets and make decisions around particular targets that should be chosen for use by the tracking system.


Referring now to user generated targets, the plurality of spaced apart targets may include a plurality of target arrays of predetermined configuration, each of the target arrays having at least three targets spaced apart from each other by predetermined distances. Typically, a target array has a unique spaced apart configuration of targets, compared with any other target array which assists the processor in identifying which particular target is being imaged.


A target array may take many forms including for example an upright mast on which the at least three targets are disposed in a spaced apart and colinear arrangement and a cross having upright and horizontal members each supporting a plurality of targets disposed in a spaced apart and colinear arrangement. In the example of a cross configuration of targets, a single camera imaging this array of targets would be able to determine its position and orientation based on the relative appearance of the targets (e.g. apparent distance between targets) as the camera moves closer/further away and rotates in yaw, pitch and roll relative to the targets. In one example, the targets are arranged on each mast or cross spaced apart from each other according to unique predetermined target spacings for each mast or cross.


Typically, the plurality of spaced apart targets include at least two target arrays manually locatable in predetermined spaced apart positions, viewable by the camera array when the object is located in an operating position in which its position and orientation is to be determined.


In another arrangement, the plurality of spaced apart targets are arranged in configurations selected from one or both of spaced apart along a straight line; and, spaced apart in two intersecting lines. In this example, the or each line of targets is horizontally disposed and typically one camera views targets in the first line and a second camera views targets in the second line.


Other techniques for assisting in the unique identification of targets may be employed. For example colour may be used to distinguish the targets. The targets may comprise ultra-bright light emitting diodes. In other preferred arrangements, entire target arrays may be coloured identically, while separate target arrays have targets coloured identically but in different colours.


In another example, time synchronisation of targets is used. In this example, the targets are lights such as light emitting diodes (LEDs) that are time synchronised to switch on and off at defined intervals to thereby allow a camera imaging a target to identify the target that is imaged. The processor can determine that for an image taken at a particular time, at that time, a particular target was programmed to be on which thereby identifies which target is in the image. Multiple cameras may each see the target that is on at the same time. In practice, the time interval would be in the order of milliseconds and to the human eye it would likely appear that all of the targets were on. If the targets are time synchronised the design of the target arrays is simplified and cost and setup time would be reduced.


In another example of the system, the body includes a surveying target such as an SMR (Spherical Mount Reflector) that is viewable by a surveying instrument to determine the position of the body relative to the surveying instrument. The surveying instrument is preferably selected from one of a theodolite such as a total station, or a laser tracker, in which case the surveying target on the body will be an optical target or reflector. In such an example, the camera array is used to determine the orientation of the body or determines the orientation and position of the body to supplement the position data from the surveying instrument, or provides a back-up where the surveying target is occluded due to site activity and the surveying instrument is temporarily unable to provide distance data. Such an example may allow simpler point targets to be used for the orientation determination and position may be measured more accurately with the laser tracker, however it includes a laser tacker or similar which will add expense to the tracking system.


Referring now to examples in which the computer generates or determines its own targets. In one example, the at least one camera images the environment and the one or more electronic processing devices are further configured to receive the image data from the at least one camera; and, analyse the image data to identify a number of potential targets using image recognition algorithms; select a plurality of the potential targets for use by the tracking system based at least in part on a set of target rules; and, determine a position and orientation of the selected targets in the environment. As previously mentioned the targets are fixed reference points in the environment which may include for discernible parts of existing structures such as fences, roofs, buildings, trees, light posts etc.


Typically, the one or more electronic processing devices create a map of the environment including the selected targets. The map may be created during initial setup of the object in the environment, for example when the environment is being calibrated to setup a coordinate system in which the targets are positioned.


In some examples, a user can at least one of select the targets based on a number of potential targets identified by the one or more electronic processing devices; and, override, confirm or delete targets selected by the one or more electronic processing devices. In this way, a user can ultimately still have a degree of control over which targets are selected to ensure for example that a transient target such as a parked car or object which may move is not selected as a target.


As the object moves and the at least one camera images the environment, the one or more electronic processing devices are configured to analyse image data to identify at least some of the selected targets for use in position and/or orientation determination. Different targets would be selected as the object moves through the environment and better targets come into view of the at least one camera.


In one example, the system includes at least one initial reference target at a known location in the environment and wherein the one or more electronic processing devices are configured to determine the position and/or orientation of the object by imaging the at least one initial reference target; and, determine the position and/or orientation of one or more random targets at unknown locations in the environment using the determined position and/or orientation of the object. The initial reference target may be removed after a predefined number of random targets have been positioned in the environment by the one or more electronic processing devices. In this type of system, new targets can be established as the object moves through the environment. The above described system is based on a forward position calculation from the at least one camera to the targets and then a backward position calculation from the targets to the at least one camera. If a known target is used as an initial reference, then the at least one camera can calculate its position and orientation (via the backward calculation) and then calculate the position of the “unknown” or random targets using the forward calculation. Once enough random targets have been measured, the initial reference target can be removed and the at least one camera will continue to know where it is (from the backward calculation from the random targets) and can establish the position of new random targets via the forward calculation, and by doing this continuously or at intervals as it moves, can continue to establish new targets as it moves into new regions.


Typically, a target position in an image is determined by the one or more electronic processing devices analysing pixel target saturation, to determine pixel array coordinates for the centre of the target.


It will be appreciated that triangulation is performed on the processed image data to determine at least the distance between a target and a camera and that was previously described the system is configured to ensure that the triangulation problem is always well conditioned to provide distance accuracy.


Preferably, the pixel array coordinates corresponding to the position of a target are determined to sub-pixel resolution using any suitable sub-pixel resolution algorithm. The pixel array coordinates corresponding to the position of the target in the image are indicative of angular data representing a target heading angle and an elevation angle. This angular data is used in the triangulation to determine the position and orientation of the at least one camera.


In some instances it is also preferable to determine the velocity of the object in addition to its position and orientation. In one example, previously stored images are analysed by the one or more electronic processing devices to determine a rate of change of the target heading angle and target elevation angle for use in determining the velocity of the object.


It will be appreciated that the system also typically includes a look-up table of calibration data stored in memory of the one or more electronic processing devices, the calibration data including pixel position values and range correlated to camera focusing data, so that observed target pixel array coordinates have camera focusing data applied to thereby apply range correction in the determination of distance to targets. This enables the pixel array coordinates to be corrected for lens distortion and camera errors.


The camera used in the system is typically a digital camera having one of a charge-coupled device (CCD) image sensor; and, a complementary metal oxide semiconductor (CMOS) image sensor. Currently available high speed CMOS sensors can provide multi mega pixel images at high frame rates. For example the Alexima AM41 sensor can provide 2336×1728 pixels at 500 frames per second (fps). Sub pixel resolution algorithms calculate target position to approximately one tenth of a pixel. In an example using 20 cameras to obtain 360 view angle, the sub pixel horizontal resolution is 2336×20×10/360=1298 sub pixels per degree or 0.0007 degrees. The sensors and optics in the camera array can be calibrated by imaging known points, or a grid, in multiple orientations of the camera array and applying a mathematical table of corrections. Thus each camera pixel coordinate can be mapped to a calibrated actual angle.


Preferably, the or each camera is connected to a dedicated image processor for processing the image data from the camera. The image processor is typically a Field Programmable Gate Array (FPGA) or an Application Specific Integrated Circuit (ASIC) but in other examples could be a microprocessor or a microcontroller.


The image processor of each camera sends data via a data bus to a dedicated position and velocity processor that determines the position, orientation and velocity of the object. The position and velocity processor is typically a Field Programmable Gate Array (FPGA) or an Application Specific Integrated Circuit (ASIC) but in other examples could be a microprocessor or a microcontroller. The position and velocity processor typically outputs data to a control and logging system via a fieldbus link such as Ethercat to enable the data to be used in the positional control of the robot end effector so that it can perform an interaction in the environment.


In another broad form, the present invention provides a method of tracking the position and/or orientation of an object in an environment, the method including mounting at least one camera to the object so that at least some of a plurality of targets are viewable by the at least one camera when the object is located in an operating position in which its position and/or orientation is to be determined; and, the method further including in one or more electronic processing devices: determining target position data indicative of the relative spatial position of the targets; receiving image data indicative of an image from the at least one camera, said image including at least some of the targets; and, processing the image data to: identify one or more targets in the image; determine pixel array coordinates corresponding to a position of the one or more targets in the image; and, using the processed image data to determine the position and/or orientation of the object by triangulation.


Typically, the method includes mounting a camera array to the object, the camera array including at least two cameras that are at least one of housed in a body attached to the object; and, distributed around the object.


Referring to FIG. 3, a six degrees of freedom tracking system 32 is illustrated. The six degrees of freedom tracking system 32 is designed to track the position and orientation of an object in space. The six degrees of freedom tracking system 32 tracks the position of the object in three dimensions returning coordinate values for x and z coordinates in a horizontal plane and a value for height coordinate y. The six degrees of freedom tracking system 32 also returns values for pitch, roll and yaw of the object. The present application for the six degrees of freedom tracking system 32 is tracking the position and orientation of a brick laying and adhesive applying head within the confines of a building site, and is used to assist with the control of a brick laying robot in the construction of a building such as a house on a slab 59. It will be appreciated that this example is not intended to be limiting.


The six degrees of freedom tracking system 32 is provided with a body 1, provided with twenty cameras located radially in a horizontal plane to form a camera array, one of the cameras of the array being is indicated at 2. The cameras collectively view three target arrays 3, 4, 5. In practice each camera has a narrow field of view and each target will normally be visible to a single camera in the camera array 1, and at the most, two cameras in the camera array 1. Where the target concerned is visible to two cameras it will typically be due to orientation of the body 1 in a position where target is located in the overlapping fields of view of two adjacent cameras.



FIG. 4 shows the first embodiment of the camera array showing the body 1 as an over-square cylinder with seven of the twenty cameras in this embodiment being visible, being cameras indicated at 6, 7, 8, 9, 10, 11 and 12. The cameras in the camera array are arranged radially around a central axis 13. This camera array with its horizontal configuration is optimised for a system that maintains a substantially horizontal orientation of the radial camera array, with axis 13 remaining substantially vertical. Pitch, roll and yaw of the object will be detected by the camera array and can be corrected for in the control of the orientation of the object to which the camera array is affixed. Further detail of the first embodiment of the camera array is shown in FIGS. 17, 18, 19 and 20.



FIG. 5 shows a second alternative embodiment of a camera array, provided as an alternative camera array to that shown in FIG. 3. The second embodiment of the camera array has a spherical body 14 with cameras 16 arranged in a spherical pattern about a central point 15. The camera array of the second embodiment is used in a tracking system that can have any arbitrary orientation.


Those skilled in the art will appreciate that the number and orientation of the cameras can be arranged to maintain line of sight and accommodate the structural requirements of the object being tracked. Positions for the cameras 16 on the spherical body 14 of the camera array can be determined using known algorithms.



FIG. 6 shows a transverse cross-section of the first embodiment of the camera array of the first embodiment. A first camera 6 is shown mounted to the body 1 and on the opposite side of the body 1 is mounted a second camera 17. First camera 6 is connected to a first FPGA (field programmable gate array) 19 by a high speed data bus 20. The second camera 17 is connected to a second FPGA 21 by second high speed data bus 22. The first FPGA 19 and the second FPGA 21 are connected respectively to a 6 DOF position and velocity FPGA module 18 by a first data bus 23 and a second data bus 24. The individual FPGAs 18, 19 and 21 and the data busses 20, 23, 24 and 22 could be implemented on a common PCB or set of pluggable PCBs or the FPGAs could exist as IP cores within a larger single FPGA. All of the devices could be combined into or implemented as ASICS (application specific integrated circuits).


The first camera 6 and the second camera 17 are representative of each camera in the camera array 1, and each camera 6 is directly connected with a high speed bus 20 to an FPGA 19. That is, in the camera array, each camera is connected by a high speed bus to a FPGA dedicated to that camera. All twenty of these FPGAs are connected to the 6 DOF position and velocity FPGA module 18.



FIG. 7 shows a target array 3. The target array 3 has a structure 25 that supports targets 26, 27, 28, 29, 30 and 31. The number of the targets 26-31 on the target array and the arrangement of the targets 26-31 on the target array can be varied without deviating from the concept and scope of the present invention. While the first embodiment illustrated in FIG. 3 shows three targets, increasing the number of target arrays 3 in the tracking system 32 increases both the system accuracy and the probability of line of sight from as many as possible of the total number of targets on the target arrays to the camera array.


The targets 26-31 are uniquely arranged on the target array 3 so that the distance between adjacent targets 26-31 is always unique. This unique coding of adjacent target 26-31 distance allows each target 26-31 to be uniquely identified. In the preferred embodiment of the target array 3, the targets 26-31 are arranged in a substantially vertical pattern. Each target can be assigned a unique upper/lower ratio which is the distance to the target above it divided by the distance to the target below it, for example in FIG. 7, target 28 has an upper/lower ratio=d2/d1. The upper/lower ratio for each target 26-31 uniquely identifies each target 26-31. In addition to this, each target array 3, 4 or 5 is different from the others by having the targets 26-31 spaced differently. This allows the target arrays 3, 4 and 5 to be readily distinguished from each other.


Referring to FIG. 7, in the preferred embodiment of the target array 3, the structure 25 consists of a substantially vertical tube 33 supported by three legs 34, 35 and 36 which rest on the ground 37. In the preferred embodiment of the target array 3, the structure 25 is made of carbon fibre reinforced plastic painted highly reflective white to minimise thermal distortion.


In the preferred embodiment of the target array 3, the targets 26 to 31 are ultra-bright coloured LEDs. In the preferred embodiment of the camera 6, the camera 6 is fitted with a filter 38 that passes the colour of the targets 26-31 and rejects other colours. In the preferred embodiment of the targets 26 to 31, each target 31 is fitted with a combined lens, reflector and shield 39 that projects a light field of uniform shape that does not impact the structure 25 of the adjacent target array 3.



FIG. 8 shows the camera array 1 located near an obstruction 40. FIG. 8 shows that the camera 2 has a lowermost line of sight 41 that is obstructed by the obstruction 40, and an upper most line of sight 42. Since the lowermost line of sight 41 is obstructed by the obstruction 40, target 26 is not visible to the camera 2. In FIG. 6 the target 27, being above the obstruction 40, is visible to the camera 2. Targets 30 and 31 are above the upper most line of sight 42 and are not visible to the camera 2. Targets 27, 28 and 29 are above the line of obstruction 43 and below the uppermost line of sight 42 and are therefore visible. The upper/lower ratio d2/d1 uniquely identifies target 28 and therefore all other visible targets 27-29 of the target array 3. Even when the complete target array 3 is not visible to the camera. 2, the targets can be uniquely identified by their relative position and the upper/lower ratio, provided that at least three consecutive targets 26-31 are visible to the camera 2.



FIG. 9 shows the data processing pipelines. In the preferred embodiment illustrated in FIG. 9 there are twenty cameras being “Camera 01” 6, “Camera 02” 7, “Camera 03” to “Camera 19” which are not shown, and “Camera 20” 44. Each camera has a similar data processing pipeline which will be illustrated by describing the camera data processing pipeline 45 for “Camera 01” 6. “Camera 01” 6 is connected by a high speed data bus 20 to a camera FPGA analysis module 19. The FPGA camera analysis module 19 contains programmed gate arrays whose purpose is in a first step 47 to identify the targets 26 to 31 shown in FIG. 5. In a second step 48, the images of the targets 26 to 31, if present, of the targets 26-31 are identified by considering pixels with the correct values that are in the correct relationship with the surrounding pixels, and the targets identified in the previous photo. Thus pixel noise and false targets may be rejected. The target pixel coordinates of the centre of the target are then calculated by using industry standard machine vision gate array methods.


The “Camera 01” 6 would have been previously calibrated using standard machine vision techniques. These follow a procedure where the camera takes a picture of the target. The pixel location is mapped to an A and B ray angle from a focal point known in 3D. The focal point is dependent upon the focus of the camera and also the pixel location; that is, the rays from the lens may be skew and not all originate from the same focal point. The aim of camera calibration is to determine for each pixel, the focus distance for each object distance, the 3D focal point coordinate and the A and B ray angles from the focal point coordinate. In a first instance, the calibration table consists of data for each individual pixel. In a second instance, the data set can be linearised so that a linear (or other deterministic function fit) best fit approximation is applied to the data between suitably spaced pixels. For example, lens distortion characteristics are such that the changes in calibration data can be considered to be linear across a small range, say (ten) pixels. This reduces the calibration data set size from say a 2000×1000 pixel array, to a calibration data set of say 200×100 (a 100 fold reduction in calibration data). Furthermore, this simplifies the calibration process, because rather than determining the A, B ray angles and focal data for each pixel, a calibration plate can be used which provides an X, Y target that is imaged onto a pixel, and via sub pixel resolution techniques, thereby to a sub pixel coordinate p, q. Each calibration plate target is imaged to a sub pixel resolution, with corresponding focal distance d data stored.












For each camera


MEASURED DATA








Calibration plate
Camera










Target
Distance
sub pixel coordinate
focal distance












X
Y
D
p
q
d















0
0
1000
25.1
50
23.215


0
10
1000
25.3
150
23.217


10
10
1000
125.4
150
23.218


0
0
2000
12.51
25.3
24.103


0
10
2000
12.32
75.2
24.102


10
10
2000
62.17
75.3
24.102









The measured data is then used to construct the calibration table at the desired calibration interval (e.g. ten pixels). These techniques are known and standard. The known process is extended by being repeated at different object (calibration plate) distances D by moving the calibration plate by a known amount. Multiple positions of the calibration plate then allow the A and B ray angle calibration data and the focal point coordinate to be determined for each calibration interval. This constructs a multi-dimensional look up table that for the calibration pixel p, q and object distance D, has calibration data (A, B ray angles, and x,y,z focal point coordinate.












DERIVED


CALIBRATION DATA











Sub pixel
Object
Focal
Ray
Focal point


coordinate
Distance
Distance
angles
coordinates















p
q
D
d
A
B
x
y
z













 0
0
1000



10
0
1000


20
0
1000


30
0
1000


. . .


 0
10
1000


10
10
1000


20
10
1000


30
10
1000


. . .


 0
0
2000


10
0
2000


20
0
2000


30
0
2000


. . .


 0
10
2000


10
10
2000


20
10
2000


30
10
2000


. . .









This technique is further extended so that the calibration plate is imaged by multiple cameras. It may be further extended so that the calibration plate is a series of plates encircling the camera array. Alternatively the camera array may be mounted to a turntable that can be accurately moved through an angle, thereby presenting different cameras to view the calibration plate. Alternatively the camera array may be mounted on a tilting turntable that can be rotated and tilted accurately to present different cameras to view the calibration plate. The calibration process is automated to collect the required data.


The camera error corrections are then applied in a third step 49 resulting in data 51 consisting of the target heading angle and target elevation angle and also a rate of change of the target heading angle and a rate of change of the target elevation angle. The data 51 is transmitted on a data bus 23 to the 6 DOF position and velocity FPGA module 18. Each FPGA analysis module 19, 52, 53 and the seventeen others (not shown) is connected to the data bus 50 and passes the target heading and elevation angle data 51 to the 6 DOF position and velocity analysis FPGA module 18. As IC (integrated circuit) technology advances and FPGA and ASIC technology improves, it may be possible to combine the various FPGA modules shown into fewer modules, or perhaps even one module. With the state of the technology as at 2017, the preferred embodiment is to use an FPGA for each FPGA camera analysis module 46 and an FPGA for the 6 DOF position and velocity FPGA module 18.


The 6 DOF position and velocity FPGA module 18 uses well known navigation and statistical algorithms to combine the multiple target heading angle, elevation angle and velocity data to calculate a single set of 6 DOF position and velocity data 55 for the camera array 1, which is transmitted by an internal data link 56 to a data link module 57 which formats and transmits the data to an external data link 58.


In the preferred embodiment the data link 58 is an Ethercat fieldbus. In other embodiments the data link 58 could be an industrial field bus such as Modbus, RS232, Profibus, Sercos, Powerlink, RT Ethernet, UDP ethernet or in non-realtime applications TCPIP ethernet. In a further embodiment, the data link 58 could be a number of simulated encoder outputs in any type of encoder format such as quadrature, BiSS, Hiperface, Endat or as simulated resolver output. In less preferred embodiments, the data link 58 could be multiple analogue signals such as 4-20 mA current loop or +−10V analogue.


The datalink 58 connects the 6 DOF tracking system 32 to a control and logging system 60.


In some instances it will be most convenient for the camera array 1 to be as compact as possible. In other instances it may be necessary for reasons such as line of sight for the camera array 1, to be spread out. In some situations, it may be advantageous for the camera array to be distributed around an object. FIG. 10 shows a distributed camera array 61 around an arbitrary object 62. The ten cameras 63-72 are distributed around the object 62. Each camera has a directly connected camera analysis module, not shown for clarity for cameras 63 and cameras 65-72, but shown for camera 64 which is directly connected to camera analysis module 73. Camera analysis module 73 includes a field bus connection 74. The fieldbus connection 74 is connected by a first cable 75 to the fieldbus network 77 and by a second cable 76 to the fieldbus network 78 which includes the other cameras 63 and 65 to 72 and a control system 78. Each camera 63 to 72 transmits via its respective camera analysis module, the target pixel coordinates and pixel velocity as numerical data to the fieldbus network 77. In the preferred embodiment of the distributed camera array 61, the fieldbus network 77 is an Ethercat network and the control system 78 is a Twincat master on an industrial PC. The control system 78 includes a software module to combine the camera data and calculate the 6 DOF position and velocity.



FIG. 11 shows a preferred embodiment of the construction of the electronics of the camera array 1 shown previously in FIGS. 2 and 15 to 18. Each camera 6 has a CMOS or CCD IC 79 surface mounted to a first PCB 80. First camera PCB 80 includes the FPGA camera analysis module 18. Each camera PCB 80 is fitted by an edge connector 81 to a socket 82 surface mounted to a back plane PCB 83. Each edge connector socket 82 has tracks 84 connecting it to the 6 DOF position and velocity module 18 which is then connected to the fieldbus connectors 85 which in turn connect to the external data link 58.



FIG. 12 shows a cross section of a first embodiment of the assembly of the electronics of the camera array 1 into a CNC machined billet 6061-T6 aluminum lower housing 86 and upper housing 87. The back plane PCB 83 is screwed to multiple standoffs 88 which may be integrally machined with the lower housing 86. Each camera PCB 80 is screwed to camera mount bosses 90 which may be integrally machined with the lower housing 86. Lenses 91 are fitted in holes 92 and sealed with O rings 93. The upper housing 87 is mechanically fastened (not shown) to the lower housing 86 and sealed with an O ring 94.



FIG. 13 shows a cross section of a second embodiment of the assembly of the electronics of the camera array into a lower housing 86, which also mounts the lenses 91 in holes 92 which are sealed with O rings 93. A lid 96 is fastened to the lower housing 86 with screws 95 and sealed by an o ring 97. The back plane PCB 83 is mounted to standoffs 88 that are integrally machined with the lower housing 86, by screws 98.



FIG. 14 shows an alternative embodiment with a first horizontal target array 99 and a second horizontal target array 100, located normal to each other and spaced from two boundaries of a working envelope 101. In this embodiment the camera array 102 has a minimal plurality of cameras, in this case a first camera 103 and a second camera 104. The first camera 103 has lines of sight 105, 106, and the second camera 104 has lines of sight 107, 108. The first camera 103 must maintain vision of at least three targets on the first horizontal target array 99 and the second camera 104 must maintain vision of at least three targets on the second horizontal target array 100 for the embodiment 101 to be able to calculate its position and orientation. This defines the working envelope 101 of this embodiment. An advantage of this embodiment is that fewer cameras 103, 104 are required than in the other embodiment of the camera array 1. A disadvantage of this embodiment is that the working envelope 101 is reduced in area and the orientation of the camera array 102 must only vary within a small range so that the target arrays 99, 100 are in view of the respective cameras 103, 104.



FIG. 15 shows an embodiment of the tracking system 110 in which three single targets 111, 112, 113 are placed around a working area 114. A three axis laser tracker 115 is set up adjacent to the working area 114. The camera array 1 supports a laser tracker target 116 such as an SMR (Spherical Mount Reflector). The laser tracker 115 tracks the 3D position of the laser tracker target 116. No orientation data is available from the three axis laser tracker 115 because it measures only the position of the laser tracker target 116. The camera array 1 is used to measure the orientation. During set up it is possible for the laser tracker 115 to measure the precise position of the targets 111, 112 and 113. Alternatively, once the camera array 1 has been moved to three different positions (not shown), the precise position of the targets 111, 112, 113 can be determined by known surveying or navigation calculations. This embodiment of the tracking system 110 has the advantage that it may measure position more accurately than the embodiment of the tracking system 32 but with the disadvantage that it adds an expensive laser tracker 115 and requires more set up work to set up the laser tracker 115. The targets 111, 112 and 113 are simpler than the target arrays 3, 4, 5, 99, 100.



FIG. 16 shows an embodiment of the tracking system 117 in which three single targets 111, 112, 113 are placed around a working area 114. For set up the camera array 1 is sequentially positioned at three precisely known positions and orientations 118, 119 and 120 on a set up jig 121. Each set up position 118, 119 and 120 may be provided with a coded transducer, not shown to communicate with the 6 DOF position and velocity FPGA module 18, the current position, 118, 119, or 120 of the camera array on the set up jig 121. The set up jig 121 provides a known linear scale to the triangular measurements taken of the targets 111, 112 and 113 during set up at the known positions and orientations 118, 119 and 120. By known surveying or navigation calculations, the 3D positions of the targets 111, 112, 113 can be determined. The set up jig 121 can then be removed and the 6 DOF tracking system 117 can then determine the position and orientation of the camera array 1, relative to the fixed targets 111, 112, 113. An advantage of embodiment 117 is that only simple targets 111, 112, 113 are required and no laser tracker 115 (see FIG. 15) is required. The disadvantage is that the set up jig 121 must be set up and the camera array 1 must be moved to the three known positions 118, 119, 120. It should be noted that the camera array 1 could be moved manually or could be moved by a motorised stage or robot not shown.


Referring now to FIG. 21, there is shown a tracking system 500 including a camera array 1 mounted to an object 502 such as a robotic arm. In this example, the cameras of the camera array 1 determine the position and orientation of the object 502 via targets 510, 520, 530 that are fixed reference points in the environment. The targets, in this case part of a roof fence and street lamp are targets that would be selected by the processing device of the system as being suitable targets for use by the system. The targets would be imaged in an initial image capture of the environment and then suitable machine learning or artificial intelligence algorithms would be used to identify objects in the image and select certain objects as being suitable for use as targets, for example, in accordance with predefined target rules. Such target rules might include for example not using transient objects as targets that are likely to move either in the environment or entirely out of the environment. For example, items like cars and lawnmowers or animals like birds or dogs (or people) should not be used as targets whereas static objects like roofs, windows or other structural parts of buildings would be suitable. The system would therefore be able to perform image processing to discern what objects are in the image and then select suitable objects for use as targets (discernible parts thereof such as corners for example).


The system 500 would then generate a map of the environment during initial calibration of the robot in the environment to position the computer generated targets in the environment. As the object moves throughout the environment, the camera array images some of the selected targets for reference points used in the determination of the position and orientation of the object. Such a system is advantageous as it does not require targets to be manually positioned in the environment by a user and does not require any special type of target design as the targets already exist in the environment in which the object such as a robot is operating.


Referring now to FIG. 22, a method of tracking the position and/or orientation of an object in an environment shall now be described.


In this example, at step 600, the method includes mounting at least one camera to the object so that at least some of a plurality of targets are viewable by the at least one camera when the object is located in an operating position in which its position and/or orientation is to be determined.


At step 610 the method includes optionally positioning the targets in the environment, for example when the targets are manually placed by a user such as target arrays and the like. Alternatively, the system is able to deduce its own targets which pre-exist in the environment using artificial intelligence or other type of image recognition algorithm.


At step 620, the method includes in one or more electronic processing devices determining target position data indicative of the relative spatial position of the targets. This data comprising the relative spatial position of the targets may be manually input to a processing device by a programming interface such as a keypad or may be provided as data measured by surveying equipment such as a total station used to survey the environment (e.g. a building site) once the targets have been placed. Alternatively, the target position data may be determined by creating a cartesian map of the environment with computer selected targets (such as fixed landmarks or reference points in the environment) forming part of the map and their positions determined relative to an environment coordinate system assigned to the map.


At step 630, the method includes in the one or more electronic processing devices receiving image data indicative of an image from the at least one camera, said image including at least some of the targets. At step 640, the image data is processed to identify one or more targets in the image and determine pixel array coordinates corresponding to a position of the one or more targets in the image at step 650.


Finally, at step 660 the processed image data is used to determine the position and/or orientation of the object by triangulation.


Accordingly, it will be appreciated that in at least one example the above described tracking system provides a useful alternative to known tracking systems that is cheaper to implement, as it provides a camera based alternative to a more common laser tracker based measurement system. The system preferably uses an array of cameras imaging a plurality of sufficiently spaced apart targets in the environment to ensure that the triangulation problem is always well conditioned so that location can be determined to a high accuracy.


Throughout this specification and claims which follow, unless the context requires otherwise, the word “comprise”, and variations such as “comprises” or “comprising”, will be understood to imply the inclusion of a stated integer or group of integers or steps but not the exclusion of any other integer or group of integers.


Persons skilled in the art will appreciate that numerous variations and modifications will become apparent. All such variations and modifications which become apparent to persons skilled in the art, should be considered to fall within the spirit and scope that the invention broadly appearing before described.

Claims
  • 1. A tracking system for tracking the position and/or orientation of an object in an environment, the tracking system including: a) at least one camera mounted to the object including a body attachable to the object, the body having a camera array including a plurality of spaced apart cameras each having a field of view with a central axis, with the central axis of adjacent spaced apart cameras being divergently spaced by a predetermined fixed angle;b) a plurality of spaced apart targets, at least some of said targets viewable by the at least one camera, wherein the fields of view of adjacent cameras are at least partially overlapping so that at least some cameras can each view one or more common targets; and,c) one or more electronic processing devices configured to: i) determine target position data indicative of the relative spatial position of the targets;ii) receive image data indicative of an image from the at least one camera, said image including at least some of the targets;iii) process the image data to: (1) identify one or more targets in the image;(2) determine pixel array coordinates corresponding to a position of the one or more targets in the image; and,iv) use the processed image data to determine the position and/or orientation of the object by triangulation.
  • 2. The system of claim 1, wherein the camera array includes two or more cameras mounted around the object in a distributed arrangement.
  • 3. The system according to claim 1, wherein the plurality of cameras are spaced radially apart with their central axes lying in a common plane.
  • 4. The system according to claim 1, wherein the body is spherical and the camera array includes a plurality of cameras arranged about the spherical body with their central axes spaced at predetermined angles.
  • 5. The system according to claim 1, wherein a target defines at least one of: a) an individual point target; and,b) a target array comprising a plurality of point targets.
  • 6. The system according to claim 5, wherein the plurality of spaced apart targets are at least one of: a) user generated targets that are manually set up in the environment at predetermined locations by the user; orb) computer generated.
  • 7. The system according to claim 6, wherein the plurality of spaced apart targets include a plurality of target arrays of predetermined configuration, each of the target arrays having at least three targets spaced apart from each other by predetermined distances.
  • 8. The system according to claim 7, wherein a target array has a unique spaced apart configuration of targets, compared with any other target array.
  • 9. The system as claimed in claim 7, wherein a target array includes at least one of: a) an upright mast on which the at least three targets are disposed in a spaced apart and colinear arrangement; orb) a cross having upright and horizontal members each supporting a plurality of targets disposed in a spaced apart and colinear arrangement;wherein the targets are arranged on each mast or cross spaced apart from each other according to unique predetermined target spacings for each mast or cross.
  • 10. The system according to claim 6, wherein the plurality of spaced apart targets one or more of: include at least two target arrays manually locatable in predetermined spaced apart positions, viewable by the camera array when the object is located in an operating position in which its position and orientation is to be determined; orare arranged in configurations selected from one or both of: a) spaced apart along a straight line; and,b) spaced apart in two intersecting lines.
  • 11. The system according to claim 1, wherein the targets are lights that are time synchronised to switch on and off at defined intervals to thereby allow a camera imaging a target to identify the target that is imaged.
  • 12. The system according to claim 1, wherein the body includes a surveying target viewable by a surveying instrument to determine the position of the body relative to the surveying instrument, and wherein the surveying instrument is selected from one of a theodolite such as a total station, or a laser tracker.
  • 13. The system according to claim 12, wherein the camera array is used to determine the orientation of the body.
  • 14. The system according to claim 1, wherein the at least one camera images the environment and the one or more electronic processing devices are further configured to: a) receive the image data from the at least one camera; and,b) analyse the image data to: i) identify a number of potential targets using image recognition algorithms;ii) select a plurality of the potential targets for use by the tracking system based at least in part on a set of target rules; and,iii) determine a position and orientation of the selected targets in the environment.
  • 15. The system according to claim 14, wherein the targets are fixed reference points in environment, and wherein the one or more electronic processing devices create a map of the environment including the selected targets, the map being created during initial setup of the object in the environment.
  • 16. The system according to claim 14, wherein a user can at least one of: a) select the targets based on a number of potential targets identified by the one or more electronic processing devices; or,b) override, confirm or delete targets selected by the one or more electronic processing devices.
  • 17. The system according to claim 14, wherein as the object moves and the at least one camera images the environment, the one or more electronic processing devices are configured to analyse image data to identify at least some of the selected targets for use in position and/or orientation determination.
  • 18. The system according to claim 1, wherein the system includes at least one initial reference target at a known location in the environment and wherein the one or more electronic processing devices are configured to: a) determine the position and/or orientation of the object by imaging the at least one initial reference target; and,b) determine the position and/or orientation of one or more random targets at unknown locations in the environment using the determined position and/or orientation of the object.
  • 19. The system according to claim 18, wherein the initial reference target is removed after a predefined number of random targets have been positioned in the environment by the one or more electronic processing devices, and wherein the system establishes new targets as the object moves through the environment.
  • 20. The system according to claim 1, wherein a target position in an image is determined by the one or more electronic processing devices analysing pixel target saturation, to determine pixel array coordinates for the centre of the target.
  • 21. The system according to claim 5, wherein the targets use colour to distinguish individual targets in a target array.
  • 22. The system according to claim 1, wherein triangulation is performed on the processed image data to determine at least the distance between a target and a camera.
  • 23. The system according to claim 22, wherein the pixel array coordinates corresponding to the position of a target are determined to sub-pixel resolution.
  • 24. The system according to claim 23, wherein the pixel array coordinates corresponding to the position of the target in the image are indicative of angular data representing a target heading angle and an elevation angle.
  • 25. The system according to claim 23, wherein previously stored images are analysed by the one or more electronic processing devices to determine a rate of change of the target heading angle and target elevation angle for use in determining the velocity of the object.
  • 26. The system according to claim 23 or claim 24, wherein the system further includes a look-up table of calibration data stored in memory of the one or more electronic processing devices, the calibration data including pixel position values and range correlated to camera focusing data, so that observed target pixel array coordinates have camera focusing data applied to thereby apply range correction in the determination of distance to targets.
  • 27. The system according to claim 1 wherein the at least one camera is a digital camera having one of: a) a charge-coupled device (CCD) image sensor; orb) a complementary metal oxide semiconductor (CMOS) image sensor;wherein the or each camera is connected to a dedicated image processor for processing the image data from the camera.
  • 28. The system according to claim 27, wherein the image processor of each camera sends data via a data bus to a dedicated position and velocity processor that determines the position, orientation and velocity of the object.
  • 29. The system according to claim 28, wherein the position and velocity processor outputs data to a control and logging system via a fieldbus link.
  • 30. The system according to claim 1, wherein the system includes at least one of: at least two cameras viewing at least two targets so that the triangulation is well conditioned to increase positional accuracy; oran array of cameras and targets so that as position and orientation of the object changes, the triangulation remains well conditioned.
  • 31. A method of tracking the position and/or orientation of an object in an environment, the method including: a) mounting at least one camera to the object so that at least some of a plurality of targets are viewable by the at least one camera when the object is located in an operating position in which its position and/or orientation is to be determined;b) mounting a camera array to the object, the camera array including a plurality of spaced apart cameras each having a field of view with a central axis, with the central axis of adjacent spaced apart cameras being divergently spaced by a predetermined fixed angle; wherein the fields of view of adjacent cameras are at least partially overlapping so that at least some cameras can each view one or more common targets; and,c) the method further including in one or more electronic processing devices: i) determining target position data indicative of the relative spatial position of the targets;ii) receiving image data indicative of an image from the at least one camera, said image including at least some of the targets; and,iii) processing the image data to: (1) identify one or more targets in the image;(2) determine pixel array coordinates corresponding to a position of the one or more targets in the image; and,iv) using the processed image data to determine the position and/or orientation of the object by triangulation.
  • 32. The method according to claim 31, wherein the camera array includes at least two cameras that are at least one of: a) housed in a body attached to the object; and,b) distributed around the object.
Priority Claims (1)
Number Date Country Kind
2017902623 Jul 2017 AU national
PCT Information
Filing Document Filing Date Country Kind
PCT/AU2018/050698 7/5/2018 WO
Publishing Document Publishing Date Country Kind
WO2019/006511 1/10/2019 WO A
US Referenced Citations (411)
Number Name Date Kind
1633192 Reagan Jun 1927 A
1829435 Barnhart Oct 1931 A
3438171 Demarest Apr 1969 A
3757484 Williamson et al. Sep 1973 A
3790428 Lingl Feb 1974 A
RE28305 Williamson et al. Jan 1975 E
3930929 Lingl Jan 1976 A
3950914 Lowen Apr 1976 A
4033463 Cervin Jul 1977 A
4106259 Taylor-smith Aug 1978 A
4221258 Richard Sep 1980 A
4245451 Taylor-smith Jan 1981 A
4303363 Cervin Dec 1981 A
4523100 Payne Jun 1985 A
4708562 Melan et al. Nov 1987 A
4714339 Lau Dec 1987 A
4758036 Legille et al. Jul 1988 A
4765789 Lonardi et al. Aug 1988 A
4790651 Brown et al. Dec 1988 A
4827689 Lonardi et al. May 1989 A
4852237 Tradt et al. Aug 1989 A
4911595 Kirchen et al. Mar 1990 A
4945493 Huang et al. Jul 1990 A
4952772 Zana Aug 1990 A
4954762 Miyake et al. Sep 1990 A
4969789 Searle Nov 1990 A
5004844 Van et al. Apr 1991 A
5013986 Gauggel May 1991 A
5018923 Melan et al. May 1991 A
5049797 Phillips Sep 1991 A
5080415 Bjornson Jan 1992 A
5196900 Pettersen Mar 1993 A
5284000 Milne et al. Feb 1994 A
5321353 Furness Jun 1994 A
5403140 Carmichael et al. Apr 1995 A
5413454 Movsesian May 1995 A
5419669 Kremer et al. May 1995 A
5420489 Hansen et al. May 1995 A
5469531 Faure et al. Nov 1995 A
5497061 Nonaka et al. Mar 1996 A
5523663 Tsuge et al. Jun 1996 A
5527145 Duncan Jun 1996 A
5557397 Hyde et al. Sep 1996 A
5737500 Seraji et al. Apr 1998 A
5838882 Gan et al. Nov 1998 A
6018923 Wendt Feb 2000 A
6049377 Lau et al. Apr 2000 A
6101455 Davis Aug 2000 A
6134507 Markey, Jr. et al. Oct 2000 A
6166809 Pettersen et al. Dec 2000 A
6166811 Long et al. Dec 2000 A
6172754 Niebuhr Jan 2001 B1
6213309 Dadisho Apr 2001 B1
6285959 Greer Sep 2001 B1
6310644 Keightley Oct 2001 B1
6330503 Sharp et al. Dec 2001 B1
6370837 Mcmahon et al. Apr 2002 B1
6427122 Lin Jul 2002 B1
6429016 Mcneil Aug 2002 B1
6512993 Kacyra et al. Jan 2003 B2
6516272 Lin Feb 2003 B2
6584378 Anfindsen Jun 2003 B1
6611141 Schulz Aug 2003 B1
6618496 Tassakos et al. Sep 2003 B1
6628322 Cerruti Sep 2003 B1
6643002 Drake, Jr. Nov 2003 B2
6664529 Pack et al. Dec 2003 B2
6681145 Greenwood et al. Jan 2004 B1
6683694 Cornil Jan 2004 B2
6704619 Coleman et al. Mar 2004 B1
6741364 Lange et al. May 2004 B2
6825937 Gebauer et al. Nov 2004 B1
6850946 Rappaport et al. Feb 2005 B1
6859729 Breakfield et al. Feb 2005 B2
6864966 Giger Mar 2005 B2
6868847 Ainedter et al. Mar 2005 B2
6873880 Hooke et al. Mar 2005 B2
6917893 Dietsch et al. Jul 2005 B2
6935036 Barber et al. Aug 2005 B2
6957496 Raab et al. Oct 2005 B2
6965843 Hobden et al. Nov 2005 B2
6970802 Ban et al. Nov 2005 B2
6996912 Raab et al. Feb 2006 B2
7050930 Hobden et al. May 2006 B2
7051450 Barber et al. May 2006 B2
7069664 Barber et al. Jul 2006 B2
7107144 Capozzi et al. Sep 2006 B2
7111437 Ainedter Sep 2006 B2
7130034 Barvosa-carter et al. Oct 2006 B2
7142981 Hablani Nov 2006 B2
7145647 Suphellen et al. Dec 2006 B2
7153454 Khoshnevis Dec 2006 B2
7174651 Barber et al. Feb 2007 B2
7230689 Lau Jun 2007 B2
7246030 Raab et al. Jul 2007 B2
7269910 Raab et al. Sep 2007 B2
7347311 Rudge Mar 2008 B2
7519493 Atwell et al. Apr 2009 B2
7551121 Oconnell et al. Jun 2009 B1
7564538 Sakimura et al. Jul 2009 B2
7570371 Storm Aug 2009 B1
7576836 Bridges Aug 2009 B2
7576847 Bridges Aug 2009 B2
7591078 Crampton Sep 2009 B2
7639347 Eaton Dec 2009 B2
7693325 Pulla et al. Apr 2010 B2
7701587 Shioda et al. Apr 2010 B2
7774159 Cheng et al. Aug 2010 B2
7800758 Bridges et al. Sep 2010 B1
7804602 Raab Sep 2010 B2
RE42055 Raab et al. Jan 2011 E
RE42082 Raab et al. Feb 2011 E
7881896 Atwell et al. Feb 2011 B2
7967549 Geist et al. Jun 2011 B2
7993289 Quistgaard et al. Aug 2011 B2
8036452 Pettersson et al. Oct 2011 B2
8054451 Karazi et al. Nov 2011 B2
8060344 Stathis Nov 2011 B2
8145446 Atwell et al. Mar 2012 B2
8166727 Pivac et al. May 2012 B2
8169604 Braghiroli et al. May 2012 B2
8185240 Williams et al. May 2012 B2
8229208 Pulla et al. Jul 2012 B2
8233153 Knuettel Jul 2012 B2
8244030 Pettersson et al. Aug 2012 B2
8248620 Wicks et al. Aug 2012 B2
8269984 Hinderling et al. Sep 2012 B2
8327555 Champ Dec 2012 B2
8337407 Quistgaard et al. Dec 2012 B2
8345926 Clark et al. Jan 2013 B2
8346392 Walser et al. Jan 2013 B2
8405716 Yu et al. Mar 2013 B2
8467072 Cramer et al. Jun 2013 B2
8537372 Siercks et al. Sep 2013 B2
8537376 Day et al. Sep 2013 B2
8558992 Steffey Oct 2013 B2
8593648 Cramer et al. Nov 2013 B2
8595948 Raab et al. Dec 2013 B2
8606399 Williams et al. Dec 2013 B2
8634950 Simonetti et al. Jan 2014 B2
8644964 Hendron et al. Feb 2014 B2
8670114 Bridges et al. Mar 2014 B2
8677643 Bridges et al. Mar 2014 B2
8792709 Pulla et al. Jul 2014 B2
8803055 Lau et al. Aug 2014 B2
8812155 Brethe Aug 2014 B2
8825208 Benson Sep 2014 B1
8832954 Atwell et al. Sep 2014 B2
8848203 Bridges et al. Sep 2014 B2
8875409 Kretschmer et al. Nov 2014 B2
8898919 Bridges et al. Dec 2014 B2
8902408 Bridges Dec 2014 B2
8913814 Gandyra Dec 2014 B2
8931182 Raab et al. Jan 2015 B2
8942940 York Jan 2015 B2
8965571 Peters et al. Feb 2015 B2
8996244 Summer et al. Mar 2015 B2
8997362 Briggs et al. Apr 2015 B2
9020240 Pettersson et al. Apr 2015 B2
9033998 Schaible et al. May 2015 B1
RE45565 Bridges et al. Jun 2015 E
9046360 Atwell et al. Jun 2015 B2
9074381 Drew Jul 2015 B1
9109877 Thierman Aug 2015 B2
9146315 Bosse et al. Sep 2015 B2
9151830 Bridges Oct 2015 B2
9163922 Bridges et al. Oct 2015 B2
9170096 Fowler et al. Oct 2015 B2
9188430 Atwell et al. Nov 2015 B2
9207309 Bridges Dec 2015 B2
9223025 Debrunner et al. Dec 2015 B2
9229108 Debrunner et al. Jan 2016 B2
9266238 Huettenhofer Feb 2016 B2
9267784 Atwell et al. Feb 2016 B2
9278448 Freeman Mar 2016 B2
9279661 Tateno et al. Mar 2016 B2
9303988 Tani Apr 2016 B2
9353519 Williams May 2016 B2
9354051 Dunne et al. May 2016 B2
9358688 Drew Jun 2016 B2
9367741 Le Marec Jun 2016 B2
9377301 Neier et al. Jun 2016 B2
9383200 Hulm et al. Jul 2016 B2
9395174 Bridges Jul 2016 B2
9405293 Meuleau Aug 2016 B2
9423282 Moy Aug 2016 B2
9437005 Tateno et al. Sep 2016 B2
9443308 Pettersson et al. Sep 2016 B2
9452533 Calkins et al. Sep 2016 B2
9454818 Cramer Sep 2016 B2
9476695 Becker et al. Oct 2016 B2
9482524 Metzler et al. Nov 2016 B2
9482525 Bridges Nov 2016 B2
9482746 Bridges Nov 2016 B2
9494686 Maryfield et al. Nov 2016 B2
9513100 Raab et al. Dec 2016 B2
9536163 Veeser et al. Jan 2017 B2
9541371 Pettersson et al. Jan 2017 B2
9561019 Mihailescu et al. Feb 2017 B2
9607239 Bridges et al. Mar 2017 B2
9618620 Zweigle et al. Apr 2017 B2
9658061 Wilson et al. May 2017 B2
9671221 Ruhland et al. Jun 2017 B2
9679385 Suzuki et al. Jun 2017 B2
9686532 Tohme Jun 2017 B2
9708079 Desjardien et al. Jul 2017 B2
9715730 Suzuki Jul 2017 B2
9720087 Christen et al. Aug 2017 B2
9734609 Pulla et al. Aug 2017 B2
9739595 Lau Aug 2017 B2
9746308 Gong Aug 2017 B2
9757859 Kolb et al. Sep 2017 B1
9768837 Charvat et al. Sep 2017 B2
9772173 Atwell et al. Sep 2017 B2
9803969 Gong Oct 2017 B2
9816813 Lettau et al. Nov 2017 B2
9829305 Gong Nov 2017 B2
9835717 Bosse et al. Dec 2017 B2
9844792 Pettersson et al. Dec 2017 B2
9879976 Bridges et al. Jan 2018 B2
9897442 Pettersson et al. Feb 2018 B2
9903939 Charvat et al. Feb 2018 B2
9909855 Becker et al. Mar 2018 B2
9915733 Fried et al. Mar 2018 B2
9921046 Gong Mar 2018 B2
9958268 Ohtomo et al. May 2018 B2
9958545 Eichenholz et al. May 2018 B2
9964398 Becker et al. May 2018 B2
9964402 Tohme et al. May 2018 B2
9967545 Tohme May 2018 B2
9989353 Bartmann et al. Jun 2018 B2
10012732 Eichenholz et al. Jul 2018 B2
10030972 Iseli et al. Jul 2018 B2
10041793 Metzler et al. Aug 2018 B2
10054422 Böckem et al. Aug 2018 B2
10058394 Johnson et al. Aug 2018 B2
10073162 Charvat et al. Sep 2018 B2
10074889 Charvat et al. Sep 2018 B2
10082521 Atlas et al. Sep 2018 B2
10090944 Charvat et al. Oct 2018 B1
10094909 Charvat et al. Oct 2018 B2
10126415 Becker et al. Nov 2018 B2
10189176 Williams Jan 2019 B2
10220511 Linnell et al. Mar 2019 B2
10240949 Peters et al. Mar 2019 B2
10876308 Pivac et al. Dec 2020 B2
11106836 Pivac et al. Aug 2021 B2
20020176603 Bauer et al. Nov 2002 A1
20030048459 Gooch Mar 2003 A1
20030090682 Gooch et al. May 2003 A1
20030120377 Hooke et al. Jun 2003 A1
20030206285 Lau Nov 2003 A1
20030208302 Lemelson Nov 2003 A1
20040078137 Breakfield et al. Apr 2004 A1
20040093119 Gunnarsson et al. May 2004 A1
20040200947 Lau Oct 2004 A1
20050007450 Hill et al. Jan 2005 A1
20050057745 Bontje Mar 2005 A1
20050060092 Hablani Mar 2005 A1
20050086901 Chisholm Apr 2005 A1
20050131619 Rappaport et al. Jun 2005 A1
20050196484 Khoshnevis Sep 2005 A1
20050252118 Matsufuji Nov 2005 A1
20060167587 Read Jul 2006 A1
20060215179 Mcmurtry et al. Sep 2006 A1
20070024870 Girard et al. Feb 2007 A1
20070229802 Lau Oct 2007 A1
20070284215 Rudge Dec 2007 A1
20080030855 Lau Feb 2008 A1
20080189046 Eliasson et al. Aug 2008 A1
20090038258 Pivac et al. Feb 2009 A1
20090074979 Krogedal et al. Mar 2009 A1
20100025349 Khoshnevis Feb 2010 A1
20100138185 Kang Jun 2010 A1
20100143089 Hvass Jun 2010 A1
20100152899 Chang et al. Jun 2010 A1
20100274390 Walser Oct 2010 A1
20100281822 Murray Nov 2010 A1
20110043515 Stathis Feb 2011 A1
20110066393 Groll et al. Mar 2011 A1
20110153524 Schnackel Jun 2011 A1
20110208347 Otake et al. Aug 2011 A1
20120038074 Khoshnevis Feb 2012 A1
20120099096 Bridges et al. Apr 2012 A1
20120136524 Everett et al. May 2012 A1
20120265391 Letsky Oct 2012 A1
20120277898 Kawai et al. Nov 2012 A1
20130028478 St-pierre et al. Jan 2013 A1
20130068061 Yoon Mar 2013 A1
20130103192 Huettenholer Apr 2013 A1
20130104407 Lee May 2013 A1
20130222816 Briggs et al. Aug 2013 A1
20130250285 Bridges et al. Sep 2013 A1
20130286196 Atwell Oct 2013 A1
20130297046 Hendron et al. Nov 2013 A1
20130310982 Scheurer Nov 2013 A1
20140002608 Atwell et al. Jan 2014 A1
20140067121 Brooks et al. Mar 2014 A1
20140176677 Valkenburg et al. Jun 2014 A1
20140192187 Atwell et al. Jul 2014 A1
20140309960 Vennegeerts et al. Oct 2014 A1
20140343727 Calkins et al. Nov 2014 A1
20140348388 Metzler Nov 2014 A1
20140366481 Benson Dec 2014 A1
20140376768 Troy Dec 2014 A1
20150082740 Peters et al. Mar 2015 A1
20150100066 Kostrzewski et al. Apr 2015 A1
20150134303 Chang et al. May 2015 A1
20150153720 Pettersson et al. Jun 2015 A1
20150158181 Kawamura Jun 2015 A1
20150165620 Osaka Jun 2015 A1
20150241203 Jordil et al. Aug 2015 A1
20150258694 Hand et al. Sep 2015 A1
20150276402 Grsser et al. Oct 2015 A1
20150280829 Breuer Oct 2015 A1
20150293596 Krausen et al. Oct 2015 A1
20150309175 Hinderling et al. Oct 2015 A1
20150314890 Desjardien et al. Nov 2015 A1
20150352721 Wicks et al. Dec 2015 A1
20150355310 Gong et al. Dec 2015 A1
20150367509 Georgeson Dec 2015 A1
20150371082 Csaszar et al. Dec 2015 A1
20150377606 Thielemans Dec 2015 A1
20160005185 Geissler Jan 2016 A1
20160093099 Bridges Mar 2016 A1
20160153786 Liu et al. Jun 2016 A1
20160187130 Metzler et al. Jun 2016 A1
20160187470 Becker et al. Jun 2016 A1
20160223364 Peters et al. Aug 2016 A1
20160242744 Mihailescu et al. Aug 2016 A1
20160263767 Williams Sep 2016 A1
20160274237 Stutz Sep 2016 A1
20160282107 Roland et al. Sep 2016 A1
20160282110 Vagman et al. Sep 2016 A1
20160282179 Nazemi et al. Sep 2016 A1
20160288331 Sivich et al. Oct 2016 A1
20160313114 Tohme et al. Oct 2016 A1
20160318187 Tani Nov 2016 A1
20160327383 Becker et al. Nov 2016 A1
20160340873 Eidenberger et al. Nov 2016 A1
20160341041 Puura et al. Nov 2016 A1
20160349746 Grau Dec 2016 A1
20160363436 Clark et al. Dec 2016 A1
20160363659 Mindell et al. Dec 2016 A1
20160363663 Mindell et al. Dec 2016 A1
20160363664 Mindell et al. Dec 2016 A1
20160364869 Siercks et al. Dec 2016 A1
20160364874 Tohme et al. Dec 2016 A1
20170028550 Terada Feb 2017 A1
20170066157 Peters et al. Mar 2017 A1
20170067739 Siercks et al. Mar 2017 A1
20170071680 Swarup Mar 2017 A1
20170082436 Siercks et al. Mar 2017 A1
20170091922 Siercks et al. Mar 2017 A1
20170091923 Siercks et al. Mar 2017 A1
20170108528 Atlas et al. Apr 2017 A1
20170122733 Brown May 2017 A1
20170122736 Dold et al. May 2017 A1
20170166399 Stubbs Jun 2017 A1
20170173796 Kim et al. Jun 2017 A1
20170176572 Charvat et al. Jun 2017 A1
20170179570 Charvat Jun 2017 A1
20170179603 Charvat et al. Jun 2017 A1
20170191822 Becker et al. Jul 2017 A1
20170227355 Pettersson et al. Aug 2017 A1
20170236299 Valkenburg et al. Aug 2017 A1
20170254102 Peters et al. Sep 2017 A1
20170269203 Trishaun Sep 2017 A1
20170291805 Hao et al. Oct 2017 A1
20170307757 Hinderling et al. Oct 2017 A1
20170314909 Dang Nov 2017 A1
20170314918 Shah Nov 2017 A1
20170333137 Roessler Nov 2017 A1
20170343336 Lettau Nov 2017 A1
20170371342 Hashimoto Dec 2017 A1
20180001479 Li et al. Jan 2018 A1
20180003493 Bernhard et al. Jan 2018 A1
20180017384 Siercks et al. Jan 2018 A1
20180023935 Atwell et al. Jan 2018 A1
20180038684 Fröhlich et al. Feb 2018 A1
20180046096 Shibazaki Feb 2018 A1
20180052233 Frank et al. Feb 2018 A1
20180108178 Murugappan et al. Apr 2018 A1
20180121571 Tiwari et al. May 2018 A1
20180149469 Becker et al. May 2018 A1
20180156601 Pontai Jun 2018 A1
20180170719 Tasch et al. Jun 2018 A1
20180180416 Edelman et al. Jun 2018 A1
20180202796 Ziegenbein Jul 2018 A1
20180209156 Pettersson Jul 2018 A1
20180239010 Mindell et al. Aug 2018 A1
20180300433 Maxam et al. Oct 2018 A1
20190026401 Benjamin et al. Jan 2019 A1
20190032348 Parkes Jan 2019 A1
20190184555 Linnell et al. Jun 2019 A1
20190224846 Pivac et al. Jul 2019 A1
20190251210 Pivac et al. Aug 2019 A1
20190316369 Pivac et al. Oct 2019 A1
20190352146 Pivac et al. Nov 2019 A1
20200206923 Pivac et al. Jul 2020 A1
20200206924 Pivac et al. Jul 2020 A1
20200215688 Pivac et al. Jul 2020 A1
20200215692 Pivac et al. Jul 2020 A1
20200215693 Pivac et al. Jul 2020 A1
20200324981 Pivac et al. Oct 2020 A1
20210016437 Pivac et al. Jan 2021 A1
20210016438 Pivac et al. Jan 2021 A1
20210080582 Pivac et al. Mar 2021 A1
20210291362 Pivac et al. Sep 2021 A1
20210370509 Pivac et al. Dec 2021 A1
20210379775 Pivac et al. Dec 2021 A1
Foreign Referenced Citations (153)
Number Date Country
645640 Jan 1994 AU
673498 Mar 1990 CH
2730976 Oct 2005 CN
2902981 May 2007 CN
2923903 Jul 2007 CN
101100903 Jan 2008 CN
201184054 Jan 2009 CN
101360873 Feb 2009 CN
101476883 Jul 2009 CN
100557169 Nov 2009 CN
101694130 Apr 2010 CN
201972413 Sep 2011 CN
102359282 Feb 2012 CN
202248944 May 2012 CN
202292752 Jul 2012 CN
102995911 Mar 2013 CN
202925913 May 2013 CN
103363902 Oct 2013 CN
103698769 Apr 2014 CN
203701626 Jul 2014 CN
104141391 Nov 2014 CN
104153591 Nov 2014 CN
104493810 Apr 2015 CN
204295678 Apr 2015 CN
104612411 May 2015 CN
204311767 May 2015 CN
103774859 Nov 2015 CN
103753586 Dec 2015 CN
105113373 Dec 2015 CN
105178616 Dec 2015 CN
105257008 Jan 2016 CN
105544998 May 2016 CN
104806028 Nov 2016 CN
205668271 Nov 2016 CN
205840368 Dec 2016 CN
205990775 Mar 2017 CN
206185879 May 2017 CN
206189878 May 2017 CN
105089274 Jun 2017 CN
105064699 Jul 2017 CN
107217859 Sep 2017 CN
107237483 Oct 2017 CN
107357294 Nov 2017 CN
107605167 Jan 2018 CN
206844687 Jan 2018 CN
107654077 Feb 2018 CN
107675891 Feb 2018 CN
107740591 Feb 2018 CN
106088632 Mar 2018 CN
107762165 Mar 2018 CN
207063553 Mar 2018 CN
106088631 May 2018 CN
107975245 May 2018 CN
108061551 May 2018 CN
108222527 Jun 2018 CN
108301628 Jul 2018 CN
108331362 Jul 2018 CN
106150109 Aug 2018 CN
108457479 Aug 2018 CN
108708560 Oct 2018 CN
208023979 Oct 2018 CN
106881711 Apr 2019 CN
107083845 Jun 2019 CN
108016585 Jul 2019 CN
3430915 Mar 1986 DE
4038260 Jun 1991 DE
4207384 Sep 1993 DE
19509809 Oct 1995 DE
4417928 Nov 1995 DE
29601535 May 1997 DE
19600006 Jul 1997 DE
19603234 Sep 1997 DE
19743717 Apr 1999 DE
19849720 May 2000 DE
10230021 Jul 2003 DE
102006030130 Sep 2007 DE
102009018070 Oct 2010 DE
102009042014 Mar 2011 DE
202012100646 Jun 2013 DE
102013019869 May 2015 DE
190076 Aug 1986 EP
370682 May 1990 EP
456020 Jan 1995 EP
493020 Apr 1995 EP
495525 Apr 1995 EP
836664 Jan 1999 EP
674069 Dec 1999 EP
1375083 Jan 2004 EP
1918478 May 2008 EP
2112291 Oct 2009 EP
2219528 Aug 2010 EP
2249997 Nov 2010 EP
2353801 Aug 2011 EP
2199719 Oct 2014 EP
3084719 Oct 2016 EP
2296556 Apr 2008 ES
2230825 Dec 1974 FR
2524522 Oct 1983 FR
119331 Oct 1918 GB
2198105 May 1923 GB
673472 Jun 1952 GB
682010 Nov 1952 GB
839253 Jun 1960 GB
1067604 May 1967 GB
1465068 Feb 1977 GB
125079 Dec 2001 GB
2422400 Jul 2006 GB
64006719 Jan 1989 JP
H07101509 Nov 1999 JP
2005283600 Oct 2005 JP
4294990 Apr 2009 JP
2009521630 Jun 2009 JP
5508895 Mar 2014 JP
87054 Jun 1989 LU
87381 Jun 1990 LU
88144 Apr 1994 LU
85392 Aug 2009 RU
9702397 Jan 1997 WO
2001076830 Oct 2001 WO
2004020760 Mar 2004 WO
2004083540 Feb 2005 WO
2005014240 Feb 2005 WO
2005017550 Feb 2005 WO
2005070657 Aug 2005 WO
2004011734 Nov 2005 WO
2006111827 Oct 2006 WO
2007076581 Jul 2007 WO
2008110559 Sep 2008 WO
2008124713 Oct 2008 WO
2009026641 Mar 2009 WO
2009026642 Mar 2009 WO
2010020457 Feb 2010 WO
2011077006 Jun 2011 WO
2013088154 Jun 2013 WO
2013134559 Sep 2013 WO
2018009978 Jan 2018 WO
2018009980 Jan 2018 WO
2018009981 Jan 2018 WO
2018009985 Jan 2018 WO
2018009986 Jan 2018 WO
2018052469 Apr 2018 WO
201899323 Jun 2018 WO
2019006511 Jan 2019 WO
2019014701 Jan 2019 WO
2019014702 Jan 2019 WO
2019014705 Jan 2019 WO
2019014706 Jan 2019 WO
2019014707 Jan 2019 WO
2019033165 Feb 2019 WO
2019033166 Feb 2019 WO
2019033170 Feb 2019 WO
2019068128 Apr 2019 WO
2019071313 Apr 2019 WO
Non-Patent Literature Citations (86)
Entry
Delgado, R. et al.: “Development and Control of an Omnidirectional Mobile Robot on an EtherCAT Network”, International Journal of Applied Engineering Research, vol. 11, No. 21, 2016, pp. 10586-10592, XP055574484.
Dorfler, K. et al.: “Mobile Robotic Brickwork , Automation of a Discrete Robotic Fabrication Process Using an Autonomous Mobile Robot Robotic Fabrication in Architecture”, Art and Design 2016, Feb. 4, 2016 (Feb. 4, 2016), pp. 204-217, XP055567451.
Egerstedt, M. et al.: “Control of Mobile Platforms using a Virtual Vehicle Approach”, IEEE Transactions On Automatic Control, vol. 46, No. 11, Nov. 2001 (Nov. 1, 2001), XP055567515.
Fastbrick Robotics, Fastbrick Robotics: Hadrian 105 First Look Revealed, Nov. 16, 2015 (Nov. 16, 2015), XP054978174, Retrieved from the Internet <URL:https://www.youtube.com/watch?v=7Zw7qHxMtrY> [retrieved on Nov. 16, 2015].
Fastbrick Robotics: Hadrian 105 Demonstrative Model Animation, Jun. 29, 2015 (Jun. 29, 2015), XP054979424, Retrieved from the Internet <URL:https://www.youtube.com/watch?v=Rebqcsb61gY> [retrieved on Mar. 7, 2018].
Fastbrick Robotics: Hadrian 105 Time Lapse, Fastbrick Robotics Time Lapse, May 22, 2016 (May 22, 2016), XP054978173, Retrieved from the Internet <URL:https://www.youtube.com/watch?v=4Ycr080NcfY> [retrieved on May 22, 2016].
Feng, C. et al.: “Vision Guided Autonomous Robotic Assembly and as-built Scanning on Unstructured Construction Sites”, Automation in Construction, vol. 59, Nov. 2015 (Nov. 1, 2015), pp. 128-138, XP055567454.
Gao, X. et al.: “Complete Solution Classification for the Perspective-Three-Point Problem”, IEEE Transactions On Pattern Analysis and Machine Intelligence, vol. 25, No. 8, Aug. 2003 (Aug. 1, 2003), pp. 930-943, XP011099374.
Giftthaler, M. et al., “Efficient Kinematic Planning for Mobile Manipulators with Non-holonomic Constraints Using Optimal Control”, 2017 IEEE International Conference on Robotics and Automation (ICRA), Singapore, May 29-Jun. 3, 2017.
Heintze, H., “Design and Control of a Hydraulically Actuated Industrial Brick Laying Robot,” 264 pages.
Heintze, J. et al., “Controlled hydraulics for a direct drive brick laying robot,” Automation in Construction 5 (1996), pp. 23-29.
Helm, V. et al.: “Mobile Robotic Fabrication on Construction Sites: dimRob”, IEEE /RSJ International Conference On Intelligent Robots and Systems, Oct. 7, 2012 (Oct. 7, 2012), Vilamoura, Portugal, pp. 4335-4341, XP032287463.
http://www.new-technologies.org/ECT/Other/brickrob.htm. “Emerging Construction Technologies.” Dec. 1, 2006.
Huang, S. et al., “Applying High-Speed Vision Sensing to an Industrial Robot for High-Performance Position Regulation under Uncertainties,” Sensors, 2016, 16, 1195, 15 pages.
International Preliminary Report on Patentability for International Application No. PCT/AU2017/050731; dated Jan. 15, 2019; 5 pages.
International Preliminary Report on Patentability for International Application No. PCT/AU2017/050738; dated Jan. 15, 2019; 13 pages.
International Preliminary Report on Patentability for International Application No. PCT/AU2017/050739; dated Jan. 15, 2019; 6 pages.
International Preliminary Report on Patentability for International Application No. PCT/AU2018/050733; dated Jan. 21, 2020; 6 pages.
International Preliminary Report on Patentability for International Application No. PCT/AU2018/050734; dated Jan. 21, 2020; 9 pages.
International Preliminary Report on Patentability for International Application No. PCT/AU2018/050737; dated Jan. 21, 2020; 6 pages.
International Preliminary Report on Patentability for International Application No. PCT/AU2018/050739; dated Jan. 21, 2020; 6 pages.
International Preliminary Report on Patentability for International Application No. PCT/AU2018/050740; dated Jan. 21, 2020; 6 pages.
International Search Report and Written Opinion for International Application No. PCT/AU2017/050730; dated Aug. 23, 2017; 17 pages.
International Search Report and Written Opinion for International Application No. PCT/AU2017/050731; dated Aug. 31, 2017; 8 pages.
International Search Report and Written Opinion for International Application No. PCT/AU2017/050738; dated Oct. 17, 2017; 19 pages.
International Search Report and Written Opinion for International Application No. PCT/AU2017/050739; dated Sep. 28, 2017; 9 pages.
Kazemi, M. et al.: “Path Planning for Image-based Control of Wheeled Mobile Manipulators”, 2012 IEEE/RSJ International Conference On Intelligent Robots and Systems, Oct. 7, 2012 (Oct. 7, 2012), Vilamoura, Portugal, XP055567470.
Kleinkes, M. et al.: “Laser Tracker and 6DoF measurement strategies in industrial robot applications”, CMSC 2011: Coordinate Metrology System Conference, Jul. 25, 2011 (Jul. 25, 2011), XP055456272.
Koren et al.: “End-effector guidance of robot arms”, CIRP Annals—Manufacturing Technology, vol. 36, No. 1, 1987, pp. 289-292, XP055456270.
Kwon, S. et al., “On the Coarse/Fine Dual-Stage Manipulators with Robust Perturbation Compensator,” IEEE, May 21-26, 2001, pp. 121-126.
Kyle in CMSC: Charlotte-Concord, Jul. 21-25, 2008.
Latteur, et al., “Drone-Based Additive Manufacturing of Architectural Structures,” IASS Symposium 2015, Amsterdam, The Netherlands; Aug. 17-20, 2015; 12 pages.
Lippiello, V. et al.: “Position-Based Visual Servoing in Industrial Multirobot Cells Using a Hybrid Camera Configuration”, IEEE Transactions On Robotics, vol. 23, No. 1, Feb. 2007 (Feb. 1, 2007), XP011163518.
Liu, Z. et al.: “EtherCAT Based Robot Modular Joint Controller”, Proceeding of The 2015 IEEE International Conference On Information and Automation, Aug. 2015 (Aug. 1, 2015), Lijiang, China, pp. 1708-1713, XP033222650.
Notice of Acceptance of Patent Application received for priority Australian Patent Application No. 2017294796, dated May 15, 2019 (158 pages).
Pless, R .: “Using Many Cameras as One”, IEEE Computer Society Conference On Computer Vision and Pattern Recognition, Jun. 18, 2003 (Jun. 18, 2003), Madison , WI, USA, pp. 1-7, XP055564465.
Posada et al.: “High accurate robotic drilling with external sensor and compliance model-based compensation”, Robotics and Automation (ICRA), 2016 IEEE International Conference, May 16, 2016 (May 16, 2016), pp. 3901-3907, XP032908649.
Pritschow, G. et al., “A Mobile Robot for On-Site Construction of Masonry,” Inst. Of Control Tech. for Machine Tools and Manuf. Units, pp. 1701-1707.
Pritschow, G. et al., “Application Specific Realisation of a Mobile Robot for On-Site Construction of Masonry,” Automation and Robotics in Construction XI, 1994, pp. 95-102.
Pritschow, G. et al., “Configurable Control System of a Mobile Robot for ON-Site Construction of Masonry,” Inst. Of Control Technology for Machine Tools and Manuf. Units, pp. 85-92.
Pritschow, G. et al., “Technological aspects in the development of a mobile bricklaying robot,” Automation in Construction 5 (1996), pp. 3-13.
Riegl Laser Measurement Systems. “Long Range & High Accuracy 3D Terrestrial Laser Scanner System—LMS-Z420i.” pp. 1-4.
Salcudean, S. et al., “On the Control of Redundant Coarse-Fine Manipulators,” IEEE, pp. 1834-1840.
Sandy, T. et al.: “Autonomous Repositioning and Localization of an In Situ Fabricator”, 2016 IEEE International Conference On Robotics and Automation (ICRA), May 16, 2016 (May 16, 2016), pp. 2852-2858, XP055567467.
Skibniewski, M.J., “Current Status of Construction Automation and Robotics in the United States of America,” The 9th International Symposium on Automation and Robotics in Construction, Jun. 3-5, 1992, 8 pages.
Trimble ATS. “Advanced Tracking Sensor (ATS) with target recognition capability for stakeless machine control survey applications.” pp. 1-4.
Vincze, M. et al., “A Laser Tracking System to Measure Position and Orientation of Robot End Effectors Under Motion,” The International Journal of Robotics Research, vol. 13, No. 4, Aug. 1994, pp. 305-314.
Warszawski, A. et al., “Implementation of Robotics in Building: Current Status and Future Prospects,” Journal of Construction Engineering and Management, Jan./Feb. 1998, 124(1), pp. 31-41.
Willmann, J. et al.: “Robotic Timber Construction—Expanding Additive Fabrication to New Dimensions”, Automation in Construction, vol. 61, 2016, pp. 16-23, XP029310896.
Xu, H. et al.: “Uncalibrated Visual Servoing of Mobile Manipulators with an Eye-to-hand Camera”, Proceedings of The 2016 IEEE International Conference On Robotics and Biomimetics, Dec. 3, 2016 (Dec. 3, 2016), Qingdao, China, pp. 2145-2150, XP033071767.
Yu, S.N. et al., “Feasibility verification of brick-laying robot using manipulation trajectory and the laying pattern optimization,” Dept. of Mech. Eng., Automation in Construction (2009), pp. 644-655.
Partial Supplementary European Search Report dated Apr. 14, 2020 in European Patent Application No. 17826696.1, 10 pages.
Zaki, T., “Parametric modeling of Blackwall assemblies for automated generation of shop drawings and detailed estimates using BIM”, Master's Thesis, May 23, 2016, pp. 1-151.
Boston Dynamics: “Introducing Spot (previously SpotMini)”, Jun. 28, 2016, YouTube video, 1 page (screenshot of video); video retrieved at <https://www.youtube.com/watch?v=tf7IEVTDjng>.
Examination Report dated Apr. 18, 2021 in GCC Patent Application No. 2018-35644, 5 pages.
Examination Report dated Apr. 30, 2021 in GCC Patent Application No. 2018-35643, 3 pages.
Examination Report dated Jun. 29, 2021 for India Patent Application No. 201927004006, 6 pages.
Examination Report dated Sep. 30, 2021 for Australian Patent Application No. 2017295316, 3 pages.
Extended European Search Report dated Jun. 4, 2021 for European Patent Application No. 18865644.1, 7 pages.
Extended European Search Report dated Mar. 16, 2021 for European Patent Application No. 18834565.6, 19 pages.
Extended European Search Report dated Mar. 17, 2021 for European Patent Application No. 18835861.8, 12 pages.
Extended European Search Report dated Mar. 18, 2021 for European Patent Application No. 18834673.8, 14 pages.
Extended European Search Report dated Mar. 18, 2021 for European Patent Application No. 18834893.2, 12 pages.
Extended European Search Report dated Mar. 18, 2021 for European Patent Application No. 18835737.0, 10 pages.
Extended European Search Report dated Mar. 30, 2021 for European Patent Application No. 18845794.9, 13 pages.
Extended European Search Report dated Mar. 5, 2021 for European Patent Application No. 18828425.1, 7 pages.
Fastbrick Robotics: Hadrian X Digital Construction System, published on Sep. 21, 2016 <URL: https://www.youtube.com/watch?v=5bW1vuCgEaA >.
Gander H et al.: “Application of a floating point digital signal processor to a dynamic robot measurement system”, Instrumentation and Measurement Technology Conference, 1994. IMTC/94. Conference Proceedings. 10th Anniversary. Advanced Technologies in I & M 1994 IEEE Hamamatsu, Japan May 10-12, 1994, New York, NY, USA, IEEE, May 10, 1994 (May 10, 1994), pp. 372-375, XP010121924, DOI: 10.1109/IMTC.1994.352046, ISBN: 978-0-7803-1880-9, *whole document*.
Garrido, S. et al., “FM2: A real-time fast marching sensor based motion planner”, Advanced Intelligent Mechatronics, 2007 IEEE/ASME International Conference On, IEEE, PI, Sep. 1, 2007 (Sep. 1, 2007), pp. 1-6.
International Search Report and Written Opinion for International Patent Application No. PCT/AU19/50742; dated Sep. 23, 2019; 5 pages.
International Search Report and Written Opinion for International Patent Application No. PCT/AU19/50743; dated Oct. 1, 2019; 10 pages.
International Search Report and Written Opinion for International Patent Application No. PCT/AU20/50367; dated Jun. 29, 2020; 15 pages.
International Search Report and Written Opinion for International Patent Application No. PCT/AU20/50368; dated Jun. 25, 2020; 11 pages.
Kleinigger, M. et al.: “Application of 6-DOF sensing for robotic disturbance compensation”, Automation Science and Engineering (CASE), 2010 IEEE Conference On, IEEE, Piscataway, NJ, USA, Aug. 21, 2010 (Aug. 21, 2010, pp. 344-349, XP031762876, ISBN: 978-1-4244-5477-1, *abstract*, *sections 1 to 3*.
Mercedes-Benz: “Mercedes-Benz “Chicken” Magic Body Control TV commercial”, YouTube, Sep. 23, 2013, 1 page. Retrieved from the internet: <https://www.youtube.com/watch?v+nLwML2PagbY>.
Office Action dated Apr. 21, 2021 in Japanese Patent Application No. 2019-523148, 4 pages.
Office Action dated Aug. 20, 2021 for Japanese Patent Application No. 2019-523147, 3 pages.
Office Action dated Jul. 5, 2021 for Japanese Patent Application No. 2019-523145, 4 pages.
Office Action dated May 24, 2021 for Chinese Patent Application No. 201880067520.0, 8 pages.
Office Action dated Sep. 3, 2021 for Chinese Patent Application No. 201780056460.8, 9 pages.
Siciliano, B. et al., “Robotics—chapters 2-4” Robotics, Dec. 31, 2009 (Dec. 31, 2009), Springer London, London, pp. 39-189.
European search report dated Mar. 28, 2022 in European Patent Application No. 19837417.5, 10 pages.
European search report dated Mar. 7, 2022 in European Patent Application No. 19838430.7, 9 pages.
Examination report dated Feb. 24, 2022 in Australian Patent Application No. 2017295317, 3 pages.
Examination report dated Dec. 26, 2021 in Saudi Arabian Patent Application No. 519400899, 8 pages.
Examination report dated Feb. 9, 2022 in Chinese Patent Application No. 201880067520.0, with English translation, 14 pages.
Related Publications (1)
Number Date Country
20200173777 A1 Jun 2020 US