What are CAD apps written in, and how are they organized?

Rook picture Rook · Apr 23, 2009 · Viewed 9.2k times · Source

What are CAD applications (Rhino, Autocad) of today written in and how are they organized internally ?

I gave as an example, Autocad and Rhino, although I would love to hear of other examples as well. I'm particularly interested in knowing what is their backend written in (multilanguage ?) and how is it organized, and how do they handle their frontend (GUI) in real time ? Do they use native windows API's or some libraries of their own, since I imagine, as good as may be, the open source solutions on today's market won't cut it. I may be wrong ...

As most of you who have used them know, they handle amongs other things relatively complex rotational operations in realtime (shading is not interesting me). I've been doing some experiments with several packages recently, and for some larger models found that there is considerable difference in speed in, for example, programed rotation (big full ship models) amongst some of them (which I won't name). So I'm wondering about their internals ...

Also, if someone knows of some book on the subject, I'd be interested to hear of it.

Answer

Gabriel Cuvillier picture Gabriel Cuvillier · Mar 20, 2010

3D Mechanical CAD software such as CATIAv5, Pro/Engineer and Solidworks are mostly written in C++, sometimes with a thin COM interface for publishing basic API to customers.

Since these applications are really huge and are being developped by several teams, they rely on large scale C++ design principles, such as Interface/Implementation patterns to insulate the modules from changes.

They are composed of several subsystems such as:

  • a base framework to provide abstraction from the underlaying OS
  • a framework for GUI, dialogs and user interaction
  • a 3D renderer (mostly using OpenGL with some custom scene graph layer)
  • a geometric kernel, with a tessellation module (so that geometry can be displayed in the renderer)
  • a parametric modeler build upon the geometric kernel
  • and a lot specific modelers targeted at different domains (Mechanical, Drafting, Simulation, ...)