Question

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.

Was it helpful?

Solution

As my company is a registered developer for AutoCAD, I know for certain that its written in C++. It exposes a COM interface, as well as a .Net wrapper. Also, it graphics display is componentized and could be possibly replaced. Way back in its history it used be cross-platform. However its been Windows only for about 10 years and now takes advantage every Windows feature I've seen. You may be interested in the Open Design Alliance.

OTHER TIPS

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, ...)

AutoLISP is a flavor of lisp that has been used for years to program AutoCAD. Very powerful, not at all friendly. AutoCAD (and most verticals) have had VBA built-in for about 10 years. Kind of powerful, very friendly. VBA projects are stored in a separate file that is loaded by a mechanism internal to the host program. The latest version (currently 2010) no longer includes VBA by default. You must install a separate VBA enabler. This is to put us on notice that VBA (VB6 for that matter) will at some point be a thing of the past. The .NET platform is currently the preferred choice. VB.NET, C#.NET, C++ are commonly used. Some have experimented with other .NET languages like F# and IronPython.

The open source project BRL-CAD might interest you.

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top