USE OF INCLINOMETERS TO IMPROVE RELOCATION OF A PORTABLE ARTICULATED ARM COORDINATE MEASURING MACHINE
A method of relocating a portable articulated arm coordinate measuring machine (AACMM) from a first location to a second location, wherein the AACMM has, at the first location, a first origin point and a first frame of reference and, at the second location, a second origin point and a second frame of reference, the method including the steps of: measuring an amount of tilt of the portable AACMM along two perpendicular directions, each of which are approximately perpendicular to a gravity vector, with the portable AACMM in each of the first and second locations; measuring a first target and a second target with the portable AACMM in the first location to obtain, in the first frame of reference, a first set of x, y, and z coordinates and a second set of x, y, and z coordinates; measuring the first target and the second target with the portable AACMM in the second location to obtain, in the second frame of reference, a third set of x, y, and z coordinates and a fourth set of x, y, and z coordinates; and finding x, y, and z coordinates of the second origin point with respect to the first frame of reference, wherein the x, y, and z coordinates of the second origin point are found using the first, second, third, and fourth sets of x, y, and z coordinates but without using additional x, y, and z coordinates of a third target measured with the AACMM at the first location and at the second location.
Latest FARO TECHNOLOGIES, INC. Patents:
- Construction site defect and hazard detection using artificial intelligence
- DETECTING OBJECTS OF INTERESTS IN PANORAMIC IMAGES OF AN ENVIRONMENT
- Referencing pose manipulation system for marker based tracking of position measurement system
- Photosensor processing for improved line scanner performance
- Calibrating system for colorizing point-clouds
The present application claims the benefit of provisional application No. 61/296,555 filed Jan. 20, 2010, the content of which is hereby incorporated by reference in its entirety.
BACKGROUNDThe present disclosure relates to coordinate measuring machines, and more particularly to a portable articulated arm coordinate measuring machine having one or more inclinometers located on or within the portable articulated arm coordinate measuring machine and which may be used to improve the accuracy of a relocation of the portable articulated arm coordinate measuring machine between different locations.
Portable articulated arm coordinate measuring machines (AACMMs) have found widespread use in the manufacturing or production of parts where there is a need to rapidly and accurately verify the dimensions of the part during various stages of the manufacturing or production (e.g., machining) of the part. Portable AACMMs represent a vast improvement over known stationary or fixed, cost-intensive and relatively difficult to use measurement installations, particularly in the amount of time it takes to perform dimensional measurements of relatively complex parts. Typically, a user of a portable AACMM simply guides a probe along the surface of the part or object to be measured. The measurement data are then recorded and provided to the user. In some cases, the data are provided to the user in visual form, for example, three-dimensional (3-D) form on a computer screen. In other cases, the data are provided to the user in numeric form, for example when measuring the diameter of a hole, the text “Diameter=1.0034” is displayed on a computer screen.
An example of a prior art portable articulated arm CMM is disclosed in commonly assigned U.S. Pat. No. 5,402,582 ('582), which is incorporated herein by reference in its entirety. The '582 patent discloses a 3-D measuring system comprised of a manually-operated articulated arm CMM having a support base on one end and a measurement probe at the other end. Commonly assigned U.S. Pat. No. 5,611,147 ('147), which is incorporated herein by reference in its entirety, discloses a similar articulated arm CMM. In the '147 patent, the articulated arm CMM includes a number of features including an additional rotational axis at the probe end, thereby providing for an arm with either a two-two-two or a two-two-three axis configuration (the latter case being a seven axis arm).
What is needed is a portable AACMM that includes one or more inclinometers located on or within the portable AACMM and which may be used to improve the accuracy of a relocation of the portable AACMM, and/or may be used to reduce the number of targets (e.g., nests, seats, or fixtures) required for the portable AACMM to complete a relocation of itself when measurement of a relatively large part by the portable AACMM requires that the portable AACMM to be physically moved between different locations to complete the measurement.
SUMMARY OF THE INVENTIONA method of relocating a portable articulated arm coordinate measuring machine (AACMM) from a first location to a second location, wherein the AACMM has, at the first location, a first origin point and a first frame of reference and, at the second location, a second origin point and a second frame of reference, the method including the steps of: measuring an amount of tilt of the portable AACMM along two perpendicular directions, each of which are approximately perpendicular to a gravity vector, with the portable AACMM in each of the first and second locations; measuring a first target and a second target with the portable AACMM in the first location to obtain, in the first frame of reference, a first set of x, y, and z coordinates and a second set of x, y, and z coordinates; measuring the first target and the second target with the portable AACMM in the second location to obtain, in the second frame of reference, a third set of x, y, and z coordinates and a fourth set of x, y, and z coordinates; and finding x, y, and z coordinates of the second origin point with respect to the first frame of reference, wherein the x, y, and z coordinates of the second origin point are found using the first, second, third, and fourth sets of x, y, and z coordinates but without using additional x, y, and z coordinates of a third target measured with the AACMM at the first location and at the second location.
Referring now to the drawings, exemplary embodiments are shown which should not be construed to be limiting regarding the entire scope of the disclosure, and wherein the elements are numbered alike in several FIGURES:
Embodiments of the present invention include one or more inclinometers located on or within a portable AACMM and which may be used to improve the accuracy of a relocation of the portable AACMM, and/or may be used to reduce the number of targets (e.g., nests, seats, or fixtures) required for the portable AACMM to complete a relocation of the portable AACMM when measurement of a relatively large part by the portable AACMM requires that the portable AACMM to be physically moved between different locations to complete the measurement.
Each bearing cartridge within each bearing cartridge grouping 110, 112, 114 typically contains an encoder system (e.g., an optical angular encoder system). The encoder system (i.e., transducer) provides an indication of the position of the respective arm segments 106, 108 and corresponding bearing cartridge groupings 110, 112, 114 that all together provide an indication of the position of the probe 118 with respect to the base 116 (and, thus, the position of the object being measured by the AACMM 100 in a certain frame of reference—for example a local or global frame of reference). The arm segments 106, 108 may be made from a suitably rigid material such as but not limited to a carbon composite material for example. A portable AACMM 100 with six or seven axes of articulated movement (i.e., degrees of freedom) provides advantages in allowing the operator to position the probe 118 in a desired location within a 360° area about the base 116 while providing an arm portion 104 that may be easily handled by the operator. However, it should be appreciated that the illustration of an arm portion 104 having two arm segments 106, 108 is for exemplary purposes, and the claimed invention should not be so limited. An AACMM 100 may have any number of arm segments coupled together by bearing cartridges (and, thus, more or less than six or seven axes of articulated movement or degrees of freedom).
The probe 118 is detachably mounted to the measurement probe housing 102, which is connected to bearing cartridge grouping 112. A handle 126 is removable with respect to the measurement probe housing 102 by way of, for example, a quick-connect interface. The handle 126 may be replaced with another device (e.g., a laser line probe, a bar code reader), thereby providing advantages in allowing the operator to use different measurement devices with the same AACMM 100. In exemplary embodiments, the probe housing 102 houses a removable probe 118, which is a contacting measurement device and may have different tips 118 that physically contact the object to be measured, including, but not limited to: ball, touch-sensitive, curved and extension type probes. In other embodiments, the measurement is performed, for example, by a non-contacting device such as a laser line probe (LLP). In an embodiment, the handle 126 is replaced with the LLP using the quick-connect interface. Other types of measurement devices may replace the removable handle 126 to provide additional functionality. Examples of such measurement devices include, but are not limited to, one or more illumination lights, a temperature sensor, a thermal scanner, a bar code scanner, a projector, a paint sprayer, a camera, or the like, for example.
As shown in
In various embodiments, each grouping of bearing cartridges 110, 112, 114 allows the arm portion 104 of the AACMM 100 to move about multiple axes of rotation. As mentioned, each bearing cartridge grouping 110, 112, 114 includes corresponding encoder systems, such as optical angular encoders for example, that are each arranged coaxially with the corresponding axis of rotation of, e.g., the arm segments 106, 108. The optical encoder system detects rotational (swivel) or transverse (hinge) movement of, e.g., each one of the arm segments 106, 108 about the corresponding axis and transmits a signal to an electronic data processing system within the AACMM 100 as described in more detail herein below. Each individual raw encoder count is sent separately to the electronic data processing system as a signal where it is further processed into measurement data. No position calculator separate from the AACMM 100 itself (e.g., a serial box) is required, as disclosed in commonly assigned U.S. Pat. No. 5,402,582 ('582).
The base 116 may include an attachment device or mounting device 120. The mounting device 120 allows the AACMM 100 to be removably mounted to a desired location, such as an inspection table, a machining center, a wall or the floor for example. In one embodiment, the base 116 includes a handle portion 122 that provides a convenient location for the operator to hold the base 116 as the AACMM 100 is being moved. In one embodiment, the base 116 further includes a movable cover portion 124 that folds down to reveal a user interface, such as a display screen.
In accordance with an embodiment, the base 116 of the portable AACMM 100 contains or houses an electronic data processing system that includes two primary components: a base processing system that processes the data from the various encoder systems within the AACMM 100 as well as data representing other arm parameters to support three-dimensional (3-D) positional calculations; and a user interface processing system that includes an on-board operating system, a touch screen display, and resident application software that allows for relatively complete metrology functions to be implemented within the AACMM 100 without the need for connection to an external computer.
The electronic data processing system in the base 116 may communicate with the encoder systems, sensors, and other peripheral hardware located away from the base 116 (e.g., a LLP that can be mounted to the removable handle 126 on the AACMM 100). The electronics that support these peripheral hardware devices or features may be located in each of the bearing cartridge groupings 110, 112, 114 located within the portable AACMM 100.
As shown in
Also shown in
In an embodiment shown in
The base processor board 204 also manages all the wired and wireless data communication with external (host computer) and internal (display processor 202) devices. The base processor board 204 has the capability of communicating with an Ethernet network via an Ethernet function 320 (e.g., using a clock synchronization standard such as Institute of Electrical and Electronics Engineers (IEEE) 1588), with a wireless local area network (WLAN) via a LAN function 322, and with Bluetooth module 232 via a parallel to serial communications (PSC) function 314. The base processor board 204 also includes a connection to a universal serial bus (USB) device 312.
The base processor board 204 transmits and collects raw measurement data (e.g., encoder system counts, temperature readings) for processing into measurement data without the need for any preprocessing, such as disclosed in the serial box of the aforementioned '582 patent. The base processor 204 sends the processed data to the display processor 328 on the user interface board 202 via an RS485 interface (IF) 326. In an embodiment, the base processor 204 also sends the raw measurement data to an external computer.
Turning now to the user interface board 202 in
The electronic data processing system 210 shown in
Though shown as separate components, in other embodiments all or a subset of the components may be physically located in different locations and/or functions combined in different manners than that shown in
Referring to
In exemplary embodiments, an inclinometer, which may have at least one measuring axis, but having two measuring axes in exemplary embodiments, may be placed within or on the portable AACMM 100. The inclinometer may be placed anywhere in or on the portable AACMM 100, but may be placed within the bearing cartridge grouping 114 located above the base 116. Another alternative embodiment is to place the inclinometer within the base 116 of the portable AACMM 100. Thus, in these exemplary embodiments, the inclinometer is not visible in
Relocation is typically defined to be a procedure in which the portable AACMM 100 is moved from an initial or first physical location with respect to the part being measured to one or more subsequent different physical locations with respect to the part being measured while retaining the same global frame of reference during the measurement process. By performing a relocation, a portable AACMM 100 may access a greater portion (preferably all or the entirety) of a relatively large object (e.g., an automobile) for measurement purposes. Without performing a relocation, the portable AACMM 100 being held in only one physical location may not be able to access, and thus measure, the entire part or object, as the total distance between the measurement probe 118 and the base 116 of the portable AACMM 100 with the arm segments 106, 108 fully extended may typically be only several feet, as is common with modern portable AACMMs 100, which may not be adequate to measure the entire part. In addition, using previous relocation methods, a minimum of three targets was required to perform relocation. Using a two-axis inclinometer with the method described herein according to embodiments of the present invention, a relocation of the portable AACMM 100 may be obtained using just two targets.
A common method of relocation of a portable AACMM 100 is usually referred to as the “leapfrog” method. With this method, three or more targets are placed on a stationary object. A portable AACMM 100 located in a first or initial location is used to measure the coordinates of these three or more targets. The portable AACMM 100 is then moved to a second location, where it is again used to measure the coordinates of the three or more targets. Mathematical methods are used to adjust the frame of reference of the portable AACMM 100 in the second position 430 to that of the portable AACMM 100 in the first location or to some other global frame of reference.
A related method of portable AACMM relocation uses targets permanently attached to a grid in the vicinity in which the portable AACMM 100 is used. However, floors typically suffer from thermal expansion and other defects. Another related method has the portable AACMM 100 measure the vertices of a small pyramid, which may be made of a relatively low coefficient of thermal expansion (CTE) material. Such artifacts have the undesirable characteristics of being small and expensive. All of the above methods have the disadvantage of increasing error each time a leapfrog operation is performed. Due to the fact that six degrees of freedom (three translational and three orientational degrees of freedom) must be obtained each time relocation is performed (i.e., for a six axis portable AACMM 100), the resulting errors in the global frame of reference often are about as large as the errors in the portable AACMM 100 itself. With each succeeding leapfrog operation, errors in the global frame of reference increase. Another disadvantage of the above mentioned methods is that they tend to be time-consuming. Usually many targets must be measured to obtain the information needed for a single relocation.
In embodiments of the present invention, benefits include improved accuracy and reduced measurement time. In exemplary embodiments, a two-axis inclinometer may be used. In this case, both axes of the inclinometer lie in a plane that is approximately parallel to the floor or other surface (e.g., table top) upon or to which the portable AACMM 100 is mounted. The inclinometer may be placed within the bearing cartridge grouping 114 located above the base 116 of the portable AACMM 100. By then rotating this axis, the readings of the inclinometer can be taken as a function of the rotation angle. By using this information, it is possible to compensate for systematic errors in the inclinometer sensor. After performing this compensation, it is usually possible to limit errors in the inclinometer readings to less than one arc second, even with some relatively inexpensive inclinometers.
By using a two-axis inclinometer, two of the six degrees of freedom can be eliminated from the relocation calculations. There are many known mathematical methods that can be used to perform relocation. The most common method fits the collected data to equations that relate the measured coordinates. This type of calculation is known as an optimization or best-fit calculation, and for a specific case in which the portable AACMM 100 is moved to two or more different locations, is often called a “bundle adjustment.”
In accordance with embodiments of the present invention, a relatively simple mathematical method demonstrates the performance of a relocation of a portable AACMM 100 using two targets, rather than the usual three (or more) targets as described herein above, for the case in which the portable AACMM 100 is equipped with a dual axis inclinometer.
The targets 410, 420 may each comprise a relatively rigid device, such as a nest, seat or fixture. The probe tip 118 of the portable AACMM 100 may be placed in a relative secure manner within each nest, seat or fixture (Nest A 410, Nest B 420) during the execution of the method of embodiments of the present invention. The AACMM 100 measures the position of the probe 118 with respect to the origin of the AACMM 100 (which might be located in the base 116, for example) when the AACMM 100 is in first position 400 and the probe 118 is first seated in Nest A 410 and is then seated in Nest B 420.
After the portable AACMM 100 is moved to second position 430, as shown in
A method for obtaining this result according to embodiments of this aspect of the present invention is described with reference to
The AACMM 100 has a local frame of reference, which is the frame of reference with which measurements of the articulated arm are referred. For example, in the local frame of reference, a simple choice (shown in
When the AACMM 100 is moved to second position 430, the z axis in the new local frame of reference will again be approximately aligned with the gravity vector, and the x and y axes will again be in a plane that is approximately horizontal. The x and y axes in the local frame of reference at second position 430 will probably not be parallel to the corresponding x and y axes of the local frame of reference at first position 400. In order to convert the coordinate data collected in positions 1 and 2 by AACMM 100, a method is needed to display the measured data in the same frame of reference. In other words, collected coordinate data needs to be transformed into a common frame of reference.
There are many ways to do such a transformation. A simple way is to first convert the local frame of reference of the AACMM 100 at first position 400 into a gravity frame of reference at first position 400. This is done by rotating the z axis in such a way as to align it with the gravity vector. The information needed to perform such a mathematical rotation is provided by the 2-axis inclinometer. Similarly, the local frame of reference of the AACMM 100 at second position 430 can be converted into a gravity frame of reference at second position 430 by using the information provided by the inclinometer. The rotational matrix that is used to rotate the local frame of reference of the AACMM 100 at first position 400 to the gravity frame of reference at first position 400 can also be applied to all of the coordinates measured by the AACMM 100 at first position 400. The result is that all of the measured points are given in the gravity frame of reference of the AACMM 100 at first position 400.
The rotational matrix that is used to rotate the local frame of reference of the AACMM 100 at second position 430 to the gravity frame of reference at second position 430 can also be applied to all of the points measured by the AACMM 100 at second position 430. The result is that all of the measured points are given in the gravity frame of reference of the AACMM 100 at second position 430. To move the data measured by the AACMM 100 at second position 430 into the frame of reference of the AACMM 100 at first position 400, two further transformations are needed. First, all of the coordinate data collected by the AACMM 100 at second position 430 needs to be translated or shifted along the x, y, and z directions of the gravity frame of reference of the AACMM 100 at first position 400 by an amount that would cause the origin of the AACMM 100 at second position 430 to coincide with the origin at first position 400. Second, all of the coordinate data needs to be rotated about the gravity vector by an amount that would cause the x and y axes in the gravity frame of reference of the AACMM 100 at second position 430 to be parallel to the corresponding x and y axes in the gravity frame of reference of the AACMM 100 at first position 400. The amount of rotation about the gravity vector is called the yaw angle.
To summarize, one way to transform data so that it can be compared in a common frame of reference is to first use the tilt angles measured by the inclinometer to rotate coordinate data into the gravity frame of reference of first position 400, which is the common frame of reference for the combined data. Next, the tilt angles measured by the inclinometer are used to rotate the coordinate data into the gravity frame of reference of second position 430. The data are translated by an appropriate amount in the x, y, and z directions, and the x and y data are rotated about the z axis.
Methods for doing rotations and translations of coordinate data are well known to those of ordinary skill in the art. A rotation in three dimensional space may be obtained by multiplying a 3×3 rotation matrix by a 3 element coordinate vector. Translation and rotation steps can be combined in a single 4×4 matrix. Because these methods are so well known, they are not discussed further here.
It is also possible to move data collected with the AACMM 100 in two different positions by using different types of transformations. For example, it would be possible to compare the data collected by the AACMM 100 at second position 430 to the local frame of reference of the AACMM 100 at first position 400 rather than to the gravity frame of reference of the AACMM 100 at first position 400. A single matrix rotation is sufficient to transform the data in a gravity frame of reference into a local frame of reference. Similarly, it would be possible to convert coordinate data into an arbitrary global frame of reference. In this case, suitable additional rotations and translations are applied to the coordinate data from the AACMM 100 at the first and second positions. By the same token, it will obvious to one of ordinary skill in the art that additional relocations are possible to a third position, a fourth position, and so forth. The same mathematical methods are used for each successive relocation.
Embodiments of the method of the present invention may be embodied in software or firmware that may be stored internal to the AACMM 100, for example, as instructions stored within memory 332 on the user interface board 202 (
Referring also to
The inclinometer is used in a step 1010 to measure the tilt of the portable AACMM 100 along the x and y directions at first and second positions. Then, in step 1020, each of the AACMM readings is corrected to be in the gravity frame of reference, where z in the new AACMM frame of reference coincides with the gravity vector. The new x and y vectors are perpendicular to the gravity vector.
In this instance, the tilt sensor is used to measure the tilt in two directions with respect to the gravity vector. This may be done by using a two-axis tilt sensor in the base. Alternatively a single axis tilt sensor may be located in the rotating portion of bearing cartridge grouping 114. In the latter case, the inclinometer is used to measure the tilt angle at two or more positions as the operator rotates the arm in an appropriate way.
Next, in step 1030, the coordinates of Nests A and B 410, 420 (in the gravity frame of reference) are read with the portable AACMM 100 at first position 400. These coordinates may be referred to as (xA, yA, zA) and (xB, yB, zB). In step 1040, step 1030 is repeated with the portable AACMM 100 at second position 430 to obtain coordinates (xA′, yA′, zA′) and (xB′, yB′, zB′).
The coordinates of the origin point of the portable AACMM 100 at first position 400 are (0, 0, 0). Next, in step 1050, as shown in
As shown in top views of
(X−xA)2+(Y−yA)2=(xA′)2+(yA′)2 (Eq. 1)
(X−xB)2+(Y−yB)2=(xB′)2+(yB′)2 (Eq. 2)
The analytical solution to Equations 1 and 2 contain many terms. Numerical methods for solving these equations are relatively fast and are preferred. There are two possible solutions for X and Y from these equations, but only one of these solutions will be reasonable, and the other possible solution can be eliminated.
The x and y components of the vector from Nest B 420 to Nest A 410 are xA−xB and yA−yB, respectively. Next, in step 1070 the yaw angle θ of the portable AACMM 100 at second position 430 is selected to match these vector x and y components. The errors in the x and y components are given by the following equations:
Ex=(xA′−xB′)cos θ+(yA′−yB′)sin θ−(xA−xB) (Eq. 3)
Ey=(xA′−xB′)(−sin θ)+(yA′−yB′)cos θ−(yA−yB) (Eq. 4)
To find the relatively best value for 0, the standard method of minimizing the squared error of these two terms may be used in step 1070. In other words, θ can be found by minimizing the error in Ex2+Ey2.
It should be noted that the order of the actions in
Although a detailed procedure has been given herein above to demonstrate that use of inclinometers in the portable AACMM 100 makes it possible to relocate the portable AACMM 100 using only two targets in accordance with embodiments of the present invention, the specific method of calculation set forth herein is merely exemplary, as other methods may be used to mathematically extract the four relevant parameters for the coordinates of the portable AACMM 100 at second position 430 and for the yaw angle. In addition, an equivalent method may be used to move or relocate the portable AACMM 100 to a third different location, a fourth different location, and so on, although detailed steps have not been given for this, yet these steps should be obvious to one of ordinary skill in the art. Embodiments of this aspect of the present invention have utility in that they improve the accuracy of the relocation process and that they reduce the amount of time required to perform the relocation procedure.
The mathematical methods described above provides a fast and accurate method for finding the four quantities X, Y, Z, and a However, these four quantities can be found with other mathematical methods. For example, it is possible to write equations that can be solved using an iterative optimization procedure for all four variables. Therefore, the mathematical computation should not be limited to that described by Equations (1)-(4).
Technical effects and benefits include the inclusion of one or more inclinometers located on or within a portable AACMM and which may be used to improve the accuracy of relocation of the portable AACMM, and/or may be used to reduce the number of targets (e.g., nests, seats, or fixtures) required for the portable AACMM 100 to complete a relocation of itself when measurement of a large part by the portable AACMM 100 requires that the portable AACMM 100 to be physically moved between different locations.
As will be appreciated by one skilled in the art, aspects of the present invention may be embodied as a system, method, or computer program product. Accordingly, aspects of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, aspects of the present invention may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.
Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that may contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
Computer program code for carrying out operations for aspects of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++, C# or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Aspects of the present invention are described with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, may be implemented by computer program instructions.
These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer program instructions may also be stored in a computer readable medium that may direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods, and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the Figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, may be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
While the invention has been described with reference to example embodiments, it will be understood by those skilled in the art that various changes may be made and equivalents may be substituted for elements thereof without departing from the scope of the invention. In addition, many modifications may be made to adapt a particular situation or material to the teachings of the invention without departing from the essential scope thereof. Therefore, it is intended that the invention not be limited to the particular embodiment disclosed as the best mode contemplated for carrying out this invention, but that the invention will include all embodiments falling within the scope of the appended claims. Moreover, the use of the terms first, second, etc. do not denote any order or importance, but rather the terms first, second, etc. are used to distinguish one element from another. Furthermore, the use of the terms a, an, etc. do not denote a limitation of quantity, but rather denote the presence of at least one of the referenced item.
Claims
1. A method of relocating a portable articulated arm coordinate measuring machine (AACMM) from a first location to a second location, wherein the AACMM has, at the first location, a first origin point and a first frame of reference and, at the second location, a second origin point and a second frame of reference, the method comprising the steps of:
- measuring, with the portable AACMM in the first location, an amount of tilt of the portable AACMM along a first set of two perpendicular directions, each direction approximately perpendicular to a gravity vector;
- measuring, with the portable AACMM in the second location, an amount of tilt of the portable AACMM along a second set of two perpendicular directions, each direction approximately perpendicular to the gravity vector;
- measuring a first target and a second target with the portable AACMM in the first location to obtain, in the first frame of reference, a first set of x, y, and z coordinates and a second set of x, y, and z coordinates;
- measuring the first target and the second target with the portable AACMM in the second location to obtain, in the second frame of reference, a third set of x, y, and z coordinates and a fourth set of x, y, and z coordinates; and
- finding x, y and z coordinates of the second origin point with respect to the first frame of reference, wherein the x, y, and z coordinates of the second origin point are found using the first, second, third, and fourth sets of x, y, and z coordinates but without using additional x, y, and z coordinates of a third target measured with the AACMM at the first location and at the second location.
2. The method of claim 1, further comprising the step of:
- identifying a first gravity frame of reference of the AACMM in the first location as that frame of reference resulting from application of the measured amount of tilt along the first set of two perpendicular directions to rotate x, y, and z axes of the first frame of reference into transformed x, y, and z axes of the first gravity frame of reference in such a way that the transformed z axis of the first gravity frame of reference is aligned with the gravity vector.
3. The method of claim 2, further comprising the step of:
- identifying a second gravity frame of reference of the AACMM in the second location as that frame of reference resulting from application of the measured amount of tilt along the second set of two perpendicular directions to rotate x, y, and z axes of the second frame of reference into transformed x, y, and z axes of the second gravity frame of reference in such a way that the transformed z axis of the second gravity frame of reference is aligned with the gravity vector.
4. The method of claim 3, further comprising the step of:
- determining a yaw angle of the portable AACMM in the second location, wherein the determined yaw angle comprises an amount of rotation about the transformed z axis of the second gravity frame of reference to make the transformed x and y axes of the second gravity frame of reference parallel to the transformed x and y axes of the first gravity frame of reference.
5. The method of claim 3, further comprising the steps of:
- converting the first set of x, y, and z coordinates into a first set of transformed x, y, and z coordinates in the first gravity frame of reference;
- converting the second set of x, y, and z coordinates into a second set of transformed x, y, and z coordinates in the first gravity frame of reference;
- converting the third set of x, y, and z coordinates into a third set of transformed x, y, and z coordinates in the second gravity frame of reference; and
- converting the fourth set of x, y, and z coordinates into a fourth set of transformed x, y, and z coordinates in the second gravity frame of reference.
6. The method of claim 5, further comprising the step of:
- calculating the z coordinate of the second origin point in the first frame of reference using the transformed z coordinates from the first set of transformed x, y, and z coordinates and the third set of transformed x, y, and z coordinates.
7. The method of claim 6, further comprising the step of:
- calculating the z coordinate of the second origin point in the first frame of reference using the transformed z coordinates from the second set of transformed x, y, and z coordinates and the fourth set of transformed x, y, and z coordinates.
8. The method of claim 7, further comprising the step of:
- calculating the z coordinate of the second origin point in the first frame of reference by taking an average of the z coordinate calculated in claim 6 and the z coordinate calculated in claim 7.
9. The method of claim 5, further comprising the step of:
- finding the x and y coordinates of the second origin point in the first frame of reference by solving two equations simultaneously, wherein the first equation includes transformed x and y coordinates from the first and third sets of transformed x, y, and z coordinates and the second equation includes transformed x and y coordinates from the second and fourth sets of transformed x, y, and z coordinates.
10. The method of claim 4, further comprising the step of:
- transforming coordinate data collected by the AACMM in the first location and the second location into a common global frame of reference.
11. A computer program product comprising a storage medium having computer-readable program code embodied thereon, which when executed by a computer causes the computer to implement a method of relocating a portable articulated arm coordinate measuring machine (AACMM) from a first location to a second location, wherein the AACMM has, at the first location, a first origin point and a first frame of reference and, at the second location, a second origin point and a second frame of reference, the method including the steps of:
- measuring, with the portable AACMM in the first location, an amount of tilt of the portable AACMM along a first set of two perpendicular directions, each direction approximately perpendicular to a gravity vector;
- measuring, with the portable AACMM in the second location, an amount of tilt of the portable AACMM along a second set of two perpendicular directions, each direction approximately perpendicular to the gravity vector;
- identifying a first gravity frame of reference of the AACMM in the first location as that frame of reference resulting from application of the measured amount of tilt along the first set of two perpendicular directions to rotate x, y, and z axes of the first frame of reference into transformed x, y, and z axes of the first gravity frame of reference in such a way that the transformed z axis of the first gravity frame of reference is aligned with the gravity vector;
- identifying a second gravity frame of reference of the AACMM in the second location as that frame of reference resulting from application of the measured amount of tilt along the second set of two perpendicular directions to rotate x, y, and z axes of the second frame of reference into transformed x, y, and z axes of the second gravity frame of reference in such a way that the transformed z axis of the second gravity frame of reference is aligned with the gravity vector;
- measuring a first target and a second target with the portable AACMM in the first location to obtain, in the first frame of reference, a first set of x, y, and z coordinates and a second set of x, y, and z coordinates;
- measuring the first target and the second target with the portable AACMM in the second location to obtain, in the second frame of reference, a third set of x, y, and z coordinates and a fourth set of x, y, and z coordinates;
- finding x, y and z coordinates of the second origin point with respect to the first frame of reference, wherein the x, y, and z coordinates of the second origin point are found using the first, second, third, and fourth sets of x, y, and z coordinates but without using additional x, y, and z coordinates of a third target measured with the AACMM at the first location and at the second location; and
- determining a yaw angle of the portable AACMM in the second location, wherein the determined yaw angle comprises an amount of rotation about the transformed z axis of the second gravity frame of reference to make the transformed x and y axes of the second gravity frame of reference parallel to the transformed x and y axes of the first gravity frame of reference.
12. The computer program product of claim 11, in which the method further comprises the step of:
- calculating the z coordinate of the second origin point in the first frame of reference using the transformed z coordinates from the first set of transformed x, y, and z coordinates and the third set of transformed x, y, and z coordinates.
13. The computer program product of claim 12, in which the method further comprises the step of:
- calculating the z coordinate of the second origin point in the first frame of reference using the transformed z coordinates from the second set of transformed x, y, and z coordinates and the fourth set of transformed x, y, and z coordinates.
14. The computer program product of claim 13, in which the method further comprises the step of:
- calculating the z coordinate of the second origin point in the first frame of reference by taking an average of the z coordinate calculated in claim 12 and the z coordinate calculated in claim 13.
15. The computer program product of claim 11, in which the method further comprises the step of:
- finding the x and y coordinates of the second origin point in the first frame of reference by solving two equations simultaneously, wherein the first equation includes transformed x and y coordinates from the first and third sets of transformed x, y, and z coordinates and the second equation includes transformed x and y coordinates from the second and fourth sets of transformed x, y, and z coordinates.
16. The computer program product of claim 11, in which the method further comprises the step of:
- transforming coordinate data collected by the AACMM in the first location and the second location into a common global frame of reference.
Type: Application
Filed: Jan 14, 2011
Publication Date: Jul 21, 2011
Applicant: FARO TECHNOLOGIES, INC. (Lake Mary, FL)
Inventors: Robert E. Bridges (Kennett Square, PA), David H. Parker (Earlysville, VA)
Application Number: 13/006,458
International Classification: G01B 5/008 (20060101); G06F 15/00 (20060101);