US9390202B2 - Coordinate measuring system data reduction - Google Patents

Coordinate measuring system data reduction Download PDF

Info

Publication number
US9390202B2
US9390202B2 US13/560,724 US201213560724A US9390202B2 US 9390202 B2 US9390202 B2 US 9390202B2 US 201213560724 A US201213560724 A US 201213560724A US 9390202 B2 US9390202 B2 US 9390202B2
Authority
US
United States
Prior art keywords
data
geometric
coordinate measurement
geometric feature
computer
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active, expires
Application number
US13/560,724
Other versions
US20130030773A1 (en
Inventor
Jonathan J. O'Hare
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Hexagon Manufacturing Intelligence Inc
Original Assignee
Hexagon Metrology Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Hexagon Metrology Inc filed Critical Hexagon Metrology Inc
Priority to US13/560,724 priority Critical patent/US9390202B2/en
Assigned to HEXAGON METROLOGY, INC. reassignment HEXAGON METROLOGY, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: O'HARE, JONATHAN J.
Publication of US20130030773A1 publication Critical patent/US20130030773A1/en
Application granted granted Critical
Publication of US9390202B2 publication Critical patent/US9390202B2/en
Assigned to HEXAGON METROLOGY, INC. reassignment HEXAGON METROLOGY, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: O'HARE, Jonathan
Assigned to HEXAGON METROLOGY, INC. reassignment HEXAGON METROLOGY, INC. CORRECTIVE ASSIGNMENT TO CORRECT THE THE INVENTORS NAME PREVIOUSLY RECORDED AT REEL: 058117 FRAME: 832. ASSIGNOR(S) HEREBY CONFIRMS THE ASSIGNMENT. Assignors: O'HARE, JONATHAN J.
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • G06F17/50
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01BMEASURING LENGTH, THICKNESS OR SIMILAR LINEAR DIMENSIONS; MEASURING ANGLES; MEASURING AREAS; MEASURING IRREGULARITIES OF SURFACES OR CONTOURS
    • G01B21/00Measuring arrangements or details thereof, where the measuring technique is not covered by the other groups of this subclass, unspecified or not relevant
    • G01B21/02Measuring arrangements or details thereof, where the measuring technique is not covered by the other groups of this subclass, unspecified or not relevant for measuring length, width, or thickness
    • G01B21/04Measuring arrangements or details thereof, where the measuring technique is not covered by the other groups of this subclass, unspecified or not relevant for measuring length, width, or thickness by measuring coordinates of points
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T17/00Three dimensional [3D] modelling, e.g. data description of 3D objects
    • G06T7/0032
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T7/00Image analysis
    • G06T7/30Determination of transform parameters for the alignment of images, i.e. image registration
    • G06T7/33Determination of transform parameters for the alignment of images, i.e. image registration using feature-based methods
    • G06T7/344Determination of transform parameters for the alignment of images, i.e. image registration using feature-based methods involving models
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2207/00Indexing scheme for image analysis or image enhancement
    • G06T2207/10Image acquisition modality
    • G06T2207/10028Range image; Depth image; 3D point clouds
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2210/00Indexing scheme for image generation or computer graphics
    • G06T2210/56Particle system, point based geometry or rendering

Definitions

  • This invention relates generally to coordinate measuring systems, and more specifically to apparatuses and methods for systematically reducing data collected by coordinate measuring machines, including non-tactile coordinate measuring machines.
  • Coordinate measuring machines are in common use for dimensional inspection of workpieces.
  • a workpiece is secured to a table, and a probe, such as one using a touch sensor, is moved in three dimensions on an arm of the CMM within a measurement volume to contact the workpiece at various points.
  • measuring scales in the x, y and z directions are read to obtain the position coordinates of the contacted point on the workpiece.
  • measurements of workpiece features can be obtained.
  • Non-tactile measuring systems such as scanning CMMs, vision systems, and micro-CT radiate light or other types of radiation toward a workpiece and sense the reflected or transmitted radiation as part of determining the surface structure of the workpieces.
  • scanning CMMs a laser line scanner emits light toward a workpiece surface and returns a stream of measured surface points along its path of motion. This process may be repeated in multiple paths/passes across a workpiece collecting thousands or millions of scan points across the workpiece surface.
  • a large amount of point data is generated for a scanned workpiece, and this set of data is often referred to as a point cloud.
  • a computer-implemented method includes receiving coordinate measurement data associated with a measurement of a physical object, and operating a computer-implemented system to segment the coordinate measurement data into two or more data sets based on distinct geometric features of the object, the geometric features having been identified using nominal geometric information from an electronic file containing nominal geometric information for an object that corresponds to the physical object.
  • the method further includes operating a computer-implemented system to reduce the coordinate measurement data in a first data set of the two or more data sets to a first reduced data set in a first manner, and operating a computer-implemented system to reduce the coordinate measurement data in a second data set of the two or more data sets to a second reduced data set in a second manner, different from the first manner.
  • a computer-implemented method includes using a computer-implemented system to receive geometric feature data originating from an electronic file containing nominal geometrical information for an object, the geometric feature data including a tolerance for one or more geometric features. Also included is an act of using a computer-implemented system to define a data segmentation volume associated with a first geometric feature of the object by establishing boundaries of the data segmentation volume, including establishing a first boundary of the data segmentation volume based at least in part on the received tolerance for the first geometric feature.
  • a computer-implemented method includes using a computer-implemented system to receive geometric feature information originating from an electronic file containing nominal geometric information for an object, and using a computer-implemented system to define a first data segmentation volume associated with a first geometric feature of the object and a second data segmentation volume associated with a second geometric feature of the object.
  • the method also includes transforming coordinate measurement data of a physical object to a coordinate system of the electronic file, the coordinate measurement data comprising a plurality of data points. Further includes in the method are acts of designating data points which are located within the defined first data segmentation volume as being associated with the first geometric feature, and designating data points which are located within the defined second data segmentation volume as being associated with the second geometric feature.
  • a computer-implemented method includes receiving an identification of a type of geometric characteristic to be inspected on a geometric feature, the identification of the type of geometric characteristic having originated from a computer model which includes the geometric feature.
  • a further act includes receiving coordinate measurement data associated with a measurement of a physical geometric feature that corresponds to the geometric feature of the computer model.
  • a computer-implemented system is used to determine an algorithm for reducing the coordinate measurement data, wherein the determination of the algorithm is based at least in part on the identified type of the geometric characteristic to be inspected.
  • a computer-implemented method includes receiving tolerance information for a geometric characteristic to be inspected on a geometric feature, and receiving coordinate measurement data associated with a measurement of the physical feature. The method also includes using a computer-implemented system to determine an algorithm for reducing the coordinate measurement data, wherein the determination of the algorithm is based at least in part on the tolerance information for the geometric characteristic.
  • At least one computer-readable medium storage device has computer-readable instructions for performing steps of a method of segmenting and reducing coordinate measurement data, the method including receiving coordinate measurement data associated with a measurement of a physical object, and operating a computer-implemented system to segment the coordinate measurement data into two or more data sets based on distinct geometric features of the object, the geometric features having been identified using data from an electronic file containing nominal geometric data for an object which corresponds to the physical object.
  • the method also includes operating a computer-implemented system to reduce the coordinate measurement data in a first data set of the two or more data sets to a first reduced data set in a first manner.
  • the method further includes operating a computer-implemented system to reduce the coordinate measurement data in a second data set of the two or more data sets to a second reduced data set in a second manner, different from the first manner.
  • FIG. 1 is a flow chart representative of a method for managing coordinate measurement data, according to one embodiment
  • FIG. 2 is an isometric view of a CAD model of an object
  • FIG. 3 is a schematic drawing showing one example of geometric dimensioning and tolerance information contained within the CAD model of FIG. 2 ;
  • FIG. 4 a is an isometric view of coordinate measurement data superimposed on the CAD model of FIG. 2 , and a data segmentation volume;
  • FIG. 4 b is a front plan view of the CAD model, the superimposed coordinate measurement data and the data segmentation volume of FIG. 4 b;
  • FIG. 5 is a flow chart representative of a method for segmenting coordinate measurement data, according to one embodiment
  • FIG. 6 is a flow chart representative of a method for reducing coordinate measurement data, according to one embodiment.
  • FIG. 7 is a data flow chart representative of a method for reducing coordinate measurement data.
  • This disclosure recognizes the importance of applying data reduction techniques to point cloud data in an automated, systematic manner using existing nominal geometric data as a guide, such as data from a Computer-Aided Design (CAD) model or a standard CMM inspection plan.
  • CAD Computer-Aided Design
  • the ability to reduce point cloud data can be particularly beneficial when scanning objects with a non-tactile measuring instrument.
  • to reduce point cloud data generated by a scanner data reduction is performed on a feature-by-feature basis through reference to a computer model of a nominal object.
  • user input is permitted to adjust, select, refine, and/or set parameter values for an automated reduction algorithm.
  • Non-tactile measuring instruments typically are able to produce coordinate measurement data more quickly than traditional contact CMMs because fewer moving parts are used.
  • large quantities of data often can be generated by a non-tactile measuring instrument in a short amount of time.
  • the large amount of data often referred to as a point cloud, can aid in producing accurate and precise data definitions of inspected objects, but the sheer quantity of data can also be problematic.
  • storing, communicating and processing the point cloud data can be time consuming or impractical, thereby resulting in overall process inefficiencies.
  • memory and communication speed requirements to handle the data may necessitate costly implementations or upgrades of hardware and/or software components.
  • Point cloud data reduction can help reduce the data burden associated with scanning technologies.
  • Various data reduction techniques exist, such as filtering, smoothing, and decimation, among others.
  • these techniques are applied to an entire dataset to reduce the overall amount of data. Applying such techniques to an entire data set of a scanned object may excessively reduce data for some portions of the data set, thereby unacceptably eroding the accuracy or precision of the resulting data. Or, in some cases, the maximum permitted data reduction in consideration of accuracy or precision requirements may not sufficiently pare the data for practical data management or processing.
  • point cloud data is reduced in a strategic and systematic manner by segmenting the data set based on an object's geometric features and/or tolerances.
  • a software application is used to identify various geometric features of a CAD model of an object, and then create a data segmentation volume for each geometric feature.
  • the various data segmentation volumes may be assigned different data extraction requirements based on one or more parameters, such as: the type of feature, the identified geometric characteristic to be inspected, the tolerance set forth in the CAD model, and/or other suitable parameters.
  • the resulting point cloud data may be aligned with the nominal CAD model, and the data points which reside within a data segmentation volume are assigned to that data segmentation volume.
  • the data in each data segmentation volume then may be reduced in a manner which meets the assigned data requirements.
  • the particular manner of data reduction may be determined by one or more parameters, and the data reduction algorithms may differ among data segmentation volumes associated with the same object.
  • point cloud data may be reduced or strategically specified on a feature-by-feature basis to meet the data requirements for each specific feature. In some embodiments, this feature-by-feature reduction may be performed in an automated or a semi-automated fashion.
  • a software application may analyze a CAD model of an object and categorize two identified features into two feature types, namely a plane feature type and a cylinder feature type.
  • two feature types namely a plane feature type and a cylinder feature type.
  • portions of the resulting point cloud data can be segmented into two data sets based on this feature categorization.
  • data segmentation volumes are established through use of a programmed algorithm which uses information from the CAD model.
  • Each of the two data sets then may be reduced in a different manner.
  • the subset of the point cloud data in the area of the plane feature is reduced based on its categorization as a plane and optionally on one or more other parameters such as GD&T callout type and tolerance.
  • the data may be reduced in a manner different from the data reduction manner used for the plane feature.
  • the plane feature data quantity may be uniformly reduced over its whole area by 75% and/or involve the use of a certain type of data filtering, while the cylinder feature data quantity may be reduced by 50% and/or involve the use of a certain type of data filtering.
  • the reduction percentage is not the only aspect that may vary between the resulting reduced data sets of two or more features.
  • the reduced data set associated with the plane feature may include a substantially evenly geometrically distributed set of data points, while the cylinder feature data may be reduced such that data points are densely populated along cross-sectional profiles at strategically specified distances along the length of the cylinder.
  • point cloud data can be reduced in a targeted fashion so that sufficient data remains for each area or feature of a scanned object without undue amounts of superfluous coordinate measurement data being maintained for some or all of the object's areas or features. Efficient reduction of the point cloud data can be particularly important when CMMs are used to inspect manufactured workpieces. Timely results can aid in confirming part compliance or discovering manufacturing errors for use as feedback to the manufacturing process.
  • data reduction For purposes herein, the terms “data reduction”, “reducing data”, “point cloud reduction”, and other associated terms are intended to encompass acts, methods and systems in which a subset of data is extracted from a larger data set. For example, if 10% of the data points from a point cloud are selected and used for analysis, storage, display and/or other purposes, such an act would be considered data reduction, even if the remaining 90% of data points are not expressly deleted.
  • a method 100 of managing coordinate measurement data includes segmenting and/or reducing data based on features determined using a CAD model.
  • Three dimensional measurement data may be contained in a voxel grid 102 , from which a point cloud of surface data points may be later extracted.
  • a voxel grid 102 from which a point cloud of surface data points may be later extracted.
  • Other suitable formats for storing and/or displaying coordinate measurement data may be used with embodiments disclosed herein.
  • the data in the voxel grid may be measured as part of method 100 , may be retrieved from a computer storage device, and/or may be received from a third party.
  • receiving as it relates to data and information is meant to include receipt from a third party, receipt from an external computer system, receipt by one portion of a computer system from another portion of the same computer system, and generation of the data or information within the computer system which receives the data.
  • receiving data or information includes any suitable provision of the data or information to the entity(ies) performing the acts of a method.
  • each voxel will contain a point location ⁇ x, y, z ⁇ and an intensity value ⁇ I ⁇ , though other arrangements are possible.
  • a data representation of a complete surface 106 is created using the voxel grid.
  • the surface data may be represented by point locations with normal vectors, i.e., ⁇ x, y, z, i, j, k ⁇ .
  • a data representation of an approximate surface 110 may be created in an act 108 by reducing the data in the complete surface data representation. For example, decimation techniques may be used to reduce the entire data set of the complete surface to create an approximate surface that is sufficient for an initial best-fit operation to align the measured surface data to the CAD model 112 .
  • a best-fit operation (act 114 ) then may be performed to arrive at a transformation matrix 116 which aligns the surface data to the CAD model 112 by transforming the coordinate system of the surface data to the coordinate system of the CAD model.
  • a least-squares method may be used as part of the best-fit operation, though other suitable methods may be used.
  • the transformation matrix 116 then may be used to align the data representation of the complete surface to the CAD model 112 (act 118 ).
  • the intervening acts associated with creating a data representation of an approximate surface are not performed. That is, a best-fit operation may be performed directly on the complete surface data representation without first determining a transformation matrix based on an approximate surface.
  • transforming a coordinate system of coordinate measurement data to the coordinate system of a CAD model is intended to include a transformation of a coordinate system of a CAD model to a coordinate system of coordinate measurement data.
  • Such a transformation is intended to include any operation which results in at least an approximate alignment of the coordinate measurement data to the CAD model (or other electronic model or file containing geometric information).
  • transformation of a coordinate measurement system is intended to include a translation and/or rotation of a coordinate measurement system, as well as a transformation from one type of coordinate measurement system to another (e.g., from spherical coordinates to Cartesian coordinates).
  • the data representation of the complete surface 106 is segmented into data sets based on features identified through use the CAD model. For example, a CAD model of a physical object may be analyzed and a number of distinct geometric features may be identified.
  • the surface data derived from the coordinate measurement data is divided into data sets with each data set corresponding to one of the identified geometric features. Subsets of the data sets may grouped together within a category of geometric features. For example, two or more of the identified geometric features may be identified as planes, and the two associated data sets may be grouped together in a plane category. Any suitable number of categories may be established or defined.
  • the identification of the geometric features in the CAD model may be performed prior to initiation of method 100 , or may be performed at any suitable time during act 100 .
  • the analysis of the CAD model (or other electronic model) may be performed by a pre-defined algorithm that searches for shapes, areas, edges, and/or other attributes of the CAD model to identify types of geometric features.
  • a user may be prompted to enter values to set parameters, and/or a user may be prompted to select from a list of identification algorithms. In such embodiments, the segmentation is still considered to be the use of a pre-defined algorithm.
  • dialog boxes may be presented to the user.
  • drop down menus, readable files, or selectable tables may be used, and in still further embodiments, users may be permitted to directly enter values.
  • a data segmentation volume may be created for each identified geometric feature to define which data points of the coordinate measurement data to associate with the identified geometric feature.
  • the data points contained within each data segmentation volume then may be reduced.
  • the boundaries of each data segmentation volume may be set using at least in part geometric dimensioning and tolerance (GD&T) information contained with the CAD model in some embodiments.
  • GD&T geometric dimensioning and tolerance
  • data points associated with the coordinate measurement of a plane will not be exactly co-planar with one another, that is, some points will lie in front of the nominal plane and some points will lie behind the nominal plane.
  • geometric tolerance and dimension information from the CAD model may be used. Further detail regarding examples of establishing data segmentation volumes are discussed further below with reference to FIGS. 4 a and 4 b.
  • Each of the data sets may be reduced in a manner specific to the feature corresponding to the data set (act 122 ). For example, a first data set corresponding to a first feature may be reduced using triangular decimation at a specified percentage rate or specific number of vertices, while a second data set corresponding to a second feature may be reduced using the same triangular decimation algorithm but specify a maximum deviation or minimum angle between neighboring facets.
  • a third data set corresponding to a third feature may be reduced using a Gaussian filter to remove outliers outside some N number of standard deviations.
  • a fourth data set may be reduced by uniform interpolation over its surface by specifying the spacing between points, or points per unit area.
  • a fifth data set may be reduced by strategically extracting uniformly spaced points along specified cross-sectional profiles at different locations or angular positions along a feature.
  • a sixth data set may be reduced by strategically extracting specific surface point locations from user-defined nominal points and vectors intersecting the actual surface.
  • a seventh data set may not be reduced at all.
  • the above example is not intended to be limiting as other types of data reduction may be used for various features.
  • FIG. 2 shows an isometric view of a CAD model of an object 200 composed of a rectangular prism 202 with a cylindrical bore 204 .
  • Rectangular prism 202 includes a top planar surface 206 , a bottom planar surface 208 , a front planar surface 210 , a rear planar surface 212 and two side planar surfaces 214 , 216 .
  • a two-dimensional layout of the object is shown in FIG. 3 along with GD&T information.
  • the GD&T information of this CAD model includes various callouts for features of interest, including basic dimensions and control frames.
  • the CAD model also includes datum features. As discussed further below with reference to FIGS.
  • this GD&T information in some cases in conjunction with user inputs, is used to define sectioning boundaries which enclose a subset of data points from a coordinate measurement data point cloud.
  • the point cloud (or other suitable set of data points) is generated through coordinate measurement of a corresponding physical object.
  • FIG. 3 includes three callouts, namely a size dimension 302 defining the diameter of a cylindrical bore, and two feature control frames 304 , 306 .
  • Feature control frame 304 provides information regarding the position of the cylindrical bore relative to the datum features labeled “-A-”, “-B-” and “-C-”. The “M” after the “0.1” position tolerance indicates that there is extra allowance for error as the bore's size increases, therefore more data on the cylinder surface about its diameter may be beneficial in determining extra allowance in the tolerance evaluation.
  • Feature control frame 306 provides information regarding a desired flatness of top planar surface 206 .
  • Basic dimensions 308 and 310 provide the location of the center of cylindrical bore 204 relative to a front edge of prism 200 .
  • Datum features which in this example include datum planes 312 , 314 and 316 , are also provided within the CAD model.
  • boundaries may be constructed to define a data segmentation volume for each of various features of the object.
  • the data contained within these data segments then can be reduced based on the type of feature and/or other parameters. For example, as shown in FIGS. 4 a and 4 b , a segmentation volume 400 is shown enclosing coordinate measurement data points 402 associated with front planar surface 210 .
  • a method 500 may be used to create one or more data segmentation volumes through use of the CAD model.
  • method 500 may be a computer-implemented method, and may or may not include prompts for user input.
  • Method 500 described herein is one example of a method of performing act 120 of method 100 described above with reference to FIG. 1 .
  • other suitable methods for performing act 120 may be used, and method 500 may be used in methods other than method 100 .
  • one or more geometric feature types are identified from the CAD model. This identification may be performed by a software application programmed to process CAD model data and locate geometric features. In some embodiments, a data segmentation volume may not be established for all identified features.
  • the software program may include instructions to not establish data segmentation volumes for certain geometric feature types. Examples of geometric feature types include: planes, cylinders, cones, spheres, ellipses, etc., as well as other, complex free-formed surfaces composed of higher order equations between surface points.
  • boundaries may be set along the datum surface by defining boundaries inwardly of the nominal surface edges by a clearance distance (act 504 ) to avoid inclusion of data points that are over the edges.
  • segmentation volume 400 is spaced inwardly from the edges of front planar surface 210 by a clearance distance D b .
  • the upper and lower boundary surfaces are set at clearance distance D b from top planar surface 206 and bottom planar surface 208 .
  • the side boundary surfaces are set at clearance distance D b from side planar surfaces 214 , 216 .
  • D b may be set at a default value for distance from edges defined in the CAD model.
  • clearance distance D b may be calculated based on various values contained within the model, such as tolerances set forth in the CAD model, and/or the dimensions of the planar surface. Segmentation volumes may have different clearance distances along different edges, and of course segmentation volumes may have clearance distances which differ from other segmentation volumes within the same CAD model. In some embodiments, one or more clearance distances may be based at least in part on the precision and/or point density of the coordinate measurement data. As will be apparent to one of skill in the art, data segmentation volumes are not necessarily displayed or explicitly defined as a volume. For example, each of the boundaries of a data segmentation volume may be defined mathematically or defined by a series of points which establish a line, plane, or other surface. In some embodiments, a data segmentation volume may not include boundaries which form a closed volume in the sense that in some areas or directions, any measured data points would be included in the data segmentation volume.
  • a tolerance band t also may be established to define boundaries for encompassing coordinate measurement data points that are in front of or behind the nominal datum surface defined in the CAD model (act 506 ).
  • a value for the tolerance band may be set by using a multiple of the feature tolerance set forth in the CAD model, or by using a default tolerance band value, or by using a specific tolerance band value input by a user. Different default tolerance band values may correspond to different feature types in some embodiments.
  • the depth of data segmentation volume 400 may be set as a tolerance band based on a multiplier of two of the tolerance defined in the CAD model for datum plane C 316 (0.01 mm), resulting in a tolerance band t having a depth of 0.02 mm.
  • tolerance band default value may be used.
  • Tolerance values may be provided by computer models or other electronic files other than CAD models.
  • tolerance information may be contained in or input to a computer file, and the tolerance information may be assigned to various geometric features. Clearance distances from surface edges may be preset at a specified distance, and the particular values may vary based on the feature type.
  • the clearance distances may be set based on values such as the size of the feature or certain tolerance information provided in the CAD model.
  • each segmentation volume may be reduced in a manner specific to the feature type, and/or specific to one or more other parameters such as a tolerance set forth in the CAD model.
  • the corresponding target point density may be input to a known data reduction program which then reduces the data to the target point density.
  • coordinate measurement data may be reduced in a manner targeted to the data needs for each type of feature.
  • the segmentation and/or reduction may be performed in an automated fashion.
  • 3D Reshaper available from Technodigit
  • PC-DMIS® available from Wilcox Associates, Inc.
  • QUINDOS® available from Hexagon Metrology GMBH, though any suitable data reduction program may be used.
  • Technodigit's 3D Reshaper software can uniformly reduce data through triangular decimation and Gaussian filter algorithms.
  • 3D Reshaper can also strategically extract points along profiles at sectioned locations in a geometric feature.
  • PC-DMIS® and QUINDOS® software both have a wide range of filtering options as well as the ability to strategically extract points at nominal locations, as do many other CMM inspection software packages in the industry.
  • a target point density of nine points per square millimeter may be defined if the tolerance is less than or equal to 0.005 mm. If the tolerance is greater than 0.005 mm and less than or equal to 0.050 mm, the target point density may be set to 4 points per square millimeter. In cases where the tolerance is greater than 0.050 mm, the target point density may be set to 1 point per square millimeter. Table 2 shows one example of a chart of point density and/or point arrangement based on the type of measurement, the type of callout, and the tolerance range into which the associated tolerance falls.
  • the above embodiment includes the use of a CAD model for access to nominal geometric data, however other types of electronic files which contain nominal geometric information may be used with embodiments disclosed herein, either independent of, or supplemental to, information provided by a CAD model.
  • FIG. 6 One example of a method 600 of reducing and analyzing data contained within a data segmentation volume is shown in FIG. 6 . Not all of the acts shown in FIG. 6 necessarily need to be performed to reduce and/or analyze coordinate measurement data.
  • a target data point density and/or data point arrangement is determined. The determination may be based on the type of feature being analyzed, the type of callout specified, and/or a tolerance or other piece of GD&T information. This determination may be implemented through use of a lookup table, such as the example shown in Table 2.
  • Act 604 may include an analysis of the target point density and/or arrangement which was determined in act 602 .
  • the existing data point density from a point cloud may be compared to the target point density determined in act 602 , and a particular data reduction scheme (decimation, smoothing, etc.) may be selected based on this comparison.
  • the same type of data reduction algorithm may be used for each data segmentation volume, but particular parameters within the data reduction algorithm may be determined based on the target point density and/or GD&T information.
  • the coordinate measurement data is reduced in an act 606 .
  • the reduced data which may be more amendable to analysis due to the lessened data handling requirements, may be analyzed in any suitable manner in an act 608 .
  • the flatness of a plane, or the length of a geometric feature may be calculated and compared to the CAD model or other standard.
  • Such analyses may be implemented as part of a quality analysis/quality control program or as part of any other process involving the measurement and analysis of objects.
  • FIG. 7 shows a data flow chart representative of various embodiments described herein.
  • a pre-defined reduction algorithm 702 receives an electronic file, or data therefrom, such as a nominal CAD geometry and tolerance data 704 .
  • Algorithm 702 also receives acquired point cloud data 706 .
  • Point cloud data 706 may be data from a non-contact CMM, a contact CMM, or other measurement device.
  • the point cloud data may be received directly from a CMM, or may be received from a data file, or any other suitable source.
  • User input also may be received by reduction algorithm 702 , such as user input for a point sampling strategy 708 .
  • an algorithm is considered to be pre-defined even if the algorithm is selected from a set of possible algorithms. Further, user inputs to the pre-defined algorithm do not necessarily render the algorithm no longer pre-defined.
  • reduction algorithm 702 reduces the point cloud data to a reduced data set 710 that is more easily managed and analyzed.
  • the above-described embodiments can be implemented in any of numerous ways.
  • the embodiments may be implemented using hardware, software or a combination thereof.
  • the software code can be executed on any suitable processor or collection of processors, whether provided in a single computer or distributed among multiple computers.
  • a computer may be embodied in any of a number of forms, such as a rack-mounted computer, a desktop computer, a laptop computer, or a tablet computer. Additionally, a computer may be embedded in a device with suitable processing capabilities, including a Personal Digital Assistant (PDA), a smart phone or any other suitable portable or fixed electronic device.
  • PDA Personal Digital Assistant
  • a computer may have one or more input and output devices. These devices can be used, among other things, to present a user interface. Examples of output devices that can be used to provide a user interface include printers or display screens for visual presentation of output and speakers or other sound generating devices for audible presentation of output. Examples of input devices that can be used for a user interface include keyboards, and pointing devices, such as mice, touch pads, and digitizing tablets. As another example, a computer may receive input information through speech recognition or in other audible format.
  • Such computers may be interconnected by one or more networks in any suitable form, including as a local area network or a wide area network, such as an enterprise network or the Internet.
  • networks may be based on any suitable technology and may operate according to any suitable protocol and may include wireless networks, wired networks or fiber optic networks.
  • the various methods or processes outlined herein may be coded as software that is executable on one or more processors that employ any one or more of a variety of operating systems or platforms. Additionally, such software may be written using any of a number of suitable programming languages and/or programming or scripting tools, and also may be compiled as executable machine language code or intermediate code that is executed on a framework or virtual machine.
  • embodiments of the invention may be embodied as a computer-readable storage medium or multiple computer-readable media encoded with one or more programs that, when executed on one or more computers or other processors, perform methods that implement the various embodiments of the invention discussed above.
  • Computer readable media may include, for example, a computer memory, one or more floppy discs, compact discs (CD), optical discs, digital video disks (DVD), magnetic tapes, flash memories, circuit configurations in Field Programmable Gate Arrays or other semiconductor devices, or other tangible computer storage medium.
  • a computer readable storage medium may retain information for a sufficient time to provide computer-executable instructions in a non-transitory form.
  • Such a computer readable storage medium or media can be transportable, such that the program or programs stored thereon can be loaded onto one or more different computers or other processors to implement various aspects of the present invention as discussed above.
  • the term “computer-readable storage medium” encompasses only a computer-readable medium that can be considered to be a manufacture (i.e., article of manufacture) or a machine.
  • the embodiments of the invention may be embodied as a computer-readable medium other than a computer-readable storage medium, such as a propagating signal.
  • program or “software” are used herein in a generic sense to refer to any type of computer code or set of computer-executable instructions that can be employed to program a computer or other processor to implement various aspects of the present invention as discussed above. Additionally, it should be appreciated that according to one aspect of this embodiment, one or more computer programs that when executed perform methods of embodiments of the present invention need not reside on a single computer or processor, but may be distributed in a modular fashion amongst a number of different computers or processors to implement various aspects of embodiments of the present invention.
  • Computer-executable instructions may be in many forms, such as program modules, executed by one or more computers or other devices.
  • program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types.
  • functionality of the program modules may be combined or distributed as desired in various embodiments.
  • a reference to “A and/or B”, when used in conjunction with open-ended language such as “comprising” can refer, in one embodiment, to A only (optionally including elements other than B); in another embodiment, to B only (optionally including elements other than A); in yet another embodiment, to both A and B (optionally including other elements); etc.

Abstract

Coordinate measurement data such as point cloud data associated with coordinate measurement machine data is reduced in a strategic and systematic manner by segmenting and/or reducing data based on nominal geometric information contained in an electronic file such as a CAD model or a coordinate measurement machine inspection plan. For example, in one embodiment, a software application is used to identify geometric features and tolerances within a CAD model of an object, and to segment coordinate measurement data of a physical object based on the identified geometric features and tolerances from the CAD model. The various segments of coordinate measurement data may be assigned different data requirements, and the data may be reduced in different manners on a feature-by-feature basis.

Description

RELATED APPLICATION
This application claims the benefit under 35 U.S.C. §119 of U.S. Provisional Application Ser. No. 61/513,451, filed Jul. 29, 2011, entitled “Coordinate Measuring System Data Reduction”, which is hereby incorporated by reference in its entirety.
FIELD OF INVENTION
This invention relates generally to coordinate measuring systems, and more specifically to apparatuses and methods for systematically reducing data collected by coordinate measuring machines, including non-tactile coordinate measuring machines.
DESCRIPTION OF THE RELATED ART
Coordinate measuring machines (CMMs) are in common use for dimensional inspection of workpieces. Typically, a workpiece is secured to a table, and a probe, such as one using a touch sensor, is moved in three dimensions on an arm of the CMM within a measurement volume to contact the workpiece at various points. When the probe contacts the workpiece, measuring scales in the x, y and z directions are read to obtain the position coordinates of the contacted point on the workpiece. By contacting various points on the workpiece, measurements of workpiece features can be obtained.
Non-tactile measuring systems, such as scanning CMMs, vision systems, and micro-CT radiate light or other types of radiation toward a workpiece and sense the reflected or transmitted radiation as part of determining the surface structure of the workpieces. For example, in some scanning CMMs, a laser line scanner emits light toward a workpiece surface and returns a stream of measured surface points along its path of motion. This process may be repeated in multiple paths/passes across a workpiece collecting thousands or millions of scan points across the workpiece surface. Typically, a large amount of point data is generated for a scanned workpiece, and this set of data is often referred to as a point cloud.
SUMMARY
According to one embodiment of the invention, a computer-implemented method includes receiving coordinate measurement data associated with a measurement of a physical object, and operating a computer-implemented system to segment the coordinate measurement data into two or more data sets based on distinct geometric features of the object, the geometric features having been identified using nominal geometric information from an electronic file containing nominal geometric information for an object that corresponds to the physical object. The method further includes operating a computer-implemented system to reduce the coordinate measurement data in a first data set of the two or more data sets to a first reduced data set in a first manner, and operating a computer-implemented system to reduce the coordinate measurement data in a second data set of the two or more data sets to a second reduced data set in a second manner, different from the first manner.
According to another embodiment of the invention, a computer-implemented method includes using a computer-implemented system to receive geometric feature data originating from an electronic file containing nominal geometrical information for an object, the geometric feature data including a tolerance for one or more geometric features. Also included is an act of using a computer-implemented system to define a data segmentation volume associated with a first geometric feature of the object by establishing boundaries of the data segmentation volume, including establishing a first boundary of the data segmentation volume based at least in part on the received tolerance for the first geometric feature.
According to a further embodiment of the invention, a computer-implemented method includes using a computer-implemented system to receive geometric feature information originating from an electronic file containing nominal geometric information for an object, and using a computer-implemented system to define a first data segmentation volume associated with a first geometric feature of the object and a second data segmentation volume associated with a second geometric feature of the object. The method also includes transforming coordinate measurement data of a physical object to a coordinate system of the electronic file, the coordinate measurement data comprising a plurality of data points. Further includes in the method are acts of designating data points which are located within the defined first data segmentation volume as being associated with the first geometric feature, and designating data points which are located within the defined second data segmentation volume as being associated with the second geometric feature.
According to yet another embodiment of the invention, a computer-implemented method includes receiving an identification of a type of geometric characteristic to be inspected on a geometric feature, the identification of the type of geometric characteristic having originated from a computer model which includes the geometric feature. A further act includes receiving coordinate measurement data associated with a measurement of a physical geometric feature that corresponds to the geometric feature of the computer model. A computer-implemented system is used to determine an algorithm for reducing the coordinate measurement data, wherein the determination of the algorithm is based at least in part on the identified type of the geometric characteristic to be inspected.
According to another embodiment of the invention, a computer-implemented method includes receiving tolerance information for a geometric characteristic to be inspected on a geometric feature, and receiving coordinate measurement data associated with a measurement of the physical feature. The method also includes using a computer-implemented system to determine an algorithm for reducing the coordinate measurement data, wherein the determination of the algorithm is based at least in part on the tolerance information for the geometric characteristic.
According to a further embodiment of the invention, at least one computer-readable medium storage device has computer-readable instructions for performing steps of a method of segmenting and reducing coordinate measurement data, the method including receiving coordinate measurement data associated with a measurement of a physical object, and operating a computer-implemented system to segment the coordinate measurement data into two or more data sets based on distinct geometric features of the object, the geometric features having been identified using data from an electronic file containing nominal geometric data for an object which corresponds to the physical object. The method also includes operating a computer-implemented system to reduce the coordinate measurement data in a first data set of the two or more data sets to a first reduced data set in a first manner. The method further includes operating a computer-implemented system to reduce the coordinate measurement data in a second data set of the two or more data sets to a second reduced data set in a second manner, different from the first manner.
BRIEF DESCRIPTION OF DRAWINGS
The accompanying drawings are not intended to be drawn to scale. In the drawings, each identical or nearly identical component that is illustrated in various figures is represented by a like numeral. For purposes of clarity, not every component may be labeled in every drawing. In the drawings:
FIG. 1 is a flow chart representative of a method for managing coordinate measurement data, according to one embodiment;
FIG. 2 is an isometric view of a CAD model of an object;
FIG. 3 is a schematic drawing showing one example of geometric dimensioning and tolerance information contained within the CAD model of FIG. 2;
FIG. 4a is an isometric view of coordinate measurement data superimposed on the CAD model of FIG. 2, and a data segmentation volume;
FIG. 4b is a front plan view of the CAD model, the superimposed coordinate measurement data and the data segmentation volume of FIG. 4 b;
FIG. 5 is a flow chart representative of a method for segmenting coordinate measurement data, according to one embodiment;
FIG. 6 is a flow chart representative of a method for reducing coordinate measurement data, according to one embodiment; and
FIG. 7 is a data flow chart representative of a method for reducing coordinate measurement data.
DETAILED DESCRIPTION
This disclosure recognizes the importance of applying data reduction techniques to point cloud data in an automated, systematic manner using existing nominal geometric data as a guide, such as data from a Computer-Aided Design (CAD) model or a standard CMM inspection plan. The ability to reduce point cloud data can be particularly beneficial when scanning objects with a non-tactile measuring instrument. In some embodiments disclosed herein, to reduce point cloud data generated by a scanner, data reduction is performed on a feature-by-feature basis through reference to a computer model of a nominal object. In some embodiments, user input is permitted to adjust, select, refine, and/or set parameter values for an automated reduction algorithm.
Non-tactile measuring instruments typically are able to produce coordinate measurement data more quickly than traditional contact CMMs because fewer moving parts are used. As a result, large quantities of data often can be generated by a non-tactile measuring instrument in a short amount of time. The large amount of data, often referred to as a point cloud, can aid in producing accurate and precise data definitions of inspected objects, but the sheer quantity of data can also be problematic. For example, storing, communicating and processing the point cloud data can be time consuming or impractical, thereby resulting in overall process inefficiencies. Further, memory and communication speed requirements to handle the data may necessitate costly implementations or upgrades of hardware and/or software components. These limitations may present difficulties if analysis of point cloud data is desired for statistical process control, or for other process-oriented purposes.
Point cloud data reduction can help reduce the data burden associated with scanning technologies. Various data reduction techniques exist, such as filtering, smoothing, and decimation, among others. Typically these techniques are applied to an entire dataset to reduce the overall amount of data. Applying such techniques to an entire data set of a scanned object may excessively reduce data for some portions of the data set, thereby unacceptably eroding the accuracy or precision of the resulting data. Or, in some cases, the maximum permitted data reduction in consideration of accuracy or precision requirements may not sufficiently pare the data for practical data management or processing.
According to some embodiments of the invention, point cloud data is reduced in a strategic and systematic manner by segmenting the data set based on an object's geometric features and/or tolerances. For example, in one embodiment, a software application is used to identify various geometric features of a CAD model of an object, and then create a data segmentation volume for each geometric feature. The various data segmentation volumes may be assigned different data extraction requirements based on one or more parameters, such as: the type of feature, the identified geometric characteristic to be inspected, the tolerance set forth in the CAD model, and/or other suitable parameters.
After a physical workpiece of the object is manufactured and scanned, the resulting point cloud data may be aligned with the nominal CAD model, and the data points which reside within a data segmentation volume are assigned to that data segmentation volume. The data in each data segmentation volume then may be reduced in a manner which meets the assigned data requirements. The particular manner of data reduction may be determined by one or more parameters, and the data reduction algorithms may differ among data segmentation volumes associated with the same object. In this manner, point cloud data may be reduced or strategically specified on a feature-by-feature basis to meet the data requirements for each specific feature. In some embodiments, this feature-by-feature reduction may be performed in an automated or a semi-automated fashion.
For example, a software application according to one embodiment of the invention may analyze a CAD model of an object and categorize two identified features into two feature types, namely a plane feature type and a cylinder feature type. Once a physical object is formed and scanned with a 3D scanner, portions of the resulting point cloud data can be segmented into two data sets based on this feature categorization. In some embodiments, data segmentation volumes are established through use of a programmed algorithm which uses information from the CAD model. Each of the two data sets then may be reduced in a different manner. The subset of the point cloud data in the area of the plane feature is reduced based on its categorization as a plane and optionally on one or more other parameters such as GD&T callout type and tolerance. In the area of the cylinder feature, the data may be reduced in a manner different from the data reduction manner used for the plane feature. As one example, the plane feature data quantity may be uniformly reduced over its whole area by 75% and/or involve the use of a certain type of data filtering, while the cylinder feature data quantity may be reduced by 50% and/or involve the use of a certain type of data filtering. The reduction percentage is not the only aspect that may vary between the resulting reduced data sets of two or more features. For example, the reduced data set associated with the plane feature may include a substantially evenly geometrically distributed set of data points, while the cylinder feature data may be reduced such that data points are densely populated along cross-sectional profiles at strategically specified distances along the length of the cylinder.
In this manner, point cloud data can be reduced in a targeted fashion so that sufficient data remains for each area or feature of a scanned object without undue amounts of superfluous coordinate measurement data being maintained for some or all of the object's areas or features. Efficient reduction of the point cloud data can be particularly important when CMMs are used to inspect manufactured workpieces. Timely results can aid in confirming part compliance or discovering manufacturing errors for use as feedback to the manufacturing process.
For purposes herein, the terms “data reduction”, “reducing data”, “point cloud reduction”, and other associated terms are intended to encompass acts, methods and systems in which a subset of data is extracted from a larger data set. For example, if 10% of the data points from a point cloud are selected and used for analysis, storage, display and/or other purposes, such an act would be considered data reduction, even if the remaining 90% of data points are not expressly deleted.
While embodiments are described herein with reference to point clouds and coordinate measurement data originating from non-tactile measuring instruments, in some embodiments methods and systems described herein may be used with coordinate measurement data originating from contact coordinate measuring machines.
According to one embodiment of the invention, a method 100 of managing coordinate measurement data includes segmenting and/or reducing data based on features determined using a CAD model. Three dimensional measurement data may be contained in a voxel grid 102, from which a point cloud of surface data points may be later extracted. Of course, other suitable formats for storing and/or displaying coordinate measurement data may be used with embodiments disclosed herein. The data in the voxel grid may be measured as part of method 100, may be retrieved from a computer storage device, and/or may be received from a third party. For purposes herein, the term “receive” as it relates to data and information is meant to include receipt from a third party, receipt from an external computer system, receipt by one portion of a computer system from another portion of the same computer system, and generation of the data or information within the computer system which receives the data. In effect, receiving data or information includes any suitable provision of the data or information to the entity(ies) performing the acts of a method.
Typically, each voxel will contain a point location {x, y, z} and an intensity value {I}, though other arrangements are possible. In an act 104, a data representation of a complete surface 106 is created using the voxel grid. The surface data may be represented by point locations with normal vectors, i.e., {x, y, z, i, j, k}.
In preparation for aligning the surface data with a CAD model 112 or other electronic file containing nominal geometric information, a data representation of an approximate surface 110 may be created in an act 108 by reducing the data in the complete surface data representation. For example, decimation techniques may be used to reduce the entire data set of the complete surface to create an approximate surface that is sufficient for an initial best-fit operation to align the measured surface data to the CAD model 112. A best-fit operation (act 114) then may be performed to arrive at a transformation matrix 116 which aligns the surface data to the CAD model 112 by transforming the coordinate system of the surface data to the coordinate system of the CAD model. Typically, a least-squares method may be used as part of the best-fit operation, though other suitable methods may be used. The transformation matrix 116 then may be used to align the data representation of the complete surface to the CAD model 112 (act 118).
In some embodiments, the intervening acts associated with creating a data representation of an approximate surface are not performed. That is, a best-fit operation may be performed directly on the complete surface data representation without first determining a transformation matrix based on an approximate surface. For purposes herein, transforming a coordinate system of coordinate measurement data to the coordinate system of a CAD model is intended to include a transformation of a coordinate system of a CAD model to a coordinate system of coordinate measurement data. Such a transformation is intended to include any operation which results in at least an approximate alignment of the coordinate measurement data to the CAD model (or other electronic model or file containing geometric information). For purposes herein, transformation of a coordinate measurement system is intended to include a translation and/or rotation of a coordinate measurement system, as well as a transformation from one type of coordinate measurement system to another (e.g., from spherical coordinates to Cartesian coordinates).
In an act 120, the data representation of the complete surface 106 is segmented into data sets based on features identified through use the CAD model. For example, a CAD model of a physical object may be analyzed and a number of distinct geometric features may be identified. In act 120, the surface data derived from the coordinate measurement data is divided into data sets with each data set corresponding to one of the identified geometric features. Subsets of the data sets may grouped together within a category of geometric features. For example, two or more of the identified geometric features may be identified as planes, and the two associated data sets may be grouped together in a plane category. Any suitable number of categories may be established or defined. For example, two, three, four, six, seven features, or any number of features greater than seven may be identified and associated with a same number of categories or a different number of categories. The identification of the geometric features in the CAD model may be performed prior to initiation of method 100, or may be performed at any suitable time during act 100. The analysis of the CAD model (or other electronic model) may be performed by a pre-defined algorithm that searches for shapes, areas, edges, and/or other attributes of the CAD model to identify types of geometric features. In some embodiments, a user may be prompted to enter values to set parameters, and/or a user may be prompted to select from a list of identification algorithms. In such embodiments, the segmentation is still considered to be the use of a pre-defined algorithm.
To prompt and/or receive a user's selection of parameter values, algorithms and/or other selections, dialog boxes may be presented to the user. In some embodiments, drop down menus, readable files, or selectable tables may be used, and in still further embodiments, users may be permitted to directly enter values.
A data segmentation volume may be created for each identified geometric feature to define which data points of the coordinate measurement data to associate with the identified geometric feature. The data points contained within each data segmentation volume then may be reduced. The boundaries of each data segmentation volume may be set using at least in part geometric dimensioning and tolerance (GD&T) information contained with the CAD model in some embodiments. For example, data points associated with the coordinate measurement of a plane of course will not be exactly co-planar with one another, that is, some points will lie in front of the nominal plane and some points will lie behind the nominal plane. To determine the boundaries of inclusion of data points which lie behind or in front of the nominal plane, geometric tolerance and dimension information from the CAD model may be used. Further detail regarding examples of establishing data segmentation volumes are discussed further below with reference to FIGS. 4a and 4 b.
Each of the data sets may be reduced in a manner specific to the feature corresponding to the data set (act 122). For example, a first data set corresponding to a first feature may be reduced using triangular decimation at a specified percentage rate or specific number of vertices, while a second data set corresponding to a second feature may be reduced using the same triangular decimation algorithm but specify a maximum deviation or minimum angle between neighboring facets. A third data set corresponding to a third feature may be reduced using a Gaussian filter to remove outliers outside some N number of standard deviations. A fourth data set may be reduced by uniform interpolation over its surface by specifying the spacing between points, or points per unit area. A fifth data set may be reduced by strategically extracting uniformly spaced points along specified cross-sectional profiles at different locations or angular positions along a feature. A sixth data set may be reduced by strategically extracting specific surface point locations from user-defined nominal points and vectors intersecting the actual surface. Lastly, a seventh data set may not be reduced at all. Of course the above example is not intended to be limiting as other types of data reduction may be used for various features.
Turning now to one example of a particular application of the methods and apparatuses disclosed herein, FIG. 2 shows an isometric view of a CAD model of an object 200 composed of a rectangular prism 202 with a cylindrical bore 204. Rectangular prism 202 includes a top planar surface 206, a bottom planar surface 208, a front planar surface 210, a rear planar surface 212 and two side planar surfaces 214, 216. A two-dimensional layout of the object is shown in FIG. 3 along with GD&T information. The GD&T information of this CAD model includes various callouts for features of interest, including basic dimensions and control frames. The CAD model also includes datum features. As discussed further below with reference to FIGS. 4a and 4b , this GD&T information, in some cases in conjunction with user inputs, is used to define sectioning boundaries which enclose a subset of data points from a coordinate measurement data point cloud. The point cloud (or other suitable set of data points) is generated through coordinate measurement of a corresponding physical object.
FIG. 3 includes three callouts, namely a size dimension 302 defining the diameter of a cylindrical bore, and two feature control frames 304, 306. Feature control frame 304 provides information regarding the position of the cylindrical bore relative to the datum features labeled “-A-”, “-B-” and “-C-”. The “M” after the “0.1” position tolerance indicates that there is extra allowance for error as the bore's size increases, therefore more data on the cylinder surface about its diameter may be beneficial in determining extra allowance in the tolerance evaluation. Feature control frame 306 provides information regarding a desired flatness of top planar surface 206. Basic dimensions 308 and 310 provide the location of the center of cylindrical bore 204 relative to a front edge of prism 200. Datum features, which in this example include datum planes 312, 314 and 316, are also provided within the CAD model.
From the CAD model and the GD&T information, boundaries may be constructed to define a data segmentation volume for each of various features of the object. The data contained within these data segments then can be reduced based on the type of feature and/or other parameters. For example, as shown in FIGS. 4a and 4b , a segmentation volume 400 is shown enclosing coordinate measurement data points 402 associated with front planar surface 210.
According to one embodiment of the invention, a method 500 may be used to create one or more data segmentation volumes through use of the CAD model. In some embodiments, method 500 may be a computer-implemented method, and may or may not include prompts for user input. Method 500 described herein is one example of a method of performing act 120 of method 100 described above with reference to FIG. 1. However, other suitable methods for performing act 120 may be used, and method 500 may be used in methods other than method 100.
In an act 502, one or more geometric feature types are identified from the CAD model. This identification may be performed by a software application programmed to process CAD model data and locate geometric features. In some embodiments, a data segmentation volume may not be established for all identified features. For example, the software program may include instructions to not establish data segmentation volumes for certain geometric feature types. Examples of geometric feature types include: planes, cylinders, cones, spheres, ellipses, etc., as well as other, complex free-formed surfaces composed of higher order equations between surface points.
As one example of establishing a data segmentation volume, for a given identified datum surface, boundaries may be set along the datum surface by defining boundaries inwardly of the nominal surface edges by a clearance distance (act 504) to avoid inclusion of data points that are over the edges. For example, segmentation volume 400 is spaced inwardly from the edges of front planar surface 210 by a clearance distance Db. The upper and lower boundary surfaces are set at clearance distance Db from top planar surface 206 and bottom planar surface 208. Likewise, the side boundary surfaces are set at clearance distance Db from side planar surfaces 214, 216. Db may be set at a default value for distance from edges defined in the CAD model. Or, in some embodiments, clearance distance Db may be calculated based on various values contained within the model, such as tolerances set forth in the CAD model, and/or the dimensions of the planar surface. Segmentation volumes may have different clearance distances along different edges, and of course segmentation volumes may have clearance distances which differ from other segmentation volumes within the same CAD model. In some embodiments, one or more clearance distances may be based at least in part on the precision and/or point density of the coordinate measurement data. As will be apparent to one of skill in the art, data segmentation volumes are not necessarily displayed or explicitly defined as a volume. For example, each of the boundaries of a data segmentation volume may be defined mathematically or defined by a series of points which establish a line, plane, or other surface. In some embodiments, a data segmentation volume may not include boundaries which form a closed volume in the sense that in some areas or directions, any measured data points would be included in the data segmentation volume.
A tolerance band t also may be established to define boundaries for encompassing coordinate measurement data points that are in front of or behind the nominal datum surface defined in the CAD model (act 506). A value for the tolerance band may be set by using a multiple of the feature tolerance set forth in the CAD model, or by using a default tolerance band value, or by using a specific tolerance band value input by a user. Different default tolerance band values may correspond to different feature types in some embodiments. For example, the depth of data segmentation volume 400 may be set as a tolerance band based on a multiplier of two of the tolerance defined in the CAD model for datum plane C 316 (0.01 mm), resulting in a tolerance band t having a depth of 0.02 mm.
A chart of examples of values for tolerance bands and clearance distances is shown in Table 1. In cases where a feature type does not typically include tolerances, or a tolerance is not provided by the CAD model, a tolerance band default value may be used. Tolerance values may be provided by computer models or other electronic files other than CAD models. For example, in some embodiments, tolerance information may be contained in or input to a computer file, and the tolerance information may be assigned to various geometric features. Clearance distances from surface edges may be preset at a specified distance, and the particular values may vary based on the feature type. In some embodiments, the clearance distances may be set based on values such as the size of the feature or certain tolerance information provided in the CAD model.
TABLE 1
Clearance
Tolerance multiplier distance
(override tolerance Tolerance from surface
Feature Type default) default edges (Db)
Plane (Datum-A-) 2 × 0.01 = 0.02 mm 0.05 mm 0.5 mm
Plane (all others) 2 × {tolerance not found} 0.05 mm 0.5 mm
Cylinder 2 × 0.2 = 0.4 mm 0.05 mm 0.5 mm
Cone 3 × {tolerance not found} 0.05 mm 0.5 mm
Sphere 2 × {tolerance not found} 0.05 mm 0.5 mm
Free-formed 3 × {tolerance not found} 0.05 mm 0.5 mm
Note:
Bold values indicate those that would be applied to features depending on information available in the CAD model for those features
Once boundaries have been set to define data segmentation volumes for data points, the data included within each segmentation volume may be reduced in a manner specific to the feature type, and/or specific to one or more other parameters such as a tolerance set forth in the CAD model. For each data segmentation volume, the corresponding target point density may be input to a known data reduction program which then reduces the data to the target point density. In this manner, coordinate measurement data may be reduced in a manner targeted to the data needs for each type of feature. In some embodiments, the segmentation and/or reduction may be performed in an automated fashion. Examples of known data reduction programs include 3D Reshaper, available from Technodigit, PC-DMIS®, available from Wilcox Associates, Inc., and QUINDOS®, available from Hexagon Metrology GMBH, though any suitable data reduction program may be used. Technodigit's 3D Reshaper software can uniformly reduce data through triangular decimation and Gaussian filter algorithms. 3D Reshaper can also strategically extract points along profiles at sectioned locations in a geometric feature. PC-DMIS® and QUINDOS® software both have a wide range of filtering options as well as the ability to strategically extract points at nominal locations, as do many other CMM inspection software packages in the industry.
For example, for a callout of flatness, a target point density of nine points per square millimeter may be defined if the tolerance is less than or equal to 0.005 mm. If the tolerance is greater than 0.005 mm and less than or equal to 0.050 mm, the target point density may be set to 4 points per square millimeter. In cases where the tolerance is greater than 0.050 mm, the target point density may be set to 1 point per square millimeter. Table 2 shows one example of a chart of point density and/or point arrangement based on the type of measurement, the type of callout, and the tolerance range into which the associated tolerance falls.
TABLE 2
1st tolerance range 2nd tolerance range 3rd tolerance range
Callout Name Reduction Method ≦0.005 mm >0.005 ≦0.050 mm >0.050 mm
Flatness Uniform 9 pt/mm2 4 pt/mm2 1 pt/mm2
Interpolation
Roundness Strategic section@height = h, section@height = h, section @height = h,
Extraction 300 pt/rev 100 pt/rev 50 pt/rev
Cylindricity Strategic #steps = N between #steps = N between h0 #steps = N between
Extraction h0 and hmax and hmax h0 and hmax
300 pt/rev 100 pt/rev 8 pt/rev
Profile Triangular No reduction Deviation limit = Deviation limit =
Decimation performed 0.001 mm 0.005 mm
Total Runout Triangular No reduction Deviation limit = Deviation limit =
Decimation performed 0.001 mm 0.005 mm
Diameter Strategic 10 pt/mm, steps = N 100 pt/rev, Gauss 100 pt/rev,
Extraction and between h0 and hmax Filter = 50 cc/rev Gauss Filter = 50 cc/
Gauss Polar Filter rev
Position/Location Strategic Specified nominal Specified Specified
Extraction vector points: nominal vector nominal vector
x, y, z, i, j, k points: x, y, z, i, j, k points: x, y, z, i, j, k
The above embodiment includes the use of a CAD model for access to nominal geometric data, however other types of electronic files which contain nominal geometric information may be used with embodiments disclosed herein, either independent of, or supplemental to, information provided by a CAD model.
One example of a method 600 of reducing and analyzing data contained within a data segmentation volume is shown in FIG. 6. Not all of the acts shown in FIG. 6 necessarily need to be performed to reduce and/or analyze coordinate measurement data. In an act 602, a target data point density and/or data point arrangement is determined. The determination may be based on the type of feature being analyzed, the type of callout specified, and/or a tolerance or other piece of GD&T information. This determination may be implemented through use of a lookup table, such as the example shown in Table 2.
A type of data reduction algorithm is determined in an act 604. Act 604 may include an analysis of the target point density and/or arrangement which was determined in act 602. For example, in act 604, the existing data point density from a point cloud may be compared to the target point density determined in act 602, and a particular data reduction scheme (decimation, smoothing, etc.) may be selected based on this comparison. In some embodiments, the same type of data reduction algorithm may be used for each data segmentation volume, but particular parameters within the data reduction algorithm may be determined based on the target point density and/or GD&T information.
The coordinate measurement data is reduced in an act 606.
The reduced data, which may be more amendable to analysis due to the lessened data handling requirements, may be analyzed in any suitable manner in an act 608. For example, the flatness of a plane, or the length of a geometric feature may be calculated and compared to the CAD model or other standard. Such analyses may be implemented as part of a quality analysis/quality control program or as part of any other process involving the measurement and analysis of objects.
FIG. 7 shows a data flow chart representative of various embodiments described herein. A pre-defined reduction algorithm 702 receives an electronic file, or data therefrom, such as a nominal CAD geometry and tolerance data 704. Algorithm 702 also receives acquired point cloud data 706. Point cloud data 706 may be data from a non-contact CMM, a contact CMM, or other measurement device. The point cloud data may be received directly from a CMM, or may be received from a data file, or any other suitable source. User input also may be received by reduction algorithm 702, such as user input for a point sampling strategy 708. For purposes herein, an algorithm is considered to be pre-defined even if the algorithm is selected from a set of possible algorithms. Further, user inputs to the pre-defined algorithm do not necessarily render the algorithm no longer pre-defined.
Using the nominal CAD geometry and tolerance data 704, the point cloud data 706 and the user input for a point sampling strategy 708, reduction algorithm 702 reduces the point cloud data to a reduced data set 710 that is more easily managed and analyzed.
The above-described embodiments can be implemented in any of numerous ways. For example, the embodiments may be implemented using hardware, software or a combination thereof. When implemented in software, the software code can be executed on any suitable processor or collection of processors, whether provided in a single computer or distributed among multiple computers.
Further, it should be appreciated that a computer may be embodied in any of a number of forms, such as a rack-mounted computer, a desktop computer, a laptop computer, or a tablet computer. Additionally, a computer may be embedded in a device with suitable processing capabilities, including a Personal Digital Assistant (PDA), a smart phone or any other suitable portable or fixed electronic device.
Also, a computer may have one or more input and output devices. These devices can be used, among other things, to present a user interface. Examples of output devices that can be used to provide a user interface include printers or display screens for visual presentation of output and speakers or other sound generating devices for audible presentation of output. Examples of input devices that can be used for a user interface include keyboards, and pointing devices, such as mice, touch pads, and digitizing tablets. As another example, a computer may receive input information through speech recognition or in other audible format.
Such computers may be interconnected by one or more networks in any suitable form, including as a local area network or a wide area network, such as an enterprise network or the Internet. Such networks may be based on any suitable technology and may operate according to any suitable protocol and may include wireless networks, wired networks or fiber optic networks.
Also, the various methods or processes outlined herein may be coded as software that is executable on one or more processors that employ any one or more of a variety of operating systems or platforms. Additionally, such software may be written using any of a number of suitable programming languages and/or programming or scripting tools, and also may be compiled as executable machine language code or intermediate code that is executed on a framework or virtual machine.
In this respect, embodiments of the invention may be embodied as a computer-readable storage medium or multiple computer-readable media encoded with one or more programs that, when executed on one or more computers or other processors, perform methods that implement the various embodiments of the invention discussed above. Computer readable media may include, for example, a computer memory, one or more floppy discs, compact discs (CD), optical discs, digital video disks (DVD), magnetic tapes, flash memories, circuit configurations in Field Programmable Gate Arrays or other semiconductor devices, or other tangible computer storage medium. As is apparent from the foregoing examples, a computer readable storage medium may retain information for a sufficient time to provide computer-executable instructions in a non-transitory form. Such a computer readable storage medium or media can be transportable, such that the program or programs stored thereon can be loaded onto one or more different computers or other processors to implement various aspects of the present invention as discussed above. As used herein, the term “computer-readable storage medium” encompasses only a computer-readable medium that can be considered to be a manufacture (i.e., article of manufacture) or a machine. Alternatively or additionally, the embodiments of the invention may be embodied as a computer-readable medium other than a computer-readable storage medium, such as a propagating signal.
The terms “program” or “software” are used herein in a generic sense to refer to any type of computer code or set of computer-executable instructions that can be employed to program a computer or other processor to implement various aspects of the present invention as discussed above. Additionally, it should be appreciated that according to one aspect of this embodiment, one or more computer programs that when executed perform methods of embodiments of the present invention need not reside on a single computer or processor, but may be distributed in a modular fashion amongst a number of different computers or processors to implement various aspects of embodiments of the present invention.
Computer-executable instructions may be in many forms, such as program modules, executed by one or more computers or other devices. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. Typically the functionality of the program modules may be combined or distributed as desired in various embodiments.
The phrase “and/or,” as used herein in the specification and in the claims, should be understood to mean “either or both” of the elements so conjoined, i.e., elements that are conjunctively present in some cases and disjunctively present in other cases. Multiple elements listed with “and/or” should be construed in the same fashion, i.e., “one or more” of the elements so conjoined. Other elements may optionally be present other than the elements specifically identified by the “and/or” clause, whether related or unrelated to those elements specifically identified. Thus, as a non-limiting example, a reference to “A and/or B”, when used in conjunction with open-ended language such as “comprising” can refer, in one embodiment, to A only (optionally including elements other than B); in another embodiment, to B only (optionally including elements other than A); in yet another embodiment, to both A and B (optionally including other elements); etc.
As used herein in the specification and in the claims, “or” should be understood to have the same meaning as “and/or” as defined above. For example, when separating items in a list, “or” or “and/or’ shall be interpreted as being inclusive, i.e., the inclusion of at least one, but also including more than one, of a number or list of elements, and, optionally, additional unlisted items. Only terms clearly indicated to the contrary, such as “only one of” or “exactly one of,” or, when used in the claims, “consisting of,” will refer to the inclusion of exactly one element of a number or list of elements. In general, the term “or” as used herein shall only be interpreted as indicating exclusive alternatives (i.e. “one or the other but not both”) when preceded by terms of exclusivity, such as “either,” “one of,” “only one of,” or “exactly one of.” “Consisting essentially of,” when used in the claims, shall have its ordinary meaning as used in the field of patent law.
It should also be understood that, unless clearly indicated to the contrary, in any methods claimed herein that include more than one step or act, the order of the steps or acts of the method is not necessarily limited to the order in which the steps or acts of the method are recited.
Having thus described several aspects of at least one embodiment of this invention, it is to be appreciated various alterations, modifications, and improvements will readily occur to those skilled in the art. Such alterations, modifications, and improvements are intended to be part of this disclosure, and are intended to be within the spirit and scope of the invention. Accordingly, the foregoing description and drawings are by way of example only.

Claims (18)

What is claimed is:
1. A method comprising:
operating a coordinate measuring machine to measure a physical object to generate coordinate measurement data from the physical object;
operating a computer-implemented system to identify first and second distinct geometric features of the object using a CAD model containing nominal geometric information for an object that corresponds to the physical object;
operating a processor to segment the coordinate measurement data into two or more data sets, a first data set of the two or more data sets being associated with the first distinct geometric feature of the object, a second data set of the two or more data sets being associated with the second distinct geometric feature of the object, the geometric features having been identified using the nominal geometric information from the CAD model;
operating a processor to reduce the coordinate measurement data in the first data set of the two or more data sets to a first reduced data set in a first data reduction manner associated with the first geometric feature; and
operating a processor to reduce the coordinate measurement data in the second data set of the two or more data sets to a second reduced data set in a second data reduction manner associated with the second geometric feature, the second data reduction manner being different from the first data reduction manner.
2. The method of claim 1, wherein operating a coordinate measuring machine to generate the coordinate measurement data comprises operating a scanning coordinate measuring machine to generate point cloud data.
3. The method of claim 1, wherein the coordinate measurement data comprises data generated by a 3D scanner.
4. The method of claim 1, further comprising:
determining a characteristic of a first geometric feature using the first reduced data set; and
determining a characteristic of a second geometric feature using the second reduced data set.
5. The method of claim 1, wherein the first data set and the second data set include data points which are included in both the first data set and the second data set.
6. The method of claim 1, wherein the electronic file comprises an inspection plan for a coordinate measuring machine.
7. The method of claim 1, wherein operating a computer-implemented system to segment the coordinate measurement data comprises segmenting the coordinate measurement data in a manner which is defined prior to receiving the coordinate measurement data.
8. The method of claim 1, further comprising operating a computer-implemented system to identify the distinct geometric features of the object using the electronic file by using a pre-defined set of computer-readable instructions stored on a non-transitory computer storage device to perform steps which identify the distinct geometric features of the object using data from the electronic file.
9. A method comprising:
operating a coordinate measuring machine to measure a physical object to generate coordinate measurement data;
using a computer-implemented system to identify geometric feature information using a CAD model containing nominal geometric information for an object, including identifying nominal geometric information for a first geometric feature of the object and for a second geometric feature of the object; and
using a computer-implemented system to define a first data segmentation volume associated with the first geometric feature of the object and a second data segmentation volume associated with the second geometric feature of the object;
transforming the coordinate measurement data of the physical object to a coordinate system of the CAD model, the coordinate measurement data comprising a plurality of data points;
designating data points which are located within the defined first data segmentation volume as being associated with the first geometric feature; and
designating data points which are located within the defined second data segmentation volume as being associated with the second geometric feature.
10. The method of claim 9, wherein the coordinate measurement data comprises a point cloud.
11. The method of claim 9, further comprising:
reducing the data points associated with the first geometric feature in a first manner; and
reducing the data points associated with the second geometric feature using a second manner, different from the first manner.
12. The method of claim 9, wherein the geometric feature information originating from a CAD model of an object comprises tolerance information associated with the first geometric feature.
13. The method of claim 9, wherein the geometric feature information comprises information regarding a type of the first geometric feature.
14. A method comprising:
receiving an identification of a type of geometric characteristic to be inspected on a geometric feature, the identification of the type of geometric characteristic having originated from a CAD model of a nominal object which includes the geometric feature;
operating a coordinate measuring machine to generate coordinate measurement data of a physical geometric feature that corresponds to the geometric feature of the CAD model;
using a computer-implemented system to determine a manner of reducing the coordinate measurement data, wherein the determination of the manner is based at least in part on the identified type of the geometric characteristic to be inspected.
15. At least one computer-readable non-transitory storage medium device having computer-readable instructions for performing steps of a method of segmenting and reducing coordinate measurement data, the method comprising:
receiving coordinate measurement data associated with a measurement of a physical object;
identifying first and second distinct geometric features of the object using a CAD model containing nominal geometric information for an object that corresponds to the physical object;
operating a computer-implemented system to segment the coordinate measurement data into two or more data sets, a first data set of the two or more data sets being associated with the first distinct geometric feature of the object, a second data set of the two or more data sets being associated with the second distinct geometric feature of the object;
operating a computer-implemented system to reduce the coordinate measurement data in the first data set of the two or more data sets to a first reduced data set using a first manner associated with the first geometric feature; and
operating a computer-implemented system to reduce the coordinate measurement data in the second data set of the two or more data sets to a second reduced data set using a second manner associated with the second geometric feature, the second manner being different from the first manner.
16. The method of claim 1, wherein the first data reduction manner is selected based at least in part on a user input.
17. The method of claim 1, wherein the first data reduction manner is selected based at least in part on a user input regarding a point sampling strategy.
18. The method of claim 14, wherein the determination of the manner is based at least in part on a user input regarding a point sampling strategy.
US13/560,724 2011-07-29 2012-07-27 Coordinate measuring system data reduction Active 2033-11-18 US9390202B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US13/560,724 US9390202B2 (en) 2011-07-29 2012-07-27 Coordinate measuring system data reduction

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US201161513451P 2011-07-29 2011-07-29
US13/560,724 US9390202B2 (en) 2011-07-29 2012-07-27 Coordinate measuring system data reduction

Publications (2)

Publication Number Publication Date
US20130030773A1 US20130030773A1 (en) 2013-01-31
US9390202B2 true US9390202B2 (en) 2016-07-12

Family

ID=47597945

Family Applications (1)

Application Number Title Priority Date Filing Date
US13/560,724 Active 2033-11-18 US9390202B2 (en) 2011-07-29 2012-07-27 Coordinate measuring system data reduction

Country Status (9)

Country Link
US (1) US9390202B2 (en)
EP (1) EP2737426B1 (en)
JP (1) JP2014527663A (en)
KR (1) KR20140066177A (en)
CN (1) CN103890766B (en)
AU (1) AU2012290426A1 (en)
BR (1) BR112014002063A2 (en)
CA (1) CA2843414A1 (en)
WO (1) WO2013019609A1 (en)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20180058843A1 (en) * 2016-08-26 2018-03-01 Keyence Corporation Three-Dimensional Measurement Device
US11162787B2 (en) * 2018-12-20 2021-11-02 Industrial Technology Research Institute Measuring program compiling device and measuring program compiling method

Families Citing this family (32)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10552551B2 (en) 2011-11-18 2020-02-04 Nike, Inc. Generation of tool paths for shore assembly
US9451810B2 (en) 2011-11-18 2016-09-27 Nike, Inc. Automated identification of shoe parts
US8755925B2 (en) 2011-11-18 2014-06-17 Nike, Inc. Automated identification and assembly of shoe parts
US8958901B2 (en) 2011-11-18 2015-02-17 Nike, Inc. Automated manufacturing of shoe parts
US8849620B2 (en) * 2011-11-18 2014-09-30 Nike, Inc. Automated 3-D modeling of shoe parts
US8942837B2 (en) * 2012-03-12 2015-01-27 United Technologies Corporation Method for inspecting a manufacturing device
CN103335626B (en) * 2013-06-04 2015-12-23 上海交通大学 The sample point optimum option method of three coordinate measuring engine measurement flatness
EP2823952A1 (en) * 2013-07-09 2015-01-14 Siemens Aktiengesellschaft Adaptation method and production method for components produced by means of SLM
US9885960B2 (en) * 2013-12-26 2018-02-06 Toshiba Memory Corporation Pattern shape adjustment method, pattern shape adjustment system, exposure apparatus, and recording medium
EP3201564B1 (en) 2014-09-30 2020-05-20 Hexagon Metrology, Inc System and method for measuring an object using x-ray projections. computer program product.
GB201504612D0 (en) * 2015-03-18 2015-05-06 Inquisitive Systems Ltd Forensic analysis
KR101650011B1 (en) * 2015-04-02 2016-08-22 주식회사 쓰리디시스템즈코리아 Method of setting inspection criteria coordinate by aligning geometry created by 3D scanner
CN104820764B (en) * 2015-05-26 2017-12-19 中国电子科技集团公司第三十八研究所 The preparation method and device of circuit assembly technical papers
CN105320802B (en) * 2015-05-29 2018-07-31 南京市城市规划编制研究中心 A method of it is designed based on AutoCAD general graphical object implementatio8 auxiliary programmings
KR101702517B1 (en) * 2015-06-25 2017-02-06 삼성중공업(주) Apparatus for inspecting protrusion of outfittings
CN105976353B (en) * 2016-04-14 2020-01-24 南京理工大学 Spatial non-cooperative target pose estimation method based on model and point cloud global matching
CN106441311B (en) * 2016-07-15 2019-06-28 上海宇航系统工程研究所 A kind of non-cooperative Spacecraft relative pose measurement method based on laser imaging radar
US20180268614A1 (en) * 2017-03-16 2018-09-20 General Electric Company Systems and methods for aligning pmi object on a model
CN107123085B (en) * 2017-03-22 2019-10-18 华南理工大学 A kind of point cloud ratio standard method based on triangulation
DE102017126389A1 (en) 2017-11-10 2019-05-16 Liebherr-Werk Biberach Gmbh Method and device for providing a workpiece representation at a production location
JP6983704B2 (en) * 2018-03-19 2021-12-17 株式会社ミツトヨ Measurement plan generation method and equipment for X-ray CT for measurement
DE102019107952B4 (en) * 2019-03-27 2023-08-10 Volume Graphics Gmbh Computer-implemented method for analyzing measurement data of an object
EP3714836B1 (en) * 2019-03-29 2022-01-12 Biomet 3I, LLC Optimized library solution for dental implants
EP3882568B1 (en) * 2020-03-16 2022-07-06 Carl Zeiss Industrielle Messtechnik GmbH Computer-implemented method for automatically creating a measurement plan and corresponding computer program, computer program product and coordinate measuring machine
US20210304620A1 (en) * 2020-03-26 2021-09-30 Honeywell International Inc. Systems and methods for distributed data acquisition
EP3901563B1 (en) * 2020-04-21 2022-12-14 Carl Zeiss Industrielle Messtechnik GmbH Method and device for determining a measuring strategy for measuring a measurement object and program
US11301989B2 (en) * 2020-05-14 2022-04-12 Taurex Drill Bits, LLC Wear data quantification for well tools
EP3916495A1 (en) * 2020-05-28 2021-12-01 Carl Zeiss Industrielle Messtechnik GmbH Method and arrangement for evaluating or preparing an evaluation of a sample of measurement data from a measurement of a plurality of workpieces
EP3933339B1 (en) * 2020-06-30 2024-03-20 Mitutoyo Corporation Method and computer program product for filtering a measurement data set usable for specifying and/or verifying an internal feature of a workpiece
CN112629456B (en) * 2020-11-17 2022-11-08 中国航发哈尔滨东安发动机有限公司 System and method for automatically measuring complex curved surface of part of turboshaft engine
EP4348169A1 (en) * 2021-05-25 2024-04-10 Hexagon Metrology, Inc. Post-processing of measurement data collected with optical probe
US11543809B2 (en) * 2021-05-28 2023-01-03 Textron Innovations Inc. Automated inspection program generation

Citations (55)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5471406A (en) * 1992-04-14 1995-11-28 Carl Zeiss-Stiftung Method of measuring elemental shapes of a workpiece on a coordinate measuring machine
US5471878A (en) 1993-09-27 1995-12-05 General Electric Company Method of suppressing grain noise in ultrasonic waveform data by 3D filtering
US5610846A (en) * 1994-05-27 1997-03-11 Carl Zeiss Stiftung Method for coordinate measurement on workpieces adjusted for bending of measuring apparatus structure
US5936627A (en) 1997-02-28 1999-08-10 International Business Machines Corporation Method and system for performing perspective divide operations on three-dimensional graphical object data within a computer system
US6161079A (en) * 1997-08-18 2000-12-12 Giddings & Lewis, Llc Method and apparatus for determining tolerance and nominal measurement values for a coordinate measuring machine
US20010027381A1 (en) * 2000-03-01 2001-10-04 Mitutoyo Corporation Method and apparatus for measuring geometry elements
US6330523B1 (en) 1996-04-24 2001-12-11 Cyra Technologies, Inc. Integrated system for quickly and accurately imaging and modeling three-dimensional objects
US6359960B1 (en) 1999-08-03 2002-03-19 Siemens Aktiengesellschaft Method for identifying and locating markers in a 3D volume data set
US20020130873A1 (en) 1997-01-29 2002-09-19 Sharp Kabushiki Kaisha Method of processing animation by interpolation between key frames with small data quantity
US6611617B1 (en) * 1995-07-26 2003-08-26 Stephen James Crampton Scanning apparatus and method
US6690820B2 (en) 2001-01-31 2004-02-10 Magic Earth, Inc. System and method for analyzing and imaging and enhanced three-dimensional volume data set using one or more attributes
US20040028274A1 (en) 2002-08-09 2004-02-12 Celsys Co., Ltd. Method for generating vector data for a hand-drawn curve
US6708138B1 (en) * 1998-08-28 2004-03-16 Mitutoyo Corporation Maintenance-and-control apparatus and method for coordinate and surface texture measuring device
US6720966B2 (en) 1999-12-23 2004-04-13 Siemens Aktiengesellschaft Method for reconstructing 3D image data with respect to a volume of interest of an examination subject
US6765570B1 (en) 1998-07-21 2004-07-20 Magic Earth, Inc. System and method for analyzing and imaging three-dimensional volume data sets using a three-dimensional sampling probe
US6778172B2 (en) 2000-09-14 2004-08-17 Minolta Co., Ltd. Method and apparatus for extracting surface from three-dimensional shape data as well as recording medium
US6788210B1 (en) * 1999-09-16 2004-09-07 The Research Foundation Of State University Of New York Method and apparatus for three dimensional surface contouring and ranging using a digital video projection system
US6914601B2 (en) 2001-06-12 2005-07-05 Minolta Co., Ltd. Method, apparatus, and computer program for generating three-dimensional shape data or volume data
US7006085B1 (en) 2000-10-30 2006-02-28 Magic Earth, Inc. System and method for analyzing and imaging three-dimensional volume data sets
US7024027B1 (en) 2001-11-13 2006-04-04 Koninklijke Philips Electronics N.V. Method and apparatus for three-dimensional filtering of angiographic volume data
US7061484B2 (en) 2002-11-27 2006-06-13 Voxar Limited User-interface and method for curved multi-planar reformatting of three-dimensional volume data sets
US7088848B2 (en) 2002-02-15 2006-08-08 Siemens Aktiengesellschaft Method for the presentation of projection images or tomograms from 3D volume data of an examination volume
US7133047B2 (en) 2003-12-29 2006-11-07 Intel Corporation Method and mechanism for programmable filtering of texture map data in 3D graphics subsystems
US20060273268A1 (en) 2005-06-07 2006-12-07 Inus Technology, Inc. Method for detecting 3D measurement data using allowable error zone
US7327857B2 (en) * 2004-03-09 2008-02-05 General Electric Company Non-contact measurement method and apparatus
US20080075227A1 (en) * 2004-05-26 2008-03-27 Ralf Christoph Coordinate Measuring Apparatus And Method For Measuring An Object
US7372462B2 (en) 2005-03-14 2008-05-13 Ricoh Company, Ltd. Three-dimensional geometry processing system and method for CAD apparatus restricted in surface representations to import solid data
US7477261B2 (en) 2003-12-29 2009-01-13 Intel Corporation Method and mechanism for programmable filtering of texture map data in 3D graphics subsystems
US20090027412A1 (en) 2007-07-23 2009-01-29 Disney Enterprises, Inc. Three-dimensional location-based texture transfers
US20090040530A1 (en) * 2007-08-06 2009-02-12 Vistec Semiconductor Systems Gmbh Coordinate measuring machine and a method for correcting non-linearities of the interferometers of a coordinate measuring machine
US7492415B2 (en) 2004-02-05 2009-02-17 Broadcom Corporation Method and system for data compression for storage of 3D comb filter data
US7620023B2 (en) 2005-04-18 2009-11-17 Sierra Wireless, Inc. Configurable multislot class for wireless devices
US7620234B2 (en) 2000-10-06 2009-11-17 Canon Kabushiki Kaisha Image processing apparatus and method for generating a three-dimensional model of an object from a collection of images of the object recorded at different viewpoints and segmented using semi-automatic segmentation techniques
US20090307916A1 (en) * 2005-04-25 2009-12-17 Renishaw Plc Method for scanning the surface of a workpiece
US7646672B2 (en) 2008-01-18 2010-01-12 Pgs Geophysical As Method for wavefield separation in 3D dual sensor towed streamer data with aliased energy in cross-streamer direction
US7650023B2 (en) 2004-02-24 2010-01-19 Siemens Aktiengeśellschaft Method for filtering tomographic 3D images after completed reconstruction of volume data
US7653243B2 (en) 2005-10-14 2010-01-26 Siemens Medical Solutions Usa, Inc. System and method for 3D volume segmentation using exact minimal surfaces given a boundary
CN101672637A (en) 2009-09-24 2010-03-17 华东理工大学 Digitizing detection method of complicated curved face
US7684613B2 (en) 2005-05-27 2010-03-23 Konica Minolta Sensing, Inc. Method and system for aligning three-dimensional shape data from photogrammetry data and three-dimensional measurement data using target locations and surface vectors
US20100079140A1 (en) 2006-12-11 2010-04-01 Koninklijke Philips Electronics N. V. Fibre tracking on the basis of macroscopic information
CN101692257A (en) 2009-09-25 2010-04-07 华东理工大学 Method for registering complex curved surface
US20100142798A1 (en) * 2007-08-17 2010-06-10 Renishaw Plc Non-contact measurement apparatus and method
US7805442B1 (en) 2000-12-05 2010-09-28 Navteq North America, Llc Method and system for representation of geographical features in a computer-based system
US7804988B2 (en) 2005-08-17 2010-09-28 Siemens Aktiengesellschaft Method for filtering of tomographic 3D displays on the basis of the reconstruction of volume data
US20100268355A1 (en) * 2009-04-21 2010-10-21 Hon Hai Precision Industry Co., Ltd. Programming system for a coordinate measuring machine and method thereof
US20100299945A1 (en) * 2009-06-02 2010-12-02 James Richard Lacy System and method for workpiece coordinate measurements
US20110184695A1 (en) * 2008-10-29 2011-07-28 Renishaw Plc Measurement method
US20110268322A1 (en) * 2010-05-03 2011-11-03 Paul David Clausen Establishing coordinate systems for measurement
US8089689B1 (en) * 2006-11-30 2012-01-03 Lockheed Martin Corporation Apparatus and method for optical gain fiber having segments of differing core sizes
US20120154576A1 (en) * 2009-09-11 2012-06-21 Renishaw Plc Non-contact object inspection
US8520930B2 (en) * 2008-04-18 2013-08-27 3D Scanners Ltd. Method and computer program for improving the dimensional acquisition of an object
US8773700B2 (en) * 2011-03-07 2014-07-08 Kabushiki Kaisha Topcon Panoramic image preparing method and three-dimensional laser scanner
US8825427B2 (en) * 2007-11-20 2014-09-02 Carl Zeiss Industrielle Messtechnik Gmbh Method for calibrating a coordinate measuring machine
US8958654B1 (en) * 2001-04-25 2015-02-17 Lockheed Martin Corporation Method and apparatus for enhancing three-dimensional imagery data
US20150219451A1 (en) * 2012-08-16 2015-08-06 Hexagon Technology Center Gmbh Method and system for determining spatial coordinates with a mobile coordinate measuring machine

Patent Citations (61)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5471406A (en) * 1992-04-14 1995-11-28 Carl Zeiss-Stiftung Method of measuring elemental shapes of a workpiece on a coordinate measuring machine
US5471878A (en) 1993-09-27 1995-12-05 General Electric Company Method of suppressing grain noise in ultrasonic waveform data by 3D filtering
US5610846A (en) * 1994-05-27 1997-03-11 Carl Zeiss Stiftung Method for coordinate measurement on workpieces adjusted for bending of measuring apparatus structure
US6611617B1 (en) * 1995-07-26 2003-08-26 Stephen James Crampton Scanning apparatus and method
US6330523B1 (en) 1996-04-24 2001-12-11 Cyra Technologies, Inc. Integrated system for quickly and accurately imaging and modeling three-dimensional objects
US20020130873A1 (en) 1997-01-29 2002-09-19 Sharp Kabushiki Kaisha Method of processing animation by interpolation between key frames with small data quantity
US5936627A (en) 1997-02-28 1999-08-10 International Business Machines Corporation Method and system for performing perspective divide operations on three-dimensional graphical object data within a computer system
US6161079A (en) * 1997-08-18 2000-12-12 Giddings & Lewis, Llc Method and apparatus for determining tolerance and nominal measurement values for a coordinate measuring machine
US6765570B1 (en) 1998-07-21 2004-07-20 Magic Earth, Inc. System and method for analyzing and imaging three-dimensional volume data sets using a three-dimensional sampling probe
US6708138B1 (en) * 1998-08-28 2004-03-16 Mitutoyo Corporation Maintenance-and-control apparatus and method for coordinate and surface texture measuring device
US6359960B1 (en) 1999-08-03 2002-03-19 Siemens Aktiengesellschaft Method for identifying and locating markers in a 3D volume data set
US6788210B1 (en) * 1999-09-16 2004-09-07 The Research Foundation Of State University Of New York Method and apparatus for three dimensional surface contouring and ranging using a digital video projection system
US6720966B2 (en) 1999-12-23 2004-04-13 Siemens Aktiengesellschaft Method for reconstructing 3D image data with respect to a volume of interest of an examination subject
US20010027381A1 (en) * 2000-03-01 2001-10-04 Mitutoyo Corporation Method and apparatus for measuring geometry elements
US6778172B2 (en) 2000-09-14 2004-08-17 Minolta Co., Ltd. Method and apparatus for extracting surface from three-dimensional shape data as well as recording medium
US7620234B2 (en) 2000-10-06 2009-11-17 Canon Kabushiki Kaisha Image processing apparatus and method for generating a three-dimensional model of an object from a collection of images of the object recorded at different viewpoints and segmented using semi-automatic segmentation techniques
US7098908B2 (en) 2000-10-30 2006-08-29 Landmark Graphics Corporation System and method for analyzing and imaging three-dimensional volume data sets
US7502026B2 (en) 2000-10-30 2009-03-10 Landmark Graphics Corporation System and method for analyzing and imaging three-dimensional volume data sets
US7006085B1 (en) 2000-10-30 2006-02-28 Magic Earth, Inc. System and method for analyzing and imaging three-dimensional volume data sets
US7248258B2 (en) 2000-10-30 2007-07-24 Landmark Graphics Corporation System and method for analyzing and imaging three-dimensional volume data sets
US7805442B1 (en) 2000-12-05 2010-09-28 Navteq North America, Llc Method and system for representation of geographical features in a computer-based system
US6987878B2 (en) 2001-01-31 2006-01-17 Magic Earth, Inc. System and method for analyzing and imaging an enhanced three-dimensional volume data set using one or more attributes
US6690820B2 (en) 2001-01-31 2004-02-10 Magic Earth, Inc. System and method for analyzing and imaging and enhanced three-dimensional volume data set using one or more attributes
US8958654B1 (en) * 2001-04-25 2015-02-17 Lockheed Martin Corporation Method and apparatus for enhancing three-dimensional imagery data
US6914601B2 (en) 2001-06-12 2005-07-05 Minolta Co., Ltd. Method, apparatus, and computer program for generating three-dimensional shape data or volume data
US7024027B1 (en) 2001-11-13 2006-04-04 Koninklijke Philips Electronics N.V. Method and apparatus for three-dimensional filtering of angiographic volume data
US7088848B2 (en) 2002-02-15 2006-08-08 Siemens Aktiengesellschaft Method for the presentation of projection images or tomograms from 3D volume data of an examination volume
US20040028274A1 (en) 2002-08-09 2004-02-12 Celsys Co., Ltd. Method for generating vector data for a hand-drawn curve
US7061484B2 (en) 2002-11-27 2006-06-13 Voxar Limited User-interface and method for curved multi-planar reformatting of three-dimensional volume data sets
US7477261B2 (en) 2003-12-29 2009-01-13 Intel Corporation Method and mechanism for programmable filtering of texture map data in 3D graphics subsystems
US7133047B2 (en) 2003-12-29 2006-11-07 Intel Corporation Method and mechanism for programmable filtering of texture map data in 3D graphics subsystems
US7697010B2 (en) 2003-12-29 2010-04-13 Intel Corporation Method and mechanism for programmable filtering of texture map data in 3D graphics subsystems
US7492415B2 (en) 2004-02-05 2009-02-17 Broadcom Corporation Method and system for data compression for storage of 3D comb filter data
US7650023B2 (en) 2004-02-24 2010-01-19 Siemens Aktiengeśellschaft Method for filtering tomographic 3D images after completed reconstruction of volume data
US7327857B2 (en) * 2004-03-09 2008-02-05 General Electric Company Non-contact measurement method and apparatus
US20080075227A1 (en) * 2004-05-26 2008-03-27 Ralf Christoph Coordinate Measuring Apparatus And Method For Measuring An Object
US7372462B2 (en) 2005-03-14 2008-05-13 Ricoh Company, Ltd. Three-dimensional geometry processing system and method for CAD apparatus restricted in surface representations to import solid data
US7620023B2 (en) 2005-04-18 2009-11-17 Sierra Wireless, Inc. Configurable multislot class for wireless devices
US20090307916A1 (en) * 2005-04-25 2009-12-17 Renishaw Plc Method for scanning the surface of a workpiece
US7684613B2 (en) 2005-05-27 2010-03-23 Konica Minolta Sensing, Inc. Method and system for aligning three-dimensional shape data from photogrammetry data and three-dimensional measurement data using target locations and surface vectors
US20060273268A1 (en) 2005-06-07 2006-12-07 Inus Technology, Inc. Method for detecting 3D measurement data using allowable error zone
US7804988B2 (en) 2005-08-17 2010-09-28 Siemens Aktiengesellschaft Method for filtering of tomographic 3D displays on the basis of the reconstruction of volume data
US7653243B2 (en) 2005-10-14 2010-01-26 Siemens Medical Solutions Usa, Inc. System and method for 3D volume segmentation using exact minimal surfaces given a boundary
US8089689B1 (en) * 2006-11-30 2012-01-03 Lockheed Martin Corporation Apparatus and method for optical gain fiber having segments of differing core sizes
US20100079140A1 (en) 2006-12-11 2010-04-01 Koninklijke Philips Electronics N. V. Fibre tracking on the basis of macroscopic information
US20090027412A1 (en) 2007-07-23 2009-01-29 Disney Enterprises, Inc. Three-dimensional location-based texture transfers
US20090040530A1 (en) * 2007-08-06 2009-02-12 Vistec Semiconductor Systems Gmbh Coordinate measuring machine and a method for correcting non-linearities of the interferometers of a coordinate measuring machine
US20100142798A1 (en) * 2007-08-17 2010-06-10 Renishaw Plc Non-contact measurement apparatus and method
US8825427B2 (en) * 2007-11-20 2014-09-02 Carl Zeiss Industrielle Messtechnik Gmbh Method for calibrating a coordinate measuring machine
US7646672B2 (en) 2008-01-18 2010-01-12 Pgs Geophysical As Method for wavefield separation in 3D dual sensor towed streamer data with aliased energy in cross-streamer direction
US8520930B2 (en) * 2008-04-18 2013-08-27 3D Scanners Ltd. Method and computer program for improving the dimensional acquisition of an object
US20110184695A1 (en) * 2008-10-29 2011-07-28 Renishaw Plc Measurement method
US20100268355A1 (en) * 2009-04-21 2010-10-21 Hon Hai Precision Industry Co., Ltd. Programming system for a coordinate measuring machine and method thereof
US8255184B2 (en) * 2009-04-21 2012-08-28 Hong Fu Jin Precision Industry (Shenzhen) Co., Ltd. Programming system for a coordinate measuring machine and method thereof
US20100299945A1 (en) * 2009-06-02 2010-12-02 James Richard Lacy System and method for workpiece coordinate measurements
US20120154576A1 (en) * 2009-09-11 2012-06-21 Renishaw Plc Non-contact object inspection
CN101672637A (en) 2009-09-24 2010-03-17 华东理工大学 Digitizing detection method of complicated curved face
CN101692257A (en) 2009-09-25 2010-04-07 华东理工大学 Method for registering complex curved surface
US20110268322A1 (en) * 2010-05-03 2011-11-03 Paul David Clausen Establishing coordinate systems for measurement
US8773700B2 (en) * 2011-03-07 2014-07-08 Kabushiki Kaisha Topcon Panoramic image preparing method and three-dimensional laser scanner
US20150219451A1 (en) * 2012-08-16 2015-08-06 Hexagon Technology Center Gmbh Method and system for determining spatial coordinates with a mobile coordinate measuring machine

Non-Patent Citations (12)

* Cited by examiner, † Cited by third party
Title
"Exploit a 3D Dimensioning Analysis," Application Software for Analysis and Visualization of Industrial Computer Tomography/Voxel Data , Volume Graphics, 26 pages, Apr. 2010.
"Exploit a 3D Nominal/Actual Comparison," Application Software for Analysis and Visualization of Industrial Computer Tomography/Voxel Data, Volume Graphics, 21 pages, Apr. 2010.
"VGStudio MAX 2.1," Volume Graphics, 8 pages, 2010.
"Visualization Technology at its Best, VGStudio MAX," 3DScanning Technologies, 2 pages, vol. 1, No. 3,Dec. 2008.
Bliek, "Geometric Inspection of Small Components with CT-Scanners", InnovMetric Software, 7 pages, retrieved from the Internet May 2012.
Extended Supplementary European Search Report for International Application No. EP 12820824 dated Jan. 30, 2015.
Gong, Study of CMM Automatic Measurement Technology Based on Quasi-CAM Model. Chinese Excellent Master's theses. Text Database. Engineering Technology. Mar. 15, 2009;3:C030-12.
He, Key Technological Research on Processing of Scattered Point Clouds China Doctor Dissertation. Text Database, Information Technology Edition. Jun. 15, 2008;6:1138-46.
Hussain et al. ("Reverse Engineering: Point Cloud Generation With CMM for Part Modeling and Error Analysis", Asian Research Publishing Network, 2008, pp. 37-40). *
International Preliminary Report on Patentability and Written Opinion for International Application No. PCT/US2012/048522 dated Feb. 4, 2014.
Supplementary European Search Report from European Patent Application No. EP 12 82 0824 dated Jan. 30, 2015.
Zainuddin et al. ("From Laser Point Cloud to Surface: Data Reduction Procedure Test", Geoinformation Science Journal, 2009, pp. 1-9). *

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20180058843A1 (en) * 2016-08-26 2018-03-01 Keyence Corporation Three-Dimensional Measurement Device
US10508902B2 (en) * 2016-08-26 2019-12-17 Keyence Corporation Three-dimensional measurement device
US11162787B2 (en) * 2018-12-20 2021-11-02 Industrial Technology Research Institute Measuring program compiling device and measuring program compiling method

Also Published As

Publication number Publication date
AU2012290426A1 (en) 2014-02-20
BR112014002063A2 (en) 2017-02-21
WO2013019609A1 (en) 2013-02-07
CN103890766A (en) 2014-06-25
CA2843414A1 (en) 2013-02-07
KR20140066177A (en) 2014-05-30
US20130030773A1 (en) 2013-01-31
EP2737426B1 (en) 2019-04-03
JP2014527663A (en) 2014-10-16
EP2737426A4 (en) 2015-03-11
CN103890766B (en) 2017-10-10
EP2737426A1 (en) 2014-06-04

Similar Documents

Publication Publication Date Title
US9390202B2 (en) Coordinate measuring system data reduction
Shi et al. Adaptive simplification of point cloud using k-means clustering
Woo et al. A new segmentation method for point cloud data
KR102021945B1 (en) Determination of localised quality measurements from a volumetric image record
US9704293B2 (en) Finite element mesh customisation
Lalehpour et al. Adaptive data reduction with neighbourhood search approach in coordinate measurement of planar surfaces
KR101918168B1 (en) Method for performing 3D measurement and Apparatus thereof
US20160138914A1 (en) System and method for analyzing data
TW201349169A (en) Method for splicing point cloud
Senin et al. Characterisation of individual areal features
Mahboubkhah et al. An investigation on measurement accuracy of digitizing methods in turbine blade reverse engineering
CN111159800A (en) Method and device for automatically generating 3D model based on CAD file
US7333104B2 (en) Method and program of converting three-dimensional shape data into cell internal data
Mohib et al. Feature-based hybrid inspection planning: A mathematical programming approach
CN114076773A (en) Borehole detection method, borehole detection system and detection device
Zhang et al. Region segmentation and shape characterisation for tessellated CAD models
US8761515B2 (en) Electronic device and method for creating measurement codes
Sitnik et al. Optimized point cloud triangulation for 3D scanning systems
Sitnik et al. Segmentation of unsorted cloud of points data from full field optical measurement for metrological validation
KR102280668B1 (en) Method and system for dimensional quality inspectation
Navangul Stereolithography (STL) file modification by vertex translation algorithm (VTA) for precision layered manufacturing
CN113396441A (en) Computer-implemented method for determining a surface in measurement data
Gohari et al. Finding optimal correspondence sets for large digital metrology point clouds using anisotropic diffusion analogy
Minetola et al. Contactless inspection of castings: analysis of alignment procedures
US11335064B1 (en) System and processes for determining suitability of manufacturing processes from a digital 3D model of a product to be manufactured

Legal Events

Date Code Title Description
AS Assignment

Owner name: HEXAGON METROLOGY, INC., RHODE ISLAND

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:O'HARE, JONATHAN J.;REEL/FRAME:029135/0497

Effective date: 20121004

STCF Information on status: patent grant

Free format text: PATENTED CASE

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 4

AS Assignment

Owner name: HEXAGON METROLOGY, INC., RHODE ISLAND

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:O'HARE, JONATHAN;REEL/FRAME:058117/0832

Effective date: 20211015

AS Assignment

Owner name: HEXAGON METROLOGY, INC., RHODE ISLAND

Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE THE INVENTORS NAME PREVIOUSLY RECORDED AT REEL: 058117 FRAME: 832. ASSIGNOR(S) HEREBY CONFIRMS THE ASSIGNMENT;ASSIGNOR:O'HARE, JONATHAN J.;REEL/FRAME:060203/0274

Effective date: 20211015

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 8