OpenSCAD is kinda neat

(nuxx.net)

236 points | by c0nsumer 15 hours ago ago

167 comments

  • fogleman 12 hours ago

    It is kinda neat, but OpenSCAD's limitations are the main thing that motivated me to write this Python library to generate 3D meshes used signed distance functions:

    https://github.com/fogleman/sdf

    One big plus to doing it this way is that it's "just" Python and you can use arbitrary logic to help construct your model.

    You can even load an existing 3D mesh and operate on it as an SDF. Great for hollowing, chopping, eroding/dilating, etc. existing models.

    I should probably do more with this project. I think there's a lot of interest in this space.

    • vhanda 10 hours ago

      Could you please elaborate on how this is different than the other python based modeling tools - build123d[0] and CadQuery[1].

      I recently also got annoyed with OpenSCAD and its limitations and therefore started experimenting with Build123d. I'm very much a beginner in the CAD space and would love to understand what inspired you to build sdf.

      My basic understanding is that STL files are essentially like Bitmap images and store a list of triangles and their positions, whereas STEP files are more like Vector art where there is a list of instructions on how to build the model. Most CAD GUI programs also operate on a similar model to vector art where they record a list of operations one on top of another. It's why STEP files are a standardized format and can be imported / exported from most GUI based CAD builders. I think.

      Given that SDF also seems like it builds only STL files (I could be wrong), wouldn't learning build123d or CadQuery work better if one cares about compatibility with existing GUI based CAD modeling software?

      Additionally, atleast build123d offers a similar conceptual model to using Fusion360 and FreeCad - I have limited experience here - but essentially you sketch something in 2D on a particular plane, and then apply some operations to convert it to 3d in a particular manner - the simplest being extruding. This means the mental modeling of how to construct something is very similar across both GUI based CAD programs and Build123d, and that makes it easier for me to jump between GUI based and code based CAD modelling.

      I'd love to understand your point of view, and learn more.

      [0] - https://github.com/gumyr/build123d

      [1] - https://github.com/CadQuery/cadquery

      • fogleman 9 hours ago

        It seems like you already understand the differences. I wasn't aware of those other projects. build123d looks pretty neat.

        Like most of my projects, this was just for fun and I mainly made it for myself. I'm a DIY kind of guy when it comes to software. I just throw things up on GitHub in case anyone else can get some use or inspiration out of it.

        • silvertab 3 hours ago

          > It seems like you already understand the differences.

          Honestly I was about to ask the same questions as the parent comment. Whenever I'm interested in something I usually look at what available tools exists out there already; seeing a new tool mentioned that I've never heard of before, my reflex is to ask "oh neat, what makes it different than the existing tools?". I don't think the question was ill-intended, just genuine curiosity; assuming that you wrote your library because you had no idea build123d existed rather than because you were unsatisfied with it and wanted to tackle the problem differently is a bit of a leap.

    • jandrese 11 hours ago

      > You can even load an existing 3D mesh and operate on it as an SDF. Great for hollowing, chopping, eroding/dilating, etc. existing models.

      This has my instant interest. Multiple times I have wanted to take an existing .STL file and cut a hole on it or add another object to it and have never had success.

      I've tried things like Meshlab, but while the interface has what appears to be a hundred different functions, attempting to use anything returns some error code that requires a PhD to understand and none of the "repair" functions seem to help.

      I mean seriously: Mesh inputs must induce a piecewise constant winding number field.

      How the hell am I supposed to accomplish that on a STL file?

      • Brian_K_White 8 hours ago

        You can do that effortlessly right in openscad itself or in freecad for a more visual way, or in every single cad app in existence I think.

        In freecad you first just open the stl file, then Part -> Create part from mesh, then you have a solid you can modify.

        • fogleman 6 hours ago

          I just tried this in OpenSCAD and it crashed:

          intersection() { import("3DBenchy.stl"); sphere(30); }

      • dekhn 11 hours ago

        Blender also has a high learning curve but you typically don't need a PhD to understand the errors (instead you just watch youtube videos and copy what they do).

        Removing faces from an STL and adding other objects is quite straightforward. Previously, Autodesk had Meshmixer and 123D, I guess Meshmixer is still available: https://meshmixer.org/ and I found it to be great for quick editing of the type you're describing.

      • fogleman 11 hours ago

        That feature requires getting pyopenvdb installed, which can be a headache, and I never really updated the README with examples, but it does work. There is one example script:

        https://github.com/fogleman/sdf/blob/main/examples/mesh.py

        You basically just say:

        f = Mesh.from_file(path).sdf(voxel_size=0.25, half_width=1)

        Then you can operate on `f`.

      • kesor 11 hours ago

        OpenSCAD can load STLs and cut holes in them.

      • btbuildem 10 hours ago

        Tinkercad is a very low-barrier-to-entry option here

    • zimpenfish 10 hours ago

      Bless you for your service, sir! I have used `sdf` to create a whole bunch of stuff (buttons for my mother, tealight holders, etc.) and `gg` gets used in a bunch of places (including a couple of bots).

      > I should probably do more with this project.

      I, for one, would be glad.

    • JonathanRaines 12 hours ago

      I've used your library and really like it!

    • FeepingCreature 9 hours ago

      See also my site fncad https://fncad.github.io ! It's basically intended as "SDFs in your browser with realtime preview with openscad-like syntax". I mostly use it for 3d models for printing.

      What do you use for sdf meshing? I never really got the perf where I wanted it.

      • fogleman 8 hours ago

        It's explained in the README. The SDF is evaluated on whole batches of points (32x32x32 tiles by default) using numpy. (And it's multithreaded.)

        • FeepingCreature 5 hours ago

          So uniform sampling? And then I guess marching cubes or sth?

          • fogleman 5 hours ago

            I see you still haven't read the README.

    • ur-whale 4 hours ago

      SDFs are very neat up until the point where you need to build parts that have very precise specifications.

      Something like two precisely interlocking gears with a tooth geometry with a profile that's the developed curve of the opposite tooth is a nightmare to build with SDFs

      Or precise fillets.

      Or hard intersections and differences.

      Very useful for doing soft, squishy shapes, less so for hard CAD.

      Also, a suggestion: in your project, please consider using Wavefront OBJ as an output format, it is a much, much better choice than STL (STL can't represent the actual topology of the object, it has to be reconstructed).

  • charlie-83 14 hours ago

    Just started using OpenSCAD recently and love it. While most CAD tools have a million features to learn, OpenSCAD is completely described by a cheat sheet you could print on a piece of A4 (like most programming languages).

    I would really recommend using the git master than the latest release though. The last release was 2021 but they are still actively working on it and it's much faster now.

    I also have to recommend the BOSL2 library which means you don't have to implement all of those one million features from typical CAD software yourself. Its definitely got a bit of a learning curve but the fact that you can always default back to vanilla OpenSCAD and that you can actually see how stuff is implemented makes it much more satisfying to me to learn than learning what all the traditional CAD GUI buttons do.

    • porkloin 13 hours ago

      Commenting off of you since I wrote all of this and then realized it's basically exactly what you're saying. But to +1 everything you just said in my own words:

      I love OpenSCAD. I've been 3D printing for a while, but I never really got to a place where I could design interesting parts until I started to get the precision of doing models in code. Sometimes it is slower, for sure.

      Every time I've used as a CAD GUI program I would get to this point where I would need to alter a single dimension by 0.25mm and realize that _all_ of my fastener holes, cutouts, etc have to be nudged with the keyboard or mouse to accommodate it. The input devices lack precision for that kind of task, and having to repeat the operation dozens of times (or bulk select) gave me a terrible sinking feeling, and I'd often just step away and give up on the design at that point out of frustration. I try to approach everything in OpensSCAD in a way that means I never have to experience that feeling again.

      I will also say that doing everything from scratch in OpenSCAD would be it's own special kind of hell. Libraries like [BOSL2](https://github.com/BelfrySCAD/BOSL2) provide a good set of core ideas and preferences that help set you on a good path. A good example: BOSL2 shapes tend to have a "center origin" by default, which is different than the OpenSCAD default, but makes doing transforms later way easier.

      Anyway, happy to see OpenSCAD getting some attention here :)

      • zargon 12 hours ago

        > Every time I've used as a CAD GUI program I would get to this point where I would need to alter a single dimension by 0.25mm and realize that _all_ of my fastener holes, cutouts, etc have to be nudged with the keyboard or mouse to accommodate it.

        There seems to be some fundamental misunderstanding of CAD here. I can't imagine how you could even design something in CAD in a way that you would end up in this situation.

        • dcminter 11 hours ago

          I wonder if he's using TinkerCAD or something similar? I often use that, 'cos it's quick for simple things that are one-offs, but it has exactly this issue as it's not at all parametric, just primitives and booleans (though it does have some basic sketch capabilities now)

          When I'm doing something more sophisticated I use SolveSpace, but I'm a lot slower with that.

          • porkloin 11 hours ago

            yeah, op here: it's exactly that. I've used most of the free or open source software options and it seemed like none of them are parametric. I know I could buy fusion or something like that, but I found OpenSCAD before I got to that point and feel like it fits the bill for me.

            • le-mark 5 hours ago

              Freecad is fully parametric, set constraints so it’s 0 degrees of freedom and you shouldn’t have that problem.

            • Kerbiter 7 hours ago

              You don't necessarily need to buy Fusion, it has a well hidden free tier for personal use, just gotta dig on the site a bit.

            • sfifs 10 hours ago

              Fusion is free for personal use and in my experience at least was much faster experience than OpenSCAD.

            • skybrian 9 hours ago

              I like Onshape. It’s free to use provided that you’re okay with your design being public.

            • Arodex 7 hours ago

              Solvespace and Onshape are free and parametric.

      • Arodex 13 hours ago

        >Every time I've used as a CAD GUI program I would get to this point where I would need to alter a single dimension by 0.25mm and realize that _all_ of my fastener holes, cutouts, etc have to be nudged with the keyboard or mouse to accommodate it.

        What.

        This makes no sense. This isn't PowerPoint; your holes and cutouts are supposed to be parameterized. How are they even supposed to be at the proper position in the first place?

        As a CAD user, this is like e.g. a coder seeing someone write code with global variables everywhere.

        • porkloin 11 hours ago

          I think I'm realizing that openscad was probably just the first time that parametric design options were given to me in a context where it made sense to me (in code). Maybe some of the software I've used has supported parametric positioning, but it wasn't made obvious to me. In OpenSCAD it's parametric by necessity. I said this in another comment, but the other programs I've worked with in GUI are most certainly not high end pieces of software: tinkercad, freecad, sketchup.

          I'm not doing complex character model designs, I'm usually building functional prints like enclosures or cases. It certainly sounds like there are features of better CAD software that makes parametric the default?

          • jazzyjackson 10 hours ago

            FreeCAD is definitely parametric but I hear you that the interface doesn't make it obvious. It might be worth another look particularly since it's interoperable with OpenSCAD and can work on CSG trees within the interface

            At least you've inspired me to try it and see if it's "worth writing home about"

            https://wiki.freecad.org/OpenSCAD_Workbench

          • Arodex 7 hours ago

            Oh, it is not that software like freecad is not parametric by necessity; it is just that in a parametric design process, you don't set all the parameters at once. Why? Because a) you don't overconstraint a design, and b) your parameters rely on references (a point, a line, the side of another object, a tangent), and you may want to change which reference you choose.

            For example, if you put a hole in a box, do you want to reference the center of the sides of the hole? And do you want to place them relative to the left side or right side, and front or back? You never say "it's x mm from the left and y mm from the right and my box is w mm wide" - because the relationship x+y=w is always here! You only define 2 out of 3. But it may happen that you picked the wrong 2 - and a parametric CAD makes it very easy to do so in a few clicks, while a programmatic CAD like OpenSCAD is a large rewrite with calculation you have to do yourself on the side.

            My example is silly but start doing big designs, large assemblies, and you "chains of cotations" may need to be redone again and again - especially when tolerances begin to add up.

          • JP44 9 hours ago

            If you're doing enclosures, check out Dune3d! Has been featured here as well (it's how I found it). It's pretty easy to use and feels intuitive for prints you'll only have to make once or twice. It's missing some things here or there but nothing fundamental (except trimming edges i.m.o.)

            I often switch between FreeCad and Dune3d now, Freecad for things I know how to design properly and Dune when I'm in 'claying' mode. E.g. export a .step part when I get stuck in FreeCad, import it into Dune, make some progress and vice versa so I don't walk away from the project

          • exasperaited 10 hours ago

            I think I understand this — I mean, OpenSCAD was my brief gateway to parametric CAD, and then I got to FreeCAD via brief stepping stones of CadQuery and other packages.

            But OpenSCAD isn't really parametric CAD. It's a programming language; it's parametric for that reason. But it's not really CAD, at another level, in the sense that it does nothing to "aid" your design work. It has no interim abstraction for generated geometry; everything must be explicitly described.

            FreeCAD, though, is profoundly parametric, through and through, and really always has been. Indeed the parametric aspects are the main thing that made it workable before the TNP mitigations were added. It is not a limited CAD package, by any means. It's just a somewhat unfriendly one with a CAD kernel that has some limitations. Really it's almost better understood as a 3D IDE with some workflow affordances.

            If you are stuck trying to get your head into how FreeCAD works, there are now three really good ways on Youtube: the Mango Jelly Solutions videos are incredible, the Shawn Hymnel/Digikey FreeCAD and 3D Printing course is good, and there are great recent videos by Deltahedra.

            But what you will be able to make with it, once you get your head into it, is night and day different to what is possible with OpenSCAD. Because your parametric work in FreeCAD (or other CAD packages) can operate on the geometry of the result of previous operations.

            Give it a try in the New Year with FreeCAD 1.1 when it is released.

            If you want another stepping stone from OpenSCAD to FreeCAD or any other package, I really recommend you look at CadQuery/Build123D. This will give you a similar coding approach but it will introduce you to operations on the true faces, edges and vertexes of the output of other operations.

            (FWIW I would not say that Sketchup is not high end, either. It's not to my tastes but it is quite powerful)

        • tonyarkles 11 hours ago

          You would not believe how many CAD models are not parameterized. Not mine, but ones I’ve had to work with.

      • 0_____0 13 hours ago

        A properly parameterized model shouldn't have the issue with having to nudge everything manually after a trivial change.

        I had the change the height of an entire enclosure to accommodate a taller than anticipated PCB, and simply edited the sketch at the top of my design tree that defined the overall dimensions.

        It took about 5 minutes to adjust the odd broken fillet and change some mates in assembly and it was done. No fidgety mouse movements. I actually do a lot of mech design on a laptop with a trackpad, arrow keys for view changes and numeric dimensioning for 95% of everything else.

      • abdullahkhalids 13 hours ago

        > Every time I've used as a CAD GUI program I would get to this point where I would need to alter a single dimension by 0.25mm and realize that _all_ of my fastener holes, cutouts, etc have to be nudged with the keyboard or mouse to accommodate it.

        I am just starting to learn CAD and FreeCAD - also dabbled a bit in OpenSCAD. But I do know that FreeCAD has Spreadsheets [1] and Configuration Tables [2] which allows you to define your model parameterically and changes values as needed.

        How good this is, I don't know yet.

        [1] https://wiki.freecad.org/Spreadsheet_Workbench [2] https://wiki.freecad.org/Configuration_Tables

        • ElCapitanMarkla 12 hours ago

          It’s a fantastic feature and works really well, my problem is I can never invest the required time to learn the interface. It all falls apart when I need to switch modes to move something or whatever. With scad can usually knock whatever I want together pretty quickly without having to relearn how to use the tool.

        • MegaDeKay 11 hours ago

          Spreadsheets are really slow in FreeCAD. I'd suggest you look into Varsets [0] if you don't need some of the fancier capabilities that spreadsheets provide.

          [0] https://wiki.freecad.org/Std_VarSet/en

          • exasperaited 10 hours ago

            Yes, VarSets are definitely better (more granular dependency recalculations).

            The little-known Configuration Tables aspect of Spreadsheets is absolutely worth using, though, and has no equivalent in the VarSets scheme at this point. Once you get that set up it is great fun.

      • girvo 10 hours ago

        > I would get to this point where I would need to alter a single dimension by 0.25mm and realize that _all_ of my fastener holes, cutouts, etc have to be nudged with the keyboard or mouse to accommodate it

        Thats surprising! Last time I used software like this (Inventor, back in ~2005-2006) constraints meant that I didn't need to do this at all

    • moebrowne 12 hours ago

      > I would really recommend using the git master than the latest release though.

      This. The master version is so much further ahead of the last tagged version. The render time can be orders of magnitude faster for more complex models.

    • cm2187 12 hours ago

      Agree but you quickly run into its limitations. Like if you 3d print something, you need to eliminate when possible sharp edges. That's not fun to do with OpenSCAD.

    • m4rtink 10 hours ago

      BOSL2 is SO nice and powerful, can also highly recommend it! :)

    • exasperaited 10 hours ago

      OpenSCAD isn't a CAD tool, IMO. It does nothing at all to aid your design. It barely even helps describe it in any abstract way.

      It is a useful tool for programmatically describing either very simple or heavily geometric objects. For everything else it's the wrong tool.

  • WillAdams 13 hours ago

    The great thing about OpenSCAD is that it makes it easy to 3D model things which may be described using spheres, cylinders, and cubes which are stretch, and/or rotated, and arranged in 3D space.

    The awful thing about OpenSCAD is that what one can model in 3D is limited by one's ability to mathematically stretch, rotate, and/or arrange spheres, cylinders, and cubes in 3D.

    For folks who want "real" (read mutable in normal terms of scope) variables there is a Python-enabled fork (which should become part of the main release presently:

    https://pythonscad.org/

    • IgorPartola 13 hours ago

      Not just that but it also positions everything in absolute coordinates and does not have the ability to reason about solids, just surfaces. Basically if you want to model something like a bolt you need to create a cylinder for the shaft, a separate head of the bolt, and then a thread profile you can rotate around the cylinder. You must ensure there is enough overlap between these three separate parts so the resultant object is a single surface and not three separate ones.

      You can use modules to create a semblance of relative measurements but you still cannot do things like “attach this surface of object A to that surface of object B)”. In practice this means that if you want to create something like a spacer or a bracket you can do that easily enough. But if you want to make a part that matches some real world design you are stuck doing a lot of caliper measurements and math to try to create a part that lines up correctly. The you 3D print it and find that you positioned some hole based on its edge and not center and so nothing quite fits.

      OpenSCAD is easy to start but difficult to scale because of these limitations and because once you hard-code any measurement you are stuck with it. The “proper” way to do this is to give everything a variable but honestly that makes reasoning about how to line things up even more difficult. “Does base_width include the width of the vertical walls? What about the margin to make the parts fit together?”

      I have never been able to understand how things like FreeCAD lay out their UI. TinkerCAD is relatively simple but clearly a lot less powerful. I did try cadquery which solved a lot of OpenSCAD’s issues by having all offsets be relative by default but also introduces a few issues of its own.

      One tip I will give about OS: grab a copy of the latest beta/dev release. The renderer is several orders of magnitude faster.

      • c0nsumer 9 hours ago

        > You must ensure there is enough overlap between these three separate parts so the resultant object is a single surface and not three separate ones.

        (Post author here.)

        This was a very weird thing to me I ran into and have thus far just sort of... accepted.

        In Fusion, and other CAD software, if I have two faces end at the same point, unless I've specifically said to create them as separate bodies, they are joined, because they share a plane.

        In OpenSCAD, in the tutorial, it has you extend an object 0.001 to ensure they overlap. To quote:

        > In the example above, the second cube sits exactly on top of the first cube. This is something that should be avoided, as it’s not clear to OpenSCAD whether the two cubes form one object together. This issue can be easily solved by always maintaining a small overlap of about 0.001 - 0.002 between the corresponding objects. One way to do so is by decreasing the amount of translation along the Z axis from 10 unit to 9.999 units.

        This struck me when making the example in my post. In line 47 I specifically add 1 to heightCompartment to ensure the opening extends past the top of the main body. If I didn't do that, this happens during preview: https://imgur.com/a/Amc1dK6 (That's an exported image from the latest nightly of OpenSCAD.)

        But it doesn't happen during the actual render?

        Still, that just feels... like there's something going on with a floating point value or something which, programatically, is probably correct... But from the perspective of someone trying to design something feels Very Wrong. Because I have a 20mm high box, I subtract a 19mm high box from it, starting 1mm up from the base. Why shouldn't the top be open? Why is it acceptable for it to be maybe kinda open but broken by design?

      • somat 12 hours ago

        > but you still cannot do things like “attach this surface of object A to that surface of object B)”

        Sure you can, but openscad is an imperative language so you need to do it in an imperative manner.

            a_cube_loc = [10, 5, 5];
            a_cube_size = [2, 4, 1];
            b_cube_loc = [a_cube_loc[0], a_cube_loc[1] + a_cube_size[1], a_cube_loc[2] ];
            b_cube_size = [2, 4, 1];
        
           translate(a_cube_loc) cube(a_cube_size);
           translate(b_cube_loc) cube(b_cube_size);
        
        It would be nice to have more declarative constraints. The solvespace file format is plain text and it almost feels like you could write it by hand, but that would be a lot of manual record keeping. and you would loose all that imperative goodness. Perhaps you could have an imperative layer(say python or lisp or forth) that outputs the declarative layer(solvespace) and then solvespace renders(picture or stl) the declarative layer.
        • WillAdams 11 hours ago

          I think a text input option for Solvespace which was optimize for readability and usability would be _very_ interesting approach, esp. if Solvespace was able to write back out to the same format, and it allowed math/variables/parameters and supported the same in the UI.

      • coryrc 12 hours ago

        BOSL2 allows attaching when you define attachment points or something with attachment points defined for you (most everything in BOSL2).

        Manifold backend also eliminates the need to avoid coincident faces.

        • IgorPartola 10 hours ago

          Can you explain this a bit more? Might be the after effects of the COVID/flu vaccine I got yesterday but I am not picking up what you mean.

      • m4rtink 10 hours ago

        Let me introduce to the awesomness of the BOSL2 screw module:

        https://github.com/BelfrySCAD/BOSL2/wiki/screws.scad

        • IgorPartola 10 hours ago

          This is amazing but the first time I needed to make a screw I needed to make one that used the NPT standard which this module still does not cover :)

      • ur-whale 4 hours ago

        > I have never been able to understand how things like FreeCAD lay out their UI.

        I'm 100% with you there. One of the most utterly confusing UI I've had to deal with.

        And I suspect the answer is : the FreeCAD devs don't either.

    • RobotToaster 12 hours ago

      > The great thing about OpenSCAD is that it makes it easy to 3D model things which may be described using spheres, cylinders, and cubes which are stretch, and/or rotated, and arranged in 3D space.

      It also has hulls and minkowski sums, which are powerful once you understand them.

      • WillAdams 12 hours ago

        Aren't hulls just a direct connection of the edges of two shapes (which could be simulated by a series of duplications) while Minkowski is "just" a matter of putting spheres along the edges of an object to round the straight edges?

        So, spheres and cylinders and cubes placed, rotated, stretched and placed mathematically.

    • culi 13 hours ago

      There's also OpenJSCAD. Which, being JavaScript ofc, can run in the browser

      https://openjscad.xyz/

      https://github.com/jscad/OpenJSCAD.org

      • xixixao 12 hours ago

        From my testing, the CSG operations, with post-processing, don’t produce watertight meshes. And being focused on printing, it doesn’t support different colors for the CSG operands. My use case is animation/games, so I’m reimplementing the CSG with a watertight b-rep.

      • rafabulsing 12 hours ago

        Re: JS based CAD, there's also replicad, which I've used previously and found to be really good.

        https://replicad.xyz/

      • spwa4 13 hours ago

        Don't people think this is one tool that would greatly benefit from using the very fastest languages available? Where's the C++, Rust, maybe even FORTRAN version?

        • htgb 13 hours ago

          This is only the language for describing the volumes. That's not heavy, rather the importance is that you can express the ideas you want. The heavy lifting of rendering and computing how volumes interact etc is already implemented in native code.

        • WillAdams 12 hours ago

          My understanding is that the core of OpenSCAD is done using C++.

          If you wish to use Rust for 3D modeling directly there is:

          https://fornjot.app/

          (the developer of which is actually working on a BREP kernel)

    • jandrese 11 hours ago

      You can also make more complex shapes if you're willing to define points, even on a 2D plane that you can then extrude. Downside is that it's basically a MENSA test to define all of the points in the correct order. I've done it a few times, but it's never fun.

    • tombert 5 hours ago

      I think people should also give Bowler Studio a shot. It has a pretty decent Java-based CAD thing, and it even has built in Clojure support, with physics simulation support and everything. I really like it.

    • coryrc 12 hours ago

      Also you can use the new backend by writing C++: https://github.com/elalish/manifold

      Which avoids using the OpenSCAD language, but also means you can't use BOSL2. Might as well use FreeCAD.

      • pca006132 10 hours ago

        It has many language bindings, including python and js. Though the js backend is not parallel because it uses wasm, and we had problem with mimalloc memory usage with pthread enabled.

    • JoshTriplett 12 hours ago

      Another interesting option is FreeCAD, which is scriptable in Python but its primary interface is a GUI. So you can use a script to create things programmatically, edit graphically, or both.

      • criddell 12 hours ago

        FreeCAD sounds great but in practice it’s sooo slow.

        If you are coming from SolidWorks, Fusion360, Inventor, or OnShape, it won’t take long before you start finding that there are a lot of things missing from it.

        • zihotki 12 hours ago

          I'm coming from Fusion, advanced hobbyist, I can't find anything missing. </anecdata>

          There is a problem though - sometimes what you want requires deep understanding. It's less user friendly, polished, and documented. That's also relevant to the performance - it's easy to cause performance issues. But I remember the same was also applicable to Fusion.

          • Animats 12 hours ago

            Of course FreeCAD is less user friendly, polished, and documented. It's open source. Open source people do not get GUIs. They think command line. It's taken decades for artists and graphic designers to nag the GIMP and Blender people into usable interfaces, and they're still inferior to Photoshop and Maya.

    • ai-christianson 12 hours ago

      I've had really good luck with https://github.com/SolidCode/SolidPython

    • NortySpock 12 hours ago

      I ended up adding the https://github.com/BelfrySCAD/BOSL2 library to OpenSCAD and it had some reasonable options for some gear and rack-and-pinion modeling that I needed to do.

      (3D printing a sacrificial gear for a seat position adjustment mechanism)

    • M_bara 13 hours ago

      Or perhaps take a look at cadquery? It’s also pretty neat - http://cadquery.readthedocs.io/

    • ur-whale 4 hours ago

      > https://pythonscad.org/

      Thanks for this, didn't know about it.

      How does that compare to solid python 2?

      https://github.com/jeff-dh/SolidPython

    • TOGoS 2 hours ago

      > The awful thing about OpenSCAD is that what one can model in 3D is limited by one's ability to mathematically stretch, rotate, and/or arrange spheres, cylinders, and cubes in 3D.

      Not at all. You can build any polyhedron you want using the polyhedron command.

      Which would be an enormous pain to write out by hand every time, but I wrote a function once upon a time to generate a polyhedron from a stack of layers, each of which is a list of points, and haven't had to mess with old cubes and spheres since.

      One annoying thing is that the default way of writing programs in OpenSCAD uses 'modules', which are a bit limited compared to functions (you can't store them as values to to functions or other modules). I worked around that by writing a module that interprets arrays (think S-expressions) that representing the shape, and then just build up that S-expression-like thing with functions and whatever.

      Once you've built your own programming language inside OpenSCAD it's perfectly usable. :-)

      This might sound like sarcasm but I actually do prefer this to dealing with Python's mutable state jungle / package management nightmare.

  • vjvjvjvjghv 29 minutes ago

    It’s pretty neat but for my taste the language is too functional. I don’t think a purely functional paradigm works well with CAD parts and the way they are constructed. The language gets in the way. Debugging complex parts is also quite difficult from my experience. But with some better tooling I think it could be absolutely great.

  • elcapitan 14 hours ago

    For me as a casual 3d-modeler, my favorite thing about OpenSCAD is that I don't have to learn a new application the size of Photoshop with everything hidden 7 levels deep in some menu that is probably intuitive for some people who learned CAD in the 80s.

    Instead it's basically like graphics programming, with a couple of basic primitives, some linear transformations and a bit of set theory. When I do a model a month and get back to previous work, I read a few lines of code and know exactly how I achieved the result.

    • unbelievably 13 hours ago

      I was once a big OpenSCAD user myself but I'm really skeptical that there are many use cases where it's actually more intuitive than a traditional CAD program, even if you're a programmer. It's true CAD programs have a huge amount of features but the basic sketch, extrude, revolve, and loft tools aren't conceptually difficult and are basically the same between Onshape, Fusion, Solidworks, etc. Those tools are sufficient to make 99.99% of OpenSCAD models I'm seeing.

      I also have the opposite experience about understanding previous scripts. Unless it's dead simple I'm usually thinking why the hell did I multiply this thingy by sqrt(3)/2 plus this other thing. Maybe a documentation problem, but it's inescapable that sometimes you need a lot of math for what are trivial constraints in an interactive sketch. A real CAD program will let you roll back to any feature to figure out how it's constructed step by step so there's really nothing to decipher.

      • WillAdams 12 hours ago

        I've been trying to model joints for woodworking, and in traditional tools, the shapes I wish to arrive at verge on nightmarish, while I was able to knock them out in OpenSCAD in pretty short order --- except that when I sent a 1" x 2" x 1" test joint to a CAM program, it took some 18 minutes and generated a ~140MB G-code file, hence my working on:

        https://github.com/WillAdams/gcodepreview

      • IshKebab 11 hours ago

        Yeah I agree. OpenSCAD is good for highly parametric modelling: fasteners, gears, generative art, ... that's about it. Most things aren't like that, and a traditional parametric CAD program is 10x easier.

      • wat10000 8 hours ago

        The older I get, the less I want GUIs. If I want to rotate something, I want to type “rotate,” not find the rotation icon or menu item or remember the keyboard shortcut or whatever.

        I know this is not typical, and nothing against folks who see it the other way. But OpenSCAD fits the way I think and want to work better than the more “normal” tools.

  • iamwil an hour ago

    Ah OpenSCAD. I wrote a tutorial a long time ago about the 10 things you need to know to get started.

    https://cubehero.com/2013/11/19/know-only-10-things-to-be-da...

  • Brian_K_White 8 hours ago

    It's a lot of work to make models that are useful in real life, but for some things it's worth it because it's sooo nice having 2k of plain text that describes an entire object, and it's even fully parametric, and it even comes with a customizer panel for the parameters, so every model isn't just a model, it's a model generator app, and even has meaningful diffs in git.

    The same model in freecad is like 6 megs of zipped xml and realistically not nearly as usefully parametric.

    That couple-k of plain text is such a huge deal that it makes all the other difficulty worth it for mechanical/functional stuff.

    • bb88 8 hours ago

      I find that I'm often making one-offs. I take a part I designed and I need a slight modification for it for some reason.

      Fusion is great for that as long as there's not too many parts. But sometimes I'll want a new variant or a series of new variants.

      And reaching for python makes that easy.

    • dheera 8 hours ago

      OpenSCAD is the only CAD tool I use. I can'd figure out how to operate a graphical 3D software with a 2D GUI so it's just easier to describe things mathematically.

      I just wish it had operations for subtractively chamfering, rounding, etc. as doing minkowski() with cones and spheres to achieve that result can be unwieldy.

  • anfractuosity 14 hours ago

    It's super useful, been using with my 3D printer to print things such as an adapter to connect a Canon EF lens to night vision tube and parts to link motorised linear stages together.

    Currently I'm playing with a gear library which is part of BOSL2 (https://github.com/BelfrySCAD/BOSL2/wiki/gears.scad), to make something to rotate a polariser in my microscope.

  • cpeth 12 hours ago

    Check out https://zoo.dev/

    I went from OpenSCAD -> cadquery/build123d -> Zoo/KCL

    It still is early days, and it needs some more helper functions but it's really nice having two-way capabilities (not just code -> model, but also the reverse).

    Of course having Text-to-model as a first class citizen is also nice.

    • dbuxton 12 hours ago

      I have played with this but been underwhelmed. However I do think probably on the right track.

      I know the ecosystem not-at-all (sum total knowledge of the CAD ecosystem is that my kids got a Bambu printer for Hanukkah) but it feels to me that current LLMs should be able to generate specs for something like https://partcad.readthedocs.io/en/latest/, which can then be sliced etc.

      Curious to know what others think? I come at this from the position of zero interest in developing the fine design skills needed to master but wanting to be able to build and tweak basic functional designs.

    • bob778 10 hours ago

      I want to like Zoo but the rendering engine is so buggy currently that it’s not really usable for more than simple shapes. The text-to-CAD feature they highlight is slow and error-prone, so much so that they explicitly use a “prebuilt” version in the tutorial, and each time I tried it, it gave tool errors or took so long I just did it manually.

  • tylervigen 10 hours ago

    I’ve used OpenSCAD for 3D printing random objects for years. It’s the perfect tool for designing super simple geometric objects, because it giant demands that you remember hardly anything about his the interface works. Contrast with Fusion 360 or any other more powerful tool, which are fantastic if you use them daily but a slog of you only boot them up a few times a year.

    Also with OpenSCAD, you can feed the documentation to your favorite LLM and ask it for a starter design of whatever you are building. (Or you can skip the documentation; it is in the trading data after all.) Maybe in the future that SVG Pelican on a bike test will be a 3D model in OpenSCAD.

    • rcarmo 8 hours ago

      Ooh, an LLM that could take requests for custom Gridfinity bins would be a good step towards AGI indeed.

  • overtone1000 14 hours ago
  • mcv 9 hours ago

    There's a tutorial? Maybe I should have started there.

    I recently started messing around with OpenSCAD too. I found these boxes that are great for storing the tiles for various 18xx railroad boardgames: https://www.printables.com/model/287297-parametric-18xx-tile...

    Cool thing is that you can easily print them in whichever size you like, and the sizes in the supplied files are rather large, so I tried some smaller sizes, and discovered some details weren't actually centered properly, so I dove into the code, tweaking some bits here and there until I got it centered properly.

    Then my dad asked me to print boxes for a game that had slightly larger tiles, so I needed to tweak the sizes, the thickness, and made everything just a bit more configurable.

    I've got another idea I haven't tried yet: print the shape of the track on the tile on the spot its meant for. That's a whole new feature and not merely tweaking an existing one, so maybe it's time to finally learn how this format actually works.

    Although I did see in the code that you create shapes through intersections and substractions with other shapes. And that's where I got stuck. Maybe it's time to pick it up again. It's a fun way of building shapes.

  • dvh 11 hours ago

    I rage-quited every other CAD program. Then I found OpenSCAD. Now I'm looking forward to work in it every time I need to do some 3d modeling (usually new part model for kicad or some other project).

  • Ccecil 13 hours ago

    If you are a programmer OpenSCAD is likely for you. It certainly has benefits in things that are repeating patterns (gears and such)...and if your mind is good at visualizing things in "code" things will likely go a lot faster.

    I personally do better with CAD software such as fusion or freecad since my mind doesn't work in the code realm since I have more of a hardware mindset. Translating the picture in my head to code is more difficult than drawing it using the standard CAD set of tools.

    My opinion on OpenSCAD is that it is a very useful piece of software which many have used to make some very interesting things. If you have a background in code I recommend giving it a go. I largely view it as "the coder's CAD".

    • shmeeed 11 hours ago

      I was just about to say the same: OpenSCAD is CAD for programmers. It's very different from what's generally considered "CAD".

      That's not necessarily a bad thing; there's a clientele for it, especially here on HN. But as a mechanical engineer who's used quite a few industry standard CAD systems, I'm sorry to say I wouldn't touch it with a ten foot pole.

      Funnily, just a few days ago I tried FreeCAD, and found it to be better than I had expected.

      • Ccecil 7 hours ago

        I switched from Fusion to Freecad just before the 1.0 update.

        Freecad 1.0 is a gamechanger IMHO. It so far has suited all my needs as well as being significantly easier to use than the pre 1.0 versions.

      • ThrowawayTestr 10 hours ago

        FreeCAD feels like blender before the UI revamp. I can tell it's powerful but the UI is opaque to me.

  • arjie 11 hours ago

    Oh I had no idea that OpenSCAD was a programmatic toolkit. I recently bought a 3D printer and I don't model so much as describe to Claude Code how to write a Python script that will generate the required STL that I then rescale or whatever in Bambu Studio. LLMs are great at code-oriented stuff so I've stayed away from traditional modeling tools because I assumed you'd have to point and click and so on and I don't really want to learn the ins and outs of their interface. I just need the right mesh made.

    The chatbots kept recommending I try using OpenSCAD but I resisted without even giving it a look. The results I had with just the Python script are quite adequate for the tasks I had. You can just ask the LLM to add a fillet to a vertical pin on a plane or to chamfer some edge and it is pretty good at doing it.

    https://wiki.roshangeorge.dev/w/Blog/2025-12-01/Grounding_Yo... if you want to roughly see the workflow.

    I'm going to try using OpenSCAD for things in the future. Does anyone else use exclusively an LLM with OpenSCAD (I used Claude Code and Codex) and if you do what did you do to make it more effective? The Python script wouldn't always generate printable meshes so I had to give it a check script to operate on.

    • ThrowawayTestr 10 hours ago

      Fusion 360 is free for hobbyists and it's not too hard to learn for basic stuff

      • avmich 5 hours ago

        Is it online only? I in general prefer locally installed software, without Internet requirements.

      • arjie 10 hours ago

        Maybe I should suck it up and just give it a crack. Thank you for the recommendation.

  • khufiya 13 hours ago

    I've been experimenting with using Claude Code and the Gemini CLI to generate OpenSCAD with the renderer in the loop.

    https://github.com/rahulgarg123/openscad-mcp

    It’s still strictly worse than what these models are capable of for general-purpose coding, but for simple tasks where precision isn't the bottleneck, it's surprisingly decent.The "aha" moment for me was an image-to-object workflow: found a geometric design on the web --> generated OpenSCAD to match the image --> 3D printed it. Going from seeing a JPEG to holding the physical object in a few hours.

  • JonathanRaines 13 hours ago

    Also check out CADQuery and or build123d (python equivalents)

    • alhirzel 10 hours ago

      +1 for CADQuery - it lets you easily specify surfaces as the basis for manipulation, and results in much less fragile designs than OpenSCAD.

  • bradfitz 14 hours ago

    I find myself using OpenSCAD regularly to 3D print little things for the house. (Most recently: hooks to attach Christmas lights to our roof deck's glass walls)

    And when something gets too trick, ChatGPT is amazing at writing in it. Often it nails the whole design in the first try, like https://bsky.app/profile/bradfitz.com/post/3maelwomyw22n to mask off certain Raspberry Pi pins to make reassembly of projects easier later.

  • haberman 10 hours ago

    A long time ago I read that CadQuery has a fundamentally more powerful geometry kernel than OpenSCAD, so I dropped any attempt to try OpenSCAD.

    Years later, I never actually got the hang of CadQuery, and I'm wondering if it was a mistake to write off OpenSCAD.

    I am pretty new to CAD, so I don't actually know when I would run into OpenSCAD's limitations.

    • WillAdams 10 hours ago

      The notable limitations for OpenSCAD are:

      - functional programming model --- some folks find not having traditionally mutable variables limiting

      - output is as an STL, or DXF using polylines

      - native objects are spheres, cylinders, cubes, with functions for hull and Minkowski, so filleting and other traditional CAD operations can be difficult

  • jacquesm 11 hours ago

    It is amazing. I spend more time in OpenSCAD than in any other program I use and I'm amazingly productive with it. 3 to 4 cycles / day, the longest time is waiting for the printer to cough up the next iteration, then it is building debugging and improving again.

    The power of parametric cad is such that I wouldn't be a 10th as productive using an interactive cad system. And because it is effectively software you are writing (even if it compiles into physical objects) you can use all of the goodies that you can use to manage software. Diff files, git, kompare, branching, merging. It is nothing short of amazing, it is like I have a design team and a prototype injection molding facility in one. And the turnaround time is something you'd have killed for in the 90's.

    • echoangle 11 hours ago

      > The power of parametric cad is such that I wouldn't be a 10th as productive using an interactive cad system.

      This sounds like parametric and interactive CAD are polar opposites. Normal CAD software is generally parametric too.

      The other points about the advantage of text files still applies though.

      • jacquesm 11 hours ago

        'Normal' cad software is parametric in an entirely different sense. You don't normally build up from entities just like you would in software, which you can then manipulate symbolically.

        There are cad packages that can do this but unlike OpenSCAD the main interaction there is the 3D window, not the text editor.

        Though AutoCAD of course had this with AutoLISP since 1986.

        Interestingly, I'm not sure which has the steeper learning curve, OpenSCAD or AutoLISP. OpenSCAD is really great once it clicks but most people give up long before then.

        • jazzyjackson 10 hours ago

          Iirc autolisp applies to 2D drawings, so it's not a competitor for generating meshes

          Mathematica however is Lispy enough and has a lot of helpful geometry primatives and can export STL

        • avmich 5 hours ago

          Interesting to read that. I don't remember any learning barrier for OpenSCAD, while FreeCAD and Rhino3D took many days before I had to put it down. I guess people differ...

  • yehoshuapw 14 hours ago

    worth also looking at cadquery, build123d and similar

    https://github.com/gumyr/build123d

  • Robdel12 14 hours ago

    OpenSCAD has become my go to with my 3-D printer for dumb little things. And the best part is LLMs are getting decent / pretty good with it!

    My favorite thing I’ve printed is a little downsize coupler for the cool shirt system I built for my spec miata. It’s realllly silly & small thing, but it saved me!

  • fcpk 13 hours ago

    openscad is quite nifty for small geometric projects. unfortunately it lacks some Features that make most bigger cad programs really useful... for example: - the ability to select faces/paths from a render, which can be hugely helpful when modifying complex models. - the ability to do constrained sketching in both 2d and 3d - caching at intermediate render levels - nested Projects and joining parts with mechanical constraints. it's still pretty nifty but very niche. I personally would dream of having the tools of a tool like fusion 360 or Catia, but in a gilly textual progemmatic way, while keeping the ability to select objects from the rendrr view.

    • coryrc 12 hours ago

      It does have caching, but you are otherwise correct. I would also add that it can't do arcs; any curve is discretized immediately upon creation.

  • rcpt 13 hours ago

    I haven't tried the latest models but for at least a year LLMs have been mostly able to generate openscad to match my descriptions.

    It's neat that I can tell the computer what I want in words and then have that object come out of the 3D printer

  • VerifiedReports an hour ago

    Anything that helps people shun Autodesk's despicable, anti-customer and anti-industry practices is laudable.

  • lorenzohess 9 hours ago

    That let() {} expression seems pretty similar to the LISP let()() form: https://lisp-lang.org/learn/variables

  • zihotki 12 hours ago

    Mind you, it can't export to step file. That makes it impossible to re-use the models in other CADs to make assimblies. Also it's tedious to use for 3d printing when you want to include modifier objects with your model. Otherwise it's great and good enough for part modeling

  • timonoko 13 hours ago

    I have solved the only problem OpenSCAD ever had and that is

      total lack of interactivity.
    
    https://youtu.be/eG5lhLYvihQ?si=ehet5COZhiNrcK9b
    • timonoko 13 hours ago

      Now they say newest version of OpenSCAD has this functionality builtin. It took only a year.

      • xixixao 12 hours ago

        This is important and should be a given. But the more interesting challenge is to highlight the object you’re editing (where your cursor is). It’s not clear even how to exactly visualize it (it could be inside subtract of union of subtract etc).

        • timonoko 12 hours ago

          It moves or grows or whatever. What other indication you want?

          I have not yet invented any other improvement.

          I tried decimal points, but that was stupid, you just add "/100" if you want micrometer accuracy.

  • gunalx 10 hours ago

    Once had a complex model that would fully crash and lockup fusion, but once redone in openscad rendered after a little while. (badly designed + slow pc at tye time)

  • ifndbdb 12 hours ago

    The OpenSCAD kernel is significantly overrated in my opinion. Many operations take ages to compute or are not possible at all

    Ok if you want to generate a couple of cubes, but if you want anything advanced the kernel quickly falls apart

    • coryrc 12 hours ago

      It's switched to a new backend https://github.com/elalish/manifold

      Which you can also use directly instead by writing C++. Trivial operations are two orders of magnitude faster and complex ones every faster.

    • timonoko 12 hours ago

      The openscad-nightly is lightning-fast, but makes occasional occlusion errors.

      Assuming you make all the necessary adjustements in preferences.

  • rcarmo 8 hours ago

    I’ve been using it for almost a decade and I still miss proper fillets and chamfers (and yes, I know the usual tricks).

  • bilsbie 12 hours ago

    FYI I’ve had really surprising success using AI to generate openscad code.

    And even if it’s not perfect it saves a lot of time looking up the documentation and generally gets the relationships between objects right.

  • jasonthorsness 14 hours ago

    OpenSCAD is great! I used it to create a bunch of things to cut on a CNC router over the years. Best achievements were a scale model of Mount Rainier and some one-piece picture frames with text cut into them.

  • ai-christianson 14 hours ago

    Is OpenSCAD still being maintained?

    • floating-io 14 hours ago

      Yes. The "official release" is just so old as to be useless at this point. They should either update it or take it down and point people at github or something, IMO.

      I use the latest version all the time. The newer renderer ("manifold", IIRC) is much faster, and there are newer facilities that make it possible to build 3MF files containing multiple objects for multi-color printing, though that takes a bit of thought to do correctly.

      • MattRix 14 hours ago

        Yes everything this person said is correct. The Manifold backend is no joke, probably 100x faster.

        To do multi-color printing it’s pretty easy now, just turn on the poorly named feature in preferences called “lazy-unions”. This will make it so that each top level object in your file gets exported as a separate subobject in the 3mf file.

    • crazysim 14 hours ago

      Apparently the nightlies are the one to use. At least, they build it for Apple Silicon in those.

    • c0nsumer 14 hours ago

      The last release was 2021.01 but the GitHub repo seems to be recently updated. So I'd say... Maybe?

      That said, there are often times software gets so stable that not having a new release for years is fine. Maybe this is one of them?

      (I'm very new to OpenSCAD so I haven't run into bugs yet... But maybe it's pretty solid?)

    • MattRix 14 hours ago

      Yes, but the main downloads on the site are very old for some reason. Just get the nightly version instead, and then in Preferences -> Advanced -> Backend change it to “Manifold”. It will make your models “render” 10x faster (or more!).

      • bdcravens 14 hours ago

        I believe that's the default now (at least in the latest MacOS nightly)

        • coryrc 12 hours ago

          It is for all nightly builds, starting in the last few months.

    • aeonik 14 hours ago
  • convolvatron 14 hours ago

    I love the model, it's nice to be able to generate things parametrically instead of grabbing knots with the mouse. so I use scad pretty often.

    but it has real problems - the language is weird and unfortunate. not anything super fatal, just the obvious product of evolution that would be more cohesive if it were architected wholesale

      epsilons are really unfortunate. you have to expect that after getting what you want in the whole, you're going to have to scan over the whole thing and look for cracks or collision where there shouldn't be 
    
      performance is quite sad. here you are happy going back and forth between the view and text windows, but as you go on, it starts taking .. minutes.. to update the view once you have a reasonably complicated geometry
    
      high-level operators would also be nice. I made the mistake of using a thread library once, not only did that make my model unrenderable, there was so much noise in the model and the manufacturing process I had to make 3 expensive test prints in sintered nylon to get the fit right. (I'm thinking an annotation on a cylinder that says 'standard 1mm thread')
    • WillAdams 13 hours ago

      If you're inclined to use Python there is:

      https://pythonscad.org/

    • MattRix 14 hours ago

      It actually renders things incredibly fast if you get the nightly version and set the backend to Manifold. It is probably 100x faster (!!). In fact it renders so fast that I put a render() command at the top of my hierarchy so that everything just renders all the time, it’s faster and more performant. I make incredibly complex models with it too, with hundreds of holes, complex svg files with text in them, etc.

      • coryrc 12 hours ago

        Why not just press F6 instead?

        • MattRix 2 hours ago

          It does it every time I save the file instead, basically the regular openscad workflow of update-on-save, but instead of doing a preview it’s just full rendering all the time.

  • seamossfet 12 hours ago

    How does this compare to something like Zoo?

  • constantcrying 14 hours ago

    OpenSCAD is very cool, but completely unusable once you understand how great state of the art CAD Software like Fusion or Onshape is.

    The big distinction is that those work implicitly, while OpenSCAD requires you to be implicit.

    • culi 13 hours ago

      I'm a programmer. I once had an idea stuck in my head for a 3d model that I just needed to get down somewhere. I tried learning the basics of AutoCAD but after 2 days of tutorials I still felt overwhelmed.

      I looked into alternatives and learned about OpenSCAD. The immediate visual feedback makes picking up the language a breeze. Within an hour of downloading I familiarized myself with the language and had manifested my idea into a 3d model

      I think that's a perfect example of a use-case where OpenSCAD shines. It's extremely easy to pick up if you have programming experience and it might even be a good thing to learn before moving onto more professional CAD software. From a teaching perspective, being able to have almost immediately-useful output is priceless

      • WillAdams 12 hours ago

        The BlockSCAD folks are hoeing that row quite effectively to my mind:

        https://www.blockscad3d.com/editor/

        I just wish that they'd add the balance of the language/fix some bugs.

      • constantcrying 10 hours ago

        I think that modern CAD software, like Onshape or Fusion 360 is quite easy to learn. I have no doubt that AutoCAD is difficult to grasp, but it is not a good representative of what is possible.

        >It's extremely easy to pick up if you have programming experience and it might even be a good thing to learn before moving onto more professional CAD software.

        No, it definitely is not. OpenSCAD makes you think exactly the wrong way about CAD, because it forces you to reason explicitly about your model, when that is something which you need to let the CAD Software do for you. Modern Parametric CAD works by the user defining constraints, which the Software uses to derive the shape of the model, this is not something which conceptually exists in OpenSCAD.

        >From a teaching perspective, being able to have almost immediately-useful output is priceless

        Which is something which modern CAD does just as well.

    • WillAdams 13 hours ago

      The thing is, I've crashed-and-burned every time I've tried to do traditional 3D CAD --- the closest I've come to success was making it all the way through the tutorial for Dune 3D:

      https://news.ycombinator.com/item?id=37979758

      https://news.ycombinator.com/item?id=40228068

      OpenSCAD "just works", even on quite limited hardware, and if one has trouble modeling something, well, arriving at a solution is just a matter of learning the appropriate mathematics.

      • kiba 8 hours ago

        The way I learned CAD is the same way I approach programming projects. I tackle simple, bite size projects, which then increase in complexity until I have the skills necessary to tackle big complicated projects.

        I found that standard CAD to be no simpler than OpenSCAD. Really, the biggest disadvantages that OpenSCAD have is usability and a library which is fixed by using BOLS2.

        BOLS2 has the same problem as standard CAD, it is overwhelmingly big. In some cases, I didn't know features were already in BOLS2 so I don't have to reinvent the wheel writing my own inferior library.

        So, how to tackle it? Same thing as any learning projects. I just tackle it in bite size chunk.

      • constantcrying 10 hours ago

        To be honest, I found Fusion 360 and Onshape very intuitive to learn.

        >and if one has trouble modeling something, well, arriving at a solution is just a matter of learning the appropriate mathematics.

        Which is the terrible thing about OpenSCAD. YOU need to derive the equations. In a modern CAD program you define the constraints on the object and the equations are derived for you.

    • d_silin 13 hours ago

      excplicitely, you mean?

  • exasperaited 10 hours ago

    Neat-ish.

    I don't really see why that code is better, more logical, more readable or more robust than the equivalent quite trivial parametrics in more or less any GUI CAD program, and I think the geek discourse is really harmed by people who don't understand the value of the things that OpenSCAD can't ever offer.

    • avmich 5 hours ago

      I wonder what kind of things OpenSCAD can't ever offer... It's pretty automatable.

  • ur-whale 4 hours ago

    OpenSCAD is great, and I use it all the time.Especially these days if you combine it with an LLM agent like codex and start vibe coding objects (see my other post on this).

    However, there are a number of limitations that are truly and deeply frustrating.

    1. The language is downright weird. Don't get me wrong, it's a very nice little exercise in implementing a functional-tasting scripting language. Someone obviously wanted to scratch a functional DSL design itch and he did, but the result is unfortunately extremely limiting. Creating a function that does not return geometry is barely possible (only bloody lambdas IIRC). He should have picked python instead (and yes, I know about SolidPython2)

    2. From my POV: the main headache with OpenSCAD is there is no way to partially evaluate an object and use the result of that partial evaluation in the rest of the construction. For example, if you try to take two complex assemblies and place them tangent to one another ... very good luck to you sir, I pray and hope the 3D math is really strong with you.

    Whereas: if you had a simple rayIntersect(csg_tree, line_in_3d_spce) that would return the first intersection and two normals ... something you can reuse in subsequent transforms and construction, man would life be simpler.

    These days, with LLMs you can sort of build a scaffolding to work around this by asking the agent to break down the assembly in multiple stages and use external libraries to do the partial eval for you, but ... ugh ... what a mess.

    3. Speed. The moment your CSG assembly gets complex (e.g. uses a ton of morpho ... hull, minkowski, etc...), OpenSCAD crawls to a halt.

    4. NO FILLETS. The age-old, standard methodology of building things CSG style with cubes, spheres, cylinders, etc ... and then once the object is finished adding the rounding ... simply not possible with OpenSCAD. Adding fillets after the fact once you've built a complex CSG tree ... nightmare with OpenSCAD.

    So, YMMV, but caveat emptor, if you get serious with the toole, you're bound to hit some very hard walls.

  • ur-whale 4 hours ago

    OpenSCAD is kinda of neat, especially if you pair it with something like codex to build objects.

    And then, you discover that those darn LLMs have absolutely no spatial intuition. None.

    It is seriously frustrating: one the one hand you can just feel the raw potential of vibe coding complex geometries, and on the other, when you do, you keep seeing the agent making mistakes a 5 year old playing lego would never make.

    Absolutely infuriating.