WO2012058604A2 - Procédés et systèmes de conception assistée par ordinateur - Google Patents

Procédés et systèmes de conception assistée par ordinateur Download PDF

Info

Publication number
WO2012058604A2
WO2012058604A2 PCT/US2011/058406 US2011058406W WO2012058604A2 WO 2012058604 A2 WO2012058604 A2 WO 2012058604A2 US 2011058406 W US2011058406 W US 2011058406W WO 2012058604 A2 WO2012058604 A2 WO 2012058604A2
Authority
WO
WIPO (PCT)
Prior art keywords
cad
parametric
geometry
feature
user
Prior art date
Application number
PCT/US2011/058406
Other languages
English (en)
Other versions
WO2012058604A3 (fr
Inventor
John Christopher Buchowski
Rudy Hubert Slegers
Brian Thompson
Anton Tsypkin
Yihmin Chin
Yacov Estrin
Paul Sagar
Leonid Ryvchin
Valery Burkatovskiy
Original Assignee
Parametric Technology Corporation
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
Priority claimed from US12/913,998 external-priority patent/US20120109589A1/en
Priority claimed from US12/914,008 external-priority patent/US8566066B2/en
Priority claimed from US12/913,992 external-priority patent/US8589128B2/en
Priority claimed from US12/914,001 external-priority patent/US8890867B2/en
Application filed by Parametric Technology Corporation filed Critical Parametric Technology Corporation
Priority to EP11837204.4A priority Critical patent/EP2633448A4/fr
Priority to JP2013536886A priority patent/JP6000267B2/ja
Publication of WO2012058604A2 publication Critical patent/WO2012058604A2/fr
Publication of WO2012058604A3 publication Critical patent/WO2012058604A3/fr

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2111/00Details relating to CAD techniques
    • G06F2111/02CAD in a network environment, e.g. collaborative CAD or distributed simulation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2111/00Details relating to CAD techniques
    • G06F2111/04Constraint-based CAD
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2111/00Details relating to CAD techniques
    • G06F2111/20Configuration CAD, e.g. designing by assembling or positioning modules selected from libraries of predesigned modules
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • G06F30/10Geometric CAD
    • G06F30/15Vehicle, aircraft or watercraft design

Definitions

  • CAD computer- aided design
  • CAE computer-aided engineering
  • CAM computer- aided manufacturing
  • CAD applications allow a user to input and view a design for a particular structure in the form of an object. The user can often rotate the view of the object to any angle, and also zoom in or zoom out for different views and perspectives. Additional visual features such as highlighting, shading, cross-hatching, coloring, texturing, and others enable the user to design an object with the aid of a computing device.
  • parametric or history-based CAD the application can also keep track of and monitor design changes to the object in addition to design dependencies.
  • a length of a first object may be defined by a formula that includes, as a variable, a length of a second object. Accordingly, modifying the length of the second object may cause the CAD application to recalculate the length of the first object and regenerate the model.
  • objects While in many uses, objects may be simple assemblies of a few basic geometric shapes, in others, objects may include many thousands of complex parts. For example, a detailed CAD model of an automobile may include thousands of unique features of diverse types including tread design on tires, taillight lens design, electrical subsystem routing, instrument panel layout, spark plug gap spacing, seatbelt latch design, and many others. This complexity may result in slow operation of these applications. Furthermore, due to the complexity, these programs typically have very steep learning curves.
  • the present disclosure features methods and systems for creation of a dynamically configurable product design, sometimes referred to as business driven assemblies.
  • Such product designs may be referred to as driven by a bill-of-materials (BOM) or selection of options by a customer, sales representative, or vendor, and may be performed responsive to a product lifecycle management (PLM) plan.
  • BOM bill-of-materials
  • PLM product lifecycle management
  • the system allows a customer to define specifications of a product, and then dynamically generates a CAD model responsive to the defined specifications or selected options.
  • the present invention is directed to a method for creation of a dynamically -configurable product design.
  • the method includes creating, by a user of a computer-aided design (CAD) application executing on a processor of a computing device, a modular structure of a plurality of modules of a dynamically-configurable product design, the plurality of modules comprising at least one variable module.
  • the method also includes selecting, by the user from a plurality of variants of the at least one variable module, a variant to use in the dynamically-configurable product design.
  • the method further includes placing, by the CAD application, the selected variant in a geometric model of the dynamically- configurable product design.
  • the method also includes modifying, by the CAD application, positioning or geometry of a module adjacent to the placed selected variant in the geometric model responsive to one or more constraints of the placed selected variant.
  • the method includes the modular structure comprising a tree of relationships of modules of a product design.
  • the method includes each module of the product design including a locator interface or a shaper interface.
  • the method includes each variant of the plurality of variants of the at least one variable module including a corresponding locator interface or shaper interface.
  • the method includes the plurality of variants of the at least one variable module including a generic variant.
  • the method includes selecting, by the user, a variant from a predetermined list of variants of the variable module presented by a product configuration tool. In other embodiments, the method includes replacing a previously -used variant of the at least one variable module in the geometric model with the selected variant. In one embodiment, the method includes modifying positioning or geometry of the adjacent module to align an interface of the adjacent module to a corresponding interface of the placed selected variant. In another embodiment, the method includes the one or more constraints of the placed selected variant comprising rules for aligning a locator or shaper interface of an adjacent module to a corresponding locator or shaper interface of the placed selected variant. In some embodiments, the method includes the dynamically-configurable product design comprising an historic recipe of feature-based geometry of a CAD model.
  • the present invention features a system for creation of a dynamically-configurable product design.
  • the system includes a computing device comprising a processor, the processor configured to execute a computer-aided design (CAD) application for creating, by a user of the CAD application, a modular structure of a plurality of modules of a dynamically-configurable product design, the plurality of modules comprising at least one variable module; a selection interface for selecting, by the user from a plurality of variants of the at least one variable module, a variant to use in the dynamically- configurable product design; and a geometry engine for placing the selected variant in a geometric model of the dynamically-configurable product design, and modifying positioning or geometry of a module adjacent to the placed selected variant in the geometric model responsive to one or more constraints of the placed selected variant.
  • CAD computer-aided design
  • the modular structure comprises a tree of relationships of modules of a product design.
  • each module of the product design includes a locator interface or a shaper interface.
  • each variant of the plurality of variants of the at least one variable module includes a corresponding locator interface or shaper interface.
  • the plurality of variants of the at least one variable module includes a generic variant.
  • the selection interface is configured for selecting, by the user, a variant from a predetermined list of variants of the variable module presented by a product configuration tool.
  • the geometry engine is configured for replacing a previously -used variant of the at least one variable module in the geometric model with the selected variant.
  • the geometry engine is configured for modifying positioning or geometry of the adjacent module to align an interface of the adjacent module to a
  • the one or more constraints of the placed selected variant comprise rules for aligning a locator or shaper interface of an adjacent module to a corresponding locator or shaper interface of the placed selected variant.
  • dynamically -configurable product design comprises an historic recipe of feature-based geometry of a CAD model.
  • the present disclosure features methods and systems for direct-parametric interoperability in computer-aided design.
  • Two approaches for developing three-dimensional designs are currently widely used: direct and parametric computer-aided design (CAD) modeling.
  • CAD computer-aided design
  • a direct modeling user interface is used for editing a model, allowing intuitive and easy manipulation of geometry, and a parametric geometry engine interprets these manipulations as history-based features to create a construction recipe.
  • the underlying architecture of the model remains parametric, even though the user may not realize that history and associative relationships are being created and modified during every manipulation.
  • the present invention provides the intuitive WYSIWYG editing of direct CAD modeling, while retaining the powerful features and regenerative capabilities of parametric modelers.
  • the present invention features a computer-aided design (CAD) system.
  • the system includes a computing device comprising a processor configured to execute a parametric geometry engine for creating an historic recipe of feature-based geometry of a CAD object, and a direct modeling user interface for modifying geometry of the CAD object, wherein history and parametric features of the CAD object are hidden from a user of the direct modeling user interface.
  • CAD computer-aided design
  • the parametric geometry engine is configured to interpret a modification to geometry of the CAD object in the direct modeling user interface as creation or modification of a parametric feature in the historic recipe.
  • the created or modified parametric feature in the historic recipe is dependent on a second, prior parametric feature in the historic recipe.
  • the created or modified parametric feature in the historic recipe is dependent on the second, prior parametric feature in the historic recipe, responsive to an order of creation of the parametric features.
  • the created or modified parametric feature in the historic recipe is dependent on the second, prior parametric feature in the historic recipe responsive to an implicit constraint between the created or modified parametric features and the second, prior parametric feature.
  • the created or modified parametric feature is an engineering feature of the second, prior parametric feature.
  • the parametric geometry engine is configured to regenerate the created or modified parametric feature, responsive to modification of the second, prior parametric feature; and the direct modeling user interface is configured to display the regenerated created or modified parametric feature.
  • the created or modified parametric feature comprises a traditional parametric feature.
  • the created or modified parametric feature comprises a flex move or a flex move copy parametric feature.
  • the parametric geometry engine is configured to identify symmetric geometric elements of the CAD object created in the direct modeling user interface; and create a parametric flexible symmetric feature representative of an association between symmetric geometric elements of the CAD object.
  • the parametric geometry engine is configured to identify a pattern of a plurality of geometric elements of the CAD object created in the direct modeling user interface; and create a parametric flexible pattern feature representative of a pattern association between the plurality of geometric elements of the CAD object.
  • the processor is further configured to execute a parametric modeling user interface for reviewing and accepting or rejecting, by a user of the parametric modeling user interface, each of a plurality of modifications to a CAD model made by a user of the direct modeling user interface.
  • the parametric geometry engine is configured to recalculate geometry of a second CAD object of the CAD model, responsive to a rejection, by the user of the parametric modeling user interface, of a modification made by the user of the direct modeling user interface to a first CAD object, the second CAD object having a dependent relationship to the first CAD object in the historic recipe of feature-based geometry.
  • the present invention features a method using a computer- aided design (CAD) system.
  • the method includes modifying, by a user of a direct modeling user interface provided by a CAD application executing on a processor of a computing device, geometry of a CAD object.
  • the method also includes creating, by a parametric geometry engine of the CAD application, an historic recipe of feature-based geometry of a CAD object. In the method, history and parametric features of the CAD object are hidden from the user of the direct modeling user interface.
  • CAD computer- aided design
  • the method includes interpreting, by the parametric geometry engine, a modification to geometry of the CAD object by the user in the direct modeling user interface as creation or modification of a parametric feature in the historic recipe.
  • the method includes the created or modified parametric feature in the historic recipe being dependent on a second, prior parametric feature in the historic recipe, and the method further comprises regenerating, by the parametric geometry engine the created or modified parametric feature, responsive to modification of the second, prior parametric feature; and displaying, by the direct modeling user interface, the regenerated created or modified parametric feature.
  • the method includes the created or modified parametric feature comprising a flex move or a flex move copy parametric feature.
  • the method includes identifying, by the parametric geometry engine, symmetric geometric elements of the CAD object created in the direct modeling user interface; and creating, by the parametric geometry engine, a parametric flexible symmetric feature representative of an association between symmetric geometric elements of the CAD object.
  • the method includes identifying, by the parametric geometry engine, a pattern of a plurality of geometric elements of the CAD object created in the direct modeling user interface; and creating, by the parametric geometry engine, a parametric flexible pattern feature representative of a pattern association between the plurality of geometric elements of the CAD object.
  • the method includes reviewing and accepting or rejecting, by a user of a parametric modeling user interface of the CAD application, each of a plurality of modifications to a CAD model made by a user of the direct modeling user interface.
  • the method includes recalculating, by the parametric geometry engine, geometry of a second CAD object of the CAD model, responsive to a rejection, by the user of the parametric modeling user interface, of a modification made by the user of the direct modeling user interface to a first CAD object, the second CAD object having a dependent relationship to the first CAD object in the historic recipe of feature-based geometry.
  • a complicated CAD model may include thousands or tens of thousands of parts, each comprising dozens or hundreds of individual features.
  • the present invention features systems and methods for dynamically loading portions of a computer-aided design model on demand.
  • a CAD application may progressively load portions of a CAD model as needed by a user for a particular design task. This reduces both memory and processing
  • the present disclosure features a method for dynamically loading portions of a computer-aided design (CAD) model on demand.
  • the method includes loading, by a CAD application executed by a processor of a computing device, a first portion of a CAD model, the first portion comprising (i) a modular structure of the CAD model and (ii) graphics and geometry data of a first element of the modular structure.
  • the method also includes selecting, by a user of the CAD application, a second element of the modular structure.
  • the method further includes loading, by the CAD application and responsive to the selection, a second portion of the CAD model, the second portion comprising (i) a modular structure of the selected second element and (ii) graphics and geometry data of the selected second element.
  • the method includes identifying one or more visible or external surfaces of the first element and loading graphics and geometry data of the identified visible or external surfaces of the first element. In another embodiment, the method includes loading one or more location interfaces or shaper interfaces of the first element. In yet another embodiment, the method includes identifying one or more visible or external surfaces of the second element, and loading graphics and geometry data of the identified visible or external surfaces of the second element. In still another embodiment, the method includes loading one or more location interfaces or shaper interfaces of the second element.
  • the method includes adding the second element to the modular structure.
  • the method includes selecting, by the user of the CAD application, one or more items of geometry data of a third element of the modular structure for defining a constraint of geometry data of the first element or the second element; and loading, by the CAD application and responsive to the selection, the selected one or more items of geometry data of the third element.
  • the method includes not loading unselected items of geometry data of the third element
  • the method includes selecting, by the user of the CAD application, a third element of the modular structure, the third element not directly related to the second element in the modular structure; and loading, by the CAD application and responsive to the selection, a third portion of the CAD model, the third portion comprising (i) a modular structure of the selected third element and (ii) graphics and geometry data of the selected third element.
  • the method includes unloading, by the CAD application and responsive to the third element being not directly related to the second element in the modular structure, the second portion of the CAD model.
  • the present disclosure features a system for dynamically loading portions of a computer-aided design (CAD) model on demand.
  • the system includes a computing device comprising a processor, the processor configured to execute a CAD application.
  • the CAD application includes a user interface of the CAD application for selecting, by a user, a first element of a modular structure of a CAD model; and a geometry engine of the CAD application configured to: load a first portion of the CAD model, the first portion comprising (i) a modular structure of the CAD model and (ii) graphics and geometry data of a second element of the modular structure, and load, responsive to the selection by the user, a second portion of the CAD model, the second portion comprising (i) a modular structure of the selected first element and (ii) graphics and geometry data of the selected first element.
  • CAD computer-aided design
  • the geometry engine is further configured to identifying one or more visible or external surfaces of the second element and load graphics and geometry data of the identified visible or external surfaces of the second element. In another embodiment, the geometry engine is further configured to load one or more location interfaces or shaper interfaces of the second element. In still another embodiment, the geometry engine is further configured to identify one or more visible or external surfaces of the first element, and load graphics and geometry data of the identified visible or external surfaces of the first element. In yet still another embodiment, the geometry engine is further configured to load one or more location interfaces or shaper interfaces of the first element. In some embodiments, the geometry engine is further configured to add the first element to the modular structure.
  • the user interface is used for selecting, by the user of the
  • the geometry engine is further configured to load, responsive to the selection, the selected one or more items of geometry data of the third element.
  • the geometry engine is further configured to not load unselected items of geometry data of the third element.
  • the user interface is used for selecting, by the user of the CAD application, a third element of the modular structure, the third element not directly related to the first element in the modular structure; and the geometry engine is further configured to load, responsive to the selection, a third portion of the CAD model, the third portion comprising (i) a modular structure of the selected third element and (ii) graphics and geometry data of the selected third element.
  • the geometry engine is further configured to unload, responsive to the third element being not directly related to the first element in the modular structure, the second portion of the CAD model.
  • a parametric geometry engine of a CAD application may compare an attempted edit to a feature in a direct modeling user interface of the CAD application to an existing constraint created in a parametric modeling user interface, and, in one embodiment, prevent the user from completing the edit.
  • the parametric geometry engine may present a dialog box to the user and allow them to reject the edit, override or delete the constraint, modify the constraint, or take other actions as appropriate.
  • the parametric geometry engine may allow one user to edit the feature, but not another user. Thus, parametric constraints and permissions-based ownership of entities may be enforced in a direct modeling user interface.
  • the present disclosure is directed to a computer-aided design
  • the system includes a computing device comprising a processor configured to execute a parametric geometry engine for creating an historic recipe of feature-based geometry of a CAD object.
  • the processor is also configured to execute a parametric modeling user interface for creating, by a first user, a feature constraint of the CAD object.
  • the processor is further configured to execute a direct modeling user interface for attempting to modify, by a second user of the direct modeling user interface, the CAD object, wherein history and parametric features of the CAD object are hidden from the second user.
  • the parametric geometry engine is further configured to enforce the feature constraint in the direct modeling user interface, responsive to the second user attempting to modify the geometry.
  • the parametric geometry engine is configured to interpret a modification to geometry of the CAD object in the direct modeling user interface as creation or modification of a parametric feature in the historic recipe.
  • the feature constraint comprises a geometric constraint.
  • the feature constraint comprises an engineering constraint.
  • attempting to modify the CAD object comprises attempting to modify geometry of the CAD object or a feature of the CAD object.
  • attempting to modify the CAD object comprises attempting to modify product information of the CAD object or a feature of the CAD object.
  • the parametric geometry engine is configured to prevent or reject the attempted modification to the CAD object, responsive to the second user attempting to modify the geometry.
  • the parametric geometry engine is configured to allow the second user to override or modify the feature constraint in the direct modeling user interface.
  • enforcing the feature constraint in the direct modeling user interface comprises allowing modification of the CAD object in the direct modeling user interface, responsive to the second user overriding or modifying the feature constraint.
  • the parametric geometry engine is configured to prevent or reject the attempted modification to the CAD object, responsive to the second user lacking permission to modify the geometry.
  • the present disclosure is directed to a method of enforcing constraints in a computer-aided design (CAD) system.
  • the method includes creating, by a first user of a parametric modeling user interface of a CAD application executed by a processor of a computing device, a feature constraint of a CAD object, the CAD object comprising an historic recipe of feature-based geometry.
  • the method also includes attempting to modify, by a second user of a direct modeling user interface of the CAD application, the CAD object, wherein history and parametric features of the CAD object are hidden from the second user in the direct modeling user interface.
  • the method further includes enforcing, by a parametric modeling engine of the CAD application, the feature constraint in the direct modeling user interface, responsive to the second user attempting to modify the geometry.
  • the method includes interpreting, by the parametric geometry engine, a modification to geometry of the CAD object in the direct modeling user interface as creation or modification of a parametric feature in the historic recipe.
  • the feature constraint comprises a geometric constraint. In other embodiments, the feature constraint comprises an engineering constraint.
  • the method includes attempting to modify, by the second user of the direct modeling user interface, geometry of the CAD object or a feature of the CAD object. In another embodiment, the method includes attempting to modify, by the second user of the direct modeling user interface, product information of the CAD object or a feature of the CAD object.
  • the method includes preventing or rejecting, by the parametric geometry engine, the attempted modification to the CAD object, responsive to the second user attempting to modify the geometry.
  • the method includes allowing, by the parametric geometry engine, the second user to override or modify the feature constraint in the direct modeling user interface.
  • the method includes allowing, by the parametric geometry engine, modification of the CAD object in the direct modeling user interface, responsive to the second user overriding or modifying the feature constraint.
  • the method includes preventing or rejecting, by the parametric geometry engine, responsive to the second user lacking permission to modify the geometry.
  • FIG. 1 A is a block diagram depicting an embodiment of a network environment comprising local machines in communication with remote machines;
  • FIGs. IB-IE are block diagrams depicting embodiments of computers useful in connection with the methods and systems described herein;
  • FIG. 2A is a block diagram of an embodiment of creation of a chamfered three-dimensional object through direct modeling
  • FIG. 2B is a block diagram of an embodiment of creation of a chamfered three-dimensional object through parametric modeling
  • FIG. 3A is a block diagram of an embodiment of a system for computer-aided design
  • FIG. 3B is a flow chart of an embodiment of a method of computer-aided [0048]
  • FIG. 3C is a flow chart of another embodiment of a method of computer-aided design;
  • FIG. 3D is a flow chart of yet another embodiment of a method of computer- aided design
  • FIG. 3E is a flow chart of an embodiment of constraint locking in a method of computer-aided design
  • FIG. 4A is a block diagram of an embodiment of a system for creation of business driven assemblies
  • FIG. 4B is a tree diagram of a modular structure and three dimensional model of an example of a business driven assembly
  • FIG. 4C is a tree diagram of an embodiment of a plurality of variants of a variable module in an example of a business driven assembly
  • FIG. 4D is a flow chart of an embodiment of a method of creation of business driven assemblies
  • FIG. 5A is a three-dimensional view of an example of a computer-aided design model
  • FIG. 5B is a three-dimensional view of a sub-assembly of the example of the computer-aided design model
  • FIG. 5C is a three-dimensional view of a sub-assembly of the sub-assembly of the example of the computer-aided design model.
  • FIG. 5D is a flow chart of an embodiment of a method for dynamically loading portions of a computer-aided design model on demand.
  • the present disclosure describes, among other things, methods and systems for creation of a dynamically configurable product design, direct-parametric interoperability in computer-aided design, dynamically loading portions of a computer-aided design model on demand, and/or enforcing parametric constraints in a direct modeling interface in computer- aided design.
  • Section A describes a network environment and computing environment which may be useful for practicing embodiments described herein;
  • Section B describes embodiments of systems and methods for using a direct computer-aided design modeling user interface for creating and modifying a parametric computer-aided design model
  • Section C describes embodiments of systems and methods for creating business driven assemblies
  • Section D describes embodiments of systems and methods for dynamically loading portions of a computer-aided design model on demand.
  • the network environment comprises one or more local machines 102a-102n (also generally referred to as local machine(s) 102, client(s) 102, client node(s) 102, client machine(s) 102, client computer(s) 102, client device(s) 102, endpoint(s) 102, or endpoint node(s) 102) in communication with one or more remote machines 106a-106n (also generally referred to as server(s) 106 or remote machine(s) 106) via one or more networks 104.
  • a local machine 102 has the capacity to function as both a client node seeking access to resources provided by a server and as a server providing access to hosted resources for other clients 102a-102n.
  • FIG. 1A shows a network 104 between the local machines 102 and the remote machines 106
  • the network 104 can be a local-area network (LAN), such as a company Intranet, a metropolitan area network (MAN), or a wide area network (WAN), such as the Internet or the World Wide Web.
  • LAN local-area network
  • MAN metropolitan area network
  • WAN wide area network
  • a network 104' (not shown) may be a private network and a network 104 may be a public network.
  • a network 104 may be a private network and a network 104' a public network.
  • networks 104 and 104' may both be private networks.
  • networks 104 and 104' may both be public networks.
  • the network 104 may be any type and/or form of network and may include any of the following: a point to point network, a broadcast network, a wide area network, a local area network, a telecommunications network, a data communication network, a computer network, an ATM (Asynchronous Transfer Mode) network, a SONET
  • the network 104 may comprise a wireless link, such as an infrared channel or satellite band.
  • the topology of the network 104 may be a bus, star, or ring network topology.
  • the network 104 may be of any such network topology as known to those ordinarily skilled in the art capable of supporting the operations described herein.
  • the network may comprise mobile telephone networks utilizing any protocol or protocols used to communicate among mobile devices, including AMPS, TDMA, CDMA, GSM, GPRS or UMTS.
  • different types of data may be transmitted via different protocols. In other embodiments, the same types of data may be transmitted via different protocols.
  • the system may include multiple, logically-grouped remote machines 106.
  • the logical group of remote machines may be referred to as a server farm 38.
  • the remote machines 106 may be geographically dispersed.
  • a server farm 38 may be administered as a single entity.
  • the server farm 38 comprises a plurality of server farms 38.
  • the remote machines 106 within each server farm 38 can be heterogeneous - one or more of the remote machines 106 can operate according to one type of operating system platform (e.g., WINDOWS NT, WINDOWS 2003, WINDOWS 2008, WINDOWS 7 and WINDOWS Server 2008 R2, all of which are manufactured by Microsoft Corp. of Redmond, Washington), while one or more of the other remote machines 106 can operate on according to another type of operating system platform (e.g., Unix or Linux).
  • operating system platform e.g., WINDOWS NT, WINDOWS 2003, WINDOWS 2008, WINDOWS 7 and WINDOWS Server 2008 R2, all of which are manufactured by Microsoft Corp. of Redmond, Washington
  • Unix or Linux e.g., Unix or Linux
  • the remote machines 106 of each server farm 38 do not need to be physically proximate to another remote machine 106 in the same server farm 38.
  • the group of remote machines 106 logically grouped as a server farm 38 may be interconnected using a wide-area network (WAN) connection or a metropolitan-area network (MAN) connection.
  • WAN wide-area network
  • MAN metropolitan-area network
  • a server farm 38 may include remote machines 106 physically located in different continents or different regions of a continent, country, state, city, campus, or room. Data transmission speeds between remote machines 106 in the server farm 38 can be increased if the remote machines 106 are connected using a local-area network (LAN) connection or some form of direct connection.
  • LAN local-area network
  • a remote machine 106 may be a file server, application server, web server, proxy server, appliance, network appliance, gateway, application gateway, gateway server, virtualization server, deployment server, SSL VPN server, or firewall.
  • a remote machine 106 provides a remote authentication dial-in user service, and is referred to as a RADIUS server.
  • a remote machine 106 may have the capacity to function as either an application server or as a master application server.
  • a remote machine 106 is a blade server.
  • a remote machine 106 executes a virtual machine providing, to a user or client computer 102, access to a computing environment.
  • a remote machine 106 may include an Active Directory.
  • the remote machine 106 may be an application acceleration appliance.
  • the remote machine 106 may provide functionality including firewall functionality, application firewall functionality, or load balancing functionality.
  • the remote machine 106 comprises an appliance such as one of the line of appliances manufactured by the Citrix Application Networking Group, of San Jose, CA, or Silver Peak Systems, Inc., of Mountain View, CA, or of Riverbed Technology, Inc., of San Francisco, CA, or of F5 Networks, Inc., of Seattle, WA, or of Juniper Networks, Inc., of Sunnyvale, CA.
  • a remote machine 106 executes an application on behalf of a user of a local machine 102.
  • a remote machine 106 executes a virtual machine, which provides an execution session within which applications execute on behalf of a user of a local machine 102.
  • the execution session is a hosted desktop session.
  • the execution session provides access to a computing environment, which may comprise one or more of: an application, a plurality of applications, a desktop application, and a desktop session in which one or more applications may execute.
  • a local machine 102 communicates with a remote machine 106.
  • the local machine 102 communicates directly with one of the remote machines 106 in a server farm 38.
  • the local machine 102 executes a program neighborhood application to communicate with a remote machine 106 in a server farm 38.
  • the remote machine 106 provides the functionality of a master node.
  • the local machine 102 communicates with the remote machine 106 in the server farm 38 through a network 104. Over the network 104, the local machine 102 can, for example, request execution of various applications hosted by the remote machines 106a-106n in the server farm 38 and receive output of the results of the application execution for display.
  • only a master node provides the functionality required to identify and provide address information associated with a remote machine 106b hosting a requested application.
  • the remote machine 106 provides the functionality of a web server.
  • the remote machine 106a receives requests from the local machine 102, forwards the requests to a second remote machine 106b and responds to the request by the local machine 102 with a response to the request from the remote machine 106b.
  • the remote machine 106a acquires an enumeration of applications available to the local machine 102 and address information associated with a remote machine 106b hosting an application identified by the enumeration of applications.
  • the remote machine 106 presents the response to the request to the local machine 102 using a web interface.
  • the local machine 102 communicates directly with the remote machine 106 to access the identified application.
  • the local machine 102 receives output data, such as display data, generated by an execution of the identified application on the remote machine 106.
  • the remote machine 106 or a server farm 38 may be running one or more applications, such as an application providing a thin-client computing or remote display presentation application.
  • the remote machine 106 or server farm 38 executes as an application any portion of the CITRIX ACCESS SUITE by Citrix Systems, Inc., such as the METAFRAME or CITRIX PRESENTATION SERVER products, any of the following products manufactured by Citrix Systems, Inc.: CITRIX XENAPP, CITRIX XENDESKTOP, CITRIX ACCESS GATEWAY, and/or any of the MICROSOFT WINDOWS Terminal Services manufactured by the Microsoft Corporation.
  • the application is an ICA client, developed by Citrix Systems, Inc. of Fort Lauderdale, Florida.
  • the remote machine 106 may run an application, which, for example, may be an application server providing email services such as MICROSOFT EXCHANGE manufactured by the Microsoft Corporation of Redmond, Washington, a web or Internet server, or a desktop sharing server, or a collaboration server.
  • any of the applications may comprise any type of hosted service or products, such as GOTOMEETING provided by Citrix Online Division, Inc. of Santa Barbara, California, WEBEX provided by WebEx, Inc. of Santa Clara, California, or Microsoft Office LIVE MEETING provided by Microsoft Corporation of Redmond, Washington.
  • a local machine 102 may execute, operate or otherwise provide an application, which can be any type and/or form of software, program, or executable instructions such as any type and/or form of web browser, web-based client, client-server application, a thin-client computing client, an ActiveX control, or a Java applet, or any other type and/or form of executable instructions capable of executing on local machine 102.
  • the application may be a server-based or a remote-based application executed on behalf of the local machine 102 on a remote machine 106.
  • the remote machine 106 may display output to the local machine 102 using any thin-client protocol, presentation layer protocol, or remote-display protocol, such as the Independent Computing Architecture (ICA) protocol manufactured by Citrix Systems, Inc. of Ft. Lauderdale, Florida; the Remote Desktop Protocol (RDP) manufactured by the Microsoft Corporation of Redmond, Washington; the X 11 protocol; the Virtual Network Computing (VNC) protocol, manufactured by AT&T Bell Labs; the SPICE protocol, manufactured by Qumranet, Inc., of Sunnyvale, CA, USA, and of Raanana, Israel; the Net2Display protocol, manufactured by VESA, of Milpitas, CA; the PC-over-IP protocol, manufactured by Teradici Corporation, of Burnaby, B.C.; the TCX protocol, manufactured by Wyse Technology, Inc., of San Jose, CA; the THTNC protocol developed by Columbia University in the City of New York, of New York, NY; or the Virtual-D protocols manufactured by Desktone, Inc., of Chelmsford, MA.
  • ICA Independent
  • the application can use any type of protocol and it can be, for example, an HTTP client, an FTP client, an Oscar client, or a Telnet client.
  • the application comprises any type of software related to voice over Internet protocol (VoIP) communications, such as a soft IP telephone.
  • VoIP voice over Internet protocol
  • the application comprises any application related to real-time data communications, such as applications for streaming video and/or audio.
  • the application comprises any application related to computer-aided design (CAD), computer-aided manufacturing (CAM), computer-aided engineering (CAE), product life-cycle management (PLM), project management, resource management, customer relationship management (CRM), or any other application for the generation, modification, modeling, and/or analysis of data.
  • CAD computer-aided design
  • CAM computer-aided manufacturing
  • CAE computer-aided engineering
  • PLM product life-cycle management
  • CRM customer relationship management
  • the local machine 102 and remote machine 106 may be deployed as and/or executed on any type and form of computing device, such as a computer, network device or appliance capable of communicating on any type and form of network and performing the operations described herein.
  • FIGs. IB and 1C depict block diagrams of a computing device 100 useful for practicing an embodiment of the local machine 102 or a remote machine 106. As shown in FIGs. IB and 1C, each computing device 100 includes a central processing unit 121, and a main memory unit 122. As shown in FIG.
  • a computing device 100 may include a storage device 128, an installation device 116, a network interface 1 18, an 170 controller 123, display devices 124a-n, a keyboard 126 and a pointing device 127, such as a mouse.
  • the storage device 128 may include, without limitation, an operating system, software, and a client agent 120.
  • each computing device 100 may also include additional optional elements, such as a memory port 103, a bridge 170, one or more input/output devices 130a-130n (generally referred to using reference numeral 130), and a cache memory 140 in communication with the central processing unit 121.
  • the central processing unit 121 is any logic circuitry that responds to and processes instructions fetched from the main memory unit 122.
  • the central processing unit 121 is provided by a microprocessor unit, such as: those manufactured by Intel Corporation of Mountain View, California; those manufactured by Motorola Corporation of Schaumburg, Illinois; those manufactured by Transmeta Corporation of Santa Clara, California; the RS/6000 processor, those manufactured by International Business Machines of White Plains, New York; or those manufactured by Advanced Micro Devices of Sunnyvale, California.
  • the computing device 100 may be based on any of these processors, or any other processor capable of operating as described herein.
  • Main memory unit 122 may be one or more memory chips capable of storing data and allowing any storage location to be directly accessed by the microprocessor 121, such as Static random access memory (SRAM), Burst SRAM or SynchBurst SRAM
  • SRAM Static random access memory
  • Burst SRAM Burst SRAM
  • BSRAM Dynamic random access memory
  • DRAM Dynamic random access memory
  • FPM DRAM Fast Page Mode DRAM
  • EDRAM Enhanced DRAM
  • EDO DRAM Enhanced DRAM
  • EDRAM Extended Data Output RAM
  • EDO DRAM Extended Data Output DRAM
  • BEDO DRAM Enhanced DRAM
  • EDRAM synchronous DRAM
  • SDRAM JEDEC SRAM
  • PCIOO SDRAM Double Data Rate SDRAM
  • DDR SDRAM Double Data Rate SDRAM
  • ESDRAM Enhanced SDRAM
  • SLDRAM Direct Rambus DRAM
  • FRAM Ferroelectric RAM
  • the main memory 122 may be based on any of the above described memory chips, or any other available memory chips capable of operating as described herein. In the embodiment shown in FIG.
  • FIG. 1C depicts an embodiment of a computing device 100 in which the processor communicates directly with main memory 122 via a memory port 103.
  • the main memory 122 may be DRDRAM.
  • FIG. 1C depicts an embodiment in which the main processor 121
  • main processor 121 communicates directly with cache memory 140 via a secondary bus, sometimes referred to as a backside bus.
  • main processor 121 communicates with cache memory 140 using the system bus 150.
  • Cache memory 140 typically has a faster response time than main memory 122 and is typically provided by SRAM, BSRAM, or EDRAM.
  • the processor 121 communicates with various I/O devices 130 via a local system bus 150.
  • FIG. 1C depicts an embodiment of a computer 100 in which the main processor 121 communicates directly with I O device 130b via HYPERTRANSPORT, RAPIDIO, or INFINIBAND communications technology.
  • FIG. 1C also depicts an embodiment in which local busses and direct communication are mixed: the processor 121 communicates with I/O device 130a using a local interconnect bus while communicating with I/O device 130b directly.
  • I O devices 130a-130n may be present in the computing device 100.
  • Input devices include keyboards, mice, trackpads, trackballs, microphones, and drawing tablets.
  • Output devices include video displays, speakers, inkjet printers, laser printers, and dye-sublimation printers.
  • An I/O controller 123 may control the I/O devices.
  • the I O controller may control one or more I/O devices such as a keyboard 126 and a pointing device 127, e.g., a mouse or optical pen.
  • an I/O device may also provide storage and/or an installation medium 1 16 for the computing device 100.
  • the computing device 100 may provide USB connections (not shown) to receive handheld USB storage devices such as the USB Flash Drive line of devices manufactured by Twintech Industry, Inc. of Los Alamitos, California.
  • the computing device 100 may support any suitable installation device 116, such as a floppy disk drive for receiving floppy disks such as 3.5-inch, 5.25-inch disks or ZIP disks, a CD-ROM drive, a CD-R/RW drive, a DVD-ROM drive, tape drives of various formats, USB device, hard-drive or any other device suitable for installing software and programs.
  • the computing device 100 may further comprise a storage device, such as one or more hard disk drives or redundant arrays of independent disks, for storing an operating system and other related software, and for storing application software programs such as any program related to the client agent 120.
  • any of the installation devices 1 16 could also be used as the storage device.
  • the operating system and the software can be run from a bootable medium, for example, a bootable CD, such as KNOPPIX, a bootable CD for GNU/Linux that is available as a GNU/Linux distribution from knoppix.net.
  • a bootable CD such as KNOPPIX
  • KNOPPIX a bootable CD for GNU/Linux that is available as a GNU/Linux distribution from knoppix.net.
  • the computing device 100 may include a network interface 1 18 to interface to the network 104 through a variety of connections including, but not limited to, standard telephone lines, LAN or WAN links (e.g., 802.1 1, Tl, T3, 56kb, X.25, SNA, DECNET), broadband connections (e.g., ISDN, Frame Relay, ATM, Gigabit Ethernet, Ethernet-over-SONET), wireless connections, or some combination of any or all of the above.
  • standard telephone lines LAN or WAN links (e.g., 802.1 1, Tl, T3, 56kb, X.25, SNA, DECNET), broadband connections (e.g., ISDN, Frame Relay, ATM, Gigabit Ethernet, Ethernet-over-SONET), wireless connections, or some combination of any or all of the above.
  • LAN or WAN links e.g., 802.1 1, Tl, T3, 56kb, X.25, SNA, DECNET
  • broadband connections e.g., ISDN, Frame Relay
  • Connections can be established using a variety of communication protocols (e.g., TCP/IP, IPX, SPX, NetBIOS, Ethernet, ARCNET, SONET, SDH, Fiber Distributed Data Interface (FDDI), RS232, IEEE 802.1 1, IEEE 802.11a, IEEE 802.1 1b, IEEE 802.1 1g, CDMA, GSM, WiMax and direct asynchronous connections).
  • the computing device 100 communicates with other computing devices 100' via any type and/or form of gateway or tunneling protocol such as Secure Socket Layer (SSL) or Transport Layer Security (TLS), or the Citrix Gateway Protocol manufactured by Citrix Systems, Inc. of Ft. Lauderdale, Florida.
  • SSL Secure Socket Layer
  • TLS Transport Layer Security
  • Citrix Gateway Protocol manufactured by Citrix Systems, Inc. of Ft. Lauderdale, Florida.
  • the network interface 118 may comprise a built-in network adapter, network interface card, PCMCIA network card, card bus network adapter, wireless network adapter, USB network adapter, modem or any other device suitable for interfacing the computing device 100 to any type of network capable of communication and performing the operations described herein.
  • the computing device 100 may comprise or be connected to multiple display devices 124a-124n, which each may be of the same or different type and/or form.
  • any of the I/O devices 130a-130n and/or the I/O controller 123 may comprise any type and/or form of suitable hardware, software, or combination of hardware and software to support, enable or provide for the connection and use of multiple display devices 124a-124n by the computing device 100.
  • the computing device 100 may include any type and/or form of video adapter, video card, driver, and/or library to interface, communicate, connect or otherwise use the display devices 124a-124n.
  • a video adapter may comprise multiple connectors to interface to multiple display devices 124a- 124n.
  • the computing device 100 may include multiple video adapters, with each video adapter connected to one or more of the display devices 124a-124n. In some embodiments, any portion of the operating system of the computing device 100 may be configured for using multiple displays 124a-124n. In other embodiments, one or more of the display devices 124a-124n may be provided by one or more other computing devices, such as computing devices 100a and 100b connected to the computing device 100, for example, via a network. These embodiments may include any type of software designed and constructed to use another computer's display device as a second display device 124a for the computing device 100. One ordinarily skilled in the art will recognize and appreciate the various ways and embodiments that a computing device 100 may be configured to have multiple display devices 124a- 124n.
  • an I/O device 130 may be a bridge between the system bus 150 and an external communication bus, such as a USB bus, an Apple Desktop Bus, an RS-232 serial connection, a SCSI bus, a Fire Wire bus, a Fire Wire 800 bus, an Ethernet bus, an AppleTalk bus, a Gigabit Ethernet bus, an Asynchronous Transfer Mode bus, a HIPPI bus, a Super HIPPI bus, a SerialPlus bus, a SCI/LAMP bus, a FibreChannel bus, or a Serial Attached small computer system interface bus.
  • an external communication bus such as a USB bus, an Apple Desktop Bus, an RS-232 serial connection, a SCSI bus, a Fire Wire bus, a Fire Wire 800 bus, an Ethernet bus, an AppleTalk bus, a Gigabit Ethernet bus, an Asynchronous Transfer Mode bus, a HIPPI bus, a Super HIPPI bus, a SerialPlus bus, a SCI/LAMP bus, a FibreChannel bus, or a
  • a computing device 100 of the sort depicted in FIGs. IB and 1C typically operates under the control of operating systems, which control scheduling of tasks and access to system resources.
  • the computing device 100 can be running any operating system such as any of the versions of the MICROSOFT WINDOWS operating systems, the different releases of the Unix and Linux operating systems, any version of the MAC OS for Macintosh computers, any embedded operating system, any real-time operating system, any open source operating system, any proprietary operating system, any operating systems for mobile computing devices, or any other operating system capable of running on the computing device and performing the operations described herein.
  • Typical operating systems include, but are not limited to: WINDOWS 3.x, WINDOWS 95, WINDOWS 98, WINDOWS 2000, WINDOWS NT 3.51, WINDOWS NT 4.0, WINDOWS 7, WINDOWS CE, WINDOWS XP, and WINDOWS VISTA, all of which are manufactured by Microsoft Corporation of Redmond, Washington; MAC OS, manufactured by Apple Inc., of Cupertino, California; OS/2, manufactured by International Business Machines of Armonk, New York; and Linux, a freely-available operating system distributed by Caldera Corp. of Salt Lake City, Utah, or any type and/or form of a Unix operating system, among others.
  • the computing device 100 can be any workstation, desktop computer, laptop or notebook computer, server, handheld computer, mobile telephone or other portable telecommunication device, media playing device, a gaming system, mobile computing device, or any other type and/or form of computing, telecommunications or media device that is capable of communication and that has sufficient processor power and memory capacity to perform the operations described herein.
  • the computing device 100 may comprise a device of the IPOD family of devices manufactured by Apple Inc., of Cupertino, California, a PLAYSTATION 2, PLAYSTATION 3, or PERSONAL PLAYSTATION PORTABLE (PSP) device manufactured by the Sony Corporation of Tokyo, Japan, a NINTENDO DS, NINTENDO GAMEBOY, NINTENDO GAMEBOY ADVANCED or NINTENDO REVOLUTION device manufactured by Nintendo Co., Ltd., of Kyoto, Japan, or an XBOX or XBOX 360 device manufactured by the Microsoft Corporation of Redmond, Washington.
  • PSP PERSONAL PLAYSTATION PORTABLE
  • the computing device 100 may have different processors, operating systems, and input devices consistent with the device.
  • the computing device 100 is a TREO 180, 270, 600, 650, 680, 700p, 700w/wx, 750, 755p, 800w, Centro, or Pro smart phone manufactured by Palm, Inc.
  • the TREO smart phone is operated under the control of the PalmOS operating system and includes a stylus input device as well as a five-way navigator device.
  • the computing device 100 is a mobile device, such as a
  • JAVA-enabled cellular telephone or personal digital assistant such as the i55sr, i58sr, i85s, i88s, i90c, i95cl, i335, i365, i570, 1576, i580, i615, i760, i836, i850, i870, i880, i920, i930, ic502, ic602, ic902, i776 or the iml 100, all of which are manufactured by Motorola Corp.
  • PDA personal digital assistant
  • the computing device 100 is a mobile device manufactured by Nokia of Finland, or by Sony Ericsson Mobile Communications AB of Lund, Sweden.
  • the computing device 100 is a Blackberry handheld or smart phone, such as the devices manufactured by Research In Motion Limited, including the Blackberry 7100 series, 8700 series, 7700 series, 7200 series, the Blackberry 7520, the Blackberry PEARL 8100, the 8700 series, the 8800 series, the Blackberry Storm, Blackberry Bold, Blackberry Curve 8900, and the Blackberry Pearl Flip.
  • the computing device 100 is a smart phone, Pocket PC, Pocket PC Phone, or other handheld mobile device supporting Microsoft Windows Mobile Software.
  • the computing device 100 can be any workstation, desktop computer, laptop or notebook computer, server, handheld computer, mobile telephone, any other computer, or other form of computing or telecommunications device that is capable of communication and that has sufficient processor power and memory capacity to perform the operations described herein.
  • the computing device 100 is a digital audio player.
  • the computing device 100 is a digital audio player such as the Apple IPOD, IPOD Touch, IPOD NANO, and IPOD SHUFFLE lines of devices, manufactured by Apple Inc., of Cupertino, California.
  • the digital audio player may function as both a portable media player and as a mass storage device.
  • the computing device 100 is a digital audio player such as the DigitalAudioPlayer Select MP3 players, manufactured by Samsung Electronics America, of Ridgefield Park, NJ, or the Motorola m500 or m25 Digital Audio Players, manufactured by Motorola Inc. of Schaumburg, IL.
  • the computing device 100 is a portable media player, such as the Zen Vision W, the Zen Vision series, the Zen Portable Media Center devices, or the Digital MP3 line of MP3 players, manufactured by Creative Technologies Ltd.
  • the computing device 100 is a portable media player or digital audio player supporting file formats including, but not limited to, MP3, WAV, M4A/AAC, WMA Protected AAC, AIFF, Audible audiobook, Apple Lossless audio file formats and .mov, .m4v, and .mp4 MPEG-4 (H.264/MPEG-4 AVC) video file formats.
  • file formats including, but not limited to, MP3, WAV, M4A/AAC, WMA Protected AAC, AIFF, Audible audiobook, Apple Lossless audio file formats and .mov, .m4v, and .mp4 MPEG-4 (H.264/MPEG-4 AVC) video file formats.
  • the computing device 100 comprises a combination of devices, such as a mobile phone combined with a digital audio player or portable media player.
  • the computing device 100 is a Motorola RAZR or Motorola ROKR line of combination digital audio players and mobile phones.
  • the computing device 100 is a device in the iPhone line of smartphones, manufactured by Apple Inc., of Cupertino, California.
  • a computing device 102a may request resources from a remote machine 106, while providing the functionality of a remote machine 106 to a client 102b.
  • the computing device 102a may be referred to as a client with respect to data received from the remote machine 106 (which may be referred to as a server) and the computing device 102a may be referred to as a server with respect to the second client 102b.
  • the client 102 may request resources from the remote machine 106 on behalf of a user of the client 102.
  • the computing device 100 may comprise multiple processors and may provide functionality for simultaneous execution of instructions or for simultaneous execution of one instruction on more than one piece of data.
  • the computing device 100 may comprise a parallel processor with one or more cores.
  • the computing device 100 is a shared memory parallel device, with multiple processors and/or multiple processor cores, accessing all available memory as a single global address space.
  • the computing device 100 is a distributed memory parallel device with multiple processors each accessing local memory only.
  • the computing device 100 has both some memory which is shared and some memory which can only be accessed by particular processors or subsets of processors.
  • the computing device 100 such as a multicore microprocessor, combines two or more independent processors into a single package, often a single integrated circuit (IC).
  • the computing device 100 includes a chip having a CELL BROADBAND ENGINE architecture and including a Power processor element and a plurality of synergistic processing elements, the Power processor element and the plurality of synergistic processing elements linked together by an internal high speed bus, which may be referred to as an element interconnect bus.
  • the processors provide functionality for execution of a single instruction simultaneously on multiple pieces of data (SIMD). In other embodiments, the processors provide functionality for execution of multiple instructions simultaneously on multiple pieces of data (MIMD). In still other embodiments, the processor may use any combination of SIMD and MIMD cores in a single device.
  • the computing device 100 may comprise a graphics processing unit.
  • the computing device 100 includes at least one central processing unit 121 and at least one graphics processing unit.
  • the computing device 100 includes at least one parallel processing unit and at least one graphics processing unit.
  • the computing device 100 includes at least one graphics processing unit.
  • the computing device 100 includes a plurality of processing units of any type, one of the plurality of processing units comprising a graphics processing unit.
  • a resource may be a program, an application, a document, a file, a plurality of applications, a plurality of files, an executable program file, a desktop environment, a computing environment, or other resource made available to a user of the local computing device 102.
  • the resource may be delivered to the local computing device 102 via a plurality of access methods including, but not limited to, conventional installation directly on the local computing device 102, delivery to the local computing device 102 via a method for application streaming, delivery to the local computing device 102 of output data generated by an execution of the resource on a third computing device 106b and
  • the local computing device 102 transmits output data generated by the execution of the resource to another client computing device 102b.
  • a user of a local computing device 102 connects to a remote computing device 106 and views a display on the local computing device 102 of a local version of a remote desktop environment, comprising a plurality of data objects, generated on the remote computing device 106.
  • at least one resource is provided to the user by the remote computing device 106 (or by a second remote computing device 106b) and displayed in the remote desktop environment.
  • the user of the local computing device 102 would prefer an integrated desktop environment providing access to all of the resources available to the user, instead of separate desktop environments for resources provided by separate machines. For example, a user may find navigating between multiple graphical displays confusing and difficult to use productively. Or, a user may wish to use the data generated by one application provided by one machine in conjunction with another resource provided by a different machine.
  • requests for execution of a resource, windowing moves, application minimize/maximize, resizing windows, and termination of executing resources may be controlled by interacting with a remote desktop environment that integrates the display of the remote resources and of the local resources.
  • an application or other resource accessible via an integrated desktop environment - including those resources executed on the local computing device 102 and those executed on the remote computing device 106 - is shown in a single desktop environment.
  • data objects from a remote computing device 106 are integrated into a desktop environment generated by the local computing device 102.
  • the remote computing device 106 maintains the integrated desktop.
  • the local computing device 102 maintains the integrated desktop.
  • a single remote desktop environment 204 is displayed.
  • the remote desktop environment 204 is displayed as a fullscreen desktop. In other embodiments, a plurality of remote desktop environments 204 is displayed. In one of these embodiments, one or more of the remote desktop environments are displayed in non- full-screen mode on one or more display devices 124. In another of these embodiments, the remote desktop environments are displayed in full-screen mode on individual display devices. In still another of these embodiments, one or more of the remote desktop environments are displayed in full-screen mode on one or more display devices 124.
  • direct modeling allows for easy and quick creation of three- dimensional designs, and modification through direct, on-the-fly interactions with the model geometry. Results are displayed in an intuitive what-you-see-is-what-you-get (WYSIWYG) format.
  • WYSIWYG what-you-see-is-what-you-get
  • direct modeling is easy to learn and allows for fast creation of complex models.
  • FIG. 2 A shown is a block diagram of an embodiment of creation of a chamfered three-dimensional object through direct modeling.
  • a user may create a two-dimensional square and pull the square into a three-dimensional cube.
  • the user may also create another three-dimensional prism, oriented at a 45 degree diagonal to the cube.
  • the user may then position the prism overlapping a corner of the cube, and perform a Boolean subtraction to create a chamfered edge.
  • Other methods of creating chamfers exist, including adding construction lines along the top and side faces, diagonal construction lines along the front and back faces, and subtracting the region bounded by these lines.
  • parametric modeling sometimes referred to as associative parametric modeling, feature-based modeling, or history-based modeling
  • geometry is created through a two-step process.
  • the user defines geometry construction recipes through the use of feature constructs, including extrusions, holes, cuts, fillets, chamfers, rounds, and others.
  • the parametric geometry engine interprets these recipes and creates the geometry of the model for display by a modeling and/or display engine.
  • These recipes may sometimes be referred to as feature histories, and may comprise a sequence of the different combinations of features utilized in modeling a final modeled object as the modeled object is designed.
  • FIG. 2B shown in FIG. 2B is a block diagram of an embodiment of creation of a chamfered three-dimensional object through parametric modeling.
  • a user first defines a square through associations of multiple edges.
  • edges may be defined through an association of two vertices, while in other embodiments, edges may be defined through relative position, size and angle to another edge; by a vertex, and length and direction of a vector; or by any other means.
  • the user may sketch the square, and the parametric geometry engine may interpret the geometry as an association of edges and vertices.
  • the length of the extrusion may be defined by another vertex, an explicit length, or by any other means.
  • the user creates a chamfer by defining the chamfer in terms of an object, edge, and depth.
  • a modeling or display engine interprets the instruction list or recipe to create the displayed model.
  • angular relationships may be defined in parametric CAD modelers, such as a line being defined as perpendicular to a tangent of a circle, i.e. in a direction along a line through the center of the circle and the tangent point. If the position of the circle is modified, the angle or position of the line may be correspondingly modified. However, in a direct CAD modeler, because this history is not maintained, moving the circle may result in no change to position or angle of the line, causing it to no longer be perpendicular to the circle.
  • direct modeling is a geometry-based paradigm for direct manipulation of geometry, agnostic or unaware of design intent, history, and associative relationships.
  • Direct modeling should not be confused with direct design manipulation, which refers to manually pushing, pulling, or modifying geometry as opposed to entering data into a dialog box to edit geometry, sometimes referred to as indirect design manipulation.
  • Direct design manipulation and indirect, or dialog box, design manipulation thus refer to methods of inputting data in a user interface; while direct or explicit modeling and parametric modeling thus refer to a modeling paradigm.
  • losses of geometric fidelity can occur during transfers. For example, due to truncation or rounding of position data, an object that may be constrained to contact with a second object in a parametric modeler may be placed slightly apart from the second object when imported into a direct modeler.
  • a direct modeling user interface is used for editing a model, allowing intuitive and easy manipulation of geometry, and a parametric geometry engine interprets these manipulations as history-based features to create a construction recipe.
  • a parametric geometry engine interprets these manipulations as history-based features to create a construction recipe.
  • the underlying architecture of the model remains parametric, but even though the user may not realize that history and associative relationships are being created and modified during every manipulation.
  • the present invention provides the intuitive WYSIWYG editing of direct CAD modeling, while retaining the powerful features and regenerative capabilities of parametric modelers.
  • the parametric geometry engine can recognize various direct modeling manipulations by mapping simple manipulations to traditional features. For example, pulling a face of an object may be mapped to an extrusion, pushing a subsection of a face may be mapped to a hole, a follow-me type extrusion may be mapped to a sweep, etc.
  • many direct modeling manipulations are not interpretable as traditional parametric history-based features, such as moving a surface in such a way that the topology of the surrounding geometry has to change. For example, while it may be easy to interpret a square pulled into a cube as an extruded face, rotating the top face to form a twisted prism may be difficult to interpret parametrically.
  • a first figure can be swept along a curved edge and recognized as a sweep feature, but if the curved edge is then modified, a parametric association between the edge and the sweep may be broken.
  • the parametric geometry engine may map these non-traditional features to a non-traditional, "flexible" feature, termed a flex move feature.
  • a flex move feature may comprise a parametric feature or a combination of parametric features or sub-features, and may be placed in a parametric history or recipe like any other feature.
  • the flex move feature may be a child of a prior feature or have other dependencies, and later features may be children of the flex move feature.
  • the flex move feature may comprise an ordered set of rigid translations and rotations of a set of entities or surfaces, a set of modifiable dimensions, or a set of assembly constraints that fully define the position and orientation of the geometry selection.
  • the flex move feature may indicate to delete geometry from a position prior to the ordered translations or rotations. For example, in one embodiment in which a first object intersecting a second object along an intersection line is moved away from the second object, the flex move feature may cause the parametric geometry engine to delete the intersection line after the move. This prevents geometry caused by the prior location of the moved entity from leaving artifacts behind.
  • the flex move feature may indicate to close openings left in surfaces or edges or other solid entities due to the deletion or movement of the geometry. For example, moving an object from a prior position intersecting a second solid object may result in a hole being left in a surface of the second solid object.
  • the flex move feature may cause the parametric geometry engine to close this hole.
  • the flex move feature may act on a surface, a collection of surfaces within a solid geometrical entity, or a collection of surfaces belonging to a quilt.
  • the flex move feature may act on planes, axes, points, complex systems, or combinations of any of these.
  • movement of geometric entities may cause the parametric geometry engine to create or modify the geometry of the moved entities or neighboring entities to re-attach the moved entities to the model. For instance, moving an edge to a position apart from a surface may cause the parametric geometry entity to extend the edge and/or surface, create tangent lines of curves, or create non-tangential straight lines to reconnect and close the intervening space in a solid surface or object.
  • the parametric geometry engine may map a non- traditional feature to a new feature termed a flex move copy feature, or sometimes a flex copy feature.
  • the flex move copy feature may comprise a parametric feature similar to a flex move feature, identifying translations and rotations of geometric entities, but without deleting geometry from the prior position of the entities.
  • flex move and flex move copy features may be placed in a parametric feature history. In one embodiment, these features may be placed as dependent or child features of the geometry on which they act. In a further embodiment, further modifications to the moved or copied geometry, including traditional features such as extrusions, revolves, sweeps, or others, or further moves or copies, may be created as dependent or child features of the flex feature. Accordingly, this allows the parametric geometry engine to properly regenerate and recalculate geometry as a user makes changes throughout the parametric recipe.
  • the parametric geometry engine may map relationships created in the direct modeling user interface to parametric features. For example, in one such embodiment, a user may create a symmetric or mirrored copy of a geometric entity or entities. The parametric geometry engine may interpret this as creation of a flexible symmetric feature.
  • a flexible symmetric feature may comprise a group header feature for a plurality of symmetric or mirrored entities, and an identification of a plane of symmetry. Because of the association between the entities in the parametric feature list, the parametric engine may later apply an edit to one entity to the symmetric or mirrored entity automatically during recalculation or regeneration.
  • the parametric geometry engine may interpret the symmetric or mirrored entities as a traditional mirror feature.
  • the user may create a pattern of geometric entities, such as a pattern of evenly spaced holes around a disc. Again, systems that simply import and translate direct models into parametric systems may not be able to interpret these entities as a common pattern of holes, and may identify each hole as a distinct and unrelated feature.
  • the parametric engine of the present invention can create a flexible pattern feature.
  • the flexible pattern feature may comprise a group header feature for a plurality of flex move copy features; or a pattern of related and associated members, such that modification to one member propagates the modification to all other members.
  • the parametric geometry engine may interpret the pattern of geometric entities as a traditional pattern feature.
  • Some versions of these systems allow only overall approval or rejection of the direct modeling edits, while others may do limited comparisons to detect traditional features such as extrusions or sweeps and allow some basic subdivisions of edits for approval or rejection.
  • history and dependencies are lost in these systems, changes cannot be tracked on a granular, individual-edit level. For example, a user may be able to
  • a designer using a parametric system may arrive at an end geometry for a part through any of several different operations.
  • Features that are not dependent upon each other may, in some embodiments, be created in any order - a sweep may be applied on one part of a model and an extrude on another part, or the extrude may be created first followed by the sweep.
  • the order of creation may be representative of the intent of the designer. However, because order is not recorded in a direct modeling system, this representation of intent may be lost when translating the model between parametric and direct systems, even where individual features are recognized.
  • a user of a parametric modeling user interface may review, accept, and reject individual changes or modifications made to a model by a user of a direct modeling user interface without having to import the model after each change.
  • the user of the parametric modeling user interface may reject a modification made by the user of the direct modeling interface to a first object, and responsive to the rejection and a dependent relationship of a second object to the first object, the geometry engine may recalculate geometry of the second object.
  • a computing device 100 may include or connect to storage 128.
  • storage 128 may comprise a network storage device or external storage device.
  • Storage device 128 may include one or more models 310, which may include one or more objects 312a and 312b, referred to generally as objects 312.
  • an object may comprise one or more features 314a-314n (referred to generally as features 314) which may comprise a history-based or ordered construction recipe.
  • a first feature may be a child of a second feature, or conversely the second feature may be a parent of the first feature.
  • a feature may be referred to as a child of a parent feature if it is dependent upon the parent feature for some aspect of its geometry or other data.
  • an object may comprise one or more sub-objects 312'a or 312'b, referred to generally as sub-objects 312'.
  • a sub-object 312' may comprise further sub-objects and/or one or more features 314.
  • Computing device 100 may execute or communicate with a CAD application 300.
  • a computing device 100 executes a CAD application 300.
  • the application may comprise a CAM application, CAE application, or other application for two or three-dimensional design, modeling, or analysis.
  • CAD application 300 may comprise a program, application, service, sub-routine, or other executable logic for creating, modifying, analyzing, and modeling two or three-dimensional geometry.
  • CAD application 300 may be used for engineering, manufacturing, architectural, animation, modeling, artistic, or other design or manufacturing functions.
  • CAD application 300 may comprise one or more of a geometry engine 302, a display engine 304, a parametric modeling user interface (UI) 306, a direct modeling UI 308, a modeling library 316, regeneration instructions 317, and a constraint library 318.
  • modeling library 317 may comprise a library, API, or other database of executable routines to enable the creation and evaluation of CAD geometry.
  • modeling library 316 may contain the feature history and model deltas of a model 310 or object 312. For example, as the design process of a modeled object evolves, the feature history may be sequentially established and stored by the modeling library 316. In many embodiments, modeling library 316 may be considered part of storage 128 and accessed by CAD application 300.
  • CAD application 300 may comprise a constraint library 318, which may function in conjunction with the modeling library 316.
  • Constraint library 318 may comprise a library of functions for controlling the governing dimensions and parameters of a design, driving the placement of assembly components and interrelating objects. For example, when a project is initiated or during the design process, certain project constraints can be provided for the modeled object. These constraints can include dimensional constraints, material constraints, weight constraints, strength constraints, or any other type of constraints.
  • the constraint library 318 may be used to monitor the design process and guide the placement and characteristics of the features as they are added to the modeled object to ensure the final result fits within a predetermined specification.
  • CAD application 300 may also include a library of regeneration instructions
  • Regeneration instructions 316 may utilize the constraint library 318 to specify the location of features and then construct the features specified in the modeling library 316.
  • the geometry engine 302 of CAD application 300 may comprise an agent, program, service, routine, logic, or other executable functions for executing parametric functions and instructions in the libraries 316-318.
  • Geometry engine 302 may comprise hardware, software, or a combination of hardware and software.
  • geometry engine 302 may comprise dedicated processing units for executing CAD functions and features.
  • geometry engine 302 may utilize modeling library 316 as an application programming interface (API) for generating or recalculating geometry or other features of a model 310.
  • API application programming interface
  • CAD application 300 may include a display engine 304.
  • Display engine 304 may comprise an agent, program, service, routine, logic, or other executable functions for rendering and outputting or displaying three-dimensional surfaces and objects.
  • display engine 304 may comprise functionality for ray tracing, scan-line rendering, ray-casting, shading, texture mapping, or other functions for generating realistic or non-realistic graphics.
  • CAD application 300 may include either or both of a parametric modeling UI 306 and a direct modeling UI 308.
  • parametric modeling user interfaces show a historical recipe or instruction set of features, and relationships or dependencies between these features. The user is aware of features that they create, and regeneration and dependencies are made obvious and apparent to the user.
  • a direct modeling user interface does not display a history, recipe or features.
  • the user may use a direct modeling
  • UI 308 to interact with geometry of a model, and the interactions are interpreted by the history-based geometry engine 302 as features.
  • a single geometry engine may be used for both the parametric modeling UI and the direct modeling UI.
  • a user may create feature- based geometry of a CAD object using a CAD application.
  • the user may modify geometry of the CAD object with a direct modeling user interface (UI).
  • UI direct modeling user interface
  • the CAD application may store the modified geometry as feature-based geometry.
  • a user may use a CAD application executed by a processor of a computing device to create a recipe of feature-based geometry of a CAD object or model.
  • the user may use a direct modeling user interface of the CAD application to modify geometry of the CAD object or model.
  • the direct modeling user interface hides history and/or parametric features of the CAD object or model from the user. Accordingly, in one embodiment, the user may be unaware that a modification of the CAD object or model in the direct modeling UI may cause creation and/or modification of a parametric CAD object and/or dependencies or
  • the CAD application may store the modified geometry as parametric features or modifications to parametric features of the CAD object.
  • the CAD application may store the modified geometry as one or more traditional parametric features, such as sweeps, revolves, holes, cuts, extrudes, or similar features.
  • the CAD application may store the modified geometry as one or more flexible parametric features, such as a flex move or flex move copy feature.
  • the CAD application may store the modified geometry as a combination of traditional and flexible parametric features.
  • the CAD application may store one or more relationships or dependencies between the modified geometry feature or features and one or more existing geometry features, such as through a history or tree dependency representation.
  • the CAD application may regenerate geometry data of other objects with dependencies on the modified object.
  • the CAD application may direct a display engine to render or display regenerated geometry data.
  • FIG. 3C Shown in FIG. 3C is a flow chart of another embodiment of a method of computer-aided design.
  • a user may create a first feature of a CAD object using a direct modeling UI of a CAD application executed by a processor of a computing device.
  • the user may create a second, dependent feature of the CAD object using the direct modeling UI.
  • the user may modify the first feature of the CAD object using the direct modeling UI.
  • the CAD application may recalculate geometry of the second feature of the CAD application.
  • a user may create a first feature of a CAD object using a direct modeling user interface.
  • the user may be unaware that they are creating a feature.
  • an underlying parametric geometry engine may interpret the user's commands and direct manipulations of geometry in the direct modeling UI as creation and modification of parametric features.
  • the user may create a second feature of a
  • the user may be unaware both that they are creating a feature and that they are creating a feature with a dependent relationship on the first feature.
  • the user may modify the first feature of the
  • the user may be unaware that they are modifying a feature.
  • the user may modify a surface, edge, vertex or other entity of the CAD object using the direct modeling user interface, without apparently modifying an existing first feature or the user being aware that a feature is associated with the entity.
  • the user may modify geometry of the first feature using direct modeling user interface.
  • the CAD application may recalculate or regenerate geometry of the second feature. This may be done responsive to the user's modification of the first feature.
  • the CAD application may direct a display engine to render or display the regenerated geometry data.
  • FIG. 3D shown is a flow chart of yet another embodiment of a method of computer-aided design.
  • this embodiment describes mapping, by the geometry engine, direct modeling edits to traditional and flexible parametric features.
  • a user of a direct modeling user interface of a CAD application makes an edit or modification to a CAD model.
  • a parametric geometry engine of the CAD application determines if it can map the edit or modification to a traditional parametric feature. If so, at step 342, the parametric geometry engine creates or modifies a parametric feature in a history-based parametric feature recipe. If not, at step 344, the parametric geometry engine creates or modifies a flexible parametric features, such as a flex move or flex move copy feature, as discussed above.
  • the parametric geometry engine determines if it can recognize a pattern or symmetry associated with the feature. In one embodiment, this may comprise identifying an explicit pattern or symmetry creation command in the direct modeling user interface by the user. In another embodiment, this may comprise identifying an implicit pattern or symmetry creation, such as a copy and paste operation by the user in the direct modeling user interface. If the parametric geometry engine can recognize a pattern or symmetry, then at step 346, the parametric geometry engine may create or modify a flexible pattern or flexible symmetry feature of the parametric model. In some embodiments, steps 340-346 may be repeated.
  • the parametric geometry engine may recalculate or regenerate one or more features according to the parametric features list, responsive to the user's edit to geometry.
  • modification by the user in the direct modeling user interface of an entity or feature associated with a flexible pattern or flexible symmetry feature may cause the parametric geometry engine to propagate the edit to corresponding entities or features of the pattern or symmetry feature.
  • only the most recent feature the user has created in the direct modeling user interface may be recalcualted or regenerated. Because direct modeling CAD typically does not regenerate features not modified by a user because of the lack of parametric dependencies, history, and relationships, it may be confusing to a user if multiple features are regenerated in response to a single operation.
  • additional features may be recalculated or regenerated, depending on type or class of feature. For example, certain types of features may be easier to regenerate, or the user may be confused if certain types of features are not regenerated. Accordingly, in one such embodiment, these features may be regenerated, even if others are not.
  • a first surface may be constrained in a parametric environment to be parallel to a second surface, such that rotating one causes a geometry engine to recalculate and rotate the other accordingly.
  • a model may include engineering constraints for material selection or safety reasons, such as requiring a specified thickness of material around a hole to be drilled, requiring a roll bar of a passenger compartment to be at least a certain diameter, or requiring an engine part to be a minimum distance from an operator position. If these constraints are lost during translation to a direct modeling environment, a user could easily move parts in ways that violate safety rules, resulting in higher manufacturing expense to redesign later. Additionally, if the model is then returned to the parametric modeling environment, because the constraints were lost during the first translation, they may not reappear. As a result, a user of the parametric modeling environment may believe that, because the parametric features of the imported model do not show engineering constraints that other parametric models may include, no such constraints exist.
  • constraints of features may be retained during direct modeling.
  • a geometry engine may compare an attempted edit to a feature in a direct modeling user interface to an existing constraint, and, in one embodiment, prevent the user from completing the edit.
  • the geometry engine may present a dialog box to the user and allow them to reject the edit, override or delete the constraint, modify the constraint, or take other actions as appropriate.
  • the geometry engine may allow one user to edit the feature, but not another user. This allows for ownership or user-based permissions of surfaces and features in a direct modeling user interface.
  • a lead designer may create a base set of features that only the lead designer can edit, such as a structural frame or powertrain, and secondary designers may then add, delete and modify additional optional features, such as seats, windows, electrical subsystems, or other elements.
  • a feature controlled in these methods may be referred to as a read-only surface or feature, or a constraint-locked feature.
  • a user may create a feature constraint in a parametric modeling user interface of a CAD application.
  • the feature constraint may comprise a geometric constraint, such as a specified orientation with respect to or distance from another feature or other similar constraint.
  • the feature may comprise an engineering constraint, such as a material type, strength requirement, maximum weight allowance, or other similar constraint.
  • the user may attempt to edit the feature in a direct modeling user interface of the CAD application.
  • attempting to edit the feature may comprise performing a direct manipulation on the feature, such as a push, pull, move, rotate, or other manipulation, or may comprise editing product information of the feature, such as a material, paint, surface, or other manufacturing aspect of the feature.
  • the parametric geometry engine may enforce the feature constraint in the direct modeling user interface, responsive to the user's attempt to edit the feature.
  • enforcing the feature constraint may comprise rejecting or preventing the edit, presenting a dialog to the user, allowing the user to override or modify the constraint, enforcing permission-based editing by user or group ownership, or other enforcement mechanisms.
  • a completed design may be used for manufacturing of many copies of the designed product.
  • a consumer automobile company may create a design for a new model of car, and then use an assembly line to create in excess of a hundred cars per day.
  • a design may be used only once or twice.
  • the large towing engines for commercial semi-trailers commonly referred to as tractors, prime movers, trucks, or big rigs, are frequently heavily customized prior to manufacture.
  • One customer may request an extended cab, double-axle, five-speed manual transmission model, and another customer may request a regular cab, triple-axle, four speed automatic transmission model.
  • one aspect of the present invention includes a method and system for creation of a dynamically-configurable product design, sometimes referred to as business driven assemblies.
  • Such product designs may be referred to as driven by a bill-of- materials (BOM) or selection of options by a customer, sales representative, or vendor, and may be performed responsive to a product lifecycle management (PLM) plan.
  • BOM bill-of- materials
  • PLM product lifecycle management
  • the system allows a customer to define specifications of a product, and then dynamically generates a CAD model responsive to the defined specifications or selected options.
  • FIG. 4A Shown in FIG. 4A is a block diagram of an embodiment of a system for creation of business driven assemblies.
  • a computing device 100 executes a CAD application 300 and includes or communicates with storage 128, which includes one ore more models 310. Each object 312 and/or sub-object 312' may include one or more variants 406.
  • the computing device 100 may also execute or communicate with another computing device executing a product lifecycle management (PLM) application 400.
  • PLM application 400 may, in some embodiments, comprise a part database 402 and/or a part selection engine 404.
  • a computing device includes or executes a PLM application 400.
  • PLM application 400 executes on a second computing device that communicates with or passes data to computing device 100.
  • PLM application 400 may comprise an application, program, routine, web service, applet, or other executable instructions for configuring a product through selection of one or more predetermined options or variants.
  • PLM application 400 also comprises a user interface for presenting a part database 402 or portion thereof, and allowing a customer, sales
  • a part database 402 may comprise a database, file, library, or other set of one or more parts, and may include an identification of one or more features of a part.
  • the part database may include descriptions, costs, weights, materials and sub-parts needed, part numbers, or other information useful to a customer, sales representative, or manufacturer.
  • Part database 402 may be used, along with a part selection engine 404 and/or a user interface to allow a customer to configure options for a product design and communicate said selected options to a parametric geometry engine 302 of a CAD application 300.
  • objects 312 and/or sub-objects are objects 312 and/or sub-objects
  • a variant 406 may comprise an alternate assembly to be used in a model or product design.
  • a variant 406 may include a default variant to be used in the absence of a selection by a user.
  • a variant 406 may include a generic variant, sometimes referred to as a shape generic, which may be used as a placeholder in a model for later generation of a custom feature where a user wishes to apply a custom option that has not yet been created.
  • a user may select from a predetermined list of options for truck tires including variations in size, width, and tread type and depth, or may select a generic tire shape, possibly just a torus, to be placed in the model until a tire is later selected.
  • a variant 406 may comprise one or more interfaces or
  • a locator handle or interface may comprise a constraint or joint-based interface used for positioning of an adjacent object.
  • a vehicle door object may include different options such as power doors or windows, which may require different routing of electrical cables.
  • different variants may have different centers of gravity or require different mounting options, and thus require different hinge positions.
  • each variant may include one or more locator interfaces for a door hinge that correspond to one or more hinge elements on the vehicle frame.
  • the geometry engine may automatically adjust positioning of the frame and/or door to match up the door hinges and the frame hinges.
  • a shaper handle or interface may cause the parametric geometry engine to adjust the geometry of an adjacent object.
  • different variants of engines may have exhaust ports or coolant intake ports in different positions.
  • a shaper interface at an exhaust port for instance, may correspond to a shaper interface on a front pipe of an exhaust system. Responsive to the relative positions of the shaper interface, the geometry engine may automatically extend, extrude, rotate, enlarge or shrink, or otherwise manipulate the front pipe of the exhaust system to match the position and orientation of the exhaust port.
  • shaper interfaces may be used in an electrical subsystem to cause the geometry engine to automatically extend and route cables to meet connectors of adjacent modules.
  • the modular structure 310 may comprise a parametric feature- based recipe of objects 312, sub-objects 312', sub-sub-objects 312", or other levels of objects as discussed above.
  • Associative links and dependencies of the model are shown in the structure 310 as branches in the tree diagram.
  • a mower frame 312a is the base object for a mower, and has three children, the mower deck 312'a, engine 312'b, and operator compartment 312'c.
  • the engine 312'b has two child objects, the hydrostatic transmission 312"a and mechanical transmission 312"b.
  • the operator has two child objects, the hydrostatic transmission 312"a and mechanical transmission 312"b.
  • compartment 312'c has two child objects, seat 312"c and rollover protection 312"d.
  • seat 312"c has two child objects, seat 312"c and rollover protection 312"d.
  • Several of these component objects are visible in the three-dimensional model 315, which is included for clarity.
  • the feature-based recipe does not include an image of the 3D model, but rather the 3D model is generated by a display engine of a CAD application.
  • three components are outlined in dotted line, to signify that variants of these components exist for a user to select for product configuration.
  • an application may present the user with a tree diagram such as the one shown for selecting variant parts, while in other embodiments, configuration options may be presented in alternate manners, such as a configuration page of a web site, or even a printed form with checkboxes.
  • a tree diagram such as the one shown for selecting variant parts
  • configuration options may be presented in alternate manners, such as a configuration page of a web site, or even a printed form with checkboxes.
  • FIG. 4B is provided primarily as an abstraction to show dependencies of objects, in many embodiments, the tree diagram may also comprise part of a user interface.
  • FIG. 4C shown is a tree diagram of an embodiment of a plurality of variants of a variable module in an example of a business driven assembly.
  • one of the configurable modules presented in FIG. 4B, the seat 312"c comprises four variants 406a-406d, referred to generally as variants 406.
  • Each variant 406 comprises one or more geometric entities and features and may be predesigned or configured by a user of the system.
  • a variant may comprise a shape generic that may be used as a placeholder in the model, representative of the object.
  • each variant may include one or more locator and/or shaper interfaces.
  • each seat 406b-406d includes a similar mounting assembly 408.
  • mounting assembly 408 can be seen where it connects to a portion of operator compartment 312'c and/or frame 312a.
  • each seat 406a-d may include a locator interface to allow the parametric geometry engine to automatically orient the seat properly in the model against a corresponding interface on the operator compartment 312'c and/or frame 312a.
  • each seat 406a-d may include a shaper interface to reposition mounting hardware of operator compartment 312'c and/or frame 312a as necessary.
  • locator and shaper interfaces may be used to adjust position of the rollover protection 312" d, as well as steering and control elements, shock absorbers, or any other feature of the model.
  • a user or designer may create a modular structure of a plurality of modules of a dynamically configurable product design using a CAD application.
  • the plurality of modules may comprise at least one variable module comprising a plurality of variants or a default and at least one variant.
  • the user may select a variant of the at least one variable module to use in the dynamically configurable product design.
  • the CAD application or a geometry engine of the CAD application may place the selected variant in a geometric model of the dynamically configurable product design.
  • the CAD application may modify position or geometry of a module adjacent to the placed selected variant in the geometric model, responsive to one or more constraints of the placed selected variant.
  • a user of a computer aided design application may create a modular structure of a plurality of modules of a dynamically configurable product design.
  • the plurality of modules may comprise at least one variable module.
  • the modular structure may comprise an historic feature-based parametric construction recipe, where dependencies between one or more objects and/or features may implicitly create the modular structure. For example, in a parametric history with a base object, and two dependent objects, the dependencies between the dependent objects and the base object may be considered a modular structure.
  • a module may refer to an individual object or a feature, but in most embodiments, a module may refer to a group of objects or features comprising a sub-assembly of a product, such as a functional module such as a keypad or an engine, or a structural module, such as a product face plate or vehicle frame.
  • a functional module such as a keypad or an engine
  • a structural module such as a product face plate or vehicle frame.
  • functional or structural modules other classifications of modules may be used without limitation.
  • variable module may comprise a plurality of alternate sub-assemblies, with common connections to adjacent modules.
  • variable module may include a default sub-assembly or variant.
  • variable module may include a generic shape sub-assembly with only basic features.
  • a common connection to an adjacent module of the subassembly may comprise a locator interface or a shaper interface, as discussed above, which may be used by a parametric geometry engine to modify positioning of modules or geometry of modules.
  • a user may select a variant of the variable module to use in the dynamically configurable product design.
  • the user may use a selection interface of a PDM application, while in another embodiment, the user may use a web form, an order form, a catalog, or any other form for selecting a variant to use in the design.
  • the CAD application or a geometry engine of the CAD application may place the selected variant in a geometric model of the dynamically configurable product design.
  • placing the selected variant in a geometric model may comprise executing, by the geometry engine, a feature list or recipe of the variant to construct the variant in the geometric model.
  • the CAD application or geometry engine may modify positioning or geometry of the variant or of a module adjacent to the placed selected variant in the geometric model responsive to one or more constraints of the placed selected variant. These one or more constraints may be identified by one or more locator or shaper interfaces, as discussed above.
  • the CAD application or geometry engine may translate and/or rotate the selected variant to align one or more locator interfaces of the selected variant with one or more locator interfaces of one or more adjacent modules or objects.
  • the CAD application or geometry engine may translate and/or rotate the one or more adjacent modules or objects to align one or more locator interfaces of the one or more adjacent modules or objects with one or more locator interfaces of the selected variant.
  • the CAD application or geometry engine may scale or stretch the selected variant to cause one or more shaper interfaces of the variant to align with one or more shaper interfaces of one or more adjacent modules or objects.
  • the CAD application or geometry engine may extend, twist, or otherwise route geometry of the variant to align one or more shaper interfaces of the variant with one or more shaper interfaces of an adjacent module or object.
  • the CAD application or geometry engine may extend, twist, or otherwise route geometry of an adjacent module or object to align one or more shaper interfaces of the adjacent module or object with one or more shaper interfaces of the variant.
  • the system may load all parts or features of a CAD model at once.
  • a geometry engine may execute, regenerate, or recalculate each step of a history-based feature list to construct a CAD model for display by a display or rendering engine.
  • a simple model with only a few features, this can be done quickly.
  • complicated models may include thousands or tens of thousands of parts, each comprising dozens or hundreds of individual features.
  • a model of a truck may comprise separate parts for the frame, axels, universal joints, elements of the power train, elements of brake assemblies, electrical subsystems, lights, hydraulics, windows, seats, instruments, exhaust systems, fuel lines, etc.
  • the engine alone may comprise several hundred parts and several thousand features.
  • CAD designers break a CAD model into subsections and design each subsection in different models.
  • a CAD designer may have a single model that only includes the electrical systems, and a second model that only includes the non-moving parts of the frame, and a third model that only includes the engine fuel/exhaust system, etc.
  • this may lead to confusion and inefficiencies, as well as errors where a modification is made to one subsection, such as engine mounts of a frame, that will require modifications in a different subsection, such as the engine itself. Because these parts are not in the same model, the designer must perform complicated manual bookkeeping to ensure that the models are synchronized and compatible. Additionally, the ability to perform engineering and manufacturing analysis on the model is reduced, because features such as weight and center of gravity will be a result of a combination of all of the subsections.
  • one aspect of the present invention features systems and methods for dynamically loading portions of a computer-aided design model on demand.
  • a CAD application may progressively load portions of a CAD model as needed by a user for a particular design task. This reduces both memory and processing
  • a user may retrieve a model of a vehicle in order to assemble one or more new components.
  • the CAD application may load the vehicle structure and graphics for display.
  • the user may then select new components to add, such as a transmission assembly.
  • the CAD application may load the transmission structure and graphics for display.
  • those selected geometry references may be loaded by the CAD application, without loading the entire geometry of the model.
  • FIG. 5A shown in FIG. 5A is a three-dimensional view of an example of a computer-aided design model 500 of a truck.
  • the CAD application may load graphics of the model 500, which in one embodiment, may be stored with the model or in a separate file. In another embodiment, graphics may be generated dynamically, but without loading geometry of the entire model.
  • the CAD application may determine a shell or set of outer, visible surfaces of the model, and store a geometric representation of these surfaces. This shell representation may be used to dynamically generate graphics, without needing to load geometry of underlying, hidden or internal surfaces.
  • the CAD application may also load a modular structure of the model, as discussed above in connection with FIGs. 4A-4D.
  • a modular structure may comprise a structure of individual objects or features.
  • a modular structure may include a base portion of a seat, a back rest, internal framing, one or two armrests, cushions or other padding, various seams and stitching, etc., each with dependencies and relationships with other geometric entities and parts.
  • the CAD application may load a portion of a modular structure, such as the group of elements referred to as the seat in the above example.
  • the CAD application may load an overall modular structure of the truck, including the frame, cab, engine compartment, powertrain, etc., without loading individual elements of each sub-assembly.
  • the user may select a sub-assembly such as engine model 502. Responsive to the selection, the CAD application may load a modular structure of the engine model and graphics and geometry data of the engine.
  • the graphics data may comprise graphics data of only external or visible elements of the engine, and may be stored or generated as discussed above.
  • FIG. 5C is a three-dimensional view of a sub-assembly of the sub-assembly of the example of the computer-aided design model.
  • the user may select a sub-assembly of the engine such as engine piston model 504.
  • the CAD application may load a modular structure of the engine piston model and graphics and geometry data of the engine piston.
  • the graphics data may comprise graphics data of only external or visible elements of the engine piston, and may be stored or generated as discussed above.
  • geometry and graphics data of the second object may be loaded. For example, if the user attempts to modify the diameter of the engine piston, and the diameter has a constraint or relationship to a surrounding cylinder, the CAD application may load geometry of the cylinder to enforce constraints and recalculate or regenerate features as necessary. Accordingly, the user has full ability to manipulate and edit all features of even a highly complex model with reduced memory and processing requirements.
  • a CAD application may load a first portion of a CAD model.
  • the first portion of the CAD model may comprise a modular structure of the CAD model.
  • the modular structure may comprise one or more subassemblies or modules of the CAD model.
  • the first portion of the CAD model may comprise graphics and geometry data of a first element of the modular structure.
  • the first element of the modular structure may comprise a root element, assembly, or module of the modular structure.
  • the graphics data may comprise a shell or outer surface or surfaces of the modular structure or CAD model.
  • the user may select a second element of the modular structure.
  • the second element may comprise a sub- element of the modular structure.
  • the second element may comprise a non-directly related element or sub-assembly in the modular structure.
  • selection by the user of a non-directly related element may cause the CAD application to unload graphics and geometry data of the first element from memory.
  • the CAD application may load a second portion of the CAD model the second portion comprising a modular structure of the selected second element.
  • the modular structure of the second element may comprise one or more subassemblies or modules of the second element.
  • the second portion of the CAD model may comprise graphics and geometry data of the selected second element.
  • the graphics data may comprise a shell or outer surface or surfaces of the selected second element.
  • steps 512-514 or 510-514 may be repeated.
  • a user may select one or more items of geometry data of a third element of the modular structure for defining a constraint of geometry data of the first element or the second element; and the CAD application may load, responsive to the selection, the selected one or more items of geometry data of the third element.
  • loading graphics and geometry of the third element may comprise not loading unselected items of geometry data of the third element.
  • the CAD application may load a diameter of the cylinder when the user attempts to edit a diameter of the piston, but not load a depth or other features of the cylinder if they are not needed.
  • selecting a non-directly related element of the model may cause the CAD application to unload earlier loaded portions of the model, to free up memory.
  • loading graphics and geometry of an element may comprise loading one or more location interfaces or shaper interfaces of the element.
  • loading graphics and geometry data of an element may comprise identifying one or more visible or external surfaces of the element, and loading graphics and geometry data of the identified visible or external surfaces of the element.
  • selecting the element may comprise adding the element to the modular structure of a previous element.
  • systems described above may provide multiple ones of any or each of those components and these components may be provided on either a standalone machine or, in some embodiments, on multiple machines in a distributed system.
  • the systems and methods described above may be implemented as a method, apparatus or article of manufacture using programming and/or engineering techniques to produce software, firmware, hardware, or any combination thereof.
  • the systems and methods described above may be provided as one or more computer-readable programs embodied on or in one or more articles of manufacture.
  • article of manufacture as used herein is intended to encompass code or logic accessible from and embedded in one or more computer-readable devices, firmware, programmable logic, memory devices (e.g., EEPROMs, ROMs, PROMs, RAMs, SRAMs, etc.), hardware (e.g., integrated circuit chip, Field Programmable Gate Array (FPGA), Application Specific Integrated Circuit (ASIC), etc.), electronic devices, a computer readable non-volatile storage unit (e.g., CD-ROM, floppy disk, hard disk drive, etc.).
  • the article of manufacture may be accessible from a file server providing access to the computer-readable programs via a network transmission line, wireless transmission media, signals propagating through space, radio waves, infrared signals, etc.
  • the article of manufacture may be a flash memory card or a magnetic tape.
  • the article of manufacture includes hardware logic as well as software or programmable code embedded in a computer readable medium that is executed by a processor.
  • the computer-readable programs may be implemented in any programming language, such as LISP, PERL, C, C++, C#, PROLOG, or in any byte code language such as JAVA.
  • the software programs may be stored on or in one or more articles of manufacture as object code.

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • Evolutionary Computation (AREA)
  • Geometry (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Processing Or Creating Images (AREA)

Abstract

La présente invention concerne des procédés et des systèmes de création d'une conception de produit configurable de façon dynamique, d'interopérabilité paramétrique directe dans la conception assistée par ordinateur, de chargement dynamique de parties d'un modèle de conception assistée par ordinateur à la demande, et/ou d'application de contraintes paramétriques dans une interface de modélisation directe en conception assistée par ordinateur.
PCT/US2011/058406 2010-10-28 2011-10-28 Procédés et systèmes de conception assistée par ordinateur WO2012058604A2 (fr)

Priority Applications (2)

Application Number Priority Date Filing Date Title
EP11837204.4A EP2633448A4 (fr) 2010-10-28 2011-10-28 Procédés et systèmes de conception assistée par ordinateur
JP2013536886A JP6000267B2 (ja) 2010-10-28 2011-10-28 コンピュータ支援設計のための方法およびシステム

Applications Claiming Priority (8)

Application Number Priority Date Filing Date Title
US12/913,998 US20120109589A1 (en) 2010-10-28 2010-10-28 Methods and systems for direct-parametric interoperability in computer-aided design
US12/914,008 US8566066B2 (en) 2010-10-28 2010-10-28 Enforcing parametric constraints in a direct modeling interface in computer-aided design
US12/913,992 2010-10-28
US12/913,992 US8589128B2 (en) 2010-10-28 2010-10-28 Methods and systems for creation of a dynamically configurable product design
US12/913,998 2010-10-28
US12/914,008 2010-10-28
US12/914,001 2010-10-28
US12/914,001 US8890867B2 (en) 2010-10-28 2010-10-28 Methods and systems for dynamically loading portions of a computer-aided design model on demand

Publications (2)

Publication Number Publication Date
WO2012058604A2 true WO2012058604A2 (fr) 2012-05-03
WO2012058604A3 WO2012058604A3 (fr) 2012-07-05

Family

ID=45994820

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2011/058406 WO2012058604A2 (fr) 2010-10-28 2011-10-28 Procédés et systèmes de conception assistée par ordinateur

Country Status (3)

Country Link
EP (1) EP2633448A4 (fr)
JP (2) JP6000267B2 (fr)
WO (1) WO2012058604A2 (fr)

Cited By (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2014130735A1 (fr) * 2013-02-20 2014-08-28 Brigham Young University Système et procédés d'édition de cax multiutilisateurs de cohérence de données
WO2014193659A1 (fr) * 2013-05-28 2014-12-04 Siemens Product Lifecycle Management Software Inc. Modélisation géométrique avec mélanges mutuellement dépendants
EP2891998A1 (fr) * 2013-12-31 2015-07-08 Dassault Systèmes Conception d'un objet modélisé en trois dimensions
JP2016517123A (ja) * 2013-04-30 2016-06-09 シーメンス プロダクト ライフサイクル マネージメント ソフトウェアー インコーポレイテッドSiemens Product Lifecycle Management Software Inc. バリエーショナルシステムにおける曲線
CN106415551A (zh) * 2014-05-28 2017-02-15 西门子产品生命周期管理软件公司 对于定位任务的智能约束选择
CN106416145A (zh) * 2014-05-28 2017-02-15 西门子产品生命周期管理软件公司 用于海量约束网络的创建和编辑的方法
CN106897966A (zh) * 2017-01-24 2017-06-27 刘守乾 一种图像合成方法及装置
CN107408142A (zh) * 2015-02-25 2017-11-28 昂沙普公司 基于多用户云参数特征的3d cad系统
CN110249328A (zh) * 2017-05-08 2019-09-17 西门子产品生命周期管理软件公司 用于已建模系统的接口的接口工件生成
WO2020089240A1 (fr) * 2018-10-29 2020-05-07 Lenze Automation Gmbh Procédé pour configurer un système d'entraînement pour un dispositif technique
CN112734922A (zh) * 2021-01-12 2021-04-30 中铁工程设计咨询集团有限公司 一种铁路路基的三维设计方法
RU2764382C1 (ru) * 2020-10-13 2022-01-17 федеральное государственное автономное образовательное учреждение высшего образования "Санкт-Петербургский политехнический университет Петра Великого" (ФГАОУ ВО "СПбПУ") Способ параметрического моделирования высоконапорных гидроэнергетических объектов
WO2023163708A1 (fr) * 2022-02-25 2023-08-31 Siemens Industry Software Inc. Procédé de modélisation de composants de conception technique avec des motifs et des contraintes
CN117725642A (zh) * 2023-12-29 2024-03-19 重庆宇海精密制造股份有限公司 笔电模具设计用的动态建模方法及装置

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2990970A1 (fr) * 2014-08-26 2016-03-02 Dassault Systèmes Exécution d'une mise à jour séquentielle
KR102435917B1 (ko) * 2019-03-06 2022-08-24 주식회사 클루 전산응용해석 지식 거래 시스템의 제어 장치, 제어 방법 및 이를 기록한 기록매체

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050071135A1 (en) * 2003-09-30 2005-03-31 Vredenburgh David W. Knowledge management system for computer-aided design modeling
US20050203718A1 (en) * 2004-03-12 2005-09-15 Carek Rick A. Knowledge management system with integrated product document management for computer-aided design modeling
US20070198230A1 (en) * 2006-02-20 2007-08-23 Ford Global Technologies, Llc Parametric modeling method and system for conceptual vehicle design
US20080040080A1 (en) * 2006-05-09 2008-02-14 Seockhoon Bae System and Method for Identifying Original Design Intents Using 3D Scan Data
US20080201113A1 (en) * 2005-03-14 2008-08-21 Holomar, Inc. Methods and Systems for Combining Models of Goods and Services
US20080247636A1 (en) * 2006-03-20 2008-10-09 Siemens Power Generation, Inc. Method and System for Interactive Virtual Inspection of Modeled Objects
US20080309678A1 (en) * 2007-05-01 2008-12-18 M.E.P. Cad, Inc. Methods and apparatuses for resolving a CAD drawing conflict with an arm around
US20090259442A1 (en) * 2008-04-14 2009-10-15 Mallikarjuna Gandikota System and method for geometric editing

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0635997A (ja) * 1992-07-15 1994-02-10 Haseko Corp 複数要素の指定システム
US7079990B2 (en) * 2001-02-08 2006-07-18 Solidworks Corporation Automated connections of computer-aided design components
JP2006195735A (ja) * 2005-01-13 2006-07-27 Chiyoda Corp プラント設計支援システム及び方法
JP4860232B2 (ja) * 2005-10-24 2012-01-25 三菱電機株式会社 ツリー構成検討装置
US8305376B2 (en) * 2007-04-12 2012-11-06 Dassault Systemes Solidworks Corporation Locally updating a three-dimensional model
EP2333682B1 (fr) * 2009-11-06 2020-05-20 Dassault Systèmes Procédé et système pour concevoir un ensemble d'objets dans un système de conception assistée par ordinateur

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050071135A1 (en) * 2003-09-30 2005-03-31 Vredenburgh David W. Knowledge management system for computer-aided design modeling
US20050203718A1 (en) * 2004-03-12 2005-09-15 Carek Rick A. Knowledge management system with integrated product document management for computer-aided design modeling
US20080201113A1 (en) * 2005-03-14 2008-08-21 Holomar, Inc. Methods and Systems for Combining Models of Goods and Services
US20070198230A1 (en) * 2006-02-20 2007-08-23 Ford Global Technologies, Llc Parametric modeling method and system for conceptual vehicle design
US20080247636A1 (en) * 2006-03-20 2008-10-09 Siemens Power Generation, Inc. Method and System for Interactive Virtual Inspection of Modeled Objects
US20080040080A1 (en) * 2006-05-09 2008-02-14 Seockhoon Bae System and Method for Identifying Original Design Intents Using 3D Scan Data
US20080309678A1 (en) * 2007-05-01 2008-12-18 M.E.P. Cad, Inc. Methods and apparatuses for resolving a CAD drawing conflict with an arm around
US20090259442A1 (en) * 2008-04-14 2009-10-15 Mallikarjuna Gandikota System and method for geometric editing

Cited By (20)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10503840B2 (en) 2013-02-20 2019-12-10 Brigham Young University System and methods for multi-user CAx editing data consistency
WO2014130735A1 (fr) * 2013-02-20 2014-08-28 Brigham Young University Système et procédés d'édition de cax multiutilisateurs de cohérence de données
JP2016517123A (ja) * 2013-04-30 2016-06-09 シーメンス プロダクト ライフサイクル マネージメント ソフトウェアー インコーポレイテッドSiemens Product Lifecycle Management Software Inc. バリエーショナルシステムにおける曲線
US9690878B2 (en) 2013-05-28 2017-06-27 Siemens Prodcut Lifecycle Management Software Inc Geometric modeling with mutually dependent blends
WO2014193659A1 (fr) * 2013-05-28 2014-12-04 Siemens Product Lifecycle Management Software Inc. Modélisation géométrique avec mélanges mutuellement dépendants
EP2891998A1 (fr) * 2013-12-31 2015-07-08 Dassault Systèmes Conception d'un objet modélisé en trois dimensions
CN106415551A (zh) * 2014-05-28 2017-02-15 西门子产品生命周期管理软件公司 对于定位任务的智能约束选择
CN106416145A (zh) * 2014-05-28 2017-02-15 西门子产品生命周期管理软件公司 用于海量约束网络的创建和编辑的方法
CN106415551B (zh) * 2014-05-28 2020-11-13 西门子工业软件有限公司 对于定位任务的智能约束选择
EP3149633A4 (fr) * 2014-05-28 2017-12-27 Siemens Product Lifecycle Management Software Inc. Sélection de contrainte intelligente pour des tâches de positionnement
CN106416145B (zh) * 2014-05-28 2020-03-06 西门子产品生命周期管理软件公司 用于海量约束网络的创建和编辑的方法
CN107408142A (zh) * 2015-02-25 2017-11-28 昂沙普公司 基于多用户云参数特征的3d cad系统
CN107408142B (zh) * 2015-02-25 2022-09-06 Ptc公司 基于多用户云参数特征的3d cad系统
CN106897966A (zh) * 2017-01-24 2017-06-27 刘守乾 一种图像合成方法及装置
CN110249328A (zh) * 2017-05-08 2019-09-17 西门子产品生命周期管理软件公司 用于已建模系统的接口的接口工件生成
WO2020089240A1 (fr) * 2018-10-29 2020-05-07 Lenze Automation Gmbh Procédé pour configurer un système d'entraînement pour un dispositif technique
RU2764382C1 (ru) * 2020-10-13 2022-01-17 федеральное государственное автономное образовательное учреждение высшего образования "Санкт-Петербургский политехнический университет Петра Великого" (ФГАОУ ВО "СПбПУ") Способ параметрического моделирования высоконапорных гидроэнергетических объектов
CN112734922A (zh) * 2021-01-12 2021-04-30 中铁工程设计咨询集团有限公司 一种铁路路基的三维设计方法
WO2023163708A1 (fr) * 2022-02-25 2023-08-31 Siemens Industry Software Inc. Procédé de modélisation de composants de conception technique avec des motifs et des contraintes
CN117725642A (zh) * 2023-12-29 2024-03-19 重庆宇海精密制造股份有限公司 笔电模具设计用的动态建模方法及装置

Also Published As

Publication number Publication date
JP2017016676A (ja) 2017-01-19
EP2633448A4 (fr) 2017-11-01
JP6224191B2 (ja) 2017-11-01
EP2633448A2 (fr) 2013-09-04
JP2013546071A (ja) 2013-12-26
WO2012058604A3 (fr) 2012-07-05
JP6000267B2 (ja) 2016-09-28

Similar Documents

Publication Publication Date Title
US8566066B2 (en) Enforcing parametric constraints in a direct modeling interface in computer-aided design
US8589128B2 (en) Methods and systems for creation of a dynamically configurable product design
US8890867B2 (en) Methods and systems for dynamically loading portions of a computer-aided design model on demand
US20120109589A1 (en) Methods and systems for direct-parametric interoperability in computer-aided design
JP6224191B2 (ja) コンピュータ支援設計のための方法およびシステム
US8818769B2 (en) Methods and systems for managing synchronization of a plurality of information items of a computer-aided design data model
US8892404B2 (en) Methods and systems for consistent concurrent operation of a plurality of computer-aided design applications
US20120110595A1 (en) Methods and systems for managing concurrent design of computer-aided design objects
US9836884B2 (en) Parameterizing a 3D modeled object for tessellation
US7639267B1 (en) Systems and methods for modifying three dimensional geometry using an arbitrary cross-section plane
US9875577B2 (en) Tessellation of a parameterized 3D modeled object
Tornincasa et al. The future and the evolution of CAD
US8983805B2 (en) Modeled object updating
CN102067131B (zh) 用于转换尺寸的系统和方法
JP6799938B2 (ja) 製品可視化システム
EP3460760B1 (fr) Génération d'un dessin 2d représentant une pièce mécanique
EP2474930B1 (fr) Actualisation d'un objet modelé
EP2990970A1 (fr) Exécution d'une mise à jour séquentielle
EP2990969A1 (fr) Critère pour la mise à jour de manière séquentielle
US11941325B2 (en) 3D modeled object of a physical prototype of a product
JP6209253B2 (ja) コンピュータ支援設計のための方法およびシステム
US20230114354A1 (en) Designing a modeled object
EP2852904A1 (fr) Procédé et système de simulation de modèle de pièce
KR20140063475A (ko) 오브젝트들의 원형 스태거드 패턴의 설계
US20150339410A1 (en) Cad components with overlay data

Legal Events

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

Ref document number: 11837204

Country of ref document: EP

Kind code of ref document: A2

ENP Entry into the national phase in:

Ref document number: 2013536886

Country of ref document: JP

Kind code of ref document: A

NENP Non-entry into the national phase in:

Ref country code: DE

WWE Wipo information: entry into national phase

Ref document number: 2011837204

Country of ref document: EP