#ifndef BEST_FIT_H #define BEST_FIT_H // This routine was released in 'snippet' form // by John W. Ratcliff mailto:jratcliffscarab@gmail.com // on March 22, 2006. // // This routine computes the 'best fit' plane equation to // a set of input data points with an optional per vertex // weighting component. // // The implementation for this was lifted directly from // David Eberly's Magic Software implementation. // computes the best fit plane to a collection of data points. // returns the plane equation as A,B,C,D format. (Ax+By+Cz+D) // // Geometric Tools, Inc. // http://www.geometrictools.com // Copyright (c) 1998-2006. All Rights Reserved // // The Wild Magic Library (WM3) source code is supplied under the terms of // the license agreement // http://www.geometrictools.com/License/WildMagic3License.pdf // and may not be copied or disclosed except in accordance with the terms // of that agreement. /*! ** ** Copyright (c) 2007 by John W. Ratcliff mailto:jratcliffscarab@gmail.com ** ** Portions of this source has been released with the PhysXViewer application, as well as ** Rocket, CreateDynamics, ODF, and as a number of sample code snippets. ** ** If you find this code useful or you are feeling particularily generous I would ** ask that you please go to http://www.amillionpixels.us and make a donation ** to Troy DeMolay. ** ** DeMolay is a youth group for young men between the ages of 12 and 21. ** It teaches strong moral principles, as well as leadership skills and ** public speaking. The donations page uses the 'pay for pixels' paradigm ** where, in this case, a pixel is only a single penny. Donations can be ** made for as small as $4 or as high as a $100 block. Each person who donates ** will get a link to their own site as well as acknowledgement on the ** donations blog located here http://www.amillionpixels.blogspot.com/ ** ** If you wish to contact me you can use the following methods: ** ** Skype Phone: 636-486-4040 (let it ring a long time while it goes through switches) ** Skype ID: jratcliff63367 ** Yahoo: jratcliff63367 ** AOL: jratcliff1961 ** email: jratcliffscarab@gmail.com ** Personal website: http://jratcliffscarab.blogspot.com ** Coding Website: http://codesuppository.blogspot.com ** FundRaising Blog: http://amillionpixels.blogspot.com ** Fundraising site: http://www.amillionpixels.us ** New Temple Site: http://newtemple.blogspot.com ** ** ** The MIT license: ** ** Permission is hereby granted, free of charge, to any person obtaining a copy ** of this software and associated documentation files (the "Software"), to deal ** in the Software without restriction, including without limitation the rights ** to use, copy, modify, merge, publish, distribute, sublicense, and/or sell ** copies of the Software, and to permit persons to whom the Software is furnished ** to do so, subject to the following conditions: ** ** The above copyright notice and this permission notice shall be included in all ** copies or substantial portions of the Software. ** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR ** IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, ** FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE ** AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, ** WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN ** CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ // A version that works with double precision floats. bool getBestFitPlane(unsigned int vcount, // number of input data points const double *points, // starting address of points array. unsigned int vstride, // stride between input points. const double *weights, // *optional point weighting values. unsigned int wstride, // weight stride for each vertex. double *plane); // A version that works with single precision floats. bool getBestFitPlane(unsigned int vcount, // number of input data points const float *points, // starting address of points array. unsigned int vstride, // stride between input points. const float *weights, // *optional point weighting values. unsigned int wstride, // weight stride for each vertex. float *plane); #endif