WO2014193750A1 - Automatic detection of regular patterns of features - Google Patents

Automatic detection of regular patterns of features Download PDF

Info

Publication number
WO2014193750A1
WO2014193750A1 PCT/US2014/039315 US2014039315W WO2014193750A1 WO 2014193750 A1 WO2014193750 A1 WO 2014193750A1 US 2014039315 W US2014039315 W US 2014039315W WO 2014193750 A1 WO2014193750 A1 WO 2014193750A1
Authority
WO
WIPO (PCT)
Prior art keywords
pattern
points
data processing
processing system
indicated
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.)
Ceased
Application number
PCT/US2014/039315
Other languages
French (fr)
Inventor
Howard Charles Duncan Mattson
Douglas Joseph King
Daniel C. Staples
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.)
Siemens Industry Software Inc
Original Assignee
Siemens Product Lifecycle Management Software 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 Siemens Product Lifecycle Management Software Inc filed Critical Siemens Product Lifecycle Management Software Inc
Priority to CN202111523212.4A priority Critical patent/CN114186294A/en
Priority to EP14804913.3A priority patent/EP3005237B1/en
Priority to CN201480031126.3A priority patent/CN105229672A/en
Priority to RU2015156064A priority patent/RU2633167C2/en
Priority to JP2016516703A priority patent/JP6049944B2/en
Publication of WO2014193750A1 publication Critical patent/WO2014193750A1/en
Anticipated expiration legal-status Critical
Ceased legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06VIMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
    • G06V10/00Arrangements for image or video recognition or understanding
    • G06V10/40Extraction of image or video features
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06VIMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
    • G06V10/00Arrangements for image or video recognition or understanding
    • G06V10/40Extraction of image or video features
    • G06V10/44Local feature extraction by analysis of parts of the pattern, e.g. by detecting edges, contours, loops, corners, strokes or intersections; Connectivity analysis, e.g. of connected components
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T7/00Image analysis
    • G06T7/60Analysis of geometric attributes
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F18/00Pattern recognition
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T11/00Two-dimensional [2D] image generation
    • G06T11/20Drawing from basic elements

Definitions

  • Figure 2 illustrates a flowchart of a process in accordance with disclosed embodiments
  • Figure 3B illustrates the projection of the assigned points of features into a plane, in accordance with disclosed embodiments
  • Figure 4 illustrates an example of a set of 2D points corresponding to a geometric model that can be processed in accordance with disclosed embodiments
  • Figures 5A-5D illustrate examples of pattern indicators in accordance with disclosed embodiment
  • Figure 6 illustrates one technique for calculating the center for the circular indicator, in accordance with disclosed embodiments.
  • FIGS 7A-7J illustrate an example of the results and advantages of an iterative process as described herein.
  • FIGURES 1 through 7J discussed below, and the various embodiments used to describe the principles of the present disclosure in this patent document are by way of illustration only and should not be construed in any way to limit the scope of the disclosure. Those skilled in the art will understand that the principles of the present disclosure may be implemented in any suitably arranged device. The numerous innovative teachings of the present application will be described with reference to exemplary non-limiting embodiments.
  • CAD and other systems can maintain grids or patterns of features, which will be referred to generically as "patterns" herein.
  • patterns refer to a structured organization of features of a geometric model with respect to each other. These features can be any elements of a geometric model maintained in a PDM or other system.
  • Various systems include methods for patterns of features to be created and explicitly labeled and so function as part of the system.
  • models may contain implicit patterns, not explicitly labeled, and which cannot, therefore, function properly in the system. These may arise in many ways including but not limited to data imported from a different system, features within models generated in earlier versions of the system, models created via un-conventional, indirect or obscure methods, and others.
  • Disclosed embodiments include systems and methods for automatically recognizing rectangular, circular, and linear patterns between features of geometric models.
  • FIG. 1 illustrates a block diagram of a data processing system in which an embodiment can be implemented, for example as a CAD system particularly configured by software or otherwise to perform the processes as described herein, and in particular as each one of a plurality of interconnected and communicating systems as described herein.
  • the data processing system depicted includes a processor 102 connected to a level two cache/bridge 104, which is connected in turn to a local system bus 106.
  • Local system bus 106 may be, for example, a peripheral component interconnect (PCI) architecture bus.
  • PCI peripheral component interconnect
  • main memory 108 Also connected to local system bus in the depicted example are a main memory 108 and a graphics adapter 1 10.
  • the graphics adapter 1 10 may be connected to display 1 1 1.
  • Peripherals such as local area network (LAN) / Wide Area Network / Wireless (e.g. WiFi) adapter 1 12, may also be connected to local system bus 106.
  • Expansion bus interface 1 14 connects local system bus 106 to input/output (I/O) bus 1 16.
  • I/O bus 1 16 is connected to keyboard/mouse adapter 1 18, disk controller 120, and I/O adapter 122.
  • Disk controller 120 can be connected to a storage 126, which can be any suitable machine usable or machine readable storage medium, including but not limited to nonvolatile, hard-coded type mediums such as read only memories (ROMs) or erasable, electrically programmable read only memories (EEPROMs), magnetic tape storage, and user-recordable type mediums such as floppy disks, hard disk drives and compact disk read only memories (CD-ROMs) or digital versatile disks (DVDs), and other known optical, electrical, or magnetic storage devices.
  • ROMs read only memories
  • EEPROMs electrically programmable read only memories
  • CD-ROMs compact disk read only memories
  • DVDs digital versatile disks
  • a data processing system in accordance with an embodiment of the present disclosure includes an operating system employing a graphical user interface.
  • the operating system permits multiple display windows to be presented in the graphical user interface simultaneously, with each display window providing an interface to a different application or to a different instance of the same application.
  • a cursor in the graphical user interface may be manipulated by a user through the pointing device. The position of the cursor may be changed and/or an event, such as clicking a mouse button, generated to actuate a desired response.
  • One of various commercial operating systems such as a version of Microsoft WindowsTM, a product of Microsoft Corporation located in Redmond, Wash, may be employed if suitably modified.
  • the operating system is modified or created in accordance with the present disclosure as described.
  • Disclosed embodiments can analyze a geometric model including a plurality of features and automatically recognize patterns between the features.
  • Figure 2 illustrates a flowchart of a process in accordance with disclosed embodiments that may be performed, for example, by one or more CAD systems (referred to generically below as the "system"); other figures are used in the description below to illustrate aspects or examples of such a process.
  • CAD systems referred to generically below as the "system”
  • the system receives a set of two-dimensional 2D points representing at least a portion of a geometric model (205).
  • Receiving can include loading from storage, receiving from another device or process, receiving via an interaction with a user, preprocessing other data to produce the received data, or otherwise.
  • Figure 3B illustrates the projection of the assigned points of features 320 into a plane 322. Projected points 324 correspond to the location of the points on each of the features 320.
  • the system can then find rectangular, linear, circular, or other patterns within the points.
  • the system identifies the nearest "neighbor” points for each point in the set (210).
  • the term "neighbor,” as used herein, refers to one or more points closest to one or more points comprising a set of points.
  • the number of nearest neighbors identified for each point can depend on the "indicators” selected, as described below, or can include any number of neighbors.
  • Indicators, such as pattern indicators recognized by the system include but are not limited to, rectangular pattern indicators, linear pattern indicators, circular pattern indicators, and skew pattern indicators; other pattern indicators are contemplated.
  • the identification process 210 can include determining the distance and direction (together, the vector) from each point to its neighbor points.
  • the system finds indicated patterns among the set of points (215). For each point in the set, the system determines whether it and its nearest neighbors indicate any patterns. Note that a single point can indicate multiple pattern types. The system can receive a user selection of pattern indicators to apply so that only certain types of patterns are identified or can apply any or all pattern indicators. [0040] The pattern indicators indicate a pattern among the points. Each point is checked against its nearest neighbors to see if it indicates a pattern. If it does then the information about this pattern (e.g. type, spacing, directions) can be stored together with an identification of the point that first indicated it (origin), as described below.
  • This pattern e.g. type, spacing, directions
  • Figures 5A-5D illustrate examples of pattern indicators in accordance with disclosed embodiment. These indicators are not limiting, and other indicators of patterns between points can be used.
  • Fig. 5A illustrates an example of a rectangular pattern indicator.
  • point P is the point being processed.
  • the vectors A and B from P to its nearest neighbors are found.
  • Vectors A and B are orthogonal (90 degrees) to each other, and form an example of a rectangular pattern indicator.
  • regular distances can include multiples of a regular distance without a point at each interval. For example, this is intended to include the case where a first neighboring point is at a distance X, and the next point in the pattern, in the same direction, is at distance 4X, even if there were no points in the set at distances 2X or 3X.
  • Fig. 5B illustrates an example of a linear pattern indicator.
  • point P is the point being processed.
  • the vectors A and B from P to its nearest neighbors are found.
  • Vectors A and B are linear (180 degrees, in line) to each other and of equal magnitude, and form an example of a linear pattern indicator.
  • the linear pattern can therefore be identified by a plurality of points in the set at regular distances from and in line with the given point P within a 2D plane.
  • Fig. 5C illustrates an example of a circular pattern indicator.
  • point P is the point being processed.
  • the vectors A and B from P to its nearest neighbors are found.
  • Vectors A and B are the same magnitude as each other; that is, the neighbor points to P are of equal distance from P.
  • the system can calculate the center C, radius r, and angle ⁇ between successive pattern elements with respect to the center of an indicated pattern from the points A, B, and P.
  • a circular pattern can therefore be identified by a plurality of points in the set at regular distances from each other and that each lie along an arc of a circle with a common center C (though the circle and its center are not part of the points or the model).
  • Fig. 5D illustrates an example of a "skew" pattern indicator.
  • Skew patterns are a natural extension of rectangular patterns where the angle between the directions is varied from 90 degrees, so the vectors are not orthogonal to each other.
  • a skew pattern can be identified by a plurality of points in the set at regular distances from and in line with a given point in two directions within the 2D plane.
  • point P is the point being processed.
  • the vectors A and B from P to its nearest neighbors are found.
  • Vectors A and B are not orthogonal to each other, and form an example of a skew pattern indicator.
  • a skew pattern can be identified by a plurality of points in the set at regular distances from and in line with a given point in two directions within the 2D plane..
  • Figure 6 illustrates one technique for calculating the center C for the circular indicator, given point P, vector A from point P to neighboring point P2, and vector B from point P to neighboring point PI .
  • the system can define a line PLl as the bisector of vector B at midpoint ml , orthogonal to vector B.
  • the system can define a line PL2 as the bisector of vector A at midpoint m2, orthogonal to vector A.
  • the center C of the circle pattern is the intersection of PLl and PL2.
  • the system can store x and y spacing, and x and y directions.
  • the first point that indicated this pattern can be used as the origin (which is stored as origin for the first point).
  • Rectangular patterns indicate the same pattern as a previous pattern when their respective patterns fall on one another, so x and y spacing is equal, x and y directions parallel respectively (and orthogonal to each other), and the origin of each lies on the pattern of the other.
  • the system can store spacing, direction and origin.
  • the first point that indicated this pattern can be used as the origin (which is stored as origin for the first point).
  • Linear patterns indicate the same pattern as a previous pattern when their respective patterns fall on one another, so the spacing between points is equal, the vector directions are parallel, and the origin of each lies on the pattern of the other.
  • the system can store center, angular spacing, direction, and origin.
  • the first point that indicated this pattern can be used as the origin (which is stored as origin for the first point).
  • Circular patterns indicate the same pattern as a previous pattern when their respective patterns fall on one another, so the angle spacings ⁇ are equal, the centers C are equal, the radii r (center to origin distance) are equal, and the origin of each lies on the pattern of the other.
  • the circular pattern does not require a full "set" of points to complete a circle.
  • the system can consolidate found linear patterns into rectangular patterns (220).
  • the pattern-finding process can occasionally generate what would ideally be rectangular patterns as individual linear patterns. In such cases, the system can correct this and combine such cases into rectangular patterns.
  • the system can select a primary pattern (225). From all indicated patterns, at this stage, the system can select a primary pattern.
  • the primary pattern can be selected from the indicated patterns in various ways to meet particular demands. For example, one criterion for selecting the primary pattern can be the pattern containing the largest number of points. In many cases, when selecting a primary pattern, any indicated patterns with three points or less are ignored.
  • Figure 7C illustrates an example of the remaining set of points after the rectangular pattern identified in the first iteration (as illustrated in Fig. 7B) are removed from the input set of points after the first iteration. These remaining points 704 are input to the second iteration. Note that, for illustrative purposes, the features or points for the pattern are actually removed from the illustrated model; in a typical implementation, however, these features or points only removed from consideration in the data, and are not included in the set of points passed to the next iteration of the process.
  • Figure 7E illustrates an example of the remaining set of points after the rectangular pattern identified in the second iteration (as illustrated in Fig. 7D) are also removed from the set of points being processed. These remaining points are input to the third iteration.
  • Figure 7J illustrates an example of a circular pattern identified in the fifth iteration of a process as described herein, such as illustrated at 712. Note that this pattern may not have been identified in the first iteration because the now-removed points obscured the pattern when processed as neighboring points.
  • the system can first find rectangular and circular patterns, remove them from the input set of points, and then search for linear pattern in remaining data in a subsequent iteration.

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Multimedia (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Geometry (AREA)
  • General Engineering & Computer Science (AREA)
  • Evolutionary Computation (AREA)
  • Computer Hardware Design (AREA)
  • Processing Or Creating Images (AREA)
  • Image Analysis (AREA)
  • User Interface Of Digital Computer (AREA)
  • Image Processing (AREA)
  • Architecture (AREA)
  • Software Systems (AREA)

Abstract

Methods for pattern recognition and corresponding systems and computer-readable mediums. A method includes receiving (205) a set of two-dimensional points (400). The method includes identifying (210) neighbor points for each of a plurality of points in the set and finding (215) at least one indicated pattern between points in the set. The indicated pattern can be one of a linear pattern (710), a rectangular pattern (702), a skew pattern, or a circular pattern (708, 712). The method includes storing (230) pattern data corresponding to the found indicated pattern.

Description

AUTOMATIC DETECTION OF REGULAR PATTERNS OF FEATURES
TECHNICAL FIELD
[0001] The present disclosure is directed, in general, to computer-aided design, visualization, and manufacturing systems, product lifecycle management ("PLM") systems, and similar systems, that manage data for products and other items (collectively, "Product Data Management" systems or PDM systems).
BACKGROUND OF THE DISCLOSURE
[0002] Computer-aided design systems ("CAD systems") enable users to design and visualize model objects. Improved systems are desirable.
SUMMARY OF THE DISCLOSURE
[0003] Various disclosed embodiments include methods for pattern recognition and corresponding systems and computer-readable mediums. A method includes receiving a set of two-dimensional (2D) points. The method includes identifying neighbor points for each of a plurality of points in the set and finding at least one indicated pattern between points in the set. The indicated pattern can be one of a linear pattern identified by a plurality of points in the set at regular distances from and in line with a given point within a 2D plane, a rectangular pattern identified by a plurality of points in the set at regular distances from a given point in orthogonal directions, a skew pattern identified by a plurality of points in the set at regular distances from and in line with a given point in two directions within the 2D plane, or a circular pattern identified by a plurality of points in the set at regular distances from each other and that each lie along an arc of a circle with a common center. The method includes storing pattern data corresponding to the found indicated pattern.
[0004] The foregoing has outlined rather broadly the features and technical advantages of the present disclosure so that those skilled in the art may better understand the detailed description that follows. Additional features and advantages of the disclosure will be described hereinafter that form the subject of the claims. Those skilled in the art will appreciate that they may readily use the conception and the specific embodiment disclosed as a basis for modifying or designing other structures for carrying out the same purposes of the present disclosure. Those skilled in the art will also realize that such equivalent constructions do not depart from the spirit and scope of the disclosure in its broadest form.
[0005] Before undertaking the DETAILED DESCRIPTION below, it may be advantageous to set forth definitions of certain words or phrases used throughout this patent document: the terms "include" and "comprise," as well as derivatives thereof, mean inclusion without limitation; the term "or" is inclusive, meaning and/or; the phrases "associated with" and "associated therewith," as well as derivatives thereof, may mean to include, be included within, interconnect with, contain, be contained within, connect to or with, couple to or with, be communicable with, cooperate with, interleave, juxtapose, be proximate to, be bound to or with, have, have a property of, or the like; and the term "controller" means any device, system or part thereof that controls at least one operation, whether such a device is implemented in hardware, firmware, software or some combination of at least two of the same. It should be noted that the functionality associated with any particular controller may be centralized or distributed, whether locally or remotely. Definitions for certain words and phrases are provided throughout this patent document, and those of ordinary skill in the art will understand that such definitions apply in many, if not most, instances to prior as well as future uses of such defined words and phrases. While some terms may include a wide variety of embodiments, the appended claims may expressly limit these terms to specific embodiments.
BRIEF DESCRIPTION OF THE DRAWINGS
[0006] For a more complete understanding of the present disclosure, and the advantages thereof, reference is now made to the following descriptions taken in conjunction with the accompanying drawings, wherein like numbers designate like objects, and in which:
[0007] Figure 1 illustrates a block diagram of a data processing system in which an embodiment can be implemented;
[0008] Figure 2 illustrates a flowchart of a process in accordance with disclosed embodiments;
[0009] Figure 3A illustrates a model that includes a plurality of 3D features two different basic feature types, in accordance with disclosed embodiments;
[0010] Figure 3B illustrates the projection of the assigned points of features into a plane, in accordance with disclosed embodiments;
[0011] Figure 4 illustrates an example of a set of 2D points corresponding to a geometric model that can be processed in accordance with disclosed embodiments;
[0012] Figures 5A-5D illustrate examples of pattern indicators in accordance with disclosed embodiment;
[0013] Figure 6 illustrates one technique for calculating the center for the circular indicator, in accordance with disclosed embodiments; and
[0014] Figures 7A-7J illustrate an example of the results and advantages of an iterative process as described herein. DETAILED DESCRIPTION
[0015] FIGURES 1 through 7J, discussed below, and the various embodiments used to describe the principles of the present disclosure in this patent document are by way of illustration only and should not be construed in any way to limit the scope of the disclosure. Those skilled in the art will understand that the principles of the present disclosure may be implemented in any suitably arranged device. The numerous innovative teachings of the present application will be described with reference to exemplary non-limiting embodiments.
[0016] CAD and other systems can maintain grids or patterns of features, which will be referred to generically as "patterns" herein. These patterns, as used herein refer to a structured organization of features of a geometric model with respect to each other. These features can be any elements of a geometric model maintained in a PDM or other system. Various systems include methods for patterns of features to be created and explicitly labeled and so function as part of the system.
[0017] However, many models may contain implicit patterns, not explicitly labeled, and which cannot, therefore, function properly in the system. These may arise in many ways including but not limited to data imported from a different system, features within models generated in earlier versions of the system, models created via un-conventional, indirect or obscure methods, and others.
[0018] Disclosed embodiments include systems and methods for automatically recognizing rectangular, circular, and linear patterns between features of geometric models.
[0019] Figure 1 illustrates a block diagram of a data processing system in which an embodiment can be implemented, for example as a CAD system particularly configured by software or otherwise to perform the processes as described herein, and in particular as each one of a plurality of interconnected and communicating systems as described herein. The data processing system depicted includes a processor 102 connected to a level two cache/bridge 104, which is connected in turn to a local system bus 106. Local system bus 106 may be, for example, a peripheral component interconnect (PCI) architecture bus. Also connected to local system bus in the depicted example are a main memory 108 and a graphics adapter 1 10. The graphics adapter 1 10 may be connected to display 1 1 1.
[0020] Other peripherals, such as local area network (LAN) / Wide Area Network / Wireless (e.g. WiFi) adapter 1 12, may also be connected to local system bus 106. Expansion bus interface 1 14 connects local system bus 106 to input/output (I/O) bus 1 16. I/O bus 1 16 is connected to keyboard/mouse adapter 1 18, disk controller 120, and I/O adapter 122. Disk controller 120 can be connected to a storage 126, which can be any suitable machine usable or machine readable storage medium, including but not limited to nonvolatile, hard-coded type mediums such as read only memories (ROMs) or erasable, electrically programmable read only memories (EEPROMs), magnetic tape storage, and user-recordable type mediums such as floppy disks, hard disk drives and compact disk read only memories (CD-ROMs) or digital versatile disks (DVDs), and other known optical, electrical, or magnetic storage devices.
[0021] Also connected to I/O bus 1 16 in the example shown is audio adapter 124, to which speakers (not shown) may be connected for playing sounds. Keyboard/mouse adapter 1 18 provides a connection for a pointing device (not shown), such as a mouse, trackball, trackpointer, touchpad, etc.
[0022] Those of ordinary skill in the art will appreciate that the hardware depicted in Figure 1 may vary for particular implementations. For example, other peripheral devices, such as an optical disk drive and the like, also may be used in addition or in place of the hardware depicted. The depicted example is provided for the purpose of explanation only and is not meant to imply architectural limitations with respect to the present disclosure.
[0023] A data processing system in accordance with an embodiment of the present disclosure includes an operating system employing a graphical user interface. The operating system permits multiple display windows to be presented in the graphical user interface simultaneously, with each display window providing an interface to a different application or to a different instance of the same application. A cursor in the graphical user interface may be manipulated by a user through the pointing device. The position of the cursor may be changed and/or an event, such as clicking a mouse button, generated to actuate a desired response.
[0024] One of various commercial operating systems, such as a version of Microsoft Windows™, a product of Microsoft Corporation located in Redmond, Wash, may be employed if suitably modified. The operating system is modified or created in accordance with the present disclosure as described.
[0025] LAN/ WAN/Wireless adapter 1 12 can be connected to a network 130 (not a part of data processing system 100), which can be any public or private data processing system network or combination of networks, as known to those of skill in the art, including the Internet. Data processing system 100 can communicate over network 130 with server system 140, which is also not part of data processing system 100, but can be implemented, for example, as a separate data processing system 100.
[0026] Disclosed embodiments can analyze a geometric model including a plurality of features and automatically recognize patterns between the features. Figure 2 illustrates a flowchart of a process in accordance with disclosed embodiments that may be performed, for example, by one or more CAD systems (referred to generically below as the "system"); other figures are used in the description below to illustrate aspects or examples of such a process.
[0027] The system receives a set of two-dimensional 2D points representing at least a portion of a geometric model (205). Receiving, as used herein, can include loading from storage, receiving from another device or process, receiving via an interaction with a user, preprocessing other data to produce the received data, or otherwise.
[0028] A process in accordance with disclosed embodiments can take as input a simple set of 2D points. The raw input from a model can alternately be either 2D or three- dimensional (3D) features, and as part of 205, the system can obtain a consistent representative point for each of the features, as described in more detail below with reference to Figs. 3A and 3B. [0029] Figure 3A illustrates a model 300 that includes a plurality of 3D features of two different basic feature types (shapes). For each of the feature types, the system can assign a consistent point on the feature type and an orientation vector for the feature. For example, feature 302 is a specific feature type with a specific shape; the system assigns a point 304 at the same location on each of these shapes, and assigns an orientation vector 306, originating at the point 304, that indicates the orientation of each shape. The original assignment of the point and vector on the first one of any given feature type can be arbitrary, and the remaining assignments for identical feature types are assigned relative to the first one of that type.
[0030] For features whose points are not already in 2D space, the system can convert the points into 2D space by projecting onto a common plane. Figure 3B illustrates the projection of the assigned points of features 320 into a plane 322. Projected points 324 correspond to the location of the points on each of the features 320.
[0031] Features in the model will likely have many different types, shapes, sizes, orientations and, in 3D, heights from plane. Any, some, or all of these variables, plus others, can be used to pre-divide the input.
[0032] For example, if features of different types should not be considered for inclusion into a pattern, then they can be divided out and can be passed to separate and distinct calls to the detection process. That is, where only patterns among common feature types should be identified, then the detection processes described herein can be separately executed, sequentially or in parallel for each of the different feature types. For example, in the context of Fig. 3A, the process can be performed once for all features of the same feature type as feature 302, and can be performed a second time for all features of the same feature type as feature 308.
[0033] As another example, if only features of a particular orientation are of interest then they can be grouped, and each orientation group (or only the orientation group of interest) can be separately put through the detection process. For example, in the context of Fig. 3A, the process can be performed for just features of the same vertical orientation as feature 308, and not on features of a different orientation, such as feature 310. [0034] When features are grouped, included, or excluded as described herein, the corresponding 2D projected points can be grouped, included, or excluded accordingly for the detection process.
[0035] The examples above serve only as illustrations. Any features that can be processed into a set of 2D points in any way can be handled by techniques disclosed herein, and any such processes are intended to be included as part of receiving the set of 2D points.
[0036] The system can then find rectangular, linear, circular, or other patterns within the points.
[0037] Figure 4 illustrates an example of a set of 2D points 400 corresponding to a geometric model (2D, or 3D via a projection technique such as described above) that can be processed in accordance with disclosed embodiments after being received. The system can detect patterns among the 2D points.
[0038] Returning to the process of Fig. 2, the system identifies the nearest "neighbor" points for each point in the set (210). The term "neighbor," as used herein, refers to one or more points closest to one or more points comprising a set of points. The number of nearest neighbors identified for each point can depend on the "indicators" selected, as described below, or can include any number of neighbors. Indicators, such as pattern indicators recognized by the system, include but are not limited to, rectangular pattern indicators, linear pattern indicators, circular pattern indicators, and skew pattern indicators; other pattern indicators are contemplated. The identification process 210 can include determining the distance and direction (together, the vector) from each point to its neighbor points.
[0039] The system then finds indicated patterns among the set of points (215). For each point in the set, the system determines whether it and its nearest neighbors indicate any patterns. Note that a single point can indicate multiple pattern types. The system can receive a user selection of pattern indicators to apply so that only certain types of patterns are identified or can apply any or all pattern indicators. [0040] The pattern indicators indicate a pattern among the points. Each point is checked against its nearest neighbors to see if it indicates a pattern. If it does then the information about this pattern (e.g. type, spacing, directions) can be stored together with an identification of the point that first indicated it (origin), as described below.
[0041] Figures 5A-5D illustrate examples of pattern indicators in accordance with disclosed embodiment. These indicators are not limiting, and other indicators of patterns between points can be used.
[0042] Fig. 5A illustrates an example of a rectangular pattern indicator. In this example, point P is the point being processed. The vectors A and B from P to its nearest neighbors are found. Vectors A and B are orthogonal (90 degrees) to each other, and form an example of a rectangular pattern indicator. A rectangular pattern identified by a plurality of points in the set at regular distances from the given point P in orthogonal directions. Note that "regular distances," as used herein, can include multiples of a regular distance without a point at each interval. For example, this is intended to include the case where a first neighboring point is at a distance X, and the next point in the pattern, in the same direction, is at distance 4X, even if there were no points in the set at distances 2X or 3X.
[0043] Fig. 5B illustrates an example of a linear pattern indicator. In this example, point P is the point being processed. The vectors A and B from P to its nearest neighbors are found. Vectors A and B are linear (180 degrees, in line) to each other and of equal magnitude, and form an example of a linear pattern indicator. The linear pattern can therefore be identified by a plurality of points in the set at regular distances from and in line with the given point P within a 2D plane.
[0044] Fig. 5C illustrates an example of a circular pattern indicator. In this example, point P is the point being processed. The vectors A and B from P to its nearest neighbors are found. Vectors A and B are the same magnitude as each other; that is, the neighbor points to P are of equal distance from P. The system can calculate the center C, radius r, and angle Θ between successive pattern elements with respect to the center of an indicated pattern from the points A, B, and P. A circular pattern can therefore be identified by a plurality of points in the set at regular distances from each other and that each lie along an arc of a circle with a common center C (though the circle and its center are not part of the points or the model).
[0045] Fig. 5D illustrates an example of a "skew" pattern indicator. Skew patterns are a natural extension of rectangular patterns where the angle between the directions is varied from 90 degrees, so the vectors are not orthogonal to each other. A skew pattern can be identified by a plurality of points in the set at regular distances from and in line with a given point in two directions within the 2D plane. In this example, point P is the point being processed. The vectors A and B from P to its nearest neighbors are found. Vectors A and B are not orthogonal to each other, and form an example of a skew pattern indicator. A skew pattern can be identified by a plurality of points in the set at regular distances from and in line with a given point in two directions within the 2D plane..
[0046] Figure 6 illustrates one technique for calculating the center C for the circular indicator, given point P, vector A from point P to neighboring point P2, and vector B from point P to neighboring point PI . The system can define a line PLl as the bisector of vector B at midpoint ml , orthogonal to vector B. The system can define a line PL2 as the bisector of vector A at midpoint m2, orthogonal to vector A. The center C of the circle pattern is the intersection of PLl and PL2.
[0047] There are two types of circular patterns indicated by various embodiments - open circular patterns and closed circular patterns. They are both indicated by the same indicator form but importantly the angle Θ for closed patterns must be a value that divides 360 degrees (i.e. 360° = N* angle Θ, where N is natural number). That is, the angle between points on a "closed" circular pattern divides evenly into 360 degrees, so that the set of points in the closed circular pattern would be evenly spaced on the circumference of the implied circle if there were enough points to complete the circle. An "open" circular pattern has no such requirement; the angle Θ is not evenly divisible into 360 degrees, and though the actual points in the set are evenly spaced on the implied circle, if there were enough points to complete the circle, then at least two of them could not be evenly spaced. [0048] Returning to the process illustrated in Fig. 2, as part of finding indicated patterns at 215, for each type of pattern indicated by a given point (if any), the system can check whether this pattern has already been indicated by comparing indicated patterns. If the pattern has not already been indicated, the system can store the newly- found pattern, such as by adding to a list of indicated patterns the following data and comparing the data to determine that the pattern is already indicated:
• For rectangular patterns, the system can store x and y spacing, and x and y directions. The first point that indicated this pattern can be used as the origin (which is stored as origin for the first point). Rectangular patterns indicate the same pattern as a previous pattern when their respective patterns fall on one another, so x and y spacing is equal, x and y directions parallel respectively (and orthogonal to each other), and the origin of each lies on the pattern of the other.
• For linear patterns, the system can store spacing, direction and origin. The first point that indicated this pattern can be used as the origin (which is stored as origin for the first point). Linear patterns indicate the same pattern as a previous pattern when their respective patterns fall on one another, so the spacing between points is equal, the vector directions are parallel, and the origin of each lies on the pattern of the other.
• For circular patterns, the system can store center, angular spacing, direction, and origin. The first point that indicated this pattern can be used as the origin (which is stored as origin for the first point). Circular patterns indicate the same pattern as a previous pattern when their respective patterns fall on one another, so the angle spacings Θ are equal, the centers C are equal, the radii r (center to origin distance) are equal, and the origin of each lies on the pattern of the other. The circular pattern does not require a full "set" of points to complete a circle.
[0049] If the current indicated pattern is the same as a previously found indicated pattern, then the system can increment the count of this indicated pattern.
[0050] The system can consolidate found linear patterns into rectangular patterns (220). The pattern-finding process can occasionally generate what would ideally be rectangular patterns as individual linear patterns. In such cases, the system can correct this and combine such cases into rectangular patterns.
[0051] The system can select a primary pattern (225). From all indicated patterns, at this stage, the system can select a primary pattern. The primary pattern can be selected from the indicated patterns in various ways to meet particular demands. For example, one criterion for selecting the primary pattern can be the pattern containing the largest number of points. In many cases, when selecting a primary pattern, any indicated patterns with three points or less are ignored.
[0052] The system can store pattern data including the associated points (230). This can include marking, labeling, or otherwise associating with the patterns, including any primary pattern, all the points from the set that match the primary pattern, and with any 2D or 3D features that were used to produce the set of points, and storing this pattern data. This can include removing all points that correspond to the primary pattern, or from all found patterns, from the set of points. In various embodiments, all points that correspond to found patterns can be removed, or only points that correspond to the primary pattern can be removed. All of the points that match the patterns, in either of these cases, can be removed from the set of points currently being processed, so that additional patterns can be found that do not include the points already associated with the primary pattern or other found patterns.
[0053] The system can repeat the process to 210, now processing only the remaining points in the set, to find another other patterns. That is, once the points in the first primary pattern or all found patterns are removed from the set, the system can repeat the process using only the remaining points, beginning with finding the nearest neighbors to each remaining point.
[0054] Figures 7A-7J illustrate an example of the results and some advantages of an iterative process as described herein; other advantages exist. Figure 7A illustrates an example of an input set of points for the first iteration of a process as described herein. [0055] Figure 7B illustrates an example of a rectangular pattern identified in the first iteration of a process as described herein, such as illustrated at 702.
[0056] After these patterns have been identified in the first iteration, all the points in these patterns are removed from the original set of points, and the remaining points are processed in a second iteration.
[0057] Figure 7C illustrates an example of the remaining set of points after the rectangular pattern identified in the first iteration (as illustrated in Fig. 7B) are removed from the input set of points after the first iteration. These remaining points 704 are input to the second iteration. Note that, for illustrative purposes, the features or points for the pattern are actually removed from the illustrated model; in a typical implementation, however, these features or points only removed from consideration in the data, and are not included in the set of points passed to the next iteration of the process.
[0058] Figure 7D illustrates an example of a rectangular pattern identified in the second iteration of a process as described herein, such as illustrated at 706. Note that this pattern may not have been identified in the first iteration because the now-removed points obscured the pattern when processed as neighboring points.
[0059] Figure 7E illustrates an example of the remaining set of points after the rectangular pattern identified in the second iteration (as illustrated in Fig. 7D) are also removed from the set of points being processed. These remaining points are input to the third iteration.
[0060] Figure 7F illustrates an example of a circular pattern identified in the third iteration of a process as described herein, such as illustrated at 708. Note that this pattern may not have been identified in the first iteration because the now-removed points obscured the pattern when processed as neighboring points.
[0061] Figure 7G illustrates an example of the remaining set of points after the circular pattern identified in the third iteration (as illustrated in Fig. 7F) are also removed from the set of points being processed. These remaining points are input to the fourth iteration. [0062] Figure 7H illustrates an example of a linear pattern identified in the fourth iteration of a process as described herein, such as illustrated at 710. Note that this pattern may not have been identified in the first iteration because the now-removed points obscured the pattern when processed as neighboring points.
[0063] Figure 71 illustrates an example of the remaining set of points after the linear pattern identified in the fourth iteration (as illustrated in Fig. 7H) are also removed from the set of points being processed. These remaining points are input to the fifth iteration.
[0064] Figure 7J illustrates an example of a circular pattern identified in the fifth iteration of a process as described herein, such as illustrated at 712. Note that this pattern may not have been identified in the first iteration because the now-removed points obscured the pattern when processed as neighboring points.
[0065] Other embodiments include variations on the specific techniques disclosed above. For example, a "linear" pattern could alternatively be represented as a rectangular pattern with Y count equal to one and y-spacing equal to zero. In some embodiments, all the points can be stored in a tree structure, which makes finding the closest neighbors much faster.
[0066] In some embodiments, to prevent finding of all the possible linear patterns within rectangular patterns, the system can first find rectangular and circular patterns, remove them from the input set of points, and then search for linear pattern in remaining data in a subsequent iteration.
[0067] Of course, those of skill in the art will recognize that, unless specifically indicated or required by the sequence of operations, certain steps in the processes described above may be omitted, performed concurrently or sequentially, or performed in a different order.
[0068] Those skilled in the art will recognize that, for simplicity and clarity, the full structure and operation of all data processing systems suitable for use with the present disclosure is not being depicted or described herein. Instead, only so much of a data processing system as is unique to the present disclosure or necessary for an understanding of the present disclosure is depicted and described. The remainder of the construction and operation of data processing system 100 may conform to any of the various current implementations and practices known in the art.
[0069] It is important to note that while the disclosure includes a description in the context of a fully functional system, those skilled in the art will appreciate that at least portions of the mechanism of the present disclosure are capable of being distributed in the form of instructions contained within a machine -usable, computer-usable, or computer- readable medium in any of a variety of forms, and that the present disclosure applies equally regardless of the particular type of instruction or signal bearing medium or storage medium utilized to actually carry out the distribution. Examples of machine usable/readable or computer usable/readable mediums include: nonvolatile, hard-coded type mediums such as read only memories (ROMs) or erasable, electrically programmable read only memories (EEPROMs), and user-recordable type mediums such as floppy disks, hard disk drives and compact disk read only memories (CD-ROMs) or digital versatile disks (DVDs).
[0070] Although an exemplary embodiment of the present disclosure has been described in detail, those skilled in the art will understand that various changes, substitutions, variations, and improvements disclosed herein may be made without departing from the spirit and scope of the disclosure in its broadest form.
[0071] None of the description in the present application should be read as implying that any particular element, step, or function is an essential element which must be included in the claim scope: the scope of patented subject matter is defined only by the allowed claims. Moreover, none of these claims are intended to invoke paragraph six of 35 USC § 1 12 unless the exact words "means for" are followed by a participle.

Claims

CLAIMS:
1. A method for pattern recognition, the method performed by a data processing system (100) and comprising:
receiving (205) a set of two-dimensional points (400) by the data processing
system - two-dimensional in the following denoted by 2D -; identifying (210) neighbor points for each of a plurality of points in the set, by the data processing system;
finding (215) at least one indicated pattern between points in the set, by the data processing system, wherein the indicated pattern is one of a linear pattern (710) identified by a plurality of points in the set at regular distances from and in line with a given point (P) within a 2D plane, a rectangular pattern (702) identified by a plurality of points in the set at regular distances from a given point (P) in orthogonal directions, a skew pattern identified by a plurality of points in the set at regular distances from and in line with a given point (P) in two directions within the 2D plane, or
a circular pattern (708, 712) identified by a plurality of points in the set at regular distances from each other and that each lie along an arc of a circle with a common center (C); and
storing (230) pattern data corresponding to the found indicated pattern.
2. The method of claim 1, wherein the data processing system also converts 2D or three-dimensional features (320) into the set of 2D points.
3. The method of claim 1 or 2, wherein the data processing system consolidates (220) multiple linear patterns into a rectangular pattern.
4. The method of any of claims 1 to 3, wherein points corresponding to the found indicated pattern are removed from the set of 2D points, and the data processing system repeats identifying, finding, and storing.
5. The method of any of claims 1 to 4, wherein the data processing system receives a user selection of the indicated pattern to find.
6. The method of any of claims 1 to 5, wherein the data processing system
determines a distance and direction between each point in the set and each neighbor point to the point in the set.
7. The method of any of claims 1 to 6, wherein the data processing system finds multiple indicated patterns, and selects (225) a primary pattern from the multiple found indicated patterns.
8. A data processing system (100) comprising:
a processor (102); and
an accessible memory (108), the data processing system particularly configured to receive (205) a set of two-dimensional points (400) - two-dimensional in the following denoted by 2D -;
identify (210) neighbor points for each of a plurality of points (400) in the set; find (215) at least one indicated pattern between points in the set, wherein the indicated pattern is one of
a linear pattern (710) identified by a plurality of points in the set at regular distances from and in line with a given point (P) within a 2D plane, a rectangular pattern (702) identified by a plurality of points in the set at regular distances from a given point (P) in orthogonal directions, a skew pattern identified by a plurality of points in the set at regular distances from and in line with a given point (P) in two directions within the 2D plane, or
a circular pattern (708, 712) identified by a plurality of points in the set at regular distances from each other and that each lie along an arc of a circle with a common center (C); and
store (230) pattern data corresponding to the found indicated pattern.
9. The data processing system of claim 8, wherein the data processing system also converts 2D or three-dimensional features (320) into the set of 2D points.
10. The data processing system of claim 8 or 9, wherein the data processing system consolidates (220) multiple linear patterns into a rectangular pattern.
11. The data processing system of any of claims 8 to 10, wherein points
corresponding to the found indicated pattern are removed from the set of 2D points, and the data processing system repeats identifying, finding, and storing.
12. The data processing system of any of claims 8 to 1 1, wherein the data processing system receives a user selection of the indicated pattern to find.
13. The data processing system of any of claims 8 to 12, wherein the data processing system determines a distance and direction between each point in the set and each neighbor point to the point in the set.
14. The data processing system of any of claims 8 to 13, wherein the data processing system finds multiple indicated patterns, and selects (225) a primary pattern from the multiple found indicated patterns.
15. A non-transitory computer-readable medium (126) encoded with executable
instructions that, when executed, cause one or more data processing systems (100) to:
receive (205) a set of two-dimensional points (400) - two-dimensional in the following denoted by 2D -;
identify (210) neighbor points for each of a plurality of points (400) in the set; find (215) at least one indicated pattern between points in the set, wherein the indicated pattern is one of
a linear pattern (710) identified by a plurality of points in the set at regular distances from and in line with a given point (P) within a 2D plane, a rectangular pattern (702) identified by a plurality of points in the set at regular distances from a given point (P) in orthogonal directions, a skew pattern identified by a plurality of points in the set at regular distances from and in line with a given point (P) in two directions within the 2D plane, or
a circular pattern (708, 712) identified by a plurality of points in the set at regular distances from each other and that each lie along an arc of a circle with a common center (C); and
store (230) pattern data corresponding to the found indicated pattern.
16. The computer-readable medium of claim 15, wherein the data processing system also converts 2D or three-dimensional features (320) into the set of 2D points.
17. The computer-readable medium of claim 15 or 16, wherein the data processing system consolidates (220) multiple linear patterns into a rectangular pattern.
18. The computer- readable medium of any of claims 15 to 17, wherein points
corresponding to the found indicated pattern are removed from the set of 2D points, and the data processing system repeats identifying, finding, and storing.
19. The computer-readable medium of any of claims 15 to 18, wherein the data
processing system receives a user selection of the indicated pattern to find. The computer-readable medium of any of claims 15 to 19, wherein the data processing system determines a distance and direction between each point in set and each neighbor point to the point in the set.
PCT/US2014/039315 2013-05-31 2014-05-23 Automatic detection of regular patterns of features Ceased WO2014193750A1 (en)

Priority Applications (5)

Application Number Priority Date Filing Date Title
CN202111523212.4A CN114186294A (en) 2013-05-31 2014-05-23 Automatic detection of regular patterns of features
EP14804913.3A EP3005237B1 (en) 2013-05-31 2014-05-23 Automatic detection of regular patterns of features
CN201480031126.3A CN105229672A (en) 2013-05-31 2014-05-23 Automatic detection of regular patterns of features
RU2015156064A RU2633167C2 (en) 2013-05-31 2014-05-23 Automatic detection of regular figures from elements
JP2016516703A JP6049944B2 (en) 2013-05-31 2014-05-23 Automatic detection of feature patterns

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US13/907,034 2013-05-31
US13/907,034 US20140355888A1 (en) 2013-05-31 2013-05-31 Automatic detection of regular patterns of features

Publications (1)

Publication Number Publication Date
WO2014193750A1 true WO2014193750A1 (en) 2014-12-04

Family

ID=51985181

Family Applications (2)

Application Number Title Priority Date Filing Date
PCT/US2014/039315 Ceased WO2014193750A1 (en) 2013-05-31 2014-05-23 Automatic detection of regular patterns of features
PCT/US2015/018427 Ceased WO2015142510A1 (en) 2013-05-31 2015-03-03 Multi-level structures in cad models

Family Applications After (1)

Application Number Title Priority Date Filing Date
PCT/US2015/018427 Ceased WO2015142510A1 (en) 2013-05-31 2015-03-03 Multi-level structures in cad models

Country Status (6)

Country Link
US (2) US20140355888A1 (en)
EP (1) EP3005237B1 (en)
JP (1) JP6049944B2 (en)
CN (2) CN105229672A (en)
RU (1) RU2633167C2 (en)
WO (2) WO2014193750A1 (en)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20240095226A1 (en) * 2022-09-15 2024-03-21 Rodney Kuhn Haffnerson King Methods and related devices for storing and accessing data using multi-level fractal grids

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2002013137A2 (en) 2000-08-07 2002-02-14 Electro Scientific Industries, Inc. Polygon finder and pruned tree geometric match method
US20040070800A1 (en) * 2002-10-15 2004-04-15 Dai Nippon Printing Co., Ltd. Holographic fine-line Pattern
US20070196017A1 (en) * 2006-02-17 2007-08-23 Sharp Kabushiki Kaisha Management information adding method and image forming apparatus
US20080219565A1 (en) * 2007-03-06 2008-09-11 Kabushiki Kaisha Toshiba Training device and pattern recognizing device
US20090220142A1 (en) * 2008-02-29 2009-09-03 Hiroshi Matsushita Linear pattern detection method and apparatus
US20130058574A1 (en) * 2010-01-21 2013-03-07 Universite Paris 13 Method for segmenting images, computer program, and corresponding computer system

Family Cites Families (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH077448B2 (en) * 1987-10-08 1995-01-30 日立ソフトウェアエンジニアリング株式会社 Arc part recognition method
JPH01180680A (en) * 1988-01-13 1989-07-18 Ricoh Co Ltd Line figure approximation method
JPH01282684A (en) * 1988-05-10 1989-11-14 Ricoh Co Ltd Approximation error correction method for line figures
KR950013127B1 (en) * 1993-03-15 1995-10-25 김진형 English Character Recognition Method and System
US6122628A (en) * 1997-10-31 2000-09-19 International Business Machines Corporation Multidimensional data clustering and dimension reduction for indexing and searching
US7643968B1 (en) * 2002-02-25 2010-01-05 Autodesk, Inc. Method and apparatus for simplified patterning of features in a computer aided design (CAD) model
RU2406136C2 (en) * 2006-06-09 2010-12-10 Кейденс Дизайн Системс, Инк. Method and mechanism of extracting and identifying polygons when designing integrated circuits
US8041120B2 (en) * 2007-06-26 2011-10-18 Microsoft Corporation Unified digital ink recognition
US8457405B2 (en) * 2007-08-31 2013-06-04 Adobe Systems Incorporated Example-based procedural synthesis of element arrangements
US8116553B2 (en) * 2007-10-03 2012-02-14 Siemens Product Lifecycle Management Software Inc. Rotation invariant 2D sketch descriptor
US9400853B2 (en) * 2010-05-05 2016-07-26 Siemens Product Lifecycle Management Software Inc. System and method for identifying under-defined geometries due to singular constraint schemes
US8605093B2 (en) * 2010-06-10 2013-12-10 Autodesk, Inc. Pipe reconstruction from unorganized point cloud data
US9058687B2 (en) * 2011-06-08 2015-06-16 Empire Technology Development Llc Two-dimensional image capture for an augmented reality representation
US9122818B2 (en) * 2012-06-21 2015-09-01 Siemens Product Lifecycle Management Software Inc. Representation and discovery of geometric relationships in a three dimensional model
US9141731B2 (en) * 2012-06-21 2015-09-22 Siemens Product Lifecycle Management Software Inc. Symmetry of discovered geometric relationships in a three dimensional model
US10176291B2 (en) * 2012-07-06 2019-01-08 Siemens Product Lifecycle Management Software Inc. Ordering optional constraints in a variational system

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2002013137A2 (en) 2000-08-07 2002-02-14 Electro Scientific Industries, Inc. Polygon finder and pruned tree geometric match method
US20040070800A1 (en) * 2002-10-15 2004-04-15 Dai Nippon Printing Co., Ltd. Holographic fine-line Pattern
US20070196017A1 (en) * 2006-02-17 2007-08-23 Sharp Kabushiki Kaisha Management information adding method and image forming apparatus
US20080219565A1 (en) * 2007-03-06 2008-09-11 Kabushiki Kaisha Toshiba Training device and pattern recognizing device
US20090220142A1 (en) * 2008-02-29 2009-09-03 Hiroshi Matsushita Linear pattern detection method and apparatus
US20130058574A1 (en) * 2010-01-21 2013-03-07 Universite Paris 13 Method for segmenting images, computer program, and corresponding computer system

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See also references of EP3005237A4

Also Published As

Publication number Publication date
RU2633167C2 (en) 2017-10-11
CN114186294A (en) 2022-03-15
US20140355888A1 (en) 2014-12-04
WO2015142510A1 (en) 2015-09-24
US20150261890A1 (en) 2015-09-17
CN105229672A (en) 2016-01-06
EP3005237A1 (en) 2016-04-13
JP6049944B2 (en) 2016-12-21
JP2016520934A (en) 2016-07-14
EP3005237B1 (en) 2022-12-28
RU2015156064A (en) 2017-07-06
EP3005237A4 (en) 2017-05-17

Similar Documents

Publication Publication Date Title
US9844917B2 (en) Support structures for additive manufacturing of solid models
JP6198824B2 (en) A method for ordering additional constraints in a variational system.
US20130132424A1 (en) Massive model visualization with spatial indexing
US9779292B2 (en) System and method for interactive sketch recognition based on geometric contraints
US20150269284A1 (en) Intelligent chamfer recognition in cad models
WO2021014557A1 (en) Mesh structure facility detection device, mesh structure facility detection method, and program
US9400853B2 (en) System and method for identifying under-defined geometries due to singular constraint schemes
WO2015164052A1 (en) Duplicate pattern of assembly components in cad models
EP3005237B1 (en) Automatic detection of regular patterns of features
CN116229116A (en) Process reuse processing method, system and electronic equipment based on similar parts
WO2014051949A1 (en) Systems and methods for computing solutions of geometric constraint equations of computer-implemented virtual models
JP2009168525A (en) Link matching system, method, and program
US11398074B1 (en) Method and apparatus for identifying planes of objects in 3D scenes
EP3425593A1 (en) Highly parallelizable algorithm for detecting intersections of shapes
JP6827906B2 (en) 3D data processing device and 3D data processing method
EP4430490A1 (en) Method and system for creating 3d model for digital twin from point cloud
WO2013033534A1 (en) Tolerant intersections in graphical models
CN105719310B (en) Collision detection method and device
EP3152689A1 (en) Aerospace joggle on multiple adjacent web faces with intersecting runouts
US9122818B2 (en) Representation and discovery of geometric relationships in a three dimensional model
JP2019012427A (en) Image collation program, image collation method, and image collation apparatus
US20150278401A1 (en) Intelligent offset recognition in cad models
JP6086017B2 (en) Data processing apparatus and data processing program

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 201480031126.3

Country of ref document: CN

121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 14804913

Country of ref document: EP

Kind code of ref document: A1

WWE Wipo information: entry into national phase

Ref document number: 2014804913

Country of ref document: EP

ENP Entry into the national phase

Ref document number: 2016516703

Country of ref document: JP

Kind code of ref document: A

NENP Non-entry into the national phase

Ref country code: DE

ENP Entry into the national phase

Ref document number: 2015156064

Country of ref document: RU

Kind code of ref document: A