Naming project

This template is the guideline for a FreeCAD development project. It follows the rules of the Getting Things Done (GTD) process. The projects are collected in the Development roadmap.

Purpose and principles

This is an development and design effort to implement a robust topological naming in FreeCAD.


Outcome

  1. Interface in (Part::TopoShape) to robustly reference (name) shapes and sub-shapes (faces, edges, vertexes) through a string (sub-element name like "Face1")

    Here we need a interface to provide Part::TopoShape with all information need to do the Naming, e.g. NewShape, additional information from a algos like deleted faces, modeling step (for 2.) and ......

  2. Association of modeling steps with the resulting faces/edges.

    In case of a big model the user is lost if he/she has hundreds of fillets or bore hole. So if the faces/edges would know what modeling step it created we could implement a double click on edge/face opens the right feature!

  3. An algorithm to keep the naming stable throughout changes in modeling history, like splitting edge/faces and moving vertexes

    NamingExample.jpg

  4. (optional) memory optimized data structure to keep only changed faces/edges in each modeling feature. <p> This will become important when the models get bigger. Its not efficient to copy most of the shape just through. Would be much more effective to share the unchanged faces/edges between Feautures and copy only whats changed.

Brainstorming

A lot was discussed in the "Robust Reference" Post of jrheinlaender.

Others

Literature & Papers

Describes a method to do the first three points in the List. Would say the is the approach used by Catia and OCC-TNaming. At least the interface looks the same. The paper was nowhere to download. I had to buy it. If someone is interested I can send it via E-Mail.
Interesting approach via shell-graphs, tackles the point four on the list by reusing faces/edges not changed.
Very good overview and Examples

Summary of Work To-Date

As of June 13th, 2016, here is a summary of the work that has been done for this project:

Organizing

Information about TNaming

See here for a decent write-up on ezzieyguywuf's github repo. Here are some highlights:

Next actions

Next Steps (as of June 13th, 2016)

  1. Determine if opencascade TNaming toolkit fully resolves Topological Naming issue in FreeCAD
    • What are all instances where Topological Naming is a problem?
    • What are complex scenarios where this approach will need to work?
  2. Incorporate TNaming code into FreeCAD
    1. Start with a bare-bones approach, i.e. Make a Cube and a Cylinder, Fuse, Fillet, and then re-size the Cylinder. Fillet should not move
    2. Gradually add more functionality
  3. Determine if TNaming will be the solution long-term
  4. Whether or not TNaming is the long-term solution, figure out a way to 'serialize/deserialize' the data that TNaming uses for persistence across sessions


Online version: "http://www.freecadweb.org/wiki/index.php?title=Naming_project&oldid=188424"

Navigation menu