2 *  This program is free software: you can redistribute it and/or modify
 
    3 *  it under the terms of the GNU Lesser General Public License as
 
    4 *  published by the Free Software Foundation, either version 3 of the
 
    5 *  License, or  (at your option) any later version.
 
    7 *  This program is distributed in the hope that it will be useful,
 
    8 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 
    9 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
   10 *  GNU General Public License for more details.
 
   12 *  You should have received a copy of the GNU General Public License
 
   13 *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
   19 * @author Kacper Pluta (\c kacper.pluta@esiee.fr )
 
   20 * Laboratoire d'Informatique Gaspard-Monge - LIGM, A3SI, France
 
   24 * Implementation of inline methods defined in Knot_5_1.h
 
   26 * This file is part of the DGtal library.
 
   29///////////////////////////////////////////////////////////////////////////////
 
   30// IMPLEMENTATION of inline methods.
 
   31///////////////////////////////////////////////////////////////////////////////
 
   33//////////////////////////////////////////////////////////////////////////////
 
   34//////////////////////////////////////////////////////////////////////////////
 
   38///////////////////////////////////////////////////////////////////////////////
 
   39// Implementation of inline methods                                          //
 
   43DGtal::Knot_5_1<T>::Knot_5_1 ( long double scale_1, long double scale_2, long double scale_3 ) : scale {scale_1, scale_2, scale_3}
 
   48typename DGtal::Knot_5_1<T>::RealPoint DGtal::Knot_5_1<T>::x ( const long double t ) const
 
   51           scale[0] * 1. / 5. * ( std::pow ( t, 5 ) - 36. * std::pow ( t, 3 ) + 260. * t),
 
   52           scale[1] * 1. / 2. * ( std::pow ( t, 4 ) - 24. * t * t ),
 
   53           scale[2] * 1. / 100. * ( std::pow ( t, 7 ) - 31. * std::pow ( t, 5 ) + 164. * std::pow ( t, 3 ) + 560. * t )
 
   59typename DGtal::Knot_5_1<T>::RealPoint DGtal::Knot_5_1<T>::xp ( const long double t ) const
 
   62            scale[0] * ( 52. - ( 108. * t *t ) / 5. + std::pow ( t, 4 ) ), scale[1] * 2. * t * ( -12. + t * t ),
 
   63            scale[2] * 1. / 100. * ( 560. + 492. * t * t -155. * std::pow ( t, 4 ) + 7. * std::pow ( t, 6 ) ) );
 
   69void DGtal::Knot_5_1<T>::selfDisplay ( std::ostream & out ) const
 
   74///////////////////////////////////////////////////////////////////////////////
 
   75// Implementation of inline functions and external operators                 //
 
   78 * Overloads 'operator<<' for displaying objects of class 'Knot_5_1'.
 
   79 * @param out the output stream where the object is written.
 
   80 * @param object the object of class 'Knot_5_1' to write.
 
   81 * @return the output stream after the writing.
 
   86DGtal::operator<< ( std::ostream & out, const Knot_5_1<T> & object )
 
   88    object.selfDisplay ( out );
 
   93///////////////////////////////////////////////////////////////////////////////