<html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"></head><body dir="auto"><div>Hi Lin,</div><div><br></div><div>There are a couple things to do to prepare for the operations</div><div><br></div><div>1. Besides handling a square patch (where parametric coordinates are bounded by a d-dimensional rectangle), it would be useful to support a simplicial patch using barycentric coordinates (i.e., (r,s,t) in [0,R]x<span style="background-color: rgba(255, 255, 255, 0);"> [0,S]x [0,T] subject to r+s+t <= 1, r >= 0, s >= 0, t >= 0). This can be used to create sets of patches that cover parametric domains of any polyhedral shape, not possible when using only square patches without introducing singularities. We will use this in the contouring algorithm. See </span><a href="https://en.wikipedia.org/wiki/B%C3%A9zier_triangle">https://en.wikipedia.org/wiki/B%C3%A9zier_triangle</a></div><div><br></div><div>2. While you've implemented interpolation, there is also point inversion: determining the parametric coordinates (r,s,t) nearest a given point in world coordinates (x,y,z). The NURBS Book covers this on p. 229. We must use this when cutting (to find where, if anywhere, a patch intersects a cutting surface) and contouring (to find parametric coordinates where a patch takes on a particular scalar value).</div><div><br></div><div> David<br><br><br></div><div><br>On Jul 21, 2015, at 22:01, Lin M <<a href="mailto:majcjc@gmail.com">majcjc@gmail.com</a>> wrote:<br><br></div><blockquote type="cite"><div><div dir="ltr">Hi Dr. Thompson,<div><br></div><div>Besides loading external NURBS files, what's the next thing to do? Based on our proposal, we should work on implementing the operation algorithms now. Where do you think I can start with?</div><div><br></div><div>Best,</div><div>Lin</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Jul 8, 2015 at 5:06 PM, David Thompson <span dir="ltr"><<a href="mailto:david.thompson@kitware.com" target="_blank">david.thompson@kitware.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi Lin,<br>
<span class=""><br>
> I read the document for BRep format and checked those files in CGM/test. It seems that only a small part of the test files contains bezier/b-spline surfaces and all these files contains quite a number of different kinds of shapes. I can write a class to read such file but it will only display the bezier/b-spline part. I'm afraid that it will just be a piece of the original shape which the file represents. Do you think I should do that or there is a better way to load external shape?<br>
<br>
</span>I think it would be great to start with the parts of the CGM files that are NURBS. The remaining shapes should either be straight (lines, planes) or conics (for which you have written a few routines we can use to create patches that will represent them properly).<br>
<br>
> PS. I opened a new google doc to summarize what we have done now. I will update new progress to it during the development. (link)<br>
<br>
Great!<br>
<span class="HOEnZb"><font color="#888888"><br>
David<br>
<br>
<br>
</font></span></blockquote></div><br></div>
</div></blockquote></body></html>