<div dir="ltr">On Tue, Nov 10, 2015 at 8:20 PM, Clifford Yapp &lt;<a href="mailto:cliffyapp@gmail.com">cliffyapp@gmail.com</a>&gt; wrote:<br>&gt; <a href="http://dev.opencascade.org/index.php?q=node/1091">http://dev.opencascade.org/index.php?q=node/1091</a><br>&gt; <a href="http://dev.opencascade.org/index.php?q=node/1056">http://dev.opencascade.org/index.php?q=node/1056</a><br>&gt;<br>&gt; Do those improvements sound like they might address enough of the<br>&gt; problems you found with OpenCASCADE to make it more interesting?<br><br>License situation improvement has been good news. I am negative on long-term maintainability of the source code, the low quality of source code, and the lack of tests is unfortunate and makes developing much more difficult. OCE cleans up a few things but by my estimate only a small small tiny slice of the whole pie. Some of this seems even beyond the territory of refactoring; way more progress can be made starting from higher-quality source code.<br><br>&gt; I&#39;m somewhat surprised to see verbnurbs is in javascript - how does<br>&gt; that perform compared to C/C++ for this application?  Could it be<br>&gt; translated to C++, perhaps in combination with OpenNURBS?<br><br>verbnurbs is written in haxe, which is apparently a tool that can generate C++ from haxe source code input:<br><a href="http://haxe.org/">http://haxe.org/</a><br><br>OpenNURBS integration is doable if you compile to C++ first, but I suspect there would be minimal benefit to be had by doing so. A few years ago I was doing a (private/unreleased) rewrite of OpenNURBS in python because why not, and I found that most of it is somewhat trivial, especially since Rhino didn&#39;t release the intersection functions. So if you find some value in the OpenNURBS library that is missing from verbnurbs, I would recommend porting the features into verbnurbs directly. Alternative implementations of the surface-surface intersection methods have been written by the BRL-CAD crew, although I have not looked at whether that work is completely redundant with verbnurb&#39;s implementation of surface-surface intersection.... this would be a good thing to know, check and figure out.<br><br>On Wed, Nov 11, 2015 at 12:43 PM, Nancy Ouyang &lt;<a href="mailto:nancy.ouyang@gmail.com">nancy.ouyang@gmail.com</a>&gt; wrote:<br>&gt; I don&#39;t follow that in 3D things are more amenable to programmatic design.<br>&gt; It&#39;s certainly possible, but I don&#39;t feel that not having a GUI should be a<br>&gt; goal.<br><br>Well, when I think about these problems, I approach them from a separation-of-concerns angle, that is to say that the GUI implementation should be independent of the CAD kernel. The GUI implementation is somewhat harder to write if you do not have a specification for the data types, input and output of the CAD engine. So usually when it seems like I am deprioritizing GUI, that&#39;s usually because I figure that scripting and APIs and SDKs are faster to implement on top of the same imaginary CAD kernel that the GUI would then be written against.<br><br>On Wed, Nov 11, 2015 at 1:46 PM, John Griessen &lt;<a href="mailto:john@industromatic.com">john@industromatic.com</a>&gt; wrote:<br>&gt; OpenSCAD is nice for mathematical shapes, but try to make a mold for plastic<br>&gt; with draft angles<br>&gt; and rounded corners everywhere...  That&#39;s  a simple set of rules to apply,<br>&gt; yet wold go nutty<br>&gt; trying to code generate and position it all.<br><br>I wonder how much of that is an API problem. I suspect you would have the same difficulties in current versions of cadquery, freecad python, or pythonocc. &quot;If the API doesn&#39;t help you reach your goals in a simple and easy manner, then that&#39;s a bug.&quot;<br><br>On Thu, Nov 12, 2015 at 3:07 PM, Matt Carney &lt;<a href="mailto:mcarney@media.mit.edu">mcarney@media.mit.edu</a>&gt; wrote:<br>&gt; Though I still don&#39;t see anything of sufficient detail or complexity<br><br>Yeah I admit those weren&#39;t great examples. I have often considered using one of these scripting languages to show off and make a giant mecha robot or gundam mobile suit with reasonable technological resolution beyond simply &quot;here are some boxes intersecting each other to resemble the popularized image&quot;. The point would be to dump some time into a group where the participants are working, perhaps modularly, on open-source CAD scripting a moderately complex mechanical or mechatronic project.<br><br>On Fri, Nov 20, 2015 at 3:28 PM, Jeremy Wright &lt;<a href="mailto:wrightjmf@gmail.com">wrightjmf@gmail.com</a>&gt; wrote:<br>&gt; This is something we&#39;ve discussed doing with CadQuery. The CadQuery script<br>&gt; would basically be the file format, but you could use mouse interaction in<br>&gt; the GUI exclusively if you wanted to. This model adds other challenges<br>&gt; though as autogeneration and manipulation of code can get messy/complex.<br><br>One way to do this would be an interactive interpreter or REPL for the source code, and then the GUI responds to keypresses (like tabs) to highlight possibilities. Thomas Paviot did some videos of how this works with pythonocc and ipython:<br><a href="https://www.youtube.com/watch?v=mnQ1IqfjsCs">https://www.youtube.com/watch?v=mnQ1IqfjsCs</a><br><br>Perhaps non-coding input would just be stored as an additional STEP file, which would then be imported into the script mode, to avoid auto-generated code bloat. &quot;Then the magic happens&quot; can be hidden away.<br><br>&gt; From what I&#39;m hearing, it seems like the issue might be with the quality and<br>&gt; maintainability of the OpenCASCADE codebase, which seems to be addressed a<br><br>Correct. But that&#39;s just my assessment, don&#39;t let me stop you from looking:<br><a href="http://diyhpl.us/wiki/cad/opencascade/">http://diyhpl.us/wiki/cad/opencascade/</a><br><br>&gt; little bit in the first link. I wonder how long it will take those changes<br>&gt; to make it into OpenCASCADE Community Edition<br>&gt; (<a href="https://github.com/tpaviot/oce">https://github.com/tpaviot/oce</a>).<br><br>Not long. Months at most.<br><br>&gt; This is something that Mach 30 is experimenting with now. We have scripted<br>&gt; unit tests (done in CadQuery) to verify geometry automatically.<br><br>Could you link to some of those files please?<br><br>- Bryan<br><a href="http://heybryan.org/">http://heybryan.org/</a><div>1 512-203-0507</div></div>